speechrecorderng 3.10.13 → 3.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (99) hide show
  1. package/README.md +1 -1
  2. package/fesm2022/speechrecorderng.mjs +204 -201
  3. package/fesm2022/speechrecorderng.mjs.map +1 -1
  4. package/lib/audio/ui/audio_canvas_layer_comp.d.ts +2 -2
  5. package/lib/spr.module.version.d.ts +1 -1
  6. package/lib/ui/canvas_layer_comp.d.ts +1 -1
  7. package/lib/ui/responsive_component.d.ts +1 -1
  8. package/package.json +13 -15
  9. package/esm2022/lib/action/action.mjs +0 -73
  10. package/esm2022/lib/audio/array_audio_buffer.mjs +0 -164
  11. package/esm2022/lib/audio/array_audio_buffer_input_stream.mjs +0 -86
  12. package/esm2022/lib/audio/array_audio_buffer_random_access_stream.mjs +0 -16
  13. package/esm2022/lib/audio/audio_data_holder.mjs +0 -264
  14. package/esm2022/lib/audio/audio_display.mjs +0 -118
  15. package/esm2022/lib/audio/audio_player.mjs +0 -238
  16. package/esm2022/lib/audio/capture/capture.mjs +0 -855
  17. package/esm2022/lib/audio/context.mjs +0 -79
  18. package/esm2022/lib/audio/dsp/level_measure.mjs +0 -517
  19. package/esm2022/lib/audio/format.mjs +0 -20
  20. package/esm2022/lib/audio/impl/wavformat.mjs +0 -7
  21. package/esm2022/lib/audio/impl/wavreader.mjs +0 -144
  22. package/esm2022/lib/audio/impl/wavwriter.mjs +0 -191
  23. package/esm2022/lib/audio/inddb_audio_buffer.mjs +0 -508
  24. package/esm2022/lib/audio/io/stream.mjs +0 -59
  25. package/esm2022/lib/audio/net_audio_buffer.mjs +0 -293
  26. package/esm2022/lib/audio/persistor.mjs +0 -81
  27. package/esm2022/lib/audio/playback/array_audio_buffer_source_node.mjs +0 -126
  28. package/esm2022/lib/audio/playback/audio_source_node.mjs +0 -18
  29. package/esm2022/lib/audio/playback/audio_source_worklet_module_loader.mjs +0 -167
  30. package/esm2022/lib/audio/playback/inddb_audio_buffer_source_node.mjs +0 -167
  31. package/esm2022/lib/audio/playback/net_audio_buffer_source_node.mjs +0 -218
  32. package/esm2022/lib/audio/playback/player.mjs +0 -402
  33. package/esm2022/lib/audio/ui/audio_canvas_layer_comp.mjs +0 -347
  34. package/esm2022/lib/audio/ui/audio_display_control.mjs +0 -150
  35. package/esm2022/lib/audio/ui/audio_display_scroll_pane.mjs +0 -146
  36. package/esm2022/lib/audio/ui/audiosignal.mjs +0 -533
  37. package/esm2022/lib/audio/ui/common.mjs +0 -19
  38. package/esm2022/lib/audio/ui/container.mjs +0 -414
  39. package/esm2022/lib/audio/ui/livelevel.mjs +0 -361
  40. package/esm2022/lib/audio/ui/scroll_pane_horizontal.mjs +0 -11
  41. package/esm2022/lib/audio/ui/sonagram.mjs +0 -900
  42. package/esm2022/lib/db/inddb.mjs +0 -120
  43. package/esm2022/lib/dsp/utils.mjs +0 -48
  44. package/esm2022/lib/environment/environment.defaults.mjs +0 -9
  45. package/esm2022/lib/io/BinaryReader.mjs +0 -93
  46. package/esm2022/lib/io/BinaryWriter.mjs +0 -80
  47. package/esm2022/lib/io/stream.mjs +0 -259
  48. package/esm2022/lib/math/2d/geometry.mjs +0 -28
  49. package/esm2022/lib/math/complex.mjs +0 -58
  50. package/esm2022/lib/math/dft.mjs +0 -196
  51. package/esm2022/lib/media/utils.mjs +0 -14
  52. package/esm2022/lib/net/uploader.mjs +0 -367
  53. package/esm2022/lib/recorder_component.mjs +0 -65
  54. package/esm2022/lib/speechrecorder/project/project.mjs +0 -54
  55. package/esm2022/lib/speechrecorder/project/project.service.mjs +0 -64
  56. package/esm2022/lib/speechrecorder/recording.mjs +0 -124
  57. package/esm2022/lib/speechrecorder/recordings/basic_recording.service.mjs +0 -221
  58. package/esm2022/lib/speechrecorder/recordings/recordings.service.mjs +0 -1014
  59. package/esm2022/lib/speechrecorder/script/script.mjs +0 -114
  60. package/esm2022/lib/speechrecorder/script/script.service.mjs +0 -47
  61. package/esm2022/lib/speechrecorder/session/audiorecorder.mjs +0 -1179
  62. package/esm2022/lib/speechrecorder/session/basicrecorder.mjs +0 -676
  63. package/esm2022/lib/speechrecorder/session/controlpanel.mjs +0 -416
  64. package/esm2022/lib/speechrecorder/session/item.mjs +0 -30
  65. package/esm2022/lib/speechrecorder/session/progress.mjs +0 -135
  66. package/esm2022/lib/speechrecorder/session/prompting.mjs +0 -639
  67. package/esm2022/lib/speechrecorder/session/recorder_combi_pane.mjs +0 -88
  68. package/esm2022/lib/speechrecorder/session/recording_file_cache.mjs +0 -195
  69. package/esm2022/lib/speechrecorder/session/recording_list.mjs +0 -188
  70. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +0 -128
  71. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-navi.component.mjs +0 -114
  72. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +0 -146
  73. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +0 -424
  74. package/esm2022/lib/speechrecorder/session/recordingfile/recording-file.mjs +0 -68
  75. package/esm2022/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +0 -288
  76. package/esm2022/lib/speechrecorder/session/session.mjs +0 -2
  77. package/esm2022/lib/speechrecorder/session/session.service.mjs +0 -69
  78. package/esm2022/lib/speechrecorder/session/session_finished_dialog.mjs +0 -46
  79. package/esm2022/lib/speechrecorder/session/sessionmanager.mjs +0 -1385
  80. package/esm2022/lib/speechrecorder/session/warning_bar.mjs +0 -33
  81. package/esm2022/lib/speechrecorder/spruploader.mjs +0 -22
  82. package/esm2022/lib/speechrecorder/startstopsignal/startstopsignal.mjs +0 -2
  83. package/esm2022/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.mjs +0 -57
  84. package/esm2022/lib/speechrecorderng.component.mjs +0 -392
  85. package/esm2022/lib/speechrecorderng.module.mjs +0 -97
  86. package/esm2022/lib/spr.config.mjs +0 -27
  87. package/esm2022/lib/spr.module.version.mjs +0 -2
  88. package/esm2022/lib/ui/canvas_layer_comp.mjs +0 -38
  89. package/esm2022/lib/ui/intersection-observer.directive.mjs +0 -32
  90. package/esm2022/lib/ui/message_dialog.mjs +0 -51
  91. package/esm2022/lib/ui/recordingitem_display.mjs +0 -253
  92. package/esm2022/lib/ui/responsive_component.mjs +0 -24
  93. package/esm2022/lib/utils/scrollIntoViewToBottom.mjs +0 -23
  94. package/esm2022/lib/utils/ua-parser.mjs +0 -190
  95. package/esm2022/lib/utils/utils.mjs +0 -132
  96. package/esm2022/lib/utils/wake_lock.mjs +0 -114
  97. package/esm2022/lib/utils/wake_lock_media.mjs +0 -2
  98. package/esm2022/public-api.mjs +0 -35
  99. package/esm2022/speechrecorderng.mjs +0 -5
