speechrecorderng 3.0.0 → 3.3.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 (142) hide show
  1. package/esm2020/lib/action/action.mjs +2 -1
  2. package/esm2020/lib/audio/array_audio_buffer.mjs +65 -2
  3. package/esm2020/lib/audio/array_audio_buffer_input_stream.mjs +2 -2
  4. package/esm2020/lib/audio/array_audio_buffer_random_access_stream.mjs +16 -0
  5. package/esm2020/lib/audio/audio_data_holder.mjs +203 -48
  6. package/esm2020/lib/audio/audio_display.mjs +10 -34
  7. package/esm2020/lib/audio/audio_player.mjs +18 -45
  8. package/esm2020/lib/audio/capture/capture.mjs +293 -69
  9. package/esm2020/lib/audio/dsp/level_measure.mjs +211 -88
  10. package/esm2020/lib/audio/impl/wavformat.mjs +1 -1
  11. package/esm2020/lib/audio/impl/wavreader.mjs +134 -0
  12. package/esm2020/lib/audio/impl/wavwriter.mjs +10 -9
  13. package/esm2020/lib/audio/inddb_audio_buffer.mjs +508 -0
  14. package/esm2020/lib/audio/net_audio_buffer.mjs +297 -0
  15. package/esm2020/lib/audio/persistor.mjs +8 -2
  16. package/esm2020/lib/audio/playback/array_audio_buffer_source_node.mjs +15 -154
  17. package/esm2020/lib/audio/playback/audio_source_node.mjs +18 -0
  18. package/esm2020/lib/audio/playback/audio_source_worklet_module_loader.mjs +167 -0
  19. package/esm2020/lib/audio/playback/inddb_audio_buffer_source_node.mjs +167 -0
  20. package/esm2020/lib/audio/playback/net_audio_buffer_source_node.mjs +218 -0
  21. package/esm2020/lib/audio/playback/player.mjs +190 -171
  22. package/esm2020/lib/audio/ui/audio_canvas_layer_comp.mjs +35 -76
  23. package/esm2020/lib/audio/ui/audio_display_control.mjs +12 -24
  24. package/esm2020/lib/audio/ui/audio_display_scroll_pane.mjs +14 -45
  25. package/esm2020/lib/audio/ui/audiosignal.mjs +333 -267
  26. package/esm2020/lib/audio/ui/container.mjs +40 -57
  27. package/esm2020/lib/audio/ui/livelevel.mjs +53 -52
  28. package/esm2020/lib/audio/ui/scroll_pane_horizontal.mjs +5 -19
  29. package/esm2020/lib/audio/ui/sonagram.mjs +386 -339
  30. package/esm2020/lib/db/inddb.mjs +120 -0
  31. package/esm2020/lib/io/BinaryReader.mjs +85 -0
  32. package/esm2020/lib/io/stream.mjs +101 -1
  33. package/esm2020/lib/net/uploader.mjs +111 -5
  34. package/esm2020/lib/recorder_component.mjs +59 -1
  35. package/esm2020/lib/speechrecorder/project/project.mjs +10 -1
  36. package/esm2020/lib/speechrecorder/project/project.service.mjs +3 -3
  37. package/esm2020/lib/speechrecorder/recording.mjs +30 -6
  38. package/esm2020/lib/speechrecorder/recordings/basic_recording.service.mjs +213 -0
  39. package/esm2020/lib/speechrecorder/recordings/recordings.service.mjs +732 -65
  40. package/esm2020/lib/speechrecorder/script/script.service.mjs +3 -3
  41. package/esm2020/lib/speechrecorder/session/audiorecorder.mjs +358 -184
  42. package/esm2020/lib/speechrecorder/session/basicrecorder.mjs +181 -28
  43. package/esm2020/lib/speechrecorder/session/controlpanel.mjs +47 -129
  44. package/esm2020/lib/speechrecorder/session/item.mjs +13 -1
  45. package/esm2020/lib/speechrecorder/session/progress.mjs +26 -55
  46. package/esm2020/lib/speechrecorder/session/prompting.mjs +33 -176
  47. package/esm2020/lib/speechrecorder/session/recorder_combi_pane.mjs +6 -6
  48. package/esm2020/lib/speechrecorder/session/recording_file_cache.mjs +28 -15
  49. package/esm2020/lib/speechrecorder/session/recording_list.mjs +92 -55
  50. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +9 -13
  51. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-navi.component.mjs +9 -18
  52. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +10 -36
  53. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +10 -37
  54. package/esm2020/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +80 -56
  55. package/esm2020/lib/speechrecorder/session/session.service.mjs +3 -3
  56. package/esm2020/lib/speechrecorder/session/session_finished_dialog.mjs +4 -4
  57. package/esm2020/lib/speechrecorder/session/sessionmanager.mjs +409 -165
  58. package/esm2020/lib/speechrecorder/session/warning_bar.mjs +6 -29
  59. package/esm2020/lib/speechrecorder/spruploader.mjs +3 -3
  60. package/esm2020/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.mjs +6 -41
  61. package/esm2020/lib/speechrecorderng.component.mjs +42 -31
  62. package/esm2020/lib/speechrecorderng.module.mjs +5 -5
  63. package/esm2020/lib/spr.config.mjs +3 -3
  64. package/esm2020/lib/spr.module.version.mjs +2 -2
  65. package/esm2020/lib/ui/canvas_layer_comp.mjs +3 -3
  66. package/esm2020/lib/ui/message_dialog.mjs +7 -7
  67. package/esm2020/lib/ui/recordingitem_display.mjs +26 -59
  68. package/esm2020/lib/utils/scrollIntoViewToBottom.mjs +3 -3
  69. package/esm2020/lib/utils/ua-parser.mjs +28 -4
  70. package/esm2020/lib/utils/utils.mjs +29 -1
  71. package/fesm2015/speechrecorderng.mjs +12755 -9195
  72. package/fesm2015/speechrecorderng.mjs.map +1 -1
  73. package/fesm2020/speechrecorderng.mjs +12652 -9101
  74. package/fesm2020/speechrecorderng.mjs.map +1 -1
  75. package/{speechrecorderng.d.ts → index.d.ts} +0 -0
  76. package/lib/audio/array_audio_buffer.d.ts +17 -1
  77. package/lib/audio/array_audio_buffer_random_access_stream.d.ts +9 -0
  78. package/lib/audio/audio_data_holder.d.ts +69 -14
  79. package/lib/audio/audio_display.d.ts +1 -1
  80. package/lib/audio/audio_player.d.ts +3 -7
  81. package/lib/audio/capture/capture.d.ts +24 -4
  82. package/lib/audio/dsp/level_measure.d.ts +2 -23
  83. package/lib/audio/impl/wavformat.d.ts +3 -3
  84. package/lib/audio/impl/wavreader.d.ts +16 -0
  85. package/lib/audio/impl/wavwriter.d.ts +1 -4
  86. package/lib/audio/inddb_audio_buffer.d.ts +68 -0
  87. package/lib/audio/net_audio_buffer.d.ts +59 -0
  88. package/lib/audio/persistor.d.ts +3 -9
  89. package/lib/audio/playback/array_audio_buffer_source_node.d.ts +2 -8
  90. package/lib/audio/playback/audio_source_node.d.ts +10 -0
  91. package/lib/audio/playback/audio_source_worklet_module_loader.d.ts +4 -0
  92. package/lib/audio/playback/inddb_audio_buffer_source_node.d.ts +21 -0
  93. package/lib/audio/playback/net_audio_buffer_source_node.d.ts +27 -0
  94. package/lib/audio/playback/player.d.ts +19 -16
  95. package/lib/audio/ui/audio_canvas_layer_comp.d.ts +3 -3
  96. package/lib/audio/ui/audio_display_control.d.ts +3 -6
  97. package/lib/audio/ui/audio_display_scroll_pane.d.ts +1 -1
  98. package/lib/audio/ui/audiosignal.d.ts +4 -3
  99. package/lib/audio/ui/container.d.ts +1 -1
  100. package/lib/audio/ui/livelevel.d.ts +11 -4
  101. package/lib/audio/ui/scroll_pane_horizontal.d.ts +1 -1
  102. package/lib/audio/ui/sonagram.d.ts +4 -3
  103. package/lib/db/inddb.d.ts +21 -0
  104. package/lib/io/BinaryReader.d.ts +18 -0
  105. package/lib/io/stream.d.ts +18 -0
  106. package/lib/net/uploader.d.ts +20 -2
  107. package/lib/recorder_component.d.ts +5 -0
  108. package/lib/speechrecorder/project/project.d.ts +9 -0
  109. package/lib/speechrecorder/recording.d.ts +8 -2
  110. package/lib/speechrecorder/recordings/basic_recording.service.d.ts +27 -0
  111. package/lib/speechrecorder/recordings/recordings.service.d.ts +21 -6
  112. package/lib/speechrecorder/session/audiorecorder.d.ts +7 -18
  113. package/lib/speechrecorder/session/basicrecorder.d.ts +28 -4
  114. package/lib/speechrecorder/session/controlpanel.d.ts +7 -7
  115. package/lib/speechrecorder/session/item.d.ts +1 -0
  116. package/lib/speechrecorder/session/progress.d.ts +2 -1
  117. package/lib/speechrecorder/session/prompting.d.ts +5 -5
  118. package/lib/speechrecorder/session/recorder_combi_pane.d.ts +1 -1
  119. package/lib/speechrecorder/session/recording_file_cache.d.ts +7 -4
  120. package/lib/speechrecorder/session/recording_list.d.ts +2 -1
  121. package/lib/speechrecorder/session/recordingfile/recording-file-meta.component.d.ts +1 -1
  122. package/lib/speechrecorder/session/recordingfile/recording-file-navi.component.d.ts +1 -1
  123. package/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.d.ts +1 -1
  124. package/lib/speechrecorder/session/recordingfile/recording-file-view.component.d.ts +1 -1
  125. package/lib/speechrecorder/session/recordingfile/recordingfile-service.d.ts +4 -5
  126. package/lib/speechrecorder/session/session_finished_dialog.d.ts +1 -1
  127. package/lib/speechrecorder/session/sessionmanager.d.ts +10 -10
  128. package/lib/speechrecorder/session/warning_bar.d.ts +1 -1
  129. package/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.d.ts +1 -1
  130. package/lib/speechrecorderng.component.d.ts +2 -1
  131. package/lib/spr.module.version.d.ts +1 -1
  132. package/lib/ui/canvas_layer_comp.d.ts +1 -1
  133. package/lib/ui/message_dialog.d.ts +1 -1
  134. package/lib/ui/recordingitem_display.d.ts +3 -2
  135. package/lib/utils/scrollIntoViewToBottom.d.ts +1 -1
  136. package/lib/utils/ua-parser.d.ts +4 -1
  137. package/lib/utils/utils.d.ts +6 -0
  138. package/package.json +5 -4
  139. package/esm2020/lib/math/utils.mjs +0 -14
  140. package/esm2020/lib/utils/css_utils.mjs +0 -7
  141. package/lib/math/utils.d.ts +0 -3
  142. package/lib/utils/css_utils.d.ts +0 -3
