speechrecorderng 3.10.13 → 3.11.0

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.
Files changed (99) hide show
  1. package/README.md +1 -1
  2. package/fesm2022/speechrecorderng.mjs +204 -201
  3. package/fesm2022/speechrecorderng.mjs.map +1 -1
  4. package/lib/audio/ui/audio_canvas_layer_comp.d.ts +2 -2
  5. package/lib/spr.module.version.d.ts +1 -1
  6. package/lib/ui/canvas_layer_comp.d.ts +1 -1
  7. package/lib/ui/responsive_component.d.ts +1 -1
  8. package/package.json +13 -15
  9. package/esm2022/lib/action/action.mjs +0 -73
  10. package/esm2022/lib/audio/array_audio_buffer.mjs +0 -164
  11. package/esm2022/lib/audio/array_audio_buffer_input_stream.mjs +0 -86
  12. package/esm2022/lib/audio/array_audio_buffer_random_access_stream.mjs +0 -16
  13. package/esm2022/lib/audio/audio_data_holder.mjs +0 -264
  14. package/esm2022/lib/audio/audio_display.mjs +0 -118
  15. package/esm2022/lib/audio/audio_player.mjs +0 -238
  16. package/esm2022/lib/audio/capture/capture.mjs +0 -855
  17. package/esm2022/lib/audio/context.mjs +0 -79
  18. package/esm2022/lib/audio/dsp/level_measure.mjs +0 -517
  19. package/esm2022/lib/audio/format.mjs +0 -20
  20. package/esm2022/lib/audio/impl/wavformat.mjs +0 -7
  21. package/esm2022/lib/audio/impl/wavreader.mjs +0 -144
  22. package/esm2022/lib/audio/impl/wavwriter.mjs +0 -191
  23. package/esm2022/lib/audio/inddb_audio_buffer.mjs +0 -508
  24. package/esm2022/lib/audio/io/stream.mjs +0 -59
  25. package/esm2022/lib/audio/net_audio_buffer.mjs +0 -293
  26. package/esm2022/lib/audio/persistor.mjs +0 -81
  27. package/esm2022/lib/audio/playback/array_audio_buffer_source_node.mjs +0 -126
  28. package/esm2022/lib/audio/playback/audio_source_node.mjs +0 -18
  29. package/esm2022/lib/audio/playback/audio_source_worklet_module_loader.mjs +0 -167
  30. package/esm2022/lib/audio/playback/inddb_audio_buffer_source_node.mjs +0 -167
  31. package/esm2022/lib/audio/playback/net_audio_buffer_source_node.mjs +0 -218
  32. package/esm2022/lib/audio/playback/player.mjs +0 -402
  33. package/esm2022/lib/audio/ui/audio_canvas_layer_comp.mjs +0 -347
  34. package/esm2022/lib/audio/ui/audio_display_control.mjs +0 -150
  35. package/esm2022/lib/audio/ui/audio_display_scroll_pane.mjs +0 -146
  36. package/esm2022/lib/audio/ui/audiosignal.mjs +0 -533
  37. package/esm2022/lib/audio/ui/common.mjs +0 -19
  38. package/esm2022/lib/audio/ui/container.mjs +0 -414
  39. package/esm2022/lib/audio/ui/livelevel.mjs +0 -361
  40. package/esm2022/lib/audio/ui/scroll_pane_horizontal.mjs +0 -11
  41. package/esm2022/lib/audio/ui/sonagram.mjs +0 -900
  42. package/esm2022/lib/db/inddb.mjs +0 -120
  43. package/esm2022/lib/dsp/utils.mjs +0 -48
  44. package/esm2022/lib/environment/environment.defaults.mjs +0 -9
  45. package/esm2022/lib/io/BinaryReader.mjs +0 -93
  46. package/esm2022/lib/io/BinaryWriter.mjs +0 -80
  47. package/esm2022/lib/io/stream.mjs +0 -259
  48. package/esm2022/lib/math/2d/geometry.mjs +0 -28
  49. package/esm2022/lib/math/complex.mjs +0 -58
  50. package/esm2022/lib/math/dft.mjs +0 -196
  51. package/esm2022/lib/media/utils.mjs +0 -14
  52. package/esm2022/lib/net/uploader.mjs +0 -367
  53. package/esm2022/lib/recorder_component.mjs +0 -65
  54. package/esm2022/lib/speechrecorder/project/project.mjs +0 -54
  55. package/esm2022/lib/speechrecorder/project/project.service.mjs +0 -64
  56. package/esm2022/lib/speechrecorder/recording.mjs +0 -124
  57. package/esm2022/lib/speechrecorder/recordings/basic_recording.service.mjs +0 -221
  58. package/esm2022/lib/speechrecorder/recordings/recordings.service.mjs +0 -1014
  59. package/esm2022/lib/speechrecorder/script/script.mjs +0 -114
  60. package/esm2022/lib/speechrecorder/script/script.service.mjs +0 -47
  61. package/esm2022/lib/speechrecorder/session/audiorecorder.mjs +0 -1179
  62. package/esm2022/lib/speechrecorder/session/basicrecorder.mjs +0 -676
  63. package/esm2022/lib/speechrecorder/session/controlpanel.mjs +0 -416
  64. package/esm2022/lib/speechrecorder/session/item.mjs +0 -30
  65. package/esm2022/lib/speechrecorder/session/progress.mjs +0 -135
  66. package/esm2022/lib/speechrecorder/session/prompting.mjs +0 -639
  67. package/esm2022/lib/speechrecorder/session/recorder_combi_pane.mjs +0 -88
  68. package/esm2022/lib/speechrecorder/session/recording_file_cache.mjs +0 -195
  69. package/esm2022/lib/speechrecorder/session/recording_list.mjs +0 -188
  70. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +0 -128
  71. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-navi.component.mjs +0 -114
  72. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +0 -146
  73. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +0 -424
  74. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file.mjs +0 -68
  75. package/esm2022/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +0 -288
  76. package/esm2022/lib/speechrecorder/session/session.mjs +0 -2
  77. package/esm2022/lib/speechrecorder/session/session.service.mjs +0 -69
  78. package/esm2022/lib/speechrecorder/session/session_finished_dialog.mjs +0 -46
  79. package/esm2022/lib/speechrecorder/session/sessionmanager.mjs +0 -1385
  80. package/esm2022/lib/speechrecorder/session/warning_bar.mjs +0 -33
  81. package/esm2022/lib/speechrecorder/spruploader.mjs +0 -22
  82. package/esm2022/lib/speechrecorder/startstopsignal/startstopsignal.mjs +0 -2
  83. package/esm2022/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.mjs +0 -57
  84. package/esm2022/lib/speechrecorderng.component.mjs +0 -392
  85. package/esm2022/lib/speechrecorderng.module.mjs +0 -97
  86. package/esm2022/lib/spr.config.mjs +0 -27
  87. package/esm2022/lib/spr.module.version.mjs +0 -2
  88. package/esm2022/lib/ui/canvas_layer_comp.mjs +0 -38
  89. package/esm2022/lib/ui/intersection-observer.directive.mjs +0 -32
  90. package/esm2022/lib/ui/message_dialog.mjs +0 -51
  91. package/esm2022/lib/ui/recordingitem_display.mjs +0 -253
  92. package/esm2022/lib/ui/responsive_component.mjs +0 -24
  93. package/esm2022/lib/utils/scrollIntoViewToBottom.mjs +0 -23
  94. package/esm2022/lib/utils/ua-parser.mjs +0 -190
  95. package/esm2022/lib/utils/utils.mjs +0 -132
  96. package/esm2022/lib/utils/wake_lock.mjs +0 -114
  97. package/esm2022/lib/utils/wake_lock_media.mjs +0 -2
  98. package/esm2022/public-api.mjs +0 -35
  99. package/esm2022/speechrecorderng.mjs +0 -5
