speechrecorderng 3.4.4 → 3.6.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 (67) hide show
  1. package/README.md +1 -1
  2. package/esm2020/lib/action/action.mjs +3 -3
  3. package/esm2020/lib/audio/audio_display.mjs +7 -9
  4. package/esm2020/lib/audio/audio_player.mjs +13 -26
  5. package/esm2020/lib/audio/capture/capture.mjs +244 -207
  6. package/esm2020/lib/audio/context.mjs +64 -2
  7. package/esm2020/lib/audio/io/stream.mjs +1 -1
  8. package/esm2020/lib/audio/net_audio_buffer.mjs +5 -9
  9. package/esm2020/lib/audio/playback/array_audio_buffer_source_node.mjs +2 -2
  10. package/esm2020/lib/audio/playback/audio_source_worklet_module_loader.mjs +2 -2
  11. package/esm2020/lib/audio/playback/inddb_audio_buffer_source_node.mjs +1 -1
  12. package/esm2020/lib/audio/playback/player.mjs +137 -96
  13. package/esm2020/lib/audio/ui/audio_display_control.mjs +1 -1
  14. package/esm2020/lib/audio/ui/container.mjs +3 -3
  15. package/esm2020/lib/db/inddb.mjs +1 -1
  16. package/esm2020/lib/net/uploader.mjs +31 -28
  17. package/esm2020/lib/speechrecorder/project/project.mjs +1 -1
  18. package/esm2020/lib/speechrecorder/project/project.service.mjs +4 -4
  19. package/esm2020/lib/speechrecorder/recordings/basic_recording.service.mjs +59 -56
  20. package/esm2020/lib/speechrecorder/recordings/recordings.service.mjs +151 -142
  21. package/esm2020/lib/speechrecorder/script/script.service.mjs +1 -1
  22. package/esm2020/lib/speechrecorder/session/audiorecorder.mjs +49 -99
  23. package/esm2020/lib/speechrecorder/session/basicrecorder.mjs +9 -2
  24. package/esm2020/lib/speechrecorder/session/controlpanel.mjs +13 -11
  25. package/esm2020/lib/speechrecorder/session/progress.mjs +1 -1
  26. package/esm2020/lib/speechrecorder/session/prompting.mjs +1 -1
  27. package/esm2020/lib/speechrecorder/session/recorder_combi_pane.mjs +1 -1
  28. package/esm2020/lib/speechrecorder/session/recording_list.mjs +1 -1
  29. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +3 -3
  30. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-navi.component.mjs +3 -3
  31. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +17 -16
  32. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +13 -14
  33. package/esm2020/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +145 -135
  34. package/esm2020/lib/speechrecorder/session/session.service.mjs +12 -9
  35. package/esm2020/lib/speechrecorder/session/sessionmanager.mjs +66 -70
  36. package/esm2020/lib/speechrecorder/startstopsignal/startstopsignal.mjs +1 -2
  37. package/esm2020/lib/speechrecorderng.component.mjs +10 -16
  38. package/esm2020/lib/speechrecorderng.module.mjs +1 -1
  39. package/esm2020/lib/spr.module.version.mjs +2 -2
  40. package/esm2020/lib/ui/recordingitem_display.mjs +2 -2
  41. package/fesm2015/speechrecorderng.mjs +1077 -976
  42. package/fesm2015/speechrecorderng.mjs.map +1 -1
  43. package/fesm2020/speechrecorderng.mjs +1074 -976
  44. package/fesm2020/speechrecorderng.mjs.map +1 -1
  45. package/lib/action/action.d.ts +1 -1
  46. package/lib/audio/audio_display.d.ts +1 -3
  47. package/lib/audio/audio_player.d.ts +0 -1
  48. package/lib/audio/capture/capture.d.ts +5 -4
  49. package/lib/audio/context.d.ts +2 -0
  50. package/lib/audio/io/stream.d.ts +1 -1
  51. package/lib/audio/net_audio_buffer.d.ts +2 -4
  52. package/lib/audio/playback/player.d.ts +3 -2
  53. package/lib/net/uploader.d.ts +6 -6
  54. package/lib/speechrecorder/project/project.d.ts +1 -0
  55. package/lib/speechrecorder/project/project.service.d.ts +4 -4
  56. package/lib/speechrecorder/recordings/basic_recording.service.d.ts +2 -2
  57. package/lib/speechrecorder/recordings/recordings.service.d.ts +8 -8
  58. package/lib/speechrecorder/script/script.service.d.ts +2 -2
  59. package/lib/speechrecorder/session/audiorecorder.d.ts +1 -2
  60. package/lib/speechrecorder/session/basicrecorder.d.ts +4 -1
  61. package/lib/speechrecorder/session/controlpanel.d.ts +1 -1
  62. package/lib/speechrecorder/session/recordingfile/recording-file-meta.component.d.ts +1 -0
  63. package/lib/speechrecorder/session/recordingfile/recordingfile-service.d.ts +2 -2
  64. package/lib/speechrecorder/session/session.service.d.ts +2 -2
  65. package/lib/speechrecorder/session/sessionmanager.d.ts +1 -0
  66. package/lib/spr.module.version.d.ts +1 -1
  67. package/package.json +1 -1
