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
@@ -1,5 +1,6 @@
1
1
  import { DSPUtils } from "../../dsp/utils";
2
2
  import { Arrays, WorkerHelper } from "../../utils/utils";
3
+ import { Observable } from "rxjs";
3
4
  export const MIN_DB_LEVEL = -40.0;
4
5
  export class LevelInfo {
5
6
  constructor(channelCount, startFrame = 0, frameLength = 0, minLinLevels, maxLinLevels) {
@@ -83,108 +84,230 @@ export class LevelInfos {
83
84
  return this.peakLevelInfo.frameLength / this.bufferLevelInfos.length;
84
85
  }
85
86
  }
86
- export class PeakLevelInterceptor {
87
- constructor(levelListener) {
88
- this.levelListener = levelListener;
89
- this._channelCount = 0;
90
- this._peakDbLvl = MIN_DB_LEVEL;
91
- }
92
- get peakDbLvl() {
93
- return this._peakDbLvl;
94
- }
95
- get channelCount() {
96
- return this._channelCount;
97
- }
98
- set channelCount(value) {
99
- this._channelCount = value;
100
- if (this.levelListener) {
101
- this.levelListener.channelCount = value;
102
- }
103
- }
104
- update(levelInfo, peakLevelInfo) {
105
- let peakDBVal = levelInfo.powerLevelDB();
106
- if (this.peakDbLvl < peakDBVal) {
107
- this._peakDbLvl = peakDBVal;
108
- }
109
- }
110
- streamFinished() {
111
- if (this.levelListener) {
112
- this.levelListener.streamFinished();
113
- }
114
- }
115
- reset() {
116
- this._peakDbLvl = MIN_DB_LEVEL;
117
- if (this.levelListener) {
118
- this.levelListener.reset();
119
- }
120
- }
121
- }
122
87
  export class LevelMeasure {
123
- //private bufferLevelInfos=new Array<LevelInfo>();
124
- //private peakLevelInfo!:LevelInfo;
125
88
  constructor() {
126
- this.worker = null;
127
89
  this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction);
128
90
  }
129
91
  calcBufferLevelInfos(audioDataHolder, bufferTimeLength) {
130
- return new Promise((resolve) => {
92
+ return new Observable(subscriber => {
131
93
  let chs = audioDataHolder.numberOfChannels;
132
94
  let bufferFrameLength = Math.round(audioDataHolder.sampleRate * bufferTimeLength);
133
95
  let ais = audioDataHolder.audioInputStream();
134
- let audioBuffers = new Array(chs);
135
- let trBuffers = new Array(chs);
136
- for (let ch = 0; ch < chs; ch++) {
137
- audioBuffers[ch] = new Float32Array(bufferFrameLength);
138
- }
139
- let bufferLevelInfos = new Array();
140
- let peakLevelInfo = new LevelInfo(chs);
141
- this.worker = new Worker(this.workerURL);
142
- this.worker.onmessage = (me) => {
143
- if (me.data.linLevelBuffers) {
144
- let linLevelArrs = new Array(chs);
145
- for (let ch = 0; ch < chs; ch++) {
146
- linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);
147
- }
148
- let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);
149
- let framePos = 0;
150
- for (let bi = 0; bi < bufferCount; bi++) {
151
- let minLevels = new Array(chs);
152
- let maxLevels = new Array(chs);
96
+ // Test: Check CRC
97
+ //let crcVal:number=0;
98
+ //let crclen:number=0;
99
+ if (ais) {
100
+ let audioBuffers = new Array(chs);
101
+ let trBuffers = new Array(chs);
102
+ for (let ch = 0; ch < chs; ch++) {
103
+ audioBuffers[ch] = new Float32Array(bufferFrameLength);
104
+ }
105
+ let bufferLevelInfos = new Array();
106
+ let peakLevelInfo = new LevelInfo(chs);
107
+ let worker = new Worker(this.workerURL);
108
+ worker.onmessage = (me) => {
109
+ if (me.data.linLevelBuffers) {
110
+ let linLevelArrs = new Array(chs);
153
111
  for (let ch = 0; ch < chs; ch++) {
154
- let linLvlArrPos = bi * 2;
155
- minLevels[ch] = linLevelArrs[ch][linLvlArrPos];
156
- maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];
112
+ linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);
157
113
  }
158
- let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);
159
- bufferLevelInfos.push(bli);
160
- peakLevelInfo.merge(bli);
114
+ let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);
115
+ let framePos = 0;
116
+ for (let bi = 0; bi < bufferCount; bi++) {
117
+ let minLevels = new Array(chs);
118
+ let maxLevels = new Array(chs);
119
+ for (let ch = 0; ch < chs; ch++) {
120
+ let linLvlArrPos = bi * 2;
121
+ minLevels[ch] = linLevelArrs[ch][linLvlArrPos];
122
+ maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];
123
+ }
124
+ let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);
125
+ bufferLevelInfos.push(bli);
126
+ peakLevelInfo.merge(bli);
127
+ }
128
+ }
129
+ if (me.data.eod === true) {
130
+ // end of data, terminate worker and return result
131
+ //this.terminateWorker();
132
+ worker.terminate();
133
+ ais?.close();
134
+ //console.debug("Audio input stream CRC hex: "+crcVal.toString(16)+", crcLen: "+crclen+", buffer frame len: "+bufferFrameLength);
135
+ subscriber.next(new LevelInfos(bufferLevelInfos, peakLevelInfo));
136
+ subscriber.complete();
161
137
  }
138
+ else {
139
+ if (ais) {
140
+ let read = ais.read(audioBuffers);
141
+ // TEST:
142
+ // if(audioBuffers && audioBuffers.length>0) {
143
+ // crcVal = crc32(audioBuffers[0].buffer, crcVal);
144
+ // crclen += audioBuffers[0].buffer.byteLength;
145
+ // //console.debug("trBuffers.length: "+trBuffers[0].length+", CRC len: "+crclen);
146
+ // }else{
147
+ // console.debug("audioBuffers not avail!");
148
+ // }
149
+ for (let ch = 0; ch < chs; ch++) {
150
+ // let copy = new Float32Array(audioBuffers[ch]);
151
+ // trBuffers[ch] = copy.buffer;
152
+ const arrAbBufCh = audioBuffers[ch];
153
+ const adLen = arrAbBufCh.buffer.byteLength;
154
+ if (!trBuffers[ch] || trBuffers[ch].byteLength !== adLen) {
155
+ trBuffers[ch] = new ArrayBuffer(adLen);
156
+ }
157
+ let fAdaCh = new Float32Array(trBuffers[ch]);
158
+ fAdaCh.set(audioBuffers[ch]);
159
+ }
160
+ worker.postMessage({
161
+ bufferFrameLength: bufferFrameLength,
162
+ audioData: trBuffers,
163
+ chs: chs,
164
+ len: read
165
+ }, trBuffers);
166
+ }
167
+ }
168
+ };
169
+ let read = ais.read(audioBuffers);
170
+ // TEST:
171
+ // if(audioBuffers && audioBuffers.length>0) {
172
+ // crcVal = crc32(audioBuffers[0].buffer, crcVal);
173
+ // crclen += audioBuffers[0].buffer.byteLength;
174
+ // //console.debug("trBuffers.length: "+trBuffers[0].length+", CRC len: "+crclen);
175
+ // }else{
176
+ // console.debug("audioBuffers not avail!");
177
+ // }
178
+ for (let ch = 0; ch < chs; ch++) {
179
+ // let copy = new Float32Array(audioBuffers[ch]);
180
+ // trBuffers[ch] = copy.buffer;
181
+ const arrAbBufCh = audioBuffers[ch];
182
+ const adLen = arrAbBufCh.buffer.byteLength;
183
+ if (!trBuffers[ch] || trBuffers[ch].byteLength !== adLen) {
184
+ trBuffers[ch] = new ArrayBuffer(adLen);
185
+ }
186
+ let fAdaCh = new Float32Array(trBuffers[ch]);
187
+ fAdaCh.set(audioBuffers[ch]);
162
188
  }
163
- if (me.data.eod === true) {
164
- // end of data, terminate worker and return result
165
- this.terminateWorker();
166
- resolve(new LevelInfos(bufferLevelInfos, peakLevelInfo));
189
+ worker.postMessage({
190
+ bufferFrameLength: bufferFrameLength,
191
+ audioData: trBuffers,
192
+ chs: chs,
193
+ len: read
194
+ }, trBuffers);
195
+ }
196
+ else {
197
+ let aAis = audioDataHolder.asyncAudioInputStream();
198
+ let audioBuffers = new Array(chs);
199
+ let trBuffers = new Array(chs);
200
+ for (let ch = 0; ch < chs; ch++) {
201
+ audioBuffers[ch] = new Float32Array(bufferFrameLength);
167
202
  }
168
- else {
169
- let read = ais.read(audioBuffers);
170
- for (let ch = 0; ch < chs; ch++) {
171
- let copy = new Float32Array(audioBuffers[ch]);
172
- trBuffers[ch] = copy.buffer;
203
+ let bufferLevelInfos = new Array();
204
+ let peakLevelInfo = new LevelInfo(chs);
205
+ let worker = new Worker(this.workerURL);
206
+ worker.onmessage = (me) => {
207
+ if (subscriber.closed) {
208
+ // subscriber abandoned
209
+ worker.terminate();
210
+ ais?.close();
211
+ aAis?.close();
173
212
  }
174
- this.worker?.postMessage({ bufferFrameLength: bufferFrameLength, audioData: trBuffers, chs: chs, len: read }, trBuffers);
175
- }
176
- };
177
- let read = ais.read(audioBuffers);
178
- for (let ch = 0; ch < chs; ch++) {
179
- let copy = new Float32Array(audioBuffers[ch]);
180
- trBuffers[ch] = copy.buffer;
213
+ else {
214
+ if (me.data.linLevelBuffers) {
215
+ let linLevelArrs = new Array(chs);
216
+ for (let ch = 0; ch < chs; ch++) {
217
+ linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);
218
+ }
219
+ let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);
220
+ let framePos = 0;
221
+ for (let bi = 0; bi < bufferCount; bi++) {
222
+ let minLevels = new Array(chs);
223
+ let maxLevels = new Array(chs);
224
+ for (let ch = 0; ch < chs; ch++) {
225
+ let linLvlArrPos = bi * 2;
226
+ minLevels[ch] = linLevelArrs[ch][linLvlArrPos];
227
+ maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];
228
+ }
229
+ let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);
230
+ bufferLevelInfos.push(bli);
231
+ peakLevelInfo.merge(bli);
232
+ }
233
+ }
234
+ if (me.data.eod === true) {
235
+ // end of data, terminate worker and return result
236
+ //this.terminateWorker();
237
+ worker.terminate();
238
+ ais?.close();
239
+ aAis?.close();
240
+ //console.debug("Audio input stream CRC hex: "+crcVal.toString(16)+", crcLen: "+crclen+", buffer frame len: "+bufferFrameLength);
241
+ subscriber.next(new LevelInfos(bufferLevelInfos, peakLevelInfo));
242
+ subscriber.complete();
243
+ }
244
+ else {
245
+ if (aAis) {
246
+ aAis?.readObs(audioBuffers).subscribe({
247
+ next: (read) => {
248
+ // TEST:
249
+ // if(audioBuffers && audioBuffers.length>0) {
250
+ // crcVal = crc32(audioBuffers[0].buffer, crcVal);
251
+ // crclen += audioBuffers[0].buffer.byteLength;
252
+ // //console.debug("trBuffers.length: "+trBuffers[0].length+", CRC len: "+crclen);
253
+ // }else{
254
+ // console.debug("audioBuffers not avail!");
255
+ // }
256
+ for (let ch = 0; ch < chs; ch++) {
257
+ // let copy = new Float32Array(audioBuffers[ch]);
258
+ // trBuffers[ch] = copy.buffer;
259
+ const arrAbBufCh = audioBuffers[ch];
260
+ const adLen = arrAbBufCh.buffer.byteLength;
261
+ if (!trBuffers[ch] || trBuffers[ch].byteLength !== adLen) {
262
+ trBuffers[ch] = new ArrayBuffer(adLen);
263
+ }
264
+ let fAdaCh = new Float32Array(trBuffers[ch]);
265
+ fAdaCh.set(audioBuffers[ch]);
266
+ }
267
+ worker.postMessage({
268
+ bufferFrameLength: bufferFrameLength,
269
+ audioData: trBuffers,
270
+ chs: chs,
271
+ len: read
272
+ }, trBuffers);
273
+ }
274
+ });
275
+ }
276
+ }
277
+ }
278
+ };
279
+ aAis?.readObs(audioBuffers).subscribe({
280
+ next: (read) => {
281
+ // TEST:
282
+ // if(audioBuffers && audioBuffers.length>0) {
283
+ // crcVal = crc32(audioBuffers[0].buffer, crcVal);
284
+ // crclen += audioBuffers[0].buffer.byteLength;
285
+ // //console.debug("trBuffers.length: "+trBuffers[0].length+", CRC len: "+crclen);
286
+ // }else{
287
+ // console.debug("audioBuffers not avail!");
288
+ // }
289
+ for (let ch = 0; ch < chs; ch++) {
290
+ // let copy = new Float32Array(audioBuffers[ch]);
291
+ // trBuffers[ch] = copy.buffer;
292
+ const arrAbBufCh = audioBuffers[ch];
293
+ const adLen = arrAbBufCh.buffer.byteLength;
294
+ if (!trBuffers[ch] || trBuffers[ch].byteLength !== adLen) {
295
+ trBuffers[ch] = new ArrayBuffer(adLen);
296
+ }
297
+ let fAdaCh = new Float32Array(trBuffers[ch]);
298
+ fAdaCh.set(audioBuffers[ch]);
299
+ }
300
+ worker.postMessage({
301
+ bufferFrameLength: bufferFrameLength,
302
+ audioData: trBuffers,
303
+ chs: chs,
304
+ len: read
305
+ }, trBuffers);
306
+ }
307
+ });
181
308
  }
