speechrecorderng 2.21.4 → 2.22.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 (111) hide show
  1. package/{esm2015/lib/action/action.js → esm2020/lib/action/action.mjs} +0 -0
  2. package/{esm2015/lib/audio/audio_display.js → esm2020/lib/audio/audio_display.mjs} +5 -5
  3. package/esm2020/lib/audio/audio_player.mjs +276 -0
  4. package/esm2020/lib/audio/capture/capture.mjs +547 -0
  5. package/{esm2015/lib/audio/context.js → esm2020/lib/audio/context.mjs} +0 -0
  6. package/esm2020/lib/audio/dsp/level_measure.mjs +351 -0
  7. package/{esm2015/lib/audio/format.js → esm2020/lib/audio/format.mjs} +0 -0
  8. package/{esm2015/lib/audio/impl/wavformat.js → esm2020/lib/audio/impl/wavformat.mjs} +0 -0
  9. package/{esm2015/lib/audio/impl/wavwriter.js → esm2020/lib/audio/impl/wavwriter.mjs} +0 -0
  10. package/{esm2015/lib/audio/io/stream.js → esm2020/lib/audio/io/stream.mjs} +0 -0
  11. package/{esm2015/lib/audio/persistor.js → esm2020/lib/audio/persistor.mjs} +0 -0
  12. package/{esm2015/lib/audio/playback/player.js → esm2020/lib/audio/playback/player.mjs} +0 -0
  13. package/esm2020/lib/audio/ui/audio_canvas_layer_comp.mjs +376 -0
  14. package/{esm2015/lib/audio/ui/audio_display_control.js → esm2020/lib/audio/ui/audio_display_control.mjs} +5 -5
  15. package/{esm2015/lib/audio/ui/audio_display_scroll_pane.js → esm2020/lib/audio/ui/audio_display_scroll_pane.mjs} +5 -5
  16. package/{esm2015/lib/audio/ui/audiosignal.js → esm2020/lib/audio/ui/audiosignal.mjs} +5 -5
  17. package/{esm2015/lib/audio/ui/common.js → esm2020/lib/audio/ui/common.mjs} +0 -0
  18. package/esm2020/lib/audio/ui/container.mjs +431 -0
  19. package/{esm2015/lib/audio/ui/livelevel.js → esm2020/lib/audio/ui/livelevel.mjs} +5 -5
  20. package/{esm2015/lib/audio/ui/scroll_pane_horizontal.js → esm2020/lib/audio/ui/scroll_pane_horizontal.mjs} +4 -4
  21. package/{esm2015/lib/audio/ui/sonagram.js → esm2020/lib/audio/ui/sonagram.mjs} +5 -5
  22. package/{esm2015/lib/dsp/utils.js → esm2020/lib/dsp/utils.mjs} +0 -0
  23. package/{esm2015/lib/io/BinaryWriter.js → esm2020/lib/io/BinaryWriter.mjs} +0 -0
  24. package/{esm2015/lib/io/stream.js → esm2020/lib/io/stream.mjs} +0 -0
  25. package/{esm2015/lib/math/2d/geometry.js → esm2020/lib/math/2d/geometry.mjs} +0 -0
  26. package/{esm2015/lib/math/complex.js → esm2020/lib/math/complex.mjs} +0 -0
  27. package/{esm2015/lib/math/dft.js → esm2020/lib/math/dft.mjs} +0 -0
  28. package/{esm2015/lib/math/utils.js → esm2020/lib/math/utils.mjs} +0 -0
  29. package/esm2020/lib/media/utils.mjs +14 -0
  30. package/esm2020/lib/net/uploader.mjs +246 -0
  31. package/{esm2015/lib/speechrecorder/project/project.js → esm2020/lib/speechrecorder/project/project.mjs} +0 -0
  32. package/{esm2015/lib/speechrecorder/project/project.service.js → esm2020/lib/speechrecorder/project/project.service.mjs} +4 -4
  33. package/esm2020/lib/speechrecorder/recording.mjs +54 -0
  34. package/esm2020/lib/speechrecorder/recordings/recordings.service.mjs +246 -0
  35. package/{esm2015/lib/speechrecorder/script/script.js → esm2020/lib/speechrecorder/script/script.mjs} +2 -2
  36. package/{esm2015/lib/speechrecorder/script/script.service.js → esm2020/lib/speechrecorder/script/script.service.mjs} +4 -4
  37. package/esm2020/lib/speechrecorder/session/audiorecorder.mjs +1144 -0
  38. package/esm2020/lib/speechrecorder/session/controlpanel.mjs +449 -0
  39. package/{esm2015/lib/speechrecorder/session/item.js → esm2020/lib/speechrecorder/session/item.mjs} +1 -1
  40. package/{esm2015/lib/speechrecorder/session/progress.js → esm2020/lib/speechrecorder/session/progress.mjs} +5 -5
  41. package/{esm2015/lib/speechrecorder/session/prompting.js → esm2020/lib/speechrecorder/session/prompting.mjs} +21 -21
  42. package/esm2020/lib/speechrecorder/session/recorder_combi_pane.mjs +75 -0
  43. package/esm2020/lib/speechrecorder/session/recording_list.mjs +109 -0
  44. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +126 -0
  45. package/{esm2015/lib/speechrecorder/session/recordingfile/recording-file-navi.component.js → esm2020/lib/speechrecorder/session/recordingfile/recording-file-navi.component.mjs} +5 -5
  46. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +168 -0
  47. package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +415 -0
  48. package/{esm2015/lib/speechrecorder/session/recordingfile/recording-file.js → esm2020/lib/speechrecorder/session/recordingfile/recording-file.mjs} +1 -1
  49. package/esm2020/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +251 -0
  50. package/{esm2015/lib/speechrecorder/session/session.js → esm2020/lib/speechrecorder/session/session.mjs} +0 -0
  51. package/{esm2015/lib/speechrecorder/session/session.service.js → esm2020/lib/speechrecorder/session/session.service.mjs} +4 -4
  52. package/{esm2015/lib/speechrecorder/session/session_finished_dialog.js → esm2020/lib/speechrecorder/session/session_finished_dialog.mjs} +4 -4
  53. package/esm2020/lib/speechrecorder/session/sessionmanager.mjs +1274 -0
  54. package/{esm2015/lib/speechrecorder/session/warning_bar.js → esm2020/lib/speechrecorder/session/warning_bar.mjs} +5 -5
  55. package/{esm2015/lib/speechrecorder/spruploader.js → esm2020/lib/speechrecorder/spruploader.mjs} +4 -4
  56. package/{esm2015/lib/speechrecorder/startstopsignal/startstopsignal.js → esm2020/lib/speechrecorder/startstopsignal/startstopsignal.mjs} +0 -0
  57. package/{esm2015/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.js → esm2020/lib/speechrecorder/startstopsignal/ui/simpletrafficlight.mjs} +5 -5
  58. package/esm2020/lib/speechrecorderng.component.mjs +427 -0
  59. package/{esm2015/lib/speechrecorderng.module.js → esm2020/lib/speechrecorderng.module.mjs} +12 -11
  60. package/{esm2015/lib/spr.config.js → esm2020/lib/spr.config.mjs} +4 -4
  61. package/{esm2015/lib/spr.module.version.js → esm2020/lib/spr.module.version.mjs} +2 -2
  62. package/{esm2015/lib/ui/canvas_layer_comp.js → esm2020/lib/ui/canvas_layer_comp.mjs} +4 -4
  63. package/{esm2015/lib/ui/message_dialog.js → esm2020/lib/ui/message_dialog.mjs} +4 -4
  64. package/{esm2015/lib/ui/recordingitem_display.js → esm2020/lib/ui/recordingitem_display.mjs} +9 -9
  65. package/{esm2015/lib/utils/css_utils.js → esm2020/lib/utils/css_utils.mjs} +0 -0
  66. package/{esm2015/lib/utils/scrollIntoViewToBottom.js → esm2020/lib/utils/scrollIntoViewToBottom.mjs} +4 -4
  67. package/{esm2015/lib/utils/ua-parser.js → esm2020/lib/utils/ua-parser.mjs} +0 -0
  68. package/{esm2015/lib/utils/utils.js → esm2020/lib/utils/utils.mjs} +0 -0
  69. package/esm2020/public-api.mjs +31 -0
  70. package/{esm2015/speechrecorderng.js → esm2020/speechrecorderng.mjs} +0 -0
  71. package/fesm2015/speechrecorderng.mjs +11991 -0
  72. package/fesm2015/speechrecorderng.mjs.map +1 -0
  73. package/{fesm2015/speechrecorderng.js → fesm2020/speechrecorderng.mjs} +1863 -285
  74. package/fesm2020/speechrecorderng.mjs.map +1 -0
  75. package/lib/media/utils.d.ts +3 -0
  76. package/lib/net/uploader.d.ts +4 -2
  77. package/lib/speechrecorder/recording.d.ts +14 -3
  78. package/lib/speechrecorder/recordings/recordings.service.d.ts +12 -5
  79. package/lib/speechrecorder/session/audiorecorder.d.ts +150 -0
  80. package/lib/speechrecorder/session/controlpanel.d.ts +2 -1
  81. package/lib/speechrecorder/session/item.d.ts +2 -2
  82. package/lib/speechrecorder/session/recorder_combi_pane.d.ts +26 -0
  83. package/lib/speechrecorder/session/recording_list.d.ts +19 -0
  84. package/lib/speechrecorder/session/recordingfile/recording-file-meta.component.d.ts +6 -2
  85. package/lib/speechrecorder/session/recordingfile/recording-file-view.component.d.ts +5 -4
  86. package/lib/speechrecorder/session/recordingfile/recording-file.d.ts +2 -2
  87. package/lib/speechrecorder/session/recordingfile/recordingfile-service.d.ts +5 -3
  88. package/lib/speechrecorder/session/sessionmanager.d.ts +5 -5
  89. package/lib/speechrecorderng.module.d.ts +31 -28
  90. package/lib/spr.module.version.d.ts +1 -1
  91. package/package.json +33 -20
  92. package/public-api.d.ts +2 -1
  93. package/bundles/speechrecorderng.umd.js +0 -10146
  94. package/bundles/speechrecorderng.umd.js.map +0 -1
  95. package/esm2015/lib/audio/audio_player.js +0 -274
  96. package/esm2015/lib/audio/capture/capture.js +0 -544
  97. package/esm2015/lib/audio/dsp/level_measure.js +0 -356
  98. package/esm2015/lib/audio/ui/audio_canvas_layer_comp.js +0 -364
  99. package/esm2015/lib/audio/ui/container.js +0 -412
  100. package/esm2015/lib/net/uploader.js +0 -220
  101. package/esm2015/lib/speechrecorder/recording.js +0 -38
  102. package/esm2015/lib/speechrecorder/recordings/recordings.service.js +0 -173
  103. package/esm2015/lib/speechrecorder/session/controlpanel.js +0 -446
  104. package/esm2015/lib/speechrecorder/session/recordingfile/recording-file-meta.component.js +0 -83
  105. package/esm2015/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.js +0 -163
  106. package/esm2015/lib/speechrecorder/session/recordingfile/recording-file-view.component.js +0 -386
  107. package/esm2015/lib/speechrecorder/session/recordingfile/recordingfile-service.js +0 -191
  108. package/esm2015/lib/speechrecorder/session/sessionmanager.js +0 -1271
  109. package/esm2015/lib/speechrecorderng.component.js +0 -423
  110. package/esm2015/public-api.js +0 -30
  111. package/fesm2015/speechrecorderng.js.map +0 -1