@@ -1,288 +0,0 @@
1
- import { Inject, Injectable } from '@angular/core';
2
- import { HttpHeaders } from "@angular/common/http";
3
- import { Observable } from "rxjs";
4
- import { ApiType, SPEECHRECORDER_CONFIG } from "../../../spr.config";
5
- import { UUID } from "../../../utils/utils";
6
- import { RecordingFileUtils } from "../../recording";
7
- import { AudioBufferSource, AudioDataHolder } from "../../../audio/audio_data_holder";
8
- import { BasicRecordingService } from "../../recordings/basic_recording.service";
9
- import { AudioContextProvider } from "../../../audio/context";
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "@angular/common/http";
12
- import * as i2 from "../../../spr.config";
13
- export class RecordingFileService extends BasicRecordingService {
14
- static { this.RECOFILE_API_CTX = 'recordingfile'; }
15
- constructor(http, config) {
16
- super(http, config);
17
- this.http = http;
18
- this.config = config;
19
- //private debugDelay:number=10000;
20
- this.debugDelay = 0;
21
- }
22
- recoFileUrl(recordingFileId) {
23
- let encRecfileId = encodeURIComponent(recordingFileId);
24
- let recUrl = this.apiEndPoint + RecordingFileService.RECOFILE_API_CTX + '/' + encRecfileId;
25
- return recUrl;
26
- }
27
- fetchAudiofile(recordingFileId) {
28
- let recUrl = this.recoFileUrl(recordingFileId);
29
- if (this.config && this.config.apiType === ApiType.FILES) {
30
- // for development and demo
31
- // append UUID to make request URL unique to avoid localhost server caching
32
- recUrl = recUrl + '.wav';
33
- }
34
- let headers = new HttpHeaders({
35
- 'Accept': 'audio/wav'
36
- });
37
- return this.http.get(recUrl, {
38
- observe: 'response',
39
- headers: headers,
40
- responseType: 'arraybuffer',
41
- withCredentials: this.withCredentials
42
- });
43
- }
44
- recordingFileDescrObserver(recordingFileId) {
45
- let recUrl = this.recoFileUrl(recordingFileId);
46
- if (this.config && this.config.apiType === ApiType.FILES) {
47
- // for development and demo
48
- // append UUID to make request URL unique to avoid localhost server caching
49
- recUrl = recUrl + '.json?requestUUID=' + UUID.generate();
50
- }
51
- return this.http.get(recUrl, { withCredentials: this.withCredentials });
52
- }
53
- sprRecordingFileDescrObserver(recordingFileId) {
54
- let recUrl = this.recoFileUrl(recordingFileId);
55
- if (this.config && this.config.apiType === ApiType.FILES) {
56
- // for development and demo
57
- // append UUID to make request URL unique to avoid localhost server caching
58
- recUrl = recUrl + '.json?requestUUID=' + UUID.generate();
59
- }
60
- return this.http.get(recUrl, { withCredentials: this.withCredentials });
61
- }
62
- fetchSessionAudiofileById(projectName, sessId, recordingFileId) {
63
- let recUrl = this.recoFileUrl(recordingFileId);
64
- // if (this.config && this.config.apiType === ApiType.FILES) {
65
- // // for development and demo
66
- // // append UUID to make request URL unique to avoid localhost server caching
67
- // recUrl = recUrl + '.wav?requestUUID=' + UUID.generate();
68
- // }
69
- return this.http.get(recUrl, {
70
- observe: 'response',
71
- responseType: 'arraybuffer',
72
- withCredentials: this.withCredentials
73
- });
74
- }
75
- // TODO test
76
- fetchAndApplyRecordingFile(recordingFile) {
77
- let wobs = new Observable(observer => {
78
- if (recordingFile.recordingFileId) {
79
- let obs = this.fetchAudiofile(recordingFile.recordingFileId);
80
- obs.subscribe({ next: resp => {
81
- if (resp.body) {
82
- AudioContextProvider.decodeAudioData(resp.body).then(ab => {
83
- let as = new AudioBufferSource(ab);
84
- RecordingFileUtils.setAudioData(recordingFile, new AudioDataHolder(as));
85
- if (this.debugDelay > 0) {
86
- window.setTimeout(() => {
87
- observer.next(recordingFile);
88
- observer.complete();
89
- }, this.debugDelay);
90
- }
91
- else {
92
- observer.next(recordingFile);
93
- observer.complete();
94
- }
95
- }).catch(reason => { observer.error(reason); });
96
- }
97
- else {
98
- observer.error('Received no audio data!');
99
- }
100
- },
101
- error: (error) => {
102
- if (error.status == 404) {
103
- // Interpret not as an error, the file ist not recorded yet
104
- observer.next(null);
105
- observer.complete();
106
- }
107
- else {
108
- // all other states are errors
109
- observer.error(error);
110
- observer.complete();
111
- }
112
- }
113
- });
114
- }
115
- else {
116
- observer.error();
117
- }
118
- });
119
- return wobs;
120
- }
121
- fetchRecordingFile(aCtx, recordingFileId) {
122
- let wobs = new Observable(observer => {
123
- let rf = null;
124
- let rfDescrObs = this.recordingFileDescrObserver(recordingFileId);
125
- rfDescrObs.subscribe({ next: value => {
126
- rf = value;
127
- }, error: (error) => {
128
- observer.error(error);
129
- }, complete: () => {
130
- let rfAudioObs = this.fetchAudiofile(recordingFileId);
131
- rfAudioObs.subscribe({
132
- next: resp => {
133
- // Do not use Promise version, which does not work with Safari 13
134
- if (resp.body) {
135
- AudioContextProvider.decodeAudioData(resp.body).then(ab => {
136
- if (rf) {
137
- let as = new AudioBufferSource(ab);
138
- RecordingFileUtils.setAudioData(rf, new AudioDataHolder(as));
139
- }
140
- else {
141
- observer.error('Recording file object null');
142
- }
143
- if (this.debugDelay > 0) {
144
- window.setTimeout(() => {
145
- observer.next(rf);
146
- observer.complete();
147
- }, this.debugDelay);
148
- }
149
- else {
150
- observer.next(rf);
151
- observer.complete();
152
- }
153
- }).catch(reason => { observer.error(reason); });
154
- }
155
- else {
156
- observer.error('Received no audio data');
157
- }
158
- },
159
- error: (error) => {
160
- if (error.status == 404) {
161
- // Interpret not as an error, the file ist not recorded yet
162
- observer.next(null);
163
- observer.complete();
164
- }
165
- else {
166
- // all other states are errors
167
- observer.error(error);
168
- observer.complete();
169
- }
170
- }
171
- });
172
- }
173
- });
174
- });
175
- return wobs;
176
- }
177
- fetchSprRecordingFile(recordingFileId) {
178
- let wobs = new Observable(observer => {
179
- let rf = null;
180
- let rfDescrObs = this.sprRecordingFileDescrObserver(recordingFileId);
181
- rfDescrObs.subscribe({ next: value => {
182
- rf = value;
183
- },
184
- error: (error) => {
185
- observer.error(error);
186
- }, complete: () => {
187
- let sampleCnt = null;
188
- if (rf && rf.channels && rf.frames) {
189
- sampleCnt = rf.channels * rf.frames;
190
- }
191
- // TODO use download storage type depending on sample count of file
192
- if (rf && rf.samplerate && sampleCnt != null && sampleCnt > this._maxAutoNetMemStoreSamples) {
193
- const baseUrl = this.recoFileUrl(recordingFileId);
194
- const obNetAb = this.chunkAudioRequestToNetAudioBuffer(baseUrl, 0, rf?.samplerate, BasicRecordingService.DEFAULT_CHUNKED_DOWNLOAD_SECONDS, rf.frames);
195
- obNetAb.subscribe({
196
- next: (nab) => {
197
- let adh = new AudioDataHolder(nab);
198
- if (rf) {
199
- RecordingFileUtils.setAudioData(rf, adh);
200
- observer.next(rf);
201
- }
202
- },
203
- complete: () => {
204
- observer.complete();
205
- },
206
- error: (error) => {
207
- if (error.status == 404) {
208
- // Interpret not as an error, the file ist not recorded yet
209
- observer.next(null);
210
- observer.complete();
211
- }
212
- else {
213
- // all other states are errors
214
- observer.error(error);
215
- observer.complete();
216
- }
217
- }
218
- });
219
- }
220
- else {
221
- let rfAudioObs = this.fetchAudiofile(recordingFileId);
222
- rfAudioObs.subscribe({ next: resp => {
223
- // Do not use Promise version, which does not work with Safari 13
224
- if (resp.body) {
225
- AudioContextProvider.decodeAudioData(resp.body).then(ab => {
226
- if (rf) {
227
- let as = new AudioBufferSource(ab);
228
- let adh = new AudioDataHolder(as);
229
- RecordingFileUtils.setAudioData(rf, adh);
230
- }
231
- else {
232
- observer.error('Recording file object null');
233
- }
234
- if (this.debugDelay > 0) {
235
- window.setTimeout(() => {
236
- observer.next(rf);
237
- observer.complete();
238
- }, this.debugDelay);
239
- }
240
- else {
241
- observer.next(rf);
242
- observer.complete();
243
- }
244
- }).catch(reason => { observer.error(reason); });
245
- }
246
- else {
247
- observer.error('Received no audio data');
248
- }
249
- },
250
- error: (error) => {
251
- if (error.status == 404) {
252
- // Interpret not as an error, the file ist not recorded yet
253
- observer.next(null);
254
- observer.complete();
255
- }
256
- else {
257
- // all other states are errors
258
- observer.error(error);
259
- observer.complete();
260
- }
261
- }
262
- });
263
- }
264
- }
265
- });
266
- });
267
- return wobs;
268
- }
269
- saveEditSelection(recordingFileId, editSampleRate, editStartFrame, editEndFrame) {
270
- let recUrl = this.apiEndPoint + RecordingFileService.RECOFILE_API_CTX + '/' + recordingFileId;
271
- if (this.config && this.config.apiType === ApiType.FILES) {
272
- // for development and demo
273
- // append UUID to make request URL unique to avoid localhost server caching
274
- recUrl = recUrl + '.json?requestUUID=' + UUID.generate();
275
- }
276
- //console.log("Path request URL: "+recUrl)
277
- return this.http.patch(recUrl, { editSampleRate: editSampleRate, editStartFrame: editStartFrame, editEndFrame: editEndFrame }, { withCredentials: this.withCredentials });
278
- }
279
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: RecordingFileService, deps: [{ token: i1.HttpClient }, { token: SPEECHRECORDER_CONFIG }], target: i0.ɵɵFactoryTarget.Injectable }); }
280
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: RecordingFileService }); }
281
- }
282
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: RecordingFileService, decorators: [{
283
- type: Injectable
284
- }], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.SpeechRecorderConfig, decorators: [{
285
- type: Inject,
286
- args: [SPEECHRECORDER_CONFIG]
287
- }] }] });
288
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recordingfile-service.js","sourceRoot":"","sources":["../../../../../../../projects/speechrecorderng/src/lib/speechrecorder/session/recordingfile/recordingfile-service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable} from '@angular/core';\r\nimport { HttpClient, HttpErrorResponse, HttpHeaders, HttpResponse } from \"@angular/common/http\";\r\n\r\n\r\nimport {Observable} from \"rxjs\";\r\n\r\n\r\nimport {ApiType, SPEECHRECORDER_CONFIG, SpeechRecorderConfig} from \"../../../spr.config\";\r\nimport {UUID} from \"../../../utils/utils\";\r\nimport {RecordingFile, RecordingFileUtils, SprRecordingFile} from \"../../recording\";\r\nimport {AudioBufferSource, AudioDataHolder} from \"../../../audio/audio_data_holder\";\r\nimport {BasicRecordingService} from \"../../recordings/basic_recording.service\";\r\nimport {AudioContextProvider} from \"../../../audio/context\";\r\n\r\n\r\n@Injectable()\r\nexport class RecordingFileService extends BasicRecordingService{\r\n\r\n  public static readonly RECOFILE_API_CTX = 'recordingfile'\r\n\r\n  //private debugDelay:number=10000;\r\n  private debugDelay:number=0;\r\n\r\n  constructor(protected http: HttpClient, @Inject(SPEECHRECORDER_CONFIG) protected config?: SpeechRecorderConfig) {\r\n      super(http,config);\r\n  }\r\n\r\n  private recoFileUrl(recordingFileId: string | number):string{\r\n    let encRecfileId=encodeURIComponent(recordingFileId);\r\n    let recUrl = this.apiEndPoint + RecordingFileService.RECOFILE_API_CTX + '/' + encRecfileId;\r\n\r\n    return recUrl;\r\n  }\r\n\r\n  private fetchAudiofile(recordingFileId: string | number): Observable<HttpResponse<ArrayBuffer>> {\r\n    let recUrl = this.recoFileUrl(recordingFileId);\r\n    if (this.config && this.config.apiType === ApiType.FILES) {\r\n      // for development and demo\r\n      // append UUID to make request URL unique to avoid localhost server caching\r\n      recUrl = recUrl + '.wav';\r\n    }\r\n    let headers = new HttpHeaders({\r\n      'Accept': 'audio/wav'\r\n    });\r\n\r\n    return this.http.get(recUrl, {\r\n      observe: 'response',\r\n      headers: headers,\r\n      responseType: 'arraybuffer',\r\n      withCredentials: this.withCredentials\r\n    });\r\n  }\r\n\r\n  private recordingFileDescrObserver(recordingFileId: string | number): Observable<RecordingFile> {\r\n\r\n    let recUrl = this.recoFileUrl(recordingFileId);\r\n    if (this.config && this.config.apiType === ApiType.FILES) {\r\n      // for development and demo\r\n      // append UUID to make request URL unique to avoid localhost server caching\r\n      recUrl = recUrl + '.json?requestUUID='+UUID.generate();\r\n    }\r\n    return this.http.get<RecordingFile>(recUrl,{ withCredentials: this.withCredentials });\r\n  }\r\n\r\n  private sprRecordingFileDescrObserver(recordingFileId: string | number): Observable<SprRecordingFile> {\r\n\r\n    let recUrl = this.recoFileUrl(recordingFileId);\r\n    if (this.config && this.config.apiType === ApiType.FILES) {\r\n      // for development and demo\r\n      // append UUID to make request URL unique to avoid localhost server caching\r\n      recUrl = recUrl + '.json?requestUUID='+UUID.generate();\r\n    }\r\n    return this.http.get<SprRecordingFile>(recUrl,{ withCredentials: this.withCredentials });\r\n  }\r\n\r\n\r\n  private fetchSessionAudiofileById(projectName: string, sessId: string | number, recordingFileId: string | number): Observable<HttpResponse<ArrayBuffer>> {\r\n\r\n    let recUrl = this.recoFileUrl(recordingFileId);\r\n    // if (this.config && this.config.apiType === ApiType.FILES) {\r\n    //   // for development and demo\r\n    //   // append UUID to make request URL unique to avoid localhost server caching\r\n    //   recUrl = recUrl + '.wav?requestUUID=' + UUID.generate();\r\n    // }\r\n    return this.http.get(recUrl, {\r\n      observe: 'response',\r\n      responseType: 'arraybuffer',\r\n      withCredentials: this.withCredentials\r\n    });\r\n  }\r\n\r\n\r\n  // TODO test\r\n\r\n  fetchAndApplyRecordingFile(recordingFile:SprRecordingFile):Observable<SprRecordingFile|null> {\r\n\r\n    let wobs = new Observable<SprRecordingFile|null>(observer=>{\r\n      if(recordingFile.recordingFileId) {\r\n        let obs = this.fetchAudiofile(recordingFile.recordingFileId);\r\n\r\n        obs.subscribe(\r\n            {next:resp => {\r\n              if(resp.body) {\r\n                AudioContextProvider.decodeAudioData(resp.body).then(ab => {\r\n                  let as=new AudioBufferSource(ab);\r\n                  RecordingFileUtils.setAudioData(recordingFile,new AudioDataHolder(as));\r\n                  if (this.debugDelay > 0) {\r\n                    window.setTimeout(() => {\r\n\r\n                      observer.next(recordingFile);\r\n                      observer.complete();\r\n                    }, this.debugDelay);\r\n                  } else {\r\n                    observer.next(recordingFile);\r\n                    observer.complete();\r\n                  }\r\n                }).catch(reason=>{observer.error(reason)});\r\n              }else{\r\n                observer.error('Received no audio data!');\r\n              }\r\n            },\r\n            error:(error: HttpErrorResponse) => {\r\n              if (error.status == 404) {\r\n                // Interpret not as an error, the file ist not recorded yet\r\n                observer.next(null);\r\n                observer.complete()\r\n              } else {\r\n                // all other states are errors\r\n                observer.error(error);\r\n                observer.complete();\r\n              }\r\n            }\r\n      });\r\n      }else{\r\n        observer.error();\r\n      }\r\n    });\r\n\r\n    return wobs;\r\n  }\r\n\r\n  fetchRecordingFile(aCtx: AudioContext, recordingFileId: string | number): Observable<RecordingFile | null> {\r\n\r\n    let wobs = new Observable<RecordingFile | null>(observer => {\r\n      let rf: RecordingFile|null = null;\r\n      let rfDescrObs = this.recordingFileDescrObserver(recordingFileId);\r\n      rfDescrObs.subscribe(\r\n          {next:value => {\r\n        rf = value;\r\n      }, error:(error) => {\r\n        observer.error(error);\r\n      }, complete:() => {\r\n        let rfAudioObs = this.fetchAudiofile(recordingFileId);\r\n        rfAudioObs.subscribe({\r\n          next: resp => {\r\n            // Do not use Promise version, which does not work with Safari 13\r\n            if (resp.body) {\r\n              AudioContextProvider.decodeAudioData(resp.body).then( ab => {\r\n                if (rf) {\r\n                  let as = new AudioBufferSource(ab);\r\n                  RecordingFileUtils.setAudioData(rf, new AudioDataHolder(as));\r\n                } else {\r\n                  observer.error('Recording file object null');\r\n                }\r\n                if (this.debugDelay > 0) {\r\n                  window.setTimeout(() => {\r\n                    observer.next(rf);\r\n                    observer.complete();\r\n                  }, this.debugDelay);\r\n                } else {\r\n                  observer.next(rf);\r\n                  observer.complete();\r\n                }\r\n              }).catch(reason => {observer.error(reason)});\r\n            } else {\r\n              observer.error('Received no audio data');\r\n            }\r\n          },\r\n          error: (error: HttpErrorResponse) => {\r\n            if (error.status == 404) {\r\n              // Interpret not as an error, the file ist not recorded yet\r\n              observer.next(null);\r\n              observer.complete()\r\n            } else {\r\n              // all other states are errors\r\n              observer.error(error);\r\n              observer.complete();\r\n            }\r\n          }\r\n        });\r\n        }\r\n      });\r\n    });\r\n\r\n    return wobs;\r\n  }\r\n\r\n  fetchSprRecordingFile( recordingFileId: string | number): Observable<SprRecordingFile | null> {\r\n\r\n    let wobs = new Observable<SprRecordingFile | null>(observer => {\r\n      let rf: SprRecordingFile|null = null;\r\n      let rfDescrObs = this.sprRecordingFileDescrObserver(recordingFileId);\r\n      rfDescrObs.subscribe({next:value => {\r\n        rf = value;\r\n      }\r\n    , error:(error) => {\r\n        observer.error(error);\r\n      }, complete:() => {\r\n        let sampleCnt: number | null = null;\r\n        if (rf && rf.channels && rf.frames) {\r\n          sampleCnt = rf.channels * rf.frames;\r\n        }\r\n        // TODO use download storage type depending on sample count of file\r\n        if (rf && rf.samplerate && sampleCnt != null && sampleCnt > this._maxAutoNetMemStoreSamples) {\r\n          const baseUrl = this.recoFileUrl(recordingFileId);\r\n          const obNetAb = this.chunkAudioRequestToNetAudioBuffer(baseUrl, 0, rf?.samplerate, BasicRecordingService.DEFAULT_CHUNKED_DOWNLOAD_SECONDS, rf.frames);\r\n          obNetAb.subscribe(\r\n              {\r\n                next: (nab) => {\r\n                  let adh = new AudioDataHolder(nab);\r\n                  if (rf) {\r\n                    RecordingFileUtils.setAudioData(rf, adh);\r\n                    observer.next(rf);\r\n                  }\r\n                },\r\n                complete: () => {\r\n                  observer.complete();\r\n                },\r\n                error: (error) => {\r\n                  if (error.status == 404) {\r\n                    // Interpret not as an error, the file ist not recorded yet\r\n                    observer.next(null);\r\n                    observer.complete()\r\n                  } else {\r\n                    // all other states are errors\r\n                    observer.error(error);\r\n                    observer.complete();\r\n                  }\r\n                }\r\n              }\r\n          );\r\n        } else {\r\n\r\n          let rfAudioObs = this.fetchAudiofile(recordingFileId);\r\n          rfAudioObs.subscribe(\r\n              {next:resp =>\r\n          {\r\n            // Do not use Promise version, which does not work with Safari 13\r\n            if (resp.body) {\r\n              AudioContextProvider.decodeAudioData(resp.body).then( ab => {\r\n                if (rf) {\r\n                  let as = new AudioBufferSource(ab);\r\n                  let adh = new AudioDataHolder(as);\r\n                  RecordingFileUtils.setAudioData(rf, adh);\r\n                } else {\r\n                  observer.error('Recording file object null');\r\n                }\r\n                if (this.debugDelay > 0) {\r\n                  window.setTimeout(() => {\r\n                    observer.next(rf);\r\n                    observer.complete();\r\n                  }, this.debugDelay);\r\n                } else {\r\n                  observer.next(rf);\r\n                  observer.complete();\r\n                }\r\n              }).catch(reason => {observer.error(reason)});\r\n            } else {\r\n              observer.error('Received no audio data');\r\n            }\r\n          }\r\n        , error:(error: HttpErrorResponse) => {\r\n            if (error.status == 404) {\r\n              // Interpret not as an error, the file ist not recorded yet\r\n              observer.next(null);\r\n              observer.complete()\r\n            } else {\r\n              // all other states are errors\r\n              observer.error(error);\r\n              observer.complete();\r\n            }\r\n          }\r\n        });\r\n        }\r\n      }\r\n    });\r\n    });\r\n\r\n    return wobs;\r\n  }\r\n\r\n  saveEditSelection(recordingFileId: string | number,editSampleRate:number|null,editStartFrame:number|null,editEndFrame:number|null): Observable<SprRecordingFile | null> {\r\n    let recUrl = this.apiEndPoint + RecordingFileService.RECOFILE_API_CTX + '/' + recordingFileId;\r\n    if (this.config && this.config.apiType === ApiType.FILES) {\r\n      // for development and demo\r\n      // append UUID to make request URL unique to avoid localhost server caching\r\n      recUrl = recUrl + '.json?requestUUID='+UUID.generate();\r\n    }\r\n    //console.log(\"Path request URL: \"+recUrl)\r\n    return this.http.patch<SprRecordingFile>(recUrl,{editSampleRate:editSampleRate,editStartFrame:editStartFrame,editEndFrame:editEndFrame},{ withCredentials: this.withCredentials });\r\n  }\r\n\r\n}\r\n\r\n\r\n"]}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Vzc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NwZWVjaHJlY29yZGVybmcvc3JjL2xpYi9zcGVlY2hyZWNvcmRlci9zZXNzaW9uL3Nlc3Npb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIlxyXG5leHBvcnQgdHlwZSBTdGF0dXM9IFwiQ1JFQVRFRFwiIHwgXCJMT0FERURcIiB8IFwiU1RBUlRFRF9UUkFJTklOR1wiIHwgXCJTVEFSVEVEXCIgfCBcIkNPTVBMRVRFRFwiO1xyXG5cclxuZXhwb3J0IHR5cGUgVHlwZT0gJ05PUk0nIHwgJ1RFU1QnIHwgJ1RFU1RfREVGX0EnIHwgJ1NJTlVTX1RFU1QnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTZXNzaW9ue1xyXG5cclxuICBzZXNzaW9uSWQ6IHN0cmluZyB8IG51bWJlcixcclxuICBzdGF0dXM6IFN0YXR1cyxcclxuICBzZWFsZWQ/OmJvb2xlYW4sXHJcbiAgdHlwZTogVHlwZSxcclxuICBsb2FkZWREYXRlPzpEYXRlLFxyXG4gIHN0YXJ0ZWRUcmFpbmluZ0RhdGU/OkRhdGUsXHJcbiAgc3RhcnRlZERhdGU/OkRhdGUsXHJcbiAgY29tcGxldGVkRGF0ZT86RGF0ZSxcclxuICByZXN0YXJ0ZWREYXRlPzpEYXRlLFxyXG4gIHByb2plY3Q6IHN0cmluZyxcclxuICBzY3JpcHQ6IHN0cmluZyB8IG51bWJlclxyXG5cclxufVxyXG4iXX0=
@@ -1,69 +0,0 @@
1
- import { Inject, Injectable } from '@angular/core';
2
- import { ApiType, SPEECHRECORDER_CONFIG } from "../../spr.config";
3
- import { UUID } from "../../utils/utils";
4
- import { Observable } from "rxjs";
5
- import { ProjectService } from "../project/project.service";
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "@angular/common/http";
8
- import * as i2 from "../../spr.config";
9
- export class SessionService {
10
- get uploadCount() {
11
- return this._uploadCount;
12
- }
13
- static { this.SESSION_API_CTX = 'session'; }
14
- constructor(http, config) {
15
- this.http = http;
16
- this.config = config;
17
- this.apiEndPoint = '';
18
- this.withCredentials = false;
19
- this._uploadCount = 0;
20
- if (config && config.apiEndPoint) {
21
- this.apiEndPoint = config.apiEndPoint;
22
- }
23
- if (this.apiEndPoint !== '') {
24
- this.apiEndPoint = this.apiEndPoint + '/';
25
- }
26
- if (config != null && config.withCredentials != null) {
27
- this.withCredentials = config.withCredentials;
28
- }
29
- this.sessionsUrl = this.apiEndPoint + SessionService.SESSION_API_CTX;
30
- }
31
- sessionObserver(id) {
32
- let sessUrl = this.sessionsUrl + '/' + id;
33
- if (this.config && this.config.apiType === ApiType.FILES) {
34
- // for development and demo
35
- // append UUID to make request URL unique to avoid localhost server caching
36
- sessUrl = sessUrl + '.json?requestUUID=' + UUID.generate();
37
- }
38
- return this.http.get(sessUrl, { withCredentials: this.withCredentials });
39
- }
40
- patchSessionObserver(session, body) {
41
- let sesssUrl = this.apiEndPoint + ProjectService.PROJECT_API_CTX + '/' + session.project + '/' + SessionService.SESSION_API_CTX + '/' + session.sessionId;
42
- let wrapObs = new Observable(subscriber => {
43
- this._uploadCount++;
44
- let obs = this.http.patch(sesssUrl, body, { withCredentials: this.withCredentials });
45
- obs.subscribe({
46
- next: (value) => {
47
- subscriber.next(value);
48
- },
49
- error: error => {
50
- this._uploadCount--;
51
- subscriber.error(error);
52
- }, complete: () => {
53
- this._uploadCount--;
54
- subscriber.complete();
55
- }
56
- });
57
- });
58
- return wrapObs;
59
- }
60
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SessionService, deps: [{ token: i1.HttpClient }, { token: SPEECHRECORDER_CONFIG }], target: i0.ɵɵFactoryTarget.Injectable }); }
61
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SessionService }); }
62
- }
63
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SessionService, decorators: [{
64
- type: Injectable
65
- }], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.SpeechRecorderConfig, decorators: [{
66
- type: Inject,
67
- args: [SPEECHRECORDER_CONFIG]
68
- }] }] });
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Vzc2lvbi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL3NwZWVjaHJlY29yZGVyL3Nlc3Npb24vc2Vzc2lvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxNQUFNLEVBQUUsVUFBVSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRWpELE9BQU8sRUFBQyxPQUFPLEVBQUUscUJBQXFCLEVBQXVCLE1BQU0sa0JBQWtCLENBQUM7QUFFdEYsT0FBTyxFQUFDLElBQUksRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxNQUFNLENBQUM7QUFDaEMsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLDRCQUE0QixDQUFDOzs7O0FBSzFELE1BQU0sT0FBTyxjQUFjO0lBQ3pCLElBQUksV0FBVztRQUNiLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztJQUMzQixDQUFDO2FBQ3NCLG9CQUFlLEdBQUMsU0FBUyxBQUFWLENBQVc7SUFNakQsWUFBb0IsSUFBZSxFQUF3QyxNQUE0QjtRQUFuRixTQUFJLEdBQUosSUFBSSxDQUFXO1FBQXdDLFdBQU0sR0FBTixNQUFNLENBQXNCO1FBTC9GLGdCQUFXLEdBQUMsRUFBRSxDQUFDO1FBRU4sb0JBQWUsR0FBUyxLQUFLLENBQUM7UUFDdkMsaUJBQVksR0FBQyxDQUFDLENBQUM7UUFJckIsSUFBRyxNQUFNLElBQUksTUFBTSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ2hDLElBQUksQ0FBQyxXQUFXLEdBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQztRQUN0QyxDQUFDO1FBQ0QsSUFBRyxJQUFJLENBQUMsV0FBVyxLQUFLLEVBQUUsRUFBQyxDQUFDO1lBQzFCLElBQUksQ0FBQyxXQUFXLEdBQUMsSUFBSSxDQUFDLFdBQVcsR0FBQyxHQUFHLENBQUE7UUFDdkMsQ0FBQztRQUNELElBQUcsTUFBTSxJQUFFLElBQUksSUFBSSxNQUFNLENBQUMsZUFBZSxJQUFFLElBQUksRUFBQyxDQUFDO1lBQy9DLElBQUksQ0FBQyxlQUFlLEdBQUMsTUFBTSxDQUFDLGVBQWUsQ0FBQztRQUM5QyxDQUFDO1FBQ0QsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxHQUFHLGNBQWMsQ0FBQyxlQUFlLENBQUM7SUFDdkUsQ0FBQztJQUVELGVBQWUsQ0FBQyxFQUFVO1FBRXhCLElBQUksT0FBTyxHQUFHLElBQUksQ0FBQyxXQUFXLEdBQUcsR0FBRyxHQUFHLEVBQUUsQ0FBQztRQUMxQyxJQUFJLElBQUksQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEtBQUssT0FBTyxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ3pELDJCQUEyQjtZQUMzQiwyRUFBMkU7WUFDM0UsT0FBTyxHQUFHLE9BQU8sR0FBRyxvQkFBb0IsR0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDM0QsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQVUsT0FBTyxFQUFDLEVBQUUsZUFBZSxFQUFFLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQyxDQUFDO0lBRW5GLENBQUM7SUFFRCxvQkFBb0IsQ0FBQyxPQUFlLEVBQUMsSUFBUTtRQUUzQyxJQUFJLFFBQVEsR0FBRyxJQUFJLENBQUMsV0FBVyxHQUFHLGNBQWMsQ0FBQyxlQUFlLEdBQUcsR0FBRyxHQUFHLE9BQU8sQ0FBQyxPQUFPLEdBQUcsR0FBRyxHQUFHLGNBQWMsQ0FBQyxlQUFlLEdBQUcsR0FBRyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUE7UUFFekosSUFBSSxPQUFPLEdBQUcsSUFBSSxVQUFVLENBQVUsVUFBVSxDQUFDLEVBQUU7WUFDakQsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3BCLElBQUksR0FBRyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFVLFFBQVEsRUFBRSxJQUFJLEVBQUUsRUFBQyxlQUFlLEVBQUUsSUFBSSxDQUFDLGVBQWUsRUFBQyxDQUFDLENBQUM7WUFDNUYsR0FBRyxDQUFDLFNBQVMsQ0FBQztnQkFDZCxJQUFJLEVBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtvQkFFYixVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUN6QixDQUFDO2dCQUNBLEtBQUssRUFBRSxLQUFLLENBQUMsRUFBRTtvQkFDZCxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7b0JBQ3BCLFVBQVUsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBQzFCLENBQUMsRUFBRSxRQUFRLEVBQUMsR0FBRyxFQUFFO29CQUNmLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztvQkFDcEIsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUN4QixDQUFDO2FBQ0YsQ0FBQyxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLE9BQU8sQ0FBQztJQUNqQixDQUFDOytHQTFEVSxjQUFjLDRDQVVtQixxQkFBcUI7bUhBVnRELGNBQWM7OzRGQUFkLGNBQWM7a0JBRDFCLFVBQVU7OzBCQVc0QixNQUFNOzJCQUFDLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0LCBJbmplY3RhYmxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gXCJAYW5ndWxhci9jb21tb24vaHR0cFwiO1xyXG5pbXBvcnQge0FwaVR5cGUsIFNQRUVDSFJFQ09SREVSX0NPTkZJRywgU3BlZWNoUmVjb3JkZXJDb25maWd9IGZyb20gXCIuLi8uLi9zcHIuY29uZmlnXCI7XHJcbmltcG9ydCB7U2Vzc2lvbn0gZnJvbSBcIi4vc2Vzc2lvblwiO1xyXG5pbXBvcnQge1VVSUR9IGZyb20gXCIuLi8uLi91dGlscy91dGlsc1wiO1xyXG5pbXBvcnQge09ic2VydmFibGV9IGZyb20gXCJyeGpzXCI7XHJcbmltcG9ydCB7UHJvamVjdFNlcnZpY2V9IGZyb20gXCIuLi9wcm9qZWN0L3Byb2plY3Quc2VydmljZVwiO1xyXG5cclxuXHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBTZXNzaW9uU2VydmljZSB7XHJcbiAgZ2V0IHVwbG9hZENvdW50KCk6IG51bWJlciB7XHJcbiAgICByZXR1cm4gdGhpcy5fdXBsb2FkQ291bnQ7XHJcbiAgfVxyXG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgU0VTU0lPTl9BUElfQ1RYPSdzZXNzaW9uJztcclxuICBwcml2YXRlIGFwaUVuZFBvaW50PScnO1xyXG4gIHByaXZhdGUgcmVhZG9ubHkgc2Vzc2lvbnNVcmw6c3RyaW5nO1xyXG4gIHByaXZhdGUgcmVhZG9ubHkgd2l0aENyZWRlbnRpYWxzOmJvb2xlYW49ZmFsc2U7XHJcbiAgcHJpdmF0ZSBfdXBsb2FkQ291bnQ9MDtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBodHRwOkh0dHBDbGllbnQsQEluamVjdChTUEVFQ0hSRUNPUkRFUl9DT05GSUcpIHByaXZhdGUgY29uZmlnPzpTcGVlY2hSZWNvcmRlckNvbmZpZykge1xyXG5cclxuICAgIGlmKGNvbmZpZyAmJiBjb25maWcuYXBpRW5kUG9pbnQpIHtcclxuICAgICAgdGhpcy5hcGlFbmRQb2ludD1jb25maWcuYXBpRW5kUG9pbnQ7XHJcbiAgICB9XHJcbiAgICBpZih0aGlzLmFwaUVuZFBvaW50ICE9PSAnJyl7XHJcbiAgICAgIHRoaXMuYXBpRW5kUG9pbnQ9dGhpcy5hcGlFbmRQb2ludCsnLydcclxuICAgIH1cclxuICAgIGlmKGNvbmZpZyE9bnVsbCAmJiBjb25maWcud2l0aENyZWRlbnRpYWxzIT1udWxsKXtcclxuICAgICAgdGhpcy53aXRoQ3JlZGVudGlhbHM9Y29uZmlnLndpdGhDcmVkZW50aWFscztcclxuICAgIH1cclxuICAgIHRoaXMuc2Vzc2lvbnNVcmwgPSB0aGlzLmFwaUVuZFBvaW50ICsgU2Vzc2lvblNlcnZpY2UuU0VTU0lPTl9BUElfQ1RYO1xyXG4gIH1cclxuXHJcbiAgc2Vzc2lvbk9ic2VydmVyKGlkOiBzdHJpbmcpOiBPYnNlcnZhYmxlPFNlc3Npb24+IHtcclxuXHJcbiAgICBsZXQgc2Vzc1VybCA9IHRoaXMuc2Vzc2lvbnNVcmwgKyAnLycgKyBpZDtcclxuICAgIGlmICh0aGlzLmNvbmZpZyAmJiB0aGlzLmNvbmZpZy5hcGlUeXBlID09PSBBcGlUeXBlLkZJTEVTKSB7XHJcbiAgICAgIC8vIGZvciBkZXZlbG9wbWVudCBhbmQgZGVtb1xyXG4gICAgICAvLyBhcHBlbmQgVVVJRCB0byBtYWtlIHJlcXVlc3QgVVJMIHVuaXF1ZSB0byBhdm9pZCBsb2NhbGhvc3Qgc2VydmVyIGNhY2hpbmdcclxuICAgICAgc2Vzc1VybCA9IHNlc3NVcmwgKyAnLmpzb24/cmVxdWVzdFVVSUQ9JytVVUlELmdlbmVyYXRlKCk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldDxTZXNzaW9uPihzZXNzVXJsLHsgd2l0aENyZWRlbnRpYWxzOiB0aGlzLndpdGhDcmVkZW50aWFscyB9KTtcclxuXHJcbiAgfVxyXG5cclxuICBwYXRjaFNlc3Npb25PYnNlcnZlcihzZXNzaW9uOlNlc3Npb24sYm9keTphbnkpOiBPYnNlcnZhYmxlPFNlc3Npb24+IHtcclxuXHJcbiAgICBsZXQgc2Vzc3NVcmwgPSB0aGlzLmFwaUVuZFBvaW50ICsgUHJvamVjdFNlcnZpY2UuUFJPSkVDVF9BUElfQ1RYICsgJy8nICsgc2Vzc2lvbi5wcm9qZWN0ICsgJy8nICsgU2Vzc2lvblNlcnZpY2UuU0VTU0lPTl9BUElfQ1RYICsgJy8nICsgc2Vzc2lvbi5zZXNzaW9uSWRcclxuXHJcbiAgICBsZXQgd3JhcE9icyA9IG5ldyBPYnNlcnZhYmxlPFNlc3Npb24+KHN1YnNjcmliZXIgPT4ge1xyXG4gICAgICB0aGlzLl91cGxvYWRDb3VudCsrO1xyXG4gICAgICBsZXQgb2JzID0gdGhpcy5odHRwLnBhdGNoPFNlc3Npb24+KHNlc3NzVXJsLCBib2R5LCB7d2l0aENyZWRlbnRpYWxzOiB0aGlzLndpdGhDcmVkZW50aWFsc30pO1xyXG4gICAgICBvYnMuc3Vic2NyaWJlKHtcclxuICAgICAgbmV4dDoodmFsdWUpID0+XHJcbiAgICAgIHtcclxuICAgICAgICBzdWJzY3JpYmVyLm5leHQodmFsdWUpO1xyXG4gICAgICB9XHJcbiAgICAgICxlcnJvcjogZXJyb3IgPT4ge1xyXG4gICAgICAgIHRoaXMuX3VwbG9hZENvdW50LS07XHJcbiAgICAgICAgc3Vic2NyaWJlci5lcnJvcihlcnJvcik7XHJcbiAgICAgIH0sIGNvbXBsZXRlOigpID0+IHtcclxuICAgICAgICB0aGlzLl91cGxvYWRDb3VudC0tO1xyXG4gICAgICAgIHN1YnNjcmliZXIuY29tcGxldGUoKTtcclxuICAgICAgfVxyXG4gICAgfSk7XHJcbiAgICB9KTtcclxuICAgIHJldHVybiB3cmFwT2JzO1xyXG4gIH1cclxuXHJcbiAgLy8gcHV0U2Vzc2lvbk9ic2VydmVyKHNlc3Npb246IFNlc3Npb24pOiBPYnNlcnZhYmxlPFNlc3Npb24+IHtcclxuICAvL1xyXG4gIC8vICAgbGV0IHNlc3NzVXJsID0gdGhpcy5hcGlFbmRQb2ludCArIFByb2plY3RTZXJ2aWNlLlBST0pFQ1RfQVBJX0NUWCArICcvJyArIHNlc3Npb24ucHJvamVjdCArICcvJyArIFNlc3Npb25TZXJ2aWNlLlNFU1NJT05fQVBJX0NUWCArICcvJyArIHNlc3Npb24uc2Vzc2lvblxyXG4gIC8vXHJcbiAgLy8gICBsZXQgd3JhcE9icyA9IG5ldyBPYnNlcnZhYmxlPFNlc3Npb24+KHN1YnNjcmliZXIgPT4ge1xyXG4gIC8vICAgICB0aGlzLl91cGxvYWRDb3VudCsrO1xyXG4gIC8vICAgICBsZXQgb2JzID0gdGhpcy5odHRwLnB1dDxTZXNzaW9uPihzZXNzc1VybCwgc2Vzc2lvbiwge3dpdGhDcmVkZW50aWFsczogdGhpcy53aXRoQ3JlZGVudGlhbHN9KTtcclxuICAvLyAgICAgb2JzLnN1YnNjcmliZSgodmFsdWUpID0+IHtcclxuICAvLyAgICAgICBzdWJzY3JpYmVyLm5leHQodmFsdWUpO1xyXG4gIC8vICAgICB9LCBlcnJvciA9PiB7XHJcbiAgLy8gICAgICAgdGhpcy5fdXBsb2FkQ291bnQtLTtcclxuICAvLyAgICAgICBzdWJzY3JpYmVyLmVycm9yKGVycm9yKTtcclxuICAvLyAgICAgfSwgKCkgPT4ge1xyXG4gIC8vICAgICAgIHRoaXMuX3VwbG9hZENvdW50LS07XHJcbiAgLy8gICAgICAgc3Vic2NyaWJlci5jb21wbGV0ZSgpO1xyXG4gIC8vICAgICB9KTtcclxuICAvLyAgIH0pO1xyXG4gIC8vICAgcmV0dXJuIHdyYXBPYnM7XHJcbiAgLy8gfVxyXG4gIC8vXHJcblxyXG5cclxufVxyXG5cclxuXHJcblxyXG4iXX0=
@@ -1,46 +0,0 @@
1
- import { Component, Inject } from "@angular/core";
2
- import { MAT_DIALOG_DATA } from "@angular/material/dialog";
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/material/dialog";
5
- import * as i2 from "@angular/material/icon";
6
- import * as i3 from "@angular/material/button";
7
- export class SessionFinishedDialog {
8
- constructor(dialogRef, data) {
9
- this.dialogRef = dialogRef;
10
- this.data = data;
11
- }
12
- closeDialog() {
13
- this.dialogRef.close();
14
- }
15
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SessionFinishedDialog, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
16
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: SessionFinishedDialog, selector: "spr-session-finished-dialog", ngImport: i0, template: `<h1 mat-dialog-title><mat-icon [style.color]="'green'">done_all</mat-icon> Session finished</h1>
17
- <div mat-dialog-content>
18
-
19
- <p>Thank you! The recording session is complete.</p>
20
-
21
- </div>
22
- <div mat-dialog-actions>
23
- <button mat-button (click)="closeDialog()">OK</button>
24
- </div>
25
- `, isInline: true, dependencies: [{ kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }] }); }
26
- }
27
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SessionFinishedDialog, decorators: [{
28
- type: Component,
29
- args: [{
30
- selector: 'spr-session-finished-dialog',
31
- template: `<h1 mat-dialog-title><mat-icon [style.color]="'green'">done_all</mat-icon> Session finished</h1>
32
- <div mat-dialog-content>
33
-
34
- <p>Thank you! The recording session is complete.</p>
35
-
36
- </div>
37
- <div mat-dialog-actions>
38
- <button mat-button (click)="closeDialog()">OK</button>
39
- </div>
40
- `
41
- }]
42
- }], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
43
- type: Inject,
44
- args: [MAT_DIALOG_DATA]
45
- }] }] });
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Vzc2lvbl9maW5pc2hlZF9kaWFsb2cuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zcGVlY2hyZWNvcmRlcm5nL3NyYy9saWIvc3BlZWNocmVjb3JkZXIvc2Vzc2lvbi9zZXNzaW9uX2ZpbmlzaGVkX2RpYWxvZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsU0FBUyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUUsZUFBZSxFQUFnQixNQUFNLDBCQUEwQixDQUFDOzs7OztBQWV6RSxNQUFNLE9BQU8scUJBQXFCO0lBRWhDLFlBQ1MsU0FBOEMsRUFDckIsSUFBUztRQURsQyxjQUFTLEdBQVQsU0FBUyxDQUFxQztRQUNyQixTQUFJLEdBQUosSUFBSSxDQUFLO0lBQUksQ0FBQztJQUVoRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN6QixDQUFDOytHQVJVLHFCQUFxQiw4Q0FJdEIsZUFBZTttR0FKZCxxQkFBcUIsbUVBWHRCOzs7Ozs7Ozs7R0FTVDs7NEZBRVUscUJBQXFCO2tCQWJqQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSw2QkFBNkI7b0JBQ3ZDLFFBQVEsRUFBRTs7Ozs7Ozs7O0dBU1Q7aUJBQ0Y7OzBCQUtJLE1BQU07MkJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbIlxyXG5pbXBvcnQge0NvbXBvbmVudCwgSW5qZWN0fSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBNQVRfRElBTE9HX0RBVEEsIE1hdERpYWxvZ1JlZiB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2dcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnc3ByLXNlc3Npb24tZmluaXNoZWQtZGlhbG9nJyxcclxuICB0ZW1wbGF0ZTogYDxoMSBtYXQtZGlhbG9nLXRpdGxlPjxtYXQtaWNvbiBbc3R5bGUuY29sb3JdPVwiJ2dyZWVuJ1wiPmRvbmVfYWxsPC9tYXQtaWNvbj4gU2Vzc2lvbiBmaW5pc2hlZDwvaDE+XHJcbiAgPGRpdiBtYXQtZGlhbG9nLWNvbnRlbnQ+XHJcblxyXG4gICAgPHA+VGhhbmsgeW91ISBUaGUgcmVjb3JkaW5nIHNlc3Npb24gaXMgY29tcGxldGUuPC9wPlxyXG5cclxuICA8L2Rpdj5cclxuICA8ZGl2IG1hdC1kaWFsb2ctYWN0aW9ucz5cclxuICAgIDxidXR0b24gbWF0LWJ1dHRvbiAoY2xpY2spPVwiY2xvc2VEaWFsb2coKVwiPk9LPC9idXR0b24+XHJcbiAgPC9kaXY+XHJcbiAgYFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2Vzc2lvbkZpbmlzaGVkRGlhbG9ne1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHB1YmxpYyBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxTZXNzaW9uRmluaXNoZWREaWFsb2c+LFxyXG4gICAgQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBkYXRhOiBhbnkpIHsgfVxyXG5cclxuICBjbG9zZURpYWxvZygpOiB2b2lkIHtcclxuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKCk7XHJcbiAgfVxyXG5cclxufVxyXG4iXX0=