speechrecorderng 3.6.0 → 3.8.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 (220) hide show
  1. package/esm2022/lib/action/action.mjs +73 -0
  2. package/{esm2020 → esm2022}/lib/audio/array_audio_buffer.mjs +163 -163
  3. package/{esm2020 → esm2022}/lib/audio/array_audio_buffer_input_stream.mjs +85 -85
  4. package/{esm2020 → esm2022}/lib/audio/array_audio_buffer_random_access_stream.mjs +15 -15
  5. package/esm2022/lib/audio/audio_data_holder.mjs +264 -0
  6. package/{esm2020 → esm2022}/lib/audio/audio_display.mjs +93 -93
  7. package/{esm2020 → esm2022}/lib/audio/audio_player.mjs +213 -213
  8. package/esm2022/lib/audio/capture/capture.mjs +855 -0
  9. package/esm2022/lib/audio/context.mjs +79 -0
  10. package/{esm2020 → esm2022}/lib/audio/dsp/level_measure.mjs +515 -515
  11. package/{esm2020 → esm2022}/lib/audio/format.mjs +16 -16
  12. package/esm2022/lib/audio/impl/wavformat.mjs +6 -0
  13. package/{esm2020 → esm2022}/lib/audio/impl/wavreader.mjs +133 -133
  14. package/esm2022/lib/audio/impl/wavwriter.mjs +105 -0
  15. package/esm2022/lib/audio/inddb_audio_buffer.mjs +508 -0
  16. package/{esm2020 → esm2022}/lib/audio/io/stream.mjs +58 -58
  17. package/esm2022/lib/audio/net_audio_buffer.mjs +293 -0
  18. package/{esm2020 → esm2022}/lib/audio/persistor.mjs +80 -80
  19. package/{esm2020 → esm2022}/lib/audio/playback/array_audio_buffer_source_node.mjs +125 -125
  20. package/esm2022/lib/audio/playback/audio_source_node.mjs +18 -0
  21. package/esm2022/lib/audio/playback/audio_source_worklet_module_loader.mjs +167 -0
  22. package/{esm2020 → esm2022}/lib/audio/playback/inddb_audio_buffer_source_node.mjs +166 -166
  23. package/{esm2020 → esm2022}/lib/audio/playback/net_audio_buffer_source_node.mjs +217 -217
  24. package/esm2022/lib/audio/playback/player.mjs +402 -0
  25. package/esm2022/lib/audio/ui/audio_canvas_layer_comp.mjs +347 -0
  26. package/{esm2020 → esm2022}/lib/audio/ui/audio_display_control.mjs +65 -65
  27. package/{esm2020 → esm2022}/lib/audio/ui/audio_display_scroll_pane.mjs +139 -139
  28. package/{esm2020 → esm2022}/lib/audio/ui/audiosignal.mjs +524 -524
  29. package/{esm2020 → esm2022}/lib/audio/ui/common.mjs +18 -18
  30. package/esm2022/lib/audio/ui/container.mjs +414 -0
  31. package/{esm2020 → esm2022}/lib/audio/ui/livelevel.mjs +352 -352
  32. package/esm2022/lib/audio/ui/scroll_pane_horizontal.mjs +11 -0
  33. package/esm2022/lib/audio/ui/sonagram.mjs +900 -0
  34. package/esm2022/lib/db/inddb.mjs +120 -0
  35. package/esm2022/lib/dsp/utils.mjs +48 -0
  36. package/{esm2020 → esm2022}/lib/io/BinaryReader.mjs +84 -84
  37. package/esm2022/lib/io/BinaryWriter.mjs +74 -0
  38. package/{esm2020 → esm2022}/lib/io/stream.mjs +258 -258
  39. package/{esm2020 → esm2022}/lib/math/2d/geometry.mjs +27 -27
  40. package/esm2022/lib/math/complex.mjs +58 -0
  41. package/{esm2020 → esm2022}/lib/math/dft.mjs +195 -195
  42. package/{esm2020 → esm2022}/lib/media/utils.mjs +13 -13
  43. package/esm2022/lib/net/uploader.mjs +367 -0
  44. package/{esm2020 → esm2022}/lib/recorder_component.mjs +64 -64
  45. package/esm2022/lib/speechrecorder/project/project.mjs +49 -0
  46. package/esm2022/lib/speechrecorder/project/project.service.mjs +64 -0
  47. package/{esm2020 → esm2022}/lib/speechrecorder/recording.mjs +123 -123
  48. package/esm2022/lib/speechrecorder/recordings/basic_recording.service.mjs +218 -0
  49. package/esm2022/lib/speechrecorder/recordings/recordings.service.mjs +1014 -0
  50. package/{esm2020 → esm2022}/lib/speechrecorder/script/script.mjs +114 -114
  51. package/{esm2020 → esm2022}/lib/speechrecorder/script/script.service.mjs +47 -47
  52. package/esm2022/lib/speechrecorder/session/audiorecorder.mjs +1179 -0
  53. package/esm2022/lib/speechrecorder/session/basicrecorder.mjs +668 -0
  54. package/esm2022/lib/speechrecorder/session/controlpanel.mjs +416 -0
  55. package/{esm2020 → esm2022}/lib/speechrecorder/session/item.mjs +29 -29
  56. package/{esm2020 → esm2022}/lib/speechrecorder/session/progress.mjs +69 -69
  57. package/{esm2020 → esm2022}/lib/speechrecorder/session/prompting.mjs +571 -571
  58. package/{esm2020 → esm2022}/lib/speechrecorder/session/recorder_combi_pane.mjs +65 -65
  59. package/esm2022/lib/speechrecorder/session/recording_file_cache.mjs +195 -0
  60. package/{esm2020 → esm2022}/lib/speechrecorder/session/recording_list.mjs +103 -103
  61. package/{esm2020 → esm2022}/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +63 -63
  62. package/{esm2020 → esm2022}/lib/speechrecorder/session/recordingfile/recording-file-navi.component.mjs +51 -51
  63. package/{esm2020 → esm2022}/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +104 -104
  64. package/{esm2020 → esm2022}/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +381 -381
  65. package/{esm2020 → esm2022}/lib/speechrecorder/session/recordingfile/recording-file.mjs +67 -67
  66. package/esm2022/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +288 -0
  67. package/{esm2020 → esm2022}/lib/speechrecorder/session/session.mjs +1 -1
  68. package/esm2022/lib/speechrecorder/session/session.service.mjs +69 -0
  69. package/{esm2020 → esm2022}/lib/speechrecorder/session/session_finished_dialog.mjs +29 -29
  70. package/esm2022/lib/speechrecorder/session/sessionmanager.mjs +1386 -0
  71. package/{esm2020 → esm2022}/lib/speechrecorder/session/warning_bar.mjs +28 -28
  72. package/{esm2020 → esm2022}/lib/speechrecorder/spruploader.mjs +22 -22
  73. package/{esm2020 → esm2022}/lib/speechrecorder/startstopsignal/startstopsignal.mjs +1 -1
  74. package/esm2022/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.mjs +57 -0
  75. package/{esm2020 → esm2022}/lib/speechrecorderng.component.mjs +388 -388
  76. package/{esm2020 → esm2022}/lib/speechrecorderng.module.mjs +100 -100
  77. package/{esm2020 → esm2022}/lib/spr.config.mjs +26 -26
  78. package/{esm2020 → esm2022}/lib/spr.module.version.mjs +2 -2
  79. package/{esm2020 → esm2022}/lib/ui/canvas_layer_comp.mjs +38 -38
  80. package/{esm2020 → esm2022}/lib/ui/message_dialog.mjs +30 -30
  81. package/esm2022/lib/ui/recordingitem_display.mjs +253 -0
  82. package/{esm2020 → esm2022}/lib/ui/responsive_component.mjs +24 -24
  83. package/{esm2020 → esm2022}/lib/utils/scrollIntoViewToBottom.mjs +23 -23
  84. package/esm2022/lib/utils/ua-parser.mjs +190 -0
  85. package/esm2022/lib/utils/utils.mjs +105 -0
  86. package/esm2022/lib/utils/wake_lock.mjs +114 -0
  87. package/{esm2020 → esm2022}/lib/utils/wake_lock_media.mjs +1 -1
  88. package/{esm2020 → esm2022}/public-api.mjs +33 -33
  89. package/{esm2020 → esm2022}/speechrecorderng.mjs +4 -4
  90. package/{fesm2020 → fesm2022}/speechrecorderng.mjs +16518 -16454
  91. package/fesm2022/speechrecorderng.mjs.map +1 -0
  92. package/index.d.ts +5 -5
  93. package/lib/action/action.d.ts +27 -27
  94. package/lib/audio/array_audio_buffer.d.ts +31 -31
  95. package/lib/audio/array_audio_buffer_input_stream.d.ts +14 -14
  96. package/lib/audio/array_audio_buffer_random_access_stream.d.ts +9 -9
  97. package/lib/audio/audio_data_holder.d.ts +84 -84
  98. package/lib/audio/audio_display.d.ts +36 -36
  99. package/lib/audio/audio_player.d.ts +47 -47
  100. package/lib/audio/capture/capture.d.ts +67 -67
  101. package/lib/audio/context.d.ts +6 -6
  102. package/lib/audio/dsp/level_measure.d.ts +60 -60
  103. package/lib/audio/format.d.ts +11 -11
  104. package/lib/audio/impl/wavformat.d.ts +5 -5
  105. package/lib/audio/impl/wavreader.d.ts +16 -16
  106. package/lib/audio/impl/wavwriter.d.ts +13 -13
  107. package/lib/audio/inddb_audio_buffer.d.ts +68 -68
  108. package/lib/audio/io/stream.d.ts +28 -28
  109. package/lib/audio/net_audio_buffer.d.ts +57 -57
  110. package/lib/audio/persistor.d.ts +29 -29
  111. package/lib/audio/playback/array_audio_buffer_source_node.d.ts +18 -18
  112. package/lib/audio/playback/audio_source_node.d.ts +10 -10
  113. package/lib/audio/playback/audio_source_worklet_module_loader.d.ts +4 -4
  114. package/lib/audio/playback/inddb_audio_buffer_source_node.d.ts +21 -21
  115. package/lib/audio/playback/net_audio_buffer_source_node.d.ts +27 -27
  116. package/lib/audio/playback/player.d.ts +65 -65
  117. package/lib/audio/ui/audio_canvas_layer_comp.d.ts +68 -68
  118. package/lib/audio/ui/audio_display_control.d.ts +25 -25
  119. package/lib/audio/ui/audio_display_scroll_pane.d.ts +26 -26
  120. package/lib/audio/ui/audiosignal.d.ts +30 -30
  121. package/lib/audio/ui/common.d.ts +11 -11
  122. package/lib/audio/ui/container.d.ts +63 -63
  123. package/lib/audio/ui/livelevel.d.ts +60 -60
  124. package/lib/audio/ui/scroll_pane_horizontal.d.ts +5 -5
  125. package/lib/audio/ui/sonagram.d.ts +37 -37
  126. package/lib/db/inddb.d.ts +21 -21
  127. package/lib/dsp/utils.d.ts +19 -19
  128. package/lib/io/BinaryReader.d.ts +18 -18
  129. package/lib/io/BinaryWriter.d.ts +15 -15
  130. package/lib/io/stream.d.ts +59 -59
  131. package/lib/math/2d/geometry.d.ts +18 -18
  132. package/lib/math/complex.d.ts +17 -17
  133. package/lib/math/dft.d.ts +22 -22
  134. package/lib/media/utils.d.ts +3 -3
  135. package/lib/net/uploader.d.ts +81 -81
  136. package/lib/recorder_component.d.ts +16 -16
  137. package/lib/speechrecorder/project/project.d.ts +59 -59
  138. package/lib/speechrecorder/project/project.service.d.ts +21 -21
  139. package/lib/speechrecorder/recording.d.ts +51 -51
  140. package/lib/speechrecorder/recordings/basic_recording.service.d.ts +27 -27
  141. package/lib/speechrecorder/recordings/recordings.service.d.ts +48 -48
  142. package/lib/speechrecorder/script/script.d.ts +80 -79
  143. package/lib/speechrecorder/script/script.service.d.ts +16 -16
  144. package/lib/speechrecorder/session/audiorecorder.d.ts +122 -122
  145. package/lib/speechrecorder/session/basicrecorder.d.ts +139 -139
  146. package/lib/speechrecorder/session/controlpanel.d.ts +109 -107
  147. package/lib/speechrecorder/session/item.d.ts +12 -12
  148. package/lib/speechrecorder/session/progress.d.ts +17 -17
  149. package/lib/speechrecorder/session/prompting.d.ts +121 -121
  150. package/lib/speechrecorder/session/recorder_combi_pane.d.ts +32 -32
  151. package/lib/speechrecorder/session/recording_file_cache.d.ts +33 -33
  152. package/lib/speechrecorder/session/recording_list.d.ts +24 -24
  153. package/lib/speechrecorder/session/recordingfile/recording-file-meta.component.d.ts +15 -15
  154. package/lib/speechrecorder/session/recordingfile/recording-file-navi.component.d.ts +20 -20
  155. package/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.d.ts +31 -31
  156. package/lib/speechrecorder/session/recordingfile/recording-file-view.component.d.ts +55 -55
  157. package/lib/speechrecorder/session/recordingfile/recording-file.d.ts +7 -7
  158. package/lib/speechrecorder/session/recordingfile/recordingfile-service.d.ts +24 -24
  159. package/lib/speechrecorder/session/session.d.ts +15 -15
  160. package/lib/speechrecorder/session/session.service.d.ts +20 -20
  161. package/lib/speechrecorder/session/session_finished_dialog.d.ts +10 -10
  162. package/lib/speechrecorder/session/sessionmanager.d.ts +129 -123
  163. package/lib/speechrecorder/session/warning_bar.d.ts +8 -8
  164. package/lib/speechrecorder/spruploader.d.ts +11 -11
  165. package/lib/speechrecorder/startstopsignal/startstopsignal.d.ts +10 -10
  166. package/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.d.ts +11 -11
  167. package/lib/speechrecorderng.component.d.ts +61 -61
  168. package/lib/speechrecorderng.module.d.ts +56 -56
  169. package/lib/spr.config.d.ts +17 -17
  170. package/lib/spr.module.version.d.ts +1 -1
  171. package/lib/ui/canvas_layer_comp.d.ts +13 -13
  172. package/lib/ui/message_dialog.d.ts +10 -10
  173. package/lib/ui/recordingitem_display.d.ts +84 -84
  174. package/lib/ui/responsive_component.d.ts +9 -9
  175. package/lib/utils/scrollIntoViewToBottom.d.ts +9 -9
  176. package/lib/utils/ua-parser.d.ts +43 -43
  177. package/lib/utils/utils.d.ts +19 -19
  178. package/lib/utils/wake_lock.d.ts +23 -23
  179. package/lib/utils/wake_lock_media.d.ts +1 -1
  180. package/package.json +17 -23
  181. package/public-api.d.ts +33 -33
  182. package/esm2020/lib/action/action.mjs +0 -73
  183. package/esm2020/lib/audio/audio_data_holder.mjs +0 -264
  184. package/esm2020/lib/audio/capture/capture.mjs +0 -855
  185. package/esm2020/lib/audio/context.mjs +0 -79
  186. package/esm2020/lib/audio/impl/wavformat.mjs +0 -6
  187. package/esm2020/lib/audio/impl/wavwriter.mjs +0 -105
  188. package/esm2020/lib/audio/inddb_audio_buffer.mjs +0 -508
  189. package/esm2020/lib/audio/net_audio_buffer.mjs +0 -293
  190. package/esm2020/lib/audio/playback/audio_source_node.mjs +0 -18
  191. package/esm2020/lib/audio/playback/audio_source_worklet_module_loader.mjs +0 -167
  192. package/esm2020/lib/audio/playback/player.mjs +0 -402
  193. package/esm2020/lib/audio/ui/audio_canvas_layer_comp.mjs +0 -347
  194. package/esm2020/lib/audio/ui/container.mjs +0 -414
  195. package/esm2020/lib/audio/ui/scroll_pane_horizontal.mjs +0 -11
  196. package/esm2020/lib/audio/ui/sonagram.mjs +0 -900
  197. package/esm2020/lib/db/inddb.mjs +0 -120
  198. package/esm2020/lib/dsp/utils.mjs +0 -48
  199. package/esm2020/lib/io/BinaryWriter.mjs +0 -74
  200. package/esm2020/lib/math/complex.mjs +0 -58
  201. package/esm2020/lib/net/uploader.mjs +0 -367
  202. package/esm2020/lib/speechrecorder/project/project.mjs +0 -49
  203. package/esm2020/lib/speechrecorder/project/project.service.mjs +0 -64
  204. package/esm2020/lib/speechrecorder/recordings/basic_recording.service.mjs +0 -216
  205. package/esm2020/lib/speechrecorder/recordings/recordings.service.mjs +0 -1014
  206. package/esm2020/lib/speechrecorder/session/audiorecorder.mjs +0 -1179
  207. package/esm2020/lib/speechrecorder/session/basicrecorder.mjs +0 -666
  208. package/esm2020/lib/speechrecorder/session/controlpanel.mjs +0 -409
  209. package/esm2020/lib/speechrecorder/session/recording_file_cache.mjs +0 -195
  210. package/esm2020/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +0 -288
  211. package/esm2020/lib/speechrecorder/session/session.service.mjs +0 -69
  212. package/esm2020/lib/speechrecorder/session/sessionmanager.mjs +0 -1333
  213. package/esm2020/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.mjs +0 -57
  214. package/esm2020/lib/ui/recordingitem_display.mjs +0 -253
  215. package/esm2020/lib/utils/ua-parser.mjs +0 -190
  216. package/esm2020/lib/utils/utils.mjs +0 -105
  217. package/esm2020/lib/utils/wake_lock.mjs +0 -114
  218. package/fesm2015/speechrecorderng.mjs +0 -17708
  219. package/fesm2015/speechrecorderng.mjs.map +0 -1
  220. package/fesm2020/speechrecorderng.mjs.map +0 -1