@@ -69,8 +69,8 @@ export class AudioDisplay {
69
69
  this.status = 'ERROR';
70
70
  }
71
71
  }
72
- AudioDisplay.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: AudioDisplay, deps: [{ token: i1.ActivatedRoute }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
73
- AudioDisplay.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", 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: `
72
+ AudioDisplay.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: AudioDisplay, deps: [{ token: i1.ActivatedRoute }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
73
+ AudioDisplay.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.1", 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: `
74
74
 
75
75
  <audio-display-scroll-pane #audioDisplayScrollPane></audio-display-scroll-pane>
76
76
 
@@ -83,8 +83,8 @@ AudioDisplay.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version:
83
83
  [zoomOutAction]="zoomOutAction"
84
84
  [zoomSelectedAction]="zoomSelectedAction"
85
85
  [zoomFitToPanelAction]="zoomFitToPanelAction"></audio-display-control>
86
- `, isInline: true, styles: [":host {\n display: flex;\n flex-direction: column;\n position: absolute;\n bottom: 0px;\n height: 100%;\n width: 100%;\n overflow: hidden;\n padding: 20px;\n z-index: 5;\n box-sizing: border-box;\n background-color: rgba(230, 230, 230, 1.0)\n }", "\n legend{\n margin-left: 1em; padding: 0.2em 0.8em;font-size: 0.8em;\n }", "\n fieldset{\n border: 1px darkgray solid\n }\n "], components: [{ type: i2.AudioDisplayScrollPane, selector: "audio-display-scroll-pane", inputs: ["audioClip"], outputs: ["zoomInAction", "zoomOutAction", "zoomSelectedAction", "zoomFitToPanelAction"] }, { type: i3.AudioDisplayControl, selector: "audio-display-control", inputs: ["audioClip", "playStartAction", "playSelectionAction", "playStopAction", "zoomInAction", "zoomOutAction", "zoomFitToPanelAction", "zoomSelectedAction", "autoPlayOnSelectToggleAction"] }] });
87
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: AudioDisplay, decorators: [{
86
+ `, isInline: true, styles: [":host{display:flex;flex-direction:column;position:absolute;bottom:0px;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"], components: [{ type: i2.AudioDisplayScrollPane, selector: "audio-display-scroll-pane", inputs: ["audioClip"], outputs: ["zoomInAction", "zoomOutAction", "zoomSelectedAction", "zoomFitToPanelAction"] }, { type: i3.AudioDisplayControl, selector: "audio-display-control", inputs: ["audioClip", "playStartAction", "playSelectionAction", "playStopAction", "zoomInAction", "zoomOutAction", "zoomFitToPanelAction", "zoomSelectedAction", "autoPlayOnSelectToggleAction"] }] });
87
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: AudioDisplay, decorators: [{
88
88
  type: Component,
89
89
  args: [{
90
90
  selector: 'app-audiodisplay',
@@ -141,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImpo
141
141
  }], audioClip: [{
142
142
  type: Input
143
143
  }] } });