@@ -1,347 +0,0 @@
1
- import { CanvasLayerComponent } from "../../ui/canvas_layer_comp";
2
- import { Selection } from '../persistor';
3
- import { EventEmitter, HostListener, Input, Output, ViewChild, Directive } from "@angular/core";
4
- import { Marker } from "./common";
5
- import * as i0 from "@angular/core";
6
- export class ViewSelection {
7
- get startX() {
8
- return this._startX;
9
- }
10
- get endX() {
11
- return this._endX;
12
- }
13
- width() {
14
- return this._endX - this._startX;
15
- }
16
- constructor(_startX, _endX) {
17
- this._startX = _startX;
18
- this._endX = _endX;
19
- }
20
- }
21
- export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
22
- constructor() {
23
- super(...arguments);
24
- this._audioDataHolder = null;
25
- this._bgColor = 'white';
26
- this._selectColor = 'rgba(0%,0%,100%,25%)';
27
- }
28
- /**
29
- * Returns pixel position depending on current zoom setting.
30
- * @param framePos audio frame (sample) position
31
- */
32
- frameToXPixelPosition(framePos) {
33
- let pixelPos = null;
34
- let frameLength = this._audioDataHolder?.frameLen;
35
- if (frameLength !== undefined) {
36
- let vw;
37
- if (this.bounds) {
38
- vw = this.bounds.dimension.width;
39
- }
40
- if (this.virtualDimension) {
41
- vw = this.virtualDimension.width;
42
- }
43
- if (vw !== undefined) {
44
- pixelPos = framePos * vw / frameLength;
45
- }
46
- }
47
- return pixelPos;
48
- }
49
- /**
50
- * Returns pixel position in view port (visible window of scroll pane).
51
- * @param framePos audio frame (sample) position
52
- */
53
- frameToViewPortXPixelPosition(framePos) {
54
- let pixelPos = this.frameToXPixelPosition(framePos);
55
- if (pixelPos != null) {
56
- return this.toXViewPortPixelPosition(pixelPos);
57
- }
58
- else {
59
- return null;
60
- }
61
- }
62
- viewPortXPixelToFramePosition(xViewPortPixelPos) {
63
- let vpXframePos = null;
64
- const frameLength = this._audioDataHolder?.frameLen;
65
- if (frameLength !== undefined) {
66
- let vw = undefined;
67
- if (this.bounds) {
68
- vw = this.bounds.dimension.width;
69
- }
70
- if (this.virtualDimension) {
71
- vw = this.virtualDimension.width;
72
- }
73
- if (vw !== undefined) {
74
- const xVirtualPixelPos = this.toXVirtualPixelPosition(xViewPortPixelPos);
75
- const framesPerPixel = frameLength / vw;
76
- let framePos = framesPerPixel * xVirtualPixelPos;
77
- if (framePos < 0) {
78
- framePos = 0;
79
- }
80
- if (framePos >= frameLength) {
81
- framePos = frameLength - 1;
82
- }
83
- vpXframePos = Math.round(framePos);
84
- }
85
- }
86
- return vpXframePos;
87
- }
88
- layoutBounds(bounds, virtualDimension, redraw) {
89
- this.bounds = bounds;
90
- this.virtualDimension = virtualDimension;
91
- for (let ci = 0; ci < this.canvasLayers.length; ci++) {
92
- const cl = this.canvasLayers[ci];
93
- const leftStyle = bounds.position.left + 'px';
94
- if (cl.style.left != leftStyle) {
95
- cl.style.left = leftStyle;
96
- }
97
- const topStyle = bounds.position.top + 'px';
98
- if (cl.style.top != topStyle) {
99
- cl.style.top = topStyle;
100
- }
101
- }
102
- if (bounds.dimension.width) {
103
- const intW = Math.floor(bounds.dimension.width);
104
- if (redraw) {
105
- // Do not set width of background canvas (causes flicker on start render)
106
- for (let ci = 1; ci < this.canvasLayers.length; ci++) {
107
- let cl = this.canvasLayers[ci];
108
- if (cl.width != intW) {
109
- cl.width = intW;
110
- }
111
- }
112
- }
113
- const wStr = intW.toString() + 'px';
114
- for (let ci = 0; ci < this.canvasLayers.length; ci++) {
115
- let cl = this.canvasLayers[ci];
116
- if (cl.style.width != wStr) {
117
- cl.style.width = wStr;
118
- }
119
- }
120
- }
121
- if (bounds.dimension.height) {
122
- const intH = Math.floor(bounds.dimension.height);
123
- if (redraw) {
124
- // Do not set height of background canvas (causes flicker on start render)
125
- for (let ci = 1; ci < this.canvasLayers.length; ci++) {
126
- let cl = this.canvasLayers[ci];
127
- if (cl.height != intH) {
128
- cl.height = intH;
129
- }
130
- }
131
- }
132
- const hStr = intH + 'px';
133
- for (let ci = 0; ci < this.canvasLayers.length; ci++) {
134
- let cl = this.canvasLayers[ci];
135
- if (cl.style.height != hStr) {
136
- cl.style.height = hStr;
137
- }
138
- }
139
- }
140
- }
141
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BasicAudioCanvasLayerComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
142
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.12", type: BasicAudioCanvasLayerComponent, usesInheritance: true, ngImport: i0 }); }
143
- }
144
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BasicAudioCanvasLayerComponent, decorators: [{
145
- type: Directive
146
- }] });
147
- export class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {
148
- constructor() {
149
- super(...arguments);
150
- this._pointerPosition = null;
151
- this.selectStartX = null;
152
- this._selecting = null;
153
- this._selection = null;
154
- this.pointerPositionEventEmitter = new EventEmitter();
155
- this.selectingEventEmitter = new EventEmitter();
156
- this.selectedEventEmitter = new EventEmitter();
157
- }
158
- static { this.ENABLE_STREAMING_NUMBER_OF_SAMPLES_THRESHOLD = 10 * 60 * 48000; } // Use streaming/chunking if audio clip has more than this number of samples
159
- onMouseup(me) {
160
- this.selectionCommit(me);
161
- }
162
- layoutBounds(bounds, virtualDimension, redraw, clear = true) {
163
- super.layoutBounds(bounds, virtualDimension, redraw);
164
- if (redraw) {
165
- this.startDraw(clear);
166
- }
167
- }
168
- set pointerPosition(pointerPosition) {
169
- this._pointerPosition = pointerPosition;
170
- this.drawCursorLayer();
171
- }
172
- set selecting(selecting) {
173
- this._selecting = selecting;
174
- this.drawBg();
175
- this.drawCursorLayer();
176
- }
177
- get selecting() {
178
- return this._selecting;
179
- }
180
- set selection(selection) {
181
- this._selection = selection;
182
- this.selecting = null;
183
- this.drawBg();
184
- this.drawCursorLayer();
185
- }
186
- get selection() {
187
- return this._selection;
188
- }
189
- selectionStart(me) {
190
- this.selectStartX = me.offsetX;
191
- }
192
- selectionCommit(me) {
193
- let vs = null;
194
- if (this.selectStartX != null) {
195
- vs = new ViewSelection(this.selectStartX, me.offsetX);
196
- this.selectStartX = null;
197
- this.select(vs);
198
- }
199
- }
200
- updateCursorCanvas(me, showCursorPosition = true) {
201
- if (this.cursorCanvas) {
202
- if (me) {
203
- if (this.selectStartX) {
204
- this.pointerPositionChanged(null);
205
- this.selectingChange(new ViewSelection(this.selectStartX, me.offsetX));
206
- }
207
- else {
208
- if (showCursorPosition) {
209
- this.pointerPositionChanged(me.offsetX);
210
- }
211
- else {
212
- this.pointerPositionChanged(null);
213
- }
214
- }
215
- }
216
- }
217
- }
218
- pointerPositionChanged(xPosition) {
219
- let pointerPosition = undefined;
220
- if (xPosition) {
221
- pointerPosition = new Marker();
222
- let vpXPos = this.viewPortXPixelToFramePosition(xPosition);
223
- if (vpXPos != null) {
224
- pointerPosition.framePosition = vpXPos;
225
- }
226
- }
227
- this.pointerPositionEventEmitter.emit(pointerPosition);
228
- }
229
- _selectingChange(viewSel) {
230
- let ns = undefined;
231
- if (viewSel) {
232
- let frameStart = this.viewPortXPixelToFramePosition(viewSel.startX);
233
- let frameEnd = this.viewPortXPixelToFramePosition(viewSel.endX);
234
- if (this._audioDataHolder && frameStart != null && frameEnd != null) {
235
- ns = new Selection(this._audioDataHolder.sampleRate, frameStart, frameEnd);
236
- }
237
- }
238
- return ns;
239
- }
240
- selectingChange(viewSel) {
241
- const ns = this._selectingChange(viewSel);
242
- this.selectingEventEmitter.emit(ns);
243
- }
244
- select(viewSel) {
245
- const ns = this._selectingChange(viewSel);
246
- this.selectedEventEmitter.emit(ns);
247
- }
248
- viewSelection() {
249
- let vs = null;
250
- let s = null;
251
- if (this._selecting) {
252
- s = this._selecting;
253
- }
254
- else if (this._selection) {
255
- s = this._selection;
256
- }
257
- if (s) {
258
- const sf = s.startFrame;
259
- const ef = s.endFrame;
260
- const xs = this.frameToViewPortXPixelPosition(sf);
261
- const xe = this.frameToViewPortXPixelPosition(ef);
262
- if (xs != null && xe != null) {
263
- vs = new ViewSelection(xs, xe);
264
- }
265
- }
266
- return vs;
267
- }
268
- drawBg() {
269
- if (this.bgCanvas && this.bounds) {
270
- this.bgCanvas.style.left = Math.round(this.bounds.position.left).toString() + 'px';
271
- this.bgCanvas.width = Math.round(this.bounds.dimension.width);
272
- this.bgCanvas.height = Math.round(this.bounds.dimension.height);
273
- let g1 = this.bgCanvas.getContext("2d");
274
- if (g1) {
275
- const w = this.bgCanvas.width;
276
- const h = this.bgCanvas.height;
277
- g1.clearRect(0, 0, w, h);
278
- if (this._bgColor) {
279
- g1.fillStyle = this._bgColor;
280
- g1.fillRect(0, 0, w, h);
281
- }
282
- let vs = this.viewSelection();
283
- if (vs) {
284
- g1.fillStyle = this._selectColor;
285
- g1.fillRect(vs.startX, 0, vs.width(), h);
286
- }
287
- }
288
- }
289
- }
290
- drawCursorLayer() {
291
- if (this.cursorCanvas) {
292
- const w = this.cursorCanvas.width;
293
- const h = this.cursorCanvas.height;
294
- const g = this.cursorCanvas.getContext("2d");
295
- if (g) {
296
- g.clearRect(0, 0, w, h);
297
- if (this._pointerPosition) {
298
- let framePos = this._pointerPosition.framePosition;
299
- if (framePos) {
300
- let xViewPortPixelpos = this.frameToViewPortXPixelPosition(framePos);
301
- if (xViewPortPixelpos) {
302
- g.fillStyle = 'yellow';
303
- g.strokeStyle = 'yellow';
304
- g.beginPath();
305
- g.moveTo(xViewPortPixelpos, 0);
306
- g.lineTo(xViewPortPixelpos, h);
307
- g.closePath();
308
- g.stroke();
309
- if (this._audioDataHolder) {
310
- g.font = '14px sans-serif';
311
- g.fillStyle = 'yellow';
312
- g.fillText(framePos.toString(), xViewPortPixelpos + 2, 50);
313
- }
314
- }
315
- }
316
- }
317
- }
318
- }
319
- }
320
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: AudioCanvasLayerComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
321
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.12", type: AudioCanvasLayerComponent, inputs: { pointerPosition: "pointerPosition", selecting: "selecting", selection: "selection" }, outputs: { pointerPositionEventEmitter: "pointerPositionEventEmitter", selectingEventEmitter: "selectingEventEmitter", selectedEventEmitter: "selectedEventEmitter" }, host: { listeners: { "document:mouseup": "onMouseup($event)" } }, viewQueries: [{ propertyName: "bgCanvasRef", first: true, predicate: ["bg"], descendants: true, static: true }, { propertyName: "cursorCanvasRef", first: true, predicate: ["cursor"], descendants: true, static: true }], usesInheritance: true, ngImport: i0 }); }
322
- }
323
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: AudioCanvasLayerComponent, decorators: [{
324
- type: Directive
325
- }], propDecorators: { bgCanvasRef: [{
326
- type: ViewChild,
327
- args: ['bg', { static: true }]
328
- }], cursorCanvasRef: [{
329
- type: ViewChild,
330
- args: ['cursor', { static: true }]
331
- }], onMouseup: [{
332
- type: HostListener,
333
- args: ['document:mouseup', ['$event']]
334
- }], pointerPosition: [{
335
- type: Input
336
- }], selecting: [{
337
- type: Input
338
- }], selection: [{
339
- type: Input
340
- }], pointerPositionEventEmitter: [{
341
- type: Output
342
- }], selectingEventEmitter: [{
343
- type: Output
344
- }], selectedEventEmitter: [{
345
- type: Output
346
- }] } });
347
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audio_canvas_layer_comp.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/ui/audio_canvas_layer_comp.ts"],"names":[],"mappings":"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","sourcesContent":["import {CanvasLayerComponent} from \"../../ui/canvas_layer_comp\";\r\nimport {Selection} from '../persistor'\r\nimport { ElementRef, EventEmitter, HostListener, Input, Output, ViewChild, Directive } from \"@angular/core\";\r\nimport {Marker} from \"./common\";\r\nimport {Dimension, Rectangle} from \"../../math/2d/geometry\";\r\nimport {AudioDataHolder} from \"../audio_data_holder\";\r\n\r\n\r\nexport class ViewSelection{\r\n  get startX(): number {\r\n    return this._startX;\r\n  }\r\n\r\n  get endX(): number {\r\n    return this._endX;\r\n  }\r\n\r\n  width():number{\r\n    return this._endX-this._startX\r\n  }\r\n\r\n  constructor(private _startX:number, private _endX:number){}\r\n}\r\n\r\n@Directive()\r\nexport abstract class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {\r\n  protected _audioDataHolder:AudioDataHolder| null=null;\r\n  protected _bgColor:string|null='white';\r\n  protected _selectColor='rgba(0%,0%,100%,25%)';\r\n\r\n  /**\r\n   * Returns pixel position depending on current zoom setting.\r\n   * @param framePos audio frame (sample) position\r\n   */\r\n  frameToXPixelPosition(framePos: number): number | null {\r\n    let pixelPos=null;\r\n    let frameLength = this._audioDataHolder?.frameLen;\r\n\r\n    if(frameLength!==undefined) {\r\n      let vw;\r\n      if (this.bounds) {\r\n        vw = this.bounds.dimension.width;\r\n      }\r\n      if (this.virtualDimension) {\r\n        vw = this.virtualDimension.width;\r\n      }\r\n      if (vw !== undefined) {\r\n        pixelPos = framePos * vw / frameLength;\r\n      }\r\n    }\r\n    return pixelPos;\r\n  }\r\n\r\n  /**\r\n   * Returns pixel position in view port (visible window of scroll pane).\r\n   * @param framePos audio frame (sample) position\r\n   */\r\n  frameToViewPortXPixelPosition(framePos: number): number | null {\r\n    let pixelPos=this.frameToXPixelPosition(framePos);\r\n    if(pixelPos!=null){\r\n      return this.toXViewPortPixelPosition(pixelPos);\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n\r\n  viewPortXPixelToFramePosition(xViewPortPixelPos: number): number | null {\r\n    let vpXframePos=null;\r\n    const frameLength = this._audioDataHolder?.frameLen;\r\n    if(frameLength!==undefined) {\r\n      let vw:number|undefined=undefined;\r\n      if (this.bounds) {\r\n        vw= this.bounds.dimension.width;\r\n      }\r\n      if (this.virtualDimension) {\r\n        vw = this.virtualDimension.width;\r\n      }\r\n      if(vw!== undefined) {\r\n        const xVirtualPixelPos = this.toXVirtualPixelPosition(xViewPortPixelPos)\r\n        const framesPerPixel = frameLength / vw;\r\n        let framePos = framesPerPixel * xVirtualPixelPos;\r\n        if (framePos < 0) {\r\n          framePos = 0\r\n        }\r\n        if (framePos >= frameLength) {\r\n          framePos = frameLength - 1\r\n        }\r\n        vpXframePos = Math.round(framePos);\r\n      }\r\n    }\r\n    return vpXframePos;\r\n  }\r\n\r\n    layoutBounds(bounds:Rectangle, virtualDimension:Dimension,redraw: boolean) {\r\n        this.bounds=bounds;\r\n        this.virtualDimension=virtualDimension;\r\n        for(let ci=0;ci<this.canvasLayers.length;ci++) {\r\n            const cl = this.canvasLayers[ci];\r\n            const leftStyle=bounds.position.left+ 'px';\r\n            if(cl.style.left!=leftStyle) {\r\n              cl.style.left = leftStyle;\r\n            }\r\n            const topStyle=bounds.position.top + 'px';\r\n            if(cl.style.top!=topStyle) {\r\n              cl.style.top = topStyle;\r\n            }\r\n        }\r\n        if (bounds.dimension.width) {\r\n            const intW=Math.floor(bounds.dimension.width);\r\n            if (redraw) {\r\n                // Do not set width of background canvas (causes flicker on start render)\r\n                for(let ci=1;ci<this.canvasLayers.length;ci++) {\r\n                    let cl = this.canvasLayers[ci];\r\n                    if(cl.width!=intW) {\r\n                      cl.width = intW;\r\n                    }\r\n                }\r\n            }\r\n            const wStr = intW.toString() + 'px';\r\n            for(let ci=0;ci<this.canvasLayers.length;ci++) {\r\n                let cl = this.canvasLayers[ci];\r\n                if(cl.style.width!=wStr) {\r\n                  cl.style.width = wStr;\r\n                }\r\n            }\r\n        }\r\n        if (bounds.dimension.height) {\r\n            const intH=Math.floor(bounds.dimension.height)\r\n            if (redraw) {\r\n                // Do not set height of background canvas (causes flicker on start render)\r\n                for(let ci=1;ci<this.canvasLayers.length;ci++) {\r\n                    let cl = this.canvasLayers[ci];\r\n                    if(cl.height!=intH) {\r\n                      cl.height = intH;\r\n                    }\r\n                }\r\n            }\r\n            const hStr = intH + 'px';\r\n            for(let ci=0;ci<this.canvasLayers.length;ci++) {\r\n                let cl = this.canvasLayers[ci];\r\n                if(cl.style.height!=hStr){\r\n                  cl.style.height = hStr;\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n\r\n@Directive()\r\nexport abstract class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {\r\n\r\n    protected static readonly ENABLE_STREAMING_NUMBER_OF_SAMPLES_THRESHOLD=10*60*48000;  // Use streaming/chunking if audio clip has more than this number of samples\r\n\r\n    _pointerPosition:Marker|null=null;\r\n\r\n    protected selectStartX:number|null=null;\r\n\r\n    @ViewChild('bg', { static: true }) bgCanvasRef!: ElementRef;\r\n    bgCanvas!: HTMLCanvasElement;\r\n\r\n    @ViewChild('cursor', { static: true }) cursorCanvasRef!: ElementRef;\r\n    cursorCanvas!: HTMLCanvasElement;\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  onMouseup(me: MouseEvent) {\r\n    this.selectionCommit(me)\r\n  }\r\n\r\n    layoutBounds(bounds:Rectangle, virtualDimension:Dimension,redraw: boolean,clear:boolean=true) {\r\n        super.layoutBounds(bounds,virtualDimension,redraw)\r\n        if (redraw) {\r\n            this.startDraw(clear);\r\n        }\r\n    }\r\n\r\n    @Input() set pointerPosition(pointerPosition:Marker|null){\r\n        this._pointerPosition=pointerPosition\r\n        this.drawCursorLayer()\r\n    }\r\n\r\n    _selecting: Selection|null =null;\r\n    @Input() set selecting(selecting:Selection| null){\r\n        this._selecting=selecting\r\n        this.drawBg()\r\n        this.drawCursorLayer()\r\n    }\r\n\r\n    get selecting():Selection|null{\r\n        return this._selecting\r\n    }\r\n\r\n    _selection: Selection|null =null\r\n    @Input() set selection(selection:Selection|null){\r\n        this._selection=selection;\r\n        this.selecting=null;\r\n        this.drawBg()\r\n        this.drawCursorLayer()\r\n    }\r\n\r\n    get selection():Selection|null{\r\n        return this._selection\r\n    }\r\n\r\n    selectionStart(me:MouseEvent){\r\n        this.selectStartX=me.offsetX;\r\n    }\r\n\r\n    selectionCommit(me:MouseEvent){\r\n        let vs:ViewSelection|null=null;\r\n        if(this.selectStartX!=null) {\r\n          vs=new ViewSelection(this.selectStartX,me.offsetX)\r\n          this.selectStartX=null;\r\n          this.select(vs);\r\n        }\r\n    }\r\n\r\n    abstract startDraw(clear:boolean):void;\r\n\r\n    updateCursorCanvas(me:MouseEvent,showCursorPosition=true){\r\n        if (this.cursorCanvas) {\r\n            if (me) {\r\n                if (this.selectStartX) {\r\n                    this.pointerPositionChanged(null)\r\n                    this.selectingChange(new ViewSelection(this.selectStartX, me.offsetX));\r\n                } else {\r\n                    if (showCursorPosition) {\r\n                        this.pointerPositionChanged(me.offsetX)\r\n                    }else{\r\n                        this.pointerPositionChanged(null)\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    @Output() pointerPositionEventEmitter = new EventEmitter<Marker>();\r\n    @Output() selectingEventEmitter = new EventEmitter<Selection>();\r\n    @Output() selectedEventEmitter = new EventEmitter<Selection>();\r\n\r\n\r\n    pointerPositionChanged(xPosition:number| null){\r\n        let pointerPosition:Marker|undefined=undefined;\r\n        if(xPosition){\r\n            pointerPosition=new Marker();\r\n            let vpXPos=this.viewPortXPixelToFramePosition(xPosition);\r\n            if(vpXPos!=null) {\r\n                pointerPosition.framePosition =vpXPos;\r\n            }\r\n        }\r\n        this.pointerPositionEventEmitter.emit(pointerPosition);\r\n    }\r\n\r\n    private _selectingChange(viewSel:ViewSelection| null):Selection|undefined {\r\n      let ns: Selection | undefined = undefined;\r\n      if (viewSel) {\r\n        let frameStart = this.viewPortXPixelToFramePosition(viewSel.startX)\r\n        let frameEnd = this.viewPortXPixelToFramePosition(viewSel.endX)\r\n        if (this._audioDataHolder && frameStart != null && frameEnd != null) {\r\n          ns = new Selection(this._audioDataHolder.sampleRate, frameStart, frameEnd);\r\n        }\r\n      }\r\n      return ns;\r\n    }\r\n\r\n    selectingChange(viewSel:ViewSelection| null){\r\n        const ns=this._selectingChange(viewSel);\r\n        this.selectingEventEmitter.emit(ns)\r\n    }\r\n\r\n    select(viewSel:ViewSelection| null){\r\n        const ns=this._selectingChange(viewSel);\r\n        this.selectedEventEmitter.emit(ns)\r\n    }\r\n\r\n    viewSelection():ViewSelection|null{\r\n      let vs:ViewSelection|null=null;\r\n      let s:Selection|null=null;\r\n      if(this._selecting){\r\n        s=this._selecting\r\n      }else if(this._selection){\r\n        s=this._selection\r\n      }\r\n      if(s){\r\n        const sf=s.startFrame;\r\n        const ef=s.endFrame;\r\n        const xs=this.frameToViewPortXPixelPosition(sf)\r\n        const xe=this.frameToViewPortXPixelPosition(ef)\r\n          if(xs!=null && xe!=null) {\r\n              vs = new ViewSelection(xs, xe)\r\n          }\r\n      }\r\n      return vs;\r\n    }\r\n\r\n\r\n  drawBg(){\r\n      if(this.bgCanvas && this.bounds) {\r\n          this.bgCanvas.style.left = Math.round(this.bounds.position.left).toString() + 'px';\r\n          this.bgCanvas.width = Math.round(this.bounds.dimension.width);\r\n          this.bgCanvas.height = Math.round(this.bounds.dimension.height);\r\n        let g1 = this.bgCanvas.getContext(\"2d\");\r\n        if (g1) {\r\n          const w = this.bgCanvas.width;\r\n          const h = this.bgCanvas.height;\r\n          g1.clearRect(0, 0, w, h);\r\n          if(this._bgColor) {\r\n            g1.fillStyle = this._bgColor;\r\n            g1.fillRect(0, 0, w, h);\r\n          }\r\n          let vs = this.viewSelection()\r\n          if (vs) {\r\n            g1.fillStyle = this._selectColor;\r\n            g1.fillRect(vs.startX, 0, vs.width(), h);\r\n          }\r\n        }\r\n      }\r\n  }\r\n    drawCursorLayer(){\r\n        if (this.cursorCanvas) {\r\n            const w = this.cursorCanvas.width;\r\n            const h = this.cursorCanvas.height;\r\n            const g = this.cursorCanvas.getContext(\"2d\");\r\n            if(g) {\r\n                g.clearRect(0, 0, w, h);\r\n                if(this._pointerPosition){\r\n                    let framePos=this._pointerPosition.framePosition\r\n                    if(framePos) {\r\n                        let xViewPortPixelpos = this.frameToViewPortXPixelPosition(framePos)\r\n                        if (xViewPortPixelpos) {\r\n\r\n                            g.fillStyle = 'yellow';\r\n                            g.strokeStyle = 'yellow';\r\n                            g.beginPath();\r\n                            g.moveTo(xViewPortPixelpos, 0);\r\n                            g.lineTo(xViewPortPixelpos, h);\r\n                            g.closePath();\r\n\r\n                            g.stroke();\r\n\r\n                            if (this._audioDataHolder) {\r\n                                g.font = '14px sans-serif';\r\n                                g.fillStyle = 'yellow';\r\n                                g.fillText(framePos.toString(), xViewPortPixelpos + 2, 50);\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n}\r\n\r\n\r\n\r\n"]}
@@ -1,150 +0,0 @@
1
- import { Component, Input, ViewChild } from '@angular/core';
2
- import { MatCheckbox } from "@angular/material/checkbox";
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/common";
5
- import * as i2 from "@angular/material/icon";
6
- import * as i3 from "@angular/material/tooltip";
7
- import * as i4 from "@angular/material/checkbox";
8
- export class AudioDisplayControl {
9
- constructor() {
10
- this.audioClip = null;
11
- this.autoplaySelectedCheckbox = null;
12
- this.zoomInAction = null;
13
- this.zoomOutAction = null;
14
- this.status = null;
15
- }
16
- clearSelection() {
17
- if (this.audioClip != null) {
18
- this.audioClip.selection = null;
19
- }
20
- }
21
- hasSelection() {
22
- let hs = false;
23
- if (this.audioClip) {
24
- hs = (this.audioClip.selection != null);
25
- }
26
- return hs;
27
- }
28
- autoPlaySelectionChange(ch) {
29
- if (this.autoPlayOnSelectToggleAction) {
30
- this.autoPlayOnSelectToggleAction.perform(ch.checked);
31
- }
32
- }
33
- error() {
34
- this.status = 'ERROR';
35
- }
36
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: AudioDisplayControl, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
37
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: AudioDisplayControl, selector: "audio-display-control", inputs: { audioClip: "audioClip", playStartAction: "playStartAction", playSelectionAction: "playSelectionAction", playStopAction: "playStopAction", zoomInAction: "zoomInAction", zoomOutAction: "zoomOutAction", zoomFitToPanelAction: "zoomFitToPanelAction", zoomSelectedAction: "zoomSelectedAction", autoPlayOnSelectToggleAction: "autoPlayOnSelectToggleAction" }, viewQueries: [{ propertyName: "autoplaySelectedCheckbox", first: true, predicate: MatCheckbox, descendants: true, static: true }], ngImport: i0, template: `
38
- <div #controlPanel style="display:flex;flex-direction: row;">
39
- <fieldset>
40
-
41
- <legend>Play</legend>
42
-
43
- <button (click)="playStartAction?.perform()" [disabled]="playStartAction?.disabled"
44
- [style.color]="playStartAction?.disabled ? 'grey' : 'green'" matTooltip="Play all">
45
- <mat-icon>play_arrow</mat-icon>
46
- </button>
47
- <button (click)="playSelectionAction?.perform()" [disabled]="playSelectionAction?.disabled"
48
- [style.color]="playSelectionAction?.disabled ? 'grey' : 'green'" matTooltip="Play selection">
49
- <mat-icon>play_circle_outline</mat-icon>
50
- </button>
51
- <button (click)="playStopAction?.perform()" [disabled]="playStopAction?.disabled"
52
- [style.color]="playStopAction?.disabled ? 'grey' : 'yellow'">
53
- <mat-icon>stop</mat-icon>
54
- </button>&nbsp;
55
- <mat-checkbox #autoplaySelectionCheckbox (change)="autoPlaySelectionChange($event)">Autoplay on select
56
- </mat-checkbox>
57
- </fieldset>
58
- <fieldset>
59
-
60
- <legend>Zoom</legend>
61
- <button (click)="zoomFitToPanelAction?.perform()"
62
- [disabled]="zoomFitToPanelAction?.disabled">{{zoomFitToPanelAction?.name}}</button>
63
- <button (click)="zoomOutAction?.perform()"
64
- [disabled]="zoomOutAction?.disabled">{{zoomOutAction?.name}}</button>
65
- <button (click)="zoomInAction?.perform()"
66
- [disabled]="zoomInAction?.disabled">{{zoomInAction?.name}}</button>
67
- <button (click)="zoomSelectedAction?.perform()"
68
- [disabled]="zoomSelectedAction?.disabled">{{zoomSelectedAction?.name}}</button>
69
- </fieldset>
70
- <fieldset>
71
- <legend>Selection</legend>
72
- {{audioClip?.selection?.leftFrame}} <span
73
- *ngIf="audioClip?.selection">to</span> {{audioClip?.selection?.rightFrame}}
74
- <button (click)="clearSelection()" [disabled]="audioClip?.selection==null"
75
- [style.color]="hasSelection() ? 'red' : 'grey'" matTooltip="Clear selection">
76
- <mat-icon>clear</mat-icon>
77
- </button>
78
-
79
- </fieldset>
80
- </div>`, isInline: true, styles: [":host{flex:0}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i4.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }] }); }
81
- }
82
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: AudioDisplayControl, decorators: [{
83
- type: Component,
84
- args: [{ selector: 'audio-display-control', template: `
85
- <div #controlPanel style="display:flex;flex-direction: row;">
86
- <fieldset>
87
-
88
- <legend>Play</legend>
89
-
90
- <button (click)="playStartAction?.perform()" [disabled]="playStartAction?.disabled"
91
- [style.color]="playStartAction?.disabled ? 'grey' : 'green'" matTooltip="Play all">
92
- <mat-icon>play_arrow</mat-icon>
93
- </button>
94
- <button (click)="playSelectionAction?.perform()" [disabled]="playSelectionAction?.disabled"
95
- [style.color]="playSelectionAction?.disabled ? 'grey' : 'green'" matTooltip="Play selection">
96
- <mat-icon>play_circle_outline</mat-icon>
97
- </button>
98
- <button (click)="playStopAction?.perform()" [disabled]="playStopAction?.disabled"
99
- [style.color]="playStopAction?.disabled ? 'grey' : 'yellow'">
100
- <mat-icon>stop</mat-icon>
101
- </button>&nbsp;
102
- <mat-checkbox #autoplaySelectionCheckbox (change)="autoPlaySelectionChange($event)">Autoplay on select
103
- </mat-checkbox>
104
- </fieldset>
105
- <fieldset>
106
-
107
- <legend>Zoom</legend>
108
- <button (click)="zoomFitToPanelAction?.perform()"
109
- [disabled]="zoomFitToPanelAction?.disabled">{{zoomFitToPanelAction?.name}}</button>
110
- <button (click)="zoomOutAction?.perform()"
111
- [disabled]="zoomOutAction?.disabled">{{zoomOutAction?.name}}</button>
112
- <button (click)="zoomInAction?.perform()"
113
- [disabled]="zoomInAction?.disabled">{{zoomInAction?.name}}</button>
114
- <button (click)="zoomSelectedAction?.perform()"
115
- [disabled]="zoomSelectedAction?.disabled">{{zoomSelectedAction?.name}}</button>
116
- </fieldset>
117
- <fieldset>
118
- <legend>Selection</legend>
119
- {{audioClip?.selection?.leftFrame}} <span
120
- *ngIf="audioClip?.selection">to</span> {{audioClip?.selection?.rightFrame}}
121
- <button (click)="clearSelection()" [disabled]="audioClip?.selection==null"
122
- [style.color]="hasSelection() ? 'red' : 'grey'" matTooltip="Clear selection">
123
- <mat-icon>clear</mat-icon>
124
- </button>
125
-
126
- </fieldset>
127
- </div>`, styles: [":host{flex:0}\n"] }]
128
- }], ctorParameters: () => [], propDecorators: { audioClip: [{
129
- type: Input
130
- }], autoplaySelectedCheckbox: [{
131
- type: ViewChild,
132
- args: [MatCheckbox, { static: true }]
133
- }], playStartAction: [{
134
- type: Input
135
- }], playSelectionAction: [{
136
- type: Input
137
- }], playStopAction: [{
138
- type: Input
139
- }], zoomInAction: [{
140
- type: Input
141
- }], zoomOutAction: [{
142
- type: Input
143
- }], zoomFitToPanelAction: [{
144
- type: Input
145
- }], zoomSelectedAction: [{
146
- type: Input
147
- }], autoPlayOnSelectToggleAction: [{
148
- type: Input
149
- }] } });
150
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXVkaW9fZGlzcGxheV9jb250cm9sLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL2F1ZGlvL3VpL2F1ZGlvX2Rpc3BsYXlfY29udHJvbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUMsTUFBTSxlQUFlLENBQUE7QUFFekQsT0FBTyxFQUFDLFdBQVcsRUFBb0IsTUFBTSw0QkFBNEIsQ0FBQzs7Ozs7O0FBMkR6RSxNQUFNLE9BQU8sbUJBQW1CO0lBa0IvQjtRQWhCVyxjQUFTLEdBQWlCLElBQUksQ0FBQztRQUdoQyw2QkFBd0IsR0FBbUIsSUFBSSxDQUFDO1FBSS9DLGlCQUFZLEdBQW9CLElBQUksQ0FBQztRQUNyQyxrQkFBYSxHQUFvQixJQUFJLENBQUM7UUFJL0MsV0FBTSxHQUFhLElBQUksQ0FBQztJQUlYLENBQUM7SUFFZCxjQUFjO1FBQ1YsSUFBRyxJQUFJLENBQUMsU0FBUyxJQUFFLElBQUksRUFBQyxDQUFDO1lBQ3JCLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxHQUFDLElBQUksQ0FBQTtRQUNqQyxDQUFDO0lBQ0wsQ0FBQztJQUVDLFlBQVk7UUFDUixJQUFJLEVBQUUsR0FBQyxLQUFLLENBQUM7UUFDYixJQUFHLElBQUksQ0FBQyxTQUFTLEVBQUMsQ0FBQztZQUNmLEVBQUUsR0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxJQUFFLElBQUksQ0FBQyxDQUFDO1FBQ3hDLENBQUM7UUFDRCxPQUFPLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFSCx1QkFBdUIsQ0FBQyxFQUFxQjtRQUN6QyxJQUFJLElBQUksQ0FBQyw0QkFBNEIsRUFBRSxDQUFDO1lBQ3BDLElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzFELENBQUM7SUFDTCxDQUFDO0lBRUgsS0FBSztRQUNKLElBQUksQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDO0lBQ3ZCLENBQUM7K0dBMUNXLG1CQUFtQjttR0FBbkIsbUJBQW1CLGllQUlsQixXQUFXLDhEQXZEWjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztlQTJDQzs7NEZBUUQsbUJBQW1CO2tCQXZEOUIsU0FBUzsrQkFFRSx1QkFBdUIsWUFFdkI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7ZUEyQ0M7d0RBVUYsU0FBUztzQkFBakIsS0FBSztnQkFHRSx3QkFBd0I7c0JBRC9CLFNBQVM7dUJBQUMsV0FBVyxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFFL0IsZUFBZTtzQkFBdkIsS0FBSztnQkFDRyxtQkFBbUI7c0JBQTNCLEtBQUs7Z0JBQ0csY0FBYztzQkFBdEIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csb0JBQW9CO3NCQUE1QixLQUFLO2dCQUNHLGtCQUFrQjtzQkFBMUIsS0FBSztnQkFDRyw0QkFBNEI7c0JBQXBDLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5wdXQsIFZpZXdDaGlsZH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcclxuaW1wb3J0IHtBY3Rpb259IGZyb20gXCIuLi8uLi9hY3Rpb24vYWN0aW9uXCI7XHJcbmltcG9ydCB7TWF0Q2hlY2tib3gsIE1hdENoZWNrYm94Q2hhbmdlfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvY2hlY2tib3hcIjtcclxuaW1wb3J0IHtBdWRpb0NsaXB9IGZyb20gXCIuLi9wZXJzaXN0b3JcIjtcclxuXHJcblxyXG4gIEBDb21wb25lbnQoe1xyXG5cclxuICAgIHNlbGVjdG9yOiAnYXVkaW8tZGlzcGxheS1jb250cm9sJyxcclxuXHJcbiAgICB0ZW1wbGF0ZTogYFxyXG4gICAgICAgIDxkaXYgI2NvbnRyb2xQYW5lbCBzdHlsZT1cImRpc3BsYXk6ZmxleDtmbGV4LWRpcmVjdGlvbjogcm93O1wiPlxyXG4gICAgICAgICAgICA8ZmllbGRzZXQ+XHJcblxyXG4gICAgICAgICAgICAgICAgPGxlZ2VuZD5QbGF5PC9sZWdlbmQ+XHJcblxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwicGxheVN0YXJ0QWN0aW9uPy5wZXJmb3JtKClcIiBbZGlzYWJsZWRdPVwicGxheVN0YXJ0QWN0aW9uPy5kaXNhYmxlZFwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtzdHlsZS5jb2xvcl09XCJwbGF5U3RhcnRBY3Rpb24/LmRpc2FibGVkID8gJ2dyZXknIDogJ2dyZWVuJ1wiIG1hdFRvb2x0aXA9XCJQbGF5IGFsbFwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxtYXQtaWNvbj5wbGF5X2Fycm93PC9tYXQtaWNvbj5cclxuICAgICAgICAgICAgICAgIDwvYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwicGxheVNlbGVjdGlvbkFjdGlvbj8ucGVyZm9ybSgpXCIgW2Rpc2FibGVkXT1cInBsYXlTZWxlY3Rpb25BY3Rpb24/LmRpc2FibGVkXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgW3N0eWxlLmNvbG9yXT1cInBsYXlTZWxlY3Rpb25BY3Rpb24/LmRpc2FibGVkID8gJ2dyZXknIDogJ2dyZWVuJ1wiIG1hdFRvb2x0aXA9XCJQbGF5IHNlbGVjdGlvblwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxtYXQtaWNvbj5wbGF5X2NpcmNsZV9vdXRsaW5lPC9tYXQtaWNvbj5cclxuICAgICAgICAgICAgICAgIDwvYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwicGxheVN0b3BBY3Rpb24/LnBlcmZvcm0oKVwiIFtkaXNhYmxlZF09XCJwbGF5U3RvcEFjdGlvbj8uZGlzYWJsZWRcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbc3R5bGUuY29sb3JdPVwicGxheVN0b3BBY3Rpb24/LmRpc2FibGVkID8gJ2dyZXknIDogJ3llbGxvdydcIj5cclxuICAgICAgICAgICAgICAgICAgICA8bWF0LWljb24+c3RvcDwvbWF0LWljb24+XHJcbiAgICAgICAgICAgICAgICA8L2J1dHRvbj4mbmJzcDtcclxuICAgICAgICAgICAgICAgIDxtYXQtY2hlY2tib3ggI2F1dG9wbGF5U2VsZWN0aW9uQ2hlY2tib3ggKGNoYW5nZSk9XCJhdXRvUGxheVNlbGVjdGlvbkNoYW5nZSgkZXZlbnQpXCI+QXV0b3BsYXkgb24gc2VsZWN0XHJcbiAgICAgICAgICAgICAgICA8L21hdC1jaGVja2JveD5cclxuICAgICAgICAgICAgPC9maWVsZHNldD5cclxuICAgICAgICAgICAgPGZpZWxkc2V0PlxyXG5cclxuICAgICAgICAgICAgICAgIDxsZWdlbmQ+Wm9vbTwvbGVnZW5kPlxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwiem9vbUZpdFRvUGFuZWxBY3Rpb24/LnBlcmZvcm0oKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJ6b29tRml0VG9QYW5lbEFjdGlvbj8uZGlzYWJsZWRcIj57e3pvb21GaXRUb1BhbmVsQWN0aW9uPy5uYW1lfX08L2J1dHRvbj5cclxuICAgICAgICAgICAgICAgIDxidXR0b24gKGNsaWNrKT1cInpvb21PdXRBY3Rpb24/LnBlcmZvcm0oKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJ6b29tT3V0QWN0aW9uPy5kaXNhYmxlZFwiPnt7em9vbU91dEFjdGlvbj8ubmFtZX19PC9idXR0b24+XHJcbiAgICAgICAgICAgICAgICA8YnV0dG9uIChjbGljayk9XCJ6b29tSW5BY3Rpb24/LnBlcmZvcm0oKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJ6b29tSW5BY3Rpb24/LmRpc2FibGVkXCI+e3t6b29tSW5BY3Rpb24/Lm5hbWV9fTwvYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwiem9vbVNlbGVjdGVkQWN0aW9uPy5wZXJmb3JtKClcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbZGlzYWJsZWRdPVwiem9vbVNlbGVjdGVkQWN0aW9uPy5kaXNhYmxlZFwiPnt7em9vbVNlbGVjdGVkQWN0aW9uPy5uYW1lfX08L2J1dHRvbj5cclxuICAgICAgICAgICAgPC9maWVsZHNldD5cclxuICAgICAgICAgICAgPGZpZWxkc2V0PlxyXG4gICAgICAgICAgICAgICAgPGxlZ2VuZD5TZWxlY3Rpb248L2xlZ2VuZD5cclxuICAgICAgICAgICAgICAgIHt7YXVkaW9DbGlwPy5zZWxlY3Rpb24/LmxlZnRGcmFtZX19IDxzcGFuXHJcbiAgICAgICAgICAgICAgICAgICAgKm5nSWY9XCJhdWRpb0NsaXA/LnNlbGVjdGlvblwiPnRvPC9zcGFuPiB7e2F1ZGlvQ2xpcD8uc2VsZWN0aW9uPy5yaWdodEZyYW1lfX1cclxuICAgICAgICAgICAgICAgIDxidXR0b24gKGNsaWNrKT1cImNsZWFyU2VsZWN0aW9uKClcIiBbZGlzYWJsZWRdPVwiYXVkaW9DbGlwPy5zZWxlY3Rpb249PW51bGxcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbc3R5bGUuY29sb3JdPVwiaGFzU2VsZWN0aW9uKCkgPyAncmVkJyA6ICdncmV5J1wiIG1hdFRvb2x0aXA9XCJDbGVhciBzZWxlY3Rpb25cIj5cclxuICAgICAgICAgICAgICAgICAgICA8bWF0LWljb24+Y2xlYXI8L21hdC1pY29uPlxyXG4gICAgICAgICAgICAgICAgPC9idXR0b24+XHJcblxyXG4gICAgICAgICAgICA8L2ZpZWxkc2V0PlxyXG4gICAgICAgIDwvZGl2PmAsXHJcbiAgICBzdHlsZXM6IFtcclxuICAgICAgICBgOmhvc3Qge1xyXG4gICAgICAgICAgICAgICAgIGZsZXg6IDA7XHJcbiAgICAgICAgIFxyXG4gICAgICAgICAgICAgICB9YF1cclxuXHJcbiAgfSlcclxuXHRleHBvcnQgY2xhc3MgQXVkaW9EaXNwbGF5Q29udHJvbCB7XHJcblxyXG4gICAgQElucHV0KCkgYXVkaW9DbGlwOiBBdWRpb0NsaXB8bnVsbD1udWxsO1xyXG5cclxuICAgIEBWaWV3Q2hpbGQoTWF0Q2hlY2tib3gsIHsgc3RhdGljOiB0cnVlIH0pXHJcbiAgICBwcml2YXRlIGF1dG9wbGF5U2VsZWN0ZWRDaGVja2JveDogTWF0Q2hlY2tib3h8bnVsbD1udWxsO1xyXG4gICAgQElucHV0KCkgcGxheVN0YXJ0QWN0aW9uOiBBY3Rpb248dm9pZD58dW5kZWZpbmVkO1xyXG4gICAgQElucHV0KCkgcGxheVNlbGVjdGlvbkFjdGlvbjogQWN0aW9uPHZvaWQ+fHVuZGVmaW5lZDtcclxuICAgIEBJbnB1dCgpIHBsYXlTdG9wQWN0aW9uOiBBY3Rpb248dm9pZD58dW5kZWZpbmVkO1xyXG4gICAgQElucHV0KCkgem9vbUluQWN0aW9uOiBBY3Rpb248dm9pZD58bnVsbD1udWxsO1xyXG4gICAgQElucHV0KCkgem9vbU91dEFjdGlvbjogQWN0aW9uPHZvaWQ+fG51bGw9bnVsbDtcclxuICAgIEBJbnB1dCgpIHpvb21GaXRUb1BhbmVsQWN0aW9uOiBBY3Rpb248dm9pZD58dW5kZWZpbmVkO1xyXG4gICAgQElucHV0KCkgem9vbVNlbGVjdGVkQWN0aW9uOiBBY3Rpb248dm9pZD58dW5kZWZpbmVkO1xyXG4gICAgQElucHV0KCkgYXV0b1BsYXlPblNlbGVjdFRvZ2dsZUFjdGlvbjogQWN0aW9uPGJvb2xlYW4+fHVuZGVmaW5lZDtcclxuXHQgICBzdGF0dXM6c3RyaW5nfG51bGw9bnVsbDtcclxuXHJcblx0XHRhdWRpbzphbnk7XHJcblxyXG5cdFx0Y29uc3RydWN0b3IoKSB7fVxyXG5cclxuICAgIGNsZWFyU2VsZWN0aW9uKCl7XHJcbiAgICAgICAgaWYodGhpcy5hdWRpb0NsaXAhPW51bGwpe1xyXG4gICAgICAgICAgICB0aGlzLmF1ZGlvQ2xpcC5zZWxlY3Rpb249bnVsbFxyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICAgIGhhc1NlbGVjdGlvbigpOmJvb2xlYW57XHJcbiAgICAgICAgICBsZXQgaHM9ZmFsc2U7XHJcbiAgICAgICAgICBpZih0aGlzLmF1ZGlvQ2xpcCl7XHJcbiAgICAgICAgICAgICAgaHM9KHRoaXMuYXVkaW9DbGlwLnNlbGVjdGlvbiE9bnVsbCk7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgICByZXR1cm4gaHM7XHJcbiAgICAgIH1cclxuXHJcbiAgICBhdXRvUGxheVNlbGVjdGlvbkNoYW5nZShjaDogTWF0Q2hlY2tib3hDaGFuZ2UpIHtcclxuICAgICAgICBpZiAodGhpcy5hdXRvUGxheU9uU2VsZWN0VG9nZ2xlQWN0aW9uKSB7XHJcbiAgICAgICAgICAgIHRoaXMuYXV0b1BsYXlPblNlbGVjdFRvZ2dsZUFjdGlvbi5wZXJmb3JtKGNoLmNoZWNrZWQpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcblx0XHRlcnJvcigpe1xyXG5cdFx0XHR0aGlzLnN0YXR1cyA9ICdFUlJPUic7XHJcblx0XHR9XHJcblxyXG5cclxuICAgIH1cclxuXHJcbiJdfQ==