182
- this.worker?.postMessage({ bufferFrameLength: bufferFrameLength, audioData: trBuffers, chs: chs, len: read }, trBuffers);
183
309
  });
184
310
  }
185
- terminateWorker() {
186
- this.worker?.terminate();
187
- }
188
311
  /*
189
312
  * Method used as worker code.
190
313
  */
@@ -284,7 +407,7 @@ export class StreamLevelMeasure {
284
407
  minLevels[ch] = fls[0];
285
408
  maxLevels[ch] = fls[1];
286
409
  }
287
- let bi = new LevelInfo(this.channelCount, this.frameCount, me.data.fraemLength, minLevels, maxLevels);
410
+ let bi = new LevelInfo(this.channelCount, this.frameCount, me.data.frameLength, minLevels, maxLevels);
288
411
  this.updateLevels(bi);
289
412
  }
290
413
  };
@@ -380,7 +503,7 @@ export class StreamLevelMeasure {
380
503
  let peakDBVal = bufferLevelInfo.powerLevelDB();
381
504
  if (this.peakLevelInDb < peakDBVal) {
382
505
  this.peakLevelInDb = peakDBVal;
383
- // the event comes from outside of an Angular zone
506
+ // the event comes from outside an Angular zone
384
507
  this.peakLevelListener(this.peakLevelInDb);
385
508
  }
386
509
  }