package/README.md CHANGED
@@ -1,6 +1,6 @@
1
1
  # Speechrecorderng
2
2
 
3
- This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 12.0.0.
3
+ This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 14.0.0.
4
4
 
5
5
  ## Code scaffolding
6
6
 
@@ -56,7 +56,7 @@ export class Action {
56
56
  ctrl.disabled = this.disabled;
57
57
  this.controls.push(ctrl);
58
58
  if (actionEventName) {
59
- ctrl.addEventListener(actionEventName, (e) => {
59
+ ctrl.addEventListener(actionEventName, () => {
60
60
  this.perform();
61
61
  });
62
62
  }
@@ -64,10 +64,10 @@ export class Action {
64
64
  }
65
65
  }
66
66
  removeControl(ctrl) {
67
- var i = this.controls.indexOf(ctrl);
67
+ const i = this.controls.indexOf(ctrl);
68
68
  if (i >= 0) {
69
69
  this.controls = this.controls.splice(i, 1);
70
70
  }
71
71
  }
72
72
  }
73
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL2FjdGlvbi9hY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0ksTUFBTSxPQUFPLFdBQVc7SUFJcEIsWUFBb0IsU0FBYyxJQUFJO1FBQWxCLFdBQU0sR0FBTixNQUFNLENBQVk7SUFFdEMsQ0FBQztJQUxELElBQUksS0FBSztRQUNMLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUN2QixDQUFDO0NBSUo7QUFNRCxNQUFNLE9BQU8sTUFBTTtJQVlmLFlBQVksSUFBVyxFQUFDLFFBQWEsSUFBSTtRQUx6QyxjQUFTLEdBQUMsSUFBSSxDQUFDO1FBQ1AsY0FBUyxHQUE2QixJQUFJLENBQUM7UUFLL0MsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7UUFDbEIsSUFBSSxDQUFDLE1BQU0sR0FBQyxLQUFLLENBQUE7UUFDakIsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLEtBQUssRUFBMEIsQ0FBQztRQUNyRCxJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBaEJELElBQUksS0FBSztRQUNMLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUN2QixDQUFDO0lBZ0JELElBQUksSUFBSTtRQUNKLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUN0QixDQUFDO0lBR0QsSUFBSSxRQUFRO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzFCLENBQUM7SUFFRCxJQUFJLFFBQVEsQ0FBQyxLQUFpQztRQUMxQyxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztJQUMzQixDQUFDO0lBRVUsaUJBQWlCLENBQUMsUUFBYyxJQUFJO1FBQzNDLFdBQVc7UUFDWCxPQUFPLElBQUksV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFRCxPQUFPLENBQUMsUUFBYyxJQUFJO1FBQ3RCLElBQUksQ0FBQyxNQUFNLEdBQUMsS0FBSyxDQUFBO1FBQ2pCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbEMsSUFBSSxFQUFFLEdBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUFBO1lBQ3BDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLENBQUM7U0FDdEI7SUFDTCxDQUFDO0lBRUQsSUFBSSxRQUFRLENBQUMsUUFBZ0I7UUFDMUIsNkRBQTZEO1FBQzVELElBQUksQ0FBQyxTQUFTLEdBQUcsUUFBUSxDQUFDO1FBQzFCLEtBQUssSUFBSSxDQUFDLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN6QixDQUFDLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7U0FDL0I7UUFDRCxnREFBZ0Q7UUFDaEQsc0NBQXNDO0lBQzFDLENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDUixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDMUIsQ0FBQztJQUVELFVBQVUsQ0FBQyxJQUFzQixFQUFFLGVBQXdCO1FBQ3ZELElBQUksSUFBSSxFQUFFO1lBQ04sSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQ2pDLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQztnQkFDOUIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ3pCLElBQUksZUFBZSxFQUFFO29CQUNqQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUU7d0JBQ3pDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztvQkFDbkIsQ0FBQyxDQUFDLENBQUM7aUJBQ047YUFDSjtTQUNKO0lBQ0wsQ0FBQztJQUVELGFBQWEsQ0FBQyxJQUFxQjtRQUMvQixJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNwQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDUixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztTQUM5QztJQUNMLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbIlxyXG4gICAgZXhwb3J0IGNsYXNzIEFjdGlvbkV2ZW50PFQ+IHtcclxuICAgICAgICBnZXQgdmFsdWUoKTogVHxudWxsIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMuX3ZhbHVlO1xyXG4gICAgICAgIH1cclxuICAgICAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIF92YWx1ZTpUfG51bGw9bnVsbCkge1xyXG5cclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgZXhwb3J0IGludGVyZmFjZSBBY3Rpb25FdmVudExpc3RlbmVyPFQ+e1xyXG4gICAgICAgIChhZTpBY3Rpb25FdmVudDxUPik6dm9pZDtcclxuICAgIH1cclxuXHJcbiAgICBleHBvcnQgY2xhc3MgQWN0aW9uPFQ+IHtcclxuICAgICAgICBnZXQgdmFsdWUoKTogVHxudWxsIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMuX3ZhbHVlO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcHJpdmF0ZSBfbmFtZTpzdHJpbmc7XHJcbiAgICAgICAgcHJpdmF0ZSBfdmFsdWU6VHxudWxsO1xyXG4gICAgICAgIF9kaXNhYmxlZD10cnVlO1xyXG4gICAgICAgIHByaXZhdGUgX29uQWN0aW9uOkFjdGlvbkV2ZW50TGlzdGVuZXI8VD58bnVsbD1udWxsO1xyXG4gICAgICAgIGxpc3RlbmVyczpBcnJheTxBY3Rpb25FdmVudExpc3RlbmVyPFQ+PjtcclxuICAgICAgICBwcml2YXRlIGNvbnRyb2xzOkhUTUxJbnB1dEVsZW1lbnRbXTtcclxuXHJcbiAgICAgICAgY29uc3RydWN0b3IobmFtZTpzdHJpbmcsdmFsdWU6VHxudWxsPW51bGwpIHtcclxuICAgICAgICAgICAgdGhpcy5fbmFtZSA9IG5hbWU7XHJcbiAgICAgICAgICAgIHRoaXMuX3ZhbHVlPXZhbHVlXHJcbiAgICAgICAgICAgIHRoaXMubGlzdGVuZXJzID0gbmV3IEFycmF5PEFjdGlvbkV2ZW50TGlzdGVuZXI8VD4+KCk7XHJcbiAgICAgICAgICAgIHRoaXMuY29udHJvbHMgPSBbXTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGdldCBuYW1lKCk6c3RyaW5nIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMuX25hbWU7XHJcbiAgICAgICAgfVxyXG5cclxuXHJcbiAgICAgICAgZ2V0IG9uQWN0aW9uKCk6QWN0aW9uRXZlbnRMaXN0ZW5lcjxUPnxudWxsIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMuX29uQWN0aW9uO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgc2V0IG9uQWN0aW9uKHZhbHVlOkFjdGlvbkV2ZW50TGlzdGVuZXI8VD58bnVsbCkge1xyXG4gICAgICAgICAgICB0aGlzLl9vbkFjdGlvbiA9IHZhbHVlO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcHJvdGVjdGVkICBjcmVhdGVBY3Rpb25FdmVudCh2YWx1ZTogVHxudWxsPW51bGwpOkFjdGlvbkV2ZW50PFQ+IHtcclxuICAgICAgICAgICAgLy8gZGVmYXVsdDpcclxuICAgICAgICAgICAgcmV0dXJuIG5ldyBBY3Rpb25FdmVudCh2YWx1ZSk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBwZXJmb3JtKHZhbHVlOiBUfG51bGw9bnVsbCk6dm9pZCB7XHJcbiAgICAgICAgICAgIHRoaXMuX3ZhbHVlPXZhbHVlXHJcbiAgICAgICAgICAgIGlmICghdGhpcy5kaXNhYmxlZCAmJiB0aGlzLl9vbkFjdGlvbikge1xyXG4gICAgICAgICAgICAgICAgbGV0IGFlPXRoaXMuY3JlYXRlQWN0aW9uRXZlbnQodmFsdWUpXHJcbiAgICAgICAgICAgICAgICB0aGlzLl9vbkFjdGlvbihhZSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHNldCBkaXNhYmxlZChkaXNhYmxlZDpib29sZWFuKSB7XHJcbiAgICAgICAgICAgLy9jb25zb2xlLmRlYnVnKFwiQWN0aW9uOiBcIit0aGlzLl9uYW1lK1wiIGRpc2FibGVkOiBcIitkaXNhYmxlZClcclxuICAgICAgICAgICAgdGhpcy5fZGlzYWJsZWQgPSBkaXNhYmxlZDtcclxuICAgICAgICAgICAgZm9yIChsZXQgYyBvZiB0aGlzLmNvbnRyb2xzKSB7XHJcbiAgICAgICAgICAgICAgICBjLmRpc2FibGVkID0gdGhpcy5fZGlzYWJsZWQ7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgLy9sZXQgZGlzU3RyPXRoaXMuZGlzYWJsZWQ/XCJkaXNhYmxlZFwiOlwiZW5hYmxlZFwiO1xyXG4gICAgICAgICAgICAvL2NvbnNvbGUubG9nKHRoaXMuX25hbWUrXCI6IFwiK2Rpc1N0cik7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBnZXQgZGlzYWJsZWQoKTpib29sZWFuIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMuX2Rpc2FibGVkO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgYWRkQ29udHJvbChjdHJsOiBIVE1MSW5wdXRFbGVtZW50LCBhY3Rpb25FdmVudE5hbWU/OiBzdHJpbmcpIHtcclxuICAgICAgICAgICAgaWYgKGN0cmwpIHtcclxuICAgICAgICAgICAgICAgIGlmICh0aGlzLmNvbnRyb2xzLmluZGV4T2YoY3RybCkgPCAwKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgY3RybC5kaXNhYmxlZCA9IHRoaXMuZGlzYWJsZWQ7XHJcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5jb250cm9scy5wdXNoKGN0cmwpO1xyXG4gICAgICAgICAgICAgICAgICAgIGlmIChhY3Rpb25FdmVudE5hbWUpIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgY3RybC5hZGRFdmVudExpc3RlbmVyKGFjdGlvbkV2ZW50TmFtZSwgKGUpID0+IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMucGVyZm9ybSgpO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHJlbW92ZUNvbnRyb2woY3RybDpIVE1MSW5wdXRFbGVtZW50KSB7XHJcbiAgICAgICAgICAgIHZhciBpID0gdGhpcy5jb250cm9scy5pbmRleE9mKGN0cmwpO1xyXG4gICAgICAgICAgICBpZiAoaSA+PSAwKSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLmNvbnRyb2xzID0gdGhpcy5jb250cm9scy5zcGxpY2UoaSwgMSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4iXX0=
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL2FjdGlvbi9hY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0ksTUFBTSxPQUFPLFdBQVc7SUFJcEIsWUFBb0IsU0FBYyxJQUFJO1FBQWxCLFdBQU0sR0FBTixNQUFNLENBQVk7SUFFdEMsQ0FBQztJQUxELElBQUksS0FBSztRQUNMLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUN2QixDQUFDO0NBSUo7QUFNRCxNQUFNLE9BQU8sTUFBTTtJQVlmLFlBQVksSUFBVyxFQUFDLFFBQWEsSUFBSTtRQUx6QyxjQUFTLEdBQUMsSUFBSSxDQUFDO1FBQ1AsY0FBUyxHQUE2QixJQUFJLENBQUM7UUFLL0MsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7UUFDbEIsSUFBSSxDQUFDLE1BQU0sR0FBQyxLQUFLLENBQUE7UUFDakIsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLEtBQUssRUFBMEIsQ0FBQztRQUNyRCxJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBaEJELElBQUksS0FBSztRQUNMLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUN2QixDQUFDO0lBZ0JELElBQUksSUFBSTtRQUNKLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUN0QixDQUFDO0lBR0QsSUFBSSxRQUFRO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzFCLENBQUM7SUFFRCxJQUFJLFFBQVEsQ0FBQyxLQUFpQztRQUMxQyxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztJQUMzQixDQUFDO0lBRVUsaUJBQWlCLENBQUMsUUFBYyxJQUFJO1FBQzNDLFdBQVc7UUFDWCxPQUFPLElBQUksV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFRCxPQUFPLENBQUMsUUFBYyxJQUFJO1FBQ3RCLElBQUksQ0FBQyxNQUFNLEdBQUMsS0FBSyxDQUFBO1FBQ2pCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbEMsSUFBSSxFQUFFLEdBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUFBO1lBQ3BDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLENBQUM7U0FDdEI7SUFDTCxDQUFDO0lBRUQsSUFBSSxRQUFRLENBQUMsUUFBZ0I7UUFDMUIsNkRBQTZEO1FBQzVELElBQUksQ0FBQyxTQUFTLEdBQUcsUUFBUSxDQUFDO1FBQzFCLEtBQUssSUFBSSxDQUFDLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN6QixDQUFDLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7U0FDL0I7UUFDRCxnREFBZ0Q7UUFDaEQsc0NBQXNDO0lBQzFDLENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDUixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDMUIsQ0FBQztJQUVELFVBQVUsQ0FBQyxJQUFzQixFQUFFLGVBQXdCO1FBQ3ZELElBQUksSUFBSSxFQUFFO1lBQ04sSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQ2pDLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQztnQkFDOUIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ3pCLElBQUksZUFBZSxFQUFFO29CQUNqQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxFQUFFLEdBQUcsRUFBRTt3QkFDeEMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO29CQUNuQixDQUFDLENBQUMsQ0FBQztpQkFDTjthQUNKO1NBQ0o7SUFDTCxDQUFDO0lBRUQsYUFBYSxDQUFDLElBQXFCO1FBQy9CLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUNSLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1NBQzlDO0lBQ0wsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiXHJcbiAgICBleHBvcnQgY2xhc3MgQWN0aW9uRXZlbnQ8VD4ge1xyXG4gICAgICAgIGdldCB2YWx1ZSgpOiBUfG51bGwge1xyXG4gICAgICAgICAgICByZXR1cm4gdGhpcy5fdmFsdWU7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgX3ZhbHVlOlR8bnVsbD1udWxsKSB7XHJcblxyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBleHBvcnQgaW50ZXJmYWNlIEFjdGlvbkV2ZW50TGlzdGVuZXI8VD57XHJcbiAgICAgICAgKGFlOkFjdGlvbkV2ZW50PFQ+KTp2b2lkO1xyXG4gICAgfVxyXG5cclxuICAgIGV4cG9ydCBjbGFzcyBBY3Rpb248VD4ge1xyXG4gICAgICAgIGdldCB2YWx1ZSgpOiBUfG51bGwge1xyXG4gICAgICAgICAgICByZXR1cm4gdGhpcy5fdmFsdWU7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IF9uYW1lOnN0cmluZztcclxuICAgICAgICBwcml2YXRlIF92YWx1ZTpUfG51bGw7XHJcbiAgICAgICAgX2Rpc2FibGVkPXRydWU7XHJcbiAgICAgICAgcHJpdmF0ZSBfb25BY3Rpb246QWN0aW9uRXZlbnRMaXN0ZW5lcjxUPnxudWxsPW51bGw7XHJcbiAgICAgICAgbGlzdGVuZXJzOkFycmF5PEFjdGlvbkV2ZW50TGlzdGVuZXI8VD4+O1xyXG4gICAgICAgIHByaXZhdGUgY29udHJvbHM6SFRNTElucHV0RWxlbWVudFtdO1xyXG5cclxuICAgICAgICBjb25zdHJ1Y3RvcihuYW1lOnN0cmluZyx2YWx1ZTpUfG51bGw9bnVsbCkge1xyXG4gICAgICAgICAgICB0aGlzLl9uYW1lID0gbmFtZTtcclxuICAgICAgICAgICAgdGhpcy5fdmFsdWU9dmFsdWVcclxuICAgICAgICAgICAgdGhpcy5saXN0ZW5lcnMgPSBuZXcgQXJyYXk8QWN0aW9uRXZlbnRMaXN0ZW5lcjxUPj4oKTtcclxuICAgICAgICAgICAgdGhpcy5jb250cm9scyA9IFtdO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgZ2V0IG5hbWUoKTpzdHJpbmcge1xyXG4gICAgICAgICAgICByZXR1cm4gdGhpcy5fbmFtZTtcclxuICAgICAgICB9XHJcblxyXG5cclxuICAgICAgICBnZXQgb25BY3Rpb24oKTpBY3Rpb25FdmVudExpc3RlbmVyPFQ+fG51bGwge1xyXG4gICAgICAgICAgICByZXR1cm4gdGhpcy5fb25BY3Rpb247XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBzZXQgb25BY3Rpb24odmFsdWU6QWN0aW9uRXZlbnRMaXN0ZW5lcjxUPnxudWxsKSB7XHJcbiAgICAgICAgICAgIHRoaXMuX29uQWN0aW9uID0gdmFsdWU7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBwcm90ZWN0ZWQgIGNyZWF0ZUFjdGlvbkV2ZW50KHZhbHVlOiBUfG51bGw9bnVsbCk6QWN0aW9uRXZlbnQ8VD4ge1xyXG4gICAgICAgICAgICAvLyBkZWZhdWx0OlxyXG4gICAgICAgICAgICByZXR1cm4gbmV3IEFjdGlvbkV2ZW50KHZhbHVlKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHBlcmZvcm0odmFsdWU6IFR8bnVsbD1udWxsKTp2b2lkIHtcclxuICAgICAgICAgICAgdGhpcy5fdmFsdWU9dmFsdWVcclxuICAgICAgICAgICAgaWYgKCF0aGlzLmRpc2FibGVkICYmIHRoaXMuX29uQWN0aW9uKSB7XHJcbiAgICAgICAgICAgICAgICBsZXQgYWU9dGhpcy5jcmVhdGVBY3Rpb25FdmVudCh2YWx1ZSlcclxuICAgICAgICAgICAgICAgIHRoaXMuX29uQWN0aW9uKGFlKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgc2V0IGRpc2FibGVkKGRpc2FibGVkOmJvb2xlYW4pIHtcclxuICAgICAgICAgICAvL2NvbnNvbGUuZGVidWcoXCJBY3Rpb246IFwiK3RoaXMuX25hbWUrXCIgZGlzYWJsZWQ6IFwiK2Rpc2FibGVkKVxyXG4gICAgICAgICAgICB0aGlzLl9kaXNhYmxlZCA9IGRpc2FibGVkO1xyXG4gICAgICAgICAgICBmb3IgKGxldCBjIG9mIHRoaXMuY29udHJvbHMpIHtcclxuICAgICAgICAgICAgICAgIGMuZGlzYWJsZWQgPSB0aGlzLl9kaXNhYmxlZDtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAvL2xldCBkaXNTdHI9dGhpcy5kaXNhYmxlZD9cImRpc2FibGVkXCI6XCJlbmFibGVkXCI7XHJcbiAgICAgICAgICAgIC8vY29uc29sZS5sb2codGhpcy5fbmFtZStcIjogXCIrZGlzU3RyKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGdldCBkaXNhYmxlZCgpOmJvb2xlYW4ge1xyXG4gICAgICAgICAgICByZXR1cm4gdGhpcy5fZGlzYWJsZWQ7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBhZGRDb250cm9sKGN0cmw6IEhUTUxJbnB1dEVsZW1lbnQsIGFjdGlvbkV2ZW50TmFtZT86IHN0cmluZykge1xyXG4gICAgICAgICAgICBpZiAoY3RybCkge1xyXG4gICAgICAgICAgICAgICAgaWYgKHRoaXMuY29udHJvbHMuaW5kZXhPZihjdHJsKSA8IDApIHtcclxuICAgICAgICAgICAgICAgICAgICBjdHJsLmRpc2FibGVkID0gdGhpcy5kaXNhYmxlZDtcclxuICAgICAgICAgICAgICAgICAgICB0aGlzLmNvbnRyb2xzLnB1c2goY3RybCk7XHJcbiAgICAgICAgICAgICAgICAgICAgaWYgKGFjdGlvbkV2ZW50TmFtZSkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjdHJsLmFkZEV2ZW50TGlzdGVuZXIoYWN0aW9uRXZlbnROYW1lLCAoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aGlzLnBlcmZvcm0oKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICByZW1vdmVDb250cm9sKGN0cmw6SFRNTElucHV0RWxlbWVudCkge1xyXG4gICAgICAgICAgICBjb25zdCBpID0gdGhpcy5jb250cm9scy5pbmRleE9mKGN0cmwpO1xyXG4gICAgICAgICAgICBpZiAoaSA+PSAwKSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLmNvbnRyb2xzID0gdGhpcy5jb250cm9scy5zcGxpY2UoaSwgMSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4iXX0=
@@ -2,12 +2,10 @@ import { Component, ViewChild, Input, } from '@angular/core';
2
2
  import { Action } from "../action/action";
3
3
  import { AudioDisplayScrollPane } from "./ui/audio_display_scroll_pane";
4
4
  import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/router";
6
- import * as i2 from "./ui/audio_display_scroll_pane";
7
- import * as i3 from "./ui/audio_display_control";
5
+ import * as i1 from "./ui/audio_display_scroll_pane";
6
+ import * as i2 from "./ui/audio_display_control";
8
7
  export class AudioDisplay {
9
- constructor(route, ref, eRef) {
10
- this.route = route;
8
+ constructor(ref, eRef) {
11
9
  this.ref = ref;
12
10
  this.eRef = eRef;
13
11
  this._audioClip = null;
@@ -70,7 +68,7 @@ export class AudioDisplay {
70
68
  this.status = 'ERROR';
71
69
  }
72
70
  }
73
- AudioDisplay.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AudioDisplay, deps: [{ token: i1.ActivatedRoute }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
71
+ AudioDisplay.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AudioDisplay, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
74
72
  AudioDisplay.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: AudioDisplay, selector: "app-audiodisplay", 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: `
75
73
 
76
74
  <audio-display-scroll-pane #audioDisplayScrollPane></audio-display-scroll-pane>
@@ -84,7 +82,7 @@ AudioDisplay.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version:
84
82
  [zoomOutAction]="zoomOutAction"
85
83
  [zoomSelectedAction]="zoomSelectedAction"
86
84
  [zoomFitToPanelAction]="zoomFitToPanelAction"></audio-display-control>
87
- `, 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:#e6e6e6}\n", "legend{margin-left:1em;padding:.2em .8em;font-size:.8em}\n", "fieldset{border:1px darkgray solid}\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"] }] });
85
+ `, 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:#e6e6e6}\n", "legend{margin-left:1em;padding:.2em .8em;font-size:.8em}\n", "fieldset{border:1px darkgray solid}\n"], dependencies: [{ kind: "component", type: i1.AudioDisplayScrollPane, selector: "audio-display-scroll-pane", inputs: ["audioClip"], outputs: ["zoomInAction", "zoomOutAction", "zoomSelectedAction", "zoomFitToPanelAction"] }, { kind: "component", type: i2.AudioDisplayControl, selector: "audio-display-control", inputs: ["audioClip", "playStartAction", "playSelectionAction", "playStopAction", "zoomInAction", "zoomOutAction", "zoomFitToPanelAction", "zoomSelectedAction", "autoPlayOnSelectToggleAction"] }] });
88
86
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AudioDisplay, decorators: [{
89
87
  type: Component,
90
88
  args: [{ selector: 'app-audiodisplay', template: `
@@ -101,7 +99,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
101
99
  [zoomSelectedAction]="zoomSelectedAction"
102
100
  [zoomFitToPanelAction]="zoomFitToPanelAction"></audio-display-control>
103
101
  `, 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:#e6e6e6}\n", "legend{margin-left:1em;padding:.2em .8em;font-size:.8em}\n", "fieldset{border:1px darkgray solid}\n"] }]
104
- }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, propDecorators: { playStartAction: [{
102
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, propDecorators: { playStartAction: [{
105
103
  type: Input
106
104
  }], playStopAction: [{
107
105
  type: Input
@@ -117,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
117
115
  }], audioClip: [{
118
116
  type: Input
119
117
  }] } });
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audio_display.js","sourceRoot":"","sources":["../../../../../projects/speechrecorderng/src/lib/audio/audio_display.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, Selection} from './persistor'\r\nimport {ActivatedRoute} from \"@angular/router\";\r\nimport {Action} from \"../action/action\";\r\nimport {AudioDisplayScrollPane} from \"./ui/audio_display_scroll_pane\";\r\nimport {AudioDataHolder} from \"./audio_data_holder\";\r\n\r\n@Component({\r\n\r\n  selector: 'app-audiodisplay',\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]=\"autoPlayOnSelectToggleAction\"\r\n    [zoomInAction]=\"zoomInAction\"\r\n    [zoomOutAction]=\"zoomOutAction\"\r\n    [zoomSelectedAction]=\"zoomSelectedAction\"\r\n    [zoomFitToPanelAction]=\"zoomFitToPanelAction\"></audio-display-control>\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(230, 230, 230, 1.0)\r\n    }`,`\r\n          legend{\r\n              margin-left: 1em; padding: 0.2em 0.8em;font-size: 0.8em;\r\n      }`,`\r\n        fieldset{\r\n            border: 1px darkgray solid\r\n      }\r\n      `]\r\n\r\n})\r\nexport class AudioDisplay implements OnInit,AfterViewInit {\r\n\r\n  parentE: HTMLElement;\r\n  private _audioClip:AudioClip|null=null\r\n\r\n  @Input()\r\n  playStartAction: Action<void>|undefined;\r\n  @Input()\r\n  playStopAction: Action<void>|undefined;\r\n  @Input()\r\n  playSelectionAction:Action<void>|undefined;\r\n  @Input()\r\n  autoPlayOnSelectToggleAction!:Action<boolean>|undefined;\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  clearSelectionAction!:Action<void>\r\n\r\n  status: string;\r\n\r\n  audio: any;\r\n\r\n  @ViewChild(AudioDisplayScrollPane, { static: true })\r\n  audioDisplayScrollPane!: AudioDisplayScrollPane;\r\n\r\n  constructor(private route: ActivatedRoute, private ref: ChangeDetectorRef,private eRef:ElementRef) {\r\n    //console.log(\"constructor: \"+this.ac);\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\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  }\r\n\r\n  ngAfterViewInit() {\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  }\r\n\r\n\r\n  layout(){\r\n    this.audioDisplayScrollPane.layout();\r\n  }\r\n\r\n\r\n  started() {\r\n    console.log(\"Play started\");\r\n    this.status = 'Playing...';\r\n  }\r\n\r\n\r\n  @Input()\r\n  set audioData(audioData: AudioDataHolder){\r\n      this.audioDisplayScrollPane.audioData = audioData;\r\n      if(this.playStartAction) {\r\n        console.debug(\"Play start action (by AudioDisplay::set audioData) disabled: \"+(audioData==null));\r\n          this.playStartAction.disabled = (audioData == null)\r\n      }\r\n  }\r\n\r\n\r\n  @Input()\r\n  set audioClip(audioClip: AudioClip | null) {\r\n\r\n    //let audioData:AudioBuffer|null=null;\r\n    let sel:Selection|null=null;\r\n    if(audioClip){\r\n      //audioData=audioClip.audioDataHolder.buffer;\r\n      sel=audioClip.selection;\r\n      }\r\n    this._audioClip=audioClip\r\n    this.audioDisplayScrollPane.audioClip = audioClip;\r\n    //this.playStartAction.disabled = (audioData!==null)\r\n  }\r\n\r\n  get audioClip():AudioClip|null{\r\n    return this._audioClip\r\n  }\r\n\r\n  set playFramePosition(playFramePosition:number){\r\n      this.audioDisplayScrollPane.playFramePosition = playFramePosition\r\n  }\r\n\r\n  error() {\r\n    this.status = 'ERROR';\r\n  }\r\n\r\n}\r\n\r\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"audio_display.js","sourceRoot":"","sources":["../../../../../projects/speechrecorderng/src/lib/audio/audio_display.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, Selection} from './persistor'\r\nimport {Action} from \"../action/action\";\r\nimport {AudioDisplayScrollPane} from \"./ui/audio_display_scroll_pane\";\r\nimport {AudioDataHolder} from \"./audio_data_holder\";\r\n\r\n@Component({\r\n\r\n  selector: 'app-audiodisplay',\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]=\"autoPlayOnSelectToggleAction\"\r\n    [zoomInAction]=\"zoomInAction\"\r\n    [zoomOutAction]=\"zoomOutAction\"\r\n    [zoomSelectedAction]=\"zoomSelectedAction\"\r\n    [zoomFitToPanelAction]=\"zoomFitToPanelAction\"></audio-display-control>\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(230, 230, 230, 1.0)\r\n    }`,`\r\n          legend{\r\n              margin-left: 1em; padding: 0.2em 0.8em;font-size: 0.8em;\r\n      }`,`\r\n        fieldset{\r\n            border: 1px darkgray solid\r\n      }\r\n      `]\r\n\r\n})\r\nexport class AudioDisplay implements OnInit,AfterViewInit {\r\n\r\n  parentE: HTMLElement;\r\n  private _audioClip:AudioClip|null=null\r\n\r\n  @Input()\r\n  playStartAction: Action<void>|undefined;\r\n  @Input()\r\n  playStopAction: Action<void>|undefined;\r\n  @Input()\r\n  playSelectionAction:Action<void>|undefined;\r\n  @Input()\r\n  autoPlayOnSelectToggleAction!:Action<boolean>|undefined;\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  clearSelectionAction!:Action<void>\r\n\r\n  status: string;\r\n\r\n  audio: any;\r\n\r\n  @ViewChild(AudioDisplayScrollPane, { static: true })\r\n  audioDisplayScrollPane!: AudioDisplayScrollPane;\r\n\r\n  constructor(private ref: ChangeDetectorRef,private eRef:ElementRef) {\r\n    //console.log(\"constructor: \"+this.ac);\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\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  }\r\n\r\n  ngAfterViewInit() {\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  }\r\n\r\n\r\n  layout(){\r\n    this.audioDisplayScrollPane.layout();\r\n  }\r\n\r\n\r\n  started() {\r\n    console.log(\"Play started\");\r\n    this.status = 'Playing...';\r\n  }\r\n\r\n\r\n  @Input()\r\n  set audioData(audioData: AudioDataHolder){\r\n      this.audioDisplayScrollPane.audioData = audioData;\r\n      if(this.playStartAction) {\r\n        console.debug(\"Play start action (by AudioDisplay::set audioData) disabled: \"+(audioData==null));\r\n          this.playStartAction.disabled = (audioData == null)\r\n      }\r\n  }\r\n\r\n\r\n  @Input()\r\n  set audioClip(audioClip: AudioClip | null) {\r\n\r\n    //let audioData:AudioBuffer|null=null;\r\n    let sel:Selection|null=null;\r\n    if(audioClip){\r\n      //audioData=audioClip.audioDataHolder.buffer;\r\n      sel=audioClip.selection;\r\n      }\r\n    this._audioClip=audioClip\r\n    this.audioDisplayScrollPane.audioClip = audioClip;\r\n    //this.playStartAction.disabled = (audioData!==null)\r\n  }\r\n\r\n  get audioClip():AudioClip|null{\r\n    return this._audioClip\r\n  }\r\n\r\n  set playFramePosition(playFramePosition:number){\r\n      this.audioDisplayScrollPane.playFramePosition = playFramePosition\r\n  }\r\n\r\n  error() {\r\n    this.status = 'ERROR';\r\n  }\r\n\r\n}\r\n\r\n"]}
@@ -15,10 +15,8 @@ export class AudioDisplayPlayer {
15
15
  this.ref = ref;
16
16
  this.eRef = eRef;
17
17
  this._audioUrl = null;
18
- this.aCtx = null;
19
18
  this._audioClip = null;
20
19
  this.currentLoader = null;
21
- //console.log("constructor: "+this.ac);
22
20
  this.parentE = this.eRef.nativeElement;
23
21
  this.playStartAction = new Action("Start");
24
22
  this.playSelectionAction = new Action("Play selected");
@@ -26,26 +24,18 @@ export class AudioDisplayPlayer {
26
24
  this.status = "Player created.";
27
25
  }
28
26
  ngOnInit() {
29
- //console.log("OnInit: "+this.ac);
30
27
  this.zoomSelectedAction = this.audioDisplayScrollPane.zoomSelectedAction;
31
28
  this.zoomFitToPanelAction = this.audioDisplayScrollPane.zoomFitToPanelAction;
32
29
  this.zoomOutAction = this.audioDisplayScrollPane.zoomOutAction;
33
30
  this.zoomInAction = this.audioDisplayScrollPane.zoomInAction;
34
- try {
35
- this.aCtx = AudioContextProvider.audioContextInstance();
36
- if (this.aCtx) {
37
- this.ap = new AudioPlayer(this.aCtx, this);
38
- }
39
- }
40
- catch (err) {
41
- if (err instanceof Error) {
42
- this.status = err.message;
43
- }
44
- }
31
+ this.ap = new AudioPlayer(this);
45
32
  }
46
33
  ngAfterViewInit() {
47
- if (this.aCtx && this.ap) {
48
- this.playStartAction.onAction = () => this.ap?.start();
34
+ if (this.ap) {
35
+ this.playStartAction.onAction = () => {
36
+ console.debug("Start action, player: " + this.ap);
37
+ this.ap?.start();
38
+ };
49
39
  this.playSelectionAction.onAction = () => this.ap?.startSelected();
50
40
  this.playStopAction.onAction = () => this.ap?.stop();
51
41
  }
@@ -110,15 +100,12 @@ export class AudioDisplayPlayer {
110
100
  //console.debug("Loaded");
111
101
  this.status = 'Audio file loaded.';
112
102
  //console.debug("Received data ", data.byteLength);
113
- // Do not use Promise version, which does not work with Safari 13
114
- if (this.aCtx) {
115
- this.aCtx.decodeAudioData(data, (audioBuffer) => {
116
- //console.debug("Audio Buffer Samplerate: ", audioBuffer.sampleRate)
117
- let as = new AudioBufferSource(audioBuffer);
118
- let adh = new AudioDataHolder(as);
119
- this.audioClip = new AudioClip(adh);
120
- });
121
- }
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
+ });
122
109
  }
123
110
  set audioData(audioData) {
124
111
  this.audioDisplayScrollPane.audioData = audioData;
@@ -248,4 +235,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
248
235
  }], audioClip: [{
249
236
  type: Input
250
237
  }] } });
251
- //# 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, AfterContentInit, OnInit, AfterContentChecked, AfterViewChecked, 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\r\n  aCtx: AudioContext|null=null;\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\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    //console.log(\"constructor: \"+this.ac);\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\r\n  ngOnInit(){\r\n    //console.log(\"OnInit: \"+this.ac);\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     try {\r\n       this.aCtx = AudioContextProvider.audioContextInstance();\r\n       if(this.aCtx) {\r\n         this.ap = new AudioPlayer(this.aCtx, this);\r\n       }\r\n     }catch(err){\r\n       if(err instanceof Error) {\r\n         this.status = err.message;\r\n       }\r\n      }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n      if (this.aCtx && this.ap) {\r\n          this.playStartAction.onAction = () => this.ap?.start();\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    // Do not use Promise version, which does not work with Safari 13\r\n    if(this.aCtx) {\r\n      this.aCtx.decodeAudioData(data, (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"]}
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"]}