speechrecorderng 3.10.13 → 3.11.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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,97 +0,0 @@
1
- import { NgModule } from '@angular/core';
2
- import { SpeechrecorderngComponent } from "./speechrecorderng.component";
3
- import { SimpleTrafficLight } from "./speechrecorder/startstopsignal/ui/simpletrafficlight";
4
- import { CommonModule } from "@angular/common";
5
- import { Progress } from "./speechrecorder/session/progress";
6
- import { PromptContainer, Prompter, Prompting, PromptingContainer, Recinstructions, } from "./speechrecorder/session/prompting";
7
- import { SessionManager } from "./speechrecorder/session/sessionmanager";
8
- import { WarningBar } from "./speechrecorder/session/warning_bar";
9
- import { ScrollIntoViewDirective } from "./utils/scrollIntoViewToBottom";
10
- import { MatButtonModule } from "@angular/material/button";
11
- import { MatDialogModule } from "@angular/material/dialog";
12
- import { MatIconModule } from "@angular/material/icon";
13
- import { MatProgressBarModule } from "@angular/material/progress-bar";
14
- import { MatProgressSpinnerModule } from "@angular/material/progress-spinner";
15
- import { MatTooltipModule } from "@angular/material/tooltip";
16
- import { provideHttpClient, withInterceptorsFromDi } from "@angular/common/http";
17
- import { SessionService } from "./speechrecorder/session/session.service";
18
- import { ScriptService } from "./speechrecorder/script/script.service";
19
- import { RouterModule } from "@angular/router";
20
- import { SPEECHRECORDER_CONFIG } from "./spr.config";
21
- import { SpeechRecorderUploader } from "./speechrecorder/spruploader";
22
- import { ProjectService } from "./speechrecorder/project/project.service";
23
- import { ControlPanel, ProgressDisplay, ReadyStateIndicator, StatusDisplay, TransportPanel, UploadStatus, WakeLockIndicator } from "./speechrecorder/session/controlpanel";
24
- //import {FlexLayoutModule} from "@angular/flex-layout";
25
- import { SessionFinishedDialog } from "./speechrecorder/session/session_finished_dialog";
26
- import { MessageDialog } from "./ui/message_dialog";
27
- import { RecordingItemControls, RecordingItemDisplay } from "./ui/recordingitem_display";
28
- import { RecordingService } from "./speechrecorder/recordings/recordings.service";
29
- import { ScrollPaneHorizontal } from "./audio/ui/scroll_pane_horizontal";
30
- import { AudioClipUIContainer } from "./audio/ui/container";
31
- import { AudioSignal } from "./audio/ui/audiosignal";
32
- import { Sonagram } from "./audio/ui/sonagram";
33
- import { AudioDisplayPlayer } from "./audio/audio_player";
34
- import { AudioDisplay } from "./audio/audio_display";
35
- import { AudioDisplayControl } from "./audio/ui/audio_display_control";
36
- import { LevelBar } from "./audio/ui/livelevel";
37
- import { AudioDisplayScrollPane } from "./audio/ui/audio_display_scroll_pane";
38
- import { MatCheckboxModule } from "@angular/material/checkbox";
39
- import { MatCardModule } from "@angular/material/card";
40
- import { MatDividerModule } from "@angular/material/divider";
41
- import { MatGridListModule } from "@angular/material/grid-list";
42
- import { RecordingFileUI } from "./speechrecorder/session/recordingfile/recording-file-u-i.component";
43
- import { RecordingFileService } from "./speechrecorder/session/recordingfile/recordingfile-service";
44
- import { RecordingFileViewComponent } from "./speechrecorder/session/recordingfile/recording-file-view.component";
45
- import { MatTableModule } from "@angular/material/table";
46
- import { RecordingFileNaviComponent } from './speechrecorder/session/recordingfile/recording-file-navi.component';
47
- import { RecordingFileMetaComponent } from "./speechrecorder/session/recordingfile/recording-file-meta.component";
48
- import { MatSelectModule } from "@angular/material/select";
49
- import { MatInputModule } from "@angular/material/input";
50
- import { MatSnackBarModule } from "@angular/material/snack-bar";
51
- import { AudioRecorder, AudioRecorderComponent } from "./speechrecorder/session/audiorecorder";
52
- import { RecordingList } from "./speechrecorder/session/recording_list";
53
- import { RecorderCombiPane } from "./speechrecorder/session/recorder_combi_pane";
54
- import { MatMenuModule } from "@angular/material/menu";
55
- import { IntersectionObserverDirective } from "./ui/intersection-observer.directive";
56
- import * as i0 from "@angular/core";
57
- import * as i1 from "@angular/router";
58
- export const SPR_ROUTES = [
59
- { path: 'spr/session/:id', component: SpeechrecorderngComponent },
60
- { path: 'recorder/session/:id', component: AudioRecorderComponent },
61
- { path: 'recorder', component: AudioRecorderComponent },
62
- { path: 'spr/db/project/:project/session/:sessionId/recordingfile/_view/:recordingFileId', component: RecordingFileViewComponent },
63
- { path: 'spr/db/project/:project/session/:sessionId/recordingfile/_edit/:recordingFileId', component: RecordingFileUI },
64
- { path: 'spr/db/project/:project/session/:sessionId/recordingfile/_view', component: RecordingFileViewComponent },
65
- { path: 'spr/db/project/:project/session/:sessionId/recordingfile/_edit', component: RecordingFileUI },
66
- { path: 'spr/db/project/:project/session/:sessionId/recordingfile/:recordingFileId', component: RecordingFileUI },
67
- { path: 'spr/db/project/:project/session/:sessionId/recordingfile', component: RecordingFileUI },
68
- { path: 'spr/db/recordingfile/_view/:recordingFileId', component: RecordingFileViewComponent },
69
- { path: 'spr/db/recordingfile/_edit/:recordingFileId', component: RecordingFileUI },
70
- { path: 'spr/db/recordingfile/_view/', component: RecordingFileViewComponent },
71
- { path: 'spr/db/recordingfile/_view', component: RecordingFileViewComponent },
72
- { path: 'spr/db/recordingfile/_edit', component: RecordingFileUI },
73
- { path: 'spr/db/recordingfile/:recordingFileId', component: RecordingFileUI },
74
- { path: 'spr/db/recordingfile', component: RecordingFileUI },
75
- { path: 'spr', component: SpeechrecorderngComponent }
76
- ];
77
- export class SpeechrecorderngModule {
78
- static forRoot(config) {
79
- return {
80
- ngModule: SpeechrecorderngModule,
81
- providers: [
82
- { provide: SPEECHRECORDER_CONFIG, useValue: config }
83
- ]
84
- };
85
- }
86
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SpeechrecorderngModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
87
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.12", ngImport: i0, type: SpeechrecorderngModule, declarations: [AudioSignal, Sonagram, ScrollPaneHorizontal, AudioClipUIContainer, AudioDisplayScrollPane, AudioDisplay, AudioDisplayPlayer, AudioDisplayControl, LevelBar, Progress, SimpleTrafficLight, Recinstructions, Prompter, PromptContainer, PromptingContainer, Prompting, StatusDisplay,
88
- ProgressDisplay, RecordingItemDisplay, RecordingItemControls, UploadStatus, TransportPanel, WakeLockIndicator, ReadyStateIndicator, ControlPanel, WarningBar, AudioRecorder, SessionManager, MessageDialog, SessionFinishedDialog, SpeechrecorderngComponent, AudioRecorderComponent, RecordingFileViewComponent, RecordingFileUI, ScrollIntoViewDirective, RecordingFileNaviComponent, RecordingFileMetaComponent, RecordingList, RecorderCombiPane, AudioRecorder], imports: [i1.RouterModule, CommonModule, MatIconModule, MatButtonModule, MatDialogModule, MatProgressBarModule, MatProgressSpinnerModule, MatTooltipModule, MatCheckboxModule, MatCardModule, MatDividerModule, MatGridListModule, MatTableModule, MatInputModule, MatSelectModule, MatSnackBarModule, MatMenuModule, IntersectionObserverDirective], exports: [MessageDialog, SpeechrecorderngComponent, ScrollPaneHorizontal, AudioClipUIContainer, AudioDisplayScrollPane, AudioDisplay, AudioDisplayPlayer, AudioDisplayControl, LevelBar, AudioRecorder] }); }
89
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SpeechrecorderngModule, providers: [SessionService, ProjectService, ScriptService, RecordingService, RecordingFileService, SpeechRecorderUploader, provideHttpClient(withInterceptorsFromDi())], imports: [RouterModule.forChild(SPR_ROUTES), CommonModule, MatIconModule, MatButtonModule, MatDialogModule, MatProgressBarModule, MatProgressSpinnerModule, MatTooltipModule, MatCheckboxModule, MatCardModule, MatDividerModule, MatGridListModule, MatTableModule, MatInputModule, MatSelectModule, MatSnackBarModule, MatMenuModule] }); }
90
- }
91
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SpeechrecorderngModule, decorators: [{
92
- type: NgModule,
93
- args: [{ declarations: [AudioSignal, Sonagram, ScrollPaneHorizontal, AudioClipUIContainer, AudioDisplayScrollPane, AudioDisplay, AudioDisplayPlayer, AudioDisplayControl, LevelBar, Progress, SimpleTrafficLight, Recinstructions, Prompter, PromptContainer, PromptingContainer, Prompting, StatusDisplay,
94
- ProgressDisplay, RecordingItemDisplay, RecordingItemControls, UploadStatus, TransportPanel, WakeLockIndicator, ReadyStateIndicator, ControlPanel, WarningBar, AudioRecorder, SessionManager, MessageDialog, SessionFinishedDialog, SpeechrecorderngComponent, AudioRecorderComponent, RecordingFileViewComponent, RecordingFileUI, ScrollIntoViewDirective, RecordingFileNaviComponent, RecordingFileMetaComponent, RecordingList, RecorderCombiPane, AudioRecorder],
95
- exports: [MessageDialog, SpeechrecorderngComponent, ScrollPaneHorizontal, AudioClipUIContainer, AudioDisplayScrollPane, AudioDisplay, AudioDisplayPlayer, AudioDisplayControl, LevelBar, AudioRecorder], imports: [RouterModule.forChild(SPR_ROUTES), CommonModule, MatIconModule, MatButtonModule, MatDialogModule, MatProgressBarModule, MatProgressSpinnerModule, MatTooltipModule, MatCheckboxModule, MatCardModule, MatDividerModule, MatGridListModule, MatTableModule, MatInputModule, MatSelectModule, MatSnackBarModule, MatMenuModule, IntersectionObserverDirective], providers: [SessionService, ProjectService, ScriptService, RecordingService, RecordingFileService, SpeechRecorderUploader, provideHttpClient(withInterceptorsFromDi())] }]
96
- }] });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"speechrecorderng.module.js","sourceRoot":"","sources":["../../../../projects/speechrecorderng/src/lib/speechrecorderng.module.ts"],"names":[],"mappings":"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","sourcesContent":["import {ModuleWithProviders, NgModule} from '@angular/core';\r\nimport {SpeechrecorderngComponent} from \"./speechrecorderng.component\";\r\nimport {SimpleTrafficLight} from \"./speechrecorder/startstopsignal/ui/simpletrafficlight\";\r\n\r\nimport {CommonModule} from \"@angular/common\";\r\nimport {Progress} from \"./speechrecorder/session/progress\";\r\nimport {\r\n  PromptContainer, Prompter, Prompting, PromptingContainer, Recinstructions,\r\n} from \"./speechrecorder/session/prompting\";\r\nimport {SessionManager} from \"./speechrecorder/session/sessionmanager\";\r\nimport {WarningBar} from \"./speechrecorder/session/warning_bar\";\r\nimport {ScrollIntoViewDirective} from \"./utils/scrollIntoViewToBottom\";\r\nimport { MatButtonModule } from \"@angular/material/button\";\r\nimport { MatDialogModule } from \"@angular/material/dialog\";\r\nimport { MatIconModule } from \"@angular/material/icon\";\r\nimport { MatProgressBarModule } from \"@angular/material/progress-bar\";\r\nimport { MatProgressSpinnerModule } from \"@angular/material/progress-spinner\";\r\nimport { MatTooltipModule } from \"@angular/material/tooltip\";\r\nimport { provideHttpClient, withInterceptorsFromDi } from \"@angular/common/http\";\r\nimport {SessionService} from \"./speechrecorder/session/session.service\";\r\nimport {ScriptService} from \"./speechrecorder/script/script.service\";\r\nimport {RouterModule, Routes} from \"@angular/router\";\r\nimport {SpeechRecorderConfig, SPEECHRECORDER_CONFIG} from \"./spr.config\";\r\nimport {SpeechRecorderUploader} from \"./speechrecorder/spruploader\";\r\nimport {ProjectService} from \"./speechrecorder/project/project.service\";\r\nimport {\r\n  ControlPanel,\r\n  ProgressDisplay,\r\n  ReadyStateIndicator,\r\n  StatusDisplay,\r\n  TransportPanel,\r\n  UploadStatus, WakeLockIndicator\r\n} from \"./speechrecorder/session/controlpanel\";\r\n//import {FlexLayoutModule} from \"@angular/flex-layout\";\r\nimport {SessionFinishedDialog} from \"./speechrecorder/session/session_finished_dialog\";\r\nimport {MessageDialog} from \"./ui/message_dialog\";\r\nimport {RecordingItemControls, RecordingItemDisplay} from \"./ui/recordingitem_display\";\r\nimport {RecordingService} from \"./speechrecorder/recordings/recordings.service\";\r\nimport {ScrollPaneHorizontal} from \"./audio/ui/scroll_pane_horizontal\";\r\nimport {AudioClipUIContainer} from \"./audio/ui/container\";\r\nimport {AudioSignal} from \"./audio/ui/audiosignal\";\r\nimport {Sonagram} from \"./audio/ui/sonagram\";\r\nimport {AudioDisplayPlayer} from \"./audio/audio_player\";\r\nimport {AudioDisplay} from \"./audio/audio_display\";\r\nimport {AudioDisplayControl} from \"./audio/ui/audio_display_control\";\r\nimport {LevelBar} from \"./audio/ui/livelevel\";\r\nimport {AudioDisplayScrollPane} from \"./audio/ui/audio_display_scroll_pane\";\r\nimport {MatCheckboxModule} from \"@angular/material/checkbox\";\r\nimport {MatCardModule} from \"@angular/material/card\";\r\nimport {MatDividerModule} from \"@angular/material/divider\";\r\nimport {MatGridListModule} from \"@angular/material/grid-list\";\r\nimport {RecordingFileUI} from \"./speechrecorder/session/recordingfile/recording-file-u-i.component\";\r\nimport {RecordingFileService} from \"./speechrecorder/session/recordingfile/recordingfile-service\";\r\nimport {RecordingFileViewComponent} from \"./speechrecorder/session/recordingfile/recording-file-view.component\";\r\nimport {MatTableModule} from \"@angular/material/table\";\r\nimport { RecordingFileNaviComponent } from './speechrecorder/session/recordingfile/recording-file-navi.component';\r\nimport {RecordingFileMetaComponent} from \"./speechrecorder/session/recordingfile/recording-file-meta.component\";\r\nimport {MatSelectModule} from \"@angular/material/select\";\r\nimport {MatInputModule} from \"@angular/material/input\";\r\nimport {MatSnackBarModule} from \"@angular/material/snack-bar\";\r\nimport {AudioRecorder, AudioRecorderComponent} from \"./speechrecorder/session/audiorecorder\";\r\nimport {RecordingList} from \"./speechrecorder/session/recording_list\";\r\nimport {RecorderCombiPane} from \"./speechrecorder/session/recorder_combi_pane\";\r\nimport {MatMenuModule} from \"@angular/material/menu\";\r\nimport {IntersectionObserverDirective} from \"./ui/intersection-observer.directive\";\r\n\r\n\r\n\r\n\r\nexport const SPR_ROUTES: Routes = [\r\n  { path: 'spr/session/:id',      component: SpeechrecorderngComponent },\r\n  { path: 'recorder/session/:id',      component: AudioRecorderComponent},\r\n  { path: 'recorder',      component: AudioRecorderComponent},\r\n  { path: 'spr/db/project/:project/session/:sessionId/recordingfile/_view/:recordingFileId',      component: RecordingFileViewComponent },\r\n  { path: 'spr/db/project/:project/session/:sessionId/recordingfile/_edit/:recordingFileId',      component: RecordingFileUI },\r\n  { path: 'spr/db/project/:project/session/:sessionId/recordingfile/_view',      component: RecordingFileViewComponent },\r\n  { path: 'spr/db/project/:project/session/:sessionId/recordingfile/_edit',      component: RecordingFileUI },\r\n  { path: 'spr/db/project/:project/session/:sessionId/recordingfile/:recordingFileId',      component: RecordingFileUI },\r\n  { path: 'spr/db/project/:project/session/:sessionId/recordingfile',      component: RecordingFileUI },\r\n  { path: 'spr/db/recordingfile/_view/:recordingFileId',      component: RecordingFileViewComponent },\r\n  { path: 'spr/db/recordingfile/_edit/:recordingFileId',      component: RecordingFileUI },\r\n  { path: 'spr/db/recordingfile/_view/',      component: RecordingFileViewComponent },\r\n  { path: 'spr/db/recordingfile/_view',      component: RecordingFileViewComponent },\r\n  { path: 'spr/db/recordingfile/_edit',      component: RecordingFileUI },\r\n  { path: 'spr/db/recordingfile/:recordingFileId',      component: RecordingFileUI },\r\n  { path: 'spr/db/recordingfile',      component: RecordingFileUI },\r\n  { path: 'spr',      component: SpeechrecorderngComponent }\r\n];\r\n\r\n@NgModule({ declarations: [AudioSignal, Sonagram, ScrollPaneHorizontal, AudioClipUIContainer, AudioDisplayScrollPane, AudioDisplay, AudioDisplayPlayer, AudioDisplayControl, LevelBar, Progress, SimpleTrafficLight, Recinstructions, Prompter, PromptContainer, PromptingContainer, Prompting, StatusDisplay,\r\n        ProgressDisplay, RecordingItemDisplay, RecordingItemControls, UploadStatus, TransportPanel, WakeLockIndicator, ReadyStateIndicator, ControlPanel, WarningBar, AudioRecorder, SessionManager, MessageDialog, SessionFinishedDialog, SpeechrecorderngComponent, AudioRecorderComponent, RecordingFileViewComponent, RecordingFileUI, ScrollIntoViewDirective, RecordingFileNaviComponent, RecordingFileMetaComponent, RecordingList, RecorderCombiPane, AudioRecorder],\r\n    exports: [MessageDialog, SpeechrecorderngComponent, ScrollPaneHorizontal, AudioClipUIContainer, AudioDisplayScrollPane, AudioDisplay, AudioDisplayPlayer, AudioDisplayControl, LevelBar, AudioRecorder], imports: [RouterModule.forChild(SPR_ROUTES), CommonModule, MatIconModule, MatButtonModule, MatDialogModule, MatProgressBarModule, MatProgressSpinnerModule, MatTooltipModule, MatCheckboxModule, MatCardModule, MatDividerModule, MatGridListModule, MatTableModule, MatInputModule, MatSelectModule, MatSnackBarModule, MatMenuModule, IntersectionObserverDirective], providers: [SessionService, ProjectService, ScriptService, RecordingService, RecordingFileService, SpeechRecorderUploader, provideHttpClient(withInterceptorsFromDi())] })\r\nexport class SpeechrecorderngModule{\r\n\r\n  static forRoot(config: SpeechRecorderConfig): ModuleWithProviders<SpeechrecorderngModule> {\r\n    return {\r\n      ngModule: SpeechrecorderngModule,\r\n      providers: [\r\n        {provide: SPEECHRECORDER_CONFIG, useValue: config }\r\n      ]\r\n    };\r\n  }\r\n}\r\n"]}
@@ -1,27 +0,0 @@
1
- import { Injectable, InjectionToken } from "@angular/core";
2
- import * as i0 from "@angular/core";
3
- export const SPEECHRECORDER_CONFIG = new InjectionToken('speechrecorder.config');
4
- export var ApiType;
5
- (function (ApiType) {
6
- ApiType[ApiType["NORMAL"] = 0] = "NORMAL";
7
- ApiType[ApiType["FILES"] = 1] = "FILES";
8
- })(ApiType || (ApiType = {}));
9
- export class SpeechRecorderConfig {
10
- constructor() {
11
- this.apiEndPoint = null;
12
- this.apiType = null;
13
- this.apiVersion = 1;
14
- this.withCredentials = false;
15
- this.enableDownloadRecordings = false;
16
- this.enableUploadRecordings = true;
17
- this.apiEndPoint = null;
18
- this.apiType = null;
19
- this.withCredentials = false;
20
- }
21
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SpeechRecorderConfig, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
22
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SpeechRecorderConfig }); }
23
- }
24
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SpeechRecorderConfig, decorators: [{
25
- type: Injectable
26
- }], ctorParameters: () => [] });
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ByLmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3NwZWVjaHJlY29yZGVybmcvc3JjL2xpYi9zcHIuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxVQUFVLEVBQUUsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDOztBQUV6RCxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLGNBQWMsQ0FBdUIsdUJBQXVCLENBQUMsQ0FBQztBQUd2RyxNQUFNLENBQU4sSUFBWSxPQUVYO0FBRkQsV0FBWSxPQUFPO0lBQ2pCLHlDQUFNLENBQUE7SUFBQyx1Q0FBSyxDQUFBO0FBQ2QsQ0FBQyxFQUZXLE9BQU8sS0FBUCxPQUFPLFFBRWxCO0FBRUQsTUFBTSxPQUFPLG9CQUFvQjtJQU8vQjtRQU5BLGdCQUFXLEdBQWlCLElBQUksQ0FBQztRQUNqQyxZQUFPLEdBQWtCLElBQUksQ0FBQztRQUM5QixlQUFVLEdBQVMsQ0FBQyxDQUFDO1FBQ3JCLG9CQUFlLEdBQVcsS0FBSyxDQUFDO1FBQ2hDLDZCQUF3QixHQUFXLEtBQUssQ0FBQztRQUN6QywyQkFBc0IsR0FBVyxJQUFJLENBQUM7UUFFcEMsSUFBSSxDQUFDLFdBQVcsR0FBQyxJQUFJLENBQUM7UUFDdEIsSUFBSSxDQUFDLE9BQU8sR0FBQyxJQUFJLENBQUM7UUFDbEIsSUFBSSxDQUFDLGVBQWUsR0FBQyxLQUFLLENBQUM7SUFDN0IsQ0FBQzsrR0FYVSxvQkFBb0I7bUhBQXBCLG9CQUFvQjs7NEZBQXBCLG9CQUFvQjtrQkFEaEMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZSwgSW5qZWN0aW9uVG9rZW59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5leHBvcnQgY29uc3QgU1BFRUNIUkVDT1JERVJfQ09ORklHID0gbmV3IEluamVjdGlvblRva2VuPFNwZWVjaFJlY29yZGVyQ29uZmlnPignc3BlZWNocmVjb3JkZXIuY29uZmlnJyk7XHJcblxyXG5cclxuZXhwb3J0IGVudW0gQXBpVHlwZSB7XHJcbiAgTk9STUFMLEZJTEVTXHJcbn1cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgU3BlZWNoUmVjb3JkZXJDb25maWd7XHJcbiAgYXBpRW5kUG9pbnQ/OiBzdHJpbmcgfCBudWxsPW51bGw7XHJcbiAgYXBpVHlwZT86IEFwaVR5cGUgfCBudWxsPW51bGw7XHJcbiAgYXBpVmVyc2lvbjogbnVtYmVyPTE7XHJcbiAgd2l0aENyZWRlbnRpYWxzPzogYm9vbGVhbj1mYWxzZTtcclxuICBlbmFibGVEb3dubG9hZFJlY29yZGluZ3M/OiBib29sZWFuPWZhbHNlO1xyXG4gIGVuYWJsZVVwbG9hZFJlY29yZGluZ3M/OiBib29sZWFuPXRydWU7XHJcbiAgY29uc3RydWN0b3IoKXtcclxuICAgIHRoaXMuYXBpRW5kUG9pbnQ9bnVsbDtcclxuICAgIHRoaXMuYXBpVHlwZT1udWxsO1xyXG4gICAgdGhpcy53aXRoQ3JlZGVudGlhbHM9ZmFsc2U7XHJcbiAgfVxyXG59XHJcblxyXG4iXX0=
@@ -1,2 +0,0 @@
1
- export const VERSION = '3.10.13';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ByLm1vZHVsZS52ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL3Nwci5tb2R1bGUudmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUMsU0FBUyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFZFUlNJT049JzMuMTAuMTMnIl19
@@ -1,38 +0,0 @@
1
- import { Position } from "../math/2d/geometry";
2
- import { Directive } from "@angular/core";
3
- import * as i0 from "@angular/core";
4
- export class CanvasLayerComponent {
5
- constructor() {
6
- this.bounds = null;
7
- // TODO make clear that first element is background canvas
8
- this.canvasLayers = new Array();
9
- }
10
- toXViewPortPixelPosition(virtualX) {
11
- let pixelPos = virtualX;
12
- if (this.bounds) {
13
- pixelPos = Math.round(virtualX - this.bounds.position.left);
14
- }
15
- return pixelPos;
16
- }
17
- toXVirtualPixelPosition(viewPortX) {
18
- let pixelPos = viewPortX;
19
- if (this.bounds) {
20
- pixelPos = Math.round(viewPortX + this.bounds.position.left);
21
- }
22
- return pixelPos;
23
- }
24
- toViewPortPosition(virtualPos) {
25
- if (this.bounds) {
26
- return new Position(virtualPos.left - this.bounds.position.left, virtualPos.top - this.bounds.position.top);
27
- }
28
- else {
29
- return virtualPos;
30
- }
31
- }
32
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: CanvasLayerComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
33
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.12", type: CanvasLayerComponent, ngImport: i0 }); }
34
- }
35
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: CanvasLayerComponent, decorators: [{
36
- type: Directive
37
- }], ctorParameters: () => [] });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FudmFzX2xheWVyX2NvbXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zcGVlY2hyZWNvcmRlcm5nL3NyYy9saWIvdWkvY2FudmFzX2xheWVyX2NvbXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFFBQVEsRUFBc0IsTUFBTSxxQkFBcUIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUcxQyxNQUFNLE9BQWdCLG9CQUFvQjtJQU14QztRQUpVLFdBQU0sR0FBZ0IsSUFBSSxDQUFDO1FBTW5DLDBEQUEwRDtRQUMxRCxJQUFJLENBQUMsWUFBWSxHQUFDLElBQUksS0FBSyxFQUFxQixDQUFDO0lBQ25ELENBQUM7SUFFRCx3QkFBd0IsQ0FBQyxRQUFlO1FBQ3RDLElBQUksUUFBUSxHQUFDLFFBQVEsQ0FBQztRQUNwQixJQUFHLElBQUksQ0FBQyxNQUFNLEVBQUMsQ0FBQztZQUNaLFFBQVEsR0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsR0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUM1RCxDQUFDO1FBQ0QsT0FBTyxRQUFRLENBQUM7SUFDcEIsQ0FBQztJQUVELHVCQUF1QixDQUFDLFNBQWdCO1FBQ3RDLElBQUksUUFBUSxHQUFDLFNBQVMsQ0FBQztRQUN2QixJQUFHLElBQUksQ0FBQyxNQUFNLEVBQUMsQ0FBQztZQUNkLFFBQVEsR0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsR0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMzRCxDQUFDO1FBQ0QsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztJQUVELGtCQUFrQixDQUFDLFVBQW1CO1FBRXBDLElBQUcsSUFBSSxDQUFDLE1BQU0sRUFBQyxDQUFDO1lBQ2QsT0FBTyxJQUFJLFFBQVEsQ0FBQyxVQUFVLENBQUMsSUFBSSxHQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksRUFBQyxVQUFVLENBQUMsR0FBRyxHQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3pHLENBQUM7YUFBSSxDQUFDO1lBQ0osT0FBTyxVQUFVLENBQUM7UUFDcEIsQ0FBQztJQUNILENBQUM7K0dBbkNtQixvQkFBb0I7bUdBQXBCLG9CQUFvQjs7NEZBQXBCLG9CQUFvQjtrQkFEekMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7UG9zaXRpb24sRGltZW5zaW9uLCBSZWN0YW5nbGV9IGZyb20gXCIuLi9tYXRoLzJkL2dlb21ldHJ5XCI7XHJcbmltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5ARGlyZWN0aXZlKClcclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIENhbnZhc0xheWVyQ29tcG9uZW50e1xyXG5cclxuICBwcm90ZWN0ZWQgYm91bmRzOlJlY3RhbmdsZXxudWxsPW51bGw7XHJcbiAgcHJvdGVjdGVkIHZpcnR1YWxEaW1lbnNpb24hOkRpbWVuc2lvbjtcclxuICBwcm90ZWN0ZWQgY2FudmFzTGF5ZXJzOkFycmF5PEhUTUxDYW52YXNFbGVtZW50PjtcclxuXHJcbiAgY29uc3RydWN0b3IoKXtcclxuXHJcbiAgICAvLyBUT0RPIG1ha2UgY2xlYXIgdGhhdCBmaXJzdCBlbGVtZW50IGlzIGJhY2tncm91bmQgY2FudmFzXHJcbiAgICB0aGlzLmNhbnZhc0xheWVycz1uZXcgQXJyYXk8SFRNTENhbnZhc0VsZW1lbnQ+KCk7XHJcbiAgfVxyXG5cclxuICB0b1hWaWV3UG9ydFBpeGVsUG9zaXRpb24odmlydHVhbFg6bnVtYmVyKXtcclxuICAgIGxldCBwaXhlbFBvcz12aXJ0dWFsWDtcclxuICAgICAgaWYodGhpcy5ib3VuZHMpe1xyXG4gICAgICAgICAgcGl4ZWxQb3M9TWF0aC5yb3VuZCh2aXJ0dWFsWC10aGlzLmJvdW5kcy5wb3NpdGlvbi5sZWZ0KTtcclxuICAgICAgfVxyXG4gICAgICByZXR1cm4gcGl4ZWxQb3M7XHJcbiAgfVxyXG5cclxuICB0b1hWaXJ0dWFsUGl4ZWxQb3NpdGlvbih2aWV3UG9ydFg6bnVtYmVyKXtcclxuICAgIGxldCBwaXhlbFBvcz12aWV3UG9ydFg7XHJcbiAgICBpZih0aGlzLmJvdW5kcyl7XHJcbiAgICAgIHBpeGVsUG9zPU1hdGgucm91bmQodmlld1BvcnRYK3RoaXMuYm91bmRzLnBvc2l0aW9uLmxlZnQpO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHBpeGVsUG9zO1xyXG4gIH1cclxuXHJcbiAgdG9WaWV3UG9ydFBvc2l0aW9uKHZpcnR1YWxQb3M6UG9zaXRpb24pOlBvc2l0aW9ue1xyXG5cclxuICAgIGlmKHRoaXMuYm91bmRzKXtcclxuICAgICAgcmV0dXJuIG5ldyBQb3NpdGlvbih2aXJ0dWFsUG9zLmxlZnQtdGhpcy5ib3VuZHMucG9zaXRpb24ubGVmdCx2aXJ0dWFsUG9zLnRvcC10aGlzLmJvdW5kcy5wb3NpdGlvbi50b3ApO1xyXG4gICAgfWVsc2V7XHJcbiAgICAgIHJldHVybiB2aXJ0dWFsUG9zO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcblxyXG59XHJcbiJdfQ==
@@ -1,32 +0,0 @@
1
- import { Directive, Input } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class IntersectionObserverDirective {
4
- //private intersectionObserver:IntersectionObserver|null=null;
5
- constructor(elRef) {
6
- this.elRef = elRef;
7
- const ne = this.elRef.nativeElement;
8
- //ne.style.backgroundColor = 'yellow';
9
- }
10
- set updateObservation(elIntersection) {
11
- //console.debug("visi: "+elIntersection.selected);
12
- if (elIntersection.observe) {
13
- //this.elRef.nativeElement.scrollIntoView(false);
14
- elIntersection.observer.observe(this.elRef.nativeElement);
15
- }
16
- else {
17
- elIntersection.observer.unobserve(this.elRef.nativeElement);
18
- }
19
- }
20
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: IntersectionObserverDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
21
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.12", type: IntersectionObserverDirective, isStandalone: true, selector: "[updateObservation]", inputs: { updateObservation: "updateObservation" }, ngImport: i0 }); }
22
- }
23
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: IntersectionObserverDirective, decorators: [{
24
- type: Directive,
25
- args: [{
26
- selector: '[updateObservation]',
27
- standalone: true,
28
- }]
29
- }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { updateObservation: [{
30
- type: Input
31
- }] } });
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJzZWN0aW9uLW9ic2VydmVyLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NwZWVjaHJlY29yZGVybmcvc3JjL2xpYi91aS9pbnRlcnNlY3Rpb24tb2JzZXJ2ZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQWMsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDOztBQVczRCxNQUFNLE9BQU8sNkJBQTZCO0lBRXhDLDhEQUE4RDtJQUM5RCxZQUFvQixLQUFpQjtRQUFqQixVQUFLLEdBQUwsS0FBSyxDQUFZO1FBQ25DLE1BQU0sRUFBRSxHQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDO1FBQ2xDLHNDQUFzQztJQUV4QyxDQUFDO0lBRUQsSUFDSSxpQkFBaUIsQ0FBQyxjQUFrQztRQUN0RCxrREFBa0Q7UUFDbEQsSUFBRyxjQUFjLENBQUMsT0FBTyxFQUFDLENBQUM7WUFDekIsaURBQWlEO1lBQ2pELGNBQWMsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDNUQsQ0FBQzthQUFJLENBQUM7WUFDSixjQUFjLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzlELENBQUM7SUFDSCxDQUFDOytHQWxCVSw2QkFBNkI7bUdBQTdCLDZCQUE2Qjs7NEZBQTdCLDZCQUE2QjtrQkFKekMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixVQUFVLEVBQUUsSUFBSTtpQkFDakI7K0VBV0ssaUJBQWlCO3NCQURwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRWxlbWVudEludGVyc2VjdGlvbntcclxuICAgIG9ic2VydmVyOkludGVyc2VjdGlvbk9ic2VydmVyLFxyXG4gICAgb2JzZXJ2ZTpib29sZWFuXHJcbn1cclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiAnW3VwZGF0ZU9ic2VydmF0aW9uXScsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEludGVyc2VjdGlvbk9ic2VydmVyRGlyZWN0aXZlIHtcclxuXHJcbiAgLy9wcml2YXRlIGludGVyc2VjdGlvbk9ic2VydmVyOkludGVyc2VjdGlvbk9ic2VydmVyfG51bGw9bnVsbDtcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsUmVmOiBFbGVtZW50UmVmKSB7XHJcbiAgICBjb25zdCBuZT10aGlzLmVsUmVmLm5hdGl2ZUVsZW1lbnQ7XHJcbiAgICAvL25lLnN0eWxlLmJhY2tncm91bmRDb2xvciA9ICd5ZWxsb3cnO1xyXG5cclxuICB9XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgc2V0IHVwZGF0ZU9ic2VydmF0aW9uKGVsSW50ZXJzZWN0aW9uOkVsZW1lbnRJbnRlcnNlY3Rpb24pe1xyXG4gICAgLy9jb25zb2xlLmRlYnVnKFwidmlzaTogXCIrZWxJbnRlcnNlY3Rpb24uc2VsZWN0ZWQpO1xyXG4gICAgaWYoZWxJbnRlcnNlY3Rpb24ub2JzZXJ2ZSl7XHJcbiAgICAgIC8vdGhpcy5lbFJlZi5uYXRpdmVFbGVtZW50LnNjcm9sbEludG9WaWV3KGZhbHNlKTtcclxuICAgICAgZWxJbnRlcnNlY3Rpb24ub2JzZXJ2ZXIub2JzZXJ2ZSh0aGlzLmVsUmVmLm5hdGl2ZUVsZW1lbnQpO1xyXG4gICAgfWVsc2V7XHJcbiAgICAgIGVsSW50ZXJzZWN0aW9uLm9ic2VydmVyLnVub2JzZXJ2ZSh0aGlzLmVsUmVmLm5hdGl2ZUVsZW1lbnQpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbn1cclxuIl19
@@ -1,51 +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/common";
6
- import * as i3 from "@angular/material/icon";
7
- import * as i4 from "@angular/material/button";
8
- export class MessageDialog {
9
- constructor(dialogRef, data) {
10
- this.dialogRef = dialogRef;
11
- this.data = data;
12
- }
13
- closeDialog() {
14
- this.dialogRef.close();
15
- }
16
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MessageDialog, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
17
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: MessageDialog, selector: "msg-dialog", ngImport: i0, template: `<h1 mat-dialog-title><mat-icon *ngIf="data.type==='error'" [style.color]="'red'">error</mat-icon>
18
- <mat-icon *ngIf="data.type==='warning'" [style.color]="'yellow'">warning</mat-icon>{{data.title}}</h1>
19
- <div mat-dialog-content>
20
-
21
- <p>{{data.msg}}</p>
22
- <p>{{data.advice}}</p>
23
-
24
- </div>
25
- <div mat-dialog-actions>
26
- <button mat-button (click)="closeDialog()">OK</button>
27
- </div>
28
- `, isInline: true, dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.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]" }] }); }
29
- }
30
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MessageDialog, decorators: [{
31
- type: Component,
32
- args: [{
33
- selector: 'msg-dialog',
34
- template: `<h1 mat-dialog-title><mat-icon *ngIf="data.type==='error'" [style.color]="'red'">error</mat-icon>
35
- <mat-icon *ngIf="data.type==='warning'" [style.color]="'yellow'">warning</mat-icon>{{data.title}}</h1>
36
- <div mat-dialog-content>
37
-
38
- <p>{{data.msg}}</p>
39
- <p>{{data.advice}}</p>
40
-
41
- </div>
42
- <div mat-dialog-actions>
43
- <button mat-button (click)="closeDialog()">OK</button>
44
- </div>
45
- `
46
- }]
47
- }], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
48
- type: Inject,
49
- args: [MAT_DIALOG_DATA]
50
- }] }] });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzc2FnZV9kaWFsb2cuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zcGVlY2hyZWNvcmRlcm5nL3NyYy9saWIvdWkvbWVzc2FnZV9kaWFsb2cudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFFLGVBQWUsRUFBZ0IsTUFBTSwwQkFBMEIsQ0FBQzs7Ozs7O0FBaUJ6RSxNQUFNLE9BQU8sYUFBYTtJQUV4QixZQUNTLFNBQXNDLEVBQ2IsSUFBUztRQURsQyxjQUFTLEdBQVQsU0FBUyxDQUE2QjtRQUNiLFNBQUksR0FBSixJQUFJLENBQUs7SUFBSSxDQUFDO0lBRWhELFdBQVc7UUFDVCxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3pCLENBQUM7K0dBUlUsYUFBYSw4Q0FJZCxlQUFlO21HQUpkLGFBQWEsa0RBYmQ7Ozs7Ozs7Ozs7O0dBV1Q7OzRGQUVVLGFBQWE7a0JBZnpCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFlBQVk7b0JBQ3RCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7R0FXVDtpQkFDRjs7MEJBS0ksTUFBTTsyQkFBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEluamVjdH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgTUFUX0RJQUxPR19EQVRBLCBNYXREaWFsb2dSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ21zZy1kaWFsb2cnLFxyXG4gIHRlbXBsYXRlOiBgPGgxIG1hdC1kaWFsb2ctdGl0bGU+PG1hdC1pY29uICpuZ0lmPVwiZGF0YS50eXBlPT09J2Vycm9yJ1wiIFtzdHlsZS5jb2xvcl09XCIncmVkJ1wiPmVycm9yPC9tYXQtaWNvbj5cclxuICAgIDxtYXQtaWNvbiAqbmdJZj1cImRhdGEudHlwZT09PSd3YXJuaW5nJ1wiIFtzdHlsZS5jb2xvcl09XCIneWVsbG93J1wiPndhcm5pbmc8L21hdC1pY29uPnt7ZGF0YS50aXRsZX19PC9oMT5cclxuICA8ZGl2IG1hdC1kaWFsb2ctY29udGVudD5cclxuXHJcbiAgICA8cD57e2RhdGEubXNnfX08L3A+XHJcbiAgICA8cD57e2RhdGEuYWR2aWNlfX08L3A+XHJcblxyXG4gIDwvZGl2PlxyXG4gIDxkaXYgbWF0LWRpYWxvZy1hY3Rpb25zPlxyXG4gICAgPGJ1dHRvbiBtYXQtYnV0dG9uIChjbGljayk9XCJjbG9zZURpYWxvZygpXCI+T0s8L2J1dHRvbj5cclxuICA8L2Rpdj5cclxuICBgXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNZXNzYWdlRGlhbG9ne1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHB1YmxpYyBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxNZXNzYWdlRGlhbG9nPixcclxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKSBwdWJsaWMgZGF0YTogYW55KSB7IH1cclxuXHJcbiAgY2xvc2VEaWFsb2coKTogdm9pZCB7XHJcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSgpO1xyXG4gIH1cclxuXHJcbn1cclxuIl19
@@ -1,253 +0,0 @@
1
- import { Component, EventEmitter, Input, Output, ViewChild } from "@angular/core";
2
- import { LevelBar } from "../audio/ui/livelevel";
3
- import { ResponsiveComponent } from "./responsive_component";
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/cdk/layout";
6
- import * as i2 from "@angular/common";
7
- import * as i3 from "@angular/material/icon";
8
- import * as i4 from "@angular/material/tooltip";
9
- import * as i5 from "../audio/ui/livelevel";
10
- export const MIN_DB_LEVEL = -40.0;
11
- export const DEFAULT_WARN_DB_LEVEL = -2;
12
- export class RecordingItemControls extends ResponsiveComponent {
13
- set agc(agc) {
14
- this._agc = agc;
15
- if (this._agc === undefined || this._agc === null) {
16
- this.agcString = 'n/a';
17
- }
18
- else {
19
- if (this._agc === true) {
20
- this.agcString = 'On';
21
- }
22
- else {
23
- this.agcString = 'Off';
24
- }
25
- }
26
- }
27
- constructor(bpo, ref, changeDetectorRef) {
28
- super(bpo);
29
- this.bpo = bpo;
30
- this.ref = ref;
31
- this.changeDetectorRef = changeDetectorRef;
32
- this.ce = null;
33
- this.audioSignalCollapsed = true;
34
- this.enableDownload = false;
35
- this.peakDbLvl = MIN_DB_LEVEL;
36
- this._displayLevelInfos = null;
37
- this._agc = undefined;
38
- this.agcString = 'n/a';
39
- this.onShowRecordingDetails = new EventEmitter();
40
- this.onDownloadRecording = new EventEmitter();
41
- this.disableAudioDetails = true;
42
- this.audioLoaded = false;
43
- this.playStartEnabled = false;
44
- this.playStopEnabled = false;
45
- this.updateTimerId = null;
46
- this.destroyed = false;
47
- this.warnDbLevel = DEFAULT_WARN_DB_LEVEL;
48
- }
49
- ngOnDestroy() {
50
- this.destroyed = true;
51
- }
52
- showRecordingDetails() {
53
- this.onShowRecordingDetails.emit();
54
- }
55
- downloadRecording() {
56
- this.onDownloadRecording.emit();
57
- }
58
- ngAfterViewInit() {
59
- this.ce = this.ref.nativeElement;
60
- }
61
- set displayLevelInfos(levelInfos) {
62
- this._displayLevelInfos = levelInfos;
63
- }
64
- error() {
65
- // this.status = 'ERROR';
66
- }
67
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: RecordingItemControls, deps: [{ token: i1.BreakpointObserver }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
68
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: RecordingItemControls, selector: "spr-recordingitemcontrols", inputs: { audioSignalCollapsed: "audioSignalCollapsed", enableDownload: "enableDownload", peakDbLvl: "peakDbLvl", agc: "agc", disableAudioDetails: "disableAudioDetails", audioLoaded: "audioLoaded", playStartAction: "playStartAction", playStopAction: "playStopAction", displayLevelInfos: "displayLevelInfos" }, outputs: { onShowRecordingDetails: "onShowRecordingDetails", onDownloadRecording: "onDownloadRecording" }, usesInheritance: true, ngImport: i0, template: `
69
- <button matTooltip="Start playback" (click)="playStartAction?.perform()"
70
- [disabled]="playStartAction?playStartAction.disabled:true"
71
- [style.color]="playStartAction?.disabled ? 'grey' : 'green'">
72
- <mat-icon>play_arrow</mat-icon>
73
- </button>
74
- <button matTooltip="Stop playback" (click)="playStopAction?.perform()"
75
- [disabled]="playStopAction?.disabled"
76
- [style.color]="playStopAction?.disabled ? 'grey' : 'yellow'">
77
- <mat-icon>stop</mat-icon>
78
- </button>
79
- <button *ngIf="!screenXs" matTooltip="Toggle detailed audio display" [disabled]="disableAudioDetails || !audioLoaded"
80
- (click)="showRecordingDetails()">
81
- <mat-icon>{{(audioSignalCollapsed) ? "expand_less" : "expand_more"}}</mat-icon>
82
- </button>
83
- <button matTooltip="Download current recording" *ngIf="enableDownload" [disabled]="disableAudioDetails || !audioLoaded"
84
- (click)="downloadRecording()">
85
- <mat-icon>file_download</mat-icon>
86
- </button>
87
- <div style="min-width: 14ch;padding:2px"><table style="border-style: none"><tr><td>Peak:</td><td><span matTooltip="Peak level"
88
- [style.color]="(peakDbLvl > warnDbLevel)?'red':'black'">{{peakDbLvl | number:'1.1-1'}} dB </span></td></tr>
89
- <tr *ngIf="_agc"><td>AGC:</td><td><span matTooltip="Auto gain control">{{agcString}}</span></td></tr></table></div>
90
- `, isInline: true, styles: [":host{flex:0;width:100%;background:#a9a9a9;padding:4px;box-sizing:border-box;height:100%;display:flex;flex-direction:row;flex-wrap:nowrap}\n", "span{flex:0;font-weight:700;display:inline-block;white-space:nowrap;box-sizing:border-box}\n", "button{touch-action:manipulation}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i2.DecimalPipe, name: "number" }] }); }
91
- }
92
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: RecordingItemControls, decorators: [{
93
- type: Component,
94
- args: [{ selector: 'spr-recordingitemcontrols', template: `
95
- <button matTooltip="Start playback" (click)="playStartAction?.perform()"
96
- [disabled]="playStartAction?playStartAction.disabled:true"
97
- [style.color]="playStartAction?.disabled ? 'grey' : 'green'">
98
- <mat-icon>play_arrow</mat-icon>
99
- </button>
100
- <button matTooltip="Stop playback" (click)="playStopAction?.perform()"
101
- [disabled]="playStopAction?.disabled"
102
- [style.color]="playStopAction?.disabled ? 'grey' : 'yellow'">
103
- <mat-icon>stop</mat-icon>
104
- </button>
105
- <button *ngIf="!screenXs" matTooltip="Toggle detailed audio display" [disabled]="disableAudioDetails || !audioLoaded"
106
- (click)="showRecordingDetails()">
107
- <mat-icon>{{(audioSignalCollapsed) ? "expand_less" : "expand_more"}}</mat-icon>
108
- </button>
109
- <button matTooltip="Download current recording" *ngIf="enableDownload" [disabled]="disableAudioDetails || !audioLoaded"
110
- (click)="downloadRecording()">
111
- <mat-icon>file_download</mat-icon>
112
- </button>
113
- <div style="min-width: 14ch;padding:2px"><table style="border-style: none"><tr><td>Peak:</td><td><span matTooltip="Peak level"
114
- [style.color]="(peakDbLvl > warnDbLevel)?'red':'black'">{{peakDbLvl | number:'1.1-1'}} dB </span></td></tr>
115
- <tr *ngIf="_agc"><td>AGC:</td><td><span matTooltip="Auto gain control">{{agcString}}</span></td></tr></table></div>
116
- `, styles: [":host{flex:0;width:100%;background:#a9a9a9;padding:4px;box-sizing:border-box;height:100%;display:flex;flex-direction:row;flex-wrap:nowrap}\n", "span{flex:0;font-weight:700;display:inline-block;white-space:nowrap;box-sizing:border-box}\n", "button{touch-action:manipulation}\n"] }]
117
- }], ctorParameters: () => [{ type: i1.BreakpointObserver }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], propDecorators: { audioSignalCollapsed: [{
118
- type: Input
119
- }], enableDownload: [{
120
- type: Input
121
- }], peakDbLvl: [{
122
- type: Input
123
- }], agc: [{
124
- type: Input
125
- }], onShowRecordingDetails: [{
126
- type: Output
127
- }], onDownloadRecording: [{
128
- type: Output
129
- }], disableAudioDetails: [{
130
- type: Input
131
- }], audioLoaded: [{
132
- type: Input
133
- }], playStartAction: [{
134
- type: Input
135
- }], playStopAction: [{
136
- type: Input
137
- }], displayLevelInfos: [{
138
- type: Input
139
- }] } });
140
- export class RecordingItemDisplay extends ResponsiveComponent {
141
- set agc(agc) {
142
- this._agc = agc;
143
- }
144
- constructor(bpo, ref, changeDetectorRef) {
145
- super(bpo);
146
- this.bpo = bpo;
147
- this.ref = ref;
148
- this.changeDetectorRef = changeDetectorRef;
149
- this.ce = null;
150
- this.streamingMode = false;
151
- this.audioSignalCollapsed = true;
152
- this.enableDownload = false;
153
- this.peakDbLvl = MIN_DB_LEVEL;
154
- this._displayLevelInfos = null;
155
- this._agc = undefined;
156
- this.agcString = 'n/a';
157
- this.onShowRecordingDetails = new EventEmitter();
158
- this.onDownloadRecording = new EventEmitter();
159
- this.playStartEnabled = false;
160
- this.playStopEnabled = false;
161
- this.updateTimerId = null;
162
- this.destroyed = false;
163
- this.warnDbLevel = DEFAULT_WARN_DB_LEVEL;
164
- }
165
- ngOnDestroy() {
166
- this.destroyed = true;
167
- }
168
- set displayAudioBuffer(displayAudioBuffer) {
169
- this._displayAudioBuffer = displayAudioBuffer;
170
- }
171
- get displayAudioBuffer() {
172
- return this._displayAudioBuffer;
173
- }
174
- showRecordingDetails() {
175
- this.onShowRecordingDetails.emit();
176
- }
177
- downloadRecording() {
178
- this.onDownloadRecording.emit();
179
- }
180
- ngAfterViewInit() {
181
- this.ce = this.ref.nativeElement;
182
- //this.controlAudioPlayer.listener=this;
183
- }
184
- set displayLevelInfos(levelInfos) {
185
- this._displayLevelInfos = levelInfos;
186
- }
187
- set channelCount(channelCount) {
188
- this.reset();
189
- this.liveLevel.channelCount = channelCount;
190
- }
191
- set playFramePosition(playFramePosition) {
192
- this.liveLevel.playFramePosition = playFramePosition;
193
- }
194
- update(levelInfo, peakLevelInfo) {
195
- let peakDBVal = levelInfo.powerLevelDB();
196
- if (this.peakDbLvl < peakDBVal) {
197
- this.peakDbLvl = peakDBVal;
198
- // the event comes from outside an Angular zone
199
- this.changeDetectorRef.detectChanges();
200
- }
201
- this.liveLevel.update(levelInfo);
202
- }
203
- error() {
204
- // this.status = 'ERROR';
205
- }
206
- streamFinished() {
207
- this.liveLevel.streamFinished();
208
- }
209
- reset() {
210
- this.peakDbLvl = MIN_DB_LEVEL;
211
- this.changeDetectorRef.detectChanges();
212
- }
213
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: RecordingItemDisplay, deps: [{ token: i1.BreakpointObserver }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
214
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: RecordingItemDisplay, selector: "spr-recordingitemdisplay", inputs: { streamingMode: "streamingMode", audioSignalCollapsed: "audioSignalCollapsed", enableDownload: "enableDownload", agc: "agc", playStartAction: "playStartAction", playStopAction: "playStopAction", displayAudioBuffer: "displayAudioBuffer", displayLevelInfos: "displayLevelInfos" }, outputs: { onShowRecordingDetails: "onShowRecordingDetails", onDownloadRecording: "onDownloadRecording" }, viewQueries: [{ propertyName: "liveLevel", first: true, predicate: LevelBar, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: `
215
- <div [class]="{audioStatusDisplay:!screenXs,audioStatusDisplayXs:screenXs}">
216
- <audio-levelbar style="flex:1 0 1%" [streamingMode]="streamingMode" [displayLevelInfos]="_displayLevelInfos"></audio-levelbar>
217
- <spr-recordingitemcontrols style="flex:0 0 0px" [audioLoaded]="displayAudioBuffer!==null" [playStartAction]="playStartAction" [playStopAction]="playStopAction" [peakDbLvl]="peakDbLvl" [agc]="_agc" (onShowRecordingDetails)="onShowRecordingDetails.emit()"></spr-recordingitemcontrols>
218
- </div>
219
- `, isInline: true, styles: ["div{width:100%;background:#a9a9a9;padding:4px;box-sizing:border-box;flex-wrap:nowrap}\n", "audio-levelbar{box-sizing:border-box}\n", ".audioStatusDisplay{display:flex;flex-direction:row;height:100px;min-height:100px}\n", ".audioStatusDisplayXs{display:flex;flex-direction:column;height:125px;min-height:125px}\n"], dependencies: [{ kind: "component", type: i5.LevelBar, selector: "audio-levelbar", inputs: ["streamingMode", "displayLevelInfos", "state"] }, { kind: "component", type: RecordingItemControls, selector: "spr-recordingitemcontrols", inputs: ["audioSignalCollapsed", "enableDownload", "peakDbLvl", "agc", "disableAudioDetails", "audioLoaded", "playStartAction", "playStopAction", "displayLevelInfos"], outputs: ["onShowRecordingDetails", "onDownloadRecording"] }] }); }
220
- }
221
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: RecordingItemDisplay, decorators: [{
222
- type: Component,
223
- args: [{ selector: 'spr-recordingitemdisplay', template: `
224
- <div [class]="{audioStatusDisplay:!screenXs,audioStatusDisplayXs:screenXs}">
225
- <audio-levelbar style="flex:1 0 1%" [streamingMode]="streamingMode" [displayLevelInfos]="_displayLevelInfos"></audio-levelbar>
226
- <spr-recordingitemcontrols style="flex:0 0 0px" [audioLoaded]="displayAudioBuffer!==null" [playStartAction]="playStartAction" [playStopAction]="playStopAction" [peakDbLvl]="peakDbLvl" [agc]="_agc" (onShowRecordingDetails)="onShowRecordingDetails.emit()"></spr-recordingitemcontrols>
227
- </div>
228
- `, styles: ["div{width:100%;background:#a9a9a9;padding:4px;box-sizing:border-box;flex-wrap:nowrap}\n", "audio-levelbar{box-sizing:border-box}\n", ".audioStatusDisplay{display:flex;flex-direction:row;height:100px;min-height:100px}\n", ".audioStatusDisplayXs{display:flex;flex-direction:column;height:125px;min-height:125px}\n"] }]
229
- }], ctorParameters: () => [{ type: i1.BreakpointObserver }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], propDecorators: { liveLevel: [{
230
- type: ViewChild,
231
- args: [LevelBar, { static: true }]
232
- }], streamingMode: [{
233
- type: Input
234
- }], audioSignalCollapsed: [{
235
- type: Input
236
- }], enableDownload: [{
237
- type: Input
238
- }], agc: [{
239
- type: Input
240
- }], onShowRecordingDetails: [{
241
- type: Output
242
- }], onDownloadRecording: [{
243
- type: Output
244
- }], playStartAction: [{
245
- type: Input
246
- }], playStopAction: [{
247
- type: Input
248
- }], displayAudioBuffer: [{
249
- type: Input
250
- }], displayLevelInfos: [{
251
- type: Input
252
- }] } });
253
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recordingitem_display.js","sourceRoot":"","sources":["../../../../../projects/speechrecorderng/src/lib/ui/recordingitem_display.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, OnDestroy, Output,\r\n    ViewChild\r\n} from \"@angular/core\"\r\nimport {LevelInfo, LevelInfos, LevelListener} from \"../audio/dsp/level_measure\";\r\nimport {LevelBar} from \"../audio/ui/livelevel\";\r\nimport {Action} from \"../action/action\";\r\nimport {ResponsiveComponent} from \"./responsive_component\";\r\nimport {BreakpointObserver} from \"@angular/cdk/layout\";\r\n\r\n\r\nexport const MIN_DB_LEVEL = -40.0;\r\nexport const DEFAULT_WARN_DB_LEVEL = -2;\r\n\r\n@Component({\r\n  selector: 'spr-recordingitemcontrols',\r\n  template: `\r\n        <button matTooltip=\"Start playback\" (click)=\"playStartAction?.perform()\"\r\n                [disabled]=\"playStartAction?playStartAction.disabled:true\"\r\n                [style.color]=\"playStartAction?.disabled ? 'grey' : 'green'\">\r\n            <mat-icon>play_arrow</mat-icon>\r\n        </button>\r\n        <button matTooltip=\"Stop playback\" (click)=\"playStopAction?.perform()\"\r\n                [disabled]=\"playStopAction?.disabled\"\r\n                [style.color]=\"playStopAction?.disabled ? 'grey' : 'yellow'\">\r\n            <mat-icon>stop</mat-icon>\r\n        </button>\r\n        <button *ngIf=\"!screenXs\" matTooltip=\"Toggle detailed audio display\" [disabled]=\"disableAudioDetails || !audioLoaded\"\r\n                (click)=\"showRecordingDetails()\">\r\n            <mat-icon>{{(audioSignalCollapsed) ? \"expand_less\" : \"expand_more\"}}</mat-icon>\r\n        </button>\r\n        <button matTooltip=\"Download current recording\" *ngIf=\"enableDownload\" [disabled]=\"disableAudioDetails || !audioLoaded\"\r\n                (click)=\"downloadRecording()\">\r\n            <mat-icon>file_download</mat-icon>\r\n        </button>\r\n        <div style=\"min-width: 14ch;padding:2px\"><table style=\"border-style: none\"><tr><td>Peak:</td><td><span matTooltip=\"Peak level\"\r\n                                                                        [style.color]=\"(peakDbLvl > warnDbLevel)?'red':'black'\">{{peakDbLvl | number:'1.1-1'}} dB </span></td></tr>\r\n          <tr *ngIf=\"_agc\"><td>AGC:</td><td><span matTooltip=\"Auto gain control\">{{agcString}}</span></td></tr></table></div>\r\n    `,\r\n  styles: [`:host {\r\n        flex: 0; /* only required vertical space */\r\n        width: 100%;\r\n        background: darkgray;\r\n        padding: 4px;\r\n        box-sizing: border-box;\r\n        height: 100%;\r\n\r\n        display: flex; /* flex container: left level bar, right decimal peak level value */\r\n        flex-direction: row;\r\n        flex-wrap: nowrap; /* wrap could completely destroy the layout */\r\n    }`, `span {\r\n        flex: 0;\r\n        font-weight: bold;\r\n        display: inline-block;\r\n        white-space: nowrap;\r\n        box-sizing: border-box;\r\n    }`,`\r\n     button {\r\n       touch-action: manipulation;\r\n     }`]\r\n\r\n})\r\nexport class RecordingItemControls extends ResponsiveComponent implements OnDestroy {\r\n\r\n  ce: HTMLDivElement|null=null;\r\n  @Input() audioSignalCollapsed: boolean=true;\r\n  private _displayAudioBuffer: AudioBuffer | null|undefined;\r\n  @Input() enableDownload: boolean=false;\r\n\r\n  @Input() peakDbLvl = MIN_DB_LEVEL;\r\n\r\n  _displayLevelInfos: LevelInfos | null=null;\r\n\r\n  _agc:boolean|null|undefined=undefined;\r\n  agcString='n/a';\r\n\r\n  @Input() set agc(agc:boolean|null|undefined){\r\n    this._agc=agc;\r\n    if(this._agc===undefined || this._agc===null){\r\n      this.agcString='n/a';\r\n    }else{\r\n      if(this._agc===true){\r\n        this.agcString='On';\r\n      }else{\r\n        this.agcString='Off';\r\n      }\r\n    }\r\n  }\r\n\r\n  @Output() onShowRecordingDetails: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() onDownloadRecording: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Input() disableAudioDetails=true;\r\n  @Input() audioLoaded=false;\r\n  //@Input() controlAudioPlayer: AudioPlayer;\r\n  @Input() playStartAction:Action<void>|undefined;\r\n  @Input() playStopAction:Action<void>|undefined;\r\n  playStartEnabled = false;\r\n  playStopEnabled = false;\r\n  private updateTimerId: number|null=null;\r\n\r\n  private destroyed = false;\r\n\r\n  warnDbLevel = DEFAULT_WARN_DB_LEVEL;\r\n\r\n  constructor(protected bpo:BreakpointObserver,private ref: ElementRef, private changeDetectorRef: ChangeDetectorRef) {\r\n    super(bpo);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroyed = true;\r\n  }\r\n\r\n  showRecordingDetails() {\r\n    this.onShowRecordingDetails.emit();\r\n  }\r\n\r\n  downloadRecording() {\r\n    this.onDownloadRecording.emit();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.ce = this.ref.nativeElement;\r\n  }\r\n\r\n  @Input()\r\n  set displayLevelInfos(levelInfos: LevelInfos | null) {\r\n    this._displayLevelInfos = levelInfos;\r\n  }\r\n\r\n  error() {\r\n    // this.status = 'ERROR';\r\n  }\r\n\r\n}\r\n\r\n\r\n@Component({\r\n    selector: 'spr-recordingitemdisplay',\r\n    template: `\r\n      <div [class]=\"{audioStatusDisplay:!screenXs,audioStatusDisplayXs:screenXs}\">\r\n        <audio-levelbar style=\"flex:1 0 1%\" [streamingMode]=\"streamingMode\" [displayLevelInfos]=\"_displayLevelInfos\"></audio-levelbar>\r\n        <spr-recordingitemcontrols style=\"flex:0 0 0px\" [audioLoaded]=\"displayAudioBuffer!==null\" [playStartAction]=\"playStartAction\" [playStopAction]=\"playStopAction\" [peakDbLvl]=\"peakDbLvl\" [agc]=\"_agc\" (onShowRecordingDetails)=\"onShowRecordingDetails.emit()\"></spr-recordingitemcontrols>\r\n      </div>\r\n    `,\r\n    styles: [`div {\r\n        width: 100%;\r\n        background: darkgray;\r\n        padding: 4px;\r\n        box-sizing: border-box;\r\n        flex-wrap: nowrap; /* wrap could completely destroy the layout */\r\n    }`, `audio-levelbar {\r\n        box-sizing: border-box;\r\n    }`,`.audioStatusDisplay{\r\n    display:flex;\r\n    flex-direction: row;\r\n    height:100px;\r\n    min-height: 100px;\r\n  }`,`.audioStatusDisplayXs{\r\n    display:flex;\r\n    flex-direction: column;\r\n    height:125px;\r\n    min-height: 125px;\r\n  }`]\r\n\r\n})\r\nexport class RecordingItemDisplay extends ResponsiveComponent implements LevelListener, OnDestroy {\r\n\r\n    ce: HTMLDivElement|null=null;\r\n    @ViewChild(LevelBar, { static: true }) liveLevel!: LevelBar;\r\n    @Input() streamingMode: boolean=false;\r\n    @Input() audioSignalCollapsed: boolean=true;\r\n    private _displayAudioBuffer: AudioBuffer | null|undefined;\r\n    @Input() enableDownload: boolean=false;\r\n\r\n    peakDbLvl = MIN_DB_LEVEL;\r\n\r\n    _displayLevelInfos: LevelInfos | null=null;\r\n\r\n    _agc:boolean|null|undefined=undefined;\r\n    agcString='n/a';\r\n\r\n    @Input() set agc(agc:boolean|null|undefined){\r\n      this._agc=agc;\r\n    }\r\n\r\n    @Output() onShowRecordingDetails: EventEmitter<void> = new EventEmitter<void>();\r\n    @Output() onDownloadRecording: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    //@Input() controlAudioPlayer: AudioPlayer;\r\n    @Input() playStartAction:Action<void>|undefined;\r\n    @Input() playStopAction:Action<void>|undefined;\r\n    playStartEnabled = false;\r\n    playStopEnabled = false;\r\n    private updateTimerId: number|null=null;\r\n\r\n    private destroyed = false;\r\n\r\n    warnDbLevel = DEFAULT_WARN_DB_LEVEL;\r\n\r\n    constructor(protected bpo:BreakpointObserver,private ref: ElementRef, private changeDetectorRef: ChangeDetectorRef) {\r\n        super(bpo);\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.destroyed = true;\r\n    }\r\n\r\n\r\n    @Input()\r\n    set displayAudioBuffer(displayAudioBuffer: AudioBuffer | null| undefined) {\r\n        this._displayAudioBuffer = displayAudioBuffer;\r\n    }\r\n\r\n    get displayAudioBuffer() {\r\n        return this._displayAudioBuffer;\r\n    }\r\n\r\n    showRecordingDetails() {\r\n        this.onShowRecordingDetails.emit();\r\n    }\r\n\r\n    downloadRecording() {\r\n        this.onDownloadRecording.emit();\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        this.ce = this.ref.nativeElement;\r\n        //this.controlAudioPlayer.listener=this;\r\n    }\r\n\r\n    @Input()\r\n    set displayLevelInfos(levelInfos: LevelInfos | null) {\r\n        this._displayLevelInfos = levelInfos;\r\n    }\r\n\r\n    set channelCount(channelCount: number) {\r\n        this.reset();\r\n        this.liveLevel.channelCount = channelCount;\r\n    }\r\n\r\n  set playFramePosition(playFramePosition: number) {\r\n    this.liveLevel.playFramePosition=playFramePosition;\r\n  }\r\n\r\n    update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo) {\r\n        let peakDBVal = levelInfo.powerLevelDB();\r\n        if (this.peakDbLvl < peakDBVal) {\r\n            this.peakDbLvl = peakDBVal;\r\n            // the event comes from outside an Angular zone\r\n            this.changeDetectorRef.detectChanges();\r\n        }\r\n        this.liveLevel.update(levelInfo);\r\n    }\r\n\r\n    error() {\r\n        // this.status = 'ERROR';\r\n    }\r\n\r\n    streamFinished() {\r\n        this.liveLevel.streamFinished();\r\n    }\r\n\r\n    reset() {\r\n        this.peakDbLvl = MIN_DB_LEVEL;\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n\r\n}\r\n"]}