@@ -390,4 +513,4 @@ export class StreamLevelMeasure {
390
513
  this.worker?.terminate();
391
514
  }
392
515
  }
393
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"level_measure.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/dsp/level_measure.ts"],"names":[],"mappings":"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","sourcesContent":["import {DSPUtils} from \"../../dsp/utils\";\r\nimport {SequenceAudioFloat32OutStream} from \"../io/stream\";\r\nimport {Arrays, WorkerHelper} from \"../../utils/utils\";\r\nimport {AudioDataHolder} from \"../audio_data_holder\";\r\n\r\nexport const MIN_DB_LEVEL = -40.0;\r\n\r\n\r\n\r\nexport class LevelInfo {\r\n\r\n  private readonly _minLinLevels: Array<number>;\r\n  private readonly _maxLinLevels: Array<number>;\r\n\r\n  constructor(public readonly channelCount: number,\r\n              public startFrame: number = 0,\r\n              public frameLength: number = 0,\r\n              minLinLevels?: Array<number>,\r\n              maxLinLevels?: Array<number>) {\r\n    this._minLinLevels = this.checkOrInitArray(minLinLevels);\r\n    this._maxLinLevels = this.checkOrInitArray(maxLinLevels);\r\n  }\r\n\r\n  get minLinLevels() {\r\n    return this._minLinLevels;\r\n  }\r\n\r\n  get maxLinLevels() {\r\n    return this._maxLinLevels;\r\n  }\r\n\r\n  private checkOrInitArray(arr: Array<number> | undefined): Array<number> {\r\n    if (arr) {\r\n      if (arr.length !== this.channelCount)\r\n        throw  new Error(\"Level arrays must be equal to channel count \" + this.channelCount);\r\n      return arr;\r\n    } else {\r\n      return new Array<number>(this.channelCount)\r\n    }\r\n  }\r\n\r\n  merge(levelInfo: LevelInfo) {\r\n    if (levelInfo === null) {\r\n      return;\r\n    }\r\n    if (this.channelCount !== levelInfo.channelCount) {\r\n      throw new Error(\"Channel count of level info to merge must be equal. (\" + this.channelCount + \" != \" + levelInfo.channelCount + \")\");\r\n    }\r\n\r\n    let endFrame = this.startFrame + this.frameLength;\r\n    let mergeEndFrame = levelInfo.startFrame + levelInfo.frameLength;\r\n\r\n    if (levelInfo.startFrame < this.startFrame) {\r\n      this.startFrame = levelInfo.startFrame;\r\n    }\r\n\r\n    if (mergeEndFrame > endFrame) {\r\n      this.frameLength = mergeEndFrame - this.startFrame;\r\n    }\r\n\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n\r\n      if (levelInfo.minLinLevels[ch] < this.minLinLevels[ch]) {\r\n        this.minLinLevels[ch] = levelInfo.minLinLevels[ch];\r\n      }\r\n      if (levelInfo.maxLinLevels[ch] > this.maxLinLevels[ch]) {\r\n        this.maxLinLevels[ch] = levelInfo.maxLinLevels[ch];\r\n      }\r\n    }\r\n  }\r\n\r\n  levelsLin(): Array<number> {\r\n    let lvlsLin = new Array<number>(this.channelCount);\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n      lvlsLin[ch] = Math.max(Math.abs(this.minLinLevels[ch]), Math.abs(this.maxLinLevels[ch]));\r\n    }\r\n    return lvlsLin;\r\n  }\r\n\r\n  powerLevelsDB(): Array<number> {\r\n    let lvlsDb = new Array<number>(this.channelCount);\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n      lvlsDb[ch] = DSPUtils.toPowerLevelInDB(this.levelsLin()[ch]);\r\n    }\r\n    return lvlsDb;\r\n  }\r\n\r\n  powerLevelDB(): number {\r\n    let pLvlsDb = this.powerLevelsDB();\r\n    return Math.max(...pLvlsDb);\r\n  }\r\n\r\n  clone(): LevelInfo {\r\n    return new LevelInfo(this.channelCount, this.startFrame, this.frameLength, Arrays.cloneNumberArray(this.minLinLevels),\r\n      Arrays.cloneNumberArray(this.maxLinLevels));\r\n  }\r\n}\r\n\r\nexport class LevelInfos {\r\n  constructor(public readonly bufferLevelInfos: Array<LevelInfo>, public readonly peakLevelInfo: LevelInfo) {\r\n  }\r\n\r\n  framesPerBuffer():number{\r\n    if(this.bufferLevelInfos.length>0){\r\n      return this.bufferLevelInfos[0].frameLength;\r\n    }\r\n    return this.peakLevelInfo.frameLength/this.bufferLevelInfos.length;\r\n  }\r\n}\r\n\r\n\r\nexport interface LevelListener {\r\n  channelCount: number;\r\n\r\n  update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo): void;\r\n\r\n  streamFinished(): void;\r\n\r\n  reset(): void;\r\n}\r\n\r\nexport interface PeakLevelListener {\r\n  update(peakLevel:number): void;\r\n}\r\n\r\nexport interface PeakLevelListener {\r\n\r\n  update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo): void;\r\n\r\n  streamFinished(): void;\r\n\r\n  reset(): void;\r\n}\r\n\r\nexport class PeakLevelInterceptor implements LevelListener{\r\n  get peakDbLvl(): number {\r\n    return this._peakDbLvl;\r\n  }\r\n  get channelCount(): number {\r\n    return this._channelCount;\r\n  }\r\n\r\n  set channelCount(value: number) {\r\n    this._channelCount = value;\r\n    if(this.levelListener){\r\n      this.levelListener.channelCount=value;\r\n    }\r\n  }\r\n\r\n  private _channelCount: number=0;\r\n\r\n  private _peakDbLvl = MIN_DB_LEVEL;\r\n\r\n\r\n\r\n  constructor(private levelListener?:LevelListener) {}\r\n\r\n  update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo): void{\r\n    let peakDBVal = levelInfo.powerLevelDB();\r\n    if (this.peakDbLvl < peakDBVal) {\r\n      this._peakDbLvl = peakDBVal;\r\n    }\r\n  }\r\n\r\n  streamFinished(): void{\r\n    if(this.levelListener){\r\n      this.levelListener.streamFinished();\r\n    }\r\n  }\r\n\r\n  reset(): void{\r\n    this._peakDbLvl = MIN_DB_LEVEL;\r\n    if(this.levelListener){\r\n      this.levelListener.reset();\r\n    }\r\n  }\r\n}\r\n\r\ndeclare function postMessage(message: any, transfer?: Array<any>): void;\r\n\r\n\r\nexport class LevelMeasure {\r\n\r\n  private readonly workerURL: string;\r\n  private worker: Worker|null=null;\r\n  //private bufferLevelInfos=new Array<LevelInfo>();\r\n  //private peakLevelInfo!:LevelInfo;\r\n\r\n  constructor() {\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n  }\r\n\r\n  calcBufferLevelInfos(audioDataHolder:AudioDataHolder, bufferTimeLength: number): Promise<LevelInfos> {\r\n    return new Promise<LevelInfos>((resolve)=>{\r\n      let chs = audioDataHolder.numberOfChannels;\r\n      let bufferFrameLength=Math.round(audioDataHolder.sampleRate*bufferTimeLength);\r\n      let ais=audioDataHolder.audioInputStream();\r\n      let audioBuffers = new Array<Float32Array>(chs);\r\n      let trBuffers=new Array<any>(chs);\r\n      for (let ch = 0; ch < chs; ch++) {\r\n        audioBuffers[ch]=new Float32Array(bufferFrameLength);\r\n      }\r\n      let bufferLevelInfos=new Array<LevelInfo>();\r\n      let peakLevelInfo=new LevelInfo(chs);\r\n\r\n\r\n      this.worker = new Worker(this.workerURL);\r\n      this.worker.onmessage = (me) => {\r\n\r\n        if(me.data.linLevelBuffers) {\r\n          let linLevelArrs = new Array<Float32Array>(chs);\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);\r\n          }\r\n\r\n          let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);\r\n          let framePos = 0;\r\n\r\n          for (let bi = 0; bi < bufferCount; bi++) {\r\n            let minLevels = new Array<number>(chs);\r\n            let maxLevels = new Array<number>(chs);\r\n            for (let ch = 0; ch < chs; ch++) {\r\n              let linLvlArrPos = bi * 2;\r\n              minLevels[ch] = linLevelArrs[ch][linLvlArrPos];\r\n              maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];\r\n            }\r\n            let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);\r\n            bufferLevelInfos.push(bli);\r\n            peakLevelInfo.merge(bli);\r\n          }\r\n\r\n        }\r\n        if(me.data.eod===true) {\r\n          // end of data, terminate worker and return result\r\n          this.terminateWorker();\r\n          resolve(new LevelInfos(bufferLevelInfos, peakLevelInfo));\r\n        }else{\r\n          let read=ais.read(audioBuffers);\r\n          for(let ch=0;ch<chs;ch++){\r\n            let copy=new Float32Array(audioBuffers[ch]);\r\n            trBuffers[ch]=copy.buffer;\r\n          }\r\n          this.worker?.postMessage({bufferFrameLength: bufferFrameLength, audioData: trBuffers, chs: chs,len:read}, trBuffers);\r\n        }\r\n      };\r\n\r\n      let read=ais.read(audioBuffers);\r\n      for(let ch=0;ch<chs;ch++){\r\n        let copy=new Float32Array(audioBuffers[ch]);\r\n        trBuffers[ch]=copy.buffer;\r\n      }\r\n      this.worker?.postMessage({bufferFrameLength: bufferFrameLength, audioData: trBuffers, chs: chs,len:read}, trBuffers);\r\n    });\r\n\r\n  }\r\n\r\n\r\n  private terminateWorker() {\r\n    this.worker?.terminate();\r\n\r\n  }\r\n\r\n  /*\r\n   *  Method used as worker code.\r\n   */\r\n  workerFunction() {\r\n    self.onmessage = function (msg:MessageEvent) {\r\n\r\n      let len=msg.data.len;\r\n      let bufferFrameLength = msg.data.bufferFrameLength;\r\n      if(len==-1){\r\n        // start\r\n        postMessage({\r\n          eod:false,\r\n          bufferFrameLength: bufferFrameLength,\r\n          frameLength: len\r\n        });\r\n      }\r\n\r\n      if(len==0) {\r\n        postMessage({\r\n          eod:true,\r\n          bufferFrameLength: bufferFrameLength,\r\n          frameLength: len\r\n        });\r\n      }else{\r\n        let chs = msg.data.chs;\r\n\r\n        let audioData = new Array<Float32Array>(chs);\r\n        let linLevels = new Array<Float32Array>(chs);\r\n\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          audioData[ch] = new Float32Array(msg.data.audioData[ch]);\r\n        }\r\n\r\n        //let frameLength = audioData[0].length;\r\n\r\n        let bufferCount = Math.ceil(len / bufferFrameLength);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevels[ch] = new Float32Array(bufferCount * 2);\r\n        }\r\n        if (audioData && chs > 0) {\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            let chData = audioData[ch];\r\n\r\n            for (let s = 0; s < len; s++) {\r\n              let bi = Math.floor(s / bufferFrameLength);\r\n              let lvlArrPos = bi * 2;\r\n              //let bs = s % bufferFrameLength;\r\n              let chSample = chData[s];\r\n              if (chSample < linLevels[ch][lvlArrPos]) {\r\n                linLevels[ch][lvlArrPos] = chSample;\r\n              }\r\n              lvlArrPos++;\r\n              if (chSample > linLevels[ch][lvlArrPos]) {\r\n                linLevels[ch][lvlArrPos] = chSample;\r\n              }\r\n            }\r\n          }\r\n          const linLevelBufs = new Array<any>(chs);\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            linLevelBufs[ch] = linLevels[ch].buffer;\r\n          }\r\n          postMessage({\r\n            eod:false,\r\n            bufferFrameLength: bufferFrameLength,\r\n            frameLength: len,\r\n            linLevelBuffers: linLevelBufs\r\n          }, linLevelBufs);\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n\r\nexport class StreamLevelMeasure implements SequenceAudioFloat32OutStream {\r\n\r\n  currentLevelInfos: LevelInfo|null=null;\r\n  peakLevelInfo: LevelInfo|null=null;\r\n\r\n  private readonly workerURL: string;\r\n  private worker: Worker|null=null;\r\n  private channelCount: number=0;\r\n  private bufferIndex: number = 0;\r\n  private frameCount: number = 0;\r\n\r\n  levelListener: LevelListener|null=null;\r\n  peakLevelListener: ((peakLvlInDb:number)=>void)|null=null;\r\n  private peakLevelInDb:number=MIN_DB_LEVEL;\r\n\r\n  constructor() {\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n  }\r\n\r\n  setFormat(channels: number, sampleRate: number) {\r\n    this.channelCount = channels;\r\n    this.currentLevelInfos = new LevelInfo(this.channelCount);\r\n    this.peakLevelInfo = new LevelInfo(this.channelCount);\r\n    this.worker = new Worker(this.workerURL);\r\n    this.worker.onmessage = (me) => {\r\n      let streamFinished = me.data.streamFinished;\r\n      if (streamFinished) {\r\n        if (this.levelListener) {\r\n          this.levelListener.streamFinished()\r\n        }\r\n      } else {\r\n\r\n        let minLevels = new Array<number>(this.channelCount);\r\n        let maxLevels = new Array<number>(this.channelCount);\r\n        for (let ch = 0; ch < this.channelCount; ch++) {\r\n          let fls = new Float32Array(me.data.linLevelBuffers[ch]);\r\n          minLevels[ch] = fls[0];\r\n          maxLevels[ch] = fls[1];\r\n        }\r\n        let bi = new LevelInfo(this.channelCount, this.frameCount, me.data.fraemLength, minLevels, maxLevels);\r\n        this.updateLevels(bi);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  nextStream() {\r\n    this.reset();\r\n  }\r\n\r\n  private reset() {\r\n    this.currentLevelInfos = new LevelInfo(this.channelCount);\r\n    this.peakLevelInfo = new LevelInfo(this.channelCount);\r\n    if (this.levelListener) {\r\n      this.levelListener.reset();\r\n      this.levelListener.channelCount = this.channelCount;\r\n    }\r\n    if (this.peakLevelListener) {\r\n      this.peakLevelInDb=MIN_DB_LEVEL;\r\n      this.peakLevelListener(this.peakLevelInDb);\r\n    }\r\n  }\r\n\r\n  write(bufferData: Array<Float32Array>): number {\r\n    let bufArrCopies = new Array<Float32Array>(bufferData.length);\r\n    let buffers = new Array<any>(bufferData.length);\r\n    for (let ch = 0; ch < bufferData.length; ch++) {\r\n      bufArrCopies[ch] = bufferData[ch].slice();\r\n      buffers[ch] = bufArrCopies[ch].buffer;\r\n    }\r\n    this.worker?.postMessage({\r\n      streamFinished: false,\r\n      audioData: buffers,\r\n      chs: this.channelCount,\r\n      bufferIndex: this.bufferIndex\r\n    }, buffers);\r\n    this.bufferIndex++;\r\n    return bufArrCopies[0].length;\r\n  }\r\n\r\n  flush() {\r\n    this.worker?.postMessage({streamFinished: true});\r\n\r\n  }\r\n\r\n  close() {\r\n      this.worker?.terminate();\r\n  }\r\n\r\n  /*\r\n   *  Method used as worker code.\r\n   */\r\n  workerFunction() {\r\n    self.onmessage = function (msg:MessageEvent) {\r\n      let streamFinished = msg.data.streamFinished;\r\n      if (streamFinished) {\r\n        postMessage({streamFinished: true});\r\n      } else {\r\n        let chs = msg.data.chs;\r\n        let frameLength = null;\r\n        let audioData = new Array<Float32Array>(chs);\r\n        let linLevels = new Array<Float32Array>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevels[ch] = new Float32Array(2);\r\n          audioData[ch] = new Float32Array(msg.data.audioData[ch]);\r\n        }\r\n\r\n        if (audioData) {\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            let chData = audioData[ch];\r\n            if (frameLength === null) {\r\n              frameLength = chData.length;\r\n            }\r\n            for (let s = 0; s < frameLength; s++) {\r\n              let chSample=chData[s];\r\n              if (chSample < linLevels[ch][0]) {\r\n                linLevels[ch][0] = chSample;\r\n              }\r\n              if (chSample > linLevels[ch][1]) {\r\n                linLevels[ch][1] = chSample;\r\n              }\r\n            }\r\n          }\r\n        }\r\n        let linLevelBufs = new Array<any>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevelBufs[ch] = linLevels[ch].buffer;\r\n        }\r\n        postMessage({streamFinished: false, frameLength: frameLength, linLevelBuffers: linLevelBufs}, linLevelBufs);\r\n      }\r\n    }\r\n  }\r\n\r\n  updateLevels(bufferLevelInfo: LevelInfo) {\r\n\r\n    this.currentLevelInfos = bufferLevelInfo;\r\n    if(this.peakLevelInfo) {\r\n      this.peakLevelInfo.merge(bufferLevelInfo);\r\n      if (this.levelListener) {\r\n        this.levelListener.update(this.currentLevelInfos, this.peakLevelInfo.clone());\r\n      }\r\n      if(this.peakLevelListener){\r\n        let peakDBVal = bufferLevelInfo.powerLevelDB();\r\n        if (this.peakLevelInDb < peakDBVal) {\r\n          this.peakLevelInDb = peakDBVal;\r\n          // the event comes from outside of an Angular zone\r\n          this.peakLevelListener(this.peakLevelInDb);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  stop() {\r\n    this.worker?.terminate();\r\n  }\r\n\r\n\r\n}\r\n"]}
516
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"level_measure.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/dsp/level_measure.ts"],"names":[],"mappings":"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","sourcesContent":["import {DSPUtils} from \"../../dsp/utils\";\r\nimport {SequenceAudioFloat32OutStream} from \"../io/stream\";\r\nimport {Arrays, WorkerHelper} from \"../../utils/utils\";\r\nimport {AudioDataHolder} from \"../audio_data_holder\";\r\nimport {Observable} from \"rxjs\";\r\n\r\nexport const MIN_DB_LEVEL = -40.0;\r\n\r\nexport class LevelInfo {\r\n\r\n  private readonly _minLinLevels: Array<number>;\r\n  private readonly _maxLinLevels: Array<number>;\r\n\r\n  constructor(public readonly channelCount: number,\r\n              public startFrame: number = 0,\r\n              public frameLength: number = 0,\r\n              minLinLevels?: Array<number>,\r\n              maxLinLevels?: Array<number>) {\r\n    this._minLinLevels = this.checkOrInitArray(minLinLevels);\r\n    this._maxLinLevels = this.checkOrInitArray(maxLinLevels);\r\n  }\r\n\r\n  get minLinLevels() {\r\n    return this._minLinLevels;\r\n  }\r\n\r\n  get maxLinLevels() {\r\n    return this._maxLinLevels;\r\n  }\r\n\r\n  private checkOrInitArray(arr: Array<number> | undefined): Array<number> {\r\n    if (arr) {\r\n      if (arr.length !== this.channelCount)\r\n        throw  new Error(\"Level arrays must be equal to channel count \" + this.channelCount);\r\n      return arr;\r\n    } else {\r\n      return new Array<number>(this.channelCount)\r\n    }\r\n  }\r\n\r\n  merge(levelInfo: LevelInfo) {\r\n    if (levelInfo === null) {\r\n      return;\r\n    }\r\n    if (this.channelCount !== levelInfo.channelCount) {\r\n      throw new Error(\"Channel count of level info to merge must be equal. (\" + this.channelCount + \" != \" + levelInfo.channelCount + \")\");\r\n    }\r\n\r\n    let endFrame = this.startFrame + this.frameLength;\r\n    let mergeEndFrame = levelInfo.startFrame + levelInfo.frameLength;\r\n\r\n    if (levelInfo.startFrame < this.startFrame) {\r\n      this.startFrame = levelInfo.startFrame;\r\n    }\r\n\r\n    if (mergeEndFrame > endFrame) {\r\n      this.frameLength = mergeEndFrame - this.startFrame;\r\n    }\r\n\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n\r\n      if (levelInfo.minLinLevels[ch] < this.minLinLevels[ch]) {\r\n        this.minLinLevels[ch] = levelInfo.minLinLevels[ch];\r\n      }\r\n      if (levelInfo.maxLinLevels[ch] > this.maxLinLevels[ch]) {\r\n        this.maxLinLevels[ch] = levelInfo.maxLinLevels[ch];\r\n      }\r\n    }\r\n  }\r\n\r\n  levelsLin(): Array<number> {\r\n    let lvlsLin = new Array<number>(this.channelCount);\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n      lvlsLin[ch] = Math.max(Math.abs(this.minLinLevels[ch]), Math.abs(this.maxLinLevels[ch]));\r\n    }\r\n    return lvlsLin;\r\n  }\r\n\r\n  powerLevelsDB(): Array<number> {\r\n    let lvlsDb = new Array<number>(this.channelCount);\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n      lvlsDb[ch] = DSPUtils.toPowerLevelInDB(this.levelsLin()[ch]);\r\n    }\r\n    return lvlsDb;\r\n  }\r\n\r\n  powerLevelDB(): number {\r\n    let pLvlsDb = this.powerLevelsDB();\r\n    return Math.max(...pLvlsDb);\r\n  }\r\n\r\n  clone(): LevelInfo {\r\n    return new LevelInfo(this.channelCount, this.startFrame, this.frameLength, Arrays.cloneNumberArray(this.minLinLevels),\r\n      Arrays.cloneNumberArray(this.maxLinLevels));\r\n  }\r\n}\r\n\r\nexport class LevelInfos {\r\n  constructor(public readonly bufferLevelInfos: Array<LevelInfo>, public readonly peakLevelInfo: LevelInfo) {\r\n  }\r\n\r\n  framesPerBuffer():number{\r\n    if(this.bufferLevelInfos.length>0){\r\n      return this.bufferLevelInfos[0].frameLength;\r\n    }\r\n    return this.peakLevelInfo.frameLength/this.bufferLevelInfos.length;\r\n  }\r\n}\r\n\r\n\r\nexport interface LevelListener {\r\n  channelCount: number;\r\n\r\n  update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo): void;\r\n\r\n  streamFinished(): void;\r\n\r\n  reset(): void;\r\n}\r\n\r\ndeclare function postMessage(message: any, transfer?: Array<any>): void;\r\n\r\nexport class LevelMeasure {\r\n\r\n  private readonly workerURL: string;\r\n\r\n  constructor() {\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction);\r\n  }\r\n\r\n  calcBufferLevelInfos(audioDataHolder:AudioDataHolder, bufferTimeLength: number): Observable<LevelInfos> {\r\n    return new Observable<LevelInfos>(subscriber => {\r\n\r\n      let chs = audioDataHolder.numberOfChannels;\r\n      let bufferFrameLength = Math.round(audioDataHolder.sampleRate * bufferTimeLength);\r\n\r\n      let ais = audioDataHolder.audioInputStream();\r\n      // Test: Check CRC\r\n      //let crcVal:number=0;\r\n      //let crclen:number=0;\r\n      if (ais) {\r\n\r\n        let audioBuffers = new Array<Float32Array>(chs);\r\n        let trBuffers = new Array<ArrayBuffer>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          audioBuffers[ch] = new Float32Array(bufferFrameLength);\r\n        }\r\n        let bufferLevelInfos = new Array<LevelInfo>();\r\n        let peakLevelInfo = new LevelInfo(chs);\r\n\r\n        let worker = new Worker(this.workerURL);\r\n        worker.onmessage = (me) => {\r\n\r\n          if (me.data.linLevelBuffers) {\r\n            let linLevelArrs = new Array<Float32Array>(chs);\r\n            for (let ch = 0; ch < chs; ch++) {\r\n              linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);\r\n            }\r\n\r\n            let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);\r\n            let framePos = 0;\r\n\r\n            for (let bi = 0; bi < bufferCount; bi++) {\r\n              let minLevels = new Array<number>(chs);\r\n              let maxLevels = new Array<number>(chs);\r\n              for (let ch = 0; ch < chs; ch++) {\r\n                let linLvlArrPos = bi * 2;\r\n                minLevels[ch] = linLevelArrs[ch][linLvlArrPos];\r\n                maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];\r\n              }\r\n              let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);\r\n              bufferLevelInfos.push(bli);\r\n              peakLevelInfo.merge(bli);\r\n            }\r\n\r\n          }\r\n          if (me.data.eod === true) {\r\n            // end of data, terminate worker and return result\r\n            //this.terminateWorker();\r\n            worker.terminate();\r\n            ais?.close();\r\n            //console.debug(\"Audio input stream CRC hex: \"+crcVal.toString(16)+\", crcLen: \"+crclen+\", buffer frame len: \"+bufferFrameLength);\r\n            subscriber.next(new LevelInfos(bufferLevelInfos, peakLevelInfo));\r\n            subscriber.complete();\r\n          } else {\r\n            if (ais) {\r\n              let read = ais.read(audioBuffers);\r\n              // TEST:\r\n              // if(audioBuffers && audioBuffers.length>0) {\r\n              //   crcVal = crc32(audioBuffers[0].buffer, crcVal);\r\n              //   crclen += audioBuffers[0].buffer.byteLength;\r\n              //   //console.debug(\"trBuffers.length: \"+trBuffers[0].length+\", CRC len: \"+crclen);\r\n              // }else{\r\n              //   console.debug(\"audioBuffers not avail!\");\r\n              // }\r\n              for (let ch = 0; ch < chs; ch++) {\r\n                // let copy = new Float32Array(audioBuffers[ch]);\r\n                // trBuffers[ch] = copy.buffer;\r\n                const arrAbBufCh=audioBuffers[ch];\r\n                const adLen = arrAbBufCh.buffer.byteLength;\r\n                if (!trBuffers[ch] || trBuffers[ch].byteLength !==  adLen) {\r\n                  trBuffers[ch] = new ArrayBuffer(adLen);\r\n                }\r\n                let fAdaCh=new Float32Array(trBuffers[ch]);\r\n                fAdaCh.set(audioBuffers[ch]);\r\n              }\r\n\r\n              worker.postMessage({\r\n                bufferFrameLength: bufferFrameLength,\r\n                audioData: trBuffers,\r\n                chs: chs,\r\n                len: read\r\n              }, trBuffers);\r\n            }\r\n          }\r\n        };\r\n\r\n        let read = ais.read(audioBuffers);\r\n        // TEST:\r\n        // if(audioBuffers && audioBuffers.length>0) {\r\n        //   crcVal = crc32(audioBuffers[0].buffer, crcVal);\r\n        //   crclen += audioBuffers[0].buffer.byteLength;\r\n        //   //console.debug(\"trBuffers.length: \"+trBuffers[0].length+\", CRC len: \"+crclen);\r\n        // }else{\r\n        //   console.debug(\"audioBuffers not avail!\");\r\n        // }\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          // let copy = new Float32Array(audioBuffers[ch]);\r\n          // trBuffers[ch] = copy.buffer;\r\n          const arrAbBufCh=audioBuffers[ch];\r\n          const adLen = arrAbBufCh.buffer.byteLength;\r\n          if (!trBuffers[ch] || trBuffers[ch].byteLength !==  adLen) {\r\n            trBuffers[ch] = new ArrayBuffer(adLen);\r\n          }\r\n          let fAdaCh=new Float32Array(trBuffers[ch]);\r\n          fAdaCh.set(audioBuffers[ch]);\r\n        }\r\n\r\n        worker.postMessage({\r\n          bufferFrameLength: bufferFrameLength,\r\n          audioData: trBuffers,\r\n          chs: chs,\r\n          len: read\r\n        }, trBuffers);\r\n      } else {\r\n\r\n        let aAis = audioDataHolder.asyncAudioInputStream();\r\n        let audioBuffers = new Array<Float32Array>(chs);\r\n        let trBuffers = new Array<any>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          audioBuffers[ch] = new Float32Array(bufferFrameLength);\r\n        }\r\n        let bufferLevelInfos = new Array<LevelInfo>();\r\n        let peakLevelInfo = new LevelInfo(chs);\r\n\r\n        let worker = new Worker(this.workerURL);\r\n        worker.onmessage = (me) => {\r\n\r\n          if (subscriber.closed) {\r\n            // subscriber abandoned\r\n            worker.terminate();\r\n            ais?.close();\r\n            aAis?.close();\r\n          }else {\r\n\r\n            if (me.data.linLevelBuffers) {\r\n              let linLevelArrs = new Array<Float32Array>(chs);\r\n              for (let ch = 0; ch < chs; ch++) {\r\n                linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);\r\n              }\r\n\r\n              let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);\r\n              let framePos = 0;\r\n\r\n              for (let bi = 0; bi < bufferCount; bi++) {\r\n                let minLevels = new Array<number>(chs);\r\n                let maxLevels = new Array<number>(chs);\r\n                for (let ch = 0; ch < chs; ch++) {\r\n                  let linLvlArrPos = bi * 2;\r\n                  minLevels[ch] = linLevelArrs[ch][linLvlArrPos];\r\n                  maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];\r\n                }\r\n                let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);\r\n                bufferLevelInfos.push(bli);\r\n                peakLevelInfo.merge(bli);\r\n              }\r\n\r\n            }\r\n            if (me.data.eod === true) {\r\n              // end of data, terminate worker and return result\r\n              //this.terminateWorker();\r\n              worker.terminate();\r\n              ais?.close();\r\n              aAis?.close();\r\n              //console.debug(\"Audio input stream CRC hex: \"+crcVal.toString(16)+\", crcLen: \"+crclen+\", buffer frame len: \"+bufferFrameLength);\r\n              subscriber.next(new LevelInfos(bufferLevelInfos, peakLevelInfo));\r\n              subscriber.complete();\r\n            } else {\r\n\r\n              if (aAis) {\r\n                aAis?.readObs(audioBuffers).subscribe({\r\n                    next: (read) => {\r\n                      // TEST:\r\n                      // if(audioBuffers && audioBuffers.length>0) {\r\n                      //   crcVal = crc32(audioBuffers[0].buffer, crcVal);\r\n                      //   crclen += audioBuffers[0].buffer.byteLength;\r\n                      //   //console.debug(\"trBuffers.length: \"+trBuffers[0].length+\", CRC len: \"+crclen);\r\n                      // }else{\r\n                      //   console.debug(\"audioBuffers not avail!\");\r\n                      // }\r\n                      for (let ch = 0; ch < chs; ch++) {\r\n\r\n                        // let copy = new Float32Array(audioBuffers[ch]);\r\n                        // trBuffers[ch] = copy.buffer;\r\n                        const arrAbBufCh=audioBuffers[ch];\r\n                        const adLen = arrAbBufCh.buffer.byteLength;\r\n                        if (!trBuffers[ch] || trBuffers[ch].byteLength !==  adLen) {\r\n                          trBuffers[ch] = new ArrayBuffer(adLen);\r\n                        }\r\n                        let fAdaCh=new Float32Array(trBuffers[ch]);\r\n                        fAdaCh.set(audioBuffers[ch]);\r\n                      }\r\n\r\n                      worker.postMessage({\r\n                        bufferFrameLength: bufferFrameLength,\r\n                        audioData: trBuffers,\r\n                        chs: chs,\r\n                        len: read\r\n                      }, trBuffers);\r\n                    }\r\n                  }\r\n                );\r\n              }\r\n            }\r\n          }\r\n        };\r\n\r\n        aAis?.readObs(audioBuffers).subscribe({\r\n            next: (read) => {\r\n              // TEST:\r\n              // if(audioBuffers && audioBuffers.length>0) {\r\n              //   crcVal = crc32(audioBuffers[0].buffer, crcVal);\r\n              //   crclen += audioBuffers[0].buffer.byteLength;\r\n              //   //console.debug(\"trBuffers.length: \"+trBuffers[0].length+\", CRC len: \"+crclen);\r\n              // }else{\r\n              //   console.debug(\"audioBuffers not avail!\");\r\n              // }\r\n              for (let ch = 0; ch < chs; ch++) {\r\n                // let copy = new Float32Array(audioBuffers[ch]);\r\n                // trBuffers[ch] = copy.buffer;\r\n\r\n                const arrAbBufCh=audioBuffers[ch];\r\n                const adLen = arrAbBufCh.buffer.byteLength;\r\n                if (!trBuffers[ch] || trBuffers[ch].byteLength !==  adLen) {\r\n                  trBuffers[ch] = new ArrayBuffer(adLen);\r\n                }\r\n                let fAdaCh=new Float32Array(trBuffers[ch]);\r\n                fAdaCh.set(audioBuffers[ch]);\r\n              }\r\n              worker.postMessage({\r\n                bufferFrameLength: bufferFrameLength,\r\n                audioData: trBuffers,\r\n                chs: chs,\r\n                len: read\r\n              }, trBuffers);\r\n            }\r\n          }\r\n        );\r\n      }\r\n    });\r\n  }\r\n\r\n  /*\r\n   *  Method used as worker code.\r\n   */\r\n  workerFunction() {\r\n    self.onmessage = function (msg:MessageEvent) {\r\n\r\n      let len=msg.data.len;\r\n      let bufferFrameLength = msg.data.bufferFrameLength;\r\n      if(len==-1){\r\n        // start\r\n        postMessage({\r\n          eod:false,\r\n          bufferFrameLength: bufferFrameLength,\r\n          frameLength: len\r\n        });\r\n      }\r\n\r\n      if(len==0) {\r\n        postMessage({\r\n          eod:true,\r\n          bufferFrameLength: bufferFrameLength,\r\n          frameLength: len\r\n        });\r\n      }else{\r\n        let chs = msg.data.chs;\r\n\r\n        let audioData = new Array<Float32Array>(chs);\r\n        let linLevels = new Array<Float32Array>(chs);\r\n\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          audioData[ch] = new Float32Array(msg.data.audioData[ch]);\r\n        }\r\n\r\n        //let frameLength = audioData[0].length;\r\n\r\n        let bufferCount = Math.ceil(len / bufferFrameLength);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevels[ch] = new Float32Array(bufferCount * 2);\r\n        }\r\n        if (audioData && chs > 0) {\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            let chData = audioData[ch];\r\n\r\n            for (let s = 0; s < len; s++) {\r\n              let bi = Math.floor(s / bufferFrameLength);\r\n              let lvlArrPos = bi * 2;\r\n              //let bs = s % bufferFrameLength;\r\n              let chSample = chData[s];\r\n              if (chSample < linLevels[ch][lvlArrPos]) {\r\n                linLevels[ch][lvlArrPos] = chSample;\r\n              }\r\n              lvlArrPos++;\r\n              if (chSample > linLevels[ch][lvlArrPos]) {\r\n                linLevels[ch][lvlArrPos] = chSample;\r\n              }\r\n            }\r\n          }\r\n          const linLevelBufs = new Array<any>(chs);\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            linLevelBufs[ch] = linLevels[ch].buffer;\r\n          }\r\n          postMessage({\r\n            eod:false,\r\n            bufferFrameLength: bufferFrameLength,\r\n            frameLength: len,\r\n            linLevelBuffers: linLevelBufs\r\n          }, linLevelBufs);\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n\r\nexport class StreamLevelMeasure implements SequenceAudioFloat32OutStream {\r\n\r\n  currentLevelInfos: LevelInfo|null=null;\r\n  peakLevelInfo: LevelInfo|null=null;\r\n\r\n  private readonly workerURL: string;\r\n  private worker: Worker|null=null;\r\n  private channelCount: number=0;\r\n  private bufferIndex: number = 0;\r\n  private frameCount: number = 0;\r\n\r\n  levelListener: LevelListener|null=null;\r\n  peakLevelListener: ((peakLvlInDb:number)=>void)|null=null;\r\n  private peakLevelInDb:number=MIN_DB_LEVEL;\r\n\r\n  constructor() {\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n  }\r\n\r\n  setFormat(channels: number, sampleRate: number) {\r\n    this.channelCount = channels;\r\n    this.currentLevelInfos = new LevelInfo(this.channelCount);\r\n    this.peakLevelInfo = new LevelInfo(this.channelCount);\r\n    this.worker = new Worker(this.workerURL);\r\n    this.worker.onmessage = (me) => {\r\n      let streamFinished = me.data.streamFinished;\r\n      if (streamFinished) {\r\n        if (this.levelListener) {\r\n          this.levelListener.streamFinished()\r\n        }\r\n      } else {\r\n\r\n        let minLevels = new Array<number>(this.channelCount);\r\n        let maxLevels = new Array<number>(this.channelCount);\r\n        for (let ch = 0; ch < this.channelCount; ch++) {\r\n          let fls = new Float32Array(me.data.linLevelBuffers[ch]);\r\n          minLevels[ch] = fls[0];\r\n          maxLevels[ch] = fls[1];\r\n        }\r\n        let bi = new LevelInfo(this.channelCount, this.frameCount, me.data.frameLength, minLevels, maxLevels);\r\n        this.updateLevels(bi);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  nextStream() {\r\n    this.reset();\r\n  }\r\n\r\n  private reset() {\r\n    this.currentLevelInfos = new LevelInfo(this.channelCount);\r\n    this.peakLevelInfo = new LevelInfo(this.channelCount);\r\n    if (this.levelListener) {\r\n      this.levelListener.reset();\r\n      this.levelListener.channelCount = this.channelCount;\r\n    }\r\n    if (this.peakLevelListener) {\r\n      this.peakLevelInDb=MIN_DB_LEVEL;\r\n      this.peakLevelListener(this.peakLevelInDb);\r\n    }\r\n  }\r\n\r\n  write(bufferData: Array<Float32Array>): number {\r\n    let bufArrCopies = new Array<Float32Array>(bufferData.length);\r\n    let buffers = new Array<any>(bufferData.length);\r\n    for (let ch = 0; ch < bufferData.length; ch++) {\r\n      bufArrCopies[ch] = bufferData[ch].slice();\r\n      buffers[ch] = bufArrCopies[ch].buffer;\r\n    }\r\n    this.worker?.postMessage({\r\n      streamFinished: false,\r\n      audioData: buffers,\r\n      chs: this.channelCount,\r\n      bufferIndex: this.bufferIndex\r\n    }, buffers);\r\n    this.bufferIndex++;\r\n    return bufArrCopies[0].length;\r\n  }\r\n\r\n  flush() {\r\n    this.worker?.postMessage({streamFinished: true});\r\n\r\n  }\r\n\r\n  close() {\r\n      this.worker?.terminate();\r\n  }\r\n\r\n  /*\r\n   *  Method used as worker code.\r\n   */\r\n  workerFunction() {\r\n    self.onmessage = function (msg:MessageEvent) {\r\n      let streamFinished = msg.data.streamFinished;\r\n      if (streamFinished) {\r\n        postMessage({streamFinished: true});\r\n      } else {\r\n        let chs = msg.data.chs;\r\n        let frameLength = null;\r\n        let audioData = new Array<Float32Array>(chs);\r\n        let linLevels = new Array<Float32Array>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevels[ch] = new Float32Array(2);\r\n          audioData[ch] = new Float32Array(msg.data.audioData[ch]);\r\n        }\r\n\r\n        if (audioData) {\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            let chData = audioData[ch];\r\n            if (frameLength === null) {\r\n              frameLength = chData.length;\r\n            }\r\n            for (let s = 0; s < frameLength; s++) {\r\n              let chSample=chData[s];\r\n              if (chSample < linLevels[ch][0]) {\r\n                linLevels[ch][0] = chSample;\r\n              }\r\n              if (chSample > linLevels[ch][1]) {\r\n                linLevels[ch][1] = chSample;\r\n              }\r\n            }\r\n          }\r\n        }\r\n        let linLevelBufs = new Array<any>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevelBufs[ch] = linLevels[ch].buffer;\r\n        }\r\n        postMessage({streamFinished: false, frameLength: frameLength, linLevelBuffers: linLevelBufs}, linLevelBufs);\r\n      }\r\n    }\r\n  }\r\n\r\n  updateLevels(bufferLevelInfo: LevelInfo) {\r\n\r\n    this.currentLevelInfos = bufferLevelInfo;\r\n    if(this.peakLevelInfo) {\r\n      this.peakLevelInfo.merge(bufferLevelInfo);\r\n      if (this.levelListener) {\r\n        this.levelListener.update(this.currentLevelInfos, this.peakLevelInfo.clone());\r\n      }\r\n      if(this.peakLevelListener){\r\n        let peakDBVal = bufferLevelInfo.powerLevelDB();\r\n        if (this.peakLevelInDb < peakDBVal) {\r\n          this.peakLevelInDb = peakDBVal;\r\n          // the event comes from outside an Angular zone\r\n          this.peakLevelListener(this.peakLevelInDb);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  stop() {\r\n    this.worker?.terminate();\r\n  }\r\n\r\n}\r\n"]}
@@ -3,4 +3,4 @@ export class WavFileFormat {
3
3
  WavFileFormat.RIFF_KEY = 'RIFF';
4
4
  WavFileFormat.WAV_KEY = 'WAVE';
5
5
  WavFileFormat.PCM = 0x0001;
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F2Zm9ybWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL2F1ZGlvL2ltcGwvd2F2Zm9ybWF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVFLE1BQU0sT0FBTyxhQUFhOztBQUNmLHNCQUFRLEdBQVUsTUFBTSxDQUFDO0FBQ3pCLHFCQUFPLEdBQVUsTUFBTSxDQUFDO0FBQ3hCLGlCQUFHLEdBQVcsTUFBTSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXG5cbiAgZXhwb3J0IGNsYXNzIFdhdkZpbGVGb3JtYXQge1xuICAgICAgc3RhdGljIFJJRkZfS0VZOnN0cmluZyA9ICdSSUZGJztcbiAgICAgIHN0YXRpYyBXQVZfS0VZOnN0cmluZyA9ICdXQVZFJztcbiAgICAgIHN0YXRpYyBQQ006bnVtYmVyID0gIDB4MDAwMTtcbiAgICB9XG5cblxuXG5cbiJdfQ==
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F2Zm9ybWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL2F1ZGlvL2ltcGwvd2F2Zm9ybWF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVFLE1BQU0sT0FBTyxhQUFhOztBQUNOLHNCQUFRLEdBQVUsTUFBTSxDQUFDO0FBQ3pCLHFCQUFPLEdBQVUsTUFBTSxDQUFDO0FBQ3hCLGlCQUFHLEdBQVcsTUFBTSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXHJcblxyXG4gIGV4cG9ydCBjbGFzcyBXYXZGaWxlRm9ybWF0IHtcclxuICAgICAgc3RhdGljIHJlYWRvbmx5IFJJRkZfS0VZOnN0cmluZyA9ICdSSUZGJztcclxuICAgICAgc3RhdGljIHJlYWRvbmx5IFdBVl9LRVk6c3RyaW5nID0gJ1dBVkUnO1xyXG4gICAgICBzdGF0aWMgcmVhZG9ubHkgUENNOm51bWJlciA9ICAweDAwMDE7XHJcbiAgICB9XHJcblxyXG5cclxuXHJcblxyXG4iXX0=