ngx-scandoc 18.0.2 → 19.0.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.
- package/fesm2022/ngx-scandoc.mjs +130 -130
- package/fesm2022/ngx-scandoc.mjs.map +1 -1
- package/package.json +9 -11
- package/esm2022/core/app.worker.mjs +0 -236
- package/esm2022/core/components/base.component.mjs +0 -15
- package/esm2022/core/components/camera-switch/camera-switch.component.mjs +0 -25
- package/esm2022/core/components/components.module.mjs +0 -69
- package/esm2022/core/components/manual-scan/manual-scan.component.mjs +0 -290
- package/esm2022/core/components/scan/scan.component.mjs +0 -733
- package/esm2022/core/components/scan-results/scan-results.component.mjs +0 -65
- package/esm2022/core/components/webcam/domain/webcam-image.mjs +0 -58
- package/esm2022/core/components/webcam/domain/webcam-init-error.mjs +0 -3
- package/esm2022/core/components/webcam/domain/webcam-mirror-properties.mjs +0 -3
- package/esm2022/core/components/webcam/util/webcam.util.mjs +0 -50
- package/esm2022/core/components/webcam/webcam/webcam.component.mjs +0 -543
- package/esm2022/core/components/webcam/webcam.module.mjs +0 -29
- package/esm2022/core/helpers/object-utils.mjs +0 -100
- package/esm2022/core/interfaces/config.mjs +0 -2
- package/esm2022/core/interfaces/guest.data.mjs +0 -2
- package/esm2022/core/pipes/pipes.module.mjs +0 -19
- package/esm2022/core/pipes/safeResourceUrl.pipe.mjs +0 -20
- package/esm2022/core/shared/material.module.mjs +0 -162
- package/esm2022/core/tokens/config.tokens.mjs +0 -4
- package/esm2022/dialogs/components/blank/blank.component.mjs +0 -46
- package/esm2022/dialogs/components/confirm/confirm.component.mjs +0 -51
- package/esm2022/dialogs/components/loading/loading.component.mjs +0 -12
- package/esm2022/dialogs/components/prompt-manual/prompt-manual.component.mjs +0 -30
- package/esm2022/dialogs/components/scan-profile/scan-profile.component.mjs +0 -79
- package/esm2022/dialogs/components/scan-selfie/scan-selfie.component.mjs +0 -95
- package/esm2022/dialogs/components/turn-document/turn-document.component.mjs +0 -31
- package/esm2022/dialogs/dialogs.core.provider.mjs +0 -120
- package/esm2022/dialogs/dialogs.module.mjs +0 -102
- package/esm2022/forms/form.module.mjs +0 -87
- package/esm2022/forms/types/avatar.type.mjs +0 -58
- package/esm2022/forms/types/profile.image.type.mjs +0 -64
- package/esm2022/forms/types/title.type.mjs +0 -32
- package/esm2022/lib/ngx-scandoc.module.mjs +0 -44
- package/esm2022/ngx-scandoc.mjs +0 -5
- package/esm2022/providers/auth.provider.mjs +0 -113
- package/esm2022/providers/camera.provider.mjs +0 -87
- package/esm2022/providers/interceptor.provider.mjs +0 -77
- package/esm2022/providers/layout.provider.mjs +0 -30
- package/esm2022/providers/scan.form.mjs +0 -347
- package/esm2022/providers/scan.provider.mjs +0 -756
- package/esm2022/providers/translate-loader.provider.mjs +0 -126
- package/esm2022/providers/translation.provider.mjs +0 -133
- package/esm2022/providers/webrtc.provider.mjs +0 -58
- package/esm2022/public-api.mjs +0 -33
package/package.json
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ngx-scandoc",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "19.0.1",
|
|
4
4
|
"peerDependencies": {
|
|
5
|
-
"@angular/cdk": "^
|
|
6
|
-
"@angular/common": "^
|
|
7
|
-
"@angular/core": "^
|
|
8
|
-
"@angular/forms": "^
|
|
9
|
-
"@angular/material": "^
|
|
5
|
+
"@angular/cdk": "^19.2.19",
|
|
6
|
+
"@angular/common": "^19.2.14",
|
|
7
|
+
"@angular/core": "^19.2.14",
|
|
8
|
+
"@angular/forms": "^19.2.14",
|
|
9
|
+
"@angular/material": "^19.2.19",
|
|
10
10
|
"jwt-decode": "^4.0.0",
|
|
11
11
|
"moment": "^2.30.1",
|
|
12
12
|
"ndarray": "^1.0.19",
|
|
13
13
|
"ndarray-ops": "^1.2.2",
|
|
14
|
-
"ngx-avatars": "
|
|
15
|
-
"ngx-device-detector": "^
|
|
14
|
+
"ngx-avatars": "1.9",
|
|
15
|
+
"ngx-device-detector": "^9.0.0",
|
|
16
16
|
"onnxruntime-web": "^1.18.0",
|
|
17
17
|
"rxjs": "^7.8.2"
|
|
18
18
|
},
|
|
@@ -24,13 +24,11 @@
|
|
|
24
24
|
},
|
|
25
25
|
".": {
|
|
26
26
|
"types": "./index.d.ts",
|
|
27
|
-
"esm2022": "./esm2022/ngx-scandoc.mjs",
|
|
28
|
-
"esm": "./esm2022/ngx-scandoc.mjs",
|
|
29
27
|
"default": "./fesm2022/ngx-scandoc.mjs"
|
|
30
28
|
}
|
|
31
29
|
},
|
|
32
30
|
"sideEffects": false,
|
|
33
31
|
"dependencies": {
|
|
34
|
-
"tslib": "^2.
|
|
32
|
+
"tslib": "^2.3.0"
|
|
35
33
|
}
|
|
36
34
|
}
|
|
@@ -1,236 +0,0 @@
|
|
|
1
|
-
export const workertext = `
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
let readStream = true;
|
|
5
|
-
async function blobToBase64(blob) {
|
|
6
|
-
return new Promise((resolve, _) => {
|
|
7
|
-
const reader = new FileReader();
|
|
8
|
-
reader.onloadend = () => resolve(reader.result);
|
|
9
|
-
reader.readAsDataURL(blob);
|
|
10
|
-
});
|
|
11
|
-
}
|
|
12
|
-
async function delay(ms) {
|
|
13
|
-
return new Promise((resolve) =>
|
|
14
|
-
ms > 0 ? setTimeout(resolve, ms) : resolve(0)
|
|
15
|
-
);
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
function calculateDelay(startTime) {
|
|
19
|
-
const endTime = Date.now();
|
|
20
|
-
// difference in ms
|
|
21
|
-
const dt = endTime - startTime;
|
|
22
|
-
const delay = 100 - dt;
|
|
23
|
-
// console.log('[WORKER TIME]', dt, '[DELAY 100-x]', delay);
|
|
24
|
-
return delay > 4 ? delay : 0;
|
|
25
|
-
}
|
|
26
|
-
async function parseFrame(frameStream, trackSettings) {
|
|
27
|
-
const reader = frameStream.getReader();
|
|
28
|
-
|
|
29
|
-
while (readStream) {
|
|
30
|
-
const time = Date.now();
|
|
31
|
-
const result = await reader.read();
|
|
32
|
-
if (result.done) break;
|
|
33
|
-
|
|
34
|
-
const frameFromCamera = result.value;
|
|
35
|
-
|
|
36
|
-
await parseFrameFromCamera(frameFromCamera, trackSettings);
|
|
37
|
-
// wait
|
|
38
|
-
await delay(calculateDelay(time));
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
async function parseFrameFast(frameStream, trackSettings) {
|
|
43
|
-
console.warn('FAST', performance.now());
|
|
44
|
-
const reader = frameStream.getReader();
|
|
45
|
-
const { width, height } = trackSettings;
|
|
46
|
-
const offscreenSmall = new OffscreenCanvas(384, 384);
|
|
47
|
-
const context = offscreenSmall.getContext('2d');
|
|
48
|
-
let time = 0;
|
|
49
|
-
while (true) {
|
|
50
|
-
// const t0 = performance.now();
|
|
51
|
-
// console.time('result');
|
|
52
|
-
const result = reader.read();
|
|
53
|
-
// console.timeEnd('result');
|
|
54
|
-
if (result.done) break;
|
|
55
|
-
|
|
56
|
-
const frameFromCamera = result.value;
|
|
57
|
-
// console.log(frameFromCamera.timestamp);
|
|
58
|
-
|
|
59
|
-
// const tt = frameFromCamera.timestamp - time;
|
|
60
|
-
// console.log(tt / 1000);
|
|
61
|
-
// time = frameFromCamera.timestamp;
|
|
62
|
-
|
|
63
|
-
// console.time('bitmap');
|
|
64
|
-
const bitmap = await createImageBitmap(frameFromCamera, {
|
|
65
|
-
premultiplyAlpha: 'default',
|
|
66
|
-
});
|
|
67
|
-
console.warn(new Date().getTime());
|
|
68
|
-
// console.timeEnd('bitmap');
|
|
69
|
-
|
|
70
|
-
// context.clearRect(0, 0, 384, 384);
|
|
71
|
-
// console.time('draw');
|
|
72
|
-
// context.drawImage(bitmap, 0, 0, width, height, 0, 0, 384, 384);
|
|
73
|
-
// console.timeEnd('draw');
|
|
74
|
-
// console.time('transfer');
|
|
75
|
-
// const bitmapSmall = offscreenSmall.transferToImageBitmap();
|
|
76
|
-
// console.timeEnd('transfer');
|
|
77
|
-
|
|
78
|
-
frameFromCamera.close();
|
|
79
|
-
// //
|
|
80
|
-
// const t1 = performance.now();
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
// await parseFrameFromCamera(frameFromCamera, trackSettings);
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
async function parseFrameFromCamera(frameFromCamera, trackSettings) {
|
|
88
|
-
const { width, height } = trackSettings;
|
|
89
|
-
const offscreenSmall = new OffscreenCanvas(384, 384);
|
|
90
|
-
// console.time('bit2');
|
|
91
|
-
const bitmap = await createImageBitmap(frameFromCamera, {
|
|
92
|
-
premultiplyAlpha: 'default',
|
|
93
|
-
});
|
|
94
|
-
// console.timeEnd('bit2');
|
|
95
|
-
const context = offscreenSmall.getContext('2d');
|
|
96
|
-
|
|
97
|
-
// console.time('buffer');
|
|
98
|
-
// const buffer = new Uint8Array(frameFromCamera.allocationSize());
|
|
99
|
-
// let layout = await frameFromCamera.copyTo(buffer);
|
|
100
|
-
|
|
101
|
-
// const base64 = await blobToBase64(new Blob([buffer]));
|
|
102
|
-
// console.log(base64)
|
|
103
|
-
// console.timeEnd('buffer');
|
|
104
|
-
|
|
105
|
-
if (context) {
|
|
106
|
-
context.imageSmoothingEnabled = false;
|
|
107
|
-
|
|
108
|
-
// let videoFrame2 = frameFromCamera.clone();
|
|
109
|
-
|
|
110
|
-
// createImageBitmap();
|
|
111
|
-
|
|
112
|
-
// console.time('clear');
|
|
113
|
-
// context.clearRect(0, 0, width, height);
|
|
114
|
-
// console.timeEnd('clear');
|
|
115
|
-
// console.time('draw');
|
|
116
|
-
context.drawImage(bitmap, 0, 0, width, height, 0, 0, 384, 384);
|
|
117
|
-
// console.timeEnd('draw');
|
|
118
|
-
// context.drawImage(bit, 0, 0);
|
|
119
|
-
// bit2.close();
|
|
120
|
-
// bit.close();
|
|
121
|
-
// console.timeEnd('draw');
|
|
122
|
-
// console.time('capture');
|
|
123
|
-
|
|
124
|
-
// const bitmapsmall = offscreenSmall.transferToImageBitmap();
|
|
125
|
-
|
|
126
|
-
// const imageData = context.getImageData(0, 0, 384, 384);
|
|
127
|
-
// console.timeEnd('capture');
|
|
128
|
-
// console.time('blob');
|
|
129
|
-
const resized = await offscreenSmall.convertToBlob({
|
|
130
|
-
type: 'image/jpeg',
|
|
131
|
-
});
|
|
132
|
-
// console.timeEnd('blob');
|
|
133
|
-
// console.log(resized);
|
|
134
|
-
// console.time('base64');
|
|
135
|
-
const base64 = await blobToBase64(resized);
|
|
136
|
-
//console.timeEnd('base64');
|
|
137
|
-
// console.log(blob);
|
|
138
|
-
|
|
139
|
-
// console.time('convert')
|
|
140
|
-
// await convert(bitmap, trackSettings)
|
|
141
|
-
// console.timeEnd('convert');
|
|
142
|
-
// console.log(
|
|
143
|
-
// '%c ',
|
|
144
|
-
// 'font-size:384px; background:url('+blob+') no-repeat;'
|
|
145
|
-
// );
|
|
146
|
-
|
|
147
|
-
// console.timeEnd('blob');
|
|
148
|
-
postMessage({ base64, bitmap }, [bitmap]);
|
|
149
|
-
// videoFrame2.close();
|
|
150
|
-
}
|
|
151
|
-
frameFromCamera.close();
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
async function convert(image, trackSettings) {
|
|
155
|
-
const { width, height } = trackSettings;
|
|
156
|
-
|
|
157
|
-
const offscreenSmall = new OffscreenCanvas(width, height);
|
|
158
|
-
|
|
159
|
-
const context = offscreenSmall.getContext('2d');
|
|
160
|
-
|
|
161
|
-
// console.time('buffer');
|
|
162
|
-
// const buffer = new Uint8Array(frameFromCamera.allocationSize());
|
|
163
|
-
// let layout = await frameFromCamera.copyTo(buffer);
|
|
164
|
-
// console.timeEnd('buffer');
|
|
165
|
-
|
|
166
|
-
if (context) {
|
|
167
|
-
context.imageSmoothingEnabled = false;
|
|
168
|
-
// let videoFrame2 = frameFromCamera.clone();
|
|
169
|
-
console.warn(image);
|
|
170
|
-
// createImageBitmap();
|
|
171
|
-
|
|
172
|
-
// console.time('clear');
|
|
173
|
-
// context.clearRect(0, 0, width, height);
|
|
174
|
-
// console.timeEnd('clear');
|
|
175
|
-
|
|
176
|
-
context.drawImage(image, 0, 0);
|
|
177
|
-
// context.drawImage(bit, 0, 0);
|
|
178
|
-
// image.close();
|
|
179
|
-
// console.timeEnd('drawB');
|
|
180
|
-
console.time('blob2');
|
|
181
|
-
const resized = await offscreenSmall.convertToBlob({
|
|
182
|
-
type: 'image/jpeg',
|
|
183
|
-
});
|
|
184
|
-
console.timeEnd('blob2');
|
|
185
|
-
|
|
186
|
-
// image.close();
|
|
187
|
-
// console.time('base64');
|
|
188
|
-
const base64 = await blobToBase64(resized);
|
|
189
|
-
|
|
190
|
-
// console.log(blob);
|
|
191
|
-
|
|
192
|
-
// console.log(
|
|
193
|
-
// '%c ',
|
|
194
|
-
// 'font-size:384px; background:url(' + base64 + ') no-repeat;'
|
|
195
|
-
// );
|
|
196
|
-
|
|
197
|
-
// console.timeEnd('base64');
|
|
198
|
-
//postMessage({ type: 'convert', base64 });
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
addEventListener('message', ({ data }) => {
|
|
202
|
-
const { type, image, frameStream, trackSettings } = data;
|
|
203
|
-
// console.log(data);
|
|
204
|
-
switch (type) {
|
|
205
|
-
case 'start':
|
|
206
|
-
readStream = true;
|
|
207
|
-
parseFrame(frameStream, trackSettings);
|
|
208
|
-
break;
|
|
209
|
-
|
|
210
|
-
case 'fast':
|
|
211
|
-
readStream = true;
|
|
212
|
-
parseFrameFast(frameStream, trackSettings);
|
|
213
|
-
break;
|
|
214
|
-
|
|
215
|
-
case 'stop':
|
|
216
|
-
console.warn('STOP WORKER');
|
|
217
|
-
readStream = false;
|
|
218
|
-
break;
|
|
219
|
-
|
|
220
|
-
case 'convert':
|
|
221
|
-
convert(image, trackSettings);
|
|
222
|
-
break;
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
// const canvas = document.createElement('canvas');
|
|
226
|
-
// const ctx = canvas.getContext('2d');
|
|
227
|
-
|
|
228
|
-
// if (data.canvas) {
|
|
229
|
-
// postMessage('ok');
|
|
230
|
-
// } else {
|
|
231
|
-
|
|
232
|
-
// postMessage(response);
|
|
233
|
-
// }
|
|
234
|
-
});
|
|
235
|
-
`;
|
|
236
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.worker.js","sourceRoot":"","sources":["../../../../projects/ngx-scandoc/src/core/app.worker.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,UAAU,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA0OzB,CAAC","sourcesContent":["export const workertext = `\n\n\nlet readStream = true;\nasync function blobToBase64(blob) {\n  return new Promise((resolve, _) => {\n    const reader = new FileReader();\n    reader.onloadend = () => resolve(reader.result);\n    reader.readAsDataURL(blob);\n  });\n}\nasync function delay(ms) {\n  return new Promise((resolve) =>\n    ms > 0 ? setTimeout(resolve, ms) : resolve(0)\n  );\n}\n\nfunction calculateDelay(startTime) {\n  const endTime = Date.now();\n  // difference in ms\n  const dt = endTime - startTime;\n  const delay = 100 - dt;\n // console.log('[WORKER TIME]', dt, '[DELAY 100-x]', delay);\n  return delay > 4 ? delay : 0;\n}\nasync function parseFrame(frameStream, trackSettings) {\n  const reader = frameStream.getReader();\n\n  while (readStream) {\n    const time = Date.now();\n    const result = await reader.read();\n    if (result.done) break;\n\n    const frameFromCamera = result.value;\n\n    await parseFrameFromCamera(frameFromCamera, trackSettings);\n    // wait\n    await delay(calculateDelay(time));\n  }\n}\n\nasync function parseFrameFast(frameStream, trackSettings) {\n  console.warn('FAST', performance.now());\n  const reader = frameStream.getReader();\n  const { width, height } = trackSettings;\n  const offscreenSmall = new OffscreenCanvas(384, 384);\n  const context = offscreenSmall.getContext('2d');\n  let time = 0;\n  while (true) {\n    // const t0 = performance.now();\n    //  console.time('result');\n    const result = reader.read();\n    //  console.timeEnd('result');\n    if (result.done) break;\n\n    const frameFromCamera = result.value;\n    // console.log(frameFromCamera.timestamp);\n\n    // const tt = frameFromCamera.timestamp - time;\n    // console.log(tt / 1000);\n    // time = frameFromCamera.timestamp;\n\n    // console.time('bitmap');\n    const bitmap = await createImageBitmap(frameFromCamera, {\n      premultiplyAlpha: 'default',\n    });\n    console.warn(new Date().getTime());\n    // console.timeEnd('bitmap');\n\n    // context.clearRect(0, 0, 384, 384);\n    // console.time('draw');\n    // context.drawImage(bitmap, 0, 0, width, height, 0, 0, 384, 384);\n    // console.timeEnd('draw');\n    // console.time('transfer');\n    // const bitmapSmall = offscreenSmall.transferToImageBitmap();\n    // console.timeEnd('transfer');\n\n    frameFromCamera.close();\n    // //\n    // const t1 = performance.now();\n\n\n    // await parseFrameFromCamera(frameFromCamera, trackSettings);\n  }\n}\n\nasync function parseFrameFromCamera(frameFromCamera, trackSettings) {\n  const { width, height } = trackSettings;\n  const offscreenSmall = new OffscreenCanvas(384, 384);\n  // console.time('bit2');\n  const bitmap = await createImageBitmap(frameFromCamera, {\n    premultiplyAlpha: 'default',\n  });\n  // console.timeEnd('bit2');\n  const context = offscreenSmall.getContext('2d');\n\n  //      console.time('buffer');\n  //      const buffer = new Uint8Array(frameFromCamera.allocationSize());\n  //      let layout = await frameFromCamera.copyTo(buffer);\n\n  //       const base64 = await blobToBase64(new Blob([buffer]));\n  // console.log(base64)\n  //      console.timeEnd('buffer');\n\n  if (context) {\n    context.imageSmoothingEnabled = false;\n\n    // let videoFrame2 = frameFromCamera.clone();\n\n    //   createImageBitmap();\n\n    // console.time('clear');\n    // context.clearRect(0, 0, width, height);\n    //  console.timeEnd('clear');\n    // console.time('draw');\n    context.drawImage(bitmap, 0, 0, width, height, 0, 0, 384, 384);\n    // console.timeEnd('draw');\n    // context.drawImage(bit, 0, 0);\n    //  bit2.close();\n    //  bit.close();\n    //  console.timeEnd('draw');\n    // console.time('capture');\n\n    // const bitmapsmall = offscreenSmall.transferToImageBitmap();\n\n    // const imageData = context.getImageData(0, 0, 384, 384);\n    //  console.timeEnd('capture');\n    // console.time('blob');\n    const resized = await offscreenSmall.convertToBlob({\n      type: 'image/jpeg',\n    });\n    // console.timeEnd('blob');\n    //  console.log(resized);\n    //  console.time('base64');\n    const base64 = await blobToBase64(resized);\n    //console.timeEnd('base64');\n    // console.log(blob);\n\n    // console.time('convert')\n    // await convert(bitmap, trackSettings)\n    // console.timeEnd('convert');\n    // console.log(\n    //   '%c ',\n    //   'font-size:384px; background:url('+blob+') no-repeat;'\n    // );\n\n    //   console.timeEnd('blob');\n    postMessage({ base64, bitmap }, [bitmap]);\n    // videoFrame2.close();\n  }\n  frameFromCamera.close();\n}\n\nasync function convert(image, trackSettings) {\n  const { width, height } = trackSettings;\n\n  const offscreenSmall = new OffscreenCanvas(width, height);\n\n  const context = offscreenSmall.getContext('2d');\n\n  // console.time('buffer');\n  // const buffer = new Uint8Array(frameFromCamera.allocationSize());\n  // let layout = await frameFromCamera.copyTo(buffer);\n  // console.timeEnd('buffer');\n\n  if (context) {\n    context.imageSmoothingEnabled = false;\n    // let videoFrame2 = frameFromCamera.clone();\n    console.warn(image);\n    //   createImageBitmap();\n\n    // console.time('clear');\n    // context.clearRect(0, 0, width, height);\n    // console.timeEnd('clear');\n\n    context.drawImage(image, 0, 0);\n    // context.drawImage(bit, 0, 0);\n    // image.close();\n    // console.timeEnd('drawB');\n    console.time('blob2');\n    const resized = await offscreenSmall.convertToBlob({\n      type: 'image/jpeg',\n    });\n    console.timeEnd('blob2');\n\n    // image.close();\n    // console.time('base64');\n    const base64 = await blobToBase64(resized);\n\n    // console.log(blob);\n\n    // console.log(\n    //   '%c ',\n    //   'font-size:384px; background:url(' + base64 + ') no-repeat;'\n    // );\n\n    //  console.timeEnd('base64');\n    //postMessage({ type: 'convert', base64 });\n  }\n}\naddEventListener('message', ({ data }) => {\n  const { type, image, frameStream, trackSettings } = data;\n  // console.log(data);\n  switch (type) {\n    case 'start':\n      readStream = true;\n      parseFrame(frameStream, trackSettings);\n      break;\n\n    case 'fast':\n      readStream = true;\n      parseFrameFast(frameStream, trackSettings);\n      break;\n\n    case 'stop':\n      console.warn('STOP WORKER');\n      readStream = false;\n      break;\n\n    case 'convert':\n      convert(image, trackSettings);\n      break;\n  }\n\n  // const canvas = document.createElement('canvas');\n  // const ctx = canvas.getContext('2d');\n\n  // if (data.canvas) {\n  //   postMessage('ok');\n  // } else {\n\n  //   postMessage(response);\n  // }\n});\n`;\n"]}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { Subject } from 'rxjs';
|
|
2
|
-
import { takeUntil } from 'rxjs/operators';
|
|
3
|
-
export class BaseComponent {
|
|
4
|
-
constructor() {
|
|
5
|
-
this.$destroy = new Subject();
|
|
6
|
-
}
|
|
7
|
-
__subs(observable) {
|
|
8
|
-
return observable.pipe(takeUntil(this.$destroy));
|
|
9
|
-
}
|
|
10
|
-
__destroy() {
|
|
11
|
-
this.$destroy.next(true);
|
|
12
|
-
this.$destroy.complete();
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2NhbmRvYy9zcmMvY29yZS9jb21wb25lbnRzL2Jhc2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYyxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDM0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTNDLE1BQU0sT0FBTyxhQUFhO0lBQTFCO1FBQ0UsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFFLENBQUM7SUFVM0IsQ0FBQztJQVJDLE1BQU0sQ0FBQyxVQUEyQjtRQUNoQyxPQUFPLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRCxTQUFTO1FBQ1AsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDekIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUMzQixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmV4cG9ydCBjbGFzcyBCYXNlQ29tcG9uZW50IHtcbiAgJGRlc3Ryb3kgPSBuZXcgU3ViamVjdCgpO1xuXG4gIF9fc3VicyhvYnNlcnZhYmxlOiBPYnNlcnZhYmxlPGFueT4pIHtcbiAgICByZXR1cm4gb2JzZXJ2YWJsZS5waXBlKHRha2VVbnRpbCh0aGlzLiRkZXN0cm95KSk7XG4gIH1cblxuICBfX2Rlc3Ryb3koKSB7XG4gICAgdGhpcy4kZGVzdHJveS5uZXh0KHRydWUpO1xuICAgIHRoaXMuJGRlc3Ryb3kuY29tcGxldGUoKTtcbiAgfVxufVxuIl19
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { Component, } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "../../../providers/camera.provider";
|
|
4
|
-
import * as i2 from "@angular/common";
|
|
5
|
-
import * as i3 from "@angular/forms";
|
|
6
|
-
import * as i4 from "@angular/material/form-field";
|
|
7
|
-
import * as i5 from "@angular/material/select";
|
|
8
|
-
import * as i6 from "@angular/material/core";
|
|
9
|
-
import * as i7 from "@ngx-translate/core";
|
|
10
|
-
export class CameraSwitchComponent {
|
|
11
|
-
constructor(cameraProvider) {
|
|
12
|
-
this.cameraProvider = cameraProvider;
|
|
13
|
-
}
|
|
14
|
-
ngAfterViewInit() {
|
|
15
|
-
// this.cameraProvider.setDefault();
|
|
16
|
-
}
|
|
17
|
-
ngOnDestroy() { }
|
|
18
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CameraSwitchComponent, deps: [{ token: i1.NgxScandocCameraProvider }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
19
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CameraSwitchComponent, selector: "ngx-scan-camera-switch", ngImport: i0, template: "<mat-form-field\n style=\"font-size: 14px; margin-top: 8px\"\n class=\"w-100-p mr-16 mt-8\"\n\n>\n <mat-label> {{ \"scandoc.camera\" | translate }} </mat-label>\n <mat-select\n (selectionChange)=\"cameraProvider.selectCamera($event)\"\n [(ngModel)]=\"cameraProvider.deviceId\"\n >\n <mat-option\n *ngFor=\"let device of cameraProvider.mediaDevices\"\n [value]=\"device.deviceId\"\n >\n {{ device.label }}\n </mat-option>\n </mat-select>\n</mat-form-field>\n", styles: [":host{display:flex;flex-direction:column!important;flex:1}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
|
|
20
|
-
}
|
|
21
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CameraSwitchComponent, decorators: [{
|
|
22
|
-
type: Component,
|
|
23
|
-
args: [{ selector: 'ngx-scan-camera-switch', template: "<mat-form-field\n style=\"font-size: 14px; margin-top: 8px\"\n class=\"w-100-p mr-16 mt-8\"\n\n>\n <mat-label> {{ \"scandoc.camera\" | translate }} </mat-label>\n <mat-select\n (selectionChange)=\"cameraProvider.selectCamera($event)\"\n [(ngModel)]=\"cameraProvider.deviceId\"\n >\n <mat-option\n *ngFor=\"let device of cameraProvider.mediaDevices\"\n [value]=\"device.deviceId\"\n >\n {{ device.label }}\n </mat-option>\n </mat-select>\n</mat-form-field>\n", styles: [":host{display:flex;flex-direction:column!important;flex:1}\n"] }]
|
|
24
|
-
}], ctorParameters: () => [{ type: i1.NgxScandocCameraProvider }] });
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FtZXJhLXN3aXRjaC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2NhbmRvYy9zcmMvY29yZS9jb21wb25lbnRzL2NhbWVyYS1zd2l0Y2gvY2FtZXJhLXN3aXRjaC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2NhbmRvYy9zcmMvY29yZS9jb21wb25lbnRzL2NhbWVyYS1zd2l0Y2gvY2FtZXJhLXN3aXRjaC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxHQU1WLE1BQU0sZUFBZSxDQUFDOzs7Ozs7Ozs7QUFTdkIsTUFBTSxPQUFPLHFCQUFxQjtJQUNoQyxZQUFtQixjQUF3QztRQUF4QyxtQkFBYyxHQUFkLGNBQWMsQ0FBMEI7SUFBRyxDQUFDO0lBSS9ELGVBQWU7UUFFZCxvQ0FBb0M7SUFDckMsQ0FBQztJQUVELFdBQVcsS0FBVSxDQUFDOytHQVZYLHFCQUFxQjttR0FBckIscUJBQXFCLDhEQ2hCbEMsZ2ZBa0JBOzs0RkRGYSxxQkFBcUI7a0JBTmpDLFNBQVM7K0JBQ0Usd0JBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIEFmdGVyVmlld0luaXQsXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBJbnB1dCxcbiAgT25EZXN0cm95LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5neFNjYW5kb2NDYW1lcmFQcm92aWRlciB9IGZyb20gJy4uLy4uLy4uL3Byb3ZpZGVycy9jYW1lcmEucHJvdmlkZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICduZ3gtc2Nhbi1jYW1lcmEtc3dpdGNoJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NhbWVyYS1zd2l0Y2guY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jYW1lcmEtc3dpdGNoLmNvbXBvbmVudC5zY3NzJ10sXG4gLy8gY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIENhbWVyYVN3aXRjaENvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBjYW1lcmFQcm92aWRlcjogTmd4U2NhbmRvY0NhbWVyYVByb3ZpZGVyKSB7fVxuXG5cblxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG5cbiAgIC8vIHRoaXMuY2FtZXJhUHJvdmlkZXIuc2V0RGVmYXVsdCgpO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7fVxufVxuIiwiPG1hdC1mb3JtLWZpZWxkXG4gIHN0eWxlPVwiZm9udC1zaXplOiAxNHB4OyAgbWFyZ2luLXRvcDogOHB4XCJcbiAgY2xhc3M9XCJ3LTEwMC1wIG1yLTE2IG10LThcIlxuXG4+XG4gIDxtYXQtbGFiZWw+IHt7IFwic2NhbmRvYy5jYW1lcmFcIiB8IHRyYW5zbGF0ZSB9fSA8L21hdC1sYWJlbD5cbiAgPG1hdC1zZWxlY3RcbiAgICAoc2VsZWN0aW9uQ2hhbmdlKT1cImNhbWVyYVByb3ZpZGVyLnNlbGVjdENhbWVyYSgkZXZlbnQpXCJcbiAgICBbKG5nTW9kZWwpXT1cImNhbWVyYVByb3ZpZGVyLmRldmljZUlkXCJcbiAgPlxuICAgIDxtYXQtb3B0aW9uXG4gICAgICAqbmdGb3I9XCJsZXQgZGV2aWNlIG9mIGNhbWVyYVByb3ZpZGVyLm1lZGlhRGV2aWNlc1wiXG4gICAgICBbdmFsdWVdPVwiZGV2aWNlLmRldmljZUlkXCJcbiAgICA+XG4gICAgICB7eyBkZXZpY2UubGFiZWwgfX1cbiAgICA8L21hdC1vcHRpb24+XG4gIDwvbWF0LXNlbGVjdD5cbjwvbWF0LWZvcm0tZmllbGQ+XG4iXX0=
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { WebcamModule } from './webcam/webcam.module';
|
|
4
|
-
import { ScanComponent } from './scan/scan.component';
|
|
5
|
-
import { MaterialModule } from '../shared/material.module';
|
|
6
|
-
import { AppFormModule } from '../../forms/form.module';
|
|
7
|
-
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
8
|
-
import { TranslateModule } from '@ngx-translate/core';
|
|
9
|
-
import { CameraSwitchComponent } from './camera-switch/camera-switch.component';
|
|
10
|
-
import { ScanResultsComponent } from './scan-results/scan-results.component';
|
|
11
|
-
import { ManualScanComponent } from './manual-scan/manual-scan.component';
|
|
12
|
-
import * as i0 from "@angular/core";
|
|
13
|
-
import * as i1 from "./webcam/webcam.module";
|
|
14
|
-
//import { NgxScandocCameraProvider } from '../../providers/camera.provider';
|
|
15
|
-
export class CoreComponentsModule {
|
|
16
|
-
static forRoot() {
|
|
17
|
-
return {
|
|
18
|
-
ngModule: CoreComponentsModule,
|
|
19
|
-
providers: [],
|
|
20
|
-
};
|
|
21
|
-
}
|
|
22
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CoreComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
23
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: CoreComponentsModule, declarations: [ScanComponent,
|
|
24
|
-
ScanResultsComponent,
|
|
25
|
-
CameraSwitchComponent,
|
|
26
|
-
ManualScanComponent], imports: [CommonModule,
|
|
27
|
-
FormsModule,
|
|
28
|
-
TranslateModule, i1.WebcamModule, MaterialModule,
|
|
29
|
-
AppFormModule,
|
|
30
|
-
ReactiveFormsModule], exports: [WebcamModule,
|
|
31
|
-
ScanComponent,
|
|
32
|
-
CameraSwitchComponent,
|
|
33
|
-
ManualScanComponent] }); }
|
|
34
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CoreComponentsModule, imports: [CommonModule,
|
|
35
|
-
FormsModule,
|
|
36
|
-
TranslateModule,
|
|
37
|
-
WebcamModule.forRoot(),
|
|
38
|
-
MaterialModule,
|
|
39
|
-
AppFormModule,
|
|
40
|
-
ReactiveFormsModule, WebcamModule] }); }
|
|
41
|
-
}
|
|
42
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CoreComponentsModule, decorators: [{
|
|
43
|
-
type: NgModule,
|
|
44
|
-
args: [{
|
|
45
|
-
imports: [
|
|
46
|
-
CommonModule,
|
|
47
|
-
FormsModule,
|
|
48
|
-
TranslateModule,
|
|
49
|
-
WebcamModule.forRoot(),
|
|
50
|
-
MaterialModule,
|
|
51
|
-
AppFormModule,
|
|
52
|
-
ReactiveFormsModule,
|
|
53
|
-
],
|
|
54
|
-
declarations: [
|
|
55
|
-
ScanComponent,
|
|
56
|
-
ScanResultsComponent,
|
|
57
|
-
CameraSwitchComponent,
|
|
58
|
-
ManualScanComponent,
|
|
59
|
-
],
|
|
60
|
-
exports: [
|
|
61
|
-
WebcamModule,
|
|
62
|
-
ScanComponent,
|
|
63
|
-
CameraSwitchComponent,
|
|
64
|
-
ManualScanComponent,
|
|
65
|
-
],
|
|
66
|
-
providers: [],
|
|
67
|
-
}]
|
|
68
|
-
}] });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2NhbmRvYy9zcmMvY29yZS9jb21wb25lbnRzL2NvbXBvbmVudHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBdUIsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTlELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNoRixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQzs7O0FBQzFFLDZFQUE2RTtBQTBCN0UsTUFBTSxPQUFPLG9CQUFvQjtJQUMvQixNQUFNLENBQUMsT0FBTztRQUNaLE9BQU87WUFDTCxRQUFRLEVBQUUsb0JBQW9CO1lBQzlCLFNBQVMsRUFBRSxFQUFFO1NBQ2QsQ0FBQztJQUNKLENBQUM7K0dBTlUsb0JBQW9CO2dIQUFwQixvQkFBb0IsaUJBYjdCLGFBQWE7WUFDYixvQkFBb0I7WUFDcEIscUJBQXFCO1lBQ3JCLG1CQUFtQixhQVpuQixZQUFZO1lBQ1osV0FBVztZQUNYLGVBQWUsbUJBRWYsY0FBYztZQUNkLGFBQWE7WUFDYixtQkFBbUIsYUFTbkIsWUFBWTtZQUNaLGFBQWE7WUFDYixxQkFBcUI7WUFDckIsbUJBQW1CO2dIQUlWLG9CQUFvQixZQXRCN0IsWUFBWTtZQUNaLFdBQVc7WUFDWCxlQUFlO1lBQ2YsWUFBWSxDQUFDLE9BQU8sRUFBRTtZQUN0QixjQUFjO1lBQ2QsYUFBYTtZQUNiLG1CQUFtQixFQVNuQixZQUFZOzs0RkFPSCxvQkFBb0I7a0JBeEJoQyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsZUFBZTt3QkFDZixZQUFZLENBQUMsT0FBTyxFQUFFO3dCQUN0QixjQUFjO3dCQUNkLGFBQWE7d0JBQ2IsbUJBQW1CO3FCQUNwQjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1osYUFBYTt3QkFDYixvQkFBb0I7d0JBQ3BCLHFCQUFxQjt3QkFDckIsbUJBQW1CO3FCQUNwQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3dCQUNiLHFCQUFxQjt3QkFDckIsbUJBQW1CO3FCQUNwQjtvQkFDRCxTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7IFdlYmNhbU1vZHVsZSB9IGZyb20gJy4vd2ViY2FtL3dlYmNhbS5tb2R1bGUnO1xuaW1wb3J0IHsgU2NhbkNvbXBvbmVudCB9IGZyb20gJy4vc2Nhbi9zY2FuLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRlcmlhbE1vZHVsZSB9IGZyb20gJy4uL3NoYXJlZC9tYXRlcmlhbC5tb2R1bGUnO1xuaW1wb3J0IHsgQXBwRm9ybU1vZHVsZSB9IGZyb20gJy4uLy4uL2Zvcm1zL2Zvcm0ubW9kdWxlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQgeyBDYW1lcmFTd2l0Y2hDb21wb25lbnQgfSBmcm9tICcuL2NhbWVyYS1zd2l0Y2gvY2FtZXJhLXN3aXRjaC5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2NhblJlc3VsdHNDb21wb25lbnQgfSBmcm9tICcuL3NjYW4tcmVzdWx0cy9zY2FuLXJlc3VsdHMuY29tcG9uZW50JztcbmltcG9ydCB7IE1hbnVhbFNjYW5Db21wb25lbnQgfSBmcm9tICcuL21hbnVhbC1zY2FuL21hbnVhbC1zY2FuLmNvbXBvbmVudCc7XG4vL2ltcG9ydCB7IE5neFNjYW5kb2NDYW1lcmFQcm92aWRlciB9IGZyb20gJy4uLy4uL3Byb3ZpZGVycy9jYW1lcmEucHJvdmlkZXInO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgICBXZWJjYW1Nb2R1bGUuZm9yUm9vdCgpLFxuICAgIE1hdGVyaWFsTW9kdWxlLFxuICAgIEFwcEZvcm1Nb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgU2NhbkNvbXBvbmVudCxcbiAgICBTY2FuUmVzdWx0c0NvbXBvbmVudCxcbiAgICBDYW1lcmFTd2l0Y2hDb21wb25lbnQsXG4gICAgTWFudWFsU2NhbkNvbXBvbmVudCxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIFdlYmNhbU1vZHVsZSxcbiAgICBTY2FuQ29tcG9uZW50LFxuICAgIENhbWVyYVN3aXRjaENvbXBvbmVudCxcbiAgICBNYW51YWxTY2FuQ29tcG9uZW50LFxuICBdLFxuICBwcm92aWRlcnM6IFtdLFxufSlcbmV4cG9ydCBjbGFzcyBDb3JlQ29tcG9uZW50c01vZHVsZSB7XG4gIHN0YXRpYyBmb3JSb290KCk6IE1vZHVsZVdpdGhQcm92aWRlcnM8Q29yZUNvbXBvbmVudHNNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IENvcmVDb21wb25lbnRzTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXSxcbiAgICB9O1xuICB9XG59XG4iXX0=
|