diff --git a/docs/kiosk.html b/docs/kiosk.html index 2b4cda0e74d..ed8b5825f35 100644 --- a/docs/kiosk.html +++ b/docs/kiosk.html @@ -23,7 +23,7 @@ Learn how to configure a non-root public URL by running `npm run build`. --> MakeCode Arcade Kiosk - + diff --git a/docs/static/kiosk/asset-manifest.json b/docs/static/kiosk/asset-manifest.json index 3bb42c36fa9..5e8335446bc 100644 --- a/docs/static/kiosk/asset-manifest.json +++ b/docs/static/kiosk/asset-manifest.json @@ -1,15 +1,15 @@ { "files": { "main.css": "/static/kiosk/static/css/main.5f8c7aeb.css", - "main.js": "/static/kiosk/static/js/main.0d14f3d0.js", + "main.js": "/static/kiosk/static/js/main.b5a9c480.js", "static/js/787.709d397d.chunk.js": "/static/kiosk/static/js/787.709d397d.chunk.js", "index.html": "/static/kiosk/index.html", "main.5f8c7aeb.css.map": "/static/kiosk/static/css/main.5f8c7aeb.css.map", - "main.0d14f3d0.js.map": "/static/kiosk/static/js/main.0d14f3d0.js.map", + "main.b5a9c480.js.map": "/static/kiosk/static/js/main.b5a9c480.js.map", "787.709d397d.chunk.js.map": "/static/kiosk/static/js/787.709d397d.chunk.js.map" }, "entrypoints": [ "static/css/main.5f8c7aeb.css", - "static/js/main.0d14f3d0.js" + "static/js/main.b5a9c480.js" ] } \ No newline at end of file diff --git a/docs/static/kiosk/static/js/main.0d14f3d0.js.map b/docs/static/kiosk/static/js/main.0d14f3d0.js.map deleted file mode 100644 index 5ed465062e2..00000000000 --- a/docs/static/kiosk/static/js/main.0d14f3d0.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"static/js/main.0d14f3d0.js","mappings":"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K,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAAK,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAChCI,WAAWJ,KAA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,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,KAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,KAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,KAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,KAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MAAS,MACnG,IAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,MAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,MAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,MAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OAAS,OACnG,OAAS,OAAS,SAKtBo4D,GAAaQ,eAAiBx4D,WAAWJ,KAAK,CAC1C,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,KAC3G,IAAK,IAAK,KAAM,IAAK,KAAM,IAAK,KAAM,IAAK,IAAK,IAAK,KAAM,KAAM,IAAK,IAAK,IAAK,KAAM,IAAK,KAAM,IAAK,KAAM,IAC5G,IAAK,IAAK,IAAK,KAAM,IAAK,IAAK,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACvG,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAK,IAAK,IAAK,IAAK,IAAK,KAAM,IAAK,IAC5G,KAAM,IAAK,IAAK,IAAK,KAAM,IAAK,KAAM,IAAK,IAAK,IAAK,IAAK,KAAM,KAAM,IAAK,IAAK,KAAM,IAAK,KAAM,IAAK,KAAM,IAC5G,IAAK,IAAK,KAAM,IAAK,IAAK,KAAM,KAAM,KAAM,KAAM,IAAK,IAAK,KAAM,IAAK,KAAM,IAAK,KAAM,KAAM,IAAK,IAAK,IAAK,IAC7G,KAAM,IAAK,KAAM,IAAK,IAAK,IAAK,KAAM,KAAM,KAAM,KAAM,IAAK,KAAM,KAAM,KAAM,KAAM,KAAM,IAAK,IAAK,IAAK,IAC1G,KAAM,KAAM,KAAM,IAAK,IAAK,IAAK,IAAK,KAAM,IAAK,IAAK,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAK,IAAK,IAAK,IACzG,KAAM,IAAK,KAAM,IAAK,IAAK,IAAK,IAAK,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KACvG,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAC5G,IAAK,IAAK,IAAK,IAAK,KAAM,KAAM,IAAK,IAAK,IAAK,KAAM,IAAK,KAAM,IAAK,IAAK,IAAK,IAAK,KAAM,KAAM,IAAK,KAAM,IAC3G,KAAM,IAAK,KAAM,IAAK,IAAK,IAAK,KAAM,IAAK,IAAK,KAAM,KAAM,KAAM,KAAM,IAAK,KAAM,IAAK,KAAM,KAAM,IAAK,IACzG,KAAM,IAAK,KAAM,IAAK,IAAK,IAAK,KAAM,KAAM,KAAM,IAAK,KAAM,KAAM,IAAK,IAAK,KAAM,IAAK,KAAM,IAAK,KAAM,KACzG,KAAM,IAAK,IAAK,IAAK,KAAM,IAAK,KAAM,IAAK,KAAM,IAAK,IAAK,IAAK,KAAM,KAAM,KAAM,KAAM,KAAM,IAAK,KAAM,IACzG,KAAM,KAAM,KAAM,KAAM,KAAM,IAAK,KAAM,KAAM,IAAK,IAAK,IAAK,IAAK,KAAM,KAAM,KAAM,IAAK,IAAK,IAAK,KAAM,IAC1G,IAAK,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAK,IAAK,IAAK,KAAM,IAAK,KAAM,IAAK,IAAK,IAAK,IAAK,KAAM,KAAM,KACzG,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAK,IAAK,KAAM,IAAK,KAAM,IAAK,KAAM,IAAK,IAAK,IAAK,KAAM,IAAK,IAAK,KACzG,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAK,IAAK,IAC1G,IAAK,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAK,IAAK,IAAK,KAAM,IAAK,IAAK,KAAM,KAAM,KAC5G,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAC5G,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,IAAK,KA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","sources":["../node_modules/html5-qrcode/third_party/zxing-js.umd.js","../node_modules/react-dom/cjs/react-dom.production.min.js","../node_modules/react-dom/client.js","../node_modules/react-dom/index.js","../node_modules/react/cjs/react-jsx-runtime.production.min.js","../node_modules/react/cjs/react.production.min.js","../node_modules/react/index.js","../node_modules/react/jsx-runtime.js","../node_modules/scheduler/cjs/scheduler.production.min.js","../node_modules/scheduler/index.js","../node_modules/@babel/runtime/helpers/arrayLikeToArray.js","../node_modules/@babel/runtime/helpers/arrayWithHoles.js","../node_modules/@babel/runtime/helpers/assertThisInitialized.js","../node_modules/@babel/runtime/helpers/classCallCheck.js","../node_modules/@babel/runtime/helpers/createClass.js","../node_modules/@babel/runtime/helpers/createForOfIteratorHelper.js","../node_modules/@babel/runtime/helpers/createSuper.js","../node_modules/@babel/runtime/helpers/get.js","../node_modules/@babel/runtime/helpers/getPrototypeOf.js","../node_modules/@babel/runtime/helpers/inherits.js","../node_modules/@babel/runtime/helpers/isNativeReflectConstruct.js","../node_modules/@babel/runtime/helpers/iterableToArrayLimit.js","../node_modules/@babel/runtime/helpers/nonIterableRest.js","../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js","../node_modules/@babel/runtime/helpers/regeneratorRuntime.js","../node_modules/@babel/runtime/helpers/setPrototypeOf.js","../node_modules/@babel/runtime/helpers/slicedToArray.js","../node_modules/@babel/runtime/helpers/superPropBase.js","../node_modules/@babel/runtime/helpers/typeof.js","../node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js","../webpack/bootstrap","../webpack/runtime/define property getters","../webpack/runtime/ensure chunk","../webpack/runtime/get javascript chunk filename","../webpack/runtime/get mini-css chunk filename","../webpack/runtime/global","../webpack/runtime/hasOwnProperty shorthand","../webpack/runtime/load script","../webpack/runtime/make namespace object","../webpack/runtime/publicPath","../webpack/runtime/jsonp chunk loading","../node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","../node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","../node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/@babel/runtime/helpers/esm/objectSpread2.js","../node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/@babel/runtime/helpers/esm/regeneratorRuntime.js","../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js","../node_modules/@babel/runtime/helpers/esm/classCallCheck.js","../node_modules/@babel/runtime/helpers/esm/createClass.js","Models/KioskState.ts","Models/KeyboardManager.ts","Models/GamepadManager.ts","Models/HighScore.ts","Models/GameData.ts","BackendRequests.ts","browserUtils.ts","Models/Kiosk.ts","Components/AddGameButton.tsx","../node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../node_modules/ssr-window/ssr-window.esm.js","../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js","../node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/isNativeReflectConstruct.js","../node_modules/@babel/runtime/helpers/esm/construct.js","../node_modules/@babel/runtime/helpers/esm/wrapNativeSuper.js","../node_modules/@babel/runtime/helpers/esm/isNativeFunction.js","../node_modules/dom7/dom7.esm.js","../node_modules/@babel/runtime/helpers/esm/inherits.js","../node_modules/@babel/runtime/helpers/esm/createSuper.js","../node_modules/swiper/shared/dom.js","../node_modules/swiper/shared/get-support.js","../node_modules/swiper/shared/get-device.js","../node_modules/swiper/shared/get-browser.js","../node_modules/swiper/shared/utils.js","../node_modules/swiper/core/events-emitter.js","../node_modules/swiper/core/update/index.js","../node_modules/swiper/core/update/updateSize.js","../node_modules/swiper/core/update/updateSlides.js","../node_modules/swiper/core/update/updateAutoHeight.js","../node_modules/swiper/core/update/updateSlidesOffset.js","../node_modules/swiper/core/update/updateSlidesProgress.js","../node_modules/swiper/core/update/updateProgress.js","../node_modules/swiper/core/update/updateSlidesClasses.js","../node_modules/swiper/core/update/updateActiveIndex.js","../node_modules/swiper/core/update/updateClickedSlide.js","../node_modules/swiper/core/translate/index.js","../node_modules/swiper/core/translate/getTranslate.js","../node_modules/swiper/core/translate/setTranslate.js","../node_modules/swiper/core/translate/minTranslate.js","../node_modules/swiper/core/translate/maxTranslate.js","../node_modules/swiper/core/translate/translateTo.js","../node_modules/swiper/core/transition/transitionEmit.js","../node_modules/swiper/core/transition/index.js","../node_modules/swiper/core/transition/setTransition.js","../node_modules/swiper/core/transition/transitionStart.js","../node_modules/swiper/core/transition/transitionEnd.js","../node_modules/swiper/core/slide/index.js","../node_modules/swiper/core/slide/slideTo.js","../node_modules/swiper/core/slide/slideToLoop.js","../node_modules/swiper/core/slide/slideNext.js","../node_modules/swiper/core/slide/slidePrev.js","../node_modules/swiper/core/slide/slideReset.js","../node_modules/swiper/core/slide/slideToClosest.js","../node_modules/swiper/core/slide/slideToClickedSlide.js","../node_modules/swiper/core/loop/index.js","../node_modules/swiper/core/loop/loopCreate.js","../node_modules/swiper/core/loop/loopFix.js","../node_modules/swiper/core/loop/loopDestroy.js","../node_modules/swiper/core/events/onTouchStart.js","../node_modules/swiper/core/events/onTouchMove.js","../node_modules/swiper/core/events/onTouchEnd.js","../node_modules/swiper/core/events/onResize.js","../node_modules/swiper/core/events/onClick.js","../node_modules/swiper/core/events/onScroll.js","../node_modules/swiper/core/events/index.js","../node_modules/swiper/core/breakpoints/setBreakpoint.js","../node_modules/swiper/core/breakpoints/index.js","../node_modules/swiper/core/breakpoints/getBreakpoint.js","../node_modules/swiper/core/classes/index.js","../node_modules/swiper/core/classes/addClasses.js","../node_modules/swiper/core/classes/removeClasses.js","../node_modules/swiper/core/check-overflow/index.js","../node_modules/swiper/core/defaults.js","../node_modules/swiper/core/moduleExtendParams.js","../node_modules/swiper/core/core.js","../node_modules/swiper/core/grab-cursor/index.js","../node_modules/swiper/core/grab-cursor/setGrabCursor.js","../node_modules/swiper/core/grab-cursor/unsetGrabCursor.js","../node_modules/swiper/core/images/index.js","../node_modules/swiper/core/images/loadImage.js","../node_modules/swiper/core/images/preloadImages.js","../node_modules/swiper/core/modules/resize/resize.js","../node_modules/swiper/core/modules/observer/observer.js","../node_modules/swiper/modules/keyboard/keyboard.js","../node_modules/swiper/shared/classes-to-selector.js","../node_modules/swiper/modules/pagination/pagination.js","../node_modules/swiper/shared/create-element-if-not-defined.js","../node_modules/swiper/shared/create-shadow.js","../node_modules/swiper/shared/effect-target.js","../node_modules/swiper/modules/effect-coverflow/effect-coverflow.js","../node_modules/swiper/shared/effect-init.js","../node_modules/swiper/components-shared/utils.js","../node_modules/swiper/components-shared/params-list.js","../node_modules/swiper/shared/calc-looped-slides.js","../node_modules/swiper/react/get-children.js","../node_modules/swiper/components-shared/update-swiper.js","../node_modules/swiper/react/use-isomorphic-layout-effect.js","../node_modules/swiper/react/context.js","../node_modules/swiper/react/swiper.js","../node_modules/swiper/components-shared/get-params.js","../node_modules/swiper/components-shared/mount-swiper.js","../node_modules/swiper/components-shared/get-changed-params.js","../node_modules/swiper/components-shared/update-on-virtual-data.js","../node_modules/swiper/react/virtual.js","../node_modules/swiper/react/loop.js","../node_modules/swiper/react/swiper-slide.js","Components/DeleteButton.tsx","Components/HighScoresList.tsx","Components/GameSlide.tsx","Components/GameList.tsx","Components/DeletionModal.tsx","Components/MainMenu.tsx","Components/HighScoreInitial.tsx","Components/NewScoreEntry.tsx","Components/ExistingScoreEntry.tsx","Components/EnterHighScore.tsx","../node_modules/@babel/runtime/helpers/esm/createForOfIteratorHelper.js","../node_modules/qrcode.react/lib/esm/index.js","../../../src/core.ts","Components/KioskNotification.tsx","Components/AddingGame.tsx","../../../src/strings.ts","../../../src/state-manager.ts","../../../src/utils.ts","../../../src/zxing-html5-qrcode-decoder.ts","../../../src/native-bar-code-detector.ts","../../../src/code-decoder.ts","../../../src/experimental-features.ts","../../../src/html5-qrcode-scanner.ts","../../../src/html5-qrcode.ts","../../../src/image-assets.ts","../../../src/storage.ts","../../../src/ui.ts","../../../src/camera.ts","../../../../../src/ui/scanner/scan-type-selector.ts","../../../../../src/ui/scanner/torch-button.ts","Components/QrScanner.tsx","Components/ErrorModal.tsx","Components/ScanQR.tsx","Components/QrSuccess.tsx","Components/GameOver.tsx","App.tsx","reportWebVitals.ts","index.tsx"],"sourcesContent":["(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :\n typeof define === 'function' && define.amd ? define(['exports'], factory) :\n (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.ZXing = {}));\n}(this, (function (exports) { 'use strict';\n\n /*! *****************************************************************************\n Copyright (c) Microsoft Corporation. All rights reserved.\n Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use\n this file except in compliance with the License. You may obtain a copy of the\n License at http://www.apache.org/licenses/LICENSE-2.0\n\n THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\n WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\n MERCHANTABLITY OR NON-INFRINGEMENT.\n\n See the Apache Version 2.0 License for specific language governing permissions\n and limitations under the License.\n ***************************************************************************** */\n /* global Reflect, Promise */\n\n var extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n\n function __extends(d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n }\n\n function fixProto(target, prototype) {\n var setPrototypeOf = Object.setPrototypeOf;\n setPrototypeOf ? setPrototypeOf(target, prototype) : (target.__proto__ = prototype);\n }\n\n function fixStack(target, fn) {\n if (fn === void 0) {\n fn = target.constructor;\n }\n var captureStackTrace = Error.captureStackTrace;\n captureStackTrace && captureStackTrace(target, fn);\n }\n\n\n\n\n\n var CustomError = (function (_super) {\n __extends(CustomError, _super);\n function CustomError(message) {\n var _newTarget = this.constructor;\n var _this = _super.call(this, message) || this;\n Object.defineProperty(_this, 'name', {\n value: _newTarget.name,\n enumerable: false\n });\n fixProto(_this, _newTarget.prototype);\n fixStack(_this);\n return _this;\n }\n \n return CustomError;\n })(Error);\n\n /**\n * Custom Error class of type Exception.\n */\n class Exception extends CustomError {\n /**\n * Allows Exception to be constructed directly\n * with some message and prototype definition.\n */\n constructor(message = undefined) {\n super(message);\n this.message = message;\n }\n getKind() {\n const ex = this.constructor;\n return ex.kind;\n }\n }\n /**\n * It's typed as string so it can be extended and overriden.\n */\n Exception.kind = 'Exception';\n\n /**\n * Custom Error class of type Exception.\n */\n class ArgumentException extends Exception {\n }\n ArgumentException.kind = 'ArgumentException';\n\n /**\n * Custom Error class of type Exception.\n */\n class IllegalArgumentException extends Exception {\n }\n IllegalArgumentException.kind = 'IllegalArgumentException';\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n class BinaryBitmap {\n constructor(binarizer) {\n this.binarizer = binarizer;\n if (binarizer === null) {\n throw new IllegalArgumentException('Binarizer must be non-null.');\n }\n }\n /**\n * @return The width of the bitmap.\n */\n getWidth() {\n return this.binarizer.getWidth();\n }\n /**\n * @return The height of the bitmap.\n */\n getHeight() {\n return this.binarizer.getHeight();\n }\n /**\n * Converts one row of luminance data to 1 bit data. May actually do the conversion, or return\n * cached data. Callers should assume this method is expensive and call it as seldom as possible.\n * This method is intended for decoding 1D barcodes and may choose to apply sharpening.\n *\n * @param y The row to fetch, which must be in [0, bitmap height)\n * @param row An optional preallocated array. If null or too small, it will be ignored.\n * If used, the Binarizer will call BitArray.clear(). Always use the returned object.\n * @return The array of bits for this row (true means black).\n * @throws NotFoundException if row can't be binarized\n */\n getBlackRow(y /*int*/, row) {\n return this.binarizer.getBlackRow(y, row);\n }\n /**\n * Converts a 2D array of luminance data to 1 bit. As above, assume this method is expensive\n * and do not call it repeatedly. This method is intended for decoding 2D barcodes and may or\n * may not apply sharpening. Therefore, a row from this matrix may not be identical to one\n * fetched using getBlackRow(), so don't mix and match between them.\n *\n * @return The 2D array of bits for the image (true means black).\n * @throws NotFoundException if image can't be binarized to make a matrix\n */\n getBlackMatrix() {\n // The matrix is created on demand the first time it is requested, then cached. There are two\n // reasons for this:\n // 1. This work will never be done if the caller only installs 1D Reader objects, or if a\n // 1D Reader finds a barcode before the 2D Readers run.\n // 2. This work will only be done once even if the caller installs multiple 2D Readers.\n if (this.matrix === null || this.matrix === undefined) {\n this.matrix = this.binarizer.getBlackMatrix();\n }\n return this.matrix;\n }\n /**\n * @return Whether this bitmap can be cropped.\n */\n isCropSupported() {\n return this.binarizer.getLuminanceSource().isCropSupported();\n }\n /**\n * Returns a new object with cropped image data. Implementations may keep a reference to the\n * original data rather than a copy. Only callable if isCropSupported() is true.\n *\n * @param left The left coordinate, which must be in [0,getWidth())\n * @param top The top coordinate, which must be in [0,getHeight())\n * @param width The width of the rectangle to crop.\n * @param height The height of the rectangle to crop.\n * @return A cropped version of this object.\n */\n crop(left /*int*/, top /*int*/, width /*int*/, height /*int*/) {\n const newSource = this.binarizer.getLuminanceSource().crop(left, top, width, height);\n return new BinaryBitmap(this.binarizer.createBinarizer(newSource));\n }\n /**\n * @return Whether this bitmap supports counter-clockwise rotation.\n */\n isRotateSupported() {\n return this.binarizer.getLuminanceSource().isRotateSupported();\n }\n /**\n * Returns a new object with rotated image data by 90 degrees counterclockwise.\n * Only callable if {@link #isRotateSupported()} is true.\n *\n * @return A rotated version of this object.\n */\n rotateCounterClockwise() {\n const newSource = this.binarizer.getLuminanceSource().rotateCounterClockwise();\n return new BinaryBitmap(this.binarizer.createBinarizer(newSource));\n }\n /**\n * Returns a new object with rotated image data by 45 degrees counterclockwise.\n * Only callable if {@link #isRotateSupported()} is true.\n *\n * @return A rotated version of this object.\n */\n rotateCounterClockwise45() {\n const newSource = this.binarizer.getLuminanceSource().rotateCounterClockwise45();\n return new BinaryBitmap(this.binarizer.createBinarizer(newSource));\n }\n /*@Override*/\n toString() {\n try {\n return this.getBlackMatrix().toString();\n }\n catch (e /*: NotFoundException*/) {\n return '';\n }\n }\n }\n\n /**\n * Custom Error class of type Exception.\n */\n class ChecksumException extends Exception {\n static getChecksumInstance() {\n return new ChecksumException();\n }\n }\n ChecksumException.kind = 'ChecksumException';\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * This class hierarchy provides a set of methods to convert luminance data to 1 bit data.\n * It allows the algorithm to vary polymorphically, for example allowing a very expensive\n * thresholding technique for servers and a fast one for mobile. It also permits the implementation\n * to vary, e.g. a JNI version for Android and a Java fallback version for other platforms.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class Binarizer {\n constructor(source) {\n this.source = source;\n }\n getLuminanceSource() {\n return this.source;\n }\n getWidth() {\n return this.source.getWidth();\n }\n getHeight() {\n return this.source.getHeight();\n }\n }\n\n class System {\n // public static void arraycopy(Object src, int srcPos, Object dest, int destPos, int length)\n /**\n * Makes a copy of a array.\n */\n static arraycopy(src, srcPos, dest, destPos, length) {\n // TODO: better use split or set?\n while (length--) {\n dest[destPos++] = src[srcPos++];\n }\n }\n /**\n * Returns the current time in milliseconds.\n */\n static currentTimeMillis() {\n return Date.now();\n }\n }\n\n /**\n * Custom Error class of type Exception.\n */\n class IndexOutOfBoundsException extends Exception {\n }\n IndexOutOfBoundsException.kind = 'IndexOutOfBoundsException';\n\n /**\n * Custom Error class of type Exception.\n */\n class ArrayIndexOutOfBoundsException extends IndexOutOfBoundsException {\n constructor(index = undefined, message = undefined) {\n super(message);\n this.index = index;\n this.message = message;\n }\n }\n ArrayIndexOutOfBoundsException.kind = 'ArrayIndexOutOfBoundsException';\n\n class Arrays {\n /**\n * Assigns the specified int value to each element of the specified array\n * of ints.\n *\n * @param a the array to be filled\n * @param val the value to be stored in all elements of the array\n */\n static fill(a, val) {\n for (let i = 0, len = a.length; i < len; i++)\n a[i] = val;\n }\n /**\n * Assigns the specified int value to each element of the specified\n * range of the specified array of ints. The range to be filled\n * extends from index {@code fromIndex}, inclusive, to index\n * {@code toIndex}, exclusive. (If {@code fromIndex==toIndex}, the\n * range to be filled is empty.)\n *\n * @param a the array to be filled\n * @param fromIndex the index of the first element (inclusive) to be\n * filled with the specified value\n * @param toIndex the index of the last element (exclusive) to be\n * filled with the specified value\n * @param val the value to be stored in all elements of the array\n * @throws IllegalArgumentException if {@code fromIndex > toIndex}\n * @throws ArrayIndexOutOfBoundsException if {@code fromIndex < 0} or\n * {@code toIndex > a.length}\n */\n static fillWithin(a, fromIndex, toIndex, val) {\n Arrays.rangeCheck(a.length, fromIndex, toIndex);\n for (let i = fromIndex; i < toIndex; i++)\n a[i] = val;\n }\n /**\n * Checks that {@code fromIndex} and {@code toIndex} are in\n * the range and throws an exception if they aren't.\n */\n static rangeCheck(arrayLength, fromIndex, toIndex) {\n if (fromIndex > toIndex) {\n throw new IllegalArgumentException('fromIndex(' + fromIndex + ') > toIndex(' + toIndex + ')');\n }\n if (fromIndex < 0) {\n throw new ArrayIndexOutOfBoundsException(fromIndex);\n }\n if (toIndex > arrayLength) {\n throw new ArrayIndexOutOfBoundsException(toIndex);\n }\n }\n static asList(...args) {\n return args;\n }\n static create(rows, cols, value) {\n let arr = Array.from({ length: rows });\n return arr.map(x => Array.from({ length: cols }).fill(value));\n }\n static createInt32Array(rows, cols, value) {\n let arr = Array.from({ length: rows });\n return arr.map(x => Int32Array.from({ length: cols }).fill(value));\n }\n static equals(first, second) {\n if (!first) {\n return false;\n }\n if (!second) {\n return false;\n }\n if (!first.length) {\n return false;\n }\n if (!second.length) {\n return false;\n }\n if (first.length !== second.length) {\n return false;\n }\n for (let i = 0, length = first.length; i < length; i++) {\n if (first[i] !== second[i]) {\n return false;\n }\n }\n return true;\n }\n static hashCode(a) {\n if (a === null) {\n return 0;\n }\n let result = 1;\n for (const element of a) {\n result = 31 * result + element;\n }\n return result;\n }\n static fillUint8Array(a, value) {\n for (let i = 0; i !== a.length; i++) {\n a[i] = value;\n }\n }\n static copyOf(original, newLength) {\n return original.slice(0, newLength);\n }\n static copyOfUint8Array(original, newLength) {\n if (original.length <= newLength) {\n const newArray = new Uint8Array(newLength);\n newArray.set(original);\n return newArray;\n }\n return original.slice(0, newLength);\n }\n static copyOfRange(original, from, to) {\n const newLength = to - from;\n const copy = new Int32Array(newLength);\n System.arraycopy(original, from, copy, 0, newLength);\n return copy;\n }\n /*\n * Returns the index of of the element in a sorted array or (-n-1) where n is the insertion point\n * for the new element.\n * Parameters:\n * ar - A sorted array\n * el - An element to search for\n * comparator - A comparator function. The function takes two arguments: (a, b) and returns:\n * a negative number if a is less than b;\n * 0 if a is equal to b;\n * a positive number of a is greater than b.\n * The array may contain duplicate elements. If there are more than one equal elements in the array,\n * the returned value can be the index of any one of the equal elements.\n *\n * http://jsfiddle.net/aryzhov/pkfst550/\n */\n static binarySearch(ar, el, comparator) {\n if (undefined === comparator) {\n comparator = Arrays.numberComparator;\n }\n let m = 0;\n let n = ar.length - 1;\n while (m <= n) {\n const k = (n + m) >> 1;\n const cmp = comparator(el, ar[k]);\n if (cmp > 0) {\n m = k + 1;\n }\n else if (cmp < 0) {\n n = k - 1;\n }\n else {\n return k;\n }\n }\n return -m - 1;\n }\n static numberComparator(a, b) {\n return a - b;\n }\n }\n\n /**\n * Ponyfill for Java's Integer class.\n */\n class Integer {\n static numberOfTrailingZeros(i) {\n let y;\n if (i === 0)\n return 32;\n let n = 31;\n y = i << 16;\n if (y !== 0) {\n n -= 16;\n i = y;\n }\n y = i << 8;\n if (y !== 0) {\n n -= 8;\n i = y;\n }\n y = i << 4;\n if (y !== 0) {\n n -= 4;\n i = y;\n }\n y = i << 2;\n if (y !== 0) {\n n -= 2;\n i = y;\n }\n return n - ((i << 1) >>> 31);\n }\n static numberOfLeadingZeros(i) {\n // HD, Figure 5-6\n if (i === 0) {\n return 32;\n }\n let n = 1;\n if (i >>> 16 === 0) {\n n += 16;\n i <<= 16;\n }\n if (i >>> 24 === 0) {\n n += 8;\n i <<= 8;\n }\n if (i >>> 28 === 0) {\n n += 4;\n i <<= 4;\n }\n if (i >>> 30 === 0) {\n n += 2;\n i <<= 2;\n }\n n -= i >>> 31;\n return n;\n }\n static toHexString(i) {\n return i.toString(16);\n }\n static toBinaryString(intNumber) {\n return String(parseInt(String(intNumber), 2));\n }\n // Returns the number of one-bits in the two's complement binary representation of the specified int value. This function is sometimes referred to as the population count.\n // Returns:\n // the number of one-bits in the two's complement binary representation of the specified int value.\n static bitCount(i) {\n // HD, Figure 5-2\n i = i - ((i >>> 1) & 0x55555555);\n i = (i & 0x33333333) + ((i >>> 2) & 0x33333333);\n i = (i + (i >>> 4)) & 0x0f0f0f0f;\n i = i + (i >>> 8);\n i = i + (i >>> 16);\n return i & 0x3f;\n }\n static truncDivision(dividend, divisor) {\n return Math.trunc(dividend / divisor);\n }\n /**\n * Converts A string to an integer.\n * @param s A string to convert into a number.\n * @param radix A value between 2 and 36 that specifies the base of the number in numString. If this argument is not supplied, strings with a prefix of '0x' are considered hexadecimal. All other strings are considered decimal.\n */\n static parseInt(num, radix = undefined) {\n return parseInt(num, radix);\n }\n }\n Integer.MIN_VALUE_32_BITS = -2147483648;\n Integer.MAX_VALUE = Number.MAX_SAFE_INTEGER;\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

A simple, fast array of bits, represented compactly by an array of ints internally.

\n *\n * @author Sean Owen\n */\n class BitArray /*implements Cloneable*/ {\n // public constructor() {\n // this.size = 0\n // this.bits = new Int32Array(1)\n // }\n // public constructor(size?: number /*int*/) {\n // if (undefined === size) {\n // this.size = 0\n // } else {\n // this.size = size\n // }\n // this.bits = this.makeArray(size)\n // }\n // For testing only\n constructor(size /*int*/, bits) {\n if (undefined === size) {\n this.size = 0;\n this.bits = new Int32Array(1);\n }\n else {\n this.size = size;\n if (undefined === bits || null === bits) {\n this.bits = BitArray.makeArray(size);\n }\n else {\n this.bits = bits;\n }\n }\n }\n getSize() {\n return this.size;\n }\n getSizeInBytes() {\n return Math.floor((this.size + 7) / 8);\n }\n ensureCapacity(size /*int*/) {\n if (size > this.bits.length * 32) {\n const newBits = BitArray.makeArray(size);\n System.arraycopy(this.bits, 0, newBits, 0, this.bits.length);\n this.bits = newBits;\n }\n }\n /**\n * @param i bit to get\n * @return true iff bit i is set\n */\n get(i /*int*/) {\n return (this.bits[Math.floor(i / 32)] & (1 << (i & 0x1F))) !== 0;\n }\n /**\n * Sets bit i.\n *\n * @param i bit to set\n */\n set(i /*int*/) {\n this.bits[Math.floor(i / 32)] |= 1 << (i & 0x1F);\n }\n /**\n * Flips bit i.\n *\n * @param i bit to set\n */\n flip(i /*int*/) {\n this.bits[Math.floor(i / 32)] ^= 1 << (i & 0x1F);\n }\n /**\n * @param from first bit to check\n * @return index of first bit that is set, starting from the given index, or size if none are set\n * at or beyond this given index\n * @see #getNextUnset(int)\n */\n getNextSet(from /*int*/) {\n const size = this.size;\n if (from >= size) {\n return size;\n }\n const bits = this.bits;\n let bitsOffset = Math.floor(from / 32);\n let currentBits = bits[bitsOffset];\n // mask off lesser bits first\n currentBits &= ~((1 << (from & 0x1F)) - 1);\n const length = bits.length;\n while (currentBits === 0) {\n if (++bitsOffset === length) {\n return size;\n }\n currentBits = bits[bitsOffset];\n }\n const result = (bitsOffset * 32) + Integer.numberOfTrailingZeros(currentBits);\n return result > size ? size : result;\n }\n /**\n * @param from index to start looking for unset bit\n * @return index of next unset bit, or {@code size} if none are unset until the end\n * @see #getNextSet(int)\n */\n getNextUnset(from /*int*/) {\n const size = this.size;\n if (from >= size) {\n return size;\n }\n const bits = this.bits;\n let bitsOffset = Math.floor(from / 32);\n let currentBits = ~bits[bitsOffset];\n // mask off lesser bits first\n currentBits &= ~((1 << (from & 0x1F)) - 1);\n const length = bits.length;\n while (currentBits === 0) {\n if (++bitsOffset === length) {\n return size;\n }\n currentBits = ~bits[bitsOffset];\n }\n const result = (bitsOffset * 32) + Integer.numberOfTrailingZeros(currentBits);\n return result > size ? size : result;\n }\n /**\n * Sets a block of 32 bits, starting at bit i.\n *\n * @param i first bit to set\n * @param newBits the new value of the next 32 bits. Note again that the least-significant bit\n * corresponds to bit i, the next-least-significant to i+1, and so on.\n */\n setBulk(i /*int*/, newBits /*int*/) {\n this.bits[Math.floor(i / 32)] = newBits;\n }\n /**\n * Sets a range of bits.\n *\n * @param start start of range, inclusive.\n * @param end end of range, exclusive\n */\n setRange(start /*int*/, end /*int*/) {\n if (end < start || start < 0 || end > this.size) {\n throw new IllegalArgumentException();\n }\n if (end === start) {\n return;\n }\n end--; // will be easier to treat this as the last actually set bit -- inclusive\n const firstInt = Math.floor(start / 32);\n const lastInt = Math.floor(end / 32);\n const bits = this.bits;\n for (let i = firstInt; i <= lastInt; i++) {\n const firstBit = i > firstInt ? 0 : start & 0x1F;\n const lastBit = i < lastInt ? 31 : end & 0x1F;\n // Ones from firstBit to lastBit, inclusive\n const mask = (2 << lastBit) - (1 << firstBit);\n bits[i] |= mask;\n }\n }\n /**\n * Clears all bits (sets to false).\n */\n clear() {\n const max = this.bits.length;\n const bits = this.bits;\n for (let i = 0; i < max; i++) {\n bits[i] = 0;\n }\n }\n /**\n * Efficient method to check if a range of bits is set, or not set.\n *\n * @param start start of range, inclusive.\n * @param end end of range, exclusive\n * @param value if true, checks that bits in range are set, otherwise checks that they are not set\n * @return true iff all bits are set or not set in range, according to value argument\n * @throws IllegalArgumentException if end is less than start or the range is not contained in the array\n */\n isRange(start /*int*/, end /*int*/, value) {\n if (end < start || start < 0 || end > this.size) {\n throw new IllegalArgumentException();\n }\n if (end === start) {\n return true; // empty range matches\n }\n end--; // will be easier to treat this as the last actually set bit -- inclusive\n const firstInt = Math.floor(start / 32);\n const lastInt = Math.floor(end / 32);\n const bits = this.bits;\n for (let i = firstInt; i <= lastInt; i++) {\n const firstBit = i > firstInt ? 0 : start & 0x1F;\n const lastBit = i < lastInt ? 31 : end & 0x1F;\n // Ones from firstBit to lastBit, inclusive\n const mask = (2 << lastBit) - (1 << firstBit) & 0xFFFFFFFF;\n // TYPESCRIPTPORT: & 0xFFFFFFFF added to discard anything after 32 bits, as ES has 53 bits\n // Return false if we're looking for 1s and the masked bits[i] isn't all 1s (is: that,\n // equals the mask, or we're looking for 0s and the masked portion is not all 0s\n if ((bits[i] & mask) !== (value ? mask : 0)) {\n return false;\n }\n }\n return true;\n }\n appendBit(bit) {\n this.ensureCapacity(this.size + 1);\n if (bit) {\n this.bits[Math.floor(this.size / 32)] |= 1 << (this.size & 0x1F);\n }\n this.size++;\n }\n /**\n * Appends the least-significant bits, from value, in order from most-significant to\n * least-significant. For example, appending 6 bits from 0x000001E will append the bits\n * 0, 1, 1, 1, 1, 0 in that order.\n *\n * @param value {@code int} containing bits to append\n * @param numBits bits from value to append\n */\n appendBits(value /*int*/, numBits /*int*/) {\n if (numBits < 0 || numBits > 32) {\n throw new IllegalArgumentException('Num bits must be between 0 and 32');\n }\n this.ensureCapacity(this.size + numBits);\n // const appendBit = this.appendBit;\n for (let numBitsLeft = numBits; numBitsLeft > 0; numBitsLeft--) {\n this.appendBit(((value >> (numBitsLeft - 1)) & 0x01) === 1);\n }\n }\n appendBitArray(other) {\n const otherSize = other.size;\n this.ensureCapacity(this.size + otherSize);\n // const appendBit = this.appendBit;\n for (let i = 0; i < otherSize; i++) {\n this.appendBit(other.get(i));\n }\n }\n xor(other) {\n if (this.size !== other.size) {\n throw new IllegalArgumentException('Sizes don\\'t match');\n }\n const bits = this.bits;\n for (let i = 0, length = bits.length; i < length; i++) {\n // The last int could be incomplete (i.e. not have 32 bits in\n // it) but there is no problem since 0 XOR 0 == 0.\n bits[i] ^= other.bits[i];\n }\n }\n /**\n *\n * @param bitOffset first bit to start writing\n * @param array array to write into. Bytes are written most-significant byte first. This is the opposite\n * of the internal representation, which is exposed by {@link #getBitArray()}\n * @param offset position in array to start writing\n * @param numBytes how many bytes to write\n */\n toBytes(bitOffset /*int*/, array, offset /*int*/, numBytes /*int*/) {\n for (let i = 0; i < numBytes; i++) {\n let theByte = 0;\n for (let j = 0; j < 8; j++) {\n if (this.get(bitOffset)) {\n theByte |= 1 << (7 - j);\n }\n bitOffset++;\n }\n array[offset + i] = /*(byte)*/ theByte;\n }\n }\n /**\n * @return underlying array of ints. The first element holds the first 32 bits, and the least\n * significant bit is bit 0.\n */\n getBitArray() {\n return this.bits;\n }\n /**\n * Reverses all bits in the array.\n */\n reverse() {\n const newBits = new Int32Array(this.bits.length);\n // reverse all int's first\n const len = Math.floor((this.size - 1) / 32);\n const oldBitsLen = len + 1;\n const bits = this.bits;\n for (let i = 0; i < oldBitsLen; i++) {\n let x = bits[i];\n x = ((x >> 1) & 0x55555555) | ((x & 0x55555555) << 1);\n x = ((x >> 2) & 0x33333333) | ((x & 0x33333333) << 2);\n x = ((x >> 4) & 0x0f0f0f0f) | ((x & 0x0f0f0f0f) << 4);\n x = ((x >> 8) & 0x00ff00ff) | ((x & 0x00ff00ff) << 8);\n x = ((x >> 16) & 0x0000ffff) | ((x & 0x0000ffff) << 16);\n newBits[len - i] = /*(int)*/ x;\n }\n // now correct the int's if the bit size isn't a multiple of 32\n if (this.size !== oldBitsLen * 32) {\n const leftOffset = oldBitsLen * 32 - this.size;\n let currentInt = newBits[0] >>> leftOffset;\n for (let i = 1; i < oldBitsLen; i++) {\n const nextInt = newBits[i];\n currentInt |= nextInt << (32 - leftOffset);\n newBits[i - 1] = currentInt;\n currentInt = nextInt >>> leftOffset;\n }\n newBits[oldBitsLen - 1] = currentInt;\n }\n this.bits = newBits;\n }\n static makeArray(size /*int*/) {\n return new Int32Array(Math.floor((size + 31) / 32));\n }\n /*@Override*/\n equals(o) {\n if (!(o instanceof BitArray)) {\n return false;\n }\n const other = o;\n return this.size === other.size && Arrays.equals(this.bits, other.bits);\n }\n /*@Override*/\n hashCode() {\n return 31 * this.size + Arrays.hashCode(this.bits);\n }\n /*@Override*/\n toString() {\n let result = '';\n for (let i = 0, size = this.size; i < size; i++) {\n if ((i & 0x07) === 0) {\n result += ' ';\n }\n result += this.get(i) ? 'X' : '.';\n }\n return result;\n }\n /*@Override*/\n clone() {\n return new BitArray(this.size, this.bits.slice());\n }\n }\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing {*/\n /**\n * Encapsulates a type of hint that a caller may pass to a barcode reader to help it\n * more quickly or accurately decode it. It is up to implementations to decide what,\n * if anything, to do with the information that is supplied.\n *\n * @author Sean Owen\n * @author dswitkin@google.com (Daniel Switkin)\n * @see Reader#decode(BinaryBitmap,java.util.Map)\n */\n var DecodeHintType;\n (function (DecodeHintType) {\n /**\n * Unspecified, application-specific hint. Maps to an unspecified {@link Object}.\n */\n DecodeHintType[DecodeHintType[\"OTHER\"] = 0] = \"OTHER\"; /*(Object.class)*/\n /**\n * Image is a pure monochrome image of a barcode. Doesn't matter what it maps to;\n * use {@link Boolean#TRUE}.\n */\n DecodeHintType[DecodeHintType[\"PURE_BARCODE\"] = 1] = \"PURE_BARCODE\"; /*(Void.class)*/\n /**\n * Image is known to be of one of a few possible formats.\n * Maps to a {@link List} of {@link BarcodeFormat}s.\n */\n DecodeHintType[DecodeHintType[\"POSSIBLE_FORMATS\"] = 2] = \"POSSIBLE_FORMATS\"; /*(List.class)*/\n /**\n * Spend more time to try to find a barcode; optimize for accuracy, not speed.\n * Doesn't matter what it maps to; use {@link Boolean#TRUE}.\n */\n DecodeHintType[DecodeHintType[\"TRY_HARDER\"] = 3] = \"TRY_HARDER\"; /*(Void.class)*/\n /**\n * Specifies what character encoding to use when decoding, where applicable (type String)\n */\n DecodeHintType[DecodeHintType[\"CHARACTER_SET\"] = 4] = \"CHARACTER_SET\"; /*(String.class)*/\n /**\n * Allowed lengths of encoded data -- reject anything else. Maps to an {@code Int32Array}.\n */\n DecodeHintType[DecodeHintType[\"ALLOWED_LENGTHS\"] = 5] = \"ALLOWED_LENGTHS\"; /*(Int32Array.class)*/\n /**\n * Assume Code 39 codes employ a check digit. Doesn't matter what it maps to;\n * use {@link Boolean#TRUE}.\n */\n DecodeHintType[DecodeHintType[\"ASSUME_CODE_39_CHECK_DIGIT\"] = 6] = \"ASSUME_CODE_39_CHECK_DIGIT\"; /*(Void.class)*/\n /**\n * Assume the barcode is being processed as a GS1 barcode, and modify behavior as needed.\n * For example this affects FNC1 handling for Code 128 (aka GS1-128). Doesn't matter what it maps to;\n * use {@link Boolean#TRUE}.\n */\n DecodeHintType[DecodeHintType[\"ASSUME_GS1\"] = 7] = \"ASSUME_GS1\"; /*(Void.class)*/\n /**\n * If true, return the start and end digits in a Codabar barcode instead of stripping them. They\n * are alpha, whereas the rest are numeric. By default, they are stripped, but this causes them\n * to not be. Doesn't matter what it maps to; use {@link Boolean#TRUE}.\n */\n DecodeHintType[DecodeHintType[\"RETURN_CODABAR_START_END\"] = 8] = \"RETURN_CODABAR_START_END\"; /*(Void.class)*/\n /**\n * The caller needs to be notified via callback when a possible {@link ResultPoint}\n * is found. Maps to a {@link ResultPointCallback}.\n */\n DecodeHintType[DecodeHintType[\"NEED_RESULT_POINT_CALLBACK\"] = 9] = \"NEED_RESULT_POINT_CALLBACK\"; /*(ResultPointCallback.class)*/\n /**\n * Allowed extension lengths for EAN or UPC barcodes. Other formats will ignore this.\n * Maps to an {@code Int32Array} of the allowed extension lengths, for example [2], [5], or [2, 5].\n * If it is optional to have an extension, do not set this hint. If this is set,\n * and a UPC or EAN barcode is found but an extension is not, then no result will be returned\n * at all.\n */\n DecodeHintType[DecodeHintType[\"ALLOWED_EAN_EXTENSIONS\"] = 10] = \"ALLOWED_EAN_EXTENSIONS\"; /*(Int32Array.class)*/\n // End of enumeration values.\n /**\n * Data type the hint is expecting.\n * Among the possible values the {@link Void} stands out as being used for\n * hints that do not expect a value to be supplied (flag hints). Such hints\n * will possibly have their value ignored, or replaced by a\n * {@link Boolean#TRUE}. Hint suppliers should probably use\n * {@link Boolean#TRUE} as directed by the actual hint documentation.\n */\n // private valueType: Class\n // DecodeHintType(valueType: Class) {\n // this.valueType = valueType\n // }\n // public getValueType(): Class {\n // return valueType\n // }\n })(DecodeHintType || (DecodeHintType = {}));\n var DecodeHintType$1 = DecodeHintType;\n\n /**\n * Custom Error class of type Exception.\n */\n class FormatException extends Exception {\n static getFormatInstance() {\n return new FormatException();\n }\n }\n FormatException.kind = 'FormatException';\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.util.HashMap;*/\n /*import java.util.Map;*/\n var CharacterSetValueIdentifiers;\n (function (CharacterSetValueIdentifiers) {\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"Cp437\"] = 0] = \"Cp437\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_1\"] = 1] = \"ISO8859_1\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_2\"] = 2] = \"ISO8859_2\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_3\"] = 3] = \"ISO8859_3\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_4\"] = 4] = \"ISO8859_4\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_5\"] = 5] = \"ISO8859_5\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_6\"] = 6] = \"ISO8859_6\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_7\"] = 7] = \"ISO8859_7\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_8\"] = 8] = \"ISO8859_8\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_9\"] = 9] = \"ISO8859_9\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_10\"] = 10] = \"ISO8859_10\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_11\"] = 11] = \"ISO8859_11\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_13\"] = 12] = \"ISO8859_13\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_14\"] = 13] = \"ISO8859_14\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_15\"] = 14] = \"ISO8859_15\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ISO8859_16\"] = 15] = \"ISO8859_16\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"SJIS\"] = 16] = \"SJIS\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"Cp1250\"] = 17] = \"Cp1250\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"Cp1251\"] = 18] = \"Cp1251\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"Cp1252\"] = 19] = \"Cp1252\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"Cp1256\"] = 20] = \"Cp1256\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"UnicodeBigUnmarked\"] = 21] = \"UnicodeBigUnmarked\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"UTF8\"] = 22] = \"UTF8\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"ASCII\"] = 23] = \"ASCII\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"Big5\"] = 24] = \"Big5\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"GB18030\"] = 25] = \"GB18030\";\n CharacterSetValueIdentifiers[CharacterSetValueIdentifiers[\"EUC_KR\"] = 26] = \"EUC_KR\";\n })(CharacterSetValueIdentifiers || (CharacterSetValueIdentifiers = {}));\n /**\n * Encapsulates a Character Set ECI, according to \"Extended Channel Interpretations\" 5.3.1.1\n * of ISO 18004.\n *\n * @author Sean Owen\n */\n class CharacterSetECI {\n constructor(valueIdentifier, valuesParam, name, ...otherEncodingNames) {\n this.valueIdentifier = valueIdentifier;\n this.name = name;\n if (typeof valuesParam === 'number') {\n this.values = Int32Array.from([valuesParam]);\n }\n else {\n this.values = valuesParam;\n }\n this.otherEncodingNames = otherEncodingNames;\n CharacterSetECI.VALUE_IDENTIFIER_TO_ECI.set(valueIdentifier, this);\n CharacterSetECI.NAME_TO_ECI.set(name, this);\n const values = this.values;\n for (let i = 0, length = values.length; i !== length; i++) {\n const v = values[i];\n CharacterSetECI.VALUES_TO_ECI.set(v, this);\n }\n for (const otherName of otherEncodingNames) {\n CharacterSetECI.NAME_TO_ECI.set(otherName, this);\n }\n }\n // CharacterSetECI(value: number /*int*/) {\n // this(new Int32Array {value})\n // }\n // CharacterSetECI(value: number /*int*/, String... otherEncodingNames) {\n // this.values = new Int32Array {value}\n // this.otherEncodingNames = otherEncodingNames\n // }\n // CharacterSetECI(values: Int32Array, String... otherEncodingNames) {\n // this.values = values\n // this.otherEncodingNames = otherEncodingNames\n // }\n getValueIdentifier() {\n return this.valueIdentifier;\n }\n getName() {\n return this.name;\n }\n getValue() {\n return this.values[0];\n }\n /**\n * @param value character set ECI value\n * @return {@code CharacterSetECI} representing ECI of given value, or null if it is legal but\n * unsupported\n * @throws FormatException if ECI value is invalid\n */\n static getCharacterSetECIByValue(value /*int*/) {\n if (value < 0 || value >= 900) {\n throw new FormatException('incorect value');\n }\n const characterSet = CharacterSetECI.VALUES_TO_ECI.get(value);\n if (undefined === characterSet) {\n throw new FormatException('incorect value');\n }\n return characterSet;\n }\n /**\n * @param name character set ECI encoding name\n * @return CharacterSetECI representing ECI for character encoding, or null if it is legal\n * but unsupported\n */\n static getCharacterSetECIByName(name) {\n const characterSet = CharacterSetECI.NAME_TO_ECI.get(name);\n if (undefined === characterSet) {\n throw new FormatException('incorect value');\n }\n return characterSet;\n }\n equals(o) {\n if (!(o instanceof CharacterSetECI)) {\n return false;\n }\n const other = o;\n return this.getName() === other.getName();\n }\n }\n CharacterSetECI.VALUE_IDENTIFIER_TO_ECI = new Map();\n CharacterSetECI.VALUES_TO_ECI = new Map();\n CharacterSetECI.NAME_TO_ECI = new Map();\n // Enum name is a Java encoding valid for java.lang and java.io\n // TYPESCRIPTPORT: changed the main label for ISO as the TextEncoder did not recognized them in the form from java\n // (eg ISO8859_1 must be ISO88591 or ISO8859-1 or ISO-8859-1)\n // later on: well, except 16 wich does not work with ISO885916 so used ISO-8859-1 form for default\n CharacterSetECI.Cp437 = new CharacterSetECI(CharacterSetValueIdentifiers.Cp437, Int32Array.from([0, 2]), 'Cp437');\n CharacterSetECI.ISO8859_1 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_1, Int32Array.from([1, 3]), 'ISO-8859-1', 'ISO88591', 'ISO8859_1');\n CharacterSetECI.ISO8859_2 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_2, 4, 'ISO-8859-2', 'ISO88592', 'ISO8859_2');\n CharacterSetECI.ISO8859_3 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_3, 5, 'ISO-8859-3', 'ISO88593', 'ISO8859_3');\n CharacterSetECI.ISO8859_4 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_4, 6, 'ISO-8859-4', 'ISO88594', 'ISO8859_4');\n CharacterSetECI.ISO8859_5 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_5, 7, 'ISO-8859-5', 'ISO88595', 'ISO8859_5');\n CharacterSetECI.ISO8859_6 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_6, 8, 'ISO-8859-6', 'ISO88596', 'ISO8859_6');\n CharacterSetECI.ISO8859_7 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_7, 9, 'ISO-8859-7', 'ISO88597', 'ISO8859_7');\n CharacterSetECI.ISO8859_8 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_8, 10, 'ISO-8859-8', 'ISO88598', 'ISO8859_8');\n CharacterSetECI.ISO8859_9 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_9, 11, 'ISO-8859-9', 'ISO88599', 'ISO8859_9');\n CharacterSetECI.ISO8859_10 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_10, 12, 'ISO-8859-10', 'ISO885910', 'ISO8859_10');\n CharacterSetECI.ISO8859_11 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_11, 13, 'ISO-8859-11', 'ISO885911', 'ISO8859_11');\n CharacterSetECI.ISO8859_13 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_13, 15, 'ISO-8859-13', 'ISO885913', 'ISO8859_13');\n CharacterSetECI.ISO8859_14 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_14, 16, 'ISO-8859-14', 'ISO885914', 'ISO8859_14');\n CharacterSetECI.ISO8859_15 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_15, 17, 'ISO-8859-15', 'ISO885915', 'ISO8859_15');\n CharacterSetECI.ISO8859_16 = new CharacterSetECI(CharacterSetValueIdentifiers.ISO8859_16, 18, 'ISO-8859-16', 'ISO885916', 'ISO8859_16');\n CharacterSetECI.SJIS = new CharacterSetECI(CharacterSetValueIdentifiers.SJIS, 20, 'SJIS', 'Shift_JIS');\n CharacterSetECI.Cp1250 = new CharacterSetECI(CharacterSetValueIdentifiers.Cp1250, 21, 'Cp1250', 'windows-1250');\n CharacterSetECI.Cp1251 = new CharacterSetECI(CharacterSetValueIdentifiers.Cp1251, 22, 'Cp1251', 'windows-1251');\n CharacterSetECI.Cp1252 = new CharacterSetECI(CharacterSetValueIdentifiers.Cp1252, 23, 'Cp1252', 'windows-1252');\n CharacterSetECI.Cp1256 = new CharacterSetECI(CharacterSetValueIdentifiers.Cp1256, 24, 'Cp1256', 'windows-1256');\n CharacterSetECI.UnicodeBigUnmarked = new CharacterSetECI(CharacterSetValueIdentifiers.UnicodeBigUnmarked, 25, 'UnicodeBigUnmarked', 'UTF-16BE', 'UnicodeBig');\n CharacterSetECI.UTF8 = new CharacterSetECI(CharacterSetValueIdentifiers.UTF8, 26, 'UTF8', 'UTF-8');\n CharacterSetECI.ASCII = new CharacterSetECI(CharacterSetValueIdentifiers.ASCII, Int32Array.from([27, 170]), 'ASCII', 'US-ASCII');\n CharacterSetECI.Big5 = new CharacterSetECI(CharacterSetValueIdentifiers.Big5, 28, 'Big5');\n CharacterSetECI.GB18030 = new CharacterSetECI(CharacterSetValueIdentifiers.GB18030, 29, 'GB18030', 'GB2312', 'EUC_CN', 'GBK');\n CharacterSetECI.EUC_KR = new CharacterSetECI(CharacterSetValueIdentifiers.EUC_KR, 30, 'EUC_KR', 'EUC-KR');\n\n /**\n * Custom Error class of type Exception.\n */\n class UnsupportedOperationException extends Exception {\n }\n UnsupportedOperationException.kind = 'UnsupportedOperationException';\n\n /**\n * Responsible for en/decoding strings.\n */\n class StringEncoding {\n /**\n * Decodes some Uint8Array to a string format.\n */\n static decode(bytes, encoding) {\n const encodingName = this.encodingName(encoding);\n if (this.customDecoder) {\n return this.customDecoder(bytes, encodingName);\n }\n // Increases browser support.\n if (typeof TextDecoder === 'undefined' || this.shouldDecodeOnFallback(encodingName)) {\n return this.decodeFallback(bytes, encodingName);\n }\n return new TextDecoder(encodingName).decode(bytes);\n }\n /**\n * Checks if the decoding method should use the fallback for decoding\n * once Node TextDecoder doesn't support all encoding formats.\n *\n * @param encodingName\n */\n static shouldDecodeOnFallback(encodingName) {\n return !StringEncoding.isBrowser() && encodingName === 'ISO-8859-1';\n }\n /**\n * Encodes some string into a Uint8Array.\n */\n static encode(s, encoding) {\n const encodingName = this.encodingName(encoding);\n if (this.customEncoder) {\n return this.customEncoder(s, encodingName);\n }\n // Increases browser support.\n if (typeof TextEncoder === 'undefined') {\n return this.encodeFallback(s);\n }\n // TextEncoder only encodes to UTF8 by default as specified by encoding.spec.whatwg.org\n return new TextEncoder().encode(s);\n }\n static isBrowser() {\n return (typeof window !== 'undefined' && {}.toString.call(window) === '[object Window]');\n }\n /**\n * Returns the string value from some encoding character set.\n */\n static encodingName(encoding) {\n return typeof encoding === 'string'\n ? encoding\n : encoding.getName();\n }\n /**\n * Returns character set from some encoding character set.\n */\n static encodingCharacterSet(encoding) {\n if (encoding instanceof CharacterSetECI) {\n return encoding;\n }\n return CharacterSetECI.getCharacterSetECIByName(encoding);\n }\n /**\n * Runs a fallback for the native decoding funcion.\n */\n static decodeFallback(bytes, encoding) {\n const characterSet = this.encodingCharacterSet(encoding);\n if (StringEncoding.isDecodeFallbackSupported(characterSet)) {\n let s = '';\n for (let i = 0, length = bytes.length; i < length; i++) {\n let h = bytes[i].toString(16);\n if (h.length < 2) {\n h = '0' + h;\n }\n s += '%' + h;\n }\n return decodeURIComponent(s);\n }\n if (characterSet.equals(CharacterSetECI.UnicodeBigUnmarked)) {\n return String.fromCharCode.apply(null, new Uint16Array(bytes.buffer));\n }\n throw new UnsupportedOperationException(`Encoding ${this.encodingName(encoding)} not supported by fallback.`);\n }\n static isDecodeFallbackSupported(characterSet) {\n return characterSet.equals(CharacterSetECI.UTF8) ||\n characterSet.equals(CharacterSetECI.ISO8859_1) ||\n characterSet.equals(CharacterSetECI.ASCII);\n }\n /**\n * Runs a fallback for the native encoding funcion.\n *\n * @see https://stackoverflow.com/a/17192845/4367683\n */\n static encodeFallback(s) {\n const encodedURIstring = btoa(unescape(encodeURIComponent(s)));\n const charList = encodedURIstring.split('');\n const uintArray = [];\n for (let i = 0; i < charList.length; i++) {\n uintArray.push(charList[i].charCodeAt(0));\n }\n return new Uint8Array(uintArray);\n }\n }\n\n /*\n * Copyright (C) 2010 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * Common string-related functions.\n *\n * @author Sean Owen\n * @author Alex Dupre\n */\n class StringUtils {\n // SHIFT_JIS.equalsIgnoreCase(PLATFORM_DEFAULT_ENCODING) ||\n // EUC_JP.equalsIgnoreCase(PLATFORM_DEFAULT_ENCODING);\n static castAsNonUtf8Char(code, encoding = null) {\n // ISO 8859-1 is the Java default as UTF-8 is JavaScripts\n // you can see this method as a Java version of String.fromCharCode\n const e = encoding ? encoding.getName() : this.ISO88591;\n // use passed format (fromCharCode will return UTF8 encoding)\n return StringEncoding.decode(new Uint8Array([code]), e);\n }\n /**\n * @param bytes bytes encoding a string, whose encoding should be guessed\n * @param hints decode hints if applicable\n * @return name of guessed encoding; at the moment will only guess one of:\n * {@link #SHIFT_JIS}, {@link #UTF8}, {@link #ISO88591}, or the platform\n * default encoding if none of these can possibly be correct\n */\n static guessEncoding(bytes, hints) {\n if (hints !== null && hints !== undefined && undefined !== hints.get(DecodeHintType$1.CHARACTER_SET)) {\n return hints.get(DecodeHintType$1.CHARACTER_SET).toString();\n }\n // For now, merely tries to distinguish ISO-8859-1, UTF-8 and Shift_JIS,\n // which should be by far the most common encodings.\n const length = bytes.length;\n let canBeISO88591 = true;\n let canBeShiftJIS = true;\n let canBeUTF8 = true;\n let utf8BytesLeft = 0;\n // int utf8LowChars = 0\n let utf2BytesChars = 0;\n let utf3BytesChars = 0;\n let utf4BytesChars = 0;\n let sjisBytesLeft = 0;\n // int sjisLowChars = 0\n let sjisKatakanaChars = 0;\n // int sjisDoubleBytesChars = 0\n let sjisCurKatakanaWordLength = 0;\n let sjisCurDoubleBytesWordLength = 0;\n let sjisMaxKatakanaWordLength = 0;\n let sjisMaxDoubleBytesWordLength = 0;\n // int isoLowChars = 0\n // int isoHighChars = 0\n let isoHighOther = 0;\n const utf8bom = bytes.length > 3 &&\n bytes[0] === /*(byte) */ 0xEF &&\n bytes[1] === /*(byte) */ 0xBB &&\n bytes[2] === /*(byte) */ 0xBF;\n for (let i = 0; i < length && (canBeISO88591 || canBeShiftJIS || canBeUTF8); i++) {\n const value = bytes[i] & 0xFF;\n // UTF-8 stuff\n if (canBeUTF8) {\n if (utf8BytesLeft > 0) {\n if ((value & 0x80) === 0) {\n canBeUTF8 = false;\n }\n else {\n utf8BytesLeft--;\n }\n }\n else if ((value & 0x80) !== 0) {\n if ((value & 0x40) === 0) {\n canBeUTF8 = false;\n }\n else {\n utf8BytesLeft++;\n if ((value & 0x20) === 0) {\n utf2BytesChars++;\n }\n else {\n utf8BytesLeft++;\n if ((value & 0x10) === 0) {\n utf3BytesChars++;\n }\n else {\n utf8BytesLeft++;\n if ((value & 0x08) === 0) {\n utf4BytesChars++;\n }\n else {\n canBeUTF8 = false;\n }\n }\n }\n }\n } // else {\n // utf8LowChars++\n // }\n }\n // ISO-8859-1 stuff\n if (canBeISO88591) {\n if (value > 0x7F && value < 0xA0) {\n canBeISO88591 = false;\n }\n else if (value > 0x9F) {\n if (value < 0xC0 || value === 0xD7 || value === 0xF7) {\n isoHighOther++;\n } // else {\n // isoHighChars++\n // }\n } // else {\n // isoLowChars++\n // }\n }\n // Shift_JIS stuff\n if (canBeShiftJIS) {\n if (sjisBytesLeft > 0) {\n if (value < 0x40 || value === 0x7F || value > 0xFC) {\n canBeShiftJIS = false;\n }\n else {\n sjisBytesLeft--;\n }\n }\n else if (value === 0x80 || value === 0xA0 || value > 0xEF) {\n canBeShiftJIS = false;\n }\n else if (value > 0xA0 && value < 0xE0) {\n sjisKatakanaChars++;\n sjisCurDoubleBytesWordLength = 0;\n sjisCurKatakanaWordLength++;\n if (sjisCurKatakanaWordLength > sjisMaxKatakanaWordLength) {\n sjisMaxKatakanaWordLength = sjisCurKatakanaWordLength;\n }\n }\n else if (value > 0x7F) {\n sjisBytesLeft++;\n // sjisDoubleBytesChars++\n sjisCurKatakanaWordLength = 0;\n sjisCurDoubleBytesWordLength++;\n if (sjisCurDoubleBytesWordLength > sjisMaxDoubleBytesWordLength) {\n sjisMaxDoubleBytesWordLength = sjisCurDoubleBytesWordLength;\n }\n }\n else {\n // sjisLowChars++\n sjisCurKatakanaWordLength = 0;\n sjisCurDoubleBytesWordLength = 0;\n }\n }\n }\n if (canBeUTF8 && utf8BytesLeft > 0) {\n canBeUTF8 = false;\n }\n if (canBeShiftJIS && sjisBytesLeft > 0) {\n canBeShiftJIS = false;\n }\n // Easy -- if there is BOM or at least 1 valid not-single byte character (and no evidence it can't be UTF-8), done\n if (canBeUTF8 && (utf8bom || utf2BytesChars + utf3BytesChars + utf4BytesChars > 0)) {\n return StringUtils.UTF8;\n }\n // Easy -- if assuming Shift_JIS or at least 3 valid consecutive not-ascii characters (and no evidence it can't be), done\n if (canBeShiftJIS && (StringUtils.ASSUME_SHIFT_JIS || sjisMaxKatakanaWordLength >= 3 || sjisMaxDoubleBytesWordLength >= 3)) {\n return StringUtils.SHIFT_JIS;\n }\n // Distinguishing Shift_JIS and ISO-8859-1 can be a little tough for short words. The crude heuristic is:\n // - If we saw\n // - only two consecutive katakana chars in the whole text, or\n // - at least 10% of bytes that could be \"upper\" not-alphanumeric Latin1,\n // - then we conclude Shift_JIS, else ISO-8859-1\n if (canBeISO88591 && canBeShiftJIS) {\n return (sjisMaxKatakanaWordLength === 2 && sjisKatakanaChars === 2) || isoHighOther * 10 >= length\n ? StringUtils.SHIFT_JIS : StringUtils.ISO88591;\n }\n // Otherwise, try in order ISO-8859-1, Shift JIS, UTF-8 and fall back to default platform encoding\n if (canBeISO88591) {\n return StringUtils.ISO88591;\n }\n if (canBeShiftJIS) {\n return StringUtils.SHIFT_JIS;\n }\n if (canBeUTF8) {\n return StringUtils.UTF8;\n }\n // Otherwise, we take a wild guess with platform encoding\n return StringUtils.PLATFORM_DEFAULT_ENCODING;\n }\n /**\n *\n * @see https://stackoverflow.com/a/13439711/4367683\n *\n * @param append The new string to append.\n * @param args Argumets values to be formated.\n */\n static format(append, ...args) {\n let i = -1;\n function callback(exp, p0, p1, p2, p3, p4) {\n if (exp === '%%')\n return '%';\n if (args[++i] === undefined)\n return undefined;\n exp = p2 ? parseInt(p2.substr(1)) : undefined;\n let base = p3 ? parseInt(p3.substr(1)) : undefined;\n let val;\n switch (p4) {\n case 's':\n val = args[i];\n break;\n case 'c':\n val = args[i][0];\n break;\n case 'f':\n val = parseFloat(args[i]).toFixed(exp);\n break;\n case 'p':\n val = parseFloat(args[i]).toPrecision(exp);\n break;\n case 'e':\n val = parseFloat(args[i]).toExponential(exp);\n break;\n case 'x':\n val = parseInt(args[i]).toString(base ? base : 16);\n break;\n case 'd':\n val = parseFloat(parseInt(args[i], base ? base : 10).toPrecision(exp)).toFixed(0);\n break;\n }\n val = typeof val === 'object' ? JSON.stringify(val) : (+val).toString(base);\n let size = parseInt(p1); /* padding size */\n let ch = p1 && (p1[0] + '') === '0' ? '0' : ' '; /* isnull? */\n while (val.length < size)\n val = p0 !== undefined ? val + ch : ch + val; /* isminus? */\n return val;\n }\n let regex = /%(-)?(0?[0-9]+)?([.][0-9]+)?([#][0-9]+)?([scfpexd%])/g;\n return append.replace(regex, callback);\n }\n /**\n *\n */\n static getBytes(str, encoding) {\n return StringEncoding.encode(str, encoding);\n }\n /**\n * Returns the charcode at the specified index or at index zero.\n */\n static getCharCode(str, index = 0) {\n return str.charCodeAt(index);\n }\n /**\n * Returns char for given charcode\n */\n static getCharAt(charCode) {\n return String.fromCharCode(charCode);\n }\n }\n StringUtils.SHIFT_JIS = CharacterSetECI.SJIS.getName(); // \"SJIS\"\n StringUtils.GB2312 = 'GB2312';\n StringUtils.ISO88591 = CharacterSetECI.ISO8859_1.getName(); // \"ISO8859_1\"\n StringUtils.EUC_JP = 'EUC_JP';\n StringUtils.UTF8 = CharacterSetECI.UTF8.getName(); // \"UTF8\"\n StringUtils.PLATFORM_DEFAULT_ENCODING = StringUtils.UTF8; // \"UTF8\"//Charset.defaultCharset().name()\n StringUtils.ASSUME_SHIFT_JIS = false;\n\n class StringBuilder {\n constructor(value = '') {\n this.value = value;\n }\n enableDecoding(encoding) {\n this.encoding = encoding;\n return this;\n }\n append(s) {\n if (typeof s === 'string') {\n this.value += s.toString();\n }\n else if (this.encoding) {\n // use passed format (fromCharCode will return UTF8 encoding)\n this.value += StringUtils.castAsNonUtf8Char(s, this.encoding);\n }\n else {\n // correctly converts from UTF-8, but not other encodings\n this.value += String.fromCharCode(s);\n }\n return this;\n }\n appendChars(str, offset, len) {\n for (let i = offset; offset < offset + len; i++) {\n this.append(str[i]);\n }\n return this;\n }\n length() {\n return this.value.length;\n }\n charAt(n) {\n return this.value.charAt(n);\n }\n deleteCharAt(n) {\n this.value = this.value.substr(0, n) + this.value.substring(n + 1);\n }\n setCharAt(n, c) {\n this.value = this.value.substr(0, n) + c + this.value.substr(n + 1);\n }\n substring(start, end) {\n return this.value.substring(start, end);\n }\n /**\n * @note helper method for RSS Expanded\n */\n setLengthToZero() {\n this.value = '';\n }\n toString() {\n return this.value;\n }\n insert(n, c) {\n this.value = this.value.substr(0, n) + c + this.value.substr(n + c.length);\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Represents a 2D matrix of bits. In function arguments below, and throughout the common\n * module, x is the column position, and y is the row position. The ordering is always x, y.\n * The origin is at the top-left.

\n *\n *

Internally the bits are represented in a 1-D array of 32-bit ints. However, each row begins\n * with a new int. This is done intentionally so that we can copy out a row into a BitArray very\n * efficiently.

\n *\n *

The ordering of bits is row-major. Within each int, the least significant bits are used first,\n * meaning they represent lower x values. This is compatible with BitArray's implementation.

\n *\n * @author Sean Owen\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class BitMatrix /*implements Cloneable*/ {\n /**\n * Creates an empty square {@link BitMatrix}.\n *\n * @param dimension height and width\n */\n // public constructor(dimension: number /*int*/) {\n // this(dimension, dimension)\n // }\n /**\n * Creates an empty {@link BitMatrix}.\n *\n * @param width bit matrix width\n * @param height bit matrix height\n */\n // public constructor(width: number /*int*/, height: number /*int*/) {\n // if (width < 1 || height < 1) {\n // throw new IllegalArgumentException(\"Both dimensions must be greater than 0\")\n // }\n // this.width = width\n // this.height = height\n // this.rowSize = (width + 31) / 32\n // bits = new int[rowSize * height];\n // }\n constructor(width /*int*/, height /*int*/, rowSize /*int*/, bits) {\n this.width = width;\n this.height = height;\n this.rowSize = rowSize;\n this.bits = bits;\n if (undefined === height || null === height) {\n height = width;\n }\n this.height = height;\n if (width < 1 || height < 1) {\n throw new IllegalArgumentException('Both dimensions must be greater than 0');\n }\n if (undefined === rowSize || null === rowSize) {\n rowSize = Math.floor((width + 31) / 32);\n }\n this.rowSize = rowSize;\n if (undefined === bits || null === bits) {\n this.bits = new Int32Array(this.rowSize * this.height);\n }\n }\n /**\n * Interprets a 2D array of booleans as a {@link BitMatrix}, where \"true\" means an \"on\" bit.\n *\n * @function parse\n * @param image bits of the image, as a row-major 2D array. Elements are arrays representing rows\n * @return {@link BitMatrix} representation of image\n */\n static parseFromBooleanArray(image) {\n const height = image.length;\n const width = image[0].length;\n const bits = new BitMatrix(width, height);\n for (let i = 0; i < height; i++) {\n const imageI = image[i];\n for (let j = 0; j < width; j++) {\n if (imageI[j]) {\n bits.set(j, i);\n }\n }\n }\n return bits;\n }\n /**\n *\n * @function parse\n * @param stringRepresentation\n * @param setString\n * @param unsetString\n */\n static parseFromString(stringRepresentation, setString, unsetString) {\n if (stringRepresentation === null) {\n throw new IllegalArgumentException('stringRepresentation cannot be null');\n }\n const bits = new Array(stringRepresentation.length);\n let bitsPos = 0;\n let rowStartPos = 0;\n let rowLength = -1;\n let nRows = 0;\n let pos = 0;\n while (pos < stringRepresentation.length) {\n if (stringRepresentation.charAt(pos) === '\\n' ||\n stringRepresentation.charAt(pos) === '\\r') {\n if (bitsPos > rowStartPos) {\n if (rowLength === -1) {\n rowLength = bitsPos - rowStartPos;\n }\n else if (bitsPos - rowStartPos !== rowLength) {\n throw new IllegalArgumentException('row lengths do not match');\n }\n rowStartPos = bitsPos;\n nRows++;\n }\n pos++;\n }\n else if (stringRepresentation.substring(pos, pos + setString.length) === setString) {\n pos += setString.length;\n bits[bitsPos] = true;\n bitsPos++;\n }\n else if (stringRepresentation.substring(pos, pos + unsetString.length) === unsetString) {\n pos += unsetString.length;\n bits[bitsPos] = false;\n bitsPos++;\n }\n else {\n throw new IllegalArgumentException('illegal character encountered: ' + stringRepresentation.substring(pos));\n }\n }\n // no EOL at end?\n if (bitsPos > rowStartPos) {\n if (rowLength === -1) {\n rowLength = bitsPos - rowStartPos;\n }\n else if (bitsPos - rowStartPos !== rowLength) {\n throw new IllegalArgumentException('row lengths do not match');\n }\n nRows++;\n }\n const matrix = new BitMatrix(rowLength, nRows);\n for (let i = 0; i < bitsPos; i++) {\n if (bits[i]) {\n matrix.set(Math.floor(i % rowLength), Math.floor(i / rowLength));\n }\n }\n return matrix;\n }\n /**\n *

Gets the requested bit, where true means black.

\n *\n * @param x The horizontal component (i.e. which column)\n * @param y The vertical component (i.e. which row)\n * @return value of given bit in matrix\n */\n get(x /*int*/, y /*int*/) {\n const offset = y * this.rowSize + Math.floor(x / 32);\n return ((this.bits[offset] >>> (x & 0x1f)) & 1) !== 0;\n }\n /**\n *

Sets the given bit to true.

\n *\n * @param x The horizontal component (i.e. which column)\n * @param y The vertical component (i.e. which row)\n */\n set(x /*int*/, y /*int*/) {\n const offset = y * this.rowSize + Math.floor(x / 32);\n this.bits[offset] |= (1 << (x & 0x1f)) & 0xFFFFFFFF;\n }\n unset(x /*int*/, y /*int*/) {\n const offset = y * this.rowSize + Math.floor(x / 32);\n this.bits[offset] &= ~((1 << (x & 0x1f)) & 0xFFFFFFFF);\n }\n /**\n *

Flips the given bit.

\n *\n * @param x The horizontal component (i.e. which column)\n * @param y The vertical component (i.e. which row)\n */\n flip(x /*int*/, y /*int*/) {\n const offset = y * this.rowSize + Math.floor(x / 32);\n this.bits[offset] ^= ((1 << (x & 0x1f)) & 0xFFFFFFFF);\n }\n /**\n * Exclusive-or (XOR): Flip the bit in this {@code BitMatrix} if the corresponding\n * mask bit is set.\n *\n * @param mask XOR mask\n */\n xor(mask) {\n if (this.width !== mask.getWidth() || this.height !== mask.getHeight()\n || this.rowSize !== mask.getRowSize()) {\n throw new IllegalArgumentException('input matrix dimensions do not match');\n }\n const rowArray = new BitArray(Math.floor(this.width / 32) + 1);\n const rowSize = this.rowSize;\n const bits = this.bits;\n for (let y = 0, height = this.height; y < height; y++) {\n const offset = y * rowSize;\n const row = mask.getRow(y, rowArray).getBitArray();\n for (let x = 0; x < rowSize; x++) {\n bits[offset + x] ^= row[x];\n }\n }\n }\n /**\n * Clears all bits (sets to false).\n */\n clear() {\n const bits = this.bits;\n const max = bits.length;\n for (let i = 0; i < max; i++) {\n bits[i] = 0;\n }\n }\n /**\n *

Sets a square region of the bit matrix to true.

\n *\n * @param left The horizontal position to begin at (inclusive)\n * @param top The vertical position to begin at (inclusive)\n * @param width The width of the region\n * @param height The height of the region\n */\n setRegion(left /*int*/, top /*int*/, width /*int*/, height /*int*/) {\n if (top < 0 || left < 0) {\n throw new IllegalArgumentException('Left and top must be nonnegative');\n }\n if (height < 1 || width < 1) {\n throw new IllegalArgumentException('Height and width must be at least 1');\n }\n const right = left + width;\n const bottom = top + height;\n if (bottom > this.height || right > this.width) {\n throw new IllegalArgumentException('The region must fit inside the matrix');\n }\n const rowSize = this.rowSize;\n const bits = this.bits;\n for (let y = top; y < bottom; y++) {\n const offset = y * rowSize;\n for (let x = left; x < right; x++) {\n bits[offset + Math.floor(x / 32)] |= ((1 << (x & 0x1f)) & 0xFFFFFFFF);\n }\n }\n }\n /**\n * A fast method to retrieve one row of data from the matrix as a BitArray.\n *\n * @param y The row to retrieve\n * @param row An optional caller-allocated BitArray, will be allocated if null or too small\n * @return The resulting BitArray - this reference should always be used even when passing\n * your own row\n */\n getRow(y /*int*/, row) {\n if (row === null || row === undefined || row.getSize() < this.width) {\n row = new BitArray(this.width);\n }\n else {\n row.clear();\n }\n const rowSize = this.rowSize;\n const bits = this.bits;\n const offset = y * rowSize;\n for (let x = 0; x < rowSize; x++) {\n row.setBulk(x * 32, bits[offset + x]);\n }\n return row;\n }\n /**\n * @param y row to set\n * @param row {@link BitArray} to copy from\n */\n setRow(y /*int*/, row) {\n System.arraycopy(row.getBitArray(), 0, this.bits, y * this.rowSize, this.rowSize);\n }\n /**\n * Modifies this {@code BitMatrix} to represent the same but rotated 180 degrees\n */\n rotate180() {\n const width = this.getWidth();\n const height = this.getHeight();\n let topRow = new BitArray(width);\n let bottomRow = new BitArray(width);\n for (let i = 0, length = Math.floor((height + 1) / 2); i < length; i++) {\n topRow = this.getRow(i, topRow);\n bottomRow = this.getRow(height - 1 - i, bottomRow);\n topRow.reverse();\n bottomRow.reverse();\n this.setRow(i, bottomRow);\n this.setRow(height - 1 - i, topRow);\n }\n }\n /**\n * This is useful in detecting the enclosing rectangle of a 'pure' barcode.\n *\n * @return {@code left,top,width,height} enclosing rectangle of all 1 bits, or null if it is all white\n */\n getEnclosingRectangle() {\n const width = this.width;\n const height = this.height;\n const rowSize = this.rowSize;\n const bits = this.bits;\n let left = width;\n let top = height;\n let right = -1;\n let bottom = -1;\n for (let y = 0; y < height; y++) {\n for (let x32 = 0; x32 < rowSize; x32++) {\n const theBits = bits[y * rowSize + x32];\n if (theBits !== 0) {\n if (y < top) {\n top = y;\n }\n if (y > bottom) {\n bottom = y;\n }\n if (x32 * 32 < left) {\n let bit = 0;\n while (((theBits << (31 - bit)) & 0xFFFFFFFF) === 0) {\n bit++;\n }\n if ((x32 * 32 + bit) < left) {\n left = x32 * 32 + bit;\n }\n }\n if (x32 * 32 + 31 > right) {\n let bit = 31;\n while ((theBits >>> bit) === 0) {\n bit--;\n }\n if ((x32 * 32 + bit) > right) {\n right = x32 * 32 + bit;\n }\n }\n }\n }\n }\n if (right < left || bottom < top) {\n return null;\n }\n return Int32Array.from([left, top, right - left + 1, bottom - top + 1]);\n }\n /**\n * This is useful in detecting a corner of a 'pure' barcode.\n *\n * @return {@code x,y} coordinate of top-left-most 1 bit, or null if it is all white\n */\n getTopLeftOnBit() {\n const rowSize = this.rowSize;\n const bits = this.bits;\n let bitsOffset = 0;\n while (bitsOffset < bits.length && bits[bitsOffset] === 0) {\n bitsOffset++;\n }\n if (bitsOffset === bits.length) {\n return null;\n }\n const y = bitsOffset / rowSize;\n let x = (bitsOffset % rowSize) * 32;\n const theBits = bits[bitsOffset];\n let bit = 0;\n while (((theBits << (31 - bit)) & 0xFFFFFFFF) === 0) {\n bit++;\n }\n x += bit;\n return Int32Array.from([x, y]);\n }\n getBottomRightOnBit() {\n const rowSize = this.rowSize;\n const bits = this.bits;\n let bitsOffset = bits.length - 1;\n while (bitsOffset >= 0 && bits[bitsOffset] === 0) {\n bitsOffset--;\n }\n if (bitsOffset < 0) {\n return null;\n }\n const y = Math.floor(bitsOffset / rowSize);\n let x = Math.floor(bitsOffset % rowSize) * 32;\n const theBits = bits[bitsOffset];\n let bit = 31;\n while ((theBits >>> bit) === 0) {\n bit--;\n }\n x += bit;\n return Int32Array.from([x, y]);\n }\n /**\n * @return The width of the matrix\n */\n getWidth() {\n return this.width;\n }\n /**\n * @return The height of the matrix\n */\n getHeight() {\n return this.height;\n }\n /**\n * @return The row size of the matrix\n */\n getRowSize() {\n return this.rowSize;\n }\n /*@Override*/\n equals(o) {\n if (!(o instanceof BitMatrix)) {\n return false;\n }\n const other = o;\n return this.width === other.width && this.height === other.height && this.rowSize === other.rowSize &&\n Arrays.equals(this.bits, other.bits);\n }\n /*@Override*/\n hashCode() {\n let hash = this.width;\n hash = 31 * hash + this.width;\n hash = 31 * hash + this.height;\n hash = 31 * hash + this.rowSize;\n hash = 31 * hash + Arrays.hashCode(this.bits);\n return hash;\n }\n /**\n * @return string representation using \"X\" for set and \" \" for unset bits\n */\n /*@Override*/\n // public toString(): string {\n // return toString(\": \"X, \" \")\n // }\n /**\n * @param setString representation of a set bit\n * @param unsetString representation of an unset bit\n * @return string representation of entire matrix utilizing given strings\n */\n // public toString(setString: string = \"X \", unsetString: string = \" \"): string {\n // return this.buildToString(setString, unsetString, \"\\n\")\n // }\n /**\n * @param setString representation of a set bit\n * @param unsetString representation of an unset bit\n * @param lineSeparator newline character in string representation\n * @return string representation of entire matrix utilizing given strings and line separator\n * @deprecated call {@link #toString(String,String)} only, which uses \\n line separator always\n */\n // @Deprecated\n toString(setString = 'X ', unsetString = ' ', lineSeparator = '\\n') {\n return this.buildToString(setString, unsetString, lineSeparator);\n }\n buildToString(setString, unsetString, lineSeparator) {\n let result = new StringBuilder();\n // result.append(lineSeparator);\n for (let y = 0, height = this.height; y < height; y++) {\n for (let x = 0, width = this.width; x < width; x++) {\n result.append(this.get(x, y) ? setString : unsetString);\n }\n result.append(lineSeparator);\n }\n return result.toString();\n }\n /*@Override*/\n clone() {\n return new BitMatrix(this.width, this.height, this.rowSize, this.bits.slice());\n }\n }\n\n /**\n * Custom Error class of type Exception.\n */\n class NotFoundException extends Exception {\n static getNotFoundInstance() {\n return new NotFoundException();\n }\n }\n NotFoundException.kind = 'NotFoundException';\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * This Binarizer implementation uses the old ZXing global histogram approach. It is suitable\n * for low-end mobile devices which don't have enough CPU or memory to use a local thresholding\n * algorithm. However, because it picks a global black point, it cannot handle difficult shadows\n * and gradients.\n *\n * Faster mobile devices and all desktop applications should probably use HybridBinarizer instead.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n * @author Sean Owen\n */\n class GlobalHistogramBinarizer extends Binarizer {\n constructor(source) {\n super(source);\n this.luminances = GlobalHistogramBinarizer.EMPTY;\n this.buckets = new Int32Array(GlobalHistogramBinarizer.LUMINANCE_BUCKETS);\n }\n // Applies simple sharpening to the row data to improve performance of the 1D Readers.\n /*@Override*/\n getBlackRow(y /*int*/, row) {\n const source = this.getLuminanceSource();\n const width = source.getWidth();\n if (row === undefined || row === null || row.getSize() < width) {\n row = new BitArray(width);\n }\n else {\n row.clear();\n }\n this.initArrays(width);\n const localLuminances = source.getRow(y, this.luminances);\n const localBuckets = this.buckets;\n for (let x = 0; x < width; x++) {\n localBuckets[(localLuminances[x] & 0xff) >> GlobalHistogramBinarizer.LUMINANCE_SHIFT]++;\n }\n const blackPoint = GlobalHistogramBinarizer.estimateBlackPoint(localBuckets);\n if (width < 3) {\n // Special case for very small images\n for (let x = 0; x < width; x++) {\n if ((localLuminances[x] & 0xff) < blackPoint) {\n row.set(x);\n }\n }\n }\n else {\n let left = localLuminances[0] & 0xff;\n let center = localLuminances[1] & 0xff;\n for (let x = 1; x < width - 1; x++) {\n const right = localLuminances[x + 1] & 0xff;\n // A simple -1 4 -1 box filter with a weight of 2.\n if (((center * 4) - left - right) / 2 < blackPoint) {\n row.set(x);\n }\n left = center;\n center = right;\n }\n }\n return row;\n }\n // Does not sharpen the data, as this call is intended to only be used by 2D Readers.\n /*@Override*/\n getBlackMatrix() {\n const source = this.getLuminanceSource();\n const width = source.getWidth();\n const height = source.getHeight();\n const matrix = new BitMatrix(width, height);\n // Quickly calculates the histogram by sampling four rows from the image. This proved to be\n // more robust on the blackbox tests than sampling a diagonal as we used to do.\n this.initArrays(width);\n const localBuckets = this.buckets;\n for (let y = 1; y < 5; y++) {\n const row = Math.floor((height * y) / 5);\n const localLuminances = source.getRow(row, this.luminances);\n const right = Math.floor((width * 4) / 5);\n for (let x = Math.floor(width / 5); x < right; x++) {\n const pixel = localLuminances[x] & 0xff;\n localBuckets[pixel >> GlobalHistogramBinarizer.LUMINANCE_SHIFT]++;\n }\n }\n const blackPoint = GlobalHistogramBinarizer.estimateBlackPoint(localBuckets);\n // We delay reading the entire image luminance until the black point estimation succeeds.\n // Although we end up reading four rows twice, it is consistent with our motto of\n // \"fail quickly\" which is necessary for continuous scanning.\n const localLuminances = source.getMatrix();\n for (let y = 0; y < height; y++) {\n const offset = y * width;\n for (let x = 0; x < width; x++) {\n const pixel = localLuminances[offset + x] & 0xff;\n if (pixel < blackPoint) {\n matrix.set(x, y);\n }\n }\n }\n return matrix;\n }\n /*@Override*/\n createBinarizer(source) {\n return new GlobalHistogramBinarizer(source);\n }\n initArrays(luminanceSize /*int*/) {\n if (this.luminances.length < luminanceSize) {\n this.luminances = new Uint8ClampedArray(luminanceSize);\n }\n const buckets = this.buckets;\n for (let x = 0; x < GlobalHistogramBinarizer.LUMINANCE_BUCKETS; x++) {\n buckets[x] = 0;\n }\n }\n static estimateBlackPoint(buckets) {\n // Find the tallest peak in the histogram.\n const numBuckets = buckets.length;\n let maxBucketCount = 0;\n let firstPeak = 0;\n let firstPeakSize = 0;\n for (let x = 0; x < numBuckets; x++) {\n if (buckets[x] > firstPeakSize) {\n firstPeak = x;\n firstPeakSize = buckets[x];\n }\n if (buckets[x] > maxBucketCount) {\n maxBucketCount = buckets[x];\n }\n }\n // Find the second-tallest peak which is somewhat far from the tallest peak.\n let secondPeak = 0;\n let secondPeakScore = 0;\n for (let x = 0; x < numBuckets; x++) {\n const distanceToBiggest = x - firstPeak;\n // Encourage more distant second peaks by multiplying by square of distance.\n const score = buckets[x] * distanceToBiggest * distanceToBiggest;\n if (score > secondPeakScore) {\n secondPeak = x;\n secondPeakScore = score;\n }\n }\n // Make sure firstPeak corresponds to the black peak.\n if (firstPeak > secondPeak) {\n const temp = firstPeak;\n firstPeak = secondPeak;\n secondPeak = temp;\n }\n // If there is too little contrast in the image to pick a meaningful black point, throw rather\n // than waste time trying to decode the image, and risk false positives.\n if (secondPeak - firstPeak <= numBuckets / 16) {\n throw new NotFoundException();\n }\n // Find a valley between them that is low and closer to the white peak.\n let bestValley = secondPeak - 1;\n let bestValleyScore = -1;\n for (let x = secondPeak - 1; x > firstPeak; x--) {\n const fromFirst = x - firstPeak;\n const score = fromFirst * fromFirst * (secondPeak - x) * (maxBucketCount - buckets[x]);\n if (score > bestValleyScore) {\n bestValley = x;\n bestValleyScore = score;\n }\n }\n return bestValley << GlobalHistogramBinarizer.LUMINANCE_SHIFT;\n }\n }\n GlobalHistogramBinarizer.LUMINANCE_BITS = 5;\n GlobalHistogramBinarizer.LUMINANCE_SHIFT = 8 - GlobalHistogramBinarizer.LUMINANCE_BITS;\n GlobalHistogramBinarizer.LUMINANCE_BUCKETS = 1 << GlobalHistogramBinarizer.LUMINANCE_BITS;\n GlobalHistogramBinarizer.EMPTY = Uint8ClampedArray.from([0]);\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * This class implements a local thresholding algorithm, which while slower than the\n * GlobalHistogramBinarizer, is fairly efficient for what it does. It is designed for\n * high frequency images of barcodes with black data on white backgrounds. For this application,\n * it does a much better job than a global blackpoint with severe shadows and gradients.\n * However it tends to produce artifacts on lower frequency images and is therefore not\n * a good general purpose binarizer for uses outside ZXing.\n *\n * This class extends GlobalHistogramBinarizer, using the older histogram approach for 1D readers,\n * and the newer local approach for 2D readers. 1D decoding using a per-row histogram is already\n * inherently local, and only fails for horizontal gradients. We can revisit that problem later,\n * but for now it was not a win to use local blocks for 1D.\n *\n * This Binarizer is the default for the unit tests and the recommended class for library users.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class HybridBinarizer extends GlobalHistogramBinarizer {\n constructor(source) {\n super(source);\n this.matrix = null;\n }\n /**\n * Calculates the final BitMatrix once for all requests. This could be called once from the\n * constructor instead, but there are some advantages to doing it lazily, such as making\n * profiling easier, and not doing heavy lifting when callers don't expect it.\n */\n /*@Override*/\n getBlackMatrix() {\n if (this.matrix !== null) {\n return this.matrix;\n }\n const source = this.getLuminanceSource();\n const width = source.getWidth();\n const height = source.getHeight();\n if (width >= HybridBinarizer.MINIMUM_DIMENSION && height >= HybridBinarizer.MINIMUM_DIMENSION) {\n const luminances = source.getMatrix();\n let subWidth = width >> HybridBinarizer.BLOCK_SIZE_POWER;\n if ((width & HybridBinarizer.BLOCK_SIZE_MASK) !== 0) {\n subWidth++;\n }\n let subHeight = height >> HybridBinarizer.BLOCK_SIZE_POWER;\n if ((height & HybridBinarizer.BLOCK_SIZE_MASK) !== 0) {\n subHeight++;\n }\n const blackPoints = HybridBinarizer.calculateBlackPoints(luminances, subWidth, subHeight, width, height);\n const newMatrix = new BitMatrix(width, height);\n HybridBinarizer.calculateThresholdForBlock(luminances, subWidth, subHeight, width, height, blackPoints, newMatrix);\n this.matrix = newMatrix;\n }\n else {\n // If the image is too small, fall back to the global histogram approach.\n this.matrix = super.getBlackMatrix();\n }\n return this.matrix;\n }\n /*@Override*/\n createBinarizer(source) {\n return new HybridBinarizer(source);\n }\n /**\n * For each block in the image, calculate the average black point using a 5x5 grid\n * of the blocks around it. Also handles the corner cases (fractional blocks are computed based\n * on the last pixels in the row/column which are also used in the previous block).\n */\n static calculateThresholdForBlock(luminances, subWidth /*int*/, subHeight /*int*/, width /*int*/, height /*int*/, blackPoints, matrix) {\n const maxYOffset = height - HybridBinarizer.BLOCK_SIZE;\n const maxXOffset = width - HybridBinarizer.BLOCK_SIZE;\n for (let y = 0; y < subHeight; y++) {\n let yoffset = y << HybridBinarizer.BLOCK_SIZE_POWER;\n if (yoffset > maxYOffset) {\n yoffset = maxYOffset;\n }\n const top = HybridBinarizer.cap(y, 2, subHeight - 3);\n for (let x = 0; x < subWidth; x++) {\n let xoffset = x << HybridBinarizer.BLOCK_SIZE_POWER;\n if (xoffset > maxXOffset) {\n xoffset = maxXOffset;\n }\n const left = HybridBinarizer.cap(x, 2, subWidth - 3);\n let sum = 0;\n for (let z = -2; z <= 2; z++) {\n const blackRow = blackPoints[top + z];\n sum += blackRow[left - 2] + blackRow[left - 1] + blackRow[left] + blackRow[left + 1] + blackRow[left + 2];\n }\n const average = sum / 25;\n HybridBinarizer.thresholdBlock(luminances, xoffset, yoffset, average, width, matrix);\n }\n }\n }\n static cap(value /*int*/, min /*int*/, max /*int*/) {\n return value < min ? min : value > max ? max : value;\n }\n /**\n * Applies a single threshold to a block of pixels.\n */\n static thresholdBlock(luminances, xoffset /*int*/, yoffset /*int*/, threshold /*int*/, stride /*int*/, matrix) {\n for (let y = 0, offset = yoffset * stride + xoffset; y < HybridBinarizer.BLOCK_SIZE; y++, offset += stride) {\n for (let x = 0; x < HybridBinarizer.BLOCK_SIZE; x++) {\n // Comparison needs to be <= so that black == 0 pixels are black even if the threshold is 0.\n if ((luminances[offset + x] & 0xFF) <= threshold) {\n matrix.set(xoffset + x, yoffset + y);\n }\n }\n }\n }\n /**\n * Calculates a single black point for each block of pixels and saves it away.\n * See the following thread for a discussion of this algorithm:\n * http://groups.google.com/group/zxing/browse_thread/thread/d06efa2c35a7ddc0\n */\n static calculateBlackPoints(luminances, subWidth /*int*/, subHeight /*int*/, width /*int*/, height /*int*/) {\n const maxYOffset = height - HybridBinarizer.BLOCK_SIZE;\n const maxXOffset = width - HybridBinarizer.BLOCK_SIZE;\n // tslint:disable-next-line:whitespace\n const blackPoints = new Array(subHeight); // subWidth\n for (let y = 0; y < subHeight; y++) {\n blackPoints[y] = new Int32Array(subWidth);\n let yoffset = y << HybridBinarizer.BLOCK_SIZE_POWER;\n if (yoffset > maxYOffset) {\n yoffset = maxYOffset;\n }\n for (let x = 0; x < subWidth; x++) {\n let xoffset = x << HybridBinarizer.BLOCK_SIZE_POWER;\n if (xoffset > maxXOffset) {\n xoffset = maxXOffset;\n }\n let sum = 0;\n let min = 0xFF;\n let max = 0;\n for (let yy = 0, offset = yoffset * width + xoffset; yy < HybridBinarizer.BLOCK_SIZE; yy++, offset += width) {\n for (let xx = 0; xx < HybridBinarizer.BLOCK_SIZE; xx++) {\n const pixel = luminances[offset + xx] & 0xFF;\n sum += pixel;\n // still looking for good contrast\n if (pixel < min) {\n min = pixel;\n }\n if (pixel > max) {\n max = pixel;\n }\n }\n // short-circuit min/max tests once dynamic range is met\n if (max - min > HybridBinarizer.MIN_DYNAMIC_RANGE) {\n // finish the rest of the rows quickly\n for (yy++, offset += width; yy < HybridBinarizer.BLOCK_SIZE; yy++, offset += width) {\n for (let xx = 0; xx < HybridBinarizer.BLOCK_SIZE; xx++) {\n sum += luminances[offset + xx] & 0xFF;\n }\n }\n }\n }\n // The default estimate is the average of the values in the block.\n let average = sum >> (HybridBinarizer.BLOCK_SIZE_POWER * 2);\n if (max - min <= HybridBinarizer.MIN_DYNAMIC_RANGE) {\n // If variation within the block is low, assume this is a block with only light or only\n // dark pixels. In that case we do not want to use the average, as it would divide this\n // low contrast area into black and white pixels, essentially creating data out of noise.\n //\n // The default assumption is that the block is light/background. Since no estimate for\n // the level of dark pixels exists locally, use half the min for the block.\n average = min / 2;\n if (y > 0 && x > 0) {\n // Correct the \"white background\" assumption for blocks that have neighbors by comparing\n // the pixels in this block to the previously calculated black points. This is based on\n // the fact that dark barcode symbology is always surrounded by some amount of light\n // background for which reasonable black point estimates were made. The bp estimated at\n // the boundaries is used for the interior.\n // The (min < bp) is arbitrary but works better than other heuristics that were tried.\n const averageNeighborBlackPoint = (blackPoints[y - 1][x] + (2 * blackPoints[y][x - 1]) + blackPoints[y - 1][x - 1]) / 4;\n if (min < averageNeighborBlackPoint) {\n average = averageNeighborBlackPoint;\n }\n }\n }\n blackPoints[y][x] = average;\n }\n }\n return blackPoints;\n }\n }\n // This class uses 5x5 blocks to compute local luminance, where each block is 8x8 pixels.\n // So this is the smallest dimension in each axis we can accept.\n HybridBinarizer.BLOCK_SIZE_POWER = 3;\n HybridBinarizer.BLOCK_SIZE = 1 << HybridBinarizer.BLOCK_SIZE_POWER; // ...0100...00\n HybridBinarizer.BLOCK_SIZE_MASK = HybridBinarizer.BLOCK_SIZE - 1; // ...0011...11\n HybridBinarizer.MINIMUM_DIMENSION = HybridBinarizer.BLOCK_SIZE * 5;\n HybridBinarizer.MIN_DYNAMIC_RANGE = 24;\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing {*/\n /**\n * The purpose of this class hierarchy is to abstract different bitmap implementations across\n * platforms into a standard interface for requesting greyscale luminance values. The interface\n * only provides immutable methods; therefore crop and rotation create copies. This is to ensure\n * that one Reader does not modify the original luminance source and leave it in an unknown state\n * for other Readers in the chain.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class LuminanceSource {\n constructor(width /*int*/, height /*int*/) {\n this.width = width;\n this.height = height;\n }\n /**\n * @return The width of the bitmap.\n */\n getWidth() {\n return this.width;\n }\n /**\n * @return The height of the bitmap.\n */\n getHeight() {\n return this.height;\n }\n /**\n * @return Whether this subclass supports cropping.\n */\n isCropSupported() {\n return false;\n }\n /**\n * Returns a new object with cropped image data. Implementations may keep a reference to the\n * original data rather than a copy. Only callable if isCropSupported() is true.\n *\n * @param left The left coordinate, which must be in [0,getWidth())\n * @param top The top coordinate, which must be in [0,getHeight())\n * @param width The width of the rectangle to crop.\n * @param height The height of the rectangle to crop.\n * @return A cropped version of this object.\n */\n crop(left /*int*/, top /*int*/, width /*int*/, height /*int*/) {\n throw new UnsupportedOperationException('This luminance source does not support cropping.');\n }\n /**\n * @return Whether this subclass supports counter-clockwise rotation.\n */\n isRotateSupported() {\n return false;\n }\n /**\n * Returns a new object with rotated image data by 90 degrees counterclockwise.\n * Only callable if {@link #isRotateSupported()} is true.\n *\n * @return A rotated version of this object.\n */\n rotateCounterClockwise() {\n throw new UnsupportedOperationException('This luminance source does not support rotation by 90 degrees.');\n }\n /**\n * Returns a new object with rotated image data by 45 degrees counterclockwise.\n * Only callable if {@link #isRotateSupported()} is true.\n *\n * @return A rotated version of this object.\n */\n rotateCounterClockwise45() {\n throw new UnsupportedOperationException('This luminance source does not support rotation by 45 degrees.');\n }\n /*@Override*/\n toString() {\n const row = new Uint8ClampedArray(this.width);\n let result = new StringBuilder();\n for (let y = 0; y < this.height; y++) {\n const sourceRow = this.getRow(y, row);\n for (let x = 0; x < this.width; x++) {\n const luminance = sourceRow[x] & 0xFF;\n let c;\n if (luminance < 0x40) {\n c = '#';\n }\n else if (luminance < 0x80) {\n c = '+';\n }\n else if (luminance < 0xC0) {\n c = '.';\n }\n else {\n c = ' ';\n }\n result.append(c);\n }\n result.append('\\n');\n }\n return result.toString();\n }\n }\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing {*/\n /**\n * A wrapper implementation of {@link LuminanceSource} which inverts the luminances it returns -- black becomes\n * white and vice versa, and each value becomes (255-value).\n *\n * @author Sean Owen\n */\n class InvertedLuminanceSource extends LuminanceSource {\n constructor(delegate) {\n super(delegate.getWidth(), delegate.getHeight());\n this.delegate = delegate;\n }\n /*@Override*/\n getRow(y /*int*/, row) {\n const sourceRow = this.delegate.getRow(y, row);\n const width = this.getWidth();\n for (let i = 0; i < width; i++) {\n sourceRow[i] = /*(byte)*/ (255 - (sourceRow[i] & 0xFF));\n }\n return sourceRow;\n }\n /*@Override*/\n getMatrix() {\n const matrix = this.delegate.getMatrix();\n const length = this.getWidth() * this.getHeight();\n const invertedMatrix = new Uint8ClampedArray(length);\n for (let i = 0; i < length; i++) {\n invertedMatrix[i] = /*(byte)*/ (255 - (matrix[i] & 0xFF));\n }\n return invertedMatrix;\n }\n /*@Override*/\n isCropSupported() {\n return this.delegate.isCropSupported();\n }\n /*@Override*/\n crop(left /*int*/, top /*int*/, width /*int*/, height /*int*/) {\n return new InvertedLuminanceSource(this.delegate.crop(left, top, width, height));\n }\n /*@Override*/\n isRotateSupported() {\n return this.delegate.isRotateSupported();\n }\n /**\n * @return original delegate {@link LuminanceSource} since invert undoes itself\n */\n /*@Override*/\n invert() {\n return this.delegate;\n }\n /*@Override*/\n rotateCounterClockwise() {\n return new InvertedLuminanceSource(this.delegate.rotateCounterClockwise());\n }\n /*@Override*/\n rotateCounterClockwise45() {\n return new InvertedLuminanceSource(this.delegate.rotateCounterClockwise45());\n }\n }\n\n /**\n * @deprecated Moving to @zxing/browser\n */\n class HTMLCanvasElementLuminanceSource extends LuminanceSource {\n constructor(canvas) {\n super(canvas.width, canvas.height);\n this.canvas = canvas;\n this.tempCanvasElement = null;\n this.buffer = HTMLCanvasElementLuminanceSource.makeBufferFromCanvasImageData(canvas);\n }\n static makeBufferFromCanvasImageData(canvas) {\n const imageData = canvas.getContext('2d').getImageData(0, 0, canvas.width, canvas.height);\n return HTMLCanvasElementLuminanceSource.toGrayscaleBuffer(imageData.data, canvas.width, canvas.height);\n }\n static toGrayscaleBuffer(imageBuffer, width, height) {\n const grayscaleBuffer = new Uint8ClampedArray(width * height);\n for (let i = 0, j = 0, length = imageBuffer.length; i < length; i += 4, j++) {\n let gray;\n const alpha = imageBuffer[i + 3];\n // The color of fully-transparent pixels is irrelevant. They are often, technically, fully-transparent\n // black (0 alpha, and then 0 RGB). They are often used, of course as the \"white\" area in a\n // barcode image. Force any such pixel to be white:\n if (alpha === 0) {\n gray = 0xFF;\n }\n else {\n const pixelR = imageBuffer[i];\n const pixelG = imageBuffer[i + 1];\n const pixelB = imageBuffer[i + 2];\n // .299R + 0.587G + 0.114B (YUV/YIQ for PAL and NTSC),\n // (306*R) >> 10 is approximately equal to R*0.299, and so on.\n // 0x200 >> 10 is 0.5, it implements rounding.\n gray = (306 * pixelR +\n 601 * pixelG +\n 117 * pixelB +\n 0x200) >> 10;\n }\n grayscaleBuffer[j] = gray;\n }\n return grayscaleBuffer;\n }\n getRow(y /*int*/, row) {\n if (y < 0 || y >= this.getHeight()) {\n throw new IllegalArgumentException('Requested row is outside the image: ' + y);\n }\n const width = this.getWidth();\n const start = y * width;\n if (row === null) {\n row = this.buffer.slice(start, start + width);\n }\n else {\n if (row.length < width) {\n row = new Uint8ClampedArray(width);\n }\n // The underlying raster of image consists of bytes with the luminance values\n // TODO: can avoid set/slice?\n row.set(this.buffer.slice(start, start + width));\n }\n return row;\n }\n getMatrix() {\n return this.buffer;\n }\n isCropSupported() {\n return true;\n }\n crop(left /*int*/, top /*int*/, width /*int*/, height /*int*/) {\n super.crop(left, top, width, height);\n return this;\n }\n /**\n * This is always true, since the image is a gray-scale image.\n *\n * @return true\n */\n isRotateSupported() {\n return true;\n }\n rotateCounterClockwise() {\n this.rotate(-90);\n return this;\n }\n rotateCounterClockwise45() {\n this.rotate(-45);\n return this;\n }\n getTempCanvasElement() {\n if (null === this.tempCanvasElement) {\n const tempCanvasElement = this.canvas.ownerDocument.createElement('canvas');\n tempCanvasElement.width = this.canvas.width;\n tempCanvasElement.height = this.canvas.height;\n this.tempCanvasElement = tempCanvasElement;\n }\n return this.tempCanvasElement;\n }\n rotate(angle) {\n const tempCanvasElement = this.getTempCanvasElement();\n const tempContext = tempCanvasElement.getContext('2d');\n const angleRadians = angle * HTMLCanvasElementLuminanceSource.DEGREE_TO_RADIANS;\n // Calculate and set new dimensions for temp canvas\n const width = this.canvas.width;\n const height = this.canvas.height;\n const newWidth = Math.ceil(Math.abs(Math.cos(angleRadians)) * width + Math.abs(Math.sin(angleRadians)) * height);\n const newHeight = Math.ceil(Math.abs(Math.sin(angleRadians)) * width + Math.abs(Math.cos(angleRadians)) * height);\n tempCanvasElement.width = newWidth;\n tempCanvasElement.height = newHeight;\n // Draw at center of temp canvas to prevent clipping of image data\n tempContext.translate(newWidth / 2, newHeight / 2);\n tempContext.rotate(angleRadians);\n tempContext.drawImage(this.canvas, width / -2, height / -2);\n this.buffer = HTMLCanvasElementLuminanceSource.makeBufferFromCanvasImageData(tempCanvasElement);\n return this;\n }\n invert() {\n return new InvertedLuminanceSource(this);\n }\n }\n HTMLCanvasElementLuminanceSource.DEGREE_TO_RADIANS = Math.PI / 180;\n\n /**\n * @deprecated Moving to @zxing/browser\n *\n * Video input device metadata containing the id and label of the device if available.\n */\n class VideoInputDevice {\n /**\n * Creates an instance of VideoInputDevice.\n *\n * @param {string} deviceId the video input device id\n * @param {string} label the label of the device if available\n */\n constructor(deviceId, label, groupId) {\n this.deviceId = deviceId;\n this.label = label;\n /** @inheritdoc */\n this.kind = 'videoinput';\n this.groupId = groupId || undefined;\n }\n /** @inheritdoc */\n toJSON() {\n return {\n kind: this.kind,\n groupId: this.groupId,\n deviceId: this.deviceId,\n label: this.label,\n };\n }\n }\n\n var __awaiter = ((globalThis || global || self || window || undefined) && (globalThis || global || self || window || undefined).__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n };\n /**\n * @deprecated Moving to @zxing/browser\n *\n * Base class for browser code reader.\n */\n class BrowserCodeReader {\n /**\n * Creates an instance of BrowserCodeReader.\n * @param {Reader} reader The reader instance to decode the barcode\n * @param {number} [timeBetweenScansMillis=500] the time delay between subsequent successful decode tries\n *\n * @memberOf BrowserCodeReader\n */\n constructor(reader, timeBetweenScansMillis = 500, _hints) {\n this.reader = reader;\n this.timeBetweenScansMillis = timeBetweenScansMillis;\n this._hints = _hints;\n /**\n * This will break the loop.\n */\n this._stopContinuousDecode = false;\n /**\n * This will break the loop.\n */\n this._stopAsyncDecode = false;\n /**\n * Delay time between decode attempts made by the scanner.\n */\n this._timeBetweenDecodingAttempts = 0;\n }\n /**\n * If navigator is present.\n */\n get hasNavigator() {\n return typeof navigator !== 'undefined';\n }\n /**\n * If mediaDevices under navigator is supported.\n */\n get isMediaDevicesSuported() {\n return this.hasNavigator && !!navigator.mediaDevices;\n }\n /**\n * If enumerateDevices under navigator is supported.\n */\n get canEnumerateDevices() {\n return !!(this.isMediaDevicesSuported && navigator.mediaDevices.enumerateDevices);\n }\n /** Time between two decoding tries in milli seconds. */\n get timeBetweenDecodingAttempts() {\n return this._timeBetweenDecodingAttempts;\n }\n /**\n * Change the time span the decoder waits between two decoding tries.\n *\n * @param {number} millis Time between two decoding tries in milli seconds.\n */\n set timeBetweenDecodingAttempts(millis) {\n this._timeBetweenDecodingAttempts = millis < 0 ? 0 : millis;\n }\n /**\n * Sets the hints.\n */\n set hints(hints) {\n this._hints = hints || null;\n }\n /**\n * Sets the hints.\n */\n get hints() {\n return this._hints;\n }\n /**\n * Lists all the available video input devices.\n */\n listVideoInputDevices() {\n return __awaiter(this, void 0, void 0, function* () {\n if (!this.hasNavigator) {\n throw new Error('Can\\'t enumerate devices, navigator is not present.');\n }\n if (!this.canEnumerateDevices) {\n throw new Error('Can\\'t enumerate devices, method not supported.');\n }\n const devices = yield navigator.mediaDevices.enumerateDevices();\n const videoDevices = [];\n for (const device of devices) {\n const kind = device.kind === 'video' ? 'videoinput' : device.kind;\n if (kind !== 'videoinput') {\n continue;\n }\n const deviceId = device.deviceId || device.id;\n const label = device.label || `Video device ${videoDevices.length + 1}`;\n const groupId = device.groupId;\n const videoDevice = { deviceId, label, kind, groupId };\n videoDevices.push(videoDevice);\n }\n return videoDevices;\n });\n }\n /**\n * Obtain the list of available devices with type 'videoinput'.\n *\n * @returns {Promise} an array of available video input devices\n *\n * @memberOf BrowserCodeReader\n *\n * @deprecated Use `listVideoInputDevices` instead.\n */\n getVideoInputDevices() {\n return __awaiter(this, void 0, void 0, function* () {\n const devices = yield this.listVideoInputDevices();\n return devices.map(d => new VideoInputDevice(d.deviceId, d.label));\n });\n }\n /**\n * Let's you find a device using it's Id.\n */\n findDeviceById(deviceId) {\n return __awaiter(this, void 0, void 0, function* () {\n const devices = yield this.listVideoInputDevices();\n if (!devices) {\n return null;\n }\n return devices.find(x => x.deviceId === deviceId);\n });\n }\n /**\n * Decodes the barcode from the device specified by deviceId while showing the video in the specified video element.\n *\n * @param deviceId the id of one of the devices obtained after calling getVideoInputDevices. Can be undefined, in this case it will decode from one of the available devices, preffering the main camera (environment facing) if available.\n * @param video the video element in page where to show the video while decoding. Can be either an element id or directly an HTMLVideoElement. Can be undefined, in which case no video will be shown.\n * @returns The decoding result.\n *\n * @memberOf BrowserCodeReader\n *\n * @deprecated Use `decodeOnceFromVideoDevice` instead.\n */\n decodeFromInputVideoDevice(deviceId, videoSource) {\n return __awaiter(this, void 0, void 0, function* () {\n return yield this.decodeOnceFromVideoDevice(deviceId, videoSource);\n });\n }\n /**\n * In one attempt, tries to decode the barcode from the device specified by deviceId while showing the video in the specified video element.\n *\n * @param deviceId the id of one of the devices obtained after calling getVideoInputDevices. Can be undefined, in this case it will decode from one of the available devices, preffering the main camera (environment facing) if available.\n * @param video the video element in page where to show the video while decoding. Can be either an element id or directly an HTMLVideoElement. Can be undefined, in which case no video will be shown.\n * @returns The decoding result.\n *\n * @memberOf BrowserCodeReader\n */\n decodeOnceFromVideoDevice(deviceId, videoSource) {\n return __awaiter(this, void 0, void 0, function* () {\n this.reset();\n let videoConstraints;\n if (!deviceId) {\n videoConstraints = { facingMode: 'environment' };\n }\n else {\n videoConstraints = { deviceId: { exact: deviceId } };\n }\n const constraints = { video: videoConstraints };\n return yield this.decodeOnceFromConstraints(constraints, videoSource);\n });\n }\n /**\n * In one attempt, tries to decode the barcode from a stream obtained from the given constraints while showing the video in the specified video element.\n *\n * @param constraints the media stream constraints to get s valid media stream to decode from\n * @param video the video element in page where to show the video while decoding. Can be either an element id or directly an HTMLVideoElement. Can be undefined, in which case no video will be shown.\n * @returns The decoding result.\n *\n * @memberOf BrowserCodeReader\n */\n decodeOnceFromConstraints(constraints, videoSource) {\n return __awaiter(this, void 0, void 0, function* () {\n const stream = yield navigator.mediaDevices.getUserMedia(constraints);\n return yield this.decodeOnceFromStream(stream, videoSource);\n });\n }\n /**\n * In one attempt, tries to decode the barcode from a stream obtained from the given constraints while showing the video in the specified video element.\n *\n * @param {MediaStream} [constraints] the media stream constraints to get s valid media stream to decode from\n * @param {string|HTMLVideoElement} [video] the video element in page where to show the video while decoding. Can be either an element id or directly an HTMLVideoElement. Can be undefined, in which case no video will be shown.\n * @returns {Promise} The decoding result.\n *\n * @memberOf BrowserCodeReader\n */\n decodeOnceFromStream(stream, videoSource) {\n return __awaiter(this, void 0, void 0, function* () {\n this.reset();\n const video = yield this.attachStreamToVideo(stream, videoSource);\n const result = yield this.decodeOnce(video);\n return result;\n });\n }\n /**\n * Continuously decodes the barcode from the device specified by device while showing the video in the specified video element.\n *\n * @param {string|null} [deviceId] the id of one of the devices obtained after calling getVideoInputDevices. Can be undefined, in this case it will decode from one of the available devices, preffering the main camera (environment facing) if available.\n * @param {string|HTMLVideoElement|null} [video] the video element in page where to show the video while decoding. Can be either an element id or directly an HTMLVideoElement. Can be undefined, in which case no video will be shown.\n * @returns {Promise}\n *\n * @memberOf BrowserCodeReader\n *\n * @deprecated Use `decodeFromVideoDevice` instead.\n */\n decodeFromInputVideoDeviceContinuously(deviceId, videoSource, callbackFn) {\n return __awaiter(this, void 0, void 0, function* () {\n return yield this.decodeFromVideoDevice(deviceId, videoSource, callbackFn);\n });\n }\n /**\n * Continuously tries to decode the barcode from the device specified by device while showing the video in the specified video element.\n *\n * @param {string|null} [deviceId] the id of one of the devices obtained after calling getVideoInputDevices. Can be undefined, in this case it will decode from one of the available devices, preffering the main camera (environment facing) if available.\n * @param {string|HTMLVideoElement|null} [video] the video element in page where to show the video while decoding. Can be either an element id or directly an HTMLVideoElement. Can be undefined, in which case no video will be shown.\n * @returns {Promise}\n *\n * @memberOf BrowserCodeReader\n */\n decodeFromVideoDevice(deviceId, videoSource, callbackFn) {\n return __awaiter(this, void 0, void 0, function* () {\n let videoConstraints;\n if (!deviceId) {\n videoConstraints = { facingMode: 'environment' };\n }\n else {\n videoConstraints = { deviceId: { exact: deviceId } };\n }\n const constraints = { video: videoConstraints };\n return yield this.decodeFromConstraints(constraints, videoSource, callbackFn);\n });\n }\n /**\n * Continuously tries to decode the barcode from a stream obtained from the given constraints while showing the video in the specified video element.\n *\n * @param {MediaStream} [constraints] the media stream constraints to get s valid media stream to decode from\n * @param {string|HTMLVideoElement} [video] the video element in page where to show the video while decoding. Can be either an element id or directly an HTMLVideoElement. Can be undefined, in which case no video will be shown.\n * @returns {Promise} The decoding result.\n *\n * @memberOf BrowserCodeReader\n */\n decodeFromConstraints(constraints, videoSource, callbackFn) {\n return __awaiter(this, void 0, void 0, function* () {\n const stream = yield navigator.mediaDevices.getUserMedia(constraints);\n return yield this.decodeFromStream(stream, videoSource, callbackFn);\n });\n }\n /**\n * In one attempt, tries to decode the barcode from a stream obtained from the given constraints while showing the video in the specified video element.\n *\n * @param {MediaStream} [constraints] the media stream constraints to get s valid media stream to decode from\n * @param {string|HTMLVideoElement} [video] the video element in page where to show the video while decoding. Can be either an element id or directly an HTMLVideoElement. Can be undefined, in which case no video will be shown.\n * @returns {Promise} The decoding result.\n *\n * @memberOf BrowserCodeReader\n */\n decodeFromStream(stream, videoSource, callbackFn) {\n return __awaiter(this, void 0, void 0, function* () {\n this.reset();\n const video = yield this.attachStreamToVideo(stream, videoSource);\n return yield this.decodeContinuously(video, callbackFn);\n });\n }\n /**\n * Breaks the decoding loop.\n */\n stopAsyncDecode() {\n this._stopAsyncDecode = true;\n }\n /**\n * Breaks the decoding loop.\n */\n stopContinuousDecode() {\n this._stopContinuousDecode = true;\n }\n /**\n * Sets the new stream and request a new decoding-with-delay.\n *\n * @param stream The stream to be shown in the video element.\n * @param decodeFn A callback for the decode method.\n */\n attachStreamToVideo(stream, videoSource) {\n return __awaiter(this, void 0, void 0, function* () {\n const videoElement = this.prepareVideoElement(videoSource);\n this.addVideoSource(videoElement, stream);\n this.videoElement = videoElement;\n this.stream = stream;\n yield this.playVideoOnLoadAsync(videoElement);\n return videoElement;\n });\n }\n /**\n *\n * @param videoElement\n */\n playVideoOnLoadAsync(videoElement) {\n return new Promise((resolve, reject) => this.playVideoOnLoad(videoElement, () => resolve()));\n }\n /**\n * Binds listeners and callbacks to the videoElement.\n *\n * @param element\n * @param callbackFn\n */\n playVideoOnLoad(element, callbackFn) {\n this.videoEndedListener = () => this.stopStreams();\n this.videoCanPlayListener = () => this.tryPlayVideo(element);\n element.addEventListener('ended', this.videoEndedListener);\n element.addEventListener('canplay', this.videoCanPlayListener);\n element.addEventListener('playing', callbackFn);\n // if canplay was already fired, we won't know when to play, so just give it a try\n this.tryPlayVideo(element);\n }\n /**\n * Checks if the given video element is currently playing.\n */\n isVideoPlaying(video) {\n return video.currentTime > 0 && !video.paused && !video.ended && video.readyState > 2;\n }\n /**\n * Just tries to play the video and logs any errors.\n * The play call is only made is the video is not already playing.\n */\n tryPlayVideo(videoElement) {\n return __awaiter(this, void 0, void 0, function* () {\n if (this.isVideoPlaying(videoElement)) {\n console.warn('Trying to play video that is already playing.');\n return;\n }\n try {\n yield videoElement.play();\n }\n catch (_a) {\n console.warn('It was not possible to play the video.');\n }\n });\n }\n /**\n * Searches and validates a media element.\n */\n getMediaElement(mediaElementId, type) {\n const mediaElement = document.getElementById(mediaElementId);\n if (!mediaElement) {\n throw new ArgumentException(`element with id '${mediaElementId}' not found`);\n }\n if (mediaElement.nodeName.toLowerCase() !== type.toLowerCase()) {\n throw new ArgumentException(`element with id '${mediaElementId}' must be an ${type} element`);\n }\n return mediaElement;\n }\n /**\n * Decodes the barcode from an image.\n *\n * @param {(string|HTMLImageElement)} [source] The image element that can be either an element id or the element itself. Can be undefined in which case the decoding will be done from the imageUrl parameter.\n * @param {string} [url]\n * @returns {Promise} The decoding result.\n *\n * @memberOf BrowserCodeReader\n */\n decodeFromImage(source, url) {\n if (!source && !url) {\n throw new ArgumentException('either imageElement with a src set or an url must be provided');\n }\n if (url && !source) {\n return this.decodeFromImageUrl(url);\n }\n return this.decodeFromImageElement(source);\n }\n /**\n * Decodes the barcode from a video.\n *\n * @param {(string|HTMLImageElement)} [source] The image element that can be either an element id or the element itself. Can be undefined in which case the decoding will be done from the imageUrl parameter.\n * @param {string} [url]\n * @returns {Promise} The decoding result.\n *\n * @memberOf BrowserCodeReader\n */\n decodeFromVideo(source, url) {\n if (!source && !url) {\n throw new ArgumentException('Either an element with a src set or an URL must be provided');\n }\n if (url && !source) {\n return this.decodeFromVideoUrl(url);\n }\n return this.decodeFromVideoElement(source);\n }\n /**\n * Decodes continuously the barcode from a video.\n *\n * @param {(string|HTMLImageElement)} [source] The image element that can be either an element id or the element itself. Can be undefined in which case the decoding will be done from the imageUrl parameter.\n * @param {string} [url]\n * @returns {Promise} The decoding result.\n *\n * @memberOf BrowserCodeReader\n *\n * @experimental\n */\n decodeFromVideoContinuously(source, url, callbackFn) {\n if (undefined === source && undefined === url) {\n throw new ArgumentException('Either an element with a src set or an URL must be provided');\n }\n if (url && !source) {\n return this.decodeFromVideoUrlContinuously(url, callbackFn);\n }\n return this.decodeFromVideoElementContinuously(source, callbackFn);\n }\n /**\n * Decodes something from an image HTML element.\n */\n decodeFromImageElement(source) {\n if (!source) {\n throw new ArgumentException('An image element must be provided.');\n }\n this.reset();\n const element = this.prepareImageElement(source);\n this.imageElement = element;\n let task;\n if (this.isImageLoaded(element)) {\n task = this.decodeOnce(element, false, true);\n }\n else {\n task = this._decodeOnLoadImage(element);\n }\n return task;\n }\n /**\n * Decodes something from an image HTML element.\n */\n decodeFromVideoElement(source) {\n const element = this._decodeFromVideoElementSetup(source);\n return this._decodeOnLoadVideo(element);\n }\n /**\n * Decodes something from an image HTML element.\n */\n decodeFromVideoElementContinuously(source, callbackFn) {\n const element = this._decodeFromVideoElementSetup(source);\n return this._decodeOnLoadVideoContinuously(element, callbackFn);\n }\n /**\n * Sets up the video source so it can be decoded when loaded.\n *\n * @param source The video source element.\n */\n _decodeFromVideoElementSetup(source) {\n if (!source) {\n throw new ArgumentException('A video element must be provided.');\n }\n this.reset();\n const element = this.prepareVideoElement(source);\n // defines the video element before starts decoding\n this.videoElement = element;\n return element;\n }\n /**\n * Decodes an image from a URL.\n */\n decodeFromImageUrl(url) {\n if (!url) {\n throw new ArgumentException('An URL must be provided.');\n }\n this.reset();\n const element = this.prepareImageElement();\n this.imageElement = element;\n const decodeTask = this._decodeOnLoadImage(element);\n element.src = url;\n return decodeTask;\n }\n /**\n * Decodes an image from a URL.\n */\n decodeFromVideoUrl(url) {\n if (!url) {\n throw new ArgumentException('An URL must be provided.');\n }\n this.reset();\n // creates a new element\n const element = this.prepareVideoElement();\n const decodeTask = this.decodeFromVideoElement(element);\n element.src = url;\n return decodeTask;\n }\n /**\n * Decodes an image from a URL.\n *\n * @experimental\n */\n decodeFromVideoUrlContinuously(url, callbackFn) {\n if (!url) {\n throw new ArgumentException('An URL must be provided.');\n }\n this.reset();\n // creates a new element\n const element = this.prepareVideoElement();\n const decodeTask = this.decodeFromVideoElementContinuously(element, callbackFn);\n element.src = url;\n return decodeTask;\n }\n _decodeOnLoadImage(element) {\n return new Promise((resolve, reject) => {\n this.imageLoadedListener = () => this.decodeOnce(element, false, true).then(resolve, reject);\n element.addEventListener('load', this.imageLoadedListener);\n });\n }\n _decodeOnLoadVideo(videoElement) {\n return __awaiter(this, void 0, void 0, function* () {\n // plays the video\n yield this.playVideoOnLoadAsync(videoElement);\n // starts decoding after played the video\n return yield this.decodeOnce(videoElement);\n });\n }\n _decodeOnLoadVideoContinuously(videoElement, callbackFn) {\n return __awaiter(this, void 0, void 0, function* () {\n // plays the video\n yield this.playVideoOnLoadAsync(videoElement);\n // starts decoding after played the video\n this.decodeContinuously(videoElement, callbackFn);\n });\n }\n isImageLoaded(img) {\n // During the onload event, IE correctly identifies any images that\n // weren’t downloaded as not complete. Others should too. Gecko-based\n // browsers act like NS4 in that they report this incorrectly.\n if (!img.complete) {\n return false;\n }\n // However, they do have two very useful properties: naturalWidth and\n // naturalHeight. These give the true size of the image. If it failed\n // to load, either of these should be zero.\n if (img.naturalWidth === 0) {\n return false;\n }\n // No other way of checking: assume it’s ok.\n return true;\n }\n prepareImageElement(imageSource) {\n let imageElement;\n if (typeof imageSource === 'undefined') {\n imageElement = document.createElement('img');\n imageElement.width = 200;\n imageElement.height = 200;\n }\n if (typeof imageSource === 'string') {\n imageElement = this.getMediaElement(imageSource, 'img');\n }\n if (imageSource instanceof HTMLImageElement) {\n imageElement = imageSource;\n }\n return imageElement;\n }\n /**\n * Sets a HTMLVideoElement for scanning or creates a new one.\n *\n * @param videoSource The HTMLVideoElement to be set.\n */\n prepareVideoElement(videoSource) {\n let videoElement;\n if (!videoSource && typeof document !== 'undefined') {\n videoElement = document.createElement('video');\n videoElement.width = 200;\n videoElement.height = 200;\n }\n if (typeof videoSource === 'string') {\n videoElement = this.getMediaElement(videoSource, 'video');\n }\n if (videoSource instanceof HTMLVideoElement) {\n videoElement = videoSource;\n }\n // Needed for iOS 11\n videoElement.setAttribute('autoplay', 'true');\n videoElement.setAttribute('muted', 'true');\n videoElement.setAttribute('playsinline', 'true');\n return videoElement;\n }\n /**\n * Tries to decode from the video input until it finds some value.\n */\n decodeOnce(element, retryIfNotFound = true, retryIfChecksumOrFormatError = true) {\n this._stopAsyncDecode = false;\n const loop = (resolve, reject) => {\n if (this._stopAsyncDecode) {\n reject(new NotFoundException('Video stream has ended before any code could be detected.'));\n this._stopAsyncDecode = undefined;\n return;\n }\n try {\n const result = this.decode(element);\n resolve(result);\n }\n catch (e) {\n const ifNotFound = retryIfNotFound && e instanceof NotFoundException;\n const isChecksumOrFormatError = e instanceof ChecksumException || e instanceof FormatException;\n const ifChecksumOrFormat = isChecksumOrFormatError && retryIfChecksumOrFormatError;\n if (ifNotFound || ifChecksumOrFormat) {\n // trying again\n return setTimeout(loop, this._timeBetweenDecodingAttempts, resolve, reject);\n }\n reject(e);\n }\n };\n return new Promise((resolve, reject) => loop(resolve, reject));\n }\n /**\n * Continuously decodes from video input.\n */\n decodeContinuously(element, callbackFn) {\n this._stopContinuousDecode = false;\n const loop = () => {\n if (this._stopContinuousDecode) {\n this._stopContinuousDecode = undefined;\n return;\n }\n try {\n const result = this.decode(element);\n callbackFn(result, null);\n setTimeout(loop, this.timeBetweenScansMillis);\n }\n catch (e) {\n callbackFn(null, e);\n const isChecksumOrFormatError = e instanceof ChecksumException || e instanceof FormatException;\n const isNotFound = e instanceof NotFoundException;\n if (isChecksumOrFormatError || isNotFound) {\n // trying again\n setTimeout(loop, this._timeBetweenDecodingAttempts);\n }\n }\n };\n loop();\n }\n /**\n * Gets the BinaryBitmap for ya! (and decodes it)\n */\n decode(element) {\n // get binary bitmap for decode function\n const binaryBitmap = this.createBinaryBitmap(element);\n return this.decodeBitmap(binaryBitmap);\n }\n /**\n * Creates a binaryBitmap based in some image source.\n *\n * @param mediaElement HTML element containing drawable image source.\n */\n createBinaryBitmap(mediaElement) {\n const ctx = this.getCaptureCanvasContext(mediaElement);\n this.drawImageOnCanvas(ctx, mediaElement);\n const canvas = this.getCaptureCanvas(mediaElement);\n const luminanceSource = new HTMLCanvasElementLuminanceSource(canvas);\n const hybridBinarizer = new HybridBinarizer(luminanceSource);\n return new BinaryBitmap(hybridBinarizer);\n }\n /**\n *\n */\n getCaptureCanvasContext(mediaElement) {\n if (!this.captureCanvasContext) {\n const elem = this.getCaptureCanvas(mediaElement);\n const ctx = elem.getContext('2d');\n this.captureCanvasContext = ctx;\n }\n return this.captureCanvasContext;\n }\n /**\n *\n */\n getCaptureCanvas(mediaElement) {\n if (!this.captureCanvas) {\n const elem = this.createCaptureCanvas(mediaElement);\n this.captureCanvas = elem;\n }\n return this.captureCanvas;\n }\n /**\n * Ovewriting this allows you to manipulate the snapshot image in anyway you want before decode.\n */\n drawImageOnCanvas(canvasElementContext, srcElement) {\n canvasElementContext.drawImage(srcElement, 0, 0);\n }\n /**\n * Call the encapsulated readers decode\n */\n decodeBitmap(binaryBitmap) {\n return this.reader.decode(binaryBitmap, this._hints);\n }\n /**\n * 🖌 Prepares the canvas for capture and scan frames.\n */\n createCaptureCanvas(mediaElement) {\n if (typeof document === 'undefined') {\n this._destroyCaptureCanvas();\n return null;\n }\n const canvasElement = document.createElement('canvas');\n let width;\n let height;\n if (typeof mediaElement !== 'undefined') {\n if (mediaElement instanceof HTMLVideoElement) {\n width = mediaElement.videoWidth;\n height = mediaElement.videoHeight;\n }\n else if (mediaElement instanceof HTMLImageElement) {\n width = mediaElement.naturalWidth || mediaElement.width;\n height = mediaElement.naturalHeight || mediaElement.height;\n }\n }\n canvasElement.style.width = width + 'px';\n canvasElement.style.height = height + 'px';\n canvasElement.width = width;\n canvasElement.height = height;\n return canvasElement;\n }\n /**\n * Stops the continuous scan and cleans the stream.\n */\n stopStreams() {\n if (this.stream) {\n this.stream.getVideoTracks().forEach(t => t.stop());\n this.stream = undefined;\n }\n if (this._stopAsyncDecode === false) {\n this.stopAsyncDecode();\n }\n if (this._stopContinuousDecode === false) {\n this.stopContinuousDecode();\n }\n }\n /**\n * Resets the code reader to the initial state. Cancels any ongoing barcode scanning from video or camera.\n *\n * @memberOf BrowserCodeReader\n */\n reset() {\n // stops the camera, preview and scan 🔴\n this.stopStreams();\n // clean and forget about HTML elements\n this._destroyVideoElement();\n this._destroyImageElement();\n this._destroyCaptureCanvas();\n }\n _destroyVideoElement() {\n if (!this.videoElement) {\n return;\n }\n // first gives freedon to the element 🕊\n if (typeof this.videoEndedListener !== 'undefined') {\n this.videoElement.removeEventListener('ended', this.videoEndedListener);\n }\n if (typeof this.videoPlayingEventListener !== 'undefined') {\n this.videoElement.removeEventListener('playing', this.videoPlayingEventListener);\n }\n if (typeof this.videoCanPlayListener !== 'undefined') {\n this.videoElement.removeEventListener('loadedmetadata', this.videoCanPlayListener);\n }\n // then forgets about that element 😢\n this.cleanVideoSource(this.videoElement);\n this.videoElement = undefined;\n }\n _destroyImageElement() {\n if (!this.imageElement) {\n return;\n }\n // first gives freedon to the element 🕊\n if (undefined !== this.imageLoadedListener) {\n this.imageElement.removeEventListener('load', this.imageLoadedListener);\n }\n // then forget about that element 😢\n this.imageElement.src = undefined;\n this.imageElement.removeAttribute('src');\n this.imageElement = undefined;\n }\n /**\n * Cleans canvas references 🖌\n */\n _destroyCaptureCanvas() {\n // then forget about that element 😢\n this.captureCanvasContext = undefined;\n this.captureCanvas = undefined;\n }\n /**\n * Defines what the videoElement src will be.\n *\n * @param videoElement\n * @param stream\n */\n addVideoSource(videoElement, stream) {\n // Older browsers may not have `srcObject`\n try {\n // @note Throws Exception if interrupted by a new loaded request\n videoElement.srcObject = stream;\n }\n catch (err) {\n // @note Avoid using this in new browsers, as it is going away.\n videoElement.src = URL.createObjectURL(stream);\n }\n }\n /**\n * Unbinds a HTML video src property.\n *\n * @param videoElement\n */\n cleanVideoSource(videoElement) {\n try {\n videoElement.srcObject = null;\n }\n catch (err) {\n videoElement.src = '';\n }\n this.videoElement.removeAttribute('src');\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates the result of decoding a barcode within an image.

\n *\n * @author Sean Owen\n */\n class Result {\n // public constructor(private text: string,\n // Uint8Array rawBytes,\n // ResultPoconst resultPoints: Int32Array,\n // BarcodeFormat format) {\n // this(text, rawBytes, resultPoints, format, System.currentTimeMillis())\n // }\n // public constructor(text: string,\n // Uint8Array rawBytes,\n // ResultPoconst resultPoints: Int32Array,\n // BarcodeFormat format,\n // long timestamp) {\n // this(text, rawBytes, rawBytes == null ? 0 : 8 * rawBytes.length,\n // resultPoints, format, timestamp)\n // }\n constructor(text, rawBytes, numBits = rawBytes == null ? 0 : 8 * rawBytes.length, resultPoints, format, timestamp = System.currentTimeMillis()) {\n this.text = text;\n this.rawBytes = rawBytes;\n this.numBits = numBits;\n this.resultPoints = resultPoints;\n this.format = format;\n this.timestamp = timestamp;\n this.text = text;\n this.rawBytes = rawBytes;\n if (undefined === numBits || null === numBits) {\n this.numBits = (rawBytes === null || rawBytes === undefined) ? 0 : 8 * rawBytes.length;\n }\n else {\n this.numBits = numBits;\n }\n this.resultPoints = resultPoints;\n this.format = format;\n this.resultMetadata = null;\n if (undefined === timestamp || null === timestamp) {\n this.timestamp = System.currentTimeMillis();\n }\n else {\n this.timestamp = timestamp;\n }\n }\n /**\n * @return raw text encoded by the barcode\n */\n getText() {\n return this.text;\n }\n /**\n * @return raw bytes encoded by the barcode, if applicable, otherwise {@code null}\n */\n getRawBytes() {\n return this.rawBytes;\n }\n /**\n * @return how many bits of {@link #getRawBytes()} are valid; typically 8 times its length\n * @since 3.3.0\n */\n getNumBits() {\n return this.numBits;\n }\n /**\n * @return points related to the barcode in the image. These are typically points\n * identifying finder patterns or the corners of the barcode. The exact meaning is\n * specific to the type of barcode that was decoded.\n */\n getResultPoints() {\n return this.resultPoints;\n }\n /**\n * @return {@link BarcodeFormat} representing the format of the barcode that was decoded\n */\n getBarcodeFormat() {\n return this.format;\n }\n /**\n * @return {@link Map} mapping {@link ResultMetadataType} keys to values. May be\n * {@code null}. This contains optional metadata about what was detected about the barcode,\n * like orientation.\n */\n getResultMetadata() {\n return this.resultMetadata;\n }\n putMetadata(type, value) {\n if (this.resultMetadata === null) {\n this.resultMetadata = new Map();\n }\n this.resultMetadata.set(type, value);\n }\n putAllMetadata(metadata) {\n if (metadata !== null) {\n if (this.resultMetadata === null) {\n this.resultMetadata = metadata;\n }\n else {\n this.resultMetadata = new Map(metadata);\n }\n }\n }\n addResultPoints(newPoints) {\n const oldPoints = this.resultPoints;\n if (oldPoints === null) {\n this.resultPoints = newPoints;\n }\n else if (newPoints !== null && newPoints.length > 0) {\n const allPoints = new Array(oldPoints.length + newPoints.length);\n System.arraycopy(oldPoints, 0, allPoints, 0, oldPoints.length);\n System.arraycopy(newPoints, 0, allPoints, oldPoints.length, newPoints.length);\n this.resultPoints = allPoints;\n }\n }\n getTimestamp() {\n return this.timestamp;\n }\n /*@Override*/\n toString() {\n return this.text;\n }\n }\n\n /*\n * Direct port to TypeScript of ZXing by Adrian Toșcă\n */\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing {*/\n /**\n * Enumerates barcode formats known to this package. Please keep alphabetized.\n *\n * @author Sean Owen\n */\n var BarcodeFormat;\n (function (BarcodeFormat) {\n /** Aztec 2D barcode format. */\n BarcodeFormat[BarcodeFormat[\"AZTEC\"] = 0] = \"AZTEC\";\n /** CODABAR 1D format. */\n BarcodeFormat[BarcodeFormat[\"CODABAR\"] = 1] = \"CODABAR\";\n /** Code 39 1D format. */\n BarcodeFormat[BarcodeFormat[\"CODE_39\"] = 2] = \"CODE_39\";\n /** Code 93 1D format. */\n BarcodeFormat[BarcodeFormat[\"CODE_93\"] = 3] = \"CODE_93\";\n /** Code 128 1D format. */\n BarcodeFormat[BarcodeFormat[\"CODE_128\"] = 4] = \"CODE_128\";\n /** Data Matrix 2D barcode format. */\n BarcodeFormat[BarcodeFormat[\"DATA_MATRIX\"] = 5] = \"DATA_MATRIX\";\n /** EAN-8 1D format. */\n BarcodeFormat[BarcodeFormat[\"EAN_8\"] = 6] = \"EAN_8\";\n /** EAN-13 1D format. */\n BarcodeFormat[BarcodeFormat[\"EAN_13\"] = 7] = \"EAN_13\";\n /** ITF (Interleaved Two of Five) 1D format. */\n BarcodeFormat[BarcodeFormat[\"ITF\"] = 8] = \"ITF\";\n /** MaxiCode 2D barcode format. */\n BarcodeFormat[BarcodeFormat[\"MAXICODE\"] = 9] = \"MAXICODE\";\n /** PDF417 format. */\n BarcodeFormat[BarcodeFormat[\"PDF_417\"] = 10] = \"PDF_417\";\n /** QR Code 2D barcode format. */\n BarcodeFormat[BarcodeFormat[\"QR_CODE\"] = 11] = \"QR_CODE\";\n /** RSS 14 */\n BarcodeFormat[BarcodeFormat[\"RSS_14\"] = 12] = \"RSS_14\";\n /** RSS EXPANDED */\n BarcodeFormat[BarcodeFormat[\"RSS_EXPANDED\"] = 13] = \"RSS_EXPANDED\";\n /** UPC-A 1D format. */\n BarcodeFormat[BarcodeFormat[\"UPC_A\"] = 14] = \"UPC_A\";\n /** UPC-E 1D format. */\n BarcodeFormat[BarcodeFormat[\"UPC_E\"] = 15] = \"UPC_E\";\n /** UPC/EAN extension format. Not a stand-alone format. */\n BarcodeFormat[BarcodeFormat[\"UPC_EAN_EXTENSION\"] = 16] = \"UPC_EAN_EXTENSION\";\n })(BarcodeFormat || (BarcodeFormat = {}));\n var BarcodeFormat$1 = BarcodeFormat;\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing {*/\n /**\n * Represents some type of metadata about the result of the decoding that the decoder\n * wishes to communicate back to the caller.\n *\n * @author Sean Owen\n */\n var ResultMetadataType;\n (function (ResultMetadataType) {\n /**\n * Unspecified, application-specific metadata. Maps to an unspecified {@link Object}.\n */\n ResultMetadataType[ResultMetadataType[\"OTHER\"] = 0] = \"OTHER\";\n /**\n * Denotes the likely approximate orientation of the barcode in the image. This value\n * is given as degrees rotated clockwise from the normal, upright orientation.\n * For example a 1D barcode which was found by reading top-to-bottom would be\n * said to have orientation \"90\". This key maps to an {@link Integer} whose\n * value is in the range [0,360).\n */\n ResultMetadataType[ResultMetadataType[\"ORIENTATION\"] = 1] = \"ORIENTATION\";\n /**\n *

2D barcode formats typically encode text, but allow for a sort of 'byte mode'\n * which is sometimes used to encode binary data. While {@link Result} makes available\n * the complete raw bytes in the barcode for these formats, it does not offer the bytes\n * from the byte segments alone.

\n *\n *

This maps to a {@link java.util.List} of byte arrays corresponding to the\n * raw bytes in the byte segments in the barcode, in order.

\n */\n ResultMetadataType[ResultMetadataType[\"BYTE_SEGMENTS\"] = 2] = \"BYTE_SEGMENTS\";\n /**\n * Error correction level used, if applicable. The value type depends on the\n * format, but is typically a String.\n */\n ResultMetadataType[ResultMetadataType[\"ERROR_CORRECTION_LEVEL\"] = 3] = \"ERROR_CORRECTION_LEVEL\";\n /**\n * For some periodicals, indicates the issue number as an {@link Integer}.\n */\n ResultMetadataType[ResultMetadataType[\"ISSUE_NUMBER\"] = 4] = \"ISSUE_NUMBER\";\n /**\n * For some products, indicates the suggested retail price in the barcode as a\n * formatted {@link String}.\n */\n ResultMetadataType[ResultMetadataType[\"SUGGESTED_PRICE\"] = 5] = \"SUGGESTED_PRICE\";\n /**\n * For some products, the possible country of manufacture as a {@link String} denoting the\n * ISO country code. Some map to multiple possible countries, like \"US/CA\".\n */\n ResultMetadataType[ResultMetadataType[\"POSSIBLE_COUNTRY\"] = 6] = \"POSSIBLE_COUNTRY\";\n /**\n * For some products, the extension text\n */\n ResultMetadataType[ResultMetadataType[\"UPC_EAN_EXTENSION\"] = 7] = \"UPC_EAN_EXTENSION\";\n /**\n * PDF417-specific metadata\n */\n ResultMetadataType[ResultMetadataType[\"PDF417_EXTRA_METADATA\"] = 8] = \"PDF417_EXTRA_METADATA\";\n /**\n * If the code format supports structured append and the current scanned code is part of one then the\n * sequence number is given with it.\n */\n ResultMetadataType[ResultMetadataType[\"STRUCTURED_APPEND_SEQUENCE\"] = 9] = \"STRUCTURED_APPEND_SEQUENCE\";\n /**\n * If the code format supports structured append and the current scanned code is part of one then the\n * parity is given with it.\n */\n ResultMetadataType[ResultMetadataType[\"STRUCTURED_APPEND_PARITY\"] = 10] = \"STRUCTURED_APPEND_PARITY\";\n })(ResultMetadataType || (ResultMetadataType = {}));\n var ResultMetadataType$1 = ResultMetadataType;\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing.common {*/\n /*import java.util.List;*/\n /**\n *

Encapsulates the result of decoding a matrix of bits. This typically\n * applies to 2D barcode formats. For now it contains the raw bytes obtained,\n * as well as a String interpretation of those bytes, if applicable.

\n *\n * @author Sean Owen\n */\n class DecoderResult {\n // public constructor(rawBytes: Uint8Array,\n // text: string,\n // List byteSegments,\n // String ecLevel) {\n // this(rawBytes, text, byteSegments, ecLevel, -1, -1)\n // }\n constructor(rawBytes, text, byteSegments, ecLevel, structuredAppendSequenceNumber = -1, structuredAppendParity = -1) {\n this.rawBytes = rawBytes;\n this.text = text;\n this.byteSegments = byteSegments;\n this.ecLevel = ecLevel;\n this.structuredAppendSequenceNumber = structuredAppendSequenceNumber;\n this.structuredAppendParity = structuredAppendParity;\n this.numBits = (rawBytes === undefined || rawBytes === null) ? 0 : 8 * rawBytes.length;\n }\n /**\n * @return raw bytes representing the result, or {@code null} if not applicable\n */\n getRawBytes() {\n return this.rawBytes;\n }\n /**\n * @return how many bits of {@link #getRawBytes()} are valid; typically 8 times its length\n * @since 3.3.0\n */\n getNumBits() {\n return this.numBits;\n }\n /**\n * @param numBits overrides the number of bits that are valid in {@link #getRawBytes()}\n * @since 3.3.0\n */\n setNumBits(numBits /*int*/) {\n this.numBits = numBits;\n }\n /**\n * @return text representation of the result\n */\n getText() {\n return this.text;\n }\n /**\n * @return list of byte segments in the result, or {@code null} if not applicable\n */\n getByteSegments() {\n return this.byteSegments;\n }\n /**\n * @return name of error correction level used, or {@code null} if not applicable\n */\n getECLevel() {\n return this.ecLevel;\n }\n /**\n * @return number of errors corrected, or {@code null} if not applicable\n */\n getErrorsCorrected() {\n return this.errorsCorrected;\n }\n setErrorsCorrected(errorsCorrected /*Integer*/) {\n this.errorsCorrected = errorsCorrected;\n }\n /**\n * @return number of erasures corrected, or {@code null} if not applicable\n */\n getErasures() {\n return this.erasures;\n }\n setErasures(erasures /*Integer*/) {\n this.erasures = erasures;\n }\n /**\n * @return arbitrary additional metadata\n */\n getOther() {\n return this.other;\n }\n setOther(other) {\n this.other = other;\n }\n hasStructuredAppend() {\n return this.structuredAppendParity >= 0 && this.structuredAppendSequenceNumber >= 0;\n }\n getStructuredAppendParity() {\n return this.structuredAppendParity;\n }\n getStructuredAppendSequenceNumber() {\n return this.structuredAppendSequenceNumber;\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

This class contains utility methods for performing mathematical operations over\n * the Galois Fields. Operations use a given primitive polynomial in calculations.

\n *\n *

Throughout this package, elements of the GF are represented as an {@code int}\n * for convenience and speed (but at the cost of memory).\n *

\n *\n * @author Sean Owen\n * @author David Olivier\n */\n class AbstractGenericGF {\n /**\n * @return 2 to the power of a in GF(size)\n */\n exp(a) {\n return this.expTable[a];\n }\n /**\n * @return base 2 log of a in GF(size)\n */\n log(a /*int*/) {\n if (a === 0) {\n throw new IllegalArgumentException();\n }\n return this.logTable[a];\n }\n /**\n * Implements both addition and subtraction -- they are the same in GF(size).\n *\n * @return sum/difference of a and b\n */\n static addOrSubtract(a /*int*/, b /*int*/) {\n return a ^ b;\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Represents a polynomial whose coefficients are elements of a GF.\n * Instances of this class are immutable.

\n *\n *

Much credit is due to William Rucklidge since portions of this code are an indirect\n * port of his C++ Reed-Solomon implementation.

\n *\n * @author Sean Owen\n */\n class GenericGFPoly {\n /**\n * @param field the {@link GenericGF} instance representing the field to use\n * to perform computations\n * @param coefficients coefficients as ints representing elements of GF(size), arranged\n * from most significant (highest-power term) coefficient to least significant\n * @throws IllegalArgumentException if argument is null or empty,\n * or if leading coefficient is 0 and this is not a\n * constant polynomial (that is, it is not the monomial \"0\")\n */\n constructor(field, coefficients) {\n if (coefficients.length === 0) {\n throw new IllegalArgumentException();\n }\n this.field = field;\n const coefficientsLength = coefficients.length;\n if (coefficientsLength > 1 && coefficients[0] === 0) {\n // Leading term must be non-zero for anything except the constant polynomial \"0\"\n let firstNonZero = 1;\n while (firstNonZero < coefficientsLength && coefficients[firstNonZero] === 0) {\n firstNonZero++;\n }\n if (firstNonZero === coefficientsLength) {\n this.coefficients = Int32Array.from([0]);\n }\n else {\n this.coefficients = new Int32Array(coefficientsLength - firstNonZero);\n System.arraycopy(coefficients, firstNonZero, this.coefficients, 0, this.coefficients.length);\n }\n }\n else {\n this.coefficients = coefficients;\n }\n }\n getCoefficients() {\n return this.coefficients;\n }\n /**\n * @return degree of this polynomial\n */\n getDegree() {\n return this.coefficients.length - 1;\n }\n /**\n * @return true iff this polynomial is the monomial \"0\"\n */\n isZero() {\n return this.coefficients[0] === 0;\n }\n /**\n * @return coefficient of x^degree term in this polynomial\n */\n getCoefficient(degree /*int*/) {\n return this.coefficients[this.coefficients.length - 1 - degree];\n }\n /**\n * @return evaluation of this polynomial at a given point\n */\n evaluateAt(a /*int*/) {\n if (a === 0) {\n // Just return the x^0 coefficient\n return this.getCoefficient(0);\n }\n const coefficients = this.coefficients;\n let result;\n if (a === 1) {\n // Just the sum of the coefficients\n result = 0;\n for (let i = 0, length = coefficients.length; i !== length; i++) {\n const coefficient = coefficients[i];\n result = AbstractGenericGF.addOrSubtract(result, coefficient);\n }\n return result;\n }\n result = coefficients[0];\n const size = coefficients.length;\n const field = this.field;\n for (let i = 1; i < size; i++) {\n result = AbstractGenericGF.addOrSubtract(field.multiply(a, result), coefficients[i]);\n }\n return result;\n }\n addOrSubtract(other) {\n if (!this.field.equals(other.field)) {\n throw new IllegalArgumentException('GenericGFPolys do not have same GenericGF field');\n }\n if (this.isZero()) {\n return other;\n }\n if (other.isZero()) {\n return this;\n }\n let smallerCoefficients = this.coefficients;\n let largerCoefficients = other.coefficients;\n if (smallerCoefficients.length > largerCoefficients.length) {\n const temp = smallerCoefficients;\n smallerCoefficients = largerCoefficients;\n largerCoefficients = temp;\n }\n let sumDiff = new Int32Array(largerCoefficients.length);\n const lengthDiff = largerCoefficients.length - smallerCoefficients.length;\n // Copy high-order terms only found in higher-degree polynomial's coefficients\n System.arraycopy(largerCoefficients, 0, sumDiff, 0, lengthDiff);\n for (let i = lengthDiff; i < largerCoefficients.length; i++) {\n sumDiff[i] = AbstractGenericGF.addOrSubtract(smallerCoefficients[i - lengthDiff], largerCoefficients[i]);\n }\n return new GenericGFPoly(this.field, sumDiff);\n }\n multiply(other) {\n if (!this.field.equals(other.field)) {\n throw new IllegalArgumentException('GenericGFPolys do not have same GenericGF field');\n }\n if (this.isZero() || other.isZero()) {\n return this.field.getZero();\n }\n const aCoefficients = this.coefficients;\n const aLength = aCoefficients.length;\n const bCoefficients = other.coefficients;\n const bLength = bCoefficients.length;\n const product = new Int32Array(aLength + bLength - 1);\n const field = this.field;\n for (let i = 0; i < aLength; i++) {\n const aCoeff = aCoefficients[i];\n for (let j = 0; j < bLength; j++) {\n product[i + j] = AbstractGenericGF.addOrSubtract(product[i + j], field.multiply(aCoeff, bCoefficients[j]));\n }\n }\n return new GenericGFPoly(field, product);\n }\n multiplyScalar(scalar /*int*/) {\n if (scalar === 0) {\n return this.field.getZero();\n }\n if (scalar === 1) {\n return this;\n }\n const size = this.coefficients.length;\n const field = this.field;\n const product = new Int32Array(size);\n const coefficients = this.coefficients;\n for (let i = 0; i < size; i++) {\n product[i] = field.multiply(coefficients[i], scalar);\n }\n return new GenericGFPoly(field, product);\n }\n multiplyByMonomial(degree /*int*/, coefficient /*int*/) {\n if (degree < 0) {\n throw new IllegalArgumentException();\n }\n if (coefficient === 0) {\n return this.field.getZero();\n }\n const coefficients = this.coefficients;\n const size = coefficients.length;\n const product = new Int32Array(size + degree);\n const field = this.field;\n for (let i = 0; i < size; i++) {\n product[i] = field.multiply(coefficients[i], coefficient);\n }\n return new GenericGFPoly(field, product);\n }\n divide(other) {\n if (!this.field.equals(other.field)) {\n throw new IllegalArgumentException('GenericGFPolys do not have same GenericGF field');\n }\n if (other.isZero()) {\n throw new IllegalArgumentException('Divide by 0');\n }\n const field = this.field;\n let quotient = field.getZero();\n let remainder = this;\n const denominatorLeadingTerm = other.getCoefficient(other.getDegree());\n const inverseDenominatorLeadingTerm = field.inverse(denominatorLeadingTerm);\n while (remainder.getDegree() >= other.getDegree() && !remainder.isZero()) {\n const degreeDifference = remainder.getDegree() - other.getDegree();\n const scale = field.multiply(remainder.getCoefficient(remainder.getDegree()), inverseDenominatorLeadingTerm);\n const term = other.multiplyByMonomial(degreeDifference, scale);\n const iterationQuotient = field.buildMonomial(degreeDifference, scale);\n quotient = quotient.addOrSubtract(iterationQuotient);\n remainder = remainder.addOrSubtract(term);\n }\n return [quotient, remainder];\n }\n /*@Override*/\n toString() {\n let result = '';\n for (let degree = this.getDegree(); degree >= 0; degree--) {\n let coefficient = this.getCoefficient(degree);\n if (coefficient !== 0) {\n if (coefficient < 0) {\n result += ' - ';\n coefficient = -coefficient;\n }\n else {\n if (result.length > 0) {\n result += ' + ';\n }\n }\n if (degree === 0 || coefficient !== 1) {\n const alphaPower = this.field.log(coefficient);\n if (alphaPower === 0) {\n result += '1';\n }\n else if (alphaPower === 1) {\n result += 'a';\n }\n else {\n result += 'a^';\n result += alphaPower;\n }\n }\n if (degree !== 0) {\n if (degree === 1) {\n result += 'x';\n }\n else {\n result += 'x^';\n result += degree;\n }\n }\n }\n }\n return result;\n }\n }\n\n /**\n * Custom Error class of type Exception.\n */\n class ArithmeticException extends Exception {\n }\n ArithmeticException.kind = 'ArithmeticException';\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

This class contains utility methods for performing mathematical operations over\n * the Galois Fields. Operations use a given primitive polynomial in calculations.

\n *\n *

Throughout this package, elements of the GF are represented as an {@code int}\n * for convenience and speed (but at the cost of memory).\n *

\n *\n * @author Sean Owen\n * @author David Olivier\n */\n class GenericGF extends AbstractGenericGF {\n /**\n * Create a representation of GF(size) using the given primitive polynomial.\n *\n * @param primitive irreducible polynomial whose coefficients are represented by\n * the bits of an int, where the least-significant bit represents the constant\n * coefficient\n * @param size the size of the field\n * @param b the factor b in the generator polynomial can be 0- or 1-based\n * (g(x) = (x+a^b)(x+a^(b+1))...(x+a^(b+2t-1))).\n * In most cases it should be 1, but for QR code it is 0.\n */\n constructor(primitive /*int*/, size /*int*/, generatorBase /*int*/) {\n super();\n this.primitive = primitive;\n this.size = size;\n this.generatorBase = generatorBase;\n const expTable = new Int32Array(size);\n let x = 1;\n for (let i = 0; i < size; i++) {\n expTable[i] = x;\n x *= 2; // we're assuming the generator alpha is 2\n if (x >= size) {\n x ^= primitive;\n x &= size - 1;\n }\n }\n this.expTable = expTable;\n const logTable = new Int32Array(size);\n for (let i = 0; i < size - 1; i++) {\n logTable[expTable[i]] = i;\n }\n this.logTable = logTable;\n // logTable[0] == 0 but this should never be used\n this.zero = new GenericGFPoly(this, Int32Array.from([0]));\n this.one = new GenericGFPoly(this, Int32Array.from([1]));\n }\n getZero() {\n return this.zero;\n }\n getOne() {\n return this.one;\n }\n /**\n * @return the monomial representing coefficient * x^degree\n */\n buildMonomial(degree /*int*/, coefficient /*int*/) {\n if (degree < 0) {\n throw new IllegalArgumentException();\n }\n if (coefficient === 0) {\n return this.zero;\n }\n const coefficients = new Int32Array(degree + 1);\n coefficients[0] = coefficient;\n return new GenericGFPoly(this, coefficients);\n }\n /**\n * @return multiplicative inverse of a\n */\n inverse(a /*int*/) {\n if (a === 0) {\n throw new ArithmeticException();\n }\n return this.expTable[this.size - this.logTable[a] - 1];\n }\n /**\n * @return product of a and b in GF(size)\n */\n multiply(a /*int*/, b /*int*/) {\n if (a === 0 || b === 0) {\n return 0;\n }\n return this.expTable[(this.logTable[a] + this.logTable[b]) % (this.size - 1)];\n }\n getSize() {\n return this.size;\n }\n getGeneratorBase() {\n return this.generatorBase;\n }\n /*@Override*/\n toString() {\n return ('GF(0x' + Integer.toHexString(this.primitive) + ',' + this.size + ')');\n }\n equals(o) {\n return o === this;\n }\n }\n GenericGF.AZTEC_DATA_12 = new GenericGF(0x1069, 4096, 1); // x^12 + x^6 + x^5 + x^3 + 1\n GenericGF.AZTEC_DATA_10 = new GenericGF(0x409, 1024, 1); // x^10 + x^3 + 1\n GenericGF.AZTEC_DATA_6 = new GenericGF(0x43, 64, 1); // x^6 + x + 1\n GenericGF.AZTEC_PARAM = new GenericGF(0x13, 16, 1); // x^4 + x + 1\n GenericGF.QR_CODE_FIELD_256 = new GenericGF(0x011d, 256, 0); // x^8 + x^4 + x^3 + x^2 + 1\n GenericGF.DATA_MATRIX_FIELD_256 = new GenericGF(0x012d, 256, 1); // x^8 + x^5 + x^3 + x^2 + 1\n GenericGF.AZTEC_DATA_8 = GenericGF.DATA_MATRIX_FIELD_256;\n GenericGF.MAXICODE_FIELD_64 = GenericGF.AZTEC_DATA_6;\n\n /**\n * Custom Error class of type Exception.\n */\n class ReedSolomonException extends Exception {\n }\n ReedSolomonException.kind = 'ReedSolomonException';\n\n /**\n * Custom Error class of type Exception.\n */\n class IllegalStateException extends Exception {\n }\n IllegalStateException.kind = 'IllegalStateException';\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Implements Reed-Solomon decoding, as the name implies.

\n *\n *

The algorithm will not be explained here, but the following references were helpful\n * in creating this implementation:

\n *\n * \n *\n *

Much credit is due to William Rucklidge since portions of this code are an indirect\n * port of his C++ Reed-Solomon implementation.

\n *\n * @author Sean Owen\n * @author William Rucklidge\n * @author sanfordsquires\n */\n class ReedSolomonDecoder {\n constructor(field) {\n this.field = field;\n }\n /**\n *

Decodes given set of received codewords, which include both data and error-correction\n * codewords. Really, this means it uses Reed-Solomon to detect and correct errors, in-place,\n * in the input.

\n *\n * @param received data and error-correction codewords\n * @param twoS number of error-correction codewords available\n * @throws ReedSolomonException if decoding fails for any reason\n */\n decode(received, twoS /*int*/) {\n const field = this.field;\n const poly = new GenericGFPoly(field, received);\n const syndromeCoefficients = new Int32Array(twoS);\n let noError = true;\n for (let i = 0; i < twoS; i++) {\n const evalResult = poly.evaluateAt(field.exp(i + field.getGeneratorBase()));\n syndromeCoefficients[syndromeCoefficients.length - 1 - i] = evalResult;\n if (evalResult !== 0) {\n noError = false;\n }\n }\n if (noError) {\n return;\n }\n const syndrome = new GenericGFPoly(field, syndromeCoefficients);\n const sigmaOmega = this.runEuclideanAlgorithm(field.buildMonomial(twoS, 1), syndrome, twoS);\n const sigma = sigmaOmega[0];\n const omega = sigmaOmega[1];\n const errorLocations = this.findErrorLocations(sigma);\n const errorMagnitudes = this.findErrorMagnitudes(omega, errorLocations);\n for (let i = 0; i < errorLocations.length; i++) {\n const position = received.length - 1 - field.log(errorLocations[i]);\n if (position < 0) {\n throw new ReedSolomonException('Bad error location');\n }\n received[position] = GenericGF.addOrSubtract(received[position], errorMagnitudes[i]);\n }\n }\n runEuclideanAlgorithm(a, b, R /*int*/) {\n // Assume a's degree is >= b's\n if (a.getDegree() < b.getDegree()) {\n const temp = a;\n a = b;\n b = temp;\n }\n const field = this.field;\n let rLast = a;\n let r = b;\n let tLast = field.getZero();\n let t = field.getOne();\n // Run Euclidean algorithm until r's degree is less than R/2\n while (r.getDegree() >= (R / 2 | 0)) {\n let rLastLast = rLast;\n let tLastLast = tLast;\n rLast = r;\n tLast = t;\n // Divide rLastLast by rLast, with quotient in q and remainder in r\n if (rLast.isZero()) {\n // Oops, Euclidean algorithm already terminated?\n throw new ReedSolomonException('r_{i-1} was zero');\n }\n r = rLastLast;\n let q = field.getZero();\n const denominatorLeadingTerm = rLast.getCoefficient(rLast.getDegree());\n const dltInverse = field.inverse(denominatorLeadingTerm);\n while (r.getDegree() >= rLast.getDegree() && !r.isZero()) {\n const degreeDiff = r.getDegree() - rLast.getDegree();\n const scale = field.multiply(r.getCoefficient(r.getDegree()), dltInverse);\n q = q.addOrSubtract(field.buildMonomial(degreeDiff, scale));\n r = r.addOrSubtract(rLast.multiplyByMonomial(degreeDiff, scale));\n }\n t = q.multiply(tLast).addOrSubtract(tLastLast);\n if (r.getDegree() >= rLast.getDegree()) {\n throw new IllegalStateException('Division algorithm failed to reduce polynomial?');\n }\n }\n const sigmaTildeAtZero = t.getCoefficient(0);\n if (sigmaTildeAtZero === 0) {\n throw new ReedSolomonException('sigmaTilde(0) was zero');\n }\n const inverse = field.inverse(sigmaTildeAtZero);\n const sigma = t.multiplyScalar(inverse);\n const omega = r.multiplyScalar(inverse);\n return [sigma, omega];\n }\n findErrorLocations(errorLocator) {\n // This is a direct application of Chien's search\n const numErrors = errorLocator.getDegree();\n if (numErrors === 1) { // shortcut\n return Int32Array.from([errorLocator.getCoefficient(1)]);\n }\n const result = new Int32Array(numErrors);\n let e = 0;\n const field = this.field;\n for (let i = 1; i < field.getSize() && e < numErrors; i++) {\n if (errorLocator.evaluateAt(i) === 0) {\n result[e] = field.inverse(i);\n e++;\n }\n }\n if (e !== numErrors) {\n throw new ReedSolomonException('Error locator degree does not match number of roots');\n }\n return result;\n }\n findErrorMagnitudes(errorEvaluator, errorLocations) {\n // This is directly applying Forney's Formula\n const s = errorLocations.length;\n const result = new Int32Array(s);\n const field = this.field;\n for (let i = 0; i < s; i++) {\n const xiInverse = field.inverse(errorLocations[i]);\n let denominator = 1;\n for (let j = 0; j < s; j++) {\n if (i !== j) {\n // denominator = field.multiply(denominator,\n // GenericGF.addOrSubtract(1, field.multiply(errorLocations[j], xiInverse)))\n // Above should work but fails on some Apple and Linux JDKs due to a Hotspot bug.\n // Below is a funny-looking workaround from Steven Parkes\n const term = field.multiply(errorLocations[j], xiInverse);\n const termPlus1 = (term & 0x1) === 0 ? term | 1 : term & ~1;\n denominator = field.multiply(denominator, termPlus1);\n }\n }\n result[i] = field.multiply(errorEvaluator.evaluateAt(xiInverse), field.inverse(denominator));\n if (field.getGeneratorBase() !== 0) {\n result[i] = field.multiply(result[i], xiInverse);\n }\n }\n return result;\n }\n }\n\n /*\n * Copyright 2010 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // import java.util.Arrays;\n var Table;\n (function (Table) {\n Table[Table[\"UPPER\"] = 0] = \"UPPER\";\n Table[Table[\"LOWER\"] = 1] = \"LOWER\";\n Table[Table[\"MIXED\"] = 2] = \"MIXED\";\n Table[Table[\"DIGIT\"] = 3] = \"DIGIT\";\n Table[Table[\"PUNCT\"] = 4] = \"PUNCT\";\n Table[Table[\"BINARY\"] = 5] = \"BINARY\";\n })(Table || (Table = {}));\n /**\n *

The main class which implements Aztec Code decoding -- as opposed to locating and extracting\n * the Aztec Code from an image.

\n *\n * @author David Olivier\n */\n class Decoder {\n decode(detectorResult) {\n this.ddata = detectorResult;\n let matrix = detectorResult.getBits();\n let rawbits = this.extractBits(matrix);\n let correctedBits = this.correctBits(rawbits);\n let rawBytes = Decoder.convertBoolArrayToByteArray(correctedBits);\n let result = Decoder.getEncodedData(correctedBits);\n let decoderResult = new DecoderResult(rawBytes, result, null, null);\n decoderResult.setNumBits(correctedBits.length);\n return decoderResult;\n }\n // This method is used for testing the high-level encoder\n static highLevelDecode(correctedBits) {\n return this.getEncodedData(correctedBits);\n }\n /**\n * Gets the string encoded in the aztec code bits\n *\n * @return the decoded string\n */\n static getEncodedData(correctedBits) {\n let endIndex = correctedBits.length;\n let latchTable = Table.UPPER; // table most recently latched to\n let shiftTable = Table.UPPER; // table to use for the next read\n let result = '';\n let index = 0;\n while (index < endIndex) {\n if (shiftTable === Table.BINARY) {\n if (endIndex - index < 5) {\n break;\n }\n let length = Decoder.readCode(correctedBits, index, 5);\n index += 5;\n if (length === 0) {\n if (endIndex - index < 11) {\n break;\n }\n length = Decoder.readCode(correctedBits, index, 11) + 31;\n index += 11;\n }\n for (let charCount = 0; charCount < length; charCount++) {\n if (endIndex - index < 8) {\n index = endIndex; // Force outer loop to exit\n break;\n }\n const code = Decoder.readCode(correctedBits, index, 8);\n result += /*(char)*/ StringUtils.castAsNonUtf8Char(code);\n index += 8;\n }\n // Go back to whatever mode we had been in\n shiftTable = latchTable;\n }\n else {\n let size = shiftTable === Table.DIGIT ? 4 : 5;\n if (endIndex - index < size) {\n break;\n }\n let code = Decoder.readCode(correctedBits, index, size);\n index += size;\n let str = Decoder.getCharacter(shiftTable, code);\n if (str.startsWith('CTRL_')) {\n // Table changes\n // ISO/IEC 24778:2008 prescribes ending a shift sequence in the mode from which it was invoked.\n // That's including when that mode is a shift.\n // Our test case dlusbs.png for issue #642 exercises that.\n latchTable = shiftTable; // Latch the current mode, so as to return to Upper after U/S B/S\n shiftTable = Decoder.getTable(str.charAt(5));\n if (str.charAt(6) === 'L') {\n latchTable = shiftTable;\n }\n }\n else {\n result += str;\n // Go back to whatever mode we had been in\n shiftTable = latchTable;\n }\n }\n }\n return result;\n }\n /**\n * gets the table corresponding to the char passed\n */\n static getTable(t) {\n switch (t) {\n case 'L':\n return Table.LOWER;\n case 'P':\n return Table.PUNCT;\n case 'M':\n return Table.MIXED;\n case 'D':\n return Table.DIGIT;\n case 'B':\n return Table.BINARY;\n case 'U':\n default:\n return Table.UPPER;\n }\n }\n /**\n * Gets the character (or string) corresponding to the passed code in the given table\n *\n * @param table the table used\n * @param code the code of the character\n */\n static getCharacter(table, code) {\n switch (table) {\n case Table.UPPER:\n return Decoder.UPPER_TABLE[code];\n case Table.LOWER:\n return Decoder.LOWER_TABLE[code];\n case Table.MIXED:\n return Decoder.MIXED_TABLE[code];\n case Table.PUNCT:\n return Decoder.PUNCT_TABLE[code];\n case Table.DIGIT:\n return Decoder.DIGIT_TABLE[code];\n default:\n // Should not reach here.\n throw new IllegalStateException('Bad table');\n }\n }\n /**\n *

Performs RS error correction on an array of bits.

\n *\n * @return the corrected array\n * @throws FormatException if the input contains too many errors\n */\n correctBits(rawbits) {\n let gf;\n let codewordSize;\n if (this.ddata.getNbLayers() <= 2) {\n codewordSize = 6;\n gf = GenericGF.AZTEC_DATA_6;\n }\n else if (this.ddata.getNbLayers() <= 8) {\n codewordSize = 8;\n gf = GenericGF.AZTEC_DATA_8;\n }\n else if (this.ddata.getNbLayers() <= 22) {\n codewordSize = 10;\n gf = GenericGF.AZTEC_DATA_10;\n }\n else {\n codewordSize = 12;\n gf = GenericGF.AZTEC_DATA_12;\n }\n let numDataCodewords = this.ddata.getNbDatablocks();\n let numCodewords = rawbits.length / codewordSize;\n if (numCodewords < numDataCodewords) {\n throw new FormatException();\n }\n let offset = rawbits.length % codewordSize;\n let dataWords = new Int32Array(numCodewords);\n for (let i = 0; i < numCodewords; i++, offset += codewordSize) {\n dataWords[i] = Decoder.readCode(rawbits, offset, codewordSize);\n }\n try {\n let rsDecoder = new ReedSolomonDecoder(gf);\n rsDecoder.decode(dataWords, numCodewords - numDataCodewords);\n }\n catch (ex) {\n throw new FormatException(ex);\n }\n // Now perform the unstuffing operation.\n // First, count how many bits are going to be thrown out as stuffing\n let mask = (1 << codewordSize) - 1;\n let stuffedBits = 0;\n for (let i = 0; i < numDataCodewords; i++) {\n let dataWord = dataWords[i];\n if (dataWord === 0 || dataWord === mask) {\n throw new FormatException();\n }\n else if (dataWord === 1 || dataWord === mask - 1) {\n stuffedBits++;\n }\n }\n // Now, actually unpack the bits and remove the stuffing\n let correctedBits = new Array(numDataCodewords * codewordSize - stuffedBits);\n let index = 0;\n for (let i = 0; i < numDataCodewords; i++) {\n let dataWord = dataWords[i];\n if (dataWord === 1 || dataWord === mask - 1) {\n // next codewordSize-1 bits are all zeros or all ones\n correctedBits.fill(dataWord > 1, index, index + codewordSize - 1);\n // Arrays.fill(correctedBits, index, index + codewordSize - 1, dataWord > 1);\n index += codewordSize - 1;\n }\n else {\n for (let bit = codewordSize - 1; bit >= 0; --bit) {\n correctedBits[index++] = (dataWord & (1 << bit)) !== 0;\n }\n }\n }\n return correctedBits;\n }\n /**\n * Gets the array of bits from an Aztec Code matrix\n *\n * @return the array of bits\n */\n extractBits(matrix) {\n let compact = this.ddata.isCompact();\n let layers = this.ddata.getNbLayers();\n let baseMatrixSize = (compact ? 11 : 14) + layers * 4; // not including alignment lines\n let alignmentMap = new Int32Array(baseMatrixSize);\n let rawbits = new Array(this.totalBitsInLayer(layers, compact));\n if (compact) {\n for (let i = 0; i < alignmentMap.length; i++) {\n alignmentMap[i] = i;\n }\n }\n else {\n let matrixSize = baseMatrixSize + 1 + 2 * Integer.truncDivision((Integer.truncDivision(baseMatrixSize, 2) - 1), 15);\n let origCenter = baseMatrixSize / 2;\n let center = Integer.truncDivision(matrixSize, 2);\n for (let i = 0; i < origCenter; i++) {\n let newOffset = i + Integer.truncDivision(i, 15);\n alignmentMap[origCenter - i - 1] = center - newOffset - 1;\n alignmentMap[origCenter + i] = center + newOffset + 1;\n }\n }\n for (let i = 0, rowOffset = 0; i < layers; i++) {\n let rowSize = (layers - i) * 4 + (compact ? 9 : 12);\n // The top-left most point of this layer is (not including alignment lines)\n let low = i * 2;\n // The bottom-right most point of this layer is (not including alignment lines)\n let high = baseMatrixSize - 1 - low;\n // We pull bits from the two 2 x rowSize columns and two rowSize x 2 rows\n for (let j = 0; j < rowSize; j++) {\n let columnOffset = j * 2;\n for (let k = 0; k < 2; k++) {\n // left column\n rawbits[rowOffset + columnOffset + k] =\n matrix.get(alignmentMap[low + k], alignmentMap[low + j]);\n // bottom row\n rawbits[rowOffset + 2 * rowSize + columnOffset + k] =\n matrix.get(alignmentMap[low + j], alignmentMap[high - k]);\n // right column\n rawbits[rowOffset + 4 * rowSize + columnOffset + k] =\n matrix.get(alignmentMap[high - k], alignmentMap[high - j]);\n // top row\n rawbits[rowOffset + 6 * rowSize + columnOffset + k] =\n matrix.get(alignmentMap[high - j], alignmentMap[low + k]);\n }\n }\n rowOffset += rowSize * 8;\n }\n return rawbits;\n }\n /**\n * Reads a code of given length and at given index in an array of bits\n */\n static readCode(rawbits, startIndex, length) {\n let res = 0;\n for (let i = startIndex; i < startIndex + length; i++) {\n res <<= 1;\n if (rawbits[i]) {\n res |= 0x01;\n }\n }\n return res;\n }\n /**\n * Reads a code of length 8 in an array of bits, padding with zeros\n */\n static readByte(rawbits, startIndex) {\n let n = rawbits.length - startIndex;\n if (n >= 8) {\n return Decoder.readCode(rawbits, startIndex, 8);\n }\n return Decoder.readCode(rawbits, startIndex, n) << (8 - n);\n }\n /**\n * Packs a bit array into bytes, most significant bit first\n */\n static convertBoolArrayToByteArray(boolArr) {\n let byteArr = new Uint8Array((boolArr.length + 7) / 8);\n for (let i = 0; i < byteArr.length; i++) {\n byteArr[i] = Decoder.readByte(boolArr, 8 * i);\n }\n return byteArr;\n }\n totalBitsInLayer(layers, compact) {\n return ((compact ? 88 : 112) + 16 * layers) * layers;\n }\n }\n Decoder.UPPER_TABLE = [\n 'CTRL_PS', ' ', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P',\n 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'CTRL_LL', 'CTRL_ML', 'CTRL_DL', 'CTRL_BS'\n ];\n Decoder.LOWER_TABLE = [\n 'CTRL_PS', ' ', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p',\n 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'CTRL_US', 'CTRL_ML', 'CTRL_DL', 'CTRL_BS'\n ];\n Decoder.MIXED_TABLE = [\n // Module parse failed: Octal literal in strict mode (50:29)\n // so number string were scaped\n 'CTRL_PS', ' ', '\\\\1', '\\\\2', '\\\\3', '\\\\4', '\\\\5', '\\\\6', '\\\\7', '\\b', '\\t', '\\n',\n '\\\\13', '\\f', '\\r', '\\\\33', '\\\\34', '\\\\35', '\\\\36', '\\\\37', '@', '\\\\', '^', '_',\n '`', '|', '~', '\\\\177', 'CTRL_LL', 'CTRL_UL', 'CTRL_PL', 'CTRL_BS'\n ];\n Decoder.PUNCT_TABLE = [\n '', '\\r', '\\r\\n', '. ', ', ', ': ', '!', '\"', '#', '$', '%', '&', '\\'', '(', ')',\n '*', '+', ',', '-', '.', '/', ':', ';', '<', '=', '>', '?', '[', ']', '{', '}', 'CTRL_UL'\n ];\n Decoder.DIGIT_TABLE = [\n 'CTRL_PS', ' ', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', ',', '.', 'CTRL_UL', 'CTRL_US'\n ];\n\n /*\n * Copyright 2012 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing.common.detector {*/\n /**\n * General math-related and numeric utility functions.\n */\n class MathUtils {\n constructor() { }\n /**\n * Ends up being a bit faster than {@link Math#round(float)}. This merely rounds its\n * argument to the nearest int, where x.5 rounds up to x+1. Semantics of this shortcut\n * differ slightly from {@link Math#round(float)} in that half rounds down for negative\n * values. -2.5 rounds to -3, not -2. For purposes here it makes no difference.\n *\n * @param d real value to round\n * @return nearest {@code int}\n */\n static round(d /*float*/) {\n if (NaN === d)\n return 0;\n if (d <= Number.MIN_SAFE_INTEGER)\n return Number.MIN_SAFE_INTEGER;\n if (d >= Number.MAX_SAFE_INTEGER)\n return Number.MAX_SAFE_INTEGER;\n return /*(int) */ (d + (d < 0.0 ? -0.5 : 0.5)) | 0;\n }\n // TYPESCRIPTPORT: maybe remove round method and call directly Math.round, it looks like it doesn't make sense for js\n /**\n * @param aX point A x coordinate\n * @param aY point A y coordinate\n * @param bX point B x coordinate\n * @param bY point B y coordinate\n * @return Euclidean distance between points A and B\n */\n static distance(aX /*float|int*/, aY /*float|int*/, bX /*float|int*/, bY /*float|int*/) {\n const xDiff = aX - bX;\n const yDiff = aY - bY;\n return /*(float) */ Math.sqrt(xDiff * xDiff + yDiff * yDiff);\n }\n /**\n * @param aX point A x coordinate\n * @param aY point A y coordinate\n * @param bX point B x coordinate\n * @param bY point B y coordinate\n * @return Euclidean distance between points A and B\n */\n // public static distance(aX: number /*int*/, aY: number /*int*/, bX: number /*int*/, bY: number /*int*/): float {\n // const xDiff = aX - bX\n // const yDiff = aY - bY\n // return (float) Math.sqrt(xDiff * xDiff + yDiff * yDiff);\n // }\n /**\n * @param array values to sum\n * @return sum of values in array\n */\n static sum(array) {\n let count = 0;\n for (let i = 0, length = array.length; i !== length; i++) {\n const a = array[i];\n count += a;\n }\n return count;\n }\n }\n\n /**\n * Ponyfill for Java's Float class.\n */\n class Float {\n /**\n * SincTS has no difference between int and float, there's all numbers,\n * this is used only to polyfill Java code.\n */\n static floatToIntBits(f) {\n return f;\n }\n }\n /**\n * The float max value in JS is the number max value.\n */\n Float.MAX_VALUE = Number.MAX_SAFE_INTEGER;\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates a point of interest in an image containing a barcode. Typically, this\n * would be the location of a finder pattern or the corner of the barcode, for example.

\n *\n * @author Sean Owen\n */\n class ResultPoint {\n constructor(x, y) {\n this.x = x;\n this.y = y;\n }\n getX() {\n return this.x;\n }\n getY() {\n return this.y;\n }\n /*@Override*/\n equals(other) {\n if (other instanceof ResultPoint) {\n const otherPoint = other;\n return this.x === otherPoint.x && this.y === otherPoint.y;\n }\n return false;\n }\n /*@Override*/\n hashCode() {\n return 31 * Float.floatToIntBits(this.x) + Float.floatToIntBits(this.y);\n }\n /*@Override*/\n toString() {\n return '(' + this.x + ',' + this.y + ')';\n }\n /**\n * Orders an array of three ResultPoints in an order [A,B,C] such that AB is less than AC\n * and BC is less than AC, and the angle between BC and BA is less than 180 degrees.\n *\n * @param patterns array of three {@code ResultPoint} to order\n */\n static orderBestPatterns(patterns) {\n // Find distances between pattern centers\n const zeroOneDistance = this.distance(patterns[0], patterns[1]);\n const oneTwoDistance = this.distance(patterns[1], patterns[2]);\n const zeroTwoDistance = this.distance(patterns[0], patterns[2]);\n let pointA;\n let pointB;\n let pointC;\n // Assume one closest to other two is B; A and C will just be guesses at first\n if (oneTwoDistance >= zeroOneDistance && oneTwoDistance >= zeroTwoDistance) {\n pointB = patterns[0];\n pointA = patterns[1];\n pointC = patterns[2];\n }\n else if (zeroTwoDistance >= oneTwoDistance && zeroTwoDistance >= zeroOneDistance) {\n pointB = patterns[1];\n pointA = patterns[0];\n pointC = patterns[2];\n }\n else {\n pointB = patterns[2];\n pointA = patterns[0];\n pointC = patterns[1];\n }\n // Use cross product to figure out whether A and C are correct or flipped.\n // This asks whether BC x BA has a positive z component, which is the arrangement\n // we want for A, B, C. If it's negative, then we've got it flipped around and\n // should swap A and C.\n if (this.crossProductZ(pointA, pointB, pointC) < 0.0) {\n const temp = pointA;\n pointA = pointC;\n pointC = temp;\n }\n patterns[0] = pointA;\n patterns[1] = pointB;\n patterns[2] = pointC;\n }\n /**\n * @param pattern1 first pattern\n * @param pattern2 second pattern\n * @return distance between two points\n */\n static distance(pattern1, pattern2) {\n return MathUtils.distance(pattern1.x, pattern1.y, pattern2.x, pattern2.y);\n }\n /**\n * Returns the z component of the cross product between vectors BC and BA.\n */\n static crossProductZ(pointA, pointB, pointC) {\n const bX = pointB.x;\n const bY = pointB.y;\n return ((pointC.x - bX) * (pointA.y - bY)) - ((pointC.y - bY) * (pointA.x - bX));\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates the result of detecting a barcode in an image. This includes the raw\n * matrix of black/white pixels corresponding to the barcode, and possibly points of interest\n * in the image, like the location of finder patterns or corners of the barcode in the image.

\n *\n * @author Sean Owen\n */\n class DetectorResult {\n constructor(bits, points) {\n this.bits = bits;\n this.points = points;\n }\n getBits() {\n return this.bits;\n }\n getPoints() {\n return this.points;\n }\n }\n\n /*\n * Copyright 2010 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Extends {@link DetectorResult} with more information specific to the Aztec format,\n * like the number of layers and whether it's compact.

\n *\n * @author Sean Owen\n */\n class AztecDetectorResult extends DetectorResult {\n constructor(bits, points, compact, nbDatablocks, nbLayers) {\n super(bits, points);\n this.compact = compact;\n this.nbDatablocks = nbDatablocks;\n this.nbLayers = nbLayers;\n }\n getNbLayers() {\n return this.nbLayers;\n }\n getNbDatablocks() {\n return this.nbDatablocks;\n }\n isCompact() {\n return this.compact;\n }\n }\n\n /*\n * Copyright 2010 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

\n * Detects a candidate barcode-like rectangular region within an image. It\n * starts around the center of the image, increases the size of the candidate\n * region until it finds a white rectangular region. By keeping track of the\n * last black points it encountered, it determines the corners of the barcode.\n *

\n *\n * @author David Olivier\n */\n class WhiteRectangleDetector {\n // public constructor(private image: BitMatrix) /*throws NotFoundException*/ {\n // this(image, INIT_SIZE, image.getWidth() / 2, image.getHeight() / 2)\n // }\n /**\n * @param image barcode image to find a rectangle in\n * @param initSize initial size of search area around center\n * @param x x position of search center\n * @param y y position of search center\n * @throws NotFoundException if image is too small to accommodate {@code initSize}\n */\n constructor(image, initSize /*int*/, x /*int*/, y /*int*/) {\n this.image = image;\n this.height = image.getHeight();\n this.width = image.getWidth();\n if (undefined === initSize || null === initSize) {\n initSize = WhiteRectangleDetector.INIT_SIZE;\n }\n if (undefined === x || null === x) {\n x = image.getWidth() / 2 | 0;\n }\n if (undefined === y || null === y) {\n y = image.getHeight() / 2 | 0;\n }\n const halfsize = initSize / 2 | 0;\n this.leftInit = x - halfsize;\n this.rightInit = x + halfsize;\n this.upInit = y - halfsize;\n this.downInit = y + halfsize;\n if (this.upInit < 0 || this.leftInit < 0 || this.downInit >= this.height || this.rightInit >= this.width) {\n throw new NotFoundException();\n }\n }\n /**\n *

\n * Detects a candidate barcode-like rectangular region within an image. It\n * starts around the center of the image, increases the size of the candidate\n * region until it finds a white rectangular region.\n *

\n *\n * @return {@link ResultPoint}[] describing the corners of the rectangular\n * region. The first and last points are opposed on the diagonal, as\n * are the second and third. The first point will be the topmost\n * point and the last, the bottommost. The second point will be\n * leftmost and the third, the rightmost\n * @throws NotFoundException if no Data Matrix Code can be found\n */\n detect() {\n let left = this.leftInit;\n let right = this.rightInit;\n let up = this.upInit;\n let down = this.downInit;\n let sizeExceeded = false;\n let aBlackPointFoundOnBorder = true;\n let atLeastOneBlackPointFoundOnBorder = false;\n let atLeastOneBlackPointFoundOnRight = false;\n let atLeastOneBlackPointFoundOnBottom = false;\n let atLeastOneBlackPointFoundOnLeft = false;\n let atLeastOneBlackPointFoundOnTop = false;\n const width = this.width;\n const height = this.height;\n while (aBlackPointFoundOnBorder) {\n aBlackPointFoundOnBorder = false;\n // .....\n // . |\n // .....\n let rightBorderNotWhite = true;\n while ((rightBorderNotWhite || !atLeastOneBlackPointFoundOnRight) && right < width) {\n rightBorderNotWhite = this.containsBlackPoint(up, down, right, false);\n if (rightBorderNotWhite) {\n right++;\n aBlackPointFoundOnBorder = true;\n atLeastOneBlackPointFoundOnRight = true;\n }\n else if (!atLeastOneBlackPointFoundOnRight) {\n right++;\n }\n }\n if (right >= width) {\n sizeExceeded = true;\n break;\n }\n // .....\n // . .\n // .___.\n let bottomBorderNotWhite = true;\n while ((bottomBorderNotWhite || !atLeastOneBlackPointFoundOnBottom) && down < height) {\n bottomBorderNotWhite = this.containsBlackPoint(left, right, down, true);\n if (bottomBorderNotWhite) {\n down++;\n aBlackPointFoundOnBorder = true;\n atLeastOneBlackPointFoundOnBottom = true;\n }\n else if (!atLeastOneBlackPointFoundOnBottom) {\n down++;\n }\n }\n if (down >= height) {\n sizeExceeded = true;\n break;\n }\n // .....\n // | .\n // .....\n let leftBorderNotWhite = true;\n while ((leftBorderNotWhite || !atLeastOneBlackPointFoundOnLeft) && left >= 0) {\n leftBorderNotWhite = this.containsBlackPoint(up, down, left, false);\n if (leftBorderNotWhite) {\n left--;\n aBlackPointFoundOnBorder = true;\n atLeastOneBlackPointFoundOnLeft = true;\n }\n else if (!atLeastOneBlackPointFoundOnLeft) {\n left--;\n }\n }\n if (left < 0) {\n sizeExceeded = true;\n break;\n }\n // .___.\n // . .\n // .....\n let topBorderNotWhite = true;\n while ((topBorderNotWhite || !atLeastOneBlackPointFoundOnTop) && up >= 0) {\n topBorderNotWhite = this.containsBlackPoint(left, right, up, true);\n if (topBorderNotWhite) {\n up--;\n aBlackPointFoundOnBorder = true;\n atLeastOneBlackPointFoundOnTop = true;\n }\n else if (!atLeastOneBlackPointFoundOnTop) {\n up--;\n }\n }\n if (up < 0) {\n sizeExceeded = true;\n break;\n }\n if (aBlackPointFoundOnBorder) {\n atLeastOneBlackPointFoundOnBorder = true;\n }\n }\n if (!sizeExceeded && atLeastOneBlackPointFoundOnBorder) {\n const maxSize = right - left;\n let z = null;\n for (let i = 1; z === null && i < maxSize; i++) {\n z = this.getBlackPointOnSegment(left, down - i, left + i, down);\n }\n if (z == null) {\n throw new NotFoundException();\n }\n let t = null;\n // go down right\n for (let i = 1; t === null && i < maxSize; i++) {\n t = this.getBlackPointOnSegment(left, up + i, left + i, up);\n }\n if (t == null) {\n throw new NotFoundException();\n }\n let x = null;\n // go down left\n for (let i = 1; x === null && i < maxSize; i++) {\n x = this.getBlackPointOnSegment(right, up + i, right - i, up);\n }\n if (x == null) {\n throw new NotFoundException();\n }\n let y = null;\n // go up left\n for (let i = 1; y === null && i < maxSize; i++) {\n y = this.getBlackPointOnSegment(right, down - i, right - i, down);\n }\n if (y == null) {\n throw new NotFoundException();\n }\n return this.centerEdges(y, z, x, t);\n }\n else {\n throw new NotFoundException();\n }\n }\n getBlackPointOnSegment(aX /*float*/, aY /*float*/, bX /*float*/, bY /*float*/) {\n const dist = MathUtils.round(MathUtils.distance(aX, aY, bX, bY));\n const xStep = (bX - aX) / dist;\n const yStep = (bY - aY) / dist;\n const image = this.image;\n for (let i = 0; i < dist; i++) {\n const x = MathUtils.round(aX + i * xStep);\n const y = MathUtils.round(aY + i * yStep);\n if (image.get(x, y)) {\n return new ResultPoint(x, y);\n }\n }\n return null;\n }\n /**\n * recenters the points of a constant distance towards the center\n *\n * @param y bottom most point\n * @param z left most point\n * @param x right most point\n * @param t top most point\n * @return {@link ResultPoint}[] describing the corners of the rectangular\n * region. The first and last points are opposed on the diagonal, as\n * are the second and third. The first point will be the topmost\n * point and the last, the bottommost. The second point will be\n * leftmost and the third, the rightmost\n */\n centerEdges(y, z, x, t) {\n //\n // t t\n // z x\n // x OR z\n // y y\n //\n const yi = y.getX();\n const yj = y.getY();\n const zi = z.getX();\n const zj = z.getY();\n const xi = x.getX();\n const xj = x.getY();\n const ti = t.getX();\n const tj = t.getY();\n const CORR = WhiteRectangleDetector.CORR;\n if (yi < this.width / 2.0) {\n return [\n new ResultPoint(ti - CORR, tj + CORR),\n new ResultPoint(zi + CORR, zj + CORR),\n new ResultPoint(xi - CORR, xj - CORR),\n new ResultPoint(yi + CORR, yj - CORR)\n ];\n }\n else {\n return [\n new ResultPoint(ti + CORR, tj + CORR),\n new ResultPoint(zi + CORR, zj - CORR),\n new ResultPoint(xi - CORR, xj + CORR),\n new ResultPoint(yi - CORR, yj - CORR)\n ];\n }\n }\n /**\n * Determines whether a segment contains a black point\n *\n * @param a min value of the scanned coordinate\n * @param b max value of the scanned coordinate\n * @param fixed value of fixed coordinate\n * @param horizontal set to true if scan must be horizontal, false if vertical\n * @return true if a black point has been found, else false.\n */\n containsBlackPoint(a /*int*/, b /*int*/, fixed /*int*/, horizontal) {\n const image = this.image;\n if (horizontal) {\n for (let x = a; x <= b; x++) {\n if (image.get(x, fixed)) {\n return true;\n }\n }\n }\n else {\n for (let y = a; y <= b; y++) {\n if (image.get(fixed, y)) {\n return true;\n }\n }\n }\n return false;\n }\n }\n WhiteRectangleDetector.INIT_SIZE = 10;\n WhiteRectangleDetector.CORR = 1;\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * Implementations of this class can, given locations of finder patterns for a QR code in an\n * image, sample the right points in the image to reconstruct the QR code, accounting for\n * perspective distortion. It is abstracted since it is relatively expensive and should be allowed\n * to take advantage of platform-specific optimized implementations, like Sun's Java Advanced\n * Imaging library, but which may not be available in other environments such as J2ME, and vice\n * versa.\n *\n * The implementation used can be controlled by calling {@link #setGridSampler(GridSampler)}\n * with an instance of a class which implements this interface.\n *\n * @author Sean Owen\n */\n class GridSampler {\n /**\n *

Checks a set of points that have been transformed to sample points on an image against\n * the image's dimensions to see if the point are even within the image.

\n *\n *

This method will actually \"nudge\" the endpoints back onto the image if they are found to be\n * barely (less than 1 pixel) off the image. This accounts for imperfect detection of finder\n * patterns in an image where the QR Code runs all the way to the image border.

\n *\n *

For efficiency, the method will check points from either end of the line until one is found\n * to be within the image. Because the set of points are assumed to be linear, this is valid.

\n *\n * @param image image into which the points should map\n * @param points actual points in x1,y1,...,xn,yn form\n * @throws NotFoundException if an endpoint is lies outside the image boundaries\n */\n static checkAndNudgePoints(image, points) {\n const width = image.getWidth();\n const height = image.getHeight();\n // Check and nudge points from start until we see some that are OK:\n let nudged = true;\n for (let offset = 0; offset < points.length && nudged; offset += 2) {\n const x = Math.floor(points[offset]);\n const y = Math.floor(points[offset + 1]);\n if (x < -1 || x > width || y < -1 || y > height) {\n throw new NotFoundException();\n }\n nudged = false;\n if (x === -1) {\n points[offset] = 0.0;\n nudged = true;\n }\n else if (x === width) {\n points[offset] = width - 1;\n nudged = true;\n }\n if (y === -1) {\n points[offset + 1] = 0.0;\n nudged = true;\n }\n else if (y === height) {\n points[offset + 1] = height - 1;\n nudged = true;\n }\n }\n // Check and nudge points from end:\n nudged = true;\n for (let offset = points.length - 2; offset >= 0 && nudged; offset -= 2) {\n const x = Math.floor(points[offset]);\n const y = Math.floor(points[offset + 1]);\n if (x < -1 || x > width || y < -1 || y > height) {\n throw new NotFoundException();\n }\n nudged = false;\n if (x === -1) {\n points[offset] = 0.0;\n nudged = true;\n }\n else if (x === width) {\n points[offset] = width - 1;\n nudged = true;\n }\n if (y === -1) {\n points[offset + 1] = 0.0;\n nudged = true;\n }\n else if (y === height) {\n points[offset + 1] = height - 1;\n nudged = true;\n }\n }\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing.common {*/\n /**\n *

This class implements a perspective transform in two dimensions. Given four source and four\n * destination points, it will compute the transformation implied between them. The code is based\n * directly upon section 3.4.2 of George Wolberg's \"Digital Image Warping\"; see pages 54-56.

\n *\n * @author Sean Owen\n */\n class PerspectiveTransform {\n constructor(a11 /*float*/, a21 /*float*/, a31 /*float*/, a12 /*float*/, a22 /*float*/, a32 /*float*/, a13 /*float*/, a23 /*float*/, a33 /*float*/) {\n this.a11 = a11;\n this.a21 = a21;\n this.a31 = a31;\n this.a12 = a12;\n this.a22 = a22;\n this.a32 = a32;\n this.a13 = a13;\n this.a23 = a23;\n this.a33 = a33;\n }\n static quadrilateralToQuadrilateral(x0 /*float*/, y0 /*float*/, x1 /*float*/, y1 /*float*/, x2 /*float*/, y2 /*float*/, x3 /*float*/, y3 /*float*/, x0p /*float*/, y0p /*float*/, x1p /*float*/, y1p /*float*/, x2p /*float*/, y2p /*float*/, x3p /*float*/, y3p /*float*/) {\n const qToS = PerspectiveTransform.quadrilateralToSquare(x0, y0, x1, y1, x2, y2, x3, y3);\n const sToQ = PerspectiveTransform.squareToQuadrilateral(x0p, y0p, x1p, y1p, x2p, y2p, x3p, y3p);\n return sToQ.times(qToS);\n }\n transformPoints(points) {\n const max = points.length;\n const a11 = this.a11;\n const a12 = this.a12;\n const a13 = this.a13;\n const a21 = this.a21;\n const a22 = this.a22;\n const a23 = this.a23;\n const a31 = this.a31;\n const a32 = this.a32;\n const a33 = this.a33;\n for (let i = 0; i < max; i += 2) {\n const x = points[i];\n const y = points[i + 1];\n const denominator = a13 * x + a23 * y + a33;\n points[i] = (a11 * x + a21 * y + a31) / denominator;\n points[i + 1] = (a12 * x + a22 * y + a32) / denominator;\n }\n }\n transformPointsWithValues(xValues, yValues) {\n const a11 = this.a11;\n const a12 = this.a12;\n const a13 = this.a13;\n const a21 = this.a21;\n const a22 = this.a22;\n const a23 = this.a23;\n const a31 = this.a31;\n const a32 = this.a32;\n const a33 = this.a33;\n const n = xValues.length;\n for (let i = 0; i < n; i++) {\n const x = xValues[i];\n const y = yValues[i];\n const denominator = a13 * x + a23 * y + a33;\n xValues[i] = (a11 * x + a21 * y + a31) / denominator;\n yValues[i] = (a12 * x + a22 * y + a32) / denominator;\n }\n }\n static squareToQuadrilateral(x0 /*float*/, y0 /*float*/, x1 /*float*/, y1 /*float*/, x2 /*float*/, y2 /*float*/, x3 /*float*/, y3 /*float*/) {\n const dx3 = x0 - x1 + x2 - x3;\n const dy3 = y0 - y1 + y2 - y3;\n if (dx3 === 0.0 && dy3 === 0.0) {\n // Affine\n return new PerspectiveTransform(x1 - x0, x2 - x1, x0, y1 - y0, y2 - y1, y0, 0.0, 0.0, 1.0);\n }\n else {\n const dx1 = x1 - x2;\n const dx2 = x3 - x2;\n const dy1 = y1 - y2;\n const dy2 = y3 - y2;\n const denominator = dx1 * dy2 - dx2 * dy1;\n const a13 = (dx3 * dy2 - dx2 * dy3) / denominator;\n const a23 = (dx1 * dy3 - dx3 * dy1) / denominator;\n return new PerspectiveTransform(x1 - x0 + a13 * x1, x3 - x0 + a23 * x3, x0, y1 - y0 + a13 * y1, y3 - y0 + a23 * y3, y0, a13, a23, 1.0);\n }\n }\n static quadrilateralToSquare(x0 /*float*/, y0 /*float*/, x1 /*float*/, y1 /*float*/, x2 /*float*/, y2 /*float*/, x3 /*float*/, y3 /*float*/) {\n // Here, the adjoint serves as the inverse:\n return PerspectiveTransform.squareToQuadrilateral(x0, y0, x1, y1, x2, y2, x3, y3).buildAdjoint();\n }\n buildAdjoint() {\n // Adjoint is the transpose of the cofactor matrix:\n return new PerspectiveTransform(this.a22 * this.a33 - this.a23 * this.a32, this.a23 * this.a31 - this.a21 * this.a33, this.a21 * this.a32 - this.a22 * this.a31, this.a13 * this.a32 - this.a12 * this.a33, this.a11 * this.a33 - this.a13 * this.a31, this.a12 * this.a31 - this.a11 * this.a32, this.a12 * this.a23 - this.a13 * this.a22, this.a13 * this.a21 - this.a11 * this.a23, this.a11 * this.a22 - this.a12 * this.a21);\n }\n times(other) {\n return new PerspectiveTransform(this.a11 * other.a11 + this.a21 * other.a12 + this.a31 * other.a13, this.a11 * other.a21 + this.a21 * other.a22 + this.a31 * other.a23, this.a11 * other.a31 + this.a21 * other.a32 + this.a31 * other.a33, this.a12 * other.a11 + this.a22 * other.a12 + this.a32 * other.a13, this.a12 * other.a21 + this.a22 * other.a22 + this.a32 * other.a23, this.a12 * other.a31 + this.a22 * other.a32 + this.a32 * other.a33, this.a13 * other.a11 + this.a23 * other.a12 + this.a33 * other.a13, this.a13 * other.a21 + this.a23 * other.a22 + this.a33 * other.a23, this.a13 * other.a31 + this.a23 * other.a32 + this.a33 * other.a33);\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author Sean Owen\n */\n class DefaultGridSampler extends GridSampler {\n /*@Override*/\n sampleGrid(image, dimensionX /*int*/, dimensionY /*int*/, p1ToX /*float*/, p1ToY /*float*/, p2ToX /*float*/, p2ToY /*float*/, p3ToX /*float*/, p3ToY /*float*/, p4ToX /*float*/, p4ToY /*float*/, p1FromX /*float*/, p1FromY /*float*/, p2FromX /*float*/, p2FromY /*float*/, p3FromX /*float*/, p3FromY /*float*/, p4FromX /*float*/, p4FromY /*float*/) {\n const transform = PerspectiveTransform.quadrilateralToQuadrilateral(p1ToX, p1ToY, p2ToX, p2ToY, p3ToX, p3ToY, p4ToX, p4ToY, p1FromX, p1FromY, p2FromX, p2FromY, p3FromX, p3FromY, p4FromX, p4FromY);\n return this.sampleGridWithTransform(image, dimensionX, dimensionY, transform);\n }\n /*@Override*/\n sampleGridWithTransform(image, dimensionX /*int*/, dimensionY /*int*/, transform) {\n if (dimensionX <= 0 || dimensionY <= 0) {\n throw new NotFoundException();\n }\n const bits = new BitMatrix(dimensionX, dimensionY);\n const points = new Float32Array(2 * dimensionX);\n for (let y = 0; y < dimensionY; y++) {\n const max = points.length;\n const iValue = y + 0.5;\n for (let x = 0; x < max; x += 2) {\n points[x] = (x / 2) + 0.5;\n points[x + 1] = iValue;\n }\n transform.transformPoints(points);\n // Quick check to see if points transformed to something inside the image\n // sufficient to check the endpoints\n GridSampler.checkAndNudgePoints(image, points);\n try {\n for (let x = 0; x < max; x += 2) {\n if (image.get(Math.floor(points[x]), Math.floor(points[x + 1]))) {\n // Black(-ish) pixel\n bits.set(x / 2, y);\n }\n }\n }\n catch (aioobe /*: ArrayIndexOutOfBoundsException*/) {\n // This feels wrong, but, sometimes if the finder patterns are misidentified, the resulting\n // transform gets \"twisted\" such that it maps a straight line of points to a set of points\n // whose endpoints are in bounds, but others are not. There is probably some mathematical\n // way to detect this about the transformation that I don't know yet.\n // This results in an ugly runtime exception despite our clever checks above -- can't have\n // that. We could check each point's coordinates but that feels duplicative. We settle for\n // catching and wrapping ArrayIndexOutOfBoundsException.\n throw new NotFoundException();\n }\n }\n return bits;\n }\n }\n\n class GridSamplerInstance {\n /**\n * Sets the implementation of GridSampler used by the library. One global\n * instance is stored, which may sound problematic. But, the implementation provided\n * ought to be appropriate for the entire platform, and all uses of this library\n * in the whole lifetime of the JVM. For instance, an Android activity can swap in\n * an implementation that takes advantage of native platform libraries.\n *\n * @param newGridSampler The platform-specific object to install.\n */\n static setGridSampler(newGridSampler) {\n GridSamplerInstance.gridSampler = newGridSampler;\n }\n /**\n * @return the current implementation of GridSampler\n */\n static getInstance() {\n return GridSamplerInstance.gridSampler;\n }\n }\n GridSamplerInstance.gridSampler = new DefaultGridSampler();\n\n /*\n * Copyright 2010 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n class Point {\n constructor(x, y) {\n this.x = x;\n this.y = y;\n }\n toResultPoint() {\n return new ResultPoint(this.getX(), this.getY());\n }\n getX() {\n return this.x;\n }\n getY() {\n return this.y;\n }\n }\n /**\n * Encapsulates logic that can detect an Aztec Code in an image, even if the Aztec Code\n * is rotated or skewed, or partially obscured.\n *\n * @author David Olivier\n * @author Frank Yellin\n */\n class Detector {\n constructor(image) {\n this.EXPECTED_CORNER_BITS = new Int32Array([\n 0xee0,\n 0x1dc,\n 0x83b,\n 0x707,\n ]);\n this.image = image;\n }\n detect() {\n return this.detectMirror(false);\n }\n /**\n * Detects an Aztec Code in an image.\n *\n * @param isMirror if true, image is a mirror-image of original\n * @return {@link AztecDetectorResult} encapsulating results of detecting an Aztec Code\n * @throws NotFoundException if no Aztec Code can be found\n */\n detectMirror(isMirror) {\n // 1. Get the center of the aztec matrix\n let pCenter = this.getMatrixCenter();\n // 2. Get the center points of the four diagonal points just outside the bull's eye\n // [topRight, bottomRight, bottomLeft, topLeft]\n let bullsEyeCorners = this.getBullsEyeCorners(pCenter);\n if (isMirror) {\n let temp = bullsEyeCorners[0];\n bullsEyeCorners[0] = bullsEyeCorners[2];\n bullsEyeCorners[2] = temp;\n }\n // 3. Get the size of the matrix and other parameters from the bull's eye\n this.extractParameters(bullsEyeCorners);\n // 4. Sample the grid\n let bits = this.sampleGrid(this.image, bullsEyeCorners[this.shift % 4], bullsEyeCorners[(this.shift + 1) % 4], bullsEyeCorners[(this.shift + 2) % 4], bullsEyeCorners[(this.shift + 3) % 4]);\n // 5. Get the corners of the matrix.\n let corners = this.getMatrixCornerPoints(bullsEyeCorners);\n return new AztecDetectorResult(bits, corners, this.compact, this.nbDataBlocks, this.nbLayers);\n }\n /**\n * Extracts the number of data layers and data blocks from the layer around the bull's eye.\n *\n * @param bullsEyeCorners the array of bull's eye corners\n * @throws NotFoundException in case of too many errors or invalid parameters\n */\n extractParameters(bullsEyeCorners) {\n if (!this.isValidPoint(bullsEyeCorners[0]) || !this.isValidPoint(bullsEyeCorners[1]) ||\n !this.isValidPoint(bullsEyeCorners[2]) || !this.isValidPoint(bullsEyeCorners[3])) {\n throw new NotFoundException();\n }\n let length = 2 * this.nbCenterLayers;\n // Get the bits around the bull's eye\n let sides = new Int32Array([\n this.sampleLine(bullsEyeCorners[0], bullsEyeCorners[1], length),\n this.sampleLine(bullsEyeCorners[1], bullsEyeCorners[2], length),\n this.sampleLine(bullsEyeCorners[2], bullsEyeCorners[3], length),\n this.sampleLine(bullsEyeCorners[3], bullsEyeCorners[0], length) // Top\n ]);\n // bullsEyeCorners[shift] is the corner of the bulls'eye that has three\n // orientation marks.\n // sides[shift] is the row/column that goes from the corner with three\n // orientation marks to the corner with two.\n this.shift = this.getRotation(sides, length);\n // Flatten the parameter bits into a single 28- or 40-bit long\n let parameterData = 0;\n for (let i = 0; i < 4; i++) {\n let side = sides[(this.shift + i) % 4];\n if (this.compact) {\n // Each side of the form ..XXXXXXX. where Xs are parameter data\n parameterData <<= 7;\n parameterData += (side >> 1) & 0x7F;\n }\n else {\n // Each side of the form ..XXXXX.XXXXX. where Xs are parameter data\n parameterData <<= 10;\n parameterData += ((side >> 2) & (0x1f << 5)) + ((side >> 1) & 0x1F);\n }\n }\n // Corrects parameter data using RS. Returns just the data portion\n // without the error correction.\n let correctedData = this.getCorrectedParameterData(parameterData, this.compact);\n if (this.compact) {\n // 8 bits: 2 bits layers and 6 bits data blocks\n this.nbLayers = (correctedData >> 6) + 1;\n this.nbDataBlocks = (correctedData & 0x3F) + 1;\n }\n else {\n // 16 bits: 5 bits layers and 11 bits data blocks\n this.nbLayers = (correctedData >> 11) + 1;\n this.nbDataBlocks = (correctedData & 0x7FF) + 1;\n }\n }\n getRotation(sides, length) {\n // In a normal pattern, we expect to See\n // ** .* D A\n // * *\n //\n // . *\n // .. .. C B\n //\n // Grab the 3 bits from each of the sides the form the locator pattern and concatenate\n // into a 12-bit integer. Start with the bit at A\n let cornerBits = 0;\n sides.forEach((side, idx, arr) => {\n // XX......X where X's are orientation marks\n let t = ((side >> (length - 2)) << 1) + (side & 1);\n cornerBits = (cornerBits << 3) + t;\n });\n // for (var side in sides) {\n // // XX......X where X's are orientation marks\n // var t = ((side >> (length - 2)) << 1) + (side & 1);\n // cornerBits = (cornerBits << 3) + t;\n // }\n // Mov the bottom bit to the top, so that the three bits of the locator pattern at A are\n // together. cornerBits is now:\n // 3 orientation bits at A || 3 orientation bits at B || ... || 3 orientation bits at D\n cornerBits = ((cornerBits & 1) << 11) + (cornerBits >> 1);\n // The result shift indicates which element of BullsEyeCorners[] goes into the top-left\n // corner. Since the four rotation values have a Hamming distance of 8, we\n // can easily tolerate two errors.\n for (let shift = 0; shift < 4; shift++) {\n if (Integer.bitCount(cornerBits ^ this.EXPECTED_CORNER_BITS[shift]) <= 2) {\n return shift;\n }\n }\n throw new NotFoundException();\n }\n /**\n * Corrects the parameter bits using Reed-Solomon algorithm.\n *\n * @param parameterData parameter bits\n * @param compact true if this is a compact Aztec code\n * @throws NotFoundException if the array contains too many errors\n */\n getCorrectedParameterData(parameterData, compact) {\n let numCodewords;\n let numDataCodewords;\n if (compact) {\n numCodewords = 7;\n numDataCodewords = 2;\n }\n else {\n numCodewords = 10;\n numDataCodewords = 4;\n }\n let numECCodewords = numCodewords - numDataCodewords;\n let parameterWords = new Int32Array(numCodewords);\n for (let i = numCodewords - 1; i >= 0; --i) {\n parameterWords[i] = parameterData & 0xF;\n parameterData >>= 4;\n }\n try {\n let rsDecoder = new ReedSolomonDecoder(GenericGF.AZTEC_PARAM);\n rsDecoder.decode(parameterWords, numECCodewords);\n }\n catch (ignored) {\n throw new NotFoundException();\n }\n // Toss the error correction. Just return the data as an integer\n let result = 0;\n for (let i = 0; i < numDataCodewords; i++) {\n result = (result << 4) + parameterWords[i];\n }\n return result;\n }\n /**\n * Finds the corners of a bull-eye centered on the passed point.\n * This returns the centers of the diagonal points just outside the bull's eye\n * Returns [topRight, bottomRight, bottomLeft, topLeft]\n *\n * @param pCenter Center point\n * @return The corners of the bull-eye\n * @throws NotFoundException If no valid bull-eye can be found\n */\n getBullsEyeCorners(pCenter) {\n let pina = pCenter;\n let pinb = pCenter;\n let pinc = pCenter;\n let pind = pCenter;\n let color = true;\n for (this.nbCenterLayers = 1; this.nbCenterLayers < 9; this.nbCenterLayers++) {\n let pouta = this.getFirstDifferent(pina, color, 1, -1);\n let poutb = this.getFirstDifferent(pinb, color, 1, 1);\n let poutc = this.getFirstDifferent(pinc, color, -1, 1);\n let poutd = this.getFirstDifferent(pind, color, -1, -1);\n // d a\n //\n // c b\n if (this.nbCenterLayers > 2) {\n let q = (this.distancePoint(poutd, pouta) * this.nbCenterLayers) / (this.distancePoint(pind, pina) * (this.nbCenterLayers + 2));\n if (q < 0.75 || q > 1.25 || !this.isWhiteOrBlackRectangle(pouta, poutb, poutc, poutd)) {\n break;\n }\n }\n pina = pouta;\n pinb = poutb;\n pinc = poutc;\n pind = poutd;\n color = !color;\n }\n if (this.nbCenterLayers !== 5 && this.nbCenterLayers !== 7) {\n throw new NotFoundException();\n }\n this.compact = this.nbCenterLayers === 5;\n // Expand the square by .5 pixel in each direction so that we're on the border\n // between the white square and the black square\n let pinax = new ResultPoint(pina.getX() + 0.5, pina.getY() - 0.5);\n let pinbx = new ResultPoint(pinb.getX() + 0.5, pinb.getY() + 0.5);\n let pincx = new ResultPoint(pinc.getX() - 0.5, pinc.getY() + 0.5);\n let pindx = new ResultPoint(pind.getX() - 0.5, pind.getY() - 0.5);\n // Expand the square so that its corners are the centers of the points\n // just outside the bull's eye.\n return this.expandSquare([pinax, pinbx, pincx, pindx], 2 * this.nbCenterLayers - 3, 2 * this.nbCenterLayers);\n }\n /**\n * Finds a candidate center point of an Aztec code from an image\n *\n * @return the center point\n */\n getMatrixCenter() {\n let pointA;\n let pointB;\n let pointC;\n let pointD;\n // Get a white rectangle that can be the border of the matrix in center bull's eye or\n try {\n let cornerPoints = new WhiteRectangleDetector(this.image).detect();\n pointA = cornerPoints[0];\n pointB = cornerPoints[1];\n pointC = cornerPoints[2];\n pointD = cornerPoints[3];\n }\n catch (e) {\n // This exception can be in case the initial rectangle is white\n // In that case, surely in the bull's eye, we try to expand the rectangle.\n let cx = this.image.getWidth() / 2;\n let cy = this.image.getHeight() / 2;\n pointA = this.getFirstDifferent(new Point(cx + 7, cy - 7), false, 1, -1).toResultPoint();\n pointB = this.getFirstDifferent(new Point(cx + 7, cy + 7), false, 1, 1).toResultPoint();\n pointC = this.getFirstDifferent(new Point(cx - 7, cy + 7), false, -1, 1).toResultPoint();\n pointD = this.getFirstDifferent(new Point(cx - 7, cy - 7), false, -1, -1).toResultPoint();\n }\n // Compute the center of the rectangle\n let cx = MathUtils.round((pointA.getX() + pointD.getX() + pointB.getX() + pointC.getX()) / 4.0);\n let cy = MathUtils.round((pointA.getY() + pointD.getY() + pointB.getY() + pointC.getY()) / 4.0);\n // Redetermine the white rectangle starting from previously computed center.\n // This will ensure that we end up with a white rectangle in center bull's eye\n // in order to compute a more accurate center.\n try {\n let cornerPoints = new WhiteRectangleDetector(this.image, 15, cx, cy).detect();\n pointA = cornerPoints[0];\n pointB = cornerPoints[1];\n pointC = cornerPoints[2];\n pointD = cornerPoints[3];\n }\n catch (e) {\n // This exception can be in case the initial rectangle is white\n // In that case we try to expand the rectangle.\n pointA = this.getFirstDifferent(new Point(cx + 7, cy - 7), false, 1, -1).toResultPoint();\n pointB = this.getFirstDifferent(new Point(cx + 7, cy + 7), false, 1, 1).toResultPoint();\n pointC = this.getFirstDifferent(new Point(cx - 7, cy + 7), false, -1, 1).toResultPoint();\n pointD = this.getFirstDifferent(new Point(cx - 7, cy - 7), false, -1, -1).toResultPoint();\n }\n // Recompute the center of the rectangle\n cx = MathUtils.round((pointA.getX() + pointD.getX() + pointB.getX() + pointC.getX()) / 4.0);\n cy = MathUtils.round((pointA.getY() + pointD.getY() + pointB.getY() + pointC.getY()) / 4.0);\n return new Point(cx, cy);\n }\n /**\n * Gets the Aztec code corners from the bull's eye corners and the parameters.\n *\n * @param bullsEyeCorners the array of bull's eye corners\n * @return the array of aztec code corners\n */\n getMatrixCornerPoints(bullsEyeCorners) {\n return this.expandSquare(bullsEyeCorners, 2 * this.nbCenterLayers, this.getDimension());\n }\n /**\n * Creates a BitMatrix by sampling the provided image.\n * topLeft, topRight, bottomRight, and bottomLeft are the centers of the squares on the\n * diagonal just outside the bull's eye.\n */\n sampleGrid(image, topLeft, topRight, bottomRight, bottomLeft) {\n let sampler = GridSamplerInstance.getInstance();\n let dimension = this.getDimension();\n let low = dimension / 2 - this.nbCenterLayers;\n let high = dimension / 2 + this.nbCenterLayers;\n return sampler.sampleGrid(image, dimension, dimension, low, low, // topleft\n high, low, // topright\n high, high, // bottomright\n low, high, // bottomleft\n topLeft.getX(), topLeft.getY(), topRight.getX(), topRight.getY(), bottomRight.getX(), bottomRight.getY(), bottomLeft.getX(), bottomLeft.getY());\n }\n /**\n * Samples a line.\n *\n * @param p1 start point (inclusive)\n * @param p2 end point (exclusive)\n * @param size number of bits\n * @return the array of bits as an int (first bit is high-order bit of result)\n */\n sampleLine(p1, p2, size) {\n let result = 0;\n let d = this.distanceResultPoint(p1, p2);\n let moduleSize = d / size;\n let px = p1.getX();\n let py = p1.getY();\n let dx = moduleSize * (p2.getX() - p1.getX()) / d;\n let dy = moduleSize * (p2.getY() - p1.getY()) / d;\n for (let i = 0; i < size; i++) {\n if (this.image.get(MathUtils.round(px + i * dx), MathUtils.round(py + i * dy))) {\n result |= 1 << (size - i - 1);\n }\n }\n return result;\n }\n /**\n * @return true if the border of the rectangle passed in parameter is compound of white points only\n * or black points only\n */\n isWhiteOrBlackRectangle(p1, p2, p3, p4) {\n let corr = 3;\n p1 = new Point(p1.getX() - corr, p1.getY() + corr);\n p2 = new Point(p2.getX() - corr, p2.getY() - corr);\n p3 = new Point(p3.getX() + corr, p3.getY() - corr);\n p4 = new Point(p4.getX() + corr, p4.getY() + corr);\n let cInit = this.getColor(p4, p1);\n if (cInit === 0) {\n return false;\n }\n let c = this.getColor(p1, p2);\n if (c !== cInit) {\n return false;\n }\n c = this.getColor(p2, p3);\n if (c !== cInit) {\n return false;\n }\n c = this.getColor(p3, p4);\n return c === cInit;\n }\n /**\n * Gets the color of a segment\n *\n * @return 1 if segment more than 90% black, -1 if segment is more than 90% white, 0 else\n */\n getColor(p1, p2) {\n let d = this.distancePoint(p1, p2);\n let dx = (p2.getX() - p1.getX()) / d;\n let dy = (p2.getY() - p1.getY()) / d;\n let error = 0;\n let px = p1.getX();\n let py = p1.getY();\n let colorModel = this.image.get(p1.getX(), p1.getY());\n let iMax = Math.ceil(d);\n for (let i = 0; i < iMax; i++) {\n px += dx;\n py += dy;\n if (this.image.get(MathUtils.round(px), MathUtils.round(py)) !== colorModel) {\n error++;\n }\n }\n let errRatio = error / d;\n if (errRatio > 0.1 && errRatio < 0.9) {\n return 0;\n }\n return (errRatio <= 0.1) === colorModel ? 1 : -1;\n }\n /**\n * Gets the coordinate of the first point with a different color in the given direction\n */\n getFirstDifferent(init, color, dx, dy) {\n let x = init.getX() + dx;\n let y = init.getY() + dy;\n while (this.isValid(x, y) && this.image.get(x, y) === color) {\n x += dx;\n y += dy;\n }\n x -= dx;\n y -= dy;\n while (this.isValid(x, y) && this.image.get(x, y) === color) {\n x += dx;\n }\n x -= dx;\n while (this.isValid(x, y) && this.image.get(x, y) === color) {\n y += dy;\n }\n y -= dy;\n return new Point(x, y);\n }\n /**\n * Expand the square represented by the corner points by pushing out equally in all directions\n *\n * @param cornerPoints the corners of the square, which has the bull's eye at its center\n * @param oldSide the original length of the side of the square in the target bit matrix\n * @param newSide the new length of the size of the square in the target bit matrix\n * @return the corners of the expanded square\n */\n expandSquare(cornerPoints, oldSide, newSide) {\n let ratio = newSide / (2.0 * oldSide);\n let dx = cornerPoints[0].getX() - cornerPoints[2].getX();\n let dy = cornerPoints[0].getY() - cornerPoints[2].getY();\n let centerx = (cornerPoints[0].getX() + cornerPoints[2].getX()) / 2.0;\n let centery = (cornerPoints[0].getY() + cornerPoints[2].getY()) / 2.0;\n let result0 = new ResultPoint(centerx + ratio * dx, centery + ratio * dy);\n let result2 = new ResultPoint(centerx - ratio * dx, centery - ratio * dy);\n dx = cornerPoints[1].getX() - cornerPoints[3].getX();\n dy = cornerPoints[1].getY() - cornerPoints[3].getY();\n centerx = (cornerPoints[1].getX() + cornerPoints[3].getX()) / 2.0;\n centery = (cornerPoints[1].getY() + cornerPoints[3].getY()) / 2.0;\n let result1 = new ResultPoint(centerx + ratio * dx, centery + ratio * dy);\n let result3 = new ResultPoint(centerx - ratio * dx, centery - ratio * dy);\n let results = [result0, result1, result2, result3];\n return results;\n }\n isValid(x, y) {\n return x >= 0 && x < this.image.getWidth() && y > 0 && y < this.image.getHeight();\n }\n isValidPoint(point) {\n let x = MathUtils.round(point.getX());\n let y = MathUtils.round(point.getY());\n return this.isValid(x, y);\n }\n distancePoint(a, b) {\n return MathUtils.distance(a.getX(), a.getY(), b.getX(), b.getY());\n }\n distanceResultPoint(a, b) {\n return MathUtils.distance(a.getX(), a.getY(), b.getX(), b.getY());\n }\n getDimension() {\n if (this.compact) {\n return 4 * this.nbLayers + 11;\n }\n if (this.nbLayers <= 4) {\n return 4 * this.nbLayers + 15;\n }\n return 4 * this.nbLayers + 2 * (Integer.truncDivision((this.nbLayers - 4), 8) + 1) + 15;\n }\n }\n\n /*\n * Copyright 2010 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // import java.util.List;\n // import java.util.Map;\n /**\n * This implementation can detect and decode Aztec codes in an image.\n *\n * @author David Olivier\n */\n class AztecReader {\n /**\n * Locates and decodes a Data Matrix code in an image.\n *\n * @return a String representing the content encoded by the Data Matrix code\n * @throws NotFoundException if a Data Matrix code cannot be found\n * @throws FormatException if a Data Matrix code cannot be decoded\n */\n decode(image, hints = null) {\n let exception = null;\n let detector = new Detector(image.getBlackMatrix());\n let points = null;\n let decoderResult = null;\n try {\n let detectorResult = detector.detectMirror(false);\n points = detectorResult.getPoints();\n this.reportFoundResultPoints(hints, points);\n decoderResult = new Decoder().decode(detectorResult);\n }\n catch (e) {\n exception = e;\n }\n if (decoderResult == null) {\n try {\n let detectorResult = detector.detectMirror(true);\n points = detectorResult.getPoints();\n this.reportFoundResultPoints(hints, points);\n decoderResult = new Decoder().decode(detectorResult);\n }\n catch (e) {\n if (exception != null) {\n throw exception;\n }\n throw e;\n }\n }\n let result = new Result(decoderResult.getText(), decoderResult.getRawBytes(), decoderResult.getNumBits(), points, BarcodeFormat$1.AZTEC, System.currentTimeMillis());\n let byteSegments = decoderResult.getByteSegments();\n if (byteSegments != null) {\n result.putMetadata(ResultMetadataType$1.BYTE_SEGMENTS, byteSegments);\n }\n let ecLevel = decoderResult.getECLevel();\n if (ecLevel != null) {\n result.putMetadata(ResultMetadataType$1.ERROR_CORRECTION_LEVEL, ecLevel);\n }\n return result;\n }\n reportFoundResultPoints(hints, points) {\n if (hints != null) {\n let rpcb = hints.get(DecodeHintType$1.NEED_RESULT_POINT_CALLBACK);\n if (rpcb != null) {\n points.forEach((point, idx, arr) => {\n rpcb.foundPossibleResultPoint(point);\n });\n }\n }\n }\n // @Override\n reset() {\n // do nothing\n }\n }\n\n /**\n * Aztec Code reader to use from browser.\n *\n * @class BrowserAztecCodeReader\n * @extends {BrowserCodeReader}\n */\n class BrowserAztecCodeReader extends BrowserCodeReader {\n /**\n * Creates an instance of BrowserAztecCodeReader.\n * @param {number} [timeBetweenScansMillis=500] the time delay between subsequent decode tries\n *\n * @memberOf BrowserAztecCodeReader\n */\n constructor(timeBetweenScansMillis = 500) {\n super(new AztecReader(), timeBetweenScansMillis);\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * Encapsulates functionality and implementation that is common to all families\n * of one-dimensional barcodes.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n * @author Sean Owen\n */\n class OneDReader {\n /*\n @Override\n public Result decode(BinaryBitmap image) throws NotFoundException, FormatException {\n return decode(image, null);\n }\n */\n // Note that we don't try rotation without the try harder flag, even if rotation was supported.\n // @Override\n decode(image, hints) {\n try {\n return this.doDecode(image, hints);\n }\n catch (nfe) {\n const tryHarder = hints && (hints.get(DecodeHintType$1.TRY_HARDER) === true);\n if (tryHarder && image.isRotateSupported()) {\n const rotatedImage = image.rotateCounterClockwise();\n const result = this.doDecode(rotatedImage, hints);\n // Record that we found it rotated 90 degrees CCW / 270 degrees CW\n const metadata = result.getResultMetadata();\n let orientation = 270;\n if (metadata !== null && (metadata.get(ResultMetadataType$1.ORIENTATION) === true)) {\n // But if we found it reversed in doDecode(), add in that result here:\n orientation = (orientation + metadata.get(ResultMetadataType$1.ORIENTATION) % 360);\n }\n result.putMetadata(ResultMetadataType$1.ORIENTATION, orientation);\n // Update result points\n const points = result.getResultPoints();\n if (points !== null) {\n const height = rotatedImage.getHeight();\n for (let i = 0; i < points.length; i++) {\n points[i] = new ResultPoint(height - points[i].getY() - 1, points[i].getX());\n }\n }\n return result;\n }\n else {\n throw new NotFoundException();\n }\n }\n }\n // @Override\n reset() {\n // do nothing\n }\n /**\n * We're going to examine rows from the middle outward, searching alternately above and below the\n * middle, and farther out each time. rowStep is the number of rows between each successive\n * attempt above and below the middle. So we'd scan row middle, then middle - rowStep, then\n * middle + rowStep, then middle - (2 * rowStep), etc.\n * rowStep is bigger as the image is taller, but is always at least 1. We've somewhat arbitrarily\n * decided that moving up and down by about 1/16 of the image is pretty good; we try more of the\n * image if \"trying harder\".\n *\n * @param image The image to decode\n * @param hints Any hints that were requested\n * @return The contents of the decoded barcode\n * @throws NotFoundException Any spontaneous errors which occur\n */\n doDecode(image, hints) {\n const width = image.getWidth();\n const height = image.getHeight();\n let row = new BitArray(width);\n const tryHarder = hints && (hints.get(DecodeHintType$1.TRY_HARDER) === true);\n const rowStep = Math.max(1, height >> (tryHarder ? 8 : 5));\n let maxLines;\n if (tryHarder) {\n maxLines = height; // Look at the whole image, not just the center\n }\n else {\n maxLines = 15; // 15 rows spaced 1/32 apart is roughly the middle half of the image\n }\n const middle = Math.trunc(height / 2);\n for (let x = 0; x < maxLines; x++) {\n // Scanning from the middle out. Determine which row we're looking at next:\n const rowStepsAboveOrBelow = Math.trunc((x + 1) / 2);\n const isAbove = (x & 0x01) === 0; // i.e. is x even?\n const rowNumber = middle + rowStep * (isAbove ? rowStepsAboveOrBelow : -rowStepsAboveOrBelow);\n if (rowNumber < 0 || rowNumber >= height) {\n // Oops, if we run off the top or bottom, stop\n break;\n }\n // Estimate black point for this row and load it:\n try {\n row = image.getBlackRow(rowNumber, row);\n }\n catch (ignored) {\n continue;\n }\n // While we have the image data in a BitArray, it's fairly cheap to reverse it in place to\n // handle decoding upside down barcodes.\n for (let attempt = 0; attempt < 2; attempt++) {\n if (attempt === 1) { // trying again?\n row.reverse(); // reverse the row and continue\n // This means we will only ever draw result points *once* in the life of this method\n // since we want to avoid drawing the wrong points after flipping the row, and,\n // don't want to clutter with noise from every single row scan -- just the scans\n // that start on the center line.\n if (hints && (hints.get(DecodeHintType$1.NEED_RESULT_POINT_CALLBACK) === true)) {\n const newHints = new Map();\n hints.forEach((hint, key) => newHints.set(key, hint));\n newHints.delete(DecodeHintType$1.NEED_RESULT_POINT_CALLBACK);\n hints = newHints;\n }\n }\n try {\n // Look for a barcode\n const result = this.decodeRow(rowNumber, row, hints);\n // We found our barcode\n if (attempt === 1) {\n // But it was upside down, so note that\n result.putMetadata(ResultMetadataType$1.ORIENTATION, 180);\n // And remember to flip the result points horizontally.\n const points = result.getResultPoints();\n if (points !== null) {\n points[0] = new ResultPoint(width - points[0].getX() - 1, points[0].getY());\n points[1] = new ResultPoint(width - points[1].getX() - 1, points[1].getY());\n }\n }\n return result;\n }\n catch (re) {\n // continue -- just couldn't decode this row\n }\n }\n }\n throw new NotFoundException();\n }\n /**\n * Records the size of successive runs of white and black pixels in a row, starting at a given point.\n * The values are recorded in the given array, and the number of runs recorded is equal to the size\n * of the array. If the row starts on a white pixel at the given start point, then the first count\n * recorded is the run of white pixels starting from that point; likewise it is the count of a run\n * of black pixels if the row begin on a black pixels at that point.\n *\n * @param row row to count from\n * @param start offset into row to start at\n * @param counters array into which to record counts\n * @throws NotFoundException if counters cannot be filled entirely from row before running out\n * of pixels\n */\n static recordPattern(row, start, counters) {\n const numCounters = counters.length;\n for (let index = 0; index < numCounters; index++)\n counters[index] = 0;\n const end = row.getSize();\n if (start >= end) {\n throw new NotFoundException();\n }\n let isWhite = !row.get(start);\n let counterPosition = 0;\n let i = start;\n while (i < end) {\n if (row.get(i) !== isWhite) {\n counters[counterPosition]++;\n }\n else {\n if (++counterPosition === numCounters) {\n break;\n }\n else {\n counters[counterPosition] = 1;\n isWhite = !isWhite;\n }\n }\n i++;\n }\n // If we read fully the last section of pixels and filled up our counters -- or filled\n // the last counter but ran off the side of the image, OK. Otherwise, a problem.\n if (!(counterPosition === numCounters || (counterPosition === numCounters - 1 && i === end))) {\n throw new NotFoundException();\n }\n }\n static recordPatternInReverse(row, start, counters) {\n // This could be more efficient I guess\n let numTransitionsLeft = counters.length;\n let last = row.get(start);\n while (start > 0 && numTransitionsLeft >= 0) {\n if (row.get(--start) !== last) {\n numTransitionsLeft--;\n last = !last;\n }\n }\n if (numTransitionsLeft >= 0) {\n throw new NotFoundException();\n }\n OneDReader.recordPattern(row, start + 1, counters);\n }\n /**\n * Determines how closely a set of observed counts of runs of black/white values matches a given\n * target pattern. This is reported as the ratio of the total variance from the expected pattern\n * proportions across all pattern elements, to the length of the pattern.\n *\n * @param counters observed counters\n * @param pattern expected pattern\n * @param maxIndividualVariance The most any counter can differ before we give up\n * @return ratio of total variance between counters and pattern compared to total pattern size\n */\n static patternMatchVariance(counters, pattern, maxIndividualVariance) {\n const numCounters = counters.length;\n let total = 0;\n let patternLength = 0;\n for (let i = 0; i < numCounters; i++) {\n total += counters[i];\n patternLength += pattern[i];\n }\n if (total < patternLength) {\n // If we don't even have one pixel per unit of bar width, assume this is too small\n // to reliably match, so fail:\n return Number.POSITIVE_INFINITY;\n }\n const unitBarWidth = total / patternLength;\n maxIndividualVariance *= unitBarWidth;\n let totalVariance = 0.0;\n for (let x = 0; x < numCounters; x++) {\n const counter = counters[x];\n const scaledPattern = pattern[x] * unitBarWidth;\n const variance = counter > scaledPattern ? counter - scaledPattern : scaledPattern - counter;\n if (variance > maxIndividualVariance) {\n return Number.POSITIVE_INFINITY;\n }\n totalVariance += variance;\n }\n return totalVariance / total;\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Decodes Code 128 barcodes.

\n *\n * @author Sean Owen\n */\n class Code128Reader extends OneDReader {\n static findStartPattern(row) {\n const width = row.getSize();\n const rowOffset = row.getNextSet(0);\n let counterPosition = 0;\n let counters = Int32Array.from([0, 0, 0, 0, 0, 0]);\n let patternStart = rowOffset;\n let isWhite = false;\n const patternLength = 6;\n for (let i = rowOffset; i < width; i++) {\n if (row.get(i) !== isWhite) {\n counters[counterPosition]++;\n }\n else {\n if (counterPosition === (patternLength - 1)) {\n let bestVariance = Code128Reader.MAX_AVG_VARIANCE;\n let bestMatch = -1;\n for (let startCode = Code128Reader.CODE_START_A; startCode <= Code128Reader.CODE_START_C; startCode++) {\n const variance = OneDReader.patternMatchVariance(counters, Code128Reader.CODE_PATTERNS[startCode], Code128Reader.MAX_INDIVIDUAL_VARIANCE);\n if (variance < bestVariance) {\n bestVariance = variance;\n bestMatch = startCode;\n }\n }\n // Look for whitespace before start pattern, >= 50% of width of start pattern\n if (bestMatch >= 0 &&\n row.isRange(Math.max(0, patternStart - (i - patternStart) / 2), patternStart, false)) {\n return Int32Array.from([patternStart, i, bestMatch]);\n }\n patternStart += counters[0] + counters[1];\n counters = counters.slice(2, counters.length - 1);\n counters[counterPosition - 1] = 0;\n counters[counterPosition] = 0;\n counterPosition--;\n }\n else {\n counterPosition++;\n }\n counters[counterPosition] = 1;\n isWhite = !isWhite;\n }\n }\n throw new NotFoundException();\n }\n static decodeCode(row, counters, rowOffset) {\n OneDReader.recordPattern(row, rowOffset, counters);\n let bestVariance = Code128Reader.MAX_AVG_VARIANCE; // worst variance we'll accept\n let bestMatch = -1;\n for (let d = 0; d < Code128Reader.CODE_PATTERNS.length; d++) {\n const pattern = Code128Reader.CODE_PATTERNS[d];\n const variance = this.patternMatchVariance(counters, pattern, Code128Reader.MAX_INDIVIDUAL_VARIANCE);\n if (variance < bestVariance) {\n bestVariance = variance;\n bestMatch = d;\n }\n }\n // TODO We're overlooking the fact that the STOP pattern has 7 values, not 6.\n if (bestMatch >= 0) {\n return bestMatch;\n }\n else {\n throw new NotFoundException();\n }\n }\n decodeRow(rowNumber, row, hints) {\n const convertFNC1 = hints && (hints.get(DecodeHintType$1.ASSUME_GS1) === true);\n const startPatternInfo = Code128Reader.findStartPattern(row);\n const startCode = startPatternInfo[2];\n let currentRawCodesIndex = 0;\n const rawCodes = new Uint8Array(20);\n rawCodes[currentRawCodesIndex++] = startCode;\n let codeSet;\n switch (startCode) {\n case Code128Reader.CODE_START_A:\n codeSet = Code128Reader.CODE_CODE_A;\n break;\n case Code128Reader.CODE_START_B:\n codeSet = Code128Reader.CODE_CODE_B;\n break;\n case Code128Reader.CODE_START_C:\n codeSet = Code128Reader.CODE_CODE_C;\n break;\n default:\n throw new FormatException();\n }\n let done = false;\n let isNextShifted = false;\n let result = '';\n let lastStart = startPatternInfo[0];\n let nextStart = startPatternInfo[1];\n const counters = Int32Array.from([0, 0, 0, 0, 0, 0]);\n let lastCode = 0;\n let code = 0;\n let checksumTotal = startCode;\n let multiplier = 0;\n let lastCharacterWasPrintable = true;\n let upperMode = false;\n let shiftUpperMode = false;\n while (!done) {\n const unshift = isNextShifted;\n isNextShifted = false;\n // Save off last code\n lastCode = code;\n // Decode another code from image\n code = Code128Reader.decodeCode(row, counters, nextStart);\n rawCodes[currentRawCodesIndex++] = code;\n // Remember whether the last code was printable or not (excluding CODE_STOP)\n if (code !== Code128Reader.CODE_STOP) {\n lastCharacterWasPrintable = true;\n }\n // Add to checksum computation (if not CODE_STOP of course)\n if (code !== Code128Reader.CODE_STOP) {\n multiplier++;\n checksumTotal += multiplier * code;\n }\n // Advance to where the next code will to start\n lastStart = nextStart;\n nextStart += counters.reduce((previous, current) => previous + current, 0);\n // Take care of illegal start codes\n switch (code) {\n case Code128Reader.CODE_START_A:\n case Code128Reader.CODE_START_B:\n case Code128Reader.CODE_START_C:\n throw new FormatException();\n }\n switch (codeSet) {\n case Code128Reader.CODE_CODE_A:\n if (code < 64) {\n if (shiftUpperMode === upperMode) {\n result += String.fromCharCode((' '.charCodeAt(0) + code));\n }\n else {\n result += String.fromCharCode((' '.charCodeAt(0) + code + 128));\n }\n shiftUpperMode = false;\n }\n else if (code < 96) {\n if (shiftUpperMode === upperMode) {\n result += String.fromCharCode((code - 64));\n }\n else {\n result += String.fromCharCode((code + 64));\n }\n shiftUpperMode = false;\n }\n else {\n // Don't let CODE_STOP, which always appears, affect whether whether we think the last\n // code was printable or not.\n if (code !== Code128Reader.CODE_STOP) {\n lastCharacterWasPrintable = false;\n }\n switch (code) {\n case Code128Reader.CODE_FNC_1:\n if (convertFNC1) {\n if (result.length === 0) {\n // GS1 specification 5.4.3.7. and 5.4.6.4. If the first char after the start code\n // is FNC1 then this is GS1-128. We add the symbology identifier.\n result += ']C1';\n }\n else {\n // GS1 specification 5.4.7.5. Every subsequent FNC1 is returned as ASCII 29 (GS)\n result += String.fromCharCode(29);\n }\n }\n break;\n case Code128Reader.CODE_FNC_2:\n case Code128Reader.CODE_FNC_3:\n // do nothing?\n break;\n case Code128Reader.CODE_FNC_4_A:\n if (!upperMode && shiftUpperMode) {\n upperMode = true;\n shiftUpperMode = false;\n }\n else if (upperMode && shiftUpperMode) {\n upperMode = false;\n shiftUpperMode = false;\n }\n else {\n shiftUpperMode = true;\n }\n break;\n case Code128Reader.CODE_SHIFT:\n isNextShifted = true;\n codeSet = Code128Reader.CODE_CODE_B;\n break;\n case Code128Reader.CODE_CODE_B:\n codeSet = Code128Reader.CODE_CODE_B;\n break;\n case Code128Reader.CODE_CODE_C:\n codeSet = Code128Reader.CODE_CODE_C;\n break;\n case Code128Reader.CODE_STOP:\n done = true;\n break;\n }\n }\n break;\n case Code128Reader.CODE_CODE_B:\n if (code < 96) {\n if (shiftUpperMode === upperMode) {\n result += String.fromCharCode((' '.charCodeAt(0) + code));\n }\n else {\n result += String.fromCharCode((' '.charCodeAt(0) + code + 128));\n }\n shiftUpperMode = false;\n }\n else {\n if (code !== Code128Reader.CODE_STOP) {\n lastCharacterWasPrintable = false;\n }\n switch (code) {\n case Code128Reader.CODE_FNC_1:\n if (convertFNC1) {\n if (result.length === 0) {\n // GS1 specification 5.4.3.7. and 5.4.6.4. If the first char after the start code\n // is FNC1 then this is GS1-128. We add the symbology identifier.\n result += ']C1';\n }\n else {\n // GS1 specification 5.4.7.5. Every subsequent FNC1 is returned as ASCII 29 (GS)\n result += String.fromCharCode(29);\n }\n }\n break;\n case Code128Reader.CODE_FNC_2:\n case Code128Reader.CODE_FNC_3:\n // do nothing?\n break;\n case Code128Reader.CODE_FNC_4_B:\n if (!upperMode && shiftUpperMode) {\n upperMode = true;\n shiftUpperMode = false;\n }\n else if (upperMode && shiftUpperMode) {\n upperMode = false;\n shiftUpperMode = false;\n }\n else {\n shiftUpperMode = true;\n }\n break;\n case Code128Reader.CODE_SHIFT:\n isNextShifted = true;\n codeSet = Code128Reader.CODE_CODE_A;\n break;\n case Code128Reader.CODE_CODE_A:\n codeSet = Code128Reader.CODE_CODE_A;\n break;\n case Code128Reader.CODE_CODE_C:\n codeSet = Code128Reader.CODE_CODE_C;\n break;\n case Code128Reader.CODE_STOP:\n done = true;\n break;\n }\n }\n break;\n case Code128Reader.CODE_CODE_C:\n if (code < 100) {\n if (code < 10) {\n result += '0';\n }\n result += code;\n }\n else {\n if (code !== Code128Reader.CODE_STOP) {\n lastCharacterWasPrintable = false;\n }\n switch (code) {\n case Code128Reader.CODE_FNC_1:\n if (convertFNC1) {\n if (result.length === 0) {\n // GS1 specification 5.4.3.7. and 5.4.6.4. If the first char after the start code\n // is FNC1 then this is GS1-128. We add the symbology identifier.\n result += ']C1';\n }\n else {\n // GS1 specification 5.4.7.5. Every subsequent FNC1 is returned as ASCII 29 (GS)\n result += String.fromCharCode(29);\n }\n }\n break;\n case Code128Reader.CODE_CODE_A:\n codeSet = Code128Reader.CODE_CODE_A;\n break;\n case Code128Reader.CODE_CODE_B:\n codeSet = Code128Reader.CODE_CODE_B;\n break;\n case Code128Reader.CODE_STOP:\n done = true;\n break;\n }\n }\n break;\n }\n // Unshift back to another code set if we were shifted\n if (unshift) {\n codeSet = codeSet === Code128Reader.CODE_CODE_A ? Code128Reader.CODE_CODE_B : Code128Reader.CODE_CODE_A;\n }\n }\n const lastPatternSize = nextStart - lastStart;\n // Check for ample whitespace following pattern, but, to do this we first need to remember that\n // we fudged decoding CODE_STOP since it actually has 7 bars, not 6. There is a black bar left\n // to read off. Would be slightly better to properly read. Here we just skip it:\n nextStart = row.getNextUnset(nextStart);\n if (!row.isRange(nextStart, Math.min(row.getSize(), nextStart + (nextStart - lastStart) / 2), false)) {\n throw new NotFoundException();\n }\n // Pull out from sum the value of the penultimate check code\n checksumTotal -= multiplier * lastCode;\n // lastCode is the checksum then:\n if (checksumTotal % 103 !== lastCode) {\n throw new ChecksumException();\n }\n // Need to pull out the check digits from string\n const resultLength = result.length;\n if (resultLength === 0) {\n // false positive\n throw new NotFoundException();\n }\n // Only bother if the result had at least one character, and if the checksum digit happened to\n // be a printable character. If it was just interpreted as a control code, nothing to remove.\n if (resultLength > 0 && lastCharacterWasPrintable) {\n if (codeSet === Code128Reader.CODE_CODE_C) {\n result = result.substring(0, resultLength - 2);\n }\n else {\n result = result.substring(0, resultLength - 1);\n }\n }\n const left = (startPatternInfo[1] + startPatternInfo[0]) / 2.0;\n const right = lastStart + lastPatternSize / 2.0;\n const rawCodesSize = rawCodes.length;\n const rawBytes = new Uint8Array(rawCodesSize);\n for (let i = 0; i < rawCodesSize; i++) {\n rawBytes[i] = rawCodes[i];\n }\n const points = [new ResultPoint(left, rowNumber), new ResultPoint(right, rowNumber)];\n return new Result(result, rawBytes, 0, points, BarcodeFormat$1.CODE_128, new Date().getTime());\n }\n }\n Code128Reader.CODE_PATTERNS = [\n Int32Array.from([2, 1, 2, 2, 2, 2]),\n Int32Array.from([2, 2, 2, 1, 2, 2]),\n Int32Array.from([2, 2, 2, 2, 2, 1]),\n Int32Array.from([1, 2, 1, 2, 2, 3]),\n Int32Array.from([1, 2, 1, 3, 2, 2]),\n Int32Array.from([1, 3, 1, 2, 2, 2]),\n Int32Array.from([1, 2, 2, 2, 1, 3]),\n Int32Array.from([1, 2, 2, 3, 1, 2]),\n Int32Array.from([1, 3, 2, 2, 1, 2]),\n Int32Array.from([2, 2, 1, 2, 1, 3]),\n Int32Array.from([2, 2, 1, 3, 1, 2]),\n Int32Array.from([2, 3, 1, 2, 1, 2]),\n Int32Array.from([1, 1, 2, 2, 3, 2]),\n Int32Array.from([1, 2, 2, 1, 3, 2]),\n Int32Array.from([1, 2, 2, 2, 3, 1]),\n Int32Array.from([1, 1, 3, 2, 2, 2]),\n Int32Array.from([1, 2, 3, 1, 2, 2]),\n Int32Array.from([1, 2, 3, 2, 2, 1]),\n Int32Array.from([2, 2, 3, 2, 1, 1]),\n Int32Array.from([2, 2, 1, 1, 3, 2]),\n Int32Array.from([2, 2, 1, 2, 3, 1]),\n Int32Array.from([2, 1, 3, 2, 1, 2]),\n Int32Array.from([2, 2, 3, 1, 1, 2]),\n Int32Array.from([3, 1, 2, 1, 3, 1]),\n Int32Array.from([3, 1, 1, 2, 2, 2]),\n Int32Array.from([3, 2, 1, 1, 2, 2]),\n Int32Array.from([3, 2, 1, 2, 2, 1]),\n Int32Array.from([3, 1, 2, 2, 1, 2]),\n Int32Array.from([3, 2, 2, 1, 1, 2]),\n Int32Array.from([3, 2, 2, 2, 1, 1]),\n Int32Array.from([2, 1, 2, 1, 2, 3]),\n Int32Array.from([2, 1, 2, 3, 2, 1]),\n Int32Array.from([2, 3, 2, 1, 2, 1]),\n Int32Array.from([1, 1, 1, 3, 2, 3]),\n Int32Array.from([1, 3, 1, 1, 2, 3]),\n Int32Array.from([1, 3, 1, 3, 2, 1]),\n Int32Array.from([1, 1, 2, 3, 1, 3]),\n Int32Array.from([1, 3, 2, 1, 1, 3]),\n Int32Array.from([1, 3, 2, 3, 1, 1]),\n Int32Array.from([2, 1, 1, 3, 1, 3]),\n Int32Array.from([2, 3, 1, 1, 1, 3]),\n Int32Array.from([2, 3, 1, 3, 1, 1]),\n Int32Array.from([1, 1, 2, 1, 3, 3]),\n Int32Array.from([1, 1, 2, 3, 3, 1]),\n Int32Array.from([1, 3, 2, 1, 3, 1]),\n Int32Array.from([1, 1, 3, 1, 2, 3]),\n Int32Array.from([1, 1, 3, 3, 2, 1]),\n Int32Array.from([1, 3, 3, 1, 2, 1]),\n Int32Array.from([3, 1, 3, 1, 2, 1]),\n Int32Array.from([2, 1, 1, 3, 3, 1]),\n Int32Array.from([2, 3, 1, 1, 3, 1]),\n Int32Array.from([2, 1, 3, 1, 1, 3]),\n Int32Array.from([2, 1, 3, 3, 1, 1]),\n Int32Array.from([2, 1, 3, 1, 3, 1]),\n Int32Array.from([3, 1, 1, 1, 2, 3]),\n Int32Array.from([3, 1, 1, 3, 2, 1]),\n Int32Array.from([3, 3, 1, 1, 2, 1]),\n Int32Array.from([3, 1, 2, 1, 1, 3]),\n Int32Array.from([3, 1, 2, 3, 1, 1]),\n Int32Array.from([3, 3, 2, 1, 1, 1]),\n Int32Array.from([3, 1, 4, 1, 1, 1]),\n Int32Array.from([2, 2, 1, 4, 1, 1]),\n Int32Array.from([4, 3, 1, 1, 1, 1]),\n Int32Array.from([1, 1, 1, 2, 2, 4]),\n Int32Array.from([1, 1, 1, 4, 2, 2]),\n Int32Array.from([1, 2, 1, 1, 2, 4]),\n Int32Array.from([1, 2, 1, 4, 2, 1]),\n Int32Array.from([1, 4, 1, 1, 2, 2]),\n Int32Array.from([1, 4, 1, 2, 2, 1]),\n Int32Array.from([1, 1, 2, 2, 1, 4]),\n Int32Array.from([1, 1, 2, 4, 1, 2]),\n Int32Array.from([1, 2, 2, 1, 1, 4]),\n Int32Array.from([1, 2, 2, 4, 1, 1]),\n Int32Array.from([1, 4, 2, 1, 1, 2]),\n Int32Array.from([1, 4, 2, 2, 1, 1]),\n Int32Array.from([2, 4, 1, 2, 1, 1]),\n Int32Array.from([2, 2, 1, 1, 1, 4]),\n Int32Array.from([4, 1, 3, 1, 1, 1]),\n Int32Array.from([2, 4, 1, 1, 1, 2]),\n Int32Array.from([1, 3, 4, 1, 1, 1]),\n Int32Array.from([1, 1, 1, 2, 4, 2]),\n Int32Array.from([1, 2, 1, 1, 4, 2]),\n Int32Array.from([1, 2, 1, 2, 4, 1]),\n Int32Array.from([1, 1, 4, 2, 1, 2]),\n Int32Array.from([1, 2, 4, 1, 1, 2]),\n Int32Array.from([1, 2, 4, 2, 1, 1]),\n Int32Array.from([4, 1, 1, 2, 1, 2]),\n Int32Array.from([4, 2, 1, 1, 1, 2]),\n Int32Array.from([4, 2, 1, 2, 1, 1]),\n Int32Array.from([2, 1, 2, 1, 4, 1]),\n Int32Array.from([2, 1, 4, 1, 2, 1]),\n Int32Array.from([4, 1, 2, 1, 2, 1]),\n Int32Array.from([1, 1, 1, 1, 4, 3]),\n Int32Array.from([1, 1, 1, 3, 4, 1]),\n Int32Array.from([1, 3, 1, 1, 4, 1]),\n Int32Array.from([1, 1, 4, 1, 1, 3]),\n Int32Array.from([1, 1, 4, 3, 1, 1]),\n Int32Array.from([4, 1, 1, 1, 1, 3]),\n Int32Array.from([4, 1, 1, 3, 1, 1]),\n Int32Array.from([1, 1, 3, 1, 4, 1]),\n Int32Array.from([1, 1, 4, 1, 3, 1]),\n Int32Array.from([3, 1, 1, 1, 4, 1]),\n Int32Array.from([4, 1, 1, 1, 3, 1]),\n Int32Array.from([2, 1, 1, 4, 1, 2]),\n Int32Array.from([2, 1, 1, 2, 1, 4]),\n Int32Array.from([2, 1, 1, 2, 3, 2]),\n Int32Array.from([2, 3, 3, 1, 1, 1, 2]),\n ];\n Code128Reader.MAX_AVG_VARIANCE = 0.25;\n Code128Reader.MAX_INDIVIDUAL_VARIANCE = 0.7;\n Code128Reader.CODE_SHIFT = 98;\n Code128Reader.CODE_CODE_C = 99;\n Code128Reader.CODE_CODE_B = 100;\n Code128Reader.CODE_CODE_A = 101;\n Code128Reader.CODE_FNC_1 = 102;\n Code128Reader.CODE_FNC_2 = 97;\n Code128Reader.CODE_FNC_3 = 96;\n Code128Reader.CODE_FNC_4_A = 101;\n Code128Reader.CODE_FNC_4_B = 100;\n Code128Reader.CODE_START_A = 103;\n Code128Reader.CODE_START_B = 104;\n Code128Reader.CODE_START_C = 105;\n Code128Reader.CODE_STOP = 106;\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Decodes Code 39 barcodes. Supports \"Full ASCII Code 39\" if USE_CODE_39_EXTENDED_MODE is set.

\n *\n * @author Sean Owen\n * @see Code93Reader\n */\n class Code39Reader extends OneDReader {\n /**\n * Creates a reader that assumes all encoded data is data, and does not treat the final\n * character as a check digit. It will not decoded \"extended Code 39\" sequences.\n */\n // public Code39Reader() {\n // this(false);\n // }\n /**\n * Creates a reader that can be configured to check the last character as a check digit.\n * It will not decoded \"extended Code 39\" sequences.\n *\n * @param usingCheckDigit if true, treat the last data character as a check digit, not\n * data, and verify that the checksum passes.\n */\n // public Code39Reader(boolean usingCheckDigit) {\n // this(usingCheckDigit, false);\n // }\n /**\n * Creates a reader that can be configured to check the last character as a check digit,\n * or optionally attempt to decode \"extended Code 39\" sequences that are used to encode\n * the full ASCII character set.\n *\n * @param usingCheckDigit if true, treat the last data character as a check digit, not\n * data, and verify that the checksum passes.\n * @param extendedMode if true, will attempt to decode extended Code 39 sequences in the\n * text.\n */\n constructor(usingCheckDigit = false, extendedMode = false) {\n super();\n this.usingCheckDigit = usingCheckDigit;\n this.extendedMode = extendedMode;\n this.decodeRowResult = '';\n this.counters = new Int32Array(9);\n }\n decodeRow(rowNumber, row, hints) {\n let theCounters = this.counters;\n theCounters.fill(0);\n this.decodeRowResult = '';\n let start = Code39Reader.findAsteriskPattern(row, theCounters);\n // Read off white space\n let nextStart = row.getNextSet(start[1]);\n let end = row.getSize();\n let decodedChar;\n let lastStart;\n do {\n Code39Reader.recordPattern(row, nextStart, theCounters);\n let pattern = Code39Reader.toNarrowWidePattern(theCounters);\n if (pattern < 0) {\n throw new NotFoundException();\n }\n decodedChar = Code39Reader.patternToChar(pattern);\n this.decodeRowResult += decodedChar;\n lastStart = nextStart;\n for (let counter of theCounters) {\n nextStart += counter;\n }\n // Read off white space\n nextStart = row.getNextSet(nextStart);\n } while (decodedChar !== '*');\n this.decodeRowResult = this.decodeRowResult.substring(0, this.decodeRowResult.length - 1); // remove asterisk\n // Look for whitespace after pattern:\n let lastPatternSize = 0;\n for (let counter of theCounters) {\n lastPatternSize += counter;\n }\n let whiteSpaceAfterEnd = nextStart - lastStart - lastPatternSize;\n // If 50% of last pattern size, following last pattern, is not whitespace, fail\n // (but if it's whitespace to the very end of the image, that's OK)\n if (nextStart !== end && (whiteSpaceAfterEnd * 2) < lastPatternSize) {\n throw new NotFoundException();\n }\n if (this.usingCheckDigit) {\n let max = this.decodeRowResult.length - 1;\n let total = 0;\n for (let i = 0; i < max; i++) {\n total += Code39Reader.ALPHABET_STRING.indexOf(this.decodeRowResult.charAt(i));\n }\n if (this.decodeRowResult.charAt(max) !== Code39Reader.ALPHABET_STRING.charAt(total % 43)) {\n throw new ChecksumException();\n }\n this.decodeRowResult = this.decodeRowResult.substring(0, max);\n }\n if (this.decodeRowResult.length === 0) {\n // false positive\n throw new NotFoundException();\n }\n let resultString;\n if (this.extendedMode) {\n resultString = Code39Reader.decodeExtended(this.decodeRowResult);\n }\n else {\n resultString = this.decodeRowResult;\n }\n let left = (start[1] + start[0]) / 2.0;\n let right = lastStart + lastPatternSize / 2.0;\n return new Result(resultString, null, 0, [new ResultPoint(left, rowNumber), new ResultPoint(right, rowNumber)], BarcodeFormat$1.CODE_39, new Date().getTime());\n }\n static findAsteriskPattern(row, counters) {\n let width = row.getSize();\n let rowOffset = row.getNextSet(0);\n let counterPosition = 0;\n let patternStart = rowOffset;\n let isWhite = false;\n let patternLength = counters.length;\n for (let i = rowOffset; i < width; i++) {\n if (row.get(i) !== isWhite) {\n counters[counterPosition]++;\n }\n else {\n if (counterPosition === patternLength - 1) {\n // Look for whitespace before start pattern, >= 50% of width of start pattern\n if (this.toNarrowWidePattern(counters) === Code39Reader.ASTERISK_ENCODING &&\n row.isRange(Math.max(0, patternStart - Math.floor((i - patternStart) / 2)), patternStart, false)) {\n return [patternStart, i];\n }\n patternStart += counters[0] + counters[1];\n counters.copyWithin(0, 2, 2 + counterPosition - 1);\n counters[counterPosition - 1] = 0;\n counters[counterPosition] = 0;\n counterPosition--;\n }\n else {\n counterPosition++;\n }\n counters[counterPosition] = 1;\n isWhite = !isWhite;\n }\n }\n throw new NotFoundException();\n }\n // For efficiency, returns -1 on failure. Not throwing here saved as many as 700 exceptions\n // per image when using some of our blackbox images.\n static toNarrowWidePattern(counters) {\n let numCounters = counters.length;\n let maxNarrowCounter = 0;\n let wideCounters;\n do {\n let minCounter = 0x7fffffff;\n for (let counter of counters) {\n if (counter < minCounter && counter > maxNarrowCounter) {\n minCounter = counter;\n }\n }\n maxNarrowCounter = minCounter;\n wideCounters = 0;\n let totalWideCountersWidth = 0;\n let pattern = 0;\n for (let i = 0; i < numCounters; i++) {\n let counter = counters[i];\n if (counter > maxNarrowCounter) {\n pattern |= 1 << (numCounters - 1 - i);\n wideCounters++;\n totalWideCountersWidth += counter;\n }\n }\n if (wideCounters === 3) {\n // Found 3 wide counters, but are they close enough in width?\n // We can perform a cheap, conservative check to see if any individual\n // counter is more than 1.5 times the average:\n for (let i = 0; i < numCounters && wideCounters > 0; i++) {\n let counter = counters[i];\n if (counter > maxNarrowCounter) {\n wideCounters--;\n // totalWideCountersWidth = 3 * average, so this checks if counter >= 3/2 * average\n if ((counter * 2) >= totalWideCountersWidth) {\n return -1;\n }\n }\n }\n return pattern;\n }\n } while (wideCounters > 3);\n return -1;\n }\n static patternToChar(pattern) {\n for (let i = 0; i < Code39Reader.CHARACTER_ENCODINGS.length; i++) {\n if (Code39Reader.CHARACTER_ENCODINGS[i] === pattern) {\n return Code39Reader.ALPHABET_STRING.charAt(i);\n }\n }\n if (pattern === Code39Reader.ASTERISK_ENCODING) {\n return '*';\n }\n throw new NotFoundException();\n }\n static decodeExtended(encoded) {\n let length = encoded.length;\n let decoded = '';\n for (let i = 0; i < length; i++) {\n let c = encoded.charAt(i);\n if (c === '+' || c === '$' || c === '%' || c === '/') {\n let next = encoded.charAt(i + 1);\n let decodedChar = '\\0';\n switch (c) {\n case '+':\n // +A to +Z map to a to z\n if (next >= 'A' && next <= 'Z') {\n decodedChar = String.fromCharCode(next.charCodeAt(0) + 32);\n }\n else {\n throw new FormatException();\n }\n break;\n case '$':\n // $A to $Z map to control codes SH to SB\n if (next >= 'A' && next <= 'Z') {\n decodedChar = String.fromCharCode(next.charCodeAt(0) - 64);\n }\n else {\n throw new FormatException();\n }\n break;\n case '%':\n // %A to %E map to control codes ESC to US\n if (next >= 'A' && next <= 'E') {\n decodedChar = String.fromCharCode(next.charCodeAt(0) - 38);\n }\n else if (next >= 'F' && next <= 'J') {\n decodedChar = String.fromCharCode(next.charCodeAt(0) - 11);\n }\n else if (next >= 'K' && next <= 'O') {\n decodedChar = String.fromCharCode(next.charCodeAt(0) + 16);\n }\n else if (next >= 'P' && next <= 'T') {\n decodedChar = String.fromCharCode(next.charCodeAt(0) + 43);\n }\n else if (next === 'U') {\n decodedChar = '\\0';\n }\n else if (next === 'V') {\n decodedChar = '@';\n }\n else if (next === 'W') {\n decodedChar = '`';\n }\n else if (next === 'X' || next === 'Y' || next === 'Z') {\n decodedChar = '\\x7f';\n }\n else {\n throw new FormatException();\n }\n break;\n case '/':\n // /A to /O map to ! to , and /Z maps to :\n if (next >= 'A' && next <= 'O') {\n decodedChar = String.fromCharCode(next.charCodeAt(0) - 32);\n }\n else if (next === 'Z') {\n decodedChar = ':';\n }\n else {\n throw new FormatException();\n }\n break;\n }\n decoded += decodedChar;\n // bump up i again since we read two characters\n i++;\n }\n else {\n decoded += c;\n }\n }\n return decoded;\n }\n }\n Code39Reader.ALPHABET_STRING = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%';\n /**\n * These represent the encodings of characters, as patterns of wide and narrow bars.\n * The 9 least-significant bits of each int correspond to the pattern of wide and narrow,\n * with 1s representing \"wide\" and 0s representing narrow.\n */\n Code39Reader.CHARACTER_ENCODINGS = [\n 0x034, 0x121, 0x061, 0x160, 0x031, 0x130, 0x070, 0x025, 0x124, 0x064,\n 0x109, 0x049, 0x148, 0x019, 0x118, 0x058, 0x00D, 0x10C, 0x04C, 0x01C,\n 0x103, 0x043, 0x142, 0x013, 0x112, 0x052, 0x007, 0x106, 0x046, 0x016,\n 0x181, 0x0C1, 0x1C0, 0x091, 0x190, 0x0D0, 0x085, 0x184, 0x0C4, 0x0A8,\n 0x0A2, 0x08A, 0x02A // /-%\n ];\n Code39Reader.ASTERISK_ENCODING = 0x094;\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Decodes ITF barcodes.

\n *\n * @author Tjieco\n */\n class ITFReader extends OneDReader {\n constructor() {\n // private static W = 3; // Pixel width of a 3x wide line\n // private static w = 2; // Pixel width of a 2x wide line\n // private static N = 1; // Pixed width of a narrow line\n super(...arguments);\n // Stores the actual narrow line width of the image being decoded.\n this.narrowLineWidth = -1;\n }\n // See ITFWriter.PATTERNS\n /*\n \n /!**\n * Patterns of Wide / Narrow lines to indicate each digit\n *!/\n */\n decodeRow(rowNumber, row, hints) {\n // Find out where the Middle section (payload) starts & ends\n let startRange = this.decodeStart(row);\n let endRange = this.decodeEnd(row);\n let result = new StringBuilder();\n ITFReader.decodeMiddle(row, startRange[1], endRange[0], result);\n let resultString = result.toString();\n let allowedLengths = null;\n if (hints != null) {\n allowedLengths = hints.get(DecodeHintType$1.ALLOWED_LENGTHS);\n }\n if (allowedLengths == null) {\n allowedLengths = ITFReader.DEFAULT_ALLOWED_LENGTHS;\n }\n // To avoid false positives with 2D barcodes (and other patterns), make\n // an assumption that the decoded string must be a 'standard' length if it's short\n let length = resultString.length;\n let lengthOK = false;\n let maxAllowedLength = 0;\n for (let value of allowedLengths) {\n if (length === value) {\n lengthOK = true;\n break;\n }\n if (value > maxAllowedLength) {\n maxAllowedLength = value;\n }\n }\n if (!lengthOK && length > maxAllowedLength) {\n lengthOK = true;\n }\n if (!lengthOK) {\n throw new FormatException();\n }\n const points = [new ResultPoint(startRange[1], rowNumber), new ResultPoint(endRange[0], rowNumber)];\n let resultReturn = new Result(resultString, null, // no natural byte representation for these barcodes\n 0, points, BarcodeFormat$1.ITF, new Date().getTime());\n return resultReturn;\n }\n /*\n /!**\n * @param row row of black/white values to search\n * @param payloadStart offset of start pattern\n * @param resultString {@link StringBuilder} to append decoded chars to\n * @throws NotFoundException if decoding could not complete successfully\n *!/*/\n static decodeMiddle(row, payloadStart, payloadEnd, resultString) {\n // Digits are interleaved in pairs - 5 black lines for one digit, and the\n // 5\n // interleaved white lines for the second digit.\n // Therefore, need to scan 10 lines and then\n // split these into two arrays\n let counterDigitPair = new Int32Array(10); // 10\n let counterBlack = new Int32Array(5); // 5\n let counterWhite = new Int32Array(5); // 5\n counterDigitPair.fill(0);\n counterBlack.fill(0);\n counterWhite.fill(0);\n while (payloadStart < payloadEnd) {\n // Get 10 runs of black/white.\n OneDReader.recordPattern(row, payloadStart, counterDigitPair);\n // Split them into each array\n for (let k = 0; k < 5; k++) {\n let twoK = 2 * k;\n counterBlack[k] = counterDigitPair[twoK];\n counterWhite[k] = counterDigitPair[twoK + 1];\n }\n let bestMatch = ITFReader.decodeDigit(counterBlack);\n resultString.append(bestMatch.toString());\n bestMatch = this.decodeDigit(counterWhite);\n resultString.append(bestMatch.toString());\n counterDigitPair.forEach(function (counterDigit) {\n payloadStart += counterDigit;\n });\n }\n }\n /*/!**\n * Identify where the start of the middle / payload section starts.\n *\n * @param row row of black/white values to search\n * @return Array, containing index of start of 'start block' and end of\n * 'start block'\n *!/*/\n decodeStart(row) {\n let endStart = ITFReader.skipWhiteSpace(row);\n let startPattern = ITFReader.findGuardPattern(row, endStart, ITFReader.START_PATTERN);\n // Determine the width of a narrow line in pixels. We can do this by\n // getting the width of the start pattern and dividing by 4 because its\n // made up of 4 narrow lines.\n this.narrowLineWidth = (startPattern[1] - startPattern[0]) / 4;\n this.validateQuietZone(row, startPattern[0]);\n return startPattern;\n }\n /*/!**\n * The start & end patterns must be pre/post fixed by a quiet zone. This\n * zone must be at least 10 times the width of a narrow line. Scan back until\n * we either get to the start of the barcode or match the necessary number of\n * quiet zone pixels.\n *\n * Note: Its assumed the row is reversed when using this method to find\n * quiet zone after the end pattern.\n *\n * ref: http://www.barcode-1.net/i25code.html\n *\n * @param row bit array representing the scanned barcode.\n * @param startPattern index into row of the start or end pattern.\n * @throws NotFoundException if the quiet zone cannot be found\n *!/*/\n validateQuietZone(row, startPattern) {\n let quietCount = this.narrowLineWidth * 10; // expect to find this many pixels of quiet zone\n // if there are not so many pixel at all let's try as many as possible\n quietCount = quietCount < startPattern ? quietCount : startPattern;\n for (let i = startPattern - 1; quietCount > 0 && i >= 0; i--) {\n if (row.get(i)) {\n break;\n }\n quietCount--;\n }\n if (quietCount !== 0) {\n // Unable to find the necessary number of quiet zone pixels.\n throw new NotFoundException();\n }\n }\n /*\n /!**\n * Skip all whitespace until we get to the first black line.\n *\n * @param row row of black/white values to search\n * @return index of the first black line.\n * @throws NotFoundException Throws exception if no black lines are found in the row\n *!/*/\n static skipWhiteSpace(row) {\n const width = row.getSize();\n const endStart = row.getNextSet(0);\n if (endStart === width) {\n throw new NotFoundException();\n }\n return endStart;\n }\n /*/!**\n * Identify where the end of the middle / payload section ends.\n *\n * @param row row of black/white values to search\n * @return Array, containing index of start of 'end block' and end of 'end\n * block'\n *!/*/\n decodeEnd(row) {\n // For convenience, reverse the row and then\n // search from 'the start' for the end block\n row.reverse();\n try {\n let endStart = ITFReader.skipWhiteSpace(row);\n let endPattern;\n try {\n endPattern = ITFReader.findGuardPattern(row, endStart, ITFReader.END_PATTERN_REVERSED[0]);\n }\n catch (error) {\n if (error instanceof NotFoundException) {\n endPattern = ITFReader.findGuardPattern(row, endStart, ITFReader.END_PATTERN_REVERSED[1]);\n }\n }\n // The start & end patterns must be pre/post fixed by a quiet zone. This\n // zone must be at least 10 times the width of a narrow line.\n // ref: http://www.barcode-1.net/i25code.html\n this.validateQuietZone(row, endPattern[0]);\n // Now recalculate the indices of where the 'endblock' starts & stops to\n // accommodate\n // the reversed nature of the search\n let temp = endPattern[0];\n endPattern[0] = row.getSize() - endPattern[1];\n endPattern[1] = row.getSize() - temp;\n return endPattern;\n }\n finally {\n // Put the row back the right way.\n row.reverse();\n }\n }\n /*\n /!**\n * @param row row of black/white values to search\n * @param rowOffset position to start search\n * @param pattern pattern of counts of number of black and white pixels that are\n * being searched for as a pattern\n * @return start/end horizontal offset of guard pattern, as an array of two\n * ints\n * @throws NotFoundException if pattern is not found\n *!/*/\n static findGuardPattern(row, rowOffset, pattern) {\n let patternLength = pattern.length;\n let counters = new Int32Array(patternLength);\n let width = row.getSize();\n let isWhite = false;\n let counterPosition = 0;\n let patternStart = rowOffset;\n counters.fill(0);\n for (let x = rowOffset; x < width; x++) {\n if (row.get(x) !== isWhite) {\n counters[counterPosition]++;\n }\n else {\n if (counterPosition === patternLength - 1) {\n if (OneDReader.patternMatchVariance(counters, pattern, ITFReader.MAX_INDIVIDUAL_VARIANCE) < ITFReader.MAX_AVG_VARIANCE) {\n return [patternStart, x];\n }\n patternStart += counters[0] + counters[1];\n System.arraycopy(counters, 2, counters, 0, counterPosition - 1);\n counters[counterPosition - 1] = 0;\n counters[counterPosition] = 0;\n counterPosition--;\n }\n else {\n counterPosition++;\n }\n counters[counterPosition] = 1;\n isWhite = !isWhite;\n }\n }\n throw new NotFoundException();\n }\n /*/!**\n * Attempts to decode a sequence of ITF black/white lines into single\n * digit.\n *\n * @param counters the counts of runs of observed black/white/black/... values\n * @return The decoded digit\n * @throws NotFoundException if digit cannot be decoded\n *!/*/\n static decodeDigit(counters) {\n let bestVariance = ITFReader.MAX_AVG_VARIANCE; // worst variance we'll accept\n let bestMatch = -1;\n let max = ITFReader.PATTERNS.length;\n for (let i = 0; i < max; i++) {\n let pattern = ITFReader.PATTERNS[i];\n let variance = OneDReader.patternMatchVariance(counters, pattern, ITFReader.MAX_INDIVIDUAL_VARIANCE);\n if (variance < bestVariance) {\n bestVariance = variance;\n bestMatch = i;\n }\n else if (variance === bestVariance) {\n // if we find a second 'best match' with the same variance, we can not reliably report to have a suitable match\n bestMatch = -1;\n }\n }\n if (bestMatch >= 0) {\n return bestMatch % 10;\n }\n else {\n throw new NotFoundException();\n }\n }\n }\n ITFReader.PATTERNS = [\n Int32Array.from([1, 1, 2, 2, 1]),\n Int32Array.from([2, 1, 1, 1, 2]),\n Int32Array.from([1, 2, 1, 1, 2]),\n Int32Array.from([2, 2, 1, 1, 1]),\n Int32Array.from([1, 1, 2, 1, 2]),\n Int32Array.from([2, 1, 2, 1, 1]),\n Int32Array.from([1, 2, 2, 1, 1]),\n Int32Array.from([1, 1, 1, 2, 2]),\n Int32Array.from([2, 1, 1, 2, 1]),\n Int32Array.from([1, 2, 1, 2, 1]),\n Int32Array.from([1, 1, 3, 3, 1]),\n Int32Array.from([3, 1, 1, 1, 3]),\n Int32Array.from([1, 3, 1, 1, 3]),\n Int32Array.from([3, 3, 1, 1, 1]),\n Int32Array.from([1, 1, 3, 1, 3]),\n Int32Array.from([3, 1, 3, 1, 1]),\n Int32Array.from([1, 3, 3, 1, 1]),\n Int32Array.from([1, 1, 1, 3, 3]),\n Int32Array.from([3, 1, 1, 3, 1]),\n Int32Array.from([1, 3, 1, 3, 1]) // 9\n ];\n ITFReader.MAX_AVG_VARIANCE = 0.38;\n ITFReader.MAX_INDIVIDUAL_VARIANCE = 0.5;\n /* /!** Valid ITF lengths. Anything longer than the largest value is also allowed. *!/*/\n ITFReader.DEFAULT_ALLOWED_LENGTHS = [6, 8, 10, 12, 14];\n /*/!**\n * Start/end guard pattern.\n *\n * Note: The end pattern is reversed because the row is reversed before\n * searching for the END_PATTERN\n *!/*/\n ITFReader.START_PATTERN = Int32Array.from([1, 1, 1, 1]);\n ITFReader.END_PATTERN_REVERSED = [\n Int32Array.from([1, 1, 2]),\n Int32Array.from([1, 1, 3]) // 3x\n ];\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates functionality and implementation that is common to UPC and EAN families\n * of one-dimensional barcodes.

\n *\n * @author dswitkin@google.com (Daniel Switkin)\n * @author Sean Owen\n * @author alasdair@google.com (Alasdair Mackintosh)\n */\n class AbstractUPCEANReader extends OneDReader {\n constructor() {\n super(...arguments);\n this.decodeRowStringBuffer = '';\n }\n // private final UPCEANExtensionSupport extensionReader;\n // private final EANManufacturerOrgSupport eanManSupport;\n /*\n protected UPCEANReader() {\n decodeRowStringBuffer = new StringBuilder(20);\n extensionReader = new UPCEANExtensionSupport();\n eanManSupport = new EANManufacturerOrgSupport();\n }\n */\n static findStartGuardPattern(row) {\n let foundStart = false;\n let startRange;\n let nextStart = 0;\n let counters = Int32Array.from([0, 0, 0]);\n while (!foundStart) {\n counters = Int32Array.from([0, 0, 0]);\n startRange = AbstractUPCEANReader.findGuardPattern(row, nextStart, false, this.START_END_PATTERN, counters);\n let start = startRange[0];\n nextStart = startRange[1];\n let quietStart = start - (nextStart - start);\n if (quietStart >= 0) {\n foundStart = row.isRange(quietStart, start, false);\n }\n }\n return startRange;\n }\n static checkChecksum(s) {\n return AbstractUPCEANReader.checkStandardUPCEANChecksum(s);\n }\n static checkStandardUPCEANChecksum(s) {\n let length = s.length;\n if (length === 0)\n return false;\n let check = parseInt(s.charAt(length - 1), 10);\n return AbstractUPCEANReader.getStandardUPCEANChecksum(s.substring(0, length - 1)) === check;\n }\n static getStandardUPCEANChecksum(s) {\n let length = s.length;\n let sum = 0;\n for (let i = length - 1; i >= 0; i -= 2) {\n let digit = s.charAt(i).charCodeAt(0) - '0'.charCodeAt(0);\n if (digit < 0 || digit > 9) {\n throw new FormatException();\n }\n sum += digit;\n }\n sum *= 3;\n for (let i = length - 2; i >= 0; i -= 2) {\n let digit = s.charAt(i).charCodeAt(0) - '0'.charCodeAt(0);\n if (digit < 0 || digit > 9) {\n throw new FormatException();\n }\n sum += digit;\n }\n return (1000 - sum) % 10;\n }\n static decodeEnd(row, endStart) {\n return AbstractUPCEANReader.findGuardPattern(row, endStart, false, AbstractUPCEANReader.START_END_PATTERN, new Int32Array(AbstractUPCEANReader.START_END_PATTERN.length).fill(0));\n }\n /**\n * @throws NotFoundException\n */\n static findGuardPatternWithoutCounters(row, rowOffset, whiteFirst, pattern) {\n return this.findGuardPattern(row, rowOffset, whiteFirst, pattern, new Int32Array(pattern.length));\n }\n /**\n * @param row row of black/white values to search\n * @param rowOffset position to start search\n * @param whiteFirst if true, indicates that the pattern specifies white/black/white/...\n * pixel counts, otherwise, it is interpreted as black/white/black/...\n * @param pattern pattern of counts of number of black and white pixels that are being\n * searched for as a pattern\n * @param counters array of counters, as long as pattern, to re-use\n * @return start/end horizontal offset of guard pattern, as an array of two ints\n * @throws NotFoundException if pattern is not found\n */\n static findGuardPattern(row, rowOffset, whiteFirst, pattern, counters) {\n let width = row.getSize();\n rowOffset = whiteFirst ? row.getNextUnset(rowOffset) : row.getNextSet(rowOffset);\n let counterPosition = 0;\n let patternStart = rowOffset;\n let patternLength = pattern.length;\n let isWhite = whiteFirst;\n for (let x = rowOffset; x < width; x++) {\n if (row.get(x) !== isWhite) {\n counters[counterPosition]++;\n }\n else {\n if (counterPosition === patternLength - 1) {\n if (OneDReader.patternMatchVariance(counters, pattern, AbstractUPCEANReader.MAX_INDIVIDUAL_VARIANCE) < AbstractUPCEANReader.MAX_AVG_VARIANCE) {\n return Int32Array.from([patternStart, x]);\n }\n patternStart += counters[0] + counters[1];\n let slice = counters.slice(2, counters.length - 1);\n for (let i = 0; i < counterPosition - 1; i++) {\n counters[i] = slice[i];\n }\n counters[counterPosition - 1] = 0;\n counters[counterPosition] = 0;\n counterPosition--;\n }\n else {\n counterPosition++;\n }\n counters[counterPosition] = 1;\n isWhite = !isWhite;\n }\n }\n throw new NotFoundException();\n }\n static decodeDigit(row, counters, rowOffset, patterns) {\n this.recordPattern(row, rowOffset, counters);\n let bestVariance = this.MAX_AVG_VARIANCE;\n let bestMatch = -1;\n let max = patterns.length;\n for (let i = 0; i < max; i++) {\n let pattern = patterns[i];\n let variance = OneDReader.patternMatchVariance(counters, pattern, AbstractUPCEANReader.MAX_INDIVIDUAL_VARIANCE);\n if (variance < bestVariance) {\n bestVariance = variance;\n bestMatch = i;\n }\n }\n if (bestMatch >= 0) {\n return bestMatch;\n }\n else {\n throw new NotFoundException();\n }\n }\n }\n // These two values are critical for determining how permissive the decoding will be.\n // We've arrived at these values through a lot of trial and error. Setting them any higher\n // lets false positives creep in quickly.\n AbstractUPCEANReader.MAX_AVG_VARIANCE = 0.48;\n AbstractUPCEANReader.MAX_INDIVIDUAL_VARIANCE = 0.7;\n /**\n * Start/end guard pattern.\n */\n AbstractUPCEANReader.START_END_PATTERN = Int32Array.from([1, 1, 1]);\n /**\n * Pattern marking the middle of a UPC/EAN pattern, separating the two halves.\n */\n AbstractUPCEANReader.MIDDLE_PATTERN = Int32Array.from([1, 1, 1, 1, 1]);\n /**\n * end guard pattern.\n */\n AbstractUPCEANReader.END_PATTERN = Int32Array.from([1, 1, 1, 1, 1, 1]);\n /**\n * \"Odd\", or \"L\" patterns used to encode UPC/EAN digits.\n */\n AbstractUPCEANReader.L_PATTERNS = [\n Int32Array.from([3, 2, 1, 1]),\n Int32Array.from([2, 2, 2, 1]),\n Int32Array.from([2, 1, 2, 2]),\n Int32Array.from([1, 4, 1, 1]),\n Int32Array.from([1, 1, 3, 2]),\n Int32Array.from([1, 2, 3, 1]),\n Int32Array.from([1, 1, 1, 4]),\n Int32Array.from([1, 3, 1, 2]),\n Int32Array.from([1, 2, 1, 3]),\n Int32Array.from([3, 1, 1, 2]),\n ];\n\n /*\n * Copyright (C) 2010 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @see UPCEANExtension2Support\n */\n class UPCEANExtension5Support {\n constructor() {\n this.CHECK_DIGIT_ENCODINGS = [0x18, 0x14, 0x12, 0x11, 0x0C, 0x06, 0x03, 0x0A, 0x09, 0x05];\n this.decodeMiddleCounters = Int32Array.from([0, 0, 0, 0]);\n this.decodeRowStringBuffer = '';\n }\n decodeRow(rowNumber, row, extensionStartRange) {\n let result = this.decodeRowStringBuffer;\n let end = this.decodeMiddle(row, extensionStartRange, result);\n let resultString = result.toString();\n let extensionData = UPCEANExtension5Support.parseExtensionString(resultString);\n let resultPoints = [\n new ResultPoint((extensionStartRange[0] + extensionStartRange[1]) / 2.0, rowNumber),\n new ResultPoint(end, rowNumber)\n ];\n let extensionResult = new Result(resultString, null, 0, resultPoints, BarcodeFormat$1.UPC_EAN_EXTENSION, new Date().getTime());\n if (extensionData != null) {\n extensionResult.putAllMetadata(extensionData);\n }\n return extensionResult;\n }\n decodeMiddle(row, startRange, resultString) {\n let counters = this.decodeMiddleCounters;\n counters[0] = 0;\n counters[1] = 0;\n counters[2] = 0;\n counters[3] = 0;\n let end = row.getSize();\n let rowOffset = startRange[1];\n let lgPatternFound = 0;\n for (let x = 0; x < 5 && rowOffset < end; x++) {\n let bestMatch = AbstractUPCEANReader.decodeDigit(row, counters, rowOffset, AbstractUPCEANReader.L_AND_G_PATTERNS);\n resultString += String.fromCharCode(('0'.charCodeAt(0) + bestMatch % 10));\n for (let counter of counters) {\n rowOffset += counter;\n }\n if (bestMatch >= 10) {\n lgPatternFound |= 1 << (4 - x);\n }\n if (x !== 4) {\n // Read off separator if not last\n rowOffset = row.getNextSet(rowOffset);\n rowOffset = row.getNextUnset(rowOffset);\n }\n }\n if (resultString.length !== 5) {\n throw new NotFoundException();\n }\n let checkDigit = this.determineCheckDigit(lgPatternFound);\n if (UPCEANExtension5Support.extensionChecksum(resultString.toString()) !== checkDigit) {\n throw new NotFoundException();\n }\n return rowOffset;\n }\n static extensionChecksum(s) {\n let length = s.length;\n let sum = 0;\n for (let i = length - 2; i >= 0; i -= 2) {\n sum += s.charAt(i).charCodeAt(0) - '0'.charCodeAt(0);\n }\n sum *= 3;\n for (let i = length - 1; i >= 0; i -= 2) {\n sum += s.charAt(i).charCodeAt(0) - '0'.charCodeAt(0);\n }\n sum *= 3;\n return sum % 10;\n }\n determineCheckDigit(lgPatternFound) {\n for (let d = 0; d < 10; d++) {\n if (lgPatternFound === this.CHECK_DIGIT_ENCODINGS[d]) {\n return d;\n }\n }\n throw new NotFoundException();\n }\n static parseExtensionString(raw) {\n if (raw.length !== 5) {\n return null;\n }\n let value = UPCEANExtension5Support.parseExtension5String(raw);\n if (value == null) {\n return null;\n }\n return new Map([[ResultMetadataType$1.SUGGESTED_PRICE, value]]);\n }\n static parseExtension5String(raw) {\n let currency;\n switch (raw.charAt(0)) {\n case '0':\n currency = '£';\n break;\n case '5':\n currency = '$';\n break;\n case '9':\n // Reference: http://www.jollytech.com\n switch (raw) {\n case '90000':\n // No suggested retail price\n return null;\n case '99991':\n // Complementary\n return '0.00';\n case '99990':\n return 'Used';\n }\n // Otherwise... unknown currency?\n currency = '';\n break;\n default:\n currency = '';\n break;\n }\n let rawAmount = parseInt(raw.substring(1));\n let unitsString = (rawAmount / 100).toString();\n let hundredths = rawAmount % 100;\n let hundredthsString = hundredths < 10 ? '0' + hundredths : hundredths.toString(); // fixme\n return currency + unitsString + '.' + hundredthsString;\n }\n }\n\n /*\n * Copyright (C) 2012 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @see UPCEANExtension5Support\n */\n class UPCEANExtension2Support {\n constructor() {\n this.decodeMiddleCounters = Int32Array.from([0, 0, 0, 0]);\n this.decodeRowStringBuffer = '';\n }\n decodeRow(rowNumber, row, extensionStartRange) {\n let result = this.decodeRowStringBuffer;\n let end = this.decodeMiddle(row, extensionStartRange, result);\n let resultString = result.toString();\n let extensionData = UPCEANExtension2Support.parseExtensionString(resultString);\n let resultPoints = [\n new ResultPoint((extensionStartRange[0] + extensionStartRange[1]) / 2.0, rowNumber),\n new ResultPoint(end, rowNumber)\n ];\n let extensionResult = new Result(resultString, null, 0, resultPoints, BarcodeFormat$1.UPC_EAN_EXTENSION, new Date().getTime());\n if (extensionData != null) {\n extensionResult.putAllMetadata(extensionData);\n }\n return extensionResult;\n }\n decodeMiddle(row, startRange, resultString) {\n let counters = this.decodeMiddleCounters;\n counters[0] = 0;\n counters[1] = 0;\n counters[2] = 0;\n counters[3] = 0;\n let end = row.getSize();\n let rowOffset = startRange[1];\n let checkParity = 0;\n for (let x = 0; x < 2 && rowOffset < end; x++) {\n let bestMatch = AbstractUPCEANReader.decodeDigit(row, counters, rowOffset, AbstractUPCEANReader.L_AND_G_PATTERNS);\n resultString += String.fromCharCode(('0'.charCodeAt(0) + bestMatch % 10));\n for (let counter of counters) {\n rowOffset += counter;\n }\n if (bestMatch >= 10) {\n checkParity |= 1 << (1 - x);\n }\n if (x !== 1) {\n // Read off separator if not last\n rowOffset = row.getNextSet(rowOffset);\n rowOffset = row.getNextUnset(rowOffset);\n }\n }\n if (resultString.length !== 2) {\n throw new NotFoundException();\n }\n if (parseInt(resultString.toString()) % 4 !== checkParity) {\n throw new NotFoundException();\n }\n return rowOffset;\n }\n static parseExtensionString(raw) {\n if (raw.length !== 2) {\n return null;\n }\n return new Map([[ResultMetadataType$1.ISSUE_NUMBER, parseInt(raw)]]);\n }\n }\n\n /*\n * Copyright (C) 2010 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n class UPCEANExtensionSupport {\n static decodeRow(rowNumber, row, rowOffset) {\n let extensionStartRange = AbstractUPCEANReader.findGuardPattern(row, rowOffset, false, this.EXTENSION_START_PATTERN, new Int32Array(this.EXTENSION_START_PATTERN.length).fill(0));\n try {\n // return null;\n let fiveSupport = new UPCEANExtension5Support();\n return fiveSupport.decodeRow(rowNumber, row, extensionStartRange);\n }\n catch (err) {\n // return null;\n let twoSupport = new UPCEANExtension2Support();\n return twoSupport.decodeRow(rowNumber, row, extensionStartRange);\n }\n }\n }\n UPCEANExtensionSupport.EXTENSION_START_PATTERN = Int32Array.from([1, 1, 2]);\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates functionality and implementation that is common to UPC and EAN families\n * of one-dimensional barcodes.

\n *\n * @author dswitkin@google.com (Daniel Switkin)\n * @author Sean Owen\n * @author alasdair@google.com (Alasdair Mackintosh)\n */\n class UPCEANReader extends AbstractUPCEANReader {\n constructor() {\n super();\n this.decodeRowStringBuffer = '';\n UPCEANReader.L_AND_G_PATTERNS = UPCEANReader.L_PATTERNS.map(arr => Int32Array.from(arr));\n for (let i = 10; i < 20; i++) {\n let widths = UPCEANReader.L_PATTERNS[i - 10];\n let reversedWidths = new Int32Array(widths.length);\n for (let j = 0; j < widths.length; j++) {\n reversedWidths[j] = widths[widths.length - j - 1];\n }\n UPCEANReader.L_AND_G_PATTERNS[i] = reversedWidths;\n }\n }\n decodeRow(rowNumber, row, hints) {\n let startGuardRange = UPCEANReader.findStartGuardPattern(row);\n let resultPointCallback = hints == null ? null : hints.get(DecodeHintType$1.NEED_RESULT_POINT_CALLBACK);\n if (resultPointCallback != null) {\n const resultPoint = new ResultPoint((startGuardRange[0] + startGuardRange[1]) / 2.0, rowNumber);\n resultPointCallback.foundPossibleResultPoint(resultPoint);\n }\n let budello = this.decodeMiddle(row, startGuardRange, this.decodeRowStringBuffer);\n let endStart = budello.rowOffset;\n let result = budello.resultString;\n if (resultPointCallback != null) {\n const resultPoint = new ResultPoint(endStart, rowNumber);\n resultPointCallback.foundPossibleResultPoint(resultPoint);\n }\n let endRange = UPCEANReader.decodeEnd(row, endStart);\n if (resultPointCallback != null) {\n const resultPoint = new ResultPoint((endRange[0] + endRange[1]) / 2.0, rowNumber);\n resultPointCallback.foundPossibleResultPoint(resultPoint);\n }\n // Make sure there is a quiet zone at least as big as the end pattern after the barcode. The\n // spec might want more whitespace, but in practice this is the maximum we can count on.\n let end = endRange[1];\n let quietEnd = end + (end - endRange[0]);\n if (quietEnd >= row.getSize() || !row.isRange(end, quietEnd, false)) {\n throw new NotFoundException();\n }\n let resultString = result.toString();\n // UPC/EAN should never be less than 8 chars anyway\n if (resultString.length < 8) {\n throw new FormatException();\n }\n if (!UPCEANReader.checkChecksum(resultString)) {\n throw new ChecksumException();\n }\n let left = (startGuardRange[1] + startGuardRange[0]) / 2.0;\n let right = (endRange[1] + endRange[0]) / 2.0;\n let format = this.getBarcodeFormat();\n let resultPoint = [new ResultPoint(left, rowNumber), new ResultPoint(right, rowNumber)];\n let decodeResult = new Result(resultString, null, 0, resultPoint, format, new Date().getTime());\n let extensionLength = 0;\n try {\n let extensionResult = UPCEANExtensionSupport.decodeRow(rowNumber, row, endRange[1]);\n decodeResult.putMetadata(ResultMetadataType$1.UPC_EAN_EXTENSION, extensionResult.getText());\n decodeResult.putAllMetadata(extensionResult.getResultMetadata());\n decodeResult.addResultPoints(extensionResult.getResultPoints());\n extensionLength = extensionResult.getText().length;\n }\n catch (err) {\n }\n let allowedExtensions = hints == null ? null : hints.get(DecodeHintType$1.ALLOWED_EAN_EXTENSIONS);\n if (allowedExtensions != null) {\n let valid = false;\n for (let length in allowedExtensions) {\n if (extensionLength.toString() === length) { // check me\n valid = true;\n break;\n }\n }\n if (!valid) {\n throw new NotFoundException();\n }\n }\n if (format === BarcodeFormat$1.EAN_13 || format === BarcodeFormat$1.UPC_A) ;\n return decodeResult;\n }\n static checkChecksum(s) {\n return UPCEANReader.checkStandardUPCEANChecksum(s);\n }\n static checkStandardUPCEANChecksum(s) {\n let length = s.length;\n if (length === 0)\n return false;\n let check = parseInt(s.charAt(length - 1), 10);\n return UPCEANReader.getStandardUPCEANChecksum(s.substring(0, length - 1)) === check;\n }\n static getStandardUPCEANChecksum(s) {\n let length = s.length;\n let sum = 0;\n for (let i = length - 1; i >= 0; i -= 2) {\n let digit = s.charAt(i).charCodeAt(0) - '0'.charCodeAt(0);\n if (digit < 0 || digit > 9) {\n throw new FormatException();\n }\n sum += digit;\n }\n sum *= 3;\n for (let i = length - 2; i >= 0; i -= 2) {\n let digit = s.charAt(i).charCodeAt(0) - '0'.charCodeAt(0);\n if (digit < 0 || digit > 9) {\n throw new FormatException();\n }\n sum += digit;\n }\n return (1000 - sum) % 10;\n }\n static decodeEnd(row, endStart) {\n return UPCEANReader.findGuardPattern(row, endStart, false, UPCEANReader.START_END_PATTERN, new Int32Array(UPCEANReader.START_END_PATTERN.length).fill(0));\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Implements decoding of the EAN-13 format.

\n *\n * @author dswitkin@google.com (Daniel Switkin)\n * @author Sean Owen\n * @author alasdair@google.com (Alasdair Mackintosh)\n */\n class EAN13Reader extends UPCEANReader {\n constructor() {\n super();\n this.decodeMiddleCounters = Int32Array.from([0, 0, 0, 0]);\n }\n decodeMiddle(row, startRange, resultString) {\n let counters = this.decodeMiddleCounters;\n counters[0] = 0;\n counters[1] = 0;\n counters[2] = 0;\n counters[3] = 0;\n let end = row.getSize();\n let rowOffset = startRange[1];\n let lgPatternFound = 0;\n for (let x = 0; x < 6 && rowOffset < end; x++) {\n let bestMatch = UPCEANReader.decodeDigit(row, counters, rowOffset, UPCEANReader.L_AND_G_PATTERNS);\n resultString += String.fromCharCode(('0'.charCodeAt(0) + bestMatch % 10));\n for (let counter of counters) {\n rowOffset += counter;\n }\n if (bestMatch >= 10) {\n lgPatternFound |= 1 << (5 - x);\n }\n }\n resultString = EAN13Reader.determineFirstDigit(resultString, lgPatternFound);\n let middleRange = UPCEANReader.findGuardPattern(row, rowOffset, true, UPCEANReader.MIDDLE_PATTERN, new Int32Array(UPCEANReader.MIDDLE_PATTERN.length).fill(0));\n rowOffset = middleRange[1];\n for (let x = 0; x < 6 && rowOffset < end; x++) {\n let bestMatch = UPCEANReader.decodeDigit(row, counters, rowOffset, UPCEANReader.L_PATTERNS);\n resultString += String.fromCharCode(('0'.charCodeAt(0) + bestMatch));\n for (let counter of counters) {\n rowOffset += counter;\n }\n }\n return { rowOffset, resultString };\n }\n getBarcodeFormat() {\n return BarcodeFormat$1.EAN_13;\n }\n static determineFirstDigit(resultString, lgPatternFound) {\n for (let d = 0; d < 10; d++) {\n if (lgPatternFound === this.FIRST_DIGIT_ENCODINGS[d]) {\n resultString = String.fromCharCode(('0'.charCodeAt(0) + d)) + resultString;\n return resultString;\n }\n }\n throw new NotFoundException();\n }\n }\n EAN13Reader.FIRST_DIGIT_ENCODINGS = [0x00, 0x0B, 0x0D, 0xE, 0x13, 0x19, 0x1C, 0x15, 0x16, 0x1A];\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Implements decoding of the EAN-8 format.

\n *\n * @author Sean Owen\n */\n class EAN8Reader extends UPCEANReader {\n constructor() {\n super();\n this.decodeMiddleCounters = Int32Array.from([0, 0, 0, 0]);\n }\n decodeMiddle(row, startRange, resultString) {\n const counters = this.decodeMiddleCounters;\n counters[0] = 0;\n counters[1] = 0;\n counters[2] = 0;\n counters[3] = 0;\n let end = row.getSize();\n let rowOffset = startRange[1];\n for (let x = 0; x < 4 && rowOffset < end; x++) {\n let bestMatch = UPCEANReader.decodeDigit(row, counters, rowOffset, UPCEANReader.L_PATTERNS);\n resultString += String.fromCharCode(('0'.charCodeAt(0) + bestMatch));\n for (let counter of counters) {\n rowOffset += counter;\n }\n }\n let middleRange = UPCEANReader.findGuardPattern(row, rowOffset, true, UPCEANReader.MIDDLE_PATTERN, new Int32Array(UPCEANReader.MIDDLE_PATTERN.length).fill(0));\n rowOffset = middleRange[1];\n for (let x = 0; x < 4 && rowOffset < end; x++) {\n let bestMatch = UPCEANReader.decodeDigit(row, counters, rowOffset, UPCEANReader.L_PATTERNS);\n resultString += String.fromCharCode(('0'.charCodeAt(0) + bestMatch));\n for (let counter of counters) {\n rowOffset += counter;\n }\n }\n return { rowOffset, resultString };\n }\n getBarcodeFormat() {\n return BarcodeFormat$1.EAN_8;\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * Encapsulates functionality and implementation that is common to all families\n * of one-dimensional barcodes.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n * @author Sean Owen\n * @author sam2332 (Sam Rudloff)\n *\n * @source https://github.com/zxing/zxing/blob/3c96923276dd5785d58eb970b6ba3f80d36a9505/core/src/main/java/com/google/zxing/oned/UPCAReader.java\n *\n * @experimental\n */\n class UPCAReader extends UPCEANReader {\n constructor() {\n super(...arguments);\n this.ean13Reader = new EAN13Reader();\n }\n // @Override\n getBarcodeFormat() {\n return BarcodeFormat$1.UPC_A;\n }\n // Note that we don't try rotation without the try harder flag, even if rotation was supported.\n // @Override\n decode(image, hints) {\n return this.maybeReturnResult(this.ean13Reader.decode(image));\n }\n // @Override\n decodeRow(rowNumber, row, hints) {\n return this.maybeReturnResult(this.ean13Reader.decodeRow(rowNumber, row, hints));\n }\n // @Override\n decodeMiddle(row, startRange, resultString) {\n return this.ean13Reader.decodeMiddle(row, startRange, resultString);\n }\n maybeReturnResult(result) {\n let text = result.getText();\n if (text.charAt(0) === '0') {\n let upcaResult = new Result(text.substring(1), null, null, result.getResultPoints(), BarcodeFormat$1.UPC_A);\n if (result.getResultMetadata() != null) {\n upcaResult.putAllMetadata(result.getResultMetadata());\n }\n return upcaResult;\n }\n else {\n throw new NotFoundException();\n }\n }\n reset() {\n this.ean13Reader.reset();\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // package com.google.zxing.oned;\n // import com.google.zxing.BarcodeFormat;\n // import com.google.zxing.FormatException;\n // import com.google.zxing.NotFoundException;\n // import com.google.zxing.common.BitArray;\n /**\n *

Implements decoding of the UPC-E format.

\n *

This is a great reference for\n * UPC-E information.

\n *\n * @author Sean Owen\n *\n * @source https://github.com/zxing/zxing/blob/3c96923276dd5785d58eb970b6ba3f80d36a9505/core/src/main/java/com/google/zxing/oned/UPCEReader.java\n *\n * @experimental\n */\n /* final */ class UPCEReader extends UPCEANReader {\n constructor() {\n super();\n this.decodeMiddleCounters = new Int32Array(4);\n }\n /**\n * @throws NotFoundException\n */\n // @Override\n decodeMiddle(row, startRange, result) {\n const counters = this.decodeMiddleCounters.map(x => x);\n counters[0] = 0;\n counters[1] = 0;\n counters[2] = 0;\n counters[3] = 0;\n const end = row.getSize();\n let rowOffset = startRange[1];\n let lgPatternFound = 0;\n for (let x = 0; x < 6 && rowOffset < end; x++) {\n const bestMatch = UPCEReader.decodeDigit(row, counters, rowOffset, UPCEReader.L_AND_G_PATTERNS);\n result += String.fromCharCode(('0'.charCodeAt(0) + bestMatch % 10));\n for (let counter of counters) {\n rowOffset += counter;\n }\n if (bestMatch >= 10) {\n lgPatternFound |= 1 << (5 - x);\n }\n }\n UPCEReader.determineNumSysAndCheckDigit(new StringBuilder(result), lgPatternFound);\n return rowOffset;\n }\n /**\n * @throws NotFoundException\n */\n // @Override\n decodeEnd(row, endStart) {\n return UPCEReader.findGuardPatternWithoutCounters(row, endStart, true, UPCEReader.MIDDLE_END_PATTERN);\n }\n /**\n * @throws FormatException\n */\n // @Override\n checkChecksum(s) {\n return UPCEANReader.checkChecksum(UPCEReader.convertUPCEtoUPCA(s));\n }\n /**\n * @throws NotFoundException\n */\n static determineNumSysAndCheckDigit(resultString, lgPatternFound) {\n for (let numSys = 0; numSys <= 1; numSys++) {\n for (let d = 0; d < 10; d++) {\n if (lgPatternFound === this.NUMSYS_AND_CHECK_DIGIT_PATTERNS[numSys][d]) {\n resultString.insert(0, /*(char)*/ ('0' + numSys));\n resultString.append(/*(char)*/ ('0' + d));\n return;\n }\n }\n }\n throw NotFoundException.getNotFoundInstance();\n }\n // @Override\n getBarcodeFormat() {\n return BarcodeFormat$1.UPC_E;\n }\n /**\n * Expands a UPC-E value back into its full, equivalent UPC-A code value.\n *\n * @param upce UPC-E code as string of digits\n * @return equivalent UPC-A code as string of digits\n */\n static convertUPCEtoUPCA(upce) {\n // the following line is equivalent to upce.getChars(1, 7, upceChars, 0);\n const upceChars = upce.slice(1, 7).split('').map(x => x.charCodeAt(0));\n const result = new StringBuilder( /*12*/);\n result.append(upce.charAt(0));\n let lastChar = upceChars[5];\n switch (lastChar) {\n case 0:\n case 1:\n case 2:\n result.appendChars(upceChars, 0, 2);\n result.append(lastChar);\n result.append('0000');\n result.appendChars(upceChars, 2, 3);\n break;\n case 3:\n result.appendChars(upceChars, 0, 3);\n result.append('00000');\n result.appendChars(upceChars, 3, 2);\n break;\n case 4:\n result.appendChars(upceChars, 0, 4);\n result.append('00000');\n result.append(upceChars[4]);\n break;\n default:\n result.appendChars(upceChars, 0, 5);\n result.append('0000');\n result.append(lastChar);\n break;\n }\n // Only append check digit in conversion if supplied\n if (upce.length >= 8) {\n result.append(upce.charAt(7));\n }\n return result.toString();\n }\n }\n /**\n * The pattern that marks the middle, and end, of a UPC-E pattern.\n * There is no \"second half\" to a UPC-E barcode.\n */\n UPCEReader.MIDDLE_END_PATTERN = Int32Array.from([1, 1, 1, 1, 1, 1]);\n // For an UPC-E barcode, the final digit is represented by the parities used\n // to encode the middle six digits, according to the table below.\n //\n // Parity of next 6 digits\n // Digit 0 1 2 3 4 5\n // 0 Even Even Even Odd Odd Odd\n // 1 Even Even Odd Even Odd Odd\n // 2 Even Even Odd Odd Even Odd\n // 3 Even Even Odd Odd Odd Even\n // 4 Even Odd Even Even Odd Odd\n // 5 Even Odd Odd Even Even Odd\n // 6 Even Odd Odd Odd Even Even\n // 7 Even Odd Even Odd Even Odd\n // 8 Even Odd Even Odd Odd Even\n // 9 Even Odd Odd Even Odd Even\n //\n // The encoding is represented by the following array, which is a bit pattern\n // using Odd = 0 and Even = 1. For example, 5 is represented by:\n //\n // Odd Even Even Odd Odd Even\n // in binary:\n // 0 1 1 0 0 1 == 0x19\n //\n /**\n * See {@link #L_AND_G_PATTERNS}; these values similarly represent patterns of\n * even-odd parity encodings of digits that imply both the number system (0 or 1)\n * used, and the check digit.\n */\n UPCEReader.NUMSYS_AND_CHECK_DIGIT_PATTERNS = [\n Int32Array.from([0x38, 0x34, 0x32, 0x31, 0x2C, 0x26, 0x23, 0x2A, 0x29, 0x25]),\n Int32Array.from([0x07, 0x0B, 0x0D, 0x0E, 0x13, 0x19, 0x1C, 0x15, 0x16, 0x1]),\n ];\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

A reader that can read all available UPC/EAN formats. If a caller wants to try to\n * read all such formats, it is most efficient to use this implementation rather than invoke\n * individual readers.

\n *\n * @author Sean Owen\n */\n class MultiFormatUPCEANReader extends OneDReader {\n constructor(hints) {\n super();\n let possibleFormats = hints == null ? null : hints.get(DecodeHintType$1.POSSIBLE_FORMATS);\n let readers = [];\n if (possibleFormats != null) {\n if (possibleFormats.indexOf(BarcodeFormat$1.EAN_13) > -1) {\n readers.push(new EAN13Reader());\n }\n else if (possibleFormats.indexOf(BarcodeFormat$1.UPC_A) > -1) {\n readers.push(new UPCAReader());\n }\n if (possibleFormats.indexOf(BarcodeFormat$1.EAN_8) > -1) {\n readers.push(new EAN8Reader());\n }\n if (possibleFormats.indexOf(BarcodeFormat$1.UPC_E) > -1) {\n readers.push(new UPCEReader());\n }\n }\n if (readers.length === 0) {\n readers.push(new EAN13Reader());\n // UPC-A is covered by EAN-13\n readers.push(new EAN8Reader());\n readers.push(new UPCEReader());\n }\n this.readers = readers;\n }\n decodeRow(rowNumber, row, hints) {\n for (let reader of this.readers) {\n try {\n // const result: Result = reader.decodeRow(rowNumber, row, startGuardPattern, hints);\n const result = reader.decodeRow(rowNumber, row, hints);\n // Special case: a 12-digit code encoded in UPC-A is identical to a \"0\"\n // followed by those 12 digits encoded as EAN-13. Each will recognize such a code,\n // UPC-A as a 12-digit string and EAN-13 as a 13-digit string starting with \"0\".\n // Individually these are correct and their readers will both read such a code\n // and correctly call it EAN-13, or UPC-A, respectively.\n //\n // In this case, if we've been looking for both types, we'd like to call it\n // a UPC-A code. But for efficiency we only run the EAN-13 decoder to also read\n // UPC-A. So we special case it here, and convert an EAN-13 result to a UPC-A\n // result if appropriate.\n //\n // But, don't return UPC-A if UPC-A was not a requested format!\n const ean13MayBeUPCA = result.getBarcodeFormat() === BarcodeFormat$1.EAN_13 &&\n result.getText().charAt(0) === '0';\n // @SuppressWarnings(\"unchecked\")\n const possibleFormats = hints == null ? null : hints.get(DecodeHintType$1.POSSIBLE_FORMATS);\n const canReturnUPCA = possibleFormats == null || possibleFormats.includes(BarcodeFormat$1.UPC_A);\n if (ean13MayBeUPCA && canReturnUPCA) {\n const rawBytes = result.getRawBytes();\n // Transfer the metadata across\n const resultUPCA = new Result(result.getText().substring(1), rawBytes, rawBytes.length, result.getResultPoints(), BarcodeFormat$1.UPC_A);\n resultUPCA.putAllMetadata(result.getResultMetadata());\n return resultUPCA;\n }\n return result;\n }\n catch (err) {\n // continue;\n }\n }\n throw new NotFoundException();\n }\n reset() {\n for (let reader of this.readers) {\n reader.reset();\n }\n }\n }\n\n // import Integer from '../../util/Integer';\n // import Float from '../../util/Float';\n class AbstractRSSReader extends OneDReader {\n constructor() {\n super();\n this.decodeFinderCounters = new Int32Array(4);\n this.dataCharacterCounters = new Int32Array(8);\n this.oddRoundingErrors = new Array(4);\n this.evenRoundingErrors = new Array(4);\n this.oddCounts = new Array(this.dataCharacterCounters.length / 2);\n this.evenCounts = new Array(this.dataCharacterCounters.length / 2);\n }\n getDecodeFinderCounters() {\n return this.decodeFinderCounters;\n }\n getDataCharacterCounters() {\n return this.dataCharacterCounters;\n }\n getOddRoundingErrors() {\n return this.oddRoundingErrors;\n }\n getEvenRoundingErrors() {\n return this.evenRoundingErrors;\n }\n getOddCounts() {\n return this.oddCounts;\n }\n getEvenCounts() {\n return this.evenCounts;\n }\n parseFinderValue(counters, finderPatterns) {\n for (let value = 0; value < finderPatterns.length; value++) {\n if (OneDReader.patternMatchVariance(counters, finderPatterns[value], AbstractRSSReader.MAX_INDIVIDUAL_VARIANCE) < AbstractRSSReader.MAX_AVG_VARIANCE) {\n return value;\n }\n }\n throw new NotFoundException();\n }\n /**\n * @param array values to sum\n * @return sum of values\n * @deprecated call {@link MathUtils#sum(int[])}\n */\n static count(array) {\n return MathUtils.sum(new Int32Array(array));\n }\n static increment(array, errors) {\n let index = 0;\n let biggestError = errors[0];\n for (let i = 1; i < array.length; i++) {\n if (errors[i] > biggestError) {\n biggestError = errors[i];\n index = i;\n }\n }\n array[index]++;\n }\n static decrement(array, errors) {\n let index = 0;\n let biggestError = errors[0];\n for (let i = 1; i < array.length; i++) {\n if (errors[i] < biggestError) {\n biggestError = errors[i];\n index = i;\n }\n }\n array[index]--;\n }\n static isFinderPattern(counters) {\n let firstTwoSum = counters[0] + counters[1];\n let sum = firstTwoSum + counters[2] + counters[3];\n let ratio = firstTwoSum / sum;\n if (ratio >= AbstractRSSReader.MIN_FINDER_PATTERN_RATIO && ratio <= AbstractRSSReader.MAX_FINDER_PATTERN_RATIO) {\n // passes ratio test in spec, but see if the counts are unreasonable\n let minCounter = Number.MAX_SAFE_INTEGER;\n let maxCounter = Number.MIN_SAFE_INTEGER;\n for (let counter of counters) {\n if (counter > maxCounter) {\n maxCounter = counter;\n }\n if (counter < minCounter) {\n minCounter = counter;\n }\n }\n return maxCounter < 10 * minCounter;\n }\n return false;\n }\n }\n AbstractRSSReader.MAX_AVG_VARIANCE = 0.2;\n AbstractRSSReader.MAX_INDIVIDUAL_VARIANCE = 0.45;\n AbstractRSSReader.MIN_FINDER_PATTERN_RATIO = 9.5 / 12.0;\n AbstractRSSReader.MAX_FINDER_PATTERN_RATIO = 12.5 / 14.0;\n\n class DataCharacter {\n constructor(value, checksumPortion) {\n this.value = value;\n this.checksumPortion = checksumPortion;\n }\n getValue() {\n return this.value;\n }\n getChecksumPortion() {\n return this.checksumPortion;\n }\n toString() {\n return this.value + '(' + this.checksumPortion + ')';\n }\n equals(o) {\n if (!(o instanceof DataCharacter)) {\n return false;\n }\n const that = o;\n return this.value === that.value && this.checksumPortion === that.checksumPortion;\n }\n hashCode() {\n return this.value ^ this.checksumPortion;\n }\n }\n\n class FinderPattern {\n constructor(value, startEnd, start, end, rowNumber) {\n this.value = value;\n this.startEnd = startEnd;\n this.value = value;\n this.startEnd = startEnd;\n this.resultPoints = new Array();\n this.resultPoints.push(new ResultPoint(start, rowNumber));\n this.resultPoints.push(new ResultPoint(end, rowNumber));\n }\n getValue() {\n return this.value;\n }\n getStartEnd() {\n return this.startEnd;\n }\n getResultPoints() {\n return this.resultPoints;\n }\n equals(o) {\n if (!(o instanceof FinderPattern)) {\n return false;\n }\n const that = o;\n return this.value === that.value;\n }\n hashCode() {\n return this.value;\n }\n }\n\n /**\n * RSS util functions.\n */\n class RSSUtils {\n constructor() { }\n static getRSSvalue(widths, maxWidth, noNarrow) {\n let n = 0;\n for (let width of widths) {\n n += width;\n }\n let val = 0;\n let narrowMask = 0;\n let elements = widths.length;\n for (let bar = 0; bar < elements - 1; bar++) {\n let elmWidth;\n for (elmWidth = 1, narrowMask |= 1 << bar; elmWidth < widths[bar]; elmWidth++, narrowMask &= ~(1 << bar)) {\n let subVal = RSSUtils.combins(n - elmWidth - 1, elements - bar - 2);\n if (noNarrow && (narrowMask === 0) && (n - elmWidth - (elements - bar - 1) >= elements - bar - 1)) {\n subVal -= RSSUtils.combins(n - elmWidth - (elements - bar), elements - bar - 2);\n }\n if (elements - bar - 1 > 1) {\n let lessVal = 0;\n for (let mxwElement = n - elmWidth - (elements - bar - 2); mxwElement > maxWidth; mxwElement--) {\n lessVal += RSSUtils.combins(n - elmWidth - mxwElement - 1, elements - bar - 3);\n }\n subVal -= lessVal * (elements - 1 - bar);\n }\n else if (n - elmWidth > maxWidth) {\n subVal--;\n }\n val += subVal;\n }\n n -= elmWidth;\n }\n return val;\n }\n static combins(n, r) {\n let maxDenom;\n let minDenom;\n if (n - r > r) {\n minDenom = r;\n maxDenom = n - r;\n }\n else {\n minDenom = n - r;\n maxDenom = r;\n }\n let val = 1;\n let j = 1;\n for (let i = n; i > maxDenom; i--) {\n val *= i;\n if (j <= minDenom) {\n val /= j;\n j++;\n }\n }\n while ((j <= minDenom)) {\n val /= j;\n j++;\n }\n return val;\n }\n }\n\n class BitArrayBuilder {\n static buildBitArray(pairs) {\n let charNumber = (pairs.length * 2) - 1;\n if (pairs[pairs.length - 1].getRightChar() == null) {\n charNumber -= 1;\n }\n let size = 12 * charNumber;\n let binary = new BitArray(size);\n let accPos = 0;\n let firstPair = pairs[0];\n let firstValue = firstPair.getRightChar().getValue();\n for (let i = 11; i >= 0; --i) {\n if ((firstValue & (1 << i)) != 0) {\n binary.set(accPos);\n }\n accPos++;\n }\n for (let i = 1; i < pairs.length; ++i) {\n let currentPair = pairs[i];\n let leftValue = currentPair.getLeftChar().getValue();\n for (let j = 11; j >= 0; --j) {\n if ((leftValue & (1 << j)) != 0) {\n binary.set(accPos);\n }\n accPos++;\n }\n if (currentPair.getRightChar() != null) {\n let rightValue = currentPair.getRightChar().getValue();\n for (let j = 11; j >= 0; --j) {\n if ((rightValue & (1 << j)) != 0) {\n binary.set(accPos);\n }\n accPos++;\n }\n }\n }\n return binary;\n }\n }\n\n class BlockParsedResult {\n constructor(finished, decodedInformation) {\n if (decodedInformation) {\n this.decodedInformation = null;\n }\n else {\n this.finished = finished;\n this.decodedInformation = decodedInformation;\n }\n }\n getDecodedInformation() {\n return this.decodedInformation;\n }\n isFinished() {\n return this.finished;\n }\n }\n\n class DecodedObject {\n constructor(newPosition) {\n this.newPosition = newPosition;\n }\n getNewPosition() {\n return this.newPosition;\n }\n }\n\n class DecodedChar extends DecodedObject {\n constructor(newPosition, value) {\n super(newPosition);\n this.value = value;\n }\n getValue() {\n return this.value;\n }\n isFNC1() {\n return this.value === DecodedChar.FNC1;\n }\n }\n DecodedChar.FNC1 = '$';\n\n class DecodedInformation extends DecodedObject {\n constructor(newPosition, newString, remainingValue) {\n super(newPosition);\n if (remainingValue) {\n this.remaining = true;\n this.remainingValue = this.remainingValue;\n }\n else {\n this.remaining = false;\n this.remainingValue = 0;\n }\n this.newString = newString;\n }\n getNewString() {\n return this.newString;\n }\n isRemaining() {\n return this.remaining;\n }\n getRemainingValue() {\n return this.remainingValue;\n }\n }\n\n class DecodedNumeric extends DecodedObject {\n constructor(newPosition, firstDigit, secondDigit) {\n super(newPosition);\n if (firstDigit < 0 || firstDigit > 10 || secondDigit < 0 || secondDigit > 10) {\n throw new FormatException();\n }\n this.firstDigit = firstDigit;\n this.secondDigit = secondDigit;\n }\n getFirstDigit() {\n return this.firstDigit;\n }\n getSecondDigit() {\n return this.secondDigit;\n }\n getValue() {\n return this.firstDigit * 10 + this.secondDigit;\n }\n isFirstDigitFNC1() {\n return this.firstDigit === DecodedNumeric.FNC1;\n }\n isSecondDigitFNC1() {\n return this.secondDigit === DecodedNumeric.FNC1;\n }\n isAnyFNC1() {\n return this.firstDigit === DecodedNumeric.FNC1 || this.secondDigit === DecodedNumeric.FNC1;\n }\n }\n DecodedNumeric.FNC1 = 10;\n\n class FieldParser {\n constructor() {\n }\n static parseFieldsInGeneralPurpose(rawInformation) {\n if (!rawInformation) {\n return null;\n }\n // Processing 2-digit AIs\n if (rawInformation.length < 2) {\n throw new NotFoundException();\n }\n let firstTwoDigits = rawInformation.substring(0, 2);\n for (let dataLength of FieldParser.TWO_DIGIT_DATA_LENGTH) {\n if (dataLength[0] === firstTwoDigits) {\n if (dataLength[1] === FieldParser.VARIABLE_LENGTH) {\n return FieldParser.processVariableAI(2, dataLength[2], rawInformation);\n }\n return FieldParser.processFixedAI(2, dataLength[1], rawInformation);\n }\n }\n if (rawInformation.length < 3) {\n throw new NotFoundException();\n }\n let firstThreeDigits = rawInformation.substring(0, 3);\n for (let dataLength of FieldParser.THREE_DIGIT_DATA_LENGTH) {\n if (dataLength[0] === firstThreeDigits) {\n if (dataLength[1] === FieldParser.VARIABLE_LENGTH) {\n return FieldParser.processVariableAI(3, dataLength[2], rawInformation);\n }\n return FieldParser.processFixedAI(3, dataLength[1], rawInformation);\n }\n }\n for (let dataLength of FieldParser.THREE_DIGIT_PLUS_DIGIT_DATA_LENGTH) {\n if (dataLength[0] === firstThreeDigits) {\n if (dataLength[1] === FieldParser.VARIABLE_LENGTH) {\n return FieldParser.processVariableAI(4, dataLength[2], rawInformation);\n }\n return FieldParser.processFixedAI(4, dataLength[1], rawInformation);\n }\n }\n if (rawInformation.length < 4) {\n throw new NotFoundException();\n }\n let firstFourDigits = rawInformation.substring(0, 4);\n for (let dataLength of FieldParser.FOUR_DIGIT_DATA_LENGTH) {\n if (dataLength[0] === firstFourDigits) {\n if (dataLength[1] === FieldParser.VARIABLE_LENGTH) {\n return FieldParser.processVariableAI(4, dataLength[2], rawInformation);\n }\n return FieldParser.processFixedAI(4, dataLength[1], rawInformation);\n }\n }\n throw new NotFoundException();\n }\n static processFixedAI(aiSize, fieldSize, rawInformation) {\n if (rawInformation.length < aiSize) {\n throw new NotFoundException();\n }\n let ai = rawInformation.substring(0, aiSize);\n if (rawInformation.length < aiSize + fieldSize) {\n throw new NotFoundException();\n }\n let field = rawInformation.substring(aiSize, aiSize + fieldSize);\n let remaining = rawInformation.substring(aiSize + fieldSize);\n let result = '(' + ai + ')' + field;\n let parsedAI = FieldParser.parseFieldsInGeneralPurpose(remaining);\n return parsedAI == null ? result : result + parsedAI;\n }\n static processVariableAI(aiSize, variableFieldSize, rawInformation) {\n let ai = rawInformation.substring(0, aiSize);\n let maxSize;\n if (rawInformation.length < aiSize + variableFieldSize) {\n maxSize = rawInformation.length;\n }\n else {\n maxSize = aiSize + variableFieldSize;\n }\n let field = rawInformation.substring(aiSize, maxSize);\n let remaining = rawInformation.substring(maxSize);\n let result = '(' + ai + ')' + field;\n let parsedAI = FieldParser.parseFieldsInGeneralPurpose(remaining);\n return parsedAI == null ? result : result + parsedAI;\n }\n }\n FieldParser.VARIABLE_LENGTH = [];\n FieldParser.TWO_DIGIT_DATA_LENGTH = [\n ['00', 18],\n ['01', 14],\n ['02', 14],\n ['10', FieldParser.VARIABLE_LENGTH, 20],\n ['11', 6],\n ['12', 6],\n ['13', 6],\n ['15', 6],\n ['17', 6],\n ['20', 2],\n ['21', FieldParser.VARIABLE_LENGTH, 20],\n ['22', FieldParser.VARIABLE_LENGTH, 29],\n ['30', FieldParser.VARIABLE_LENGTH, 8],\n ['37', FieldParser.VARIABLE_LENGTH, 8],\n // internal company codes\n ['90', FieldParser.VARIABLE_LENGTH, 30],\n ['91', FieldParser.VARIABLE_LENGTH, 30],\n ['92', FieldParser.VARIABLE_LENGTH, 30],\n ['93', FieldParser.VARIABLE_LENGTH, 30],\n ['94', FieldParser.VARIABLE_LENGTH, 30],\n ['95', FieldParser.VARIABLE_LENGTH, 30],\n ['96', FieldParser.VARIABLE_LENGTH, 30],\n ['97', FieldParser.VARIABLE_LENGTH, 3],\n ['98', FieldParser.VARIABLE_LENGTH, 30],\n ['99', FieldParser.VARIABLE_LENGTH, 30],\n ];\n FieldParser.THREE_DIGIT_DATA_LENGTH = [\n // Same format as above\n ['240', FieldParser.VARIABLE_LENGTH, 30],\n ['241', FieldParser.VARIABLE_LENGTH, 30],\n ['242', FieldParser.VARIABLE_LENGTH, 6],\n ['250', FieldParser.VARIABLE_LENGTH, 30],\n ['251', FieldParser.VARIABLE_LENGTH, 30],\n ['253', FieldParser.VARIABLE_LENGTH, 17],\n ['254', FieldParser.VARIABLE_LENGTH, 20],\n ['400', FieldParser.VARIABLE_LENGTH, 30],\n ['401', FieldParser.VARIABLE_LENGTH, 30],\n ['402', 17],\n ['403', FieldParser.VARIABLE_LENGTH, 30],\n ['410', 13],\n ['411', 13],\n ['412', 13],\n ['413', 13],\n ['414', 13],\n ['420', FieldParser.VARIABLE_LENGTH, 20],\n ['421', FieldParser.VARIABLE_LENGTH, 15],\n ['422', 3],\n ['423', FieldParser.VARIABLE_LENGTH, 15],\n ['424', 3],\n ['425', 3],\n ['426', 3],\n ];\n FieldParser.THREE_DIGIT_PLUS_DIGIT_DATA_LENGTH = [\n // Same format as above\n ['310', 6],\n ['311', 6],\n ['312', 6],\n ['313', 6],\n ['314', 6],\n ['315', 6],\n ['316', 6],\n ['320', 6],\n ['321', 6],\n ['322', 6],\n ['323', 6],\n ['324', 6],\n ['325', 6],\n ['326', 6],\n ['327', 6],\n ['328', 6],\n ['329', 6],\n ['330', 6],\n ['331', 6],\n ['332', 6],\n ['333', 6],\n ['334', 6],\n ['335', 6],\n ['336', 6],\n ['340', 6],\n ['341', 6],\n ['342', 6],\n ['343', 6],\n ['344', 6],\n ['345', 6],\n ['346', 6],\n ['347', 6],\n ['348', 6],\n ['349', 6],\n ['350', 6],\n ['351', 6],\n ['352', 6],\n ['353', 6],\n ['354', 6],\n ['355', 6],\n ['356', 6],\n ['357', 6],\n ['360', 6],\n ['361', 6],\n ['362', 6],\n ['363', 6],\n ['364', 6],\n ['365', 6],\n ['366', 6],\n ['367', 6],\n ['368', 6],\n ['369', 6],\n ['390', FieldParser.VARIABLE_LENGTH, 15],\n ['391', FieldParser.VARIABLE_LENGTH, 18],\n ['392', FieldParser.VARIABLE_LENGTH, 15],\n ['393', FieldParser.VARIABLE_LENGTH, 18],\n ['703', FieldParser.VARIABLE_LENGTH, 30],\n ];\n FieldParser.FOUR_DIGIT_DATA_LENGTH = [\n // Same format as above\n ['7001', 13],\n ['7002', FieldParser.VARIABLE_LENGTH, 30],\n ['7003', 10],\n ['8001', 14],\n ['8002', FieldParser.VARIABLE_LENGTH, 20],\n ['8003', FieldParser.VARIABLE_LENGTH, 30],\n ['8004', FieldParser.VARIABLE_LENGTH, 30],\n ['8005', 6],\n ['8006', 18],\n ['8007', FieldParser.VARIABLE_LENGTH, 30],\n ['8008', FieldParser.VARIABLE_LENGTH, 12],\n ['8018', 18],\n ['8020', FieldParser.VARIABLE_LENGTH, 25],\n ['8100', 6],\n ['8101', 10],\n ['8102', 2],\n ['8110', FieldParser.VARIABLE_LENGTH, 70],\n ['8200', FieldParser.VARIABLE_LENGTH, 70],\n ];\n\n class GeneralAppIdDecoder {\n constructor(information) {\n this.buffer = new StringBuilder();\n this.information = information;\n }\n decodeAllCodes(buff, initialPosition) {\n let currentPosition = initialPosition;\n let remaining = null;\n do {\n let info = this.decodeGeneralPurposeField(currentPosition, remaining);\n let parsedFields = FieldParser.parseFieldsInGeneralPurpose(info.getNewString());\n if (parsedFields != null) {\n buff.append(parsedFields);\n }\n if (info.isRemaining()) {\n remaining = '' + info.getRemainingValue();\n }\n else {\n remaining = null;\n }\n if (currentPosition === info.getNewPosition()) { // No step forward!\n break;\n }\n currentPosition = info.getNewPosition();\n } while (true);\n return buff.toString();\n }\n isStillNumeric(pos) {\n // It's numeric if it still has 7 positions\n // and one of the first 4 bits is \"1\".\n if (pos + 7 > this.information.getSize()) {\n return pos + 4 <= this.information.getSize();\n }\n for (let i = pos; i < pos + 3; ++i) {\n if (this.information.get(i)) {\n return true;\n }\n }\n return this.information.get(pos + 3);\n }\n decodeNumeric(pos) {\n if (pos + 7 > this.information.getSize()) {\n let numeric = this.extractNumericValueFromBitArray(pos, 4);\n if (numeric === 0) {\n return new DecodedNumeric(this.information.getSize(), DecodedNumeric.FNC1, DecodedNumeric.FNC1);\n }\n return new DecodedNumeric(this.information.getSize(), numeric - 1, DecodedNumeric.FNC1);\n }\n let numeric = this.extractNumericValueFromBitArray(pos, 7);\n let digit1 = (numeric - 8) / 11;\n let digit2 = (numeric - 8) % 11;\n return new DecodedNumeric(pos + 7, digit1, digit2);\n }\n extractNumericValueFromBitArray(pos, bits) {\n return GeneralAppIdDecoder.extractNumericValueFromBitArray(this.information, pos, bits);\n }\n static extractNumericValueFromBitArray(information, pos, bits) {\n let value = 0;\n for (let i = 0; i < bits; ++i) {\n if (information.get(pos + i)) {\n value |= 1 << (bits - i - 1);\n }\n }\n return value;\n }\n decodeGeneralPurposeField(pos, remaining) {\n // this.buffer.setLength(0);\n this.buffer.setLengthToZero();\n if (remaining != null) {\n this.buffer.append(remaining);\n }\n this.current.setPosition(pos);\n let lastDecoded = this.parseBlocks();\n if (lastDecoded != null && lastDecoded.isRemaining()) {\n return new DecodedInformation(this.current.getPosition(), this.buffer.toString(), lastDecoded.getRemainingValue());\n }\n return new DecodedInformation(this.current.getPosition(), this.buffer.toString());\n }\n parseBlocks() {\n let isFinished;\n let result;\n do {\n let initialPosition = this.current.getPosition();\n if (this.current.isAlpha()) {\n result = this.parseAlphaBlock();\n isFinished = result.isFinished();\n }\n else if (this.current.isIsoIec646()) {\n result = this.parseIsoIec646Block();\n isFinished = result.isFinished();\n }\n else { // it must be numeric\n result = this.parseNumericBlock();\n isFinished = result.isFinished();\n }\n let positionChanged = initialPosition !== this.current.getPosition();\n if (!positionChanged && !isFinished) {\n break;\n }\n } while (!isFinished);\n return result.getDecodedInformation();\n }\n parseNumericBlock() {\n while (this.isStillNumeric(this.current.getPosition())) {\n let numeric = this.decodeNumeric(this.current.getPosition());\n this.current.setPosition(numeric.getNewPosition());\n if (numeric.isFirstDigitFNC1()) {\n let information;\n if (numeric.isSecondDigitFNC1()) {\n information = new DecodedInformation(this.current.getPosition(), this.buffer.toString());\n }\n else {\n information = new DecodedInformation(this.current.getPosition(), this.buffer.toString(), numeric.getSecondDigit());\n }\n return new BlockParsedResult(true, information);\n }\n this.buffer.append(numeric.getFirstDigit());\n if (numeric.isSecondDigitFNC1()) {\n let information = new DecodedInformation(this.current.getPosition(), this.buffer.toString());\n return new BlockParsedResult(true, information);\n }\n this.buffer.append(numeric.getSecondDigit());\n }\n if (this.isNumericToAlphaNumericLatch(this.current.getPosition())) {\n this.current.setAlpha();\n this.current.incrementPosition(4);\n }\n return new BlockParsedResult(false);\n }\n parseIsoIec646Block() {\n while (this.isStillIsoIec646(this.current.getPosition())) {\n let iso = this.decodeIsoIec646(this.current.getPosition());\n this.current.setPosition(iso.getNewPosition());\n if (iso.isFNC1()) {\n let information = new DecodedInformation(this.current.getPosition(), this.buffer.toString());\n return new BlockParsedResult(true, information);\n }\n this.buffer.append(iso.getValue());\n }\n if (this.isAlphaOr646ToNumericLatch(this.current.getPosition())) {\n this.current.incrementPosition(3);\n this.current.setNumeric();\n }\n else if (this.isAlphaTo646ToAlphaLatch(this.current.getPosition())) {\n if (this.current.getPosition() + 5 < this.information.getSize()) {\n this.current.incrementPosition(5);\n }\n else {\n this.current.setPosition(this.information.getSize());\n }\n this.current.setAlpha();\n }\n return new BlockParsedResult(false);\n }\n parseAlphaBlock() {\n while (this.isStillAlpha(this.current.getPosition())) {\n let alpha = this.decodeAlphanumeric(this.current.getPosition());\n this.current.setPosition(alpha.getNewPosition());\n if (alpha.isFNC1()) {\n let information = new DecodedInformation(this.current.getPosition(), this.buffer.toString());\n return new BlockParsedResult(true, information); // end of the char block\n }\n this.buffer.append(alpha.getValue());\n }\n if (this.isAlphaOr646ToNumericLatch(this.current.getPosition())) {\n this.current.incrementPosition(3);\n this.current.setNumeric();\n }\n else if (this.isAlphaTo646ToAlphaLatch(this.current.getPosition())) {\n if (this.current.getPosition() + 5 < this.information.getSize()) {\n this.current.incrementPosition(5);\n }\n else {\n this.current.setPosition(this.information.getSize());\n }\n this.current.setIsoIec646();\n }\n return new BlockParsedResult(false);\n }\n isStillIsoIec646(pos) {\n if (pos + 5 > this.information.getSize()) {\n return false;\n }\n let fiveBitValue = this.extractNumericValueFromBitArray(pos, 5);\n if (fiveBitValue >= 5 && fiveBitValue < 16) {\n return true;\n }\n if (pos + 7 > this.information.getSize()) {\n return false;\n }\n let sevenBitValue = this.extractNumericValueFromBitArray(pos, 7);\n if (sevenBitValue >= 64 && sevenBitValue < 116) {\n return true;\n }\n if (pos + 8 > this.information.getSize()) {\n return false;\n }\n let eightBitValue = this.extractNumericValueFromBitArray(pos, 8);\n return eightBitValue >= 232 && eightBitValue < 253;\n }\n decodeIsoIec646(pos) {\n let fiveBitValue = this.extractNumericValueFromBitArray(pos, 5);\n if (fiveBitValue === 15) {\n return new DecodedChar(pos + 5, DecodedChar.FNC1);\n }\n if (fiveBitValue >= 5 && fiveBitValue < 15) {\n return new DecodedChar(pos + 5, ('0' + (fiveBitValue - 5)));\n }\n let sevenBitValue = this.extractNumericValueFromBitArray(pos, 7);\n if (sevenBitValue >= 64 && sevenBitValue < 90) {\n return new DecodedChar(pos + 7, ('' + (sevenBitValue + 1)));\n }\n if (sevenBitValue >= 90 && sevenBitValue < 116) {\n return new DecodedChar(pos + 7, ('' + (sevenBitValue + 7)));\n }\n let eightBitValue = this.extractNumericValueFromBitArray(pos, 8);\n let c;\n switch (eightBitValue) {\n case 232:\n c = '!';\n break;\n case 233:\n c = '\"';\n break;\n case 234:\n c = '%';\n break;\n case 235:\n c = '&';\n break;\n case 236:\n c = '\\'';\n break;\n case 237:\n c = '(';\n break;\n case 238:\n c = ')';\n break;\n case 239:\n c = '*';\n break;\n case 240:\n c = '+';\n break;\n case 241:\n c = ',';\n break;\n case 242:\n c = '-';\n break;\n case 243:\n c = '.';\n break;\n case 244:\n c = '/';\n break;\n case 245:\n c = ':';\n break;\n case 246:\n c = ';';\n break;\n case 247:\n c = '<';\n break;\n case 248:\n c = '=';\n break;\n case 249:\n c = '>';\n break;\n case 250:\n c = '?';\n break;\n case 251:\n c = '_';\n break;\n case 252:\n c = ' ';\n break;\n default:\n throw new FormatException();\n }\n return new DecodedChar(pos + 8, c);\n }\n isStillAlpha(pos) {\n if (pos + 5 > this.information.getSize()) {\n return false;\n }\n // We now check if it's a valid 5-bit value (0..9 and FNC1)\n let fiveBitValue = this.extractNumericValueFromBitArray(pos, 5);\n if (fiveBitValue >= 5 && fiveBitValue < 16) {\n return true;\n }\n if (pos + 6 > this.information.getSize()) {\n return false;\n }\n let sixBitValue = this.extractNumericValueFromBitArray(pos, 6);\n return sixBitValue >= 16 && sixBitValue < 63; // 63 not included\n }\n decodeAlphanumeric(pos) {\n let fiveBitValue = this.extractNumericValueFromBitArray(pos, 5);\n if (fiveBitValue === 15) {\n return new DecodedChar(pos + 5, DecodedChar.FNC1);\n }\n if (fiveBitValue >= 5 && fiveBitValue < 15) {\n return new DecodedChar(pos + 5, ('0' + (fiveBitValue - 5)));\n }\n let sixBitValue = this.extractNumericValueFromBitArray(pos, 6);\n if (sixBitValue >= 32 && sixBitValue < 58) {\n return new DecodedChar(pos + 6, ('' + (sixBitValue + 33)));\n }\n let c;\n switch (sixBitValue) {\n case 58:\n c = '*';\n break;\n case 59:\n c = ',';\n break;\n case 60:\n c = '-';\n break;\n case 61:\n c = '.';\n break;\n case 62:\n c = '/';\n break;\n default:\n throw new IllegalStateException('Decoding invalid alphanumeric value: ' + sixBitValue);\n }\n return new DecodedChar(pos + 6, c);\n }\n isAlphaTo646ToAlphaLatch(pos) {\n if (pos + 1 > this.information.getSize()) {\n return false;\n }\n for (let i = 0; i < 5 && i + pos < this.information.getSize(); ++i) {\n if (i === 2) {\n if (!this.information.get(pos + 2)) {\n return false;\n }\n }\n else if (this.information.get(pos + i)) {\n return false;\n }\n }\n return true;\n }\n isAlphaOr646ToNumericLatch(pos) {\n // Next is alphanumeric if there are 3 positions and they are all zeros\n if (pos + 3 > this.information.getSize()) {\n return false;\n }\n for (let i = pos; i < pos + 3; ++i) {\n if (this.information.get(i)) {\n return false;\n }\n }\n return true;\n }\n isNumericToAlphaNumericLatch(pos) {\n // Next is alphanumeric if there are 4 positions and they are all zeros, or\n // if there is a subset of this just before the end of the symbol\n if (pos + 1 > this.information.getSize()) {\n return false;\n }\n for (let i = 0; i < 4 && i + pos < this.information.getSize(); ++i) {\n if (this.information.get(pos + i)) {\n return false;\n }\n }\n return true;\n }\n }\n\n class AbstractExpandedDecoder {\n constructor(information) {\n this.information = information;\n this.generalDecoder = new GeneralAppIdDecoder(information);\n }\n getInformation() {\n return this.information;\n }\n getGeneralDecoder() {\n return this.generalDecoder;\n }\n }\n\n class AI01decoder extends AbstractExpandedDecoder {\n constructor(information) {\n super(information);\n }\n encodeCompressedGtin(buf, currentPos) {\n buf.append('(01)');\n let initialPosition = buf.length();\n buf.append('9');\n this.encodeCompressedGtinWithoutAI(buf, currentPos, initialPosition);\n }\n encodeCompressedGtinWithoutAI(buf, currentPos, initialBufferPosition) {\n for (let i = 0; i < 4; ++i) {\n let currentBlock = this.getGeneralDecoder().extractNumericValueFromBitArray(currentPos + 10 * i, 10);\n if (currentBlock / 100 === 0) {\n buf.append('0');\n }\n if (currentBlock / 10 === 0) {\n buf.append('0');\n }\n buf.append(currentBlock);\n }\n AI01decoder.appendCheckDigit(buf, initialBufferPosition);\n }\n static appendCheckDigit(buf, currentPos) {\n let checkDigit = 0;\n for (let i = 0; i < 13; i++) {\n // let digit = buf.charAt(i + currentPos) - '0';\n // To be checked\n let digit = buf.charAt(i + currentPos).charCodeAt(0) - '0'.charCodeAt(0);\n checkDigit += (i & 0x01) === 0 ? 3 * digit : digit;\n }\n checkDigit = 10 - (checkDigit % 10);\n if (checkDigit === 10) {\n checkDigit = 0;\n }\n buf.append(checkDigit);\n }\n }\n AI01decoder.GTIN_SIZE = 40;\n\n class AI01AndOtherAIs extends AI01decoder {\n // the second one is the encodation method, and the other two are for the variable length\n constructor(information) {\n super(information);\n }\n parseInformation() {\n let buff = new StringBuilder();\n buff.append('(01)');\n let initialGtinPosition = buff.length();\n let firstGtinDigit = this.getGeneralDecoder().extractNumericValueFromBitArray(AI01AndOtherAIs.HEADER_SIZE, 4);\n buff.append(firstGtinDigit);\n this.encodeCompressedGtinWithoutAI(buff, AI01AndOtherAIs.HEADER_SIZE + 4, initialGtinPosition);\n return this.getGeneralDecoder().decodeAllCodes(buff, AI01AndOtherAIs.HEADER_SIZE + 44);\n }\n }\n AI01AndOtherAIs.HEADER_SIZE = 1 + 1 + 2; // first bit encodes the linkage flag,\n\n class AnyAIDecoder extends AbstractExpandedDecoder {\n constructor(information) {\n super(information);\n }\n parseInformation() {\n let buf = new StringBuilder();\n return this.getGeneralDecoder().decodeAllCodes(buf, AnyAIDecoder.HEADER_SIZE);\n }\n }\n AnyAIDecoder.HEADER_SIZE = 2 + 1 + 2;\n\n class AI01weightDecoder extends AI01decoder {\n constructor(information) {\n super(information);\n }\n encodeCompressedWeight(buf, currentPos, weightSize) {\n let originalWeightNumeric = this.getGeneralDecoder().extractNumericValueFromBitArray(currentPos, weightSize);\n this.addWeightCode(buf, originalWeightNumeric);\n let weightNumeric = this.checkWeight(originalWeightNumeric);\n let currentDivisor = 100000;\n for (let i = 0; i < 5; ++i) {\n if (weightNumeric / currentDivisor === 0) {\n buf.append('0');\n }\n currentDivisor /= 10;\n }\n buf.append(weightNumeric);\n }\n }\n\n class AI013x0xDecoder extends AI01weightDecoder {\n constructor(information) {\n super(information);\n }\n parseInformation() {\n if (this.getInformation().getSize() != AI013x0xDecoder.HEADER_SIZE + AI01weightDecoder.GTIN_SIZE + AI013x0xDecoder.WEIGHT_SIZE) {\n throw new NotFoundException();\n }\n let buf = new StringBuilder();\n this.encodeCompressedGtin(buf, AI013x0xDecoder.HEADER_SIZE);\n this.encodeCompressedWeight(buf, AI013x0xDecoder.HEADER_SIZE + AI01weightDecoder.GTIN_SIZE, AI013x0xDecoder.WEIGHT_SIZE);\n return buf.toString();\n }\n }\n AI013x0xDecoder.HEADER_SIZE = 4 + 1;\n AI013x0xDecoder.WEIGHT_SIZE = 15;\n\n class AI013103decoder extends AI013x0xDecoder {\n constructor(information) {\n super(information);\n }\n addWeightCode(buf, weight) {\n buf.append('(3103)');\n }\n checkWeight(weight) {\n return weight;\n }\n }\n\n class AI01320xDecoder extends AI013x0xDecoder {\n constructor(information) {\n super(information);\n }\n addWeightCode(buf, weight) {\n if (weight < 10000) {\n buf.append('(3202)');\n }\n else {\n buf.append('(3203)');\n }\n }\n checkWeight(weight) {\n if (weight < 10000) {\n return weight;\n }\n return weight - 10000;\n }\n }\n\n class AI01392xDecoder extends AI01decoder {\n constructor(information) {\n super(information);\n }\n parseInformation() {\n if (this.getInformation().getSize() < AI01392xDecoder.HEADER_SIZE + AI01decoder.GTIN_SIZE) {\n throw new NotFoundException();\n }\n let buf = new StringBuilder();\n this.encodeCompressedGtin(buf, AI01392xDecoder.HEADER_SIZE);\n let lastAIdigit = this.getGeneralDecoder().extractNumericValueFromBitArray(AI01392xDecoder.HEADER_SIZE + AI01decoder.GTIN_SIZE, AI01392xDecoder.LAST_DIGIT_SIZE);\n buf.append('(392');\n buf.append(lastAIdigit);\n buf.append(')');\n let decodedInformation = this.getGeneralDecoder().decodeGeneralPurposeField(AI01392xDecoder.HEADER_SIZE + AI01decoder.GTIN_SIZE + AI01392xDecoder.LAST_DIGIT_SIZE, null);\n buf.append(decodedInformation.getNewString());\n return buf.toString();\n }\n }\n AI01392xDecoder.HEADER_SIZE = 5 + 1 + 2;\n AI01392xDecoder.LAST_DIGIT_SIZE = 2;\n\n class AI01393xDecoder extends AI01decoder {\n constructor(information) {\n super(information);\n }\n parseInformation() {\n if (this.getInformation().getSize() < AI01393xDecoder.HEADER_SIZE + AI01decoder.GTIN_SIZE) {\n throw new NotFoundException();\n }\n let buf = new StringBuilder();\n this.encodeCompressedGtin(buf, AI01393xDecoder.HEADER_SIZE);\n let lastAIdigit = this.getGeneralDecoder().extractNumericValueFromBitArray(AI01393xDecoder.HEADER_SIZE + AI01decoder.GTIN_SIZE, AI01393xDecoder.LAST_DIGIT_SIZE);\n buf.append('(393');\n buf.append(lastAIdigit);\n buf.append(')');\n let firstThreeDigits = this.getGeneralDecoder().extractNumericValueFromBitArray(AI01393xDecoder.HEADER_SIZE + AI01decoder.GTIN_SIZE + AI01393xDecoder.LAST_DIGIT_SIZE, AI01393xDecoder.FIRST_THREE_DIGITS_SIZE);\n if (firstThreeDigits / 100 == 0) {\n buf.append('0');\n }\n if (firstThreeDigits / 10 == 0) {\n buf.append('0');\n }\n buf.append(firstThreeDigits);\n let generalInformation = this.getGeneralDecoder().decodeGeneralPurposeField(AI01393xDecoder.HEADER_SIZE + AI01decoder.GTIN_SIZE + AI01393xDecoder.LAST_DIGIT_SIZE + AI01393xDecoder.FIRST_THREE_DIGITS_SIZE, null);\n buf.append(generalInformation.getNewString());\n return buf.toString();\n }\n }\n AI01393xDecoder.HEADER_SIZE = 5 + 1 + 2;\n AI01393xDecoder.LAST_DIGIT_SIZE = 2;\n AI01393xDecoder.FIRST_THREE_DIGITS_SIZE = 10;\n\n class AI013x0x1xDecoder extends AI01weightDecoder {\n constructor(information, firstAIdigits, dateCode) {\n super(information);\n this.dateCode = dateCode;\n this.firstAIdigits = firstAIdigits;\n }\n parseInformation() {\n if (this.getInformation().getSize() != AI013x0x1xDecoder.HEADER_SIZE + AI013x0x1xDecoder.GTIN_SIZE + AI013x0x1xDecoder.WEIGHT_SIZE + AI013x0x1xDecoder.DATE_SIZE) {\n throw new NotFoundException();\n }\n let buf = new StringBuilder();\n this.encodeCompressedGtin(buf, AI013x0x1xDecoder.HEADER_SIZE);\n this.encodeCompressedWeight(buf, AI013x0x1xDecoder.HEADER_SIZE + AI013x0x1xDecoder.GTIN_SIZE, AI013x0x1xDecoder.WEIGHT_SIZE);\n this.encodeCompressedDate(buf, AI013x0x1xDecoder.HEADER_SIZE + AI013x0x1xDecoder.GTIN_SIZE + AI013x0x1xDecoder.WEIGHT_SIZE);\n return buf.toString();\n }\n encodeCompressedDate(buf, currentPos) {\n let numericDate = this.getGeneralDecoder().extractNumericValueFromBitArray(currentPos, AI013x0x1xDecoder.DATE_SIZE);\n if (numericDate == 38400) {\n return;\n }\n buf.append('(');\n buf.append(this.dateCode);\n buf.append(')');\n let day = numericDate % 32;\n numericDate /= 32;\n let month = numericDate % 12 + 1;\n numericDate /= 12;\n let year = numericDate;\n if (year / 10 == 0) {\n buf.append('0');\n }\n buf.append(year);\n if (month / 10 == 0) {\n buf.append('0');\n }\n buf.append(month);\n if (day / 10 == 0) {\n buf.append('0');\n }\n buf.append(day);\n }\n addWeightCode(buf, weight) {\n buf.append('(');\n buf.append(this.firstAIdigits);\n buf.append(weight / 100000);\n buf.append(')');\n }\n checkWeight(weight) {\n return weight % 100000;\n }\n }\n AI013x0x1xDecoder.HEADER_SIZE = 7 + 1;\n AI013x0x1xDecoder.WEIGHT_SIZE = 20;\n AI013x0x1xDecoder.DATE_SIZE = 16;\n\n function createDecoder(information) {\n try {\n if (information.get(1)) {\n return new AI01AndOtherAIs(information);\n }\n if (!information.get(2)) {\n return new AnyAIDecoder(information);\n }\n let fourBitEncodationMethod = GeneralAppIdDecoder.extractNumericValueFromBitArray(information, 1, 4);\n switch (fourBitEncodationMethod) {\n case 4: return new AI013103decoder(information);\n case 5: return new AI01320xDecoder(information);\n }\n let fiveBitEncodationMethod = GeneralAppIdDecoder.extractNumericValueFromBitArray(information, 1, 5);\n switch (fiveBitEncodationMethod) {\n case 12: return new AI01392xDecoder(information);\n case 13: return new AI01393xDecoder(information);\n }\n let sevenBitEncodationMethod = GeneralAppIdDecoder.extractNumericValueFromBitArray(information, 1, 7);\n switch (sevenBitEncodationMethod) {\n case 56: return new AI013x0x1xDecoder(information, '310', '11');\n case 57: return new AI013x0x1xDecoder(information, '320', '11');\n case 58: return new AI013x0x1xDecoder(information, '310', '13');\n case 59: return new AI013x0x1xDecoder(information, '320', '13');\n case 60: return new AI013x0x1xDecoder(information, '310', '15');\n case 61: return new AI013x0x1xDecoder(information, '320', '15');\n case 62: return new AI013x0x1xDecoder(information, '310', '17');\n case 63: return new AI013x0x1xDecoder(information, '320', '17');\n }\n }\n catch (e) {\n console.log(e);\n throw new IllegalStateException('unknown decoder: ' + information);\n }\n }\n\n class ExpandedPair {\n constructor(leftChar, rightChar, finderPatter, mayBeLast) {\n this.leftchar = leftChar;\n this.rightchar = rightChar;\n this.finderpattern = finderPatter;\n this.maybeLast = mayBeLast;\n }\n mayBeLast() {\n return this.maybeLast;\n }\n getLeftChar() {\n return this.leftchar;\n }\n getRightChar() {\n return this.rightchar;\n }\n getFinderPattern() {\n return this.finderpattern;\n }\n mustBeLast() {\n return this.rightchar == null;\n }\n toString() {\n return '[ ' + this.leftchar + ', ' + this.rightchar + ' : ' + (this.finderpattern == null ? 'null' : this.finderpattern.getValue()) + ' ]';\n }\n static equals(o1, o2) {\n if (!(o1 instanceof ExpandedPair)) {\n return false;\n }\n return ExpandedPair.equalsOrNull(o1.leftchar, o2.leftchar) &&\n ExpandedPair.equalsOrNull(o1.rightchar, o2.rightchar) &&\n ExpandedPair.equalsOrNull(o1.finderpattern, o2.finderpattern);\n }\n static equalsOrNull(o1, o2) {\n return o1 === null ? o2 === null : ExpandedPair.equals(o1, o2);\n }\n hashCode() {\n // return ExpandedPair.hashNotNull(leftChar) ^ hashNotNull(rightChar) ^ hashNotNull(finderPattern);\n let value = this.leftchar.getValue() ^ this.rightchar.getValue() ^ this.finderpattern.getValue();\n return value;\n }\n }\n\n class ExpandedRow {\n constructor(pairs, rowNumber, wasReversed) {\n this.pairs = pairs;\n this.rowNumber = rowNumber;\n this.wasReversed = wasReversed;\n }\n getPairs() {\n return this.pairs;\n }\n getRowNumber() {\n return this.rowNumber;\n }\n isReversed() {\n return this.wasReversed;\n }\n // check implementation\n isEquivalent(otherPairs) {\n return this.checkEqualitity(this, otherPairs);\n }\n // @Override\n toString() {\n return '{ ' + this.pairs + ' }';\n }\n /**\n * Two rows are equal if they contain the same pairs in the same order.\n */\n // @Override\n // check implementation\n equals(o1, o2) {\n if (!(o1 instanceof ExpandedRow)) {\n return false;\n }\n return this.checkEqualitity(o1, o2) && o1.wasReversed === o2.wasReversed;\n }\n checkEqualitity(pair1, pair2) {\n if (!pair1 || !pair2)\n return;\n let result;\n pair1.forEach((e1, i) => {\n pair2.forEach(e2 => {\n if (e1.getLeftChar().getValue() === e2.getLeftChar().getValue() && e1.getRightChar().getValue() === e2.getRightChar().getValue() && e1.getFinderPatter().getValue() === e2.getFinderPatter().getValue()) {\n result = true;\n }\n });\n });\n return result;\n }\n }\n\n // import java.util.ArrayList;\n // import java.util.Iterator;\n // import java.util.List;\n // import java.util.Map;\n // import java.util.Collections;\n class RSSExpandedReader extends AbstractRSSReader {\n constructor(verbose) {\n super(...arguments);\n this.pairs = new Array(RSSExpandedReader.MAX_PAIRS);\n this.rows = new Array();\n this.startEnd = [2];\n this.verbose = (verbose === true);\n }\n decodeRow(rowNumber, row, hints) {\n // Rows can start with even pattern in case in prev rows there where odd number of patters.\n // So lets try twice\n // this.pairs.clear();\n this.pairs.length = 0;\n this.startFromEven = false;\n try {\n return RSSExpandedReader.constructResult(this.decodeRow2pairs(rowNumber, row));\n }\n catch (e) {\n // OK\n if (this.verbose) {\n console.log(e);\n }\n }\n this.pairs.length = 0;\n this.startFromEven = true;\n return RSSExpandedReader.constructResult(this.decodeRow2pairs(rowNumber, row));\n }\n reset() {\n this.pairs.length = 0;\n this.rows.length = 0;\n }\n // Not private for testing\n decodeRow2pairs(rowNumber, row) {\n let done = false;\n while (!done) {\n try {\n this.pairs.push(this.retrieveNextPair(row, this.pairs, rowNumber));\n }\n catch (error) {\n if (error instanceof NotFoundException) {\n if (!this.pairs.length) {\n throw new NotFoundException();\n }\n // exit this loop when retrieveNextPair() fails and throws\n done = true;\n }\n }\n }\n // TODO: verify sequence of finder patterns as in checkPairSequence()\n if (this.checkChecksum()) {\n return this.pairs;\n }\n let tryStackedDecode;\n if (this.rows.length) {\n tryStackedDecode = true;\n }\n else {\n tryStackedDecode = false;\n }\n // let tryStackedDecode = !this.rows.isEmpty();\n this.storeRow(rowNumber, false); // TODO: deal with reversed rows\n if (tryStackedDecode) {\n // When the image is 180-rotated, then rows are sorted in wrong direction.\n // Try twice with both the directions.\n let ps = this.checkRowsBoolean(false);\n if (ps != null) {\n return ps;\n }\n ps = this.checkRowsBoolean(true);\n if (ps != null) {\n return ps;\n }\n }\n throw new NotFoundException();\n }\n // Need to Verify\n checkRowsBoolean(reverse) {\n // Limit number of rows we are checking\n // We use recursive algorithm with pure complexity and don't want it to take forever\n // Stacked barcode can have up to 11 rows, so 25 seems reasonable enough\n if (this.rows.length > 25) {\n this.rows.length = 0; // We will never have a chance to get result, so clear it\n return null;\n }\n this.pairs.length = 0;\n if (reverse) {\n this.rows = this.rows.reverse();\n // Collections.reverse(this.rows);\n }\n let ps = null;\n try {\n ps = this.checkRows(new Array(), 0);\n }\n catch (e) {\n // OK\n if (this.verbose) {\n console.log(e);\n }\n }\n if (reverse) {\n this.rows = this.rows.reverse();\n // Collections.reverse(this.rows);\n }\n return ps;\n }\n // Try to construct a valid rows sequence\n // Recursion is used to implement backtracking\n checkRows(collectedRows, currentRow) {\n for (let i = currentRow; i < this.rows.length; i++) {\n let row = this.rows[i];\n this.pairs.length = 0;\n for (let collectedRow of collectedRows) {\n this.pairs.push(collectedRow.getPairs());\n }\n this.pairs.push(row.getPairs());\n if (!RSSExpandedReader.isValidSequence(this.pairs)) {\n continue;\n }\n if (this.checkChecksum()) {\n return this.pairs;\n }\n let rs = new Array(collectedRows);\n rs.push(row);\n try {\n // Recursion: try to add more rows\n return this.checkRows(rs, i + 1);\n }\n catch (e) {\n // We failed, try the next candidate\n if (this.verbose) {\n console.log(e);\n }\n }\n }\n throw new NotFoundException();\n }\n // Whether the pairs form a valid find pattern sequence,\n // either complete or a prefix\n static isValidSequence(pairs) {\n for (let sequence of RSSExpandedReader.FINDER_PATTERN_SEQUENCES) {\n if (pairs.length > sequence.length) {\n continue;\n }\n let stop = true;\n for (let j = 0; j < pairs.length; j++) {\n if (pairs[j].getFinderPattern().getValue() != sequence[j]) {\n stop = false;\n break;\n }\n }\n if (stop) {\n return true;\n }\n }\n return false;\n }\n storeRow(rowNumber, wasReversed) {\n // Discard if duplicate above or below; otherwise insert in order by row number.\n let insertPos = 0;\n let prevIsSame = false;\n let nextIsSame = false;\n while (insertPos < this.rows.length) {\n let erow = this.rows[insertPos];\n if (erow.getRowNumber() > rowNumber) {\n nextIsSame = erow.isEquivalent(this.pairs);\n break;\n }\n prevIsSame = erow.isEquivalent(this.pairs);\n insertPos++;\n }\n if (nextIsSame || prevIsSame) {\n return;\n }\n // When the row was partially decoded (e.g. 2 pairs found instead of 3),\n // it will prevent us from detecting the barcode.\n // Try to merge partial rows\n // Check whether the row is part of an allready detected row\n if (RSSExpandedReader.isPartialRow(this.pairs, this.rows)) {\n return;\n }\n this.rows.push(insertPos, new ExpandedRow(this.pairs, rowNumber, wasReversed));\n this.removePartialRows(this.pairs, this.rows);\n }\n // Remove all the rows that contains only specified pairs\n removePartialRows(pairs, rows) {\n // for (Iterator iterator = rows.iterator(); iterator.hasNext();) {\n // ExpandedRow r = iterator.next();\n // if (r.getPairs().size() == pairs.size()) {\n // continue;\n // }\n // boolean allFound = true;\n // for (ExpandedPair p : r.getPairs()) {\n // boolean found = false;\n // for (ExpandedPair pp : pairs) {\n // if (p.equals(pp)) {\n // found = true;\n // break;\n // }\n // }\n // if (!found) {\n // allFound = false;\n // break;\n // }\n // }\n // if (allFound) {\n // // 'pairs' contains all the pairs from the row 'r'\n // iterator.remove();\n // }\n // }\n for (let row of rows) {\n if (row.getPairs().length === pairs.length) {\n continue;\n }\n for (let p of row.getPairs()) {\n for (let pp of pairs) {\n if (ExpandedPair.equals(p, pp)) {\n break;\n }\n }\n }\n }\n }\n // Returns true when one of the rows already contains all the pairs\n static isPartialRow(pairs, rows) {\n for (let r of rows) {\n let allFound = true;\n for (let p of pairs) {\n let found = false;\n for (let pp of r.getPairs()) {\n if (p.equals(pp)) {\n found = true;\n break;\n }\n }\n if (!found) {\n allFound = false;\n break;\n }\n }\n if (allFound) {\n // the row 'r' contain all the pairs from 'pairs'\n return true;\n }\n }\n return false;\n }\n // Only used for unit testing\n getRows() {\n return this.rows;\n }\n // Not private for unit testing\n static constructResult(pairs) {\n let binary = BitArrayBuilder.buildBitArray(pairs);\n let decoder = createDecoder(binary);\n let resultingString = decoder.parseInformation();\n let firstPoints = pairs[0].getFinderPattern().getResultPoints();\n let lastPoints = pairs[pairs.length - 1].getFinderPattern().getResultPoints();\n let points = [firstPoints[0], firstPoints[1], lastPoints[0], lastPoints[1]];\n return new Result(resultingString, null, null, points, BarcodeFormat$1.RSS_EXPANDED, null);\n }\n checkChecksum() {\n let firstPair = this.pairs.get(0);\n let checkCharacter = firstPair.getLeftChar();\n let firstCharacter = firstPair.getRightChar();\n if (firstCharacter == null) {\n return false;\n }\n let checksum = firstCharacter.getChecksumPortion();\n let s = 2;\n for (let i = 1; i < this.pairs.size(); ++i) {\n let currentPair = this.pairs.get(i);\n checksum += currentPair.getLeftChar().getChecksumPortion();\n s++;\n let currentRightChar = currentPair.getRightChar();\n if (currentRightChar != null) {\n checksum += currentRightChar.getChecksumPortion();\n s++;\n }\n }\n checksum %= 211;\n let checkCharacterValue = 211 * (s - 4) + checksum;\n return checkCharacterValue == checkCharacter.getValue();\n }\n static getNextSecondBar(row, initialPos) {\n let currentPos;\n if (row.get(initialPos)) {\n currentPos = row.getNextUnset(initialPos);\n currentPos = row.getNextSet(currentPos);\n }\n else {\n currentPos = row.getNextSet(initialPos);\n currentPos = row.getNextUnset(currentPos);\n }\n return currentPos;\n }\n // not private for testing\n retrieveNextPair(row, previousPairs, rowNumber) {\n let isOddPattern = previousPairs.length % 2 == 0;\n if (this.startFromEven) {\n isOddPattern = !isOddPattern;\n }\n let pattern;\n let keepFinding = true;\n let forcedOffset = -1;\n do {\n this.findNextPair(row, previousPairs, forcedOffset);\n pattern = this.parseFoundFinderPattern(row, rowNumber, isOddPattern);\n if (pattern == null) {\n forcedOffset = RSSExpandedReader.getNextSecondBar(row, this.startEnd[0]);\n }\n else {\n keepFinding = false;\n }\n } while (keepFinding);\n // When stacked symbol is split over multiple rows, there's no way to guess if this pair can be last or not.\n // boolean mayBeLast = checkPairSequence(previousPairs, pattern);\n let leftChar = this.decodeDataCharacter(row, pattern, isOddPattern, true);\n if (!this.isEmptyPair(previousPairs) && previousPairs[previousPairs.length - 1].mustBeLast()) {\n throw new NotFoundException();\n }\n let rightChar;\n try {\n rightChar = this.decodeDataCharacter(row, pattern, isOddPattern, false);\n }\n catch (e) {\n rightChar = null;\n if (this.verbose) {\n console.log(e);\n }\n }\n return new ExpandedPair(leftChar, rightChar, pattern, true);\n }\n isEmptyPair(pairs) {\n if (pairs.length === 0) {\n return true;\n }\n return false;\n }\n findNextPair(row, previousPairs, forcedOffset) {\n let counters = this.getDecodeFinderCounters();\n counters[0] = 0;\n counters[1] = 0;\n counters[2] = 0;\n counters[3] = 0;\n let width = row.getSize();\n let rowOffset;\n if (forcedOffset >= 0) {\n rowOffset = forcedOffset;\n }\n else if (this.isEmptyPair(previousPairs)) {\n rowOffset = 0;\n }\n else {\n let lastPair = previousPairs[previousPairs.length - 1];\n rowOffset = lastPair.getFinderPattern().getStartEnd()[1];\n }\n let searchingEvenPair = previousPairs.length % 2 != 0;\n if (this.startFromEven) {\n searchingEvenPair = !searchingEvenPair;\n }\n let isWhite = false;\n while (rowOffset < width) {\n isWhite = !row.get(rowOffset);\n if (!isWhite) {\n break;\n }\n rowOffset++;\n }\n let counterPosition = 0;\n let patternStart = rowOffset;\n for (let x = rowOffset; x < width; x++) {\n if (row.get(x) != isWhite) {\n counters[counterPosition]++;\n }\n else {\n if (counterPosition == 3) {\n if (searchingEvenPair) {\n RSSExpandedReader.reverseCounters(counters);\n }\n if (RSSExpandedReader.isFinderPattern(counters)) {\n this.startEnd[0] = patternStart;\n this.startEnd[1] = x;\n return;\n }\n if (searchingEvenPair) {\n RSSExpandedReader.reverseCounters(counters);\n }\n patternStart += counters[0] + counters[1];\n counters[0] = counters[2];\n counters[1] = counters[3];\n counters[2] = 0;\n counters[3] = 0;\n counterPosition--;\n }\n else {\n counterPosition++;\n }\n counters[counterPosition] = 1;\n isWhite = !isWhite;\n }\n }\n throw new NotFoundException();\n }\n static reverseCounters(counters) {\n let length = counters.length;\n for (let i = 0; i < length / 2; ++i) {\n let tmp = counters[i];\n counters[i] = counters[length - i - 1];\n counters[length - i - 1] = tmp;\n }\n }\n parseFoundFinderPattern(row, rowNumber, oddPattern) {\n // Actually we found elements 2-5.\n let firstCounter;\n let start;\n let end;\n if (oddPattern) {\n // If pattern number is odd, we need to locate element 1 *before* the current block.\n let firstElementStart = this.startEnd[0] - 1;\n // Locate element 1\n while (firstElementStart >= 0 && !row.get(firstElementStart)) {\n firstElementStart--;\n }\n firstElementStart++;\n firstCounter = this.startEnd[0] - firstElementStart;\n start = firstElementStart;\n end = this.startEnd[1];\n }\n else {\n // If pattern number is even, the pattern is reversed, so we need to locate element 1 *after* the current block.\n start = this.startEnd[0];\n end = row.getNextUnset(this.startEnd[1] + 1);\n firstCounter = end - this.startEnd[1];\n }\n // Make 'counters' hold 1-4\n let counters = this.getDecodeFinderCounters();\n System.arraycopy(counters, 0, counters, 1, counters.length - 1);\n counters[0] = firstCounter;\n let value;\n try {\n value = this.parseFinderValue(counters, RSSExpandedReader.FINDER_PATTERNS);\n }\n catch (e) {\n return null;\n }\n // return new FinderPattern(value, new int[] { start, end }, start, end, rowNumber});\n return new FinderPattern(value, [start, end], start, end, rowNumber);\n }\n decodeDataCharacter(row, pattern, isOddPattern, leftChar) {\n let counters = this.getDataCharacterCounters();\n for (let x = 0; x < counters.length; x++) {\n counters[x] = 0;\n }\n if (leftChar) {\n RSSExpandedReader.recordPatternInReverse(row, pattern.getStartEnd()[0], counters);\n }\n else {\n RSSExpandedReader.recordPattern(row, pattern.getStartEnd()[1], counters);\n // reverse it\n for (let i = 0, j = counters.length - 1; i < j; i++, j--) {\n let temp = counters[i];\n counters[i] = counters[j];\n counters[j] = temp;\n }\n } // counters[] has the pixels of the module\n let numModules = 17; // left and right data characters have all the same length\n let elementWidth = MathUtils.sum(new Int32Array(counters)) / numModules;\n // Sanity check: element width for pattern and the character should match\n let expectedElementWidth = (pattern.getStartEnd()[1] - pattern.getStartEnd()[0]) / 15.0;\n if (Math.abs(elementWidth - expectedElementWidth) / expectedElementWidth > 0.3) {\n throw new NotFoundException();\n }\n let oddCounts = this.getOddCounts();\n let evenCounts = this.getEvenCounts();\n let oddRoundingErrors = this.getOddRoundingErrors();\n let evenRoundingErrors = this.getEvenRoundingErrors();\n for (let i = 0; i < counters.length; i++) {\n let value = 1.0 * counters[i] / elementWidth;\n let count = value + 0.5; // Round\n if (count < 1) {\n if (value < 0.3) {\n throw new NotFoundException();\n }\n count = 1;\n }\n else if (count > 8) {\n if (value > 8.7) {\n throw new NotFoundException();\n }\n count = 8;\n }\n let offset = i / 2;\n if ((i & 0x01) == 0) {\n oddCounts[offset] = count;\n oddRoundingErrors[offset] = value - count;\n }\n else {\n evenCounts[offset] = count;\n evenRoundingErrors[offset] = value - count;\n }\n }\n this.adjustOddEvenCounts(numModules);\n let weightRowNumber = 4 * pattern.getValue() + (isOddPattern ? 0 : 2) + (leftChar ? 0 : 1) - 1;\n let oddSum = 0;\n let oddChecksumPortion = 0;\n for (let i = oddCounts.length - 1; i >= 0; i--) {\n if (RSSExpandedReader.isNotA1left(pattern, isOddPattern, leftChar)) {\n let weight = RSSExpandedReader.WEIGHTS[weightRowNumber][2 * i];\n oddChecksumPortion += oddCounts[i] * weight;\n }\n oddSum += oddCounts[i];\n }\n let evenChecksumPortion = 0;\n // int evenSum = 0;\n for (let i = evenCounts.length - 1; i >= 0; i--) {\n if (RSSExpandedReader.isNotA1left(pattern, isOddPattern, leftChar)) {\n let weight = RSSExpandedReader.WEIGHTS[weightRowNumber][2 * i + 1];\n evenChecksumPortion += evenCounts[i] * weight;\n }\n // evenSum += evenCounts[i];\n }\n let checksumPortion = oddChecksumPortion + evenChecksumPortion;\n if ((oddSum & 0x01) != 0 || oddSum > 13 || oddSum < 4) {\n throw new NotFoundException();\n }\n let group = (13 - oddSum) / 2;\n let oddWidest = RSSExpandedReader.SYMBOL_WIDEST[group];\n let evenWidest = 9 - oddWidest;\n let vOdd = RSSUtils.getRSSvalue(oddCounts, oddWidest, true);\n let vEven = RSSUtils.getRSSvalue(evenCounts, evenWidest, false);\n let tEven = RSSExpandedReader.EVEN_TOTAL_SUBSET[group];\n let gSum = RSSExpandedReader.GSUM[group];\n let value = vOdd * tEven + vEven + gSum;\n return new DataCharacter(value, checksumPortion);\n }\n static isNotA1left(pattern, isOddPattern, leftChar) {\n // A1: pattern.getValue is 0 (A), and it's an oddPattern, and it is a left char\n return !(pattern.getValue() == 0 && isOddPattern && leftChar);\n }\n adjustOddEvenCounts(numModules) {\n let oddSum = MathUtils.sum(new Int32Array(this.getOddCounts()));\n let evenSum = MathUtils.sum(new Int32Array(this.getEvenCounts()));\n let incrementOdd = false;\n let decrementOdd = false;\n if (oddSum > 13) {\n decrementOdd = true;\n }\n else if (oddSum < 4) {\n incrementOdd = true;\n }\n let incrementEven = false;\n let decrementEven = false;\n if (evenSum > 13) {\n decrementEven = true;\n }\n else if (evenSum < 4) {\n incrementEven = true;\n }\n let mismatch = oddSum + evenSum - numModules;\n let oddParityBad = (oddSum & 0x01) == 1;\n let evenParityBad = (evenSum & 0x01) == 0;\n if (mismatch == 1) {\n if (oddParityBad) {\n if (evenParityBad) {\n throw new NotFoundException();\n }\n decrementOdd = true;\n }\n else {\n if (!evenParityBad) {\n throw new NotFoundException();\n }\n decrementEven = true;\n }\n }\n else if (mismatch == -1) {\n if (oddParityBad) {\n if (evenParityBad) {\n throw new NotFoundException();\n }\n incrementOdd = true;\n }\n else {\n if (!evenParityBad) {\n throw new NotFoundException();\n }\n incrementEven = true;\n }\n }\n else if (mismatch == 0) {\n if (oddParityBad) {\n if (!evenParityBad) {\n throw new NotFoundException();\n }\n // Both bad\n if (oddSum < evenSum) {\n incrementOdd = true;\n decrementEven = true;\n }\n else {\n decrementOdd = true;\n incrementEven = true;\n }\n }\n else {\n if (evenParityBad) {\n throw new NotFoundException();\n }\n // Nothing to do!\n }\n }\n else {\n throw new NotFoundException();\n }\n if (incrementOdd) {\n if (decrementOdd) {\n throw new NotFoundException();\n }\n RSSExpandedReader.increment(this.getOddCounts(), this.getOddRoundingErrors());\n }\n if (decrementOdd) {\n RSSExpandedReader.decrement(this.getOddCounts(), this.getOddRoundingErrors());\n }\n if (incrementEven) {\n if (decrementEven) {\n throw new NotFoundException();\n }\n RSSExpandedReader.increment(this.getEvenCounts(), this.getOddRoundingErrors());\n }\n if (decrementEven) {\n RSSExpandedReader.decrement(this.getEvenCounts(), this.getEvenRoundingErrors());\n }\n }\n }\n RSSExpandedReader.SYMBOL_WIDEST = [7, 5, 4, 3, 1];\n RSSExpandedReader.EVEN_TOTAL_SUBSET = [4, 20, 52, 104, 204];\n RSSExpandedReader.GSUM = [0, 348, 1388, 2948, 3988];\n RSSExpandedReader.FINDER_PATTERNS = [\n Int32Array.from([1, 8, 4, 1]),\n Int32Array.from([3, 6, 4, 1]),\n Int32Array.from([3, 4, 6, 1]),\n Int32Array.from([3, 2, 8, 1]),\n Int32Array.from([2, 6, 5, 1]),\n Int32Array.from([2, 2, 9, 1]) // F\n ];\n RSSExpandedReader.WEIGHTS = [\n [1, 3, 9, 27, 81, 32, 96, 77],\n [20, 60, 180, 118, 143, 7, 21, 63],\n [189, 145, 13, 39, 117, 140, 209, 205],\n [193, 157, 49, 147, 19, 57, 171, 91],\n [62, 186, 136, 197, 169, 85, 44, 132],\n [185, 133, 188, 142, 4, 12, 36, 108],\n [113, 128, 173, 97, 80, 29, 87, 50],\n [150, 28, 84, 41, 123, 158, 52, 156],\n [46, 138, 203, 187, 139, 206, 196, 166],\n [76, 17, 51, 153, 37, 111, 122, 155],\n [43, 129, 176, 106, 107, 110, 119, 146],\n [16, 48, 144, 10, 30, 90, 59, 177],\n [109, 116, 137, 200, 178, 112, 125, 164],\n [70, 210, 208, 202, 184, 130, 179, 115],\n [134, 191, 151, 31, 93, 68, 204, 190],\n [148, 22, 66, 198, 172, 94, 71, 2],\n [6, 18, 54, 162, 64, 192, 154, 40],\n [120, 149, 25, 75, 14, 42, 126, 167],\n [79, 26, 78, 23, 69, 207, 199, 175],\n [103, 98, 83, 38, 114, 131, 182, 124],\n [161, 61, 183, 127, 170, 88, 53, 159],\n [55, 165, 73, 8, 24, 72, 5, 15],\n [45, 135, 194, 160, 58, 174, 100, 89]\n ];\n RSSExpandedReader.FINDER_PAT_A = 0;\n RSSExpandedReader.FINDER_PAT_B = 1;\n RSSExpandedReader.FINDER_PAT_C = 2;\n RSSExpandedReader.FINDER_PAT_D = 3;\n RSSExpandedReader.FINDER_PAT_E = 4;\n RSSExpandedReader.FINDER_PAT_F = 5;\n RSSExpandedReader.FINDER_PATTERN_SEQUENCES = [\n [RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_A],\n [RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_B],\n [RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_C, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_D],\n [RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_E, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_D, RSSExpandedReader.FINDER_PAT_C],\n [RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_E, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_D, RSSExpandedReader.FINDER_PAT_D, RSSExpandedReader.FINDER_PAT_F],\n [RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_E, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_D, RSSExpandedReader.FINDER_PAT_E, RSSExpandedReader.FINDER_PAT_F, RSSExpandedReader.FINDER_PAT_F],\n [RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_C, RSSExpandedReader.FINDER_PAT_C, RSSExpandedReader.FINDER_PAT_D, RSSExpandedReader.FINDER_PAT_D],\n [RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_C, RSSExpandedReader.FINDER_PAT_C, RSSExpandedReader.FINDER_PAT_D, RSSExpandedReader.FINDER_PAT_E, RSSExpandedReader.FINDER_PAT_E],\n [RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_C, RSSExpandedReader.FINDER_PAT_C, RSSExpandedReader.FINDER_PAT_D, RSSExpandedReader.FINDER_PAT_E, RSSExpandedReader.FINDER_PAT_F, RSSExpandedReader.FINDER_PAT_F],\n [RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_A, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_B, RSSExpandedReader.FINDER_PAT_C, RSSExpandedReader.FINDER_PAT_D, RSSExpandedReader.FINDER_PAT_D, RSSExpandedReader.FINDER_PAT_E, RSSExpandedReader.FINDER_PAT_E, RSSExpandedReader.FINDER_PAT_F, RSSExpandedReader.FINDER_PAT_F],\n ];\n RSSExpandedReader.MAX_PAIRS = 11;\n\n class Pair extends DataCharacter {\n constructor(value, checksumPortion, finderPattern) {\n super(value, checksumPortion);\n this.count = 0;\n this.finderPattern = finderPattern;\n }\n getFinderPattern() {\n return this.finderPattern;\n }\n getCount() {\n return this.count;\n }\n incrementCount() {\n this.count++;\n }\n }\n\n class RSS14Reader extends AbstractRSSReader {\n constructor() {\n super(...arguments);\n this.possibleLeftPairs = [];\n this.possibleRightPairs = [];\n }\n decodeRow(rowNumber, row, hints) {\n const leftPair = this.decodePair(row, false, rowNumber, hints);\n RSS14Reader.addOrTally(this.possibleLeftPairs, leftPair);\n row.reverse();\n let rightPair = this.decodePair(row, true, rowNumber, hints);\n RSS14Reader.addOrTally(this.possibleRightPairs, rightPair);\n row.reverse();\n for (let left of this.possibleLeftPairs) {\n if (left.getCount() > 1) {\n for (let right of this.possibleRightPairs) {\n if (right.getCount() > 1 && RSS14Reader.checkChecksum(left, right)) {\n return RSS14Reader.constructResult(left, right);\n }\n }\n }\n }\n throw new NotFoundException();\n }\n static addOrTally(possiblePairs, pair) {\n if (pair == null) {\n return;\n }\n let found = false;\n for (let other of possiblePairs) {\n if (other.getValue() === pair.getValue()) {\n other.incrementCount();\n found = true;\n break;\n }\n }\n if (!found) {\n possiblePairs.push(pair);\n }\n }\n reset() {\n this.possibleLeftPairs.length = 0;\n this.possibleRightPairs.length = 0;\n }\n static constructResult(leftPair, rightPair) {\n let symbolValue = 4537077 * leftPair.getValue() + rightPair.getValue();\n let text = new String(symbolValue).toString();\n let buffer = new StringBuilder();\n for (let i = 13 - text.length; i > 0; i--) {\n buffer.append('0');\n }\n buffer.append(text);\n let checkDigit = 0;\n for (let i = 0; i < 13; i++) {\n let digit = buffer.charAt(i).charCodeAt(0) - '0'.charCodeAt(0);\n checkDigit += ((i & 0x01) === 0) ? 3 * digit : digit;\n }\n checkDigit = 10 - (checkDigit % 10);\n if (checkDigit === 10) {\n checkDigit = 0;\n }\n buffer.append(checkDigit.toString());\n let leftPoints = leftPair.getFinderPattern().getResultPoints();\n let rightPoints = rightPair.getFinderPattern().getResultPoints();\n return new Result(buffer.toString(), null, 0, [leftPoints[0], leftPoints[1], rightPoints[0], rightPoints[1]], BarcodeFormat$1.RSS_14, new Date().getTime());\n }\n static checkChecksum(leftPair, rightPair) {\n let checkValue = (leftPair.getChecksumPortion() + 16 * rightPair.getChecksumPortion()) % 79;\n let targetCheckValue = 9 * leftPair.getFinderPattern().getValue() + rightPair.getFinderPattern().getValue();\n if (targetCheckValue > 72) {\n targetCheckValue--;\n }\n if (targetCheckValue > 8) {\n targetCheckValue--;\n }\n return checkValue === targetCheckValue;\n }\n decodePair(row, right, rowNumber, hints) {\n try {\n let startEnd = this.findFinderPattern(row, right);\n let pattern = this.parseFoundFinderPattern(row, rowNumber, right, startEnd);\n let resultPointCallback = hints == null ? null : hints.get(DecodeHintType$1.NEED_RESULT_POINT_CALLBACK);\n if (resultPointCallback != null) {\n let center = (startEnd[0] + startEnd[1]) / 2.0;\n if (right) {\n // row is actually reversed\n center = row.getSize() - 1 - center;\n }\n resultPointCallback.foundPossibleResultPoint(new ResultPoint(center, rowNumber));\n }\n let outside = this.decodeDataCharacter(row, pattern, true);\n let inside = this.decodeDataCharacter(row, pattern, false);\n return new Pair(1597 * outside.getValue() + inside.getValue(), outside.getChecksumPortion() + 4 * inside.getChecksumPortion(), pattern);\n }\n catch (err) {\n return null;\n }\n }\n decodeDataCharacter(row, pattern, outsideChar) {\n let counters = this.getDataCharacterCounters();\n for (let x = 0; x < counters.length; x++) {\n counters[x] = 0;\n }\n if (outsideChar) {\n OneDReader.recordPatternInReverse(row, pattern.getStartEnd()[0], counters);\n }\n else {\n OneDReader.recordPattern(row, pattern.getStartEnd()[1] + 1, counters);\n // reverse it\n for (let i = 0, j = counters.length - 1; i < j; i++, j--) {\n let temp = counters[i];\n counters[i] = counters[j];\n counters[j] = temp;\n }\n }\n let numModules = outsideChar ? 16 : 15;\n let elementWidth = MathUtils.sum(new Int32Array(counters)) / numModules;\n let oddCounts = this.getOddCounts();\n let evenCounts = this.getEvenCounts();\n let oddRoundingErrors = this.getOddRoundingErrors();\n let evenRoundingErrors = this.getEvenRoundingErrors();\n for (let i = 0; i < counters.length; i++) {\n let value = counters[i] / elementWidth;\n let count = Math.floor(value + 0.5);\n if (count < 1) {\n count = 1;\n }\n else if (count > 8) {\n count = 8;\n }\n let offset = Math.floor(i / 2);\n if ((i & 0x01) === 0) {\n oddCounts[offset] = count;\n oddRoundingErrors[offset] = value - count;\n }\n else {\n evenCounts[offset] = count;\n evenRoundingErrors[offset] = value - count;\n }\n }\n this.adjustOddEvenCounts(outsideChar, numModules);\n let oddSum = 0;\n let oddChecksumPortion = 0;\n for (let i = oddCounts.length - 1; i >= 0; i--) {\n oddChecksumPortion *= 9;\n oddChecksumPortion += oddCounts[i];\n oddSum += oddCounts[i];\n }\n let evenChecksumPortion = 0;\n let evenSum = 0;\n for (let i = evenCounts.length - 1; i >= 0; i--) {\n evenChecksumPortion *= 9;\n evenChecksumPortion += evenCounts[i];\n evenSum += evenCounts[i];\n }\n let checksumPortion = oddChecksumPortion + 3 * evenChecksumPortion;\n if (outsideChar) {\n if ((oddSum & 0x01) !== 0 || oddSum > 12 || oddSum < 4) {\n throw new NotFoundException();\n }\n let group = (12 - oddSum) / 2;\n let oddWidest = RSS14Reader.OUTSIDE_ODD_WIDEST[group];\n let evenWidest = 9 - oddWidest;\n let vOdd = RSSUtils.getRSSvalue(oddCounts, oddWidest, false);\n let vEven = RSSUtils.getRSSvalue(evenCounts, evenWidest, true);\n let tEven = RSS14Reader.OUTSIDE_EVEN_TOTAL_SUBSET[group];\n let gSum = RSS14Reader.OUTSIDE_GSUM[group];\n return new DataCharacter(vOdd * tEven + vEven + gSum, checksumPortion);\n }\n else {\n if ((evenSum & 0x01) !== 0 || evenSum > 10 || evenSum < 4) {\n throw new NotFoundException();\n }\n let group = (10 - evenSum) / 2;\n let oddWidest = RSS14Reader.INSIDE_ODD_WIDEST[group];\n let evenWidest = 9 - oddWidest;\n let vOdd = RSSUtils.getRSSvalue(oddCounts, oddWidest, true);\n let vEven = RSSUtils.getRSSvalue(evenCounts, evenWidest, false);\n let tOdd = RSS14Reader.INSIDE_ODD_TOTAL_SUBSET[group];\n let gSum = RSS14Reader.INSIDE_GSUM[group];\n return new DataCharacter(vEven * tOdd + vOdd + gSum, checksumPortion);\n }\n }\n findFinderPattern(row, rightFinderPattern) {\n let counters = this.getDecodeFinderCounters();\n counters[0] = 0;\n counters[1] = 0;\n counters[2] = 0;\n counters[3] = 0;\n let width = row.getSize();\n let isWhite = false;\n let rowOffset = 0;\n while (rowOffset < width) {\n isWhite = !row.get(rowOffset);\n if (rightFinderPattern === isWhite) {\n // Will encounter white first when searching for right finder pattern\n break;\n }\n rowOffset++;\n }\n let counterPosition = 0;\n let patternStart = rowOffset;\n for (let x = rowOffset; x < width; x++) {\n if (row.get(x) !== isWhite) {\n counters[counterPosition]++;\n }\n else {\n if (counterPosition === 3) {\n if (AbstractRSSReader.isFinderPattern(counters)) {\n return [patternStart, x];\n }\n patternStart += counters[0] + counters[1];\n counters[0] = counters[2];\n counters[1] = counters[3];\n counters[2] = 0;\n counters[3] = 0;\n counterPosition--;\n }\n else {\n counterPosition++;\n }\n counters[counterPosition] = 1;\n isWhite = !isWhite;\n }\n }\n throw new NotFoundException();\n }\n parseFoundFinderPattern(row, rowNumber, right, startEnd) {\n // Actually we found elements 2-5\n let firstIsBlack = row.get(startEnd[0]);\n let firstElementStart = startEnd[0] - 1;\n // Locate element 1\n while (firstElementStart >= 0 && firstIsBlack !== row.get(firstElementStart)) {\n firstElementStart--;\n }\n firstElementStart++;\n const firstCounter = startEnd[0] - firstElementStart;\n // Make 'counters' hold 1-4\n const counters = this.getDecodeFinderCounters();\n const copy = new Int32Array(counters.length);\n System.arraycopy(counters, 0, copy, 1, counters.length - 1);\n copy[0] = firstCounter;\n const value = this.parseFinderValue(copy, RSS14Reader.FINDER_PATTERNS);\n let start = firstElementStart;\n let end = startEnd[1];\n if (right) {\n // row is actually reversed\n start = row.getSize() - 1 - start;\n end = row.getSize() - 1 - end;\n }\n return new FinderPattern(value, [firstElementStart, startEnd[1]], start, end, rowNumber);\n }\n adjustOddEvenCounts(outsideChar, numModules) {\n let oddSum = MathUtils.sum(new Int32Array(this.getOddCounts()));\n let evenSum = MathUtils.sum(new Int32Array(this.getEvenCounts()));\n let incrementOdd = false;\n let decrementOdd = false;\n let incrementEven = false;\n let decrementEven = false;\n if (outsideChar) {\n if (oddSum > 12) {\n decrementOdd = true;\n }\n else if (oddSum < 4) {\n incrementOdd = true;\n }\n if (evenSum > 12) {\n decrementEven = true;\n }\n else if (evenSum < 4) {\n incrementEven = true;\n }\n }\n else {\n if (oddSum > 11) {\n decrementOdd = true;\n }\n else if (oddSum < 5) {\n incrementOdd = true;\n }\n if (evenSum > 10) {\n decrementEven = true;\n }\n else if (evenSum < 4) {\n incrementEven = true;\n }\n }\n let mismatch = oddSum + evenSum - numModules;\n let oddParityBad = (oddSum & 0x01) === (outsideChar ? 1 : 0);\n let evenParityBad = (evenSum & 0x01) === 1;\n if (mismatch === 1) {\n if (oddParityBad) {\n if (evenParityBad) {\n throw new NotFoundException();\n }\n decrementOdd = true;\n }\n else {\n if (!evenParityBad) {\n throw new NotFoundException();\n }\n decrementEven = true;\n }\n }\n else if (mismatch === -1) {\n if (oddParityBad) {\n if (evenParityBad) {\n throw new NotFoundException();\n }\n incrementOdd = true;\n }\n else {\n if (!evenParityBad) {\n throw new NotFoundException();\n }\n incrementEven = true;\n }\n }\n else if (mismatch === 0) {\n if (oddParityBad) {\n if (!evenParityBad) {\n throw new NotFoundException();\n }\n // Both bad\n if (oddSum < evenSum) {\n incrementOdd = true;\n decrementEven = true;\n }\n else {\n decrementOdd = true;\n incrementEven = true;\n }\n }\n else {\n if (evenParityBad) {\n throw new NotFoundException();\n }\n // Nothing to do!\n }\n }\n else {\n throw new NotFoundException();\n }\n if (incrementOdd) {\n if (decrementOdd) {\n throw new NotFoundException();\n }\n AbstractRSSReader.increment(this.getOddCounts(), this.getOddRoundingErrors());\n }\n if (decrementOdd) {\n AbstractRSSReader.decrement(this.getOddCounts(), this.getOddRoundingErrors());\n }\n if (incrementEven) {\n if (decrementEven) {\n throw new NotFoundException();\n }\n AbstractRSSReader.increment(this.getEvenCounts(), this.getOddRoundingErrors());\n }\n if (decrementEven) {\n AbstractRSSReader.decrement(this.getEvenCounts(), this.getEvenRoundingErrors());\n }\n }\n }\n RSS14Reader.OUTSIDE_EVEN_TOTAL_SUBSET = [1, 10, 34, 70, 126];\n RSS14Reader.INSIDE_ODD_TOTAL_SUBSET = [4, 20, 48, 81];\n RSS14Reader.OUTSIDE_GSUM = [0, 161, 961, 2015, 2715];\n RSS14Reader.INSIDE_GSUM = [0, 336, 1036, 1516];\n RSS14Reader.OUTSIDE_ODD_WIDEST = [8, 6, 4, 3, 1];\n RSS14Reader.INSIDE_ODD_WIDEST = [2, 4, 6, 8];\n RSS14Reader.FINDER_PATTERNS = [\n Int32Array.from([3, 8, 2, 1]),\n Int32Array.from([3, 5, 5, 1]),\n Int32Array.from([3, 3, 7, 1]),\n Int32Array.from([3, 1, 9, 1]),\n Int32Array.from([2, 7, 4, 1]),\n Int32Array.from([2, 5, 6, 1]),\n Int32Array.from([2, 3, 8, 1]),\n Int32Array.from([1, 5, 7, 1]),\n Int32Array.from([1, 3, 9, 1]),\n ];\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author Daniel Switkin \n * @author Sean Owen\n */\n class MultiFormatOneDReader extends OneDReader {\n constructor(hints, verbose) {\n super();\n this.readers = [];\n this.verbose = (verbose === true);\n const possibleFormats = !hints ? null : hints.get(DecodeHintType$1.POSSIBLE_FORMATS);\n const useCode39CheckDigit = hints && hints.get(DecodeHintType$1.ASSUME_CODE_39_CHECK_DIGIT) !== undefined;\n if (possibleFormats) {\n if (possibleFormats.includes(BarcodeFormat$1.EAN_13) ||\n possibleFormats.includes(BarcodeFormat$1.UPC_A) ||\n possibleFormats.includes(BarcodeFormat$1.EAN_8) ||\n possibleFormats.includes(BarcodeFormat$1.UPC_E)) {\n this.readers.push(new MultiFormatUPCEANReader(hints));\n }\n if (possibleFormats.includes(BarcodeFormat$1.CODE_39)) {\n this.readers.push(new Code39Reader(useCode39CheckDigit));\n }\n // if (possibleFormats.includes(BarcodeFormat.CODE_93)) {\n // this.readers.push(new Code93Reader());\n // }\n if (possibleFormats.includes(BarcodeFormat$1.CODE_128)) {\n this.readers.push(new Code128Reader());\n }\n if (possibleFormats.includes(BarcodeFormat$1.ITF)) {\n this.readers.push(new ITFReader());\n }\n // if (possibleFormats.includes(BarcodeFormat.CODABAR)) {\n // this.readers.push(new CodaBarReader());\n // }\n if (possibleFormats.includes(BarcodeFormat$1.RSS_14)) {\n this.readers.push(new RSS14Reader());\n }\n if (possibleFormats.includes(BarcodeFormat$1.RSS_EXPANDED)) {\n this.readers.push(new RSSExpandedReader(this.verbose));\n }\n }\n if (this.readers.length === 0) {\n this.readers.push(new MultiFormatUPCEANReader(hints));\n this.readers.push(new Code39Reader());\n // this.readers.push(new CodaBarReader());\n // this.readers.push(new Code93Reader());\n this.readers.push(new MultiFormatUPCEANReader(hints));\n this.readers.push(new Code128Reader());\n this.readers.push(new ITFReader());\n this.readers.push(new RSS14Reader());\n this.readers.push(new RSSExpandedReader(this.verbose));\n }\n }\n // @Override\n decodeRow(rowNumber, row, hints) {\n for (let i = 0; i < this.readers.length; i++) {\n try {\n return this.readers[i].decodeRow(rowNumber, row, hints);\n }\n catch (re) {\n // continue\n }\n }\n throw new NotFoundException();\n }\n // @Override\n reset() {\n this.readers.forEach(reader => reader.reset());\n }\n }\n\n /**\n * @deprecated Moving to @zxing/browser\n *\n * Barcode reader reader to use from browser.\n */\n class BrowserBarcodeReader extends BrowserCodeReader {\n /**\n * Creates an instance of BrowserBarcodeReader.\n * @param {number} [timeBetweenScansMillis=500] the time delay between subsequent decode tries\n * @param {Map} hints\n */\n constructor(timeBetweenScansMillis = 500, hints) {\n super(new MultiFormatOneDReader(hints), timeBetweenScansMillis, hints);\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates a set of error-correction blocks in one symbol version. Most versions will\n * use blocks of differing sizes within one version, so, this encapsulates the parameters for\n * each set of blocks. It also holds the number of error-correction codewords per block since it\n * will be the same across all blocks within one version.

\n */\n class ECBlocks {\n constructor(ecCodewords, ecBlocks1, ecBlocks2) {\n this.ecCodewords = ecCodewords;\n this.ecBlocks = [ecBlocks1];\n ecBlocks2 && this.ecBlocks.push(ecBlocks2);\n }\n getECCodewords() {\n return this.ecCodewords;\n }\n getECBlocks() {\n return this.ecBlocks;\n }\n }\n /**\n *

Encapsulates the parameters for one error-correction block in one symbol version.\n * This includes the number of data codewords, and the number of times a block with these\n * parameters is used consecutively in the Data Matrix code version's format.

\n */\n class ECB {\n constructor(count, dataCodewords) {\n this.count = count;\n this.dataCodewords = dataCodewords;\n }\n getCount() {\n return this.count;\n }\n getDataCodewords() {\n return this.dataCodewords;\n }\n }\n /**\n * The Version object encapsulates attributes about a particular\n * size Data Matrix Code.\n *\n * @author bbrown@google.com (Brian Brown)\n */\n class Version {\n constructor(versionNumber, symbolSizeRows, symbolSizeColumns, dataRegionSizeRows, dataRegionSizeColumns, ecBlocks) {\n this.versionNumber = versionNumber;\n this.symbolSizeRows = symbolSizeRows;\n this.symbolSizeColumns = symbolSizeColumns;\n this.dataRegionSizeRows = dataRegionSizeRows;\n this.dataRegionSizeColumns = dataRegionSizeColumns;\n this.ecBlocks = ecBlocks;\n // Calculate the total number of codewords\n let total = 0;\n const ecCodewords = ecBlocks.getECCodewords();\n const ecbArray = ecBlocks.getECBlocks();\n for (let ecBlock of ecbArray) {\n total += ecBlock.getCount() * (ecBlock.getDataCodewords() + ecCodewords);\n }\n this.totalCodewords = total;\n }\n getVersionNumber() {\n return this.versionNumber;\n }\n getSymbolSizeRows() {\n return this.symbolSizeRows;\n }\n getSymbolSizeColumns() {\n return this.symbolSizeColumns;\n }\n getDataRegionSizeRows() {\n return this.dataRegionSizeRows;\n }\n getDataRegionSizeColumns() {\n return this.dataRegionSizeColumns;\n }\n getTotalCodewords() {\n return this.totalCodewords;\n }\n getECBlocks() {\n return this.ecBlocks;\n }\n /**\n *

Deduces version information from Data Matrix dimensions.

\n *\n * @param numRows Number of rows in modules\n * @param numColumns Number of columns in modules\n * @return Version for a Data Matrix Code of those dimensions\n * @throws FormatException if dimensions do correspond to a valid Data Matrix size\n */\n static getVersionForDimensions(numRows, numColumns) {\n if ((numRows & 0x01) !== 0 || (numColumns & 0x01) !== 0) {\n throw new FormatException();\n }\n for (let version of Version.VERSIONS) {\n if (version.symbolSizeRows === numRows && version.symbolSizeColumns === numColumns) {\n return version;\n }\n }\n throw new FormatException();\n }\n // @Override\n toString() {\n return '' + this.versionNumber;\n }\n /**\n * See ISO 16022:2006 5.5.1 Table 7\n */\n static buildVersions() {\n return [\n new Version(1, 10, 10, 8, 8, new ECBlocks(5, new ECB(1, 3))),\n new Version(2, 12, 12, 10, 10, new ECBlocks(7, new ECB(1, 5))),\n new Version(3, 14, 14, 12, 12, new ECBlocks(10, new ECB(1, 8))),\n new Version(4, 16, 16, 14, 14, new ECBlocks(12, new ECB(1, 12))),\n new Version(5, 18, 18, 16, 16, new ECBlocks(14, new ECB(1, 18))),\n new Version(6, 20, 20, 18, 18, new ECBlocks(18, new ECB(1, 22))),\n new Version(7, 22, 22, 20, 20, new ECBlocks(20, new ECB(1, 30))),\n new Version(8, 24, 24, 22, 22, new ECBlocks(24, new ECB(1, 36))),\n new Version(9, 26, 26, 24, 24, new ECBlocks(28, new ECB(1, 44))),\n new Version(10, 32, 32, 14, 14, new ECBlocks(36, new ECB(1, 62))),\n new Version(11, 36, 36, 16, 16, new ECBlocks(42, new ECB(1, 86))),\n new Version(12, 40, 40, 18, 18, new ECBlocks(48, new ECB(1, 114))),\n new Version(13, 44, 44, 20, 20, new ECBlocks(56, new ECB(1, 144))),\n new Version(14, 48, 48, 22, 22, new ECBlocks(68, new ECB(1, 174))),\n new Version(15, 52, 52, 24, 24, new ECBlocks(42, new ECB(2, 102))),\n new Version(16, 64, 64, 14, 14, new ECBlocks(56, new ECB(2, 140))),\n new Version(17, 72, 72, 16, 16, new ECBlocks(36, new ECB(4, 92))),\n new Version(18, 80, 80, 18, 18, new ECBlocks(48, new ECB(4, 114))),\n new Version(19, 88, 88, 20, 20, new ECBlocks(56, new ECB(4, 144))),\n new Version(20, 96, 96, 22, 22, new ECBlocks(68, new ECB(4, 174))),\n new Version(21, 104, 104, 24, 24, new ECBlocks(56, new ECB(6, 136))),\n new Version(22, 120, 120, 18, 18, new ECBlocks(68, new ECB(6, 175))),\n new Version(23, 132, 132, 20, 20, new ECBlocks(62, new ECB(8, 163))),\n new Version(24, 144, 144, 22, 22, new ECBlocks(62, new ECB(8, 156), new ECB(2, 155))),\n new Version(25, 8, 18, 6, 16, new ECBlocks(7, new ECB(1, 5))),\n new Version(26, 8, 32, 6, 14, new ECBlocks(11, new ECB(1, 10))),\n new Version(27, 12, 26, 10, 24, new ECBlocks(14, new ECB(1, 16))),\n new Version(28, 12, 36, 10, 16, new ECBlocks(18, new ECB(1, 22))),\n new Version(29, 16, 36, 14, 16, new ECBlocks(24, new ECB(1, 32))),\n new Version(30, 16, 48, 14, 22, new ECBlocks(28, new ECB(1, 49)))\n ];\n }\n }\n Version.VERSIONS = Version.buildVersions();\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author bbrown@google.com (Brian Brown)\n */\n class BitMatrixParser {\n /**\n * @param bitMatrix {@link BitMatrix} to parse\n * @throws FormatException if dimension is < 8 or > 144 or not 0 mod 2\n */\n constructor(bitMatrix) {\n const dimension = bitMatrix.getHeight();\n if (dimension < 8 || dimension > 144 || (dimension & 0x01) !== 0) {\n throw new FormatException();\n }\n this.version = BitMatrixParser.readVersion(bitMatrix);\n this.mappingBitMatrix = this.extractDataRegion(bitMatrix);\n this.readMappingMatrix = new BitMatrix(this.mappingBitMatrix.getWidth(), this.mappingBitMatrix.getHeight());\n }\n getVersion() {\n return this.version;\n }\n /**\n *

Creates the version object based on the dimension of the original bit matrix from\n * the datamatrix code.

\n *\n *

See ISO 16022:2006 Table 7 - ECC 200 symbol attributes

\n *\n * @param bitMatrix Original {@link BitMatrix} including alignment patterns\n * @return {@link Version} encapsulating the Data Matrix Code's \"version\"\n * @throws FormatException if the dimensions of the mapping matrix are not valid\n * Data Matrix dimensions.\n */\n static readVersion(bitMatrix) {\n const numRows = bitMatrix.getHeight();\n const numColumns = bitMatrix.getWidth();\n return Version.getVersionForDimensions(numRows, numColumns);\n }\n /**\n *

Reads the bits in the {@link BitMatrix} representing the mapping matrix (No alignment patterns)\n * in the correct order in order to reconstitute the codewords bytes contained within the\n * Data Matrix Code.

\n *\n * @return bytes encoded within the Data Matrix Code\n * @throws FormatException if the exact number of bytes expected is not read\n */\n readCodewords() {\n const result = new Int8Array(this.version.getTotalCodewords());\n let resultOffset = 0;\n let row = 4;\n let column = 0;\n const numRows = this.mappingBitMatrix.getHeight();\n const numColumns = this.mappingBitMatrix.getWidth();\n let corner1Read = false;\n let corner2Read = false;\n let corner3Read = false;\n let corner4Read = false;\n // Read all of the codewords\n do {\n // Check the four corner cases\n if ((row === numRows) && (column === 0) && !corner1Read) {\n result[resultOffset++] = this.readCorner1(numRows, numColumns) & 0xff;\n row -= 2;\n column += 2;\n corner1Read = true;\n }\n else if ((row === numRows - 2) && (column === 0) && ((numColumns & 0x03) !== 0) && !corner2Read) {\n result[resultOffset++] = this.readCorner2(numRows, numColumns) & 0xff;\n row -= 2;\n column += 2;\n corner2Read = true;\n }\n else if ((row === numRows + 4) && (column === 2) && ((numColumns & 0x07) === 0) && !corner3Read) {\n result[resultOffset++] = this.readCorner3(numRows, numColumns) & 0xff;\n row -= 2;\n column += 2;\n corner3Read = true;\n }\n else if ((row === numRows - 2) && (column === 0) && ((numColumns & 0x07) === 4) && !corner4Read) {\n result[resultOffset++] = this.readCorner4(numRows, numColumns) & 0xff;\n row -= 2;\n column += 2;\n corner4Read = true;\n }\n else {\n // Sweep upward diagonally to the right\n do {\n if ((row < numRows) && (column >= 0) && !this.readMappingMatrix.get(column, row)) {\n result[resultOffset++] = this.readUtah(row, column, numRows, numColumns) & 0xff;\n }\n row -= 2;\n column += 2;\n } while ((row >= 0) && (column < numColumns));\n row += 1;\n column += 3;\n // Sweep downward diagonally to the left\n do {\n if ((row >= 0) && (column < numColumns) && !this.readMappingMatrix.get(column, row)) {\n result[resultOffset++] = this.readUtah(row, column, numRows, numColumns) & 0xff;\n }\n row += 2;\n column -= 2;\n } while ((row < numRows) && (column >= 0));\n row += 3;\n column += 1;\n }\n } while ((row < numRows) || (column < numColumns));\n if (resultOffset !== this.version.getTotalCodewords()) {\n throw new FormatException();\n }\n return result;\n }\n /**\n *

Reads a bit of the mapping matrix accounting for boundary wrapping.

\n *\n * @param row Row to read in the mapping matrix\n * @param column Column to read in the mapping matrix\n * @param numRows Number of rows in the mapping matrix\n * @param numColumns Number of columns in the mapping matrix\n * @return value of the given bit in the mapping matrix\n */\n readModule(row, column, numRows, numColumns) {\n // Adjust the row and column indices based on boundary wrapping\n if (row < 0) {\n row += numRows;\n column += 4 - ((numRows + 4) & 0x07);\n }\n if (column < 0) {\n column += numColumns;\n row += 4 - ((numColumns + 4) & 0x07);\n }\n this.readMappingMatrix.set(column, row);\n return this.mappingBitMatrix.get(column, row);\n }\n /**\n *

Reads the 8 bits of the standard Utah-shaped pattern.

\n *\n *

See ISO 16022:2006, 5.8.1 Figure 6

\n *\n * @param row Current row in the mapping matrix, anchored at the 8th bit (LSB) of the pattern\n * @param column Current column in the mapping matrix, anchored at the 8th bit (LSB) of the pattern\n * @param numRows Number of rows in the mapping matrix\n * @param numColumns Number of columns in the mapping matrix\n * @return byte from the utah shape\n */\n readUtah(row, column, numRows, numColumns) {\n let currentByte = 0;\n if (this.readModule(row - 2, column - 2, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(row - 2, column - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(row - 1, column - 2, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(row - 1, column - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(row - 1, column, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(row, column - 2, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(row, column - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(row, column, numRows, numColumns)) {\n currentByte |= 1;\n }\n return currentByte;\n }\n /**\n *

Reads the 8 bits of the special corner condition 1.

\n *\n *

See ISO 16022:2006, Figure F.3

\n *\n * @param numRows Number of rows in the mapping matrix\n * @param numColumns Number of columns in the mapping matrix\n * @return byte from the Corner condition 1\n */\n readCorner1(numRows, numColumns) {\n let currentByte = 0;\n if (this.readModule(numRows - 1, 0, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(numRows - 1, 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(numRows - 1, 2, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(0, numColumns - 2, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(0, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(1, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(2, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(3, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n return currentByte;\n }\n /**\n *

Reads the 8 bits of the special corner condition 2.

\n *\n *

See ISO 16022:2006, Figure F.4

\n *\n * @param numRows Number of rows in the mapping matrix\n * @param numColumns Number of columns in the mapping matrix\n * @return byte from the Corner condition 2\n */\n readCorner2(numRows, numColumns) {\n let currentByte = 0;\n if (this.readModule(numRows - 3, 0, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(numRows - 2, 0, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(numRows - 1, 0, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(0, numColumns - 4, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(0, numColumns - 3, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(0, numColumns - 2, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(0, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(1, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n return currentByte;\n }\n /**\n *

Reads the 8 bits of the special corner condition 3.

\n *\n *

See ISO 16022:2006, Figure F.5

\n *\n * @param numRows Number of rows in the mapping matrix\n * @param numColumns Number of columns in the mapping matrix\n * @return byte from the Corner condition 3\n */\n readCorner3(numRows, numColumns) {\n let currentByte = 0;\n if (this.readModule(numRows - 1, 0, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(numRows - 1, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(0, numColumns - 3, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(0, numColumns - 2, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(0, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(1, numColumns - 3, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(1, numColumns - 2, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(1, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n return currentByte;\n }\n /**\n *

Reads the 8 bits of the special corner condition 4.

\n *\n *

See ISO 16022:2006, Figure F.6

\n *\n * @param numRows Number of rows in the mapping matrix\n * @param numColumns Number of columns in the mapping matrix\n * @return byte from the Corner condition 4\n */\n readCorner4(numRows, numColumns) {\n let currentByte = 0;\n if (this.readModule(numRows - 3, 0, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(numRows - 2, 0, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(numRows - 1, 0, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(0, numColumns - 2, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(0, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(1, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(2, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n currentByte <<= 1;\n if (this.readModule(3, numColumns - 1, numRows, numColumns)) {\n currentByte |= 1;\n }\n return currentByte;\n }\n /**\n *

Extracts the data region from a {@link BitMatrix} that contains\n * alignment patterns.

\n *\n * @param bitMatrix Original {@link BitMatrix} with alignment patterns\n * @return BitMatrix that has the alignment patterns removed\n */\n extractDataRegion(bitMatrix) {\n const symbolSizeRows = this.version.getSymbolSizeRows();\n const symbolSizeColumns = this.version.getSymbolSizeColumns();\n if (bitMatrix.getHeight() !== symbolSizeRows) {\n throw new IllegalArgumentException('Dimension of bitMatrix must match the version size');\n }\n const dataRegionSizeRows = this.version.getDataRegionSizeRows();\n const dataRegionSizeColumns = this.version.getDataRegionSizeColumns();\n const numDataRegionsRow = symbolSizeRows / dataRegionSizeRows | 0;\n const numDataRegionsColumn = symbolSizeColumns / dataRegionSizeColumns | 0;\n const sizeDataRegionRow = numDataRegionsRow * dataRegionSizeRows;\n const sizeDataRegionColumn = numDataRegionsColumn * dataRegionSizeColumns;\n const bitMatrixWithoutAlignment = new BitMatrix(sizeDataRegionColumn, sizeDataRegionRow);\n for (let dataRegionRow = 0; dataRegionRow < numDataRegionsRow; ++dataRegionRow) {\n const dataRegionRowOffset = dataRegionRow * dataRegionSizeRows;\n for (let dataRegionColumn = 0; dataRegionColumn < numDataRegionsColumn; ++dataRegionColumn) {\n const dataRegionColumnOffset = dataRegionColumn * dataRegionSizeColumns;\n for (let i = 0; i < dataRegionSizeRows; ++i) {\n const readRowOffset = dataRegionRow * (dataRegionSizeRows + 2) + 1 + i;\n const writeRowOffset = dataRegionRowOffset + i;\n for (let j = 0; j < dataRegionSizeColumns; ++j) {\n const readColumnOffset = dataRegionColumn * (dataRegionSizeColumns + 2) + 1 + j;\n if (bitMatrix.get(readColumnOffset, readRowOffset)) {\n const writeColumnOffset = dataRegionColumnOffset + j;\n bitMatrixWithoutAlignment.set(writeColumnOffset, writeRowOffset);\n }\n }\n }\n }\n }\n return bitMatrixWithoutAlignment;\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates a block of data within a Data Matrix Code. Data Matrix Codes may split their data into\n * multiple blocks, each of which is a unit of data and error-correction codewords. Each\n * is represented by an instance of this class.

\n *\n * @author bbrown@google.com (Brian Brown)\n */\n class DataBlock {\n constructor(numDataCodewords, codewords) {\n this.numDataCodewords = numDataCodewords;\n this.codewords = codewords;\n }\n /**\n *

When Data Matrix Codes use multiple data blocks, they actually interleave the bytes of each of them.\n * That is, the first byte of data block 1 to n is written, then the second bytes, and so on. This\n * method will separate the data into original blocks.

\n *\n * @param rawCodewords bytes as read directly from the Data Matrix Code\n * @param version version of the Data Matrix Code\n * @return DataBlocks containing original bytes, \"de-interleaved\" from representation in the\n * Data Matrix Code\n */\n static getDataBlocks(rawCodewords, version) {\n // Figure out the number and size of data blocks used by this version\n const ecBlocks = version.getECBlocks();\n // First count the total number of data blocks\n let totalBlocks = 0;\n const ecBlockArray = ecBlocks.getECBlocks();\n for (let ecBlock of ecBlockArray) {\n totalBlocks += ecBlock.getCount();\n }\n // Now establish DataBlocks of the appropriate size and number of data codewords\n const result = new Array(totalBlocks);\n let numResultBlocks = 0;\n for (let ecBlock of ecBlockArray) {\n for (let i = 0; i < ecBlock.getCount(); i++) {\n const numDataCodewords = ecBlock.getDataCodewords();\n const numBlockCodewords = ecBlocks.getECCodewords() + numDataCodewords;\n result[numResultBlocks++] = new DataBlock(numDataCodewords, new Uint8Array(numBlockCodewords));\n }\n }\n // All blocks have the same amount of data, except that the last n\n // (where n may be 0) have 1 less byte. Figure out where these start.\n // TODO(bbrown): There is only one case where there is a difference for Data Matrix for size 144\n const longerBlocksTotalCodewords = result[0].codewords.length;\n // int shorterBlocksTotalCodewords = longerBlocksTotalCodewords - 1;\n const longerBlocksNumDataCodewords = longerBlocksTotalCodewords - ecBlocks.getECCodewords();\n const shorterBlocksNumDataCodewords = longerBlocksNumDataCodewords - 1;\n // The last elements of result may be 1 element shorter for 144 matrix\n // first fill out as many elements as all of them have minus 1\n let rawCodewordsOffset = 0;\n for (let i = 0; i < shorterBlocksNumDataCodewords; i++) {\n for (let j = 0; j < numResultBlocks; j++) {\n result[j].codewords[i] = rawCodewords[rawCodewordsOffset++];\n }\n }\n // Fill out the last data block in the longer ones\n const specialVersion = version.getVersionNumber() === 24;\n const numLongerBlocks = specialVersion ? 8 : numResultBlocks;\n for (let j = 0; j < numLongerBlocks; j++) {\n result[j].codewords[longerBlocksNumDataCodewords - 1] = rawCodewords[rawCodewordsOffset++];\n }\n // Now add in error correction blocks\n const max = result[0].codewords.length;\n for (let i = longerBlocksNumDataCodewords; i < max; i++) {\n for (let j = 0; j < numResultBlocks; j++) {\n const jOffset = specialVersion ? (j + 8) % numResultBlocks : j;\n const iOffset = specialVersion && jOffset > 7 ? i - 1 : i;\n result[jOffset].codewords[iOffset] = rawCodewords[rawCodewordsOffset++];\n }\n }\n if (rawCodewordsOffset !== rawCodewords.length) {\n throw new IllegalArgumentException();\n }\n return result;\n }\n getNumDataCodewords() {\n return this.numDataCodewords;\n }\n getCodewords() {\n return this.codewords;\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

This provides an easy abstraction to read bits at a time from a sequence of bytes, where the\n * number of bits read is not often a multiple of 8.

\n *\n *

This class is thread-safe but not reentrant -- unless the caller modifies the bytes array\n * it passed in, in which case all bets are off.

\n *\n * @author Sean Owen\n */\n class BitSource {\n /**\n * @param bytes bytes from which this will read bits. Bits will be read from the first byte first.\n * Bits are read within a byte from most-significant to least-significant bit.\n */\n constructor(bytes) {\n this.bytes = bytes;\n this.byteOffset = 0;\n this.bitOffset = 0;\n }\n /**\n * @return index of next bit in current byte which would be read by the next call to {@link #readBits(int)}.\n */\n getBitOffset() {\n return this.bitOffset;\n }\n /**\n * @return index of next byte in input byte array which would be read by the next call to {@link #readBits(int)}.\n */\n getByteOffset() {\n return this.byteOffset;\n }\n /**\n * @param numBits number of bits to read\n * @return int representing the bits read. The bits will appear as the least-significant\n * bits of the int\n * @throws IllegalArgumentException if numBits isn't in [1,32] or more than is available\n */\n readBits(numBits /*int*/) {\n if (numBits < 1 || numBits > 32 || numBits > this.available()) {\n throw new IllegalArgumentException('' + numBits);\n }\n let result = 0;\n let bitOffset = this.bitOffset;\n let byteOffset = this.byteOffset;\n const bytes = this.bytes;\n // First, read remainder from current byte\n if (bitOffset > 0) {\n const bitsLeft = 8 - bitOffset;\n const toRead = numBits < bitsLeft ? numBits : bitsLeft;\n const bitsToNotRead = bitsLeft - toRead;\n const mask = (0xFF >> (8 - toRead)) << bitsToNotRead;\n result = (bytes[byteOffset] & mask) >> bitsToNotRead;\n numBits -= toRead;\n bitOffset += toRead;\n if (bitOffset === 8) {\n bitOffset = 0;\n byteOffset++;\n }\n }\n // Next read whole bytes\n if (numBits > 0) {\n while (numBits >= 8) {\n result = (result << 8) | (bytes[byteOffset] & 0xFF);\n byteOffset++;\n numBits -= 8;\n }\n // Finally read a partial byte\n if (numBits > 0) {\n const bitsToNotRead = 8 - numBits;\n const mask = (0xFF >> bitsToNotRead) << bitsToNotRead;\n result = (result << numBits) | ((bytes[byteOffset] & mask) >> bitsToNotRead);\n bitOffset += numBits;\n }\n }\n this.bitOffset = bitOffset;\n this.byteOffset = byteOffset;\n return result;\n }\n /**\n * @return number of bits that can be read successfully\n */\n available() {\n return 8 * (this.bytes.length - this.byteOffset) - this.bitOffset;\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n var Mode;\n (function (Mode) {\n Mode[Mode[\"PAD_ENCODE\"] = 0] = \"PAD_ENCODE\";\n Mode[Mode[\"ASCII_ENCODE\"] = 1] = \"ASCII_ENCODE\";\n Mode[Mode[\"C40_ENCODE\"] = 2] = \"C40_ENCODE\";\n Mode[Mode[\"TEXT_ENCODE\"] = 3] = \"TEXT_ENCODE\";\n Mode[Mode[\"ANSIX12_ENCODE\"] = 4] = \"ANSIX12_ENCODE\";\n Mode[Mode[\"EDIFACT_ENCODE\"] = 5] = \"EDIFACT_ENCODE\";\n Mode[Mode[\"BASE256_ENCODE\"] = 6] = \"BASE256_ENCODE\";\n })(Mode || (Mode = {}));\n /**\n *

Data Matrix Codes can encode text as bits in one of several modes, and can use multiple modes\n * in one Data Matrix Code. This class decodes the bits back into text.

\n *\n *

See ISO 16022:2006, 5.2.1 - 5.2.9.2

\n *\n * @author bbrown@google.com (Brian Brown)\n * @author Sean Owen\n */\n class DecodedBitStreamParser {\n static decode(bytes) {\n const bits = new BitSource(bytes);\n const result = new StringBuilder();\n const resultTrailer = new StringBuilder();\n const byteSegments = new Array();\n let mode = Mode.ASCII_ENCODE;\n do {\n if (mode === Mode.ASCII_ENCODE) {\n mode = this.decodeAsciiSegment(bits, result, resultTrailer);\n }\n else {\n switch (mode) {\n case Mode.C40_ENCODE:\n this.decodeC40Segment(bits, result);\n break;\n case Mode.TEXT_ENCODE:\n this.decodeTextSegment(bits, result);\n break;\n case Mode.ANSIX12_ENCODE:\n this.decodeAnsiX12Segment(bits, result);\n break;\n case Mode.EDIFACT_ENCODE:\n this.decodeEdifactSegment(bits, result);\n break;\n case Mode.BASE256_ENCODE:\n this.decodeBase256Segment(bits, result, byteSegments);\n break;\n default:\n throw new FormatException();\n }\n mode = Mode.ASCII_ENCODE;\n }\n } while (mode !== Mode.PAD_ENCODE && bits.available() > 0);\n if (resultTrailer.length() > 0) {\n result.append(resultTrailer.toString());\n }\n return new DecoderResult(bytes, result.toString(), byteSegments.length === 0 ? null : byteSegments, null);\n }\n /**\n * See ISO 16022:2006, 5.2.3 and Annex C, Table C.2\n */\n static decodeAsciiSegment(bits, result, resultTrailer) {\n let upperShift = false;\n do {\n let oneByte = bits.readBits(8);\n if (oneByte === 0) {\n throw new FormatException();\n }\n else if (oneByte <= 128) { // ASCII data (ASCII value + 1)\n if (upperShift) {\n oneByte += 128;\n // upperShift = false;\n }\n result.append(String.fromCharCode(oneByte - 1));\n return Mode.ASCII_ENCODE;\n }\n else if (oneByte === 129) { // Pad\n return Mode.PAD_ENCODE;\n }\n else if (oneByte <= 229) { // 2-digit data 00-99 (Numeric Value + 130)\n const value = oneByte - 130;\n if (value < 10) { // pad with '0' for single digit values\n result.append('0');\n }\n result.append('' + value);\n }\n else {\n switch (oneByte) {\n case 230: // Latch to C40 encodation\n return Mode.C40_ENCODE;\n case 231: // Latch to Base 256 encodation\n return Mode.BASE256_ENCODE;\n case 232: // FNC1\n result.append(String.fromCharCode(29)); // translate as ASCII 29\n break;\n case 233: // Structured Append\n case 234: // Reader Programming\n // Ignore these symbols for now\n // throw ReaderException.getInstance();\n break;\n case 235: // Upper Shift (shift to Extended ASCII)\n upperShift = true;\n break;\n case 236: // 05 Macro\n result.append('[)>\\u001E05\\u001D');\n resultTrailer.insert(0, '\\u001E\\u0004');\n break;\n case 237: // 06 Macro\n result.append('[)>\\u001E06\\u001D');\n resultTrailer.insert(0, '\\u001E\\u0004');\n break;\n case 238: // Latch to ANSI X12 encodation\n return Mode.ANSIX12_ENCODE;\n case 239: // Latch to Text encodation\n return Mode.TEXT_ENCODE;\n case 240: // Latch to EDIFACT encodation\n return Mode.EDIFACT_ENCODE;\n case 241: // ECI Character\n // TODO(bbrown): I think we need to support ECI\n // throw ReaderException.getInstance();\n // Ignore this symbol for now\n break;\n default:\n // Not to be used in ASCII encodation\n // but work around encoders that end with 254, latch back to ASCII\n if (oneByte !== 254 || bits.available() !== 0) {\n throw new FormatException();\n }\n break;\n }\n }\n } while (bits.available() > 0);\n return Mode.ASCII_ENCODE;\n }\n /**\n * See ISO 16022:2006, 5.2.5 and Annex C, Table C.1\n */\n static decodeC40Segment(bits, result) {\n // Three C40 values are encoded in a 16-bit value as\n // (1600 * C1) + (40 * C2) + C3 + 1\n // TODO(bbrown): The Upper Shift with C40 doesn't work in the 4 value scenario all the time\n let upperShift = false;\n const cValues = [];\n let shift = 0;\n do {\n // If there is only one byte left then it will be encoded as ASCII\n if (bits.available() === 8) {\n return;\n }\n const firstByte = bits.readBits(8);\n if (firstByte === 254) { // Unlatch codeword\n return;\n }\n this.parseTwoBytes(firstByte, bits.readBits(8), cValues);\n for (let i = 0; i < 3; i++) {\n const cValue = cValues[i];\n switch (shift) {\n case 0:\n if (cValue < 3) {\n shift = cValue + 1;\n }\n else if (cValue < this.C40_BASIC_SET_CHARS.length) {\n const c40char = this.C40_BASIC_SET_CHARS[cValue];\n if (upperShift) {\n result.append(String.fromCharCode(c40char.charCodeAt(0) + 128));\n upperShift = false;\n }\n else {\n result.append(c40char);\n }\n }\n else {\n throw new FormatException();\n }\n break;\n case 1:\n if (upperShift) {\n result.append(String.fromCharCode(cValue + 128));\n upperShift = false;\n }\n else {\n result.append(String.fromCharCode(cValue));\n }\n shift = 0;\n break;\n case 2:\n if (cValue < this.C40_SHIFT2_SET_CHARS.length) {\n const c40char = this.C40_SHIFT2_SET_CHARS[cValue];\n if (upperShift) {\n result.append(String.fromCharCode(c40char.charCodeAt(0) + 128));\n upperShift = false;\n }\n else {\n result.append(c40char);\n }\n }\n else {\n switch (cValue) {\n case 27: // FNC1\n result.append(String.fromCharCode(29)); // translate as ASCII 29\n break;\n case 30: // Upper Shift\n upperShift = true;\n break;\n default:\n throw new FormatException();\n }\n }\n shift = 0;\n break;\n case 3:\n if (upperShift) {\n result.append(String.fromCharCode(cValue + 224));\n upperShift = false;\n }\n else {\n result.append(String.fromCharCode(cValue + 96));\n }\n shift = 0;\n break;\n default:\n throw new FormatException();\n }\n }\n } while (bits.available() > 0);\n }\n /**\n * See ISO 16022:2006, 5.2.6 and Annex C, Table C.2\n */\n static decodeTextSegment(bits, result) {\n // Three Text values are encoded in a 16-bit value as\n // (1600 * C1) + (40 * C2) + C3 + 1\n // TODO(bbrown): The Upper Shift with Text doesn't work in the 4 value scenario all the time\n let upperShift = false;\n let cValues = [];\n let shift = 0;\n do {\n // If there is only one byte left then it will be encoded as ASCII\n if (bits.available() === 8) {\n return;\n }\n const firstByte = bits.readBits(8);\n if (firstByte === 254) { // Unlatch codeword\n return;\n }\n this.parseTwoBytes(firstByte, bits.readBits(8), cValues);\n for (let i = 0; i < 3; i++) {\n const cValue = cValues[i];\n switch (shift) {\n case 0:\n if (cValue < 3) {\n shift = cValue + 1;\n }\n else if (cValue < this.TEXT_BASIC_SET_CHARS.length) {\n const textChar = this.TEXT_BASIC_SET_CHARS[cValue];\n if (upperShift) {\n result.append(String.fromCharCode(textChar.charCodeAt(0) + 128));\n upperShift = false;\n }\n else {\n result.append(textChar);\n }\n }\n else {\n throw new FormatException();\n }\n break;\n case 1:\n if (upperShift) {\n result.append(String.fromCharCode(cValue + 128));\n upperShift = false;\n }\n else {\n result.append(String.fromCharCode(cValue));\n }\n shift = 0;\n break;\n case 2:\n // Shift 2 for Text is the same encoding as C40\n if (cValue < this.TEXT_SHIFT2_SET_CHARS.length) {\n const textChar = this.TEXT_SHIFT2_SET_CHARS[cValue];\n if (upperShift) {\n result.append(String.fromCharCode(textChar.charCodeAt(0) + 128));\n upperShift = false;\n }\n else {\n result.append(textChar);\n }\n }\n else {\n switch (cValue) {\n case 27: // FNC1\n result.append(String.fromCharCode(29)); // translate as ASCII 29\n break;\n case 30: // Upper Shift\n upperShift = true;\n break;\n default:\n throw new FormatException();\n }\n }\n shift = 0;\n break;\n case 3:\n if (cValue < this.TEXT_SHIFT3_SET_CHARS.length) {\n const textChar = this.TEXT_SHIFT3_SET_CHARS[cValue];\n if (upperShift) {\n result.append(String.fromCharCode(textChar.charCodeAt(0) + 128));\n upperShift = false;\n }\n else {\n result.append(textChar);\n }\n shift = 0;\n }\n else {\n throw new FormatException();\n }\n break;\n default:\n throw new FormatException();\n }\n }\n } while (bits.available() > 0);\n }\n /**\n * See ISO 16022:2006, 5.2.7\n */\n static decodeAnsiX12Segment(bits, result) {\n // Three ANSI X12 values are encoded in a 16-bit value as\n // (1600 * C1) + (40 * C2) + C3 + 1\n const cValues = [];\n do {\n // If there is only one byte left then it will be encoded as ASCII\n if (bits.available() === 8) {\n return;\n }\n const firstByte = bits.readBits(8);\n if (firstByte === 254) { // Unlatch codeword\n return;\n }\n this.parseTwoBytes(firstByte, bits.readBits(8), cValues);\n for (let i = 0; i < 3; i++) {\n const cValue = cValues[i];\n switch (cValue) {\n case 0: // X12 segment terminator \n result.append('\\r');\n break;\n case 1: // X12 segment separator *\n result.append('*');\n break;\n case 2: // X12 sub-element separator >\n result.append('>');\n break;\n case 3: // space\n result.append(' ');\n break;\n default:\n if (cValue < 14) { // 0 - 9\n result.append(String.fromCharCode(cValue + 44));\n }\n else if (cValue < 40) { // A - Z\n result.append(String.fromCharCode(cValue + 51));\n }\n else {\n throw new FormatException();\n }\n break;\n }\n }\n } while (bits.available() > 0);\n }\n static parseTwoBytes(firstByte, secondByte, result) {\n let fullBitValue = (firstByte << 8) + secondByte - 1;\n let temp = Math.floor(fullBitValue / 1600);\n result[0] = temp;\n fullBitValue -= temp * 1600;\n temp = Math.floor(fullBitValue / 40);\n result[1] = temp;\n result[2] = fullBitValue - temp * 40;\n }\n /**\n * See ISO 16022:2006, 5.2.8 and Annex C Table C.3\n */\n static decodeEdifactSegment(bits, result) {\n do {\n // If there is only two or less bytes left then it will be encoded as ASCII\n if (bits.available() <= 16) {\n return;\n }\n for (let i = 0; i < 4; i++) {\n let edifactValue = bits.readBits(6);\n // Check for the unlatch character\n if (edifactValue === 0x1F) { // 011111\n // Read rest of byte, which should be 0, and stop\n const bitsLeft = 8 - bits.getBitOffset();\n if (bitsLeft !== 8) {\n bits.readBits(bitsLeft);\n }\n return;\n }\n if ((edifactValue & 0x20) === 0) { // no 1 in the leading (6th) bit\n edifactValue |= 0x40; // Add a leading 01 to the 6 bit binary value\n }\n result.append(String.fromCharCode(edifactValue));\n }\n } while (bits.available() > 0);\n }\n /**\n * See ISO 16022:2006, 5.2.9 and Annex B, B.2\n */\n static decodeBase256Segment(bits, result, byteSegments) {\n // Figure out how long the Base 256 Segment is.\n let codewordPosition = 1 + bits.getByteOffset(); // position is 1-indexed\n const d1 = this.unrandomize255State(bits.readBits(8), codewordPosition++);\n let count;\n if (d1 === 0) { // Read the remainder of the symbol\n count = bits.available() / 8 | 0;\n }\n else if (d1 < 250) {\n count = d1;\n }\n else {\n count = 250 * (d1 - 249) + this.unrandomize255State(bits.readBits(8), codewordPosition++);\n }\n // We're seeing NegativeArraySizeException errors from users.\n if (count < 0) {\n throw new FormatException();\n }\n const bytes = new Uint8Array(count);\n for (let i = 0; i < count; i++) {\n // Have seen this particular error in the wild, such as at\n // http://www.bcgen.com/demo/IDAutomationStreamingDataMatrix.aspx?MODE=3&D=Fred&PFMT=3&PT=F&X=0.3&O=0&LM=0.2\n if (bits.available() < 8) {\n throw new FormatException();\n }\n bytes[i] = this.unrandomize255State(bits.readBits(8), codewordPosition++);\n }\n byteSegments.push(bytes);\n try {\n result.append(StringEncoding.decode(bytes, StringUtils.ISO88591));\n }\n catch (uee) {\n throw new IllegalStateException('Platform does not support required encoding: ' + uee.message);\n }\n }\n /**\n * See ISO 16022:2006, Annex B, B.2\n */\n static unrandomize255State(randomizedBase256Codeword, base256CodewordPosition) {\n const pseudoRandomNumber = ((149 * base256CodewordPosition) % 255) + 1;\n const tempVariable = randomizedBase256Codeword - pseudoRandomNumber;\n return tempVariable >= 0 ? tempVariable : tempVariable + 256;\n }\n }\n /**\n * See ISO 16022:2006, Annex C Table C.1\n * The C40 Basic Character Set (*'s used for placeholders for the shift values)\n */\n DecodedBitStreamParser.C40_BASIC_SET_CHARS = [\n '*', '*', '*', ' ', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',\n 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',\n 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'\n ];\n DecodedBitStreamParser.C40_SHIFT2_SET_CHARS = [\n '!', '\"', '#', '$', '%', '&', '\\'', '(', ')', '*', '+', ',', '-', '.',\n '/', ':', ';', '<', '=', '>', '?', '@', '[', '\\\\', ']', '^', '_'\n ];\n /**\n * See ISO 16022:2006, Annex C Table C.2\n * The Text Basic Character Set (*'s used for placeholders for the shift values)\n */\n DecodedBitStreamParser.TEXT_BASIC_SET_CHARS = [\n '*', '*', '*', ' ', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',\n 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',\n 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'\n ];\n // Shift 2 for Text is the same encoding as C40\n DecodedBitStreamParser.TEXT_SHIFT2_SET_CHARS = DecodedBitStreamParser.C40_SHIFT2_SET_CHARS;\n DecodedBitStreamParser.TEXT_SHIFT3_SET_CHARS = [\n '`', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',\n 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '{', '|', '}', '~', String.fromCharCode(127)\n ];\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

The main class which implements Data Matrix Code decoding -- as opposed to locating and extracting\n * the Data Matrix Code from an image.

\n *\n * @author bbrown@google.com (Brian Brown)\n */\n class Decoder$1 {\n constructor() {\n this.rsDecoder = new ReedSolomonDecoder(GenericGF.DATA_MATRIX_FIELD_256);\n }\n /**\n *

Decodes a Data Matrix Code represented as a {@link BitMatrix}. A 1 or \"true\" is taken\n * to mean a black module.

\n *\n * @param bits booleans representing white/black Data Matrix Code modules\n * @return text and bytes encoded within the Data Matrix Code\n * @throws FormatException if the Data Matrix Code cannot be decoded\n * @throws ChecksumException if error correction fails\n */\n decode(bits) {\n // Construct a parser and read version, error-correction level\n const parser = new BitMatrixParser(bits);\n const version = parser.getVersion();\n // Read codewords\n const codewords = parser.readCodewords();\n // Separate into data blocks\n const dataBlocks = DataBlock.getDataBlocks(codewords, version);\n // Count total number of data bytes\n let totalBytes = 0;\n for (let db of dataBlocks) {\n totalBytes += db.getNumDataCodewords();\n }\n const resultBytes = new Uint8Array(totalBytes);\n const dataBlocksCount = dataBlocks.length;\n // Error-correct and copy data blocks together into a stream of bytes\n for (let j = 0; j < dataBlocksCount; j++) {\n const dataBlock = dataBlocks[j];\n const codewordBytes = dataBlock.getCodewords();\n const numDataCodewords = dataBlock.getNumDataCodewords();\n this.correctErrors(codewordBytes, numDataCodewords);\n for (let i = 0; i < numDataCodewords; i++) {\n // De-interlace data blocks.\n resultBytes[i * dataBlocksCount + j] = codewordBytes[i];\n }\n }\n // Decode the contents of that stream of bytes\n return DecodedBitStreamParser.decode(resultBytes);\n }\n /**\n *

Given data and error-correction codewords received, possibly corrupted by errors, attempts to\n * correct the errors in-place using Reed-Solomon error correction.

\n *\n * @param codewordBytes data and error correction codewords\n * @param numDataCodewords number of codewords that are data bytes\n * @throws ChecksumException if error correction fails\n */\n correctErrors(codewordBytes, numDataCodewords) {\n // const numCodewords = codewordBytes.length;\n // First read into an array of ints\n const codewordsInts = new Int32Array(codewordBytes);\n // for (let i = 0; i < numCodewords; i++) {\n // codewordsInts[i] = codewordBytes[i] & 0xFF;\n // }\n try {\n this.rsDecoder.decode(codewordsInts, codewordBytes.length - numDataCodewords);\n }\n catch (ignored /* ReedSolomonException */) {\n throw new ChecksumException();\n }\n // Copy back into array of bytes -- only need to worry about the bytes that were data\n // We don't care about errors in the error-correction codewords\n for (let i = 0; i < numDataCodewords; i++) {\n codewordBytes[i] = codewordsInts[i];\n }\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates logic that can detect a Data Matrix Code in an image, even if the Data Matrix Code\n * is rotated or skewed, or partially obscured.

\n *\n * @author Sean Owen\n */\n class Detector$1 {\n constructor(image) {\n this.image = image;\n this.rectangleDetector = new WhiteRectangleDetector(this.image);\n }\n /**\n *

Detects a Data Matrix Code in an image.

\n *\n * @return {@link DetectorResult} encapsulating results of detecting a Data Matrix Code\n * @throws NotFoundException if no Data Matrix Code can be found\n */\n detect() {\n const cornerPoints = this.rectangleDetector.detect();\n let points = this.detectSolid1(cornerPoints);\n points = this.detectSolid2(points);\n points[3] = this.correctTopRight(points);\n if (!points[3]) {\n throw new NotFoundException();\n }\n points = this.shiftToModuleCenter(points);\n const topLeft = points[0];\n const bottomLeft = points[1];\n const bottomRight = points[2];\n const topRight = points[3];\n let dimensionTop = this.transitionsBetween(topLeft, topRight) + 1;\n let dimensionRight = this.transitionsBetween(bottomRight, topRight) + 1;\n if ((dimensionTop & 0x01) === 1) {\n dimensionTop += 1;\n }\n if ((dimensionRight & 0x01) === 1) {\n dimensionRight += 1;\n }\n if (4 * dimensionTop < 7 * dimensionRight && 4 * dimensionRight < 7 * dimensionTop) {\n // The matrix is square\n dimensionTop = dimensionRight = Math.max(dimensionTop, dimensionRight);\n }\n let bits = Detector$1.sampleGrid(this.image, topLeft, bottomLeft, bottomRight, topRight, dimensionTop, dimensionRight);\n return new DetectorResult(bits, [topLeft, bottomLeft, bottomRight, topRight]);\n }\n static shiftPoint(point, to, div) {\n let x = (to.getX() - point.getX()) / (div + 1);\n let y = (to.getY() - point.getY()) / (div + 1);\n return new ResultPoint(point.getX() + x, point.getY() + y);\n }\n static moveAway(point, fromX, fromY) {\n let x = point.getX();\n let y = point.getY();\n if (x < fromX) {\n x -= 1;\n }\n else {\n x += 1;\n }\n if (y < fromY) {\n y -= 1;\n }\n else {\n y += 1;\n }\n return new ResultPoint(x, y);\n }\n /**\n * Detect a solid side which has minimum transition.\n */\n detectSolid1(cornerPoints) {\n // 0 2\n // 1 3\n let pointA = cornerPoints[0];\n let pointB = cornerPoints[1];\n let pointC = cornerPoints[3];\n let pointD = cornerPoints[2];\n let trAB = this.transitionsBetween(pointA, pointB);\n let trBC = this.transitionsBetween(pointB, pointC);\n let trCD = this.transitionsBetween(pointC, pointD);\n let trDA = this.transitionsBetween(pointD, pointA);\n // 0..3\n // : :\n // 1--2\n let min = trAB;\n let points = [pointD, pointA, pointB, pointC];\n if (min > trBC) {\n min = trBC;\n points[0] = pointA;\n points[1] = pointB;\n points[2] = pointC;\n points[3] = pointD;\n }\n if (min > trCD) {\n min = trCD;\n points[0] = pointB;\n points[1] = pointC;\n points[2] = pointD;\n points[3] = pointA;\n }\n if (min > trDA) {\n points[0] = pointC;\n points[1] = pointD;\n points[2] = pointA;\n points[3] = pointB;\n }\n return points;\n }\n /**\n * Detect a second solid side next to first solid side.\n */\n detectSolid2(points) {\n // A..D\n // : :\n // B--C\n let pointA = points[0];\n let pointB = points[1];\n let pointC = points[2];\n let pointD = points[3];\n // Transition detection on the edge is not stable.\n // To safely detect, shift the points to the module center.\n let tr = this.transitionsBetween(pointA, pointD);\n let pointBs = Detector$1.shiftPoint(pointB, pointC, (tr + 1) * 4);\n let pointCs = Detector$1.shiftPoint(pointC, pointB, (tr + 1) * 4);\n let trBA = this.transitionsBetween(pointBs, pointA);\n let trCD = this.transitionsBetween(pointCs, pointD);\n // 0..3\n // | :\n // 1--2\n if (trBA < trCD) {\n // solid sides: A-B-C\n points[0] = pointA;\n points[1] = pointB;\n points[2] = pointC;\n points[3] = pointD;\n }\n else {\n // solid sides: B-C-D\n points[0] = pointB;\n points[1] = pointC;\n points[2] = pointD;\n points[3] = pointA;\n }\n return points;\n }\n /**\n * Calculates the corner position of the white top right module.\n */\n correctTopRight(points) {\n // A..D\n // | :\n // B--C\n let pointA = points[0];\n let pointB = points[1];\n let pointC = points[2];\n let pointD = points[3];\n // shift points for safe transition detection.\n let trTop = this.transitionsBetween(pointA, pointD);\n let trRight = this.transitionsBetween(pointB, pointD);\n let pointAs = Detector$1.shiftPoint(pointA, pointB, (trRight + 1) * 4);\n let pointCs = Detector$1.shiftPoint(pointC, pointB, (trTop + 1) * 4);\n trTop = this.transitionsBetween(pointAs, pointD);\n trRight = this.transitionsBetween(pointCs, pointD);\n let candidate1 = new ResultPoint(pointD.getX() + (pointC.getX() - pointB.getX()) / (trTop + 1), pointD.getY() + (pointC.getY() - pointB.getY()) / (trTop + 1));\n let candidate2 = new ResultPoint(pointD.getX() + (pointA.getX() - pointB.getX()) / (trRight + 1), pointD.getY() + (pointA.getY() - pointB.getY()) / (trRight + 1));\n if (!this.isValid(candidate1)) {\n if (this.isValid(candidate2)) {\n return candidate2;\n }\n return null;\n }\n if (!this.isValid(candidate2)) {\n return candidate1;\n }\n let sumc1 = this.transitionsBetween(pointAs, candidate1) + this.transitionsBetween(pointCs, candidate1);\n let sumc2 = this.transitionsBetween(pointAs, candidate2) + this.transitionsBetween(pointCs, candidate2);\n if (sumc1 > sumc2) {\n return candidate1;\n }\n else {\n return candidate2;\n }\n }\n /**\n * Shift the edge points to the module center.\n */\n shiftToModuleCenter(points) {\n // A..D\n // | :\n // B--C\n let pointA = points[0];\n let pointB = points[1];\n let pointC = points[2];\n let pointD = points[3];\n // calculate pseudo dimensions\n let dimH = this.transitionsBetween(pointA, pointD) + 1;\n let dimV = this.transitionsBetween(pointC, pointD) + 1;\n // shift points for safe dimension detection\n let pointAs = Detector$1.shiftPoint(pointA, pointB, dimV * 4);\n let pointCs = Detector$1.shiftPoint(pointC, pointB, dimH * 4);\n // calculate more precise dimensions\n dimH = this.transitionsBetween(pointAs, pointD) + 1;\n dimV = this.transitionsBetween(pointCs, pointD) + 1;\n if ((dimH & 0x01) === 1) {\n dimH += 1;\n }\n if ((dimV & 0x01) === 1) {\n dimV += 1;\n }\n // WhiteRectangleDetector returns points inside of the rectangle.\n // I want points on the edges.\n let centerX = (pointA.getX() + pointB.getX() + pointC.getX() + pointD.getX()) / 4;\n let centerY = (pointA.getY() + pointB.getY() + pointC.getY() + pointD.getY()) / 4;\n pointA = Detector$1.moveAway(pointA, centerX, centerY);\n pointB = Detector$1.moveAway(pointB, centerX, centerY);\n pointC = Detector$1.moveAway(pointC, centerX, centerY);\n pointD = Detector$1.moveAway(pointD, centerX, centerY);\n let pointBs;\n let pointDs;\n // shift points to the center of each modules\n pointAs = Detector$1.shiftPoint(pointA, pointB, dimV * 4);\n pointAs = Detector$1.shiftPoint(pointAs, pointD, dimH * 4);\n pointBs = Detector$1.shiftPoint(pointB, pointA, dimV * 4);\n pointBs = Detector$1.shiftPoint(pointBs, pointC, dimH * 4);\n pointCs = Detector$1.shiftPoint(pointC, pointD, dimV * 4);\n pointCs = Detector$1.shiftPoint(pointCs, pointB, dimH * 4);\n pointDs = Detector$1.shiftPoint(pointD, pointC, dimV * 4);\n pointDs = Detector$1.shiftPoint(pointDs, pointA, dimH * 4);\n return [pointAs, pointBs, pointCs, pointDs];\n }\n isValid(p) {\n return p.getX() >= 0 && p.getX() < this.image.getWidth() && p.getY() > 0 && p.getY() < this.image.getHeight();\n }\n static sampleGrid(image, topLeft, bottomLeft, bottomRight, topRight, dimensionX, dimensionY) {\n const sampler = GridSamplerInstance.getInstance();\n return sampler.sampleGrid(image, dimensionX, dimensionY, 0.5, 0.5, dimensionX - 0.5, 0.5, dimensionX - 0.5, dimensionY - 0.5, 0.5, dimensionY - 0.5, topLeft.getX(), topLeft.getY(), topRight.getX(), topRight.getY(), bottomRight.getX(), bottomRight.getY(), bottomLeft.getX(), bottomLeft.getY());\n }\n /**\n * Counts the number of black/white transitions between two points, using something like Bresenham's algorithm.\n */\n transitionsBetween(from, to) {\n // See QR Code Detector, sizeOfBlackWhiteBlackRun()\n let fromX = Math.trunc(from.getX());\n let fromY = Math.trunc(from.getY());\n let toX = Math.trunc(to.getX());\n let toY = Math.trunc(to.getY());\n let steep = Math.abs(toY - fromY) > Math.abs(toX - fromX);\n if (steep) {\n let temp = fromX;\n fromX = fromY;\n fromY = temp;\n temp = toX;\n toX = toY;\n toY = temp;\n }\n let dx = Math.abs(toX - fromX);\n let dy = Math.abs(toY - fromY);\n let error = -dx / 2;\n let ystep = fromY < toY ? 1 : -1;\n let xstep = fromX < toX ? 1 : -1;\n let transitions = 0;\n let inBlack = this.image.get(steep ? fromY : fromX, steep ? fromX : fromY);\n for (let x = fromX, y = fromY; x !== toX; x += xstep) {\n let isBlack = this.image.get(steep ? y : x, steep ? x : y);\n if (isBlack !== inBlack) {\n transitions++;\n inBlack = isBlack;\n }\n error += dy;\n if (error > 0) {\n if (y === toY) {\n break;\n }\n y += ystep;\n error -= dx;\n }\n }\n return transitions;\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * This implementation can detect and decode Data Matrix codes in an image.\n *\n * @author bbrown@google.com (Brian Brown)\n */\n class DataMatrixReader {\n constructor() {\n this.decoder = new Decoder$1();\n }\n /**\n * Locates and decodes a Data Matrix code in an image.\n *\n * @return a String representing the content encoded by the Data Matrix code\n * @throws NotFoundException if a Data Matrix code cannot be found\n * @throws FormatException if a Data Matrix code cannot be decoded\n * @throws ChecksumException if error correction fails\n */\n // @Override\n // public Result decode(BinaryBitmap image) throws NotFoundException, ChecksumException, FormatException {\n // return decode(image, null);\n // }\n // @Override\n decode(image, hints = null) {\n let decoderResult;\n let points;\n if (hints != null && hints.has(DecodeHintType$1.PURE_BARCODE)) {\n const bits = DataMatrixReader.extractPureBits(image.getBlackMatrix());\n decoderResult = this.decoder.decode(bits);\n points = DataMatrixReader.NO_POINTS;\n }\n else {\n const detectorResult = new Detector$1(image.getBlackMatrix()).detect();\n decoderResult = this.decoder.decode(detectorResult.getBits());\n points = detectorResult.getPoints();\n }\n const rawBytes = decoderResult.getRawBytes();\n const result = new Result(decoderResult.getText(), rawBytes, 8 * rawBytes.length, points, BarcodeFormat$1.DATA_MATRIX, System.currentTimeMillis());\n const byteSegments = decoderResult.getByteSegments();\n if (byteSegments != null) {\n result.putMetadata(ResultMetadataType$1.BYTE_SEGMENTS, byteSegments);\n }\n const ecLevel = decoderResult.getECLevel();\n if (ecLevel != null) {\n result.putMetadata(ResultMetadataType$1.ERROR_CORRECTION_LEVEL, ecLevel);\n }\n return result;\n }\n // @Override\n reset() {\n // do nothing\n }\n /**\n * This method detects a code in a \"pure\" image -- that is, pure monochrome image\n * which contains only an unrotated, unskewed, image of a code, with some white border\n * around it. This is a specialized method that works exceptionally fast in this special\n * case.\n *\n * @see com.google.zxing.qrcode.QRCodeReader#extractPureBits(BitMatrix)\n */\n static extractPureBits(image) {\n const leftTopBlack = image.getTopLeftOnBit();\n const rightBottomBlack = image.getBottomRightOnBit();\n if (leftTopBlack == null || rightBottomBlack == null) {\n throw new NotFoundException();\n }\n const moduleSize = this.moduleSize(leftTopBlack, image);\n let top = leftTopBlack[1];\n const bottom = rightBottomBlack[1];\n let left = leftTopBlack[0];\n const right = rightBottomBlack[0];\n const matrixWidth = (right - left + 1) / moduleSize;\n const matrixHeight = (bottom - top + 1) / moduleSize;\n if (matrixWidth <= 0 || matrixHeight <= 0) {\n throw new NotFoundException();\n }\n // Push in the \"border\" by half the module width so that we start\n // sampling in the middle of the module. Just in case the image is a\n // little off, this will help recover.\n const nudge = moduleSize / 2;\n top += nudge;\n left += nudge;\n // Now just read off the bits\n const bits = new BitMatrix(matrixWidth, matrixHeight);\n for (let y = 0; y < matrixHeight; y++) {\n const iOffset = top + y * moduleSize;\n for (let x = 0; x < matrixWidth; x++) {\n if (image.get(left + x * moduleSize, iOffset)) {\n bits.set(x, y);\n }\n }\n }\n return bits;\n }\n static moduleSize(leftTopBlack, image) {\n const width = image.getWidth();\n let x = leftTopBlack[0];\n const y = leftTopBlack[1];\n while (x < width && image.get(x, y)) {\n x++;\n }\n if (x === width) {\n throw new NotFoundException();\n }\n const moduleSize = x - leftTopBlack[0];\n if (moduleSize === 0) {\n throw new NotFoundException();\n }\n return moduleSize;\n }\n }\n DataMatrixReader.NO_POINTS = [];\n\n /**\n * @deprecated Moving to @zxing/browser\n *\n * QR Code reader to use from browser.\n */\n class BrowserDatamatrixCodeReader extends BrowserCodeReader {\n /**\n * Creates an instance of BrowserQRCodeReader.\n * @param {number} [timeBetweenScansMillis=500] the time delay between subsequent decode tries\n */\n constructor(timeBetweenScansMillis = 500) {\n super(new DataMatrixReader(), timeBetweenScansMillis);\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n var ErrorCorrectionLevelValues;\n (function (ErrorCorrectionLevelValues) {\n ErrorCorrectionLevelValues[ErrorCorrectionLevelValues[\"L\"] = 0] = \"L\";\n ErrorCorrectionLevelValues[ErrorCorrectionLevelValues[\"M\"] = 1] = \"M\";\n ErrorCorrectionLevelValues[ErrorCorrectionLevelValues[\"Q\"] = 2] = \"Q\";\n ErrorCorrectionLevelValues[ErrorCorrectionLevelValues[\"H\"] = 3] = \"H\";\n })(ErrorCorrectionLevelValues || (ErrorCorrectionLevelValues = {}));\n /**\n *

See ISO 18004:2006, 6.5.1. This enum encapsulates the four error correction levels\n * defined by the QR code standard.

\n *\n * @author Sean Owen\n */\n class ErrorCorrectionLevel {\n constructor(value, stringValue, bits /*int*/) {\n this.value = value;\n this.stringValue = stringValue;\n this.bits = bits;\n ErrorCorrectionLevel.FOR_BITS.set(bits, this);\n ErrorCorrectionLevel.FOR_VALUE.set(value, this);\n }\n getValue() {\n return this.value;\n }\n getBits() {\n return this.bits;\n }\n static fromString(s) {\n switch (s) {\n case 'L': return ErrorCorrectionLevel.L;\n case 'M': return ErrorCorrectionLevel.M;\n case 'Q': return ErrorCorrectionLevel.Q;\n case 'H': return ErrorCorrectionLevel.H;\n default: throw new ArgumentException(s + 'not available');\n }\n }\n toString() {\n return this.stringValue;\n }\n equals(o) {\n if (!(o instanceof ErrorCorrectionLevel)) {\n return false;\n }\n const other = o;\n return this.value === other.value;\n }\n /**\n * @param bits int containing the two bits encoding a QR Code's error correction level\n * @return ErrorCorrectionLevel representing the encoded error correction level\n */\n static forBits(bits /*int*/) {\n if (bits < 0 || bits >= ErrorCorrectionLevel.FOR_BITS.size) {\n throw new IllegalArgumentException();\n }\n return ErrorCorrectionLevel.FOR_BITS.get(bits);\n }\n }\n ErrorCorrectionLevel.FOR_BITS = new Map();\n ErrorCorrectionLevel.FOR_VALUE = new Map();\n /** L = ~7% correction */\n ErrorCorrectionLevel.L = new ErrorCorrectionLevel(ErrorCorrectionLevelValues.L, 'L', 0x01);\n /** M = ~15% correction */\n ErrorCorrectionLevel.M = new ErrorCorrectionLevel(ErrorCorrectionLevelValues.M, 'M', 0x00);\n /** Q = ~25% correction */\n ErrorCorrectionLevel.Q = new ErrorCorrectionLevel(ErrorCorrectionLevelValues.Q, 'Q', 0x03);\n /** H = ~30% correction */\n ErrorCorrectionLevel.H = new ErrorCorrectionLevel(ErrorCorrectionLevelValues.H, 'H', 0x02);\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates a QR Code's format information, including the data mask used and\n * error correction level.

\n *\n * @author Sean Owen\n * @see DataMask\n * @see ErrorCorrectionLevel\n */\n class FormatInformation {\n constructor(formatInfo /*int*/) {\n // Bits 3,4\n this.errorCorrectionLevel = ErrorCorrectionLevel.forBits((formatInfo >> 3) & 0x03);\n // Bottom 3 bits\n this.dataMask = /*(byte) */ (formatInfo & 0x07);\n }\n static numBitsDiffering(a /*int*/, b /*int*/) {\n return Integer.bitCount(a ^ b);\n }\n /**\n * @param maskedFormatInfo1 format info indicator, with mask still applied\n * @param maskedFormatInfo2 second copy of same info; both are checked at the same time\n * to establish best match\n * @return information about the format it specifies, or {@code null}\n * if doesn't seem to match any known pattern\n */\n static decodeFormatInformation(maskedFormatInfo1 /*int*/, maskedFormatInfo2 /*int*/) {\n const formatInfo = FormatInformation.doDecodeFormatInformation(maskedFormatInfo1, maskedFormatInfo2);\n if (formatInfo !== null) {\n return formatInfo;\n }\n // Should return null, but, some QR codes apparently\n // do not mask this info. Try again by actually masking the pattern\n // first\n return FormatInformation.doDecodeFormatInformation(maskedFormatInfo1 ^ FormatInformation.FORMAT_INFO_MASK_QR, maskedFormatInfo2 ^ FormatInformation.FORMAT_INFO_MASK_QR);\n }\n static doDecodeFormatInformation(maskedFormatInfo1 /*int*/, maskedFormatInfo2 /*int*/) {\n // Find the int in FORMAT_INFO_DECODE_LOOKUP with fewest bits differing\n let bestDifference = Number.MAX_SAFE_INTEGER;\n let bestFormatInfo = 0;\n for (const decodeInfo of FormatInformation.FORMAT_INFO_DECODE_LOOKUP) {\n const targetInfo = decodeInfo[0];\n if (targetInfo === maskedFormatInfo1 || targetInfo === maskedFormatInfo2) {\n // Found an exact match\n return new FormatInformation(decodeInfo[1]);\n }\n let bitsDifference = FormatInformation.numBitsDiffering(maskedFormatInfo1, targetInfo);\n if (bitsDifference < bestDifference) {\n bestFormatInfo = decodeInfo[1];\n bestDifference = bitsDifference;\n }\n if (maskedFormatInfo1 !== maskedFormatInfo2) {\n // also try the other option\n bitsDifference = FormatInformation.numBitsDiffering(maskedFormatInfo2, targetInfo);\n if (bitsDifference < bestDifference) {\n bestFormatInfo = decodeInfo[1];\n bestDifference = bitsDifference;\n }\n }\n }\n // Hamming distance of the 32 masked codes is 7, by construction, so <= 3 bits\n // differing means we found a match\n if (bestDifference <= 3) {\n return new FormatInformation(bestFormatInfo);\n }\n return null;\n }\n getErrorCorrectionLevel() {\n return this.errorCorrectionLevel;\n }\n getDataMask() {\n return this.dataMask;\n }\n /*@Override*/\n hashCode() {\n return (this.errorCorrectionLevel.getBits() << 3) | this.dataMask;\n }\n /*@Override*/\n equals(o) {\n if (!(o instanceof FormatInformation)) {\n return false;\n }\n const other = o;\n return this.errorCorrectionLevel === other.errorCorrectionLevel &&\n this.dataMask === other.dataMask;\n }\n }\n FormatInformation.FORMAT_INFO_MASK_QR = 0x5412;\n /**\n * See ISO 18004:2006, Annex C, Table C.1\n */\n FormatInformation.FORMAT_INFO_DECODE_LOOKUP = [\n Int32Array.from([0x5412, 0x00]),\n Int32Array.from([0x5125, 0x01]),\n Int32Array.from([0x5E7C, 0x02]),\n Int32Array.from([0x5B4B, 0x03]),\n Int32Array.from([0x45F9, 0x04]),\n Int32Array.from([0x40CE, 0x05]),\n Int32Array.from([0x4F97, 0x06]),\n Int32Array.from([0x4AA0, 0x07]),\n Int32Array.from([0x77C4, 0x08]),\n Int32Array.from([0x72F3, 0x09]),\n Int32Array.from([0x7DAA, 0x0A]),\n Int32Array.from([0x789D, 0x0B]),\n Int32Array.from([0x662F, 0x0C]),\n Int32Array.from([0x6318, 0x0D]),\n Int32Array.from([0x6C41, 0x0E]),\n Int32Array.from([0x6976, 0x0F]),\n Int32Array.from([0x1689, 0x10]),\n Int32Array.from([0x13BE, 0x11]),\n Int32Array.from([0x1CE7, 0x12]),\n Int32Array.from([0x19D0, 0x13]),\n Int32Array.from([0x0762, 0x14]),\n Int32Array.from([0x0255, 0x15]),\n Int32Array.from([0x0D0C, 0x16]),\n Int32Array.from([0x083B, 0x17]),\n Int32Array.from([0x355F, 0x18]),\n Int32Array.from([0x3068, 0x19]),\n Int32Array.from([0x3F31, 0x1A]),\n Int32Array.from([0x3A06, 0x1B]),\n Int32Array.from([0x24B4, 0x1C]),\n Int32Array.from([0x2183, 0x1D]),\n Int32Array.from([0x2EDA, 0x1E]),\n Int32Array.from([0x2BED, 0x1F]),\n ];\n\n /**\n *

Encapsulates a set of error-correction blocks in one symbol version. Most versions will\n * use blocks of differing sizes within one version, so, this encapsulates the parameters for\n * each set of blocks. It also holds the number of error-correction codewords per block since it\n * will be the same across all blocks within one version.

\n */\n class ECBlocks$1 {\n constructor(ecCodewordsPerBlock /*int*/, ...ecBlocks) {\n this.ecCodewordsPerBlock = ecCodewordsPerBlock;\n this.ecBlocks = ecBlocks;\n }\n getECCodewordsPerBlock() {\n return this.ecCodewordsPerBlock;\n }\n getNumBlocks() {\n let total = 0;\n const ecBlocks = this.ecBlocks;\n for (const ecBlock of ecBlocks) {\n total += ecBlock.getCount();\n }\n return total;\n }\n getTotalECCodewords() {\n return this.ecCodewordsPerBlock * this.getNumBlocks();\n }\n getECBlocks() {\n return this.ecBlocks;\n }\n }\n\n /**\n *

Encapsulates the parameters for one error-correction block in one symbol version.\n * This includes the number of data codewords, and the number of times a block with these\n * parameters is used consecutively in the QR code version's format.

\n */\n class ECB$1 {\n constructor(count /*int*/, dataCodewords /*int*/) {\n this.count = count;\n this.dataCodewords = dataCodewords;\n }\n getCount() {\n return this.count;\n }\n getDataCodewords() {\n return this.dataCodewords;\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * See ISO 18004:2006 Annex D\n *\n * @author Sean Owen\n */\n class Version$1 {\n constructor(versionNumber /*int*/, alignmentPatternCenters, ...ecBlocks) {\n this.versionNumber = versionNumber;\n this.alignmentPatternCenters = alignmentPatternCenters;\n this.ecBlocks = ecBlocks;\n let total = 0;\n const ecCodewords = ecBlocks[0].getECCodewordsPerBlock();\n const ecbArray = ecBlocks[0].getECBlocks();\n for (const ecBlock of ecbArray) {\n total += ecBlock.getCount() * (ecBlock.getDataCodewords() + ecCodewords);\n }\n this.totalCodewords = total;\n }\n getVersionNumber() {\n return this.versionNumber;\n }\n getAlignmentPatternCenters() {\n return this.alignmentPatternCenters;\n }\n getTotalCodewords() {\n return this.totalCodewords;\n }\n getDimensionForVersion() {\n return 17 + 4 * this.versionNumber;\n }\n getECBlocksForLevel(ecLevel) {\n return this.ecBlocks[ecLevel.getValue()];\n // TYPESCRIPTPORT: original was using ordinal, and using the order of levels as defined in ErrorCorrectionLevel enum (LMQH)\n // I will use the direct value from ErrorCorrectionLevelValues enum which in typescript goes to a number\n }\n /**\n *

Deduces version information purely from QR Code dimensions.

\n *\n * @param dimension dimension in modules\n * @return Version for a QR Code of that dimension\n * @throws FormatException if dimension is not 1 mod 4\n */\n static getProvisionalVersionForDimension(dimension /*int*/) {\n if (dimension % 4 !== 1) {\n throw new FormatException();\n }\n try {\n return this.getVersionForNumber((dimension - 17) / 4);\n }\n catch (ignored /*: IllegalArgumentException*/) {\n throw new FormatException();\n }\n }\n static getVersionForNumber(versionNumber /*int*/) {\n if (versionNumber < 1 || versionNumber > 40) {\n throw new IllegalArgumentException();\n }\n return Version$1.VERSIONS[versionNumber - 1];\n }\n static decodeVersionInformation(versionBits /*int*/) {\n let bestDifference = Number.MAX_SAFE_INTEGER;\n let bestVersion = 0;\n for (let i = 0; i < Version$1.VERSION_DECODE_INFO.length; i++) {\n const targetVersion = Version$1.VERSION_DECODE_INFO[i];\n // Do the version info bits match exactly? done.\n if (targetVersion === versionBits) {\n return Version$1.getVersionForNumber(i + 7);\n }\n // Otherwise see if this is the closest to a real version info bit string\n // we have seen so far\n const bitsDifference = FormatInformation.numBitsDiffering(versionBits, targetVersion);\n if (bitsDifference < bestDifference) {\n bestVersion = i + 7;\n bestDifference = bitsDifference;\n }\n }\n // We can tolerate up to 3 bits of error since no two version info codewords will\n // differ in less than 8 bits.\n if (bestDifference <= 3) {\n return Version$1.getVersionForNumber(bestVersion);\n }\n // If we didn't find a close enough match, fail\n return null;\n }\n /**\n * See ISO 18004:2006 Annex E\n */\n buildFunctionPattern() {\n const dimension = this.getDimensionForVersion();\n const bitMatrix = new BitMatrix(dimension);\n // Top left finder pattern + separator + format\n bitMatrix.setRegion(0, 0, 9, 9);\n // Top right finder pattern + separator + format\n bitMatrix.setRegion(dimension - 8, 0, 8, 9);\n // Bottom left finder pattern + separator + format\n bitMatrix.setRegion(0, dimension - 8, 9, 8);\n // Alignment patterns\n const max = this.alignmentPatternCenters.length;\n for (let x = 0; x < max; x++) {\n const i = this.alignmentPatternCenters[x] - 2;\n for (let y = 0; y < max; y++) {\n if ((x === 0 && (y === 0 || y === max - 1)) || (x === max - 1 && y === 0)) {\n // No alignment patterns near the three finder patterns\n continue;\n }\n bitMatrix.setRegion(this.alignmentPatternCenters[y] - 2, i, 5, 5);\n }\n }\n // Vertical timing pattern\n bitMatrix.setRegion(6, 9, 1, dimension - 17);\n // Horizontal timing pattern\n bitMatrix.setRegion(9, 6, dimension - 17, 1);\n if (this.versionNumber > 6) {\n // Version info, top right\n bitMatrix.setRegion(dimension - 11, 0, 3, 6);\n // Version info, bottom left\n bitMatrix.setRegion(0, dimension - 11, 6, 3);\n }\n return bitMatrix;\n }\n /*@Override*/\n toString() {\n return '' + this.versionNumber;\n }\n }\n /**\n * See ISO 18004:2006 Annex D.\n * Element i represents the raw version bits that specify version i + 7\n */\n Version$1.VERSION_DECODE_INFO = Int32Array.from([\n 0x07C94, 0x085BC, 0x09A99, 0x0A4D3, 0x0BBF6,\n 0x0C762, 0x0D847, 0x0E60D, 0x0F928, 0x10B78,\n 0x1145D, 0x12A17, 0x13532, 0x149A6, 0x15683,\n 0x168C9, 0x177EC, 0x18EC4, 0x191E1, 0x1AFAB,\n 0x1B08E, 0x1CC1A, 0x1D33F, 0x1ED75, 0x1F250,\n 0x209D5, 0x216F0, 0x228BA, 0x2379F, 0x24B0B,\n 0x2542E, 0x26A64, 0x27541, 0x28C69\n ]);\n /**\n * See ISO 18004:2006 6.5.1 Table 9\n */\n Version$1.VERSIONS = [\n new Version$1(1, new Int32Array(0), new ECBlocks$1(7, new ECB$1(1, 19)), new ECBlocks$1(10, new ECB$1(1, 16)), new ECBlocks$1(13, new ECB$1(1, 13)), new ECBlocks$1(17, new ECB$1(1, 9))),\n new Version$1(2, Int32Array.from([6, 18]), new ECBlocks$1(10, new ECB$1(1, 34)), new ECBlocks$1(16, new ECB$1(1, 28)), new ECBlocks$1(22, new ECB$1(1, 22)), new ECBlocks$1(28, new ECB$1(1, 16))),\n new Version$1(3, Int32Array.from([6, 22]), new ECBlocks$1(15, new ECB$1(1, 55)), new ECBlocks$1(26, new ECB$1(1, 44)), new ECBlocks$1(18, new ECB$1(2, 17)), new ECBlocks$1(22, new ECB$1(2, 13))),\n new Version$1(4, Int32Array.from([6, 26]), new ECBlocks$1(20, new ECB$1(1, 80)), new ECBlocks$1(18, new ECB$1(2, 32)), new ECBlocks$1(26, new ECB$1(2, 24)), new ECBlocks$1(16, new ECB$1(4, 9))),\n new Version$1(5, Int32Array.from([6, 30]), new ECBlocks$1(26, new ECB$1(1, 108)), new ECBlocks$1(24, new ECB$1(2, 43)), new ECBlocks$1(18, new ECB$1(2, 15), new ECB$1(2, 16)), new ECBlocks$1(22, new ECB$1(2, 11), new ECB$1(2, 12))),\n new Version$1(6, Int32Array.from([6, 34]), new ECBlocks$1(18, new ECB$1(2, 68)), new ECBlocks$1(16, new ECB$1(4, 27)), new ECBlocks$1(24, new ECB$1(4, 19)), new ECBlocks$1(28, new ECB$1(4, 15))),\n new Version$1(7, Int32Array.from([6, 22, 38]), new ECBlocks$1(20, new ECB$1(2, 78)), new ECBlocks$1(18, new ECB$1(4, 31)), new ECBlocks$1(18, new ECB$1(2, 14), new ECB$1(4, 15)), new ECBlocks$1(26, new ECB$1(4, 13), new ECB$1(1, 14))),\n new Version$1(8, Int32Array.from([6, 24, 42]), new ECBlocks$1(24, new ECB$1(2, 97)), new ECBlocks$1(22, new ECB$1(2, 38), new ECB$1(2, 39)), new ECBlocks$1(22, new ECB$1(4, 18), new ECB$1(2, 19)), new ECBlocks$1(26, new ECB$1(4, 14), new ECB$1(2, 15))),\n new Version$1(9, Int32Array.from([6, 26, 46]), new ECBlocks$1(30, new ECB$1(2, 116)), new ECBlocks$1(22, new ECB$1(3, 36), new ECB$1(2, 37)), new ECBlocks$1(20, new ECB$1(4, 16), new ECB$1(4, 17)), new ECBlocks$1(24, new ECB$1(4, 12), new ECB$1(4, 13))),\n new Version$1(10, Int32Array.from([6, 28, 50]), new ECBlocks$1(18, new ECB$1(2, 68), new ECB$1(2, 69)), new ECBlocks$1(26, new ECB$1(4, 43), new ECB$1(1, 44)), new ECBlocks$1(24, new ECB$1(6, 19), new ECB$1(2, 20)), new ECBlocks$1(28, new ECB$1(6, 15), new ECB$1(2, 16))),\n new Version$1(11, Int32Array.from([6, 30, 54]), new ECBlocks$1(20, new ECB$1(4, 81)), new ECBlocks$1(30, new ECB$1(1, 50), new ECB$1(4, 51)), new ECBlocks$1(28, new ECB$1(4, 22), new ECB$1(4, 23)), new ECBlocks$1(24, new ECB$1(3, 12), new ECB$1(8, 13))),\n new Version$1(12, Int32Array.from([6, 32, 58]), new ECBlocks$1(24, new ECB$1(2, 92), new ECB$1(2, 93)), new ECBlocks$1(22, new ECB$1(6, 36), new ECB$1(2, 37)), new ECBlocks$1(26, new ECB$1(4, 20), new ECB$1(6, 21)), new ECBlocks$1(28, new ECB$1(7, 14), new ECB$1(4, 15))),\n new Version$1(13, Int32Array.from([6, 34, 62]), new ECBlocks$1(26, new ECB$1(4, 107)), new ECBlocks$1(22, new ECB$1(8, 37), new ECB$1(1, 38)), new ECBlocks$1(24, new ECB$1(8, 20), new ECB$1(4, 21)), new ECBlocks$1(22, new ECB$1(12, 11), new ECB$1(4, 12))),\n new Version$1(14, Int32Array.from([6, 26, 46, 66]), new ECBlocks$1(30, new ECB$1(3, 115), new ECB$1(1, 116)), new ECBlocks$1(24, new ECB$1(4, 40), new ECB$1(5, 41)), new ECBlocks$1(20, new ECB$1(11, 16), new ECB$1(5, 17)), new ECBlocks$1(24, new ECB$1(11, 12), new ECB$1(5, 13))),\n new Version$1(15, Int32Array.from([6, 26, 48, 70]), new ECBlocks$1(22, new ECB$1(5, 87), new ECB$1(1, 88)), new ECBlocks$1(24, new ECB$1(5, 41), new ECB$1(5, 42)), new ECBlocks$1(30, new ECB$1(5, 24), new ECB$1(7, 25)), new ECBlocks$1(24, new ECB$1(11, 12), new ECB$1(7, 13))),\n new Version$1(16, Int32Array.from([6, 26, 50, 74]), new ECBlocks$1(24, new ECB$1(5, 98), new ECB$1(1, 99)), new ECBlocks$1(28, new ECB$1(7, 45), new ECB$1(3, 46)), new ECBlocks$1(24, new ECB$1(15, 19), new ECB$1(2, 20)), new ECBlocks$1(30, new ECB$1(3, 15), new ECB$1(13, 16))),\n new Version$1(17, Int32Array.from([6, 30, 54, 78]), new ECBlocks$1(28, new ECB$1(1, 107), new ECB$1(5, 108)), new ECBlocks$1(28, new ECB$1(10, 46), new ECB$1(1, 47)), new ECBlocks$1(28, new ECB$1(1, 22), new ECB$1(15, 23)), new ECBlocks$1(28, new ECB$1(2, 14), new ECB$1(17, 15))),\n new Version$1(18, Int32Array.from([6, 30, 56, 82]), new ECBlocks$1(30, new ECB$1(5, 120), new ECB$1(1, 121)), new ECBlocks$1(26, new ECB$1(9, 43), new ECB$1(4, 44)), new ECBlocks$1(28, new ECB$1(17, 22), new ECB$1(1, 23)), new ECBlocks$1(28, new ECB$1(2, 14), new ECB$1(19, 15))),\n new Version$1(19, Int32Array.from([6, 30, 58, 86]), new ECBlocks$1(28, new ECB$1(3, 113), new ECB$1(4, 114)), new ECBlocks$1(26, new ECB$1(3, 44), new ECB$1(11, 45)), new ECBlocks$1(26, new ECB$1(17, 21), new ECB$1(4, 22)), new ECBlocks$1(26, new ECB$1(9, 13), new ECB$1(16, 14))),\n new Version$1(20, Int32Array.from([6, 34, 62, 90]), new ECBlocks$1(28, new ECB$1(3, 107), new ECB$1(5, 108)), new ECBlocks$1(26, new ECB$1(3, 41), new ECB$1(13, 42)), new ECBlocks$1(30, new ECB$1(15, 24), new ECB$1(5, 25)), new ECBlocks$1(28, new ECB$1(15, 15), new ECB$1(10, 16))),\n new Version$1(21, Int32Array.from([6, 28, 50, 72, 94]), new ECBlocks$1(28, new ECB$1(4, 116), new ECB$1(4, 117)), new ECBlocks$1(26, new ECB$1(17, 42)), new ECBlocks$1(28, new ECB$1(17, 22), new ECB$1(6, 23)), new ECBlocks$1(30, new ECB$1(19, 16), new ECB$1(6, 17))),\n new Version$1(22, Int32Array.from([6, 26, 50, 74, 98]), new ECBlocks$1(28, new ECB$1(2, 111), new ECB$1(7, 112)), new ECBlocks$1(28, new ECB$1(17, 46)), new ECBlocks$1(30, new ECB$1(7, 24), new ECB$1(16, 25)), new ECBlocks$1(24, new ECB$1(34, 13))),\n new Version$1(23, Int32Array.from([6, 30, 54, 78, 102]), new ECBlocks$1(30, new ECB$1(4, 121), new ECB$1(5, 122)), new ECBlocks$1(28, new ECB$1(4, 47), new ECB$1(14, 48)), new ECBlocks$1(30, new ECB$1(11, 24), new ECB$1(14, 25)), new ECBlocks$1(30, new ECB$1(16, 15), new ECB$1(14, 16))),\n new Version$1(24, Int32Array.from([6, 28, 54, 80, 106]), new ECBlocks$1(30, new ECB$1(6, 117), new ECB$1(4, 118)), new ECBlocks$1(28, new ECB$1(6, 45), new ECB$1(14, 46)), new ECBlocks$1(30, new ECB$1(11, 24), new ECB$1(16, 25)), new ECBlocks$1(30, new ECB$1(30, 16), new ECB$1(2, 17))),\n new Version$1(25, Int32Array.from([6, 32, 58, 84, 110]), new ECBlocks$1(26, new ECB$1(8, 106), new ECB$1(4, 107)), new ECBlocks$1(28, new ECB$1(8, 47), new ECB$1(13, 48)), new ECBlocks$1(30, new ECB$1(7, 24), new ECB$1(22, 25)), new ECBlocks$1(30, new ECB$1(22, 15), new ECB$1(13, 16))),\n new Version$1(26, Int32Array.from([6, 30, 58, 86, 114]), new ECBlocks$1(28, new ECB$1(10, 114), new ECB$1(2, 115)), new ECBlocks$1(28, new ECB$1(19, 46), new ECB$1(4, 47)), new ECBlocks$1(28, new ECB$1(28, 22), new ECB$1(6, 23)), new ECBlocks$1(30, new ECB$1(33, 16), new ECB$1(4, 17))),\n new Version$1(27, Int32Array.from([6, 34, 62, 90, 118]), new ECBlocks$1(30, new ECB$1(8, 122), new ECB$1(4, 123)), new ECBlocks$1(28, new ECB$1(22, 45), new ECB$1(3, 46)), new ECBlocks$1(30, new ECB$1(8, 23), new ECB$1(26, 24)), new ECBlocks$1(30, new ECB$1(12, 15), new ECB$1(28, 16))),\n new Version$1(28, Int32Array.from([6, 26, 50, 74, 98, 122]), new ECBlocks$1(30, new ECB$1(3, 117), new ECB$1(10, 118)), new ECBlocks$1(28, new ECB$1(3, 45), new ECB$1(23, 46)), new ECBlocks$1(30, new ECB$1(4, 24), new ECB$1(31, 25)), new ECBlocks$1(30, new ECB$1(11, 15), new ECB$1(31, 16))),\n new Version$1(29, Int32Array.from([6, 30, 54, 78, 102, 126]), new ECBlocks$1(30, new ECB$1(7, 116), new ECB$1(7, 117)), new ECBlocks$1(28, new ECB$1(21, 45), new ECB$1(7, 46)), new ECBlocks$1(30, new ECB$1(1, 23), new ECB$1(37, 24)), new ECBlocks$1(30, new ECB$1(19, 15), new ECB$1(26, 16))),\n new Version$1(30, Int32Array.from([6, 26, 52, 78, 104, 130]), new ECBlocks$1(30, new ECB$1(5, 115), new ECB$1(10, 116)), new ECBlocks$1(28, new ECB$1(19, 47), new ECB$1(10, 48)), new ECBlocks$1(30, new ECB$1(15, 24), new ECB$1(25, 25)), new ECBlocks$1(30, new ECB$1(23, 15), new ECB$1(25, 16))),\n new Version$1(31, Int32Array.from([6, 30, 56, 82, 108, 134]), new ECBlocks$1(30, new ECB$1(13, 115), new ECB$1(3, 116)), new ECBlocks$1(28, new ECB$1(2, 46), new ECB$1(29, 47)), new ECBlocks$1(30, new ECB$1(42, 24), new ECB$1(1, 25)), new ECBlocks$1(30, new ECB$1(23, 15), new ECB$1(28, 16))),\n new Version$1(32, Int32Array.from([6, 34, 60, 86, 112, 138]), new ECBlocks$1(30, new ECB$1(17, 115)), new ECBlocks$1(28, new ECB$1(10, 46), new ECB$1(23, 47)), new ECBlocks$1(30, new ECB$1(10, 24), new ECB$1(35, 25)), new ECBlocks$1(30, new ECB$1(19, 15), new ECB$1(35, 16))),\n new Version$1(33, Int32Array.from([6, 30, 58, 86, 114, 142]), new ECBlocks$1(30, new ECB$1(17, 115), new ECB$1(1, 116)), new ECBlocks$1(28, new ECB$1(14, 46), new ECB$1(21, 47)), new ECBlocks$1(30, new ECB$1(29, 24), new ECB$1(19, 25)), new ECBlocks$1(30, new ECB$1(11, 15), new ECB$1(46, 16))),\n new Version$1(34, Int32Array.from([6, 34, 62, 90, 118, 146]), new ECBlocks$1(30, new ECB$1(13, 115), new ECB$1(6, 116)), new ECBlocks$1(28, new ECB$1(14, 46), new ECB$1(23, 47)), new ECBlocks$1(30, new ECB$1(44, 24), new ECB$1(7, 25)), new ECBlocks$1(30, new ECB$1(59, 16), new ECB$1(1, 17))),\n new Version$1(35, Int32Array.from([6, 30, 54, 78, 102, 126, 150]), new ECBlocks$1(30, new ECB$1(12, 121), new ECB$1(7, 122)), new ECBlocks$1(28, new ECB$1(12, 47), new ECB$1(26, 48)), new ECBlocks$1(30, new ECB$1(39, 24), new ECB$1(14, 25)), new ECBlocks$1(30, new ECB$1(22, 15), new ECB$1(41, 16))),\n new Version$1(36, Int32Array.from([6, 24, 50, 76, 102, 128, 154]), new ECBlocks$1(30, new ECB$1(6, 121), new ECB$1(14, 122)), new ECBlocks$1(28, new ECB$1(6, 47), new ECB$1(34, 48)), new ECBlocks$1(30, new ECB$1(46, 24), new ECB$1(10, 25)), new ECBlocks$1(30, new ECB$1(2, 15), new ECB$1(64, 16))),\n new Version$1(37, Int32Array.from([6, 28, 54, 80, 106, 132, 158]), new ECBlocks$1(30, new ECB$1(17, 122), new ECB$1(4, 123)), new ECBlocks$1(28, new ECB$1(29, 46), new ECB$1(14, 47)), new ECBlocks$1(30, new ECB$1(49, 24), new ECB$1(10, 25)), new ECBlocks$1(30, new ECB$1(24, 15), new ECB$1(46, 16))),\n new Version$1(38, Int32Array.from([6, 32, 58, 84, 110, 136, 162]), new ECBlocks$1(30, new ECB$1(4, 122), new ECB$1(18, 123)), new ECBlocks$1(28, new ECB$1(13, 46), new ECB$1(32, 47)), new ECBlocks$1(30, new ECB$1(48, 24), new ECB$1(14, 25)), new ECBlocks$1(30, new ECB$1(42, 15), new ECB$1(32, 16))),\n new Version$1(39, Int32Array.from([6, 26, 54, 82, 110, 138, 166]), new ECBlocks$1(30, new ECB$1(20, 117), new ECB$1(4, 118)), new ECBlocks$1(28, new ECB$1(40, 47), new ECB$1(7, 48)), new ECBlocks$1(30, new ECB$1(43, 24), new ECB$1(22, 25)), new ECBlocks$1(30, new ECB$1(10, 15), new ECB$1(67, 16))),\n new Version$1(40, Int32Array.from([6, 30, 58, 86, 114, 142, 170]), new ECBlocks$1(30, new ECB$1(19, 118), new ECB$1(6, 119)), new ECBlocks$1(28, new ECB$1(18, 47), new ECB$1(31, 48)), new ECBlocks$1(30, new ECB$1(34, 24), new ECB$1(34, 25)), new ECBlocks$1(30, new ECB$1(20, 15), new ECB$1(61, 16)))\n ];\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n var DataMaskValues;\n (function (DataMaskValues) {\n DataMaskValues[DataMaskValues[\"DATA_MASK_000\"] = 0] = \"DATA_MASK_000\";\n DataMaskValues[DataMaskValues[\"DATA_MASK_001\"] = 1] = \"DATA_MASK_001\";\n DataMaskValues[DataMaskValues[\"DATA_MASK_010\"] = 2] = \"DATA_MASK_010\";\n DataMaskValues[DataMaskValues[\"DATA_MASK_011\"] = 3] = \"DATA_MASK_011\";\n DataMaskValues[DataMaskValues[\"DATA_MASK_100\"] = 4] = \"DATA_MASK_100\";\n DataMaskValues[DataMaskValues[\"DATA_MASK_101\"] = 5] = \"DATA_MASK_101\";\n DataMaskValues[DataMaskValues[\"DATA_MASK_110\"] = 6] = \"DATA_MASK_110\";\n DataMaskValues[DataMaskValues[\"DATA_MASK_111\"] = 7] = \"DATA_MASK_111\";\n })(DataMaskValues || (DataMaskValues = {}));\n /**\n *

Encapsulates data masks for the data bits in a QR code, per ISO 18004:2006 6.8. Implementations\n * of this class can un-mask a raw BitMatrix. For simplicity, they will unmask the entire BitMatrix,\n * including areas used for finder patterns, timing patterns, etc. These areas should be unused\n * after the point they are unmasked anyway.

\n *\n *

Note that the diagram in section 6.8.1 is misleading since it indicates that i is column position\n * and j is row position. In fact, as the text says, i is row position and j is column position.

\n *\n * @author Sean Owen\n */\n class DataMask {\n // See ISO 18004:2006 6.8.1\n constructor(value, isMasked) {\n this.value = value;\n this.isMasked = isMasked;\n }\n // End of enum constants.\n /**\n *

Implementations of this method reverse the data masking process applied to a QR Code and\n * make its bits ready to read.

\n *\n * @param bits representation of QR Code bits\n * @param dimension dimension of QR Code, represented by bits, being unmasked\n */\n unmaskBitMatrix(bits, dimension /*int*/) {\n for (let i = 0; i < dimension; i++) {\n for (let j = 0; j < dimension; j++) {\n if (this.isMasked(i, j)) {\n bits.flip(j, i);\n }\n }\n }\n }\n }\n DataMask.values = new Map([\n /**\n * 000: mask bits for which (x + y) mod 2 == 0\n */\n [DataMaskValues.DATA_MASK_000, new DataMask(DataMaskValues.DATA_MASK_000, (i /*int*/, j /*int*/) => { return ((i + j) & 0x01) === 0; })],\n /**\n * 001: mask bits for which x mod 2 == 0\n */\n [DataMaskValues.DATA_MASK_001, new DataMask(DataMaskValues.DATA_MASK_001, (i /*int*/, j /*int*/) => { return (i & 0x01) === 0; })],\n /**\n * 010: mask bits for which y mod 3 == 0\n */\n [DataMaskValues.DATA_MASK_010, new DataMask(DataMaskValues.DATA_MASK_010, (i /*int*/, j /*int*/) => { return j % 3 === 0; })],\n /**\n * 011: mask bits for which (x + y) mod 3 == 0\n */\n [DataMaskValues.DATA_MASK_011, new DataMask(DataMaskValues.DATA_MASK_011, (i /*int*/, j /*int*/) => { return (i + j) % 3 === 0; })],\n /**\n * 100: mask bits for which (x/2 + y/3) mod 2 == 0\n */\n [DataMaskValues.DATA_MASK_100, new DataMask(DataMaskValues.DATA_MASK_100, (i /*int*/, j /*int*/) => { return ((Math.floor(i / 2) + Math.floor(j / 3)) & 0x01) === 0; })],\n /**\n * 101: mask bits for which xy mod 2 + xy mod 3 == 0\n * equivalently, such that xy mod 6 == 0\n */\n [DataMaskValues.DATA_MASK_101, new DataMask(DataMaskValues.DATA_MASK_101, (i /*int*/, j /*int*/) => { return (i * j) % 6 === 0; })],\n /**\n * 110: mask bits for which (xy mod 2 + xy mod 3) mod 2 == 0\n * equivalently, such that xy mod 6 < 3\n */\n [DataMaskValues.DATA_MASK_110, new DataMask(DataMaskValues.DATA_MASK_110, (i /*int*/, j /*int*/) => { return ((i * j) % 6) < 3; })],\n /**\n * 111: mask bits for which ((x+y)mod 2 + xy mod 3) mod 2 == 0\n * equivalently, such that (x + y + xy mod 3) mod 2 == 0\n */\n [DataMaskValues.DATA_MASK_111, new DataMask(DataMaskValues.DATA_MASK_111, (i /*int*/, j /*int*/) => { return ((i + j + ((i * j) % 3)) & 0x01) === 0; })],\n ]);\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author Sean Owen\n */\n class BitMatrixParser$1 {\n /**\n * @param bitMatrix {@link BitMatrix} to parse\n * @throws FormatException if dimension is not >= 21 and 1 mod 4\n */\n constructor(bitMatrix) {\n const dimension = bitMatrix.getHeight();\n if (dimension < 21 || (dimension & 0x03) !== 1) {\n throw new FormatException();\n }\n this.bitMatrix = bitMatrix;\n }\n /**\n *

Reads format information from one of its two locations within the QR Code.

\n *\n * @return {@link FormatInformation} encapsulating the QR Code's format info\n * @throws FormatException if both format information locations cannot be parsed as\n * the valid encoding of format information\n */\n readFormatInformation() {\n if (this.parsedFormatInfo !== null && this.parsedFormatInfo !== undefined) {\n return this.parsedFormatInfo;\n }\n // Read top-left format info bits\n let formatInfoBits1 = 0;\n for (let i = 0; i < 6; i++) {\n formatInfoBits1 = this.copyBit(i, 8, formatInfoBits1);\n }\n // .. and skip a bit in the timing pattern ...\n formatInfoBits1 = this.copyBit(7, 8, formatInfoBits1);\n formatInfoBits1 = this.copyBit(8, 8, formatInfoBits1);\n formatInfoBits1 = this.copyBit(8, 7, formatInfoBits1);\n // .. and skip a bit in the timing pattern ...\n for (let j = 5; j >= 0; j--) {\n formatInfoBits1 = this.copyBit(8, j, formatInfoBits1);\n }\n // Read the top-right/bottom-left pattern too\n const dimension = this.bitMatrix.getHeight();\n let formatInfoBits2 = 0;\n const jMin = dimension - 7;\n for (let j = dimension - 1; j >= jMin; j--) {\n formatInfoBits2 = this.copyBit(8, j, formatInfoBits2);\n }\n for (let i = dimension - 8; i < dimension; i++) {\n formatInfoBits2 = this.copyBit(i, 8, formatInfoBits2);\n }\n this.parsedFormatInfo = FormatInformation.decodeFormatInformation(formatInfoBits1, formatInfoBits2);\n if (this.parsedFormatInfo !== null) {\n return this.parsedFormatInfo;\n }\n throw new FormatException();\n }\n /**\n *

Reads version information from one of its two locations within the QR Code.

\n *\n * @return {@link Version} encapsulating the QR Code's version\n * @throws FormatException if both version information locations cannot be parsed as\n * the valid encoding of version information\n */\n readVersion() {\n if (this.parsedVersion !== null && this.parsedVersion !== undefined) {\n return this.parsedVersion;\n }\n const dimension = this.bitMatrix.getHeight();\n const provisionalVersion = Math.floor((dimension - 17) / 4);\n if (provisionalVersion <= 6) {\n return Version$1.getVersionForNumber(provisionalVersion);\n }\n // Read top-right version info: 3 wide by 6 tall\n let versionBits = 0;\n const ijMin = dimension - 11;\n for (let j = 5; j >= 0; j--) {\n for (let i = dimension - 9; i >= ijMin; i--) {\n versionBits = this.copyBit(i, j, versionBits);\n }\n }\n let theParsedVersion = Version$1.decodeVersionInformation(versionBits);\n if (theParsedVersion !== null && theParsedVersion.getDimensionForVersion() === dimension) {\n this.parsedVersion = theParsedVersion;\n return theParsedVersion;\n }\n // Hmm, failed. Try bottom left: 6 wide by 3 tall\n versionBits = 0;\n for (let i = 5; i >= 0; i--) {\n for (let j = dimension - 9; j >= ijMin; j--) {\n versionBits = this.copyBit(i, j, versionBits);\n }\n }\n theParsedVersion = Version$1.decodeVersionInformation(versionBits);\n if (theParsedVersion !== null && theParsedVersion.getDimensionForVersion() === dimension) {\n this.parsedVersion = theParsedVersion;\n return theParsedVersion;\n }\n throw new FormatException();\n }\n copyBit(i /*int*/, j /*int*/, versionBits /*int*/) {\n const bit = this.isMirror ? this.bitMatrix.get(j, i) : this.bitMatrix.get(i, j);\n return bit ? (versionBits << 1) | 0x1 : versionBits << 1;\n }\n /**\n *

Reads the bits in the {@link BitMatrix} representing the finder pattern in the\n * correct order in order to reconstruct the codewords bytes contained within the\n * QR Code.

\n *\n * @return bytes encoded within the QR Code\n * @throws FormatException if the exact number of bytes expected is not read\n */\n readCodewords() {\n const formatInfo = this.readFormatInformation();\n const version = this.readVersion();\n // Get the data mask for the format used in this QR Code. This will exclude\n // some bits from reading as we wind through the bit matrix.\n const dataMask = DataMask.values.get(formatInfo.getDataMask());\n const dimension = this.bitMatrix.getHeight();\n dataMask.unmaskBitMatrix(this.bitMatrix, dimension);\n const functionPattern = version.buildFunctionPattern();\n let readingUp = true;\n const result = new Uint8Array(version.getTotalCodewords());\n let resultOffset = 0;\n let currentByte = 0;\n let bitsRead = 0;\n // Read columns in pairs, from right to left\n for (let j = dimension - 1; j > 0; j -= 2) {\n if (j === 6) {\n // Skip whole column with vertical alignment pattern\n // saves time and makes the other code proceed more cleanly\n j--;\n }\n // Read alternatingly from bottom to top then top to bottom\n for (let count = 0; count < dimension; count++) {\n const i = readingUp ? dimension - 1 - count : count;\n for (let col = 0; col < 2; col++) {\n // Ignore bits covered by the function pattern\n if (!functionPattern.get(j - col, i)) {\n // Read a bit\n bitsRead++;\n currentByte <<= 1;\n if (this.bitMatrix.get(j - col, i)) {\n currentByte |= 1;\n }\n // If we've made a whole byte, save it off\n if (bitsRead === 8) {\n result[resultOffset++] = /*(byte) */ currentByte;\n bitsRead = 0;\n currentByte = 0;\n }\n }\n }\n }\n readingUp = !readingUp; // readingUp ^= true; // readingUp = !readingUp; // switch directions\n }\n if (resultOffset !== version.getTotalCodewords()) {\n throw new FormatException();\n }\n return result;\n }\n /**\n * Revert the mask removal done while reading the code words. The bit matrix should revert to its original state.\n */\n remask() {\n if (this.parsedFormatInfo === null) {\n return; // We have no format information, and have no data mask\n }\n const dataMask = DataMask.values[this.parsedFormatInfo.getDataMask()];\n const dimension = this.bitMatrix.getHeight();\n dataMask.unmaskBitMatrix(this.bitMatrix, dimension);\n }\n /**\n * Prepare the parser for a mirrored operation.\n * This flag has effect only on the {@link #readFormatInformation()} and the\n * {@link #readVersion()}. Before proceeding with {@link #readCodewords()} the\n * {@link #mirror()} method should be called.\n *\n * @param mirror Whether to read version and format information mirrored.\n */\n setMirror(isMirror) {\n this.parsedVersion = null;\n this.parsedFormatInfo = null;\n this.isMirror = isMirror;\n }\n /** Mirror the bit matrix in order to attempt a second reading. */\n mirror() {\n const bitMatrix = this.bitMatrix;\n for (let x = 0, width = bitMatrix.getWidth(); x < width; x++) {\n for (let y = x + 1, height = bitMatrix.getHeight(); y < height; y++) {\n if (bitMatrix.get(x, y) !== bitMatrix.get(y, x)) {\n bitMatrix.flip(y, x);\n bitMatrix.flip(x, y);\n }\n }\n }\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates a block of data within a QR Code. QR Codes may split their data into\n * multiple blocks, each of which is a unit of data and error-correction codewords. Each\n * is represented by an instance of this class.

\n *\n * @author Sean Owen\n */\n class DataBlock$1 {\n constructor(numDataCodewords /*int*/, codewords) {\n this.numDataCodewords = numDataCodewords;\n this.codewords = codewords;\n }\n /**\n *

When QR Codes use multiple data blocks, they are actually interleaved.\n * That is, the first byte of data block 1 to n is written, then the second bytes, and so on. This\n * method will separate the data into original blocks.

\n *\n * @param rawCodewords bytes as read directly from the QR Code\n * @param version version of the QR Code\n * @param ecLevel error-correction level of the QR Code\n * @return DataBlocks containing original bytes, \"de-interleaved\" from representation in the\n * QR Code\n */\n static getDataBlocks(rawCodewords, version, ecLevel) {\n if (rawCodewords.length !== version.getTotalCodewords()) {\n throw new IllegalArgumentException();\n }\n // Figure out the number and size of data blocks used by this version and\n // error correction level\n const ecBlocks = version.getECBlocksForLevel(ecLevel);\n // First count the total number of data blocks\n let totalBlocks = 0;\n const ecBlockArray = ecBlocks.getECBlocks();\n for (const ecBlock of ecBlockArray) {\n totalBlocks += ecBlock.getCount();\n }\n // Now establish DataBlocks of the appropriate size and number of data codewords\n const result = new Array(totalBlocks);\n let numResultBlocks = 0;\n for (const ecBlock of ecBlockArray) {\n for (let i = 0; i < ecBlock.getCount(); i++) {\n const numDataCodewords = ecBlock.getDataCodewords();\n const numBlockCodewords = ecBlocks.getECCodewordsPerBlock() + numDataCodewords;\n result[numResultBlocks++] = new DataBlock$1(numDataCodewords, new Uint8Array(numBlockCodewords));\n }\n }\n // All blocks have the same amount of data, except that the last n\n // (where n may be 0) have 1 more byte. Figure out where these start.\n const shorterBlocksTotalCodewords = result[0].codewords.length;\n let longerBlocksStartAt = result.length - 1;\n // TYPESCRIPTPORT: check length is correct here\n while (longerBlocksStartAt >= 0) {\n const numCodewords = result[longerBlocksStartAt].codewords.length;\n if (numCodewords === shorterBlocksTotalCodewords) {\n break;\n }\n longerBlocksStartAt--;\n }\n longerBlocksStartAt++;\n const shorterBlocksNumDataCodewords = shorterBlocksTotalCodewords - ecBlocks.getECCodewordsPerBlock();\n // The last elements of result may be 1 element longer\n // first fill out as many elements as all of them have\n let rawCodewordsOffset = 0;\n for (let i = 0; i < shorterBlocksNumDataCodewords; i++) {\n for (let j = 0; j < numResultBlocks; j++) {\n result[j].codewords[i] = rawCodewords[rawCodewordsOffset++];\n }\n }\n // Fill out the last data block in the longer ones\n for (let j = longerBlocksStartAt; j < numResultBlocks; j++) {\n result[j].codewords[shorterBlocksNumDataCodewords] = rawCodewords[rawCodewordsOffset++];\n }\n // Now add in error correction blocks\n const max = result[0].codewords.length;\n for (let i = shorterBlocksNumDataCodewords; i < max; i++) {\n for (let j = 0; j < numResultBlocks; j++) {\n const iOffset = j < longerBlocksStartAt ? i : i + 1;\n result[j].codewords[iOffset] = rawCodewords[rawCodewordsOffset++];\n }\n }\n return result;\n }\n getNumDataCodewords() {\n return this.numDataCodewords;\n }\n getCodewords() {\n return this.codewords;\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n var ModeValues;\n (function (ModeValues) {\n ModeValues[ModeValues[\"TERMINATOR\"] = 0] = \"TERMINATOR\";\n ModeValues[ModeValues[\"NUMERIC\"] = 1] = \"NUMERIC\";\n ModeValues[ModeValues[\"ALPHANUMERIC\"] = 2] = \"ALPHANUMERIC\";\n ModeValues[ModeValues[\"STRUCTURED_APPEND\"] = 3] = \"STRUCTURED_APPEND\";\n ModeValues[ModeValues[\"BYTE\"] = 4] = \"BYTE\";\n ModeValues[ModeValues[\"ECI\"] = 5] = \"ECI\";\n ModeValues[ModeValues[\"KANJI\"] = 6] = \"KANJI\";\n ModeValues[ModeValues[\"FNC1_FIRST_POSITION\"] = 7] = \"FNC1_FIRST_POSITION\";\n ModeValues[ModeValues[\"FNC1_SECOND_POSITION\"] = 8] = \"FNC1_SECOND_POSITION\";\n /** See GBT 18284-2000; \"Hanzi\" is a transliteration of this mode name. */\n ModeValues[ModeValues[\"HANZI\"] = 9] = \"HANZI\";\n })(ModeValues || (ModeValues = {}));\n /**\n *

See ISO 18004:2006, 6.4.1, Tables 2 and 3. This enum encapsulates the various modes in which\n * data can be encoded to bits in the QR code standard.

\n *\n * @author Sean Owen\n */\n class Mode$1 {\n constructor(value, stringValue, characterCountBitsForVersions, bits /*int*/) {\n this.value = value;\n this.stringValue = stringValue;\n this.characterCountBitsForVersions = characterCountBitsForVersions;\n this.bits = bits;\n Mode$1.FOR_BITS.set(bits, this);\n Mode$1.FOR_VALUE.set(value, this);\n }\n /**\n * @param bits four bits encoding a QR Code data mode\n * @return Mode encoded by these bits\n * @throws IllegalArgumentException if bits do not correspond to a known mode\n */\n static forBits(bits /*int*/) {\n const mode = Mode$1.FOR_BITS.get(bits);\n if (undefined === mode) {\n throw new IllegalArgumentException();\n }\n return mode;\n }\n /**\n * @param version version in question\n * @return number of bits used, in this QR Code symbol {@link Version}, to encode the\n * count of characters that will follow encoded in this Mode\n */\n getCharacterCountBits(version) {\n const versionNumber = version.getVersionNumber();\n let offset;\n if (versionNumber <= 9) {\n offset = 0;\n }\n else if (versionNumber <= 26) {\n offset = 1;\n }\n else {\n offset = 2;\n }\n return this.characterCountBitsForVersions[offset];\n }\n getValue() {\n return this.value;\n }\n getBits() {\n return this.bits;\n }\n equals(o) {\n if (!(o instanceof Mode$1)) {\n return false;\n }\n const other = o;\n return this.value === other.value;\n }\n toString() {\n return this.stringValue;\n }\n }\n Mode$1.FOR_BITS = new Map();\n Mode$1.FOR_VALUE = new Map();\n Mode$1.TERMINATOR = new Mode$1(ModeValues.TERMINATOR, 'TERMINATOR', Int32Array.from([0, 0, 0]), 0x00); // Not really a mode...\n Mode$1.NUMERIC = new Mode$1(ModeValues.NUMERIC, 'NUMERIC', Int32Array.from([10, 12, 14]), 0x01);\n Mode$1.ALPHANUMERIC = new Mode$1(ModeValues.ALPHANUMERIC, 'ALPHANUMERIC', Int32Array.from([9, 11, 13]), 0x02);\n Mode$1.STRUCTURED_APPEND = new Mode$1(ModeValues.STRUCTURED_APPEND, 'STRUCTURED_APPEND', Int32Array.from([0, 0, 0]), 0x03); // Not supported\n Mode$1.BYTE = new Mode$1(ModeValues.BYTE, 'BYTE', Int32Array.from([8, 16, 16]), 0x04);\n Mode$1.ECI = new Mode$1(ModeValues.ECI, 'ECI', Int32Array.from([0, 0, 0]), 0x07); // character counts don't apply\n Mode$1.KANJI = new Mode$1(ModeValues.KANJI, 'KANJI', Int32Array.from([8, 10, 12]), 0x08);\n Mode$1.FNC1_FIRST_POSITION = new Mode$1(ModeValues.FNC1_FIRST_POSITION, 'FNC1_FIRST_POSITION', Int32Array.from([0, 0, 0]), 0x05);\n Mode$1.FNC1_SECOND_POSITION = new Mode$1(ModeValues.FNC1_SECOND_POSITION, 'FNC1_SECOND_POSITION', Int32Array.from([0, 0, 0]), 0x09);\n /** See GBT 18284-2000; \"Hanzi\" is a transliteration of this mode name. */\n Mode$1.HANZI = new Mode$1(ModeValues.HANZI, 'HANZI', Int32Array.from([8, 10, 12]), 0x0D);\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.io.UnsupportedEncodingException;*/\n /*import java.util.ArrayList;*/\n /*import java.util.Collection;*/\n /*import java.util.List;*/\n /*import java.util.Map;*/\n /**\n *

QR Codes can encode text as bits in one of several modes, and can use multiple modes\n * in one QR Code. This class decodes the bits back into text.

\n *\n *

See ISO 18004:2006, 6.4.3 - 6.4.7

\n *\n * @author Sean Owen\n */\n class DecodedBitStreamParser$1 {\n static decode(bytes, version, ecLevel, hints) {\n const bits = new BitSource(bytes);\n let result = new StringBuilder();\n const byteSegments = new Array(); // 1\n // TYPESCRIPTPORT: I do not use constructor with size 1 as in original Java means capacity and the array length is checked below\n let symbolSequence = -1;\n let parityData = -1;\n try {\n let currentCharacterSetECI = null;\n let fc1InEffect = false;\n let mode;\n do {\n // While still another segment to read...\n if (bits.available() < 4) {\n // OK, assume we're done. Really, a TERMINATOR mode should have been recorded here\n mode = Mode$1.TERMINATOR;\n }\n else {\n const modeBits = bits.readBits(4);\n mode = Mode$1.forBits(modeBits); // mode is encoded by 4 bits\n }\n switch (mode) {\n case Mode$1.TERMINATOR:\n break;\n case Mode$1.FNC1_FIRST_POSITION:\n case Mode$1.FNC1_SECOND_POSITION:\n // We do little with FNC1 except alter the parsed result a bit according to the spec\n fc1InEffect = true;\n break;\n case Mode$1.STRUCTURED_APPEND:\n if (bits.available() < 16) {\n throw new FormatException();\n }\n // sequence number and parity is added later to the result metadata\n // Read next 8 bits (symbol sequence #) and 8 bits (data: parity), then continue\n symbolSequence = bits.readBits(8);\n parityData = bits.readBits(8);\n break;\n case Mode$1.ECI:\n // Count doesn't apply to ECI\n const value = DecodedBitStreamParser$1.parseECIValue(bits);\n currentCharacterSetECI = CharacterSetECI.getCharacterSetECIByValue(value);\n if (currentCharacterSetECI === null) {\n throw new FormatException();\n }\n break;\n case Mode$1.HANZI:\n // First handle Hanzi mode which does not start with character count\n // Chinese mode contains a sub set indicator right after mode indicator\n const subset = bits.readBits(4);\n const countHanzi = bits.readBits(mode.getCharacterCountBits(version));\n if (subset === DecodedBitStreamParser$1.GB2312_SUBSET) {\n DecodedBitStreamParser$1.decodeHanziSegment(bits, result, countHanzi);\n }\n break;\n default:\n // \"Normal\" QR code modes:\n // How many characters will follow, encoded in this mode?\n const count = bits.readBits(mode.getCharacterCountBits(version));\n switch (mode) {\n case Mode$1.NUMERIC:\n DecodedBitStreamParser$1.decodeNumericSegment(bits, result, count);\n break;\n case Mode$1.ALPHANUMERIC:\n DecodedBitStreamParser$1.decodeAlphanumericSegment(bits, result, count, fc1InEffect);\n break;\n case Mode$1.BYTE:\n DecodedBitStreamParser$1.decodeByteSegment(bits, result, count, currentCharacterSetECI, byteSegments, hints);\n break;\n case Mode$1.KANJI:\n DecodedBitStreamParser$1.decodeKanjiSegment(bits, result, count);\n break;\n default:\n throw new FormatException();\n }\n break;\n }\n } while (mode !== Mode$1.TERMINATOR);\n }\n catch (iae /*: IllegalArgumentException*/) {\n // from readBits() calls\n throw new FormatException();\n }\n return new DecoderResult(bytes, result.toString(), byteSegments.length === 0 ? null : byteSegments, ecLevel === null ? null : ecLevel.toString(), symbolSequence, parityData);\n }\n /**\n * See specification GBT 18284-2000\n */\n static decodeHanziSegment(bits, result, count /*int*/) {\n // Don't crash trying to read more bits than we have available.\n if (count * 13 > bits.available()) {\n throw new FormatException();\n }\n // Each character will require 2 bytes. Read the characters as 2-byte pairs\n // and decode as GB2312 afterwards\n const buffer = new Uint8Array(2 * count);\n let offset = 0;\n while (count > 0) {\n // Each 13 bits encodes a 2-byte character\n const twoBytes = bits.readBits(13);\n let assembledTwoBytes = (((twoBytes / 0x060) << 8) & 0xFFFFFFFF) | (twoBytes % 0x060);\n if (assembledTwoBytes < 0x003BF) {\n // In the 0xA1A1 to 0xAAFE range\n assembledTwoBytes += 0x0A1A1;\n }\n else {\n // In the 0xB0A1 to 0xFAFE range\n assembledTwoBytes += 0x0A6A1;\n }\n buffer[offset] = /*(byte) */ ((assembledTwoBytes >> 8) & 0xFF);\n buffer[offset + 1] = /*(byte) */ (assembledTwoBytes & 0xFF);\n offset += 2;\n count--;\n }\n try {\n result.append(StringEncoding.decode(buffer, StringUtils.GB2312));\n // TYPESCRIPTPORT: TODO: implement GB2312 decode. StringView from MDN could be a starting point\n }\n catch (ignored /*: UnsupportedEncodingException*/) {\n throw new FormatException(ignored);\n }\n }\n static decodeKanjiSegment(bits, result, count /*int*/) {\n // Don't crash trying to read more bits than we have available.\n if (count * 13 > bits.available()) {\n throw new FormatException();\n }\n // Each character will require 2 bytes. Read the characters as 2-byte pairs\n // and decode as Shift_JIS afterwards\n const buffer = new Uint8Array(2 * count);\n let offset = 0;\n while (count > 0) {\n // Each 13 bits encodes a 2-byte character\n const twoBytes = bits.readBits(13);\n let assembledTwoBytes = (((twoBytes / 0x0C0) << 8) & 0xFFFFFFFF) | (twoBytes % 0x0C0);\n if (assembledTwoBytes < 0x01F00) {\n // In the 0x8140 to 0x9FFC range\n assembledTwoBytes += 0x08140;\n }\n else {\n // In the 0xE040 to 0xEBBF range\n assembledTwoBytes += 0x0C140;\n }\n buffer[offset] = /*(byte) */ (assembledTwoBytes >> 8);\n buffer[offset + 1] = /*(byte) */ assembledTwoBytes;\n offset += 2;\n count--;\n }\n // Shift_JIS may not be supported in some environments:\n try {\n result.append(StringEncoding.decode(buffer, StringUtils.SHIFT_JIS));\n // TYPESCRIPTPORT: TODO: implement SHIFT_JIS decode. StringView from MDN could be a starting point\n }\n catch (ignored /*: UnsupportedEncodingException*/) {\n throw new FormatException(ignored);\n }\n }\n static decodeByteSegment(bits, result, count /*int*/, currentCharacterSetECI, byteSegments, hints) {\n // Don't crash trying to read more bits than we have available.\n if (8 * count > bits.available()) {\n throw new FormatException();\n }\n const readBytes = new Uint8Array(count);\n for (let i = 0; i < count; i++) {\n readBytes[i] = /*(byte) */ bits.readBits(8);\n }\n let encoding;\n if (currentCharacterSetECI === null) {\n // The spec isn't clear on this mode; see\n // section 6.4.5: t does not say which encoding to assuming\n // upon decoding. I have seen ISO-8859-1 used as well as\n // Shift_JIS -- without anything like an ECI designator to\n // give a hint.\n encoding = StringUtils.guessEncoding(readBytes, hints);\n }\n else {\n encoding = currentCharacterSetECI.getName();\n }\n try {\n result.append(StringEncoding.decode(readBytes, encoding));\n }\n catch (ignored /*: UnsupportedEncodingException*/) {\n throw new FormatException(ignored);\n }\n byteSegments.push(readBytes);\n }\n static toAlphaNumericChar(value /*int*/) {\n if (value >= DecodedBitStreamParser$1.ALPHANUMERIC_CHARS.length) {\n throw new FormatException();\n }\n return DecodedBitStreamParser$1.ALPHANUMERIC_CHARS[value];\n }\n static decodeAlphanumericSegment(bits, result, count /*int*/, fc1InEffect) {\n // Read two characters at a time\n const start = result.length();\n while (count > 1) {\n if (bits.available() < 11) {\n throw new FormatException();\n }\n const nextTwoCharsBits = bits.readBits(11);\n result.append(DecodedBitStreamParser$1.toAlphaNumericChar(Math.floor(nextTwoCharsBits / 45)));\n result.append(DecodedBitStreamParser$1.toAlphaNumericChar(nextTwoCharsBits % 45));\n count -= 2;\n }\n if (count === 1) {\n // special case: one character left\n if (bits.available() < 6) {\n throw new FormatException();\n }\n result.append(DecodedBitStreamParser$1.toAlphaNumericChar(bits.readBits(6)));\n }\n // See section 6.4.8.1, 6.4.8.2\n if (fc1InEffect) {\n // We need to massage the result a bit if in an FNC1 mode:\n for (let i = start; i < result.length(); i++) {\n if (result.charAt(i) === '%') {\n if (i < result.length() - 1 && result.charAt(i + 1) === '%') {\n // %% is rendered as %\n result.deleteCharAt(i + 1);\n }\n else {\n // In alpha mode, % should be converted to FNC1 separator 0x1D\n result.setCharAt(i, String.fromCharCode(0x1D));\n }\n }\n }\n }\n }\n static decodeNumericSegment(bits, result, count /*int*/) {\n // Read three digits at a time\n while (count >= 3) {\n // Each 10 bits encodes three digits\n if (bits.available() < 10) {\n throw new FormatException();\n }\n const threeDigitsBits = bits.readBits(10);\n if (threeDigitsBits >= 1000) {\n throw new FormatException();\n }\n result.append(DecodedBitStreamParser$1.toAlphaNumericChar(Math.floor(threeDigitsBits / 100)));\n result.append(DecodedBitStreamParser$1.toAlphaNumericChar(Math.floor(threeDigitsBits / 10) % 10));\n result.append(DecodedBitStreamParser$1.toAlphaNumericChar(threeDigitsBits % 10));\n count -= 3;\n }\n if (count === 2) {\n // Two digits left over to read, encoded in 7 bits\n if (bits.available() < 7) {\n throw new FormatException();\n }\n const twoDigitsBits = bits.readBits(7);\n if (twoDigitsBits >= 100) {\n throw new FormatException();\n }\n result.append(DecodedBitStreamParser$1.toAlphaNumericChar(Math.floor(twoDigitsBits / 10)));\n result.append(DecodedBitStreamParser$1.toAlphaNumericChar(twoDigitsBits % 10));\n }\n else if (count === 1) {\n // One digit left over to read\n if (bits.available() < 4) {\n throw new FormatException();\n }\n const digitBits = bits.readBits(4);\n if (digitBits >= 10) {\n throw new FormatException();\n }\n result.append(DecodedBitStreamParser$1.toAlphaNumericChar(digitBits));\n }\n }\n static parseECIValue(bits) {\n const firstByte = bits.readBits(8);\n if ((firstByte & 0x80) === 0) {\n // just one byte\n return firstByte & 0x7F;\n }\n if ((firstByte & 0xC0) === 0x80) {\n // two bytes\n const secondByte = bits.readBits(8);\n return (((firstByte & 0x3F) << 8) & 0xFFFFFFFF) | secondByte;\n }\n if ((firstByte & 0xE0) === 0xC0) {\n // three bytes\n const secondThirdBytes = bits.readBits(16);\n return (((firstByte & 0x1F) << 16) & 0xFFFFFFFF) | secondThirdBytes;\n }\n throw new FormatException();\n }\n }\n /**\n * See ISO 18004:2006, 6.4.4 Table 5\n */\n DecodedBitStreamParser$1.ALPHANUMERIC_CHARS = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ $%*+-./:';\n DecodedBitStreamParser$1.GB2312_SUBSET = 1;\n // function Uint8ArrayToString(a: Uint8Array): string {\n // const CHUNK_SZ = 0x8000;\n // const c = new StringBuilder();\n // for (let i = 0, length = a.length; i < length; i += CHUNK_SZ) {\n // c.append(String.fromCharCode.apply(null, a.subarray(i, i + CHUNK_SZ)));\n // }\n // return c.toString();\n // }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * Meta-data container for QR Code decoding. Instances of this class may be used to convey information back to the\n * decoding caller. Callers are expected to process this.\n *\n * @see com.google.zxing.common.DecoderResult#getOther()\n */\n class QRCodeDecoderMetaData {\n constructor(mirrored) {\n this.mirrored = mirrored;\n }\n /**\n * @return true if the QR Code was mirrored.\n */\n isMirrored() {\n return this.mirrored;\n }\n /**\n * Apply the result points' order correction due to mirroring.\n *\n * @param points Array of points to apply mirror correction to.\n */\n applyMirroredCorrection(points) {\n if (!this.mirrored || points === null || points.length < 3) {\n return;\n }\n const bottomLeft = points[0];\n points[0] = points[2];\n points[2] = bottomLeft;\n // No need to 'fix' top-left and alignment pattern.\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.util.Map;*/\n /**\n *

The main class which implements QR Code decoding -- as opposed to locating and extracting\n * the QR Code from an image.

\n *\n * @author Sean Owen\n */\n class Decoder$2 {\n constructor() {\n this.rsDecoder = new ReedSolomonDecoder(GenericGF.QR_CODE_FIELD_256);\n }\n // public decode(image: boolean[][]): DecoderResult /*throws ChecksumException, FormatException*/ {\n // return decode(image, null)\n // }\n /**\n *

Convenience method that can decode a QR Code represented as a 2D array of booleans.\n * \"true\" is taken to mean a black module.

\n *\n * @param image booleans representing white/black QR Code modules\n * @param hints decoding hints that should be used to influence decoding\n * @return text and bytes encoded within the QR Code\n * @throws FormatException if the QR Code cannot be decoded\n * @throws ChecksumException if error correction fails\n */\n decodeBooleanArray(image, hints) {\n return this.decodeBitMatrix(BitMatrix.parseFromBooleanArray(image), hints);\n }\n // public decodeBitMatrix(bits: BitMatrix): DecoderResult /*throws ChecksumException, FormatException*/ {\n // return decode(bits, null)\n // }\n /**\n *

Decodes a QR Code represented as a {@link BitMatrix}. A 1 or \"true\" is taken to mean a black module.

\n *\n * @param bits booleans representing white/black QR Code modules\n * @param hints decoding hints that should be used to influence decoding\n * @return text and bytes encoded within the QR Code\n * @throws FormatException if the QR Code cannot be decoded\n * @throws ChecksumException if error correction fails\n */\n decodeBitMatrix(bits, hints) {\n // Construct a parser and read version, error-correction level\n const parser = new BitMatrixParser$1(bits);\n let ex = null;\n try {\n return this.decodeBitMatrixParser(parser, hints);\n }\n catch (e /*: FormatException, ChecksumException*/) {\n ex = e;\n }\n try {\n // Revert the bit matrix\n parser.remask();\n // Will be attempting a mirrored reading of the version and format info.\n parser.setMirror(true);\n // Preemptively read the version.\n parser.readVersion();\n // Preemptively read the format information.\n parser.readFormatInformation();\n /*\n * Since we're here, this means we have successfully detected some kind\n * of version and format information when mirrored. This is a good sign,\n * that the QR code may be mirrored, and we should try once more with a\n * mirrored content.\n */\n // Prepare for a mirrored reading.\n parser.mirror();\n const result = this.decodeBitMatrixParser(parser, hints);\n // Success! Notify the caller that the code was mirrored.\n result.setOther(new QRCodeDecoderMetaData(true));\n return result;\n }\n catch (e /*FormatException | ChecksumException*/) {\n // Throw the exception from the original reading\n if (ex !== null) {\n throw ex;\n }\n throw e;\n }\n }\n decodeBitMatrixParser(parser, hints) {\n const version = parser.readVersion();\n const ecLevel = parser.readFormatInformation().getErrorCorrectionLevel();\n // Read codewords\n const codewords = parser.readCodewords();\n // Separate into data blocks\n const dataBlocks = DataBlock$1.getDataBlocks(codewords, version, ecLevel);\n // Count total number of data bytes\n let totalBytes = 0;\n for (const dataBlock of dataBlocks) {\n totalBytes += dataBlock.getNumDataCodewords();\n }\n const resultBytes = new Uint8Array(totalBytes);\n let resultOffset = 0;\n // Error-correct and copy data blocks together into a stream of bytes\n for (const dataBlock of dataBlocks) {\n const codewordBytes = dataBlock.getCodewords();\n const numDataCodewords = dataBlock.getNumDataCodewords();\n this.correctErrors(codewordBytes, numDataCodewords);\n for (let i = 0; i < numDataCodewords; i++) {\n resultBytes[resultOffset++] = codewordBytes[i];\n }\n }\n // Decode the contents of that stream of bytes\n return DecodedBitStreamParser$1.decode(resultBytes, version, ecLevel, hints);\n }\n /**\n *

Given data and error-correction codewords received, possibly corrupted by errors, attempts to\n * correct the errors in-place using Reed-Solomon error correction.

\n *\n * @param codewordBytes data and error correction codewords\n * @param numDataCodewords number of codewords that are data bytes\n * @throws ChecksumException if error correction fails\n */\n correctErrors(codewordBytes, numDataCodewords /*int*/) {\n // const numCodewords = codewordBytes.length;\n // First read into an array of ints\n const codewordsInts = new Int32Array(codewordBytes);\n // TYPESCRIPTPORT: not realy necessary to transform to ints? could redesign everything to work with unsigned bytes?\n // const codewordsInts = new Int32Array(numCodewords)\n // for (let i = 0; i < numCodewords; i++) {\n // codewordsInts[i] = codewordBytes[i] & 0xFF\n // }\n try {\n this.rsDecoder.decode(codewordsInts, codewordBytes.length - numDataCodewords);\n }\n catch (ignored /*: ReedSolomonException*/) {\n throw new ChecksumException();\n }\n // Copy back into array of bytes -- only need to worry about the bytes that were data\n // We don't care about errors in the error-correction codewords\n for (let i = 0; i < numDataCodewords; i++) {\n codewordBytes[i] = /*(byte) */ codewordsInts[i];\n }\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates an alignment pattern, which are the smaller square patterns found in\n * all but the simplest QR Codes.

\n *\n * @author Sean Owen\n */\n class AlignmentPattern extends ResultPoint {\n constructor(posX /*float*/, posY /*float*/, estimatedModuleSize /*float*/) {\n super(posX, posY);\n this.estimatedModuleSize = estimatedModuleSize;\n }\n /**\n *

Determines if this alignment pattern \"about equals\" an alignment pattern at the stated\n * position and size -- meaning, it is at nearly the same center with nearly the same size.

\n */\n aboutEquals(moduleSize /*float*/, i /*float*/, j /*float*/) {\n if (Math.abs(i - this.getY()) <= moduleSize && Math.abs(j - this.getX()) <= moduleSize) {\n const moduleSizeDiff = Math.abs(moduleSize - this.estimatedModuleSize);\n return moduleSizeDiff <= 1.0 || moduleSizeDiff <= this.estimatedModuleSize;\n }\n return false;\n }\n /**\n * Combines this object's current estimate of a finder pattern position and module size\n * with a new estimate. It returns a new {@code FinderPattern} containing an average of the two.\n */\n combineEstimate(i /*float*/, j /*float*/, newModuleSize /*float*/) {\n const combinedX = (this.getX() + j) / 2.0;\n const combinedY = (this.getY() + i) / 2.0;\n const combinedModuleSize = (this.estimatedModuleSize + newModuleSize) / 2.0;\n return new AlignmentPattern(combinedX, combinedY, combinedModuleSize);\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.util.ArrayList;*/\n /*import java.util.List;*/\n /**\n *

This class attempts to find alignment patterns in a QR Code. Alignment patterns look like finder\n * patterns but are smaller and appear at regular intervals throughout the image.

\n *\n *

At the moment this only looks for the bottom-right alignment pattern.

\n *\n *

This is mostly a simplified copy of {@link FinderPatternFinder}. It is copied,\n * pasted and stripped down here for maximum performance but does unfortunately duplicate\n * some code.

\n *\n *

This class is thread-safe but not reentrant. Each thread must allocate its own object.

\n *\n * @author Sean Owen\n */\n class AlignmentPatternFinder {\n /**\n *

Creates a finder that will look in a portion of the whole image.

\n *\n * @param image image to search\n * @param startX left column from which to start searching\n * @param startY top row from which to start searching\n * @param width width of region to search\n * @param height height of region to search\n * @param moduleSize estimated module size so far\n */\n constructor(image, startX /*int*/, startY /*int*/, width /*int*/, height /*int*/, moduleSize /*float*/, resultPointCallback) {\n this.image = image;\n this.startX = startX;\n this.startY = startY;\n this.width = width;\n this.height = height;\n this.moduleSize = moduleSize;\n this.resultPointCallback = resultPointCallback;\n this.possibleCenters = []; // new Array(5))\n // TYPESCRIPTPORT: array initialization without size as the length is checked below\n this.crossCheckStateCount = new Int32Array(3);\n }\n /**\n *

This method attempts to find the bottom-right alignment pattern in the image. It is a bit messy since\n * it's pretty performance-critical and so is written to be fast foremost.

\n *\n * @return {@link AlignmentPattern} if found\n * @throws NotFoundException if not found\n */\n find() {\n const startX = this.startX;\n const height = this.height;\n const width = this.width;\n const maxJ = startX + width;\n const middleI = this.startY + (height / 2);\n // We are looking for black/white/black modules in 1:1:1 ratio\n // this tracks the number of black/white/black modules seen so far\n const stateCount = new Int32Array(3);\n const image = this.image;\n for (let iGen = 0; iGen < height; iGen++) {\n // Search from middle outwards\n const i = middleI + ((iGen & 0x01) === 0 ? Math.floor((iGen + 1) / 2) : -Math.floor((iGen + 1) / 2));\n stateCount[0] = 0;\n stateCount[1] = 0;\n stateCount[2] = 0;\n let j = startX;\n // Burn off leading white pixels before anything else; if we start in the middle of\n // a white run, it doesn't make sense to count its length, since we don't know if the\n // white run continued to the left of the start point\n while (j < maxJ && !image.get(j, i)) {\n j++;\n }\n let currentState = 0;\n while (j < maxJ) {\n if (image.get(j, i)) {\n // Black pixel\n if (currentState === 1) { // Counting black pixels\n stateCount[1]++;\n }\n else { // Counting white pixels\n if (currentState === 2) { // A winner?\n if (this.foundPatternCross(stateCount)) { // Yes\n const confirmed = this.handlePossibleCenter(stateCount, i, j);\n if (confirmed !== null) {\n return confirmed;\n }\n }\n stateCount[0] = stateCount[2];\n stateCount[1] = 1;\n stateCount[2] = 0;\n currentState = 1;\n }\n else {\n stateCount[++currentState]++;\n }\n }\n }\n else { // White pixel\n if (currentState === 1) { // Counting black pixels\n currentState++;\n }\n stateCount[currentState]++;\n }\n j++;\n }\n if (this.foundPatternCross(stateCount)) {\n const confirmed = this.handlePossibleCenter(stateCount, i, maxJ);\n if (confirmed !== null) {\n return confirmed;\n }\n }\n }\n // Hmm, nothing we saw was observed and confirmed twice. If we had\n // any guess at all, return it.\n if (this.possibleCenters.length !== 0) {\n return this.possibleCenters[0];\n }\n throw new NotFoundException();\n }\n /**\n * Given a count of black/white/black pixels just seen and an end position,\n * figures the location of the center of this black/white/black run.\n */\n static centerFromEnd(stateCount, end /*int*/) {\n return (end - stateCount[2]) - stateCount[1] / 2.0;\n }\n /**\n * @param stateCount count of black/white/black pixels just read\n * @return true iff the proportions of the counts is close enough to the 1/1/1 ratios\n * used by alignment patterns to be considered a match\n */\n foundPatternCross(stateCount) {\n const moduleSize = this.moduleSize;\n const maxVariance = moduleSize / 2.0;\n for (let i = 0; i < 3; i++) {\n if (Math.abs(moduleSize - stateCount[i]) >= maxVariance) {\n return false;\n }\n }\n return true;\n }\n /**\n *

After a horizontal scan finds a potential alignment pattern, this method\n * \"cross-checks\" by scanning down vertically through the center of the possible\n * alignment pattern to see if the same proportion is detected.

\n *\n * @param startI row where an alignment pattern was detected\n * @param centerJ center of the section that appears to cross an alignment pattern\n * @param maxCount maximum reasonable number of modules that should be\n * observed in any reading state, based on the results of the horizontal scan\n * @return vertical center of alignment pattern, or {@link Float#NaN} if not found\n */\n crossCheckVertical(startI /*int*/, centerJ /*int*/, maxCount /*int*/, originalStateCountTotal /*int*/) {\n const image = this.image;\n const maxI = image.getHeight();\n const stateCount = this.crossCheckStateCount;\n stateCount[0] = 0;\n stateCount[1] = 0;\n stateCount[2] = 0;\n // Start counting up from center\n let i = startI;\n while (i >= 0 && image.get(centerJ, i) && stateCount[1] <= maxCount) {\n stateCount[1]++;\n i--;\n }\n // If already too many modules in this state or ran off the edge:\n if (i < 0 || stateCount[1] > maxCount) {\n return NaN;\n }\n while (i >= 0 && !image.get(centerJ, i) && stateCount[0] <= maxCount) {\n stateCount[0]++;\n i--;\n }\n if (stateCount[0] > maxCount) {\n return NaN;\n }\n // Now also count down from center\n i = startI + 1;\n while (i < maxI && image.get(centerJ, i) && stateCount[1] <= maxCount) {\n stateCount[1]++;\n i++;\n }\n if (i === maxI || stateCount[1] > maxCount) {\n return NaN;\n }\n while (i < maxI && !image.get(centerJ, i) && stateCount[2] <= maxCount) {\n stateCount[2]++;\n i++;\n }\n if (stateCount[2] > maxCount) {\n return NaN;\n }\n const stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2];\n if (5 * Math.abs(stateCountTotal - originalStateCountTotal) >= 2 * originalStateCountTotal) {\n return NaN;\n }\n return this.foundPatternCross(stateCount) ? AlignmentPatternFinder.centerFromEnd(stateCount, i) : NaN;\n }\n /**\n *

This is called when a horizontal scan finds a possible alignment pattern. It will\n * cross check with a vertical scan, and if successful, will see if this pattern had been\n * found on a previous horizontal scan. If so, we consider it confirmed and conclude we have\n * found the alignment pattern.

\n *\n * @param stateCount reading state module counts from horizontal scan\n * @param i row where alignment pattern may be found\n * @param j end of possible alignment pattern in row\n * @return {@link AlignmentPattern} if we have found the same pattern twice, or null if not\n */\n handlePossibleCenter(stateCount, i /*int*/, j /*int*/) {\n const stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2];\n const centerJ = AlignmentPatternFinder.centerFromEnd(stateCount, j);\n const centerI = this.crossCheckVertical(i, /*(int) */ centerJ, 2 * stateCount[1], stateCountTotal);\n if (!isNaN(centerI)) {\n const estimatedModuleSize = (stateCount[0] + stateCount[1] + stateCount[2]) / 3.0;\n for (const center of this.possibleCenters) {\n // Look for about the same center and module size:\n if (center.aboutEquals(estimatedModuleSize, centerI, centerJ)) {\n return center.combineEstimate(centerI, centerJ, estimatedModuleSize);\n }\n }\n // Hadn't found this before; save it\n const point = new AlignmentPattern(centerJ, centerI, estimatedModuleSize);\n this.possibleCenters.push(point);\n if (this.resultPointCallback !== null && this.resultPointCallback !== undefined) {\n this.resultPointCallback.foundPossibleResultPoint(point);\n }\n }\n return null;\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates a finder pattern, which are the three square patterns found in\n * the corners of QR Codes. It also encapsulates a count of similar finder patterns,\n * as a convenience to the finder's bookkeeping.

\n *\n * @author Sean Owen\n */\n class FinderPattern$1 extends ResultPoint {\n // FinderPattern(posX: number/*float*/, posY: number/*float*/, estimatedModuleSize: number/*float*/) {\n // this(posX, posY, estimatedModuleSize, 1)\n // }\n constructor(posX /*float*/, posY /*float*/, estimatedModuleSize /*float*/, count /*int*/) {\n super(posX, posY);\n this.estimatedModuleSize = estimatedModuleSize;\n this.count = count;\n if (undefined === count) {\n this.count = 1;\n }\n }\n getEstimatedModuleSize() {\n return this.estimatedModuleSize;\n }\n getCount() {\n return this.count;\n }\n /*\n void incrementCount() {\n this.count++\n }\n */\n /**\n *

Determines if this finder pattern \"about equals\" a finder pattern at the stated\n * position and size -- meaning, it is at nearly the same center with nearly the same size.

\n */\n aboutEquals(moduleSize /*float*/, i /*float*/, j /*float*/) {\n if (Math.abs(i - this.getY()) <= moduleSize && Math.abs(j - this.getX()) <= moduleSize) {\n const moduleSizeDiff = Math.abs(moduleSize - this.estimatedModuleSize);\n return moduleSizeDiff <= 1.0 || moduleSizeDiff <= this.estimatedModuleSize;\n }\n return false;\n }\n /**\n * Combines this object's current estimate of a finder pattern position and module size\n * with a new estimate. It returns a new {@code FinderPattern} containing a weighted average\n * based on count.\n */\n combineEstimate(i /*float*/, j /*float*/, newModuleSize /*float*/) {\n const combinedCount = this.count + 1;\n const combinedX = (this.count * this.getX() + j) / combinedCount;\n const combinedY = (this.count * this.getY() + i) / combinedCount;\n const combinedModuleSize = (this.count * this.estimatedModuleSize + newModuleSize) / combinedCount;\n return new FinderPattern$1(combinedX, combinedY, combinedModuleSize, combinedCount);\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Encapsulates information about finder patterns in an image, including the location of\n * the three finder patterns, and their estimated module size.

\n *\n * @author Sean Owen\n */\n class FinderPatternInfo {\n constructor(patternCenters) {\n this.bottomLeft = patternCenters[0];\n this.topLeft = patternCenters[1];\n this.topRight = patternCenters[2];\n }\n getBottomLeft() {\n return this.bottomLeft;\n }\n getTopLeft() {\n return this.topLeft;\n }\n getTopRight() {\n return this.topRight;\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.io.Serializable;*/\n /*import java.util.ArrayList;*/\n /*import java.util.Collections;*/\n /*import java.util.Comparator;*/\n /*import java.util.List;*/\n /*import java.util.Map;*/\n /**\n *

This class attempts to find finder patterns in a QR Code. Finder patterns are the square\n * markers at three corners of a QR Code.

\n *\n *

This class is thread-safe but not reentrant. Each thread must allocate its own object.\n *\n * @author Sean Owen\n */\n class FinderPatternFinder {\n /**\n *

Creates a finder that will search the image for three finder patterns.

\n *\n * @param image image to search\n */\n // public constructor(image: BitMatrix) {\n // this(image, null)\n // }\n constructor(image, resultPointCallback) {\n this.image = image;\n this.resultPointCallback = resultPointCallback;\n this.possibleCenters = [];\n this.crossCheckStateCount = new Int32Array(5);\n this.resultPointCallback = resultPointCallback;\n }\n getImage() {\n return this.image;\n }\n getPossibleCenters() {\n return this.possibleCenters;\n }\n find(hints) {\n const tryHarder = (hints !== null && hints !== undefined) && undefined !== hints.get(DecodeHintType$1.TRY_HARDER);\n const pureBarcode = (hints !== null && hints !== undefined) && undefined !== hints.get(DecodeHintType$1.PURE_BARCODE);\n const image = this.image;\n const maxI = image.getHeight();\n const maxJ = image.getWidth();\n // We are looking for black/white/black/white/black modules in\n // 1:1:3:1:1 ratio; this tracks the number of such modules seen so far\n // Let's assume that the maximum version QR Code we support takes up 1/4 the height of the\n // image, and then account for the center being 3 modules in size. This gives the smallest\n // number of pixels the center could be, so skip this often. When trying harder, look for all\n // QR versions regardless of how dense they are.\n let iSkip = Math.floor((3 * maxI) / (4 * FinderPatternFinder.MAX_MODULES));\n if (iSkip < FinderPatternFinder.MIN_SKIP || tryHarder) {\n iSkip = FinderPatternFinder.MIN_SKIP;\n }\n let done = false;\n const stateCount = new Int32Array(5);\n for (let i = iSkip - 1; i < maxI && !done; i += iSkip) {\n // Get a row of black/white values\n stateCount[0] = 0;\n stateCount[1] = 0;\n stateCount[2] = 0;\n stateCount[3] = 0;\n stateCount[4] = 0;\n let currentState = 0;\n for (let j = 0; j < maxJ; j++) {\n if (image.get(j, i)) {\n // Black pixel\n if ((currentState & 1) === 1) { // Counting white pixels\n currentState++;\n }\n stateCount[currentState]++;\n }\n else { // White pixel\n if ((currentState & 1) === 0) { // Counting black pixels\n if (currentState === 4) { // A winner?\n if (FinderPatternFinder.foundPatternCross(stateCount)) { // Yes\n const confirmed = this.handlePossibleCenter(stateCount, i, j, pureBarcode);\n if (confirmed === true) {\n // Start examining every other line. Checking each line turned out to be too\n // expensive and didn't improve performance.\n iSkip = 2;\n if (this.hasSkipped === true) {\n done = this.haveMultiplyConfirmedCenters();\n }\n else {\n const rowSkip = this.findRowSkip();\n if (rowSkip > stateCount[2]) {\n // Skip rows between row of lower confirmed center\n // and top of presumed third confirmed center\n // but back up a bit to get a full chance of detecting\n // it, entire width of center of finder pattern\n // Skip by rowSkip, but back off by stateCount[2] (size of last center\n // of pattern we saw) to be conservative, and also back off by iSkip which\n // is about to be re-added\n i += rowSkip - stateCount[2] - iSkip;\n j = maxJ - 1;\n }\n }\n }\n else {\n stateCount[0] = stateCount[2];\n stateCount[1] = stateCount[3];\n stateCount[2] = stateCount[4];\n stateCount[3] = 1;\n stateCount[4] = 0;\n currentState = 3;\n continue;\n }\n // Clear state to start looking again\n currentState = 0;\n stateCount[0] = 0;\n stateCount[1] = 0;\n stateCount[2] = 0;\n stateCount[3] = 0;\n stateCount[4] = 0;\n }\n else { // No, shift counts back by two\n stateCount[0] = stateCount[2];\n stateCount[1] = stateCount[3];\n stateCount[2] = stateCount[4];\n stateCount[3] = 1;\n stateCount[4] = 0;\n currentState = 3;\n }\n }\n else {\n stateCount[++currentState]++;\n }\n }\n else { // Counting white pixels\n stateCount[currentState]++;\n }\n }\n }\n if (FinderPatternFinder.foundPatternCross(stateCount)) {\n const confirmed = this.handlePossibleCenter(stateCount, i, maxJ, pureBarcode);\n if (confirmed === true) {\n iSkip = stateCount[0];\n if (this.hasSkipped) {\n // Found a third one\n done = this.haveMultiplyConfirmedCenters();\n }\n }\n }\n }\n const patternInfo = this.selectBestPatterns();\n ResultPoint.orderBestPatterns(patternInfo);\n return new FinderPatternInfo(patternInfo);\n }\n /**\n * Given a count of black/white/black/white/black pixels just seen and an end position,\n * figures the location of the center of this run.\n */\n static centerFromEnd(stateCount, end /*int*/) {\n return (end - stateCount[4] - stateCount[3]) - stateCount[2] / 2.0;\n }\n /**\n * @param stateCount count of black/white/black/white/black pixels just read\n * @return true iff the proportions of the counts is close enough to the 1/1/3/1/1 ratios\n * used by finder patterns to be considered a match\n */\n static foundPatternCross(stateCount) {\n let totalModuleSize = 0;\n for (let i = 0; i < 5; i++) {\n const count = stateCount[i];\n if (count === 0) {\n return false;\n }\n totalModuleSize += count;\n }\n if (totalModuleSize < 7) {\n return false;\n }\n const moduleSize = totalModuleSize / 7.0;\n const maxVariance = moduleSize / 2.0;\n // Allow less than 50% variance from 1-1-3-1-1 proportions\n return Math.abs(moduleSize - stateCount[0]) < maxVariance &&\n Math.abs(moduleSize - stateCount[1]) < maxVariance &&\n Math.abs(3.0 * moduleSize - stateCount[2]) < 3 * maxVariance &&\n Math.abs(moduleSize - stateCount[3]) < maxVariance &&\n Math.abs(moduleSize - stateCount[4]) < maxVariance;\n }\n getCrossCheckStateCount() {\n const crossCheckStateCount = this.crossCheckStateCount;\n crossCheckStateCount[0] = 0;\n crossCheckStateCount[1] = 0;\n crossCheckStateCount[2] = 0;\n crossCheckStateCount[3] = 0;\n crossCheckStateCount[4] = 0;\n return crossCheckStateCount;\n }\n /**\n * After a vertical and horizontal scan finds a potential finder pattern, this method\n * \"cross-cross-cross-checks\" by scanning down diagonally through the center of the possible\n * finder pattern to see if the same proportion is detected.\n *\n * @param startI row where a finder pattern was detected\n * @param centerJ center of the section that appears to cross a finder pattern\n * @param maxCount maximum reasonable number of modules that should be\n * observed in any reading state, based on the results of the horizontal scan\n * @param originalStateCountTotal The original state count total.\n * @return true if proportions are withing expected limits\n */\n crossCheckDiagonal(startI /*int*/, centerJ /*int*/, maxCount /*int*/, originalStateCountTotal /*int*/) {\n const stateCount = this.getCrossCheckStateCount();\n // Start counting up, left from center finding black center mass\n let i = 0;\n const image = this.image;\n while (startI >= i && centerJ >= i && image.get(centerJ - i, startI - i)) {\n stateCount[2]++;\n i++;\n }\n if (startI < i || centerJ < i) {\n return false;\n }\n // Continue up, left finding white space\n while (startI >= i && centerJ >= i && !image.get(centerJ - i, startI - i) &&\n stateCount[1] <= maxCount) {\n stateCount[1]++;\n i++;\n }\n // If already too many modules in this state or ran off the edge:\n if (startI < i || centerJ < i || stateCount[1] > maxCount) {\n return false;\n }\n // Continue up, left finding black border\n while (startI >= i && centerJ >= i && image.get(centerJ - i, startI - i) &&\n stateCount[0] <= maxCount) {\n stateCount[0]++;\n i++;\n }\n if (stateCount[0] > maxCount) {\n return false;\n }\n const maxI = image.getHeight();\n const maxJ = image.getWidth();\n // Now also count down, right from center\n i = 1;\n while (startI + i < maxI && centerJ + i < maxJ && image.get(centerJ + i, startI + i)) {\n stateCount[2]++;\n i++;\n }\n // Ran off the edge?\n if (startI + i >= maxI || centerJ + i >= maxJ) {\n return false;\n }\n while (startI + i < maxI && centerJ + i < maxJ && !image.get(centerJ + i, startI + i) &&\n stateCount[3] < maxCount) {\n stateCount[3]++;\n i++;\n }\n if (startI + i >= maxI || centerJ + i >= maxJ || stateCount[3] >= maxCount) {\n return false;\n }\n while (startI + i < maxI && centerJ + i < maxJ && image.get(centerJ + i, startI + i) &&\n stateCount[4] < maxCount) {\n stateCount[4]++;\n i++;\n }\n if (stateCount[4] >= maxCount) {\n return false;\n }\n // If we found a finder-pattern-like section, but its size is more than 100% different than\n // the original, assume it's a false positive\n const stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2] + stateCount[3] + stateCount[4];\n return Math.abs(stateCountTotal - originalStateCountTotal) < 2 * originalStateCountTotal &&\n FinderPatternFinder.foundPatternCross(stateCount);\n }\n /**\n *

After a horizontal scan finds a potential finder pattern, this method\n * \"cross-checks\" by scanning down vertically through the center of the possible\n * finder pattern to see if the same proportion is detected.

\n *\n * @param startI row where a finder pattern was detected\n * @param centerJ center of the section that appears to cross a finder pattern\n * @param maxCount maximum reasonable number of modules that should be\n * observed in any reading state, based on the results of the horizontal scan\n * @return vertical center of finder pattern, or {@link Float#NaN} if not found\n */\n crossCheckVertical(startI /*int*/, centerJ /*int*/, maxCount /*int*/, originalStateCountTotal /*int*/) {\n const image = this.image;\n const maxI = image.getHeight();\n const stateCount = this.getCrossCheckStateCount();\n // Start counting up from center\n let i = startI;\n while (i >= 0 && image.get(centerJ, i)) {\n stateCount[2]++;\n i--;\n }\n if (i < 0) {\n return NaN;\n }\n while (i >= 0 && !image.get(centerJ, i) && stateCount[1] <= maxCount) {\n stateCount[1]++;\n i--;\n }\n // If already too many modules in this state or ran off the edge:\n if (i < 0 || stateCount[1] > maxCount) {\n return NaN;\n }\n while (i >= 0 && image.get(centerJ, i) && stateCount[0] <= maxCount) {\n stateCount[0]++;\n i--;\n }\n if (stateCount[0] > maxCount) {\n return NaN;\n }\n // Now also count down from center\n i = startI + 1;\n while (i < maxI && image.get(centerJ, i)) {\n stateCount[2]++;\n i++;\n }\n if (i === maxI) {\n return NaN;\n }\n while (i < maxI && !image.get(centerJ, i) && stateCount[3] < maxCount) {\n stateCount[3]++;\n i++;\n }\n if (i === maxI || stateCount[3] >= maxCount) {\n return NaN;\n }\n while (i < maxI && image.get(centerJ, i) && stateCount[4] < maxCount) {\n stateCount[4]++;\n i++;\n }\n if (stateCount[4] >= maxCount) {\n return NaN;\n }\n // If we found a finder-pattern-like section, but its size is more than 40% different than\n // the original, assume it's a false positive\n const stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2] + stateCount[3] +\n stateCount[4];\n if (5 * Math.abs(stateCountTotal - originalStateCountTotal) >= 2 * originalStateCountTotal) {\n return NaN;\n }\n return FinderPatternFinder.foundPatternCross(stateCount) ? FinderPatternFinder.centerFromEnd(stateCount, i) : NaN;\n }\n /**\n *

Like {@link #crossCheckVertical(int, int, int, int)}, and in fact is basically identical,\n * except it reads horizontally instead of vertically. This is used to cross-cross\n * check a vertical cross check and locate the real center of the alignment pattern.

\n */\n crossCheckHorizontal(startJ /*int*/, centerI /*int*/, maxCount /*int*/, originalStateCountTotal /*int*/) {\n const image = this.image;\n const maxJ = image.getWidth();\n const stateCount = this.getCrossCheckStateCount();\n let j = startJ;\n while (j >= 0 && image.get(j, centerI)) {\n stateCount[2]++;\n j--;\n }\n if (j < 0) {\n return NaN;\n }\n while (j >= 0 && !image.get(j, centerI) && stateCount[1] <= maxCount) {\n stateCount[1]++;\n j--;\n }\n if (j < 0 || stateCount[1] > maxCount) {\n return NaN;\n }\n while (j >= 0 && image.get(j, centerI) && stateCount[0] <= maxCount) {\n stateCount[0]++;\n j--;\n }\n if (stateCount[0] > maxCount) {\n return NaN;\n }\n j = startJ + 1;\n while (j < maxJ && image.get(j, centerI)) {\n stateCount[2]++;\n j++;\n }\n if (j === maxJ) {\n return NaN;\n }\n while (j < maxJ && !image.get(j, centerI) && stateCount[3] < maxCount) {\n stateCount[3]++;\n j++;\n }\n if (j === maxJ || stateCount[3] >= maxCount) {\n return NaN;\n }\n while (j < maxJ && image.get(j, centerI) && stateCount[4] < maxCount) {\n stateCount[4]++;\n j++;\n }\n if (stateCount[4] >= maxCount) {\n return NaN;\n }\n // If we found a finder-pattern-like section, but its size is significantly different than\n // the original, assume it's a false positive\n const stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2] + stateCount[3] +\n stateCount[4];\n if (5 * Math.abs(stateCountTotal - originalStateCountTotal) >= originalStateCountTotal) {\n return NaN;\n }\n return FinderPatternFinder.foundPatternCross(stateCount) ? FinderPatternFinder.centerFromEnd(stateCount, j) : NaN;\n }\n /**\n *

This is called when a horizontal scan finds a possible alignment pattern. It will\n * cross check with a vertical scan, and if successful, will, ah, cross-cross-check\n * with another horizontal scan. This is needed primarily to locate the real horizontal\n * center of the pattern in cases of extreme skew.\n * And then we cross-cross-cross check with another diagonal scan.

\n *\n *

If that succeeds the finder pattern location is added to a list that tracks\n * the number of times each location has been nearly-matched as a finder pattern.\n * Each additional find is more evidence that the location is in fact a finder\n * pattern center\n *\n * @param stateCount reading state module counts from horizontal scan\n * @param i row where finder pattern may be found\n * @param j end of possible finder pattern in row\n * @param pureBarcode true if in \"pure barcode\" mode\n * @return true if a finder pattern candidate was found this time\n */\n handlePossibleCenter(stateCount, i /*int*/, j /*int*/, pureBarcode) {\n const stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2] + stateCount[3] +\n stateCount[4];\n let centerJ = FinderPatternFinder.centerFromEnd(stateCount, j);\n let centerI = this.crossCheckVertical(i, /*(int) */ Math.floor(centerJ), stateCount[2], stateCountTotal);\n if (!isNaN(centerI)) {\n // Re-cross check\n centerJ = this.crossCheckHorizontal(/*(int) */ Math.floor(centerJ), /*(int) */ Math.floor(centerI), stateCount[2], stateCountTotal);\n if (!isNaN(centerJ) &&\n (!pureBarcode || this.crossCheckDiagonal(/*(int) */ Math.floor(centerI), /*(int) */ Math.floor(centerJ), stateCount[2], stateCountTotal))) {\n const estimatedModuleSize = stateCountTotal / 7.0;\n let found = false;\n const possibleCenters = this.possibleCenters;\n for (let index = 0, length = possibleCenters.length; index < length; index++) {\n const center = possibleCenters[index];\n // Look for about the same center and module size:\n if (center.aboutEquals(estimatedModuleSize, centerI, centerJ)) {\n possibleCenters[index] = center.combineEstimate(centerI, centerJ, estimatedModuleSize);\n found = true;\n break;\n }\n }\n if (!found) {\n const point = new FinderPattern$1(centerJ, centerI, estimatedModuleSize);\n possibleCenters.push(point);\n if (this.resultPointCallback !== null && this.resultPointCallback !== undefined) {\n this.resultPointCallback.foundPossibleResultPoint(point);\n }\n }\n return true;\n }\n }\n return false;\n }\n /**\n * @return number of rows we could safely skip during scanning, based on the first\n * two finder patterns that have been located. In some cases their position will\n * allow us to infer that the third pattern must lie below a certain point farther\n * down in the image.\n */\n findRowSkip() {\n const max = this.possibleCenters.length;\n if (max <= 1) {\n return 0;\n }\n let firstConfirmedCenter = null;\n for (const center of this.possibleCenters) {\n if (center.getCount() >= FinderPatternFinder.CENTER_QUORUM) {\n if (firstConfirmedCenter == null) {\n firstConfirmedCenter = center;\n }\n else {\n // We have two confirmed centers\n // How far down can we skip before resuming looking for the next\n // pattern? In the worst case, only the difference between the\n // difference in the x / y coordinates of the two centers.\n // This is the case where you find top left last.\n this.hasSkipped = true;\n return /*(int) */ Math.floor((Math.abs(firstConfirmedCenter.getX() - center.getX()) -\n Math.abs(firstConfirmedCenter.getY() - center.getY())) / 2);\n }\n }\n }\n return 0;\n }\n /**\n * @return true iff we have found at least 3 finder patterns that have been detected\n * at least {@link #CENTER_QUORUM} times each, and, the estimated module size of the\n * candidates is \"pretty similar\"\n */\n haveMultiplyConfirmedCenters() {\n let confirmedCount = 0;\n let totalModuleSize = 0.0;\n const max = this.possibleCenters.length;\n for (const pattern of this.possibleCenters) {\n if (pattern.getCount() >= FinderPatternFinder.CENTER_QUORUM) {\n confirmedCount++;\n totalModuleSize += pattern.getEstimatedModuleSize();\n }\n }\n if (confirmedCount < 3) {\n return false;\n }\n // OK, we have at least 3 confirmed centers, but, it's possible that one is a \"false positive\"\n // and that we need to keep looking. We detect this by asking if the estimated module sizes\n // vary too much. We arbitrarily say that when the total deviation from average exceeds\n // 5% of the total module size estimates, it's too much.\n const average = totalModuleSize / max;\n let totalDeviation = 0.0;\n for (const pattern of this.possibleCenters) {\n totalDeviation += Math.abs(pattern.getEstimatedModuleSize() - average);\n }\n return totalDeviation <= 0.05 * totalModuleSize;\n }\n /**\n * @return the 3 best {@link FinderPattern}s from our list of candidates. The \"best\" are\n * those that have been detected at least {@link #CENTER_QUORUM} times, and whose module\n * size differs from the average among those patterns the least\n * @throws NotFoundException if 3 such finder patterns do not exist\n */\n selectBestPatterns() {\n const startSize = this.possibleCenters.length;\n if (startSize < 3) {\n // Couldn't find enough finder patterns\n throw new NotFoundException();\n }\n const possibleCenters = this.possibleCenters;\n let average;\n // Filter outlier possibilities whose module size is too different\n if (startSize > 3) {\n // But we can only afford to do so if we have at least 4 possibilities to choose from\n let totalModuleSize = 0.0;\n let square = 0.0;\n for (const center of this.possibleCenters) {\n const size = center.getEstimatedModuleSize();\n totalModuleSize += size;\n square += size * size;\n }\n average = totalModuleSize / startSize;\n let stdDev = Math.sqrt(square / startSize - average * average);\n possibleCenters.sort(\n /**\n *

Orders by furthest from average

\n */\n // FurthestFromAverageComparator implements Comparator\n (center1, center2) => {\n const dA = Math.abs(center2.getEstimatedModuleSize() - average);\n const dB = Math.abs(center1.getEstimatedModuleSize() - average);\n return dA < dB ? -1 : dA > dB ? 1 : 0;\n });\n const limit = Math.max(0.2 * average, stdDev);\n for (let i = 0; i < possibleCenters.length && possibleCenters.length > 3; i++) {\n const pattern = possibleCenters[i];\n if (Math.abs(pattern.getEstimatedModuleSize() - average) > limit) {\n possibleCenters.splice(i, 1);\n i--;\n }\n }\n }\n if (possibleCenters.length > 3) {\n // Throw away all but those first size candidate points we found.\n let totalModuleSize = 0.0;\n for (const possibleCenter of possibleCenters) {\n totalModuleSize += possibleCenter.getEstimatedModuleSize();\n }\n average = totalModuleSize / possibleCenters.length;\n possibleCenters.sort(\n /**\n *

Orders by {@link FinderPattern#getCount()}, descending.

\n */\n // CenterComparator implements Comparator\n (center1, center2) => {\n if (center2.getCount() === center1.getCount()) {\n const dA = Math.abs(center2.getEstimatedModuleSize() - average);\n const dB = Math.abs(center1.getEstimatedModuleSize() - average);\n return dA < dB ? 1 : dA > dB ? -1 : 0;\n }\n else {\n return center2.getCount() - center1.getCount();\n }\n });\n possibleCenters.splice(3); // this is not realy necessary as we only return first 3 anyway\n }\n return [\n possibleCenters[0],\n possibleCenters[1],\n possibleCenters[2]\n ];\n }\n }\n FinderPatternFinder.CENTER_QUORUM = 2;\n FinderPatternFinder.MIN_SKIP = 3; // 1 pixel/module times 3 modules/center\n FinderPatternFinder.MAX_MODULES = 57; // support up to version 10 for mobile clients\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.util.Map;*/\n /**\n *

Encapsulates logic that can detect a QR Code in an image, even if the QR Code\n * is rotated or skewed, or partially obscured.

\n *\n * @author Sean Owen\n */\n class Detector$2 {\n constructor(image) {\n this.image = image;\n }\n getImage() {\n return this.image;\n }\n getResultPointCallback() {\n return this.resultPointCallback;\n }\n /**\n *

Detects a QR Code in an image.

\n *\n * @return {@link DetectorResult} encapsulating results of detecting a QR Code\n * @throws NotFoundException if QR Code cannot be found\n * @throws FormatException if a QR Code cannot be decoded\n */\n // public detect(): DetectorResult /*throws NotFoundException, FormatException*/ {\n // return detect(null)\n // }\n /**\n *

Detects a QR Code in an image.

\n *\n * @param hints optional hints to detector\n * @return {@link DetectorResult} encapsulating results of detecting a QR Code\n * @throws NotFoundException if QR Code cannot be found\n * @throws FormatException if a QR Code cannot be decoded\n */\n detect(hints) {\n this.resultPointCallback = (hints === null || hints === undefined) ? null :\n /*(ResultPointCallback) */ hints.get(DecodeHintType$1.NEED_RESULT_POINT_CALLBACK);\n const finder = new FinderPatternFinder(this.image, this.resultPointCallback);\n const info = finder.find(hints);\n return this.processFinderPatternInfo(info);\n }\n processFinderPatternInfo(info) {\n const topLeft = info.getTopLeft();\n const topRight = info.getTopRight();\n const bottomLeft = info.getBottomLeft();\n const moduleSize = this.calculateModuleSize(topLeft, topRight, bottomLeft);\n if (moduleSize < 1.0) {\n throw new NotFoundException('No pattern found in proccess finder.');\n }\n const dimension = Detector$2.computeDimension(topLeft, topRight, bottomLeft, moduleSize);\n const provisionalVersion = Version$1.getProvisionalVersionForDimension(dimension);\n const modulesBetweenFPCenters = provisionalVersion.getDimensionForVersion() - 7;\n let alignmentPattern = null;\n // Anything above version 1 has an alignment pattern\n if (provisionalVersion.getAlignmentPatternCenters().length > 0) {\n // Guess where a \"bottom right\" finder pattern would have been\n const bottomRightX = topRight.getX() - topLeft.getX() + bottomLeft.getX();\n const bottomRightY = topRight.getY() - topLeft.getY() + bottomLeft.getY();\n // Estimate that alignment pattern is closer by 3 modules\n // from \"bottom right\" to known top left location\n const correctionToTopLeft = 1.0 - 3.0 / modulesBetweenFPCenters;\n const estAlignmentX = /*(int) */ Math.floor(topLeft.getX() + correctionToTopLeft * (bottomRightX - topLeft.getX()));\n const estAlignmentY = /*(int) */ Math.floor(topLeft.getY() + correctionToTopLeft * (bottomRightY - topLeft.getY()));\n // Kind of arbitrary -- expand search radius before giving up\n for (let i = 4; i <= 16; i <<= 1) {\n try {\n alignmentPattern = this.findAlignmentInRegion(moduleSize, estAlignmentX, estAlignmentY, i);\n break;\n }\n catch (re /*NotFoundException*/) {\n if (!(re instanceof NotFoundException)) {\n throw re;\n }\n // try next round\n }\n }\n // If we didn't find alignment pattern... well try anyway without it\n }\n const transform = Detector$2.createTransform(topLeft, topRight, bottomLeft, alignmentPattern, dimension);\n const bits = Detector$2.sampleGrid(this.image, transform, dimension);\n let points;\n if (alignmentPattern === null) {\n points = [bottomLeft, topLeft, topRight];\n }\n else {\n points = [bottomLeft, topLeft, topRight, alignmentPattern];\n }\n return new DetectorResult(bits, points);\n }\n static createTransform(topLeft, topRight, bottomLeft, alignmentPattern, dimension /*int*/) {\n const dimMinusThree = dimension - 3.5;\n let bottomRightX; /*float*/\n let bottomRightY; /*float*/\n let sourceBottomRightX; /*float*/\n let sourceBottomRightY; /*float*/\n if (alignmentPattern !== null) {\n bottomRightX = alignmentPattern.getX();\n bottomRightY = alignmentPattern.getY();\n sourceBottomRightX = dimMinusThree - 3.0;\n sourceBottomRightY = sourceBottomRightX;\n }\n else {\n // Don't have an alignment pattern, just make up the bottom-right point\n bottomRightX = (topRight.getX() - topLeft.getX()) + bottomLeft.getX();\n bottomRightY = (topRight.getY() - topLeft.getY()) + bottomLeft.getY();\n sourceBottomRightX = dimMinusThree;\n sourceBottomRightY = dimMinusThree;\n }\n return PerspectiveTransform.quadrilateralToQuadrilateral(3.5, 3.5, dimMinusThree, 3.5, sourceBottomRightX, sourceBottomRightY, 3.5, dimMinusThree, topLeft.getX(), topLeft.getY(), topRight.getX(), topRight.getY(), bottomRightX, bottomRightY, bottomLeft.getX(), bottomLeft.getY());\n }\n static sampleGrid(image, transform, dimension /*int*/) {\n const sampler = GridSamplerInstance.getInstance();\n return sampler.sampleGridWithTransform(image, dimension, dimension, transform);\n }\n /**\n *

Computes the dimension (number of modules on a size) of the QR Code based on the position\n * of the finder patterns and estimated module size.

\n */\n static computeDimension(topLeft, topRight, bottomLeft, moduleSize /*float*/) {\n const tltrCentersDimension = MathUtils.round(ResultPoint.distance(topLeft, topRight) / moduleSize);\n const tlblCentersDimension = MathUtils.round(ResultPoint.distance(topLeft, bottomLeft) / moduleSize);\n let dimension = Math.floor((tltrCentersDimension + tlblCentersDimension) / 2) + 7;\n switch (dimension & 0x03) { // mod 4\n case 0:\n dimension++;\n break;\n // 1? do nothing\n case 2:\n dimension--;\n break;\n case 3:\n throw new NotFoundException('Dimensions could be not found.');\n }\n return dimension;\n }\n /**\n *

Computes an average estimated module size based on estimated derived from the positions\n * of the three finder patterns.

\n *\n * @param topLeft detected top-left finder pattern center\n * @param topRight detected top-right finder pattern center\n * @param bottomLeft detected bottom-left finder pattern center\n * @return estimated module size\n */\n calculateModuleSize(topLeft, topRight, bottomLeft) {\n // Take the average\n return (this.calculateModuleSizeOneWay(topLeft, topRight) +\n this.calculateModuleSizeOneWay(topLeft, bottomLeft)) / 2.0;\n }\n /**\n *

Estimates module size based on two finder patterns -- it uses\n * {@link #sizeOfBlackWhiteBlackRunBothWays(int, int, int, int)} to figure the\n * width of each, measuring along the axis between their centers.

\n */\n calculateModuleSizeOneWay(pattern, otherPattern) {\n const moduleSizeEst1 = this.sizeOfBlackWhiteBlackRunBothWays(/*(int) */ Math.floor(pattern.getX()), \n /*(int) */ Math.floor(pattern.getY()), \n /*(int) */ Math.floor(otherPattern.getX()), \n /*(int) */ Math.floor(otherPattern.getY()));\n const moduleSizeEst2 = this.sizeOfBlackWhiteBlackRunBothWays(/*(int) */ Math.floor(otherPattern.getX()), \n /*(int) */ Math.floor(otherPattern.getY()), \n /*(int) */ Math.floor(pattern.getX()), \n /*(int) */ Math.floor(pattern.getY()));\n if (isNaN(moduleSizeEst1)) {\n return moduleSizeEst2 / 7.0;\n }\n if (isNaN(moduleSizeEst2)) {\n return moduleSizeEst1 / 7.0;\n }\n // Average them, and divide by 7 since we've counted the width of 3 black modules,\n // and 1 white and 1 black module on either side. Ergo, divide sum by 14.\n return (moduleSizeEst1 + moduleSizeEst2) / 14.0;\n }\n /**\n * See {@link #sizeOfBlackWhiteBlackRun(int, int, int, int)}; computes the total width of\n * a finder pattern by looking for a black-white-black run from the center in the direction\n * of another point (another finder pattern center), and in the opposite direction too.\n */\n sizeOfBlackWhiteBlackRunBothWays(fromX /*int*/, fromY /*int*/, toX /*int*/, toY /*int*/) {\n let result = this.sizeOfBlackWhiteBlackRun(fromX, fromY, toX, toY);\n // Now count other way -- don't run off image though of course\n let scale = 1.0;\n let otherToX = fromX - (toX - fromX);\n if (otherToX < 0) {\n scale = fromX / /*(float) */ (fromX - otherToX);\n otherToX = 0;\n }\n else if (otherToX >= this.image.getWidth()) {\n scale = (this.image.getWidth() - 1 - fromX) / /*(float) */ (otherToX - fromX);\n otherToX = this.image.getWidth() - 1;\n }\n let otherToY = /*(int) */ Math.floor(fromY - (toY - fromY) * scale);\n scale = 1.0;\n if (otherToY < 0) {\n scale = fromY / /*(float) */ (fromY - otherToY);\n otherToY = 0;\n }\n else if (otherToY >= this.image.getHeight()) {\n scale = (this.image.getHeight() - 1 - fromY) / /*(float) */ (otherToY - fromY);\n otherToY = this.image.getHeight() - 1;\n }\n otherToX = /*(int) */ Math.floor(fromX + (otherToX - fromX) * scale);\n result += this.sizeOfBlackWhiteBlackRun(fromX, fromY, otherToX, otherToY);\n // Middle pixel is double-counted this way; subtract 1\n return result - 1.0;\n }\n /**\n *

This method traces a line from a point in the image, in the direction towards another point.\n * It begins in a black region, and keeps going until it finds white, then black, then white again.\n * It reports the distance from the start to this point.

\n *\n *

This is used when figuring out how wide a finder pattern is, when the finder pattern\n * may be skewed or rotated.

\n */\n sizeOfBlackWhiteBlackRun(fromX /*int*/, fromY /*int*/, toX /*int*/, toY /*int*/) {\n // Mild variant of Bresenham's algorithm\n // see http://en.wikipedia.org/wiki/Bresenham's_line_algorithm\n const steep = Math.abs(toY - fromY) > Math.abs(toX - fromX);\n if (steep) {\n let temp = fromX;\n fromX = fromY;\n fromY = temp;\n temp = toX;\n toX = toY;\n toY = temp;\n }\n const dx = Math.abs(toX - fromX);\n const dy = Math.abs(toY - fromY);\n let error = -dx / 2;\n const xstep = fromX < toX ? 1 : -1;\n const ystep = fromY < toY ? 1 : -1;\n // In black pixels, looking for white, first or second time.\n let state = 0;\n // Loop up until x == toX, but not beyond\n const xLimit = toX + xstep;\n for (let x = fromX, y = fromY; x !== xLimit; x += xstep) {\n const realX = steep ? y : x;\n const realY = steep ? x : y;\n // Does current pixel mean we have moved white to black or vice versa?\n // Scanning black in state 0,2 and white in state 1, so if we find the wrong\n // color, advance to next state or end if we are in state 2 already\n if ((state === 1) === this.image.get(realX, realY)) {\n if (state === 2) {\n return MathUtils.distance(x, y, fromX, fromY);\n }\n state++;\n }\n error += dy;\n if (error > 0) {\n if (y === toY) {\n break;\n }\n y += ystep;\n error -= dx;\n }\n }\n // Found black-white-black; give the benefit of the doubt that the next pixel outside the image\n // is \"white\" so this last point at (toX+xStep,toY) is the right ending. This is really a\n // small approximation; (toX+xStep,toY+yStep) might be really correct. Ignore this.\n if (state === 2) {\n return MathUtils.distance(toX + xstep, toY, fromX, fromY);\n }\n // else we didn't find even black-white-black; no estimate is really possible\n return NaN;\n }\n /**\n *

Attempts to locate an alignment pattern in a limited region of the image, which is\n * guessed to contain it. This method uses {@link AlignmentPattern}.

\n *\n * @param overallEstModuleSize estimated module size so far\n * @param estAlignmentX x coordinate of center of area probably containing alignment pattern\n * @param estAlignmentY y coordinate of above\n * @param allowanceFactor number of pixels in all directions to search from the center\n * @return {@link AlignmentPattern} if found, or null otherwise\n * @throws NotFoundException if an unexpected error occurs during detection\n */\n findAlignmentInRegion(overallEstModuleSize /*float*/, estAlignmentX /*int*/, estAlignmentY /*int*/, allowanceFactor /*float*/) {\n // Look for an alignment pattern (3 modules in size) around where it\n // should be\n const allowance = /*(int) */ Math.floor(allowanceFactor * overallEstModuleSize);\n const alignmentAreaLeftX = Math.max(0, estAlignmentX - allowance);\n const alignmentAreaRightX = Math.min(this.image.getWidth() - 1, estAlignmentX + allowance);\n if (alignmentAreaRightX - alignmentAreaLeftX < overallEstModuleSize * 3) {\n throw new NotFoundException('Alignment top exceeds estimated module size.');\n }\n const alignmentAreaTopY = Math.max(0, estAlignmentY - allowance);\n const alignmentAreaBottomY = Math.min(this.image.getHeight() - 1, estAlignmentY + allowance);\n if (alignmentAreaBottomY - alignmentAreaTopY < overallEstModuleSize * 3) {\n throw new NotFoundException('Alignment bottom exceeds estimated module size.');\n }\n const alignmentFinder = new AlignmentPatternFinder(this.image, alignmentAreaLeftX, alignmentAreaTopY, alignmentAreaRightX - alignmentAreaLeftX, alignmentAreaBottomY - alignmentAreaTopY, overallEstModuleSize, this.resultPointCallback);\n return alignmentFinder.find();\n }\n }\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.util.List;*/\n /*import java.util.Map;*/\n /**\n * This implementation can detect and decode QR Codes in an image.\n *\n * @author Sean Owen\n */\n class QRCodeReader {\n constructor() {\n this.decoder = new Decoder$2();\n }\n getDecoder() {\n return this.decoder;\n }\n /**\n * Locates and decodes a QR code in an image.\n *\n * @return a representing: string the content encoded by the QR code\n * @throws NotFoundException if a QR code cannot be found\n * @throws FormatException if a QR code cannot be decoded\n * @throws ChecksumException if error correction fails\n */\n /*@Override*/\n // public decode(image: BinaryBitmap): Result /*throws NotFoundException, ChecksumException, FormatException */ {\n // return this.decode(image, null)\n // }\n /*@Override*/\n decode(image, hints) {\n let decoderResult;\n let points;\n if (hints !== undefined && hints !== null && undefined !== hints.get(DecodeHintType$1.PURE_BARCODE)) {\n const bits = QRCodeReader.extractPureBits(image.getBlackMatrix());\n decoderResult = this.decoder.decodeBitMatrix(bits, hints);\n points = QRCodeReader.NO_POINTS;\n }\n else {\n const detectorResult = new Detector$2(image.getBlackMatrix()).detect(hints);\n decoderResult = this.decoder.decodeBitMatrix(detectorResult.getBits(), hints);\n points = detectorResult.getPoints();\n }\n // If the code was mirrored: swap the bottom-left and the top-right points.\n if (decoderResult.getOther() instanceof QRCodeDecoderMetaData) {\n decoderResult.getOther().applyMirroredCorrection(points);\n }\n const result = new Result(decoderResult.getText(), decoderResult.getRawBytes(), undefined, points, BarcodeFormat$1.QR_CODE, undefined);\n const byteSegments = decoderResult.getByteSegments();\n if (byteSegments !== null) {\n result.putMetadata(ResultMetadataType$1.BYTE_SEGMENTS, byteSegments);\n }\n const ecLevel = decoderResult.getECLevel();\n if (ecLevel !== null) {\n result.putMetadata(ResultMetadataType$1.ERROR_CORRECTION_LEVEL, ecLevel);\n }\n if (decoderResult.hasStructuredAppend()) {\n result.putMetadata(ResultMetadataType$1.STRUCTURED_APPEND_SEQUENCE, decoderResult.getStructuredAppendSequenceNumber());\n result.putMetadata(ResultMetadataType$1.STRUCTURED_APPEND_PARITY, decoderResult.getStructuredAppendParity());\n }\n return result;\n }\n /*@Override*/\n reset() {\n // do nothing\n }\n /**\n * This method detects a code in a \"pure\" image -- that is, pure monochrome image\n * which contains only an unrotated, unskewed, image of a code, with some white border\n * around it. This is a specialized method that works exceptionally fast in this special\n * case.\n *\n * @see com.google.zxing.datamatrix.DataMatrixReader#extractPureBits(BitMatrix)\n */\n static extractPureBits(image) {\n const leftTopBlack = image.getTopLeftOnBit();\n const rightBottomBlack = image.getBottomRightOnBit();\n if (leftTopBlack === null || rightBottomBlack === null) {\n throw new NotFoundException();\n }\n const moduleSize = this.moduleSize(leftTopBlack, image);\n let top = leftTopBlack[1];\n let bottom = rightBottomBlack[1];\n let left = leftTopBlack[0];\n let right = rightBottomBlack[0];\n // Sanity check!\n if (left >= right || top >= bottom) {\n throw new NotFoundException();\n }\n if (bottom - top !== right - left) {\n // Special case, where bottom-right module wasn't black so we found something else in the last row\n // Assume it's a square, so use height as the width\n right = left + (bottom - top);\n if (right >= image.getWidth()) {\n // Abort if that would not make sense -- off image\n throw new NotFoundException();\n }\n }\n const matrixWidth = Math.round((right - left + 1) / moduleSize);\n const matrixHeight = Math.round((bottom - top + 1) / moduleSize);\n if (matrixWidth <= 0 || matrixHeight <= 0) {\n throw new NotFoundException();\n }\n if (matrixHeight !== matrixWidth) {\n // Only possibly decode square regions\n throw new NotFoundException();\n }\n // Push in the \"border\" by half the module width so that we start\n // sampling in the middle of the module. Just in case the image is a\n // little off, this will help recover.\n const nudge = /*(int) */ Math.floor(moduleSize / 2.0);\n top += nudge;\n left += nudge;\n // But careful that this does not sample off the edge\n // \"right\" is the farthest-right valid pixel location -- right+1 is not necessarily\n // This is positive by how much the inner x loop below would be too large\n const nudgedTooFarRight = left + /*(int) */ Math.floor((matrixWidth - 1) * moduleSize) - right;\n if (nudgedTooFarRight > 0) {\n if (nudgedTooFarRight > nudge) {\n // Neither way fits; abort\n throw new NotFoundException();\n }\n left -= nudgedTooFarRight;\n }\n // See logic above\n const nudgedTooFarDown = top + /*(int) */ Math.floor((matrixHeight - 1) * moduleSize) - bottom;\n if (nudgedTooFarDown > 0) {\n if (nudgedTooFarDown > nudge) {\n // Neither way fits; abort\n throw new NotFoundException();\n }\n top -= nudgedTooFarDown;\n }\n // Now just read off the bits\n const bits = new BitMatrix(matrixWidth, matrixHeight);\n for (let y = 0; y < matrixHeight; y++) {\n const iOffset = top + /*(int) */ Math.floor(y * moduleSize);\n for (let x = 0; x < matrixWidth; x++) {\n if (image.get(left + /*(int) */ Math.floor(x * moduleSize), iOffset)) {\n bits.set(x, y);\n }\n }\n }\n return bits;\n }\n static moduleSize(leftTopBlack, image) {\n const height = image.getHeight();\n const width = image.getWidth();\n let x = leftTopBlack[0];\n let y = leftTopBlack[1];\n let inBlack = true;\n let transitions = 0;\n while (x < width && y < height) {\n if (inBlack !== image.get(x, y)) {\n if (++transitions === 5) {\n break;\n }\n inBlack = !inBlack;\n }\n x++;\n y++;\n }\n if (x === width || y === height) {\n throw new NotFoundException();\n }\n return (x - leftTopBlack[0]) / 7.0;\n }\n }\n QRCodeReader.NO_POINTS = new Array();\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author SITA Lab (kevin.osullivan@sita.aero)\n * @author Guenther Grau\n */\n /*public final*/ class PDF417Common {\n PDF417Common() {\n }\n /**\n * @param moduleBitCount values to sum\n * @return sum of values\n * @deprecated call {@link MathUtils#sum(int[])}\n */\n // @Deprecated\n static getBitCountSum(moduleBitCount) {\n return MathUtils.sum(moduleBitCount);\n }\n static toIntArray(list) {\n if (list == null || !list.length) {\n return PDF417Common.EMPTY_INT_ARRAY;\n }\n const result = new Int32Array(list.length);\n let i = 0;\n for (const integer of list) {\n result[i++] = integer;\n }\n return result;\n }\n /**\n * @param symbol encoded symbol to translate to a codeword\n * @return the codeword corresponding to the symbol.\n */\n static getCodeword(symbol /*int*/) {\n const i = Arrays.binarySearch(PDF417Common.SYMBOL_TABLE, symbol & 0x3FFFF);\n if (i < 0) {\n return -1;\n }\n return (PDF417Common.CODEWORD_TABLE[i] - 1) % PDF417Common.NUMBER_OF_CODEWORDS;\n }\n }\n PDF417Common.NUMBER_OF_CODEWORDS = 929;\n // Maximum Codewords (Data + Error).\n PDF417Common.MAX_CODEWORDS_IN_BARCODE = PDF417Common.NUMBER_OF_CODEWORDS - 1;\n PDF417Common.MIN_ROWS_IN_BARCODE = 3;\n PDF417Common.MAX_ROWS_IN_BARCODE = 90;\n // One left row indication column + max 30 data columns + one right row indicator column\n // public static /*final*/ MAX_CODEWORDS_IN_ROW: /*int*/ number = 32;\n PDF417Common.MODULES_IN_CODEWORD = 17;\n PDF417Common.MODULES_IN_STOP_PATTERN = 18;\n PDF417Common.BARS_IN_MODULE = 8;\n PDF417Common.EMPTY_INT_ARRAY = new Int32Array([]);\n /**\n * The sorted table of all possible symbols. Extracted from the PDF417\n * specification. The index of a symbol in this table corresponds to the\n * index into the codeword table.\n */\n PDF417Common.SYMBOL_TABLE = Int32Array.from([\n 0x1025e, 0x1027a, 0x1029e, 0x102bc, 0x102f2, 0x102f4, 0x1032e, 0x1034e, 0x1035c, 0x10396, 0x103a6, 0x103ac,\n 0x10422, 0x10428, 0x10436, 0x10442, 0x10444, 0x10448, 0x10450, 0x1045e, 0x10466, 0x1046c, 0x1047a, 0x10482,\n 0x1049e, 0x104a0, 0x104bc, 0x104c6, 0x104d8, 0x104ee, 0x104f2, 0x104f4, 0x10504, 0x10508, 0x10510, 0x1051e,\n 0x10520, 0x1053c, 0x10540, 0x10578, 0x10586, 0x1058c, 0x10598, 0x105b0, 0x105be, 0x105ce, 0x105dc, 0x105e2,\n 0x105e4, 0x105e8, 0x105f6, 0x1062e, 0x1064e, 0x1065c, 0x1068e, 0x1069c, 0x106b8, 0x106de, 0x106fa, 0x10716,\n 0x10726, 0x1072c, 0x10746, 0x1074c, 0x10758, 0x1076e, 0x10792, 0x10794, 0x107a2, 0x107a4, 0x107a8, 0x107b6,\n 0x10822, 0x10828, 0x10842, 0x10848, 0x10850, 0x1085e, 0x10866, 0x1086c, 0x1087a, 0x10882, 0x10884, 0x10890,\n 0x1089e, 0x108a0, 0x108bc, 0x108c6, 0x108cc, 0x108d8, 0x108ee, 0x108f2, 0x108f4, 0x10902, 0x10908, 0x1091e,\n 0x10920, 0x1093c, 0x10940, 0x10978, 0x10986, 0x10998, 0x109b0, 0x109be, 0x109ce, 0x109dc, 0x109e2, 0x109e4,\n 0x109e8, 0x109f6, 0x10a08, 0x10a10, 0x10a1e, 0x10a20, 0x10a3c, 0x10a40, 0x10a78, 0x10af0, 0x10b06, 0x10b0c,\n 0x10b18, 0x10b30, 0x10b3e, 0x10b60, 0x10b7c, 0x10b8e, 0x10b9c, 0x10bb8, 0x10bc2, 0x10bc4, 0x10bc8, 0x10bd0,\n 0x10bde, 0x10be6, 0x10bec, 0x10c2e, 0x10c4e, 0x10c5c, 0x10c62, 0x10c64, 0x10c68, 0x10c76, 0x10c8e, 0x10c9c,\n 0x10cb8, 0x10cc2, 0x10cc4, 0x10cc8, 0x10cd0, 0x10cde, 0x10ce6, 0x10cec, 0x10cfa, 0x10d0e, 0x10d1c, 0x10d38,\n 0x10d70, 0x10d7e, 0x10d82, 0x10d84, 0x10d88, 0x10d90, 0x10d9e, 0x10da0, 0x10dbc, 0x10dc6, 0x10dcc, 0x10dd8,\n 0x10dee, 0x10df2, 0x10df4, 0x10e16, 0x10e26, 0x10e2c, 0x10e46, 0x10e58, 0x10e6e, 0x10e86, 0x10e8c, 0x10e98,\n 0x10eb0, 0x10ebe, 0x10ece, 0x10edc, 0x10f0a, 0x10f12, 0x10f14, 0x10f22, 0x10f28, 0x10f36, 0x10f42, 0x10f44,\n 0x10f48, 0x10f50, 0x10f5e, 0x10f66, 0x10f6c, 0x10fb2, 0x10fb4, 0x11022, 0x11028, 0x11042, 0x11048, 0x11050,\n 0x1105e, 0x1107a, 0x11082, 0x11084, 0x11090, 0x1109e, 0x110a0, 0x110bc, 0x110c6, 0x110cc, 0x110d8, 0x110ee,\n 0x110f2, 0x110f4, 0x11102, 0x1111e, 0x11120, 0x1113c, 0x11140, 0x11178, 0x11186, 0x11198, 0x111b0, 0x111be,\n 0x111ce, 0x111dc, 0x111e2, 0x111e4, 0x111e8, 0x111f6, 0x11208, 0x1121e, 0x11220, 0x11278, 0x112f0, 0x1130c,\n 0x11330, 0x1133e, 0x11360, 0x1137c, 0x1138e, 0x1139c, 0x113b8, 0x113c2, 0x113c8, 0x113d0, 0x113de, 0x113e6,\n 0x113ec, 0x11408, 0x11410, 0x1141e, 0x11420, 0x1143c, 0x11440, 0x11478, 0x114f0, 0x115e0, 0x1160c, 0x11618,\n 0x11630, 0x1163e, 0x11660, 0x1167c, 0x116c0, 0x116f8, 0x1171c, 0x11738, 0x11770, 0x1177e, 0x11782, 0x11784,\n 0x11788, 0x11790, 0x1179e, 0x117a0, 0x117bc, 0x117c6, 0x117cc, 0x117d8, 0x117ee, 0x1182e, 0x11834, 0x1184e,\n 0x1185c, 0x11862, 0x11864, 0x11868, 0x11876, 0x1188e, 0x1189c, 0x118b8, 0x118c2, 0x118c8, 0x118d0, 0x118de,\n 0x118e6, 0x118ec, 0x118fa, 0x1190e, 0x1191c, 0x11938, 0x11970, 0x1197e, 0x11982, 0x11984, 0x11990, 0x1199e,\n 0x119a0, 0x119bc, 0x119c6, 0x119cc, 0x119d8, 0x119ee, 0x119f2, 0x119f4, 0x11a0e, 0x11a1c, 0x11a38, 0x11a70,\n 0x11a7e, 0x11ae0, 0x11afc, 0x11b08, 0x11b10, 0x11b1e, 0x11b20, 0x11b3c, 0x11b40, 0x11b78, 0x11b8c, 0x11b98,\n 0x11bb0, 0x11bbe, 0x11bce, 0x11bdc, 0x11be2, 0x11be4, 0x11be8, 0x11bf6, 0x11c16, 0x11c26, 0x11c2c, 0x11c46,\n 0x11c4c, 0x11c58, 0x11c6e, 0x11c86, 0x11c98, 0x11cb0, 0x11cbe, 0x11cce, 0x11cdc, 0x11ce2, 0x11ce4, 0x11ce8,\n 0x11cf6, 0x11d06, 0x11d0c, 0x11d18, 0x11d30, 0x11d3e, 0x11d60, 0x11d7c, 0x11d8e, 0x11d9c, 0x11db8, 0x11dc4,\n 0x11dc8, 0x11dd0, 0x11dde, 0x11de6, 0x11dec, 0x11dfa, 0x11e0a, 0x11e12, 0x11e14, 0x11e22, 0x11e24, 0x11e28,\n 0x11e36, 0x11e42, 0x11e44, 0x11e50, 0x11e5e, 0x11e66, 0x11e6c, 0x11e82, 0x11e84, 0x11e88, 0x11e90, 0x11e9e,\n 0x11ea0, 0x11ebc, 0x11ec6, 0x11ecc, 0x11ed8, 0x11eee, 0x11f1a, 0x11f2e, 0x11f32, 0x11f34, 0x11f4e, 0x11f5c,\n 0x11f62, 0x11f64, 0x11f68, 0x11f76, 0x12048, 0x1205e, 0x12082, 0x12084, 0x12090, 0x1209e, 0x120a0, 0x120bc,\n 0x120d8, 0x120f2, 0x120f4, 0x12108, 0x1211e, 0x12120, 0x1213c, 0x12140, 0x12178, 0x12186, 0x12198, 0x121b0,\n 0x121be, 0x121e2, 0x121e4, 0x121e8, 0x121f6, 0x12204, 0x12210, 0x1221e, 0x12220, 0x12278, 0x122f0, 0x12306,\n 0x1230c, 0x12330, 0x1233e, 0x12360, 0x1237c, 0x1238e, 0x1239c, 0x123b8, 0x123c2, 0x123c8, 0x123d0, 0x123e6,\n 0x123ec, 0x1241e, 0x12420, 0x1243c, 0x124f0, 0x125e0, 0x12618, 0x1263e, 0x12660, 0x1267c, 0x126c0, 0x126f8,\n 0x12738, 0x12770, 0x1277e, 0x12782, 0x12784, 0x12790, 0x1279e, 0x127a0, 0x127bc, 0x127c6, 0x127cc, 0x127d8,\n 0x127ee, 0x12820, 0x1283c, 0x12840, 0x12878, 0x128f0, 0x129e0, 0x12bc0, 0x12c18, 0x12c30, 0x12c3e, 0x12c60,\n 0x12c7c, 0x12cc0, 0x12cf8, 0x12df0, 0x12e1c, 0x12e38, 0x12e70, 0x12e7e, 0x12ee0, 0x12efc, 0x12f04, 0x12f08,\n 0x12f10, 0x12f20, 0x12f3c, 0x12f40, 0x12f78, 0x12f86, 0x12f8c, 0x12f98, 0x12fb0, 0x12fbe, 0x12fce, 0x12fdc,\n 0x1302e, 0x1304e, 0x1305c, 0x13062, 0x13068, 0x1308e, 0x1309c, 0x130b8, 0x130c2, 0x130c8, 0x130d0, 0x130de,\n 0x130ec, 0x130fa, 0x1310e, 0x13138, 0x13170, 0x1317e, 0x13182, 0x13184, 0x13190, 0x1319e, 0x131a0, 0x131bc,\n 0x131c6, 0x131cc, 0x131d8, 0x131f2, 0x131f4, 0x1320e, 0x1321c, 0x13270, 0x1327e, 0x132e0, 0x132fc, 0x13308,\n 0x1331e, 0x13320, 0x1333c, 0x13340, 0x13378, 0x13386, 0x13398, 0x133b0, 0x133be, 0x133ce, 0x133dc, 0x133e2,\n 0x133e4, 0x133e8, 0x133f6, 0x1340e, 0x1341c, 0x13438, 0x13470, 0x1347e, 0x134e0, 0x134fc, 0x135c0, 0x135f8,\n 0x13608, 0x13610, 0x1361e, 0x13620, 0x1363c, 0x13640, 0x13678, 0x136f0, 0x1370c, 0x13718, 0x13730, 0x1373e,\n 0x13760, 0x1377c, 0x1379c, 0x137b8, 0x137c2, 0x137c4, 0x137c8, 0x137d0, 0x137de, 0x137e6, 0x137ec, 0x13816,\n 0x13826, 0x1382c, 0x13846, 0x1384c, 0x13858, 0x1386e, 0x13874, 0x13886, 0x13898, 0x138b0, 0x138be, 0x138ce,\n 0x138dc, 0x138e2, 0x138e4, 0x138e8, 0x13906, 0x1390c, 0x13930, 0x1393e, 0x13960, 0x1397c, 0x1398e, 0x1399c,\n 0x139b8, 0x139c8, 0x139d0, 0x139de, 0x139e6, 0x139ec, 0x139fa, 0x13a06, 0x13a0c, 0x13a18, 0x13a30, 0x13a3e,\n 0x13a60, 0x13a7c, 0x13ac0, 0x13af8, 0x13b0e, 0x13b1c, 0x13b38, 0x13b70, 0x13b7e, 0x13b88, 0x13b90, 0x13b9e,\n 0x13ba0, 0x13bbc, 0x13bcc, 0x13bd8, 0x13bee, 0x13bf2, 0x13bf4, 0x13c12, 0x13c14, 0x13c22, 0x13c24, 0x13c28,\n 0x13c36, 0x13c42, 0x13c48, 0x13c50, 0x13c5e, 0x13c66, 0x13c6c, 0x13c82, 0x13c84, 0x13c90, 0x13c9e, 0x13ca0,\n 0x13cbc, 0x13cc6, 0x13ccc, 0x13cd8, 0x13cee, 0x13d02, 0x13d04, 0x13d08, 0x13d10, 0x13d1e, 0x13d20, 0x13d3c,\n 0x13d40, 0x13d78, 0x13d86, 0x13d8c, 0x13d98, 0x13db0, 0x13dbe, 0x13dce, 0x13ddc, 0x13de4, 0x13de8, 0x13df6,\n 0x13e1a, 0x13e2e, 0x13e32, 0x13e34, 0x13e4e, 0x13e5c, 0x13e62, 0x13e64, 0x13e68, 0x13e76, 0x13e8e, 0x13e9c,\n 0x13eb8, 0x13ec2, 0x13ec4, 0x13ec8, 0x13ed0, 0x13ede, 0x13ee6, 0x13eec, 0x13f26, 0x13f2c, 0x13f3a, 0x13f46,\n 0x13f4c, 0x13f58, 0x13f6e, 0x13f72, 0x13f74, 0x14082, 0x1409e, 0x140a0, 0x140bc, 0x14104, 0x14108, 0x14110,\n 0x1411e, 0x14120, 0x1413c, 0x14140, 0x14178, 0x1418c, 0x14198, 0x141b0, 0x141be, 0x141e2, 0x141e4, 0x141e8,\n 0x14208, 0x14210, 0x1421e, 0x14220, 0x1423c, 0x14240, 0x14278, 0x142f0, 0x14306, 0x1430c, 0x14318, 0x14330,\n 0x1433e, 0x14360, 0x1437c, 0x1438e, 0x143c2, 0x143c4, 0x143c8, 0x143d0, 0x143e6, 0x143ec, 0x14408, 0x14410,\n 0x1441e, 0x14420, 0x1443c, 0x14440, 0x14478, 0x144f0, 0x145e0, 0x1460c, 0x14618, 0x14630, 0x1463e, 0x14660,\n 0x1467c, 0x146c0, 0x146f8, 0x1471c, 0x14738, 0x14770, 0x1477e, 0x14782, 0x14784, 0x14788, 0x14790, 0x147a0,\n 0x147bc, 0x147c6, 0x147cc, 0x147d8, 0x147ee, 0x14810, 0x14820, 0x1483c, 0x14840, 0x14878, 0x148f0, 0x149e0,\n 0x14bc0, 0x14c30, 0x14c3e, 0x14c60, 0x14c7c, 0x14cc0, 0x14cf8, 0x14df0, 0x14e38, 0x14e70, 0x14e7e, 0x14ee0,\n 0x14efc, 0x14f04, 0x14f08, 0x14f10, 0x14f1e, 0x14f20, 0x14f3c, 0x14f40, 0x14f78, 0x14f86, 0x14f8c, 0x14f98,\n 0x14fb0, 0x14fce, 0x14fdc, 0x15020, 0x15040, 0x15078, 0x150f0, 0x151e0, 0x153c0, 0x15860, 0x1587c, 0x158c0,\n 0x158f8, 0x159f0, 0x15be0, 0x15c70, 0x15c7e, 0x15ce0, 0x15cfc, 0x15dc0, 0x15df8, 0x15e08, 0x15e10, 0x15e20,\n 0x15e40, 0x15e78, 0x15ef0, 0x15f0c, 0x15f18, 0x15f30, 0x15f60, 0x15f7c, 0x15f8e, 0x15f9c, 0x15fb8, 0x1604e,\n 0x1605c, 0x1608e, 0x1609c, 0x160b8, 0x160c2, 0x160c4, 0x160c8, 0x160de, 0x1610e, 0x1611c, 0x16138, 0x16170,\n 0x1617e, 0x16184, 0x16188, 0x16190, 0x1619e, 0x161a0, 0x161bc, 0x161c6, 0x161cc, 0x161d8, 0x161f2, 0x161f4,\n 0x1620e, 0x1621c, 0x16238, 0x16270, 0x1627e, 0x162e0, 0x162fc, 0x16304, 0x16308, 0x16310, 0x1631e, 0x16320,\n 0x1633c, 0x16340, 0x16378, 0x16386, 0x1638c, 0x16398, 0x163b0, 0x163be, 0x163ce, 0x163dc, 0x163e2, 0x163e4,\n 0x163e8, 0x163f6, 0x1640e, 0x1641c, 0x16438, 0x16470, 0x1647e, 0x164e0, 0x164fc, 0x165c0, 0x165f8, 0x16610,\n 0x1661e, 0x16620, 0x1663c, 0x16640, 0x16678, 0x166f0, 0x16718, 0x16730, 0x1673e, 0x16760, 0x1677c, 0x1678e,\n 0x1679c, 0x167b8, 0x167c2, 0x167c4, 0x167c8, 0x167d0, 0x167de, 0x167e6, 0x167ec, 0x1681c, 0x16838, 0x16870,\n 0x168e0, 0x168fc, 0x169c0, 0x169f8, 0x16bf0, 0x16c10, 0x16c1e, 0x16c20, 0x16c3c, 0x16c40, 0x16c78, 0x16cf0,\n 0x16de0, 0x16e18, 0x16e30, 0x16e3e, 0x16e60, 0x16e7c, 0x16ec0, 0x16ef8, 0x16f1c, 0x16f38, 0x16f70, 0x16f7e,\n 0x16f84, 0x16f88, 0x16f90, 0x16f9e, 0x16fa0, 0x16fbc, 0x16fc6, 0x16fcc, 0x16fd8, 0x17026, 0x1702c, 0x17046,\n 0x1704c, 0x17058, 0x1706e, 0x17086, 0x1708c, 0x17098, 0x170b0, 0x170be, 0x170ce, 0x170dc, 0x170e8, 0x17106,\n 0x1710c, 0x17118, 0x17130, 0x1713e, 0x17160, 0x1717c, 0x1718e, 0x1719c, 0x171b8, 0x171c2, 0x171c4, 0x171c8,\n 0x171d0, 0x171de, 0x171e6, 0x171ec, 0x171fa, 0x17206, 0x1720c, 0x17218, 0x17230, 0x1723e, 0x17260, 0x1727c,\n 0x172c0, 0x172f8, 0x1730e, 0x1731c, 0x17338, 0x17370, 0x1737e, 0x17388, 0x17390, 0x1739e, 0x173a0, 0x173bc,\n 0x173cc, 0x173d8, 0x173ee, 0x173f2, 0x173f4, 0x1740c, 0x17418, 0x17430, 0x1743e, 0x17460, 0x1747c, 0x174c0,\n 0x174f8, 0x175f0, 0x1760e, 0x1761c, 0x17638, 0x17670, 0x1767e, 0x176e0, 0x176fc, 0x17708, 0x17710, 0x1771e,\n 0x17720, 0x1773c, 0x17740, 0x17778, 0x17798, 0x177b0, 0x177be, 0x177dc, 0x177e2, 0x177e4, 0x177e8, 0x17822,\n 0x17824, 0x17828, 0x17836, 0x17842, 0x17844, 0x17848, 0x17850, 0x1785e, 0x17866, 0x1786c, 0x17882, 0x17884,\n 0x17888, 0x17890, 0x1789e, 0x178a0, 0x178bc, 0x178c6, 0x178cc, 0x178d8, 0x178ee, 0x178f2, 0x178f4, 0x17902,\n 0x17904, 0x17908, 0x17910, 0x1791e, 0x17920, 0x1793c, 0x17940, 0x17978, 0x17986, 0x1798c, 0x17998, 0x179b0,\n 0x179be, 0x179ce, 0x179dc, 0x179e2, 0x179e4, 0x179e8, 0x179f6, 0x17a04, 0x17a08, 0x17a10, 0x17a1e, 0x17a20,\n 0x17a3c, 0x17a40, 0x17a78, 0x17af0, 0x17b06, 0x17b0c, 0x17b18, 0x17b30, 0x17b3e, 0x17b60, 0x17b7c, 0x17b8e,\n 0x17b9c, 0x17bb8, 0x17bc4, 0x17bc8, 0x17bd0, 0x17bde, 0x17be6, 0x17bec, 0x17c2e, 0x17c32, 0x17c34, 0x17c4e,\n 0x17c5c, 0x17c62, 0x17c64, 0x17c68, 0x17c76, 0x17c8e, 0x17c9c, 0x17cb8, 0x17cc2, 0x17cc4, 0x17cc8, 0x17cd0,\n 0x17cde, 0x17ce6, 0x17cec, 0x17d0e, 0x17d1c, 0x17d38, 0x17d70, 0x17d82, 0x17d84, 0x17d88, 0x17d90, 0x17d9e,\n 0x17da0, 0x17dbc, 0x17dc6, 0x17dcc, 0x17dd8, 0x17dee, 0x17e26, 0x17e2c, 0x17e3a, 0x17e46, 0x17e4c, 0x17e58,\n 0x17e6e, 0x17e72, 0x17e74, 0x17e86, 0x17e8c, 0x17e98, 0x17eb0, 0x17ece, 0x17edc, 0x17ee2, 0x17ee4, 0x17ee8,\n 0x17ef6, 0x1813a, 0x18172, 0x18174, 0x18216, 0x18226, 0x1823a, 0x1824c, 0x18258, 0x1826e, 0x18272, 0x18274,\n 0x18298, 0x182be, 0x182e2, 0x182e4, 0x182e8, 0x182f6, 0x1835e, 0x1837a, 0x183ae, 0x183d6, 0x18416, 0x18426,\n 0x1842c, 0x1843a, 0x18446, 0x18458, 0x1846e, 0x18472, 0x18474, 0x18486, 0x184b0, 0x184be, 0x184ce, 0x184dc,\n 0x184e2, 0x184e4, 0x184e8, 0x184f6, 0x18506, 0x1850c, 0x18518, 0x18530, 0x1853e, 0x18560, 0x1857c, 0x1858e,\n 0x1859c, 0x185b8, 0x185c2, 0x185c4, 0x185c8, 0x185d0, 0x185de, 0x185e6, 0x185ec, 0x185fa, 0x18612, 0x18614,\n 0x18622, 0x18628, 0x18636, 0x18642, 0x18650, 0x1865e, 0x1867a, 0x18682, 0x18684, 0x18688, 0x18690, 0x1869e,\n 0x186a0, 0x186bc, 0x186c6, 0x186cc, 0x186d8, 0x186ee, 0x186f2, 0x186f4, 0x1872e, 0x1874e, 0x1875c, 0x18796,\n 0x187a6, 0x187ac, 0x187d2, 0x187d4, 0x18826, 0x1882c, 0x1883a, 0x18846, 0x1884c, 0x18858, 0x1886e, 0x18872,\n 0x18874, 0x18886, 0x18898, 0x188b0, 0x188be, 0x188ce, 0x188dc, 0x188e2, 0x188e4, 0x188e8, 0x188f6, 0x1890c,\n 0x18930, 0x1893e, 0x18960, 0x1897c, 0x1898e, 0x189b8, 0x189c2, 0x189c8, 0x189d0, 0x189de, 0x189e6, 0x189ec,\n 0x189fa, 0x18a18, 0x18a30, 0x18a3e, 0x18a60, 0x18a7c, 0x18ac0, 0x18af8, 0x18b1c, 0x18b38, 0x18b70, 0x18b7e,\n 0x18b82, 0x18b84, 0x18b88, 0x18b90, 0x18b9e, 0x18ba0, 0x18bbc, 0x18bc6, 0x18bcc, 0x18bd8, 0x18bee, 0x18bf2,\n 0x18bf4, 0x18c22, 0x18c24, 0x18c28, 0x18c36, 0x18c42, 0x18c48, 0x18c50, 0x18c5e, 0x18c66, 0x18c7a, 0x18c82,\n 0x18c84, 0x18c90, 0x18c9e, 0x18ca0, 0x18cbc, 0x18ccc, 0x18cf2, 0x18cf4, 0x18d04, 0x18d08, 0x18d10, 0x18d1e,\n 0x18d20, 0x18d3c, 0x18d40, 0x18d78, 0x18d86, 0x18d98, 0x18dce, 0x18de2, 0x18de4, 0x18de8, 0x18e2e, 0x18e32,\n 0x18e34, 0x18e4e, 0x18e5c, 0x18e62, 0x18e64, 0x18e68, 0x18e8e, 0x18e9c, 0x18eb8, 0x18ec2, 0x18ec4, 0x18ec8,\n 0x18ed0, 0x18efa, 0x18f16, 0x18f26, 0x18f2c, 0x18f46, 0x18f4c, 0x18f58, 0x18f6e, 0x18f8a, 0x18f92, 0x18f94,\n 0x18fa2, 0x18fa4, 0x18fa8, 0x18fb6, 0x1902c, 0x1903a, 0x19046, 0x1904c, 0x19058, 0x19072, 0x19074, 0x19086,\n 0x19098, 0x190b0, 0x190be, 0x190ce, 0x190dc, 0x190e2, 0x190e8, 0x190f6, 0x19106, 0x1910c, 0x19130, 0x1913e,\n 0x19160, 0x1917c, 0x1918e, 0x1919c, 0x191b8, 0x191c2, 0x191c8, 0x191d0, 0x191de, 0x191e6, 0x191ec, 0x191fa,\n 0x19218, 0x1923e, 0x19260, 0x1927c, 0x192c0, 0x192f8, 0x19338, 0x19370, 0x1937e, 0x19382, 0x19384, 0x19390,\n 0x1939e, 0x193a0, 0x193bc, 0x193c6, 0x193cc, 0x193d8, 0x193ee, 0x193f2, 0x193f4, 0x19430, 0x1943e, 0x19460,\n 0x1947c, 0x194c0, 0x194f8, 0x195f0, 0x19638, 0x19670, 0x1967e, 0x196e0, 0x196fc, 0x19702, 0x19704, 0x19708,\n 0x19710, 0x19720, 0x1973c, 0x19740, 0x19778, 0x19786, 0x1978c, 0x19798, 0x197b0, 0x197be, 0x197ce, 0x197dc,\n 0x197e2, 0x197e4, 0x197e8, 0x19822, 0x19824, 0x19842, 0x19848, 0x19850, 0x1985e, 0x19866, 0x1987a, 0x19882,\n 0x19884, 0x19890, 0x1989e, 0x198a0, 0x198bc, 0x198cc, 0x198f2, 0x198f4, 0x19902, 0x19908, 0x1991e, 0x19920,\n 0x1993c, 0x19940, 0x19978, 0x19986, 0x19998, 0x199ce, 0x199e2, 0x199e4, 0x199e8, 0x19a08, 0x19a10, 0x19a1e,\n 0x19a20, 0x19a3c, 0x19a40, 0x19a78, 0x19af0, 0x19b18, 0x19b3e, 0x19b60, 0x19b9c, 0x19bc2, 0x19bc4, 0x19bc8,\n 0x19bd0, 0x19be6, 0x19c2e, 0x19c34, 0x19c4e, 0x19c5c, 0x19c62, 0x19c64, 0x19c68, 0x19c8e, 0x19c9c, 0x19cb8,\n 0x19cc2, 0x19cc8, 0x19cd0, 0x19ce6, 0x19cfa, 0x19d0e, 0x19d1c, 0x19d38, 0x19d70, 0x19d7e, 0x19d82, 0x19d84,\n 0x19d88, 0x19d90, 0x19da0, 0x19dcc, 0x19df2, 0x19df4, 0x19e16, 0x19e26, 0x19e2c, 0x19e46, 0x19e4c, 0x19e58,\n 0x19e74, 0x19e86, 0x19e8c, 0x19e98, 0x19eb0, 0x19ebe, 0x19ece, 0x19ee2, 0x19ee4, 0x19ee8, 0x19f0a, 0x19f12,\n 0x19f14, 0x19f22, 0x19f24, 0x19f28, 0x19f42, 0x19f44, 0x19f48, 0x19f50, 0x19f5e, 0x19f6c, 0x19f9a, 0x19fae,\n 0x19fb2, 0x19fb4, 0x1a046, 0x1a04c, 0x1a072, 0x1a074, 0x1a086, 0x1a08c, 0x1a098, 0x1a0b0, 0x1a0be, 0x1a0e2,\n 0x1a0e4, 0x1a0e8, 0x1a0f6, 0x1a106, 0x1a10c, 0x1a118, 0x1a130, 0x1a13e, 0x1a160, 0x1a17c, 0x1a18e, 0x1a19c,\n 0x1a1b8, 0x1a1c2, 0x1a1c4, 0x1a1c8, 0x1a1d0, 0x1a1de, 0x1a1e6, 0x1a1ec, 0x1a218, 0x1a230, 0x1a23e, 0x1a260,\n 0x1a27c, 0x1a2c0, 0x1a2f8, 0x1a31c, 0x1a338, 0x1a370, 0x1a37e, 0x1a382, 0x1a384, 0x1a388, 0x1a390, 0x1a39e,\n 0x1a3a0, 0x1a3bc, 0x1a3c6, 0x1a3cc, 0x1a3d8, 0x1a3ee, 0x1a3f2, 0x1a3f4, 0x1a418, 0x1a430, 0x1a43e, 0x1a460,\n 0x1a47c, 0x1a4c0, 0x1a4f8, 0x1a5f0, 0x1a61c, 0x1a638, 0x1a670, 0x1a67e, 0x1a6e0, 0x1a6fc, 0x1a702, 0x1a704,\n 0x1a708, 0x1a710, 0x1a71e, 0x1a720, 0x1a73c, 0x1a740, 0x1a778, 0x1a786, 0x1a78c, 0x1a798, 0x1a7b0, 0x1a7be,\n 0x1a7ce, 0x1a7dc, 0x1a7e2, 0x1a7e4, 0x1a7e8, 0x1a830, 0x1a860, 0x1a87c, 0x1a8c0, 0x1a8f8, 0x1a9f0, 0x1abe0,\n 0x1ac70, 0x1ac7e, 0x1ace0, 0x1acfc, 0x1adc0, 0x1adf8, 0x1ae04, 0x1ae08, 0x1ae10, 0x1ae20, 0x1ae3c, 0x1ae40,\n 0x1ae78, 0x1aef0, 0x1af06, 0x1af0c, 0x1af18, 0x1af30, 0x1af3e, 0x1af60, 0x1af7c, 0x1af8e, 0x1af9c, 0x1afb8,\n 0x1afc4, 0x1afc8, 0x1afd0, 0x1afde, 0x1b042, 0x1b05e, 0x1b07a, 0x1b082, 0x1b084, 0x1b088, 0x1b090, 0x1b09e,\n 0x1b0a0, 0x1b0bc, 0x1b0cc, 0x1b0f2, 0x1b0f4, 0x1b102, 0x1b104, 0x1b108, 0x1b110, 0x1b11e, 0x1b120, 0x1b13c,\n 0x1b140, 0x1b178, 0x1b186, 0x1b198, 0x1b1ce, 0x1b1e2, 0x1b1e4, 0x1b1e8, 0x1b204, 0x1b208, 0x1b210, 0x1b21e,\n 0x1b220, 0x1b23c, 0x1b240, 0x1b278, 0x1b2f0, 0x1b30c, 0x1b33e, 0x1b360, 0x1b39c, 0x1b3c2, 0x1b3c4, 0x1b3c8,\n 0x1b3d0, 0x1b3e6, 0x1b410, 0x1b41e, 0x1b420, 0x1b43c, 0x1b440, 0x1b478, 0x1b4f0, 0x1b5e0, 0x1b618, 0x1b660,\n 0x1b67c, 0x1b6c0, 0x1b738, 0x1b782, 0x1b784, 0x1b788, 0x1b790, 0x1b79e, 0x1b7a0, 0x1b7cc, 0x1b82e, 0x1b84e,\n 0x1b85c, 0x1b88e, 0x1b89c, 0x1b8b8, 0x1b8c2, 0x1b8c4, 0x1b8c8, 0x1b8d0, 0x1b8e6, 0x1b8fa, 0x1b90e, 0x1b91c,\n 0x1b938, 0x1b970, 0x1b97e, 0x1b982, 0x1b984, 0x1b988, 0x1b990, 0x1b99e, 0x1b9a0, 0x1b9cc, 0x1b9f2, 0x1b9f4,\n 0x1ba0e, 0x1ba1c, 0x1ba38, 0x1ba70, 0x1ba7e, 0x1bae0, 0x1bafc, 0x1bb08, 0x1bb10, 0x1bb20, 0x1bb3c, 0x1bb40,\n 0x1bb98, 0x1bbce, 0x1bbe2, 0x1bbe4, 0x1bbe8, 0x1bc16, 0x1bc26, 0x1bc2c, 0x1bc46, 0x1bc4c, 0x1bc58, 0x1bc72,\n 0x1bc74, 0x1bc86, 0x1bc8c, 0x1bc98, 0x1bcb0, 0x1bcbe, 0x1bcce, 0x1bce2, 0x1bce4, 0x1bce8, 0x1bd06, 0x1bd0c,\n 0x1bd18, 0x1bd30, 0x1bd3e, 0x1bd60, 0x1bd7c, 0x1bd9c, 0x1bdc2, 0x1bdc4, 0x1bdc8, 0x1bdd0, 0x1bde6, 0x1bdfa,\n 0x1be12, 0x1be14, 0x1be22, 0x1be24, 0x1be28, 0x1be42, 0x1be44, 0x1be48, 0x1be50, 0x1be5e, 0x1be66, 0x1be82,\n 0x1be84, 0x1be88, 0x1be90, 0x1be9e, 0x1bea0, 0x1bebc, 0x1becc, 0x1bef4, 0x1bf1a, 0x1bf2e, 0x1bf32, 0x1bf34,\n 0x1bf4e, 0x1bf5c, 0x1bf62, 0x1bf64, 0x1bf68, 0x1c09a, 0x1c0b2, 0x1c0b4, 0x1c11a, 0x1c132, 0x1c134, 0x1c162,\n 0x1c164, 0x1c168, 0x1c176, 0x1c1ba, 0x1c21a, 0x1c232, 0x1c234, 0x1c24e, 0x1c25c, 0x1c262, 0x1c264, 0x1c268,\n 0x1c276, 0x1c28e, 0x1c2c2, 0x1c2c4, 0x1c2c8, 0x1c2d0, 0x1c2de, 0x1c2e6, 0x1c2ec, 0x1c2fa, 0x1c316, 0x1c326,\n 0x1c33a, 0x1c346, 0x1c34c, 0x1c372, 0x1c374, 0x1c41a, 0x1c42e, 0x1c432, 0x1c434, 0x1c44e, 0x1c45c, 0x1c462,\n 0x1c464, 0x1c468, 0x1c476, 0x1c48e, 0x1c49c, 0x1c4b8, 0x1c4c2, 0x1c4c8, 0x1c4d0, 0x1c4de, 0x1c4e6, 0x1c4ec,\n 0x1c4fa, 0x1c51c, 0x1c538, 0x1c570, 0x1c57e, 0x1c582, 0x1c584, 0x1c588, 0x1c590, 0x1c59e, 0x1c5a0, 0x1c5bc,\n 0x1c5c6, 0x1c5cc, 0x1c5d8, 0x1c5ee, 0x1c5f2, 0x1c5f4, 0x1c616, 0x1c626, 0x1c62c, 0x1c63a, 0x1c646, 0x1c64c,\n 0x1c658, 0x1c66e, 0x1c672, 0x1c674, 0x1c686, 0x1c68c, 0x1c698, 0x1c6b0, 0x1c6be, 0x1c6ce, 0x1c6dc, 0x1c6e2,\n 0x1c6e4, 0x1c6e8, 0x1c712, 0x1c714, 0x1c722, 0x1c728, 0x1c736, 0x1c742, 0x1c744, 0x1c748, 0x1c750, 0x1c75e,\n 0x1c766, 0x1c76c, 0x1c77a, 0x1c7ae, 0x1c7d6, 0x1c7ea, 0x1c81a, 0x1c82e, 0x1c832, 0x1c834, 0x1c84e, 0x1c85c,\n 0x1c862, 0x1c864, 0x1c868, 0x1c876, 0x1c88e, 0x1c89c, 0x1c8b8, 0x1c8c2, 0x1c8c8, 0x1c8d0, 0x1c8de, 0x1c8e6,\n 0x1c8ec, 0x1c8fa, 0x1c90e, 0x1c938, 0x1c970, 0x1c97e, 0x1c982, 0x1c984, 0x1c990, 0x1c99e, 0x1c9a0, 0x1c9bc,\n 0x1c9c6, 0x1c9cc, 0x1c9d8, 0x1c9ee, 0x1c9f2, 0x1c9f4, 0x1ca38, 0x1ca70, 0x1ca7e, 0x1cae0, 0x1cafc, 0x1cb02,\n 0x1cb04, 0x1cb08, 0x1cb10, 0x1cb20, 0x1cb3c, 0x1cb40, 0x1cb78, 0x1cb86, 0x1cb8c, 0x1cb98, 0x1cbb0, 0x1cbbe,\n 0x1cbce, 0x1cbdc, 0x1cbe2, 0x1cbe4, 0x1cbe8, 0x1cbf6, 0x1cc16, 0x1cc26, 0x1cc2c, 0x1cc3a, 0x1cc46, 0x1cc58,\n 0x1cc72, 0x1cc74, 0x1cc86, 0x1ccb0, 0x1ccbe, 0x1ccce, 0x1cce2, 0x1cce4, 0x1cce8, 0x1cd06, 0x1cd0c, 0x1cd18,\n 0x1cd30, 0x1cd3e, 0x1cd60, 0x1cd7c, 0x1cd9c, 0x1cdc2, 0x1cdc4, 0x1cdc8, 0x1cdd0, 0x1cdde, 0x1cde6, 0x1cdfa,\n 0x1ce22, 0x1ce28, 0x1ce42, 0x1ce50, 0x1ce5e, 0x1ce66, 0x1ce7a, 0x1ce82, 0x1ce84, 0x1ce88, 0x1ce90, 0x1ce9e,\n 0x1cea0, 0x1cebc, 0x1cecc, 0x1cef2, 0x1cef4, 0x1cf2e, 0x1cf32, 0x1cf34, 0x1cf4e, 0x1cf5c, 0x1cf62, 0x1cf64,\n 0x1cf68, 0x1cf96, 0x1cfa6, 0x1cfac, 0x1cfca, 0x1cfd2, 0x1cfd4, 0x1d02e, 0x1d032, 0x1d034, 0x1d04e, 0x1d05c,\n 0x1d062, 0x1d064, 0x1d068, 0x1d076, 0x1d08e, 0x1d09c, 0x1d0b8, 0x1d0c2, 0x1d0c4, 0x1d0c8, 0x1d0d0, 0x1d0de,\n 0x1d0e6, 0x1d0ec, 0x1d0fa, 0x1d11c, 0x1d138, 0x1d170, 0x1d17e, 0x1d182, 0x1d184, 0x1d188, 0x1d190, 0x1d19e,\n 0x1d1a0, 0x1d1bc, 0x1d1c6, 0x1d1cc, 0x1d1d8, 0x1d1ee, 0x1d1f2, 0x1d1f4, 0x1d21c, 0x1d238, 0x1d270, 0x1d27e,\n 0x1d2e0, 0x1d2fc, 0x1d302, 0x1d304, 0x1d308, 0x1d310, 0x1d31e, 0x1d320, 0x1d33c, 0x1d340, 0x1d378, 0x1d386,\n 0x1d38c, 0x1d398, 0x1d3b0, 0x1d3be, 0x1d3ce, 0x1d3dc, 0x1d3e2, 0x1d3e4, 0x1d3e8, 0x1d3f6, 0x1d470, 0x1d47e,\n 0x1d4e0, 0x1d4fc, 0x1d5c0, 0x1d5f8, 0x1d604, 0x1d608, 0x1d610, 0x1d620, 0x1d640, 0x1d678, 0x1d6f0, 0x1d706,\n 0x1d70c, 0x1d718, 0x1d730, 0x1d73e, 0x1d760, 0x1d77c, 0x1d78e, 0x1d79c, 0x1d7b8, 0x1d7c2, 0x1d7c4, 0x1d7c8,\n 0x1d7d0, 0x1d7de, 0x1d7e6, 0x1d7ec, 0x1d826, 0x1d82c, 0x1d83a, 0x1d846, 0x1d84c, 0x1d858, 0x1d872, 0x1d874,\n 0x1d886, 0x1d88c, 0x1d898, 0x1d8b0, 0x1d8be, 0x1d8ce, 0x1d8e2, 0x1d8e4, 0x1d8e8, 0x1d8f6, 0x1d90c, 0x1d918,\n 0x1d930, 0x1d93e, 0x1d960, 0x1d97c, 0x1d99c, 0x1d9c2, 0x1d9c4, 0x1d9c8, 0x1d9d0, 0x1d9e6, 0x1d9fa, 0x1da0c,\n 0x1da18, 0x1da30, 0x1da3e, 0x1da60, 0x1da7c, 0x1dac0, 0x1daf8, 0x1db38, 0x1db82, 0x1db84, 0x1db88, 0x1db90,\n 0x1db9e, 0x1dba0, 0x1dbcc, 0x1dbf2, 0x1dbf4, 0x1dc22, 0x1dc42, 0x1dc44, 0x1dc48, 0x1dc50, 0x1dc5e, 0x1dc66,\n 0x1dc7a, 0x1dc82, 0x1dc84, 0x1dc88, 0x1dc90, 0x1dc9e, 0x1dca0, 0x1dcbc, 0x1dccc, 0x1dcf2, 0x1dcf4, 0x1dd04,\n 0x1dd08, 0x1dd10, 0x1dd1e, 0x1dd20, 0x1dd3c, 0x1dd40, 0x1dd78, 0x1dd86, 0x1dd98, 0x1ddce, 0x1dde2, 0x1dde4,\n 0x1dde8, 0x1de2e, 0x1de32, 0x1de34, 0x1de4e, 0x1de5c, 0x1de62, 0x1de64, 0x1de68, 0x1de8e, 0x1de9c, 0x1deb8,\n 0x1dec2, 0x1dec4, 0x1dec8, 0x1ded0, 0x1dee6, 0x1defa, 0x1df16, 0x1df26, 0x1df2c, 0x1df46, 0x1df4c, 0x1df58,\n 0x1df72, 0x1df74, 0x1df8a, 0x1df92, 0x1df94, 0x1dfa2, 0x1dfa4, 0x1dfa8, 0x1e08a, 0x1e092, 0x1e094, 0x1e0a2,\n 0x1e0a4, 0x1e0a8, 0x1e0b6, 0x1e0da, 0x1e10a, 0x1e112, 0x1e114, 0x1e122, 0x1e124, 0x1e128, 0x1e136, 0x1e142,\n 0x1e144, 0x1e148, 0x1e150, 0x1e166, 0x1e16c, 0x1e17a, 0x1e19a, 0x1e1b2, 0x1e1b4, 0x1e20a, 0x1e212, 0x1e214,\n 0x1e222, 0x1e224, 0x1e228, 0x1e236, 0x1e242, 0x1e248, 0x1e250, 0x1e25e, 0x1e266, 0x1e26c, 0x1e27a, 0x1e282,\n 0x1e284, 0x1e288, 0x1e290, 0x1e2a0, 0x1e2bc, 0x1e2c6, 0x1e2cc, 0x1e2d8, 0x1e2ee, 0x1e2f2, 0x1e2f4, 0x1e31a,\n 0x1e332, 0x1e334, 0x1e35c, 0x1e362, 0x1e364, 0x1e368, 0x1e3ba, 0x1e40a, 0x1e412, 0x1e414, 0x1e422, 0x1e428,\n 0x1e436, 0x1e442, 0x1e448, 0x1e450, 0x1e45e, 0x1e466, 0x1e46c, 0x1e47a, 0x1e482, 0x1e484, 0x1e490, 0x1e49e,\n 0x1e4a0, 0x1e4bc, 0x1e4c6, 0x1e4cc, 0x1e4d8, 0x1e4ee, 0x1e4f2, 0x1e4f4, 0x1e502, 0x1e504, 0x1e508, 0x1e510,\n 0x1e51e, 0x1e520, 0x1e53c, 0x1e540, 0x1e578, 0x1e586, 0x1e58c, 0x1e598, 0x1e5b0, 0x1e5be, 0x1e5ce, 0x1e5dc,\n 0x1e5e2, 0x1e5e4, 0x1e5e8, 0x1e5f6, 0x1e61a, 0x1e62e, 0x1e632, 0x1e634, 0x1e64e, 0x1e65c, 0x1e662, 0x1e668,\n 0x1e68e, 0x1e69c, 0x1e6b8, 0x1e6c2, 0x1e6c4, 0x1e6c8, 0x1e6d0, 0x1e6e6, 0x1e6fa, 0x1e716, 0x1e726, 0x1e72c,\n 0x1e73a, 0x1e746, 0x1e74c, 0x1e758, 0x1e772, 0x1e774, 0x1e792, 0x1e794, 0x1e7a2, 0x1e7a4, 0x1e7a8, 0x1e7b6,\n 0x1e812, 0x1e814, 0x1e822, 0x1e824, 0x1e828, 0x1e836, 0x1e842, 0x1e844, 0x1e848, 0x1e850, 0x1e85e, 0x1e866,\n 0x1e86c, 0x1e87a, 0x1e882, 0x1e884, 0x1e888, 0x1e890, 0x1e89e, 0x1e8a0, 0x1e8bc, 0x1e8c6, 0x1e8cc, 0x1e8d8,\n 0x1e8ee, 0x1e8f2, 0x1e8f4, 0x1e902, 0x1e904, 0x1e908, 0x1e910, 0x1e920, 0x1e93c, 0x1e940, 0x1e978, 0x1e986,\n 0x1e98c, 0x1e998, 0x1e9b0, 0x1e9be, 0x1e9ce, 0x1e9dc, 0x1e9e2, 0x1e9e4, 0x1e9e8, 0x1e9f6, 0x1ea04, 0x1ea08,\n 0x1ea10, 0x1ea20, 0x1ea40, 0x1ea78, 0x1eaf0, 0x1eb06, 0x1eb0c, 0x1eb18, 0x1eb30, 0x1eb3e, 0x1eb60, 0x1eb7c,\n 0x1eb8e, 0x1eb9c, 0x1ebb8, 0x1ebc2, 0x1ebc4, 0x1ebc8, 0x1ebd0, 0x1ebde, 0x1ebe6, 0x1ebec, 0x1ec1a, 0x1ec2e,\n 0x1ec32, 0x1ec34, 0x1ec4e, 0x1ec5c, 0x1ec62, 0x1ec64, 0x1ec68, 0x1ec8e, 0x1ec9c, 0x1ecb8, 0x1ecc2, 0x1ecc4,\n 0x1ecc8, 0x1ecd0, 0x1ece6, 0x1ecfa, 0x1ed0e, 0x1ed1c, 0x1ed38, 0x1ed70, 0x1ed7e, 0x1ed82, 0x1ed84, 0x1ed88,\n 0x1ed90, 0x1ed9e, 0x1eda0, 0x1edcc, 0x1edf2, 0x1edf4, 0x1ee16, 0x1ee26, 0x1ee2c, 0x1ee3a, 0x1ee46, 0x1ee4c,\n 0x1ee58, 0x1ee6e, 0x1ee72, 0x1ee74, 0x1ee86, 0x1ee8c, 0x1ee98, 0x1eeb0, 0x1eebe, 0x1eece, 0x1eedc, 0x1eee2,\n 0x1eee4, 0x1eee8, 0x1ef12, 0x1ef22, 0x1ef24, 0x1ef28, 0x1ef36, 0x1ef42, 0x1ef44, 0x1ef48, 0x1ef50, 0x1ef5e,\n 0x1ef66, 0x1ef6c, 0x1ef7a, 0x1efae, 0x1efb2, 0x1efb4, 0x1efd6, 0x1f096, 0x1f0a6, 0x1f0ac, 0x1f0ba, 0x1f0ca,\n 0x1f0d2, 0x1f0d4, 0x1f116, 0x1f126, 0x1f12c, 0x1f13a, 0x1f146, 0x1f14c, 0x1f158, 0x1f16e, 0x1f172, 0x1f174,\n 0x1f18a, 0x1f192, 0x1f194, 0x1f1a2, 0x1f1a4, 0x1f1a8, 0x1f1da, 0x1f216, 0x1f226, 0x1f22c, 0x1f23a, 0x1f246,\n 0x1f258, 0x1f26e, 0x1f272, 0x1f274, 0x1f286, 0x1f28c, 0x1f298, 0x1f2b0, 0x1f2be, 0x1f2ce, 0x1f2dc, 0x1f2e2,\n 0x1f2e4, 0x1f2e8, 0x1f2f6, 0x1f30a, 0x1f312, 0x1f314, 0x1f322, 0x1f328, 0x1f342, 0x1f344, 0x1f348, 0x1f350,\n 0x1f35e, 0x1f366, 0x1f37a, 0x1f39a, 0x1f3ae, 0x1f3b2, 0x1f3b4, 0x1f416, 0x1f426, 0x1f42c, 0x1f43a, 0x1f446,\n 0x1f44c, 0x1f458, 0x1f46e, 0x1f472, 0x1f474, 0x1f486, 0x1f48c, 0x1f498, 0x1f4b0, 0x1f4be, 0x1f4ce, 0x1f4dc,\n 0x1f4e2, 0x1f4e4, 0x1f4e8, 0x1f4f6, 0x1f506, 0x1f50c, 0x1f518, 0x1f530, 0x1f53e, 0x1f560, 0x1f57c, 0x1f58e,\n 0x1f59c, 0x1f5b8, 0x1f5c2, 0x1f5c4, 0x1f5c8, 0x1f5d0, 0x1f5de, 0x1f5e6, 0x1f5ec, 0x1f5fa, 0x1f60a, 0x1f612,\n 0x1f614, 0x1f622, 0x1f624, 0x1f628, 0x1f636, 0x1f642, 0x1f644, 0x1f648, 0x1f650, 0x1f65e, 0x1f666, 0x1f67a,\n 0x1f682, 0x1f684, 0x1f688, 0x1f690, 0x1f69e, 0x1f6a0, 0x1f6bc, 0x1f6cc, 0x1f6f2, 0x1f6f4, 0x1f71a, 0x1f72e,\n 0x1f732, 0x1f734, 0x1f74e, 0x1f75c, 0x1f762, 0x1f764, 0x1f768, 0x1f776, 0x1f796, 0x1f7a6, 0x1f7ac, 0x1f7ba,\n 0x1f7d2, 0x1f7d4, 0x1f89a, 0x1f8ae, 0x1f8b2, 0x1f8b4, 0x1f8d6, 0x1f8ea, 0x1f91a, 0x1f92e, 0x1f932, 0x1f934,\n 0x1f94e, 0x1f95c, 0x1f962, 0x1f964, 0x1f968, 0x1f976, 0x1f996, 0x1f9a6, 0x1f9ac, 0x1f9ba, 0x1f9ca, 0x1f9d2,\n 0x1f9d4, 0x1fa1a, 0x1fa2e, 0x1fa32, 0x1fa34, 0x1fa4e, 0x1fa5c, 0x1fa62, 0x1fa64, 0x1fa68, 0x1fa76, 0x1fa8e,\n 0x1fa9c, 0x1fab8, 0x1fac2, 0x1fac4, 0x1fac8, 0x1fad0, 0x1fade, 0x1fae6, 0x1faec, 0x1fb16, 0x1fb26, 0x1fb2c,\n 0x1fb3a, 0x1fb46, 0x1fb4c, 0x1fb58, 0x1fb6e, 0x1fb72, 0x1fb74, 0x1fb8a, 0x1fb92, 0x1fb94, 0x1fba2, 0x1fba4,\n 0x1fba8, 0x1fbb6, 0x1fbda\n ]);\n /**\n * This table contains to codewords for all symbols.\n */\n PDF417Common.CODEWORD_TABLE = Int32Array.from([\n 2627, 1819, 2622, 2621, 1813, 1812, 2729, 2724, 2723, 2779, 2774, 2773, 902, 896, 908, 868, 865, 861, 859, 2511,\n 873, 871, 1780, 835, 2493, 825, 2491, 842, 837, 844, 1764, 1762, 811, 810, 809, 2483, 807, 2482, 806, 2480, 815,\n 814, 813, 812, 2484, 817, 816, 1745, 1744, 1742, 1746, 2655, 2637, 2635, 2626, 2625, 2623, 2628, 1820, 2752,\n 2739, 2737, 2728, 2727, 2725, 2730, 2785, 2783, 2778, 2777, 2775, 2780, 787, 781, 747, 739, 736, 2413, 754, 752,\n 1719, 692, 689, 681, 2371, 678, 2369, 700, 697, 694, 703, 1688, 1686, 642, 638, 2343, 631, 2341, 627, 2338, 651,\n 646, 643, 2345, 654, 652, 1652, 1650, 1647, 1654, 601, 599, 2322, 596, 2321, 594, 2319, 2317, 611, 610, 608, 606,\n 2324, 603, 2323, 615, 614, 612, 1617, 1616, 1614, 1612, 616, 1619, 1618, 2575, 2538, 2536, 905, 901, 898, 909,\n 2509, 2507, 2504, 870, 867, 864, 860, 2512, 875, 872, 1781, 2490, 2489, 2487, 2485, 1748, 836, 834, 832, 830,\n 2494, 827, 2492, 843, 841, 839, 845, 1765, 1763, 2701, 2676, 2674, 2653, 2648, 2656, 2634, 2633, 2631, 2629,\n 1821, 2638, 2636, 2770, 2763, 2761, 2750, 2745, 2753, 2736, 2735, 2733, 2731, 1848, 2740, 2738, 2786, 2784, 591,\n 588, 576, 569, 566, 2296, 1590, 537, 534, 526, 2276, 522, 2274, 545, 542, 539, 548, 1572, 1570, 481, 2245, 466,\n 2242, 462, 2239, 492, 485, 482, 2249, 496, 494, 1534, 1531, 1528, 1538, 413, 2196, 406, 2191, 2188, 425, 419,\n 2202, 415, 2199, 432, 430, 427, 1472, 1467, 1464, 433, 1476, 1474, 368, 367, 2160, 365, 2159, 362, 2157, 2155,\n 2152, 378, 377, 375, 2166, 372, 2165, 369, 2162, 383, 381, 379, 2168, 1419, 1418, 1416, 1414, 385, 1411, 384,\n 1423, 1422, 1420, 1424, 2461, 802, 2441, 2439, 790, 786, 783, 794, 2409, 2406, 2403, 750, 742, 738, 2414, 756,\n 753, 1720, 2367, 2365, 2362, 2359, 1663, 693, 691, 684, 2373, 680, 2370, 702, 699, 696, 704, 1690, 1687, 2337,\n 2336, 2334, 2332, 1624, 2329, 1622, 640, 637, 2344, 634, 2342, 630, 2340, 650, 648, 645, 2346, 655, 653, 1653,\n 1651, 1649, 1655, 2612, 2597, 2595, 2571, 2568, 2565, 2576, 2534, 2529, 2526, 1787, 2540, 2537, 907, 904, 900,\n 910, 2503, 2502, 2500, 2498, 1768, 2495, 1767, 2510, 2508, 2506, 869, 866, 863, 2513, 876, 874, 1782, 2720, 2713,\n 2711, 2697, 2694, 2691, 2702, 2672, 2670, 2664, 1828, 2678, 2675, 2647, 2646, 2644, 2642, 1823, 2639, 1822, 2654,\n 2652, 2650, 2657, 2771, 1855, 2765, 2762, 1850, 1849, 2751, 2749, 2747, 2754, 353, 2148, 344, 342, 336, 2142,\n 332, 2140, 345, 1375, 1373, 306, 2130, 299, 2128, 295, 2125, 319, 314, 311, 2132, 1354, 1352, 1349, 1356, 262,\n 257, 2101, 253, 2096, 2093, 274, 273, 267, 2107, 263, 2104, 280, 278, 275, 1316, 1311, 1308, 1320, 1318, 2052,\n 202, 2050, 2044, 2040, 219, 2063, 212, 2060, 208, 2055, 224, 221, 2066, 1260, 1258, 1252, 231, 1248, 229, 1266,\n 1264, 1261, 1268, 155, 1998, 153, 1996, 1994, 1991, 1988, 165, 164, 2007, 162, 2006, 159, 2003, 2000, 172, 171,\n 169, 2012, 166, 2010, 1186, 1184, 1182, 1179, 175, 1176, 173, 1192, 1191, 1189, 1187, 176, 1194, 1193, 2313,\n 2307, 2305, 592, 589, 2294, 2292, 2289, 578, 572, 568, 2297, 580, 1591, 2272, 2267, 2264, 1547, 538, 536, 529,\n 2278, 525, 2275, 547, 544, 541, 1574, 1571, 2237, 2235, 2229, 1493, 2225, 1489, 478, 2247, 470, 2244, 465, 2241,\n 493, 488, 484, 2250, 498, 495, 1536, 1533, 1530, 1539, 2187, 2186, 2184, 2182, 1432, 2179, 1430, 2176, 1427, 414,\n 412, 2197, 409, 2195, 405, 2193, 2190, 426, 424, 421, 2203, 418, 2201, 431, 429, 1473, 1471, 1469, 1466, 434,\n 1477, 1475, 2478, 2472, 2470, 2459, 2457, 2454, 2462, 803, 2437, 2432, 2429, 1726, 2443, 2440, 792, 789, 785,\n 2401, 2399, 2393, 1702, 2389, 1699, 2411, 2408, 2405, 745, 741, 2415, 758, 755, 1721, 2358, 2357, 2355, 2353,\n 1661, 2350, 1660, 2347, 1657, 2368, 2366, 2364, 2361, 1666, 690, 687, 2374, 683, 2372, 701, 698, 705, 1691, 1689,\n 2619, 2617, 2610, 2608, 2605, 2613, 2593, 2588, 2585, 1803, 2599, 2596, 2563, 2561, 2555, 1797, 2551, 1795, 2573,\n 2570, 2567, 2577, 2525, 2524, 2522, 2520, 1786, 2517, 1785, 2514, 1783, 2535, 2533, 2531, 2528, 1788, 2541, 2539,\n 906, 903, 911, 2721, 1844, 2715, 2712, 1838, 1836, 2699, 2696, 2693, 2703, 1827, 1826, 1824, 2673, 2671, 2669,\n 2666, 1829, 2679, 2677, 1858, 1857, 2772, 1854, 1853, 1851, 1856, 2766, 2764, 143, 1987, 139, 1986, 135, 133,\n 131, 1984, 128, 1983, 125, 1981, 138, 137, 136, 1985, 1133, 1132, 1130, 112, 110, 1974, 107, 1973, 104, 1971,\n 1969, 122, 121, 119, 117, 1977, 114, 1976, 124, 1115, 1114, 1112, 1110, 1117, 1116, 84, 83, 1953, 81, 1952, 78,\n 1950, 1948, 1945, 94, 93, 91, 1959, 88, 1958, 85, 1955, 99, 97, 95, 1961, 1086, 1085, 1083, 1081, 1078, 100,\n 1090, 1089, 1087, 1091, 49, 47, 1917, 44, 1915, 1913, 1910, 1907, 59, 1926, 56, 1925, 53, 1922, 1919, 66, 64,\n 1931, 61, 1929, 1042, 1040, 1038, 71, 1035, 70, 1032, 68, 1048, 1047, 1045, 1043, 1050, 1049, 12, 10, 1869, 1867,\n 1864, 1861, 21, 1880, 19, 1877, 1874, 1871, 28, 1888, 25, 1886, 22, 1883, 982, 980, 977, 974, 32, 30, 991, 989,\n 987, 984, 34, 995, 994, 992, 2151, 2150, 2147, 2146, 2144, 356, 355, 354, 2149, 2139, 2138, 2136, 2134, 1359,\n 343, 341, 338, 2143, 335, 2141, 348, 347, 346, 1376, 1374, 2124, 2123, 2121, 2119, 1326, 2116, 1324, 310, 308,\n 305, 2131, 302, 2129, 298, 2127, 320, 318, 316, 313, 2133, 322, 321, 1355, 1353, 1351, 1357, 2092, 2091, 2089,\n 2087, 1276, 2084, 1274, 2081, 1271, 259, 2102, 256, 2100, 252, 2098, 2095, 272, 269, 2108, 266, 2106, 281, 279,\n 277, 1317, 1315, 1313, 1310, 282, 1321, 1319, 2039, 2037, 2035, 2032, 1203, 2029, 1200, 1197, 207, 2053, 205,\n 2051, 201, 2049, 2046, 2043, 220, 218, 2064, 215, 2062, 211, 2059, 228, 226, 223, 2069, 1259, 1257, 1254, 232,\n 1251, 230, 1267, 1265, 1263, 2316, 2315, 2312, 2311, 2309, 2314, 2304, 2303, 2301, 2299, 1593, 2308, 2306, 590,\n 2288, 2287, 2285, 2283, 1578, 2280, 1577, 2295, 2293, 2291, 579, 577, 574, 571, 2298, 582, 581, 1592, 2263, 2262,\n 2260, 2258, 1545, 2255, 1544, 2252, 1541, 2273, 2271, 2269, 2266, 1550, 535, 532, 2279, 528, 2277, 546, 543, 549,\n 1575, 1573, 2224, 2222, 2220, 1486, 2217, 1485, 2214, 1482, 1479, 2238, 2236, 2234, 2231, 1496, 2228, 1492, 480,\n 477, 2248, 473, 2246, 469, 2243, 490, 487, 2251, 497, 1537, 1535, 1532, 2477, 2476, 2474, 2479, 2469, 2468, 2466,\n 2464, 1730, 2473, 2471, 2453, 2452, 2450, 2448, 1729, 2445, 1728, 2460, 2458, 2456, 2463, 805, 804, 2428, 2427,\n 2425, 2423, 1725, 2420, 1724, 2417, 1722, 2438, 2436, 2434, 2431, 1727, 2444, 2442, 793, 791, 788, 795, 2388,\n 2386, 2384, 1697, 2381, 1696, 2378, 1694, 1692, 2402, 2400, 2398, 2395, 1703, 2392, 1701, 2412, 2410, 2407, 751,\n 748, 744, 2416, 759, 757, 1807, 2620, 2618, 1806, 1805, 2611, 2609, 2607, 2614, 1802, 1801, 1799, 2594, 2592,\n 2590, 2587, 1804, 2600, 2598, 1794, 1793, 1791, 1789, 2564, 2562, 2560, 2557, 1798, 2554, 1796, 2574, 2572, 2569,\n 2578, 1847, 1846, 2722, 1843, 1842, 1840, 1845, 2716, 2714, 1835, 1834, 1832, 1830, 1839, 1837, 2700, 2698, 2695,\n 2704, 1817, 1811, 1810, 897, 862, 1777, 829, 826, 838, 1760, 1758, 808, 2481, 1741, 1740, 1738, 1743, 2624, 1818,\n 2726, 2776, 782, 740, 737, 1715, 686, 679, 695, 1682, 1680, 639, 628, 2339, 647, 644, 1645, 1643, 1640, 1648,\n 602, 600, 597, 595, 2320, 593, 2318, 609, 607, 604, 1611, 1610, 1608, 1606, 613, 1615, 1613, 2328, 926, 924, 892,\n 886, 899, 857, 850, 2505, 1778, 824, 823, 821, 819, 2488, 818, 2486, 833, 831, 828, 840, 1761, 1759, 2649, 2632,\n 2630, 2746, 2734, 2732, 2782, 2781, 570, 567, 1587, 531, 527, 523, 540, 1566, 1564, 476, 467, 463, 2240, 486,\n 483, 1524, 1521, 1518, 1529, 411, 403, 2192, 399, 2189, 423, 416, 1462, 1457, 1454, 428, 1468, 1465, 2210, 366,\n 363, 2158, 360, 2156, 357, 2153, 376, 373, 370, 2163, 1410, 1409, 1407, 1405, 382, 1402, 380, 1417, 1415, 1412,\n 1421, 2175, 2174, 777, 774, 771, 784, 732, 725, 722, 2404, 743, 1716, 676, 674, 668, 2363, 665, 2360, 685, 1684,\n 1681, 626, 624, 622, 2335, 620, 2333, 617, 2330, 641, 635, 649, 1646, 1644, 1642, 2566, 928, 925, 2530, 2527,\n 894, 891, 888, 2501, 2499, 2496, 858, 856, 854, 851, 1779, 2692, 2668, 2665, 2645, 2643, 2640, 2651, 2768, 2759,\n 2757, 2744, 2743, 2741, 2748, 352, 1382, 340, 337, 333, 1371, 1369, 307, 300, 296, 2126, 315, 312, 1347, 1342,\n 1350, 261, 258, 250, 2097, 246, 2094, 271, 268, 264, 1306, 1301, 1298, 276, 1312, 1309, 2115, 203, 2048, 195,\n 2045, 191, 2041, 213, 209, 2056, 1246, 1244, 1238, 225, 1234, 222, 1256, 1253, 1249, 1262, 2080, 2079, 154, 1997,\n 150, 1995, 147, 1992, 1989, 163, 160, 2004, 156, 2001, 1175, 1174, 1172, 1170, 1167, 170, 1164, 167, 1185, 1183,\n 1180, 1177, 174, 1190, 1188, 2025, 2024, 2022, 587, 586, 564, 559, 556, 2290, 573, 1588, 520, 518, 512, 2268,\n 508, 2265, 530, 1568, 1565, 461, 457, 2233, 450, 2230, 446, 2226, 479, 471, 489, 1526, 1523, 1520, 397, 395,\n 2185, 392, 2183, 389, 2180, 2177, 410, 2194, 402, 422, 1463, 1461, 1459, 1456, 1470, 2455, 799, 2433, 2430, 779,\n 776, 773, 2397, 2394, 2390, 734, 728, 724, 746, 1717, 2356, 2354, 2351, 2348, 1658, 677, 675, 673, 670, 667, 688,\n 1685, 1683, 2606, 2589, 2586, 2559, 2556, 2552, 927, 2523, 2521, 2518, 2515, 1784, 2532, 895, 893, 890, 2718,\n 2709, 2707, 2689, 2687, 2684, 2663, 2662, 2660, 2658, 1825, 2667, 2769, 1852, 2760, 2758, 142, 141, 1139, 1138,\n 134, 132, 129, 126, 1982, 1129, 1128, 1126, 1131, 113, 111, 108, 105, 1972, 101, 1970, 120, 118, 115, 1109, 1108,\n 1106, 1104, 123, 1113, 1111, 82, 79, 1951, 75, 1949, 72, 1946, 92, 89, 86, 1956, 1077, 1076, 1074, 1072, 98,\n 1069, 96, 1084, 1082, 1079, 1088, 1968, 1967, 48, 45, 1916, 42, 1914, 39, 1911, 1908, 60, 57, 54, 1923, 50, 1920,\n 1031, 1030, 1028, 1026, 67, 1023, 65, 1020, 62, 1041, 1039, 1036, 1033, 69, 1046, 1044, 1944, 1943, 1941, 11, 9,\n 1868, 7, 1865, 1862, 1859, 20, 1878, 16, 1875, 13, 1872, 970, 968, 966, 963, 29, 960, 26, 23, 983, 981, 978, 975,\n 33, 971, 31, 990, 988, 985, 1906, 1904, 1902, 993, 351, 2145, 1383, 331, 330, 328, 326, 2137, 323, 2135, 339,\n 1372, 1370, 294, 293, 291, 289, 2122, 286, 2120, 283, 2117, 309, 303, 317, 1348, 1346, 1344, 245, 244, 242, 2090,\n 239, 2088, 236, 2085, 2082, 260, 2099, 249, 270, 1307, 1305, 1303, 1300, 1314, 189, 2038, 186, 2036, 183, 2033,\n 2030, 2026, 206, 198, 2047, 194, 216, 1247, 1245, 1243, 1240, 227, 1237, 1255, 2310, 2302, 2300, 2286, 2284,\n 2281, 565, 563, 561, 558, 575, 1589, 2261, 2259, 2256, 2253, 1542, 521, 519, 517, 514, 2270, 511, 533, 1569,\n 1567, 2223, 2221, 2218, 2215, 1483, 2211, 1480, 459, 456, 453, 2232, 449, 474, 491, 1527, 1525, 1522, 2475, 2467,\n 2465, 2451, 2449, 2446, 801, 800, 2426, 2424, 2421, 2418, 1723, 2435, 780, 778, 775, 2387, 2385, 2382, 2379,\n 1695, 2375, 1693, 2396, 735, 733, 730, 727, 749, 1718, 2616, 2615, 2604, 2603, 2601, 2584, 2583, 2581, 2579,\n 1800, 2591, 2550, 2549, 2547, 2545, 1792, 2542, 1790, 2558, 929, 2719, 1841, 2710, 2708, 1833, 1831, 2690, 2688,\n 2686, 1815, 1809, 1808, 1774, 1756, 1754, 1737, 1736, 1734, 1739, 1816, 1711, 1676, 1674, 633, 629, 1638, 1636,\n 1633, 1641, 598, 1605, 1604, 1602, 1600, 605, 1609, 1607, 2327, 887, 853, 1775, 822, 820, 1757, 1755, 1584, 524,\n 1560, 1558, 468, 464, 1514, 1511, 1508, 1519, 408, 404, 400, 1452, 1447, 1444, 417, 1458, 1455, 2208, 364, 361,\n 358, 2154, 1401, 1400, 1398, 1396, 374, 1393, 371, 1408, 1406, 1403, 1413, 2173, 2172, 772, 726, 723, 1712, 672,\n 669, 666, 682, 1678, 1675, 625, 623, 621, 618, 2331, 636, 632, 1639, 1637, 1635, 920, 918, 884, 880, 889, 849,\n 848, 847, 846, 2497, 855, 852, 1776, 2641, 2742, 2787, 1380, 334, 1367, 1365, 301, 297, 1340, 1338, 1335, 1343,\n 255, 251, 247, 1296, 1291, 1288, 265, 1302, 1299, 2113, 204, 196, 192, 2042, 1232, 1230, 1224, 214, 1220, 210,\n 1242, 1239, 1235, 1250, 2077, 2075, 151, 148, 1993, 144, 1990, 1163, 1162, 1160, 1158, 1155, 161, 1152, 157,\n 1173, 1171, 1168, 1165, 168, 1181, 1178, 2021, 2020, 2018, 2023, 585, 560, 557, 1585, 516, 509, 1562, 1559, 458,\n 447, 2227, 472, 1516, 1513, 1510, 398, 396, 393, 390, 2181, 386, 2178, 407, 1453, 1451, 1449, 1446, 420, 1460,\n 2209, 769, 764, 720, 712, 2391, 729, 1713, 664, 663, 661, 659, 2352, 656, 2349, 671, 1679, 1677, 2553, 922, 919,\n 2519, 2516, 885, 883, 881, 2685, 2661, 2659, 2767, 2756, 2755, 140, 1137, 1136, 130, 127, 1125, 1124, 1122, 1127,\n 109, 106, 102, 1103, 1102, 1100, 1098, 116, 1107, 1105, 1980, 80, 76, 73, 1947, 1068, 1067, 1065, 1063, 90, 1060,\n 87, 1075, 1073, 1070, 1080, 1966, 1965, 46, 43, 40, 1912, 36, 1909, 1019, 1018, 1016, 1014, 58, 1011, 55, 1008,\n 51, 1029, 1027, 1024, 1021, 63, 1037, 1034, 1940, 1939, 1937, 1942, 8, 1866, 4, 1863, 1, 1860, 956, 954, 952,\n 949, 946, 17, 14, 969, 967, 964, 961, 27, 957, 24, 979, 976, 972, 1901, 1900, 1898, 1896, 986, 1905, 1903, 350,\n 349, 1381, 329, 327, 324, 1368, 1366, 292, 290, 287, 284, 2118, 304, 1341, 1339, 1337, 1345, 243, 240, 237, 2086,\n 233, 2083, 254, 1297, 1295, 1293, 1290, 1304, 2114, 190, 187, 184, 2034, 180, 2031, 177, 2027, 199, 1233, 1231,\n 1229, 1226, 217, 1223, 1241, 2078, 2076, 584, 555, 554, 552, 550, 2282, 562, 1586, 507, 506, 504, 502, 2257, 499,\n 2254, 515, 1563, 1561, 445, 443, 441, 2219, 438, 2216, 435, 2212, 460, 454, 475, 1517, 1515, 1512, 2447, 798,\n 797, 2422, 2419, 770, 768, 766, 2383, 2380, 2376, 721, 719, 717, 714, 731, 1714, 2602, 2582, 2580, 2548, 2546,\n 2543, 923, 921, 2717, 2706, 2705, 2683, 2682, 2680, 1771, 1752, 1750, 1733, 1732, 1731, 1735, 1814, 1707, 1670,\n 1668, 1631, 1629, 1626, 1634, 1599, 1598, 1596, 1594, 1603, 1601, 2326, 1772, 1753, 1751, 1581, 1554, 1552, 1504,\n 1501, 1498, 1509, 1442, 1437, 1434, 401, 1448, 1445, 2206, 1392, 1391, 1389, 1387, 1384, 359, 1399, 1397, 1394,\n 1404, 2171, 2170, 1708, 1672, 1669, 619, 1632, 1630, 1628, 1773, 1378, 1363, 1361, 1333, 1328, 1336, 1286, 1281,\n 1278, 248, 1292, 1289, 2111, 1218, 1216, 1210, 197, 1206, 193, 1228, 1225, 1221, 1236, 2073, 2071, 1151, 1150,\n 1148, 1146, 152, 1143, 149, 1140, 145, 1161, 1159, 1156, 1153, 158, 1169, 1166, 2017, 2016, 2014, 2019, 1582,\n 510, 1556, 1553, 452, 448, 1506, 1500, 394, 391, 387, 1443, 1441, 1439, 1436, 1450, 2207, 765, 716, 713, 1709,\n 662, 660, 657, 1673, 1671, 916, 914, 879, 878, 877, 882, 1135, 1134, 1121, 1120, 1118, 1123, 1097, 1096, 1094,\n 1092, 103, 1101, 1099, 1979, 1059, 1058, 1056, 1054, 77, 1051, 74, 1066, 1064, 1061, 1071, 1964, 1963, 1007,\n 1006, 1004, 1002, 999, 41, 996, 37, 1017, 1015, 1012, 1009, 52, 1025, 1022, 1936, 1935, 1933, 1938, 942, 940,\n 938, 935, 932, 5, 2, 955, 953, 950, 947, 18, 943, 15, 965, 962, 958, 1895, 1894, 1892, 1890, 973, 1899, 1897,\n 1379, 325, 1364, 1362, 288, 285, 1334, 1332, 1330, 241, 238, 234, 1287, 1285, 1283, 1280, 1294, 2112, 188, 185,\n 181, 178, 2028, 1219, 1217, 1215, 1212, 200, 1209, 1227, 2074, 2072, 583, 553, 551, 1583, 505, 503, 500, 513,\n 1557, 1555, 444, 442, 439, 436, 2213, 455, 451, 1507, 1505, 1502, 796, 763, 762, 760, 767, 711, 710, 708, 706,\n 2377, 718, 715, 1710, 2544, 917, 915, 2681, 1627, 1597, 1595, 2325, 1769, 1749, 1747, 1499, 1438, 1435, 2204,\n 1390, 1388, 1385, 1395, 2169, 2167, 1704, 1665, 1662, 1625, 1623, 1620, 1770, 1329, 1282, 1279, 2109, 1214, 1207,\n 1222, 2068, 2065, 1149, 1147, 1144, 1141, 146, 1157, 1154, 2013, 2011, 2008, 2015, 1579, 1549, 1546, 1495, 1487,\n 1433, 1431, 1428, 1425, 388, 1440, 2205, 1705, 658, 1667, 1664, 1119, 1095, 1093, 1978, 1057, 1055, 1052, 1062,\n 1962, 1960, 1005, 1003, 1000, 997, 38, 1013, 1010, 1932, 1930, 1927, 1934, 941, 939, 936, 933, 6, 930, 3, 951,\n 948, 944, 1889, 1887, 1884, 1881, 959, 1893, 1891, 35, 1377, 1360, 1358, 1327, 1325, 1322, 1331, 1277, 1275,\n 1272, 1269, 235, 1284, 2110, 1205, 1204, 1201, 1198, 182, 1195, 179, 1213, 2070, 2067, 1580, 501, 1551, 1548,\n 440, 437, 1497, 1494, 1490, 1503, 761, 709, 707, 1706, 913, 912, 2198, 1386, 2164, 2161, 1621, 1766, 2103, 1208,\n 2058, 2054, 1145, 1142, 2005, 2002, 1999, 2009, 1488, 1429, 1426, 2200, 1698, 1659, 1656, 1975, 1053, 1957, 1954,\n 1001, 998, 1924, 1921, 1918, 1928, 937, 934, 931, 1879, 1876, 1873, 1870, 945, 1885, 1882, 1323, 1273, 1270,\n 2105, 1202, 1199, 1196, 1211, 2061, 2057, 1576, 1543, 1540, 1484, 1481, 1478, 1491, 1700\n ]);\n\n /*\n * Copyright 2007 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // import java.util.List;\n /**\n * @author Guenther Grau\n */\n /*public final*/ class PDF417DetectorResult {\n constructor(bits, points) {\n this.bits = bits;\n this.points = points;\n }\n getBits() {\n return this.bits;\n }\n getPoints() {\n return this.points;\n }\n }\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // import java.util.ArrayList;\n // import java.util.Arrays;\n // import java.util.List;\n // import java.util.Map;\n /**\n *

Encapsulates logic that can detect a PDF417 Code in an image, even if the\n * PDF417 Code is rotated or skewed, or partially obscured.

\n *\n * @author SITA Lab (kevin.osullivan@sita.aero)\n * @author dswitkin@google.com (Daniel Switkin)\n * @author Guenther Grau\n */\n /*public*/ /*final*/ class Detector$3 {\n /**\n *

Detects a PDF417 Code in an image. Only checks 0 and 180 degree rotations.

\n *\n * @param image barcode image to decode\n * @param hints optional hints to detector\n * @param multiple if true, then the image is searched for multiple codes. If false, then at most one code will\n * be found and returned\n * @return {@link PDF417DetectorResult} encapsulating results of detecting a PDF417 code\n * @throws NotFoundException if no PDF417 Code can be found\n */\n static detectMultiple(image, hints, multiple) {\n // TODO detection improvement, tryHarder could try several different luminance thresholds/blackpoints or even\n // different binarizers\n // boolean tryHarder = hints != null && hints.containsKey(DecodeHintType.TRY_HARDER);\n let bitMatrix = image.getBlackMatrix();\n let barcodeCoordinates = Detector$3.detect(multiple, bitMatrix);\n if (!barcodeCoordinates.length) {\n bitMatrix = bitMatrix.clone();\n bitMatrix.rotate180();\n barcodeCoordinates = Detector$3.detect(multiple, bitMatrix);\n }\n return new PDF417DetectorResult(bitMatrix, barcodeCoordinates);\n }\n /**\n * Detects PDF417 codes in an image. Only checks 0 degree rotation\n * @param multiple if true, then the image is searched for multiple codes. If false, then at most one code will\n * be found and returned\n * @param bitMatrix bit matrix to detect barcodes in\n * @return List of ResultPoint arrays containing the coordinates of found barcodes\n */\n static detect(multiple, bitMatrix) {\n const barcodeCoordinates = new Array();\n let row = 0;\n let column = 0;\n let foundBarcodeInRow = false;\n while (row < bitMatrix.getHeight()) {\n const vertices = Detector$3.findVertices(bitMatrix, row, column);\n if (vertices[0] == null && vertices[3] == null) {\n if (!foundBarcodeInRow) {\n // we didn't find any barcode so that's the end of searching\n break;\n }\n // we didn't find a barcode starting at the given column and row. Try again from the first column and slightly\n // below the lowest barcode we found so far.\n foundBarcodeInRow = false;\n column = 0;\n for (const barcodeCoordinate of barcodeCoordinates) {\n if (barcodeCoordinate[1] != null) {\n row = Math.trunc(Math.max(row, barcodeCoordinate[1].getY()));\n }\n if (barcodeCoordinate[3] != null) {\n row = Math.max(row, Math.trunc(barcodeCoordinate[3].getY()));\n }\n }\n row += Detector$3.ROW_STEP;\n continue;\n }\n foundBarcodeInRow = true;\n barcodeCoordinates.push(vertices);\n if (!multiple) {\n break;\n }\n // if we didn't find a right row indicator column, then continue the search for the next barcode after the\n // start pattern of the barcode just found.\n if (vertices[2] != null) {\n column = Math.trunc(vertices[2].getX());\n row = Math.trunc(vertices[2].getY());\n }\n else {\n column = Math.trunc(vertices[4].getX());\n row = Math.trunc(vertices[4].getY());\n }\n }\n return barcodeCoordinates;\n }\n /**\n * Locate the vertices and the codewords area of a black blob using the Start\n * and Stop patterns as locators.\n *\n * @param matrix the scanned barcode image.\n * @return an array containing the vertices:\n * vertices[0] x, y top left barcode\n * vertices[1] x, y bottom left barcode\n * vertices[2] x, y top right barcode\n * vertices[3] x, y bottom right barcode\n * vertices[4] x, y top left codeword area\n * vertices[5] x, y bottom left codeword area\n * vertices[6] x, y top right codeword area\n * vertices[7] x, y bottom right codeword area\n */\n static findVertices(matrix, startRow, startColumn) {\n const height = matrix.getHeight();\n const width = matrix.getWidth();\n // const result = new ResultPoint[8];\n const result = new Array(8);\n Detector$3.copyToResult(result, Detector$3.findRowsWithPattern(matrix, height, width, startRow, startColumn, Detector$3.START_PATTERN), Detector$3.INDEXES_START_PATTERN);\n if (result[4] != null) {\n startColumn = Math.trunc(result[4].getX());\n startRow = Math.trunc(result[4].getY());\n }\n Detector$3.copyToResult(result, Detector$3.findRowsWithPattern(matrix, height, width, startRow, startColumn, Detector$3.STOP_PATTERN), Detector$3.INDEXES_STOP_PATTERN);\n return result;\n }\n static copyToResult(result, tmpResult, destinationIndexes) {\n for (let i = 0; i < destinationIndexes.length; i++) {\n result[destinationIndexes[i]] = tmpResult[i];\n }\n }\n static findRowsWithPattern(matrix, height, width, startRow, startColumn, pattern) {\n // const result = new ResultPoint[4];\n const result = new Array(4);\n let found = false;\n const counters = new Int32Array(pattern.length);\n for (; startRow < height; startRow += Detector$3.ROW_STEP) {\n let loc = Detector$3.findGuardPattern(matrix, startColumn, startRow, width, false, pattern, counters);\n if (loc != null) {\n while (startRow > 0) {\n const previousRowLoc = Detector$3.findGuardPattern(matrix, startColumn, --startRow, width, false, pattern, counters);\n if (previousRowLoc != null) {\n loc = previousRowLoc;\n }\n else {\n startRow++;\n break;\n }\n }\n result[0] = new ResultPoint(loc[0], startRow);\n result[1] = new ResultPoint(loc[1], startRow);\n found = true;\n break;\n }\n }\n let stopRow = startRow + 1;\n // Last row of the current symbol that contains pattern\n if (found) {\n let skippedRowCount = 0;\n let previousRowLoc = Int32Array.from([Math.trunc(result[0].getX()), Math.trunc(result[1].getX())]);\n for (; stopRow < height; stopRow++) {\n const loc = Detector$3.findGuardPattern(matrix, previousRowLoc[0], stopRow, width, false, pattern, counters);\n // a found pattern is only considered to belong to the same barcode if the start and end positions\n // don't differ too much. Pattern drift should be not bigger than two for consecutive rows. With\n // a higher number of skipped rows drift could be larger. To keep it simple for now, we allow a slightly\n // larger drift and don't check for skipped rows.\n if (loc != null &&\n Math.abs(previousRowLoc[0] - loc[0]) < Detector$3.MAX_PATTERN_DRIFT &&\n Math.abs(previousRowLoc[1] - loc[1]) < Detector$3.MAX_PATTERN_DRIFT) {\n previousRowLoc = loc;\n skippedRowCount = 0;\n }\n else {\n if (skippedRowCount > Detector$3.SKIPPED_ROW_COUNT_MAX) {\n break;\n }\n else {\n skippedRowCount++;\n }\n }\n }\n stopRow -= skippedRowCount + 1;\n result[2] = new ResultPoint(previousRowLoc[0], stopRow);\n result[3] = new ResultPoint(previousRowLoc[1], stopRow);\n }\n if (stopRow - startRow < Detector$3.BARCODE_MIN_HEIGHT) {\n Arrays.fill(result, null);\n }\n return result;\n }\n /**\n * @param matrix row of black/white values to search\n * @param column x position to start search\n * @param row y position to start search\n * @param width the number of pixels to search on this row\n * @param pattern pattern of counts of number of black and white pixels that are\n * being searched for as a pattern\n * @param counters array of counters, as long as pattern, to re-use\n * @return start/end horizontal offset of guard pattern, as an array of two ints.\n */\n static findGuardPattern(matrix, column, row, width, whiteFirst, pattern, counters) {\n Arrays.fillWithin(counters, 0, counters.length, 0);\n let patternStart = column;\n let pixelDrift = 0;\n // if there are black pixels left of the current pixel shift to the left, but only for MAX_PIXEL_DRIFT pixels\n while (matrix.get(patternStart, row) && patternStart > 0 && pixelDrift++ < Detector$3.MAX_PIXEL_DRIFT) {\n patternStart--;\n }\n let x = patternStart;\n let counterPosition = 0;\n let patternLength = pattern.length;\n for (let isWhite = whiteFirst; x < width; x++) {\n let pixel = matrix.get(x, row);\n if (pixel !== isWhite) {\n counters[counterPosition]++;\n }\n else {\n if (counterPosition === patternLength - 1) {\n if (Detector$3.patternMatchVariance(counters, pattern, Detector$3.MAX_INDIVIDUAL_VARIANCE) < Detector$3.MAX_AVG_VARIANCE) {\n return new Int32Array([patternStart, x]);\n }\n patternStart += counters[0] + counters[1];\n System.arraycopy(counters, 2, counters, 0, counterPosition - 1);\n counters[counterPosition - 1] = 0;\n counters[counterPosition] = 0;\n counterPosition--;\n }\n else {\n counterPosition++;\n }\n counters[counterPosition] = 1;\n isWhite = !isWhite;\n }\n }\n if (counterPosition === patternLength - 1 &&\n Detector$3.patternMatchVariance(counters, pattern, Detector$3.MAX_INDIVIDUAL_VARIANCE) < Detector$3.MAX_AVG_VARIANCE) {\n return new Int32Array([patternStart, x - 1]);\n }\n return null;\n }\n /**\n * Determines how closely a set of observed counts of runs of black/white\n * values matches a given target pattern. This is reported as the ratio of\n * the total variance from the expected pattern proportions across all\n * pattern elements, to the length of the pattern.\n *\n * @param counters observed counters\n * @param pattern expected pattern\n * @param maxIndividualVariance The most any counter can differ before we give up\n * @return ratio of total variance between counters and pattern compared to total pattern size\n */\n static patternMatchVariance(counters, pattern, maxIndividualVariance) {\n let numCounters = counters.length;\n let total = 0;\n let patternLength = 0;\n for (let i = 0; i < numCounters; i++) {\n total += counters[i];\n patternLength += pattern[i];\n }\n if (total < patternLength) {\n // If we don't even have one pixel per unit of bar width, assume this\n // is too small to reliably match, so fail:\n return /*Float.POSITIVE_INFINITY*/ Infinity;\n }\n // We're going to fake floating-point math in integers. We just need to use more bits.\n // Scale up patternLength so that intermediate values below like scaledCounter will have\n // more \"significant digits\".\n let unitBarWidth = total / patternLength;\n maxIndividualVariance *= unitBarWidth;\n let totalVariance = 0.0;\n for (let x = 0; x < numCounters; x++) {\n let counter = counters[x];\n let scaledPattern = pattern[x] * unitBarWidth;\n let variance = counter > scaledPattern ? counter - scaledPattern : scaledPattern - counter;\n if (variance > maxIndividualVariance) {\n return /*Float.POSITIVE_INFINITY*/ Infinity;\n }\n totalVariance += variance;\n }\n return totalVariance / total;\n }\n }\n Detector$3.INDEXES_START_PATTERN = Int32Array.from([0, 4, 1, 5]);\n Detector$3.INDEXES_STOP_PATTERN = Int32Array.from([6, 2, 7, 3]);\n Detector$3.MAX_AVG_VARIANCE = 0.42;\n Detector$3.MAX_INDIVIDUAL_VARIANCE = 0.8;\n // B S B S B S B S Bar/Space pattern\n // 11111111 0 1 0 1 0 1 000\n Detector$3.START_PATTERN = Int32Array.from([8, 1, 1, 1, 1, 1, 1, 3]);\n // 1111111 0 1 000 1 0 1 00 1\n Detector$3.STOP_PATTERN = Int32Array.from([7, 1, 1, 3, 1, 1, 1, 2, 1]);\n Detector$3.MAX_PIXEL_DRIFT = 3;\n Detector$3.MAX_PATTERN_DRIFT = 5;\n // if we set the value too low, then we don't detect the correct height of the bar if the start patterns are damaged.\n // if we set the value too high, then we might detect the start pattern from a neighbor barcode.\n Detector$3.SKIPPED_ROW_COUNT_MAX = 25;\n // A PDF471 barcode should have at least 3 rows, with each row being >= 3 times the module width. Therefore it should be at least\n // 9 pixels tall. To be conservative, we use about half the size to ensure we don't miss it.\n Detector$3.ROW_STEP = 5;\n Detector$3.BARCODE_MIN_HEIGHT = 10;\n\n /*\n * Copyright 2012 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author Sean Owen\n * @see com.google.zxing.common.reedsolomon.GenericGFPoly\n */\n /*final*/ class ModulusPoly {\n constructor(field, coefficients) {\n if (coefficients.length === 0) {\n throw new IllegalArgumentException();\n }\n this.field = field;\n let coefficientsLength = /*int*/ coefficients.length;\n if (coefficientsLength > 1 && coefficients[0] === 0) {\n // Leading term must be non-zero for anything except the constant polynomial \"0\"\n let firstNonZero = /*int*/ 1;\n while (firstNonZero < coefficientsLength && coefficients[firstNonZero] === 0) {\n firstNonZero++;\n }\n if (firstNonZero === coefficientsLength) {\n this.coefficients = new Int32Array([0]);\n }\n else {\n this.coefficients = new Int32Array(coefficientsLength - firstNonZero);\n System.arraycopy(coefficients, firstNonZero, this.coefficients, 0, this.coefficients.length);\n }\n }\n else {\n this.coefficients = coefficients;\n }\n }\n getCoefficients() {\n return this.coefficients;\n }\n /**\n * @return degree of this polynomial\n */\n getDegree() {\n return this.coefficients.length - 1;\n }\n /**\n * @return true iff this polynomial is the monomial \"0\"\n */\n isZero() {\n return this.coefficients[0] === 0;\n }\n /**\n * @return coefficient of x^degree term in this polynomial\n */\n getCoefficient(degree) {\n return this.coefficients[this.coefficients.length - 1 - degree];\n }\n /**\n * @return evaluation of this polynomial at a given point\n */\n evaluateAt(a) {\n if (a === 0) {\n // Just return the x^0 coefficient\n return this.getCoefficient(0);\n }\n if (a === 1) {\n // Just the sum of the coefficients\n let sum = /*int*/ 0;\n for (let coefficient /*int*/ of this.coefficients) {\n sum = this.field.add(sum, coefficient);\n }\n return sum;\n }\n let result = /*int*/ this.coefficients[0];\n let size = /*int*/ this.coefficients.length;\n for (let i /*int*/ = 1; i < size; i++) {\n result = this.field.add(this.field.multiply(a, result), this.coefficients[i]);\n }\n return result;\n }\n add(other) {\n if (!this.field.equals(other.field)) {\n throw new IllegalArgumentException('ModulusPolys do not have same ModulusGF field');\n }\n if (this.isZero()) {\n return other;\n }\n if (other.isZero()) {\n return this;\n }\n let smallerCoefficients = this.coefficients;\n let largerCoefficients = other.coefficients;\n if (smallerCoefficients.length > largerCoefficients.length) {\n let temp = smallerCoefficients;\n smallerCoefficients = largerCoefficients;\n largerCoefficients = temp;\n }\n let sumDiff = new Int32Array(largerCoefficients.length);\n let lengthDiff = /*int*/ largerCoefficients.length - smallerCoefficients.length;\n // Copy high-order terms only found in higher-degree polynomial's coefficients\n System.arraycopy(largerCoefficients, 0, sumDiff, 0, lengthDiff);\n for (let i /*int*/ = lengthDiff; i < largerCoefficients.length; i++) {\n sumDiff[i] = this.field.add(smallerCoefficients[i - lengthDiff], largerCoefficients[i]);\n }\n return new ModulusPoly(this.field, sumDiff);\n }\n subtract(other) {\n if (!this.field.equals(other.field)) {\n throw new IllegalArgumentException('ModulusPolys do not have same ModulusGF field');\n }\n if (other.isZero()) {\n return this;\n }\n return this.add(other.negative());\n }\n multiply(other) {\n if (other instanceof ModulusPoly) {\n return this.multiplyOther(other);\n }\n return this.multiplyScalar(other);\n }\n multiplyOther(other) {\n if (!this.field.equals(other.field)) {\n throw new IllegalArgumentException('ModulusPolys do not have same ModulusGF field');\n }\n if (this.isZero() || other.isZero()) {\n // return this.field.getZero();\n return new ModulusPoly(this.field, new Int32Array([0]));\n }\n let aCoefficients = this.coefficients;\n let aLength = /*int*/ aCoefficients.length;\n let bCoefficients = other.coefficients;\n let bLength = /*int*/ bCoefficients.length;\n let product = new Int32Array(aLength + bLength - 1);\n for (let i /*int*/ = 0; i < aLength; i++) {\n let aCoeff = /*int*/ aCoefficients[i];\n for (let j /*int*/ = 0; j < bLength; j++) {\n product[i + j] = this.field.add(product[i + j], this.field.multiply(aCoeff, bCoefficients[j]));\n }\n }\n return new ModulusPoly(this.field, product);\n }\n negative() {\n let size = /*int*/ this.coefficients.length;\n let negativeCoefficients = new Int32Array(size);\n for (let i /*int*/ = 0; i < size; i++) {\n negativeCoefficients[i] = this.field.subtract(0, this.coefficients[i]);\n }\n return new ModulusPoly(this.field, negativeCoefficients);\n }\n multiplyScalar(scalar) {\n if (scalar === 0) {\n return new ModulusPoly(this.field, new Int32Array([0]));\n }\n if (scalar === 1) {\n return this;\n }\n let size = /*int*/ this.coefficients.length;\n let product = new Int32Array(size);\n for (let i /*int*/ = 0; i < size; i++) {\n product[i] = this.field.multiply(this.coefficients[i], scalar);\n }\n return new ModulusPoly(this.field, product);\n }\n multiplyByMonomial(degree, coefficient) {\n if (degree < 0) {\n throw new IllegalArgumentException();\n }\n if (coefficient === 0) {\n return new ModulusPoly(this.field, new Int32Array([0]));\n }\n let size = /*int*/ this.coefficients.length;\n let product = new Int32Array(size + degree);\n for (let i /*int*/ = 0; i < size; i++) {\n product[i] = this.field.multiply(this.coefficients[i], coefficient);\n }\n return new ModulusPoly(this.field, product);\n }\n /*\n ModulusPoly[] divide(other: ModulusPoly) {\n if (!field.equals(other.field)) {\n throw new IllegalArgumentException(\"ModulusPolys do not have same ModulusGF field\");\n }\n if (other.isZero()) {\n throw new IllegalArgumentException(\"Divide by 0\");\n }\n \n let quotient: ModulusPoly = field.getZero();\n let remainder: ModulusPoly = this;\n \n let denominatorLeadingTerm: /*int/ number = other.getCoefficient(other.getDegree());\n let inverseDenominatorLeadingTerm: /*int/ number = field.inverse(denominatorLeadingTerm);\n \n while (remainder.getDegree() >= other.getDegree() && !remainder.isZero()) {\n let degreeDifference: /*int/ number = remainder.getDegree() - other.getDegree();\n let scale: /*int/ number = field.multiply(remainder.getCoefficient(remainder.getDegree()), inverseDenominatorLeadingTerm);\n let term: ModulusPoly = other.multiplyByMonomial(degreeDifference, scale);\n let iterationQuotient: ModulusPoly = field.buildMonomial(degreeDifference, scale);\n quotient = quotient.add(iterationQuotient);\n remainder = remainder.subtract(term);\n }\n \n return new ModulusPoly[] { quotient, remainder };\n }\n */\n // @Override\n toString() {\n let result = new StringBuilder( /*8 * this.getDegree()*/); // dynamic string size in JS\n for (let degree /*int*/ = this.getDegree(); degree >= 0; degree--) {\n let coefficient = /*int*/ this.getCoefficient(degree);\n if (coefficient !== 0) {\n if (coefficient < 0) {\n result.append(' - ');\n coefficient = -coefficient;\n }\n else {\n if (result.length() > 0) {\n result.append(' + ');\n }\n }\n if (degree === 0 || coefficient !== 1) {\n result.append(coefficient);\n }\n if (degree !== 0) {\n if (degree === 1) {\n result.append('x');\n }\n else {\n result.append('x^');\n result.append(degree);\n }\n }\n }\n }\n return result.toString();\n }\n }\n\n class ModulusBase {\n add(a, b) {\n return (a + b) % this.modulus;\n }\n subtract(a, b) {\n return (this.modulus + a - b) % this.modulus;\n }\n exp(a) {\n return this.expTable[a];\n }\n log(a) {\n if (a === 0) {\n throw new IllegalArgumentException();\n }\n return this.logTable[a];\n }\n inverse(a) {\n if (a === 0) {\n throw new ArithmeticException();\n }\n return this.expTable[this.modulus - this.logTable[a] - 1];\n }\n multiply(a, b) {\n if (a === 0 || b === 0) {\n return 0;\n }\n return this.expTable[(this.logTable[a] + this.logTable[b]) % (this.modulus - 1)];\n }\n getSize() {\n return this.modulus;\n }\n equals(o) {\n return o === this;\n }\n }\n\n /*\n * Copyright 2012 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

A field based on powers of a generator integer, modulo some modulus.

\n *\n * @author Sean Owen\n * @see com.google.zxing.common.reedsolomon.GenericGF\n */\n /*public final*/ class ModulusGF extends ModulusBase {\n // private /*final*/ modulus: /*int*/ number;\n constructor(modulus, generator) {\n super();\n this.modulus = modulus;\n this.expTable = new Int32Array(modulus);\n this.logTable = new Int32Array(modulus);\n let x = /*int*/ 1;\n for (let i /*int*/ = 0; i < modulus; i++) {\n this.expTable[i] = x;\n x = (x * generator) % modulus;\n }\n for (let i /*int*/ = 0; i < modulus - 1; i++) {\n this.logTable[this.expTable[i]] = i;\n }\n // logTable[0] == 0 but this should never be used\n this.zero = new ModulusPoly(this, new Int32Array([0]));\n this.one = new ModulusPoly(this, new Int32Array([1]));\n }\n getZero() {\n return this.zero;\n }\n getOne() {\n return this.one;\n }\n buildMonomial(degree, coefficient) {\n if (degree < 0) {\n throw new IllegalArgumentException();\n }\n if (coefficient === 0) {\n return this.zero;\n }\n let coefficients = new Int32Array(degree + 1);\n coefficients[0] = coefficient;\n return new ModulusPoly(this, coefficients);\n }\n }\n ModulusGF.PDF417_GF = new ModulusGF(PDF417Common.NUMBER_OF_CODEWORDS, 3);\n\n /*\n * Copyright 2012 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

PDF417 error correction implementation.

\n *\n *

This example\n * is quite useful in understanding the algorithm.

\n *\n * @author Sean Owen\n * @see com.google.zxing.common.reedsolomon.ReedSolomonDecoder\n */\n /*public final*/ class ErrorCorrection {\n constructor() {\n this.field = ModulusGF.PDF417_GF;\n }\n /**\n * @param received received codewords\n * @param numECCodewords number of those codewords used for EC\n * @param erasures location of erasures\n * @return number of errors\n * @throws ChecksumException if errors cannot be corrected, maybe because of too many errors\n */\n decode(received, numECCodewords, erasures) {\n let poly = new ModulusPoly(this.field, received);\n let S = new Int32Array(numECCodewords);\n let error = false;\n for (let i /*int*/ = numECCodewords; i > 0; i--) {\n let evaluation = poly.evaluateAt(this.field.exp(i));\n S[numECCodewords - i] = evaluation;\n if (evaluation !== 0) {\n error = true;\n }\n }\n if (!error) {\n return 0;\n }\n let knownErrors = this.field.getOne();\n if (erasures != null) {\n for (const erasure of erasures) {\n let b = this.field.exp(received.length - 1 - erasure);\n // Add (1 - bx) term:\n let term = new ModulusPoly(this.field, new Int32Array([this.field.subtract(0, b), 1]));\n knownErrors = knownErrors.multiply(term);\n }\n }\n let syndrome = new ModulusPoly(this.field, S);\n // syndrome = syndrome.multiply(knownErrors);\n let sigmaOmega = this.runEuclideanAlgorithm(this.field.buildMonomial(numECCodewords, 1), syndrome, numECCodewords);\n let sigma = sigmaOmega[0];\n let omega = sigmaOmega[1];\n // sigma = sigma.multiply(knownErrors);\n let errorLocations = this.findErrorLocations(sigma);\n let errorMagnitudes = this.findErrorMagnitudes(omega, sigma, errorLocations);\n for (let i /*int*/ = 0; i < errorLocations.length; i++) {\n let position = received.length - 1 - this.field.log(errorLocations[i]);\n if (position < 0) {\n throw ChecksumException.getChecksumInstance();\n }\n received[position] = this.field.subtract(received[position], errorMagnitudes[i]);\n }\n return errorLocations.length;\n }\n /**\n *\n * @param ModulusPoly\n * @param a\n * @param ModulusPoly\n * @param b\n * @param int\n * @param R\n * @throws ChecksumException\n */\n runEuclideanAlgorithm(a, b, R) {\n // Assume a's degree is >= b's\n if (a.getDegree() < b.getDegree()) {\n let temp = a;\n a = b;\n b = temp;\n }\n let rLast = a;\n let r = b;\n let tLast = this.field.getZero();\n let t = this.field.getOne();\n // Run Euclidean algorithm until r's degree is less than R/2\n while (r.getDegree() >= Math.round(R / 2)) {\n let rLastLast = rLast;\n let tLastLast = tLast;\n rLast = r;\n tLast = t;\n // Divide rLastLast by rLast, with quotient in q and remainder in r\n if (rLast.isZero()) {\n // Oops, Euclidean algorithm already terminated?\n throw ChecksumException.getChecksumInstance();\n }\n r = rLastLast;\n let q = this.field.getZero();\n let denominatorLeadingTerm = rLast.getCoefficient(rLast.getDegree());\n let dltInverse = this.field.inverse(denominatorLeadingTerm);\n while (r.getDegree() >= rLast.getDegree() && !r.isZero()) {\n let degreeDiff = r.getDegree() - rLast.getDegree();\n let scale = this.field.multiply(r.getCoefficient(r.getDegree()), dltInverse);\n q = q.add(this.field.buildMonomial(degreeDiff, scale));\n r = r.subtract(rLast.multiplyByMonomial(degreeDiff, scale));\n }\n t = q.multiply(tLast).subtract(tLastLast).negative();\n }\n let sigmaTildeAtZero = t.getCoefficient(0);\n if (sigmaTildeAtZero === 0) {\n throw ChecksumException.getChecksumInstance();\n }\n let inverse = this.field.inverse(sigmaTildeAtZero);\n let sigma = t.multiply(inverse);\n let omega = r.multiply(inverse);\n return [sigma, omega];\n }\n /**\n *\n * @param errorLocator\n * @throws ChecksumException\n */\n findErrorLocations(errorLocator) {\n // This is a direct application of Chien's search\n let numErrors = errorLocator.getDegree();\n let result = new Int32Array(numErrors);\n let e = 0;\n for (let i /*int*/ = 1; i < this.field.getSize() && e < numErrors; i++) {\n if (errorLocator.evaluateAt(i) === 0) {\n result[e] = this.field.inverse(i);\n e++;\n }\n }\n if (e !== numErrors) {\n throw ChecksumException.getChecksumInstance();\n }\n return result;\n }\n findErrorMagnitudes(errorEvaluator, errorLocator, errorLocations) {\n let errorLocatorDegree = errorLocator.getDegree();\n let formalDerivativeCoefficients = new Int32Array(errorLocatorDegree);\n for (let i /*int*/ = 1; i <= errorLocatorDegree; i++) {\n formalDerivativeCoefficients[errorLocatorDegree - i] =\n this.field.multiply(i, errorLocator.getCoefficient(i));\n }\n let formalDerivative = new ModulusPoly(this.field, formalDerivativeCoefficients);\n // This is directly applying Forney's Formula\n let s = errorLocations.length;\n let result = new Int32Array(s);\n for (let i /*int*/ = 0; i < s; i++) {\n let xiInverse = this.field.inverse(errorLocations[i]);\n let numerator = this.field.subtract(0, errorEvaluator.evaluateAt(xiInverse));\n let denominator = this.field.inverse(formalDerivative.evaluateAt(xiInverse));\n result[i] = this.field.multiply(numerator, denominator);\n }\n return result;\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author Guenther Grau\n */\n /*final*/ class BoundingBox {\n constructor(image, topLeft, bottomLeft, topRight, bottomRight) {\n if (image instanceof BoundingBox) {\n this.constructor_2(image);\n }\n else {\n this.constructor_1(image, topLeft, bottomLeft, topRight, bottomRight);\n }\n }\n /**\n *\n * @param image\n * @param topLeft\n * @param bottomLeft\n * @param topRight\n * @param bottomRight\n *\n * @throws NotFoundException\n */\n constructor_1(image, topLeft, bottomLeft, topRight, bottomRight) {\n const leftUnspecified = topLeft == null || bottomLeft == null;\n const rightUnspecified = topRight == null || bottomRight == null;\n if (leftUnspecified && rightUnspecified) {\n throw new NotFoundException();\n }\n if (leftUnspecified) {\n topLeft = new ResultPoint(0, topRight.getY());\n bottomLeft = new ResultPoint(0, bottomRight.getY());\n }\n else if (rightUnspecified) {\n topRight = new ResultPoint(image.getWidth() - 1, topLeft.getY());\n bottomRight = new ResultPoint(image.getWidth() - 1, bottomLeft.getY());\n }\n this.image = image;\n this.topLeft = topLeft;\n this.bottomLeft = bottomLeft;\n this.topRight = topRight;\n this.bottomRight = bottomRight;\n this.minX = Math.trunc(Math.min(topLeft.getX(), bottomLeft.getX()));\n this.maxX = Math.trunc(Math.max(topRight.getX(), bottomRight.getX()));\n this.minY = Math.trunc(Math.min(topLeft.getY(), topRight.getY()));\n this.maxY = Math.trunc(Math.max(bottomLeft.getY(), bottomRight.getY()));\n }\n constructor_2(boundingBox) {\n this.image = boundingBox.image;\n this.topLeft = boundingBox.getTopLeft();\n this.bottomLeft = boundingBox.getBottomLeft();\n this.topRight = boundingBox.getTopRight();\n this.bottomRight = boundingBox.getBottomRight();\n this.minX = boundingBox.getMinX();\n this.maxX = boundingBox.getMaxX();\n this.minY = boundingBox.getMinY();\n this.maxY = boundingBox.getMaxY();\n }\n /**\n * @throws NotFoundException\n */\n static merge(leftBox, rightBox) {\n if (leftBox == null) {\n return rightBox;\n }\n if (rightBox == null) {\n return leftBox;\n }\n return new BoundingBox(leftBox.image, leftBox.topLeft, leftBox.bottomLeft, rightBox.topRight, rightBox.bottomRight);\n }\n /**\n * @throws NotFoundException\n */\n addMissingRows(missingStartRows, missingEndRows, isLeft) {\n let newTopLeft = this.topLeft;\n let newBottomLeft = this.bottomLeft;\n let newTopRight = this.topRight;\n let newBottomRight = this.bottomRight;\n if (missingStartRows > 0) {\n let top = isLeft ? this.topLeft : this.topRight;\n let newMinY = Math.trunc(top.getY() - missingStartRows);\n if (newMinY < 0) {\n newMinY = 0;\n }\n let newTop = new ResultPoint(top.getX(), newMinY);\n if (isLeft) {\n newTopLeft = newTop;\n }\n else {\n newTopRight = newTop;\n }\n }\n if (missingEndRows > 0) {\n let bottom = isLeft ? this.bottomLeft : this.bottomRight;\n let newMaxY = Math.trunc(bottom.getY() + missingEndRows);\n if (newMaxY >= this.image.getHeight()) {\n newMaxY = this.image.getHeight() - 1;\n }\n let newBottom = new ResultPoint(bottom.getX(), newMaxY);\n if (isLeft) {\n newBottomLeft = newBottom;\n }\n else {\n newBottomRight = newBottom;\n }\n }\n return new BoundingBox(this.image, newTopLeft, newBottomLeft, newTopRight, newBottomRight);\n }\n getMinX() {\n return this.minX;\n }\n getMaxX() {\n return this.maxX;\n }\n getMinY() {\n return this.minY;\n }\n getMaxY() {\n return this.maxY;\n }\n getTopLeft() {\n return this.topLeft;\n }\n getTopRight() {\n return this.topRight;\n }\n getBottomLeft() {\n return this.bottomLeft;\n }\n getBottomRight() {\n return this.bottomRight;\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // package com.google.zxing.pdf417.decoder;\n /**\n * @author Guenther Grau\n */\n /*final*/ class BarcodeMetadata {\n constructor(columnCount, rowCountUpperPart, rowCountLowerPart, errorCorrectionLevel) {\n this.columnCount = columnCount;\n this.errorCorrectionLevel = errorCorrectionLevel;\n this.rowCountUpperPart = rowCountUpperPart;\n this.rowCountLowerPart = rowCountLowerPart;\n this.rowCount = rowCountUpperPart + rowCountLowerPart;\n }\n getColumnCount() {\n return this.columnCount;\n }\n getErrorCorrectionLevel() {\n return this.errorCorrectionLevel;\n }\n getRowCount() {\n return this.rowCount;\n }\n getRowCountUpperPart() {\n return this.rowCountUpperPart;\n }\n getRowCountLowerPart() {\n return this.rowCountLowerPart;\n }\n }\n\n /**\n * Java Formatter class polyfill that works in the JS way.\n */\n class Formatter {\n constructor() {\n this.buffer = '';\n }\n /**\n *\n * @see https://stackoverflow.com/a/13439711/4367683\n *\n * @param str\n * @param arr\n */\n static form(str, arr) {\n let i = -1;\n function callback(exp, p0, p1, p2, p3, p4) {\n if (exp === '%%')\n return '%';\n if (arr[++i] === undefined)\n return undefined;\n exp = p2 ? parseInt(p2.substr(1)) : undefined;\n let base = p3 ? parseInt(p3.substr(1)) : undefined;\n let val;\n switch (p4) {\n case 's':\n val = arr[i];\n break;\n case 'c':\n val = arr[i][0];\n break;\n case 'f':\n val = parseFloat(arr[i]).toFixed(exp);\n break;\n case 'p':\n val = parseFloat(arr[i]).toPrecision(exp);\n break;\n case 'e':\n val = parseFloat(arr[i]).toExponential(exp);\n break;\n case 'x':\n val = parseInt(arr[i]).toString(base ? base : 16);\n break;\n case 'd':\n val = parseFloat(parseInt(arr[i], base ? base : 10).toPrecision(exp)).toFixed(0);\n break;\n }\n val = typeof val === 'object' ? JSON.stringify(val) : (+val).toString(base);\n let size = parseInt(p1); /* padding size */\n let ch = p1 && (p1[0] + '') === '0' ? '0' : ' '; /* isnull? */\n while (val.length < size)\n val = p0 !== undefined ? val + ch : ch + val; /* isminus? */\n return val;\n }\n let regex = /%(-)?(0?[0-9]+)?([.][0-9]+)?([#][0-9]+)?([scfpexd%])/g;\n return str.replace(regex, callback);\n }\n /**\n *\n * @param append The new string to append.\n * @param args Argumets values to be formated.\n */\n format(append, ...args) {\n this.buffer += Formatter.form(append, args);\n }\n /**\n * Returns the Formatter string value.\n */\n toString() {\n return this.buffer;\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author Guenther Grau\n */\n class DetectionResultColumn {\n constructor(boundingBox) {\n this.boundingBox = new BoundingBox(boundingBox);\n // this.codewords = new Codeword[boundingBox.getMaxY() - boundingBox.getMinY() + 1];\n this.codewords = new Array(boundingBox.getMaxY() - boundingBox.getMinY() + 1);\n }\n /*final*/ getCodewordNearby(imageRow) {\n let codeword = this.getCodeword(imageRow);\n if (codeword != null) {\n return codeword;\n }\n for (let i = 1; i < DetectionResultColumn.MAX_NEARBY_DISTANCE; i++) {\n let nearImageRow = this.imageRowToCodewordIndex(imageRow) - i;\n if (nearImageRow >= 0) {\n codeword = this.codewords[nearImageRow];\n if (codeword != null) {\n return codeword;\n }\n }\n nearImageRow = this.imageRowToCodewordIndex(imageRow) + i;\n if (nearImageRow < this.codewords.length) {\n codeword = this.codewords[nearImageRow];\n if (codeword != null) {\n return codeword;\n }\n }\n }\n return null;\n }\n /*final int*/ imageRowToCodewordIndex(imageRow) {\n return imageRow - this.boundingBox.getMinY();\n }\n /*final void*/ setCodeword(imageRow, codeword) {\n this.codewords[this.imageRowToCodewordIndex(imageRow)] = codeword;\n }\n /*final*/ getCodeword(imageRow) {\n return this.codewords[this.imageRowToCodewordIndex(imageRow)];\n }\n /*final*/ getBoundingBox() {\n return this.boundingBox;\n }\n /*final*/ getCodewords() {\n return this.codewords;\n }\n // @Override\n toString() {\n const formatter = new Formatter();\n let row = 0;\n for (const codeword of this.codewords) {\n if (codeword == null) {\n formatter.format('%3d: | %n', row++);\n continue;\n }\n formatter.format('%3d: %3d|%3d%n', row++, codeword.getRowNumber(), codeword.getValue());\n }\n return formatter.toString();\n }\n }\n DetectionResultColumn.MAX_NEARBY_DISTANCE = 5;\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // import java.util.ArrayList;\n // import java.util.Collection;\n // import java.util.HashMap;\n // import java.util.Map;\n // import java.util.Map.Entry;\n /**\n * @author Guenther Grau\n */\n /*final*/ class BarcodeValue {\n constructor() {\n this.values = new Map();\n }\n /**\n * Add an occurrence of a value\n */\n setValue(value) {\n value = Math.trunc(value);\n let confidence = this.values.get(value);\n if (confidence == null) {\n confidence = 0;\n }\n confidence++;\n this.values.set(value, confidence);\n }\n /**\n * Determines the maximum occurrence of a set value and returns all values which were set with this occurrence.\n * @return an array of int, containing the values with the highest occurrence, or null, if no value was set\n */\n getValue() {\n let maxConfidence = -1;\n let result = new Array();\n for (const [key, value] of this.values.entries()) {\n const entry = {\n getKey: () => key,\n getValue: () => value,\n };\n if (entry.getValue() > maxConfidence) {\n maxConfidence = entry.getValue();\n result = [];\n result.push(entry.getKey());\n }\n else if (entry.getValue() === maxConfidence) {\n result.push(entry.getKey());\n }\n }\n return PDF417Common.toIntArray(result);\n }\n getConfidence(value) {\n return this.values.get(value);\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author Guenther Grau\n */\n /*final*/ class DetectionResultRowIndicatorColumn extends DetectionResultColumn {\n constructor(boundingBox, isLeft) {\n super(boundingBox);\n this._isLeft = isLeft;\n }\n setRowNumbers() {\n for (let codeword /*Codeword*/ of this.getCodewords()) {\n if (codeword != null) {\n codeword.setRowNumberAsRowIndicatorColumn();\n }\n }\n }\n // TODO implement properly\n // TODO maybe we should add missing codewords to store the correct row number to make\n // finding row numbers for other columns easier\n // use row height count to make detection of invalid row numbers more reliable\n adjustCompleteIndicatorColumnRowNumbers(barcodeMetadata) {\n let codewords = this.getCodewords();\n this.setRowNumbers();\n this.removeIncorrectCodewords(codewords, barcodeMetadata);\n let boundingBox = this.getBoundingBox();\n let top = this._isLeft ? boundingBox.getTopLeft() : boundingBox.getTopRight();\n let bottom = this._isLeft ? boundingBox.getBottomLeft() : boundingBox.getBottomRight();\n let firstRow = this.imageRowToCodewordIndex(Math.trunc(top.getY()));\n let lastRow = this.imageRowToCodewordIndex(Math.trunc(bottom.getY()));\n // We need to be careful using the average row height. Barcode could be skewed so that we have smaller and\n // taller rows\n // float averageRowHeight = (lastRow - firstRow) / /*(float)*/ barcodeMetadata.getRowCount();\n let barcodeRow = -1;\n let maxRowHeight = 1;\n let currentRowHeight = 0;\n for (let codewordsRow /*int*/ = firstRow; codewordsRow < lastRow; codewordsRow++) {\n if (codewords[codewordsRow] == null) {\n continue;\n }\n let codeword = codewords[codewordsRow];\n // float expectedRowNumber = (codewordsRow - firstRow) / averageRowHeight;\n // if (Math.abs(codeword.getRowNumber() - expectedRowNumber) > 2) {\n // SimpleLog.log(LEVEL.WARNING,\n // \"Removing codeword, rowNumberSkew too high, codeword[\" + codewordsRow + \"]: Expected Row: \" +\n // expectedRowNumber + \", RealRow: \" + codeword.getRowNumber() + \", value: \" + codeword.getValue());\n // codewords[codewordsRow] = null;\n // }\n let rowDifference = codeword.getRowNumber() - barcodeRow;\n // TODO improve handling with case where first row indicator doesn't start with 0\n if (rowDifference === 0) {\n currentRowHeight++;\n }\n else if (rowDifference === 1) {\n maxRowHeight = Math.max(maxRowHeight, currentRowHeight);\n currentRowHeight = 1;\n barcodeRow = codeword.getRowNumber();\n }\n else if (rowDifference < 0 ||\n codeword.getRowNumber() >= barcodeMetadata.getRowCount() ||\n rowDifference > codewordsRow) {\n codewords[codewordsRow] = null;\n }\n else {\n let checkedRows;\n if (maxRowHeight > 2) {\n checkedRows = (maxRowHeight - 2) * rowDifference;\n }\n else {\n checkedRows = rowDifference;\n }\n let closePreviousCodewordFound = checkedRows >= codewordsRow;\n for (let i /*int*/ = 1; i <= checkedRows && !closePreviousCodewordFound; i++) {\n // there must be (height * rowDifference) number of codewords missing. For now we assume height = 1.\n // This should hopefully get rid of most problems already.\n closePreviousCodewordFound = codewords[codewordsRow - i] != null;\n }\n if (closePreviousCodewordFound) {\n codewords[codewordsRow] = null;\n }\n else {\n barcodeRow = codeword.getRowNumber();\n currentRowHeight = 1;\n }\n }\n }\n // return (int) (averageRowHeight + 0.5);\n }\n getRowHeights() {\n let barcodeMetadata = this.getBarcodeMetadata();\n if (barcodeMetadata == null) {\n return null;\n }\n this.adjustIncompleteIndicatorColumnRowNumbers(barcodeMetadata);\n let result = new Int32Array(barcodeMetadata.getRowCount());\n for (let codeword /*Codeword*/ of this.getCodewords()) {\n if (codeword != null) {\n let rowNumber = codeword.getRowNumber();\n if (rowNumber >= result.length) {\n // We have more rows than the barcode metadata allows for, ignore them.\n continue;\n }\n result[rowNumber]++;\n } // else throw exception?\n }\n return result;\n }\n // TODO maybe we should add missing codewords to store the correct row number to make\n // finding row numbers for other columns easier\n // use row height count to make detection of invalid row numbers more reliable\n adjustIncompleteIndicatorColumnRowNumbers(barcodeMetadata) {\n let boundingBox = this.getBoundingBox();\n let top = this._isLeft ? boundingBox.getTopLeft() : boundingBox.getTopRight();\n let bottom = this._isLeft ? boundingBox.getBottomLeft() : boundingBox.getBottomRight();\n let firstRow = this.imageRowToCodewordIndex(Math.trunc(top.getY()));\n let lastRow = this.imageRowToCodewordIndex(Math.trunc(bottom.getY()));\n // float averageRowHeight = (lastRow - firstRow) / /*(float)*/ barcodeMetadata.getRowCount();\n let codewords = this.getCodewords();\n let barcodeRow = -1;\n for (let codewordsRow /*int*/ = firstRow; codewordsRow < lastRow; codewordsRow++) {\n if (codewords[codewordsRow] == null) {\n continue;\n }\n let codeword = codewords[codewordsRow];\n codeword.setRowNumberAsRowIndicatorColumn();\n let rowDifference = codeword.getRowNumber() - barcodeRow;\n // TODO improve handling with case where first row indicator doesn't start with 0\n if (rowDifference === 0) ;\n else if (rowDifference === 1) {\n barcodeRow = codeword.getRowNumber();\n }\n else if (codeword.getRowNumber() >= barcodeMetadata.getRowCount()) {\n codewords[codewordsRow] = null;\n }\n else {\n barcodeRow = codeword.getRowNumber();\n }\n }\n // return (int) (averageRowHeight + 0.5);\n }\n getBarcodeMetadata() {\n let codewords = this.getCodewords();\n let barcodeColumnCount = new BarcodeValue();\n let barcodeRowCountUpperPart = new BarcodeValue();\n let barcodeRowCountLowerPart = new BarcodeValue();\n let barcodeECLevel = new BarcodeValue();\n for (let codeword /*Codeword*/ of codewords) {\n if (codeword == null) {\n continue;\n }\n codeword.setRowNumberAsRowIndicatorColumn();\n let rowIndicatorValue = codeword.getValue() % 30;\n let codewordRowNumber = codeword.getRowNumber();\n if (!this._isLeft) {\n codewordRowNumber += 2;\n }\n switch (codewordRowNumber % 3) {\n case 0:\n barcodeRowCountUpperPart.setValue(rowIndicatorValue * 3 + 1);\n break;\n case 1:\n barcodeECLevel.setValue(rowIndicatorValue / 3);\n barcodeRowCountLowerPart.setValue(rowIndicatorValue % 3);\n break;\n case 2:\n barcodeColumnCount.setValue(rowIndicatorValue + 1);\n break;\n }\n }\n // Maybe we should check if we have ambiguous values?\n if ((barcodeColumnCount.getValue().length === 0) ||\n (barcodeRowCountUpperPart.getValue().length === 0) ||\n (barcodeRowCountLowerPart.getValue().length === 0) ||\n (barcodeECLevel.getValue().length === 0) ||\n barcodeColumnCount.getValue()[0] < 1 ||\n barcodeRowCountUpperPart.getValue()[0] + barcodeRowCountLowerPart.getValue()[0] < PDF417Common.MIN_ROWS_IN_BARCODE ||\n barcodeRowCountUpperPart.getValue()[0] + barcodeRowCountLowerPart.getValue()[0] > PDF417Common.MAX_ROWS_IN_BARCODE) {\n return null;\n }\n let barcodeMetadata = new BarcodeMetadata(barcodeColumnCount.getValue()[0], barcodeRowCountUpperPart.getValue()[0], barcodeRowCountLowerPart.getValue()[0], barcodeECLevel.getValue()[0]);\n this.removeIncorrectCodewords(codewords, barcodeMetadata);\n return barcodeMetadata;\n }\n removeIncorrectCodewords(codewords, barcodeMetadata) {\n // Remove codewords which do not match the metadata\n // TODO Maybe we should keep the incorrect codewords for the start and end positions?\n for (let codewordRow /*int*/ = 0; codewordRow < codewords.length; codewordRow++) {\n let codeword = codewords[codewordRow];\n if (codewords[codewordRow] == null) {\n continue;\n }\n let rowIndicatorValue = codeword.getValue() % 30;\n let codewordRowNumber = codeword.getRowNumber();\n if (codewordRowNumber > barcodeMetadata.getRowCount()) {\n codewords[codewordRow] = null;\n continue;\n }\n if (!this._isLeft) {\n codewordRowNumber += 2;\n }\n switch (codewordRowNumber % 3) {\n case 0:\n if (rowIndicatorValue * 3 + 1 !== barcodeMetadata.getRowCountUpperPart()) {\n codewords[codewordRow] = null;\n }\n break;\n case 1:\n if (Math.trunc(rowIndicatorValue / 3) !== barcodeMetadata.getErrorCorrectionLevel() ||\n rowIndicatorValue % 3 !== barcodeMetadata.getRowCountLowerPart()) {\n codewords[codewordRow] = null;\n }\n break;\n case 2:\n if (rowIndicatorValue + 1 !== barcodeMetadata.getColumnCount()) {\n codewords[codewordRow] = null;\n }\n break;\n }\n }\n }\n isLeft() {\n return this._isLeft;\n }\n // @Override\n toString() {\n return 'IsLeft: ' + this._isLeft + '\\n' + super.toString();\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author Guenther Grau\n */\n /*final*/ class DetectionResult {\n constructor(barcodeMetadata, boundingBox) {\n /*final*/ this.ADJUST_ROW_NUMBER_SKIP = 2;\n this.barcodeMetadata = barcodeMetadata;\n this.barcodeColumnCount = barcodeMetadata.getColumnCount();\n this.boundingBox = boundingBox;\n // this.detectionResultColumns = new DetectionResultColumn[this.barcodeColumnCount + 2];\n this.detectionResultColumns = new Array(this.barcodeColumnCount + 2);\n }\n getDetectionResultColumns() {\n this.adjustIndicatorColumnRowNumbers(this.detectionResultColumns[0]);\n this.adjustIndicatorColumnRowNumbers(this.detectionResultColumns[this.barcodeColumnCount + 1]);\n let unadjustedCodewordCount = PDF417Common.MAX_CODEWORDS_IN_BARCODE;\n let previousUnadjustedCount;\n do {\n previousUnadjustedCount = unadjustedCodewordCount;\n unadjustedCodewordCount = this.adjustRowNumbersAndGetCount();\n } while (unadjustedCodewordCount > 0 && unadjustedCodewordCount < previousUnadjustedCount);\n return this.detectionResultColumns;\n }\n adjustIndicatorColumnRowNumbers(detectionResultColumn) {\n if (detectionResultColumn != null) {\n detectionResultColumn\n .adjustCompleteIndicatorColumnRowNumbers(this.barcodeMetadata);\n }\n }\n // TODO ensure that no detected codewords with unknown row number are left\n // we should be able to estimate the row height and use it as a hint for the row number\n // we should also fill the rows top to bottom and bottom to top\n /**\n * @return number of codewords which don't have a valid row number. Note that the count is not accurate as codewords\n * will be counted several times. It just serves as an indicator to see when we can stop adjusting row numbers\n */\n adjustRowNumbersAndGetCount() {\n let unadjustedCount = this.adjustRowNumbersByRow();\n if (unadjustedCount === 0) {\n return 0;\n }\n for (let barcodeColumn /*int*/ = 1; barcodeColumn < this.barcodeColumnCount + 1; barcodeColumn++) {\n let codewords = this.detectionResultColumns[barcodeColumn].getCodewords();\n for (let codewordsRow /*int*/ = 0; codewordsRow < codewords.length; codewordsRow++) {\n if (codewords[codewordsRow] == null) {\n continue;\n }\n if (!codewords[codewordsRow].hasValidRowNumber()) {\n this.adjustRowNumbers(barcodeColumn, codewordsRow, codewords);\n }\n }\n }\n return unadjustedCount;\n }\n adjustRowNumbersByRow() {\n this.adjustRowNumbersFromBothRI();\n // TODO we should only do full row adjustments if row numbers of left and right row indicator column match.\n // Maybe it's even better to calculated the height (rows: d) and divide it by the number of barcode\n // rows. This, together with the LRI and RRI row numbers should allow us to get a good estimate where a row\n // number starts and ends.\n let unadjustedCount = this.adjustRowNumbersFromLRI();\n return unadjustedCount + this.adjustRowNumbersFromRRI();\n }\n adjustRowNumbersFromBothRI() {\n if (this.detectionResultColumns[0] == null || this.detectionResultColumns[this.barcodeColumnCount + 1] == null) {\n return;\n }\n let LRIcodewords = this.detectionResultColumns[0].getCodewords();\n let RRIcodewords = this.detectionResultColumns[this.barcodeColumnCount + 1].getCodewords();\n for (let codewordsRow /*int*/ = 0; codewordsRow < LRIcodewords.length; codewordsRow++) {\n if (LRIcodewords[codewordsRow] != null &&\n RRIcodewords[codewordsRow] != null &&\n LRIcodewords[codewordsRow].getRowNumber() === RRIcodewords[codewordsRow].getRowNumber()) {\n for (let barcodeColumn /*int*/ = 1; barcodeColumn <= this.barcodeColumnCount; barcodeColumn++) {\n let codeword = this.detectionResultColumns[barcodeColumn].getCodewords()[codewordsRow];\n if (codeword == null) {\n continue;\n }\n codeword.setRowNumber(LRIcodewords[codewordsRow].getRowNumber());\n if (!codeword.hasValidRowNumber()) {\n this.detectionResultColumns[barcodeColumn].getCodewords()[codewordsRow] = null;\n }\n }\n }\n }\n }\n adjustRowNumbersFromRRI() {\n if (this.detectionResultColumns[this.barcodeColumnCount + 1] == null) {\n return 0;\n }\n let unadjustedCount = 0;\n let codewords = this.detectionResultColumns[this.barcodeColumnCount + 1].getCodewords();\n for (let codewordsRow /*int*/ = 0; codewordsRow < codewords.length; codewordsRow++) {\n if (codewords[codewordsRow] == null) {\n continue;\n }\n let rowIndicatorRowNumber = codewords[codewordsRow].getRowNumber();\n let invalidRowCounts = 0;\n for (let barcodeColumn /*int*/ = this.barcodeColumnCount + 1; barcodeColumn > 0 && invalidRowCounts < this.ADJUST_ROW_NUMBER_SKIP; barcodeColumn--) {\n let codeword = this.detectionResultColumns[barcodeColumn].getCodewords()[codewordsRow];\n if (codeword != null) {\n invalidRowCounts = DetectionResult.adjustRowNumberIfValid(rowIndicatorRowNumber, invalidRowCounts, codeword);\n if (!codeword.hasValidRowNumber()) {\n unadjustedCount++;\n }\n }\n }\n }\n return unadjustedCount;\n }\n adjustRowNumbersFromLRI() {\n if (this.detectionResultColumns[0] == null) {\n return 0;\n }\n let unadjustedCount = 0;\n let codewords = this.detectionResultColumns[0].getCodewords();\n for (let codewordsRow /*int*/ = 0; codewordsRow < codewords.length; codewordsRow++) {\n if (codewords[codewordsRow] == null) {\n continue;\n }\n let rowIndicatorRowNumber = codewords[codewordsRow].getRowNumber();\n let invalidRowCounts = 0;\n for (let barcodeColumn /*int*/ = 1; barcodeColumn < this.barcodeColumnCount + 1 && invalidRowCounts < this.ADJUST_ROW_NUMBER_SKIP; barcodeColumn++) {\n let codeword = this.detectionResultColumns[barcodeColumn].getCodewords()[codewordsRow];\n if (codeword != null) {\n invalidRowCounts = DetectionResult.adjustRowNumberIfValid(rowIndicatorRowNumber, invalidRowCounts, codeword);\n if (!codeword.hasValidRowNumber()) {\n unadjustedCount++;\n }\n }\n }\n }\n return unadjustedCount;\n }\n static adjustRowNumberIfValid(rowIndicatorRowNumber, invalidRowCounts, codeword) {\n if (codeword == null) {\n return invalidRowCounts;\n }\n if (!codeword.hasValidRowNumber()) {\n if (codeword.isValidRowNumber(rowIndicatorRowNumber)) {\n codeword.setRowNumber(rowIndicatorRowNumber);\n invalidRowCounts = 0;\n }\n else {\n ++invalidRowCounts;\n }\n }\n return invalidRowCounts;\n }\n adjustRowNumbers(barcodeColumn, codewordsRow, codewords) {\n let codeword = codewords[codewordsRow];\n let previousColumnCodewords = this.detectionResultColumns[barcodeColumn - 1].getCodewords();\n let nextColumnCodewords = previousColumnCodewords;\n if (this.detectionResultColumns[barcodeColumn + 1] != null) {\n nextColumnCodewords = this.detectionResultColumns[barcodeColumn + 1].getCodewords();\n }\n // let otherCodewords: Codeword[] = new Codeword[14];\n let otherCodewords = new Array(14);\n otherCodewords[2] = previousColumnCodewords[codewordsRow];\n otherCodewords[3] = nextColumnCodewords[codewordsRow];\n if (codewordsRow > 0) {\n otherCodewords[0] = codewords[codewordsRow - 1];\n otherCodewords[4] = previousColumnCodewords[codewordsRow - 1];\n otherCodewords[5] = nextColumnCodewords[codewordsRow - 1];\n }\n if (codewordsRow > 1) {\n otherCodewords[8] = codewords[codewordsRow - 2];\n otherCodewords[10] = previousColumnCodewords[codewordsRow - 2];\n otherCodewords[11] = nextColumnCodewords[codewordsRow - 2];\n }\n if (codewordsRow < codewords.length - 1) {\n otherCodewords[1] = codewords[codewordsRow + 1];\n otherCodewords[6] = previousColumnCodewords[codewordsRow + 1];\n otherCodewords[7] = nextColumnCodewords[codewordsRow + 1];\n }\n if (codewordsRow < codewords.length - 2) {\n otherCodewords[9] = codewords[codewordsRow + 2];\n otherCodewords[12] = previousColumnCodewords[codewordsRow + 2];\n otherCodewords[13] = nextColumnCodewords[codewordsRow + 2];\n }\n for (let otherCodeword of otherCodewords) {\n if (DetectionResult.adjustRowNumber(codeword, otherCodeword)) {\n return;\n }\n }\n }\n /**\n * @return true, if row number was adjusted, false otherwise\n */\n static adjustRowNumber(codeword, otherCodeword) {\n if (otherCodeword == null) {\n return false;\n }\n if (otherCodeword.hasValidRowNumber() && otherCodeword.getBucket() === codeword.getBucket()) {\n codeword.setRowNumber(otherCodeword.getRowNumber());\n return true;\n }\n return false;\n }\n getBarcodeColumnCount() {\n return this.barcodeColumnCount;\n }\n getBarcodeRowCount() {\n return this.barcodeMetadata.getRowCount();\n }\n getBarcodeECLevel() {\n return this.barcodeMetadata.getErrorCorrectionLevel();\n }\n setBoundingBox(boundingBox) {\n this.boundingBox = boundingBox;\n }\n getBoundingBox() {\n return this.boundingBox;\n }\n setDetectionResultColumn(barcodeColumn, detectionResultColumn) {\n this.detectionResultColumns[barcodeColumn] = detectionResultColumn;\n }\n getDetectionResultColumn(barcodeColumn) {\n return this.detectionResultColumns[barcodeColumn];\n }\n // @Override\n toString() {\n let rowIndicatorColumn = this.detectionResultColumns[0];\n if (rowIndicatorColumn == null) {\n rowIndicatorColumn = this.detectionResultColumns[this.barcodeColumnCount + 1];\n }\n // try (\n let formatter = new Formatter();\n // ) {\n for (let codewordsRow /*int*/ = 0; codewordsRow < rowIndicatorColumn.getCodewords().length; codewordsRow++) {\n formatter.format('CW %3d:', codewordsRow);\n for (let barcodeColumn /*int*/ = 0; barcodeColumn < this.barcodeColumnCount + 2; barcodeColumn++) {\n if (this.detectionResultColumns[barcodeColumn] == null) {\n formatter.format(' | ');\n continue;\n }\n let codeword = this.detectionResultColumns[barcodeColumn].getCodewords()[codewordsRow];\n if (codeword == null) {\n formatter.format(' | ');\n continue;\n }\n formatter.format(' %3d|%3d', codeword.getRowNumber(), codeword.getValue());\n }\n formatter.format('%n');\n }\n return formatter.toString();\n // }\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // package com.google.zxing.pdf417.decoder;\n /**\n * @author Guenther Grau\n */\n /*final*/ class Codeword {\n constructor(startX, endX, bucket, value) {\n this.rowNumber = Codeword.BARCODE_ROW_UNKNOWN;\n this.startX = Math.trunc(startX);\n this.endX = Math.trunc(endX);\n this.bucket = Math.trunc(bucket);\n this.value = Math.trunc(value);\n }\n hasValidRowNumber() {\n return this.isValidRowNumber(this.rowNumber);\n }\n isValidRowNumber(rowNumber) {\n return rowNumber !== Codeword.BARCODE_ROW_UNKNOWN && this.bucket === (rowNumber % 3) * 3;\n }\n setRowNumberAsRowIndicatorColumn() {\n this.rowNumber = Math.trunc((Math.trunc(this.value / 30)) * 3 + Math.trunc(this.bucket / 3));\n }\n getWidth() {\n return this.endX - this.startX;\n }\n getStartX() {\n return this.startX;\n }\n getEndX() {\n return this.endX;\n }\n getBucket() {\n return this.bucket;\n }\n getValue() {\n return this.value;\n }\n getRowNumber() {\n return this.rowNumber;\n }\n setRowNumber(rowNumber) {\n this.rowNumber = rowNumber;\n }\n // @Override\n toString() {\n return this.rowNumber + '|' + this.value;\n }\n }\n Codeword.BARCODE_ROW_UNKNOWN = -1;\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author Guenther Grau\n * @author creatale GmbH (christoph.schulz@creatale.de)\n */\n /*final*/ class PDF417CodewordDecoder {\n /* @note\n * this action have to be performed before first use of class\n * - static constructor\n * working with 32bit float (based from Java logic)\n */\n static initialize() {\n // Pre-computes the symbol ratio table.\n for ( /*int*/let i = 0; i < PDF417Common.SYMBOL_TABLE.length; i++) {\n let currentSymbol = PDF417Common.SYMBOL_TABLE[i];\n let currentBit = currentSymbol & 0x1;\n for ( /*int*/let j = 0; j < PDF417Common.BARS_IN_MODULE; j++) {\n let size = 0.0;\n while ((currentSymbol & 0x1) === currentBit) {\n size += 1.0;\n currentSymbol >>= 1;\n }\n currentBit = currentSymbol & 0x1;\n if (!PDF417CodewordDecoder.RATIOS_TABLE[i]) {\n PDF417CodewordDecoder.RATIOS_TABLE[i] = new Array(PDF417Common.BARS_IN_MODULE);\n }\n PDF417CodewordDecoder.RATIOS_TABLE[i][PDF417Common.BARS_IN_MODULE - j - 1] = Math.fround(size / PDF417Common.MODULES_IN_CODEWORD);\n }\n }\n this.bSymbolTableReady = true;\n }\n static getDecodedValue(moduleBitCount) {\n let decodedValue = PDF417CodewordDecoder.getDecodedCodewordValue(PDF417CodewordDecoder.sampleBitCounts(moduleBitCount));\n if (decodedValue !== -1) {\n return decodedValue;\n }\n return PDF417CodewordDecoder.getClosestDecodedValue(moduleBitCount);\n }\n static sampleBitCounts(moduleBitCount) {\n let bitCountSum = MathUtils.sum(moduleBitCount);\n let result = new Int32Array(PDF417Common.BARS_IN_MODULE);\n let bitCountIndex = 0;\n let sumPreviousBits = 0;\n for ( /*int*/let i = 0; i < PDF417Common.MODULES_IN_CODEWORD; i++) {\n let sampleIndex = bitCountSum / (2 * PDF417Common.MODULES_IN_CODEWORD) +\n (i * bitCountSum) / PDF417Common.MODULES_IN_CODEWORD;\n if (sumPreviousBits + moduleBitCount[bitCountIndex] <= sampleIndex) {\n sumPreviousBits += moduleBitCount[bitCountIndex];\n bitCountIndex++;\n }\n result[bitCountIndex]++;\n }\n return result;\n }\n static getDecodedCodewordValue(moduleBitCount) {\n let decodedValue = PDF417CodewordDecoder.getBitValue(moduleBitCount);\n return PDF417Common.getCodeword(decodedValue) === -1 ? -1 : decodedValue;\n }\n static getBitValue(moduleBitCount) {\n let result = /*long*/ 0;\n for (let /*int*/ i = 0; i < moduleBitCount.length; i++) {\n for ( /*int*/let bit = 0; bit < moduleBitCount[i]; bit++) {\n result = (result << 1) | (i % 2 === 0 ? 1 : 0);\n }\n }\n return Math.trunc(result);\n }\n // working with 32bit float (as in Java)\n static getClosestDecodedValue(moduleBitCount) {\n let bitCountSum = MathUtils.sum(moduleBitCount);\n let bitCountRatios = new Array(PDF417Common.BARS_IN_MODULE);\n if (bitCountSum > 1) {\n for (let /*int*/ i = 0; i < bitCountRatios.length; i++) {\n bitCountRatios[i] = Math.fround(moduleBitCount[i] / bitCountSum);\n }\n }\n let bestMatchError = Float.MAX_VALUE;\n let bestMatch = -1;\n if (!this.bSymbolTableReady) {\n PDF417CodewordDecoder.initialize();\n }\n for ( /*int*/let j = 0; j < PDF417CodewordDecoder.RATIOS_TABLE.length; j++) {\n let error = 0.0;\n let ratioTableRow = PDF417CodewordDecoder.RATIOS_TABLE[j];\n for ( /*int*/let k = 0; k < PDF417Common.BARS_IN_MODULE; k++) {\n let diff = Math.fround(ratioTableRow[k] - bitCountRatios[k]);\n error += Math.fround(diff * diff);\n if (error >= bestMatchError) {\n break;\n }\n }\n if (error < bestMatchError) {\n bestMatchError = error;\n bestMatch = PDF417Common.SYMBOL_TABLE[j];\n }\n }\n return bestMatch;\n }\n }\n // flag that the table is ready for use\n PDF417CodewordDecoder.bSymbolTableReady = false;\n PDF417CodewordDecoder.RATIOS_TABLE = new Array(PDF417Common.SYMBOL_TABLE.length).map(x => x = new Array(PDF417Common.BARS_IN_MODULE));\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // package com.google.zxing.pdf417;\n /**\n * @author Guenther Grau\n */\n /*public final*/ class PDF417ResultMetadata {\n constructor() {\n this.segmentCount = -1;\n this.fileSize = -1;\n this.timestamp = -1;\n this.checksum = -1;\n }\n /**\n * The Segment ID represents the segment of the whole file distributed over different symbols.\n *\n * @return File segment index\n */\n getSegmentIndex() {\n return this.segmentIndex;\n }\n setSegmentIndex(segmentIndex) {\n this.segmentIndex = segmentIndex;\n }\n /**\n * Is the same for each related PDF417 symbol\n *\n * @return File ID\n */\n getFileId() {\n return this.fileId;\n }\n setFileId(fileId) {\n this.fileId = fileId;\n }\n /**\n * @return always null\n * @deprecated use dedicated already parsed fields\n */\n // @Deprecated\n getOptionalData() {\n return this.optionalData;\n }\n /**\n * @param optionalData old optional data format as int array\n * @deprecated parse and use new fields\n */\n // @Deprecated\n setOptionalData(optionalData) {\n this.optionalData = optionalData;\n }\n /**\n * @return true if it is the last segment\n */\n isLastSegment() {\n return this.lastSegment;\n }\n setLastSegment(lastSegment) {\n this.lastSegment = lastSegment;\n }\n /**\n * @return count of segments, -1 if not set\n */\n getSegmentCount() {\n return this.segmentCount;\n }\n setSegmentCount(segmentCount /*int*/) {\n this.segmentCount = segmentCount;\n }\n getSender() {\n return this.sender || null;\n }\n setSender(sender) {\n this.sender = sender;\n }\n getAddressee() {\n return this.addressee || null;\n }\n setAddressee(addressee) {\n this.addressee = addressee;\n }\n /**\n * Filename of the encoded file\n *\n * @return filename\n */\n getFileName() {\n return this.fileName;\n }\n setFileName(fileName) {\n this.fileName = fileName;\n }\n /**\n * filesize in bytes of the encoded file\n *\n * @return filesize in bytes, -1 if not set\n */\n getFileSize() {\n return this.fileSize;\n }\n setFileSize(fileSize /*long*/) {\n this.fileSize = fileSize;\n }\n /**\n * 16-bit CRC checksum using CCITT-16\n *\n * @return crc checksum, -1 if not set\n */\n getChecksum() {\n return this.checksum;\n }\n setChecksum(checksum /*int*/) {\n this.checksum = checksum;\n }\n /**\n * unix epock timestamp, elapsed seconds since 1970-01-01\n *\n * @return elapsed seconds, -1 if not set\n */\n getTimestamp() {\n return this.timestamp;\n }\n setTimestamp(timestamp /*long*/) {\n this.timestamp = timestamp;\n }\n }\n\n /**\n * Ponyfill for Java's Long class.\n */\n class Long {\n /**\n * Parses a string to a number, since JS has no really Int64.\n *\n * @param num Numeric string.\n * @param radix Destination radix.\n */\n static parseLong(num, radix = undefined) {\n return parseInt(num, radix);\n }\n }\n\n /**\n * Custom Error class of type Exception.\n */\n class NullPointerException extends Exception {\n }\n NullPointerException.kind = 'NullPointerException';\n\n /*\n * Copyright (c) 1994, 2004, Oracle and/or its affiliates. All rights reserved.\n * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.\n *\n * This code is free software; you can redistribute it and/or modify it\n * under the terms of the GNU General Public License version 2 only, as\n * published by the Free Software Foundation. Oracle designates this\n * particular file as subject to the \"Classpath\" exception as provided\n * by Oracle in the LICENSE file that accompanied this code.\n *\n * This code is distributed in the hope that it will be useful, but WITHOUT\n * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or\n * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License\n * version 2 for more details (a copy is included in the LICENSE file that\n * accompanied this code).\n *\n * You should have received a copy of the GNU General Public License version\n * 2 along with this work; if not, write to the Free Software Foundation,\n * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.\n *\n * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA\n * or visit www.oracle.com if you need additional information or have any\n * questions.\n */\n // package java.io;\n /**\n * This abstract class is the superclass of all classes representing\n * an output stream of bytes. An output stream accepts output bytes\n * and sends them to some sink.\n *

\n * Applications that need to define a subclass of\n * OutputStream must always provide at least a method\n * that writes one byte of output.\n *\n * @author Arthur van Hoff\n * @see java.io.BufferedOutputStream\n * @see java.io.ByteArrayOutputStream\n * @see java.io.DataOutputStream\n * @see java.io.FilterOutputStream\n * @see java.io.InputStream\n * @see java.io.OutputStream#write(int)\n * @since JDK1.0\n */\n /*public*/ class OutputStream /*implements Closeable, Flushable*/ {\n /**\n * Writes b.length bytes from the specified byte array\n * to this output stream. The general contract for write(b)\n * is that it should have exactly the same effect as the call\n * write(b, 0, b.length).\n *\n * @param b the data.\n * @exception IOException if an I/O error occurs.\n * @see java.io.OutputStream#write(byte[], int, int)\n */\n writeBytes(b) {\n this.writeBytesOffset(b, 0, b.length);\n }\n /**\n * Writes len bytes from the specified byte array\n * starting at offset off to this output stream.\n * The general contract for write(b, off, len) is that\n * some of the bytes in the array b are written to the\n * output stream in order; element b[off] is the first\n * byte written and b[off+len-1] is the last byte written\n * by this operation.\n *

\n * The write method of OutputStream calls\n * the write method of one argument on each of the bytes to be\n * written out. Subclasses are encouraged to override this method and\n * provide a more efficient implementation.\n *

\n * If b is null, a\n * NullPointerException is thrown.\n *

\n * If off is negative, or len is negative, or\n * off+len is greater than the length of the array\n * b, then an IndexOutOfBoundsException is thrown.\n *\n * @param b the data.\n * @param off the start offset in the data.\n * @param len the number of bytes to write.\n * @exception IOException if an I/O error occurs. In particular,\n * an IOException is thrown if the output\n * stream is closed.\n */\n writeBytesOffset(b, off, len) {\n if (b == null) {\n throw new NullPointerException();\n }\n else if ((off < 0) || (off > b.length) || (len < 0) ||\n ((off + len) > b.length) || ((off + len) < 0)) {\n throw new IndexOutOfBoundsException();\n }\n else if (len === 0) {\n return;\n }\n for (let i = 0; i < len; i++) {\n this.write(b[off + i]);\n }\n }\n /**\n * Flushes this output stream and forces any buffered output bytes\n * to be written out. The general contract of flush is\n * that calling it is an indication that, if any bytes previously\n * written have been buffered by the implementation of the output\n * stream, such bytes should immediately be written to their\n * intended destination.\n *

\n * If the intended destination of this stream is an abstraction provided by\n * the underlying operating system, for example a file, then flushing the\n * stream guarantees only that bytes previously written to the stream are\n * passed to the operating system for writing; it does not guarantee that\n * they are actually written to a physical device such as a disk drive.\n *

\n * The flush method of OutputStream does nothing.\n *\n * @exception IOException if an I/O error occurs.\n */\n flush() {\n }\n /**\n * Closes this output stream and releases any system resources\n * associated with this stream. The general contract of close\n * is that it closes the output stream. A closed stream cannot perform\n * output operations and cannot be reopened.\n *

\n * The close method of OutputStream does nothing.\n *\n * @exception IOException if an I/O error occurs.\n */\n close() {\n }\n }\n\n /**\n * Custom Error class of type Exception.\n */\n class OutOfMemoryError extends Exception {\n }\n\n /*\n * Copyright (c) 1994, 2010, Oracle and/or its affiliates. All rights reserved.\n * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.\n *\n * This code is free software; you can redistribute it and/or modify it\n * under the terms of the GNU General Public License version 2 only, as\n * published by the Free Software Foundation. Oracle designates this\n * particular file as subject to the \"Classpath\" exception as provided\n * by Oracle in the LICENSE file that accompanied this code.\n *\n * This code is distributed in the hope that it will be useful, but WITHOUT\n * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or\n * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License\n * version 2 for more details (a copy is included in the LICENSE file that\n * accompanied this code).\n *\n * You should have received a copy of the GNU General Public License version\n * 2 along with this work; if not, write to the Free Software Foundation,\n * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.\n *\n * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA\n * or visit www.oracle.com if you need additional information or have any\n * questions.\n */\n /**\n * This class implements an output stream in which the data is\n * written into a byte array. The buffer automatically grows as data\n * is written to it.\n * The data can be retrieved using toByteArray() and\n * toString().\n *

\n * Closing a ByteArrayOutputStream has no effect. The methods in\n * this class can be called after the stream has been closed without\n * generating an IOException.\n *\n * @author Arthur van Hoff\n * @since JDK1.0\n */\n /*public*/ class ByteArrayOutputStream extends OutputStream {\n /**\n * Creates a new byte array output stream. The buffer capacity is\n * initially 32 bytes, though its size increases if necessary.\n */\n // public constructor() {\n // this(32);\n // }\n /**\n * Creates a new byte array output stream, with a buffer capacity of\n * the specified size, in bytes.\n *\n * @param size the initial size.\n * @exception IllegalArgumentException if size is negative.\n */\n constructor(size = 32) {\n super();\n /**\n * The number of valid bytes in the buffer.\n */\n this.count = 0;\n if (size < 0) {\n throw new IllegalArgumentException('Negative initial size: '\n + size);\n }\n this.buf = new Uint8Array(size);\n }\n /**\n * Increases the capacity if necessary to ensure that it can hold\n * at least the number of elements specified by the minimum\n * capacity argument.\n *\n * @param minCapacity the desired minimum capacity\n * @throws OutOfMemoryError if {@code minCapacity < 0}. This is\n * interpreted as a request for the unsatisfiably large capacity\n * {@code (long) Integer.MAX_VALUE + (minCapacity - Integer.MAX_VALUE)}.\n */\n ensureCapacity(minCapacity) {\n // overflow-conscious code\n if (minCapacity - this.buf.length > 0)\n this.grow(minCapacity);\n }\n /**\n * Increases the capacity to ensure that it can hold at least the\n * number of elements specified by the minimum capacity argument.\n *\n * @param minCapacity the desired minimum capacity\n */\n grow(minCapacity) {\n // overflow-conscious code\n let oldCapacity = this.buf.length;\n let newCapacity = oldCapacity << 1;\n if (newCapacity - minCapacity < 0)\n newCapacity = minCapacity;\n if (newCapacity < 0) {\n if (minCapacity < 0) // overflow\n throw new OutOfMemoryError();\n newCapacity = Integer.MAX_VALUE;\n }\n this.buf = Arrays.copyOfUint8Array(this.buf, newCapacity);\n }\n /**\n * Writes the specified byte to this byte array output stream.\n *\n * @param b the byte to be written.\n */\n write(b) {\n this.ensureCapacity(this.count + 1);\n this.buf[this.count] = /*(byte)*/ b;\n this.count += 1;\n }\n /**\n * Writes len bytes from the specified byte array\n * starting at offset off to this byte array output stream.\n *\n * @param b the data.\n * @param off the start offset in the data.\n * @param len the number of bytes to write.\n */\n writeBytesOffset(b, off, len) {\n if ((off < 0) || (off > b.length) || (len < 0) ||\n ((off + len) - b.length > 0)) {\n throw new IndexOutOfBoundsException();\n }\n this.ensureCapacity(this.count + len);\n System.arraycopy(b, off, this.buf, this.count, len);\n this.count += len;\n }\n /**\n * Writes the complete contents of this byte array output stream to\n * the specified output stream argument, as if by calling the output\n * stream's write method using out.write(buf, 0, count).\n *\n * @param out the output stream to which to write the data.\n * @exception IOException if an I/O error occurs.\n */\n writeTo(out) {\n out.writeBytesOffset(this.buf, 0, this.count);\n }\n /**\n * Resets the count field of this byte array output\n * stream to zero, so that all currently accumulated output in the\n * output stream is discarded. The output stream can be used again,\n * reusing the already allocated buffer space.\n *\n * @see java.io.ByteArrayInputStream#count\n */\n reset() {\n this.count = 0;\n }\n /**\n * Creates a newly allocated byte array. Its size is the current\n * size of this output stream and the valid contents of the buffer\n * have been copied into it.\n *\n * @return the current contents of this output stream, as a byte array.\n * @see java.io.ByteArrayOutputStream#size()\n */\n toByteArray() {\n return Arrays.copyOfUint8Array(this.buf, this.count);\n }\n /**\n * Returns the current size of the buffer.\n *\n * @return the value of the count field, which is the number\n * of valid bytes in this output stream.\n * @see java.io.ByteArrayOutputStream#count\n */\n size() {\n return this.count;\n }\n toString(param) {\n if (!param) {\n return this.toString_void();\n }\n if (typeof param === 'string') {\n return this.toString_string(param);\n }\n return this.toString_number(param);\n }\n /**\n * Converts the buffer's contents into a string decoding bytes using the\n * platform's default character set. The length of the new String\n * is a function of the character set, and hence may not be equal to the\n * size of the buffer.\n *\n *

This method always replaces malformed-input and unmappable-character\n * sequences with the default replacement string for the platform's\n * default character set. The {@linkplain java.nio.charset.CharsetDecoder}\n * class should be used when more control over the decoding process is\n * required.\n *\n * @return String decoded from the buffer's contents.\n * @since JDK1.1\n */\n toString_void() {\n return new String(this.buf /*, 0, this.count*/).toString();\n }\n /**\n * Converts the buffer's contents into a string by decoding the bytes using\n * the specified {@link java.nio.charset.Charset charsetName}. The length of\n * the new String is a function of the charset, and hence may not be\n * equal to the length of the byte array.\n *\n *

This method always replaces malformed-input and unmappable-character\n * sequences with this charset's default replacement string. The {@link\n * java.nio.charset.CharsetDecoder} class should be used when more control\n * over the decoding process is required.\n *\n * @param charsetName the name of a supported\n * {@linkplain java.nio.charset.Charset charset}\n * @return String decoded from the buffer's contents.\n * @exception UnsupportedEncodingException\n * If the named charset is not supported\n * @since JDK1.1\n */\n toString_string(charsetName) {\n return new String(this.buf /*, 0, this.count, charsetName*/).toString();\n }\n /**\n * Creates a newly allocated string. Its size is the current size of\n * the output stream and the valid contents of the buffer have been\n * copied into it. Each character c in the resulting string is\n * constructed from the corresponding element b in the byte\n * array such that:\n *

\n         *     c == (char)(((hibyte & 0xff) << 8) | (b & 0xff))\n         * 
\n *\n * @deprecated This method does not properly convert bytes into characters.\n * As of JDK 1.1, the preferred way to do this is via the\n * toString(String enc) method, which takes an encoding-name\n * argument, or the toString() method, which uses the\n * platform's default character encoding.\n *\n * @param hibyte the high byte of each resulting Unicode character.\n * @return the current contents of the output stream, as a string.\n * @see java.io.ByteArrayOutputStream#size()\n * @see java.io.ByteArrayOutputStream#toString(String)\n * @see java.io.ByteArrayOutputStream#toString()\n */\n // @Deprecated\n toString_number(hibyte) {\n return new String(this.buf /*, hibyte, 0, this.count*/).toString();\n }\n /**\n * Closing a ByteArrayOutputStream has no effect. The methods in\n * this class can be called after the stream has been closed without\n * generating an IOException.\n *

\n *\n * @throws IOException\n */\n close() {\n }\n }\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*private*/ var Mode$2;\n (function (Mode) {\n Mode[Mode[\"ALPHA\"] = 0] = \"ALPHA\";\n Mode[Mode[\"LOWER\"] = 1] = \"LOWER\";\n Mode[Mode[\"MIXED\"] = 2] = \"MIXED\";\n Mode[Mode[\"PUNCT\"] = 3] = \"PUNCT\";\n Mode[Mode[\"ALPHA_SHIFT\"] = 4] = \"ALPHA_SHIFT\";\n Mode[Mode[\"PUNCT_SHIFT\"] = 5] = \"PUNCT_SHIFT\";\n })(Mode$2 || (Mode$2 = {}));\n /**\n * Indirectly access the global BigInt constructor, it\n * allows browsers that doesn't support BigInt to run\n * the library without breaking due to \"undefined BigInt\"\n * errors.\n */\n function getBigIntConstructor() {\n if (typeof window !== 'undefined') {\n return window['BigInt'] || null;\n }\n if (typeof global !== 'undefined') {\n return global['BigInt'] || null;\n }\n if (typeof self !== 'undefined') {\n return self['BigInt'] || null;\n }\n throw new Error('Can\\'t search globals for BigInt!');\n }\n /**\n * Used to store the BigInt constructor.\n */\n let BigInteger;\n /**\n * This function creates a bigint value. It allows browsers\n * that doesn't support BigInt to run the rest of the library\n * by not directly accessing the BigInt constructor.\n */\n function createBigInt(num) {\n if (typeof BigInteger === 'undefined') {\n BigInteger = getBigIntConstructor();\n }\n if (BigInteger === null) {\n throw new Error('BigInt is not supported!');\n }\n return BigInteger(num);\n }\n function getEXP900() {\n // in Java - array with length = 16\n let EXP900 = [];\n EXP900[0] = createBigInt(1);\n let nineHundred = createBigInt(900);\n EXP900[1] = nineHundred;\n // in Java - array with length = 16\n for (let i /*int*/ = 2; i < 16; i++) {\n EXP900[i] = EXP900[i - 1] * nineHundred;\n }\n return EXP900;\n }\n /**\n *

This class contains the methods for decoding the PDF417 codewords.

\n *\n * @author SITA Lab (kevin.osullivan@sita.aero)\n * @author Guenther Grau\n */\n /*final*/ class DecodedBitStreamParser$2 {\n // private DecodedBitStreamParser() {\n // }\n /**\n *\n * @param codewords\n * @param ecLevel\n *\n * @throws FormatException\n */\n static decode(codewords, ecLevel) {\n // pass encoding to result (will be used for decode symbols in byte mode)\n let result = new StringBuilder('');\n // let encoding: Charset = StandardCharsets.ISO_8859_1;\n let encoding = CharacterSetECI.ISO8859_1;\n /**\n * @note the next command is specific from this TypeScript library\n * because TS can't properly cast some values to char and\n * convert it to string later correctly due to encoding\n * differences from Java version. As reported here:\n * https://github.com/zxing-js/library/pull/264/files#r382831593\n */\n result.enableDecoding(encoding);\n // Get compaction mode\n let codeIndex = 1;\n let code = codewords[codeIndex++];\n let resultMetadata = new PDF417ResultMetadata();\n while (codeIndex < codewords[0]) {\n switch (code) {\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex, result);\n break;\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n codeIndex = DecodedBitStreamParser$2.byteCompaction(code, codewords, encoding, codeIndex, result);\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n result.append(/*(char)*/ codewords[codeIndex++]);\n break;\n case DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH:\n codeIndex = DecodedBitStreamParser$2.numericCompaction(codewords, codeIndex, result);\n break;\n case DecodedBitStreamParser$2.ECI_CHARSET:\n let charsetECI = CharacterSetECI.getCharacterSetECIByValue(codewords[codeIndex++]);\n // encoding = Charset.forName(charsetECI.getName());\n break;\n case DecodedBitStreamParser$2.ECI_GENERAL_PURPOSE:\n // Can't do anything with generic ECI; skip its 2 characters\n codeIndex += 2;\n break;\n case DecodedBitStreamParser$2.ECI_USER_DEFINED:\n // Can't do anything with user ECI; skip its 1 character\n codeIndex++;\n break;\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK:\n codeIndex = DecodedBitStreamParser$2.decodeMacroBlock(codewords, codeIndex, resultMetadata);\n break;\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n // Should not see these outside a macro block\n throw new FormatException();\n default:\n // Default to text compaction. During testing numerous barcodes\n // appeared to be missing the starting mode. In these cases defaulting\n // to text compaction seems to work.\n codeIndex--;\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex, result);\n break;\n }\n if (codeIndex < codewords.length) {\n code = codewords[codeIndex++];\n }\n else {\n throw FormatException.getFormatInstance();\n }\n }\n if (result.length() === 0) {\n throw FormatException.getFormatInstance();\n }\n let decoderResult = new DecoderResult(null, result.toString(), null, ecLevel);\n decoderResult.setOther(resultMetadata);\n return decoderResult;\n }\n /**\n *\n * @param int\n * @param param1\n * @param codewords\n * @param int\n * @param codeIndex\n * @param PDF417ResultMetadata\n * @param resultMetadata\n *\n * @throws FormatException\n */\n // @SuppressWarnings(\"deprecation\")\n static decodeMacroBlock(codewords, codeIndex, resultMetadata) {\n if (codeIndex + DecodedBitStreamParser$2.NUMBER_OF_SEQUENCE_CODEWORDS > codewords[0]) {\n // we must have at least two bytes left for the segment index\n throw FormatException.getFormatInstance();\n }\n let segmentIndexArray = new Int32Array(DecodedBitStreamParser$2.NUMBER_OF_SEQUENCE_CODEWORDS);\n for (let i /*int*/ = 0; i < DecodedBitStreamParser$2.NUMBER_OF_SEQUENCE_CODEWORDS; i++, codeIndex++) {\n segmentIndexArray[i] = codewords[codeIndex];\n }\n resultMetadata.setSegmentIndex(Integer.parseInt(DecodedBitStreamParser$2.decodeBase900toBase10(segmentIndexArray, DecodedBitStreamParser$2.NUMBER_OF_SEQUENCE_CODEWORDS)));\n let fileId = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex, fileId);\n resultMetadata.setFileId(fileId.toString());\n let optionalFieldsStart = -1;\n if (codewords[codeIndex] === DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD) {\n optionalFieldsStart = codeIndex + 1;\n }\n while (codeIndex < codewords[0]) {\n switch (codewords[codeIndex]) {\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n codeIndex++;\n switch (codewords[codeIndex]) {\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_FILE_NAME:\n let fileName = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex + 1, fileName);\n resultMetadata.setFileName(fileName.toString());\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_SENDER:\n let sender = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex + 1, sender);\n resultMetadata.setSender(sender.toString());\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_ADDRESSEE:\n let addressee = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex + 1, addressee);\n resultMetadata.setAddressee(addressee.toString());\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_SEGMENT_COUNT:\n let segmentCount = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.numericCompaction(codewords, codeIndex + 1, segmentCount);\n resultMetadata.setSegmentCount(Integer.parseInt(segmentCount.toString()));\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_TIME_STAMP:\n let timestamp = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.numericCompaction(codewords, codeIndex + 1, timestamp);\n resultMetadata.setTimestamp(Long.parseLong(timestamp.toString()));\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_CHECKSUM:\n let checksum = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.numericCompaction(codewords, codeIndex + 1, checksum);\n resultMetadata.setChecksum(Integer.parseInt(checksum.toString()));\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_FILE_SIZE:\n let fileSize = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.numericCompaction(codewords, codeIndex + 1, fileSize);\n resultMetadata.setFileSize(Long.parseLong(fileSize.toString()));\n break;\n default:\n throw FormatException.getFormatInstance();\n }\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n codeIndex++;\n resultMetadata.setLastSegment(true);\n break;\n default:\n throw FormatException.getFormatInstance();\n }\n }\n // copy optional fields to additional options\n if (optionalFieldsStart !== -1) {\n let optionalFieldsLength = codeIndex - optionalFieldsStart;\n if (resultMetadata.isLastSegment()) {\n // do not include terminator\n optionalFieldsLength--;\n }\n resultMetadata.setOptionalData(Arrays.copyOfRange(codewords, optionalFieldsStart, optionalFieldsStart + optionalFieldsLength));\n }\n return codeIndex;\n }\n /**\n * Text Compaction mode (see 5.4.1.5) permits all printable ASCII characters to be\n * encoded, i.e. values 32 - 126 inclusive in accordance with ISO/IEC 646 (IRV), as\n * well as selected control characters.\n *\n * @param codewords The array of codewords (data + error)\n * @param codeIndex The current index into the codeword array.\n * @param result The decoded data is appended to the result.\n * @return The next index into the codeword array.\n */\n static textCompaction(codewords, codeIndex, result) {\n // 2 character per codeword\n let textCompactionData = new Int32Array((codewords[0] - codeIndex) * 2);\n // Used to hold the byte compaction value if there is a mode shift\n let byteCompactionData = new Int32Array((codewords[0] - codeIndex) * 2);\n let index = 0;\n let end = false;\n while ((codeIndex < codewords[0]) && !end) {\n let code = codewords[codeIndex++];\n if (code < DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH) {\n textCompactionData[index] = code / 30;\n textCompactionData[index + 1] = code % 30;\n index += 2;\n }\n else {\n switch (code) {\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n // reinitialize text compaction mode to alpha sub mode\n textCompactionData[index++] = DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH;\n break;\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n case DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n codeIndex--;\n end = true;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n // The Mode Shift codeword 913 shall cause a temporary\n // switch from Text Compaction mode to Byte Compaction mode.\n // This switch shall be in effect for only the next codeword,\n // after which the mode shall revert to the prevailing sub-mode\n // of the Text Compaction mode. Codeword 913 is only available\n // in Text Compaction mode; its use is described in 5.4.2.4.\n textCompactionData[index] = DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE;\n code = codewords[codeIndex++];\n byteCompactionData[index] = code;\n index++;\n break;\n }\n }\n }\n DecodedBitStreamParser$2.decodeTextCompaction(textCompactionData, byteCompactionData, index, result);\n return codeIndex;\n }\n /**\n * The Text Compaction mode includes all the printable ASCII characters\n * (i.e. values from 32 to 126) and three ASCII control characters: HT or tab\n * (9: e), LF or line feed (10: e), and CR or carriage\n * return (13: e). The Text Compaction mode also includes various latch\n * and shift characters which are used exclusively within the mode. The Text\n * Compaction mode encodes up to 2 characters per codeword. The compaction rules\n * for converting data into PDF417 codewords are defined in 5.4.2.2. The sub-mode\n * switches are defined in 5.4.2.3.\n *\n * @param textCompactionData The text compaction data.\n * @param byteCompactionData The byte compaction data if there\n * was a mode shift.\n * @param length The size of the text compaction and byte compaction data.\n * @param result The decoded data is appended to the result.\n */\n static decodeTextCompaction(textCompactionData, byteCompactionData, length, result) {\n // Beginning from an initial state of the Alpha sub-mode\n // The default compaction mode for PDF417 in effect at the start of each symbol shall always be Text\n // Compaction mode Alpha sub-mode (alphabetic: uppercase). A latch codeword from another mode to the Text\n // Compaction mode shall always switch to the Text Compaction Alpha sub-mode.\n let subMode = Mode$2.ALPHA;\n let priorToShiftMode = Mode$2.ALPHA;\n let i = 0;\n while (i < length) {\n let subModeCh = textCompactionData[i];\n let ch = /*char*/ '';\n switch (subMode) {\n case Mode$2.ALPHA:\n // Alpha (alphabetic: uppercase)\n if (subModeCh < 26) {\n // Upper case Alpha Character\n // Note: 65 = 'A' ASCII -> there is byte code of symbol\n ch = /*(char)('A' + subModeCh) */ String.fromCharCode(65 + subModeCh);\n }\n else {\n switch (subModeCh) {\n case 26:\n ch = ' ';\n break;\n case DecodedBitStreamParser$2.LL:\n subMode = Mode$2.LOWER;\n break;\n case DecodedBitStreamParser$2.ML:\n subMode = Mode$2.MIXED;\n break;\n case DecodedBitStreamParser$2.PS:\n // Shift to punctuation\n priorToShiftMode = subMode;\n subMode = Mode$2.PUNCT_SHIFT;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n result.append(/*(char)*/ byteCompactionData[i]);\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n case Mode$2.LOWER:\n // Lower (alphabetic: lowercase)\n if (subModeCh < 26) {\n ch = /*(char)('a' + subModeCh)*/ String.fromCharCode(97 + subModeCh);\n }\n else {\n switch (subModeCh) {\n case 26:\n ch = ' ';\n break;\n case DecodedBitStreamParser$2.AS:\n // Shift to alpha\n priorToShiftMode = subMode;\n subMode = Mode$2.ALPHA_SHIFT;\n break;\n case DecodedBitStreamParser$2.ML:\n subMode = Mode$2.MIXED;\n break;\n case DecodedBitStreamParser$2.PS:\n // Shift to punctuation\n priorToShiftMode = subMode;\n subMode = Mode$2.PUNCT_SHIFT;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n // TODO Does this need to use the current character encoding? See other occurrences below\n result.append(/*(char)*/ byteCompactionData[i]);\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n case Mode$2.MIXED:\n // Mixed (punctuation: e)\n if (subModeCh < DecodedBitStreamParser$2.PL) {\n ch = DecodedBitStreamParser$2.MIXED_CHARS[subModeCh];\n }\n else {\n switch (subModeCh) {\n case DecodedBitStreamParser$2.PL:\n subMode = Mode$2.PUNCT;\n break;\n case 26:\n ch = ' ';\n break;\n case DecodedBitStreamParser$2.LL:\n subMode = Mode$2.LOWER;\n break;\n case DecodedBitStreamParser$2.AL:\n subMode = Mode$2.ALPHA;\n break;\n case DecodedBitStreamParser$2.PS:\n // Shift to punctuation\n priorToShiftMode = subMode;\n subMode = Mode$2.PUNCT_SHIFT;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n result.append(/*(char)*/ byteCompactionData[i]);\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n case Mode$2.PUNCT:\n // Punctuation\n if (subModeCh < DecodedBitStreamParser$2.PAL) {\n ch = DecodedBitStreamParser$2.PUNCT_CHARS[subModeCh];\n }\n else {\n switch (subModeCh) {\n case DecodedBitStreamParser$2.PAL:\n subMode = Mode$2.ALPHA;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n result.append(/*(char)*/ byteCompactionData[i]);\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n case Mode$2.ALPHA_SHIFT:\n // Restore sub-mode\n subMode = priorToShiftMode;\n if (subModeCh < 26) {\n ch = /*(char)('A' + subModeCh)*/ String.fromCharCode(65 + subModeCh);\n }\n else {\n switch (subModeCh) {\n case 26:\n ch = ' ';\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n case Mode$2.PUNCT_SHIFT:\n // Restore sub-mode\n subMode = priorToShiftMode;\n if (subModeCh < DecodedBitStreamParser$2.PAL) {\n ch = DecodedBitStreamParser$2.PUNCT_CHARS[subModeCh];\n }\n else {\n switch (subModeCh) {\n case DecodedBitStreamParser$2.PAL:\n subMode = Mode$2.ALPHA;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n // PS before Shift-to-Byte is used as a padding character,\n // see 5.4.2.4 of the specification\n result.append(/*(char)*/ byteCompactionData[i]);\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n }\n // if (ch !== 0) {\n if (ch !== '') {\n // Append decoded character to result\n result.append(ch);\n }\n i++;\n }\n }\n /**\n * Byte Compaction mode (see 5.4.3) permits all 256 possible 8-bit byte values to be encoded.\n * This includes all ASCII characters value 0 to 127 inclusive and provides for international\n * character set support.\n *\n * @param mode The byte compaction mode i.e. 901 or 924\n * @param codewords The array of codewords (data + error)\n * @param encoding Currently active character encoding\n * @param codeIndex The current index into the codeword array.\n * @param result The decoded data is appended to the result.\n * @return The next index into the codeword array.\n */\n static /*int*/ byteCompaction(mode, codewords, encoding, codeIndex, result) {\n let decodedBytes = new ByteArrayOutputStream();\n let count = 0;\n let value = /*long*/ 0;\n let end = false;\n switch (mode) {\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n // Total number of Byte Compaction characters to be encoded\n // is not a multiple of 6\n let byteCompactedCodewords = new Int32Array(6);\n let nextCode = codewords[codeIndex++];\n while ((codeIndex < codewords[0]) && !end) {\n byteCompactedCodewords[count++] = nextCode;\n // Base 900\n value = 900 * value + nextCode;\n nextCode = codewords[codeIndex++];\n // perhaps it should be ok to check only nextCode >= TEXT_COMPACTION_MODE_LATCH\n switch (nextCode) {\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n codeIndex--;\n end = true;\n break;\n default:\n if ((count % 5 === 0) && (count > 0)) {\n // Decode every 5 codewords\n // Convert to Base 256\n for (let j /*int*/ = 0; j < 6; ++j) {\n /* @note\n * JavaScript stores numbers as 64 bits floating point numbers, but all bitwise operations are performed on 32 bits binary numbers.\n * So the next bitwise operation could not be done with simple numbers\n */\n decodedBytes.write(/*(byte)*/ Number(createBigInt(value) >> createBigInt(8 * (5 - j))));\n }\n value = 0;\n count = 0;\n }\n break;\n }\n }\n // if the end of all codewords is reached the last codeword needs to be added\n if (codeIndex === codewords[0] && nextCode < DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH) {\n byteCompactedCodewords[count++] = nextCode;\n }\n // If Byte Compaction mode is invoked with codeword 901,\n // the last group of codewords is interpreted directly\n // as one byte per codeword, without compaction.\n for (let i /*int*/ = 0; i < count; i++) {\n decodedBytes.write(/*(byte)*/ byteCompactedCodewords[i]);\n }\n break;\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n // Total number of Byte Compaction characters to be encoded\n // is an integer multiple of 6\n while (codeIndex < codewords[0] && !end) {\n let code = codewords[codeIndex++];\n if (code < DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH) {\n count++;\n // Base 900\n value = 900 * value + code;\n }\n else {\n switch (code) {\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n codeIndex--;\n end = true;\n break;\n }\n }\n if ((count % 5 === 0) && (count > 0)) {\n // Decode every 5 codewords\n // Convert to Base 256\n /* @note\n * JavaScript stores numbers as 64 bits floating point numbers, but all bitwise operations are performed on 32 bits binary numbers.\n * So the next bitwise operation could not be done with simple numbers\n */\n for (let j /*int*/ = 0; j < 6; ++j) {\n decodedBytes.write(/*(byte)*/ Number(createBigInt(value) >> createBigInt(8 * (5 - j))));\n }\n value = 0;\n count = 0;\n }\n }\n break;\n }\n result.append(StringEncoding.decode(decodedBytes.toByteArray(), encoding));\n return codeIndex;\n }\n /**\n * Numeric Compaction mode (see 5.4.4) permits efficient encoding of numeric data strings.\n *\n * @param codewords The array of codewords (data + error)\n * @param codeIndex The current index into the codeword array.\n * @param result The decoded data is appended to the result.\n * @return The next index into the codeword array.\n *\n * @throws FormatException\n */\n static numericCompaction(codewords, codeIndex /*int*/, result) {\n let count = 0;\n let end = false;\n let numericCodewords = new Int32Array(DecodedBitStreamParser$2.MAX_NUMERIC_CODEWORDS);\n while (codeIndex < codewords[0] && !end) {\n let code = codewords[codeIndex++];\n if (codeIndex === codewords[0]) {\n end = true;\n }\n if (code < DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH) {\n numericCodewords[count] = code;\n count++;\n }\n else {\n switch (code) {\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n codeIndex--;\n end = true;\n break;\n }\n }\n if ((count % DecodedBitStreamParser$2.MAX_NUMERIC_CODEWORDS === 0 || code === DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH || end) && count > 0) {\n // Re-invoking Numeric Compaction mode (by using codeword 902\n // while in Numeric Compaction mode) serves to terminate the\n // current Numeric Compaction mode grouping as described in 5.4.4.2,\n // and then to start a new one grouping.\n result.append(DecodedBitStreamParser$2.decodeBase900toBase10(numericCodewords, count));\n count = 0;\n }\n }\n return codeIndex;\n }\n /**\n * Convert a list of Numeric Compacted codewords from Base 900 to Base 10.\n *\n * @param codewords The array of codewords\n * @param count The number of codewords\n * @return The decoded string representing the Numeric data.\n *\n * EXAMPLE\n * Encode the fifteen digit numeric string 000213298174000\n * Prefix the numeric string with a 1 and set the initial value of\n * t = 1 000 213 298 174 000\n * Calculate codeword 0\n * d0 = 1 000 213 298 174 000 mod 900 = 200\n *\n * t = 1 000 213 298 174 000 div 900 = 1 111 348 109 082\n * Calculate codeword 1\n * d1 = 1 111 348 109 082 mod 900 = 282\n *\n * t = 1 111 348 109 082 div 900 = 1 234 831 232\n * Calculate codeword 2\n * d2 = 1 234 831 232 mod 900 = 632\n *\n * t = 1 234 831 232 div 900 = 1 372 034\n * Calculate codeword 3\n * d3 = 1 372 034 mod 900 = 434\n *\n * t = 1 372 034 div 900 = 1 524\n * Calculate codeword 4\n * d4 = 1 524 mod 900 = 624\n *\n * t = 1 524 div 900 = 1\n * Calculate codeword 5\n * d5 = 1 mod 900 = 1\n * t = 1 div 900 = 0\n * Codeword sequence is: 1, 624, 434, 632, 282, 200\n *\n * Decode the above codewords involves\n * 1 x 900 power of 5 + 624 x 900 power of 4 + 434 x 900 power of 3 +\n * 632 x 900 power of 2 + 282 x 900 power of 1 + 200 x 900 power of 0 = 1000213298174000\n *\n * Remove leading 1 => Result is 000213298174000\n *\n * @throws FormatException\n */\n static decodeBase900toBase10(codewords, count) {\n let result = createBigInt(0);\n for (let i /*int*/ = 0; i < count; i++) {\n result += DecodedBitStreamParser$2.EXP900[count - i - 1] * createBigInt(codewords[i]);\n }\n let resultString = result.toString();\n if (resultString.charAt(0) !== '1') {\n throw new FormatException();\n }\n return resultString.substring(1);\n }\n }\n DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH = 900;\n DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH = 901;\n DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH = 902;\n DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6 = 924;\n DecodedBitStreamParser$2.ECI_USER_DEFINED = 925;\n DecodedBitStreamParser$2.ECI_GENERAL_PURPOSE = 926;\n DecodedBitStreamParser$2.ECI_CHARSET = 927;\n DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK = 928;\n DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD = 923;\n DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR = 922;\n DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE = 913;\n DecodedBitStreamParser$2.MAX_NUMERIC_CODEWORDS = 15;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_FILE_NAME = 0;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_SEGMENT_COUNT = 1;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_TIME_STAMP = 2;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_SENDER = 3;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_ADDRESSEE = 4;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_FILE_SIZE = 5;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_CHECKSUM = 6;\n DecodedBitStreamParser$2.PL = 25;\n DecodedBitStreamParser$2.LL = 27;\n DecodedBitStreamParser$2.AS = 27;\n DecodedBitStreamParser$2.ML = 28;\n DecodedBitStreamParser$2.AL = 28;\n DecodedBitStreamParser$2.PS = 29;\n DecodedBitStreamParser$2.PAL = 29;\n DecodedBitStreamParser$2.PUNCT_CHARS = ';<>@[\\\\]_`~!\\r\\t,:\\n-.$/\"|*()?{}\\'';\n DecodedBitStreamParser$2.MIXED_CHARS = '0123456789&\\r\\t,:#-.$/+%*=^';\n /**\n * Table containing values for the exponent of 900.\n * This is used in the numeric compaction decode algorithm.\n */\n DecodedBitStreamParser$2.EXP900 = getBigIntConstructor() ? getEXP900() : [];\n DecodedBitStreamParser$2.NUMBER_OF_SEQUENCE_CODEWORDS = 2;\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // import java.util.ArrayList;\n // import java.util.Collection;\n // import java.util.Formatter;\n // import java.util.List;\n /**\n * @author Guenther Grau\n */\n /*public final*/ class PDF417ScanningDecoder {\n constructor() { }\n /**\n * @TODO don't pass in minCodewordWidth and maxCodewordWidth, pass in barcode columns for start and stop pattern\n *\n * columns. That way width can be deducted from the pattern column.\n * This approach also allows to detect more details about the barcode, e.g. if a bar type (white or black) is wider\n * than it should be. This can happen if the scanner used a bad blackpoint.\n *\n * @param BitMatrix\n * @param image\n * @param ResultPoint\n * @param imageTopLeft\n * @param ResultPoint\n * @param imageBottomLeft\n * @param ResultPoint\n * @param imageTopRight\n * @param ResultPoint\n * @param imageBottomRight\n * @param int\n * @param minCodewordWidth\n * @param int\n * @param maxCodewordWidth\n *\n * @throws NotFoundException\n * @throws FormatException\n * @throws ChecksumException\n */\n static decode(image, imageTopLeft, imageBottomLeft, imageTopRight, imageBottomRight, minCodewordWidth, maxCodewordWidth) {\n let boundingBox = new BoundingBox(image, imageTopLeft, imageBottomLeft, imageTopRight, imageBottomRight);\n let leftRowIndicatorColumn = null;\n let rightRowIndicatorColumn = null;\n let detectionResult;\n for (let firstPass /*boolean*/ = true;; firstPass = false) {\n if (imageTopLeft != null) {\n leftRowIndicatorColumn = PDF417ScanningDecoder.getRowIndicatorColumn(image, boundingBox, imageTopLeft, true, minCodewordWidth, maxCodewordWidth);\n }\n if (imageTopRight != null) {\n rightRowIndicatorColumn = PDF417ScanningDecoder.getRowIndicatorColumn(image, boundingBox, imageTopRight, false, minCodewordWidth, maxCodewordWidth);\n }\n detectionResult = PDF417ScanningDecoder.merge(leftRowIndicatorColumn, rightRowIndicatorColumn);\n if (detectionResult == null) {\n throw NotFoundException.getNotFoundInstance();\n }\n let resultBox = detectionResult.getBoundingBox();\n if (firstPass && resultBox != null &&\n (resultBox.getMinY() < boundingBox.getMinY() || resultBox.getMaxY() > boundingBox.getMaxY())) {\n boundingBox = resultBox;\n }\n else {\n break;\n }\n }\n detectionResult.setBoundingBox(boundingBox);\n let maxBarcodeColumn = detectionResult.getBarcodeColumnCount() + 1;\n detectionResult.setDetectionResultColumn(0, leftRowIndicatorColumn);\n detectionResult.setDetectionResultColumn(maxBarcodeColumn, rightRowIndicatorColumn);\n let leftToRight = leftRowIndicatorColumn != null;\n for (let barcodeColumnCount /*int*/ = 1; barcodeColumnCount <= maxBarcodeColumn; barcodeColumnCount++) {\n let barcodeColumn = leftToRight ? barcodeColumnCount : maxBarcodeColumn - barcodeColumnCount;\n if (detectionResult.getDetectionResultColumn(barcodeColumn) !== /* null */ undefined) {\n // This will be the case for the opposite row indicator column, which doesn't need to be decoded again.\n continue;\n }\n let detectionResultColumn;\n if (barcodeColumn === 0 || barcodeColumn === maxBarcodeColumn) {\n detectionResultColumn = new DetectionResultRowIndicatorColumn(boundingBox, barcodeColumn === 0);\n }\n else {\n detectionResultColumn = new DetectionResultColumn(boundingBox);\n }\n detectionResult.setDetectionResultColumn(barcodeColumn, detectionResultColumn);\n let startColumn = -1;\n let previousStartColumn = startColumn;\n // TODO start at a row for which we know the start position, then detect upwards and downwards from there.\n for (let imageRow /*int*/ = boundingBox.getMinY(); imageRow <= boundingBox.getMaxY(); imageRow++) {\n startColumn = PDF417ScanningDecoder.getStartColumn(detectionResult, barcodeColumn, imageRow, leftToRight);\n if (startColumn < 0 || startColumn > boundingBox.getMaxX()) {\n if (previousStartColumn === -1) {\n continue;\n }\n startColumn = previousStartColumn;\n }\n let codeword = PDF417ScanningDecoder.detectCodeword(image, boundingBox.getMinX(), boundingBox.getMaxX(), leftToRight, startColumn, imageRow, minCodewordWidth, maxCodewordWidth);\n if (codeword != null) {\n detectionResultColumn.setCodeword(imageRow, codeword);\n previousStartColumn = startColumn;\n minCodewordWidth = Math.min(minCodewordWidth, codeword.getWidth());\n maxCodewordWidth = Math.max(maxCodewordWidth, codeword.getWidth());\n }\n }\n }\n return PDF417ScanningDecoder.createDecoderResult(detectionResult);\n }\n /**\n *\n * @param leftRowIndicatorColumn\n * @param rightRowIndicatorColumn\n *\n * @throws NotFoundException\n */\n static merge(leftRowIndicatorColumn, rightRowIndicatorColumn) {\n if (leftRowIndicatorColumn == null && rightRowIndicatorColumn == null) {\n return null;\n }\n let barcodeMetadata = PDF417ScanningDecoder.getBarcodeMetadata(leftRowIndicatorColumn, rightRowIndicatorColumn);\n if (barcodeMetadata == null) {\n return null;\n }\n let boundingBox = BoundingBox.merge(PDF417ScanningDecoder.adjustBoundingBox(leftRowIndicatorColumn), PDF417ScanningDecoder.adjustBoundingBox(rightRowIndicatorColumn));\n return new DetectionResult(barcodeMetadata, boundingBox);\n }\n /**\n *\n * @param rowIndicatorColumn\n *\n * @throws NotFoundException\n */\n static adjustBoundingBox(rowIndicatorColumn) {\n if (rowIndicatorColumn == null) {\n return null;\n }\n let rowHeights = rowIndicatorColumn.getRowHeights();\n if (rowHeights == null) {\n return null;\n }\n let maxRowHeight = PDF417ScanningDecoder.getMax(rowHeights);\n let missingStartRows = 0;\n for (let rowHeight /*int*/ of rowHeights) {\n missingStartRows += maxRowHeight - rowHeight;\n if (rowHeight > 0) {\n break;\n }\n }\n let codewords = rowIndicatorColumn.getCodewords();\n for (let row /*int*/ = 0; missingStartRows > 0 && codewords[row] == null; row++) {\n missingStartRows--;\n }\n let missingEndRows = 0;\n for (let row /*int*/ = rowHeights.length - 1; row >= 0; row--) {\n missingEndRows += maxRowHeight - rowHeights[row];\n if (rowHeights[row] > 0) {\n break;\n }\n }\n for (let row /*int*/ = codewords.length - 1; missingEndRows > 0 && codewords[row] == null; row--) {\n missingEndRows--;\n }\n return rowIndicatorColumn.getBoundingBox().addMissingRows(missingStartRows, missingEndRows, rowIndicatorColumn.isLeft());\n }\n static getMax(values) {\n let maxValue = -1;\n for (let value /*int*/ of values) {\n maxValue = Math.max(maxValue, value);\n }\n return maxValue;\n }\n static getBarcodeMetadata(leftRowIndicatorColumn, rightRowIndicatorColumn) {\n let leftBarcodeMetadata;\n if (leftRowIndicatorColumn == null ||\n (leftBarcodeMetadata = leftRowIndicatorColumn.getBarcodeMetadata()) == null) {\n return rightRowIndicatorColumn == null ? null : rightRowIndicatorColumn.getBarcodeMetadata();\n }\n let rightBarcodeMetadata;\n if (rightRowIndicatorColumn == null ||\n (rightBarcodeMetadata = rightRowIndicatorColumn.getBarcodeMetadata()) == null) {\n return leftBarcodeMetadata;\n }\n if (leftBarcodeMetadata.getColumnCount() !== rightBarcodeMetadata.getColumnCount() &&\n leftBarcodeMetadata.getErrorCorrectionLevel() !== rightBarcodeMetadata.getErrorCorrectionLevel() &&\n leftBarcodeMetadata.getRowCount() !== rightBarcodeMetadata.getRowCount()) {\n return null;\n }\n return leftBarcodeMetadata;\n }\n static getRowIndicatorColumn(image, boundingBox, startPoint, leftToRight, minCodewordWidth, maxCodewordWidth) {\n let rowIndicatorColumn = new DetectionResultRowIndicatorColumn(boundingBox, leftToRight);\n for (let i /*int*/ = 0; i < 2; i++) {\n let increment = i === 0 ? 1 : -1;\n let startColumn = Math.trunc(Math.trunc(startPoint.getX()));\n for (let imageRow /*int*/ = Math.trunc(Math.trunc(startPoint.getY())); imageRow <= boundingBox.getMaxY() &&\n imageRow >= boundingBox.getMinY(); imageRow += increment) {\n let codeword = PDF417ScanningDecoder.detectCodeword(image, 0, image.getWidth(), leftToRight, startColumn, imageRow, minCodewordWidth, maxCodewordWidth);\n if (codeword != null) {\n rowIndicatorColumn.setCodeword(imageRow, codeword);\n if (leftToRight) {\n startColumn = codeword.getStartX();\n }\n else {\n startColumn = codeword.getEndX();\n }\n }\n }\n }\n return rowIndicatorColumn;\n }\n /**\n *\n * @param detectionResult\n * @param BarcodeValue\n * @param param2\n * @param param3\n * @param barcodeMatrix\n *\n * @throws NotFoundException\n */\n static adjustCodewordCount(detectionResult, barcodeMatrix) {\n let barcodeMatrix01 = barcodeMatrix[0][1];\n let numberOfCodewords = barcodeMatrix01.getValue();\n let calculatedNumberOfCodewords = detectionResult.getBarcodeColumnCount() *\n detectionResult.getBarcodeRowCount() -\n PDF417ScanningDecoder.getNumberOfECCodeWords(detectionResult.getBarcodeECLevel());\n if (numberOfCodewords.length === 0) {\n if (calculatedNumberOfCodewords < 1 || calculatedNumberOfCodewords > PDF417Common.MAX_CODEWORDS_IN_BARCODE) {\n throw NotFoundException.getNotFoundInstance();\n }\n barcodeMatrix01.setValue(calculatedNumberOfCodewords);\n }\n else if (numberOfCodewords[0] !== calculatedNumberOfCodewords) {\n // The calculated one is more reliable as it is derived from the row indicator columns\n barcodeMatrix01.setValue(calculatedNumberOfCodewords);\n }\n }\n /**\n *\n * @param detectionResult\n *\n * @throws FormatException\n * @throws ChecksumException\n * @throws NotFoundException\n */\n static createDecoderResult(detectionResult) {\n let barcodeMatrix = PDF417ScanningDecoder.createBarcodeMatrix(detectionResult);\n PDF417ScanningDecoder.adjustCodewordCount(detectionResult, barcodeMatrix);\n let erasures /*Collection*/ = new Array();\n let codewords = new Int32Array(detectionResult.getBarcodeRowCount() * detectionResult.getBarcodeColumnCount());\n let ambiguousIndexValuesList = /*List*/ [];\n let ambiguousIndexesList = /*Collection*/ new Array();\n for (let row /*int*/ = 0; row < detectionResult.getBarcodeRowCount(); row++) {\n for (let column /*int*/ = 0; column < detectionResult.getBarcodeColumnCount(); column++) {\n let values = barcodeMatrix[row][column + 1].getValue();\n let codewordIndex = row * detectionResult.getBarcodeColumnCount() + column;\n if (values.length === 0) {\n erasures.push(codewordIndex);\n }\n else if (values.length === 1) {\n codewords[codewordIndex] = values[0];\n }\n else {\n ambiguousIndexesList.push(codewordIndex);\n ambiguousIndexValuesList.push(values);\n }\n }\n }\n let ambiguousIndexValues = new Array(ambiguousIndexValuesList.length);\n for (let i /*int*/ = 0; i < ambiguousIndexValues.length; i++) {\n ambiguousIndexValues[i] = ambiguousIndexValuesList[i];\n }\n return PDF417ScanningDecoder.createDecoderResultFromAmbiguousValues(detectionResult.getBarcodeECLevel(), codewords, PDF417Common.toIntArray(erasures), PDF417Common.toIntArray(ambiguousIndexesList), ambiguousIndexValues);\n }\n /**\n * This method deals with the fact, that the decoding process doesn't always yield a single most likely value. The\n * current error correction implementation doesn't deal with erasures very well, so it's better to provide a value\n * for these ambiguous codewords instead of treating it as an erasure. The problem is that we don't know which of\n * the ambiguous values to choose. We try decode using the first value, and if that fails, we use another of the\n * ambiguous values and try to decode again. This usually only happens on very hard to read and decode barcodes,\n * so decoding the normal barcodes is not affected by this.\n *\n * @param erasureArray contains the indexes of erasures\n * @param ambiguousIndexes array with the indexes that have more than one most likely value\n * @param ambiguousIndexValues two dimensional array that contains the ambiguous values. The first dimension must\n * be the same length as the ambiguousIndexes array\n *\n * @throws FormatException\n * @throws ChecksumException\n */\n static createDecoderResultFromAmbiguousValues(ecLevel, codewords, erasureArray, ambiguousIndexes, ambiguousIndexValues) {\n let ambiguousIndexCount = new Int32Array(ambiguousIndexes.length);\n let tries = 100;\n while (tries-- > 0) {\n for (let i /*int*/ = 0; i < ambiguousIndexCount.length; i++) {\n codewords[ambiguousIndexes[i]] = ambiguousIndexValues[i][ambiguousIndexCount[i]];\n }\n try {\n return PDF417ScanningDecoder.decodeCodewords(codewords, ecLevel, erasureArray);\n }\n catch (err) {\n let ignored = err instanceof ChecksumException;\n if (!ignored) {\n throw err;\n }\n }\n if (ambiguousIndexCount.length === 0) {\n throw ChecksumException.getChecksumInstance();\n }\n for (let i /*int*/ = 0; i < ambiguousIndexCount.length; i++) {\n if (ambiguousIndexCount[i] < ambiguousIndexValues[i].length - 1) {\n ambiguousIndexCount[i]++;\n break;\n }\n else {\n ambiguousIndexCount[i] = 0;\n if (i === ambiguousIndexCount.length - 1) {\n throw ChecksumException.getChecksumInstance();\n }\n }\n }\n }\n throw ChecksumException.getChecksumInstance();\n }\n static createBarcodeMatrix(detectionResult) {\n // let barcodeMatrix: BarcodeValue[][] =\n // new BarcodeValue[detectionResult.getBarcodeRowCount()][detectionResult.getBarcodeColumnCount() + 2];\n let barcodeMatrix = Array.from({ length: detectionResult.getBarcodeRowCount() }, () => new Array(detectionResult.getBarcodeColumnCount() + 2));\n for (let row /*int*/ = 0; row < barcodeMatrix.length; row++) {\n for (let column /*int*/ = 0; column < barcodeMatrix[row].length; column++) {\n barcodeMatrix[row][column] = new BarcodeValue();\n }\n }\n let column = 0;\n for (let detectionResultColumn /*DetectionResultColumn*/ of detectionResult.getDetectionResultColumns()) {\n if (detectionResultColumn != null) {\n for (let codeword /*Codeword*/ of detectionResultColumn.getCodewords()) {\n if (codeword != null) {\n let rowNumber = codeword.getRowNumber();\n if (rowNumber >= 0) {\n if (rowNumber >= barcodeMatrix.length) {\n // We have more rows than the barcode metadata allows for, ignore them.\n continue;\n }\n barcodeMatrix[rowNumber][column].setValue(codeword.getValue());\n }\n }\n }\n }\n column++;\n }\n return barcodeMatrix;\n }\n static isValidBarcodeColumn(detectionResult, barcodeColumn) {\n return barcodeColumn >= 0 && barcodeColumn <= detectionResult.getBarcodeColumnCount() + 1;\n }\n static getStartColumn(detectionResult, barcodeColumn, imageRow, leftToRight) {\n let offset = leftToRight ? 1 : -1;\n let codeword = null;\n if (PDF417ScanningDecoder.isValidBarcodeColumn(detectionResult, barcodeColumn - offset)) {\n codeword = detectionResult.getDetectionResultColumn(barcodeColumn - offset).getCodeword(imageRow);\n }\n if (codeword != null) {\n return leftToRight ? codeword.getEndX() : codeword.getStartX();\n }\n codeword = detectionResult.getDetectionResultColumn(barcodeColumn).getCodewordNearby(imageRow);\n if (codeword != null) {\n return leftToRight ? codeword.getStartX() : codeword.getEndX();\n }\n if (PDF417ScanningDecoder.isValidBarcodeColumn(detectionResult, barcodeColumn - offset)) {\n codeword = detectionResult.getDetectionResultColumn(barcodeColumn - offset).getCodewordNearby(imageRow);\n }\n if (codeword != null) {\n return leftToRight ? codeword.getEndX() : codeword.getStartX();\n }\n let skippedColumns = 0;\n while (PDF417ScanningDecoder.isValidBarcodeColumn(detectionResult, barcodeColumn - offset)) {\n barcodeColumn -= offset;\n for (let previousRowCodeword /*Codeword*/ of detectionResult.getDetectionResultColumn(barcodeColumn).getCodewords()) {\n if (previousRowCodeword != null) {\n return (leftToRight ? previousRowCodeword.getEndX() : previousRowCodeword.getStartX()) +\n offset *\n skippedColumns *\n (previousRowCodeword.getEndX() - previousRowCodeword.getStartX());\n }\n }\n skippedColumns++;\n }\n return leftToRight ? detectionResult.getBoundingBox().getMinX() : detectionResult.getBoundingBox().getMaxX();\n }\n static detectCodeword(image, minColumn, maxColumn, leftToRight, startColumn, imageRow, minCodewordWidth, maxCodewordWidth) {\n startColumn = PDF417ScanningDecoder.adjustCodewordStartColumn(image, minColumn, maxColumn, leftToRight, startColumn, imageRow);\n // we usually know fairly exact now how long a codeword is. We should provide minimum and maximum expected length\n // and try to adjust the read pixels, e.g. remove single pixel errors or try to cut off exceeding pixels.\n // min and maxCodewordWidth should not be used as they are calculated for the whole barcode an can be inaccurate\n // for the current position\n let moduleBitCount = PDF417ScanningDecoder.getModuleBitCount(image, minColumn, maxColumn, leftToRight, startColumn, imageRow);\n if (moduleBitCount == null) {\n return null;\n }\n let endColumn;\n let codewordBitCount = MathUtils.sum(moduleBitCount);\n if (leftToRight) {\n endColumn = startColumn + codewordBitCount;\n }\n else {\n for (let i /*int*/ = 0; i < moduleBitCount.length / 2; i++) {\n let tmpCount = moduleBitCount[i];\n moduleBitCount[i] = moduleBitCount[moduleBitCount.length - 1 - i];\n moduleBitCount[moduleBitCount.length - 1 - i] = tmpCount;\n }\n endColumn = startColumn;\n startColumn = endColumn - codewordBitCount;\n }\n // TODO implement check for width and correction of black and white bars\n // use start (and maybe stop pattern) to determine if black bars are wider than white bars. If so, adjust.\n // should probably done only for codewords with a lot more than 17 bits.\n // The following fixes 10-1.png, which has wide black bars and small white bars\n // for (let i /*int*/ = 0; i < moduleBitCount.length; i++) {\n // if (i % 2 === 0) {\n // moduleBitCount[i]--;\n // } else {\n // moduleBitCount[i]++;\n // }\n // }\n // We could also use the width of surrounding codewords for more accurate results, but this seems\n // sufficient for now\n if (!PDF417ScanningDecoder.checkCodewordSkew(codewordBitCount, minCodewordWidth, maxCodewordWidth)) {\n // We could try to use the startX and endX position of the codeword in the same column in the previous row,\n // create the bit count from it and normalize it to 8. This would help with single pixel errors.\n return null;\n }\n let decodedValue = PDF417CodewordDecoder.getDecodedValue(moduleBitCount);\n let codeword = PDF417Common.getCodeword(decodedValue);\n if (codeword === -1) {\n return null;\n }\n return new Codeword(startColumn, endColumn, PDF417ScanningDecoder.getCodewordBucketNumber(decodedValue), codeword);\n }\n static getModuleBitCount(image, minColumn, maxColumn, leftToRight, startColumn, imageRow) {\n let imageColumn = startColumn;\n let moduleBitCount = new Int32Array(8);\n let moduleNumber = 0;\n let increment = leftToRight ? 1 : -1;\n let previousPixelValue = leftToRight;\n while ((leftToRight ? imageColumn < maxColumn : imageColumn >= minColumn) &&\n moduleNumber < moduleBitCount.length) {\n if (image.get(imageColumn, imageRow) === previousPixelValue) {\n moduleBitCount[moduleNumber]++;\n imageColumn += increment;\n }\n else {\n moduleNumber++;\n previousPixelValue = !previousPixelValue;\n }\n }\n if (moduleNumber === moduleBitCount.length ||\n ((imageColumn === (leftToRight ? maxColumn : minColumn)) &&\n moduleNumber === moduleBitCount.length - 1)) {\n return moduleBitCount;\n }\n return null;\n }\n static getNumberOfECCodeWords(barcodeECLevel) {\n return 2 << barcodeECLevel;\n }\n static adjustCodewordStartColumn(image, minColumn, maxColumn, leftToRight, codewordStartColumn, imageRow) {\n let correctedStartColumn = codewordStartColumn;\n let increment = leftToRight ? -1 : 1;\n // there should be no black pixels before the start column. If there are, then we need to start earlier.\n for (let i /*int*/ = 0; i < 2; i++) {\n while ((leftToRight ? correctedStartColumn >= minColumn : correctedStartColumn < maxColumn) &&\n leftToRight === image.get(correctedStartColumn, imageRow)) {\n if (Math.abs(codewordStartColumn - correctedStartColumn) > PDF417ScanningDecoder.CODEWORD_SKEW_SIZE) {\n return codewordStartColumn;\n }\n correctedStartColumn += increment;\n }\n increment = -increment;\n leftToRight = !leftToRight;\n }\n return correctedStartColumn;\n }\n static checkCodewordSkew(codewordSize, minCodewordWidth, maxCodewordWidth) {\n return minCodewordWidth - PDF417ScanningDecoder.CODEWORD_SKEW_SIZE <= codewordSize &&\n codewordSize <= maxCodewordWidth + PDF417ScanningDecoder.CODEWORD_SKEW_SIZE;\n }\n /**\n * @throws FormatException,\n * @throws ChecksumException\n */\n static decodeCodewords(codewords, ecLevel, erasures) {\n if (codewords.length === 0) {\n throw FormatException.getFormatInstance();\n }\n let numECCodewords = 1 << (ecLevel + 1);\n let correctedErrorsCount = PDF417ScanningDecoder.correctErrors(codewords, erasures, numECCodewords);\n PDF417ScanningDecoder.verifyCodewordCount(codewords, numECCodewords);\n // Decode the codewords\n let decoderResult = DecodedBitStreamParser$2.decode(codewords, '' + ecLevel);\n decoderResult.setErrorsCorrected(correctedErrorsCount);\n decoderResult.setErasures(erasures.length);\n return decoderResult;\n }\n /**\n *

Given data and error-correction codewords received, possibly corrupted by errors, attempts to\n * correct the errors in-place.

\n *\n * @param codewords data and error correction codewords\n * @param erasures positions of any known erasures\n * @param numECCodewords number of error correction codewords that are available in codewords\n * @throws ChecksumException if error correction fails\n */\n static correctErrors(codewords, erasures, numECCodewords) {\n if (erasures != null &&\n erasures.length > numECCodewords / 2 + PDF417ScanningDecoder.MAX_ERRORS ||\n numECCodewords < 0 ||\n numECCodewords > PDF417ScanningDecoder.MAX_EC_CODEWORDS) {\n // Too many errors or EC Codewords is corrupted\n throw ChecksumException.getChecksumInstance();\n }\n return PDF417ScanningDecoder.errorCorrection.decode(codewords, numECCodewords, erasures);\n }\n /**\n * Verify that all is OK with the codeword array.\n * @throws FormatException\n */\n static verifyCodewordCount(codewords, numECCodewords) {\n if (codewords.length < 4) {\n // Codeword array size should be at least 4 allowing for\n // Count CW, At least one Data CW, Error Correction CW, Error Correction CW\n throw FormatException.getFormatInstance();\n }\n // The first codeword, the Symbol Length Descriptor, shall always encode the total number of data\n // codewords in the symbol, including the Symbol Length Descriptor itself, data codewords and pad\n // codewords, but excluding the number of error correction codewords.\n let numberOfCodewords = codewords[0];\n if (numberOfCodewords > codewords.length) {\n throw FormatException.getFormatInstance();\n }\n if (numberOfCodewords === 0) {\n // Reset to the length of the array - 8 (Allow for at least level 3 Error Correction (8 Error Codewords)\n if (numECCodewords < codewords.length) {\n codewords[0] = codewords.length - numECCodewords;\n }\n else {\n throw FormatException.getFormatInstance();\n }\n }\n }\n static getBitCountForCodeword(codeword) {\n let result = new Int32Array(8);\n let previousValue = 0;\n let i = result.length - 1;\n while (true) {\n if ((codeword & 0x1) !== previousValue) {\n previousValue = codeword & 0x1;\n i--;\n if (i < 0) {\n break;\n }\n }\n result[i]++;\n codeword >>= 1;\n }\n return result;\n }\n static getCodewordBucketNumber(codeword) {\n if (codeword instanceof Int32Array) {\n return this.getCodewordBucketNumber_Int32Array(codeword);\n }\n return this.getCodewordBucketNumber_number(codeword);\n }\n static getCodewordBucketNumber_number(codeword) {\n return PDF417ScanningDecoder.getCodewordBucketNumber(PDF417ScanningDecoder.getBitCountForCodeword(codeword));\n }\n static getCodewordBucketNumber_Int32Array(moduleBitCount) {\n return (moduleBitCount[0] - moduleBitCount[2] + moduleBitCount[4] - moduleBitCount[6] + 9) % 9;\n }\n static toString(barcodeMatrix) {\n let formatter = new Formatter();\n // try (let formatter = new Formatter()) {\n for (let row /*int*/ = 0; row < barcodeMatrix.length; row++) {\n formatter.format('Row %2d: ', row);\n for (let column /*int*/ = 0; column < barcodeMatrix[row].length; column++) {\n let barcodeValue = barcodeMatrix[row][column];\n if (barcodeValue.getValue().length === 0) {\n formatter.format(' ', null);\n }\n else {\n formatter.format('%4d(%2d)', barcodeValue.getValue()[0], barcodeValue.getConfidence(barcodeValue.getValue()[0]));\n }\n }\n formatter.format('%n');\n }\n return formatter.toString();\n // }\n }\n }\n /*final*/ PDF417ScanningDecoder.CODEWORD_SKEW_SIZE = 2;\n /*final*/ PDF417ScanningDecoder.MAX_ERRORS = 3;\n /*final*/ PDF417ScanningDecoder.MAX_EC_CODEWORDS = 512;\n /*final*/ PDF417ScanningDecoder.errorCorrection = new ErrorCorrection();\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // import java.util.ArrayList;\n // import java.util.List;\n // import java.util.Map;\n /**\n * This implementation can detect and decode PDF417 codes in an image.\n *\n * @author Guenther Grau\n */\n /*public final*/ class PDF417Reader {\n // private static /*final Result[]*/ EMPTY_RESULT_ARRAY: Result[] = new Result([0]);\n /**\n * Locates and decodes a PDF417 code in an image.\n *\n * @return a String representing the content encoded by the PDF417 code\n * @throws NotFoundException if a PDF417 code cannot be found,\n * @throws FormatException if a PDF417 cannot be decoded\n * @throws ChecksumException\n */\n // @Override\n decode(image, hints = null) {\n let result = PDF417Reader.decode(image, hints, false);\n if (result == null || result.length === 0 || result[0] == null) {\n throw NotFoundException.getNotFoundInstance();\n }\n return result[0];\n }\n /**\n *\n * @param BinaryBitmap\n * @param image\n * @throws NotFoundException\n */\n // @Override\n decodeMultiple(image, hints = null) {\n try {\n return PDF417Reader.decode(image, hints, true);\n }\n catch (ignored) {\n if (ignored instanceof FormatException || ignored instanceof ChecksumException) {\n throw NotFoundException.getNotFoundInstance();\n }\n throw ignored;\n }\n }\n /**\n *\n * @param image\n * @param hints\n * @param multiple\n *\n * @throws NotFoundException\n * @throws FormatExceptionß\n * @throws ChecksumException\n */\n static decode(image, hints, multiple) {\n const results = new Array();\n const detectorResult = Detector$3.detectMultiple(image, hints, multiple);\n for (const points of detectorResult.getPoints()) {\n const decoderResult = PDF417ScanningDecoder.decode(detectorResult.getBits(), points[4], points[5], points[6], points[7], PDF417Reader.getMinCodewordWidth(points), PDF417Reader.getMaxCodewordWidth(points));\n const result = new Result(decoderResult.getText(), decoderResult.getRawBytes(), undefined, points, BarcodeFormat$1.PDF_417);\n result.putMetadata(ResultMetadataType$1.ERROR_CORRECTION_LEVEL, decoderResult.getECLevel());\n const pdf417ResultMetadata = decoderResult.getOther();\n if (pdf417ResultMetadata != null) {\n result.putMetadata(ResultMetadataType$1.PDF417_EXTRA_METADATA, pdf417ResultMetadata);\n }\n results.push(result);\n }\n return results.map(x => x);\n }\n static getMaxWidth(p1, p2) {\n if (p1 == null || p2 == null) {\n return 0;\n }\n return Math.trunc(Math.abs(p1.getX() - p2.getX()));\n }\n static getMinWidth(p1, p2) {\n if (p1 == null || p2 == null) {\n return Integer.MAX_VALUE;\n }\n return Math.trunc(Math.abs(p1.getX() - p2.getX()));\n }\n static getMaxCodewordWidth(p) {\n return Math.floor(Math.max(Math.max(PDF417Reader.getMaxWidth(p[0], p[4]), PDF417Reader.getMaxWidth(p[6], p[2]) * PDF417Common.MODULES_IN_CODEWORD /\n PDF417Common.MODULES_IN_STOP_PATTERN), Math.max(PDF417Reader.getMaxWidth(p[1], p[5]), PDF417Reader.getMaxWidth(p[7], p[3]) * PDF417Common.MODULES_IN_CODEWORD /\n PDF417Common.MODULES_IN_STOP_PATTERN)));\n }\n static getMinCodewordWidth(p) {\n return Math.floor(Math.min(Math.min(PDF417Reader.getMinWidth(p[0], p[4]), PDF417Reader.getMinWidth(p[6], p[2]) * PDF417Common.MODULES_IN_CODEWORD /\n PDF417Common.MODULES_IN_STOP_PATTERN), Math.min(PDF417Reader.getMinWidth(p[1], p[5]), PDF417Reader.getMinWidth(p[7], p[3]) * PDF417Common.MODULES_IN_CODEWORD /\n PDF417Common.MODULES_IN_STOP_PATTERN)));\n }\n // @Override\n reset() {\n // nothing needs to be reset\n }\n }\n\n /**\n * Custom Error class of type Exception.\n */\n class ReaderException extends Exception {\n }\n ReaderException.kind = 'ReaderException';\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing {*/\n /**\n * MultiFormatReader is a convenience class and the main entry point into the library for most uses.\n * By default it attempts to decode all barcode formats that the library supports. Optionally, you\n * can provide a hints object to request different behavior, for example only decoding QR codes.\n *\n * @author Sean Owen\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class MultiFormatReader {\n /**\n * Creates an instance of this class\n * \n * @param {Boolean} verbose if 'true' logs will be dumped to console, otherwise hidden.\n * @param hints The hints to use, clearing the previous state.\n */\n constructor(verbose, hints) {\n this.verbose = (verbose === true);\n if (hints) {\n this.setHints(hints);\n }\n }\n /**\n * This version of decode honors the intent of Reader.decode(BinaryBitmap) in that it\n * passes null as a hint to the decoders. However, that makes it inefficient to call repeatedly.\n * Use setHints() followed by decodeWithState() for continuous scan applications.\n *\n * @param image The pixel data to decode\n * @return The contents of the image\n *\n * @throws NotFoundException Any errors which occurred\n */\n /*@Override*/\n // public decode(image: BinaryBitmap): Result {\n // setHints(null)\n // return decodeInternal(image)\n // }\n /**\n * Decode an image using the hints provided. Does not honor existing state.\n *\n * @param image The pixel data to decode\n * @param hints The hints to use, clearing the previous state.\n * @return The contents of the image\n *\n * @throws NotFoundException Any errors which occurred\n */\n /*@Override*/\n decode(image, hints) {\n if (hints) {\n this.setHints(hints);\n }\n return this.decodeInternal(image);\n }\n /**\n * Decode an image using the state set up by calling setHints() previously. Continuous scan\n * clients will get a large speed increase by using this instead of decode().\n *\n * @param image The pixel data to decode\n * @return The contents of the image\n *\n * @throws NotFoundException Any errors which occurred\n */\n decodeWithState(image) {\n // Make sure to set up the default state so we don't crash\n if (this.readers === null || this.readers === undefined) {\n this.setHints(null);\n }\n return this.decodeInternal(image);\n }\n /**\n * This method adds state to the MultiFormatReader. By setting the hints once, subsequent calls\n * to decodeWithState(image) can reuse the same set of readers without reallocating memory. This\n * is important for performance in continuous scan clients.\n *\n * @param hints The set of hints to use for subsequent calls to decode(image)\n */\n setHints(hints) {\n this.hints = hints;\n const tryHarder = hints !== null && hints !== undefined && undefined !== hints.get(DecodeHintType$1.TRY_HARDER);\n /*@SuppressWarnings(\"unchecked\")*/\n const formats = hints === null || hints === undefined ? null : hints.get(DecodeHintType$1.POSSIBLE_FORMATS);\n const readers = new Array();\n if (formats !== null && formats !== undefined) {\n const addOneDReader = formats.some(f => f === BarcodeFormat$1.UPC_A ||\n f === BarcodeFormat$1.UPC_E ||\n f === BarcodeFormat$1.EAN_13 ||\n f === BarcodeFormat$1.EAN_8 ||\n f === BarcodeFormat$1.CODABAR ||\n f === BarcodeFormat$1.CODE_39 ||\n f === BarcodeFormat$1.CODE_93 ||\n f === BarcodeFormat$1.CODE_128 ||\n f === BarcodeFormat$1.ITF ||\n f === BarcodeFormat$1.RSS_14 ||\n f === BarcodeFormat$1.RSS_EXPANDED);\n // Put 1D readers upfront in \"normal\" mode\n // TYPESCRIPTPORT: TODO: uncomment below as they are ported\n if (addOneDReader && !tryHarder) {\n readers.push(new MultiFormatOneDReader(hints, this.verbose));\n }\n if (formats.includes(BarcodeFormat$1.QR_CODE)) {\n readers.push(new QRCodeReader());\n }\n if (formats.includes(BarcodeFormat$1.DATA_MATRIX)) {\n readers.push(new DataMatrixReader());\n }\n if (formats.includes(BarcodeFormat$1.AZTEC)) {\n readers.push(new AztecReader());\n }\n if (formats.includes(BarcodeFormat$1.PDF_417)) {\n readers.push(new PDF417Reader());\n }\n // if (formats.includes(BarcodeFormat.MAXICODE)) {\n // readers.push(new MaxiCodeReader())\n // }\n // At end in \"try harder\" mode\n if (addOneDReader && tryHarder) {\n readers.push(new MultiFormatOneDReader(hints, this.verbose));\n }\n }\n if (readers.length === 0) {\n if (!tryHarder) {\n readers.push(new MultiFormatOneDReader(hints, this.verbose));\n }\n readers.push(new QRCodeReader());\n readers.push(new DataMatrixReader());\n readers.push(new AztecReader());\n readers.push(new PDF417Reader());\n // readers.push(new MaxiCodeReader())\n if (tryHarder) {\n readers.push(new MultiFormatOneDReader(hints, this.verbose));\n }\n }\n this.readers = readers; // .toArray(new Reader[readers.size()])\n }\n /*@Override*/\n reset() {\n if (this.readers !== null) {\n for (const reader of this.readers) {\n reader.reset();\n }\n }\n }\n /**\n * @throws NotFoundException\n */\n decodeInternal(image) {\n if (this.readers === null) {\n throw new ReaderException('No readers where selected, nothing can be read.');\n }\n for (const reader of this.readers) {\n // Trying to decode with ${reader} reader.\n try {\n return reader.decode(image, this.hints);\n }\n catch (ex) {\n if (ex instanceof ReaderException) {\n continue;\n }\n // Bad Exception.\n }\n }\n throw new NotFoundException('No MultiFormat Readers were able to detect the code.');\n }\n }\n\n class BrowserMultiFormatReader extends BrowserCodeReader {\n constructor(hints = null, timeBetweenScansMillis = 500) {\n const reader = new MultiFormatReader();\n reader.setHints(hints);\n super(reader, timeBetweenScansMillis);\n }\n /**\n * Overwrite decodeBitmap to call decodeWithState, which will pay\n * attention to the hints set in the constructor function\n */\n decodeBitmap(binaryBitmap) {\n return this.reader.decodeWithState(binaryBitmap);\n }\n }\n\n /**\n * @deprecated Moving to @zxing/browser\n *\n * QR Code reader to use from browser.\n */\n class BrowserPDF417Reader extends BrowserCodeReader {\n /**\n * Creates an instance of BrowserPDF417Reader.\n * @param {number} [timeBetweenScansMillis=500] the time delay between subsequent decode tries\n */\n constructor(timeBetweenScansMillis = 500) {\n super(new PDF417Reader(), timeBetweenScansMillis);\n }\n }\n\n /**\n * @deprecated Moving to @zxing/browser\n *\n * QR Code reader to use from browser.\n */\n class BrowserQRCodeReader extends BrowserCodeReader {\n /**\n * Creates an instance of BrowserQRCodeReader.\n * @param {number} [timeBetweenScansMillis=500] the time delay between subsequent decode tries\n */\n constructor(timeBetweenScansMillis = 500) {\n super(new QRCodeReader(), timeBetweenScansMillis);\n }\n }\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing {*/\n /**\n * These are a set of hints that you may pass to Writers to specify their behavior.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n var EncodeHintType;\n (function (EncodeHintType) {\n /**\n * Specifies what degree of error correction to use, for example in QR Codes.\n * Type depends on the encoder. For example for QR codes it's type\n * {@link com.google.zxing.qrcode.decoder.ErrorCorrectionLevel ErrorCorrectionLevel}.\n * For Aztec it is of type {@link Integer}, representing the minimal percentage of error correction words.\n * For PDF417 it is of type {@link Integer}, valid values being 0 to 8.\n * In all cases, it can also be a {@link String} representation of the desired value as well.\n * Note: an Aztec symbol should have a minimum of 25% EC words.\n */\n EncodeHintType[EncodeHintType[\"ERROR_CORRECTION\"] = 0] = \"ERROR_CORRECTION\";\n /**\n * Specifies what character encoding to use where applicable (type {@link String})\n */\n EncodeHintType[EncodeHintType[\"CHARACTER_SET\"] = 1] = \"CHARACTER_SET\";\n /**\n * Specifies the matrix shape for Data Matrix (type {@link com.google.zxing.datamatrix.encoder.SymbolShapeHint})\n */\n EncodeHintType[EncodeHintType[\"DATA_MATRIX_SHAPE\"] = 2] = \"DATA_MATRIX_SHAPE\";\n /**\n * Specifies a minimum barcode size (type {@link Dimension}). Only applicable to Data Matrix now.\n *\n * @deprecated use width/height params in\n * {@link com.google.zxing.datamatrix.DataMatrixWriter#encode(String, BarcodeFormat, int, int)}\n */\n /*@Deprecated*/\n EncodeHintType[EncodeHintType[\"MIN_SIZE\"] = 3] = \"MIN_SIZE\";\n /**\n * Specifies a maximum barcode size (type {@link Dimension}). Only applicable to Data Matrix now.\n *\n * @deprecated without replacement\n */\n /*@Deprecated*/\n EncodeHintType[EncodeHintType[\"MAX_SIZE\"] = 4] = \"MAX_SIZE\";\n /**\n * Specifies margin, in pixels, to use when generating the barcode. The meaning can vary\n * by format; for example it controls margin before and after the barcode horizontally for\n * most 1D formats. (Type {@link Integer}, or {@link String} representation of the integer value).\n */\n EncodeHintType[EncodeHintType[\"MARGIN\"] = 5] = \"MARGIN\";\n /**\n * Specifies whether to use compact mode for PDF417 (type {@link Boolean}, or \"true\" or \"false\"\n * {@link String} value).\n */\n EncodeHintType[EncodeHintType[\"PDF417_COMPACT\"] = 6] = \"PDF417_COMPACT\";\n /**\n * Specifies what compaction mode to use for PDF417 (type\n * {@link com.google.zxing.pdf417.encoder.Compaction Compaction} or {@link String} value of one of its\n * enum values).\n */\n EncodeHintType[EncodeHintType[\"PDF417_COMPACTION\"] = 7] = \"PDF417_COMPACTION\";\n /**\n * Specifies the minimum and maximum number of rows and columns for PDF417 (type\n * {@link com.google.zxing.pdf417.encoder.Dimensions Dimensions}).\n */\n EncodeHintType[EncodeHintType[\"PDF417_DIMENSIONS\"] = 8] = \"PDF417_DIMENSIONS\";\n /**\n * Specifies the required number of layers for an Aztec code.\n * A negative number (-1, -2, -3, -4) specifies a compact Aztec code.\n * 0 indicates to use the minimum number of layers (the default).\n * A positive number (1, 2, .. 32) specifies a normal (non-compact) Aztec code.\n * (Type {@link Integer}, or {@link String} representation of the integer value).\n */\n EncodeHintType[EncodeHintType[\"AZTEC_LAYERS\"] = 9] = \"AZTEC_LAYERS\";\n /**\n * Specifies the exact version of QR code to be encoded.\n * (Type {@link Integer}, or {@link String} representation of the integer value).\n */\n EncodeHintType[EncodeHintType[\"QR_VERSION\"] = 10] = \"QR_VERSION\";\n })(EncodeHintType || (EncodeHintType = {}));\n var EncodeHintType$1 = EncodeHintType;\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

Implements Reed-Solomon encoding, as the name implies.

\n *\n * @author Sean Owen\n * @author William Rucklidge\n */\n class ReedSolomonEncoder {\n /**\n * A reed solomon error-correcting encoding constructor is created by\n * passing as Galois Field with of size equal to the number of code\n * words (symbols) in the alphabet (the number of values in each\n * element of arrays that are encoded/decoded).\n * @param field A galois field with a number of elements equal to the size\n * of the alphabet of symbols to encode.\n */\n constructor(field) {\n this.field = field;\n this.cachedGenerators = [];\n this.cachedGenerators.push(new GenericGFPoly(field, Int32Array.from([1])));\n }\n buildGenerator(degree /*int*/) {\n const cachedGenerators = this.cachedGenerators;\n if (degree >= cachedGenerators.length) {\n let lastGenerator = cachedGenerators[cachedGenerators.length - 1];\n const field = this.field;\n for (let d = cachedGenerators.length; d <= degree; d++) {\n const nextGenerator = lastGenerator.multiply(new GenericGFPoly(field, Int32Array.from([1, field.exp(d - 1 + field.getGeneratorBase())])));\n cachedGenerators.push(nextGenerator);\n lastGenerator = nextGenerator;\n }\n }\n return cachedGenerators[degree];\n }\n /**\n *

Encode a sequence of code words (symbols) using Reed-Solomon to allow decoders\n * to detect and correct errors that may have been introduced when the resulting\n * data is stored or transmitted.

\n *\n * @param toEncode array used for both and output. Caller initializes the array with\n * the code words (symbols) to be encoded followed by empty elements allocated to make\n * space for error-correction code words in the encoded output. The array contains\n * the encdoded output when encode returns. Code words are encoded as numbers from\n * 0 to n-1, where n is the number of possible code words (symbols), as determined\n * by the size of the Galois Field passed in the constructor of this object.\n * @param ecBytes the number of elements reserved in the array (first parameter)\n * to store error-correction code words. Thus, the number of code words (symbols)\n * to encode in the first parameter is thus toEncode.length - ecBytes.\n * Note, the use of \"bytes\" in the name of this parameter is misleading, as there may\n * be more or fewer than 256 symbols being encoded, as determined by the number of\n * elements in the Galois Field passed as a constructor to this object.\n * @throws IllegalArgumentException thrown in response to validation errros.\n */\n encode(toEncode, ecBytes /*int*/) {\n if (ecBytes === 0) {\n throw new IllegalArgumentException('No error correction bytes');\n }\n const dataBytes = toEncode.length - ecBytes;\n if (dataBytes <= 0) {\n throw new IllegalArgumentException('No data bytes provided');\n }\n const generator = this.buildGenerator(ecBytes);\n const infoCoefficients = new Int32Array(dataBytes);\n System.arraycopy(toEncode, 0, infoCoefficients, 0, dataBytes);\n let info = new GenericGFPoly(this.field, infoCoefficients);\n info = info.multiplyByMonomial(ecBytes, 1);\n const remainder = info.divide(generator)[1];\n const coefficients = remainder.getCoefficients();\n const numZeroCoefficients = ecBytes - coefficients.length;\n for (let i = 0; i < numZeroCoefficients; i++) {\n toEncode[dataBytes + i] = 0;\n }\n System.arraycopy(coefficients, 0, toEncode, dataBytes + numZeroCoefficients, coefficients.length);\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author Satoru Takabayashi\n * @author Daniel Switkin\n * @author Sean Owen\n */\n class MaskUtil {\n constructor() {\n // do nothing\n }\n /**\n * Apply mask penalty rule 1 and return the penalty. Find repetitive cells with the same color and\n * give penalty to them. Example: 00000 or 11111.\n */\n static applyMaskPenaltyRule1(matrix) {\n return MaskUtil.applyMaskPenaltyRule1Internal(matrix, true) + MaskUtil.applyMaskPenaltyRule1Internal(matrix, false);\n }\n /**\n * Apply mask penalty rule 2 and return the penalty. Find 2x2 blocks with the same color and give\n * penalty to them. This is actually equivalent to the spec's rule, which is to find MxN blocks and give a\n * penalty proportional to (M-1)x(N-1), because this is the number of 2x2 blocks inside such a block.\n */\n static applyMaskPenaltyRule2(matrix) {\n let penalty = 0;\n const array = matrix.getArray();\n const width = matrix.getWidth();\n const height = matrix.getHeight();\n for (let y = 0; y < height - 1; y++) {\n const arrayY = array[y];\n for (let x = 0; x < width - 1; x++) {\n const value = arrayY[x];\n if (value === arrayY[x + 1] && value === array[y + 1][x] && value === array[y + 1][x + 1]) {\n penalty++;\n }\n }\n }\n return MaskUtil.N2 * penalty;\n }\n /**\n * Apply mask penalty rule 3 and return the penalty. Find consecutive runs of 1:1:3:1:1:4\n * starting with black, or 4:1:1:3:1:1 starting with white, and give penalty to them. If we\n * find patterns like 000010111010000, we give penalty once.\n */\n static applyMaskPenaltyRule3(matrix) {\n let numPenalties = 0;\n const array = matrix.getArray();\n const width = matrix.getWidth();\n const height = matrix.getHeight();\n for (let y = 0; y < height; y++) {\n for (let x = 0; x < width; x++) {\n const arrayY = array[y]; // We can at least optimize this access\n if (x + 6 < width &&\n arrayY[x] === 1 &&\n arrayY[x + 1] === 0 &&\n arrayY[x + 2] === 1 &&\n arrayY[x + 3] === 1 &&\n arrayY[x + 4] === 1 &&\n arrayY[x + 5] === 0 &&\n arrayY[x + 6] === 1 &&\n (MaskUtil.isWhiteHorizontal(arrayY, x - 4, x) || MaskUtil.isWhiteHorizontal(arrayY, x + 7, x + 11))) {\n numPenalties++;\n }\n if (y + 6 < height &&\n array[y][x] === 1 &&\n array[y + 1][x] === 0 &&\n array[y + 2][x] === 1 &&\n array[y + 3][x] === 1 &&\n array[y + 4][x] === 1 &&\n array[y + 5][x] === 0 &&\n array[y + 6][x] === 1 &&\n (MaskUtil.isWhiteVertical(array, x, y - 4, y) || MaskUtil.isWhiteVertical(array, x, y + 7, y + 11))) {\n numPenalties++;\n }\n }\n }\n return numPenalties * MaskUtil.N3;\n }\n static isWhiteHorizontal(rowArray, from /*int*/, to /*int*/) {\n from = Math.max(from, 0);\n to = Math.min(to, rowArray.length);\n for (let i = from; i < to; i++) {\n if (rowArray[i] === 1) {\n return false;\n }\n }\n return true;\n }\n static isWhiteVertical(array, col /*int*/, from /*int*/, to /*int*/) {\n from = Math.max(from, 0);\n to = Math.min(to, array.length);\n for (let i = from; i < to; i++) {\n if (array[i][col] === 1) {\n return false;\n }\n }\n return true;\n }\n /**\n * Apply mask penalty rule 4 and return the penalty. Calculate the ratio of dark cells and give\n * penalty if the ratio is far from 50%. It gives 10 penalty for 5% distance.\n */\n static applyMaskPenaltyRule4(matrix) {\n let numDarkCells = 0;\n const array = matrix.getArray();\n const width = matrix.getWidth();\n const height = matrix.getHeight();\n for (let y = 0; y < height; y++) {\n const arrayY = array[y];\n for (let x = 0; x < width; x++) {\n if (arrayY[x] === 1) {\n numDarkCells++;\n }\n }\n }\n const numTotalCells = matrix.getHeight() * matrix.getWidth();\n const fivePercentVariances = Math.floor(Math.abs(numDarkCells * 2 - numTotalCells) * 10 / numTotalCells);\n return fivePercentVariances * MaskUtil.N4;\n }\n /**\n * Return the mask bit for \"getMaskPattern\" at \"x\" and \"y\". See 8.8 of JISX0510:2004 for mask\n * pattern conditions.\n */\n static getDataMaskBit(maskPattern /*int*/, x /*int*/, y /*int*/) {\n let intermediate; /*int*/\n let temp; /*int*/\n switch (maskPattern) {\n case 0:\n intermediate = (y + x) & 0x1;\n break;\n case 1:\n intermediate = y & 0x1;\n break;\n case 2:\n intermediate = x % 3;\n break;\n case 3:\n intermediate = (y + x) % 3;\n break;\n case 4:\n intermediate = (Math.floor(y / 2) + Math.floor(x / 3)) & 0x1;\n break;\n case 5:\n temp = y * x;\n intermediate = (temp & 0x1) + (temp % 3);\n break;\n case 6:\n temp = y * x;\n intermediate = ((temp & 0x1) + (temp % 3)) & 0x1;\n break;\n case 7:\n temp = y * x;\n intermediate = ((temp % 3) + ((y + x) & 0x1)) & 0x1;\n break;\n default:\n throw new IllegalArgumentException('Invalid mask pattern: ' + maskPattern);\n }\n return intermediate === 0;\n }\n /**\n * Helper function for applyMaskPenaltyRule1. We need this for doing this calculation in both\n * vertical and horizontal orders respectively.\n */\n static applyMaskPenaltyRule1Internal(matrix, isHorizontal) {\n let penalty = 0;\n const iLimit = isHorizontal ? matrix.getHeight() : matrix.getWidth();\n const jLimit = isHorizontal ? matrix.getWidth() : matrix.getHeight();\n const array = matrix.getArray();\n for (let i = 0; i < iLimit; i++) {\n let numSameBitCells = 0;\n let prevBit = -1;\n for (let j = 0; j < jLimit; j++) {\n const bit = isHorizontal ? array[i][j] : array[j][i];\n if (bit === prevBit) {\n numSameBitCells++;\n }\n else {\n if (numSameBitCells >= 5) {\n penalty += MaskUtil.N1 + (numSameBitCells - 5);\n }\n numSameBitCells = 1; // Include the cell itself.\n prevBit = bit;\n }\n }\n if (numSameBitCells >= 5) {\n penalty += MaskUtil.N1 + (numSameBitCells - 5);\n }\n }\n return penalty;\n }\n }\n // Penalty weights from section 6.8.2.1\n MaskUtil.N1 = 3;\n MaskUtil.N2 = 3;\n MaskUtil.N3 = 40;\n MaskUtil.N4 = 10;\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * JAVAPORT: The original code was a 2D array of ints, but since it only ever gets assigned\n * -1, 0, and 1, I'm going to use less memory and go with bytes.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class ByteMatrix {\n constructor(width /*int*/, height /*int*/) {\n this.width = width;\n this.height = height;\n const bytes = new Array(height); // [height][width]\n for (let i = 0; i !== height; i++) {\n bytes[i] = new Uint8Array(width);\n }\n this.bytes = bytes;\n }\n getHeight() {\n return this.height;\n }\n getWidth() {\n return this.width;\n }\n get(x /*int*/, y /*int*/) {\n return this.bytes[y][x];\n }\n /**\n * @return an internal representation as bytes, in row-major order. array[y][x] represents point (x,y)\n */\n getArray() {\n return this.bytes;\n }\n // TYPESCRIPTPORT: preffer to let two methods instead of override to avoid type comparison inside\n setNumber(x /*int*/, y /*int*/, value /*byte|int*/) {\n this.bytes[y][x] = value;\n }\n // public set(x: number /*int*/, y: number /*int*/, value: number /*int*/): void {\n // bytes[y][x] = (byte) value\n // }\n setBoolean(x /*int*/, y /*int*/, value) {\n this.bytes[y][x] = /*(byte) */ (value ? 1 : 0);\n }\n clear(value /*byte*/) {\n for (const aByte of this.bytes) {\n Arrays.fill(aByte, value);\n }\n }\n equals(o) {\n if (!(o instanceof ByteMatrix)) {\n return false;\n }\n const other = o;\n if (this.width !== other.width) {\n return false;\n }\n if (this.height !== other.height) {\n return false;\n }\n for (let y = 0, height = this.height; y < height; ++y) {\n const bytesY = this.bytes[y];\n const otherBytesY = other.bytes[y];\n for (let x = 0, width = this.width; x < width; ++x) {\n if (bytesY[x] !== otherBytesY[x]) {\n return false;\n }\n }\n }\n return true;\n }\n /*@Override*/\n toString() {\n const result = new StringBuilder(); // (2 * width * height + 2)\n for (let y = 0, height = this.height; y < height; ++y) {\n const bytesY = this.bytes[y];\n for (let x = 0, width = this.width; x < width; ++x) {\n switch (bytesY[x]) {\n case 0:\n result.append(' 0');\n break;\n case 1:\n result.append(' 1');\n break;\n default:\n result.append(' ');\n break;\n }\n }\n result.append('\\n');\n }\n return result.toString();\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author satorux@google.com (Satoru Takabayashi) - creator\n * @author dswitkin@google.com (Daniel Switkin) - ported from C++\n */\n class QRCode {\n constructor() {\n this.maskPattern = -1;\n }\n getMode() {\n return this.mode;\n }\n getECLevel() {\n return this.ecLevel;\n }\n getVersion() {\n return this.version;\n }\n getMaskPattern() {\n return this.maskPattern;\n }\n getMatrix() {\n return this.matrix;\n }\n /*@Override*/\n toString() {\n const result = new StringBuilder(); // (200)\n result.append('<<\\n');\n result.append(' mode: ');\n result.append(this.mode ? this.mode.toString() : 'null');\n result.append('\\n ecLevel: ');\n result.append(this.ecLevel ? this.ecLevel.toString() : 'null');\n result.append('\\n version: ');\n result.append(this.version ? this.version.toString() : 'null');\n result.append('\\n maskPattern: ');\n result.append(this.maskPattern.toString());\n if (this.matrix) {\n result.append('\\n matrix:\\n');\n result.append(this.matrix.toString());\n }\n else {\n result.append('\\n matrix: null\\n');\n }\n result.append('>>\\n');\n return result.toString();\n }\n setMode(value) {\n this.mode = value;\n }\n setECLevel(value) {\n this.ecLevel = value;\n }\n setVersion(version) {\n this.version = version;\n }\n setMaskPattern(value /*int*/) {\n this.maskPattern = value;\n }\n setMatrix(value) {\n this.matrix = value;\n }\n // Check if \"mask_pattern\" is valid.\n static isValidMaskPattern(maskPattern /*int*/) {\n return maskPattern >= 0 && maskPattern < QRCode.NUM_MASK_PATTERNS;\n }\n }\n QRCode.NUM_MASK_PATTERNS = 8;\n\n /**\n * Custom Error class of type Exception.\n */\n class WriterException extends Exception {\n }\n WriterException.kind = 'WriterException';\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author satorux@google.com (Satoru Takabayashi) - creator\n * @author dswitkin@google.com (Daniel Switkin) - ported from C++\n */\n class MatrixUtil {\n constructor() {\n // do nothing\n }\n // Set all cells to -1 (TYPESCRIPTPORT: 255). -1 (TYPESCRIPTPORT: 255) means that the cell is empty (not set yet).\n //\n // JAVAPORT: We shouldn't need to do this at all. The code should be rewritten to begin encoding\n // with the ByteMatrix initialized all to zero.\n static clearMatrix(matrix) {\n // TYPESCRIPTPORT: we use UintArray se changed here from -1 to 255\n matrix.clear(/*(byte) */ /*-1*/ 255);\n }\n // Build 2D matrix of QR Code from \"dataBits\" with \"ecLevel\", \"version\" and \"getMaskPattern\". On\n // success, store the result in \"matrix\" and return true.\n static buildMatrix(dataBits, ecLevel, version, maskPattern /*int*/, matrix) {\n MatrixUtil.clearMatrix(matrix);\n MatrixUtil.embedBasicPatterns(version, matrix);\n // Type information appear with any version.\n MatrixUtil.embedTypeInfo(ecLevel, maskPattern, matrix);\n // Version info appear if version >= 7.\n MatrixUtil.maybeEmbedVersionInfo(version, matrix);\n // Data should be embedded at end.\n MatrixUtil.embedDataBits(dataBits, maskPattern, matrix);\n }\n // Embed basic patterns. On success, modify the matrix and return true.\n // The basic patterns are:\n // - Position detection patterns\n // - Timing patterns\n // - Dark dot at the left bottom corner\n // - Position adjustment patterns, if need be\n static embedBasicPatterns(version, matrix) {\n // Let's get started with embedding big squares at corners.\n MatrixUtil.embedPositionDetectionPatternsAndSeparators(matrix);\n // Then, embed the dark dot at the left bottom corner.\n MatrixUtil.embedDarkDotAtLeftBottomCorner(matrix);\n // Position adjustment patterns appear if version >= 2.\n MatrixUtil.maybeEmbedPositionAdjustmentPatterns(version, matrix);\n // Timing patterns should be embedded after position adj. patterns.\n MatrixUtil.embedTimingPatterns(matrix);\n }\n // Embed type information. On success, modify the matrix.\n static embedTypeInfo(ecLevel, maskPattern /*int*/, matrix) {\n const typeInfoBits = new BitArray();\n MatrixUtil.makeTypeInfoBits(ecLevel, maskPattern, typeInfoBits);\n for (let i = 0, size = typeInfoBits.getSize(); i < size; ++i) {\n // Place bits in LSB to MSB order. LSB (least significant bit) is the last value in\n // \"typeInfoBits\".\n const bit = typeInfoBits.get(typeInfoBits.getSize() - 1 - i);\n // Type info bits at the left top corner. See 8.9 of JISX0510:2004 (p.46).\n const coordinates = MatrixUtil.TYPE_INFO_COORDINATES[i];\n const x1 = coordinates[0];\n const y1 = coordinates[1];\n matrix.setBoolean(x1, y1, bit);\n if (i < 8) {\n // Right top corner.\n const x2 = matrix.getWidth() - i - 1;\n const y2 = 8;\n matrix.setBoolean(x2, y2, bit);\n }\n else {\n // Left bottom corner.\n const x2 = 8;\n const y2 = matrix.getHeight() - 7 + (i - 8);\n matrix.setBoolean(x2, y2, bit);\n }\n }\n }\n // Embed version information if need be. On success, modify the matrix and return true.\n // See 8.10 of JISX0510:2004 (p.47) for how to embed version information.\n static maybeEmbedVersionInfo(version, matrix) {\n if (version.getVersionNumber() < 7) { // Version info is necessary if version >= 7.\n return; // Don't need version info.\n }\n const versionInfoBits = new BitArray();\n MatrixUtil.makeVersionInfoBits(version, versionInfoBits);\n let bitIndex = 6 * 3 - 1; // It will decrease from 17 to 0.\n for (let i = 0; i < 6; ++i) {\n for (let j = 0; j < 3; ++j) {\n // Place bits in LSB (least significant bit) to MSB order.\n const bit = versionInfoBits.get(bitIndex);\n bitIndex--;\n // Left bottom corner.\n matrix.setBoolean(i, matrix.getHeight() - 11 + j, bit);\n // Right bottom corner.\n matrix.setBoolean(matrix.getHeight() - 11 + j, i, bit);\n }\n }\n }\n // Embed \"dataBits\" using \"getMaskPattern\". On success, modify the matrix and return true.\n // For debugging purposes, it skips masking process if \"getMaskPattern\" is -1(TYPESCRIPTPORT: 255).\n // See 8.7 of JISX0510:2004 (p.38) for how to embed data bits.\n static embedDataBits(dataBits, maskPattern /*int*/, matrix) {\n let bitIndex = 0;\n let direction = -1;\n // Start from the right bottom cell.\n let x = matrix.getWidth() - 1;\n let y = matrix.getHeight() - 1;\n while (x > 0) {\n // Skip the vertical timing pattern.\n if (x === 6) {\n x -= 1;\n }\n while (y >= 0 && y < matrix.getHeight()) {\n for (let i = 0; i < 2; ++i) {\n const xx = x - i;\n // Skip the cell if it's not empty.\n if (!MatrixUtil.isEmpty(matrix.get(xx, y))) {\n continue;\n }\n let bit;\n if (bitIndex < dataBits.getSize()) {\n bit = dataBits.get(bitIndex);\n ++bitIndex;\n }\n else {\n // Padding bit. If there is no bit left, we'll fill the left cells with 0, as described\n // in 8.4.9 of JISX0510:2004 (p. 24).\n bit = false;\n }\n // Skip masking if mask_pattern is -1 (TYPESCRIPTPORT: 255).\n if (maskPattern !== 255 && MaskUtil.getDataMaskBit(maskPattern, xx, y)) {\n bit = !bit;\n }\n matrix.setBoolean(xx, y, bit);\n }\n y += direction;\n }\n direction = -direction; // Reverse the direction.\n y += direction;\n x -= 2; // Move to the left.\n }\n // All bits should be consumed.\n if (bitIndex !== dataBits.getSize()) {\n throw new WriterException('Not all bits consumed: ' + bitIndex + '/' + dataBits.getSize());\n }\n }\n // Return the position of the most significant bit set (one: to) in the \"value\". The most\n // significant bit is position 32. If there is no bit set, return 0. Examples:\n // - findMSBSet(0) => 0\n // - findMSBSet(1) => 1\n // - findMSBSet(255) => 8\n static findMSBSet(value /*int*/) {\n return 32 - Integer.numberOfLeadingZeros(value);\n }\n // Calculate BCH (Bose-Chaudhuri-Hocquenghem) code for \"value\" using polynomial \"poly\". The BCH\n // code is used for encoding type information and version information.\n // Example: Calculation of version information of 7.\n // f(x) is created from 7.\n // - 7 = 000111 in 6 bits\n // - f(x) = x^2 + x^1 + x^0\n // g(x) is given by the standard (p. 67)\n // - g(x) = x^12 + x^11 + x^10 + x^9 + x^8 + x^5 + x^2 + 1\n // Multiply f(x) by x^(18 - 6)\n // - f'(x) = f(x) * x^(18 - 6)\n // - f'(x) = x^14 + x^13 + x^12\n // Calculate the remainder of f'(x) / g(x)\n // x^2\n // __________________________________________________\n // g(x) )x^14 + x^13 + x^12\n // x^14 + x^13 + x^12 + x^11 + x^10 + x^7 + x^4 + x^2\n // --------------------------------------------------\n // x^11 + x^10 + x^7 + x^4 + x^2\n //\n // The remainder is x^11 + x^10 + x^7 + x^4 + x^2\n // Encode it in binary: 110010010100\n // The return value is 0xc94 (1100 1001 0100)\n //\n // Since all coefficients in the polynomials are 1 or 0, we can do the calculation by bit\n // operations. We don't care if coefficients are positive or negative.\n static calculateBCHCode(value /*int*/, poly /*int*/) {\n if (poly === 0) {\n throw new IllegalArgumentException('0 polynomial');\n }\n // If poly is \"1 1111 0010 0101\" (version info poly), msbSetInPoly is 13. We'll subtract 1\n // from 13 to make it 12.\n const msbSetInPoly = MatrixUtil.findMSBSet(poly);\n value <<= msbSetInPoly - 1;\n // Do the division business using exclusive-or operations.\n while (MatrixUtil.findMSBSet(value) >= msbSetInPoly) {\n value ^= poly << (MatrixUtil.findMSBSet(value) - msbSetInPoly);\n }\n // Now the \"value\" is the remainder (i.e. the BCH code)\n return value;\n }\n // Make bit vector of type information. On success, store the result in \"bits\" and return true.\n // Encode error correction level and mask pattern. See 8.9 of\n // JISX0510:2004 (p.45) for details.\n static makeTypeInfoBits(ecLevel, maskPattern /*int*/, bits) {\n if (!QRCode.isValidMaskPattern(maskPattern)) {\n throw new WriterException('Invalid mask pattern');\n }\n const typeInfo = (ecLevel.getBits() << 3) | maskPattern;\n bits.appendBits(typeInfo, 5);\n const bchCode = MatrixUtil.calculateBCHCode(typeInfo, MatrixUtil.TYPE_INFO_POLY);\n bits.appendBits(bchCode, 10);\n const maskBits = new BitArray();\n maskBits.appendBits(MatrixUtil.TYPE_INFO_MASK_PATTERN, 15);\n bits.xor(maskBits);\n if (bits.getSize() !== 15) { // Just in case.\n throw new WriterException('should not happen but we got: ' + bits.getSize());\n }\n }\n // Make bit vector of version information. On success, store the result in \"bits\" and return true.\n // See 8.10 of JISX0510:2004 (p.45) for details.\n static makeVersionInfoBits(version, bits) {\n bits.appendBits(version.getVersionNumber(), 6);\n const bchCode = MatrixUtil.calculateBCHCode(version.getVersionNumber(), MatrixUtil.VERSION_INFO_POLY);\n bits.appendBits(bchCode, 12);\n if (bits.getSize() !== 18) { // Just in case.\n throw new WriterException('should not happen but we got: ' + bits.getSize());\n }\n }\n // Check if \"value\" is empty.\n static isEmpty(value /*int*/) {\n return value === 255; // -1\n }\n static embedTimingPatterns(matrix) {\n // -8 is for skipping position detection patterns (7: size), and two horizontal/vertical\n // separation patterns (1: size). Thus, 8 = 7 + 1.\n for (let i = 8; i < matrix.getWidth() - 8; ++i) {\n const bit = (i + 1) % 2;\n // Horizontal line.\n if (MatrixUtil.isEmpty(matrix.get(i, 6))) {\n matrix.setNumber(i, 6, bit);\n }\n // Vertical line.\n if (MatrixUtil.isEmpty(matrix.get(6, i))) {\n matrix.setNumber(6, i, bit);\n }\n }\n }\n // Embed the lonely dark dot at left bottom corner. JISX0510:2004 (p.46)\n static embedDarkDotAtLeftBottomCorner(matrix) {\n if (matrix.get(8, matrix.getHeight() - 8) === 0) {\n throw new WriterException();\n }\n matrix.setNumber(8, matrix.getHeight() - 8, 1);\n }\n static embedHorizontalSeparationPattern(xStart /*int*/, yStart /*int*/, matrix) {\n for (let x = 0; x < 8; ++x) {\n if (!MatrixUtil.isEmpty(matrix.get(xStart + x, yStart))) {\n throw new WriterException();\n }\n matrix.setNumber(xStart + x, yStart, 0);\n }\n }\n static embedVerticalSeparationPattern(xStart /*int*/, yStart /*int*/, matrix) {\n for (let y = 0; y < 7; ++y) {\n if (!MatrixUtil.isEmpty(matrix.get(xStart, yStart + y))) {\n throw new WriterException();\n }\n matrix.setNumber(xStart, yStart + y, 0);\n }\n }\n static embedPositionAdjustmentPattern(xStart /*int*/, yStart /*int*/, matrix) {\n for (let y = 0; y < 5; ++y) {\n const patternY = MatrixUtil.POSITION_ADJUSTMENT_PATTERN[y];\n for (let x = 0; x < 5; ++x) {\n matrix.setNumber(xStart + x, yStart + y, patternY[x]);\n }\n }\n }\n static embedPositionDetectionPattern(xStart /*int*/, yStart /*int*/, matrix) {\n for (let y = 0; y < 7; ++y) {\n const patternY = MatrixUtil.POSITION_DETECTION_PATTERN[y];\n for (let x = 0; x < 7; ++x) {\n matrix.setNumber(xStart + x, yStart + y, patternY[x]);\n }\n }\n }\n // Embed position detection patterns and surrounding vertical/horizontal separators.\n static embedPositionDetectionPatternsAndSeparators(matrix) {\n // Embed three big squares at corners.\n const pdpWidth = MatrixUtil.POSITION_DETECTION_PATTERN[0].length;\n // Left top corner.\n MatrixUtil.embedPositionDetectionPattern(0, 0, matrix);\n // Right top corner.\n MatrixUtil.embedPositionDetectionPattern(matrix.getWidth() - pdpWidth, 0, matrix);\n // Left bottom corner.\n MatrixUtil.embedPositionDetectionPattern(0, matrix.getWidth() - pdpWidth, matrix);\n // Embed horizontal separation patterns around the squares.\n const hspWidth = 8;\n // Left top corner.\n MatrixUtil.embedHorizontalSeparationPattern(0, hspWidth - 1, matrix);\n // Right top corner.\n MatrixUtil.embedHorizontalSeparationPattern(matrix.getWidth() - hspWidth, hspWidth - 1, matrix);\n // Left bottom corner.\n MatrixUtil.embedHorizontalSeparationPattern(0, matrix.getWidth() - hspWidth, matrix);\n // Embed vertical separation patterns around the squares.\n const vspSize = 7;\n // Left top corner.\n MatrixUtil.embedVerticalSeparationPattern(vspSize, 0, matrix);\n // Right top corner.\n MatrixUtil.embedVerticalSeparationPattern(matrix.getHeight() - vspSize - 1, 0, matrix);\n // Left bottom corner.\n MatrixUtil.embedVerticalSeparationPattern(vspSize, matrix.getHeight() - vspSize, matrix);\n }\n // Embed position adjustment patterns if need be.\n static maybeEmbedPositionAdjustmentPatterns(version, matrix) {\n if (version.getVersionNumber() < 2) { // The patterns appear if version >= 2\n return;\n }\n const index = version.getVersionNumber() - 1;\n const coordinates = MatrixUtil.POSITION_ADJUSTMENT_PATTERN_COORDINATE_TABLE[index];\n for (let i = 0, length = coordinates.length; i !== length; i++) {\n const y = coordinates[i];\n if (y >= 0) {\n for (let j = 0; j !== length; j++) {\n const x = coordinates[j];\n if (x >= 0 && MatrixUtil.isEmpty(matrix.get(x, y))) {\n // If the cell is unset, we embed the position adjustment pattern here.\n // -2 is necessary since the x/y coordinates point to the center of the pattern, not the\n // left top corner.\n MatrixUtil.embedPositionAdjustmentPattern(x - 2, y - 2, matrix);\n }\n }\n }\n }\n }\n }\n MatrixUtil.POSITION_DETECTION_PATTERN = Array.from([\n Int32Array.from([1, 1, 1, 1, 1, 1, 1]),\n Int32Array.from([1, 0, 0, 0, 0, 0, 1]),\n Int32Array.from([1, 0, 1, 1, 1, 0, 1]),\n Int32Array.from([1, 0, 1, 1, 1, 0, 1]),\n Int32Array.from([1, 0, 1, 1, 1, 0, 1]),\n Int32Array.from([1, 0, 0, 0, 0, 0, 1]),\n Int32Array.from([1, 1, 1, 1, 1, 1, 1]),\n ]);\n MatrixUtil.POSITION_ADJUSTMENT_PATTERN = Array.from([\n Int32Array.from([1, 1, 1, 1, 1]),\n Int32Array.from([1, 0, 0, 0, 1]),\n Int32Array.from([1, 0, 1, 0, 1]),\n Int32Array.from([1, 0, 0, 0, 1]),\n Int32Array.from([1, 1, 1, 1, 1]),\n ]);\n // From Appendix E. Table 1, JIS0510X:2004 (71: p). The table was double-checked by komatsu.\n MatrixUtil.POSITION_ADJUSTMENT_PATTERN_COORDINATE_TABLE = Array.from([\n Int32Array.from([-1, -1, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 18, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 22, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 26, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 30, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 34, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 22, 38, -1, -1, -1, -1]),\n Int32Array.from([6, 24, 42, -1, -1, -1, -1]),\n Int32Array.from([6, 26, 46, -1, -1, -1, -1]),\n Int32Array.from([6, 28, 50, -1, -1, -1, -1]),\n Int32Array.from([6, 30, 54, -1, -1, -1, -1]),\n Int32Array.from([6, 32, 58, -1, -1, -1, -1]),\n Int32Array.from([6, 34, 62, -1, -1, -1, -1]),\n Int32Array.from([6, 26, 46, 66, -1, -1, -1]),\n Int32Array.from([6, 26, 48, 70, -1, -1, -1]),\n Int32Array.from([6, 26, 50, 74, -1, -1, -1]),\n Int32Array.from([6, 30, 54, 78, -1, -1, -1]),\n Int32Array.from([6, 30, 56, 82, -1, -1, -1]),\n Int32Array.from([6, 30, 58, 86, -1, -1, -1]),\n Int32Array.from([6, 34, 62, 90, -1, -1, -1]),\n Int32Array.from([6, 28, 50, 72, 94, -1, -1]),\n Int32Array.from([6, 26, 50, 74, 98, -1, -1]),\n Int32Array.from([6, 30, 54, 78, 102, -1, -1]),\n Int32Array.from([6, 28, 54, 80, 106, -1, -1]),\n Int32Array.from([6, 32, 58, 84, 110, -1, -1]),\n Int32Array.from([6, 30, 58, 86, 114, -1, -1]),\n Int32Array.from([6, 34, 62, 90, 118, -1, -1]),\n Int32Array.from([6, 26, 50, 74, 98, 122, -1]),\n Int32Array.from([6, 30, 54, 78, 102, 126, -1]),\n Int32Array.from([6, 26, 52, 78, 104, 130, -1]),\n Int32Array.from([6, 30, 56, 82, 108, 134, -1]),\n Int32Array.from([6, 34, 60, 86, 112, 138, -1]),\n Int32Array.from([6, 30, 58, 86, 114, 142, -1]),\n Int32Array.from([6, 34, 62, 90, 118, 146, -1]),\n Int32Array.from([6, 30, 54, 78, 102, 126, 150]),\n Int32Array.from([6, 24, 50, 76, 102, 128, 154]),\n Int32Array.from([6, 28, 54, 80, 106, 132, 158]),\n Int32Array.from([6, 32, 58, 84, 110, 136, 162]),\n Int32Array.from([6, 26, 54, 82, 110, 138, 166]),\n Int32Array.from([6, 30, 58, 86, 114, 142, 170]),\n ]);\n // Type info cells at the left top corner.\n MatrixUtil.TYPE_INFO_COORDINATES = Array.from([\n Int32Array.from([8, 0]),\n Int32Array.from([8, 1]),\n Int32Array.from([8, 2]),\n Int32Array.from([8, 3]),\n Int32Array.from([8, 4]),\n Int32Array.from([8, 5]),\n Int32Array.from([8, 7]),\n Int32Array.from([8, 8]),\n Int32Array.from([7, 8]),\n Int32Array.from([5, 8]),\n Int32Array.from([4, 8]),\n Int32Array.from([3, 8]),\n Int32Array.from([2, 8]),\n Int32Array.from([1, 8]),\n Int32Array.from([0, 8]),\n ]);\n // From Appendix D in JISX0510:2004 (p. 67)\n MatrixUtil.VERSION_INFO_POLY = 0x1f25; // 1 1111 0010 0101\n // From Appendix C in JISX0510:2004 (p.65).\n MatrixUtil.TYPE_INFO_POLY = 0x537;\n MatrixUtil.TYPE_INFO_MASK_PATTERN = 0x5412;\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing.qrcode.encoder {*/\n class BlockPair {\n constructor(dataBytes, errorCorrectionBytes) {\n this.dataBytes = dataBytes;\n this.errorCorrectionBytes = errorCorrectionBytes;\n }\n getDataBytes() {\n return this.dataBytes;\n }\n getErrorCorrectionBytes() {\n return this.errorCorrectionBytes;\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.io.UnsupportedEncodingException;*/\n /*import java.util.ArrayList;*/\n /*import java.util.Collection;*/\n /*import java.util.Map;*/\n /**\n * @author satorux@google.com (Satoru Takabayashi) - creator\n * @author dswitkin@google.com (Daniel Switkin) - ported from C++\n */\n class Encoder {\n // TYPESCRIPTPORT: changed to UTF8, the default for js\n constructor() { }\n // The mask penalty calculation is complicated. See Table 21 of JISX0510:2004 (p.45) for details.\n // Basically it applies four rules and summate all penalties.\n static calculateMaskPenalty(matrix) {\n return MaskUtil.applyMaskPenaltyRule1(matrix)\n + MaskUtil.applyMaskPenaltyRule2(matrix)\n + MaskUtil.applyMaskPenaltyRule3(matrix)\n + MaskUtil.applyMaskPenaltyRule4(matrix);\n }\n /**\n * @param content text to encode\n * @param ecLevel error correction level to use\n * @return {@link QRCode} representing the encoded QR code\n * @throws WriterException if encoding can't succeed, because of for example invalid content\n * or configuration\n */\n // public static encode(content: string, ecLevel: ErrorCorrectionLevel): QRCode /*throws WriterException*/ {\n // return encode(content, ecLevel, null)\n // }\n static encode(content, ecLevel, hints = null) {\n // Determine what character encoding has been specified by the caller, if any\n let encoding = Encoder.DEFAULT_BYTE_MODE_ENCODING;\n const hasEncodingHint = hints !== null && undefined !== hints.get(EncodeHintType$1.CHARACTER_SET);\n if (hasEncodingHint) {\n encoding = hints.get(EncodeHintType$1.CHARACTER_SET).toString();\n }\n // Pick an encoding mode appropriate for the content. Note that this will not attempt to use\n // multiple modes / segments even if that were more efficient. Twould be nice.\n const mode = this.chooseMode(content, encoding);\n // This will store the header information, like mode and\n // length, as well as \"header\" segments like an ECI segment.\n const headerBits = new BitArray();\n // Append ECI segment if applicable\n if (mode === Mode$1.BYTE && (hasEncodingHint || Encoder.DEFAULT_BYTE_MODE_ENCODING !== encoding)) {\n const eci = CharacterSetECI.getCharacterSetECIByName(encoding);\n if (eci !== undefined) {\n this.appendECI(eci, headerBits);\n }\n }\n // (With ECI in place,) Write the mode marker\n this.appendModeInfo(mode, headerBits);\n // Collect data within the main segment, separately, to count its size if needed. Don't add it to\n // main payload yet.\n const dataBits = new BitArray();\n this.appendBytes(content, mode, dataBits, encoding);\n let version;\n if (hints !== null && undefined !== hints.get(EncodeHintType$1.QR_VERSION)) {\n const versionNumber = Number.parseInt(hints.get(EncodeHintType$1.QR_VERSION).toString(), 10);\n version = Version$1.getVersionForNumber(versionNumber);\n const bitsNeeded = this.calculateBitsNeeded(mode, headerBits, dataBits, version);\n if (!this.willFit(bitsNeeded, version, ecLevel)) {\n throw new WriterException('Data too big for requested version');\n }\n }\n else {\n version = this.recommendVersion(ecLevel, mode, headerBits, dataBits);\n }\n const headerAndDataBits = new BitArray();\n headerAndDataBits.appendBitArray(headerBits);\n // Find \"length\" of main segment and write it\n const numLetters = mode === Mode$1.BYTE ? dataBits.getSizeInBytes() : content.length;\n this.appendLengthInfo(numLetters, version, mode, headerAndDataBits);\n // Put data together into the overall payload\n headerAndDataBits.appendBitArray(dataBits);\n const ecBlocks = version.getECBlocksForLevel(ecLevel);\n const numDataBytes = version.getTotalCodewords() - ecBlocks.getTotalECCodewords();\n // Terminate the bits properly.\n this.terminateBits(numDataBytes, headerAndDataBits);\n // Interleave data bits with error correction code.\n const finalBits = this.interleaveWithECBytes(headerAndDataBits, version.getTotalCodewords(), numDataBytes, ecBlocks.getNumBlocks());\n const qrCode = new QRCode();\n qrCode.setECLevel(ecLevel);\n qrCode.setMode(mode);\n qrCode.setVersion(version);\n // Choose the mask pattern and set to \"qrCode\".\n const dimension = version.getDimensionForVersion();\n const matrix = new ByteMatrix(dimension, dimension);\n const maskPattern = this.chooseMaskPattern(finalBits, ecLevel, version, matrix);\n qrCode.setMaskPattern(maskPattern);\n // Build the matrix and set it to \"qrCode\".\n MatrixUtil.buildMatrix(finalBits, ecLevel, version, maskPattern, matrix);\n qrCode.setMatrix(matrix);\n return qrCode;\n }\n /**\n * Decides the smallest version of QR code that will contain all of the provided data.\n *\n * @throws WriterException if the data cannot fit in any version\n */\n static recommendVersion(ecLevel, mode, headerBits, dataBits) {\n // Hard part: need to know version to know how many bits length takes. But need to know how many\n // bits it takes to know version. First we take a guess at version by assuming version will be\n // the minimum, 1:\n const provisionalBitsNeeded = this.calculateBitsNeeded(mode, headerBits, dataBits, Version$1.getVersionForNumber(1));\n const provisionalVersion = this.chooseVersion(provisionalBitsNeeded, ecLevel);\n // Use that guess to calculate the right version. I am still not sure this works in 100% of cases.\n const bitsNeeded = this.calculateBitsNeeded(mode, headerBits, dataBits, provisionalVersion);\n return this.chooseVersion(bitsNeeded, ecLevel);\n }\n static calculateBitsNeeded(mode, headerBits, dataBits, version) {\n return headerBits.getSize() + mode.getCharacterCountBits(version) + dataBits.getSize();\n }\n /**\n * @return the code point of the table used in alphanumeric mode or\n * -1 if there is no corresponding code in the table.\n */\n static getAlphanumericCode(code /*int*/) {\n if (code < Encoder.ALPHANUMERIC_TABLE.length) {\n return Encoder.ALPHANUMERIC_TABLE[code];\n }\n return -1;\n }\n // public static chooseMode(content: string): Mode {\n // return chooseMode(content, null);\n // }\n /**\n * Choose the best mode by examining the content. Note that 'encoding' is used as a hint;\n * if it is Shift_JIS, and the input is only double-byte Kanji, then we return {@link Mode#KANJI}.\n */\n static chooseMode(content, encoding = null) {\n if (CharacterSetECI.SJIS.getName() === encoding && this.isOnlyDoubleByteKanji(content)) {\n // Choose Kanji mode if all input are double-byte characters\n return Mode$1.KANJI;\n }\n let hasNumeric = false;\n let hasAlphanumeric = false;\n for (let i = 0, length = content.length; i < length; ++i) {\n const c = content.charAt(i);\n if (Encoder.isDigit(c)) {\n hasNumeric = true;\n }\n else if (this.getAlphanumericCode(c.charCodeAt(0)) !== -1) {\n hasAlphanumeric = true;\n }\n else {\n return Mode$1.BYTE;\n }\n }\n if (hasAlphanumeric) {\n return Mode$1.ALPHANUMERIC;\n }\n if (hasNumeric) {\n return Mode$1.NUMERIC;\n }\n return Mode$1.BYTE;\n }\n static isOnlyDoubleByteKanji(content) {\n let bytes;\n try {\n bytes = StringEncoding.encode(content, CharacterSetECI.SJIS); // content.getBytes(\"Shift_JIS\"))\n }\n catch (ignored /*: UnsupportedEncodingException*/) {\n return false;\n }\n const length = bytes.length;\n if (length % 2 !== 0) {\n return false;\n }\n for (let i = 0; i < length; i += 2) {\n const byte1 = bytes[i] & 0xFF;\n if ((byte1 < 0x81 || byte1 > 0x9F) && (byte1 < 0xE0 || byte1 > 0xEB)) {\n return false;\n }\n }\n return true;\n }\n static chooseMaskPattern(bits, ecLevel, version, matrix) {\n let minPenalty = Number.MAX_SAFE_INTEGER; // Lower penalty is better.\n let bestMaskPattern = -1;\n // We try all mask patterns to choose the best one.\n for (let maskPattern = 0; maskPattern < QRCode.NUM_MASK_PATTERNS; maskPattern++) {\n MatrixUtil.buildMatrix(bits, ecLevel, version, maskPattern, matrix);\n let penalty = this.calculateMaskPenalty(matrix);\n if (penalty < minPenalty) {\n minPenalty = penalty;\n bestMaskPattern = maskPattern;\n }\n }\n return bestMaskPattern;\n }\n static chooseVersion(numInputBits /*int*/, ecLevel) {\n for (let versionNum = 1; versionNum <= 40; versionNum++) {\n const version = Version$1.getVersionForNumber(versionNum);\n if (Encoder.willFit(numInputBits, version, ecLevel)) {\n return version;\n }\n }\n throw new WriterException('Data too big');\n }\n /**\n * @return true if the number of input bits will fit in a code with the specified version and\n * error correction level.\n */\n static willFit(numInputBits /*int*/, version, ecLevel) {\n // In the following comments, we use numbers of Version 7-H.\n // numBytes = 196\n const numBytes = version.getTotalCodewords();\n // getNumECBytes = 130\n const ecBlocks = version.getECBlocksForLevel(ecLevel);\n const numEcBytes = ecBlocks.getTotalECCodewords();\n // getNumDataBytes = 196 - 130 = 66\n const numDataBytes = numBytes - numEcBytes;\n const totalInputBytes = (numInputBits + 7) / 8;\n return numDataBytes >= totalInputBytes;\n }\n /**\n * Terminate bits as described in 8.4.8 and 8.4.9 of JISX0510:2004 (p.24).\n */\n static terminateBits(numDataBytes /*int*/, bits) {\n const capacity = numDataBytes * 8;\n if (bits.getSize() > capacity) {\n throw new WriterException('data bits cannot fit in the QR Code' + bits.getSize() + ' > ' +\n capacity);\n }\n for (let i = 0; i < 4 && bits.getSize() < capacity; ++i) {\n bits.appendBit(false);\n }\n // Append termination bits. See 8.4.8 of JISX0510:2004 (p.24) for details.\n // If the last byte isn't 8-bit aligned, we'll add padding bits.\n const numBitsInLastByte = bits.getSize() & 0x07;\n if (numBitsInLastByte > 0) {\n for (let i = numBitsInLastByte; i < 8; i++) {\n bits.appendBit(false);\n }\n }\n // If we have more space, we'll fill the space with padding patterns defined in 8.4.9 (p.24).\n const numPaddingBytes = numDataBytes - bits.getSizeInBytes();\n for (let i = 0; i < numPaddingBytes; ++i) {\n bits.appendBits((i & 0x01) === 0 ? 0xEC : 0x11, 8);\n }\n if (bits.getSize() !== capacity) {\n throw new WriterException('Bits size does not equal capacity');\n }\n }\n /**\n * Get number of data bytes and number of error correction bytes for block id \"blockID\". Store\n * the result in \"numDataBytesInBlock\", and \"numECBytesInBlock\". See table 12 in 8.5.1 of\n * JISX0510:2004 (p.30)\n */\n static getNumDataBytesAndNumECBytesForBlockID(numTotalBytes /*int*/, numDataBytes /*int*/, numRSBlocks /*int*/, blockID /*int*/, numDataBytesInBlock, numECBytesInBlock) {\n if (blockID >= numRSBlocks) {\n throw new WriterException('Block ID too large');\n }\n // numRsBlocksInGroup2 = 196 % 5 = 1\n const numRsBlocksInGroup2 = numTotalBytes % numRSBlocks;\n // numRsBlocksInGroup1 = 5 - 1 = 4\n const numRsBlocksInGroup1 = numRSBlocks - numRsBlocksInGroup2;\n // numTotalBytesInGroup1 = 196 / 5 = 39\n const numTotalBytesInGroup1 = Math.floor(numTotalBytes / numRSBlocks);\n // numTotalBytesInGroup2 = 39 + 1 = 40\n const numTotalBytesInGroup2 = numTotalBytesInGroup1 + 1;\n // numDataBytesInGroup1 = 66 / 5 = 13\n const numDataBytesInGroup1 = Math.floor(numDataBytes / numRSBlocks);\n // numDataBytesInGroup2 = 13 + 1 = 14\n const numDataBytesInGroup2 = numDataBytesInGroup1 + 1;\n // numEcBytesInGroup1 = 39 - 13 = 26\n const numEcBytesInGroup1 = numTotalBytesInGroup1 - numDataBytesInGroup1;\n // numEcBytesInGroup2 = 40 - 14 = 26\n const numEcBytesInGroup2 = numTotalBytesInGroup2 - numDataBytesInGroup2;\n // Sanity checks.\n // 26 = 26\n if (numEcBytesInGroup1 !== numEcBytesInGroup2) {\n throw new WriterException('EC bytes mismatch');\n }\n // 5 = 4 + 1.\n if (numRSBlocks !== numRsBlocksInGroup1 + numRsBlocksInGroup2) {\n throw new WriterException('RS blocks mismatch');\n }\n // 196 = (13 + 26) * 4 + (14 + 26) * 1\n if (numTotalBytes !==\n ((numDataBytesInGroup1 + numEcBytesInGroup1) *\n numRsBlocksInGroup1) +\n ((numDataBytesInGroup2 + numEcBytesInGroup2) *\n numRsBlocksInGroup2)) {\n throw new WriterException('Total bytes mismatch');\n }\n if (blockID < numRsBlocksInGroup1) {\n numDataBytesInBlock[0] = numDataBytesInGroup1;\n numECBytesInBlock[0] = numEcBytesInGroup1;\n }\n else {\n numDataBytesInBlock[0] = numDataBytesInGroup2;\n numECBytesInBlock[0] = numEcBytesInGroup2;\n }\n }\n /**\n * Interleave \"bits\" with corresponding error correction bytes. On success, store the result in\n * \"result\". The interleave rule is complicated. See 8.6 of JISX0510:2004 (p.37) for details.\n */\n static interleaveWithECBytes(bits, numTotalBytes /*int*/, numDataBytes /*int*/, numRSBlocks /*int*/) {\n // \"bits\" must have \"getNumDataBytes\" bytes of data.\n if (bits.getSizeInBytes() !== numDataBytes) {\n throw new WriterException('Number of bits and data bytes does not match');\n }\n // Step 1. Divide data bytes into blocks and generate error correction bytes for them. We'll\n // store the divided data bytes blocks and error correction bytes blocks into \"blocks\".\n let dataBytesOffset = 0;\n let maxNumDataBytes = 0;\n let maxNumEcBytes = 0;\n // Since, we know the number of reedsolmon blocks, we can initialize the vector with the number.\n const blocks = new Array(); // new Array(numRSBlocks)\n for (let i = 0; i < numRSBlocks; ++i) {\n const numDataBytesInBlock = new Int32Array(1);\n const numEcBytesInBlock = new Int32Array(1);\n Encoder.getNumDataBytesAndNumECBytesForBlockID(numTotalBytes, numDataBytes, numRSBlocks, i, numDataBytesInBlock, numEcBytesInBlock);\n const size = numDataBytesInBlock[0];\n const dataBytes = new Uint8Array(size);\n bits.toBytes(8 * dataBytesOffset, dataBytes, 0, size);\n const ecBytes = Encoder.generateECBytes(dataBytes, numEcBytesInBlock[0]);\n blocks.push(new BlockPair(dataBytes, ecBytes));\n maxNumDataBytes = Math.max(maxNumDataBytes, size);\n maxNumEcBytes = Math.max(maxNumEcBytes, ecBytes.length);\n dataBytesOffset += numDataBytesInBlock[0];\n }\n if (numDataBytes !== dataBytesOffset) {\n throw new WriterException('Data bytes does not match offset');\n }\n const result = new BitArray();\n // First, place data blocks.\n for (let i = 0; i < maxNumDataBytes; ++i) {\n for (const block of blocks) {\n const dataBytes = block.getDataBytes();\n if (i < dataBytes.length) {\n result.appendBits(dataBytes[i], 8);\n }\n }\n }\n // Then, place error correction blocks.\n for (let i = 0; i < maxNumEcBytes; ++i) {\n for (const block of blocks) {\n const ecBytes = block.getErrorCorrectionBytes();\n if (i < ecBytes.length) {\n result.appendBits(ecBytes[i], 8);\n }\n }\n }\n if (numTotalBytes !== result.getSizeInBytes()) { // Should be same.\n throw new WriterException('Interleaving error: ' + numTotalBytes + ' and ' +\n result.getSizeInBytes() + ' differ.');\n }\n return result;\n }\n static generateECBytes(dataBytes, numEcBytesInBlock /*int*/) {\n const numDataBytes = dataBytes.length;\n const toEncode = new Int32Array(numDataBytes + numEcBytesInBlock); // int[numDataBytes + numEcBytesInBlock]\n for (let i = 0; i < numDataBytes; i++) {\n toEncode[i] = dataBytes[i] & 0xFF;\n }\n new ReedSolomonEncoder(GenericGF.QR_CODE_FIELD_256).encode(toEncode, numEcBytesInBlock);\n const ecBytes = new Uint8Array(numEcBytesInBlock);\n for (let i = 0; i < numEcBytesInBlock; i++) {\n ecBytes[i] = /*(byte) */ toEncode[numDataBytes + i];\n }\n return ecBytes;\n }\n /**\n * Append mode info. On success, store the result in \"bits\".\n */\n static appendModeInfo(mode, bits) {\n bits.appendBits(mode.getBits(), 4);\n }\n /**\n * Append length info. On success, store the result in \"bits\".\n */\n static appendLengthInfo(numLetters /*int*/, version, mode, bits) {\n const numBits = mode.getCharacterCountBits(version);\n if (numLetters >= (1 << numBits)) {\n throw new WriterException(numLetters + ' is bigger than ' + ((1 << numBits) - 1));\n }\n bits.appendBits(numLetters, numBits);\n }\n /**\n * Append \"bytes\" in \"mode\" mode (encoding) into \"bits\". On success, store the result in \"bits\".\n */\n static appendBytes(content, mode, bits, encoding) {\n switch (mode) {\n case Mode$1.NUMERIC:\n Encoder.appendNumericBytes(content, bits);\n break;\n case Mode$1.ALPHANUMERIC:\n Encoder.appendAlphanumericBytes(content, bits);\n break;\n case Mode$1.BYTE:\n Encoder.append8BitBytes(content, bits, encoding);\n break;\n case Mode$1.KANJI:\n Encoder.appendKanjiBytes(content, bits);\n break;\n default:\n throw new WriterException('Invalid mode: ' + mode);\n }\n }\n static getDigit(singleCharacter) {\n return singleCharacter.charCodeAt(0) - 48;\n }\n static isDigit(singleCharacter) {\n const cn = Encoder.getDigit(singleCharacter);\n return cn >= 0 && cn <= 9;\n }\n static appendNumericBytes(content, bits) {\n const length = content.length;\n let i = 0;\n while (i < length) {\n const num1 = Encoder.getDigit(content.charAt(i));\n if (i + 2 < length) {\n // Encode three numeric letters in ten bits.\n const num2 = Encoder.getDigit(content.charAt(i + 1));\n const num3 = Encoder.getDigit(content.charAt(i + 2));\n bits.appendBits(num1 * 100 + num2 * 10 + num3, 10);\n i += 3;\n }\n else if (i + 1 < length) {\n // Encode two numeric letters in seven bits.\n const num2 = Encoder.getDigit(content.charAt(i + 1));\n bits.appendBits(num1 * 10 + num2, 7);\n i += 2;\n }\n else {\n // Encode one numeric letter in four bits.\n bits.appendBits(num1, 4);\n i++;\n }\n }\n }\n static appendAlphanumericBytes(content, bits) {\n const length = content.length;\n let i = 0;\n while (i < length) {\n const code1 = Encoder.getAlphanumericCode(content.charCodeAt(i));\n if (code1 === -1) {\n throw new WriterException();\n }\n if (i + 1 < length) {\n const code2 = Encoder.getAlphanumericCode(content.charCodeAt(i + 1));\n if (code2 === -1) {\n throw new WriterException();\n }\n // Encode two alphanumeric letters in 11 bits.\n bits.appendBits(code1 * 45 + code2, 11);\n i += 2;\n }\n else {\n // Encode one alphanumeric letter in six bits.\n bits.appendBits(code1, 6);\n i++;\n }\n }\n }\n static append8BitBytes(content, bits, encoding) {\n let bytes;\n try {\n bytes = StringEncoding.encode(content, encoding);\n }\n catch (uee /*: UnsupportedEncodingException*/) {\n throw new WriterException(uee);\n }\n for (let i = 0, length = bytes.length; i !== length; i++) {\n const b = bytes[i];\n bits.appendBits(b, 8);\n }\n }\n /**\n * @throws WriterException\n */\n static appendKanjiBytes(content, bits) {\n let bytes;\n try {\n bytes = StringEncoding.encode(content, CharacterSetECI.SJIS);\n }\n catch (uee /*: UnsupportedEncodingException*/) {\n throw new WriterException(uee);\n }\n const length = bytes.length;\n for (let i = 0; i < length; i += 2) {\n const byte1 = bytes[i] & 0xFF;\n const byte2 = bytes[i + 1] & 0xFF;\n const code = ((byte1 << 8) & 0xFFFFFFFF) | byte2;\n let subtracted = -1;\n if (code >= 0x8140 && code <= 0x9ffc) {\n subtracted = code - 0x8140;\n }\n else if (code >= 0xe040 && code <= 0xebbf) {\n subtracted = code - 0xc140;\n }\n if (subtracted === -1) {\n throw new WriterException('Invalid byte sequence');\n }\n const encoded = ((subtracted >> 8) * 0xc0) + (subtracted & 0xff);\n bits.appendBits(encoded, 13);\n }\n }\n static appendECI(eci, bits) {\n bits.appendBits(Mode$1.ECI.getBits(), 4);\n // This is correct for values up to 127, which is all we need now.\n bits.appendBits(eci.getValue(), 8);\n }\n }\n // The original table is defined in the table 5 of JISX0510:2004 (p.19).\n Encoder.ALPHANUMERIC_TABLE = Int32Array.from([\n -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,\n -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,\n 36, -1, -1, -1, 37, 38, -1, -1, -1, -1, 39, 40, -1, 41, 42, 43,\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 44, -1, -1, -1, -1, -1,\n -1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24,\n 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, -1, -1, -1, -1, -1,\n ]);\n Encoder.DEFAULT_BYTE_MODE_ENCODING = CharacterSetECI.UTF8.getName(); // \"ISO-8859-1\"\n\n /**\n * @deprecated Moving to @zxing/browser\n */\n class BrowserQRCodeSvgWriter {\n /**\n * Writes and renders a QRCode SVG element.\n *\n * @param contents\n * @param width\n * @param height\n * @param hints\n */\n write(contents, width, height, hints = null) {\n if (contents.length === 0) {\n throw new IllegalArgumentException('Found empty contents');\n }\n // if (format != BarcodeFormat.QR_CODE) {\n // throw new IllegalArgumentException(\"Can only encode QR_CODE, but got \" + format)\n // }\n if (width < 0 || height < 0) {\n throw new IllegalArgumentException('Requested dimensions are too small: ' + width + 'x' + height);\n }\n let errorCorrectionLevel = ErrorCorrectionLevel.L;\n let quietZone = BrowserQRCodeSvgWriter.QUIET_ZONE_SIZE;\n if (hints !== null) {\n if (undefined !== hints.get(EncodeHintType$1.ERROR_CORRECTION)) {\n errorCorrectionLevel = ErrorCorrectionLevel.fromString(hints.get(EncodeHintType$1.ERROR_CORRECTION).toString());\n }\n if (undefined !== hints.get(EncodeHintType$1.MARGIN)) {\n quietZone = Number.parseInt(hints.get(EncodeHintType$1.MARGIN).toString(), 10);\n }\n }\n const code = Encoder.encode(contents, errorCorrectionLevel, hints);\n return this.renderResult(code, width, height, quietZone);\n }\n /**\n * Renders the result and then appends it to the DOM.\n */\n writeToDom(containerElement, contents, width, height, hints = null) {\n if (typeof containerElement === 'string') {\n containerElement = document.querySelector(containerElement);\n }\n const svgElement = this.write(contents, width, height, hints);\n if (containerElement)\n containerElement.appendChild(svgElement);\n }\n /**\n * Note that the input matrix uses 0 == white, 1 == black.\n * The output matrix uses 0 == black, 255 == white (i.e. an 8 bit greyscale bitmap).\n */\n renderResult(code, width /*int*/, height /*int*/, quietZone /*int*/) {\n const input = code.getMatrix();\n if (input === null) {\n throw new IllegalStateException();\n }\n const inputWidth = input.getWidth();\n const inputHeight = input.getHeight();\n const qrWidth = inputWidth + (quietZone * 2);\n const qrHeight = inputHeight + (quietZone * 2);\n const outputWidth = Math.max(width, qrWidth);\n const outputHeight = Math.max(height, qrHeight);\n const multiple = Math.min(Math.floor(outputWidth / qrWidth), Math.floor(outputHeight / qrHeight));\n // Padding includes both the quiet zone and the extra white pixels to accommodate the requested\n // dimensions. For example, if input is 25x25 the QR will be 33x33 including the quiet zone.\n // If the requested size is 200x160, the multiple will be 4, for a QR of 132x132. These will\n // handle all the padding from 100x100 (the actual QR) up to 200x160.\n const leftPadding = Math.floor((outputWidth - (inputWidth * multiple)) / 2);\n const topPadding = Math.floor((outputHeight - (inputHeight * multiple)) / 2);\n const svgElement = this.createSVGElement(outputWidth, outputHeight);\n for (let inputY = 0, outputY = topPadding; inputY < inputHeight; inputY++, outputY += multiple) {\n // Write the contents of this row of the barcode\n for (let inputX = 0, outputX = leftPadding; inputX < inputWidth; inputX++, outputX += multiple) {\n if (input.get(inputX, inputY) === 1) {\n const svgRectElement = this.createSvgRectElement(outputX, outputY, multiple, multiple);\n svgElement.appendChild(svgRectElement);\n }\n }\n }\n return svgElement;\n }\n /**\n * Creates a SVG element.\n *\n * @param w SVG's width attribute\n * @param h SVG's height attribute\n */\n createSVGElement(w, h) {\n const svgElement = document.createElementNS(BrowserQRCodeSvgWriter.SVG_NS, 'svg');\n svgElement.setAttributeNS(null, 'height', w.toString());\n svgElement.setAttributeNS(null, 'width', h.toString());\n return svgElement;\n }\n /**\n * Creates a SVG rect element.\n *\n * @param x Element's x coordinate\n * @param y Element's y coordinate\n * @param w Element's width attribute\n * @param h Element's height attribute\n */\n createSvgRectElement(x, y, w, h) {\n const rect = document.createElementNS(BrowserQRCodeSvgWriter.SVG_NS, 'rect');\n rect.setAttributeNS(null, 'x', x.toString());\n rect.setAttributeNS(null, 'y', y.toString());\n rect.setAttributeNS(null, 'height', w.toString());\n rect.setAttributeNS(null, 'width', h.toString());\n rect.setAttributeNS(null, 'fill', '#000000');\n return rect;\n }\n }\n BrowserQRCodeSvgWriter.QUIET_ZONE_SIZE = 4;\n /**\n * SVG markup NameSpace\n */\n BrowserQRCodeSvgWriter.SVG_NS = 'http://www.w3.org/2000/svg';\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.util.Map;*/\n /**\n * This object renders a QR Code as a BitMatrix 2D array of greyscale values.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class QRCodeWriter {\n /*@Override*/\n // public encode(contents: string, format: BarcodeFormat, width: number /*int*/, height: number /*int*/): BitMatrix\n // /*throws WriterException */ {\n // return encode(contents, format, width, height, null)\n // }\n /*@Override*/\n encode(contents, format, width /*int*/, height /*int*/, hints) {\n if (contents.length === 0) {\n throw new IllegalArgumentException('Found empty contents');\n }\n if (format !== BarcodeFormat$1.QR_CODE) {\n throw new IllegalArgumentException('Can only encode QR_CODE, but got ' + format);\n }\n if (width < 0 || height < 0) {\n throw new IllegalArgumentException(`Requested dimensions are too small: ${width}x${height}`);\n }\n let errorCorrectionLevel = ErrorCorrectionLevel.L;\n let quietZone = QRCodeWriter.QUIET_ZONE_SIZE;\n if (hints !== null) {\n if (undefined !== hints.get(EncodeHintType$1.ERROR_CORRECTION)) {\n errorCorrectionLevel = ErrorCorrectionLevel.fromString(hints.get(EncodeHintType$1.ERROR_CORRECTION).toString());\n }\n if (undefined !== hints.get(EncodeHintType$1.MARGIN)) {\n quietZone = Number.parseInt(hints.get(EncodeHintType$1.MARGIN).toString(), 10);\n }\n }\n const code = Encoder.encode(contents, errorCorrectionLevel, hints);\n return QRCodeWriter.renderResult(code, width, height, quietZone);\n }\n // Note that the input matrix uses 0 == white, 1 == black, while the output matrix uses\n // 0 == black, 255 == white (i.e. an 8 bit greyscale bitmap).\n static renderResult(code, width /*int*/, height /*int*/, quietZone /*int*/) {\n const input = code.getMatrix();\n if (input === null) {\n throw new IllegalStateException();\n }\n const inputWidth = input.getWidth();\n const inputHeight = input.getHeight();\n const qrWidth = inputWidth + (quietZone * 2);\n const qrHeight = inputHeight + (quietZone * 2);\n const outputWidth = Math.max(width, qrWidth);\n const outputHeight = Math.max(height, qrHeight);\n const multiple = Math.min(Math.floor(outputWidth / qrWidth), Math.floor(outputHeight / qrHeight));\n // Padding includes both the quiet zone and the extra white pixels to accommodate the requested\n // dimensions. For example, if input is 25x25 the QR will be 33x33 including the quiet zone.\n // If the requested size is 200x160, the multiple will be 4, for a QR of 132x132. These will\n // handle all the padding from 100x100 (the actual QR) up to 200x160.\n const leftPadding = Math.floor((outputWidth - (inputWidth * multiple)) / 2);\n const topPadding = Math.floor((outputHeight - (inputHeight * multiple)) / 2);\n const output = new BitMatrix(outputWidth, outputHeight);\n for (let inputY = 0, outputY = topPadding; inputY < inputHeight; inputY++, outputY += multiple) {\n // Write the contents of this row of the barcode\n for (let inputX = 0, outputX = leftPadding; inputX < inputWidth; inputX++, outputX += multiple) {\n if (input.get(inputX, inputY) === 1) {\n output.setRegion(outputX, outputY, multiple, multiple);\n }\n }\n }\n return output;\n }\n }\n QRCodeWriter.QUIET_ZONE_SIZE = 4;\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.util.Map;*/\n /**\n * This is a factory class which finds the appropriate Writer subclass for the BarcodeFormat\n * requested and encodes the barcode with the supplied contents.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class MultiFormatWriter {\n /*@Override*/\n // public encode(contents: string,\n // format: BarcodeFormat,\n // width: number /*int*/,\n // height: number /*int*/): BitMatrix /*throws WriterException */ {\n // return encode(contents, format, width, height, null)\n // }\n /*@Override*/\n encode(contents, format, width /*int*/, height /*int*/, hints) {\n let writer;\n switch (format) {\n // case BarcodeFormat.EAN_8:\n // writer = new EAN8Writer()\n // break\n // case BarcodeFormat.UPC_E:\n // writer = new UPCEWriter()\n // break\n // case BarcodeFormat.EAN_13:\n // writer = new EAN13Writer()\n // break\n // case BarcodeFormat.UPC_A:\n // writer = new UPCAWriter()\n // break\n case BarcodeFormat$1.QR_CODE:\n writer = new QRCodeWriter();\n break;\n // case BarcodeFormat.CODE_39:\n // writer = new Code39Writer()\n // break\n // case BarcodeFormat.CODE_93:\n // writer = new Code93Writer()\n // break\n // case BarcodeFormat.CODE_128:\n // writer = new Code128Writer()\n // break\n // case BarcodeFormat.ITF:\n // writer = new ITFWriter()\n // break\n // case BarcodeFormat.PDF_417:\n // writer = new PDF417Writer()\n // break\n // case BarcodeFormat.CODABAR:\n // writer = new CodaBarWriter()\n // break\n // case BarcodeFormat.DATA_MATRIX:\n // writer = new DataMatrixWriter()\n // break\n // case BarcodeFormat.AZTEC:\n // writer = new AztecWriter()\n // break\n default:\n throw new IllegalArgumentException('No encoder available for format ' + format);\n }\n return writer.encode(contents, format, width, height, hints);\n }\n }\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * This object extends LuminanceSource around an array of YUV data returned from the camera driver,\n * with the option to crop to a rectangle within the full data. This can be used to exclude\n * superfluous pixels around the perimeter and speed up decoding.\n *\n * It works for any pixel format where the Y channel is planar and appears first, including\n * YCbCr_420_SP and YCbCr_422_SP.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class PlanarYUVLuminanceSource extends LuminanceSource {\n constructor(yuvData, dataWidth /*int*/, dataHeight /*int*/, left /*int*/, top /*int*/, width /*int*/, height /*int*/, reverseHorizontal) {\n super(width, height);\n this.yuvData = yuvData;\n this.dataWidth = dataWidth;\n this.dataHeight = dataHeight;\n this.left = left;\n this.top = top;\n if (left + width > dataWidth || top + height > dataHeight) {\n throw new IllegalArgumentException('Crop rectangle does not fit within image data.');\n }\n if (reverseHorizontal) {\n this.reverseHorizontal(width, height);\n }\n }\n /*@Override*/\n getRow(y /*int*/, row) {\n if (y < 0 || y >= this.getHeight()) {\n throw new IllegalArgumentException('Requested row is outside the image: ' + y);\n }\n const width = this.getWidth();\n if (row === null || row === undefined || row.length < width) {\n row = new Uint8ClampedArray(width);\n }\n const offset = (y + this.top) * this.dataWidth + this.left;\n System.arraycopy(this.yuvData, offset, row, 0, width);\n return row;\n }\n /*@Override*/\n getMatrix() {\n const width = this.getWidth();\n const height = this.getHeight();\n // If the caller asks for the entire underlying image, save the copy and give them the\n // original data. The docs specifically warn that result.length must be ignored.\n if (width === this.dataWidth && height === this.dataHeight) {\n return this.yuvData;\n }\n const area = width * height;\n const matrix = new Uint8ClampedArray(area);\n let inputOffset = this.top * this.dataWidth + this.left;\n // If the width matches the full width of the underlying data, perform a single copy.\n if (width === this.dataWidth) {\n System.arraycopy(this.yuvData, inputOffset, matrix, 0, area);\n return matrix;\n }\n // Otherwise copy one cropped row at a time.\n for (let y = 0; y < height; y++) {\n const outputOffset = y * width;\n System.arraycopy(this.yuvData, inputOffset, matrix, outputOffset, width);\n inputOffset += this.dataWidth;\n }\n return matrix;\n }\n /*@Override*/\n isCropSupported() {\n return true;\n }\n /*@Override*/\n crop(left /*int*/, top /*int*/, width /*int*/, height /*int*/) {\n return new PlanarYUVLuminanceSource(this.yuvData, this.dataWidth, this.dataHeight, this.left + left, this.top + top, width, height, false);\n }\n renderThumbnail() {\n const width = this.getWidth() / PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR;\n const height = this.getHeight() / PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR;\n const pixels = new Int32Array(width * height);\n const yuv = this.yuvData;\n let inputOffset = this.top * this.dataWidth + this.left;\n for (let y = 0; y < height; y++) {\n const outputOffset = y * width;\n for (let x = 0; x < width; x++) {\n const grey = yuv[inputOffset + x * PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR] & 0xff;\n pixels[outputOffset + x] = 0xFF000000 | (grey * 0x00010101);\n }\n inputOffset += this.dataWidth * PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR;\n }\n return pixels;\n }\n /**\n * @return width of image from {@link #renderThumbnail()}\n */\n getThumbnailWidth() {\n return this.getWidth() / PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR;\n }\n /**\n * @return height of image from {@link #renderThumbnail()}\n */\n getThumbnailHeight() {\n return this.getHeight() / PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR;\n }\n reverseHorizontal(width /*int*/, height /*int*/) {\n const yuvData = this.yuvData;\n for (let y = 0, rowStart = this.top * this.dataWidth + this.left; y < height; y++, rowStart += this.dataWidth) {\n const middle = rowStart + width / 2;\n for (let x1 = rowStart, x2 = rowStart + width - 1; x1 < middle; x1++, x2--) {\n const temp = yuvData[x1];\n yuvData[x1] = yuvData[x2];\n yuvData[x2] = temp;\n }\n }\n }\n invert() {\n return new InvertedLuminanceSource(this);\n }\n }\n PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR = 2;\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * This class is used to help decode images from files which arrive as RGB data from\n * an ARGB pixel array. It does not support rotation.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n * @author Betaminos\n */\n class RGBLuminanceSource extends LuminanceSource {\n constructor(luminances, width /*int*/, height /*int*/, dataWidth /*int*/, dataHeight /*int*/, left /*int*/, top /*int*/) {\n super(width, height);\n this.dataWidth = dataWidth;\n this.dataHeight = dataHeight;\n this.left = left;\n this.top = top;\n if (luminances.BYTES_PER_ELEMENT === 4) { // Int32Array\n const size = width * height;\n const luminancesUint8Array = new Uint8ClampedArray(size);\n for (let offset = 0; offset < size; offset++) {\n const pixel = luminances[offset];\n const r = (pixel >> 16) & 0xff; // red\n const g2 = (pixel >> 7) & 0x1fe; // 2 * green\n const b = pixel & 0xff; // blue\n // Calculate green-favouring average cheaply\n luminancesUint8Array[offset] = /*(byte) */ ((r + g2 + b) / 4) & 0xFF;\n }\n this.luminances = luminancesUint8Array;\n }\n else {\n this.luminances = luminances;\n }\n if (undefined === dataWidth) {\n this.dataWidth = width;\n }\n if (undefined === dataHeight) {\n this.dataHeight = height;\n }\n if (undefined === left) {\n this.left = 0;\n }\n if (undefined === top) {\n this.top = 0;\n }\n if (this.left + width > this.dataWidth || this.top + height > this.dataHeight) {\n throw new IllegalArgumentException('Crop rectangle does not fit within image data.');\n }\n }\n /*@Override*/\n getRow(y /*int*/, row) {\n if (y < 0 || y >= this.getHeight()) {\n throw new IllegalArgumentException('Requested row is outside the image: ' + y);\n }\n const width = this.getWidth();\n if (row === null || row === undefined || row.length < width) {\n row = new Uint8ClampedArray(width);\n }\n const offset = (y + this.top) * this.dataWidth + this.left;\n System.arraycopy(this.luminances, offset, row, 0, width);\n return row;\n }\n /*@Override*/\n getMatrix() {\n const width = this.getWidth();\n const height = this.getHeight();\n // If the caller asks for the entire underlying image, save the copy and give them the\n // original data. The docs specifically warn that result.length must be ignored.\n if (width === this.dataWidth && height === this.dataHeight) {\n return this.luminances;\n }\n const area = width * height;\n const matrix = new Uint8ClampedArray(area);\n let inputOffset = this.top * this.dataWidth + this.left;\n // If the width matches the full width of the underlying data, perform a single copy.\n if (width === this.dataWidth) {\n System.arraycopy(this.luminances, inputOffset, matrix, 0, area);\n return matrix;\n }\n // Otherwise copy one cropped row at a time.\n for (let y = 0; y < height; y++) {\n const outputOffset = y * width;\n System.arraycopy(this.luminances, inputOffset, matrix, outputOffset, width);\n inputOffset += this.dataWidth;\n }\n return matrix;\n }\n /*@Override*/\n isCropSupported() {\n return true;\n }\n /*@Override*/\n crop(left /*int*/, top /*int*/, width /*int*/, height /*int*/) {\n return new RGBLuminanceSource(this.luminances, width, height, this.dataWidth, this.dataHeight, this.left + left, this.top + top);\n }\n invert() {\n return new InvertedLuminanceSource(this);\n }\n }\n\n /**\n * Just to make a shortcut between Java code and TS code.\n */\n class Charset extends CharacterSetECI {\n static forName(name) {\n return this.getCharacterSetECIByName(name);\n }\n }\n\n /**\n * Just to make a shortcut between Java code and TS code.\n */\n class StandardCharsets {\n }\n StandardCharsets.ISO_8859_1 = CharacterSetECI.ISO8859_1;\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * Aztec 2D code representation\n *\n * @author Rustam Abdullaev\n */\n /*public final*/ class AztecCode {\n /**\n * @return {@code true} if compact instead of full mode\n */\n isCompact() {\n return this.compact;\n }\n setCompact(compact) {\n this.compact = compact;\n }\n /**\n * @return size in pixels (width and height)\n */\n getSize() {\n return this.size;\n }\n setSize(size) {\n this.size = size;\n }\n /**\n * @return number of levels\n */\n getLayers() {\n return this.layers;\n }\n setLayers(layers) {\n this.layers = layers;\n }\n /**\n * @return number of data codewords\n */\n getCodeWords() {\n return this.codeWords;\n }\n setCodeWords(codeWords) {\n this.codeWords = codeWords;\n }\n /**\n * @return the symbol image\n */\n getMatrix() {\n return this.matrix;\n }\n setMatrix(matrix) {\n this.matrix = matrix;\n }\n }\n\n class Collections {\n /**\n * The singletonList(T) method is used to return an immutable list containing only the specified object.\n */\n static singletonList(item) {\n return [item];\n }\n /**\n * The min(Collection, Comparator) method is used to return the minimum element of the given collection, according to the order induced by the specified comparator.\n */\n static min(collection, comparator) {\n return collection.sort(comparator)[0];\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n class Token {\n constructor(previous) {\n this.previous = previous;\n }\n getPrevious() {\n return this.previous;\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*final*/ class SimpleToken extends Token {\n constructor(previous, value, bitCount) {\n super(previous);\n this.value = value;\n this.bitCount = bitCount;\n }\n /**\n * @Override\n */\n appendTo(bitArray, text) {\n bitArray.appendBits(this.value, this.bitCount);\n }\n add(value, bitCount) {\n return new SimpleToken(this, value, bitCount);\n }\n addBinaryShift(start, byteCount) {\n // no-op can't binary shift a simple token\n console.warn('addBinaryShift on SimpleToken, this simply returns a copy of this token');\n return new SimpleToken(this, start, byteCount);\n }\n /**\n * @Override\n */\n toString() {\n let value = this.value & ((1 << this.bitCount) - 1);\n value |= 1 << this.bitCount;\n return '<' + Integer.toBinaryString(value | (1 << this.bitCount)).substring(1) + '>';\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*final*/ class BinaryShiftToken extends SimpleToken {\n constructor(previous, binaryShiftStart, binaryShiftByteCount) {\n super(previous, 0, 0);\n this.binaryShiftStart = binaryShiftStart;\n this.binaryShiftByteCount = binaryShiftByteCount;\n }\n /**\n * @Override\n */\n appendTo(bitArray, text) {\n for (let i = 0; i < this.binaryShiftByteCount; i++) {\n if (i === 0 || (i === 31 && this.binaryShiftByteCount <= 62)) {\n // We need a header before the first character, and before\n // character 31 when the total byte code is <= 62\n bitArray.appendBits(31, 5); // BINARY_SHIFT\n if (this.binaryShiftByteCount > 62) {\n bitArray.appendBits(this.binaryShiftByteCount - 31, 16);\n }\n else if (i === 0) {\n // 1 <= binaryShiftByteCode <= 62\n bitArray.appendBits(Math.min(this.binaryShiftByteCount, 31), 5);\n }\n else {\n // 32 <= binaryShiftCount <= 62 and i == 31\n bitArray.appendBits(this.binaryShiftByteCount - 31, 5);\n }\n }\n bitArray.appendBits(text[this.binaryShiftStart + i], 8);\n }\n }\n addBinaryShift(start, byteCount) {\n // int bitCount = (byteCount * 8) + (byteCount <= 31 ? 10 : byteCount <= 62 ? 20 : 21);\n return new BinaryShiftToken(this, start, byteCount);\n }\n /**\n * @Override\n */\n toString() {\n return '<' + this.binaryShiftStart + '::' + (this.binaryShiftStart + this.binaryShiftByteCount - 1) + '>';\n }\n }\n\n function addBinaryShift(token, start, byteCount) {\n // int bitCount = (byteCount * 8) + (byteCount <= 31 ? 10 : byteCount <= 62 ? 20 : 21);\n return new BinaryShiftToken(token, start, byteCount);\n }\n function add(token, value, bitCount) {\n return new SimpleToken(token, value, bitCount);\n }\n\n const /*final*/ MODE_NAMES = [\n 'UPPER',\n 'LOWER',\n 'DIGIT',\n 'MIXED',\n 'PUNCT'\n ];\n const /*final*/ MODE_UPPER = 0; // 5 bits\n const /*final*/ MODE_LOWER = 1; // 5 bits\n const /*final*/ MODE_DIGIT = 2; // 4 bits\n const /*final*/ MODE_MIXED = 3; // 5 bits\n const /*final*/ MODE_PUNCT = 4; // 5 bits\n const EMPTY_TOKEN = new SimpleToken(null, 0, 0);\n\n // The Latch Table shows, for each pair of Modes, the optimal method for\n // getting from one mode to another. In the worst possible case, this can\n // be up to 14 bits. In the best possible case, we are already there!\n // The high half-word of each entry gives the number of bits.\n // The low half-word of each entry are the actual bits necessary to change\n const LATCH_TABLE = [\n Int32Array.from([\n 0,\n (5 << 16) + 28,\n (5 << 16) + 30,\n (5 << 16) + 29,\n (10 << 16) + (29 << 5) + 30 // UPPER -> MIXED -> PUNCT\n ]),\n Int32Array.from([\n (9 << 16) + (30 << 4) + 14,\n 0,\n (5 << 16) + 30,\n (5 << 16) + 29,\n (10 << 16) + (29 << 5) + 30 // LOWER -> MIXED -> PUNCT\n ]),\n Int32Array.from([\n (4 << 16) + 14,\n (9 << 16) + (14 << 5) + 28,\n 0,\n (9 << 16) + (14 << 5) + 29,\n (14 << 16) + (14 << 10) + (29 << 5) + 30\n // DIGIT -> UPPER -> MIXED -> PUNCT\n ]),\n Int32Array.from([\n (5 << 16) + 29,\n (5 << 16) + 28,\n (10 << 16) + (29 << 5) + 30,\n 0,\n (5 << 16) + 30 // MIXED -> PUNCT\n ]),\n Int32Array.from([\n (5 << 16) + 31,\n (10 << 16) + (31 << 5) + 28,\n (10 << 16) + (31 << 5) + 30,\n (10 << 16) + (31 << 5) + 29,\n 0\n ])\n ];\n\n function static_SHIFT_TABLE(SHIFT_TABLE) {\n for (let table /*Int32Array*/ of SHIFT_TABLE) {\n Arrays.fill(table, -1);\n }\n SHIFT_TABLE[MODE_UPPER][MODE_PUNCT] = 0;\n SHIFT_TABLE[MODE_LOWER][MODE_PUNCT] = 0;\n SHIFT_TABLE[MODE_LOWER][MODE_UPPER] = 28;\n SHIFT_TABLE[MODE_MIXED][MODE_PUNCT] = 0;\n SHIFT_TABLE[MODE_DIGIT][MODE_PUNCT] = 0;\n SHIFT_TABLE[MODE_DIGIT][MODE_UPPER] = 15;\n return SHIFT_TABLE;\n }\n const /*final*/ SHIFT_TABLE = static_SHIFT_TABLE(Arrays.createInt32Array(6, 6)); // mode shift codes, per table\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * State represents all information about a sequence necessary to generate the current output.\n * Note that a state is immutable.\n */\n /*final*/ class State {\n constructor(token, mode, binaryBytes, bitCount) {\n this.token = token;\n this.mode = mode;\n this.binaryShiftByteCount = binaryBytes;\n this.bitCount = bitCount;\n // Make sure we match the token\n // int binaryShiftBitCount = (binaryShiftByteCount * 8) +\n // (binaryShiftByteCount === 0 ? 0 :\n // binaryShiftByteCount <= 31 ? 10 :\n // binaryShiftByteCount <= 62 ? 20 : 21);\n // assert this.bitCount === token.getTotalBitCount() + binaryShiftBitCount;\n }\n getMode() {\n return this.mode;\n }\n getToken() {\n return this.token;\n }\n getBinaryShiftByteCount() {\n return this.binaryShiftByteCount;\n }\n getBitCount() {\n return this.bitCount;\n }\n // Create a new state representing this state with a latch to a (not\n // necessary different) mode, and then a code.\n latchAndAppend(mode, value) {\n // assert binaryShiftByteCount === 0;\n let bitCount = this.bitCount;\n let token = this.token;\n if (mode !== this.mode) {\n let latch = LATCH_TABLE[this.mode][mode];\n token = add(token, latch & 0xffff, latch >> 16);\n bitCount += latch >> 16;\n }\n let latchModeBitCount = mode === MODE_DIGIT ? 4 : 5;\n token = add(token, value, latchModeBitCount);\n return new State(token, mode, 0, bitCount + latchModeBitCount);\n }\n // Create a new state representing this state, with a temporary shift\n // to a different mode to output a single value.\n shiftAndAppend(mode, value) {\n // assert binaryShiftByteCount === 0 && this.mode !== mode;\n let token = this.token;\n let thisModeBitCount = this.mode === MODE_DIGIT ? 4 : 5;\n // Shifts exist only to UPPER and PUNCT, both with tokens size 5.\n token = add(token, SHIFT_TABLE[this.mode][mode], thisModeBitCount);\n token = add(token, value, 5);\n return new State(token, this.mode, 0, this.bitCount + thisModeBitCount + 5);\n }\n // Create a new state representing this state, but an additional character\n // output in Binary Shift mode.\n addBinaryShiftChar(index) {\n let token = this.token;\n let mode = this.mode;\n let bitCount = this.bitCount;\n if (this.mode === MODE_PUNCT || this.mode === MODE_DIGIT) {\n // assert binaryShiftByteCount === 0;\n let latch = LATCH_TABLE[mode][MODE_UPPER];\n token = add(token, latch & 0xffff, latch >> 16);\n bitCount += latch >> 16;\n mode = MODE_UPPER;\n }\n let deltaBitCount = this.binaryShiftByteCount === 0 || this.binaryShiftByteCount === 31\n ? 18\n : this.binaryShiftByteCount === 62\n ? 9\n : 8;\n let result = new State(token, mode, this.binaryShiftByteCount + 1, bitCount + deltaBitCount);\n if (result.binaryShiftByteCount === 2047 + 31) {\n // The string is as long as it's allowed to be. We should end it.\n result = result.endBinaryShift(index + 1);\n }\n return result;\n }\n // Create the state identical to this one, but we are no longer in\n // Binary Shift mode.\n endBinaryShift(index) {\n if (this.binaryShiftByteCount === 0) {\n return this;\n }\n let token = this.token;\n token = addBinaryShift(token, index - this.binaryShiftByteCount, this.binaryShiftByteCount);\n // assert token.getTotalBitCount() === this.bitCount;\n return new State(token, this.mode, 0, this.bitCount);\n }\n // Returns true if \"this\" state is better (equal: or) to be in than \"that\"\n // state under all possible circumstances.\n isBetterThanOrEqualTo(other) {\n let newModeBitCount = this.bitCount + (LATCH_TABLE[this.mode][other.mode] >> 16);\n if (this.binaryShiftByteCount < other.binaryShiftByteCount) {\n // add additional B/S encoding cost of other, if any\n newModeBitCount +=\n State.calculateBinaryShiftCost(other) -\n State.calculateBinaryShiftCost(this);\n }\n else if (this.binaryShiftByteCount > other.binaryShiftByteCount &&\n other.binaryShiftByteCount > 0) {\n // maximum possible additional cost (it: h)\n newModeBitCount += 10;\n }\n return newModeBitCount <= other.bitCount;\n }\n toBitArray(text) {\n // Reverse the tokens, so that they are in the order that they should\n // be output\n let symbols = [];\n for (let token = this.endBinaryShift(text.length).token; token !== null; token = token.getPrevious()) {\n symbols.unshift(token);\n }\n let bitArray = new BitArray();\n // Add each token to the result.\n for (const symbol of symbols) {\n symbol.appendTo(bitArray, text);\n }\n // assert bitArray.getSize() === this.bitCount;\n return bitArray;\n }\n /**\n * @Override\n */\n toString() {\n return StringUtils.format('%s bits=%d bytes=%d', MODE_NAMES[this.mode], this.bitCount, this.binaryShiftByteCount);\n }\n static calculateBinaryShiftCost(state) {\n if (state.binaryShiftByteCount > 62) {\n return 21; // B/S with extended length\n }\n if (state.binaryShiftByteCount > 31) {\n return 20; // two B/S\n }\n if (state.binaryShiftByteCount > 0) {\n return 10; // one B/S\n }\n return 0;\n }\n }\n State.INITIAL_STATE = new State(EMPTY_TOKEN, MODE_UPPER, 0, 0);\n\n function static_CHAR_MAP(CHAR_MAP) {\n const spaceCharCode = StringUtils.getCharCode(' ');\n const pointCharCode = StringUtils.getCharCode('.');\n const commaCharCode = StringUtils.getCharCode(',');\n CHAR_MAP[MODE_UPPER][spaceCharCode] = 1;\n const zUpperCharCode = StringUtils.getCharCode('Z');\n const aUpperCharCode = StringUtils.getCharCode('A');\n for (let c = aUpperCharCode; c <= zUpperCharCode; c++) {\n CHAR_MAP[MODE_UPPER][c] = c - aUpperCharCode + 2;\n }\n CHAR_MAP[MODE_LOWER][spaceCharCode] = 1;\n const zLowerCharCode = StringUtils.getCharCode('z');\n const aLowerCharCode = StringUtils.getCharCode('a');\n for (let c = aLowerCharCode; c <= zLowerCharCode; c++) {\n CHAR_MAP[MODE_LOWER][c] = c - aLowerCharCode + 2;\n }\n CHAR_MAP[MODE_DIGIT][spaceCharCode] = 1;\n const nineCharCode = StringUtils.getCharCode('9');\n const zeroCharCode = StringUtils.getCharCode('0');\n for (let c = zeroCharCode; c <= nineCharCode; c++) {\n CHAR_MAP[MODE_DIGIT][c] = c - zeroCharCode + 2;\n }\n CHAR_MAP[MODE_DIGIT][commaCharCode] = 12;\n CHAR_MAP[MODE_DIGIT][pointCharCode] = 13;\n const mixedTable = [\n '\\x00',\n ' ',\n '\\x01',\n '\\x02',\n '\\x03',\n '\\x04',\n '\\x05',\n '\\x06',\n '\\x07',\n '\\b',\n '\\t',\n '\\n',\n '\\x0b',\n '\\f',\n '\\r',\n '\\x1b',\n '\\x1c',\n '\\x1d',\n '\\x1e',\n '\\x1f',\n '@',\n '\\\\',\n '^',\n '_',\n '`',\n '|',\n '~',\n '\\x7f'\n ];\n for (let i = 0; i < mixedTable.length; i++) {\n CHAR_MAP[MODE_MIXED][StringUtils.getCharCode(mixedTable[i])] = i;\n }\n const punctTable = [\n '\\x00',\n '\\r',\n '\\x00',\n '\\x00',\n '\\x00',\n '\\x00',\n '!',\n '\\'',\n '#',\n '$',\n '%',\n '&',\n '\\'',\n '(',\n ')',\n '*',\n '+',\n ',',\n '-',\n '.',\n '/',\n ':',\n ';',\n '<',\n '=',\n '>',\n '?',\n '[',\n ']',\n '{',\n '}'\n ];\n for (let i = 0; i < punctTable.length; i++) {\n if (StringUtils.getCharCode(punctTable[i]) > 0) {\n CHAR_MAP[MODE_PUNCT][StringUtils.getCharCode(punctTable[i])] = i;\n }\n }\n return CHAR_MAP;\n }\n const CHAR_MAP = static_CHAR_MAP(Arrays.createInt32Array(5, 256));\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * This produces nearly optimal encodings of text into the first-level of\n * encoding used by Aztec code.\n *\n * It uses a dynamic algorithm. For each prefix of the string, it determines\n * a set of encodings that could lead to this prefix. We repeatedly add a\n * character and generate a new set of optimal encodings until we have read\n * through the entire input.\n *\n * @author Frank Yellin\n * @author Rustam Abdullaev\n */\n /*public final*/ class HighLevelEncoder {\n constructor(text) {\n this.text = text;\n }\n /**\n * @return text represented by this encoder encoded as a {@link BitArray}\n */\n encode() {\n const spaceCharCode = StringUtils.getCharCode(' ');\n const lineBreakCharCode = StringUtils.getCharCode('\\n');\n let states = Collections.singletonList(State.INITIAL_STATE);\n for (let index = 0; index < this.text.length; index++) {\n let pairCode;\n let nextChar = index + 1 < this.text.length ? this.text[index + 1] : 0;\n switch (this.text[index]) {\n case StringUtils.getCharCode('\\r'):\n pairCode = nextChar === lineBreakCharCode ? 2 : 0;\n break;\n case StringUtils.getCharCode('.'):\n pairCode = nextChar === spaceCharCode ? 3 : 0;\n break;\n case StringUtils.getCharCode(','):\n pairCode = nextChar === spaceCharCode ? 4 : 0;\n break;\n case StringUtils.getCharCode(':'):\n pairCode = nextChar === spaceCharCode ? 5 : 0;\n break;\n default:\n pairCode = 0;\n }\n if (pairCode > 0) {\n // We have one of the four special PUNCT pairs. Treat them specially.\n // Get a new set of states for the two new characters.\n states = HighLevelEncoder.updateStateListForPair(states, index, pairCode);\n index++;\n }\n else {\n // Get a new set of states for the new character.\n states = this.updateStateListForChar(states, index);\n }\n }\n // We are left with a set of states. Find the shortest one.\n const minState = Collections.min(states, (a, b) => {\n return a.getBitCount() - b.getBitCount();\n });\n // Convert it to a bit array, and return.\n return minState.toBitArray(this.text);\n }\n // We update a set of states for a new character by updating each state\n // for the new character, merging the results, and then removing the\n // non-optimal states.\n updateStateListForChar(states, index) {\n const result = [];\n for (let state /*State*/ of states) {\n this.updateStateForChar(state, index, result);\n }\n return HighLevelEncoder.simplifyStates(result);\n }\n // Return a set of states that represent the possible ways of updating this\n // state for the next character. The resulting set of states are added to\n // the \"result\" list.\n updateStateForChar(state, index, result) {\n let ch = (this.text[index] & 0xff);\n let charInCurrentTable = CHAR_MAP[state.getMode()][ch] > 0;\n let stateNoBinary = null;\n for (let mode /*int*/ = 0; mode <= MODE_PUNCT; mode++) {\n let charInMode = CHAR_MAP[mode][ch];\n if (charInMode > 0) {\n if (stateNoBinary == null) {\n // Only create stateNoBinary the first time it's required.\n stateNoBinary = state.endBinaryShift(index);\n }\n // Try generating the character by latching to its mode\n if (!charInCurrentTable ||\n mode === state.getMode() ||\n mode === MODE_DIGIT) {\n // If the character is in the current table, we don't want to latch to\n // any other mode except possibly digit (which uses only 4 bits). Any\n // other latch would be equally successful *after* this character, and\n // so wouldn't save any bits.\n const latchState = stateNoBinary.latchAndAppend(mode, charInMode);\n result.push(latchState);\n }\n // Try generating the character by switching to its mode.\n if (!charInCurrentTable &&\n SHIFT_TABLE[state.getMode()][mode] >= 0) {\n // It never makes sense to temporarily shift to another mode if the\n // character exists in the current mode. That can never save bits.\n const shiftState = stateNoBinary.shiftAndAppend(mode, charInMode);\n result.push(shiftState);\n }\n }\n }\n if (state.getBinaryShiftByteCount() > 0 ||\n CHAR_MAP[state.getMode()][ch] === 0) {\n // It's never worthwhile to go into binary shift mode if you're not already\n // in binary shift mode, and the character exists in your current mode.\n // That can never save bits over just outputting the char in the current mode.\n let binaryState = state.addBinaryShiftChar(index);\n result.push(binaryState);\n }\n }\n static updateStateListForPair(states, index, pairCode) {\n const result = [];\n for (let state /*State*/ of states) {\n this.updateStateForPair(state, index, pairCode, result);\n }\n return this.simplifyStates(result);\n }\n static updateStateForPair(state, index, pairCode, result) {\n let stateNoBinary = state.endBinaryShift(index);\n // Possibility 1. Latch to C.MODE_PUNCT, and then append this code\n result.push(stateNoBinary.latchAndAppend(MODE_PUNCT, pairCode));\n if (state.getMode() !== MODE_PUNCT) {\n // Possibility 2. Shift to C.MODE_PUNCT, and then append this code.\n // Every state except C.MODE_PUNCT (handled above) can shift\n result.push(stateNoBinary.shiftAndAppend(MODE_PUNCT, pairCode));\n }\n if (pairCode === 3 || pairCode === 4) {\n // both characters are in DIGITS. Sometimes better to just add two digits\n let digitState = stateNoBinary\n .latchAndAppend(MODE_DIGIT, 16 - pairCode) // period or comma in DIGIT\n .latchAndAppend(MODE_DIGIT, 1); // space in DIGIT\n result.push(digitState);\n }\n if (state.getBinaryShiftByteCount() > 0) {\n // It only makes sense to do the characters as binary if we're already\n // in binary mode.\n let binaryState = state\n .addBinaryShiftChar(index)\n .addBinaryShiftChar(index + 1);\n result.push(binaryState);\n }\n }\n static simplifyStates(states) {\n let result = [];\n for (const newState of states) {\n let add = true;\n for (const oldState of result) {\n if (oldState.isBetterThanOrEqualTo(newState)) {\n add = false;\n break;\n }\n if (newState.isBetterThanOrEqualTo(oldState)) {\n // iterator.remove();\n result = result.filter(x => x !== oldState); // remove old state\n }\n }\n if (add) {\n result.push(newState);\n }\n }\n return result;\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // package com.google.zxing.aztec.encoder;\n // import com.google.zxing.common.BitArray;\n // import com.google.zxing.common.BitMatrix;\n // import com.google.zxing.common.reedsolomon.GenericGF;\n // import com.google.zxing.common.reedsolomon.ReedSolomonEncoder;\n /**\n * Generates Aztec 2D barcodes.\n *\n * @author Rustam Abdullaev\n */\n /*public final*/ class Encoder$1 {\n constructor() {\n }\n /**\n * Encodes the given binary content as an Aztec symbol\n *\n * @param data input data string\n * @return Aztec symbol matrix with metadata\n */\n static encodeBytes(data) {\n return Encoder$1.encode(data, Encoder$1.DEFAULT_EC_PERCENT, Encoder$1.DEFAULT_AZTEC_LAYERS);\n }\n /**\n * Encodes the given binary content as an Aztec symbol\n *\n * @param data input data string\n * @param minECCPercent minimal percentage of error check words (According to ISO/IEC 24778:2008,\n * a minimum of 23% + 3 words is recommended)\n * @param userSpecifiedLayers if non-zero, a user-specified value for the number of layers\n * @return Aztec symbol matrix with metadata\n */\n static encode(data, minECCPercent, userSpecifiedLayers) {\n // High-level encode\n let bits = new HighLevelEncoder(data).encode();\n // stuff bits and choose symbol size\n let eccBits = Integer.truncDivision((bits.getSize() * minECCPercent), 100) + 11;\n let totalSizeBits = bits.getSize() + eccBits;\n let compact;\n let layers;\n let totalBitsInLayer;\n let wordSize;\n let stuffedBits;\n if (userSpecifiedLayers !== Encoder$1.DEFAULT_AZTEC_LAYERS) {\n compact = userSpecifiedLayers < 0;\n layers = Math.abs(userSpecifiedLayers);\n if (layers > (compact ? Encoder$1.MAX_NB_BITS_COMPACT : Encoder$1.MAX_NB_BITS)) {\n throw new IllegalArgumentException(StringUtils.format('Illegal value %s for layers', userSpecifiedLayers));\n }\n totalBitsInLayer = Encoder$1.totalBitsInLayer(layers, compact);\n wordSize = Encoder$1.WORD_SIZE[layers];\n let usableBitsInLayers = totalBitsInLayer - (totalBitsInLayer % wordSize);\n stuffedBits = Encoder$1.stuffBits(bits, wordSize);\n if (stuffedBits.getSize() + eccBits > usableBitsInLayers) {\n throw new IllegalArgumentException('Data to large for user specified layer');\n }\n if (compact && stuffedBits.getSize() > wordSize * 64) {\n // Compact format only allows 64 data words, though C4 can hold more words than that\n throw new IllegalArgumentException('Data to large for user specified layer');\n }\n }\n else {\n wordSize = 0;\n stuffedBits = null;\n // We look at the possible table sizes in the order Compact1, Compact2, Compact3,\n // Compact4, Normal4,... Normal(i) for i < 4 isn't typically used since Compact(i+1)\n // is the same size, but has more data.\n for (let i /*int*/ = 0;; i++) {\n if (i > Encoder$1.MAX_NB_BITS) {\n throw new IllegalArgumentException('Data too large for an Aztec code');\n }\n compact = i <= 3;\n layers = compact ? i + 1 : i;\n totalBitsInLayer = Encoder$1.totalBitsInLayer(layers, compact);\n if (totalSizeBits > totalBitsInLayer) {\n continue;\n }\n // [Re]stuff the bits if this is the first opportunity, or if the\n // wordSize has changed\n if (stuffedBits == null || wordSize !== Encoder$1.WORD_SIZE[layers]) {\n wordSize = Encoder$1.WORD_SIZE[layers];\n stuffedBits = Encoder$1.stuffBits(bits, wordSize);\n }\n let usableBitsInLayers = totalBitsInLayer - (totalBitsInLayer % wordSize);\n if (compact && stuffedBits.getSize() > wordSize * 64) {\n // Compact format only allows 64 data words, though C4 can hold more words than that\n continue;\n }\n if (stuffedBits.getSize() + eccBits <= usableBitsInLayers) {\n break;\n }\n }\n }\n let messageBits = Encoder$1.generateCheckWords(stuffedBits, totalBitsInLayer, wordSize);\n // generate mode message\n let messageSizeInWords = stuffedBits.getSize() / wordSize;\n let modeMessage = Encoder$1.generateModeMessage(compact, layers, messageSizeInWords);\n // allocate symbol\n let baseMatrixSize = (compact ? 11 : 14) + layers * 4; // not including alignment lines\n let alignmentMap = new Int32Array(baseMatrixSize);\n let matrixSize;\n if (compact) {\n // no alignment marks in compact mode, alignmentMap is a no-op\n matrixSize = baseMatrixSize;\n for (let i /*int*/ = 0; i < alignmentMap.length; i++) {\n alignmentMap[i] = i;\n }\n }\n else {\n matrixSize = baseMatrixSize + 1 + 2 * Integer.truncDivision((Integer.truncDivision(baseMatrixSize, 2) - 1), 15);\n let origCenter = Integer.truncDivision(baseMatrixSize, 2);\n let center = Integer.truncDivision(matrixSize, 2);\n for (let i /*int*/ = 0; i < origCenter; i++) {\n let newOffset = i + Integer.truncDivision(i, 15);\n alignmentMap[origCenter - i - 1] = center - newOffset - 1;\n alignmentMap[origCenter + i] = center + newOffset + 1;\n }\n }\n let matrix = new BitMatrix(matrixSize);\n // draw data bits\n for (let i /*int*/ = 0, rowOffset = 0; i < layers; i++) {\n let rowSize = (layers - i) * 4 + (compact ? 9 : 12);\n for (let j /*int*/ = 0; j < rowSize; j++) {\n let columnOffset = j * 2;\n for (let k /*int*/ = 0; k < 2; k++) {\n if (messageBits.get(rowOffset + columnOffset + k)) {\n matrix.set(alignmentMap[i * 2 + k], alignmentMap[i * 2 + j]);\n }\n if (messageBits.get(rowOffset + rowSize * 2 + columnOffset + k)) {\n matrix.set(alignmentMap[i * 2 + j], alignmentMap[baseMatrixSize - 1 - i * 2 - k]);\n }\n if (messageBits.get(rowOffset + rowSize * 4 + columnOffset + k)) {\n matrix.set(alignmentMap[baseMatrixSize - 1 - i * 2 - k], alignmentMap[baseMatrixSize - 1 - i * 2 - j]);\n }\n if (messageBits.get(rowOffset + rowSize * 6 + columnOffset + k)) {\n matrix.set(alignmentMap[baseMatrixSize - 1 - i * 2 - j], alignmentMap[i * 2 + k]);\n }\n }\n }\n rowOffset += rowSize * 8;\n }\n // draw mode message\n Encoder$1.drawModeMessage(matrix, compact, matrixSize, modeMessage);\n // draw alignment marks\n if (compact) {\n Encoder$1.drawBullsEye(matrix, Integer.truncDivision(matrixSize, 2), 5);\n }\n else {\n Encoder$1.drawBullsEye(matrix, Integer.truncDivision(matrixSize, 2), 7);\n for (let i /*int*/ = 0, j = 0; i < Integer.truncDivision(baseMatrixSize, 2) - 1; i += 15, j += 16) {\n for (let k /*int*/ = Integer.truncDivision(matrixSize, 2) & 1; k < matrixSize; k += 2) {\n matrix.set(Integer.truncDivision(matrixSize, 2) - j, k);\n matrix.set(Integer.truncDivision(matrixSize, 2) + j, k);\n matrix.set(k, Integer.truncDivision(matrixSize, 2) - j);\n matrix.set(k, Integer.truncDivision(matrixSize, 2) + j);\n }\n }\n }\n let aztec = new AztecCode();\n aztec.setCompact(compact);\n aztec.setSize(matrixSize);\n aztec.setLayers(layers);\n aztec.setCodeWords(messageSizeInWords);\n aztec.setMatrix(matrix);\n return aztec;\n }\n static drawBullsEye(matrix, center, size) {\n for (let i /*int*/ = 0; i < size; i += 2) {\n for (let j /*int*/ = center - i; j <= center + i; j++) {\n matrix.set(j, center - i);\n matrix.set(j, center + i);\n matrix.set(center - i, j);\n matrix.set(center + i, j);\n }\n }\n matrix.set(center - size, center - size);\n matrix.set(center - size + 1, center - size);\n matrix.set(center - size, center - size + 1);\n matrix.set(center + size, center - size);\n matrix.set(center + size, center - size + 1);\n matrix.set(center + size, center + size - 1);\n }\n static generateModeMessage(compact, layers, messageSizeInWords) {\n let modeMessage = new BitArray();\n if (compact) {\n modeMessage.appendBits(layers - 1, 2);\n modeMessage.appendBits(messageSizeInWords - 1, 6);\n modeMessage = Encoder$1.generateCheckWords(modeMessage, 28, 4);\n }\n else {\n modeMessage.appendBits(layers - 1, 5);\n modeMessage.appendBits(messageSizeInWords - 1, 11);\n modeMessage = Encoder$1.generateCheckWords(modeMessage, 40, 4);\n }\n return modeMessage;\n }\n static drawModeMessage(matrix, compact, matrixSize, modeMessage) {\n let center = Integer.truncDivision(matrixSize, 2);\n if (compact) {\n for (let i /*int*/ = 0; i < 7; i++) {\n let offset = center - 3 + i;\n if (modeMessage.get(i)) {\n matrix.set(offset, center - 5);\n }\n if (modeMessage.get(i + 7)) {\n matrix.set(center + 5, offset);\n }\n if (modeMessage.get(20 - i)) {\n matrix.set(offset, center + 5);\n }\n if (modeMessage.get(27 - i)) {\n matrix.set(center - 5, offset);\n }\n }\n }\n else {\n for (let i /*int*/ = 0; i < 10; i++) {\n let offset = center - 5 + i + Integer.truncDivision(i, 5);\n if (modeMessage.get(i)) {\n matrix.set(offset, center - 7);\n }\n if (modeMessage.get(i + 10)) {\n matrix.set(center + 7, offset);\n }\n if (modeMessage.get(29 - i)) {\n matrix.set(offset, center + 7);\n }\n if (modeMessage.get(39 - i)) {\n matrix.set(center - 7, offset);\n }\n }\n }\n }\n static generateCheckWords(bitArray, totalBits, wordSize) {\n // bitArray is guaranteed to be a multiple of the wordSize, so no padding needed\n let messageSizeInWords = bitArray.getSize() / wordSize;\n let rs = new ReedSolomonEncoder(Encoder$1.getGF(wordSize));\n let totalWords = Integer.truncDivision(totalBits, wordSize);\n let messageWords = Encoder$1.bitsToWords(bitArray, wordSize, totalWords);\n rs.encode(messageWords, totalWords - messageSizeInWords);\n let startPad = totalBits % wordSize;\n let messageBits = new BitArray();\n messageBits.appendBits(0, startPad);\n for (const messageWord /*: int*/ of Array.from(messageWords)) {\n messageBits.appendBits(messageWord, wordSize);\n }\n return messageBits;\n }\n static bitsToWords(stuffedBits, wordSize, totalWords) {\n let message = new Int32Array(totalWords);\n let i;\n let n;\n for (i = 0, n = stuffedBits.getSize() / wordSize; i < n; i++) {\n let value = 0;\n for (let j /*int*/ = 0; j < wordSize; j++) {\n value |= stuffedBits.get(i * wordSize + j) ? (1 << wordSize - j - 1) : 0;\n }\n message[i] = value;\n }\n return message;\n }\n static getGF(wordSize) {\n switch (wordSize) {\n case 4:\n return GenericGF.AZTEC_PARAM;\n case 6:\n return GenericGF.AZTEC_DATA_6;\n case 8:\n return GenericGF.AZTEC_DATA_8;\n case 10:\n return GenericGF.AZTEC_DATA_10;\n case 12:\n return GenericGF.AZTEC_DATA_12;\n default:\n throw new IllegalArgumentException('Unsupported word size ' + wordSize);\n }\n }\n static stuffBits(bits, wordSize) {\n let out = new BitArray();\n let n = bits.getSize();\n let mask = (1 << wordSize) - 2;\n for (let i /*int*/ = 0; i < n; i += wordSize) {\n let word = 0;\n for (let j /*int*/ = 0; j < wordSize; j++) {\n if (i + j >= n || bits.get(i + j)) {\n word |= 1 << (wordSize - 1 - j);\n }\n }\n if ((word & mask) === mask) {\n out.appendBits(word & mask, wordSize);\n i--;\n }\n else if ((word & mask) === 0) {\n out.appendBits(word | 1, wordSize);\n i--;\n }\n else {\n out.appendBits(word, wordSize);\n }\n }\n return out;\n }\n static totalBitsInLayer(layers, compact) {\n return ((compact ? 88 : 112) + 16 * layers) * layers;\n }\n }\n Encoder$1.DEFAULT_EC_PERCENT = 33; // default minimal percentage of error check words\n Encoder$1.DEFAULT_AZTEC_LAYERS = 0;\n Encoder$1.MAX_NB_BITS = 32;\n Encoder$1.MAX_NB_BITS_COMPACT = 4;\n Encoder$1.WORD_SIZE = Int32Array.from([\n 4, 6, 6, 8, 8, 8, 8, 8, 8, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,\n 12, 12, 12, 12, 12, 12, 12, 12, 12, 12\n ]);\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * Renders an Aztec code as a {@link BitMatrix}.\n */\n /*public final*/ class AztecWriter {\n // @Override\n encode(contents, format, width, height) {\n return this.encodeWithHints(contents, format, width, height, null);\n }\n // @Override\n encodeWithHints(contents, format, width, height, hints) {\n let charset = StandardCharsets.ISO_8859_1;\n let eccPercent = Encoder$1.DEFAULT_EC_PERCENT;\n let layers = Encoder$1.DEFAULT_AZTEC_LAYERS;\n if (hints != null) {\n if (hints.has(EncodeHintType$1.CHARACTER_SET)) {\n charset = Charset.forName(hints.get(EncodeHintType$1.CHARACTER_SET).toString());\n }\n if (hints.has(EncodeHintType$1.ERROR_CORRECTION)) {\n eccPercent = Integer.parseInt(hints.get(EncodeHintType$1.ERROR_CORRECTION).toString());\n }\n if (hints.has(EncodeHintType$1.AZTEC_LAYERS)) {\n layers = Integer.parseInt(hints.get(EncodeHintType$1.AZTEC_LAYERS).toString());\n }\n }\n return AztecWriter.encodeLayers(contents, format, width, height, charset, eccPercent, layers);\n }\n static encodeLayers(contents, format, width, height, charset, eccPercent, layers) {\n if (format !== BarcodeFormat$1.AZTEC) {\n throw new IllegalArgumentException('Can only encode AZTEC, but got ' + format);\n }\n let aztec = Encoder$1.encode(StringUtils.getBytes(contents, charset), eccPercent, layers);\n return AztecWriter.renderResult(aztec, width, height);\n }\n static renderResult(code, width, height) {\n let input = code.getMatrix();\n if (input == null) {\n throw new IllegalStateException();\n }\n let inputWidth = input.getWidth();\n let inputHeight = input.getHeight();\n let outputWidth = Math.max(width, inputWidth);\n let outputHeight = Math.max(height, inputHeight);\n let multiple = Math.min(outputWidth / inputWidth, outputHeight / inputHeight);\n let leftPadding = (outputWidth - (inputWidth * multiple)) / 2;\n let topPadding = (outputHeight - (inputHeight * multiple)) / 2;\n let output = new BitMatrix(outputWidth, outputHeight);\n for (let inputY /*int*/ = 0, outputY = topPadding; inputY < inputHeight; inputY++, outputY += multiple) {\n // Write the contents of this row of the barcode\n for (let inputX /*int*/ = 0, outputX = leftPadding; inputX < inputWidth; inputX++, outputX += multiple) {\n if (input.get(inputX, inputY)) {\n output.setRegion(outputX, outputY, multiple, multiple);\n }\n }\n }\n return output;\n }\n }\n\n exports.ArgumentException = ArgumentException;\n exports.ArithmeticException = ArithmeticException;\n exports.AztecCode = AztecCode;\n exports.AztecCodeReader = AztecReader;\n exports.AztecCodeWriter = AztecWriter;\n exports.AztecDecoder = Decoder;\n exports.AztecDetector = Detector;\n exports.AztecDetectorResult = AztecDetectorResult;\n exports.AztecEncoder = Encoder$1;\n exports.AztecHighLevelEncoder = HighLevelEncoder;\n exports.AztecPoint = Point;\n exports.BarcodeFormat = BarcodeFormat$1;\n exports.Binarizer = Binarizer;\n exports.BinaryBitmap = BinaryBitmap;\n exports.BitArray = BitArray;\n exports.BitMatrix = BitMatrix;\n exports.BitSource = BitSource;\n exports.BrowserAztecCodeReader = BrowserAztecCodeReader;\n exports.BrowserBarcodeReader = BrowserBarcodeReader;\n exports.BrowserCodeReader = BrowserCodeReader;\n exports.BrowserDatamatrixCodeReader = BrowserDatamatrixCodeReader;\n exports.BrowserMultiFormatReader = BrowserMultiFormatReader;\n exports.BrowserPDF417Reader = BrowserPDF417Reader;\n exports.BrowserQRCodeReader = BrowserQRCodeReader;\n exports.BrowserQRCodeSvgWriter = BrowserQRCodeSvgWriter;\n exports.CharacterSetECI = CharacterSetECI;\n exports.ChecksumException = ChecksumException;\n exports.Code128Reader = Code128Reader;\n exports.Code39Reader = Code39Reader;\n exports.DataMatrixDecodedBitStreamParser = DecodedBitStreamParser;\n exports.DataMatrixReader = DataMatrixReader;\n exports.DecodeHintType = DecodeHintType$1;\n exports.DecoderResult = DecoderResult;\n exports.DefaultGridSampler = DefaultGridSampler;\n exports.DetectorResult = DetectorResult;\n exports.EAN13Reader = EAN13Reader;\n exports.EncodeHintType = EncodeHintType$1;\n exports.Exception = Exception;\n exports.FormatException = FormatException;\n exports.GenericGF = GenericGF;\n exports.GenericGFPoly = GenericGFPoly;\n exports.GlobalHistogramBinarizer = GlobalHistogramBinarizer;\n exports.GridSampler = GridSampler;\n exports.GridSamplerInstance = GridSamplerInstance;\n exports.HTMLCanvasElementLuminanceSource = HTMLCanvasElementLuminanceSource;\n exports.HybridBinarizer = HybridBinarizer;\n exports.ITFReader = ITFReader;\n exports.IllegalArgumentException = IllegalArgumentException;\n exports.IllegalStateException = IllegalStateException;\n exports.InvertedLuminanceSource = InvertedLuminanceSource;\n exports.LuminanceSource = LuminanceSource;\n exports.MathUtils = MathUtils;\n exports.MultiFormatOneDReader = MultiFormatOneDReader;\n exports.MultiFormatReader = MultiFormatReader;\n exports.MultiFormatWriter = MultiFormatWriter;\n exports.NotFoundException = NotFoundException;\n exports.OneDReader = OneDReader;\n exports.PDF417DecodedBitStreamParser = DecodedBitStreamParser$2;\n exports.PDF417DecoderErrorCorrection = ErrorCorrection;\n exports.PDF417Reader = PDF417Reader;\n exports.PDF417ResultMetadata = PDF417ResultMetadata;\n exports.PerspectiveTransform = PerspectiveTransform;\n exports.PlanarYUVLuminanceSource = PlanarYUVLuminanceSource;\n exports.QRCodeByteMatrix = ByteMatrix;\n exports.QRCodeDataMask = DataMask;\n exports.QRCodeDecodedBitStreamParser = DecodedBitStreamParser$1;\n exports.QRCodeDecoderErrorCorrectionLevel = ErrorCorrectionLevel;\n exports.QRCodeDecoderFormatInformation = FormatInformation;\n exports.QRCodeEncoder = Encoder;\n exports.QRCodeEncoderQRCode = QRCode;\n exports.QRCodeMaskUtil = MaskUtil;\n exports.QRCodeMatrixUtil = MatrixUtil;\n exports.QRCodeMode = Mode$1;\n exports.QRCodeReader = QRCodeReader;\n exports.QRCodeVersion = Version$1;\n exports.QRCodeWriter = QRCodeWriter;\n exports.RGBLuminanceSource = RGBLuminanceSource;\n exports.RSS14Reader = RSS14Reader;\n exports.RSSExpandedReader = RSSExpandedReader;\n exports.ReaderException = ReaderException;\n exports.ReedSolomonDecoder = ReedSolomonDecoder;\n exports.ReedSolomonEncoder = ReedSolomonEncoder;\n exports.ReedSolomonException = ReedSolomonException;\n exports.Result = Result;\n exports.ResultMetadataType = ResultMetadataType$1;\n exports.ResultPoint = ResultPoint;\n exports.StringUtils = StringUtils;\n exports.UnsupportedOperationException = UnsupportedOperationException;\n exports.VideoInputDevice = VideoInputDevice;\n exports.WhiteRectangleDetector = WhiteRectangleDetector;\n exports.WriterException = WriterException;\n exports.ZXingArrays = Arrays;\n exports.ZXingCharset = Charset;\n exports.ZXingInteger = Integer;\n exports.ZXingStandardCharsets = StandardCharsets;\n exports.ZXingStringBuilder = StringBuilder;\n exports.ZXingStringEncoding = StringEncoding;\n exports.ZXingSystem = System;\n\n Object.defineProperty(exports, '__esModule', { value: true });\n\n})));\n//# sourceMappingURL=index.js.map\n","/**\n * @license React\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),ca=require(\"scheduler\");function p(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;cb}return!1}function v(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var z={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){z[a]=new v(a,0,!1,a,null,!1,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];z[b]=new v(b,1,!1,a[1],null,!1,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){z[a]=new v(a,2,!1,a.toLowerCase(),null,!1,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){z[a]=new v(a,2,!1,a,null,!1,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){z[a]=new v(a,3,!1,a.toLowerCase(),null,!1,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){z[a]=new v(a,3,!0,a,null,!1,!1)});[\"capture\",\"download\"].forEach(function(a){z[a]=new v(a,4,!1,a,null,!1,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){z[a]=new v(a,6,!1,a,null,!1,!1)});[\"rowSpan\",\"start\"].forEach(function(a){z[a]=new v(a,5,!1,a.toLowerCase(),null,!1,!1)});var ra=/[\\-:]([a-z])/g;function sa(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(ra,\nsa);z[b]=new v(b,1,!1,a,null,!1,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1,!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1,!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!1,!1)});\nz.xlinkHref=new v(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0,!1);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!0,!0)});\nfunction ta(a,b,c,d){var e=z.hasOwnProperty(b)?z[b]:null;if(null!==e?0!==e.type:d||!(2h||e[g]!==f[h]){var k=\"\\n\"+e[g].replace(\" at new \",\" at \");a.displayName&&k.includes(\"\")&&(k=k.replace(\"\",a.displayName));return k}while(1<=g&&0<=h)}break}}}finally{Na=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:\"\")?Ma(a):\"\"}\nfunction Pa(a){switch(a.tag){case 5:return Ma(a.type);case 16:return Ma(\"Lazy\");case 13:return Ma(\"Suspense\");case 19:return Ma(\"SuspenseList\");case 0:case 2:case 15:return a=Oa(a.type,!1),a;case 11:return a=Oa(a.type.render,!1),a;case 1:return a=Oa(a.type,!0),a;default:return\"\"}}\nfunction Qa(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case ya:return\"Fragment\";case wa:return\"Portal\";case Aa:return\"Profiler\";case za:return\"StrictMode\";case Ea:return\"Suspense\";case Fa:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case Ca:return(a.displayName||\"Context\")+\".Consumer\";case Ba:return(a._context.displayName||\"Context\")+\".Provider\";case Da:var b=a.render;a=a.displayName;a||(a=b.displayName||\nb.name||\"\",a=\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");return a;case Ga:return b=a.displayName||null,null!==b?b:Qa(a.type)||\"Memo\";case Ha:b=a._payload;a=a._init;try{return Qa(a(b))}catch(c){}}return null}\nfunction Ra(a){var b=a.type;switch(a.tag){case 24:return\"Cache\";case 9:return(b.displayName||\"Context\")+\".Consumer\";case 10:return(b._context.displayName||\"Context\")+\".Provider\";case 18:return\"DehydratedFragment\";case 11:return a=b.render,a=a.displayName||a.name||\"\",b.displayName||(\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");case 7:return\"Fragment\";case 5:return b;case 4:return\"Portal\";case 3:return\"Root\";case 6:return\"Text\";case 16:return Qa(b);case 8:return b===za?\"StrictMode\":\"Mode\";case 22:return\"Offscreen\";\ncase 12:return\"Profiler\";case 21:return\"Scope\";case 13:return\"Suspense\";case 19:return\"SuspenseList\";case 25:return\"TracingMarker\";case 1:case 0:case 17:case 2:case 14:case 15:if(\"function\"===typeof b)return b.displayName||b.name||null;if(\"string\"===typeof b)return b}return null}function Sa(a){switch(typeof a){case \"boolean\":case \"number\":case \"string\":case \"undefined\":return a;case \"object\":return a;default:return\"\"}}\nfunction Ta(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction Ua(a){var b=Ta(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=Ta(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}\nfunction Ya(a,b){var c=b.checked;return A({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function ab(a,b){b=b.checked;null!=b&&ta(a,\"checked\",b,!1)}\nfunction bb(a,b){ab(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?cb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&cb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction db(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction cb(a,b,c){if(\"number\"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}var eb=Array.isArray;\nfunction fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e\"+b.valueOf().toString()+\"\";for(b=mb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction ob(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}\nvar pb={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,\nzoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},qb=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(pb).forEach(function(a){qb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);pb[b]=pb[a]})});function rb(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||pb.hasOwnProperty(a)&&pb[a]?(\"\"+b).trim():b+\"px\"}\nfunction sb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=rb(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var tb=A({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction ub(a,b){if(b){if(tb[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(p(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(p(60));if(\"object\"!==typeof b.dangerouslySetInnerHTML||!(\"__html\"in b.dangerouslySetInnerHTML))throw Error(p(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(p(62));}}\nfunction vb(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}var wb=null;function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;\nfunction Bb(a){if(a=Cb(a)){if(\"function\"!==typeof yb)throw Error(p(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;a>>=0;return 0===a?32:31-(pc(a)/qc|0)|0}var rc=64,sc=4194304;\nfunction tc(a){switch(a&-a){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return a&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return a&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;\ndefault:return a}}function uc(a,b){var c=a.pendingLanes;if(0===c)return 0;var d=0,e=a.suspendedLanes,f=a.pingedLanes,g=c&268435455;if(0!==g){var h=g&~e;0!==h?d=tc(h):(f&=g,0!==f&&(d=tc(f)))}else g=c&~e,0!==g?d=tc(g):0!==f&&(d=tc(f));if(0===d)return 0;if(0!==b&&b!==d&&0===(b&e)&&(e=d&-d,f=b&-b,e>=f||16===e&&0!==(f&4194240)))return b;0!==(d&4)&&(d|=c&16);b=a.entangledLanes;if(0!==b)for(a=a.entanglements,b&=d;0c;c++)b.push(a);return b}\nfunction Ac(a,b,c){a.pendingLanes|=b;536870912!==b&&(a.suspendedLanes=0,a.pingedLanes=0);a=a.eventTimes;b=31-oc(b);a[b]=c}function Bc(a,b){var c=a.pendingLanes&~b;a.pendingLanes=b;a.suspendedLanes=0;a.pingedLanes=0;a.expiredLanes&=b;a.mutableReadLanes&=b;a.entangledLanes&=b;b=a.entanglements;var d=a.eventTimes;for(a=a.expirationTimes;0=be),ee=String.fromCharCode(32),fe=!1;\nfunction ge(a,b){switch(a){case \"keyup\":return-1!==$d.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"focusout\":return!0;default:return!1}}function he(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case \"compositionend\":return he(b);case \"keypress\":if(32!==b.which)return null;fe=!0;return ee;case \"textInput\":return a=b.data,a===ee&&fe?null:a;default:return null}}\nfunction ke(a,b){if(ie)return\"compositionend\"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Je(c)}}function Le(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Le(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}\nfunction Me(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Ne(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}\nfunction Oe(a){var b=Me(),c=a.focusedElem,d=a.selectionRange;if(b!==c&&c&&c.ownerDocument&&Le(c.ownerDocument.documentElement,c)){if(null!==d&&Ne(c))if(b=d.start,a=d.end,void 0===a&&(a=b),\"selectionStart\"in c)c.selectionStart=b,c.selectionEnd=Math.min(a,c.value.length);else if(a=(b=c.ownerDocument||document)&&b.defaultView||window,a.getSelection){a=a.getSelection();var e=c.textContent.length,f=Math.min(d.start,e);d=void 0===d.end?f:Math.min(d.end,e);!a.extend&&f>d&&(e=d,d=f,f=e);e=Ke(c,f);var g=Ke(c,\nd);e&&g&&(1!==a.rangeCount||a.anchorNode!==e.node||a.anchorOffset!==e.offset||a.focusNode!==g.node||a.focusOffset!==g.offset)&&(b=b.createRange(),b.setStart(e.node,e.offset),a.removeAllRanges(),f>d?(a.addRange(b),a.extend(g.node,g.offset)):(b.setEnd(g.node,g.offset),a.addRange(b)))}b=[];for(a=c;a=a.parentNode;)1===a.nodeType&&b.push({element:a,left:a.scrollLeft,top:a.scrollTop});\"function\"===typeof c.focus&&c.focus();for(c=0;c=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;\nfunction Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,\"selectionStart\"in d&&Ne(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Ie(Se,d)||(Se=d,d=oe(Re,\"onSelect\"),0Tf||(a.current=Sf[Tf],Sf[Tf]=null,Tf--)}function G(a,b){Tf++;Sf[Tf]=a.current;a.current=b}var Vf={},H=Uf(Vf),Wf=Uf(!1),Xf=Vf;function Yf(a,b){var c=a.type.contextTypes;if(!c)return Vf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}\nfunction Zf(a){a=a.childContextTypes;return null!==a&&void 0!==a}function $f(){E(Wf);E(H)}function ag(a,b,c){if(H.current!==Vf)throw Error(p(168));G(H,b);G(Wf,c)}function bg(a,b,c){var d=a.stateNode;b=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in b))throw Error(p(108,Ra(a)||\"Unknown\",e));return A({},c,d)}\nfunction cg(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Vf;Xf=H.current;G(H,a);G(Wf,Wf.current);return!0}function dg(a,b,c){var d=a.stateNode;if(!d)throw Error(p(169));c?(a=bg(a,b,Xf),d.__reactInternalMemoizedMergedChildContext=a,E(Wf),E(H),G(H,a)):E(Wf);G(Wf,c)}var eg=null,fg=!1,gg=!1;function hg(a){null===eg?eg=[a]:eg.push(a)}function ig(a){fg=!0;hg(a)}\nfunction jg(){if(!gg&&null!==eg){gg=!0;var a=0,b=C;try{var c=eg;for(C=1;a>=g;e-=g;rg=1<<32-oc(b)+e|c<w?(x=u,u=null):x=u.sibling;var n=r(e,u,h[w],k);if(null===n){null===u&&(u=x);break}a&&u&&null===n.alternate&&b(e,u);g=f(n,g,w);null===m?l=n:m.sibling=n;m=n;u=x}if(w===h.length)return c(e,u),I&&tg(e,w),l;if(null===u){for(;ww?(x=m,m=null):x=m.sibling;var t=r(e,m,n.value,k);if(null===t){null===m&&(m=x);break}a&&m&&null===t.alternate&&b(e,m);g=f(t,g,w);null===u?l=t:u.sibling=t;u=t;m=x}if(n.done)return c(e,\nm),I&&tg(e,w),l;if(null===m){for(;!n.done;w++,n=h.next())n=q(e,n.value,k),null!==n&&(g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);I&&tg(e,w);return l}for(m=d(e,m);!n.done;w++,n=h.next())n=y(m,e,w,n.value,k),null!==n&&(a&&null!==n.alternate&&m.delete(null===n.key?w:n.key),g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);a&&m.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function J(a,d,f,h){\"object\"===typeof f&&null!==f&&f.type===ya&&null===f.key&&(f=f.props.children);if(\"object\"===typeof f&&null!==f){switch(f.$$typeof){case va:a:{for(var k=\nf.key,l=d;null!==l;){if(l.key===k){k=f.type;if(k===ya){if(7===l.tag){c(a,l.sibling);d=e(l,f.props.children);d.return=a;a=d;break a}}else if(l.elementType===k||\"object\"===typeof k&&null!==k&&k.$$typeof===Ha&&uh(k)===l.type){c(a,l.sibling);d=e(l,f.props);d.ref=sh(a,l,f);d.return=a;a=d;break a}c(a,l);break}else b(a,l);l=l.sibling}f.type===ya?(d=Ah(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=yh(f.type,f.key,f.props,null,a.mode,h),h.ref=sh(a,d,f),h.return=a,a=h)}return g(a);case wa:a:{for(l=f.key;null!==\nd;){if(d.key===l)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=zh(f,a.mode,h);d.return=a;a=d}return g(a);case Ha:return l=f._init,J(a,d,l(f._payload),h)}if(eb(f))return n(a,d,f,h);if(Ka(f))return t(a,d,f,h);th(a,f)}return\"string\"===typeof f&&\"\"!==f||\"number\"===typeof f?(f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):\n(c(a,d),d=xh(f,a.mode,h),d.return=a,a=d),g(a)):c(a,d)}return J}var Bh=vh(!0),Ch=vh(!1),Dh={},Eh=Uf(Dh),Fh=Uf(Dh),Gh=Uf(Dh);function Hh(a){if(a===Dh)throw Error(p(174));return a}function Ih(a,b){G(Gh,b);G(Fh,a);G(Eh,Dh);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:lb(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=lb(b,a)}E(Eh);G(Eh,b)}function Jh(){E(Eh);E(Fh);E(Gh)}\nfunction Kh(a){Hh(Gh.current);var b=Hh(Eh.current);var c=lb(b,a.type);b!==c&&(G(Fh,a),G(Eh,c))}function Lh(a){Fh.current===a&&(E(Eh),E(Fh))}var M=Uf(0);\nfunction Mh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||\"$?\"===c.data||\"$!\"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&128))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var Nh=[];\nfunction Oh(){for(var a=0;ac?c:4;a(!0);var d=Qh.transition;Qh.transition={};try{a(!1),b()}finally{C=c,Qh.transition=d}}function Fi(){return di().memoizedState}\nfunction Gi(a,b,c){var d=lh(a);c={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,c);else if(c=Yg(a,b,c,d),null!==c){var e=L();mh(c,a,d,e);Ji(c,b,d)}}\nfunction ri(a,b,c){var d=lh(a),e={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,e);else{var f=a.alternate;if(0===a.lanes&&(null===f||0===f.lanes)&&(f=b.lastRenderedReducer,null!==f))try{var g=b.lastRenderedState,h=f(g,c);e.hasEagerState=!0;e.eagerState=h;if(He(h,g)){var k=b.interleaved;null===k?(e.next=e,Xg(b)):(e.next=k.next,k.next=e);b.interleaved=e;return}}catch(l){}finally{}c=Yg(a,b,e,d);null!==c&&(e=L(),mh(c,a,d,e),Ji(c,b,d))}}\nfunction Hi(a){var b=a.alternate;return a===N||null!==b&&b===N}function Ii(a,b){Th=Sh=!0;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}function Ji(a,b,c){if(0!==(c&4194240)){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}\nvar ai={readContext:Vg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useInsertionEffect:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useDeferredValue:Q,useTransition:Q,useMutableSource:Q,useSyncExternalStore:Q,useId:Q,unstable_isNewReconciler:!1},Yh={readContext:Vg,useCallback:function(a,b){ci().memoizedState=[a,void 0===b?null:b];return a},useContext:Vg,useEffect:vi,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ti(4194308,\n4,yi.bind(null,b,a),c)},useLayoutEffect:function(a,b){return ti(4194308,4,a,b)},useInsertionEffect:function(a,b){return ti(4,2,a,b)},useMemo:function(a,b){var c=ci();b=void 0===b?null:b;a=a();c.memoizedState=[a,b];return a},useReducer:function(a,b,c){var d=ci();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};d.queue=a;a=a.dispatch=Gi.bind(null,N,a);return[d.memoizedState,a]},useRef:function(a){var b=\nci();a={current:a};return b.memoizedState=a},useState:qi,useDebugValue:Ai,useDeferredValue:function(a){return ci().memoizedState=a},useTransition:function(){var a=qi(!1),b=a[0];a=Ei.bind(null,a[1]);ci().memoizedState=a;return[b,a]},useMutableSource:function(){},useSyncExternalStore:function(a,b,c){var d=N,e=ci();if(I){if(void 0===c)throw Error(p(407));c=c()}else{c=b();if(null===R)throw Error(p(349));0!==(Rh&30)||ni(d,b,c)}e.memoizedState=c;var f={value:c,getSnapshot:b};e.queue=f;vi(ki.bind(null,d,\nf,a),[a]);d.flags|=2048;li(9,mi.bind(null,d,f,c,b),void 0,null);return c},useId:function(){var a=ci(),b=R.identifierPrefix;if(I){var c=sg;var d=rg;c=(d&~(1<<32-oc(d)-1)).toString(32)+c;b=\":\"+b+\"R\"+c;c=Uh++;0\\x3c/script>\",a=a.removeChild(a.firstChild)):\n\"string\"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),\"select\"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[Of]=b;a[Pf]=d;Aj(a,b,!1,!1);b.stateNode=a;a:{g=vb(c,d);switch(c){case \"dialog\":D(\"cancel\",a);D(\"close\",a);e=d;break;case \"iframe\":case \"object\":case \"embed\":D(\"load\",a);e=d;break;case \"video\":case \"audio\":for(e=0;eHj&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304)}else{if(!d)if(a=Mh(g),null!==a){if(b.flags|=128,d=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Ej(f,!0),null===f.tail&&\"hidden\"===f.tailMode&&!g.alternate&&!I)return S(b),null}else 2*B()-f.renderingStartTime>Hj&&1073741824!==c&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304);f.isBackwards?(g.sibling=b.child,b.child=g):(c=f.last,null!==c?c.sibling=g:b.child=g,f.last=g)}if(null!==f.tail)return b=f.tail,f.rendering=\nb,f.tail=b.sibling,f.renderingStartTime=B(),b.sibling=null,c=M.current,G(M,d?c&1|2:c&1),b;S(b);return null;case 22:case 23:return Ij(),d=null!==b.memoizedState,null!==a&&null!==a.memoizedState!==d&&(b.flags|=8192),d&&0!==(b.mode&1)?0!==(gj&1073741824)&&(S(b),b.subtreeFlags&6&&(b.flags|=8192)):S(b),null;case 24:return null;case 25:return null}throw Error(p(156,b.tag));}\nfunction Jj(a,b){wg(b);switch(b.tag){case 1:return Zf(b.type)&&$f(),a=b.flags,a&65536?(b.flags=a&-65537|128,b):null;case 3:return Jh(),E(Wf),E(H),Oh(),a=b.flags,0!==(a&65536)&&0===(a&128)?(b.flags=a&-65537|128,b):null;case 5:return Lh(b),null;case 13:E(M);a=b.memoizedState;if(null!==a&&null!==a.dehydrated){if(null===b.alternate)throw Error(p(340));Ig()}a=b.flags;return a&65536?(b.flags=a&-65537|128,b):null;case 19:return E(M),null;case 4:return Jh(),null;case 10:return Rg(b.type._context),null;case 22:case 23:return Ij(),\nnull;case 24:return null;default:return null}}var Kj=!1,U=!1,Lj=\"function\"===typeof WeakSet?WeakSet:Set,V=null;function Mj(a,b){var c=a.ref;if(null!==c)if(\"function\"===typeof c)try{c(null)}catch(d){W(a,b,d)}else c.current=null}function Nj(a,b,c){try{c()}catch(d){W(a,b,d)}}var Oj=!1;\nfunction Pj(a,b){Cf=dd;a=Me();if(Ne(a)){if(\"selectionStart\"in a)var c={start:a.selectionStart,end:a.selectionEnd};else a:{c=(c=a.ownerDocument)&&c.defaultView||window;var d=c.getSelection&&c.getSelection();if(d&&0!==d.rangeCount){c=d.anchorNode;var e=d.anchorOffset,f=d.focusNode;d=d.focusOffset;try{c.nodeType,f.nodeType}catch(F){c=null;break a}var g=0,h=-1,k=-1,l=0,m=0,q=a,r=null;b:for(;;){for(var y;;){q!==c||0!==e&&3!==q.nodeType||(h=g+e);q!==f||0!==d&&3!==q.nodeType||(k=g+d);3===q.nodeType&&(g+=\nq.nodeValue.length);if(null===(y=q.firstChild))break;r=q;q=y}for(;;){if(q===a)break b;r===c&&++l===e&&(h=g);r===f&&++m===d&&(k=g);if(null!==(y=q.nextSibling))break;q=r;r=q.parentNode}q=y}c=-1===h||-1===k?null:{start:h,end:k}}else c=null}c=c||{start:0,end:0}}else c=null;Df={focusedElem:a,selectionRange:c};dd=!1;for(V=b;null!==V;)if(b=V,a=b.child,0!==(b.subtreeFlags&1028)&&null!==a)a.return=b,V=a;else for(;null!==V;){b=V;try{var n=b.alternate;if(0!==(b.flags&1024))switch(b.tag){case 0:case 11:case 15:break;\ncase 1:if(null!==n){var t=n.memoizedProps,J=n.memoizedState,x=b.stateNode,w=x.getSnapshotBeforeUpdate(b.elementType===b.type?t:Lg(b.type,t),J);x.__reactInternalSnapshotBeforeUpdate=w}break;case 3:var u=b.stateNode.containerInfo;1===u.nodeType?u.textContent=\"\":9===u.nodeType&&u.documentElement&&u.removeChild(u.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(p(163));}}catch(F){W(b,b.return,F)}a=b.sibling;if(null!==a){a.return=b.return;V=a;break}V=b.return}n=Oj;Oj=!1;return n}\nfunction Qj(a,b,c){var d=b.updateQueue;d=null!==d?d.lastEffect:null;if(null!==d){var e=d=d.next;do{if((e.tag&a)===a){var f=e.destroy;e.destroy=void 0;void 0!==f&&Nj(b,c,f)}e=e.next}while(e!==d)}}function Rj(a,b){b=b.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){var c=b=b.next;do{if((c.tag&a)===a){var d=c.create;c.destroy=d()}c=c.next}while(c!==b)}}function Sj(a){var b=a.ref;if(null!==b){var c=a.stateNode;switch(a.tag){case 5:a=c;break;default:a=c}\"function\"===typeof b?b(a):b.current=a}}\nfunction Tj(a){var b=a.alternate;null!==b&&(a.alternate=null,Tj(b));a.child=null;a.deletions=null;a.sibling=null;5===a.tag&&(b=a.stateNode,null!==b&&(delete b[Of],delete b[Pf],delete b[of],delete b[Qf],delete b[Rf]));a.stateNode=null;a.return=null;a.dependencies=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.stateNode=null;a.updateQueue=null}function Uj(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction Vj(a){a:for(;;){for(;null===a.sibling;){if(null===a.return||Uj(a.return))return null;a=a.return}a.sibling.return=a.return;for(a=a.sibling;5!==a.tag&&6!==a.tag&&18!==a.tag;){if(a.flags&2)continue a;if(null===a.child||4===a.tag)continue a;else a.child.return=a,a=a.child}if(!(a.flags&2))return a.stateNode}}\nfunction Wj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=Bf));else if(4!==d&&(a=a.child,null!==a))for(Wj(a,b,c),a=a.sibling;null!==a;)Wj(a,b,c),a=a.sibling}\nfunction Xj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(Xj(a,b,c),a=a.sibling;null!==a;)Xj(a,b,c),a=a.sibling}var X=null,Yj=!1;function Zj(a,b,c){for(c=c.child;null!==c;)ak(a,b,c),c=c.sibling}\nfunction ak(a,b,c){if(lc&&\"function\"===typeof lc.onCommitFiberUnmount)try{lc.onCommitFiberUnmount(kc,c)}catch(h){}switch(c.tag){case 5:U||Mj(c,b);case 6:var d=X,e=Yj;X=null;Zj(a,b,c);X=d;Yj=e;null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?a.parentNode.removeChild(c):a.removeChild(c)):X.removeChild(c.stateNode));break;case 18:null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?Kf(a.parentNode,c):1===a.nodeType&&Kf(a,c),bd(a)):Kf(X,c.stateNode));break;case 4:d=X;e=Yj;X=c.stateNode.containerInfo;Yj=!0;\nZj(a,b,c);X=d;Yj=e;break;case 0:case 11:case 14:case 15:if(!U&&(d=c.updateQueue,null!==d&&(d=d.lastEffect,null!==d))){e=d=d.next;do{var f=e,g=f.destroy;f=f.tag;void 0!==g&&(0!==(f&2)?Nj(c,b,g):0!==(f&4)&&Nj(c,b,g));e=e.next}while(e!==d)}Zj(a,b,c);break;case 1:if(!U&&(Mj(c,b),d=c.stateNode,\"function\"===typeof d.componentWillUnmount))try{d.props=c.memoizedProps,d.state=c.memoizedState,d.componentWillUnmount()}catch(h){W(c,b,h)}Zj(a,b,c);break;case 21:Zj(a,b,c);break;case 22:c.mode&1?(U=(d=U)||null!==\nc.memoizedState,Zj(a,b,c),U=d):Zj(a,b,c);break;default:Zj(a,b,c)}}function bk(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Lj);b.forEach(function(b){var d=ck.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}\nfunction dk(a,b){var c=b.deletions;if(null!==c)for(var d=0;de&&(e=g);d&=~f}d=e;d=B()-d;d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*mk(d/1960))-d;if(10a?16:a;if(null===xk)var d=!1;else{a=xk;xk=null;yk=0;if(0!==(K&6))throw Error(p(331));var e=K;K|=4;for(V=a.current;null!==V;){var f=V,g=f.child;if(0!==(V.flags&16)){var h=f.deletions;if(null!==h){for(var k=0;kB()-gk?Lk(a,0):sk|=c);Ek(a,b)}function Zk(a,b){0===b&&(0===(a.mode&1)?b=1:(b=sc,sc<<=1,0===(sc&130023424)&&(sc=4194304)));var c=L();a=Zg(a,b);null!==a&&(Ac(a,b,c),Ek(a,c))}function vj(a){var b=a.memoizedState,c=0;null!==b&&(c=b.retryLane);Zk(a,c)}\nfunction ck(a,b){var c=0;switch(a.tag){case 13:var d=a.stateNode;var e=a.memoizedState;null!==e&&(c=e.retryLane);break;case 19:d=a.stateNode;break;default:throw Error(p(314));}null!==d&&d.delete(b);Zk(a,c)}var Wk;\nWk=function(a,b,c){if(null!==a)if(a.memoizedProps!==b.pendingProps||Wf.current)Ug=!0;else{if(0===(a.lanes&c)&&0===(b.flags&128))return Ug=!1,zj(a,b,c);Ug=0!==(a.flags&131072)?!0:!1}else Ug=!1,I&&0!==(b.flags&1048576)&&ug(b,ng,b.index);b.lanes=0;switch(b.tag){case 2:var d=b.type;jj(a,b);a=b.pendingProps;var e=Yf(b,H.current);Tg(b,c);e=Xh(null,b,d,a,e,c);var f=bi();b.flags|=1;\"object\"===typeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof?(b.tag=1,b.memoizedState=null,b.updateQueue=\nnull,Zf(d)?(f=!0,cg(b)):f=!1,b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null,ah(b),e.updater=nh,b.stateNode=e,e._reactInternals=b,rh(b,d,a,c),b=kj(null,b,d,!0,f,c)):(b.tag=0,I&&f&&vg(b),Yi(null,b,e,c),b=b.child);return b;case 16:d=b.elementType;a:{jj(a,b);a=b.pendingProps;e=d._init;d=e(d._payload);b.type=d;e=b.tag=$k(d);a=Lg(d,a);switch(e){case 0:b=dj(null,b,d,a,c);break a;case 1:b=ij(null,b,d,a,c);break a;case 11:b=Zi(null,b,d,a,c);break a;case 14:b=aj(null,b,d,Lg(d.type,a),c);break a}throw Error(p(306,\nd,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),dj(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),ij(a,b,d,e,c);case 3:a:{lj(b);if(null===a)throw Error(p(387));d=b.pendingProps;f=b.memoizedState;e=f.element;bh(a,b);gh(b,d,null,c);var g=b.memoizedState;d=g.element;if(f.isDehydrated)if(f={element:d,isDehydrated:!1,cache:g.cache,pendingSuspenseBoundaries:g.pendingSuspenseBoundaries,transitions:g.transitions},b.updateQueue.baseState=\nf,b.memoizedState=f,b.flags&256){e=Ki(Error(p(423)),b);b=mj(a,b,d,c,e);break a}else if(d!==e){e=Ki(Error(p(424)),b);b=mj(a,b,d,c,e);break a}else for(yg=Lf(b.stateNode.containerInfo.firstChild),xg=b,I=!0,zg=null,c=Ch(b,null,d,c),b.child=c;c;)c.flags=c.flags&-3|4096,c=c.sibling;else{Ig();if(d===e){b=$i(a,b,c);break a}Yi(a,b,d,c)}b=b.child}return b;case 5:return Kh(b),null===a&&Eg(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,Ef(d,e)?g=null:null!==f&&Ef(d,f)&&(b.flags|=32),\nhj(a,b),Yi(a,b,g,c),b.child;case 6:return null===a&&Eg(b),null;case 13:return pj(a,b,c);case 4:return Ih(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Bh(b,null,d,c):Yi(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),Zi(a,b,d,e,c);case 7:return Yi(a,b,b.pendingProps,c),b.child;case 8:return Yi(a,b,b.pendingProps.children,c),b.child;case 12:return Yi(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;f=b.memoizedProps;\ng=e.value;G(Mg,d._currentValue);d._currentValue=g;if(null!==f)if(He(f.value,g)){if(f.children===e.children&&!Wf.current){b=$i(a,b,c);break a}}else for(f=b.child,null!==f&&(f.return=b);null!==f;){var h=f.dependencies;if(null!==h){g=f.child;for(var k=h.firstContext;null!==k;){if(k.context===d){if(1===f.tag){k=ch(-1,c&-c);k.tag=2;var l=f.updateQueue;if(null!==l){l=l.shared;var m=l.pending;null===m?k.next=k:(k.next=m.next,m.next=k);l.pending=k}}f.lanes|=c;k=f.alternate;null!==k&&(k.lanes|=c);Sg(f.return,\nc,b);h.lanes|=c;break}k=k.next}}else if(10===f.tag)g=f.type===b.type?null:f.child;else if(18===f.tag){g=f.return;if(null===g)throw Error(p(341));g.lanes|=c;h=g.alternate;null!==h&&(h.lanes|=c);Sg(g,c,b);g=f.sibling}else g=f.child;if(null!==g)g.return=f;else for(g=f;null!==g;){if(g===b){g=null;break}f=g.sibling;if(null!==f){f.return=g.return;g=f;break}g=g.return}f=g}Yi(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,d=b.pendingProps.children,Tg(b,c),e=Vg(e),d=d(e),b.flags|=1,Yi(a,b,d,c),\nb.child;case 14:return d=b.type,e=Lg(d,b.pendingProps),e=Lg(d.type,e),aj(a,b,d,e,c);case 15:return cj(a,b,b.type,b.pendingProps,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),jj(a,b),b.tag=1,Zf(d)?(a=!0,cg(b)):a=!1,Tg(b,c),ph(b,d,e),rh(b,d,e,c),kj(null,b,d,!0,a,c);case 19:return yj(a,b,c);case 22:return ej(a,b,c)}throw Error(p(156,b.tag));};function Gk(a,b){return ac(a,b)}\nfunction al(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.subtreeFlags=this.flags=0;this.deletions=null;this.childLanes=this.lanes=0;this.alternate=null}function Bg(a,b,c,d){return new al(a,b,c,d)}function bj(a){a=a.prototype;return!(!a||!a.isReactComponent)}\nfunction $k(a){if(\"function\"===typeof a)return bj(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Da)return 11;if(a===Ga)return 14}return 2}\nfunction wh(a,b){var c=a.alternate;null===c?(c=Bg(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.type=a.type,c.flags=0,c.subtreeFlags=0,c.deletions=null);c.flags=a.flags&14680064;c.childLanes=a.childLanes;c.lanes=a.lanes;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{lanes:b.lanes,firstContext:b.firstContext};\nc.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction yh(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)bj(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case ya:return Ah(c.children,e,f,b);case za:g=8;e|=8;break;case Aa:return a=Bg(12,c,b,e|2),a.elementType=Aa,a.lanes=f,a;case Ea:return a=Bg(13,c,b,e),a.elementType=Ea,a.lanes=f,a;case Fa:return a=Bg(19,c,b,e),a.elementType=Fa,a.lanes=f,a;case Ia:return qj(c,e,f,b);default:if(\"object\"===typeof a&&null!==a)switch(a.$$typeof){case Ba:g=10;break a;case Ca:g=9;break a;case Da:g=11;\nbreak a;case Ga:g=14;break a;case Ha:g=16;d=null;break a}throw Error(p(130,null==a?a:typeof a,\"\"));}b=Bg(g,c,b,e);b.elementType=a;b.type=d;b.lanes=f;return b}function Ah(a,b,c,d){a=Bg(7,a,d,b);a.lanes=c;return a}function qj(a,b,c,d){a=Bg(22,a,d,b);a.elementType=Ia;a.lanes=c;a.stateNode={isHidden:!1};return a}function xh(a,b,c){a=Bg(6,a,null,b);a.lanes=c;return a}\nfunction zh(a,b,c){b=Bg(4,null!==a.children?a.children:[],a.key,b);b.lanes=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction bl(a,b,c,d,e){this.tag=b;this.containerInfo=a;this.finishedWork=this.pingCache=this.current=this.pendingChildren=null;this.timeoutHandle=-1;this.callbackNode=this.pendingContext=this.context=null;this.callbackPriority=0;this.eventTimes=zc(0);this.expirationTimes=zc(-1);this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0;this.entanglements=zc(0);this.identifierPrefix=d;this.onRecoverableError=e;this.mutableSourceEagerHydrationData=\nnull}function cl(a,b,c,d,e,f,g,h,k){a=new bl(a,b,c,h,k);1===b?(b=1,!0===f&&(b|=8)):b=0;f=Bg(3,null,null,b);a.current=f;f.stateNode=a;f.memoizedState={element:d,isDehydrated:c,cache:null,transitions:null,pendingSuspenseBoundaries:null};ah(f);return a}function dl(a,b,c){var d=3>>1,e=a[d];if(0>>1;dg(C,c))ng(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(ng(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}\nfunction g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D=\"function\"===typeof setTimeout?setTimeout:null,E=\"function\"===typeof clearTimeout?clearTimeout:null,F=\"undefined\"!==typeof setImmediate?setImmediate:null;\n\"undefined\"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}\nfunction J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if(\"function\"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;\nfunction M(){return exports.unstable_now()-Qa||125d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};\nexports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n return arr2;\n}\nmodule.exports = _arrayLikeToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\nmodule.exports = _arrayWithHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}\nmodule.exports = _assertThisInitialized, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nmodule.exports = _classCallCheck, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nmodule.exports = _createClass, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nfunction _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n if (!it) {\n if (Array.isArray(o) || (it = unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n var F = function F() {};\n return {\n s: F,\n n: function n() {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function e(_e) {\n throw _e;\n },\n f: F\n };\n }\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function s() {\n it = it.call(o);\n },\n n: function n() {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function e(_e2) {\n didErr = true;\n err = _e2;\n },\n f: function f() {\n try {\n if (!normalCompletion && it[\"return\"] != null) it[\"return\"]();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n}\nmodule.exports = _createForOfIteratorHelper, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var getPrototypeOf = require(\"./getPrototypeOf.js\");\nvar isNativeReflectConstruct = require(\"./isNativeReflectConstruct.js\");\nvar possibleConstructorReturn = require(\"./possibleConstructorReturn.js\");\nfunction _createSuper(Derived) {\n var hasNativeReflectConstruct = isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = getPrototypeOf(Derived),\n result;\n if (hasNativeReflectConstruct) {\n var NewTarget = getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n return possibleConstructorReturn(this, result);\n };\n}\nmodule.exports = _createSuper, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var superPropBase = require(\"./superPropBase.js\");\nfunction _get() {\n if (typeof Reflect !== \"undefined\" && Reflect.get) {\n module.exports = _get = Reflect.get.bind(), module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n } else {\n module.exports = _get = function _get(target, property, receiver) {\n var base = superPropBase(target, property);\n if (!base) return;\n var desc = Object.getOwnPropertyDescriptor(base, property);\n if (desc.get) {\n return desc.get.call(arguments.length < 3 ? target : receiver);\n }\n return desc.value;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n }\n return _get.apply(this, arguments);\n}\nmodule.exports = _get, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _getPrototypeOf(o) {\n module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _getPrototypeOf(o);\n}\nmodule.exports = _getPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}\nmodule.exports = _inherits, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\nmodule.exports = _isNativeReflectConstruct, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n return _arr;\n}\nmodule.exports = _iterableToArrayLimit, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nmodule.exports = _nonIterableRest, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nvar assertThisInitialized = require(\"./assertThisInitialized.js\");\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return assertThisInitialized(self);\n}\nmodule.exports = _possibleConstructorReturn, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nfunction _regeneratorRuntime() {\n \"use strict\"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */\n module.exports = _regeneratorRuntime = function _regeneratorRuntime() {\n return exports;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n var exports = {},\n Op = Object.prototype,\n hasOwn = Op.hasOwnProperty,\n defineProperty = Object.defineProperty || function (obj, key, desc) {\n obj[key] = desc.value;\n },\n $Symbol = \"function\" == typeof Symbol ? Symbol : {},\n iteratorSymbol = $Symbol.iterator || \"@@iterator\",\n asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\",\n toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n function define(obj, key, value) {\n return Object.defineProperty(obj, key, {\n value: value,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }), obj[key];\n }\n try {\n define({}, \"\");\n } catch (err) {\n define = function define(obj, key, value) {\n return obj[key] = value;\n };\n }\n function wrap(innerFn, outerFn, self, tryLocsList) {\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator,\n generator = Object.create(protoGenerator.prototype),\n context = new Context(tryLocsList || []);\n return defineProperty(generator, \"_invoke\", {\n value: makeInvokeMethod(innerFn, self, context)\n }), generator;\n }\n function tryCatch(fn, obj, arg) {\n try {\n return {\n type: \"normal\",\n arg: fn.call(obj, arg)\n };\n } catch (err) {\n return {\n type: \"throw\",\n arg: err\n };\n }\n }\n exports.wrap = wrap;\n var ContinueSentinel = {};\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n var getProto = Object.getPrototypeOf,\n NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype);\n var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype);\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function (method) {\n define(prototype, method, function (arg) {\n return this._invoke(method, arg);\n });\n });\n }\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (\"throw\" !== record.type) {\n var result = record.arg,\n value = result.value;\n return value && \"object\" == _typeof(value) && hasOwn.call(value, \"__await\") ? PromiseImpl.resolve(value.__await).then(function (value) {\n invoke(\"next\", value, resolve, reject);\n }, function (err) {\n invoke(\"throw\", err, resolve, reject);\n }) : PromiseImpl.resolve(value).then(function (unwrapped) {\n result.value = unwrapped, resolve(result);\n }, function (error) {\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n reject(record.arg);\n }\n var previousPromise;\n defineProperty(this, \"_invoke\", {\n value: function value(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function (resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();\n }\n });\n }\n function makeInvokeMethod(innerFn, self, context) {\n var state = \"suspendedStart\";\n return function (method, arg) {\n if (\"executing\" === state) throw new Error(\"Generator is already running\");\n if (\"completed\" === state) {\n if (\"throw\" === method) throw arg;\n return doneResult();\n }\n for (context.method = method, context.arg = arg;;) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n if (\"next\" === context.method) context.sent = context._sent = context.arg;else if (\"throw\" === context.method) {\n if (\"suspendedStart\" === state) throw state = \"completed\", context.arg;\n context.dispatchException(context.arg);\n } else \"return\" === context.method && context.abrupt(\"return\", context.arg);\n state = \"executing\";\n var record = tryCatch(innerFn, self, context);\n if (\"normal\" === record.type) {\n if (state = context.done ? \"completed\" : \"suspendedYield\", record.arg === ContinueSentinel) continue;\n return {\n value: record.arg,\n done: context.done\n };\n }\n \"throw\" === record.type && (state = \"completed\", context.method = \"throw\", context.arg = record.arg);\n }\n };\n }\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (undefined === method) {\n if (context.delegate = null, \"throw\" === context.method) {\n if (delegate.iterator[\"return\"] && (context.method = \"return\", context.arg = undefined, maybeInvokeDelegate(delegate, context), \"throw\" === context.method)) return ContinueSentinel;\n context.method = \"throw\", context.arg = new TypeError(\"The iterator does not provide a 'throw' method\");\n }\n return ContinueSentinel;\n }\n var record = tryCatch(method, delegate.iterator, context.arg);\n if (\"throw\" === record.type) return context.method = \"throw\", context.arg = record.arg, context.delegate = null, ContinueSentinel;\n var info = record.arg;\n return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, \"return\" !== context.method && (context.method = \"next\", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = \"throw\", context.arg = new TypeError(\"iterator result is not an object\"), context.delegate = null, ContinueSentinel);\n }\n function pushTryEntry(locs) {\n var entry = {\n tryLoc: locs[0]\n };\n 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry);\n }\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\", delete record.arg, entry.completion = record;\n }\n function Context(tryLocsList) {\n this.tryEntries = [{\n tryLoc: \"root\"\n }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0);\n }\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) return iteratorMethod.call(iterable);\n if (\"function\" == typeof iterable.next) return iterable;\n if (!isNaN(iterable.length)) {\n var i = -1,\n next = function next() {\n for (; ++i < iterable.length;) {\n if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next;\n }\n return next.value = undefined, next.done = !0, next;\n };\n return next.next = next;\n }\n }\n return {\n next: doneResult\n };\n }\n function doneResult() {\n return {\n value: undefined,\n done: !0\n };\n }\n return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, \"constructor\", {\n value: GeneratorFunctionPrototype,\n configurable: !0\n }), defineProperty(GeneratorFunctionPrototype, \"constructor\", {\n value: GeneratorFunction,\n configurable: !0\n }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, \"GeneratorFunction\"), exports.isGeneratorFunction = function (genFun) {\n var ctor = \"function\" == typeof genFun && genFun.constructor;\n return !!ctor && (ctor === GeneratorFunction || \"GeneratorFunction\" === (ctor.displayName || ctor.name));\n }, exports.mark = function (genFun) {\n return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, \"GeneratorFunction\")), genFun.prototype = Object.create(Gp), genFun;\n }, exports.awrap = function (arg) {\n return {\n __await: arg\n };\n }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n void 0 === PromiseImpl && (PromiseImpl = Promise);\n var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl);\n return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) {\n return result.done ? result.value : iter.next();\n });\n }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, \"Generator\"), define(Gp, iteratorSymbol, function () {\n return this;\n }), define(Gp, \"toString\", function () {\n return \"[object Generator]\";\n }), exports.keys = function (val) {\n var object = Object(val),\n keys = [];\n for (var key in object) {\n keys.push(key);\n }\n return keys.reverse(), function next() {\n for (; keys.length;) {\n var key = keys.pop();\n if (key in object) return next.value = key, next.done = !1, next;\n }\n return next.done = !0, next;\n };\n }, exports.values = values, Context.prototype = {\n constructor: Context,\n reset: function reset(skipTempReset) {\n if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = \"next\", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) {\n \"t\" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined);\n }\n },\n stop: function stop() {\n this.done = !0;\n var rootRecord = this.tryEntries[0].completion;\n if (\"throw\" === rootRecord.type) throw rootRecord.arg;\n return this.rval;\n },\n dispatchException: function dispatchException(exception) {\n if (this.done) throw exception;\n var context = this;\n function handle(loc, caught) {\n return record.type = \"throw\", record.arg = exception, context.next = loc, caught && (context.method = \"next\", context.arg = undefined), !!caught;\n }\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i],\n record = entry.completion;\n if (\"root\" === entry.tryLoc) return handle(\"end\");\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\"),\n hasFinally = hasOwn.call(entry, \"finallyLoc\");\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n } else {\n if (!hasFinally) throw new Error(\"try statement without catch or finally\");\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n }\n }\n }\n },\n abrupt: function abrupt(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n finallyEntry && (\"break\" === type || \"continue\" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null);\n var record = finallyEntry ? finallyEntry.completion : {};\n return record.type = type, record.arg = arg, finallyEntry ? (this.method = \"next\", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record);\n },\n complete: function complete(record, afterLoc) {\n if (\"throw\" === record.type) throw record.arg;\n return \"break\" === record.type || \"continue\" === record.type ? this.next = record.arg : \"return\" === record.type ? (this.rval = this.arg = record.arg, this.method = \"return\", this.next = \"end\") : \"normal\" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel;\n },\n finish: function finish(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel;\n }\n },\n \"catch\": function _catch(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (\"throw\" === record.type) {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n throw new Error(\"illegal catch attempt\");\n },\n delegateYield: function delegateYield(iterable, resultName, nextLoc) {\n return this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n }, \"next\" === this.method && (this.arg = undefined), ContinueSentinel;\n }\n }, exports;\n}\nmodule.exports = _regeneratorRuntime, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _setPrototypeOf(o, p) {\n module.exports = _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _setPrototypeOf(o, p);\n}\nmodule.exports = _setPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayWithHoles = require(\"./arrayWithHoles.js\");\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit.js\");\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nvar nonIterableRest = require(\"./nonIterableRest.js\");\nfunction _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}\nmodule.exports = _slicedToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var getPrototypeOf = require(\"./getPrototypeOf.js\");\nfunction _superPropBase(object, property) {\n while (!Object.prototype.hasOwnProperty.call(object, property)) {\n object = getPrototypeOf(object);\n if (object === null) break;\n }\n return object;\n}\nmodule.exports = _superPropBase, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return (module.exports = _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports), _typeof(obj);\n}\nmodule.exports = _typeof, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}\nmodule.exports = _unsupportedIterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = function(chunkId) {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce(function(promises, key) {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"static/js/\" + chunkId + \".\" + \"709d397d\" + \".chunk.js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = function(chunkId) {\n\t// return url for filenames based on template\n\treturn undefined;\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","var inProgress = {};\nvar dataWebpackPrefix = \"makecode-arcade-kiosk:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = function(url, done, key, chunkId) {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = function(prev, event) {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach(function(fn) { return fn(event); });\n\t\tif(prev) return prev(event);\n\t}\n\t;\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"/static/kiosk/\";","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t179: 0\n};\n\n__webpack_require__.f.j = function(chunkId, promises) {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise(function(resolve, reject) { installedChunkData = installedChunks[chunkId] = [resolve, reject]; });\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = function(event) {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t} else installedChunks[chunkId] = 0;\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = function(parentChunkLoadingFunction, data) {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some(function(id) { return installedChunks[id] !== 0; })) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunkmakecode_arcade_kiosk\"] = self[\"webpackChunkmakecode_arcade_kiosk\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n return arr2;\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n return _arr;\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}","import defineProperty from \"./defineProperty.js\";\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n enumerableOnly && (symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n })), keys.push.apply(keys, symbols);\n }\n return keys;\n}\nexport default function _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = null != arguments[i] ? arguments[i] : {};\n i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {\n defineProperty(target, key, source[key]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}","export default function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj);\n}","import _typeof from \"./typeof.js\";\nexport default function _regeneratorRuntime() {\n \"use strict\"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */\n _regeneratorRuntime = function _regeneratorRuntime() {\n return exports;\n };\n var exports = {},\n Op = Object.prototype,\n hasOwn = Op.hasOwnProperty,\n defineProperty = Object.defineProperty || function (obj, key, desc) {\n obj[key] = desc.value;\n },\n $Symbol = \"function\" == typeof Symbol ? Symbol : {},\n iteratorSymbol = $Symbol.iterator || \"@@iterator\",\n asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\",\n toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n function define(obj, key, value) {\n return Object.defineProperty(obj, key, {\n value: value,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }), obj[key];\n }\n try {\n define({}, \"\");\n } catch (err) {\n define = function define(obj, key, value) {\n return obj[key] = value;\n };\n }\n function wrap(innerFn, outerFn, self, tryLocsList) {\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator,\n generator = Object.create(protoGenerator.prototype),\n context = new Context(tryLocsList || []);\n return defineProperty(generator, \"_invoke\", {\n value: makeInvokeMethod(innerFn, self, context)\n }), generator;\n }\n function tryCatch(fn, obj, arg) {\n try {\n return {\n type: \"normal\",\n arg: fn.call(obj, arg)\n };\n } catch (err) {\n return {\n type: \"throw\",\n arg: err\n };\n }\n }\n exports.wrap = wrap;\n var ContinueSentinel = {};\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n var getProto = Object.getPrototypeOf,\n NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype);\n var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype);\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function (method) {\n define(prototype, method, function (arg) {\n return this._invoke(method, arg);\n });\n });\n }\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (\"throw\" !== record.type) {\n var result = record.arg,\n value = result.value;\n return value && \"object\" == _typeof(value) && hasOwn.call(value, \"__await\") ? PromiseImpl.resolve(value.__await).then(function (value) {\n invoke(\"next\", value, resolve, reject);\n }, function (err) {\n invoke(\"throw\", err, resolve, reject);\n }) : PromiseImpl.resolve(value).then(function (unwrapped) {\n result.value = unwrapped, resolve(result);\n }, function (error) {\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n reject(record.arg);\n }\n var previousPromise;\n defineProperty(this, \"_invoke\", {\n value: function value(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function (resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();\n }\n });\n }\n function makeInvokeMethod(innerFn, self, context) {\n var state = \"suspendedStart\";\n return function (method, arg) {\n if (\"executing\" === state) throw new Error(\"Generator is already running\");\n if (\"completed\" === state) {\n if (\"throw\" === method) throw arg;\n return doneResult();\n }\n for (context.method = method, context.arg = arg;;) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n if (\"next\" === context.method) context.sent = context._sent = context.arg;else if (\"throw\" === context.method) {\n if (\"suspendedStart\" === state) throw state = \"completed\", context.arg;\n context.dispatchException(context.arg);\n } else \"return\" === context.method && context.abrupt(\"return\", context.arg);\n state = \"executing\";\n var record = tryCatch(innerFn, self, context);\n if (\"normal\" === record.type) {\n if (state = context.done ? \"completed\" : \"suspendedYield\", record.arg === ContinueSentinel) continue;\n return {\n value: record.arg,\n done: context.done\n };\n }\n \"throw\" === record.type && (state = \"completed\", context.method = \"throw\", context.arg = record.arg);\n }\n };\n }\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (undefined === method) {\n if (context.delegate = null, \"throw\" === context.method) {\n if (delegate.iterator[\"return\"] && (context.method = \"return\", context.arg = undefined, maybeInvokeDelegate(delegate, context), \"throw\" === context.method)) return ContinueSentinel;\n context.method = \"throw\", context.arg = new TypeError(\"The iterator does not provide a 'throw' method\");\n }\n return ContinueSentinel;\n }\n var record = tryCatch(method, delegate.iterator, context.arg);\n if (\"throw\" === record.type) return context.method = \"throw\", context.arg = record.arg, context.delegate = null, ContinueSentinel;\n var info = record.arg;\n return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, \"return\" !== context.method && (context.method = \"next\", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = \"throw\", context.arg = new TypeError(\"iterator result is not an object\"), context.delegate = null, ContinueSentinel);\n }\n function pushTryEntry(locs) {\n var entry = {\n tryLoc: locs[0]\n };\n 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry);\n }\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\", delete record.arg, entry.completion = record;\n }\n function Context(tryLocsList) {\n this.tryEntries = [{\n tryLoc: \"root\"\n }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0);\n }\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) return iteratorMethod.call(iterable);\n if (\"function\" == typeof iterable.next) return iterable;\n if (!isNaN(iterable.length)) {\n var i = -1,\n next = function next() {\n for (; ++i < iterable.length;) {\n if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next;\n }\n return next.value = undefined, next.done = !0, next;\n };\n return next.next = next;\n }\n }\n return {\n next: doneResult\n };\n }\n function doneResult() {\n return {\n value: undefined,\n done: !0\n };\n }\n return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, \"constructor\", {\n value: GeneratorFunctionPrototype,\n configurable: !0\n }), defineProperty(GeneratorFunctionPrototype, \"constructor\", {\n value: GeneratorFunction,\n configurable: !0\n }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, \"GeneratorFunction\"), exports.isGeneratorFunction = function (genFun) {\n var ctor = \"function\" == typeof genFun && genFun.constructor;\n return !!ctor && (ctor === GeneratorFunction || \"GeneratorFunction\" === (ctor.displayName || ctor.name));\n }, exports.mark = function (genFun) {\n return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, \"GeneratorFunction\")), genFun.prototype = Object.create(Gp), genFun;\n }, exports.awrap = function (arg) {\n return {\n __await: arg\n };\n }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n void 0 === PromiseImpl && (PromiseImpl = Promise);\n var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl);\n return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) {\n return result.done ? result.value : iter.next();\n });\n }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, \"Generator\"), define(Gp, iteratorSymbol, function () {\n return this;\n }), define(Gp, \"toString\", function () {\n return \"[object Generator]\";\n }), exports.keys = function (val) {\n var object = Object(val),\n keys = [];\n for (var key in object) {\n keys.push(key);\n }\n return keys.reverse(), function next() {\n for (; keys.length;) {\n var key = keys.pop();\n if (key in object) return next.value = key, next.done = !1, next;\n }\n return next.done = !0, next;\n };\n }, exports.values = values, Context.prototype = {\n constructor: Context,\n reset: function reset(skipTempReset) {\n if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = \"next\", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) {\n \"t\" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined);\n }\n },\n stop: function stop() {\n this.done = !0;\n var rootRecord = this.tryEntries[0].completion;\n if (\"throw\" === rootRecord.type) throw rootRecord.arg;\n return this.rval;\n },\n dispatchException: function dispatchException(exception) {\n if (this.done) throw exception;\n var context = this;\n function handle(loc, caught) {\n return record.type = \"throw\", record.arg = exception, context.next = loc, caught && (context.method = \"next\", context.arg = undefined), !!caught;\n }\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i],\n record = entry.completion;\n if (\"root\" === entry.tryLoc) return handle(\"end\");\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\"),\n hasFinally = hasOwn.call(entry, \"finallyLoc\");\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n } else {\n if (!hasFinally) throw new Error(\"try statement without catch or finally\");\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n }\n }\n }\n },\n abrupt: function abrupt(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n finallyEntry && (\"break\" === type || \"continue\" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null);\n var record = finallyEntry ? finallyEntry.completion : {};\n return record.type = type, record.arg = arg, finallyEntry ? (this.method = \"next\", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record);\n },\n complete: function complete(record, afterLoc) {\n if (\"throw\" === record.type) throw record.arg;\n return \"break\" === record.type || \"continue\" === record.type ? this.next = record.arg : \"return\" === record.type ? (this.rval = this.arg = record.arg, this.method = \"return\", this.next = \"end\") : \"normal\" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel;\n },\n finish: function finish(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel;\n }\n },\n \"catch\": function _catch(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (\"throw\" === record.type) {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n throw new Error(\"illegal catch attempt\");\n },\n delegateYield: function delegateYield(iterable, resultName, nextLoc) {\n return this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n }, \"next\" === this.method && (this.arg = undefined), ContinueSentinel;\n }\n }, exports;\n}","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\nexport default function _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n _next(undefined);\n });\n };\n}","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}","export enum KioskState {\n MainMenu,\n PlayingGame,\n EnterHighScore,\n AddingGame,\n ScanQR,\n QrSuccess,\n GameOver,\n}","import configData from \"../config.json\"\n\nexport class KeyboardManager {\n private keyboardState: { [index: string]: boolean} = {};\n\n constructor() {\n document.addEventListener(\"keydown\", (e) => {\n this.onKeydown(e.key)\n });\n document.addEventListener(\"keyup\", (e) => {\n this.onKeyup(e.key);\n });\n }\n\n private checkPressed(gamepadIndex: number, keys: string[][]): boolean {\n if (gamepadIndex == -1) {\n return keys.some((list) => list.some(key => this.keyboardState[key.toUpperCase()]));\n }\n\n return keys[gamepadIndex].some(key => this.keyboardState[key.toUpperCase()]);\n }\n\n isAButtonPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardAButtonKeys);\n }\n\n isBButtonPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardBButtonKeys);\n }\n\n isEscapeButtonPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardEscapeButtonKeys);\n }\n\n isResetButtonPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardResetButtonKeys);\n }\n\n isMenuButtonPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardMenuButtonKeys);\n }\n\n isLeftPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardLeftKeys);\n }\n\n isRightPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardRightKeys);\n }\n\n isUpPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardUpKeys);\n }\n\n isDownPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardDownKeys);\n }\n\n onKeydown(key: string) {\n this.keyboardState[key.toUpperCase()] = true;\n }\n\n onKeyup(key: string) {\n this.keyboardState[key.toUpperCase()] = false;\n }\n\n clear() {\n this.keyboardState = {};\n }\n}","import configData from \"../config.json\"\nimport { KeyboardManager } from \"./KeyboardManager\";\n\nexport class GamepadManager {\n private cachedGamepads: Gamepad[] = [];\n private cacheExpires: number = 0;\n\n private minButtonPinRequired: number = 0;\n private minAxisRequired: number = 0;\n\n public keyboardManager: KeyboardManager = new KeyboardManager();\n\n constructor() {\n this.minButtonPinRequired = Math.max(\n configData.GamepadAButtonPin,\n configData.GamepadBButtonPin,\n configData.GamepadEscapeButtonPin,\n configData.GamepadMenuButtonPin,\n configData.GamepadResetButtonPin\n );\n\n this.minAxisRequired = Math.max(\n configData.GamepadUpDownAxis,\n configData.GamepadLeftRightAxis\n );\n }\n\n getGamepads(): Gamepad[] {\n // We cache the gamepads so that we limit how often we call the underlying API. We also\n // filter down to the gamepads that are not null and have the buttons and axes we need\n // to operate based on the config settings. This might not cover all scenarios, but does\n // a good job at filtering out the random devices (like plugged-in Surface Headphones?!?)\n // that get picked up as gamepads.\n\n if (this.cacheExpires <= Date.now()) {\n this.cachedGamepads = navigator.getGamepads().filter(\n item => item &&\n item.axes && item.axes.length >= this.minAxisRequired &&\n item.buttons && item.buttons.length >= this.minButtonPinRequired\n ) as Gamepad[];\n this.cacheExpires = Date.now() + configData.GamepadCacheMilli;\n }\n\n return this.cachedGamepads;\n }\n\n validateGamepadIndex(gamepads: Gamepad[], gamepadIndex: number) {\n if ((gamepadIndex < -1) || (gamepadIndex >= gamepads.length)) {\n throw new Error(`No gamepad available at index ${gamepadIndex}`);\n }\n }\n\n isButtonPressed(gamepadIndex: number, pinIndex: number): boolean {\n const gamepads: Gamepad[] = this.getGamepads();\n\n if (gamepadIndex === -1) {\n return gamepads.some((item, index) => this.isButtonPressed(index, pinIndex));\n }\n\n this.validateGamepadIndex(gamepads, gamepadIndex);\n if ((pinIndex < 0) || (pinIndex >= gamepads[gamepadIndex].buttons.length)) {\n throw new Error(`Gamepad at index ${gamepadIndex} does not have a button at pin ${pinIndex}`);\n }\n\n return gamepads[gamepadIndex].buttons[pinIndex].pressed;\n }\n\n isAButtonPressed(gamepadIndex: number = -1): boolean {\n return this.keyboardManager.isAButtonPressed(gamepadIndex) ||\n this.isButtonPressed(gamepadIndex, configData.GamepadAButtonPin);\n }\n\n isBButtonPressed(gamepadIndex: number = -1): boolean {\n return this.keyboardManager.isBButtonPressed(gamepadIndex) ||\n this.isButtonPressed(gamepadIndex, configData.GamepadBButtonPin);\n }\n\n isEscapeButtonPressed(gamepadIndex: number = -1): boolean {\n return this.keyboardManager.isEscapeButtonPressed(gamepadIndex) ||\n this.isButtonPressed(gamepadIndex, configData.GamepadEscapeButtonPin);\n }\n\n isResetButtonPressed(gamepadIndex: number = -1): boolean {\n return this.keyboardManager.isResetButtonPressed(gamepadIndex) ||\n this.isButtonPressed(gamepadIndex, configData.GamepadResetButtonPin);\n }\n\n isMenuButtonPressed(gamepadIndex: number = -1): boolean {\n return this.keyboardManager.isMenuButtonPressed(gamepadIndex) ||\n this.isButtonPressed(gamepadIndex, configData.GamepadMenuButtonPin);\n }\n\n isDirectionPressed(gamepadIndex: number, axisIndex: number, threshold: number): boolean {\n const gamepads: Gamepad[] = this.getGamepads();\n\n if (gamepadIndex === -1) {\n return gamepads.some((item, index) => this.isDirectionPressed(index, axisIndex, threshold));\n }\n\n this.validateGamepadIndex(gamepads, gamepadIndex);\n\n const gamepad: Gamepad = gamepads[gamepadIndex];\n\n if ((axisIndex < 0) || (axisIndex >= gamepad.axes.length)) {\n throw new Error(`Gamepad at index ${gamepadIndex} does not have an axis at index ${axisIndex}`);\n }\n\n if (threshold < 0) {\n return gamepad.axes[axisIndex] <= threshold;\n }\n\n return gamepad.axes[axisIndex] >= threshold;\n }\n\n isLeftPressed(gamepadIndex: number = -1) {\n return this.keyboardManager.isLeftPressed(gamepadIndex) ||\n this.isDirectionPressed(gamepadIndex, configData.GamepadLeftRightAxis, -configData.GamepadLeftRightThreshold);\n }\n\n isRightPressed(gamepadIndex: number = -1) {\n return this.keyboardManager.isRightPressed(gamepadIndex) ||\n this.isDirectionPressed(gamepadIndex, configData.GamepadLeftRightAxis, configData.GamepadLeftRightThreshold);\n }\n\n isUpPressed(gamepadIndex: number = -1) {\n return this.keyboardManager.isUpPressed(gamepadIndex) ||\n this.isDirectionPressed(gamepadIndex, configData.GamepadUpDownAxis, -configData.GamepadUpDownThreshold);\n }\n\n isDownPressed(gamepadIndex: number = -1) {\n return this.keyboardManager.isDownPressed(gamepadIndex) ||\n this.isDirectionPressed(gamepadIndex, configData.GamepadUpDownAxis, configData.GamepadUpDownThreshold);\n }\n}","export class HighScore {\n constructor(public initials: string, public score: number) {}\n}","export class GameData {\n constructor(public id: string,\n public name: string,\n public description: string,\n public highScoreMode: string,\n public uniqueIdentifier?: string,\n public date?: string,\n public userAdded?: boolean,\n public deleted?: boolean\n ) {\n }\n}","const stagingEndpoint = \"https://staging.pxt.io/api/kiosk\"\nconst kioskBackendEndpoint = \"https://makecode.com/api/kiosk\";\nconst apiBackendEndpoint = \"https://makecode.com/api\";\n\nexport const getGameCodesAsync = async (kioskCode: string) => {\n const getGameCodeUrl = `${kioskBackendEndpoint}/code/${kioskCode}`;\n let response = await fetch(getGameCodeUrl);\n if (!response.ok) {\n const e = new Error(response.statusText);\n e.name = \"PollError\";\n throw e;\n } else {\n const gameCodeEntries = JSON.parse((await response.json())?.shareIds);\n return gameCodeEntries;\n }\n}\n\nexport const generateKioskCodeAsync = async (time?: number) => {\n const codeGenerationUrl = `${kioskBackendEndpoint}/newcode${time ? `?time=${time}` : \"\"}`;\n const response = await fetch(codeGenerationUrl);\n if (!response.ok) {\n const e = new Error(response.statusText);\n e.name = \"KioskCodeGenError\";\n throw e;\n } else {\n try {\n const newKioskCode = (await response.json()).code;\n return newKioskCode;\n }\n catch (error) {\n throw new Error(\"No code returned from the request.\");\n }\n }\n}\n\nexport const addGameToKioskAsync = async (kioskId: string | undefined, gameShareId: string | undefined) => {\n const updateKioskUrl = `${kioskBackendEndpoint}/updatecode`;\n const response: Response = await fetch(updateKioskUrl, {\n method: 'POST',\n headers: {\n 'Accept': 'application/json',\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n \"kioskCode\": kioskId,\n \"shareId\": gameShareId\n }),\n });\n\n if (!response.ok) {\n throw new Error(`${response.status} ${response.statusText}`)\n } else {\n return await response.json();\n }\n\n\n}\n\nexport const getGameDetailsAsync = async (gameId: string) => {\n const gameDetailsUrl = `${apiBackendEndpoint}/${gameId}`;\n const response = await fetch(gameDetailsUrl);\n if (!response.ok) {\n throw new Error(\"Unable to fetch the game details\");\n } else {\n return await response.json();\n }\n}","export function tickEvent(id: string, data?: { [key: string]: string | number }) {\n (window as any).pxtTickEvent?.(id, data);\n}\n\nexport function devicePixelRatio(): number {\n if (typeof window === \"undefined\" || !window.screen) return 1;\n\n // these are IE specific\n const sysXDPI = (window.screen as any).systemXDPI\n const logicalXDPI = (window.screen as any).logicalXDPI\n if (sysXDPI !== undefined\n && logicalXDPI !== undefined\n && sysXDPI > logicalXDPI) {\n return sysXDPI / logicalXDPI;\n }\n else if (window && window.devicePixelRatio !== undefined) {\n return window.devicePixelRatio;\n }\n return 1;\n}\n\nexport function isLocal() {\n return window.location.hostname === \"localhost\";\n}","import { GamepadManager } from \"./GamepadManager\";\nimport { HighScore } from \"./HighScore\";\nimport { GameData } from \"./GameData\";\nimport { BuiltSimJSInfo } from \"./BuiltSimJsInfo\";\nimport { KioskState } from \"./KioskState\";\nimport configData from \"../config.json\";\nimport { getGameDetailsAsync } from \"../BackendRequests\"\nimport { tickEvent } from \"../browserUtils\";\nexport class Kiosk {\n games: GameData[] = [];\n gamepadManager: GamepadManager = new GamepadManager();\n selectedGame?: GameData;\n selectedGameIndex?: number;\n mostRecentScores: number[] = [];\n onGameSelected!: () => void;\n onNavigated!: () => void;\n launchedGame: string = \"\";\n state: KioskState = KioskState.MainMenu;\n clean: boolean;\n locked: boolean;\n time?: string;\n\n private readonly highScoresLocalStorageKey: string = \"HighScores\";\n private readonly addedGamesLocalStorageKey: string = \"UserAddedGames\";\n private initializePromise: any;\n private siteElements: ChildNode[] = [];\n private intervalId: any;\n private readonly allScoresStateKey: string = \"S/all-scores\";\n private lockedGameId?: string;\n private builtGamesCache: { [gameId: string]: BuiltSimJSInfo } = { };\n private defaultGameDescription = \"Made with love in MakeCode Arcade\";\n\n constructor(clean: boolean, locked: boolean, time?: string) {\n this.clean = clean;\n this.locked = locked;\n this.time = time;\n }\n\n async downloadGameListAsync(): Promise {\n if (!this.clean) {\n let url = configData.GameDataUrl;\n if (configData.Debug) {\n url = `/static/kiosk/${url}`;\n }\n \n const response = await fetch(url);\n if (!response.ok) {\n throw new Error(`Unable to download game list from \"${url}\"`);\n }\n \n try {\n this.games = (await response.json()).games;\n this.games.push()\n }\n catch (error) {\n throw new Error(`Unable to process game list downloaded from \"${url}\": ${error}`);\n }\n } else {\n tickEvent(\"kiosk.clean\");\n }\n\n // the added games persist in local storage, but not the live game list\n // that feeds the carousel. That's what this function is for.\n this.addNewGamesToList();\n }\n\n getGameName(name: string) {\n if (name.toLowerCase() === \"untitled\") {\n return \"Kiosk Game\";\n }\n \n return name;\n }\n\n getGameDescription(desc: string) {\n if (desc.length === 0) {\n return this.defaultGameDescription\n }\n \n return desc;\n }\n\n async saveNewGamesAsync(games: { [index: string]: { [index: string]: string } }): Promise {\n const allAddedGames = this.getAllAddedGames();\n let gamesToAdd: string[] = [];\n const gameIds = Object.keys(games);\n for (const gameId of gameIds) {\n if (!allAddedGames[gameId]) {\n let gameName;\n let gameDescription;\n \n try {\n const gameDetails = await getGameDetailsAsync(gameId);\n gameName = this.getGameName(gameDetails.name);\n gameDescription = this.getGameDescription(gameDetails.description);\n } catch (error) {\n gameName = \"Kiosk Game\";\n gameDescription = this.defaultGameDescription;\n }\n \n const gameUploadDate = (new Date()).toLocaleString()\n const newGame = new GameData(gameId, gameName, gameDescription, \"None\", games[gameId].id, gameUploadDate, true);\n \n this.games.push(newGame);\n gamesToAdd.push(gameName);\n allAddedGames[gameId] = newGame;\n } else if (allAddedGames[gameId]?.deleted) {\n if (games[gameId].id !== allAddedGames[gameId].uniqueIdentifier) {\n allAddedGames[gameId].uniqueIdentifier = games[gameId].id;\n allAddedGames[gameId].deleted = false;\n gamesToAdd.push(allAddedGames[gameId].name);\n this.games.push(allAddedGames[gameId]);\n }\n } else {\n // we need to keep the backend and frontend unique identifiers the same\n allAddedGames[gameId].uniqueIdentifier = games[gameId].id;\n }\n }\n if (gamesToAdd.length) {\n this.selectGame(0);\n }\n localStorage.setItem(this.addedGamesLocalStorageKey, JSON.stringify(allAddedGames));\n return gamesToAdd;\n }\n\n getAllAddedGames(): { [index: string]: GameData } {\n const json = localStorage.getItem(this.addedGamesLocalStorageKey);\n if (!json) {\n return {};\n }\n const allAddedGames: { [index: string]: GameData } = JSON.parse(json);\n return allAddedGames;\n }\n\n addNewGamesToList() : void {\n // check if there are custom games to add to the game list from local storage\n const addedGames = this.getAllAddedGames();\n const addedGamesObjs: GameData[] = Object.values(addedGames);\n for (const game of addedGamesObjs) {\n if (!game?.deleted) {\n this.games.push(game);\n }\n }\n }\n\n gamePadLoop(): void {\n const isDebug = true;\n if (isDebug) {\n // Add cases for debugging via the gamepad here.\n }\n\n if (this.gamepadManager.isResetButtonPressed() &&\n this.gamepadManager.isEscapeButtonPressed() &&\n this.gamepadManager.isBButtonPressed() &&\n this.gamepadManager.isLeftPressed()) {\n this.resetHighScores();\n console.log(\"High scores reset\");\n return;\n }\n\n if (this.gamepadManager.isEscapeButtonPressed() || this.gamepadManager.isMenuButtonPressed()) {\n if (this.state === KioskState.PlayingGame) {\n this.escapeGame();\n } else {\n this.showMainMenu();\n }\n return;\n }\n }\n\n async initialize(): Promise {\n if (this.initializePromise) {\n return this.initializePromise;\n }\n\n this.initializePromise = this.downloadGameListAsync();\n\n this.intervalId = setInterval(() => this.gamePadLoop(), configData.GamepadPollLoopMilli);\n\n window.addEventListener(\"message\", (event) => {\n if (event.data?.js) {\n let builtGame: BuiltSimJSInfo | undefined = this.getBuiltGame(this.launchedGame);\n if (!builtGame) {\n this.addBuiltGame(this.launchedGame, event.data);\n } else {\n this.sendBuiltGame(this.launchedGame);\n }\n }\n switch (event.data.type) {\n case \"simulator\":\n switch (event.data.command) {\n case \"setstate\":\n switch (event.data.stateKey) {\n case this.allScoresStateKey:\n const rawData = atob(event.data.stateValue);\n const json = decodeURIComponent(rawData);\n this.mostRecentScores = JSON.parse(json);\n this.gameOver();\n break;\n }\n break;\n }\n break;\n case \"messagepacket\":\n const channel = event.data.channel;\n const parts = channel.split(\"-\");\n if (parts[0] === \"keydown\") {\n this.gamepadManager.keyboardManager.onKeydown(parts[1]);\n }\n else {\n this.gamepadManager.keyboardManager.onKeyup(parts[1]);\n }\n break;\n\n case \"ready\":\n let builtGame: BuiltSimJSInfo | undefined = this.getBuiltGame(this.launchedGame);\n if (builtGame) {\n this.sendBuiltGame(this.launchedGame);\n }\n break;\n }\n });\n\n return this.initializePromise;\n }\n\n cleanup() {\n if (this.intervalId) {\n clearInterval(this.intervalId);\n this.intervalId = null;\n }\n }\n\n navigate(state: KioskState) {\n this.state = state;\n if (this.onNavigated) {\n this.onNavigated();\n }\n }\n\n showMainMenu() {\n this.navigate(KioskState.MainMenu);\n }\n\n selectGame(gameIndex: number): void {\n if (gameIndex >= 0) {\n this.selectedGame = this.games[gameIndex];\n this.selectedGameIndex = gameIndex;\n }\n else {\n this.selectedGame = undefined;\n }\n }\n\n exitToEnterHighScore(): void {\n const launchedGameHighs = this.getHighScores(this.launchedGame);\n const currentHighScore = this.mostRecentScores[0];\n const lastScore = launchedGameHighs[launchedGameHighs.length - 1]?.score;\n if (launchedGameHighs.length === configData.HighScoresToKeep \n && lastScore \n && currentHighScore < lastScore) {\n this.exitGame(KioskState.GameOver);\n\n } else {\n this.exitGame(KioskState.EnterHighScore);\n }\n\n }\n\n gameOver(skipHighScore?: boolean): void {\n if (this.state !== KioskState.PlayingGame) { return; }\n\n if (this.lockedGameId) {\n this.launchGame(this.lockedGameId);\n return;\n }\n\n if (!skipHighScore && this.mostRecentScores && this.mostRecentScores.length && (this.selectedGame!.highScoreMode !== \"None\")) {\n this.exitToEnterHighScore();\n }\n else {\n this.exitGame(KioskState.GameOver);\n }\n }\n\n escapeGame(): void {\n if (this.state !== KioskState.PlayingGame || this.lockedGameId) { return; }\n this.gamepadManager.keyboardManager.clear();\n this.exitGame(KioskState.MainMenu);\n }\n\n private exitGame(state: KioskState): void {\n if (this.state !== KioskState.PlayingGame) { return; }\n this.navigate(state);\n\n const gamespace = document.getElementsByTagName(\"BODY\")[0];\n while (gamespace.firstChild) {\n gamespace.firstChild.remove();\n }\n\n this.siteElements.forEach(item => gamespace.appendChild(item));\n }\n\n getBuiltGame(gameId: string): BuiltSimJSInfo | undefined {\n const allBuiltGames = this.builtGamesCache;\n if (allBuiltGames[gameId]) {\n return allBuiltGames[gameId];\n }\n }\n\n addBuiltGame(gameId: string, builtSimJs: BuiltSimJSInfo) {\n const allBuiltGames = this.builtGamesCache;\n\n if (!allBuiltGames[gameId]) {\n allBuiltGames[gameId] = builtSimJs;\n }\n\n }\n\n sendBuiltGame(gameId: string) {\n const builtGame = this.getBuiltGame(gameId);\n const simIframe = document.getElementsByTagName(\"iframe\")[0] as HTMLIFrameElement;\n simIframe?.contentWindow?.postMessage({ ...builtGame, \"type\": \"builtjs\"}, \"*\");\n }\n\n launchGame(gameId: string, preventReturningToMenu = false): void {\n this.launchedGame = gameId;\n if (this.state === KioskState.PlayingGame) { return; }\n if (preventReturningToMenu) this.lockedGameId = gameId;\n this.navigate(KioskState.PlayingGame);\n\n this.siteElements = [];\n const gamespace = document.getElementsByTagName(\"BODY\")[0];\n while (gamespace.firstChild) {\n this.siteElements.push(gamespace.firstChild);\n gamespace.firstChild.remove();\n }\n\n const playUrlBase = `${configData.PlayUrlRoot}?id=${gameId}&hideSimButtons=1&noFooter=1&single=1&fullscreen=1&autofocus=1`\n let playQueryParam = this.getBuiltGame(gameId) ? \"&server=1\" : \"&sendBuilt=1\";\n\n function createIFrame(src: string) {\n const iframe: HTMLIFrameElement = document.createElement(\"iframe\");\n iframe.className = \"sim-embed\";\n iframe.frameBorder = \"0\";\n iframe.setAttribute(\"sandbox\", \"allow-popups allow-forms allow-scripts allow-same-origin\");\n iframe.src = src;\n return iframe;\n }\n const playerIFrame = createIFrame(playUrlBase + playQueryParam);\n gamespace.appendChild(playerIFrame);\n playerIFrame.focus();\n }\n\n launchAddGame() {\n this.navigate(KioskState.AddingGame);\n }\n\n getAllHighScores(): { [index: string]: HighScore[] } {\n const json = localStorage.getItem(this.highScoresLocalStorageKey);\n if (!json) {\n return {};\n }\n\n const allHighScores: {[index: string]: HighScore[]} = JSON.parse(json);\n return allHighScores;\n }\n\n getHighScores(gameId: string): HighScore[] {\n const allHighScores = this.getAllHighScores();\n if (!allHighScores[gameId]) {\n return [];\n }\n\n return allHighScores[gameId];\n }\n\n saveHighScore(gameId: string, initials: string, score: number) {\n const allHighScores = this.getAllHighScores();\n if (!allHighScores[gameId]) {\n allHighScores[gameId] = [];\n }\n\n allHighScores[gameId].push(new HighScore(initials, score));\n\n allHighScores[gameId].sort((first, second) => second.score - first.score);\n allHighScores[gameId].splice(configData.HighScoresToKeep);\n\n localStorage.setItem(this.highScoresLocalStorageKey, JSON.stringify(allHighScores));\n }\n\n resetHighScores() {\n localStorage.removeItem(this.highScoresLocalStorageKey);\n }\n}","import \"../Kiosk.css\";\ninterface IProps {\n selected: boolean;\n content: string;\n}\n\nconst AddGameButton: React.FC = ({ selected, content }) => {\n const buttonClassBase = \"kioskButton\";\n const specificButtonClass = selected ? \"buttonSelected\" : \"buttonUnselected\";\n const kioskButtonClass = `${buttonClassBase} ${specificButtonClass}`;\n\n return (\n
\n \n
\n )\n}\n\nexport default AddGameButton;","import objectWithoutPropertiesLoose from \"./objectWithoutPropertiesLoose.js\";\nexport default function _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for (i = 0; i < sourceSymbolKeys.length; i++) {\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}","import arrayWithoutHoles from \"./arrayWithoutHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableSpread from \"./nonIterableSpread.js\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}","export default function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","/**\n * SSR Window 4.0.2\n * Better handling for window object in SSR environment\n * https://github.com/nolimits4web/ssr-window\n *\n * Copyright 2021, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: December 13, 2021\n */\n/* eslint-disable no-param-reassign */\nfunction isObject(obj) {\n return (obj !== null &&\n typeof obj === 'object' &&\n 'constructor' in obj &&\n obj.constructor === Object);\n}\nfunction extend(target = {}, src = {}) {\n Object.keys(src).forEach((key) => {\n if (typeof target[key] === 'undefined')\n target[key] = src[key];\n else if (isObject(src[key]) &&\n isObject(target[key]) &&\n Object.keys(src[key]).length > 0) {\n extend(target[key], src[key]);\n }\n });\n}\n\nconst ssrDocument = {\n body: {},\n addEventListener() { },\n removeEventListener() { },\n activeElement: {\n blur() { },\n nodeName: '',\n },\n querySelector() {\n return null;\n },\n querySelectorAll() {\n return [];\n },\n getElementById() {\n return null;\n },\n createEvent() {\n return {\n initEvent() { },\n };\n },\n createElement() {\n return {\n children: [],\n childNodes: [],\n style: {},\n setAttribute() { },\n getElementsByTagName() {\n return [];\n },\n };\n },\n createElementNS() {\n return {};\n },\n importNode() {\n return null;\n },\n location: {\n hash: '',\n host: '',\n hostname: '',\n href: '',\n origin: '',\n pathname: '',\n protocol: '',\n search: '',\n },\n};\nfunction getDocument() {\n const doc = typeof document !== 'undefined' ? document : {};\n extend(doc, ssrDocument);\n return doc;\n}\n\nconst ssrWindow = {\n document: ssrDocument,\n navigator: {\n userAgent: '',\n },\n location: {\n hash: '',\n host: '',\n hostname: '',\n href: '',\n origin: '',\n pathname: '',\n protocol: '',\n search: '',\n },\n history: {\n replaceState() { },\n pushState() { },\n go() { },\n back() { },\n },\n CustomEvent: function CustomEvent() {\n return this;\n },\n addEventListener() { },\n removeEventListener() { },\n getComputedStyle() {\n return {\n getPropertyValue() {\n return '';\n },\n };\n },\n Image() { },\n Date() { },\n screen: {},\n setTimeout() { },\n clearTimeout() { },\n matchMedia() {\n return {};\n },\n requestAnimationFrame(callback) {\n if (typeof setTimeout === 'undefined') {\n callback();\n return null;\n }\n return setTimeout(callback, 0);\n },\n cancelAnimationFrame(id) {\n if (typeof setTimeout === 'undefined') {\n return;\n }\n clearTimeout(id);\n },\n};\nfunction getWindow() {\n const win = typeof window !== 'undefined' ? window : {};\n extend(win, ssrWindow);\n return win;\n}\n\nexport { extend, getDocument, getWindow, ssrDocument, ssrWindow };\n","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}","import _typeof from \"./typeof.js\";\nimport assertThisInitialized from \"./assertThisInitialized.js\";\nexport default function _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return assertThisInitialized(self);\n}","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}","export default function _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}","export default function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nexport default function _construct(Parent, args, Class) {\n if (isNativeReflectConstruct()) {\n _construct = Reflect.construct.bind();\n } else {\n _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) setPrototypeOf(instance, Class.prototype);\n return instance;\n };\n }\n return _construct.apply(null, arguments);\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeFunction from \"./isNativeFunction.js\";\nimport construct from \"./construct.js\";\nexport default function _wrapNativeSuper(Class) {\n var _cache = typeof Map === \"function\" ? new Map() : undefined;\n _wrapNativeSuper = function _wrapNativeSuper(Class) {\n if (Class === null || !isNativeFunction(Class)) return Class;\n if (typeof Class !== \"function\") {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n if (typeof _cache !== \"undefined\") {\n if (_cache.has(Class)) return _cache.get(Class);\n _cache.set(Class, Wrapper);\n }\n function Wrapper() {\n return construct(Class, arguments, getPrototypeOf(this).constructor);\n }\n Wrapper.prototype = Object.create(Class.prototype, {\n constructor: {\n value: Wrapper,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n return setPrototypeOf(Wrapper, Class);\n };\n return _wrapNativeSuper(Class);\n}","export default function _isNativeFunction(fn) {\n return Function.toString.call(fn).indexOf(\"[native code]\") !== -1;\n}","/**\n * Dom7 4.0.4\n * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API\n * https://framework7.io/docs/dom7.html\n *\n * Copyright 2022, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: January 11, 2022\n */\nimport { getWindow, getDocument } from 'ssr-window';\n\n/* eslint-disable no-proto */\nfunction makeReactive(obj) {\n const proto = obj.__proto__;\n Object.defineProperty(obj, '__proto__', {\n get() {\n return proto;\n },\n\n set(value) {\n proto.__proto__ = value;\n }\n\n });\n}\n\nclass Dom7 extends Array {\n constructor(items) {\n if (typeof items === 'number') {\n super(items);\n } else {\n super(...(items || []));\n makeReactive(this);\n }\n }\n\n}\n\nfunction arrayFlat(arr = []) {\n const res = [];\n arr.forEach(el => {\n if (Array.isArray(el)) {\n res.push(...arrayFlat(el));\n } else {\n res.push(el);\n }\n });\n return res;\n}\nfunction arrayFilter(arr, callback) {\n return Array.prototype.filter.call(arr, callback);\n}\nfunction arrayUnique(arr) {\n const uniqueArray = [];\n\n for (let i = 0; i < arr.length; i += 1) {\n if (uniqueArray.indexOf(arr[i]) === -1) uniqueArray.push(arr[i]);\n }\n\n return uniqueArray;\n}\nfunction toCamelCase(string) {\n return string.toLowerCase().replace(/-(.)/g, (match, group) => group.toUpperCase());\n}\n\n// eslint-disable-next-line\n\nfunction qsa(selector, context) {\n if (typeof selector !== 'string') {\n return [selector];\n }\n\n const a = [];\n const res = context.querySelectorAll(selector);\n\n for (let i = 0; i < res.length; i += 1) {\n a.push(res[i]);\n }\n\n return a;\n}\n\nfunction $(selector, context) {\n const window = getWindow();\n const document = getDocument();\n let arr = [];\n\n if (!context && selector instanceof Dom7) {\n return selector;\n }\n\n if (!selector) {\n return new Dom7(arr);\n }\n\n if (typeof selector === 'string') {\n const html = selector.trim();\n\n if (html.indexOf('<') >= 0 && html.indexOf('>') >= 0) {\n let toCreate = 'div';\n if (html.indexOf(' c.split(' ')));\n this.forEach(el => {\n el.classList.add(...classNames);\n });\n return this;\n}\n\nfunction removeClass(...classes) {\n const classNames = arrayFlat(classes.map(c => c.split(' ')));\n this.forEach(el => {\n el.classList.remove(...classNames);\n });\n return this;\n}\n\nfunction toggleClass(...classes) {\n const classNames = arrayFlat(classes.map(c => c.split(' ')));\n this.forEach(el => {\n classNames.forEach(className => {\n el.classList.toggle(className);\n });\n });\n}\n\nfunction hasClass(...classes) {\n const classNames = arrayFlat(classes.map(c => c.split(' ')));\n return arrayFilter(this, el => {\n return classNames.filter(className => el.classList.contains(className)).length > 0;\n }).length > 0;\n}\n\nfunction attr(attrs, value) {\n if (arguments.length === 1 && typeof attrs === 'string') {\n // Get attr\n if (this[0]) return this[0].getAttribute(attrs);\n return undefined;\n } // Set attrs\n\n\n for (let i = 0; i < this.length; i += 1) {\n if (arguments.length === 2) {\n // String\n this[i].setAttribute(attrs, value);\n } else {\n // Object\n for (const attrName in attrs) {\n this[i][attrName] = attrs[attrName];\n this[i].setAttribute(attrName, attrs[attrName]);\n }\n }\n }\n\n return this;\n}\n\nfunction removeAttr(attr) {\n for (let i = 0; i < this.length; i += 1) {\n this[i].removeAttribute(attr);\n }\n\n return this;\n}\n\nfunction prop(props, value) {\n if (arguments.length === 1 && typeof props === 'string') {\n // Get prop\n if (this[0]) return this[0][props];\n } else {\n // Set props\n for (let i = 0; i < this.length; i += 1) {\n if (arguments.length === 2) {\n // String\n this[i][props] = value;\n } else {\n // Object\n for (const propName in props) {\n this[i][propName] = props[propName];\n }\n }\n }\n\n return this;\n }\n\n return this;\n}\n\nfunction data(key, value) {\n let el;\n\n if (typeof value === 'undefined') {\n el = this[0];\n if (!el) return undefined; // Get value\n\n if (el.dom7ElementDataStorage && key in el.dom7ElementDataStorage) {\n return el.dom7ElementDataStorage[key];\n }\n\n const dataKey = el.getAttribute(`data-${key}`);\n\n if (dataKey) {\n return dataKey;\n }\n\n return undefined;\n } // Set value\n\n\n for (let i = 0; i < this.length; i += 1) {\n el = this[i];\n if (!el.dom7ElementDataStorage) el.dom7ElementDataStorage = {};\n el.dom7ElementDataStorage[key] = value;\n }\n\n return this;\n}\n\nfunction removeData(key) {\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (el.dom7ElementDataStorage && el.dom7ElementDataStorage[key]) {\n el.dom7ElementDataStorage[key] = null;\n delete el.dom7ElementDataStorage[key];\n }\n }\n}\n\nfunction dataset() {\n const el = this[0];\n if (!el) return undefined;\n const dataset = {}; // eslint-disable-line\n\n if (el.dataset) {\n for (const dataKey in el.dataset) {\n dataset[dataKey] = el.dataset[dataKey];\n }\n } else {\n for (let i = 0; i < el.attributes.length; i += 1) {\n const attr = el.attributes[i];\n\n if (attr.name.indexOf('data-') >= 0) {\n dataset[toCamelCase(attr.name.split('data-')[1])] = attr.value;\n }\n }\n }\n\n for (const key in dataset) {\n if (dataset[key] === 'false') dataset[key] = false;else if (dataset[key] === 'true') dataset[key] = true;else if (parseFloat(dataset[key]) === dataset[key] * 1) dataset[key] *= 1;\n }\n\n return dataset;\n}\n\nfunction val(value) {\n if (typeof value === 'undefined') {\n // get value\n const el = this[0];\n if (!el) return undefined;\n\n if (el.multiple && el.nodeName.toLowerCase() === 'select') {\n const values = [];\n\n for (let i = 0; i < el.selectedOptions.length; i += 1) {\n values.push(el.selectedOptions[i].value);\n }\n\n return values;\n }\n\n return el.value;\n } // set value\n\n\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (Array.isArray(value) && el.multiple && el.nodeName.toLowerCase() === 'select') {\n for (let j = 0; j < el.options.length; j += 1) {\n el.options[j].selected = value.indexOf(el.options[j].value) >= 0;\n }\n } else {\n el.value = value;\n }\n }\n\n return this;\n}\n\nfunction value(value) {\n return this.val(value);\n}\n\nfunction transform(transform) {\n for (let i = 0; i < this.length; i += 1) {\n this[i].style.transform = transform;\n }\n\n return this;\n}\n\nfunction transition(duration) {\n for (let i = 0; i < this.length; i += 1) {\n this[i].style.transitionDuration = typeof duration !== 'string' ? `${duration}ms` : duration;\n }\n\n return this;\n}\n\nfunction on(...args) {\n let [eventType, targetSelector, listener, capture] = args;\n\n if (typeof args[1] === 'function') {\n [eventType, listener, capture] = args;\n targetSelector = undefined;\n }\n\n if (!capture) capture = false;\n\n function handleLiveEvent(e) {\n const target = e.target;\n if (!target) return;\n const eventData = e.target.dom7EventData || [];\n\n if (eventData.indexOf(e) < 0) {\n eventData.unshift(e);\n }\n\n if ($(target).is(targetSelector)) listener.apply(target, eventData);else {\n const parents = $(target).parents(); // eslint-disable-line\n\n for (let k = 0; k < parents.length; k += 1) {\n if ($(parents[k]).is(targetSelector)) listener.apply(parents[k], eventData);\n }\n }\n }\n\n function handleEvent(e) {\n const eventData = e && e.target ? e.target.dom7EventData || [] : [];\n\n if (eventData.indexOf(e) < 0) {\n eventData.unshift(e);\n }\n\n listener.apply(this, eventData);\n }\n\n const events = eventType.split(' ');\n let j;\n\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (!targetSelector) {\n for (j = 0; j < events.length; j += 1) {\n const event = events[j];\n if (!el.dom7Listeners) el.dom7Listeners = {};\n if (!el.dom7Listeners[event]) el.dom7Listeners[event] = [];\n el.dom7Listeners[event].push({\n listener,\n proxyListener: handleEvent\n });\n el.addEventListener(event, handleEvent, capture);\n }\n } else {\n // Live events\n for (j = 0; j < events.length; j += 1) {\n const event = events[j];\n if (!el.dom7LiveListeners) el.dom7LiveListeners = {};\n if (!el.dom7LiveListeners[event]) el.dom7LiveListeners[event] = [];\n el.dom7LiveListeners[event].push({\n listener,\n proxyListener: handleLiveEvent\n });\n el.addEventListener(event, handleLiveEvent, capture);\n }\n }\n }\n\n return this;\n}\n\nfunction off(...args) {\n let [eventType, targetSelector, listener, capture] = args;\n\n if (typeof args[1] === 'function') {\n [eventType, listener, capture] = args;\n targetSelector = undefined;\n }\n\n if (!capture) capture = false;\n const events = eventType.split(' ');\n\n for (let i = 0; i < events.length; i += 1) {\n const event = events[i];\n\n for (let j = 0; j < this.length; j += 1) {\n const el = this[j];\n let handlers;\n\n if (!targetSelector && el.dom7Listeners) {\n handlers = el.dom7Listeners[event];\n } else if (targetSelector && el.dom7LiveListeners) {\n handlers = el.dom7LiveListeners[event];\n }\n\n if (handlers && handlers.length) {\n for (let k = handlers.length - 1; k >= 0; k -= 1) {\n const handler = handlers[k];\n\n if (listener && handler.listener === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (listener && handler.listener && handler.listener.dom7proxy && handler.listener.dom7proxy === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (!listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n }\n }\n }\n }\n }\n\n return this;\n}\n\nfunction once(...args) {\n const dom = this;\n let [eventName, targetSelector, listener, capture] = args;\n\n if (typeof args[1] === 'function') {\n [eventName, listener, capture] = args;\n targetSelector = undefined;\n }\n\n function onceHandler(...eventArgs) {\n listener.apply(this, eventArgs);\n dom.off(eventName, targetSelector, onceHandler, capture);\n\n if (onceHandler.dom7proxy) {\n delete onceHandler.dom7proxy;\n }\n }\n\n onceHandler.dom7proxy = listener;\n return dom.on(eventName, targetSelector, onceHandler, capture);\n}\n\nfunction trigger(...args) {\n const window = getWindow();\n const events = args[0].split(' ');\n const eventData = args[1];\n\n for (let i = 0; i < events.length; i += 1) {\n const event = events[i];\n\n for (let j = 0; j < this.length; j += 1) {\n const el = this[j];\n\n if (window.CustomEvent) {\n const evt = new window.CustomEvent(event, {\n detail: eventData,\n bubbles: true,\n cancelable: true\n });\n el.dom7EventData = args.filter((data, dataIndex) => dataIndex > 0);\n el.dispatchEvent(evt);\n el.dom7EventData = [];\n delete el.dom7EventData;\n }\n }\n }\n\n return this;\n}\n\nfunction transitionEnd(callback) {\n const dom = this;\n\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off('transitionend', fireCallBack);\n }\n\n if (callback) {\n dom.on('transitionend', fireCallBack);\n }\n\n return this;\n}\n\nfunction animationEnd(callback) {\n const dom = this;\n\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off('animationend', fireCallBack);\n }\n\n if (callback) {\n dom.on('animationend', fireCallBack);\n }\n\n return this;\n}\n\nfunction width() {\n const window = getWindow();\n\n if (this[0] === window) {\n return window.innerWidth;\n }\n\n if (this.length > 0) {\n return parseFloat(this.css('width'));\n }\n\n return null;\n}\n\nfunction outerWidth(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n const styles = this.styles();\n return this[0].offsetWidth + parseFloat(styles.getPropertyValue('margin-right')) + parseFloat(styles.getPropertyValue('margin-left'));\n }\n\n return this[0].offsetWidth;\n }\n\n return null;\n}\n\nfunction height() {\n const window = getWindow();\n\n if (this[0] === window) {\n return window.innerHeight;\n }\n\n if (this.length > 0) {\n return parseFloat(this.css('height'));\n }\n\n return null;\n}\n\nfunction outerHeight(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n const styles = this.styles();\n return this[0].offsetHeight + parseFloat(styles.getPropertyValue('margin-top')) + parseFloat(styles.getPropertyValue('margin-bottom'));\n }\n\n return this[0].offsetHeight;\n }\n\n return null;\n}\n\nfunction offset() {\n if (this.length > 0) {\n const window = getWindow();\n const document = getDocument();\n const el = this[0];\n const box = el.getBoundingClientRect();\n const body = document.body;\n const clientTop = el.clientTop || body.clientTop || 0;\n const clientLeft = el.clientLeft || body.clientLeft || 0;\n const scrollTop = el === window ? window.scrollY : el.scrollTop;\n const scrollLeft = el === window ? window.scrollX : el.scrollLeft;\n return {\n top: box.top + scrollTop - clientTop,\n left: box.left + scrollLeft - clientLeft\n };\n }\n\n return null;\n}\n\nfunction hide() {\n for (let i = 0; i < this.length; i += 1) {\n this[i].style.display = 'none';\n }\n\n return this;\n}\n\nfunction show() {\n const window = getWindow();\n\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (el.style.display === 'none') {\n el.style.display = '';\n }\n\n if (window.getComputedStyle(el, null).getPropertyValue('display') === 'none') {\n // Still not visible\n el.style.display = 'block';\n }\n }\n\n return this;\n}\n\nfunction styles() {\n const window = getWindow();\n if (this[0]) return window.getComputedStyle(this[0], null);\n return {};\n}\n\nfunction css(props, value) {\n const window = getWindow();\n let i;\n\n if (arguments.length === 1) {\n if (typeof props === 'string') {\n // .css('width')\n if (this[0]) return window.getComputedStyle(this[0], null).getPropertyValue(props);\n } else {\n // .css({ width: '100px' })\n for (i = 0; i < this.length; i += 1) {\n for (const prop in props) {\n this[i].style[prop] = props[prop];\n }\n }\n\n return this;\n }\n }\n\n if (arguments.length === 2 && typeof props === 'string') {\n // .css('width', '100px')\n for (i = 0; i < this.length; i += 1) {\n this[i].style[props] = value;\n }\n\n return this;\n }\n\n return this;\n}\n\nfunction each(callback) {\n if (!callback) return this;\n this.forEach((el, index) => {\n callback.apply(el, [el, index]);\n });\n return this;\n}\n\nfunction filter(callback) {\n const result = arrayFilter(this, callback);\n return $(result);\n}\n\nfunction html(html) {\n if (typeof html === 'undefined') {\n return this[0] ? this[0].innerHTML : null;\n }\n\n for (let i = 0; i < this.length; i += 1) {\n this[i].innerHTML = html;\n }\n\n return this;\n}\n\nfunction text(text) {\n if (typeof text === 'undefined') {\n return this[0] ? this[0].textContent.trim() : null;\n }\n\n for (let i = 0; i < this.length; i += 1) {\n this[i].textContent = text;\n }\n\n return this;\n}\n\nfunction is(selector) {\n const window = getWindow();\n const document = getDocument();\n const el = this[0];\n let compareWith;\n let i;\n if (!el || typeof selector === 'undefined') return false;\n\n if (typeof selector === 'string') {\n if (el.matches) return el.matches(selector);\n if (el.webkitMatchesSelector) return el.webkitMatchesSelector(selector);\n if (el.msMatchesSelector) return el.msMatchesSelector(selector);\n compareWith = $(selector);\n\n for (i = 0; i < compareWith.length; i += 1) {\n if (compareWith[i] === el) return true;\n }\n\n return false;\n }\n\n if (selector === document) {\n return el === document;\n }\n\n if (selector === window) {\n return el === window;\n }\n\n if (selector.nodeType || selector instanceof Dom7) {\n compareWith = selector.nodeType ? [selector] : selector;\n\n for (i = 0; i < compareWith.length; i += 1) {\n if (compareWith[i] === el) return true;\n }\n\n return false;\n }\n\n return false;\n}\n\nfunction index() {\n let child = this[0];\n let i;\n\n if (child) {\n i = 0; // eslint-disable-next-line\n\n while ((child = child.previousSibling) !== null) {\n if (child.nodeType === 1) i += 1;\n }\n\n return i;\n }\n\n return undefined;\n}\n\nfunction eq(index) {\n if (typeof index === 'undefined') return this;\n const length = this.length;\n\n if (index > length - 1) {\n return $([]);\n }\n\n if (index < 0) {\n const returnIndex = length + index;\n if (returnIndex < 0) return $([]);\n return $([this[returnIndex]]);\n }\n\n return $([this[index]]);\n}\n\nfunction append(...els) {\n let newChild;\n const document = getDocument();\n\n for (let k = 0; k < els.length; k += 1) {\n newChild = els[k];\n\n for (let i = 0; i < this.length; i += 1) {\n if (typeof newChild === 'string') {\n const tempDiv = document.createElement('div');\n tempDiv.innerHTML = newChild;\n\n while (tempDiv.firstChild) {\n this[i].appendChild(tempDiv.firstChild);\n }\n } else if (newChild instanceof Dom7) {\n for (let j = 0; j < newChild.length; j += 1) {\n this[i].appendChild(newChild[j]);\n }\n } else {\n this[i].appendChild(newChild);\n }\n }\n }\n\n return this;\n}\n\nfunction appendTo(parent) {\n $(parent).append(this);\n return this;\n}\n\nfunction prepend(newChild) {\n const document = getDocument();\n let i;\n let j;\n\n for (i = 0; i < this.length; i += 1) {\n if (typeof newChild === 'string') {\n const tempDiv = document.createElement('div');\n tempDiv.innerHTML = newChild;\n\n for (j = tempDiv.childNodes.length - 1; j >= 0; j -= 1) {\n this[i].insertBefore(tempDiv.childNodes[j], this[i].childNodes[0]);\n }\n } else if (newChild instanceof Dom7) {\n for (j = 0; j < newChild.length; j += 1) {\n this[i].insertBefore(newChild[j], this[i].childNodes[0]);\n }\n } else {\n this[i].insertBefore(newChild, this[i].childNodes[0]);\n }\n }\n\n return this;\n}\n\nfunction prependTo(parent) {\n $(parent).prepend(this);\n return this;\n}\n\nfunction insertBefore(selector) {\n const before = $(selector);\n\n for (let i = 0; i < this.length; i += 1) {\n if (before.length === 1) {\n before[0].parentNode.insertBefore(this[i], before[0]);\n } else if (before.length > 1) {\n for (let j = 0; j < before.length; j += 1) {\n before[j].parentNode.insertBefore(this[i].cloneNode(true), before[j]);\n }\n }\n }\n}\n\nfunction insertAfter(selector) {\n const after = $(selector);\n\n for (let i = 0; i < this.length; i += 1) {\n if (after.length === 1) {\n after[0].parentNode.insertBefore(this[i], after[0].nextSibling);\n } else if (after.length > 1) {\n for (let j = 0; j < after.length; j += 1) {\n after[j].parentNode.insertBefore(this[i].cloneNode(true), after[j].nextSibling);\n }\n }\n }\n}\n\nfunction next(selector) {\n if (this.length > 0) {\n if (selector) {\n if (this[0].nextElementSibling && $(this[0].nextElementSibling).is(selector)) {\n return $([this[0].nextElementSibling]);\n }\n\n return $([]);\n }\n\n if (this[0].nextElementSibling) return $([this[0].nextElementSibling]);\n return $([]);\n }\n\n return $([]);\n}\n\nfunction nextAll(selector) {\n const nextEls = [];\n let el = this[0];\n if (!el) return $([]);\n\n while (el.nextElementSibling) {\n const next = el.nextElementSibling; // eslint-disable-line\n\n if (selector) {\n if ($(next).is(selector)) nextEls.push(next);\n } else nextEls.push(next);\n\n el = next;\n }\n\n return $(nextEls);\n}\n\nfunction prev(selector) {\n if (this.length > 0) {\n const el = this[0];\n\n if (selector) {\n if (el.previousElementSibling && $(el.previousElementSibling).is(selector)) {\n return $([el.previousElementSibling]);\n }\n\n return $([]);\n }\n\n if (el.previousElementSibling) return $([el.previousElementSibling]);\n return $([]);\n }\n\n return $([]);\n}\n\nfunction prevAll(selector) {\n const prevEls = [];\n let el = this[0];\n if (!el) return $([]);\n\n while (el.previousElementSibling) {\n const prev = el.previousElementSibling; // eslint-disable-line\n\n if (selector) {\n if ($(prev).is(selector)) prevEls.push(prev);\n } else prevEls.push(prev);\n\n el = prev;\n }\n\n return $(prevEls);\n}\n\nfunction siblings(selector) {\n return this.nextAll(selector).add(this.prevAll(selector));\n}\n\nfunction parent(selector) {\n const parents = []; // eslint-disable-line\n\n for (let i = 0; i < this.length; i += 1) {\n if (this[i].parentNode !== null) {\n if (selector) {\n if ($(this[i].parentNode).is(selector)) parents.push(this[i].parentNode);\n } else {\n parents.push(this[i].parentNode);\n }\n }\n }\n\n return $(parents);\n}\n\nfunction parents(selector) {\n const parents = []; // eslint-disable-line\n\n for (let i = 0; i < this.length; i += 1) {\n let parent = this[i].parentNode; // eslint-disable-line\n\n while (parent) {\n if (selector) {\n if ($(parent).is(selector)) parents.push(parent);\n } else {\n parents.push(parent);\n }\n\n parent = parent.parentNode;\n }\n }\n\n return $(parents);\n}\n\nfunction closest(selector) {\n let closest = this; // eslint-disable-line\n\n if (typeof selector === 'undefined') {\n return $([]);\n }\n\n if (!closest.is(selector)) {\n closest = closest.parents(selector).eq(0);\n }\n\n return closest;\n}\n\nfunction find(selector) {\n const foundElements = [];\n\n for (let i = 0; i < this.length; i += 1) {\n const found = this[i].querySelectorAll(selector);\n\n for (let j = 0; j < found.length; j += 1) {\n foundElements.push(found[j]);\n }\n }\n\n return $(foundElements);\n}\n\nfunction children(selector) {\n const children = []; // eslint-disable-line\n\n for (let i = 0; i < this.length; i += 1) {\n const childNodes = this[i].children;\n\n for (let j = 0; j < childNodes.length; j += 1) {\n if (!selector || $(childNodes[j]).is(selector)) {\n children.push(childNodes[j]);\n }\n }\n }\n\n return $(children);\n}\n\nfunction remove() {\n for (let i = 0; i < this.length; i += 1) {\n if (this[i].parentNode) this[i].parentNode.removeChild(this[i]);\n }\n\n return this;\n}\n\nfunction detach() {\n return this.remove();\n}\n\nfunction add(...els) {\n const dom = this;\n let i;\n let j;\n\n for (i = 0; i < els.length; i += 1) {\n const toAdd = $(els[i]);\n\n for (j = 0; j < toAdd.length; j += 1) {\n dom.push(toAdd[j]);\n }\n }\n\n return dom;\n}\n\nfunction empty() {\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (el.nodeType === 1) {\n for (let j = 0; j < el.childNodes.length; j += 1) {\n if (el.childNodes[j].parentNode) {\n el.childNodes[j].parentNode.removeChild(el.childNodes[j]);\n }\n }\n\n el.textContent = '';\n }\n }\n\n return this;\n}\n\n// eslint-disable-next-line\n\nfunction scrollTo(...args) {\n const window = getWindow();\n let [left, top, duration, easing, callback] = args;\n\n if (args.length === 4 && typeof easing === 'function') {\n callback = easing;\n [left, top, duration, callback, easing] = args;\n }\n\n if (typeof easing === 'undefined') easing = 'swing';\n return this.each(function animate() {\n const el = this;\n let currentTop;\n let currentLeft;\n let maxTop;\n let maxLeft;\n let newTop;\n let newLeft;\n let scrollTop; // eslint-disable-line\n\n let scrollLeft; // eslint-disable-line\n\n let animateTop = top > 0 || top === 0;\n let animateLeft = left > 0 || left === 0;\n\n if (typeof easing === 'undefined') {\n easing = 'swing';\n }\n\n if (animateTop) {\n currentTop = el.scrollTop;\n\n if (!duration) {\n el.scrollTop = top;\n }\n }\n\n if (animateLeft) {\n currentLeft = el.scrollLeft;\n\n if (!duration) {\n el.scrollLeft = left;\n }\n }\n\n if (!duration) return;\n\n if (animateTop) {\n maxTop = el.scrollHeight - el.offsetHeight;\n newTop = Math.max(Math.min(top, maxTop), 0);\n }\n\n if (animateLeft) {\n maxLeft = el.scrollWidth - el.offsetWidth;\n newLeft = Math.max(Math.min(left, maxLeft), 0);\n }\n\n let startTime = null;\n if (animateTop && newTop === currentTop) animateTop = false;\n if (animateLeft && newLeft === currentLeft) animateLeft = false;\n\n function render(time = new Date().getTime()) {\n if (startTime === null) {\n startTime = time;\n }\n\n const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);\n const easeProgress = easing === 'linear' ? progress : 0.5 - Math.cos(progress * Math.PI) / 2;\n let done;\n if (animateTop) scrollTop = currentTop + easeProgress * (newTop - currentTop);\n if (animateLeft) scrollLeft = currentLeft + easeProgress * (newLeft - currentLeft);\n\n if (animateTop && newTop > currentTop && scrollTop >= newTop) {\n el.scrollTop = newTop;\n done = true;\n }\n\n if (animateTop && newTop < currentTop && scrollTop <= newTop) {\n el.scrollTop = newTop;\n done = true;\n }\n\n if (animateLeft && newLeft > currentLeft && scrollLeft >= newLeft) {\n el.scrollLeft = newLeft;\n done = true;\n }\n\n if (animateLeft && newLeft < currentLeft && scrollLeft <= newLeft) {\n el.scrollLeft = newLeft;\n done = true;\n }\n\n if (done) {\n if (callback) callback();\n return;\n }\n\n if (animateTop) el.scrollTop = scrollTop;\n if (animateLeft) el.scrollLeft = scrollLeft;\n window.requestAnimationFrame(render);\n }\n\n window.requestAnimationFrame(render);\n });\n} // scrollTop(top, duration, easing, callback) {\n\n\nfunction scrollTop(...args) {\n let [top, duration, easing, callback] = args;\n\n if (args.length === 3 && typeof easing === 'function') {\n [top, duration, callback, easing] = args;\n }\n\n const dom = this;\n\n if (typeof top === 'undefined') {\n if (dom.length > 0) return dom[0].scrollTop;\n return null;\n }\n\n return dom.scrollTo(undefined, top, duration, easing, callback);\n}\n\nfunction scrollLeft(...args) {\n let [left, duration, easing, callback] = args;\n\n if (args.length === 3 && typeof easing === 'function') {\n [left, duration, callback, easing] = args;\n }\n\n const dom = this;\n\n if (typeof left === 'undefined') {\n if (dom.length > 0) return dom[0].scrollLeft;\n return null;\n }\n\n return dom.scrollTo(left, undefined, duration, easing, callback);\n}\n\n// eslint-disable-next-line\n\nfunction animate(initialProps, initialParams) {\n const window = getWindow();\n const els = this;\n const a = {\n props: Object.assign({}, initialProps),\n params: Object.assign({\n duration: 300,\n easing: 'swing' // or 'linear'\n\n /* Callbacks\n begin(elements)\n complete(elements)\n progress(elements, complete, remaining, start, tweenValue)\n */\n\n }, initialParams),\n elements: els,\n animating: false,\n que: [],\n\n easingProgress(easing, progress) {\n if (easing === 'swing') {\n return 0.5 - Math.cos(progress * Math.PI) / 2;\n }\n\n if (typeof easing === 'function') {\n return easing(progress);\n }\n\n return progress;\n },\n\n stop() {\n if (a.frameId) {\n window.cancelAnimationFrame(a.frameId);\n }\n\n a.animating = false;\n a.elements.each(el => {\n const element = el;\n delete element.dom7AnimateInstance;\n });\n a.que = [];\n },\n\n done(complete) {\n a.animating = false;\n a.elements.each(el => {\n const element = el;\n delete element.dom7AnimateInstance;\n });\n if (complete) complete(els);\n\n if (a.que.length > 0) {\n const que = a.que.shift();\n a.animate(que[0], que[1]);\n }\n },\n\n animate(props, params) {\n if (a.animating) {\n a.que.push([props, params]);\n return a;\n }\n\n const elements = []; // Define & Cache Initials & Units\n\n a.elements.each((el, index) => {\n let initialFullValue;\n let initialValue;\n let unit;\n let finalValue;\n let finalFullValue;\n if (!el.dom7AnimateInstance) a.elements[index].dom7AnimateInstance = a;\n elements[index] = {\n container: el\n };\n Object.keys(props).forEach(prop => {\n initialFullValue = window.getComputedStyle(el, null).getPropertyValue(prop).replace(',', '.');\n initialValue = parseFloat(initialFullValue);\n unit = initialFullValue.replace(initialValue, '');\n finalValue = parseFloat(props[prop]);\n finalFullValue = props[prop] + unit;\n elements[index][prop] = {\n initialFullValue,\n initialValue,\n unit,\n finalValue,\n finalFullValue,\n currentValue: initialValue\n };\n });\n });\n let startTime = null;\n let time;\n let elementsDone = 0;\n let propsDone = 0;\n let done;\n let began = false;\n a.animating = true;\n\n function render() {\n time = new Date().getTime();\n let progress;\n let easeProgress; // let el;\n\n if (!began) {\n began = true;\n if (params.begin) params.begin(els);\n }\n\n if (startTime === null) {\n startTime = time;\n }\n\n if (params.progress) {\n // eslint-disable-next-line\n params.progress(els, Math.max(Math.min((time - startTime) / params.duration, 1), 0), startTime + params.duration - time < 0 ? 0 : startTime + params.duration - time, startTime);\n }\n\n elements.forEach(element => {\n const el = element;\n if (done || el.done) return;\n Object.keys(props).forEach(prop => {\n if (done || el.done) return;\n progress = Math.max(Math.min((time - startTime) / params.duration, 1), 0);\n easeProgress = a.easingProgress(params.easing, progress);\n const {\n initialValue,\n finalValue,\n unit\n } = el[prop];\n el[prop].currentValue = initialValue + easeProgress * (finalValue - initialValue);\n const currentValue = el[prop].currentValue;\n\n if (finalValue > initialValue && currentValue >= finalValue || finalValue < initialValue && currentValue <= finalValue) {\n el.container.style[prop] = finalValue + unit;\n propsDone += 1;\n\n if (propsDone === Object.keys(props).length) {\n el.done = true;\n elementsDone += 1;\n }\n\n if (elementsDone === elements.length) {\n done = true;\n }\n }\n\n if (done) {\n a.done(params.complete);\n return;\n }\n\n el.container.style[prop] = currentValue + unit;\n });\n });\n if (done) return; // Then call\n\n a.frameId = window.requestAnimationFrame(render);\n }\n\n a.frameId = window.requestAnimationFrame(render);\n return a;\n }\n\n };\n\n if (a.elements.length === 0) {\n return els;\n }\n\n let animateInstance;\n\n for (let i = 0; i < a.elements.length; i += 1) {\n if (a.elements[i].dom7AnimateInstance) {\n animateInstance = a.elements[i].dom7AnimateInstance;\n } else a.elements[i].dom7AnimateInstance = a;\n }\n\n if (!animateInstance) {\n animateInstance = a;\n }\n\n if (initialProps === 'stop') {\n animateInstance.stop();\n } else {\n animateInstance.animate(a.props, a.params);\n }\n\n return els;\n}\n\nfunction stop() {\n const els = this;\n\n for (let i = 0; i < els.length; i += 1) {\n if (els[i].dom7AnimateInstance) {\n els[i].dom7AnimateInstance.stop();\n }\n }\n}\n\nconst noTrigger = 'resize scroll'.split(' ');\n\nfunction shortcut(name) {\n function eventHandler(...args) {\n if (typeof args[0] === 'undefined') {\n for (let i = 0; i < this.length; i += 1) {\n if (noTrigger.indexOf(name) < 0) {\n if (name in this[i]) this[i][name]();else {\n $(this[i]).trigger(name);\n }\n }\n }\n\n return this;\n }\n\n return this.on(name, ...args);\n }\n\n return eventHandler;\n}\n\nconst click = shortcut('click');\nconst blur = shortcut('blur');\nconst focus = shortcut('focus');\nconst focusin = shortcut('focusin');\nconst focusout = shortcut('focusout');\nconst keyup = shortcut('keyup');\nconst keydown = shortcut('keydown');\nconst keypress = shortcut('keypress');\nconst submit = shortcut('submit');\nconst change = shortcut('change');\nconst mousedown = shortcut('mousedown');\nconst mousemove = shortcut('mousemove');\nconst mouseup = shortcut('mouseup');\nconst mouseenter = shortcut('mouseenter');\nconst mouseleave = shortcut('mouseleave');\nconst mouseout = shortcut('mouseout');\nconst mouseover = shortcut('mouseover');\nconst touchstart = shortcut('touchstart');\nconst touchend = shortcut('touchend');\nconst touchmove = shortcut('touchmove');\nconst resize = shortcut('resize');\nconst scroll = shortcut('scroll');\n\nexport default $;\nexport { $, add, addClass, animate, animationEnd, append, appendTo, attr, blur, change, children, click, closest, css, data, dataset, detach, each, empty, eq, filter, find, focus, focusin, focusout, hasClass, height, hide, html, index, insertAfter, insertBefore, is, keydown, keypress, keyup, mousedown, mouseenter, mouseleave, mousemove, mouseout, mouseover, mouseup, next, nextAll, off, offset, on, once, outerHeight, outerWidth, parent, parents, prepend, prependTo, prev, prevAll, prop, remove, removeAttr, removeClass, removeData, resize, scroll, scrollLeft, scrollTo, scrollTop, show, siblings, stop, styles, submit, text, toggleClass, touchend, touchmove, touchstart, transform, transition, transitionEnd, trigger, val, value, width };\n","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nimport possibleConstructorReturn from \"./possibleConstructorReturn.js\";\nexport default function _createSuper(Derived) {\n var hasNativeReflectConstruct = isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = getPrototypeOf(Derived),\n result;\n if (hasNativeReflectConstruct) {\n var NewTarget = getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n return possibleConstructorReturn(this, result);\n };\n}","import { $, addClass, removeClass, hasClass, toggleClass, attr, removeAttr, transform, transition, on, off, trigger, transitionEnd, outerWidth, outerHeight, styles, offset, css, each, html, text, is, index, eq, append, prepend, next, nextAll, prev, prevAll, parent, parents, closest, find, children, filter, remove } from 'dom7';\nconst Methods = {\n addClass,\n removeClass,\n hasClass,\n toggleClass,\n attr,\n removeAttr,\n transform,\n transition,\n on,\n off,\n trigger,\n transitionEnd,\n outerWidth,\n outerHeight,\n styles,\n offset,\n css,\n each,\n html,\n text,\n is,\n index,\n eq,\n append,\n prepend,\n next,\n nextAll,\n prev,\n prevAll,\n parent,\n parents,\n closest,\n find,\n children,\n filter,\n remove\n};\nObject.keys(Methods).forEach(methodName => {\n Object.defineProperty($.fn, methodName, {\n value: Methods[methodName],\n writable: true\n });\n});\nexport default $;","import { getWindow, getDocument } from 'ssr-window';\nlet support;\n\nfunction calcSupport() {\n const window = getWindow();\n const document = getDocument();\n return {\n smoothScroll: document.documentElement && 'scrollBehavior' in document.documentElement.style,\n touch: !!('ontouchstart' in window || window.DocumentTouch && document instanceof window.DocumentTouch),\n passiveListener: function checkPassiveListener() {\n let supportsPassive = false;\n\n try {\n const opts = Object.defineProperty({}, 'passive', {\n // eslint-disable-next-line\n get() {\n supportsPassive = true;\n }\n\n });\n window.addEventListener('testPassiveListener', null, opts);\n } catch (e) {// No support\n }\n\n return supportsPassive;\n }(),\n gestures: function checkGestures() {\n return 'ongesturestart' in window;\n }()\n };\n}\n\nfunction getSupport() {\n if (!support) {\n support = calcSupport();\n }\n\n return support;\n}\n\nexport { getSupport };","import { getWindow } from 'ssr-window';\nimport { getSupport } from './get-support.js';\nlet deviceCached;\n\nfunction calcDevice({\n userAgent\n} = {}) {\n const support = getSupport();\n const window = getWindow();\n const platform = window.navigator.platform;\n const ua = userAgent || window.navigator.userAgent;\n const device = {\n ios: false,\n android: false\n };\n const screenWidth = window.screen.width;\n const screenHeight = window.screen.height;\n const android = ua.match(/(Android);?[\\s\\/]+([\\d.]+)?/); // eslint-disable-line\n\n let ipad = ua.match(/(iPad).*OS\\s([\\d_]+)/);\n const ipod = ua.match(/(iPod)(.*OS\\s([\\d_]+))?/);\n const iphone = !ipad && ua.match(/(iPhone\\sOS|iOS)\\s([\\d_]+)/);\n const windows = platform === 'Win32';\n let macos = platform === 'MacIntel'; // iPadOs 13 fix\n\n const iPadScreens = ['1024x1366', '1366x1024', '834x1194', '1194x834', '834x1112', '1112x834', '768x1024', '1024x768', '820x1180', '1180x820', '810x1080', '1080x810'];\n\n if (!ipad && macos && support.touch && iPadScreens.indexOf(`${screenWidth}x${screenHeight}`) >= 0) {\n ipad = ua.match(/(Version)\\/([\\d.]+)/);\n if (!ipad) ipad = [0, 1, '13_0_0'];\n macos = false;\n } // Android\n\n\n if (android && !windows) {\n device.os = 'android';\n device.android = true;\n }\n\n if (ipad || iphone || ipod) {\n device.os = 'ios';\n device.ios = true;\n } // Export object\n\n\n return device;\n}\n\nfunction getDevice(overrides = {}) {\n if (!deviceCached) {\n deviceCached = calcDevice(overrides);\n }\n\n return deviceCached;\n}\n\nexport { getDevice };","import { getWindow } from 'ssr-window';\nlet browser;\n\nfunction calcBrowser() {\n const window = getWindow();\n\n function isSafari() {\n const ua = window.navigator.userAgent.toLowerCase();\n return ua.indexOf('safari') >= 0 && ua.indexOf('chrome') < 0 && ua.indexOf('android') < 0;\n }\n\n return {\n isSafari: isSafari(),\n isWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(window.navigator.userAgent)\n };\n}\n\nfunction getBrowser() {\n if (!browser) {\n browser = calcBrowser();\n }\n\n return browser;\n}\n\nexport { getBrowser };","import { getWindow } from 'ssr-window';\n\nfunction deleteProps(obj) {\n const object = obj;\n Object.keys(object).forEach(key => {\n try {\n object[key] = null;\n } catch (e) {// no getter for object\n }\n\n try {\n delete object[key];\n } catch (e) {// something got wrong\n }\n });\n}\n\nfunction nextTick(callback, delay = 0) {\n return setTimeout(callback, delay);\n}\n\nfunction now() {\n return Date.now();\n}\n\nfunction getComputedStyle(el) {\n const window = getWindow();\n let style;\n\n if (window.getComputedStyle) {\n style = window.getComputedStyle(el, null);\n }\n\n if (!style && el.currentStyle) {\n style = el.currentStyle;\n }\n\n if (!style) {\n style = el.style;\n }\n\n return style;\n}\n\nfunction getTranslate(el, axis = 'x') {\n const window = getWindow();\n let matrix;\n let curTransform;\n let transformMatrix;\n const curStyle = getComputedStyle(el, null);\n\n if (window.WebKitCSSMatrix) {\n curTransform = curStyle.transform || curStyle.webkitTransform;\n\n if (curTransform.split(',').length > 6) {\n curTransform = curTransform.split(', ').map(a => a.replace(',', '.')).join(', ');\n } // Some old versions of Webkit choke when 'none' is passed; pass\n // empty string instead in this case\n\n\n transformMatrix = new window.WebKitCSSMatrix(curTransform === 'none' ? '' : curTransform);\n } else {\n transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue('transform').replace('translate(', 'matrix(1, 0, 0, 1,');\n matrix = transformMatrix.toString().split(',');\n }\n\n if (axis === 'x') {\n // Latest Chrome and webkits Fix\n if (window.WebKitCSSMatrix) curTransform = transformMatrix.m41; // Crazy IE10 Matrix\n else if (matrix.length === 16) curTransform = parseFloat(matrix[12]); // Normal Browsers\n else curTransform = parseFloat(matrix[4]);\n }\n\n if (axis === 'y') {\n // Latest Chrome and webkits Fix\n if (window.WebKitCSSMatrix) curTransform = transformMatrix.m42; // Crazy IE10 Matrix\n else if (matrix.length === 16) curTransform = parseFloat(matrix[13]); // Normal Browsers\n else curTransform = parseFloat(matrix[5]);\n }\n\n return curTransform || 0;\n}\n\nfunction isObject(o) {\n return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';\n}\n\nfunction isNode(node) {\n // eslint-disable-next-line\n if (typeof window !== 'undefined' && typeof window.HTMLElement !== 'undefined') {\n return node instanceof HTMLElement;\n }\n\n return node && (node.nodeType === 1 || node.nodeType === 11);\n}\n\nfunction extend(...args) {\n const to = Object(args[0]);\n const noExtend = ['__proto__', 'constructor', 'prototype'];\n\n for (let i = 1; i < args.length; i += 1) {\n const nextSource = args[i];\n\n if (nextSource !== undefined && nextSource !== null && !isNode(nextSource)) {\n const keysArray = Object.keys(Object(nextSource)).filter(key => noExtend.indexOf(key) < 0);\n\n for (let nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex += 1) {\n const nextKey = keysArray[nextIndex];\n const desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n\n if (desc !== undefined && desc.enumerable) {\n if (isObject(to[nextKey]) && isObject(nextSource[nextKey])) {\n if (nextSource[nextKey].__swiper__) {\n to[nextKey] = nextSource[nextKey];\n } else {\n extend(to[nextKey], nextSource[nextKey]);\n }\n } else if (!isObject(to[nextKey]) && isObject(nextSource[nextKey])) {\n to[nextKey] = {};\n\n if (nextSource[nextKey].__swiper__) {\n to[nextKey] = nextSource[nextKey];\n } else {\n extend(to[nextKey], nextSource[nextKey]);\n }\n } else {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n }\n }\n\n return to;\n}\n\nfunction setCSSProperty(el, varName, varValue) {\n el.style.setProperty(varName, varValue);\n}\n\nfunction animateCSSModeScroll({\n swiper,\n targetPosition,\n side\n}) {\n const window = getWindow();\n const startPosition = -swiper.translate;\n let startTime = null;\n let time;\n const duration = swiper.params.speed;\n swiper.wrapperEl.style.scrollSnapType = 'none';\n window.cancelAnimationFrame(swiper.cssModeFrameID);\n const dir = targetPosition > startPosition ? 'next' : 'prev';\n\n const isOutOfBound = (current, target) => {\n return dir === 'next' && current >= target || dir === 'prev' && current <= target;\n };\n\n const animate = () => {\n time = new Date().getTime();\n\n if (startTime === null) {\n startTime = time;\n }\n\n const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);\n const easeProgress = 0.5 - Math.cos(progress * Math.PI) / 2;\n let currentPosition = startPosition + easeProgress * (targetPosition - startPosition);\n\n if (isOutOfBound(currentPosition, targetPosition)) {\n currentPosition = targetPosition;\n }\n\n swiper.wrapperEl.scrollTo({\n [side]: currentPosition\n });\n\n if (isOutOfBound(currentPosition, targetPosition)) {\n swiper.wrapperEl.style.overflow = 'hidden';\n swiper.wrapperEl.style.scrollSnapType = '';\n setTimeout(() => {\n swiper.wrapperEl.style.overflow = '';\n swiper.wrapperEl.scrollTo({\n [side]: currentPosition\n });\n });\n window.cancelAnimationFrame(swiper.cssModeFrameID);\n return;\n }\n\n swiper.cssModeFrameID = window.requestAnimationFrame(animate);\n };\n\n animate();\n}\n\nexport { animateCSSModeScroll, deleteProps, nextTick, now, getTranslate, isObject, extend, getComputedStyle, setCSSProperty };","/* eslint-disable no-underscore-dangle */\nexport default {\n on(events, handler, priority) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (typeof handler !== 'function') return self;\n const method = priority ? 'unshift' : 'push';\n events.split(' ').forEach(event => {\n if (!self.eventsListeners[event]) self.eventsListeners[event] = [];\n self.eventsListeners[event][method](handler);\n });\n return self;\n },\n\n once(events, handler, priority) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (typeof handler !== 'function') return self;\n\n function onceHandler(...args) {\n self.off(events, onceHandler);\n\n if (onceHandler.__emitterProxy) {\n delete onceHandler.__emitterProxy;\n }\n\n handler.apply(self, args);\n }\n\n onceHandler.__emitterProxy = handler;\n return self.on(events, onceHandler, priority);\n },\n\n onAny(handler, priority) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (typeof handler !== 'function') return self;\n const method = priority ? 'unshift' : 'push';\n\n if (self.eventsAnyListeners.indexOf(handler) < 0) {\n self.eventsAnyListeners[method](handler);\n }\n\n return self;\n },\n\n offAny(handler) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (!self.eventsAnyListeners) return self;\n const index = self.eventsAnyListeners.indexOf(handler);\n\n if (index >= 0) {\n self.eventsAnyListeners.splice(index, 1);\n }\n\n return self;\n },\n\n off(events, handler) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (!self.eventsListeners) return self;\n events.split(' ').forEach(event => {\n if (typeof handler === 'undefined') {\n self.eventsListeners[event] = [];\n } else if (self.eventsListeners[event]) {\n self.eventsListeners[event].forEach((eventHandler, index) => {\n if (eventHandler === handler || eventHandler.__emitterProxy && eventHandler.__emitterProxy === handler) {\n self.eventsListeners[event].splice(index, 1);\n }\n });\n }\n });\n return self;\n },\n\n emit(...args) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (!self.eventsListeners) return self;\n let events;\n let data;\n let context;\n\n if (typeof args[0] === 'string' || Array.isArray(args[0])) {\n events = args[0];\n data = args.slice(1, args.length);\n context = self;\n } else {\n events = args[0].events;\n data = args[0].data;\n context = args[0].context || self;\n }\n\n data.unshift(context);\n const eventsArray = Array.isArray(events) ? events : events.split(' ');\n eventsArray.forEach(event => {\n if (self.eventsAnyListeners && self.eventsAnyListeners.length) {\n self.eventsAnyListeners.forEach(eventHandler => {\n eventHandler.apply(context, [event, ...data]);\n });\n }\n\n if (self.eventsListeners && self.eventsListeners[event]) {\n self.eventsListeners[event].forEach(eventHandler => {\n eventHandler.apply(context, data);\n });\n }\n });\n return self;\n }\n\n};","import updateSize from './updateSize.js';\nimport updateSlides from './updateSlides.js';\nimport updateAutoHeight from './updateAutoHeight.js';\nimport updateSlidesOffset from './updateSlidesOffset.js';\nimport updateSlidesProgress from './updateSlidesProgress.js';\nimport updateProgress from './updateProgress.js';\nimport updateSlidesClasses from './updateSlidesClasses.js';\nimport updateActiveIndex from './updateActiveIndex.js';\nimport updateClickedSlide from './updateClickedSlide.js';\nexport default {\n updateSize,\n updateSlides,\n updateAutoHeight,\n updateSlidesOffset,\n updateSlidesProgress,\n updateProgress,\n updateSlidesClasses,\n updateActiveIndex,\n updateClickedSlide\n};","export default function updateSize() {\n const swiper = this;\n let width;\n let height;\n const $el = swiper.$el;\n\n if (typeof swiper.params.width !== 'undefined' && swiper.params.width !== null) {\n width = swiper.params.width;\n } else {\n width = $el[0].clientWidth;\n }\n\n if (typeof swiper.params.height !== 'undefined' && swiper.params.height !== null) {\n height = swiper.params.height;\n } else {\n height = $el[0].clientHeight;\n }\n\n if (width === 0 && swiper.isHorizontal() || height === 0 && swiper.isVertical()) {\n return;\n } // Subtract paddings\n\n\n width = width - parseInt($el.css('padding-left') || 0, 10) - parseInt($el.css('padding-right') || 0, 10);\n height = height - parseInt($el.css('padding-top') || 0, 10) - parseInt($el.css('padding-bottom') || 0, 10);\n if (Number.isNaN(width)) width = 0;\n if (Number.isNaN(height)) height = 0;\n Object.assign(swiper, {\n width,\n height,\n size: swiper.isHorizontal() ? width : height\n });\n}","import { setCSSProperty } from '../../shared/utils.js';\nexport default function updateSlides() {\n const swiper = this;\n\n function getDirectionLabel(property) {\n if (swiper.isHorizontal()) {\n return property;\n } // prettier-ignore\n\n\n return {\n 'width': 'height',\n 'margin-top': 'margin-left',\n 'margin-bottom ': 'margin-right',\n 'margin-left': 'margin-top',\n 'margin-right': 'margin-bottom',\n 'padding-left': 'padding-top',\n 'padding-right': 'padding-bottom',\n 'marginRight': 'marginBottom'\n }[property];\n }\n\n function getDirectionPropertyValue(node, label) {\n return parseFloat(node.getPropertyValue(getDirectionLabel(label)) || 0);\n }\n\n const params = swiper.params;\n const {\n $wrapperEl,\n size: swiperSize,\n rtlTranslate: rtl,\n wrongRTL\n } = swiper;\n const isVirtual = swiper.virtual && params.virtual.enabled;\n const previousSlidesLength = isVirtual ? swiper.virtual.slides.length : swiper.slides.length;\n const slides = $wrapperEl.children(`.${swiper.params.slideClass}`);\n const slidesLength = isVirtual ? swiper.virtual.slides.length : slides.length;\n let snapGrid = [];\n const slidesGrid = [];\n const slidesSizesGrid = [];\n let offsetBefore = params.slidesOffsetBefore;\n\n if (typeof offsetBefore === 'function') {\n offsetBefore = params.slidesOffsetBefore.call(swiper);\n }\n\n let offsetAfter = params.slidesOffsetAfter;\n\n if (typeof offsetAfter === 'function') {\n offsetAfter = params.slidesOffsetAfter.call(swiper);\n }\n\n const previousSnapGridLength = swiper.snapGrid.length;\n const previousSlidesGridLength = swiper.slidesGrid.length;\n let spaceBetween = params.spaceBetween;\n let slidePosition = -offsetBefore;\n let prevSlideSize = 0;\n let index = 0;\n\n if (typeof swiperSize === 'undefined') {\n return;\n }\n\n if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {\n spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiperSize;\n }\n\n swiper.virtualSize = -spaceBetween; // reset margins\n\n if (rtl) slides.css({\n marginLeft: '',\n marginBottom: '',\n marginTop: ''\n });else slides.css({\n marginRight: '',\n marginBottom: '',\n marginTop: ''\n }); // reset cssMode offsets\n\n if (params.centeredSlides && params.cssMode) {\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', '');\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-after', '');\n }\n\n const gridEnabled = params.grid && params.grid.rows > 1 && swiper.grid;\n\n if (gridEnabled) {\n swiper.grid.initSlides(slidesLength);\n } // Calc slides\n\n\n let slideSize;\n const shouldResetSlideSize = params.slidesPerView === 'auto' && params.breakpoints && Object.keys(params.breakpoints).filter(key => {\n return typeof params.breakpoints[key].slidesPerView !== 'undefined';\n }).length > 0;\n\n for (let i = 0; i < slidesLength; i += 1) {\n slideSize = 0;\n const slide = slides.eq(i);\n\n if (gridEnabled) {\n swiper.grid.updateSlide(i, slide, slidesLength, getDirectionLabel);\n }\n\n if (slide.css('display') === 'none') continue; // eslint-disable-line\n\n if (params.slidesPerView === 'auto') {\n if (shouldResetSlideSize) {\n slides[i].style[getDirectionLabel('width')] = ``;\n }\n\n const slideStyles = getComputedStyle(slide[0]);\n const currentTransform = slide[0].style.transform;\n const currentWebKitTransform = slide[0].style.webkitTransform;\n\n if (currentTransform) {\n slide[0].style.transform = 'none';\n }\n\n if (currentWebKitTransform) {\n slide[0].style.webkitTransform = 'none';\n }\n\n if (params.roundLengths) {\n slideSize = swiper.isHorizontal() ? slide.outerWidth(true) : slide.outerHeight(true);\n } else {\n // eslint-disable-next-line\n const width = getDirectionPropertyValue(slideStyles, 'width');\n const paddingLeft = getDirectionPropertyValue(slideStyles, 'padding-left');\n const paddingRight = getDirectionPropertyValue(slideStyles, 'padding-right');\n const marginLeft = getDirectionPropertyValue(slideStyles, 'margin-left');\n const marginRight = getDirectionPropertyValue(slideStyles, 'margin-right');\n const boxSizing = slideStyles.getPropertyValue('box-sizing');\n\n if (boxSizing && boxSizing === 'border-box') {\n slideSize = width + marginLeft + marginRight;\n } else {\n const {\n clientWidth,\n offsetWidth\n } = slide[0];\n slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight + (offsetWidth - clientWidth);\n }\n }\n\n if (currentTransform) {\n slide[0].style.transform = currentTransform;\n }\n\n if (currentWebKitTransform) {\n slide[0].style.webkitTransform = currentWebKitTransform;\n }\n\n if (params.roundLengths) slideSize = Math.floor(slideSize);\n } else {\n slideSize = (swiperSize - (params.slidesPerView - 1) * spaceBetween) / params.slidesPerView;\n if (params.roundLengths) slideSize = Math.floor(slideSize);\n\n if (slides[i]) {\n slides[i].style[getDirectionLabel('width')] = `${slideSize}px`;\n }\n }\n\n if (slides[i]) {\n slides[i].swiperSlideSize = slideSize;\n }\n\n slidesSizesGrid.push(slideSize);\n\n if (params.centeredSlides) {\n slidePosition = slidePosition + slideSize / 2 + prevSlideSize / 2 + spaceBetween;\n if (prevSlideSize === 0 && i !== 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;\n if (i === 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;\n if (Math.abs(slidePosition) < 1 / 1000) slidePosition = 0;\n if (params.roundLengths) slidePosition = Math.floor(slidePosition);\n if (index % params.slidesPerGroup === 0) snapGrid.push(slidePosition);\n slidesGrid.push(slidePosition);\n } else {\n if (params.roundLengths) slidePosition = Math.floor(slidePosition);\n if ((index - Math.min(swiper.params.slidesPerGroupSkip, index)) % swiper.params.slidesPerGroup === 0) snapGrid.push(slidePosition);\n slidesGrid.push(slidePosition);\n slidePosition = slidePosition + slideSize + spaceBetween;\n }\n\n swiper.virtualSize += slideSize + spaceBetween;\n prevSlideSize = slideSize;\n index += 1;\n }\n\n swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter;\n\n if (rtl && wrongRTL && (params.effect === 'slide' || params.effect === 'coverflow')) {\n $wrapperEl.css({\n width: `${swiper.virtualSize + params.spaceBetween}px`\n });\n }\n\n if (params.setWrapperSize) {\n $wrapperEl.css({\n [getDirectionLabel('width')]: `${swiper.virtualSize + params.spaceBetween}px`\n });\n }\n\n if (gridEnabled) {\n swiper.grid.updateWrapperSize(slideSize, snapGrid, getDirectionLabel);\n } // Remove last grid elements depending on width\n\n\n if (!params.centeredSlides) {\n const newSlidesGrid = [];\n\n for (let i = 0; i < snapGrid.length; i += 1) {\n let slidesGridItem = snapGrid[i];\n if (params.roundLengths) slidesGridItem = Math.floor(slidesGridItem);\n\n if (snapGrid[i] <= swiper.virtualSize - swiperSize) {\n newSlidesGrid.push(slidesGridItem);\n }\n }\n\n snapGrid = newSlidesGrid;\n\n if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) {\n snapGrid.push(swiper.virtualSize - swiperSize);\n }\n }\n\n if (snapGrid.length === 0) snapGrid = [0];\n\n if (params.spaceBetween !== 0) {\n const key = swiper.isHorizontal() && rtl ? 'marginLeft' : getDirectionLabel('marginRight');\n slides.filter((_, slideIndex) => {\n if (!params.cssMode) return true;\n\n if (slideIndex === slides.length - 1) {\n return false;\n }\n\n return true;\n }).css({\n [key]: `${spaceBetween}px`\n });\n }\n\n if (params.centeredSlides && params.centeredSlidesBounds) {\n let allSlidesSize = 0;\n slidesSizesGrid.forEach(slideSizeValue => {\n allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n });\n allSlidesSize -= params.spaceBetween;\n const maxSnap = allSlidesSize - swiperSize;\n snapGrid = snapGrid.map(snap => {\n if (snap < 0) return -offsetBefore;\n if (snap > maxSnap) return maxSnap + offsetAfter;\n return snap;\n });\n }\n\n if (params.centerInsufficientSlides) {\n let allSlidesSize = 0;\n slidesSizesGrid.forEach(slideSizeValue => {\n allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n });\n allSlidesSize -= params.spaceBetween;\n\n if (allSlidesSize < swiperSize) {\n const allSlidesOffset = (swiperSize - allSlidesSize) / 2;\n snapGrid.forEach((snap, snapIndex) => {\n snapGrid[snapIndex] = snap - allSlidesOffset;\n });\n slidesGrid.forEach((snap, snapIndex) => {\n slidesGrid[snapIndex] = snap + allSlidesOffset;\n });\n }\n }\n\n Object.assign(swiper, {\n slides,\n snapGrid,\n slidesGrid,\n slidesSizesGrid\n });\n\n if (params.centeredSlides && params.cssMode && !params.centeredSlidesBounds) {\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', `${-snapGrid[0]}px`);\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-after', `${swiper.size / 2 - slidesSizesGrid[slidesSizesGrid.length - 1] / 2}px`);\n const addToSnapGrid = -swiper.snapGrid[0];\n const addToSlidesGrid = -swiper.slidesGrid[0];\n swiper.snapGrid = swiper.snapGrid.map(v => v + addToSnapGrid);\n swiper.slidesGrid = swiper.slidesGrid.map(v => v + addToSlidesGrid);\n }\n\n if (slidesLength !== previousSlidesLength) {\n swiper.emit('slidesLengthChange');\n }\n\n if (snapGrid.length !== previousSnapGridLength) {\n if (swiper.params.watchOverflow) swiper.checkOverflow();\n swiper.emit('snapGridLengthChange');\n }\n\n if (slidesGrid.length !== previousSlidesGridLength) {\n swiper.emit('slidesGridLengthChange');\n }\n\n if (params.watchSlidesProgress) {\n swiper.updateSlidesOffset();\n }\n\n if (!isVirtual && !params.cssMode && (params.effect === 'slide' || params.effect === 'fade')) {\n const backFaceHiddenClass = `${params.containerModifierClass}backface-hidden`;\n const hasClassBackfaceClassAdded = swiper.$el.hasClass(backFaceHiddenClass);\n\n if (slidesLength <= params.maxBackfaceHiddenSlides) {\n if (!hasClassBackfaceClassAdded) swiper.$el.addClass(backFaceHiddenClass);\n } else if (hasClassBackfaceClassAdded) {\n swiper.$el.removeClass(backFaceHiddenClass);\n }\n }\n}","import $ from '../../shared/dom.js';\nexport default function updateAutoHeight(speed) {\n const swiper = this;\n const activeSlides = [];\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n let newHeight = 0;\n let i;\n\n if (typeof speed === 'number') {\n swiper.setTransition(speed);\n } else if (speed === true) {\n swiper.setTransition(swiper.params.speed);\n }\n\n const getSlideByIndex = index => {\n if (isVirtual) {\n return swiper.slides.filter(el => parseInt(el.getAttribute('data-swiper-slide-index'), 10) === index)[0];\n }\n\n return swiper.slides.eq(index)[0];\n }; // Find slides currently in view\n\n\n if (swiper.params.slidesPerView !== 'auto' && swiper.params.slidesPerView > 1) {\n if (swiper.params.centeredSlides) {\n (swiper.visibleSlides || $([])).each(slide => {\n activeSlides.push(slide);\n });\n } else {\n for (i = 0; i < Math.ceil(swiper.params.slidesPerView); i += 1) {\n const index = swiper.activeIndex + i;\n if (index > swiper.slides.length && !isVirtual) break;\n activeSlides.push(getSlideByIndex(index));\n }\n }\n } else {\n activeSlides.push(getSlideByIndex(swiper.activeIndex));\n } // Find new height from highest slide in view\n\n\n for (i = 0; i < activeSlides.length; i += 1) {\n if (typeof activeSlides[i] !== 'undefined') {\n const height = activeSlides[i].offsetHeight;\n newHeight = height > newHeight ? height : newHeight;\n }\n } // Update Height\n\n\n if (newHeight || newHeight === 0) swiper.$wrapperEl.css('height', `${newHeight}px`);\n}","export default function updateSlidesOffset() {\n const swiper = this;\n const slides = swiper.slides;\n\n for (let i = 0; i < slides.length; i += 1) {\n slides[i].swiperSlideOffset = swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop;\n }\n}","import $ from '../../shared/dom.js';\nexport default function updateSlidesProgress(translate = this && this.translate || 0) {\n const swiper = this;\n const params = swiper.params;\n const {\n slides,\n rtlTranslate: rtl,\n snapGrid\n } = swiper;\n if (slides.length === 0) return;\n if (typeof slides[0].swiperSlideOffset === 'undefined') swiper.updateSlidesOffset();\n let offsetCenter = -translate;\n if (rtl) offsetCenter = translate; // Visible Slides\n\n slides.removeClass(params.slideVisibleClass);\n swiper.visibleSlidesIndexes = [];\n swiper.visibleSlides = [];\n\n for (let i = 0; i < slides.length; i += 1) {\n const slide = slides[i];\n let slideOffset = slide.swiperSlideOffset;\n\n if (params.cssMode && params.centeredSlides) {\n slideOffset -= slides[0].swiperSlideOffset;\n }\n\n const slideProgress = (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);\n const originalSlideProgress = (offsetCenter - snapGrid[0] + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);\n const slideBefore = -(offsetCenter - slideOffset);\n const slideAfter = slideBefore + swiper.slidesSizesGrid[i];\n const isVisible = slideBefore >= 0 && slideBefore < swiper.size - 1 || slideAfter > 1 && slideAfter <= swiper.size || slideBefore <= 0 && slideAfter >= swiper.size;\n\n if (isVisible) {\n swiper.visibleSlides.push(slide);\n swiper.visibleSlidesIndexes.push(i);\n slides.eq(i).addClass(params.slideVisibleClass);\n }\n\n slide.progress = rtl ? -slideProgress : slideProgress;\n slide.originalProgress = rtl ? -originalSlideProgress : originalSlideProgress;\n }\n\n swiper.visibleSlides = $(swiper.visibleSlides);\n}","export default function updateProgress(translate) {\n const swiper = this;\n\n if (typeof translate === 'undefined') {\n const multiplier = swiper.rtlTranslate ? -1 : 1; // eslint-disable-next-line\n\n translate = swiper && swiper.translate && swiper.translate * multiplier || 0;\n }\n\n const params = swiper.params;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n let {\n progress,\n isBeginning,\n isEnd\n } = swiper;\n const wasBeginning = isBeginning;\n const wasEnd = isEnd;\n\n if (translatesDiff === 0) {\n progress = 0;\n isBeginning = true;\n isEnd = true;\n } else {\n progress = (translate - swiper.minTranslate()) / translatesDiff;\n isBeginning = progress <= 0;\n isEnd = progress >= 1;\n }\n\n Object.assign(swiper, {\n progress,\n isBeginning,\n isEnd\n });\n if (params.watchSlidesProgress || params.centeredSlides && params.autoHeight) swiper.updateSlidesProgress(translate);\n\n if (isBeginning && !wasBeginning) {\n swiper.emit('reachBeginning toEdge');\n }\n\n if (isEnd && !wasEnd) {\n swiper.emit('reachEnd toEdge');\n }\n\n if (wasBeginning && !isBeginning || wasEnd && !isEnd) {\n swiper.emit('fromEdge');\n }\n\n swiper.emit('progress', progress);\n}","export default function updateSlidesClasses() {\n const swiper = this;\n const {\n slides,\n params,\n $wrapperEl,\n activeIndex,\n realIndex\n } = swiper;\n const isVirtual = swiper.virtual && params.virtual.enabled;\n slides.removeClass(`${params.slideActiveClass} ${params.slideNextClass} ${params.slidePrevClass} ${params.slideDuplicateActiveClass} ${params.slideDuplicateNextClass} ${params.slideDuplicatePrevClass}`);\n let activeSlide;\n\n if (isVirtual) {\n activeSlide = swiper.$wrapperEl.find(`.${params.slideClass}[data-swiper-slide-index=\"${activeIndex}\"]`);\n } else {\n activeSlide = slides.eq(activeIndex);\n } // Active classes\n\n\n activeSlide.addClass(params.slideActiveClass);\n\n if (params.loop) {\n // Duplicate to all looped slides\n if (activeSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${realIndex}\"]`).addClass(params.slideDuplicateActiveClass);\n } else {\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${realIndex}\"]`).addClass(params.slideDuplicateActiveClass);\n }\n } // Next Slide\n\n\n let nextSlide = activeSlide.nextAll(`.${params.slideClass}`).eq(0).addClass(params.slideNextClass);\n\n if (params.loop && nextSlide.length === 0) {\n nextSlide = slides.eq(0);\n nextSlide.addClass(params.slideNextClass);\n } // Prev Slide\n\n\n let prevSlide = activeSlide.prevAll(`.${params.slideClass}`).eq(0).addClass(params.slidePrevClass);\n\n if (params.loop && prevSlide.length === 0) {\n prevSlide = slides.eq(-1);\n prevSlide.addClass(params.slidePrevClass);\n }\n\n if (params.loop) {\n // Duplicate to all looped slides\n if (nextSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${nextSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicateNextClass);\n } else {\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${nextSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicateNextClass);\n }\n\n if (prevSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${prevSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicatePrevClass);\n } else {\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${prevSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicatePrevClass);\n }\n }\n\n swiper.emitSlidesClasses();\n}","export default function updateActiveIndex(newActiveIndex) {\n const swiper = this;\n const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n const {\n slidesGrid,\n snapGrid,\n params,\n activeIndex: previousIndex,\n realIndex: previousRealIndex,\n snapIndex: previousSnapIndex\n } = swiper;\n let activeIndex = newActiveIndex;\n let snapIndex;\n\n if (typeof activeIndex === 'undefined') {\n for (let i = 0; i < slidesGrid.length; i += 1) {\n if (typeof slidesGrid[i + 1] !== 'undefined') {\n if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1] - (slidesGrid[i + 1] - slidesGrid[i]) / 2) {\n activeIndex = i;\n } else if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1]) {\n activeIndex = i + 1;\n }\n } else if (translate >= slidesGrid[i]) {\n activeIndex = i;\n }\n } // Normalize slideIndex\n\n\n if (params.normalizeSlideIndex) {\n if (activeIndex < 0 || typeof activeIndex === 'undefined') activeIndex = 0;\n }\n }\n\n if (snapGrid.indexOf(translate) >= 0) {\n snapIndex = snapGrid.indexOf(translate);\n } else {\n const skip = Math.min(params.slidesPerGroupSkip, activeIndex);\n snapIndex = skip + Math.floor((activeIndex - skip) / params.slidesPerGroup);\n }\n\n if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;\n\n if (activeIndex === previousIndex) {\n if (snapIndex !== previousSnapIndex) {\n swiper.snapIndex = snapIndex;\n swiper.emit('snapIndexChange');\n }\n\n return;\n } // Get real index\n\n\n const realIndex = parseInt(swiper.slides.eq(activeIndex).attr('data-swiper-slide-index') || activeIndex, 10);\n Object.assign(swiper, {\n snapIndex,\n realIndex,\n previousIndex,\n activeIndex\n });\n swiper.emit('activeIndexChange');\n swiper.emit('snapIndexChange');\n\n if (previousRealIndex !== realIndex) {\n swiper.emit('realIndexChange');\n }\n\n if (swiper.initialized || swiper.params.runCallbacksOnInit) {\n swiper.emit('slideChange');\n }\n}","import $ from '../../shared/dom.js';\nexport default function updateClickedSlide(e) {\n const swiper = this;\n const params = swiper.params;\n const slide = $(e).closest(`.${params.slideClass}`)[0];\n let slideFound = false;\n let slideIndex;\n\n if (slide) {\n for (let i = 0; i < swiper.slides.length; i += 1) {\n if (swiper.slides[i] === slide) {\n slideFound = true;\n slideIndex = i;\n break;\n }\n }\n }\n\n if (slide && slideFound) {\n swiper.clickedSlide = slide;\n\n if (swiper.virtual && swiper.params.virtual.enabled) {\n swiper.clickedIndex = parseInt($(slide).attr('data-swiper-slide-index'), 10);\n } else {\n swiper.clickedIndex = slideIndex;\n }\n } else {\n swiper.clickedSlide = undefined;\n swiper.clickedIndex = undefined;\n return;\n }\n\n if (params.slideToClickedSlide && swiper.clickedIndex !== undefined && swiper.clickedIndex !== swiper.activeIndex) {\n swiper.slideToClickedSlide();\n }\n}","import getTranslate from './getTranslate.js';\nimport setTranslate from './setTranslate.js';\nimport minTranslate from './minTranslate.js';\nimport maxTranslate from './maxTranslate.js';\nimport translateTo from './translateTo.js';\nexport default {\n getTranslate,\n setTranslate,\n minTranslate,\n maxTranslate,\n translateTo\n};","import { getTranslate } from '../../shared/utils.js';\nexport default function getSwiperTranslate(axis = this.isHorizontal() ? 'x' : 'y') {\n const swiper = this;\n const {\n params,\n rtlTranslate: rtl,\n translate,\n $wrapperEl\n } = swiper;\n\n if (params.virtualTranslate) {\n return rtl ? -translate : translate;\n }\n\n if (params.cssMode) {\n return translate;\n }\n\n let currentTranslate = getTranslate($wrapperEl[0], axis);\n if (rtl) currentTranslate = -currentTranslate;\n return currentTranslate || 0;\n}","export default function setTranslate(translate, byController) {\n const swiper = this;\n const {\n rtlTranslate: rtl,\n params,\n $wrapperEl,\n wrapperEl,\n progress\n } = swiper;\n let x = 0;\n let y = 0;\n const z = 0;\n\n if (swiper.isHorizontal()) {\n x = rtl ? -translate : translate;\n } else {\n y = translate;\n }\n\n if (params.roundLengths) {\n x = Math.floor(x);\n y = Math.floor(y);\n }\n\n if (params.cssMode) {\n wrapperEl[swiper.isHorizontal() ? 'scrollLeft' : 'scrollTop'] = swiper.isHorizontal() ? -x : -y;\n } else if (!params.virtualTranslate) {\n $wrapperEl.transform(`translate3d(${x}px, ${y}px, ${z}px)`);\n }\n\n swiper.previousTranslate = swiper.translate;\n swiper.translate = swiper.isHorizontal() ? x : y; // Check if we need to update progress\n\n let newProgress;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n\n if (translatesDiff === 0) {\n newProgress = 0;\n } else {\n newProgress = (translate - swiper.minTranslate()) / translatesDiff;\n }\n\n if (newProgress !== progress) {\n swiper.updateProgress(translate);\n }\n\n swiper.emit('setTranslate', swiper.translate, byController);\n}","export default function minTranslate() {\n return -this.snapGrid[0];\n}","export default function maxTranslate() {\n return -this.snapGrid[this.snapGrid.length - 1];\n}","import { animateCSSModeScroll } from '../../shared/utils.js';\nexport default function translateTo(translate = 0, speed = this.params.speed, runCallbacks = true, translateBounds = true, internal) {\n const swiper = this;\n const {\n params,\n wrapperEl\n } = swiper;\n\n if (swiper.animating && params.preventInteractionOnTransition) {\n return false;\n }\n\n const minTranslate = swiper.minTranslate();\n const maxTranslate = swiper.maxTranslate();\n let newTranslate;\n if (translateBounds && translate > minTranslate) newTranslate = minTranslate;else if (translateBounds && translate < maxTranslate) newTranslate = maxTranslate;else newTranslate = translate; // Update progress\n\n swiper.updateProgress(newTranslate);\n\n if (params.cssMode) {\n const isH = swiper.isHorizontal();\n\n if (speed === 0) {\n wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = -newTranslate;\n } else {\n if (!swiper.support.smoothScroll) {\n animateCSSModeScroll({\n swiper,\n targetPosition: -newTranslate,\n side: isH ? 'left' : 'top'\n });\n return true;\n }\n\n wrapperEl.scrollTo({\n [isH ? 'left' : 'top']: -newTranslate,\n behavior: 'smooth'\n });\n }\n\n return true;\n }\n\n if (speed === 0) {\n swiper.setTransition(0);\n swiper.setTranslate(newTranslate);\n\n if (runCallbacks) {\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.emit('transitionEnd');\n }\n } else {\n swiper.setTransition(speed);\n swiper.setTranslate(newTranslate);\n\n if (runCallbacks) {\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.emit('transitionStart');\n }\n\n if (!swiper.animating) {\n swiper.animating = true;\n\n if (!swiper.onTranslateToWrapperTransitionEnd) {\n swiper.onTranslateToWrapperTransitionEnd = function transitionEnd(e) {\n if (!swiper || swiper.destroyed) return;\n if (e.target !== this) return;\n swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onTranslateToWrapperTransitionEnd);\n swiper.onTranslateToWrapperTransitionEnd = null;\n delete swiper.onTranslateToWrapperTransitionEnd;\n\n if (runCallbacks) {\n swiper.emit('transitionEnd');\n }\n };\n }\n\n swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\n swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onTranslateToWrapperTransitionEnd);\n }\n }\n\n return true;\n}","export default function transitionEmit({\n swiper,\n runCallbacks,\n direction,\n step\n}) {\n const {\n activeIndex,\n previousIndex\n } = swiper;\n let dir = direction;\n\n if (!dir) {\n if (activeIndex > previousIndex) dir = 'next';else if (activeIndex < previousIndex) dir = 'prev';else dir = 'reset';\n }\n\n swiper.emit(`transition${step}`);\n\n if (runCallbacks && activeIndex !== previousIndex) {\n if (dir === 'reset') {\n swiper.emit(`slideResetTransition${step}`);\n return;\n }\n\n swiper.emit(`slideChangeTransition${step}`);\n\n if (dir === 'next') {\n swiper.emit(`slideNextTransition${step}`);\n } else {\n swiper.emit(`slidePrevTransition${step}`);\n }\n }\n}","import setTransition from './setTransition.js';\nimport transitionStart from './transitionStart.js';\nimport transitionEnd from './transitionEnd.js';\nexport default {\n setTransition,\n transitionStart,\n transitionEnd\n};","export default function setTransition(duration, byController) {\n const swiper = this;\n\n if (!swiper.params.cssMode) {\n swiper.$wrapperEl.transition(duration);\n }\n\n swiper.emit('setTransition', duration, byController);\n}","import transitionEmit from './transitionEmit.js';\nexport default function transitionStart(runCallbacks = true, direction) {\n const swiper = this;\n const {\n params\n } = swiper;\n if (params.cssMode) return;\n\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n\n transitionEmit({\n swiper,\n runCallbacks,\n direction,\n step: 'Start'\n });\n}","import transitionEmit from './transitionEmit.js';\nexport default function transitionEnd(runCallbacks = true, direction) {\n const swiper = this;\n const {\n params\n } = swiper;\n swiper.animating = false;\n if (params.cssMode) return;\n swiper.setTransition(0);\n transitionEmit({\n swiper,\n runCallbacks,\n direction,\n step: 'End'\n });\n}","import slideTo from './slideTo.js';\nimport slideToLoop from './slideToLoop.js';\nimport slideNext from './slideNext.js';\nimport slidePrev from './slidePrev.js';\nimport slideReset from './slideReset.js';\nimport slideToClosest from './slideToClosest.js';\nimport slideToClickedSlide from './slideToClickedSlide.js';\nexport default {\n slideTo,\n slideToLoop,\n slideNext,\n slidePrev,\n slideReset,\n slideToClosest,\n slideToClickedSlide\n};","import { animateCSSModeScroll } from '../../shared/utils.js';\nexport default function slideTo(index = 0, speed = this.params.speed, runCallbacks = true, internal, initial) {\n if (typeof index !== 'number' && typeof index !== 'string') {\n throw new Error(`The 'index' argument cannot have type other than 'number' or 'string'. [${typeof index}] given.`);\n }\n\n if (typeof index === 'string') {\n /**\n * The `index` argument converted from `string` to `number`.\n * @type {number}\n */\n const indexAsNumber = parseInt(index, 10);\n /**\n * Determines whether the `index` argument is a valid `number`\n * after being converted from the `string` type.\n * @type {boolean}\n */\n\n const isValidNumber = isFinite(indexAsNumber);\n\n if (!isValidNumber) {\n throw new Error(`The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`);\n } // Knowing that the converted `index` is a valid number,\n // we can update the original argument's value.\n\n\n index = indexAsNumber;\n }\n\n const swiper = this;\n let slideIndex = index;\n if (slideIndex < 0) slideIndex = 0;\n const {\n params,\n snapGrid,\n slidesGrid,\n previousIndex,\n activeIndex,\n rtlTranslate: rtl,\n wrapperEl,\n enabled\n } = swiper;\n\n if (swiper.animating && params.preventInteractionOnTransition || !enabled && !internal && !initial) {\n return false;\n }\n\n const skip = Math.min(swiper.params.slidesPerGroupSkip, slideIndex);\n let snapIndex = skip + Math.floor((slideIndex - skip) / swiper.params.slidesPerGroup);\n if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;\n const translate = -snapGrid[snapIndex]; // Normalize slideIndex\n\n if (params.normalizeSlideIndex) {\n for (let i = 0; i < slidesGrid.length; i += 1) {\n const normalizedTranslate = -Math.floor(translate * 100);\n const normalizedGrid = Math.floor(slidesGrid[i] * 100);\n const normalizedGridNext = Math.floor(slidesGrid[i + 1] * 100);\n\n if (typeof slidesGrid[i + 1] !== 'undefined') {\n if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext - (normalizedGridNext - normalizedGrid) / 2) {\n slideIndex = i;\n } else if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext) {\n slideIndex = i + 1;\n }\n } else if (normalizedTranslate >= normalizedGrid) {\n slideIndex = i;\n }\n }\n } // Directions locks\n\n\n if (swiper.initialized && slideIndex !== activeIndex) {\n if (!swiper.allowSlideNext && translate < swiper.translate && translate < swiper.minTranslate()) {\n return false;\n }\n\n if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) {\n if ((activeIndex || 0) !== slideIndex) return false;\n }\n }\n\n if (slideIndex !== (previousIndex || 0) && runCallbacks) {\n swiper.emit('beforeSlideChangeStart');\n } // Update progress\n\n\n swiper.updateProgress(translate);\n let direction;\n if (slideIndex > activeIndex) direction = 'next';else if (slideIndex < activeIndex) direction = 'prev';else direction = 'reset'; // Update Index\n\n if (rtl && -translate === swiper.translate || !rtl && translate === swiper.translate) {\n swiper.updateActiveIndex(slideIndex); // Update Height\n\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n\n swiper.updateSlidesClasses();\n\n if (params.effect !== 'slide') {\n swiper.setTranslate(translate);\n }\n\n if (direction !== 'reset') {\n swiper.transitionStart(runCallbacks, direction);\n swiper.transitionEnd(runCallbacks, direction);\n }\n\n return false;\n }\n\n if (params.cssMode) {\n const isH = swiper.isHorizontal();\n const t = rtl ? translate : -translate;\n\n if (speed === 0) {\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n\n if (isVirtual) {\n swiper.wrapperEl.style.scrollSnapType = 'none';\n swiper._immediateVirtual = true;\n }\n\n wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = t;\n\n if (isVirtual) {\n requestAnimationFrame(() => {\n swiper.wrapperEl.style.scrollSnapType = '';\n swiper._swiperImmediateVirtual = false;\n });\n }\n } else {\n if (!swiper.support.smoothScroll) {\n animateCSSModeScroll({\n swiper,\n targetPosition: t,\n side: isH ? 'left' : 'top'\n });\n return true;\n }\n\n wrapperEl.scrollTo({\n [isH ? 'left' : 'top']: t,\n behavior: 'smooth'\n });\n }\n\n return true;\n }\n\n swiper.setTransition(speed);\n swiper.setTranslate(translate);\n swiper.updateActiveIndex(slideIndex);\n swiper.updateSlidesClasses();\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.transitionStart(runCallbacks, direction);\n\n if (speed === 0) {\n swiper.transitionEnd(runCallbacks, direction);\n } else if (!swiper.animating) {\n swiper.animating = true;\n\n if (!swiper.onSlideToWrapperTransitionEnd) {\n swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) {\n if (!swiper || swiper.destroyed) return;\n if (e.target !== this) return;\n swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n swiper.onSlideToWrapperTransitionEnd = null;\n delete swiper.onSlideToWrapperTransitionEnd;\n swiper.transitionEnd(runCallbacks, direction);\n };\n }\n\n swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n }\n\n return true;\n}","export default function slideToLoop(index = 0, speed = this.params.speed, runCallbacks = true, internal) {\n if (typeof index === 'string') {\n /**\n * The `index` argument converted from `string` to `number`.\n * @type {number}\n */\n const indexAsNumber = parseInt(index, 10);\n /**\n * Determines whether the `index` argument is a valid `number`\n * after being converted from the `string` type.\n * @type {boolean}\n */\n\n const isValidNumber = isFinite(indexAsNumber);\n\n if (!isValidNumber) {\n throw new Error(`The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`);\n } // Knowing that the converted `index` is a valid number,\n // we can update the original argument's value.\n\n\n index = indexAsNumber;\n }\n\n const swiper = this;\n let newIndex = index;\n\n if (swiper.params.loop) {\n newIndex += swiper.loopedSlides;\n }\n\n return swiper.slideTo(newIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideNext(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n const {\n animating,\n enabled,\n params\n } = swiper;\n if (!enabled) return swiper;\n let perGroup = params.slidesPerGroup;\n\n if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {\n perGroup = Math.max(swiper.slidesPerViewDynamic('current', true), 1);\n }\n\n const increment = swiper.activeIndex < params.slidesPerGroupSkip ? 1 : perGroup;\n\n if (params.loop) {\n if (animating && params.loopPreventsSlide) return false;\n swiper.loopFix(); // eslint-disable-next-line\n\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n }\n\n if (params.rewind && swiper.isEnd) {\n return swiper.slideTo(0, speed, runCallbacks, internal);\n }\n\n return swiper.slideTo(swiper.activeIndex + increment, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slidePrev(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n const {\n params,\n animating,\n snapGrid,\n slidesGrid,\n rtlTranslate,\n enabled\n } = swiper;\n if (!enabled) return swiper;\n\n if (params.loop) {\n if (animating && params.loopPreventsSlide) return false;\n swiper.loopFix(); // eslint-disable-next-line\n\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n }\n\n const translate = rtlTranslate ? swiper.translate : -swiper.translate;\n\n function normalize(val) {\n if (val < 0) return -Math.floor(Math.abs(val));\n return Math.floor(val);\n }\n\n const normalizedTranslate = normalize(translate);\n const normalizedSnapGrid = snapGrid.map(val => normalize(val));\n let prevSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1];\n\n if (typeof prevSnap === 'undefined' && params.cssMode) {\n let prevSnapIndex;\n snapGrid.forEach((snap, snapIndex) => {\n if (normalizedTranslate >= snap) {\n // prevSnap = snap;\n prevSnapIndex = snapIndex;\n }\n });\n\n if (typeof prevSnapIndex !== 'undefined') {\n prevSnap = snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1 : prevSnapIndex];\n }\n }\n\n let prevIndex = 0;\n\n if (typeof prevSnap !== 'undefined') {\n prevIndex = slidesGrid.indexOf(prevSnap);\n if (prevIndex < 0) prevIndex = swiper.activeIndex - 1;\n\n if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {\n prevIndex = prevIndex - swiper.slidesPerViewDynamic('previous', true) + 1;\n prevIndex = Math.max(prevIndex, 0);\n }\n }\n\n if (params.rewind && swiper.isBeginning) {\n const lastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;\n return swiper.slideTo(lastIndex, speed, runCallbacks, internal);\n }\n\n return swiper.slideTo(prevIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideReset(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideToClosest(speed = this.params.speed, runCallbacks = true, internal, threshold = 0.5) {\n const swiper = this;\n let index = swiper.activeIndex;\n const skip = Math.min(swiper.params.slidesPerGroupSkip, index);\n const snapIndex = skip + Math.floor((index - skip) / swiper.params.slidesPerGroup);\n const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n\n if (translate >= swiper.snapGrid[snapIndex]) {\n // The current translate is on or after the current snap index, so the choice\n // is between the current index and the one after it.\n const currentSnap = swiper.snapGrid[snapIndex];\n const nextSnap = swiper.snapGrid[snapIndex + 1];\n\n if (translate - currentSnap > (nextSnap - currentSnap) * threshold) {\n index += swiper.params.slidesPerGroup;\n }\n } else {\n // The current translate is before the current snap index, so the choice\n // is between the current index and the one before it.\n const prevSnap = swiper.snapGrid[snapIndex - 1];\n const currentSnap = swiper.snapGrid[snapIndex];\n\n if (translate - prevSnap <= (currentSnap - prevSnap) * threshold) {\n index -= swiper.params.slidesPerGroup;\n }\n }\n\n index = Math.max(index, 0);\n index = Math.min(index, swiper.slidesGrid.length - 1);\n return swiper.slideTo(index, speed, runCallbacks, internal);\n}","import $ from '../../shared/dom.js';\nimport { nextTick } from '../../shared/utils.js';\nexport default function slideToClickedSlide() {\n const swiper = this;\n const {\n params,\n $wrapperEl\n } = swiper;\n const slidesPerView = params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : params.slidesPerView;\n let slideToIndex = swiper.clickedIndex;\n let realIndex;\n\n if (params.loop) {\n if (swiper.animating) return;\n realIndex = parseInt($(swiper.clickedSlide).attr('data-swiper-slide-index'), 10);\n\n if (params.centeredSlides) {\n if (slideToIndex < swiper.loopedSlides - slidesPerView / 2 || slideToIndex > swiper.slides.length - swiper.loopedSlides + slidesPerView / 2) {\n swiper.loopFix();\n slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index=\"${realIndex}\"]:not(.${params.slideDuplicateClass})`).eq(0).index();\n nextTick(() => {\n swiper.slideTo(slideToIndex);\n });\n } else {\n swiper.slideTo(slideToIndex);\n }\n } else if (slideToIndex > swiper.slides.length - slidesPerView) {\n swiper.loopFix();\n slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index=\"${realIndex}\"]:not(.${params.slideDuplicateClass})`).eq(0).index();\n nextTick(() => {\n swiper.slideTo(slideToIndex);\n });\n } else {\n swiper.slideTo(slideToIndex);\n }\n } else {\n swiper.slideTo(slideToIndex);\n }\n}","import loopCreate from './loopCreate.js';\nimport loopFix from './loopFix.js';\nimport loopDestroy from './loopDestroy.js';\nexport default {\n loopCreate,\n loopFix,\n loopDestroy\n};","import { getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function loopCreate() {\n const swiper = this;\n const document = getDocument();\n const {\n params,\n $wrapperEl\n } = swiper; // Remove duplicated slides\n\n const $selector = $wrapperEl.children().length > 0 ? $($wrapperEl.children()[0].parentNode) : $wrapperEl;\n $selector.children(`.${params.slideClass}.${params.slideDuplicateClass}`).remove();\n let slides = $selector.children(`.${params.slideClass}`);\n\n if (params.loopFillGroupWithBlank) {\n const blankSlidesNum = params.slidesPerGroup - slides.length % params.slidesPerGroup;\n\n if (blankSlidesNum !== params.slidesPerGroup) {\n for (let i = 0; i < blankSlidesNum; i += 1) {\n const blankNode = $(document.createElement('div')).addClass(`${params.slideClass} ${params.slideBlankClass}`);\n $selector.append(blankNode);\n }\n\n slides = $selector.children(`.${params.slideClass}`);\n }\n }\n\n if (params.slidesPerView === 'auto' && !params.loopedSlides) params.loopedSlides = slides.length;\n swiper.loopedSlides = Math.ceil(parseFloat(params.loopedSlides || params.slidesPerView, 10));\n swiper.loopedSlides += params.loopAdditionalSlides;\n\n if (swiper.loopedSlides > slides.length && swiper.params.loopedSlidesLimit) {\n swiper.loopedSlides = slides.length;\n }\n\n const prependSlides = [];\n const appendSlides = [];\n slides.each((el, index) => {\n const slide = $(el);\n slide.attr('data-swiper-slide-index', index);\n });\n\n for (let i = 0; i < swiper.loopedSlides; i += 1) {\n const index = i - Math.floor(i / slides.length) * slides.length;\n appendSlides.push(slides.eq(index)[0]);\n prependSlides.unshift(slides.eq(slides.length - index - 1)[0]);\n }\n\n for (let i = 0; i < appendSlides.length; i += 1) {\n $selector.append($(appendSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n\n for (let i = prependSlides.length - 1; i >= 0; i -= 1) {\n $selector.prepend($(prependSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n}","export default function loopFix() {\n const swiper = this;\n swiper.emit('beforeLoopFix');\n const {\n activeIndex,\n slides,\n loopedSlides,\n allowSlidePrev,\n allowSlideNext,\n snapGrid,\n rtlTranslate: rtl\n } = swiper;\n let newIndex;\n swiper.allowSlidePrev = true;\n swiper.allowSlideNext = true;\n const snapTranslate = -snapGrid[activeIndex];\n const diff = snapTranslate - swiper.getTranslate(); // Fix For Negative Oversliding\n\n if (activeIndex < loopedSlides) {\n newIndex = slides.length - loopedSlides * 3 + activeIndex;\n newIndex += loopedSlides;\n const slideChanged = swiper.slideTo(newIndex, 0, false, true);\n\n if (slideChanged && diff !== 0) {\n swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n }\n } else if (activeIndex >= slides.length - loopedSlides) {\n // Fix For Positive Oversliding\n newIndex = -slides.length + activeIndex + loopedSlides;\n newIndex += loopedSlides;\n const slideChanged = swiper.slideTo(newIndex, 0, false, true);\n\n if (slideChanged && diff !== 0) {\n swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n }\n }\n\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n swiper.emit('loopFix');\n}","export default function loopDestroy() {\n const swiper = this;\n const {\n $wrapperEl,\n params,\n slides\n } = swiper;\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass},.${params.slideClass}.${params.slideBlankClass}`).remove();\n slides.removeAttr('data-swiper-slide-index');\n}","import { getWindow, getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { now } from '../../shared/utils.js'; // Modified from https://stackoverflow.com/questions/54520554/custom-element-getrootnode-closest-function-crossing-multiple-parent-shadowd\n\nfunction closestElement(selector, base = this) {\n function __closestFrom(el) {\n if (!el || el === getDocument() || el === getWindow()) return null;\n if (el.assignedSlot) el = el.assignedSlot;\n const found = el.closest(selector);\n\n if (!found && !el.getRootNode) {\n return null;\n }\n\n return found || __closestFrom(el.getRootNode().host);\n }\n\n return __closestFrom(base);\n}\n\nexport default function onTouchStart(event) {\n const swiper = this;\n const document = getDocument();\n const window = getWindow();\n const data = swiper.touchEventsData;\n const {\n params,\n touches,\n enabled\n } = swiper;\n if (!enabled) return;\n\n if (swiper.animating && params.preventInteractionOnTransition) {\n return;\n }\n\n if (!swiper.animating && params.cssMode && params.loop) {\n swiper.loopFix();\n }\n\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n let $targetEl = $(e.target);\n\n if (params.touchEventsTarget === 'wrapper') {\n if (!$targetEl.closest(swiper.wrapperEl).length) return;\n }\n\n data.isTouchEvent = e.type === 'touchstart';\n if (!data.isTouchEvent && 'which' in e && e.which === 3) return;\n if (!data.isTouchEvent && 'button' in e && e.button > 0) return;\n if (data.isTouched && data.isMoved) return; // change target el for shadow root component\n\n const swipingClassHasValue = !!params.noSwipingClass && params.noSwipingClass !== ''; // eslint-disable-next-line\n\n const eventPath = event.composedPath ? event.composedPath() : event.path;\n\n if (swipingClassHasValue && e.target && e.target.shadowRoot && eventPath) {\n $targetEl = $(eventPath[0]);\n }\n\n const noSwipingSelector = params.noSwipingSelector ? params.noSwipingSelector : `.${params.noSwipingClass}`;\n const isTargetShadow = !!(e.target && e.target.shadowRoot); // use closestElement for shadow root element to get the actual closest for nested shadow root element\n\n if (params.noSwiping && (isTargetShadow ? closestElement(noSwipingSelector, $targetEl[0]) : $targetEl.closest(noSwipingSelector)[0])) {\n swiper.allowClick = true;\n return;\n }\n\n if (params.swipeHandler) {\n if (!$targetEl.closest(params.swipeHandler)[0]) return;\n }\n\n touches.currentX = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;\n touches.currentY = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;\n const startX = touches.currentX;\n const startY = touches.currentY; // Do NOT start if iOS edge swipe is detected. Otherwise iOS app cannot swipe-to-go-back anymore\n\n const edgeSwipeDetection = params.edgeSwipeDetection || params.iOSEdgeSwipeDetection;\n const edgeSwipeThreshold = params.edgeSwipeThreshold || params.iOSEdgeSwipeThreshold;\n\n if (edgeSwipeDetection && (startX <= edgeSwipeThreshold || startX >= window.innerWidth - edgeSwipeThreshold)) {\n if (edgeSwipeDetection === 'prevent') {\n event.preventDefault();\n } else {\n return;\n }\n }\n\n Object.assign(data, {\n isTouched: true,\n isMoved: false,\n allowTouchCallbacks: true,\n isScrolling: undefined,\n startMoving: undefined\n });\n touches.startX = startX;\n touches.startY = startY;\n data.touchStartTime = now();\n swiper.allowClick = true;\n swiper.updateSize();\n swiper.swipeDirection = undefined;\n if (params.threshold > 0) data.allowThresholdMove = false;\n\n if (e.type !== 'touchstart') {\n let preventDefault = true;\n\n if ($targetEl.is(data.focusableElements)) {\n preventDefault = false;\n\n if ($targetEl[0].nodeName === 'SELECT') {\n data.isTouched = false;\n }\n }\n\n if (document.activeElement && $(document.activeElement).is(data.focusableElements) && document.activeElement !== $targetEl[0]) {\n document.activeElement.blur();\n }\n\n const shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault;\n\n if ((params.touchStartForcePreventDefault || shouldPreventDefault) && !$targetEl[0].isContentEditable) {\n e.preventDefault();\n }\n }\n\n if (swiper.params.freeMode && swiper.params.freeMode.enabled && swiper.freeMode && swiper.animating && !params.cssMode) {\n swiper.freeMode.onTouchStart();\n }\n\n swiper.emit('touchStart', e);\n}","import { getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { now } from '../../shared/utils.js';\nexport default function onTouchMove(event) {\n const document = getDocument();\n const swiper = this;\n const data = swiper.touchEventsData;\n const {\n params,\n touches,\n rtlTranslate: rtl,\n enabled\n } = swiper;\n if (!enabled) return;\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n\n if (!data.isTouched) {\n if (data.startMoving && data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n\n return;\n }\n\n if (data.isTouchEvent && e.type !== 'touchmove') return;\n const targetTouch = e.type === 'touchmove' && e.targetTouches && (e.targetTouches[0] || e.changedTouches[0]);\n const pageX = e.type === 'touchmove' ? targetTouch.pageX : e.pageX;\n const pageY = e.type === 'touchmove' ? targetTouch.pageY : e.pageY;\n\n if (e.preventedByNestedSwiper) {\n touches.startX = pageX;\n touches.startY = pageY;\n return;\n }\n\n if (!swiper.allowTouchMove) {\n if (!$(e.target).is(data.focusableElements)) {\n swiper.allowClick = false;\n }\n\n if (data.isTouched) {\n Object.assign(touches, {\n startX: pageX,\n startY: pageY,\n currentX: pageX,\n currentY: pageY\n });\n data.touchStartTime = now();\n }\n\n return;\n }\n\n if (data.isTouchEvent && params.touchReleaseOnEdges && !params.loop) {\n if (swiper.isVertical()) {\n // Vertical\n if (pageY < touches.startY && swiper.translate <= swiper.maxTranslate() || pageY > touches.startY && swiper.translate >= swiper.minTranslate()) {\n data.isTouched = false;\n data.isMoved = false;\n return;\n }\n } else if (pageX < touches.startX && swiper.translate <= swiper.maxTranslate() || pageX > touches.startX && swiper.translate >= swiper.minTranslate()) {\n return;\n }\n }\n\n if (data.isTouchEvent && document.activeElement) {\n if (e.target === document.activeElement && $(e.target).is(data.focusableElements)) {\n data.isMoved = true;\n swiper.allowClick = false;\n return;\n }\n }\n\n if (data.allowTouchCallbacks) {\n swiper.emit('touchMove', e);\n }\n\n if (e.targetTouches && e.targetTouches.length > 1) return;\n touches.currentX = pageX;\n touches.currentY = pageY;\n const diffX = touches.currentX - touches.startX;\n const diffY = touches.currentY - touches.startY;\n if (swiper.params.threshold && Math.sqrt(diffX ** 2 + diffY ** 2) < swiper.params.threshold) return;\n\n if (typeof data.isScrolling === 'undefined') {\n let touchAngle;\n\n if (swiper.isHorizontal() && touches.currentY === touches.startY || swiper.isVertical() && touches.currentX === touches.startX) {\n data.isScrolling = false;\n } else {\n // eslint-disable-next-line\n if (diffX * diffX + diffY * diffY >= 25) {\n touchAngle = Math.atan2(Math.abs(diffY), Math.abs(diffX)) * 180 / Math.PI;\n data.isScrolling = swiper.isHorizontal() ? touchAngle > params.touchAngle : 90 - touchAngle > params.touchAngle;\n }\n }\n }\n\n if (data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n\n if (typeof data.startMoving === 'undefined') {\n if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) {\n data.startMoving = true;\n }\n }\n\n if (data.isScrolling) {\n data.isTouched = false;\n return;\n }\n\n if (!data.startMoving) {\n return;\n }\n\n swiper.allowClick = false;\n\n if (!params.cssMode && e.cancelable) {\n e.preventDefault();\n }\n\n if (params.touchMoveStopPropagation && !params.nested) {\n e.stopPropagation();\n }\n\n if (!data.isMoved) {\n if (params.loop && !params.cssMode) {\n swiper.loopFix();\n }\n\n data.startTranslate = swiper.getTranslate();\n swiper.setTransition(0);\n\n if (swiper.animating) {\n swiper.$wrapperEl.trigger('webkitTransitionEnd transitionend');\n }\n\n data.allowMomentumBounce = false; // Grab Cursor\n\n if (params.grabCursor && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(true);\n }\n\n swiper.emit('sliderFirstMove', e);\n }\n\n swiper.emit('sliderMove', e);\n data.isMoved = true;\n let diff = swiper.isHorizontal() ? diffX : diffY;\n touches.diff = diff;\n diff *= params.touchRatio;\n if (rtl) diff = -diff;\n swiper.swipeDirection = diff > 0 ? 'prev' : 'next';\n data.currentTranslate = diff + data.startTranslate;\n let disableParentSwiper = true;\n let resistanceRatio = params.resistanceRatio;\n\n if (params.touchReleaseOnEdges) {\n resistanceRatio = 0;\n }\n\n if (diff > 0 && data.currentTranslate > swiper.minTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) data.currentTranslate = swiper.minTranslate() - 1 + (-swiper.minTranslate() + data.startTranslate + diff) ** resistanceRatio;\n } else if (diff < 0 && data.currentTranslate < swiper.maxTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) data.currentTranslate = swiper.maxTranslate() + 1 - (swiper.maxTranslate() - data.startTranslate - diff) ** resistanceRatio;\n }\n\n if (disableParentSwiper) {\n e.preventedByNestedSwiper = true;\n } // Directions locks\n\n\n if (!swiper.allowSlideNext && swiper.swipeDirection === 'next' && data.currentTranslate < data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n\n if (!swiper.allowSlidePrev && swiper.swipeDirection === 'prev' && data.currentTranslate > data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n\n if (!swiper.allowSlidePrev && !swiper.allowSlideNext) {\n data.currentTranslate = data.startTranslate;\n } // Threshold\n\n\n if (params.threshold > 0) {\n if (Math.abs(diff) > params.threshold || data.allowThresholdMove) {\n if (!data.allowThresholdMove) {\n data.allowThresholdMove = true;\n touches.startX = touches.currentX;\n touches.startY = touches.currentY;\n data.currentTranslate = data.startTranslate;\n touches.diff = swiper.isHorizontal() ? touches.currentX - touches.startX : touches.currentY - touches.startY;\n return;\n }\n } else {\n data.currentTranslate = data.startTranslate;\n return;\n }\n }\n\n if (!params.followFinger || params.cssMode) return; // Update active index in free mode\n\n if (params.freeMode && params.freeMode.enabled && swiper.freeMode || params.watchSlidesProgress) {\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n if (swiper.params.freeMode && params.freeMode.enabled && swiper.freeMode) {\n swiper.freeMode.onTouchMove();\n } // Update progress\n\n\n swiper.updateProgress(data.currentTranslate); // Update translate\n\n swiper.setTranslate(data.currentTranslate);\n}","import { now, nextTick } from '../../shared/utils.js';\nexport default function onTouchEnd(event) {\n const swiper = this;\n const data = swiper.touchEventsData;\n const {\n params,\n touches,\n rtlTranslate: rtl,\n slidesGrid,\n enabled\n } = swiper;\n if (!enabled) return;\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n\n if (data.allowTouchCallbacks) {\n swiper.emit('touchEnd', e);\n }\n\n data.allowTouchCallbacks = false;\n\n if (!data.isTouched) {\n if (data.isMoved && params.grabCursor) {\n swiper.setGrabCursor(false);\n }\n\n data.isMoved = false;\n data.startMoving = false;\n return;\n } // Return Grab Cursor\n\n\n if (params.grabCursor && data.isMoved && data.isTouched && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(false);\n } // Time diff\n\n\n const touchEndTime = now();\n const timeDiff = touchEndTime - data.touchStartTime; // Tap, doubleTap, Click\n\n if (swiper.allowClick) {\n const pathTree = e.path || e.composedPath && e.composedPath();\n swiper.updateClickedSlide(pathTree && pathTree[0] || e.target);\n swiper.emit('tap click', e);\n\n if (timeDiff < 300 && touchEndTime - data.lastClickTime < 300) {\n swiper.emit('doubleTap doubleClick', e);\n }\n }\n\n data.lastClickTime = now();\n nextTick(() => {\n if (!swiper.destroyed) swiper.allowClick = true;\n });\n\n if (!data.isTouched || !data.isMoved || !swiper.swipeDirection || touches.diff === 0 || data.currentTranslate === data.startTranslate) {\n data.isTouched = false;\n data.isMoved = false;\n data.startMoving = false;\n return;\n }\n\n data.isTouched = false;\n data.isMoved = false;\n data.startMoving = false;\n let currentPos;\n\n if (params.followFinger) {\n currentPos = rtl ? swiper.translate : -swiper.translate;\n } else {\n currentPos = -data.currentTranslate;\n }\n\n if (params.cssMode) {\n return;\n }\n\n if (swiper.params.freeMode && params.freeMode.enabled) {\n swiper.freeMode.onTouchEnd({\n currentPos\n });\n return;\n } // Find current slide\n\n\n let stopIndex = 0;\n let groupSize = swiper.slidesSizesGrid[0];\n\n for (let i = 0; i < slidesGrid.length; i += i < params.slidesPerGroupSkip ? 1 : params.slidesPerGroup) {\n const increment = i < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;\n\n if (typeof slidesGrid[i + increment] !== 'undefined') {\n if (currentPos >= slidesGrid[i] && currentPos < slidesGrid[i + increment]) {\n stopIndex = i;\n groupSize = slidesGrid[i + increment] - slidesGrid[i];\n }\n } else if (currentPos >= slidesGrid[i]) {\n stopIndex = i;\n groupSize = slidesGrid[slidesGrid.length - 1] - slidesGrid[slidesGrid.length - 2];\n }\n }\n\n let rewindFirstIndex = null;\n let rewindLastIndex = null;\n\n if (params.rewind) {\n if (swiper.isBeginning) {\n rewindLastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;\n } else if (swiper.isEnd) {\n rewindFirstIndex = 0;\n }\n } // Find current slide size\n\n\n const ratio = (currentPos - slidesGrid[stopIndex]) / groupSize;\n const increment = stopIndex < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;\n\n if (timeDiff > params.longSwipesMs) {\n // Long touches\n if (!params.longSwipes) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n\n if (swiper.swipeDirection === 'next') {\n if (ratio >= params.longSwipesRatio) swiper.slideTo(params.rewind && swiper.isEnd ? rewindFirstIndex : stopIndex + increment);else swiper.slideTo(stopIndex);\n }\n\n if (swiper.swipeDirection === 'prev') {\n if (ratio > 1 - params.longSwipesRatio) {\n swiper.slideTo(stopIndex + increment);\n } else if (rewindLastIndex !== null && ratio < 0 && Math.abs(ratio) > params.longSwipesRatio) {\n swiper.slideTo(rewindLastIndex);\n } else {\n swiper.slideTo(stopIndex);\n }\n }\n } else {\n // Short swipes\n if (!params.shortSwipes) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n\n const isNavButtonTarget = swiper.navigation && (e.target === swiper.navigation.nextEl || e.target === swiper.navigation.prevEl);\n\n if (!isNavButtonTarget) {\n if (swiper.swipeDirection === 'next') {\n swiper.slideTo(rewindFirstIndex !== null ? rewindFirstIndex : stopIndex + increment);\n }\n\n if (swiper.swipeDirection === 'prev') {\n swiper.slideTo(rewindLastIndex !== null ? rewindLastIndex : stopIndex);\n }\n } else if (e.target === swiper.navigation.nextEl) {\n swiper.slideTo(stopIndex + increment);\n } else {\n swiper.slideTo(stopIndex);\n }\n }\n}","export default function onResize() {\n const swiper = this;\n const {\n params,\n el\n } = swiper;\n if (el && el.offsetWidth === 0) return; // Breakpoints\n\n if (params.breakpoints) {\n swiper.setBreakpoint();\n } // Save locks\n\n\n const {\n allowSlideNext,\n allowSlidePrev,\n snapGrid\n } = swiper; // Disable locks on resize\n\n swiper.allowSlideNext = true;\n swiper.allowSlidePrev = true;\n swiper.updateSize();\n swiper.updateSlides();\n swiper.updateSlidesClasses();\n\n if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !swiper.isBeginning && !swiper.params.centeredSlides) {\n swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n } else {\n swiper.slideTo(swiper.activeIndex, 0, false, true);\n }\n\n if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {\n swiper.autoplay.run();\n } // Return locks after resize\n\n\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n\n if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) {\n swiper.checkOverflow();\n }\n}","export default function onClick(e) {\n const swiper = this;\n if (!swiper.enabled) return;\n\n if (!swiper.allowClick) {\n if (swiper.params.preventClicks) e.preventDefault();\n\n if (swiper.params.preventClicksPropagation && swiper.animating) {\n e.stopPropagation();\n e.stopImmediatePropagation();\n }\n }\n}","export default function onScroll() {\n const swiper = this;\n const {\n wrapperEl,\n rtlTranslate,\n enabled\n } = swiper;\n if (!enabled) return;\n swiper.previousTranslate = swiper.translate;\n\n if (swiper.isHorizontal()) {\n swiper.translate = -wrapperEl.scrollLeft;\n } else {\n swiper.translate = -wrapperEl.scrollTop;\n } // eslint-disable-next-line\n\n\n if (swiper.translate === 0) swiper.translate = 0;\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n let newProgress;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n\n if (translatesDiff === 0) {\n newProgress = 0;\n } else {\n newProgress = (swiper.translate - swiper.minTranslate()) / translatesDiff;\n }\n\n if (newProgress !== swiper.progress) {\n swiper.updateProgress(rtlTranslate ? -swiper.translate : swiper.translate);\n }\n\n swiper.emit('setTranslate', swiper.translate, false);\n}","import { getDocument } from 'ssr-window';\nimport onTouchStart from './onTouchStart.js';\nimport onTouchMove from './onTouchMove.js';\nimport onTouchEnd from './onTouchEnd.js';\nimport onResize from './onResize.js';\nimport onClick from './onClick.js';\nimport onScroll from './onScroll.js';\nlet dummyEventAttached = false;\n\nfunction dummyEventListener() {}\n\nconst events = (swiper, method) => {\n const document = getDocument();\n const {\n params,\n touchEvents,\n el,\n wrapperEl,\n device,\n support\n } = swiper;\n const capture = !!params.nested;\n const domMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';\n const swiperMethod = method; // Touch Events\n\n if (!support.touch) {\n el[domMethod](touchEvents.start, swiper.onTouchStart, false);\n document[domMethod](touchEvents.move, swiper.onTouchMove, capture);\n document[domMethod](touchEvents.end, swiper.onTouchEnd, false);\n } else {\n const passiveListener = touchEvents.start === 'touchstart' && support.passiveListener && params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n el[domMethod](touchEvents.start, swiper.onTouchStart, passiveListener);\n el[domMethod](touchEvents.move, swiper.onTouchMove, support.passiveListener ? {\n passive: false,\n capture\n } : capture);\n el[domMethod](touchEvents.end, swiper.onTouchEnd, passiveListener);\n\n if (touchEvents.cancel) {\n el[domMethod](touchEvents.cancel, swiper.onTouchEnd, passiveListener);\n }\n } // Prevent Links Clicks\n\n\n if (params.preventClicks || params.preventClicksPropagation) {\n el[domMethod]('click', swiper.onClick, true);\n }\n\n if (params.cssMode) {\n wrapperEl[domMethod]('scroll', swiper.onScroll);\n } // Resize handler\n\n\n if (params.updateOnWindowResize) {\n swiper[swiperMethod](device.ios || device.android ? 'resize orientationchange observerUpdate' : 'resize observerUpdate', onResize, true);\n } else {\n swiper[swiperMethod]('observerUpdate', onResize, true);\n }\n};\n\nfunction attachEvents() {\n const swiper = this;\n const document = getDocument();\n const {\n params,\n support\n } = swiper;\n swiper.onTouchStart = onTouchStart.bind(swiper);\n swiper.onTouchMove = onTouchMove.bind(swiper);\n swiper.onTouchEnd = onTouchEnd.bind(swiper);\n\n if (params.cssMode) {\n swiper.onScroll = onScroll.bind(swiper);\n }\n\n swiper.onClick = onClick.bind(swiper);\n\n if (support.touch && !dummyEventAttached) {\n document.addEventListener('touchstart', dummyEventListener);\n dummyEventAttached = true;\n }\n\n events(swiper, 'on');\n}\n\nfunction detachEvents() {\n const swiper = this;\n events(swiper, 'off');\n}\n\nexport default {\n attachEvents,\n detachEvents\n};","import { extend } from '../../shared/utils.js';\n\nconst isGridEnabled = (swiper, params) => {\n return swiper.grid && params.grid && params.grid.rows > 1;\n};\n\nexport default function setBreakpoint() {\n const swiper = this;\n const {\n activeIndex,\n initialized,\n loopedSlides = 0,\n params,\n $el\n } = swiper;\n const breakpoints = params.breakpoints;\n if (!breakpoints || breakpoints && Object.keys(breakpoints).length === 0) return; // Get breakpoint for window width and update parameters\n\n const breakpoint = swiper.getBreakpoint(breakpoints, swiper.params.breakpointsBase, swiper.el);\n if (!breakpoint || swiper.currentBreakpoint === breakpoint) return;\n const breakpointOnlyParams = breakpoint in breakpoints ? breakpoints[breakpoint] : undefined;\n const breakpointParams = breakpointOnlyParams || swiper.originalParams;\n const wasMultiRow = isGridEnabled(swiper, params);\n const isMultiRow = isGridEnabled(swiper, breakpointParams);\n const wasEnabled = params.enabled;\n\n if (wasMultiRow && !isMultiRow) {\n $el.removeClass(`${params.containerModifierClass}grid ${params.containerModifierClass}grid-column`);\n swiper.emitContainerClasses();\n } else if (!wasMultiRow && isMultiRow) {\n $el.addClass(`${params.containerModifierClass}grid`);\n\n if (breakpointParams.grid.fill && breakpointParams.grid.fill === 'column' || !breakpointParams.grid.fill && params.grid.fill === 'column') {\n $el.addClass(`${params.containerModifierClass}grid-column`);\n }\n\n swiper.emitContainerClasses();\n } // Toggle navigation, pagination, scrollbar\n\n\n ['navigation', 'pagination', 'scrollbar'].forEach(prop => {\n const wasModuleEnabled = params[prop] && params[prop].enabled;\n const isModuleEnabled = breakpointParams[prop] && breakpointParams[prop].enabled;\n\n if (wasModuleEnabled && !isModuleEnabled) {\n swiper[prop].disable();\n }\n\n if (!wasModuleEnabled && isModuleEnabled) {\n swiper[prop].enable();\n }\n });\n const directionChanged = breakpointParams.direction && breakpointParams.direction !== params.direction;\n const needsReLoop = params.loop && (breakpointParams.slidesPerView !== params.slidesPerView || directionChanged);\n\n if (directionChanged && initialized) {\n swiper.changeDirection();\n }\n\n extend(swiper.params, breakpointParams);\n const isEnabled = swiper.params.enabled;\n Object.assign(swiper, {\n allowTouchMove: swiper.params.allowTouchMove,\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev\n });\n\n if (wasEnabled && !isEnabled) {\n swiper.disable();\n } else if (!wasEnabled && isEnabled) {\n swiper.enable();\n }\n\n swiper.currentBreakpoint = breakpoint;\n swiper.emit('_beforeBreakpoint', breakpointParams);\n\n if (needsReLoop && initialized) {\n swiper.loopDestroy();\n swiper.loopCreate();\n swiper.updateSlides();\n swiper.slideTo(activeIndex - loopedSlides + swiper.loopedSlides, 0, false);\n }\n\n swiper.emit('breakpoint', breakpointParams);\n}","import setBreakpoint from './setBreakpoint.js';\nimport getBreakpoint from './getBreakpoint.js';\nexport default {\n setBreakpoint,\n getBreakpoint\n};","import { getWindow } from 'ssr-window';\nexport default function getBreakpoint(breakpoints, base = 'window', containerEl) {\n if (!breakpoints || base === 'container' && !containerEl) return undefined;\n let breakpoint = false;\n const window = getWindow();\n const currentHeight = base === 'window' ? window.innerHeight : containerEl.clientHeight;\n const points = Object.keys(breakpoints).map(point => {\n if (typeof point === 'string' && point.indexOf('@') === 0) {\n const minRatio = parseFloat(point.substr(1));\n const value = currentHeight * minRatio;\n return {\n value,\n point\n };\n }\n\n return {\n value: point,\n point\n };\n });\n points.sort((a, b) => parseInt(a.value, 10) - parseInt(b.value, 10));\n\n for (let i = 0; i < points.length; i += 1) {\n const {\n point,\n value\n } = points[i];\n\n if (base === 'window') {\n if (window.matchMedia(`(min-width: ${value}px)`).matches) {\n breakpoint = point;\n }\n } else if (value <= containerEl.clientWidth) {\n breakpoint = point;\n }\n }\n\n return breakpoint || 'max';\n}","import addClasses from './addClasses.js';\nimport removeClasses from './removeClasses.js';\nexport default {\n addClasses,\n removeClasses\n};","function prepareClasses(entries, prefix) {\n const resultClasses = [];\n entries.forEach(item => {\n if (typeof item === 'object') {\n Object.keys(item).forEach(classNames => {\n if (item[classNames]) {\n resultClasses.push(prefix + classNames);\n }\n });\n } else if (typeof item === 'string') {\n resultClasses.push(prefix + item);\n }\n });\n return resultClasses;\n}\n\nexport default function addClasses() {\n const swiper = this;\n const {\n classNames,\n params,\n rtl,\n $el,\n device,\n support\n } = swiper; // prettier-ignore\n\n const suffixes = prepareClasses(['initialized', params.direction, {\n 'pointer-events': !support.touch\n }, {\n 'free-mode': swiper.params.freeMode && params.freeMode.enabled\n }, {\n 'autoheight': params.autoHeight\n }, {\n 'rtl': rtl\n }, {\n 'grid': params.grid && params.grid.rows > 1\n }, {\n 'grid-column': params.grid && params.grid.rows > 1 && params.grid.fill === 'column'\n }, {\n 'android': device.android\n }, {\n 'ios': device.ios\n }, {\n 'css-mode': params.cssMode\n }, {\n 'centered': params.cssMode && params.centeredSlides\n }, {\n 'watch-progress': params.watchSlidesProgress\n }], params.containerModifierClass);\n classNames.push(...suffixes);\n $el.addClass([...classNames].join(' '));\n swiper.emitContainerClasses();\n}","export default function removeClasses() {\n const swiper = this;\n const {\n $el,\n classNames\n } = swiper;\n $el.removeClass(classNames.join(' '));\n swiper.emitContainerClasses();\n}","function checkOverflow() {\n const swiper = this;\n const {\n isLocked: wasLocked,\n params\n } = swiper;\n const {\n slidesOffsetBefore\n } = params;\n\n if (slidesOffsetBefore) {\n const lastSlideIndex = swiper.slides.length - 1;\n const lastSlideRightEdge = swiper.slidesGrid[lastSlideIndex] + swiper.slidesSizesGrid[lastSlideIndex] + slidesOffsetBefore * 2;\n swiper.isLocked = swiper.size > lastSlideRightEdge;\n } else {\n swiper.isLocked = swiper.snapGrid.length === 1;\n }\n\n if (params.allowSlideNext === true) {\n swiper.allowSlideNext = !swiper.isLocked;\n }\n\n if (params.allowSlidePrev === true) {\n swiper.allowSlidePrev = !swiper.isLocked;\n }\n\n if (wasLocked && wasLocked !== swiper.isLocked) {\n swiper.isEnd = false;\n }\n\n if (wasLocked !== swiper.isLocked) {\n swiper.emit(swiper.isLocked ? 'lock' : 'unlock');\n }\n}\n\nexport default {\n checkOverflow\n};","export default {\n init: true,\n direction: 'horizontal',\n touchEventsTarget: 'wrapper',\n initialSlide: 0,\n speed: 300,\n cssMode: false,\n updateOnWindowResize: true,\n resizeObserver: true,\n nested: false,\n createElements: false,\n enabled: true,\n focusableElements: 'input, select, option, textarea, button, video, label',\n // Overrides\n width: null,\n height: null,\n //\n preventInteractionOnTransition: false,\n // ssr\n userAgent: null,\n url: null,\n // To support iOS's swipe-to-go-back gesture (when being used in-app).\n edgeSwipeDetection: false,\n edgeSwipeThreshold: 20,\n // Autoheight\n autoHeight: false,\n // Set wrapper width\n setWrapperSize: false,\n // Virtual Translate\n virtualTranslate: false,\n // Effects\n effect: 'slide',\n // 'slide' or 'fade' or 'cube' or 'coverflow' or 'flip'\n // Breakpoints\n breakpoints: undefined,\n breakpointsBase: 'window',\n // Slides grid\n spaceBetween: 0,\n slidesPerView: 1,\n slidesPerGroup: 1,\n slidesPerGroupSkip: 0,\n slidesPerGroupAuto: false,\n centeredSlides: false,\n centeredSlidesBounds: false,\n slidesOffsetBefore: 0,\n // in px\n slidesOffsetAfter: 0,\n // in px\n normalizeSlideIndex: true,\n centerInsufficientSlides: false,\n // Disable swiper and hide navigation when container not overflow\n watchOverflow: true,\n // Round length\n roundLengths: false,\n // Touches\n touchRatio: 1,\n touchAngle: 45,\n simulateTouch: true,\n shortSwipes: true,\n longSwipes: true,\n longSwipesRatio: 0.5,\n longSwipesMs: 300,\n followFinger: true,\n allowTouchMove: true,\n threshold: 0,\n touchMoveStopPropagation: false,\n touchStartPreventDefault: true,\n touchStartForcePreventDefault: false,\n touchReleaseOnEdges: false,\n // Unique Navigation Elements\n uniqueNavElements: true,\n // Resistance\n resistance: true,\n resistanceRatio: 0.85,\n // Progress\n watchSlidesProgress: false,\n // Cursor\n grabCursor: false,\n // Clicks\n preventClicks: true,\n preventClicksPropagation: true,\n slideToClickedSlide: false,\n // Images\n preloadImages: true,\n updateOnImagesReady: true,\n // loop\n loop: false,\n loopAdditionalSlides: 0,\n loopedSlides: null,\n loopedSlidesLimit: true,\n loopFillGroupWithBlank: false,\n loopPreventsSlide: true,\n // rewind\n rewind: false,\n // Swiping/no swiping\n allowSlidePrev: true,\n allowSlideNext: true,\n swipeHandler: null,\n // '.swipe-handler',\n noSwiping: true,\n noSwipingClass: 'swiper-no-swiping',\n noSwipingSelector: null,\n // Passive Listeners\n passiveListeners: true,\n maxBackfaceHiddenSlides: 10,\n // NS\n containerModifierClass: 'swiper-',\n // NEW\n slideClass: 'swiper-slide',\n slideBlankClass: 'swiper-slide-invisible-blank',\n slideActiveClass: 'swiper-slide-active',\n slideDuplicateActiveClass: 'swiper-slide-duplicate-active',\n slideVisibleClass: 'swiper-slide-visible',\n slideDuplicateClass: 'swiper-slide-duplicate',\n slideNextClass: 'swiper-slide-next',\n slideDuplicateNextClass: 'swiper-slide-duplicate-next',\n slidePrevClass: 'swiper-slide-prev',\n slideDuplicatePrevClass: 'swiper-slide-duplicate-prev',\n wrapperClass: 'swiper-wrapper',\n // Callbacks\n runCallbacksOnInit: true,\n // Internals\n _emitClasses: false\n};","import { extend } from '../shared/utils.js';\nexport default function moduleExtendParams(params, allModulesParams) {\n return function extendParams(obj = {}) {\n const moduleParamName = Object.keys(obj)[0];\n const moduleParams = obj[moduleParamName];\n\n if (typeof moduleParams !== 'object' || moduleParams === null) {\n extend(allModulesParams, obj);\n return;\n }\n\n if (['navigation', 'pagination', 'scrollbar'].indexOf(moduleParamName) >= 0 && params[moduleParamName] === true) {\n params[moduleParamName] = {\n auto: true\n };\n }\n\n if (!(moduleParamName in params && 'enabled' in moduleParams)) {\n extend(allModulesParams, obj);\n return;\n }\n\n if (params[moduleParamName] === true) {\n params[moduleParamName] = {\n enabled: true\n };\n }\n\n if (typeof params[moduleParamName] === 'object' && !('enabled' in params[moduleParamName])) {\n params[moduleParamName].enabled = true;\n }\n\n if (!params[moduleParamName]) params[moduleParamName] = {\n enabled: false\n };\n extend(allModulesParams, obj);\n };\n}","/* eslint no-param-reassign: \"off\" */\nimport { getDocument } from 'ssr-window';\nimport $ from '../shared/dom.js';\nimport { extend, now, deleteProps } from '../shared/utils.js';\nimport { getSupport } from '../shared/get-support.js';\nimport { getDevice } from '../shared/get-device.js';\nimport { getBrowser } from '../shared/get-browser.js';\nimport Resize from './modules/resize/resize.js';\nimport Observer from './modules/observer/observer.js';\nimport eventsEmitter from './events-emitter.js';\nimport update from './update/index.js';\nimport translate from './translate/index.js';\nimport transition from './transition/index.js';\nimport slide from './slide/index.js';\nimport loop from './loop/index.js';\nimport grabCursor from './grab-cursor/index.js';\nimport events from './events/index.js';\nimport breakpoints from './breakpoints/index.js';\nimport classes from './classes/index.js';\nimport images from './images/index.js';\nimport checkOverflow from './check-overflow/index.js';\nimport defaults from './defaults.js';\nimport moduleExtendParams from './moduleExtendParams.js';\nconst prototypes = {\n eventsEmitter,\n update,\n translate,\n transition,\n slide,\n loop,\n grabCursor,\n events,\n breakpoints,\n checkOverflow,\n classes,\n images\n};\nconst extendedDefaults = {};\n\nclass Swiper {\n constructor(...args) {\n let el;\n let params;\n\n if (args.length === 1 && args[0].constructor && Object.prototype.toString.call(args[0]).slice(8, -1) === 'Object') {\n params = args[0];\n } else {\n [el, params] = args;\n }\n\n if (!params) params = {};\n params = extend({}, params);\n if (el && !params.el) params.el = el;\n\n if (params.el && $(params.el).length > 1) {\n const swipers = [];\n $(params.el).each(containerEl => {\n const newParams = extend({}, params, {\n el: containerEl\n });\n swipers.push(new Swiper(newParams));\n }); // eslint-disable-next-line no-constructor-return\n\n return swipers;\n } // Swiper Instance\n\n\n const swiper = this;\n swiper.__swiper__ = true;\n swiper.support = getSupport();\n swiper.device = getDevice({\n userAgent: params.userAgent\n });\n swiper.browser = getBrowser();\n swiper.eventsListeners = {};\n swiper.eventsAnyListeners = [];\n swiper.modules = [...swiper.__modules__];\n\n if (params.modules && Array.isArray(params.modules)) {\n swiper.modules.push(...params.modules);\n }\n\n const allModulesParams = {};\n swiper.modules.forEach(mod => {\n mod({\n swiper,\n extendParams: moduleExtendParams(params, allModulesParams),\n on: swiper.on.bind(swiper),\n once: swiper.once.bind(swiper),\n off: swiper.off.bind(swiper),\n emit: swiper.emit.bind(swiper)\n });\n }); // Extend defaults with modules params\n\n const swiperParams = extend({}, defaults, allModulesParams); // Extend defaults with passed params\n\n swiper.params = extend({}, swiperParams, extendedDefaults, params);\n swiper.originalParams = extend({}, swiper.params);\n swiper.passedParams = extend({}, params); // add event listeners\n\n if (swiper.params && swiper.params.on) {\n Object.keys(swiper.params.on).forEach(eventName => {\n swiper.on(eventName, swiper.params.on[eventName]);\n });\n }\n\n if (swiper.params && swiper.params.onAny) {\n swiper.onAny(swiper.params.onAny);\n } // Save Dom lib\n\n\n swiper.$ = $; // Extend Swiper\n\n Object.assign(swiper, {\n enabled: swiper.params.enabled,\n el,\n // Classes\n classNames: [],\n // Slides\n slides: $(),\n slidesGrid: [],\n snapGrid: [],\n slidesSizesGrid: [],\n\n // isDirection\n isHorizontal() {\n return swiper.params.direction === 'horizontal';\n },\n\n isVertical() {\n return swiper.params.direction === 'vertical';\n },\n\n // Indexes\n activeIndex: 0,\n realIndex: 0,\n //\n isBeginning: true,\n isEnd: false,\n // Props\n translate: 0,\n previousTranslate: 0,\n progress: 0,\n velocity: 0,\n animating: false,\n // Locks\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev,\n // Touch Events\n touchEvents: function touchEvents() {\n const touch = ['touchstart', 'touchmove', 'touchend', 'touchcancel'];\n const desktop = ['pointerdown', 'pointermove', 'pointerup'];\n swiper.touchEventsTouch = {\n start: touch[0],\n move: touch[1],\n end: touch[2],\n cancel: touch[3]\n };\n swiper.touchEventsDesktop = {\n start: desktop[0],\n move: desktop[1],\n end: desktop[2]\n };\n return swiper.support.touch || !swiper.params.simulateTouch ? swiper.touchEventsTouch : swiper.touchEventsDesktop;\n }(),\n touchEventsData: {\n isTouched: undefined,\n isMoved: undefined,\n allowTouchCallbacks: undefined,\n touchStartTime: undefined,\n isScrolling: undefined,\n currentTranslate: undefined,\n startTranslate: undefined,\n allowThresholdMove: undefined,\n // Form elements to match\n focusableElements: swiper.params.focusableElements,\n // Last click time\n lastClickTime: now(),\n clickTimeout: undefined,\n // Velocities\n velocities: [],\n allowMomentumBounce: undefined,\n isTouchEvent: undefined,\n startMoving: undefined\n },\n // Clicks\n allowClick: true,\n // Touches\n allowTouchMove: swiper.params.allowTouchMove,\n touches: {\n startX: 0,\n startY: 0,\n currentX: 0,\n currentY: 0,\n diff: 0\n },\n // Images\n imagesToLoad: [],\n imagesLoaded: 0\n });\n swiper.emit('_swiper'); // Init\n\n if (swiper.params.init) {\n swiper.init();\n } // Return app instance\n // eslint-disable-next-line no-constructor-return\n\n\n return swiper;\n }\n\n enable() {\n const swiper = this;\n if (swiper.enabled) return;\n swiper.enabled = true;\n\n if (swiper.params.grabCursor) {\n swiper.setGrabCursor();\n }\n\n swiper.emit('enable');\n }\n\n disable() {\n const swiper = this;\n if (!swiper.enabled) return;\n swiper.enabled = false;\n\n if (swiper.params.grabCursor) {\n swiper.unsetGrabCursor();\n }\n\n swiper.emit('disable');\n }\n\n setProgress(progress, speed) {\n const swiper = this;\n progress = Math.min(Math.max(progress, 0), 1);\n const min = swiper.minTranslate();\n const max = swiper.maxTranslate();\n const current = (max - min) * progress + min;\n swiper.translateTo(current, typeof speed === 'undefined' ? 0 : speed);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n emitContainerClasses() {\n const swiper = this;\n if (!swiper.params._emitClasses || !swiper.el) return;\n const cls = swiper.el.className.split(' ').filter(className => {\n return className.indexOf('swiper') === 0 || className.indexOf(swiper.params.containerModifierClass) === 0;\n });\n swiper.emit('_containerClasses', cls.join(' '));\n }\n\n getSlideClasses(slideEl) {\n const swiper = this;\n if (swiper.destroyed) return '';\n return slideEl.className.split(' ').filter(className => {\n return className.indexOf('swiper-slide') === 0 || className.indexOf(swiper.params.slideClass) === 0;\n }).join(' ');\n }\n\n emitSlidesClasses() {\n const swiper = this;\n if (!swiper.params._emitClasses || !swiper.el) return;\n const updates = [];\n swiper.slides.each(slideEl => {\n const classNames = swiper.getSlideClasses(slideEl);\n updates.push({\n slideEl,\n classNames\n });\n swiper.emit('_slideClass', slideEl, classNames);\n });\n swiper.emit('_slideClasses', updates);\n }\n\n slidesPerViewDynamic(view = 'current', exact = false) {\n const swiper = this;\n const {\n params,\n slides,\n slidesGrid,\n slidesSizesGrid,\n size: swiperSize,\n activeIndex\n } = swiper;\n let spv = 1;\n\n if (params.centeredSlides) {\n let slideSize = slides[activeIndex].swiperSlideSize;\n let breakLoop;\n\n for (let i = activeIndex + 1; i < slides.length; i += 1) {\n if (slides[i] && !breakLoop) {\n slideSize += slides[i].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) breakLoop = true;\n }\n }\n\n for (let i = activeIndex - 1; i >= 0; i -= 1) {\n if (slides[i] && !breakLoop) {\n slideSize += slides[i].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) breakLoop = true;\n }\n }\n } else {\n // eslint-disable-next-line\n if (view === 'current') {\n for (let i = activeIndex + 1; i < slides.length; i += 1) {\n const slideInView = exact ? slidesGrid[i] + slidesSizesGrid[i] - slidesGrid[activeIndex] < swiperSize : slidesGrid[i] - slidesGrid[activeIndex] < swiperSize;\n\n if (slideInView) {\n spv += 1;\n }\n }\n } else {\n // previous\n for (let i = activeIndex - 1; i >= 0; i -= 1) {\n const slideInView = slidesGrid[activeIndex] - slidesGrid[i] < swiperSize;\n\n if (slideInView) {\n spv += 1;\n }\n }\n }\n }\n\n return spv;\n }\n\n update() {\n const swiper = this;\n if (!swiper || swiper.destroyed) return;\n const {\n snapGrid,\n params\n } = swiper; // Breakpoints\n\n if (params.breakpoints) {\n swiper.setBreakpoint();\n }\n\n swiper.updateSize();\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n function setTranslate() {\n const translateValue = swiper.rtlTranslate ? swiper.translate * -1 : swiper.translate;\n const newTranslate = Math.min(Math.max(translateValue, swiper.maxTranslate()), swiper.minTranslate());\n swiper.setTranslate(newTranslate);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n let translated;\n\n if (swiper.params.freeMode && swiper.params.freeMode.enabled) {\n setTranslate();\n\n if (swiper.params.autoHeight) {\n swiper.updateAutoHeight();\n }\n } else {\n if ((swiper.params.slidesPerView === 'auto' || swiper.params.slidesPerView > 1) && swiper.isEnd && !swiper.params.centeredSlides) {\n translated = swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n } else {\n translated = swiper.slideTo(swiper.activeIndex, 0, false, true);\n }\n\n if (!translated) {\n setTranslate();\n }\n }\n\n if (params.watchOverflow && snapGrid !== swiper.snapGrid) {\n swiper.checkOverflow();\n }\n\n swiper.emit('update');\n }\n\n changeDirection(newDirection, needUpdate = true) {\n const swiper = this;\n const currentDirection = swiper.params.direction;\n\n if (!newDirection) {\n // eslint-disable-next-line\n newDirection = currentDirection === 'horizontal' ? 'vertical' : 'horizontal';\n }\n\n if (newDirection === currentDirection || newDirection !== 'horizontal' && newDirection !== 'vertical') {\n return swiper;\n }\n\n swiper.$el.removeClass(`${swiper.params.containerModifierClass}${currentDirection}`).addClass(`${swiper.params.containerModifierClass}${newDirection}`);\n swiper.emitContainerClasses();\n swiper.params.direction = newDirection;\n swiper.slides.each(slideEl => {\n if (newDirection === 'vertical') {\n slideEl.style.width = '';\n } else {\n slideEl.style.height = '';\n }\n });\n swiper.emit('changeDirection');\n if (needUpdate) swiper.update();\n return swiper;\n }\n\n changeLanguageDirection(direction) {\n const swiper = this;\n if (swiper.rtl && direction === 'rtl' || !swiper.rtl && direction === 'ltr') return;\n swiper.rtl = direction === 'rtl';\n swiper.rtlTranslate = swiper.params.direction === 'horizontal' && swiper.rtl;\n\n if (swiper.rtl) {\n swiper.$el.addClass(`${swiper.params.containerModifierClass}rtl`);\n swiper.el.dir = 'rtl';\n } else {\n swiper.$el.removeClass(`${swiper.params.containerModifierClass}rtl`);\n swiper.el.dir = 'ltr';\n }\n\n swiper.update();\n }\n\n mount(el) {\n const swiper = this;\n if (swiper.mounted) return true; // Find el\n\n const $el = $(el || swiper.params.el);\n el = $el[0];\n\n if (!el) {\n return false;\n }\n\n el.swiper = swiper;\n\n const getWrapperSelector = () => {\n return `.${(swiper.params.wrapperClass || '').trim().split(' ').join('.')}`;\n };\n\n const getWrapper = () => {\n if (el && el.shadowRoot && el.shadowRoot.querySelector) {\n const res = $(el.shadowRoot.querySelector(getWrapperSelector())); // Children needs to return slot items\n\n res.children = options => $el.children(options);\n\n return res;\n }\n\n if (!$el.children) {\n return $($el).children(getWrapperSelector());\n }\n\n return $el.children(getWrapperSelector());\n }; // Find Wrapper\n\n\n let $wrapperEl = getWrapper();\n\n if ($wrapperEl.length === 0 && swiper.params.createElements) {\n const document = getDocument();\n const wrapper = document.createElement('div');\n $wrapperEl = $(wrapper);\n wrapper.className = swiper.params.wrapperClass;\n $el.append(wrapper);\n $el.children(`.${swiper.params.slideClass}`).each(slideEl => {\n $wrapperEl.append(slideEl);\n });\n }\n\n Object.assign(swiper, {\n $el,\n el,\n $wrapperEl,\n wrapperEl: $wrapperEl[0],\n mounted: true,\n // RTL\n rtl: el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl',\n rtlTranslate: swiper.params.direction === 'horizontal' && (el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl'),\n wrongRTL: $wrapperEl.css('display') === '-webkit-box'\n });\n return true;\n }\n\n init(el) {\n const swiper = this;\n if (swiper.initialized) return swiper;\n const mounted = swiper.mount(el);\n if (mounted === false) return swiper;\n swiper.emit('beforeInit'); // Set breakpoint\n\n if (swiper.params.breakpoints) {\n swiper.setBreakpoint();\n } // Add Classes\n\n\n swiper.addClasses(); // Create loop\n\n if (swiper.params.loop) {\n swiper.loopCreate();\n } // Update size\n\n\n swiper.updateSize(); // Update slides\n\n swiper.updateSlides();\n\n if (swiper.params.watchOverflow) {\n swiper.checkOverflow();\n } // Set Grab Cursor\n\n\n if (swiper.params.grabCursor && swiper.enabled) {\n swiper.setGrabCursor();\n }\n\n if (swiper.params.preloadImages) {\n swiper.preloadImages();\n } // Slide To Initial Slide\n\n\n if (swiper.params.loop) {\n swiper.slideTo(swiper.params.initialSlide + swiper.loopedSlides, 0, swiper.params.runCallbacksOnInit, false, true);\n } else {\n swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit, false, true);\n } // Attach events\n\n\n swiper.attachEvents(); // Init Flag\n\n swiper.initialized = true; // Emit\n\n swiper.emit('init');\n swiper.emit('afterInit');\n return swiper;\n }\n\n destroy(deleteInstance = true, cleanStyles = true) {\n const swiper = this;\n const {\n params,\n $el,\n $wrapperEl,\n slides\n } = swiper;\n\n if (typeof swiper.params === 'undefined' || swiper.destroyed) {\n return null;\n }\n\n swiper.emit('beforeDestroy'); // Init Flag\n\n swiper.initialized = false; // Detach events\n\n swiper.detachEvents(); // Destroy loop\n\n if (params.loop) {\n swiper.loopDestroy();\n } // Cleanup styles\n\n\n if (cleanStyles) {\n swiper.removeClasses();\n $el.removeAttr('style');\n $wrapperEl.removeAttr('style');\n\n if (slides && slides.length) {\n slides.removeClass([params.slideVisibleClass, params.slideActiveClass, params.slideNextClass, params.slidePrevClass].join(' ')).removeAttr('style').removeAttr('data-swiper-slide-index');\n }\n }\n\n swiper.emit('destroy'); // Detach emitter events\n\n Object.keys(swiper.eventsListeners).forEach(eventName => {\n swiper.off(eventName);\n });\n\n if (deleteInstance !== false) {\n swiper.$el[0].swiper = null;\n deleteProps(swiper);\n }\n\n swiper.destroyed = true;\n return null;\n }\n\n static extendDefaults(newDefaults) {\n extend(extendedDefaults, newDefaults);\n }\n\n static get extendedDefaults() {\n return extendedDefaults;\n }\n\n static get defaults() {\n return defaults;\n }\n\n static installModule(mod) {\n if (!Swiper.prototype.__modules__) Swiper.prototype.__modules__ = [];\n const modules = Swiper.prototype.__modules__;\n\n if (typeof mod === 'function' && modules.indexOf(mod) < 0) {\n modules.push(mod);\n }\n }\n\n static use(module) {\n if (Array.isArray(module)) {\n module.forEach(m => Swiper.installModule(m));\n return Swiper;\n }\n\n Swiper.installModule(module);\n return Swiper;\n }\n\n}\n\nObject.keys(prototypes).forEach(prototypeGroup => {\n Object.keys(prototypes[prototypeGroup]).forEach(protoMethod => {\n Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod];\n });\n});\nSwiper.use([Resize, Observer]);\nexport default Swiper;","import setGrabCursor from './setGrabCursor.js';\nimport unsetGrabCursor from './unsetGrabCursor.js';\nexport default {\n setGrabCursor,\n unsetGrabCursor\n};","export default function setGrabCursor(moving) {\n const swiper = this;\n if (swiper.support.touch || !swiper.params.simulateTouch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return;\n const el = swiper.params.touchEventsTarget === 'container' ? swiper.el : swiper.wrapperEl;\n el.style.cursor = 'move';\n el.style.cursor = moving ? 'grabbing' : 'grab';\n}","export default function unsetGrabCursor() {\n const swiper = this;\n\n if (swiper.support.touch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) {\n return;\n }\n\n swiper[swiper.params.touchEventsTarget === 'container' ? 'el' : 'wrapperEl'].style.cursor = '';\n}","import loadImage from './loadImage.js';\nimport preloadImages from './preloadImages.js';\nexport default {\n loadImage,\n preloadImages\n};","import { getWindow } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function loadImage(imageEl, src, srcset, sizes, checkForComplete, callback) {\n const window = getWindow();\n let image;\n\n function onReady() {\n if (callback) callback();\n }\n\n const isPicture = $(imageEl).parent('picture')[0];\n\n if (!isPicture && (!imageEl.complete || !checkForComplete)) {\n if (src) {\n image = new window.Image();\n image.onload = onReady;\n image.onerror = onReady;\n\n if (sizes) {\n image.sizes = sizes;\n }\n\n if (srcset) {\n image.srcset = srcset;\n }\n\n if (src) {\n image.src = src;\n }\n } else {\n onReady();\n }\n } else {\n // image already loaded...\n onReady();\n }\n}","export default function preloadImages() {\n const swiper = this;\n swiper.imagesToLoad = swiper.$el.find('img');\n\n function onReady() {\n if (typeof swiper === 'undefined' || swiper === null || !swiper || swiper.destroyed) return;\n if (swiper.imagesLoaded !== undefined) swiper.imagesLoaded += 1;\n\n if (swiper.imagesLoaded === swiper.imagesToLoad.length) {\n if (swiper.params.updateOnImagesReady) swiper.update();\n swiper.emit('imagesReady');\n }\n }\n\n for (let i = 0; i < swiper.imagesToLoad.length; i += 1) {\n const imageEl = swiper.imagesToLoad[i];\n swiper.loadImage(imageEl, imageEl.currentSrc || imageEl.getAttribute('src'), imageEl.srcset || imageEl.getAttribute('srcset'), imageEl.sizes || imageEl.getAttribute('sizes'), true, onReady);\n }\n}","import { getWindow } from 'ssr-window';\nexport default function Resize({\n swiper,\n on,\n emit\n}) {\n const window = getWindow();\n let observer = null;\n let animationFrame = null;\n\n const resizeHandler = () => {\n if (!swiper || swiper.destroyed || !swiper.initialized) return;\n emit('beforeResize');\n emit('resize');\n };\n\n const createObserver = () => {\n if (!swiper || swiper.destroyed || !swiper.initialized) return;\n observer = new ResizeObserver(entries => {\n animationFrame = window.requestAnimationFrame(() => {\n const {\n width,\n height\n } = swiper;\n let newWidth = width;\n let newHeight = height;\n entries.forEach(({\n contentBoxSize,\n contentRect,\n target\n }) => {\n if (target && target !== swiper.el) return;\n newWidth = contentRect ? contentRect.width : (contentBoxSize[0] || contentBoxSize).inlineSize;\n newHeight = contentRect ? contentRect.height : (contentBoxSize[0] || contentBoxSize).blockSize;\n });\n\n if (newWidth !== width || newHeight !== height) {\n resizeHandler();\n }\n });\n });\n observer.observe(swiper.el);\n };\n\n const removeObserver = () => {\n if (animationFrame) {\n window.cancelAnimationFrame(animationFrame);\n }\n\n if (observer && observer.unobserve && swiper.el) {\n observer.unobserve(swiper.el);\n observer = null;\n }\n };\n\n const orientationChangeHandler = () => {\n if (!swiper || swiper.destroyed || !swiper.initialized) return;\n emit('orientationchange');\n };\n\n on('init', () => {\n if (swiper.params.resizeObserver && typeof window.ResizeObserver !== 'undefined') {\n createObserver();\n return;\n }\n\n window.addEventListener('resize', resizeHandler);\n window.addEventListener('orientationchange', orientationChangeHandler);\n });\n on('destroy', () => {\n removeObserver();\n window.removeEventListener('resize', resizeHandler);\n window.removeEventListener('orientationchange', orientationChangeHandler);\n });\n}","import { getWindow } from 'ssr-window';\nexport default function Observer({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const observers = [];\n const window = getWindow();\n\n const attach = (target, options = {}) => {\n const ObserverFunc = window.MutationObserver || window.WebkitMutationObserver;\n const observer = new ObserverFunc(mutations => {\n // The observerUpdate event should only be triggered\n // once despite the number of mutations. Additional\n // triggers are redundant and are very costly\n if (mutations.length === 1) {\n emit('observerUpdate', mutations[0]);\n return;\n }\n\n const observerUpdate = function observerUpdate() {\n emit('observerUpdate', mutations[0]);\n };\n\n if (window.requestAnimationFrame) {\n window.requestAnimationFrame(observerUpdate);\n } else {\n window.setTimeout(observerUpdate, 0);\n }\n });\n observer.observe(target, {\n attributes: typeof options.attributes === 'undefined' ? true : options.attributes,\n childList: typeof options.childList === 'undefined' ? true : options.childList,\n characterData: typeof options.characterData === 'undefined' ? true : options.characterData\n });\n observers.push(observer);\n };\n\n const init = () => {\n if (!swiper.params.observer) return;\n\n if (swiper.params.observeParents) {\n const containerParents = swiper.$el.parents();\n\n for (let i = 0; i < containerParents.length; i += 1) {\n attach(containerParents[i]);\n }\n } // Observe container\n\n\n attach(swiper.$el[0], {\n childList: swiper.params.observeSlideChildren\n }); // Observe wrapper\n\n attach(swiper.$wrapperEl[0], {\n attributes: false\n });\n };\n\n const destroy = () => {\n observers.forEach(observer => {\n observer.disconnect();\n });\n observers.splice(0, observers.length);\n };\n\n extendParams({\n observer: false,\n observeParents: false,\n observeSlideChildren: false\n });\n on('init', init);\n on('destroy', destroy);\n}","/* eslint-disable consistent-return */\nimport { getWindow, getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function Keyboard({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const document = getDocument();\n const window = getWindow();\n swiper.keyboard = {\n enabled: false\n };\n extendParams({\n keyboard: {\n enabled: false,\n onlyInViewport: true,\n pageUpDown: true\n }\n });\n\n function handle(event) {\n if (!swiper.enabled) return;\n const {\n rtlTranslate: rtl\n } = swiper;\n let e = event;\n if (e.originalEvent) e = e.originalEvent; // jquery fix\n\n const kc = e.keyCode || e.charCode;\n const pageUpDown = swiper.params.keyboard.pageUpDown;\n const isPageUp = pageUpDown && kc === 33;\n const isPageDown = pageUpDown && kc === 34;\n const isArrowLeft = kc === 37;\n const isArrowRight = kc === 39;\n const isArrowUp = kc === 38;\n const isArrowDown = kc === 40; // Directions locks\n\n if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) {\n return false;\n }\n\n if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) {\n return false;\n }\n\n if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {\n return undefined;\n }\n\n if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === 'input' || document.activeElement.nodeName.toLowerCase() === 'textarea')) {\n return undefined;\n }\n\n if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {\n let inView = false; // Check that swiper should be inside of visible area of window\n\n if (swiper.$el.parents(`.${swiper.params.slideClass}`).length > 0 && swiper.$el.parents(`.${swiper.params.slideActiveClass}`).length === 0) {\n return undefined;\n }\n\n const $el = swiper.$el;\n const swiperWidth = $el[0].clientWidth;\n const swiperHeight = $el[0].clientHeight;\n const windowWidth = window.innerWidth;\n const windowHeight = window.innerHeight;\n const swiperOffset = swiper.$el.offset();\n if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;\n const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiperWidth, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiperHeight], [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight]];\n\n for (let i = 0; i < swiperCoord.length; i += 1) {\n const point = swiperCoord[i];\n\n if (point[0] >= 0 && point[0] <= windowWidth && point[1] >= 0 && point[1] <= windowHeight) {\n if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line\n\n inView = true;\n }\n }\n\n if (!inView) return undefined;\n }\n\n if (swiper.isHorizontal()) {\n if (isPageUp || isPageDown || isArrowLeft || isArrowRight) {\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n }\n\n if ((isPageDown || isArrowRight) && !rtl || (isPageUp || isArrowLeft) && rtl) swiper.slideNext();\n if ((isPageUp || isArrowLeft) && !rtl || (isPageDown || isArrowRight) && rtl) swiper.slidePrev();\n } else {\n if (isPageUp || isPageDown || isArrowUp || isArrowDown) {\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n }\n\n if (isPageDown || isArrowDown) swiper.slideNext();\n if (isPageUp || isArrowUp) swiper.slidePrev();\n }\n\n emit('keyPress', kc);\n return undefined;\n }\n\n function enable() {\n if (swiper.keyboard.enabled) return;\n $(document).on('keydown', handle);\n swiper.keyboard.enabled = true;\n }\n\n function disable() {\n if (!swiper.keyboard.enabled) return;\n $(document).off('keydown', handle);\n swiper.keyboard.enabled = false;\n }\n\n on('init', () => {\n if (swiper.params.keyboard.enabled) {\n enable();\n }\n });\n on('destroy', () => {\n if (swiper.keyboard.enabled) {\n disable();\n }\n });\n Object.assign(swiper.keyboard, {\n enable,\n disable\n });\n}","export default function classesToSelector(classes = '') {\n return `.${classes.trim().replace(/([\\.:!\\/])/g, '\\\\$1') // eslint-disable-line\n .replace(/ /g, '.')}`;\n}","import $ from '../../shared/dom.js';\nimport classesToSelector from '../../shared/classes-to-selector.js';\nimport createElementIfNotDefined from '../../shared/create-element-if-not-defined.js';\nexport default function Pagination({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const pfx = 'swiper-pagination';\n extendParams({\n pagination: {\n el: null,\n bulletElement: 'span',\n clickable: false,\n hideOnClick: false,\n renderBullet: null,\n renderProgressbar: null,\n renderFraction: null,\n renderCustom: null,\n progressbarOpposite: false,\n type: 'bullets',\n // 'bullets' or 'progressbar' or 'fraction' or 'custom'\n dynamicBullets: false,\n dynamicMainBullets: 1,\n formatFractionCurrent: number => number,\n formatFractionTotal: number => number,\n bulletClass: `${pfx}-bullet`,\n bulletActiveClass: `${pfx}-bullet-active`,\n modifierClass: `${pfx}-`,\n currentClass: `${pfx}-current`,\n totalClass: `${pfx}-total`,\n hiddenClass: `${pfx}-hidden`,\n progressbarFillClass: `${pfx}-progressbar-fill`,\n progressbarOppositeClass: `${pfx}-progressbar-opposite`,\n clickableClass: `${pfx}-clickable`,\n lockClass: `${pfx}-lock`,\n horizontalClass: `${pfx}-horizontal`,\n verticalClass: `${pfx}-vertical`,\n paginationDisabledClass: `${pfx}-disabled`\n }\n });\n swiper.pagination = {\n el: null,\n $el: null,\n bullets: []\n };\n let bulletSize;\n let dynamicBulletIndex = 0;\n\n function isPaginationDisabled() {\n return !swiper.params.pagination.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0;\n }\n\n function setSideBullets($bulletEl, position) {\n const {\n bulletActiveClass\n } = swiper.params.pagination;\n $bulletEl[position]().addClass(`${bulletActiveClass}-${position}`)[position]().addClass(`${bulletActiveClass}-${position}-${position}`);\n }\n\n function update() {\n // Render || Update Pagination bullets/items\n const rtl = swiper.rtl;\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n const $el = swiper.pagination.$el; // Current/Total\n\n let current;\n const total = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n\n if (swiper.params.loop) {\n current = Math.ceil((swiper.activeIndex - swiper.loopedSlides) / swiper.params.slidesPerGroup);\n\n if (current > slidesLength - 1 - swiper.loopedSlides * 2) {\n current -= slidesLength - swiper.loopedSlides * 2;\n }\n\n if (current > total - 1) current -= total;\n if (current < 0 && swiper.params.paginationType !== 'bullets') current = total + current;\n } else if (typeof swiper.snapIndex !== 'undefined') {\n current = swiper.snapIndex;\n } else {\n current = swiper.activeIndex || 0;\n } // Types\n\n\n if (params.type === 'bullets' && swiper.pagination.bullets && swiper.pagination.bullets.length > 0) {\n const bullets = swiper.pagination.bullets;\n let firstIndex;\n let lastIndex;\n let midIndex;\n\n if (params.dynamicBullets) {\n bulletSize = bullets.eq(0)[swiper.isHorizontal() ? 'outerWidth' : 'outerHeight'](true);\n $el.css(swiper.isHorizontal() ? 'width' : 'height', `${bulletSize * (params.dynamicMainBullets + 4)}px`);\n\n if (params.dynamicMainBullets > 1 && swiper.previousIndex !== undefined) {\n dynamicBulletIndex += current - (swiper.previousIndex - swiper.loopedSlides || 0);\n\n if (dynamicBulletIndex > params.dynamicMainBullets - 1) {\n dynamicBulletIndex = params.dynamicMainBullets - 1;\n } else if (dynamicBulletIndex < 0) {\n dynamicBulletIndex = 0;\n }\n }\n\n firstIndex = Math.max(current - dynamicBulletIndex, 0);\n lastIndex = firstIndex + (Math.min(bullets.length, params.dynamicMainBullets) - 1);\n midIndex = (lastIndex + firstIndex) / 2;\n }\n\n bullets.removeClass(['', '-next', '-next-next', '-prev', '-prev-prev', '-main'].map(suffix => `${params.bulletActiveClass}${suffix}`).join(' '));\n\n if ($el.length > 1) {\n bullets.each(bullet => {\n const $bullet = $(bullet);\n const bulletIndex = $bullet.index();\n\n if (bulletIndex === current) {\n $bullet.addClass(params.bulletActiveClass);\n }\n\n if (params.dynamicBullets) {\n if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) {\n $bullet.addClass(`${params.bulletActiveClass}-main`);\n }\n\n if (bulletIndex === firstIndex) {\n setSideBullets($bullet, 'prev');\n }\n\n if (bulletIndex === lastIndex) {\n setSideBullets($bullet, 'next');\n }\n }\n });\n } else {\n const $bullet = bullets.eq(current);\n const bulletIndex = $bullet.index();\n $bullet.addClass(params.bulletActiveClass);\n\n if (params.dynamicBullets) {\n const $firstDisplayedBullet = bullets.eq(firstIndex);\n const $lastDisplayedBullet = bullets.eq(lastIndex);\n\n for (let i = firstIndex; i <= lastIndex; i += 1) {\n bullets.eq(i).addClass(`${params.bulletActiveClass}-main`);\n }\n\n if (swiper.params.loop) {\n if (bulletIndex >= bullets.length) {\n for (let i = params.dynamicMainBullets; i >= 0; i -= 1) {\n bullets.eq(bullets.length - i).addClass(`${params.bulletActiveClass}-main`);\n }\n\n bullets.eq(bullets.length - params.dynamicMainBullets - 1).addClass(`${params.bulletActiveClass}-prev`);\n } else {\n setSideBullets($firstDisplayedBullet, 'prev');\n setSideBullets($lastDisplayedBullet, 'next');\n }\n } else {\n setSideBullets($firstDisplayedBullet, 'prev');\n setSideBullets($lastDisplayedBullet, 'next');\n }\n }\n }\n\n if (params.dynamicBullets) {\n const dynamicBulletsLength = Math.min(bullets.length, params.dynamicMainBullets + 4);\n const bulletsOffset = (bulletSize * dynamicBulletsLength - bulletSize) / 2 - midIndex * bulletSize;\n const offsetProp = rtl ? 'right' : 'left';\n bullets.css(swiper.isHorizontal() ? offsetProp : 'top', `${bulletsOffset}px`);\n }\n }\n\n if (params.type === 'fraction') {\n $el.find(classesToSelector(params.currentClass)).text(params.formatFractionCurrent(current + 1));\n $el.find(classesToSelector(params.totalClass)).text(params.formatFractionTotal(total));\n }\n\n if (params.type === 'progressbar') {\n let progressbarDirection;\n\n if (params.progressbarOpposite) {\n progressbarDirection = swiper.isHorizontal() ? 'vertical' : 'horizontal';\n } else {\n progressbarDirection = swiper.isHorizontal() ? 'horizontal' : 'vertical';\n }\n\n const scale = (current + 1) / total;\n let scaleX = 1;\n let scaleY = 1;\n\n if (progressbarDirection === 'horizontal') {\n scaleX = scale;\n } else {\n scaleY = scale;\n }\n\n $el.find(classesToSelector(params.progressbarFillClass)).transform(`translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`).transition(swiper.params.speed);\n }\n\n if (params.type === 'custom' && params.renderCustom) {\n $el.html(params.renderCustom(swiper, current + 1, total));\n emit('paginationRender', $el[0]);\n } else {\n emit('paginationUpdate', $el[0]);\n }\n\n if (swiper.params.watchOverflow && swiper.enabled) {\n $el[swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n }\n }\n\n function render() {\n // Render Container\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n const $el = swiper.pagination.$el;\n let paginationHTML = '';\n\n if (params.type === 'bullets') {\n let numberOfBullets = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n\n if (swiper.params.freeMode && swiper.params.freeMode.enabled && !swiper.params.loop && numberOfBullets > slidesLength) {\n numberOfBullets = slidesLength;\n }\n\n for (let i = 0; i < numberOfBullets; i += 1) {\n if (params.renderBullet) {\n paginationHTML += params.renderBullet.call(swiper, i, params.bulletClass);\n } else {\n paginationHTML += `<${params.bulletElement} class=\"${params.bulletClass}\">`;\n }\n }\n\n $el.html(paginationHTML);\n swiper.pagination.bullets = $el.find(classesToSelector(params.bulletClass));\n }\n\n if (params.type === 'fraction') {\n if (params.renderFraction) {\n paginationHTML = params.renderFraction.call(swiper, params.currentClass, params.totalClass);\n } else {\n paginationHTML = `` + ' / ' + ``;\n }\n\n $el.html(paginationHTML);\n }\n\n if (params.type === 'progressbar') {\n if (params.renderProgressbar) {\n paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass);\n } else {\n paginationHTML = ``;\n }\n\n $el.html(paginationHTML);\n }\n\n if (params.type !== 'custom') {\n emit('paginationRender', swiper.pagination.$el[0]);\n }\n }\n\n function init() {\n swiper.params.pagination = createElementIfNotDefined(swiper, swiper.originalParams.pagination, swiper.params.pagination, {\n el: 'swiper-pagination'\n });\n const params = swiper.params.pagination;\n if (!params.el) return;\n let $el = $(params.el);\n if ($el.length === 0) return;\n\n if (swiper.params.uniqueNavElements && typeof params.el === 'string' && $el.length > 1) {\n $el = swiper.$el.find(params.el); // check if it belongs to another nested Swiper\n\n if ($el.length > 1) {\n $el = $el.filter(el => {\n if ($(el).parents('.swiper')[0] !== swiper.el) return false;\n return true;\n });\n }\n }\n\n if (params.type === 'bullets' && params.clickable) {\n $el.addClass(params.clickableClass);\n }\n\n $el.addClass(params.modifierClass + params.type);\n $el.addClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n\n if (params.type === 'bullets' && params.dynamicBullets) {\n $el.addClass(`${params.modifierClass}${params.type}-dynamic`);\n dynamicBulletIndex = 0;\n\n if (params.dynamicMainBullets < 1) {\n params.dynamicMainBullets = 1;\n }\n }\n\n if (params.type === 'progressbar' && params.progressbarOpposite) {\n $el.addClass(params.progressbarOppositeClass);\n }\n\n if (params.clickable) {\n $el.on('click', classesToSelector(params.bulletClass), function onClick(e) {\n e.preventDefault();\n let index = $(this).index() * swiper.params.slidesPerGroup;\n if (swiper.params.loop) index += swiper.loopedSlides;\n swiper.slideTo(index);\n });\n }\n\n Object.assign(swiper.pagination, {\n $el,\n el: $el[0]\n });\n\n if (!swiper.enabled) {\n $el.addClass(params.lockClass);\n }\n }\n\n function destroy() {\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const $el = swiper.pagination.$el;\n $el.removeClass(params.hiddenClass);\n $el.removeClass(params.modifierClass + params.type);\n $el.removeClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n if (swiper.pagination.bullets && swiper.pagination.bullets.removeClass) swiper.pagination.bullets.removeClass(params.bulletActiveClass);\n\n if (params.clickable) {\n $el.off('click', classesToSelector(params.bulletClass));\n }\n }\n\n on('init', () => {\n if (swiper.params.pagination.enabled === false) {\n // eslint-disable-next-line\n disable();\n } else {\n init();\n render();\n update();\n }\n });\n on('activeIndexChange', () => {\n if (swiper.params.loop) {\n update();\n } else if (typeof swiper.snapIndex === 'undefined') {\n update();\n }\n });\n on('snapIndexChange', () => {\n if (!swiper.params.loop) {\n update();\n }\n });\n on('slidesLengthChange', () => {\n if (swiper.params.loop) {\n render();\n update();\n }\n });\n on('snapGridLengthChange', () => {\n if (!swiper.params.loop) {\n render();\n update();\n }\n });\n on('destroy', () => {\n destroy();\n });\n on('enable disable', () => {\n const {\n $el\n } = swiper.pagination;\n\n if ($el) {\n $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.pagination.lockClass);\n }\n });\n on('lock unlock', () => {\n update();\n });\n on('click', (_s, e) => {\n const targetEl = e.target;\n const {\n $el\n } = swiper.pagination;\n\n if (swiper.params.pagination.el && swiper.params.pagination.hideOnClick && $el && $el.length > 0 && !$(targetEl).hasClass(swiper.params.pagination.bulletClass)) {\n if (swiper.navigation && (swiper.navigation.nextEl && targetEl === swiper.navigation.nextEl || swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl)) return;\n const isHidden = $el.hasClass(swiper.params.pagination.hiddenClass);\n\n if (isHidden === true) {\n emit('paginationShow');\n } else {\n emit('paginationHide');\n }\n\n $el.toggleClass(swiper.params.pagination.hiddenClass);\n }\n });\n\n const enable = () => {\n swiper.$el.removeClass(swiper.params.pagination.paginationDisabledClass);\n\n if (swiper.pagination.$el) {\n swiper.pagination.$el.removeClass(swiper.params.pagination.paginationDisabledClass);\n }\n\n init();\n render();\n update();\n };\n\n const disable = () => {\n swiper.$el.addClass(swiper.params.pagination.paginationDisabledClass);\n\n if (swiper.pagination.$el) {\n swiper.pagination.$el.addClass(swiper.params.pagination.paginationDisabledClass);\n }\n\n destroy();\n };\n\n Object.assign(swiper.pagination, {\n enable,\n disable,\n render,\n update,\n init,\n destroy\n });\n}","import { getDocument } from 'ssr-window';\nexport default function createElementIfNotDefined(swiper, originalParams, params, checkProps) {\n const document = getDocument();\n\n if (swiper.params.createElements) {\n Object.keys(checkProps).forEach(key => {\n if (!params[key] && params.auto === true) {\n let element = swiper.$el.children(`.${checkProps[key]}`)[0];\n\n if (!element) {\n element = document.createElement('div');\n element.className = checkProps[key];\n swiper.$el.append(element);\n }\n\n params[key] = element;\n originalParams[key] = element;\n }\n });\n }\n\n return params;\n}","import $ from './dom.js';\nexport default function createShadow(params, $slideEl, side) {\n const shadowClass = `swiper-slide-shadow${side ? `-${side}` : ''}`;\n const $shadowContainer = params.transformEl ? $slideEl.find(params.transformEl) : $slideEl;\n let $shadowEl = $shadowContainer.children(`.${shadowClass}`);\n\n if (!$shadowEl.length) {\n $shadowEl = $(`
`);\n $shadowContainer.append($shadowEl);\n }\n\n return $shadowEl;\n}","export default function effectTarget(effectParams, $slideEl) {\n if (effectParams.transformEl) {\n return $slideEl.find(effectParams.transformEl).css({\n 'backface-visibility': 'hidden',\n '-webkit-backface-visibility': 'hidden'\n });\n }\n\n return $slideEl;\n}","import createShadow from '../../shared/create-shadow.js';\nimport effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nexport default function EffectCoverflow({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n coverflowEffect: {\n rotate: 50,\n stretch: 0,\n depth: 100,\n scale: 1,\n modifier: 1,\n slideShadows: true,\n transformEl: null\n }\n });\n\n const setTranslate = () => {\n const {\n width: swiperWidth,\n height: swiperHeight,\n slides,\n slidesSizesGrid\n } = swiper;\n const params = swiper.params.coverflowEffect;\n const isHorizontal = swiper.isHorizontal();\n const transform = swiper.translate;\n const center = isHorizontal ? -transform + swiperWidth / 2 : -transform + swiperHeight / 2;\n const rotate = isHorizontal ? params.rotate : -params.rotate;\n const translate = params.depth; // Each slide offset from center\n\n for (let i = 0, length = slides.length; i < length; i += 1) {\n const $slideEl = slides.eq(i);\n const slideSize = slidesSizesGrid[i];\n const slideOffset = $slideEl[0].swiperSlideOffset;\n const centerOffset = (center - slideOffset - slideSize / 2) / slideSize;\n const offsetMultiplier = typeof params.modifier === 'function' ? params.modifier(centerOffset) : centerOffset * params.modifier;\n let rotateY = isHorizontal ? rotate * offsetMultiplier : 0;\n let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier; // var rotateZ = 0\n\n let translateZ = -translate * Math.abs(offsetMultiplier);\n let stretch = params.stretch; // Allow percentage to make a relative stretch for responsive sliders\n\n if (typeof stretch === 'string' && stretch.indexOf('%') !== -1) {\n stretch = parseFloat(params.stretch) / 100 * slideSize;\n }\n\n let translateY = isHorizontal ? 0 : stretch * offsetMultiplier;\n let translateX = isHorizontal ? stretch * offsetMultiplier : 0;\n let scale = 1 - (1 - params.scale) * Math.abs(offsetMultiplier); // Fix for ultra small values\n\n if (Math.abs(translateX) < 0.001) translateX = 0;\n if (Math.abs(translateY) < 0.001) translateY = 0;\n if (Math.abs(translateZ) < 0.001) translateZ = 0;\n if (Math.abs(rotateY) < 0.001) rotateY = 0;\n if (Math.abs(rotateX) < 0.001) rotateX = 0;\n if (Math.abs(scale) < 0.001) scale = 0;\n const slideTransform = `translate3d(${translateX}px,${translateY}px,${translateZ}px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) scale(${scale})`;\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(slideTransform);\n $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;\n\n if (params.slideShadows) {\n // Set shadows\n let $shadowBeforeEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n let $shadowAfterEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n\n if ($shadowBeforeEl.length === 0) {\n $shadowBeforeEl = createShadow(params, $slideEl, isHorizontal ? 'left' : 'top');\n }\n\n if ($shadowAfterEl.length === 0) {\n $shadowAfterEl = createShadow(params, $slideEl, isHorizontal ? 'right' : 'bottom');\n }\n\n if ($shadowBeforeEl.length) $shadowBeforeEl[0].style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;\n if ($shadowAfterEl.length) $shadowAfterEl[0].style.opacity = -offsetMultiplier > 0 ? -offsetMultiplier : 0;\n }\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.coverflowEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);\n };\n\n effectInit({\n effect: 'coverflow',\n swiper,\n on,\n setTranslate,\n setTransition,\n perspective: () => true,\n overwriteParams: () => ({\n watchSlidesProgress: true\n })\n });\n}","export default function effectInit(params) {\n const {\n effect,\n swiper,\n on,\n setTranslate,\n setTransition,\n overwriteParams,\n perspective,\n recreateShadows,\n getEffectParams\n } = params;\n on('beforeInit', () => {\n if (swiper.params.effect !== effect) return;\n swiper.classNames.push(`${swiper.params.containerModifierClass}${effect}`);\n\n if (perspective && perspective()) {\n swiper.classNames.push(`${swiper.params.containerModifierClass}3d`);\n }\n\n const overwriteParamsResult = overwriteParams ? overwriteParams() : {};\n Object.assign(swiper.params, overwriteParamsResult);\n Object.assign(swiper.originalParams, overwriteParamsResult);\n });\n on('setTranslate', () => {\n if (swiper.params.effect !== effect) return;\n setTranslate();\n });\n on('setTransition', (_s, duration) => {\n if (swiper.params.effect !== effect) return;\n setTransition(duration);\n });\n on('transitionEnd', () => {\n if (swiper.params.effect !== effect) return;\n\n if (recreateShadows) {\n if (!getEffectParams || !getEffectParams().slideShadows) return; // remove shadows\n\n swiper.slides.each(slideEl => {\n const $slideEl = swiper.$(slideEl);\n $slideEl.find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').remove();\n }); // create new one\n\n recreateShadows();\n }\n });\n let requireUpdateOnVirtual;\n on('virtualUpdate', () => {\n if (swiper.params.effect !== effect) return;\n\n if (!swiper.slides.length) {\n requireUpdateOnVirtual = true;\n }\n\n requestAnimationFrame(() => {\n if (requireUpdateOnVirtual && swiper.slides && swiper.slides.length) {\n setTranslate();\n requireUpdateOnVirtual = false;\n }\n });\n });\n}","function isObject(o) {\n return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';\n}\n\nfunction extend(target, src) {\n const noExtend = ['__proto__', 'constructor', 'prototype'];\n Object.keys(src).filter(key => noExtend.indexOf(key) < 0).forEach(key => {\n if (typeof target[key] === 'undefined') target[key] = src[key];else if (isObject(src[key]) && isObject(target[key]) && Object.keys(src[key]).length > 0) {\n if (src[key].__swiper__) target[key] = src[key];else extend(target[key], src[key]);\n } else {\n target[key] = src[key];\n }\n });\n}\n\nfunction needsNavigation(params = {}) {\n return params.navigation && typeof params.navigation.nextEl === 'undefined' && typeof params.navigation.prevEl === 'undefined';\n}\n\nfunction needsPagination(params = {}) {\n return params.pagination && typeof params.pagination.el === 'undefined';\n}\n\nfunction needsScrollbar(params = {}) {\n return params.scrollbar && typeof params.scrollbar.el === 'undefined';\n}\n\nfunction uniqueClasses(classNames = '') {\n const classes = classNames.split(' ').map(c => c.trim()).filter(c => !!c);\n const unique = [];\n classes.forEach(c => {\n if (unique.indexOf(c) < 0) unique.push(c);\n });\n return unique.join(' ');\n}\n\nexport { isObject, extend, needsNavigation, needsPagination, needsScrollbar, uniqueClasses };","/* underscore in name -> watch for changes */\nconst paramsList = ['modules', 'init', '_direction', 'touchEventsTarget', 'initialSlide', '_speed', 'cssMode', 'updateOnWindowResize', 'resizeObserver', 'nested', 'focusableElements', '_enabled', '_width', '_height', 'preventInteractionOnTransition', 'userAgent', 'url', '_edgeSwipeDetection', '_edgeSwipeThreshold', '_freeMode', '_autoHeight', 'setWrapperSize', 'virtualTranslate', '_effect', 'breakpoints', '_spaceBetween', '_slidesPerView', 'maxBackfaceHiddenSlides', '_grid', '_slidesPerGroup', '_slidesPerGroupSkip', '_slidesPerGroupAuto', '_centeredSlides', '_centeredSlidesBounds', '_slidesOffsetBefore', '_slidesOffsetAfter', 'normalizeSlideIndex', '_centerInsufficientSlides', '_watchOverflow', 'roundLengths', 'touchRatio', 'touchAngle', 'simulateTouch', '_shortSwipes', '_longSwipes', 'longSwipesRatio', 'longSwipesMs', '_followFinger', 'allowTouchMove', '_threshold', 'touchMoveStopPropagation', 'touchStartPreventDefault', 'touchStartForcePreventDefault', 'touchReleaseOnEdges', 'uniqueNavElements', '_resistance', '_resistanceRatio', '_watchSlidesProgress', '_grabCursor', 'preventClicks', 'preventClicksPropagation', '_slideToClickedSlide', '_preloadImages', 'updateOnImagesReady', '_loop', '_loopAdditionalSlides', '_loopedSlides', '_loopedSlidesLimit', '_loopFillGroupWithBlank', 'loopPreventsSlide', '_rewind', '_allowSlidePrev', '_allowSlideNext', '_swipeHandler', '_noSwiping', 'noSwipingClass', 'noSwipingSelector', 'passiveListeners', 'containerModifierClass', 'slideClass', 'slideBlankClass', 'slideActiveClass', 'slideDuplicateActiveClass', 'slideVisibleClass', 'slideDuplicateClass', 'slideNextClass', 'slideDuplicateNextClass', 'slidePrevClass', 'slideDuplicatePrevClass', 'wrapperClass', 'runCallbacksOnInit', 'observer', 'observeParents', 'observeSlideChildren', // modules\n'a11y', '_autoplay', '_controller', 'coverflowEffect', 'cubeEffect', 'fadeEffect', 'flipEffect', 'creativeEffect', 'cardsEffect', 'hashNavigation', 'history', 'keyboard', 'lazy', 'mousewheel', '_navigation', '_pagination', 'parallax', '_scrollbar', '_thumbs', 'virtual', 'zoom'];\nexport { paramsList };","import Swiper from 'swiper';\nexport const calcLoopedSlides = (slides, swiperParams) => {\n let slidesPerViewParams = swiperParams.slidesPerView;\n\n if (swiperParams.breakpoints) {\n const breakpoint = Swiper.prototype.getBreakpoint(swiperParams.breakpoints);\n const breakpointOnlyParams = breakpoint in swiperParams.breakpoints ? swiperParams.breakpoints[breakpoint] : undefined;\n\n if (breakpointOnlyParams && breakpointOnlyParams.slidesPerView) {\n slidesPerViewParams = breakpointOnlyParams.slidesPerView;\n }\n }\n\n let loopedSlides = Math.ceil(parseFloat(swiperParams.loopedSlides || slidesPerViewParams, 10));\n loopedSlides += swiperParams.loopAdditionalSlides;\n\n if (loopedSlides > slides.length && swiperParams.loopedSlidesLimit) {\n loopedSlides = slides.length;\n }\n\n return loopedSlides;\n};","import React from 'react';\n\nfunction isChildSwiperSlide(child) {\n return child.type && child.type.displayName && child.type.displayName.includes('SwiperSlide');\n}\n\nfunction processChildren(c) {\n const slides = [];\n React.Children.toArray(c).forEach(child => {\n if (isChildSwiperSlide(child)) {\n slides.push(child);\n } else if (child.props && child.props.children) {\n processChildren(child.props.children).forEach(slide => slides.push(slide));\n }\n });\n return slides;\n}\n\nfunction getChildren(c) {\n const slides = [];\n const slots = {\n 'container-start': [],\n 'container-end': [],\n 'wrapper-start': [],\n 'wrapper-end': []\n };\n React.Children.toArray(c).forEach(child => {\n if (isChildSwiperSlide(child)) {\n slides.push(child);\n } else if (child.props && child.props.slot && slots[child.props.slot]) {\n slots[child.props.slot].push(child);\n } else if (child.props && child.props.children) {\n const foundSlides = processChildren(child.props.children);\n\n if (foundSlides.length > 0) {\n foundSlides.forEach(slide => slides.push(slide));\n } else {\n slots['container-end'].push(child);\n }\n } else {\n slots['container-end'].push(child);\n }\n });\n return {\n slides,\n slots\n };\n}\n\nexport { getChildren };","import { isObject, extend } from './utils.js';\n\nfunction updateSwiper({\n swiper,\n slides,\n passedParams,\n changedParams,\n nextEl,\n prevEl,\n scrollbarEl,\n paginationEl\n}) {\n const updateParams = changedParams.filter(key => key !== 'children' && key !== 'direction');\n const {\n params: currentParams,\n pagination,\n navigation,\n scrollbar,\n virtual,\n thumbs\n } = swiper;\n let needThumbsInit;\n let needControllerInit;\n let needPaginationInit;\n let needScrollbarInit;\n let needNavigationInit;\n\n if (changedParams.includes('thumbs') && passedParams.thumbs && passedParams.thumbs.swiper && currentParams.thumbs && !currentParams.thumbs.swiper) {\n needThumbsInit = true;\n }\n\n if (changedParams.includes('controller') && passedParams.controller && passedParams.controller.control && currentParams.controller && !currentParams.controller.control) {\n needControllerInit = true;\n }\n\n if (changedParams.includes('pagination') && passedParams.pagination && (passedParams.pagination.el || paginationEl) && (currentParams.pagination || currentParams.pagination === false) && pagination && !pagination.el) {\n needPaginationInit = true;\n }\n\n if (changedParams.includes('scrollbar') && passedParams.scrollbar && (passedParams.scrollbar.el || scrollbarEl) && (currentParams.scrollbar || currentParams.scrollbar === false) && scrollbar && !scrollbar.el) {\n needScrollbarInit = true;\n }\n\n if (changedParams.includes('navigation') && passedParams.navigation && (passedParams.navigation.prevEl || prevEl) && (passedParams.navigation.nextEl || nextEl) && (currentParams.navigation || currentParams.navigation === false) && navigation && !navigation.prevEl && !navigation.nextEl) {\n needNavigationInit = true;\n }\n\n const destroyModule = mod => {\n if (!swiper[mod]) return;\n swiper[mod].destroy();\n\n if (mod === 'navigation') {\n currentParams[mod].prevEl = undefined;\n currentParams[mod].nextEl = undefined;\n swiper[mod].prevEl = undefined;\n swiper[mod].nextEl = undefined;\n } else {\n currentParams[mod].el = undefined;\n swiper[mod].el = undefined;\n }\n };\n\n updateParams.forEach(key => {\n if (isObject(currentParams[key]) && isObject(passedParams[key])) {\n extend(currentParams[key], passedParams[key]);\n } else {\n const newValue = passedParams[key];\n\n if ((newValue === true || newValue === false) && (key === 'navigation' || key === 'pagination' || key === 'scrollbar')) {\n if (newValue === false) {\n destroyModule(key);\n }\n } else {\n currentParams[key] = passedParams[key];\n }\n }\n });\n\n if (updateParams.includes('controller') && !needControllerInit && swiper.controller && swiper.controller.control && currentParams.controller && currentParams.controller.control) {\n swiper.controller.control = currentParams.controller.control;\n }\n\n if (changedParams.includes('children') && slides && virtual && currentParams.virtual.enabled) {\n virtual.slides = slides;\n virtual.update(true);\n } else if (changedParams.includes('children') && swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n\n if (needThumbsInit) {\n const initialized = thumbs.init();\n if (initialized) thumbs.update(true);\n }\n\n if (needControllerInit) {\n swiper.controller.control = currentParams.controller.control;\n }\n\n if (needPaginationInit) {\n if (paginationEl) currentParams.pagination.el = paginationEl;\n pagination.init();\n pagination.render();\n pagination.update();\n }\n\n if (needScrollbarInit) {\n if (scrollbarEl) currentParams.scrollbar.el = scrollbarEl;\n scrollbar.init();\n scrollbar.updateSize();\n scrollbar.setTranslate();\n }\n\n if (needNavigationInit) {\n if (nextEl) currentParams.navigation.nextEl = nextEl;\n if (prevEl) currentParams.navigation.prevEl = prevEl;\n navigation.init();\n navigation.update();\n }\n\n if (changedParams.includes('allowSlideNext')) {\n swiper.allowSlideNext = passedParams.allowSlideNext;\n }\n\n if (changedParams.includes('allowSlidePrev')) {\n swiper.allowSlidePrev = passedParams.allowSlidePrev;\n }\n\n if (changedParams.includes('direction')) {\n swiper.changeDirection(passedParams.direction, false);\n }\n\n swiper.update();\n}\n\nexport { updateSwiper };","import { useEffect, useLayoutEffect } from 'react';\n\nfunction useIsomorphicLayoutEffect(callback, deps) {\n // eslint-disable-next-line\n if (typeof window === 'undefined') return useEffect(callback, deps);\n return useLayoutEffect(callback, deps);\n}\n\nexport { useIsomorphicLayoutEffect };","import { createContext, useContext } from 'react';\nexport const SwiperSlideContext = /*#__PURE__*/createContext(null);\nexport const useSwiperSlide = () => {\n return useContext(SwiperSlideContext);\n};\nexport const SwiperContext = /*#__PURE__*/createContext(null);\nexport const useSwiper = () => {\n return useContext(SwiperContext);\n};","function _extends() { _extends = Object.assign ? Object.assign.bind() : 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; }; return _extends.apply(this, arguments); }\n\nimport React, { useRef, useState, useEffect, forwardRef } from 'react';\nimport SwiperCore from 'swiper';\nimport { getParams } from '../components-shared/get-params.js';\nimport { mountSwiper } from '../components-shared/mount-swiper.js';\nimport { needsScrollbar, needsNavigation, needsPagination, uniqueClasses, extend } from '../components-shared/utils.js';\nimport { renderLoop, calcLoopedSlides } from './loop.js';\nimport { getChangedParams } from '../components-shared/get-changed-params.js';\nimport { getChildren } from './get-children.js';\nimport { updateSwiper } from '../components-shared/update-swiper.js';\nimport { renderVirtual } from './virtual.js';\nimport { updateOnVirtualData } from '../components-shared/update-on-virtual-data.js';\nimport { useIsomorphicLayoutEffect } from './use-isomorphic-layout-effect.js';\nimport { SwiperContext } from './context.js';\nconst Swiper = /*#__PURE__*/forwardRef(function (_temp, externalElRef) {\n let {\n className,\n tag: Tag = 'div',\n wrapperTag: WrapperTag = 'div',\n children,\n onSwiper,\n ...rest\n } = _temp === void 0 ? {} : _temp;\n let eventsAssigned = false;\n const [containerClasses, setContainerClasses] = useState('swiper');\n const [virtualData, setVirtualData] = useState(null);\n const [breakpointChanged, setBreakpointChanged] = useState(false);\n const initializedRef = useRef(false);\n const swiperElRef = useRef(null);\n const swiperRef = useRef(null);\n const oldPassedParamsRef = useRef(null);\n const oldSlides = useRef(null);\n const nextElRef = useRef(null);\n const prevElRef = useRef(null);\n const paginationElRef = useRef(null);\n const scrollbarElRef = useRef(null);\n const {\n params: swiperParams,\n passedParams,\n rest: restProps,\n events\n } = getParams(rest);\n const {\n slides,\n slots\n } = getChildren(children);\n\n const onBeforeBreakpoint = () => {\n setBreakpointChanged(!breakpointChanged);\n };\n\n Object.assign(swiperParams.on, {\n _containerClasses(swiper, classes) {\n setContainerClasses(classes);\n }\n\n });\n\n const initSwiper = () => {\n // init swiper\n Object.assign(swiperParams.on, events);\n eventsAssigned = true;\n swiperRef.current = new SwiperCore(swiperParams);\n\n swiperRef.current.loopCreate = () => {};\n\n swiperRef.current.loopDestroy = () => {};\n\n if (swiperParams.loop) {\n swiperRef.current.loopedSlides = calcLoopedSlides(slides, swiperParams);\n }\n\n if (swiperRef.current.virtual && swiperRef.current.params.virtual.enabled) {\n swiperRef.current.virtual.slides = slides;\n const extendWith = {\n cache: false,\n slides,\n renderExternal: setVirtualData,\n renderExternalUpdate: false\n };\n extend(swiperRef.current.params.virtual, extendWith);\n extend(swiperRef.current.originalParams.virtual, extendWith);\n }\n };\n\n if (!swiperElRef.current) {\n initSwiper();\n } // Listen for breakpoints change\n\n\n if (swiperRef.current) {\n swiperRef.current.on('_beforeBreakpoint', onBeforeBreakpoint);\n }\n\n const attachEvents = () => {\n if (eventsAssigned || !events || !swiperRef.current) return;\n Object.keys(events).forEach(eventName => {\n swiperRef.current.on(eventName, events[eventName]);\n });\n };\n\n const detachEvents = () => {\n if (!events || !swiperRef.current) return;\n Object.keys(events).forEach(eventName => {\n swiperRef.current.off(eventName, events[eventName]);\n });\n };\n\n useEffect(() => {\n return () => {\n if (swiperRef.current) swiperRef.current.off('_beforeBreakpoint', onBeforeBreakpoint);\n };\n }); // set initialized flag\n\n useEffect(() => {\n if (!initializedRef.current && swiperRef.current) {\n swiperRef.current.emitSlidesClasses();\n initializedRef.current = true;\n }\n }); // mount swiper\n\n useIsomorphicLayoutEffect(() => {\n if (externalElRef) {\n externalElRef.current = swiperElRef.current;\n }\n\n if (!swiperElRef.current) return;\n\n if (swiperRef.current.destroyed) {\n initSwiper();\n }\n\n mountSwiper({\n el: swiperElRef.current,\n nextEl: nextElRef.current,\n prevEl: prevElRef.current,\n paginationEl: paginationElRef.current,\n scrollbarEl: scrollbarElRef.current,\n swiper: swiperRef.current\n }, swiperParams);\n if (onSwiper) onSwiper(swiperRef.current); // eslint-disable-next-line\n\n return () => {\n if (swiperRef.current && !swiperRef.current.destroyed) {\n swiperRef.current.destroy(true, false);\n }\n };\n }, []); // watch for params change\n\n useIsomorphicLayoutEffect(() => {\n attachEvents();\n const changedParams = getChangedParams(passedParams, oldPassedParamsRef.current, slides, oldSlides.current, c => c.key);\n oldPassedParamsRef.current = passedParams;\n oldSlides.current = slides;\n\n if (changedParams.length && swiperRef.current && !swiperRef.current.destroyed) {\n updateSwiper({\n swiper: swiperRef.current,\n slides,\n passedParams,\n changedParams,\n nextEl: nextElRef.current,\n prevEl: prevElRef.current,\n scrollbarEl: scrollbarElRef.current,\n paginationEl: paginationElRef.current\n });\n }\n\n return () => {\n detachEvents();\n };\n }); // update on virtual update\n\n useIsomorphicLayoutEffect(() => {\n updateOnVirtualData(swiperRef.current);\n }, [virtualData]); // bypass swiper instance to slides\n\n function renderSlides() {\n if (swiperParams.virtual) {\n return renderVirtual(swiperRef.current, slides, virtualData);\n }\n\n if (!swiperParams.loop || swiperRef.current && swiperRef.current.destroyed) {\n return slides.map(child => {\n return /*#__PURE__*/React.cloneElement(child, {\n swiper: swiperRef.current\n });\n });\n }\n\n return renderLoop(swiperRef.current, slides, swiperParams);\n }\n\n return /*#__PURE__*/React.createElement(Tag, _extends({\n ref: swiperElRef,\n className: uniqueClasses(`${containerClasses}${className ? ` ${className}` : ''}`)\n }, restProps), /*#__PURE__*/React.createElement(SwiperContext.Provider, {\n value: swiperRef.current\n }, slots['container-start'], /*#__PURE__*/React.createElement(WrapperTag, {\n className: \"swiper-wrapper\"\n }, slots['wrapper-start'], renderSlides(), slots['wrapper-end']), needsNavigation(swiperParams) && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(\"div\", {\n ref: prevElRef,\n className: \"swiper-button-prev\"\n }), /*#__PURE__*/React.createElement(\"div\", {\n ref: nextElRef,\n className: \"swiper-button-next\"\n })), needsScrollbar(swiperParams) && /*#__PURE__*/React.createElement(\"div\", {\n ref: scrollbarElRef,\n className: \"swiper-scrollbar\"\n }), needsPagination(swiperParams) && /*#__PURE__*/React.createElement(\"div\", {\n ref: paginationElRef,\n className: \"swiper-pagination\"\n }), slots['container-end']));\n});\nSwiper.displayName = 'Swiper';\nexport { Swiper };","import Swiper from 'swiper';\nimport { isObject, extend } from './utils.js';\nimport { paramsList } from './params-list.js';\n\nfunction getParams(obj = {}, splitEvents = true) {\n const params = {\n on: {}\n };\n const events = {};\n const passedParams = {};\n extend(params, Swiper.defaults);\n extend(params, Swiper.extendedDefaults);\n params._emitClasses = true;\n params.init = false;\n const rest = {};\n const allowedParams = paramsList.map(key => key.replace(/_/, ''));\n const plainObj = Object.assign({}, obj);\n Object.keys(plainObj).forEach(key => {\n if (typeof obj[key] === 'undefined') return;\n\n if (allowedParams.indexOf(key) >= 0) {\n if (isObject(obj[key])) {\n params[key] = {};\n passedParams[key] = {};\n extend(params[key], obj[key]);\n extend(passedParams[key], obj[key]);\n } else {\n params[key] = obj[key];\n passedParams[key] = obj[key];\n }\n } else if (key.search(/on[A-Z]/) === 0 && typeof obj[key] === 'function') {\n if (splitEvents) {\n events[`${key[2].toLowerCase()}${key.substr(3)}`] = obj[key];\n } else {\n params.on[`${key[2].toLowerCase()}${key.substr(3)}`] = obj[key];\n }\n } else {\n rest[key] = obj[key];\n }\n });\n ['navigation', 'pagination', 'scrollbar'].forEach(key => {\n if (params[key] === true) params[key] = {};\n if (params[key] === false) delete params[key];\n });\n return {\n params,\n passedParams,\n rest,\n events\n };\n}\n\nexport { getParams };","import { needsNavigation, needsPagination, needsScrollbar } from './utils.js';\n\nfunction mountSwiper({\n el,\n nextEl,\n prevEl,\n paginationEl,\n scrollbarEl,\n swiper\n}, swiperParams) {\n if (needsNavigation(swiperParams) && nextEl && prevEl) {\n swiper.params.navigation.nextEl = nextEl;\n swiper.originalParams.navigation.nextEl = nextEl;\n swiper.params.navigation.prevEl = prevEl;\n swiper.originalParams.navigation.prevEl = prevEl;\n }\n\n if (needsPagination(swiperParams) && paginationEl) {\n swiper.params.pagination.el = paginationEl;\n swiper.originalParams.pagination.el = paginationEl;\n }\n\n if (needsScrollbar(swiperParams) && scrollbarEl) {\n swiper.params.scrollbar.el = scrollbarEl;\n swiper.originalParams.scrollbar.el = scrollbarEl;\n }\n\n swiper.init(el);\n}\n\nexport { mountSwiper };","import { paramsList } from './params-list.js';\nimport { isObject } from './utils.js';\n\nfunction getChangedParams(swiperParams, oldParams, children, oldChildren, getKey) {\n const keys = [];\n if (!oldParams) return keys;\n\n const addKey = key => {\n if (keys.indexOf(key) < 0) keys.push(key);\n };\n\n if (children && oldChildren) {\n const oldChildrenKeys = oldChildren.map(getKey);\n const childrenKeys = children.map(getKey);\n if (oldChildrenKeys.join('') !== childrenKeys.join('')) addKey('children');\n if (oldChildren.length !== children.length) addKey('children');\n }\n\n const watchParams = paramsList.filter(key => key[0] === '_').map(key => key.replace(/_/, ''));\n watchParams.forEach(key => {\n if (key in swiperParams && key in oldParams) {\n if (isObject(swiperParams[key]) && isObject(oldParams[key])) {\n const newKeys = Object.keys(swiperParams[key]);\n const oldKeys = Object.keys(oldParams[key]);\n\n if (newKeys.length !== oldKeys.length) {\n addKey(key);\n } else {\n newKeys.forEach(newKey => {\n if (swiperParams[key][newKey] !== oldParams[key][newKey]) {\n addKey(key);\n }\n });\n oldKeys.forEach(oldKey => {\n if (swiperParams[key][oldKey] !== oldParams[key][oldKey]) addKey(key);\n });\n }\n } else if (swiperParams[key] !== oldParams[key]) {\n addKey(key);\n }\n }\n });\n return keys;\n}\n\nexport { getChangedParams };","export const updateOnVirtualData = swiper => {\n if (!swiper || swiper.destroyed || !swiper.params.virtual || swiper.params.virtual && !swiper.params.virtual.enabled) return;\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n if (swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n\n if (swiper.parallax && swiper.params.parallax && swiper.params.parallax.enabled) {\n swiper.parallax.setTranslate();\n }\n};","import React from 'react';\n\nfunction renderVirtual(swiper, slides, virtualData) {\n if (!virtualData) return null;\n const style = swiper.isHorizontal() ? {\n [swiper.rtlTranslate ? 'right' : 'left']: `${virtualData.offset}px`\n } : {\n top: `${virtualData.offset}px`\n };\n return slides.filter((child, index) => index >= virtualData.from && index <= virtualData.to).map(child => {\n return /*#__PURE__*/React.cloneElement(child, {\n swiper,\n style\n });\n });\n}\n\nexport { renderVirtual };","import React from 'react';\nimport { calcLoopedSlides } from '../shared/calc-looped-slides.js';\n\nfunction renderLoop(swiper, slides, swiperParams) {\n const modifiedSlides = slides.map((child, index) => {\n return /*#__PURE__*/React.cloneElement(child, {\n swiper,\n 'data-swiper-slide-index': index\n });\n });\n\n function duplicateSlide(child, index, position) {\n return /*#__PURE__*/React.cloneElement(child, {\n key: `${child.key}-duplicate-${index}-${position}`,\n className: `${child.props.className || ''} ${swiperParams.slideDuplicateClass}`\n });\n }\n\n if (swiperParams.loopFillGroupWithBlank) {\n const blankSlidesNum = swiperParams.slidesPerGroup - modifiedSlides.length % swiperParams.slidesPerGroup;\n\n if (blankSlidesNum !== swiperParams.slidesPerGroup) {\n for (let i = 0; i < blankSlidesNum; i += 1) {\n const blankSlide = /*#__PURE__*/React.createElement(\"div\", {\n className: `${swiperParams.slideClass} ${swiperParams.slideBlankClass}`\n });\n modifiedSlides.push(blankSlide);\n }\n }\n }\n\n if (swiperParams.slidesPerView === 'auto' && !swiperParams.loopedSlides) {\n swiperParams.loopedSlides = modifiedSlides.length;\n }\n\n const loopedSlides = calcLoopedSlides(modifiedSlides, swiperParams);\n const prependSlides = [];\n const appendSlides = [];\n\n for (let i = 0; i < loopedSlides; i += 1) {\n const index = i - Math.floor(i / modifiedSlides.length) * modifiedSlides.length;\n appendSlides.push(duplicateSlide(modifiedSlides[index], i, 'append'));\n prependSlides.unshift(duplicateSlide(modifiedSlides[modifiedSlides.length - index - 1], i, 'prepend'));\n }\n\n if (swiper) {\n swiper.loopedSlides = loopedSlides;\n }\n\n return [...prependSlides, ...modifiedSlides, ...appendSlides];\n}\n\nexport { calcLoopedSlides, renderLoop };","function _extends() { _extends = Object.assign ? Object.assign.bind() : 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; }; return _extends.apply(this, arguments); }\n\nimport React, { useRef, useState, forwardRef } from 'react';\nimport { uniqueClasses } from '../components-shared/utils.js';\nimport { useIsomorphicLayoutEffect } from './use-isomorphic-layout-effect.js';\nimport { SwiperSlideContext } from './context.js';\nconst SwiperSlide = /*#__PURE__*/forwardRef(function (_temp, externalRef) {\n let {\n tag: Tag = 'div',\n children,\n className = '',\n swiper,\n zoom,\n virtualIndex,\n ...rest\n } = _temp === void 0 ? {} : _temp;\n const slideElRef = useRef(null);\n const [slideClasses, setSlideClasses] = useState('swiper-slide');\n\n function updateClasses(_s, el, classNames) {\n if (el === slideElRef.current) {\n setSlideClasses(classNames);\n }\n }\n\n useIsomorphicLayoutEffect(() => {\n if (externalRef) {\n externalRef.current = slideElRef.current;\n }\n\n if (!slideElRef.current || !swiper) {\n return;\n }\n\n if (swiper.destroyed) {\n if (slideClasses !== 'swiper-slide') {\n setSlideClasses('swiper-slide');\n }\n\n return;\n }\n\n swiper.on('_slideClass', updateClasses); // eslint-disable-next-line\n\n return () => {\n if (!swiper) return;\n swiper.off('_slideClass', updateClasses);\n };\n });\n useIsomorphicLayoutEffect(() => {\n if (swiper && slideElRef.current && !swiper.destroyed) {\n setSlideClasses(swiper.getSlideClasses(slideElRef.current));\n }\n }, [swiper]);\n const slideData = {\n isActive: slideClasses.indexOf('swiper-slide-active') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-active') >= 0,\n isVisible: slideClasses.indexOf('swiper-slide-visible') >= 0,\n isDuplicate: slideClasses.indexOf('swiper-slide-duplicate') >= 0,\n isPrev: slideClasses.indexOf('swiper-slide-prev') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-prev') >= 0,\n isNext: slideClasses.indexOf('swiper-slide-next') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-next') >= 0\n };\n\n const renderChildren = () => {\n return typeof children === 'function' ? children(slideData) : children;\n };\n\n return /*#__PURE__*/React.createElement(Tag, _extends({\n ref: slideElRef,\n className: uniqueClasses(`${slideClasses}${className ? ` ${className}` : ''}`),\n \"data-swiper-slide-index\": virtualIndex\n }, rest), /*#__PURE__*/React.createElement(SwiperSlideContext.Provider, {\n value: slideData\n }, zoom ? /*#__PURE__*/React.createElement(\"div\", {\n className: \"swiper-zoom-container\",\n \"data-swiper-zoom\": typeof zoom === 'number' ? zoom : undefined\n }, renderChildren()) : renderChildren()));\n});\nSwiperSlide.displayName = 'SwiperSlide';\nexport { SwiperSlide };","import \"../Kiosk.css\";\ninterface IProps {\n focused: boolean;\n}\n\nexport const DeleteButton: React.FC = ({ focused }) => {\n const specificButtonClass = focused ? \"deleteSelected\" : \"buttonUnselected\";\n\n return (\n
\n \n

Delete Game

\n
\n )\n}\n","import { HighScore } from \"../Models/HighScore\";\n\ninterface IProps {\n highScores: HighScore[];\n highScoreMode: string;\n }\n\nconst HighScoresList: React.FC = ({ highScores, highScoreMode }) => {\n const highScoresExist = !!highScores.length;\n\n if (highScoreMode === \"None\") {\n return null;\n }\n\n return (\n
\n

High Scores

\n {\n !highScoresExist && \n

None yet

\n }\n {\n highScoresExist &&\n
    \n {\n highScores.slice(0, 5).map((highScore, index) => {\n return (\n
  1. \n {highScore.initials}\n {highScore.score}\n
  2. \n ) \n }\n\n )\n }\n
\n }\n\n
\n );\n}\n \nexport default HighScoresList;","import { useEffect, useState } from \"react\";\nimport { GameData } from \"../Models/GameData\";\nimport { HighScore } from \"../Models/HighScore\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport { DeleteButton } from \"./DeleteButton\";\nimport HighScoresList from \"./HighScoresList\";\ninterface IProps {\n highScores: HighScore[];\n addButtonSelected: boolean;\n deleteButtonSelected: boolean;\n game: GameData;\n}\nconst GameSlide: React.FC = (\n { highScores,\n addButtonSelected,\n deleteButtonSelected,\n game,\n }) => {\n const buttonSelected = addButtonSelected || deleteButtonSelected;\n const carouselSelected = buttonSelected ? \"unselected\" : \"selected\";\n\n return (\n
\n
\n\n

Press A to Start

\n\n
\n
{game.name}
\n
{game.description}
\n \n {\n game.date &&\n
\n Added {game.date}\n
\n }\n { game.userAdded &&\n \n }\n
\n
\n )\n}\n\nexport default GameSlide;\n","import React, { useEffect, useRef, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport { KioskState } from \"../Models/KioskState\";\nimport configData from \"../config.json\"\nimport \"../Kiosk.css\";\nimport { Swiper, SwiperSlide } from 'swiper/react';\nimport { EffectCoverflow, Keyboard, Navigation, Pagination } from \"swiper\";\nimport \"swiper/css\";\nimport \"swiper/css/keyboard\";\nimport GameSlide from \"./GameSlide\";\nimport { tickEvent } from \"../browserUtils\";\ninterface IProps {\n kiosk: Kiosk;\n addButtonSelected: boolean;\n deleteButtonSelected: boolean;\n }\n\n\nconst GameList: React.FC = ({ kiosk, addButtonSelected, deleteButtonSelected }) => {\n const [games, setGames] = useState(kiosk.games);\n const buttonSelected = addButtonSelected || deleteButtonSelected;\n const localSwiper = useRef();\n\n const leftKeyEvent = (eventType: string) => {\n return new KeyboardEvent(eventType, {\n \"key\": \"ArrowLeft\",\n \"code\": \"ArrowLeft\",\n \"composed\": true,\n \"keyCode\": 37,\n \"cancelable\": true,\n \"view\": window\n });\n }\n\n const rightKeyEvent = (eventType: string) => {\n return new KeyboardEvent(eventType, {\n \"key\": \"ArrowRight\",\n \"code\": \"ArrowRight\",\n \"composed\": true,\n \"keyCode\": 39,\n \"cancelable\": true,\n \"view\": window\n });\n }\n\n const getGameIndex = () => {\n let gameIndex = (localSwiper.current.activeIndex - 2) % games.length;\n if (gameIndex < 0) {\n gameIndex = games.length - 1;\n }\n return gameIndex;\n }\n\n const changeFocusedItem = () => {\n const gameIndex = getGameIndex();\n kiosk.selectGame(gameIndex);\n }\n\n const clickItem = () => {\n const localSwiperIndex = getGameIndex();\n if (localSwiperIndex !== kiosk.selectedGameIndex) {\n kiosk.selectGame(localSwiperIndex);\n }\n\n const gameId = kiosk.selectedGame?.id;\n if (gameId) {\n tickEvent(\"kiosk.gameLaunched\", { game: gameId });\n kiosk.launchGame(gameId);\n }\n }\n \n const updateLoop = () => {\n if (kiosk.state !== KioskState.MainMenu) {\n return;\n }\n\n if (kiosk.gamepadManager.isAButtonPressed()) {\n clickItem();\n }\n\n if (kiosk.gamepadManager.isLeftPressed()) {\n document.dispatchEvent(leftKeyEvent(\"keydown\"));\n document.dispatchEvent(leftKeyEvent(\"keyup\"));\n changeFocusedItem();\n }\n\n if (kiosk.gamepadManager.isRightPressed()) {\n document.dispatchEvent(rightKeyEvent(\"keydown\"));\n document.dispatchEvent(rightKeyEvent(\"keyup\"));\n changeFocusedItem();\n }\n }\n\n // on page load use effect\n useEffect(() => {\n kiosk.initialize().then(() => {\n setGames(kiosk.games);\n\n if (!kiosk.selectedGame && kiosk.games.length) {\n kiosk.selectGame(0);\n }\n\n if (kiosk.selectedGameIndex) {\n localSwiper.current.slideTo(kiosk.selectedGameIndex + 2);\n }\n })\n }, []);\n\n // poll for game pad input\n useEffect(() => {\n let intervalId: any = null;\n if (games.length) {\n intervalId = setInterval(() => {\n if (!buttonSelected) {\n updateLoop();\n }\n }, configData.GamepadPollLoopMilli);\n }\n \n return () => {\n if (intervalId) {\n clearInterval(intervalId);\n }\n };\n }, [games, buttonSelected]);\n\n if (!kiosk.games || !kiosk.games.length) {\n return(\n
\n

Currently no kiosk games

\n
);\n }\n\n return(\n
\n {\n localSwiper.current = swiper;\n }}\n coverflowEffect={{\n scale: 0.75,\n depth: 5,\n }}\n allowTouchMove={false}\n allowSlideNext={!buttonSelected}\n allowSlidePrev={!buttonSelected}\n modules={[EffectCoverflow, Keyboard, Pagination]}\n keyboard={{enabled: true}}\n >\n {kiosk.games.map((game, index) => {\n const gameHighScores = kiosk.getHighScores(game.id);\n return (\n \n \n \n )\n })}\n \n
\n )\n}\n \nexport default GameList;","import { useEffect, useState } from \"react\";\nimport { tickEvent } from \"../browserUtils\";\nimport \"../Kiosk.css\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport configData from \"../config.json\";\n\ninterface IProps {\n kiosk: Kiosk;\n active: (p: boolean) => void;\n changeFocus: (p: boolean) => void;\n}\nconst DeletionModal: React.FC = ({ kiosk, active, changeFocus }) => {\n const [cancelButtonState, setCancelButtonState] = useState(true);\n const [confirmButtonState, setConfirmButtonState] = useState(false);\n const addedGamesLocalStorageKey: string = \"UserAddedGames\";\n\n const deleteGame = () => {\n const userAddedGames = kiosk.getAllAddedGames();\n const gameId = kiosk.selectedGame?.id!;\n if (gameId in userAddedGames) {\n userAddedGames[gameId].deleted = true;\n localStorage.setItem(addedGamesLocalStorageKey, JSON.stringify(userAddedGames));\n kiosk.games.splice(kiosk.selectedGameIndex!, 1);\n }\n }\n\n const cancelClicked = () => {\n active(false);\n changeFocus(false);\n }\n\n const confirmClicked = () => {\n deleteGame();\n cancelClicked();\n }\n\n const updateLoop = () => {\n if (kiosk.gamepadManager.isLeftPressed()) {\n setCancelButtonState(true);\n setConfirmButtonState(false);\n\n }\n if (kiosk.gamepadManager.isRightPressed()) {\n setCancelButtonState(false);\n setConfirmButtonState(true);\n\n }\n if (cancelButtonState && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.deleteGame.cancelled\");\n cancelClicked();\n }\n\n if (confirmButtonState && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.deleteGame.confirmed\");\n confirmClicked();\n }\n }\n\n useEffect(() => {\n let intervalId: any = null;\n\n intervalId = setInterval(() => {\n updateLoop();\n }, configData.GamepadPollLoopMilli);\n\n return () => {\n if (intervalId) {\n clearInterval(intervalId);\n }\n };\n });\n\n return (\n
\n
\n
\n
\n Delete the Game\n
\n
\n

\n Delete the game? The only way to get the game back\n is by re-uploading it.\n

\n
\n
\n \n \n
\n
\n
\n
\n )\n}\n\nexport default DeletionModal;","import { useEffect, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport AddGameButton from \"./AddGameButton\";\nimport GameList from \"./GameList\";\nimport configData from \"../config.json\"\nimport HighScoresList from \"./HighScoresList\";\nimport { DeleteButton } from \"./DeleteButton\";\nimport { tickEvent } from \"../browserUtils\";\nimport DeletionModal from \"./DeletionModal\";\n\ninterface IProps {\n kiosk: Kiosk\n }\n\nconst MainMenu: React.FC = ({ kiosk }) => {\n const [addButtonSelected, setAddButtonState] = useState(false);\n const [deleteButtonSelected, setDeleteButtonState] = useState(false);\n const [deleteTriggered, setDeleteTriggered] = useState(false);\n const lockedClassName = kiosk.locked ? \" locked\" : \"\";\n\n const updateLoop = () => {\n if (!addButtonSelected && kiosk.gamepadManager.isUpPressed()) {\n setAddButtonState(true);\n }\n if (addButtonSelected && kiosk.gamepadManager.isDownPressed()) {\n setAddButtonState(false);\n }\n if (!addButtonSelected && kiosk.selectedGame?.userAdded && kiosk.gamepadManager.isDownPressed()) {\n setDeleteButtonState(true);\n }\n if (deleteButtonSelected && kiosk.gamepadManager.isUpPressed()) {\n setAddButtonState(false);\n setDeleteButtonState(false);\n }\n if (addButtonSelected && (kiosk.gamepadManager.isAButtonPressed() || kiosk.gamepadManager.isBButtonPressed())) {\n tickEvent(\"kiosk.addGamePageLoaded\");\n kiosk.launchAddGame();\n }\n if (deleteButtonSelected && (kiosk.gamepadManager.isAButtonPressed() || kiosk.gamepadManager.isBButtonPressed())) {\n setDeleteTriggered(true);\n }\n }\n\n useEffect(() => {\n if (!kiosk.locked) {\n let intervalId: any = null;\n intervalId = setInterval(() => {\n if (!deleteTriggered) {\n updateLoop();\n }\n }, configData.GamepadPollLoopMilli);\n \n return () => {\n if (intervalId) {\n clearInterval(intervalId);\n }\n };\n } else {\n tickEvent(\"kiosk.locked\");\n }\n });\n\n return(\n
\n \n \n {\n deleteTriggered &&\n \n }\n\n
\n )\n}\n \nexport default MainMenu;","import { useEffect, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport configData from \"../config.json\"\nimport { tickEvent } from \"../browserUtils\";\n\ninterface IProps {\n kiosk: Kiosk,\n isSelected: boolean,\n onCharacterChanged: (initial: string) => void\n }\n\nconst HighScoreInitial: React.FC = ({ kiosk, isSelected, onCharacterChanged }) => {\n const [index, setIndex] = useState(0);\n\n const getPreviousIndex = () => (index + configData.HighScoreInitialAllowedCharacters.length - 1) % configData.HighScoreInitialAllowedCharacters.length;\n const getNextIndex = () => (index + 1) % configData.HighScoreInitialAllowedCharacters.length;\n\n const previousInitial = () => {\n const newIndex = getPreviousIndex();\n setIndex(newIndex);\n onCharacterChanged(configData.HighScoreInitialAllowedCharacters[newIndex]);\n }\n\n const nextInitial = () => {\n const newIndex = getNextIndex();\n setIndex(newIndex);\n onCharacterChanged(configData.HighScoreInitialAllowedCharacters[newIndex]);\n }\n\n useEffect(() => {\n const gamepadLoop = () => {\n if (!isSelected) { return; }\n\n if (kiosk.gamepadManager.isUpPressed()) {\n tickEvent(\"kiosk.newHighScore.upPressed\");\n previousInitial();\n }\n\n if (kiosk.gamepadManager.isDownPressed()) {\n tickEvent(\"kiosk.newHighScore.downPressed\");\n nextInitial();\n }\n };\n\n const interval = setInterval(() => gamepadLoop(), configData.GamepadPollLoopMilli);\n return () => clearInterval(interval);\n });\n\n const classNames = [\n \"highScoreInitialControl\",\n \"highScoreInitial\",\n isSelected ? \"highScoreInitialControlSelected\" : \"\"]\n\n return(\n
\n
{configData.HighScoreInitialAllowedCharacters[index]}
\n
\n )\n}\n \nexport default HighScoreInitial;","import { useEffect, useState } from \"react\";\nimport { HighScore } from \"../Models/HighScore\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport { KioskState } from \"../Models/KioskState\";\nimport HighScoreInitial from \"./HighScoreInitial\";\nimport configData from \"../config.json\"\nimport { tickEvent } from \"../browserUtils\";\n\ninterface IProps {\n kiosk: Kiosk\n }\n\nconst NewScoreEntry: React.FC = ({ kiosk }) => {\n const [indexChanged, setIndexChanged] = useState(false);\n const [nextIndex, setNextIndex] = useState(false);\n const [previousIndex, setPreviousIndex] = useState(false);\n\n const [initials, setInitials] = useState(Array(configData.HighScoreInitialsLength + 1).join(configData.HighScoreInitialAllowedCharacters[0]));\n const [timesAPressed, setTimesAPressed] = useState(0);\n const [runOnce, setRunOnce] = useState(false);\n const [firstRun, setFirstRun] = useState(true);\n\n const gamepadLoop = () => {\n if (kiosk.state !== KioskState.EnterHighScore) { return; }\n\n if (kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.newHighScore.nextInitial\");\n setIndexChanged(true);\n setNextIndex(true);\n } \n\n else if (kiosk.gamepadManager.isBButtonPressed()) {\n tickEvent(\"kiosk.newHighScore.prevInitial\");\n setIndexChanged(true);\n setPreviousIndex(true);\n } \n else {\n setIndexChanged(false);\n setPreviousIndex(false);\n setNextIndex(false);\n\n }\n\n if (kiosk.gamepadManager.isEscapeButtonPressed()) {\n tickEvent(\"kiosk.newHighScore.defaultInitialsUsed\");\n kiosk.saveHighScore(kiosk.selectedGame!.id, initials, kiosk.mostRecentScores[0]);\n kiosk.navigate(KioskState.GameOver);\n }\n };\n\n useEffect(() => {\n let interval: any;\n let timeout: any;\n timeout = setTimeout(() => {\n interval = setInterval(() =>\n gamepadLoop(),\n configData.EnterHighScorePoll\n )\n }, configData.EnterHighScoreDelayMilli)\n\n\n return () => {\n if (interval) {\n clearInterval(interval);\n }\n if (timeout) {\n clearTimeout(timeout);\n }\n }\n }, []);\n\n const decrementTimesPressed = () => {\n if (timesAPressed === 0) {\n return 0;\n } else {\n setTimesAPressed(timesAPressed - 1);\n return timesAPressed - 1;\n }\n }\n\n const updateTimesPressed = () => {\n if (runOnce) {\n setRunOnce(false);\n return timesAPressed;\n }\n else if (firstRun) {\n setFirstRun(false);\n return timesAPressed;\n }\n else {\n setRunOnce(true);\n if (nextIndex) {\n setTimesAPressed(timesAPressed + 1);\n return timesAPressed + 1;\n } \n else if (previousIndex) {\n return decrementTimesPressed();\n } else {\n return timesAPressed;\n }\n }\n }\n\n useEffect(() => {\n const updatedPressed = updateTimesPressed();\n\n\n if (updatedPressed >= 3) {\n setTimesAPressed(0);\n tickEvent(\"kiosk.newHighScore.initialsEntered\");\n kiosk.saveHighScore(kiosk.selectedGame!.id, initials, kiosk.mostRecentScores[0]);\n kiosk.navigate(KioskState.GameOver);\n }\n\n }, [indexChanged]);\n\n\n const updateInitial = (i: number, character: string) => {\n const newInitials = `${initials.substring(0, i)}${character}${initials.substring(i + 1)}`;\n setInitials(newInitials);\n }\n\n const renderInitials = (): JSX.Element[] => {\n const elements = [];\n\n for (let lcv = 0; lcv < configData.HighScoreInitialsLength; lcv++) {\n const thisIndex = lcv;\n elements.push(\n updateInitial(thisIndex, character[0])} />\n );\n }\n\n return elements;\n }\n\n return (\n \n {renderInitials()}\n {kiosk.mostRecentScores[0]}\n \n\n )\n}\n\nexport default NewScoreEntry;","interface IProps {\n highScoreInitials: string;\n highScoreScore: number;\n}\n\nconst ExistingScoreEntry: React.FC = ({ highScoreInitials, highScoreScore }) => {\n return (\n
  • \n {highScoreInitials}\n {highScoreScore}\n
  • \n )\n}\n\nexport default ExistingScoreEntry;","import { Kiosk } from \"../Models/Kiosk\";\nimport NewScoreEntry from \"./NewScoreEntry\";\nimport ExistingScoreEntry from \"./ExistingScoreEntry\";\nimport { useEffect } from \"react\";\n\ninterface IProps {\n kiosk: Kiosk\n }\n\nconst EnterHighScore: React.FC = ({ kiosk }) => {\n const existingHighScores = kiosk.getHighScores(kiosk.selectedGame!.id);\n\n useEffect(() => {\n if (!kiosk.mostRecentScores || !kiosk.mostRecentScores.length) {\n throw new Error(\"Cannot load high score entry view without having recent scores\");\n }\n }, []);\n\n const aboveScores = existingHighScores.filter(item => item.score > kiosk.mostRecentScores[0]);\n const belowScores = existingHighScores.slice(aboveScores.length, existingHighScores.length);\n\n return(\n
    \n
    \n

    YOU GOT A HIGH SCORE!

    \n

    Enter your initials

    \n
    \n
    \n
    \n
      \n {\n aboveScores.map((highScore, i) =>\n \n )\n }\n
    1. \n {\n belowScores.map((highScore, i) =>\n \n )\n }\n
    \n
    \n\n
    \n
      \n
    • Use up/down to scroll through the alphabet
    • \n
    • When you find your initial, press A
    • \n
    \n\n
    \n
    \n
    \n )\n}\n\nexport default EnterHighScore;","import unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nexport default function _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n if (!it) {\n if (Array.isArray(o) || (it = unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n var F = function F() {};\n return {\n s: F,\n n: function n() {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function e(_e) {\n throw _e;\n },\n f: F\n };\n }\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function s() {\n it = it.call(o);\n },\n n: function n() {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function e(_e2) {\n didErr = true;\n err = _e2;\n },\n f: function f() {\n try {\n if (!normalCompletion && it[\"return\"] != null) it[\"return\"]();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n}","var __defProp = Object.defineProperty;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n if (__getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(b)) {\n if (__propIsEnum.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n }\n return a;\n};\nvar __objRest = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\n\n// src/index.tsx\nimport React, { useRef, useEffect, useState } from \"react\";\n\n// src/third-party/qrcodegen/index.ts\n/**\n * @license QR Code generator library (TypeScript)\n * Copyright (c) Project Nayuki.\n * SPDX-License-Identifier: MIT\n */\nvar qrcodegen;\n((qrcodegen2) => {\n const _QrCode = class {\n constructor(version, errorCorrectionLevel, dataCodewords, msk) {\n this.version = version;\n this.errorCorrectionLevel = errorCorrectionLevel;\n this.modules = [];\n this.isFunction = [];\n if (version < _QrCode.MIN_VERSION || version > _QrCode.MAX_VERSION)\n throw new RangeError(\"Version value out of range\");\n if (msk < -1 || msk > 7)\n throw new RangeError(\"Mask value out of range\");\n this.size = version * 4 + 17;\n let row = [];\n for (let i = 0; i < this.size; i++)\n row.push(false);\n for (let i = 0; i < this.size; i++) {\n this.modules.push(row.slice());\n this.isFunction.push(row.slice());\n }\n this.drawFunctionPatterns();\n const allCodewords = this.addEccAndInterleave(dataCodewords);\n this.drawCodewords(allCodewords);\n if (msk == -1) {\n let minPenalty = 1e9;\n for (let i = 0; i < 8; i++) {\n this.applyMask(i);\n this.drawFormatBits(i);\n const penalty = this.getPenaltyScore();\n if (penalty < minPenalty) {\n msk = i;\n minPenalty = penalty;\n }\n this.applyMask(i);\n }\n }\n assert(0 <= msk && msk <= 7);\n this.mask = msk;\n this.applyMask(msk);\n this.drawFormatBits(msk);\n this.isFunction = [];\n }\n static encodeText(text, ecl) {\n const segs = qrcodegen2.QrSegment.makeSegments(text);\n return _QrCode.encodeSegments(segs, ecl);\n }\n static encodeBinary(data, ecl) {\n const seg = qrcodegen2.QrSegment.makeBytes(data);\n return _QrCode.encodeSegments([seg], ecl);\n }\n static encodeSegments(segs, ecl, minVersion = 1, maxVersion = 40, mask = -1, boostEcl = true) {\n if (!(_QrCode.MIN_VERSION <= minVersion && minVersion <= maxVersion && maxVersion <= _QrCode.MAX_VERSION) || mask < -1 || mask > 7)\n throw new RangeError(\"Invalid value\");\n let version;\n let dataUsedBits;\n for (version = minVersion; ; version++) {\n const dataCapacityBits2 = _QrCode.getNumDataCodewords(version, ecl) * 8;\n const usedBits = QrSegment.getTotalBits(segs, version);\n if (usedBits <= dataCapacityBits2) {\n dataUsedBits = usedBits;\n break;\n }\n if (version >= maxVersion)\n throw new RangeError(\"Data too long\");\n }\n for (const newEcl of [_QrCode.Ecc.MEDIUM, _QrCode.Ecc.QUARTILE, _QrCode.Ecc.HIGH]) {\n if (boostEcl && dataUsedBits <= _QrCode.getNumDataCodewords(version, newEcl) * 8)\n ecl = newEcl;\n }\n let bb = [];\n for (const seg of segs) {\n appendBits(seg.mode.modeBits, 4, bb);\n appendBits(seg.numChars, seg.mode.numCharCountBits(version), bb);\n for (const b of seg.getData())\n bb.push(b);\n }\n assert(bb.length == dataUsedBits);\n const dataCapacityBits = _QrCode.getNumDataCodewords(version, ecl) * 8;\n assert(bb.length <= dataCapacityBits);\n appendBits(0, Math.min(4, dataCapacityBits - bb.length), bb);\n appendBits(0, (8 - bb.length % 8) % 8, bb);\n assert(bb.length % 8 == 0);\n for (let padByte = 236; bb.length < dataCapacityBits; padByte ^= 236 ^ 17)\n appendBits(padByte, 8, bb);\n let dataCodewords = [];\n while (dataCodewords.length * 8 < bb.length)\n dataCodewords.push(0);\n bb.forEach((b, i) => dataCodewords[i >>> 3] |= b << 7 - (i & 7));\n return new _QrCode(version, ecl, dataCodewords, mask);\n }\n getModule(x, y) {\n return 0 <= x && x < this.size && 0 <= y && y < this.size && this.modules[y][x];\n }\n getModules() {\n return this.modules;\n }\n drawFunctionPatterns() {\n for (let i = 0; i < this.size; i++) {\n this.setFunctionModule(6, i, i % 2 == 0);\n this.setFunctionModule(i, 6, i % 2 == 0);\n }\n this.drawFinderPattern(3, 3);\n this.drawFinderPattern(this.size - 4, 3);\n this.drawFinderPattern(3, this.size - 4);\n const alignPatPos = this.getAlignmentPatternPositions();\n const numAlign = alignPatPos.length;\n for (let i = 0; i < numAlign; i++) {\n for (let j = 0; j < numAlign; j++) {\n if (!(i == 0 && j == 0 || i == 0 && j == numAlign - 1 || i == numAlign - 1 && j == 0))\n this.drawAlignmentPattern(alignPatPos[i], alignPatPos[j]);\n }\n }\n this.drawFormatBits(0);\n this.drawVersion();\n }\n drawFormatBits(mask) {\n const data = this.errorCorrectionLevel.formatBits << 3 | mask;\n let rem = data;\n for (let i = 0; i < 10; i++)\n rem = rem << 1 ^ (rem >>> 9) * 1335;\n const bits = (data << 10 | rem) ^ 21522;\n assert(bits >>> 15 == 0);\n for (let i = 0; i <= 5; i++)\n this.setFunctionModule(8, i, getBit(bits, i));\n this.setFunctionModule(8, 7, getBit(bits, 6));\n this.setFunctionModule(8, 8, getBit(bits, 7));\n this.setFunctionModule(7, 8, getBit(bits, 8));\n for (let i = 9; i < 15; i++)\n this.setFunctionModule(14 - i, 8, getBit(bits, i));\n for (let i = 0; i < 8; i++)\n this.setFunctionModule(this.size - 1 - i, 8, getBit(bits, i));\n for (let i = 8; i < 15; i++)\n this.setFunctionModule(8, this.size - 15 + i, getBit(bits, i));\n this.setFunctionModule(8, this.size - 8, true);\n }\n drawVersion() {\n if (this.version < 7)\n return;\n let rem = this.version;\n for (let i = 0; i < 12; i++)\n rem = rem << 1 ^ (rem >>> 11) * 7973;\n const bits = this.version << 12 | rem;\n assert(bits >>> 18 == 0);\n for (let i = 0; i < 18; i++) {\n const color = getBit(bits, i);\n const a = this.size - 11 + i % 3;\n const b = Math.floor(i / 3);\n this.setFunctionModule(a, b, color);\n this.setFunctionModule(b, a, color);\n }\n }\n drawFinderPattern(x, y) {\n for (let dy = -4; dy <= 4; dy++) {\n for (let dx = -4; dx <= 4; dx++) {\n const dist = Math.max(Math.abs(dx), Math.abs(dy));\n const xx = x + dx;\n const yy = y + dy;\n if (0 <= xx && xx < this.size && 0 <= yy && yy < this.size)\n this.setFunctionModule(xx, yy, dist != 2 && dist != 4);\n }\n }\n }\n drawAlignmentPattern(x, y) {\n for (let dy = -2; dy <= 2; dy++) {\n for (let dx = -2; dx <= 2; dx++)\n this.setFunctionModule(x + dx, y + dy, Math.max(Math.abs(dx), Math.abs(dy)) != 1);\n }\n }\n setFunctionModule(x, y, isDark) {\n this.modules[y][x] = isDark;\n this.isFunction[y][x] = true;\n }\n addEccAndInterleave(data) {\n const ver = this.version;\n const ecl = this.errorCorrectionLevel;\n if (data.length != _QrCode.getNumDataCodewords(ver, ecl))\n throw new RangeError(\"Invalid argument\");\n const numBlocks = _QrCode.NUM_ERROR_CORRECTION_BLOCKS[ecl.ordinal][ver];\n const blockEccLen = _QrCode.ECC_CODEWORDS_PER_BLOCK[ecl.ordinal][ver];\n const rawCodewords = Math.floor(_QrCode.getNumRawDataModules(ver) / 8);\n const numShortBlocks = numBlocks - rawCodewords % numBlocks;\n const shortBlockLen = Math.floor(rawCodewords / numBlocks);\n let blocks = [];\n const rsDiv = _QrCode.reedSolomonComputeDivisor(blockEccLen);\n for (let i = 0, k = 0; i < numBlocks; i++) {\n let dat = data.slice(k, k + shortBlockLen - blockEccLen + (i < numShortBlocks ? 0 : 1));\n k += dat.length;\n const ecc = _QrCode.reedSolomonComputeRemainder(dat, rsDiv);\n if (i < numShortBlocks)\n dat.push(0);\n blocks.push(dat.concat(ecc));\n }\n let result = [];\n for (let i = 0; i < blocks[0].length; i++) {\n blocks.forEach((block, j) => {\n if (i != shortBlockLen - blockEccLen || j >= numShortBlocks)\n result.push(block[i]);\n });\n }\n assert(result.length == rawCodewords);\n return result;\n }\n drawCodewords(data) {\n if (data.length != Math.floor(_QrCode.getNumRawDataModules(this.version) / 8))\n throw new RangeError(\"Invalid argument\");\n let i = 0;\n for (let right = this.size - 1; right >= 1; right -= 2) {\n if (right == 6)\n right = 5;\n for (let vert = 0; vert < this.size; vert++) {\n for (let j = 0; j < 2; j++) {\n const x = right - j;\n const upward = (right + 1 & 2) == 0;\n const y = upward ? this.size - 1 - vert : vert;\n if (!this.isFunction[y][x] && i < data.length * 8) {\n this.modules[y][x] = getBit(data[i >>> 3], 7 - (i & 7));\n i++;\n }\n }\n }\n }\n assert(i == data.length * 8);\n }\n applyMask(mask) {\n if (mask < 0 || mask > 7)\n throw new RangeError(\"Mask value out of range\");\n for (let y = 0; y < this.size; y++) {\n for (let x = 0; x < this.size; x++) {\n let invert;\n switch (mask) {\n case 0:\n invert = (x + y) % 2 == 0;\n break;\n case 1:\n invert = y % 2 == 0;\n break;\n case 2:\n invert = x % 3 == 0;\n break;\n case 3:\n invert = (x + y) % 3 == 0;\n break;\n case 4:\n invert = (Math.floor(x / 3) + Math.floor(y / 2)) % 2 == 0;\n break;\n case 5:\n invert = x * y % 2 + x * y % 3 == 0;\n break;\n case 6:\n invert = (x * y % 2 + x * y % 3) % 2 == 0;\n break;\n case 7:\n invert = ((x + y) % 2 + x * y % 3) % 2 == 0;\n break;\n default:\n throw new Error(\"Unreachable\");\n }\n if (!this.isFunction[y][x] && invert)\n this.modules[y][x] = !this.modules[y][x];\n }\n }\n }\n getPenaltyScore() {\n let result = 0;\n for (let y = 0; y < this.size; y++) {\n let runColor = false;\n let runX = 0;\n let runHistory = [0, 0, 0, 0, 0, 0, 0];\n for (let x = 0; x < this.size; x++) {\n if (this.modules[y][x] == runColor) {\n runX++;\n if (runX == 5)\n result += _QrCode.PENALTY_N1;\n else if (runX > 5)\n result++;\n } else {\n this.finderPenaltyAddHistory(runX, runHistory);\n if (!runColor)\n result += this.finderPenaltyCountPatterns(runHistory) * _QrCode.PENALTY_N3;\n runColor = this.modules[y][x];\n runX = 1;\n }\n }\n result += this.finderPenaltyTerminateAndCount(runColor, runX, runHistory) * _QrCode.PENALTY_N3;\n }\n for (let x = 0; x < this.size; x++) {\n let runColor = false;\n let runY = 0;\n let runHistory = [0, 0, 0, 0, 0, 0, 0];\n for (let y = 0; y < this.size; y++) {\n if (this.modules[y][x] == runColor) {\n runY++;\n if (runY == 5)\n result += _QrCode.PENALTY_N1;\n else if (runY > 5)\n result++;\n } else {\n this.finderPenaltyAddHistory(runY, runHistory);\n if (!runColor)\n result += this.finderPenaltyCountPatterns(runHistory) * _QrCode.PENALTY_N3;\n runColor = this.modules[y][x];\n runY = 1;\n }\n }\n result += this.finderPenaltyTerminateAndCount(runColor, runY, runHistory) * _QrCode.PENALTY_N3;\n }\n for (let y = 0; y < this.size - 1; y++) {\n for (let x = 0; x < this.size - 1; x++) {\n const color = this.modules[y][x];\n if (color == this.modules[y][x + 1] && color == this.modules[y + 1][x] && color == this.modules[y + 1][x + 1])\n result += _QrCode.PENALTY_N2;\n }\n }\n let dark = 0;\n for (const row of this.modules)\n dark = row.reduce((sum, color) => sum + (color ? 1 : 0), dark);\n const total = this.size * this.size;\n const k = Math.ceil(Math.abs(dark * 20 - total * 10) / total) - 1;\n assert(0 <= k && k <= 9);\n result += k * _QrCode.PENALTY_N4;\n assert(0 <= result && result <= 2568888);\n return result;\n }\n getAlignmentPatternPositions() {\n if (this.version == 1)\n return [];\n else {\n const numAlign = Math.floor(this.version / 7) + 2;\n const step = this.version == 32 ? 26 : Math.ceil((this.version * 4 + 4) / (numAlign * 2 - 2)) * 2;\n let result = [6];\n for (let pos = this.size - 7; result.length < numAlign; pos -= step)\n result.splice(1, 0, pos);\n return result;\n }\n }\n static getNumRawDataModules(ver) {\n if (ver < _QrCode.MIN_VERSION || ver > _QrCode.MAX_VERSION)\n throw new RangeError(\"Version number out of range\");\n let result = (16 * ver + 128) * ver + 64;\n if (ver >= 2) {\n const numAlign = Math.floor(ver / 7) + 2;\n result -= (25 * numAlign - 10) * numAlign - 55;\n if (ver >= 7)\n result -= 36;\n }\n assert(208 <= result && result <= 29648);\n return result;\n }\n static getNumDataCodewords(ver, ecl) {\n return Math.floor(_QrCode.getNumRawDataModules(ver) / 8) - _QrCode.ECC_CODEWORDS_PER_BLOCK[ecl.ordinal][ver] * _QrCode.NUM_ERROR_CORRECTION_BLOCKS[ecl.ordinal][ver];\n }\n static reedSolomonComputeDivisor(degree) {\n if (degree < 1 || degree > 255)\n throw new RangeError(\"Degree out of range\");\n let result = [];\n for (let i = 0; i < degree - 1; i++)\n result.push(0);\n result.push(1);\n let root = 1;\n for (let i = 0; i < degree; i++) {\n for (let j = 0; j < result.length; j++) {\n result[j] = _QrCode.reedSolomonMultiply(result[j], root);\n if (j + 1 < result.length)\n result[j] ^= result[j + 1];\n }\n root = _QrCode.reedSolomonMultiply(root, 2);\n }\n return result;\n }\n static reedSolomonComputeRemainder(data, divisor) {\n let result = divisor.map((_) => 0);\n for (const b of data) {\n const factor = b ^ result.shift();\n result.push(0);\n divisor.forEach((coef, i) => result[i] ^= _QrCode.reedSolomonMultiply(coef, factor));\n }\n return result;\n }\n static reedSolomonMultiply(x, y) {\n if (x >>> 8 != 0 || y >>> 8 != 0)\n throw new RangeError(\"Byte out of range\");\n let z = 0;\n for (let i = 7; i >= 0; i--) {\n z = z << 1 ^ (z >>> 7) * 285;\n z ^= (y >>> i & 1) * x;\n }\n assert(z >>> 8 == 0);\n return z;\n }\n finderPenaltyCountPatterns(runHistory) {\n const n = runHistory[1];\n assert(n <= this.size * 3);\n const core = n > 0 && runHistory[2] == n && runHistory[3] == n * 3 && runHistory[4] == n && runHistory[5] == n;\n return (core && runHistory[0] >= n * 4 && runHistory[6] >= n ? 1 : 0) + (core && runHistory[6] >= n * 4 && runHistory[0] >= n ? 1 : 0);\n }\n finderPenaltyTerminateAndCount(currentRunColor, currentRunLength, runHistory) {\n if (currentRunColor) {\n this.finderPenaltyAddHistory(currentRunLength, runHistory);\n currentRunLength = 0;\n }\n currentRunLength += this.size;\n this.finderPenaltyAddHistory(currentRunLength, runHistory);\n return this.finderPenaltyCountPatterns(runHistory);\n }\n finderPenaltyAddHistory(currentRunLength, runHistory) {\n if (runHistory[0] == 0)\n currentRunLength += this.size;\n runHistory.pop();\n runHistory.unshift(currentRunLength);\n }\n };\n let QrCode = _QrCode;\n QrCode.MIN_VERSION = 1;\n QrCode.MAX_VERSION = 40;\n QrCode.PENALTY_N1 = 3;\n QrCode.PENALTY_N2 = 3;\n QrCode.PENALTY_N3 = 40;\n QrCode.PENALTY_N4 = 10;\n QrCode.ECC_CODEWORDS_PER_BLOCK = [\n [-1, 7, 10, 15, 20, 26, 18, 20, 24, 30, 18, 20, 24, 26, 30, 22, 24, 28, 30, 28, 28, 28, 28, 30, 30, 26, 28, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30],\n [-1, 10, 16, 26, 18, 24, 16, 18, 22, 22, 26, 30, 22, 22, 24, 24, 28, 28, 26, 26, 26, 26, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28],\n [-1, 13, 22, 18, 26, 18, 24, 18, 22, 20, 24, 28, 26, 24, 20, 30, 24, 28, 28, 26, 30, 28, 30, 30, 30, 30, 28, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30],\n [-1, 17, 28, 22, 16, 22, 28, 26, 26, 24, 28, 24, 28, 22, 24, 24, 30, 28, 28, 26, 28, 30, 24, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30]\n ];\n QrCode.NUM_ERROR_CORRECTION_BLOCKS = [\n [-1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 4, 4, 4, 4, 4, 6, 6, 6, 6, 7, 8, 8, 9, 9, 10, 12, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 24, 25],\n [-1, 1, 1, 1, 2, 2, 4, 4, 4, 5, 5, 5, 8, 9, 9, 10, 10, 11, 13, 14, 16, 17, 17, 18, 20, 21, 23, 25, 26, 28, 29, 31, 33, 35, 37, 38, 40, 43, 45, 47, 49],\n [-1, 1, 1, 2, 2, 4, 4, 6, 6, 8, 8, 8, 10, 12, 16, 12, 17, 16, 18, 21, 20, 23, 23, 25, 27, 29, 34, 34, 35, 38, 40, 43, 45, 48, 51, 53, 56, 59, 62, 65, 68],\n [-1, 1, 1, 2, 4, 4, 4, 5, 6, 8, 8, 11, 11, 16, 16, 18, 16, 19, 21, 25, 25, 25, 34, 30, 32, 35, 37, 40, 42, 45, 48, 51, 54, 57, 60, 63, 66, 70, 74, 77, 81]\n ];\n qrcodegen2.QrCode = QrCode;\n function appendBits(val, len, bb) {\n if (len < 0 || len > 31 || val >>> len != 0)\n throw new RangeError(\"Value out of range\");\n for (let i = len - 1; i >= 0; i--)\n bb.push(val >>> i & 1);\n }\n function getBit(x, i) {\n return (x >>> i & 1) != 0;\n }\n function assert(cond) {\n if (!cond)\n throw new Error(\"Assertion error\");\n }\n const _QrSegment = class {\n constructor(mode, numChars, bitData) {\n this.mode = mode;\n this.numChars = numChars;\n this.bitData = bitData;\n if (numChars < 0)\n throw new RangeError(\"Invalid argument\");\n this.bitData = bitData.slice();\n }\n static makeBytes(data) {\n let bb = [];\n for (const b of data)\n appendBits(b, 8, bb);\n return new _QrSegment(_QrSegment.Mode.BYTE, data.length, bb);\n }\n static makeNumeric(digits) {\n if (!_QrSegment.isNumeric(digits))\n throw new RangeError(\"String contains non-numeric characters\");\n let bb = [];\n for (let i = 0; i < digits.length; ) {\n const n = Math.min(digits.length - i, 3);\n appendBits(parseInt(digits.substr(i, n), 10), n * 3 + 1, bb);\n i += n;\n }\n return new _QrSegment(_QrSegment.Mode.NUMERIC, digits.length, bb);\n }\n static makeAlphanumeric(text) {\n if (!_QrSegment.isAlphanumeric(text))\n throw new RangeError(\"String contains unencodable characters in alphanumeric mode\");\n let bb = [];\n let i;\n for (i = 0; i + 2 <= text.length; i += 2) {\n let temp = _QrSegment.ALPHANUMERIC_CHARSET.indexOf(text.charAt(i)) * 45;\n temp += _QrSegment.ALPHANUMERIC_CHARSET.indexOf(text.charAt(i + 1));\n appendBits(temp, 11, bb);\n }\n if (i < text.length)\n appendBits(_QrSegment.ALPHANUMERIC_CHARSET.indexOf(text.charAt(i)), 6, bb);\n return new _QrSegment(_QrSegment.Mode.ALPHANUMERIC, text.length, bb);\n }\n static makeSegments(text) {\n if (text == \"\")\n return [];\n else if (_QrSegment.isNumeric(text))\n return [_QrSegment.makeNumeric(text)];\n else if (_QrSegment.isAlphanumeric(text))\n return [_QrSegment.makeAlphanumeric(text)];\n else\n return [_QrSegment.makeBytes(_QrSegment.toUtf8ByteArray(text))];\n }\n static makeEci(assignVal) {\n let bb = [];\n if (assignVal < 0)\n throw new RangeError(\"ECI assignment value out of range\");\n else if (assignVal < 1 << 7)\n appendBits(assignVal, 8, bb);\n else if (assignVal < 1 << 14) {\n appendBits(2, 2, bb);\n appendBits(assignVal, 14, bb);\n } else if (assignVal < 1e6) {\n appendBits(6, 3, bb);\n appendBits(assignVal, 21, bb);\n } else\n throw new RangeError(\"ECI assignment value out of range\");\n return new _QrSegment(_QrSegment.Mode.ECI, 0, bb);\n }\n static isNumeric(text) {\n return _QrSegment.NUMERIC_REGEX.test(text);\n }\n static isAlphanumeric(text) {\n return _QrSegment.ALPHANUMERIC_REGEX.test(text);\n }\n getData() {\n return this.bitData.slice();\n }\n static getTotalBits(segs, version) {\n let result = 0;\n for (const seg of segs) {\n const ccbits = seg.mode.numCharCountBits(version);\n if (seg.numChars >= 1 << ccbits)\n return Infinity;\n result += 4 + ccbits + seg.bitData.length;\n }\n return result;\n }\n static toUtf8ByteArray(str) {\n str = encodeURI(str);\n let result = [];\n for (let i = 0; i < str.length; i++) {\n if (str.charAt(i) != \"%\")\n result.push(str.charCodeAt(i));\n else {\n result.push(parseInt(str.substr(i + 1, 2), 16));\n i += 2;\n }\n }\n return result;\n }\n };\n let QrSegment = _QrSegment;\n QrSegment.NUMERIC_REGEX = /^[0-9]*$/;\n QrSegment.ALPHANUMERIC_REGEX = /^[A-Z0-9 $%*+.\\/:-]*$/;\n QrSegment.ALPHANUMERIC_CHARSET = \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ $%*+-./:\";\n qrcodegen2.QrSegment = QrSegment;\n})(qrcodegen || (qrcodegen = {}));\n((qrcodegen2) => {\n let QrCode;\n ((QrCode2) => {\n const _Ecc = class {\n constructor(ordinal, formatBits) {\n this.ordinal = ordinal;\n this.formatBits = formatBits;\n }\n };\n let Ecc = _Ecc;\n Ecc.LOW = new _Ecc(0, 1);\n Ecc.MEDIUM = new _Ecc(1, 0);\n Ecc.QUARTILE = new _Ecc(2, 3);\n Ecc.HIGH = new _Ecc(3, 2);\n QrCode2.Ecc = Ecc;\n })(QrCode = qrcodegen2.QrCode || (qrcodegen2.QrCode = {}));\n})(qrcodegen || (qrcodegen = {}));\n((qrcodegen2) => {\n let QrSegment;\n ((QrSegment2) => {\n const _Mode = class {\n constructor(modeBits, numBitsCharCount) {\n this.modeBits = modeBits;\n this.numBitsCharCount = numBitsCharCount;\n }\n numCharCountBits(ver) {\n return this.numBitsCharCount[Math.floor((ver + 7) / 17)];\n }\n };\n let Mode = _Mode;\n Mode.NUMERIC = new _Mode(1, [10, 12, 14]);\n Mode.ALPHANUMERIC = new _Mode(2, [9, 11, 13]);\n Mode.BYTE = new _Mode(4, [8, 16, 16]);\n Mode.KANJI = new _Mode(8, [8, 10, 12]);\n Mode.ECI = new _Mode(7, [0, 0, 0]);\n QrSegment2.Mode = Mode;\n })(QrSegment = qrcodegen2.QrSegment || (qrcodegen2.QrSegment = {}));\n})(qrcodegen || (qrcodegen = {}));\nvar qrcodegen_default = qrcodegen;\n\n// src/index.tsx\n/**\n * @license qrcode.react\n * Copyright (c) Paul O'Shannessy\n * SPDX-License-Identifier: ISC\n */\nvar ERROR_LEVEL_MAP = {\n L: qrcodegen_default.QrCode.Ecc.LOW,\n M: qrcodegen_default.QrCode.Ecc.MEDIUM,\n Q: qrcodegen_default.QrCode.Ecc.QUARTILE,\n H: qrcodegen_default.QrCode.Ecc.HIGH\n};\nvar DEFAULT_SIZE = 128;\nvar DEFAULT_LEVEL = \"L\";\nvar DEFAULT_BGCOLOR = \"#FFFFFF\";\nvar DEFAULT_FGCOLOR = \"#000000\";\nvar DEFAULT_INCLUDEMARGIN = false;\nvar MARGIN_SIZE = 4;\nvar DEFAULT_IMG_SCALE = 0.1;\nfunction generatePath(modules, margin = 0) {\n const ops = [];\n modules.forEach(function(row, y) {\n let start = null;\n row.forEach(function(cell, x) {\n if (!cell && start !== null) {\n ops.push(`M${start + margin} ${y + margin}h${x - start}v1H${start + margin}z`);\n start = null;\n return;\n }\n if (x === row.length - 1) {\n if (!cell) {\n return;\n }\n if (start === null) {\n ops.push(`M${x + margin},${y + margin} h1v1H${x + margin}z`);\n } else {\n ops.push(`M${start + margin},${y + margin} h${x + 1 - start}v1H${start + margin}z`);\n }\n return;\n }\n if (cell && start === null) {\n start = x;\n }\n });\n });\n return ops.join(\"\");\n}\nfunction excavateModules(modules, excavation) {\n return modules.slice().map((row, y) => {\n if (y < excavation.y || y >= excavation.y + excavation.h) {\n return row;\n }\n return row.map((cell, x) => {\n if (x < excavation.x || x >= excavation.x + excavation.w) {\n return cell;\n }\n return false;\n });\n });\n}\nfunction getImageSettings(cells, size, includeMargin, imageSettings) {\n if (imageSettings == null) {\n return null;\n }\n const margin = includeMargin ? MARGIN_SIZE : 0;\n const numCells = cells.length + margin * 2;\n const defaultSize = Math.floor(size * DEFAULT_IMG_SCALE);\n const scale = numCells / size;\n const w = (imageSettings.width || defaultSize) * scale;\n const h = (imageSettings.height || defaultSize) * scale;\n const x = imageSettings.x == null ? cells.length / 2 - w / 2 : imageSettings.x * scale;\n const y = imageSettings.y == null ? cells.length / 2 - h / 2 : imageSettings.y * scale;\n let excavation = null;\n if (imageSettings.excavate) {\n let floorX = Math.floor(x);\n let floorY = Math.floor(y);\n let ceilW = Math.ceil(w + x - floorX);\n let ceilH = Math.ceil(h + y - floorY);\n excavation = { x: floorX, y: floorY, w: ceilW, h: ceilH };\n }\n return { x, y, h, w, excavation };\n}\nvar SUPPORTS_PATH2D = function() {\n try {\n new Path2D().addPath(new Path2D());\n } catch (e) {\n return false;\n }\n return true;\n}();\nfunction QRCodeCanvas(props) {\n const _a = props, {\n value,\n size = DEFAULT_SIZE,\n level = DEFAULT_LEVEL,\n bgColor = DEFAULT_BGCOLOR,\n fgColor = DEFAULT_FGCOLOR,\n includeMargin = DEFAULT_INCLUDEMARGIN,\n style,\n imageSettings\n } = _a, otherProps = __objRest(_a, [\n \"value\",\n \"size\",\n \"level\",\n \"bgColor\",\n \"fgColor\",\n \"includeMargin\",\n \"style\",\n \"imageSettings\"\n ]);\n const imgSrc = imageSettings == null ? void 0 : imageSettings.src;\n const _canvas = useRef(null);\n const _image = useRef(null);\n const [isImgLoaded, setIsImageLoaded] = useState(false);\n useEffect(() => {\n if (_canvas.current != null) {\n const canvas = _canvas.current;\n const ctx = canvas.getContext(\"2d\");\n if (!ctx) {\n return;\n }\n let cells = qrcodegen_default.QrCode.encodeText(value, ERROR_LEVEL_MAP[level]).getModules();\n const margin = includeMargin ? MARGIN_SIZE : 0;\n const numCells = cells.length + margin * 2;\n const calculatedImageSettings = getImageSettings(cells, size, includeMargin, imageSettings);\n const image = _image.current;\n const haveImageToRender = calculatedImageSettings != null && image !== null && image.complete && image.naturalHeight !== 0 && image.naturalWidth !== 0;\n if (haveImageToRender) {\n if (calculatedImageSettings.excavation != null) {\n cells = excavateModules(cells, calculatedImageSettings.excavation);\n }\n }\n const pixelRatio = window.devicePixelRatio || 1;\n canvas.height = canvas.width = size * pixelRatio;\n const scale = size / numCells * pixelRatio;\n ctx.scale(scale, scale);\n ctx.fillStyle = bgColor;\n ctx.fillRect(0, 0, numCells, numCells);\n ctx.fillStyle = fgColor;\n if (SUPPORTS_PATH2D) {\n ctx.fill(new Path2D(generatePath(cells, margin)));\n } else {\n cells.forEach(function(row, rdx) {\n row.forEach(function(cell, cdx) {\n if (cell) {\n ctx.fillRect(cdx + margin, rdx + margin, 1, 1);\n }\n });\n });\n }\n if (haveImageToRender) {\n ctx.drawImage(image, calculatedImageSettings.x + margin, calculatedImageSettings.y + margin, calculatedImageSettings.w, calculatedImageSettings.h);\n }\n }\n });\n useEffect(() => {\n setIsImageLoaded(false);\n }, [imgSrc]);\n const canvasStyle = __spreadValues({ height: size, width: size }, style);\n let img = null;\n if (imgSrc != null) {\n img = /* @__PURE__ */ React.createElement(\"img\", {\n src: imgSrc,\n key: imgSrc,\n style: { display: \"none\" },\n onLoad: () => {\n setIsImageLoaded(true);\n },\n ref: _image\n });\n }\n return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(\"canvas\", __spreadValues({\n style: canvasStyle,\n height: size,\n width: size,\n ref: _canvas\n }, otherProps)), img);\n}\nfunction QRCodeSVG(props) {\n const _a = props, {\n value,\n size = DEFAULT_SIZE,\n level = DEFAULT_LEVEL,\n bgColor = DEFAULT_BGCOLOR,\n fgColor = DEFAULT_FGCOLOR,\n includeMargin = DEFAULT_INCLUDEMARGIN,\n imageSettings\n } = _a, otherProps = __objRest(_a, [\n \"value\",\n \"size\",\n \"level\",\n \"bgColor\",\n \"fgColor\",\n \"includeMargin\",\n \"imageSettings\"\n ]);\n let cells = qrcodegen_default.QrCode.encodeText(value, ERROR_LEVEL_MAP[level]).getModules();\n const margin = includeMargin ? MARGIN_SIZE : 0;\n const numCells = cells.length + margin * 2;\n const calculatedImageSettings = getImageSettings(cells, size, includeMargin, imageSettings);\n let image = null;\n if (imageSettings != null && calculatedImageSettings != null) {\n if (calculatedImageSettings.excavation != null) {\n cells = excavateModules(cells, calculatedImageSettings.excavation);\n }\n image = /* @__PURE__ */ React.createElement(\"image\", {\n xlinkHref: imageSettings.src,\n height: calculatedImageSettings.h,\n width: calculatedImageSettings.w,\n x: calculatedImageSettings.x + margin,\n y: calculatedImageSettings.y + margin,\n preserveAspectRatio: \"none\"\n });\n }\n const fgPath = generatePath(cells, margin);\n return /* @__PURE__ */ React.createElement(\"svg\", __spreadValues({\n height: size,\n width: size,\n viewBox: `0 0 ${numCells} ${numCells}`\n }, otherProps), /* @__PURE__ */ React.createElement(\"path\", {\n fill: bgColor,\n d: `M0,0 h${numCells}v${numCells}H0z`,\n shapeRendering: \"crispEdges\"\n }), /* @__PURE__ */ React.createElement(\"path\", {\n fill: fgColor,\n d: fgPath,\n shapeRendering: \"crispEdges\"\n }), image);\n}\nvar QRCode = (props) => {\n const _a = props, { renderAs } = _a, otherProps = __objRest(_a, [\"renderAs\"]);\n if (renderAs === \"svg\") {\n return /* @__PURE__ */ React.createElement(QRCodeSVG, __spreadValues({}, otherProps));\n }\n return /* @__PURE__ */ React.createElement(QRCodeCanvas, __spreadValues({}, otherProps));\n};\nexport {\n QRCodeCanvas,\n QRCodeSVG,\n QRCode as default\n};\n",null,"import { useEffect, useState } from \"react\";\nimport { tickEvent } from \"../browserUtils\";\nimport \"../Kiosk.css\";\n\ninterface IProps {\n setActive: (p: boolean) => void;\n duration?: number;\n content: string;\n}\n\nconst KioskNotification: React.FC = ({ setActive, duration=5000, content }) => {\n useEffect(() => {\n let notificationLength = setTimeout(() => {\n setActive(false);\n }, duration);\n\n return () => {\n clearTimeout(notificationLength);\n }\n }, [])\n\n return (\n
    \n
    \n

    {content}

    \n
    \n
    \n )\n}\n\nexport default KioskNotification;","import { useEffect, useRef, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport { KioskState } from \"../Models/KioskState\";\nimport configData from \"../config.json\"\nimport \"../Kiosk.css\";\nimport AddGameButton from \"./AddGameButton\";\nimport {QRCodeSVG} from 'qrcode.react';\nimport { generateKioskCodeAsync, getGameCodesAsync } from \"../BackendRequests\";\nimport { isLocal, tickEvent } from \"../browserUtils\";\nimport { GameData } from \"../Models/GameData\";\nimport KioskNotification from \"./KioskNotification\";\ninterface IProps {\n kiosk: Kiosk\n}\n\nconst AddingGame: React.FC = ({ kiosk }) => {\n const [kioskCode, setKioskCode] = useState(\"\");\n const [renderQRCode, setRenderQRCode] = useState(true);\n const [menuButtonSelected, setMenuButtonState] = useState(false);\n const [qrCodeButtonSelected, setQrButtonState] = useState(false);\n const [notify, setNotify] = useState(false);\n const [notifyContent, setNotifyContent] = useState(\"\");\n const generatingKioskCode = useRef(false);\n const kioskCodeNextGenerationTime = useRef(0);\n const nextSafePollTime = useRef(0);\n const kioskCodeUrl = isLocal() ? \"http://localhost:3000/static/kiosk/\" : \"https://arcade.makecode.com/kiosk\";\n const kioskTimeOutInMinutes = getKioskCodeDuration();\n\n function getKioskCodeDuration(): number {\n const kioskCodeTime = localStorage.getItem(\"codeDuration\");\n if (kioskCodeTime) {\n return parseInt(kioskCodeTime);\n } else if (kiosk.time) {\n const kioskTime = parseInt(kiosk.time);\n return (kioskTime > 240 ? 240 : kioskTime) * 60;\n } else {\n return 30;\n }\n }\n\n const updateLoop = () => {\n if (!menuButtonSelected && kiosk.gamepadManager.isDownPressed()) {\n setMenuButtonState(true);\n if (qrCodeButtonSelected) {\n setQrButtonState(false);\n }\n }\n if (menuButtonSelected && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.toMainMenu\");\n kiosk.showMainMenu();\n }\n if (!renderQRCode && kiosk.gamepadManager.isUpPressed()) {\n setMenuButtonState(false);\n setQrButtonState(true);\n }\n if (qrCodeButtonSelected && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.newKioskCode\");\n setRenderQRCode(true);\n }\n }\n\n const kioskLinkClicked = () => {\n tickEvent(\"kiosk.addGameLink\");\n return true;\n }\n\n const displayGamesAdded = (addedGames: string[]): void => {\n const games = addedGames.join(\", \");\n const notification = `${games} added!`\n setNotifyContent(notification);\n setNotify(true);\n }\n\n useEffect(() => {\n let intervalId: any = null;\n intervalId = setInterval(() => {\n updateLoop();\n }, configData.GamepadPollLoopMilli);\n \n return () => {\n if (intervalId) {\n clearInterval(intervalId);\n }\n };\n });\n\n useEffect(() => {\n let pollTimer: any;\n const pollDelay = 5000;\n\n const pollForGameCode = async () => {\n const timeElapsed = nextSafePollTime.current - Date.now();\n const timeToPoll = Math.max(Math.min(timeElapsed, pollDelay), 0);\n nextSafePollTime.current = Date.now() + pollDelay;\n\n clearTimeout(pollTimer);\n pollTimer = setTimeout(async () => {\n try {\n const gameCodes = await getGameCodesAsync(kioskCode);\n if (gameCodes) {\n const justAddedGames = await kiosk.saveNewGamesAsync(gameCodes);\n if (justAddedGames.length) {\n displayGamesAdded(justAddedGames);\n }\n }\n if (kioskCode) {\n await pollForGameCode();\n }\n } catch (error: any) {\n clearTimeout(pollTimer);\n localStorage.removeItem(\"kioskCodeEnd\");\n localStorage.removeItem(\"currentKioskCode\");\n localStorage.removeItem(\"codeDuration\");\n setKioskCode(\"\");\n setRenderQRCode(false);\n }\n }, timeToPoll)\n }\n\n if (kioskCode) {\n pollForGameCode();\n }\n\n return () => {\n clearTimeout(pollTimer);\n }\n }, [kioskCode])\n\n useEffect(() => {\n let codeGenerationTimer: any;\n const generatedCodeDuration = kioskTimeOutInMinutes * 60 * 1000; // wait for kioskTimeOutInMinutes a.k.a until the kiosk code expires, backend has extra buffer\n\n const generateKioskCode = async () => {\n //TODO: maybe? spinner here to indicate work\n let newKioskCode: string;\n try {\n generatingKioskCode.current = true;\n if (kiosk.time) {\n newKioskCode = await generateKioskCodeAsync(kioskTimeOutInMinutes);\n } else {\n newKioskCode = await generateKioskCodeAsync();\n }\n setKioskCode(newKioskCode);\n\n kioskCodeNextGenerationTime.current = Date.now() + generatedCodeDuration;\n localStorage.setItem(\"kioskCodeEnd\", kioskCodeNextGenerationTime.current.toString());\n localStorage.setItem(\"currentKioskCode\", newKioskCode);\n localStorage.setItem(\"codeDuration\", kioskTimeOutInMinutes.toString());\n } catch (error) {\n setRenderQRCode(false);\n }\n generatingKioskCode.current = false;\n }\n\n\n if (!generatingKioskCode.current && renderQRCode) {\n const kioskCodeEndTime = localStorage.getItem(\"kioskCodeEnd\");\n if (kioskCodeEndTime) {\n const endTime = parseInt(kioskCodeEndTime);\n const timeElapsed = endTime - Date.now();\n if (timeElapsed > 0) {\n kioskCodeNextGenerationTime.current = endTime;\n const storedKioskCode = localStorage.getItem(\"currentKioskCode\");\n if (storedKioskCode) {\n setKioskCode(storedKioskCode);\n }\n } else {\n localStorage.removeItem(\"kioskCodeEnd\");\n localStorage.removeItem(\"currentKioskCode\");\n localStorage.removeItem(\"codeDuration\");\n generateKioskCode();\n }\n }\n else if (!kioskCode) {\n generateKioskCode();\n } else {\n const timeElapsed = kioskCodeNextGenerationTime.current - Date.now();\n const time = Math.max(Math.min(timeElapsed, generatedCodeDuration), 0);\n codeGenerationTimer = setTimeout(() => {\n setKioskCode(\"\");\n setRenderQRCode(false);\n localStorage.removeItem(\"kioskCodeEnd\");\n localStorage.removeItem(\"currentKioskCode\");\n localStorage.removeItem(\"codeDuration\");\n }, time)\n }\n }\n\n return () => {\n clearTimeout(codeGenerationTimer);\n }\n }, [kioskCode, renderQRCode]);\n\n const qrDivContent = () => {\n if (renderQRCode && kioskCode) {\n const kioskUrl = `${kioskCodeUrl}#add-game:${kioskCode}`;\n return (\n
    \n

    {kioskTimeOutInMinutes} minute Kiosk ID

    \n

    {kioskCode}

    \n \n \n\n
    \n )\n }\n else {\n return (\n
    \n \n
    \n )\n }\n };\n\n return (\n
    \n

    Add your game

    \n
    \n
    \n

    How to upload your game

    \n
      \n
    1. Use your mobile device to scan the QR code
    2. \n
    3. Use the new page to scan or enter your game's share code
    4. \n
    5. If your game is uploaded successfully, it will be added to the game list
    6. \n
    \n
    \n\n
    \n {qrDivContent()}\n
    \n
    \n \n {\n notify &&\n \n }\n
    \n\n )\n}\n\nexport default AddingGame;",null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,"import \"../Kiosk.css\";\nimport { Html5Qrcode } from \"html5-qrcode\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport { addGameToKioskAsync } from \"../BackendRequests\";\nimport { KioskState } from \"../Models/KioskState\";\nimport { tickEvent } from \"../browserUtils\";\n\nexport const play = async (\n kiosk: Kiosk,\n kioskId: string,\n html5QrCode: Html5Qrcode,\n setAddError: (p: string) => void,\n setDesc: (p: string) => void\n ) => {\n let devices: any[];\n\n async function onScanSuccess(decodedText: string, decodedResult: any) {\n const shareId = /\\/([^\\/]+)\\/?$/.exec(decodedText)?.[1];\n try {\n await addGameToKioskAsync(kioskId, shareId);\n tickEvent(\"kiosk.gameQrScanned.success\");\n await html5QrCode.stop();\n kiosk.navigate(KioskState.QrSuccess);\n } catch (error: any) {\n setAddError(error.toString());\n if (error.toString().includes(\"404\")) {\n setDesc(\"This is likely because the kiosk code is expired. Go back to the kiosk to make a new code.\");\n } else {\n setDesc(\"Something went wrong. Please try again later.\");\n }\n }\n }\n \n function onScanFailure(errorMessage: string, error: any) {\n console.log(\"scan failed\");\n throw new Error(\"bad scan\");\n }\n\n try {\n devices = await Html5Qrcode.getCameras();\n if (devices && devices.length) {\n try {\n html5QrCode.start(\n {facingMode: \"environment\"},\n undefined,\n onScanSuccess,\n onScanFailure\n );\n } catch (error) {\n console.log(\"failed to start scanning\");\n }\n }\n } catch (error) {\n console.log(\"couldn't get camera permissions\");\n }\n}\n\nexport const stopScan = async (html5QrCode: Html5Qrcode) => {\n await html5QrCode.stop();\n}","import { useEffect, useState } from \"react\";\nimport { tickEvent } from \"../browserUtils\";\nimport \"../Kiosk.css\";\n\n\ninterface IProps {\n errorType: string;\n errorDescription: string;\n setShowing: (p: string) => void;\n}\nconst ErrorModal: React.FC = ({ errorType, errorDescription, setShowing }) => {\n const cancelClicked = () => {\n tickEvent(\"kiosk.scanError.dismissed\");\n setShowing(\"\");\n }\n\n return (\n
    \n
    \n
    \n
    \n {errorType}\n
    \n
    \n

    \n {errorDescription}\n

    \n
    \n
    \n \n
    \n
    \n
    \n
    \n )\n}\n\nexport default ErrorModal;","import { useEffect, useRef, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport \"../Kiosk.css\";\nimport { play, stopScan } from \"./QrScanner\";\nimport { addGameToKioskAsync } from \"../BackendRequests\";\nimport { KioskState } from \"../Models/KioskState\";\nimport { Html5Qrcode } from \"html5-qrcode\";\nimport { tickEvent } from \"../browserUtils\";\nimport ErrorModal from \"./ErrorModal\";\n\ninterface IProps {\n kiosk: Kiosk\n}\n\nconst ScanQR: React.FC = ({ kiosk }) => {\n const fullUrlHash = window.location.hash;\n const urlHashList = /add-game:((?:[a-zA-Z0-9]{6}))/.exec(fullUrlHash);\n const kioskId = urlHashList?.[1];\n const [scannerVisible, setScannerVisible] = useState(false);\n const [linkError, setLinkError] = useState(false);\n const [addingError, setAddingError] = useState(\"\");\n const [errorDesc, setErrorDesc] = useState(\"\");\n const qrReaderRendered = useRef(null);\n const [html5QrCode, setHtml5QrCode] = useState();\n\n const renderQrScanner = () => {\n tickEvent(\"kiosk.scanQrClicked\");\n play(kiosk, kioskId!, html5QrCode!, setAddingError, setErrorDesc);\n setScannerVisible(true);\n }\n\n const stopQrScanner = () => {\n tickEvent(\"kiosk.stopScanClicked\");\n stopScan(html5QrCode!);\n setScannerVisible(false);\n }\n\n const initiateQrCode = () => {\n if (qrReaderRendered.current) {\n const qrCodeReader = new Html5Qrcode(\"qrReader\");\n setHtml5QrCode(qrCodeReader);\n }\n }\n\n const clickHelp = () => {\n tickEvent(\"kiosk.helpLink\");\n return true;\n }\n\n useEffect(() => {\n tickEvent(\"kiosk.scanQrLoaded\");\n initiateQrCode();\n }, [])\n\n const checkUrl = async () => {\n const input = document.getElementById(\"kiosk-share-link\") as HTMLInputElement;\n const inputValue = input.value?.trim();\n const shareLink = /^(https:\\/\\/)((arcade\\.makecode\\.com\\/)|(makecode\\.com\\/))((?:S?\\d{5}-\\d{5}-\\d{5}-\\d{5})$|(?:_[a-zA-Z0-9]+)$)/i.exec(inputValue);\n const shareCode = /(^(?:S?\\d{5}-\\d{5}-\\d{5}-\\d{5})$|^(?:_[a-zA-Z0-9]{12})$)/.exec(inputValue);\n let shareId;\n if (shareLink) {\n shareId = /\\/([^\\/]+)\\/?$/.exec(inputValue)?.[1];\n } else if (shareCode) {\n shareId = shareCode[1];\n }\n tickEvent(\"kiosk.submitGameId.clicked\", { submitVal: inputValue });\n if (shareId) {\n setLinkError(false);\n try {\n await addGameToKioskAsync(kioskId, shareId);\n tickEvent(\"kiosk.submitGameId.submitSuccess\");\n kiosk.navigate(KioskState.QrSuccess);\n } catch (error: any) {\n setAddingError(error.toString());\n if (error.toString().includes(\"404\")) {\n setErrorDesc(\"The kiosk code expired. Go back to the kiosk to make a new code.\");\n } else {\n setErrorDesc(\"Something went wrong. Please try again later.\");\n }\n }\n } else {\n setLinkError(true);\n }\n\n }\n\n const clearStatus = () => {\n if (linkError) {\n setLinkError(false);\n }\n }\n\n return (\n
    \n

    Add game to
    Kiosk {kioskId}

    \n
    \n
    \n {\n !scannerVisible &&\n \n }\n
    \n {\n scannerVisible &&\n
    \n \n

    Tip: Do not use the kiosk's QR code

    \n
    \n }\n

    OR

    \n
    \n
    \n \n \n \n {\n linkError &&\n

    Incorrect format for a share link

    \n }\n
    \n \n How do I get a game's share link or QR code?\n \n
    \n {\n !!addingError &&\n \n }\n
    \n )\n}\n\nexport default ScanQR;","import { useEffect } from \"react\";\nimport { tickEvent } from \"../browserUtils\";\nimport \"../Kiosk.css\";\n\nconst QrSuccess: React.FC<{}> = () => {\n // TODO: pass the game's title and the kiosk's id through to give more feedback to the user\n useEffect(() => {\n tickEvent(\"kiosk.qrSuccessLoaded\");\n },[]);\n\n return (\n
    \n

    You have successfully uploaded your game to the kiosk!

    \n

    You can close this window. Happy playing!

    \n
    \n )\n}\nexport default QrSuccess;","import { useEffect, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport AddGameButton from \"./AddGameButton\";\nimport configData from \"../config.json\"\nimport { KioskState } from \"../Models/KioskState\";\nimport { tickEvent } from \"../browserUtils\";\n\n\ninterface IProps {\n kiosk: Kiosk\n }\n\nconst GameOver: React.FC = ({ kiosk }) => {\n const [homeButtonSelected, setHomeButtonState] = useState(false);\n const [retryButtonSelected, setRetryButtonState] = useState(false);\n const gameId = kiosk.launchedGame;\n\n\n const updateLoop = () => {\n if (kiosk.gamepadManager.isLeftPressed()) {\n setRetryButtonState(true);\n setHomeButtonState(false);\n\n }\n if (kiosk.gamepadManager.isRightPressed()) {\n setHomeButtonState(true);\n setRetryButtonState(false);\n\n }\n if (homeButtonSelected && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.gameOver.mainMenu\");\n kiosk.navigate(KioskState.MainMenu);\n }\n\n if (retryButtonSelected && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.gameOver.retry\");\n kiosk.launchGame(gameId);\n }\n }\n\n useEffect(() => {\n let intervalId: any = null;\n\n intervalId = setInterval(() => {\n updateLoop();\n }, configData.GamepadPollLoopMilli);\n\n return () => {\n if (intervalId) {\n clearInterval(intervalId);\n }\n };\n });\n\n\n return (\n
    \n

    GAME OVER

    \n

    Would you like to retry?

    \n
    \n \n \n
    \n
    \n )\n}\n\nexport default GameOver;","import React, { useEffect, useState } from 'react';\nimport './Kiosk.css';\nimport './Fonts.css';\nimport { Kiosk } from './Models/Kiosk';\nimport MainMenu from './Components/MainMenu';\nimport { KioskState } from './Models/KioskState';\nimport EnterHighScore from './Components/EnterHighScore';\nimport AddingGame from './Components/AddingGame';\nimport ScanQR from './Components/ScanQR';\nimport QrSuccess from './Components/QrSuccess';\nimport GameOver from './Components/GameOver';\n\nconst url = window.location.href;\nconst clean = !!/clean(?:[:=])1/.test(url);\nconst locked = !!/lock(?:[:=])1/i.test(url);\nconst time = (/time=((?:[0-9]{1,3}))/i.exec(url))?.[1];\n\nconst kioskSingleton: Kiosk = new Kiosk(clean, locked, time);\nkioskSingleton.initialize().catch(error => alert(error));\n\nfunction App() {\n const[state, setState] = useState(kioskSingleton.state);\n\n useEffect(() => {\n window.onhashchange = onHashChange;\n\n kioskSingleton.onNavigated = () => {\n setState(kioskSingleton.state);\n };\n onHashChange();\n }, []);\n\n switch(state) {\n case KioskState.MainMenu:\n return ()\n case KioskState.EnterHighScore:\n return ()\n case KioskState.AddingGame:\n return ()\n case KioskState.ScanQR:\n return ()\n case KioskState.QrSuccess:\n return ()\n case KioskState.GameOver:\n return ()\n }\n\n return (
    )\n}\n\nfunction onHashChange() {\n const hash = window.location.hash;\n const match = /pub:((?:\\d{5}-\\d{5}-\\d{5}-\\d{5})|(?:_[a-zA-Z0-9]+))/.exec(hash);\n const addGame = /add-game:((?:[a-zA-Z0-9]{6}))/.exec(hash);\n if (match) {\n kioskSingleton.launchGame(match[1], true);\n } else if (addGame) {\n kioskSingleton.navigate(KioskState.ScanQR);\n }\n}\n\nexport default App;","import { ReportHandler } from 'web-vitals';\n\nconst reportWebVitals = (onPerfEntry?: ReportHandler) => {\n if (onPerfEntry && onPerfEntry instanceof Function) {\n import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\n getCLS(onPerfEntry);\n getFID(onPerfEntry);\n getFCP(onPerfEntry);\n getLCP(onPerfEntry);\n getTTFB(onPerfEntry);\n });\n }\n};\n\nexport default reportWebVitals;\n","import React from 'react';\nimport ReactDOM from 'react-dom/client';\nimport './Kiosk.css';\nimport App from './App';\nimport reportWebVitals from './reportWebVitals';\nimport { devicePixelRatio, isLocal, tickEvent } from './browserUtils';\n\ninterface Map {\n [index: string]: T;\n}\n\nfunction enableAnalytics() {\n const stats: Map = {};\n if (typeof window !== \"undefined\") {\n const screen = window.screen;\n stats[\"screen.width\"] = screen.width;\n stats[\"screen.height\"] = screen.height;\n stats[\"screen.availwidth\"] = screen.availWidth;\n stats[\"screen.availheight\"] = screen.availHeight;\n stats[\"screen.innerWidth\"] = window.innerWidth;\n stats[\"screen.innerHeight\"] = window.innerHeight;\n stats[\"screen.devicepixelratio\"] = devicePixelRatio();\n const body = document.firstElementChild; // body\n if (body) {\n stats[\"screen.clientWidth\"] = body.clientWidth;\n stats[\"screen.clientHeight\"] = body.clientHeight;\n }\n }\n tickEvent(\"kiosk.loaded\", stats);\n}\n\nwindow.addEventListener(\"DOMContentLoaded\", () => {\n enableAnalytics();\n\n const root = ReactDOM.createRoot(\n document.getElementById('root') as HTMLElement\n );\n root.render(\n \n \n \n );\n});\n\n// If you want to start measuring performance in your app, pass a function\n// to log results (for example: reportWebVitals(console.log))\n// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals\nreportWebVitals();\n"],"names":["exports","extendStatics","Object","setPrototypeOf","__proto__","Array","d","b","p","hasOwnProperty","__extends","__","this","constructor","prototype","create","fixProto","target","fixStack","fn","captureStackTrace","Error","Exception","message","undefined","kind","_super","CustomError","_newTarget","_this","call","defineProperty","value","name","enumerable","ArgumentException","IllegalArgumentException","BinaryBitmap","binarizer","getWidth","getHeight","y","row","getBlackRow","matrix","getBlackMatrix","getLuminanceSource","isCropSupported","left","top","width","height","newSource","crop","createBinarizer","isRotateSupported","rotateCounterClockwise","rotateCounterClockwise45","toString","e","ChecksumException","Binarizer","source","System","src","srcPos","dest","destPos","length","Date","now","IndexOutOfBoundsException","ArrayIndexOutOfBoundsException","index","Arrays","a","val","i","len","fromIndex","toIndex","rangeCheck","arrayLength","args","rows","cols","from","map","x","fill","Int32Array","first","second","result","original","newLength","slice","newArray","Uint8Array","set","to","copy","arraycopy","ar","el","comparator","numberComparator","m","n","k","cmp","Integer","intNumber","String","parseInt","dividend","divisor","Math","trunc","num","MIN_VALUE_32_BITS","MAX_VALUE","Number","MAX_SAFE_INTEGER","DecodeHintType","BitArray","size","bits","makeArray","floor","newBits","bitsOffset","currentBits","numberOfTrailingZeros","start","end","firstInt","lastInt","mask","max","bit","ensureCapacity","numBits","numBitsLeft","appendBit","other","otherSize","get","bitOffset","array","offset","numBytes","theByte","j","oldBitsLen","leftOffset","currentInt","nextInt","o","equals","hashCode","CharacterSetValueIdentifiers","DecodeHintType$1","FormatException","CharacterSetECI","valueIdentifier","valuesParam","values","otherEncodingNames","VALUE_IDENTIFIER_TO_ECI","NAME_TO_ECI","v","VALUES_TO_ECI","otherName","getName","characterSet","Map","Cp437","ISO8859_1","ISO8859_2","ISO8859_3","ISO8859_4","ISO8859_5","ISO8859_6","ISO8859_7","ISO8859_8","ISO8859_9","ISO8859_10","ISO8859_11","ISO8859_13","ISO8859_14","ISO8859_15","ISO8859_16","SJIS","Cp1250","Cp1251","Cp1252","Cp1256","UnicodeBigUnmarked","UTF8","ASCII","Big5","GB18030","EUC_KR","UnsupportedOperationException","StringEncoding","bytes","encoding","encodingName","customDecoder","TextDecoder","shouldDecodeOnFallback","decodeFallback","decode","isBrowser","s","customEncoder","TextEncoder","encodeFallback","encode","window","getCharacterSetECIByName","encodingCharacterSet","isDecodeFallbackSupported","h","decodeURIComponent","fromCharCode","apply","Uint16Array","buffer","charList","btoa","unescape","encodeURIComponent","split","uintArray","push","charCodeAt","StringUtils","code","ISO88591","hints","CHARACTER_SET","canBeISO88591","canBeShiftJIS","canBeUTF8","utf8BytesLeft","utf2BytesChars","utf3BytesChars","utf4BytesChars","sjisBytesLeft","sjisKatakanaChars","sjisCurKatakanaWordLength","sjisCurDoubleBytesWordLength","sjisMaxKatakanaWordLength","sjisMaxDoubleBytesWordLength","isoHighOther","utf8bom","ASSUME_SHIFT_JIS","SHIFT_JIS","PLATFORM_DEFAULT_ENCODING","append","callback","exp","p0","p1","p2","p3","p4","substr","base","parseFloat","toFixed","toPrecision","toExponential","JSON","stringify","ch","regex","replace","str","charCode","GB2312","EUC_JP","StringBuilder","castAsNonUtf8Char","charAt","substring","c","BitMatrix","rowSize","getRowSize","rowArray","getRow","getBitArray","right","bottom","getSize","clear","setBulk","topRow","bottomRow","reverse","setRow","x32","theBits","hash","setString","unsetString","lineSeparator","buildToString","image","imageI","stringRepresentation","bitsPos","rowStartPos","rowLength","nRows","pos","NotFoundException","GlobalHistogramBinarizer","luminances","EMPTY","buckets","LUMINANCE_BUCKETS","initArrays","localLuminances","localBuckets","LUMINANCE_SHIFT","blackPoint","estimateBlackPoint","center","getMatrix","luminanceSize","Uint8ClampedArray","numBuckets","maxBucketCount","firstPeak","firstPeakSize","secondPeak","secondPeakScore","distanceToBiggest","score","temp","bestValley","bestValleyScore","fromFirst","LUMINANCE_BITS","HybridBinarizer","MINIMUM_DIMENSION","subWidth","BLOCK_SIZE_POWER","BLOCK_SIZE_MASK","subHeight","blackPoints","calculateBlackPoints","newMatrix","calculateThresholdForBlock","maxYOffset","BLOCK_SIZE","maxXOffset","yoffset","cap","xoffset","sum","z","blackRow","average","thresholdBlock","min","threshold","stride","yy","xx","pixel","MIN_DYNAMIC_RANGE","averageNeighborBlackPoint","LuminanceSource","sourceRow","luminance","InvertedLuminanceSource","delegate","invertedMatrix","HTMLCanvasElementLuminanceSource","canvas","tempCanvasElement","makeBufferFromCanvasImageData","rotate","ownerDocument","createElement","angle","getTempCanvasElement","tempContext","getContext","angleRadians","DEGREE_TO_RADIANS","newWidth","ceil","abs","cos","sin","newHeight","translate","drawImage","imageData","getImageData","toGrayscaleBuffer","data","imageBuffer","grayscaleBuffer","gray","PI","BarcodeFormat","VideoInputDevice","deviceId","label","groupId","__awaiter","globalThis","global","self","thisArg","_arguments","P","generator","adopt","resolve","Promise","reject","fulfilled","step","next","rejected","done","then","BrowserCodeReader","reader","timeBetweenScansMillis","_hints","_stopContinuousDecode","_stopAsyncDecode","_timeBetweenDecodingAttempts","navigator","hasNavigator","mediaDevices","isMediaDevicesSuported","enumerateDevices","millis","canEnumerateDevices","devices","videoDevices","device","id","videoDevice","listVideoInputDevices","find","videoSource","decodeOnceFromVideoDevice","reset","constraints","video","exact","facingMode","decodeOnceFromConstraints","getUserMedia","stream","decodeOnceFromStream","attachStreamToVideo","decodeOnce","callbackFn","decodeFromVideoDevice","decodeFromConstraints","decodeFromStream","decodeContinuously","videoElement","prepareVideoElement","addVideoSource","playVideoOnLoadAsync","playVideoOnLoad","element","videoEndedListener","stopStreams","videoCanPlayListener","tryPlayVideo","addEventListener","currentTime","paused","ended","readyState","isVideoPlaying","console","warn","play","mediaElementId","type","mediaElement","document","getElementById","nodeName","toLowerCase","url","decodeFromImageUrl","decodeFromImageElement","decodeFromVideoUrl","decodeFromVideoElement","decodeFromVideoUrlContinuously","decodeFromVideoElementContinuously","prepareImageElement","imageElement","isImageLoaded","_decodeOnLoadImage","_decodeFromVideoElementSetup","_decodeOnLoadVideo","_decodeOnLoadVideoContinuously","decodeTask","imageLoadedListener","img","complete","naturalWidth","imageSource","getMediaElement","HTMLImageElement","HTMLVideoElement","setAttribute","retryIfNotFound","retryIfChecksumOrFormatError","loop","setTimeout","binaryBitmap","createBinaryBitmap","decodeBitmap","ctx","getCaptureCanvasContext","drawImageOnCanvas","getCaptureCanvas","luminanceSource","hybridBinarizer","captureCanvasContext","captureCanvas","elem","createCaptureCanvas","canvasElementContext","srcElement","_destroyCaptureCanvas","canvasElement","videoWidth","videoHeight","naturalHeight","style","getVideoTracks","forEach","t","stop","stopAsyncDecode","stopContinuousDecode","_destroyVideoElement","_destroyImageElement","removeEventListener","videoPlayingEventListener","cleanVideoSource","removeAttribute","srcObject","err","URL","createObjectURL","Result","text","rawBytes","resultPoints","format","timestamp","currentTimeMillis","resultMetadata","metadata","newPoints","oldPoints","allPoints","ResultMetadataType","BarcodeFormat$1","ResultMetadataType$1","DecoderResult","byteSegments","ecLevel","structuredAppendSequenceNumber","structuredAppendParity","errorsCorrected","erasures","AbstractGenericGF","expTable","logTable","GenericGFPoly","field","coefficients","coefficientsLength","firstNonZero","degree","getCoefficient","coefficient","addOrSubtract","multiply","isZero","smallerCoefficients","largerCoefficients","sumDiff","lengthDiff","getZero","aCoefficients","aLength","bCoefficients","bLength","product","aCoeff","scalar","quotient","remainder","denominatorLeadingTerm","getDegree","inverseDenominatorLeadingTerm","inverse","degreeDifference","scale","term","multiplyByMonomial","iterationQuotient","buildMonomial","alphaPower","log","ArithmeticException","GenericGF","primitive","generatorBase","zero","one","toHexString","AZTEC_DATA_12","AZTEC_DATA_10","AZTEC_DATA_6","AZTEC_PARAM","QR_CODE_FIELD_256","DATA_MATRIX_FIELD_256","AZTEC_DATA_8","MAXICODE_FIELD_64","ReedSolomonException","IllegalStateException","Table","ReedSolomonDecoder","received","twoS","poly","syndromeCoefficients","noError","evalResult","evaluateAt","getGeneratorBase","syndrome","sigmaOmega","runEuclideanAlgorithm","sigma","omega","errorLocations","findErrorLocations","errorMagnitudes","findErrorMagnitudes","position","R","rLast","r","tLast","getOne","rLastLast","tLastLast","q","dltInverse","degreeDiff","sigmaTildeAtZero","multiplyScalar","errorLocator","numErrors","errorEvaluator","xiInverse","denominator","termPlus1","Decoder","detectorResult","ddata","getBits","rawbits","extractBits","correctedBits","correctBits","convertBoolArrayToByteArray","getEncodedData","decoderResult","setNumBits","gf","codewordSize","getNbLayers","numDataCodewords","getNbDatablocks","numCodewords","dataWords","readCode","ex","stuffedBits","dataWord","compact","isCompact","layers","baseMatrixSize","alignmentMap","totalBitsInLayer","matrixSize","truncDivision","origCenter","newOffset","rowOffset","low","high","columnOffset","endIndex","latchTable","UPPER","shiftTable","BINARY","charCount","DIGIT","getCharacter","startsWith","getTable","LOWER","PUNCT","MIXED","table","UPPER_TABLE","LOWER_TABLE","MIXED_TABLE","PUNCT_TABLE","DIGIT_TABLE","startIndex","res","boolArr","byteArr","readByte","MathUtils","NaN","MIN_SAFE_INTEGER","aX","aY","bX","bY","xDiff","yDiff","sqrt","count","Float","f","ResultPoint","otherPoint","floatToIntBits","patterns","pointA","pointB","pointC","zeroOneDistance","distance","oneTwoDistance","zeroTwoDistance","crossProductZ","pattern1","pattern2","DetectorResult","points","AztecDetectorResult","nbDatablocks","nbLayers","WhiteRectangleDetector","initSize","INIT_SIZE","halfsize","leftInit","rightInit","upInit","downInit","up","down","sizeExceeded","aBlackPointFoundOnBorder","atLeastOneBlackPointFoundOnBorder","atLeastOneBlackPointFoundOnRight","atLeastOneBlackPointFoundOnBottom","atLeastOneBlackPointFoundOnLeft","atLeastOneBlackPointFoundOnTop","rightBorderNotWhite","containsBlackPoint","bottomBorderNotWhite","leftBorderNotWhite","topBorderNotWhite","maxSize","getBlackPointOnSegment","centerEdges","dist","round","xStep","yStep","yi","getX","yj","getY","zi","zj","xi","xj","ti","tj","CORR","fixed","horizontal","GridSampler","nudged","PerspectiveTransform","a11","a21","a31","a12","a22","a32","a13","a23","a33","xValues","yValues","x0","y0","x1","y1","x2","y2","x3","y3","x0p","y0p","x1p","y1p","x2p","y2p","x3p","y3p","qToS","quadrilateralToSquare","squareToQuadrilateral","times","dx3","dy3","dx1","dx2","dy1","dy2","buildAdjoint","DefaultGridSampler","dimensionX","dimensionY","p1ToX","p1ToY","p2ToX","p2ToY","p3ToX","p3ToY","p4ToX","p4ToY","p1FromX","p1FromY","p2FromX","p2FromY","p3FromX","p3FromY","p4FromX","p4FromY","transform","quadrilateralToQuadrilateral","sampleGridWithTransform","Float32Array","iValue","transformPoints","checkAndNudgePoints","aioobe","GridSamplerInstance","newGridSampler","gridSampler","Point","Detector","EXPECTED_CORNER_BITS","detectMirror","isMirror","pCenter","getMatrixCenter","bullsEyeCorners","getBullsEyeCorners","extractParameters","sampleGrid","shift","corners","getMatrixCornerPoints","nbDataBlocks","isValidPoint","nbCenterLayers","sides","sampleLine","getRotation","parameterData","side","correctedData","getCorrectedParameterData","cornerBits","idx","arr","bitCount","numECCodewords","parameterWords","ignored","pina","pinb","pinc","pind","color","pouta","getFirstDifferent","poutb","poutc","poutd","distancePoint","isWhiteOrBlackRectangle","pinax","pinbx","pincx","pindx","expandSquare","pointD","cornerPoints","detect","cx","cy","toResultPoint","getDimension","topLeft","topRight","bottomRight","bottomLeft","sampler","getInstance","dimension","distanceResultPoint","moduleSize","px","py","dx","dy","corr","cInit","getColor","error","colorModel","iMax","errRatio","init","isValid","oldSide","newSide","ratio","centerx","centery","result0","result2","point","AztecReader","exception","detector","getPoints","reportFoundResultPoints","getText","getRawBytes","getNumBits","AZTEC","getByteSegments","putMetadata","BYTE_SEGMENTS","getECLevel","ERROR_CORRECTION_LEVEL","rpcb","NEED_RESULT_POINT_CALLBACK","foundPossibleResultPoint","BrowserAztecCodeReader","OneDReader","doDecode","nfe","TRY_HARDER","rotatedImage","getResultMetadata","orientation","ORIENTATION","getResultPoints","maxLines","tryHarder","rowStep","middle","rowStepsAboveOrBelow","rowNumber","attempt","newHints","hint","key","delete","decodeRow","re","counters","numCounters","isWhite","counterPosition","numTransitionsLeft","last","recordPattern","pattern","maxIndividualVariance","total","patternLength","POSITIVE_INFINITY","unitBarWidth","totalVariance","counter","scaledPattern","variance","Code128Reader","codeSet","convertFNC1","ASSUME_GS1","startPatternInfo","findStartPattern","startCode","currentRawCodesIndex","rawCodes","CODE_START_A","CODE_CODE_A","CODE_START_B","CODE_CODE_B","CODE_START_C","CODE_CODE_C","isNextShifted","lastStart","nextStart","lastCode","checksumTotal","multiplier","lastCharacterWasPrintable","upperMode","shiftUpperMode","unshift","decodeCode","CODE_STOP","reduce","previous","current","CODE_FNC_1","CODE_FNC_2","CODE_FNC_3","CODE_FNC_4_A","CODE_SHIFT","CODE_FNC_4_B","lastPatternSize","getNextUnset","isRange","resultLength","rawCodesSize","CODE_128","getTime","getNextSet","patternStart","bestVariance","MAX_AVG_VARIANCE","bestMatch","patternMatchVariance","CODE_PATTERNS","MAX_INDIVIDUAL_VARIANCE","Code39Reader","usingCheckDigit","extendedMode","decodeRowResult","theCounters","decodedChar","findAsteriskPattern","toNarrowWidePattern","patternToChar","resultString","ALPHABET_STRING","indexOf","decodeExtended","CODE_39","ASTERISK_ENCODING","copyWithin","wideCounters","maxNarrowCounter","minCounter","totalWideCountersWidth","CHARACTER_ENCODINGS","encoded","decoded","ITFReader","arguments","narrowLineWidth","startRange","decodeStart","endRange","decodeEnd","decodeMiddle","allowedLengths","ALLOWED_LENGTHS","DEFAULT_ALLOWED_LENGTHS","lengthOK","maxAllowedLength","ITF","endStart","skipWhiteSpace","startPattern","findGuardPattern","START_PATTERN","validateQuietZone","quietCount","endPattern","END_PATTERN_REVERSED","payloadStart","payloadEnd","counterDigitPair","counterBlack","counterWhite","twoK","decodeDigit","counterDigit","PATTERNS","AbstractUPCEANReader","decodeRowStringBuffer","foundStart","START_END_PATTERN","quietStart","checkStandardUPCEANChecksum","check","getStandardUPCEANChecksum","digit","whiteFirst","MIDDLE_PATTERN","END_PATTERN","L_PATTERNS","UPCEANExtension5Support","CHECK_DIGIT_ENCODINGS","decodeMiddleCounters","extensionStartRange","extensionData","parseExtensionString","extensionResult","UPC_EAN_EXTENSION","putAllMetadata","lgPatternFound","L_AND_G_PATTERNS","checkDigit","determineCheckDigit","extensionChecksum","raw","parseExtension5String","SUGGESTED_PRICE","currency","rawAmount","hundredths","UPCEANExtension2Support","checkParity","ISSUE_NUMBER","UPCEANExtensionSupport","EXTENSION_START_PATTERN","UPCEANReader","widths","reversedWidths","startGuardRange","findStartGuardPattern","resultPointCallback","resultPoint","budello","quietEnd","checkChecksum","getBarcodeFormat","decodeResult","extensionLength","addResultPoints","allowedExtensions","ALLOWED_EAN_EXTENSIONS","valid","EAN_13","UPC_A","EAN13Reader","determineFirstDigit","FIRST_DIGIT_ENCODINGS","EAN8Reader","EAN_8","UPCAReader","ean13Reader","maybeReturnResult","upcaResult","UPCEReader","determineNumSysAndCheckDigit","findGuardPatternWithoutCounters","MIDDLE_END_PATTERN","convertUPCEtoUPCA","UPC_E","numSys","NUMSYS_AND_CHECK_DIGIT_PATTERNS","insert","getNotFoundInstance","upce","upceChars","lastChar","appendChars","MultiFormatUPCEANReader","possibleFormats","POSSIBLE_FORMATS","readers","ean13MayBeUPCA","canReturnUPCA","includes","resultUPCA","AbstractRSSReader","decodeFinderCounters","dataCharacterCounters","oddRoundingErrors","evenRoundingErrors","oddCounts","evenCounts","finderPatterns","errors","biggestError","firstTwoSum","MIN_FINDER_PATTERN_RATIO","MAX_FINDER_PATTERN_RATIO","maxCounter","DataCharacter","checksumPortion","that","FinderPattern","startEnd","RSSUtils","maxWidth","noNarrow","narrowMask","elements","bar","elmWidth","subVal","combins","lessVal","mxwElement","maxDenom","minDenom","BitArrayBuilder","pairs","charNumber","getRightChar","binary","accPos","firstValue","getValue","currentPair","leftValue","getLeftChar","rightValue","BlockParsedResult","finished","decodedInformation","DecodedObject","newPosition","DecodedChar","FNC1","DecodedInformation","newString","remainingValue","remaining","DecodedNumeric","firstDigit","secondDigit","FieldParser","rawInformation","firstTwoDigits","TWO_DIGIT_DATA_LENGTH","dataLength","VARIABLE_LENGTH","processVariableAI","processFixedAI","firstThreeDigits","THREE_DIGIT_DATA_LENGTH","THREE_DIGIT_PLUS_DIGIT_DATA_LENGTH","firstFourDigits","FOUR_DIGIT_DATA_LENGTH","aiSize","fieldSize","ai","parsedAI","parseFieldsInGeneralPurpose","variableFieldSize","GeneralAppIdDecoder","information","buff","initialPosition","currentPosition","info","decodeGeneralPurposeField","parsedFields","getNewString","isRemaining","getRemainingValue","getNewPosition","numeric","extractNumericValueFromBitArray","setLengthToZero","setPosition","lastDecoded","parseBlocks","getPosition","isFinished","isAlpha","parseAlphaBlock","isIsoIec646","parseIsoIec646Block","parseNumericBlock","getDecodedInformation","isStillNumeric","decodeNumeric","isFirstDigitFNC1","isSecondDigitFNC1","getSecondDigit","getFirstDigit","isNumericToAlphaNumericLatch","setAlpha","incrementPosition","isStillIsoIec646","iso","decodeIsoIec646","isFNC1","isAlphaOr646ToNumericLatch","setNumeric","isAlphaTo646ToAlphaLatch","isStillAlpha","alpha","decodeAlphanumeric","setIsoIec646","fiveBitValue","sevenBitValue","eightBitValue","sixBitValue","AbstractExpandedDecoder","generalDecoder","AI01decoder","buf","currentPos","encodeCompressedGtinWithoutAI","initialBufferPosition","currentBlock","getGeneralDecoder","appendCheckDigit","GTIN_SIZE","AI01AndOtherAIs","initialGtinPosition","firstGtinDigit","HEADER_SIZE","decodeAllCodes","AnyAIDecoder","AI01weightDecoder","weightSize","originalWeightNumeric","addWeightCode","weightNumeric","checkWeight","currentDivisor","AI013x0xDecoder","getInformation","WEIGHT_SIZE","encodeCompressedGtin","encodeCompressedWeight","AI013103decoder","weight","AI01320xDecoder","AI01392xDecoder","lastAIdigit","LAST_DIGIT_SIZE","AI01393xDecoder","FIRST_THREE_DIGITS_SIZE","generalInformation","AI013x0x1xDecoder","firstAIdigits","dateCode","DATE_SIZE","encodeCompressedDate","numericDate","day","month","year","createDecoder","ExpandedPair","leftChar","rightChar","finderPatter","mayBeLast","leftchar","rightchar","finderpattern","maybeLast","o1","o2","equalsOrNull","ExpandedRow","wasReversed","otherPairs","checkEqualitity","pair1","pair2","e1","e2","getFinderPatter","RSSExpandedReader","verbose","MAX_PAIRS","startFromEven","constructResult","decodeRow2pairs","tryStackedDecode","retrieveNextPair","storeRow","ps","checkRowsBoolean","checkRows","collectedRows","currentRow","collectedRow","getPairs","isValidSequence","rs","insertPos","prevIsSame","nextIsSame","erow","getRowNumber","isEquivalent","isPartialRow","removePartialRows","pp","firstPair","checkCharacter","firstCharacter","checksum","getChecksumPortion","currentRightChar","previousPairs","isOddPattern","keepFinding","forcedOffset","findNextPair","parseFoundFinderPattern","getNextSecondBar","decodeDataCharacter","isEmptyPair","mustBeLast","getDecodeFinderCounters","getFinderPattern","getStartEnd","searchingEvenPair","reverseCounters","isFinderPattern","oddPattern","firstCounter","firstElementStart","parseFinderValue","FINDER_PATTERNS","getDataCharacterCounters","recordPatternInReverse","numModules","elementWidth","expectedElementWidth","getOddCounts","getEvenCounts","getOddRoundingErrors","getEvenRoundingErrors","adjustOddEvenCounts","weightRowNumber","oddSum","oddChecksumPortion","isNotA1left","WEIGHTS","evenChecksumPortion","group","oddWidest","SYMBOL_WIDEST","evenWidest","vOdd","getRSSvalue","vEven","tEven","EVEN_TOTAL_SUBSET","gSum","GSUM","evenSum","incrementOdd","decrementOdd","incrementEven","decrementEven","mismatch","oddParityBad","evenParityBad","increment","decrement","FINDER_PATTERN_SEQUENCES","sequence","allFound","found","resultingString","buildBitArray","parseInformation","firstPoints","lastPoints","RSS_EXPANDED","initialPos","tmp","FINDER_PAT_A","FINDER_PAT_B","FINDER_PAT_C","FINDER_PAT_D","FINDER_PAT_E","FINDER_PAT_F","Pair","finderPattern","RSS14Reader","possibleLeftPairs","possibleRightPairs","leftPair","decodePair","addOrTally","rightPair","getCount","findFinderPattern","outside","inside","outsideChar","OUTSIDE_ODD_WIDEST","OUTSIDE_EVEN_TOTAL_SUBSET","OUTSIDE_GSUM","INSIDE_ODD_WIDEST","tOdd","INSIDE_ODD_TOTAL_SUBSET","INSIDE_GSUM","rightFinderPattern","firstIsBlack","possiblePairs","pair","incrementCount","symbolValue","leftPoints","rightPoints","RSS_14","checkValue","targetCheckValue","MultiFormatOneDReader","useCode39CheckDigit","ASSUME_CODE_39_CHECK_DIGIT","BrowserBarcodeReader","ECBlocks","ecCodewords","ecBlocks1","ecBlocks2","ecBlocks","ECB","dataCodewords","Version","versionNumber","symbolSizeRows","symbolSizeColumns","dataRegionSizeRows","dataRegionSizeColumns","getECCodewords","ecbArray","getECBlocks","ecBlock","getDataCodewords","totalCodewords","numRows","numColumns","VERSIONS","version","buildVersions","Mode","BitMatrixParser","bitMatrix","readVersion","mappingBitMatrix","extractDataRegion","readMappingMatrix","Int8Array","getTotalCodewords","resultOffset","column","corner1Read","corner2Read","corner3Read","corner4Read","readUtah","readCorner4","readCorner3","readCorner2","readCorner1","currentByte","readModule","getSymbolSizeRows","getSymbolSizeColumns","getDataRegionSizeRows","getDataRegionSizeColumns","numDataRegionsRow","numDataRegionsColumn","bitMatrixWithoutAlignment","dataRegionRow","dataRegionRowOffset","dataRegionColumn","dataRegionColumnOffset","readRowOffset","writeRowOffset","readColumnOffset","writeColumnOffset","getVersionForDimensions","DataBlock","codewords","rawCodewords","totalBlocks","ecBlockArray","numResultBlocks","numBlockCodewords","longerBlocksNumDataCodewords","shorterBlocksNumDataCodewords","rawCodewordsOffset","specialVersion","getVersionNumber","numLongerBlocks","jOffset","iOffset","BitSource","byteOffset","available","bitsLeft","toRead","bitsToNotRead","DecodedBitStreamParser","resultTrailer","mode","ASCII_ENCODE","decodeAsciiSegment","C40_ENCODE","decodeC40Segment","TEXT_ENCODE","decodeTextSegment","ANSIX12_ENCODE","decodeAnsiX12Segment","EDIFACT_ENCODE","decodeEdifactSegment","BASE256_ENCODE","decodeBase256Segment","PAD_ENCODE","upperShift","oneByte","readBits","cValues","firstByte","parseTwoBytes","cValue","C40_BASIC_SET_CHARS","c40char","C40_SHIFT2_SET_CHARS","TEXT_BASIC_SET_CHARS","textChar","TEXT_SHIFT2_SET_CHARS","TEXT_SHIFT3_SET_CHARS","secondByte","fullBitValue","edifactValue","getBitOffset","codewordPosition","getByteOffset","d1","unrandomize255State","uee","randomizedBase256Codeword","base256CodewordPosition","tempVariable","Decoder$1","rsDecoder","parser","getVersion","readCodewords","dataBlocks","getDataBlocks","totalBytes","getNumDataCodewords","resultBytes","dataBlocksCount","dataBlock","codewordBytes","getCodewords","correctErrors","codewordsInts","Detector$1","rectangleDetector","detectSolid1","detectSolid2","correctTopRight","shiftToModuleCenter","dimensionTop","transitionsBetween","dimensionRight","trAB","trBC","trCD","trDA","tr","pointBs","shiftPoint","pointCs","trTop","trRight","pointAs","candidate1","candidate2","dimH","dimV","pointDs","centerX","centerY","moveAway","fromX","fromY","toX","toY","steep","ystep","xstep","transitions","inBlack","isBlack","div","DataMatrixReader","decoder","has","PURE_BARCODE","extractPureBits","NO_POINTS","DATA_MATRIX","leftTopBlack","getTopLeftOnBit","rightBottomBlack","getBottomRightOnBit","matrixWidth","matrixHeight","nudge","ErrorCorrectionLevelValues","BrowserDatamatrixCodeReader","ErrorCorrectionLevel","stringValue","FOR_BITS","FOR_VALUE","L","M","Q","H","FormatInformation","formatInfo","errorCorrectionLevel","forBits","dataMask","maskedFormatInfo1","maskedFormatInfo2","doDecodeFormatInformation","FORMAT_INFO_MASK_QR","bestDifference","bestFormatInfo","FORMAT_INFO_DECODE_LOOKUP","decodeInfo","targetInfo","bitsDifference","numBitsDiffering","DataMaskValues","ECBlocks$1","ecCodewordsPerBlock","getNumBlocks","ECB$1","Version$1","alignmentPatternCenters","getECCodewordsPerBlock","getDimensionForVersion","setRegion","getVersionForNumber","versionBits","bestVersion","VERSION_DECODE_INFO","targetVersion","DataMask","isMasked","flip","DATA_MASK_000","DATA_MASK_001","DATA_MASK_010","DATA_MASK_011","DATA_MASK_100","DATA_MASK_101","DATA_MASK_110","DATA_MASK_111","ModeValues","BitMatrixParser$1","parsedFormatInfo","formatInfoBits1","copyBit","formatInfoBits2","jMin","decodeFormatInformation","parsedVersion","provisionalVersion","ijMin","theParsedVersion","decodeVersionInformation","readFormatInformation","getDataMask","unmaskBitMatrix","functionPattern","buildFunctionPattern","readingUp","bitsRead","col","DataBlock$1","getECBlocksForLevel","shorterBlocksTotalCodewords","longerBlocksStartAt","Mode$1","characterCountBitsForVersions","TERMINATOR","NUMERIC","ALPHANUMERIC","STRUCTURED_APPEND","BYTE","ECI","KANJI","FNC1_FIRST_POSITION","FNC1_SECOND_POSITION","HANZI","DecodedBitStreamParser$1","symbolSequence","parityData","currentCharacterSetECI","fc1InEffect","modeBits","parseECIValue","getCharacterSetECIByValue","subset","countHanzi","getCharacterCountBits","GB2312_SUBSET","decodeHanziSegment","decodeNumericSegment","decodeAlphanumericSegment","decodeByteSegment","decodeKanjiSegment","iae","twoBytes","assembledTwoBytes","readBytes","guessEncoding","ALPHANUMERIC_CHARS","nextTwoCharsBits","toAlphaNumericChar","deleteCharAt","setCharAt","threeDigitsBits","twoDigitsBits","digitBits","QRCodeDecoderMetaData","mirrored","Decoder$2","decodeBitMatrix","parseFromBooleanArray","decodeBitMatrixParser","remask","setMirror","mirror","setOther","getErrorCorrectionLevel","AlignmentPattern","posX","posY","estimatedModuleSize","moduleSizeDiff","newModuleSize","AlignmentPatternFinder","startX","startY","possibleCenters","crossCheckStateCount","maxJ","middleI","stateCount","iGen","currentState","foundPatternCross","confirmed","handlePossibleCenter","maxVariance","startI","centerJ","maxCount","originalStateCountTotal","maxI","stateCountTotal","centerFromEnd","centerI","crossCheckVertical","isNaN","aboutEquals","combineEstimate","FinderPattern$1","combinedCount","FinderPatternInfo","patternCenters","FinderPatternFinder","pureBarcode","iSkip","MAX_MODULES","MIN_SKIP","hasSkipped","haveMultiplyConfirmedCenters","rowSkip","findRowSkip","patternInfo","selectBestPatterns","orderBestPatterns","getCrossCheckStateCount","startJ","crossCheckHorizontal","crossCheckDiagonal","firstConfirmedCenter","CENTER_QUORUM","confirmedCount","totalModuleSize","getEstimatedModuleSize","totalDeviation","startSize","square","stdDev","sort","center1","center2","dA","dB","limit","splice","Detector$2","processFinderPatternInfo","getTopLeft","getTopRight","getBottomLeft","calculateModuleSize","computeDimension","getProvisionalVersionForDimension","modulesBetweenFPCenters","alignmentPattern","getAlignmentPatternCenters","bottomRightX","bottomRightY","correctionToTopLeft","estAlignmentX","estAlignmentY","findAlignmentInRegion","createTransform","calculateModuleSizeOneWay","otherPattern","moduleSizeEst1","sizeOfBlackWhiteBlackRunBothWays","moduleSizeEst2","sizeOfBlackWhiteBlackRun","otherToX","otherToY","state","xLimit","realX","realY","overallEstModuleSize","allowanceFactor","allowance","alignmentAreaLeftX","alignmentAreaRightX","alignmentAreaTopY","alignmentAreaBottomY","sourceBottomRightX","sourceBottomRightY","dimMinusThree","tltrCentersDimension","tlblCentersDimension","QRCodeReader","getOther","applyMirroredCorrection","QR_CODE","hasStructuredAppend","STRUCTURED_APPEND_SEQUENCE","getStructuredAppendSequenceNumber","STRUCTURED_APPEND_PARITY","getStructuredAppendParity","nudgedTooFarRight","nudgedTooFarDown","PDF417Common","moduleBitCount","list","EMPTY_INT_ARRAY","integer","symbol","binarySearch","SYMBOL_TABLE","CODEWORD_TABLE","NUMBER_OF_CODEWORDS","MAX_CODEWORDS_IN_BARCODE","MIN_ROWS_IN_BARCODE","MAX_ROWS_IN_BARCODE","MODULES_IN_CODEWORD","MODULES_IN_STOP_PATTERN","BARS_IN_MODULE","PDF417DetectorResult","Detector$3","multiple","barcodeCoordinates","clone","rotate180","foundBarcodeInRow","vertices","findVertices","barcodeCoordinate","ROW_STEP","startRow","startColumn","copyToResult","findRowsWithPattern","INDEXES_START_PATTERN","STOP_PATTERN","INDEXES_STOP_PATTERN","tmpResult","destinationIndexes","loc","previousRowLoc","stopRow","skippedRowCount","MAX_PATTERN_DRIFT","SKIPPED_ROW_COUNT_MAX","BARCODE_MIN_HEIGHT","fillWithin","pixelDrift","MAX_PIXEL_DRIFT","ModulusPoly","add","negative","multiplyOther","negativeCoefficients","subtract","ModulusGF","modulus","PDF417_GF","ErrorCorrection","S","evaluation","knownErrors","erasure","getChecksumInstance","errorLocatorDegree","formalDerivativeCoefficients","formalDerivative","numerator","BoundingBox","constructor_2","constructor_1","leftUnspecified","rightUnspecified","minX","maxX","minY","maxY","boundingBox","getBottomRight","getMinX","getMaxX","getMinY","getMaxY","missingStartRows","missingEndRows","isLeft","newTopLeft","newBottomLeft","newTopRight","newBottomRight","newMinY","newTop","newMaxY","newBottom","leftBox","rightBox","BarcodeMetadata","columnCount","rowCountUpperPart","rowCountLowerPart","rowCount","Formatter","form","DetectionResultColumn","imageRow","codeword","getCodeword","MAX_NEARBY_DISTANCE","nearImageRow","imageRowToCodewordIndex","formatter","BarcodeValue","confidence","maxConfidence","entries","entry","getKey","toIntArray","DetectionResultRowIndicatorColumn","_isLeft","setRowNumberAsRowIndicatorColumn","barcodeMetadata","setRowNumbers","removeIncorrectCodewords","getBoundingBox","firstRow","lastRow","barcodeRow","maxRowHeight","currentRowHeight","codewordsRow","rowDifference","getRowCount","checkedRows","closePreviousCodewordFound","getBarcodeMetadata","adjustIncompleteIndicatorColumnRowNumbers","barcodeColumnCount","barcodeRowCountUpperPart","barcodeRowCountLowerPart","barcodeECLevel","rowIndicatorValue","codewordRowNumber","setValue","codewordRow","getRowCountUpperPart","getRowCountLowerPart","getColumnCount","DetectionResult","ADJUST_ROW_NUMBER_SKIP","detectionResultColumns","adjustIndicatorColumnRowNumbers","previousUnadjustedCount","unadjustedCodewordCount","adjustRowNumbersAndGetCount","detectionResultColumn","adjustCompleteIndicatorColumnRowNumbers","unadjustedCount","adjustRowNumbersByRow","barcodeColumn","hasValidRowNumber","adjustRowNumbers","adjustRowNumbersFromBothRI","adjustRowNumbersFromLRI","adjustRowNumbersFromRRI","LRIcodewords","RRIcodewords","setRowNumber","rowIndicatorRowNumber","invalidRowCounts","adjustRowNumberIfValid","previousColumnCodewords","nextColumnCodewords","otherCodewords","otherCodeword","adjustRowNumber","rowIndicatorColumn","isValidRowNumber","getBucket","Codeword","endX","bucket","BARCODE_ROW_UNKNOWN","PDF417CodewordDecoder","currentSymbol","currentBit","RATIOS_TABLE","fround","bSymbolTableReady","decodedValue","getDecodedCodewordValue","sampleBitCounts","getClosestDecodedValue","bitCountSum","bitCountIndex","sumPreviousBits","sampleIndex","getBitValue","bitCountRatios","bestMatchError","initialize","ratioTableRow","diff","PDF417ResultMetadata","segmentCount","fileSize","segmentIndex","fileId","optionalData","lastSegment","sender","addressee","fileName","Long","NullPointerException","Mode$2","BigInteger","OutputStream","writeBytesOffset","off","write","OutOfMemoryError","ByteArrayOutputStream","minCapacity","grow","newCapacity","copyOfUint8Array","out","param","toString_string","toString_number","toString_void","charsetName","hibyte","getBigIntConstructor","createBigInt","getEXP900","EXP900","nineHundred","DecodedBitStreamParser$2","enableDecoding","codeIndex","TEXT_COMPACTION_MODE_LATCH","textCompaction","BYTE_COMPACTION_MODE_LATCH","BYTE_COMPACTION_MODE_LATCH_6","byteCompaction","MODE_SHIFT_TO_BYTE_COMPACTION_MODE","NUMERIC_COMPACTION_MODE_LATCH","numericCompaction","ECI_CHARSET","ECI_GENERAL_PURPOSE","ECI_USER_DEFINED","BEGIN_MACRO_PDF417_CONTROL_BLOCK","decodeMacroBlock","BEGIN_MACRO_PDF417_OPTIONAL_FIELD","MACRO_PDF417_TERMINATOR","getFormatInstance","NUMBER_OF_SEQUENCE_CODEWORDS","segmentIndexArray","setSegmentIndex","decodeBase900toBase10","setFileId","optionalFieldsStart","MACRO_PDF417_OPTIONAL_FIELD_FILE_NAME","setFileName","MACRO_PDF417_OPTIONAL_FIELD_SENDER","setSender","MACRO_PDF417_OPTIONAL_FIELD_ADDRESSEE","setAddressee","MACRO_PDF417_OPTIONAL_FIELD_SEGMENT_COUNT","setSegmentCount","MACRO_PDF417_OPTIONAL_FIELD_TIME_STAMP","setTimestamp","parseLong","MACRO_PDF417_OPTIONAL_FIELD_CHECKSUM","setChecksum","MACRO_PDF417_OPTIONAL_FIELD_FILE_SIZE","setFileSize","setLastSegment","optionalFieldsLength","isLastSegment","setOptionalData","copyOfRange","textCompactionData","byteCompactionData","decodeTextCompaction","subMode","ALPHA","priorToShiftMode","subModeCh","LL","ML","PS","PUNCT_SHIFT","AS","ALPHA_SHIFT","PL","MIXED_CHARS","AL","PAL","PUNCT_CHARS","decodedBytes","byteCompactedCodewords","nextCode","toByteArray","numericCodewords","MAX_NUMERIC_CODEWORDS","PDF417ScanningDecoder","imageTopLeft","imageBottomLeft","imageTopRight","imageBottomRight","minCodewordWidth","maxCodewordWidth","detectionResult","leftRowIndicatorColumn","rightRowIndicatorColumn","firstPass","getRowIndicatorColumn","merge","resultBox","setBoundingBox","maxBarcodeColumn","getBarcodeColumnCount","setDetectionResultColumn","leftToRight","getDetectionResultColumn","previousStartColumn","getStartColumn","detectCodeword","setCodeword","createDecoderResult","adjustBoundingBox","rowHeights","getRowHeights","getMax","rowHeight","addMissingRows","maxValue","leftBarcodeMetadata","rightBarcodeMetadata","startPoint","getStartX","getEndX","barcodeMatrix","barcodeMatrix01","numberOfCodewords","calculatedNumberOfCodewords","getBarcodeRowCount","getNumberOfECCodeWords","getBarcodeECLevel","createBarcodeMatrix","adjustCodewordCount","ambiguousIndexValuesList","ambiguousIndexesList","codewordIndex","ambiguousIndexValues","createDecoderResultFromAmbiguousValues","erasureArray","ambiguousIndexes","ambiguousIndexCount","tries","decodeCodewords","getDetectionResultColumns","isValidBarcodeColumn","getCodewordNearby","skippedColumns","previousRowCodeword","minColumn","maxColumn","adjustCodewordStartColumn","endColumn","getModuleBitCount","codewordBitCount","tmpCount","checkCodewordSkew","getDecodedValue","getCodewordBucketNumber","imageColumn","moduleNumber","previousPixelValue","codewordStartColumn","correctedStartColumn","CODEWORD_SKEW_SIZE","correctedErrorsCount","verifyCodewordCount","setErrorsCorrected","setErasures","MAX_ERRORS","MAX_EC_CODEWORDS","errorCorrection","previousValue","getCodewordBucketNumber_Int32Array","getCodewordBucketNumber_number","getBitCountForCodeword","barcodeValue","getConfidence","PDF417Reader","results","detectMultiple","getMinCodewordWidth","getMaxCodewordWidth","PDF_417","pdf417ResultMetadata","PDF417_EXTRA_METADATA","getMaxWidth","getMinWidth","ReaderException","EncodeHintType","MultiFormatReader","setHints","decodeInternal","formats","addOneDReader","some","CODABAR","CODE_93","BrowserMultiFormatReader","decodeWithState","BrowserPDF417Reader","BrowserQRCodeReader","EncodeHintType$1","ReedSolomonEncoder","cachedGenerators","lastGenerator","nextGenerator","toEncode","ecBytes","dataBytes","buildGenerator","infoCoefficients","divide","getCoefficients","numZeroCoefficients","MaskUtil","applyMaskPenaltyRule1Internal","penalty","getArray","arrayY","N2","numPenalties","isWhiteHorizontal","isWhiteVertical","N3","numDarkCells","numTotalCells","N4","maskPattern","intermediate","isHorizontal","iLimit","jLimit","numSameBitCells","prevBit","N1","ByteMatrix","aByte","bytesY","otherBytesY","QRCode","NUM_MASK_PATTERNS","WriterException","MatrixUtil","dataBits","clearMatrix","embedBasicPatterns","embedTypeInfo","maybeEmbedVersionInfo","embedDataBits","embedPositionDetectionPatternsAndSeparators","embedDarkDotAtLeftBottomCorner","maybeEmbedPositionAdjustmentPatterns","embedTimingPatterns","typeInfoBits","makeTypeInfoBits","coordinates","TYPE_INFO_COORDINATES","setBoolean","versionInfoBits","makeVersionInfoBits","bitIndex","direction","isEmpty","getDataMaskBit","numberOfLeadingZeros","msbSetInPoly","findMSBSet","isValidMaskPattern","typeInfo","appendBits","bchCode","calculateBCHCode","TYPE_INFO_POLY","maskBits","TYPE_INFO_MASK_PATTERN","xor","VERSION_INFO_POLY","setNumber","xStart","yStart","patternY","POSITION_ADJUSTMENT_PATTERN","POSITION_DETECTION_PATTERN","pdpWidth","embedPositionDetectionPattern","hspWidth","embedHorizontalSeparationPattern","vspSize","embedVerticalSeparationPattern","POSITION_ADJUSTMENT_PATTERN_COORDINATE_TABLE","embedPositionAdjustmentPattern","BlockPair","errorCorrectionBytes","Encoder","applyMaskPenaltyRule1","applyMaskPenaltyRule2","applyMaskPenaltyRule3","applyMaskPenaltyRule4","content","DEFAULT_BYTE_MODE_ENCODING","hasEncodingHint","chooseMode","headerBits","eci","appendECI","appendModeInfo","appendBytes","QR_VERSION","bitsNeeded","calculateBitsNeeded","willFit","recommendVersion","headerAndDataBits","appendBitArray","numLetters","getSizeInBytes","appendLengthInfo","numDataBytes","getTotalECCodewords","terminateBits","finalBits","interleaveWithECBytes","qrCode","setECLevel","setMode","setVersion","chooseMaskPattern","setMaskPattern","buildMatrix","setMatrix","provisionalBitsNeeded","chooseVersion","ALPHANUMERIC_TABLE","isOnlyDoubleByteKanji","hasNumeric","hasAlphanumeric","isDigit","getAlphanumericCode","byte1","minPenalty","bestMaskPattern","calculateMaskPenalty","numInputBits","versionNum","capacity","numBitsInLastByte","numPaddingBytes","numTotalBytes","numRSBlocks","blockID","numDataBytesInBlock","numECBytesInBlock","numRsBlocksInGroup2","numRsBlocksInGroup1","numTotalBytesInGroup1","numTotalBytesInGroup2","numDataBytesInGroup1","numDataBytesInGroup2","numEcBytesInGroup1","numEcBytesInGroup2","dataBytesOffset","maxNumDataBytes","maxNumEcBytes","blocks","numEcBytesInBlock","getNumDataBytesAndNumECBytesForBlockID","toBytes","generateECBytes","getDataBytes","getErrorCorrectionBytes","appendNumericBytes","appendAlphanumericBytes","append8BitBytes","appendKanjiBytes","singleCharacter","cn","getDigit","num1","num2","num3","code1","code2","subtracted","BrowserQRCodeSvgWriter","contents","quietZone","QUIET_ZONE_SIZE","ERROR_CORRECTION","fromString","MARGIN","renderResult","containerElement","querySelector","svgElement","appendChild","input","inputWidth","inputHeight","qrWidth","qrHeight","outputWidth","outputHeight","leftPadding","topPadding","createSVGElement","inputY","outputY","inputX","outputX","svgRectElement","createSvgRectElement","w","createElementNS","SVG_NS","setAttributeNS","rect","QRCodeWriter","output","MultiFormatWriter","PlanarYUVLuminanceSource","yuvData","dataWidth","dataHeight","reverseHorizontal","area","inputOffset","outputOffset","THUMBNAIL_SCALE_FACTOR","pixels","yuv","grey","rowStart","RGBLuminanceSource","BYTES_PER_ELEMENT","luminancesUint8Array","g2","Charset","StandardCharsets","ISO_8859_1","AztecCode","codeWords","Collections","item","collection","SimpleToken","bitArray","byteCount","toBinaryString","BinaryShiftToken","binaryShiftStart","binaryShiftByteCount","addBinaryShift","token","MODE_NAMES","MODE_UPPER","MODE_LOWER","MODE_DIGIT","MODE_MIXED","MODE_PUNCT","EMPTY_TOKEN","LATCH_TABLE","static_SHIFT_TABLE","SHIFT_TABLE","createInt32Array","State","binaryBytes","latch","latchModeBitCount","thisModeBitCount","deltaBitCount","endBinaryShift","newModeBitCount","calculateBinaryShiftCost","symbols","getPrevious","appendTo","static_CHAR_MAP","CHAR_MAP","spaceCharCode","getCharCode","pointCharCode","commaCharCode","zUpperCharCode","aUpperCharCode","zLowerCharCode","aLowerCharCode","nineCharCode","zeroCharCode","mixedTable","punctTable","INITIAL_STATE","HighLevelEncoder","lineBreakCharCode","states","singletonList","pairCode","nextChar","updateStateListForPair","updateStateListForChar","getBitCount","toBitArray","updateStateForChar","simplifyStates","charInCurrentTable","getMode","stateNoBinary","charInMode","latchState","latchAndAppend","shiftState","shiftAndAppend","getBinaryShiftByteCount","binaryState","addBinaryShiftChar","updateStateForPair","digitState","newState","oldState","isBetterThanOrEqualTo","filter","Encoder$1","DEFAULT_EC_PERCENT","DEFAULT_AZTEC_LAYERS","minECCPercent","userSpecifiedLayers","wordSize","eccBits","totalSizeBits","MAX_NB_BITS_COMPACT","MAX_NB_BITS","usableBitsInLayers","WORD_SIZE","stuffBits","messageBits","generateCheckWords","messageSizeInWords","modeMessage","generateModeMessage","drawModeMessage","drawBullsEye","aztec","setCompact","setSize","setLayers","setCodeWords","totalBits","getGF","totalWords","messageWords","bitsToWords","startPad","messageWord","word","AztecWriter","encodeWithHints","charset","eccPercent","forName","AZTEC_LAYERS","encodeLayers","getBytes","AztecCodeReader","AztecCodeWriter","AztecDecoder","AztecDetector","AztecEncoder","AztecHighLevelEncoder","AztecPoint","DataMatrixDecodedBitStreamParser","PDF417DecodedBitStreamParser","PDF417DecoderErrorCorrection","QRCodeByteMatrix","QRCodeDataMask","QRCodeDecodedBitStreamParser","QRCodeDecoderErrorCorrectionLevel","QRCodeDecoderFormatInformation","QRCodeEncoder","QRCodeEncoderQRCode","QRCodeMaskUtil","QRCodeMatrixUtil","QRCodeMode","QRCodeVersion","ZXingArrays","ZXingCharset","ZXingInteger","ZXingStandardCharsets","ZXingStringBuilder","ZXingStringEncoding","ZXingSystem","factory","aa","require","ca","da","Set","ea","fa","ha","ia","ja","ka","la","ma","g","acceptsBooleans","attributeName","attributeNamespace","mustUseProperty","propertyName","sanitizeURL","removeEmptyString","ra","sa","toUpperCase","ta","pa","qa","test","oa","xlinkHref","ua","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","va","Symbol","for","wa","ya","za","Aa","Ba","Ca","Da","Ea","Fa","Ga","Ha","Ia","Ja","iterator","Ka","La","A","assign","Ma","stack","trim","match","Na","Oa","prepareStackTrace","Reflect","construct","l","displayName","Pa","tag","render","Qa","$$typeof","_context","_payload","_init","Ra","Sa","Ta","Va","_valueTracker","getOwnPropertyDescriptor","configurable","stopTracking","Ua","Wa","checked","Xa","activeElement","body","Ya","defaultChecked","defaultValue","_wrapperState","initialChecked","Za","initialValue","controlled","ab","bb","cb","db","eb","isArray","fb","options","selected","defaultSelected","disabled","gb","dangerouslySetInnerHTML","children","hb","ib","jb","textContent","kb","lb","mb","nb","namespaceURI","innerHTML","valueOf","firstChild","removeChild","MSApp","execUnsafeLocalFunction","ob","lastChild","nodeType","nodeValue","pb","animationIterationCount","aspectRatio","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columns","flex","flexGrow","flexPositive","flexShrink","flexNegative","flexOrder","gridArea","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","fontWeight","lineClamp","lineHeight","opacity","order","orphans","tabSize","widows","zIndex","zoom","fillOpacity","floodOpacity","stopOpacity","strokeDasharray","strokeDashoffset","strokeMiterlimit","strokeOpacity","strokeWidth","qb","rb","sb","setProperty","keys","tb","menuitem","br","embed","hr","keygen","link","meta","track","wbr","ub","vb","is","wb","xb","correspondingUseElement","parentNode","yb","zb","Ab","Bb","Cb","stateNode","Db","Eb","Fb","Gb","Hb","Ib","Jb","Kb","Lb","Mb","Nb","onError","Ob","Pb","Qb","Rb","Sb","Tb","Vb","alternate","return","flags","Wb","memoizedState","dehydrated","Xb","Zb","child","sibling","Yb","$b","ac","unstable_scheduleCallback","bc","unstable_cancelCallback","cc","unstable_shouldYield","dc","unstable_requestPaint","B","unstable_now","ec","unstable_getCurrentPriorityLevel","fc","unstable_ImmediatePriority","gc","unstable_UserBlockingPriority","hc","unstable_NormalPriority","ic","unstable_LowPriority","jc","unstable_IdlePriority","kc","lc","oc","clz32","pc","qc","LN2","rc","sc","tc","uc","pendingLanes","suspendedLanes","pingedLanes","entangledLanes","entanglements","vc","xc","yc","zc","Ac","eventTimes","Cc","C","Dc","Ec","Fc","Gc","Hc","Ic","Jc","Kc","Lc","Mc","Nc","Oc","Pc","Qc","Rc","Sc","pointerId","Tc","nativeEvent","blockedOn","domEventName","eventSystemFlags","targetContainers","Vc","Wc","priority","isDehydrated","containerInfo","Xc","Yc","dispatchEvent","Zc","$c","ad","bd","cd","ReactCurrentBatchConfig","dd","ed","transition","fd","gd","hd","Uc","stopPropagation","jd","kd","ld","md","nd","od","keyCode","pd","qd","rd","_reactName","_targetInst","currentTarget","isDefaultPrevented","defaultPrevented","returnValue","isPropagationStopped","preventDefault","cancelBubble","persist","isPersistent","wd","xd","yd","sd","eventPhase","bubbles","cancelable","timeStamp","isTrusted","td","ud","view","detail","vd","Ad","screenX","screenY","clientX","clientY","pageX","pageY","ctrlKey","shiftKey","altKey","metaKey","getModifierState","zd","button","buttons","relatedTarget","fromElement","toElement","movementX","movementY","Bd","Dd","dataTransfer","Fd","Hd","animationName","elapsedTime","pseudoElement","Id","clipboardData","Jd","Ld","Md","Esc","Spacebar","Left","Up","Right","Down","Del","Win","Menu","Apps","Scroll","MozPrintableKey","Nd","Od","Alt","Control","Meta","Shift","Pd","Qd","location","repeat","locale","which","Rd","Td","pressure","tangentialPressure","tiltX","tiltY","twist","pointerType","isPrimary","Vd","touches","targetTouches","changedTouches","Xd","Yd","deltaX","wheelDeltaX","deltaY","wheelDeltaY","wheelDelta","deltaZ","deltaMode","Zd","$d","ae","be","documentMode","ce","de","ee","fe","ge","he","ie","le","date","datetime","email","number","password","range","search","tel","time","week","me","ne","oe","event","listeners","pe","qe","se","te","ue","ve","we","xe","ye","ze","oninput","Ae","detachEvent","Be","Ce","attachEvent","De","Ee","Fe","He","Ie","Je","Ke","node","nextSibling","Le","contains","compareDocumentPosition","Me","HTMLIFrameElement","contentWindow","href","Ne","contentEditable","Oe","focusedElem","selectionRange","documentElement","selectionStart","selectionEnd","defaultView","getSelection","extend","rangeCount","anchorNode","anchorOffset","focusNode","focusOffset","createRange","setStart","removeAllRanges","addRange","setEnd","scrollLeft","scrollTop","focus","Pe","Qe","Re","Se","Te","Ue","Ve","We","animationend","animationiteration","animationstart","transitionend","Xe","Ye","Ze","animation","$e","af","bf","cf","df","ef","ff","hf","lf","mf","concat","nf","Ub","instance","listener","D","of","pf","qf","rf","random","sf","bind","capture","passive","J","u","F","tf","uf","parentWindow","vf","wf","na","xa","$a","ba","je","char","ke","xf","yf","zf","Af","Bf","Cf","Df","Ef","__html","Ff","Gf","clearTimeout","Hf","Jf","queueMicrotask","catch","If","Kf","Lf","Mf","previousSibling","Nf","Of","Pf","Qf","Rf","Sf","Tf","Uf","E","G","Vf","Wf","Xf","Yf","contextTypes","__reactInternalMemoizedUnmaskedChildContext","__reactInternalMemoizedMaskedChildContext","Zf","childContextTypes","$f","ag","bg","getChildContext","cg","__reactInternalMemoizedMergedChildContext","dg","eg","fg","gg","hg","jg","kg","lg","mg","ng","og","pg","qg","rg","sg","tg","ug","vg","wg","xg","yg","I","zg","Ag","Bg","elementType","deletions","Cg","pendingProps","overflow","treeContext","retryLane","Dg","Eg","Fg","Gg","memoizedProps","Hg","Ig","Jg","Kg","Lg","defaultProps","Mg","Ng","Og","Pg","Qg","Rg","_currentValue","Sg","childLanes","Tg","dependencies","firstContext","lanes","Ug","Vg","context","memoizedValue","Wg","Xg","Yg","interleaved","Zg","$g","ah","updateQueue","baseState","firstBaseUpdate","lastBaseUpdate","shared","pending","effects","bh","eventTime","lane","payload","dh","K","eh","fh","gh","hh","ih","jh","Component","refs","kh","nh","isMounted","_reactInternals","enqueueSetState","lh","mh","enqueueReplaceState","enqueueForceUpdate","oh","shouldComponentUpdate","isPureReactComponent","ph","contextType","updater","qh","componentWillReceiveProps","UNSAFE_componentWillReceiveProps","rh","props","getDerivedStateFromProps","getSnapshotBeforeUpdate","UNSAFE_componentWillMount","componentWillMount","componentDidMount","sh","ref","_owner","_stringRef","th","join","uh","vh","wh","xh","yh","implementation","zh","Ah","Bh","Ch","Dh","Eh","Fh","Gh","Hh","Ih","tagName","Jh","Kh","Lh","Mh","revealOrder","Nh","Oh","_workInProgressVersionPrimary","Ph","ReactCurrentDispatcher","Qh","Rh","N","O","Sh","Th","Uh","Vh","Wh","Xh","Yh","Zh","$h","bi","ci","baseQueue","queue","di","ei","fi","lastRenderedReducer","action","hasEagerState","eagerState","lastRenderedState","dispatch","gi","hi","ii","ji","ki","getSnapshot","li","mi","ni","lastEffect","stores","oi","pi","qi","ri","destroy","deps","si","ui","vi","wi","Ai","Bi","Ci","Di","Ei","Fi","Gi","Hi","Ii","Ji","readContext","useCallback","useContext","useEffect","useImperativeHandle","useInsertionEffect","useLayoutEffect","useMemo","useReducer","useRef","useState","useDebugValue","useDeferredValue","useTransition","useMutableSource","useSyncExternalStore","useId","unstable_isNewReconciler","identifierPrefix","Ki","digest","Li","Mi","Ni","WeakMap","Oi","Pi","Qi","Ri","getDerivedStateFromError","componentDidCatch","Si","componentStack","Ti","pingCache","Ui","Vi","Wi","Xi","ReactCurrentOwner","Yi","Zi","$i","aj","bj","compare","cj","dj","ej","baseLanes","cachePool","fj","gj","hj","ij","jj","UNSAFE_componentWillUpdate","componentWillUpdate","componentDidUpdate","kj","lj","pendingContext","mj","Aj","Cj","Dj","nj","oj","pj","fallback","qj","rj","dataset","dgst","uj","vj","_reactRetry","sj","subtreeFlags","wj","isBackwards","rendering","renderingStartTime","tail","tailMode","Ej","Fj","Gj","wasMultiple","suppressHydrationWarning","onClick","onclick","autoFocus","createTextNode","T","Hj","Ij","Jj","Kj","U","Lj","WeakSet","V","Mj","W","Nj","Oj","Qj","Rj","Sj","Tj","Uj","Vj","Wj","insertBefore","_reactRootContainer","Xj","X","Yj","Zj","ak","onCommitFiberUnmount","componentWillUnmount","bk","ck","dk","ek","fk","isHidden","gk","hk","display","ik","jk","kk","lk","__reactInternalSnapshotBeforeUpdate","Wk","mk","nk","ok","pk","Y","Z","qk","rk","sk","tk","uk","Infinity","vk","wk","xk","yk","zk","Ak","Bk","Ck","Dk","Ek","callbackNode","expirationTimes","expiredLanes","wc","callbackPriority","ig","Fk","Gk","Hk","Ik","Jk","Kk","Lk","Mk","Nk","Ok","Pk","finishedWork","finishedLanes","Qk","timeoutHandle","Rk","Sk","Tk","Uk","Vk","mutableReadLanes","Bc","Pj","onCommitFiberRoot","mc","onRecoverableError","Xk","onPostCommitFiberRoot","Yk","Zk","al","isReactComponent","pendingChildren","bl","mutableSourceEagerHydrationData","cl","cache","pendingSuspenseBoundaries","dl","fl","gl","hl","il","jl","$k","ll","reportError","ml","_internalRoot","nl","ol","pl","ql","sl","rl","unmount","unstable_scheduleHydration","querySelectorAll","tl","usingClientEntryPoint","Events","ul","findFiberByHostInstance","bundleType","rendererPackageName","vl","rendererConfig","overrideHookState","overrideHookStateDeletePath","overrideHookStateRenamePath","overrideProps","overridePropsDeletePath","overridePropsRenamePath","setErrorHandler","setSuspenseHandler","scheduleUpdate","currentDispatcherRef","findHostInstanceByFiber","findHostInstancesForRefresh","scheduleRefresh","scheduleRoot","setRefreshHandler","getCurrentFiber","reconcilerVersion","__REACT_DEVTOOLS_GLOBAL_HOOK__","wl","isDisabled","supportsFiber","inject","createPortal","createRoot","unstable_strictMode","findDOMNode","flushSync","hydrate","hydrateRoot","hydratedSources","_getVersion","_source","unmountComponentAtNode","unstable_batchedUpdates","unstable_renderSubtreeIntoContainer","checkDCE","module","__self","__source","jsx","jsxs","setState","forceUpdate","escape","_status","_result","default","Children","toArray","only","Fragment","Profiler","PureComponent","StrictMode","Suspense","cloneElement","createContext","_currentValue2","_threadCount","Provider","Consumer","_defaultValue","_globalName","createFactory","createRef","forwardRef","isValidElement","lazy","memo","startTransition","unstable_act","pop","sortIndex","performance","setImmediate","startTime","expirationTime","priorityLevel","scheduling","isInputPending","MessageChannel","port2","port1","onmessage","postMessage","unstable_Profiling","unstable_continueExecution","unstable_forceFrameRate","unstable_getFirstCallbackNode","unstable_next","unstable_pauseExecution","unstable_runWithPriority","delay","unstable_wrapCallback","arr2","__esModule","ReferenceError","Constructor","TypeError","_defineProperties","descriptor","writable","protoProps","staticProps","unsupportedIterableToArray","allowArrayLike","it","_e","normalCompletion","didErr","_e2","getPrototypeOf","isNativeReflectConstruct","possibleConstructorReturn","Derived","hasNativeReflectConstruct","Super","NewTarget","superPropBase","_get","property","receiver","desc","_getPrototypeOf","subClass","superClass","sham","Proxy","Boolean","_i","_s","_arr","_n","_d","_typeof","assertThisInitialized","_regeneratorRuntime","Op","hasOwn","obj","$Symbol","iteratorSymbol","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","toStringTag","define","wrap","innerFn","outerFn","tryLocsList","protoGenerator","Generator","Context","makeInvokeMethod","tryCatch","arg","ContinueSentinel","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","NativeIteratorPrototype","Gp","defineIteratorMethods","method","_invoke","AsyncIterator","PromiseImpl","invoke","record","__await","unwrapped","previousPromise","callInvokeWithMethodAndArg","doneResult","delegateResult","maybeInvokeDelegate","sent","_sent","dispatchException","abrupt","resultName","nextLoc","pushTryEntry","locs","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","iterable","iteratorMethod","isGeneratorFunction","genFun","ctor","mark","awrap","async","iter","object","skipTempReset","prev","rootRecord","rval","handle","caught","hasCatch","hasFinally","finallyEntry","finish","thrown","delegateYield","_setPrototypeOf","arrayWithHoles","iterableToArrayLimit","nonIterableRest","arrayLikeToArray","minLen","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","definition","chunkId","all","promises","miniCssF","Function","prop","inProgress","dataWebpackPrefix","script","needAttach","scripts","getElementsByTagName","getAttribute","timeout","nc","onScriptComplete","onerror","onload","doneFns","head","installedChunks","installedChunkData","promise","errorType","realSrc","request","webpackJsonpCallback","parentChunkLoadingFunction","chunkIds","moreModules","runtime","chunkLoadingGlobal","_arrayLikeToArray","_unsupportedIterableToArray","_defineProperty","ownKeys","enumerableOnly","getOwnPropertySymbols","sym","_objectSpread2","getOwnPropertyDescriptors","defineProperties","asyncGeneratorStep","gen","_next","_throw","_asyncToGenerator","_classCallCheck","_createClass","KioskState","KeyboardManager","keyboardState","onKeydown","onKeyup","gamepadIndex","checkPressed","configData","GamepadManager","cachedGamepads","cacheExpires","minButtonPinRequired","minAxisRequired","keyboardManager","getGamepads","axes","gamepads","pinIndex","isButtonPressed","validateGamepadIndex","pressed","isAButtonPressed","isBButtonPressed","isEscapeButtonPressed","isResetButtonPressed","isMenuButtonPressed","axisIndex","isDirectionPressed","gamepad","isLeftPressed","isRightPressed","isUpPressed","isDownPressed","HighScore","initials","GameData","description","highScoreMode","uniqueIdentifier","userAdded","deleted","kioskBackendEndpoint","getGameCodesAsync","kioskCode","getGameCodeUrl","fetch","response","statusText","json","shareIds","gameCodeEntries","parse","generateKioskCodeAsync","codeGenerationUrl","newKioskCode","addGameToKioskAsync","kioskId","gameShareId","updateKioskUrl","headers","status","getGameDetailsAsync","gameId","gameDetailsUrl","tickEvent","pxtTickEvent","Kiosk","clean","locked","games","gamepadManager","selectedGame","selectedGameIndex","mostRecentScores","onGameSelected","onNavigated","launchedGame","MainMenu","highScoresLocalStorageKey","addedGamesLocalStorageKey","initializePromise","siteElements","intervalId","allScoresStateKey","lockedGameId","builtGamesCache","defaultGameDescription","addNewGamesToList","allAddedGames","getAllAddedGames","gamesToAdd","gameIds","gameName","gameDescription","gameDetails","getGameName","getGameDescription","gameUploadDate","toLocaleString","newGame","selectGame","localStorage","setItem","getItem","addedGames","game","resetHighScores","PlayingGame","escapeGame","showMainMenu","downloadGameListAsync","setInterval","gamePadLoop","js","getBuiltGame","sendBuiltGame","addBuiltGame","command","stateKey","rawData","atob","stateValue","gameOver","parts","channel","clearInterval","navigate","gameIndex","launchedGameHighs","getHighScores","currentHighScore","lastScore","exitGame","GameOver","EnterHighScore","skipHighScore","launchGame","exitToEnterHighScore","gamespace","remove","allBuiltGames","builtSimJs","builtGame","simIframe","preventReturningToMenu","playUrlBase","playQueryParam","playerIFrame","createIFrame","iframe","className","frameBorder","AddingGame","allHighScores","getAllHighScores","removeItem","specificButtonClass","kioskButtonClass","_objectWithoutProperties","excluded","sourceKeys","sourceSymbolKeys","propertyIsEnumerable","_toConsumableArray","isObject","ssrDocument","blur","createEvent","initEvent","childNodes","importNode","host","hostname","origin","pathname","protocol","getDocument","doc","ssrWindow","userAgent","history","replaceState","pushState","go","back","CustomEvent","getComputedStyle","getPropertyValue","Image","screen","matchMedia","requestAnimationFrame","cancelAnimationFrame","getWindow","win","_assertThisInitialized","_possibleConstructorReturn","_isNativeReflectConstruct","_construct","Parent","Class","_wrapNativeSuper","_cache","Wrapper","Dom7","items","proto","makeReactive","arrayFlat","arrayFilter","$","selector","html","toCreate","tempParent","qsa","uniqueArray","arrayUnique","noTrigger","shortcut","trigger","on","Methods","addClass","classes","classNames","classList","removeClass","hasClass","toggleClass","toggle","attr","attrs","attrName","removeAttr","duration","transitionDuration","eventType","targetSelector","handleLiveEvent","eventData","dom7EventData","parents","handleEvent","events","dom7LiveListeners","proxyListener","dom7Listeners","handlers","handler","dom7proxy","evt","dataIndex","transitionEnd","dom","fireCallBack","outerWidth","includeMargins","styles","offsetWidth","outerHeight","offsetHeight","box","getBoundingClientRect","clientTop","clientLeft","scrollY","scrollX","css","each","compareWith","matches","webkitMatchesSelector","msMatchesSelector","eq","returnIndex","newChild","tempDiv","prepend","nextElementSibling","nextAll","nextEls","previousElementSibling","prevAll","prevEls","parent","closest","foundElements","methodName","support","deviceCached","browser","deleteProps","nextTick","currentStyle","getTranslate","curTransform","transformMatrix","axis","curStyle","WebKitCSSMatrix","webkitTransform","MozTransform","OTransform","MsTransform","msTransform","m41","m42","isNode","HTMLElement","noExtend","nextSource","keysArray","nextIndex","nextKey","__swiper__","setCSSProperty","varName","varValue","animateCSSModeScroll","swiper","targetPosition","startPosition","params","speed","wrapperEl","scrollSnapType","cssModeFrameID","dir","isOutOfBound","animate","progress","easeProgress","scrollTo","getSupport","smoothScroll","touch","DocumentTouch","passiveListener","supportsPassive","opts","gestures","calcSupport","calcDevice","platform","ios","android","screenWidth","screenHeight","ipad","ipod","iphone","windows","macos","iPadScreens","os","getDevice","overrides","getBrowser","isSafari","isWebView","calcBrowser","eventsListeners","destroyed","once","onceHandler","__emitterProxy","onAny","eventsAnyListeners","offAny","eventHandler","emit","eventsArray","updateSize","$el","clientWidth","clientHeight","isVertical","updateSlides","getDirectionLabel","getDirectionPropertyValue","$wrapperEl","swiperSize","rtl","rtlTranslate","wrongRTL","isVirtual","virtual","enabled","previousSlidesLength","slides","slideClass","slidesLength","snapGrid","slidesGrid","slidesSizesGrid","offsetBefore","slidesOffsetBefore","offsetAfter","slidesOffsetAfter","previousSnapGridLength","previousSlidesGridLength","spaceBetween","slidePosition","prevSlideSize","virtualSize","marginLeft","marginBottom","marginTop","marginRight","centeredSlides","cssMode","slideSize","gridEnabled","grid","initSlides","shouldResetSlideSize","slidesPerView","breakpoints","slide","updateSlide","slideStyles","currentTransform","currentWebKitTransform","roundLengths","paddingLeft","paddingRight","boxSizing","swiperSlideSize","slidesPerGroup","slidesPerGroupSkip","effect","setWrapperSize","updateWrapperSize","newSlidesGrid","slidesGridItem","_","slideIndex","centeredSlidesBounds","allSlidesSize","slideSizeValue","maxSnap","snap","centerInsufficientSlides","allSlidesOffset","snapIndex","addToSnapGrid","addToSlidesGrid","watchOverflow","checkOverflow","watchSlidesProgress","updateSlidesOffset","backFaceHiddenClass","containerModifierClass","hasClassBackfaceClassAdded","maxBackfaceHiddenSlides","updateAutoHeight","activeSlides","setTransition","getSlideByIndex","visibleSlides","activeIndex","swiperSlideOffset","offsetLeft","offsetTop","updateSlidesProgress","offsetCenter","slideVisibleClass","visibleSlidesIndexes","slideOffset","slideProgress","minTranslate","originalSlideProgress","slideBefore","slideAfter","isVisible","originalProgress","updateProgress","translatesDiff","maxTranslate","isBeginning","isEnd","wasBeginning","wasEnd","autoHeight","updateSlidesClasses","activeSlide","realIndex","slideActiveClass","slideNextClass","slidePrevClass","slideDuplicateActiveClass","slideDuplicateNextClass","slideDuplicatePrevClass","slideDuplicateClass","nextSlide","prevSlide","emitSlidesClasses","updateActiveIndex","newActiveIndex","previousIndex","previousRealIndex","previousSnapIndex","normalizeSlideIndex","skip","initialized","runCallbacksOnInit","updateClickedSlide","slideFound","clickedSlide","clickedIndex","slideToClickedSlide","virtualTranslate","currentTranslate","setTranslate","byController","previousTranslate","translateTo","runCallbacks","translateBounds","internal","animating","preventInteractionOnTransition","newTranslate","isH","onTranslateToWrapperTransitionEnd","transitionEmit","transitionStart","slideTo","initial","indexAsNumber","isValidNumber","isFinite","normalizedTranslate","normalizedGrid","normalizedGridNext","allowSlideNext","allowSlidePrev","_immediateVirtual","_swiperImmediateVirtual","onSlideToWrapperTransitionEnd","slideToLoop","newIndex","loopedSlides","slideNext","perGroup","slidesPerGroupAuto","slidesPerViewDynamic","loopPreventsSlide","loopFix","_clientLeft","rewind","slidePrev","normalize","prevSnapIndex","normalizedSnapGrid","prevSnap","prevIndex","lastIndex","slideReset","slideToClosest","currentSnap","nextSnap","slideToIndex","loopCreate","$selector","loopFillGroupWithBlank","blankSlidesNum","blankNode","slideBlankClass","loopAdditionalSlides","loopedSlidesLimit","prependSlides","appendSlides","cloneNode","loopDestroy","onTouchStart","touchEventsData","originalEvent","$targetEl","touchEventsTarget","isTouchEvent","isTouched","isMoved","swipingClassHasValue","noSwipingClass","eventPath","composedPath","path","shadowRoot","noSwipingSelector","isTargetShadow","noSwiping","__closestFrom","assignedSlot","getRootNode","closestElement","allowClick","swipeHandler","currentX","currentY","edgeSwipeDetection","iOSEdgeSwipeDetection","edgeSwipeThreshold","iOSEdgeSwipeThreshold","innerWidth","allowTouchCallbacks","isScrolling","startMoving","touchStartTime","swipeDirection","allowThresholdMove","focusableElements","shouldPreventDefault","allowTouchMove","touchStartPreventDefault","touchStartForcePreventDefault","isContentEditable","freeMode","onTouchMove","targetTouch","preventedByNestedSwiper","touchReleaseOnEdges","diffX","diffY","touchAngle","atan2","touchMoveStopPropagation","nested","startTranslate","allowMomentumBounce","grabCursor","setGrabCursor","touchRatio","disableParentSwiper","resistanceRatio","resistance","followFinger","onTouchEnd","touchEndTime","timeDiff","pathTree","lastClickTime","stopIndex","groupSize","rewindFirstIndex","rewindLastIndex","longSwipesMs","longSwipes","longSwipesRatio","shortSwipes","navigation","nextEl","prevEl","onResize","setBreakpoint","autoplay","running","run","preventClicks","preventClicksPropagation","stopImmediatePropagation","onScroll","dummyEventAttached","dummyEventListener","touchEvents","domMethod","swiperMethod","passiveListeners","move","cancel","updateOnWindowResize","attachEvents","detachEvents","isGridEnabled","breakpoint","getBreakpoint","breakpointsBase","currentBreakpoint","breakpointParams","originalParams","wasMultiRow","isMultiRow","wasEnabled","emitContainerClasses","wasModuleEnabled","isModuleEnabled","disable","enable","directionChanged","needsReLoop","changeDirection","isEnabled","containerEl","currentHeight","innerHeight","minRatio","addClasses","suffixes","prefix","resultClasses","prepareClasses","removeClasses","initialSlide","resizeObserver","createElements","simulateTouch","uniqueNavElements","preloadImages","updateOnImagesReady","wrapperClass","_emitClasses","moduleExtendParams","allModulesParams","moduleParamName","moduleParams","auto","prototypes","eventsEmitter","update","moving","isLocked","cursor","unsetGrabCursor","wasLocked","lastSlideIndex","lastSlideRightEdge","images","loadImage","imageEl","srcset","sizes","checkForComplete","onReady","imagesLoaded","imagesToLoad","currentSrc","extendedDefaults","Swiper","swipers","newParams","modules","__modules__","mod","extendParams","swiperParams","defaults","passedParams","eventName","velocity","desktop","touchEventsTouch","touchEventsDesktop","clickTimeout","velocities","cls","slideEl","updates","getSlideClasses","spv","breakLoop","slideInView","translateValue","newDirection","needUpdate","currentDirection","mounted","getWrapperSelector","getWrapper","wrapper","mount","deleteInstance","cleanStyles","newDefaults","installModule","prototypeGroup","protoMethod","use","observer","animationFrame","resizeHandler","orientationChangeHandler","ResizeObserver","contentBoxSize","contentRect","inlineSize","blockSize","observe","unobserve","observers","attach","ObserverFunc","MutationObserver","WebkitMutationObserver","mutations","observerUpdate","attributes","childList","characterData","observeParents","observeSlideChildren","containerParents","disconnect","Keyboard","pageUpDown","keyboard","isPageUp","isPageDown","isArrowLeft","isArrowRight","isArrowUp","isArrowDown","onlyInViewport","inView","swiperWidth","swiperHeight","windowWidth","windowHeight","swiperOffset","swiperCoord","classesToSelector","Pagination","bulletSize","pfx","pagination","bulletElement","clickable","hideOnClick","renderBullet","renderProgressbar","renderFraction","renderCustom","progressbarOpposite","dynamicBullets","dynamicMainBullets","formatFractionCurrent","formatFractionTotal","bulletClass","bulletActiveClass","modifierClass","currentClass","totalClass","hiddenClass","progressbarFillClass","progressbarOppositeClass","clickableClass","lockClass","horizontalClass","verticalClass","paginationDisabledClass","bullets","dynamicBulletIndex","isPaginationDisabled","setSideBullets","$bulletEl","paginationType","firstIndex","midIndex","suffix","bullet","$bullet","bulletIndex","$firstDisplayedBullet","$lastDisplayedBullet","dynamicBulletsLength","bulletsOffset","offsetProp","progressbarDirection","scaleX","scaleY","paginationHTML","numberOfBullets","checkProps","createElementIfNotDefined","targetEl","createShadow","$slideEl","shadowClass","$shadowContainer","transformEl","$shadowEl","effectTarget","effectParams","EffectCoverflow","coverflowEffect","stretch","depth","modifier","slideShadows","requireUpdateOnVirtual","overwriteParams","perspective","recreateShadows","getEffectParams","overwriteParamsResult","effectInit","centerOffset","offsetMultiplier","rotateY","rotateX","translateZ","translateY","translateX","slideTransform","$shadowBeforeEl","$shadowAfterEl","needsNavigation","needsPagination","needsScrollbar","scrollbar","uniqueClasses","unique","paramsList","calcLoopedSlides","slidesPerViewParams","breakpointOnlyParams","isChildSwiperSlide","processChildren","React","getChildren","slots","slot","foundSlides","updateSwiper","needThumbsInit","needControllerInit","needPaginationInit","needScrollbarInit","needNavigationInit","changedParams","scrollbarEl","paginationEl","updateParams","currentParams","thumbs","controller","control","newValue","load","useIsomorphicLayoutEffect","SwiperSlideContext","SwiperContext","_extends","_temp","externalElRef","Tag","wrapperTag","WrapperTag","onSwiper","rest","eventsAssigned","containerClasses","setContainerClasses","virtualData","setVirtualData","breakpointChanged","setBreakpointChanged","initializedRef","swiperElRef","swiperRef","oldPassedParamsRef","oldSlides","nextElRef","prevElRef","paginationElRef","scrollbarElRef","splitEvents","allowedParams","plainObj","getParams","restProps","onBeforeBreakpoint","_containerClasses","initSwiper","SwiperCore","extendWith","renderExternal","renderExternalUpdate","mountSwiper","oldParams","oldChildren","addKey","oldChildrenKeys","childrenKeys","newKeys","oldKeys","newKey","oldKey","getChangedParams","parallax","renderVirtual","modifiedSlides","duplicateSlide","blankSlide","renderLoop","SwiperSlide","externalRef","virtualIndex","slideElRef","slideClasses","setSlideClasses","updateClasses","slideData","isActive","isDuplicate","isPrev","isNext","renderChildren","DeleteButton","focused","xmlns","viewBox","highScores","highScoresExist","highScore","addButtonSelected","deleteButtonSelected","carouselSelected","backgroundImage","kiosk","setGames","buttonSelected","localSwiper","leftKeyEvent","KeyboardEvent","rightKeyEvent","getGameIndex","changeFocusedItem","updateLoop","localSwiperIndex","clickItem","gameHighScores","active","changeFocus","cancelButtonState","setCancelButtonState","confirmButtonState","setConfirmButtonState","cancelClicked","confirmClicked","userAddedGames","deleteGame","setAddButtonState","setDeleteButtonState","deleteTriggered","setDeleteTriggered","lockedClassName","launchAddGame","isSelected","onCharacterChanged","setIndex","previousInitial","nextInitial","interval","indexChanged","setIndexChanged","setNextIndex","setPreviousIndex","setInitials","timesAPressed","setTimesAPressed","runOnce","setRunOnce","firstRun","setFirstRun","saveHighScore","updateTimesPressed","lcv","thisIndex","character","newInitials","updateInitial","renderInitials","highScoreInitials","highScoreScore","existingHighScores","aboveScores","belowScores","_createForOfIteratorHelper","qrcodegen","qrcodegen2","__defProp","__getOwnPropSymbols","__hasOwnProp","__propIsEnum","__defNormalProp","__spreadValues","__objRest","exclude","_QrCode","msk","isFunction","MIN_VERSION","MAX_VERSION","RangeError","drawFunctionPatterns","allCodewords","addEccAndInterleave","drawCodewords","applyMask","drawFormatBits","getPenaltyScore","assert","setFunctionModule","drawFinderPattern","alignPatPos","getAlignmentPatternPositions","numAlign","drawAlignmentPattern","drawVersion","formatBits","rem","getBit","isDark","ver","ecl","numBlocks","NUM_ERROR_CORRECTION_BLOCKS","ordinal","blockEccLen","ECC_CODEWORDS_PER_BLOCK","getNumRawDataModules","numShortBlocks","shortBlockLen","rsDiv","reedSolomonComputeDivisor","dat","ecc","reedSolomonComputeRemainder","block","vert","invert","runColor","runX","runHistory","PENALTY_N1","finderPenaltyAddHistory","finderPenaltyCountPatterns","PENALTY_N3","finderPenaltyTerminateAndCount","runY","PENALTY_N2","dark","PENALTY_N4","core","currentRunColor","currentRunLength","segs","QrSegment","makeSegments","encodeSegments","seg","makeBytes","dataUsedBits","minVersion","maxVersion","boostEcl","dataCapacityBits2","usedBits","getTotalBits","Ecc","MEDIUM","QUARTILE","HIGH","newEcl","numChars","numCharCountBits","getData","dataCapacityBits","padByte","root","reedSolomonMultiply","factor","coef","QrCode","cond","_QrSegment","bitData","digits","isNumeric","isAlphanumeric","ALPHANUMERIC_CHARSET","makeNumeric","makeAlphanumeric","toUtf8ByteArray","assignVal","NUMERIC_REGEX","ALPHANUMERIC_REGEX","ccbits","encodeURI","QrCode2","_Ecc","LOW","QrSegment2","_Mode","numBitsCharCount","qrcodegen_default","ERROR_LEVEL_MAP","DEFAULT_BGCOLOR","DEFAULT_FGCOLOR","generatePath","margin","ops","cell","excavateModules","excavation","getImageSettings","cells","includeMargin","imageSettings","numCells","defaultSize","excavate","floorX","floorY","Path2D","addPath","QRCodeSVG","_a","level","bgColor","fgColor","otherProps","encodeText","getModules","calculatedImageSettings","preserveAspectRatio","fgPath","shapeRendering","Html5QrcodeSupportedFormats","setActive","notificationLength","setKioskCode","renderQRCode","setRenderQRCode","menuButtonSelected","setMenuButtonState","qrCodeButtonSelected","setQrButtonState","notify","setNotify","notifyContent","setNotifyContent","generatingKioskCode","kioskCodeNextGenerationTime","nextSafePollTime","kioskCodeUrl","kioskTimeOutInMinutes","kioskCodeTime","kioskTime","getKioskCodeDuration","kioskLinkClicked","displayGamesAdded","notification","pollTimer","pollForGameCode","timeElapsed","timeToPoll","gameCodes","saveNewGamesAsync","justAddedGames","codeGenerationTimer","generatedCodeDuration","generateKioskCode","kioskCodeEndTime","endTime","storedKioskCode","kioskUrl","qrDivContent","DecodedTextType","Html5QrcodeScanType","html5QrcodeSupportedFormatsTextMap","MAXICODE","isValidHtml5QrcodeSupportedFormats","Html5QrcodeErrorTypes","Html5QrcodeConstants","SCAN_TYPE_CAMERA","SCAN_TYPE_FILE","formatName","QrcodeResultFormat","Html5QrcodeResultFactory","decodedText","qrcodeResult","Html5QrcodeErrorFactory","errorMessage","UNKWOWN_ERROR","BaseLoggger","isExperimental","isNullOrUndefined","Html5QrcodeScannerState","Html5QrcodeStrings","Html5QrcodeScannerStrings","LibraryInfoStrings","VideoConstraintsUtil","videoConstraints","logger","typeofVideoConstraints","logError","bannedkeysSet","keysInVideoConstraints_1","requestedFormats","ZXing","createReverseFormatMap","createZXingFormats","ZXingHtml5QrcodeDecoder","zxingDecoder","toHtml5QrcodeSupportedFormats","formatMap","zxingFormat","reverseFormatMap","zxingFormats","requestedFormats_1","requestedFormat","BarcodeDetectorDelegate","isSupported","createBarcodeDetectorFormats","BarcodeDetector","barcodes","largestBarcode","selectLargestBarcode","rawValue","maxArea","barcodes_1","barcode","barcodeDetectorFormat","experimentalFeatureConfig","useBarCodeDetectorIfSupported","Html5QrcodeShim","decodeAsync","finally","executionTime","executionResults","executions","possiblyFlushPerformanceReport","EXECUTIONS_TO_REPORT_PERFORMANCE","mean","ExperimentalFeaturesConfigFactory","config","Html5QrcodeScannerStatus","NOT_STARTED","UNKNOWN","StateManagerImpl","failIfTransitionOngoing","validateTransition","onGoingTransactionNewState","tempNewState","directTransition","failIfNewStateIs","PAUSED","SCANNING","disallowedStatesToTransition","disallowedStatesToTransition_1","stateManager","StateManagerProxy","getState","StateManagerFactory","Constants","fps","SCAN_DEFAULT_FPS","disableFlip","qrbox","DEFAULT_DISABLE_FLIP","InternalHtml5QrcodeConfig","elementId","configOrVerbosityFlag","experimentalFeatures","qrcode","getSupportedFormats","foreverScanTimeout","localMediaStream","shouldScan","stateManagerProxy","Html5Qrcode","cameraIdOrConfig","configuration","qrCodeSuccessCallback","qrCodeErrorCallback","internalConfig","clearElement","videoConstraintsAvailableAndValid","isMediaStreamConstraintsValid","areVideoConstraintsEnabled","isShadedBoxEnabled","rootElementWidth","DEFAULT_WIDTH","$this","toScanningStateChangeTransaction","createVideoConstraints","audio","onMediaStreamReceived","execute","isScanning","shouldPauseVideo","isStrictlyScanning","showPausedState","pause","isPaused","transitionToScanning","hidePausedState","onVideoResume","toStoppedStateTransaction","onAllTracksClosed","childElement","SHADED_REGION_ELEMENT_ID","removeQrRegion","qrRegion","tracksToClose","tracksClosed","videoTrack","removeTrack","imageFile","showImage","scanFileV2","html5qrcodeResult","File","canScanFile","possiblyCloseLastScanImageFile","lastScanImageFile","inputImage","imageWidth","imageHeight","containerWidth","containerHeight","FILE_SCAN_MIN_HEIGHT","computeCanvasDrawConfig","visibleCanvas","createCanvasElement","context_1","hiddenCanvas","onabort","onstalled","onsuspend","getCamerasFromMediaDevices","mst","MediaStreamTrack","getSources","getCamerasFromMediaStreamTrack","isHttpsOrLocalhost","getCapabilities","getSettings","videoConstaints","applyConstraints","devices_1","tracks_1","closeActiveStreams","sourceInfos","sourceInfos_1","sourceInfo","allFormats","formatsToSupport","supportedFormats","viewfinderWidth","viewfinderHeight","qrboxSize","validateQrboxConfig","configWidth","qrDimensions","toQrdimensions","validateMinSize","MIN_QR_BOX_SIZE","validateQrboxSize","shouldShadingBeApplied","defaultQrRegion","getShadedRegionBounds","possiblyInsertShadingElement","createScannerPausedUiElement","rootElement","scannerPausedUiElement","innerText","background","textAlign","possiblyUpdateShaders","widthRatio","heightRatio","sWidthOffset","sHeightOffset","sxOffset","syOffset","triggerNextScan","foreverScan","getTimeoutFps","scanContext","isSuccessfull","mediaStream","setupVideo","createVideoElement","onVideoStart","setupUi","logErrors","facingModeKey","deviceIdKey","allowedFacingModeValues_1","exactKey","isValidFacingModeValue","formerImageWidth","formerImageHeight","muted","playsInline","qrMatch","hasBorderShaders","borderShaders","shader","backgroundColor","BORDER_SHADER_MATCH_COLOR","BORDER_SHADER_DEFAULT_COLOR","revokeObjectURL","customId","canvasWidth","canvasHeight","shadingElement","rightLeftBorderSize","topBottomBorderSize","borderLeft","borderRight","borderTop","borderBottom","largeSize","insertShaderBorders","shaderElem","SVG_XML_PREFIX","ASSET_INFO_ICON_16PX","PersistedDataFactory","hasPermission","lastUsedCameraId","createDefault","PersistedDataManager","LOCAL_STORAGE_KEY","flush","infoDiv","LibraryInfoDiv","padding","border","fontSize","projectLink","breakElemFirst","breakElemSecond","reportIssueLink","onTapIn","onTapOut","infoIcon","LibraryInfoIcon","alt","onmouseover","onHoverIn","onmouseout","onHoverOut","isShowingInfoIcon","show","hide","LibraryInfoContainer","renderInto","CameraManager","supportedScanTypes","validateAndReturnScanTypes","ScanTypeSelector","scanType","isCameraScanType","maxExpectedValues","supportedScanTypes_1","html5Qrcode","buttonElement","onTorchActionFailureCallback","TorchController","isTorchOnExpected","isTorchOn","applyVideoConstraints","settings","getRunningTrackSettings","updateUiBasedOnLatestSettings","propagateFailure","error_1","torch","torchButton","torchController","TorchButton","torchButtonOptions","flipState","TorchUtils","mediaTrackSettings","createConfig","scanTypeSelector","currentScanType","getDefaultScanType","sectionSwapAllowed","persistedDataManager","rememberLastUsedCamera","Html5QrcodeScanner","lastMatchFound","setHeaderMessage","STATUS_SUCCESS","container","createBasicLayout","getScanRegionId","resume","emptyHtmlContainer","mainContainer","resetBasicLayout","getRunningTrackCapabilities","createHeader","qrCodeScanRegion","scanRegionId","minHeight","insertCameraScanImageToScanRegion","insertFileScanImageToScanRegion","qrCodeDashboard","dashboardId","getDashboardId","setupInitialDashboard","dashboard","createSection","createSectionControlPanel","hasMoreThanOneScanType","createSectionSwap","header","headerMessageContainer","getHeaderMessageContainerId","section","getDashboardSectionId","scpCameraScanRegion","requestPermissionContainer","requestPermissionButton","createPermissionButtonIfNotExists","createPermissionButton","cameras","setHasPermission","resetHeaderMessage","renderCameraSelection","STATUS_WARNING","getCameraPermissionButtonId","createCameraListUi","hasCameraPermissions","hasPermissions","sectionControlPanel","getDashboardSectionCameraScanRegionId","isCameraScanRequired","createPermissionsUi","renderFileScanUi","fileBasedScanRegion","getDashboardSectionFileScanRegionId","fileScanInput","getFileScanInputId","accept","fileScanLabel","files","file","cameraSelectionContainer","numCameras","cameraSelectionSelect","selectCameraString","getCameraSelectionId","cameras_1","camera","name_1","option","cameraActionContainer","cameraActionStartButton","cameraActionStopButton","cameraActionTorchButton","getTorchButton","resetCameraActionStartButton","shouldShow","showHideScanTypeSwapLink","cameraId","setLastUsedCameraId","showTorchButtonIfSupported","click","getLastUsedCameraId","cameraFound","options_1","resetLastUsedCameraId","TEXT_IF_CAMERA_SCAN_SELECTED","TEXT_IF_FILE_SCAN_SELECTED","switchContainer","switchScanTypeLink","textDecoration","getDashboardSectionSwapLinkId","getFileScanInput","clearScanRegion","getCameraScanRegion","getFileScanRegion","startCameraScanIfPermissionExistsOnSwap","permissionButton","messageText","scannerStatus","STATUS_DEFAULT","messageDiv","getHeaderMessageDiv","shouldDisplay","getDashboardSectionSwapLink","cameraScanImage","fileScanImage","html5QrCode","setAddError","setDesc","onScanSuccess","onScanFailure","decodedResult","shareId","exec","QrSuccess","getCameras","stopScan","errorDescription","setShowing","fullUrlHash","urlHashList","scannerVisible","setScannerVisible","linkError","setLinkError","addingError","setAddingError","errorDesc","setErrorDesc","qrReaderRendered","setHtml5QrCode","qrCodeReader","initiateQrCode","checkUrl","inputValue","shareLink","shareCode","submitVal","placeholder","spellCheck","required","title","onChange","homeButtonSelected","setHomeButtonState","retryButtonSelected","setRetryButtonState","kioskSingleton","onHashChange","addGame","ScanQR","alert","onhashchange","onPerfEntry","getCLS","getFID","getFCP","getLCP","getTTFB","enableAnalytics","stats","availWidth","availHeight","sysXDPI","systemXDPI","logicalXDPI","devicePixelRatio","firstElementChild","ReactDOM","reportWebVitals"],"sourceRoot":""} \ No newline at end of file diff --git a/docs/static/kiosk/static/js/main.0d14f3d0.js b/docs/static/kiosk/static/js/main.b5a9c480.js similarity index 89% rename from docs/static/kiosk/static/js/main.0d14f3d0.js rename to docs/static/kiosk/static/js/main.b5a9c480.js index 71c0d116c72..821f2f560ae 100644 --- a/docs/static/kiosk/static/js/main.0d14f3d0.js +++ b/docs/static/kiosk/static/js/main.b5a9c480.js @@ -1,3 +1,3 @@ -/*! For license information please see main.0d14f3d0.js.LICENSE.txt */ -!function(){var e={484:function(e,t,n){var r=n(424).default,i=n(115).default,a=n(61).default,o=n(588).default,s=n(808).default,l=n(704).default,u=n(690).default,c=n(728).default,d=n(655).default,f=n(389).default;!function(e){"use strict";var t=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])};function h(e,n){function r(){this.constructor=e}t(e,n),e.prototype=null===n?Object.create(n):(r.prototype=n.prototype,new r)}function v(e,t){var n=Object.setPrototypeOf;n?n(e,t):e.__proto__=t}function p(e,t){void 0===t&&(t=e.constructor);var n=Error.captureStackTrace;n&&n(e,t)}var g=function(e){d(n,e);var t=f(n);function n(){var e,r=arguments.length>0&&void 0!==arguments[0]?arguments[0]:void 0;return u(this,n),(e=t.call(this,r)).message=r,e}return c(n,[{key:"getKind",value:function(){return this.constructor.kind}}]),n}(function(e){function t(t){var n=this.constructor,r=e.call(this,t)||this;return Object.defineProperty(r,"name",{value:n.name,enumerable:!1}),v(r,n.prototype),p(r),r}return h(t,e),t}(Error));g.kind="Exception";var m=function(e){d(n,e);var t=f(n);function n(){return u(this,n),t.apply(this,arguments)}return c(n)}(g);m.kind="ArgumentException";var y=function(e){d(n,e);var t=f(n);function n(){return u(this,n),t.apply(this,arguments)}return c(n)}(g);y.kind="IllegalArgumentException";var w=function(){function e(t){if(u(this,e),this.binarizer=t,null===t)throw new y("Binarizer must be non-null.")}return c(e,[{key:"getWidth",value:function(){return this.binarizer.getWidth()}},{key:"getHeight",value:function(){return this.binarizer.getHeight()}},{key:"getBlackRow",value:function(e,t){return this.binarizer.getBlackRow(e,t)}},{key:"getBlackMatrix",value:function(){return null!==this.matrix&&void 0!==this.matrix||(this.matrix=this.binarizer.getBlackMatrix()),this.matrix}},{key:"isCropSupported",value:function(){return this.binarizer.getLuminanceSource().isCropSupported()}},{key:"crop",value:function(t,n,r,i){var a=this.binarizer.getLuminanceSource().crop(t,n,r,i);return new e(this.binarizer.createBinarizer(a))}},{key:"isRotateSupported",value:function(){return this.binarizer.getLuminanceSource().isRotateSupported()}},{key:"rotateCounterClockwise",value:function(){var t=this.binarizer.getLuminanceSource().rotateCounterClockwise();return new e(this.binarizer.createBinarizer(t))}},{key:"rotateCounterClockwise45",value:function(){var t=this.binarizer.getLuminanceSource().rotateCounterClockwise45();return new e(this.binarizer.createBinarizer(t))}},{key:"toString",value:function(){try{return this.getBlackMatrix().toString()}catch(e){return""}}}]),e}(),E=function(e){d(n,e);var t=f(n);function n(){return u(this,n),t.apply(this,arguments)}return c(n,null,[{key:"getChecksumInstance",value:function(){return new n}}]),n}(g);E.kind="ChecksumException";var S=function(){function e(t){u(this,e),this.source=t}return c(e,[{key:"getLuminanceSource",value:function(){return this.source}},{key:"getWidth",value:function(){return this.source.getWidth()}},{key:"getHeight",value:function(){return this.source.getHeight()}}]),e}(),C=function(){function e(){u(this,e)}return c(e,null,[{key:"arraycopy",value:function(e,t,n,r,i){for(;i--;)n[r++]=e[t++]}},{key:"currentTimeMillis",value:function(){return Date.now()}}]),e}(),A=function(e){d(n,e);var t=f(n);function n(){return u(this,n),t.apply(this,arguments)}return c(n)}(g);A.kind="IndexOutOfBoundsException";var b=function(e){d(n,e);var t=f(n);function n(){var e,r=arguments.length>0&&void 0!==arguments[0]?arguments[0]:void 0,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:void 0;return u(this,n),(e=t.call(this,i)).index=r,e.message=i,e}return c(n)}(A);b.kind="ArrayIndexOutOfBoundsException";var k=function(){function e(){u(this,e)}return c(e,null,[{key:"fill",value:function(e,t){for(var n=0,r=e.length;nn)throw new y("fromIndex("+t+") > toIndex("+n+")");if(t<0)throw new b(t);if(n>e)throw new b(n)}},{key:"asList",value:function(){for(var e=arguments.length,t=new Array(e),n=0;n>1,s=r(n,t[o]);if(s>0)i=o+1;else{if(!(s<0))return o;a=o-1}}return-i-1}},{key:"numberComparator",value:function(e,t){return e-t}}]),e}(),I=function(){function e(){u(this,e)}return c(e,null,[{key:"numberOfTrailingZeros",value:function(e){var t;if(0===e)return 32;var n=31;return 0!==(t=e<<16)&&(n-=16,e=t),0!==(t=e<<8)&&(n-=8,e=t),0!==(t=e<<4)&&(n-=4,e=t),0!==(t=e<<2)&&(n-=2,e=t),n-(e<<1>>>31)}},{key:"numberOfLeadingZeros",value:function(e){if(0===e)return 32;var t=1;return e>>>16===0&&(t+=16,e<<=16),e>>>24===0&&(t+=8,e<<=8),e>>>28===0&&(t+=4,e<<=4),e>>>30===0&&(t+=2,e<<=2),t-=e>>>31}},{key:"toHexString",value:function(e){return e.toString(16)}},{key:"toBinaryString",value:function(e){return String(parseInt(String(e),2))}},{key:"bitCount",value:function(e){return e=(e=(858993459&(e-=e>>>1&1431655765))+(e>>>2&858993459))+(e>>>4)&252645135,e+=e>>>8,63&(e+=e>>>16)}},{key:"truncDivision",value:function(e,t){return Math.trunc(e/t)}},{key:"parseInt",value:function(e){function t(t){return e.apply(this,arguments)}return t.toString=function(){return e.toString()},t}((function(e){return parseInt(e,arguments.length>1&&void 0!==arguments[1]?arguments[1]:void 0)}))}]),e}();I.MIN_VALUE_32_BITS=-2147483648,I.MAX_VALUE=Number.MAX_SAFE_INTEGER;var _,T=function(){function e(t,n){u(this,e),void 0===t?(this.size=0,this.bits=new Int32Array(1)):(this.size=t,this.bits=void 0===n||null===n?e.makeArray(t):n)}return c(e,[{key:"getSize",value:function(){return this.size}},{key:"getSizeInBytes",value:function(){return Math.floor((this.size+7)/8)}},{key:"ensureCapacity",value:function(t){if(t>32*this.bits.length){var n=e.makeArray(t);C.arraycopy(this.bits,0,n,0,this.bits.length),this.bits=n}}},{key:"get",value:function(e){return 0!==(this.bits[Math.floor(e/32)]&1<<(31&e))}},{key:"set",value:function(e){this.bits[Math.floor(e/32)]|=1<<(31&e)}},{key:"flip",value:function(e){this.bits[Math.floor(e/32)]^=1<<(31&e)}},{key:"getNextSet",value:function(e){var t=this.size;if(e>=t)return t;var n=this.bits,r=Math.floor(e/32),i=n[r];i&=~((1<<(31&e))-1);for(var a=n.length;0===i;){if(++r===a)return t;i=n[r]}var o=32*r+I.numberOfTrailingZeros(i);return o>t?t:o}},{key:"getNextUnset",value:function(e){var t=this.size;if(e>=t)return t;var n=this.bits,r=Math.floor(e/32),i=~n[r];i&=~((1<<(31&e))-1);for(var a=n.length;0===i;){if(++r===a)return t;i=~n[r]}var o=32*r+I.numberOfTrailingZeros(i);return o>t?t:o}},{key:"setBulk",value:function(e,t){this.bits[Math.floor(e/32)]=t}},{key:"setRange",value:function(e,t){if(tthis.size)throw new y;if(t!==e){t--;for(var n=Math.floor(e/32),r=Math.floor(t/32),i=this.bits,a=n;a<=r;a++){var o=(2<<(an?0:31&e));i[a]|=o}}}},{key:"clear",value:function(){for(var e=this.bits.length,t=this.bits,n=0;nthis.size)throw new y;if(t===e)return!0;t--;for(var r=Math.floor(e/32),i=Math.floor(t/32),a=this.bits,o=r;o<=i;o++){var s=(2<<(or?0:31&e))&4294967295;if((a[o]&s)!==(n?s:0))return!1}return!0}},{key:"appendBit",value:function(e){this.ensureCapacity(this.size+1),e&&(this.bits[Math.floor(this.size/32)]|=1<<(31&this.size)),this.size++}},{key:"appendBits",value:function(e,t){if(t<0||t>32)throw new y("Num bits must be between 0 and 32");this.ensureCapacity(this.size+t);for(var n=t;n>0;n--)this.appendBit(1===(e>>n-1&1))}},{key:"appendBitArray",value:function(e){var t=e.size;this.ensureCapacity(this.size+t);for(var n=0;n>1&1431655765|(1431655765&a)<<1)>>2&858993459|(858993459&a)<<2)>>4&252645135|(252645135&a)<<4)>>8&16711935|(16711935&a)<<8)>>16&65535|(65535&a)<<16,e[t-i]=a}if(this.size!==32*n){for(var o=32*n-this.size,s=e[0]>>>o,l=1;l>>o}e[n-1]=s}this.bits=e}},{key:"equals",value:function(t){if(!(t instanceof e))return!1;var n=t;return this.size===n.size&&k.equals(this.bits,n.bits)}},{key:"hashCode",value:function(){return 31*this.size+k.hashCode(this.bits)}},{key:"toString",value:function(){for(var e="",t=0,n=this.size;t3?i-3:0),o=3;o=900)throw new D("incorect value");var n=e.VALUES_TO_ECI.get(t);if(void 0===n)throw new D("incorect value");return n}},{key:"getCharacterSetECIByName",value:function(t){var n=e.NAME_TO_ECI.get(t);if(void 0===n)throw new D("incorect value");return n}}]),e}();R.VALUE_IDENTIFIER_TO_ECI=new Map,R.VALUES_TO_ECI=new Map,R.NAME_TO_ECI=new Map,R.Cp437=new R(M.Cp437,Int32Array.from([0,2]),"Cp437"),R.ISO8859_1=new R(M.ISO8859_1,Int32Array.from([1,3]),"ISO-8859-1","ISO88591","ISO8859_1"),R.ISO8859_2=new R(M.ISO8859_2,4,"ISO-8859-2","ISO88592","ISO8859_2"),R.ISO8859_3=new R(M.ISO8859_3,5,"ISO-8859-3","ISO88593","ISO8859_3"),R.ISO8859_4=new R(M.ISO8859_4,6,"ISO-8859-4","ISO88594","ISO8859_4"),R.ISO8859_5=new R(M.ISO8859_5,7,"ISO-8859-5","ISO88595","ISO8859_5"),R.ISO8859_6=new R(M.ISO8859_6,8,"ISO-8859-6","ISO88596","ISO8859_6"),R.ISO8859_7=new R(M.ISO8859_7,9,"ISO-8859-7","ISO88597","ISO8859_7"),R.ISO8859_8=new R(M.ISO8859_8,10,"ISO-8859-8","ISO88598","ISO8859_8"),R.ISO8859_9=new R(M.ISO8859_9,11,"ISO-8859-9","ISO88599","ISO8859_9"),R.ISO8859_10=new R(M.ISO8859_10,12,"ISO-8859-10","ISO885910","ISO8859_10"),R.ISO8859_11=new R(M.ISO8859_11,13,"ISO-8859-11","ISO885911","ISO8859_11"),R.ISO8859_13=new R(M.ISO8859_13,15,"ISO-8859-13","ISO885913","ISO8859_13"),R.ISO8859_14=new R(M.ISO8859_14,16,"ISO-8859-14","ISO885914","ISO8859_14"),R.ISO8859_15=new R(M.ISO8859_15,17,"ISO-8859-15","ISO885915","ISO8859_15"),R.ISO8859_16=new R(M.ISO8859_16,18,"ISO-8859-16","ISO885916","ISO8859_16"),R.SJIS=new R(M.SJIS,20,"SJIS","Shift_JIS"),R.Cp1250=new R(M.Cp1250,21,"Cp1250","windows-1250"),R.Cp1251=new R(M.Cp1251,22,"Cp1251","windows-1251"),R.Cp1252=new R(M.Cp1252,23,"Cp1252","windows-1252"),R.Cp1256=new R(M.Cp1256,24,"Cp1256","windows-1256"),R.UnicodeBigUnmarked=new R(M.UnicodeBigUnmarked,25,"UnicodeBigUnmarked","UTF-16BE","UnicodeBig"),R.UTF8=new R(M.UTF8,26,"UTF8","UTF-8"),R.ASCII=new R(M.ASCII,Int32Array.from([27,170]),"ASCII","US-ASCII"),R.Big5=new R(M.Big5,28,"Big5"),R.GB18030=new R(M.GB18030,29,"GB18030","GB2312","EUC_CN","GBK"),R.EUC_KR=new R(M.EUC_KR,30,"EUC_KR","EUC-KR");var O=function(e){d(n,e);var t=f(n);function n(){return u(this,n),t.apply(this,arguments)}return c(n)}(g);O.kind="UnsupportedOperationException";var x=function(){function e(){u(this,e)}return c(e,null,[{key:"decode",value:function(e,t){var n=this.encodingName(t);return this.customDecoder?this.customDecoder(e,n):"undefined"===typeof TextDecoder||this.shouldDecodeOnFallback(n)?this.decodeFallback(e,n):new TextDecoder(n).decode(e)}},{key:"shouldDecodeOnFallback",value:function(t){return!e.isBrowser()&&"ISO-8859-1"===t}},{key:"encode",value:function(e,t){var n=this.encodingName(t);return this.customEncoder?this.customEncoder(e,n):"undefined"===typeof TextEncoder?this.encodeFallback(e):(new TextEncoder).encode(e)}},{key:"isBrowser",value:function(){return"undefined"!==typeof window&&"[object Window]"==={}.toString.call(window)}},{key:"encodingName",value:function(e){return"string"===typeof e?e:e.getName()}},{key:"encodingCharacterSet",value:function(e){return e instanceof R?e:R.getCharacterSetECIByName(e)}},{key:"decodeFallback",value:function(t,n){var r=this.encodingCharacterSet(n);if(e.isDecodeFallbackSupported(r)){for(var i="",a=0,o=t.length;a1&&void 0!==arguments[1]?arguments[1]:null,n=t?t.getName():this.ISO88591;return x.decode(new Uint8Array([e]),n)}},{key:"guessEncoding",value:function(t,n){if(null!==n&&void 0!==n&&void 0!==n.get(N.CHARACTER_SET))return n.get(N.CHARACTER_SET).toString();for(var r=t.length,i=!0,a=!0,o=!0,s=0,l=0,u=0,c=0,d=0,f=0,h=0,v=0,p=0,g=0,m=0,y=t.length>3&&239===t[0]&&187===t[1]&&191===t[2],w=0;w0?0===(128&E)?o=!1:s--:0!==(128&E)&&(0===(64&E)?o=!1:(s++,0===(32&E)?l++:(s++,0===(16&E)?u++:(s++,0===(8&E)?c++:o=!1))))),i&&(E>127&&E<160?i=!1:E>159&&(E<192||215===E||247===E)&&m++),a&&(d>0?E<64||127===E||E>252?a=!1:d--:128===E||160===E||E>239?a=!1:E>160&&E<224?(f++,v=0,++h>p&&(p=h)):E>127?(d++,h=0,++v>g&&(g=v)):(h=0,v=0))}return o&&s>0&&(o=!1),a&&d>0&&(a=!1),o&&(y||l+u+c>0)?e.UTF8:a&&(e.ASSUME_SHIFT_JIS||p>=3||g>=3)?e.SHIFT_JIS:i&&a?2===p&&2===f||10*m>=r?e.SHIFT_JIS:e.ISO88591:i?e.ISO88591:a?e.SHIFT_JIS:o?e.UTF8:e.PLATFORM_DEFAULT_ENCODING}},{key:"format",value:function(e){for(var t=arguments.length,n=new Array(t>1?t-1:0),r=1;r1&&void 0!==arguments[1]?arguments[1]:0;return e.charCodeAt(t)}},{key:"getCharAt",value:function(e){return String.fromCharCode(e)}}]),e}();P.SHIFT_JIS=R.SJIS.getName(),P.GB2312="GB2312",P.ISO88591=R.ISO8859_1.getName(),P.EUC_JP="EUC_JP",P.UTF8=R.UTF8.getName(),P.PLATFORM_DEFAULT_ENCODING=P.UTF8,P.ASSUME_SHIFT_JIS=!1;var L=function(){function e(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"";u(this,e),this.value=t}return c(e,[{key:"enableDecoding",value:function(e){return this.encoding=e,this}},{key:"append",value:function(e){return"string"===typeof e?this.value+=e.toString():this.encoding?this.value+=P.castAsNonUtf8Char(e,this.encoding):this.value+=String.fromCharCode(e),this}},{key:"appendChars",value:function(e,t,n){for(var r=t;t>>(31&e)&1)}},{key:"set",value:function(e,t){var n=t*this.rowSize+Math.floor(e/32);this.bits[n]|=1<<(31&e)&4294967295}},{key:"unset",value:function(e,t){var n=t*this.rowSize+Math.floor(e/32);this.bits[n]&=~(1<<(31&e)&4294967295)}},{key:"flip",value:function(e,t){var n=t*this.rowSize+Math.floor(e/32);this.bits[n]^=1<<(31&e)&4294967295}},{key:"xor",value:function(e){if(this.width!==e.getWidth()||this.height!==e.getHeight()||this.rowSize!==e.getRowSize())throw new y("input matrix dimensions do not match");for(var t=new T(Math.floor(this.width/32)+1),n=this.rowSize,r=this.bits,i=0,a=this.height;ithis.height||i>this.width)throw new y("The region must fit inside the matrix");for(var o=this.rowSize,s=this.bits,l=t;ls&&(s=l),32*uo){for(var f=31;c>>>f===0;)f--;32*u+f>o&&(o=32*u+f)}}}return o=0&&0===t[n];)n--;if(n<0)return null;for(var r=Math.floor(n/e),i=32*Math.floor(n%e),a=t[n],o=31;a>>>o===0;)o--;return i+=o,Int32Array.from([i,r])}},{key:"getWidth",value:function(){return this.width}},{key:"getHeight",value:function(){return this.height}},{key:"getRowSize",value:function(){return this.rowSize}},{key:"equals",value:function(t){if(!(t instanceof e))return!1;var n=t;return this.width===n.width&&this.height===n.height&&this.rowSize===n.rowSize&&k.equals(this.bits,n.bits)}},{key:"hashCode",value:function(){var e=this.width;return e=31*(e=31*(e=31*(e=31*e+this.width)+this.height)+this.rowSize)+k.hashCode(this.bits)}},{key:"toString",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"X ",t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:" ",n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"\n";return this.buildToString(e,t,n)}},{key:"buildToString",value:function(e,t,n){for(var r=new L,i=0,a=this.height;io){if(-1===s)s=a-o;else if(a-o!==s)throw new y("row lengths do not match");o=a,l++}u++}else if(t.substring(u,u+n.length)===n)u+=n.length,i[a]=!0,a++;else{if(t.substring(u,u+r.length)!==r)throw new y("illegal character encountered: "+t.substring(u));u+=r.length,i[a]=!1,a++}if(a>o){if(-1===s)s=a-o;else if(a-o!==s)throw new y("row lengths do not match");l++}for(var c=new e(s,l),d=0;d>n.LUMINANCE_SHIFT]++;var l=n.estimateBlackPoint(o);if(i<3)for(var u=0;u>n.LUMINANCE_SHIFT]++;for(var d=n.estimateBlackPoint(a),f=e.getMatrix(),h=0;ha&&(i=o,a=e[o]),e[o]>r&&(r=e[o]);for(var s=0,l=0,u=0;ul&&(s=u,l=d)}if(i>s){var f=i;i=s,s=f}if(s-i<=t/16)throw new F;for(var h=s-1,v=-1,p=s-1;p>i;p--){var g=p-i,m=g*g*(s-p)*(r-e[p]);m>v&&(h=p,v=m)}return h<=n.MINIMUM_DIMENSION&&r>=n.MINIMUM_DIMENSION){var i=e.getMatrix(),a=t>>n.BLOCK_SIZE_POWER;0!==(t&n.BLOCK_SIZE_MASK)&&a++;var l=r>>n.BLOCK_SIZE_POWER;0!==(r&n.BLOCK_SIZE_MASK)&&l++;var u=n.calculateBlackPoints(i,a,l,t,r),c=new B(t,r);n.calculateThresholdForBlock(i,a,l,t,r,u,c),this.matrix=c}else this.matrix=o(s(n.prototype),"getBlackMatrix",this).call(this);return this.matrix}},{key:"createBinarizer",value:function(e){return new n(e)}}],[{key:"calculateThresholdForBlock",value:function(e,t,r,i,a,o,s){for(var l=a-n.BLOCK_SIZE,u=i-n.BLOCK_SIZE,c=0;cl&&(d=l);for(var f=n.cap(c,2,r-3),h=0;hu&&(v=u);for(var p=n.cap(h,2,t-3),g=0,m=-2;m<=2;m++){var y=o[f+m];g+=y[p-2]+y[p-1]+y[p]+y[p+1]+y[p+2]}var w=g/25;n.thresholdBlock(e,v,d,w,i,s)}}}},{key:"cap",value:function(e,t,n){return en?n:e}},{key:"thresholdBlock",value:function(e,t,r,i,a,o){for(var s=0,l=r*a+t;so&&(c=o);for(var d=0;ds&&(f=s);for(var h=0,v=255,p=0,g=0,m=c*i+f;gp&&(p=w)}if(p-v>n.MIN_DYNAMIC_RANGE)for(g++,m+=i;g>2*n.BLOCK_SIZE_POWER;if(p-v<=n.MIN_DYNAMIC_RANGE&&(S=v/2,u>0&&d>0)){var C=(l[u-1][d]+2*l[u][d-1]+l[u-1][d-1])/4;v=this.getHeight())throw new y("Requested row is outside the image: "+e);var n=this.getWidth(),r=e*n;return null===t?t=this.buffer.slice(r,r+n):(t.length>10,r[a]=s}return r}}]),n}(H);V.DEGREE_TO_RADIANS=Math.PI/180;var G,W=function(){function e(t,n,r){u(this,e),this.deviceId=t,this.label=n,this.kind="videoinput",this.groupId=r||void 0}return c(e,[{key:"toJSON",value:function(){return{kind:this.kind,groupId:this.groupId,deviceId:this.deviceId,label:this.label}}}]),e}(),Y=(globalThis||n.g||self||window?(globalThis||n.g||self||window||void 0).__awaiter:void 0)||function(e,t,n,r){function i(e){return e instanceof n?e:new n((function(t){t(e)}))}return new(n||(n=Promise))((function(n,a){function o(e){try{l(r.next(e))}catch(t){a(t)}}function s(e){try{l(r.throw(e))}catch(t){a(t)}}function l(e){e.done?n(e.value):i(e.value).then(o,s)}l((r=r.apply(e,t||[])).next())}))},X=function(){function e(t){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:500,r=arguments.length>2?arguments[2]:void 0;u(this,e),this.reader=t,this.timeBetweenScansMillis=n,this._hints=r,this._stopContinuousDecode=!1,this._stopAsyncDecode=!1,this._timeBetweenDecodingAttempts=0}return c(e,[{key:"hasNavigator",get:function(){return"undefined"!==typeof navigator}},{key:"isMediaDevicesSuported",get:function(){return this.hasNavigator&&!!navigator.mediaDevices}},{key:"canEnumerateDevices",get:function(){return!(!this.isMediaDevicesSuported||!navigator.mediaDevices.enumerateDevices)}},{key:"timeBetweenDecodingAttempts",get:function(){return this._timeBetweenDecodingAttempts},set:function(e){this._timeBetweenDecodingAttempts=e<0?0:e}},{key:"hints",get:function(){return this._hints},set:function(e){this._hints=e||null}},{key:"listVideoInputDevices",value:function(){return Y(this,void 0,void 0,a().mark((function e(){var t,n,r,i,o,s,u,c,d,f;return a().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(this.hasNavigator){e.next=2;break}throw new Error("Can't enumerate devices, navigator is not present.");case 2:if(this.canEnumerateDevices){e.next=4;break}throw new Error("Can't enumerate devices, method not supported.");case 4:return e.next=6,navigator.mediaDevices.enumerateDevices();case 6:t=e.sent,n=[],r=l(t),e.prev=9,r.s();case 11:if((i=r.n()).done){e.next=23;break}if(o=i.value,"videoinput"===(s="video"===o.kind?"videoinput":o.kind)){e.next=16;break}return e.abrupt("continue",21);case 16:u=o.deviceId||o.id,c=o.label||"Video device ".concat(n.length+1),d=o.groupId,f={deviceId:u,label:c,kind:s,groupId:d},n.push(f);case 21:e.next=11;break;case 23:e.next=28;break;case 25:e.prev=25,e.t0=e.catch(9),r.e(e.t0);case 28:return e.prev=28,r.f(),e.finish(28);case 31:return e.abrupt("return",n);case 32:case"end":return e.stop()}}),e,this,[[9,25,28,31]])})))}},{key:"getVideoInputDevices",value:function(){return Y(this,void 0,void 0,a().mark((function e(){var t;return a().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,this.listVideoInputDevices();case 2:return t=e.sent,e.abrupt("return",t.map((function(e){return new W(e.deviceId,e.label)})));case 4:case"end":return e.stop()}}),e,this)})))}},{key:"findDeviceById",value:function(e){return Y(this,void 0,void 0,a().mark((function t(){var n;return a().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return t.next=2,this.listVideoInputDevices();case 2:if(n=t.sent){t.next=5;break}return t.abrupt("return",null);case 5:return t.abrupt("return",n.find((function(t){return t.deviceId===e})));case 6:case"end":return t.stop()}}),t,this)})))}},{key:"decodeFromInputVideoDevice",value:function(e,t){return Y(this,void 0,void 0,a().mark((function n(){return a().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return n.next=2,this.decodeOnceFromVideoDevice(e,t);case 2:return n.abrupt("return",n.sent);case 3:case"end":return n.stop()}}),n,this)})))}},{key:"decodeOnceFromVideoDevice",value:function(e,t){return Y(this,void 0,void 0,a().mark((function n(){var r;return a().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return this.reset(),r={video:e?{deviceId:{exact:e}}:{facingMode:"environment"}},n.next=5,this.decodeOnceFromConstraints(r,t);case 5:return n.abrupt("return",n.sent);case 6:case"end":return n.stop()}}),n,this)})))}},{key:"decodeOnceFromConstraints",value:function(e,t){return Y(this,void 0,void 0,a().mark((function n(){var r;return a().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return n.next=2,navigator.mediaDevices.getUserMedia(e);case 2:return r=n.sent,n.next=5,this.decodeOnceFromStream(r,t);case 5:return n.abrupt("return",n.sent);case 6:case"end":return n.stop()}}),n,this)})))}},{key:"decodeOnceFromStream",value:function(e,t){return Y(this,void 0,void 0,a().mark((function n(){var r,i;return a().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return this.reset(),n.next=3,this.attachStreamToVideo(e,t);case 3:return r=n.sent,n.next=6,this.decodeOnce(r);case 6:return i=n.sent,n.abrupt("return",i);case 8:case"end":return n.stop()}}),n,this)})))}},{key:"decodeFromInputVideoDeviceContinuously",value:function(e,t,n){return Y(this,void 0,void 0,a().mark((function r(){return a().wrap((function(r){for(;;)switch(r.prev=r.next){case 0:return r.next=2,this.decodeFromVideoDevice(e,t,n);case 2:return r.abrupt("return",r.sent);case 3:case"end":return r.stop()}}),r,this)})))}},{key:"decodeFromVideoDevice",value:function(e,t,n){return Y(this,void 0,void 0,a().mark((function r(){var i;return a().wrap((function(r){for(;;)switch(r.prev=r.next){case 0:return i={video:e?{deviceId:{exact:e}}:{facingMode:"environment"}},r.next=4,this.decodeFromConstraints(i,t,n);case 4:return r.abrupt("return",r.sent);case 5:case"end":return r.stop()}}),r,this)})))}},{key:"decodeFromConstraints",value:function(e,t,n){return Y(this,void 0,void 0,a().mark((function r(){var i;return a().wrap((function(r){for(;;)switch(r.prev=r.next){case 0:return r.next=2,navigator.mediaDevices.getUserMedia(e);case 2:return i=r.sent,r.next=5,this.decodeFromStream(i,t,n);case 5:return r.abrupt("return",r.sent);case 6:case"end":return r.stop()}}),r,this)})))}},{key:"decodeFromStream",value:function(e,t,n){return Y(this,void 0,void 0,a().mark((function r(){var i;return a().wrap((function(r){for(;;)switch(r.prev=r.next){case 0:return this.reset(),r.next=3,this.attachStreamToVideo(e,t);case 3:return i=r.sent,r.next=6,this.decodeContinuously(i,n);case 6:return r.abrupt("return",r.sent);case 7:case"end":return r.stop()}}),r,this)})))}},{key:"stopAsyncDecode",value:function(){this._stopAsyncDecode=!0}},{key:"stopContinuousDecode",value:function(){this._stopContinuousDecode=!0}},{key:"attachStreamToVideo",value:function(e,t){return Y(this,void 0,void 0,a().mark((function n(){var r;return a().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return r=this.prepareVideoElement(t),this.addVideoSource(r,e),this.videoElement=r,this.stream=e,n.next=6,this.playVideoOnLoadAsync(r);case 6:return n.abrupt("return",r);case 7:case"end":return n.stop()}}),n,this)})))}},{key:"playVideoOnLoadAsync",value:function(e){var t=this;return new Promise((function(n,r){return t.playVideoOnLoad(e,(function(){return n()}))}))}},{key:"playVideoOnLoad",value:function(e,t){var n=this;this.videoEndedListener=function(){return n.stopStreams()},this.videoCanPlayListener=function(){return n.tryPlayVideo(e)},e.addEventListener("ended",this.videoEndedListener),e.addEventListener("canplay",this.videoCanPlayListener),e.addEventListener("playing",t),this.tryPlayVideo(e)}},{key:"isVideoPlaying",value:function(e){return e.currentTime>0&&!e.paused&&!e.ended&&e.readyState>2}},{key:"tryPlayVideo",value:function(e){return Y(this,void 0,void 0,a().mark((function t(){return a().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:if(!this.isVideoPlaying(e)){t.next=3;break}return console.warn("Trying to play video that is already playing."),t.abrupt("return");case 3:return t.prev=3,t.next=6,e.play();case 6:t.next=11;break;case 8:t.prev=8,t.t0=t.catch(3),console.warn("It was not possible to play the video.");case 11:case"end":return t.stop()}}),t,this,[[3,8]])})))}},{key:"getMediaElement",value:function(e,t){var n=document.getElementById(e);if(!n)throw new m("element with id '".concat(e,"' not found"));if(n.nodeName.toLowerCase()!==t.toLowerCase())throw new m("element with id '".concat(e,"' must be an ").concat(t," element"));return n}},{key:"decodeFromImage",value:function(e,t){if(!e&&!t)throw new m("either imageElement with a src set or an url must be provided");return t&&!e?this.decodeFromImageUrl(t):this.decodeFromImageElement(e)}},{key:"decodeFromVideo",value:function(e,t){if(!e&&!t)throw new m("Either an element with a src set or an URL must be provided");return t&&!e?this.decodeFromVideoUrl(t):this.decodeFromVideoElement(e)}},{key:"decodeFromVideoContinuously",value:function(e,t,n){if(void 0===e&&void 0===t)throw new m("Either an element with a src set or an URL must be provided");return t&&!e?this.decodeFromVideoUrlContinuously(t,n):this.decodeFromVideoElementContinuously(e,n)}},{key:"decodeFromImageElement",value:function(e){if(!e)throw new m("An image element must be provided.");this.reset();var t=this.prepareImageElement(e);return this.imageElement=t,this.isImageLoaded(t)?this.decodeOnce(t,!1,!0):this._decodeOnLoadImage(t)}},{key:"decodeFromVideoElement",value:function(e){var t=this._decodeFromVideoElementSetup(e);return this._decodeOnLoadVideo(t)}},{key:"decodeFromVideoElementContinuously",value:function(e,t){var n=this._decodeFromVideoElementSetup(e);return this._decodeOnLoadVideoContinuously(n,t)}},{key:"_decodeFromVideoElementSetup",value:function(e){if(!e)throw new m("A video element must be provided.");this.reset();var t=this.prepareVideoElement(e);return this.videoElement=t,t}},{key:"decodeFromImageUrl",value:function(e){if(!e)throw new m("An URL must be provided.");this.reset();var t=this.prepareImageElement();this.imageElement=t;var n=this._decodeOnLoadImage(t);return t.src=e,n}},{key:"decodeFromVideoUrl",value:function(e){if(!e)throw new m("An URL must be provided.");this.reset();var t=this.prepareVideoElement(),n=this.decodeFromVideoElement(t);return t.src=e,n}},{key:"decodeFromVideoUrlContinuously",value:function(e,t){if(!e)throw new m("An URL must be provided.");this.reset();var n=this.prepareVideoElement(),r=this.decodeFromVideoElementContinuously(n,t);return n.src=e,r}},{key:"_decodeOnLoadImage",value:function(e){var t=this;return new Promise((function(n,r){t.imageLoadedListener=function(){return t.decodeOnce(e,!1,!0).then(n,r)},e.addEventListener("load",t.imageLoadedListener)}))}},{key:"_decodeOnLoadVideo",value:function(e){return Y(this,void 0,void 0,a().mark((function t(){return a().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return t.next=2,this.playVideoOnLoadAsync(e);case 2:return t.next=4,this.decodeOnce(e);case 4:return t.abrupt("return",t.sent);case 5:case"end":return t.stop()}}),t,this)})))}},{key:"_decodeOnLoadVideoContinuously",value:function(e,t){return Y(this,void 0,void 0,a().mark((function n(){return a().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return n.next=2,this.playVideoOnLoadAsync(e);case 2:this.decodeContinuously(e,t);case 3:case"end":return n.stop()}}),n,this)})))}},{key:"isImageLoaded",value:function(e){return!!e.complete&&0!==e.naturalWidth}},{key:"prepareImageElement",value:function(e){var t;return"undefined"===typeof e&&((t=document.createElement("img")).width=200,t.height=200),"string"===typeof e&&(t=this.getMediaElement(e,"img")),e instanceof HTMLImageElement&&(t=e),t}},{key:"prepareVideoElement",value:function(e){var t;return e||"undefined"===typeof document||((t=document.createElement("video")).width=200,t.height=200),"string"===typeof e&&(t=this.getMediaElement(e,"video")),e instanceof HTMLVideoElement&&(t=e),t.setAttribute("autoplay","true"),t.setAttribute("muted","true"),t.setAttribute("playsinline","true"),t}},{key:"decodeOnce",value:function(e){var t=this,n=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],r=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];this._stopAsyncDecode=!1;var i=function i(a,o){if(t._stopAsyncDecode)return o(new F("Video stream has ended before any code could be detected.")),void(t._stopAsyncDecode=void 0);try{a(t.decode(e))}catch(s){if(n&&s instanceof F||(s instanceof E||s instanceof D)&&r)return setTimeout(i,t._timeBetweenDecodingAttempts,a,o);o(s)}};return new Promise((function(e,t){return i(e,t)}))}},{key:"decodeContinuously",value:function(e,t){var n=this;this._stopContinuousDecode=!1,function r(){if(n._stopContinuousDecode)n._stopContinuousDecode=void 0;else try{var i=n.decode(e);t(i,null),setTimeout(r,n.timeBetweenScansMillis)}catch(a){t(null,a),(a instanceof E||a instanceof D||a instanceof F)&&setTimeout(r,n._timeBetweenDecodingAttempts)}}()}},{key:"decode",value:function(e){var t=this.createBinaryBitmap(e);return this.decodeBitmap(t)}},{key:"createBinaryBitmap",value:function(e){var t=this.getCaptureCanvasContext(e);this.drawImageOnCanvas(t,e);var n=this.getCaptureCanvas(e),r=new V(n),i=new z(r);return new w(i)}},{key:"getCaptureCanvasContext",value:function(e){if(!this.captureCanvasContext){var t=this.getCaptureCanvas(e).getContext("2d");this.captureCanvasContext=t}return this.captureCanvasContext}},{key:"getCaptureCanvas",value:function(e){if(!this.captureCanvas){var t=this.createCaptureCanvas(e);this.captureCanvas=t}return this.captureCanvas}},{key:"drawImageOnCanvas",value:function(e,t){e.drawImage(t,0,0)}},{key:"decodeBitmap",value:function(e){return this.reader.decode(e,this._hints)}},{key:"createCaptureCanvas",value:function(e){if("undefined"===typeof document)return this._destroyCaptureCanvas(),null;var t,n,r=document.createElement("canvas");return"undefined"!==typeof e&&(e instanceof HTMLVideoElement?(t=e.videoWidth,n=e.videoHeight):e instanceof HTMLImageElement&&(t=e.naturalWidth||e.width,n=e.naturalHeight||e.height)),r.style.width=t+"px",r.style.height=n+"px",r.width=t,r.height=n,r}},{key:"stopStreams",value:function(){this.stream&&(this.stream.getVideoTracks().forEach((function(e){return e.stop()})),this.stream=void 0),!1===this._stopAsyncDecode&&this.stopAsyncDecode(),!1===this._stopContinuousDecode&&this.stopContinuousDecode()}},{key:"reset",value:function(){this.stopStreams(),this._destroyVideoElement(),this._destroyImageElement(),this._destroyCaptureCanvas()}},{key:"_destroyVideoElement",value:function(){this.videoElement&&("undefined"!==typeof this.videoEndedListener&&this.videoElement.removeEventListener("ended",this.videoEndedListener),"undefined"!==typeof this.videoPlayingEventListener&&this.videoElement.removeEventListener("playing",this.videoPlayingEventListener),"undefined"!==typeof this.videoCanPlayListener&&this.videoElement.removeEventListener("loadedmetadata",this.videoCanPlayListener),this.cleanVideoSource(this.videoElement),this.videoElement=void 0)}},{key:"_destroyImageElement",value:function(){this.imageElement&&(void 0!==this.imageLoadedListener&&this.imageElement.removeEventListener("load",this.imageLoadedListener),this.imageElement.src=void 0,this.imageElement.removeAttribute("src"),this.imageElement=void 0)}},{key:"_destroyCaptureCanvas",value:function(){this.captureCanvasContext=void 0,this.captureCanvas=void 0}},{key:"addVideoSource",value:function(e,t){try{e.srcObject=t}catch(n){e.src=URL.createObjectURL(t)}}},{key:"cleanVideoSource",value:function(e){try{e.srcObject=null}catch(t){e.src=""}this.videoElement.removeAttribute("src")}}]),e}(),Q=function(){function e(t,n){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null==n?0:8*n.length,i=arguments.length>3?arguments[3]:void 0,a=arguments.length>4?arguments[4]:void 0,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:C.currentTimeMillis();u(this,e),this.text=t,this.rawBytes=n,this.numBits=r,this.resultPoints=i,this.format=a,this.timestamp=o,this.text=t,this.rawBytes=n,this.numBits=void 0===r||null===r?null===n||void 0===n?0:8*n.length:r,this.resultPoints=i,this.format=a,this.resultMetadata=null,this.timestamp=void 0===o||null===o?C.currentTimeMillis():o}return c(e,[{key:"getText",value:function(){return this.text}},{key:"getRawBytes",value:function(){return this.rawBytes}},{key:"getNumBits",value:function(){return this.numBits}},{key:"getResultPoints",value:function(){return this.resultPoints}},{key:"getBarcodeFormat",value:function(){return this.format}},{key:"getResultMetadata",value:function(){return this.resultMetadata}},{key:"putMetadata",value:function(e,t){null===this.resultMetadata&&(this.resultMetadata=new Map),this.resultMetadata.set(e,t)}},{key:"putAllMetadata",value:function(e){null!==e&&(null===this.resultMetadata?this.resultMetadata=e:this.resultMetadata=new Map(e))}},{key:"addResultPoints",value:function(e){var t=this.resultPoints;if(null===t)this.resultPoints=e;else if(null!==e&&e.length>0){var n=new Array(t.length+e.length);C.arraycopy(t,0,n,0,t.length),C.arraycopy(e,0,n,t.length,e.length),this.resultPoints=n}}},{key:"getTimestamp",value:function(){return this.timestamp}},{key:"toString",value:function(){return this.text}}]),e}();!function(e){e[e.AZTEC=0]="AZTEC",e[e.CODABAR=1]="CODABAR",e[e.CODE_39=2]="CODE_39",e[e.CODE_93=3]="CODE_93",e[e.CODE_128=4]="CODE_128",e[e.DATA_MATRIX=5]="DATA_MATRIX",e[e.EAN_8=6]="EAN_8",e[e.EAN_13=7]="EAN_13",e[e.ITF=8]="ITF",e[e.MAXICODE=9]="MAXICODE",e[e.PDF_417=10]="PDF_417",e[e.QR_CODE=11]="QR_CODE",e[e.RSS_14=12]="RSS_14",e[e.RSS_EXPANDED=13]="RSS_EXPANDED",e[e.UPC_A=14]="UPC_A",e[e.UPC_E=15]="UPC_E",e[e.UPC_EAN_EXTENSION=16]="UPC_EAN_EXTENSION"}(G||(G={}));var Z,K=G;!function(e){e[e.OTHER=0]="OTHER",e[e.ORIENTATION=1]="ORIENTATION",e[e.BYTE_SEGMENTS=2]="BYTE_SEGMENTS",e[e.ERROR_CORRECTION_LEVEL=3]="ERROR_CORRECTION_LEVEL",e[e.ISSUE_NUMBER=4]="ISSUE_NUMBER",e[e.SUGGESTED_PRICE=5]="SUGGESTED_PRICE",e[e.POSSIBLE_COUNTRY=6]="POSSIBLE_COUNTRY",e[e.UPC_EAN_EXTENSION=7]="UPC_EAN_EXTENSION",e[e.PDF417_EXTRA_METADATA=8]="PDF417_EXTRA_METADATA",e[e.STRUCTURED_APPEND_SEQUENCE=9]="STRUCTURED_APPEND_SEQUENCE",e[e.STRUCTURED_APPEND_PARITY=10]="STRUCTURED_APPEND_PARITY"}(Z||(Z={}));var q=Z,$=function(){function e(t,n,r,i){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:-1,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:-1;u(this,e),this.rawBytes=t,this.text=n,this.byteSegments=r,this.ecLevel=i,this.structuredAppendSequenceNumber=a,this.structuredAppendParity=o,this.numBits=void 0===t||null===t?0:8*t.length}return c(e,[{key:"getRawBytes",value:function(){return this.rawBytes}},{key:"getNumBits",value:function(){return this.numBits}},{key:"setNumBits",value:function(e){this.numBits=e}},{key:"getText",value:function(){return this.text}},{key:"getByteSegments",value:function(){return this.byteSegments}},{key:"getECLevel",value:function(){return this.ecLevel}},{key:"getErrorsCorrected",value:function(){return this.errorsCorrected}},{key:"setErrorsCorrected",value:function(e){this.errorsCorrected=e}},{key:"getErasures",value:function(){return this.erasures}},{key:"setErasures",value:function(e){this.erasures=e}},{key:"getOther",value:function(){return this.other}},{key:"setOther",value:function(e){this.other=e}},{key:"hasStructuredAppend",value:function(){return this.structuredAppendParity>=0&&this.structuredAppendSequenceNumber>=0}},{key:"getStructuredAppendParity",value:function(){return this.structuredAppendParity}},{key:"getStructuredAppendSequenceNumber",value:function(){return this.structuredAppendSequenceNumber}}]),e}(),J=function(){function e(){u(this,e)}return c(e,[{key:"exp",value:function(e){return this.expTable[e]}},{key:"log",value:function(e){if(0===e)throw new y;return this.logTable[e]}}],[{key:"addOrSubtract",value:function(e,t){return e^t}}]),e}(),ee=function(){function e(t,n){if(u(this,e),0===n.length)throw new y;this.field=t;var r=n.length;if(r>1&&0===n[0]){for(var i=1;ir.length){var i=n;n=r,r=i}var a=new Int32Array(r.length),o=r.length-n.length;C.arraycopy(r,0,a,0,o);for(var s=o;s=e.getDegree()&&!r.isZero();){var o=r.getDegree()-e.getDegree(),s=t.multiply(r.getCoefficient(r.getDegree()),a),l=e.multiplyByMonomial(o,s),u=t.buildMonomial(o,s);n=n.addOrSubtract(u),r=r.addOrSubtract(l)}return[n,r]}},{key:"toString",value:function(){for(var e="",t=this.getDegree();t>=0;t--){var n=this.getCoefficient(t);if(0!==n){if(n<0?(e+=" - ",n=-n):e.length>0&&(e+=" + "),0===t||1!==n){var r=this.field.log(n);0===r?e+="1":1===r?e+="a":(e+="a^",e+=r)}0!==t&&(1===t?e+="x":(e+="x^",e+=t))}}return e}}]),e}(),te=function(e){d(n,e);var t=f(n);function n(){return u(this,n),t.apply(this,arguments)}return c(n)}(g);te.kind="ArithmeticException";var ne=function(e){d(n,e);var t=f(n);function n(e,r,a){var o;u(this,n),(o=t.call(this)).primitive=e,o.size=r,o.generatorBase=a;for(var s=new Int32Array(r),l=1,c=0;c=r&&(l^=e,l&=r-1);o.expTable=s;for(var d=new Int32Array(r),f=0;f=(n/2|0);){var u=a,c=s;if(s=l,(a=o).isZero())throw new re("r_{i-1} was zero");o=u;for(var d=i.getZero(),f=a.getCoefficient(a.getDegree()),h=i.inverse(f);o.getDegree()>=a.getDegree()&&!o.isZero();){var v=o.getDegree()-a.getDegree(),p=i.multiply(o.getCoefficient(o.getDegree()),h);d=d.addOrSubtract(i.buildMonomial(v,p)),o=o.addOrSubtract(a.multiplyByMonomial(v,p))}if(l=d.multiply(s).addOrSubtract(c),o.getDegree()>=a.getDegree())throw new ie("Division algorithm failed to reduce polynomial?")}var g=l.getCoefficient(0);if(0===g)throw new re("sigmaTilde(0) was zero");var m=i.inverse(g);return[l.multiplyScalar(m),o.multiplyScalar(m)]}},{key:"findErrorLocations",value:function(e){var t=e.getDegree();if(1===t)return Int32Array.from([e.getCoefficient(1)]);for(var n=new Int32Array(t),r=0,i=this.field,a=1;a1,v,v+r-1),v+=r-1;else for(var m=r-1;m>=0;--m)h[v++]=0!==(g&1<=8?e.readCode(t,n,8):e.readCode(t,n,r)<<8-r}},{key:"convertBoolArrayToByteArray",value:function(t){for(var n=new Uint8Array((t.length+7)/8),r=0;r","?","[","]","{","}","CTRL_UL"],se.DIGIT_TABLE=["CTRL_PS"," ","0","1","2","3","4","5","6","7","8","9",",",".","CTRL_UL","CTRL_US"];var le=function(){function e(){u(this,e)}return c(e,null,[{key:"round",value:function(e){return NaN===e?0:e<=Number.MIN_SAFE_INTEGER?Number.MIN_SAFE_INTEGER:e>=Number.MAX_SAFE_INTEGER?Number.MAX_SAFE_INTEGER:e+(e<0?-.5:.5)|0}},{key:"distance",value:function(e,t,n,r){var i=e-n,a=t-r;return Math.sqrt(i*i+a*a)}},{key:"sum",value:function(e){for(var t=0,n=0,r=e.length;n!==r;n++)t+=e[n];return t}}]),e}(),ue=function(){function e(){u(this,e)}return c(e,null,[{key:"floatToIntBits",value:function(e){return e}}]),e}();ue.MAX_VALUE=Number.MAX_SAFE_INTEGER;var ce=function(){function e(t,n){u(this,e),this.x=t,this.y=n}return c(e,[{key:"getX",value:function(){return this.x}},{key:"getY",value:function(){return this.y}},{key:"equals",value:function(t){if(t instanceof e){var n=t;return this.x===n.x&&this.y===n.y}return!1}},{key:"hashCode",value:function(){return 31*ue.floatToIntBits(this.x)+ue.floatToIntBits(this.y)}},{key:"toString",value:function(){return"("+this.x+","+this.y+")"}}],[{key:"orderBestPatterns",value:function(e){var t,n,r,i=this.distance(e[0],e[1]),a=this.distance(e[1],e[2]),o=this.distance(e[0],e[2]);if(a>=i&&a>=o?(n=e[0],t=e[1],r=e[2]):o>=a&&o>=i?(n=e[1],t=e[0],r=e[2]):(n=e[2],t=e[0],r=e[1]),this.crossProductZ(t,n,r)<0){var s=t;t=r,r=s}e[0]=t,e[1]=n,e[2]=r}},{key:"distance",value:function(e,t){return le.distance(e.x,e.y,t.x,t.y)}},{key:"crossProductZ",value:function(e,t,n){var r=t.x,i=t.y;return(n.x-r)*(e.y-i)-(n.y-i)*(e.x-r)}}]),e}(),de=function(){function e(t,n){u(this,e),this.bits=t,this.points=n}return c(e,[{key:"getBits",value:function(){return this.bits}},{key:"getPoints",value:function(){return this.points}}]),e}(),fe=function(e){d(n,e);var t=f(n);function n(e,r,i,a,o){var s;return u(this,n),(s=t.call(this,e,r)).compact=i,s.nbDatablocks=a,s.nbLayers=o,s}return c(n,[{key:"getNbLayers",value:function(){return this.nbLayers}},{key:"getNbDatablocks",value:function(){return this.nbDatablocks}},{key:"isCompact",value:function(){return this.compact}}]),n}(de),he=function(){function e(t,n,r,i){u(this,e),this.image=t,this.height=t.getHeight(),this.width=t.getWidth(),void 0!==n&&null!==n||(n=e.INIT_SIZE),void 0!==r&&null!==r||(r=t.getWidth()/2|0),void 0!==i&&null!==i||(i=t.getHeight()/2|0);var a=n/2|0;if(this.leftInit=r-a,this.rightInit=r+a,this.upInit=i-a,this.downInit=i+a,this.upInit<0||this.leftInit<0||this.downInit>=this.height||this.rightInit>=this.width)throw new F}return c(e,[{key:"detect",value:function(){for(var e=this.leftInit,t=this.rightInit,n=this.upInit,r=this.downInit,i=!1,a=!0,o=!1,s=!1,l=!1,u=!1,c=!1,d=this.width,f=this.height;a;){a=!1;for(var h=!0;(h||!s)&&t=d){i=!0;break}for(var v=!0;(v||!l)&&r=f){i=!0;break}for(var p=!0;(p||!u)&&e>=0;)(p=this.containsBlackPoint(n,r,e,!1))?(e--,a=!0,u=!0):u||e--;if(e<0){i=!0;break}for(var g=!0;(g||!c)&&n>=0;)(g=this.containsBlackPoint(e,t,n,!0))?(n--,a=!0,c=!0):c||n--;if(n<0){i=!0;break}a&&(o=!0)}if(!i&&o){for(var m=t-e,y=null,w=1;null===y&&wn||s<-1||s>r)throw new F;i=!1,-1===o?(t[a]=0,i=!0):o===n&&(t[a]=n-1,i=!0),-1===s?(t[a+1]=0,i=!0):s===r&&(t[a+1]=r-1,i=!0)}i=!0;for(var l=t.length-2;l>=0&&i;l-=2){var u=Math.floor(t[l]),c=Math.floor(t[l+1]);if(u<-1||u>n||c<-1||c>r)throw new F;i=!1,-1===u?(t[l]=0,i=!0):u===n&&(t[l]=n-1,i=!0),-1===c?(t[l+1]=0,i=!0):c===r&&(t[l+1]=r-1,i=!0)}}}]),e}(),pe=function(){function e(t,n,r,i,a,o,s,l,c){u(this,e),this.a11=t,this.a21=n,this.a31=r,this.a12=i,this.a22=a,this.a32=o,this.a13=s,this.a23=l,this.a33=c}return c(e,[{key:"transformPoints",value:function(e){for(var t=e.length,n=this.a11,r=this.a12,i=this.a13,a=this.a21,o=this.a22,s=this.a23,l=this.a31,u=this.a32,c=this.a33,d=0;d>1&127):(r<<=10,r+=(a>>2&992)+(a>>1&31))}var o=this.getCorrectedParameterData(r,this.compact);this.compact?(this.nbLayers=1+(o>>6),this.nbDataBlocks=1+(63&o)):(this.nbLayers=1+(o>>11),this.nbDataBlocks=1+(2047&o))}},{key:"getRotation",value:function(e,t){var n=0;e.forEach((function(e,r,i){n=(e>>t-2<<1)+(1&e)+(n<<3)})),n=((1&n)<<11)+(n>>1);for(var r=0;r<4;r++)if(I.bitCount(n^this.EXPECTED_CORNER_BITS[r])<=2)return r;throw new F}},{key:"getCorrectedParameterData",value:function(e,t){var n,r;t?(n=7,r=2):(n=10,r=4);for(var i=n-r,a=new Int32Array(n),o=n-1;o>=0;--o)a[o]=15&e,e>>=4;try{new oe(ne.AZTEC_PARAM).decode(a,i)}catch(u){throw new F}for(var s=0,l=0;l2){var c=this.distancePoint(u,o)*this.nbCenterLayers/(this.distancePoint(i,t)*(this.nbCenterLayers+2));if(c<.75||c>1.25||!this.isWhiteOrBlackRectangle(o,s,l,u))break}t=o,n=s,r=l,i=u,a=!a}if(5!==this.nbCenterLayers&&7!==this.nbCenterLayers)throw new F;this.compact=5===this.nbCenterLayers;var d=new ce(t.getX()+.5,t.getY()-.5),f=new ce(n.getX()+.5,n.getY()+.5),h=new ce(r.getX()-.5,r.getY()+.5),v=new ce(i.getX()-.5,i.getY()-.5);return this.expandSquare([d,f,h,v],2*this.nbCenterLayers-3,2*this.nbCenterLayers)}},{key:"getMatrixCenter",value:function(){var e,t,n,r;try{var i=new he(this.image).detect();e=i[0],t=i[1],n=i[2],r=i[3]}catch(c){var a=this.image.getWidth()/2,o=this.image.getHeight()/2;e=this.getFirstDifferent(new ye(a+7,o-7),!1,1,-1).toResultPoint(),t=this.getFirstDifferent(new ye(a+7,o+7),!1,1,1).toResultPoint(),n=this.getFirstDifferent(new ye(a-7,o+7),!1,-1,1).toResultPoint(),r=this.getFirstDifferent(new ye(a-7,o-7),!1,-1,-1).toResultPoint()}var s=le.round((e.getX()+r.getX()+t.getX()+n.getX())/4),l=le.round((e.getY()+r.getY()+t.getY()+n.getY())/4);try{var u=new he(this.image,15,s,l).detect();e=u[0],t=u[1],n=u[2],r=u[3]}catch(c){e=this.getFirstDifferent(new ye(s+7,l-7),!1,1,-1).toResultPoint(),t=this.getFirstDifferent(new ye(s+7,l+7),!1,1,1).toResultPoint(),n=this.getFirstDifferent(new ye(s-7,l+7),!1,-1,1).toResultPoint(),r=this.getFirstDifferent(new ye(s-7,l-7),!1,-1,-1).toResultPoint()}return s=le.round((e.getX()+r.getX()+t.getX()+n.getX())/4),l=le.round((e.getY()+r.getY()+t.getY()+n.getY())/4),new ye(s,l)}},{key:"getMatrixCornerPoints",value:function(e){return this.expandSquare(e,2*this.nbCenterLayers,this.getDimension())}},{key:"sampleGrid",value:function(e,t,n,r,i){var a=me.getInstance(),o=this.getDimension(),s=o/2-this.nbCenterLayers,l=o/2+this.nbCenterLayers;return a.sampleGrid(e,o,o,s,s,l,s,l,l,s,l,t.getX(),t.getY(),n.getX(),n.getY(),r.getX(),r.getY(),i.getX(),i.getY())}},{key:"sampleLine",value:function(e,t,n){for(var r=0,i=this.distanceResultPoint(e,t),a=i/n,o=e.getX(),s=e.getY(),l=a*(t.getX()-e.getX())/i,u=a*(t.getY()-e.getY())/i,c=0;c.1&&d<.9?0:d<=.1===l?1:-1}},{key:"getFirstDifferent",value:function(e,t,n,r){for(var i=e.getX()+n,a=e.getY()+r;this.isValid(i,a)&&this.image.get(i,a)===t;)i+=n,a+=r;for(i-=n,a-=r;this.isValid(i,a)&&this.image.get(i,a)===t;)i+=n;for(i-=n;this.isValid(i,a)&&this.image.get(i,a)===t;)a+=r;return new ye(i,a-=r)}},{key:"expandSquare",value:function(e,t,n){var r=n/(2*t),i=e[0].getX()-e[2].getX(),a=e[0].getY()-e[2].getY(),o=(e[0].getX()+e[2].getX())/2,s=(e[0].getY()+e[2].getY())/2,l=new ce(o+r*i,s+r*a),u=new ce(o-r*i,s-r*a);return i=e[1].getX()-e[3].getX(),a=e[1].getY()-e[3].getY(),o=(e[1].getX()+e[3].getX())/2,s=(e[1].getY()+e[3].getY())/2,[l,new ce(o+r*i,s+r*a),u,new ce(o-r*i,s-r*a)]}},{key:"isValid",value:function(e,t){return e>=0&&e0&&t1&&void 0!==arguments[1]?arguments[1]:null,n=null,r=new we(e.getBlackMatrix()),i=null,a=null;try{var o=r.detectMirror(!1);i=o.getPoints(),this.reportFoundResultPoints(t,i),a=(new se).decode(o)}catch(d){n=d}if(null==a)try{var s=r.detectMirror(!0);i=s.getPoints(),this.reportFoundResultPoints(t,i),a=(new se).decode(s)}catch(d){if(null!=n)throw n;throw d}var l=new Q(a.getText(),a.getRawBytes(),a.getNumBits(),i,K.AZTEC,C.currentTimeMillis()),u=a.getByteSegments();null!=u&&l.putMetadata(q.BYTE_SEGMENTS,u);var c=a.getECLevel();return null!=c&&l.putMetadata(q.ERROR_CORRECTION_LEVEL,c),l}},{key:"reportFoundResultPoints",value:function(e,t){if(null!=e){var n=e.get(N.NEED_RESULT_POINT_CALLBACK);null!=n&&t.forEach((function(e,t,r){n.foundPossibleResultPoint(e)}))}}},{key:"reset",value:function(){}}]),e}(),Se=function(e){d(n,e);var t=f(n);function n(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:500;return u(this,n),t.call(this,new Ee,e)}return c(n)}(X),Ce=function(){function e(){u(this,e)}return c(e,[{key:"decode",value:function(e,t){try{return this.doDecode(e,t)}catch(u){if(t&&!0===t.get(N.TRY_HARDER)&&e.isRotateSupported()){var n=e.rotateCounterClockwise(),r=this.doDecode(n,t),i=r.getResultMetadata(),a=270;null!==i&&!0===i.get(q.ORIENTATION)&&(a+=i.get(q.ORIENTATION)%360),r.putMetadata(q.ORIENTATION,a);var o=r.getResultPoints();if(null!==o)for(var s=n.getHeight(),l=0;l>(o?8:5));n=o?i:15;for(var l=Math.trunc(i/2),u=0;u=i)break;try{a=e.getBlackRow(d,a)}catch(p){continue}for(var f=0;f<2;f++){1===f&&(a.reverse(),t&&!0===t.get(N.NEED_RESULT_POINT_CALLBACK)&&function(){var e=new Map;t.forEach((function(t,n){return e.set(n,t)})),e.delete(N.NEED_RESULT_POINT_CALLBACK),t=e}());try{var h=this.decodeRow(d,a,t);if(1===f){h.putMetadata(q.ORIENTATION,180);var v=h.getResultPoints();null!==v&&(v[0]=new ce(r-v[0].getX()-1,v[0].getY()),v[1]=new ce(r-v[1].getX()-1,v[1].getY()))}return h}catch(g){}}}throw new F}}],[{key:"recordPattern",value:function(e,t,n){for(var r=n.length,i=0;i=a)throw new F;for(var o=!e.get(t),s=0,l=t;l0&&i>=0;)t.get(--n)!==a&&(i--,a=!a);if(i>=0)throw new F;e.recordPattern(t,n+1,r)}},{key:"patternMatchVariance",value:function(e,t,n){for(var r=e.length,i=0,a=0,o=0;od?c-d:d-c;if(f>n)return Number.POSITIVE_INFINITY;l+=f}return l/i}}]),e}(),Ae=function(e){d(n,e);var t=f(n);function n(){return u(this,n),t.apply(this,arguments)}return c(n,[{key:"decodeRow",value:function(e,t,r){var i,a=r&&!0===r.get(N.ASSUME_GS1),o=n.findStartPattern(t),s=o[2],l=0,u=new Uint8Array(20);switch(u[l++]=s,s){case n.CODE_START_A:i=n.CODE_CODE_A;break;case n.CODE_START_B:i=n.CODE_CODE_B;break;case n.CODE_START_C:i=n.CODE_CODE_C;break;default:throw new D}for(var c=!1,d=!1,f="",h=o[0],v=o[1],p=Int32Array.from([0,0,0,0,0,0]),g=0,m=0,y=s,w=0,S=!0,C=!1,A=!1;!c;){var b=d;switch(d=!1,g=m,m=n.decodeCode(t,p,v),u[l++]=m,m!==n.CODE_STOP&&(S=!0),m!==n.CODE_STOP&&(y+=++w*m),h=v,v+=p.reduce((function(e,t){return e+t}),0),m){case n.CODE_START_A:case n.CODE_START_B:case n.CODE_START_C:throw new D}switch(i){case n.CODE_CODE_A:if(m<64)f+=A===C?String.fromCharCode(" ".charCodeAt(0)+m):String.fromCharCode(" ".charCodeAt(0)+m+128),A=!1;else if(m<96)f+=A===C?String.fromCharCode(m-64):String.fromCharCode(m+64),A=!1;else switch(m!==n.CODE_STOP&&(S=!1),m){case n.CODE_FNC_1:a&&(0===f.length?f+="]C1":f+=String.fromCharCode(29));break;case n.CODE_FNC_2:case n.CODE_FNC_3:break;case n.CODE_FNC_4_A:!C&&A?(C=!0,A=!1):C&&A?(C=!1,A=!1):A=!0;break;case n.CODE_SHIFT:d=!0,i=n.CODE_CODE_B;break;case n.CODE_CODE_B:i=n.CODE_CODE_B;break;case n.CODE_CODE_C:i=n.CODE_CODE_C;break;case n.CODE_STOP:c=!0}break;case n.CODE_CODE_B:if(m<96)f+=A===C?String.fromCharCode(" ".charCodeAt(0)+m):String.fromCharCode(" ".charCodeAt(0)+m+128),A=!1;else switch(m!==n.CODE_STOP&&(S=!1),m){case n.CODE_FNC_1:a&&(0===f.length?f+="]C1":f+=String.fromCharCode(29));break;case n.CODE_FNC_2:case n.CODE_FNC_3:break;case n.CODE_FNC_4_B:!C&&A?(C=!0,A=!1):C&&A?(C=!1,A=!1):A=!0;break;case n.CODE_SHIFT:d=!0,i=n.CODE_CODE_A;break;case n.CODE_CODE_A:i=n.CODE_CODE_A;break;case n.CODE_CODE_C:i=n.CODE_CODE_C;break;case n.CODE_STOP:c=!0}break;case n.CODE_CODE_C:if(m<100)m<10&&(f+="0"),f+=m;else switch(m!==n.CODE_STOP&&(S=!1),m){case n.CODE_FNC_1:a&&(0===f.length?f+="]C1":f+=String.fromCharCode(29));break;case n.CODE_CODE_A:i=n.CODE_CODE_A;break;case n.CODE_CODE_B:i=n.CODE_CODE_B;break;case n.CODE_STOP:c=!0}}b&&(i=i===n.CODE_CODE_A?n.CODE_CODE_B:n.CODE_CODE_A)}var k=v-h;if(v=t.getNextUnset(v),!t.isRange(v,Math.min(t.getSize(),v+(v-h)/2),!1))throw new F;if((y-=w*g)%103!==g)throw new E;var I=f.length;if(0===I)throw new F;I>0&&S&&(f=i===n.CODE_CODE_C?f.substring(0,I-2):f.substring(0,I-1));for(var _=(o[1]+o[0])/2,T=h+k/2,M=u.length,R=new Uint8Array(M),O=0;O=0&&e.isRange(Math.max(0,o-(u-o)/2),o,!1))return Int32Array.from([o,u,d]);o+=a[0]+a[1],(a=a.slice(2,a.length-1))[i-1]=0,a[i]=0,i--}else i++;a[i]=1,s=!s}throw new F}},{key:"decodeCode",value:function(e,t,r){Ce.recordPattern(e,r,t);for(var i=n.MAX_AVG_VARIANCE,a=-1,o=0;o=0)return a;throw new F}}]),n}(Ce);Ae.CODE_PATTERNS=[Int32Array.from([2,1,2,2,2,2]),Int32Array.from([2,2,2,1,2,2]),Int32Array.from([2,2,2,2,2,1]),Int32Array.from([1,2,1,2,2,3]),Int32Array.from([1,2,1,3,2,2]),Int32Array.from([1,3,1,2,2,2]),Int32Array.from([1,2,2,2,1,3]),Int32Array.from([1,2,2,3,1,2]),Int32Array.from([1,3,2,2,1,2]),Int32Array.from([2,2,1,2,1,3]),Int32Array.from([2,2,1,3,1,2]),Int32Array.from([2,3,1,2,1,2]),Int32Array.from([1,1,2,2,3,2]),Int32Array.from([1,2,2,1,3,2]),Int32Array.from([1,2,2,2,3,1]),Int32Array.from([1,1,3,2,2,2]),Int32Array.from([1,2,3,1,2,2]),Int32Array.from([1,2,3,2,2,1]),Int32Array.from([2,2,3,2,1,1]),Int32Array.from([2,2,1,1,3,2]),Int32Array.from([2,2,1,2,3,1]),Int32Array.from([2,1,3,2,1,2]),Int32Array.from([2,2,3,1,1,2]),Int32Array.from([3,1,2,1,3,1]),Int32Array.from([3,1,1,2,2,2]),Int32Array.from([3,2,1,1,2,2]),Int32Array.from([3,2,1,2,2,1]),Int32Array.from([3,1,2,2,1,2]),Int32Array.from([3,2,2,1,1,2]),Int32Array.from([3,2,2,2,1,1]),Int32Array.from([2,1,2,1,2,3]),Int32Array.from([2,1,2,3,2,1]),Int32Array.from([2,3,2,1,2,1]),Int32Array.from([1,1,1,3,2,3]),Int32Array.from([1,3,1,1,2,3]),Int32Array.from([1,3,1,3,2,1]),Int32Array.from([1,1,2,3,1,3]),Int32Array.from([1,3,2,1,1,3]),Int32Array.from([1,3,2,3,1,1]),Int32Array.from([2,1,1,3,1,3]),Int32Array.from([2,3,1,1,1,3]),Int32Array.from([2,3,1,3,1,1]),Int32Array.from([1,1,2,1,3,3]),Int32Array.from([1,1,2,3,3,1]),Int32Array.from([1,3,2,1,3,1]),Int32Array.from([1,1,3,1,2,3]),Int32Array.from([1,1,3,3,2,1]),Int32Array.from([1,3,3,1,2,1]),Int32Array.from([3,1,3,1,2,1]),Int32Array.from([2,1,1,3,3,1]),Int32Array.from([2,3,1,1,3,1]),Int32Array.from([2,1,3,1,1,3]),Int32Array.from([2,1,3,3,1,1]),Int32Array.from([2,1,3,1,3,1]),Int32Array.from([3,1,1,1,2,3]),Int32Array.from([3,1,1,3,2,1]),Int32Array.from([3,3,1,1,2,1]),Int32Array.from([3,1,2,1,1,3]),Int32Array.from([3,1,2,3,1,1]),Int32Array.from([3,3,2,1,1,1]),Int32Array.from([3,1,4,1,1,1]),Int32Array.from([2,2,1,4,1,1]),Int32Array.from([4,3,1,1,1,1]),Int32Array.from([1,1,1,2,2,4]),Int32Array.from([1,1,1,4,2,2]),Int32Array.from([1,2,1,1,2,4]),Int32Array.from([1,2,1,4,2,1]),Int32Array.from([1,4,1,1,2,2]),Int32Array.from([1,4,1,2,2,1]),Int32Array.from([1,1,2,2,1,4]),Int32Array.from([1,1,2,4,1,2]),Int32Array.from([1,2,2,1,1,4]),Int32Array.from([1,2,2,4,1,1]),Int32Array.from([1,4,2,1,1,2]),Int32Array.from([1,4,2,2,1,1]),Int32Array.from([2,4,1,2,1,1]),Int32Array.from([2,2,1,1,1,4]),Int32Array.from([4,1,3,1,1,1]),Int32Array.from([2,4,1,1,1,2]),Int32Array.from([1,3,4,1,1,1]),Int32Array.from([1,1,1,2,4,2]),Int32Array.from([1,2,1,1,4,2]),Int32Array.from([1,2,1,2,4,1]),Int32Array.from([1,1,4,2,1,2]),Int32Array.from([1,2,4,1,1,2]),Int32Array.from([1,2,4,2,1,1]),Int32Array.from([4,1,1,2,1,2]),Int32Array.from([4,2,1,1,1,2]),Int32Array.from([4,2,1,2,1,1]),Int32Array.from([2,1,2,1,4,1]),Int32Array.from([2,1,4,1,2,1]),Int32Array.from([4,1,2,1,2,1]),Int32Array.from([1,1,1,1,4,3]),Int32Array.from([1,1,1,3,4,1]),Int32Array.from([1,3,1,1,4,1]),Int32Array.from([1,1,4,1,1,3]),Int32Array.from([1,1,4,3,1,1]),Int32Array.from([4,1,1,1,1,3]),Int32Array.from([4,1,1,3,1,1]),Int32Array.from([1,1,3,1,4,1]),Int32Array.from([1,1,4,1,3,1]),Int32Array.from([3,1,1,1,4,1]),Int32Array.from([4,1,1,1,3,1]),Int32Array.from([2,1,1,4,1,2]),Int32Array.from([2,1,1,2,1,4]),Int32Array.from([2,1,1,2,3,2]),Int32Array.from([2,3,3,1,1,1,2])],Ae.MAX_AVG_VARIANCE=.25,Ae.MAX_INDIVIDUAL_VARIANCE=.7,Ae.CODE_SHIFT=98,Ae.CODE_CODE_C=99,Ae.CODE_CODE_B=100,Ae.CODE_CODE_A=101,Ae.CODE_FNC_1=102,Ae.CODE_FNC_2=97,Ae.CODE_FNC_3=96,Ae.CODE_FNC_4_A=101,Ae.CODE_FNC_4_B=100,Ae.CODE_START_A=103,Ae.CODE_START_B=104,Ae.CODE_START_C=105,Ae.CODE_STOP=106;var be=function(e){d(n,e);var t=f(n);function n(){var e,r=arguments.length>0&&void 0!==arguments[0]&&arguments[0],i=arguments.length>1&&void 0!==arguments[1]&&arguments[1];return u(this,n),(e=t.call(this)).usingCheckDigit=r,e.extendedMode=i,e.decodeRowResult="",e.counters=new Int32Array(9),e}return c(n,[{key:"decodeRow",value:function(e,t,r){var i=this.counters;i.fill(0),this.decodeRowResult="";var a,o,s=n.findAsteriskPattern(t,i),u=t.getNextSet(s[1]),c=t.getSize();do{n.recordPattern(t,u,i);var d=n.toNarrowWidePattern(i);if(d<0)throw new F;a=n.patternToChar(d),this.decodeRowResult+=a,o=u;var f,h=l(i);try{for(h.s();!(f=h.n()).done;)u+=f.value}catch(b){h.e(b)}finally{h.f()}u=t.getNextSet(u)}while("*"!==a);this.decodeRowResult=this.decodeRowResult.substring(0,this.decodeRowResult.length-1);var v,p,g=0,m=l(i);try{for(m.s();!(v=m.n()).done;)g+=v.value}catch(b){m.e(b)}finally{m.f()}if(u!==c&&2*(u-o-g)r&&(a=s)}}catch(p){o.e(p)}finally{o.f()}r=a,t=0;for(var u=0,c=0,d=0;dr&&(c|=1<0;h++){var v=e[h];if(v>r&&(t--,2*v>=u))return-1}return c}}while(t>3);return-1}},{key:"patternToChar",value:function(e){for(var t=0;t="A"&&a<="Z"))throw new D;o=String.fromCharCode(a.charCodeAt(0)+32);break;case"$":if(!(a>="A"&&a<="Z"))throw new D;o=String.fromCharCode(a.charCodeAt(0)-64);break;case"%":if(a>="A"&&a<="E")o=String.fromCharCode(a.charCodeAt(0)-38);else if(a>="F"&&a<="J")o=String.fromCharCode(a.charCodeAt(0)-11);else if(a>="K"&&a<="O")o=String.fromCharCode(a.charCodeAt(0)+16);else if(a>="P"&&a<="T")o=String.fromCharCode(a.charCodeAt(0)+43);else if("U"===a)o="\0";else if("V"===a)o="@";else if("W"===a)o="`";else{if("X"!==a&&"Y"!==a&&"Z"!==a)throw new D;o="\x7f"}break;case"/":if(a>="A"&&a<="O")o=String.fromCharCode(a.charCodeAt(0)-32);else{if("Z"!==a)throw new D;o=":"}}n+=o,r++}else n+=i}return n}}]),n}(Ce);be.ALPHABET_STRING="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%",be.CHARACTER_ENCODINGS=[52,289,97,352,49,304,112,37,292,100,265,73,328,25,280,88,13,268,76,28,259,67,322,19,274,82,7,262,70,22,385,193,448,145,400,208,133,388,196,168,162,138,42],be.ASTERISK_ENCODING=148;var ke=function(e){d(n,e);var t=f(n);function n(){var e;return u(this,n),(e=t.apply(this,arguments)).narrowLineWidth=-1,e}return c(n,[{key:"decodeRow",value:function(e,t,r){var i=this.decodeStart(t),a=this.decodeEnd(t),o=new L;n.decodeMiddle(t,i[1],a[0],o);var s=o.toString(),u=null;null!=r&&(u=r.get(N.ALLOWED_LENGTHS)),null==u&&(u=n.DEFAULT_ALLOWED_LENGTHS);var c,d=s.length,f=!1,h=0,v=l(u);try{for(v.s();!(c=v.n()).done;){var p=c.value;if(d===p){f=!0;break}p>h&&(h=p)}}catch(m){v.e(m)}finally{v.f()}if(!f&&d>h&&(f=!0),!f)throw new D;var g=[new ce(i[1],e),new ce(a[0],e)];return new Q(s,null,0,g,K.ITF,(new Date).getTime())}},{key:"decodeStart",value:function(e){var t=n.skipWhiteSpace(e),r=n.findGuardPattern(e,t,n.START_PATTERN);return this.narrowLineWidth=(r[1]-r[0])/4,this.validateQuietZone(e,r[0]),r}},{key:"validateQuietZone",value:function(e,t){var n=10*this.narrowLineWidth;n=n0&&r>=0&&!e.get(r);r--)n--;if(0!==n)throw new F}},{key:"decodeEnd",value:function(e){e.reverse();try{var t,r=n.skipWhiteSpace(e);try{t=n.findGuardPattern(e,r,n.END_PATTERN_REVERSED[0])}catch(a){a instanceof F&&(t=n.findGuardPattern(e,r,n.END_PATTERN_REVERSED[1]))}this.validateQuietZone(e,t[0]);var i=t[0];return t[0]=e.getSize()-t[1],t[1]=e.getSize()-i,t}finally{e.reverse()}}}],[{key:"decodeMiddle",value:function(e,t,r,i){var a=new Int32Array(10),o=new Int32Array(5),s=new Int32Array(5);for(a.fill(0),o.fill(0),s.fill(0);t=0)return r%10;throw new F}}]),n}(Ce);ke.PATTERNS=[Int32Array.from([1,1,2,2,1]),Int32Array.from([2,1,1,1,2]),Int32Array.from([1,2,1,1,2]),Int32Array.from([2,2,1,1,1]),Int32Array.from([1,1,2,1,2]),Int32Array.from([2,1,2,1,1]),Int32Array.from([1,2,2,1,1]),Int32Array.from([1,1,1,2,2]),Int32Array.from([2,1,1,2,1]),Int32Array.from([1,2,1,2,1]),Int32Array.from([1,1,3,3,1]),Int32Array.from([3,1,1,1,3]),Int32Array.from([1,3,1,1,3]),Int32Array.from([3,3,1,1,1]),Int32Array.from([1,1,3,1,3]),Int32Array.from([3,1,3,1,1]),Int32Array.from([1,3,3,1,1]),Int32Array.from([1,1,1,3,3]),Int32Array.from([3,1,1,3,1]),Int32Array.from([1,3,1,3,1])],ke.MAX_AVG_VARIANCE=.38,ke.MAX_INDIVIDUAL_VARIANCE=.5,ke.DEFAULT_ALLOWED_LENGTHS=[6,8,10,12,14],ke.START_PATTERN=Int32Array.from([1,1,1,1]),ke.END_PATTERN_REVERSED=[Int32Array.from([1,1,2]),Int32Array.from([1,1,3])];var Ie=function(e){d(n,e);var t=f(n);function n(){var e;return u(this,n),(e=t.apply(this,arguments)).decodeRowStringBuffer="",e}return c(n,null,[{key:"findStartGuardPattern",value:function(e){for(var t,r=!1,i=0,a=Int32Array.from([0,0,0]);!r;){a=Int32Array.from([0,0,0]);var o=(t=n.findGuardPattern(e,i,!1,this.START_END_PATTERN,a))[0],s=o-((i=t[1])-o);s>=0&&(r=e.isRange(s,o,!1))}return t}},{key:"checkChecksum",value:function(e){return n.checkStandardUPCEANChecksum(e)}},{key:"checkStandardUPCEANChecksum",value:function(e){var t=e.length;if(0===t)return!1;var r=parseInt(e.charAt(t-1),10);return n.getStandardUPCEANChecksum(e.substring(0,t-1))===r}},{key:"getStandardUPCEANChecksum",value:function(e){for(var t=e.length,n=0,r=t-1;r>=0;r-=2){var i=e.charAt(r).charCodeAt(0)-"0".charCodeAt(0);if(i<0||i>9)throw new D;n+=i}n*=3;for(var a=t-2;a>=0;a-=2){var o=e.charAt(a).charCodeAt(0)-"0".charCodeAt(0);if(o<0||o>9)throw new D;n+=o}return(1e3-n)%10}},{key:"decodeEnd",value:function(e,t){return n.findGuardPattern(e,t,!1,n.START_END_PATTERN,new Int32Array(n.START_END_PATTERN.length).fill(0))}},{key:"findGuardPatternWithoutCounters",value:function(e,t,n,r){return this.findGuardPattern(e,t,n,r,new Int32Array(r.length))}},{key:"findGuardPattern",value:function(e,t,r,i,a){for(var o=e.getSize(),s=0,l=t=r?e.getNextUnset(t):e.getNextSet(t),u=i.length,c=r,d=t;d=0)return o;throw new F}}]),n}(Ce);Ie.MAX_AVG_VARIANCE=.48,Ie.MAX_INDIVIDUAL_VARIANCE=.7,Ie.START_END_PATTERN=Int32Array.from([1,1,1]),Ie.MIDDLE_PATTERN=Int32Array.from([1,1,1,1,1]),Ie.END_PATTERN=Int32Array.from([1,1,1,1,1,1]),Ie.L_PATTERNS=[Int32Array.from([3,2,1,1]),Int32Array.from([2,2,2,1]),Int32Array.from([2,1,2,2]),Int32Array.from([1,4,1,1]),Int32Array.from([1,1,3,2]),Int32Array.from([1,2,3,1]),Int32Array.from([1,1,1,4]),Int32Array.from([1,3,1,2]),Int32Array.from([1,2,1,3]),Int32Array.from([3,1,1,2])];var _e=function(){function e(){u(this,e),this.CHECK_DIGIT_ENCODINGS=[24,20,18,17,12,6,3,10,9,5],this.decodeMiddleCounters=Int32Array.from([0,0,0,0]),this.decodeRowStringBuffer=""}return c(e,[{key:"decodeRow",value:function(t,n,r){var i=this.decodeRowStringBuffer,a=this.decodeMiddle(n,r,i),o=i.toString(),s=e.parseExtensionString(o),l=[new ce((r[0]+r[1])/2,t),new ce(a,t)],u=new Q(o,null,0,l,K.UPC_EAN_EXTENSION,(new Date).getTime());return null!=s&&u.putAllMetadata(s),u}},{key:"decodeMiddle",value:function(t,n,r){var i=this.decodeMiddleCounters;i[0]=0,i[1]=0,i[2]=0,i[3]=0;for(var a=t.getSize(),o=n[1],s=0,u=0;u<5&&o=10&&(s|=1<<4-u),4!==u&&(o=t.getNextSet(o),o=t.getNextUnset(o))}if(5!==r.length)throw new F;var h=this.determineCheckDigit(s);if(e.extensionChecksum(r.toString())!==h)throw new F;return o}},{key:"determineCheckDigit",value:function(e){for(var t=0;t<10;t++)if(e===this.CHECK_DIGIT_ENCODINGS[t])return t;throw new F}}],[{key:"extensionChecksum",value:function(e){for(var t=e.length,n=0,r=t-2;r>=0;r-=2)n+=e.charAt(r).charCodeAt(0)-"0".charCodeAt(0);n*=3;for(var i=t-1;i>=0;i-=2)n+=e.charAt(i).charCodeAt(0)-"0".charCodeAt(0);return(n*=3)%10}},{key:"parseExtensionString",value:function(t){if(5!==t.length)return null;var n=e.parseExtension5String(t);return null==n?null:new Map([[q.SUGGESTED_PRICE,n]])}},{key:"parseExtension5String",value:function(e){var t;switch(e.charAt(0)){case"0":t="\xa3";break;case"5":t="$";break;case"9":switch(e){case"90000":return null;case"99991":return"0.00";case"99990":return"Used"}t="";break;default:t=""}var n=parseInt(e.substring(1)),r=n%100;return t+(n/100).toString()+"."+(r<10?"0"+r:r.toString())}}]),e}(),Te=function(){function e(){u(this,e),this.decodeMiddleCounters=Int32Array.from([0,0,0,0]),this.decodeRowStringBuffer=""}return c(e,[{key:"decodeRow",value:function(t,n,r){var i=this.decodeRowStringBuffer,a=this.decodeMiddle(n,r,i),o=i.toString(),s=e.parseExtensionString(o),l=[new ce((r[0]+r[1])/2,t),new ce(a,t)],u=new Q(o,null,0,l,K.UPC_EAN_EXTENSION,(new Date).getTime());return null!=s&&u.putAllMetadata(s),u}},{key:"decodeMiddle",value:function(e,t,n){var r=this.decodeMiddleCounters;r[0]=0,r[1]=0,r[2]=0,r[3]=0;for(var i=e.getSize(),a=t[1],o=0,s=0;s<2&&a=10&&(o|=1<<1-s),1!==s&&(a=e.getNextSet(a),a=e.getNextUnset(a))}if(2!==n.length)throw new F;if(parseInt(n.toString())%4!==o)throw new F;return a}}],[{key:"parseExtensionString",value:function(e){return 2!==e.length?null:new Map([[q.ISSUE_NUMBER,parseInt(e)]])}}]),e}(),Me=function(){function e(){u(this,e)}return c(e,null,[{key:"decodeRow",value:function(e,t,n){var r=Ie.findGuardPattern(t,n,!1,this.EXTENSION_START_PATTERN,new Int32Array(this.EXTENSION_START_PATTERN.length).fill(0));try{return(new _e).decodeRow(e,t,r)}catch(i){return(new Te).decodeRow(e,t,r)}}}]),e}();Me.EXTENSION_START_PATTERN=Int32Array.from([1,1,2]);var Ne=function(e){d(n,e);var t=f(n);function n(){var e;u(this,n),(e=t.call(this)).decodeRowStringBuffer="",n.L_AND_G_PATTERNS=n.L_PATTERNS.map((function(e){return Int32Array.from(e)}));for(var r=10;r<20;r++){for(var i=n.L_PATTERNS[r-10],a=new Int32Array(i.length),o=0;o=t.getSize()||!t.isRange(h,v,!1))throw new F;var p=u.toString();if(p.length<8)throw new D;if(!n.checkChecksum(p))throw new E;var g=(i[1]+i[0])/2,m=(d[1]+d[0])/2,y=this.getBarcodeFormat(),w=[new ce(g,e),new ce(m,e)],S=new Q(p,null,0,w,y,(new Date).getTime()),C=0;try{var A=Me.decodeRow(e,t,d[1]);S.putMetadata(q.UPC_EAN_EXTENSION,A.getText()),S.putAllMetadata(A.getResultMetadata()),S.addResultPoints(A.getResultPoints()),C=A.getText().length}catch(_){}var b=null==r?null:r.get(N.ALLOWED_EAN_EXTENSIONS);if(null!=b){var k=!1;for(var I in b)if(C.toString()===I){k=!0;break}if(!k)throw new F}return y===K.EAN_13||K.UPC_A,S}}],[{key:"checkChecksum",value:function(e){return n.checkStandardUPCEANChecksum(e)}},{key:"checkStandardUPCEANChecksum",value:function(e){var t=e.length;if(0===t)return!1;var r=parseInt(e.charAt(t-1),10);return n.getStandardUPCEANChecksum(e.substring(0,t-1))===r}},{key:"getStandardUPCEANChecksum",value:function(e){for(var t=e.length,n=0,r=t-1;r>=0;r-=2){var i=e.charAt(r).charCodeAt(0)-"0".charCodeAt(0);if(i<0||i>9)throw new D;n+=i}n*=3;for(var a=t-2;a>=0;a-=2){var o=e.charAt(a).charCodeAt(0)-"0".charCodeAt(0);if(o<0||o>9)throw new D;n+=o}return(1e3-n)%10}},{key:"decodeEnd",value:function(e,t){return n.findGuardPattern(e,t,!1,n.START_END_PATTERN,new Int32Array(n.START_END_PATTERN.length).fill(0))}}]),n}(Ie),De=function(e){d(n,e);var t=f(n);function n(){var e;return u(this,n),(e=t.call(this)).decodeMiddleCounters=Int32Array.from([0,0,0,0]),e}return c(n,[{key:"decodeMiddle",value:function(e,t,r){var i=this.decodeMiddleCounters;i[0]=0,i[1]=0,i[2]=0,i[3]=0;for(var a=e.getSize(),o=t[1],s=0,u=0;u<6&&o=10&&(s|=1<<5-u)}r=n.determineFirstDigit(r,s),o=Ne.findGuardPattern(e,o,!0,Ne.MIDDLE_PATTERN,new Int32Array(Ne.MIDDLE_PATTERN.length).fill(0))[1];for(var h=0;h<6&&o=10&&(s|=1<<5-u)}return n.determineNumSysAndCheckDigit(new L(r),s),o}},{key:"decodeEnd",value:function(e,t){return n.findGuardPatternWithoutCounters(e,t,!0,n.MIDDLE_END_PATTERN)}},{key:"checkChecksum",value:function(e){return Ne.checkChecksum(n.convertUPCEtoUPCA(e))}},{key:"getBarcodeFormat",value:function(){return K.UPC_E}}],[{key:"determineNumSysAndCheckDigit",value:function(e,t){for(var n=0;n<=1;n++)for(var r=0;r<10;r++)if(t===this.NUMSYS_AND_CHECK_DIGIT_PATTERNS[n][r])return e.insert(0,"0"+n),void e.append("0"+r);throw F.getNotFoundInstance()}},{key:"convertUPCEtoUPCA",value:function(e){var t=e.slice(1,7).split("").map((function(e){return e.charCodeAt(0)})),n=new L;n.append(e.charAt(0));var r=t[5];switch(r){case 0:case 1:case 2:n.appendChars(t,0,2),n.append(r),n.append("0000"),n.appendChars(t,2,3);break;case 3:n.appendChars(t,0,3),n.append("00000"),n.appendChars(t,3,2);break;case 4:n.appendChars(t,0,4),n.append("00000"),n.append(t[4]);break;default:n.appendChars(t,0,5),n.append("0000"),n.append(r)}return e.length>=8&&n.append(e.charAt(7)),n.toString()}}]),n}(Ne);xe.MIDDLE_END_PATTERN=Int32Array.from([1,1,1,1,1,1]),xe.NUMSYS_AND_CHECK_DIGIT_PATTERNS=[Int32Array.from([56,52,50,49,44,38,35,42,41,37]),Int32Array.from([7,11,13,14,19,25,28,21,22,1])];var Pe=function(e){d(n,e);var t=f(n);function n(e){var r;u(this,n),r=t.call(this);var i=null==e?null:e.get(N.POSSIBLE_FORMATS),a=[];return null!=i&&(i.indexOf(K.EAN_13)>-1?a.push(new De):i.indexOf(K.UPC_A)>-1&&a.push(new Oe),i.indexOf(K.EAN_8)>-1&&a.push(new Re),i.indexOf(K.UPC_E)>-1&&a.push(new xe)),0===a.length&&(a.push(new De),a.push(new Re),a.push(new xe)),r.readers=a,r}return c(n,[{key:"decodeRow",value:function(e,t,n){var r,i=l(this.readers);try{for(i.s();!(r=i.n()).done;){var a=r.value;try{var o=a.decodeRow(e,t,n),s=o.getBarcodeFormat()===K.EAN_13&&"0"===o.getText().charAt(0),u=null==n?null:n.get(N.POSSIBLE_FORMATS),c=null==u||u.includes(K.UPC_A);if(s&&c){var d=o.getRawBytes(),f=new Q(o.getText().substring(1),d,d.length,o.getResultPoints(),K.UPC_A);return f.putAllMetadata(o.getResultMetadata()),f}return o}catch(h){}}}catch(h){i.e(h)}finally{i.f()}throw new F}},{key:"reset",value:function(){var e,t=l(this.readers);try{for(t.s();!(e=t.n()).done;)e.value.reset()}catch(n){t.e(n)}finally{t.f()}}}]),n}(Ce),Le=function(e){d(n,e);var t=f(n);function n(){var e;return u(this,n),(e=t.call(this)).decodeFinderCounters=new Int32Array(4),e.dataCharacterCounters=new Int32Array(8),e.oddRoundingErrors=new Array(4),e.evenRoundingErrors=new Array(4),e.oddCounts=new Array(e.dataCharacterCounters.length/2),e.evenCounts=new Array(e.dataCharacterCounters.length/2),e}return c(n,[{key:"getDecodeFinderCounters",value:function(){return this.decodeFinderCounters}},{key:"getDataCharacterCounters",value:function(){return this.dataCharacterCounters}},{key:"getOddRoundingErrors",value:function(){return this.oddRoundingErrors}},{key:"getEvenRoundingErrors",value:function(){return this.evenRoundingErrors}},{key:"getOddCounts",value:function(){return this.oddCounts}},{key:"getEvenCounts",value:function(){return this.evenCounts}},{key:"parseFinderValue",value:function(e,t){for(var r=0;rr&&(r=t[i],n=i);e[n]++}},{key:"decrement",value:function(e,t){for(var n=0,r=t[0],i=1;i=n.MIN_FINDER_PATTERN_RATIO&&r<=n.MAX_FINDER_PATTERN_RATIO){var i,a=Number.MAX_SAFE_INTEGER,o=Number.MIN_SAFE_INTEGER,s=l(e);try{for(s.s();!(i=s.n()).done;){var u=i.value;u>o&&(o=u),u=c-d-1&&(h-=e.combins(a-f-(c-d),c-d-2)),c-d-1>1){for(var v=0,p=a-f-(c-d-2);p>n;p--)v+=e.combins(a-f-p-1,c-d-3);h-=v*(c-1-d)}else a-f>n&&h--;s+=h}a-=f}return s}},{key:"combins",value:function(e,t){var n,r;e-t>t?(r=t,n=e-t):(r=e-t,n=t);for(var i=1,a=1,o=e;o>n;o--)i*=o,a<=r&&(i/=a,a++);for(;a<=r;)i/=a,a++;return i}}]),e}(),ze=function(){function e(){u(this,e)}return c(e,null,[{key:"buildBitArray",value:function(e){var t=2*e.length-1;null==e[e.length-1].getRightChar()&&(t-=1);for(var n=new T(12*t),r=0,i=e[0].getRightChar().getValue(),a=11;a>=0;--a)0!=(i&1<=0;--u)0!=(l&1<=0;--d)0!=(c&1<10||i<0||i>10)throw new D;return a.firstDigit=r,a.secondDigit=i,a}return c(n,[{key:"getFirstDigit",value:function(){return this.firstDigit}},{key:"getSecondDigit",value:function(){return this.secondDigit}},{key:"getValue",value:function(){return 10*this.firstDigit+this.secondDigit}},{key:"isFirstDigitFNC1",value:function(){return this.firstDigit===n.FNC1}},{key:"isSecondDigitFNC1",value:function(){return this.secondDigit===n.FNC1}},{key:"isAnyFNC1",value:function(){return this.firstDigit===n.FNC1||this.secondDigit===n.FNC1}}]),n}(je);We.FNC1=10;var Ye=function(){function e(){u(this,e)}return c(e,null,[{key:"parseFieldsInGeneralPurpose",value:function(t){if(!t)return null;if(t.length<2)throw new F;var n,r=t.substring(0,2),i=l(e.TWO_DIGIT_DATA_LENGTH);try{for(i.s();!(n=i.n()).done;){var a=n.value;if(a[0]===r)return a[1]===e.VARIABLE_LENGTH?e.processVariableAI(2,a[2],t):e.processFixedAI(2,a[1],t)}}catch(y){i.e(y)}finally{i.f()}if(t.length<3)throw new F;var o,s=t.substring(0,3),u=l(e.THREE_DIGIT_DATA_LENGTH);try{for(u.s();!(o=u.n()).done;){var c=o.value;if(c[0]===s)return c[1]===e.VARIABLE_LENGTH?e.processVariableAI(3,c[2],t):e.processFixedAI(3,c[1],t)}}catch(y){u.e(y)}finally{u.f()}var d,f=l(e.THREE_DIGIT_PLUS_DIGIT_DATA_LENGTH);try{for(f.s();!(d=f.n()).done;){var h=d.value;if(h[0]===s)return h[1]===e.VARIABLE_LENGTH?e.processVariableAI(4,h[2],t):e.processFixedAI(4,h[1],t)}}catch(y){f.e(y)}finally{f.f()}if(t.length<4)throw new F;var v,p=t.substring(0,4),g=l(e.FOUR_DIGIT_DATA_LENGTH);try{for(g.s();!(v=g.n()).done;){var m=v.value;if(m[0]===p)return m[1]===e.VARIABLE_LENGTH?e.processVariableAI(4,m[2],t):e.processFixedAI(4,m[1],t)}}catch(y){g.e(y)}finally{g.f()}throw new F}},{key:"processFixedAI",value:function(t,n,r){if(r.lengththis.information.getSize())return e+4<=this.information.getSize();for(var t=e;tthis.information.getSize()){var t=this.extractNumericValueFromBitArray(e,4);return new We(this.information.getSize(),0===t?We.FNC1:t-1,We.FNC1)}var n=this.extractNumericValueFromBitArray(e,7);return new We(e+7,(n-8)/11,(n-8)%11)}},{key:"extractNumericValueFromBitArray",value:function(t,n){return e.extractNumericValueFromBitArray(this.information,t,n)}},{key:"decodeGeneralPurposeField",value:function(e,t){this.buffer.setLengthToZero(),null!=t&&this.buffer.append(t),this.current.setPosition(e);var n=this.parseBlocks();return null!=n&&n.isRemaining()?new Ge(this.current.getPosition(),this.buffer.toString(),n.getRemainingValue()):new Ge(this.current.getPosition(),this.buffer.toString())}},{key:"parseBlocks",value:function(){var e,t;do{var n=this.current.getPosition();if(e=this.current.isAlpha()?(t=this.parseAlphaBlock()).isFinished():this.current.isIsoIec646()?(t=this.parseIsoIec646Block()).isFinished():(t=this.parseNumericBlock()).isFinished(),n===this.current.getPosition()&&!e)break}while(!e);return t.getDecodedInformation()}},{key:"parseNumericBlock",value:function(){for(;this.isStillNumeric(this.current.getPosition());){var e=this.decodeNumeric(this.current.getPosition());if(this.current.setPosition(e.getNewPosition()),e.isFirstDigitFNC1()){var t=void 0;return t=e.isSecondDigitFNC1()?new Ge(this.current.getPosition(),this.buffer.toString()):new Ge(this.current.getPosition(),this.buffer.toString(),e.getSecondDigit()),new He(!0,t)}if(this.buffer.append(e.getFirstDigit()),e.isSecondDigitFNC1()){var n=new Ge(this.current.getPosition(),this.buffer.toString());return new He(!0,n)}this.buffer.append(e.getSecondDigit())}return this.isNumericToAlphaNumericLatch(this.current.getPosition())&&(this.current.setAlpha(),this.current.incrementPosition(4)),new He(!1)}},{key:"parseIsoIec646Block",value:function(){for(;this.isStillIsoIec646(this.current.getPosition());){var e=this.decodeIsoIec646(this.current.getPosition());if(this.current.setPosition(e.getNewPosition()),e.isFNC1()){var t=new Ge(this.current.getPosition(),this.buffer.toString());return new He(!0,t)}this.buffer.append(e.getValue())}return this.isAlphaOr646ToNumericLatch(this.current.getPosition())?(this.current.incrementPosition(3),this.current.setNumeric()):this.isAlphaTo646ToAlphaLatch(this.current.getPosition())&&(this.current.getPosition()+5this.information.getSize())return!1;var t=this.extractNumericValueFromBitArray(e,5);if(t>=5&&t<16)return!0;if(e+7>this.information.getSize())return!1;var n=this.extractNumericValueFromBitArray(e,7);if(n>=64&&n<116)return!0;if(e+8>this.information.getSize())return!1;var r=this.extractNumericValueFromBitArray(e,8);return r>=232&&r<253}},{key:"decodeIsoIec646",value:function(e){var t=this.extractNumericValueFromBitArray(e,5);if(15===t)return new Ve(e+5,Ve.FNC1);if(t>=5&&t<15)return new Ve(e+5,"0"+(t-5));var n,r=this.extractNumericValueFromBitArray(e,7);if(r>=64&&r<90)return new Ve(e+7,""+(r+1));if(r>=90&&r<116)return new Ve(e+7,""+(r+7));switch(this.extractNumericValueFromBitArray(e,8)){case 232:n="!";break;case 233:n='"';break;case 234:n="%";break;case 235:n="&";break;case 236:n="'";break;case 237:n="(";break;case 238:n=")";break;case 239:n="*";break;case 240:n="+";break;case 241:n=",";break;case 242:n="-";break;case 243:n=".";break;case 244:n="/";break;case 245:n=":";break;case 246:n=";";break;case 247:n="<";break;case 248:n="=";break;case 249:n=">";break;case 250:n="?";break;case 251:n="_";break;case 252:n=" ";break;default:throw new D}return new Ve(e+8,n)}},{key:"isStillAlpha",value:function(e){if(e+5>this.information.getSize())return!1;var t=this.extractNumericValueFromBitArray(e,5);if(t>=5&&t<16)return!0;if(e+6>this.information.getSize())return!1;var n=this.extractNumericValueFromBitArray(e,6);return n>=16&&n<63}},{key:"decodeAlphanumeric",value:function(e){var t=this.extractNumericValueFromBitArray(e,5);if(15===t)return new Ve(e+5,Ve.FNC1);if(t>=5&&t<15)return new Ve(e+5,"0"+(t-5));var n,r=this.extractNumericValueFromBitArray(e,6);if(r>=32&&r<58)return new Ve(e+6,""+(r+33));switch(r){case 58:n="*";break;case 59:n=",";break;case 60:n="-";break;case 61:n=".";break;case 62:n="/";break;default:throw new ie("Decoding invalid alphanumeric value: "+r)}return new Ve(e+6,n)}},{key:"isAlphaTo646ToAlphaLatch",value:function(e){if(e+1>this.information.getSize())return!1;for(var t=0;t<5&&t+ethis.information.getSize())return!1;for(var t=e;tthis.information.getSize())return!1;for(var t=0;t<4&&t+e25)return this.rows.length=0,null;this.pairs.length=0,e&&(this.rows=this.rows.reverse());var t=null;try{t=this.checkRows(new Array,0)}catch(n){this.verbose&&console.log(n)}return e&&(this.rows=this.rows.reverse()),t}},{key:"checkRows",value:function(e,t){for(var r=t;re){a=o.isEquivalent(this.pairs);break}i=o.isEquivalent(this.pairs),r++}a||i||n.isPartialRow(this.pairs,this.rows)||(this.rows.push(r,new st(this.pairs,e,t)),this.removePartialRows(this.pairs,this.rows))}},{key:"removePartialRows",value:function(e,t){var n,r=l(t);try{for(r.s();!(n=r.n()).done;){var i=n.value;if(i.getPairs().length!==e.length){var a,o=l(i.getPairs());try{for(o.s();!(a=o.n()).done;){var s,u=a.value,c=l(e);try{for(c.s();!(s=c.n()).done;){var d=s.value;if(ot.equals(u,d))break}}catch(f){c.e(f)}finally{c.f()}}}catch(f){o.e(f)}finally{o.f()}}}}catch(f){r.e(f)}finally{r.f()}}},{key:"getRows",value:function(){return this.rows}},{key:"checkChecksum",value:function(){var e=this.pairs.get(0),t=e.getLeftChar(),n=e.getRightChar();if(null==n)return!1;for(var r=n.getChecksumPortion(),i=2,a=1;a=0?r:this.isEmptyPair(t)?0:t[t.length-1].getFinderPattern().getStartEnd()[1];var s=t.length%2!=0;this.startFromEven&&(s=!s);for(var l=!1;a=0&&!e.get(s);)s--;s++,i=this.startEnd[0]-s,a=s,o=this.startEnd[1]}else a=this.startEnd[0],i=(o=e.getNextUnset(this.startEnd[1]+1))-this.startEnd[1];var l,u=this.getDecodeFinderCounters();C.arraycopy(u,0,u,1,u.length-1),u[0]=i;try{l=this.parseFinderValue(u,n.FINDER_PATTERNS)}catch(c){return null}return new Fe(l,[a,o],a,o,t)}},{key:"decodeDataCharacter",value:function(e,t,r,i){for(var a=this.getDataCharacterCounters(),o=0;o.3)throw new F;for(var h=this.getOddCounts(),v=this.getEvenCounts(),p=this.getOddRoundingErrors(),g=this.getEvenRoundingErrors(),m=0;m8){if(y>8.7)throw new F;w=8}var E=m/2;0==(1&m)?(h[E]=w,p[E]=y-w):(v[E]=w,g[E]=y-w)}this.adjustOddEvenCounts(c);for(var S=4*t.getValue()+(r?0:2)+(i?0:1)-1,C=0,A=0,b=h.length-1;b>=0;b--){if(n.isNotA1left(t,r,i)){var k=n.WEIGHTS[S][2*b];A+=h[b]*k}C+=h[b]}for(var I=0,_=v.length-1;_>=0;_--)if(n.isNotA1left(t,r,i)){var T=n.WEIGHTS[S][2*_+1];I+=v[_]*T}var M=A+I;if(0!=(1&C)||C>13||C<4)throw new F;var N=(13-C)/2,D=n.SYMBOL_WIDEST[N],R=9-D,O=Ue.getRSSvalue(h,D,!0),x=Ue.getRSSvalue(v,R,!1),P=n.EVEN_TOTAL_SUBSET[N],L=n.GSUM[N];return new Be(O*P+x+L,M)}},{key:"adjustOddEvenCounts",value:function(e){var t=le.sum(new Int32Array(this.getOddCounts())),r=le.sum(new Int32Array(this.getEvenCounts())),i=!1,a=!1;t>13?a=!0:t<4&&(i=!0);var o=!1,s=!1;r>13?s=!0:r<4&&(o=!0);var l=t+r-e,u=1==(1&t),c=0==(1&r);if(1==l)if(u){if(c)throw new F;a=!0}else{if(!c)throw new F;s=!0}else if(-1==l)if(u){if(c)throw new F;i=!0}else{if(!c)throw new F;o=!0}else{if(0!=l)throw new F;if(u){if(!c)throw new F;ti.length)){for(var a=!0,o=0;o1){var c,d=l(this.possibleRightPairs);try{for(d.s();!(c=d.n()).done;){var f=c.value;if(f.getCount()>1&&n.checkChecksum(u,f))return n.constructResult(u,f)}}catch(h){d.e(h)}finally{d.f()}}}}catch(h){s.e(h)}finally{s.f()}throw new F}},{key:"reset",value:function(){this.possibleLeftPairs.length=0,this.possibleRightPairs.length=0}},{key:"decodePair",value:function(e,t,n,r){try{var i=this.findFinderPattern(e,t),a=this.parseFoundFinderPattern(e,n,t,i),o=null==r?null:r.get(N.NEED_RESULT_POINT_CALLBACK);if(null!=o){var s=(i[0]+i[1])/2;t&&(s=e.getSize()-1-s),o.foundPossibleResultPoint(new ce(s,n))}var l=this.decodeDataCharacter(e,a,!0),u=this.decodeDataCharacter(e,a,!1);return new ut(1597*l.getValue()+u.getValue(),l.getChecksumPortion()+4*u.getChecksumPortion(),a)}catch(c){return null}}},{key:"decodeDataCharacter",value:function(e,t,r){for(var i=this.getDataCharacterCounters(),a=0;a8&&(m=8);var y=Math.floor(p/2);0===(1&p)?(d[y]=m,h[y]=g-m):(f[y]=m,v[y]=g-m)}this.adjustOddEvenCounts(r,u);for(var w=0,E=0,S=d.length-1;S>=0;S--)E*=9,E+=d[S],w+=d[S];for(var C=0,A=0,b=f.length-1;b>=0;b--)C*=9,C+=f[b],A+=f[b];var k=E+3*C;if(r){if(0!==(1&w)||w>12||w<4)throw new F;var I=(12-w)/2,_=n.OUTSIDE_ODD_WIDEST[I],T=9-_,M=Ue.getRSSvalue(d,_,!1),N=Ue.getRSSvalue(f,T,!0),D=n.OUTSIDE_EVEN_TOTAL_SUBSET[I],R=n.OUTSIDE_GSUM[I];return new Be(M*D+N+R,k)}if(0!==(1&A)||A>10||A<4)throw new F;var O=(10-A)/2,x=n.INSIDE_ODD_WIDEST[O],P=9-x,L=Ue.getRSSvalue(d,x,!0),B=Ue.getRSSvalue(f,P,!1),U=n.INSIDE_ODD_TOTAL_SUBSET[O],z=n.INSIDE_GSUM[O];return new Be(B*U+L+z,k)}},{key:"findFinderPattern",value:function(e,t){var n=this.getDecodeFinderCounters();n[0]=0,n[1]=0,n[2]=0,n[3]=0;for(var r=e.getSize(),i=!1,a=0;a=0&&a!==e.get(o);)o--;o++;var s=i[0]-o,l=this.getDecodeFinderCounters(),u=new Int32Array(l.length);C.arraycopy(l,0,u,1,l.length-1),u[0]=s;var c=this.parseFinderValue(u,n.FINDER_PATTERNS),d=o,f=i[1];return r&&(d=e.getSize()-1-d,f=e.getSize()-1-f),new Fe(c,[o,i[1]],d,f,t)}},{key:"adjustOddEvenCounts",value:function(e,t){var n=le.sum(new Int32Array(this.getOddCounts())),r=le.sum(new Int32Array(this.getEvenCounts())),i=!1,a=!1,o=!1,s=!1;e?(n>12?a=!0:n<4&&(i=!0),r>12?s=!0:r<4&&(o=!0)):(n>11?a=!0:n<5&&(i=!0),r>10?s=!0:r<4&&(o=!0));var l=n+r-t,u=(1&n)===(e?1:0),c=1===(1&r);if(1===l)if(u){if(c)throw new F;a=!0}else{if(!c)throw new F;s=!0}else if(-1===l)if(u){if(c)throw new F;i=!0}else{if(!c)throw new F;o=!0}else{if(0!==l)throw new F;if(u){if(!c)throw new F;n0;a--)i.append("0");i.append(r);for(var o=0,s=0;s<13;s++){var l=i.charAt(s).charCodeAt(0)-"0".charCodeAt(0);o+=0===(1&s)?3*l:l}10===(o=10-o%10)&&(o=0),i.append(o.toString());var u=e.getFinderPattern().getResultPoints(),c=t.getFinderPattern().getResultPoints();return new Q(i.toString(),null,0,[u[0],u[1],c[0],c[1]],K.RSS_14,(new Date).getTime())}},{key:"checkChecksum",value:function(e,t){var n=(e.getChecksumPortion()+16*t.getChecksumPortion())%79,r=9*e.getFinderPattern().getValue()+t.getFinderPattern().getValue();return r>72&&r--,r>8&&r--,n===r}}]),n}(Le);ct.OUTSIDE_EVEN_TOTAL_SUBSET=[1,10,34,70,126],ct.INSIDE_ODD_TOTAL_SUBSET=[4,20,48,81],ct.OUTSIDE_GSUM=[0,161,961,2015,2715],ct.INSIDE_GSUM=[0,336,1036,1516],ct.OUTSIDE_ODD_WIDEST=[8,6,4,3,1],ct.INSIDE_ODD_WIDEST=[2,4,6,8],ct.FINDER_PATTERNS=[Int32Array.from([3,8,2,1]),Int32Array.from([3,5,5,1]),Int32Array.from([3,3,7,1]),Int32Array.from([3,1,9,1]),Int32Array.from([2,7,4,1]),Int32Array.from([2,5,6,1]),Int32Array.from([2,3,8,1]),Int32Array.from([1,5,7,1]),Int32Array.from([1,3,9,1])];var dt=function(e){d(n,e);var t=f(n);function n(e,r){var i;u(this,n),(i=t.call(this)).readers=[],i.verbose=!0===r;var a=e?e.get(N.POSSIBLE_FORMATS):null,o=e&&void 0!==e.get(N.ASSUME_CODE_39_CHECK_DIGIT);return a&&((a.includes(K.EAN_13)||a.includes(K.UPC_A)||a.includes(K.EAN_8)||a.includes(K.UPC_E))&&i.readers.push(new Pe(e)),a.includes(K.CODE_39)&&i.readers.push(new be(o)),a.includes(K.CODE_128)&&i.readers.push(new Ae),a.includes(K.ITF)&&i.readers.push(new ke),a.includes(K.RSS_14)&&i.readers.push(new ct),a.includes(K.RSS_EXPANDED)&&i.readers.push(new lt(i.verbose))),0===i.readers.length&&(i.readers.push(new Pe(e)),i.readers.push(new be),i.readers.push(new Pe(e)),i.readers.push(new Ae),i.readers.push(new ke),i.readers.push(new ct),i.readers.push(new lt(i.verbose))),i}return c(n,[{key:"decodeRow",value:function(e,t,n){for(var r=0;r0&&void 0!==arguments[0]?arguments[0]:500,r=arguments.length>1?arguments[1]:void 0;return u(this,n),t.call(this,new dt(r),e,r)}return c(n)}(X),ht=function(){function e(t,n,r){u(this,e),this.ecCodewords=t,this.ecBlocks=[n],r&&this.ecBlocks.push(r)}return c(e,[{key:"getECCodewords",value:function(){return this.ecCodewords}},{key:"getECBlocks",value:function(){return this.ecBlocks}}]),e}(),vt=function(){function e(t,n){u(this,e),this.count=t,this.dataCodewords=n}return c(e,[{key:"getCount",value:function(){return this.count}},{key:"getDataCodewords",value:function(){return this.dataCodewords}}]),e}(),pt=function(){function e(t,n,r,i,a,o){u(this,e),this.versionNumber=t,this.symbolSizeRows=n,this.symbolSizeColumns=r,this.dataRegionSizeRows=i,this.dataRegionSizeColumns=a,this.ecBlocks=o;var s,c=0,d=o.getECCodewords(),f=o.getECBlocks(),h=l(f);try{for(h.s();!(s=h.n()).done;){var v=s.value;c+=v.getCount()*(v.getDataCodewords()+d)}}catch(p){h.e(p)}finally{h.f()}this.totalCodewords=c}return c(e,[{key:"getVersionNumber",value:function(){return this.versionNumber}},{key:"getSymbolSizeRows",value:function(){return this.symbolSizeRows}},{key:"getSymbolSizeColumns",value:function(){return this.symbolSizeColumns}},{key:"getDataRegionSizeRows",value:function(){return this.dataRegionSizeRows}},{key:"getDataRegionSizeColumns",value:function(){return this.dataRegionSizeColumns}},{key:"getTotalCodewords",value:function(){return this.totalCodewords}},{key:"getECBlocks",value:function(){return this.ecBlocks}},{key:"toString",value:function(){return""+this.versionNumber}}],[{key:"getVersionForDimensions",value:function(t,n){if(0!==(1&t)||0!==(1&n))throw new D;var r,i=l(e.VERSIONS);try{for(i.s();!(r=i.n()).done;){var a=r.value;if(a.symbolSizeRows===t&&a.symbolSizeColumns===n)return a}}catch(o){i.e(o)}finally{i.f()}throw new D}},{key:"buildVersions",value:function(){return[new e(1,10,10,8,8,new ht(5,new vt(1,3))),new e(2,12,12,10,10,new ht(7,new vt(1,5))),new e(3,14,14,12,12,new ht(10,new vt(1,8))),new e(4,16,16,14,14,new ht(12,new vt(1,12))),new e(5,18,18,16,16,new ht(14,new vt(1,18))),new e(6,20,20,18,18,new ht(18,new vt(1,22))),new e(7,22,22,20,20,new ht(20,new vt(1,30))),new e(8,24,24,22,22,new ht(24,new vt(1,36))),new e(9,26,26,24,24,new ht(28,new vt(1,44))),new e(10,32,32,14,14,new ht(36,new vt(1,62))),new e(11,36,36,16,16,new ht(42,new vt(1,86))),new e(12,40,40,18,18,new ht(48,new vt(1,114))),new e(13,44,44,20,20,new ht(56,new vt(1,144))),new e(14,48,48,22,22,new ht(68,new vt(1,174))),new e(15,52,52,24,24,new ht(42,new vt(2,102))),new e(16,64,64,14,14,new ht(56,new vt(2,140))),new e(17,72,72,16,16,new ht(36,new vt(4,92))),new e(18,80,80,18,18,new ht(48,new vt(4,114))),new e(19,88,88,20,20,new ht(56,new vt(4,144))),new e(20,96,96,22,22,new ht(68,new vt(4,174))),new e(21,104,104,24,24,new ht(56,new vt(6,136))),new e(22,120,120,18,18,new ht(68,new vt(6,175))),new e(23,132,132,20,20,new ht(62,new vt(8,163))),new e(24,144,144,22,22,new ht(62,new vt(8,156),new vt(2,155))),new e(25,8,18,6,16,new ht(7,new vt(1,5))),new e(26,8,32,6,14,new ht(11,new vt(1,10))),new e(27,12,26,10,24,new ht(14,new vt(1,16))),new e(28,12,36,10,16,new ht(18,new vt(1,22))),new e(29,16,36,14,16,new ht(24,new vt(1,32))),new e(30,16,48,14,22,new ht(28,new vt(1,49)))]}}]),e}();pt.VERSIONS=pt.buildVersions();var gt,mt=function(){function e(t){u(this,e);var n=t.getHeight();if(n<8||n>144||0!==(1&n))throw new D;this.version=e.readVersion(t),this.mappingBitMatrix=this.extractDataRegion(t),this.readMappingMatrix=new B(this.mappingBitMatrix.getWidth(),this.mappingBitMatrix.getHeight())}return c(e,[{key:"getVersion",value:function(){return this.version}},{key:"readCodewords",value:function(){var e=new Int8Array(this.version.getTotalCodewords()),t=0,n=4,r=0,i=this.mappingBitMatrix.getHeight(),a=this.mappingBitMatrix.getWidth(),o=!1,s=!1,l=!1,u=!1;do{if(n!==i||0!==r||o)if(n!==i-2||0!==r||0===(3&a)||s)if(n!==i+4||2!==r||0!==(7&a)||l)if(n!==i-2||0!==r||4!==(7&a)||u){do{n=0&&!this.readMappingMatrix.get(r,n)&&(e[t++]=255&this.readUtah(n,r,i,a)),n-=2,r+=2}while(n>=0&&r=0&&r=0);n+=3,r+=1}else e[t++]=255&this.readCorner4(i,a),n-=2,r+=2,u=!0;else e[t++]=255&this.readCorner3(i,a),n-=2,r+=2,l=!0;else e[t++]=255&this.readCorner2(i,a),n-=2,r+=2,s=!0;else e[t++]=255&this.readCorner1(i,a),n-=2,r+=2,o=!0}while(n7?_-1:_;c[M].codewords[N]=t[E++]}if(E!==t.length)throw new y;return c}}]),e}(),wt=function(){function e(t){u(this,e),this.bytes=t,this.byteOffset=0,this.bitOffset=0}return c(e,[{key:"getBitOffset",value:function(){return this.bitOffset}},{key:"getByteOffset",value:function(){return this.byteOffset}},{key:"readBits",value:function(e){if(e<1||e>32||e>this.available())throw new y(""+e);var t=0,n=this.bitOffset,r=this.byteOffset,i=this.bytes;if(n>0){var a=8-n,o=e>8-o<>s,e-=o,8===(n+=o)&&(n=0,r++)}if(e>0){for(;e>=8;)t=t<<8|255&i[r],r++,e-=8;if(e>0){var u=8-e,c=255>>u<>u,n+=e}}return this.bitOffset=n,this.byteOffset=r,t}},{key:"available",value:function(){return 8*(this.bytes.length-this.byteOffset)-this.bitOffset}}]),e}();!function(e){e[e.PAD_ENCODE=0]="PAD_ENCODE",e[e.ASCII_ENCODE=1]="ASCII_ENCODE",e[e.C40_ENCODE=2]="C40_ENCODE",e[e.TEXT_ENCODE=3]="TEXT_ENCODE",e[e.ANSIX12_ENCODE=4]="ANSIX12_ENCODE",e[e.EDIFACT_ENCODE=5]="EDIFACT_ENCODE",e[e.BASE256_ENCODE=6]="BASE256_ENCODE"}(gt||(gt={}));var Et=function(){function e(){u(this,e)}return c(e,null,[{key:"decode",value:function(e){var t=new wt(e),n=new L,r=new L,i=new Array,a=gt.ASCII_ENCODE;do{if(a===gt.ASCII_ENCODE)a=this.decodeAsciiSegment(t,n,r);else{switch(a){case gt.C40_ENCODE:this.decodeC40Segment(t,n);break;case gt.TEXT_ENCODE:this.decodeTextSegment(t,n);break;case gt.ANSIX12_ENCODE:this.decodeAnsiX12Segment(t,n);break;case gt.EDIFACT_ENCODE:this.decodeEdifactSegment(t,n);break;case gt.BASE256_ENCODE:this.decodeBase256Segment(t,n,i);break;default:throw new D}a=gt.ASCII_ENCODE}}while(a!==gt.PAD_ENCODE&&t.available()>0);return r.length()>0&&n.append(r.toString()),new $(e,n.toString(),0===i.length?null:i,null)}},{key:"decodeAsciiSegment",value:function(e,t,n){var r=!1;do{var i=e.readBits(8);if(0===i)throw new D;if(i<=128)return r&&(i+=128),t.append(String.fromCharCode(i-1)),gt.ASCII_ENCODE;if(129===i)return gt.PAD_ENCODE;if(i<=229){var a=i-130;a<10&&t.append("0"),t.append(""+a)}else switch(i){case 230:return gt.C40_ENCODE;case 231:return gt.BASE256_ENCODE;case 232:t.append(String.fromCharCode(29));break;case 233:case 234:case 241:break;case 235:r=!0;break;case 236:t.append("[)>\x1e05\x1d"),n.insert(0,"\x1e\x04");break;case 237:t.append("[)>\x1e06\x1d"),n.insert(0,"\x1e\x04");break;case 238:return gt.ANSIX12_ENCODE;case 239:return gt.TEXT_ENCODE;case 240:return gt.EDIFACT_ENCODE;default:if(254!==i||0!==e.available())throw new D}}while(e.available()>0);return gt.ASCII_ENCODE}},{key:"decodeC40Segment",value:function(e,t){var n=!1,r=[],i=0;do{if(8===e.available())return;var a=e.readBits(8);if(254===a)return;this.parseTwoBytes(a,e.readBits(8),r);for(var o=0;o<3;o++){var s=r[o];switch(i){case 0:if(s<3)i=s+1;else{if(!(s0)}},{key:"decodeTextSegment",value:function(e,t){var n=!1,r=[],i=0;do{if(8===e.available())return;var a=e.readBits(8);if(254===a)return;this.parseTwoBytes(a,e.readBits(8),r);for(var o=0;o<3;o++){var s=r[o];switch(i){case 0:if(s<3)i=s+1;else{if(!(s0)}},{key:"decodeAnsiX12Segment",value:function(e,t){var n=[];do{if(8===e.available())return;var r=e.readBits(8);if(254===r)return;this.parseTwoBytes(r,e.readBits(8),n);for(var i=0;i<3;i++){var a=n[i];switch(a){case 0:t.append("\r");break;case 1:t.append("*");break;case 2:t.append(">");break;case 3:t.append(" ");break;default:if(a<14)t.append(String.fromCharCode(a+44));else{if(!(a<40))throw new D;t.append(String.fromCharCode(a+51))}}}}while(e.available()>0)}},{key:"parseTwoBytes",value:function(e,t,n){var r=(e<<8)+t-1,i=Math.floor(r/1600);n[0]=i,r-=1600*i,i=Math.floor(r/40),n[1]=i,n[2]=r-40*i}},{key:"decodeEdifactSegment",value:function(e,t){do{if(e.available()<=16)return;for(var n=0;n<4;n++){var r=e.readBits(6);if(31===r){var i=8-e.getBitOffset();return void(8!==i&&e.readBits(i))}0===(32&r)&&(r|=64),t.append(String.fromCharCode(r))}}while(e.available()>0)}},{key:"decodeBase256Segment",value:function(e,t,n){var r,i=1+e.getByteOffset(),a=this.unrandomize255State(e.readBits(8),i++);if((r=0===a?e.available()/8|0:a<250?a:250*(a-249)+this.unrandomize255State(e.readBits(8),i++))<0)throw new D;for(var o=new Uint8Array(r),s=0;s=0?n:n+256}}]),e}();Et.C40_BASIC_SET_CHARS=["*","*","*"," ","0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"],Et.C40_SHIFT2_SET_CHARS=["!",'"',"#","$","%","&","'","(",")","*","+",",","-",".","/",":",";","<","=",">","?","@","[","\\","]","^","_"],Et.TEXT_BASIC_SET_CHARS=["*","*","*"," ","0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z"],Et.TEXT_SHIFT2_SET_CHARS=Et.C40_SHIFT2_SET_CHARS,Et.TEXT_SHIFT3_SET_CHARS=["`","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","{","|","}","~",String.fromCharCode(127)];var St=function(){function e(){u(this,e),this.rsDecoder=new oe(ne.DATA_MATRIX_FIELD_256)}return c(e,[{key:"decode",value:function(e){var t,n=new mt(e),r=n.getVersion(),i=n.readCodewords(),a=yt.getDataBlocks(i,r),o=0,s=l(a);try{for(s.s();!(t=s.n()).done;)o+=t.value.getNumDataCodewords()}catch(g){s.e(g)}finally{s.f()}for(var u=new Uint8Array(o),c=a.length,d=0;do&&(u=o,c[0]=t,c[1]=n,c[2]=r,c[3]=i),u>s&&(u=s,c[0]=n,c[1]=r,c[2]=i,c[3]=t),u>l&&(c[0]=r,c[1]=i,c[2]=t,c[3]=n),c}},{key:"detectSolid2",value:function(t){var n=t[0],r=t[1],i=t[2],a=t[3],o=this.transitionsBetween(n,a),s=e.shiftPoint(r,i,4*(o+1)),l=e.shiftPoint(i,r,4*(o+1));return this.transitionsBetween(s,n)this.transitionsBetween(l,d)+this.transitionsBetween(u,d)?c:d:c:this.isValid(d)?d:null}},{key:"shiftToModuleCenter",value:function(t){var n=t[0],r=t[1],i=t[2],a=t[3],o=this.transitionsBetween(n,a)+1,s=this.transitionsBetween(i,a)+1,l=e.shiftPoint(n,r,4*s),u=e.shiftPoint(i,r,4*o);1===(1&(o=this.transitionsBetween(l,a)+1))&&(o+=1),1===(1&(s=this.transitionsBetween(u,a)+1))&&(s+=1);var c,d,f=(n.getX()+r.getX()+i.getX()+a.getX())/4,h=(n.getY()+r.getY()+i.getY()+a.getY())/4;return n=e.moveAway(n,f,h),r=e.moveAway(r,f,h),i=e.moveAway(i,f,h),a=e.moveAway(a,f,h),l=e.shiftPoint(n,r,4*s),l=e.shiftPoint(l,a,4*o),c=e.shiftPoint(r,n,4*s),c=e.shiftPoint(c,i,4*o),u=e.shiftPoint(i,a,4*s),u=e.shiftPoint(u,r,4*o),d=e.shiftPoint(a,i,4*s),[l,c,u,d=e.shiftPoint(d,n,4*o)]}},{key:"isValid",value:function(e){return e.getX()>=0&&e.getX()0&&e.getY()Math.abs(i-n);if(o){var s=n;n=r,r=s,s=i,i=a,a=s}for(var l=Math.abs(i-n),u=Math.abs(a-r),c=-l/2,d=r0){if(g===a)break;g+=d,c-=l}}return h}}],[{key:"shiftPoint",value:function(e,t,n){var r=(t.getX()-e.getX())/(n+1),i=(t.getY()-e.getY())/(n+1);return new ce(e.getX()+r,e.getY()+i)}},{key:"moveAway",value:function(e,t,n){var r=e.getX(),i=e.getY();return r1&&void 0!==arguments[1]?arguments[1]:null;if(null!=i&&i.has(N.PURE_BARCODE)){var a=e.extractPureBits(t.getBlackMatrix());n=this.decoder.decode(a),r=e.NO_POINTS}else{var o=new Ct(t.getBlackMatrix()).detect();n=this.decoder.decode(o.getBits()),r=o.getPoints()}var s=n.getRawBytes(),l=new Q(n.getText(),s,8*s.length,r,K.DATA_MATRIX,C.currentTimeMillis()),u=n.getByteSegments();null!=u&&l.putMetadata(q.BYTE_SEGMENTS,u);var c=n.getECLevel();return null!=c&&l.putMetadata(q.ERROR_CORRECTION_LEVEL,c),l}},{key:"reset",value:function(){}}],[{key:"extractPureBits",value:function(e){var t=e.getTopLeftOnBit(),n=e.getBottomRightOnBit();if(null==t||null==n)throw new F;var r=this.moduleSize(t,e),i=t[1],a=n[1],o=t[0],s=(n[0]-o+1)/r,l=(a-i+1)/r;if(s<=0||l<=0)throw new F;var u=r/2;i+=u,o+=u;for(var c=new B(s,l),d=0;d0&&void 0!==arguments[0]?arguments[0]:500;return u(this,n),t.call(this,new At,e)}return c(n)}(X);!function(e){e[e.L=0]="L",e[e.M=1]="M",e[e.Q=2]="Q",e[e.H=3]="H"}(bt||(bt={}));var It=function(){function e(t,n,r){u(this,e),this.value=t,this.stringValue=n,this.bits=r,e.FOR_BITS.set(r,this),e.FOR_VALUE.set(t,this)}return c(e,[{key:"getValue",value:function(){return this.value}},{key:"getBits",value:function(){return this.bits}},{key:"toString",value:function(){return this.stringValue}},{key:"equals",value:function(t){if(!(t instanceof e))return!1;var n=t;return this.value===n.value}}],[{key:"fromString",value:function(t){switch(t){case"L":return e.L;case"M":return e.M;case"Q":return e.Q;case"H":return e.H;default:throw new m(t+"not available")}}},{key:"forBits",value:function(t){if(t<0||t>=e.FOR_BITS.size)throw new y;return e.FOR_BITS.get(t)}}]),e}();It.FOR_BITS=new Map,It.FOR_VALUE=new Map,It.L=new It(bt.L,"L",1),It.M=new It(bt.M,"M",0),It.Q=new It(bt.Q,"Q",3),It.H=new It(bt.H,"H",2);var _t=function(){function e(t){u(this,e),this.errorCorrectionLevel=It.forBits(t>>3&3),this.dataMask=7&t}return c(e,[{key:"getErrorCorrectionLevel",value:function(){return this.errorCorrectionLevel}},{key:"getDataMask",value:function(){return this.dataMask}},{key:"hashCode",value:function(){return this.errorCorrectionLevel.getBits()<<3|this.dataMask}},{key:"equals",value:function(t){if(!(t instanceof e))return!1;var n=t;return this.errorCorrectionLevel===n.errorCorrectionLevel&&this.dataMask===n.dataMask}}],[{key:"numBitsDiffering",value:function(e,t){return I.bitCount(e^t)}},{key:"decodeFormatInformation",value:function(t,n){var r=e.doDecodeFormatInformation(t,n);return null!==r?r:e.doDecodeFormatInformation(t^e.FORMAT_INFO_MASK_QR,n^e.FORMAT_INFO_MASK_QR)}},{key:"doDecodeFormatInformation",value:function(t,n){var r,i=Number.MAX_SAFE_INTEGER,a=0,o=l(e.FORMAT_INFO_DECODE_LOOKUP);try{for(o.s();!(r=o.n()).done;){var s=r.value,u=s[0];if(u===t||u===n)return new e(s[1]);var c=e.numBitsDiffering(t,u);c1?n-1:0),i=1;i2?r-2:0),a=2;a6&&(t.setRegion(e-11,0,3,6),t.setRegion(0,e-11,6,3)),t}},{key:"toString",value:function(){return""+this.versionNumber}}],[{key:"getProvisionalVersionForDimension",value:function(e){if(e%4!==1)throw new D;try{return this.getVersionForNumber((e-17)/4)}catch(t){throw new D}}},{key:"getVersionForNumber",value:function(t){if(t<1||t>40)throw new y;return e.VERSIONS[t-1]}},{key:"decodeVersionInformation",value:function(t){for(var n=Number.MAX_SAFE_INTEGER,r=0,i=0;i=0;n--)e=this.copyBit(8,n,e);for(var r=this.bitMatrix.getHeight(),i=0,a=r-7,o=r-1;o>=a;o--)i=this.copyBit(8,o,i);for(var s=r-8;s=0;i--)for(var a=e-9;a>=r;a--)n=this.copyBit(a,i,n);var o=Dt.decodeVersionInformation(n);if(null!==o&&o.getDimensionForVersion()===e)return this.parsedVersion=o,o;n=0;for(var s=5;s>=0;s--)for(var l=e-9;l>=r;l--)n=this.copyBit(s,l,n);if(null!==(o=Dt.decodeVersionInformation(n))&&o.getDimensionForVersion()===e)return this.parsedVersion=o,o;throw new D}},{key:"copyBit",value:function(e,t,n){return(this.isMirror?this.bitMatrix.get(t,e):this.bitMatrix.get(e,t))?n<<1|1:n<<1}},{key:"readCodewords",value:function(){var e=this.readFormatInformation(),t=this.readVersion(),n=Rt.values.get(e.getDataMask()),r=this.bitMatrix.getHeight();n.unmaskBitMatrix(this.bitMatrix,r);for(var i=t.buildFunctionPattern(),a=!0,o=new Uint8Array(t.getTotalCodewords()),s=0,l=0,u=0,c=r-1;c>0;c-=2){6===c&&c--;for(var d=0;d=0&&d[E].codewords.length!==w;)E--;E++;for(var S=w-a.getECCodewordsPerBlock(),C=0,A=0;Ae.available())throw new D;for(var r=new Uint8Array(2*n),i=0;n>0;){var a=e.readBits(13),o=a/96<<8&4294967295|a%96;o+=o<959?41377:42657,r[i]=o>>8&255,r[i+1]=255&o,i+=2,n--}try{t.append(x.decode(r,P.GB2312))}catch(s){throw new D(s)}}},{key:"decodeKanjiSegment",value:function(e,t,n){if(13*n>e.available())throw new D;for(var r=new Uint8Array(2*n),i=0;n>0;){var a=e.readBits(13),o=a/192<<8&4294967295|a%192;o+=o<7936?33088:49472,r[i]=o>>8,r[i+1]=o,i+=2,n--}try{t.append(x.decode(r,P.SHIFT_JIS))}catch(s){throw new D(s)}}},{key:"decodeByteSegment",value:function(e,t,n,r,i,a){if(8*n>e.available())throw new D;for(var o,s=new Uint8Array(n),l=0;l=e.ALPHANUMERIC_CHARS.length)throw new D;return e.ALPHANUMERIC_CHARS[t]}},{key:"decodeAlphanumericSegment",value:function(t,n,r,i){for(var a=n.length();r>1;){if(t.available()<11)throw new D;var o=t.readBits(11);n.append(e.toAlphaNumericChar(Math.floor(o/45))),n.append(e.toAlphaNumericChar(o%45)),r-=2}if(1===r){if(t.available()<6)throw new D;n.append(e.toAlphaNumericChar(t.readBits(6)))}if(i)for(var s=a;s=3;){if(t.available()<10)throw new D;var i=t.readBits(10);if(i>=1e3)throw new D;n.append(e.toAlphaNumericChar(Math.floor(i/100))),n.append(e.toAlphaNumericChar(Math.floor(i/10)%10)),n.append(e.toAlphaNumericChar(i%10)),r-=3}if(2===r){if(t.available()<7)throw new D;var a=t.readBits(7);if(a>=100)throw new D;n.append(e.toAlphaNumericChar(Math.floor(a/10))),n.append(e.toAlphaNumericChar(a%10))}else if(1===r){if(t.available()<4)throw new D;var o=t.readBits(4);if(o>=10)throw new D;n.append(e.toAlphaNumericChar(o))}}},{key:"parseECIValue",value:function(e){var t=e.readBits(8);if(0===(128&t))return 127&t;if(128===(192&t))return(63&t)<<8&4294967295|e.readBits(8);if(192===(224&t))return(31&t)<<16&4294967295|e.readBits(16);throw new D}}]),e}();Bt.ALPHANUMERIC_CHARS="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ $%*+-./:",Bt.GB2312_SUBSET=1;var Ft=function(){function e(t){u(this,e),this.mirrored=t}return c(e,[{key:"isMirrored",value:function(){return this.mirrored}},{key:"applyMirroredCorrection",value:function(e){if(this.mirrored&&null!==e&&!(e.length<3)){var t=e[0];e[0]=e[2],e[2]=t}}}]),e}(),Ut=function(){function e(){u(this,e),this.rsDecoder=new oe(ne.QR_CODE_FIELD_256)}return c(e,[{key:"decodeBooleanArray",value:function(e,t){return this.decodeBitMatrix(B.parseFromBooleanArray(e),t)}},{key:"decodeBitMatrix",value:function(e,t){var n=new xt(e),r=null;try{return this.decodeBitMatrixParser(n,t)}catch(a){r=a}try{n.remask(),n.setMirror(!0),n.readVersion(),n.readFormatInformation(),n.mirror();var i=this.decodeBitMatrixParser(n,t);return i.setOther(new Ft(!0)),i}catch(a){if(null!==r)throw r;throw a}}},{key:"decodeBitMatrixParser",value:function(e,t){var n,r=e.readVersion(),i=e.readFormatInformation().getErrorCorrectionLevel(),a=e.readCodewords(),o=Pt.getDataBlocks(a,r,i),s=0,u=l(o);try{for(u.s();!(n=u.n()).done;)s+=n.value.getNumDataCodewords()}catch(y){u.e(y)}finally{u.f()}var c,d=new Uint8Array(s),f=0,h=l(o);try{for(h.s();!(c=h.n()).done;){var v=c.value,p=v.getCodewords(),g=v.getNumDataCodewords();this.correctErrors(p,g);for(var m=0;m=n)return!1;return!0}},{key:"crossCheckVertical",value:function(t,n,r,i){var a=this.image,o=a.getHeight(),s=this.crossCheckStateCount;s[0]=0,s[1]=0,s[2]=0;for(var l=t;l>=0&&a.get(n,l)&&s[1]<=r;)s[1]++,l--;if(l<0||s[1]>r)return NaN;for(;l>=0&&!a.get(n,l)&&s[0]<=r;)s[0]++,l--;if(s[0]>r)return NaN;for(l=t+1;lr)return NaN;for(;lr)return NaN;var u=s[0]+s[1]+s[2];return 5*Math.abs(u-i)>=2*i?NaN:this.foundPatternCross(s)?e.centerFromEnd(s,l):NaN}},{key:"handlePossibleCenter",value:function(t,n,r){var i=t[0]+t[1]+t[2],a=e.centerFromEnd(t,r),o=this.crossCheckVertical(n,a,2*t[1],i);if(!isNaN(o)){var s,u=(t[0]+t[1]+t[2])/3,c=l(this.possibleCenters);try{for(c.s();!(s=c.n()).done;){var d=s.value;if(d.aboutEquals(u,o,a))return d.combineEstimate(o,a,u)}}catch(h){c.e(h)}finally{c.f()}var f=new zt(a,o,u);this.possibleCenters.push(f),null!==this.resultPointCallback&&void 0!==this.resultPointCallback&&this.resultPointCallback.foundPossibleResultPoint(f)}return null}}],[{key:"centerFromEnd",value:function(e,t){return t-e[2]-e[1]/2}}]),e}(),jt=function(e){d(n,e);var t=f(n);function n(e,r,i,a){var o;return u(this,n),(o=t.call(this,e,r)).estimatedModuleSize=i,o.count=a,void 0===a&&(o.count=1),o}return c(n,[{key:"getEstimatedModuleSize",value:function(){return this.estimatedModuleSize}},{key:"getCount",value:function(){return this.count}},{key:"aboutEquals",value:function(e,t,n){if(Math.abs(t-this.getY())<=e&&Math.abs(n-this.getX())<=e){var r=Math.abs(e-this.estimatedModuleSize);return r<=1||r<=this.estimatedModuleSize}return!1}},{key:"combineEstimate",value:function(e,t,r){var i=this.count+1;return new n((this.count*this.getX()+t)/i,(this.count*this.getY()+e)/i,(this.count*this.estimatedModuleSize+r)/i,i)}}]),n}(ce),Vt=function(){function e(t){u(this,e),this.bottomLeft=t[0],this.topLeft=t[1],this.topRight=t[2]}return c(e,[{key:"getBottomLeft",value:function(){return this.bottomLeft}},{key:"getTopLeft",value:function(){return this.topLeft}},{key:"getTopRight",value:function(){return this.topRight}}]),e}(),Gt=function(){function e(t,n){u(this,e),this.image=t,this.resultPointCallback=n,this.possibleCenters=[],this.crossCheckStateCount=new Int32Array(5),this.resultPointCallback=n}return c(e,[{key:"getImage",value:function(){return this.image}},{key:"getPossibleCenters",value:function(){return this.possibleCenters}},{key:"find",value:function(t){var n=null!==t&&void 0!==t&&void 0!==t.get(N.TRY_HARDER),r=null!==t&&void 0!==t&&void 0!==t.get(N.PURE_BARCODE),i=this.image,a=i.getHeight(),o=i.getWidth(),s=Math.floor(3*a/(4*e.MAX_MODULES));(su[2]&&(c+=h-u[2]-s,f=o-1)}d=0,u[0]=0,u[1]=0,u[2]=0,u[3]=0,u[4]=0}else u[0]=u[2],u[1]=u[3],u[2]=u[4],u[3]=1,u[4]=0,d=3;else u[++d]++;else u[d]++;e.foundPatternCross(u)&&!0===this.handlePossibleCenter(u,c,o,r)&&(s=u[0],this.hasSkipped&&(l=this.haveMultiplyConfirmedCenters()))}var v=this.selectBestPatterns();return ce.orderBestPatterns(v),new Vt(v)}},{key:"getCrossCheckStateCount",value:function(){var e=this.crossCheckStateCount;return e[0]=0,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e}},{key:"crossCheckDiagonal",value:function(t,n,r,i){for(var a=this.getCrossCheckStateCount(),o=0,s=this.image;t>=o&&n>=o&&s.get(n-o,t-o);)a[2]++,o++;if(t=o&&n>=o&&!s.get(n-o,t-o)&&a[1]<=r;)a[1]++,o++;if(tr)return!1;for(;t>=o&&n>=o&&s.get(n-o,t-o)&&a[0]<=r;)a[0]++,o++;if(a[0]>r)return!1;var l=s.getHeight(),u=s.getWidth();for(o=1;t+o=l||n+o>=u)return!1;for(;t+o=l||n+o>=u||a[3]>=r)return!1;for(;t+o=r)return!1;var c=a[0]+a[1]+a[2]+a[3]+a[4];return Math.abs(c-i)<2*i&&e.foundPatternCross(a)}},{key:"crossCheckVertical",value:function(t,n,r,i){for(var a=this.image,o=a.getHeight(),s=this.getCrossCheckStateCount(),l=t;l>=0&&a.get(n,l);)s[2]++,l--;if(l<0)return NaN;for(;l>=0&&!a.get(n,l)&&s[1]<=r;)s[1]++,l--;if(l<0||s[1]>r)return NaN;for(;l>=0&&a.get(n,l)&&s[0]<=r;)s[0]++,l--;if(s[0]>r)return NaN;for(l=t+1;l=r)return NaN;for(;l=r)return NaN;var u=s[0]+s[1]+s[2]+s[3]+s[4];return 5*Math.abs(u-i)>=2*i?NaN:e.foundPatternCross(s)?e.centerFromEnd(s,l):NaN}},{key:"crossCheckHorizontal",value:function(t,n,r,i){for(var a=this.image,o=a.getWidth(),s=this.getCrossCheckStateCount(),l=t;l>=0&&a.get(l,n);)s[2]++,l--;if(l<0)return NaN;for(;l>=0&&!a.get(l,n)&&s[1]<=r;)s[1]++,l--;if(l<0||s[1]>r)return NaN;for(;l>=0&&a.get(l,n)&&s[0]<=r;)s[0]++,l--;if(s[0]>r)return NaN;for(l=t+1;l=r)return NaN;for(;l=r)return NaN;var u=s[0]+s[1]+s[2]+s[3]+s[4];return 5*Math.abs(u-i)>=i?NaN:e.foundPatternCross(s)?e.centerFromEnd(s,l):NaN}},{key:"handlePossibleCenter",value:function(t,n,r,i){var a=t[0]+t[1]+t[2]+t[3]+t[4],o=e.centerFromEnd(t,r),s=this.crossCheckVertical(n,Math.floor(o),t[2],a);if(!isNaN(s)&&(o=this.crossCheckHorizontal(Math.floor(o),Math.floor(s),t[2],a),!isNaN(o)&&(!i||this.crossCheckDiagonal(Math.floor(s),Math.floor(o),t[2],a)))){for(var l=a/7,u=!1,c=this.possibleCenters,d=0,f=c.length;d=e.CENTER_QUORUM){if(null!=n)return this.hasSkipped=!0,Math.floor((Math.abs(n.getX()-i.getX())-Math.abs(n.getY()-i.getY()))/2);n=i}}}catch(a){r.e(a)}finally{r.f()}return 0}},{key:"haveMultiplyConfirmedCenters",value:function(){var t,n=0,r=0,i=this.possibleCenters.length,a=l(this.possibleCenters);try{for(a.s();!(t=a.n()).done;){var o=t.value;o.getCount()>=e.CENTER_QUORUM&&(n++,r+=o.getEstimatedModuleSize())}}catch(h){a.e(h)}finally{a.f()}if(n<3)return!1;var s,u=r/i,c=0,d=l(this.possibleCenters);try{for(d.s();!(s=d.n()).done;){var f=s.value;c+=Math.abs(f.getEstimatedModuleSize()-u)}}catch(h){d.e(h)}finally{d.f()}return c<=.05*r}},{key:"selectBestPatterns",value:function(){var e=this.possibleCenters.length;if(e<3)throw new F;var t,n=this.possibleCenters;if(e>3){var r,i=0,a=0,o=l(this.possibleCenters);try{for(o.s();!(r=o.n()).done;){var s=r.value.getEstimatedModuleSize();i+=s,a+=s*s}}catch(g){o.e(g)}finally{o.f()}t=i/e;var u=Math.sqrt(a/e-t*t);n.sort((function(e,n){var r=Math.abs(n.getEstimatedModuleSize()-t),i=Math.abs(e.getEstimatedModuleSize()-t);return ri?1:0}));for(var c=Math.max(.2*t,u),d=0;d3;d++){var f=n[d];Math.abs(f.getEstimatedModuleSize()-t)>c&&(n.splice(d,1),d--)}}if(n.length>3){var h,v=0,p=l(n);try{for(p.s();!(h=p.n()).done;)v+=h.value.getEstimatedModuleSize()}catch(g){p.e(g)}finally{p.f()}t=v/n.length,n.sort((function(e,n){if(n.getCount()===e.getCount()){var r=Math.abs(n.getEstimatedModuleSize()-t),i=Math.abs(e.getEstimatedModuleSize()-t);return ri?-1:0}return n.getCount()-e.getCount()})),n.splice(3)}return[n[0],n[1],n[2]]}}],[{key:"centerFromEnd",value:function(e,t){return t-e[4]-e[3]-e[2]/2}},{key:"foundPatternCross",value:function(e){for(var t=0,n=0;n<5;n++){var r=e[n];if(0===r)return!1;t+=r}if(t<7)return!1;var i=t/7,a=i/2;return Math.abs(i-e[0])0)for(var c=r.getX()-n.getX()+i.getX(),d=r.getY()-n.getY()+i.getY(),f=1-3/l,h=Math.floor(n.getX()+f*(c-n.getX())),v=Math.floor(n.getY()+f*(d-n.getY())),p=4;p<=16;p<<=1)try{u=this.findAlignmentInRegion(a,h,v,p);break}catch(y){if(!(y instanceof F))throw y}var g=e.createTransform(n,r,i,u,o),m=e.sampleGrid(this.image,g,o);return new de(m,null===u?[i,n,r]:[i,n,r,u])}},{key:"calculateModuleSize",value:function(e,t,n){return(this.calculateModuleSizeOneWay(e,t)+this.calculateModuleSizeOneWay(e,n))/2}},{key:"calculateModuleSizeOneWay",value:function(e,t){var n=this.sizeOfBlackWhiteBlackRunBothWays(Math.floor(e.getX()),Math.floor(e.getY()),Math.floor(t.getX()),Math.floor(t.getY())),r=this.sizeOfBlackWhiteBlackRunBothWays(Math.floor(t.getX()),Math.floor(t.getY()),Math.floor(e.getX()),Math.floor(e.getY()));return isNaN(n)?r/7:isNaN(r)?n/7:(n+r)/14}},{key:"sizeOfBlackWhiteBlackRunBothWays",value:function(e,t,n,r){var i=this.sizeOfBlackWhiteBlackRun(e,t,n,r),a=1,o=e-(n-e);o<0?(a=e/(e-o),o=0):o>=this.image.getWidth()&&(a=(this.image.getWidth()-1-e)/(o-e),o=this.image.getWidth()-1);var s=Math.floor(t-(r-t)*a);return a=1,s<0?(a=t/(t-s),s=0):s>=this.image.getHeight()&&(a=(this.image.getHeight()-1-t)/(s-t),s=this.image.getHeight()-1),o=Math.floor(e+(o-e)*a),(i+=this.sizeOfBlackWhiteBlackRun(e,t,o,s))-1}},{key:"sizeOfBlackWhiteBlackRun",value:function(e,t,n,r){var i=Math.abs(r-t)>Math.abs(n-e);if(i){var a=e;e=t,t=a,a=n,n=r,r=a}for(var o=Math.abs(n-e),s=Math.abs(r-t),l=-o/2,u=e0){if(v===r)break;v+=c,l-=o}}return 2===d?le.distance(n+u,r,e,t):NaN}},{key:"findAlignmentInRegion",value:function(e,t,n,r){var i=Math.floor(r*e),a=Math.max(0,t-i),o=Math.min(this.image.getWidth()-1,t+i);if(o-a<3*e)throw new F("Alignment top exceeds estimated module size.");var s=Math.max(0,n-i),l=Math.min(this.image.getHeight()-1,n+i);if(l-s<3*e)throw new F("Alignment bottom exceeds estimated module size.");return new Ht(this.image,a,s,o-a,l-s,e,this.resultPointCallback).find()}}],[{key:"createTransform",value:function(e,t,n,r,i){var a,o,s,l,u=i-3.5;return null!==r?(a=r.getX(),o=r.getY(),l=s=u-3):(a=t.getX()-e.getX()+n.getX(),o=t.getY()-e.getY()+n.getY(),s=u,l=u),pe.quadrilateralToQuadrilateral(3.5,3.5,u,3.5,s,l,3.5,u,e.getX(),e.getY(),t.getX(),t.getY(),a,o,n.getX(),n.getY())}},{key:"sampleGrid",value:function(e,t,n){return me.getInstance().sampleGridWithTransform(e,n,n,t)}},{key:"computeDimension",value:function(e,t,n,r){var i=le.round(ce.distance(e,t)/r),a=le.round(ce.distance(e,n)/r),o=Math.floor((i+a)/2)+7;switch(3&o){case 0:o++;break;case 2:o--;break;case 3:throw new F("Dimensions could be not found.")}return o}}]),e}(),Yt=function(){function e(){u(this,e),this.decoder=new Ut}return c(e,[{key:"getDecoder",value:function(){return this.decoder}},{key:"decode",value:function(t,n){var r,i;if(void 0!==n&&null!==n&&void 0!==n.get(N.PURE_BARCODE)){var a=e.extractPureBits(t.getBlackMatrix());r=this.decoder.decodeBitMatrix(a,n),i=e.NO_POINTS}else{var o=new Wt(t.getBlackMatrix()).detect(n);r=this.decoder.decodeBitMatrix(o.getBits(),n),i=o.getPoints()}r.getOther()instanceof Ft&&r.getOther().applyMirroredCorrection(i);var s=new Q(r.getText(),r.getRawBytes(),void 0,i,K.QR_CODE,void 0),l=r.getByteSegments();null!==l&&s.putMetadata(q.BYTE_SEGMENTS,l);var u=r.getECLevel();return null!==u&&s.putMetadata(q.ERROR_CORRECTION_LEVEL,u),r.hasStructuredAppend()&&(s.putMetadata(q.STRUCTURED_APPEND_SEQUENCE,r.getStructuredAppendSequenceNumber()),s.putMetadata(q.STRUCTURED_APPEND_PARITY,r.getStructuredAppendParity())),s}},{key:"reset",value:function(){}}],[{key:"extractPureBits",value:function(e){var t=e.getTopLeftOnBit(),n=e.getBottomRightOnBit();if(null===t||null===n)throw new F;var r=this.moduleSize(t,e),i=t[1],a=n[1],o=t[0],s=n[0];if(o>=s||i>=a)throw new F;if(a-i!==s-o&&(s=o+(a-i))>=e.getWidth())throw new F;var l=Math.round((s-o+1)/r),u=Math.round((a-i+1)/r);if(l<=0||u<=0)throw new F;if(u!==l)throw new F;var c=Math.floor(r/2);i+=c;var d=(o+=c)+Math.floor((l-1)*r)-s;if(d>0){if(d>c)throw new F;o-=d}var f=i+Math.floor((u-1)*r)-a;if(f>0){if(f>c)throw new F;i-=f}for(var h=new B(l,u),v=0;v0;){var d=e.findGuardPattern(t,a,--i,r,!1,o,u);if(null==d){i++;break}c=d}s[0]=new ce(c[0],i),s[1]=new ce(c[1],i),l=!0;break}}var f=i+1;if(l){for(var h=0,v=Int32Array.from([Math.trunc(s[0].getX()),Math.trunc(s[1].getX())]);fe.SKIPPED_ROW_COUNT_MAX)break;h++}}f-=h+1,s[2]=new ce(v[0],f),s[3]=new ce(v[1],f)}return f-i0&&u++d?c-d:d-c;if(f>n)return 1/0;l+=f}return l/i}}]),e}();Zt.INDEXES_START_PATTERN=Int32Array.from([0,4,1,5]),Zt.INDEXES_STOP_PATTERN=Int32Array.from([6,2,7,3]),Zt.MAX_AVG_VARIANCE=.42,Zt.MAX_INDIVIDUAL_VARIANCE=.8,Zt.START_PATTERN=Int32Array.from([8,1,1,1,1,1,1,3]),Zt.STOP_PATTERN=Int32Array.from([7,1,1,3,1,1,1,2,1]),Zt.MAX_PIXEL_DRIFT=3,Zt.MAX_PATTERN_DRIFT=5,Zt.SKIPPED_ROW_COUNT_MAX=25,Zt.ROW_STEP=5,Zt.BARCODE_MIN_HEIGHT=10;var Kt=function(){function e(t,n){if(u(this,e),0===n.length)throw new y;this.field=t;var r=n.length;if(r>1&&0===n[0]){for(var i=1;ir.length){var i=n;n=r,r=i}var a=new Int32Array(r.length),o=r.length-n.length;C.arraycopy(r,0,a,0,o);for(var s=o;s=0;t--){var n=this.getCoefficient(t);0!==n&&(n<0?(e.append(" - "),n=-n):e.length()>0&&e.append(" + "),0!==t&&1===n||e.append(n),0!==t&&(1===t?e.append("x"):(e.append("x^"),e.append(t))))}return e.toString()}}]),e}(),qt=function(e){d(n,e);var t=f(n);function n(e,r){var a;u(this,n),(a=t.call(this)).modulus=e,a.expTable=new Int32Array(e),a.logTable=new Int32Array(e);for(var o=1,s=0;s0;o--){var s=r.evaluateAt(this.field.exp(o));i[t-o]=s,0!==s&&(a=!0)}if(!a)return 0;var u=this.field.getOne();if(null!=n){var c,d=l(n);try{for(d.s();!(c=d.n()).done;){var f=c.value,h=this.field.exp(e.length-1-f),v=new Kt(this.field,new Int32Array([this.field.subtract(0,h),1]));u=u.multiply(v)}}catch(b){d.e(b)}finally{d.f()}}for(var p=new Kt(this.field,i),g=this.runEuclideanAlgorithm(this.field.buildMonomial(t,1),p,t),m=g[0],y=g[1],w=this.findErrorLocations(m),S=this.findErrorMagnitudes(y,m,w),C=0;C=Math.round(n/2);){var l=i,u=o;if(o=s,(i=a).isZero())throw E.getChecksumInstance();a=l;for(var c=this.field.getZero(),d=i.getCoefficient(i.getDegree()),f=this.field.inverse(d);a.getDegree()>=i.getDegree()&&!a.isZero();){var h=a.getDegree()-i.getDegree(),v=this.field.multiply(a.getCoefficient(a.getDegree()),f);c=c.add(this.field.buildMonomial(h,v)),a=a.subtract(i.multiplyByMonomial(h,v))}s=c.multiply(o).subtract(u).negative()}var p=s.getCoefficient(0);if(0===p)throw E.getChecksumInstance();var g=this.field.inverse(p);return[s.multiply(g),a.multiply(g)]}},{key:"findErrorLocations",value:function(e){for(var t=e.getDegree(),n=new Int32Array(t),r=0,i=1;i0){var l=r?this.topLeft:this.topRight,u=Math.trunc(l.getY()-t);u<0&&(u=0);var c=new ce(l.getX(),u);r?i=c:o=c}if(n>0){var d=r?this.bottomLeft:this.bottomRight,f=Math.trunc(d.getY()+n);f>=this.image.getHeight()&&(f=this.image.getHeight()-1);var h=new ce(d.getX(),f);r?a=h:s=h}return new e(this.image,i,a,o,s)}},{key:"getMinX",value:function(){return this.minX}},{key:"getMaxX",value:function(){return this.maxX}},{key:"getMinY",value:function(){return this.minY}},{key:"getMaxY",value:function(){return this.maxY}},{key:"getTopLeft",value:function(){return this.topLeft}},{key:"getTopRight",value:function(){return this.topRight}},{key:"getBottomLeft",value:function(){return this.bottomLeft}},{key:"getBottomRight",value:function(){return this.bottomRight}}],[{key:"merge",value:function(t,n){return null==t?n:null==n?t:new e(t.image,t.topLeft,t.bottomLeft,n.topRight,n.bottomRight)}}]),e}(),en=function(){function e(t,n,r,i){u(this,e),this.columnCount=t,this.errorCorrectionLevel=i,this.rowCountUpperPart=n,this.rowCountLowerPart=r,this.rowCount=n+r}return c(e,[{key:"getColumnCount",value:function(){return this.columnCount}},{key:"getErrorCorrectionLevel",value:function(){return this.errorCorrectionLevel}},{key:"getRowCount",value:function(){return this.rowCount}},{key:"getRowCountUpperPart",value:function(){return this.rowCountUpperPart}},{key:"getRowCountLowerPart",value:function(){return this.rowCountLowerPart}}]),e}(),tn=function(){function e(){u(this,e),this.buffer=""}return c(e,[{key:"format",value:function(t){for(var n=arguments.length,r=new Array(n>1?n-1:0),i=1;i=0&&null!=(n=this.codewords[i]))return n;if((i=this.imageRowToCodewordIndex(t)+r)t?(t=s.getValue(),(n=[]).push(s.getKey())):s.getValue()===t&&n.push(s.getKey())};for(i.s();!(e=i.n()).done;)a()}catch(o){i.e(o)}finally{i.f()}return Xt.toIntArray(n)}},{key:"getConfidence",value:function(e){return this.values.get(e)}}]),e}(),an=function(e){d(n,e);var t=f(n);function n(e,r){var i;return u(this,n),(i=t.call(this,e))._isLeft=r,i}return c(n,[{key:"setRowNumbers",value:function(){var e,t=l(this.getCodewords());try{for(t.s();!(e=t.n()).done;){var n=e.value;null!=n&&n.setRowNumberAsRowIndicatorColumn()}}catch(r){t.e(r)}finally{t.f()}}},{key:"adjustCompleteIndicatorColumnRowNumbers",value:function(e){var t=this.getCodewords();this.setRowNumbers(),this.removeIncorrectCodewords(t,e);for(var n=this.getBoundingBox(),r=this._isLeft?n.getTopLeft():n.getTopRight(),i=this._isLeft?n.getBottomLeft():n.getBottomRight(),a=this.imageRowToCodewordIndex(Math.trunc(r.getY())),o=this.imageRowToCodewordIndex(Math.trunc(i.getY())),s=-1,l=1,u=0,c=a;c=e.getRowCount()||f>c)t[c]=null;else{for(var h=void 0,v=(h=l>2?(l-2)*f:f)>=c,p=1;p<=h&&!v;p++)v=null!=t[c-p];v?t[c]=null:(s=d.getRowNumber(),u=1)}}}},{key:"getRowHeights",value:function(){var e=this.getBarcodeMetadata();if(null==e)return null;this.adjustIncompleteIndicatorColumnRowNumbers(e);var t,n=new Int32Array(e.getRowCount()),r=l(this.getCodewords());try{for(r.s();!(t=r.n()).done;){var i=t.value;if(null!=i){var a=i.getRowNumber();if(a>=n.length)continue;n[a]++}}}catch(o){r.e(o)}finally{r.f()}return n}},{key:"adjustIncompleteIndicatorColumnRowNumbers",value:function(e){for(var t=this.getBoundingBox(),n=this._isLeft?t.getTopLeft():t.getTopRight(),r=this._isLeft?t.getBottomLeft():t.getBottomRight(),i=this.imageRowToCodewordIndex(Math.trunc(n.getY())),a=this.imageRowToCodewordIndex(Math.trunc(r.getY())),o=this.getCodewords(),s=-1,l=i;l=e.getRowCount()?o[l]=null:s=u.getRowNumber())}}},{key:"getBarcodeMetadata",value:function(){var e,t=this.getCodewords(),n=new rn,r=new rn,i=new rn,a=new rn,o=l(t);try{for(o.s();!(e=o.n()).done;){var s=e.value;if(null!=s){s.setRowNumberAsRowIndicatorColumn();var u=s.getValue()%30,c=s.getRowNumber();switch(this._isLeft||(c+=2),c%3){case 0:r.setValue(3*u+1);break;case 1:a.setValue(u/3),i.setValue(u%3);break;case 2:n.setValue(u+1)}}}}catch(f){o.e(f)}finally{o.f()}if(0===n.getValue().length||0===r.getValue().length||0===i.getValue().length||0===a.getValue().length||n.getValue()[0]<1||r.getValue()[0]+i.getValue()[0]Xt.MAX_ROWS_IN_BARCODE)return null;var d=new en(n.getValue()[0],r.getValue()[0],i.getValue()[0],a.getValue()[0]);return this.removeIncorrectCodewords(t,d),d}},{key:"removeIncorrectCodewords",value:function(e,t){for(var n=0;nt.getRowCount())e[n]=null;else switch(this._isLeft||(a+=2),a%3){case 0:3*i+1!==t.getRowCountUpperPart()&&(e[n]=null);break;case 1:Math.trunc(i/3)===t.getErrorCorrectionLevel()&&i%3===t.getRowCountLowerPart()||(e[n]=null);break;case 2:i+1!==t.getColumnCount()&&(e[n]=null)}}}}},{key:"isLeft",value:function(){return this._isLeft}},{key:"toString",value:function(){return"IsLeft: "+this._isLeft+"\n"+o(s(n.prototype),"toString",this).call(this)}}]),n}(nn),on=function(){function e(t,n){u(this,e),this.ADJUST_ROW_NUMBER_SKIP=2,this.barcodeMetadata=t,this.barcodeColumnCount=t.getColumnCount(),this.boundingBox=n,this.detectionResultColumns=new Array(this.barcodeColumnCount+2)}return c(e,[{key:"getDetectionResultColumns",value:function(){this.adjustIndicatorColumnRowNumbers(this.detectionResultColumns[0]),this.adjustIndicatorColumnRowNumbers(this.detectionResultColumns[this.barcodeColumnCount+1]);var e,t=Xt.MAX_CODEWORDS_IN_BARCODE;do{e=t,t=this.adjustRowNumbersAndGetCount()}while(t>0&&t0&&a0&&(s[0]=r[n-1],s[4]=a[n-1],s[5]=o[n-1]),n>1&&(s[8]=r[n-2],s[10]=a[n-2],s[11]=o[n-2]),n>=1;r=1&n,e.RATIOS_TABLE[t]||(e.RATIOS_TABLE[t]=new Array(Xt.BARS_IN_MODULE)),e.RATIOS_TABLE[t][Xt.BARS_IN_MODULE-i-1]=Math.fround(a/Xt.MODULES_IN_CODEWORD)}this.bSymbolTableReady=!0}},{key:"getDecodedValue",value:function(t){var n=e.getDecodedCodewordValue(e.sampleBitCounts(t));return-1!==n?n:e.getClosestDecodedValue(t)}},{key:"sampleBitCounts",value:function(e){for(var t=le.sum(e),n=new Int32Array(Xt.BARS_IN_MODULE),r=0,i=0,a=0;a1)for(var i=0;i=a)break}l1&&void 0!==arguments[1]?arguments[1]:void 0)}}]),e}(),dn=function(e){d(n,e);var t=f(n);function n(){return u(this,n),t.apply(this,arguments)}return c(n)}(g);dn.kind="NullPointerException";var fn,hn,vn=function(){function e(){u(this,e)}return c(e,[{key:"writeBytes",value:function(e){this.writeBytesOffset(e,0,e.length)}},{key:"writeBytesOffset",value:function(e,t,n){if(null==e)throw new dn;if(t<0||t>e.length||n<0||t+n>e.length||t+n<0)throw new A;if(0!==n)for(var r=0;r0&&void 0!==arguments[0]?arguments[0]:32;if(u(this,n),(e=t.call(this)).count=0,r<0)throw new y("Negative initial size: "+r);return e.buf=new Uint8Array(r),e}return c(n,[{key:"ensureCapacity",value:function(e){e-this.buf.length>0&&this.grow(e)}},{key:"grow",value:function(e){var t=this.buf.length<<1;if(t-e<0&&(t=e),t<0){if(e<0)throw new pn;t=I.MAX_VALUE}this.buf=k.copyOfUint8Array(this.buf,t)}},{key:"write",value:function(e){this.ensureCapacity(this.count+1),this.buf[this.count]=e,this.count+=1}},{key:"writeBytesOffset",value:function(e,t,n){if(t<0||t>e.length||n<0||t+n-e.length>0)throw new A;this.ensureCapacity(this.count+n),C.arraycopy(e,t,this.buf,this.count,n),this.count+=n}},{key:"writeTo",value:function(e){e.writeBytesOffset(this.buf,0,this.count)}},{key:"reset",value:function(){this.count=0}},{key:"toByteArray",value:function(){return k.copyOfUint8Array(this.buf,this.count)}},{key:"size",value:function(){return this.count}},{key:"toString",value:function(e){return e?"string"===typeof e?this.toString_string(e):this.toString_number(e):this.toString_void()}},{key:"toString_void",value:function(){return new String(this.buf).toString()}},{key:"toString_string",value:function(e){return new String(this.buf).toString()}},{key:"toString_number",value:function(e){return new String(this.buf).toString()}},{key:"close",value:function(){}}]),n}(vn);function mn(){if("undefined"!==typeof window)return window.BigInt||null;if("undefined"!==typeof n.g)return n.g.BigInt||null;if("undefined"!==typeof self)return self.BigInt||null;throw new Error("Can't search globals for BigInt!")}function yn(e){if("undefined"===typeof hn&&(hn=mn()),null===hn)throw new Error("BigInt is not supported!");return hn(e)}function wn(){var e=[];e[0]=yn(1);var t=yn(900);e[1]=t;for(var n=2;n<16;n++)e[n]=e[n-1]*t;return e}!function(e){e[e.ALPHA=0]="ALPHA",e[e.LOWER=1]="LOWER",e[e.MIXED=2]="MIXED",e[e.PUNCT=3]="PUNCT",e[e.ALPHA_SHIFT=4]="ALPHA_SHIFT",e[e.PUNCT_SHIFT=5]="PUNCT_SHIFT"}(fn||(fn={}));var En=function(){function e(){u(this,e)}return c(e,null,[{key:"decode",value:function(t,n){var r=new L(""),i=R.ISO8859_1;r.enableDecoding(i);for(var a=1,o=t[a++],s=new un;at[0])throw D.getFormatInstance();for(var i=new Int32Array(e.NUMBER_OF_SEQUENCE_CODEWORDS),a=0;a0){for(var f=0;f<6;++f)o.write(Number(yn(l)>>yn(8*(5-f))));l=0,s=0}}i===n[0]&&d0){for(var p=0;p<6;++p)o.write(Number(yn(l)>>yn(8*(5-p))));l=0,s=0}}}return a.append(x.decode(o.toByteArray(),r)),i}},{key:"numericCompaction",value:function(t,n,r){for(var i=0,a=!1,o=new Int32Array(e.MAX_NUMERIC_CODEWORDS);n0&&(r.append(e.decodeBase900toBase10(o,i)),i=0)}return n}},{key:"decodeBase900toBase10",value:function(t,n){for(var r=yn(0),i=0;i@[\\]_`~!\r\t,:\n-.$/\"|*()?{}'",En.MIXED_CHARS="0123456789&\r\t,:#-.$/+%*=^",En.EXP900=mn()?wn():[],En.NUMBER_OF_SEQUENCE_CODEWORDS=2;var Sn=function(){function e(){u(this,e)}return c(e,null,[{key:"decode",value:function(t,n,r,i,a,o,s){for(var l,u=new Jt(t,n,r,i,a),c=null,d=null,f=!0;;f=!1){if(null!=n&&(c=e.getRowIndicatorColumn(t,u,n,!0,o,s)),null!=i&&(d=e.getRowIndicatorColumn(t,u,i,!1,o,s)),null==(l=e.merge(c,d)))throw F.getNotFoundInstance();var h=l.getBoundingBox();if(!f||null==h||!(h.getMinY()u.getMaxY()))break;u=h}l.setBoundingBox(u);var v=l.getBarcodeColumnCount()+1;l.setDetectionResultColumn(0,c),l.setDetectionResultColumn(v,d);for(var p=null!=c,g=1;g<=v;g++){var m=p?g:v-g;if(void 0===l.getDetectionResultColumn(m)){var y=void 0;y=0===m||m===v?new an(u,0===m):new nn(u),l.setDetectionResultColumn(m,y);for(var w=-1,E=w,S=u.getMinY();S<=u.getMaxY();S++){if((w=e.getStartColumn(l,m,S,p))<0||w>u.getMaxX()){if(-1===E)continue;w=E}var C=e.detectCodeword(t,u.getMinX(),u.getMaxX(),p,w,S,o,s);null!=C&&(y.setCodeword(S,C),E=w,o=Math.min(o,C.getWidth()),s=Math.max(s,C.getWidth()))}}}return e.createDecoderResult(l)}},{key:"merge",value:function(t,n){if(null==t&&null==n)return null;var r=e.getBarcodeMetadata(t,n);if(null==r)return null;var i=Jt.merge(e.adjustBoundingBox(t),e.adjustBoundingBox(n));return new on(r,i)}},{key:"adjustBoundingBox",value:function(t){if(null==t)return null;var n=t.getRowHeights();if(null==n)return null;var r,i=e.getMax(n),a=0,o=l(n);try{for(o.s();!(r=o.n()).done;){var s=r.value;if(a+=i-s,s>0)break}}catch(v){o.e(v)}finally{o.f()}for(var u=t.getCodewords(),c=0;a>0&&null==u[c];c++)a--;for(var d=0,f=n.length-1;f>=0&&(d+=i-n[f],!(n[f]>0));f--);for(var h=u.length-1;d>0&&null==u[h];h--)d--;return t.getBoundingBox().addMissingRows(a,d,t.isLeft())}},{key:"getMax",value:function(e){var t,n=-1,r=l(e);try{for(r.s();!(t=r.n()).done;){var i=t.value;n=Math.max(n,i)}}catch(a){r.e(a)}finally{r.f()}return n}},{key:"getBarcodeMetadata",value:function(e,t){var n,r;return null==e||null==(n=e.getBarcodeMetadata())?null==t?null:t.getBarcodeMetadata():null==t||null==(r=t.getBarcodeMetadata())?n:n.getColumnCount()!==r.getColumnCount()&&n.getErrorCorrectionLevel()!==r.getErrorCorrectionLevel()&&n.getRowCount()!==r.getRowCount()?null:n}},{key:"getRowIndicatorColumn",value:function(t,n,r,i,a,o){for(var s=new an(n,i),l=0;l<2;l++)for(var u=0===l?1:-1,c=Math.trunc(Math.trunc(r.getX())),d=Math.trunc(Math.trunc(r.getY()));d<=n.getMaxY()&&d>=n.getMinY();d+=u){var f=e.detectCodeword(t,0,t.getWidth(),i,c,d,a,o);null!=f&&(s.setCodeword(d,f),c=i?f.getStartX():f.getEndX())}return s}},{key:"adjustCodewordCount",value:function(t,n){var r=n[0][1],i=r.getValue(),a=t.getBarcodeColumnCount()*t.getBarcodeRowCount()-e.getNumberOfECCodeWords(t.getBarcodeECLevel());if(0===i.length){if(a<1||a>Xt.MAX_CODEWORDS_IN_BARCODE)throw F.getNotFoundInstance();r.setValue(a)}else i[0]!==a&&r.setValue(a)}},{key:"createDecoderResult",value:function(t){var n=e.createBarcodeMatrix(t);e.adjustCodewordCount(t,n);for(var r=new Array,i=new Int32Array(t.getBarcodeRowCount()*t.getBarcodeColumnCount()),a=[],o=new Array,s=0;s0;){for(var l=0;l=0){if(f>=t.length)continue;t[f][a].setValue(d.getValue())}}}}catch(h){c.e(h)}finally{c.f()}}a++}}catch(h){o.e(h)}finally{o.f()}return t}},{key:"isValidBarcodeColumn",value:function(e,t){return t>=0&&t<=e.getBarcodeColumnCount()+1}},{key:"getStartColumn",value:function(t,n,r,i){var a=i?1:-1,o=null;if(e.isValidBarcodeColumn(t,n-a)&&(o=t.getDetectionResultColumn(n-a).getCodeword(r)),null!=o)return i?o.getEndX():o.getStartX();if(null!=(o=t.getDetectionResultColumn(n).getCodewordNearby(r)))return i?o.getStartX():o.getEndX();if(e.isValidBarcodeColumn(t,n-a)&&(o=t.getDetectionResultColumn(n-a).getCodewordNearby(r)),null!=o)return i?o.getEndX():o.getStartX();for(var s=0;e.isValidBarcodeColumn(t,n-a);){n-=a;var u,c=l(t.getDetectionResultColumn(n).getCodewords());try{for(c.s();!(u=c.n()).done;){var d=u.value;if(null!=d)return(i?d.getEndX():d.getStartX())+a*s*(d.getEndX()-d.getStartX())}}catch(f){c.e(f)}finally{c.f()}s++}return i?t.getBoundingBox().getMinX():t.getBoundingBox().getMaxX()}},{key:"detectCodeword",value:function(t,n,r,i,a,o,s,l){a=e.adjustCodewordStartColumn(t,n,r,i,a,o);var u,c=e.getModuleBitCount(t,n,r,i,a,o);if(null==c)return null;var d=le.sum(c);if(i)u=a+d;else{for(var f=0;f=t)&&l=n:se.CODEWORD_SKEW_SIZE)return a;s+=l}l=-l,i=!i}return s}},{key:"checkCodewordSkew",value:function(t,n,r){return n-e.CODEWORD_SKEW_SIZE<=t&&t<=r+e.CODEWORD_SKEW_SIZE}},{key:"decodeCodewords",value:function(t,n,r){if(0===t.length)throw D.getFormatInstance();var i=1<r/2+e.MAX_ERRORS||r<0||r>e.MAX_EC_CODEWORDS)throw E.getChecksumInstance();return e.errorCorrection.decode(t,r,n)}},{key:"verifyCodewordCount",value:function(e,t){if(e.length<4)throw D.getFormatInstance();var n=e[0];if(n>e.length)throw D.getFormatInstance();if(0===n){if(!(t>=1;return t}},{key:"getCodewordBucketNumber",value:function(e){return e instanceof Int32Array?this.getCodewordBucketNumber_Int32Array(e):this.getCodewordBucketNumber_number(e)}},{key:"getCodewordBucketNumber_number",value:function(t){return e.getCodewordBucketNumber(e.getBitCountForCodeword(t))}},{key:"getCodewordBucketNumber_Int32Array",value:function(e){return(e[0]-e[2]+e[4]-e[6]+9)%9}},{key:"toString",value:function(e){for(var t=new tn,n=0;n1&&void 0!==arguments[1]?arguments[1]:null,r=e.decode(t,n,!1);if(null==r||0===r.length||null==r[0])throw F.getNotFoundInstance();return r[0]}},{key:"decodeMultiple",value:function(t){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;try{return e.decode(t,n,!0)}catch(r){if(r instanceof D||r instanceof E)throw F.getNotFoundInstance();throw r}}},{key:"reset",value:function(){}}],[{key:"decode",value:function(t,n,r){var i,a=new Array,o=Zt.detectMultiple(t,n,r),s=l(o.getPoints());try{for(s.s();!(i=s.n()).done;){var u=i.value,c=Sn.decode(o.getBits(),u[4],u[5],u[6],u[7],e.getMinCodewordWidth(u),e.getMaxCodewordWidth(u)),d=new Q(c.getText(),c.getRawBytes(),void 0,u,K.PDF_417);d.putMetadata(q.ERROR_CORRECTION_LEVEL,c.getECLevel());var f=c.getOther();null!=f&&d.putMetadata(q.PDF417_EXTRA_METADATA,f),a.push(d)}}catch(h){s.e(h)}finally{s.f()}return a.map((function(e){return e}))}},{key:"getMaxWidth",value:function(e,t){return null==e||null==t?0:Math.trunc(Math.abs(e.getX()-t.getX()))}},{key:"getMinWidth",value:function(e,t){return null==e||null==t?I.MAX_VALUE:Math.trunc(Math.abs(e.getX()-t.getX()))}},{key:"getMaxCodewordWidth",value:function(t){return Math.floor(Math.max(Math.max(e.getMaxWidth(t[0],t[4]),e.getMaxWidth(t[6],t[2])*Xt.MODULES_IN_CODEWORD/Xt.MODULES_IN_STOP_PATTERN),Math.max(e.getMaxWidth(t[1],t[5]),e.getMaxWidth(t[7],t[3])*Xt.MODULES_IN_CODEWORD/Xt.MODULES_IN_STOP_PATTERN)))}},{key:"getMinCodewordWidth",value:function(t){return Math.floor(Math.min(Math.min(e.getMinWidth(t[0],t[4]),e.getMinWidth(t[6],t[2])*Xt.MODULES_IN_CODEWORD/Xt.MODULES_IN_STOP_PATTERN),Math.min(e.getMinWidth(t[1],t[5]),e.getMinWidth(t[7],t[3])*Xt.MODULES_IN_CODEWORD/Xt.MODULES_IN_STOP_PATTERN)))}}]),e}(),An=function(e){d(n,e);var t=f(n);function n(){return u(this,n),t.apply(this,arguments)}return c(n)}(g);An.kind="ReaderException";var bn,kn=function(){function e(t,n){u(this,e),this.verbose=!0===t,n&&this.setHints(n)}return c(e,[{key:"decode",value:function(e,t){return t&&this.setHints(t),this.decodeInternal(e)}},{key:"decodeWithState",value:function(e){return null!==this.readers&&void 0!==this.readers||this.setHints(null),this.decodeInternal(e)}},{key:"setHints",value:function(e){this.hints=e;var t=null!==e&&void 0!==e&&void 0!==e.get(N.TRY_HARDER),n=null===e||void 0===e?null:e.get(N.POSSIBLE_FORMATS),r=new Array;if(null!==n&&void 0!==n){var i=n.some((function(e){return e===K.UPC_A||e===K.UPC_E||e===K.EAN_13||e===K.EAN_8||e===K.CODABAR||e===K.CODE_39||e===K.CODE_93||e===K.CODE_128||e===K.ITF||e===K.RSS_14||e===K.RSS_EXPANDED}));i&&!t&&r.push(new dt(e,this.verbose)),n.includes(K.QR_CODE)&&r.push(new Yt),n.includes(K.DATA_MATRIX)&&r.push(new At),n.includes(K.AZTEC)&&r.push(new Ee),n.includes(K.PDF_417)&&r.push(new Cn),i&&t&&r.push(new dt(e,this.verbose))}0===r.length&&(t||r.push(new dt(e,this.verbose)),r.push(new Yt),r.push(new At),r.push(new Ee),r.push(new Cn),t&&r.push(new dt(e,this.verbose))),this.readers=r}},{key:"reset",value:function(){if(null!==this.readers){var e,t=l(this.readers);try{for(t.s();!(e=t.n()).done;)e.value.reset()}catch(n){t.e(n)}finally{t.f()}}}},{key:"decodeInternal",value:function(e){if(null===this.readers)throw new An("No readers where selected, nothing can be read.");var t,n=l(this.readers);try{for(n.s();!(t=n.n()).done;){var r=t.value;try{return r.decode(e,this.hints)}catch(i){if(i instanceof An)continue}}}catch(a){n.e(a)}finally{n.f()}throw new F("No MultiFormat Readers were able to detect the code.")}}]),e}(),In=function(e){d(n,e);var t=f(n);function n(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:500;u(this,n);var i=new kn;return i.setHints(e),t.call(this,i,r)}return c(n,[{key:"decodeBitmap",value:function(e){return this.reader.decodeWithState(e)}}]),n}(X),_n=function(e){d(n,e);var t=f(n);function n(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:500;return u(this,n),t.call(this,new Cn,e)}return c(n)}(X),Tn=function(e){d(n,e);var t=f(n);function n(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:500;return u(this,n),t.call(this,new Yt,e)}return c(n)}(X);!function(e){e[e.ERROR_CORRECTION=0]="ERROR_CORRECTION",e[e.CHARACTER_SET=1]="CHARACTER_SET",e[e.DATA_MATRIX_SHAPE=2]="DATA_MATRIX_SHAPE",e[e.MIN_SIZE=3]="MIN_SIZE",e[e.MAX_SIZE=4]="MAX_SIZE",e[e.MARGIN=5]="MARGIN",e[e.PDF417_COMPACT=6]="PDF417_COMPACT",e[e.PDF417_COMPACTION=7]="PDF417_COMPACTION",e[e.PDF417_DIMENSIONS=8]="PDF417_DIMENSIONS",e[e.AZTEC_LAYERS=9]="AZTEC_LAYERS",e[e.QR_VERSION=10]="QR_VERSION"}(bn||(bn={}));var Mn=bn,Nn=function(){function e(t){u(this,e),this.field=t,this.cachedGenerators=[],this.cachedGenerators.push(new ee(t,Int32Array.from([1])))}return c(e,[{key:"buildGenerator",value:function(e){var t=this.cachedGenerators;if(e>=t.length)for(var n=t[t.length-1],r=this.field,i=t.length;i<=e;i++){var a=n.multiply(new ee(r,Int32Array.from([1,r.exp(i-1+r.getGeneratorBase())])));t.push(a),n=a}return t[e]}},{key:"encode",value:function(e,t){if(0===t)throw new y("No error correction bytes");var n=e.length-t;if(n<=0)throw new y("No data bytes provided");var r=this.buildGenerator(t),i=new Int32Array(n);C.arraycopy(e,0,i,0,n);for(var a=new ee(this.field,i),o=(a=a.multiplyByMonomial(t,1)).divide(r)[1].getCoefficients(),s=t-o.length,l=0;l=5&&(r+=e.N1+(l-5)),l=1,u=d)}l>=5&&(r+=e.N1+(l-5))}return r}}]),e}();Dn.N1=3,Dn.N2=3,Dn.N3=40,Dn.N4=10;var Rn=function(){function e(t,n){u(this,e),this.width=t,this.height=n;for(var r=new Array(n),i=0;i!==n;i++)r[i]=new Uint8Array(t);this.bytes=r}return c(e,[{key:"getHeight",value:function(){return this.height}},{key:"getWidth",value:function(){return this.width}},{key:"get",value:function(e,t){return this.bytes[t][e]}},{key:"getArray",value:function(){return this.bytes}},{key:"setNumber",value:function(e,t,n){this.bytes[t][e]=n}},{key:"setBoolean",value:function(e,t,n){this.bytes[t][e]=n?1:0}},{key:"clear",value:function(e){var t,n=l(this.bytes);try{for(n.s();!(t=n.n()).done;){var r=t.value;k.fill(r,e)}}catch(i){n.e(i)}finally{n.f()}}},{key:"equals",value:function(t){if(!(t instanceof e))return!1;var n=t;if(this.width!==n.width)return!1;if(this.height!==n.height)return!1;for(var r=0,i=this.height;r>\n"),e.toString()}},{key:"setMode",value:function(e){this.mode=e}},{key:"setECLevel",value:function(e){this.ecLevel=e}},{key:"setVersion",value:function(e){this.version=e}},{key:"setMaskPattern",value:function(e){this.maskPattern=e}},{key:"setMatrix",value:function(e){this.matrix=e}}],[{key:"isValidMaskPattern",value:function(t){return t>=0&&t0;){for(6===o&&(o-=1);s>=0&&s=r;)t^=n<=0)for(var l=0;l!==o;l++){var u=i[l];u>=0&&e.isEmpty(n.get(u,s))&&e.embedPositionAdjustmentPattern(u-2,s-2,n)}}}}]),e}();Pn.POSITION_DETECTION_PATTERN=Array.from([Int32Array.from([1,1,1,1,1,1,1]),Int32Array.from([1,0,0,0,0,0,1]),Int32Array.from([1,0,1,1,1,0,1]),Int32Array.from([1,0,1,1,1,0,1]),Int32Array.from([1,0,1,1,1,0,1]),Int32Array.from([1,0,0,0,0,0,1]),Int32Array.from([1,1,1,1,1,1,1])]),Pn.POSITION_ADJUSTMENT_PATTERN=Array.from([Int32Array.from([1,1,1,1,1]),Int32Array.from([1,0,0,0,1]),Int32Array.from([1,0,1,0,1]),Int32Array.from([1,0,0,0,1]),Int32Array.from([1,1,1,1,1])]),Pn.POSITION_ADJUSTMENT_PATTERN_COORDINATE_TABLE=Array.from([Int32Array.from([-1,-1,-1,-1,-1,-1,-1]),Int32Array.from([6,18,-1,-1,-1,-1,-1]),Int32Array.from([6,22,-1,-1,-1,-1,-1]),Int32Array.from([6,26,-1,-1,-1,-1,-1]),Int32Array.from([6,30,-1,-1,-1,-1,-1]),Int32Array.from([6,34,-1,-1,-1,-1,-1]),Int32Array.from([6,22,38,-1,-1,-1,-1]),Int32Array.from([6,24,42,-1,-1,-1,-1]),Int32Array.from([6,26,46,-1,-1,-1,-1]),Int32Array.from([6,28,50,-1,-1,-1,-1]),Int32Array.from([6,30,54,-1,-1,-1,-1]),Int32Array.from([6,32,58,-1,-1,-1,-1]),Int32Array.from([6,34,62,-1,-1,-1,-1]),Int32Array.from([6,26,46,66,-1,-1,-1]),Int32Array.from([6,26,48,70,-1,-1,-1]),Int32Array.from([6,26,50,74,-1,-1,-1]),Int32Array.from([6,30,54,78,-1,-1,-1]),Int32Array.from([6,30,56,82,-1,-1,-1]),Int32Array.from([6,30,58,86,-1,-1,-1]),Int32Array.from([6,34,62,90,-1,-1,-1]),Int32Array.from([6,28,50,72,94,-1,-1]),Int32Array.from([6,26,50,74,98,-1,-1]),Int32Array.from([6,30,54,78,102,-1,-1]),Int32Array.from([6,28,54,80,106,-1,-1]),Int32Array.from([6,32,58,84,110,-1,-1]),Int32Array.from([6,30,58,86,114,-1,-1]),Int32Array.from([6,34,62,90,118,-1,-1]),Int32Array.from([6,26,50,74,98,122,-1]),Int32Array.from([6,30,54,78,102,126,-1]),Int32Array.from([6,26,52,78,104,130,-1]),Int32Array.from([6,30,56,82,108,134,-1]),Int32Array.from([6,34,60,86,112,138,-1]),Int32Array.from([6,30,58,86,114,142,-1]),Int32Array.from([6,34,62,90,118,146,-1]),Int32Array.from([6,30,54,78,102,126,150]),Int32Array.from([6,24,50,76,102,128,154]),Int32Array.from([6,28,54,80,106,132,158]),Int32Array.from([6,32,58,84,110,136,162]),Int32Array.from([6,26,54,82,110,138,166]),Int32Array.from([6,30,58,86,114,142,170])]),Pn.TYPE_INFO_COORDINATES=Array.from([Int32Array.from([8,0]),Int32Array.from([8,1]),Int32Array.from([8,2]),Int32Array.from([8,3]),Int32Array.from([8,4]),Int32Array.from([8,5]),Int32Array.from([8,7]),Int32Array.from([8,8]),Int32Array.from([7,8]),Int32Array.from([5,8]),Int32Array.from([4,8]),Int32Array.from([3,8]),Int32Array.from([2,8]),Int32Array.from([1,8]),Int32Array.from([0,8])]),Pn.VERSION_INFO_POLY=7973,Pn.TYPE_INFO_POLY=1335,Pn.TYPE_INFO_MASK_PATTERN=21522;var Ln=function(){function e(t,n){u(this,e),this.dataBytes=t,this.errorCorrectionBytes=n}return c(e,[{key:"getDataBytes",value:function(){return this.dataBytes}},{key:"getErrorCorrectionBytes",value:function(){return this.errorCorrectionBytes}}]),e}(),Bn=function(){function e(){u(this,e)}return c(e,null,[{key:"calculateMaskPenalty",value:function(e){return Dn.applyMaskPenaltyRule1(e)+Dn.applyMaskPenaltyRule2(e)+Dn.applyMaskPenaltyRule3(e)+Dn.applyMaskPenaltyRule4(e)}},{key:"encode",value:function(t,n){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null,i=e.DEFAULT_BYTE_MODE_ENCODING,a=null!==r&&void 0!==r.get(Mn.CHARACTER_SET);a&&(i=r.get(Mn.CHARACTER_SET).toString());var o=this.chooseMode(t,i),s=new T;if(o===Lt.BYTE&&(a||e.DEFAULT_BYTE_MODE_ENCODING!==i)){var l=R.getCharacterSetECIByName(i);void 0!==l&&this.appendECI(l,s)}this.appendModeInfo(o,s);var u,c=new T;if(this.appendBytes(t,o,c,i),null!==r&&void 0!==r.get(Mn.QR_VERSION)){var d=Number.parseInt(r.get(Mn.QR_VERSION).toString(),10);u=Dt.getVersionForNumber(d);var f=this.calculateBitsNeeded(o,s,c,u);if(!this.willFit(f,u,n))throw new xn("Data too big for requested version")}else u=this.recommendVersion(n,o,s,c);var h=new T;h.appendBitArray(s);var v=o===Lt.BYTE?c.getSizeInBytes():t.length;this.appendLengthInfo(v,u,o,h),h.appendBitArray(c);var p=u.getECBlocksForLevel(n),g=u.getTotalCodewords()-p.getTotalECCodewords();this.terminateBits(g,h);var m=this.interleaveWithECBytes(h,u.getTotalCodewords(),g,p.getNumBlocks()),y=new On;y.setECLevel(n),y.setMode(o),y.setVersion(u);var w=u.getDimensionForVersion(),E=new Rn(w,w),S=this.chooseMaskPattern(m,n,u,E);return y.setMaskPattern(S),Pn.buildMatrix(m,n,u,S,E),y.setMatrix(E),y}},{key:"recommendVersion",value:function(e,t,n,r){var i=this.calculateBitsNeeded(t,n,r,Dt.getVersionForNumber(1)),a=this.chooseVersion(i,e),o=this.calculateBitsNeeded(t,n,r,a);return this.chooseVersion(o,e)}},{key:"calculateBitsNeeded",value:function(e,t,n,r){return t.getSize()+e.getCharacterCountBits(r)+n.getSize()}},{key:"getAlphanumericCode",value:function(t){return t1&&void 0!==arguments[1]?arguments[1]:null;if(R.SJIS.getName()===n&&this.isOnlyDoubleByteKanji(t))return Lt.KANJI;for(var r=!1,i=!1,a=0,o=t.length;a159)&&(i<224||i>235))return!1}return!0}},{key:"chooseMaskPattern",value:function(e,t,n,r){for(var i=Number.MAX_SAFE_INTEGER,a=-1,o=0;o=(e+7)/8}},{key:"terminateBits",value:function(e,t){var n=8*e;if(t.getSize()>n)throw new xn("data bits cannot fit in the QR Code"+t.getSize()+" > "+n);for(var r=0;r<4&&t.getSize()0)for(var a=i;a<8;a++)t.appendBit(!1);for(var o=e-t.getSizeInBytes(),s=0;s=n)throw new xn("Block ID too large");var o=e%n,s=n-o,l=Math.floor(e/n),u=l+1,c=Math.floor(t/n),d=c+1,f=l-c,h=u-d;if(f!==h)throw new xn("EC bytes mismatch");if(n!==s+o)throw new xn("RS blocks mismatch");if(e!==(c+f)*s+(d+h)*o)throw new xn("Total bytes mismatch");r=1<=0&&n<=9}},{key:"appendNumericBytes",value:function(t,n){for(var r=t.length,i=0;i=33088&&a<=40956?o=a-33088:a>=57408&&a<=60351&&(o=a-49472),-1===o)throw new xn("Invalid byte sequence");var s=192*(o>>8)+(255&o);t.appendBits(s,13)}}},{key:"appendECI",value:function(e,t){t.appendBits(Lt.ECI.getBits(),4),t.appendBits(e.getValue(),8)}}]),e}();Bn.ALPHANUMERIC_TABLE=Int32Array.from([-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,36,-1,-1,-1,37,38,-1,-1,-1,-1,39,40,-1,41,42,43,0,1,2,3,4,5,6,7,8,9,44,-1,-1,-1,-1,-1,-1,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,-1,-1,-1,-1,-1]),Bn.DEFAULT_BYTE_MODE_ENCODING=R.UTF8.getName();var Fn=function(){function e(){u(this,e)}return c(e,[{key:"write",value:function(t,n,r){var i=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null;if(0===t.length)throw new y("Found empty contents");if(n<0||r<0)throw new y("Requested dimensions are too small: "+n+"x"+r);var a=It.L,o=e.QUIET_ZONE_SIZE;null!==i&&(void 0!==i.get(Mn.ERROR_CORRECTION)&&(a=It.fromString(i.get(Mn.ERROR_CORRECTION).toString())),void 0!==i.get(Mn.MARGIN)&&(o=Number.parseInt(i.get(Mn.MARGIN).toString(),10)));var s=Bn.encode(t,a,i);return this.renderResult(s,n,r,o)}},{key:"writeToDom",value:function(e,t,n,r){var i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:null;"string"===typeof e&&(e=document.querySelector(e));var a=this.write(t,n,r,i);e&&e.appendChild(a)}},{key:"renderResult",value:function(e,t,n,r){var i=e.getMatrix();if(null===i)throw new ie;for(var a=i.getWidth(),o=i.getHeight(),s=a+2*r,l=o+2*r,u=Math.max(t,s),c=Math.max(n,l),d=Math.min(Math.floor(u/s),Math.floor(c/l)),f=Math.floor((u-a*d)/2),h=Math.floor((c-o*d)/2),v=this.createSVGElement(u,c),p=0,g=h;pr||o+l>i)throw new y("Crop rectangle does not fit within image data.");return c&&d.reverseHorizontal(s,l),d}return c(n,[{key:"getRow",value:function(e,t){if(e<0||e>=this.getHeight())throw new y("Requested row is outside the image: "+e);var n=this.getWidth();(null===t||void 0===t||t.length>16&255,g=v>>7&510,m=255&v;f[h]=(p+g+m)/4&255}c.luminances=f}else c.luminances=e;if(void 0===a&&(c.dataWidth=r),void 0===o&&(c.dataHeight=i),void 0===s&&(c.left=0),void 0===l&&(c.top=0),c.left+r>c.dataWidth||c.top+i>c.dataHeight)throw new y("Crop rectangle does not fit within image data.");return c}return c(n,[{key:"getRow",value:function(e,t){if(e<0||e>=this.getHeight())throw new y("Requested row is outside the image: "+e);var n=this.getWidth();(null===t||void 0===t||t.length"}}]),n}(function(){function e(t){u(this,e),this.previous=t}return c(e,[{key:"getPrevious",value:function(){return this.previous}}]),e}()),Qn=function(e){d(n,e);var t=f(n);function n(e,r,i){var a;return u(this,n),(a=t.call(this,e,0,0)).binaryShiftStart=r,a.binaryShiftByteCount=i,a}return c(n,[{key:"appendTo",value:function(e,t){for(var n=0;n62?e.appendBits(this.binaryShiftByteCount-31,16):0===n?e.appendBits(Math.min(this.binaryShiftByteCount,31),5):e.appendBits(this.binaryShiftByteCount-31,5)),e.appendBits(t[this.binaryShiftStart+n],8)}},{key:"addBinaryShift",value:function(e,t){return new n(this,e,t)}},{key:"toString",value:function(){return"<"+this.binaryShiftStart+"::"+(this.binaryShiftStart+this.binaryShiftByteCount-1)+">"}}]),n}(Xn);function Zn(e,t,n){return new Qn(e,t,n)}function Kn(e,t,n){return new Xn(e,t,n)}var qn=["UPPER","LOWER","DIGIT","MIXED","PUNCT"],$n=0,Jn=1,er=2,tr=3,nr=4,rr=new Xn(null,0,0),ir=[Int32Array.from([0,327708,327710,327709,656318]),Int32Array.from([590318,0,327710,327709,656318]),Int32Array.from([262158,590300,0,590301,932798]),Int32Array.from([327709,327708,656318,0,327710]),Int32Array.from([327711,656380,656382,656381,0])];function ar(e){var t,n=l(e);try{for(n.s();!(t=n.n()).done;){var r=t.value;k.fill(r,-1)}}catch(i){n.e(i)}finally{n.f()}return e[$n][nr]=0,e[Jn][nr]=0,e[Jn][$n]=28,e[tr][nr]=0,e[er][nr]=0,e[er][$n]=15,e}var or=ar(k.createInt32Array(6,6)),sr=function(){function e(t,n,r,i){u(this,e),this.token=t,this.mode=n,this.binaryShiftByteCount=r,this.bitCount=i}return c(e,[{key:"getMode",value:function(){return this.mode}},{key:"getToken",value:function(){return this.token}},{key:"getBinaryShiftByteCount",value:function(){return this.binaryShiftByteCount}},{key:"getBitCount",value:function(){return this.bitCount}},{key:"latchAndAppend",value:function(t,n){var r=this.bitCount,i=this.token;if(t!==this.mode){var a=ir[this.mode][t];i=Kn(i,65535&a,a>>16),r+=a>>16}var o=t===er?4:5;return new e(i=Kn(i,n,o),t,0,r+o)}},{key:"shiftAndAppend",value:function(t,n){var r=this.token,i=this.mode===er?4:5;return r=Kn(r,or[this.mode][t],i),new e(r=Kn(r,n,5),this.mode,0,this.bitCount+i+5)}},{key:"addBinaryShiftChar",value:function(t){var n=this.token,r=this.mode,i=this.bitCount;if(this.mode===nr||this.mode===er){var a=ir[r][$n];n=Kn(n,65535&a,a>>16),i+=a>>16,r=$n}var o=0===this.binaryShiftByteCount||31===this.binaryShiftByteCount?18:62===this.binaryShiftByteCount?9:8,s=new e(n,r,this.binaryShiftByteCount+1,i+o);return 2078===s.binaryShiftByteCount&&(s=s.endBinaryShift(t+1)),s}},{key:"endBinaryShift",value:function(t){if(0===this.binaryShiftByteCount)return this;var n=this.token;return new e(n=Zn(n,t-this.binaryShiftByteCount,this.binaryShiftByteCount),this.mode,0,this.bitCount)}},{key:"isBetterThanOrEqualTo",value:function(t){var n=this.bitCount+(ir[this.mode][t.mode]>>16);return this.binaryShiftByteCountt.binaryShiftByteCount&&t.binaryShiftByteCount>0&&(n+=10),n<=t.bitCount}},{key:"toBitArray",value:function(e){for(var t=[],n=this.endBinaryShift(e.length).token;null!==n;n=n.getPrevious())t.unshift(n);for(var r=new T,i=0,a=t;i62?21:e.binaryShiftByteCount>31?20:e.binaryShiftByteCount>0?10:0}}]),e}();function lr(e){var t=P.getCharCode(" "),n=P.getCharCode("."),r=P.getCharCode(",");e[$n][t]=1;for(var i=P.getCharCode("Z"),a=P.getCharCode("A"),o=a;o<=i;o++)e[$n][o]=o-a+2;e[Jn][t]=1;for(var s=P.getCharCode("z"),l=P.getCharCode("a"),u=l;u<=s;u++)e[Jn][u]=u-l+2;e[er][t]=1;for(var c=P.getCharCode("9"),d=P.getCharCode("0"),f=d;f<=c;f++)e[er][f]=f-d+2;e[er][r]=12,e[er][n]=13;for(var h=["\0"," ","\x01","\x02","\x03","\x04","\x05","\x06","\x07","\b","\t","\n","\v","\f","\r","\x1b","\x1c","\x1d","\x1e","\x1f","@","\\","^","_","`","|","~","\x7f"],v=0;v","?","[","]","{","}"],g=0;g0&&(e[nr][P.getCharCode(p[g])]=g);return e}sr.INITIAL_STATE=new sr(rr,$n,0,0);var ur=lr(k.createInt32Array(5,256)),cr=function(){function e(t){u(this,e),this.text=t}return c(e,[{key:"encode",value:function(){for(var t=P.getCharCode(" "),n=P.getCharCode("\n"),r=Yn.singletonList(sr.INITIAL_STATE),i=0;i0?(r=e.updateStateListForPair(r,i,a),i++):r=this.updateStateListForChar(r,i)}return Yn.min(r,(function(e,t){return e.getBitCount()-t.getBitCount()})).toBitArray(this.text)}},{key:"updateStateListForChar",value:function(t,n){var r,i=[],a=l(t);try{for(a.s();!(r=a.n()).done;){var o=r.value;this.updateStateForChar(o,n,i)}}catch(s){a.e(s)}finally{a.f()}return e.simplifyStates(i)}},{key:"updateStateForChar",value:function(e,t,n){for(var r=255&this.text[t],i=ur[e.getMode()][r]>0,a=null,o=0;o<=nr;o++){var s=ur[o][r];if(s>0){if(null==a&&(a=e.endBinaryShift(t)),!i||o===e.getMode()||o===er){var l=a.latchAndAppend(o,s);n.push(l)}if(!i&&or[e.getMode()][o]>=0){var u=a.shiftAndAppend(o,s);n.push(u)}}}if(e.getBinaryShiftByteCount()>0||0===ur[e.getMode()][r]){var c=e.addBinaryShiftChar(t);n.push(c)}}}],[{key:"updateStateListForPair",value:function(e,t,n){var r,i=[],a=l(e);try{for(a.s();!(r=a.n()).done;){var o=r.value;this.updateStateForPair(o,t,n,i)}}catch(s){a.e(s)}finally{a.f()}return this.simplifyStates(i)}},{key:"updateStateForPair",value:function(e,t,n,r){var i=e.endBinaryShift(t);if(r.push(i.latchAndAppend(nr,n)),e.getMode()!==nr&&r.push(i.shiftAndAppend(nr,n)),3===n||4===n){var a=i.latchAndAppend(er,16-n).latchAndAppend(er,1);r.push(a)}if(e.getBinaryShiftByteCount()>0){var o=e.addBinaryShiftChar(t).addBinaryShiftChar(t+1);r.push(o)}}},{key:"simplifyStates",value:function(e){var t,n=[],r=l(e);try{for(r.s();!(t=r.n()).done;){var i,a=t.value,o=!0,s=l(n);try{var u=function(){var e=i.value;if(e.isBetterThanOrEqualTo(a))return o=!1,"break";a.isBetterThanOrEqualTo(e)&&(n=n.filter((function(t){return t!==e})))};for(s.s();!(i=s.n()).done&&"break"!==u(););}catch(c){s.e(c)}finally{s.f()}o&&n.push(a)}}catch(c){r.e(c)}finally{r.f()}return n}}]),e}(),dr=function(){function e(){u(this,e)}return c(e,null,[{key:"encodeBytes",value:function(t){return e.encode(t,e.DEFAULT_EC_PERCENT,e.DEFAULT_AZTEC_LAYERS)}},{key:"encode",value:function(t,n,r){var i,a,o,s,l,u=new cr(t).encode(),c=I.truncDivision(u.getSize()*n,100)+11,d=u.getSize()+c;if(r!==e.DEFAULT_AZTEC_LAYERS){if(i=r<0,(a=Math.abs(r))>(i?e.MAX_NB_BITS_COMPACT:e.MAX_NB_BITS))throw new y(P.format("Illegal value %s for layers",r));var f=(o=e.totalBitsInLayer(a,i))-o%(s=e.WORD_SIZE[a]);if((l=e.stuffBits(u,s)).getSize()+c>f)throw new y("Data to large for user specified layer");if(i&&l.getSize()>64*s)throw new y("Data to large for user specified layer")}else{s=0,l=null;for(var h=0;;h++){if(h>e.MAX_NB_BITS)throw new y("Data too large for an Aztec code");if(a=(i=h<=3)?h+1:h,!(d>(o=e.totalBitsInLayer(a,i)))){null!=l&&s===e.WORD_SIZE[a]||(s=e.WORD_SIZE[a],l=e.stuffBits(u,s));var v=o-o%s;if(!(i&&l.getSize()>64*s)&&l.getSize()+c<=v)break}}}var p,g=e.generateCheckWords(l,o,s),m=l.getSize()/s,w=e.generateModeMessage(i,a,m),E=(i?11:14)+4*a,S=new Int32Array(E);if(i){p=E;for(var C=0;C=r||e.get(a+s))&&(o|=1<

    This method always replaces malformed-input and unmappable-character\n * sequences with this charset's default replacement string. The {@link\n * java.nio.charset.CharsetDecoder} class should be used when more control\n * over the decoding process is required.\n *\n * @param charsetName the name of a supported\n * {@linkplain java.nio.charset.Charset charset}\n * @return String decoded from the buffer's contents.\n * @exception UnsupportedEncodingException\n * If the named charset is not supported\n * @since JDK1.1\n */\n toString_string(charsetName) {\n return new String(this.buf /*, 0, this.count, charsetName*/).toString();\n }\n /**\n * Creates a newly allocated string. Its size is the current size of\n * the output stream and the valid contents of the buffer have been\n * copied into it. Each character c in the resulting string is\n * constructed from the corresponding element b in the byte\n * array such that:\n *

    \n         *     c == (char)(((hibyte & 0xff) << 8) | (b & 0xff))\n         * 
    \n *\n * @deprecated This method does not properly convert bytes into characters.\n * As of JDK 1.1, the preferred way to do this is via the\n * toString(String enc) method, which takes an encoding-name\n * argument, or the toString() method, which uses the\n * platform's default character encoding.\n *\n * @param hibyte the high byte of each resulting Unicode character.\n * @return the current contents of the output stream, as a string.\n * @see java.io.ByteArrayOutputStream#size()\n * @see java.io.ByteArrayOutputStream#toString(String)\n * @see java.io.ByteArrayOutputStream#toString()\n */\n // @Deprecated\n toString_number(hibyte) {\n return new String(this.buf /*, hibyte, 0, this.count*/).toString();\n }\n /**\n * Closing a ByteArrayOutputStream has no effect. The methods in\n * this class can be called after the stream has been closed without\n * generating an IOException.\n *

    \n *\n * @throws IOException\n */\n close() {\n }\n }\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*private*/ var Mode$2;\n (function (Mode) {\n Mode[Mode[\"ALPHA\"] = 0] = \"ALPHA\";\n Mode[Mode[\"LOWER\"] = 1] = \"LOWER\";\n Mode[Mode[\"MIXED\"] = 2] = \"MIXED\";\n Mode[Mode[\"PUNCT\"] = 3] = \"PUNCT\";\n Mode[Mode[\"ALPHA_SHIFT\"] = 4] = \"ALPHA_SHIFT\";\n Mode[Mode[\"PUNCT_SHIFT\"] = 5] = \"PUNCT_SHIFT\";\n })(Mode$2 || (Mode$2 = {}));\n /**\n * Indirectly access the global BigInt constructor, it\n * allows browsers that doesn't support BigInt to run\n * the library without breaking due to \"undefined BigInt\"\n * errors.\n */\n function getBigIntConstructor() {\n if (typeof window !== 'undefined') {\n return window['BigInt'] || null;\n }\n if (typeof global !== 'undefined') {\n return global['BigInt'] || null;\n }\n if (typeof self !== 'undefined') {\n return self['BigInt'] || null;\n }\n throw new Error('Can\\'t search globals for BigInt!');\n }\n /**\n * Used to store the BigInt constructor.\n */\n let BigInteger;\n /**\n * This function creates a bigint value. It allows browsers\n * that doesn't support BigInt to run the rest of the library\n * by not directly accessing the BigInt constructor.\n */\n function createBigInt(num) {\n if (typeof BigInteger === 'undefined') {\n BigInteger = getBigIntConstructor();\n }\n if (BigInteger === null) {\n throw new Error('BigInt is not supported!');\n }\n return BigInteger(num);\n }\n function getEXP900() {\n // in Java - array with length = 16\n let EXP900 = [];\n EXP900[0] = createBigInt(1);\n let nineHundred = createBigInt(900);\n EXP900[1] = nineHundred;\n // in Java - array with length = 16\n for (let i /*int*/ = 2; i < 16; i++) {\n EXP900[i] = EXP900[i - 1] * nineHundred;\n }\n return EXP900;\n }\n /**\n *

    This class contains the methods for decoding the PDF417 codewords.

    \n *\n * @author SITA Lab (kevin.osullivan@sita.aero)\n * @author Guenther Grau\n */\n /*final*/ class DecodedBitStreamParser$2 {\n // private DecodedBitStreamParser() {\n // }\n /**\n *\n * @param codewords\n * @param ecLevel\n *\n * @throws FormatException\n */\n static decode(codewords, ecLevel) {\n // pass encoding to result (will be used for decode symbols in byte mode)\n let result = new StringBuilder('');\n // let encoding: Charset = StandardCharsets.ISO_8859_1;\n let encoding = CharacterSetECI.ISO8859_1;\n /**\n * @note the next command is specific from this TypeScript library\n * because TS can't properly cast some values to char and\n * convert it to string later correctly due to encoding\n * differences from Java version. As reported here:\n * https://github.com/zxing-js/library/pull/264/files#r382831593\n */\n result.enableDecoding(encoding);\n // Get compaction mode\n let codeIndex = 1;\n let code = codewords[codeIndex++];\n let resultMetadata = new PDF417ResultMetadata();\n while (codeIndex < codewords[0]) {\n switch (code) {\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex, result);\n break;\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n codeIndex = DecodedBitStreamParser$2.byteCompaction(code, codewords, encoding, codeIndex, result);\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n result.append(/*(char)*/ codewords[codeIndex++]);\n break;\n case DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH:\n codeIndex = DecodedBitStreamParser$2.numericCompaction(codewords, codeIndex, result);\n break;\n case DecodedBitStreamParser$2.ECI_CHARSET:\n let charsetECI = CharacterSetECI.getCharacterSetECIByValue(codewords[codeIndex++]);\n // encoding = Charset.forName(charsetECI.getName());\n break;\n case DecodedBitStreamParser$2.ECI_GENERAL_PURPOSE:\n // Can't do anything with generic ECI; skip its 2 characters\n codeIndex += 2;\n break;\n case DecodedBitStreamParser$2.ECI_USER_DEFINED:\n // Can't do anything with user ECI; skip its 1 character\n codeIndex++;\n break;\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK:\n codeIndex = DecodedBitStreamParser$2.decodeMacroBlock(codewords, codeIndex, resultMetadata);\n break;\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n // Should not see these outside a macro block\n throw new FormatException();\n default:\n // Default to text compaction. During testing numerous barcodes\n // appeared to be missing the starting mode. In these cases defaulting\n // to text compaction seems to work.\n codeIndex--;\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex, result);\n break;\n }\n if (codeIndex < codewords.length) {\n code = codewords[codeIndex++];\n }\n else {\n throw FormatException.getFormatInstance();\n }\n }\n if (result.length() === 0) {\n throw FormatException.getFormatInstance();\n }\n let decoderResult = new DecoderResult(null, result.toString(), null, ecLevel);\n decoderResult.setOther(resultMetadata);\n return decoderResult;\n }\n /**\n *\n * @param int\n * @param param1\n * @param codewords\n * @param int\n * @param codeIndex\n * @param PDF417ResultMetadata\n * @param resultMetadata\n *\n * @throws FormatException\n */\n // @SuppressWarnings(\"deprecation\")\n static decodeMacroBlock(codewords, codeIndex, resultMetadata) {\n if (codeIndex + DecodedBitStreamParser$2.NUMBER_OF_SEQUENCE_CODEWORDS > codewords[0]) {\n // we must have at least two bytes left for the segment index\n throw FormatException.getFormatInstance();\n }\n let segmentIndexArray = new Int32Array(DecodedBitStreamParser$2.NUMBER_OF_SEQUENCE_CODEWORDS);\n for (let i /*int*/ = 0; i < DecodedBitStreamParser$2.NUMBER_OF_SEQUENCE_CODEWORDS; i++, codeIndex++) {\n segmentIndexArray[i] = codewords[codeIndex];\n }\n resultMetadata.setSegmentIndex(Integer.parseInt(DecodedBitStreamParser$2.decodeBase900toBase10(segmentIndexArray, DecodedBitStreamParser$2.NUMBER_OF_SEQUENCE_CODEWORDS)));\n let fileId = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex, fileId);\n resultMetadata.setFileId(fileId.toString());\n let optionalFieldsStart = -1;\n if (codewords[codeIndex] === DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD) {\n optionalFieldsStart = codeIndex + 1;\n }\n while (codeIndex < codewords[0]) {\n switch (codewords[codeIndex]) {\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n codeIndex++;\n switch (codewords[codeIndex]) {\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_FILE_NAME:\n let fileName = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex + 1, fileName);\n resultMetadata.setFileName(fileName.toString());\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_SENDER:\n let sender = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex + 1, sender);\n resultMetadata.setSender(sender.toString());\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_ADDRESSEE:\n let addressee = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.textCompaction(codewords, codeIndex + 1, addressee);\n resultMetadata.setAddressee(addressee.toString());\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_SEGMENT_COUNT:\n let segmentCount = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.numericCompaction(codewords, codeIndex + 1, segmentCount);\n resultMetadata.setSegmentCount(Integer.parseInt(segmentCount.toString()));\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_TIME_STAMP:\n let timestamp = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.numericCompaction(codewords, codeIndex + 1, timestamp);\n resultMetadata.setTimestamp(Long.parseLong(timestamp.toString()));\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_CHECKSUM:\n let checksum = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.numericCompaction(codewords, codeIndex + 1, checksum);\n resultMetadata.setChecksum(Integer.parseInt(checksum.toString()));\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_FILE_SIZE:\n let fileSize = new StringBuilder();\n codeIndex = DecodedBitStreamParser$2.numericCompaction(codewords, codeIndex + 1, fileSize);\n resultMetadata.setFileSize(Long.parseLong(fileSize.toString()));\n break;\n default:\n throw FormatException.getFormatInstance();\n }\n break;\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n codeIndex++;\n resultMetadata.setLastSegment(true);\n break;\n default:\n throw FormatException.getFormatInstance();\n }\n }\n // copy optional fields to additional options\n if (optionalFieldsStart !== -1) {\n let optionalFieldsLength = codeIndex - optionalFieldsStart;\n if (resultMetadata.isLastSegment()) {\n // do not include terminator\n optionalFieldsLength--;\n }\n resultMetadata.setOptionalData(Arrays.copyOfRange(codewords, optionalFieldsStart, optionalFieldsStart + optionalFieldsLength));\n }\n return codeIndex;\n }\n /**\n * Text Compaction mode (see 5.4.1.5) permits all printable ASCII characters to be\n * encoded, i.e. values 32 - 126 inclusive in accordance with ISO/IEC 646 (IRV), as\n * well as selected control characters.\n *\n * @param codewords The array of codewords (data + error)\n * @param codeIndex The current index into the codeword array.\n * @param result The decoded data is appended to the result.\n * @return The next index into the codeword array.\n */\n static textCompaction(codewords, codeIndex, result) {\n // 2 character per codeword\n let textCompactionData = new Int32Array((codewords[0] - codeIndex) * 2);\n // Used to hold the byte compaction value if there is a mode shift\n let byteCompactionData = new Int32Array((codewords[0] - codeIndex) * 2);\n let index = 0;\n let end = false;\n while ((codeIndex < codewords[0]) && !end) {\n let code = codewords[codeIndex++];\n if (code < DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH) {\n textCompactionData[index] = code / 30;\n textCompactionData[index + 1] = code % 30;\n index += 2;\n }\n else {\n switch (code) {\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n // reinitialize text compaction mode to alpha sub mode\n textCompactionData[index++] = DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH;\n break;\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n case DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n codeIndex--;\n end = true;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n // The Mode Shift codeword 913 shall cause a temporary\n // switch from Text Compaction mode to Byte Compaction mode.\n // This switch shall be in effect for only the next codeword,\n // after which the mode shall revert to the prevailing sub-mode\n // of the Text Compaction mode. Codeword 913 is only available\n // in Text Compaction mode; its use is described in 5.4.2.4.\n textCompactionData[index] = DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE;\n code = codewords[codeIndex++];\n byteCompactionData[index] = code;\n index++;\n break;\n }\n }\n }\n DecodedBitStreamParser$2.decodeTextCompaction(textCompactionData, byteCompactionData, index, result);\n return codeIndex;\n }\n /**\n * The Text Compaction mode includes all the printable ASCII characters\n * (i.e. values from 32 to 126) and three ASCII control characters: HT or tab\n * (9: e), LF or line feed (10: e), and CR or carriage\n * return (13: e). The Text Compaction mode also includes various latch\n * and shift characters which are used exclusively within the mode. The Text\n * Compaction mode encodes up to 2 characters per codeword. The compaction rules\n * for converting data into PDF417 codewords are defined in 5.4.2.2. The sub-mode\n * switches are defined in 5.4.2.3.\n *\n * @param textCompactionData The text compaction data.\n * @param byteCompactionData The byte compaction data if there\n * was a mode shift.\n * @param length The size of the text compaction and byte compaction data.\n * @param result The decoded data is appended to the result.\n */\n static decodeTextCompaction(textCompactionData, byteCompactionData, length, result) {\n // Beginning from an initial state of the Alpha sub-mode\n // The default compaction mode for PDF417 in effect at the start of each symbol shall always be Text\n // Compaction mode Alpha sub-mode (alphabetic: uppercase). A latch codeword from another mode to the Text\n // Compaction mode shall always switch to the Text Compaction Alpha sub-mode.\n let subMode = Mode$2.ALPHA;\n let priorToShiftMode = Mode$2.ALPHA;\n let i = 0;\n while (i < length) {\n let subModeCh = textCompactionData[i];\n let ch = /*char*/ '';\n switch (subMode) {\n case Mode$2.ALPHA:\n // Alpha (alphabetic: uppercase)\n if (subModeCh < 26) {\n // Upper case Alpha Character\n // Note: 65 = 'A' ASCII -> there is byte code of symbol\n ch = /*(char)('A' + subModeCh) */ String.fromCharCode(65 + subModeCh);\n }\n else {\n switch (subModeCh) {\n case 26:\n ch = ' ';\n break;\n case DecodedBitStreamParser$2.LL:\n subMode = Mode$2.LOWER;\n break;\n case DecodedBitStreamParser$2.ML:\n subMode = Mode$2.MIXED;\n break;\n case DecodedBitStreamParser$2.PS:\n // Shift to punctuation\n priorToShiftMode = subMode;\n subMode = Mode$2.PUNCT_SHIFT;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n result.append(/*(char)*/ byteCompactionData[i]);\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n case Mode$2.LOWER:\n // Lower (alphabetic: lowercase)\n if (subModeCh < 26) {\n ch = /*(char)('a' + subModeCh)*/ String.fromCharCode(97 + subModeCh);\n }\n else {\n switch (subModeCh) {\n case 26:\n ch = ' ';\n break;\n case DecodedBitStreamParser$2.AS:\n // Shift to alpha\n priorToShiftMode = subMode;\n subMode = Mode$2.ALPHA_SHIFT;\n break;\n case DecodedBitStreamParser$2.ML:\n subMode = Mode$2.MIXED;\n break;\n case DecodedBitStreamParser$2.PS:\n // Shift to punctuation\n priorToShiftMode = subMode;\n subMode = Mode$2.PUNCT_SHIFT;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n // TODO Does this need to use the current character encoding? See other occurrences below\n result.append(/*(char)*/ byteCompactionData[i]);\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n case Mode$2.MIXED:\n // Mixed (punctuation: e)\n if (subModeCh < DecodedBitStreamParser$2.PL) {\n ch = DecodedBitStreamParser$2.MIXED_CHARS[subModeCh];\n }\n else {\n switch (subModeCh) {\n case DecodedBitStreamParser$2.PL:\n subMode = Mode$2.PUNCT;\n break;\n case 26:\n ch = ' ';\n break;\n case DecodedBitStreamParser$2.LL:\n subMode = Mode$2.LOWER;\n break;\n case DecodedBitStreamParser$2.AL:\n subMode = Mode$2.ALPHA;\n break;\n case DecodedBitStreamParser$2.PS:\n // Shift to punctuation\n priorToShiftMode = subMode;\n subMode = Mode$2.PUNCT_SHIFT;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n result.append(/*(char)*/ byteCompactionData[i]);\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n case Mode$2.PUNCT:\n // Punctuation\n if (subModeCh < DecodedBitStreamParser$2.PAL) {\n ch = DecodedBitStreamParser$2.PUNCT_CHARS[subModeCh];\n }\n else {\n switch (subModeCh) {\n case DecodedBitStreamParser$2.PAL:\n subMode = Mode$2.ALPHA;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n result.append(/*(char)*/ byteCompactionData[i]);\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n case Mode$2.ALPHA_SHIFT:\n // Restore sub-mode\n subMode = priorToShiftMode;\n if (subModeCh < 26) {\n ch = /*(char)('A' + subModeCh)*/ String.fromCharCode(65 + subModeCh);\n }\n else {\n switch (subModeCh) {\n case 26:\n ch = ' ';\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n case Mode$2.PUNCT_SHIFT:\n // Restore sub-mode\n subMode = priorToShiftMode;\n if (subModeCh < DecodedBitStreamParser$2.PAL) {\n ch = DecodedBitStreamParser$2.PUNCT_CHARS[subModeCh];\n }\n else {\n switch (subModeCh) {\n case DecodedBitStreamParser$2.PAL:\n subMode = Mode$2.ALPHA;\n break;\n case DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE:\n // PS before Shift-to-Byte is used as a padding character,\n // see 5.4.2.4 of the specification\n result.append(/*(char)*/ byteCompactionData[i]);\n break;\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n subMode = Mode$2.ALPHA;\n break;\n }\n }\n break;\n }\n // if (ch !== 0) {\n if (ch !== '') {\n // Append decoded character to result\n result.append(ch);\n }\n i++;\n }\n }\n /**\n * Byte Compaction mode (see 5.4.3) permits all 256 possible 8-bit byte values to be encoded.\n * This includes all ASCII characters value 0 to 127 inclusive and provides for international\n * character set support.\n *\n * @param mode The byte compaction mode i.e. 901 or 924\n * @param codewords The array of codewords (data + error)\n * @param encoding Currently active character encoding\n * @param codeIndex The current index into the codeword array.\n * @param result The decoded data is appended to the result.\n * @return The next index into the codeword array.\n */\n static /*int*/ byteCompaction(mode, codewords, encoding, codeIndex, result) {\n let decodedBytes = new ByteArrayOutputStream();\n let count = 0;\n let value = /*long*/ 0;\n let end = false;\n switch (mode) {\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n // Total number of Byte Compaction characters to be encoded\n // is not a multiple of 6\n let byteCompactedCodewords = new Int32Array(6);\n let nextCode = codewords[codeIndex++];\n while ((codeIndex < codewords[0]) && !end) {\n byteCompactedCodewords[count++] = nextCode;\n // Base 900\n value = 900 * value + nextCode;\n nextCode = codewords[codeIndex++];\n // perhaps it should be ok to check only nextCode >= TEXT_COMPACTION_MODE_LATCH\n switch (nextCode) {\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n codeIndex--;\n end = true;\n break;\n default:\n if ((count % 5 === 0) && (count > 0)) {\n // Decode every 5 codewords\n // Convert to Base 256\n for (let j /*int*/ = 0; j < 6; ++j) {\n /* @note\n * JavaScript stores numbers as 64 bits floating point numbers, but all bitwise operations are performed on 32 bits binary numbers.\n * So the next bitwise operation could not be done with simple numbers\n */\n decodedBytes.write(/*(byte)*/ Number(createBigInt(value) >> createBigInt(8 * (5 - j))));\n }\n value = 0;\n count = 0;\n }\n break;\n }\n }\n // if the end of all codewords is reached the last codeword needs to be added\n if (codeIndex === codewords[0] && nextCode < DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH) {\n byteCompactedCodewords[count++] = nextCode;\n }\n // If Byte Compaction mode is invoked with codeword 901,\n // the last group of codewords is interpreted directly\n // as one byte per codeword, without compaction.\n for (let i /*int*/ = 0; i < count; i++) {\n decodedBytes.write(/*(byte)*/ byteCompactedCodewords[i]);\n }\n break;\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n // Total number of Byte Compaction characters to be encoded\n // is an integer multiple of 6\n while (codeIndex < codewords[0] && !end) {\n let code = codewords[codeIndex++];\n if (code < DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH) {\n count++;\n // Base 900\n value = 900 * value + code;\n }\n else {\n switch (code) {\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n codeIndex--;\n end = true;\n break;\n }\n }\n if ((count % 5 === 0) && (count > 0)) {\n // Decode every 5 codewords\n // Convert to Base 256\n /* @note\n * JavaScript stores numbers as 64 bits floating point numbers, but all bitwise operations are performed on 32 bits binary numbers.\n * So the next bitwise operation could not be done with simple numbers\n */\n for (let j /*int*/ = 0; j < 6; ++j) {\n decodedBytes.write(/*(byte)*/ Number(createBigInt(value) >> createBigInt(8 * (5 - j))));\n }\n value = 0;\n count = 0;\n }\n }\n break;\n }\n result.append(StringEncoding.decode(decodedBytes.toByteArray(), encoding));\n return codeIndex;\n }\n /**\n * Numeric Compaction mode (see 5.4.4) permits efficient encoding of numeric data strings.\n *\n * @param codewords The array of codewords (data + error)\n * @param codeIndex The current index into the codeword array.\n * @param result The decoded data is appended to the result.\n * @return The next index into the codeword array.\n *\n * @throws FormatException\n */\n static numericCompaction(codewords, codeIndex /*int*/, result) {\n let count = 0;\n let end = false;\n let numericCodewords = new Int32Array(DecodedBitStreamParser$2.MAX_NUMERIC_CODEWORDS);\n while (codeIndex < codewords[0] && !end) {\n let code = codewords[codeIndex++];\n if (codeIndex === codewords[0]) {\n end = true;\n }\n if (code < DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH) {\n numericCodewords[count] = code;\n count++;\n }\n else {\n switch (code) {\n case DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH:\n case DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK:\n case DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD:\n case DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR:\n codeIndex--;\n end = true;\n break;\n }\n }\n if ((count % DecodedBitStreamParser$2.MAX_NUMERIC_CODEWORDS === 0 || code === DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH || end) && count > 0) {\n // Re-invoking Numeric Compaction mode (by using codeword 902\n // while in Numeric Compaction mode) serves to terminate the\n // current Numeric Compaction mode grouping as described in 5.4.4.2,\n // and then to start a new one grouping.\n result.append(DecodedBitStreamParser$2.decodeBase900toBase10(numericCodewords, count));\n count = 0;\n }\n }\n return codeIndex;\n }\n /**\n * Convert a list of Numeric Compacted codewords from Base 900 to Base 10.\n *\n * @param codewords The array of codewords\n * @param count The number of codewords\n * @return The decoded string representing the Numeric data.\n *\n * EXAMPLE\n * Encode the fifteen digit numeric string 000213298174000\n * Prefix the numeric string with a 1 and set the initial value of\n * t = 1 000 213 298 174 000\n * Calculate codeword 0\n * d0 = 1 000 213 298 174 000 mod 900 = 200\n *\n * t = 1 000 213 298 174 000 div 900 = 1 111 348 109 082\n * Calculate codeword 1\n * d1 = 1 111 348 109 082 mod 900 = 282\n *\n * t = 1 111 348 109 082 div 900 = 1 234 831 232\n * Calculate codeword 2\n * d2 = 1 234 831 232 mod 900 = 632\n *\n * t = 1 234 831 232 div 900 = 1 372 034\n * Calculate codeword 3\n * d3 = 1 372 034 mod 900 = 434\n *\n * t = 1 372 034 div 900 = 1 524\n * Calculate codeword 4\n * d4 = 1 524 mod 900 = 624\n *\n * t = 1 524 div 900 = 1\n * Calculate codeword 5\n * d5 = 1 mod 900 = 1\n * t = 1 div 900 = 0\n * Codeword sequence is: 1, 624, 434, 632, 282, 200\n *\n * Decode the above codewords involves\n * 1 x 900 power of 5 + 624 x 900 power of 4 + 434 x 900 power of 3 +\n * 632 x 900 power of 2 + 282 x 900 power of 1 + 200 x 900 power of 0 = 1000213298174000\n *\n * Remove leading 1 => Result is 000213298174000\n *\n * @throws FormatException\n */\n static decodeBase900toBase10(codewords, count) {\n let result = createBigInt(0);\n for (let i /*int*/ = 0; i < count; i++) {\n result += DecodedBitStreamParser$2.EXP900[count - i - 1] * createBigInt(codewords[i]);\n }\n let resultString = result.toString();\n if (resultString.charAt(0) !== '1') {\n throw new FormatException();\n }\n return resultString.substring(1);\n }\n }\n DecodedBitStreamParser$2.TEXT_COMPACTION_MODE_LATCH = 900;\n DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH = 901;\n DecodedBitStreamParser$2.NUMERIC_COMPACTION_MODE_LATCH = 902;\n DecodedBitStreamParser$2.BYTE_COMPACTION_MODE_LATCH_6 = 924;\n DecodedBitStreamParser$2.ECI_USER_DEFINED = 925;\n DecodedBitStreamParser$2.ECI_GENERAL_PURPOSE = 926;\n DecodedBitStreamParser$2.ECI_CHARSET = 927;\n DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_CONTROL_BLOCK = 928;\n DecodedBitStreamParser$2.BEGIN_MACRO_PDF417_OPTIONAL_FIELD = 923;\n DecodedBitStreamParser$2.MACRO_PDF417_TERMINATOR = 922;\n DecodedBitStreamParser$2.MODE_SHIFT_TO_BYTE_COMPACTION_MODE = 913;\n DecodedBitStreamParser$2.MAX_NUMERIC_CODEWORDS = 15;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_FILE_NAME = 0;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_SEGMENT_COUNT = 1;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_TIME_STAMP = 2;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_SENDER = 3;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_ADDRESSEE = 4;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_FILE_SIZE = 5;\n DecodedBitStreamParser$2.MACRO_PDF417_OPTIONAL_FIELD_CHECKSUM = 6;\n DecodedBitStreamParser$2.PL = 25;\n DecodedBitStreamParser$2.LL = 27;\n DecodedBitStreamParser$2.AS = 27;\n DecodedBitStreamParser$2.ML = 28;\n DecodedBitStreamParser$2.AL = 28;\n DecodedBitStreamParser$2.PS = 29;\n DecodedBitStreamParser$2.PAL = 29;\n DecodedBitStreamParser$2.PUNCT_CHARS = ';<>@[\\\\]_`~!\\r\\t,:\\n-.$/\"|*()?{}\\'';\n DecodedBitStreamParser$2.MIXED_CHARS = '0123456789&\\r\\t,:#-.$/+%*=^';\n /**\n * Table containing values for the exponent of 900.\n * This is used in the numeric compaction decode algorithm.\n */\n DecodedBitStreamParser$2.EXP900 = getBigIntConstructor() ? getEXP900() : [];\n DecodedBitStreamParser$2.NUMBER_OF_SEQUENCE_CODEWORDS = 2;\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // import java.util.ArrayList;\n // import java.util.Collection;\n // import java.util.Formatter;\n // import java.util.List;\n /**\n * @author Guenther Grau\n */\n /*public final*/ class PDF417ScanningDecoder {\n constructor() { }\n /**\n * @TODO don't pass in minCodewordWidth and maxCodewordWidth, pass in barcode columns for start and stop pattern\n *\n * columns. That way width can be deducted from the pattern column.\n * This approach also allows to detect more details about the barcode, e.g. if a bar type (white or black) is wider\n * than it should be. This can happen if the scanner used a bad blackpoint.\n *\n * @param BitMatrix\n * @param image\n * @param ResultPoint\n * @param imageTopLeft\n * @param ResultPoint\n * @param imageBottomLeft\n * @param ResultPoint\n * @param imageTopRight\n * @param ResultPoint\n * @param imageBottomRight\n * @param int\n * @param minCodewordWidth\n * @param int\n * @param maxCodewordWidth\n *\n * @throws NotFoundException\n * @throws FormatException\n * @throws ChecksumException\n */\n static decode(image, imageTopLeft, imageBottomLeft, imageTopRight, imageBottomRight, minCodewordWidth, maxCodewordWidth) {\n let boundingBox = new BoundingBox(image, imageTopLeft, imageBottomLeft, imageTopRight, imageBottomRight);\n let leftRowIndicatorColumn = null;\n let rightRowIndicatorColumn = null;\n let detectionResult;\n for (let firstPass /*boolean*/ = true;; firstPass = false) {\n if (imageTopLeft != null) {\n leftRowIndicatorColumn = PDF417ScanningDecoder.getRowIndicatorColumn(image, boundingBox, imageTopLeft, true, minCodewordWidth, maxCodewordWidth);\n }\n if (imageTopRight != null) {\n rightRowIndicatorColumn = PDF417ScanningDecoder.getRowIndicatorColumn(image, boundingBox, imageTopRight, false, minCodewordWidth, maxCodewordWidth);\n }\n detectionResult = PDF417ScanningDecoder.merge(leftRowIndicatorColumn, rightRowIndicatorColumn);\n if (detectionResult == null) {\n throw NotFoundException.getNotFoundInstance();\n }\n let resultBox = detectionResult.getBoundingBox();\n if (firstPass && resultBox != null &&\n (resultBox.getMinY() < boundingBox.getMinY() || resultBox.getMaxY() > boundingBox.getMaxY())) {\n boundingBox = resultBox;\n }\n else {\n break;\n }\n }\n detectionResult.setBoundingBox(boundingBox);\n let maxBarcodeColumn = detectionResult.getBarcodeColumnCount() + 1;\n detectionResult.setDetectionResultColumn(0, leftRowIndicatorColumn);\n detectionResult.setDetectionResultColumn(maxBarcodeColumn, rightRowIndicatorColumn);\n let leftToRight = leftRowIndicatorColumn != null;\n for (let barcodeColumnCount /*int*/ = 1; barcodeColumnCount <= maxBarcodeColumn; barcodeColumnCount++) {\n let barcodeColumn = leftToRight ? barcodeColumnCount : maxBarcodeColumn - barcodeColumnCount;\n if (detectionResult.getDetectionResultColumn(barcodeColumn) !== /* null */ undefined) {\n // This will be the case for the opposite row indicator column, which doesn't need to be decoded again.\n continue;\n }\n let detectionResultColumn;\n if (barcodeColumn === 0 || barcodeColumn === maxBarcodeColumn) {\n detectionResultColumn = new DetectionResultRowIndicatorColumn(boundingBox, barcodeColumn === 0);\n }\n else {\n detectionResultColumn = new DetectionResultColumn(boundingBox);\n }\n detectionResult.setDetectionResultColumn(barcodeColumn, detectionResultColumn);\n let startColumn = -1;\n let previousStartColumn = startColumn;\n // TODO start at a row for which we know the start position, then detect upwards and downwards from there.\n for (let imageRow /*int*/ = boundingBox.getMinY(); imageRow <= boundingBox.getMaxY(); imageRow++) {\n startColumn = PDF417ScanningDecoder.getStartColumn(detectionResult, barcodeColumn, imageRow, leftToRight);\n if (startColumn < 0 || startColumn > boundingBox.getMaxX()) {\n if (previousStartColumn === -1) {\n continue;\n }\n startColumn = previousStartColumn;\n }\n let codeword = PDF417ScanningDecoder.detectCodeword(image, boundingBox.getMinX(), boundingBox.getMaxX(), leftToRight, startColumn, imageRow, minCodewordWidth, maxCodewordWidth);\n if (codeword != null) {\n detectionResultColumn.setCodeword(imageRow, codeword);\n previousStartColumn = startColumn;\n minCodewordWidth = Math.min(minCodewordWidth, codeword.getWidth());\n maxCodewordWidth = Math.max(maxCodewordWidth, codeword.getWidth());\n }\n }\n }\n return PDF417ScanningDecoder.createDecoderResult(detectionResult);\n }\n /**\n *\n * @param leftRowIndicatorColumn\n * @param rightRowIndicatorColumn\n *\n * @throws NotFoundException\n */\n static merge(leftRowIndicatorColumn, rightRowIndicatorColumn) {\n if (leftRowIndicatorColumn == null && rightRowIndicatorColumn == null) {\n return null;\n }\n let barcodeMetadata = PDF417ScanningDecoder.getBarcodeMetadata(leftRowIndicatorColumn, rightRowIndicatorColumn);\n if (barcodeMetadata == null) {\n return null;\n }\n let boundingBox = BoundingBox.merge(PDF417ScanningDecoder.adjustBoundingBox(leftRowIndicatorColumn), PDF417ScanningDecoder.adjustBoundingBox(rightRowIndicatorColumn));\n return new DetectionResult(barcodeMetadata, boundingBox);\n }\n /**\n *\n * @param rowIndicatorColumn\n *\n * @throws NotFoundException\n */\n static adjustBoundingBox(rowIndicatorColumn) {\n if (rowIndicatorColumn == null) {\n return null;\n }\n let rowHeights = rowIndicatorColumn.getRowHeights();\n if (rowHeights == null) {\n return null;\n }\n let maxRowHeight = PDF417ScanningDecoder.getMax(rowHeights);\n let missingStartRows = 0;\n for (let rowHeight /*int*/ of rowHeights) {\n missingStartRows += maxRowHeight - rowHeight;\n if (rowHeight > 0) {\n break;\n }\n }\n let codewords = rowIndicatorColumn.getCodewords();\n for (let row /*int*/ = 0; missingStartRows > 0 && codewords[row] == null; row++) {\n missingStartRows--;\n }\n let missingEndRows = 0;\n for (let row /*int*/ = rowHeights.length - 1; row >= 0; row--) {\n missingEndRows += maxRowHeight - rowHeights[row];\n if (rowHeights[row] > 0) {\n break;\n }\n }\n for (let row /*int*/ = codewords.length - 1; missingEndRows > 0 && codewords[row] == null; row--) {\n missingEndRows--;\n }\n return rowIndicatorColumn.getBoundingBox().addMissingRows(missingStartRows, missingEndRows, rowIndicatorColumn.isLeft());\n }\n static getMax(values) {\n let maxValue = -1;\n for (let value /*int*/ of values) {\n maxValue = Math.max(maxValue, value);\n }\n return maxValue;\n }\n static getBarcodeMetadata(leftRowIndicatorColumn, rightRowIndicatorColumn) {\n let leftBarcodeMetadata;\n if (leftRowIndicatorColumn == null ||\n (leftBarcodeMetadata = leftRowIndicatorColumn.getBarcodeMetadata()) == null) {\n return rightRowIndicatorColumn == null ? null : rightRowIndicatorColumn.getBarcodeMetadata();\n }\n let rightBarcodeMetadata;\n if (rightRowIndicatorColumn == null ||\n (rightBarcodeMetadata = rightRowIndicatorColumn.getBarcodeMetadata()) == null) {\n return leftBarcodeMetadata;\n }\n if (leftBarcodeMetadata.getColumnCount() !== rightBarcodeMetadata.getColumnCount() &&\n leftBarcodeMetadata.getErrorCorrectionLevel() !== rightBarcodeMetadata.getErrorCorrectionLevel() &&\n leftBarcodeMetadata.getRowCount() !== rightBarcodeMetadata.getRowCount()) {\n return null;\n }\n return leftBarcodeMetadata;\n }\n static getRowIndicatorColumn(image, boundingBox, startPoint, leftToRight, minCodewordWidth, maxCodewordWidth) {\n let rowIndicatorColumn = new DetectionResultRowIndicatorColumn(boundingBox, leftToRight);\n for (let i /*int*/ = 0; i < 2; i++) {\n let increment = i === 0 ? 1 : -1;\n let startColumn = Math.trunc(Math.trunc(startPoint.getX()));\n for (let imageRow /*int*/ = Math.trunc(Math.trunc(startPoint.getY())); imageRow <= boundingBox.getMaxY() &&\n imageRow >= boundingBox.getMinY(); imageRow += increment) {\n let codeword = PDF417ScanningDecoder.detectCodeword(image, 0, image.getWidth(), leftToRight, startColumn, imageRow, minCodewordWidth, maxCodewordWidth);\n if (codeword != null) {\n rowIndicatorColumn.setCodeword(imageRow, codeword);\n if (leftToRight) {\n startColumn = codeword.getStartX();\n }\n else {\n startColumn = codeword.getEndX();\n }\n }\n }\n }\n return rowIndicatorColumn;\n }\n /**\n *\n * @param detectionResult\n * @param BarcodeValue\n * @param param2\n * @param param3\n * @param barcodeMatrix\n *\n * @throws NotFoundException\n */\n static adjustCodewordCount(detectionResult, barcodeMatrix) {\n let barcodeMatrix01 = barcodeMatrix[0][1];\n let numberOfCodewords = barcodeMatrix01.getValue();\n let calculatedNumberOfCodewords = detectionResult.getBarcodeColumnCount() *\n detectionResult.getBarcodeRowCount() -\n PDF417ScanningDecoder.getNumberOfECCodeWords(detectionResult.getBarcodeECLevel());\n if (numberOfCodewords.length === 0) {\n if (calculatedNumberOfCodewords < 1 || calculatedNumberOfCodewords > PDF417Common.MAX_CODEWORDS_IN_BARCODE) {\n throw NotFoundException.getNotFoundInstance();\n }\n barcodeMatrix01.setValue(calculatedNumberOfCodewords);\n }\n else if (numberOfCodewords[0] !== calculatedNumberOfCodewords) {\n // The calculated one is more reliable as it is derived from the row indicator columns\n barcodeMatrix01.setValue(calculatedNumberOfCodewords);\n }\n }\n /**\n *\n * @param detectionResult\n *\n * @throws FormatException\n * @throws ChecksumException\n * @throws NotFoundException\n */\n static createDecoderResult(detectionResult) {\n let barcodeMatrix = PDF417ScanningDecoder.createBarcodeMatrix(detectionResult);\n PDF417ScanningDecoder.adjustCodewordCount(detectionResult, barcodeMatrix);\n let erasures /*Collection*/ = new Array();\n let codewords = new Int32Array(detectionResult.getBarcodeRowCount() * detectionResult.getBarcodeColumnCount());\n let ambiguousIndexValuesList = /*List*/ [];\n let ambiguousIndexesList = /*Collection*/ new Array();\n for (let row /*int*/ = 0; row < detectionResult.getBarcodeRowCount(); row++) {\n for (let column /*int*/ = 0; column < detectionResult.getBarcodeColumnCount(); column++) {\n let values = barcodeMatrix[row][column + 1].getValue();\n let codewordIndex = row * detectionResult.getBarcodeColumnCount() + column;\n if (values.length === 0) {\n erasures.push(codewordIndex);\n }\n else if (values.length === 1) {\n codewords[codewordIndex] = values[0];\n }\n else {\n ambiguousIndexesList.push(codewordIndex);\n ambiguousIndexValuesList.push(values);\n }\n }\n }\n let ambiguousIndexValues = new Array(ambiguousIndexValuesList.length);\n for (let i /*int*/ = 0; i < ambiguousIndexValues.length; i++) {\n ambiguousIndexValues[i] = ambiguousIndexValuesList[i];\n }\n return PDF417ScanningDecoder.createDecoderResultFromAmbiguousValues(detectionResult.getBarcodeECLevel(), codewords, PDF417Common.toIntArray(erasures), PDF417Common.toIntArray(ambiguousIndexesList), ambiguousIndexValues);\n }\n /**\n * This method deals with the fact, that the decoding process doesn't always yield a single most likely value. The\n * current error correction implementation doesn't deal with erasures very well, so it's better to provide a value\n * for these ambiguous codewords instead of treating it as an erasure. The problem is that we don't know which of\n * the ambiguous values to choose. We try decode using the first value, and if that fails, we use another of the\n * ambiguous values and try to decode again. This usually only happens on very hard to read and decode barcodes,\n * so decoding the normal barcodes is not affected by this.\n *\n * @param erasureArray contains the indexes of erasures\n * @param ambiguousIndexes array with the indexes that have more than one most likely value\n * @param ambiguousIndexValues two dimensional array that contains the ambiguous values. The first dimension must\n * be the same length as the ambiguousIndexes array\n *\n * @throws FormatException\n * @throws ChecksumException\n */\n static createDecoderResultFromAmbiguousValues(ecLevel, codewords, erasureArray, ambiguousIndexes, ambiguousIndexValues) {\n let ambiguousIndexCount = new Int32Array(ambiguousIndexes.length);\n let tries = 100;\n while (tries-- > 0) {\n for (let i /*int*/ = 0; i < ambiguousIndexCount.length; i++) {\n codewords[ambiguousIndexes[i]] = ambiguousIndexValues[i][ambiguousIndexCount[i]];\n }\n try {\n return PDF417ScanningDecoder.decodeCodewords(codewords, ecLevel, erasureArray);\n }\n catch (err) {\n let ignored = err instanceof ChecksumException;\n if (!ignored) {\n throw err;\n }\n }\n if (ambiguousIndexCount.length === 0) {\n throw ChecksumException.getChecksumInstance();\n }\n for (let i /*int*/ = 0; i < ambiguousIndexCount.length; i++) {\n if (ambiguousIndexCount[i] < ambiguousIndexValues[i].length - 1) {\n ambiguousIndexCount[i]++;\n break;\n }\n else {\n ambiguousIndexCount[i] = 0;\n if (i === ambiguousIndexCount.length - 1) {\n throw ChecksumException.getChecksumInstance();\n }\n }\n }\n }\n throw ChecksumException.getChecksumInstance();\n }\n static createBarcodeMatrix(detectionResult) {\n // let barcodeMatrix: BarcodeValue[][] =\n // new BarcodeValue[detectionResult.getBarcodeRowCount()][detectionResult.getBarcodeColumnCount() + 2];\n let barcodeMatrix = Array.from({ length: detectionResult.getBarcodeRowCount() }, () => new Array(detectionResult.getBarcodeColumnCount() + 2));\n for (let row /*int*/ = 0; row < barcodeMatrix.length; row++) {\n for (let column /*int*/ = 0; column < barcodeMatrix[row].length; column++) {\n barcodeMatrix[row][column] = new BarcodeValue();\n }\n }\n let column = 0;\n for (let detectionResultColumn /*DetectionResultColumn*/ of detectionResult.getDetectionResultColumns()) {\n if (detectionResultColumn != null) {\n for (let codeword /*Codeword*/ of detectionResultColumn.getCodewords()) {\n if (codeword != null) {\n let rowNumber = codeword.getRowNumber();\n if (rowNumber >= 0) {\n if (rowNumber >= barcodeMatrix.length) {\n // We have more rows than the barcode metadata allows for, ignore them.\n continue;\n }\n barcodeMatrix[rowNumber][column].setValue(codeword.getValue());\n }\n }\n }\n }\n column++;\n }\n return barcodeMatrix;\n }\n static isValidBarcodeColumn(detectionResult, barcodeColumn) {\n return barcodeColumn >= 0 && barcodeColumn <= detectionResult.getBarcodeColumnCount() + 1;\n }\n static getStartColumn(detectionResult, barcodeColumn, imageRow, leftToRight) {\n let offset = leftToRight ? 1 : -1;\n let codeword = null;\n if (PDF417ScanningDecoder.isValidBarcodeColumn(detectionResult, barcodeColumn - offset)) {\n codeword = detectionResult.getDetectionResultColumn(barcodeColumn - offset).getCodeword(imageRow);\n }\n if (codeword != null) {\n return leftToRight ? codeword.getEndX() : codeword.getStartX();\n }\n codeword = detectionResult.getDetectionResultColumn(barcodeColumn).getCodewordNearby(imageRow);\n if (codeword != null) {\n return leftToRight ? codeword.getStartX() : codeword.getEndX();\n }\n if (PDF417ScanningDecoder.isValidBarcodeColumn(detectionResult, barcodeColumn - offset)) {\n codeword = detectionResult.getDetectionResultColumn(barcodeColumn - offset).getCodewordNearby(imageRow);\n }\n if (codeword != null) {\n return leftToRight ? codeword.getEndX() : codeword.getStartX();\n }\n let skippedColumns = 0;\n while (PDF417ScanningDecoder.isValidBarcodeColumn(detectionResult, barcodeColumn - offset)) {\n barcodeColumn -= offset;\n for (let previousRowCodeword /*Codeword*/ of detectionResult.getDetectionResultColumn(barcodeColumn).getCodewords()) {\n if (previousRowCodeword != null) {\n return (leftToRight ? previousRowCodeword.getEndX() : previousRowCodeword.getStartX()) +\n offset *\n skippedColumns *\n (previousRowCodeword.getEndX() - previousRowCodeword.getStartX());\n }\n }\n skippedColumns++;\n }\n return leftToRight ? detectionResult.getBoundingBox().getMinX() : detectionResult.getBoundingBox().getMaxX();\n }\n static detectCodeword(image, minColumn, maxColumn, leftToRight, startColumn, imageRow, minCodewordWidth, maxCodewordWidth) {\n startColumn = PDF417ScanningDecoder.adjustCodewordStartColumn(image, minColumn, maxColumn, leftToRight, startColumn, imageRow);\n // we usually know fairly exact now how long a codeword is. We should provide minimum and maximum expected length\n // and try to adjust the read pixels, e.g. remove single pixel errors or try to cut off exceeding pixels.\n // min and maxCodewordWidth should not be used as they are calculated for the whole barcode an can be inaccurate\n // for the current position\n let moduleBitCount = PDF417ScanningDecoder.getModuleBitCount(image, minColumn, maxColumn, leftToRight, startColumn, imageRow);\n if (moduleBitCount == null) {\n return null;\n }\n let endColumn;\n let codewordBitCount = MathUtils.sum(moduleBitCount);\n if (leftToRight) {\n endColumn = startColumn + codewordBitCount;\n }\n else {\n for (let i /*int*/ = 0; i < moduleBitCount.length / 2; i++) {\n let tmpCount = moduleBitCount[i];\n moduleBitCount[i] = moduleBitCount[moduleBitCount.length - 1 - i];\n moduleBitCount[moduleBitCount.length - 1 - i] = tmpCount;\n }\n endColumn = startColumn;\n startColumn = endColumn - codewordBitCount;\n }\n // TODO implement check for width and correction of black and white bars\n // use start (and maybe stop pattern) to determine if black bars are wider than white bars. If so, adjust.\n // should probably done only for codewords with a lot more than 17 bits.\n // The following fixes 10-1.png, which has wide black bars and small white bars\n // for (let i /*int*/ = 0; i < moduleBitCount.length; i++) {\n // if (i % 2 === 0) {\n // moduleBitCount[i]--;\n // } else {\n // moduleBitCount[i]++;\n // }\n // }\n // We could also use the width of surrounding codewords for more accurate results, but this seems\n // sufficient for now\n if (!PDF417ScanningDecoder.checkCodewordSkew(codewordBitCount, minCodewordWidth, maxCodewordWidth)) {\n // We could try to use the startX and endX position of the codeword in the same column in the previous row,\n // create the bit count from it and normalize it to 8. This would help with single pixel errors.\n return null;\n }\n let decodedValue = PDF417CodewordDecoder.getDecodedValue(moduleBitCount);\n let codeword = PDF417Common.getCodeword(decodedValue);\n if (codeword === -1) {\n return null;\n }\n return new Codeword(startColumn, endColumn, PDF417ScanningDecoder.getCodewordBucketNumber(decodedValue), codeword);\n }\n static getModuleBitCount(image, minColumn, maxColumn, leftToRight, startColumn, imageRow) {\n let imageColumn = startColumn;\n let moduleBitCount = new Int32Array(8);\n let moduleNumber = 0;\n let increment = leftToRight ? 1 : -1;\n let previousPixelValue = leftToRight;\n while ((leftToRight ? imageColumn < maxColumn : imageColumn >= minColumn) &&\n moduleNumber < moduleBitCount.length) {\n if (image.get(imageColumn, imageRow) === previousPixelValue) {\n moduleBitCount[moduleNumber]++;\n imageColumn += increment;\n }\n else {\n moduleNumber++;\n previousPixelValue = !previousPixelValue;\n }\n }\n if (moduleNumber === moduleBitCount.length ||\n ((imageColumn === (leftToRight ? maxColumn : minColumn)) &&\n moduleNumber === moduleBitCount.length - 1)) {\n return moduleBitCount;\n }\n return null;\n }\n static getNumberOfECCodeWords(barcodeECLevel) {\n return 2 << barcodeECLevel;\n }\n static adjustCodewordStartColumn(image, minColumn, maxColumn, leftToRight, codewordStartColumn, imageRow) {\n let correctedStartColumn = codewordStartColumn;\n let increment = leftToRight ? -1 : 1;\n // there should be no black pixels before the start column. If there are, then we need to start earlier.\n for (let i /*int*/ = 0; i < 2; i++) {\n while ((leftToRight ? correctedStartColumn >= minColumn : correctedStartColumn < maxColumn) &&\n leftToRight === image.get(correctedStartColumn, imageRow)) {\n if (Math.abs(codewordStartColumn - correctedStartColumn) > PDF417ScanningDecoder.CODEWORD_SKEW_SIZE) {\n return codewordStartColumn;\n }\n correctedStartColumn += increment;\n }\n increment = -increment;\n leftToRight = !leftToRight;\n }\n return correctedStartColumn;\n }\n static checkCodewordSkew(codewordSize, minCodewordWidth, maxCodewordWidth) {\n return minCodewordWidth - PDF417ScanningDecoder.CODEWORD_SKEW_SIZE <= codewordSize &&\n codewordSize <= maxCodewordWidth + PDF417ScanningDecoder.CODEWORD_SKEW_SIZE;\n }\n /**\n * @throws FormatException,\n * @throws ChecksumException\n */\n static decodeCodewords(codewords, ecLevel, erasures) {\n if (codewords.length === 0) {\n throw FormatException.getFormatInstance();\n }\n let numECCodewords = 1 << (ecLevel + 1);\n let correctedErrorsCount = PDF417ScanningDecoder.correctErrors(codewords, erasures, numECCodewords);\n PDF417ScanningDecoder.verifyCodewordCount(codewords, numECCodewords);\n // Decode the codewords\n let decoderResult = DecodedBitStreamParser$2.decode(codewords, '' + ecLevel);\n decoderResult.setErrorsCorrected(correctedErrorsCount);\n decoderResult.setErasures(erasures.length);\n return decoderResult;\n }\n /**\n *

    Given data and error-correction codewords received, possibly corrupted by errors, attempts to\n * correct the errors in-place.

    \n *\n * @param codewords data and error correction codewords\n * @param erasures positions of any known erasures\n * @param numECCodewords number of error correction codewords that are available in codewords\n * @throws ChecksumException if error correction fails\n */\n static correctErrors(codewords, erasures, numECCodewords) {\n if (erasures != null &&\n erasures.length > numECCodewords / 2 + PDF417ScanningDecoder.MAX_ERRORS ||\n numECCodewords < 0 ||\n numECCodewords > PDF417ScanningDecoder.MAX_EC_CODEWORDS) {\n // Too many errors or EC Codewords is corrupted\n throw ChecksumException.getChecksumInstance();\n }\n return PDF417ScanningDecoder.errorCorrection.decode(codewords, numECCodewords, erasures);\n }\n /**\n * Verify that all is OK with the codeword array.\n * @throws FormatException\n */\n static verifyCodewordCount(codewords, numECCodewords) {\n if (codewords.length < 4) {\n // Codeword array size should be at least 4 allowing for\n // Count CW, At least one Data CW, Error Correction CW, Error Correction CW\n throw FormatException.getFormatInstance();\n }\n // The first codeword, the Symbol Length Descriptor, shall always encode the total number of data\n // codewords in the symbol, including the Symbol Length Descriptor itself, data codewords and pad\n // codewords, but excluding the number of error correction codewords.\n let numberOfCodewords = codewords[0];\n if (numberOfCodewords > codewords.length) {\n throw FormatException.getFormatInstance();\n }\n if (numberOfCodewords === 0) {\n // Reset to the length of the array - 8 (Allow for at least level 3 Error Correction (8 Error Codewords)\n if (numECCodewords < codewords.length) {\n codewords[0] = codewords.length - numECCodewords;\n }\n else {\n throw FormatException.getFormatInstance();\n }\n }\n }\n static getBitCountForCodeword(codeword) {\n let result = new Int32Array(8);\n let previousValue = 0;\n let i = result.length - 1;\n while (true) {\n if ((codeword & 0x1) !== previousValue) {\n previousValue = codeword & 0x1;\n i--;\n if (i < 0) {\n break;\n }\n }\n result[i]++;\n codeword >>= 1;\n }\n return result;\n }\n static getCodewordBucketNumber(codeword) {\n if (codeword instanceof Int32Array) {\n return this.getCodewordBucketNumber_Int32Array(codeword);\n }\n return this.getCodewordBucketNumber_number(codeword);\n }\n static getCodewordBucketNumber_number(codeword) {\n return PDF417ScanningDecoder.getCodewordBucketNumber(PDF417ScanningDecoder.getBitCountForCodeword(codeword));\n }\n static getCodewordBucketNumber_Int32Array(moduleBitCount) {\n return (moduleBitCount[0] - moduleBitCount[2] + moduleBitCount[4] - moduleBitCount[6] + 9) % 9;\n }\n static toString(barcodeMatrix) {\n let formatter = new Formatter();\n // try (let formatter = new Formatter()) {\n for (let row /*int*/ = 0; row < barcodeMatrix.length; row++) {\n formatter.format('Row %2d: ', row);\n for (let column /*int*/ = 0; column < barcodeMatrix[row].length; column++) {\n let barcodeValue = barcodeMatrix[row][column];\n if (barcodeValue.getValue().length === 0) {\n formatter.format(' ', null);\n }\n else {\n formatter.format('%4d(%2d)', barcodeValue.getValue()[0], barcodeValue.getConfidence(barcodeValue.getValue()[0]));\n }\n }\n formatter.format('%n');\n }\n return formatter.toString();\n // }\n }\n }\n /*final*/ PDF417ScanningDecoder.CODEWORD_SKEW_SIZE = 2;\n /*final*/ PDF417ScanningDecoder.MAX_ERRORS = 3;\n /*final*/ PDF417ScanningDecoder.MAX_EC_CODEWORDS = 512;\n /*final*/ PDF417ScanningDecoder.errorCorrection = new ErrorCorrection();\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // import java.util.ArrayList;\n // import java.util.List;\n // import java.util.Map;\n /**\n * This implementation can detect and decode PDF417 codes in an image.\n *\n * @author Guenther Grau\n */\n /*public final*/ class PDF417Reader {\n // private static /*final Result[]*/ EMPTY_RESULT_ARRAY: Result[] = new Result([0]);\n /**\n * Locates and decodes a PDF417 code in an image.\n *\n * @return a String representing the content encoded by the PDF417 code\n * @throws NotFoundException if a PDF417 code cannot be found,\n * @throws FormatException if a PDF417 cannot be decoded\n * @throws ChecksumException\n */\n // @Override\n decode(image, hints = null) {\n let result = PDF417Reader.decode(image, hints, false);\n if (result == null || result.length === 0 || result[0] == null) {\n throw NotFoundException.getNotFoundInstance();\n }\n return result[0];\n }\n /**\n *\n * @param BinaryBitmap\n * @param image\n * @throws NotFoundException\n */\n // @Override\n decodeMultiple(image, hints = null) {\n try {\n return PDF417Reader.decode(image, hints, true);\n }\n catch (ignored) {\n if (ignored instanceof FormatException || ignored instanceof ChecksumException) {\n throw NotFoundException.getNotFoundInstance();\n }\n throw ignored;\n }\n }\n /**\n *\n * @param image\n * @param hints\n * @param multiple\n *\n * @throws NotFoundException\n * @throws FormatExceptionß\n * @throws ChecksumException\n */\n static decode(image, hints, multiple) {\n const results = new Array();\n const detectorResult = Detector$3.detectMultiple(image, hints, multiple);\n for (const points of detectorResult.getPoints()) {\n const decoderResult = PDF417ScanningDecoder.decode(detectorResult.getBits(), points[4], points[5], points[6], points[7], PDF417Reader.getMinCodewordWidth(points), PDF417Reader.getMaxCodewordWidth(points));\n const result = new Result(decoderResult.getText(), decoderResult.getRawBytes(), undefined, points, BarcodeFormat$1.PDF_417);\n result.putMetadata(ResultMetadataType$1.ERROR_CORRECTION_LEVEL, decoderResult.getECLevel());\n const pdf417ResultMetadata = decoderResult.getOther();\n if (pdf417ResultMetadata != null) {\n result.putMetadata(ResultMetadataType$1.PDF417_EXTRA_METADATA, pdf417ResultMetadata);\n }\n results.push(result);\n }\n return results.map(x => x);\n }\n static getMaxWidth(p1, p2) {\n if (p1 == null || p2 == null) {\n return 0;\n }\n return Math.trunc(Math.abs(p1.getX() - p2.getX()));\n }\n static getMinWidth(p1, p2) {\n if (p1 == null || p2 == null) {\n return Integer.MAX_VALUE;\n }\n return Math.trunc(Math.abs(p1.getX() - p2.getX()));\n }\n static getMaxCodewordWidth(p) {\n return Math.floor(Math.max(Math.max(PDF417Reader.getMaxWidth(p[0], p[4]), PDF417Reader.getMaxWidth(p[6], p[2]) * PDF417Common.MODULES_IN_CODEWORD /\n PDF417Common.MODULES_IN_STOP_PATTERN), Math.max(PDF417Reader.getMaxWidth(p[1], p[5]), PDF417Reader.getMaxWidth(p[7], p[3]) * PDF417Common.MODULES_IN_CODEWORD /\n PDF417Common.MODULES_IN_STOP_PATTERN)));\n }\n static getMinCodewordWidth(p) {\n return Math.floor(Math.min(Math.min(PDF417Reader.getMinWidth(p[0], p[4]), PDF417Reader.getMinWidth(p[6], p[2]) * PDF417Common.MODULES_IN_CODEWORD /\n PDF417Common.MODULES_IN_STOP_PATTERN), Math.min(PDF417Reader.getMinWidth(p[1], p[5]), PDF417Reader.getMinWidth(p[7], p[3]) * PDF417Common.MODULES_IN_CODEWORD /\n PDF417Common.MODULES_IN_STOP_PATTERN)));\n }\n // @Override\n reset() {\n // nothing needs to be reset\n }\n }\n\n /**\n * Custom Error class of type Exception.\n */\n class ReaderException extends Exception {\n }\n ReaderException.kind = 'ReaderException';\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing {*/\n /**\n * MultiFormatReader is a convenience class and the main entry point into the library for most uses.\n * By default it attempts to decode all barcode formats that the library supports. Optionally, you\n * can provide a hints object to request different behavior, for example only decoding QR codes.\n *\n * @author Sean Owen\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class MultiFormatReader {\n /**\n * Creates an instance of this class\n * \n * @param {Boolean} verbose if 'true' logs will be dumped to console, otherwise hidden.\n * @param hints The hints to use, clearing the previous state.\n */\n constructor(verbose, hints) {\n this.verbose = (verbose === true);\n if (hints) {\n this.setHints(hints);\n }\n }\n /**\n * This version of decode honors the intent of Reader.decode(BinaryBitmap) in that it\n * passes null as a hint to the decoders. However, that makes it inefficient to call repeatedly.\n * Use setHints() followed by decodeWithState() for continuous scan applications.\n *\n * @param image The pixel data to decode\n * @return The contents of the image\n *\n * @throws NotFoundException Any errors which occurred\n */\n /*@Override*/\n // public decode(image: BinaryBitmap): Result {\n // setHints(null)\n // return decodeInternal(image)\n // }\n /**\n * Decode an image using the hints provided. Does not honor existing state.\n *\n * @param image The pixel data to decode\n * @param hints The hints to use, clearing the previous state.\n * @return The contents of the image\n *\n * @throws NotFoundException Any errors which occurred\n */\n /*@Override*/\n decode(image, hints) {\n if (hints) {\n this.setHints(hints);\n }\n return this.decodeInternal(image);\n }\n /**\n * Decode an image using the state set up by calling setHints() previously. Continuous scan\n * clients will get a large speed increase by using this instead of decode().\n *\n * @param image The pixel data to decode\n * @return The contents of the image\n *\n * @throws NotFoundException Any errors which occurred\n */\n decodeWithState(image) {\n // Make sure to set up the default state so we don't crash\n if (this.readers === null || this.readers === undefined) {\n this.setHints(null);\n }\n return this.decodeInternal(image);\n }\n /**\n * This method adds state to the MultiFormatReader. By setting the hints once, subsequent calls\n * to decodeWithState(image) can reuse the same set of readers without reallocating memory. This\n * is important for performance in continuous scan clients.\n *\n * @param hints The set of hints to use for subsequent calls to decode(image)\n */\n setHints(hints) {\n this.hints = hints;\n const tryHarder = hints !== null && hints !== undefined && undefined !== hints.get(DecodeHintType$1.TRY_HARDER);\n /*@SuppressWarnings(\"unchecked\")*/\n const formats = hints === null || hints === undefined ? null : hints.get(DecodeHintType$1.POSSIBLE_FORMATS);\n const readers = new Array();\n if (formats !== null && formats !== undefined) {\n const addOneDReader = formats.some(f => f === BarcodeFormat$1.UPC_A ||\n f === BarcodeFormat$1.UPC_E ||\n f === BarcodeFormat$1.EAN_13 ||\n f === BarcodeFormat$1.EAN_8 ||\n f === BarcodeFormat$1.CODABAR ||\n f === BarcodeFormat$1.CODE_39 ||\n f === BarcodeFormat$1.CODE_93 ||\n f === BarcodeFormat$1.CODE_128 ||\n f === BarcodeFormat$1.ITF ||\n f === BarcodeFormat$1.RSS_14 ||\n f === BarcodeFormat$1.RSS_EXPANDED);\n // Put 1D readers upfront in \"normal\" mode\n // TYPESCRIPTPORT: TODO: uncomment below as they are ported\n if (addOneDReader && !tryHarder) {\n readers.push(new MultiFormatOneDReader(hints, this.verbose));\n }\n if (formats.includes(BarcodeFormat$1.QR_CODE)) {\n readers.push(new QRCodeReader());\n }\n if (formats.includes(BarcodeFormat$1.DATA_MATRIX)) {\n readers.push(new DataMatrixReader());\n }\n if (formats.includes(BarcodeFormat$1.AZTEC)) {\n readers.push(new AztecReader());\n }\n if (formats.includes(BarcodeFormat$1.PDF_417)) {\n readers.push(new PDF417Reader());\n }\n // if (formats.includes(BarcodeFormat.MAXICODE)) {\n // readers.push(new MaxiCodeReader())\n // }\n // At end in \"try harder\" mode\n if (addOneDReader && tryHarder) {\n readers.push(new MultiFormatOneDReader(hints, this.verbose));\n }\n }\n if (readers.length === 0) {\n if (!tryHarder) {\n readers.push(new MultiFormatOneDReader(hints, this.verbose));\n }\n readers.push(new QRCodeReader());\n readers.push(new DataMatrixReader());\n readers.push(new AztecReader());\n readers.push(new PDF417Reader());\n // readers.push(new MaxiCodeReader())\n if (tryHarder) {\n readers.push(new MultiFormatOneDReader(hints, this.verbose));\n }\n }\n this.readers = readers; // .toArray(new Reader[readers.size()])\n }\n /*@Override*/\n reset() {\n if (this.readers !== null) {\n for (const reader of this.readers) {\n reader.reset();\n }\n }\n }\n /**\n * @throws NotFoundException\n */\n decodeInternal(image) {\n if (this.readers === null) {\n throw new ReaderException('No readers where selected, nothing can be read.');\n }\n for (const reader of this.readers) {\n // Trying to decode with ${reader} reader.\n try {\n return reader.decode(image, this.hints);\n }\n catch (ex) {\n if (ex instanceof ReaderException) {\n continue;\n }\n // Bad Exception.\n }\n }\n throw new NotFoundException('No MultiFormat Readers were able to detect the code.');\n }\n }\n\n class BrowserMultiFormatReader extends BrowserCodeReader {\n constructor(hints = null, timeBetweenScansMillis = 500) {\n const reader = new MultiFormatReader();\n reader.setHints(hints);\n super(reader, timeBetweenScansMillis);\n }\n /**\n * Overwrite decodeBitmap to call decodeWithState, which will pay\n * attention to the hints set in the constructor function\n */\n decodeBitmap(binaryBitmap) {\n return this.reader.decodeWithState(binaryBitmap);\n }\n }\n\n /**\n * @deprecated Moving to @zxing/browser\n *\n * QR Code reader to use from browser.\n */\n class BrowserPDF417Reader extends BrowserCodeReader {\n /**\n * Creates an instance of BrowserPDF417Reader.\n * @param {number} [timeBetweenScansMillis=500] the time delay between subsequent decode tries\n */\n constructor(timeBetweenScansMillis = 500) {\n super(new PDF417Reader(), timeBetweenScansMillis);\n }\n }\n\n /**\n * @deprecated Moving to @zxing/browser\n *\n * QR Code reader to use from browser.\n */\n class BrowserQRCodeReader extends BrowserCodeReader {\n /**\n * Creates an instance of BrowserQRCodeReader.\n * @param {number} [timeBetweenScansMillis=500] the time delay between subsequent decode tries\n */\n constructor(timeBetweenScansMillis = 500) {\n super(new QRCodeReader(), timeBetweenScansMillis);\n }\n }\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing {*/\n /**\n * These are a set of hints that you may pass to Writers to specify their behavior.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n var EncodeHintType;\n (function (EncodeHintType) {\n /**\n * Specifies what degree of error correction to use, for example in QR Codes.\n * Type depends on the encoder. For example for QR codes it's type\n * {@link com.google.zxing.qrcode.decoder.ErrorCorrectionLevel ErrorCorrectionLevel}.\n * For Aztec it is of type {@link Integer}, representing the minimal percentage of error correction words.\n * For PDF417 it is of type {@link Integer}, valid values being 0 to 8.\n * In all cases, it can also be a {@link String} representation of the desired value as well.\n * Note: an Aztec symbol should have a minimum of 25% EC words.\n */\n EncodeHintType[EncodeHintType[\"ERROR_CORRECTION\"] = 0] = \"ERROR_CORRECTION\";\n /**\n * Specifies what character encoding to use where applicable (type {@link String})\n */\n EncodeHintType[EncodeHintType[\"CHARACTER_SET\"] = 1] = \"CHARACTER_SET\";\n /**\n * Specifies the matrix shape for Data Matrix (type {@link com.google.zxing.datamatrix.encoder.SymbolShapeHint})\n */\n EncodeHintType[EncodeHintType[\"DATA_MATRIX_SHAPE\"] = 2] = \"DATA_MATRIX_SHAPE\";\n /**\n * Specifies a minimum barcode size (type {@link Dimension}). Only applicable to Data Matrix now.\n *\n * @deprecated use width/height params in\n * {@link com.google.zxing.datamatrix.DataMatrixWriter#encode(String, BarcodeFormat, int, int)}\n */\n /*@Deprecated*/\n EncodeHintType[EncodeHintType[\"MIN_SIZE\"] = 3] = \"MIN_SIZE\";\n /**\n * Specifies a maximum barcode size (type {@link Dimension}). Only applicable to Data Matrix now.\n *\n * @deprecated without replacement\n */\n /*@Deprecated*/\n EncodeHintType[EncodeHintType[\"MAX_SIZE\"] = 4] = \"MAX_SIZE\";\n /**\n * Specifies margin, in pixels, to use when generating the barcode. The meaning can vary\n * by format; for example it controls margin before and after the barcode horizontally for\n * most 1D formats. (Type {@link Integer}, or {@link String} representation of the integer value).\n */\n EncodeHintType[EncodeHintType[\"MARGIN\"] = 5] = \"MARGIN\";\n /**\n * Specifies whether to use compact mode for PDF417 (type {@link Boolean}, or \"true\" or \"false\"\n * {@link String} value).\n */\n EncodeHintType[EncodeHintType[\"PDF417_COMPACT\"] = 6] = \"PDF417_COMPACT\";\n /**\n * Specifies what compaction mode to use for PDF417 (type\n * {@link com.google.zxing.pdf417.encoder.Compaction Compaction} or {@link String} value of one of its\n * enum values).\n */\n EncodeHintType[EncodeHintType[\"PDF417_COMPACTION\"] = 7] = \"PDF417_COMPACTION\";\n /**\n * Specifies the minimum and maximum number of rows and columns for PDF417 (type\n * {@link com.google.zxing.pdf417.encoder.Dimensions Dimensions}).\n */\n EncodeHintType[EncodeHintType[\"PDF417_DIMENSIONS\"] = 8] = \"PDF417_DIMENSIONS\";\n /**\n * Specifies the required number of layers for an Aztec code.\n * A negative number (-1, -2, -3, -4) specifies a compact Aztec code.\n * 0 indicates to use the minimum number of layers (the default).\n * A positive number (1, 2, .. 32) specifies a normal (non-compact) Aztec code.\n * (Type {@link Integer}, or {@link String} representation of the integer value).\n */\n EncodeHintType[EncodeHintType[\"AZTEC_LAYERS\"] = 9] = \"AZTEC_LAYERS\";\n /**\n * Specifies the exact version of QR code to be encoded.\n * (Type {@link Integer}, or {@link String} representation of the integer value).\n */\n EncodeHintType[EncodeHintType[\"QR_VERSION\"] = 10] = \"QR_VERSION\";\n })(EncodeHintType || (EncodeHintType = {}));\n var EncodeHintType$1 = EncodeHintType;\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n *

    Implements Reed-Solomon encoding, as the name implies.

    \n *\n * @author Sean Owen\n * @author William Rucklidge\n */\n class ReedSolomonEncoder {\n /**\n * A reed solomon error-correcting encoding constructor is created by\n * passing as Galois Field with of size equal to the number of code\n * words (symbols) in the alphabet (the number of values in each\n * element of arrays that are encoded/decoded).\n * @param field A galois field with a number of elements equal to the size\n * of the alphabet of symbols to encode.\n */\n constructor(field) {\n this.field = field;\n this.cachedGenerators = [];\n this.cachedGenerators.push(new GenericGFPoly(field, Int32Array.from([1])));\n }\n buildGenerator(degree /*int*/) {\n const cachedGenerators = this.cachedGenerators;\n if (degree >= cachedGenerators.length) {\n let lastGenerator = cachedGenerators[cachedGenerators.length - 1];\n const field = this.field;\n for (let d = cachedGenerators.length; d <= degree; d++) {\n const nextGenerator = lastGenerator.multiply(new GenericGFPoly(field, Int32Array.from([1, field.exp(d - 1 + field.getGeneratorBase())])));\n cachedGenerators.push(nextGenerator);\n lastGenerator = nextGenerator;\n }\n }\n return cachedGenerators[degree];\n }\n /**\n *

    Encode a sequence of code words (symbols) using Reed-Solomon to allow decoders\n * to detect and correct errors that may have been introduced when the resulting\n * data is stored or transmitted.

    \n *\n * @param toEncode array used for both and output. Caller initializes the array with\n * the code words (symbols) to be encoded followed by empty elements allocated to make\n * space for error-correction code words in the encoded output. The array contains\n * the encdoded output when encode returns. Code words are encoded as numbers from\n * 0 to n-1, where n is the number of possible code words (symbols), as determined\n * by the size of the Galois Field passed in the constructor of this object.\n * @param ecBytes the number of elements reserved in the array (first parameter)\n * to store error-correction code words. Thus, the number of code words (symbols)\n * to encode in the first parameter is thus toEncode.length - ecBytes.\n * Note, the use of \"bytes\" in the name of this parameter is misleading, as there may\n * be more or fewer than 256 symbols being encoded, as determined by the number of\n * elements in the Galois Field passed as a constructor to this object.\n * @throws IllegalArgumentException thrown in response to validation errros.\n */\n encode(toEncode, ecBytes /*int*/) {\n if (ecBytes === 0) {\n throw new IllegalArgumentException('No error correction bytes');\n }\n const dataBytes = toEncode.length - ecBytes;\n if (dataBytes <= 0) {\n throw new IllegalArgumentException('No data bytes provided');\n }\n const generator = this.buildGenerator(ecBytes);\n const infoCoefficients = new Int32Array(dataBytes);\n System.arraycopy(toEncode, 0, infoCoefficients, 0, dataBytes);\n let info = new GenericGFPoly(this.field, infoCoefficients);\n info = info.multiplyByMonomial(ecBytes, 1);\n const remainder = info.divide(generator)[1];\n const coefficients = remainder.getCoefficients();\n const numZeroCoefficients = ecBytes - coefficients.length;\n for (let i = 0; i < numZeroCoefficients; i++) {\n toEncode[dataBytes + i] = 0;\n }\n System.arraycopy(coefficients, 0, toEncode, dataBytes + numZeroCoefficients, coefficients.length);\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author Satoru Takabayashi\n * @author Daniel Switkin\n * @author Sean Owen\n */\n class MaskUtil {\n constructor() {\n // do nothing\n }\n /**\n * Apply mask penalty rule 1 and return the penalty. Find repetitive cells with the same color and\n * give penalty to them. Example: 00000 or 11111.\n */\n static applyMaskPenaltyRule1(matrix) {\n return MaskUtil.applyMaskPenaltyRule1Internal(matrix, true) + MaskUtil.applyMaskPenaltyRule1Internal(matrix, false);\n }\n /**\n * Apply mask penalty rule 2 and return the penalty. Find 2x2 blocks with the same color and give\n * penalty to them. This is actually equivalent to the spec's rule, which is to find MxN blocks and give a\n * penalty proportional to (M-1)x(N-1), because this is the number of 2x2 blocks inside such a block.\n */\n static applyMaskPenaltyRule2(matrix) {\n let penalty = 0;\n const array = matrix.getArray();\n const width = matrix.getWidth();\n const height = matrix.getHeight();\n for (let y = 0; y < height - 1; y++) {\n const arrayY = array[y];\n for (let x = 0; x < width - 1; x++) {\n const value = arrayY[x];\n if (value === arrayY[x + 1] && value === array[y + 1][x] && value === array[y + 1][x + 1]) {\n penalty++;\n }\n }\n }\n return MaskUtil.N2 * penalty;\n }\n /**\n * Apply mask penalty rule 3 and return the penalty. Find consecutive runs of 1:1:3:1:1:4\n * starting with black, or 4:1:1:3:1:1 starting with white, and give penalty to them. If we\n * find patterns like 000010111010000, we give penalty once.\n */\n static applyMaskPenaltyRule3(matrix) {\n let numPenalties = 0;\n const array = matrix.getArray();\n const width = matrix.getWidth();\n const height = matrix.getHeight();\n for (let y = 0; y < height; y++) {\n for (let x = 0; x < width; x++) {\n const arrayY = array[y]; // We can at least optimize this access\n if (x + 6 < width &&\n arrayY[x] === 1 &&\n arrayY[x + 1] === 0 &&\n arrayY[x + 2] === 1 &&\n arrayY[x + 3] === 1 &&\n arrayY[x + 4] === 1 &&\n arrayY[x + 5] === 0 &&\n arrayY[x + 6] === 1 &&\n (MaskUtil.isWhiteHorizontal(arrayY, x - 4, x) || MaskUtil.isWhiteHorizontal(arrayY, x + 7, x + 11))) {\n numPenalties++;\n }\n if (y + 6 < height &&\n array[y][x] === 1 &&\n array[y + 1][x] === 0 &&\n array[y + 2][x] === 1 &&\n array[y + 3][x] === 1 &&\n array[y + 4][x] === 1 &&\n array[y + 5][x] === 0 &&\n array[y + 6][x] === 1 &&\n (MaskUtil.isWhiteVertical(array, x, y - 4, y) || MaskUtil.isWhiteVertical(array, x, y + 7, y + 11))) {\n numPenalties++;\n }\n }\n }\n return numPenalties * MaskUtil.N3;\n }\n static isWhiteHorizontal(rowArray, from /*int*/, to /*int*/) {\n from = Math.max(from, 0);\n to = Math.min(to, rowArray.length);\n for (let i = from; i < to; i++) {\n if (rowArray[i] === 1) {\n return false;\n }\n }\n return true;\n }\n static isWhiteVertical(array, col /*int*/, from /*int*/, to /*int*/) {\n from = Math.max(from, 0);\n to = Math.min(to, array.length);\n for (let i = from; i < to; i++) {\n if (array[i][col] === 1) {\n return false;\n }\n }\n return true;\n }\n /**\n * Apply mask penalty rule 4 and return the penalty. Calculate the ratio of dark cells and give\n * penalty if the ratio is far from 50%. It gives 10 penalty for 5% distance.\n */\n static applyMaskPenaltyRule4(matrix) {\n let numDarkCells = 0;\n const array = matrix.getArray();\n const width = matrix.getWidth();\n const height = matrix.getHeight();\n for (let y = 0; y < height; y++) {\n const arrayY = array[y];\n for (let x = 0; x < width; x++) {\n if (arrayY[x] === 1) {\n numDarkCells++;\n }\n }\n }\n const numTotalCells = matrix.getHeight() * matrix.getWidth();\n const fivePercentVariances = Math.floor(Math.abs(numDarkCells * 2 - numTotalCells) * 10 / numTotalCells);\n return fivePercentVariances * MaskUtil.N4;\n }\n /**\n * Return the mask bit for \"getMaskPattern\" at \"x\" and \"y\". See 8.8 of JISX0510:2004 for mask\n * pattern conditions.\n */\n static getDataMaskBit(maskPattern /*int*/, x /*int*/, y /*int*/) {\n let intermediate; /*int*/\n let temp; /*int*/\n switch (maskPattern) {\n case 0:\n intermediate = (y + x) & 0x1;\n break;\n case 1:\n intermediate = y & 0x1;\n break;\n case 2:\n intermediate = x % 3;\n break;\n case 3:\n intermediate = (y + x) % 3;\n break;\n case 4:\n intermediate = (Math.floor(y / 2) + Math.floor(x / 3)) & 0x1;\n break;\n case 5:\n temp = y * x;\n intermediate = (temp & 0x1) + (temp % 3);\n break;\n case 6:\n temp = y * x;\n intermediate = ((temp & 0x1) + (temp % 3)) & 0x1;\n break;\n case 7:\n temp = y * x;\n intermediate = ((temp % 3) + ((y + x) & 0x1)) & 0x1;\n break;\n default:\n throw new IllegalArgumentException('Invalid mask pattern: ' + maskPattern);\n }\n return intermediate === 0;\n }\n /**\n * Helper function for applyMaskPenaltyRule1. We need this for doing this calculation in both\n * vertical and horizontal orders respectively.\n */\n static applyMaskPenaltyRule1Internal(matrix, isHorizontal) {\n let penalty = 0;\n const iLimit = isHorizontal ? matrix.getHeight() : matrix.getWidth();\n const jLimit = isHorizontal ? matrix.getWidth() : matrix.getHeight();\n const array = matrix.getArray();\n for (let i = 0; i < iLimit; i++) {\n let numSameBitCells = 0;\n let prevBit = -1;\n for (let j = 0; j < jLimit; j++) {\n const bit = isHorizontal ? array[i][j] : array[j][i];\n if (bit === prevBit) {\n numSameBitCells++;\n }\n else {\n if (numSameBitCells >= 5) {\n penalty += MaskUtil.N1 + (numSameBitCells - 5);\n }\n numSameBitCells = 1; // Include the cell itself.\n prevBit = bit;\n }\n }\n if (numSameBitCells >= 5) {\n penalty += MaskUtil.N1 + (numSameBitCells - 5);\n }\n }\n return penalty;\n }\n }\n // Penalty weights from section 6.8.2.1\n MaskUtil.N1 = 3;\n MaskUtil.N2 = 3;\n MaskUtil.N3 = 40;\n MaskUtil.N4 = 10;\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * JAVAPORT: The original code was a 2D array of ints, but since it only ever gets assigned\n * -1, 0, and 1, I'm going to use less memory and go with bytes.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class ByteMatrix {\n constructor(width /*int*/, height /*int*/) {\n this.width = width;\n this.height = height;\n const bytes = new Array(height); // [height][width]\n for (let i = 0; i !== height; i++) {\n bytes[i] = new Uint8Array(width);\n }\n this.bytes = bytes;\n }\n getHeight() {\n return this.height;\n }\n getWidth() {\n return this.width;\n }\n get(x /*int*/, y /*int*/) {\n return this.bytes[y][x];\n }\n /**\n * @return an internal representation as bytes, in row-major order. array[y][x] represents point (x,y)\n */\n getArray() {\n return this.bytes;\n }\n // TYPESCRIPTPORT: preffer to let two methods instead of override to avoid type comparison inside\n setNumber(x /*int*/, y /*int*/, value /*byte|int*/) {\n this.bytes[y][x] = value;\n }\n // public set(x: number /*int*/, y: number /*int*/, value: number /*int*/): void {\n // bytes[y][x] = (byte) value\n // }\n setBoolean(x /*int*/, y /*int*/, value) {\n this.bytes[y][x] = /*(byte) */ (value ? 1 : 0);\n }\n clear(value /*byte*/) {\n for (const aByte of this.bytes) {\n Arrays.fill(aByte, value);\n }\n }\n equals(o) {\n if (!(o instanceof ByteMatrix)) {\n return false;\n }\n const other = o;\n if (this.width !== other.width) {\n return false;\n }\n if (this.height !== other.height) {\n return false;\n }\n for (let y = 0, height = this.height; y < height; ++y) {\n const bytesY = this.bytes[y];\n const otherBytesY = other.bytes[y];\n for (let x = 0, width = this.width; x < width; ++x) {\n if (bytesY[x] !== otherBytesY[x]) {\n return false;\n }\n }\n }\n return true;\n }\n /*@Override*/\n toString() {\n const result = new StringBuilder(); // (2 * width * height + 2)\n for (let y = 0, height = this.height; y < height; ++y) {\n const bytesY = this.bytes[y];\n for (let x = 0, width = this.width; x < width; ++x) {\n switch (bytesY[x]) {\n case 0:\n result.append(' 0');\n break;\n case 1:\n result.append(' 1');\n break;\n default:\n result.append(' ');\n break;\n }\n }\n result.append('\\n');\n }\n return result.toString();\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author satorux@google.com (Satoru Takabayashi) - creator\n * @author dswitkin@google.com (Daniel Switkin) - ported from C++\n */\n class QRCode {\n constructor() {\n this.maskPattern = -1;\n }\n getMode() {\n return this.mode;\n }\n getECLevel() {\n return this.ecLevel;\n }\n getVersion() {\n return this.version;\n }\n getMaskPattern() {\n return this.maskPattern;\n }\n getMatrix() {\n return this.matrix;\n }\n /*@Override*/\n toString() {\n const result = new StringBuilder(); // (200)\n result.append('<<\\n');\n result.append(' mode: ');\n result.append(this.mode ? this.mode.toString() : 'null');\n result.append('\\n ecLevel: ');\n result.append(this.ecLevel ? this.ecLevel.toString() : 'null');\n result.append('\\n version: ');\n result.append(this.version ? this.version.toString() : 'null');\n result.append('\\n maskPattern: ');\n result.append(this.maskPattern.toString());\n if (this.matrix) {\n result.append('\\n matrix:\\n');\n result.append(this.matrix.toString());\n }\n else {\n result.append('\\n matrix: null\\n');\n }\n result.append('>>\\n');\n return result.toString();\n }\n setMode(value) {\n this.mode = value;\n }\n setECLevel(value) {\n this.ecLevel = value;\n }\n setVersion(version) {\n this.version = version;\n }\n setMaskPattern(value /*int*/) {\n this.maskPattern = value;\n }\n setMatrix(value) {\n this.matrix = value;\n }\n // Check if \"mask_pattern\" is valid.\n static isValidMaskPattern(maskPattern /*int*/) {\n return maskPattern >= 0 && maskPattern < QRCode.NUM_MASK_PATTERNS;\n }\n }\n QRCode.NUM_MASK_PATTERNS = 8;\n\n /**\n * Custom Error class of type Exception.\n */\n class WriterException extends Exception {\n }\n WriterException.kind = 'WriterException';\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * @author satorux@google.com (Satoru Takabayashi) - creator\n * @author dswitkin@google.com (Daniel Switkin) - ported from C++\n */\n class MatrixUtil {\n constructor() {\n // do nothing\n }\n // Set all cells to -1 (TYPESCRIPTPORT: 255). -1 (TYPESCRIPTPORT: 255) means that the cell is empty (not set yet).\n //\n // JAVAPORT: We shouldn't need to do this at all. The code should be rewritten to begin encoding\n // with the ByteMatrix initialized all to zero.\n static clearMatrix(matrix) {\n // TYPESCRIPTPORT: we use UintArray se changed here from -1 to 255\n matrix.clear(/*(byte) */ /*-1*/ 255);\n }\n // Build 2D matrix of QR Code from \"dataBits\" with \"ecLevel\", \"version\" and \"getMaskPattern\". On\n // success, store the result in \"matrix\" and return true.\n static buildMatrix(dataBits, ecLevel, version, maskPattern /*int*/, matrix) {\n MatrixUtil.clearMatrix(matrix);\n MatrixUtil.embedBasicPatterns(version, matrix);\n // Type information appear with any version.\n MatrixUtil.embedTypeInfo(ecLevel, maskPattern, matrix);\n // Version info appear if version >= 7.\n MatrixUtil.maybeEmbedVersionInfo(version, matrix);\n // Data should be embedded at end.\n MatrixUtil.embedDataBits(dataBits, maskPattern, matrix);\n }\n // Embed basic patterns. On success, modify the matrix and return true.\n // The basic patterns are:\n // - Position detection patterns\n // - Timing patterns\n // - Dark dot at the left bottom corner\n // - Position adjustment patterns, if need be\n static embedBasicPatterns(version, matrix) {\n // Let's get started with embedding big squares at corners.\n MatrixUtil.embedPositionDetectionPatternsAndSeparators(matrix);\n // Then, embed the dark dot at the left bottom corner.\n MatrixUtil.embedDarkDotAtLeftBottomCorner(matrix);\n // Position adjustment patterns appear if version >= 2.\n MatrixUtil.maybeEmbedPositionAdjustmentPatterns(version, matrix);\n // Timing patterns should be embedded after position adj. patterns.\n MatrixUtil.embedTimingPatterns(matrix);\n }\n // Embed type information. On success, modify the matrix.\n static embedTypeInfo(ecLevel, maskPattern /*int*/, matrix) {\n const typeInfoBits = new BitArray();\n MatrixUtil.makeTypeInfoBits(ecLevel, maskPattern, typeInfoBits);\n for (let i = 0, size = typeInfoBits.getSize(); i < size; ++i) {\n // Place bits in LSB to MSB order. LSB (least significant bit) is the last value in\n // \"typeInfoBits\".\n const bit = typeInfoBits.get(typeInfoBits.getSize() - 1 - i);\n // Type info bits at the left top corner. See 8.9 of JISX0510:2004 (p.46).\n const coordinates = MatrixUtil.TYPE_INFO_COORDINATES[i];\n const x1 = coordinates[0];\n const y1 = coordinates[1];\n matrix.setBoolean(x1, y1, bit);\n if (i < 8) {\n // Right top corner.\n const x2 = matrix.getWidth() - i - 1;\n const y2 = 8;\n matrix.setBoolean(x2, y2, bit);\n }\n else {\n // Left bottom corner.\n const x2 = 8;\n const y2 = matrix.getHeight() - 7 + (i - 8);\n matrix.setBoolean(x2, y2, bit);\n }\n }\n }\n // Embed version information if need be. On success, modify the matrix and return true.\n // See 8.10 of JISX0510:2004 (p.47) for how to embed version information.\n static maybeEmbedVersionInfo(version, matrix) {\n if (version.getVersionNumber() < 7) { // Version info is necessary if version >= 7.\n return; // Don't need version info.\n }\n const versionInfoBits = new BitArray();\n MatrixUtil.makeVersionInfoBits(version, versionInfoBits);\n let bitIndex = 6 * 3 - 1; // It will decrease from 17 to 0.\n for (let i = 0; i < 6; ++i) {\n for (let j = 0; j < 3; ++j) {\n // Place bits in LSB (least significant bit) to MSB order.\n const bit = versionInfoBits.get(bitIndex);\n bitIndex--;\n // Left bottom corner.\n matrix.setBoolean(i, matrix.getHeight() - 11 + j, bit);\n // Right bottom corner.\n matrix.setBoolean(matrix.getHeight() - 11 + j, i, bit);\n }\n }\n }\n // Embed \"dataBits\" using \"getMaskPattern\". On success, modify the matrix and return true.\n // For debugging purposes, it skips masking process if \"getMaskPattern\" is -1(TYPESCRIPTPORT: 255).\n // See 8.7 of JISX0510:2004 (p.38) for how to embed data bits.\n static embedDataBits(dataBits, maskPattern /*int*/, matrix) {\n let bitIndex = 0;\n let direction = -1;\n // Start from the right bottom cell.\n let x = matrix.getWidth() - 1;\n let y = matrix.getHeight() - 1;\n while (x > 0) {\n // Skip the vertical timing pattern.\n if (x === 6) {\n x -= 1;\n }\n while (y >= 0 && y < matrix.getHeight()) {\n for (let i = 0; i < 2; ++i) {\n const xx = x - i;\n // Skip the cell if it's not empty.\n if (!MatrixUtil.isEmpty(matrix.get(xx, y))) {\n continue;\n }\n let bit;\n if (bitIndex < dataBits.getSize()) {\n bit = dataBits.get(bitIndex);\n ++bitIndex;\n }\n else {\n // Padding bit. If there is no bit left, we'll fill the left cells with 0, as described\n // in 8.4.9 of JISX0510:2004 (p. 24).\n bit = false;\n }\n // Skip masking if mask_pattern is -1 (TYPESCRIPTPORT: 255).\n if (maskPattern !== 255 && MaskUtil.getDataMaskBit(maskPattern, xx, y)) {\n bit = !bit;\n }\n matrix.setBoolean(xx, y, bit);\n }\n y += direction;\n }\n direction = -direction; // Reverse the direction.\n y += direction;\n x -= 2; // Move to the left.\n }\n // All bits should be consumed.\n if (bitIndex !== dataBits.getSize()) {\n throw new WriterException('Not all bits consumed: ' + bitIndex + '/' + dataBits.getSize());\n }\n }\n // Return the position of the most significant bit set (one: to) in the \"value\". The most\n // significant bit is position 32. If there is no bit set, return 0. Examples:\n // - findMSBSet(0) => 0\n // - findMSBSet(1) => 1\n // - findMSBSet(255) => 8\n static findMSBSet(value /*int*/) {\n return 32 - Integer.numberOfLeadingZeros(value);\n }\n // Calculate BCH (Bose-Chaudhuri-Hocquenghem) code for \"value\" using polynomial \"poly\". The BCH\n // code is used for encoding type information and version information.\n // Example: Calculation of version information of 7.\n // f(x) is created from 7.\n // - 7 = 000111 in 6 bits\n // - f(x) = x^2 + x^1 + x^0\n // g(x) is given by the standard (p. 67)\n // - g(x) = x^12 + x^11 + x^10 + x^9 + x^8 + x^5 + x^2 + 1\n // Multiply f(x) by x^(18 - 6)\n // - f'(x) = f(x) * x^(18 - 6)\n // - f'(x) = x^14 + x^13 + x^12\n // Calculate the remainder of f'(x) / g(x)\n // x^2\n // __________________________________________________\n // g(x) )x^14 + x^13 + x^12\n // x^14 + x^13 + x^12 + x^11 + x^10 + x^7 + x^4 + x^2\n // --------------------------------------------------\n // x^11 + x^10 + x^7 + x^4 + x^2\n //\n // The remainder is x^11 + x^10 + x^7 + x^4 + x^2\n // Encode it in binary: 110010010100\n // The return value is 0xc94 (1100 1001 0100)\n //\n // Since all coefficients in the polynomials are 1 or 0, we can do the calculation by bit\n // operations. We don't care if coefficients are positive or negative.\n static calculateBCHCode(value /*int*/, poly /*int*/) {\n if (poly === 0) {\n throw new IllegalArgumentException('0 polynomial');\n }\n // If poly is \"1 1111 0010 0101\" (version info poly), msbSetInPoly is 13. We'll subtract 1\n // from 13 to make it 12.\n const msbSetInPoly = MatrixUtil.findMSBSet(poly);\n value <<= msbSetInPoly - 1;\n // Do the division business using exclusive-or operations.\n while (MatrixUtil.findMSBSet(value) >= msbSetInPoly) {\n value ^= poly << (MatrixUtil.findMSBSet(value) - msbSetInPoly);\n }\n // Now the \"value\" is the remainder (i.e. the BCH code)\n return value;\n }\n // Make bit vector of type information. On success, store the result in \"bits\" and return true.\n // Encode error correction level and mask pattern. See 8.9 of\n // JISX0510:2004 (p.45) for details.\n static makeTypeInfoBits(ecLevel, maskPattern /*int*/, bits) {\n if (!QRCode.isValidMaskPattern(maskPattern)) {\n throw new WriterException('Invalid mask pattern');\n }\n const typeInfo = (ecLevel.getBits() << 3) | maskPattern;\n bits.appendBits(typeInfo, 5);\n const bchCode = MatrixUtil.calculateBCHCode(typeInfo, MatrixUtil.TYPE_INFO_POLY);\n bits.appendBits(bchCode, 10);\n const maskBits = new BitArray();\n maskBits.appendBits(MatrixUtil.TYPE_INFO_MASK_PATTERN, 15);\n bits.xor(maskBits);\n if (bits.getSize() !== 15) { // Just in case.\n throw new WriterException('should not happen but we got: ' + bits.getSize());\n }\n }\n // Make bit vector of version information. On success, store the result in \"bits\" and return true.\n // See 8.10 of JISX0510:2004 (p.45) for details.\n static makeVersionInfoBits(version, bits) {\n bits.appendBits(version.getVersionNumber(), 6);\n const bchCode = MatrixUtil.calculateBCHCode(version.getVersionNumber(), MatrixUtil.VERSION_INFO_POLY);\n bits.appendBits(bchCode, 12);\n if (bits.getSize() !== 18) { // Just in case.\n throw new WriterException('should not happen but we got: ' + bits.getSize());\n }\n }\n // Check if \"value\" is empty.\n static isEmpty(value /*int*/) {\n return value === 255; // -1\n }\n static embedTimingPatterns(matrix) {\n // -8 is for skipping position detection patterns (7: size), and two horizontal/vertical\n // separation patterns (1: size). Thus, 8 = 7 + 1.\n for (let i = 8; i < matrix.getWidth() - 8; ++i) {\n const bit = (i + 1) % 2;\n // Horizontal line.\n if (MatrixUtil.isEmpty(matrix.get(i, 6))) {\n matrix.setNumber(i, 6, bit);\n }\n // Vertical line.\n if (MatrixUtil.isEmpty(matrix.get(6, i))) {\n matrix.setNumber(6, i, bit);\n }\n }\n }\n // Embed the lonely dark dot at left bottom corner. JISX0510:2004 (p.46)\n static embedDarkDotAtLeftBottomCorner(matrix) {\n if (matrix.get(8, matrix.getHeight() - 8) === 0) {\n throw new WriterException();\n }\n matrix.setNumber(8, matrix.getHeight() - 8, 1);\n }\n static embedHorizontalSeparationPattern(xStart /*int*/, yStart /*int*/, matrix) {\n for (let x = 0; x < 8; ++x) {\n if (!MatrixUtil.isEmpty(matrix.get(xStart + x, yStart))) {\n throw new WriterException();\n }\n matrix.setNumber(xStart + x, yStart, 0);\n }\n }\n static embedVerticalSeparationPattern(xStart /*int*/, yStart /*int*/, matrix) {\n for (let y = 0; y < 7; ++y) {\n if (!MatrixUtil.isEmpty(matrix.get(xStart, yStart + y))) {\n throw new WriterException();\n }\n matrix.setNumber(xStart, yStart + y, 0);\n }\n }\n static embedPositionAdjustmentPattern(xStart /*int*/, yStart /*int*/, matrix) {\n for (let y = 0; y < 5; ++y) {\n const patternY = MatrixUtil.POSITION_ADJUSTMENT_PATTERN[y];\n for (let x = 0; x < 5; ++x) {\n matrix.setNumber(xStart + x, yStart + y, patternY[x]);\n }\n }\n }\n static embedPositionDetectionPattern(xStart /*int*/, yStart /*int*/, matrix) {\n for (let y = 0; y < 7; ++y) {\n const patternY = MatrixUtil.POSITION_DETECTION_PATTERN[y];\n for (let x = 0; x < 7; ++x) {\n matrix.setNumber(xStart + x, yStart + y, patternY[x]);\n }\n }\n }\n // Embed position detection patterns and surrounding vertical/horizontal separators.\n static embedPositionDetectionPatternsAndSeparators(matrix) {\n // Embed three big squares at corners.\n const pdpWidth = MatrixUtil.POSITION_DETECTION_PATTERN[0].length;\n // Left top corner.\n MatrixUtil.embedPositionDetectionPattern(0, 0, matrix);\n // Right top corner.\n MatrixUtil.embedPositionDetectionPattern(matrix.getWidth() - pdpWidth, 0, matrix);\n // Left bottom corner.\n MatrixUtil.embedPositionDetectionPattern(0, matrix.getWidth() - pdpWidth, matrix);\n // Embed horizontal separation patterns around the squares.\n const hspWidth = 8;\n // Left top corner.\n MatrixUtil.embedHorizontalSeparationPattern(0, hspWidth - 1, matrix);\n // Right top corner.\n MatrixUtil.embedHorizontalSeparationPattern(matrix.getWidth() - hspWidth, hspWidth - 1, matrix);\n // Left bottom corner.\n MatrixUtil.embedHorizontalSeparationPattern(0, matrix.getWidth() - hspWidth, matrix);\n // Embed vertical separation patterns around the squares.\n const vspSize = 7;\n // Left top corner.\n MatrixUtil.embedVerticalSeparationPattern(vspSize, 0, matrix);\n // Right top corner.\n MatrixUtil.embedVerticalSeparationPattern(matrix.getHeight() - vspSize - 1, 0, matrix);\n // Left bottom corner.\n MatrixUtil.embedVerticalSeparationPattern(vspSize, matrix.getHeight() - vspSize, matrix);\n }\n // Embed position adjustment patterns if need be.\n static maybeEmbedPositionAdjustmentPatterns(version, matrix) {\n if (version.getVersionNumber() < 2) { // The patterns appear if version >= 2\n return;\n }\n const index = version.getVersionNumber() - 1;\n const coordinates = MatrixUtil.POSITION_ADJUSTMENT_PATTERN_COORDINATE_TABLE[index];\n for (let i = 0, length = coordinates.length; i !== length; i++) {\n const y = coordinates[i];\n if (y >= 0) {\n for (let j = 0; j !== length; j++) {\n const x = coordinates[j];\n if (x >= 0 && MatrixUtil.isEmpty(matrix.get(x, y))) {\n // If the cell is unset, we embed the position adjustment pattern here.\n // -2 is necessary since the x/y coordinates point to the center of the pattern, not the\n // left top corner.\n MatrixUtil.embedPositionAdjustmentPattern(x - 2, y - 2, matrix);\n }\n }\n }\n }\n }\n }\n MatrixUtil.POSITION_DETECTION_PATTERN = Array.from([\n Int32Array.from([1, 1, 1, 1, 1, 1, 1]),\n Int32Array.from([1, 0, 0, 0, 0, 0, 1]),\n Int32Array.from([1, 0, 1, 1, 1, 0, 1]),\n Int32Array.from([1, 0, 1, 1, 1, 0, 1]),\n Int32Array.from([1, 0, 1, 1, 1, 0, 1]),\n Int32Array.from([1, 0, 0, 0, 0, 0, 1]),\n Int32Array.from([1, 1, 1, 1, 1, 1, 1]),\n ]);\n MatrixUtil.POSITION_ADJUSTMENT_PATTERN = Array.from([\n Int32Array.from([1, 1, 1, 1, 1]),\n Int32Array.from([1, 0, 0, 0, 1]),\n Int32Array.from([1, 0, 1, 0, 1]),\n Int32Array.from([1, 0, 0, 0, 1]),\n Int32Array.from([1, 1, 1, 1, 1]),\n ]);\n // From Appendix E. Table 1, JIS0510X:2004 (71: p). The table was double-checked by komatsu.\n MatrixUtil.POSITION_ADJUSTMENT_PATTERN_COORDINATE_TABLE = Array.from([\n Int32Array.from([-1, -1, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 18, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 22, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 26, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 30, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 34, -1, -1, -1, -1, -1]),\n Int32Array.from([6, 22, 38, -1, -1, -1, -1]),\n Int32Array.from([6, 24, 42, -1, -1, -1, -1]),\n Int32Array.from([6, 26, 46, -1, -1, -1, -1]),\n Int32Array.from([6, 28, 50, -1, -1, -1, -1]),\n Int32Array.from([6, 30, 54, -1, -1, -1, -1]),\n Int32Array.from([6, 32, 58, -1, -1, -1, -1]),\n Int32Array.from([6, 34, 62, -1, -1, -1, -1]),\n Int32Array.from([6, 26, 46, 66, -1, -1, -1]),\n Int32Array.from([6, 26, 48, 70, -1, -1, -1]),\n Int32Array.from([6, 26, 50, 74, -1, -1, -1]),\n Int32Array.from([6, 30, 54, 78, -1, -1, -1]),\n Int32Array.from([6, 30, 56, 82, -1, -1, -1]),\n Int32Array.from([6, 30, 58, 86, -1, -1, -1]),\n Int32Array.from([6, 34, 62, 90, -1, -1, -1]),\n Int32Array.from([6, 28, 50, 72, 94, -1, -1]),\n Int32Array.from([6, 26, 50, 74, 98, -1, -1]),\n Int32Array.from([6, 30, 54, 78, 102, -1, -1]),\n Int32Array.from([6, 28, 54, 80, 106, -1, -1]),\n Int32Array.from([6, 32, 58, 84, 110, -1, -1]),\n Int32Array.from([6, 30, 58, 86, 114, -1, -1]),\n Int32Array.from([6, 34, 62, 90, 118, -1, -1]),\n Int32Array.from([6, 26, 50, 74, 98, 122, -1]),\n Int32Array.from([6, 30, 54, 78, 102, 126, -1]),\n Int32Array.from([6, 26, 52, 78, 104, 130, -1]),\n Int32Array.from([6, 30, 56, 82, 108, 134, -1]),\n Int32Array.from([6, 34, 60, 86, 112, 138, -1]),\n Int32Array.from([6, 30, 58, 86, 114, 142, -1]),\n Int32Array.from([6, 34, 62, 90, 118, 146, -1]),\n Int32Array.from([6, 30, 54, 78, 102, 126, 150]),\n Int32Array.from([6, 24, 50, 76, 102, 128, 154]),\n Int32Array.from([6, 28, 54, 80, 106, 132, 158]),\n Int32Array.from([6, 32, 58, 84, 110, 136, 162]),\n Int32Array.from([6, 26, 54, 82, 110, 138, 166]),\n Int32Array.from([6, 30, 58, 86, 114, 142, 170]),\n ]);\n // Type info cells at the left top corner.\n MatrixUtil.TYPE_INFO_COORDINATES = Array.from([\n Int32Array.from([8, 0]),\n Int32Array.from([8, 1]),\n Int32Array.from([8, 2]),\n Int32Array.from([8, 3]),\n Int32Array.from([8, 4]),\n Int32Array.from([8, 5]),\n Int32Array.from([8, 7]),\n Int32Array.from([8, 8]),\n Int32Array.from([7, 8]),\n Int32Array.from([5, 8]),\n Int32Array.from([4, 8]),\n Int32Array.from([3, 8]),\n Int32Array.from([2, 8]),\n Int32Array.from([1, 8]),\n Int32Array.from([0, 8]),\n ]);\n // From Appendix D in JISX0510:2004 (p. 67)\n MatrixUtil.VERSION_INFO_POLY = 0x1f25; // 1 1111 0010 0101\n // From Appendix C in JISX0510:2004 (p.65).\n MatrixUtil.TYPE_INFO_POLY = 0x537;\n MatrixUtil.TYPE_INFO_MASK_PATTERN = 0x5412;\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*namespace com.google.zxing.qrcode.encoder {*/\n class BlockPair {\n constructor(dataBytes, errorCorrectionBytes) {\n this.dataBytes = dataBytes;\n this.errorCorrectionBytes = errorCorrectionBytes;\n }\n getDataBytes() {\n return this.dataBytes;\n }\n getErrorCorrectionBytes() {\n return this.errorCorrectionBytes;\n }\n }\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.io.UnsupportedEncodingException;*/\n /*import java.util.ArrayList;*/\n /*import java.util.Collection;*/\n /*import java.util.Map;*/\n /**\n * @author satorux@google.com (Satoru Takabayashi) - creator\n * @author dswitkin@google.com (Daniel Switkin) - ported from C++\n */\n class Encoder {\n // TYPESCRIPTPORT: changed to UTF8, the default for js\n constructor() { }\n // The mask penalty calculation is complicated. See Table 21 of JISX0510:2004 (p.45) for details.\n // Basically it applies four rules and summate all penalties.\n static calculateMaskPenalty(matrix) {\n return MaskUtil.applyMaskPenaltyRule1(matrix)\n + MaskUtil.applyMaskPenaltyRule2(matrix)\n + MaskUtil.applyMaskPenaltyRule3(matrix)\n + MaskUtil.applyMaskPenaltyRule4(matrix);\n }\n /**\n * @param content text to encode\n * @param ecLevel error correction level to use\n * @return {@link QRCode} representing the encoded QR code\n * @throws WriterException if encoding can't succeed, because of for example invalid content\n * or configuration\n */\n // public static encode(content: string, ecLevel: ErrorCorrectionLevel): QRCode /*throws WriterException*/ {\n // return encode(content, ecLevel, null)\n // }\n static encode(content, ecLevel, hints = null) {\n // Determine what character encoding has been specified by the caller, if any\n let encoding = Encoder.DEFAULT_BYTE_MODE_ENCODING;\n const hasEncodingHint = hints !== null && undefined !== hints.get(EncodeHintType$1.CHARACTER_SET);\n if (hasEncodingHint) {\n encoding = hints.get(EncodeHintType$1.CHARACTER_SET).toString();\n }\n // Pick an encoding mode appropriate for the content. Note that this will not attempt to use\n // multiple modes / segments even if that were more efficient. Twould be nice.\n const mode = this.chooseMode(content, encoding);\n // This will store the header information, like mode and\n // length, as well as \"header\" segments like an ECI segment.\n const headerBits = new BitArray();\n // Append ECI segment if applicable\n if (mode === Mode$1.BYTE && (hasEncodingHint || Encoder.DEFAULT_BYTE_MODE_ENCODING !== encoding)) {\n const eci = CharacterSetECI.getCharacterSetECIByName(encoding);\n if (eci !== undefined) {\n this.appendECI(eci, headerBits);\n }\n }\n // (With ECI in place,) Write the mode marker\n this.appendModeInfo(mode, headerBits);\n // Collect data within the main segment, separately, to count its size if needed. Don't add it to\n // main payload yet.\n const dataBits = new BitArray();\n this.appendBytes(content, mode, dataBits, encoding);\n let version;\n if (hints !== null && undefined !== hints.get(EncodeHintType$1.QR_VERSION)) {\n const versionNumber = Number.parseInt(hints.get(EncodeHintType$1.QR_VERSION).toString(), 10);\n version = Version$1.getVersionForNumber(versionNumber);\n const bitsNeeded = this.calculateBitsNeeded(mode, headerBits, dataBits, version);\n if (!this.willFit(bitsNeeded, version, ecLevel)) {\n throw new WriterException('Data too big for requested version');\n }\n }\n else {\n version = this.recommendVersion(ecLevel, mode, headerBits, dataBits);\n }\n const headerAndDataBits = new BitArray();\n headerAndDataBits.appendBitArray(headerBits);\n // Find \"length\" of main segment and write it\n const numLetters = mode === Mode$1.BYTE ? dataBits.getSizeInBytes() : content.length;\n this.appendLengthInfo(numLetters, version, mode, headerAndDataBits);\n // Put data together into the overall payload\n headerAndDataBits.appendBitArray(dataBits);\n const ecBlocks = version.getECBlocksForLevel(ecLevel);\n const numDataBytes = version.getTotalCodewords() - ecBlocks.getTotalECCodewords();\n // Terminate the bits properly.\n this.terminateBits(numDataBytes, headerAndDataBits);\n // Interleave data bits with error correction code.\n const finalBits = this.interleaveWithECBytes(headerAndDataBits, version.getTotalCodewords(), numDataBytes, ecBlocks.getNumBlocks());\n const qrCode = new QRCode();\n qrCode.setECLevel(ecLevel);\n qrCode.setMode(mode);\n qrCode.setVersion(version);\n // Choose the mask pattern and set to \"qrCode\".\n const dimension = version.getDimensionForVersion();\n const matrix = new ByteMatrix(dimension, dimension);\n const maskPattern = this.chooseMaskPattern(finalBits, ecLevel, version, matrix);\n qrCode.setMaskPattern(maskPattern);\n // Build the matrix and set it to \"qrCode\".\n MatrixUtil.buildMatrix(finalBits, ecLevel, version, maskPattern, matrix);\n qrCode.setMatrix(matrix);\n return qrCode;\n }\n /**\n * Decides the smallest version of QR code that will contain all of the provided data.\n *\n * @throws WriterException if the data cannot fit in any version\n */\n static recommendVersion(ecLevel, mode, headerBits, dataBits) {\n // Hard part: need to know version to know how many bits length takes. But need to know how many\n // bits it takes to know version. First we take a guess at version by assuming version will be\n // the minimum, 1:\n const provisionalBitsNeeded = this.calculateBitsNeeded(mode, headerBits, dataBits, Version$1.getVersionForNumber(1));\n const provisionalVersion = this.chooseVersion(provisionalBitsNeeded, ecLevel);\n // Use that guess to calculate the right version. I am still not sure this works in 100% of cases.\n const bitsNeeded = this.calculateBitsNeeded(mode, headerBits, dataBits, provisionalVersion);\n return this.chooseVersion(bitsNeeded, ecLevel);\n }\n static calculateBitsNeeded(mode, headerBits, dataBits, version) {\n return headerBits.getSize() + mode.getCharacterCountBits(version) + dataBits.getSize();\n }\n /**\n * @return the code point of the table used in alphanumeric mode or\n * -1 if there is no corresponding code in the table.\n */\n static getAlphanumericCode(code /*int*/) {\n if (code < Encoder.ALPHANUMERIC_TABLE.length) {\n return Encoder.ALPHANUMERIC_TABLE[code];\n }\n return -1;\n }\n // public static chooseMode(content: string): Mode {\n // return chooseMode(content, null);\n // }\n /**\n * Choose the best mode by examining the content. Note that 'encoding' is used as a hint;\n * if it is Shift_JIS, and the input is only double-byte Kanji, then we return {@link Mode#KANJI}.\n */\n static chooseMode(content, encoding = null) {\n if (CharacterSetECI.SJIS.getName() === encoding && this.isOnlyDoubleByteKanji(content)) {\n // Choose Kanji mode if all input are double-byte characters\n return Mode$1.KANJI;\n }\n let hasNumeric = false;\n let hasAlphanumeric = false;\n for (let i = 0, length = content.length; i < length; ++i) {\n const c = content.charAt(i);\n if (Encoder.isDigit(c)) {\n hasNumeric = true;\n }\n else if (this.getAlphanumericCode(c.charCodeAt(0)) !== -1) {\n hasAlphanumeric = true;\n }\n else {\n return Mode$1.BYTE;\n }\n }\n if (hasAlphanumeric) {\n return Mode$1.ALPHANUMERIC;\n }\n if (hasNumeric) {\n return Mode$1.NUMERIC;\n }\n return Mode$1.BYTE;\n }\n static isOnlyDoubleByteKanji(content) {\n let bytes;\n try {\n bytes = StringEncoding.encode(content, CharacterSetECI.SJIS); // content.getBytes(\"Shift_JIS\"))\n }\n catch (ignored /*: UnsupportedEncodingException*/) {\n return false;\n }\n const length = bytes.length;\n if (length % 2 !== 0) {\n return false;\n }\n for (let i = 0; i < length; i += 2) {\n const byte1 = bytes[i] & 0xFF;\n if ((byte1 < 0x81 || byte1 > 0x9F) && (byte1 < 0xE0 || byte1 > 0xEB)) {\n return false;\n }\n }\n return true;\n }\n static chooseMaskPattern(bits, ecLevel, version, matrix) {\n let minPenalty = Number.MAX_SAFE_INTEGER; // Lower penalty is better.\n let bestMaskPattern = -1;\n // We try all mask patterns to choose the best one.\n for (let maskPattern = 0; maskPattern < QRCode.NUM_MASK_PATTERNS; maskPattern++) {\n MatrixUtil.buildMatrix(bits, ecLevel, version, maskPattern, matrix);\n let penalty = this.calculateMaskPenalty(matrix);\n if (penalty < minPenalty) {\n minPenalty = penalty;\n bestMaskPattern = maskPattern;\n }\n }\n return bestMaskPattern;\n }\n static chooseVersion(numInputBits /*int*/, ecLevel) {\n for (let versionNum = 1; versionNum <= 40; versionNum++) {\n const version = Version$1.getVersionForNumber(versionNum);\n if (Encoder.willFit(numInputBits, version, ecLevel)) {\n return version;\n }\n }\n throw new WriterException('Data too big');\n }\n /**\n * @return true if the number of input bits will fit in a code with the specified version and\n * error correction level.\n */\n static willFit(numInputBits /*int*/, version, ecLevel) {\n // In the following comments, we use numbers of Version 7-H.\n // numBytes = 196\n const numBytes = version.getTotalCodewords();\n // getNumECBytes = 130\n const ecBlocks = version.getECBlocksForLevel(ecLevel);\n const numEcBytes = ecBlocks.getTotalECCodewords();\n // getNumDataBytes = 196 - 130 = 66\n const numDataBytes = numBytes - numEcBytes;\n const totalInputBytes = (numInputBits + 7) / 8;\n return numDataBytes >= totalInputBytes;\n }\n /**\n * Terminate bits as described in 8.4.8 and 8.4.9 of JISX0510:2004 (p.24).\n */\n static terminateBits(numDataBytes /*int*/, bits) {\n const capacity = numDataBytes * 8;\n if (bits.getSize() > capacity) {\n throw new WriterException('data bits cannot fit in the QR Code' + bits.getSize() + ' > ' +\n capacity);\n }\n for (let i = 0; i < 4 && bits.getSize() < capacity; ++i) {\n bits.appendBit(false);\n }\n // Append termination bits. See 8.4.8 of JISX0510:2004 (p.24) for details.\n // If the last byte isn't 8-bit aligned, we'll add padding bits.\n const numBitsInLastByte = bits.getSize() & 0x07;\n if (numBitsInLastByte > 0) {\n for (let i = numBitsInLastByte; i < 8; i++) {\n bits.appendBit(false);\n }\n }\n // If we have more space, we'll fill the space with padding patterns defined in 8.4.9 (p.24).\n const numPaddingBytes = numDataBytes - bits.getSizeInBytes();\n for (let i = 0; i < numPaddingBytes; ++i) {\n bits.appendBits((i & 0x01) === 0 ? 0xEC : 0x11, 8);\n }\n if (bits.getSize() !== capacity) {\n throw new WriterException('Bits size does not equal capacity');\n }\n }\n /**\n * Get number of data bytes and number of error correction bytes for block id \"blockID\". Store\n * the result in \"numDataBytesInBlock\", and \"numECBytesInBlock\". See table 12 in 8.5.1 of\n * JISX0510:2004 (p.30)\n */\n static getNumDataBytesAndNumECBytesForBlockID(numTotalBytes /*int*/, numDataBytes /*int*/, numRSBlocks /*int*/, blockID /*int*/, numDataBytesInBlock, numECBytesInBlock) {\n if (blockID >= numRSBlocks) {\n throw new WriterException('Block ID too large');\n }\n // numRsBlocksInGroup2 = 196 % 5 = 1\n const numRsBlocksInGroup2 = numTotalBytes % numRSBlocks;\n // numRsBlocksInGroup1 = 5 - 1 = 4\n const numRsBlocksInGroup1 = numRSBlocks - numRsBlocksInGroup2;\n // numTotalBytesInGroup1 = 196 / 5 = 39\n const numTotalBytesInGroup1 = Math.floor(numTotalBytes / numRSBlocks);\n // numTotalBytesInGroup2 = 39 + 1 = 40\n const numTotalBytesInGroup2 = numTotalBytesInGroup1 + 1;\n // numDataBytesInGroup1 = 66 / 5 = 13\n const numDataBytesInGroup1 = Math.floor(numDataBytes / numRSBlocks);\n // numDataBytesInGroup2 = 13 + 1 = 14\n const numDataBytesInGroup2 = numDataBytesInGroup1 + 1;\n // numEcBytesInGroup1 = 39 - 13 = 26\n const numEcBytesInGroup1 = numTotalBytesInGroup1 - numDataBytesInGroup1;\n // numEcBytesInGroup2 = 40 - 14 = 26\n const numEcBytesInGroup2 = numTotalBytesInGroup2 - numDataBytesInGroup2;\n // Sanity checks.\n // 26 = 26\n if (numEcBytesInGroup1 !== numEcBytesInGroup2) {\n throw new WriterException('EC bytes mismatch');\n }\n // 5 = 4 + 1.\n if (numRSBlocks !== numRsBlocksInGroup1 + numRsBlocksInGroup2) {\n throw new WriterException('RS blocks mismatch');\n }\n // 196 = (13 + 26) * 4 + (14 + 26) * 1\n if (numTotalBytes !==\n ((numDataBytesInGroup1 + numEcBytesInGroup1) *\n numRsBlocksInGroup1) +\n ((numDataBytesInGroup2 + numEcBytesInGroup2) *\n numRsBlocksInGroup2)) {\n throw new WriterException('Total bytes mismatch');\n }\n if (blockID < numRsBlocksInGroup1) {\n numDataBytesInBlock[0] = numDataBytesInGroup1;\n numECBytesInBlock[0] = numEcBytesInGroup1;\n }\n else {\n numDataBytesInBlock[0] = numDataBytesInGroup2;\n numECBytesInBlock[0] = numEcBytesInGroup2;\n }\n }\n /**\n * Interleave \"bits\" with corresponding error correction bytes. On success, store the result in\n * \"result\". The interleave rule is complicated. See 8.6 of JISX0510:2004 (p.37) for details.\n */\n static interleaveWithECBytes(bits, numTotalBytes /*int*/, numDataBytes /*int*/, numRSBlocks /*int*/) {\n // \"bits\" must have \"getNumDataBytes\" bytes of data.\n if (bits.getSizeInBytes() !== numDataBytes) {\n throw new WriterException('Number of bits and data bytes does not match');\n }\n // Step 1. Divide data bytes into blocks and generate error correction bytes for them. We'll\n // store the divided data bytes blocks and error correction bytes blocks into \"blocks\".\n let dataBytesOffset = 0;\n let maxNumDataBytes = 0;\n let maxNumEcBytes = 0;\n // Since, we know the number of reedsolmon blocks, we can initialize the vector with the number.\n const blocks = new Array(); // new Array(numRSBlocks)\n for (let i = 0; i < numRSBlocks; ++i) {\n const numDataBytesInBlock = new Int32Array(1);\n const numEcBytesInBlock = new Int32Array(1);\n Encoder.getNumDataBytesAndNumECBytesForBlockID(numTotalBytes, numDataBytes, numRSBlocks, i, numDataBytesInBlock, numEcBytesInBlock);\n const size = numDataBytesInBlock[0];\n const dataBytes = new Uint8Array(size);\n bits.toBytes(8 * dataBytesOffset, dataBytes, 0, size);\n const ecBytes = Encoder.generateECBytes(dataBytes, numEcBytesInBlock[0]);\n blocks.push(new BlockPair(dataBytes, ecBytes));\n maxNumDataBytes = Math.max(maxNumDataBytes, size);\n maxNumEcBytes = Math.max(maxNumEcBytes, ecBytes.length);\n dataBytesOffset += numDataBytesInBlock[0];\n }\n if (numDataBytes !== dataBytesOffset) {\n throw new WriterException('Data bytes does not match offset');\n }\n const result = new BitArray();\n // First, place data blocks.\n for (let i = 0; i < maxNumDataBytes; ++i) {\n for (const block of blocks) {\n const dataBytes = block.getDataBytes();\n if (i < dataBytes.length) {\n result.appendBits(dataBytes[i], 8);\n }\n }\n }\n // Then, place error correction blocks.\n for (let i = 0; i < maxNumEcBytes; ++i) {\n for (const block of blocks) {\n const ecBytes = block.getErrorCorrectionBytes();\n if (i < ecBytes.length) {\n result.appendBits(ecBytes[i], 8);\n }\n }\n }\n if (numTotalBytes !== result.getSizeInBytes()) { // Should be same.\n throw new WriterException('Interleaving error: ' + numTotalBytes + ' and ' +\n result.getSizeInBytes() + ' differ.');\n }\n return result;\n }\n static generateECBytes(dataBytes, numEcBytesInBlock /*int*/) {\n const numDataBytes = dataBytes.length;\n const toEncode = new Int32Array(numDataBytes + numEcBytesInBlock); // int[numDataBytes + numEcBytesInBlock]\n for (let i = 0; i < numDataBytes; i++) {\n toEncode[i] = dataBytes[i] & 0xFF;\n }\n new ReedSolomonEncoder(GenericGF.QR_CODE_FIELD_256).encode(toEncode, numEcBytesInBlock);\n const ecBytes = new Uint8Array(numEcBytesInBlock);\n for (let i = 0; i < numEcBytesInBlock; i++) {\n ecBytes[i] = /*(byte) */ toEncode[numDataBytes + i];\n }\n return ecBytes;\n }\n /**\n * Append mode info. On success, store the result in \"bits\".\n */\n static appendModeInfo(mode, bits) {\n bits.appendBits(mode.getBits(), 4);\n }\n /**\n * Append length info. On success, store the result in \"bits\".\n */\n static appendLengthInfo(numLetters /*int*/, version, mode, bits) {\n const numBits = mode.getCharacterCountBits(version);\n if (numLetters >= (1 << numBits)) {\n throw new WriterException(numLetters + ' is bigger than ' + ((1 << numBits) - 1));\n }\n bits.appendBits(numLetters, numBits);\n }\n /**\n * Append \"bytes\" in \"mode\" mode (encoding) into \"bits\". On success, store the result in \"bits\".\n */\n static appendBytes(content, mode, bits, encoding) {\n switch (mode) {\n case Mode$1.NUMERIC:\n Encoder.appendNumericBytes(content, bits);\n break;\n case Mode$1.ALPHANUMERIC:\n Encoder.appendAlphanumericBytes(content, bits);\n break;\n case Mode$1.BYTE:\n Encoder.append8BitBytes(content, bits, encoding);\n break;\n case Mode$1.KANJI:\n Encoder.appendKanjiBytes(content, bits);\n break;\n default:\n throw new WriterException('Invalid mode: ' + mode);\n }\n }\n static getDigit(singleCharacter) {\n return singleCharacter.charCodeAt(0) - 48;\n }\n static isDigit(singleCharacter) {\n const cn = Encoder.getDigit(singleCharacter);\n return cn >= 0 && cn <= 9;\n }\n static appendNumericBytes(content, bits) {\n const length = content.length;\n let i = 0;\n while (i < length) {\n const num1 = Encoder.getDigit(content.charAt(i));\n if (i + 2 < length) {\n // Encode three numeric letters in ten bits.\n const num2 = Encoder.getDigit(content.charAt(i + 1));\n const num3 = Encoder.getDigit(content.charAt(i + 2));\n bits.appendBits(num1 * 100 + num2 * 10 + num3, 10);\n i += 3;\n }\n else if (i + 1 < length) {\n // Encode two numeric letters in seven bits.\n const num2 = Encoder.getDigit(content.charAt(i + 1));\n bits.appendBits(num1 * 10 + num2, 7);\n i += 2;\n }\n else {\n // Encode one numeric letter in four bits.\n bits.appendBits(num1, 4);\n i++;\n }\n }\n }\n static appendAlphanumericBytes(content, bits) {\n const length = content.length;\n let i = 0;\n while (i < length) {\n const code1 = Encoder.getAlphanumericCode(content.charCodeAt(i));\n if (code1 === -1) {\n throw new WriterException();\n }\n if (i + 1 < length) {\n const code2 = Encoder.getAlphanumericCode(content.charCodeAt(i + 1));\n if (code2 === -1) {\n throw new WriterException();\n }\n // Encode two alphanumeric letters in 11 bits.\n bits.appendBits(code1 * 45 + code2, 11);\n i += 2;\n }\n else {\n // Encode one alphanumeric letter in six bits.\n bits.appendBits(code1, 6);\n i++;\n }\n }\n }\n static append8BitBytes(content, bits, encoding) {\n let bytes;\n try {\n bytes = StringEncoding.encode(content, encoding);\n }\n catch (uee /*: UnsupportedEncodingException*/) {\n throw new WriterException(uee);\n }\n for (let i = 0, length = bytes.length; i !== length; i++) {\n const b = bytes[i];\n bits.appendBits(b, 8);\n }\n }\n /**\n * @throws WriterException\n */\n static appendKanjiBytes(content, bits) {\n let bytes;\n try {\n bytes = StringEncoding.encode(content, CharacterSetECI.SJIS);\n }\n catch (uee /*: UnsupportedEncodingException*/) {\n throw new WriterException(uee);\n }\n const length = bytes.length;\n for (let i = 0; i < length; i += 2) {\n const byte1 = bytes[i] & 0xFF;\n const byte2 = bytes[i + 1] & 0xFF;\n const code = ((byte1 << 8) & 0xFFFFFFFF) | byte2;\n let subtracted = -1;\n if (code >= 0x8140 && code <= 0x9ffc) {\n subtracted = code - 0x8140;\n }\n else if (code >= 0xe040 && code <= 0xebbf) {\n subtracted = code - 0xc140;\n }\n if (subtracted === -1) {\n throw new WriterException('Invalid byte sequence');\n }\n const encoded = ((subtracted >> 8) * 0xc0) + (subtracted & 0xff);\n bits.appendBits(encoded, 13);\n }\n }\n static appendECI(eci, bits) {\n bits.appendBits(Mode$1.ECI.getBits(), 4);\n // This is correct for values up to 127, which is all we need now.\n bits.appendBits(eci.getValue(), 8);\n }\n }\n // The original table is defined in the table 5 of JISX0510:2004 (p.19).\n Encoder.ALPHANUMERIC_TABLE = Int32Array.from([\n -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,\n -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,\n 36, -1, -1, -1, 37, 38, -1, -1, -1, -1, 39, 40, -1, 41, 42, 43,\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 44, -1, -1, -1, -1, -1,\n -1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24,\n 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, -1, -1, -1, -1, -1,\n ]);\n Encoder.DEFAULT_BYTE_MODE_ENCODING = CharacterSetECI.UTF8.getName(); // \"ISO-8859-1\"\n\n /**\n * @deprecated Moving to @zxing/browser\n */\n class BrowserQRCodeSvgWriter {\n /**\n * Writes and renders a QRCode SVG element.\n *\n * @param contents\n * @param width\n * @param height\n * @param hints\n */\n write(contents, width, height, hints = null) {\n if (contents.length === 0) {\n throw new IllegalArgumentException('Found empty contents');\n }\n // if (format != BarcodeFormat.QR_CODE) {\n // throw new IllegalArgumentException(\"Can only encode QR_CODE, but got \" + format)\n // }\n if (width < 0 || height < 0) {\n throw new IllegalArgumentException('Requested dimensions are too small: ' + width + 'x' + height);\n }\n let errorCorrectionLevel = ErrorCorrectionLevel.L;\n let quietZone = BrowserQRCodeSvgWriter.QUIET_ZONE_SIZE;\n if (hints !== null) {\n if (undefined !== hints.get(EncodeHintType$1.ERROR_CORRECTION)) {\n errorCorrectionLevel = ErrorCorrectionLevel.fromString(hints.get(EncodeHintType$1.ERROR_CORRECTION).toString());\n }\n if (undefined !== hints.get(EncodeHintType$1.MARGIN)) {\n quietZone = Number.parseInt(hints.get(EncodeHintType$1.MARGIN).toString(), 10);\n }\n }\n const code = Encoder.encode(contents, errorCorrectionLevel, hints);\n return this.renderResult(code, width, height, quietZone);\n }\n /**\n * Renders the result and then appends it to the DOM.\n */\n writeToDom(containerElement, contents, width, height, hints = null) {\n if (typeof containerElement === 'string') {\n containerElement = document.querySelector(containerElement);\n }\n const svgElement = this.write(contents, width, height, hints);\n if (containerElement)\n containerElement.appendChild(svgElement);\n }\n /**\n * Note that the input matrix uses 0 == white, 1 == black.\n * The output matrix uses 0 == black, 255 == white (i.e. an 8 bit greyscale bitmap).\n */\n renderResult(code, width /*int*/, height /*int*/, quietZone /*int*/) {\n const input = code.getMatrix();\n if (input === null) {\n throw new IllegalStateException();\n }\n const inputWidth = input.getWidth();\n const inputHeight = input.getHeight();\n const qrWidth = inputWidth + (quietZone * 2);\n const qrHeight = inputHeight + (quietZone * 2);\n const outputWidth = Math.max(width, qrWidth);\n const outputHeight = Math.max(height, qrHeight);\n const multiple = Math.min(Math.floor(outputWidth / qrWidth), Math.floor(outputHeight / qrHeight));\n // Padding includes both the quiet zone and the extra white pixels to accommodate the requested\n // dimensions. For example, if input is 25x25 the QR will be 33x33 including the quiet zone.\n // If the requested size is 200x160, the multiple will be 4, for a QR of 132x132. These will\n // handle all the padding from 100x100 (the actual QR) up to 200x160.\n const leftPadding = Math.floor((outputWidth - (inputWidth * multiple)) / 2);\n const topPadding = Math.floor((outputHeight - (inputHeight * multiple)) / 2);\n const svgElement = this.createSVGElement(outputWidth, outputHeight);\n for (let inputY = 0, outputY = topPadding; inputY < inputHeight; inputY++, outputY += multiple) {\n // Write the contents of this row of the barcode\n for (let inputX = 0, outputX = leftPadding; inputX < inputWidth; inputX++, outputX += multiple) {\n if (input.get(inputX, inputY) === 1) {\n const svgRectElement = this.createSvgRectElement(outputX, outputY, multiple, multiple);\n svgElement.appendChild(svgRectElement);\n }\n }\n }\n return svgElement;\n }\n /**\n * Creates a SVG element.\n *\n * @param w SVG's width attribute\n * @param h SVG's height attribute\n */\n createSVGElement(w, h) {\n const svgElement = document.createElementNS(BrowserQRCodeSvgWriter.SVG_NS, 'svg');\n svgElement.setAttributeNS(null, 'height', w.toString());\n svgElement.setAttributeNS(null, 'width', h.toString());\n return svgElement;\n }\n /**\n * Creates a SVG rect element.\n *\n * @param x Element's x coordinate\n * @param y Element's y coordinate\n * @param w Element's width attribute\n * @param h Element's height attribute\n */\n createSvgRectElement(x, y, w, h) {\n const rect = document.createElementNS(BrowserQRCodeSvgWriter.SVG_NS, 'rect');\n rect.setAttributeNS(null, 'x', x.toString());\n rect.setAttributeNS(null, 'y', y.toString());\n rect.setAttributeNS(null, 'height', w.toString());\n rect.setAttributeNS(null, 'width', h.toString());\n rect.setAttributeNS(null, 'fill', '#000000');\n return rect;\n }\n }\n BrowserQRCodeSvgWriter.QUIET_ZONE_SIZE = 4;\n /**\n * SVG markup NameSpace\n */\n BrowserQRCodeSvgWriter.SVG_NS = 'http://www.w3.org/2000/svg';\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.util.Map;*/\n /**\n * This object renders a QR Code as a BitMatrix 2D array of greyscale values.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class QRCodeWriter {\n /*@Override*/\n // public encode(contents: string, format: BarcodeFormat, width: number /*int*/, height: number /*int*/): BitMatrix\n // /*throws WriterException */ {\n // return encode(contents, format, width, height, null)\n // }\n /*@Override*/\n encode(contents, format, width /*int*/, height /*int*/, hints) {\n if (contents.length === 0) {\n throw new IllegalArgumentException('Found empty contents');\n }\n if (format !== BarcodeFormat$1.QR_CODE) {\n throw new IllegalArgumentException('Can only encode QR_CODE, but got ' + format);\n }\n if (width < 0 || height < 0) {\n throw new IllegalArgumentException(`Requested dimensions are too small: ${width}x${height}`);\n }\n let errorCorrectionLevel = ErrorCorrectionLevel.L;\n let quietZone = QRCodeWriter.QUIET_ZONE_SIZE;\n if (hints !== null) {\n if (undefined !== hints.get(EncodeHintType$1.ERROR_CORRECTION)) {\n errorCorrectionLevel = ErrorCorrectionLevel.fromString(hints.get(EncodeHintType$1.ERROR_CORRECTION).toString());\n }\n if (undefined !== hints.get(EncodeHintType$1.MARGIN)) {\n quietZone = Number.parseInt(hints.get(EncodeHintType$1.MARGIN).toString(), 10);\n }\n }\n const code = Encoder.encode(contents, errorCorrectionLevel, hints);\n return QRCodeWriter.renderResult(code, width, height, quietZone);\n }\n // Note that the input matrix uses 0 == white, 1 == black, while the output matrix uses\n // 0 == black, 255 == white (i.e. an 8 bit greyscale bitmap).\n static renderResult(code, width /*int*/, height /*int*/, quietZone /*int*/) {\n const input = code.getMatrix();\n if (input === null) {\n throw new IllegalStateException();\n }\n const inputWidth = input.getWidth();\n const inputHeight = input.getHeight();\n const qrWidth = inputWidth + (quietZone * 2);\n const qrHeight = inputHeight + (quietZone * 2);\n const outputWidth = Math.max(width, qrWidth);\n const outputHeight = Math.max(height, qrHeight);\n const multiple = Math.min(Math.floor(outputWidth / qrWidth), Math.floor(outputHeight / qrHeight));\n // Padding includes both the quiet zone and the extra white pixels to accommodate the requested\n // dimensions. For example, if input is 25x25 the QR will be 33x33 including the quiet zone.\n // If the requested size is 200x160, the multiple will be 4, for a QR of 132x132. These will\n // handle all the padding from 100x100 (the actual QR) up to 200x160.\n const leftPadding = Math.floor((outputWidth - (inputWidth * multiple)) / 2);\n const topPadding = Math.floor((outputHeight - (inputHeight * multiple)) / 2);\n const output = new BitMatrix(outputWidth, outputHeight);\n for (let inputY = 0, outputY = topPadding; inputY < inputHeight; inputY++, outputY += multiple) {\n // Write the contents of this row of the barcode\n for (let inputX = 0, outputX = leftPadding; inputX < inputWidth; inputX++, outputX += multiple) {\n if (input.get(inputX, inputY) === 1) {\n output.setRegion(outputX, outputY, multiple, multiple);\n }\n }\n }\n return output;\n }\n }\n QRCodeWriter.QUIET_ZONE_SIZE = 4;\n\n /*\n * Copyright 2008 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*import java.util.Map;*/\n /**\n * This is a factory class which finds the appropriate Writer subclass for the BarcodeFormat\n * requested and encodes the barcode with the supplied contents.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class MultiFormatWriter {\n /*@Override*/\n // public encode(contents: string,\n // format: BarcodeFormat,\n // width: number /*int*/,\n // height: number /*int*/): BitMatrix /*throws WriterException */ {\n // return encode(contents, format, width, height, null)\n // }\n /*@Override*/\n encode(contents, format, width /*int*/, height /*int*/, hints) {\n let writer;\n switch (format) {\n // case BarcodeFormat.EAN_8:\n // writer = new EAN8Writer()\n // break\n // case BarcodeFormat.UPC_E:\n // writer = new UPCEWriter()\n // break\n // case BarcodeFormat.EAN_13:\n // writer = new EAN13Writer()\n // break\n // case BarcodeFormat.UPC_A:\n // writer = new UPCAWriter()\n // break\n case BarcodeFormat$1.QR_CODE:\n writer = new QRCodeWriter();\n break;\n // case BarcodeFormat.CODE_39:\n // writer = new Code39Writer()\n // break\n // case BarcodeFormat.CODE_93:\n // writer = new Code93Writer()\n // break\n // case BarcodeFormat.CODE_128:\n // writer = new Code128Writer()\n // break\n // case BarcodeFormat.ITF:\n // writer = new ITFWriter()\n // break\n // case BarcodeFormat.PDF_417:\n // writer = new PDF417Writer()\n // break\n // case BarcodeFormat.CODABAR:\n // writer = new CodaBarWriter()\n // break\n // case BarcodeFormat.DATA_MATRIX:\n // writer = new DataMatrixWriter()\n // break\n // case BarcodeFormat.AZTEC:\n // writer = new AztecWriter()\n // break\n default:\n throw new IllegalArgumentException('No encoder available for format ' + format);\n }\n return writer.encode(contents, format, width, height, hints);\n }\n }\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * This object extends LuminanceSource around an array of YUV data returned from the camera driver,\n * with the option to crop to a rectangle within the full data. This can be used to exclude\n * superfluous pixels around the perimeter and speed up decoding.\n *\n * It works for any pixel format where the Y channel is planar and appears first, including\n * YCbCr_420_SP and YCbCr_422_SP.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n */\n class PlanarYUVLuminanceSource extends LuminanceSource {\n constructor(yuvData, dataWidth /*int*/, dataHeight /*int*/, left /*int*/, top /*int*/, width /*int*/, height /*int*/, reverseHorizontal) {\n super(width, height);\n this.yuvData = yuvData;\n this.dataWidth = dataWidth;\n this.dataHeight = dataHeight;\n this.left = left;\n this.top = top;\n if (left + width > dataWidth || top + height > dataHeight) {\n throw new IllegalArgumentException('Crop rectangle does not fit within image data.');\n }\n if (reverseHorizontal) {\n this.reverseHorizontal(width, height);\n }\n }\n /*@Override*/\n getRow(y /*int*/, row) {\n if (y < 0 || y >= this.getHeight()) {\n throw new IllegalArgumentException('Requested row is outside the image: ' + y);\n }\n const width = this.getWidth();\n if (row === null || row === undefined || row.length < width) {\n row = new Uint8ClampedArray(width);\n }\n const offset = (y + this.top) * this.dataWidth + this.left;\n System.arraycopy(this.yuvData, offset, row, 0, width);\n return row;\n }\n /*@Override*/\n getMatrix() {\n const width = this.getWidth();\n const height = this.getHeight();\n // If the caller asks for the entire underlying image, save the copy and give them the\n // original data. The docs specifically warn that result.length must be ignored.\n if (width === this.dataWidth && height === this.dataHeight) {\n return this.yuvData;\n }\n const area = width * height;\n const matrix = new Uint8ClampedArray(area);\n let inputOffset = this.top * this.dataWidth + this.left;\n // If the width matches the full width of the underlying data, perform a single copy.\n if (width === this.dataWidth) {\n System.arraycopy(this.yuvData, inputOffset, matrix, 0, area);\n return matrix;\n }\n // Otherwise copy one cropped row at a time.\n for (let y = 0; y < height; y++) {\n const outputOffset = y * width;\n System.arraycopy(this.yuvData, inputOffset, matrix, outputOffset, width);\n inputOffset += this.dataWidth;\n }\n return matrix;\n }\n /*@Override*/\n isCropSupported() {\n return true;\n }\n /*@Override*/\n crop(left /*int*/, top /*int*/, width /*int*/, height /*int*/) {\n return new PlanarYUVLuminanceSource(this.yuvData, this.dataWidth, this.dataHeight, this.left + left, this.top + top, width, height, false);\n }\n renderThumbnail() {\n const width = this.getWidth() / PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR;\n const height = this.getHeight() / PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR;\n const pixels = new Int32Array(width * height);\n const yuv = this.yuvData;\n let inputOffset = this.top * this.dataWidth + this.left;\n for (let y = 0; y < height; y++) {\n const outputOffset = y * width;\n for (let x = 0; x < width; x++) {\n const grey = yuv[inputOffset + x * PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR] & 0xff;\n pixels[outputOffset + x] = 0xFF000000 | (grey * 0x00010101);\n }\n inputOffset += this.dataWidth * PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR;\n }\n return pixels;\n }\n /**\n * @return width of image from {@link #renderThumbnail()}\n */\n getThumbnailWidth() {\n return this.getWidth() / PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR;\n }\n /**\n * @return height of image from {@link #renderThumbnail()}\n */\n getThumbnailHeight() {\n return this.getHeight() / PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR;\n }\n reverseHorizontal(width /*int*/, height /*int*/) {\n const yuvData = this.yuvData;\n for (let y = 0, rowStart = this.top * this.dataWidth + this.left; y < height; y++, rowStart += this.dataWidth) {\n const middle = rowStart + width / 2;\n for (let x1 = rowStart, x2 = rowStart + width - 1; x1 < middle; x1++, x2--) {\n const temp = yuvData[x1];\n yuvData[x1] = yuvData[x2];\n yuvData[x2] = temp;\n }\n }\n }\n invert() {\n return new InvertedLuminanceSource(this);\n }\n }\n PlanarYUVLuminanceSource.THUMBNAIL_SCALE_FACTOR = 2;\n\n /*\n * Copyright 2009 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * This class is used to help decode images from files which arrive as RGB data from\n * an ARGB pixel array. It does not support rotation.\n *\n * @author dswitkin@google.com (Daniel Switkin)\n * @author Betaminos\n */\n class RGBLuminanceSource extends LuminanceSource {\n constructor(luminances, width /*int*/, height /*int*/, dataWidth /*int*/, dataHeight /*int*/, left /*int*/, top /*int*/) {\n super(width, height);\n this.dataWidth = dataWidth;\n this.dataHeight = dataHeight;\n this.left = left;\n this.top = top;\n if (luminances.BYTES_PER_ELEMENT === 4) { // Int32Array\n const size = width * height;\n const luminancesUint8Array = new Uint8ClampedArray(size);\n for (let offset = 0; offset < size; offset++) {\n const pixel = luminances[offset];\n const r = (pixel >> 16) & 0xff; // red\n const g2 = (pixel >> 7) & 0x1fe; // 2 * green\n const b = pixel & 0xff; // blue\n // Calculate green-favouring average cheaply\n luminancesUint8Array[offset] = /*(byte) */ ((r + g2 + b) / 4) & 0xFF;\n }\n this.luminances = luminancesUint8Array;\n }\n else {\n this.luminances = luminances;\n }\n if (undefined === dataWidth) {\n this.dataWidth = width;\n }\n if (undefined === dataHeight) {\n this.dataHeight = height;\n }\n if (undefined === left) {\n this.left = 0;\n }\n if (undefined === top) {\n this.top = 0;\n }\n if (this.left + width > this.dataWidth || this.top + height > this.dataHeight) {\n throw new IllegalArgumentException('Crop rectangle does not fit within image data.');\n }\n }\n /*@Override*/\n getRow(y /*int*/, row) {\n if (y < 0 || y >= this.getHeight()) {\n throw new IllegalArgumentException('Requested row is outside the image: ' + y);\n }\n const width = this.getWidth();\n if (row === null || row === undefined || row.length < width) {\n row = new Uint8ClampedArray(width);\n }\n const offset = (y + this.top) * this.dataWidth + this.left;\n System.arraycopy(this.luminances, offset, row, 0, width);\n return row;\n }\n /*@Override*/\n getMatrix() {\n const width = this.getWidth();\n const height = this.getHeight();\n // If the caller asks for the entire underlying image, save the copy and give them the\n // original data. The docs specifically warn that result.length must be ignored.\n if (width === this.dataWidth && height === this.dataHeight) {\n return this.luminances;\n }\n const area = width * height;\n const matrix = new Uint8ClampedArray(area);\n let inputOffset = this.top * this.dataWidth + this.left;\n // If the width matches the full width of the underlying data, perform a single copy.\n if (width === this.dataWidth) {\n System.arraycopy(this.luminances, inputOffset, matrix, 0, area);\n return matrix;\n }\n // Otherwise copy one cropped row at a time.\n for (let y = 0; y < height; y++) {\n const outputOffset = y * width;\n System.arraycopy(this.luminances, inputOffset, matrix, outputOffset, width);\n inputOffset += this.dataWidth;\n }\n return matrix;\n }\n /*@Override*/\n isCropSupported() {\n return true;\n }\n /*@Override*/\n crop(left /*int*/, top /*int*/, width /*int*/, height /*int*/) {\n return new RGBLuminanceSource(this.luminances, width, height, this.dataWidth, this.dataHeight, this.left + left, this.top + top);\n }\n invert() {\n return new InvertedLuminanceSource(this);\n }\n }\n\n /**\n * Just to make a shortcut between Java code and TS code.\n */\n class Charset extends CharacterSetECI {\n static forName(name) {\n return this.getCharacterSetECIByName(name);\n }\n }\n\n /**\n * Just to make a shortcut between Java code and TS code.\n */\n class StandardCharsets {\n }\n StandardCharsets.ISO_8859_1 = CharacterSetECI.ISO8859_1;\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * Aztec 2D code representation\n *\n * @author Rustam Abdullaev\n */\n /*public final*/ class AztecCode {\n /**\n * @return {@code true} if compact instead of full mode\n */\n isCompact() {\n return this.compact;\n }\n setCompact(compact) {\n this.compact = compact;\n }\n /**\n * @return size in pixels (width and height)\n */\n getSize() {\n return this.size;\n }\n setSize(size) {\n this.size = size;\n }\n /**\n * @return number of levels\n */\n getLayers() {\n return this.layers;\n }\n setLayers(layers) {\n this.layers = layers;\n }\n /**\n * @return number of data codewords\n */\n getCodeWords() {\n return this.codeWords;\n }\n setCodeWords(codeWords) {\n this.codeWords = codeWords;\n }\n /**\n * @return the symbol image\n */\n getMatrix() {\n return this.matrix;\n }\n setMatrix(matrix) {\n this.matrix = matrix;\n }\n }\n\n class Collections {\n /**\n * The singletonList(T) method is used to return an immutable list containing only the specified object.\n */\n static singletonList(item) {\n return [item];\n }\n /**\n * The min(Collection, Comparator) method is used to return the minimum element of the given collection, according to the order induced by the specified comparator.\n */\n static min(collection, comparator) {\n return collection.sort(comparator)[0];\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n class Token {\n constructor(previous) {\n this.previous = previous;\n }\n getPrevious() {\n return this.previous;\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*final*/ class SimpleToken extends Token {\n constructor(previous, value, bitCount) {\n super(previous);\n this.value = value;\n this.bitCount = bitCount;\n }\n /**\n * @Override\n */\n appendTo(bitArray, text) {\n bitArray.appendBits(this.value, this.bitCount);\n }\n add(value, bitCount) {\n return new SimpleToken(this, value, bitCount);\n }\n addBinaryShift(start, byteCount) {\n // no-op can't binary shift a simple token\n console.warn('addBinaryShift on SimpleToken, this simply returns a copy of this token');\n return new SimpleToken(this, start, byteCount);\n }\n /**\n * @Override\n */\n toString() {\n let value = this.value & ((1 << this.bitCount) - 1);\n value |= 1 << this.bitCount;\n return '<' + Integer.toBinaryString(value | (1 << this.bitCount)).substring(1) + '>';\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /*final*/ class BinaryShiftToken extends SimpleToken {\n constructor(previous, binaryShiftStart, binaryShiftByteCount) {\n super(previous, 0, 0);\n this.binaryShiftStart = binaryShiftStart;\n this.binaryShiftByteCount = binaryShiftByteCount;\n }\n /**\n * @Override\n */\n appendTo(bitArray, text) {\n for (let i = 0; i < this.binaryShiftByteCount; i++) {\n if (i === 0 || (i === 31 && this.binaryShiftByteCount <= 62)) {\n // We need a header before the first character, and before\n // character 31 when the total byte code is <= 62\n bitArray.appendBits(31, 5); // BINARY_SHIFT\n if (this.binaryShiftByteCount > 62) {\n bitArray.appendBits(this.binaryShiftByteCount - 31, 16);\n }\n else if (i === 0) {\n // 1 <= binaryShiftByteCode <= 62\n bitArray.appendBits(Math.min(this.binaryShiftByteCount, 31), 5);\n }\n else {\n // 32 <= binaryShiftCount <= 62 and i == 31\n bitArray.appendBits(this.binaryShiftByteCount - 31, 5);\n }\n }\n bitArray.appendBits(text[this.binaryShiftStart + i], 8);\n }\n }\n addBinaryShift(start, byteCount) {\n // int bitCount = (byteCount * 8) + (byteCount <= 31 ? 10 : byteCount <= 62 ? 20 : 21);\n return new BinaryShiftToken(this, start, byteCount);\n }\n /**\n * @Override\n */\n toString() {\n return '<' + this.binaryShiftStart + '::' + (this.binaryShiftStart + this.binaryShiftByteCount - 1) + '>';\n }\n }\n\n function addBinaryShift(token, start, byteCount) {\n // int bitCount = (byteCount * 8) + (byteCount <= 31 ? 10 : byteCount <= 62 ? 20 : 21);\n return new BinaryShiftToken(token, start, byteCount);\n }\n function add(token, value, bitCount) {\n return new SimpleToken(token, value, bitCount);\n }\n\n const /*final*/ MODE_NAMES = [\n 'UPPER',\n 'LOWER',\n 'DIGIT',\n 'MIXED',\n 'PUNCT'\n ];\n const /*final*/ MODE_UPPER = 0; // 5 bits\n const /*final*/ MODE_LOWER = 1; // 5 bits\n const /*final*/ MODE_DIGIT = 2; // 4 bits\n const /*final*/ MODE_MIXED = 3; // 5 bits\n const /*final*/ MODE_PUNCT = 4; // 5 bits\n const EMPTY_TOKEN = new SimpleToken(null, 0, 0);\n\n // The Latch Table shows, for each pair of Modes, the optimal method for\n // getting from one mode to another. In the worst possible case, this can\n // be up to 14 bits. In the best possible case, we are already there!\n // The high half-word of each entry gives the number of bits.\n // The low half-word of each entry are the actual bits necessary to change\n const LATCH_TABLE = [\n Int32Array.from([\n 0,\n (5 << 16) + 28,\n (5 << 16) + 30,\n (5 << 16) + 29,\n (10 << 16) + (29 << 5) + 30 // UPPER -> MIXED -> PUNCT\n ]),\n Int32Array.from([\n (9 << 16) + (30 << 4) + 14,\n 0,\n (5 << 16) + 30,\n (5 << 16) + 29,\n (10 << 16) + (29 << 5) + 30 // LOWER -> MIXED -> PUNCT\n ]),\n Int32Array.from([\n (4 << 16) + 14,\n (9 << 16) + (14 << 5) + 28,\n 0,\n (9 << 16) + (14 << 5) + 29,\n (14 << 16) + (14 << 10) + (29 << 5) + 30\n // DIGIT -> UPPER -> MIXED -> PUNCT\n ]),\n Int32Array.from([\n (5 << 16) + 29,\n (5 << 16) + 28,\n (10 << 16) + (29 << 5) + 30,\n 0,\n (5 << 16) + 30 // MIXED -> PUNCT\n ]),\n Int32Array.from([\n (5 << 16) + 31,\n (10 << 16) + (31 << 5) + 28,\n (10 << 16) + (31 << 5) + 30,\n (10 << 16) + (31 << 5) + 29,\n 0\n ])\n ];\n\n function static_SHIFT_TABLE(SHIFT_TABLE) {\n for (let table /*Int32Array*/ of SHIFT_TABLE) {\n Arrays.fill(table, -1);\n }\n SHIFT_TABLE[MODE_UPPER][MODE_PUNCT] = 0;\n SHIFT_TABLE[MODE_LOWER][MODE_PUNCT] = 0;\n SHIFT_TABLE[MODE_LOWER][MODE_UPPER] = 28;\n SHIFT_TABLE[MODE_MIXED][MODE_PUNCT] = 0;\n SHIFT_TABLE[MODE_DIGIT][MODE_PUNCT] = 0;\n SHIFT_TABLE[MODE_DIGIT][MODE_UPPER] = 15;\n return SHIFT_TABLE;\n }\n const /*final*/ SHIFT_TABLE = static_SHIFT_TABLE(Arrays.createInt32Array(6, 6)); // mode shift codes, per table\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * State represents all information about a sequence necessary to generate the current output.\n * Note that a state is immutable.\n */\n /*final*/ class State {\n constructor(token, mode, binaryBytes, bitCount) {\n this.token = token;\n this.mode = mode;\n this.binaryShiftByteCount = binaryBytes;\n this.bitCount = bitCount;\n // Make sure we match the token\n // int binaryShiftBitCount = (binaryShiftByteCount * 8) +\n // (binaryShiftByteCount === 0 ? 0 :\n // binaryShiftByteCount <= 31 ? 10 :\n // binaryShiftByteCount <= 62 ? 20 : 21);\n // assert this.bitCount === token.getTotalBitCount() + binaryShiftBitCount;\n }\n getMode() {\n return this.mode;\n }\n getToken() {\n return this.token;\n }\n getBinaryShiftByteCount() {\n return this.binaryShiftByteCount;\n }\n getBitCount() {\n return this.bitCount;\n }\n // Create a new state representing this state with a latch to a (not\n // necessary different) mode, and then a code.\n latchAndAppend(mode, value) {\n // assert binaryShiftByteCount === 0;\n let bitCount = this.bitCount;\n let token = this.token;\n if (mode !== this.mode) {\n let latch = LATCH_TABLE[this.mode][mode];\n token = add(token, latch & 0xffff, latch >> 16);\n bitCount += latch >> 16;\n }\n let latchModeBitCount = mode === MODE_DIGIT ? 4 : 5;\n token = add(token, value, latchModeBitCount);\n return new State(token, mode, 0, bitCount + latchModeBitCount);\n }\n // Create a new state representing this state, with a temporary shift\n // to a different mode to output a single value.\n shiftAndAppend(mode, value) {\n // assert binaryShiftByteCount === 0 && this.mode !== mode;\n let token = this.token;\n let thisModeBitCount = this.mode === MODE_DIGIT ? 4 : 5;\n // Shifts exist only to UPPER and PUNCT, both with tokens size 5.\n token = add(token, SHIFT_TABLE[this.mode][mode], thisModeBitCount);\n token = add(token, value, 5);\n return new State(token, this.mode, 0, this.bitCount + thisModeBitCount + 5);\n }\n // Create a new state representing this state, but an additional character\n // output in Binary Shift mode.\n addBinaryShiftChar(index) {\n let token = this.token;\n let mode = this.mode;\n let bitCount = this.bitCount;\n if (this.mode === MODE_PUNCT || this.mode === MODE_DIGIT) {\n // assert binaryShiftByteCount === 0;\n let latch = LATCH_TABLE[mode][MODE_UPPER];\n token = add(token, latch & 0xffff, latch >> 16);\n bitCount += latch >> 16;\n mode = MODE_UPPER;\n }\n let deltaBitCount = this.binaryShiftByteCount === 0 || this.binaryShiftByteCount === 31\n ? 18\n : this.binaryShiftByteCount === 62\n ? 9\n : 8;\n let result = new State(token, mode, this.binaryShiftByteCount + 1, bitCount + deltaBitCount);\n if (result.binaryShiftByteCount === 2047 + 31) {\n // The string is as long as it's allowed to be. We should end it.\n result = result.endBinaryShift(index + 1);\n }\n return result;\n }\n // Create the state identical to this one, but we are no longer in\n // Binary Shift mode.\n endBinaryShift(index) {\n if (this.binaryShiftByteCount === 0) {\n return this;\n }\n let token = this.token;\n token = addBinaryShift(token, index - this.binaryShiftByteCount, this.binaryShiftByteCount);\n // assert token.getTotalBitCount() === this.bitCount;\n return new State(token, this.mode, 0, this.bitCount);\n }\n // Returns true if \"this\" state is better (equal: or) to be in than \"that\"\n // state under all possible circumstances.\n isBetterThanOrEqualTo(other) {\n let newModeBitCount = this.bitCount + (LATCH_TABLE[this.mode][other.mode] >> 16);\n if (this.binaryShiftByteCount < other.binaryShiftByteCount) {\n // add additional B/S encoding cost of other, if any\n newModeBitCount +=\n State.calculateBinaryShiftCost(other) -\n State.calculateBinaryShiftCost(this);\n }\n else if (this.binaryShiftByteCount > other.binaryShiftByteCount &&\n other.binaryShiftByteCount > 0) {\n // maximum possible additional cost (it: h)\n newModeBitCount += 10;\n }\n return newModeBitCount <= other.bitCount;\n }\n toBitArray(text) {\n // Reverse the tokens, so that they are in the order that they should\n // be output\n let symbols = [];\n for (let token = this.endBinaryShift(text.length).token; token !== null; token = token.getPrevious()) {\n symbols.unshift(token);\n }\n let bitArray = new BitArray();\n // Add each token to the result.\n for (const symbol of symbols) {\n symbol.appendTo(bitArray, text);\n }\n // assert bitArray.getSize() === this.bitCount;\n return bitArray;\n }\n /**\n * @Override\n */\n toString() {\n return StringUtils.format('%s bits=%d bytes=%d', MODE_NAMES[this.mode], this.bitCount, this.binaryShiftByteCount);\n }\n static calculateBinaryShiftCost(state) {\n if (state.binaryShiftByteCount > 62) {\n return 21; // B/S with extended length\n }\n if (state.binaryShiftByteCount > 31) {\n return 20; // two B/S\n }\n if (state.binaryShiftByteCount > 0) {\n return 10; // one B/S\n }\n return 0;\n }\n }\n State.INITIAL_STATE = new State(EMPTY_TOKEN, MODE_UPPER, 0, 0);\n\n function static_CHAR_MAP(CHAR_MAP) {\n const spaceCharCode = StringUtils.getCharCode(' ');\n const pointCharCode = StringUtils.getCharCode('.');\n const commaCharCode = StringUtils.getCharCode(',');\n CHAR_MAP[MODE_UPPER][spaceCharCode] = 1;\n const zUpperCharCode = StringUtils.getCharCode('Z');\n const aUpperCharCode = StringUtils.getCharCode('A');\n for (let c = aUpperCharCode; c <= zUpperCharCode; c++) {\n CHAR_MAP[MODE_UPPER][c] = c - aUpperCharCode + 2;\n }\n CHAR_MAP[MODE_LOWER][spaceCharCode] = 1;\n const zLowerCharCode = StringUtils.getCharCode('z');\n const aLowerCharCode = StringUtils.getCharCode('a');\n for (let c = aLowerCharCode; c <= zLowerCharCode; c++) {\n CHAR_MAP[MODE_LOWER][c] = c - aLowerCharCode + 2;\n }\n CHAR_MAP[MODE_DIGIT][spaceCharCode] = 1;\n const nineCharCode = StringUtils.getCharCode('9');\n const zeroCharCode = StringUtils.getCharCode('0');\n for (let c = zeroCharCode; c <= nineCharCode; c++) {\n CHAR_MAP[MODE_DIGIT][c] = c - zeroCharCode + 2;\n }\n CHAR_MAP[MODE_DIGIT][commaCharCode] = 12;\n CHAR_MAP[MODE_DIGIT][pointCharCode] = 13;\n const mixedTable = [\n '\\x00',\n ' ',\n '\\x01',\n '\\x02',\n '\\x03',\n '\\x04',\n '\\x05',\n '\\x06',\n '\\x07',\n '\\b',\n '\\t',\n '\\n',\n '\\x0b',\n '\\f',\n '\\r',\n '\\x1b',\n '\\x1c',\n '\\x1d',\n '\\x1e',\n '\\x1f',\n '@',\n '\\\\',\n '^',\n '_',\n '`',\n '|',\n '~',\n '\\x7f'\n ];\n for (let i = 0; i < mixedTable.length; i++) {\n CHAR_MAP[MODE_MIXED][StringUtils.getCharCode(mixedTable[i])] = i;\n }\n const punctTable = [\n '\\x00',\n '\\r',\n '\\x00',\n '\\x00',\n '\\x00',\n '\\x00',\n '!',\n '\\'',\n '#',\n '$',\n '%',\n '&',\n '\\'',\n '(',\n ')',\n '*',\n '+',\n ',',\n '-',\n '.',\n '/',\n ':',\n ';',\n '<',\n '=',\n '>',\n '?',\n '[',\n ']',\n '{',\n '}'\n ];\n for (let i = 0; i < punctTable.length; i++) {\n if (StringUtils.getCharCode(punctTable[i]) > 0) {\n CHAR_MAP[MODE_PUNCT][StringUtils.getCharCode(punctTable[i])] = i;\n }\n }\n return CHAR_MAP;\n }\n const CHAR_MAP = static_CHAR_MAP(Arrays.createInt32Array(5, 256));\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * This produces nearly optimal encodings of text into the first-level of\n * encoding used by Aztec code.\n *\n * It uses a dynamic algorithm. For each prefix of the string, it determines\n * a set of encodings that could lead to this prefix. We repeatedly add a\n * character and generate a new set of optimal encodings until we have read\n * through the entire input.\n *\n * @author Frank Yellin\n * @author Rustam Abdullaev\n */\n /*public final*/ class HighLevelEncoder {\n constructor(text) {\n this.text = text;\n }\n /**\n * @return text represented by this encoder encoded as a {@link BitArray}\n */\n encode() {\n const spaceCharCode = StringUtils.getCharCode(' ');\n const lineBreakCharCode = StringUtils.getCharCode('\\n');\n let states = Collections.singletonList(State.INITIAL_STATE);\n for (let index = 0; index < this.text.length; index++) {\n let pairCode;\n let nextChar = index + 1 < this.text.length ? this.text[index + 1] : 0;\n switch (this.text[index]) {\n case StringUtils.getCharCode('\\r'):\n pairCode = nextChar === lineBreakCharCode ? 2 : 0;\n break;\n case StringUtils.getCharCode('.'):\n pairCode = nextChar === spaceCharCode ? 3 : 0;\n break;\n case StringUtils.getCharCode(','):\n pairCode = nextChar === spaceCharCode ? 4 : 0;\n break;\n case StringUtils.getCharCode(':'):\n pairCode = nextChar === spaceCharCode ? 5 : 0;\n break;\n default:\n pairCode = 0;\n }\n if (pairCode > 0) {\n // We have one of the four special PUNCT pairs. Treat them specially.\n // Get a new set of states for the two new characters.\n states = HighLevelEncoder.updateStateListForPair(states, index, pairCode);\n index++;\n }\n else {\n // Get a new set of states for the new character.\n states = this.updateStateListForChar(states, index);\n }\n }\n // We are left with a set of states. Find the shortest one.\n const minState = Collections.min(states, (a, b) => {\n return a.getBitCount() - b.getBitCount();\n });\n // Convert it to a bit array, and return.\n return minState.toBitArray(this.text);\n }\n // We update a set of states for a new character by updating each state\n // for the new character, merging the results, and then removing the\n // non-optimal states.\n updateStateListForChar(states, index) {\n const result = [];\n for (let state /*State*/ of states) {\n this.updateStateForChar(state, index, result);\n }\n return HighLevelEncoder.simplifyStates(result);\n }\n // Return a set of states that represent the possible ways of updating this\n // state for the next character. The resulting set of states are added to\n // the \"result\" list.\n updateStateForChar(state, index, result) {\n let ch = (this.text[index] & 0xff);\n let charInCurrentTable = CHAR_MAP[state.getMode()][ch] > 0;\n let stateNoBinary = null;\n for (let mode /*int*/ = 0; mode <= MODE_PUNCT; mode++) {\n let charInMode = CHAR_MAP[mode][ch];\n if (charInMode > 0) {\n if (stateNoBinary == null) {\n // Only create stateNoBinary the first time it's required.\n stateNoBinary = state.endBinaryShift(index);\n }\n // Try generating the character by latching to its mode\n if (!charInCurrentTable ||\n mode === state.getMode() ||\n mode === MODE_DIGIT) {\n // If the character is in the current table, we don't want to latch to\n // any other mode except possibly digit (which uses only 4 bits). Any\n // other latch would be equally successful *after* this character, and\n // so wouldn't save any bits.\n const latchState = stateNoBinary.latchAndAppend(mode, charInMode);\n result.push(latchState);\n }\n // Try generating the character by switching to its mode.\n if (!charInCurrentTable &&\n SHIFT_TABLE[state.getMode()][mode] >= 0) {\n // It never makes sense to temporarily shift to another mode if the\n // character exists in the current mode. That can never save bits.\n const shiftState = stateNoBinary.shiftAndAppend(mode, charInMode);\n result.push(shiftState);\n }\n }\n }\n if (state.getBinaryShiftByteCount() > 0 ||\n CHAR_MAP[state.getMode()][ch] === 0) {\n // It's never worthwhile to go into binary shift mode if you're not already\n // in binary shift mode, and the character exists in your current mode.\n // That can never save bits over just outputting the char in the current mode.\n let binaryState = state.addBinaryShiftChar(index);\n result.push(binaryState);\n }\n }\n static updateStateListForPair(states, index, pairCode) {\n const result = [];\n for (let state /*State*/ of states) {\n this.updateStateForPair(state, index, pairCode, result);\n }\n return this.simplifyStates(result);\n }\n static updateStateForPair(state, index, pairCode, result) {\n let stateNoBinary = state.endBinaryShift(index);\n // Possibility 1. Latch to C.MODE_PUNCT, and then append this code\n result.push(stateNoBinary.latchAndAppend(MODE_PUNCT, pairCode));\n if (state.getMode() !== MODE_PUNCT) {\n // Possibility 2. Shift to C.MODE_PUNCT, and then append this code.\n // Every state except C.MODE_PUNCT (handled above) can shift\n result.push(stateNoBinary.shiftAndAppend(MODE_PUNCT, pairCode));\n }\n if (pairCode === 3 || pairCode === 4) {\n // both characters are in DIGITS. Sometimes better to just add two digits\n let digitState = stateNoBinary\n .latchAndAppend(MODE_DIGIT, 16 - pairCode) // period or comma in DIGIT\n .latchAndAppend(MODE_DIGIT, 1); // space in DIGIT\n result.push(digitState);\n }\n if (state.getBinaryShiftByteCount() > 0) {\n // It only makes sense to do the characters as binary if we're already\n // in binary mode.\n let binaryState = state\n .addBinaryShiftChar(index)\n .addBinaryShiftChar(index + 1);\n result.push(binaryState);\n }\n }\n static simplifyStates(states) {\n let result = [];\n for (const newState of states) {\n let add = true;\n for (const oldState of result) {\n if (oldState.isBetterThanOrEqualTo(newState)) {\n add = false;\n break;\n }\n if (newState.isBetterThanOrEqualTo(oldState)) {\n // iterator.remove();\n result = result.filter(x => x !== oldState); // remove old state\n }\n }\n if (add) {\n result.push(newState);\n }\n }\n return result;\n }\n }\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n // package com.google.zxing.aztec.encoder;\n // import com.google.zxing.common.BitArray;\n // import com.google.zxing.common.BitMatrix;\n // import com.google.zxing.common.reedsolomon.GenericGF;\n // import com.google.zxing.common.reedsolomon.ReedSolomonEncoder;\n /**\n * Generates Aztec 2D barcodes.\n *\n * @author Rustam Abdullaev\n */\n /*public final*/ class Encoder$1 {\n constructor() {\n }\n /**\n * Encodes the given binary content as an Aztec symbol\n *\n * @param data input data string\n * @return Aztec symbol matrix with metadata\n */\n static encodeBytes(data) {\n return Encoder$1.encode(data, Encoder$1.DEFAULT_EC_PERCENT, Encoder$1.DEFAULT_AZTEC_LAYERS);\n }\n /**\n * Encodes the given binary content as an Aztec symbol\n *\n * @param data input data string\n * @param minECCPercent minimal percentage of error check words (According to ISO/IEC 24778:2008,\n * a minimum of 23% + 3 words is recommended)\n * @param userSpecifiedLayers if non-zero, a user-specified value for the number of layers\n * @return Aztec symbol matrix with metadata\n */\n static encode(data, minECCPercent, userSpecifiedLayers) {\n // High-level encode\n let bits = new HighLevelEncoder(data).encode();\n // stuff bits and choose symbol size\n let eccBits = Integer.truncDivision((bits.getSize() * minECCPercent), 100) + 11;\n let totalSizeBits = bits.getSize() + eccBits;\n let compact;\n let layers;\n let totalBitsInLayer;\n let wordSize;\n let stuffedBits;\n if (userSpecifiedLayers !== Encoder$1.DEFAULT_AZTEC_LAYERS) {\n compact = userSpecifiedLayers < 0;\n layers = Math.abs(userSpecifiedLayers);\n if (layers > (compact ? Encoder$1.MAX_NB_BITS_COMPACT : Encoder$1.MAX_NB_BITS)) {\n throw new IllegalArgumentException(StringUtils.format('Illegal value %s for layers', userSpecifiedLayers));\n }\n totalBitsInLayer = Encoder$1.totalBitsInLayer(layers, compact);\n wordSize = Encoder$1.WORD_SIZE[layers];\n let usableBitsInLayers = totalBitsInLayer - (totalBitsInLayer % wordSize);\n stuffedBits = Encoder$1.stuffBits(bits, wordSize);\n if (stuffedBits.getSize() + eccBits > usableBitsInLayers) {\n throw new IllegalArgumentException('Data to large for user specified layer');\n }\n if (compact && stuffedBits.getSize() > wordSize * 64) {\n // Compact format only allows 64 data words, though C4 can hold more words than that\n throw new IllegalArgumentException('Data to large for user specified layer');\n }\n }\n else {\n wordSize = 0;\n stuffedBits = null;\n // We look at the possible table sizes in the order Compact1, Compact2, Compact3,\n // Compact4, Normal4,... Normal(i) for i < 4 isn't typically used since Compact(i+1)\n // is the same size, but has more data.\n for (let i /*int*/ = 0;; i++) {\n if (i > Encoder$1.MAX_NB_BITS) {\n throw new IllegalArgumentException('Data too large for an Aztec code');\n }\n compact = i <= 3;\n layers = compact ? i + 1 : i;\n totalBitsInLayer = Encoder$1.totalBitsInLayer(layers, compact);\n if (totalSizeBits > totalBitsInLayer) {\n continue;\n }\n // [Re]stuff the bits if this is the first opportunity, or if the\n // wordSize has changed\n if (stuffedBits == null || wordSize !== Encoder$1.WORD_SIZE[layers]) {\n wordSize = Encoder$1.WORD_SIZE[layers];\n stuffedBits = Encoder$1.stuffBits(bits, wordSize);\n }\n let usableBitsInLayers = totalBitsInLayer - (totalBitsInLayer % wordSize);\n if (compact && stuffedBits.getSize() > wordSize * 64) {\n // Compact format only allows 64 data words, though C4 can hold more words than that\n continue;\n }\n if (stuffedBits.getSize() + eccBits <= usableBitsInLayers) {\n break;\n }\n }\n }\n let messageBits = Encoder$1.generateCheckWords(stuffedBits, totalBitsInLayer, wordSize);\n // generate mode message\n let messageSizeInWords = stuffedBits.getSize() / wordSize;\n let modeMessage = Encoder$1.generateModeMessage(compact, layers, messageSizeInWords);\n // allocate symbol\n let baseMatrixSize = (compact ? 11 : 14) + layers * 4; // not including alignment lines\n let alignmentMap = new Int32Array(baseMatrixSize);\n let matrixSize;\n if (compact) {\n // no alignment marks in compact mode, alignmentMap is a no-op\n matrixSize = baseMatrixSize;\n for (let i /*int*/ = 0; i < alignmentMap.length; i++) {\n alignmentMap[i] = i;\n }\n }\n else {\n matrixSize = baseMatrixSize + 1 + 2 * Integer.truncDivision((Integer.truncDivision(baseMatrixSize, 2) - 1), 15);\n let origCenter = Integer.truncDivision(baseMatrixSize, 2);\n let center = Integer.truncDivision(matrixSize, 2);\n for (let i /*int*/ = 0; i < origCenter; i++) {\n let newOffset = i + Integer.truncDivision(i, 15);\n alignmentMap[origCenter - i - 1] = center - newOffset - 1;\n alignmentMap[origCenter + i] = center + newOffset + 1;\n }\n }\n let matrix = new BitMatrix(matrixSize);\n // draw data bits\n for (let i /*int*/ = 0, rowOffset = 0; i < layers; i++) {\n let rowSize = (layers - i) * 4 + (compact ? 9 : 12);\n for (let j /*int*/ = 0; j < rowSize; j++) {\n let columnOffset = j * 2;\n for (let k /*int*/ = 0; k < 2; k++) {\n if (messageBits.get(rowOffset + columnOffset + k)) {\n matrix.set(alignmentMap[i * 2 + k], alignmentMap[i * 2 + j]);\n }\n if (messageBits.get(rowOffset + rowSize * 2 + columnOffset + k)) {\n matrix.set(alignmentMap[i * 2 + j], alignmentMap[baseMatrixSize - 1 - i * 2 - k]);\n }\n if (messageBits.get(rowOffset + rowSize * 4 + columnOffset + k)) {\n matrix.set(alignmentMap[baseMatrixSize - 1 - i * 2 - k], alignmentMap[baseMatrixSize - 1 - i * 2 - j]);\n }\n if (messageBits.get(rowOffset + rowSize * 6 + columnOffset + k)) {\n matrix.set(alignmentMap[baseMatrixSize - 1 - i * 2 - j], alignmentMap[i * 2 + k]);\n }\n }\n }\n rowOffset += rowSize * 8;\n }\n // draw mode message\n Encoder$1.drawModeMessage(matrix, compact, matrixSize, modeMessage);\n // draw alignment marks\n if (compact) {\n Encoder$1.drawBullsEye(matrix, Integer.truncDivision(matrixSize, 2), 5);\n }\n else {\n Encoder$1.drawBullsEye(matrix, Integer.truncDivision(matrixSize, 2), 7);\n for (let i /*int*/ = 0, j = 0; i < Integer.truncDivision(baseMatrixSize, 2) - 1; i += 15, j += 16) {\n for (let k /*int*/ = Integer.truncDivision(matrixSize, 2) & 1; k < matrixSize; k += 2) {\n matrix.set(Integer.truncDivision(matrixSize, 2) - j, k);\n matrix.set(Integer.truncDivision(matrixSize, 2) + j, k);\n matrix.set(k, Integer.truncDivision(matrixSize, 2) - j);\n matrix.set(k, Integer.truncDivision(matrixSize, 2) + j);\n }\n }\n }\n let aztec = new AztecCode();\n aztec.setCompact(compact);\n aztec.setSize(matrixSize);\n aztec.setLayers(layers);\n aztec.setCodeWords(messageSizeInWords);\n aztec.setMatrix(matrix);\n return aztec;\n }\n static drawBullsEye(matrix, center, size) {\n for (let i /*int*/ = 0; i < size; i += 2) {\n for (let j /*int*/ = center - i; j <= center + i; j++) {\n matrix.set(j, center - i);\n matrix.set(j, center + i);\n matrix.set(center - i, j);\n matrix.set(center + i, j);\n }\n }\n matrix.set(center - size, center - size);\n matrix.set(center - size + 1, center - size);\n matrix.set(center - size, center - size + 1);\n matrix.set(center + size, center - size);\n matrix.set(center + size, center - size + 1);\n matrix.set(center + size, center + size - 1);\n }\n static generateModeMessage(compact, layers, messageSizeInWords) {\n let modeMessage = new BitArray();\n if (compact) {\n modeMessage.appendBits(layers - 1, 2);\n modeMessage.appendBits(messageSizeInWords - 1, 6);\n modeMessage = Encoder$1.generateCheckWords(modeMessage, 28, 4);\n }\n else {\n modeMessage.appendBits(layers - 1, 5);\n modeMessage.appendBits(messageSizeInWords - 1, 11);\n modeMessage = Encoder$1.generateCheckWords(modeMessage, 40, 4);\n }\n return modeMessage;\n }\n static drawModeMessage(matrix, compact, matrixSize, modeMessage) {\n let center = Integer.truncDivision(matrixSize, 2);\n if (compact) {\n for (let i /*int*/ = 0; i < 7; i++) {\n let offset = center - 3 + i;\n if (modeMessage.get(i)) {\n matrix.set(offset, center - 5);\n }\n if (modeMessage.get(i + 7)) {\n matrix.set(center + 5, offset);\n }\n if (modeMessage.get(20 - i)) {\n matrix.set(offset, center + 5);\n }\n if (modeMessage.get(27 - i)) {\n matrix.set(center - 5, offset);\n }\n }\n }\n else {\n for (let i /*int*/ = 0; i < 10; i++) {\n let offset = center - 5 + i + Integer.truncDivision(i, 5);\n if (modeMessage.get(i)) {\n matrix.set(offset, center - 7);\n }\n if (modeMessage.get(i + 10)) {\n matrix.set(center + 7, offset);\n }\n if (modeMessage.get(29 - i)) {\n matrix.set(offset, center + 7);\n }\n if (modeMessage.get(39 - i)) {\n matrix.set(center - 7, offset);\n }\n }\n }\n }\n static generateCheckWords(bitArray, totalBits, wordSize) {\n // bitArray is guaranteed to be a multiple of the wordSize, so no padding needed\n let messageSizeInWords = bitArray.getSize() / wordSize;\n let rs = new ReedSolomonEncoder(Encoder$1.getGF(wordSize));\n let totalWords = Integer.truncDivision(totalBits, wordSize);\n let messageWords = Encoder$1.bitsToWords(bitArray, wordSize, totalWords);\n rs.encode(messageWords, totalWords - messageSizeInWords);\n let startPad = totalBits % wordSize;\n let messageBits = new BitArray();\n messageBits.appendBits(0, startPad);\n for (const messageWord /*: int*/ of Array.from(messageWords)) {\n messageBits.appendBits(messageWord, wordSize);\n }\n return messageBits;\n }\n static bitsToWords(stuffedBits, wordSize, totalWords) {\n let message = new Int32Array(totalWords);\n let i;\n let n;\n for (i = 0, n = stuffedBits.getSize() / wordSize; i < n; i++) {\n let value = 0;\n for (let j /*int*/ = 0; j < wordSize; j++) {\n value |= stuffedBits.get(i * wordSize + j) ? (1 << wordSize - j - 1) : 0;\n }\n message[i] = value;\n }\n return message;\n }\n static getGF(wordSize) {\n switch (wordSize) {\n case 4:\n return GenericGF.AZTEC_PARAM;\n case 6:\n return GenericGF.AZTEC_DATA_6;\n case 8:\n return GenericGF.AZTEC_DATA_8;\n case 10:\n return GenericGF.AZTEC_DATA_10;\n case 12:\n return GenericGF.AZTEC_DATA_12;\n default:\n throw new IllegalArgumentException('Unsupported word size ' + wordSize);\n }\n }\n static stuffBits(bits, wordSize) {\n let out = new BitArray();\n let n = bits.getSize();\n let mask = (1 << wordSize) - 2;\n for (let i /*int*/ = 0; i < n; i += wordSize) {\n let word = 0;\n for (let j /*int*/ = 0; j < wordSize; j++) {\n if (i + j >= n || bits.get(i + j)) {\n word |= 1 << (wordSize - 1 - j);\n }\n }\n if ((word & mask) === mask) {\n out.appendBits(word & mask, wordSize);\n i--;\n }\n else if ((word & mask) === 0) {\n out.appendBits(word | 1, wordSize);\n i--;\n }\n else {\n out.appendBits(word, wordSize);\n }\n }\n return out;\n }\n static totalBitsInLayer(layers, compact) {\n return ((compact ? 88 : 112) + 16 * layers) * layers;\n }\n }\n Encoder$1.DEFAULT_EC_PERCENT = 33; // default minimal percentage of error check words\n Encoder$1.DEFAULT_AZTEC_LAYERS = 0;\n Encoder$1.MAX_NB_BITS = 32;\n Encoder$1.MAX_NB_BITS_COMPACT = 4;\n Encoder$1.WORD_SIZE = Int32Array.from([\n 4, 6, 6, 8, 8, 8, 8, 8, 8, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,\n 12, 12, 12, 12, 12, 12, 12, 12, 12, 12\n ]);\n\n /*\n * Copyright 2013 ZXing authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n /**\n * Renders an Aztec code as a {@link BitMatrix}.\n */\n /*public final*/ class AztecWriter {\n // @Override\n encode(contents, format, width, height) {\n return this.encodeWithHints(contents, format, width, height, null);\n }\n // @Override\n encodeWithHints(contents, format, width, height, hints) {\n let charset = StandardCharsets.ISO_8859_1;\n let eccPercent = Encoder$1.DEFAULT_EC_PERCENT;\n let layers = Encoder$1.DEFAULT_AZTEC_LAYERS;\n if (hints != null) {\n if (hints.has(EncodeHintType$1.CHARACTER_SET)) {\n charset = Charset.forName(hints.get(EncodeHintType$1.CHARACTER_SET).toString());\n }\n if (hints.has(EncodeHintType$1.ERROR_CORRECTION)) {\n eccPercent = Integer.parseInt(hints.get(EncodeHintType$1.ERROR_CORRECTION).toString());\n }\n if (hints.has(EncodeHintType$1.AZTEC_LAYERS)) {\n layers = Integer.parseInt(hints.get(EncodeHintType$1.AZTEC_LAYERS).toString());\n }\n }\n return AztecWriter.encodeLayers(contents, format, width, height, charset, eccPercent, layers);\n }\n static encodeLayers(contents, format, width, height, charset, eccPercent, layers) {\n if (format !== BarcodeFormat$1.AZTEC) {\n throw new IllegalArgumentException('Can only encode AZTEC, but got ' + format);\n }\n let aztec = Encoder$1.encode(StringUtils.getBytes(contents, charset), eccPercent, layers);\n return AztecWriter.renderResult(aztec, width, height);\n }\n static renderResult(code, width, height) {\n let input = code.getMatrix();\n if (input == null) {\n throw new IllegalStateException();\n }\n let inputWidth = input.getWidth();\n let inputHeight = input.getHeight();\n let outputWidth = Math.max(width, inputWidth);\n let outputHeight = Math.max(height, inputHeight);\n let multiple = Math.min(outputWidth / inputWidth, outputHeight / inputHeight);\n let leftPadding = (outputWidth - (inputWidth * multiple)) / 2;\n let topPadding = (outputHeight - (inputHeight * multiple)) / 2;\n let output = new BitMatrix(outputWidth, outputHeight);\n for (let inputY /*int*/ = 0, outputY = topPadding; inputY < inputHeight; inputY++, outputY += multiple) {\n // Write the contents of this row of the barcode\n for (let inputX /*int*/ = 0, outputX = leftPadding; inputX < inputWidth; inputX++, outputX += multiple) {\n if (input.get(inputX, inputY)) {\n output.setRegion(outputX, outputY, multiple, multiple);\n }\n }\n }\n return output;\n }\n }\n\n exports.ArgumentException = ArgumentException;\n exports.ArithmeticException = ArithmeticException;\n exports.AztecCode = AztecCode;\n exports.AztecCodeReader = AztecReader;\n exports.AztecCodeWriter = AztecWriter;\n exports.AztecDecoder = Decoder;\n exports.AztecDetector = Detector;\n exports.AztecDetectorResult = AztecDetectorResult;\n exports.AztecEncoder = Encoder$1;\n exports.AztecHighLevelEncoder = HighLevelEncoder;\n exports.AztecPoint = Point;\n exports.BarcodeFormat = BarcodeFormat$1;\n exports.Binarizer = Binarizer;\n exports.BinaryBitmap = BinaryBitmap;\n exports.BitArray = BitArray;\n exports.BitMatrix = BitMatrix;\n exports.BitSource = BitSource;\n exports.BrowserAztecCodeReader = BrowserAztecCodeReader;\n exports.BrowserBarcodeReader = BrowserBarcodeReader;\n exports.BrowserCodeReader = BrowserCodeReader;\n exports.BrowserDatamatrixCodeReader = BrowserDatamatrixCodeReader;\n exports.BrowserMultiFormatReader = BrowserMultiFormatReader;\n exports.BrowserPDF417Reader = BrowserPDF417Reader;\n exports.BrowserQRCodeReader = BrowserQRCodeReader;\n exports.BrowserQRCodeSvgWriter = BrowserQRCodeSvgWriter;\n exports.CharacterSetECI = CharacterSetECI;\n exports.ChecksumException = ChecksumException;\n exports.Code128Reader = Code128Reader;\n exports.Code39Reader = Code39Reader;\n exports.DataMatrixDecodedBitStreamParser = DecodedBitStreamParser;\n exports.DataMatrixReader = DataMatrixReader;\n exports.DecodeHintType = DecodeHintType$1;\n exports.DecoderResult = DecoderResult;\n exports.DefaultGridSampler = DefaultGridSampler;\n exports.DetectorResult = DetectorResult;\n exports.EAN13Reader = EAN13Reader;\n exports.EncodeHintType = EncodeHintType$1;\n exports.Exception = Exception;\n exports.FormatException = FormatException;\n exports.GenericGF = GenericGF;\n exports.GenericGFPoly = GenericGFPoly;\n exports.GlobalHistogramBinarizer = GlobalHistogramBinarizer;\n exports.GridSampler = GridSampler;\n exports.GridSamplerInstance = GridSamplerInstance;\n exports.HTMLCanvasElementLuminanceSource = HTMLCanvasElementLuminanceSource;\n exports.HybridBinarizer = HybridBinarizer;\n exports.ITFReader = ITFReader;\n exports.IllegalArgumentException = IllegalArgumentException;\n exports.IllegalStateException = IllegalStateException;\n exports.InvertedLuminanceSource = InvertedLuminanceSource;\n exports.LuminanceSource = LuminanceSource;\n exports.MathUtils = MathUtils;\n exports.MultiFormatOneDReader = MultiFormatOneDReader;\n exports.MultiFormatReader = MultiFormatReader;\n exports.MultiFormatWriter = MultiFormatWriter;\n exports.NotFoundException = NotFoundException;\n exports.OneDReader = OneDReader;\n exports.PDF417DecodedBitStreamParser = DecodedBitStreamParser$2;\n exports.PDF417DecoderErrorCorrection = ErrorCorrection;\n exports.PDF417Reader = PDF417Reader;\n exports.PDF417ResultMetadata = PDF417ResultMetadata;\n exports.PerspectiveTransform = PerspectiveTransform;\n exports.PlanarYUVLuminanceSource = PlanarYUVLuminanceSource;\n exports.QRCodeByteMatrix = ByteMatrix;\n exports.QRCodeDataMask = DataMask;\n exports.QRCodeDecodedBitStreamParser = DecodedBitStreamParser$1;\n exports.QRCodeDecoderErrorCorrectionLevel = ErrorCorrectionLevel;\n exports.QRCodeDecoderFormatInformation = FormatInformation;\n exports.QRCodeEncoder = Encoder;\n exports.QRCodeEncoderQRCode = QRCode;\n exports.QRCodeMaskUtil = MaskUtil;\n exports.QRCodeMatrixUtil = MatrixUtil;\n exports.QRCodeMode = Mode$1;\n exports.QRCodeReader = QRCodeReader;\n exports.QRCodeVersion = Version$1;\n exports.QRCodeWriter = QRCodeWriter;\n exports.RGBLuminanceSource = RGBLuminanceSource;\n exports.RSS14Reader = RSS14Reader;\n exports.RSSExpandedReader = RSSExpandedReader;\n exports.ReaderException = ReaderException;\n exports.ReedSolomonDecoder = ReedSolomonDecoder;\n exports.ReedSolomonEncoder = ReedSolomonEncoder;\n exports.ReedSolomonException = ReedSolomonException;\n exports.Result = Result;\n exports.ResultMetadataType = ResultMetadataType$1;\n exports.ResultPoint = ResultPoint;\n exports.StringUtils = StringUtils;\n exports.UnsupportedOperationException = UnsupportedOperationException;\n exports.VideoInputDevice = VideoInputDevice;\n exports.WhiteRectangleDetector = WhiteRectangleDetector;\n exports.WriterException = WriterException;\n exports.ZXingArrays = Arrays;\n exports.ZXingCharset = Charset;\n exports.ZXingInteger = Integer;\n exports.ZXingStandardCharsets = StandardCharsets;\n exports.ZXingStringBuilder = StringBuilder;\n exports.ZXingStringEncoding = StringEncoding;\n exports.ZXingSystem = System;\n\n Object.defineProperty(exports, '__esModule', { value: true });\n\n})));\n//# sourceMappingURL=index.js.map\n","/**\n * @license React\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),ca=require(\"scheduler\");function p(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;cb}return!1}function v(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var z={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){z[a]=new v(a,0,!1,a,null,!1,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];z[b]=new v(b,1,!1,a[1],null,!1,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){z[a]=new v(a,2,!1,a.toLowerCase(),null,!1,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){z[a]=new v(a,2,!1,a,null,!1,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){z[a]=new v(a,3,!1,a.toLowerCase(),null,!1,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){z[a]=new v(a,3,!0,a,null,!1,!1)});[\"capture\",\"download\"].forEach(function(a){z[a]=new v(a,4,!1,a,null,!1,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){z[a]=new v(a,6,!1,a,null,!1,!1)});[\"rowSpan\",\"start\"].forEach(function(a){z[a]=new v(a,5,!1,a.toLowerCase(),null,!1,!1)});var ra=/[\\-:]([a-z])/g;function sa(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(ra,\nsa);z[b]=new v(b,1,!1,a,null,!1,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1,!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1,!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!1,!1)});\nz.xlinkHref=new v(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0,!1);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!0,!0)});\nfunction ta(a,b,c,d){var e=z.hasOwnProperty(b)?z[b]:null;if(null!==e?0!==e.type:d||!(2h||e[g]!==f[h]){var k=\"\\n\"+e[g].replace(\" at new \",\" at \");a.displayName&&k.includes(\"\")&&(k=k.replace(\"\",a.displayName));return k}while(1<=g&&0<=h)}break}}}finally{Na=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:\"\")?Ma(a):\"\"}\nfunction Pa(a){switch(a.tag){case 5:return Ma(a.type);case 16:return Ma(\"Lazy\");case 13:return Ma(\"Suspense\");case 19:return Ma(\"SuspenseList\");case 0:case 2:case 15:return a=Oa(a.type,!1),a;case 11:return a=Oa(a.type.render,!1),a;case 1:return a=Oa(a.type,!0),a;default:return\"\"}}\nfunction Qa(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case ya:return\"Fragment\";case wa:return\"Portal\";case Aa:return\"Profiler\";case za:return\"StrictMode\";case Ea:return\"Suspense\";case Fa:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case Ca:return(a.displayName||\"Context\")+\".Consumer\";case Ba:return(a._context.displayName||\"Context\")+\".Provider\";case Da:var b=a.render;a=a.displayName;a||(a=b.displayName||\nb.name||\"\",a=\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");return a;case Ga:return b=a.displayName||null,null!==b?b:Qa(a.type)||\"Memo\";case Ha:b=a._payload;a=a._init;try{return Qa(a(b))}catch(c){}}return null}\nfunction Ra(a){var b=a.type;switch(a.tag){case 24:return\"Cache\";case 9:return(b.displayName||\"Context\")+\".Consumer\";case 10:return(b._context.displayName||\"Context\")+\".Provider\";case 18:return\"DehydratedFragment\";case 11:return a=b.render,a=a.displayName||a.name||\"\",b.displayName||(\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");case 7:return\"Fragment\";case 5:return b;case 4:return\"Portal\";case 3:return\"Root\";case 6:return\"Text\";case 16:return Qa(b);case 8:return b===za?\"StrictMode\":\"Mode\";case 22:return\"Offscreen\";\ncase 12:return\"Profiler\";case 21:return\"Scope\";case 13:return\"Suspense\";case 19:return\"SuspenseList\";case 25:return\"TracingMarker\";case 1:case 0:case 17:case 2:case 14:case 15:if(\"function\"===typeof b)return b.displayName||b.name||null;if(\"string\"===typeof b)return b}return null}function Sa(a){switch(typeof a){case \"boolean\":case \"number\":case \"string\":case \"undefined\":return a;case \"object\":return a;default:return\"\"}}\nfunction Ta(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction Ua(a){var b=Ta(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=Ta(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}\nfunction Ya(a,b){var c=b.checked;return A({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function ab(a,b){b=b.checked;null!=b&&ta(a,\"checked\",b,!1)}\nfunction bb(a,b){ab(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?cb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&cb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction db(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction cb(a,b,c){if(\"number\"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}var eb=Array.isArray;\nfunction fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e\"+b.valueOf().toString()+\"\";for(b=mb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction ob(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}\nvar pb={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,\nzoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},qb=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(pb).forEach(function(a){qb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);pb[b]=pb[a]})});function rb(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||pb.hasOwnProperty(a)&&pb[a]?(\"\"+b).trim():b+\"px\"}\nfunction sb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=rb(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var tb=A({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction ub(a,b){if(b){if(tb[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(p(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(p(60));if(\"object\"!==typeof b.dangerouslySetInnerHTML||!(\"__html\"in b.dangerouslySetInnerHTML))throw Error(p(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(p(62));}}\nfunction vb(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}var wb=null;function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;\nfunction Bb(a){if(a=Cb(a)){if(\"function\"!==typeof yb)throw Error(p(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;a>>=0;return 0===a?32:31-(pc(a)/qc|0)|0}var rc=64,sc=4194304;\nfunction tc(a){switch(a&-a){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return a&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return a&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;\ndefault:return a}}function uc(a,b){var c=a.pendingLanes;if(0===c)return 0;var d=0,e=a.suspendedLanes,f=a.pingedLanes,g=c&268435455;if(0!==g){var h=g&~e;0!==h?d=tc(h):(f&=g,0!==f&&(d=tc(f)))}else g=c&~e,0!==g?d=tc(g):0!==f&&(d=tc(f));if(0===d)return 0;if(0!==b&&b!==d&&0===(b&e)&&(e=d&-d,f=b&-b,e>=f||16===e&&0!==(f&4194240)))return b;0!==(d&4)&&(d|=c&16);b=a.entangledLanes;if(0!==b)for(a=a.entanglements,b&=d;0c;c++)b.push(a);return b}\nfunction Ac(a,b,c){a.pendingLanes|=b;536870912!==b&&(a.suspendedLanes=0,a.pingedLanes=0);a=a.eventTimes;b=31-oc(b);a[b]=c}function Bc(a,b){var c=a.pendingLanes&~b;a.pendingLanes=b;a.suspendedLanes=0;a.pingedLanes=0;a.expiredLanes&=b;a.mutableReadLanes&=b;a.entangledLanes&=b;b=a.entanglements;var d=a.eventTimes;for(a=a.expirationTimes;0=be),ee=String.fromCharCode(32),fe=!1;\nfunction ge(a,b){switch(a){case \"keyup\":return-1!==$d.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"focusout\":return!0;default:return!1}}function he(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case \"compositionend\":return he(b);case \"keypress\":if(32!==b.which)return null;fe=!0;return ee;case \"textInput\":return a=b.data,a===ee&&fe?null:a;default:return null}}\nfunction ke(a,b){if(ie)return\"compositionend\"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Je(c)}}function Le(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Le(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}\nfunction Me(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Ne(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}\nfunction Oe(a){var b=Me(),c=a.focusedElem,d=a.selectionRange;if(b!==c&&c&&c.ownerDocument&&Le(c.ownerDocument.documentElement,c)){if(null!==d&&Ne(c))if(b=d.start,a=d.end,void 0===a&&(a=b),\"selectionStart\"in c)c.selectionStart=b,c.selectionEnd=Math.min(a,c.value.length);else if(a=(b=c.ownerDocument||document)&&b.defaultView||window,a.getSelection){a=a.getSelection();var e=c.textContent.length,f=Math.min(d.start,e);d=void 0===d.end?f:Math.min(d.end,e);!a.extend&&f>d&&(e=d,d=f,f=e);e=Ke(c,f);var g=Ke(c,\nd);e&&g&&(1!==a.rangeCount||a.anchorNode!==e.node||a.anchorOffset!==e.offset||a.focusNode!==g.node||a.focusOffset!==g.offset)&&(b=b.createRange(),b.setStart(e.node,e.offset),a.removeAllRanges(),f>d?(a.addRange(b),a.extend(g.node,g.offset)):(b.setEnd(g.node,g.offset),a.addRange(b)))}b=[];for(a=c;a=a.parentNode;)1===a.nodeType&&b.push({element:a,left:a.scrollLeft,top:a.scrollTop});\"function\"===typeof c.focus&&c.focus();for(c=0;c=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;\nfunction Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,\"selectionStart\"in d&&Ne(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Ie(Se,d)||(Se=d,d=oe(Re,\"onSelect\"),0Tf||(a.current=Sf[Tf],Sf[Tf]=null,Tf--)}function G(a,b){Tf++;Sf[Tf]=a.current;a.current=b}var Vf={},H=Uf(Vf),Wf=Uf(!1),Xf=Vf;function Yf(a,b){var c=a.type.contextTypes;if(!c)return Vf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}\nfunction Zf(a){a=a.childContextTypes;return null!==a&&void 0!==a}function $f(){E(Wf);E(H)}function ag(a,b,c){if(H.current!==Vf)throw Error(p(168));G(H,b);G(Wf,c)}function bg(a,b,c){var d=a.stateNode;b=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in b))throw Error(p(108,Ra(a)||\"Unknown\",e));return A({},c,d)}\nfunction cg(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Vf;Xf=H.current;G(H,a);G(Wf,Wf.current);return!0}function dg(a,b,c){var d=a.stateNode;if(!d)throw Error(p(169));c?(a=bg(a,b,Xf),d.__reactInternalMemoizedMergedChildContext=a,E(Wf),E(H),G(H,a)):E(Wf);G(Wf,c)}var eg=null,fg=!1,gg=!1;function hg(a){null===eg?eg=[a]:eg.push(a)}function ig(a){fg=!0;hg(a)}\nfunction jg(){if(!gg&&null!==eg){gg=!0;var a=0,b=C;try{var c=eg;for(C=1;a>=g;e-=g;rg=1<<32-oc(b)+e|c<w?(x=u,u=null):x=u.sibling;var n=r(e,u,h[w],k);if(null===n){null===u&&(u=x);break}a&&u&&null===n.alternate&&b(e,u);g=f(n,g,w);null===m?l=n:m.sibling=n;m=n;u=x}if(w===h.length)return c(e,u),I&&tg(e,w),l;if(null===u){for(;ww?(x=m,m=null):x=m.sibling;var t=r(e,m,n.value,k);if(null===t){null===m&&(m=x);break}a&&m&&null===t.alternate&&b(e,m);g=f(t,g,w);null===u?l=t:u.sibling=t;u=t;m=x}if(n.done)return c(e,\nm),I&&tg(e,w),l;if(null===m){for(;!n.done;w++,n=h.next())n=q(e,n.value,k),null!==n&&(g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);I&&tg(e,w);return l}for(m=d(e,m);!n.done;w++,n=h.next())n=y(m,e,w,n.value,k),null!==n&&(a&&null!==n.alternate&&m.delete(null===n.key?w:n.key),g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);a&&m.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function J(a,d,f,h){\"object\"===typeof f&&null!==f&&f.type===ya&&null===f.key&&(f=f.props.children);if(\"object\"===typeof f&&null!==f){switch(f.$$typeof){case va:a:{for(var k=\nf.key,l=d;null!==l;){if(l.key===k){k=f.type;if(k===ya){if(7===l.tag){c(a,l.sibling);d=e(l,f.props.children);d.return=a;a=d;break a}}else if(l.elementType===k||\"object\"===typeof k&&null!==k&&k.$$typeof===Ha&&uh(k)===l.type){c(a,l.sibling);d=e(l,f.props);d.ref=sh(a,l,f);d.return=a;a=d;break a}c(a,l);break}else b(a,l);l=l.sibling}f.type===ya?(d=Ah(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=yh(f.type,f.key,f.props,null,a.mode,h),h.ref=sh(a,d,f),h.return=a,a=h)}return g(a);case wa:a:{for(l=f.key;null!==\nd;){if(d.key===l)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=zh(f,a.mode,h);d.return=a;a=d}return g(a);case Ha:return l=f._init,J(a,d,l(f._payload),h)}if(eb(f))return n(a,d,f,h);if(Ka(f))return t(a,d,f,h);th(a,f)}return\"string\"===typeof f&&\"\"!==f||\"number\"===typeof f?(f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):\n(c(a,d),d=xh(f,a.mode,h),d.return=a,a=d),g(a)):c(a,d)}return J}var Bh=vh(!0),Ch=vh(!1),Dh={},Eh=Uf(Dh),Fh=Uf(Dh),Gh=Uf(Dh);function Hh(a){if(a===Dh)throw Error(p(174));return a}function Ih(a,b){G(Gh,b);G(Fh,a);G(Eh,Dh);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:lb(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=lb(b,a)}E(Eh);G(Eh,b)}function Jh(){E(Eh);E(Fh);E(Gh)}\nfunction Kh(a){Hh(Gh.current);var b=Hh(Eh.current);var c=lb(b,a.type);b!==c&&(G(Fh,a),G(Eh,c))}function Lh(a){Fh.current===a&&(E(Eh),E(Fh))}var M=Uf(0);\nfunction Mh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||\"$?\"===c.data||\"$!\"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&128))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var Nh=[];\nfunction Oh(){for(var a=0;ac?c:4;a(!0);var d=Qh.transition;Qh.transition={};try{a(!1),b()}finally{C=c,Qh.transition=d}}function Fi(){return di().memoizedState}\nfunction Gi(a,b,c){var d=lh(a);c={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,c);else if(c=Yg(a,b,c,d),null!==c){var e=L();mh(c,a,d,e);Ji(c,b,d)}}\nfunction ri(a,b,c){var d=lh(a),e={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,e);else{var f=a.alternate;if(0===a.lanes&&(null===f||0===f.lanes)&&(f=b.lastRenderedReducer,null!==f))try{var g=b.lastRenderedState,h=f(g,c);e.hasEagerState=!0;e.eagerState=h;if(He(h,g)){var k=b.interleaved;null===k?(e.next=e,Xg(b)):(e.next=k.next,k.next=e);b.interleaved=e;return}}catch(l){}finally{}c=Yg(a,b,e,d);null!==c&&(e=L(),mh(c,a,d,e),Ji(c,b,d))}}\nfunction Hi(a){var b=a.alternate;return a===N||null!==b&&b===N}function Ii(a,b){Th=Sh=!0;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}function Ji(a,b,c){if(0!==(c&4194240)){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}\nvar ai={readContext:Vg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useInsertionEffect:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useDeferredValue:Q,useTransition:Q,useMutableSource:Q,useSyncExternalStore:Q,useId:Q,unstable_isNewReconciler:!1},Yh={readContext:Vg,useCallback:function(a,b){ci().memoizedState=[a,void 0===b?null:b];return a},useContext:Vg,useEffect:vi,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ti(4194308,\n4,yi.bind(null,b,a),c)},useLayoutEffect:function(a,b){return ti(4194308,4,a,b)},useInsertionEffect:function(a,b){return ti(4,2,a,b)},useMemo:function(a,b){var c=ci();b=void 0===b?null:b;a=a();c.memoizedState=[a,b];return a},useReducer:function(a,b,c){var d=ci();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};d.queue=a;a=a.dispatch=Gi.bind(null,N,a);return[d.memoizedState,a]},useRef:function(a){var b=\nci();a={current:a};return b.memoizedState=a},useState:qi,useDebugValue:Ai,useDeferredValue:function(a){return ci().memoizedState=a},useTransition:function(){var a=qi(!1),b=a[0];a=Ei.bind(null,a[1]);ci().memoizedState=a;return[b,a]},useMutableSource:function(){},useSyncExternalStore:function(a,b,c){var d=N,e=ci();if(I){if(void 0===c)throw Error(p(407));c=c()}else{c=b();if(null===R)throw Error(p(349));0!==(Rh&30)||ni(d,b,c)}e.memoizedState=c;var f={value:c,getSnapshot:b};e.queue=f;vi(ki.bind(null,d,\nf,a),[a]);d.flags|=2048;li(9,mi.bind(null,d,f,c,b),void 0,null);return c},useId:function(){var a=ci(),b=R.identifierPrefix;if(I){var c=sg;var d=rg;c=(d&~(1<<32-oc(d)-1)).toString(32)+c;b=\":\"+b+\"R\"+c;c=Uh++;0\\x3c/script>\",a=a.removeChild(a.firstChild)):\n\"string\"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),\"select\"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[Of]=b;a[Pf]=d;Aj(a,b,!1,!1);b.stateNode=a;a:{g=vb(c,d);switch(c){case \"dialog\":D(\"cancel\",a);D(\"close\",a);e=d;break;case \"iframe\":case \"object\":case \"embed\":D(\"load\",a);e=d;break;case \"video\":case \"audio\":for(e=0;eHj&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304)}else{if(!d)if(a=Mh(g),null!==a){if(b.flags|=128,d=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Ej(f,!0),null===f.tail&&\"hidden\"===f.tailMode&&!g.alternate&&!I)return S(b),null}else 2*B()-f.renderingStartTime>Hj&&1073741824!==c&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304);f.isBackwards?(g.sibling=b.child,b.child=g):(c=f.last,null!==c?c.sibling=g:b.child=g,f.last=g)}if(null!==f.tail)return b=f.tail,f.rendering=\nb,f.tail=b.sibling,f.renderingStartTime=B(),b.sibling=null,c=M.current,G(M,d?c&1|2:c&1),b;S(b);return null;case 22:case 23:return Ij(),d=null!==b.memoizedState,null!==a&&null!==a.memoizedState!==d&&(b.flags|=8192),d&&0!==(b.mode&1)?0!==(gj&1073741824)&&(S(b),b.subtreeFlags&6&&(b.flags|=8192)):S(b),null;case 24:return null;case 25:return null}throw Error(p(156,b.tag));}\nfunction Jj(a,b){wg(b);switch(b.tag){case 1:return Zf(b.type)&&$f(),a=b.flags,a&65536?(b.flags=a&-65537|128,b):null;case 3:return Jh(),E(Wf),E(H),Oh(),a=b.flags,0!==(a&65536)&&0===(a&128)?(b.flags=a&-65537|128,b):null;case 5:return Lh(b),null;case 13:E(M);a=b.memoizedState;if(null!==a&&null!==a.dehydrated){if(null===b.alternate)throw Error(p(340));Ig()}a=b.flags;return a&65536?(b.flags=a&-65537|128,b):null;case 19:return E(M),null;case 4:return Jh(),null;case 10:return Rg(b.type._context),null;case 22:case 23:return Ij(),\nnull;case 24:return null;default:return null}}var Kj=!1,U=!1,Lj=\"function\"===typeof WeakSet?WeakSet:Set,V=null;function Mj(a,b){var c=a.ref;if(null!==c)if(\"function\"===typeof c)try{c(null)}catch(d){W(a,b,d)}else c.current=null}function Nj(a,b,c){try{c()}catch(d){W(a,b,d)}}var Oj=!1;\nfunction Pj(a,b){Cf=dd;a=Me();if(Ne(a)){if(\"selectionStart\"in a)var c={start:a.selectionStart,end:a.selectionEnd};else a:{c=(c=a.ownerDocument)&&c.defaultView||window;var d=c.getSelection&&c.getSelection();if(d&&0!==d.rangeCount){c=d.anchorNode;var e=d.anchorOffset,f=d.focusNode;d=d.focusOffset;try{c.nodeType,f.nodeType}catch(F){c=null;break a}var g=0,h=-1,k=-1,l=0,m=0,q=a,r=null;b:for(;;){for(var y;;){q!==c||0!==e&&3!==q.nodeType||(h=g+e);q!==f||0!==d&&3!==q.nodeType||(k=g+d);3===q.nodeType&&(g+=\nq.nodeValue.length);if(null===(y=q.firstChild))break;r=q;q=y}for(;;){if(q===a)break b;r===c&&++l===e&&(h=g);r===f&&++m===d&&(k=g);if(null!==(y=q.nextSibling))break;q=r;r=q.parentNode}q=y}c=-1===h||-1===k?null:{start:h,end:k}}else c=null}c=c||{start:0,end:0}}else c=null;Df={focusedElem:a,selectionRange:c};dd=!1;for(V=b;null!==V;)if(b=V,a=b.child,0!==(b.subtreeFlags&1028)&&null!==a)a.return=b,V=a;else for(;null!==V;){b=V;try{var n=b.alternate;if(0!==(b.flags&1024))switch(b.tag){case 0:case 11:case 15:break;\ncase 1:if(null!==n){var t=n.memoizedProps,J=n.memoizedState,x=b.stateNode,w=x.getSnapshotBeforeUpdate(b.elementType===b.type?t:Lg(b.type,t),J);x.__reactInternalSnapshotBeforeUpdate=w}break;case 3:var u=b.stateNode.containerInfo;1===u.nodeType?u.textContent=\"\":9===u.nodeType&&u.documentElement&&u.removeChild(u.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(p(163));}}catch(F){W(b,b.return,F)}a=b.sibling;if(null!==a){a.return=b.return;V=a;break}V=b.return}n=Oj;Oj=!1;return n}\nfunction Qj(a,b,c){var d=b.updateQueue;d=null!==d?d.lastEffect:null;if(null!==d){var e=d=d.next;do{if((e.tag&a)===a){var f=e.destroy;e.destroy=void 0;void 0!==f&&Nj(b,c,f)}e=e.next}while(e!==d)}}function Rj(a,b){b=b.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){var c=b=b.next;do{if((c.tag&a)===a){var d=c.create;c.destroy=d()}c=c.next}while(c!==b)}}function Sj(a){var b=a.ref;if(null!==b){var c=a.stateNode;switch(a.tag){case 5:a=c;break;default:a=c}\"function\"===typeof b?b(a):b.current=a}}\nfunction Tj(a){var b=a.alternate;null!==b&&(a.alternate=null,Tj(b));a.child=null;a.deletions=null;a.sibling=null;5===a.tag&&(b=a.stateNode,null!==b&&(delete b[Of],delete b[Pf],delete b[of],delete b[Qf],delete b[Rf]));a.stateNode=null;a.return=null;a.dependencies=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.stateNode=null;a.updateQueue=null}function Uj(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction Vj(a){a:for(;;){for(;null===a.sibling;){if(null===a.return||Uj(a.return))return null;a=a.return}a.sibling.return=a.return;for(a=a.sibling;5!==a.tag&&6!==a.tag&&18!==a.tag;){if(a.flags&2)continue a;if(null===a.child||4===a.tag)continue a;else a.child.return=a,a=a.child}if(!(a.flags&2))return a.stateNode}}\nfunction Wj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=Bf));else if(4!==d&&(a=a.child,null!==a))for(Wj(a,b,c),a=a.sibling;null!==a;)Wj(a,b,c),a=a.sibling}\nfunction Xj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(Xj(a,b,c),a=a.sibling;null!==a;)Xj(a,b,c),a=a.sibling}var X=null,Yj=!1;function Zj(a,b,c){for(c=c.child;null!==c;)ak(a,b,c),c=c.sibling}\nfunction ak(a,b,c){if(lc&&\"function\"===typeof lc.onCommitFiberUnmount)try{lc.onCommitFiberUnmount(kc,c)}catch(h){}switch(c.tag){case 5:U||Mj(c,b);case 6:var d=X,e=Yj;X=null;Zj(a,b,c);X=d;Yj=e;null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?a.parentNode.removeChild(c):a.removeChild(c)):X.removeChild(c.stateNode));break;case 18:null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?Kf(a.parentNode,c):1===a.nodeType&&Kf(a,c),bd(a)):Kf(X,c.stateNode));break;case 4:d=X;e=Yj;X=c.stateNode.containerInfo;Yj=!0;\nZj(a,b,c);X=d;Yj=e;break;case 0:case 11:case 14:case 15:if(!U&&(d=c.updateQueue,null!==d&&(d=d.lastEffect,null!==d))){e=d=d.next;do{var f=e,g=f.destroy;f=f.tag;void 0!==g&&(0!==(f&2)?Nj(c,b,g):0!==(f&4)&&Nj(c,b,g));e=e.next}while(e!==d)}Zj(a,b,c);break;case 1:if(!U&&(Mj(c,b),d=c.stateNode,\"function\"===typeof d.componentWillUnmount))try{d.props=c.memoizedProps,d.state=c.memoizedState,d.componentWillUnmount()}catch(h){W(c,b,h)}Zj(a,b,c);break;case 21:Zj(a,b,c);break;case 22:c.mode&1?(U=(d=U)||null!==\nc.memoizedState,Zj(a,b,c),U=d):Zj(a,b,c);break;default:Zj(a,b,c)}}function bk(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Lj);b.forEach(function(b){var d=ck.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}\nfunction dk(a,b){var c=b.deletions;if(null!==c)for(var d=0;de&&(e=g);d&=~f}d=e;d=B()-d;d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*mk(d/1960))-d;if(10a?16:a;if(null===xk)var d=!1;else{a=xk;xk=null;yk=0;if(0!==(K&6))throw Error(p(331));var e=K;K|=4;for(V=a.current;null!==V;){var f=V,g=f.child;if(0!==(V.flags&16)){var h=f.deletions;if(null!==h){for(var k=0;kB()-gk?Lk(a,0):sk|=c);Ek(a,b)}function Zk(a,b){0===b&&(0===(a.mode&1)?b=1:(b=sc,sc<<=1,0===(sc&130023424)&&(sc=4194304)));var c=L();a=Zg(a,b);null!==a&&(Ac(a,b,c),Ek(a,c))}function vj(a){var b=a.memoizedState,c=0;null!==b&&(c=b.retryLane);Zk(a,c)}\nfunction ck(a,b){var c=0;switch(a.tag){case 13:var d=a.stateNode;var e=a.memoizedState;null!==e&&(c=e.retryLane);break;case 19:d=a.stateNode;break;default:throw Error(p(314));}null!==d&&d.delete(b);Zk(a,c)}var Wk;\nWk=function(a,b,c){if(null!==a)if(a.memoizedProps!==b.pendingProps||Wf.current)Ug=!0;else{if(0===(a.lanes&c)&&0===(b.flags&128))return Ug=!1,zj(a,b,c);Ug=0!==(a.flags&131072)?!0:!1}else Ug=!1,I&&0!==(b.flags&1048576)&&ug(b,ng,b.index);b.lanes=0;switch(b.tag){case 2:var d=b.type;jj(a,b);a=b.pendingProps;var e=Yf(b,H.current);Tg(b,c);e=Xh(null,b,d,a,e,c);var f=bi();b.flags|=1;\"object\"===typeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof?(b.tag=1,b.memoizedState=null,b.updateQueue=\nnull,Zf(d)?(f=!0,cg(b)):f=!1,b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null,ah(b),e.updater=nh,b.stateNode=e,e._reactInternals=b,rh(b,d,a,c),b=kj(null,b,d,!0,f,c)):(b.tag=0,I&&f&&vg(b),Yi(null,b,e,c),b=b.child);return b;case 16:d=b.elementType;a:{jj(a,b);a=b.pendingProps;e=d._init;d=e(d._payload);b.type=d;e=b.tag=$k(d);a=Lg(d,a);switch(e){case 0:b=dj(null,b,d,a,c);break a;case 1:b=ij(null,b,d,a,c);break a;case 11:b=Zi(null,b,d,a,c);break a;case 14:b=aj(null,b,d,Lg(d.type,a),c);break a}throw Error(p(306,\nd,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),dj(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),ij(a,b,d,e,c);case 3:a:{lj(b);if(null===a)throw Error(p(387));d=b.pendingProps;f=b.memoizedState;e=f.element;bh(a,b);gh(b,d,null,c);var g=b.memoizedState;d=g.element;if(f.isDehydrated)if(f={element:d,isDehydrated:!1,cache:g.cache,pendingSuspenseBoundaries:g.pendingSuspenseBoundaries,transitions:g.transitions},b.updateQueue.baseState=\nf,b.memoizedState=f,b.flags&256){e=Ki(Error(p(423)),b);b=mj(a,b,d,c,e);break a}else if(d!==e){e=Ki(Error(p(424)),b);b=mj(a,b,d,c,e);break a}else for(yg=Lf(b.stateNode.containerInfo.firstChild),xg=b,I=!0,zg=null,c=Ch(b,null,d,c),b.child=c;c;)c.flags=c.flags&-3|4096,c=c.sibling;else{Ig();if(d===e){b=$i(a,b,c);break a}Yi(a,b,d,c)}b=b.child}return b;case 5:return Kh(b),null===a&&Eg(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,Ef(d,e)?g=null:null!==f&&Ef(d,f)&&(b.flags|=32),\nhj(a,b),Yi(a,b,g,c),b.child;case 6:return null===a&&Eg(b),null;case 13:return pj(a,b,c);case 4:return Ih(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Bh(b,null,d,c):Yi(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),Zi(a,b,d,e,c);case 7:return Yi(a,b,b.pendingProps,c),b.child;case 8:return Yi(a,b,b.pendingProps.children,c),b.child;case 12:return Yi(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;f=b.memoizedProps;\ng=e.value;G(Mg,d._currentValue);d._currentValue=g;if(null!==f)if(He(f.value,g)){if(f.children===e.children&&!Wf.current){b=$i(a,b,c);break a}}else for(f=b.child,null!==f&&(f.return=b);null!==f;){var h=f.dependencies;if(null!==h){g=f.child;for(var k=h.firstContext;null!==k;){if(k.context===d){if(1===f.tag){k=ch(-1,c&-c);k.tag=2;var l=f.updateQueue;if(null!==l){l=l.shared;var m=l.pending;null===m?k.next=k:(k.next=m.next,m.next=k);l.pending=k}}f.lanes|=c;k=f.alternate;null!==k&&(k.lanes|=c);Sg(f.return,\nc,b);h.lanes|=c;break}k=k.next}}else if(10===f.tag)g=f.type===b.type?null:f.child;else if(18===f.tag){g=f.return;if(null===g)throw Error(p(341));g.lanes|=c;h=g.alternate;null!==h&&(h.lanes|=c);Sg(g,c,b);g=f.sibling}else g=f.child;if(null!==g)g.return=f;else for(g=f;null!==g;){if(g===b){g=null;break}f=g.sibling;if(null!==f){f.return=g.return;g=f;break}g=g.return}f=g}Yi(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,d=b.pendingProps.children,Tg(b,c),e=Vg(e),d=d(e),b.flags|=1,Yi(a,b,d,c),\nb.child;case 14:return d=b.type,e=Lg(d,b.pendingProps),e=Lg(d.type,e),aj(a,b,d,e,c);case 15:return cj(a,b,b.type,b.pendingProps,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),jj(a,b),b.tag=1,Zf(d)?(a=!0,cg(b)):a=!1,Tg(b,c),ph(b,d,e),rh(b,d,e,c),kj(null,b,d,!0,a,c);case 19:return yj(a,b,c);case 22:return ej(a,b,c)}throw Error(p(156,b.tag));};function Gk(a,b){return ac(a,b)}\nfunction al(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.subtreeFlags=this.flags=0;this.deletions=null;this.childLanes=this.lanes=0;this.alternate=null}function Bg(a,b,c,d){return new al(a,b,c,d)}function bj(a){a=a.prototype;return!(!a||!a.isReactComponent)}\nfunction $k(a){if(\"function\"===typeof a)return bj(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Da)return 11;if(a===Ga)return 14}return 2}\nfunction wh(a,b){var c=a.alternate;null===c?(c=Bg(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.type=a.type,c.flags=0,c.subtreeFlags=0,c.deletions=null);c.flags=a.flags&14680064;c.childLanes=a.childLanes;c.lanes=a.lanes;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{lanes:b.lanes,firstContext:b.firstContext};\nc.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction yh(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)bj(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case ya:return Ah(c.children,e,f,b);case za:g=8;e|=8;break;case Aa:return a=Bg(12,c,b,e|2),a.elementType=Aa,a.lanes=f,a;case Ea:return a=Bg(13,c,b,e),a.elementType=Ea,a.lanes=f,a;case Fa:return a=Bg(19,c,b,e),a.elementType=Fa,a.lanes=f,a;case Ia:return qj(c,e,f,b);default:if(\"object\"===typeof a&&null!==a)switch(a.$$typeof){case Ba:g=10;break a;case Ca:g=9;break a;case Da:g=11;\nbreak a;case Ga:g=14;break a;case Ha:g=16;d=null;break a}throw Error(p(130,null==a?a:typeof a,\"\"));}b=Bg(g,c,b,e);b.elementType=a;b.type=d;b.lanes=f;return b}function Ah(a,b,c,d){a=Bg(7,a,d,b);a.lanes=c;return a}function qj(a,b,c,d){a=Bg(22,a,d,b);a.elementType=Ia;a.lanes=c;a.stateNode={isHidden:!1};return a}function xh(a,b,c){a=Bg(6,a,null,b);a.lanes=c;return a}\nfunction zh(a,b,c){b=Bg(4,null!==a.children?a.children:[],a.key,b);b.lanes=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction bl(a,b,c,d,e){this.tag=b;this.containerInfo=a;this.finishedWork=this.pingCache=this.current=this.pendingChildren=null;this.timeoutHandle=-1;this.callbackNode=this.pendingContext=this.context=null;this.callbackPriority=0;this.eventTimes=zc(0);this.expirationTimes=zc(-1);this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0;this.entanglements=zc(0);this.identifierPrefix=d;this.onRecoverableError=e;this.mutableSourceEagerHydrationData=\nnull}function cl(a,b,c,d,e,f,g,h,k){a=new bl(a,b,c,h,k);1===b?(b=1,!0===f&&(b|=8)):b=0;f=Bg(3,null,null,b);a.current=f;f.stateNode=a;f.memoizedState={element:d,isDehydrated:c,cache:null,transitions:null,pendingSuspenseBoundaries:null};ah(f);return a}function dl(a,b,c){var d=3>>1,e=a[d];if(0>>1;dg(C,c))ng(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(ng(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}\nfunction g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D=\"function\"===typeof setTimeout?setTimeout:null,E=\"function\"===typeof clearTimeout?clearTimeout:null,F=\"undefined\"!==typeof setImmediate?setImmediate:null;\n\"undefined\"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}\nfunction J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if(\"function\"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;\nfunction M(){return exports.unstable_now()-Qa||125d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};\nexports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n return arr2;\n}\nmodule.exports = _arrayLikeToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\nmodule.exports = _arrayWithHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}\nmodule.exports = _assertThisInitialized, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nmodule.exports = _classCallCheck, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nmodule.exports = _createClass, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nfunction _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n if (!it) {\n if (Array.isArray(o) || (it = unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n var F = function F() {};\n return {\n s: F,\n n: function n() {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function e(_e) {\n throw _e;\n },\n f: F\n };\n }\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function s() {\n it = it.call(o);\n },\n n: function n() {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function e(_e2) {\n didErr = true;\n err = _e2;\n },\n f: function f() {\n try {\n if (!normalCompletion && it[\"return\"] != null) it[\"return\"]();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n}\nmodule.exports = _createForOfIteratorHelper, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var getPrototypeOf = require(\"./getPrototypeOf.js\");\nvar isNativeReflectConstruct = require(\"./isNativeReflectConstruct.js\");\nvar possibleConstructorReturn = require(\"./possibleConstructorReturn.js\");\nfunction _createSuper(Derived) {\n var hasNativeReflectConstruct = isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = getPrototypeOf(Derived),\n result;\n if (hasNativeReflectConstruct) {\n var NewTarget = getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n return possibleConstructorReturn(this, result);\n };\n}\nmodule.exports = _createSuper, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var superPropBase = require(\"./superPropBase.js\");\nfunction _get() {\n if (typeof Reflect !== \"undefined\" && Reflect.get) {\n module.exports = _get = Reflect.get.bind(), module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n } else {\n module.exports = _get = function _get(target, property, receiver) {\n var base = superPropBase(target, property);\n if (!base) return;\n var desc = Object.getOwnPropertyDescriptor(base, property);\n if (desc.get) {\n return desc.get.call(arguments.length < 3 ? target : receiver);\n }\n return desc.value;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n }\n return _get.apply(this, arguments);\n}\nmodule.exports = _get, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _getPrototypeOf(o) {\n module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _getPrototypeOf(o);\n}\nmodule.exports = _getPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}\nmodule.exports = _inherits, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\nmodule.exports = _isNativeReflectConstruct, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n return _arr;\n}\nmodule.exports = _iterableToArrayLimit, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nmodule.exports = _nonIterableRest, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nvar assertThisInitialized = require(\"./assertThisInitialized.js\");\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return assertThisInitialized(self);\n}\nmodule.exports = _possibleConstructorReturn, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nfunction _regeneratorRuntime() {\n \"use strict\"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */\n module.exports = _regeneratorRuntime = function _regeneratorRuntime() {\n return exports;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n var exports = {},\n Op = Object.prototype,\n hasOwn = Op.hasOwnProperty,\n defineProperty = Object.defineProperty || function (obj, key, desc) {\n obj[key] = desc.value;\n },\n $Symbol = \"function\" == typeof Symbol ? Symbol : {},\n iteratorSymbol = $Symbol.iterator || \"@@iterator\",\n asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\",\n toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n function define(obj, key, value) {\n return Object.defineProperty(obj, key, {\n value: value,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }), obj[key];\n }\n try {\n define({}, \"\");\n } catch (err) {\n define = function define(obj, key, value) {\n return obj[key] = value;\n };\n }\n function wrap(innerFn, outerFn, self, tryLocsList) {\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator,\n generator = Object.create(protoGenerator.prototype),\n context = new Context(tryLocsList || []);\n return defineProperty(generator, \"_invoke\", {\n value: makeInvokeMethod(innerFn, self, context)\n }), generator;\n }\n function tryCatch(fn, obj, arg) {\n try {\n return {\n type: \"normal\",\n arg: fn.call(obj, arg)\n };\n } catch (err) {\n return {\n type: \"throw\",\n arg: err\n };\n }\n }\n exports.wrap = wrap;\n var ContinueSentinel = {};\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n var getProto = Object.getPrototypeOf,\n NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype);\n var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype);\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function (method) {\n define(prototype, method, function (arg) {\n return this._invoke(method, arg);\n });\n });\n }\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (\"throw\" !== record.type) {\n var result = record.arg,\n value = result.value;\n return value && \"object\" == _typeof(value) && hasOwn.call(value, \"__await\") ? PromiseImpl.resolve(value.__await).then(function (value) {\n invoke(\"next\", value, resolve, reject);\n }, function (err) {\n invoke(\"throw\", err, resolve, reject);\n }) : PromiseImpl.resolve(value).then(function (unwrapped) {\n result.value = unwrapped, resolve(result);\n }, function (error) {\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n reject(record.arg);\n }\n var previousPromise;\n defineProperty(this, \"_invoke\", {\n value: function value(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function (resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();\n }\n });\n }\n function makeInvokeMethod(innerFn, self, context) {\n var state = \"suspendedStart\";\n return function (method, arg) {\n if (\"executing\" === state) throw new Error(\"Generator is already running\");\n if (\"completed\" === state) {\n if (\"throw\" === method) throw arg;\n return doneResult();\n }\n for (context.method = method, context.arg = arg;;) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n if (\"next\" === context.method) context.sent = context._sent = context.arg;else if (\"throw\" === context.method) {\n if (\"suspendedStart\" === state) throw state = \"completed\", context.arg;\n context.dispatchException(context.arg);\n } else \"return\" === context.method && context.abrupt(\"return\", context.arg);\n state = \"executing\";\n var record = tryCatch(innerFn, self, context);\n if (\"normal\" === record.type) {\n if (state = context.done ? \"completed\" : \"suspendedYield\", record.arg === ContinueSentinel) continue;\n return {\n value: record.arg,\n done: context.done\n };\n }\n \"throw\" === record.type && (state = \"completed\", context.method = \"throw\", context.arg = record.arg);\n }\n };\n }\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (undefined === method) {\n if (context.delegate = null, \"throw\" === context.method) {\n if (delegate.iterator[\"return\"] && (context.method = \"return\", context.arg = undefined, maybeInvokeDelegate(delegate, context), \"throw\" === context.method)) return ContinueSentinel;\n context.method = \"throw\", context.arg = new TypeError(\"The iterator does not provide a 'throw' method\");\n }\n return ContinueSentinel;\n }\n var record = tryCatch(method, delegate.iterator, context.arg);\n if (\"throw\" === record.type) return context.method = \"throw\", context.arg = record.arg, context.delegate = null, ContinueSentinel;\n var info = record.arg;\n return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, \"return\" !== context.method && (context.method = \"next\", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = \"throw\", context.arg = new TypeError(\"iterator result is not an object\"), context.delegate = null, ContinueSentinel);\n }\n function pushTryEntry(locs) {\n var entry = {\n tryLoc: locs[0]\n };\n 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry);\n }\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\", delete record.arg, entry.completion = record;\n }\n function Context(tryLocsList) {\n this.tryEntries = [{\n tryLoc: \"root\"\n }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0);\n }\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) return iteratorMethod.call(iterable);\n if (\"function\" == typeof iterable.next) return iterable;\n if (!isNaN(iterable.length)) {\n var i = -1,\n next = function next() {\n for (; ++i < iterable.length;) {\n if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next;\n }\n return next.value = undefined, next.done = !0, next;\n };\n return next.next = next;\n }\n }\n return {\n next: doneResult\n };\n }\n function doneResult() {\n return {\n value: undefined,\n done: !0\n };\n }\n return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, \"constructor\", {\n value: GeneratorFunctionPrototype,\n configurable: !0\n }), defineProperty(GeneratorFunctionPrototype, \"constructor\", {\n value: GeneratorFunction,\n configurable: !0\n }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, \"GeneratorFunction\"), exports.isGeneratorFunction = function (genFun) {\n var ctor = \"function\" == typeof genFun && genFun.constructor;\n return !!ctor && (ctor === GeneratorFunction || \"GeneratorFunction\" === (ctor.displayName || ctor.name));\n }, exports.mark = function (genFun) {\n return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, \"GeneratorFunction\")), genFun.prototype = Object.create(Gp), genFun;\n }, exports.awrap = function (arg) {\n return {\n __await: arg\n };\n }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n void 0 === PromiseImpl && (PromiseImpl = Promise);\n var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl);\n return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) {\n return result.done ? result.value : iter.next();\n });\n }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, \"Generator\"), define(Gp, iteratorSymbol, function () {\n return this;\n }), define(Gp, \"toString\", function () {\n return \"[object Generator]\";\n }), exports.keys = function (val) {\n var object = Object(val),\n keys = [];\n for (var key in object) {\n keys.push(key);\n }\n return keys.reverse(), function next() {\n for (; keys.length;) {\n var key = keys.pop();\n if (key in object) return next.value = key, next.done = !1, next;\n }\n return next.done = !0, next;\n };\n }, exports.values = values, Context.prototype = {\n constructor: Context,\n reset: function reset(skipTempReset) {\n if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = \"next\", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) {\n \"t\" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined);\n }\n },\n stop: function stop() {\n this.done = !0;\n var rootRecord = this.tryEntries[0].completion;\n if (\"throw\" === rootRecord.type) throw rootRecord.arg;\n return this.rval;\n },\n dispatchException: function dispatchException(exception) {\n if (this.done) throw exception;\n var context = this;\n function handle(loc, caught) {\n return record.type = \"throw\", record.arg = exception, context.next = loc, caught && (context.method = \"next\", context.arg = undefined), !!caught;\n }\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i],\n record = entry.completion;\n if (\"root\" === entry.tryLoc) return handle(\"end\");\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\"),\n hasFinally = hasOwn.call(entry, \"finallyLoc\");\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n } else {\n if (!hasFinally) throw new Error(\"try statement without catch or finally\");\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n }\n }\n }\n },\n abrupt: function abrupt(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n finallyEntry && (\"break\" === type || \"continue\" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null);\n var record = finallyEntry ? finallyEntry.completion : {};\n return record.type = type, record.arg = arg, finallyEntry ? (this.method = \"next\", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record);\n },\n complete: function complete(record, afterLoc) {\n if (\"throw\" === record.type) throw record.arg;\n return \"break\" === record.type || \"continue\" === record.type ? this.next = record.arg : \"return\" === record.type ? (this.rval = this.arg = record.arg, this.method = \"return\", this.next = \"end\") : \"normal\" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel;\n },\n finish: function finish(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel;\n }\n },\n \"catch\": function _catch(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (\"throw\" === record.type) {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n throw new Error(\"illegal catch attempt\");\n },\n delegateYield: function delegateYield(iterable, resultName, nextLoc) {\n return this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n }, \"next\" === this.method && (this.arg = undefined), ContinueSentinel;\n }\n }, exports;\n}\nmodule.exports = _regeneratorRuntime, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _setPrototypeOf(o, p) {\n module.exports = _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _setPrototypeOf(o, p);\n}\nmodule.exports = _setPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayWithHoles = require(\"./arrayWithHoles.js\");\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit.js\");\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nvar nonIterableRest = require(\"./nonIterableRest.js\");\nfunction _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}\nmodule.exports = _slicedToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var getPrototypeOf = require(\"./getPrototypeOf.js\");\nfunction _superPropBase(object, property) {\n while (!Object.prototype.hasOwnProperty.call(object, property)) {\n object = getPrototypeOf(object);\n if (object === null) break;\n }\n return object;\n}\nmodule.exports = _superPropBase, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return (module.exports = _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports), _typeof(obj);\n}\nmodule.exports = _typeof, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}\nmodule.exports = _unsupportedIterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = function(chunkId) {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce(function(promises, key) {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"static/js/\" + chunkId + \".\" + \"709d397d\" + \".chunk.js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = function(chunkId) {\n\t// return url for filenames based on template\n\treturn undefined;\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","var inProgress = {};\nvar dataWebpackPrefix = \"makecode-arcade-kiosk:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = function(url, done, key, chunkId) {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = function(prev, event) {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach(function(fn) { return fn(event); });\n\t\tif(prev) return prev(event);\n\t}\n\t;\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"/static/kiosk/\";","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t179: 0\n};\n\n__webpack_require__.f.j = function(chunkId, promises) {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise(function(resolve, reject) { installedChunkData = installedChunks[chunkId] = [resolve, reject]; });\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = function(event) {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t} else installedChunks[chunkId] = 0;\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = function(parentChunkLoadingFunction, data) {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some(function(id) { return installedChunks[id] !== 0; })) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunkmakecode_arcade_kiosk\"] = self[\"webpackChunkmakecode_arcade_kiosk\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n return arr2;\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n return _arr;\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}","import defineProperty from \"./defineProperty.js\";\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n enumerableOnly && (symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n })), keys.push.apply(keys, symbols);\n }\n return keys;\n}\nexport default function _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = null != arguments[i] ? arguments[i] : {};\n i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {\n defineProperty(target, key, source[key]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}","export default function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj);\n}","import _typeof from \"./typeof.js\";\nexport default function _regeneratorRuntime() {\n \"use strict\"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */\n _regeneratorRuntime = function _regeneratorRuntime() {\n return exports;\n };\n var exports = {},\n Op = Object.prototype,\n hasOwn = Op.hasOwnProperty,\n defineProperty = Object.defineProperty || function (obj, key, desc) {\n obj[key] = desc.value;\n },\n $Symbol = \"function\" == typeof Symbol ? Symbol : {},\n iteratorSymbol = $Symbol.iterator || \"@@iterator\",\n asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\",\n toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n function define(obj, key, value) {\n return Object.defineProperty(obj, key, {\n value: value,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }), obj[key];\n }\n try {\n define({}, \"\");\n } catch (err) {\n define = function define(obj, key, value) {\n return obj[key] = value;\n };\n }\n function wrap(innerFn, outerFn, self, tryLocsList) {\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator,\n generator = Object.create(protoGenerator.prototype),\n context = new Context(tryLocsList || []);\n return defineProperty(generator, \"_invoke\", {\n value: makeInvokeMethod(innerFn, self, context)\n }), generator;\n }\n function tryCatch(fn, obj, arg) {\n try {\n return {\n type: \"normal\",\n arg: fn.call(obj, arg)\n };\n } catch (err) {\n return {\n type: \"throw\",\n arg: err\n };\n }\n }\n exports.wrap = wrap;\n var ContinueSentinel = {};\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n var getProto = Object.getPrototypeOf,\n NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype);\n var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype);\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function (method) {\n define(prototype, method, function (arg) {\n return this._invoke(method, arg);\n });\n });\n }\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (\"throw\" !== record.type) {\n var result = record.arg,\n value = result.value;\n return value && \"object\" == _typeof(value) && hasOwn.call(value, \"__await\") ? PromiseImpl.resolve(value.__await).then(function (value) {\n invoke(\"next\", value, resolve, reject);\n }, function (err) {\n invoke(\"throw\", err, resolve, reject);\n }) : PromiseImpl.resolve(value).then(function (unwrapped) {\n result.value = unwrapped, resolve(result);\n }, function (error) {\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n reject(record.arg);\n }\n var previousPromise;\n defineProperty(this, \"_invoke\", {\n value: function value(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function (resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();\n }\n });\n }\n function makeInvokeMethod(innerFn, self, context) {\n var state = \"suspendedStart\";\n return function (method, arg) {\n if (\"executing\" === state) throw new Error(\"Generator is already running\");\n if (\"completed\" === state) {\n if (\"throw\" === method) throw arg;\n return doneResult();\n }\n for (context.method = method, context.arg = arg;;) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n if (\"next\" === context.method) context.sent = context._sent = context.arg;else if (\"throw\" === context.method) {\n if (\"suspendedStart\" === state) throw state = \"completed\", context.arg;\n context.dispatchException(context.arg);\n } else \"return\" === context.method && context.abrupt(\"return\", context.arg);\n state = \"executing\";\n var record = tryCatch(innerFn, self, context);\n if (\"normal\" === record.type) {\n if (state = context.done ? \"completed\" : \"suspendedYield\", record.arg === ContinueSentinel) continue;\n return {\n value: record.arg,\n done: context.done\n };\n }\n \"throw\" === record.type && (state = \"completed\", context.method = \"throw\", context.arg = record.arg);\n }\n };\n }\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (undefined === method) {\n if (context.delegate = null, \"throw\" === context.method) {\n if (delegate.iterator[\"return\"] && (context.method = \"return\", context.arg = undefined, maybeInvokeDelegate(delegate, context), \"throw\" === context.method)) return ContinueSentinel;\n context.method = \"throw\", context.arg = new TypeError(\"The iterator does not provide a 'throw' method\");\n }\n return ContinueSentinel;\n }\n var record = tryCatch(method, delegate.iterator, context.arg);\n if (\"throw\" === record.type) return context.method = \"throw\", context.arg = record.arg, context.delegate = null, ContinueSentinel;\n var info = record.arg;\n return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, \"return\" !== context.method && (context.method = \"next\", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = \"throw\", context.arg = new TypeError(\"iterator result is not an object\"), context.delegate = null, ContinueSentinel);\n }\n function pushTryEntry(locs) {\n var entry = {\n tryLoc: locs[0]\n };\n 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry);\n }\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\", delete record.arg, entry.completion = record;\n }\n function Context(tryLocsList) {\n this.tryEntries = [{\n tryLoc: \"root\"\n }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0);\n }\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) return iteratorMethod.call(iterable);\n if (\"function\" == typeof iterable.next) return iterable;\n if (!isNaN(iterable.length)) {\n var i = -1,\n next = function next() {\n for (; ++i < iterable.length;) {\n if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next;\n }\n return next.value = undefined, next.done = !0, next;\n };\n return next.next = next;\n }\n }\n return {\n next: doneResult\n };\n }\n function doneResult() {\n return {\n value: undefined,\n done: !0\n };\n }\n return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, \"constructor\", {\n value: GeneratorFunctionPrototype,\n configurable: !0\n }), defineProperty(GeneratorFunctionPrototype, \"constructor\", {\n value: GeneratorFunction,\n configurable: !0\n }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, \"GeneratorFunction\"), exports.isGeneratorFunction = function (genFun) {\n var ctor = \"function\" == typeof genFun && genFun.constructor;\n return !!ctor && (ctor === GeneratorFunction || \"GeneratorFunction\" === (ctor.displayName || ctor.name));\n }, exports.mark = function (genFun) {\n return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, \"GeneratorFunction\")), genFun.prototype = Object.create(Gp), genFun;\n }, exports.awrap = function (arg) {\n return {\n __await: arg\n };\n }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n void 0 === PromiseImpl && (PromiseImpl = Promise);\n var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl);\n return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) {\n return result.done ? result.value : iter.next();\n });\n }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, \"Generator\"), define(Gp, iteratorSymbol, function () {\n return this;\n }), define(Gp, \"toString\", function () {\n return \"[object Generator]\";\n }), exports.keys = function (val) {\n var object = Object(val),\n keys = [];\n for (var key in object) {\n keys.push(key);\n }\n return keys.reverse(), function next() {\n for (; keys.length;) {\n var key = keys.pop();\n if (key in object) return next.value = key, next.done = !1, next;\n }\n return next.done = !0, next;\n };\n }, exports.values = values, Context.prototype = {\n constructor: Context,\n reset: function reset(skipTempReset) {\n if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = \"next\", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) {\n \"t\" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined);\n }\n },\n stop: function stop() {\n this.done = !0;\n var rootRecord = this.tryEntries[0].completion;\n if (\"throw\" === rootRecord.type) throw rootRecord.arg;\n return this.rval;\n },\n dispatchException: function dispatchException(exception) {\n if (this.done) throw exception;\n var context = this;\n function handle(loc, caught) {\n return record.type = \"throw\", record.arg = exception, context.next = loc, caught && (context.method = \"next\", context.arg = undefined), !!caught;\n }\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i],\n record = entry.completion;\n if (\"root\" === entry.tryLoc) return handle(\"end\");\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\"),\n hasFinally = hasOwn.call(entry, \"finallyLoc\");\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n } else {\n if (!hasFinally) throw new Error(\"try statement without catch or finally\");\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n }\n }\n }\n },\n abrupt: function abrupt(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n finallyEntry && (\"break\" === type || \"continue\" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null);\n var record = finallyEntry ? finallyEntry.completion : {};\n return record.type = type, record.arg = arg, finallyEntry ? (this.method = \"next\", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record);\n },\n complete: function complete(record, afterLoc) {\n if (\"throw\" === record.type) throw record.arg;\n return \"break\" === record.type || \"continue\" === record.type ? this.next = record.arg : \"return\" === record.type ? (this.rval = this.arg = record.arg, this.method = \"return\", this.next = \"end\") : \"normal\" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel;\n },\n finish: function finish(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel;\n }\n },\n \"catch\": function _catch(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (\"throw\" === record.type) {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n throw new Error(\"illegal catch attempt\");\n },\n delegateYield: function delegateYield(iterable, resultName, nextLoc) {\n return this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n }, \"next\" === this.method && (this.arg = undefined), ContinueSentinel;\n }\n }, exports;\n}","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\nexport default function _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n _next(undefined);\n });\n };\n}","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}","export enum KioskState {\n MainMenu,\n PlayingGame,\n EnterHighScore,\n AddingGame,\n ScanQR,\n QrSuccess,\n GameOver,\n}","import configData from \"../config.json\"\n\nexport class KeyboardManager {\n private keyboardState: { [index: string]: boolean} = {};\n\n constructor() {\n document.addEventListener(\"keydown\", (e) => {\n this.onKeydown(e.key)\n });\n document.addEventListener(\"keyup\", (e) => {\n this.onKeyup(e.key);\n });\n }\n\n private checkPressed(gamepadIndex: number, keys: string[][]): boolean {\n if (gamepadIndex == -1) {\n return keys.some((list) => list.some(key => this.keyboardState[key.toUpperCase()]));\n }\n\n return keys[gamepadIndex].some(key => this.keyboardState[key.toUpperCase()]);\n }\n\n isAButtonPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardAButtonKeys);\n }\n\n isBButtonPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardBButtonKeys);\n }\n\n isEscapeButtonPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardEscapeButtonKeys);\n }\n\n isResetButtonPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardResetButtonKeys);\n }\n\n isMenuButtonPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardMenuButtonKeys);\n }\n\n isLeftPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardLeftKeys);\n }\n\n isRightPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardRightKeys);\n }\n\n isUpPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardUpKeys);\n }\n\n isDownPressed(gamepadIndex: number = -1): boolean {\n return this.checkPressed(gamepadIndex, configData.KeyboardDownKeys);\n }\n\n onKeydown(key: string) {\n this.keyboardState[key.toUpperCase()] = true;\n }\n\n onKeyup(key: string) {\n this.keyboardState[key.toUpperCase()] = false;\n }\n\n clear() {\n this.keyboardState = {};\n }\n}","import configData from \"../config.json\"\nimport { KeyboardManager } from \"./KeyboardManager\";\n\nexport class GamepadManager {\n private cachedGamepads: Gamepad[] = [];\n private cacheExpires: number = 0;\n\n private minButtonPinRequired: number = 0;\n private minAxisRequired: number = 0;\n\n public keyboardManager: KeyboardManager = new KeyboardManager();\n\n constructor() {\n this.minButtonPinRequired = Math.max(\n configData.GamepadAButtonPin,\n configData.GamepadBButtonPin,\n configData.GamepadEscapeButtonPin,\n configData.GamepadMenuButtonPin,\n configData.GamepadResetButtonPin\n );\n\n this.minAxisRequired = Math.max(\n configData.GamepadUpDownAxis,\n configData.GamepadLeftRightAxis\n );\n }\n\n getGamepads(): Gamepad[] {\n // We cache the gamepads so that we limit how often we call the underlying API. We also\n // filter down to the gamepads that are not null and have the buttons and axes we need\n // to operate based on the config settings. This might not cover all scenarios, but does\n // a good job at filtering out the random devices (like plugged-in Surface Headphones?!?)\n // that get picked up as gamepads.\n\n if (this.cacheExpires <= Date.now()) {\n this.cachedGamepads = navigator.getGamepads().filter(\n item => item &&\n item.axes && item.axes.length >= this.minAxisRequired &&\n item.buttons && item.buttons.length >= this.minButtonPinRequired\n ) as Gamepad[];\n this.cacheExpires = Date.now() + configData.GamepadCacheMilli;\n }\n\n return this.cachedGamepads;\n }\n\n validateGamepadIndex(gamepads: Gamepad[], gamepadIndex: number) {\n if ((gamepadIndex < -1) || (gamepadIndex >= gamepads.length)) {\n throw new Error(`No gamepad available at index ${gamepadIndex}`);\n }\n }\n\n isButtonPressed(gamepadIndex: number, pinIndex: number): boolean {\n const gamepads: Gamepad[] = this.getGamepads();\n\n if (gamepadIndex === -1) {\n return gamepads.some((item, index) => this.isButtonPressed(index, pinIndex));\n }\n\n this.validateGamepadIndex(gamepads, gamepadIndex);\n if ((pinIndex < 0) || (pinIndex >= gamepads[gamepadIndex].buttons.length)) {\n throw new Error(`Gamepad at index ${gamepadIndex} does not have a button at pin ${pinIndex}`);\n }\n\n return gamepads[gamepadIndex].buttons[pinIndex].pressed;\n }\n\n isAButtonPressed(gamepadIndex: number = -1): boolean {\n return this.keyboardManager.isAButtonPressed(gamepadIndex) ||\n this.isButtonPressed(gamepadIndex, configData.GamepadAButtonPin);\n }\n\n isBButtonPressed(gamepadIndex: number = -1): boolean {\n return this.keyboardManager.isBButtonPressed(gamepadIndex) ||\n this.isButtonPressed(gamepadIndex, configData.GamepadBButtonPin);\n }\n\n isEscapeButtonPressed(gamepadIndex: number = -1): boolean {\n return this.keyboardManager.isEscapeButtonPressed(gamepadIndex) ||\n this.isButtonPressed(gamepadIndex, configData.GamepadEscapeButtonPin);\n }\n\n isResetButtonPressed(gamepadIndex: number = -1): boolean {\n return this.keyboardManager.isResetButtonPressed(gamepadIndex) ||\n this.isButtonPressed(gamepadIndex, configData.GamepadResetButtonPin);\n }\n\n isMenuButtonPressed(gamepadIndex: number = -1): boolean {\n return this.keyboardManager.isMenuButtonPressed(gamepadIndex) ||\n this.isButtonPressed(gamepadIndex, configData.GamepadMenuButtonPin);\n }\n\n isDirectionPressed(gamepadIndex: number, axisIndex: number, threshold: number): boolean {\n const gamepads: Gamepad[] = this.getGamepads();\n\n if (gamepadIndex === -1) {\n return gamepads.some((item, index) => this.isDirectionPressed(index, axisIndex, threshold));\n }\n\n this.validateGamepadIndex(gamepads, gamepadIndex);\n\n const gamepad: Gamepad = gamepads[gamepadIndex];\n\n if ((axisIndex < 0) || (axisIndex >= gamepad.axes.length)) {\n throw new Error(`Gamepad at index ${gamepadIndex} does not have an axis at index ${axisIndex}`);\n }\n\n if (threshold < 0) {\n return gamepad.axes[axisIndex] <= threshold;\n }\n\n return gamepad.axes[axisIndex] >= threshold;\n }\n\n isLeftPressed(gamepadIndex: number = -1) {\n return this.keyboardManager.isLeftPressed(gamepadIndex) ||\n this.isDirectionPressed(gamepadIndex, configData.GamepadLeftRightAxis, -configData.GamepadLeftRightThreshold);\n }\n\n isRightPressed(gamepadIndex: number = -1) {\n return this.keyboardManager.isRightPressed(gamepadIndex) ||\n this.isDirectionPressed(gamepadIndex, configData.GamepadLeftRightAxis, configData.GamepadLeftRightThreshold);\n }\n\n isUpPressed(gamepadIndex: number = -1) {\n return this.keyboardManager.isUpPressed(gamepadIndex) ||\n this.isDirectionPressed(gamepadIndex, configData.GamepadUpDownAxis, -configData.GamepadUpDownThreshold);\n }\n\n isDownPressed(gamepadIndex: number = -1) {\n return this.keyboardManager.isDownPressed(gamepadIndex) ||\n this.isDirectionPressed(gamepadIndex, configData.GamepadUpDownAxis, configData.GamepadUpDownThreshold);\n }\n}","export class HighScore {\n constructor(public initials: string, public score: number) {}\n}","export class GameData {\n constructor(public id: string,\n public name: string,\n public description: string,\n public highScoreMode: string,\n public uniqueIdentifier?: string,\n public date?: string,\n public userAdded?: boolean,\n public deleted?: boolean\n ) {\n }\n}","const stagingEndpoint = \"https://staging.pxt.io/api/kiosk\"\nconst kioskBackendEndpoint = \"https://makecode.com/api/kiosk\";\nconst apiBackendEndpoint = \"https://makecode.com/api\";\n\nexport const getGameCodesAsync = async (kioskCode: string) => {\n const getGameCodeUrl = `${kioskBackendEndpoint}/code/${kioskCode}`;\n let response = await fetch(getGameCodeUrl);\n if (!response.ok) {\n const e = new Error(response.statusText);\n e.name = \"PollError\";\n throw e;\n } else {\n const gameCodeEntries = JSON.parse((await response.json())?.shareIds);\n return gameCodeEntries;\n }\n}\n\nexport const generateKioskCodeAsync = async (time?: number) => {\n const codeGenerationUrl = `${kioskBackendEndpoint}/newcode${time ? `?time=${time}` : \"\"}`;\n const response = await fetch(codeGenerationUrl);\n if (!response.ok) {\n const e = new Error(response.statusText);\n e.name = \"KioskCodeGenError\";\n throw e;\n } else {\n try {\n const newKioskCode = (await response.json()).code;\n return newKioskCode;\n }\n catch (error) {\n throw new Error(\"No code returned from the request.\");\n }\n }\n}\n\nexport const addGameToKioskAsync = async (kioskId: string | undefined, gameShareId: string | undefined) => {\n const updateKioskUrl = `${kioskBackendEndpoint}/updatecode`;\n const response: Response = await fetch(updateKioskUrl, {\n method: 'POST',\n headers: {\n 'Accept': 'application/json',\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n \"kioskCode\": kioskId,\n \"shareId\": gameShareId\n }),\n });\n\n if (!response.ok) {\n throw new Error(`${response.status} ${response.statusText}`)\n } else {\n return await response.json();\n }\n\n\n}\n\nexport const getGameDetailsAsync = async (gameId: string) => {\n const gameDetailsUrl = `${apiBackendEndpoint}/${gameId}`;\n const response = await fetch(gameDetailsUrl);\n if (!response.ok) {\n throw new Error(\"Unable to fetch the game details\");\n } else {\n return await response.json();\n }\n}","export function tickEvent(id: string, data?: { [key: string]: string | number }) {\n (window as any).pxtTickEvent?.(id, data);\n}\n\nexport function devicePixelRatio(): number {\n if (typeof window === \"undefined\" || !window.screen) return 1;\n\n // these are IE specific\n const sysXDPI = (window.screen as any).systemXDPI\n const logicalXDPI = (window.screen as any).logicalXDPI\n if (sysXDPI !== undefined\n && logicalXDPI !== undefined\n && sysXDPI > logicalXDPI) {\n return sysXDPI / logicalXDPI;\n }\n else if (window && window.devicePixelRatio !== undefined) {\n return window.devicePixelRatio;\n }\n return 1;\n}\n\nexport function isLocal() {\n return window.location.hostname === \"localhost\";\n}","import { GamepadManager } from \"./GamepadManager\";\nimport { HighScore } from \"./HighScore\";\nimport { GameData } from \"./GameData\";\nimport { BuiltSimJSInfo } from \"./BuiltSimJsInfo\";\nimport { KioskState } from \"./KioskState\";\nimport configData from \"../config.json\";\nimport { getGameDetailsAsync } from \"../BackendRequests\"\nimport { tickEvent } from \"../browserUtils\";\nexport class Kiosk {\n games: GameData[] = [];\n gamepadManager: GamepadManager = new GamepadManager();\n selectedGame?: GameData;\n selectedGameIndex?: number;\n mostRecentScores: number[] = [];\n onGameSelected!: () => void;\n onNavigated!: () => void;\n launchedGame: string = \"\";\n state: KioskState = KioskState.MainMenu;\n clean: boolean;\n locked: boolean;\n time?: string;\n\n private readonly highScoresLocalStorageKey: string = \"HighScores\";\n private readonly addedGamesLocalStorageKey: string = \"UserAddedGames\";\n private initializePromise: any;\n private siteElements: ChildNode[] = [];\n private intervalId: any;\n private readonly allScoresStateKey: string = \"S/all-scores\";\n private lockedGameId?: string;\n private builtGamesCache: { [gameId: string]: BuiltSimJSInfo } = { };\n private defaultGameDescription = \"Made with love in MakeCode Arcade\";\n\n constructor(clean: boolean, locked: boolean, time?: string) {\n this.clean = clean;\n this.locked = locked;\n this.time = time;\n }\n\n async downloadGameListAsync(): Promise {\n if (!this.clean) {\n let url = configData.GameDataUrl;\n if (configData.Debug) {\n url = `/static/kiosk/${url}`;\n }\n \n const response = await fetch(url);\n if (!response.ok) {\n throw new Error(`Unable to download game list from \"${url}\"`);\n }\n \n try {\n this.games = (await response.json()).games;\n this.games.push()\n }\n catch (error) {\n throw new Error(`Unable to process game list downloaded from \"${url}\": ${error}`);\n }\n } else {\n tickEvent(\"kiosk.clean\");\n }\n\n // the added games persist in local storage, but not the live game list\n // that feeds the carousel. That's what this function is for.\n this.addNewGamesToList();\n }\n\n getGameName(name: string) {\n if (name.toLowerCase() === \"untitled\") {\n return \"Kiosk Game\";\n }\n \n return name;\n }\n\n getGameDescription(desc: string) {\n if (desc.length === 0) {\n return this.defaultGameDescription\n }\n \n return desc;\n }\n\n async saveNewGamesAsync(games: { [index: string]: { [index: string]: string } }): Promise {\n const allAddedGames = this.getAllAddedGames();\n let gamesToAdd: string[] = [];\n const gameIds = Object.keys(games);\n for (const gameId of gameIds) {\n if (!allAddedGames[gameId]) {\n let gameName;\n let gameDescription;\n \n try {\n const gameDetails = await getGameDetailsAsync(gameId);\n gameName = this.getGameName(gameDetails.name);\n gameDescription = this.getGameDescription(gameDetails.description);\n } catch (error) {\n gameName = \"Kiosk Game\";\n gameDescription = this.defaultGameDescription;\n }\n \n const gameUploadDate = (new Date()).toLocaleString()\n const newGame = new GameData(gameId, gameName, gameDescription, \"None\", games[gameId].id, gameUploadDate, true);\n \n this.games.push(newGame);\n gamesToAdd.push(gameName);\n allAddedGames[gameId] = newGame;\n } else if (allAddedGames[gameId]?.deleted) {\n if (games[gameId].id !== allAddedGames[gameId].uniqueIdentifier) {\n allAddedGames[gameId].uniqueIdentifier = games[gameId].id;\n allAddedGames[gameId].deleted = false;\n gamesToAdd.push(allAddedGames[gameId].name);\n this.games.push(allAddedGames[gameId]);\n }\n } else {\n // we need to keep the backend and frontend unique identifiers the same\n allAddedGames[gameId].uniqueIdentifier = games[gameId].id;\n }\n }\n if (gamesToAdd.length) {\n this.selectGame(0);\n }\n localStorage.setItem(this.addedGamesLocalStorageKey, JSON.stringify(allAddedGames));\n return gamesToAdd;\n }\n\n getAllAddedGames(): { [index: string]: GameData } {\n const json = localStorage.getItem(this.addedGamesLocalStorageKey);\n if (!json) {\n return {};\n }\n const allAddedGames: { [index: string]: GameData } = JSON.parse(json);\n return allAddedGames;\n }\n\n addNewGamesToList() : void {\n // check if there are custom games to add to the game list from local storage\n const addedGames = this.getAllAddedGames();\n const addedGamesObjs: GameData[] = Object.values(addedGames);\n for (const game of addedGamesObjs) {\n if (!game?.deleted) {\n this.games.push(game);\n }\n }\n }\n\n gamePadLoop(): void {\n const isDebug = true;\n if (isDebug) {\n // Add cases for debugging via the gamepad here.\n }\n\n if (this.gamepadManager.isResetButtonPressed() &&\n this.gamepadManager.isEscapeButtonPressed() &&\n this.gamepadManager.isBButtonPressed() &&\n this.gamepadManager.isLeftPressed()) {\n this.resetHighScores();\n console.log(\"High scores reset\");\n return;\n }\n\n if (this.gamepadManager.isEscapeButtonPressed() || this.gamepadManager.isMenuButtonPressed()) {\n if (this.state === KioskState.PlayingGame) {\n this.escapeGame();\n } else {\n this.showMainMenu();\n }\n return;\n }\n }\n\n async initialize(): Promise {\n if (this.initializePromise) {\n return this.initializePromise;\n }\n\n this.initializePromise = this.downloadGameListAsync();\n\n this.intervalId = setInterval(() => this.gamePadLoop(), configData.GamepadPollLoopMilli);\n\n window.addEventListener(\"message\", (event) => {\n if (event.data?.js) {\n let builtGame: BuiltSimJSInfo | undefined = this.getBuiltGame(this.launchedGame);\n if (!builtGame) {\n this.addBuiltGame(this.launchedGame, event.data);\n } else {\n this.sendBuiltGame(this.launchedGame);\n }\n }\n switch (event.data.type) {\n case \"simulator\":\n switch (event.data.command) {\n case \"setstate\":\n switch (event.data.stateKey) {\n case this.allScoresStateKey:\n const rawData = atob(event.data.stateValue);\n const json = decodeURIComponent(rawData);\n this.mostRecentScores = JSON.parse(json);\n this.gameOver();\n break;\n }\n break;\n }\n break;\n case \"messagepacket\":\n const channel = event.data.channel;\n const parts = channel.split(\"-\");\n if (parts[0] === \"keydown\") {\n this.gamepadManager.keyboardManager.onKeydown(parts[1]);\n }\n else {\n this.gamepadManager.keyboardManager.onKeyup(parts[1]);\n }\n break;\n\n case \"ready\":\n let builtGame: BuiltSimJSInfo | undefined = this.getBuiltGame(this.launchedGame);\n if (builtGame) {\n this.sendBuiltGame(this.launchedGame);\n }\n break;\n }\n });\n\n return this.initializePromise;\n }\n\n cleanup() {\n if (this.intervalId) {\n clearInterval(this.intervalId);\n this.intervalId = null;\n }\n }\n\n navigate(state: KioskState) {\n this.state = state;\n if (this.onNavigated) {\n this.onNavigated();\n }\n }\n\n showMainMenu() {\n this.navigate(KioskState.MainMenu);\n }\n\n selectGame(gameIndex: number): void {\n if (gameIndex >= 0) {\n this.selectedGame = this.games[gameIndex];\n this.selectedGameIndex = gameIndex;\n }\n else {\n this.selectedGame = undefined;\n }\n }\n\n exitToEnterHighScore(): void {\n const launchedGameHighs = this.getHighScores(this.launchedGame);\n const currentHighScore = this.mostRecentScores[0];\n const lastScore = launchedGameHighs[launchedGameHighs.length - 1]?.score;\n if (launchedGameHighs.length === configData.HighScoresToKeep \n && lastScore \n && currentHighScore < lastScore) {\n this.exitGame(KioskState.GameOver);\n\n } else {\n this.exitGame(KioskState.EnterHighScore);\n }\n\n }\n\n gameOver(skipHighScore?: boolean): void {\n if (this.state !== KioskState.PlayingGame) { return; }\n\n if (this.lockedGameId) {\n this.launchGame(this.lockedGameId);\n return;\n }\n\n if (!skipHighScore && this.mostRecentScores && this.mostRecentScores.length && (this.selectedGame!.highScoreMode !== \"None\")) {\n this.exitToEnterHighScore();\n }\n else {\n this.exitGame(KioskState.GameOver);\n }\n }\n\n escapeGame(): void {\n if (this.state !== KioskState.PlayingGame || this.lockedGameId) { return; }\n this.gamepadManager.keyboardManager.clear();\n this.exitGame(KioskState.MainMenu);\n }\n\n private exitGame(state: KioskState): void {\n if (this.state !== KioskState.PlayingGame) { return; }\n this.navigate(state);\n\n const gamespace = document.getElementsByTagName(\"BODY\")[0];\n while (gamespace.firstChild) {\n gamespace.firstChild.remove();\n }\n\n this.siteElements.forEach(item => gamespace.appendChild(item));\n }\n\n getBuiltGame(gameId: string): BuiltSimJSInfo | undefined {\n const allBuiltGames = this.builtGamesCache;\n if (allBuiltGames[gameId]) {\n return allBuiltGames[gameId];\n }\n }\n\n addBuiltGame(gameId: string, builtSimJs: BuiltSimJSInfo) {\n const allBuiltGames = this.builtGamesCache;\n\n if (!allBuiltGames[gameId]) {\n allBuiltGames[gameId] = builtSimJs;\n }\n\n }\n\n sendBuiltGame(gameId: string) {\n const builtGame = this.getBuiltGame(gameId);\n const simIframe = document.getElementsByTagName(\"iframe\")[0] as HTMLIFrameElement;\n simIframe?.contentWindow?.postMessage({ ...builtGame, \"type\": \"builtjs\"}, \"*\");\n }\n\n launchGame(gameId: string, preventReturningToMenu = false): void {\n this.launchedGame = gameId;\n if (this.state === KioskState.PlayingGame) { return; }\n if (preventReturningToMenu) this.lockedGameId = gameId;\n this.navigate(KioskState.PlayingGame);\n\n this.siteElements = [];\n const gamespace = document.getElementsByTagName(\"BODY\")[0];\n while (gamespace.firstChild) {\n this.siteElements.push(gamespace.firstChild);\n gamespace.firstChild.remove();\n }\n\n const playUrlBase = `${configData.PlayUrlRoot}?id=${gameId}&hideSimButtons=1&noFooter=1&single=1&fullscreen=1&autofocus=1`\n let playQueryParam = this.getBuiltGame(gameId) ? \"&server=1\" : \"&sendBuilt=1\";\n\n function createIFrame(src: string) {\n const iframe: HTMLIFrameElement = document.createElement(\"iframe\");\n iframe.className = \"sim-embed\";\n iframe.frameBorder = \"0\";\n iframe.setAttribute(\"sandbox\", \"allow-popups allow-forms allow-scripts allow-same-origin\");\n iframe.src = src;\n return iframe;\n }\n const playerIFrame = createIFrame(playUrlBase + playQueryParam);\n gamespace.appendChild(playerIFrame);\n playerIFrame.focus();\n }\n\n launchAddGame() {\n this.navigate(KioskState.AddingGame);\n }\n\n getAllHighScores(): { [index: string]: HighScore[] } {\n const json = localStorage.getItem(this.highScoresLocalStorageKey);\n if (!json) {\n return {};\n }\n\n const allHighScores: {[index: string]: HighScore[]} = JSON.parse(json);\n return allHighScores;\n }\n\n getHighScores(gameId: string): HighScore[] {\n const allHighScores = this.getAllHighScores();\n if (!allHighScores[gameId]) {\n return [];\n }\n\n return allHighScores[gameId];\n }\n\n saveHighScore(gameId: string, initials: string, score: number) {\n const allHighScores = this.getAllHighScores();\n if (!allHighScores[gameId]) {\n allHighScores[gameId] = [];\n }\n\n allHighScores[gameId].push(new HighScore(initials, score));\n\n allHighScores[gameId].sort((first, second) => second.score - first.score);\n allHighScores[gameId].splice(configData.HighScoresToKeep);\n\n localStorage.setItem(this.highScoresLocalStorageKey, JSON.stringify(allHighScores));\n }\n\n resetHighScores() {\n localStorage.removeItem(this.highScoresLocalStorageKey);\n }\n}","import \"../Kiosk.css\";\ninterface IProps {\n selected: boolean;\n content: string;\n}\n\nconst AddGameButton: React.FC = ({ selected, content }) => {\n const buttonClassBase = \"kioskButton\";\n const specificButtonClass = selected ? \"buttonSelected\" : \"buttonUnselected\";\n const kioskButtonClass = `${buttonClassBase} ${specificButtonClass}`;\n\n return (\n
    \n \n
    \n )\n}\n\nexport default AddGameButton;","import objectWithoutPropertiesLoose from \"./objectWithoutPropertiesLoose.js\";\nexport default function _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for (i = 0; i < sourceSymbolKeys.length; i++) {\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}","import arrayWithoutHoles from \"./arrayWithoutHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableSpread from \"./nonIterableSpread.js\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}","export default function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","/**\n * SSR Window 4.0.2\n * Better handling for window object in SSR environment\n * https://github.com/nolimits4web/ssr-window\n *\n * Copyright 2021, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: December 13, 2021\n */\n/* eslint-disable no-param-reassign */\nfunction isObject(obj) {\n return (obj !== null &&\n typeof obj === 'object' &&\n 'constructor' in obj &&\n obj.constructor === Object);\n}\nfunction extend(target = {}, src = {}) {\n Object.keys(src).forEach((key) => {\n if (typeof target[key] === 'undefined')\n target[key] = src[key];\n else if (isObject(src[key]) &&\n isObject(target[key]) &&\n Object.keys(src[key]).length > 0) {\n extend(target[key], src[key]);\n }\n });\n}\n\nconst ssrDocument = {\n body: {},\n addEventListener() { },\n removeEventListener() { },\n activeElement: {\n blur() { },\n nodeName: '',\n },\n querySelector() {\n return null;\n },\n querySelectorAll() {\n return [];\n },\n getElementById() {\n return null;\n },\n createEvent() {\n return {\n initEvent() { },\n };\n },\n createElement() {\n return {\n children: [],\n childNodes: [],\n style: {},\n setAttribute() { },\n getElementsByTagName() {\n return [];\n },\n };\n },\n createElementNS() {\n return {};\n },\n importNode() {\n return null;\n },\n location: {\n hash: '',\n host: '',\n hostname: '',\n href: '',\n origin: '',\n pathname: '',\n protocol: '',\n search: '',\n },\n};\nfunction getDocument() {\n const doc = typeof document !== 'undefined' ? document : {};\n extend(doc, ssrDocument);\n return doc;\n}\n\nconst ssrWindow = {\n document: ssrDocument,\n navigator: {\n userAgent: '',\n },\n location: {\n hash: '',\n host: '',\n hostname: '',\n href: '',\n origin: '',\n pathname: '',\n protocol: '',\n search: '',\n },\n history: {\n replaceState() { },\n pushState() { },\n go() { },\n back() { },\n },\n CustomEvent: function CustomEvent() {\n return this;\n },\n addEventListener() { },\n removeEventListener() { },\n getComputedStyle() {\n return {\n getPropertyValue() {\n return '';\n },\n };\n },\n Image() { },\n Date() { },\n screen: {},\n setTimeout() { },\n clearTimeout() { },\n matchMedia() {\n return {};\n },\n requestAnimationFrame(callback) {\n if (typeof setTimeout === 'undefined') {\n callback();\n return null;\n }\n return setTimeout(callback, 0);\n },\n cancelAnimationFrame(id) {\n if (typeof setTimeout === 'undefined') {\n return;\n }\n clearTimeout(id);\n },\n};\nfunction getWindow() {\n const win = typeof window !== 'undefined' ? window : {};\n extend(win, ssrWindow);\n return win;\n}\n\nexport { extend, getDocument, getWindow, ssrDocument, ssrWindow };\n","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}","import _typeof from \"./typeof.js\";\nimport assertThisInitialized from \"./assertThisInitialized.js\";\nexport default function _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return assertThisInitialized(self);\n}","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}","export default function _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}","export default function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nexport default function _construct(Parent, args, Class) {\n if (isNativeReflectConstruct()) {\n _construct = Reflect.construct.bind();\n } else {\n _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) setPrototypeOf(instance, Class.prototype);\n return instance;\n };\n }\n return _construct.apply(null, arguments);\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeFunction from \"./isNativeFunction.js\";\nimport construct from \"./construct.js\";\nexport default function _wrapNativeSuper(Class) {\n var _cache = typeof Map === \"function\" ? new Map() : undefined;\n _wrapNativeSuper = function _wrapNativeSuper(Class) {\n if (Class === null || !isNativeFunction(Class)) return Class;\n if (typeof Class !== \"function\") {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n if (typeof _cache !== \"undefined\") {\n if (_cache.has(Class)) return _cache.get(Class);\n _cache.set(Class, Wrapper);\n }\n function Wrapper() {\n return construct(Class, arguments, getPrototypeOf(this).constructor);\n }\n Wrapper.prototype = Object.create(Class.prototype, {\n constructor: {\n value: Wrapper,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n return setPrototypeOf(Wrapper, Class);\n };\n return _wrapNativeSuper(Class);\n}","export default function _isNativeFunction(fn) {\n return Function.toString.call(fn).indexOf(\"[native code]\") !== -1;\n}","/**\n * Dom7 4.0.4\n * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API\n * https://framework7.io/docs/dom7.html\n *\n * Copyright 2022, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: January 11, 2022\n */\nimport { getWindow, getDocument } from 'ssr-window';\n\n/* eslint-disable no-proto */\nfunction makeReactive(obj) {\n const proto = obj.__proto__;\n Object.defineProperty(obj, '__proto__', {\n get() {\n return proto;\n },\n\n set(value) {\n proto.__proto__ = value;\n }\n\n });\n}\n\nclass Dom7 extends Array {\n constructor(items) {\n if (typeof items === 'number') {\n super(items);\n } else {\n super(...(items || []));\n makeReactive(this);\n }\n }\n\n}\n\nfunction arrayFlat(arr = []) {\n const res = [];\n arr.forEach(el => {\n if (Array.isArray(el)) {\n res.push(...arrayFlat(el));\n } else {\n res.push(el);\n }\n });\n return res;\n}\nfunction arrayFilter(arr, callback) {\n return Array.prototype.filter.call(arr, callback);\n}\nfunction arrayUnique(arr) {\n const uniqueArray = [];\n\n for (let i = 0; i < arr.length; i += 1) {\n if (uniqueArray.indexOf(arr[i]) === -1) uniqueArray.push(arr[i]);\n }\n\n return uniqueArray;\n}\nfunction toCamelCase(string) {\n return string.toLowerCase().replace(/-(.)/g, (match, group) => group.toUpperCase());\n}\n\n// eslint-disable-next-line\n\nfunction qsa(selector, context) {\n if (typeof selector !== 'string') {\n return [selector];\n }\n\n const a = [];\n const res = context.querySelectorAll(selector);\n\n for (let i = 0; i < res.length; i += 1) {\n a.push(res[i]);\n }\n\n return a;\n}\n\nfunction $(selector, context) {\n const window = getWindow();\n const document = getDocument();\n let arr = [];\n\n if (!context && selector instanceof Dom7) {\n return selector;\n }\n\n if (!selector) {\n return new Dom7(arr);\n }\n\n if (typeof selector === 'string') {\n const html = selector.trim();\n\n if (html.indexOf('<') >= 0 && html.indexOf('>') >= 0) {\n let toCreate = 'div';\n if (html.indexOf(' c.split(' ')));\n this.forEach(el => {\n el.classList.add(...classNames);\n });\n return this;\n}\n\nfunction removeClass(...classes) {\n const classNames = arrayFlat(classes.map(c => c.split(' ')));\n this.forEach(el => {\n el.classList.remove(...classNames);\n });\n return this;\n}\n\nfunction toggleClass(...classes) {\n const classNames = arrayFlat(classes.map(c => c.split(' ')));\n this.forEach(el => {\n classNames.forEach(className => {\n el.classList.toggle(className);\n });\n });\n}\n\nfunction hasClass(...classes) {\n const classNames = arrayFlat(classes.map(c => c.split(' ')));\n return arrayFilter(this, el => {\n return classNames.filter(className => el.classList.contains(className)).length > 0;\n }).length > 0;\n}\n\nfunction attr(attrs, value) {\n if (arguments.length === 1 && typeof attrs === 'string') {\n // Get attr\n if (this[0]) return this[0].getAttribute(attrs);\n return undefined;\n } // Set attrs\n\n\n for (let i = 0; i < this.length; i += 1) {\n if (arguments.length === 2) {\n // String\n this[i].setAttribute(attrs, value);\n } else {\n // Object\n for (const attrName in attrs) {\n this[i][attrName] = attrs[attrName];\n this[i].setAttribute(attrName, attrs[attrName]);\n }\n }\n }\n\n return this;\n}\n\nfunction removeAttr(attr) {\n for (let i = 0; i < this.length; i += 1) {\n this[i].removeAttribute(attr);\n }\n\n return this;\n}\n\nfunction prop(props, value) {\n if (arguments.length === 1 && typeof props === 'string') {\n // Get prop\n if (this[0]) return this[0][props];\n } else {\n // Set props\n for (let i = 0; i < this.length; i += 1) {\n if (arguments.length === 2) {\n // String\n this[i][props] = value;\n } else {\n // Object\n for (const propName in props) {\n this[i][propName] = props[propName];\n }\n }\n }\n\n return this;\n }\n\n return this;\n}\n\nfunction data(key, value) {\n let el;\n\n if (typeof value === 'undefined') {\n el = this[0];\n if (!el) return undefined; // Get value\n\n if (el.dom7ElementDataStorage && key in el.dom7ElementDataStorage) {\n return el.dom7ElementDataStorage[key];\n }\n\n const dataKey = el.getAttribute(`data-${key}`);\n\n if (dataKey) {\n return dataKey;\n }\n\n return undefined;\n } // Set value\n\n\n for (let i = 0; i < this.length; i += 1) {\n el = this[i];\n if (!el.dom7ElementDataStorage) el.dom7ElementDataStorage = {};\n el.dom7ElementDataStorage[key] = value;\n }\n\n return this;\n}\n\nfunction removeData(key) {\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (el.dom7ElementDataStorage && el.dom7ElementDataStorage[key]) {\n el.dom7ElementDataStorage[key] = null;\n delete el.dom7ElementDataStorage[key];\n }\n }\n}\n\nfunction dataset() {\n const el = this[0];\n if (!el) return undefined;\n const dataset = {}; // eslint-disable-line\n\n if (el.dataset) {\n for (const dataKey in el.dataset) {\n dataset[dataKey] = el.dataset[dataKey];\n }\n } else {\n for (let i = 0; i < el.attributes.length; i += 1) {\n const attr = el.attributes[i];\n\n if (attr.name.indexOf('data-') >= 0) {\n dataset[toCamelCase(attr.name.split('data-')[1])] = attr.value;\n }\n }\n }\n\n for (const key in dataset) {\n if (dataset[key] === 'false') dataset[key] = false;else if (dataset[key] === 'true') dataset[key] = true;else if (parseFloat(dataset[key]) === dataset[key] * 1) dataset[key] *= 1;\n }\n\n return dataset;\n}\n\nfunction val(value) {\n if (typeof value === 'undefined') {\n // get value\n const el = this[0];\n if (!el) return undefined;\n\n if (el.multiple && el.nodeName.toLowerCase() === 'select') {\n const values = [];\n\n for (let i = 0; i < el.selectedOptions.length; i += 1) {\n values.push(el.selectedOptions[i].value);\n }\n\n return values;\n }\n\n return el.value;\n } // set value\n\n\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (Array.isArray(value) && el.multiple && el.nodeName.toLowerCase() === 'select') {\n for (let j = 0; j < el.options.length; j += 1) {\n el.options[j].selected = value.indexOf(el.options[j].value) >= 0;\n }\n } else {\n el.value = value;\n }\n }\n\n return this;\n}\n\nfunction value(value) {\n return this.val(value);\n}\n\nfunction transform(transform) {\n for (let i = 0; i < this.length; i += 1) {\n this[i].style.transform = transform;\n }\n\n return this;\n}\n\nfunction transition(duration) {\n for (let i = 0; i < this.length; i += 1) {\n this[i].style.transitionDuration = typeof duration !== 'string' ? `${duration}ms` : duration;\n }\n\n return this;\n}\n\nfunction on(...args) {\n let [eventType, targetSelector, listener, capture] = args;\n\n if (typeof args[1] === 'function') {\n [eventType, listener, capture] = args;\n targetSelector = undefined;\n }\n\n if (!capture) capture = false;\n\n function handleLiveEvent(e) {\n const target = e.target;\n if (!target) return;\n const eventData = e.target.dom7EventData || [];\n\n if (eventData.indexOf(e) < 0) {\n eventData.unshift(e);\n }\n\n if ($(target).is(targetSelector)) listener.apply(target, eventData);else {\n const parents = $(target).parents(); // eslint-disable-line\n\n for (let k = 0; k < parents.length; k += 1) {\n if ($(parents[k]).is(targetSelector)) listener.apply(parents[k], eventData);\n }\n }\n }\n\n function handleEvent(e) {\n const eventData = e && e.target ? e.target.dom7EventData || [] : [];\n\n if (eventData.indexOf(e) < 0) {\n eventData.unshift(e);\n }\n\n listener.apply(this, eventData);\n }\n\n const events = eventType.split(' ');\n let j;\n\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (!targetSelector) {\n for (j = 0; j < events.length; j += 1) {\n const event = events[j];\n if (!el.dom7Listeners) el.dom7Listeners = {};\n if (!el.dom7Listeners[event]) el.dom7Listeners[event] = [];\n el.dom7Listeners[event].push({\n listener,\n proxyListener: handleEvent\n });\n el.addEventListener(event, handleEvent, capture);\n }\n } else {\n // Live events\n for (j = 0; j < events.length; j += 1) {\n const event = events[j];\n if (!el.dom7LiveListeners) el.dom7LiveListeners = {};\n if (!el.dom7LiveListeners[event]) el.dom7LiveListeners[event] = [];\n el.dom7LiveListeners[event].push({\n listener,\n proxyListener: handleLiveEvent\n });\n el.addEventListener(event, handleLiveEvent, capture);\n }\n }\n }\n\n return this;\n}\n\nfunction off(...args) {\n let [eventType, targetSelector, listener, capture] = args;\n\n if (typeof args[1] === 'function') {\n [eventType, listener, capture] = args;\n targetSelector = undefined;\n }\n\n if (!capture) capture = false;\n const events = eventType.split(' ');\n\n for (let i = 0; i < events.length; i += 1) {\n const event = events[i];\n\n for (let j = 0; j < this.length; j += 1) {\n const el = this[j];\n let handlers;\n\n if (!targetSelector && el.dom7Listeners) {\n handlers = el.dom7Listeners[event];\n } else if (targetSelector && el.dom7LiveListeners) {\n handlers = el.dom7LiveListeners[event];\n }\n\n if (handlers && handlers.length) {\n for (let k = handlers.length - 1; k >= 0; k -= 1) {\n const handler = handlers[k];\n\n if (listener && handler.listener === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (listener && handler.listener && handler.listener.dom7proxy && handler.listener.dom7proxy === listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n } else if (!listener) {\n el.removeEventListener(event, handler.proxyListener, capture);\n handlers.splice(k, 1);\n }\n }\n }\n }\n }\n\n return this;\n}\n\nfunction once(...args) {\n const dom = this;\n let [eventName, targetSelector, listener, capture] = args;\n\n if (typeof args[1] === 'function') {\n [eventName, listener, capture] = args;\n targetSelector = undefined;\n }\n\n function onceHandler(...eventArgs) {\n listener.apply(this, eventArgs);\n dom.off(eventName, targetSelector, onceHandler, capture);\n\n if (onceHandler.dom7proxy) {\n delete onceHandler.dom7proxy;\n }\n }\n\n onceHandler.dom7proxy = listener;\n return dom.on(eventName, targetSelector, onceHandler, capture);\n}\n\nfunction trigger(...args) {\n const window = getWindow();\n const events = args[0].split(' ');\n const eventData = args[1];\n\n for (let i = 0; i < events.length; i += 1) {\n const event = events[i];\n\n for (let j = 0; j < this.length; j += 1) {\n const el = this[j];\n\n if (window.CustomEvent) {\n const evt = new window.CustomEvent(event, {\n detail: eventData,\n bubbles: true,\n cancelable: true\n });\n el.dom7EventData = args.filter((data, dataIndex) => dataIndex > 0);\n el.dispatchEvent(evt);\n el.dom7EventData = [];\n delete el.dom7EventData;\n }\n }\n }\n\n return this;\n}\n\nfunction transitionEnd(callback) {\n const dom = this;\n\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off('transitionend', fireCallBack);\n }\n\n if (callback) {\n dom.on('transitionend', fireCallBack);\n }\n\n return this;\n}\n\nfunction animationEnd(callback) {\n const dom = this;\n\n function fireCallBack(e) {\n if (e.target !== this) return;\n callback.call(this, e);\n dom.off('animationend', fireCallBack);\n }\n\n if (callback) {\n dom.on('animationend', fireCallBack);\n }\n\n return this;\n}\n\nfunction width() {\n const window = getWindow();\n\n if (this[0] === window) {\n return window.innerWidth;\n }\n\n if (this.length > 0) {\n return parseFloat(this.css('width'));\n }\n\n return null;\n}\n\nfunction outerWidth(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n const styles = this.styles();\n return this[0].offsetWidth + parseFloat(styles.getPropertyValue('margin-right')) + parseFloat(styles.getPropertyValue('margin-left'));\n }\n\n return this[0].offsetWidth;\n }\n\n return null;\n}\n\nfunction height() {\n const window = getWindow();\n\n if (this[0] === window) {\n return window.innerHeight;\n }\n\n if (this.length > 0) {\n return parseFloat(this.css('height'));\n }\n\n return null;\n}\n\nfunction outerHeight(includeMargins) {\n if (this.length > 0) {\n if (includeMargins) {\n const styles = this.styles();\n return this[0].offsetHeight + parseFloat(styles.getPropertyValue('margin-top')) + parseFloat(styles.getPropertyValue('margin-bottom'));\n }\n\n return this[0].offsetHeight;\n }\n\n return null;\n}\n\nfunction offset() {\n if (this.length > 0) {\n const window = getWindow();\n const document = getDocument();\n const el = this[0];\n const box = el.getBoundingClientRect();\n const body = document.body;\n const clientTop = el.clientTop || body.clientTop || 0;\n const clientLeft = el.clientLeft || body.clientLeft || 0;\n const scrollTop = el === window ? window.scrollY : el.scrollTop;\n const scrollLeft = el === window ? window.scrollX : el.scrollLeft;\n return {\n top: box.top + scrollTop - clientTop,\n left: box.left + scrollLeft - clientLeft\n };\n }\n\n return null;\n}\n\nfunction hide() {\n for (let i = 0; i < this.length; i += 1) {\n this[i].style.display = 'none';\n }\n\n return this;\n}\n\nfunction show() {\n const window = getWindow();\n\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (el.style.display === 'none') {\n el.style.display = '';\n }\n\n if (window.getComputedStyle(el, null).getPropertyValue('display') === 'none') {\n // Still not visible\n el.style.display = 'block';\n }\n }\n\n return this;\n}\n\nfunction styles() {\n const window = getWindow();\n if (this[0]) return window.getComputedStyle(this[0], null);\n return {};\n}\n\nfunction css(props, value) {\n const window = getWindow();\n let i;\n\n if (arguments.length === 1) {\n if (typeof props === 'string') {\n // .css('width')\n if (this[0]) return window.getComputedStyle(this[0], null).getPropertyValue(props);\n } else {\n // .css({ width: '100px' })\n for (i = 0; i < this.length; i += 1) {\n for (const prop in props) {\n this[i].style[prop] = props[prop];\n }\n }\n\n return this;\n }\n }\n\n if (arguments.length === 2 && typeof props === 'string') {\n // .css('width', '100px')\n for (i = 0; i < this.length; i += 1) {\n this[i].style[props] = value;\n }\n\n return this;\n }\n\n return this;\n}\n\nfunction each(callback) {\n if (!callback) return this;\n this.forEach((el, index) => {\n callback.apply(el, [el, index]);\n });\n return this;\n}\n\nfunction filter(callback) {\n const result = arrayFilter(this, callback);\n return $(result);\n}\n\nfunction html(html) {\n if (typeof html === 'undefined') {\n return this[0] ? this[0].innerHTML : null;\n }\n\n for (let i = 0; i < this.length; i += 1) {\n this[i].innerHTML = html;\n }\n\n return this;\n}\n\nfunction text(text) {\n if (typeof text === 'undefined') {\n return this[0] ? this[0].textContent.trim() : null;\n }\n\n for (let i = 0; i < this.length; i += 1) {\n this[i].textContent = text;\n }\n\n return this;\n}\n\nfunction is(selector) {\n const window = getWindow();\n const document = getDocument();\n const el = this[0];\n let compareWith;\n let i;\n if (!el || typeof selector === 'undefined') return false;\n\n if (typeof selector === 'string') {\n if (el.matches) return el.matches(selector);\n if (el.webkitMatchesSelector) return el.webkitMatchesSelector(selector);\n if (el.msMatchesSelector) return el.msMatchesSelector(selector);\n compareWith = $(selector);\n\n for (i = 0; i < compareWith.length; i += 1) {\n if (compareWith[i] === el) return true;\n }\n\n return false;\n }\n\n if (selector === document) {\n return el === document;\n }\n\n if (selector === window) {\n return el === window;\n }\n\n if (selector.nodeType || selector instanceof Dom7) {\n compareWith = selector.nodeType ? [selector] : selector;\n\n for (i = 0; i < compareWith.length; i += 1) {\n if (compareWith[i] === el) return true;\n }\n\n return false;\n }\n\n return false;\n}\n\nfunction index() {\n let child = this[0];\n let i;\n\n if (child) {\n i = 0; // eslint-disable-next-line\n\n while ((child = child.previousSibling) !== null) {\n if (child.nodeType === 1) i += 1;\n }\n\n return i;\n }\n\n return undefined;\n}\n\nfunction eq(index) {\n if (typeof index === 'undefined') return this;\n const length = this.length;\n\n if (index > length - 1) {\n return $([]);\n }\n\n if (index < 0) {\n const returnIndex = length + index;\n if (returnIndex < 0) return $([]);\n return $([this[returnIndex]]);\n }\n\n return $([this[index]]);\n}\n\nfunction append(...els) {\n let newChild;\n const document = getDocument();\n\n for (let k = 0; k < els.length; k += 1) {\n newChild = els[k];\n\n for (let i = 0; i < this.length; i += 1) {\n if (typeof newChild === 'string') {\n const tempDiv = document.createElement('div');\n tempDiv.innerHTML = newChild;\n\n while (tempDiv.firstChild) {\n this[i].appendChild(tempDiv.firstChild);\n }\n } else if (newChild instanceof Dom7) {\n for (let j = 0; j < newChild.length; j += 1) {\n this[i].appendChild(newChild[j]);\n }\n } else {\n this[i].appendChild(newChild);\n }\n }\n }\n\n return this;\n}\n\nfunction appendTo(parent) {\n $(parent).append(this);\n return this;\n}\n\nfunction prepend(newChild) {\n const document = getDocument();\n let i;\n let j;\n\n for (i = 0; i < this.length; i += 1) {\n if (typeof newChild === 'string') {\n const tempDiv = document.createElement('div');\n tempDiv.innerHTML = newChild;\n\n for (j = tempDiv.childNodes.length - 1; j >= 0; j -= 1) {\n this[i].insertBefore(tempDiv.childNodes[j], this[i].childNodes[0]);\n }\n } else if (newChild instanceof Dom7) {\n for (j = 0; j < newChild.length; j += 1) {\n this[i].insertBefore(newChild[j], this[i].childNodes[0]);\n }\n } else {\n this[i].insertBefore(newChild, this[i].childNodes[0]);\n }\n }\n\n return this;\n}\n\nfunction prependTo(parent) {\n $(parent).prepend(this);\n return this;\n}\n\nfunction insertBefore(selector) {\n const before = $(selector);\n\n for (let i = 0; i < this.length; i += 1) {\n if (before.length === 1) {\n before[0].parentNode.insertBefore(this[i], before[0]);\n } else if (before.length > 1) {\n for (let j = 0; j < before.length; j += 1) {\n before[j].parentNode.insertBefore(this[i].cloneNode(true), before[j]);\n }\n }\n }\n}\n\nfunction insertAfter(selector) {\n const after = $(selector);\n\n for (let i = 0; i < this.length; i += 1) {\n if (after.length === 1) {\n after[0].parentNode.insertBefore(this[i], after[0].nextSibling);\n } else if (after.length > 1) {\n for (let j = 0; j < after.length; j += 1) {\n after[j].parentNode.insertBefore(this[i].cloneNode(true), after[j].nextSibling);\n }\n }\n }\n}\n\nfunction next(selector) {\n if (this.length > 0) {\n if (selector) {\n if (this[0].nextElementSibling && $(this[0].nextElementSibling).is(selector)) {\n return $([this[0].nextElementSibling]);\n }\n\n return $([]);\n }\n\n if (this[0].nextElementSibling) return $([this[0].nextElementSibling]);\n return $([]);\n }\n\n return $([]);\n}\n\nfunction nextAll(selector) {\n const nextEls = [];\n let el = this[0];\n if (!el) return $([]);\n\n while (el.nextElementSibling) {\n const next = el.nextElementSibling; // eslint-disable-line\n\n if (selector) {\n if ($(next).is(selector)) nextEls.push(next);\n } else nextEls.push(next);\n\n el = next;\n }\n\n return $(nextEls);\n}\n\nfunction prev(selector) {\n if (this.length > 0) {\n const el = this[0];\n\n if (selector) {\n if (el.previousElementSibling && $(el.previousElementSibling).is(selector)) {\n return $([el.previousElementSibling]);\n }\n\n return $([]);\n }\n\n if (el.previousElementSibling) return $([el.previousElementSibling]);\n return $([]);\n }\n\n return $([]);\n}\n\nfunction prevAll(selector) {\n const prevEls = [];\n let el = this[0];\n if (!el) return $([]);\n\n while (el.previousElementSibling) {\n const prev = el.previousElementSibling; // eslint-disable-line\n\n if (selector) {\n if ($(prev).is(selector)) prevEls.push(prev);\n } else prevEls.push(prev);\n\n el = prev;\n }\n\n return $(prevEls);\n}\n\nfunction siblings(selector) {\n return this.nextAll(selector).add(this.prevAll(selector));\n}\n\nfunction parent(selector) {\n const parents = []; // eslint-disable-line\n\n for (let i = 0; i < this.length; i += 1) {\n if (this[i].parentNode !== null) {\n if (selector) {\n if ($(this[i].parentNode).is(selector)) parents.push(this[i].parentNode);\n } else {\n parents.push(this[i].parentNode);\n }\n }\n }\n\n return $(parents);\n}\n\nfunction parents(selector) {\n const parents = []; // eslint-disable-line\n\n for (let i = 0; i < this.length; i += 1) {\n let parent = this[i].parentNode; // eslint-disable-line\n\n while (parent) {\n if (selector) {\n if ($(parent).is(selector)) parents.push(parent);\n } else {\n parents.push(parent);\n }\n\n parent = parent.parentNode;\n }\n }\n\n return $(parents);\n}\n\nfunction closest(selector) {\n let closest = this; // eslint-disable-line\n\n if (typeof selector === 'undefined') {\n return $([]);\n }\n\n if (!closest.is(selector)) {\n closest = closest.parents(selector).eq(0);\n }\n\n return closest;\n}\n\nfunction find(selector) {\n const foundElements = [];\n\n for (let i = 0; i < this.length; i += 1) {\n const found = this[i].querySelectorAll(selector);\n\n for (let j = 0; j < found.length; j += 1) {\n foundElements.push(found[j]);\n }\n }\n\n return $(foundElements);\n}\n\nfunction children(selector) {\n const children = []; // eslint-disable-line\n\n for (let i = 0; i < this.length; i += 1) {\n const childNodes = this[i].children;\n\n for (let j = 0; j < childNodes.length; j += 1) {\n if (!selector || $(childNodes[j]).is(selector)) {\n children.push(childNodes[j]);\n }\n }\n }\n\n return $(children);\n}\n\nfunction remove() {\n for (let i = 0; i < this.length; i += 1) {\n if (this[i].parentNode) this[i].parentNode.removeChild(this[i]);\n }\n\n return this;\n}\n\nfunction detach() {\n return this.remove();\n}\n\nfunction add(...els) {\n const dom = this;\n let i;\n let j;\n\n for (i = 0; i < els.length; i += 1) {\n const toAdd = $(els[i]);\n\n for (j = 0; j < toAdd.length; j += 1) {\n dom.push(toAdd[j]);\n }\n }\n\n return dom;\n}\n\nfunction empty() {\n for (let i = 0; i < this.length; i += 1) {\n const el = this[i];\n\n if (el.nodeType === 1) {\n for (let j = 0; j < el.childNodes.length; j += 1) {\n if (el.childNodes[j].parentNode) {\n el.childNodes[j].parentNode.removeChild(el.childNodes[j]);\n }\n }\n\n el.textContent = '';\n }\n }\n\n return this;\n}\n\n// eslint-disable-next-line\n\nfunction scrollTo(...args) {\n const window = getWindow();\n let [left, top, duration, easing, callback] = args;\n\n if (args.length === 4 && typeof easing === 'function') {\n callback = easing;\n [left, top, duration, callback, easing] = args;\n }\n\n if (typeof easing === 'undefined') easing = 'swing';\n return this.each(function animate() {\n const el = this;\n let currentTop;\n let currentLeft;\n let maxTop;\n let maxLeft;\n let newTop;\n let newLeft;\n let scrollTop; // eslint-disable-line\n\n let scrollLeft; // eslint-disable-line\n\n let animateTop = top > 0 || top === 0;\n let animateLeft = left > 0 || left === 0;\n\n if (typeof easing === 'undefined') {\n easing = 'swing';\n }\n\n if (animateTop) {\n currentTop = el.scrollTop;\n\n if (!duration) {\n el.scrollTop = top;\n }\n }\n\n if (animateLeft) {\n currentLeft = el.scrollLeft;\n\n if (!duration) {\n el.scrollLeft = left;\n }\n }\n\n if (!duration) return;\n\n if (animateTop) {\n maxTop = el.scrollHeight - el.offsetHeight;\n newTop = Math.max(Math.min(top, maxTop), 0);\n }\n\n if (animateLeft) {\n maxLeft = el.scrollWidth - el.offsetWidth;\n newLeft = Math.max(Math.min(left, maxLeft), 0);\n }\n\n let startTime = null;\n if (animateTop && newTop === currentTop) animateTop = false;\n if (animateLeft && newLeft === currentLeft) animateLeft = false;\n\n function render(time = new Date().getTime()) {\n if (startTime === null) {\n startTime = time;\n }\n\n const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);\n const easeProgress = easing === 'linear' ? progress : 0.5 - Math.cos(progress * Math.PI) / 2;\n let done;\n if (animateTop) scrollTop = currentTop + easeProgress * (newTop - currentTop);\n if (animateLeft) scrollLeft = currentLeft + easeProgress * (newLeft - currentLeft);\n\n if (animateTop && newTop > currentTop && scrollTop >= newTop) {\n el.scrollTop = newTop;\n done = true;\n }\n\n if (animateTop && newTop < currentTop && scrollTop <= newTop) {\n el.scrollTop = newTop;\n done = true;\n }\n\n if (animateLeft && newLeft > currentLeft && scrollLeft >= newLeft) {\n el.scrollLeft = newLeft;\n done = true;\n }\n\n if (animateLeft && newLeft < currentLeft && scrollLeft <= newLeft) {\n el.scrollLeft = newLeft;\n done = true;\n }\n\n if (done) {\n if (callback) callback();\n return;\n }\n\n if (animateTop) el.scrollTop = scrollTop;\n if (animateLeft) el.scrollLeft = scrollLeft;\n window.requestAnimationFrame(render);\n }\n\n window.requestAnimationFrame(render);\n });\n} // scrollTop(top, duration, easing, callback) {\n\n\nfunction scrollTop(...args) {\n let [top, duration, easing, callback] = args;\n\n if (args.length === 3 && typeof easing === 'function') {\n [top, duration, callback, easing] = args;\n }\n\n const dom = this;\n\n if (typeof top === 'undefined') {\n if (dom.length > 0) return dom[0].scrollTop;\n return null;\n }\n\n return dom.scrollTo(undefined, top, duration, easing, callback);\n}\n\nfunction scrollLeft(...args) {\n let [left, duration, easing, callback] = args;\n\n if (args.length === 3 && typeof easing === 'function') {\n [left, duration, callback, easing] = args;\n }\n\n const dom = this;\n\n if (typeof left === 'undefined') {\n if (dom.length > 0) return dom[0].scrollLeft;\n return null;\n }\n\n return dom.scrollTo(left, undefined, duration, easing, callback);\n}\n\n// eslint-disable-next-line\n\nfunction animate(initialProps, initialParams) {\n const window = getWindow();\n const els = this;\n const a = {\n props: Object.assign({}, initialProps),\n params: Object.assign({\n duration: 300,\n easing: 'swing' // or 'linear'\n\n /* Callbacks\n begin(elements)\n complete(elements)\n progress(elements, complete, remaining, start, tweenValue)\n */\n\n }, initialParams),\n elements: els,\n animating: false,\n que: [],\n\n easingProgress(easing, progress) {\n if (easing === 'swing') {\n return 0.5 - Math.cos(progress * Math.PI) / 2;\n }\n\n if (typeof easing === 'function') {\n return easing(progress);\n }\n\n return progress;\n },\n\n stop() {\n if (a.frameId) {\n window.cancelAnimationFrame(a.frameId);\n }\n\n a.animating = false;\n a.elements.each(el => {\n const element = el;\n delete element.dom7AnimateInstance;\n });\n a.que = [];\n },\n\n done(complete) {\n a.animating = false;\n a.elements.each(el => {\n const element = el;\n delete element.dom7AnimateInstance;\n });\n if (complete) complete(els);\n\n if (a.que.length > 0) {\n const que = a.que.shift();\n a.animate(que[0], que[1]);\n }\n },\n\n animate(props, params) {\n if (a.animating) {\n a.que.push([props, params]);\n return a;\n }\n\n const elements = []; // Define & Cache Initials & Units\n\n a.elements.each((el, index) => {\n let initialFullValue;\n let initialValue;\n let unit;\n let finalValue;\n let finalFullValue;\n if (!el.dom7AnimateInstance) a.elements[index].dom7AnimateInstance = a;\n elements[index] = {\n container: el\n };\n Object.keys(props).forEach(prop => {\n initialFullValue = window.getComputedStyle(el, null).getPropertyValue(prop).replace(',', '.');\n initialValue = parseFloat(initialFullValue);\n unit = initialFullValue.replace(initialValue, '');\n finalValue = parseFloat(props[prop]);\n finalFullValue = props[prop] + unit;\n elements[index][prop] = {\n initialFullValue,\n initialValue,\n unit,\n finalValue,\n finalFullValue,\n currentValue: initialValue\n };\n });\n });\n let startTime = null;\n let time;\n let elementsDone = 0;\n let propsDone = 0;\n let done;\n let began = false;\n a.animating = true;\n\n function render() {\n time = new Date().getTime();\n let progress;\n let easeProgress; // let el;\n\n if (!began) {\n began = true;\n if (params.begin) params.begin(els);\n }\n\n if (startTime === null) {\n startTime = time;\n }\n\n if (params.progress) {\n // eslint-disable-next-line\n params.progress(els, Math.max(Math.min((time - startTime) / params.duration, 1), 0), startTime + params.duration - time < 0 ? 0 : startTime + params.duration - time, startTime);\n }\n\n elements.forEach(element => {\n const el = element;\n if (done || el.done) return;\n Object.keys(props).forEach(prop => {\n if (done || el.done) return;\n progress = Math.max(Math.min((time - startTime) / params.duration, 1), 0);\n easeProgress = a.easingProgress(params.easing, progress);\n const {\n initialValue,\n finalValue,\n unit\n } = el[prop];\n el[prop].currentValue = initialValue + easeProgress * (finalValue - initialValue);\n const currentValue = el[prop].currentValue;\n\n if (finalValue > initialValue && currentValue >= finalValue || finalValue < initialValue && currentValue <= finalValue) {\n el.container.style[prop] = finalValue + unit;\n propsDone += 1;\n\n if (propsDone === Object.keys(props).length) {\n el.done = true;\n elementsDone += 1;\n }\n\n if (elementsDone === elements.length) {\n done = true;\n }\n }\n\n if (done) {\n a.done(params.complete);\n return;\n }\n\n el.container.style[prop] = currentValue + unit;\n });\n });\n if (done) return; // Then call\n\n a.frameId = window.requestAnimationFrame(render);\n }\n\n a.frameId = window.requestAnimationFrame(render);\n return a;\n }\n\n };\n\n if (a.elements.length === 0) {\n return els;\n }\n\n let animateInstance;\n\n for (let i = 0; i < a.elements.length; i += 1) {\n if (a.elements[i].dom7AnimateInstance) {\n animateInstance = a.elements[i].dom7AnimateInstance;\n } else a.elements[i].dom7AnimateInstance = a;\n }\n\n if (!animateInstance) {\n animateInstance = a;\n }\n\n if (initialProps === 'stop') {\n animateInstance.stop();\n } else {\n animateInstance.animate(a.props, a.params);\n }\n\n return els;\n}\n\nfunction stop() {\n const els = this;\n\n for (let i = 0; i < els.length; i += 1) {\n if (els[i].dom7AnimateInstance) {\n els[i].dom7AnimateInstance.stop();\n }\n }\n}\n\nconst noTrigger = 'resize scroll'.split(' ');\n\nfunction shortcut(name) {\n function eventHandler(...args) {\n if (typeof args[0] === 'undefined') {\n for (let i = 0; i < this.length; i += 1) {\n if (noTrigger.indexOf(name) < 0) {\n if (name in this[i]) this[i][name]();else {\n $(this[i]).trigger(name);\n }\n }\n }\n\n return this;\n }\n\n return this.on(name, ...args);\n }\n\n return eventHandler;\n}\n\nconst click = shortcut('click');\nconst blur = shortcut('blur');\nconst focus = shortcut('focus');\nconst focusin = shortcut('focusin');\nconst focusout = shortcut('focusout');\nconst keyup = shortcut('keyup');\nconst keydown = shortcut('keydown');\nconst keypress = shortcut('keypress');\nconst submit = shortcut('submit');\nconst change = shortcut('change');\nconst mousedown = shortcut('mousedown');\nconst mousemove = shortcut('mousemove');\nconst mouseup = shortcut('mouseup');\nconst mouseenter = shortcut('mouseenter');\nconst mouseleave = shortcut('mouseleave');\nconst mouseout = shortcut('mouseout');\nconst mouseover = shortcut('mouseover');\nconst touchstart = shortcut('touchstart');\nconst touchend = shortcut('touchend');\nconst touchmove = shortcut('touchmove');\nconst resize = shortcut('resize');\nconst scroll = shortcut('scroll');\n\nexport default $;\nexport { $, add, addClass, animate, animationEnd, append, appendTo, attr, blur, change, children, click, closest, css, data, dataset, detach, each, empty, eq, filter, find, focus, focusin, focusout, hasClass, height, hide, html, index, insertAfter, insertBefore, is, keydown, keypress, keyup, mousedown, mouseenter, mouseleave, mousemove, mouseout, mouseover, mouseup, next, nextAll, off, offset, on, once, outerHeight, outerWidth, parent, parents, prepend, prependTo, prev, prevAll, prop, remove, removeAttr, removeClass, removeData, resize, scroll, scrollLeft, scrollTo, scrollTop, show, siblings, stop, styles, submit, text, toggleClass, touchend, touchmove, touchstart, transform, transition, transitionEnd, trigger, val, value, width };\n","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nimport possibleConstructorReturn from \"./possibleConstructorReturn.js\";\nexport default function _createSuper(Derived) {\n var hasNativeReflectConstruct = isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = getPrototypeOf(Derived),\n result;\n if (hasNativeReflectConstruct) {\n var NewTarget = getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n return possibleConstructorReturn(this, result);\n };\n}","import { $, addClass, removeClass, hasClass, toggleClass, attr, removeAttr, transform, transition, on, off, trigger, transitionEnd, outerWidth, outerHeight, styles, offset, css, each, html, text, is, index, eq, append, prepend, next, nextAll, prev, prevAll, parent, parents, closest, find, children, filter, remove } from 'dom7';\nconst Methods = {\n addClass,\n removeClass,\n hasClass,\n toggleClass,\n attr,\n removeAttr,\n transform,\n transition,\n on,\n off,\n trigger,\n transitionEnd,\n outerWidth,\n outerHeight,\n styles,\n offset,\n css,\n each,\n html,\n text,\n is,\n index,\n eq,\n append,\n prepend,\n next,\n nextAll,\n prev,\n prevAll,\n parent,\n parents,\n closest,\n find,\n children,\n filter,\n remove\n};\nObject.keys(Methods).forEach(methodName => {\n Object.defineProperty($.fn, methodName, {\n value: Methods[methodName],\n writable: true\n });\n});\nexport default $;","import { getWindow, getDocument } from 'ssr-window';\nlet support;\n\nfunction calcSupport() {\n const window = getWindow();\n const document = getDocument();\n return {\n smoothScroll: document.documentElement && 'scrollBehavior' in document.documentElement.style,\n touch: !!('ontouchstart' in window || window.DocumentTouch && document instanceof window.DocumentTouch),\n passiveListener: function checkPassiveListener() {\n let supportsPassive = false;\n\n try {\n const opts = Object.defineProperty({}, 'passive', {\n // eslint-disable-next-line\n get() {\n supportsPassive = true;\n }\n\n });\n window.addEventListener('testPassiveListener', null, opts);\n } catch (e) {// No support\n }\n\n return supportsPassive;\n }(),\n gestures: function checkGestures() {\n return 'ongesturestart' in window;\n }()\n };\n}\n\nfunction getSupport() {\n if (!support) {\n support = calcSupport();\n }\n\n return support;\n}\n\nexport { getSupport };","import { getWindow } from 'ssr-window';\nimport { getSupport } from './get-support.js';\nlet deviceCached;\n\nfunction calcDevice({\n userAgent\n} = {}) {\n const support = getSupport();\n const window = getWindow();\n const platform = window.navigator.platform;\n const ua = userAgent || window.navigator.userAgent;\n const device = {\n ios: false,\n android: false\n };\n const screenWidth = window.screen.width;\n const screenHeight = window.screen.height;\n const android = ua.match(/(Android);?[\\s\\/]+([\\d.]+)?/); // eslint-disable-line\n\n let ipad = ua.match(/(iPad).*OS\\s([\\d_]+)/);\n const ipod = ua.match(/(iPod)(.*OS\\s([\\d_]+))?/);\n const iphone = !ipad && ua.match(/(iPhone\\sOS|iOS)\\s([\\d_]+)/);\n const windows = platform === 'Win32';\n let macos = platform === 'MacIntel'; // iPadOs 13 fix\n\n const iPadScreens = ['1024x1366', '1366x1024', '834x1194', '1194x834', '834x1112', '1112x834', '768x1024', '1024x768', '820x1180', '1180x820', '810x1080', '1080x810'];\n\n if (!ipad && macos && support.touch && iPadScreens.indexOf(`${screenWidth}x${screenHeight}`) >= 0) {\n ipad = ua.match(/(Version)\\/([\\d.]+)/);\n if (!ipad) ipad = [0, 1, '13_0_0'];\n macos = false;\n } // Android\n\n\n if (android && !windows) {\n device.os = 'android';\n device.android = true;\n }\n\n if (ipad || iphone || ipod) {\n device.os = 'ios';\n device.ios = true;\n } // Export object\n\n\n return device;\n}\n\nfunction getDevice(overrides = {}) {\n if (!deviceCached) {\n deviceCached = calcDevice(overrides);\n }\n\n return deviceCached;\n}\n\nexport { getDevice };","import { getWindow } from 'ssr-window';\nlet browser;\n\nfunction calcBrowser() {\n const window = getWindow();\n\n function isSafari() {\n const ua = window.navigator.userAgent.toLowerCase();\n return ua.indexOf('safari') >= 0 && ua.indexOf('chrome') < 0 && ua.indexOf('android') < 0;\n }\n\n return {\n isSafari: isSafari(),\n isWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(window.navigator.userAgent)\n };\n}\n\nfunction getBrowser() {\n if (!browser) {\n browser = calcBrowser();\n }\n\n return browser;\n}\n\nexport { getBrowser };","import { getWindow } from 'ssr-window';\n\nfunction deleteProps(obj) {\n const object = obj;\n Object.keys(object).forEach(key => {\n try {\n object[key] = null;\n } catch (e) {// no getter for object\n }\n\n try {\n delete object[key];\n } catch (e) {// something got wrong\n }\n });\n}\n\nfunction nextTick(callback, delay = 0) {\n return setTimeout(callback, delay);\n}\n\nfunction now() {\n return Date.now();\n}\n\nfunction getComputedStyle(el) {\n const window = getWindow();\n let style;\n\n if (window.getComputedStyle) {\n style = window.getComputedStyle(el, null);\n }\n\n if (!style && el.currentStyle) {\n style = el.currentStyle;\n }\n\n if (!style) {\n style = el.style;\n }\n\n return style;\n}\n\nfunction getTranslate(el, axis = 'x') {\n const window = getWindow();\n let matrix;\n let curTransform;\n let transformMatrix;\n const curStyle = getComputedStyle(el, null);\n\n if (window.WebKitCSSMatrix) {\n curTransform = curStyle.transform || curStyle.webkitTransform;\n\n if (curTransform.split(',').length > 6) {\n curTransform = curTransform.split(', ').map(a => a.replace(',', '.')).join(', ');\n } // Some old versions of Webkit choke when 'none' is passed; pass\n // empty string instead in this case\n\n\n transformMatrix = new window.WebKitCSSMatrix(curTransform === 'none' ? '' : curTransform);\n } else {\n transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue('transform').replace('translate(', 'matrix(1, 0, 0, 1,');\n matrix = transformMatrix.toString().split(',');\n }\n\n if (axis === 'x') {\n // Latest Chrome and webkits Fix\n if (window.WebKitCSSMatrix) curTransform = transformMatrix.m41; // Crazy IE10 Matrix\n else if (matrix.length === 16) curTransform = parseFloat(matrix[12]); // Normal Browsers\n else curTransform = parseFloat(matrix[4]);\n }\n\n if (axis === 'y') {\n // Latest Chrome and webkits Fix\n if (window.WebKitCSSMatrix) curTransform = transformMatrix.m42; // Crazy IE10 Matrix\n else if (matrix.length === 16) curTransform = parseFloat(matrix[13]); // Normal Browsers\n else curTransform = parseFloat(matrix[5]);\n }\n\n return curTransform || 0;\n}\n\nfunction isObject(o) {\n return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';\n}\n\nfunction isNode(node) {\n // eslint-disable-next-line\n if (typeof window !== 'undefined' && typeof window.HTMLElement !== 'undefined') {\n return node instanceof HTMLElement;\n }\n\n return node && (node.nodeType === 1 || node.nodeType === 11);\n}\n\nfunction extend(...args) {\n const to = Object(args[0]);\n const noExtend = ['__proto__', 'constructor', 'prototype'];\n\n for (let i = 1; i < args.length; i += 1) {\n const nextSource = args[i];\n\n if (nextSource !== undefined && nextSource !== null && !isNode(nextSource)) {\n const keysArray = Object.keys(Object(nextSource)).filter(key => noExtend.indexOf(key) < 0);\n\n for (let nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex += 1) {\n const nextKey = keysArray[nextIndex];\n const desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n\n if (desc !== undefined && desc.enumerable) {\n if (isObject(to[nextKey]) && isObject(nextSource[nextKey])) {\n if (nextSource[nextKey].__swiper__) {\n to[nextKey] = nextSource[nextKey];\n } else {\n extend(to[nextKey], nextSource[nextKey]);\n }\n } else if (!isObject(to[nextKey]) && isObject(nextSource[nextKey])) {\n to[nextKey] = {};\n\n if (nextSource[nextKey].__swiper__) {\n to[nextKey] = nextSource[nextKey];\n } else {\n extend(to[nextKey], nextSource[nextKey]);\n }\n } else {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n }\n }\n\n return to;\n}\n\nfunction setCSSProperty(el, varName, varValue) {\n el.style.setProperty(varName, varValue);\n}\n\nfunction animateCSSModeScroll({\n swiper,\n targetPosition,\n side\n}) {\n const window = getWindow();\n const startPosition = -swiper.translate;\n let startTime = null;\n let time;\n const duration = swiper.params.speed;\n swiper.wrapperEl.style.scrollSnapType = 'none';\n window.cancelAnimationFrame(swiper.cssModeFrameID);\n const dir = targetPosition > startPosition ? 'next' : 'prev';\n\n const isOutOfBound = (current, target) => {\n return dir === 'next' && current >= target || dir === 'prev' && current <= target;\n };\n\n const animate = () => {\n time = new Date().getTime();\n\n if (startTime === null) {\n startTime = time;\n }\n\n const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);\n const easeProgress = 0.5 - Math.cos(progress * Math.PI) / 2;\n let currentPosition = startPosition + easeProgress * (targetPosition - startPosition);\n\n if (isOutOfBound(currentPosition, targetPosition)) {\n currentPosition = targetPosition;\n }\n\n swiper.wrapperEl.scrollTo({\n [side]: currentPosition\n });\n\n if (isOutOfBound(currentPosition, targetPosition)) {\n swiper.wrapperEl.style.overflow = 'hidden';\n swiper.wrapperEl.style.scrollSnapType = '';\n setTimeout(() => {\n swiper.wrapperEl.style.overflow = '';\n swiper.wrapperEl.scrollTo({\n [side]: currentPosition\n });\n });\n window.cancelAnimationFrame(swiper.cssModeFrameID);\n return;\n }\n\n swiper.cssModeFrameID = window.requestAnimationFrame(animate);\n };\n\n animate();\n}\n\nexport { animateCSSModeScroll, deleteProps, nextTick, now, getTranslate, isObject, extend, getComputedStyle, setCSSProperty };","/* eslint-disable no-underscore-dangle */\nexport default {\n on(events, handler, priority) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (typeof handler !== 'function') return self;\n const method = priority ? 'unshift' : 'push';\n events.split(' ').forEach(event => {\n if (!self.eventsListeners[event]) self.eventsListeners[event] = [];\n self.eventsListeners[event][method](handler);\n });\n return self;\n },\n\n once(events, handler, priority) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (typeof handler !== 'function') return self;\n\n function onceHandler(...args) {\n self.off(events, onceHandler);\n\n if (onceHandler.__emitterProxy) {\n delete onceHandler.__emitterProxy;\n }\n\n handler.apply(self, args);\n }\n\n onceHandler.__emitterProxy = handler;\n return self.on(events, onceHandler, priority);\n },\n\n onAny(handler, priority) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (typeof handler !== 'function') return self;\n const method = priority ? 'unshift' : 'push';\n\n if (self.eventsAnyListeners.indexOf(handler) < 0) {\n self.eventsAnyListeners[method](handler);\n }\n\n return self;\n },\n\n offAny(handler) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (!self.eventsAnyListeners) return self;\n const index = self.eventsAnyListeners.indexOf(handler);\n\n if (index >= 0) {\n self.eventsAnyListeners.splice(index, 1);\n }\n\n return self;\n },\n\n off(events, handler) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (!self.eventsListeners) return self;\n events.split(' ').forEach(event => {\n if (typeof handler === 'undefined') {\n self.eventsListeners[event] = [];\n } else if (self.eventsListeners[event]) {\n self.eventsListeners[event].forEach((eventHandler, index) => {\n if (eventHandler === handler || eventHandler.__emitterProxy && eventHandler.__emitterProxy === handler) {\n self.eventsListeners[event].splice(index, 1);\n }\n });\n }\n });\n return self;\n },\n\n emit(...args) {\n const self = this;\n if (!self.eventsListeners || self.destroyed) return self;\n if (!self.eventsListeners) return self;\n let events;\n let data;\n let context;\n\n if (typeof args[0] === 'string' || Array.isArray(args[0])) {\n events = args[0];\n data = args.slice(1, args.length);\n context = self;\n } else {\n events = args[0].events;\n data = args[0].data;\n context = args[0].context || self;\n }\n\n data.unshift(context);\n const eventsArray = Array.isArray(events) ? events : events.split(' ');\n eventsArray.forEach(event => {\n if (self.eventsAnyListeners && self.eventsAnyListeners.length) {\n self.eventsAnyListeners.forEach(eventHandler => {\n eventHandler.apply(context, [event, ...data]);\n });\n }\n\n if (self.eventsListeners && self.eventsListeners[event]) {\n self.eventsListeners[event].forEach(eventHandler => {\n eventHandler.apply(context, data);\n });\n }\n });\n return self;\n }\n\n};","import updateSize from './updateSize.js';\nimport updateSlides from './updateSlides.js';\nimport updateAutoHeight from './updateAutoHeight.js';\nimport updateSlidesOffset from './updateSlidesOffset.js';\nimport updateSlidesProgress from './updateSlidesProgress.js';\nimport updateProgress from './updateProgress.js';\nimport updateSlidesClasses from './updateSlidesClasses.js';\nimport updateActiveIndex from './updateActiveIndex.js';\nimport updateClickedSlide from './updateClickedSlide.js';\nexport default {\n updateSize,\n updateSlides,\n updateAutoHeight,\n updateSlidesOffset,\n updateSlidesProgress,\n updateProgress,\n updateSlidesClasses,\n updateActiveIndex,\n updateClickedSlide\n};","export default function updateSize() {\n const swiper = this;\n let width;\n let height;\n const $el = swiper.$el;\n\n if (typeof swiper.params.width !== 'undefined' && swiper.params.width !== null) {\n width = swiper.params.width;\n } else {\n width = $el[0].clientWidth;\n }\n\n if (typeof swiper.params.height !== 'undefined' && swiper.params.height !== null) {\n height = swiper.params.height;\n } else {\n height = $el[0].clientHeight;\n }\n\n if (width === 0 && swiper.isHorizontal() || height === 0 && swiper.isVertical()) {\n return;\n } // Subtract paddings\n\n\n width = width - parseInt($el.css('padding-left') || 0, 10) - parseInt($el.css('padding-right') || 0, 10);\n height = height - parseInt($el.css('padding-top') || 0, 10) - parseInt($el.css('padding-bottom') || 0, 10);\n if (Number.isNaN(width)) width = 0;\n if (Number.isNaN(height)) height = 0;\n Object.assign(swiper, {\n width,\n height,\n size: swiper.isHorizontal() ? width : height\n });\n}","import { setCSSProperty } from '../../shared/utils.js';\nexport default function updateSlides() {\n const swiper = this;\n\n function getDirectionLabel(property) {\n if (swiper.isHorizontal()) {\n return property;\n } // prettier-ignore\n\n\n return {\n 'width': 'height',\n 'margin-top': 'margin-left',\n 'margin-bottom ': 'margin-right',\n 'margin-left': 'margin-top',\n 'margin-right': 'margin-bottom',\n 'padding-left': 'padding-top',\n 'padding-right': 'padding-bottom',\n 'marginRight': 'marginBottom'\n }[property];\n }\n\n function getDirectionPropertyValue(node, label) {\n return parseFloat(node.getPropertyValue(getDirectionLabel(label)) || 0);\n }\n\n const params = swiper.params;\n const {\n $wrapperEl,\n size: swiperSize,\n rtlTranslate: rtl,\n wrongRTL\n } = swiper;\n const isVirtual = swiper.virtual && params.virtual.enabled;\n const previousSlidesLength = isVirtual ? swiper.virtual.slides.length : swiper.slides.length;\n const slides = $wrapperEl.children(`.${swiper.params.slideClass}`);\n const slidesLength = isVirtual ? swiper.virtual.slides.length : slides.length;\n let snapGrid = [];\n const slidesGrid = [];\n const slidesSizesGrid = [];\n let offsetBefore = params.slidesOffsetBefore;\n\n if (typeof offsetBefore === 'function') {\n offsetBefore = params.slidesOffsetBefore.call(swiper);\n }\n\n let offsetAfter = params.slidesOffsetAfter;\n\n if (typeof offsetAfter === 'function') {\n offsetAfter = params.slidesOffsetAfter.call(swiper);\n }\n\n const previousSnapGridLength = swiper.snapGrid.length;\n const previousSlidesGridLength = swiper.slidesGrid.length;\n let spaceBetween = params.spaceBetween;\n let slidePosition = -offsetBefore;\n let prevSlideSize = 0;\n let index = 0;\n\n if (typeof swiperSize === 'undefined') {\n return;\n }\n\n if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {\n spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiperSize;\n }\n\n swiper.virtualSize = -spaceBetween; // reset margins\n\n if (rtl) slides.css({\n marginLeft: '',\n marginBottom: '',\n marginTop: ''\n });else slides.css({\n marginRight: '',\n marginBottom: '',\n marginTop: ''\n }); // reset cssMode offsets\n\n if (params.centeredSlides && params.cssMode) {\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', '');\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-after', '');\n }\n\n const gridEnabled = params.grid && params.grid.rows > 1 && swiper.grid;\n\n if (gridEnabled) {\n swiper.grid.initSlides(slidesLength);\n } // Calc slides\n\n\n let slideSize;\n const shouldResetSlideSize = params.slidesPerView === 'auto' && params.breakpoints && Object.keys(params.breakpoints).filter(key => {\n return typeof params.breakpoints[key].slidesPerView !== 'undefined';\n }).length > 0;\n\n for (let i = 0; i < slidesLength; i += 1) {\n slideSize = 0;\n const slide = slides.eq(i);\n\n if (gridEnabled) {\n swiper.grid.updateSlide(i, slide, slidesLength, getDirectionLabel);\n }\n\n if (slide.css('display') === 'none') continue; // eslint-disable-line\n\n if (params.slidesPerView === 'auto') {\n if (shouldResetSlideSize) {\n slides[i].style[getDirectionLabel('width')] = ``;\n }\n\n const slideStyles = getComputedStyle(slide[0]);\n const currentTransform = slide[0].style.transform;\n const currentWebKitTransform = slide[0].style.webkitTransform;\n\n if (currentTransform) {\n slide[0].style.transform = 'none';\n }\n\n if (currentWebKitTransform) {\n slide[0].style.webkitTransform = 'none';\n }\n\n if (params.roundLengths) {\n slideSize = swiper.isHorizontal() ? slide.outerWidth(true) : slide.outerHeight(true);\n } else {\n // eslint-disable-next-line\n const width = getDirectionPropertyValue(slideStyles, 'width');\n const paddingLeft = getDirectionPropertyValue(slideStyles, 'padding-left');\n const paddingRight = getDirectionPropertyValue(slideStyles, 'padding-right');\n const marginLeft = getDirectionPropertyValue(slideStyles, 'margin-left');\n const marginRight = getDirectionPropertyValue(slideStyles, 'margin-right');\n const boxSizing = slideStyles.getPropertyValue('box-sizing');\n\n if (boxSizing && boxSizing === 'border-box') {\n slideSize = width + marginLeft + marginRight;\n } else {\n const {\n clientWidth,\n offsetWidth\n } = slide[0];\n slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight + (offsetWidth - clientWidth);\n }\n }\n\n if (currentTransform) {\n slide[0].style.transform = currentTransform;\n }\n\n if (currentWebKitTransform) {\n slide[0].style.webkitTransform = currentWebKitTransform;\n }\n\n if (params.roundLengths) slideSize = Math.floor(slideSize);\n } else {\n slideSize = (swiperSize - (params.slidesPerView - 1) * spaceBetween) / params.slidesPerView;\n if (params.roundLengths) slideSize = Math.floor(slideSize);\n\n if (slides[i]) {\n slides[i].style[getDirectionLabel('width')] = `${slideSize}px`;\n }\n }\n\n if (slides[i]) {\n slides[i].swiperSlideSize = slideSize;\n }\n\n slidesSizesGrid.push(slideSize);\n\n if (params.centeredSlides) {\n slidePosition = slidePosition + slideSize / 2 + prevSlideSize / 2 + spaceBetween;\n if (prevSlideSize === 0 && i !== 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;\n if (i === 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;\n if (Math.abs(slidePosition) < 1 / 1000) slidePosition = 0;\n if (params.roundLengths) slidePosition = Math.floor(slidePosition);\n if (index % params.slidesPerGroup === 0) snapGrid.push(slidePosition);\n slidesGrid.push(slidePosition);\n } else {\n if (params.roundLengths) slidePosition = Math.floor(slidePosition);\n if ((index - Math.min(swiper.params.slidesPerGroupSkip, index)) % swiper.params.slidesPerGroup === 0) snapGrid.push(slidePosition);\n slidesGrid.push(slidePosition);\n slidePosition = slidePosition + slideSize + spaceBetween;\n }\n\n swiper.virtualSize += slideSize + spaceBetween;\n prevSlideSize = slideSize;\n index += 1;\n }\n\n swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter;\n\n if (rtl && wrongRTL && (params.effect === 'slide' || params.effect === 'coverflow')) {\n $wrapperEl.css({\n width: `${swiper.virtualSize + params.spaceBetween}px`\n });\n }\n\n if (params.setWrapperSize) {\n $wrapperEl.css({\n [getDirectionLabel('width')]: `${swiper.virtualSize + params.spaceBetween}px`\n });\n }\n\n if (gridEnabled) {\n swiper.grid.updateWrapperSize(slideSize, snapGrid, getDirectionLabel);\n } // Remove last grid elements depending on width\n\n\n if (!params.centeredSlides) {\n const newSlidesGrid = [];\n\n for (let i = 0; i < snapGrid.length; i += 1) {\n let slidesGridItem = snapGrid[i];\n if (params.roundLengths) slidesGridItem = Math.floor(slidesGridItem);\n\n if (snapGrid[i] <= swiper.virtualSize - swiperSize) {\n newSlidesGrid.push(slidesGridItem);\n }\n }\n\n snapGrid = newSlidesGrid;\n\n if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) {\n snapGrid.push(swiper.virtualSize - swiperSize);\n }\n }\n\n if (snapGrid.length === 0) snapGrid = [0];\n\n if (params.spaceBetween !== 0) {\n const key = swiper.isHorizontal() && rtl ? 'marginLeft' : getDirectionLabel('marginRight');\n slides.filter((_, slideIndex) => {\n if (!params.cssMode) return true;\n\n if (slideIndex === slides.length - 1) {\n return false;\n }\n\n return true;\n }).css({\n [key]: `${spaceBetween}px`\n });\n }\n\n if (params.centeredSlides && params.centeredSlidesBounds) {\n let allSlidesSize = 0;\n slidesSizesGrid.forEach(slideSizeValue => {\n allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n });\n allSlidesSize -= params.spaceBetween;\n const maxSnap = allSlidesSize - swiperSize;\n snapGrid = snapGrid.map(snap => {\n if (snap < 0) return -offsetBefore;\n if (snap > maxSnap) return maxSnap + offsetAfter;\n return snap;\n });\n }\n\n if (params.centerInsufficientSlides) {\n let allSlidesSize = 0;\n slidesSizesGrid.forEach(slideSizeValue => {\n allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);\n });\n allSlidesSize -= params.spaceBetween;\n\n if (allSlidesSize < swiperSize) {\n const allSlidesOffset = (swiperSize - allSlidesSize) / 2;\n snapGrid.forEach((snap, snapIndex) => {\n snapGrid[snapIndex] = snap - allSlidesOffset;\n });\n slidesGrid.forEach((snap, snapIndex) => {\n slidesGrid[snapIndex] = snap + allSlidesOffset;\n });\n }\n }\n\n Object.assign(swiper, {\n slides,\n snapGrid,\n slidesGrid,\n slidesSizesGrid\n });\n\n if (params.centeredSlides && params.cssMode && !params.centeredSlidesBounds) {\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', `${-snapGrid[0]}px`);\n setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-after', `${swiper.size / 2 - slidesSizesGrid[slidesSizesGrid.length - 1] / 2}px`);\n const addToSnapGrid = -swiper.snapGrid[0];\n const addToSlidesGrid = -swiper.slidesGrid[0];\n swiper.snapGrid = swiper.snapGrid.map(v => v + addToSnapGrid);\n swiper.slidesGrid = swiper.slidesGrid.map(v => v + addToSlidesGrid);\n }\n\n if (slidesLength !== previousSlidesLength) {\n swiper.emit('slidesLengthChange');\n }\n\n if (snapGrid.length !== previousSnapGridLength) {\n if (swiper.params.watchOverflow) swiper.checkOverflow();\n swiper.emit('snapGridLengthChange');\n }\n\n if (slidesGrid.length !== previousSlidesGridLength) {\n swiper.emit('slidesGridLengthChange');\n }\n\n if (params.watchSlidesProgress) {\n swiper.updateSlidesOffset();\n }\n\n if (!isVirtual && !params.cssMode && (params.effect === 'slide' || params.effect === 'fade')) {\n const backFaceHiddenClass = `${params.containerModifierClass}backface-hidden`;\n const hasClassBackfaceClassAdded = swiper.$el.hasClass(backFaceHiddenClass);\n\n if (slidesLength <= params.maxBackfaceHiddenSlides) {\n if (!hasClassBackfaceClassAdded) swiper.$el.addClass(backFaceHiddenClass);\n } else if (hasClassBackfaceClassAdded) {\n swiper.$el.removeClass(backFaceHiddenClass);\n }\n }\n}","import $ from '../../shared/dom.js';\nexport default function updateAutoHeight(speed) {\n const swiper = this;\n const activeSlides = [];\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n let newHeight = 0;\n let i;\n\n if (typeof speed === 'number') {\n swiper.setTransition(speed);\n } else if (speed === true) {\n swiper.setTransition(swiper.params.speed);\n }\n\n const getSlideByIndex = index => {\n if (isVirtual) {\n return swiper.slides.filter(el => parseInt(el.getAttribute('data-swiper-slide-index'), 10) === index)[0];\n }\n\n return swiper.slides.eq(index)[0];\n }; // Find slides currently in view\n\n\n if (swiper.params.slidesPerView !== 'auto' && swiper.params.slidesPerView > 1) {\n if (swiper.params.centeredSlides) {\n (swiper.visibleSlides || $([])).each(slide => {\n activeSlides.push(slide);\n });\n } else {\n for (i = 0; i < Math.ceil(swiper.params.slidesPerView); i += 1) {\n const index = swiper.activeIndex + i;\n if (index > swiper.slides.length && !isVirtual) break;\n activeSlides.push(getSlideByIndex(index));\n }\n }\n } else {\n activeSlides.push(getSlideByIndex(swiper.activeIndex));\n } // Find new height from highest slide in view\n\n\n for (i = 0; i < activeSlides.length; i += 1) {\n if (typeof activeSlides[i] !== 'undefined') {\n const height = activeSlides[i].offsetHeight;\n newHeight = height > newHeight ? height : newHeight;\n }\n } // Update Height\n\n\n if (newHeight || newHeight === 0) swiper.$wrapperEl.css('height', `${newHeight}px`);\n}","export default function updateSlidesOffset() {\n const swiper = this;\n const slides = swiper.slides;\n\n for (let i = 0; i < slides.length; i += 1) {\n slides[i].swiperSlideOffset = swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop;\n }\n}","import $ from '../../shared/dom.js';\nexport default function updateSlidesProgress(translate = this && this.translate || 0) {\n const swiper = this;\n const params = swiper.params;\n const {\n slides,\n rtlTranslate: rtl,\n snapGrid\n } = swiper;\n if (slides.length === 0) return;\n if (typeof slides[0].swiperSlideOffset === 'undefined') swiper.updateSlidesOffset();\n let offsetCenter = -translate;\n if (rtl) offsetCenter = translate; // Visible Slides\n\n slides.removeClass(params.slideVisibleClass);\n swiper.visibleSlidesIndexes = [];\n swiper.visibleSlides = [];\n\n for (let i = 0; i < slides.length; i += 1) {\n const slide = slides[i];\n let slideOffset = slide.swiperSlideOffset;\n\n if (params.cssMode && params.centeredSlides) {\n slideOffset -= slides[0].swiperSlideOffset;\n }\n\n const slideProgress = (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);\n const originalSlideProgress = (offsetCenter - snapGrid[0] + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);\n const slideBefore = -(offsetCenter - slideOffset);\n const slideAfter = slideBefore + swiper.slidesSizesGrid[i];\n const isVisible = slideBefore >= 0 && slideBefore < swiper.size - 1 || slideAfter > 1 && slideAfter <= swiper.size || slideBefore <= 0 && slideAfter >= swiper.size;\n\n if (isVisible) {\n swiper.visibleSlides.push(slide);\n swiper.visibleSlidesIndexes.push(i);\n slides.eq(i).addClass(params.slideVisibleClass);\n }\n\n slide.progress = rtl ? -slideProgress : slideProgress;\n slide.originalProgress = rtl ? -originalSlideProgress : originalSlideProgress;\n }\n\n swiper.visibleSlides = $(swiper.visibleSlides);\n}","export default function updateProgress(translate) {\n const swiper = this;\n\n if (typeof translate === 'undefined') {\n const multiplier = swiper.rtlTranslate ? -1 : 1; // eslint-disable-next-line\n\n translate = swiper && swiper.translate && swiper.translate * multiplier || 0;\n }\n\n const params = swiper.params;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n let {\n progress,\n isBeginning,\n isEnd\n } = swiper;\n const wasBeginning = isBeginning;\n const wasEnd = isEnd;\n\n if (translatesDiff === 0) {\n progress = 0;\n isBeginning = true;\n isEnd = true;\n } else {\n progress = (translate - swiper.minTranslate()) / translatesDiff;\n isBeginning = progress <= 0;\n isEnd = progress >= 1;\n }\n\n Object.assign(swiper, {\n progress,\n isBeginning,\n isEnd\n });\n if (params.watchSlidesProgress || params.centeredSlides && params.autoHeight) swiper.updateSlidesProgress(translate);\n\n if (isBeginning && !wasBeginning) {\n swiper.emit('reachBeginning toEdge');\n }\n\n if (isEnd && !wasEnd) {\n swiper.emit('reachEnd toEdge');\n }\n\n if (wasBeginning && !isBeginning || wasEnd && !isEnd) {\n swiper.emit('fromEdge');\n }\n\n swiper.emit('progress', progress);\n}","export default function updateSlidesClasses() {\n const swiper = this;\n const {\n slides,\n params,\n $wrapperEl,\n activeIndex,\n realIndex\n } = swiper;\n const isVirtual = swiper.virtual && params.virtual.enabled;\n slides.removeClass(`${params.slideActiveClass} ${params.slideNextClass} ${params.slidePrevClass} ${params.slideDuplicateActiveClass} ${params.slideDuplicateNextClass} ${params.slideDuplicatePrevClass}`);\n let activeSlide;\n\n if (isVirtual) {\n activeSlide = swiper.$wrapperEl.find(`.${params.slideClass}[data-swiper-slide-index=\"${activeIndex}\"]`);\n } else {\n activeSlide = slides.eq(activeIndex);\n } // Active classes\n\n\n activeSlide.addClass(params.slideActiveClass);\n\n if (params.loop) {\n // Duplicate to all looped slides\n if (activeSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${realIndex}\"]`).addClass(params.slideDuplicateActiveClass);\n } else {\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${realIndex}\"]`).addClass(params.slideDuplicateActiveClass);\n }\n } // Next Slide\n\n\n let nextSlide = activeSlide.nextAll(`.${params.slideClass}`).eq(0).addClass(params.slideNextClass);\n\n if (params.loop && nextSlide.length === 0) {\n nextSlide = slides.eq(0);\n nextSlide.addClass(params.slideNextClass);\n } // Prev Slide\n\n\n let prevSlide = activeSlide.prevAll(`.${params.slideClass}`).eq(0).addClass(params.slidePrevClass);\n\n if (params.loop && prevSlide.length === 0) {\n prevSlide = slides.eq(-1);\n prevSlide.addClass(params.slidePrevClass);\n }\n\n if (params.loop) {\n // Duplicate to all looped slides\n if (nextSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${nextSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicateNextClass);\n } else {\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${nextSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicateNextClass);\n }\n\n if (prevSlide.hasClass(params.slideDuplicateClass)) {\n $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index=\"${prevSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicatePrevClass);\n } else {\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index=\"${prevSlide.attr('data-swiper-slide-index')}\"]`).addClass(params.slideDuplicatePrevClass);\n }\n }\n\n swiper.emitSlidesClasses();\n}","export default function updateActiveIndex(newActiveIndex) {\n const swiper = this;\n const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n const {\n slidesGrid,\n snapGrid,\n params,\n activeIndex: previousIndex,\n realIndex: previousRealIndex,\n snapIndex: previousSnapIndex\n } = swiper;\n let activeIndex = newActiveIndex;\n let snapIndex;\n\n if (typeof activeIndex === 'undefined') {\n for (let i = 0; i < slidesGrid.length; i += 1) {\n if (typeof slidesGrid[i + 1] !== 'undefined') {\n if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1] - (slidesGrid[i + 1] - slidesGrid[i]) / 2) {\n activeIndex = i;\n } else if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1]) {\n activeIndex = i + 1;\n }\n } else if (translate >= slidesGrid[i]) {\n activeIndex = i;\n }\n } // Normalize slideIndex\n\n\n if (params.normalizeSlideIndex) {\n if (activeIndex < 0 || typeof activeIndex === 'undefined') activeIndex = 0;\n }\n }\n\n if (snapGrid.indexOf(translate) >= 0) {\n snapIndex = snapGrid.indexOf(translate);\n } else {\n const skip = Math.min(params.slidesPerGroupSkip, activeIndex);\n snapIndex = skip + Math.floor((activeIndex - skip) / params.slidesPerGroup);\n }\n\n if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;\n\n if (activeIndex === previousIndex) {\n if (snapIndex !== previousSnapIndex) {\n swiper.snapIndex = snapIndex;\n swiper.emit('snapIndexChange');\n }\n\n return;\n } // Get real index\n\n\n const realIndex = parseInt(swiper.slides.eq(activeIndex).attr('data-swiper-slide-index') || activeIndex, 10);\n Object.assign(swiper, {\n snapIndex,\n realIndex,\n previousIndex,\n activeIndex\n });\n swiper.emit('activeIndexChange');\n swiper.emit('snapIndexChange');\n\n if (previousRealIndex !== realIndex) {\n swiper.emit('realIndexChange');\n }\n\n if (swiper.initialized || swiper.params.runCallbacksOnInit) {\n swiper.emit('slideChange');\n }\n}","import $ from '../../shared/dom.js';\nexport default function updateClickedSlide(e) {\n const swiper = this;\n const params = swiper.params;\n const slide = $(e).closest(`.${params.slideClass}`)[0];\n let slideFound = false;\n let slideIndex;\n\n if (slide) {\n for (let i = 0; i < swiper.slides.length; i += 1) {\n if (swiper.slides[i] === slide) {\n slideFound = true;\n slideIndex = i;\n break;\n }\n }\n }\n\n if (slide && slideFound) {\n swiper.clickedSlide = slide;\n\n if (swiper.virtual && swiper.params.virtual.enabled) {\n swiper.clickedIndex = parseInt($(slide).attr('data-swiper-slide-index'), 10);\n } else {\n swiper.clickedIndex = slideIndex;\n }\n } else {\n swiper.clickedSlide = undefined;\n swiper.clickedIndex = undefined;\n return;\n }\n\n if (params.slideToClickedSlide && swiper.clickedIndex !== undefined && swiper.clickedIndex !== swiper.activeIndex) {\n swiper.slideToClickedSlide();\n }\n}","import getTranslate from './getTranslate.js';\nimport setTranslate from './setTranslate.js';\nimport minTranslate from './minTranslate.js';\nimport maxTranslate from './maxTranslate.js';\nimport translateTo from './translateTo.js';\nexport default {\n getTranslate,\n setTranslate,\n minTranslate,\n maxTranslate,\n translateTo\n};","import { getTranslate } from '../../shared/utils.js';\nexport default function getSwiperTranslate(axis = this.isHorizontal() ? 'x' : 'y') {\n const swiper = this;\n const {\n params,\n rtlTranslate: rtl,\n translate,\n $wrapperEl\n } = swiper;\n\n if (params.virtualTranslate) {\n return rtl ? -translate : translate;\n }\n\n if (params.cssMode) {\n return translate;\n }\n\n let currentTranslate = getTranslate($wrapperEl[0], axis);\n if (rtl) currentTranslate = -currentTranslate;\n return currentTranslate || 0;\n}","export default function setTranslate(translate, byController) {\n const swiper = this;\n const {\n rtlTranslate: rtl,\n params,\n $wrapperEl,\n wrapperEl,\n progress\n } = swiper;\n let x = 0;\n let y = 0;\n const z = 0;\n\n if (swiper.isHorizontal()) {\n x = rtl ? -translate : translate;\n } else {\n y = translate;\n }\n\n if (params.roundLengths) {\n x = Math.floor(x);\n y = Math.floor(y);\n }\n\n if (params.cssMode) {\n wrapperEl[swiper.isHorizontal() ? 'scrollLeft' : 'scrollTop'] = swiper.isHorizontal() ? -x : -y;\n } else if (!params.virtualTranslate) {\n $wrapperEl.transform(`translate3d(${x}px, ${y}px, ${z}px)`);\n }\n\n swiper.previousTranslate = swiper.translate;\n swiper.translate = swiper.isHorizontal() ? x : y; // Check if we need to update progress\n\n let newProgress;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n\n if (translatesDiff === 0) {\n newProgress = 0;\n } else {\n newProgress = (translate - swiper.minTranslate()) / translatesDiff;\n }\n\n if (newProgress !== progress) {\n swiper.updateProgress(translate);\n }\n\n swiper.emit('setTranslate', swiper.translate, byController);\n}","export default function minTranslate() {\n return -this.snapGrid[0];\n}","export default function maxTranslate() {\n return -this.snapGrid[this.snapGrid.length - 1];\n}","import { animateCSSModeScroll } from '../../shared/utils.js';\nexport default function translateTo(translate = 0, speed = this.params.speed, runCallbacks = true, translateBounds = true, internal) {\n const swiper = this;\n const {\n params,\n wrapperEl\n } = swiper;\n\n if (swiper.animating && params.preventInteractionOnTransition) {\n return false;\n }\n\n const minTranslate = swiper.minTranslate();\n const maxTranslate = swiper.maxTranslate();\n let newTranslate;\n if (translateBounds && translate > minTranslate) newTranslate = minTranslate;else if (translateBounds && translate < maxTranslate) newTranslate = maxTranslate;else newTranslate = translate; // Update progress\n\n swiper.updateProgress(newTranslate);\n\n if (params.cssMode) {\n const isH = swiper.isHorizontal();\n\n if (speed === 0) {\n wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = -newTranslate;\n } else {\n if (!swiper.support.smoothScroll) {\n animateCSSModeScroll({\n swiper,\n targetPosition: -newTranslate,\n side: isH ? 'left' : 'top'\n });\n return true;\n }\n\n wrapperEl.scrollTo({\n [isH ? 'left' : 'top']: -newTranslate,\n behavior: 'smooth'\n });\n }\n\n return true;\n }\n\n if (speed === 0) {\n swiper.setTransition(0);\n swiper.setTranslate(newTranslate);\n\n if (runCallbacks) {\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.emit('transitionEnd');\n }\n } else {\n swiper.setTransition(speed);\n swiper.setTranslate(newTranslate);\n\n if (runCallbacks) {\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.emit('transitionStart');\n }\n\n if (!swiper.animating) {\n swiper.animating = true;\n\n if (!swiper.onTranslateToWrapperTransitionEnd) {\n swiper.onTranslateToWrapperTransitionEnd = function transitionEnd(e) {\n if (!swiper || swiper.destroyed) return;\n if (e.target !== this) return;\n swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onTranslateToWrapperTransitionEnd);\n swiper.onTranslateToWrapperTransitionEnd = null;\n delete swiper.onTranslateToWrapperTransitionEnd;\n\n if (runCallbacks) {\n swiper.emit('transitionEnd');\n }\n };\n }\n\n swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\n swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onTranslateToWrapperTransitionEnd);\n }\n }\n\n return true;\n}","export default function transitionEmit({\n swiper,\n runCallbacks,\n direction,\n step\n}) {\n const {\n activeIndex,\n previousIndex\n } = swiper;\n let dir = direction;\n\n if (!dir) {\n if (activeIndex > previousIndex) dir = 'next';else if (activeIndex < previousIndex) dir = 'prev';else dir = 'reset';\n }\n\n swiper.emit(`transition${step}`);\n\n if (runCallbacks && activeIndex !== previousIndex) {\n if (dir === 'reset') {\n swiper.emit(`slideResetTransition${step}`);\n return;\n }\n\n swiper.emit(`slideChangeTransition${step}`);\n\n if (dir === 'next') {\n swiper.emit(`slideNextTransition${step}`);\n } else {\n swiper.emit(`slidePrevTransition${step}`);\n }\n }\n}","import setTransition from './setTransition.js';\nimport transitionStart from './transitionStart.js';\nimport transitionEnd from './transitionEnd.js';\nexport default {\n setTransition,\n transitionStart,\n transitionEnd\n};","export default function setTransition(duration, byController) {\n const swiper = this;\n\n if (!swiper.params.cssMode) {\n swiper.$wrapperEl.transition(duration);\n }\n\n swiper.emit('setTransition', duration, byController);\n}","import transitionEmit from './transitionEmit.js';\nexport default function transitionStart(runCallbacks = true, direction) {\n const swiper = this;\n const {\n params\n } = swiper;\n if (params.cssMode) return;\n\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n\n transitionEmit({\n swiper,\n runCallbacks,\n direction,\n step: 'Start'\n });\n}","import transitionEmit from './transitionEmit.js';\nexport default function transitionEnd(runCallbacks = true, direction) {\n const swiper = this;\n const {\n params\n } = swiper;\n swiper.animating = false;\n if (params.cssMode) return;\n swiper.setTransition(0);\n transitionEmit({\n swiper,\n runCallbacks,\n direction,\n step: 'End'\n });\n}","import slideTo from './slideTo.js';\nimport slideToLoop from './slideToLoop.js';\nimport slideNext from './slideNext.js';\nimport slidePrev from './slidePrev.js';\nimport slideReset from './slideReset.js';\nimport slideToClosest from './slideToClosest.js';\nimport slideToClickedSlide from './slideToClickedSlide.js';\nexport default {\n slideTo,\n slideToLoop,\n slideNext,\n slidePrev,\n slideReset,\n slideToClosest,\n slideToClickedSlide\n};","import { animateCSSModeScroll } from '../../shared/utils.js';\nexport default function slideTo(index = 0, speed = this.params.speed, runCallbacks = true, internal, initial) {\n if (typeof index !== 'number' && typeof index !== 'string') {\n throw new Error(`The 'index' argument cannot have type other than 'number' or 'string'. [${typeof index}] given.`);\n }\n\n if (typeof index === 'string') {\n /**\n * The `index` argument converted from `string` to `number`.\n * @type {number}\n */\n const indexAsNumber = parseInt(index, 10);\n /**\n * Determines whether the `index` argument is a valid `number`\n * after being converted from the `string` type.\n * @type {boolean}\n */\n\n const isValidNumber = isFinite(indexAsNumber);\n\n if (!isValidNumber) {\n throw new Error(`The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`);\n } // Knowing that the converted `index` is a valid number,\n // we can update the original argument's value.\n\n\n index = indexAsNumber;\n }\n\n const swiper = this;\n let slideIndex = index;\n if (slideIndex < 0) slideIndex = 0;\n const {\n params,\n snapGrid,\n slidesGrid,\n previousIndex,\n activeIndex,\n rtlTranslate: rtl,\n wrapperEl,\n enabled\n } = swiper;\n\n if (swiper.animating && params.preventInteractionOnTransition || !enabled && !internal && !initial) {\n return false;\n }\n\n const skip = Math.min(swiper.params.slidesPerGroupSkip, slideIndex);\n let snapIndex = skip + Math.floor((slideIndex - skip) / swiper.params.slidesPerGroup);\n if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;\n const translate = -snapGrid[snapIndex]; // Normalize slideIndex\n\n if (params.normalizeSlideIndex) {\n for (let i = 0; i < slidesGrid.length; i += 1) {\n const normalizedTranslate = -Math.floor(translate * 100);\n const normalizedGrid = Math.floor(slidesGrid[i] * 100);\n const normalizedGridNext = Math.floor(slidesGrid[i + 1] * 100);\n\n if (typeof slidesGrid[i + 1] !== 'undefined') {\n if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext - (normalizedGridNext - normalizedGrid) / 2) {\n slideIndex = i;\n } else if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext) {\n slideIndex = i + 1;\n }\n } else if (normalizedTranslate >= normalizedGrid) {\n slideIndex = i;\n }\n }\n } // Directions locks\n\n\n if (swiper.initialized && slideIndex !== activeIndex) {\n if (!swiper.allowSlideNext && translate < swiper.translate && translate < swiper.minTranslate()) {\n return false;\n }\n\n if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) {\n if ((activeIndex || 0) !== slideIndex) return false;\n }\n }\n\n if (slideIndex !== (previousIndex || 0) && runCallbacks) {\n swiper.emit('beforeSlideChangeStart');\n } // Update progress\n\n\n swiper.updateProgress(translate);\n let direction;\n if (slideIndex > activeIndex) direction = 'next';else if (slideIndex < activeIndex) direction = 'prev';else direction = 'reset'; // Update Index\n\n if (rtl && -translate === swiper.translate || !rtl && translate === swiper.translate) {\n swiper.updateActiveIndex(slideIndex); // Update Height\n\n if (params.autoHeight) {\n swiper.updateAutoHeight();\n }\n\n swiper.updateSlidesClasses();\n\n if (params.effect !== 'slide') {\n swiper.setTranslate(translate);\n }\n\n if (direction !== 'reset') {\n swiper.transitionStart(runCallbacks, direction);\n swiper.transitionEnd(runCallbacks, direction);\n }\n\n return false;\n }\n\n if (params.cssMode) {\n const isH = swiper.isHorizontal();\n const t = rtl ? translate : -translate;\n\n if (speed === 0) {\n const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n\n if (isVirtual) {\n swiper.wrapperEl.style.scrollSnapType = 'none';\n swiper._immediateVirtual = true;\n }\n\n wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = t;\n\n if (isVirtual) {\n requestAnimationFrame(() => {\n swiper.wrapperEl.style.scrollSnapType = '';\n swiper._swiperImmediateVirtual = false;\n });\n }\n } else {\n if (!swiper.support.smoothScroll) {\n animateCSSModeScroll({\n swiper,\n targetPosition: t,\n side: isH ? 'left' : 'top'\n });\n return true;\n }\n\n wrapperEl.scrollTo({\n [isH ? 'left' : 'top']: t,\n behavior: 'smooth'\n });\n }\n\n return true;\n }\n\n swiper.setTransition(speed);\n swiper.setTranslate(translate);\n swiper.updateActiveIndex(slideIndex);\n swiper.updateSlidesClasses();\n swiper.emit('beforeTransitionStart', speed, internal);\n swiper.transitionStart(runCallbacks, direction);\n\n if (speed === 0) {\n swiper.transitionEnd(runCallbacks, direction);\n } else if (!swiper.animating) {\n swiper.animating = true;\n\n if (!swiper.onSlideToWrapperTransitionEnd) {\n swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) {\n if (!swiper || swiper.destroyed) return;\n if (e.target !== this) return;\n swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n swiper.onSlideToWrapperTransitionEnd = null;\n delete swiper.onSlideToWrapperTransitionEnd;\n swiper.transitionEnd(runCallbacks, direction);\n };\n }\n\n swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);\n }\n\n return true;\n}","export default function slideToLoop(index = 0, speed = this.params.speed, runCallbacks = true, internal) {\n if (typeof index === 'string') {\n /**\n * The `index` argument converted from `string` to `number`.\n * @type {number}\n */\n const indexAsNumber = parseInt(index, 10);\n /**\n * Determines whether the `index` argument is a valid `number`\n * after being converted from the `string` type.\n * @type {boolean}\n */\n\n const isValidNumber = isFinite(indexAsNumber);\n\n if (!isValidNumber) {\n throw new Error(`The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`);\n } // Knowing that the converted `index` is a valid number,\n // we can update the original argument's value.\n\n\n index = indexAsNumber;\n }\n\n const swiper = this;\n let newIndex = index;\n\n if (swiper.params.loop) {\n newIndex += swiper.loopedSlides;\n }\n\n return swiper.slideTo(newIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideNext(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n const {\n animating,\n enabled,\n params\n } = swiper;\n if (!enabled) return swiper;\n let perGroup = params.slidesPerGroup;\n\n if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {\n perGroup = Math.max(swiper.slidesPerViewDynamic('current', true), 1);\n }\n\n const increment = swiper.activeIndex < params.slidesPerGroupSkip ? 1 : perGroup;\n\n if (params.loop) {\n if (animating && params.loopPreventsSlide) return false;\n swiper.loopFix(); // eslint-disable-next-line\n\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n }\n\n if (params.rewind && swiper.isEnd) {\n return swiper.slideTo(0, speed, runCallbacks, internal);\n }\n\n return swiper.slideTo(swiper.activeIndex + increment, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slidePrev(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n const {\n params,\n animating,\n snapGrid,\n slidesGrid,\n rtlTranslate,\n enabled\n } = swiper;\n if (!enabled) return swiper;\n\n if (params.loop) {\n if (animating && params.loopPreventsSlide) return false;\n swiper.loopFix(); // eslint-disable-next-line\n\n swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;\n }\n\n const translate = rtlTranslate ? swiper.translate : -swiper.translate;\n\n function normalize(val) {\n if (val < 0) return -Math.floor(Math.abs(val));\n return Math.floor(val);\n }\n\n const normalizedTranslate = normalize(translate);\n const normalizedSnapGrid = snapGrid.map(val => normalize(val));\n let prevSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1];\n\n if (typeof prevSnap === 'undefined' && params.cssMode) {\n let prevSnapIndex;\n snapGrid.forEach((snap, snapIndex) => {\n if (normalizedTranslate >= snap) {\n // prevSnap = snap;\n prevSnapIndex = snapIndex;\n }\n });\n\n if (typeof prevSnapIndex !== 'undefined') {\n prevSnap = snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1 : prevSnapIndex];\n }\n }\n\n let prevIndex = 0;\n\n if (typeof prevSnap !== 'undefined') {\n prevIndex = slidesGrid.indexOf(prevSnap);\n if (prevIndex < 0) prevIndex = swiper.activeIndex - 1;\n\n if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {\n prevIndex = prevIndex - swiper.slidesPerViewDynamic('previous', true) + 1;\n prevIndex = Math.max(prevIndex, 0);\n }\n }\n\n if (params.rewind && swiper.isBeginning) {\n const lastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;\n return swiper.slideTo(lastIndex, speed, runCallbacks, internal);\n }\n\n return swiper.slideTo(prevIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideReset(speed = this.params.speed, runCallbacks = true, internal) {\n const swiper = this;\n return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);\n}","/* eslint no-unused-vars: \"off\" */\nexport default function slideToClosest(speed = this.params.speed, runCallbacks = true, internal, threshold = 0.5) {\n const swiper = this;\n let index = swiper.activeIndex;\n const skip = Math.min(swiper.params.slidesPerGroupSkip, index);\n const snapIndex = skip + Math.floor((index - skip) / swiper.params.slidesPerGroup);\n const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n\n if (translate >= swiper.snapGrid[snapIndex]) {\n // The current translate is on or after the current snap index, so the choice\n // is between the current index and the one after it.\n const currentSnap = swiper.snapGrid[snapIndex];\n const nextSnap = swiper.snapGrid[snapIndex + 1];\n\n if (translate - currentSnap > (nextSnap - currentSnap) * threshold) {\n index += swiper.params.slidesPerGroup;\n }\n } else {\n // The current translate is before the current snap index, so the choice\n // is between the current index and the one before it.\n const prevSnap = swiper.snapGrid[snapIndex - 1];\n const currentSnap = swiper.snapGrid[snapIndex];\n\n if (translate - prevSnap <= (currentSnap - prevSnap) * threshold) {\n index -= swiper.params.slidesPerGroup;\n }\n }\n\n index = Math.max(index, 0);\n index = Math.min(index, swiper.slidesGrid.length - 1);\n return swiper.slideTo(index, speed, runCallbacks, internal);\n}","import $ from '../../shared/dom.js';\nimport { nextTick } from '../../shared/utils.js';\nexport default function slideToClickedSlide() {\n const swiper = this;\n const {\n params,\n $wrapperEl\n } = swiper;\n const slidesPerView = params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : params.slidesPerView;\n let slideToIndex = swiper.clickedIndex;\n let realIndex;\n\n if (params.loop) {\n if (swiper.animating) return;\n realIndex = parseInt($(swiper.clickedSlide).attr('data-swiper-slide-index'), 10);\n\n if (params.centeredSlides) {\n if (slideToIndex < swiper.loopedSlides - slidesPerView / 2 || slideToIndex > swiper.slides.length - swiper.loopedSlides + slidesPerView / 2) {\n swiper.loopFix();\n slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index=\"${realIndex}\"]:not(.${params.slideDuplicateClass})`).eq(0).index();\n nextTick(() => {\n swiper.slideTo(slideToIndex);\n });\n } else {\n swiper.slideTo(slideToIndex);\n }\n } else if (slideToIndex > swiper.slides.length - slidesPerView) {\n swiper.loopFix();\n slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index=\"${realIndex}\"]:not(.${params.slideDuplicateClass})`).eq(0).index();\n nextTick(() => {\n swiper.slideTo(slideToIndex);\n });\n } else {\n swiper.slideTo(slideToIndex);\n }\n } else {\n swiper.slideTo(slideToIndex);\n }\n}","import loopCreate from './loopCreate.js';\nimport loopFix from './loopFix.js';\nimport loopDestroy from './loopDestroy.js';\nexport default {\n loopCreate,\n loopFix,\n loopDestroy\n};","import { getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function loopCreate() {\n const swiper = this;\n const document = getDocument();\n const {\n params,\n $wrapperEl\n } = swiper; // Remove duplicated slides\n\n const $selector = $wrapperEl.children().length > 0 ? $($wrapperEl.children()[0].parentNode) : $wrapperEl;\n $selector.children(`.${params.slideClass}.${params.slideDuplicateClass}`).remove();\n let slides = $selector.children(`.${params.slideClass}`);\n\n if (params.loopFillGroupWithBlank) {\n const blankSlidesNum = params.slidesPerGroup - slides.length % params.slidesPerGroup;\n\n if (blankSlidesNum !== params.slidesPerGroup) {\n for (let i = 0; i < blankSlidesNum; i += 1) {\n const blankNode = $(document.createElement('div')).addClass(`${params.slideClass} ${params.slideBlankClass}`);\n $selector.append(blankNode);\n }\n\n slides = $selector.children(`.${params.slideClass}`);\n }\n }\n\n if (params.slidesPerView === 'auto' && !params.loopedSlides) params.loopedSlides = slides.length;\n swiper.loopedSlides = Math.ceil(parseFloat(params.loopedSlides || params.slidesPerView, 10));\n swiper.loopedSlides += params.loopAdditionalSlides;\n\n if (swiper.loopedSlides > slides.length && swiper.params.loopedSlidesLimit) {\n swiper.loopedSlides = slides.length;\n }\n\n const prependSlides = [];\n const appendSlides = [];\n slides.each((el, index) => {\n const slide = $(el);\n slide.attr('data-swiper-slide-index', index);\n });\n\n for (let i = 0; i < swiper.loopedSlides; i += 1) {\n const index = i - Math.floor(i / slides.length) * slides.length;\n appendSlides.push(slides.eq(index)[0]);\n prependSlides.unshift(slides.eq(slides.length - index - 1)[0]);\n }\n\n for (let i = 0; i < appendSlides.length; i += 1) {\n $selector.append($(appendSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n\n for (let i = prependSlides.length - 1; i >= 0; i -= 1) {\n $selector.prepend($(prependSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));\n }\n}","export default function loopFix() {\n const swiper = this;\n swiper.emit('beforeLoopFix');\n const {\n activeIndex,\n slides,\n loopedSlides,\n allowSlidePrev,\n allowSlideNext,\n snapGrid,\n rtlTranslate: rtl\n } = swiper;\n let newIndex;\n swiper.allowSlidePrev = true;\n swiper.allowSlideNext = true;\n const snapTranslate = -snapGrid[activeIndex];\n const diff = snapTranslate - swiper.getTranslate(); // Fix For Negative Oversliding\n\n if (activeIndex < loopedSlides) {\n newIndex = slides.length - loopedSlides * 3 + activeIndex;\n newIndex += loopedSlides;\n const slideChanged = swiper.slideTo(newIndex, 0, false, true);\n\n if (slideChanged && diff !== 0) {\n swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n }\n } else if (activeIndex >= slides.length - loopedSlides) {\n // Fix For Positive Oversliding\n newIndex = -slides.length + activeIndex + loopedSlides;\n newIndex += loopedSlides;\n const slideChanged = swiper.slideTo(newIndex, 0, false, true);\n\n if (slideChanged && diff !== 0) {\n swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);\n }\n }\n\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n swiper.emit('loopFix');\n}","export default function loopDestroy() {\n const swiper = this;\n const {\n $wrapperEl,\n params,\n slides\n } = swiper;\n $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass},.${params.slideClass}.${params.slideBlankClass}`).remove();\n slides.removeAttr('data-swiper-slide-index');\n}","import { getWindow, getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { now } from '../../shared/utils.js'; // Modified from https://stackoverflow.com/questions/54520554/custom-element-getrootnode-closest-function-crossing-multiple-parent-shadowd\n\nfunction closestElement(selector, base = this) {\n function __closestFrom(el) {\n if (!el || el === getDocument() || el === getWindow()) return null;\n if (el.assignedSlot) el = el.assignedSlot;\n const found = el.closest(selector);\n\n if (!found && !el.getRootNode) {\n return null;\n }\n\n return found || __closestFrom(el.getRootNode().host);\n }\n\n return __closestFrom(base);\n}\n\nexport default function onTouchStart(event) {\n const swiper = this;\n const document = getDocument();\n const window = getWindow();\n const data = swiper.touchEventsData;\n const {\n params,\n touches,\n enabled\n } = swiper;\n if (!enabled) return;\n\n if (swiper.animating && params.preventInteractionOnTransition) {\n return;\n }\n\n if (!swiper.animating && params.cssMode && params.loop) {\n swiper.loopFix();\n }\n\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n let $targetEl = $(e.target);\n\n if (params.touchEventsTarget === 'wrapper') {\n if (!$targetEl.closest(swiper.wrapperEl).length) return;\n }\n\n data.isTouchEvent = e.type === 'touchstart';\n if (!data.isTouchEvent && 'which' in e && e.which === 3) return;\n if (!data.isTouchEvent && 'button' in e && e.button > 0) return;\n if (data.isTouched && data.isMoved) return; // change target el for shadow root component\n\n const swipingClassHasValue = !!params.noSwipingClass && params.noSwipingClass !== ''; // eslint-disable-next-line\n\n const eventPath = event.composedPath ? event.composedPath() : event.path;\n\n if (swipingClassHasValue && e.target && e.target.shadowRoot && eventPath) {\n $targetEl = $(eventPath[0]);\n }\n\n const noSwipingSelector = params.noSwipingSelector ? params.noSwipingSelector : `.${params.noSwipingClass}`;\n const isTargetShadow = !!(e.target && e.target.shadowRoot); // use closestElement for shadow root element to get the actual closest for nested shadow root element\n\n if (params.noSwiping && (isTargetShadow ? closestElement(noSwipingSelector, $targetEl[0]) : $targetEl.closest(noSwipingSelector)[0])) {\n swiper.allowClick = true;\n return;\n }\n\n if (params.swipeHandler) {\n if (!$targetEl.closest(params.swipeHandler)[0]) return;\n }\n\n touches.currentX = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;\n touches.currentY = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;\n const startX = touches.currentX;\n const startY = touches.currentY; // Do NOT start if iOS edge swipe is detected. Otherwise iOS app cannot swipe-to-go-back anymore\n\n const edgeSwipeDetection = params.edgeSwipeDetection || params.iOSEdgeSwipeDetection;\n const edgeSwipeThreshold = params.edgeSwipeThreshold || params.iOSEdgeSwipeThreshold;\n\n if (edgeSwipeDetection && (startX <= edgeSwipeThreshold || startX >= window.innerWidth - edgeSwipeThreshold)) {\n if (edgeSwipeDetection === 'prevent') {\n event.preventDefault();\n } else {\n return;\n }\n }\n\n Object.assign(data, {\n isTouched: true,\n isMoved: false,\n allowTouchCallbacks: true,\n isScrolling: undefined,\n startMoving: undefined\n });\n touches.startX = startX;\n touches.startY = startY;\n data.touchStartTime = now();\n swiper.allowClick = true;\n swiper.updateSize();\n swiper.swipeDirection = undefined;\n if (params.threshold > 0) data.allowThresholdMove = false;\n\n if (e.type !== 'touchstart') {\n let preventDefault = true;\n\n if ($targetEl.is(data.focusableElements)) {\n preventDefault = false;\n\n if ($targetEl[0].nodeName === 'SELECT') {\n data.isTouched = false;\n }\n }\n\n if (document.activeElement && $(document.activeElement).is(data.focusableElements) && document.activeElement !== $targetEl[0]) {\n document.activeElement.blur();\n }\n\n const shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault;\n\n if ((params.touchStartForcePreventDefault || shouldPreventDefault) && !$targetEl[0].isContentEditable) {\n e.preventDefault();\n }\n }\n\n if (swiper.params.freeMode && swiper.params.freeMode.enabled && swiper.freeMode && swiper.animating && !params.cssMode) {\n swiper.freeMode.onTouchStart();\n }\n\n swiper.emit('touchStart', e);\n}","import { getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nimport { now } from '../../shared/utils.js';\nexport default function onTouchMove(event) {\n const document = getDocument();\n const swiper = this;\n const data = swiper.touchEventsData;\n const {\n params,\n touches,\n rtlTranslate: rtl,\n enabled\n } = swiper;\n if (!enabled) return;\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n\n if (!data.isTouched) {\n if (data.startMoving && data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n\n return;\n }\n\n if (data.isTouchEvent && e.type !== 'touchmove') return;\n const targetTouch = e.type === 'touchmove' && e.targetTouches && (e.targetTouches[0] || e.changedTouches[0]);\n const pageX = e.type === 'touchmove' ? targetTouch.pageX : e.pageX;\n const pageY = e.type === 'touchmove' ? targetTouch.pageY : e.pageY;\n\n if (e.preventedByNestedSwiper) {\n touches.startX = pageX;\n touches.startY = pageY;\n return;\n }\n\n if (!swiper.allowTouchMove) {\n if (!$(e.target).is(data.focusableElements)) {\n swiper.allowClick = false;\n }\n\n if (data.isTouched) {\n Object.assign(touches, {\n startX: pageX,\n startY: pageY,\n currentX: pageX,\n currentY: pageY\n });\n data.touchStartTime = now();\n }\n\n return;\n }\n\n if (data.isTouchEvent && params.touchReleaseOnEdges && !params.loop) {\n if (swiper.isVertical()) {\n // Vertical\n if (pageY < touches.startY && swiper.translate <= swiper.maxTranslate() || pageY > touches.startY && swiper.translate >= swiper.minTranslate()) {\n data.isTouched = false;\n data.isMoved = false;\n return;\n }\n } else if (pageX < touches.startX && swiper.translate <= swiper.maxTranslate() || pageX > touches.startX && swiper.translate >= swiper.minTranslate()) {\n return;\n }\n }\n\n if (data.isTouchEvent && document.activeElement) {\n if (e.target === document.activeElement && $(e.target).is(data.focusableElements)) {\n data.isMoved = true;\n swiper.allowClick = false;\n return;\n }\n }\n\n if (data.allowTouchCallbacks) {\n swiper.emit('touchMove', e);\n }\n\n if (e.targetTouches && e.targetTouches.length > 1) return;\n touches.currentX = pageX;\n touches.currentY = pageY;\n const diffX = touches.currentX - touches.startX;\n const diffY = touches.currentY - touches.startY;\n if (swiper.params.threshold && Math.sqrt(diffX ** 2 + diffY ** 2) < swiper.params.threshold) return;\n\n if (typeof data.isScrolling === 'undefined') {\n let touchAngle;\n\n if (swiper.isHorizontal() && touches.currentY === touches.startY || swiper.isVertical() && touches.currentX === touches.startX) {\n data.isScrolling = false;\n } else {\n // eslint-disable-next-line\n if (diffX * diffX + diffY * diffY >= 25) {\n touchAngle = Math.atan2(Math.abs(diffY), Math.abs(diffX)) * 180 / Math.PI;\n data.isScrolling = swiper.isHorizontal() ? touchAngle > params.touchAngle : 90 - touchAngle > params.touchAngle;\n }\n }\n }\n\n if (data.isScrolling) {\n swiper.emit('touchMoveOpposite', e);\n }\n\n if (typeof data.startMoving === 'undefined') {\n if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) {\n data.startMoving = true;\n }\n }\n\n if (data.isScrolling) {\n data.isTouched = false;\n return;\n }\n\n if (!data.startMoving) {\n return;\n }\n\n swiper.allowClick = false;\n\n if (!params.cssMode && e.cancelable) {\n e.preventDefault();\n }\n\n if (params.touchMoveStopPropagation && !params.nested) {\n e.stopPropagation();\n }\n\n if (!data.isMoved) {\n if (params.loop && !params.cssMode) {\n swiper.loopFix();\n }\n\n data.startTranslate = swiper.getTranslate();\n swiper.setTransition(0);\n\n if (swiper.animating) {\n swiper.$wrapperEl.trigger('webkitTransitionEnd transitionend');\n }\n\n data.allowMomentumBounce = false; // Grab Cursor\n\n if (params.grabCursor && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(true);\n }\n\n swiper.emit('sliderFirstMove', e);\n }\n\n swiper.emit('sliderMove', e);\n data.isMoved = true;\n let diff = swiper.isHorizontal() ? diffX : diffY;\n touches.diff = diff;\n diff *= params.touchRatio;\n if (rtl) diff = -diff;\n swiper.swipeDirection = diff > 0 ? 'prev' : 'next';\n data.currentTranslate = diff + data.startTranslate;\n let disableParentSwiper = true;\n let resistanceRatio = params.resistanceRatio;\n\n if (params.touchReleaseOnEdges) {\n resistanceRatio = 0;\n }\n\n if (diff > 0 && data.currentTranslate > swiper.minTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) data.currentTranslate = swiper.minTranslate() - 1 + (-swiper.minTranslate() + data.startTranslate + diff) ** resistanceRatio;\n } else if (diff < 0 && data.currentTranslate < swiper.maxTranslate()) {\n disableParentSwiper = false;\n if (params.resistance) data.currentTranslate = swiper.maxTranslate() + 1 - (swiper.maxTranslate() - data.startTranslate - diff) ** resistanceRatio;\n }\n\n if (disableParentSwiper) {\n e.preventedByNestedSwiper = true;\n } // Directions locks\n\n\n if (!swiper.allowSlideNext && swiper.swipeDirection === 'next' && data.currentTranslate < data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n\n if (!swiper.allowSlidePrev && swiper.swipeDirection === 'prev' && data.currentTranslate > data.startTranslate) {\n data.currentTranslate = data.startTranslate;\n }\n\n if (!swiper.allowSlidePrev && !swiper.allowSlideNext) {\n data.currentTranslate = data.startTranslate;\n } // Threshold\n\n\n if (params.threshold > 0) {\n if (Math.abs(diff) > params.threshold || data.allowThresholdMove) {\n if (!data.allowThresholdMove) {\n data.allowThresholdMove = true;\n touches.startX = touches.currentX;\n touches.startY = touches.currentY;\n data.currentTranslate = data.startTranslate;\n touches.diff = swiper.isHorizontal() ? touches.currentX - touches.startX : touches.currentY - touches.startY;\n return;\n }\n } else {\n data.currentTranslate = data.startTranslate;\n return;\n }\n }\n\n if (!params.followFinger || params.cssMode) return; // Update active index in free mode\n\n if (params.freeMode && params.freeMode.enabled && swiper.freeMode || params.watchSlidesProgress) {\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n if (swiper.params.freeMode && params.freeMode.enabled && swiper.freeMode) {\n swiper.freeMode.onTouchMove();\n } // Update progress\n\n\n swiper.updateProgress(data.currentTranslate); // Update translate\n\n swiper.setTranslate(data.currentTranslate);\n}","import { now, nextTick } from '../../shared/utils.js';\nexport default function onTouchEnd(event) {\n const swiper = this;\n const data = swiper.touchEventsData;\n const {\n params,\n touches,\n rtlTranslate: rtl,\n slidesGrid,\n enabled\n } = swiper;\n if (!enabled) return;\n let e = event;\n if (e.originalEvent) e = e.originalEvent;\n\n if (data.allowTouchCallbacks) {\n swiper.emit('touchEnd', e);\n }\n\n data.allowTouchCallbacks = false;\n\n if (!data.isTouched) {\n if (data.isMoved && params.grabCursor) {\n swiper.setGrabCursor(false);\n }\n\n data.isMoved = false;\n data.startMoving = false;\n return;\n } // Return Grab Cursor\n\n\n if (params.grabCursor && data.isMoved && data.isTouched && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n swiper.setGrabCursor(false);\n } // Time diff\n\n\n const touchEndTime = now();\n const timeDiff = touchEndTime - data.touchStartTime; // Tap, doubleTap, Click\n\n if (swiper.allowClick) {\n const pathTree = e.path || e.composedPath && e.composedPath();\n swiper.updateClickedSlide(pathTree && pathTree[0] || e.target);\n swiper.emit('tap click', e);\n\n if (timeDiff < 300 && touchEndTime - data.lastClickTime < 300) {\n swiper.emit('doubleTap doubleClick', e);\n }\n }\n\n data.lastClickTime = now();\n nextTick(() => {\n if (!swiper.destroyed) swiper.allowClick = true;\n });\n\n if (!data.isTouched || !data.isMoved || !swiper.swipeDirection || touches.diff === 0 || data.currentTranslate === data.startTranslate) {\n data.isTouched = false;\n data.isMoved = false;\n data.startMoving = false;\n return;\n }\n\n data.isTouched = false;\n data.isMoved = false;\n data.startMoving = false;\n let currentPos;\n\n if (params.followFinger) {\n currentPos = rtl ? swiper.translate : -swiper.translate;\n } else {\n currentPos = -data.currentTranslate;\n }\n\n if (params.cssMode) {\n return;\n }\n\n if (swiper.params.freeMode && params.freeMode.enabled) {\n swiper.freeMode.onTouchEnd({\n currentPos\n });\n return;\n } // Find current slide\n\n\n let stopIndex = 0;\n let groupSize = swiper.slidesSizesGrid[0];\n\n for (let i = 0; i < slidesGrid.length; i += i < params.slidesPerGroupSkip ? 1 : params.slidesPerGroup) {\n const increment = i < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;\n\n if (typeof slidesGrid[i + increment] !== 'undefined') {\n if (currentPos >= slidesGrid[i] && currentPos < slidesGrid[i + increment]) {\n stopIndex = i;\n groupSize = slidesGrid[i + increment] - slidesGrid[i];\n }\n } else if (currentPos >= slidesGrid[i]) {\n stopIndex = i;\n groupSize = slidesGrid[slidesGrid.length - 1] - slidesGrid[slidesGrid.length - 2];\n }\n }\n\n let rewindFirstIndex = null;\n let rewindLastIndex = null;\n\n if (params.rewind) {\n if (swiper.isBeginning) {\n rewindLastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;\n } else if (swiper.isEnd) {\n rewindFirstIndex = 0;\n }\n } // Find current slide size\n\n\n const ratio = (currentPos - slidesGrid[stopIndex]) / groupSize;\n const increment = stopIndex < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;\n\n if (timeDiff > params.longSwipesMs) {\n // Long touches\n if (!params.longSwipes) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n\n if (swiper.swipeDirection === 'next') {\n if (ratio >= params.longSwipesRatio) swiper.slideTo(params.rewind && swiper.isEnd ? rewindFirstIndex : stopIndex + increment);else swiper.slideTo(stopIndex);\n }\n\n if (swiper.swipeDirection === 'prev') {\n if (ratio > 1 - params.longSwipesRatio) {\n swiper.slideTo(stopIndex + increment);\n } else if (rewindLastIndex !== null && ratio < 0 && Math.abs(ratio) > params.longSwipesRatio) {\n swiper.slideTo(rewindLastIndex);\n } else {\n swiper.slideTo(stopIndex);\n }\n }\n } else {\n // Short swipes\n if (!params.shortSwipes) {\n swiper.slideTo(swiper.activeIndex);\n return;\n }\n\n const isNavButtonTarget = swiper.navigation && (e.target === swiper.navigation.nextEl || e.target === swiper.navigation.prevEl);\n\n if (!isNavButtonTarget) {\n if (swiper.swipeDirection === 'next') {\n swiper.slideTo(rewindFirstIndex !== null ? rewindFirstIndex : stopIndex + increment);\n }\n\n if (swiper.swipeDirection === 'prev') {\n swiper.slideTo(rewindLastIndex !== null ? rewindLastIndex : stopIndex);\n }\n } else if (e.target === swiper.navigation.nextEl) {\n swiper.slideTo(stopIndex + increment);\n } else {\n swiper.slideTo(stopIndex);\n }\n }\n}","export default function onResize() {\n const swiper = this;\n const {\n params,\n el\n } = swiper;\n if (el && el.offsetWidth === 0) return; // Breakpoints\n\n if (params.breakpoints) {\n swiper.setBreakpoint();\n } // Save locks\n\n\n const {\n allowSlideNext,\n allowSlidePrev,\n snapGrid\n } = swiper; // Disable locks on resize\n\n swiper.allowSlideNext = true;\n swiper.allowSlidePrev = true;\n swiper.updateSize();\n swiper.updateSlides();\n swiper.updateSlidesClasses();\n\n if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !swiper.isBeginning && !swiper.params.centeredSlides) {\n swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n } else {\n swiper.slideTo(swiper.activeIndex, 0, false, true);\n }\n\n if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {\n swiper.autoplay.run();\n } // Return locks after resize\n\n\n swiper.allowSlidePrev = allowSlidePrev;\n swiper.allowSlideNext = allowSlideNext;\n\n if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) {\n swiper.checkOverflow();\n }\n}","export default function onClick(e) {\n const swiper = this;\n if (!swiper.enabled) return;\n\n if (!swiper.allowClick) {\n if (swiper.params.preventClicks) e.preventDefault();\n\n if (swiper.params.preventClicksPropagation && swiper.animating) {\n e.stopPropagation();\n e.stopImmediatePropagation();\n }\n }\n}","export default function onScroll() {\n const swiper = this;\n const {\n wrapperEl,\n rtlTranslate,\n enabled\n } = swiper;\n if (!enabled) return;\n swiper.previousTranslate = swiper.translate;\n\n if (swiper.isHorizontal()) {\n swiper.translate = -wrapperEl.scrollLeft;\n } else {\n swiper.translate = -wrapperEl.scrollTop;\n } // eslint-disable-next-line\n\n\n if (swiper.translate === 0) swiper.translate = 0;\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n let newProgress;\n const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n\n if (translatesDiff === 0) {\n newProgress = 0;\n } else {\n newProgress = (swiper.translate - swiper.minTranslate()) / translatesDiff;\n }\n\n if (newProgress !== swiper.progress) {\n swiper.updateProgress(rtlTranslate ? -swiper.translate : swiper.translate);\n }\n\n swiper.emit('setTranslate', swiper.translate, false);\n}","import { getDocument } from 'ssr-window';\nimport onTouchStart from './onTouchStart.js';\nimport onTouchMove from './onTouchMove.js';\nimport onTouchEnd from './onTouchEnd.js';\nimport onResize from './onResize.js';\nimport onClick from './onClick.js';\nimport onScroll from './onScroll.js';\nlet dummyEventAttached = false;\n\nfunction dummyEventListener() {}\n\nconst events = (swiper, method) => {\n const document = getDocument();\n const {\n params,\n touchEvents,\n el,\n wrapperEl,\n device,\n support\n } = swiper;\n const capture = !!params.nested;\n const domMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';\n const swiperMethod = method; // Touch Events\n\n if (!support.touch) {\n el[domMethod](touchEvents.start, swiper.onTouchStart, false);\n document[domMethod](touchEvents.move, swiper.onTouchMove, capture);\n document[domMethod](touchEvents.end, swiper.onTouchEnd, false);\n } else {\n const passiveListener = touchEvents.start === 'touchstart' && support.passiveListener && params.passiveListeners ? {\n passive: true,\n capture: false\n } : false;\n el[domMethod](touchEvents.start, swiper.onTouchStart, passiveListener);\n el[domMethod](touchEvents.move, swiper.onTouchMove, support.passiveListener ? {\n passive: false,\n capture\n } : capture);\n el[domMethod](touchEvents.end, swiper.onTouchEnd, passiveListener);\n\n if (touchEvents.cancel) {\n el[domMethod](touchEvents.cancel, swiper.onTouchEnd, passiveListener);\n }\n } // Prevent Links Clicks\n\n\n if (params.preventClicks || params.preventClicksPropagation) {\n el[domMethod]('click', swiper.onClick, true);\n }\n\n if (params.cssMode) {\n wrapperEl[domMethod]('scroll', swiper.onScroll);\n } // Resize handler\n\n\n if (params.updateOnWindowResize) {\n swiper[swiperMethod](device.ios || device.android ? 'resize orientationchange observerUpdate' : 'resize observerUpdate', onResize, true);\n } else {\n swiper[swiperMethod]('observerUpdate', onResize, true);\n }\n};\n\nfunction attachEvents() {\n const swiper = this;\n const document = getDocument();\n const {\n params,\n support\n } = swiper;\n swiper.onTouchStart = onTouchStart.bind(swiper);\n swiper.onTouchMove = onTouchMove.bind(swiper);\n swiper.onTouchEnd = onTouchEnd.bind(swiper);\n\n if (params.cssMode) {\n swiper.onScroll = onScroll.bind(swiper);\n }\n\n swiper.onClick = onClick.bind(swiper);\n\n if (support.touch && !dummyEventAttached) {\n document.addEventListener('touchstart', dummyEventListener);\n dummyEventAttached = true;\n }\n\n events(swiper, 'on');\n}\n\nfunction detachEvents() {\n const swiper = this;\n events(swiper, 'off');\n}\n\nexport default {\n attachEvents,\n detachEvents\n};","import { extend } from '../../shared/utils.js';\n\nconst isGridEnabled = (swiper, params) => {\n return swiper.grid && params.grid && params.grid.rows > 1;\n};\n\nexport default function setBreakpoint() {\n const swiper = this;\n const {\n activeIndex,\n initialized,\n loopedSlides = 0,\n params,\n $el\n } = swiper;\n const breakpoints = params.breakpoints;\n if (!breakpoints || breakpoints && Object.keys(breakpoints).length === 0) return; // Get breakpoint for window width and update parameters\n\n const breakpoint = swiper.getBreakpoint(breakpoints, swiper.params.breakpointsBase, swiper.el);\n if (!breakpoint || swiper.currentBreakpoint === breakpoint) return;\n const breakpointOnlyParams = breakpoint in breakpoints ? breakpoints[breakpoint] : undefined;\n const breakpointParams = breakpointOnlyParams || swiper.originalParams;\n const wasMultiRow = isGridEnabled(swiper, params);\n const isMultiRow = isGridEnabled(swiper, breakpointParams);\n const wasEnabled = params.enabled;\n\n if (wasMultiRow && !isMultiRow) {\n $el.removeClass(`${params.containerModifierClass}grid ${params.containerModifierClass}grid-column`);\n swiper.emitContainerClasses();\n } else if (!wasMultiRow && isMultiRow) {\n $el.addClass(`${params.containerModifierClass}grid`);\n\n if (breakpointParams.grid.fill && breakpointParams.grid.fill === 'column' || !breakpointParams.grid.fill && params.grid.fill === 'column') {\n $el.addClass(`${params.containerModifierClass}grid-column`);\n }\n\n swiper.emitContainerClasses();\n } // Toggle navigation, pagination, scrollbar\n\n\n ['navigation', 'pagination', 'scrollbar'].forEach(prop => {\n const wasModuleEnabled = params[prop] && params[prop].enabled;\n const isModuleEnabled = breakpointParams[prop] && breakpointParams[prop].enabled;\n\n if (wasModuleEnabled && !isModuleEnabled) {\n swiper[prop].disable();\n }\n\n if (!wasModuleEnabled && isModuleEnabled) {\n swiper[prop].enable();\n }\n });\n const directionChanged = breakpointParams.direction && breakpointParams.direction !== params.direction;\n const needsReLoop = params.loop && (breakpointParams.slidesPerView !== params.slidesPerView || directionChanged);\n\n if (directionChanged && initialized) {\n swiper.changeDirection();\n }\n\n extend(swiper.params, breakpointParams);\n const isEnabled = swiper.params.enabled;\n Object.assign(swiper, {\n allowTouchMove: swiper.params.allowTouchMove,\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev\n });\n\n if (wasEnabled && !isEnabled) {\n swiper.disable();\n } else if (!wasEnabled && isEnabled) {\n swiper.enable();\n }\n\n swiper.currentBreakpoint = breakpoint;\n swiper.emit('_beforeBreakpoint', breakpointParams);\n\n if (needsReLoop && initialized) {\n swiper.loopDestroy();\n swiper.loopCreate();\n swiper.updateSlides();\n swiper.slideTo(activeIndex - loopedSlides + swiper.loopedSlides, 0, false);\n }\n\n swiper.emit('breakpoint', breakpointParams);\n}","import setBreakpoint from './setBreakpoint.js';\nimport getBreakpoint from './getBreakpoint.js';\nexport default {\n setBreakpoint,\n getBreakpoint\n};","import { getWindow } from 'ssr-window';\nexport default function getBreakpoint(breakpoints, base = 'window', containerEl) {\n if (!breakpoints || base === 'container' && !containerEl) return undefined;\n let breakpoint = false;\n const window = getWindow();\n const currentHeight = base === 'window' ? window.innerHeight : containerEl.clientHeight;\n const points = Object.keys(breakpoints).map(point => {\n if (typeof point === 'string' && point.indexOf('@') === 0) {\n const minRatio = parseFloat(point.substr(1));\n const value = currentHeight * minRatio;\n return {\n value,\n point\n };\n }\n\n return {\n value: point,\n point\n };\n });\n points.sort((a, b) => parseInt(a.value, 10) - parseInt(b.value, 10));\n\n for (let i = 0; i < points.length; i += 1) {\n const {\n point,\n value\n } = points[i];\n\n if (base === 'window') {\n if (window.matchMedia(`(min-width: ${value}px)`).matches) {\n breakpoint = point;\n }\n } else if (value <= containerEl.clientWidth) {\n breakpoint = point;\n }\n }\n\n return breakpoint || 'max';\n}","import addClasses from './addClasses.js';\nimport removeClasses from './removeClasses.js';\nexport default {\n addClasses,\n removeClasses\n};","function prepareClasses(entries, prefix) {\n const resultClasses = [];\n entries.forEach(item => {\n if (typeof item === 'object') {\n Object.keys(item).forEach(classNames => {\n if (item[classNames]) {\n resultClasses.push(prefix + classNames);\n }\n });\n } else if (typeof item === 'string') {\n resultClasses.push(prefix + item);\n }\n });\n return resultClasses;\n}\n\nexport default function addClasses() {\n const swiper = this;\n const {\n classNames,\n params,\n rtl,\n $el,\n device,\n support\n } = swiper; // prettier-ignore\n\n const suffixes = prepareClasses(['initialized', params.direction, {\n 'pointer-events': !support.touch\n }, {\n 'free-mode': swiper.params.freeMode && params.freeMode.enabled\n }, {\n 'autoheight': params.autoHeight\n }, {\n 'rtl': rtl\n }, {\n 'grid': params.grid && params.grid.rows > 1\n }, {\n 'grid-column': params.grid && params.grid.rows > 1 && params.grid.fill === 'column'\n }, {\n 'android': device.android\n }, {\n 'ios': device.ios\n }, {\n 'css-mode': params.cssMode\n }, {\n 'centered': params.cssMode && params.centeredSlides\n }, {\n 'watch-progress': params.watchSlidesProgress\n }], params.containerModifierClass);\n classNames.push(...suffixes);\n $el.addClass([...classNames].join(' '));\n swiper.emitContainerClasses();\n}","export default function removeClasses() {\n const swiper = this;\n const {\n $el,\n classNames\n } = swiper;\n $el.removeClass(classNames.join(' '));\n swiper.emitContainerClasses();\n}","function checkOverflow() {\n const swiper = this;\n const {\n isLocked: wasLocked,\n params\n } = swiper;\n const {\n slidesOffsetBefore\n } = params;\n\n if (slidesOffsetBefore) {\n const lastSlideIndex = swiper.slides.length - 1;\n const lastSlideRightEdge = swiper.slidesGrid[lastSlideIndex] + swiper.slidesSizesGrid[lastSlideIndex] + slidesOffsetBefore * 2;\n swiper.isLocked = swiper.size > lastSlideRightEdge;\n } else {\n swiper.isLocked = swiper.snapGrid.length === 1;\n }\n\n if (params.allowSlideNext === true) {\n swiper.allowSlideNext = !swiper.isLocked;\n }\n\n if (params.allowSlidePrev === true) {\n swiper.allowSlidePrev = !swiper.isLocked;\n }\n\n if (wasLocked && wasLocked !== swiper.isLocked) {\n swiper.isEnd = false;\n }\n\n if (wasLocked !== swiper.isLocked) {\n swiper.emit(swiper.isLocked ? 'lock' : 'unlock');\n }\n}\n\nexport default {\n checkOverflow\n};","export default {\n init: true,\n direction: 'horizontal',\n touchEventsTarget: 'wrapper',\n initialSlide: 0,\n speed: 300,\n cssMode: false,\n updateOnWindowResize: true,\n resizeObserver: true,\n nested: false,\n createElements: false,\n enabled: true,\n focusableElements: 'input, select, option, textarea, button, video, label',\n // Overrides\n width: null,\n height: null,\n //\n preventInteractionOnTransition: false,\n // ssr\n userAgent: null,\n url: null,\n // To support iOS's swipe-to-go-back gesture (when being used in-app).\n edgeSwipeDetection: false,\n edgeSwipeThreshold: 20,\n // Autoheight\n autoHeight: false,\n // Set wrapper width\n setWrapperSize: false,\n // Virtual Translate\n virtualTranslate: false,\n // Effects\n effect: 'slide',\n // 'slide' or 'fade' or 'cube' or 'coverflow' or 'flip'\n // Breakpoints\n breakpoints: undefined,\n breakpointsBase: 'window',\n // Slides grid\n spaceBetween: 0,\n slidesPerView: 1,\n slidesPerGroup: 1,\n slidesPerGroupSkip: 0,\n slidesPerGroupAuto: false,\n centeredSlides: false,\n centeredSlidesBounds: false,\n slidesOffsetBefore: 0,\n // in px\n slidesOffsetAfter: 0,\n // in px\n normalizeSlideIndex: true,\n centerInsufficientSlides: false,\n // Disable swiper and hide navigation when container not overflow\n watchOverflow: true,\n // Round length\n roundLengths: false,\n // Touches\n touchRatio: 1,\n touchAngle: 45,\n simulateTouch: true,\n shortSwipes: true,\n longSwipes: true,\n longSwipesRatio: 0.5,\n longSwipesMs: 300,\n followFinger: true,\n allowTouchMove: true,\n threshold: 0,\n touchMoveStopPropagation: false,\n touchStartPreventDefault: true,\n touchStartForcePreventDefault: false,\n touchReleaseOnEdges: false,\n // Unique Navigation Elements\n uniqueNavElements: true,\n // Resistance\n resistance: true,\n resistanceRatio: 0.85,\n // Progress\n watchSlidesProgress: false,\n // Cursor\n grabCursor: false,\n // Clicks\n preventClicks: true,\n preventClicksPropagation: true,\n slideToClickedSlide: false,\n // Images\n preloadImages: true,\n updateOnImagesReady: true,\n // loop\n loop: false,\n loopAdditionalSlides: 0,\n loopedSlides: null,\n loopedSlidesLimit: true,\n loopFillGroupWithBlank: false,\n loopPreventsSlide: true,\n // rewind\n rewind: false,\n // Swiping/no swiping\n allowSlidePrev: true,\n allowSlideNext: true,\n swipeHandler: null,\n // '.swipe-handler',\n noSwiping: true,\n noSwipingClass: 'swiper-no-swiping',\n noSwipingSelector: null,\n // Passive Listeners\n passiveListeners: true,\n maxBackfaceHiddenSlides: 10,\n // NS\n containerModifierClass: 'swiper-',\n // NEW\n slideClass: 'swiper-slide',\n slideBlankClass: 'swiper-slide-invisible-blank',\n slideActiveClass: 'swiper-slide-active',\n slideDuplicateActiveClass: 'swiper-slide-duplicate-active',\n slideVisibleClass: 'swiper-slide-visible',\n slideDuplicateClass: 'swiper-slide-duplicate',\n slideNextClass: 'swiper-slide-next',\n slideDuplicateNextClass: 'swiper-slide-duplicate-next',\n slidePrevClass: 'swiper-slide-prev',\n slideDuplicatePrevClass: 'swiper-slide-duplicate-prev',\n wrapperClass: 'swiper-wrapper',\n // Callbacks\n runCallbacksOnInit: true,\n // Internals\n _emitClasses: false\n};","import { extend } from '../shared/utils.js';\nexport default function moduleExtendParams(params, allModulesParams) {\n return function extendParams(obj = {}) {\n const moduleParamName = Object.keys(obj)[0];\n const moduleParams = obj[moduleParamName];\n\n if (typeof moduleParams !== 'object' || moduleParams === null) {\n extend(allModulesParams, obj);\n return;\n }\n\n if (['navigation', 'pagination', 'scrollbar'].indexOf(moduleParamName) >= 0 && params[moduleParamName] === true) {\n params[moduleParamName] = {\n auto: true\n };\n }\n\n if (!(moduleParamName in params && 'enabled' in moduleParams)) {\n extend(allModulesParams, obj);\n return;\n }\n\n if (params[moduleParamName] === true) {\n params[moduleParamName] = {\n enabled: true\n };\n }\n\n if (typeof params[moduleParamName] === 'object' && !('enabled' in params[moduleParamName])) {\n params[moduleParamName].enabled = true;\n }\n\n if (!params[moduleParamName]) params[moduleParamName] = {\n enabled: false\n };\n extend(allModulesParams, obj);\n };\n}","/* eslint no-param-reassign: \"off\" */\nimport { getDocument } from 'ssr-window';\nimport $ from '../shared/dom.js';\nimport { extend, now, deleteProps } from '../shared/utils.js';\nimport { getSupport } from '../shared/get-support.js';\nimport { getDevice } from '../shared/get-device.js';\nimport { getBrowser } from '../shared/get-browser.js';\nimport Resize from './modules/resize/resize.js';\nimport Observer from './modules/observer/observer.js';\nimport eventsEmitter from './events-emitter.js';\nimport update from './update/index.js';\nimport translate from './translate/index.js';\nimport transition from './transition/index.js';\nimport slide from './slide/index.js';\nimport loop from './loop/index.js';\nimport grabCursor from './grab-cursor/index.js';\nimport events from './events/index.js';\nimport breakpoints from './breakpoints/index.js';\nimport classes from './classes/index.js';\nimport images from './images/index.js';\nimport checkOverflow from './check-overflow/index.js';\nimport defaults from './defaults.js';\nimport moduleExtendParams from './moduleExtendParams.js';\nconst prototypes = {\n eventsEmitter,\n update,\n translate,\n transition,\n slide,\n loop,\n grabCursor,\n events,\n breakpoints,\n checkOverflow,\n classes,\n images\n};\nconst extendedDefaults = {};\n\nclass Swiper {\n constructor(...args) {\n let el;\n let params;\n\n if (args.length === 1 && args[0].constructor && Object.prototype.toString.call(args[0]).slice(8, -1) === 'Object') {\n params = args[0];\n } else {\n [el, params] = args;\n }\n\n if (!params) params = {};\n params = extend({}, params);\n if (el && !params.el) params.el = el;\n\n if (params.el && $(params.el).length > 1) {\n const swipers = [];\n $(params.el).each(containerEl => {\n const newParams = extend({}, params, {\n el: containerEl\n });\n swipers.push(new Swiper(newParams));\n }); // eslint-disable-next-line no-constructor-return\n\n return swipers;\n } // Swiper Instance\n\n\n const swiper = this;\n swiper.__swiper__ = true;\n swiper.support = getSupport();\n swiper.device = getDevice({\n userAgent: params.userAgent\n });\n swiper.browser = getBrowser();\n swiper.eventsListeners = {};\n swiper.eventsAnyListeners = [];\n swiper.modules = [...swiper.__modules__];\n\n if (params.modules && Array.isArray(params.modules)) {\n swiper.modules.push(...params.modules);\n }\n\n const allModulesParams = {};\n swiper.modules.forEach(mod => {\n mod({\n swiper,\n extendParams: moduleExtendParams(params, allModulesParams),\n on: swiper.on.bind(swiper),\n once: swiper.once.bind(swiper),\n off: swiper.off.bind(swiper),\n emit: swiper.emit.bind(swiper)\n });\n }); // Extend defaults with modules params\n\n const swiperParams = extend({}, defaults, allModulesParams); // Extend defaults with passed params\n\n swiper.params = extend({}, swiperParams, extendedDefaults, params);\n swiper.originalParams = extend({}, swiper.params);\n swiper.passedParams = extend({}, params); // add event listeners\n\n if (swiper.params && swiper.params.on) {\n Object.keys(swiper.params.on).forEach(eventName => {\n swiper.on(eventName, swiper.params.on[eventName]);\n });\n }\n\n if (swiper.params && swiper.params.onAny) {\n swiper.onAny(swiper.params.onAny);\n } // Save Dom lib\n\n\n swiper.$ = $; // Extend Swiper\n\n Object.assign(swiper, {\n enabled: swiper.params.enabled,\n el,\n // Classes\n classNames: [],\n // Slides\n slides: $(),\n slidesGrid: [],\n snapGrid: [],\n slidesSizesGrid: [],\n\n // isDirection\n isHorizontal() {\n return swiper.params.direction === 'horizontal';\n },\n\n isVertical() {\n return swiper.params.direction === 'vertical';\n },\n\n // Indexes\n activeIndex: 0,\n realIndex: 0,\n //\n isBeginning: true,\n isEnd: false,\n // Props\n translate: 0,\n previousTranslate: 0,\n progress: 0,\n velocity: 0,\n animating: false,\n // Locks\n allowSlideNext: swiper.params.allowSlideNext,\n allowSlidePrev: swiper.params.allowSlidePrev,\n // Touch Events\n touchEvents: function touchEvents() {\n const touch = ['touchstart', 'touchmove', 'touchend', 'touchcancel'];\n const desktop = ['pointerdown', 'pointermove', 'pointerup'];\n swiper.touchEventsTouch = {\n start: touch[0],\n move: touch[1],\n end: touch[2],\n cancel: touch[3]\n };\n swiper.touchEventsDesktop = {\n start: desktop[0],\n move: desktop[1],\n end: desktop[2]\n };\n return swiper.support.touch || !swiper.params.simulateTouch ? swiper.touchEventsTouch : swiper.touchEventsDesktop;\n }(),\n touchEventsData: {\n isTouched: undefined,\n isMoved: undefined,\n allowTouchCallbacks: undefined,\n touchStartTime: undefined,\n isScrolling: undefined,\n currentTranslate: undefined,\n startTranslate: undefined,\n allowThresholdMove: undefined,\n // Form elements to match\n focusableElements: swiper.params.focusableElements,\n // Last click time\n lastClickTime: now(),\n clickTimeout: undefined,\n // Velocities\n velocities: [],\n allowMomentumBounce: undefined,\n isTouchEvent: undefined,\n startMoving: undefined\n },\n // Clicks\n allowClick: true,\n // Touches\n allowTouchMove: swiper.params.allowTouchMove,\n touches: {\n startX: 0,\n startY: 0,\n currentX: 0,\n currentY: 0,\n diff: 0\n },\n // Images\n imagesToLoad: [],\n imagesLoaded: 0\n });\n swiper.emit('_swiper'); // Init\n\n if (swiper.params.init) {\n swiper.init();\n } // Return app instance\n // eslint-disable-next-line no-constructor-return\n\n\n return swiper;\n }\n\n enable() {\n const swiper = this;\n if (swiper.enabled) return;\n swiper.enabled = true;\n\n if (swiper.params.grabCursor) {\n swiper.setGrabCursor();\n }\n\n swiper.emit('enable');\n }\n\n disable() {\n const swiper = this;\n if (!swiper.enabled) return;\n swiper.enabled = false;\n\n if (swiper.params.grabCursor) {\n swiper.unsetGrabCursor();\n }\n\n swiper.emit('disable');\n }\n\n setProgress(progress, speed) {\n const swiper = this;\n progress = Math.min(Math.max(progress, 0), 1);\n const min = swiper.minTranslate();\n const max = swiper.maxTranslate();\n const current = (max - min) * progress + min;\n swiper.translateTo(current, typeof speed === 'undefined' ? 0 : speed);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n emitContainerClasses() {\n const swiper = this;\n if (!swiper.params._emitClasses || !swiper.el) return;\n const cls = swiper.el.className.split(' ').filter(className => {\n return className.indexOf('swiper') === 0 || className.indexOf(swiper.params.containerModifierClass) === 0;\n });\n swiper.emit('_containerClasses', cls.join(' '));\n }\n\n getSlideClasses(slideEl) {\n const swiper = this;\n if (swiper.destroyed) return '';\n return slideEl.className.split(' ').filter(className => {\n return className.indexOf('swiper-slide') === 0 || className.indexOf(swiper.params.slideClass) === 0;\n }).join(' ');\n }\n\n emitSlidesClasses() {\n const swiper = this;\n if (!swiper.params._emitClasses || !swiper.el) return;\n const updates = [];\n swiper.slides.each(slideEl => {\n const classNames = swiper.getSlideClasses(slideEl);\n updates.push({\n slideEl,\n classNames\n });\n swiper.emit('_slideClass', slideEl, classNames);\n });\n swiper.emit('_slideClasses', updates);\n }\n\n slidesPerViewDynamic(view = 'current', exact = false) {\n const swiper = this;\n const {\n params,\n slides,\n slidesGrid,\n slidesSizesGrid,\n size: swiperSize,\n activeIndex\n } = swiper;\n let spv = 1;\n\n if (params.centeredSlides) {\n let slideSize = slides[activeIndex].swiperSlideSize;\n let breakLoop;\n\n for (let i = activeIndex + 1; i < slides.length; i += 1) {\n if (slides[i] && !breakLoop) {\n slideSize += slides[i].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) breakLoop = true;\n }\n }\n\n for (let i = activeIndex - 1; i >= 0; i -= 1) {\n if (slides[i] && !breakLoop) {\n slideSize += slides[i].swiperSlideSize;\n spv += 1;\n if (slideSize > swiperSize) breakLoop = true;\n }\n }\n } else {\n // eslint-disable-next-line\n if (view === 'current') {\n for (let i = activeIndex + 1; i < slides.length; i += 1) {\n const slideInView = exact ? slidesGrid[i] + slidesSizesGrid[i] - slidesGrid[activeIndex] < swiperSize : slidesGrid[i] - slidesGrid[activeIndex] < swiperSize;\n\n if (slideInView) {\n spv += 1;\n }\n }\n } else {\n // previous\n for (let i = activeIndex - 1; i >= 0; i -= 1) {\n const slideInView = slidesGrid[activeIndex] - slidesGrid[i] < swiperSize;\n\n if (slideInView) {\n spv += 1;\n }\n }\n }\n }\n\n return spv;\n }\n\n update() {\n const swiper = this;\n if (!swiper || swiper.destroyed) return;\n const {\n snapGrid,\n params\n } = swiper; // Breakpoints\n\n if (params.breakpoints) {\n swiper.setBreakpoint();\n }\n\n swiper.updateSize();\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n function setTranslate() {\n const translateValue = swiper.rtlTranslate ? swiper.translate * -1 : swiper.translate;\n const newTranslate = Math.min(Math.max(translateValue, swiper.maxTranslate()), swiper.minTranslate());\n swiper.setTranslate(newTranslate);\n swiper.updateActiveIndex();\n swiper.updateSlidesClasses();\n }\n\n let translated;\n\n if (swiper.params.freeMode && swiper.params.freeMode.enabled) {\n setTranslate();\n\n if (swiper.params.autoHeight) {\n swiper.updateAutoHeight();\n }\n } else {\n if ((swiper.params.slidesPerView === 'auto' || swiper.params.slidesPerView > 1) && swiper.isEnd && !swiper.params.centeredSlides) {\n translated = swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n } else {\n translated = swiper.slideTo(swiper.activeIndex, 0, false, true);\n }\n\n if (!translated) {\n setTranslate();\n }\n }\n\n if (params.watchOverflow && snapGrid !== swiper.snapGrid) {\n swiper.checkOverflow();\n }\n\n swiper.emit('update');\n }\n\n changeDirection(newDirection, needUpdate = true) {\n const swiper = this;\n const currentDirection = swiper.params.direction;\n\n if (!newDirection) {\n // eslint-disable-next-line\n newDirection = currentDirection === 'horizontal' ? 'vertical' : 'horizontal';\n }\n\n if (newDirection === currentDirection || newDirection !== 'horizontal' && newDirection !== 'vertical') {\n return swiper;\n }\n\n swiper.$el.removeClass(`${swiper.params.containerModifierClass}${currentDirection}`).addClass(`${swiper.params.containerModifierClass}${newDirection}`);\n swiper.emitContainerClasses();\n swiper.params.direction = newDirection;\n swiper.slides.each(slideEl => {\n if (newDirection === 'vertical') {\n slideEl.style.width = '';\n } else {\n slideEl.style.height = '';\n }\n });\n swiper.emit('changeDirection');\n if (needUpdate) swiper.update();\n return swiper;\n }\n\n changeLanguageDirection(direction) {\n const swiper = this;\n if (swiper.rtl && direction === 'rtl' || !swiper.rtl && direction === 'ltr') return;\n swiper.rtl = direction === 'rtl';\n swiper.rtlTranslate = swiper.params.direction === 'horizontal' && swiper.rtl;\n\n if (swiper.rtl) {\n swiper.$el.addClass(`${swiper.params.containerModifierClass}rtl`);\n swiper.el.dir = 'rtl';\n } else {\n swiper.$el.removeClass(`${swiper.params.containerModifierClass}rtl`);\n swiper.el.dir = 'ltr';\n }\n\n swiper.update();\n }\n\n mount(el) {\n const swiper = this;\n if (swiper.mounted) return true; // Find el\n\n const $el = $(el || swiper.params.el);\n el = $el[0];\n\n if (!el) {\n return false;\n }\n\n el.swiper = swiper;\n\n const getWrapperSelector = () => {\n return `.${(swiper.params.wrapperClass || '').trim().split(' ').join('.')}`;\n };\n\n const getWrapper = () => {\n if (el && el.shadowRoot && el.shadowRoot.querySelector) {\n const res = $(el.shadowRoot.querySelector(getWrapperSelector())); // Children needs to return slot items\n\n res.children = options => $el.children(options);\n\n return res;\n }\n\n if (!$el.children) {\n return $($el).children(getWrapperSelector());\n }\n\n return $el.children(getWrapperSelector());\n }; // Find Wrapper\n\n\n let $wrapperEl = getWrapper();\n\n if ($wrapperEl.length === 0 && swiper.params.createElements) {\n const document = getDocument();\n const wrapper = document.createElement('div');\n $wrapperEl = $(wrapper);\n wrapper.className = swiper.params.wrapperClass;\n $el.append(wrapper);\n $el.children(`.${swiper.params.slideClass}`).each(slideEl => {\n $wrapperEl.append(slideEl);\n });\n }\n\n Object.assign(swiper, {\n $el,\n el,\n $wrapperEl,\n wrapperEl: $wrapperEl[0],\n mounted: true,\n // RTL\n rtl: el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl',\n rtlTranslate: swiper.params.direction === 'horizontal' && (el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl'),\n wrongRTL: $wrapperEl.css('display') === '-webkit-box'\n });\n return true;\n }\n\n init(el) {\n const swiper = this;\n if (swiper.initialized) return swiper;\n const mounted = swiper.mount(el);\n if (mounted === false) return swiper;\n swiper.emit('beforeInit'); // Set breakpoint\n\n if (swiper.params.breakpoints) {\n swiper.setBreakpoint();\n } // Add Classes\n\n\n swiper.addClasses(); // Create loop\n\n if (swiper.params.loop) {\n swiper.loopCreate();\n } // Update size\n\n\n swiper.updateSize(); // Update slides\n\n swiper.updateSlides();\n\n if (swiper.params.watchOverflow) {\n swiper.checkOverflow();\n } // Set Grab Cursor\n\n\n if (swiper.params.grabCursor && swiper.enabled) {\n swiper.setGrabCursor();\n }\n\n if (swiper.params.preloadImages) {\n swiper.preloadImages();\n } // Slide To Initial Slide\n\n\n if (swiper.params.loop) {\n swiper.slideTo(swiper.params.initialSlide + swiper.loopedSlides, 0, swiper.params.runCallbacksOnInit, false, true);\n } else {\n swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit, false, true);\n } // Attach events\n\n\n swiper.attachEvents(); // Init Flag\n\n swiper.initialized = true; // Emit\n\n swiper.emit('init');\n swiper.emit('afterInit');\n return swiper;\n }\n\n destroy(deleteInstance = true, cleanStyles = true) {\n const swiper = this;\n const {\n params,\n $el,\n $wrapperEl,\n slides\n } = swiper;\n\n if (typeof swiper.params === 'undefined' || swiper.destroyed) {\n return null;\n }\n\n swiper.emit('beforeDestroy'); // Init Flag\n\n swiper.initialized = false; // Detach events\n\n swiper.detachEvents(); // Destroy loop\n\n if (params.loop) {\n swiper.loopDestroy();\n } // Cleanup styles\n\n\n if (cleanStyles) {\n swiper.removeClasses();\n $el.removeAttr('style');\n $wrapperEl.removeAttr('style');\n\n if (slides && slides.length) {\n slides.removeClass([params.slideVisibleClass, params.slideActiveClass, params.slideNextClass, params.slidePrevClass].join(' ')).removeAttr('style').removeAttr('data-swiper-slide-index');\n }\n }\n\n swiper.emit('destroy'); // Detach emitter events\n\n Object.keys(swiper.eventsListeners).forEach(eventName => {\n swiper.off(eventName);\n });\n\n if (deleteInstance !== false) {\n swiper.$el[0].swiper = null;\n deleteProps(swiper);\n }\n\n swiper.destroyed = true;\n return null;\n }\n\n static extendDefaults(newDefaults) {\n extend(extendedDefaults, newDefaults);\n }\n\n static get extendedDefaults() {\n return extendedDefaults;\n }\n\n static get defaults() {\n return defaults;\n }\n\n static installModule(mod) {\n if (!Swiper.prototype.__modules__) Swiper.prototype.__modules__ = [];\n const modules = Swiper.prototype.__modules__;\n\n if (typeof mod === 'function' && modules.indexOf(mod) < 0) {\n modules.push(mod);\n }\n }\n\n static use(module) {\n if (Array.isArray(module)) {\n module.forEach(m => Swiper.installModule(m));\n return Swiper;\n }\n\n Swiper.installModule(module);\n return Swiper;\n }\n\n}\n\nObject.keys(prototypes).forEach(prototypeGroup => {\n Object.keys(prototypes[prototypeGroup]).forEach(protoMethod => {\n Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod];\n });\n});\nSwiper.use([Resize, Observer]);\nexport default Swiper;","import setGrabCursor from './setGrabCursor.js';\nimport unsetGrabCursor from './unsetGrabCursor.js';\nexport default {\n setGrabCursor,\n unsetGrabCursor\n};","export default function setGrabCursor(moving) {\n const swiper = this;\n if (swiper.support.touch || !swiper.params.simulateTouch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return;\n const el = swiper.params.touchEventsTarget === 'container' ? swiper.el : swiper.wrapperEl;\n el.style.cursor = 'move';\n el.style.cursor = moving ? 'grabbing' : 'grab';\n}","export default function unsetGrabCursor() {\n const swiper = this;\n\n if (swiper.support.touch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) {\n return;\n }\n\n swiper[swiper.params.touchEventsTarget === 'container' ? 'el' : 'wrapperEl'].style.cursor = '';\n}","import loadImage from './loadImage.js';\nimport preloadImages from './preloadImages.js';\nexport default {\n loadImage,\n preloadImages\n};","import { getWindow } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function loadImage(imageEl, src, srcset, sizes, checkForComplete, callback) {\n const window = getWindow();\n let image;\n\n function onReady() {\n if (callback) callback();\n }\n\n const isPicture = $(imageEl).parent('picture')[0];\n\n if (!isPicture && (!imageEl.complete || !checkForComplete)) {\n if (src) {\n image = new window.Image();\n image.onload = onReady;\n image.onerror = onReady;\n\n if (sizes) {\n image.sizes = sizes;\n }\n\n if (srcset) {\n image.srcset = srcset;\n }\n\n if (src) {\n image.src = src;\n }\n } else {\n onReady();\n }\n } else {\n // image already loaded...\n onReady();\n }\n}","export default function preloadImages() {\n const swiper = this;\n swiper.imagesToLoad = swiper.$el.find('img');\n\n function onReady() {\n if (typeof swiper === 'undefined' || swiper === null || !swiper || swiper.destroyed) return;\n if (swiper.imagesLoaded !== undefined) swiper.imagesLoaded += 1;\n\n if (swiper.imagesLoaded === swiper.imagesToLoad.length) {\n if (swiper.params.updateOnImagesReady) swiper.update();\n swiper.emit('imagesReady');\n }\n }\n\n for (let i = 0; i < swiper.imagesToLoad.length; i += 1) {\n const imageEl = swiper.imagesToLoad[i];\n swiper.loadImage(imageEl, imageEl.currentSrc || imageEl.getAttribute('src'), imageEl.srcset || imageEl.getAttribute('srcset'), imageEl.sizes || imageEl.getAttribute('sizes'), true, onReady);\n }\n}","import { getWindow } from 'ssr-window';\nexport default function Resize({\n swiper,\n on,\n emit\n}) {\n const window = getWindow();\n let observer = null;\n let animationFrame = null;\n\n const resizeHandler = () => {\n if (!swiper || swiper.destroyed || !swiper.initialized) return;\n emit('beforeResize');\n emit('resize');\n };\n\n const createObserver = () => {\n if (!swiper || swiper.destroyed || !swiper.initialized) return;\n observer = new ResizeObserver(entries => {\n animationFrame = window.requestAnimationFrame(() => {\n const {\n width,\n height\n } = swiper;\n let newWidth = width;\n let newHeight = height;\n entries.forEach(({\n contentBoxSize,\n contentRect,\n target\n }) => {\n if (target && target !== swiper.el) return;\n newWidth = contentRect ? contentRect.width : (contentBoxSize[0] || contentBoxSize).inlineSize;\n newHeight = contentRect ? contentRect.height : (contentBoxSize[0] || contentBoxSize).blockSize;\n });\n\n if (newWidth !== width || newHeight !== height) {\n resizeHandler();\n }\n });\n });\n observer.observe(swiper.el);\n };\n\n const removeObserver = () => {\n if (animationFrame) {\n window.cancelAnimationFrame(animationFrame);\n }\n\n if (observer && observer.unobserve && swiper.el) {\n observer.unobserve(swiper.el);\n observer = null;\n }\n };\n\n const orientationChangeHandler = () => {\n if (!swiper || swiper.destroyed || !swiper.initialized) return;\n emit('orientationchange');\n };\n\n on('init', () => {\n if (swiper.params.resizeObserver && typeof window.ResizeObserver !== 'undefined') {\n createObserver();\n return;\n }\n\n window.addEventListener('resize', resizeHandler);\n window.addEventListener('orientationchange', orientationChangeHandler);\n });\n on('destroy', () => {\n removeObserver();\n window.removeEventListener('resize', resizeHandler);\n window.removeEventListener('orientationchange', orientationChangeHandler);\n });\n}","import { getWindow } from 'ssr-window';\nexport default function Observer({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const observers = [];\n const window = getWindow();\n\n const attach = (target, options = {}) => {\n const ObserverFunc = window.MutationObserver || window.WebkitMutationObserver;\n const observer = new ObserverFunc(mutations => {\n // The observerUpdate event should only be triggered\n // once despite the number of mutations. Additional\n // triggers are redundant and are very costly\n if (mutations.length === 1) {\n emit('observerUpdate', mutations[0]);\n return;\n }\n\n const observerUpdate = function observerUpdate() {\n emit('observerUpdate', mutations[0]);\n };\n\n if (window.requestAnimationFrame) {\n window.requestAnimationFrame(observerUpdate);\n } else {\n window.setTimeout(observerUpdate, 0);\n }\n });\n observer.observe(target, {\n attributes: typeof options.attributes === 'undefined' ? true : options.attributes,\n childList: typeof options.childList === 'undefined' ? true : options.childList,\n characterData: typeof options.characterData === 'undefined' ? true : options.characterData\n });\n observers.push(observer);\n };\n\n const init = () => {\n if (!swiper.params.observer) return;\n\n if (swiper.params.observeParents) {\n const containerParents = swiper.$el.parents();\n\n for (let i = 0; i < containerParents.length; i += 1) {\n attach(containerParents[i]);\n }\n } // Observe container\n\n\n attach(swiper.$el[0], {\n childList: swiper.params.observeSlideChildren\n }); // Observe wrapper\n\n attach(swiper.$wrapperEl[0], {\n attributes: false\n });\n };\n\n const destroy = () => {\n observers.forEach(observer => {\n observer.disconnect();\n });\n observers.splice(0, observers.length);\n };\n\n extendParams({\n observer: false,\n observeParents: false,\n observeSlideChildren: false\n });\n on('init', init);\n on('destroy', destroy);\n}","/* eslint-disable consistent-return */\nimport { getWindow, getDocument } from 'ssr-window';\nimport $ from '../../shared/dom.js';\nexport default function Keyboard({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const document = getDocument();\n const window = getWindow();\n swiper.keyboard = {\n enabled: false\n };\n extendParams({\n keyboard: {\n enabled: false,\n onlyInViewport: true,\n pageUpDown: true\n }\n });\n\n function handle(event) {\n if (!swiper.enabled) return;\n const {\n rtlTranslate: rtl\n } = swiper;\n let e = event;\n if (e.originalEvent) e = e.originalEvent; // jquery fix\n\n const kc = e.keyCode || e.charCode;\n const pageUpDown = swiper.params.keyboard.pageUpDown;\n const isPageUp = pageUpDown && kc === 33;\n const isPageDown = pageUpDown && kc === 34;\n const isArrowLeft = kc === 37;\n const isArrowRight = kc === 39;\n const isArrowUp = kc === 38;\n const isArrowDown = kc === 40; // Directions locks\n\n if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) {\n return false;\n }\n\n if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) {\n return false;\n }\n\n if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {\n return undefined;\n }\n\n if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === 'input' || document.activeElement.nodeName.toLowerCase() === 'textarea')) {\n return undefined;\n }\n\n if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {\n let inView = false; // Check that swiper should be inside of visible area of window\n\n if (swiper.$el.parents(`.${swiper.params.slideClass}`).length > 0 && swiper.$el.parents(`.${swiper.params.slideActiveClass}`).length === 0) {\n return undefined;\n }\n\n const $el = swiper.$el;\n const swiperWidth = $el[0].clientWidth;\n const swiperHeight = $el[0].clientHeight;\n const windowWidth = window.innerWidth;\n const windowHeight = window.innerHeight;\n const swiperOffset = swiper.$el.offset();\n if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;\n const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiperWidth, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiperHeight], [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight]];\n\n for (let i = 0; i < swiperCoord.length; i += 1) {\n const point = swiperCoord[i];\n\n if (point[0] >= 0 && point[0] <= windowWidth && point[1] >= 0 && point[1] <= windowHeight) {\n if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line\n\n inView = true;\n }\n }\n\n if (!inView) return undefined;\n }\n\n if (swiper.isHorizontal()) {\n if (isPageUp || isPageDown || isArrowLeft || isArrowRight) {\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n }\n\n if ((isPageDown || isArrowRight) && !rtl || (isPageUp || isArrowLeft) && rtl) swiper.slideNext();\n if ((isPageUp || isArrowLeft) && !rtl || (isPageDown || isArrowRight) && rtl) swiper.slidePrev();\n } else {\n if (isPageUp || isPageDown || isArrowUp || isArrowDown) {\n if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n }\n\n if (isPageDown || isArrowDown) swiper.slideNext();\n if (isPageUp || isArrowUp) swiper.slidePrev();\n }\n\n emit('keyPress', kc);\n return undefined;\n }\n\n function enable() {\n if (swiper.keyboard.enabled) return;\n $(document).on('keydown', handle);\n swiper.keyboard.enabled = true;\n }\n\n function disable() {\n if (!swiper.keyboard.enabled) return;\n $(document).off('keydown', handle);\n swiper.keyboard.enabled = false;\n }\n\n on('init', () => {\n if (swiper.params.keyboard.enabled) {\n enable();\n }\n });\n on('destroy', () => {\n if (swiper.keyboard.enabled) {\n disable();\n }\n });\n Object.assign(swiper.keyboard, {\n enable,\n disable\n });\n}","export default function classesToSelector(classes = '') {\n return `.${classes.trim().replace(/([\\.:!\\/])/g, '\\\\$1') // eslint-disable-line\n .replace(/ /g, '.')}`;\n}","import $ from '../../shared/dom.js';\nimport classesToSelector from '../../shared/classes-to-selector.js';\nimport createElementIfNotDefined from '../../shared/create-element-if-not-defined.js';\nexport default function Pagination({\n swiper,\n extendParams,\n on,\n emit\n}) {\n const pfx = 'swiper-pagination';\n extendParams({\n pagination: {\n el: null,\n bulletElement: 'span',\n clickable: false,\n hideOnClick: false,\n renderBullet: null,\n renderProgressbar: null,\n renderFraction: null,\n renderCustom: null,\n progressbarOpposite: false,\n type: 'bullets',\n // 'bullets' or 'progressbar' or 'fraction' or 'custom'\n dynamicBullets: false,\n dynamicMainBullets: 1,\n formatFractionCurrent: number => number,\n formatFractionTotal: number => number,\n bulletClass: `${pfx}-bullet`,\n bulletActiveClass: `${pfx}-bullet-active`,\n modifierClass: `${pfx}-`,\n currentClass: `${pfx}-current`,\n totalClass: `${pfx}-total`,\n hiddenClass: `${pfx}-hidden`,\n progressbarFillClass: `${pfx}-progressbar-fill`,\n progressbarOppositeClass: `${pfx}-progressbar-opposite`,\n clickableClass: `${pfx}-clickable`,\n lockClass: `${pfx}-lock`,\n horizontalClass: `${pfx}-horizontal`,\n verticalClass: `${pfx}-vertical`,\n paginationDisabledClass: `${pfx}-disabled`\n }\n });\n swiper.pagination = {\n el: null,\n $el: null,\n bullets: []\n };\n let bulletSize;\n let dynamicBulletIndex = 0;\n\n function isPaginationDisabled() {\n return !swiper.params.pagination.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0;\n }\n\n function setSideBullets($bulletEl, position) {\n const {\n bulletActiveClass\n } = swiper.params.pagination;\n $bulletEl[position]().addClass(`${bulletActiveClass}-${position}`)[position]().addClass(`${bulletActiveClass}-${position}-${position}`);\n }\n\n function update() {\n // Render || Update Pagination bullets/items\n const rtl = swiper.rtl;\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n const $el = swiper.pagination.$el; // Current/Total\n\n let current;\n const total = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n\n if (swiper.params.loop) {\n current = Math.ceil((swiper.activeIndex - swiper.loopedSlides) / swiper.params.slidesPerGroup);\n\n if (current > slidesLength - 1 - swiper.loopedSlides * 2) {\n current -= slidesLength - swiper.loopedSlides * 2;\n }\n\n if (current > total - 1) current -= total;\n if (current < 0 && swiper.params.paginationType !== 'bullets') current = total + current;\n } else if (typeof swiper.snapIndex !== 'undefined') {\n current = swiper.snapIndex;\n } else {\n current = swiper.activeIndex || 0;\n } // Types\n\n\n if (params.type === 'bullets' && swiper.pagination.bullets && swiper.pagination.bullets.length > 0) {\n const bullets = swiper.pagination.bullets;\n let firstIndex;\n let lastIndex;\n let midIndex;\n\n if (params.dynamicBullets) {\n bulletSize = bullets.eq(0)[swiper.isHorizontal() ? 'outerWidth' : 'outerHeight'](true);\n $el.css(swiper.isHorizontal() ? 'width' : 'height', `${bulletSize * (params.dynamicMainBullets + 4)}px`);\n\n if (params.dynamicMainBullets > 1 && swiper.previousIndex !== undefined) {\n dynamicBulletIndex += current - (swiper.previousIndex - swiper.loopedSlides || 0);\n\n if (dynamicBulletIndex > params.dynamicMainBullets - 1) {\n dynamicBulletIndex = params.dynamicMainBullets - 1;\n } else if (dynamicBulletIndex < 0) {\n dynamicBulletIndex = 0;\n }\n }\n\n firstIndex = Math.max(current - dynamicBulletIndex, 0);\n lastIndex = firstIndex + (Math.min(bullets.length, params.dynamicMainBullets) - 1);\n midIndex = (lastIndex + firstIndex) / 2;\n }\n\n bullets.removeClass(['', '-next', '-next-next', '-prev', '-prev-prev', '-main'].map(suffix => `${params.bulletActiveClass}${suffix}`).join(' '));\n\n if ($el.length > 1) {\n bullets.each(bullet => {\n const $bullet = $(bullet);\n const bulletIndex = $bullet.index();\n\n if (bulletIndex === current) {\n $bullet.addClass(params.bulletActiveClass);\n }\n\n if (params.dynamicBullets) {\n if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) {\n $bullet.addClass(`${params.bulletActiveClass}-main`);\n }\n\n if (bulletIndex === firstIndex) {\n setSideBullets($bullet, 'prev');\n }\n\n if (bulletIndex === lastIndex) {\n setSideBullets($bullet, 'next');\n }\n }\n });\n } else {\n const $bullet = bullets.eq(current);\n const bulletIndex = $bullet.index();\n $bullet.addClass(params.bulletActiveClass);\n\n if (params.dynamicBullets) {\n const $firstDisplayedBullet = bullets.eq(firstIndex);\n const $lastDisplayedBullet = bullets.eq(lastIndex);\n\n for (let i = firstIndex; i <= lastIndex; i += 1) {\n bullets.eq(i).addClass(`${params.bulletActiveClass}-main`);\n }\n\n if (swiper.params.loop) {\n if (bulletIndex >= bullets.length) {\n for (let i = params.dynamicMainBullets; i >= 0; i -= 1) {\n bullets.eq(bullets.length - i).addClass(`${params.bulletActiveClass}-main`);\n }\n\n bullets.eq(bullets.length - params.dynamicMainBullets - 1).addClass(`${params.bulletActiveClass}-prev`);\n } else {\n setSideBullets($firstDisplayedBullet, 'prev');\n setSideBullets($lastDisplayedBullet, 'next');\n }\n } else {\n setSideBullets($firstDisplayedBullet, 'prev');\n setSideBullets($lastDisplayedBullet, 'next');\n }\n }\n }\n\n if (params.dynamicBullets) {\n const dynamicBulletsLength = Math.min(bullets.length, params.dynamicMainBullets + 4);\n const bulletsOffset = (bulletSize * dynamicBulletsLength - bulletSize) / 2 - midIndex * bulletSize;\n const offsetProp = rtl ? 'right' : 'left';\n bullets.css(swiper.isHorizontal() ? offsetProp : 'top', `${bulletsOffset}px`);\n }\n }\n\n if (params.type === 'fraction') {\n $el.find(classesToSelector(params.currentClass)).text(params.formatFractionCurrent(current + 1));\n $el.find(classesToSelector(params.totalClass)).text(params.formatFractionTotal(total));\n }\n\n if (params.type === 'progressbar') {\n let progressbarDirection;\n\n if (params.progressbarOpposite) {\n progressbarDirection = swiper.isHorizontal() ? 'vertical' : 'horizontal';\n } else {\n progressbarDirection = swiper.isHorizontal() ? 'horizontal' : 'vertical';\n }\n\n const scale = (current + 1) / total;\n let scaleX = 1;\n let scaleY = 1;\n\n if (progressbarDirection === 'horizontal') {\n scaleX = scale;\n } else {\n scaleY = scale;\n }\n\n $el.find(classesToSelector(params.progressbarFillClass)).transform(`translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`).transition(swiper.params.speed);\n }\n\n if (params.type === 'custom' && params.renderCustom) {\n $el.html(params.renderCustom(swiper, current + 1, total));\n emit('paginationRender', $el[0]);\n } else {\n emit('paginationUpdate', $el[0]);\n }\n\n if (swiper.params.watchOverflow && swiper.enabled) {\n $el[swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);\n }\n }\n\n function render() {\n // Render Container\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n const $el = swiper.pagination.$el;\n let paginationHTML = '';\n\n if (params.type === 'bullets') {\n let numberOfBullets = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n\n if (swiper.params.freeMode && swiper.params.freeMode.enabled && !swiper.params.loop && numberOfBullets > slidesLength) {\n numberOfBullets = slidesLength;\n }\n\n for (let i = 0; i < numberOfBullets; i += 1) {\n if (params.renderBullet) {\n paginationHTML += params.renderBullet.call(swiper, i, params.bulletClass);\n } else {\n paginationHTML += `<${params.bulletElement} class=\"${params.bulletClass}\">`;\n }\n }\n\n $el.html(paginationHTML);\n swiper.pagination.bullets = $el.find(classesToSelector(params.bulletClass));\n }\n\n if (params.type === 'fraction') {\n if (params.renderFraction) {\n paginationHTML = params.renderFraction.call(swiper, params.currentClass, params.totalClass);\n } else {\n paginationHTML = `` + ' / ' + ``;\n }\n\n $el.html(paginationHTML);\n }\n\n if (params.type === 'progressbar') {\n if (params.renderProgressbar) {\n paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass);\n } else {\n paginationHTML = ``;\n }\n\n $el.html(paginationHTML);\n }\n\n if (params.type !== 'custom') {\n emit('paginationRender', swiper.pagination.$el[0]);\n }\n }\n\n function init() {\n swiper.params.pagination = createElementIfNotDefined(swiper, swiper.originalParams.pagination, swiper.params.pagination, {\n el: 'swiper-pagination'\n });\n const params = swiper.params.pagination;\n if (!params.el) return;\n let $el = $(params.el);\n if ($el.length === 0) return;\n\n if (swiper.params.uniqueNavElements && typeof params.el === 'string' && $el.length > 1) {\n $el = swiper.$el.find(params.el); // check if it belongs to another nested Swiper\n\n if ($el.length > 1) {\n $el = $el.filter(el => {\n if ($(el).parents('.swiper')[0] !== swiper.el) return false;\n return true;\n });\n }\n }\n\n if (params.type === 'bullets' && params.clickable) {\n $el.addClass(params.clickableClass);\n }\n\n $el.addClass(params.modifierClass + params.type);\n $el.addClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n\n if (params.type === 'bullets' && params.dynamicBullets) {\n $el.addClass(`${params.modifierClass}${params.type}-dynamic`);\n dynamicBulletIndex = 0;\n\n if (params.dynamicMainBullets < 1) {\n params.dynamicMainBullets = 1;\n }\n }\n\n if (params.type === 'progressbar' && params.progressbarOpposite) {\n $el.addClass(params.progressbarOppositeClass);\n }\n\n if (params.clickable) {\n $el.on('click', classesToSelector(params.bulletClass), function onClick(e) {\n e.preventDefault();\n let index = $(this).index() * swiper.params.slidesPerGroup;\n if (swiper.params.loop) index += swiper.loopedSlides;\n swiper.slideTo(index);\n });\n }\n\n Object.assign(swiper.pagination, {\n $el,\n el: $el[0]\n });\n\n if (!swiper.enabled) {\n $el.addClass(params.lockClass);\n }\n }\n\n function destroy() {\n const params = swiper.params.pagination;\n if (isPaginationDisabled()) return;\n const $el = swiper.pagination.$el;\n $el.removeClass(params.hiddenClass);\n $el.removeClass(params.modifierClass + params.type);\n $el.removeClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n if (swiper.pagination.bullets && swiper.pagination.bullets.removeClass) swiper.pagination.bullets.removeClass(params.bulletActiveClass);\n\n if (params.clickable) {\n $el.off('click', classesToSelector(params.bulletClass));\n }\n }\n\n on('init', () => {\n if (swiper.params.pagination.enabled === false) {\n // eslint-disable-next-line\n disable();\n } else {\n init();\n render();\n update();\n }\n });\n on('activeIndexChange', () => {\n if (swiper.params.loop) {\n update();\n } else if (typeof swiper.snapIndex === 'undefined') {\n update();\n }\n });\n on('snapIndexChange', () => {\n if (!swiper.params.loop) {\n update();\n }\n });\n on('slidesLengthChange', () => {\n if (swiper.params.loop) {\n render();\n update();\n }\n });\n on('snapGridLengthChange', () => {\n if (!swiper.params.loop) {\n render();\n update();\n }\n });\n on('destroy', () => {\n destroy();\n });\n on('enable disable', () => {\n const {\n $el\n } = swiper.pagination;\n\n if ($el) {\n $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.pagination.lockClass);\n }\n });\n on('lock unlock', () => {\n update();\n });\n on('click', (_s, e) => {\n const targetEl = e.target;\n const {\n $el\n } = swiper.pagination;\n\n if (swiper.params.pagination.el && swiper.params.pagination.hideOnClick && $el && $el.length > 0 && !$(targetEl).hasClass(swiper.params.pagination.bulletClass)) {\n if (swiper.navigation && (swiper.navigation.nextEl && targetEl === swiper.navigation.nextEl || swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl)) return;\n const isHidden = $el.hasClass(swiper.params.pagination.hiddenClass);\n\n if (isHidden === true) {\n emit('paginationShow');\n } else {\n emit('paginationHide');\n }\n\n $el.toggleClass(swiper.params.pagination.hiddenClass);\n }\n });\n\n const enable = () => {\n swiper.$el.removeClass(swiper.params.pagination.paginationDisabledClass);\n\n if (swiper.pagination.$el) {\n swiper.pagination.$el.removeClass(swiper.params.pagination.paginationDisabledClass);\n }\n\n init();\n render();\n update();\n };\n\n const disable = () => {\n swiper.$el.addClass(swiper.params.pagination.paginationDisabledClass);\n\n if (swiper.pagination.$el) {\n swiper.pagination.$el.addClass(swiper.params.pagination.paginationDisabledClass);\n }\n\n destroy();\n };\n\n Object.assign(swiper.pagination, {\n enable,\n disable,\n render,\n update,\n init,\n destroy\n });\n}","import { getDocument } from 'ssr-window';\nexport default function createElementIfNotDefined(swiper, originalParams, params, checkProps) {\n const document = getDocument();\n\n if (swiper.params.createElements) {\n Object.keys(checkProps).forEach(key => {\n if (!params[key] && params.auto === true) {\n let element = swiper.$el.children(`.${checkProps[key]}`)[0];\n\n if (!element) {\n element = document.createElement('div');\n element.className = checkProps[key];\n swiper.$el.append(element);\n }\n\n params[key] = element;\n originalParams[key] = element;\n }\n });\n }\n\n return params;\n}","import $ from './dom.js';\nexport default function createShadow(params, $slideEl, side) {\n const shadowClass = `swiper-slide-shadow${side ? `-${side}` : ''}`;\n const $shadowContainer = params.transformEl ? $slideEl.find(params.transformEl) : $slideEl;\n let $shadowEl = $shadowContainer.children(`.${shadowClass}`);\n\n if (!$shadowEl.length) {\n $shadowEl = $(`
    `);\n $shadowContainer.append($shadowEl);\n }\n\n return $shadowEl;\n}","export default function effectTarget(effectParams, $slideEl) {\n if (effectParams.transformEl) {\n return $slideEl.find(effectParams.transformEl).css({\n 'backface-visibility': 'hidden',\n '-webkit-backface-visibility': 'hidden'\n });\n }\n\n return $slideEl;\n}","import createShadow from '../../shared/create-shadow.js';\nimport effectInit from '../../shared/effect-init.js';\nimport effectTarget from '../../shared/effect-target.js';\nexport default function EffectCoverflow({\n swiper,\n extendParams,\n on\n}) {\n extendParams({\n coverflowEffect: {\n rotate: 50,\n stretch: 0,\n depth: 100,\n scale: 1,\n modifier: 1,\n slideShadows: true,\n transformEl: null\n }\n });\n\n const setTranslate = () => {\n const {\n width: swiperWidth,\n height: swiperHeight,\n slides,\n slidesSizesGrid\n } = swiper;\n const params = swiper.params.coverflowEffect;\n const isHorizontal = swiper.isHorizontal();\n const transform = swiper.translate;\n const center = isHorizontal ? -transform + swiperWidth / 2 : -transform + swiperHeight / 2;\n const rotate = isHorizontal ? params.rotate : -params.rotate;\n const translate = params.depth; // Each slide offset from center\n\n for (let i = 0, length = slides.length; i < length; i += 1) {\n const $slideEl = slides.eq(i);\n const slideSize = slidesSizesGrid[i];\n const slideOffset = $slideEl[0].swiperSlideOffset;\n const centerOffset = (center - slideOffset - slideSize / 2) / slideSize;\n const offsetMultiplier = typeof params.modifier === 'function' ? params.modifier(centerOffset) : centerOffset * params.modifier;\n let rotateY = isHorizontal ? rotate * offsetMultiplier : 0;\n let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier; // var rotateZ = 0\n\n let translateZ = -translate * Math.abs(offsetMultiplier);\n let stretch = params.stretch; // Allow percentage to make a relative stretch for responsive sliders\n\n if (typeof stretch === 'string' && stretch.indexOf('%') !== -1) {\n stretch = parseFloat(params.stretch) / 100 * slideSize;\n }\n\n let translateY = isHorizontal ? 0 : stretch * offsetMultiplier;\n let translateX = isHorizontal ? stretch * offsetMultiplier : 0;\n let scale = 1 - (1 - params.scale) * Math.abs(offsetMultiplier); // Fix for ultra small values\n\n if (Math.abs(translateX) < 0.001) translateX = 0;\n if (Math.abs(translateY) < 0.001) translateY = 0;\n if (Math.abs(translateZ) < 0.001) translateZ = 0;\n if (Math.abs(rotateY) < 0.001) rotateY = 0;\n if (Math.abs(rotateX) < 0.001) rotateX = 0;\n if (Math.abs(scale) < 0.001) scale = 0;\n const slideTransform = `translate3d(${translateX}px,${translateY}px,${translateZ}px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) scale(${scale})`;\n const $targetEl = effectTarget(params, $slideEl);\n $targetEl.transform(slideTransform);\n $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;\n\n if (params.slideShadows) {\n // Set shadows\n let $shadowBeforeEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');\n let $shadowAfterEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');\n\n if ($shadowBeforeEl.length === 0) {\n $shadowBeforeEl = createShadow(params, $slideEl, isHorizontal ? 'left' : 'top');\n }\n\n if ($shadowAfterEl.length === 0) {\n $shadowAfterEl = createShadow(params, $slideEl, isHorizontal ? 'right' : 'bottom');\n }\n\n if ($shadowBeforeEl.length) $shadowBeforeEl[0].style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;\n if ($shadowAfterEl.length) $shadowAfterEl[0].style.opacity = -offsetMultiplier > 0 ? -offsetMultiplier : 0;\n }\n }\n };\n\n const setTransition = duration => {\n const {\n transformEl\n } = swiper.params.coverflowEffect;\n const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;\n $transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);\n };\n\n effectInit({\n effect: 'coverflow',\n swiper,\n on,\n setTranslate,\n setTransition,\n perspective: () => true,\n overwriteParams: () => ({\n watchSlidesProgress: true\n })\n });\n}","export default function effectInit(params) {\n const {\n effect,\n swiper,\n on,\n setTranslate,\n setTransition,\n overwriteParams,\n perspective,\n recreateShadows,\n getEffectParams\n } = params;\n on('beforeInit', () => {\n if (swiper.params.effect !== effect) return;\n swiper.classNames.push(`${swiper.params.containerModifierClass}${effect}`);\n\n if (perspective && perspective()) {\n swiper.classNames.push(`${swiper.params.containerModifierClass}3d`);\n }\n\n const overwriteParamsResult = overwriteParams ? overwriteParams() : {};\n Object.assign(swiper.params, overwriteParamsResult);\n Object.assign(swiper.originalParams, overwriteParamsResult);\n });\n on('setTranslate', () => {\n if (swiper.params.effect !== effect) return;\n setTranslate();\n });\n on('setTransition', (_s, duration) => {\n if (swiper.params.effect !== effect) return;\n setTransition(duration);\n });\n on('transitionEnd', () => {\n if (swiper.params.effect !== effect) return;\n\n if (recreateShadows) {\n if (!getEffectParams || !getEffectParams().slideShadows) return; // remove shadows\n\n swiper.slides.each(slideEl => {\n const $slideEl = swiper.$(slideEl);\n $slideEl.find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').remove();\n }); // create new one\n\n recreateShadows();\n }\n });\n let requireUpdateOnVirtual;\n on('virtualUpdate', () => {\n if (swiper.params.effect !== effect) return;\n\n if (!swiper.slides.length) {\n requireUpdateOnVirtual = true;\n }\n\n requestAnimationFrame(() => {\n if (requireUpdateOnVirtual && swiper.slides && swiper.slides.length) {\n setTranslate();\n requireUpdateOnVirtual = false;\n }\n });\n });\n}","function isObject(o) {\n return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';\n}\n\nfunction extend(target, src) {\n const noExtend = ['__proto__', 'constructor', 'prototype'];\n Object.keys(src).filter(key => noExtend.indexOf(key) < 0).forEach(key => {\n if (typeof target[key] === 'undefined') target[key] = src[key];else if (isObject(src[key]) && isObject(target[key]) && Object.keys(src[key]).length > 0) {\n if (src[key].__swiper__) target[key] = src[key];else extend(target[key], src[key]);\n } else {\n target[key] = src[key];\n }\n });\n}\n\nfunction needsNavigation(params = {}) {\n return params.navigation && typeof params.navigation.nextEl === 'undefined' && typeof params.navigation.prevEl === 'undefined';\n}\n\nfunction needsPagination(params = {}) {\n return params.pagination && typeof params.pagination.el === 'undefined';\n}\n\nfunction needsScrollbar(params = {}) {\n return params.scrollbar && typeof params.scrollbar.el === 'undefined';\n}\n\nfunction uniqueClasses(classNames = '') {\n const classes = classNames.split(' ').map(c => c.trim()).filter(c => !!c);\n const unique = [];\n classes.forEach(c => {\n if (unique.indexOf(c) < 0) unique.push(c);\n });\n return unique.join(' ');\n}\n\nexport { isObject, extend, needsNavigation, needsPagination, needsScrollbar, uniqueClasses };","/* underscore in name -> watch for changes */\nconst paramsList = ['modules', 'init', '_direction', 'touchEventsTarget', 'initialSlide', '_speed', 'cssMode', 'updateOnWindowResize', 'resizeObserver', 'nested', 'focusableElements', '_enabled', '_width', '_height', 'preventInteractionOnTransition', 'userAgent', 'url', '_edgeSwipeDetection', '_edgeSwipeThreshold', '_freeMode', '_autoHeight', 'setWrapperSize', 'virtualTranslate', '_effect', 'breakpoints', '_spaceBetween', '_slidesPerView', 'maxBackfaceHiddenSlides', '_grid', '_slidesPerGroup', '_slidesPerGroupSkip', '_slidesPerGroupAuto', '_centeredSlides', '_centeredSlidesBounds', '_slidesOffsetBefore', '_slidesOffsetAfter', 'normalizeSlideIndex', '_centerInsufficientSlides', '_watchOverflow', 'roundLengths', 'touchRatio', 'touchAngle', 'simulateTouch', '_shortSwipes', '_longSwipes', 'longSwipesRatio', 'longSwipesMs', '_followFinger', 'allowTouchMove', '_threshold', 'touchMoveStopPropagation', 'touchStartPreventDefault', 'touchStartForcePreventDefault', 'touchReleaseOnEdges', 'uniqueNavElements', '_resistance', '_resistanceRatio', '_watchSlidesProgress', '_grabCursor', 'preventClicks', 'preventClicksPropagation', '_slideToClickedSlide', '_preloadImages', 'updateOnImagesReady', '_loop', '_loopAdditionalSlides', '_loopedSlides', '_loopedSlidesLimit', '_loopFillGroupWithBlank', 'loopPreventsSlide', '_rewind', '_allowSlidePrev', '_allowSlideNext', '_swipeHandler', '_noSwiping', 'noSwipingClass', 'noSwipingSelector', 'passiveListeners', 'containerModifierClass', 'slideClass', 'slideBlankClass', 'slideActiveClass', 'slideDuplicateActiveClass', 'slideVisibleClass', 'slideDuplicateClass', 'slideNextClass', 'slideDuplicateNextClass', 'slidePrevClass', 'slideDuplicatePrevClass', 'wrapperClass', 'runCallbacksOnInit', 'observer', 'observeParents', 'observeSlideChildren', // modules\n'a11y', '_autoplay', '_controller', 'coverflowEffect', 'cubeEffect', 'fadeEffect', 'flipEffect', 'creativeEffect', 'cardsEffect', 'hashNavigation', 'history', 'keyboard', 'lazy', 'mousewheel', '_navigation', '_pagination', 'parallax', '_scrollbar', '_thumbs', 'virtual', 'zoom'];\nexport { paramsList };","import Swiper from 'swiper';\nexport const calcLoopedSlides = (slides, swiperParams) => {\n let slidesPerViewParams = swiperParams.slidesPerView;\n\n if (swiperParams.breakpoints) {\n const breakpoint = Swiper.prototype.getBreakpoint(swiperParams.breakpoints);\n const breakpointOnlyParams = breakpoint in swiperParams.breakpoints ? swiperParams.breakpoints[breakpoint] : undefined;\n\n if (breakpointOnlyParams && breakpointOnlyParams.slidesPerView) {\n slidesPerViewParams = breakpointOnlyParams.slidesPerView;\n }\n }\n\n let loopedSlides = Math.ceil(parseFloat(swiperParams.loopedSlides || slidesPerViewParams, 10));\n loopedSlides += swiperParams.loopAdditionalSlides;\n\n if (loopedSlides > slides.length && swiperParams.loopedSlidesLimit) {\n loopedSlides = slides.length;\n }\n\n return loopedSlides;\n};","import React from 'react';\n\nfunction isChildSwiperSlide(child) {\n return child.type && child.type.displayName && child.type.displayName.includes('SwiperSlide');\n}\n\nfunction processChildren(c) {\n const slides = [];\n React.Children.toArray(c).forEach(child => {\n if (isChildSwiperSlide(child)) {\n slides.push(child);\n } else if (child.props && child.props.children) {\n processChildren(child.props.children).forEach(slide => slides.push(slide));\n }\n });\n return slides;\n}\n\nfunction getChildren(c) {\n const slides = [];\n const slots = {\n 'container-start': [],\n 'container-end': [],\n 'wrapper-start': [],\n 'wrapper-end': []\n };\n React.Children.toArray(c).forEach(child => {\n if (isChildSwiperSlide(child)) {\n slides.push(child);\n } else if (child.props && child.props.slot && slots[child.props.slot]) {\n slots[child.props.slot].push(child);\n } else if (child.props && child.props.children) {\n const foundSlides = processChildren(child.props.children);\n\n if (foundSlides.length > 0) {\n foundSlides.forEach(slide => slides.push(slide));\n } else {\n slots['container-end'].push(child);\n }\n } else {\n slots['container-end'].push(child);\n }\n });\n return {\n slides,\n slots\n };\n}\n\nexport { getChildren };","import { isObject, extend } from './utils.js';\n\nfunction updateSwiper({\n swiper,\n slides,\n passedParams,\n changedParams,\n nextEl,\n prevEl,\n scrollbarEl,\n paginationEl\n}) {\n const updateParams = changedParams.filter(key => key !== 'children' && key !== 'direction');\n const {\n params: currentParams,\n pagination,\n navigation,\n scrollbar,\n virtual,\n thumbs\n } = swiper;\n let needThumbsInit;\n let needControllerInit;\n let needPaginationInit;\n let needScrollbarInit;\n let needNavigationInit;\n\n if (changedParams.includes('thumbs') && passedParams.thumbs && passedParams.thumbs.swiper && currentParams.thumbs && !currentParams.thumbs.swiper) {\n needThumbsInit = true;\n }\n\n if (changedParams.includes('controller') && passedParams.controller && passedParams.controller.control && currentParams.controller && !currentParams.controller.control) {\n needControllerInit = true;\n }\n\n if (changedParams.includes('pagination') && passedParams.pagination && (passedParams.pagination.el || paginationEl) && (currentParams.pagination || currentParams.pagination === false) && pagination && !pagination.el) {\n needPaginationInit = true;\n }\n\n if (changedParams.includes('scrollbar') && passedParams.scrollbar && (passedParams.scrollbar.el || scrollbarEl) && (currentParams.scrollbar || currentParams.scrollbar === false) && scrollbar && !scrollbar.el) {\n needScrollbarInit = true;\n }\n\n if (changedParams.includes('navigation') && passedParams.navigation && (passedParams.navigation.prevEl || prevEl) && (passedParams.navigation.nextEl || nextEl) && (currentParams.navigation || currentParams.navigation === false) && navigation && !navigation.prevEl && !navigation.nextEl) {\n needNavigationInit = true;\n }\n\n const destroyModule = mod => {\n if (!swiper[mod]) return;\n swiper[mod].destroy();\n\n if (mod === 'navigation') {\n currentParams[mod].prevEl = undefined;\n currentParams[mod].nextEl = undefined;\n swiper[mod].prevEl = undefined;\n swiper[mod].nextEl = undefined;\n } else {\n currentParams[mod].el = undefined;\n swiper[mod].el = undefined;\n }\n };\n\n updateParams.forEach(key => {\n if (isObject(currentParams[key]) && isObject(passedParams[key])) {\n extend(currentParams[key], passedParams[key]);\n } else {\n const newValue = passedParams[key];\n\n if ((newValue === true || newValue === false) && (key === 'navigation' || key === 'pagination' || key === 'scrollbar')) {\n if (newValue === false) {\n destroyModule(key);\n }\n } else {\n currentParams[key] = passedParams[key];\n }\n }\n });\n\n if (updateParams.includes('controller') && !needControllerInit && swiper.controller && swiper.controller.control && currentParams.controller && currentParams.controller.control) {\n swiper.controller.control = currentParams.controller.control;\n }\n\n if (changedParams.includes('children') && slides && virtual && currentParams.virtual.enabled) {\n virtual.slides = slides;\n virtual.update(true);\n } else if (changedParams.includes('children') && swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n\n if (needThumbsInit) {\n const initialized = thumbs.init();\n if (initialized) thumbs.update(true);\n }\n\n if (needControllerInit) {\n swiper.controller.control = currentParams.controller.control;\n }\n\n if (needPaginationInit) {\n if (paginationEl) currentParams.pagination.el = paginationEl;\n pagination.init();\n pagination.render();\n pagination.update();\n }\n\n if (needScrollbarInit) {\n if (scrollbarEl) currentParams.scrollbar.el = scrollbarEl;\n scrollbar.init();\n scrollbar.updateSize();\n scrollbar.setTranslate();\n }\n\n if (needNavigationInit) {\n if (nextEl) currentParams.navigation.nextEl = nextEl;\n if (prevEl) currentParams.navigation.prevEl = prevEl;\n navigation.init();\n navigation.update();\n }\n\n if (changedParams.includes('allowSlideNext')) {\n swiper.allowSlideNext = passedParams.allowSlideNext;\n }\n\n if (changedParams.includes('allowSlidePrev')) {\n swiper.allowSlidePrev = passedParams.allowSlidePrev;\n }\n\n if (changedParams.includes('direction')) {\n swiper.changeDirection(passedParams.direction, false);\n }\n\n swiper.update();\n}\n\nexport { updateSwiper };","import { useEffect, useLayoutEffect } from 'react';\n\nfunction useIsomorphicLayoutEffect(callback, deps) {\n // eslint-disable-next-line\n if (typeof window === 'undefined') return useEffect(callback, deps);\n return useLayoutEffect(callback, deps);\n}\n\nexport { useIsomorphicLayoutEffect };","import { createContext, useContext } from 'react';\nexport const SwiperSlideContext = /*#__PURE__*/createContext(null);\nexport const useSwiperSlide = () => {\n return useContext(SwiperSlideContext);\n};\nexport const SwiperContext = /*#__PURE__*/createContext(null);\nexport const useSwiper = () => {\n return useContext(SwiperContext);\n};","function _extends() { _extends = Object.assign ? Object.assign.bind() : 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; }; return _extends.apply(this, arguments); }\n\nimport React, { useRef, useState, useEffect, forwardRef } from 'react';\nimport SwiperCore from 'swiper';\nimport { getParams } from '../components-shared/get-params.js';\nimport { mountSwiper } from '../components-shared/mount-swiper.js';\nimport { needsScrollbar, needsNavigation, needsPagination, uniqueClasses, extend } from '../components-shared/utils.js';\nimport { renderLoop, calcLoopedSlides } from './loop.js';\nimport { getChangedParams } from '../components-shared/get-changed-params.js';\nimport { getChildren } from './get-children.js';\nimport { updateSwiper } from '../components-shared/update-swiper.js';\nimport { renderVirtual } from './virtual.js';\nimport { updateOnVirtualData } from '../components-shared/update-on-virtual-data.js';\nimport { useIsomorphicLayoutEffect } from './use-isomorphic-layout-effect.js';\nimport { SwiperContext } from './context.js';\nconst Swiper = /*#__PURE__*/forwardRef(function (_temp, externalElRef) {\n let {\n className,\n tag: Tag = 'div',\n wrapperTag: WrapperTag = 'div',\n children,\n onSwiper,\n ...rest\n } = _temp === void 0 ? {} : _temp;\n let eventsAssigned = false;\n const [containerClasses, setContainerClasses] = useState('swiper');\n const [virtualData, setVirtualData] = useState(null);\n const [breakpointChanged, setBreakpointChanged] = useState(false);\n const initializedRef = useRef(false);\n const swiperElRef = useRef(null);\n const swiperRef = useRef(null);\n const oldPassedParamsRef = useRef(null);\n const oldSlides = useRef(null);\n const nextElRef = useRef(null);\n const prevElRef = useRef(null);\n const paginationElRef = useRef(null);\n const scrollbarElRef = useRef(null);\n const {\n params: swiperParams,\n passedParams,\n rest: restProps,\n events\n } = getParams(rest);\n const {\n slides,\n slots\n } = getChildren(children);\n\n const onBeforeBreakpoint = () => {\n setBreakpointChanged(!breakpointChanged);\n };\n\n Object.assign(swiperParams.on, {\n _containerClasses(swiper, classes) {\n setContainerClasses(classes);\n }\n\n });\n\n const initSwiper = () => {\n // init swiper\n Object.assign(swiperParams.on, events);\n eventsAssigned = true;\n swiperRef.current = new SwiperCore(swiperParams);\n\n swiperRef.current.loopCreate = () => {};\n\n swiperRef.current.loopDestroy = () => {};\n\n if (swiperParams.loop) {\n swiperRef.current.loopedSlides = calcLoopedSlides(slides, swiperParams);\n }\n\n if (swiperRef.current.virtual && swiperRef.current.params.virtual.enabled) {\n swiperRef.current.virtual.slides = slides;\n const extendWith = {\n cache: false,\n slides,\n renderExternal: setVirtualData,\n renderExternalUpdate: false\n };\n extend(swiperRef.current.params.virtual, extendWith);\n extend(swiperRef.current.originalParams.virtual, extendWith);\n }\n };\n\n if (!swiperElRef.current) {\n initSwiper();\n } // Listen for breakpoints change\n\n\n if (swiperRef.current) {\n swiperRef.current.on('_beforeBreakpoint', onBeforeBreakpoint);\n }\n\n const attachEvents = () => {\n if (eventsAssigned || !events || !swiperRef.current) return;\n Object.keys(events).forEach(eventName => {\n swiperRef.current.on(eventName, events[eventName]);\n });\n };\n\n const detachEvents = () => {\n if (!events || !swiperRef.current) return;\n Object.keys(events).forEach(eventName => {\n swiperRef.current.off(eventName, events[eventName]);\n });\n };\n\n useEffect(() => {\n return () => {\n if (swiperRef.current) swiperRef.current.off('_beforeBreakpoint', onBeforeBreakpoint);\n };\n }); // set initialized flag\n\n useEffect(() => {\n if (!initializedRef.current && swiperRef.current) {\n swiperRef.current.emitSlidesClasses();\n initializedRef.current = true;\n }\n }); // mount swiper\n\n useIsomorphicLayoutEffect(() => {\n if (externalElRef) {\n externalElRef.current = swiperElRef.current;\n }\n\n if (!swiperElRef.current) return;\n\n if (swiperRef.current.destroyed) {\n initSwiper();\n }\n\n mountSwiper({\n el: swiperElRef.current,\n nextEl: nextElRef.current,\n prevEl: prevElRef.current,\n paginationEl: paginationElRef.current,\n scrollbarEl: scrollbarElRef.current,\n swiper: swiperRef.current\n }, swiperParams);\n if (onSwiper) onSwiper(swiperRef.current); // eslint-disable-next-line\n\n return () => {\n if (swiperRef.current && !swiperRef.current.destroyed) {\n swiperRef.current.destroy(true, false);\n }\n };\n }, []); // watch for params change\n\n useIsomorphicLayoutEffect(() => {\n attachEvents();\n const changedParams = getChangedParams(passedParams, oldPassedParamsRef.current, slides, oldSlides.current, c => c.key);\n oldPassedParamsRef.current = passedParams;\n oldSlides.current = slides;\n\n if (changedParams.length && swiperRef.current && !swiperRef.current.destroyed) {\n updateSwiper({\n swiper: swiperRef.current,\n slides,\n passedParams,\n changedParams,\n nextEl: nextElRef.current,\n prevEl: prevElRef.current,\n scrollbarEl: scrollbarElRef.current,\n paginationEl: paginationElRef.current\n });\n }\n\n return () => {\n detachEvents();\n };\n }); // update on virtual update\n\n useIsomorphicLayoutEffect(() => {\n updateOnVirtualData(swiperRef.current);\n }, [virtualData]); // bypass swiper instance to slides\n\n function renderSlides() {\n if (swiperParams.virtual) {\n return renderVirtual(swiperRef.current, slides, virtualData);\n }\n\n if (!swiperParams.loop || swiperRef.current && swiperRef.current.destroyed) {\n return slides.map(child => {\n return /*#__PURE__*/React.cloneElement(child, {\n swiper: swiperRef.current\n });\n });\n }\n\n return renderLoop(swiperRef.current, slides, swiperParams);\n }\n\n return /*#__PURE__*/React.createElement(Tag, _extends({\n ref: swiperElRef,\n className: uniqueClasses(`${containerClasses}${className ? ` ${className}` : ''}`)\n }, restProps), /*#__PURE__*/React.createElement(SwiperContext.Provider, {\n value: swiperRef.current\n }, slots['container-start'], /*#__PURE__*/React.createElement(WrapperTag, {\n className: \"swiper-wrapper\"\n }, slots['wrapper-start'], renderSlides(), slots['wrapper-end']), needsNavigation(swiperParams) && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(\"div\", {\n ref: prevElRef,\n className: \"swiper-button-prev\"\n }), /*#__PURE__*/React.createElement(\"div\", {\n ref: nextElRef,\n className: \"swiper-button-next\"\n })), needsScrollbar(swiperParams) && /*#__PURE__*/React.createElement(\"div\", {\n ref: scrollbarElRef,\n className: \"swiper-scrollbar\"\n }), needsPagination(swiperParams) && /*#__PURE__*/React.createElement(\"div\", {\n ref: paginationElRef,\n className: \"swiper-pagination\"\n }), slots['container-end']));\n});\nSwiper.displayName = 'Swiper';\nexport { Swiper };","import Swiper from 'swiper';\nimport { isObject, extend } from './utils.js';\nimport { paramsList } from './params-list.js';\n\nfunction getParams(obj = {}, splitEvents = true) {\n const params = {\n on: {}\n };\n const events = {};\n const passedParams = {};\n extend(params, Swiper.defaults);\n extend(params, Swiper.extendedDefaults);\n params._emitClasses = true;\n params.init = false;\n const rest = {};\n const allowedParams = paramsList.map(key => key.replace(/_/, ''));\n const plainObj = Object.assign({}, obj);\n Object.keys(plainObj).forEach(key => {\n if (typeof obj[key] === 'undefined') return;\n\n if (allowedParams.indexOf(key) >= 0) {\n if (isObject(obj[key])) {\n params[key] = {};\n passedParams[key] = {};\n extend(params[key], obj[key]);\n extend(passedParams[key], obj[key]);\n } else {\n params[key] = obj[key];\n passedParams[key] = obj[key];\n }\n } else if (key.search(/on[A-Z]/) === 0 && typeof obj[key] === 'function') {\n if (splitEvents) {\n events[`${key[2].toLowerCase()}${key.substr(3)}`] = obj[key];\n } else {\n params.on[`${key[2].toLowerCase()}${key.substr(3)}`] = obj[key];\n }\n } else {\n rest[key] = obj[key];\n }\n });\n ['navigation', 'pagination', 'scrollbar'].forEach(key => {\n if (params[key] === true) params[key] = {};\n if (params[key] === false) delete params[key];\n });\n return {\n params,\n passedParams,\n rest,\n events\n };\n}\n\nexport { getParams };","import { needsNavigation, needsPagination, needsScrollbar } from './utils.js';\n\nfunction mountSwiper({\n el,\n nextEl,\n prevEl,\n paginationEl,\n scrollbarEl,\n swiper\n}, swiperParams) {\n if (needsNavigation(swiperParams) && nextEl && prevEl) {\n swiper.params.navigation.nextEl = nextEl;\n swiper.originalParams.navigation.nextEl = nextEl;\n swiper.params.navigation.prevEl = prevEl;\n swiper.originalParams.navigation.prevEl = prevEl;\n }\n\n if (needsPagination(swiperParams) && paginationEl) {\n swiper.params.pagination.el = paginationEl;\n swiper.originalParams.pagination.el = paginationEl;\n }\n\n if (needsScrollbar(swiperParams) && scrollbarEl) {\n swiper.params.scrollbar.el = scrollbarEl;\n swiper.originalParams.scrollbar.el = scrollbarEl;\n }\n\n swiper.init(el);\n}\n\nexport { mountSwiper };","import { paramsList } from './params-list.js';\nimport { isObject } from './utils.js';\n\nfunction getChangedParams(swiperParams, oldParams, children, oldChildren, getKey) {\n const keys = [];\n if (!oldParams) return keys;\n\n const addKey = key => {\n if (keys.indexOf(key) < 0) keys.push(key);\n };\n\n if (children && oldChildren) {\n const oldChildrenKeys = oldChildren.map(getKey);\n const childrenKeys = children.map(getKey);\n if (oldChildrenKeys.join('') !== childrenKeys.join('')) addKey('children');\n if (oldChildren.length !== children.length) addKey('children');\n }\n\n const watchParams = paramsList.filter(key => key[0] === '_').map(key => key.replace(/_/, ''));\n watchParams.forEach(key => {\n if (key in swiperParams && key in oldParams) {\n if (isObject(swiperParams[key]) && isObject(oldParams[key])) {\n const newKeys = Object.keys(swiperParams[key]);\n const oldKeys = Object.keys(oldParams[key]);\n\n if (newKeys.length !== oldKeys.length) {\n addKey(key);\n } else {\n newKeys.forEach(newKey => {\n if (swiperParams[key][newKey] !== oldParams[key][newKey]) {\n addKey(key);\n }\n });\n oldKeys.forEach(oldKey => {\n if (swiperParams[key][oldKey] !== oldParams[key][oldKey]) addKey(key);\n });\n }\n } else if (swiperParams[key] !== oldParams[key]) {\n addKey(key);\n }\n }\n });\n return keys;\n}\n\nexport { getChangedParams };","export const updateOnVirtualData = swiper => {\n if (!swiper || swiper.destroyed || !swiper.params.virtual || swiper.params.virtual && !swiper.params.virtual.enabled) return;\n swiper.updateSlides();\n swiper.updateProgress();\n swiper.updateSlidesClasses();\n\n if (swiper.lazy && swiper.params.lazy.enabled) {\n swiper.lazy.load();\n }\n\n if (swiper.parallax && swiper.params.parallax && swiper.params.parallax.enabled) {\n swiper.parallax.setTranslate();\n }\n};","import React from 'react';\n\nfunction renderVirtual(swiper, slides, virtualData) {\n if (!virtualData) return null;\n const style = swiper.isHorizontal() ? {\n [swiper.rtlTranslate ? 'right' : 'left']: `${virtualData.offset}px`\n } : {\n top: `${virtualData.offset}px`\n };\n return slides.filter((child, index) => index >= virtualData.from && index <= virtualData.to).map(child => {\n return /*#__PURE__*/React.cloneElement(child, {\n swiper,\n style\n });\n });\n}\n\nexport { renderVirtual };","import React from 'react';\nimport { calcLoopedSlides } from '../shared/calc-looped-slides.js';\n\nfunction renderLoop(swiper, slides, swiperParams) {\n const modifiedSlides = slides.map((child, index) => {\n return /*#__PURE__*/React.cloneElement(child, {\n swiper,\n 'data-swiper-slide-index': index\n });\n });\n\n function duplicateSlide(child, index, position) {\n return /*#__PURE__*/React.cloneElement(child, {\n key: `${child.key}-duplicate-${index}-${position}`,\n className: `${child.props.className || ''} ${swiperParams.slideDuplicateClass}`\n });\n }\n\n if (swiperParams.loopFillGroupWithBlank) {\n const blankSlidesNum = swiperParams.slidesPerGroup - modifiedSlides.length % swiperParams.slidesPerGroup;\n\n if (blankSlidesNum !== swiperParams.slidesPerGroup) {\n for (let i = 0; i < blankSlidesNum; i += 1) {\n const blankSlide = /*#__PURE__*/React.createElement(\"div\", {\n className: `${swiperParams.slideClass} ${swiperParams.slideBlankClass}`\n });\n modifiedSlides.push(blankSlide);\n }\n }\n }\n\n if (swiperParams.slidesPerView === 'auto' && !swiperParams.loopedSlides) {\n swiperParams.loopedSlides = modifiedSlides.length;\n }\n\n const loopedSlides = calcLoopedSlides(modifiedSlides, swiperParams);\n const prependSlides = [];\n const appendSlides = [];\n\n for (let i = 0; i < loopedSlides; i += 1) {\n const index = i - Math.floor(i / modifiedSlides.length) * modifiedSlides.length;\n appendSlides.push(duplicateSlide(modifiedSlides[index], i, 'append'));\n prependSlides.unshift(duplicateSlide(modifiedSlides[modifiedSlides.length - index - 1], i, 'prepend'));\n }\n\n if (swiper) {\n swiper.loopedSlides = loopedSlides;\n }\n\n return [...prependSlides, ...modifiedSlides, ...appendSlides];\n}\n\nexport { calcLoopedSlides, renderLoop };","function _extends() { _extends = Object.assign ? Object.assign.bind() : 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; }; return _extends.apply(this, arguments); }\n\nimport React, { useRef, useState, forwardRef } from 'react';\nimport { uniqueClasses } from '../components-shared/utils.js';\nimport { useIsomorphicLayoutEffect } from './use-isomorphic-layout-effect.js';\nimport { SwiperSlideContext } from './context.js';\nconst SwiperSlide = /*#__PURE__*/forwardRef(function (_temp, externalRef) {\n let {\n tag: Tag = 'div',\n children,\n className = '',\n swiper,\n zoom,\n virtualIndex,\n ...rest\n } = _temp === void 0 ? {} : _temp;\n const slideElRef = useRef(null);\n const [slideClasses, setSlideClasses] = useState('swiper-slide');\n\n function updateClasses(_s, el, classNames) {\n if (el === slideElRef.current) {\n setSlideClasses(classNames);\n }\n }\n\n useIsomorphicLayoutEffect(() => {\n if (externalRef) {\n externalRef.current = slideElRef.current;\n }\n\n if (!slideElRef.current || !swiper) {\n return;\n }\n\n if (swiper.destroyed) {\n if (slideClasses !== 'swiper-slide') {\n setSlideClasses('swiper-slide');\n }\n\n return;\n }\n\n swiper.on('_slideClass', updateClasses); // eslint-disable-next-line\n\n return () => {\n if (!swiper) return;\n swiper.off('_slideClass', updateClasses);\n };\n });\n useIsomorphicLayoutEffect(() => {\n if (swiper && slideElRef.current && !swiper.destroyed) {\n setSlideClasses(swiper.getSlideClasses(slideElRef.current));\n }\n }, [swiper]);\n const slideData = {\n isActive: slideClasses.indexOf('swiper-slide-active') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-active') >= 0,\n isVisible: slideClasses.indexOf('swiper-slide-visible') >= 0,\n isDuplicate: slideClasses.indexOf('swiper-slide-duplicate') >= 0,\n isPrev: slideClasses.indexOf('swiper-slide-prev') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-prev') >= 0,\n isNext: slideClasses.indexOf('swiper-slide-next') >= 0 || slideClasses.indexOf('swiper-slide-duplicate-next') >= 0\n };\n\n const renderChildren = () => {\n return typeof children === 'function' ? children(slideData) : children;\n };\n\n return /*#__PURE__*/React.createElement(Tag, _extends({\n ref: slideElRef,\n className: uniqueClasses(`${slideClasses}${className ? ` ${className}` : ''}`),\n \"data-swiper-slide-index\": virtualIndex\n }, rest), /*#__PURE__*/React.createElement(SwiperSlideContext.Provider, {\n value: slideData\n }, zoom ? /*#__PURE__*/React.createElement(\"div\", {\n className: \"swiper-zoom-container\",\n \"data-swiper-zoom\": typeof zoom === 'number' ? zoom : undefined\n }, renderChildren()) : renderChildren()));\n});\nSwiperSlide.displayName = 'SwiperSlide';\nexport { SwiperSlide };","import \"../Kiosk.css\";\ninterface IProps {\n focused: boolean;\n}\n\nexport const DeleteButton: React.FC = ({ focused }) => {\n const specificButtonClass = focused ? \"deleteSelected\" : \"buttonUnselected\";\n\n return (\n
    \n \n

    Delete Game

    \n
    \n )\n}\n","import { HighScore } from \"../Models/HighScore\";\n\ninterface IProps {\n highScores: HighScore[];\n highScoreMode: string;\n }\n\nconst HighScoresList: React.FC = ({ highScores, highScoreMode }) => {\n const highScoresExist = !!highScores.length;\n\n if (highScoreMode === \"None\") {\n return null;\n }\n\n return (\n
    \n

    High Scores

    \n {\n !highScoresExist && \n

    None yet

    \n }\n {\n highScoresExist &&\n
      \n {\n highScores.slice(0, 5).map((highScore, index) => {\n return (\n
    1. \n {highScore.initials}\n {highScore.score}\n
    2. \n ) \n }\n\n )\n }\n
    \n }\n\n
    \n );\n}\n \nexport default HighScoresList;","import { useEffect, useState } from \"react\";\nimport { GameData } from \"../Models/GameData\";\nimport { HighScore } from \"../Models/HighScore\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport { DeleteButton } from \"./DeleteButton\";\nimport HighScoresList from \"./HighScoresList\";\ninterface IProps {\n highScores: HighScore[];\n addButtonSelected: boolean;\n deleteButtonSelected: boolean;\n game: GameData;\n}\nconst GameSlide: React.FC = (\n { highScores,\n addButtonSelected,\n deleteButtonSelected,\n game,\n }) => {\n const buttonSelected = addButtonSelected || deleteButtonSelected;\n const carouselSelected = buttonSelected ? \"unselected\" : \"selected\";\n\n return (\n
    \n
    \n\n

    Press A to Start

    \n\n
    \n
    {game.name}
    \n
    {game.description}
    \n \n {\n game.date &&\n
    \n Added {game.date}\n
    \n }\n { game.userAdded &&\n \n }\n
    \n
    \n )\n}\n\nexport default GameSlide;\n","import React, { useEffect, useRef, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport { KioskState } from \"../Models/KioskState\";\nimport configData from \"../config.json\"\nimport \"../Kiosk.css\";\nimport { Swiper, SwiperSlide } from 'swiper/react';\nimport { EffectCoverflow, Keyboard, Navigation, Pagination } from \"swiper\";\nimport \"swiper/css\";\nimport \"swiper/css/keyboard\";\nimport GameSlide from \"./GameSlide\";\nimport { tickEvent } from \"../browserUtils\";\ninterface IProps {\n kiosk: Kiosk;\n addButtonSelected: boolean;\n deleteButtonSelected: boolean;\n }\n\n\nconst GameList: React.FC = ({ kiosk, addButtonSelected, deleteButtonSelected }) => {\n const [games, setGames] = useState(kiosk.games);\n const buttonSelected = addButtonSelected || deleteButtonSelected;\n const localSwiper = useRef();\n\n const leftKeyEvent = (eventType: string) => {\n return new KeyboardEvent(eventType, {\n \"key\": \"ArrowLeft\",\n \"code\": \"ArrowLeft\",\n \"composed\": true,\n \"keyCode\": 37,\n \"cancelable\": true,\n \"view\": window\n });\n }\n\n const rightKeyEvent = (eventType: string) => {\n return new KeyboardEvent(eventType, {\n \"key\": \"ArrowRight\",\n \"code\": \"ArrowRight\",\n \"composed\": true,\n \"keyCode\": 39,\n \"cancelable\": true,\n \"view\": window\n });\n }\n\n const getGameIndex = () => {\n let gameIndex = (localSwiper.current.activeIndex - 2) % games.length;\n if (gameIndex < 0) {\n gameIndex = games.length - 1;\n }\n return gameIndex;\n }\n\n const changeFocusedItem = () => {\n const gameIndex = getGameIndex();\n kiosk.selectGame(gameIndex);\n }\n\n const clickItem = () => {\n const localSwiperIndex = getGameIndex();\n if (localSwiperIndex !== kiosk.selectedGameIndex) {\n kiosk.selectGame(localSwiperIndex);\n }\n\n const gameId = kiosk.selectedGame?.id;\n if (gameId) {\n tickEvent(\"kiosk.gameLaunched\", { game: gameId });\n kiosk.launchGame(gameId);\n }\n }\n \n const updateLoop = () => {\n if (kiosk.state !== KioskState.MainMenu) {\n return;\n }\n\n if (kiosk.gamepadManager.isAButtonPressed()) {\n clickItem();\n }\n\n if (kiosk.gamepadManager.isLeftPressed()) {\n document.dispatchEvent(leftKeyEvent(\"keydown\"));\n document.dispatchEvent(leftKeyEvent(\"keyup\"));\n changeFocusedItem();\n }\n\n if (kiosk.gamepadManager.isRightPressed()) {\n document.dispatchEvent(rightKeyEvent(\"keydown\"));\n document.dispatchEvent(rightKeyEvent(\"keyup\"));\n changeFocusedItem();\n }\n }\n\n // on page load use effect\n useEffect(() => {\n kiosk.initialize().then(() => {\n setGames(kiosk.games);\n\n if (!kiosk.selectedGame && kiosk.games.length) {\n kiosk.selectGame(0);\n }\n\n if (kiosk.selectedGameIndex) {\n localSwiper.current.slideTo(kiosk.selectedGameIndex + 2);\n }\n })\n }, []);\n\n // poll for game pad input\n useEffect(() => {\n let intervalId: any = null;\n if (games.length) {\n intervalId = setInterval(() => {\n if (!buttonSelected) {\n updateLoop();\n }\n }, configData.GamepadPollLoopMilli);\n }\n \n return () => {\n if (intervalId) {\n clearInterval(intervalId);\n }\n };\n }, [games, buttonSelected]);\n\n if (!kiosk.games || !kiosk.games.length) {\n return(\n
    \n

    Currently no kiosk games

    \n
    );\n }\n\n return(\n
    \n {\n localSwiper.current = swiper;\n }}\n coverflowEffect={{\n scale: 0.75,\n depth: 5,\n }}\n allowTouchMove={false}\n allowSlideNext={!buttonSelected}\n allowSlidePrev={!buttonSelected}\n modules={[EffectCoverflow, Keyboard, Pagination]}\n keyboard={{enabled: true}}\n >\n {kiosk.games.map((game, index) => {\n const gameHighScores = kiosk.getHighScores(game.id);\n return (\n \n \n \n )\n })}\n \n
    \n )\n}\n \nexport default GameList;","import { useEffect, useState } from \"react\";\nimport { tickEvent } from \"../browserUtils\";\nimport \"../Kiosk.css\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport configData from \"../config.json\";\n\ninterface IProps {\n kiosk: Kiosk;\n active: (p: boolean) => void;\n changeFocus: (p: boolean) => void;\n}\nconst DeletionModal: React.FC = ({ kiosk, active, changeFocus }) => {\n const [cancelButtonState, setCancelButtonState] = useState(true);\n const [confirmButtonState, setConfirmButtonState] = useState(false);\n const addedGamesLocalStorageKey: string = \"UserAddedGames\";\n\n const deleteGame = () => {\n const userAddedGames = kiosk.getAllAddedGames();\n const gameId = kiosk.selectedGame?.id!;\n if (gameId in userAddedGames) {\n userAddedGames[gameId].deleted = true;\n localStorage.setItem(addedGamesLocalStorageKey, JSON.stringify(userAddedGames));\n kiosk.games.splice(kiosk.selectedGameIndex!, 1);\n }\n }\n\n const cancelClicked = () => {\n active(false);\n changeFocus(false);\n }\n\n const confirmClicked = () => {\n deleteGame();\n cancelClicked();\n }\n\n const updateLoop = () => {\n if (kiosk.gamepadManager.isLeftPressed()) {\n setCancelButtonState(true);\n setConfirmButtonState(false);\n\n }\n if (kiosk.gamepadManager.isRightPressed()) {\n setCancelButtonState(false);\n setConfirmButtonState(true);\n\n }\n if (cancelButtonState && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.deleteGame.cancelled\");\n cancelClicked();\n }\n\n if (confirmButtonState && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.deleteGame.confirmed\");\n confirmClicked();\n }\n }\n\n useEffect(() => {\n let intervalId: any = null;\n\n intervalId = setInterval(() => {\n updateLoop();\n }, configData.GamepadPollLoopMilli);\n\n return () => {\n if (intervalId) {\n clearInterval(intervalId);\n }\n };\n });\n\n return (\n
    \n
    \n
    \n
    \n Delete the Game\n
    \n
    \n

    \n Delete the game? The only way to get the game back\n is by re-uploading it.\n

    \n
    \n
    \n \n \n
    \n
    \n
    \n
    \n )\n}\n\nexport default DeletionModal;","import { useEffect, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport AddGameButton from \"./AddGameButton\";\nimport GameList from \"./GameList\";\nimport configData from \"../config.json\"\nimport HighScoresList from \"./HighScoresList\";\nimport { DeleteButton } from \"./DeleteButton\";\nimport { tickEvent } from \"../browserUtils\";\nimport DeletionModal from \"./DeletionModal\";\n\ninterface IProps {\n kiosk: Kiosk\n }\n\nconst MainMenu: React.FC = ({ kiosk }) => {\n const [addButtonSelected, setAddButtonState] = useState(false);\n const [deleteButtonSelected, setDeleteButtonState] = useState(false);\n const [deleteTriggered, setDeleteTriggered] = useState(false);\n const lockedClassName = kiosk.locked ? \" locked\" : \"\";\n\n const updateLoop = () => {\n if (!addButtonSelected && kiosk.gamepadManager.isUpPressed()) {\n setAddButtonState(true);\n }\n if (addButtonSelected && kiosk.gamepadManager.isDownPressed()) {\n setAddButtonState(false);\n }\n if (!addButtonSelected && kiosk.selectedGame?.userAdded && kiosk.gamepadManager.isDownPressed()) {\n setDeleteButtonState(true);\n }\n if (deleteButtonSelected && kiosk.gamepadManager.isUpPressed()) {\n setAddButtonState(false);\n setDeleteButtonState(false);\n }\n if (addButtonSelected && (kiosk.gamepadManager.isAButtonPressed() || kiosk.gamepadManager.isBButtonPressed())) {\n tickEvent(\"kiosk.addGamePageLoaded\");\n kiosk.launchAddGame();\n }\n if (deleteButtonSelected && (kiosk.gamepadManager.isAButtonPressed() || kiosk.gamepadManager.isBButtonPressed())) {\n setDeleteTriggered(true);\n }\n }\n\n useEffect(() => {\n if (!kiosk.locked) {\n let intervalId: any = null;\n intervalId = setInterval(() => {\n if (!deleteTriggered) {\n updateLoop();\n }\n }, configData.GamepadPollLoopMilli);\n \n return () => {\n if (intervalId) {\n clearInterval(intervalId);\n }\n };\n } else {\n tickEvent(\"kiosk.locked\");\n }\n });\n\n return(\n
    \n \n \n {\n deleteTriggered &&\n \n }\n\n
    \n )\n}\n \nexport default MainMenu;","import { useEffect, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport configData from \"../config.json\"\nimport { tickEvent } from \"../browserUtils\";\n\ninterface IProps {\n kiosk: Kiosk,\n isSelected: boolean,\n onCharacterChanged: (initial: string) => void\n }\n\nconst HighScoreInitial: React.FC = ({ kiosk, isSelected, onCharacterChanged }) => {\n const [index, setIndex] = useState(0);\n\n const getPreviousIndex = () => (index + configData.HighScoreInitialAllowedCharacters.length - 1) % configData.HighScoreInitialAllowedCharacters.length;\n const getNextIndex = () => (index + 1) % configData.HighScoreInitialAllowedCharacters.length;\n\n const previousInitial = () => {\n const newIndex = getPreviousIndex();\n setIndex(newIndex);\n onCharacterChanged(configData.HighScoreInitialAllowedCharacters[newIndex]);\n }\n\n const nextInitial = () => {\n const newIndex = getNextIndex();\n setIndex(newIndex);\n onCharacterChanged(configData.HighScoreInitialAllowedCharacters[newIndex]);\n }\n\n useEffect(() => {\n const gamepadLoop = () => {\n if (!isSelected) { return; }\n\n if (kiosk.gamepadManager.isUpPressed()) {\n tickEvent(\"kiosk.newHighScore.upPressed\");\n previousInitial();\n }\n\n if (kiosk.gamepadManager.isDownPressed()) {\n tickEvent(\"kiosk.newHighScore.downPressed\");\n nextInitial();\n }\n };\n\n const interval = setInterval(() => gamepadLoop(), configData.GamepadPollLoopMilli);\n return () => clearInterval(interval);\n });\n\n const classNames = [\n \"highScoreInitialControl\",\n \"highScoreInitial\",\n isSelected ? \"highScoreInitialControlSelected\" : \"\"]\n\n return(\n
    \n
    {configData.HighScoreInitialAllowedCharacters[index]}
    \n
    \n )\n}\n \nexport default HighScoreInitial;","import { useEffect, useState } from \"react\";\nimport { HighScore } from \"../Models/HighScore\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport { KioskState } from \"../Models/KioskState\";\nimport HighScoreInitial from \"./HighScoreInitial\";\nimport configData from \"../config.json\"\nimport { tickEvent } from \"../browserUtils\";\n\ninterface IProps {\n kiosk: Kiosk\n }\n\nconst NewScoreEntry: React.FC = ({ kiosk }) => {\n const [indexChanged, setIndexChanged] = useState(false);\n const [nextIndex, setNextIndex] = useState(false);\n const [previousIndex, setPreviousIndex] = useState(false);\n\n const [initials, setInitials] = useState(Array(configData.HighScoreInitialsLength + 1).join(configData.HighScoreInitialAllowedCharacters[0]));\n const [timesAPressed, setTimesAPressed] = useState(0);\n const [runOnce, setRunOnce] = useState(false);\n const [firstRun, setFirstRun] = useState(true);\n\n const gamepadLoop = () => {\n if (kiosk.state !== KioskState.EnterHighScore) { return; }\n\n if (kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.newHighScore.nextInitial\");\n setIndexChanged(true);\n setNextIndex(true);\n } \n\n else if (kiosk.gamepadManager.isBButtonPressed()) {\n tickEvent(\"kiosk.newHighScore.prevInitial\");\n setIndexChanged(true);\n setPreviousIndex(true);\n } \n else {\n setIndexChanged(false);\n setPreviousIndex(false);\n setNextIndex(false);\n\n }\n\n if (kiosk.gamepadManager.isEscapeButtonPressed()) {\n tickEvent(\"kiosk.newHighScore.defaultInitialsUsed\");\n kiosk.saveHighScore(kiosk.selectedGame!.id, initials, kiosk.mostRecentScores[0]);\n kiosk.navigate(KioskState.GameOver);\n }\n };\n\n useEffect(() => {\n let interval: any;\n let timeout: any;\n timeout = setTimeout(() => {\n interval = setInterval(() =>\n gamepadLoop(),\n configData.EnterHighScorePoll\n )\n }, configData.EnterHighScoreDelayMilli)\n\n\n return () => {\n if (interval) {\n clearInterval(interval);\n }\n if (timeout) {\n clearTimeout(timeout);\n }\n }\n }, []);\n\n const decrementTimesPressed = () => {\n if (timesAPressed === 0) {\n return 0;\n } else {\n setTimesAPressed(timesAPressed - 1);\n return timesAPressed - 1;\n }\n }\n\n const updateTimesPressed = () => {\n if (runOnce) {\n setRunOnce(false);\n return timesAPressed;\n }\n else if (firstRun) {\n setFirstRun(false);\n return timesAPressed;\n }\n else {\n setRunOnce(true);\n if (nextIndex) {\n setTimesAPressed(timesAPressed + 1);\n return timesAPressed + 1;\n } \n else if (previousIndex) {\n return decrementTimesPressed();\n } else {\n return timesAPressed;\n }\n }\n }\n\n useEffect(() => {\n const updatedPressed = updateTimesPressed();\n\n\n if (updatedPressed >= 3) {\n setTimesAPressed(0);\n tickEvent(\"kiosk.newHighScore.initialsEntered\");\n kiosk.saveHighScore(kiosk.selectedGame!.id, initials, kiosk.mostRecentScores[0]);\n kiosk.navigate(KioskState.GameOver);\n }\n\n }, [indexChanged]);\n\n\n const updateInitial = (i: number, character: string) => {\n const newInitials = `${initials.substring(0, i)}${character}${initials.substring(i + 1)}`;\n setInitials(newInitials);\n }\n\n const renderInitials = (): JSX.Element[] => {\n const elements = [];\n\n for (let lcv = 0; lcv < configData.HighScoreInitialsLength; lcv++) {\n const thisIndex = lcv;\n elements.push(\n updateInitial(thisIndex, character[0])} />\n );\n }\n\n return elements;\n }\n\n return (\n \n {renderInitials()}\n {kiosk.mostRecentScores[0]}\n \n\n )\n}\n\nexport default NewScoreEntry;","interface IProps {\n highScoreInitials: string;\n highScoreScore: number;\n}\n\nconst ExistingScoreEntry: React.FC = ({ highScoreInitials, highScoreScore }) => {\n return (\n
  • \n {highScoreInitials}\n {highScoreScore}\n
  • \n )\n}\n\nexport default ExistingScoreEntry;","import { Kiosk } from \"../Models/Kiosk\";\nimport NewScoreEntry from \"./NewScoreEntry\";\nimport ExistingScoreEntry from \"./ExistingScoreEntry\";\nimport { useEffect } from \"react\";\n\ninterface IProps {\n kiosk: Kiosk\n }\n\nconst EnterHighScore: React.FC = ({ kiosk }) => {\n const existingHighScores = kiosk.getHighScores(kiosk.selectedGame!.id);\n\n useEffect(() => {\n if (!kiosk.mostRecentScores || !kiosk.mostRecentScores.length) {\n throw new Error(\"Cannot load high score entry view without having recent scores\");\n }\n }, []);\n\n const aboveScores = existingHighScores.filter(item => item.score > kiosk.mostRecentScores[0]);\n const belowScores = existingHighScores.slice(aboveScores.length, existingHighScores.length);\n\n return(\n
    \n
    \n

    YOU GOT A HIGH SCORE!

    \n

    Enter your initials

    \n
    \n
    \n
    \n
      \n {\n aboveScores.map((highScore, i) =>\n \n )\n }\n
    1. \n {\n belowScores.map((highScore, i) =>\n \n )\n }\n
    \n
    \n\n
    \n
      \n
    • Use up/down to scroll through the alphabet
    • \n
    • When you find your initial, press A
    • \n
    \n\n
    \n
    \n
    \n )\n}\n\nexport default EnterHighScore;","import unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nexport default function _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n if (!it) {\n if (Array.isArray(o) || (it = unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n var F = function F() {};\n return {\n s: F,\n n: function n() {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function e(_e) {\n throw _e;\n },\n f: F\n };\n }\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function s() {\n it = it.call(o);\n },\n n: function n() {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function e(_e2) {\n didErr = true;\n err = _e2;\n },\n f: function f() {\n try {\n if (!normalCompletion && it[\"return\"] != null) it[\"return\"]();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n}","var __defProp = Object.defineProperty;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n if (__getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(b)) {\n if (__propIsEnum.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n }\n return a;\n};\nvar __objRest = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\n\n// src/index.tsx\nimport React, { useRef, useEffect, useState } from \"react\";\n\n// src/third-party/qrcodegen/index.ts\n/**\n * @license QR Code generator library (TypeScript)\n * Copyright (c) Project Nayuki.\n * SPDX-License-Identifier: MIT\n */\nvar qrcodegen;\n((qrcodegen2) => {\n const _QrCode = class {\n constructor(version, errorCorrectionLevel, dataCodewords, msk) {\n this.version = version;\n this.errorCorrectionLevel = errorCorrectionLevel;\n this.modules = [];\n this.isFunction = [];\n if (version < _QrCode.MIN_VERSION || version > _QrCode.MAX_VERSION)\n throw new RangeError(\"Version value out of range\");\n if (msk < -1 || msk > 7)\n throw new RangeError(\"Mask value out of range\");\n this.size = version * 4 + 17;\n let row = [];\n for (let i = 0; i < this.size; i++)\n row.push(false);\n for (let i = 0; i < this.size; i++) {\n this.modules.push(row.slice());\n this.isFunction.push(row.slice());\n }\n this.drawFunctionPatterns();\n const allCodewords = this.addEccAndInterleave(dataCodewords);\n this.drawCodewords(allCodewords);\n if (msk == -1) {\n let minPenalty = 1e9;\n for (let i = 0; i < 8; i++) {\n this.applyMask(i);\n this.drawFormatBits(i);\n const penalty = this.getPenaltyScore();\n if (penalty < minPenalty) {\n msk = i;\n minPenalty = penalty;\n }\n this.applyMask(i);\n }\n }\n assert(0 <= msk && msk <= 7);\n this.mask = msk;\n this.applyMask(msk);\n this.drawFormatBits(msk);\n this.isFunction = [];\n }\n static encodeText(text, ecl) {\n const segs = qrcodegen2.QrSegment.makeSegments(text);\n return _QrCode.encodeSegments(segs, ecl);\n }\n static encodeBinary(data, ecl) {\n const seg = qrcodegen2.QrSegment.makeBytes(data);\n return _QrCode.encodeSegments([seg], ecl);\n }\n static encodeSegments(segs, ecl, minVersion = 1, maxVersion = 40, mask = -1, boostEcl = true) {\n if (!(_QrCode.MIN_VERSION <= minVersion && minVersion <= maxVersion && maxVersion <= _QrCode.MAX_VERSION) || mask < -1 || mask > 7)\n throw new RangeError(\"Invalid value\");\n let version;\n let dataUsedBits;\n for (version = minVersion; ; version++) {\n const dataCapacityBits2 = _QrCode.getNumDataCodewords(version, ecl) * 8;\n const usedBits = QrSegment.getTotalBits(segs, version);\n if (usedBits <= dataCapacityBits2) {\n dataUsedBits = usedBits;\n break;\n }\n if (version >= maxVersion)\n throw new RangeError(\"Data too long\");\n }\n for (const newEcl of [_QrCode.Ecc.MEDIUM, _QrCode.Ecc.QUARTILE, _QrCode.Ecc.HIGH]) {\n if (boostEcl && dataUsedBits <= _QrCode.getNumDataCodewords(version, newEcl) * 8)\n ecl = newEcl;\n }\n let bb = [];\n for (const seg of segs) {\n appendBits(seg.mode.modeBits, 4, bb);\n appendBits(seg.numChars, seg.mode.numCharCountBits(version), bb);\n for (const b of seg.getData())\n bb.push(b);\n }\n assert(bb.length == dataUsedBits);\n const dataCapacityBits = _QrCode.getNumDataCodewords(version, ecl) * 8;\n assert(bb.length <= dataCapacityBits);\n appendBits(0, Math.min(4, dataCapacityBits - bb.length), bb);\n appendBits(0, (8 - bb.length % 8) % 8, bb);\n assert(bb.length % 8 == 0);\n for (let padByte = 236; bb.length < dataCapacityBits; padByte ^= 236 ^ 17)\n appendBits(padByte, 8, bb);\n let dataCodewords = [];\n while (dataCodewords.length * 8 < bb.length)\n dataCodewords.push(0);\n bb.forEach((b, i) => dataCodewords[i >>> 3] |= b << 7 - (i & 7));\n return new _QrCode(version, ecl, dataCodewords, mask);\n }\n getModule(x, y) {\n return 0 <= x && x < this.size && 0 <= y && y < this.size && this.modules[y][x];\n }\n getModules() {\n return this.modules;\n }\n drawFunctionPatterns() {\n for (let i = 0; i < this.size; i++) {\n this.setFunctionModule(6, i, i % 2 == 0);\n this.setFunctionModule(i, 6, i % 2 == 0);\n }\n this.drawFinderPattern(3, 3);\n this.drawFinderPattern(this.size - 4, 3);\n this.drawFinderPattern(3, this.size - 4);\n const alignPatPos = this.getAlignmentPatternPositions();\n const numAlign = alignPatPos.length;\n for (let i = 0; i < numAlign; i++) {\n for (let j = 0; j < numAlign; j++) {\n if (!(i == 0 && j == 0 || i == 0 && j == numAlign - 1 || i == numAlign - 1 && j == 0))\n this.drawAlignmentPattern(alignPatPos[i], alignPatPos[j]);\n }\n }\n this.drawFormatBits(0);\n this.drawVersion();\n }\n drawFormatBits(mask) {\n const data = this.errorCorrectionLevel.formatBits << 3 | mask;\n let rem = data;\n for (let i = 0; i < 10; i++)\n rem = rem << 1 ^ (rem >>> 9) * 1335;\n const bits = (data << 10 | rem) ^ 21522;\n assert(bits >>> 15 == 0);\n for (let i = 0; i <= 5; i++)\n this.setFunctionModule(8, i, getBit(bits, i));\n this.setFunctionModule(8, 7, getBit(bits, 6));\n this.setFunctionModule(8, 8, getBit(bits, 7));\n this.setFunctionModule(7, 8, getBit(bits, 8));\n for (let i = 9; i < 15; i++)\n this.setFunctionModule(14 - i, 8, getBit(bits, i));\n for (let i = 0; i < 8; i++)\n this.setFunctionModule(this.size - 1 - i, 8, getBit(bits, i));\n for (let i = 8; i < 15; i++)\n this.setFunctionModule(8, this.size - 15 + i, getBit(bits, i));\n this.setFunctionModule(8, this.size - 8, true);\n }\n drawVersion() {\n if (this.version < 7)\n return;\n let rem = this.version;\n for (let i = 0; i < 12; i++)\n rem = rem << 1 ^ (rem >>> 11) * 7973;\n const bits = this.version << 12 | rem;\n assert(bits >>> 18 == 0);\n for (let i = 0; i < 18; i++) {\n const color = getBit(bits, i);\n const a = this.size - 11 + i % 3;\n const b = Math.floor(i / 3);\n this.setFunctionModule(a, b, color);\n this.setFunctionModule(b, a, color);\n }\n }\n drawFinderPattern(x, y) {\n for (let dy = -4; dy <= 4; dy++) {\n for (let dx = -4; dx <= 4; dx++) {\n const dist = Math.max(Math.abs(dx), Math.abs(dy));\n const xx = x + dx;\n const yy = y + dy;\n if (0 <= xx && xx < this.size && 0 <= yy && yy < this.size)\n this.setFunctionModule(xx, yy, dist != 2 && dist != 4);\n }\n }\n }\n drawAlignmentPattern(x, y) {\n for (let dy = -2; dy <= 2; dy++) {\n for (let dx = -2; dx <= 2; dx++)\n this.setFunctionModule(x + dx, y + dy, Math.max(Math.abs(dx), Math.abs(dy)) != 1);\n }\n }\n setFunctionModule(x, y, isDark) {\n this.modules[y][x] = isDark;\n this.isFunction[y][x] = true;\n }\n addEccAndInterleave(data) {\n const ver = this.version;\n const ecl = this.errorCorrectionLevel;\n if (data.length != _QrCode.getNumDataCodewords(ver, ecl))\n throw new RangeError(\"Invalid argument\");\n const numBlocks = _QrCode.NUM_ERROR_CORRECTION_BLOCKS[ecl.ordinal][ver];\n const blockEccLen = _QrCode.ECC_CODEWORDS_PER_BLOCK[ecl.ordinal][ver];\n const rawCodewords = Math.floor(_QrCode.getNumRawDataModules(ver) / 8);\n const numShortBlocks = numBlocks - rawCodewords % numBlocks;\n const shortBlockLen = Math.floor(rawCodewords / numBlocks);\n let blocks = [];\n const rsDiv = _QrCode.reedSolomonComputeDivisor(blockEccLen);\n for (let i = 0, k = 0; i < numBlocks; i++) {\n let dat = data.slice(k, k + shortBlockLen - blockEccLen + (i < numShortBlocks ? 0 : 1));\n k += dat.length;\n const ecc = _QrCode.reedSolomonComputeRemainder(dat, rsDiv);\n if (i < numShortBlocks)\n dat.push(0);\n blocks.push(dat.concat(ecc));\n }\n let result = [];\n for (let i = 0; i < blocks[0].length; i++) {\n blocks.forEach((block, j) => {\n if (i != shortBlockLen - blockEccLen || j >= numShortBlocks)\n result.push(block[i]);\n });\n }\n assert(result.length == rawCodewords);\n return result;\n }\n drawCodewords(data) {\n if (data.length != Math.floor(_QrCode.getNumRawDataModules(this.version) / 8))\n throw new RangeError(\"Invalid argument\");\n let i = 0;\n for (let right = this.size - 1; right >= 1; right -= 2) {\n if (right == 6)\n right = 5;\n for (let vert = 0; vert < this.size; vert++) {\n for (let j = 0; j < 2; j++) {\n const x = right - j;\n const upward = (right + 1 & 2) == 0;\n const y = upward ? this.size - 1 - vert : vert;\n if (!this.isFunction[y][x] && i < data.length * 8) {\n this.modules[y][x] = getBit(data[i >>> 3], 7 - (i & 7));\n i++;\n }\n }\n }\n }\n assert(i == data.length * 8);\n }\n applyMask(mask) {\n if (mask < 0 || mask > 7)\n throw new RangeError(\"Mask value out of range\");\n for (let y = 0; y < this.size; y++) {\n for (let x = 0; x < this.size; x++) {\n let invert;\n switch (mask) {\n case 0:\n invert = (x + y) % 2 == 0;\n break;\n case 1:\n invert = y % 2 == 0;\n break;\n case 2:\n invert = x % 3 == 0;\n break;\n case 3:\n invert = (x + y) % 3 == 0;\n break;\n case 4:\n invert = (Math.floor(x / 3) + Math.floor(y / 2)) % 2 == 0;\n break;\n case 5:\n invert = x * y % 2 + x * y % 3 == 0;\n break;\n case 6:\n invert = (x * y % 2 + x * y % 3) % 2 == 0;\n break;\n case 7:\n invert = ((x + y) % 2 + x * y % 3) % 2 == 0;\n break;\n default:\n throw new Error(\"Unreachable\");\n }\n if (!this.isFunction[y][x] && invert)\n this.modules[y][x] = !this.modules[y][x];\n }\n }\n }\n getPenaltyScore() {\n let result = 0;\n for (let y = 0; y < this.size; y++) {\n let runColor = false;\n let runX = 0;\n let runHistory = [0, 0, 0, 0, 0, 0, 0];\n for (let x = 0; x < this.size; x++) {\n if (this.modules[y][x] == runColor) {\n runX++;\n if (runX == 5)\n result += _QrCode.PENALTY_N1;\n else if (runX > 5)\n result++;\n } else {\n this.finderPenaltyAddHistory(runX, runHistory);\n if (!runColor)\n result += this.finderPenaltyCountPatterns(runHistory) * _QrCode.PENALTY_N3;\n runColor = this.modules[y][x];\n runX = 1;\n }\n }\n result += this.finderPenaltyTerminateAndCount(runColor, runX, runHistory) * _QrCode.PENALTY_N3;\n }\n for (let x = 0; x < this.size; x++) {\n let runColor = false;\n let runY = 0;\n let runHistory = [0, 0, 0, 0, 0, 0, 0];\n for (let y = 0; y < this.size; y++) {\n if (this.modules[y][x] == runColor) {\n runY++;\n if (runY == 5)\n result += _QrCode.PENALTY_N1;\n else if (runY > 5)\n result++;\n } else {\n this.finderPenaltyAddHistory(runY, runHistory);\n if (!runColor)\n result += this.finderPenaltyCountPatterns(runHistory) * _QrCode.PENALTY_N3;\n runColor = this.modules[y][x];\n runY = 1;\n }\n }\n result += this.finderPenaltyTerminateAndCount(runColor, runY, runHistory) * _QrCode.PENALTY_N3;\n }\n for (let y = 0; y < this.size - 1; y++) {\n for (let x = 0; x < this.size - 1; x++) {\n const color = this.modules[y][x];\n if (color == this.modules[y][x + 1] && color == this.modules[y + 1][x] && color == this.modules[y + 1][x + 1])\n result += _QrCode.PENALTY_N2;\n }\n }\n let dark = 0;\n for (const row of this.modules)\n dark = row.reduce((sum, color) => sum + (color ? 1 : 0), dark);\n const total = this.size * this.size;\n const k = Math.ceil(Math.abs(dark * 20 - total * 10) / total) - 1;\n assert(0 <= k && k <= 9);\n result += k * _QrCode.PENALTY_N4;\n assert(0 <= result && result <= 2568888);\n return result;\n }\n getAlignmentPatternPositions() {\n if (this.version == 1)\n return [];\n else {\n const numAlign = Math.floor(this.version / 7) + 2;\n const step = this.version == 32 ? 26 : Math.ceil((this.version * 4 + 4) / (numAlign * 2 - 2)) * 2;\n let result = [6];\n for (let pos = this.size - 7; result.length < numAlign; pos -= step)\n result.splice(1, 0, pos);\n return result;\n }\n }\n static getNumRawDataModules(ver) {\n if (ver < _QrCode.MIN_VERSION || ver > _QrCode.MAX_VERSION)\n throw new RangeError(\"Version number out of range\");\n let result = (16 * ver + 128) * ver + 64;\n if (ver >= 2) {\n const numAlign = Math.floor(ver / 7) + 2;\n result -= (25 * numAlign - 10) * numAlign - 55;\n if (ver >= 7)\n result -= 36;\n }\n assert(208 <= result && result <= 29648);\n return result;\n }\n static getNumDataCodewords(ver, ecl) {\n return Math.floor(_QrCode.getNumRawDataModules(ver) / 8) - _QrCode.ECC_CODEWORDS_PER_BLOCK[ecl.ordinal][ver] * _QrCode.NUM_ERROR_CORRECTION_BLOCKS[ecl.ordinal][ver];\n }\n static reedSolomonComputeDivisor(degree) {\n if (degree < 1 || degree > 255)\n throw new RangeError(\"Degree out of range\");\n let result = [];\n for (let i = 0; i < degree - 1; i++)\n result.push(0);\n result.push(1);\n let root = 1;\n for (let i = 0; i < degree; i++) {\n for (let j = 0; j < result.length; j++) {\n result[j] = _QrCode.reedSolomonMultiply(result[j], root);\n if (j + 1 < result.length)\n result[j] ^= result[j + 1];\n }\n root = _QrCode.reedSolomonMultiply(root, 2);\n }\n return result;\n }\n static reedSolomonComputeRemainder(data, divisor) {\n let result = divisor.map((_) => 0);\n for (const b of data) {\n const factor = b ^ result.shift();\n result.push(0);\n divisor.forEach((coef, i) => result[i] ^= _QrCode.reedSolomonMultiply(coef, factor));\n }\n return result;\n }\n static reedSolomonMultiply(x, y) {\n if (x >>> 8 != 0 || y >>> 8 != 0)\n throw new RangeError(\"Byte out of range\");\n let z = 0;\n for (let i = 7; i >= 0; i--) {\n z = z << 1 ^ (z >>> 7) * 285;\n z ^= (y >>> i & 1) * x;\n }\n assert(z >>> 8 == 0);\n return z;\n }\n finderPenaltyCountPatterns(runHistory) {\n const n = runHistory[1];\n assert(n <= this.size * 3);\n const core = n > 0 && runHistory[2] == n && runHistory[3] == n * 3 && runHistory[4] == n && runHistory[5] == n;\n return (core && runHistory[0] >= n * 4 && runHistory[6] >= n ? 1 : 0) + (core && runHistory[6] >= n * 4 && runHistory[0] >= n ? 1 : 0);\n }\n finderPenaltyTerminateAndCount(currentRunColor, currentRunLength, runHistory) {\n if (currentRunColor) {\n this.finderPenaltyAddHistory(currentRunLength, runHistory);\n currentRunLength = 0;\n }\n currentRunLength += this.size;\n this.finderPenaltyAddHistory(currentRunLength, runHistory);\n return this.finderPenaltyCountPatterns(runHistory);\n }\n finderPenaltyAddHistory(currentRunLength, runHistory) {\n if (runHistory[0] == 0)\n currentRunLength += this.size;\n runHistory.pop();\n runHistory.unshift(currentRunLength);\n }\n };\n let QrCode = _QrCode;\n QrCode.MIN_VERSION = 1;\n QrCode.MAX_VERSION = 40;\n QrCode.PENALTY_N1 = 3;\n QrCode.PENALTY_N2 = 3;\n QrCode.PENALTY_N3 = 40;\n QrCode.PENALTY_N4 = 10;\n QrCode.ECC_CODEWORDS_PER_BLOCK = [\n [-1, 7, 10, 15, 20, 26, 18, 20, 24, 30, 18, 20, 24, 26, 30, 22, 24, 28, 30, 28, 28, 28, 28, 30, 30, 26, 28, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30],\n [-1, 10, 16, 26, 18, 24, 16, 18, 22, 22, 26, 30, 22, 22, 24, 24, 28, 28, 26, 26, 26, 26, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28],\n [-1, 13, 22, 18, 26, 18, 24, 18, 22, 20, 24, 28, 26, 24, 20, 30, 24, 28, 28, 26, 30, 28, 30, 30, 30, 30, 28, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30],\n [-1, 17, 28, 22, 16, 22, 28, 26, 26, 24, 28, 24, 28, 22, 24, 24, 30, 28, 28, 26, 28, 30, 24, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30]\n ];\n QrCode.NUM_ERROR_CORRECTION_BLOCKS = [\n [-1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 4, 4, 4, 4, 4, 6, 6, 6, 6, 7, 8, 8, 9, 9, 10, 12, 12, 12, 13, 14, 15, 16, 17, 18, 19, 19, 20, 21, 22, 24, 25],\n [-1, 1, 1, 1, 2, 2, 4, 4, 4, 5, 5, 5, 8, 9, 9, 10, 10, 11, 13, 14, 16, 17, 17, 18, 20, 21, 23, 25, 26, 28, 29, 31, 33, 35, 37, 38, 40, 43, 45, 47, 49],\n [-1, 1, 1, 2, 2, 4, 4, 6, 6, 8, 8, 8, 10, 12, 16, 12, 17, 16, 18, 21, 20, 23, 23, 25, 27, 29, 34, 34, 35, 38, 40, 43, 45, 48, 51, 53, 56, 59, 62, 65, 68],\n [-1, 1, 1, 2, 4, 4, 4, 5, 6, 8, 8, 11, 11, 16, 16, 18, 16, 19, 21, 25, 25, 25, 34, 30, 32, 35, 37, 40, 42, 45, 48, 51, 54, 57, 60, 63, 66, 70, 74, 77, 81]\n ];\n qrcodegen2.QrCode = QrCode;\n function appendBits(val, len, bb) {\n if (len < 0 || len > 31 || val >>> len != 0)\n throw new RangeError(\"Value out of range\");\n for (let i = len - 1; i >= 0; i--)\n bb.push(val >>> i & 1);\n }\n function getBit(x, i) {\n return (x >>> i & 1) != 0;\n }\n function assert(cond) {\n if (!cond)\n throw new Error(\"Assertion error\");\n }\n const _QrSegment = class {\n constructor(mode, numChars, bitData) {\n this.mode = mode;\n this.numChars = numChars;\n this.bitData = bitData;\n if (numChars < 0)\n throw new RangeError(\"Invalid argument\");\n this.bitData = bitData.slice();\n }\n static makeBytes(data) {\n let bb = [];\n for (const b of data)\n appendBits(b, 8, bb);\n return new _QrSegment(_QrSegment.Mode.BYTE, data.length, bb);\n }\n static makeNumeric(digits) {\n if (!_QrSegment.isNumeric(digits))\n throw new RangeError(\"String contains non-numeric characters\");\n let bb = [];\n for (let i = 0; i < digits.length; ) {\n const n = Math.min(digits.length - i, 3);\n appendBits(parseInt(digits.substr(i, n), 10), n * 3 + 1, bb);\n i += n;\n }\n return new _QrSegment(_QrSegment.Mode.NUMERIC, digits.length, bb);\n }\n static makeAlphanumeric(text) {\n if (!_QrSegment.isAlphanumeric(text))\n throw new RangeError(\"String contains unencodable characters in alphanumeric mode\");\n let bb = [];\n let i;\n for (i = 0; i + 2 <= text.length; i += 2) {\n let temp = _QrSegment.ALPHANUMERIC_CHARSET.indexOf(text.charAt(i)) * 45;\n temp += _QrSegment.ALPHANUMERIC_CHARSET.indexOf(text.charAt(i + 1));\n appendBits(temp, 11, bb);\n }\n if (i < text.length)\n appendBits(_QrSegment.ALPHANUMERIC_CHARSET.indexOf(text.charAt(i)), 6, bb);\n return new _QrSegment(_QrSegment.Mode.ALPHANUMERIC, text.length, bb);\n }\n static makeSegments(text) {\n if (text == \"\")\n return [];\n else if (_QrSegment.isNumeric(text))\n return [_QrSegment.makeNumeric(text)];\n else if (_QrSegment.isAlphanumeric(text))\n return [_QrSegment.makeAlphanumeric(text)];\n else\n return [_QrSegment.makeBytes(_QrSegment.toUtf8ByteArray(text))];\n }\n static makeEci(assignVal) {\n let bb = [];\n if (assignVal < 0)\n throw new RangeError(\"ECI assignment value out of range\");\n else if (assignVal < 1 << 7)\n appendBits(assignVal, 8, bb);\n else if (assignVal < 1 << 14) {\n appendBits(2, 2, bb);\n appendBits(assignVal, 14, bb);\n } else if (assignVal < 1e6) {\n appendBits(6, 3, bb);\n appendBits(assignVal, 21, bb);\n } else\n throw new RangeError(\"ECI assignment value out of range\");\n return new _QrSegment(_QrSegment.Mode.ECI, 0, bb);\n }\n static isNumeric(text) {\n return _QrSegment.NUMERIC_REGEX.test(text);\n }\n static isAlphanumeric(text) {\n return _QrSegment.ALPHANUMERIC_REGEX.test(text);\n }\n getData() {\n return this.bitData.slice();\n }\n static getTotalBits(segs, version) {\n let result = 0;\n for (const seg of segs) {\n const ccbits = seg.mode.numCharCountBits(version);\n if (seg.numChars >= 1 << ccbits)\n return Infinity;\n result += 4 + ccbits + seg.bitData.length;\n }\n return result;\n }\n static toUtf8ByteArray(str) {\n str = encodeURI(str);\n let result = [];\n for (let i = 0; i < str.length; i++) {\n if (str.charAt(i) != \"%\")\n result.push(str.charCodeAt(i));\n else {\n result.push(parseInt(str.substr(i + 1, 2), 16));\n i += 2;\n }\n }\n return result;\n }\n };\n let QrSegment = _QrSegment;\n QrSegment.NUMERIC_REGEX = /^[0-9]*$/;\n QrSegment.ALPHANUMERIC_REGEX = /^[A-Z0-9 $%*+.\\/:-]*$/;\n QrSegment.ALPHANUMERIC_CHARSET = \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ $%*+-./:\";\n qrcodegen2.QrSegment = QrSegment;\n})(qrcodegen || (qrcodegen = {}));\n((qrcodegen2) => {\n let QrCode;\n ((QrCode2) => {\n const _Ecc = class {\n constructor(ordinal, formatBits) {\n this.ordinal = ordinal;\n this.formatBits = formatBits;\n }\n };\n let Ecc = _Ecc;\n Ecc.LOW = new _Ecc(0, 1);\n Ecc.MEDIUM = new _Ecc(1, 0);\n Ecc.QUARTILE = new _Ecc(2, 3);\n Ecc.HIGH = new _Ecc(3, 2);\n QrCode2.Ecc = Ecc;\n })(QrCode = qrcodegen2.QrCode || (qrcodegen2.QrCode = {}));\n})(qrcodegen || (qrcodegen = {}));\n((qrcodegen2) => {\n let QrSegment;\n ((QrSegment2) => {\n const _Mode = class {\n constructor(modeBits, numBitsCharCount) {\n this.modeBits = modeBits;\n this.numBitsCharCount = numBitsCharCount;\n }\n numCharCountBits(ver) {\n return this.numBitsCharCount[Math.floor((ver + 7) / 17)];\n }\n };\n let Mode = _Mode;\n Mode.NUMERIC = new _Mode(1, [10, 12, 14]);\n Mode.ALPHANUMERIC = new _Mode(2, [9, 11, 13]);\n Mode.BYTE = new _Mode(4, [8, 16, 16]);\n Mode.KANJI = new _Mode(8, [8, 10, 12]);\n Mode.ECI = new _Mode(7, [0, 0, 0]);\n QrSegment2.Mode = Mode;\n })(QrSegment = qrcodegen2.QrSegment || (qrcodegen2.QrSegment = {}));\n})(qrcodegen || (qrcodegen = {}));\nvar qrcodegen_default = qrcodegen;\n\n// src/index.tsx\n/**\n * @license qrcode.react\n * Copyright (c) Paul O'Shannessy\n * SPDX-License-Identifier: ISC\n */\nvar ERROR_LEVEL_MAP = {\n L: qrcodegen_default.QrCode.Ecc.LOW,\n M: qrcodegen_default.QrCode.Ecc.MEDIUM,\n Q: qrcodegen_default.QrCode.Ecc.QUARTILE,\n H: qrcodegen_default.QrCode.Ecc.HIGH\n};\nvar DEFAULT_SIZE = 128;\nvar DEFAULT_LEVEL = \"L\";\nvar DEFAULT_BGCOLOR = \"#FFFFFF\";\nvar DEFAULT_FGCOLOR = \"#000000\";\nvar DEFAULT_INCLUDEMARGIN = false;\nvar MARGIN_SIZE = 4;\nvar DEFAULT_IMG_SCALE = 0.1;\nfunction generatePath(modules, margin = 0) {\n const ops = [];\n modules.forEach(function(row, y) {\n let start = null;\n row.forEach(function(cell, x) {\n if (!cell && start !== null) {\n ops.push(`M${start + margin} ${y + margin}h${x - start}v1H${start + margin}z`);\n start = null;\n return;\n }\n if (x === row.length - 1) {\n if (!cell) {\n return;\n }\n if (start === null) {\n ops.push(`M${x + margin},${y + margin} h1v1H${x + margin}z`);\n } else {\n ops.push(`M${start + margin},${y + margin} h${x + 1 - start}v1H${start + margin}z`);\n }\n return;\n }\n if (cell && start === null) {\n start = x;\n }\n });\n });\n return ops.join(\"\");\n}\nfunction excavateModules(modules, excavation) {\n return modules.slice().map((row, y) => {\n if (y < excavation.y || y >= excavation.y + excavation.h) {\n return row;\n }\n return row.map((cell, x) => {\n if (x < excavation.x || x >= excavation.x + excavation.w) {\n return cell;\n }\n return false;\n });\n });\n}\nfunction getImageSettings(cells, size, includeMargin, imageSettings) {\n if (imageSettings == null) {\n return null;\n }\n const margin = includeMargin ? MARGIN_SIZE : 0;\n const numCells = cells.length + margin * 2;\n const defaultSize = Math.floor(size * DEFAULT_IMG_SCALE);\n const scale = numCells / size;\n const w = (imageSettings.width || defaultSize) * scale;\n const h = (imageSettings.height || defaultSize) * scale;\n const x = imageSettings.x == null ? cells.length / 2 - w / 2 : imageSettings.x * scale;\n const y = imageSettings.y == null ? cells.length / 2 - h / 2 : imageSettings.y * scale;\n let excavation = null;\n if (imageSettings.excavate) {\n let floorX = Math.floor(x);\n let floorY = Math.floor(y);\n let ceilW = Math.ceil(w + x - floorX);\n let ceilH = Math.ceil(h + y - floorY);\n excavation = { x: floorX, y: floorY, w: ceilW, h: ceilH };\n }\n return { x, y, h, w, excavation };\n}\nvar SUPPORTS_PATH2D = function() {\n try {\n new Path2D().addPath(new Path2D());\n } catch (e) {\n return false;\n }\n return true;\n}();\nfunction QRCodeCanvas(props) {\n const _a = props, {\n value,\n size = DEFAULT_SIZE,\n level = DEFAULT_LEVEL,\n bgColor = DEFAULT_BGCOLOR,\n fgColor = DEFAULT_FGCOLOR,\n includeMargin = DEFAULT_INCLUDEMARGIN,\n style,\n imageSettings\n } = _a, otherProps = __objRest(_a, [\n \"value\",\n \"size\",\n \"level\",\n \"bgColor\",\n \"fgColor\",\n \"includeMargin\",\n \"style\",\n \"imageSettings\"\n ]);\n const imgSrc = imageSettings == null ? void 0 : imageSettings.src;\n const _canvas = useRef(null);\n const _image = useRef(null);\n const [isImgLoaded, setIsImageLoaded] = useState(false);\n useEffect(() => {\n if (_canvas.current != null) {\n const canvas = _canvas.current;\n const ctx = canvas.getContext(\"2d\");\n if (!ctx) {\n return;\n }\n let cells = qrcodegen_default.QrCode.encodeText(value, ERROR_LEVEL_MAP[level]).getModules();\n const margin = includeMargin ? MARGIN_SIZE : 0;\n const numCells = cells.length + margin * 2;\n const calculatedImageSettings = getImageSettings(cells, size, includeMargin, imageSettings);\n const image = _image.current;\n const haveImageToRender = calculatedImageSettings != null && image !== null && image.complete && image.naturalHeight !== 0 && image.naturalWidth !== 0;\n if (haveImageToRender) {\n if (calculatedImageSettings.excavation != null) {\n cells = excavateModules(cells, calculatedImageSettings.excavation);\n }\n }\n const pixelRatio = window.devicePixelRatio || 1;\n canvas.height = canvas.width = size * pixelRatio;\n const scale = size / numCells * pixelRatio;\n ctx.scale(scale, scale);\n ctx.fillStyle = bgColor;\n ctx.fillRect(0, 0, numCells, numCells);\n ctx.fillStyle = fgColor;\n if (SUPPORTS_PATH2D) {\n ctx.fill(new Path2D(generatePath(cells, margin)));\n } else {\n cells.forEach(function(row, rdx) {\n row.forEach(function(cell, cdx) {\n if (cell) {\n ctx.fillRect(cdx + margin, rdx + margin, 1, 1);\n }\n });\n });\n }\n if (haveImageToRender) {\n ctx.drawImage(image, calculatedImageSettings.x + margin, calculatedImageSettings.y + margin, calculatedImageSettings.w, calculatedImageSettings.h);\n }\n }\n });\n useEffect(() => {\n setIsImageLoaded(false);\n }, [imgSrc]);\n const canvasStyle = __spreadValues({ height: size, width: size }, style);\n let img = null;\n if (imgSrc != null) {\n img = /* @__PURE__ */ React.createElement(\"img\", {\n src: imgSrc,\n key: imgSrc,\n style: { display: \"none\" },\n onLoad: () => {\n setIsImageLoaded(true);\n },\n ref: _image\n });\n }\n return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(\"canvas\", __spreadValues({\n style: canvasStyle,\n height: size,\n width: size,\n ref: _canvas\n }, otherProps)), img);\n}\nfunction QRCodeSVG(props) {\n const _a = props, {\n value,\n size = DEFAULT_SIZE,\n level = DEFAULT_LEVEL,\n bgColor = DEFAULT_BGCOLOR,\n fgColor = DEFAULT_FGCOLOR,\n includeMargin = DEFAULT_INCLUDEMARGIN,\n imageSettings\n } = _a, otherProps = __objRest(_a, [\n \"value\",\n \"size\",\n \"level\",\n \"bgColor\",\n \"fgColor\",\n \"includeMargin\",\n \"imageSettings\"\n ]);\n let cells = qrcodegen_default.QrCode.encodeText(value, ERROR_LEVEL_MAP[level]).getModules();\n const margin = includeMargin ? MARGIN_SIZE : 0;\n const numCells = cells.length + margin * 2;\n const calculatedImageSettings = getImageSettings(cells, size, includeMargin, imageSettings);\n let image = null;\n if (imageSettings != null && calculatedImageSettings != null) {\n if (calculatedImageSettings.excavation != null) {\n cells = excavateModules(cells, calculatedImageSettings.excavation);\n }\n image = /* @__PURE__ */ React.createElement(\"image\", {\n xlinkHref: imageSettings.src,\n height: calculatedImageSettings.h,\n width: calculatedImageSettings.w,\n x: calculatedImageSettings.x + margin,\n y: calculatedImageSettings.y + margin,\n preserveAspectRatio: \"none\"\n });\n }\n const fgPath = generatePath(cells, margin);\n return /* @__PURE__ */ React.createElement(\"svg\", __spreadValues({\n height: size,\n width: size,\n viewBox: `0 0 ${numCells} ${numCells}`\n }, otherProps), /* @__PURE__ */ React.createElement(\"path\", {\n fill: bgColor,\n d: `M0,0 h${numCells}v${numCells}H0z`,\n shapeRendering: \"crispEdges\"\n }), /* @__PURE__ */ React.createElement(\"path\", {\n fill: fgColor,\n d: fgPath,\n shapeRendering: \"crispEdges\"\n }), image);\n}\nvar QRCode = (props) => {\n const _a = props, { renderAs } = _a, otherProps = __objRest(_a, [\"renderAs\"]);\n if (renderAs === \"svg\") {\n return /* @__PURE__ */ React.createElement(QRCodeSVG, __spreadValues({}, otherProps));\n }\n return /* @__PURE__ */ React.createElement(QRCodeCanvas, __spreadValues({}, otherProps));\n};\nexport {\n QRCodeCanvas,\n QRCodeSVG,\n QRCode as default\n};\n",null,"import { useEffect, useState } from \"react\";\nimport { tickEvent } from \"../browserUtils\";\nimport \"../Kiosk.css\";\n\ninterface IProps {\n setActive: (p: boolean) => void;\n duration?: number;\n content: string;\n}\n\nconst KioskNotification: React.FC = ({ setActive, duration=5000, content }) => {\n useEffect(() => {\n let notificationLength = setTimeout(() => {\n setActive(false);\n }, duration);\n\n return () => {\n clearTimeout(notificationLength);\n }\n }, [])\n\n return (\n
    \n
    \n

    {content}

    \n
    \n
    \n )\n}\n\nexport default KioskNotification;","import { useEffect, useRef, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport { KioskState } from \"../Models/KioskState\";\nimport configData from \"../config.json\"\nimport \"../Kiosk.css\";\nimport AddGameButton from \"./AddGameButton\";\nimport {QRCodeSVG} from 'qrcode.react';\nimport { generateKioskCodeAsync, getGameCodesAsync } from \"../BackendRequests\";\nimport { isLocal, tickEvent } from \"../browserUtils\";\nimport { GameData } from \"../Models/GameData\";\nimport KioskNotification from \"./KioskNotification\";\ninterface IProps {\n kiosk: Kiosk\n}\n\nconst AddingGame: React.FC = ({ kiosk }) => {\n const [kioskCode, setKioskCode] = useState(\"\");\n const [renderQRCode, setRenderQRCode] = useState(true);\n const [menuButtonSelected, setMenuButtonState] = useState(false);\n const [qrCodeButtonSelected, setQrButtonState] = useState(false);\n const [notify, setNotify] = useState(false);\n const [notifyContent, setNotifyContent] = useState(\"\");\n const generatingKioskCode = useRef(false);\n const kioskCodeNextGenerationTime = useRef(0);\n const nextSafePollTime = useRef(0);\n const kioskCodeUrl = isLocal() ? \"http://localhost:3000/static/kiosk/\" : \"https://arcade.makecode.com/kiosk\";\n const kioskTimeOutInMinutes = getKioskCodeDuration();\n\n function getKioskCodeDuration(): number {\n const kioskCodeTime = localStorage.getItem(\"codeDuration\");\n if (kioskCodeTime) {\n return parseInt(kioskCodeTime);\n } else if (kiosk.time) {\n const kioskTime = parseInt(kiosk.time);\n return Math.min(240, Math.max(kioskTime, 0.5)) * 60;\n } else {\n return 30;\n }\n }\n\n const updateLoop = () => {\n if (!menuButtonSelected && kiosk.gamepadManager.isDownPressed()) {\n setMenuButtonState(true);\n if (qrCodeButtonSelected) {\n setQrButtonState(false);\n }\n }\n if (menuButtonSelected && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.toMainMenu\");\n kiosk.showMainMenu();\n }\n if (!renderQRCode && kiosk.gamepadManager.isUpPressed()) {\n setMenuButtonState(false);\n setQrButtonState(true);\n }\n if (qrCodeButtonSelected && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.newKioskCode\");\n setRenderQRCode(true);\n }\n }\n\n const kioskLinkClicked = () => {\n tickEvent(\"kiosk.addGameLink\");\n return true;\n }\n\n const displayGamesAdded = (addedGames: string[]): void => {\n const games = addedGames.join(\", \");\n const notification = `${games} added!`\n setNotifyContent(notification);\n setNotify(true);\n }\n\n useEffect(() => {\n let intervalId: any = null;\n intervalId = setInterval(() => {\n updateLoop();\n }, configData.GamepadPollLoopMilli);\n \n return () => {\n if (intervalId) {\n clearInterval(intervalId);\n }\n };\n });\n\n useEffect(() => {\n let pollTimer: any;\n const pollDelay = 5000;\n\n const pollForGameCode = async () => {\n const timeElapsed = nextSafePollTime.current - Date.now();\n const timeToPoll = Math.max(Math.min(timeElapsed, pollDelay), 0);\n nextSafePollTime.current = Date.now() + pollDelay;\n\n clearTimeout(pollTimer);\n pollTimer = setTimeout(async () => {\n try {\n const gameCodes = await getGameCodesAsync(kioskCode);\n if (gameCodes) {\n const justAddedGames = await kiosk.saveNewGamesAsync(gameCodes);\n if (justAddedGames.length) {\n displayGamesAdded(justAddedGames);\n }\n }\n if (kioskCode) {\n await pollForGameCode();\n }\n } catch (error: any) {\n clearTimeout(pollTimer);\n localStorage.removeItem(\"kioskCodeEnd\");\n localStorage.removeItem(\"currentKioskCode\");\n localStorage.removeItem(\"codeDuration\");\n setKioskCode(\"\");\n setRenderQRCode(false);\n }\n }, timeToPoll)\n }\n\n if (kioskCode) {\n pollForGameCode();\n }\n\n return () => {\n clearTimeout(pollTimer);\n }\n }, [kioskCode])\n\n useEffect(() => {\n let codeGenerationTimer: any;\n const generatedCodeDuration = kioskTimeOutInMinutes * 60 * 1000; // wait for kioskTimeOutInMinutes a.k.a until the kiosk code expires, backend has extra buffer\n\n const generateKioskCode = async () => {\n //TODO: maybe? spinner here to indicate work\n let newKioskCode: string;\n try {\n generatingKioskCode.current = true;\n if (kiosk.time) {\n newKioskCode = await generateKioskCodeAsync(kioskTimeOutInMinutes);\n } else {\n newKioskCode = await generateKioskCodeAsync();\n }\n setKioskCode(newKioskCode);\n\n kioskCodeNextGenerationTime.current = Date.now() + generatedCodeDuration;\n localStorage.setItem(\"kioskCodeEnd\", kioskCodeNextGenerationTime.current.toString());\n localStorage.setItem(\"currentKioskCode\", newKioskCode);\n localStorage.setItem(\"codeDuration\", kioskTimeOutInMinutes.toString());\n } catch (error) {\n setRenderQRCode(false);\n }\n generatingKioskCode.current = false;\n }\n\n\n if (!generatingKioskCode.current && renderQRCode) {\n const kioskCodeEndTime = localStorage.getItem(\"kioskCodeEnd\");\n if (kioskCodeEndTime) {\n const endTime = parseInt(kioskCodeEndTime);\n const timeElapsed = endTime - Date.now();\n if (timeElapsed > 0) {\n kioskCodeNextGenerationTime.current = endTime;\n const storedKioskCode = localStorage.getItem(\"currentKioskCode\");\n if (storedKioskCode) {\n setKioskCode(storedKioskCode);\n }\n } else {\n localStorage.removeItem(\"kioskCodeEnd\");\n localStorage.removeItem(\"currentKioskCode\");\n localStorage.removeItem(\"codeDuration\");\n generateKioskCode();\n }\n }\n else if (!kioskCode) {\n generateKioskCode();\n } else {\n const timeElapsed = kioskCodeNextGenerationTime.current - Date.now();\n const time = Math.max(Math.min(timeElapsed, generatedCodeDuration), 0);\n codeGenerationTimer = setTimeout(() => {\n setKioskCode(\"\");\n setRenderQRCode(false);\n localStorage.removeItem(\"kioskCodeEnd\");\n localStorage.removeItem(\"currentKioskCode\");\n localStorage.removeItem(\"codeDuration\");\n }, time)\n }\n }\n\n return () => {\n clearTimeout(codeGenerationTimer);\n }\n }, [kioskCode, renderQRCode]);\n\n const qrDivContent = () => {\n if (renderQRCode && kioskCode) {\n const kioskUrl = `${kioskCodeUrl}#add-game:${kioskCode}`;\n return (\n
    \n

    {kioskTimeOutInMinutes} minute Kiosk ID

    \n

    {kioskCode}

    \n \n \n\n
    \n )\n }\n else {\n return (\n
    \n \n
    \n )\n }\n };\n\n return (\n
    \n

    Add your game

    \n
    \n
    \n

    How to upload your game

    \n
      \n
    1. Use your mobile device to scan the QR code
    2. \n
    3. Use the new page to scan or enter your game's share code
    4. \n
    5. If your game is uploaded successfully, it will be added to the game list
    6. \n
    \n
    \n\n
    \n {qrDivContent()}\n
    \n
    \n \n {\n notify &&\n \n }\n
    \n\n )\n}\n\nexport default AddingGame;",null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,"import \"../Kiosk.css\";\nimport { Html5Qrcode } from \"html5-qrcode\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport { addGameToKioskAsync } from \"../BackendRequests\";\nimport { KioskState } from \"../Models/KioskState\";\nimport { tickEvent } from \"../browserUtils\";\n\nexport const play = async (\n kiosk: Kiosk,\n kioskId: string,\n html5QrCode: Html5Qrcode,\n setAddError: (p: string) => void,\n setDesc: (p: string) => void\n ) => {\n let devices: any[];\n\n async function onScanSuccess(decodedText: string, decodedResult: any) {\n const shareId = /\\/([^\\/]+)\\/?$/.exec(decodedText)?.[1];\n try {\n await addGameToKioskAsync(kioskId, shareId);\n tickEvent(\"kiosk.gameQrScanned.success\");\n await html5QrCode.stop();\n kiosk.navigate(KioskState.QrSuccess);\n } catch (error: any) {\n setAddError(error.toString());\n if (error.toString().includes(\"404\")) {\n setDesc(\"This is likely because the kiosk code is expired. Go back to the kiosk to make a new code.\");\n } else {\n setDesc(\"Something went wrong. Please try again later.\");\n }\n }\n }\n \n function onScanFailure(errorMessage: string, error: any) {\n console.log(\"scan failed\");\n throw new Error(\"bad scan\");\n }\n\n try {\n devices = await Html5Qrcode.getCameras();\n if (devices && devices.length) {\n try {\n html5QrCode.start(\n {facingMode: \"environment\"},\n undefined,\n onScanSuccess,\n onScanFailure\n );\n } catch (error) {\n console.log(\"failed to start scanning\");\n }\n }\n } catch (error) {\n console.log(\"couldn't get camera permissions\");\n }\n}\n\nexport const stopScan = async (html5QrCode: Html5Qrcode) => {\n await html5QrCode.stop();\n}","import { useEffect, useState } from \"react\";\nimport { tickEvent } from \"../browserUtils\";\nimport \"../Kiosk.css\";\n\n\ninterface IProps {\n errorType: string;\n errorDescription: string;\n setShowing: (p: string) => void;\n}\nconst ErrorModal: React.FC = ({ errorType, errorDescription, setShowing }) => {\n const cancelClicked = () => {\n tickEvent(\"kiosk.scanError.dismissed\");\n setShowing(\"\");\n }\n\n return (\n
    \n
    \n
    \n
    \n {errorType}\n
    \n
    \n

    \n {errorDescription}\n

    \n
    \n
    \n \n
    \n
    \n
    \n
    \n )\n}\n\nexport default ErrorModal;","import { useEffect, useRef, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport \"../Kiosk.css\";\nimport { play, stopScan } from \"./QrScanner\";\nimport { addGameToKioskAsync } from \"../BackendRequests\";\nimport { KioskState } from \"../Models/KioskState\";\nimport { Html5Qrcode } from \"html5-qrcode\";\nimport { tickEvent } from \"../browserUtils\";\nimport ErrorModal from \"./ErrorModal\";\n\ninterface IProps {\n kiosk: Kiosk\n}\n\nconst ScanQR: React.FC = ({ kiosk }) => {\n const fullUrlHash = window.location.hash;\n const urlHashList = /add-game:((?:[a-zA-Z0-9]{6}))/.exec(fullUrlHash);\n const kioskId = urlHashList?.[1];\n const [scannerVisible, setScannerVisible] = useState(false);\n const [linkError, setLinkError] = useState(false);\n const [addingError, setAddingError] = useState(\"\");\n const [errorDesc, setErrorDesc] = useState(\"\");\n const qrReaderRendered = useRef(null);\n const [html5QrCode, setHtml5QrCode] = useState();\n\n const renderQrScanner = () => {\n tickEvent(\"kiosk.scanQrClicked\");\n play(kiosk, kioskId!, html5QrCode!, setAddingError, setErrorDesc);\n setScannerVisible(true);\n }\n\n const stopQrScanner = () => {\n tickEvent(\"kiosk.stopScanClicked\");\n stopScan(html5QrCode!);\n setScannerVisible(false);\n }\n\n const initiateQrCode = () => {\n if (qrReaderRendered.current) {\n const qrCodeReader = new Html5Qrcode(\"qrReader\");\n setHtml5QrCode(qrCodeReader);\n }\n }\n\n const clickHelp = () => {\n tickEvent(\"kiosk.helpLink\");\n return true;\n }\n\n useEffect(() => {\n tickEvent(\"kiosk.scanQrLoaded\");\n initiateQrCode();\n }, [])\n\n const checkUrl = async () => {\n const input = document.getElementById(\"kiosk-share-link\") as HTMLInputElement;\n const inputValue = input.value?.trim();\n const shareLink = /^(https:\\/\\/)((arcade\\.makecode\\.com\\/)|(makecode\\.com\\/))((?:S?\\d{5}-\\d{5}-\\d{5}-\\d{5})$|(?:_[a-zA-Z0-9]+)$)/i.exec(inputValue);\n const shareCode = /(^(?:S?\\d{5}-\\d{5}-\\d{5}-\\d{5})$|^(?:_[a-zA-Z0-9]{12})$)/.exec(inputValue);\n let shareId;\n if (shareLink) {\n shareId = /\\/([^\\/]+)\\/?$/.exec(inputValue)?.[1];\n } else if (shareCode) {\n shareId = shareCode[1];\n }\n tickEvent(\"kiosk.submitGameId.clicked\", { submitVal: inputValue });\n if (shareId) {\n setLinkError(false);\n try {\n await addGameToKioskAsync(kioskId, shareId);\n tickEvent(\"kiosk.submitGameId.submitSuccess\");\n kiosk.navigate(KioskState.QrSuccess);\n } catch (error: any) {\n setAddingError(error.toString());\n if (error.toString().includes(\"404\")) {\n setErrorDesc(\"The kiosk code expired. Go back to the kiosk to make a new code.\");\n } else {\n setErrorDesc(\"Something went wrong. Please try again later.\");\n }\n }\n } else {\n setLinkError(true);\n }\n\n }\n\n const clearStatus = () => {\n if (linkError) {\n setLinkError(false);\n }\n }\n\n return (\n
    \n

    Add game to
    Kiosk {kioskId}

    \n
    \n
    \n {\n !scannerVisible &&\n \n }\n
    \n {\n scannerVisible &&\n
    \n \n

    Tip: Do not use the kiosk's QR code

    \n
    \n }\n

    OR

    \n
    \n
    \n \n \n \n {\n linkError &&\n

    Incorrect format for a share link

    \n }\n
    \n \n How do I get a game's share link or QR code?\n \n
    \n {\n !!addingError &&\n \n }\n
    \n )\n}\n\nexport default ScanQR;","import { useEffect } from \"react\";\nimport { tickEvent } from \"../browserUtils\";\nimport \"../Kiosk.css\";\n\nconst QrSuccess: React.FC<{}> = () => {\n // TODO: pass the game's title and the kiosk's id through to give more feedback to the user\n useEffect(() => {\n tickEvent(\"kiosk.qrSuccessLoaded\");\n },[]);\n\n return (\n
    \n

    You have successfully uploaded your game to the kiosk!

    \n

    You can close this window. Happy playing!

    \n
    \n )\n}\nexport default QrSuccess;","import { useEffect, useState } from \"react\";\nimport { Kiosk } from \"../Models/Kiosk\";\nimport AddGameButton from \"./AddGameButton\";\nimport configData from \"../config.json\"\nimport { KioskState } from \"../Models/KioskState\";\nimport { tickEvent } from \"../browserUtils\";\n\n\ninterface IProps {\n kiosk: Kiosk\n }\n\nconst GameOver: React.FC = ({ kiosk }) => {\n const [homeButtonSelected, setHomeButtonState] = useState(false);\n const [retryButtonSelected, setRetryButtonState] = useState(false);\n const gameId = kiosk.launchedGame;\n\n\n const updateLoop = () => {\n if (kiosk.gamepadManager.isLeftPressed()) {\n setRetryButtonState(true);\n setHomeButtonState(false);\n\n }\n if (kiosk.gamepadManager.isRightPressed()) {\n setHomeButtonState(true);\n setRetryButtonState(false);\n\n }\n if (homeButtonSelected && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.gameOver.mainMenu\");\n kiosk.navigate(KioskState.MainMenu);\n }\n\n if (retryButtonSelected && kiosk.gamepadManager.isAButtonPressed()) {\n tickEvent(\"kiosk.gameOver.retry\");\n kiosk.launchGame(gameId);\n }\n }\n\n useEffect(() => {\n let intervalId: any = null;\n\n intervalId = setInterval(() => {\n updateLoop();\n }, configData.GamepadPollLoopMilli);\n\n return () => {\n if (intervalId) {\n clearInterval(intervalId);\n }\n };\n });\n\n\n return (\n
    \n

    GAME OVER

    \n

    Would you like to retry?

    \n
    \n \n \n
    \n
    \n )\n}\n\nexport default GameOver;","import React, { useEffect, useState } from 'react';\nimport './Kiosk.css';\nimport './Fonts.css';\nimport { Kiosk } from './Models/Kiosk';\nimport MainMenu from './Components/MainMenu';\nimport { KioskState } from './Models/KioskState';\nimport EnterHighScore from './Components/EnterHighScore';\nimport AddingGame from './Components/AddingGame';\nimport ScanQR from './Components/ScanQR';\nimport QrSuccess from './Components/QrSuccess';\nimport GameOver from './Components/GameOver';\n\nconst url = window.location.href;\nconst clean = !!/clean(?:[:=])1/.test(url);\nconst locked = !!/lock(?:[:=])1/i.test(url);\nconst time = (/time=((?:[0-9]{1,3}))/i.exec(url))?.[1];\n\nconst kioskSingleton: Kiosk = new Kiosk(clean, locked, time);\nkioskSingleton.initialize().catch(error => alert(error));\n\nfunction App() {\n const[state, setState] = useState(kioskSingleton.state);\n\n useEffect(() => {\n window.onhashchange = onHashChange;\n\n kioskSingleton.onNavigated = () => {\n setState(kioskSingleton.state);\n };\n onHashChange();\n }, []);\n\n switch(state) {\n case KioskState.MainMenu:\n return ()\n case KioskState.EnterHighScore:\n return ()\n case KioskState.AddingGame:\n return ()\n case KioskState.ScanQR:\n return ()\n case KioskState.QrSuccess:\n return ()\n case KioskState.GameOver:\n return ()\n }\n\n return (
    )\n}\n\nfunction onHashChange() {\n const hash = window.location.hash;\n const match = /pub:((?:\\d{5}-\\d{5}-\\d{5}-\\d{5})|(?:_[a-zA-Z0-9]+))/.exec(hash);\n const addGame = /add-game:((?:[a-zA-Z0-9]{6}))/.exec(hash);\n if (match) {\n kioskSingleton.launchGame(match[1], true);\n } else if (addGame) {\n kioskSingleton.navigate(KioskState.ScanQR);\n }\n}\n\nexport default App;","import { ReportHandler } from 'web-vitals';\n\nconst reportWebVitals = (onPerfEntry?: ReportHandler) => {\n if (onPerfEntry && onPerfEntry instanceof Function) {\n import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\n getCLS(onPerfEntry);\n getFID(onPerfEntry);\n getFCP(onPerfEntry);\n getLCP(onPerfEntry);\n getTTFB(onPerfEntry);\n });\n }\n};\n\nexport default reportWebVitals;\n","import React from 'react';\nimport ReactDOM from 'react-dom/client';\nimport './Kiosk.css';\nimport App from './App';\nimport reportWebVitals from './reportWebVitals';\nimport { devicePixelRatio, isLocal, tickEvent } from './browserUtils';\n\ninterface Map {\n [index: string]: T;\n}\n\nfunction enableAnalytics() {\n const stats: Map = {};\n if (typeof window !== \"undefined\") {\n const screen = window.screen;\n stats[\"screen.width\"] = screen.width;\n stats[\"screen.height\"] = screen.height;\n stats[\"screen.availwidth\"] = screen.availWidth;\n stats[\"screen.availheight\"] = screen.availHeight;\n stats[\"screen.innerWidth\"] = window.innerWidth;\n stats[\"screen.innerHeight\"] = window.innerHeight;\n stats[\"screen.devicepixelratio\"] = devicePixelRatio();\n const body = document.firstElementChild; // body\n if (body) {\n stats[\"screen.clientWidth\"] = body.clientWidth;\n stats[\"screen.clientHeight\"] = body.clientHeight;\n }\n }\n tickEvent(\"kiosk.loaded\", stats);\n}\n\nwindow.addEventListener(\"DOMContentLoaded\", () => {\n enableAnalytics();\n\n const root = ReactDOM.createRoot(\n document.getElementById('root') as HTMLElement\n );\n root.render(\n \n \n \n );\n});\n\n// If you want to start measuring performance in your app, pass a function\n// to log results (for example: reportWebVitals(console.log))\n// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals\nreportWebVitals();\n"],"names":["exports","extendStatics","Object","setPrototypeOf","__proto__","Array","d","b","p","hasOwnProperty","__extends","__","this","constructor","prototype","create","fixProto","target","fixStack","fn","captureStackTrace","Error","Exception","message","undefined","kind","_super","CustomError","_newTarget","_this","call","defineProperty","value","name","enumerable","ArgumentException","IllegalArgumentException","BinaryBitmap","binarizer","getWidth","getHeight","y","row","getBlackRow","matrix","getBlackMatrix","getLuminanceSource","isCropSupported","left","top","width","height","newSource","crop","createBinarizer","isRotateSupported","rotateCounterClockwise","rotateCounterClockwise45","toString","e","ChecksumException","Binarizer","source","System","src","srcPos","dest","destPos","length","Date","now","IndexOutOfBoundsException","ArrayIndexOutOfBoundsException","index","Arrays","a","val","i","len","fromIndex","toIndex","rangeCheck","arrayLength","args","rows","cols","from","map","x","fill","Int32Array","first","second","result","original","newLength","slice","newArray","Uint8Array","set","to","copy","arraycopy","ar","el","comparator","numberComparator","m","n","k","cmp","Integer","intNumber","String","parseInt","dividend","divisor","Math","trunc","num","MIN_VALUE_32_BITS","MAX_VALUE","Number","MAX_SAFE_INTEGER","DecodeHintType","BitArray","size","bits","makeArray","floor","newBits","bitsOffset","currentBits","numberOfTrailingZeros","start","end","firstInt","lastInt","mask","max","bit","ensureCapacity","numBits","numBitsLeft","appendBit","other","otherSize","get","bitOffset","array","offset","numBytes","theByte","j","oldBitsLen","leftOffset","currentInt","nextInt","o","equals","hashCode","CharacterSetValueIdentifiers","DecodeHintType$1","FormatException","CharacterSetECI","valueIdentifier","valuesParam","values","otherEncodingNames","VALUE_IDENTIFIER_TO_ECI","NAME_TO_ECI","v","VALUES_TO_ECI","otherName","getName","characterSet","Map","Cp437","ISO8859_1","ISO8859_2","ISO8859_3","ISO8859_4","ISO8859_5","ISO8859_6","ISO8859_7","ISO8859_8","ISO8859_9","ISO8859_10","ISO8859_11","ISO8859_13","ISO8859_14","ISO8859_15","ISO8859_16","SJIS","Cp1250","Cp1251","Cp1252","Cp1256","UnicodeBigUnmarked","UTF8","ASCII","Big5","GB18030","EUC_KR","UnsupportedOperationException","StringEncoding","bytes","encoding","encodingName","customDecoder","TextDecoder","shouldDecodeOnFallback","decodeFallback","decode","isBrowser","s","customEncoder","TextEncoder","encodeFallback","encode","window","getCharacterSetECIByName","encodingCharacterSet","isDecodeFallbackSupported","h","decodeURIComponent","fromCharCode","apply","Uint16Array","buffer","charList","btoa","unescape","encodeURIComponent","split","uintArray","push","charCodeAt","StringUtils","code","ISO88591","hints","CHARACTER_SET","canBeISO88591","canBeShiftJIS","canBeUTF8","utf8BytesLeft","utf2BytesChars","utf3BytesChars","utf4BytesChars","sjisBytesLeft","sjisKatakanaChars","sjisCurKatakanaWordLength","sjisCurDoubleBytesWordLength","sjisMaxKatakanaWordLength","sjisMaxDoubleBytesWordLength","isoHighOther","utf8bom","ASSUME_SHIFT_JIS","SHIFT_JIS","PLATFORM_DEFAULT_ENCODING","append","callback","exp","p0","p1","p2","p3","p4","substr","base","parseFloat","toFixed","toPrecision","toExponential","JSON","stringify","ch","regex","replace","str","charCode","GB2312","EUC_JP","StringBuilder","castAsNonUtf8Char","charAt","substring","c","BitMatrix","rowSize","getRowSize","rowArray","getRow","getBitArray","right","bottom","getSize","clear","setBulk","topRow","bottomRow","reverse","setRow","x32","theBits","hash","setString","unsetString","lineSeparator","buildToString","image","imageI","stringRepresentation","bitsPos","rowStartPos","rowLength","nRows","pos","NotFoundException","GlobalHistogramBinarizer","luminances","EMPTY","buckets","LUMINANCE_BUCKETS","initArrays","localLuminances","localBuckets","LUMINANCE_SHIFT","blackPoint","estimateBlackPoint","center","getMatrix","luminanceSize","Uint8ClampedArray","numBuckets","maxBucketCount","firstPeak","firstPeakSize","secondPeak","secondPeakScore","distanceToBiggest","score","temp","bestValley","bestValleyScore","fromFirst","LUMINANCE_BITS","HybridBinarizer","MINIMUM_DIMENSION","subWidth","BLOCK_SIZE_POWER","BLOCK_SIZE_MASK","subHeight","blackPoints","calculateBlackPoints","newMatrix","calculateThresholdForBlock","maxYOffset","BLOCK_SIZE","maxXOffset","yoffset","cap","xoffset","sum","z","blackRow","average","thresholdBlock","min","threshold","stride","yy","xx","pixel","MIN_DYNAMIC_RANGE","averageNeighborBlackPoint","LuminanceSource","sourceRow","luminance","InvertedLuminanceSource","delegate","invertedMatrix","HTMLCanvasElementLuminanceSource","canvas","tempCanvasElement","makeBufferFromCanvasImageData","rotate","ownerDocument","createElement","angle","getTempCanvasElement","tempContext","getContext","angleRadians","DEGREE_TO_RADIANS","newWidth","ceil","abs","cos","sin","newHeight","translate","drawImage","imageData","getImageData","toGrayscaleBuffer","data","imageBuffer","grayscaleBuffer","gray","PI","BarcodeFormat","VideoInputDevice","deviceId","label","groupId","__awaiter","globalThis","global","self","thisArg","_arguments","P","generator","adopt","resolve","Promise","reject","fulfilled","step","next","rejected","done","then","BrowserCodeReader","reader","timeBetweenScansMillis","_hints","_stopContinuousDecode","_stopAsyncDecode","_timeBetweenDecodingAttempts","navigator","hasNavigator","mediaDevices","isMediaDevicesSuported","enumerateDevices","millis","canEnumerateDevices","devices","videoDevices","device","id","videoDevice","listVideoInputDevices","find","videoSource","decodeOnceFromVideoDevice","reset","constraints","video","exact","facingMode","decodeOnceFromConstraints","getUserMedia","stream","decodeOnceFromStream","attachStreamToVideo","decodeOnce","callbackFn","decodeFromVideoDevice","decodeFromConstraints","decodeFromStream","decodeContinuously","videoElement","prepareVideoElement","addVideoSource","playVideoOnLoadAsync","playVideoOnLoad","element","videoEndedListener","stopStreams","videoCanPlayListener","tryPlayVideo","addEventListener","currentTime","paused","ended","readyState","isVideoPlaying","console","warn","play","mediaElementId","type","mediaElement","document","getElementById","nodeName","toLowerCase","url","decodeFromImageUrl","decodeFromImageElement","decodeFromVideoUrl","decodeFromVideoElement","decodeFromVideoUrlContinuously","decodeFromVideoElementContinuously","prepareImageElement","imageElement","isImageLoaded","_decodeOnLoadImage","_decodeFromVideoElementSetup","_decodeOnLoadVideo","_decodeOnLoadVideoContinuously","decodeTask","imageLoadedListener","img","complete","naturalWidth","imageSource","getMediaElement","HTMLImageElement","HTMLVideoElement","setAttribute","retryIfNotFound","retryIfChecksumOrFormatError","loop","setTimeout","binaryBitmap","createBinaryBitmap","decodeBitmap","ctx","getCaptureCanvasContext","drawImageOnCanvas","getCaptureCanvas","luminanceSource","hybridBinarizer","captureCanvasContext","captureCanvas","elem","createCaptureCanvas","canvasElementContext","srcElement","_destroyCaptureCanvas","canvasElement","videoWidth","videoHeight","naturalHeight","style","getVideoTracks","forEach","t","stop","stopAsyncDecode","stopContinuousDecode","_destroyVideoElement","_destroyImageElement","removeEventListener","videoPlayingEventListener","cleanVideoSource","removeAttribute","srcObject","err","URL","createObjectURL","Result","text","rawBytes","resultPoints","format","timestamp","currentTimeMillis","resultMetadata","metadata","newPoints","oldPoints","allPoints","ResultMetadataType","BarcodeFormat$1","ResultMetadataType$1","DecoderResult","byteSegments","ecLevel","structuredAppendSequenceNumber","structuredAppendParity","errorsCorrected","erasures","AbstractGenericGF","expTable","logTable","GenericGFPoly","field","coefficients","coefficientsLength","firstNonZero","degree","getCoefficient","coefficient","addOrSubtract","multiply","isZero","smallerCoefficients","largerCoefficients","sumDiff","lengthDiff","getZero","aCoefficients","aLength","bCoefficients","bLength","product","aCoeff","scalar","quotient","remainder","denominatorLeadingTerm","getDegree","inverseDenominatorLeadingTerm","inverse","degreeDifference","scale","term","multiplyByMonomial","iterationQuotient","buildMonomial","alphaPower","log","ArithmeticException","GenericGF","primitive","generatorBase","zero","one","toHexString","AZTEC_DATA_12","AZTEC_DATA_10","AZTEC_DATA_6","AZTEC_PARAM","QR_CODE_FIELD_256","DATA_MATRIX_FIELD_256","AZTEC_DATA_8","MAXICODE_FIELD_64","ReedSolomonException","IllegalStateException","Table","ReedSolomonDecoder","received","twoS","poly","syndromeCoefficients","noError","evalResult","evaluateAt","getGeneratorBase","syndrome","sigmaOmega","runEuclideanAlgorithm","sigma","omega","errorLocations","findErrorLocations","errorMagnitudes","findErrorMagnitudes","position","R","rLast","r","tLast","getOne","rLastLast","tLastLast","q","dltInverse","degreeDiff","sigmaTildeAtZero","multiplyScalar","errorLocator","numErrors","errorEvaluator","xiInverse","denominator","termPlus1","Decoder","detectorResult","ddata","getBits","rawbits","extractBits","correctedBits","correctBits","convertBoolArrayToByteArray","getEncodedData","decoderResult","setNumBits","gf","codewordSize","getNbLayers","numDataCodewords","getNbDatablocks","numCodewords","dataWords","readCode","ex","stuffedBits","dataWord","compact","isCompact","layers","baseMatrixSize","alignmentMap","totalBitsInLayer","matrixSize","truncDivision","origCenter","newOffset","rowOffset","low","high","columnOffset","endIndex","latchTable","UPPER","shiftTable","BINARY","charCount","DIGIT","getCharacter","startsWith","getTable","LOWER","PUNCT","MIXED","table","UPPER_TABLE","LOWER_TABLE","MIXED_TABLE","PUNCT_TABLE","DIGIT_TABLE","startIndex","res","boolArr","byteArr","readByte","MathUtils","NaN","MIN_SAFE_INTEGER","aX","aY","bX","bY","xDiff","yDiff","sqrt","count","Float","f","ResultPoint","otherPoint","floatToIntBits","patterns","pointA","pointB","pointC","zeroOneDistance","distance","oneTwoDistance","zeroTwoDistance","crossProductZ","pattern1","pattern2","DetectorResult","points","AztecDetectorResult","nbDatablocks","nbLayers","WhiteRectangleDetector","initSize","INIT_SIZE","halfsize","leftInit","rightInit","upInit","downInit","up","down","sizeExceeded","aBlackPointFoundOnBorder","atLeastOneBlackPointFoundOnBorder","atLeastOneBlackPointFoundOnRight","atLeastOneBlackPointFoundOnBottom","atLeastOneBlackPointFoundOnLeft","atLeastOneBlackPointFoundOnTop","rightBorderNotWhite","containsBlackPoint","bottomBorderNotWhite","leftBorderNotWhite","topBorderNotWhite","maxSize","getBlackPointOnSegment","centerEdges","dist","round","xStep","yStep","yi","getX","yj","getY","zi","zj","xi","xj","ti","tj","CORR","fixed","horizontal","GridSampler","nudged","PerspectiveTransform","a11","a21","a31","a12","a22","a32","a13","a23","a33","xValues","yValues","x0","y0","x1","y1","x2","y2","x3","y3","x0p","y0p","x1p","y1p","x2p","y2p","x3p","y3p","qToS","quadrilateralToSquare","squareToQuadrilateral","times","dx3","dy3","dx1","dx2","dy1","dy2","buildAdjoint","DefaultGridSampler","dimensionX","dimensionY","p1ToX","p1ToY","p2ToX","p2ToY","p3ToX","p3ToY","p4ToX","p4ToY","p1FromX","p1FromY","p2FromX","p2FromY","p3FromX","p3FromY","p4FromX","p4FromY","transform","quadrilateralToQuadrilateral","sampleGridWithTransform","Float32Array","iValue","transformPoints","checkAndNudgePoints","aioobe","GridSamplerInstance","newGridSampler","gridSampler","Point","Detector","EXPECTED_CORNER_BITS","detectMirror","isMirror","pCenter","getMatrixCenter","bullsEyeCorners","getBullsEyeCorners","extractParameters","sampleGrid","shift","corners","getMatrixCornerPoints","nbDataBlocks","isValidPoint","nbCenterLayers","sides","sampleLine","getRotation","parameterData","side","correctedData","getCorrectedParameterData","cornerBits","idx","arr","bitCount","numECCodewords","parameterWords","ignored","pina","pinb","pinc","pind","color","pouta","getFirstDifferent","poutb","poutc","poutd","distancePoint","isWhiteOrBlackRectangle","pinax","pinbx","pincx","pindx","expandSquare","pointD","cornerPoints","detect","cx","cy","toResultPoint","getDimension","topLeft","topRight","bottomRight","bottomLeft","sampler","getInstance","dimension","distanceResultPoint","moduleSize","px","py","dx","dy","corr","cInit","getColor","error","colorModel","iMax","errRatio","init","isValid","oldSide","newSide","ratio","centerx","centery","result0","result2","point","AztecReader","exception","detector","getPoints","reportFoundResultPoints","getText","getRawBytes","getNumBits","AZTEC","getByteSegments","putMetadata","BYTE_SEGMENTS","getECLevel","ERROR_CORRECTION_LEVEL","rpcb","NEED_RESULT_POINT_CALLBACK","foundPossibleResultPoint","BrowserAztecCodeReader","OneDReader","doDecode","nfe","TRY_HARDER","rotatedImage","getResultMetadata","orientation","ORIENTATION","getResultPoints","maxLines","tryHarder","rowStep","middle","rowStepsAboveOrBelow","rowNumber","attempt","newHints","hint","key","delete","decodeRow","re","counters","numCounters","isWhite","counterPosition","numTransitionsLeft","last","recordPattern","pattern","maxIndividualVariance","total","patternLength","POSITIVE_INFINITY","unitBarWidth","totalVariance","counter","scaledPattern","variance","Code128Reader","codeSet","convertFNC1","ASSUME_GS1","startPatternInfo","findStartPattern","startCode","currentRawCodesIndex","rawCodes","CODE_START_A","CODE_CODE_A","CODE_START_B","CODE_CODE_B","CODE_START_C","CODE_CODE_C","isNextShifted","lastStart","nextStart","lastCode","checksumTotal","multiplier","lastCharacterWasPrintable","upperMode","shiftUpperMode","unshift","decodeCode","CODE_STOP","reduce","previous","current","CODE_FNC_1","CODE_FNC_2","CODE_FNC_3","CODE_FNC_4_A","CODE_SHIFT","CODE_FNC_4_B","lastPatternSize","getNextUnset","isRange","resultLength","rawCodesSize","CODE_128","getTime","getNextSet","patternStart","bestVariance","MAX_AVG_VARIANCE","bestMatch","patternMatchVariance","CODE_PATTERNS","MAX_INDIVIDUAL_VARIANCE","Code39Reader","usingCheckDigit","extendedMode","decodeRowResult","theCounters","decodedChar","findAsteriskPattern","toNarrowWidePattern","patternToChar","resultString","ALPHABET_STRING","indexOf","decodeExtended","CODE_39","ASTERISK_ENCODING","copyWithin","wideCounters","maxNarrowCounter","minCounter","totalWideCountersWidth","CHARACTER_ENCODINGS","encoded","decoded","ITFReader","arguments","narrowLineWidth","startRange","decodeStart","endRange","decodeEnd","decodeMiddle","allowedLengths","ALLOWED_LENGTHS","DEFAULT_ALLOWED_LENGTHS","lengthOK","maxAllowedLength","ITF","endStart","skipWhiteSpace","startPattern","findGuardPattern","START_PATTERN","validateQuietZone","quietCount","endPattern","END_PATTERN_REVERSED","payloadStart","payloadEnd","counterDigitPair","counterBlack","counterWhite","twoK","decodeDigit","counterDigit","PATTERNS","AbstractUPCEANReader","decodeRowStringBuffer","foundStart","START_END_PATTERN","quietStart","checkStandardUPCEANChecksum","check","getStandardUPCEANChecksum","digit","whiteFirst","MIDDLE_PATTERN","END_PATTERN","L_PATTERNS","UPCEANExtension5Support","CHECK_DIGIT_ENCODINGS","decodeMiddleCounters","extensionStartRange","extensionData","parseExtensionString","extensionResult","UPC_EAN_EXTENSION","putAllMetadata","lgPatternFound","L_AND_G_PATTERNS","checkDigit","determineCheckDigit","extensionChecksum","raw","parseExtension5String","SUGGESTED_PRICE","currency","rawAmount","hundredths","UPCEANExtension2Support","checkParity","ISSUE_NUMBER","UPCEANExtensionSupport","EXTENSION_START_PATTERN","UPCEANReader","widths","reversedWidths","startGuardRange","findStartGuardPattern","resultPointCallback","resultPoint","budello","quietEnd","checkChecksum","getBarcodeFormat","decodeResult","extensionLength","addResultPoints","allowedExtensions","ALLOWED_EAN_EXTENSIONS","valid","EAN_13","UPC_A","EAN13Reader","determineFirstDigit","FIRST_DIGIT_ENCODINGS","EAN8Reader","EAN_8","UPCAReader","ean13Reader","maybeReturnResult","upcaResult","UPCEReader","determineNumSysAndCheckDigit","findGuardPatternWithoutCounters","MIDDLE_END_PATTERN","convertUPCEtoUPCA","UPC_E","numSys","NUMSYS_AND_CHECK_DIGIT_PATTERNS","insert","getNotFoundInstance","upce","upceChars","lastChar","appendChars","MultiFormatUPCEANReader","possibleFormats","POSSIBLE_FORMATS","readers","ean13MayBeUPCA","canReturnUPCA","includes","resultUPCA","AbstractRSSReader","decodeFinderCounters","dataCharacterCounters","oddRoundingErrors","evenRoundingErrors","oddCounts","evenCounts","finderPatterns","errors","biggestError","firstTwoSum","MIN_FINDER_PATTERN_RATIO","MAX_FINDER_PATTERN_RATIO","maxCounter","DataCharacter","checksumPortion","that","FinderPattern","startEnd","RSSUtils","maxWidth","noNarrow","narrowMask","elements","bar","elmWidth","subVal","combins","lessVal","mxwElement","maxDenom","minDenom","BitArrayBuilder","pairs","charNumber","getRightChar","binary","accPos","firstValue","getValue","currentPair","leftValue","getLeftChar","rightValue","BlockParsedResult","finished","decodedInformation","DecodedObject","newPosition","DecodedChar","FNC1","DecodedInformation","newString","remainingValue","remaining","DecodedNumeric","firstDigit","secondDigit","FieldParser","rawInformation","firstTwoDigits","TWO_DIGIT_DATA_LENGTH","dataLength","VARIABLE_LENGTH","processVariableAI","processFixedAI","firstThreeDigits","THREE_DIGIT_DATA_LENGTH","THREE_DIGIT_PLUS_DIGIT_DATA_LENGTH","firstFourDigits","FOUR_DIGIT_DATA_LENGTH","aiSize","fieldSize","ai","parsedAI","parseFieldsInGeneralPurpose","variableFieldSize","GeneralAppIdDecoder","information","buff","initialPosition","currentPosition","info","decodeGeneralPurposeField","parsedFields","getNewString","isRemaining","getRemainingValue","getNewPosition","numeric","extractNumericValueFromBitArray","setLengthToZero","setPosition","lastDecoded","parseBlocks","getPosition","isFinished","isAlpha","parseAlphaBlock","isIsoIec646","parseIsoIec646Block","parseNumericBlock","getDecodedInformation","isStillNumeric","decodeNumeric","isFirstDigitFNC1","isSecondDigitFNC1","getSecondDigit","getFirstDigit","isNumericToAlphaNumericLatch","setAlpha","incrementPosition","isStillIsoIec646","iso","decodeIsoIec646","isFNC1","isAlphaOr646ToNumericLatch","setNumeric","isAlphaTo646ToAlphaLatch","isStillAlpha","alpha","decodeAlphanumeric","setIsoIec646","fiveBitValue","sevenBitValue","eightBitValue","sixBitValue","AbstractExpandedDecoder","generalDecoder","AI01decoder","buf","currentPos","encodeCompressedGtinWithoutAI","initialBufferPosition","currentBlock","getGeneralDecoder","appendCheckDigit","GTIN_SIZE","AI01AndOtherAIs","initialGtinPosition","firstGtinDigit","HEADER_SIZE","decodeAllCodes","AnyAIDecoder","AI01weightDecoder","weightSize","originalWeightNumeric","addWeightCode","weightNumeric","checkWeight","currentDivisor","AI013x0xDecoder","getInformation","WEIGHT_SIZE","encodeCompressedGtin","encodeCompressedWeight","AI013103decoder","weight","AI01320xDecoder","AI01392xDecoder","lastAIdigit","LAST_DIGIT_SIZE","AI01393xDecoder","FIRST_THREE_DIGITS_SIZE","generalInformation","AI013x0x1xDecoder","firstAIdigits","dateCode","DATE_SIZE","encodeCompressedDate","numericDate","day","month","year","createDecoder","ExpandedPair","leftChar","rightChar","finderPatter","mayBeLast","leftchar","rightchar","finderpattern","maybeLast","o1","o2","equalsOrNull","ExpandedRow","wasReversed","otherPairs","checkEqualitity","pair1","pair2","e1","e2","getFinderPatter","RSSExpandedReader","verbose","MAX_PAIRS","startFromEven","constructResult","decodeRow2pairs","tryStackedDecode","retrieveNextPair","storeRow","ps","checkRowsBoolean","checkRows","collectedRows","currentRow","collectedRow","getPairs","isValidSequence","rs","insertPos","prevIsSame","nextIsSame","erow","getRowNumber","isEquivalent","isPartialRow","removePartialRows","pp","firstPair","checkCharacter","firstCharacter","checksum","getChecksumPortion","currentRightChar","previousPairs","isOddPattern","keepFinding","forcedOffset","findNextPair","parseFoundFinderPattern","getNextSecondBar","decodeDataCharacter","isEmptyPair","mustBeLast","getDecodeFinderCounters","getFinderPattern","getStartEnd","searchingEvenPair","reverseCounters","isFinderPattern","oddPattern","firstCounter","firstElementStart","parseFinderValue","FINDER_PATTERNS","getDataCharacterCounters","recordPatternInReverse","numModules","elementWidth","expectedElementWidth","getOddCounts","getEvenCounts","getOddRoundingErrors","getEvenRoundingErrors","adjustOddEvenCounts","weightRowNumber","oddSum","oddChecksumPortion","isNotA1left","WEIGHTS","evenChecksumPortion","group","oddWidest","SYMBOL_WIDEST","evenWidest","vOdd","getRSSvalue","vEven","tEven","EVEN_TOTAL_SUBSET","gSum","GSUM","evenSum","incrementOdd","decrementOdd","incrementEven","decrementEven","mismatch","oddParityBad","evenParityBad","increment","decrement","FINDER_PATTERN_SEQUENCES","sequence","allFound","found","resultingString","buildBitArray","parseInformation","firstPoints","lastPoints","RSS_EXPANDED","initialPos","tmp","FINDER_PAT_A","FINDER_PAT_B","FINDER_PAT_C","FINDER_PAT_D","FINDER_PAT_E","FINDER_PAT_F","Pair","finderPattern","RSS14Reader","possibleLeftPairs","possibleRightPairs","leftPair","decodePair","addOrTally","rightPair","getCount","findFinderPattern","outside","inside","outsideChar","OUTSIDE_ODD_WIDEST","OUTSIDE_EVEN_TOTAL_SUBSET","OUTSIDE_GSUM","INSIDE_ODD_WIDEST","tOdd","INSIDE_ODD_TOTAL_SUBSET","INSIDE_GSUM","rightFinderPattern","firstIsBlack","possiblePairs","pair","incrementCount","symbolValue","leftPoints","rightPoints","RSS_14","checkValue","targetCheckValue","MultiFormatOneDReader","useCode39CheckDigit","ASSUME_CODE_39_CHECK_DIGIT","BrowserBarcodeReader","ECBlocks","ecCodewords","ecBlocks1","ecBlocks2","ecBlocks","ECB","dataCodewords","Version","versionNumber","symbolSizeRows","symbolSizeColumns","dataRegionSizeRows","dataRegionSizeColumns","getECCodewords","ecbArray","getECBlocks","ecBlock","getDataCodewords","totalCodewords","numRows","numColumns","VERSIONS","version","buildVersions","Mode","BitMatrixParser","bitMatrix","readVersion","mappingBitMatrix","extractDataRegion","readMappingMatrix","Int8Array","getTotalCodewords","resultOffset","column","corner1Read","corner2Read","corner3Read","corner4Read","readUtah","readCorner4","readCorner3","readCorner2","readCorner1","currentByte","readModule","getSymbolSizeRows","getSymbolSizeColumns","getDataRegionSizeRows","getDataRegionSizeColumns","numDataRegionsRow","numDataRegionsColumn","bitMatrixWithoutAlignment","dataRegionRow","dataRegionRowOffset","dataRegionColumn","dataRegionColumnOffset","readRowOffset","writeRowOffset","readColumnOffset","writeColumnOffset","getVersionForDimensions","DataBlock","codewords","rawCodewords","totalBlocks","ecBlockArray","numResultBlocks","numBlockCodewords","longerBlocksNumDataCodewords","shorterBlocksNumDataCodewords","rawCodewordsOffset","specialVersion","getVersionNumber","numLongerBlocks","jOffset","iOffset","BitSource","byteOffset","available","bitsLeft","toRead","bitsToNotRead","DecodedBitStreamParser","resultTrailer","mode","ASCII_ENCODE","decodeAsciiSegment","C40_ENCODE","decodeC40Segment","TEXT_ENCODE","decodeTextSegment","ANSIX12_ENCODE","decodeAnsiX12Segment","EDIFACT_ENCODE","decodeEdifactSegment","BASE256_ENCODE","decodeBase256Segment","PAD_ENCODE","upperShift","oneByte","readBits","cValues","firstByte","parseTwoBytes","cValue","C40_BASIC_SET_CHARS","c40char","C40_SHIFT2_SET_CHARS","TEXT_BASIC_SET_CHARS","textChar","TEXT_SHIFT2_SET_CHARS","TEXT_SHIFT3_SET_CHARS","secondByte","fullBitValue","edifactValue","getBitOffset","codewordPosition","getByteOffset","d1","unrandomize255State","uee","randomizedBase256Codeword","base256CodewordPosition","tempVariable","Decoder$1","rsDecoder","parser","getVersion","readCodewords","dataBlocks","getDataBlocks","totalBytes","getNumDataCodewords","resultBytes","dataBlocksCount","dataBlock","codewordBytes","getCodewords","correctErrors","codewordsInts","Detector$1","rectangleDetector","detectSolid1","detectSolid2","correctTopRight","shiftToModuleCenter","dimensionTop","transitionsBetween","dimensionRight","trAB","trBC","trCD","trDA","tr","pointBs","shiftPoint","pointCs","trTop","trRight","pointAs","candidate1","candidate2","dimH","dimV","pointDs","centerX","centerY","moveAway","fromX","fromY","toX","toY","steep","ystep","xstep","transitions","inBlack","isBlack","div","DataMatrixReader","decoder","has","PURE_BARCODE","extractPureBits","NO_POINTS","DATA_MATRIX","leftTopBlack","getTopLeftOnBit","rightBottomBlack","getBottomRightOnBit","matrixWidth","matrixHeight","nudge","ErrorCorrectionLevelValues","BrowserDatamatrixCodeReader","ErrorCorrectionLevel","stringValue","FOR_BITS","FOR_VALUE","L","M","Q","H","FormatInformation","formatInfo","errorCorrectionLevel","forBits","dataMask","maskedFormatInfo1","maskedFormatInfo2","doDecodeFormatInformation","FORMAT_INFO_MASK_QR","bestDifference","bestFormatInfo","FORMAT_INFO_DECODE_LOOKUP","decodeInfo","targetInfo","bitsDifference","numBitsDiffering","DataMaskValues","ECBlocks$1","ecCodewordsPerBlock","getNumBlocks","ECB$1","Version$1","alignmentPatternCenters","getECCodewordsPerBlock","getDimensionForVersion","setRegion","getVersionForNumber","versionBits","bestVersion","VERSION_DECODE_INFO","targetVersion","DataMask","isMasked","flip","DATA_MASK_000","DATA_MASK_001","DATA_MASK_010","DATA_MASK_011","DATA_MASK_100","DATA_MASK_101","DATA_MASK_110","DATA_MASK_111","ModeValues","BitMatrixParser$1","parsedFormatInfo","formatInfoBits1","copyBit","formatInfoBits2","jMin","decodeFormatInformation","parsedVersion","provisionalVersion","ijMin","theParsedVersion","decodeVersionInformation","readFormatInformation","getDataMask","unmaskBitMatrix","functionPattern","buildFunctionPattern","readingUp","bitsRead","col","DataBlock$1","getECBlocksForLevel","shorterBlocksTotalCodewords","longerBlocksStartAt","Mode$1","characterCountBitsForVersions","TERMINATOR","NUMERIC","ALPHANUMERIC","STRUCTURED_APPEND","BYTE","ECI","KANJI","FNC1_FIRST_POSITION","FNC1_SECOND_POSITION","HANZI","DecodedBitStreamParser$1","symbolSequence","parityData","currentCharacterSetECI","fc1InEffect","modeBits","parseECIValue","getCharacterSetECIByValue","subset","countHanzi","getCharacterCountBits","GB2312_SUBSET","decodeHanziSegment","decodeNumericSegment","decodeAlphanumericSegment","decodeByteSegment","decodeKanjiSegment","iae","twoBytes","assembledTwoBytes","readBytes","guessEncoding","ALPHANUMERIC_CHARS","nextTwoCharsBits","toAlphaNumericChar","deleteCharAt","setCharAt","threeDigitsBits","twoDigitsBits","digitBits","QRCodeDecoderMetaData","mirrored","Decoder$2","decodeBitMatrix","parseFromBooleanArray","decodeBitMatrixParser","remask","setMirror","mirror","setOther","getErrorCorrectionLevel","AlignmentPattern","posX","posY","estimatedModuleSize","moduleSizeDiff","newModuleSize","AlignmentPatternFinder","startX","startY","possibleCenters","crossCheckStateCount","maxJ","middleI","stateCount","iGen","currentState","foundPatternCross","confirmed","handlePossibleCenter","maxVariance","startI","centerJ","maxCount","originalStateCountTotal","maxI","stateCountTotal","centerFromEnd","centerI","crossCheckVertical","isNaN","aboutEquals","combineEstimate","FinderPattern$1","combinedCount","FinderPatternInfo","patternCenters","FinderPatternFinder","pureBarcode","iSkip","MAX_MODULES","MIN_SKIP","hasSkipped","haveMultiplyConfirmedCenters","rowSkip","findRowSkip","patternInfo","selectBestPatterns","orderBestPatterns","getCrossCheckStateCount","startJ","crossCheckHorizontal","crossCheckDiagonal","firstConfirmedCenter","CENTER_QUORUM","confirmedCount","totalModuleSize","getEstimatedModuleSize","totalDeviation","startSize","square","stdDev","sort","center1","center2","dA","dB","limit","splice","Detector$2","processFinderPatternInfo","getTopLeft","getTopRight","getBottomLeft","calculateModuleSize","computeDimension","getProvisionalVersionForDimension","modulesBetweenFPCenters","alignmentPattern","getAlignmentPatternCenters","bottomRightX","bottomRightY","correctionToTopLeft","estAlignmentX","estAlignmentY","findAlignmentInRegion","createTransform","calculateModuleSizeOneWay","otherPattern","moduleSizeEst1","sizeOfBlackWhiteBlackRunBothWays","moduleSizeEst2","sizeOfBlackWhiteBlackRun","otherToX","otherToY","state","xLimit","realX","realY","overallEstModuleSize","allowanceFactor","allowance","alignmentAreaLeftX","alignmentAreaRightX","alignmentAreaTopY","alignmentAreaBottomY","sourceBottomRightX","sourceBottomRightY","dimMinusThree","tltrCentersDimension","tlblCentersDimension","QRCodeReader","getOther","applyMirroredCorrection","QR_CODE","hasStructuredAppend","STRUCTURED_APPEND_SEQUENCE","getStructuredAppendSequenceNumber","STRUCTURED_APPEND_PARITY","getStructuredAppendParity","nudgedTooFarRight","nudgedTooFarDown","PDF417Common","moduleBitCount","list","EMPTY_INT_ARRAY","integer","symbol","binarySearch","SYMBOL_TABLE","CODEWORD_TABLE","NUMBER_OF_CODEWORDS","MAX_CODEWORDS_IN_BARCODE","MIN_ROWS_IN_BARCODE","MAX_ROWS_IN_BARCODE","MODULES_IN_CODEWORD","MODULES_IN_STOP_PATTERN","BARS_IN_MODULE","PDF417DetectorResult","Detector$3","multiple","barcodeCoordinates","clone","rotate180","foundBarcodeInRow","vertices","findVertices","barcodeCoordinate","ROW_STEP","startRow","startColumn","copyToResult","findRowsWithPattern","INDEXES_START_PATTERN","STOP_PATTERN","INDEXES_STOP_PATTERN","tmpResult","destinationIndexes","loc","previousRowLoc","stopRow","skippedRowCount","MAX_PATTERN_DRIFT","SKIPPED_ROW_COUNT_MAX","BARCODE_MIN_HEIGHT","fillWithin","pixelDrift","MAX_PIXEL_DRIFT","ModulusPoly","add","negative","multiplyOther","negativeCoefficients","subtract","ModulusGF","modulus","PDF417_GF","ErrorCorrection","S","evaluation","knownErrors","erasure","getChecksumInstance","errorLocatorDegree","formalDerivativeCoefficients","formalDerivative","numerator","BoundingBox","constructor_2","constructor_1","leftUnspecified","rightUnspecified","minX","maxX","minY","maxY","boundingBox","getBottomRight","getMinX","getMaxX","getMinY","getMaxY","missingStartRows","missingEndRows","isLeft","newTopLeft","newBottomLeft","newTopRight","newBottomRight","newMinY","newTop","newMaxY","newBottom","leftBox","rightBox","BarcodeMetadata","columnCount","rowCountUpperPart","rowCountLowerPart","rowCount","Formatter","form","DetectionResultColumn","imageRow","codeword","getCodeword","MAX_NEARBY_DISTANCE","nearImageRow","imageRowToCodewordIndex","formatter","BarcodeValue","confidence","maxConfidence","entries","entry","getKey","toIntArray","DetectionResultRowIndicatorColumn","_isLeft","setRowNumberAsRowIndicatorColumn","barcodeMetadata","setRowNumbers","removeIncorrectCodewords","getBoundingBox","firstRow","lastRow","barcodeRow","maxRowHeight","currentRowHeight","codewordsRow","rowDifference","getRowCount","checkedRows","closePreviousCodewordFound","getBarcodeMetadata","adjustIncompleteIndicatorColumnRowNumbers","barcodeColumnCount","barcodeRowCountUpperPart","barcodeRowCountLowerPart","barcodeECLevel","rowIndicatorValue","codewordRowNumber","setValue","codewordRow","getRowCountUpperPart","getRowCountLowerPart","getColumnCount","DetectionResult","ADJUST_ROW_NUMBER_SKIP","detectionResultColumns","adjustIndicatorColumnRowNumbers","previousUnadjustedCount","unadjustedCodewordCount","adjustRowNumbersAndGetCount","detectionResultColumn","adjustCompleteIndicatorColumnRowNumbers","unadjustedCount","adjustRowNumbersByRow","barcodeColumn","hasValidRowNumber","adjustRowNumbers","adjustRowNumbersFromBothRI","adjustRowNumbersFromLRI","adjustRowNumbersFromRRI","LRIcodewords","RRIcodewords","setRowNumber","rowIndicatorRowNumber","invalidRowCounts","adjustRowNumberIfValid","previousColumnCodewords","nextColumnCodewords","otherCodewords","otherCodeword","adjustRowNumber","rowIndicatorColumn","isValidRowNumber","getBucket","Codeword","endX","bucket","BARCODE_ROW_UNKNOWN","PDF417CodewordDecoder","currentSymbol","currentBit","RATIOS_TABLE","fround","bSymbolTableReady","decodedValue","getDecodedCodewordValue","sampleBitCounts","getClosestDecodedValue","bitCountSum","bitCountIndex","sumPreviousBits","sampleIndex","getBitValue","bitCountRatios","bestMatchError","initialize","ratioTableRow","diff","PDF417ResultMetadata","segmentCount","fileSize","segmentIndex","fileId","optionalData","lastSegment","sender","addressee","fileName","Long","NullPointerException","Mode$2","BigInteger","OutputStream","writeBytesOffset","off","write","OutOfMemoryError","ByteArrayOutputStream","minCapacity","grow","newCapacity","copyOfUint8Array","out","param","toString_string","toString_number","toString_void","charsetName","hibyte","getBigIntConstructor","createBigInt","getEXP900","EXP900","nineHundred","DecodedBitStreamParser$2","enableDecoding","codeIndex","TEXT_COMPACTION_MODE_LATCH","textCompaction","BYTE_COMPACTION_MODE_LATCH","BYTE_COMPACTION_MODE_LATCH_6","byteCompaction","MODE_SHIFT_TO_BYTE_COMPACTION_MODE","NUMERIC_COMPACTION_MODE_LATCH","numericCompaction","ECI_CHARSET","ECI_GENERAL_PURPOSE","ECI_USER_DEFINED","BEGIN_MACRO_PDF417_CONTROL_BLOCK","decodeMacroBlock","BEGIN_MACRO_PDF417_OPTIONAL_FIELD","MACRO_PDF417_TERMINATOR","getFormatInstance","NUMBER_OF_SEQUENCE_CODEWORDS","segmentIndexArray","setSegmentIndex","decodeBase900toBase10","setFileId","optionalFieldsStart","MACRO_PDF417_OPTIONAL_FIELD_FILE_NAME","setFileName","MACRO_PDF417_OPTIONAL_FIELD_SENDER","setSender","MACRO_PDF417_OPTIONAL_FIELD_ADDRESSEE","setAddressee","MACRO_PDF417_OPTIONAL_FIELD_SEGMENT_COUNT","setSegmentCount","MACRO_PDF417_OPTIONAL_FIELD_TIME_STAMP","setTimestamp","parseLong","MACRO_PDF417_OPTIONAL_FIELD_CHECKSUM","setChecksum","MACRO_PDF417_OPTIONAL_FIELD_FILE_SIZE","setFileSize","setLastSegment","optionalFieldsLength","isLastSegment","setOptionalData","copyOfRange","textCompactionData","byteCompactionData","decodeTextCompaction","subMode","ALPHA","priorToShiftMode","subModeCh","LL","ML","PS","PUNCT_SHIFT","AS","ALPHA_SHIFT","PL","MIXED_CHARS","AL","PAL","PUNCT_CHARS","decodedBytes","byteCompactedCodewords","nextCode","toByteArray","numericCodewords","MAX_NUMERIC_CODEWORDS","PDF417ScanningDecoder","imageTopLeft","imageBottomLeft","imageTopRight","imageBottomRight","minCodewordWidth","maxCodewordWidth","detectionResult","leftRowIndicatorColumn","rightRowIndicatorColumn","firstPass","getRowIndicatorColumn","merge","resultBox","setBoundingBox","maxBarcodeColumn","getBarcodeColumnCount","setDetectionResultColumn","leftToRight","getDetectionResultColumn","previousStartColumn","getStartColumn","detectCodeword","setCodeword","createDecoderResult","adjustBoundingBox","rowHeights","getRowHeights","getMax","rowHeight","addMissingRows","maxValue","leftBarcodeMetadata","rightBarcodeMetadata","startPoint","getStartX","getEndX","barcodeMatrix","barcodeMatrix01","numberOfCodewords","calculatedNumberOfCodewords","getBarcodeRowCount","getNumberOfECCodeWords","getBarcodeECLevel","createBarcodeMatrix","adjustCodewordCount","ambiguousIndexValuesList","ambiguousIndexesList","codewordIndex","ambiguousIndexValues","createDecoderResultFromAmbiguousValues","erasureArray","ambiguousIndexes","ambiguousIndexCount","tries","decodeCodewords","getDetectionResultColumns","isValidBarcodeColumn","getCodewordNearby","skippedColumns","previousRowCodeword","minColumn","maxColumn","adjustCodewordStartColumn","endColumn","getModuleBitCount","codewordBitCount","tmpCount","checkCodewordSkew","getDecodedValue","getCodewordBucketNumber","imageColumn","moduleNumber","previousPixelValue","codewordStartColumn","correctedStartColumn","CODEWORD_SKEW_SIZE","correctedErrorsCount","verifyCodewordCount","setErrorsCorrected","setErasures","MAX_ERRORS","MAX_EC_CODEWORDS","errorCorrection","previousValue","getCodewordBucketNumber_Int32Array","getCodewordBucketNumber_number","getBitCountForCodeword","barcodeValue","getConfidence","PDF417Reader","results","detectMultiple","getMinCodewordWidth","getMaxCodewordWidth","PDF_417","pdf417ResultMetadata","PDF417_EXTRA_METADATA","getMaxWidth","getMinWidth","ReaderException","EncodeHintType","MultiFormatReader","setHints","decodeInternal","formats","addOneDReader","some","CODABAR","CODE_93","BrowserMultiFormatReader","decodeWithState","BrowserPDF417Reader","BrowserQRCodeReader","EncodeHintType$1","ReedSolomonEncoder","cachedGenerators","lastGenerator","nextGenerator","toEncode","ecBytes","dataBytes","buildGenerator","infoCoefficients","divide","getCoefficients","numZeroCoefficients","MaskUtil","applyMaskPenaltyRule1Internal","penalty","getArray","arrayY","N2","numPenalties","isWhiteHorizontal","isWhiteVertical","N3","numDarkCells","numTotalCells","N4","maskPattern","intermediate","isHorizontal","iLimit","jLimit","numSameBitCells","prevBit","N1","ByteMatrix","aByte","bytesY","otherBytesY","QRCode","NUM_MASK_PATTERNS","WriterException","MatrixUtil","dataBits","clearMatrix","embedBasicPatterns","embedTypeInfo","maybeEmbedVersionInfo","embedDataBits","embedPositionDetectionPatternsAndSeparators","embedDarkDotAtLeftBottomCorner","maybeEmbedPositionAdjustmentPatterns","embedTimingPatterns","typeInfoBits","makeTypeInfoBits","coordinates","TYPE_INFO_COORDINATES","setBoolean","versionInfoBits","makeVersionInfoBits","bitIndex","direction","isEmpty","getDataMaskBit","numberOfLeadingZeros","msbSetInPoly","findMSBSet","isValidMaskPattern","typeInfo","appendBits","bchCode","calculateBCHCode","TYPE_INFO_POLY","maskBits","TYPE_INFO_MASK_PATTERN","xor","VERSION_INFO_POLY","setNumber","xStart","yStart","patternY","POSITION_ADJUSTMENT_PATTERN","POSITION_DETECTION_PATTERN","pdpWidth","embedPositionDetectionPattern","hspWidth","embedHorizontalSeparationPattern","vspSize","embedVerticalSeparationPattern","POSITION_ADJUSTMENT_PATTERN_COORDINATE_TABLE","embedPositionAdjustmentPattern","BlockPair","errorCorrectionBytes","Encoder","applyMaskPenaltyRule1","applyMaskPenaltyRule2","applyMaskPenaltyRule3","applyMaskPenaltyRule4","content","DEFAULT_BYTE_MODE_ENCODING","hasEncodingHint","chooseMode","headerBits","eci","appendECI","appendModeInfo","appendBytes","QR_VERSION","bitsNeeded","calculateBitsNeeded","willFit","recommendVersion","headerAndDataBits","appendBitArray","numLetters","getSizeInBytes","appendLengthInfo","numDataBytes","getTotalECCodewords","terminateBits","finalBits","interleaveWithECBytes","qrCode","setECLevel","setMode","setVersion","chooseMaskPattern","setMaskPattern","buildMatrix","setMatrix","provisionalBitsNeeded","chooseVersion","ALPHANUMERIC_TABLE","isOnlyDoubleByteKanji","hasNumeric","hasAlphanumeric","isDigit","getAlphanumericCode","byte1","minPenalty","bestMaskPattern","calculateMaskPenalty","numInputBits","versionNum","capacity","numBitsInLastByte","numPaddingBytes","numTotalBytes","numRSBlocks","blockID","numDataBytesInBlock","numECBytesInBlock","numRsBlocksInGroup2","numRsBlocksInGroup1","numTotalBytesInGroup1","numTotalBytesInGroup2","numDataBytesInGroup1","numDataBytesInGroup2","numEcBytesInGroup1","numEcBytesInGroup2","dataBytesOffset","maxNumDataBytes","maxNumEcBytes","blocks","numEcBytesInBlock","getNumDataBytesAndNumECBytesForBlockID","toBytes","generateECBytes","getDataBytes","getErrorCorrectionBytes","appendNumericBytes","appendAlphanumericBytes","append8BitBytes","appendKanjiBytes","singleCharacter","cn","getDigit","num1","num2","num3","code1","code2","subtracted","BrowserQRCodeSvgWriter","contents","quietZone","QUIET_ZONE_SIZE","ERROR_CORRECTION","fromString","MARGIN","renderResult","containerElement","querySelector","svgElement","appendChild","input","inputWidth","inputHeight","qrWidth","qrHeight","outputWidth","outputHeight","leftPadding","topPadding","createSVGElement","inputY","outputY","inputX","outputX","svgRectElement","createSvgRectElement","w","createElementNS","SVG_NS","setAttributeNS","rect","QRCodeWriter","output","MultiFormatWriter","PlanarYUVLuminanceSource","yuvData","dataWidth","dataHeight","reverseHorizontal","area","inputOffset","outputOffset","THUMBNAIL_SCALE_FACTOR","pixels","yuv","grey","rowStart","RGBLuminanceSource","BYTES_PER_ELEMENT","luminancesUint8Array","g2","Charset","StandardCharsets","ISO_8859_1","AztecCode","codeWords","Collections","item","collection","SimpleToken","bitArray","byteCount","toBinaryString","BinaryShiftToken","binaryShiftStart","binaryShiftByteCount","addBinaryShift","token","MODE_NAMES","MODE_UPPER","MODE_LOWER","MODE_DIGIT","MODE_MIXED","MODE_PUNCT","EMPTY_TOKEN","LATCH_TABLE","static_SHIFT_TABLE","SHIFT_TABLE","createInt32Array","State","binaryBytes","latch","latchModeBitCount","thisModeBitCount","deltaBitCount","endBinaryShift","newModeBitCount","calculateBinaryShiftCost","symbols","getPrevious","appendTo","static_CHAR_MAP","CHAR_MAP","spaceCharCode","getCharCode","pointCharCode","commaCharCode","zUpperCharCode","aUpperCharCode","zLowerCharCode","aLowerCharCode","nineCharCode","zeroCharCode","mixedTable","punctTable","INITIAL_STATE","HighLevelEncoder","lineBreakCharCode","states","singletonList","pairCode","nextChar","updateStateListForPair","updateStateListForChar","getBitCount","toBitArray","updateStateForChar","simplifyStates","charInCurrentTable","getMode","stateNoBinary","charInMode","latchState","latchAndAppend","shiftState","shiftAndAppend","getBinaryShiftByteCount","binaryState","addBinaryShiftChar","updateStateForPair","digitState","newState","oldState","isBetterThanOrEqualTo","filter","Encoder$1","DEFAULT_EC_PERCENT","DEFAULT_AZTEC_LAYERS","minECCPercent","userSpecifiedLayers","wordSize","eccBits","totalSizeBits","MAX_NB_BITS_COMPACT","MAX_NB_BITS","usableBitsInLayers","WORD_SIZE","stuffBits","messageBits","generateCheckWords","messageSizeInWords","modeMessage","generateModeMessage","drawModeMessage","drawBullsEye","aztec","setCompact","setSize","setLayers","setCodeWords","totalBits","getGF","totalWords","messageWords","bitsToWords","startPad","messageWord","word","AztecWriter","encodeWithHints","charset","eccPercent","forName","AZTEC_LAYERS","encodeLayers","getBytes","AztecCodeReader","AztecCodeWriter","AztecDecoder","AztecDetector","AztecEncoder","AztecHighLevelEncoder","AztecPoint","DataMatrixDecodedBitStreamParser","PDF417DecodedBitStreamParser","PDF417DecoderErrorCorrection","QRCodeByteMatrix","QRCodeDataMask","QRCodeDecodedBitStreamParser","QRCodeDecoderErrorCorrectionLevel","QRCodeDecoderFormatInformation","QRCodeEncoder","QRCodeEncoderQRCode","QRCodeMaskUtil","QRCodeMatrixUtil","QRCodeMode","QRCodeVersion","ZXingArrays","ZXingCharset","ZXingInteger","ZXingStandardCharsets","ZXingStringBuilder","ZXingStringEncoding","ZXingSystem","factory","aa","require","ca","da","Set","ea","fa","ha","ia","ja","ka","la","ma","g","acceptsBooleans","attributeName","attributeNamespace","mustUseProperty","propertyName","sanitizeURL","removeEmptyString","ra","sa","toUpperCase","ta","pa","qa","test","oa","xlinkHref","ua","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","va","Symbol","for","wa","ya","za","Aa","Ba","Ca","Da","Ea","Fa","Ga","Ha","Ia","Ja","iterator","Ka","La","A","assign","Ma","stack","trim","match","Na","Oa","prepareStackTrace","Reflect","construct","l","displayName","Pa","tag","render","Qa","$$typeof","_context","_payload","_init","Ra","Sa","Ta","Va","_valueTracker","getOwnPropertyDescriptor","configurable","stopTracking","Ua","Wa","checked","Xa","activeElement","body","Ya","defaultChecked","defaultValue","_wrapperState","initialChecked","Za","initialValue","controlled","ab","bb","cb","db","eb","isArray","fb","options","selected","defaultSelected","disabled","gb","dangerouslySetInnerHTML","children","hb","ib","jb","textContent","kb","lb","mb","nb","namespaceURI","innerHTML","valueOf","firstChild","removeChild","MSApp","execUnsafeLocalFunction","ob","lastChild","nodeType","nodeValue","pb","animationIterationCount","aspectRatio","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columns","flex","flexGrow","flexPositive","flexShrink","flexNegative","flexOrder","gridArea","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","fontWeight","lineClamp","lineHeight","opacity","order","orphans","tabSize","widows","zIndex","zoom","fillOpacity","floodOpacity","stopOpacity","strokeDasharray","strokeDashoffset","strokeMiterlimit","strokeOpacity","strokeWidth","qb","rb","sb","setProperty","keys","tb","menuitem","br","embed","hr","keygen","link","meta","track","wbr","ub","vb","is","wb","xb","correspondingUseElement","parentNode","yb","zb","Ab","Bb","Cb","stateNode","Db","Eb","Fb","Gb","Hb","Ib","Jb","Kb","Lb","Mb","Nb","onError","Ob","Pb","Qb","Rb","Sb","Tb","Vb","alternate","return","flags","Wb","memoizedState","dehydrated","Xb","Zb","child","sibling","Yb","$b","ac","unstable_scheduleCallback","bc","unstable_cancelCallback","cc","unstable_shouldYield","dc","unstable_requestPaint","B","unstable_now","ec","unstable_getCurrentPriorityLevel","fc","unstable_ImmediatePriority","gc","unstable_UserBlockingPriority","hc","unstable_NormalPriority","ic","unstable_LowPriority","jc","unstable_IdlePriority","kc","lc","oc","clz32","pc","qc","LN2","rc","sc","tc","uc","pendingLanes","suspendedLanes","pingedLanes","entangledLanes","entanglements","vc","xc","yc","zc","Ac","eventTimes","Cc","C","Dc","Ec","Fc","Gc","Hc","Ic","Jc","Kc","Lc","Mc","Nc","Oc","Pc","Qc","Rc","Sc","pointerId","Tc","nativeEvent","blockedOn","domEventName","eventSystemFlags","targetContainers","Vc","Wc","priority","isDehydrated","containerInfo","Xc","Yc","dispatchEvent","Zc","$c","ad","bd","cd","ReactCurrentBatchConfig","dd","ed","transition","fd","gd","hd","Uc","stopPropagation","jd","kd","ld","md","nd","od","keyCode","pd","qd","rd","_reactName","_targetInst","currentTarget","isDefaultPrevented","defaultPrevented","returnValue","isPropagationStopped","preventDefault","cancelBubble","persist","isPersistent","wd","xd","yd","sd","eventPhase","bubbles","cancelable","timeStamp","isTrusted","td","ud","view","detail","vd","Ad","screenX","screenY","clientX","clientY","pageX","pageY","ctrlKey","shiftKey","altKey","metaKey","getModifierState","zd","button","buttons","relatedTarget","fromElement","toElement","movementX","movementY","Bd","Dd","dataTransfer","Fd","Hd","animationName","elapsedTime","pseudoElement","Id","clipboardData","Jd","Ld","Md","Esc","Spacebar","Left","Up","Right","Down","Del","Win","Menu","Apps","Scroll","MozPrintableKey","Nd","Od","Alt","Control","Meta","Shift","Pd","Qd","location","repeat","locale","which","Rd","Td","pressure","tangentialPressure","tiltX","tiltY","twist","pointerType","isPrimary","Vd","touches","targetTouches","changedTouches","Xd","Yd","deltaX","wheelDeltaX","deltaY","wheelDeltaY","wheelDelta","deltaZ","deltaMode","Zd","$d","ae","be","documentMode","ce","de","ee","fe","ge","he","ie","le","date","datetime","email","number","password","range","search","tel","time","week","me","ne","oe","event","listeners","pe","qe","se","te","ue","ve","we","xe","ye","ze","oninput","Ae","detachEvent","Be","Ce","attachEvent","De","Ee","Fe","He","Ie","Je","Ke","node","nextSibling","Le","contains","compareDocumentPosition","Me","HTMLIFrameElement","contentWindow","href","Ne","contentEditable","Oe","focusedElem","selectionRange","documentElement","selectionStart","selectionEnd","defaultView","getSelection","extend","rangeCount","anchorNode","anchorOffset","focusNode","focusOffset","createRange","setStart","removeAllRanges","addRange","setEnd","scrollLeft","scrollTop","focus","Pe","Qe","Re","Se","Te","Ue","Ve","We","animationend","animationiteration","animationstart","transitionend","Xe","Ye","Ze","animation","$e","af","bf","cf","df","ef","ff","hf","lf","mf","concat","nf","Ub","instance","listener","D","of","pf","qf","rf","random","sf","bind","capture","passive","J","u","F","tf","uf","parentWindow","vf","wf","na","xa","$a","ba","je","char","ke","xf","yf","zf","Af","Bf","Cf","Df","Ef","__html","Ff","Gf","clearTimeout","Hf","Jf","queueMicrotask","catch","If","Kf","Lf","Mf","previousSibling","Nf","Of","Pf","Qf","Rf","Sf","Tf","Uf","E","G","Vf","Wf","Xf","Yf","contextTypes","__reactInternalMemoizedUnmaskedChildContext","__reactInternalMemoizedMaskedChildContext","Zf","childContextTypes","$f","ag","bg","getChildContext","cg","__reactInternalMemoizedMergedChildContext","dg","eg","fg","gg","hg","jg","kg","lg","mg","ng","og","pg","qg","rg","sg","tg","ug","vg","wg","xg","yg","I","zg","Ag","Bg","elementType","deletions","Cg","pendingProps","overflow","treeContext","retryLane","Dg","Eg","Fg","Gg","memoizedProps","Hg","Ig","Jg","Kg","Lg","defaultProps","Mg","Ng","Og","Pg","Qg","Rg","_currentValue","Sg","childLanes","Tg","dependencies","firstContext","lanes","Ug","Vg","context","memoizedValue","Wg","Xg","Yg","interleaved","Zg","$g","ah","updateQueue","baseState","firstBaseUpdate","lastBaseUpdate","shared","pending","effects","bh","eventTime","lane","payload","dh","K","eh","fh","gh","hh","ih","jh","Component","refs","kh","nh","isMounted","_reactInternals","enqueueSetState","lh","mh","enqueueReplaceState","enqueueForceUpdate","oh","shouldComponentUpdate","isPureReactComponent","ph","contextType","updater","qh","componentWillReceiveProps","UNSAFE_componentWillReceiveProps","rh","props","getDerivedStateFromProps","getSnapshotBeforeUpdate","UNSAFE_componentWillMount","componentWillMount","componentDidMount","sh","ref","_owner","_stringRef","th","join","uh","vh","wh","xh","yh","implementation","zh","Ah","Bh","Ch","Dh","Eh","Fh","Gh","Hh","Ih","tagName","Jh","Kh","Lh","Mh","revealOrder","Nh","Oh","_workInProgressVersionPrimary","Ph","ReactCurrentDispatcher","Qh","Rh","N","O","Sh","Th","Uh","Vh","Wh","Xh","Yh","Zh","$h","bi","ci","baseQueue","queue","di","ei","fi","lastRenderedReducer","action","hasEagerState","eagerState","lastRenderedState","dispatch","gi","hi","ii","ji","ki","getSnapshot","li","mi","ni","lastEffect","stores","oi","pi","qi","ri","destroy","deps","si","ui","vi","wi","Ai","Bi","Ci","Di","Ei","Fi","Gi","Hi","Ii","Ji","readContext","useCallback","useContext","useEffect","useImperativeHandle","useInsertionEffect","useLayoutEffect","useMemo","useReducer","useRef","useState","useDebugValue","useDeferredValue","useTransition","useMutableSource","useSyncExternalStore","useId","unstable_isNewReconciler","identifierPrefix","Ki","digest","Li","Mi","Ni","WeakMap","Oi","Pi","Qi","Ri","getDerivedStateFromError","componentDidCatch","Si","componentStack","Ti","pingCache","Ui","Vi","Wi","Xi","ReactCurrentOwner","Yi","Zi","$i","aj","bj","compare","cj","dj","ej","baseLanes","cachePool","fj","gj","hj","ij","jj","UNSAFE_componentWillUpdate","componentWillUpdate","componentDidUpdate","kj","lj","pendingContext","mj","Aj","Cj","Dj","nj","oj","pj","fallback","qj","rj","dataset","dgst","uj","vj","_reactRetry","sj","subtreeFlags","wj","isBackwards","rendering","renderingStartTime","tail","tailMode","Ej","Fj","Gj","wasMultiple","suppressHydrationWarning","onClick","onclick","autoFocus","createTextNode","T","Hj","Ij","Jj","Kj","U","Lj","WeakSet","V","Mj","W","Nj","Oj","Qj","Rj","Sj","Tj","Uj","Vj","Wj","insertBefore","_reactRootContainer","Xj","X","Yj","Zj","ak","onCommitFiberUnmount","componentWillUnmount","bk","ck","dk","ek","fk","isHidden","gk","hk","display","ik","jk","kk","lk","__reactInternalSnapshotBeforeUpdate","Wk","mk","nk","ok","pk","Y","Z","qk","rk","sk","tk","uk","Infinity","vk","wk","xk","yk","zk","Ak","Bk","Ck","Dk","Ek","callbackNode","expirationTimes","expiredLanes","wc","callbackPriority","ig","Fk","Gk","Hk","Ik","Jk","Kk","Lk","Mk","Nk","Ok","Pk","finishedWork","finishedLanes","Qk","timeoutHandle","Rk","Sk","Tk","Uk","Vk","mutableReadLanes","Bc","Pj","onCommitFiberRoot","mc","onRecoverableError","Xk","onPostCommitFiberRoot","Yk","Zk","al","isReactComponent","pendingChildren","bl","mutableSourceEagerHydrationData","cl","cache","pendingSuspenseBoundaries","dl","fl","gl","hl","il","jl","$k","ll","reportError","ml","_internalRoot","nl","ol","pl","ql","sl","rl","unmount","unstable_scheduleHydration","querySelectorAll","tl","usingClientEntryPoint","Events","ul","findFiberByHostInstance","bundleType","rendererPackageName","vl","rendererConfig","overrideHookState","overrideHookStateDeletePath","overrideHookStateRenamePath","overrideProps","overridePropsDeletePath","overridePropsRenamePath","setErrorHandler","setSuspenseHandler","scheduleUpdate","currentDispatcherRef","findHostInstanceByFiber","findHostInstancesForRefresh","scheduleRefresh","scheduleRoot","setRefreshHandler","getCurrentFiber","reconcilerVersion","__REACT_DEVTOOLS_GLOBAL_HOOK__","wl","isDisabled","supportsFiber","inject","createPortal","createRoot","unstable_strictMode","findDOMNode","flushSync","hydrate","hydrateRoot","hydratedSources","_getVersion","_source","unmountComponentAtNode","unstable_batchedUpdates","unstable_renderSubtreeIntoContainer","checkDCE","module","__self","__source","jsx","jsxs","setState","forceUpdate","escape","_status","_result","default","Children","toArray","only","Fragment","Profiler","PureComponent","StrictMode","Suspense","cloneElement","createContext","_currentValue2","_threadCount","Provider","Consumer","_defaultValue","_globalName","createFactory","createRef","forwardRef","isValidElement","lazy","memo","startTransition","unstable_act","pop","sortIndex","performance","setImmediate","startTime","expirationTime","priorityLevel","scheduling","isInputPending","MessageChannel","port2","port1","onmessage","postMessage","unstable_Profiling","unstable_continueExecution","unstable_forceFrameRate","unstable_getFirstCallbackNode","unstable_next","unstable_pauseExecution","unstable_runWithPriority","delay","unstable_wrapCallback","arr2","__esModule","ReferenceError","Constructor","TypeError","_defineProperties","descriptor","writable","protoProps","staticProps","unsupportedIterableToArray","allowArrayLike","it","_e","normalCompletion","didErr","_e2","getPrototypeOf","isNativeReflectConstruct","possibleConstructorReturn","Derived","hasNativeReflectConstruct","Super","NewTarget","superPropBase","_get","property","receiver","desc","_getPrototypeOf","subClass","superClass","sham","Proxy","Boolean","_i","_s","_arr","_n","_d","_typeof","assertThisInitialized","_regeneratorRuntime","Op","hasOwn","obj","$Symbol","iteratorSymbol","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","toStringTag","define","wrap","innerFn","outerFn","tryLocsList","protoGenerator","Generator","Context","makeInvokeMethod","tryCatch","arg","ContinueSentinel","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","NativeIteratorPrototype","Gp","defineIteratorMethods","method","_invoke","AsyncIterator","PromiseImpl","invoke","record","__await","unwrapped","previousPromise","callInvokeWithMethodAndArg","doneResult","delegateResult","maybeInvokeDelegate","sent","_sent","dispatchException","abrupt","resultName","nextLoc","pushTryEntry","locs","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","iterable","iteratorMethod","isGeneratorFunction","genFun","ctor","mark","awrap","async","iter","object","skipTempReset","prev","rootRecord","rval","handle","caught","hasCatch","hasFinally","finallyEntry","finish","thrown","delegateYield","_setPrototypeOf","arrayWithHoles","iterableToArrayLimit","nonIterableRest","arrayLikeToArray","minLen","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","definition","chunkId","all","promises","miniCssF","Function","prop","inProgress","dataWebpackPrefix","script","needAttach","scripts","getElementsByTagName","getAttribute","timeout","nc","onScriptComplete","onerror","onload","doneFns","head","installedChunks","installedChunkData","promise","errorType","realSrc","request","webpackJsonpCallback","parentChunkLoadingFunction","chunkIds","moreModules","runtime","chunkLoadingGlobal","_arrayLikeToArray","_unsupportedIterableToArray","_defineProperty","ownKeys","enumerableOnly","getOwnPropertySymbols","sym","_objectSpread2","getOwnPropertyDescriptors","defineProperties","asyncGeneratorStep","gen","_next","_throw","_asyncToGenerator","_classCallCheck","_createClass","KioskState","KeyboardManager","keyboardState","onKeydown","onKeyup","gamepadIndex","checkPressed","configData","GamepadManager","cachedGamepads","cacheExpires","minButtonPinRequired","minAxisRequired","keyboardManager","getGamepads","axes","gamepads","pinIndex","isButtonPressed","validateGamepadIndex","pressed","isAButtonPressed","isBButtonPressed","isEscapeButtonPressed","isResetButtonPressed","isMenuButtonPressed","axisIndex","isDirectionPressed","gamepad","isLeftPressed","isRightPressed","isUpPressed","isDownPressed","HighScore","initials","GameData","description","highScoreMode","uniqueIdentifier","userAdded","deleted","kioskBackendEndpoint","getGameCodesAsync","kioskCode","getGameCodeUrl","fetch","response","statusText","json","shareIds","gameCodeEntries","parse","generateKioskCodeAsync","codeGenerationUrl","newKioskCode","addGameToKioskAsync","kioskId","gameShareId","updateKioskUrl","headers","status","getGameDetailsAsync","gameId","gameDetailsUrl","tickEvent","pxtTickEvent","Kiosk","clean","locked","games","gamepadManager","selectedGame","selectedGameIndex","mostRecentScores","onGameSelected","onNavigated","launchedGame","MainMenu","highScoresLocalStorageKey","addedGamesLocalStorageKey","initializePromise","siteElements","intervalId","allScoresStateKey","lockedGameId","builtGamesCache","defaultGameDescription","addNewGamesToList","allAddedGames","getAllAddedGames","gamesToAdd","gameIds","gameName","gameDescription","gameDetails","getGameName","getGameDescription","gameUploadDate","toLocaleString","newGame","selectGame","localStorage","setItem","getItem","addedGames","game","resetHighScores","PlayingGame","escapeGame","showMainMenu","downloadGameListAsync","setInterval","gamePadLoop","js","getBuiltGame","sendBuiltGame","addBuiltGame","command","stateKey","rawData","atob","stateValue","gameOver","parts","channel","clearInterval","navigate","gameIndex","launchedGameHighs","getHighScores","currentHighScore","lastScore","exitGame","GameOver","EnterHighScore","skipHighScore","launchGame","exitToEnterHighScore","gamespace","remove","allBuiltGames","builtSimJs","builtGame","simIframe","preventReturningToMenu","playUrlBase","playQueryParam","playerIFrame","createIFrame","iframe","className","frameBorder","AddingGame","allHighScores","getAllHighScores","removeItem","specificButtonClass","kioskButtonClass","_objectWithoutProperties","excluded","sourceKeys","sourceSymbolKeys","propertyIsEnumerable","_toConsumableArray","isObject","ssrDocument","blur","createEvent","initEvent","childNodes","importNode","host","hostname","origin","pathname","protocol","getDocument","doc","ssrWindow","userAgent","history","replaceState","pushState","go","back","CustomEvent","getComputedStyle","getPropertyValue","Image","screen","matchMedia","requestAnimationFrame","cancelAnimationFrame","getWindow","win","_assertThisInitialized","_possibleConstructorReturn","_isNativeReflectConstruct","_construct","Parent","Class","_wrapNativeSuper","_cache","Wrapper","Dom7","items","proto","makeReactive","arrayFlat","arrayFilter","$","selector","html","toCreate","tempParent","qsa","uniqueArray","arrayUnique","noTrigger","shortcut","trigger","on","Methods","addClass","classes","classNames","classList","removeClass","hasClass","toggleClass","toggle","attr","attrs","attrName","removeAttr","duration","transitionDuration","eventType","targetSelector","handleLiveEvent","eventData","dom7EventData","parents","handleEvent","events","dom7LiveListeners","proxyListener","dom7Listeners","handlers","handler","dom7proxy","evt","dataIndex","transitionEnd","dom","fireCallBack","outerWidth","includeMargins","styles","offsetWidth","outerHeight","offsetHeight","box","getBoundingClientRect","clientTop","clientLeft","scrollY","scrollX","css","each","compareWith","matches","webkitMatchesSelector","msMatchesSelector","eq","returnIndex","newChild","tempDiv","prepend","nextElementSibling","nextAll","nextEls","previousElementSibling","prevAll","prevEls","parent","closest","foundElements","methodName","support","deviceCached","browser","deleteProps","nextTick","currentStyle","getTranslate","curTransform","transformMatrix","axis","curStyle","WebKitCSSMatrix","webkitTransform","MozTransform","OTransform","MsTransform","msTransform","m41","m42","isNode","HTMLElement","noExtend","nextSource","keysArray","nextIndex","nextKey","__swiper__","setCSSProperty","varName","varValue","animateCSSModeScroll","swiper","targetPosition","startPosition","params","speed","wrapperEl","scrollSnapType","cssModeFrameID","dir","isOutOfBound","animate","progress","easeProgress","scrollTo","getSupport","smoothScroll","touch","DocumentTouch","passiveListener","supportsPassive","opts","gestures","calcSupport","calcDevice","platform","ios","android","screenWidth","screenHeight","ipad","ipod","iphone","windows","macos","iPadScreens","os","getDevice","overrides","getBrowser","isSafari","isWebView","calcBrowser","eventsListeners","destroyed","once","onceHandler","__emitterProxy","onAny","eventsAnyListeners","offAny","eventHandler","emit","eventsArray","updateSize","$el","clientWidth","clientHeight","isVertical","updateSlides","getDirectionLabel","getDirectionPropertyValue","$wrapperEl","swiperSize","rtl","rtlTranslate","wrongRTL","isVirtual","virtual","enabled","previousSlidesLength","slides","slideClass","slidesLength","snapGrid","slidesGrid","slidesSizesGrid","offsetBefore","slidesOffsetBefore","offsetAfter","slidesOffsetAfter","previousSnapGridLength","previousSlidesGridLength","spaceBetween","slidePosition","prevSlideSize","virtualSize","marginLeft","marginBottom","marginTop","marginRight","centeredSlides","cssMode","slideSize","gridEnabled","grid","initSlides","shouldResetSlideSize","slidesPerView","breakpoints","slide","updateSlide","slideStyles","currentTransform","currentWebKitTransform","roundLengths","paddingLeft","paddingRight","boxSizing","swiperSlideSize","slidesPerGroup","slidesPerGroupSkip","effect","setWrapperSize","updateWrapperSize","newSlidesGrid","slidesGridItem","_","slideIndex","centeredSlidesBounds","allSlidesSize","slideSizeValue","maxSnap","snap","centerInsufficientSlides","allSlidesOffset","snapIndex","addToSnapGrid","addToSlidesGrid","watchOverflow","checkOverflow","watchSlidesProgress","updateSlidesOffset","backFaceHiddenClass","containerModifierClass","hasClassBackfaceClassAdded","maxBackfaceHiddenSlides","updateAutoHeight","activeSlides","setTransition","getSlideByIndex","visibleSlides","activeIndex","swiperSlideOffset","offsetLeft","offsetTop","updateSlidesProgress","offsetCenter","slideVisibleClass","visibleSlidesIndexes","slideOffset","slideProgress","minTranslate","originalSlideProgress","slideBefore","slideAfter","isVisible","originalProgress","updateProgress","translatesDiff","maxTranslate","isBeginning","isEnd","wasBeginning","wasEnd","autoHeight","updateSlidesClasses","activeSlide","realIndex","slideActiveClass","slideNextClass","slidePrevClass","slideDuplicateActiveClass","slideDuplicateNextClass","slideDuplicatePrevClass","slideDuplicateClass","nextSlide","prevSlide","emitSlidesClasses","updateActiveIndex","newActiveIndex","previousIndex","previousRealIndex","previousSnapIndex","normalizeSlideIndex","skip","initialized","runCallbacksOnInit","updateClickedSlide","slideFound","clickedSlide","clickedIndex","slideToClickedSlide","virtualTranslate","currentTranslate","setTranslate","byController","previousTranslate","translateTo","runCallbacks","translateBounds","internal","animating","preventInteractionOnTransition","newTranslate","isH","onTranslateToWrapperTransitionEnd","transitionEmit","transitionStart","slideTo","initial","indexAsNumber","isValidNumber","isFinite","normalizedTranslate","normalizedGrid","normalizedGridNext","allowSlideNext","allowSlidePrev","_immediateVirtual","_swiperImmediateVirtual","onSlideToWrapperTransitionEnd","slideToLoop","newIndex","loopedSlides","slideNext","perGroup","slidesPerGroupAuto","slidesPerViewDynamic","loopPreventsSlide","loopFix","_clientLeft","rewind","slidePrev","normalize","prevSnapIndex","normalizedSnapGrid","prevSnap","prevIndex","lastIndex","slideReset","slideToClosest","currentSnap","nextSnap","slideToIndex","loopCreate","$selector","loopFillGroupWithBlank","blankSlidesNum","blankNode","slideBlankClass","loopAdditionalSlides","loopedSlidesLimit","prependSlides","appendSlides","cloneNode","loopDestroy","onTouchStart","touchEventsData","originalEvent","$targetEl","touchEventsTarget","isTouchEvent","isTouched","isMoved","swipingClassHasValue","noSwipingClass","eventPath","composedPath","path","shadowRoot","noSwipingSelector","isTargetShadow","noSwiping","__closestFrom","assignedSlot","getRootNode","closestElement","allowClick","swipeHandler","currentX","currentY","edgeSwipeDetection","iOSEdgeSwipeDetection","edgeSwipeThreshold","iOSEdgeSwipeThreshold","innerWidth","allowTouchCallbacks","isScrolling","startMoving","touchStartTime","swipeDirection","allowThresholdMove","focusableElements","shouldPreventDefault","allowTouchMove","touchStartPreventDefault","touchStartForcePreventDefault","isContentEditable","freeMode","onTouchMove","targetTouch","preventedByNestedSwiper","touchReleaseOnEdges","diffX","diffY","touchAngle","atan2","touchMoveStopPropagation","nested","startTranslate","allowMomentumBounce","grabCursor","setGrabCursor","touchRatio","disableParentSwiper","resistanceRatio","resistance","followFinger","onTouchEnd","touchEndTime","timeDiff","pathTree","lastClickTime","stopIndex","groupSize","rewindFirstIndex","rewindLastIndex","longSwipesMs","longSwipes","longSwipesRatio","shortSwipes","navigation","nextEl","prevEl","onResize","setBreakpoint","autoplay","running","run","preventClicks","preventClicksPropagation","stopImmediatePropagation","onScroll","dummyEventAttached","dummyEventListener","touchEvents","domMethod","swiperMethod","passiveListeners","move","cancel","updateOnWindowResize","attachEvents","detachEvents","isGridEnabled","breakpoint","getBreakpoint","breakpointsBase","currentBreakpoint","breakpointParams","originalParams","wasMultiRow","isMultiRow","wasEnabled","emitContainerClasses","wasModuleEnabled","isModuleEnabled","disable","enable","directionChanged","needsReLoop","changeDirection","isEnabled","containerEl","currentHeight","innerHeight","minRatio","addClasses","suffixes","prefix","resultClasses","prepareClasses","removeClasses","initialSlide","resizeObserver","createElements","simulateTouch","uniqueNavElements","preloadImages","updateOnImagesReady","wrapperClass","_emitClasses","moduleExtendParams","allModulesParams","moduleParamName","moduleParams","auto","prototypes","eventsEmitter","update","moving","isLocked","cursor","unsetGrabCursor","wasLocked","lastSlideIndex","lastSlideRightEdge","images","loadImage","imageEl","srcset","sizes","checkForComplete","onReady","imagesLoaded","imagesToLoad","currentSrc","extendedDefaults","Swiper","swipers","newParams","modules","__modules__","mod","extendParams","swiperParams","defaults","passedParams","eventName","velocity","desktop","touchEventsTouch","touchEventsDesktop","clickTimeout","velocities","cls","slideEl","updates","getSlideClasses","spv","breakLoop","slideInView","translateValue","newDirection","needUpdate","currentDirection","mounted","getWrapperSelector","getWrapper","wrapper","mount","deleteInstance","cleanStyles","newDefaults","installModule","prototypeGroup","protoMethod","use","observer","animationFrame","resizeHandler","orientationChangeHandler","ResizeObserver","contentBoxSize","contentRect","inlineSize","blockSize","observe","unobserve","observers","attach","ObserverFunc","MutationObserver","WebkitMutationObserver","mutations","observerUpdate","attributes","childList","characterData","observeParents","observeSlideChildren","containerParents","disconnect","Keyboard","pageUpDown","keyboard","isPageUp","isPageDown","isArrowLeft","isArrowRight","isArrowUp","isArrowDown","onlyInViewport","inView","swiperWidth","swiperHeight","windowWidth","windowHeight","swiperOffset","swiperCoord","classesToSelector","Pagination","bulletSize","pfx","pagination","bulletElement","clickable","hideOnClick","renderBullet","renderProgressbar","renderFraction","renderCustom","progressbarOpposite","dynamicBullets","dynamicMainBullets","formatFractionCurrent","formatFractionTotal","bulletClass","bulletActiveClass","modifierClass","currentClass","totalClass","hiddenClass","progressbarFillClass","progressbarOppositeClass","clickableClass","lockClass","horizontalClass","verticalClass","paginationDisabledClass","bullets","dynamicBulletIndex","isPaginationDisabled","setSideBullets","$bulletEl","paginationType","firstIndex","midIndex","suffix","bullet","$bullet","bulletIndex","$firstDisplayedBullet","$lastDisplayedBullet","dynamicBulletsLength","bulletsOffset","offsetProp","progressbarDirection","scaleX","scaleY","paginationHTML","numberOfBullets","checkProps","createElementIfNotDefined","targetEl","createShadow","$slideEl","shadowClass","$shadowContainer","transformEl","$shadowEl","effectTarget","effectParams","EffectCoverflow","coverflowEffect","stretch","depth","modifier","slideShadows","requireUpdateOnVirtual","overwriteParams","perspective","recreateShadows","getEffectParams","overwriteParamsResult","effectInit","centerOffset","offsetMultiplier","rotateY","rotateX","translateZ","translateY","translateX","slideTransform","$shadowBeforeEl","$shadowAfterEl","needsNavigation","needsPagination","needsScrollbar","scrollbar","uniqueClasses","unique","paramsList","calcLoopedSlides","slidesPerViewParams","breakpointOnlyParams","isChildSwiperSlide","processChildren","React","getChildren","slots","slot","foundSlides","updateSwiper","needThumbsInit","needControllerInit","needPaginationInit","needScrollbarInit","needNavigationInit","changedParams","scrollbarEl","paginationEl","updateParams","currentParams","thumbs","controller","control","newValue","load","useIsomorphicLayoutEffect","SwiperSlideContext","SwiperContext","_extends","_temp","externalElRef","Tag","wrapperTag","WrapperTag","onSwiper","rest","eventsAssigned","containerClasses","setContainerClasses","virtualData","setVirtualData","breakpointChanged","setBreakpointChanged","initializedRef","swiperElRef","swiperRef","oldPassedParamsRef","oldSlides","nextElRef","prevElRef","paginationElRef","scrollbarElRef","splitEvents","allowedParams","plainObj","getParams","restProps","onBeforeBreakpoint","_containerClasses","initSwiper","SwiperCore","extendWith","renderExternal","renderExternalUpdate","mountSwiper","oldParams","oldChildren","addKey","oldChildrenKeys","childrenKeys","newKeys","oldKeys","newKey","oldKey","getChangedParams","parallax","renderVirtual","modifiedSlides","duplicateSlide","blankSlide","renderLoop","SwiperSlide","externalRef","virtualIndex","slideElRef","slideClasses","setSlideClasses","updateClasses","slideData","isActive","isDuplicate","isPrev","isNext","renderChildren","DeleteButton","focused","xmlns","viewBox","highScores","highScoresExist","highScore","addButtonSelected","deleteButtonSelected","carouselSelected","backgroundImage","kiosk","setGames","buttonSelected","localSwiper","leftKeyEvent","KeyboardEvent","rightKeyEvent","getGameIndex","changeFocusedItem","updateLoop","localSwiperIndex","clickItem","gameHighScores","active","changeFocus","cancelButtonState","setCancelButtonState","confirmButtonState","setConfirmButtonState","cancelClicked","confirmClicked","userAddedGames","deleteGame","setAddButtonState","setDeleteButtonState","deleteTriggered","setDeleteTriggered","lockedClassName","launchAddGame","isSelected","onCharacterChanged","setIndex","previousInitial","nextInitial","interval","indexChanged","setIndexChanged","setNextIndex","setPreviousIndex","setInitials","timesAPressed","setTimesAPressed","runOnce","setRunOnce","firstRun","setFirstRun","saveHighScore","updateTimesPressed","lcv","thisIndex","character","newInitials","updateInitial","renderInitials","highScoreInitials","highScoreScore","existingHighScores","aboveScores","belowScores","_createForOfIteratorHelper","qrcodegen","qrcodegen2","__defProp","__getOwnPropSymbols","__hasOwnProp","__propIsEnum","__defNormalProp","__spreadValues","__objRest","exclude","_QrCode","msk","isFunction","MIN_VERSION","MAX_VERSION","RangeError","drawFunctionPatterns","allCodewords","addEccAndInterleave","drawCodewords","applyMask","drawFormatBits","getPenaltyScore","assert","setFunctionModule","drawFinderPattern","alignPatPos","getAlignmentPatternPositions","numAlign","drawAlignmentPattern","drawVersion","formatBits","rem","getBit","isDark","ver","ecl","numBlocks","NUM_ERROR_CORRECTION_BLOCKS","ordinal","blockEccLen","ECC_CODEWORDS_PER_BLOCK","getNumRawDataModules","numShortBlocks","shortBlockLen","rsDiv","reedSolomonComputeDivisor","dat","ecc","reedSolomonComputeRemainder","block","vert","invert","runColor","runX","runHistory","PENALTY_N1","finderPenaltyAddHistory","finderPenaltyCountPatterns","PENALTY_N3","finderPenaltyTerminateAndCount","runY","PENALTY_N2","dark","PENALTY_N4","core","currentRunColor","currentRunLength","segs","QrSegment","makeSegments","encodeSegments","seg","makeBytes","dataUsedBits","minVersion","maxVersion","boostEcl","dataCapacityBits2","usedBits","getTotalBits","Ecc","MEDIUM","QUARTILE","HIGH","newEcl","numChars","numCharCountBits","getData","dataCapacityBits","padByte","root","reedSolomonMultiply","factor","coef","QrCode","cond","_QrSegment","bitData","digits","isNumeric","isAlphanumeric","ALPHANUMERIC_CHARSET","makeNumeric","makeAlphanumeric","toUtf8ByteArray","assignVal","NUMERIC_REGEX","ALPHANUMERIC_REGEX","ccbits","encodeURI","QrCode2","_Ecc","LOW","QrSegment2","_Mode","numBitsCharCount","qrcodegen_default","ERROR_LEVEL_MAP","DEFAULT_BGCOLOR","DEFAULT_FGCOLOR","generatePath","margin","ops","cell","excavateModules","excavation","getImageSettings","cells","includeMargin","imageSettings","numCells","defaultSize","excavate","floorX","floorY","Path2D","addPath","QRCodeSVG","_a","level","bgColor","fgColor","otherProps","encodeText","getModules","calculatedImageSettings","preserveAspectRatio","fgPath","shapeRendering","Html5QrcodeSupportedFormats","setActive","notificationLength","setKioskCode","renderQRCode","setRenderQRCode","menuButtonSelected","setMenuButtonState","qrCodeButtonSelected","setQrButtonState","notify","setNotify","notifyContent","setNotifyContent","generatingKioskCode","kioskCodeNextGenerationTime","nextSafePollTime","kioskCodeUrl","kioskTimeOutInMinutes","kioskCodeTime","kioskTime","getKioskCodeDuration","kioskLinkClicked","displayGamesAdded","notification","pollTimer","pollForGameCode","timeElapsed","timeToPoll","gameCodes","saveNewGamesAsync","justAddedGames","codeGenerationTimer","generatedCodeDuration","generateKioskCode","kioskCodeEndTime","endTime","storedKioskCode","kioskUrl","qrDivContent","DecodedTextType","Html5QrcodeScanType","html5QrcodeSupportedFormatsTextMap","MAXICODE","isValidHtml5QrcodeSupportedFormats","Html5QrcodeErrorTypes","Html5QrcodeConstants","SCAN_TYPE_CAMERA","SCAN_TYPE_FILE","formatName","QrcodeResultFormat","Html5QrcodeResultFactory","decodedText","qrcodeResult","Html5QrcodeErrorFactory","errorMessage","UNKWOWN_ERROR","BaseLoggger","isExperimental","isNullOrUndefined","Html5QrcodeScannerState","Html5QrcodeStrings","Html5QrcodeScannerStrings","LibraryInfoStrings","VideoConstraintsUtil","videoConstraints","logger","typeofVideoConstraints","logError","bannedkeysSet","keysInVideoConstraints_1","requestedFormats","ZXing","createReverseFormatMap","createZXingFormats","ZXingHtml5QrcodeDecoder","zxingDecoder","toHtml5QrcodeSupportedFormats","formatMap","zxingFormat","reverseFormatMap","zxingFormats","requestedFormats_1","requestedFormat","BarcodeDetectorDelegate","isSupported","createBarcodeDetectorFormats","BarcodeDetector","barcodes","largestBarcode","selectLargestBarcode","rawValue","maxArea","barcodes_1","barcode","barcodeDetectorFormat","experimentalFeatureConfig","useBarCodeDetectorIfSupported","Html5QrcodeShim","decodeAsync","finally","executionTime","executionResults","executions","possiblyFlushPerformanceReport","EXECUTIONS_TO_REPORT_PERFORMANCE","mean","ExperimentalFeaturesConfigFactory","config","Html5QrcodeScannerStatus","NOT_STARTED","UNKNOWN","StateManagerImpl","failIfTransitionOngoing","validateTransition","onGoingTransactionNewState","tempNewState","directTransition","failIfNewStateIs","PAUSED","SCANNING","disallowedStatesToTransition","disallowedStatesToTransition_1","stateManager","StateManagerProxy","getState","StateManagerFactory","Constants","fps","SCAN_DEFAULT_FPS","disableFlip","qrbox","DEFAULT_DISABLE_FLIP","InternalHtml5QrcodeConfig","elementId","configOrVerbosityFlag","experimentalFeatures","qrcode","getSupportedFormats","foreverScanTimeout","localMediaStream","shouldScan","stateManagerProxy","Html5Qrcode","cameraIdOrConfig","configuration","qrCodeSuccessCallback","qrCodeErrorCallback","internalConfig","clearElement","videoConstraintsAvailableAndValid","isMediaStreamConstraintsValid","areVideoConstraintsEnabled","isShadedBoxEnabled","rootElementWidth","DEFAULT_WIDTH","$this","toScanningStateChangeTransaction","createVideoConstraints","audio","onMediaStreamReceived","execute","isScanning","shouldPauseVideo","isStrictlyScanning","showPausedState","pause","isPaused","transitionToScanning","hidePausedState","onVideoResume","toStoppedStateTransaction","onAllTracksClosed","childElement","SHADED_REGION_ELEMENT_ID","removeQrRegion","qrRegion","tracksToClose","tracksClosed","videoTrack","removeTrack","imageFile","showImage","scanFileV2","html5qrcodeResult","File","canScanFile","possiblyCloseLastScanImageFile","lastScanImageFile","inputImage","imageWidth","imageHeight","containerWidth","containerHeight","FILE_SCAN_MIN_HEIGHT","computeCanvasDrawConfig","visibleCanvas","createCanvasElement","context_1","hiddenCanvas","onabort","onstalled","onsuspend","getCamerasFromMediaDevices","mst","MediaStreamTrack","getSources","getCamerasFromMediaStreamTrack","isHttpsOrLocalhost","getCapabilities","getSettings","videoConstaints","applyConstraints","devices_1","tracks_1","closeActiveStreams","sourceInfos","sourceInfos_1","sourceInfo","allFormats","formatsToSupport","supportedFormats","viewfinderWidth","viewfinderHeight","qrboxSize","validateQrboxConfig","configWidth","qrDimensions","toQrdimensions","validateMinSize","MIN_QR_BOX_SIZE","validateQrboxSize","shouldShadingBeApplied","defaultQrRegion","getShadedRegionBounds","possiblyInsertShadingElement","createScannerPausedUiElement","rootElement","scannerPausedUiElement","innerText","background","textAlign","possiblyUpdateShaders","widthRatio","heightRatio","sWidthOffset","sHeightOffset","sxOffset","syOffset","triggerNextScan","foreverScan","getTimeoutFps","scanContext","isSuccessfull","mediaStream","setupVideo","createVideoElement","onVideoStart","setupUi","logErrors","facingModeKey","deviceIdKey","allowedFacingModeValues_1","exactKey","isValidFacingModeValue","formerImageWidth","formerImageHeight","muted","playsInline","qrMatch","hasBorderShaders","borderShaders","shader","backgroundColor","BORDER_SHADER_MATCH_COLOR","BORDER_SHADER_DEFAULT_COLOR","revokeObjectURL","customId","canvasWidth","canvasHeight","shadingElement","rightLeftBorderSize","topBottomBorderSize","borderLeft","borderRight","borderTop","borderBottom","largeSize","insertShaderBorders","shaderElem","SVG_XML_PREFIX","ASSET_INFO_ICON_16PX","PersistedDataFactory","hasPermission","lastUsedCameraId","createDefault","PersistedDataManager","LOCAL_STORAGE_KEY","flush","infoDiv","LibraryInfoDiv","padding","border","fontSize","projectLink","breakElemFirst","breakElemSecond","reportIssueLink","onTapIn","onTapOut","infoIcon","LibraryInfoIcon","alt","onmouseover","onHoverIn","onmouseout","onHoverOut","isShowingInfoIcon","show","hide","LibraryInfoContainer","renderInto","CameraManager","supportedScanTypes","validateAndReturnScanTypes","ScanTypeSelector","scanType","isCameraScanType","maxExpectedValues","supportedScanTypes_1","html5Qrcode","buttonElement","onTorchActionFailureCallback","TorchController","isTorchOnExpected","isTorchOn","applyVideoConstraints","settings","getRunningTrackSettings","updateUiBasedOnLatestSettings","propagateFailure","error_1","torch","torchButton","torchController","TorchButton","torchButtonOptions","flipState","TorchUtils","mediaTrackSettings","createConfig","scanTypeSelector","currentScanType","getDefaultScanType","sectionSwapAllowed","persistedDataManager","rememberLastUsedCamera","Html5QrcodeScanner","lastMatchFound","setHeaderMessage","STATUS_SUCCESS","container","createBasicLayout","getScanRegionId","resume","emptyHtmlContainer","mainContainer","resetBasicLayout","getRunningTrackCapabilities","createHeader","qrCodeScanRegion","scanRegionId","minHeight","insertCameraScanImageToScanRegion","insertFileScanImageToScanRegion","qrCodeDashboard","dashboardId","getDashboardId","setupInitialDashboard","dashboard","createSection","createSectionControlPanel","hasMoreThanOneScanType","createSectionSwap","header","headerMessageContainer","getHeaderMessageContainerId","section","getDashboardSectionId","scpCameraScanRegion","requestPermissionContainer","requestPermissionButton","createPermissionButtonIfNotExists","createPermissionButton","cameras","setHasPermission","resetHeaderMessage","renderCameraSelection","STATUS_WARNING","getCameraPermissionButtonId","createCameraListUi","hasCameraPermissions","hasPermissions","sectionControlPanel","getDashboardSectionCameraScanRegionId","isCameraScanRequired","createPermissionsUi","renderFileScanUi","fileBasedScanRegion","getDashboardSectionFileScanRegionId","fileScanInput","getFileScanInputId","accept","fileScanLabel","files","file","cameraSelectionContainer","numCameras","cameraSelectionSelect","selectCameraString","getCameraSelectionId","cameras_1","camera","name_1","option","cameraActionContainer","cameraActionStartButton","cameraActionStopButton","cameraActionTorchButton","getTorchButton","resetCameraActionStartButton","shouldShow","showHideScanTypeSwapLink","cameraId","setLastUsedCameraId","showTorchButtonIfSupported","click","getLastUsedCameraId","cameraFound","options_1","resetLastUsedCameraId","TEXT_IF_CAMERA_SCAN_SELECTED","TEXT_IF_FILE_SCAN_SELECTED","switchContainer","switchScanTypeLink","textDecoration","getDashboardSectionSwapLinkId","getFileScanInput","clearScanRegion","getCameraScanRegion","getFileScanRegion","startCameraScanIfPermissionExistsOnSwap","permissionButton","messageText","scannerStatus","STATUS_DEFAULT","messageDiv","getHeaderMessageDiv","shouldDisplay","getDashboardSectionSwapLink","cameraScanImage","fileScanImage","html5QrCode","setAddError","setDesc","onScanSuccess","onScanFailure","decodedResult","shareId","exec","QrSuccess","getCameras","stopScan","errorDescription","setShowing","fullUrlHash","urlHashList","scannerVisible","setScannerVisible","linkError","setLinkError","addingError","setAddingError","errorDesc","setErrorDesc","qrReaderRendered","setHtml5QrCode","qrCodeReader","initiateQrCode","checkUrl","inputValue","shareLink","shareCode","submitVal","placeholder","spellCheck","required","title","onChange","homeButtonSelected","setHomeButtonState","retryButtonSelected","setRetryButtonState","kioskSingleton","onHashChange","addGame","ScanQR","alert","onhashchange","onPerfEntry","getCLS","getFID","getFCP","getLCP","getTTFB","enableAnalytics","stats","availWidth","availHeight","sysXDPI","systemXDPI","logicalXDPI","devicePixelRatio","firstElementChild","ReactDOM","reportWebVitals"],"sourceRoot":""} \ No newline at end of file diff --git a/kiosk/src/Components/AddingGame.tsx b/kiosk/src/Components/AddingGame.tsx index ddf7ea56752..7fe1d36ae79 100644 --- a/kiosk/src/Components/AddingGame.tsx +++ b/kiosk/src/Components/AddingGame.tsx @@ -32,7 +32,7 @@ const AddingGame: React.FC = ({ kiosk }) => { return parseInt(kioskCodeTime); } else if (kiosk.time) { const kioskTime = parseInt(kiosk.time); - return (kioskTime > 240 ? 240 : kioskTime) * 60; + return Math.min(240, Math.max(kioskTime, 0.5)) * 60; } else { return 30; }