@@ -21,23 +21,10 @@ export class ViewSelection {
21
21
  export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
22
22
  constructor() {
23
23
  super(...arguments);
24
- //protected _audioData: AudioBuffer|null=null;
25
- //protected _arrayAudioData: ArrayAudioBuffer|null=null;
26
24
  this._audioDataHolder = null;
27
25
  this._bgColor = 'white';
28
26
  this._selectColor = 'rgba(0%,0%,100%,25%)';
29
27
  }
30
- frameLength() {
31
- let frameLength = null;
32
- // if (this._audioData && this._audioData.numberOfChannels > 0) {
33
- // let ch0 = this._audioData.getChannelData(0);
34
- // frameLength = ch0.length;
35
- //
36
- // }else if(this._arrayAudioData){
37
- // frameLength=this._arrayAudioData.frameLen;
38
- // }
39
- return frameLength;
40
- }
41
28
  /**
42
29
  * Returns pixel position depending on current zoom setting.
43
30
  * @param framePos audio frame (sample) position
@@ -66,18 +53,17 @@ export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
66
53
  frameToViewPortXPixelPosition(framePos) {
67
54
  let pixelPos = this.frameToXPixelPosition(framePos);
68
55
  if (pixelPos != null) {
69
- let vPixelPos = this.toXViewPortPixelPosition(pixelPos);
70
- return vPixelPos;
56
+ return this.toXViewPortPixelPosition(pixelPos);
71
57
  }
72
58
  else {
73
59
  return null;
74
60
  }
75
61
  }
76
62
  viewPortXPixelToFramePosition(xViewPortPixelPos) {
77
- let vpXramePos = null;
78
- let frameLength = this._audioDataHolder?.frameLen;
63
+ let vpXframePos = null;
64
+ const frameLength = this._audioDataHolder?.frameLen;
79
65
  if (frameLength !== undefined) {
80
- let vw;
66
+ let vw = undefined;
81
67
  if (this.bounds) {
82
68
  vw = this.bounds.dimension.width;
83
69
  }
@@ -85,8 +71,8 @@ export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
85
71
  vw = this.virtualDimension.width;
86
72
  }
87
73
  if (vw !== undefined) {
88
- let xVirtualPixelPos = this.toXVirtualPixelPosition(xViewPortPixelPos);
89
- let framesPerPixel = frameLength / vw;
74
+ const xVirtualPixelPos = this.toXVirtualPixelPosition(xViewPortPixelPos);
75
+ const framesPerPixel = frameLength / vw;
90
76
  let framePos = framesPerPixel * xVirtualPixelPos;
91
77
  if (framePos < 0) {
92
78
  framePos = 0;
@@ -94,17 +80,16 @@ export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
94
80
  if (framePos >= frameLength) {
95
81
  framePos = frameLength - 1;
96
82
  }
97
- vpXramePos = Math.round(framePos);
83
+ vpXframePos = Math.round(framePos);
98
84
  }
99
85
  }
100
- return vpXramePos;
86
+ return vpXframePos;
101
87
  }
102
88
  layoutBounds(bounds, virtualDimension, redraw) {
103
89
  this.bounds = bounds;
104
90
  this.virtualDimension = virtualDimension;
105
- //this.canvasLayers.forEach(cl=>{
106
91
  for (let ci = 0; ci < this.canvasLayers.length; ci++) {
107
- let cl = this.canvasLayers[ci];
92
+ const cl = this.canvasLayers[ci];
108
93
  const leftStyle = bounds.position.left + 'px';
109
94
  if (cl.style.left != leftStyle) {
110
95
  cl.style.left = leftStyle;
@@ -115,7 +100,7 @@ export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
115
100
  }
116
101
  }
117
102
  if (bounds.dimension.width) {
118
- let intW = Math.floor(bounds.dimension.width);
103
+ const intW = Math.floor(bounds.dimension.width);
119
104
  if (redraw) {
120
105
  // Do not set width of background canvas (causes flicker on start render)
121
106
  for (let ci = 1; ci < this.canvasLayers.length; ci++) {
@@ -125,7 +110,7 @@ export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
125
110
  }
126
111
  }
127
112
  }
128
- let wStr = intW.toString() + 'px';
113
+ const wStr = intW.toString() + 'px';
129
114
  for (let ci = 0; ci < this.canvasLayers.length; ci++) {
130
115
  let cl = this.canvasLayers[ci];
131
116
  if (cl.style.width != wStr) {
@@ -134,7 +119,7 @@ export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
134
119
  }
135
120
  }
136
121
  if (bounds.dimension.height) {
137
- let intH = Math.floor(bounds.dimension.height);
122
+ const intH = Math.floor(bounds.dimension.height);
138
123
  if (redraw) {
139
124
  // Do not set height of background canvas (causes flicker on start render)
140
125
  for (let ci = 1; ci < this.canvasLayers.length; ci++) {
@@ -144,7 +129,7 @@ export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
144
129
  }
145
130
  }
146
131
  }
147
- let hStr = intH + 'px';
132
+ const hStr = intH + 'px';
148
133
  for (let ci = 0; ci < this.canvasLayers.length; ci++) {
149
134
  let cl = this.canvasLayers[ci];
150
135
  if (cl.style.height != hStr) {
@@ -152,12 +137,11 @@ export class BasicAudioCanvasLayerComponent extends CanvasLayerComponent {
152
137
  }
153
138
  }
154
139
  }
155
- //});
156
140
  }
157
141
  }
158
- BasicAudioCanvasLayerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: BasicAudioCanvasLayerComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive });
159
- BasicAudioCanvasLayerComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: BasicAudioCanvasLayerComponent, usesInheritance: true, ngImport: i0 });
160
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: BasicAudioCanvasLayerComponent, decorators: [{
142
+ BasicAudioCanvasLayerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BasicAudioCanvasLayerComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive });
143
+ BasicAudioCanvasLayerComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: BasicAudioCanvasLayerComponent, usesInheritance: true, ngImport: i0 });
144
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BasicAudioCanvasLayerComponent, decorators: [{
161
145
  type: Directive
162
146
  }] });
163
147
  export class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {
@@ -214,13 +198,6 @@ export class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {
214
198
  }
215
199
  updateCursorCanvas(me, showCursorPosition = true) {
216
200
  if (this.cursorCanvas) {
217
- let w = this.cursorCanvas.width;
218
- let h = this.cursorCanvas.height;
219
- let g = this.cursorCanvas.getContext("2d");
220
- // if (!showCursorPosition) {
221
- // this.selectStartX = null
222
- // this.selectingChange(null)
223
- // }
224
201
  if (me) {
225
202
  if (this.selectStartX) {
226
203
  this.pointerPositionChanged(null);
@@ -248,7 +225,7 @@ export class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {
248
225
  }
249
226
  this.pointerPositionEventEmitter.emit(pointerPosition);
250
227
  }
251
- selectingChange(viewSel) {
228
+ _selectingChange(viewSel) {
252
229
  let ns = undefined;
253
230
  if (viewSel) {
254
231
  let frameStart = this.viewPortXPixelToFramePosition(viewSel.startX);
@@ -257,17 +234,14 @@ export class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {
257
234
  ns = new Selection(this._audioDataHolder.sampleRate, frameStart, frameEnd);
258
235
  }
259
236
  }
237
+ return ns;
238
+ }
239
+ selectingChange(viewSel) {
240
+ const ns = this._selectingChange(viewSel);
260
241
  this.selectingEventEmitter.emit(ns);
261
242
  }
262
243
  select(viewSel) {
263
- let ns = undefined;
264
- if (viewSel) {
265
- let frameStart = this.viewPortXPixelToFramePosition(viewSel.startX);
266
- let frameEnd = this.viewPortXPixelToFramePosition(viewSel.endX);
267
- if (this._audioDataHolder && frameStart != null && frameEnd != null) {
268
- ns = new Selection(this._audioDataHolder.sampleRate, frameStart, frameEnd);
269
- }
270
- }
244
+ const ns = this._selectingChange(viewSel);
271
245
  this.selectedEventEmitter.emit(ns);
272
246
  }
273
247
  viewSelection() {
@@ -280,10 +254,10 @@ export class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {
280
254
  s = this._selection;
281
255
  }
282
256
  if (s) {
283
- let sf = s.startFrame;
284
- let ef = s.endFrame;
285
- let xs = this.frameToViewPortXPixelPosition(sf);
286
- let xe = this.frameToViewPortXPixelPosition(ef);
257
+ const sf = s.startFrame;
258
+ const ef = s.endFrame;
259
+ const xs = this.frameToViewPortXPixelPosition(sf);
260
+ const xe = this.frameToViewPortXPixelPosition(ef);
287
261
  if (xs != null && xe != null) {
288
262
  vs = new ViewSelection(xs, xe);
289
263
  }
@@ -297,8 +271,8 @@ export class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {
297
271
  this.bgCanvas.height = Math.round(this.bounds.dimension.height);
298
272
  let g1 = this.bgCanvas.getContext("2d");
299
273
  if (g1) {
300
- let w = this.bgCanvas.width;
301
- let h = this.bgCanvas.height;
274
+ const w = this.bgCanvas.width;
275
+ const h = this.bgCanvas.height;
302
276
  g1.clearRect(0, 0, w, h);
303
277
  if (this._bgColor) {
304
278
  g1.fillStyle = this._bgColor;
@@ -314,26 +288,11 @@ export class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {
314
288
  }
315
289
  drawCursorLayer() {
316
290
  if (this.cursorCanvas) {
317
- let w = this.cursorCanvas.width;
318
- let h = this.cursorCanvas.height;
319
- let g = this.cursorCanvas.getContext("2d");
291
+ const w = this.cursorCanvas.width;
292
+ const h = this.cursorCanvas.height;
293
+ const g = this.cursorCanvas.getContext("2d");
320
294
  if (g) {
321
295
  g.clearRect(0, 0, w, h);
322
- // let s:Selection=null;
323
- // if(this._selecting){
324
- // s=this._selecting
325
- // }else if(this._selection){
326
- // s=this._selection
327
- // }
328
- // if(s){
329
- // let sf=s.startFrame
330
- // let ef=s.endFrame
331
- // let xs=this.frameToViewPortXPixelPosition(sf)
332
- // let xe=this.frameToViewPortXPixelPosition(ef)
333
- // let sw=xe-xs
334
- // g.fillStyle = 'rgba(0%,0%,100%,25%)';
335
- // g.fillRect(xs,0,sw,h);
336
- // }
337
296
  if (this._pointerPosition) {
338
297
  let framePos = this._pointerPosition.framePosition;
339
298
  if (framePos) {
@@ -359,9 +318,9 @@ export class AudioCanvasLayerComponent extends BasicAudioCanvasLayerComponent {
359
318
  }
360
319
  }
361
320
  AudioCanvasLayerComponent.ENABLE_STREAMING_NUMBER_OF_SAMPLES_THRESHOLD = 10 * 60 * 48000; // Use streaming/chunking if audio clip has more than this number of samples
362
- AudioCanvasLayerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AudioCanvasLayerComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive });
363
- AudioCanvasLayerComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", 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 });
364
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AudioCanvasLayerComponent, decorators: [{
321
+ AudioCanvasLayerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AudioCanvasLayerComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive });
322
+ AudioCanvasLayerComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.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 });
323
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AudioCanvasLayerComponent, decorators: [{
365
324
  type: Directive
366
325
  }], propDecorators: { bgCanvasRef: [{
367
326
  type: ViewChild,
@@ -385,4 +344,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
385
344
  }], selectedEventEmitter: [{
386
345
  type: Output
387
346
  }] } });
388
- //# 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 _audioData: AudioBuffer|null=null;\r\n  //protected _arrayAudioData: ArrayAudioBuffer|null=null;\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  private frameLength():number|null{\r\n    let frameLength = null;\r\n    // if (this._audioData && this._audioData.numberOfChannels > 0) {\r\n    //   let ch0 = this._audioData.getChannelData(0);\r\n    //   frameLength = ch0.length;\r\n    //\r\n    // }else if(this._arrayAudioData){\r\n    //   frameLength=this._arrayAudioData.frameLen;\r\n    // }\r\n\r\n    return frameLength;\r\n  }\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      let vPixelPos = this.toXViewPortPixelPosition(pixelPos);\r\n      return vPixelPos;\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n\r\n  viewPortXPixelToFramePosition(xViewPortPixelPos: number): number | null {\r\n    let vpXramePos=null;\r\n\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        let xVirtualPixelPos = this.toXVirtualPixelPosition(xViewPortPixelPos)\r\n        let 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        vpXramePos = Math.round(framePos);\r\n      }\r\n    }\r\n    return vpXramePos;\r\n  }\r\n\r\n    layoutBounds(bounds:Rectangle, virtualDimension:Dimension,redraw: boolean) {\r\n\r\n        this.bounds=bounds;\r\n        this.virtualDimension=virtualDimension;\r\n        //this.canvasLayers.forEach(cl=>{\r\n        for(let ci=0;ci<this.canvasLayers.length;ci++) {\r\n            let 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            let 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            let 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            let 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            let 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    }\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\r\n        if (this.cursorCanvas) {\r\n\r\n            let w = this.cursorCanvas.width;\r\n            let h = this.cursorCanvas.height;\r\n            let g = this.cursorCanvas.getContext(\"2d\");\r\n\r\n            // if (!showCursorPosition) {\r\n            //     this.selectStartX = null\r\n            //     this.selectingChange(null)\r\n            // }\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    selectingChange(viewSel:ViewSelection| null){\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        this.selectingEventEmitter.emit(ns)\r\n    }\r\n\r\n    select(viewSel:ViewSelection| null){\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        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        let sf=s.startFrame;\r\n        let ef=s.endFrame;\r\n        let xs=this.frameToViewPortXPixelPosition(sf)\r\n        let 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          let w = this.bgCanvas.width;\r\n          let 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            let w = this.cursorCanvas.width;\r\n            let h = this.cursorCanvas.height;\r\n            let g = this.cursorCanvas.getContext(\"2d\");\r\n            if(g) {\r\n                g.clearRect(0, 0, w, h);\r\n                // let s:Selection=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                //     let sf=s.startFrame\r\n                //     let ef=s.endFrame\r\n                //     let xs=this.frameToViewPortXPixelPosition(sf)\r\n                //     let xe=this.frameToViewPortXPixelPosition(ef)\r\n                //     let sw=xe-xs\r\n                //     g.fillStyle = 'rgba(0%,0%,100%,25%)';\r\n                //     g.fillRect(xs,0,sw,h);\r\n                // }\r\n\r\n                if(this._pointerPosition){\r\n\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"]}
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,21 +1,18 @@
1
1
  import { Component, Input, ViewChild } from '@angular/core';
2
2
  import { MatCheckbox } from "@angular/material/checkbox";
3
3
  import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/material/icon";
5
- import * as i2 from "@angular/material/checkbox";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "@angular/material/icon";
6
6
  import * as i3 from "@angular/material/tooltip";
7
- import * as i4 from "@angular/common";
7
+ import * as i4 from "@angular/material/checkbox";
8
8
  export class AudioDisplayControl {
9
- constructor(ref) {
10
- this.ref = ref;
9
+ constructor() {
11
10
  this.audioClip = null;
12
11
  this.autoplaySelectedCheckbox = null;
13
12
  this.zoomInAction = null;
14
13
  this.zoomOutAction = null;
15
14
  this.status = null;
16
15
  }
17
- ngAfterContentInit() {
18
- }
19
16
  clearSelection() {
20
17
  if (this.audioClip != null) {
21
18
  this.audioClip.selection = null;
@@ -37,8 +34,8 @@ export class AudioDisplayControl {
37
34
  this.status = 'ERROR';
38
35
  }
39
36
  }
40
- AudioDisplayControl.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AudioDisplayControl, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
41
- AudioDisplayControl.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", 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: `
37
+ AudioDisplayControl.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AudioDisplayControl, deps: [], target: i0.ɵɵFactoryTarget.Component });
38
+ AudioDisplayControl.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.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: `
42
39
  <div #controlPanel style="display:flex;flex-direction: row;">
43
40
  <fieldset>
44
41
 
@@ -81,12 +78,10 @@ AudioDisplayControl.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", ve
81
78
  </button>
82
79
 
83
80
  </fieldset>
84
- </div>`, isInline: true, styles: [":host{flex:0}\n"], components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i2.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }], directives: [{ type: i3.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
85
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AudioDisplayControl, decorators: [{
81
+ </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]", exportAs: ["matTooltip"] }, { kind: "component", type: i4.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }] });
82
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AudioDisplayControl, decorators: [{
86
83
  type: Component,
87
- args: [{
88
- selector: 'audio-display-control',
89
- template: `
84
+ args: [{ selector: 'audio-display-control', template: `
90
85
  <div #controlPanel style="display:flex;flex-direction: row;">
91
86
  <fieldset>
92
87
 
@@ -129,15 +124,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
129
124
  </button>
130
125
 
131
126
  </fieldset>
132
- </div>`,
133
- styles: [
134
- `:host {
135
- flex: 0;
136
-
137
- }`
138
- ]
139
- }]
140
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { audioClip: [{
127
+ </div>`, styles: [":host{flex:0}\n"] }]
128
+ }], ctorParameters: function () { return []; }, propDecorators: { audioClip: [{
141
129
  type: Input
142
130
  }], autoplaySelectedCheckbox: [{
143
131
  type: ViewChild,
@@ -159,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
159
147
  }], autoPlayOnSelectToggleAction: [{
160
148
  type: Input
161
149
  }] } });
162
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audio_display_control.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/ui/audio_display_control.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAuC,KAAK,EAAE,SAAS,EAAC,MAAM,eAAe,CAAA;AAE9F,OAAO,EAAC,WAAW,EAAoB,MAAM,4BAA4B,CAAC;;;;;;AA2DzE,MAAM,OAAO,mBAAmB;IAkB/B,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QAhB/B,cAAS,GAAiB,IAAI,CAAC;QAGhC,6BAAwB,GAAmB,IAAI,CAAC;QAI/C,iBAAY,GAAoB,IAAI,CAAC;QACrC,kBAAa,GAAoB,IAAI,CAAC;QAI/C,WAAM,GAAa,IAAI,CAAC;IAM1B,CAAC;IAEC,kBAAkB;IAEpB,CAAC;IAEC,cAAc;QACV,IAAG,IAAI,CAAC,SAAS,IAAE,IAAI,EAAC;YACpB,IAAI,CAAC,SAAS,CAAC,SAAS,GAAC,IAAI,CAAA;SAChC;IACL,CAAC;IAEC,YAAY;QACR,IAAI,EAAE,GAAC,KAAK,CAAC;QACb,IAAG,IAAI,CAAC,SAAS,EAAC;YACd,EAAE,GAAC,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,IAAE,IAAI,CAAC,CAAC;SACvC;QACD,OAAO,EAAE,CAAC;IACd,CAAC;IAEH,uBAAuB,CAAC,EAAqB;QACzC,IAAI,IAAI,CAAC,4BAA4B,EAAE;YACnC,IAAI,CAAC,4BAA4B,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,CAAA;SACxD;IACL,CAAC;IAEH,KAAK;QACJ,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC;IACvB,CAAC;;iHAhDW,mBAAmB;qGAAnB,mBAAmB,ieAIlB,WAAW,8DAvDZ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eA2CC;4FAQD,mBAAmB;kBAvD9B,SAAS;mBAAC;oBAET,QAAQ,EAAE,uBAAuB;oBAEjC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eA2CC;oBACX,MAAM,EAAE;wBACJ;;;QAGA;qBAAC;iBAEN;wGAGU,SAAS;sBAAjB,KAAK;gBAGE,wBAAwB;sBAD/B,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAE/B,eAAe;sBAAvB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,4BAA4B;sBAApC,KAAK","sourcesContent":["import {Component, AfterContentInit, ChangeDetectorRef, Input, ViewChild} from '@angular/core'\r\nimport {Action} from \"../../action/action\";\r\nimport {MatCheckbox, MatCheckboxChange} from \"@angular/material/checkbox\";\r\nimport {AudioClip} from \"../persistor\";\r\n\r\n\r\n  @Component({\r\n\r\n    selector: 'audio-display-control',\r\n\r\n    template: `\r\n        <div #controlPanel style=\"display:flex;flex-direction: row;\">\r\n            <fieldset>\r\n\r\n                <legend>Play</legend>\r\n\r\n                <button (click)=\"playStartAction?.perform()\" [disabled]=\"playStartAction?.disabled\"\r\n                        [style.color]=\"playStartAction?.disabled ? 'grey' : 'green'\" matTooltip=\"Play all\">\r\n                    <mat-icon>play_arrow</mat-icon>\r\n                </button>\r\n                <button (click)=\"playSelectionAction?.perform()\" [disabled]=\"playSelectionAction?.disabled\"\r\n                        [style.color]=\"playSelectionAction?.disabled ? 'grey' : 'green'\" matTooltip=\"Play selection\">\r\n                    <mat-icon>play_circle_outline</mat-icon>\r\n                </button>\r\n                <button (click)=\"playStopAction?.perform()\" [disabled]=\"playStopAction?.disabled\"\r\n                        [style.color]=\"playStopAction?.disabled ? 'grey' : 'yellow'\">\r\n                    <mat-icon>stop</mat-icon>\r\n                </button>&nbsp;\r\n                <mat-checkbox #autoplaySelectionCheckbox (change)=\"autoPlaySelectionChange($event)\">Autoplay on select\r\n                </mat-checkbox>\r\n            </fieldset>\r\n            <fieldset>\r\n\r\n                <legend>Zoom</legend>\r\n                <button (click)=\"zoomFitToPanelAction?.perform()\"\r\n                        [disabled]=\"zoomFitToPanelAction?.disabled\">{{zoomFitToPanelAction?.name}}</button>\r\n                <button (click)=\"zoomOutAction?.perform()\"\r\n                        [disabled]=\"zoomOutAction?.disabled\">{{zoomOutAction?.name}}</button>\r\n                <button (click)=\"zoomInAction?.perform()\"\r\n                        [disabled]=\"zoomInAction?.disabled\">{{zoomInAction?.name}}</button>\r\n                <button (click)=\"zoomSelectedAction?.perform()\"\r\n                        [disabled]=\"zoomSelectedAction?.disabled\">{{zoomSelectedAction?.name}}</button>\r\n            </fieldset>\r\n            <fieldset>\r\n                <legend>Selection</legend>\r\n                {{audioClip?.selection?.leftFrame}} <span\r\n                    *ngIf=\"audioClip?.selection\">to</span> {{audioClip?.selection?.rightFrame}}\r\n                <button (click)=\"clearSelection()\" [disabled]=\"audioClip?.selection==null\"\r\n                        [style.color]=\"hasSelection() ? 'red' : 'grey'\" matTooltip=\"Clear selection\">\r\n                    <mat-icon>clear</mat-icon>\r\n                </button>\r\n\r\n            </fieldset>\r\n        </div>`,\r\n    styles: [\r\n        `:host {\r\n        flex: 0;\r\n\r\n      }`]\r\n\r\n  })\r\n\texport class AudioDisplayControl implements AfterContentInit {\r\n\r\n    @Input() audioClip: AudioClip|null=null;\r\n\r\n    @ViewChild(MatCheckbox, { static: true })\r\n    private autoplaySelectedCheckbox: MatCheckbox|null=null;\r\n    @Input() playStartAction: Action<void>|undefined;\r\n    @Input() playSelectionAction: Action<void>|undefined;\r\n    @Input() playStopAction: Action<void>|undefined;\r\n    @Input() zoomInAction: Action<void>|null=null;\r\n    @Input() zoomOutAction: Action<void>|null=null;\r\n    @Input() zoomFitToPanelAction: Action<void>|undefined;\r\n    @Input() zoomSelectedAction: Action<void>|undefined;\r\n    @Input() autoPlayOnSelectToggleAction: Action<boolean>|undefined;\r\n\t   status:string|null=null;\r\n\r\n\t\taudio:any;\r\n\r\n\t\tconstructor(private ref: ChangeDetectorRef) {\r\n\r\n\t\t}\r\n\r\n    ngAfterContentInit() {\r\n\r\n\t\t}\r\n\r\n    clearSelection(){\r\n        if(this.audioClip!=null){\r\n            this.audioClip.selection=null\r\n        }\r\n    }\r\n\r\n      hasSelection():boolean{\r\n          let hs=false;\r\n          if(this.audioClip){\r\n              hs=(this.audioClip.selection!=null);\r\n          }\r\n          return hs;\r\n      }\r\n\r\n    autoPlaySelectionChange(ch: MatCheckboxChange) {\r\n        if (this.autoPlayOnSelectToggleAction) {\r\n            this.autoPlayOnSelectToggleAction.perform(ch.checked)\r\n        }\r\n    }\r\n\r\n\t\terror(){\r\n\t\t\tthis.status = 'ERROR';\r\n\t\t}\r\n\r\n\r\n    }\r\n\r\n"]}
150
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXVkaW9fZGlzcGxheV9jb250cm9sLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL2F1ZGlvL3VpL2F1ZGlvX2Rpc3BsYXlfY29udHJvbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUMsTUFBTSxlQUFlLENBQUE7QUFFekQsT0FBTyxFQUFDLFdBQVcsRUFBb0IsTUFBTSw0QkFBNEIsQ0FBQzs7Ozs7O0FBMkR6RSxNQUFNLE9BQU8sbUJBQW1CO0lBa0IvQjtRQWhCVyxjQUFTLEdBQWlCLElBQUksQ0FBQztRQUdoQyw2QkFBd0IsR0FBbUIsSUFBSSxDQUFDO1FBSS9DLGlCQUFZLEdBQW9CLElBQUksQ0FBQztRQUNyQyxrQkFBYSxHQUFvQixJQUFJLENBQUM7UUFJL0MsV0FBTSxHQUFhLElBQUksQ0FBQztJQUlYLENBQUM7SUFFZCxjQUFjO1FBQ1YsSUFBRyxJQUFJLENBQUMsU0FBUyxJQUFFLElBQUksRUFBQztZQUNwQixJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsR0FBQyxJQUFJLENBQUE7U0FDaEM7SUFDTCxDQUFDO0lBRUMsWUFBWTtRQUNSLElBQUksRUFBRSxHQUFDLEtBQUssQ0FBQztRQUNiLElBQUcsSUFBSSxDQUFDLFNBQVMsRUFBQztZQUNkLEVBQUUsR0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxJQUFFLElBQUksQ0FBQyxDQUFDO1NBQ3ZDO1FBQ0QsT0FBTyxFQUFFLENBQUM7SUFDZCxDQUFDO0lBRUgsdUJBQXVCLENBQUMsRUFBcUI7UUFDekMsSUFBSSxJQUFJLENBQUMsNEJBQTRCLEVBQUU7WUFDbkMsSUFBSSxDQUFDLDRCQUE0QixDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUE7U0FDeEQ7SUFDTCxDQUFDO0lBRUgsS0FBSztRQUNKLElBQUksQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDO0lBQ3ZCLENBQUM7O2lIQTFDVyxtQkFBbUI7cUdBQW5CLG1CQUFtQixpZUFJbEIsV0FBVyw4REF2RFo7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7ZUEyQ0M7NEZBUUQsbUJBQW1CO2tCQXZEOUIsU0FBUzsrQkFFRSx1QkFBdUIsWUFFdkI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7ZUEyQ0M7MEVBVUYsU0FBUztzQkFBakIsS0FBSztnQkFHRSx3QkFBd0I7c0JBRC9CLFNBQVM7dUJBQUMsV0FBVyxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFFL0IsZUFBZTtzQkFBdkIsS0FBSztnQkFDRyxtQkFBbUI7c0JBQTNCLEtBQUs7Z0JBQ0csY0FBYztzQkFBdEIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csb0JBQW9CO3NCQUE1QixLQUFLO2dCQUNHLGtCQUFrQjtzQkFBMUIsS0FBSztnQkFDRyw0QkFBNEI7c0JBQXBDLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5wdXQsIFZpZXdDaGlsZH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcclxuaW1wb3J0IHtBY3Rpb259IGZyb20gXCIuLi8uLi9hY3Rpb24vYWN0aW9uXCI7XHJcbmltcG9ydCB7TWF0Q2hlY2tib3gsIE1hdENoZWNrYm94Q2hhbmdlfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvY2hlY2tib3hcIjtcclxuaW1wb3J0IHtBdWRpb0NsaXB9IGZyb20gXCIuLi9wZXJzaXN0b3JcIjtcclxuXHJcblxyXG4gIEBDb21wb25lbnQoe1xyXG5cclxuICAgIHNlbGVjdG9yOiAnYXVkaW8tZGlzcGxheS1jb250cm9sJyxcclxuXHJcbiAgICB0ZW1wbGF0ZTogYFxyXG4gICAgICAgIDxkaXYgI2NvbnRyb2xQYW5lbCBzdHlsZT1cImRpc3BsYXk6ZmxleDtmbGV4LWRpcmVjdGlvbjogcm93O1wiPlxyXG4gICAgICAgICAgICA8ZmllbGRzZXQ+XHJcblxyXG4gICAgICAgICAgICAgICAgPGxlZ2VuZD5QbGF5PC9sZWdlbmQ+XHJcblxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwicGxheVN0YXJ0QWN0aW9uPy5wZXJmb3JtKClcIiBbZGlzYWJsZWRdPVwicGxheVN0YXJ0QWN0aW9uPy5kaXNhYmxlZFwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtzdHlsZS5jb2xvcl09XCJwbGF5U3RhcnRBY3Rpb24/LmRpc2FibGVkID8gJ2dyZXknIDogJ2dyZWVuJ1wiIG1hdFRvb2x0aXA9XCJQbGF5IGFsbFwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxtYXQtaWNvbj5wbGF5X2Fycm93PC9tYXQtaWNvbj5cclxuICAgICAgICAgICAgICAgIDwvYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwicGxheVNlbGVjdGlvbkFjdGlvbj8ucGVyZm9ybSgpXCIgW2Rpc2FibGVkXT1cInBsYXlTZWxlY3Rpb25BY3Rpb24/LmRpc2FibGVkXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgW3N0eWxlLmNvbG9yXT1cInBsYXlTZWxlY3Rpb25BY3Rpb24/LmRpc2FibGVkID8gJ2dyZXknIDogJ2dyZWVuJ1wiIG1hdFRvb2x0aXA9XCJQbGF5IHNlbGVjdGlvblwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxtYXQtaWNvbj5wbGF5X2NpcmNsZV9vdXRsaW5lPC9tYXQtaWNvbj5cclxuICAgICAgICAgICAgICAgIDwvYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwicGxheVN0b3BBY3Rpb24/LnBlcmZvcm0oKVwiIFtkaXNhYmxlZF09XCJwbGF5U3RvcEFjdGlvbj8uZGlzYWJsZWRcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbc3R5bGUuY29sb3JdPVwicGxheVN0b3BBY3Rpb24/LmRpc2FibGVkID8gJ2dyZXknIDogJ3llbGxvdydcIj5cclxuICAgICAgICAgICAgICAgICAgICA8bWF0LWljb24+c3RvcDwvbWF0LWljb24+XHJcbiAgICAgICAgICAgICAgICA8L2J1dHRvbj4mbmJzcDtcclxuICAgICAgICAgICAgICAgIDxtYXQtY2hlY2tib3ggI2F1dG9wbGF5U2VsZWN0aW9uQ2hlY2tib3ggKGNoYW5nZSk9XCJhdXRvUGxheVNlbGVjdGlvbkNoYW5nZSgkZXZlbnQpXCI+QXV0b3BsYXkgb24gc2VsZWN0XHJcbiAgICAgICAgICAgICAgICA8L21hdC1jaGVja2JveD5cclxuICAgICAgICAgICAgPC9maWVsZHNldD5cclxuICAgICAgICAgICAgPGZpZWxkc2V0PlxyXG5cclxuICAgICAgICAgICAgICAgIDxsZWdlbmQ+Wm9vbTwvbGVnZW5kPlxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwiem9vbUZpdFRvUGFuZWxBY3Rpb24/LnBlcmZvcm0oKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJ6b29tRml0VG9QYW5lbEFjdGlvbj8uZGlzYWJsZWRcIj57e3pvb21GaXRUb1BhbmVsQWN0aW9uPy5uYW1lfX08L2J1dHRvbj5cclxuICAgICAgICAgICAgICAgIDxidXR0b24gKGNsaWNrKT1cInpvb21PdXRBY3Rpb24/LnBlcmZvcm0oKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJ6b29tT3V0QWN0aW9uPy5kaXNhYmxlZFwiPnt7em9vbU91dEFjdGlvbj8ubmFtZX19PC9idXR0b24+XHJcbiAgICAgICAgICAgICAgICA8YnV0dG9uIChjbGljayk9XCJ6b29tSW5BY3Rpb24/LnBlcmZvcm0oKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJ6b29tSW5BY3Rpb24/LmRpc2FibGVkXCI+e3t6b29tSW5BY3Rpb24/Lm5hbWV9fTwvYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwiem9vbVNlbGVjdGVkQWN0aW9uPy5wZXJmb3JtKClcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbZGlzYWJsZWRdPVwiem9vbVNlbGVjdGVkQWN0aW9uPy5kaXNhYmxlZFwiPnt7em9vbVNlbGVjdGVkQWN0aW9uPy5uYW1lfX08L2J1dHRvbj5cclxuICAgICAgICAgICAgPC9maWVsZHNldD5cclxuICAgICAgICAgICAgPGZpZWxkc2V0PlxyXG4gICAgICAgICAgICAgICAgPGxlZ2VuZD5TZWxlY3Rpb248L2xlZ2VuZD5cclxuICAgICAgICAgICAgICAgIHt7YXVkaW9DbGlwPy5zZWxlY3Rpb24/LmxlZnRGcmFtZX19IDxzcGFuXHJcbiAgICAgICAgICAgICAgICAgICAgKm5nSWY9XCJhdWRpb0NsaXA/LnNlbGVjdGlvblwiPnRvPC9zcGFuPiB7e2F1ZGlvQ2xpcD8uc2VsZWN0aW9uPy5yaWdodEZyYW1lfX1cclxuICAgICAgICAgICAgICAgIDxidXR0b24gKGNsaWNrKT1cImNsZWFyU2VsZWN0aW9uKClcIiBbZGlzYWJsZWRdPVwiYXVkaW9DbGlwPy5zZWxlY3Rpb249PW51bGxcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbc3R5bGUuY29sb3JdPVwiaGFzU2VsZWN0aW9uKCkgPyAncmVkJyA6ICdncmV5J1wiIG1hdFRvb2x0aXA9XCJDbGVhciBzZWxlY3Rpb25cIj5cclxuICAgICAgICAgICAgICAgICAgICA8bWF0LWljb24+Y2xlYXI8L21hdC1pY29uPlxyXG4gICAgICAgICAgICAgICAgPC9idXR0b24+XHJcblxyXG4gICAgICAgICAgICA8L2ZpZWxkc2V0PlxyXG4gICAgICAgIDwvZGl2PmAsXHJcbiAgICBzdHlsZXM6IFtcclxuICAgICAgICBgOmhvc3Qge1xyXG4gICAgICAgIGZsZXg6IDA7XHJcblxyXG4gICAgICB9YF1cclxuXHJcbiAgfSlcclxuXHRleHBvcnQgY2xhc3MgQXVkaW9EaXNwbGF5Q29udHJvbCB7XHJcblxyXG4gICAgQElucHV0KCkgYXVkaW9DbGlwOiBBdWRpb0NsaXB8bnVsbD1udWxsO1xyXG5cclxuICAgIEBWaWV3Q2hpbGQoTWF0Q2hlY2tib3gsIHsgc3RhdGljOiB0cnVlIH0pXHJcbiAgICBwcml2YXRlIGF1dG9wbGF5U2VsZWN0ZWRDaGVja2JveDogTWF0Q2hlY2tib3h8bnVsbD1udWxsO1xyXG4gICAgQElucHV0KCkgcGxheVN0YXJ0QWN0aW9uOiBBY3Rpb248dm9pZD58dW5kZWZpbmVkO1xyXG4gICAgQElucHV0KCkgcGxheVNlbGVjdGlvbkFjdGlvbjogQWN0aW9uPHZvaWQ+fHVuZGVmaW5lZDtcclxuICAgIEBJbnB1dCgpIHBsYXlTdG9wQWN0aW9uOiBBY3Rpb248dm9pZD58dW5kZWZpbmVkO1xyXG4gICAgQElucHV0KCkgem9vbUluQWN0aW9uOiBBY3Rpb248dm9pZD58bnVsbD1udWxsO1xyXG4gICAgQElucHV0KCkgem9vbU91dEFjdGlvbjogQWN0aW9uPHZvaWQ+fG51bGw9bnVsbDtcclxuICAgIEBJbnB1dCgpIHpvb21GaXRUb1BhbmVsQWN0aW9uOiBBY3Rpb248dm9pZD58dW5kZWZpbmVkO1xyXG4gICAgQElucHV0KCkgem9vbVNlbGVjdGVkQWN0aW9uOiBBY3Rpb248dm9pZD58dW5kZWZpbmVkO1xyXG4gICAgQElucHV0KCkgYXV0b1BsYXlPblNlbGVjdFRvZ2dsZUFjdGlvbjogQWN0aW9uPGJvb2xlYW4+fHVuZGVmaW5lZDtcclxuXHQgICBzdGF0dXM6c3RyaW5nfG51bGw9bnVsbDtcclxuXHJcblx0XHRhdWRpbzphbnk7XHJcblxyXG5cdFx0Y29uc3RydWN0b3IoKSB7fVxyXG5cclxuICAgIGNsZWFyU2VsZWN0aW9uKCl7XHJcbiAgICAgICAgaWYodGhpcy5hdWRpb0NsaXAhPW51bGwpe1xyXG4gICAgICAgICAgICB0aGlzLmF1ZGlvQ2xpcC5zZWxlY3Rpb249bnVsbFxyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICAgIGhhc1NlbGVjdGlvbigpOmJvb2xlYW57XHJcbiAgICAgICAgICBsZXQgaHM9ZmFsc2U7XHJcbiAgICAgICAgICBpZih0aGlzLmF1ZGlvQ2xpcCl7XHJcbiAgICAgICAgICAgICAgaHM9KHRoaXMuYXVkaW9DbGlwLnNlbGVjdGlvbiE9bnVsbCk7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgICByZXR1cm4gaHM7XHJcbiAgICAgIH1cclxuXHJcbiAgICBhdXRvUGxheVNlbGVjdGlvbkNoYW5nZShjaDogTWF0Q2hlY2tib3hDaGFuZ2UpIHtcclxuICAgICAgICBpZiAodGhpcy5hdXRvUGxheU9uU2VsZWN0VG9nZ2xlQWN0aW9uKSB7XHJcbiAgICAgICAgICAgIHRoaXMuYXV0b1BsYXlPblNlbGVjdFRvZ2dsZUFjdGlvbi5wZXJmb3JtKGNoLmNoZWNrZWQpXHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuXHRcdGVycm9yKCl7XHJcblx0XHRcdHRoaXMuc3RhdHVzID0gJ0VSUk9SJztcclxuXHRcdH1cclxuXHJcblxyXG4gICAgfVxyXG5cclxuIl19