@@ -1,195 +1,194 @@
1
- import { Component, ViewChild, Input, } from '@angular/core';
2
- import { AudioClip } from './persistor';
3
- import { AudioPlayer, EventType } from './playback/player';
4
- import { Action } from "../action/action";
5
- import { AudioDisplayScrollPane } from "./ui/audio_display_scroll_pane";
6
- import { AudioContextProvider } from "./context";
7
- import { AudioBufferSource, AudioDataHolder } from "./audio_data_holder";
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/router";
10
- import * as i2 from "./ui/audio_display_scroll_pane";
11
- import * as i3 from "./ui/audio_display_control";
12
- export class AudioDisplayPlayer {
13
- constructor(route, ref, eRef) {
14
- this.route = route;
15
- this.ref = ref;
16
- this.eRef = eRef;
17
- this._audioUrl = null;
18
- this._audioClip = null;
19
- this.currentLoader = null;
20
- this.parentE = this.eRef.nativeElement;
21
- this.playStartAction = new Action("Start");
22
- this.playSelectionAction = new Action("Play selected");
23
- this.playStopAction = new Action("Stop");
24
- this.status = "Player created.";
25
- }
26
- ngOnInit() {
27
- this.zoomSelectedAction = this.audioDisplayScrollPane.zoomSelectedAction;
28
- this.zoomFitToPanelAction = this.audioDisplayScrollPane.zoomFitToPanelAction;
29
- this.zoomOutAction = this.audioDisplayScrollPane.zoomOutAction;
30
- this.zoomInAction = this.audioDisplayScrollPane.zoomInAction;
31
- this.ap = new AudioPlayer(this);
32
- }
33
- ngAfterViewInit() {
34
- if (this.ap) {
35
- this.playStartAction.onAction = () => {
36
- console.debug("Start action, player: " + this.ap);
37
- this.ap?.start();
38
- };
39
- this.playSelectionAction.onAction = () => this.ap?.startSelected();
40
- this.playStopAction.onAction = () => this.ap?.stop();
41
- }
42
- this.layout();
43
- let heightListener = new MutationObserver((mrs, mo) => {
44
- mrs.forEach((mr) => {
45
- if ('attributes' === mr.type && ('class' === mr.attributeName || 'style' === mr.attributeName)) {
46
- this.layout();
47
- }
48
- });
49
- });
50
- heightListener.observe(this.parentE, { attributes: true, childList: true, characterData: true });
51
- this.route.queryParams.subscribe((params) => {
52
- if (params['url']) {
53
- this.audioUrl = params['url'];
54
- }
55
- });
56
- }
57
- layout() {
58
- this.audioDisplayScrollPane.layout();
59
- }
60
- get audioUrl() {
61
- return this._audioUrl;
62
- }
63
- set audioUrl(value) {
64
- if (this.ap) {
65
- this.ap.stop();
66
- }
67
- this._audioUrl = value;
68
- this.load();
69
- }
70
- started() {
71
- //console.debug("Play started");
72
- this.status = 'Playing...';
73
- }
74
- load() {
75
- if (this.currentLoader) {
76
- this.currentLoader.abort();
77
- this.currentLoader = null;
78
- }
79
- if (this._audioUrl) {
80
- //this.statusMsg.innerHTML = 'Connecting...';
81
- this.currentLoader = new XMLHttpRequest();
82
- this.currentLoader.open("GET", this._audioUrl, true);
83
- this.currentLoader.responseType = "arraybuffer";
84
- this.currentLoader.onload = (e) => {
85
- if (this.currentLoader) {
86
- var data = this.currentLoader.response; // not responseText
87
- //console.debug("Received data ", data.byteLength);
88
- this.currentLoader = null;
89
- this.loaded(data);
90
- }
91
- };
92
- this.currentLoader.onerror = (e) => {
93
- console.error("Error downloading ...");
94
- this.currentLoader = null;
95
- };
96
- this.currentLoader.send();
97
- }
98
- }
99
- loaded(data) {
100
- //console.debug("Loaded");
101
- this.status = 'Audio file loaded.';
102
- //console.debug("Received data ", data.byteLength);
103
- AudioContextProvider.decodeAudioData(data).then(audioBuffer => {
104
- //console.debug("Audio Buffer Samplerate: ", audioBuffer.sampleRate)
105
- let as = new AudioBufferSource(audioBuffer);
106
- let adh = new AudioDataHolder(as);
107
- this.audioClip = new AudioClip(adh);
108
- });
109
- }
110
- set audioData(audioData) {
111
- this.audioDisplayScrollPane.audioData = audioData;
112
- if (audioData) {
113
- let clip = new AudioClip(audioData);
114
- if (this.ap) {
115
- this.ap.audioClip = clip;
116
- this.playStartAction.disabled = false;
117
- }
118
- }
119
- else {
120
- this.playStartAction.disabled = true;
121
- if (this.ap) {
122
- this.ap.audioClip = null;
123
- }
124
- }
125
- this.playSelectionAction.disabled = true;
126
- }
127
- startSelectionDisabled() {
128
- return !(this._audioClip && this.ap != null && !this.playStartAction.disabled && this._audioClip.selection);
129
- }
130
- set audioClip(audioClip) {
131
- this._audioClip = audioClip;
132
- let audioData = null;
133
- if (audioClip) {
134
- audioData = audioClip.audioDataHolder;
135
- if (this._audioClip) {
136
- this._audioClip.addSelectionObserver((ac) => {
137
- this.playSelectionAction.disabled = this.startSelectionDisabled();
138
- });
139
- }
140
- }
141
- if (audioData) {
142
- //console.debug("Play start action (by AudioDisplayPlayer::set audioClip) disabled: "+(!this.ap));
143
- this.playStartAction.disabled = (!this.ap);
144
- this.playSelectionAction.disabled = this.startSelectionDisabled();
145
- }
146
- else {
147
- this.playStartAction.disabled = true;
148
- this.playSelectionAction.disabled = true;
149
- }
150
- this.audioDisplayScrollPane.audioClip = audioClip;
151
- if (this.ap) {
152
- this.ap.audioClip = audioClip;
153
- }
154
- }
155
- get audioClip() {
156
- return this._audioClip;
157
- }
158
- updatePlayPosition() {
159
- if (this.ap && this.ap.playPositionFrames) {
160
- this.audioDisplayScrollPane.playFramePosition = this.ap.playPositionFrames;
161
- }
162
- }
163
- audioPlayerUpdate(e) {
164
- if (EventType.STARTED === e.type) {
165
- this.status = 'Playback...';
166
- this.updateTimerId = window.setInterval(() => this.updatePlayPosition(), 50);
167
- this.playStartAction.disabled = true;
168
- this.playSelectionAction.disabled = true;
169
- this.playStopAction.disabled = false;
170
- }
171
- else if (EventType.ENDED === e.type) {
172
- this.status = 'Ready.';
173
- window.clearInterval(this.updateTimerId);
174
- this.playStartAction.disabled = false;
175
- this.playSelectionAction.disabled = this.startSelectionDisabled();
176
- this.playStopAction.disabled = true;
177
- }
178
- else if (EventType.ERROR === e.type) {
179
- this.status = 'Error.';
180
- window.clearInterval(this.updateTimerId);
181
- this.playStartAction.disabled = false;
182
- this.playSelectionAction.disabled = this.startSelectionDisabled();
183
- this.playStopAction.disabled = true;
184
- }
185
- this.ref.detectChanges();
186
- }
187
- error() {
188
- this.status = 'ERROR';
189
- }
190
- }
191
- AudioDisplayPlayerfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AudioDisplayPlayer, deps: [{ token: i1.ActivatedRoute }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
192
- AudioDisplayPlayer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: AudioDisplayPlayer, selector: "app-audiodisplayplayer", inputs: { playStartAction: "playStartAction", playStopAction: "playStopAction", playSelectionAction: "playSelectionAction", autoPlayOnSelectToggleAction: "autoPlayOnSelectToggleAction", audioData: "audioData", audioClip: "audioClip" }, viewQueries: [{ propertyName: "audioDisplayScrollPane", first: true, predicate: AudioDisplayScrollPane, descendants: true, static: true }], ngImport: i0, template: `
1
+ import { Component, ViewChild, Input, } from '@angular/core';
2
+ import { AudioClip } from './persistor';
3
+ import { AudioPlayer, EventType } from './playback/player';
4
+ import { Action } from "../action/action";
5
+ import { AudioDisplayScrollPane } from "./ui/audio_display_scroll_pane";
6
+ import { AudioContextProvider } from "./context";
7
+ import { AudioBufferSource, AudioDataHolder } from "./audio_data_holder";
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/router";
10
+ import * as i2 from "./ui/audio_display_scroll_pane";
11
+ import * as i3 from "./ui/audio_display_control";
12
+ export class AudioDisplayPlayer {
13
+ constructor(route, ref, eRef) {
14
+ this.route = route;
15
+ this.ref = ref;
16
+ this.eRef = eRef;
17
+ this._audioUrl = null;
18
+ this._audioClip = null;
19
+ this.currentLoader = null;
20
+ this.parentE = this.eRef.nativeElement;
21
+ this.playStartAction = new Action("Start");
22
+ this.playSelectionAction = new Action("Play selected");
23
+ this.playStopAction = new Action("Stop");
24
+ this.status = "Player created.";
25
+ }
26
+ ngOnInit() {
27
+ this.zoomSelectedAction = this.audioDisplayScrollPane.zoomSelectedAction;
28
+ this.zoomFitToPanelAction = this.audioDisplayScrollPane.zoomFitToPanelAction;
29
+ this.zoomOutAction = this.audioDisplayScrollPane.zoomOutAction;
30
+ this.zoomInAction = this.audioDisplayScrollPane.zoomInAction;
31
+ this.ap = new AudioPlayer(this);
32
+ }
33
+ ngAfterViewInit() {
34
+ if (this.ap) {
35
+ this.playStartAction.onAction = () => {
36
+ console.debug("Start action, player: " + this.ap);
37
+ this.ap?.start();
38
+ };
39
+ this.playSelectionAction.onAction = () => this.ap?.startSelected();
40
+ this.playStopAction.onAction = () => this.ap?.stop();
41
+ }
42
+ this.layout();
43
+ let heightListener = new MutationObserver((mrs, mo) => {
44
+ mrs.forEach((mr) => {
45
+ if ('attributes' === mr.type && ('class' === mr.attributeName || 'style' === mr.attributeName)) {
46
+ this.layout();
47
+ }
48
+ });
49
+ });
50
+ heightListener.observe(this.parentE, { attributes: true, childList: true, characterData: true });
51
+ this.route.queryParams.subscribe((params) => {
52
+ if (params['url']) {
53
+ this.audioUrl = params['url'];
54
+ }
55
+ });
56
+ }
57
+ layout() {
58
+ this.audioDisplayScrollPane.layout();
59
+ }
60
+ get audioUrl() {
61
+ return this._audioUrl;
62
+ }
63
+ set audioUrl(value) {
64
+ if (this.ap) {
65
+ this.ap.stop();
66
+ }
67
+ this._audioUrl = value;
68
+ this.load();
69
+ }
70
+ started() {
71
+ //console.debug("Play started");
72
+ this.status = 'Playing...';
73
+ }
74
+ load() {
75
+ if (this.currentLoader) {
76
+ this.currentLoader.abort();
77
+ this.currentLoader = null;
78
+ }
79
+ if (this._audioUrl) {
80
+ //this.statusMsg.innerHTML = 'Connecting...';
81
+ this.currentLoader = new XMLHttpRequest();
82
+ this.currentLoader.open("GET", this._audioUrl, true);
83
+ this.currentLoader.responseType = "arraybuffer";
84
+ this.currentLoader.onload = (e) => {
85
+ if (this.currentLoader) {
86
+ var data = this.currentLoader.response; // not responseText
87
+ //console.debug("Received data ", data.byteLength);
88
+ this.currentLoader = null;
89
+ this.loaded(data);
90
+ }
91
+ };
92
+ this.currentLoader.onerror = (e) => {
93
+ console.error("Error downloading ...");
94
+ this.currentLoader = null;
95
+ };
96
+ this.currentLoader.send();
97
+ }
98
+ }
99
+ loaded(data) {
100
+ //console.debug("Loaded");
101
+ this.status = 'Audio file loaded.';
102
+ //console.debug("Received data ", data.byteLength);
103
+ AudioContextProvider.decodeAudioData(data).then(audioBuffer => {
104
+ //console.debug("Audio Buffer Samplerate: ", audioBuffer.sampleRate)
105
+ let as = new AudioBufferSource(audioBuffer);
106
+ let adh = new AudioDataHolder(as);
107
+ this.audioClip = new AudioClip(adh);
108
+ });
109
+ }
110
+ set audioData(audioData) {
111
+ this.audioDisplayScrollPane.audioData = audioData;
112
+ if (audioData) {
113
+ let clip = new AudioClip(audioData);
114
+ if (this.ap) {
115
+ this.ap.audioClip = clip;
116
+ this.playStartAction.disabled = false;
117
+ }
118
+ }
119
+ else {
120
+ this.playStartAction.disabled = true;
121
+ if (this.ap) {
122
+ this.ap.audioClip = null;
123
+ }
124
+ }
125
+ this.playSelectionAction.disabled = true;
126
+ }
127
+ startSelectionDisabled() {
128
+ return !(this._audioClip && this.ap != null && !this.playStartAction.disabled && this._audioClip.selection);
129
+ }
130
+ set audioClip(audioClip) {
131
+ this._audioClip = audioClip;
132
+ let audioData = null;
133
+ if (audioClip) {
134
+ audioData = audioClip.audioDataHolder;
135
+ if (this._audioClip) {
136
+ this._audioClip.addSelectionObserver((ac) => {
137
+ this.playSelectionAction.disabled = this.startSelectionDisabled();
138
+ });
139
+ }
140
+ }
141
+ if (audioData) {
142
+ //console.debug("Play start action (by AudioDisplayPlayer::set audioClip) disabled: "+(!this.ap));
143
+ this.playStartAction.disabled = (!this.ap);
144
+ this.playSelectionAction.disabled = this.startSelectionDisabled();
145
+ }
146
+ else {
147
+ this.playStartAction.disabled = true;
148
+ this.playSelectionAction.disabled = true;
149
+ }
150
+ this.audioDisplayScrollPane.audioClip = audioClip;
151
+ if (this.ap) {
152
+ this.ap.audioClip = audioClip;
153
+ }
154
+ }
155
+ get audioClip() {
156
+ return this._audioClip;
157
+ }
158
+ updatePlayPosition() {
159
+ if (this.ap && this.ap.playPositionFrames) {
160
+ this.audioDisplayScrollPane.playFramePosition = this.ap.playPositionFrames;
161
+ }
162
+ }
163
+ audioPlayerUpdate(e) {
164
+ if (EventType.STARTED === e.type) {
165
+ this.status = 'Playback...';
166
+ this.updateTimerId = window.setInterval(() => this.updatePlayPosition(), 50);
167
+ this.playStartAction.disabled = true;
168
+ this.playSelectionAction.disabled = true;
169
+ this.playStopAction.disabled = false;
170
+ }
171
+ else if (EventType.ENDED === e.type) {
172
+ this.status = 'Ready.';
173
+ window.clearInterval(this.updateTimerId);
174
+ this.playStartAction.disabled = false;
175
+ this.playSelectionAction.disabled = this.startSelectionDisabled();
176
+ this.playStopAction.disabled = true;
177
+ }
178
+ else if (EventType.ERROR === e.type) {
179
+ this.status = 'Error.';
180
+ window.clearInterval(this.updateTimerId);
181
+ this.playStartAction.disabled = false;
182
+ this.playSelectionAction.disabled = this.startSelectionDisabled();
183
+ this.playStopAction.disabled = true;
184
+ }
185
+ this.ref.detectChanges();
186
+ }
187
+ error() {
188
+ this.status = 'ERROR';
189
+ }
190
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: AudioDisplayPlayer, deps: [{ token: i1.ActivatedRoute }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
191
+ static { thiscmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.6", type: AudioDisplayPlayer, selector: "app-audiodisplayplayer", inputs: { playStartAction: "playStartAction", playStopAction: "playStopAction", playSelectionAction: "playSelectionAction", autoPlayOnSelectToggleAction: "autoPlayOnSelectToggleAction", audioData: "audioData", audioClip: "audioClip" }, viewQueries: [{ propertyName: "audioDisplayScrollPane", first: true, predicate: AudioDisplayScrollPane, descendants: true, static: true }], ngImport: i0, template: `
193
192
 
194
193
  <audio-display-scroll-pane #audioDisplayScrollPane></audio-display-scroll-pane>
195
194
 
@@ -202,9 +201,10 @@ AudioDisplayPlayer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", ver
202
201
  [zoomOutAction]="zoomOutAction"
203
202
  [zoomSelectedAction]="zoomSelectedAction"
204
203
  [zoomFitToPanelAction]="zoomFitToPanelAction"></audio-display-control><p>{{status}}
205
- `, isInline: true, styles: [":host{display:flex;flex-direction:column;position:absolute;bottom:0;height:100%;width:100%;overflow:hidden;padding:20px;z-index:5;box-sizing:border-box;background-color:#000000bf}\n"], dependencies: [{ kind: "component", type: i2.AudioDisplayScrollPane, selector: "audio-display-scroll-pane", inputs: ["audioClip"], outputs: ["zoomInAction", "zoomOutAction", "zoomSelectedAction", "zoomFitToPanelAction"] }, { kind: "component", type: i3.AudioDisplayControl, selector: "audio-display-control", inputs: ["audioClip", "playStartAction", "playSelectionAction", "playStopAction", "zoomInAction", "zoomOutAction", "zoomFitToPanelAction", "zoomSelectedAction", "autoPlayOnSelectToggleAction"] }] });
206
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AudioDisplayPlayer, decorators: [{
207
- type: Component,
204
+ `, isInline: true, styles: [":host{display:flex;flex-direction:column;position:absolute;bottom:0;height:100%;width:100%;overflow:hidden;padding:20px;z-index:5;box-sizing:border-box;background-color:#000000bf}\n"], dependencies: [{ kind: "component", type: i2.AudioDisplayScrollPane, selector: "audio-display-scroll-pane", inputs: ["audioClip"], outputs: ["zoomInAction", "zoomOutAction", "zoomSelectedAction", "zoomFitToPanelAction"] }, { kind: "component", type: i3.AudioDisplayControl, selector: "audio-display-control", inputs: ["audioClip", "playStartAction", "playSelectionAction", "playStopAction", "zoomInAction", "zoomOutAction", "zoomFitToPanelAction", "zoomSelectedAction", "autoPlayOnSelectToggleAction"] }] }); }
205
+ }
206
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: AudioDisplayPlayer, decorators: [{
207
+ type: Component,
208
208
  args: [{ selector: 'app-audiodisplayplayer', template: `
209
209
 
210
210
  <audio-display-scroll-pane #audioDisplayScrollPane></audio-display-scroll-pane>
@@ -218,21 +218,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
218
218
  [zoomOutAction]="zoomOutAction"
219
219
  [zoomSelectedAction]="zoomSelectedAction"
220
220
  [zoomFitToPanelAction]="zoomFitToPanelAction"></audio-display-control><p>{{status}}
221
- `, styles: [":host{display:flex;flex-direction:column;position:absolute;bottom:0;height:100%;width:100%;overflow:hidden;padding:20px;z-index:5;box-sizing:border-box;background-color:#000000bf}\n"] }]
222
- }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, propDecorators: { playStartAction: [{
223
- type: Input
224
- }], playStopAction: [{
225
- type: Input
226
- }], playSelectionAction: [{
227
- type: Input
228
- }], autoPlayOnSelectToggleAction: [{
229
- type: Input
230
- }], audioDisplayScrollPane: [{
231
- type: ViewChild,
232
- args: [AudioDisplayScrollPane, { static: true }]
233
- }], audioData: [{
234
- type: Input
235
- }], audioClip: [{
236
- type: Input
237
- }] } });
238
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audio_player.js","sourceRoot":"","sources":["../../../../../projects/speechrecorderng/src/lib/audio/audio_player.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    ViewChild,\r\n    ChangeDetectorRef,\r\n    AfterViewInit, Input, OnInit, ElementRef,\r\n} from '@angular/core'\r\n\r\nimport {AudioClip} from './persistor'\r\nimport {AudioPlayer, AudioPlayerListener, AudioPlayerEvent, EventType} from './playback/player'\r\nimport {ActivatedRoute, Params} from \"@angular/router\";\r\nimport {Action} from \"../action/action\";\r\nimport {AudioDisplayScrollPane} from \"./ui/audio_display_scroll_pane\";\r\nimport {AudioContextProvider} from \"./context\";\r\nimport {AudioBufferSource, AudioDataHolder} from \"./audio_data_holder\";\r\n\r\n@Component({\r\n\r\n  selector: 'app-audiodisplayplayer',\r\n\r\n  template: `\r\n\r\n    <audio-display-scroll-pane #audioDisplayScrollPane></audio-display-scroll-pane>\r\n\r\n    <audio-display-control [audioClip]=\"audioClip\"\r\n                             [playStartAction]=\"playStartAction\"\r\n                             [playSelectionAction]=\"playSelectionAction\"\r\n                             [playStopAction]=\"playStopAction\"\r\n                             [autoPlayOnSelectToggleAction]=\"ap?.autoPlayOnSelectToggleAction\"\r\n                             [zoomInAction]=\"zoomInAction\"\r\n                             [zoomOutAction]=\"zoomOutAction\"\r\n                             [zoomSelectedAction]=\"zoomSelectedAction\"\r\n                             [zoomFitToPanelAction]=\"zoomFitToPanelAction\"></audio-display-control><p>{{status}}\r\n  `,\r\n  styles: [\r\n      `:host {\r\n      display: flex;\r\n      flex-direction: column;\r\n      position: absolute;\r\n      bottom: 0px;\r\n      height: 100%;\r\n      width: 100%;\r\n      overflow: hidden;\r\n      padding: 20px;\r\n      z-index: 5;\r\n      box-sizing: border-box;\r\n      background-color: rgba(0, 0, 0, 0.75)\r\n    }`]\r\n\r\n})\r\nexport class AudioDisplayPlayer implements AudioPlayerListener, OnInit,AfterViewInit {\r\n  private _audioUrl: string|null=null;\r\n\r\n  parentE: HTMLElement;\r\n\r\n  @Input()\r\n  playStartAction: Action<void>;\r\n  @Input()\r\n  playStopAction: Action<void>;\r\n  @Input()\r\n  playSelectionAction:Action<void>\r\n  @Input()\r\n  autoPlayOnSelectToggleAction!:Action<boolean>;\r\n\r\n  zoomFitToPanelAction!:Action<void>;\r\n  zoomSelectedAction!:Action<void>;\r\n  zoomInAction!:Action<void>;\r\n  zoomOutAction!:Action<void>;\r\n\r\n  private _audioClip:AudioClip|null=null;\r\n  ap: AudioPlayer|undefined;\r\n  status: string;\r\n\r\n  currentLoader: XMLHttpRequest | null=null;\r\n\r\n  audio: any;\r\n  updateTimerId: any;\r\n\r\n  @ViewChild(AudioDisplayScrollPane, { static: true })\r\n  private audioDisplayScrollPane!: AudioDisplayScrollPane;\r\n\r\n  constructor(protected route: ActivatedRoute, protected ref: ChangeDetectorRef,protected eRef:ElementRef) {\r\n    this.parentE=this.eRef.nativeElement;\r\n    this.playStartAction = new Action(\"Start\");\r\n    this.playSelectionAction=new Action(\"Play selected\");\r\n    this.playStopAction = new Action(\"Stop\");\r\n    this.status=\"Player created.\";\r\n  }\r\n\r\n  ngOnInit(){\r\n    this.zoomSelectedAction=this.audioDisplayScrollPane.zoomSelectedAction\r\n    this.zoomFitToPanelAction=this.audioDisplayScrollPane.zoomFitToPanelAction;\r\n    this.zoomOutAction=this.audioDisplayScrollPane.zoomOutAction;\r\n    this.zoomInAction=this.audioDisplayScrollPane.zoomInAction;\r\n    this.ap = new AudioPlayer(this);\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n      if (this.ap) {\r\n          this.playStartAction.onAction = () => {\r\n            console.debug(\"Start action, player: \"+this.ap)\r\n            this.ap?.start();\r\n          }\r\n          this.playSelectionAction.onAction = () => this.ap?.startSelected();\r\n          this.playStopAction.onAction = () => this.ap?.stop();\r\n      }\r\n      this.layout();\r\n      let heightListener=new MutationObserver((mrs:Array<MutationRecord>,mo:MutationObserver)=>{\r\n          mrs.forEach((mr:MutationRecord)=>{\r\n              if('attributes'===mr.type && ('class'===mr.attributeName || 'style'===mr.attributeName)){\r\n                  this.layout();\r\n              }\r\n          })\r\n      });\r\n      heightListener.observe(this.parentE,{attributes: true,childList: true, characterData: true});\r\n    this.route.queryParams.subscribe((params: Params) => {\r\n      if (params['url']) {\r\n        this.audioUrl = params['url'];\r\n      }\r\n    });\r\n  }\r\n\r\n  layout(){\r\n    this.audioDisplayScrollPane.layout();\r\n  }\r\n\r\n  get audioUrl(): string|null {\r\n    return this._audioUrl;\r\n  }\r\n\r\n  set audioUrl(value: string|null) {\r\n    if(this.ap) {\r\n      this.ap.stop();\r\n    }\r\n    this._audioUrl = value;\r\n    this.load();\r\n  }\r\n\r\n\r\n  started() {\r\n    //console.debug(\"Play started\");\r\n    this.status = 'Playing...';\r\n  }\r\n\r\n  private load() {\r\n\r\n    if (this.currentLoader) {\r\n      this.currentLoader.abort();\r\n      this.currentLoader = null;\r\n    }\r\n    if(this._audioUrl) {\r\n      //this.statusMsg.innerHTML = 'Connecting...';\r\n      this.currentLoader = new XMLHttpRequest();\r\n      this.currentLoader.open(\"GET\", this._audioUrl, true);\r\n      this.currentLoader.responseType = \"arraybuffer\";\r\n      this.currentLoader.onload = (e) => {\r\n        if (this.currentLoader) {\r\n\r\n          var data = this.currentLoader.response; // not responseText\r\n          //console.debug(\"Received data \", data.byteLength);\r\n          this.currentLoader = null;\r\n          this.loaded(data);\r\n        }\r\n      }\r\n      this.currentLoader.onerror = (e) => {\r\n        console.error(\"Error downloading ...\");\r\n        this.currentLoader = null;\r\n      }\r\n      this.currentLoader.send();\r\n    }\r\n  }\r\n\r\n  private loaded(data: ArrayBuffer) {\r\n\r\n    //console.debug(\"Loaded\");\r\n    this.status = 'Audio file loaded.';\r\n    //console.debug(\"Received data \", data.byteLength);\r\n\r\n    AudioContextProvider.decodeAudioData(data).then(audioBuffer => {\r\n      //console.debug(\"Audio Buffer Samplerate: \", audioBuffer.sampleRate)\r\n      let as=new AudioBufferSource(audioBuffer);\r\n      let adh=new AudioDataHolder(as);\r\n      this.audioClip = new AudioClip(adh);\r\n    });\r\n\r\n  }\r\n\r\n  @Input()\r\n  set audioData(audioData: AudioDataHolder){\r\n      this.audioDisplayScrollPane.audioData = audioData;\r\n      if(audioData) {\r\n          let clip = new AudioClip(audioData);\r\n          if (this.ap){\r\n              this.ap.audioClip = clip;\r\n                this.playStartAction.disabled = false\r\n            }\r\n      }else{\r\n          this.playStartAction.disabled = true\r\n          if (this.ap){\r\n              this.ap.audioClip = null;\r\n          }\r\n      }\r\n    this.playSelectionAction.disabled=true\r\n  }\r\n\r\n  startSelectionDisabled(){\r\n    return !(this._audioClip && this.ap!=null && !this.playStartAction.disabled && this._audioClip.selection )\r\n  }\r\n\r\n  @Input()\r\n  set audioClip(audioClip: AudioClip | null) {\r\n    this._audioClip=audioClip\r\n    let audioData:AudioDataHolder| null=null;\r\n    if(audioClip){\r\n      audioData=audioClip.audioDataHolder;\r\n      if(this._audioClip) {\r\n        this._audioClip.addSelectionObserver((ac) => {\r\n          this.playSelectionAction.disabled = this.startSelectionDisabled()\r\n        })\r\n      }\r\n    }\r\n    if(audioData) {\r\n      //console.debug(\"Play start action (by AudioDisplayPlayer::set audioClip) disabled: \"+(!this.ap));\r\n      this.playStartAction.disabled =(!this.ap)\r\n      this.playSelectionAction.disabled=this.startSelectionDisabled()\r\n    }else{\r\n      this.playStartAction.disabled = true\r\n      this.playSelectionAction.disabled=true\r\n  }\r\n\r\n    this.audioDisplayScrollPane.audioClip=audioClip\r\n    if(this.ap) {\r\n      this.ap.audioClip = audioClip\r\n    }\r\n  }\r\n\r\n  get audioClip():AudioClip|null{\r\n    return this._audioClip\r\n  }\r\n\r\n  updatePlayPosition() {\r\n\r\n    if (this.ap && this.ap.playPositionFrames) {\r\n      this.audioDisplayScrollPane.playFramePosition = this.ap.playPositionFrames;\r\n    }\r\n  }\r\n\r\n  audioPlayerUpdate(e: AudioPlayerEvent) {\r\n    if (EventType.STARTED === e.type) {\r\n      this.status = 'Playback...';\r\n      this.updateTimerId = window.setInterval(() => this.updatePlayPosition(), 50);\r\n      this.playStartAction.disabled = true;\r\n      this.playSelectionAction.disabled=true\r\n      this.playStopAction.disabled = false;\r\n    } else if (EventType.ENDED === e.type) {\r\n      this.status = 'Ready.';\r\n      window.clearInterval(this.updateTimerId);\r\n      this.playStartAction.disabled = false;\r\n      this.playSelectionAction.disabled=this.startSelectionDisabled()\r\n      this.playStopAction.disabled = true;\r\n    }else if (EventType.ERROR === e.type) {\r\n      this.status = 'Error.';\r\n      window.clearInterval(this.updateTimerId);\r\n      this.playStartAction.disabled = false;\r\n      this.playSelectionAction.disabled=this.startSelectionDisabled()\r\n      this.playStopAction.disabled = true;\r\n    }\r\n\r\n\r\n    this.ref.detectChanges();\r\n\r\n  }\r\n\r\n  error() {\r\n    this.status = 'ERROR';\r\n  }\r\n\r\n}\r\n\r\n"]}
221
+ `, styles: [":host{display:flex;flex-direction:column;position:absolute;bottom:0;height:100%;width:100%;overflow:hidden;padding:20px;z-index:5;box-sizing:border-box;background-color:#000000bf}\n"] }]
222
+ }], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }], propDecorators: { playStartAction: [{
223
+ type: Input
224
+ }], playStopAction: [{
225
+ type: Input
226
+ }], playSelectionAction: [{
227
+ type: Input
228
+ }], autoPlayOnSelectToggleAction: [{
229
+ type: Input
230
+ }], audioDisplayScrollPane: [{
231
+ type: ViewChild,
232
+ args: [AudioDisplayScrollPane, { static: true }]
233
+ }], audioData: [{
234
+ type: Input
235
+ }], audioClip: [{
236
+ type: Input
237
+ }] } });
238
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audio_player.js","sourceRoot":"","sources":["../../../../../projects/speechrecorderng/src/lib/audio/audio_player.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    ViewChild,\r\n    ChangeDetectorRef,\r\n    AfterViewInit, Input, OnInit, ElementRef,\r\n} from '@angular/core'\r\n\r\nimport {AudioClip} from './persistor'\r\nimport {AudioPlayer, AudioPlayerListener, AudioPlayerEvent, EventType} from './playback/player'\r\nimport {ActivatedRoute, Params} from \"@angular/router\";\r\nimport {Action} from \"../action/action\";\r\nimport {AudioDisplayScrollPane} from \"./ui/audio_display_scroll_pane\";\r\nimport {AudioContextProvider} from \"./context\";\r\nimport {AudioBufferSource, AudioDataHolder} from \"./audio_data_holder\";\r\n\r\n@Component({\r\n\r\n  selector: 'app-audiodisplayplayer',\r\n\r\n  template: `\r\n\r\n    <audio-display-scroll-pane #audioDisplayScrollPane></audio-display-scroll-pane>\r\n\r\n    <audio-display-control [audioClip]=\"audioClip\"\r\n                             [playStartAction]=\"playStartAction\"\r\n                             [playSelectionAction]=\"playSelectionAction\"\r\n                             [playStopAction]=\"playStopAction\"\r\n                             [autoPlayOnSelectToggleAction]=\"ap?.autoPlayOnSelectToggleAction\"\r\n                             [zoomInAction]=\"zoomInAction\"\r\n                             [zoomOutAction]=\"zoomOutAction\"\r\n                             [zoomSelectedAction]=\"zoomSelectedAction\"\r\n                             [zoomFitToPanelAction]=\"zoomFitToPanelAction\"></audio-display-control><p>{{status}}\r\n  `,\r\n  styles: [\r\n      `:host {\r\n             display: flex;\r\n             flex-direction: column;\r\n             position: absolute;\r\n             bottom: 0px;\r\n             height: 100%;\r\n             width: 100%;\r\n             overflow: hidden;\r\n             padding: 20px;\r\n             z-index: 5;\r\n             box-sizing: border-box;\r\n             background-color: rgba(0, 0, 0, 0.75)\r\n           }`]\r\n\r\n})\r\nexport class AudioDisplayPlayer implements AudioPlayerListener, OnInit,AfterViewInit {\r\n  private _audioUrl: string|null=null;\r\n\r\n  parentE: HTMLElement;\r\n\r\n  @Input()\r\n  playStartAction: Action<void>;\r\n  @Input()\r\n  playStopAction: Action<void>;\r\n  @Input()\r\n  playSelectionAction:Action<void>\r\n  @Input()\r\n  autoPlayOnSelectToggleAction!:Action<boolean>;\r\n\r\n  zoomFitToPanelAction!:Action<void>;\r\n  zoomSelectedAction!:Action<void>;\r\n  zoomInAction!:Action<void>;\r\n  zoomOutAction!:Action<void>;\r\n\r\n  private _audioClip:AudioClip|null=null;\r\n  ap: AudioPlayer|undefined;\r\n  status: string;\r\n\r\n  currentLoader: XMLHttpRequest | null=null;\r\n\r\n  audio: any;\r\n  updateTimerId: any;\r\n\r\n  @ViewChild(AudioDisplayScrollPane, { static: true })\r\n  private audioDisplayScrollPane!: AudioDisplayScrollPane;\r\n\r\n  constructor(protected route: ActivatedRoute, protected ref: ChangeDetectorRef,protected eRef:ElementRef) {\r\n    this.parentE=this.eRef.nativeElement;\r\n    this.playStartAction = new Action(\"Start\");\r\n    this.playSelectionAction=new Action(\"Play selected\");\r\n    this.playStopAction = new Action(\"Stop\");\r\n    this.status=\"Player created.\";\r\n  }\r\n\r\n  ngOnInit(){\r\n    this.zoomSelectedAction=this.audioDisplayScrollPane.zoomSelectedAction\r\n    this.zoomFitToPanelAction=this.audioDisplayScrollPane.zoomFitToPanelAction;\r\n    this.zoomOutAction=this.audioDisplayScrollPane.zoomOutAction;\r\n    this.zoomInAction=this.audioDisplayScrollPane.zoomInAction;\r\n    this.ap = new AudioPlayer(this);\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n      if (this.ap) {\r\n          this.playStartAction.onAction = () => {\r\n            console.debug(\"Start action, player: \"+this.ap)\r\n            this.ap?.start();\r\n          }\r\n          this.playSelectionAction.onAction = () => this.ap?.startSelected();\r\n          this.playStopAction.onAction = () => this.ap?.stop();\r\n      }\r\n      this.layout();\r\n      let heightListener=new MutationObserver((mrs:Array<MutationRecord>,mo:MutationObserver)=>{\r\n          mrs.forEach((mr:MutationRecord)=>{\r\n              if('attributes'===mr.type && ('class'===mr.attributeName || 'style'===mr.attributeName)){\r\n                  this.layout();\r\n              }\r\n          })\r\n      });\r\n      heightListener.observe(this.parentE,{attributes: true,childList: true, characterData: true});\r\n    this.route.queryParams.subscribe((params: Params) => {\r\n      if (params['url']) {\r\n        this.audioUrl = params['url'];\r\n      }\r\n    });\r\n  }\r\n\r\n  layout(){\r\n    this.audioDisplayScrollPane.layout();\r\n  }\r\n\r\n  get audioUrl(): string|null {\r\n    return this._audioUrl;\r\n  }\r\n\r\n  set audioUrl(value: string|null) {\r\n    if(this.ap) {\r\n      this.ap.stop();\r\n    }\r\n    this._audioUrl = value;\r\n    this.load();\r\n  }\r\n\r\n\r\n  started() {\r\n    //console.debug(\"Play started\");\r\n    this.status = 'Playing...';\r\n  }\r\n\r\n  private load() {\r\n\r\n    if (this.currentLoader) {\r\n      this.currentLoader.abort();\r\n      this.currentLoader = null;\r\n    }\r\n    if(this._audioUrl) {\r\n      //this.statusMsg.innerHTML = 'Connecting...';\r\n      this.currentLoader = new XMLHttpRequest();\r\n      this.currentLoader.open(\"GET\", this._audioUrl, true);\r\n      this.currentLoader.responseType = \"arraybuffer\";\r\n      this.currentLoader.onload = (e) => {\r\n        if (this.currentLoader) {\r\n\r\n          var data = this.currentLoader.response; // not responseText\r\n          //console.debug(\"Received data \", data.byteLength);\r\n          this.currentLoader = null;\r\n          this.loaded(data);\r\n        }\r\n      }\r\n      this.currentLoader.onerror = (e) => {\r\n        console.error(\"Error downloading ...\");\r\n        this.currentLoader = null;\r\n      }\r\n      this.currentLoader.send();\r\n    }\r\n  }\r\n\r\n  private loaded(data: ArrayBuffer) {\r\n\r\n    //console.debug(\"Loaded\");\r\n    this.status = 'Audio file loaded.';\r\n    //console.debug(\"Received data \", data.byteLength);\r\n\r\n    AudioContextProvider.decodeAudioData(data).then(audioBuffer => {\r\n      //console.debug(\"Audio Buffer Samplerate: \", audioBuffer.sampleRate)\r\n      let as=new AudioBufferSource(audioBuffer);\r\n      let adh=new AudioDataHolder(as);\r\n      this.audioClip = new AudioClip(adh);\r\n    });\r\n\r\n  }\r\n\r\n  @Input()\r\n  set audioData(audioData: AudioDataHolder){\r\n      this.audioDisplayScrollPane.audioData = audioData;\r\n      if(audioData) {\r\n          let clip = new AudioClip(audioData);\r\n          if (this.ap){\r\n              this.ap.audioClip = clip;\r\n                this.playStartAction.disabled = false\r\n            }\r\n      }else{\r\n          this.playStartAction.disabled = true\r\n          if (this.ap){\r\n              this.ap.audioClip = null;\r\n          }\r\n      }\r\n    this.playSelectionAction.disabled=true\r\n  }\r\n\r\n  startSelectionDisabled(){\r\n    return !(this._audioClip && this.ap!=null && !this.playStartAction.disabled && this._audioClip.selection )\r\n  }\r\n\r\n  @Input()\r\n  set audioClip(audioClip: AudioClip | null) {\r\n    this._audioClip=audioClip\r\n    let audioData:AudioDataHolder| null=null;\r\n    if(audioClip){\r\n      audioData=audioClip.audioDataHolder;\r\n      if(this._audioClip) {\r\n        this._audioClip.addSelectionObserver((ac) => {\r\n          this.playSelectionAction.disabled = this.startSelectionDisabled()\r\n        })\r\n      }\r\n    }\r\n    if(audioData) {\r\n      //console.debug(\"Play start action (by AudioDisplayPlayer::set audioClip) disabled: \"+(!this.ap));\r\n      this.playStartAction.disabled =(!this.ap)\r\n      this.playSelectionAction.disabled=this.startSelectionDisabled()\r\n    }else{\r\n      this.playStartAction.disabled = true\r\n      this.playSelectionAction.disabled=true\r\n  }\r\n\r\n    this.audioDisplayScrollPane.audioClip=audioClip\r\n    if(this.ap) {\r\n      this.ap.audioClip = audioClip\r\n    }\r\n  }\r\n\r\n  get audioClip():AudioClip|null{\r\n    return this._audioClip\r\n  }\r\n\r\n  updatePlayPosition() {\r\n\r\n    if (this.ap && this.ap.playPositionFrames) {\r\n      this.audioDisplayScrollPane.playFramePosition = this.ap.playPositionFrames;\r\n    }\r\n  }\r\n\r\n  audioPlayerUpdate(e: AudioPlayerEvent) {\r\n    if (EventType.STARTED === e.type) {\r\n      this.status = 'Playback...';\r\n      this.updateTimerId = window.setInterval(() => this.updatePlayPosition(), 50);\r\n      this.playStartAction.disabled = true;\r\n      this.playSelectionAction.disabled=true\r\n      this.playStopAction.disabled = false;\r\n    } else if (EventType.ENDED === e.type) {\r\n      this.status = 'Ready.';\r\n      window.clearInterval(this.updateTimerId);\r\n      this.playStartAction.disabled = false;\r\n      this.playSelectionAction.disabled=this.startSelectionDisabled()\r\n      this.playStopAction.disabled = true;\r\n    }else if (EventType.ERROR === e.type) {\r\n      this.status = 'Error.';\r\n      window.clearInterval(this.updateTimerId);\r\n      this.playStartAction.disabled = false;\r\n      this.playSelectionAction.disabled=this.startSelectionDisabled()\r\n      this.playStopAction.disabled = true;\r\n    }\r\n\r\n\r\n    this.ref.detectChanges();\r\n\r\n  }\r\n\r\n  error() {\r\n    this.status = 'ERROR';\r\n  }\r\n\r\n}\r\n\r\n"]}