omniauth-irma 0.1.0 → 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Rakefile +32 -2
- data/app/assets/config/omniauth_irma_manifest.js +2 -0
- data/app/assets/javascripts/irma.js +784 -0
- data/app/assets/stylesheets/omniauth/irma/application.css +15 -0
- data/lib/{irma.rb → omniauth/irma.rb} +1 -1
- data/lib/omniauth/irma/engine.rb +7 -0
- data/lib/omniauth/irma/version.rb +1 -1
- data/lib/omniauth/strategies/irma.rb +0 -2
- metadata +16 -19
- data/.gitignore +0 -8
- data/Gemfile +0 -6
- data/LICENSE.txt +0 -19
- data/bin/console +0 -14
- data/bin/setup +0 -8
- data/omniauth-irma.gemspec +0 -24
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: e615c8a63c03ec6ab32bfa290c306c036ed7aa4fce2003bc31e2c4d71806aca6
|
|
4
|
+
data.tar.gz: 971d92bd8bdffd166df7c7dc71af1e859260c4782ba010dc5ed2da5b2068595d
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 4e37c09cf45621e5dc2b75f4893cecb8421bd4ddd1ed8989dbae08d86840c8de07d20414f023f5eeb82c8e6b9220df5e60c00e5a0e03d2a25b9c914e8b66566d
|
|
7
|
+
data.tar.gz: d84a4a591316853edfd5829acbb90c8684823777b24caef51a0caa00aa239b74f5079050c119be4a5fc317a414827822c5b7645c54b431acb295694e078be359
|
data/Rakefile
CHANGED
|
@@ -1,2 +1,32 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
begin
|
|
2
|
+
require 'bundler/setup'
|
|
3
|
+
rescue LoadError
|
|
4
|
+
puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
|
|
5
|
+
end
|
|
6
|
+
|
|
7
|
+
require 'rdoc/task'
|
|
8
|
+
|
|
9
|
+
RDoc::Task.new(:rdoc) do |rdoc|
|
|
10
|
+
rdoc.rdoc_dir = 'rdoc'
|
|
11
|
+
rdoc.title = 'Omniauth::Irma'
|
|
12
|
+
rdoc.options << '--line-numbers'
|
|
13
|
+
rdoc.rdoc_files.include('README.md')
|
|
14
|
+
rdoc.rdoc_files.include('lib/**/*.rb')
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
APP_RAKEFILE = File.expand_path("test/dummy/Rakefile", __dir__)
|
|
18
|
+
load 'rails/tasks/engine.rake'
|
|
19
|
+
|
|
20
|
+
load 'rails/tasks/statistics.rake'
|
|
21
|
+
|
|
22
|
+
require 'bundler/gem_tasks'
|
|
23
|
+
|
|
24
|
+
require 'rake/testtask'
|
|
25
|
+
|
|
26
|
+
Rake::TestTask.new(:test) do |t|
|
|
27
|
+
t.libs << 'test'
|
|
28
|
+
t.pattern = 'test/**/*_test.rb'
|
|
29
|
+
t.verbose = false
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
task default: :test
|
|
@@ -0,0 +1,784 @@
|
|
|
1
|
+
(function webpackUniversalModuleDefinition(root, factory) {
|
|
2
|
+
if(typeof exports === 'object' && typeof module === 'object')
|
|
3
|
+
module.exports = factory(require("eventsource"), require("qrcode"));
|
|
4
|
+
else if(typeof define === 'function' && define.amd)
|
|
5
|
+
define(["eventsource", "qrcode"], factory);
|
|
6
|
+
else if(typeof exports === 'object')
|
|
7
|
+
exports["irma"] = factory(require("eventsource"), require("qrcode"));
|
|
8
|
+
else
|
|
9
|
+
root["irma"] = factory(root["eventsource"], root["qrcode"]);
|
|
10
|
+
})(window, function(__WEBPACK_EXTERNAL_MODULE_eventsource__, __WEBPACK_EXTERNAL_MODULE_qrcode_terminal__) {
|
|
11
|
+
return /******/ (function(modules) { // webpackBootstrap
|
|
12
|
+
/******/ // install a JSONP callback for chunk loading
|
|
13
|
+
/******/ function webpackJsonpCallback(data) {
|
|
14
|
+
/******/ var chunkIds = data[0];
|
|
15
|
+
/******/ var moreModules = data[1];
|
|
16
|
+
/******/
|
|
17
|
+
/******/
|
|
18
|
+
/******/ // add "moreModules" to the modules object,
|
|
19
|
+
/******/ // then flag all "chunkIds" as loaded and fire callback
|
|
20
|
+
/******/ var moduleId, chunkId, i = 0, resolves = [];
|
|
21
|
+
/******/ for(;i < chunkIds.length; i++) {
|
|
22
|
+
/******/ chunkId = chunkIds[i];
|
|
23
|
+
/******/ if(installedChunks[chunkId]) {
|
|
24
|
+
/******/ resolves.push(installedChunks[chunkId][0]);
|
|
25
|
+
/******/ }
|
|
26
|
+
/******/ installedChunks[chunkId] = 0;
|
|
27
|
+
/******/ }
|
|
28
|
+
/******/ for(moduleId in moreModules) {
|
|
29
|
+
/******/ if(Object.prototype.hasOwnProperty.call(moreModules, moduleId)) {
|
|
30
|
+
/******/ modules[moduleId] = moreModules[moduleId];
|
|
31
|
+
/******/ }
|
|
32
|
+
/******/ }
|
|
33
|
+
/******/ if(parentJsonpFunction) parentJsonpFunction(data);
|
|
34
|
+
/******/
|
|
35
|
+
/******/ while(resolves.length) {
|
|
36
|
+
/******/ resolves.shift()();
|
|
37
|
+
/******/ }
|
|
38
|
+
/******/
|
|
39
|
+
/******/ };
|
|
40
|
+
/******/
|
|
41
|
+
/******/
|
|
42
|
+
/******/ // The module cache
|
|
43
|
+
/******/ var installedModules = {};
|
|
44
|
+
/******/
|
|
45
|
+
/******/ // object to store loaded and loading chunks
|
|
46
|
+
/******/ // undefined = chunk not loaded, null = chunk preloaded/prefetched
|
|
47
|
+
/******/ // Promise = chunk loading, 0 = chunk loaded
|
|
48
|
+
/******/ var installedChunks = {
|
|
49
|
+
/******/ "main": 0
|
|
50
|
+
/******/ };
|
|
51
|
+
/******/
|
|
52
|
+
/******/
|
|
53
|
+
/******/
|
|
54
|
+
/******/ // script path function
|
|
55
|
+
/******/ function jsonpScriptSrc(chunkId) {
|
|
56
|
+
/******/ return __webpack_require__.p + "" + ({"vendors~jwt":"vendors~jwt","jwt":"jwt"}[chunkId]||chunkId) + ".js"
|
|
57
|
+
/******/ }
|
|
58
|
+
/******/
|
|
59
|
+
/******/ // The require function
|
|
60
|
+
/******/ function __webpack_require__(moduleId) {
|
|
61
|
+
/******/
|
|
62
|
+
/******/ // Check if module is in cache
|
|
63
|
+
/******/ if(installedModules[moduleId]) {
|
|
64
|
+
/******/ return installedModules[moduleId].exports;
|
|
65
|
+
/******/ }
|
|
66
|
+
/******/ // Create a new module (and put it into the cache)
|
|
67
|
+
/******/ var module = installedModules[moduleId] = {
|
|
68
|
+
/******/ i: moduleId,
|
|
69
|
+
/******/ l: false,
|
|
70
|
+
/******/ exports: {}
|
|
71
|
+
/******/ };
|
|
72
|
+
/******/
|
|
73
|
+
/******/ // Execute the module function
|
|
74
|
+
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
|
75
|
+
/******/
|
|
76
|
+
/******/ // Flag the module as loaded
|
|
77
|
+
/******/ module.l = true;
|
|
78
|
+
/******/
|
|
79
|
+
/******/ // Return the exports of the module
|
|
80
|
+
/******/ return module.exports;
|
|
81
|
+
/******/ }
|
|
82
|
+
/******/
|
|
83
|
+
/******/ // This file contains only the entry chunk.
|
|
84
|
+
/******/ // The chunk loading function for additional chunks
|
|
85
|
+
/******/ __webpack_require__.e = function requireEnsure(chunkId) {
|
|
86
|
+
/******/ var promises = [];
|
|
87
|
+
/******/
|
|
88
|
+
/******/
|
|
89
|
+
/******/ // JSONP chunk loading for javascript
|
|
90
|
+
/******/
|
|
91
|
+
/******/ var installedChunkData = installedChunks[chunkId];
|
|
92
|
+
/******/ if(installedChunkData !== 0) { // 0 means "already installed".
|
|
93
|
+
/******/
|
|
94
|
+
/******/ // a Promise means "currently loading".
|
|
95
|
+
/******/ if(installedChunkData) {
|
|
96
|
+
/******/ promises.push(installedChunkData[2]);
|
|
97
|
+
/******/ } else {
|
|
98
|
+
/******/ // setup Promise in chunk cache
|
|
99
|
+
/******/ var promise = new Promise(function(resolve, reject) {
|
|
100
|
+
/******/ installedChunkData = installedChunks[chunkId] = [resolve, reject];
|
|
101
|
+
/******/ });
|
|
102
|
+
/******/ promises.push(installedChunkData[2] = promise);
|
|
103
|
+
/******/
|
|
104
|
+
/******/ // start chunk loading
|
|
105
|
+
/******/ var head = document.getElementsByTagName('head')[0];
|
|
106
|
+
/******/ var script = document.createElement('script');
|
|
107
|
+
/******/ var onScriptComplete;
|
|
108
|
+
/******/
|
|
109
|
+
/******/ script.charset = 'utf-8';
|
|
110
|
+
/******/ script.timeout = 120;
|
|
111
|
+
/******/ if (__webpack_require__.nc) {
|
|
112
|
+
/******/ script.setAttribute("nonce", __webpack_require__.nc);
|
|
113
|
+
/******/ }
|
|
114
|
+
/******/ script.src = jsonpScriptSrc(chunkId);
|
|
115
|
+
/******/
|
|
116
|
+
/******/ onScriptComplete = function (event) {
|
|
117
|
+
/******/ // avoid mem leaks in IE.
|
|
118
|
+
/******/ script.onerror = script.onload = null;
|
|
119
|
+
/******/ clearTimeout(timeout);
|
|
120
|
+
/******/ var chunk = installedChunks[chunkId];
|
|
121
|
+
/******/ if(chunk !== 0) {
|
|
122
|
+
/******/ if(chunk) {
|
|
123
|
+
/******/ var errorType = event && (event.type === 'load' ? 'missing' : event.type);
|
|
124
|
+
/******/ var realSrc = event && event.target && event.target.src;
|
|
125
|
+
/******/ var error = new Error('Loading chunk ' + chunkId + ' failed.\n(' + errorType + ': ' + realSrc + ')');
|
|
126
|
+
/******/ error.type = errorType;
|
|
127
|
+
/******/ error.request = realSrc;
|
|
128
|
+
/******/ chunk[1](error);
|
|
129
|
+
/******/ }
|
|
130
|
+
/******/ installedChunks[chunkId] = undefined;
|
|
131
|
+
/******/ }
|
|
132
|
+
/******/ };
|
|
133
|
+
/******/ var timeout = setTimeout(function(){
|
|
134
|
+
/******/ onScriptComplete({ type: 'timeout', target: script });
|
|
135
|
+
/******/ }, 120000);
|
|
136
|
+
/******/ script.onerror = script.onload = onScriptComplete;
|
|
137
|
+
/******/ head.appendChild(script);
|
|
138
|
+
/******/ }
|
|
139
|
+
/******/ }
|
|
140
|
+
/******/ return Promise.all(promises);
|
|
141
|
+
/******/ };
|
|
142
|
+
/******/
|
|
143
|
+
/******/ // expose the modules object (__webpack_modules__)
|
|
144
|
+
/******/ __webpack_require__.m = modules;
|
|
145
|
+
/******/
|
|
146
|
+
/******/ // expose the module cache
|
|
147
|
+
/******/ __webpack_require__.c = installedModules;
|
|
148
|
+
/******/
|
|
149
|
+
/******/ // define getter function for harmony exports
|
|
150
|
+
/******/ __webpack_require__.d = function(exports, name, getter) {
|
|
151
|
+
/******/ if(!__webpack_require__.o(exports, name)) {
|
|
152
|
+
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
|
|
153
|
+
/******/ }
|
|
154
|
+
/******/ };
|
|
155
|
+
/******/
|
|
156
|
+
/******/ // define __esModule on exports
|
|
157
|
+
/******/ __webpack_require__.r = function(exports) {
|
|
158
|
+
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
|
159
|
+
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
160
|
+
/******/ }
|
|
161
|
+
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
|
162
|
+
/******/ };
|
|
163
|
+
/******/
|
|
164
|
+
/******/ // create a fake namespace object
|
|
165
|
+
/******/ // mode & 1: value is a module id, require it
|
|
166
|
+
/******/ // mode & 2: merge all properties of value into the ns
|
|
167
|
+
/******/ // mode & 4: return value when already ns object
|
|
168
|
+
/******/ // mode & 8|1: behave like require
|
|
169
|
+
/******/ __webpack_require__.t = function(value, mode) {
|
|
170
|
+
/******/ if(mode & 1) value = __webpack_require__(value);
|
|
171
|
+
/******/ if(mode & 8) return value;
|
|
172
|
+
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
|
|
173
|
+
/******/ var ns = Object.create(null);
|
|
174
|
+
/******/ __webpack_require__.r(ns);
|
|
175
|
+
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
|
|
176
|
+
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
|
|
177
|
+
/******/ return ns;
|
|
178
|
+
/******/ };
|
|
179
|
+
/******/
|
|
180
|
+
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
|
181
|
+
/******/ __webpack_require__.n = function(module) {
|
|
182
|
+
/******/ var getter = module && module.__esModule ?
|
|
183
|
+
/******/ function getDefault() { return module['default']; } :
|
|
184
|
+
/******/ function getModuleExports() { return module; };
|
|
185
|
+
/******/ __webpack_require__.d(getter, 'a', getter);
|
|
186
|
+
/******/ return getter;
|
|
187
|
+
/******/ };
|
|
188
|
+
/******/
|
|
189
|
+
/******/ // Object.prototype.hasOwnProperty.call
|
|
190
|
+
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
|
|
191
|
+
/******/
|
|
192
|
+
/******/ // __webpack_public_path__
|
|
193
|
+
/******/ __webpack_require__.p = "";
|
|
194
|
+
/******/
|
|
195
|
+
/******/ // on error function for async loading
|
|
196
|
+
/******/ __webpack_require__.oe = function(err) { console.error(err); throw err; };
|
|
197
|
+
/******/
|
|
198
|
+
/******/ var jsonpArray = window["webpackJsonpirma"] = window["webpackJsonpirma"] || [];
|
|
199
|
+
/******/ var oldJsonpFunction = jsonpArray.push.bind(jsonpArray);
|
|
200
|
+
/******/ jsonpArray.push = webpackJsonpCallback;
|
|
201
|
+
/******/ jsonpArray = jsonpArray.slice();
|
|
202
|
+
/******/ for(var i = 0; i < jsonpArray.length; i++) webpackJsonpCallback(jsonpArray[i]);
|
|
203
|
+
/******/ var parentJsonpFunction = oldJsonpFunction;
|
|
204
|
+
/******/
|
|
205
|
+
/******/
|
|
206
|
+
/******/ // Load entry module and return exports
|
|
207
|
+
/******/ return __webpack_require__(__webpack_require__.s = "./src/index.js");
|
|
208
|
+
/******/ })
|
|
209
|
+
/************************************************************************/
|
|
210
|
+
/******/ ({
|
|
211
|
+
|
|
212
|
+
/***/ "./node_modules/can-promise/index.js":
|
|
213
|
+
/*!*******************************************!*\
|
|
214
|
+
!*** ./node_modules/can-promise/index.js ***!
|
|
215
|
+
\*******************************************/
|
|
216
|
+
/*! no static exports found */
|
|
217
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
218
|
+
|
|
219
|
+
"use strict";
|
|
220
|
+
eval("\n\nvar G = __webpack_require__(/*! window-or-global */ \"./node_modules/window-or-global/lib/index.js\")\n\nmodule.exports = function() {\n return (\n typeof G.Promise === 'function' &&\n typeof G.Promise.prototype.then === 'function'\n )\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/can-promise/index.js?");
|
|
221
|
+
|
|
222
|
+
/***/ }),
|
|
223
|
+
|
|
224
|
+
/***/ "./node_modules/css-loader/index.js!./node_modules/sass-loader/lib/loader.js!./src/irma.scss":
|
|
225
|
+
/*!******************************************************************************************!*\
|
|
226
|
+
!*** ./node_modules/css-loader!./node_modules/sass-loader/lib/loader.js!./src/irma.scss ***!
|
|
227
|
+
\******************************************************************************************/
|
|
228
|
+
/*! no static exports found */
|
|
229
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
230
|
+
|
|
231
|
+
eval("exports = module.exports = __webpack_require__(/*! ../node_modules/css-loader/lib/css-base.js */ \"./node_modules/css-loader/lib/css-base.js\")(false);\n// imports\n\n\n// module\nexports.push([module.i, \"#irma-modal {\\n position: fixed;\\n top: 50%;\\n left: 50%;\\n height: auto;\\n z-index: 2000;\\n visibility: hidden;\\n backface-visibility: hidden;\\n transform: translateX(-50%) translateY(-50%); }\\n #irma-modal #modal-irmaqr {\\n width: 230px;\\n height: 230px; }\\n #irma-modal .modal-content {\\n font: 100% Ubuntu, sans-serif;\\n font-size: 14px;\\n background-color: #004C92;\\n padding: 10px 10px 30px 10px; }\\n #irma-modal p#irma-text {\\n color: #004C92;\\n height: 75px;\\n line-height: 130%; }\\n #irma-modal .irma-page {\\n margin: 0px auto; }\\n #irma-modal .irma-content {\\n background-color: white;\\n position: relative;\\n left: 0px;\\n width: 330px;\\n margin: 40px;\\n box-sizing: content-box;\\n border-style: solid;\\n border-width: 0px;\\n border-color: #004C92;\\n border-radius: 5px;\\n padding: 20px;\\n font-weight: 200;\\n z-index: 1; }\\n #irma-modal .irma-button-box {\\n width: 370px;\\n box-sizing: content-box;\\n padding-top: 5px;\\n margin-left: 40px;\\n margin-top: -40px;\\n margin-right: 40px;\\n text-align: right; }\\n #irma-modal .irma-logo-top {\\n position: absolute;\\n left: -40px;\\n top: -40px;\\n width: 160px;\\n box-sizing: content-box;\\n z-index: 2; }\\n #irma-modal .irma-title {\\n position: absolute;\\n top: -30px;\\n right: 0px;\\n height: 40px;\\n box-sizing: content-box;\\n text-align: right;\\n color: white;\\n font-weight: 700;\\n text-transform: uppercase;\\n font-size: 20px; }\\n #irma-modal .irma-option-container {\\n text-align: center;\\n margin: 30px auto; }\\n #irma-modal .irma-option-box {\\n width: 230px;\\n height: 230px;\\n box-sizing: content-box;\\n border-style: solid;\\n border-width: medium;\\n border-color: #d0d0d0;\\n border-radius: 6px;\\n padding: 6px;\\n display: inline-block;\\n margin: 5px; }\\n #irma-modal .irma-button {\\n height: 40px;\\n display: inline-block;\\n box-sizing: content-box;\\n margin: 0;\\n padding: 0 0.5em;\\n color: white;\\n font-weight: 700;\\n text-transform: uppercase;\\n font-size: 16px;\\n text-align: center;\\n background-color: #888;\\n border-radius: 5px;\\n border: 0px none;\\n cursor: pointer; }\\n #irma-modal #irma-text {\\n text-align: justify;\\n padding-left: 125px;\\n font-size: 15px; }\\n #irma-modal .irma-dialog {\\n box-shadow: 0 0 50px rgba(0, 0, 0, 0.5);\\n -webkit-transform: translateY(-30%);\\n -moz-transform: translateY(-30%);\\n -ms-transform: translateY(-30%);\\n transform: translateY(-30%);\\n opacity: 0;\\n -webkit-transition: all 0.3s;\\n -moz-transition: all 0.3s;\\n transition: all 0.3s; }\\n #irma-modal.irma-show .irma-dialog {\\n -webkit-transform: translateY(0);\\n -moz-transform: translateY(0);\\n -ms-transform: translateY(0);\\n transform: translateY(0);\\n opacity: 1; }\\n\\n.irma-show {\\n visibility: visible !important; }\\n\\n.irma-overlay {\\n position: fixed;\\n width: 100%;\\n height: 100%;\\n visibility: hidden;\\n top: 0;\\n left: 0;\\n z-index: 1000;\\n opacity: 0;\\n background: rgba(0, 0, 0, 0.5);\\n transition: all 0.3s; }\\n\\n.irma-show ~ .irma-overlay {\\n opacity: 1;\\n visibility: visible; }\\n\", \"\"]);\n\n// exports\n\n\n//# sourceURL=webpack://irma/./src/irma.scss?./node_modules/css-loader!./node_modules/sass-loader/lib/loader.js");
|
|
232
|
+
|
|
233
|
+
/***/ }),
|
|
234
|
+
|
|
235
|
+
/***/ "./node_modules/css-loader/lib/css-base.js":
|
|
236
|
+
/*!*************************************************!*\
|
|
237
|
+
!*** ./node_modules/css-loader/lib/css-base.js ***!
|
|
238
|
+
\*************************************************/
|
|
239
|
+
/*! no static exports found */
|
|
240
|
+
/***/ (function(module, exports) {
|
|
241
|
+
|
|
242
|
+
eval("/*\n\tMIT License http://www.opensource.org/licenses/mit-license.php\n\tAuthor Tobias Koppers @sokra\n*/\n// css base code, injected by the css-loader\nmodule.exports = function(useSourceMap) {\n\tvar list = [];\n\n\t// return the list of modules as css string\n\tlist.toString = function toString() {\n\t\treturn this.map(function (item) {\n\t\t\tvar content = cssWithMappingToString(item, useSourceMap);\n\t\t\tif(item[2]) {\n\t\t\t\treturn \"@media \" + item[2] + \"{\" + content + \"}\";\n\t\t\t} else {\n\t\t\t\treturn content;\n\t\t\t}\n\t\t}).join(\"\");\n\t};\n\n\t// import a list of modules into the list\n\tlist.i = function(modules, mediaQuery) {\n\t\tif(typeof modules === \"string\")\n\t\t\tmodules = [[null, modules, \"\"]];\n\t\tvar alreadyImportedModules = {};\n\t\tfor(var i = 0; i < this.length; i++) {\n\t\t\tvar id = this[i][0];\n\t\t\tif(typeof id === \"number\")\n\t\t\t\talreadyImportedModules[id] = true;\n\t\t}\n\t\tfor(i = 0; i < modules.length; i++) {\n\t\t\tvar item = modules[i];\n\t\t\t// skip already imported module\n\t\t\t// this implementation is not 100% perfect for weird media query combinations\n\t\t\t// when a module is imported multiple times with different media queries.\n\t\t\t// I hope this will never occur (Hey this way we have smaller bundles)\n\t\t\tif(typeof item[0] !== \"number\" || !alreadyImportedModules[item[0]]) {\n\t\t\t\tif(mediaQuery && !item[2]) {\n\t\t\t\t\titem[2] = mediaQuery;\n\t\t\t\t} else if(mediaQuery) {\n\t\t\t\t\titem[2] = \"(\" + item[2] + \") and (\" + mediaQuery + \")\";\n\t\t\t\t}\n\t\t\t\tlist.push(item);\n\t\t\t}\n\t\t}\n\t};\n\treturn list;\n};\n\nfunction cssWithMappingToString(item, useSourceMap) {\n\tvar content = item[1] || '';\n\tvar cssMapping = item[3];\n\tif (!cssMapping) {\n\t\treturn content;\n\t}\n\n\tif (useSourceMap && typeof btoa === 'function') {\n\t\tvar sourceMapping = toComment(cssMapping);\n\t\tvar sourceURLs = cssMapping.sources.map(function (source) {\n\t\t\treturn '/*# sourceURL=' + cssMapping.sourceRoot + source + ' */'\n\t\t});\n\n\t\treturn [content].concat(sourceURLs).concat([sourceMapping]).join('\\n');\n\t}\n\n\treturn [content].join('\\n');\n}\n\n// Adapted from convert-source-map (MIT)\nfunction toComment(sourceMap) {\n\t// eslint-disable-next-line no-undef\n\tvar base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap))));\n\tvar data = 'sourceMappingURL=data:application/json;charset=utf-8;base64,' + base64;\n\n\treturn '/*# ' + data + ' */';\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/css-loader/lib/css-base.js?");
|
|
243
|
+
|
|
244
|
+
/***/ }),
|
|
245
|
+
|
|
246
|
+
/***/ "./node_modules/dijkstrajs/dijkstra.js":
|
|
247
|
+
/*!*********************************************!*\
|
|
248
|
+
!*** ./node_modules/dijkstrajs/dijkstra.js ***!
|
|
249
|
+
\*********************************************/
|
|
250
|
+
/*! no static exports found */
|
|
251
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
252
|
+
|
|
253
|
+
"use strict";
|
|
254
|
+
eval("\n\n/******************************************************************************\n * Created 2008-08-19.\n *\n * Dijkstra path-finding functions. Adapted from the Dijkstar Python project.\n *\n * Copyright (C) 2008\n * Wyatt Baldwin <self@wyattbaldwin.com>\n * All rights reserved\n *\n * Licensed under the MIT license.\n *\n * http://www.opensource.org/licenses/mit-license.php\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n *****************************************************************************/\nvar dijkstra = {\n single_source_shortest_paths: function(graph, s, d) {\n // Predecessor map for each node that has been encountered.\n // node ID => predecessor node ID\n var predecessors = {};\n\n // Costs of shortest paths from s to all nodes encountered.\n // node ID => cost\n var costs = {};\n costs[s] = 0;\n\n // Costs of shortest paths from s to all nodes encountered; differs from\n // `costs` in that it provides easy access to the node that currently has\n // the known shortest path from s.\n // XXX: Do we actually need both `costs` and `open`?\n var open = dijkstra.PriorityQueue.make();\n open.push(s, 0);\n\n var closest,\n u, v,\n cost_of_s_to_u,\n adjacent_nodes,\n cost_of_e,\n cost_of_s_to_u_plus_cost_of_e,\n cost_of_s_to_v,\n first_visit;\n while (!open.empty()) {\n // In the nodes remaining in graph that have a known cost from s,\n // find the node, u, that currently has the shortest path from s.\n closest = open.pop();\n u = closest.value;\n cost_of_s_to_u = closest.cost;\n\n // Get nodes adjacent to u...\n adjacent_nodes = graph[u] || {};\n\n // ...and explore the edges that connect u to those nodes, updating\n // the cost of the shortest paths to any or all of those nodes as\n // necessary. v is the node across the current edge from u.\n for (v in adjacent_nodes) {\n if (adjacent_nodes.hasOwnProperty(v)) {\n // Get the cost of the edge running from u to v.\n cost_of_e = adjacent_nodes[v];\n\n // Cost of s to u plus the cost of u to v across e--this is *a*\n // cost from s to v that may or may not be less than the current\n // known cost to v.\n cost_of_s_to_u_plus_cost_of_e = cost_of_s_to_u + cost_of_e;\n\n // If we haven't visited v yet OR if the current known cost from s to\n // v is greater than the new cost we just found (cost of s to u plus\n // cost of u to v across e), update v's cost in the cost list and\n // update v's predecessor in the predecessor list (it's now u).\n cost_of_s_to_v = costs[v];\n first_visit = (typeof costs[v] === 'undefined');\n if (first_visit || cost_of_s_to_v > cost_of_s_to_u_plus_cost_of_e) {\n costs[v] = cost_of_s_to_u_plus_cost_of_e;\n open.push(v, cost_of_s_to_u_plus_cost_of_e);\n predecessors[v] = u;\n }\n }\n }\n }\n\n if (typeof d !== 'undefined' && typeof costs[d] === 'undefined') {\n var msg = ['Could not find a path from ', s, ' to ', d, '.'].join('');\n throw new Error(msg);\n }\n\n return predecessors;\n },\n\n extract_shortest_path_from_predecessor_list: function(predecessors, d) {\n var nodes = [];\n var u = d;\n var predecessor;\n while (u) {\n nodes.push(u);\n predecessor = predecessors[u];\n u = predecessors[u];\n }\n nodes.reverse();\n return nodes;\n },\n\n find_path: function(graph, s, d) {\n var predecessors = dijkstra.single_source_shortest_paths(graph, s, d);\n return dijkstra.extract_shortest_path_from_predecessor_list(\n predecessors, d);\n },\n\n /**\n * A very naive priority queue implementation.\n */\n PriorityQueue: {\n make: function (opts) {\n var T = dijkstra.PriorityQueue,\n t = {},\n key;\n opts = opts || {};\n for (key in T) {\n if (T.hasOwnProperty(key)) {\n t[key] = T[key];\n }\n }\n t.queue = [];\n t.sorter = opts.sorter || T.default_sorter;\n return t;\n },\n\n default_sorter: function (a, b) {\n return a.cost - b.cost;\n },\n\n /**\n * Add a new item to the queue and ensure the highest priority element\n * is at the front of the queue.\n */\n push: function (value, cost) {\n var item = {value: value, cost: cost};\n this.queue.push(item);\n this.queue.sort(this.sorter);\n },\n\n /**\n * Return the highest priority element in the queue.\n */\n pop: function () {\n return this.queue.shift();\n },\n\n empty: function () {\n return this.queue.length === 0;\n }\n }\n};\n\n\n// node.js module exports\nif (true) {\n module.exports = dijkstra;\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/dijkstrajs/dijkstra.js?");
|
|
255
|
+
|
|
256
|
+
/***/ }),
|
|
257
|
+
|
|
258
|
+
/***/ "./node_modules/es6-object-assign/index.js":
|
|
259
|
+
/*!*************************************************!*\
|
|
260
|
+
!*** ./node_modules/es6-object-assign/index.js ***!
|
|
261
|
+
\*************************************************/
|
|
262
|
+
/*! no static exports found */
|
|
263
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
264
|
+
|
|
265
|
+
"use strict";
|
|
266
|
+
eval("/**\n * Code refactored from Mozilla Developer Network:\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/assign\n */\n\n\n\nfunction assign(target, firstSource) {\n if (target === undefined || target === null) {\n throw new TypeError('Cannot convert first argument to object');\n }\n\n var to = Object(target);\n for (var i = 1; i < arguments.length; i++) {\n var nextSource = arguments[i];\n if (nextSource === undefined || nextSource === null) {\n continue;\n }\n\n var keysArray = Object.keys(Object(nextSource));\n for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex++) {\n var nextKey = keysArray[nextIndex];\n var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n if (desc !== undefined && desc.enumerable) {\n to[nextKey] = nextSource[nextKey];\n }\n }\n }\n return to;\n}\n\nfunction polyfill() {\n if (!Object.assign) {\n Object.defineProperty(Object, 'assign', {\n enumerable: false,\n configurable: true,\n writable: true,\n value: assign\n });\n }\n}\n\nmodule.exports = {\n assign: assign,\n polyfill: polyfill\n};\n\n\n//# sourceURL=webpack://irma/./node_modules/es6-object-assign/index.js?");
|
|
267
|
+
|
|
268
|
+
/***/ }),
|
|
269
|
+
|
|
270
|
+
/***/ "./node_modules/es6-promise/dist/es6-promise.js":
|
|
271
|
+
/*!******************************************************!*\
|
|
272
|
+
!*** ./node_modules/es6-promise/dist/es6-promise.js ***!
|
|
273
|
+
\******************************************************/
|
|
274
|
+
/*! no static exports found */
|
|
275
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
276
|
+
|
|
277
|
+
eval("/* WEBPACK VAR INJECTION */(function(process, global) {/*!\n * @overview es6-promise - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors (Conversion to ES6 API by Jake Archibald)\n * @license Licensed under MIT license\n * See https://raw.githubusercontent.com/stefanpenner/es6-promise/master/LICENSE\n * @version v4.2.5+7f2b526d\n */\n\n(function (global, factory) {\n\t true ? module.exports = factory() :\n\tundefined;\n}(this, (function () { 'use strict';\n\nfunction objectOrFunction(x) {\n var type = typeof x;\n return x !== null && (type === 'object' || type === 'function');\n}\n\nfunction isFunction(x) {\n return typeof x === 'function';\n}\n\n\n\nvar _isArray = void 0;\nif (Array.isArray) {\n _isArray = Array.isArray;\n} else {\n _isArray = function (x) {\n return Object.prototype.toString.call(x) === '[object Array]';\n };\n}\n\nvar isArray = _isArray;\n\nvar len = 0;\nvar vertxNext = void 0;\nvar customSchedulerFn = void 0;\n\nvar asap = function asap(callback, arg) {\n queue[len] = callback;\n queue[len + 1] = arg;\n len += 2;\n if (len === 2) {\n // If len is 2, that means that we need to schedule an async flush.\n // If additional callbacks are queued before the queue is flushed, they\n // will be processed by this flush that we are scheduling.\n if (customSchedulerFn) {\n customSchedulerFn(flush);\n } else {\n scheduleFlush();\n }\n }\n};\n\nfunction setScheduler(scheduleFn) {\n customSchedulerFn = scheduleFn;\n}\n\nfunction setAsap(asapFn) {\n asap = asapFn;\n}\n\nvar browserWindow = typeof window !== 'undefined' ? window : undefined;\nvar browserGlobal = browserWindow || {};\nvar BrowserMutationObserver = browserGlobal.MutationObserver || browserGlobal.WebKitMutationObserver;\nvar isNode = typeof self === 'undefined' && typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n// test for web worker but not in IE10\nvar isWorker = typeof Uint8ClampedArray !== 'undefined' && typeof importScripts !== 'undefined' && typeof MessageChannel !== 'undefined';\n\n// node\nfunction useNextTick() {\n // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n // see https://github.com/cujojs/when/issues/410 for details\n return function () {\n return process.nextTick(flush);\n };\n}\n\n// vertx\nfunction useVertxTimer() {\n if (typeof vertxNext !== 'undefined') {\n return function () {\n vertxNext(flush);\n };\n }\n\n return useSetTimeout();\n}\n\nfunction useMutationObserver() {\n var iterations = 0;\n var observer = new BrowserMutationObserver(flush);\n var node = document.createTextNode('');\n observer.observe(node, { characterData: true });\n\n return function () {\n node.data = iterations = ++iterations % 2;\n };\n}\n\n// web worker\nfunction useMessageChannel() {\n var channel = new MessageChannel();\n channel.port1.onmessage = flush;\n return function () {\n return channel.port2.postMessage(0);\n };\n}\n\nfunction useSetTimeout() {\n // Store setTimeout reference so es6-promise will be unaffected by\n // other code modifying setTimeout (like sinon.useFakeTimers())\n var globalSetTimeout = setTimeout;\n return function () {\n return globalSetTimeout(flush, 1);\n };\n}\n\nvar queue = new Array(1000);\nfunction flush() {\n for (var i = 0; i < len; i += 2) {\n var callback = queue[i];\n var arg = queue[i + 1];\n\n callback(arg);\n\n queue[i] = undefined;\n queue[i + 1] = undefined;\n }\n\n len = 0;\n}\n\nfunction attemptVertx() {\n try {\n var vertx = Function('return this')().require('vertx');\n vertxNext = vertx.runOnLoop || vertx.runOnContext;\n return useVertxTimer();\n } catch (e) {\n return useSetTimeout();\n }\n}\n\nvar scheduleFlush = void 0;\n// Decide what async method to use to triggering processing of queued callbacks:\nif (isNode) {\n scheduleFlush = useNextTick();\n} else if (BrowserMutationObserver) {\n scheduleFlush = useMutationObserver();\n} else if (isWorker) {\n scheduleFlush = useMessageChannel();\n} else if (browserWindow === undefined && \"function\" === 'function') {\n scheduleFlush = attemptVertx();\n} else {\n scheduleFlush = useSetTimeout();\n}\n\nfunction then(onFulfillment, onRejection) {\n var parent = this;\n\n var child = new this.constructor(noop);\n\n if (child[PROMISE_ID] === undefined) {\n makePromise(child);\n }\n\n var _state = parent._state;\n\n\n if (_state) {\n var callback = arguments[_state - 1];\n asap(function () {\n return invokeCallback(_state, child, callback, parent._result);\n });\n } else {\n subscribe(parent, child, onFulfillment, onRejection);\n }\n\n return child;\n}\n\n/**\n `Promise.resolve` returns a promise that will become resolved with the\n passed `value`. It is shorthand for the following:\n\n ```javascript\n let promise = new Promise(function(resolve, reject){\n resolve(1);\n });\n\n promise.then(function(value){\n // value === 1\n });\n ```\n\n Instead of writing the above, your code now simply becomes the following:\n\n ```javascript\n let promise = Promise.resolve(1);\n\n promise.then(function(value){\n // value === 1\n });\n ```\n\n @method resolve\n @static\n @param {Any} value value that the returned promise will be resolved with\n Useful for tooling.\n @return {Promise} a promise that will become fulfilled with the given\n `value`\n*/\nfunction resolve$1(object) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (object && typeof object === 'object' && object.constructor === Constructor) {\n return object;\n }\n\n var promise = new Constructor(noop);\n resolve(promise, object);\n return promise;\n}\n\nvar PROMISE_ID = Math.random().toString(36).substring(2);\n\nfunction noop() {}\n\nvar PENDING = void 0;\nvar FULFILLED = 1;\nvar REJECTED = 2;\n\nvar TRY_CATCH_ERROR = { error: null };\n\nfunction selfFulfillment() {\n return new TypeError(\"You cannot resolve a promise with itself\");\n}\n\nfunction cannotReturnOwn() {\n return new TypeError('A promises callback cannot return that same promise.');\n}\n\nfunction getThen(promise) {\n try {\n return promise.then;\n } catch (error) {\n TRY_CATCH_ERROR.error = error;\n return TRY_CATCH_ERROR;\n }\n}\n\nfunction tryThen(then$$1, value, fulfillmentHandler, rejectionHandler) {\n try {\n then$$1.call(value, fulfillmentHandler, rejectionHandler);\n } catch (e) {\n return e;\n }\n}\n\nfunction handleForeignThenable(promise, thenable, then$$1) {\n asap(function (promise) {\n var sealed = false;\n var error = tryThen(then$$1, thenable, function (value) {\n if (sealed) {\n return;\n }\n sealed = true;\n if (thenable !== value) {\n resolve(promise, value);\n } else {\n fulfill(promise, value);\n }\n }, function (reason) {\n if (sealed) {\n return;\n }\n sealed = true;\n\n reject(promise, reason);\n }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n if (!sealed && error) {\n sealed = true;\n reject(promise, error);\n }\n }, promise);\n}\n\nfunction handleOwnThenable(promise, thenable) {\n if (thenable._state === FULFILLED) {\n fulfill(promise, thenable._result);\n } else if (thenable._state === REJECTED) {\n reject(promise, thenable._result);\n } else {\n subscribe(thenable, undefined, function (value) {\n return resolve(promise, value);\n }, function (reason) {\n return reject(promise, reason);\n });\n }\n}\n\nfunction handleMaybeThenable(promise, maybeThenable, then$$1) {\n if (maybeThenable.constructor === promise.constructor && then$$1 === then && maybeThenable.constructor.resolve === resolve$1) {\n handleOwnThenable(promise, maybeThenable);\n } else {\n if (then$$1 === TRY_CATCH_ERROR) {\n reject(promise, TRY_CATCH_ERROR.error);\n TRY_CATCH_ERROR.error = null;\n } else if (then$$1 === undefined) {\n fulfill(promise, maybeThenable);\n } else if (isFunction(then$$1)) {\n handleForeignThenable(promise, maybeThenable, then$$1);\n } else {\n fulfill(promise, maybeThenable);\n }\n }\n}\n\nfunction resolve(promise, value) {\n if (promise === value) {\n reject(promise, selfFulfillment());\n } else if (objectOrFunction(value)) {\n handleMaybeThenable(promise, value, getThen(value));\n } else {\n fulfill(promise, value);\n }\n}\n\nfunction publishRejection(promise) {\n if (promise._onerror) {\n promise._onerror(promise._result);\n }\n\n publish(promise);\n}\n\nfunction fulfill(promise, value) {\n if (promise._state !== PENDING) {\n return;\n }\n\n promise._result = value;\n promise._state = FULFILLED;\n\n if (promise._subscribers.length !== 0) {\n asap(publish, promise);\n }\n}\n\nfunction reject(promise, reason) {\n if (promise._state !== PENDING) {\n return;\n }\n promise._state = REJECTED;\n promise._result = reason;\n\n asap(publishRejection, promise);\n}\n\nfunction subscribe(parent, child, onFulfillment, onRejection) {\n var _subscribers = parent._subscribers;\n var length = _subscribers.length;\n\n\n parent._onerror = null;\n\n _subscribers[length] = child;\n _subscribers[length + FULFILLED] = onFulfillment;\n _subscribers[length + REJECTED] = onRejection;\n\n if (length === 0 && parent._state) {\n asap(publish, parent);\n }\n}\n\nfunction publish(promise) {\n var subscribers = promise._subscribers;\n var settled = promise._state;\n\n if (subscribers.length === 0) {\n return;\n }\n\n var child = void 0,\n callback = void 0,\n detail = promise._result;\n\n for (var i = 0; i < subscribers.length; i += 3) {\n child = subscribers[i];\n callback = subscribers[i + settled];\n\n if (child) {\n invokeCallback(settled, child, callback, detail);\n } else {\n callback(detail);\n }\n }\n\n promise._subscribers.length = 0;\n}\n\nfunction tryCatch(callback, detail) {\n try {\n return callback(detail);\n } catch (e) {\n TRY_CATCH_ERROR.error = e;\n return TRY_CATCH_ERROR;\n }\n}\n\nfunction invokeCallback(settled, promise, callback, detail) {\n var hasCallback = isFunction(callback),\n value = void 0,\n error = void 0,\n succeeded = void 0,\n failed = void 0;\n\n if (hasCallback) {\n value = tryCatch(callback, detail);\n\n if (value === TRY_CATCH_ERROR) {\n failed = true;\n error = value.error;\n value.error = null;\n } else {\n succeeded = true;\n }\n\n if (promise === value) {\n reject(promise, cannotReturnOwn());\n return;\n }\n } else {\n value = detail;\n succeeded = true;\n }\n\n if (promise._state !== PENDING) {\n // noop\n } else if (hasCallback && succeeded) {\n resolve(promise, value);\n } else if (failed) {\n reject(promise, error);\n } else if (settled === FULFILLED) {\n fulfill(promise, value);\n } else if (settled === REJECTED) {\n reject(promise, value);\n }\n}\n\nfunction initializePromise(promise, resolver) {\n try {\n resolver(function resolvePromise(value) {\n resolve(promise, value);\n }, function rejectPromise(reason) {\n reject(promise, reason);\n });\n } catch (e) {\n reject(promise, e);\n }\n}\n\nvar id = 0;\nfunction nextId() {\n return id++;\n}\n\nfunction makePromise(promise) {\n promise[PROMISE_ID] = id++;\n promise._state = undefined;\n promise._result = undefined;\n promise._subscribers = [];\n}\n\nfunction validationError() {\n return new Error('Array Methods must be provided an Array');\n}\n\nvar Enumerator = function () {\n function Enumerator(Constructor, input) {\n this._instanceConstructor = Constructor;\n this.promise = new Constructor(noop);\n\n if (!this.promise[PROMISE_ID]) {\n makePromise(this.promise);\n }\n\n if (isArray(input)) {\n this.length = input.length;\n this._remaining = input.length;\n\n this._result = new Array(this.length);\n\n if (this.length === 0) {\n fulfill(this.promise, this._result);\n } else {\n this.length = this.length || 0;\n this._enumerate(input);\n if (this._remaining === 0) {\n fulfill(this.promise, this._result);\n }\n }\n } else {\n reject(this.promise, validationError());\n }\n }\n\n Enumerator.prototype._enumerate = function _enumerate(input) {\n for (var i = 0; this._state === PENDING && i < input.length; i++) {\n this._eachEntry(input[i], i);\n }\n };\n\n Enumerator.prototype._eachEntry = function _eachEntry(entry, i) {\n var c = this._instanceConstructor;\n var resolve$$1 = c.resolve;\n\n\n if (resolve$$1 === resolve$1) {\n var _then = getThen(entry);\n\n if (_then === then && entry._state !== PENDING) {\n this._settledAt(entry._state, i, entry._result);\n } else if (typeof _then !== 'function') {\n this._remaining--;\n this._result[i] = entry;\n } else if (c === Promise$1) {\n var promise = new c(noop);\n handleMaybeThenable(promise, entry, _then);\n this._willSettleAt(promise, i);\n } else {\n this._willSettleAt(new c(function (resolve$$1) {\n return resolve$$1(entry);\n }), i);\n }\n } else {\n this._willSettleAt(resolve$$1(entry), i);\n }\n };\n\n Enumerator.prototype._settledAt = function _settledAt(state, i, value) {\n var promise = this.promise;\n\n\n if (promise._state === PENDING) {\n this._remaining--;\n\n if (state === REJECTED) {\n reject(promise, value);\n } else {\n this._result[i] = value;\n }\n }\n\n if (this._remaining === 0) {\n fulfill(promise, this._result);\n }\n };\n\n Enumerator.prototype._willSettleAt = function _willSettleAt(promise, i) {\n var enumerator = this;\n\n subscribe(promise, undefined, function (value) {\n return enumerator._settledAt(FULFILLED, i, value);\n }, function (reason) {\n return enumerator._settledAt(REJECTED, i, reason);\n });\n };\n\n return Enumerator;\n}();\n\n/**\n `Promise.all` accepts an array of promises, and returns a new promise which\n is fulfilled with an array of fulfillment values for the passed promises, or\n rejected with the reason of the first passed promise to be rejected. It casts all\n elements of the passed iterable to promises as it runs this algorithm.\n\n Example:\n\n ```javascript\n let promise1 = resolve(1);\n let promise2 = resolve(2);\n let promise3 = resolve(3);\n let promises = [ promise1, promise2, promise3 ];\n\n Promise.all(promises).then(function(array){\n // The array here would be [ 1, 2, 3 ];\n });\n ```\n\n If any of the `promises` given to `all` are rejected, the first promise\n that is rejected will be given as an argument to the returned promises's\n rejection handler. For example:\n\n Example:\n\n ```javascript\n let promise1 = resolve(1);\n let promise2 = reject(new Error(\"2\"));\n let promise3 = reject(new Error(\"3\"));\n let promises = [ promise1, promise2, promise3 ];\n\n Promise.all(promises).then(function(array){\n // Code here never runs because there are rejected promises!\n }, function(error) {\n // error.message === \"2\"\n });\n ```\n\n @method all\n @static\n @param {Array} entries array of promises\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise} promise that is fulfilled when all `promises` have been\n fulfilled, or rejected if any of them become rejected.\n @static\n*/\nfunction all(entries) {\n return new Enumerator(this, entries).promise;\n}\n\n/**\n `Promise.race` returns a new promise which is settled in the same way as the\n first passed promise to settle.\n\n Example:\n\n ```javascript\n let promise1 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 1');\n }, 200);\n });\n\n let promise2 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 2');\n }, 100);\n });\n\n Promise.race([promise1, promise2]).then(function(result){\n // result === 'promise 2' because it was resolved before promise1\n // was resolved.\n });\n ```\n\n `Promise.race` is deterministic in that only the state of the first\n settled promise matters. For example, even if other promises given to the\n `promises` array argument are resolved, but the first settled promise has\n become rejected before the other promises became fulfilled, the returned\n promise will become rejected:\n\n ```javascript\n let promise1 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 1');\n }, 200);\n });\n\n let promise2 = new Promise(function(resolve, reject){\n setTimeout(function(){\n reject(new Error('promise 2'));\n }, 100);\n });\n\n Promise.race([promise1, promise2]).then(function(result){\n // Code here never runs\n }, function(reason){\n // reason.message === 'promise 2' because promise 2 became rejected before\n // promise 1 became fulfilled\n });\n ```\n\n An example real-world use case is implementing timeouts:\n\n ```javascript\n Promise.race([ajax('foo.json'), timeout(5000)])\n ```\n\n @method race\n @static\n @param {Array} promises array of promises to observe\n Useful for tooling.\n @return {Promise} a promise which settles in the same way as the first passed\n promise to settle.\n*/\nfunction race(entries) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (!isArray(entries)) {\n return new Constructor(function (_, reject) {\n return reject(new TypeError('You must pass an array to race.'));\n });\n } else {\n return new Constructor(function (resolve, reject) {\n var length = entries.length;\n for (var i = 0; i < length; i++) {\n Constructor.resolve(entries[i]).then(resolve, reject);\n }\n });\n }\n}\n\n/**\n `Promise.reject` returns a promise rejected with the passed `reason`.\n It is shorthand for the following:\n\n ```javascript\n let promise = new Promise(function(resolve, reject){\n reject(new Error('WHOOPS'));\n });\n\n promise.then(function(value){\n // Code here doesn't run because the promise is rejected!\n }, function(reason){\n // reason.message === 'WHOOPS'\n });\n ```\n\n Instead of writing the above, your code now simply becomes the following:\n\n ```javascript\n let promise = Promise.reject(new Error('WHOOPS'));\n\n promise.then(function(value){\n // Code here doesn't run because the promise is rejected!\n }, function(reason){\n // reason.message === 'WHOOPS'\n });\n ```\n\n @method reject\n @static\n @param {Any} reason value that the returned promise will be rejected with.\n Useful for tooling.\n @return {Promise} a promise rejected with the given `reason`.\n*/\nfunction reject$1(reason) {\n /*jshint validthis:true */\n var Constructor = this;\n var promise = new Constructor(noop);\n reject(promise, reason);\n return promise;\n}\n\nfunction needsResolver() {\n throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n}\n\nfunction needsNew() {\n throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n}\n\n/**\n Promise objects represent the eventual result of an asynchronous operation. The\n primary way of interacting with a promise is through its `then` method, which\n registers callbacks to receive either a promise's eventual value or the reason\n why the promise cannot be fulfilled.\n\n Terminology\n -----------\n\n - `promise` is an object or function with a `then` method whose behavior conforms to this specification.\n - `thenable` is an object or function that defines a `then` method.\n - `value` is any legal JavaScript value (including undefined, a thenable, or a promise).\n - `exception` is a value that is thrown using the throw statement.\n - `reason` is a value that indicates why a promise was rejected.\n - `settled` the final resting state of a promise, fulfilled or rejected.\n\n A promise can be in one of three states: pending, fulfilled, or rejected.\n\n Promises that are fulfilled have a fulfillment value and are in the fulfilled\n state. Promises that are rejected have a rejection reason and are in the\n rejected state. A fulfillment value is never a thenable.\n\n Promises can also be said to *resolve* a value. If this value is also a\n promise, then the original promise's settled state will match the value's\n settled state. So a promise that *resolves* a promise that rejects will\n itself reject, and a promise that *resolves* a promise that fulfills will\n itself fulfill.\n\n\n Basic Usage:\n ------------\n\n ```js\n let promise = new Promise(function(resolve, reject) {\n // on success\n resolve(value);\n\n // on failure\n reject(reason);\n });\n\n promise.then(function(value) {\n // on fulfillment\n }, function(reason) {\n // on rejection\n });\n ```\n\n Advanced Usage:\n ---------------\n\n Promises shine when abstracting away asynchronous interactions such as\n `XMLHttpRequest`s.\n\n ```js\n function getJSON(url) {\n return new Promise(function(resolve, reject){\n let xhr = new XMLHttpRequest();\n\n xhr.open('GET', url);\n xhr.onreadystatechange = handler;\n xhr.responseType = 'json';\n xhr.setRequestHeader('Accept', 'application/json');\n xhr.send();\n\n function handler() {\n if (this.readyState === this.DONE) {\n if (this.status === 200) {\n resolve(this.response);\n } else {\n reject(new Error('getJSON: `' + url + '` failed with status: [' + this.status + ']'));\n }\n }\n };\n });\n }\n\n getJSON('/posts.json').then(function(json) {\n // on fulfillment\n }, function(reason) {\n // on rejection\n });\n ```\n\n Unlike callbacks, promises are great composable primitives.\n\n ```js\n Promise.all([\n getJSON('/posts'),\n getJSON('/comments')\n ]).then(function(values){\n values[0] // => postsJSON\n values[1] // => commentsJSON\n\n return values;\n });\n ```\n\n @class Promise\n @param {Function} resolver\n Useful for tooling.\n @constructor\n*/\n\nvar Promise$1 = function () {\n function Promise(resolver) {\n this[PROMISE_ID] = nextId();\n this._result = this._state = undefined;\n this._subscribers = [];\n\n if (noop !== resolver) {\n typeof resolver !== 'function' && needsResolver();\n this instanceof Promise ? initializePromise(this, resolver) : needsNew();\n }\n }\n\n /**\n The primary way of interacting with a promise is through its `then` method,\n which registers callbacks to receive either a promise's eventual value or the\n reason why the promise cannot be fulfilled.\n ```js\n findUser().then(function(user){\n // user is available\n }, function(reason){\n // user is unavailable, and you are given the reason why\n });\n ```\n Chaining\n --------\n The return value of `then` is itself a promise. This second, 'downstream'\n promise is resolved with the return value of the first promise's fulfillment\n or rejection handler, or rejected if the handler throws an exception.\n ```js\n findUser().then(function (user) {\n return user.name;\n }, function (reason) {\n return 'default name';\n }).then(function (userName) {\n // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n // will be `'default name'`\n });\n findUser().then(function (user) {\n throw new Error('Found user, but still unhappy');\n }, function (reason) {\n throw new Error('`findUser` rejected and we're unhappy');\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n });\n ```\n If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n ```js\n findUser().then(function (user) {\n throw new PedagogicalException('Upstream error');\n }).then(function (value) {\n // never reached\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // The `PedgagocialException` is propagated all the way down to here\n });\n ```\n Assimilation\n ------------\n Sometimes the value you want to propagate to a downstream promise can only be\n retrieved asynchronously. This can be achieved by returning a promise in the\n fulfillment or rejection handler. The downstream promise will then be pending\n until the returned promise is settled. This is called *assimilation*.\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // The user's comments are now available\n });\n ```\n If the assimliated promise rejects, then the downstream promise will also reject.\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // If `findCommentsByAuthor` fulfills, we'll have the value here\n }, function (reason) {\n // If `findCommentsByAuthor` rejects, we'll have the reason here\n });\n ```\n Simple Example\n --------------\n Synchronous Example\n ```javascript\n let result;\n try {\n result = findResult();\n // success\n } catch(reason) {\n // failure\n }\n ```\n Errback Example\n ```js\n findResult(function(result, err){\n if (err) {\n // failure\n } else {\n // success\n }\n });\n ```\n Promise Example;\n ```javascript\n findResult().then(function(result){\n // success\n }, function(reason){\n // failure\n });\n ```\n Advanced Example\n --------------\n Synchronous Example\n ```javascript\n let author, books;\n try {\n author = findAuthor();\n books = findBooksByAuthor(author);\n // success\n } catch(reason) {\n // failure\n }\n ```\n Errback Example\n ```js\n function foundBooks(books) {\n }\n function failure(reason) {\n }\n findAuthor(function(author, err){\n if (err) {\n failure(err);\n // failure\n } else {\n try {\n findBoooksByAuthor(author, function(books, err) {\n if (err) {\n failure(err);\n } else {\n try {\n foundBooks(books);\n } catch(reason) {\n failure(reason);\n }\n }\n });\n } catch(error) {\n failure(err);\n }\n // success\n }\n });\n ```\n Promise Example;\n ```javascript\n findAuthor().\n then(findBooksByAuthor).\n then(function(books){\n // found books\n }).catch(function(reason){\n // something went wrong\n });\n ```\n @method then\n @param {Function} onFulfilled\n @param {Function} onRejected\n Useful for tooling.\n @return {Promise}\n */\n\n /**\n `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n as the catch block of a try/catch statement.\n ```js\n function findAuthor(){\n throw new Error('couldn't find that author');\n }\n // synchronous\n try {\n findAuthor();\n } catch(reason) {\n // something went wrong\n }\n // async with promises\n findAuthor().catch(function(reason){\n // something went wrong\n });\n ```\n @method catch\n @param {Function} onRejection\n Useful for tooling.\n @return {Promise}\n */\n\n\n Promise.prototype.catch = function _catch(onRejection) {\n return this.then(null, onRejection);\n };\n\n /**\n `finally` will be invoked regardless of the promise's fate just as native\n try/catch/finally behaves\n \n Synchronous example:\n \n ```js\n findAuthor() {\n if (Math.random() > 0.5) {\n throw new Error();\n }\n return new Author();\n }\n \n try {\n return findAuthor(); // succeed or fail\n } catch(error) {\n return findOtherAuther();\n } finally {\n // always runs\n // doesn't affect the return value\n }\n ```\n \n Asynchronous example:\n \n ```js\n findAuthor().catch(function(reason){\n return findOtherAuther();\n }).finally(function(){\n // author was either found, or not\n });\n ```\n \n @method finally\n @param {Function} callback\n @return {Promise}\n */\n\n\n Promise.prototype.finally = function _finally(callback) {\n var promise = this;\n var constructor = promise.constructor;\n\n if (isFunction(callback)) {\n return promise.then(function (value) {\n return constructor.resolve(callback()).then(function () {\n return value;\n });\n }, function (reason) {\n return constructor.resolve(callback()).then(function () {\n throw reason;\n });\n });\n }\n\n return promise.then(callback, callback);\n };\n\n return Promise;\n}();\n\nPromise$1.prototype.then = then;\nPromise$1.all = all;\nPromise$1.race = race;\nPromise$1.resolve = resolve$1;\nPromise$1.reject = reject$1;\nPromise$1._setScheduler = setScheduler;\nPromise$1._setAsap = setAsap;\nPromise$1._asap = asap;\n\n/*global self*/\nfunction polyfill() {\n var local = void 0;\n\n if (typeof global !== 'undefined') {\n local = global;\n } else if (typeof self !== 'undefined') {\n local = self;\n } else {\n try {\n local = Function('return this')();\n } catch (e) {\n throw new Error('polyfill failed because global object is unavailable in this environment');\n }\n }\n\n var P = local.Promise;\n\n if (P) {\n var promiseToString = null;\n try {\n promiseToString = Object.prototype.toString.call(P.resolve());\n } catch (e) {\n // silently ignored\n }\n\n if (promiseToString === '[object Promise]' && !P.cast) {\n return;\n }\n }\n\n local.Promise = Promise$1;\n}\n\n// Strange compat..\nPromise$1.polyfill = polyfill;\nPromise$1.Promise = Promise$1;\n\nreturn Promise$1;\n\n})));\n\n\n\n//# sourceMappingURL=es6-promise.map\n\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../process/browser.js */ \"./node_modules/process/browser.js\"), __webpack_require__(/*! ./../../webpack/buildin/global.js */ \"./node_modules/webpack/buildin/global.js\")))\n\n//# sourceURL=webpack://irma/./node_modules/es6-promise/dist/es6-promise.js?");
|
|
278
|
+
|
|
279
|
+
/***/ }),
|
|
280
|
+
|
|
281
|
+
/***/ "./node_modules/isomorphic-fetch/fetch-npm-browserify.js":
|
|
282
|
+
/*!***************************************************************!*\
|
|
283
|
+
!*** ./node_modules/isomorphic-fetch/fetch-npm-browserify.js ***!
|
|
284
|
+
\***************************************************************/
|
|
285
|
+
/*! no static exports found */
|
|
286
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
287
|
+
|
|
288
|
+
eval("// the whatwg-fetch polyfill installs the fetch() function\n// on the global object (window or self)\n//\n// Return that as the export for use in Webpack, Browserify etc.\n__webpack_require__(/*! whatwg-fetch */ \"./node_modules/whatwg-fetch/fetch.js\");\nmodule.exports = self.fetch.bind(self);\n\n\n//# sourceURL=webpack://irma/./node_modules/isomorphic-fetch/fetch-npm-browserify.js?");
|
|
289
|
+
|
|
290
|
+
/***/ }),
|
|
291
|
+
|
|
292
|
+
/***/ "./node_modules/process/browser.js":
|
|
293
|
+
/*!*****************************************!*\
|
|
294
|
+
!*** ./node_modules/process/browser.js ***!
|
|
295
|
+
\*****************************************/
|
|
296
|
+
/*! no static exports found */
|
|
297
|
+
/***/ (function(module, exports) {
|
|
298
|
+
|
|
299
|
+
eval("// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n\n\n//# sourceURL=webpack://irma/./node_modules/process/browser.js?");
|
|
300
|
+
|
|
301
|
+
/***/ }),
|
|
302
|
+
|
|
303
|
+
/***/ "./node_modules/qrcode/lib/browser.js":
|
|
304
|
+
/*!********************************************!*\
|
|
305
|
+
!*** ./node_modules/qrcode/lib/browser.js ***!
|
|
306
|
+
\********************************************/
|
|
307
|
+
/*! no static exports found */
|
|
308
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
309
|
+
|
|
310
|
+
eval("var canPromise = __webpack_require__(/*! can-promise */ \"./node_modules/can-promise/index.js\")\nvar QRCode = __webpack_require__(/*! ./core/qrcode */ \"./node_modules/qrcode/lib/core/qrcode.js\")\nvar CanvasRenderer = __webpack_require__(/*! ./renderer/canvas */ \"./node_modules/qrcode/lib/renderer/canvas.js\")\nvar SvgRenderer = __webpack_require__(/*! ./renderer/svg-tag.js */ \"./node_modules/qrcode/lib/renderer/svg-tag.js\")\n\nfunction renderCanvas (renderFunc, canvas, text, opts, cb) {\n var args = [].slice.call(arguments, 1)\n var argsNum = args.length\n var isLastArgCb = typeof args[argsNum - 1] === 'function'\n\n if (!isLastArgCb && !canPromise()) {\n throw new Error('Callback required as last argument')\n }\n\n if (isLastArgCb) {\n if (argsNum < 2) {\n throw new Error('Too few arguments provided')\n }\n\n if (argsNum === 2) {\n cb = text\n text = canvas\n canvas = opts = undefined\n } else if (argsNum === 3) {\n if (canvas.getContext && typeof cb === 'undefined') {\n cb = opts\n opts = undefined\n } else {\n cb = opts\n opts = text\n text = canvas\n canvas = undefined\n }\n }\n } else {\n if (argsNum < 1) {\n throw new Error('Too few arguments provided')\n }\n\n if (argsNum === 1) {\n text = canvas\n canvas = opts = undefined\n } else if (argsNum === 2 && !canvas.getContext) {\n opts = text\n text = canvas\n canvas = undefined\n }\n\n return new Promise(function (resolve, reject) {\n try {\n var data = QRCode.create(text, opts)\n resolve(renderFunc(data, canvas, opts))\n } catch (e) {\n reject(e)\n }\n })\n }\n\n try {\n var data = QRCode.create(text, opts)\n cb(null, renderFunc(data, canvas, opts))\n } catch (e) {\n cb(e)\n }\n}\n\nexports.create = QRCode.create\nexports.toCanvas = renderCanvas.bind(null, CanvasRenderer.render)\nexports.toDataURL = renderCanvas.bind(null, CanvasRenderer.renderToDataURL)\n\n// only svg for now.\nexports.toString = renderCanvas.bind(null, function (data, _, opts) {\n return SvgRenderer.render(data, opts)\n})\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/browser.js?");
|
|
311
|
+
|
|
312
|
+
/***/ }),
|
|
313
|
+
|
|
314
|
+
/***/ "./node_modules/qrcode/lib/core/alignment-pattern.js":
|
|
315
|
+
/*!***********************************************************!*\
|
|
316
|
+
!*** ./node_modules/qrcode/lib/core/alignment-pattern.js ***!
|
|
317
|
+
\***********************************************************/
|
|
318
|
+
/*! no static exports found */
|
|
319
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
320
|
+
|
|
321
|
+
eval("/**\n * Alignment pattern are fixed reference pattern in defined positions\n * in a matrix symbology, which enables the decode software to re-synchronise\n * the coordinate mapping of the image modules in the event of moderate amounts\n * of distortion of the image.\n *\n * Alignment patterns are present only in QR Code symbols of version 2 or larger\n * and their number depends on the symbol version.\n */\n\nvar getSymbolSize = __webpack_require__(/*! ./utils */ \"./node_modules/qrcode/lib/core/utils.js\").getSymbolSize\n\n/**\n * Calculate the row/column coordinates of the center module of each alignment pattern\n * for the specified QR Code version.\n *\n * The alignment patterns are positioned symmetrically on either side of the diagonal\n * running from the top left corner of the symbol to the bottom right corner.\n *\n * Since positions are simmetrical only half of the coordinates are returned.\n * Each item of the array will represent in turn the x and y coordinate.\n * @see {@link getPositions}\n *\n * @param {Number} version QR Code version\n * @return {Array} Array of coordinate\n */\nexports.getRowColCoords = function getRowColCoords (version) {\n if (version === 1) return []\n\n var posCount = Math.floor(version / 7) + 2\n var size = getSymbolSize(version)\n var intervals = size === 145 ? 26 : Math.ceil((size - 13) / (2 * posCount - 2)) * 2\n var positions = [size - 7] // Last coord is always (size - 7)\n\n for (var i = 1; i < posCount - 1; i++) {\n positions[i] = positions[i - 1] - intervals\n }\n\n positions.push(6) // First coord is always 6\n\n return positions.reverse()\n}\n\n/**\n * Returns an array containing the positions of each alignment pattern.\n * Each array's element represent the center point of the pattern as (x, y) coordinates\n *\n * Coordinates are calculated expanding the row/column coordinates returned by {@link getRowColCoords}\n * and filtering out the items that overlaps with finder pattern\n *\n * @example\n * For a Version 7 symbol {@link getRowColCoords} returns values 6, 22 and 38.\n * The alignment patterns, therefore, are to be centered on (row, column)\n * positions (6,22), (22,6), (22,22), (22,38), (38,22), (38,38).\n * Note that the coordinates (6,6), (6,38), (38,6) are occupied by finder patterns\n * and are not therefore used for alignment patterns.\n *\n * var pos = getPositions(7)\n * // [[6,22], [22,6], [22,22], [22,38], [38,22], [38,38]]\n *\n * @param {Number} version QR Code version\n * @return {Array} Array of coordinates\n */\nexports.getPositions = function getPositions (version) {\n var coords = []\n var pos = exports.getRowColCoords(version)\n var posLength = pos.length\n\n for (var i = 0; i < posLength; i++) {\n for (var j = 0; j < posLength; j++) {\n // Skip if position is occupied by finder patterns\n if ((i === 0 && j === 0) || // top-left\n (i === 0 && j === posLength - 1) || // bottom-left\n (i === posLength - 1 && j === 0)) { // top-right\n continue\n }\n\n coords.push([pos[i], pos[j]])\n }\n }\n\n return coords\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/alignment-pattern.js?");
|
|
322
|
+
|
|
323
|
+
/***/ }),
|
|
324
|
+
|
|
325
|
+
/***/ "./node_modules/qrcode/lib/core/alphanumeric-data.js":
|
|
326
|
+
/*!***********************************************************!*\
|
|
327
|
+
!*** ./node_modules/qrcode/lib/core/alphanumeric-data.js ***!
|
|
328
|
+
\***********************************************************/
|
|
329
|
+
/*! no static exports found */
|
|
330
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
331
|
+
|
|
332
|
+
eval("var Mode = __webpack_require__(/*! ./mode */ \"./node_modules/qrcode/lib/core/mode.js\")\n\n/**\n * Array of characters available in alphanumeric mode\n *\n * As per QR Code specification, to each character\n * is assigned a value from 0 to 44 which in this case coincides\n * with the array index\n *\n * @type {Array}\n */\nvar ALPHA_NUM_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]\n\nfunction AlphanumericData (data) {\n this.mode = Mode.ALPHANUMERIC\n this.data = data\n}\n\nAlphanumericData.getBitsLength = function getBitsLength (length) {\n return 11 * Math.floor(length / 2) + 6 * (length % 2)\n}\n\nAlphanumericData.prototype.getLength = function getLength () {\n return this.data.length\n}\n\nAlphanumericData.prototype.getBitsLength = function getBitsLength () {\n return AlphanumericData.getBitsLength(this.data.length)\n}\n\nAlphanumericData.prototype.write = function write (bitBuffer) {\n var i\n\n // Input data characters are divided into groups of two characters\n // and encoded as 11-bit binary codes.\n for (i = 0; i + 2 <= this.data.length; i += 2) {\n // The character value of the first character is multiplied by 45\n var value = ALPHA_NUM_CHARS.indexOf(this.data[i]) * 45\n\n // The character value of the second digit is added to the product\n value += ALPHA_NUM_CHARS.indexOf(this.data[i + 1])\n\n // The sum is then stored as 11-bit binary number\n bitBuffer.put(value, 11)\n }\n\n // If the number of input data characters is not a multiple of two,\n // the character value of the final character is encoded as a 6-bit binary number.\n if (this.data.length % 2) {\n bitBuffer.put(ALPHA_NUM_CHARS.indexOf(this.data[i]), 6)\n }\n}\n\nmodule.exports = AlphanumericData\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/alphanumeric-data.js?");
|
|
333
|
+
|
|
334
|
+
/***/ }),
|
|
335
|
+
|
|
336
|
+
/***/ "./node_modules/qrcode/lib/core/bit-buffer.js":
|
|
337
|
+
/*!****************************************************!*\
|
|
338
|
+
!*** ./node_modules/qrcode/lib/core/bit-buffer.js ***!
|
|
339
|
+
\****************************************************/
|
|
340
|
+
/*! no static exports found */
|
|
341
|
+
/***/ (function(module, exports) {
|
|
342
|
+
|
|
343
|
+
eval("function BitBuffer () {\n this.buffer = []\n this.length = 0\n}\n\nBitBuffer.prototype = {\n\n get: function (index) {\n var bufIndex = Math.floor(index / 8)\n return ((this.buffer[bufIndex] >>> (7 - index % 8)) & 1) === 1\n },\n\n put: function (num, length) {\n for (var i = 0; i < length; i++) {\n this.putBit(((num >>> (length - i - 1)) & 1) === 1)\n }\n },\n\n getLengthInBits: function () {\n return this.length\n },\n\n putBit: function (bit) {\n var bufIndex = Math.floor(this.length / 8)\n if (this.buffer.length <= bufIndex) {\n this.buffer.push(0)\n }\n\n if (bit) {\n this.buffer[bufIndex] |= (0x80 >>> (this.length % 8))\n }\n\n this.length++\n }\n}\n\nmodule.exports = BitBuffer\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/bit-buffer.js?");
|
|
344
|
+
|
|
345
|
+
/***/ }),
|
|
346
|
+
|
|
347
|
+
/***/ "./node_modules/qrcode/lib/core/bit-matrix.js":
|
|
348
|
+
/*!****************************************************!*\
|
|
349
|
+
!*** ./node_modules/qrcode/lib/core/bit-matrix.js ***!
|
|
350
|
+
\****************************************************/
|
|
351
|
+
/*! no static exports found */
|
|
352
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
353
|
+
|
|
354
|
+
eval("var Buffer = __webpack_require__(/*! ../utils/buffer */ \"./node_modules/qrcode/lib/utils/typedarray-buffer.js\")\n\n/**\n * Helper class to handle QR Code symbol modules\n *\n * @param {Number} size Symbol size\n */\nfunction BitMatrix (size) {\n if (!size || size < 1) {\n throw new Error('BitMatrix size must be defined and greater than 0')\n }\n\n this.size = size\n this.data = new Buffer(size * size)\n this.data.fill(0)\n this.reservedBit = new Buffer(size * size)\n this.reservedBit.fill(0)\n}\n\n/**\n * Set bit value at specified location\n * If reserved flag is set, this bit will be ignored during masking process\n *\n * @param {Number} row\n * @param {Number} col\n * @param {Boolean} value\n * @param {Boolean} reserved\n */\nBitMatrix.prototype.set = function (row, col, value, reserved) {\n var index = row * this.size + col\n this.data[index] = value\n if (reserved) this.reservedBit[index] = true\n}\n\n/**\n * Returns bit value at specified location\n *\n * @param {Number} row\n * @param {Number} col\n * @return {Boolean}\n */\nBitMatrix.prototype.get = function (row, col) {\n return this.data[row * this.size + col]\n}\n\n/**\n * Applies xor operator at specified location\n * (used during masking process)\n *\n * @param {Number} row\n * @param {Number} col\n * @param {Boolean} value\n */\nBitMatrix.prototype.xor = function (row, col, value) {\n this.data[row * this.size + col] ^= value\n}\n\n/**\n * Check if bit at specified location is reserved\n *\n * @param {Number} row\n * @param {Number} col\n * @return {Boolean}\n */\nBitMatrix.prototype.isReserved = function (row, col) {\n return this.reservedBit[row * this.size + col]\n}\n\nmodule.exports = BitMatrix\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/bit-matrix.js?");
|
|
355
|
+
|
|
356
|
+
/***/ }),
|
|
357
|
+
|
|
358
|
+
/***/ "./node_modules/qrcode/lib/core/byte-data.js":
|
|
359
|
+
/*!***************************************************!*\
|
|
360
|
+
!*** ./node_modules/qrcode/lib/core/byte-data.js ***!
|
|
361
|
+
\***************************************************/
|
|
362
|
+
/*! no static exports found */
|
|
363
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
364
|
+
|
|
365
|
+
eval("var Buffer = __webpack_require__(/*! ../utils/buffer */ \"./node_modules/qrcode/lib/utils/typedarray-buffer.js\")\nvar Mode = __webpack_require__(/*! ./mode */ \"./node_modules/qrcode/lib/core/mode.js\")\n\nfunction ByteData (data) {\n this.mode = Mode.BYTE\n this.data = new Buffer(data)\n}\n\nByteData.getBitsLength = function getBitsLength (length) {\n return length * 8\n}\n\nByteData.prototype.getLength = function getLength () {\n return this.data.length\n}\n\nByteData.prototype.getBitsLength = function getBitsLength () {\n return ByteData.getBitsLength(this.data.length)\n}\n\nByteData.prototype.write = function (bitBuffer) {\n for (var i = 0, l = this.data.length; i < l; i++) {\n bitBuffer.put(this.data[i], 8)\n }\n}\n\nmodule.exports = ByteData\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/byte-data.js?");
|
|
366
|
+
|
|
367
|
+
/***/ }),
|
|
368
|
+
|
|
369
|
+
/***/ "./node_modules/qrcode/lib/core/error-correction-code.js":
|
|
370
|
+
/*!***************************************************************!*\
|
|
371
|
+
!*** ./node_modules/qrcode/lib/core/error-correction-code.js ***!
|
|
372
|
+
\***************************************************************/
|
|
373
|
+
/*! no static exports found */
|
|
374
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
375
|
+
|
|
376
|
+
eval("var ECLevel = __webpack_require__(/*! ./error-correction-level */ \"./node_modules/qrcode/lib/core/error-correction-level.js\")\r\n\r\nvar EC_BLOCKS_TABLE = [\r\n// L M Q H\r\n 1, 1, 1, 1,\r\n 1, 1, 1, 1,\r\n 1, 1, 2, 2,\r\n 1, 2, 2, 4,\r\n 1, 2, 4, 4,\r\n 2, 4, 4, 4,\r\n 2, 4, 6, 5,\r\n 2, 4, 6, 6,\r\n 2, 5, 8, 8,\r\n 4, 5, 8, 8,\r\n 4, 5, 8, 11,\r\n 4, 8, 10, 11,\r\n 4, 9, 12, 16,\r\n 4, 9, 16, 16,\r\n 6, 10, 12, 18,\r\n 6, 10, 17, 16,\r\n 6, 11, 16, 19,\r\n 6, 13, 18, 21,\r\n 7, 14, 21, 25,\r\n 8, 16, 20, 25,\r\n 8, 17, 23, 25,\r\n 9, 17, 23, 34,\r\n 9, 18, 25, 30,\r\n 10, 20, 27, 32,\r\n 12, 21, 29, 35,\r\n 12, 23, 34, 37,\r\n 12, 25, 34, 40,\r\n 13, 26, 35, 42,\r\n 14, 28, 38, 45,\r\n 15, 29, 40, 48,\r\n 16, 31, 43, 51,\r\n 17, 33, 45, 54,\r\n 18, 35, 48, 57,\r\n 19, 37, 51, 60,\r\n 19, 38, 53, 63,\r\n 20, 40, 56, 66,\r\n 21, 43, 59, 70,\r\n 22, 45, 62, 74,\r\n 24, 47, 65, 77,\r\n 25, 49, 68, 81\r\n]\r\n\r\nvar EC_CODEWORDS_TABLE = [\r\n// L M Q H\r\n 7, 10, 13, 17,\r\n 10, 16, 22, 28,\r\n 15, 26, 36, 44,\r\n 20, 36, 52, 64,\r\n 26, 48, 72, 88,\r\n 36, 64, 96, 112,\r\n 40, 72, 108, 130,\r\n 48, 88, 132, 156,\r\n 60, 110, 160, 192,\r\n 72, 130, 192, 224,\r\n 80, 150, 224, 264,\r\n 96, 176, 260, 308,\r\n 104, 198, 288, 352,\r\n 120, 216, 320, 384,\r\n 132, 240, 360, 432,\r\n 144, 280, 408, 480,\r\n 168, 308, 448, 532,\r\n 180, 338, 504, 588,\r\n 196, 364, 546, 650,\r\n 224, 416, 600, 700,\r\n 224, 442, 644, 750,\r\n 252, 476, 690, 816,\r\n 270, 504, 750, 900,\r\n 300, 560, 810, 960,\r\n 312, 588, 870, 1050,\r\n 336, 644, 952, 1110,\r\n 360, 700, 1020, 1200,\r\n 390, 728, 1050, 1260,\r\n 420, 784, 1140, 1350,\r\n 450, 812, 1200, 1440,\r\n 480, 868, 1290, 1530,\r\n 510, 924, 1350, 1620,\r\n 540, 980, 1440, 1710,\r\n 570, 1036, 1530, 1800,\r\n 570, 1064, 1590, 1890,\r\n 600, 1120, 1680, 1980,\r\n 630, 1204, 1770, 2100,\r\n 660, 1260, 1860, 2220,\r\n 720, 1316, 1950, 2310,\r\n 750, 1372, 2040, 2430\r\n]\r\n\r\n/**\r\n * Returns the number of error correction block that the QR Code should contain\r\n * for the specified version and error correction level.\r\n *\r\n * @param {Number} version QR Code version\r\n * @param {Number} errorCorrectionLevel Error correction level\r\n * @return {Number} Number of error correction blocks\r\n */\r\nexports.getBlocksCount = function getBlocksCount (version, errorCorrectionLevel) {\r\n switch (errorCorrectionLevel) {\r\n case ECLevel.L:\r\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 0]\r\n case ECLevel.M:\r\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 1]\r\n case ECLevel.Q:\r\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 2]\r\n case ECLevel.H:\r\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 3]\r\n default:\r\n return undefined\r\n }\r\n}\r\n\r\n/**\r\n * Returns the number of error correction codewords to use for the specified\r\n * version and error correction level.\r\n *\r\n * @param {Number} version QR Code version\r\n * @param {Number} errorCorrectionLevel Error correction level\r\n * @return {Number} Number of error correction codewords\r\n */\r\nexports.getTotalCodewordsCount = function getTotalCodewordsCount (version, errorCorrectionLevel) {\r\n switch (errorCorrectionLevel) {\r\n case ECLevel.L:\r\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 0]\r\n case ECLevel.M:\r\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 1]\r\n case ECLevel.Q:\r\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 2]\r\n case ECLevel.H:\r\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 3]\r\n default:\r\n return undefined\r\n }\r\n}\r\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/error-correction-code.js?");
|
|
377
|
+
|
|
378
|
+
/***/ }),
|
|
379
|
+
|
|
380
|
+
/***/ "./node_modules/qrcode/lib/core/error-correction-level.js":
|
|
381
|
+
/*!****************************************************************!*\
|
|
382
|
+
!*** ./node_modules/qrcode/lib/core/error-correction-level.js ***!
|
|
383
|
+
\****************************************************************/
|
|
384
|
+
/*! no static exports found */
|
|
385
|
+
/***/ (function(module, exports) {
|
|
386
|
+
|
|
387
|
+
eval("exports.L = { bit: 1 }\nexports.M = { bit: 0 }\nexports.Q = { bit: 3 }\nexports.H = { bit: 2 }\n\nfunction fromString (string) {\n if (typeof string !== 'string') {\n throw new Error('Param is not a string')\n }\n\n var lcStr = string.toLowerCase()\n\n switch (lcStr) {\n case 'l':\n case 'low':\n return exports.L\n\n case 'm':\n case 'medium':\n return exports.M\n\n case 'q':\n case 'quartile':\n return exports.Q\n\n case 'h':\n case 'high':\n return exports.H\n\n default:\n throw new Error('Unknown EC Level: ' + string)\n }\n}\n\nexports.isValid = function isValid (level) {\n return level && typeof level.bit !== 'undefined' &&\n level.bit >= 0 && level.bit < 4\n}\n\nexports.from = function from (value, defaultValue) {\n if (exports.isValid(value)) {\n return value\n }\n\n try {\n return fromString(value)\n } catch (e) {\n return defaultValue\n }\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/error-correction-level.js?");
|
|
388
|
+
|
|
389
|
+
/***/ }),
|
|
390
|
+
|
|
391
|
+
/***/ "./node_modules/qrcode/lib/core/finder-pattern.js":
|
|
392
|
+
/*!********************************************************!*\
|
|
393
|
+
!*** ./node_modules/qrcode/lib/core/finder-pattern.js ***!
|
|
394
|
+
\********************************************************/
|
|
395
|
+
/*! no static exports found */
|
|
396
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
397
|
+
|
|
398
|
+
eval("var getSymbolSize = __webpack_require__(/*! ./utils */ \"./node_modules/qrcode/lib/core/utils.js\").getSymbolSize\nvar FINDER_PATTERN_SIZE = 7\n\n/**\n * Returns an array containing the positions of each finder pattern.\n * Each array's element represent the top-left point of the pattern as (x, y) coordinates\n *\n * @param {Number} version QR Code version\n * @return {Array} Array of coordinates\n */\nexports.getPositions = function getPositions (version) {\n var size = getSymbolSize(version)\n\n return [\n // top-left\n [0, 0],\n // top-right\n [size - FINDER_PATTERN_SIZE, 0],\n // bottom-left\n [0, size - FINDER_PATTERN_SIZE]\n ]\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/finder-pattern.js?");
|
|
399
|
+
|
|
400
|
+
/***/ }),
|
|
401
|
+
|
|
402
|
+
/***/ "./node_modules/qrcode/lib/core/format-info.js":
|
|
403
|
+
/*!*****************************************************!*\
|
|
404
|
+
!*** ./node_modules/qrcode/lib/core/format-info.js ***!
|
|
405
|
+
\*****************************************************/
|
|
406
|
+
/*! no static exports found */
|
|
407
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
408
|
+
|
|
409
|
+
eval("var Utils = __webpack_require__(/*! ./utils */ \"./node_modules/qrcode/lib/core/utils.js\")\n\nvar G15 = (1 << 10) | (1 << 8) | (1 << 5) | (1 << 4) | (1 << 2) | (1 << 1) | (1 << 0)\nvar G15_MASK = (1 << 14) | (1 << 12) | (1 << 10) | (1 << 4) | (1 << 1)\nvar G15_BCH = Utils.getBCHDigit(G15)\n\n/**\n * Returns format information with relative error correction bits\n *\n * The format information is a 15-bit sequence containing 5 data bits,\n * with 10 error correction bits calculated using the (15, 5) BCH code.\n *\n * @param {Number} errorCorrectionLevel Error correction level\n * @param {Number} mask Mask pattern\n * @return {Number} Encoded format information bits\n */\nexports.getEncodedBits = function getEncodedBits (errorCorrectionLevel, mask) {\n var data = ((errorCorrectionLevel.bit << 3) | mask)\n var d = data << 10\n\n while (Utils.getBCHDigit(d) - G15_BCH >= 0) {\n d ^= (G15 << (Utils.getBCHDigit(d) - G15_BCH))\n }\n\n // xor final data with mask pattern in order to ensure that\n // no combination of Error Correction Level and data mask pattern\n // will result in an all-zero data string\n return ((data << 10) | d) ^ G15_MASK\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/format-info.js?");
|
|
410
|
+
|
|
411
|
+
/***/ }),
|
|
412
|
+
|
|
413
|
+
/***/ "./node_modules/qrcode/lib/core/galois-field.js":
|
|
414
|
+
/*!******************************************************!*\
|
|
415
|
+
!*** ./node_modules/qrcode/lib/core/galois-field.js ***!
|
|
416
|
+
\******************************************************/
|
|
417
|
+
/*! no static exports found */
|
|
418
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
419
|
+
|
|
420
|
+
eval("var Buffer = __webpack_require__(/*! ../utils/buffer */ \"./node_modules/qrcode/lib/utils/typedarray-buffer.js\")\n\nvar EXP_TABLE = new Buffer(512)\nvar LOG_TABLE = new Buffer(256)\n\n/**\n * Precompute the log and anti-log tables for faster computation later\n *\n * For each possible value in the galois field 2^8, we will pre-compute\n * the logarithm and anti-logarithm (exponential) of this value\n *\n * ref {@link https://en.wikiversity.org/wiki/Reed%E2%80%93Solomon_codes_for_coders#Introduction_to_mathematical_fields}\n */\n;(function initTables () {\n var x = 1\n for (var i = 0; i < 255; i++) {\n EXP_TABLE[i] = x\n LOG_TABLE[x] = i\n\n x <<= 1 // multiply by 2\n\n // The QR code specification says to use byte-wise modulo 100011101 arithmetic.\n // This means that when a number is 256 or larger, it should be XORed with 0x11D.\n if (x & 0x100) { // similar to x >= 256, but a lot faster (because 0x100 == 256)\n x ^= 0x11D\n }\n }\n\n // Optimization: double the size of the anti-log table so that we don't need to mod 255 to\n // stay inside the bounds (because we will mainly use this table for the multiplication of\n // two GF numbers, no more).\n // @see {@link mul}\n for (i = 255; i < 512; i++) {\n EXP_TABLE[i] = EXP_TABLE[i - 255]\n }\n}())\n\n/**\n * Returns log value of n inside Galois Field\n *\n * @param {Number} n\n * @return {Number}\n */\nexports.log = function log (n) {\n if (n < 1) throw new Error('log(' + n + ')')\n return LOG_TABLE[n]\n}\n\n/**\n * Returns anti-log value of n inside Galois Field\n *\n * @param {Number} n\n * @return {Number}\n */\nexports.exp = function exp (n) {\n return EXP_TABLE[n]\n}\n\n/**\n * Multiplies two number inside Galois Field\n *\n * @param {Number} x\n * @param {Number} y\n * @return {Number}\n */\nexports.mul = function mul (x, y) {\n if (x === 0 || y === 0) return 0\n\n // should be EXP_TABLE[(LOG_TABLE[x] + LOG_TABLE[y]) % 255] if EXP_TABLE wasn't oversized\n // @see {@link initTables}\n return EXP_TABLE[LOG_TABLE[x] + LOG_TABLE[y]]\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/galois-field.js?");
|
|
421
|
+
|
|
422
|
+
/***/ }),
|
|
423
|
+
|
|
424
|
+
/***/ "./node_modules/qrcode/lib/core/kanji-data.js":
|
|
425
|
+
/*!****************************************************!*\
|
|
426
|
+
!*** ./node_modules/qrcode/lib/core/kanji-data.js ***!
|
|
427
|
+
\****************************************************/
|
|
428
|
+
/*! no static exports found */
|
|
429
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
430
|
+
|
|
431
|
+
eval("var Mode = __webpack_require__(/*! ./mode */ \"./node_modules/qrcode/lib/core/mode.js\")\nvar Utils = __webpack_require__(/*! ./utils */ \"./node_modules/qrcode/lib/core/utils.js\")\n\nfunction KanjiData (data) {\n this.mode = Mode.KANJI\n this.data = data\n}\n\nKanjiData.getBitsLength = function getBitsLength (length) {\n return length * 13\n}\n\nKanjiData.prototype.getLength = function getLength () {\n return this.data.length\n}\n\nKanjiData.prototype.getBitsLength = function getBitsLength () {\n return KanjiData.getBitsLength(this.data.length)\n}\n\nKanjiData.prototype.write = function (bitBuffer) {\n var i\n\n // In the Shift JIS system, Kanji characters are represented by a two byte combination.\n // These byte values are shifted from the JIS X 0208 values.\n // JIS X 0208 gives details of the shift coded representation.\n for (i = 0; i < this.data.length; i++) {\n var value = Utils.toSJIS(this.data[i])\n\n // For characters with Shift JIS values from 0x8140 to 0x9FFC:\n if (value >= 0x8140 && value <= 0x9FFC) {\n // Subtract 0x8140 from Shift JIS value\n value -= 0x8140\n\n // For characters with Shift JIS values from 0xE040 to 0xEBBF\n } else if (value >= 0xE040 && value <= 0xEBBF) {\n // Subtract 0xC140 from Shift JIS value\n value -= 0xC140\n } else {\n throw new Error(\n 'Invalid SJIS character: ' + this.data[i] + '\\n' +\n 'Make sure your charset is UTF-8')\n }\n\n // Multiply most significant byte of result by 0xC0\n // and add least significant byte to product\n value = (((value >>> 8) & 0xff) * 0xC0) + (value & 0xff)\n\n // Convert result to a 13-bit binary string\n bitBuffer.put(value, 13)\n }\n}\n\nmodule.exports = KanjiData\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/kanji-data.js?");
|
|
432
|
+
|
|
433
|
+
/***/ }),
|
|
434
|
+
|
|
435
|
+
/***/ "./node_modules/qrcode/lib/core/mask-pattern.js":
|
|
436
|
+
/*!******************************************************!*\
|
|
437
|
+
!*** ./node_modules/qrcode/lib/core/mask-pattern.js ***!
|
|
438
|
+
\******************************************************/
|
|
439
|
+
/*! no static exports found */
|
|
440
|
+
/***/ (function(module, exports) {
|
|
441
|
+
|
|
442
|
+
eval("/**\n * Data mask pattern reference\n * @type {Object}\n */\nexports.Patterns = {\n PATTERN000: 0,\n PATTERN001: 1,\n PATTERN010: 2,\n PATTERN011: 3,\n PATTERN100: 4,\n PATTERN101: 5,\n PATTERN110: 6,\n PATTERN111: 7\n}\n\n/**\n * Weighted penalty scores for the undesirable features\n * @type {Object}\n */\nvar PenaltyScores = {\n N1: 3,\n N2: 3,\n N3: 40,\n N4: 10\n}\n\n/**\n * Check if mask pattern value is valid\n *\n * @param {Number} mask Mask pattern\n * @return {Boolean} true if valid, false otherwise\n */\nexports.isValid = function isValid (mask) {\n return mask != null && mask !== '' && !isNaN(mask) && mask >= 0 && mask <= 7\n}\n\n/**\n * Returns mask pattern from a value.\n * If value is not valid, returns undefined\n *\n * @param {Number|String} value Mask pattern value\n * @return {Number} Valid mask pattern or undefined\n */\nexports.from = function from (value) {\n return exports.isValid(value) ? parseInt(value, 10) : undefined\n}\n\n/**\n* Find adjacent modules in row/column with the same color\n* and assign a penalty value.\n*\n* Points: N1 + i\n* i is the amount by which the number of adjacent modules of the same color exceeds 5\n*/\nexports.getPenaltyN1 = function getPenaltyN1 (data) {\n var size = data.size\n var points = 0\n var sameCountCol = 0\n var sameCountRow = 0\n var lastCol = null\n var lastRow = null\n\n for (var row = 0; row < size; row++) {\n sameCountCol = sameCountRow = 0\n lastCol = lastRow = null\n\n for (var col = 0; col < size; col++) {\n var module = data.get(row, col)\n if (module === lastCol) {\n sameCountCol++\n } else {\n if (sameCountCol >= 5) points += PenaltyScores.N1 + (sameCountCol - 5)\n lastCol = module\n sameCountCol = 1\n }\n\n module = data.get(col, row)\n if (module === lastRow) {\n sameCountRow++\n } else {\n if (sameCountRow >= 5) points += PenaltyScores.N1 + (sameCountRow - 5)\n lastRow = module\n sameCountRow = 1\n }\n }\n\n if (sameCountCol >= 5) points += PenaltyScores.N1 + (sameCountCol - 5)\n if (sameCountRow >= 5) points += PenaltyScores.N1 + (sameCountRow - 5)\n }\n\n return points\n}\n\n/**\n * Find 2x2 blocks with the same color and assign a penalty value\n *\n * Points: N2 * (m - 1) * (n - 1)\n */\nexports.getPenaltyN2 = function getPenaltyN2 (data) {\n var size = data.size\n var points = 0\n\n for (var row = 0; row < size - 1; row++) {\n for (var col = 0; col < size - 1; col++) {\n var last = data.get(row, col) +\n data.get(row, col + 1) +\n data.get(row + 1, col) +\n data.get(row + 1, col + 1)\n\n if (last === 4 || last === 0) points++\n }\n }\n\n return points * PenaltyScores.N2\n}\n\n/**\n * Find 1:1:3:1:1 ratio (dark:light:dark:light:dark) pattern in row/column,\n * preceded or followed by light area 4 modules wide\n *\n * Points: N3 * number of pattern found\n */\nexports.getPenaltyN3 = function getPenaltyN3 (data) {\n var size = data.size\n var points = 0\n var bitsCol = 0\n var bitsRow = 0\n\n for (var row = 0; row < size; row++) {\n bitsCol = bitsRow = 0\n for (var col = 0; col < size; col++) {\n bitsCol = ((bitsCol << 1) & 0x7FF) | data.get(row, col)\n if (col >= 10 && (bitsCol === 0x5D0 || bitsCol === 0x05D)) points++\n\n bitsRow = ((bitsRow << 1) & 0x7FF) | data.get(col, row)\n if (col >= 10 && (bitsRow === 0x5D0 || bitsRow === 0x05D)) points++\n }\n }\n\n return points * PenaltyScores.N3\n}\n\n/**\n * Calculate proportion of dark modules in entire symbol\n *\n * Points: N4 * k\n *\n * k is the rating of the deviation of the proportion of dark modules\n * in the symbol from 50% in steps of 5%\n */\nexports.getPenaltyN4 = function getPenaltyN4 (data) {\n var darkCount = 0\n var modulesCount = data.data.length\n\n for (var i = 0; i < modulesCount; i++) darkCount += data.data[i]\n\n var k = Math.abs(Math.ceil((darkCount * 100 / modulesCount) / 5) - 10)\n\n return k * PenaltyScores.N4\n}\n\n/**\n * Return mask value at given position\n *\n * @param {Number} maskPattern Pattern reference value\n * @param {Number} i Row\n * @param {Number} j Column\n * @return {Boolean} Mask value\n */\nfunction getMaskAt (maskPattern, i, j) {\n switch (maskPattern) {\n case exports.Patterns.PATTERN000: return (i + j) % 2 === 0\n case exports.Patterns.PATTERN001: return i % 2 === 0\n case exports.Patterns.PATTERN010: return j % 3 === 0\n case exports.Patterns.PATTERN011: return (i + j) % 3 === 0\n case exports.Patterns.PATTERN100: return (Math.floor(i / 2) + Math.floor(j / 3)) % 2 === 0\n case exports.Patterns.PATTERN101: return (i * j) % 2 + (i * j) % 3 === 0\n case exports.Patterns.PATTERN110: return ((i * j) % 2 + (i * j) % 3) % 2 === 0\n case exports.Patterns.PATTERN111: return ((i * j) % 3 + (i + j) % 2) % 2 === 0\n\n default: throw new Error('bad maskPattern:' + maskPattern)\n }\n}\n\n/**\n * Apply a mask pattern to a BitMatrix\n *\n * @param {Number} pattern Pattern reference number\n * @param {BitMatrix} data BitMatrix data\n */\nexports.applyMask = function applyMask (pattern, data) {\n var size = data.size\n\n for (var col = 0; col < size; col++) {\n for (var row = 0; row < size; row++) {\n if (data.isReserved(row, col)) continue\n data.xor(row, col, getMaskAt(pattern, row, col))\n }\n }\n}\n\n/**\n * Returns the best mask pattern for data\n *\n * @param {BitMatrix} data\n * @return {Number} Mask pattern reference number\n */\nexports.getBestMask = function getBestMask (data, setupFormatFunc) {\n var numPatterns = Object.keys(exports.Patterns).length\n var bestPattern = 0\n var lowerPenalty = Infinity\n\n for (var p = 0; p < numPatterns; p++) {\n setupFormatFunc(p)\n exports.applyMask(p, data)\n\n // Calculate penalty\n var penalty =\n exports.getPenaltyN1(data) +\n exports.getPenaltyN2(data) +\n exports.getPenaltyN3(data) +\n exports.getPenaltyN4(data)\n\n // Undo previously applied mask\n exports.applyMask(p, data)\n\n if (penalty < lowerPenalty) {\n lowerPenalty = penalty\n bestPattern = p\n }\n }\n\n return bestPattern\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/mask-pattern.js?");
|
|
443
|
+
|
|
444
|
+
/***/ }),
|
|
445
|
+
|
|
446
|
+
/***/ "./node_modules/qrcode/lib/core/mode.js":
|
|
447
|
+
/*!**********************************************!*\
|
|
448
|
+
!*** ./node_modules/qrcode/lib/core/mode.js ***!
|
|
449
|
+
\**********************************************/
|
|
450
|
+
/*! no static exports found */
|
|
451
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
452
|
+
|
|
453
|
+
eval("var VersionCheck = __webpack_require__(/*! ./version-check */ \"./node_modules/qrcode/lib/core/version-check.js\")\nvar Regex = __webpack_require__(/*! ./regex */ \"./node_modules/qrcode/lib/core/regex.js\")\n\n/**\n * Numeric mode encodes data from the decimal digit set (0 - 9)\n * (byte values 30HEX to 39HEX).\n * Normally, 3 data characters are represented by 10 bits.\n *\n * @type {Object}\n */\nexports.NUMERIC = {\n id: 'Numeric',\n bit: 1 << 0,\n ccBits: [10, 12, 14]\n}\n\n/**\n * Alphanumeric mode encodes data from a set of 45 characters,\n * i.e. 10 numeric digits (0 - 9),\n * 26 alphabetic characters (A - Z),\n * and 9 symbols (SP, $, %, *, +, -, ., /, :).\n * Normally, two input characters are represented by 11 bits.\n *\n * @type {Object}\n */\nexports.ALPHANUMERIC = {\n id: 'Alphanumeric',\n bit: 1 << 1,\n ccBits: [9, 11, 13]\n}\n\n/**\n * In byte mode, data is encoded at 8 bits per character.\n *\n * @type {Object}\n */\nexports.BYTE = {\n id: 'Byte',\n bit: 1 << 2,\n ccBits: [8, 16, 16]\n}\n\n/**\n * The Kanji mode efficiently encodes Kanji characters in accordance with\n * the Shift JIS system based on JIS X 0208.\n * The Shift JIS values are shifted from the JIS X 0208 values.\n * JIS X 0208 gives details of the shift coded representation.\n * Each two-byte character value is compacted to a 13-bit binary codeword.\n *\n * @type {Object}\n */\nexports.KANJI = {\n id: 'Kanji',\n bit: 1 << 3,\n ccBits: [8, 10, 12]\n}\n\n/**\n * Mixed mode will contain a sequences of data in a combination of any of\n * the modes described above\n *\n * @type {Object}\n */\nexports.MIXED = {\n bit: -1\n}\n\n/**\n * Returns the number of bits needed to store the data length\n * according to QR Code specifications.\n *\n * @param {Mode} mode Data mode\n * @param {Number} version QR Code version\n * @return {Number} Number of bits\n */\nexports.getCharCountIndicator = function getCharCountIndicator (mode, version) {\n if (!mode.ccBits) throw new Error('Invalid mode: ' + mode)\n\n if (!VersionCheck.isValid(version)) {\n throw new Error('Invalid version: ' + version)\n }\n\n if (version >= 1 && version < 10) return mode.ccBits[0]\n else if (version < 27) return mode.ccBits[1]\n return mode.ccBits[2]\n}\n\n/**\n * Returns the most efficient mode to store the specified data\n *\n * @param {String} dataStr Input data string\n * @return {Mode} Best mode\n */\nexports.getBestModeForData = function getBestModeForData (dataStr) {\n if (Regex.testNumeric(dataStr)) return exports.NUMERIC\n else if (Regex.testAlphanumeric(dataStr)) return exports.ALPHANUMERIC\n else if (Regex.testKanji(dataStr)) return exports.KANJI\n else return exports.BYTE\n}\n\n/**\n * Return mode name as string\n *\n * @param {Mode} mode Mode object\n * @returns {String} Mode name\n */\nexports.toString = function toString (mode) {\n if (mode && mode.id) return mode.id\n throw new Error('Invalid mode')\n}\n\n/**\n * Check if input param is a valid mode object\n *\n * @param {Mode} mode Mode object\n * @returns {Boolean} True if valid mode, false otherwise\n */\nexports.isValid = function isValid (mode) {\n return mode && mode.bit && mode.ccBits\n}\n\n/**\n * Get mode object from its name\n *\n * @param {String} string Mode name\n * @returns {Mode} Mode object\n */\nfunction fromString (string) {\n if (typeof string !== 'string') {\n throw new Error('Param is not a string')\n }\n\n var lcStr = string.toLowerCase()\n\n switch (lcStr) {\n case 'numeric':\n return exports.NUMERIC\n case 'alphanumeric':\n return exports.ALPHANUMERIC\n case 'kanji':\n return exports.KANJI\n case 'byte':\n return exports.BYTE\n default:\n throw new Error('Unknown mode: ' + string)\n }\n}\n\n/**\n * Returns mode from a value.\n * If value is not a valid mode, returns defaultValue\n *\n * @param {Mode|String} value Encoding mode\n * @param {Mode} defaultValue Fallback value\n * @return {Mode} Encoding mode\n */\nexports.from = function from (value, defaultValue) {\n if (exports.isValid(value)) {\n return value\n }\n\n try {\n return fromString(value)\n } catch (e) {\n return defaultValue\n }\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/mode.js?");
|
|
454
|
+
|
|
455
|
+
/***/ }),
|
|
456
|
+
|
|
457
|
+
/***/ "./node_modules/qrcode/lib/core/numeric-data.js":
|
|
458
|
+
/*!******************************************************!*\
|
|
459
|
+
!*** ./node_modules/qrcode/lib/core/numeric-data.js ***!
|
|
460
|
+
\******************************************************/
|
|
461
|
+
/*! no static exports found */
|
|
462
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
463
|
+
|
|
464
|
+
eval("var Mode = __webpack_require__(/*! ./mode */ \"./node_modules/qrcode/lib/core/mode.js\")\n\nfunction NumericData (data) {\n this.mode = Mode.NUMERIC\n this.data = data.toString()\n}\n\nNumericData.getBitsLength = function getBitsLength (length) {\n return 10 * Math.floor(length / 3) + ((length % 3) ? ((length % 3) * 3 + 1) : 0)\n}\n\nNumericData.prototype.getLength = function getLength () {\n return this.data.length\n}\n\nNumericData.prototype.getBitsLength = function getBitsLength () {\n return NumericData.getBitsLength(this.data.length)\n}\n\nNumericData.prototype.write = function write (bitBuffer) {\n var i, group, value\n\n // The input data string is divided into groups of three digits,\n // and each group is converted to its 10-bit binary equivalent.\n for (i = 0; i + 3 <= this.data.length; i += 3) {\n group = this.data.substr(i, 3)\n value = parseInt(group, 10)\n\n bitBuffer.put(value, 10)\n }\n\n // If the number of input digits is not an exact multiple of three,\n // the final one or two digits are converted to 4 or 7 bits respectively.\n var remainingNum = this.data.length - i\n if (remainingNum > 0) {\n group = this.data.substr(i)\n value = parseInt(group, 10)\n\n bitBuffer.put(value, remainingNum * 3 + 1)\n }\n}\n\nmodule.exports = NumericData\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/numeric-data.js?");
|
|
465
|
+
|
|
466
|
+
/***/ }),
|
|
467
|
+
|
|
468
|
+
/***/ "./node_modules/qrcode/lib/core/polynomial.js":
|
|
469
|
+
/*!****************************************************!*\
|
|
470
|
+
!*** ./node_modules/qrcode/lib/core/polynomial.js ***!
|
|
471
|
+
\****************************************************/
|
|
472
|
+
/*! no static exports found */
|
|
473
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
474
|
+
|
|
475
|
+
eval("var Buffer = __webpack_require__(/*! ../utils/buffer */ \"./node_modules/qrcode/lib/utils/typedarray-buffer.js\")\nvar GF = __webpack_require__(/*! ./galois-field */ \"./node_modules/qrcode/lib/core/galois-field.js\")\n\n/**\n * Multiplies two polynomials inside Galois Field\n *\n * @param {Buffer} p1 Polynomial\n * @param {Buffer} p2 Polynomial\n * @return {Buffer} Product of p1 and p2\n */\nexports.mul = function mul (p1, p2) {\n var coeff = new Buffer(p1.length + p2.length - 1)\n coeff.fill(0)\n\n for (var i = 0; i < p1.length; i++) {\n for (var j = 0; j < p2.length; j++) {\n coeff[i + j] ^= GF.mul(p1[i], p2[j])\n }\n }\n\n return coeff\n}\n\n/**\n * Calculate the remainder of polynomials division\n *\n * @param {Buffer} divident Polynomial\n * @param {Buffer} divisor Polynomial\n * @return {Buffer} Remainder\n */\nexports.mod = function mod (divident, divisor) {\n var result = new Buffer(divident)\n\n while ((result.length - divisor.length) >= 0) {\n var coeff = result[0]\n\n for (var i = 0; i < divisor.length; i++) {\n result[i] ^= GF.mul(divisor[i], coeff)\n }\n\n // remove all zeros from buffer head\n var offset = 0\n while (offset < result.length && result[offset] === 0) offset++\n result = result.slice(offset)\n }\n\n return result\n}\n\n/**\n * Generate an irreducible generator polynomial of specified degree\n * (used by Reed-Solomon encoder)\n *\n * @param {Number} degree Degree of the generator polynomial\n * @return {Buffer} Buffer containing polynomial coefficients\n */\nexports.generateECPolynomial = function generateECPolynomial (degree) {\n var poly = new Buffer([1])\n for (var i = 0; i < degree; i++) {\n poly = exports.mul(poly, [1, GF.exp(i)])\n }\n\n return poly\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/polynomial.js?");
|
|
476
|
+
|
|
477
|
+
/***/ }),
|
|
478
|
+
|
|
479
|
+
/***/ "./node_modules/qrcode/lib/core/qrcode.js":
|
|
480
|
+
/*!************************************************!*\
|
|
481
|
+
!*** ./node_modules/qrcode/lib/core/qrcode.js ***!
|
|
482
|
+
\************************************************/
|
|
483
|
+
/*! no static exports found */
|
|
484
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
485
|
+
|
|
486
|
+
eval("var Buffer = __webpack_require__(/*! ../utils/buffer */ \"./node_modules/qrcode/lib/utils/typedarray-buffer.js\")\nvar Utils = __webpack_require__(/*! ./utils */ \"./node_modules/qrcode/lib/core/utils.js\")\nvar ECLevel = __webpack_require__(/*! ./error-correction-level */ \"./node_modules/qrcode/lib/core/error-correction-level.js\")\nvar BitBuffer = __webpack_require__(/*! ./bit-buffer */ \"./node_modules/qrcode/lib/core/bit-buffer.js\")\nvar BitMatrix = __webpack_require__(/*! ./bit-matrix */ \"./node_modules/qrcode/lib/core/bit-matrix.js\")\nvar AlignmentPattern = __webpack_require__(/*! ./alignment-pattern */ \"./node_modules/qrcode/lib/core/alignment-pattern.js\")\nvar FinderPattern = __webpack_require__(/*! ./finder-pattern */ \"./node_modules/qrcode/lib/core/finder-pattern.js\")\nvar MaskPattern = __webpack_require__(/*! ./mask-pattern */ \"./node_modules/qrcode/lib/core/mask-pattern.js\")\nvar ECCode = __webpack_require__(/*! ./error-correction-code */ \"./node_modules/qrcode/lib/core/error-correction-code.js\")\nvar ReedSolomonEncoder = __webpack_require__(/*! ./reed-solomon-encoder */ \"./node_modules/qrcode/lib/core/reed-solomon-encoder.js\")\nvar Version = __webpack_require__(/*! ./version */ \"./node_modules/qrcode/lib/core/version.js\")\nvar FormatInfo = __webpack_require__(/*! ./format-info */ \"./node_modules/qrcode/lib/core/format-info.js\")\nvar Mode = __webpack_require__(/*! ./mode */ \"./node_modules/qrcode/lib/core/mode.js\")\nvar Segments = __webpack_require__(/*! ./segments */ \"./node_modules/qrcode/lib/core/segments.js\")\nvar isArray = __webpack_require__(/*! isarray */ \"./node_modules/qrcode/node_modules/isarray/index.js\")\n\n/**\n * QRCode for JavaScript\n *\n * modified by Ryan Day for nodejs support\n * Copyright (c) 2011 Ryan Day\n *\n * Licensed under the MIT license:\n * http://www.opensource.org/licenses/mit-license.php\n *\n//---------------------------------------------------------------------\n// QRCode for JavaScript\n//\n// Copyright (c) 2009 Kazuhiko Arase\n//\n// URL: http://www.d-project.com/\n//\n// Licensed under the MIT license:\n// http://www.opensource.org/licenses/mit-license.php\n//\n// The word \"QR Code\" is registered trademark of\n// DENSO WAVE INCORPORATED\n// http://www.denso-wave.com/qrcode/faqpatent-e.html\n//\n//---------------------------------------------------------------------\n*/\n\n/**\n * Add finder patterns bits to matrix\n *\n * @param {BitMatrix} matrix Modules matrix\n * @param {Number} version QR Code version\n */\nfunction setupFinderPattern (matrix, version) {\n var size = matrix.size\n var pos = FinderPattern.getPositions(version)\n\n for (var i = 0; i < pos.length; i++) {\n var row = pos[i][0]\n var col = pos[i][1]\n\n for (var r = -1; r <= 7; r++) {\n if (row + r <= -1 || size <= row + r) continue\n\n for (var c = -1; c <= 7; c++) {\n if (col + c <= -1 || size <= col + c) continue\n\n if ((r >= 0 && r <= 6 && (c === 0 || c === 6)) ||\n (c >= 0 && c <= 6 && (r === 0 || r === 6)) ||\n (r >= 2 && r <= 4 && c >= 2 && c <= 4)) {\n matrix.set(row + r, col + c, true, true)\n } else {\n matrix.set(row + r, col + c, false, true)\n }\n }\n }\n }\n}\n\n/**\n * Add timing pattern bits to matrix\n *\n * Note: this function must be called before {@link setupAlignmentPattern}\n *\n * @param {BitMatrix} matrix Modules matrix\n */\nfunction setupTimingPattern (matrix) {\n var size = matrix.size\n\n for (var r = 8; r < size - 8; r++) {\n var value = r % 2 === 0\n matrix.set(r, 6, value, true)\n matrix.set(6, r, value, true)\n }\n}\n\n/**\n * Add alignment patterns bits to matrix\n *\n * Note: this function must be called after {@link setupTimingPattern}\n *\n * @param {BitMatrix} matrix Modules matrix\n * @param {Number} version QR Code version\n */\nfunction setupAlignmentPattern (matrix, version) {\n var pos = AlignmentPattern.getPositions(version)\n\n for (var i = 0; i < pos.length; i++) {\n var row = pos[i][0]\n var col = pos[i][1]\n\n for (var r = -2; r <= 2; r++) {\n for (var c = -2; c <= 2; c++) {\n if (r === -2 || r === 2 || c === -2 || c === 2 ||\n (r === 0 && c === 0)) {\n matrix.set(row + r, col + c, true, true)\n } else {\n matrix.set(row + r, col + c, false, true)\n }\n }\n }\n }\n}\n\n/**\n * Add version info bits to matrix\n *\n * @param {BitMatrix} matrix Modules matrix\n * @param {Number} version QR Code version\n */\nfunction setupVersionInfo (matrix, version) {\n var size = matrix.size\n var bits = Version.getEncodedBits(version)\n var row, col, mod\n\n for (var i = 0; i < 18; i++) {\n row = Math.floor(i / 3)\n col = i % 3 + size - 8 - 3\n mod = ((bits >> i) & 1) === 1\n\n matrix.set(row, col, mod, true)\n matrix.set(col, row, mod, true)\n }\n}\n\n/**\n * Add format info bits to matrix\n *\n * @param {BitMatrix} matrix Modules matrix\n * @param {ErrorCorrectionLevel} errorCorrectionLevel Error correction level\n * @param {Number} maskPattern Mask pattern reference value\n */\nfunction setupFormatInfo (matrix, errorCorrectionLevel, maskPattern) {\n var size = matrix.size\n var bits = FormatInfo.getEncodedBits(errorCorrectionLevel, maskPattern)\n var i, mod\n\n for (i = 0; i < 15; i++) {\n mod = ((bits >> i) & 1) === 1\n\n // vertical\n if (i < 6) {\n matrix.set(i, 8, mod, true)\n } else if (i < 8) {\n matrix.set(i + 1, 8, mod, true)\n } else {\n matrix.set(size - 15 + i, 8, mod, true)\n }\n\n // horizontal\n if (i < 8) {\n matrix.set(8, size - i - 1, mod, true)\n } else if (i < 9) {\n matrix.set(8, 15 - i - 1 + 1, mod, true)\n } else {\n matrix.set(8, 15 - i - 1, mod, true)\n }\n }\n\n // fixed module\n matrix.set(size - 8, 8, 1, true)\n}\n\n/**\n * Add encoded data bits to matrix\n *\n * @param {BitMatrix} matrix Modules matrix\n * @param {Buffer} data Data codewords\n */\nfunction setupData (matrix, data) {\n var size = matrix.size\n var inc = -1\n var row = size - 1\n var bitIndex = 7\n var byteIndex = 0\n\n for (var col = size - 1; col > 0; col -= 2) {\n if (col === 6) col--\n\n while (true) {\n for (var c = 0; c < 2; c++) {\n if (!matrix.isReserved(row, col - c)) {\n var dark = false\n\n if (byteIndex < data.length) {\n dark = (((data[byteIndex] >>> bitIndex) & 1) === 1)\n }\n\n matrix.set(row, col - c, dark)\n bitIndex--\n\n if (bitIndex === -1) {\n byteIndex++\n bitIndex = 7\n }\n }\n }\n\n row += inc\n\n if (row < 0 || size <= row) {\n row -= inc\n inc = -inc\n break\n }\n }\n }\n}\n\n/**\n * Create encoded codewords from data input\n *\n * @param {Number} version QR Code version\n * @param {ErrorCorrectionLevel} errorCorrectionLevel Error correction level\n * @param {ByteData} data Data input\n * @return {Buffer} Buffer containing encoded codewords\n */\nfunction createData (version, errorCorrectionLevel, segments) {\n // Prepare data buffer\n var buffer = new BitBuffer()\n\n segments.forEach(function (data) {\n // prefix data with mode indicator (4 bits)\n buffer.put(data.mode.bit, 4)\n\n // Prefix data with character count indicator.\n // The character count indicator is a string of bits that represents the\n // number of characters that are being encoded.\n // The character count indicator must be placed after the mode indicator\n // and must be a certain number of bits long, depending on the QR version\n // and data mode\n // @see {@link Mode.getCharCountIndicator}.\n buffer.put(data.getLength(), Mode.getCharCountIndicator(data.mode, version))\n\n // add binary data sequence to buffer\n data.write(buffer)\n })\n\n // Calculate required number of bits\n var totalCodewords = Utils.getSymbolTotalCodewords(version)\n var ecTotalCodewords = ECCode.getTotalCodewordsCount(version, errorCorrectionLevel)\n var dataTotalCodewordsBits = (totalCodewords - ecTotalCodewords) * 8\n\n // Add a terminator.\n // If the bit string is shorter than the total number of required bits,\n // a terminator of up to four 0s must be added to the right side of the string.\n // If the bit string is more than four bits shorter than the required number of bits,\n // add four 0s to the end.\n if (buffer.getLengthInBits() + 4 <= dataTotalCodewordsBits) {\n buffer.put(0, 4)\n }\n\n // If the bit string is fewer than four bits shorter, add only the number of 0s that\n // are needed to reach the required number of bits.\n\n // After adding the terminator, if the number of bits in the string is not a multiple of 8,\n // pad the string on the right with 0s to make the string's length a multiple of 8.\n while (buffer.getLengthInBits() % 8 !== 0) {\n buffer.putBit(0)\n }\n\n // Add pad bytes if the string is still shorter than the total number of required bits.\n // Extend the buffer to fill the data capacity of the symbol corresponding to\n // the Version and Error Correction Level by adding the Pad Codewords 11101100 (0xEC)\n // and 00010001 (0x11) alternately.\n var remainingByte = (dataTotalCodewordsBits - buffer.getLengthInBits()) / 8\n for (var i = 0; i < remainingByte; i++) {\n buffer.put(i % 2 ? 0x11 : 0xEC, 8)\n }\n\n return createCodewords(buffer, version, errorCorrectionLevel)\n}\n\n/**\n * Encode input data with Reed-Solomon and return codewords with\n * relative error correction bits\n *\n * @param {BitBuffer} bitBuffer Data to encode\n * @param {Number} version QR Code version\n * @param {ErrorCorrectionLevel} errorCorrectionLevel Error correction level\n * @return {Buffer} Buffer containing encoded codewords\n */\nfunction createCodewords (bitBuffer, version, errorCorrectionLevel) {\n // Total codewords for this QR code version (Data + Error correction)\n var totalCodewords = Utils.getSymbolTotalCodewords(version)\n\n // Total number of error correction codewords\n var ecTotalCodewords = ECCode.getTotalCodewordsCount(version, errorCorrectionLevel)\n\n // Total number of data codewords\n var dataTotalCodewords = totalCodewords - ecTotalCodewords\n\n // Total number of blocks\n var ecTotalBlocks = ECCode.getBlocksCount(version, errorCorrectionLevel)\n\n // Calculate how many blocks each group should contain\n var blocksInGroup2 = totalCodewords % ecTotalBlocks\n var blocksInGroup1 = ecTotalBlocks - blocksInGroup2\n\n var totalCodewordsInGroup1 = Math.floor(totalCodewords / ecTotalBlocks)\n\n var dataCodewordsInGroup1 = Math.floor(dataTotalCodewords / ecTotalBlocks)\n var dataCodewordsInGroup2 = dataCodewordsInGroup1 + 1\n\n // Number of EC codewords is the same for both groups\n var ecCount = totalCodewordsInGroup1 - dataCodewordsInGroup1\n\n // Initialize a Reed-Solomon encoder with a generator polynomial of degree ecCount\n var rs = new ReedSolomonEncoder(ecCount)\n\n var offset = 0\n var dcData = new Array(ecTotalBlocks)\n var ecData = new Array(ecTotalBlocks)\n var maxDataSize = 0\n var buffer = new Buffer(bitBuffer.buffer)\n\n // Divide the buffer into the required number of blocks\n for (var b = 0; b < ecTotalBlocks; b++) {\n var dataSize = b < blocksInGroup1 ? dataCodewordsInGroup1 : dataCodewordsInGroup2\n\n // extract a block of data from buffer\n dcData[b] = buffer.slice(offset, offset + dataSize)\n\n // Calculate EC codewords for this data block\n ecData[b] = rs.encode(dcData[b])\n\n offset += dataSize\n maxDataSize = Math.max(maxDataSize, dataSize)\n }\n\n // Create final data\n // Interleave the data and error correction codewords from each block\n var data = new Buffer(totalCodewords)\n var index = 0\n var i, r\n\n // Add data codewords\n for (i = 0; i < maxDataSize; i++) {\n for (r = 0; r < ecTotalBlocks; r++) {\n if (i < dcData[r].length) {\n data[index++] = dcData[r][i]\n }\n }\n }\n\n // Apped EC codewords\n for (i = 0; i < ecCount; i++) {\n for (r = 0; r < ecTotalBlocks; r++) {\n data[index++] = ecData[r][i]\n }\n }\n\n return data\n}\n\n/**\n * Build QR Code symbol\n *\n * @param {String} data Input string\n * @param {Number} version QR Code version\n * @param {ErrorCorretionLevel} errorCorrectionLevel Error level\n * @param {MaskPattern} maskPattern Mask pattern\n * @return {Object} Object containing symbol data\n */\nfunction createSymbol (data, version, errorCorrectionLevel, maskPattern) {\n var segments\n\n if (isArray(data)) {\n segments = Segments.fromArray(data)\n } else if (typeof data === 'string') {\n var estimatedVersion = version\n\n if (!estimatedVersion) {\n var rawSegments = Segments.rawSplit(data)\n\n // Estimate best version that can contain raw splitted segments\n estimatedVersion = Version.getBestVersionForData(rawSegments,\n errorCorrectionLevel)\n }\n\n // Build optimized segments\n // If estimated version is undefined, try with the highest version\n segments = Segments.fromString(data, estimatedVersion || 40)\n } else {\n throw new Error('Invalid data')\n }\n\n // Get the min version that can contain data\n var bestVersion = Version.getBestVersionForData(segments,\n errorCorrectionLevel)\n\n // If no version is found, data cannot be stored\n if (!bestVersion) {\n throw new Error('The amount of data is too big to be stored in a QR Code')\n }\n\n // If not specified, use min version as default\n if (!version) {\n version = bestVersion\n\n // Check if the specified version can contain the data\n } else if (version < bestVersion) {\n throw new Error('\\n' +\n 'The chosen QR Code version cannot contain this amount of data.\\n' +\n 'Minimum version required to store current data is: ' + bestVersion + '.\\n'\n )\n }\n\n var dataBits = createData(version, errorCorrectionLevel, segments)\n\n // Allocate matrix buffer\n var moduleCount = Utils.getSymbolSize(version)\n var modules = new BitMatrix(moduleCount)\n\n // Add function modules\n setupFinderPattern(modules, version)\n setupTimingPattern(modules)\n setupAlignmentPattern(modules, version)\n\n // Add temporary dummy bits for format info just to set them as reserved.\n // This is needed to prevent these bits from being masked by {@link MaskPattern.applyMask}\n // since the masking operation must be performed only on the encoding region.\n // These blocks will be replaced with correct values later in code.\n setupFormatInfo(modules, errorCorrectionLevel, 0)\n\n if (version >= 7) {\n setupVersionInfo(modules, version)\n }\n\n // Add data codewords\n setupData(modules, dataBits)\n\n if (isNaN(maskPattern)) {\n // Find best mask pattern\n maskPattern = MaskPattern.getBestMask(modules,\n setupFormatInfo.bind(null, modules, errorCorrectionLevel))\n }\n\n // Apply mask pattern\n MaskPattern.applyMask(maskPattern, modules)\n\n // Replace format info bits with correct values\n setupFormatInfo(modules, errorCorrectionLevel, maskPattern)\n\n return {\n modules: modules,\n version: version,\n errorCorrectionLevel: errorCorrectionLevel,\n maskPattern: maskPattern,\n segments: segments\n }\n}\n\n/**\n * QR Code\n *\n * @param {String | Array} data Input data\n * @param {Object} options Optional configurations\n * @param {Number} options.version QR Code version\n * @param {String} options.errorCorrectionLevel Error correction level\n * @param {Function} options.toSJISFunc Helper func to convert utf8 to sjis\n */\nexports.create = function create (data, options) {\n if (typeof data === 'undefined' || data === '') {\n throw new Error('No input text')\n }\n\n var errorCorrectionLevel = ECLevel.M\n var version\n var mask\n\n if (typeof options !== 'undefined') {\n // Use higher error correction level as default\n errorCorrectionLevel = ECLevel.from(options.errorCorrectionLevel, ECLevel.M)\n version = Version.from(options.version)\n mask = MaskPattern.from(options.maskPattern)\n\n if (options.toSJISFunc) {\n Utils.setToSJISFunction(options.toSJISFunc)\n }\n }\n\n return createSymbol(data, version, errorCorrectionLevel, mask)\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/qrcode.js?");
|
|
487
|
+
|
|
488
|
+
/***/ }),
|
|
489
|
+
|
|
490
|
+
/***/ "./node_modules/qrcode/lib/core/reed-solomon-encoder.js":
|
|
491
|
+
/*!**************************************************************!*\
|
|
492
|
+
!*** ./node_modules/qrcode/lib/core/reed-solomon-encoder.js ***!
|
|
493
|
+
\**************************************************************/
|
|
494
|
+
/*! no static exports found */
|
|
495
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
496
|
+
|
|
497
|
+
eval("var Buffer = __webpack_require__(/*! ../utils/buffer */ \"./node_modules/qrcode/lib/utils/typedarray-buffer.js\")\nvar Polynomial = __webpack_require__(/*! ./polynomial */ \"./node_modules/qrcode/lib/core/polynomial.js\")\n\nfunction ReedSolomonEncoder (degree) {\n this.genPoly = undefined\n this.degree = degree\n\n if (this.degree) this.initialize(this.degree)\n}\n\n/**\n * Initialize the encoder.\n * The input param should correspond to the number of error correction codewords.\n *\n * @param {Number} degree\n */\nReedSolomonEncoder.prototype.initialize = function initialize (degree) {\n // create an irreducible generator polynomial\n this.degree = degree\n this.genPoly = Polynomial.generateECPolynomial(this.degree)\n}\n\n/**\n * Encodes a chunk of data\n *\n * @param {Buffer} data Buffer containing input data\n * @return {Buffer} Buffer containing encoded data\n */\nReedSolomonEncoder.prototype.encode = function encode (data) {\n if (!this.genPoly) {\n throw new Error('Encoder not initialized')\n }\n\n // Calculate EC for this data block\n // extends data size to data+genPoly size\n var pad = new Buffer(this.degree)\n pad.fill(0)\n var paddedData = Buffer.concat([data, pad], data.length + this.degree)\n\n // The error correction codewords are the remainder after dividing the data codewords\n // by a generator polynomial\n var remainder = Polynomial.mod(paddedData, this.genPoly)\n\n // return EC data blocks (last n byte, where n is the degree of genPoly)\n // If coefficients number in remainder are less than genPoly degree,\n // pad with 0s to the left to reach the needed number of coefficients\n var start = this.degree - remainder.length\n if (start > 0) {\n var buff = new Buffer(this.degree)\n buff.fill(0)\n remainder.copy(buff, start)\n\n return buff\n }\n\n return remainder\n}\n\nmodule.exports = ReedSolomonEncoder\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/reed-solomon-encoder.js?");
|
|
498
|
+
|
|
499
|
+
/***/ }),
|
|
500
|
+
|
|
501
|
+
/***/ "./node_modules/qrcode/lib/core/regex.js":
|
|
502
|
+
/*!***********************************************!*\
|
|
503
|
+
!*** ./node_modules/qrcode/lib/core/regex.js ***!
|
|
504
|
+
\***********************************************/
|
|
505
|
+
/*! no static exports found */
|
|
506
|
+
/***/ (function(module, exports) {
|
|
507
|
+
|
|
508
|
+
eval("var numeric = '[0-9]+'\nvar alphanumeric = '[A-Z $%*+\\\\-./:]+'\nvar kanji = '(?:[u3000-u303F]|[u3040-u309F]|[u30A0-u30FF]|' +\n '[uFF00-uFFEF]|[u4E00-u9FAF]|[u2605-u2606]|[u2190-u2195]|u203B|' +\n '[u2010u2015u2018u2019u2025u2026u201Cu201Du2225u2260]|' +\n '[u0391-u0451]|[u00A7u00A8u00B1u00B4u00D7u00F7])+'\nkanji = kanji.replace(/u/g, '\\\\u')\n\nvar byte = '(?:(?![A-Z0-9 $%*+\\\\-./:]|' + kanji + ')(?:.|[\\r\\n]))+'\n\nexports.KANJI = new RegExp(kanji, 'g')\nexports.BYTE_KANJI = new RegExp('[^A-Z0-9 $%*+\\\\-./:]+', 'g')\nexports.BYTE = new RegExp(byte, 'g')\nexports.NUMERIC = new RegExp(numeric, 'g')\nexports.ALPHANUMERIC = new RegExp(alphanumeric, 'g')\n\nvar TEST_KANJI = new RegExp('^' + kanji + '$')\nvar TEST_NUMERIC = new RegExp('^' + numeric + '$')\nvar TEST_ALPHANUMERIC = new RegExp('^[A-Z0-9 $%*+\\\\-./:]+$')\n\nexports.testKanji = function testKanji (str) {\n return TEST_KANJI.test(str)\n}\n\nexports.testNumeric = function testNumeric (str) {\n return TEST_NUMERIC.test(str)\n}\n\nexports.testAlphanumeric = function testAlphanumeric (str) {\n return TEST_ALPHANUMERIC.test(str)\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/regex.js?");
|
|
509
|
+
|
|
510
|
+
/***/ }),
|
|
511
|
+
|
|
512
|
+
/***/ "./node_modules/qrcode/lib/core/segments.js":
|
|
513
|
+
/*!**************************************************!*\
|
|
514
|
+
!*** ./node_modules/qrcode/lib/core/segments.js ***!
|
|
515
|
+
\**************************************************/
|
|
516
|
+
/*! no static exports found */
|
|
517
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
518
|
+
|
|
519
|
+
eval("var Mode = __webpack_require__(/*! ./mode */ \"./node_modules/qrcode/lib/core/mode.js\")\nvar NumericData = __webpack_require__(/*! ./numeric-data */ \"./node_modules/qrcode/lib/core/numeric-data.js\")\nvar AlphanumericData = __webpack_require__(/*! ./alphanumeric-data */ \"./node_modules/qrcode/lib/core/alphanumeric-data.js\")\nvar ByteData = __webpack_require__(/*! ./byte-data */ \"./node_modules/qrcode/lib/core/byte-data.js\")\nvar KanjiData = __webpack_require__(/*! ./kanji-data */ \"./node_modules/qrcode/lib/core/kanji-data.js\")\nvar Regex = __webpack_require__(/*! ./regex */ \"./node_modules/qrcode/lib/core/regex.js\")\nvar Utils = __webpack_require__(/*! ./utils */ \"./node_modules/qrcode/lib/core/utils.js\")\nvar dijkstra = __webpack_require__(/*! dijkstrajs */ \"./node_modules/dijkstrajs/dijkstra.js\")\n\n/**\n * Returns UTF8 byte length\n *\n * @param {String} str Input string\n * @return {Number} Number of byte\n */\nfunction getStringByteLength (str) {\n return unescape(encodeURIComponent(str)).length\n}\n\n/**\n * Get a list of segments of the specified mode\n * from a string\n *\n * @param {Mode} mode Segment mode\n * @param {String} str String to process\n * @return {Array} Array of object with segments data\n */\nfunction getSegments (regex, mode, str) {\n var segments = []\n var result\n\n while ((result = regex.exec(str)) !== null) {\n segments.push({\n data: result[0],\n index: result.index,\n mode: mode,\n length: result[0].length\n })\n }\n\n return segments\n}\n\n/**\n * Extracts a series of segments with the appropriate\n * modes from a string\n *\n * @param {String} dataStr Input string\n * @return {Array} Array of object with segments data\n */\nfunction getSegmentsFromString (dataStr) {\n var numSegs = getSegments(Regex.NUMERIC, Mode.NUMERIC, dataStr)\n var alphaNumSegs = getSegments(Regex.ALPHANUMERIC, Mode.ALPHANUMERIC, dataStr)\n var byteSegs\n var kanjiSegs\n\n if (Utils.isKanjiModeEnabled()) {\n byteSegs = getSegments(Regex.BYTE, Mode.BYTE, dataStr)\n kanjiSegs = getSegments(Regex.KANJI, Mode.KANJI, dataStr)\n } else {\n byteSegs = getSegments(Regex.BYTE_KANJI, Mode.BYTE, dataStr)\n kanjiSegs = []\n }\n\n var segs = numSegs.concat(alphaNumSegs, byteSegs, kanjiSegs)\n\n return segs\n .sort(function (s1, s2) {\n return s1.index - s2.index\n })\n .map(function (obj) {\n return {\n data: obj.data,\n mode: obj.mode,\n length: obj.length\n }\n })\n}\n\n/**\n * Returns how many bits are needed to encode a string of\n * specified length with the specified mode\n *\n * @param {Number} length String length\n * @param {Mode} mode Segment mode\n * @return {Number} Bit length\n */\nfunction getSegmentBitsLength (length, mode) {\n switch (mode) {\n case Mode.NUMERIC:\n return NumericData.getBitsLength(length)\n case Mode.ALPHANUMERIC:\n return AlphanumericData.getBitsLength(length)\n case Mode.KANJI:\n return KanjiData.getBitsLength(length)\n case Mode.BYTE:\n return ByteData.getBitsLength(length)\n }\n}\n\n/**\n * Merges adjacent segments which have the same mode\n *\n * @param {Array} segs Array of object with segments data\n * @return {Array} Array of object with segments data\n */\nfunction mergeSegments (segs) {\n return segs.reduce(function (acc, curr) {\n var prevSeg = acc.length - 1 >= 0 ? acc[acc.length - 1] : null\n if (prevSeg && prevSeg.mode === curr.mode) {\n acc[acc.length - 1].data += curr.data\n return acc\n }\n\n acc.push(curr)\n return acc\n }, [])\n}\n\n/**\n * Generates a list of all possible nodes combination which\n * will be used to build a segments graph.\n *\n * Nodes are divided by groups. Each group will contain a list of all the modes\n * in which is possible to encode the given text.\n *\n * For example the text '12345' can be encoded as Numeric, Alphanumeric or Byte.\n * The group for '12345' will contain then 3 objects, one for each\n * possible encoding mode.\n *\n * Each node represents a possible segment.\n *\n * @param {Array} segs Array of object with segments data\n * @return {Array} Array of object with segments data\n */\nfunction buildNodes (segs) {\n var nodes = []\n for (var i = 0; i < segs.length; i++) {\n var seg = segs[i]\n\n switch (seg.mode) {\n case Mode.NUMERIC:\n nodes.push([seg,\n { data: seg.data, mode: Mode.ALPHANUMERIC, length: seg.length },\n { data: seg.data, mode: Mode.BYTE, length: seg.length }\n ])\n break\n case Mode.ALPHANUMERIC:\n nodes.push([seg,\n { data: seg.data, mode: Mode.BYTE, length: seg.length }\n ])\n break\n case Mode.KANJI:\n nodes.push([seg,\n { data: seg.data, mode: Mode.BYTE, length: getStringByteLength(seg.data) }\n ])\n break\n case Mode.BYTE:\n nodes.push([\n { data: seg.data, mode: Mode.BYTE, length: getStringByteLength(seg.data) }\n ])\n }\n }\n\n return nodes\n}\n\n/**\n * Builds a graph from a list of nodes.\n * All segments in each node group will be connected with all the segments of\n * the next group and so on.\n *\n * At each connection will be assigned a weight depending on the\n * segment's byte length.\n *\n * @param {Array} nodes Array of object with segments data\n * @param {Number} version QR Code version\n * @return {Object} Graph of all possible segments\n */\nfunction buildGraph (nodes, version) {\n var table = {}\n var graph = {'start': {}}\n var prevNodeIds = ['start']\n\n for (var i = 0; i < nodes.length; i++) {\n var nodeGroup = nodes[i]\n var currentNodeIds = []\n\n for (var j = 0; j < nodeGroup.length; j++) {\n var node = nodeGroup[j]\n var key = '' + i + j\n\n currentNodeIds.push(key)\n table[key] = { node: node, lastCount: 0 }\n graph[key] = {}\n\n for (var n = 0; n < prevNodeIds.length; n++) {\n var prevNodeId = prevNodeIds[n]\n\n if (table[prevNodeId] && table[prevNodeId].node.mode === node.mode) {\n graph[prevNodeId][key] =\n getSegmentBitsLength(table[prevNodeId].lastCount + node.length, node.mode) -\n getSegmentBitsLength(table[prevNodeId].lastCount, node.mode)\n\n table[prevNodeId].lastCount += node.length\n } else {\n if (table[prevNodeId]) table[prevNodeId].lastCount = node.length\n\n graph[prevNodeId][key] = getSegmentBitsLength(node.length, node.mode) +\n 4 + Mode.getCharCountIndicator(node.mode, version) // switch cost\n }\n }\n }\n\n prevNodeIds = currentNodeIds\n }\n\n for (n = 0; n < prevNodeIds.length; n++) {\n graph[prevNodeIds[n]]['end'] = 0\n }\n\n return { map: graph, table: table }\n}\n\n/**\n * Builds a segment from a specified data and mode.\n * If a mode is not specified, the more suitable will be used.\n *\n * @param {String} data Input data\n * @param {Mode | String} modesHint Data mode\n * @return {Segment} Segment\n */\nfunction buildSingleSegment (data, modesHint) {\n var mode\n var bestMode = Mode.getBestModeForData(data)\n\n mode = Mode.from(modesHint, bestMode)\n\n // Make sure data can be encoded\n if (mode !== Mode.BYTE && mode.bit < bestMode.bit) {\n throw new Error('\"' + data + '\"' +\n ' cannot be encoded with mode ' + Mode.toString(mode) +\n '.\\n Suggested mode is: ' + Mode.toString(bestMode))\n }\n\n // Use Mode.BYTE if Kanji support is disabled\n if (mode === Mode.KANJI && !Utils.isKanjiModeEnabled()) {\n mode = Mode.BYTE\n }\n\n switch (mode) {\n case Mode.NUMERIC:\n return new NumericData(data)\n\n case Mode.ALPHANUMERIC:\n return new AlphanumericData(data)\n\n case Mode.KANJI:\n return new KanjiData(data)\n\n case Mode.BYTE:\n return new ByteData(data)\n }\n}\n\n/**\n * Builds a list of segments from an array.\n * Array can contain Strings or Objects with segment's info.\n *\n * For each item which is a string, will be generated a segment with the given\n * string and the more appropriate encoding mode.\n *\n * For each item which is an object, will be generated a segment with the given\n * data and mode.\n * Objects must contain at least the property \"data\".\n * If property \"mode\" is not present, the more suitable mode will be used.\n *\n * @param {Array} array Array of objects with segments data\n * @return {Array} Array of Segments\n */\nexports.fromArray = function fromArray (array) {\n return array.reduce(function (acc, seg) {\n if (typeof seg === 'string') {\n acc.push(buildSingleSegment(seg, null))\n } else if (seg.data) {\n acc.push(buildSingleSegment(seg.data, seg.mode))\n }\n\n return acc\n }, [])\n}\n\n/**\n * Builds an optimized sequence of segments from a string,\n * which will produce the shortest possible bitstream.\n *\n * @param {String} data Input string\n * @param {Number} version QR Code version\n * @return {Array} Array of segments\n */\nexports.fromString = function fromString (data, version) {\n var segs = getSegmentsFromString(data, Utils.isKanjiModeEnabled())\n\n var nodes = buildNodes(segs)\n var graph = buildGraph(nodes, version)\n var path = dijkstra.find_path(graph.map, 'start', 'end')\n\n var optimizedSegs = []\n for (var i = 1; i < path.length - 1; i++) {\n optimizedSegs.push(graph.table[path[i]].node)\n }\n\n return exports.fromArray(mergeSegments(optimizedSegs))\n}\n\n/**\n * Splits a string in various segments with the modes which\n * best represent their content.\n * The produced segments are far from being optimized.\n * The output of this function is only used to estimate a QR Code version\n * which may contain the data.\n *\n * @param {string} data Input string\n * @return {Array} Array of segments\n */\nexports.rawSplit = function rawSplit (data) {\n return exports.fromArray(\n getSegmentsFromString(data, Utils.isKanjiModeEnabled())\n )\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/segments.js?");
|
|
520
|
+
|
|
521
|
+
/***/ }),
|
|
522
|
+
|
|
523
|
+
/***/ "./node_modules/qrcode/lib/core/utils.js":
|
|
524
|
+
/*!***********************************************!*\
|
|
525
|
+
!*** ./node_modules/qrcode/lib/core/utils.js ***!
|
|
526
|
+
\***********************************************/
|
|
527
|
+
/*! no static exports found */
|
|
528
|
+
/***/ (function(module, exports) {
|
|
529
|
+
|
|
530
|
+
eval("var toSJISFunction\nvar CODEWORDS_COUNT = [\n 0, // Not used\n 26, 44, 70, 100, 134, 172, 196, 242, 292, 346,\n 404, 466, 532, 581, 655, 733, 815, 901, 991, 1085,\n 1156, 1258, 1364, 1474, 1588, 1706, 1828, 1921, 2051, 2185,\n 2323, 2465, 2611, 2761, 2876, 3034, 3196, 3362, 3532, 3706\n]\n\n/**\n * Returns the QR Code size for the specified version\n *\n * @param {Number} version QR Code version\n * @return {Number} size of QR code\n */\nexports.getSymbolSize = function getSymbolSize (version) {\n if (!version) throw new Error('\"version\" cannot be null or undefined')\n if (version < 1 || version > 40) throw new Error('\"version\" should be in range from 1 to 40')\n return version * 4 + 17\n}\n\n/**\n * Returns the total number of codewords used to store data and EC information.\n *\n * @param {Number} version QR Code version\n * @return {Number} Data length in bits\n */\nexports.getSymbolTotalCodewords = function getSymbolTotalCodewords (version) {\n return CODEWORDS_COUNT[version]\n}\n\n/**\n * Encode data with Bose-Chaudhuri-Hocquenghem\n *\n * @param {Number} data Value to encode\n * @return {Number} Encoded value\n */\nexports.getBCHDigit = function (data) {\n var digit = 0\n\n while (data !== 0) {\n digit++\n data >>>= 1\n }\n\n return digit\n}\n\nexports.setToSJISFunction = function setToSJISFunction (f) {\n if (typeof f !== 'function') {\n throw new Error('\"toSJISFunc\" is not a valid function.')\n }\n\n toSJISFunction = f\n}\n\nexports.isKanjiModeEnabled = function () {\n return typeof toSJISFunction !== 'undefined'\n}\n\nexports.toSJIS = function toSJIS (kanji) {\n return toSJISFunction(kanji)\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/utils.js?");
|
|
531
|
+
|
|
532
|
+
/***/ }),
|
|
533
|
+
|
|
534
|
+
/***/ "./node_modules/qrcode/lib/core/version-check.js":
|
|
535
|
+
/*!*******************************************************!*\
|
|
536
|
+
!*** ./node_modules/qrcode/lib/core/version-check.js ***!
|
|
537
|
+
\*******************************************************/
|
|
538
|
+
/*! no static exports found */
|
|
539
|
+
/***/ (function(module, exports) {
|
|
540
|
+
|
|
541
|
+
eval("/**\n * Check if QR Code version is valid\n *\n * @param {Number} version QR Code version\n * @return {Boolean} true if valid version, false otherwise\n */\nexports.isValid = function isValid (version) {\n return !isNaN(version) && version >= 1 && version <= 40\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/version-check.js?");
|
|
542
|
+
|
|
543
|
+
/***/ }),
|
|
544
|
+
|
|
545
|
+
/***/ "./node_modules/qrcode/lib/core/version.js":
|
|
546
|
+
/*!*************************************************!*\
|
|
547
|
+
!*** ./node_modules/qrcode/lib/core/version.js ***!
|
|
548
|
+
\*************************************************/
|
|
549
|
+
/*! no static exports found */
|
|
550
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
551
|
+
|
|
552
|
+
eval("var Utils = __webpack_require__(/*! ./utils */ \"./node_modules/qrcode/lib/core/utils.js\")\nvar ECCode = __webpack_require__(/*! ./error-correction-code */ \"./node_modules/qrcode/lib/core/error-correction-code.js\")\nvar ECLevel = __webpack_require__(/*! ./error-correction-level */ \"./node_modules/qrcode/lib/core/error-correction-level.js\")\nvar Mode = __webpack_require__(/*! ./mode */ \"./node_modules/qrcode/lib/core/mode.js\")\nvar VersionCheck = __webpack_require__(/*! ./version-check */ \"./node_modules/qrcode/lib/core/version-check.js\")\nvar isArray = __webpack_require__(/*! isarray */ \"./node_modules/qrcode/node_modules/isarray/index.js\")\n\n// Generator polynomial used to encode version information\nvar G18 = (1 << 12) | (1 << 11) | (1 << 10) | (1 << 9) | (1 << 8) | (1 << 5) | (1 << 2) | (1 << 0)\nvar G18_BCH = Utils.getBCHDigit(G18)\n\nfunction getBestVersionForDataLength (mode, length, errorCorrectionLevel) {\n for (var currentVersion = 1; currentVersion <= 40; currentVersion++) {\n if (length <= exports.getCapacity(currentVersion, errorCorrectionLevel, mode)) {\n return currentVersion\n }\n }\n\n return undefined\n}\n\nfunction getReservedBitsCount (mode, version) {\n // Character count indicator + mode indicator bits\n return Mode.getCharCountIndicator(mode, version) + 4\n}\n\nfunction getTotalBitsFromDataArray (segments, version) {\n var totalBits = 0\n\n segments.forEach(function (data) {\n var reservedBits = getReservedBitsCount(data.mode, version)\n totalBits += reservedBits + data.getBitsLength()\n })\n\n return totalBits\n}\n\nfunction getBestVersionForMixedData (segments, errorCorrectionLevel) {\n for (var currentVersion = 1; currentVersion <= 40; currentVersion++) {\n var length = getTotalBitsFromDataArray(segments, currentVersion)\n if (length <= exports.getCapacity(currentVersion, errorCorrectionLevel, Mode.MIXED)) {\n return currentVersion\n }\n }\n\n return undefined\n}\n\n/**\n * Returns version number from a value.\n * If value is not a valid version, returns defaultValue\n *\n * @param {Number|String} value QR Code version\n * @param {Number} defaultValue Fallback value\n * @return {Number} QR Code version number\n */\nexports.from = function from (value, defaultValue) {\n if (VersionCheck.isValid(value)) {\n return parseInt(value, 10)\n }\n\n return defaultValue\n}\n\n/**\n * Returns how much data can be stored with the specified QR code version\n * and error correction level\n *\n * @param {Number} version QR Code version (1-40)\n * @param {Number} errorCorrectionLevel Error correction level\n * @param {Mode} mode Data mode\n * @return {Number} Quantity of storable data\n */\nexports.getCapacity = function getCapacity (version, errorCorrectionLevel, mode) {\n if (!VersionCheck.isValid(version)) {\n throw new Error('Invalid QR Code version')\n }\n\n // Use Byte mode as default\n if (typeof mode === 'undefined') mode = Mode.BYTE\n\n // Total codewords for this QR code version (Data + Error correction)\n var totalCodewords = Utils.getSymbolTotalCodewords(version)\n\n // Total number of error correction codewords\n var ecTotalCodewords = ECCode.getTotalCodewordsCount(version, errorCorrectionLevel)\n\n // Total number of data codewords\n var dataTotalCodewordsBits = (totalCodewords - ecTotalCodewords) * 8\n\n if (mode === Mode.MIXED) return dataTotalCodewordsBits\n\n var usableBits = dataTotalCodewordsBits - getReservedBitsCount(mode, version)\n\n // Return max number of storable codewords\n switch (mode) {\n case Mode.NUMERIC:\n return Math.floor((usableBits / 10) * 3)\n\n case Mode.ALPHANUMERIC:\n return Math.floor((usableBits / 11) * 2)\n\n case Mode.KANJI:\n return Math.floor(usableBits / 13)\n\n case Mode.BYTE:\n default:\n return Math.floor(usableBits / 8)\n }\n}\n\n/**\n * Returns the minimum version needed to contain the amount of data\n *\n * @param {Segment} data Segment of data\n * @param {Number} [errorCorrectionLevel=H] Error correction level\n * @param {Mode} mode Data mode\n * @return {Number} QR Code version\n */\nexports.getBestVersionForData = function getBestVersionForData (data, errorCorrectionLevel) {\n var seg\n\n var ecl = ECLevel.from(errorCorrectionLevel, ECLevel.M)\n\n if (isArray(data)) {\n if (data.length > 1) {\n return getBestVersionForMixedData(data, ecl)\n }\n\n if (data.length === 0) {\n return 1\n }\n\n seg = data[0]\n } else {\n seg = data\n }\n\n return getBestVersionForDataLength(seg.mode, seg.getLength(), ecl)\n}\n\n/**\n * Returns version information with relative error correction bits\n *\n * The version information is included in QR Code symbols of version 7 or larger.\n * It consists of an 18-bit sequence containing 6 data bits,\n * with 12 error correction bits calculated using the (18, 6) Golay code.\n *\n * @param {Number} version QR Code version\n * @return {Number} Encoded version info bits\n */\nexports.getEncodedBits = function getEncodedBits (version) {\n if (!VersionCheck.isValid(version) || version < 7) {\n throw new Error('Invalid QR Code version')\n }\n\n var d = version << 12\n\n while (Utils.getBCHDigit(d) - G18_BCH >= 0) {\n d ^= (G18 << (Utils.getBCHDigit(d) - G18_BCH))\n }\n\n return (version << 12) | d\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/core/version.js?");
|
|
553
|
+
|
|
554
|
+
/***/ }),
|
|
555
|
+
|
|
556
|
+
/***/ "./node_modules/qrcode/lib/renderer/canvas.js":
|
|
557
|
+
/*!****************************************************!*\
|
|
558
|
+
!*** ./node_modules/qrcode/lib/renderer/canvas.js ***!
|
|
559
|
+
\****************************************************/
|
|
560
|
+
/*! no static exports found */
|
|
561
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
562
|
+
|
|
563
|
+
eval("var Utils = __webpack_require__(/*! ./utils */ \"./node_modules/qrcode/lib/renderer/utils.js\")\n\nfunction clearCanvas (ctx, canvas, size) {\n ctx.clearRect(0, 0, canvas.width, canvas.height)\n\n if (!canvas.style) canvas.style = {}\n canvas.height = size\n canvas.width = size\n canvas.style.height = size + 'px'\n canvas.style.width = size + 'px'\n}\n\nfunction getCanvasElement () {\n try {\n return document.createElement('canvas')\n } catch (e) {\n throw new Error('You need to specify a canvas element')\n }\n}\n\nexports.render = function render (qrData, canvas, options) {\n var opts = options\n var canvasEl = canvas\n\n if (typeof opts === 'undefined' && (!canvas || !canvas.getContext)) {\n opts = canvas\n canvas = undefined\n }\n\n if (!canvas) {\n canvasEl = getCanvasElement()\n }\n\n opts = Utils.getOptions(opts)\n var size = Utils.getImageWidth(qrData.modules.size, opts)\n\n var ctx = canvasEl.getContext('2d')\n var image = ctx.createImageData(size, size)\n Utils.qrToImageData(image.data, qrData, opts)\n\n clearCanvas(ctx, canvasEl, size)\n ctx.putImageData(image, 0, 0)\n\n return canvasEl\n}\n\nexports.renderToDataURL = function renderToDataURL (qrData, canvas, options) {\n var opts = options\n\n if (typeof opts === 'undefined' && (!canvas || !canvas.getContext)) {\n opts = canvas\n canvas = undefined\n }\n\n if (!opts) opts = {}\n\n var canvasEl = exports.render(qrData, canvas, opts)\n\n var type = opts.type || 'image/png'\n var rendererOpts = opts.rendererOpts || {}\n\n return canvasEl.toDataURL(type, rendererOpts.quality)\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/renderer/canvas.js?");
|
|
564
|
+
|
|
565
|
+
/***/ }),
|
|
566
|
+
|
|
567
|
+
/***/ "./node_modules/qrcode/lib/renderer/svg-tag.js":
|
|
568
|
+
/*!*****************************************************!*\
|
|
569
|
+
!*** ./node_modules/qrcode/lib/renderer/svg-tag.js ***!
|
|
570
|
+
\*****************************************************/
|
|
571
|
+
/*! no static exports found */
|
|
572
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
573
|
+
|
|
574
|
+
eval("var Utils = __webpack_require__(/*! ./utils */ \"./node_modules/qrcode/lib/renderer/utils.js\")\n\nfunction getColorAttrib (color, attrib) {\n var alpha = color.a / 255\n var str = attrib + '=\"' + color.hex + '\"'\n\n return alpha < 1\n ? str + ' ' + attrib + '-opacity=\"' + alpha.toFixed(2).slice(1) + '\"'\n : str\n}\n\nfunction svgCmd (cmd, x, y) {\n var str = cmd + x\n if (typeof y !== 'undefined') str += ' ' + y\n\n return str\n}\n\nfunction qrToPath (data, size, margin) {\n var path = ''\n var moveBy = 0\n var newRow = false\n var lineLength = 0\n\n for (var i = 0; i < data.length; i++) {\n var col = Math.floor(i % size)\n var row = Math.floor(i / size)\n\n if (!col && !newRow) newRow = true\n\n if (data[i]) {\n lineLength++\n\n if (!(i > 0 && col > 0 && data[i - 1])) {\n path += newRow\n ? svgCmd('M', col + margin, 0.5 + row + margin)\n : svgCmd('m', moveBy, 0)\n\n moveBy = 0\n newRow = false\n }\n\n if (!(col + 1 < size && data[i + 1])) {\n path += svgCmd('h', lineLength)\n lineLength = 0\n }\n } else {\n moveBy++\n }\n }\n\n return path\n}\n\nexports.render = function render (qrData, options, cb) {\n var opts = Utils.getOptions(options)\n var size = qrData.modules.size\n var data = qrData.modules.data\n var qrcodesize = size + opts.margin * 2\n\n var bg = !opts.color.light.a\n ? ''\n : '<path ' + getColorAttrib(opts.color.light, 'fill') +\n ' d=\"M0 0h' + qrcodesize + 'v' + qrcodesize + 'H0z\"/>'\n\n var path =\n '<path ' + getColorAttrib(opts.color.dark, 'stroke') +\n ' d=\"' + qrToPath(data, size, opts.margin) + '\"/>'\n\n var viewBox = 'viewBox=\"' + '0 0 ' + qrcodesize + ' ' + qrcodesize + '\"'\n\n var width = !opts.width ? '' : 'width=\"' + opts.width + '\" height=\"' + opts.width + '\" '\n\n var svgTag = '<svg xmlns=\"http://www.w3.org/2000/svg\" ' + width + viewBox + ' shape-rendering=\"crispEdges\">' + bg + path + '</svg>\\n'\n\n if (typeof cb === 'function') {\n cb(null, svgTag)\n }\n\n return svgTag\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/renderer/svg-tag.js?");
|
|
575
|
+
|
|
576
|
+
/***/ }),
|
|
577
|
+
|
|
578
|
+
/***/ "./node_modules/qrcode/lib/renderer/utils.js":
|
|
579
|
+
/*!***************************************************!*\
|
|
580
|
+
!*** ./node_modules/qrcode/lib/renderer/utils.js ***!
|
|
581
|
+
\***************************************************/
|
|
582
|
+
/*! no static exports found */
|
|
583
|
+
/***/ (function(module, exports) {
|
|
584
|
+
|
|
585
|
+
eval("function hex2rgba (hex) {\n if (typeof hex !== 'string') {\n throw new Error('Color should be defined as hex string')\n }\n\n var hexCode = hex.slice().replace('#', '').split('')\n if (hexCode.length < 3 || hexCode.length === 5 || hexCode.length > 8) {\n throw new Error('Invalid hex color: ' + hex)\n }\n\n // Convert from short to long form (fff -> ffffff)\n if (hexCode.length === 3 || hexCode.length === 4) {\n hexCode = Array.prototype.concat.apply([], hexCode.map(function (c) {\n return [c, c]\n }))\n }\n\n // Add default alpha value\n if (hexCode.length === 6) hexCode.push('F', 'F')\n\n var hexValue = parseInt(hexCode.join(''), 16)\n\n return {\n r: (hexValue >> 24) & 255,\n g: (hexValue >> 16) & 255,\n b: (hexValue >> 8) & 255,\n a: hexValue & 255,\n hex: '#' + hexCode.slice(0, 6).join('')\n }\n}\n\nexports.getOptions = function getOptions (options) {\n if (!options) options = {}\n if (!options.color) options.color = {}\n\n var margin = typeof options.margin === 'undefined' ||\n options.margin === null ||\n options.margin < 0 ? 4 : options.margin\n\n var width = options.width && options.width >= 21 ? options.width : undefined\n var scale = options.scale || 4\n\n return {\n width: width,\n scale: width ? 4 : scale,\n margin: margin,\n color: {\n dark: hex2rgba(options.color.dark || '#000000ff'),\n light: hex2rgba(options.color.light || '#ffffffff')\n },\n type: options.type,\n rendererOpts: options.rendererOpts || {}\n }\n}\n\nexports.getScale = function getScale (qrSize, opts) {\n return opts.width && opts.width >= qrSize + opts.margin * 2\n ? opts.width / (qrSize + opts.margin * 2)\n : opts.scale\n}\n\nexports.getImageWidth = function getImageWidth (qrSize, opts) {\n var scale = exports.getScale(qrSize, opts)\n return Math.floor((qrSize + opts.margin * 2) * scale)\n}\n\nexports.qrToImageData = function qrToImageData (imgData, qr, opts) {\n var size = qr.modules.size\n var data = qr.modules.data\n var scale = exports.getScale(size, opts)\n var symbolSize = Math.floor((size + opts.margin * 2) * scale)\n var scaledMargin = opts.margin * scale\n var palette = [opts.color.light, opts.color.dark]\n\n for (var i = 0; i < symbolSize; i++) {\n for (var j = 0; j < symbolSize; j++) {\n var posDst = (i * symbolSize + j) * 4\n var pxColor = opts.color.light\n\n if (i >= scaledMargin && j >= scaledMargin &&\n i < symbolSize - scaledMargin && j < symbolSize - scaledMargin) {\n var iSrc = Math.floor((i - scaledMargin) / scale)\n var jSrc = Math.floor((j - scaledMargin) / scale)\n pxColor = palette[data[iSrc * size + jSrc] ? 1 : 0]\n }\n\n imgData[posDst++] = pxColor.r\n imgData[posDst++] = pxColor.g\n imgData[posDst++] = pxColor.b\n imgData[posDst] = pxColor.a\n }\n }\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/renderer/utils.js?");
|
|
586
|
+
|
|
587
|
+
/***/ }),
|
|
588
|
+
|
|
589
|
+
/***/ "./node_modules/qrcode/lib/utils/typedarray-buffer.js":
|
|
590
|
+
/*!************************************************************!*\
|
|
591
|
+
!*** ./node_modules/qrcode/lib/utils/typedarray-buffer.js ***!
|
|
592
|
+
\************************************************************/
|
|
593
|
+
/*! no static exports found */
|
|
594
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
595
|
+
|
|
596
|
+
"use strict";
|
|
597
|
+
eval("/**\n * Implementation of a subset of node.js Buffer methods for the browser.\n * Based on https://github.com/feross/buffer\n */\n\n/* eslint-disable no-proto */\n\n\n\nvar isArray = __webpack_require__(/*! isarray */ \"./node_modules/qrcode/node_modules/isarray/index.js\")\n\nfunction typedArraySupport () {\n // Can typed array instances be augmented?\n try {\n var arr = new Uint8Array(1)\n arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n return arr.foo() === 42\n } catch (e) {\n return false\n }\n}\n\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nvar K_MAX_LENGTH = Buffer.TYPED_ARRAY_SUPPORT\n ? 0x7fffffff\n : 0x3fffffff\n\nfunction Buffer (arg, offset, length) {\n if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) {\n return new Buffer(arg, offset, length)\n }\n\n if (typeof arg === 'number') {\n return allocUnsafe(this, arg)\n }\n\n return from(this, arg, offset, length)\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n Buffer.prototype.__proto__ = Uint8Array.prototype\n Buffer.__proto__ = Uint8Array\n\n // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n if (typeof Symbol !== 'undefined' && Symbol.species &&\n Buffer[Symbol.species] === Buffer) {\n Object.defineProperty(Buffer, Symbol.species, {\n value: null,\n configurable: true,\n enumerable: false,\n writable: false\n })\n }\n}\n\nfunction checked (length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction isnan (val) {\n return val !== val // eslint-disable-line no-self-compare\n}\n\nfunction createBuffer (that, length) {\n var buf\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n buf = new Uint8Array(length)\n buf.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n buf = that\n if (buf === null) {\n buf = new Buffer(length)\n }\n buf.length = length\n }\n\n return buf\n}\n\nfunction allocUnsafe (that, size) {\n var buf = createBuffer(that, size < 0 ? 0 : checked(size) | 0)\n\n if (!Buffer.TYPED_ARRAY_SUPPORT) {\n for (var i = 0; i < size; ++i) {\n buf[i] = 0\n }\n }\n\n return buf\n}\n\nfunction fromString (that, string) {\n var length = byteLength(string) | 0\n var buf = createBuffer(that, length)\n\n var actual = buf.write(string)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual)\n }\n\n return buf\n}\n\nfunction fromArrayLike (that, array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n var buf = createBuffer(that, length)\n for (var i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255\n }\n return buf\n}\n\nfunction fromArrayBuffer (that, array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\\'offset\\' is out of bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\\'length\\' is out of bounds')\n }\n\n var buf\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array)\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset)\n } else {\n buf = new Uint8Array(array, byteOffset, length)\n }\n\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n buf.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n buf = fromArrayLike(that, buf)\n }\n\n return buf\n}\n\nfunction fromObject (that, obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n var buf = createBuffer(that, len)\n\n if (buf.length === 0) {\n return buf\n }\n\n obj.copy(buf, 0, 0, len)\n return buf\n }\n\n if (obj) {\n if ((typeof ArrayBuffer !== 'undefined' &&\n obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n if (typeof obj.length !== 'number' || isnan(obj.length)) {\n return createBuffer(that, 0)\n }\n return fromArrayLike(that, obj)\n }\n\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(that, obj.data)\n }\n }\n\n throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction byteLength (string) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n string = '' + string\n }\n\n var len = string.length\n if (len === 0) return 0\n\n return utf8ToBytes(string).length\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n for (var i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction from (that, value, offset, length) {\n if (typeof value === 'number') {\n throw new TypeError('\"value\" argument must not be a number')\n }\n\n if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n return fromArrayBuffer(that, value, offset, length)\n }\n\n if (typeof value === 'string') {\n return fromString(that, value, offset)\n }\n\n return fromObject(that, value)\n}\n\nBuffer.prototype.write = function write (string, offset, length) {\n // Buffer#write(string)\n if (offset === undefined) {\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length])\n } else if (isFinite(offset)) {\n offset = offset | 0\n if (isFinite(length)) {\n length = length | 0\n } else {\n length = undefined\n }\n }\n\n var remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n return utf8Write(this, string, offset, length)\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n var len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n var newBuf\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n newBuf = this.subarray(start, end)\n // Return an augmented `Uint8Array` instance\n newBuf.__proto__ = Buffer.prototype\n } else {\n var sliceLen = end - start\n newBuf = new Buffer(sliceLen, undefined)\n for (var i = 0; i < sliceLen; ++i) {\n newBuf[i] = this[i + start]\n }\n }\n\n return newBuf\n}\n\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n var len = end - start\n var i\n\n if (this === target && start < targetStart && targetStart < end) {\n // descending copy from end\n for (i = len - 1; i >= 0; --i) {\n target[i + targetStart] = this[i + start]\n }\n } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n // ascending copy from start\n for (i = 0; i < len; ++i) {\n target[i + targetStart] = this[i + start]\n }\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, start + len),\n targetStart\n )\n }\n\n return len\n}\n\nBuffer.prototype.fill = function fill (val, start, end) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n end = this.length\n }\n if (val.length === 1) {\n var code = val.charCodeAt(0)\n if (code < 256) {\n val = code\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : new Buffer(val)\n var len = bytes.length\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\nBuffer.concat = function concat (list, length) {\n if (!isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return createBuffer(null, 0)\n }\n\n var i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n var buffer = allocUnsafe(null, length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n buf.copy(buffer, pos)\n pos += buf.length\n }\n return buffer\n}\n\nBuffer.byteLength = byteLength\n\nBuffer.prototype._isBuffer = true\nBuffer.isBuffer = function isBuffer (b) {\n return !!(b != null && b._isBuffer)\n}\n\nmodule.exports = Buffer\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/lib/utils/typedarray-buffer.js?");
|
|
598
|
+
|
|
599
|
+
/***/ }),
|
|
600
|
+
|
|
601
|
+
/***/ "./node_modules/qrcode/node_modules/isarray/index.js":
|
|
602
|
+
/*!***********************************************************!*\
|
|
603
|
+
!*** ./node_modules/qrcode/node_modules/isarray/index.js ***!
|
|
604
|
+
\***********************************************************/
|
|
605
|
+
/*! no static exports found */
|
|
606
|
+
/***/ (function(module, exports) {
|
|
607
|
+
|
|
608
|
+
eval("var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n\n\n//# sourceURL=webpack://irma/./node_modules/qrcode/node_modules/isarray/index.js?");
|
|
609
|
+
|
|
610
|
+
/***/ }),
|
|
611
|
+
|
|
612
|
+
/***/ "./node_modules/style-loader/lib/addStyles.js":
|
|
613
|
+
/*!****************************************************!*\
|
|
614
|
+
!*** ./node_modules/style-loader/lib/addStyles.js ***!
|
|
615
|
+
\****************************************************/
|
|
616
|
+
/*! no static exports found */
|
|
617
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
618
|
+
|
|
619
|
+
eval("/*\n\tMIT License http://www.opensource.org/licenses/mit-license.php\n\tAuthor Tobias Koppers @sokra\n*/\n\nvar stylesInDom = {};\n\nvar\tmemoize = function (fn) {\n\tvar memo;\n\n\treturn function () {\n\t\tif (typeof memo === \"undefined\") memo = fn.apply(this, arguments);\n\t\treturn memo;\n\t};\n};\n\nvar isOldIE = memoize(function () {\n\t// Test for IE <= 9 as proposed by Browserhacks\n\t// @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805\n\t// Tests for existence of standard globals is to allow style-loader\n\t// to operate correctly into non-standard environments\n\t// @see https://github.com/webpack-contrib/style-loader/issues/177\n\treturn window && document && document.all && !window.atob;\n});\n\nvar getTarget = function (target, parent) {\n if (parent){\n return parent.querySelector(target);\n }\n return document.querySelector(target);\n};\n\nvar getElement = (function (fn) {\n\tvar memo = {};\n\n\treturn function(target, parent) {\n // If passing function in options, then use it for resolve \"head\" element.\n // Useful for Shadow Root style i.e\n // {\n // insertInto: function () { return document.querySelector(\"#foo\").shadowRoot }\n // }\n if (typeof target === 'function') {\n return target();\n }\n if (typeof memo[target] === \"undefined\") {\n\t\t\tvar styleTarget = getTarget.call(this, target, parent);\n\t\t\t// Special case to return head of iframe instead of iframe itself\n\t\t\tif (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {\n\t\t\t\ttry {\n\t\t\t\t\t// This will throw an exception if access to iframe is blocked\n\t\t\t\t\t// due to cross-origin restrictions\n\t\t\t\t\tstyleTarget = styleTarget.contentDocument.head;\n\t\t\t\t} catch(e) {\n\t\t\t\t\tstyleTarget = null;\n\t\t\t\t}\n\t\t\t}\n\t\t\tmemo[target] = styleTarget;\n\t\t}\n\t\treturn memo[target]\n\t};\n})();\n\nvar singleton = null;\nvar\tsingletonCounter = 0;\nvar\tstylesInsertedAtTop = [];\n\nvar\tfixUrls = __webpack_require__(/*! ./urls */ \"./node_modules/style-loader/lib/urls.js\");\n\nmodule.exports = function(list, options) {\n\tif (typeof DEBUG !== \"undefined\" && DEBUG) {\n\t\tif (typeof document !== \"object\") throw new Error(\"The style-loader cannot be used in a non-browser environment\");\n\t}\n\n\toptions = options || {};\n\n\toptions.attrs = typeof options.attrs === \"object\" ? options.attrs : {};\n\n\t// Force single-tag solution on IE6-9, which has a hard limit on the # of <style>\n\t// tags it will allow on a page\n\tif (!options.singleton && typeof options.singleton !== \"boolean\") options.singleton = isOldIE();\n\n\t// By default, add <style> tags to the <head> element\n if (!options.insertInto) options.insertInto = \"head\";\n\n\t// By default, add <style> tags to the bottom of the target\n\tif (!options.insertAt) options.insertAt = \"bottom\";\n\n\tvar styles = listToStyles(list, options);\n\n\taddStylesToDom(styles, options);\n\n\treturn function update (newList) {\n\t\tvar mayRemove = [];\n\n\t\tfor (var i = 0; i < styles.length; i++) {\n\t\t\tvar item = styles[i];\n\t\t\tvar domStyle = stylesInDom[item.id];\n\n\t\t\tdomStyle.refs--;\n\t\t\tmayRemove.push(domStyle);\n\t\t}\n\n\t\tif(newList) {\n\t\t\tvar newStyles = listToStyles(newList, options);\n\t\t\taddStylesToDom(newStyles, options);\n\t\t}\n\n\t\tfor (var i = 0; i < mayRemove.length; i++) {\n\t\t\tvar domStyle = mayRemove[i];\n\n\t\t\tif(domStyle.refs === 0) {\n\t\t\t\tfor (var j = 0; j < domStyle.parts.length; j++) domStyle.parts[j]();\n\n\t\t\t\tdelete stylesInDom[domStyle.id];\n\t\t\t}\n\t\t}\n\t};\n};\n\nfunction addStylesToDom (styles, options) {\n\tfor (var i = 0; i < styles.length; i++) {\n\t\tvar item = styles[i];\n\t\tvar domStyle = stylesInDom[item.id];\n\n\t\tif(domStyle) {\n\t\t\tdomStyle.refs++;\n\n\t\t\tfor(var j = 0; j < domStyle.parts.length; j++) {\n\t\t\t\tdomStyle.parts[j](item.parts[j]);\n\t\t\t}\n\n\t\t\tfor(; j < item.parts.length; j++) {\n\t\t\t\tdomStyle.parts.push(addStyle(item.parts[j], options));\n\t\t\t}\n\t\t} else {\n\t\t\tvar parts = [];\n\n\t\t\tfor(var j = 0; j < item.parts.length; j++) {\n\t\t\t\tparts.push(addStyle(item.parts[j], options));\n\t\t\t}\n\n\t\t\tstylesInDom[item.id] = {id: item.id, refs: 1, parts: parts};\n\t\t}\n\t}\n}\n\nfunction listToStyles (list, options) {\n\tvar styles = [];\n\tvar newStyles = {};\n\n\tfor (var i = 0; i < list.length; i++) {\n\t\tvar item = list[i];\n\t\tvar id = options.base ? item[0] + options.base : item[0];\n\t\tvar css = item[1];\n\t\tvar media = item[2];\n\t\tvar sourceMap = item[3];\n\t\tvar part = {css: css, media: media, sourceMap: sourceMap};\n\n\t\tif(!newStyles[id]) styles.push(newStyles[id] = {id: id, parts: [part]});\n\t\telse newStyles[id].parts.push(part);\n\t}\n\n\treturn styles;\n}\n\nfunction insertStyleElement (options, style) {\n\tvar target = getElement(options.insertInto)\n\n\tif (!target) {\n\t\tthrow new Error(\"Couldn't find a style target. This probably means that the value for the 'insertInto' parameter is invalid.\");\n\t}\n\n\tvar lastStyleElementInsertedAtTop = stylesInsertedAtTop[stylesInsertedAtTop.length - 1];\n\n\tif (options.insertAt === \"top\") {\n\t\tif (!lastStyleElementInsertedAtTop) {\n\t\t\ttarget.insertBefore(style, target.firstChild);\n\t\t} else if (lastStyleElementInsertedAtTop.nextSibling) {\n\t\t\ttarget.insertBefore(style, lastStyleElementInsertedAtTop.nextSibling);\n\t\t} else {\n\t\t\ttarget.appendChild(style);\n\t\t}\n\t\tstylesInsertedAtTop.push(style);\n\t} else if (options.insertAt === \"bottom\") {\n\t\ttarget.appendChild(style);\n\t} else if (typeof options.insertAt === \"object\" && options.insertAt.before) {\n\t\tvar nextSibling = getElement(options.insertAt.before, target);\n\t\ttarget.insertBefore(style, nextSibling);\n\t} else {\n\t\tthrow new Error(\"[Style Loader]\\n\\n Invalid value for parameter 'insertAt' ('options.insertAt') found.\\n Must be 'top', 'bottom', or Object.\\n (https://github.com/webpack-contrib/style-loader#insertat)\\n\");\n\t}\n}\n\nfunction removeStyleElement (style) {\n\tif (style.parentNode === null) return false;\n\tstyle.parentNode.removeChild(style);\n\n\tvar idx = stylesInsertedAtTop.indexOf(style);\n\tif(idx >= 0) {\n\t\tstylesInsertedAtTop.splice(idx, 1);\n\t}\n}\n\nfunction createStyleElement (options) {\n\tvar style = document.createElement(\"style\");\n\n\tif(options.attrs.type === undefined) {\n\t\toptions.attrs.type = \"text/css\";\n\t}\n\n\tif(options.attrs.nonce === undefined) {\n\t\tvar nonce = getNonce();\n\t\tif (nonce) {\n\t\t\toptions.attrs.nonce = nonce;\n\t\t}\n\t}\n\n\taddAttrs(style, options.attrs);\n\tinsertStyleElement(options, style);\n\n\treturn style;\n}\n\nfunction createLinkElement (options) {\n\tvar link = document.createElement(\"link\");\n\n\tif(options.attrs.type === undefined) {\n\t\toptions.attrs.type = \"text/css\";\n\t}\n\toptions.attrs.rel = \"stylesheet\";\n\n\taddAttrs(link, options.attrs);\n\tinsertStyleElement(options, link);\n\n\treturn link;\n}\n\nfunction addAttrs (el, attrs) {\n\tObject.keys(attrs).forEach(function (key) {\n\t\tel.setAttribute(key, attrs[key]);\n\t});\n}\n\nfunction getNonce() {\n\tif (false) {}\n\n\treturn __webpack_require__.nc;\n}\n\nfunction addStyle (obj, options) {\n\tvar style, update, remove, result;\n\n\t// If a transform function was defined, run it on the css\n\tif (options.transform && obj.css) {\n\t result = typeof options.transform === 'function'\n\t\t ? options.transform(obj.css) \n\t\t : options.transform.default(obj.css);\n\n\t if (result) {\n\t \t// If transform returns a value, use that instead of the original css.\n\t \t// This allows running runtime transformations on the css.\n\t \tobj.css = result;\n\t } else {\n\t \t// If the transform function returns a falsy value, don't add this css.\n\t \t// This allows conditional loading of css\n\t \treturn function() {\n\t \t\t// noop\n\t \t};\n\t }\n\t}\n\n\tif (options.singleton) {\n\t\tvar styleIndex = singletonCounter++;\n\n\t\tstyle = singleton || (singleton = createStyleElement(options));\n\n\t\tupdate = applyToSingletonTag.bind(null, style, styleIndex, false);\n\t\tremove = applyToSingletonTag.bind(null, style, styleIndex, true);\n\n\t} else if (\n\t\tobj.sourceMap &&\n\t\ttypeof URL === \"function\" &&\n\t\ttypeof URL.createObjectURL === \"function\" &&\n\t\ttypeof URL.revokeObjectURL === \"function\" &&\n\t\ttypeof Blob === \"function\" &&\n\t\ttypeof btoa === \"function\"\n\t) {\n\t\tstyle = createLinkElement(options);\n\t\tupdate = updateLink.bind(null, style, options);\n\t\tremove = function () {\n\t\t\tremoveStyleElement(style);\n\n\t\t\tif(style.href) URL.revokeObjectURL(style.href);\n\t\t};\n\t} else {\n\t\tstyle = createStyleElement(options);\n\t\tupdate = applyToTag.bind(null, style);\n\t\tremove = function () {\n\t\t\tremoveStyleElement(style);\n\t\t};\n\t}\n\n\tupdate(obj);\n\n\treturn function updateStyle (newObj) {\n\t\tif (newObj) {\n\t\t\tif (\n\t\t\t\tnewObj.css === obj.css &&\n\t\t\t\tnewObj.media === obj.media &&\n\t\t\t\tnewObj.sourceMap === obj.sourceMap\n\t\t\t) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tupdate(obj = newObj);\n\t\t} else {\n\t\t\tremove();\n\t\t}\n\t};\n}\n\nvar replaceText = (function () {\n\tvar textStore = [];\n\n\treturn function (index, replacement) {\n\t\ttextStore[index] = replacement;\n\n\t\treturn textStore.filter(Boolean).join('\\n');\n\t};\n})();\n\nfunction applyToSingletonTag (style, index, remove, obj) {\n\tvar css = remove ? \"\" : obj.css;\n\n\tif (style.styleSheet) {\n\t\tstyle.styleSheet.cssText = replaceText(index, css);\n\t} else {\n\t\tvar cssNode = document.createTextNode(css);\n\t\tvar childNodes = style.childNodes;\n\n\t\tif (childNodes[index]) style.removeChild(childNodes[index]);\n\n\t\tif (childNodes.length) {\n\t\t\tstyle.insertBefore(cssNode, childNodes[index]);\n\t\t} else {\n\t\t\tstyle.appendChild(cssNode);\n\t\t}\n\t}\n}\n\nfunction applyToTag (style, obj) {\n\tvar css = obj.css;\n\tvar media = obj.media;\n\n\tif(media) {\n\t\tstyle.setAttribute(\"media\", media)\n\t}\n\n\tif(style.styleSheet) {\n\t\tstyle.styleSheet.cssText = css;\n\t} else {\n\t\twhile(style.firstChild) {\n\t\t\tstyle.removeChild(style.firstChild);\n\t\t}\n\n\t\tstyle.appendChild(document.createTextNode(css));\n\t}\n}\n\nfunction updateLink (link, options, obj) {\n\tvar css = obj.css;\n\tvar sourceMap = obj.sourceMap;\n\n\t/*\n\t\tIf convertToAbsoluteUrls isn't defined, but sourcemaps are enabled\n\t\tand there is no publicPath defined then lets turn convertToAbsoluteUrls\n\t\ton by default. Otherwise default to the convertToAbsoluteUrls option\n\t\tdirectly\n\t*/\n\tvar autoFixUrls = options.convertToAbsoluteUrls === undefined && sourceMap;\n\n\tif (options.convertToAbsoluteUrls || autoFixUrls) {\n\t\tcss = fixUrls(css);\n\t}\n\n\tif (sourceMap) {\n\t\t// http://stackoverflow.com/a/26603875\n\t\tcss += \"\\n/*# sourceMappingURL=data:application/json;base64,\" + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + \" */\";\n\t}\n\n\tvar blob = new Blob([css], { type: \"text/css\" });\n\n\tvar oldSrc = link.href;\n\n\tlink.href = URL.createObjectURL(blob);\n\n\tif(oldSrc) URL.revokeObjectURL(oldSrc);\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/style-loader/lib/addStyles.js?");
|
|
620
|
+
|
|
621
|
+
/***/ }),
|
|
622
|
+
|
|
623
|
+
/***/ "./node_modules/style-loader/lib/urls.js":
|
|
624
|
+
/*!***********************************************!*\
|
|
625
|
+
!*** ./node_modules/style-loader/lib/urls.js ***!
|
|
626
|
+
\***********************************************/
|
|
627
|
+
/*! no static exports found */
|
|
628
|
+
/***/ (function(module, exports) {
|
|
629
|
+
|
|
630
|
+
eval("\n/**\n * When source maps are enabled, `style-loader` uses a link element with a data-uri to\n * embed the css on the page. This breaks all relative urls because now they are relative to a\n * bundle instead of the current page.\n *\n * One solution is to only use full urls, but that may be impossible.\n *\n * Instead, this function \"fixes\" the relative urls to be absolute according to the current page location.\n *\n * A rudimentary test suite is located at `test/fixUrls.js` and can be run via the `npm test` command.\n *\n */\n\nmodule.exports = function (css) {\n // get current location\n var location = typeof window !== \"undefined\" && window.location;\n\n if (!location) {\n throw new Error(\"fixUrls requires window.location\");\n }\n\n\t// blank or null?\n\tif (!css || typeof css !== \"string\") {\n\t return css;\n }\n\n var baseUrl = location.protocol + \"//\" + location.host;\n var currentDir = baseUrl + location.pathname.replace(/\\/[^\\/]*$/, \"/\");\n\n\t// convert each url(...)\n\t/*\n\tThis regular expression is just a way to recursively match brackets within\n\ta string.\n\n\t /url\\s*\\( = Match on the word \"url\" with any whitespace after it and then a parens\n\t ( = Start a capturing group\n\t (?: = Start a non-capturing group\n\t [^)(] = Match anything that isn't a parentheses\n\t | = OR\n\t \\( = Match a start parentheses\n\t (?: = Start another non-capturing groups\n\t [^)(]+ = Match anything that isn't a parentheses\n\t | = OR\n\t \\( = Match a start parentheses\n\t [^)(]* = Match anything that isn't a parentheses\n\t \\) = Match a end parentheses\n\t ) = End Group\n *\\) = Match anything and then a close parens\n ) = Close non-capturing group\n * = Match anything\n ) = Close capturing group\n\t \\) = Match a close parens\n\n\t /gi = Get all matches, not the first. Be case insensitive.\n\t */\n\tvar fixedCss = css.replace(/url\\s*\\(((?:[^)(]|\\((?:[^)(]+|\\([^)(]*\\))*\\))*)\\)/gi, function(fullMatch, origUrl) {\n\t\t// strip quotes (if they exist)\n\t\tvar unquotedOrigUrl = origUrl\n\t\t\t.trim()\n\t\t\t.replace(/^\"(.*)\"$/, function(o, $1){ return $1; })\n\t\t\t.replace(/^'(.*)'$/, function(o, $1){ return $1; });\n\n\t\t// already a full url? no change\n\t\tif (/^(#|data:|http:\\/\\/|https:\\/\\/|file:\\/\\/\\/|\\s*$)/i.test(unquotedOrigUrl)) {\n\t\t return fullMatch;\n\t\t}\n\n\t\t// convert the url to a full url\n\t\tvar newUrl;\n\n\t\tif (unquotedOrigUrl.indexOf(\"//\") === 0) {\n\t\t \t//TODO: should we add protocol?\n\t\t\tnewUrl = unquotedOrigUrl;\n\t\t} else if (unquotedOrigUrl.indexOf(\"/\") === 0) {\n\t\t\t// path should be relative to the base url\n\t\t\tnewUrl = baseUrl + unquotedOrigUrl; // already starts with '/'\n\t\t} else {\n\t\t\t// path should be relative to current directory\n\t\t\tnewUrl = currentDir + unquotedOrigUrl.replace(/^\\.\\//, \"\"); // Strip leading './'\n\t\t}\n\n\t\t// send back the fixed url(...)\n\t\treturn \"url(\" + JSON.stringify(newUrl) + \")\";\n\t});\n\n\t// send back the fixed css\n\treturn fixedCss;\n};\n\n\n//# sourceURL=webpack://irma/./node_modules/style-loader/lib/urls.js?");
|
|
631
|
+
|
|
632
|
+
/***/ }),
|
|
633
|
+
|
|
634
|
+
/***/ "./node_modules/webpack/buildin/global.js":
|
|
635
|
+
/*!***********************************!*\
|
|
636
|
+
!*** (webpack)/buildin/global.js ***!
|
|
637
|
+
\***********************************/
|
|
638
|
+
/*! no static exports found */
|
|
639
|
+
/***/ (function(module, exports) {
|
|
640
|
+
|
|
641
|
+
eval("var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || Function(\"return this\")() || (1, eval)(\"this\");\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n\n\n//# sourceURL=webpack://irma/(webpack)/buildin/global.js?");
|
|
642
|
+
|
|
643
|
+
/***/ }),
|
|
644
|
+
|
|
645
|
+
/***/ "./node_modules/whatwg-fetch/fetch.js":
|
|
646
|
+
/*!********************************************!*\
|
|
647
|
+
!*** ./node_modules/whatwg-fetch/fetch.js ***!
|
|
648
|
+
\********************************************/
|
|
649
|
+
/*! exports provided: Headers, Request, Response, DOMException, fetch */
|
|
650
|
+
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
651
|
+
|
|
652
|
+
"use strict";
|
|
653
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Headers\", function() { return Headers; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Request\", function() { return Request; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Response\", function() { return Response; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"DOMException\", function() { return DOMException; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"fetch\", function() { return fetch; });\nvar support = {\n searchParams: 'URLSearchParams' in self,\n iterable: 'Symbol' in self && 'iterator' in Symbol,\n blob:\n 'FileReader' in self &&\n 'Blob' in self &&\n (function() {\n try {\n new Blob()\n return true\n } catch (e) {\n return false\n }\n })(),\n formData: 'FormData' in self,\n arrayBuffer: 'ArrayBuffer' in self\n}\n\nfunction isDataView(obj) {\n return obj && DataView.prototype.isPrototypeOf(obj)\n}\n\nif (support.arrayBuffer) {\n var viewClasses = [\n '[object Int8Array]',\n '[object Uint8Array]',\n '[object Uint8ClampedArray]',\n '[object Int16Array]',\n '[object Uint16Array]',\n '[object Int32Array]',\n '[object Uint32Array]',\n '[object Float32Array]',\n '[object Float64Array]'\n ]\n\n var isArrayBufferView =\n ArrayBuffer.isView ||\n function(obj) {\n return obj && viewClasses.indexOf(Object.prototype.toString.call(obj)) > -1\n }\n}\n\nfunction normalizeName(name) {\n if (typeof name !== 'string') {\n name = String(name)\n }\n if (/[^a-z0-9\\-#$%&'*+.^_`|~]/i.test(name)) {\n throw new TypeError('Invalid character in header field name')\n }\n return name.toLowerCase()\n}\n\nfunction normalizeValue(value) {\n if (typeof value !== 'string') {\n value = String(value)\n }\n return value\n}\n\n// Build a destructive iterator for the value list\nfunction iteratorFor(items) {\n var iterator = {\n next: function() {\n var value = items.shift()\n return {done: value === undefined, value: value}\n }\n }\n\n if (support.iterable) {\n iterator[Symbol.iterator] = function() {\n return iterator\n }\n }\n\n return iterator\n}\n\nfunction Headers(headers) {\n this.map = {}\n\n if (headers instanceof Headers) {\n headers.forEach(function(value, name) {\n this.append(name, value)\n }, this)\n } else if (Array.isArray(headers)) {\n headers.forEach(function(header) {\n this.append(header[0], header[1])\n }, this)\n } else if (headers) {\n Object.getOwnPropertyNames(headers).forEach(function(name) {\n this.append(name, headers[name])\n }, this)\n }\n}\n\nHeaders.prototype.append = function(name, value) {\n name = normalizeName(name)\n value = normalizeValue(value)\n var oldValue = this.map[name]\n this.map[name] = oldValue ? oldValue + ', ' + value : value\n}\n\nHeaders.prototype['delete'] = function(name) {\n delete this.map[normalizeName(name)]\n}\n\nHeaders.prototype.get = function(name) {\n name = normalizeName(name)\n return this.has(name) ? this.map[name] : null\n}\n\nHeaders.prototype.has = function(name) {\n return this.map.hasOwnProperty(normalizeName(name))\n}\n\nHeaders.prototype.set = function(name, value) {\n this.map[normalizeName(name)] = normalizeValue(value)\n}\n\nHeaders.prototype.forEach = function(callback, thisArg) {\n for (var name in this.map) {\n if (this.map.hasOwnProperty(name)) {\n callback.call(thisArg, this.map[name], name, this)\n }\n }\n}\n\nHeaders.prototype.keys = function() {\n var items = []\n this.forEach(function(value, name) {\n items.push(name)\n })\n return iteratorFor(items)\n}\n\nHeaders.prototype.values = function() {\n var items = []\n this.forEach(function(value) {\n items.push(value)\n })\n return iteratorFor(items)\n}\n\nHeaders.prototype.entries = function() {\n var items = []\n this.forEach(function(value, name) {\n items.push([name, value])\n })\n return iteratorFor(items)\n}\n\nif (support.iterable) {\n Headers.prototype[Symbol.iterator] = Headers.prototype.entries\n}\n\nfunction consumed(body) {\n if (body.bodyUsed) {\n return Promise.reject(new TypeError('Already read'))\n }\n body.bodyUsed = true\n}\n\nfunction fileReaderReady(reader) {\n return new Promise(function(resolve, reject) {\n reader.onload = function() {\n resolve(reader.result)\n }\n reader.onerror = function() {\n reject(reader.error)\n }\n })\n}\n\nfunction readBlobAsArrayBuffer(blob) {\n var reader = new FileReader()\n var promise = fileReaderReady(reader)\n reader.readAsArrayBuffer(blob)\n return promise\n}\n\nfunction readBlobAsText(blob) {\n var reader = new FileReader()\n var promise = fileReaderReady(reader)\n reader.readAsText(blob)\n return promise\n}\n\nfunction readArrayBufferAsText(buf) {\n var view = new Uint8Array(buf)\n var chars = new Array(view.length)\n\n for (var i = 0; i < view.length; i++) {\n chars[i] = String.fromCharCode(view[i])\n }\n return chars.join('')\n}\n\nfunction bufferClone(buf) {\n if (buf.slice) {\n return buf.slice(0)\n } else {\n var view = new Uint8Array(buf.byteLength)\n view.set(new Uint8Array(buf))\n return view.buffer\n }\n}\n\nfunction Body() {\n this.bodyUsed = false\n\n this._initBody = function(body) {\n this._bodyInit = body\n if (!body) {\n this._bodyText = ''\n } else if (typeof body === 'string') {\n this._bodyText = body\n } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {\n this._bodyBlob = body\n } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {\n this._bodyFormData = body\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this._bodyText = body.toString()\n } else if (support.arrayBuffer && support.blob && isDataView(body)) {\n this._bodyArrayBuffer = bufferClone(body.buffer)\n // IE 10-11 can't handle a DataView body.\n this._bodyInit = new Blob([this._bodyArrayBuffer])\n } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) {\n this._bodyArrayBuffer = bufferClone(body)\n } else {\n this._bodyText = body = Object.prototype.toString.call(body)\n }\n\n if (!this.headers.get('content-type')) {\n if (typeof body === 'string') {\n this.headers.set('content-type', 'text/plain;charset=UTF-8')\n } else if (this._bodyBlob && this._bodyBlob.type) {\n this.headers.set('content-type', this._bodyBlob.type)\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8')\n }\n }\n }\n\n if (support.blob) {\n this.blob = function() {\n var rejected = consumed(this)\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return Promise.resolve(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(new Blob([this._bodyArrayBuffer]))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as blob')\n } else {\n return Promise.resolve(new Blob([this._bodyText]))\n }\n }\n\n this.arrayBuffer = function() {\n if (this._bodyArrayBuffer) {\n return consumed(this) || Promise.resolve(this._bodyArrayBuffer)\n } else {\n return this.blob().then(readBlobAsArrayBuffer)\n }\n }\n }\n\n this.text = function() {\n var rejected = consumed(this)\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return readBlobAsText(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as text')\n } else {\n return Promise.resolve(this._bodyText)\n }\n }\n\n if (support.formData) {\n this.formData = function() {\n return this.text().then(decode)\n }\n }\n\n this.json = function() {\n return this.text().then(JSON.parse)\n }\n\n return this\n}\n\n// HTTP methods whose capitalization should be normalized\nvar methods = ['DELETE', 'GET', 'HEAD', 'OPTIONS', 'POST', 'PUT']\n\nfunction normalizeMethod(method) {\n var upcased = method.toUpperCase()\n return methods.indexOf(upcased) > -1 ? upcased : method\n}\n\nfunction Request(input, options) {\n options = options || {}\n var body = options.body\n\n if (input instanceof Request) {\n if (input.bodyUsed) {\n throw new TypeError('Already read')\n }\n this.url = input.url\n this.credentials = input.credentials\n if (!options.headers) {\n this.headers = new Headers(input.headers)\n }\n this.method = input.method\n this.mode = input.mode\n this.signal = input.signal\n if (!body && input._bodyInit != null) {\n body = input._bodyInit\n input.bodyUsed = true\n }\n } else {\n this.url = String(input)\n }\n\n this.credentials = options.credentials || this.credentials || 'same-origin'\n if (options.headers || !this.headers) {\n this.headers = new Headers(options.headers)\n }\n this.method = normalizeMethod(options.method || this.method || 'GET')\n this.mode = options.mode || this.mode || null\n this.signal = options.signal || this.signal\n this.referrer = null\n\n if ((this.method === 'GET' || this.method === 'HEAD') && body) {\n throw new TypeError('Body not allowed for GET or HEAD requests')\n }\n this._initBody(body)\n}\n\nRequest.prototype.clone = function() {\n return new Request(this, {body: this._bodyInit})\n}\n\nfunction decode(body) {\n var form = new FormData()\n body\n .trim()\n .split('&')\n .forEach(function(bytes) {\n if (bytes) {\n var split = bytes.split('=')\n var name = split.shift().replace(/\\+/g, ' ')\n var value = split.join('=').replace(/\\+/g, ' ')\n form.append(decodeURIComponent(name), decodeURIComponent(value))\n }\n })\n return form\n}\n\nfunction parseHeaders(rawHeaders) {\n var headers = new Headers()\n // Replace instances of \\r\\n and \\n followed by at least one space or horizontal tab with a space\n // https://tools.ietf.org/html/rfc7230#section-3.2\n var preProcessedHeaders = rawHeaders.replace(/\\r?\\n[\\t ]+/g, ' ')\n preProcessedHeaders.split(/\\r?\\n/).forEach(function(line) {\n var parts = line.split(':')\n var key = parts.shift().trim()\n if (key) {\n var value = parts.join(':').trim()\n headers.append(key, value)\n }\n })\n return headers\n}\n\nBody.call(Request.prototype)\n\nfunction Response(bodyInit, options) {\n if (!options) {\n options = {}\n }\n\n this.type = 'default'\n this.status = options.status === undefined ? 200 : options.status\n this.ok = this.status >= 200 && this.status < 300\n this.statusText = 'statusText' in options ? options.statusText : 'OK'\n this.headers = new Headers(options.headers)\n this.url = options.url || ''\n this._initBody(bodyInit)\n}\n\nBody.call(Response.prototype)\n\nResponse.prototype.clone = function() {\n return new Response(this._bodyInit, {\n status: this.status,\n statusText: this.statusText,\n headers: new Headers(this.headers),\n url: this.url\n })\n}\n\nResponse.error = function() {\n var response = new Response(null, {status: 0, statusText: ''})\n response.type = 'error'\n return response\n}\n\nvar redirectStatuses = [301, 302, 303, 307, 308]\n\nResponse.redirect = function(url, status) {\n if (redirectStatuses.indexOf(status) === -1) {\n throw new RangeError('Invalid status code')\n }\n\n return new Response(null, {status: status, headers: {location: url}})\n}\n\nvar DOMException = self.DOMException\ntry {\n new DOMException()\n} catch (err) {\n DOMException = function(message, name) {\n this.message = message\n this.name = name\n var error = Error(message)\n this.stack = error.stack\n }\n DOMException.prototype = Object.create(Error.prototype)\n DOMException.prototype.constructor = DOMException\n}\n\nfunction fetch(input, init) {\n return new Promise(function(resolve, reject) {\n var request = new Request(input, init)\n\n if (request.signal && request.signal.aborted) {\n return reject(new DOMException('Aborted', 'AbortError'))\n }\n\n var xhr = new XMLHttpRequest()\n\n function abortXhr() {\n xhr.abort()\n }\n\n xhr.onload = function() {\n var options = {\n status: xhr.status,\n statusText: xhr.statusText,\n headers: parseHeaders(xhr.getAllResponseHeaders() || '')\n }\n options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL')\n var body = 'response' in xhr ? xhr.response : xhr.responseText\n resolve(new Response(body, options))\n }\n\n xhr.onerror = function() {\n reject(new TypeError('Network request failed'))\n }\n\n xhr.ontimeout = function() {\n reject(new TypeError('Network request failed'))\n }\n\n xhr.onabort = function() {\n reject(new DOMException('Aborted', 'AbortError'))\n }\n\n xhr.open(request.method, request.url, true)\n\n if (request.credentials === 'include') {\n xhr.withCredentials = true\n } else if (request.credentials === 'omit') {\n xhr.withCredentials = false\n }\n\n if ('responseType' in xhr && support.blob) {\n xhr.responseType = 'blob'\n }\n\n request.headers.forEach(function(value, name) {\n xhr.setRequestHeader(name, value)\n })\n\n if (request.signal) {\n request.signal.addEventListener('abort', abortXhr)\n\n xhr.onreadystatechange = function() {\n // DONE (success or failure)\n if (xhr.readyState === 4) {\n request.signal.removeEventListener('abort', abortXhr)\n }\n }\n }\n\n xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit)\n })\n}\n\nfetch.polyfill = true\n\nif (!self.fetch) {\n self.fetch = fetch\n self.Headers = Headers\n self.Request = Request\n self.Response = Response\n}\n\n\n//# sourceURL=webpack://irma/./node_modules/whatwg-fetch/fetch.js?");
|
|
654
|
+
|
|
655
|
+
/***/ }),
|
|
656
|
+
|
|
657
|
+
/***/ "./node_modules/window-or-global/lib/index.js":
|
|
658
|
+
/*!****************************************************!*\
|
|
659
|
+
!*** ./node_modules/window-or-global/lib/index.js ***!
|
|
660
|
+
\****************************************************/
|
|
661
|
+
/*! no static exports found */
|
|
662
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
663
|
+
|
|
664
|
+
"use strict";
|
|
665
|
+
eval("/* WEBPACK VAR INJECTION */(function(global) {\nmodule.exports = (typeof self === 'object' && self.self === self && self) ||\n (typeof global === 'object' && global.global === global && global) ||\n this\n\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../webpack/buildin/global.js */ \"./node_modules/webpack/buildin/global.js\")))\n\n//# sourceURL=webpack://irma/./node_modules/window-or-global/lib/index.js?");
|
|
666
|
+
|
|
667
|
+
/***/ }),
|
|
668
|
+
|
|
669
|
+
/***/ "./src/index.js":
|
|
670
|
+
/*!**********************!*\
|
|
671
|
+
!*** ./src/index.js ***!
|
|
672
|
+
\**********************/
|
|
673
|
+
/*! exports provided: SessionStatus, setLoggingState, handleSession, setupSession, finishSession, startSession, signSessionRequest, waitConnected, waitDone, UserAgent, detectUserAgent */
|
|
674
|
+
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
675
|
+
|
|
676
|
+
"use strict";
|
|
677
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"SessionStatus\", function() { return SessionStatus; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"setLoggingState\", function() { return setLoggingState; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"handleSession\", function() { return handleSession; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"setupSession\", function() { return setupSession; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"finishSession\", function() { return finishSession; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"startSession\", function() { return startSession; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"signSessionRequest\", function() { return signSessionRequest; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"waitConnected\", function() { return waitConnected; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"waitDone\", function() { return waitDone; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"UserAgent\", function() { return UserAgent; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"detectUserAgent\", function() { return detectUserAgent; });\n/* harmony import */ var isomorphic_fetch__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! isomorphic-fetch */ \"./node_modules/isomorphic-fetch/fetch-npm-browserify.js\");\n/* harmony import */ var isomorphic_fetch__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(isomorphic_fetch__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var qrcode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! qrcode */ \"./node_modules/qrcode/lib/browser.js\");\n/* harmony import */ var qrcode__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(qrcode__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _irma_scss__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./irma.scss */ \"./src/irma.scss\");\n/* harmony import */ var _irma_scss__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_irma_scss__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _phone_png__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./phone.png */ \"./src/phone.png\");\n/* harmony import */ var _phone_png__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_phone_png__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _popup_html__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./popup.html */ \"./src/popup.html\");\n/* harmony import */ var _popup_html__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_popup_html__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var _translations__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./translations */ \"./src/translations/index.js\");\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n__webpack_require__(/*! es6-promise */ \"./node_modules/es6-promise/dist/es6-promise.js\").polyfill();\n\n__webpack_require__(/*! es6-object-assign */ \"./node_modules/es6-object-assign/index.js\").polyfill();\n\nvar browser = typeof window !== 'undefined';\nvar qrcodeterminal = !browser ? __webpack_require__(/*! qrcode-terminal */ \"qrcode-terminal\") : undefined;\nvar EventSource = !browser ? __webpack_require__(/*! eventsource */ \"eventsource\") : undefined;\n\n\n\n\n\n\nvar SessionStatus = {\n Initialized: 'INITIALIZED',\n // The session has been started and is waiting for the client to connect (scan the QR)\n Connected: 'CONNECTED',\n // The client has retrieved the session request, we wait for its response\n Cancelled: 'CANCELLED',\n // The session is cancelled, possibly due to an error\n Done: 'DONE',\n // The session has completed successfully\n Timeout: 'TIMEOUT' // Session timed out\n\n};\n/* eslint-disable no-console */\n\nvar optionsDefaults = {\n method: 'popup',\n // Supported methods: 'popup', 'canvas', 'mobile' (only browser), 'console' (only node), 'url' (both)\n element: 'irmaqr',\n // ID of the canvas to draw to if method === 'canvas'\n language: 'en',\n // Popup language when method === 'popup'\n showConnectedIcon: true,\n // When method is 'popup' or 'canvas', replace QR with a phone icon when phone connects\n returnStatus: SessionStatus.Done,\n // When the session reaches this status control is returned to the caller\n server: '',\n // Server URL to fetch the session result from after the session is done\n token: '',\n // Session token at IRMA server (only required when server option is provided)\n resultJwt: false,\n // Retrieve signed session result from the irma server\n legacyResultJwt: false,\n // Retrieve legacy (i.e. irma_api_server compatible from /getproof) JWT format\n disableMobile: false,\n // Disable automatic navigation to IRMA app on mobile\n qrterminalOptions: {},\n // Options to pass to qrcode-terminal.generate\n qrterminalDisplay: console.log // Display function for qrcode-terminal\n\n};\n/* eslint-enable no-console */\n\nvar logEnabled = true;\n/**\n * Change whether or not the irmajs library logs to console.\n */\n\nfunction setLoggingState(enabled) {\n logEnabled = enabled;\n}\n/**\n * Handle an IRMA session after it has been created at an irma server, given the QR contents\n * to be sent to the IRMA app. This function can (1) draw an IRMA QR, (2) wait for the phone to\n * connect, (3) wait for the session to complete, and (4) retrieve the session result afterwards\n * from the irma server.\n * Returns a promise that can return at any of these phases, depending on the options.\n * Compatible with both `irma server` cli and Go `irmaserver` library.\n * @param {Object} qr\n * @param {Object} options\n */\n\nfunction handleSession(qr) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var state = {};\n return setupSession(qr, state, options).then(function (p) {\n return finishSession(p, state);\n });\n}\nfunction setupSession(qr, state, options) {\n state.qr = qr;\n state.done = false; // When we start the session is always in the Initialized state, but the state at which\n // we return control to the caller depends on the options. See the function comment.\n // We implement this by 4 chained promises, each of which can \"break out of the chain\" by\n // setting state.done to true, after which all remaining then's return immediately.\n\n return Promise.resolve() // 1st phase: session started, phone not yet connected\n .then(function () {\n log('Session started', state.qr);\n state.options = processOptions(options);\n state.method = state.options.method;\n\n switch (state.method) {\n case 'url':\n state.done = true;\n return qrcode__WEBPACK_IMPORTED_MODULE_1___default.a.toDataURL(JSON.stringify(state.qr));\n\n case 'mobile':\n startMobileSession(qr, state.options.userAgent);\n break;\n\n case 'popup':\n setupPopup(qr, state.options.language);\n // fallthrough\n\n case 'canvas':\n state.canvas = window.document.getElementById(state.options.element);\n if (!state.canvas) return Promise.reject('Specified canvas not found in DOM');\n drawQr(state.canvas, state.qr);\n break;\n\n case 'console':\n qrcodeterminal.generate(JSON.stringify(state.qr), state.options.qrterminalOptions, state.options.qrterminalDisplay);\n break;\n }\n\n if (state.options.returnStatus === SessionStatus.Initialized) {\n state.done = true;\n return SessionStatus.Initialized;\n }\n\n return waitConnected(state.qr.u);\n }).catch(function (err) {\n log('Error or unexpected status', err);\n if (state.method === 'popup') closePopup();\n throw err;\n });\n}\nfunction finishSession(status, state) {\n return Promise.resolve() // 2nd phase: phone connected\n .then(function () {\n if (state.done) return status;\n log('Session state changed', status, state.qr.u);\n\n switch (state.method) {\n case 'popup':\n translatePopupElement('irma-text', 'Messages.FollowInstructions', state.options.language);\n // fallthrough\n\n case 'canvas':\n clearQr(state.canvas, state.options.showConnectedIcon);\n break;\n }\n\n if (state.options.returnStatus === SessionStatus.Connected) {\n state.done = true;\n return status;\n }\n\n return waitDone(state.qr.u);\n }) // 3rd phase: session done\n .then(function (status) {\n if (state.done) return status;\n if (state.method === 'popup') closePopup();\n\n if (state.options.server.length === 0) {\n state.done = true;\n return status;\n }\n\n var jwtType = state.options.legacyResultJwt ? 'getproof' : 'result-jwt';\n var endpoint = state.options.resultJwt || state.options.legacyResultJwt ? jwtType : 'result';\n return fetchCheck(\"\".concat(state.options.server, \"/session/\").concat(state.options.token, \"/\").concat(endpoint));\n }) // 4th phase: handle session result received from irmaserver\n .then(function (response) {\n if (state.done) return response;\n return state.options.resultJwt || state.options.legacyResultJwt ? response.text() : response.json();\n }).catch(function (err) {\n log('Error or unexpected status', err);\n if (state.method === 'popup') closePopup();\n throw err;\n });\n}\n/**\n * Start an IRMA session at an irmaserver.\n * @param {string} server URL to irmaserver at which to start the session\n * @param {Object} request Session request\n * @param {string} method authentication method (supported: undefined, none, token, hmac, publickey)\n * @param {*} key API token or JWT key\n * @param {string} name name of the requestor, only for hmac and publickey mode\n */\n\nfunction startSession(server, request, method, key, name) {\n return Promise.resolve().then(function () {\n if (_typeof(request) === 'object') return method == 'publickey' || method == 'hmac' ? signSessionRequest(request, method, key, name) : JSON.stringify(request);else return request;\n }).then(function (body) {\n var headers = {};\n\n switch (method) {\n case undefined:\n case 'none':\n headers['Content-Type'] = 'application/json';\n break;\n\n case 'token':\n headers['Authorization'] = key;\n headers['Content-Type'] = 'application/json';\n break;\n\n case 'publickey':\n case 'hmac':\n headers['Content-Type'] = 'text/plain';\n break;\n\n default:\n throw new Error('Unsupported authentication method');\n }\n\n return fetchCheck(\"\".concat(server, \"/session\"), {\n method: 'POST',\n headers: headers,\n body: body\n });\n }).then(function (res) {\n return res.json();\n });\n}\n/**\n * Sign a session request into a JWT, using the HMAC (HS256) or RSA (RS256) signing algorithm.\n * @param {Object} request Session request\n * @param {string} method authentication method (supported: undefined, none, token, hmac, publickey)\n * @param {*} key API token or JWT key\n * @param {string} name name of the requestor, only for hmac and publickey mode\n */\n\nfunction signSessionRequest(request, method, key, name) {\n return Promise.all(/*! import() | jwt */[__webpack_require__.e(\"vendors~jwt\"), __webpack_require__.e(\"jwt\")]).then(__webpack_require__.t.bind(null, /*! jsonwebtoken */ \"./node_modules/jsonwebtoken/index.js\", 7)).then(function (jwt) {\n var rrequest;\n\n if (request.type || request['@context']) {\n rrequest = {\n request: request\n };\n } else if (request.request) {\n rrequest = request;\n }\n\n var subjects = {\n disclosing: 'verification_request',\n issuing: 'issue_request',\n signing: 'signature_request'\n };\n var subjectsContext = {\n 'https://irma.app/ld/request/disclosure/v2': 'verification_request',\n 'https://irma.app/ld/request/signature/v2': 'signature_request',\n 'https://irma.app/ld/request/issuance/v2': 'issue_request'\n };\n if (!subjects[rrequest.request.type] && !subjectsContext[rrequest.request['@context']]) throw new Error('Not an IRMA session request');\n if (method !== 'publickey' && method !== 'hmac') throw new Error('Unsupported signing method');\n var fields = {\n 'verification_request': 'sprequest',\n 'issue_request': 'iprequest',\n 'signature_request': 'absrequest'\n };\n var algorithm = method === 'publickey' ? 'RS256' : 'HS256';\n var jwtOptions = {\n algorithm: algorithm,\n issuer: name,\n subject: subjects[rrequest.request.type] || subjectsContext[rrequest.request['@context']]\n };\n return jwt.sign(_defineProperty({}, fields[jwtOptions.subject], rrequest), key, jwtOptions);\n });\n}\n/**\n * Poll the status URL of an IRMA server until it indicates that\n * the status is no longer Initialized, i.e. Connected or Done. Rejects\n * on other states (Cancelled, Timeout).\n * @param {string} url\n */\n\nfunction waitConnected(url) {\n return waitStatus(url, SessionStatus.Initialized).then(function (status) {\n if (status !== SessionStatus.Connected && status !== SessionStatus.Done) return Promise.reject(status);\n return status;\n });\n}\n/**\n * Poll the status URL of an IRMA server until it indicates that the status\n * has changed from Connected to Done. Rejects on any other state.\n * @param {string} url\n */\n\nfunction waitDone(url) {\n return waitStatus(url, SessionStatus.Connected).then(function (status) {\n if (status !== SessionStatus.Done) return Promise.reject(status);\n return status;\n });\n}\n\nfunction waitStatus(url) {\n var status = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SessionStatus.Initialized;\n return new Promise(function (resolve, reject) {\n var EvtSource = browser ? window.EventSource : EventSource;\n\n if (!EvtSource) {\n log('No support for EventSource, fallback to polling');\n poller(\"\".concat(url, \"/status\"), status, resolve, reject);\n return;\n } // The EventSource.onopen Javascript callback is not consistently called across browsers (Chrome yes, Firefox+Safari no),\n // but the irmaserver manually sends an \"open\" event 200 ms after establishing the SSE connection.\n // Cancel and fallback to polling if we don't get that signal (e.g. due to a reverse proxy breaking SSE).\n\n\n var source = new EvtSource(\"\".concat(url, \"/statusevents\"));\n var canceller = setTimeout(function () {\n return reject('no open message received');\n }, 500);\n\n source.onopen = function () {\n console.log('Opened!');\n clearTimeout(canceller);\n };\n\n source.onmessage = function (e) {\n clearTimeout(canceller);\n source.close();\n resolve(JSON.parse(e.data));\n };\n\n source.onerror = function (e) {\n clearTimeout(canceller);\n log('Received server event error', e);\n source.close();\n reject(e);\n };\n }).catch(function (e) {\n log('error in server sent event, falling back to polling:', e);\n return pollStatus(\"\".concat(url, \"/status\"), status);\n });\n}\n\nfunction pollStatus(url) {\n var status = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SessionStatus.Initialized;\n return new Promise(function (resolve, reject) {\n return poller(url, status, resolve, reject);\n });\n}\n\nvar poller = function poller(url, status, resolve, reject) {\n return fetchCheck(url).then(function (response) {\n return response.json();\n }).then(function (text) {\n return text !== status ? resolve(text) : setTimeout(poller, 500, url, status, resolve, reject);\n }).catch(function (err) {\n return reject(err);\n });\n};\n\nvar UserAgent = {\n Desktop: 'Desktop',\n Android: 'Android',\n iOS: 'iOS'\n};\n\nfunction processOptions(o) {\n log('Options:', o);\n var options = Object.assign({}, optionsDefaults, o);\n options.userAgent = detectUserAgent();\n\n if (browser && !options.disableMobile && options.userAgent !== UserAgent.Desktop) {\n if (options.method !== 'mobile') log('On mobile; using method mobile instead of ' + options.method);\n options.method = 'mobile';\n }\n\n switch (options.method) {\n case 'url':\n break;\n\n case 'mobile':\n if (options.returnStatus !== SessionStatus.Done) throw new Error('On mobile sessions, returnStatus must be Done');\n break;\n\n case 'popup':\n if (!browser) throw new Error('Cannot use method popup in node');\n if (!(options.language in _translations__WEBPACK_IMPORTED_MODULE_5__[\"default\"])) throw new Error('Unsupported language, currently supported: ' + Object.keys(_translations__WEBPACK_IMPORTED_MODULE_5__[\"default\"]).join(', '));\n options.element = 'modal-irmaqr';\n options.returnStatus = SessionStatus.Done;\n break;\n\n case 'canvas':\n if (!browser) throw new Error('Cannot use method canvas in node');\n if (typeof options.element !== 'string' || options.element === '') throw new Error('canvas method requires `element` to be provided in options');\n break;\n\n case 'console':\n if (browser) throw new Error('Cannot use console method in browser');\n break;\n\n default:\n throw new Error('Unsupported method');\n }\n\n if (typeof options.server !== 'string') throw new Error('server must be a string (URL)');\n if (options.server.length > 0 && options.returnStatus !== SessionStatus.Done) throw new Error('If server option is used, returnStatus option must be SessionStatus.Done');\n if (options.server.length > 0 && (typeof options.token !== 'string' || options.token.length === 0)) throw new Error('if server option is used, providing token option is required');\n if (options.resultJwt && options.server.length === 0) throw new Error('resultJwt option was enabled but no server to retrieve result from was provided');\n if (options.resultJwt && options.legacyResultJwt) throw new Error('resultJwt and legacyResultJwt options cannot be simultaneously enabled');\n return options;\n}\n\nfunction handleFetchErrors(response) {\n if (!response.ok) {\n return response.text().then(function (text) {\n warn('Server returned error:', text);\n throw new Error(response.statusText);\n });\n }\n\n return response;\n}\n\nfunction fetchCheck() {\n return isomorphic_fetch__WEBPACK_IMPORTED_MODULE_0___default.a.apply(null, arguments).then(handleFetchErrors);\n}\n\nfunction drawQr(canvas, qr) {\n qrcode__WEBPACK_IMPORTED_MODULE_1___default.a.toCanvas(canvas, JSON.stringify(qr), {\n width: '230',\n margin: '1'\n }, function (error) {\n if (error) throw error;\n });\n}\n\nfunction clearQr(canvas, showConnectedIcon) {\n var ctx = canvas.getContext('2d');\n ctx.clearRect(0, 0, canvas.width, canvas.height);\n\n if (showConnectedIcon) {\n var scale = window.devicePixelRatio;\n var canvasSize = 230;\n var imgWidth = 79;\n var imgHeight = 150;\n canvas.width = canvasSize * scale;\n canvas.height = canvasSize * scale;\n ctx.scale(scale, scale);\n var img = new Image();\n\n img.onload = function () {\n return ctx.drawImage(img, (canvasSize - imgWidth) / 2, (canvasSize - imgHeight) / 2, imgWidth, imgHeight);\n };\n\n img.src = _phone_png__WEBPACK_IMPORTED_MODULE_3___default.a;\n }\n}\n\nfunction setupPopup(qr, language) {\n ensurePopupInitialized();\n translatePopup(qr.irmaqr, language);\n window.document.getElementById('irma-modal').classList.add('irma-show');\n var cancelbtn = window.document.getElementById('irma-cancel-button');\n cancelbtn.addEventListener('click', function del() {\n isomorphic_fetch__WEBPACK_IMPORTED_MODULE_0___default()(qr.u, {\n method: 'DELETE'\n }); // We ignore server errors by not using fetchCheck\n // The popup including the irma-cancel-button element might be reused in later IRMA sessions,\n // so we need to remove this listener. removeEventListener() requires a function reference,\n // which we don't want to have to keep track of outside of setupPopup(), so we do the removing\n // of the listener here inside the listener itself.\n\n cancelbtn.removeEventListener('click', del);\n closePopup();\n });\n}\n\nfunction closePopup() {\n if (!browser || !window.document.getElementById('irma-modal')) return;\n window.document.getElementById('irma-modal').classList.remove('irma-show');\n}\n\nfunction ensurePopupInitialized() {\n if (!browser || window.document.getElementById('irma-modal')) return;\n var popup = window.document.createElement('div');\n popup.id = 'irma-modal';\n popup.innerHTML = _popup_html__WEBPACK_IMPORTED_MODULE_4___default.a;\n window.document.body.appendChild(popup);\n var overlay = window.document.createElement('div');\n overlay.classList.add('irma-overlay');\n window.document.body.appendChild(overlay); // If we add these elements and then immediately add a css class to trigger our css animations,\n // adding the elements and the css classes get bundled up and executed simultaneously,\n // preventing the css animation from being shown. Accessing offsetHeight forces a reflow in between.\n // https://stackoverflow.com/questions/24148403/trigger-css-transition-on-appended-element\n // https://stackoverflow.com/questions/21664940/force-browser-to-trigger-reflow-while-changing-css\n\n void popup.offsetHeight; // void prevents Javascript optimizers from throwing away this line\n}\n\nfunction log() {\n if (logEnabled) console.log.apply(console, arguments); // eslint-disable-line no-console\n}\n\nfunction warn() {\n if (logEnabled) console.warn.apply(console, arguments); // eslint-disable-line no-console\n}\n\nvar sessionTypeMap = {\n disclosing: 'Verify',\n issuing: 'Issue',\n signing: 'Sign'\n};\n\nfunction translatePopup(type, lang) {\n translatePopupElement('irma-cancel-button', 'Common.Cancel', lang);\n translatePopupElement('irma-title', sessionTypeMap[type] + '.Title', lang);\n translatePopupElement('irma-text', sessionTypeMap[type] + '.Body', lang);\n}\n\nfunction translatePopupElement(el, id, lang) {\n window.document.getElementById(el).innerText = getTranslatedString(id, lang);\n}\n\nfunction getTranslatedString(id, lang) {\n var parts = id.split('.');\n var res = _translations__WEBPACK_IMPORTED_MODULE_5__[\"default\"][lang];\n\n for (var part in parts) {\n if (res === undefined) break;\n res = res[parts[part]];\n }\n\n if (res === undefined) {\n res = _translations__WEBPACK_IMPORTED_MODULE_5__[\"default\"][optionsDefaults.language];\n\n for (var _part in parts) {\n if (res === undefined) break;\n res = res[parts[_part]];\n }\n }\n\n if (res === undefined) return '';else return res;\n}\n\nfunction startMobileSession(qr, userAgent) {\n var url = 'qr/json/' + encodeURIComponent(JSON.stringify(qr));\n\n if (userAgent === UserAgent.Android) {\n var intent = 'intent://' + url + '#Intent;package=org.irmacard.cardemu;scheme=cardemu;' + 'l.timestamp=' + Date.now() + ';' + 'S.browser_fallback_url=https%3A%2F%2Fplay.google.com%2Fstore%2Fapps%2Fdetails%3Fid%3Dorg.irmacard.cardemu;end';\n log('Navigating:', intent);\n window.location.href = intent;\n } else if (userAgent === UserAgent.iOS) {\n log('Navigating:', 'irma://' + url);\n window.location.href = 'irma://' + url;\n }\n}\n\nfunction detectUserAgent() {\n if (!browser) return null; // IE11 doesn't have window.navigator, test differently\n // https://stackoverflow.com/questions/21825157/internet-explorer-11-detection\n\n if (!!window.MSInputMethodContext && !!document.documentMode) {\n log('Detected IE11');\n return UserAgent.Desktop;\n }\n\n if (/Android/i.test(window.navigator.userAgent)) {\n log('Detected Android');\n return UserAgent.Android;\n } else if (/iPad|iPhone|iPod/.test(navigator.userAgent) && !window.MSStream) {\n // https://stackoverflow.com/questions/9038625/detect-if-device-is-ios\n log('Detected iOS');\n return UserAgent.iOS;\n } else {\n log('Neither Android nor iOS, assuming desktop');\n return UserAgent.Desktop;\n }\n}\n\n//# sourceURL=webpack://irma/./src/index.js?");
|
|
678
|
+
|
|
679
|
+
/***/ }),
|
|
680
|
+
|
|
681
|
+
/***/ "./src/irma.png":
|
|
682
|
+
/*!**********************!*\
|
|
683
|
+
!*** ./src/irma.png ***!
|
|
684
|
+
\**********************/
|
|
685
|
+
/*! no static exports found */
|
|
686
|
+
/***/ (function(module, exports) {
|
|
687
|
+
|
|
688
|
+
eval("module.exports = \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAASwAAAEsCAYAAAB5fY51AAAAAXNSR0IArs4c6QAAAAlwSFlzAAALEwAACxMBAJqcGAAAB0FpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IlhNUCBDb3JlIDUuNC4wIj4KICAgPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4KICAgICAgPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIKICAgICAgICAgICAgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIgogICAgICAgICAgICB4bWxuczp0aWZmPSJodHRwOi8vbnMuYWRvYmUuY29tL3RpZmYvMS4wLyIKICAgICAgICAgICAgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIgogICAgICAgICAgICB4bWxuczpkYz0iaHR0cDovL3B1cmwub3JnL2RjL2VsZW1lbnRzLzEuMS8iCiAgICAgICAgICAgIHhtbG5zOnhtcE1NPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvbW0vIgogICAgICAgICAgICB4bWxuczpzdEV2dD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlRXZlbnQjIj4KICAgICAgICAgPHBob3Rvc2hvcDpJQ0NQcm9maWxlPnNSR0IgSUVDNjE5NjYtMi4xPC9waG90b3Nob3A6SUNDUHJvZmlsZT4KICAgICAgICAgPHBob3Rvc2hvcDpDb2xvck1vZGU+MzwvcGhvdG9zaG9wOkNvbG9yTW9kZT4KICAgICAgICAgPHRpZmY6T3JpZW50YXRpb24+MTwvdGlmZjpPcmllbnRhdGlvbj4KICAgICAgICAgPHhtcDpNZXRhZGF0YURhdGU+MjAxOS0wOC0wNlQxMTowNDo0MiswMjowMDwveG1wOk1ldGFkYXRhRGF0ZT4KICAgICAgICAgPHhtcDpDcmVhdGVEYXRlPjIwMTktMDYtMTdUMDg6NDE6NTArMDI6MDA8L3htcDpDcmVhdGVEYXRlPgogICAgICAgICA8eG1wOk1vZGlmeURhdGU+MjAxOS0wOC0wNlQxMTowNDo0MiswMjowMDwveG1wOk1vZGlmeURhdGU+CiAgICAgICAgIDxkYzpmb3JtYXQ+aW1hZ2UvcG5nPC9kYzpmb3JtYXQ+CiAgICAgICAgIDx4bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ+eG1wLmRpZDo3YzRlMmI2NC05MjMwLTQ5MjktOTc1Ni03YzM0ZWQ3ZGM4MTk8L3htcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD4KICAgICAgICAgPHhtcE1NOkhpc3Rvcnk+CiAgICAgICAgICAgIDxyZGY6U2VxPgogICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHN0RXZ0OnNvZnR3YXJlQWdlbnQ+QWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKE1hY2ludG9zaCk8L3N0RXZ0OnNvZnR3YXJlQWdlbnQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDpjaGFuZ2VkPi88L3N0RXZ0OmNoYW5nZWQ+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDp3aGVuPjIwMTktMDgtMDZUMTE6MDQ6NDIrMDI6MDA8L3N0RXZ0OndoZW4+CiAgICAgICAgICAgICAgICAgIDxzdEV2dDppbnN0YW5jZUlEPnhtcC5paWQ6N2M0ZTJiNjQtOTIzMC00OTI5LTk3NTYtN2MzNGVkN2RjODE5PC9zdEV2dDppbnN0YW5jZUlEPgogICAgICAgICAgICAgICAgICA8c3RFdnQ6YWN0aW9uPnNhdmVkPC9zdEV2dDphY3Rpb24+CiAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICA8L3JkZjpTZXE+CiAgICAgICAgIDwveG1wTU06SGlzdG9yeT4KICAgICAgICAgPHhtcE1NOkluc3RhbmNlSUQ+eG1wLmlpZDo3YzRlMmI2NC05MjMwLTQ5MjktOTc1Ni03YzM0ZWQ3ZGM4MTk8L3htcE1NOkluc3RhbmNlSUQ+CiAgICAgICAgIDx4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\"\n\n//# sourceURL=webpack://irma/./src/irma.png?");
|
|
689
|
+
|
|
690
|
+
/***/ }),
|
|
691
|
+
|
|
692
|
+
/***/ "./src/irma.scss":
|
|
693
|
+
/*!***********************!*\
|
|
694
|
+
!*** ./src/irma.scss ***!
|
|
695
|
+
\***********************/
|
|
696
|
+
/*! no static exports found */
|
|
697
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
698
|
+
|
|
699
|
+
eval("\nvar content = __webpack_require__(/*! !../node_modules/css-loader!../node_modules/sass-loader/lib/loader.js!./irma.scss */ \"./node_modules/css-loader/index.js!./node_modules/sass-loader/lib/loader.js!./src/irma.scss\");\n\nif(typeof content === 'string') content = [[module.i, content, '']];\n\nvar transform;\nvar insertInto;\n\n\n\nvar options = {\"hmr\":true}\n\noptions.transform = transform\noptions.insertInto = undefined;\n\nvar update = __webpack_require__(/*! ../node_modules/style-loader/lib/addStyles.js */ \"./node_modules/style-loader/lib/addStyles.js\")(content, options);\n\nif(content.locals) module.exports = content.locals;\n\nif(false) {}\n\n//# sourceURL=webpack://irma/./src/irma.scss?");
|
|
700
|
+
|
|
701
|
+
/***/ }),
|
|
702
|
+
|
|
703
|
+
/***/ "./src/phone.png":
|
|
704
|
+
/*!***********************!*\
|
|
705
|
+
!*** ./src/phone.png ***!
|
|
706
|
+
\***********************/
|
|
707
|
+
/*! no static exports found */
|
|
708
|
+
/***/ (function(module, exports) {
|
|
709
|
+
|
|
710
|
+
eval("module.exports = \"data:image/png;base64,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\"\n\n//# sourceURL=webpack://irma/./src/phone.png?");
|
|
711
|
+
|
|
712
|
+
/***/ }),
|
|
713
|
+
|
|
714
|
+
/***/ "./src/popup.html":
|
|
715
|
+
/*!************************!*\
|
|
716
|
+
!*** ./src/popup.html ***!
|
|
717
|
+
\************************/
|
|
718
|
+
/*! no static exports found */
|
|
719
|
+
/***/ (function(module, exports, __webpack_require__) {
|
|
720
|
+
|
|
721
|
+
eval("module.exports = \" <div class='irma-dialog'>\\n <div class='modal-content'>\\n <div class='modal-body'>\\n <div class='irma-page'>\\n <div class='irma-content'>\\n <img src='\" + __webpack_require__(/*! ./irma.png */ \"./src/irma.png\") + \"' class='irma-logo-top' alt='IRMA logo' id='irma-logo' />\\n <div class='irma-title' id='irma-title'>Disclose attributes</div>\\n <p id='irma-text'>A website requested that you disclose some IRMA attributes. Please scan the QR code with your phone.</p>\\n <div class='irma-option-container'>\\n <canvas id='modal-irmaqr' class='irma-option-box'></canvas>\\n </div>\\n </div>\\n <div class='irma-button-box'>\\n <button class='irma-button' id='irma-cancel-button'>Cancel</button>\\n </div>\\n </div>\\n </div>\\n </div>\\n </div>\\n\";\n\n//# sourceURL=webpack://irma/./src/popup.html?");
|
|
722
|
+
|
|
723
|
+
/***/ }),
|
|
724
|
+
|
|
725
|
+
/***/ "./src/translations/en.js":
|
|
726
|
+
/*!********************************!*\
|
|
727
|
+
!*** ./src/translations/en.js ***!
|
|
728
|
+
\********************************/
|
|
729
|
+
/*! exports provided: default */
|
|
730
|
+
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
731
|
+
|
|
732
|
+
"use strict";
|
|
733
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n Common: {\n WaitData: 'Waiting for data...',\n Cancel: 'Cancel'\n },\n Messages: {\n FollowInstructions: 'Please follow the instructions in your IRMA app'\n },\n Sign: {\n Title: 'signature request',\n Body: 'A website requests that you sign a message using some of your IRMA attributes. Please scan the QR code with your IRMA app.'\n },\n Verify: {\n Title: 'attribute request',\n Body: 'A website requests that you disclose some of your IRMA attributes. Please scan the QR code with your IRMA app.'\n },\n Issue: {\n Title: 'attribute issuance',\n Body: 'A website wishes to issue IRMA attributes to you. Please scan the QR code with your IRMA app.'\n }\n});\n\n//# sourceURL=webpack://irma/./src/translations/en.js?");
|
|
734
|
+
|
|
735
|
+
/***/ }),
|
|
736
|
+
|
|
737
|
+
/***/ "./src/translations/index.js":
|
|
738
|
+
/*!***********************************!*\
|
|
739
|
+
!*** ./src/translations/index.js ***!
|
|
740
|
+
\***********************************/
|
|
741
|
+
/*! exports provided: default */
|
|
742
|
+
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
743
|
+
|
|
744
|
+
"use strict";
|
|
745
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _en__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./en */ \"./src/translations/en.js\");\n/* harmony import */ var _nl__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./nl */ \"./src/translations/nl.js\");\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n en: _en__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n nl: _nl__WEBPACK_IMPORTED_MODULE_1__[\"default\"]\n});\n\n//# sourceURL=webpack://irma/./src/translations/index.js?");
|
|
746
|
+
|
|
747
|
+
/***/ }),
|
|
748
|
+
|
|
749
|
+
/***/ "./src/translations/nl.js":
|
|
750
|
+
/*!********************************!*\
|
|
751
|
+
!*** ./src/translations/nl.js ***!
|
|
752
|
+
\********************************/
|
|
753
|
+
/*! exports provided: default */
|
|
754
|
+
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
755
|
+
|
|
756
|
+
"use strict";
|
|
757
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n Common: {\n WaitData: 'Wachten op data...',\n Cancel: 'Annuleren'\n },\n Messages: {\n FollowInstructions: 'Volg de instructies in uw IRMA app.'\n },\n Sign: {\n Title: 'verzoek om te tekenen',\n Body: 'Een website vraagt u een bericht te ondertekenen met enkele van uw IRMA attributen. Scan de QR code met uw IRMA app.'\n },\n Verify: {\n Title: 'verzoek om attributen',\n Body: 'Een website vraagt u enkele van uw IRMA attributen te tonen. Scan de QR code met uw IRMA app.'\n },\n Issue: {\n Title: 'attributenuitgifte',\n Body: 'Een website wil u enkele IRMA attributen geven. Scan de QR code met uw IRMA app.'\n }\n});\n\n//# sourceURL=webpack://irma/./src/translations/nl.js?");
|
|
758
|
+
|
|
759
|
+
/***/ }),
|
|
760
|
+
|
|
761
|
+
/***/ "eventsource":
|
|
762
|
+
/*!******************************!*\
|
|
763
|
+
!*** external "eventsource" ***!
|
|
764
|
+
\******************************/
|
|
765
|
+
/*! no static exports found */
|
|
766
|
+
/***/ (function(module, exports) {
|
|
767
|
+
|
|
768
|
+
eval("module.exports = __WEBPACK_EXTERNAL_MODULE_eventsource__;\n\n//# sourceURL=webpack://irma/external_%22eventsource%22?");
|
|
769
|
+
|
|
770
|
+
/***/ }),
|
|
771
|
+
|
|
772
|
+
/***/ "qrcode-terminal":
|
|
773
|
+
/*!*************************!*\
|
|
774
|
+
!*** external "qrcode" ***!
|
|
775
|
+
\*************************/
|
|
776
|
+
/*! no static exports found */
|
|
777
|
+
/***/ (function(module, exports) {
|
|
778
|
+
|
|
779
|
+
eval("module.exports = __WEBPACK_EXTERNAL_MODULE_qrcode_terminal__;\n\n//# sourceURL=webpack://irma/external_%22qrcode%22?");
|
|
780
|
+
|
|
781
|
+
/***/ })
|
|
782
|
+
|
|
783
|
+
/******/ });
|
|
784
|
+
});
|