144
- //# 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\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(audioBuffer: AudioBuffer){\r\n      this.audioDisplayScrollPane.audioData = audioBuffer;\r\n      if(this.playStartAction) {\r\n          this.playStartAction.disabled = (audioBuffer == null)\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.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"]}
144
+ //# 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\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(audioBuffer: AudioBuffer){\r\n      this.audioDisplayScrollPane.audioData = audioBuffer;\r\n      if(this.playStartAction) {\r\n          this.playStartAction.disabled = (audioBuffer == null)\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.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"]}
@@ -0,0 +1,276 @@
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 * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/router";
9
+ import * as i2 from "./ui/audio_display_scroll_pane";
10
+ import * as i3 from "./ui/audio_display_control";
11
+ export class AudioDisplayPlayer {
12
+ constructor(route, ref, eRef) {
13
+ this.route = route;
14
+ this.ref = ref;
15
+ this.eRef = eRef;
16
+ this._audioUrl = null;
17
+ this.aCtx = null;
18
+ this._audioClip = null;
19
+ this.currentLoader = null;
20
+ //console.log("constructor: "+this.ac);
21
+ this.parentE = this.eRef.nativeElement;
22
+ this.playStartAction = new Action("Start");
23
+ this.playSelectionAction = new Action("Play selected");
24
+ this.playStopAction = new Action("Stop");
25
+ this.status = "Player created.";
26
+ }
27
+ ngOnInit() {
28
+ //console.log("OnInit: "+this.ac);
29
+ this.zoomSelectedAction = this.audioDisplayScrollPane.zoomSelectedAction;
30
+ this.zoomFitToPanelAction = this.audioDisplayScrollPane.zoomFitToPanelAction;
31
+ this.zoomOutAction = this.audioDisplayScrollPane.zoomOutAction;
32
+ this.zoomInAction = this.audioDisplayScrollPane.zoomInAction;
33
+ try {
34
+ this.aCtx = AudioContextProvider.audioContextInstance();
35
+ if (this.aCtx) {
36
+ this.ap = new AudioPlayer(this.aCtx, this);
37
+ }
38
+ }
39
+ catch (err) {
40
+ if (err instanceof Error) {
41
+ this.status = err.message;
42
+ }
43
+ }
44
+ }
45
+ ngAfterContentInit() {
46
+ //console.log("AfterContentInit: "+this.ac);
47
+ }
48
+ ngAfterContentChecked() {
49
+ //console.log("AfterContentChecked: "+this.ac);
50
+ }
51
+ ngAfterViewInit() {
52
+ if (this.aCtx && this.ap) {
53
+ this.playStartAction.onAction = () => this.ap?.start();
54
+ this.playSelectionAction.onAction = () => this.ap?.startSelected();
55
+ this.playStopAction.onAction = () => this.ap?.stop();
56
+ }
57
+ this.layout();
58
+ let heightListener = new MutationObserver((mrs, mo) => {
59
+ mrs.forEach((mr) => {
60
+ if ('attributes' === mr.type && ('class' === mr.attributeName || 'style' === mr.attributeName)) {
61
+ this.layout();
62
+ }
63
+ });
64
+ });
65
+ heightListener.observe(this.parentE, { attributes: true, childList: true, characterData: true });
66
+ this.route.queryParams.subscribe((params) => {
67
+ if (params['url']) {
68
+ this.audioUrl = params['url'];
69
+ }
70
+ });
71
+ }
72
+ ngAfterViewChecked() {
73
+ //console.log("AfterViewChecked: "+this.ac);
74
+ }
75
+ init() {
76
+ }
77
+ layout() {
78
+ this.audioDisplayScrollPane.layout();
79
+ }
80
+ get audioUrl() {
81
+ return this._audioUrl;
82
+ }
83
+ set audioUrl(value) {
84
+ if (this.ap) {
85
+ this.ap.stop();
86
+ }
87
+ this._audioUrl = value;
88
+ this.load();
89
+ }
90
+ started() {
91
+ //console.debug("Play started");
92
+ this.status = 'Playing...';
93
+ }
94
+ load() {
95
+ if (this.currentLoader) {
96
+ this.currentLoader.abort();
97
+ this.currentLoader = null;
98
+ }
99
+ if (this._audioUrl) {
100
+ //this.statusMsg.innerHTML = 'Connecting...';
101
+ this.currentLoader = new XMLHttpRequest();
102
+ this.currentLoader.open("GET", this._audioUrl, true);
103
+ this.currentLoader.responseType = "arraybuffer";
104
+ this.currentLoader.onload = (e) => {
105
+ if (this.currentLoader) {
106
+ var data = this.currentLoader.response; // not responseText
107
+ //console.debug("Received data ", data.byteLength);
108
+ this.currentLoader = null;
109
+ this.loaded(data);
110
+ }
111
+ };
112
+ this.currentLoader.onerror = (e) => {
113
+ console.error("Error downloading ...");
114
+ //this.statusMsg.innerHTML = 'Error loading audio file!';
115
+ this.currentLoader = null;
116
+ };
117
+ //this.statusMsg.innerHTML = 'Loading...';
118
+ this.currentLoader.send();
119
+ }
120
+ }
121
+ loaded(data) {
122
+ //console.debug("Loaded");
123
+ this.status = 'Audio file loaded.';
124
+ //console.debug("Received data ", data.byteLength);
125
+ // Do not use Promise version, which does not work with Safari 13
126
+ if (this.aCtx) {
127
+ this.aCtx.decodeAudioData(data, (audioBuffer) => {
128
+ //console.debug("Audio Buffer Samplerate: ", audioBuffer.sampleRate)
129
+ this.audioClip = new AudioClip(audioBuffer);
130
+ });
131
+ }
132
+ }
133
+ set audioData(audioBuffer) {
134
+ this.audioDisplayScrollPane.audioData = audioBuffer;
135
+ if (audioBuffer) {
136
+ let clip = new AudioClip(audioBuffer);
137
+ if (this.ap) {
138
+ this.ap.audioClip = clip;
139
+ this.playStartAction.disabled = false;
140
+ }
141
+ }
142
+ else {
143
+ this.playStartAction.disabled = true;
144
+ if (this.ap) {
145
+ this.ap.audioClip = null;
146
+ }
147
+ }
148
+ this.playSelectionAction.disabled = true;
149
+ }
150
+ startSelectionDisabled() {
151
+ return !(this._audioClip && this.ap != null && !this.playStartAction.disabled && this._audioClip.selection);
152
+ }
153
+ set audioClip(audioClip) {
154
+ this._audioClip = audioClip;
155
+ let audioData = null;
156
+ let sel = null;
157
+ if (audioClip) {
158
+ audioData = audioClip.buffer;
159
+ sel = audioClip.selection;
160
+ if (this._audioClip) {
161
+ this._audioClip.addSelectionObserver((ac) => {
162
+ this.playSelectionAction.disabled = this.startSelectionDisabled();
163
+ // if(this.ap && ac.selection && this.autoplaySelectedCheckbox.checked){
164
+ // this.ap.startSelected()
165
+ // }
166
+ });
167
+ }
168
+ }
169
+ if (audioData) {
170
+ this.playStartAction.disabled = (!this.ap);
171
+ this.playSelectionAction.disabled = this.startSelectionDisabled();
172
+ }
173
+ else {
174
+ this.playStartAction.disabled = true;
175
+ this.playSelectionAction.disabled = true;
176
+ }
177
+ this.audioDisplayScrollPane.audioClip = audioClip;
178
+ if (this.ap) {
179
+ this.ap.audioClip = audioClip;
180
+ }
181
+ }
182
+ get audioClip() {
183
+ return this._audioClip;
184
+ }
185
+ updatePlayPosition() {
186
+ if (this.ap && this.ap.playPositionFrames) {
187
+ this.audioDisplayScrollPane.playFramePosition = this.ap.playPositionFrames;
188
+ }
189
+ }
190
+ audioPlayerUpdate(e) {
191
+ if (EventType.STARTED === e.type) {
192
+ this.status = 'Playback...';
193
+ this.updateTimerId = window.setInterval(() => this.updatePlayPosition(), 50);
194
+ this.playStartAction.disabled = true;
195
+ this.playSelectionAction.disabled = true;
196
+ this.playStopAction.disabled = false;
197
+ }
198
+ else if (EventType.ENDED === e.type) {
199
+ this.status = 'Ready.';
200
+ window.clearInterval(this.updateTimerId);
201
+ this.playStartAction.disabled = false;
202
+ this.playSelectionAction.disabled = this.startSelectionDisabled();
203
+ this.playStopAction.disabled = true;
204
+ }
205
+ this.ref.detectChanges();
206
+ }
207
+ error() {
208
+ this.status = 'ERROR';
209
+ }
210
+ }
211
+ AudioDisplayPlayer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: AudioDisplayPlayer, deps: [{ token: i1.ActivatedRoute }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
212
+ AudioDisplayPlayer.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.1", 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: `
213
+
214
+ <audio-display-scroll-pane #audioDisplayScrollPane></audio-display-scroll-pane>
215
+
216
+ <audio-display-control [audioClip]="audioClip"
217
+ [playStartAction]="playStartAction"
218
+ [playSelectionAction]="playSelectionAction"
219
+ [playStopAction]="playStopAction"
220
+ [autoPlayOnSelectToggleAction]="ap?.autoPlayOnSelectToggleAction"
221
+ [zoomInAction]="zoomInAction"
222
+ [zoomOutAction]="zoomOutAction"
223
+ [zoomSelectedAction]="zoomSelectedAction"
224
+ [zoomFitToPanelAction]="zoomFitToPanelAction"></audio-display-control><p>{{status}}
225
+ `, isInline: true, styles: [":host{display:flex;flex-direction:column;position:absolute;bottom:0px;height:100%;width:100%;overflow:hidden;padding:20px;z-index:5;box-sizing:border-box;background-color:#000000bf}\n"], components: [{ type: i2.AudioDisplayScrollPane, selector: "audio-display-scroll-pane", inputs: ["audioClip"], outputs: ["zoomInAction", "zoomOutAction", "zoomSelectedAction", "zoomFitToPanelAction"] }, { type: i3.AudioDisplayControl, selector: "audio-display-control", inputs: ["audioClip", "playStartAction", "playSelectionAction", "playStopAction", "zoomInAction", "zoomOutAction", "zoomFitToPanelAction", "zoomSelectedAction", "autoPlayOnSelectToggleAction"] }] });
226
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: AudioDisplayPlayer, decorators: [{
227
+ type: Component,
228
+ args: [{
229
+ selector: 'app-audiodisplayplayer',
230
+ template: `
231
+
232
+ <audio-display-scroll-pane #audioDisplayScrollPane></audio-display-scroll-pane>
233
+
234
+ <audio-display-control [audioClip]="audioClip"
235
+ [playStartAction]="playStartAction"
236
+ [playSelectionAction]="playSelectionAction"
237
+ [playStopAction]="playStopAction"
238
+ [autoPlayOnSelectToggleAction]="ap?.autoPlayOnSelectToggleAction"
239
+ [zoomInAction]="zoomInAction"
240
+ [zoomOutAction]="zoomOutAction"
241
+ [zoomSelectedAction]="zoomSelectedAction"
242
+ [zoomFitToPanelAction]="zoomFitToPanelAction"></audio-display-control><p>{{status}}
243
+ `,
244
+ styles: [
245
+ `:host {
246
+ display: flex;
247
+ flex-direction: column;
248
+ position: absolute;
249
+ bottom: 0px;
250
+ height: 100%;
251
+ width: 100%;
252
+ overflow: hidden;
253
+ padding: 20px;
254
+ z-index: 5;
255
+ box-sizing: border-box;
256
+ background-color: rgba(0, 0, 0, 0.75)
257
+ }`
258
+ ]
259
+ }]
260
+ }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, propDecorators: { playStartAction: [{
261
+ type: Input
262
+ }], playStopAction: [{
263
+ type: Input
264
+ }], playSelectionAction: [{
265
+ type: Input
266
+ }], autoPlayOnSelectToggleAction: [{
267
+ type: Input
268
+ }], audioDisplayScrollPane: [{
269
+ type: ViewChild,
270
+ args: [AudioDisplayScrollPane, { static: true }]
271
+ }], audioData: [{
272
+ type: Input
273
+ }], audioClip: [{
274
+ type: Input
275
+ }] } });
276
+ //# 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, Selection} 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\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,AfterContentInit,AfterContentChecked,AfterViewInit,AfterViewChecked {\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  ngAfterContentInit(){\r\n    //console.log(\"AfterContentInit: \"+this.ac);\r\n  }\r\n\r\n  ngAfterContentChecked(){\r\n    //console.log(\"AfterContentChecked: \"+this.ac);\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\r\n  ngAfterViewChecked(){\r\n    //console.log(\"AfterViewChecked: \"+this.ac);\r\n  }\r\n\r\n\r\n  init() {\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.statusMsg.innerHTML = 'Error loading audio file!';\r\n        this.currentLoader = null;\r\n      }\r\n      //this.statusMsg.innerHTML = 'Loading...';\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        this.audioClip = new AudioClip(audioBuffer)\r\n      });\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  set audioData(audioBuffer: AudioBuffer){\r\n      this.audioDisplayScrollPane.audioData = audioBuffer;\r\n      if(audioBuffer) {\r\n          let clip = new AudioClip(audioBuffer);\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:AudioBuffer|null=null;\r\n    let sel:Selection|null=null;\r\n    if(audioClip){\r\n      audioData=audioClip.buffer;\r\n      sel=audioClip.selection;\r\n      if(this._audioClip) {\r\n        this._audioClip.addSelectionObserver((ac) => {\r\n\r\n          this.playSelectionAction.disabled = this.startSelectionDisabled()\r\n          // if(this.ap && ac.selection && this.autoplaySelectedCheckbox.checked){\r\n          //   this.ap.startSelected()\r\n          // }\r\n\r\n        })\r\n      }\r\n    }\r\n    if(audioData) {\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    }\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"]}