speechrecorderng 2.22.3 → 2.23.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.
- package/esm2020/lib/speechrecorder/script/script.mjs +1 -1
- package/esm2020/lib/speechrecorder/session/audiorecorder.mjs +12 -272
- package/esm2020/lib/speechrecorder/session/basicrecorder.mjs +283 -0
- package/esm2020/lib/speechrecorder/session/controlpanel.mjs +6 -3
- package/esm2020/lib/speechrecorder/session/prompting.mjs +5 -5
- package/esm2020/lib/speechrecorder/session/sessionmanager.mjs +12 -279
- package/esm2020/lib/spr.module.version.mjs +2 -2
- package/esm2020/lib/ui/recordingitem_display.mjs +6 -3
- package/fesm2015/speechrecorderng.mjs +5149 -5386
- package/fesm2015/speechrecorderng.mjs.map +1 -1
- package/fesm2020/speechrecorderng.mjs +5045 -5282
- package/fesm2020/speechrecorderng.mjs.map +1 -1
- package/lib/speechrecorder/script/script.d.ts +1 -1
- package/lib/speechrecorder/session/audiorecorder.d.ts +5 -46
- package/lib/speechrecorder/session/basicrecorder.d.ts +57 -0
- package/lib/speechrecorder/session/sessionmanager.d.ts +4 -48
- package/lib/spr.module.version.d.ts +1 -1
- package/package.json +1 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export const VERSION = '2.
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export const VERSION = '2.23.0';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ByLm1vZHVsZS52ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL3Nwci5tb2R1bGUudmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUMsUUFBUSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFZFUlNJT049JzIuMjMuMCciXX0=
|
|
@@ -85,7 +85,7 @@ RecordingItemControls.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0",
|
|
|
85
85
|
<div style="min-width: 14ch;padding:2px"><table style="border-style: none"><tr><td>Peak:</td><td><span matTooltip="Peak level"
|
|
86
86
|
[style.color]="(peakDbLvl > warnDbLevel)?'red':'black'">{{peakDbLvl | number:'1.1-1'}} dB </span></td></tr>
|
|
87
87
|
<tr *ngIf="_agc"><td>AGC:</td><td><span matTooltip="Auto gain control">{{agcString}}</span></td></tr></table></div>
|
|
88
|
-
`, isInline: true, styles: [":host{flex:0;width:100%;background:darkgray;padding:4px;box-sizing:border-box;height:100%;display:flex;flex-direction:row;flex-wrap:nowrap}\n", "span{flex:0;font-weight:700;display:inline-block;white-space:nowrap;box-sizing:border-box}\n"], components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i3.DefaultShowHideDirective, selector: " [fxShow], [fxShow.print], [fxShow.xs], [fxShow.sm], [fxShow.md], [fxShow.lg], [fxShow.xl], [fxShow.lt-sm], [fxShow.lt-md], [fxShow.lt-lg], [fxShow.lt-xl], [fxShow.gt-xs], [fxShow.gt-sm], [fxShow.gt-md], [fxShow.gt-lg], [fxHide], [fxHide.print], [fxHide.xs], [fxHide.sm], [fxHide.md], [fxHide.lg], [fxHide.xl], [fxHide.lt-sm], [fxHide.lt-md], [fxHide.lt-lg], [fxHide.lt-xl], [fxHide.gt-xs], [fxHide.gt-sm], [fxHide.gt-md], [fxHide.gt-lg]", inputs: ["fxShow", "fxShow.print", "fxShow.xs", "fxShow.sm", "fxShow.md", "fxShow.lg", "fxShow.xl", "fxShow.lt-sm", "fxShow.lt-md", "fxShow.lt-lg", "fxShow.lt-xl", "fxShow.gt-xs", "fxShow.gt-sm", "fxShow.gt-md", "fxShow.gt-lg", "fxHide", "fxHide.print", "fxHide.xs", "fxHide.sm", "fxHide.md", "fxHide.lg", "fxHide.xl", "fxHide.lt-sm", "fxHide.lt-md", "fxHide.lt-lg", "fxHide.lt-xl", "fxHide.gt-xs", "fxHide.gt-sm", "fxHide.gt-md", "fxHide.gt-lg"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "number": i4.DecimalPipe } });
|
|
88
|
+
`, isInline: true, styles: [":host{flex:0;width:100%;background:darkgray;padding:4px;box-sizing:border-box;height:100%;display:flex;flex-direction:row;flex-wrap:nowrap}\n", "span{flex:0;font-weight:700;display:inline-block;white-space:nowrap;box-sizing:border-box}\n", "button{touch-action:manipulation}\n"], components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i3.DefaultShowHideDirective, selector: " [fxShow], [fxShow.print], [fxShow.xs], [fxShow.sm], [fxShow.md], [fxShow.lg], [fxShow.xl], [fxShow.lt-sm], [fxShow.lt-md], [fxShow.lt-lg], [fxShow.lt-xl], [fxShow.gt-xs], [fxShow.gt-sm], [fxShow.gt-md], [fxShow.gt-lg], [fxHide], [fxHide.print], [fxHide.xs], [fxHide.sm], [fxHide.md], [fxHide.lg], [fxHide.xl], [fxHide.lt-sm], [fxHide.lt-md], [fxHide.lt-lg], [fxHide.lt-xl], [fxHide.gt-xs], [fxHide.gt-sm], [fxHide.gt-md], [fxHide.gt-lg]", inputs: ["fxShow", "fxShow.print", "fxShow.xs", "fxShow.sm", "fxShow.md", "fxShow.lg", "fxShow.xl", "fxShow.lt-sm", "fxShow.lt-md", "fxShow.lt-lg", "fxShow.lt-xl", "fxShow.gt-xs", "fxShow.gt-sm", "fxShow.gt-md", "fxShow.gt-lg", "fxHide", "fxHide.print", "fxHide.xs", "fxHide.sm", "fxHide.md", "fxHide.lg", "fxHide.xl", "fxHide.lt-sm", "fxHide.lt-md", "fxHide.lt-lg", "fxHide.lt-xl", "fxHide.gt-xs", "fxHide.gt-sm", "fxHide.gt-md", "fxHide.gt-lg"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "number": i4.DecimalPipe } });
|
|
89
89
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: RecordingItemControls, decorators: [{
|
|
90
90
|
type: Component,
|
|
91
91
|
args: [{
|
|
@@ -130,7 +130,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
|
|
|
130
130
|
display: inline-block;
|
|
131
131
|
white-space: nowrap;
|
|
132
132
|
box-sizing: border-box;
|
|
133
|
-
}`
|
|
133
|
+
}`, `
|
|
134
|
+
button {
|
|
135
|
+
touch-action: manipulation;
|
|
136
|
+
}`]
|
|
134
137
|
}]
|
|
135
138
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { audioSignalCollapsed: [{
|
|
136
139
|
type: Input
|
|
@@ -276,4 +279,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
|
|
|
276
279
|
}], displayLevelInfos: [{
|
|
277
280
|
type: Input
|
|
278
281
|
}] } });
|
|
279
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recordingitem_display.js","sourceRoot":"","sources":["../../../../../projects/speechrecorderng/src/lib/ui/recordingitem_display.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, OnDestroy, Output,\r\n    ViewChild\r\n} from \"@angular/core\"\r\nimport {LevelInfo, LevelInfos, LevelListener} from \"../audio/dsp/level_measure\";\r\nimport {LevelBar} from \"../audio/ui/livelevel\";\r\nimport {Action} from \"../action/action\";\r\n\r\n\r\nexport const MIN_DB_LEVEL = -40.0;\r\nexport const DEFAULT_WARN_DB_LEVEL = -2;\r\n\r\n@Component({\r\n  selector: 'spr-recordingitemcontrols',\r\n  template: `\r\n        <button matTooltip=\"Start playback\" (click)=\"playStartAction?.perform()\"\r\n                [disabled]=\"playStartAction?.disabled\"\r\n                [style.color]=\"playStartAction?.disabled ? 'grey' : 'green'\">\r\n            <mat-icon>play_arrow</mat-icon>\r\n        </button>\r\n        <button matTooltip=\"Stop playback\" (click)=\"playStopAction?.perform()\"\r\n                [disabled]=\"playStopAction?.disabled\"\r\n                [style.color]=\"playStopAction?.disabled ? 'grey' : 'yellow'\">\r\n            <mat-icon>stop</mat-icon>\r\n        </button>\r\n        <button fxHide.xs matTooltip=\"Toggle detailed audio display\" [disabled]=\"!audioLoaded\"\r\n                (click)=\"showRecordingDetails()\">\r\n            <mat-icon>{{(audioSignalCollapsed) ? \"expand_less\" : \"expand_more\"}}</mat-icon>\r\n        </button>\r\n        <button matTooltip=\"Download current recording\" *ngIf=\"enableDownload\" [disabled]=\"!audioLoaded\"\r\n                (click)=\"downloadRecording()\">\r\n            <mat-icon>file_download</mat-icon>\r\n        </button>\r\n        <div style=\"min-width: 14ch;padding:2px\"><table style=\"border-style: none\"><tr><td>Peak:</td><td><span matTooltip=\"Peak level\"\r\n                                                                        [style.color]=\"(peakDbLvl > warnDbLevel)?'red':'black'\">{{peakDbLvl | number:'1.1-1'}} dB </span></td></tr>\r\n          <tr *ngIf=\"_agc\"><td>AGC:</td><td><span matTooltip=\"Auto gain control\">{{agcString}}</span></td></tr></table></div>\r\n    `,\r\n  styles: [`:host {\r\n        flex: 0; /* only required vertical space */\r\n        width: 100%;\r\n        background: darkgray;\r\n        padding: 4px;\r\n        box-sizing: border-box;\r\n        height: 100%;\r\n\r\n        display: flex; /* flex container: left level bar, right decimal peak level value */\r\n        flex-direction: row;\r\n        flex-wrap: nowrap; /* wrap could completely destroy the layout */\r\n    }`, `span {\r\n        flex: 0;\r\n        font-weight: bold;\r\n        display: inline-block;\r\n        white-space: nowrap;\r\n        box-sizing: border-box;\r\n    }`]\r\n\r\n})\r\nexport class RecordingItemControls implements OnDestroy {\r\n\r\n  ce: HTMLDivElement|null=null;\r\n  @Input() audioSignalCollapsed: boolean=true;\r\n  private _displayAudioBuffer: AudioBuffer | null|undefined;\r\n  @Input() enableDownload: boolean=false;\r\n\r\n  @Input() peakDbLvl = MIN_DB_LEVEL;\r\n\r\n  _displayLevelInfos: LevelInfos | null=null;\r\n\r\n  _agc:boolean|null|undefined=undefined;\r\n  agcString='n/a';\r\n\r\n  @Input() set agc(agc:boolean|null|undefined){\r\n    this._agc=agc;\r\n    if(this._agc===undefined || this._agc===null){\r\n      this.agcString='n/a';\r\n    }else{\r\n      if(this._agc===true){\r\n        this.agcString='On';\r\n      }else{\r\n        this.agcString='Off';\r\n      }\r\n    }\r\n  }\r\n\r\n  @Output() onShowRecordingDetails: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() onDownloadRecording: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Input() audioLoaded=false;\r\n  //@Input() controlAudioPlayer: AudioPlayer;\r\n  @Input() playStartAction:Action<void>|undefined;\r\n  @Input() playStopAction:Action<void>|undefined;\r\n  playStartEnabled = false;\r\n  playStopEnabled = false;\r\n  private updateTimerId: number|null=null;\r\n\r\n  private destroyed = false;\r\n\r\n  warnDbLevel = DEFAULT_WARN_DB_LEVEL;\r\n\r\n  constructor(private ref: ElementRef, private changeDetectorRef: ChangeDetectorRef) {\r\n\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroyed = true;\r\n  }\r\n\r\n  showRecordingDetails() {\r\n    this.onShowRecordingDetails.emit();\r\n  }\r\n\r\n  downloadRecording() {\r\n    this.onDownloadRecording.emit();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.ce = this.ref.nativeElement;\r\n  }\r\n\r\n  @Input()\r\n  set displayLevelInfos(levelInfos: LevelInfos | null) {\r\n    this._displayLevelInfos = levelInfos;\r\n  }\r\n\r\n  error() {\r\n    // this.status = 'ERROR';\r\n  }\r\n\r\n}\r\n\r\n\r\n@Component({\r\n    selector: 'spr-recordingitemdisplay',\r\n    template: `\r\n      <div fxLayout=\"row\" fxLayout.xs=\"column\" [ngStyle]=\"{'height.px':100,'min-height.px': 100}\" [ngStyle.xs]=\"{'height.px':125,'min-height.px': 125}\">\r\n        <audio-levelbar fxFlex=\"1 0 1\" [streamingMode]=\"streamingMode\" [displayLevelInfos]=\"_displayLevelInfos\"></audio-levelbar>\r\n        <spr-recordingitemcontrols fxFlex=\"0 0 0\" [audioLoaded]=\"displayAudioBuffer!==null\" [playStartAction]=\"playStartAction\" [playStopAction]=\"playStopAction\" [peakDbLvl]=\"peakDbLvl\" [agc]=\"_agc\" (onShowRecordingDetails)=\"onShowRecordingDetails.emit()\"></spr-recordingitemcontrols>\r\n      </div>\r\n    `,\r\n    styles: [`div {\r\n        width: 100%;\r\n        background: darkgray;\r\n        padding: 4px;\r\n        box-sizing: border-box;\r\n        flex-wrap: nowrap; /* wrap could completely destroy the layout */\r\n    }`, `audio-levelbar {\r\n        box-sizing: border-box;\r\n    }`]\r\n\r\n})\r\nexport class RecordingItemDisplay implements LevelListener, OnDestroy {\r\n\r\n    ce: HTMLDivElement|null=null;\r\n    @ViewChild(LevelBar, { static: true }) liveLevel!: LevelBar;\r\n    @Input() streamingMode: boolean=false;\r\n    @Input() audioSignalCollapsed: boolean=true;\r\n    private _displayAudioBuffer: AudioBuffer | null|undefined;\r\n    @Input() enableDownload: boolean=false;\r\n\r\n    peakDbLvl = MIN_DB_LEVEL;\r\n\r\n    _displayLevelInfos: LevelInfos | null=null;\r\n\r\n    _agc:boolean|null|undefined=undefined;\r\n    agcString='n/a';\r\n\r\n    @Input() set agc(agc:boolean|null|undefined){\r\n      this._agc=agc;\r\n    }\r\n\r\n    @Output() onShowRecordingDetails: EventEmitter<void> = new EventEmitter<void>();\r\n    @Output() onDownloadRecording: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    //@Input() controlAudioPlayer: AudioPlayer;\r\n    @Input() playStartAction:Action<void>|undefined;\r\n    @Input() playStopAction:Action<void>|undefined;\r\n    playStartEnabled = false;\r\n    playStopEnabled = false;\r\n    private updateTimerId: number|null=null;\r\n\r\n    private destroyed = false;\r\n\r\n    warnDbLevel = DEFAULT_WARN_DB_LEVEL;\r\n\r\n    constructor(private ref: ElementRef, private changeDetectorRef: ChangeDetectorRef) {\r\n\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.destroyed = true;\r\n    }\r\n\r\n\r\n    @Input()\r\n    set displayAudioBuffer(displayAudioBuffer: AudioBuffer | null| undefined) {\r\n        this._displayAudioBuffer = displayAudioBuffer;\r\n    }\r\n\r\n    get displayAudioBuffer() {\r\n        return this._displayAudioBuffer;\r\n    }\r\n\r\n    showRecordingDetails() {\r\n        this.onShowRecordingDetails.emit();\r\n    }\r\n\r\n    downloadRecording() {\r\n        this.onDownloadRecording.emit();\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        this.ce = this.ref.nativeElement;\r\n        //this.controlAudioPlayer.listener=this;\r\n    }\r\n\r\n    @Input()\r\n    set displayLevelInfos(levelInfos: LevelInfos | null) {\r\n        this._displayLevelInfos = levelInfos;\r\n    }\r\n\r\n    set channelCount(channelCount: number) {\r\n        this.reset();\r\n        this.liveLevel.channelCount = channelCount;\r\n    }\r\n\r\n  set playFramePosition(playFramePosition: number) {\r\n    this.liveLevel.playFramePosition=playFramePosition;\r\n  }\r\n\r\n    update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo) {\r\n        let peakDBVal = levelInfo.powerLevelDB();\r\n        if (this.peakDbLvl < peakDBVal) {\r\n            this.peakDbLvl = peakDBVal;\r\n            // the event comes from outside of an Angular zone\r\n            this.changeDetectorRef.detectChanges();\r\n        }\r\n        this.liveLevel.update(levelInfo);\r\n    }\r\n\r\n    error() {\r\n        // this.status = 'ERROR';\r\n    }\r\n\r\n    streamFinished() {\r\n        this.liveLevel.streamFinished();\r\n    }\r\n\r\n    reset() {\r\n        this.peakDbLvl = MIN_DB_LEVEL;\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n\r\n}\r\n"]}
|
|
282
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recordingitem_display.js","sourceRoot":"","sources":["../../../../../projects/speechrecorderng/src/lib/ui/recordingitem_display.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, OnDestroy, Output,\r\n    ViewChild\r\n} from \"@angular/core\"\r\nimport {LevelInfo, LevelInfos, LevelListener} from \"../audio/dsp/level_measure\";\r\nimport {LevelBar} from \"../audio/ui/livelevel\";\r\nimport {Action} from \"../action/action\";\r\n\r\n\r\nexport const MIN_DB_LEVEL = -40.0;\r\nexport const DEFAULT_WARN_DB_LEVEL = -2;\r\n\r\n@Component({\r\n  selector: 'spr-recordingitemcontrols',\r\n  template: `\r\n        <button matTooltip=\"Start playback\" (click)=\"playStartAction?.perform()\"\r\n                [disabled]=\"playStartAction?.disabled\"\r\n                [style.color]=\"playStartAction?.disabled ? 'grey' : 'green'\">\r\n            <mat-icon>play_arrow</mat-icon>\r\n        </button>\r\n        <button matTooltip=\"Stop playback\" (click)=\"playStopAction?.perform()\"\r\n                [disabled]=\"playStopAction?.disabled\"\r\n                [style.color]=\"playStopAction?.disabled ? 'grey' : 'yellow'\">\r\n            <mat-icon>stop</mat-icon>\r\n        </button>\r\n        <button fxHide.xs matTooltip=\"Toggle detailed audio display\" [disabled]=\"!audioLoaded\"\r\n                (click)=\"showRecordingDetails()\">\r\n            <mat-icon>{{(audioSignalCollapsed) ? \"expand_less\" : \"expand_more\"}}</mat-icon>\r\n        </button>\r\n        <button matTooltip=\"Download current recording\" *ngIf=\"enableDownload\" [disabled]=\"!audioLoaded\"\r\n                (click)=\"downloadRecording()\">\r\n            <mat-icon>file_download</mat-icon>\r\n        </button>\r\n        <div style=\"min-width: 14ch;padding:2px\"><table style=\"border-style: none\"><tr><td>Peak:</td><td><span matTooltip=\"Peak level\"\r\n                                                                        [style.color]=\"(peakDbLvl > warnDbLevel)?'red':'black'\">{{peakDbLvl | number:'1.1-1'}} dB </span></td></tr>\r\n          <tr *ngIf=\"_agc\"><td>AGC:</td><td><span matTooltip=\"Auto gain control\">{{agcString}}</span></td></tr></table></div>\r\n    `,\r\n  styles: [`:host {\r\n        flex: 0; /* only required vertical space */\r\n        width: 100%;\r\n        background: darkgray;\r\n        padding: 4px;\r\n        box-sizing: border-box;\r\n        height: 100%;\r\n\r\n        display: flex; /* flex container: left level bar, right decimal peak level value */\r\n        flex-direction: row;\r\n        flex-wrap: nowrap; /* wrap could completely destroy the layout */\r\n    }`, `span {\r\n        flex: 0;\r\n        font-weight: bold;\r\n        display: inline-block;\r\n        white-space: nowrap;\r\n        box-sizing: border-box;\r\n    }`,`\r\n     button {\r\n       touch-action: manipulation;\r\n     }`]\r\n\r\n})\r\nexport class RecordingItemControls implements OnDestroy {\r\n\r\n  ce: HTMLDivElement|null=null;\r\n  @Input() audioSignalCollapsed: boolean=true;\r\n  private _displayAudioBuffer: AudioBuffer | null|undefined;\r\n  @Input() enableDownload: boolean=false;\r\n\r\n  @Input() peakDbLvl = MIN_DB_LEVEL;\r\n\r\n  _displayLevelInfos: LevelInfos | null=null;\r\n\r\n  _agc:boolean|null|undefined=undefined;\r\n  agcString='n/a';\r\n\r\n  @Input() set agc(agc:boolean|null|undefined){\r\n    this._agc=agc;\r\n    if(this._agc===undefined || this._agc===null){\r\n      this.agcString='n/a';\r\n    }else{\r\n      if(this._agc===true){\r\n        this.agcString='On';\r\n      }else{\r\n        this.agcString='Off';\r\n      }\r\n    }\r\n  }\r\n\r\n  @Output() onShowRecordingDetails: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() onDownloadRecording: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Input() audioLoaded=false;\r\n  //@Input() controlAudioPlayer: AudioPlayer;\r\n  @Input() playStartAction:Action<void>|undefined;\r\n  @Input() playStopAction:Action<void>|undefined;\r\n  playStartEnabled = false;\r\n  playStopEnabled = false;\r\n  private updateTimerId: number|null=null;\r\n\r\n  private destroyed = false;\r\n\r\n  warnDbLevel = DEFAULT_WARN_DB_LEVEL;\r\n\r\n  constructor(private ref: ElementRef, private changeDetectorRef: ChangeDetectorRef) {\r\n\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroyed = true;\r\n  }\r\n\r\n  showRecordingDetails() {\r\n    this.onShowRecordingDetails.emit();\r\n  }\r\n\r\n  downloadRecording() {\r\n    this.onDownloadRecording.emit();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.ce = this.ref.nativeElement;\r\n  }\r\n\r\n  @Input()\r\n  set displayLevelInfos(levelInfos: LevelInfos | null) {\r\n    this._displayLevelInfos = levelInfos;\r\n  }\r\n\r\n  error() {\r\n    // this.status = 'ERROR';\r\n  }\r\n\r\n}\r\n\r\n\r\n@Component({\r\n    selector: 'spr-recordingitemdisplay',\r\n    template: `\r\n      <div fxLayout=\"row\" fxLayout.xs=\"column\" [ngStyle]=\"{'height.px':100,'min-height.px': 100}\" [ngStyle.xs]=\"{'height.px':125,'min-height.px': 125}\">\r\n        <audio-levelbar fxFlex=\"1 0 1\" [streamingMode]=\"streamingMode\" [displayLevelInfos]=\"_displayLevelInfos\"></audio-levelbar>\r\n        <spr-recordingitemcontrols fxFlex=\"0 0 0\" [audioLoaded]=\"displayAudioBuffer!==null\" [playStartAction]=\"playStartAction\" [playStopAction]=\"playStopAction\" [peakDbLvl]=\"peakDbLvl\" [agc]=\"_agc\" (onShowRecordingDetails)=\"onShowRecordingDetails.emit()\"></spr-recordingitemcontrols>\r\n      </div>\r\n    `,\r\n    styles: [`div {\r\n        width: 100%;\r\n        background: darkgray;\r\n        padding: 4px;\r\n        box-sizing: border-box;\r\n        flex-wrap: nowrap; /* wrap could completely destroy the layout */\r\n    }`, `audio-levelbar {\r\n        box-sizing: border-box;\r\n    }`]\r\n\r\n})\r\nexport class RecordingItemDisplay implements LevelListener, OnDestroy {\r\n\r\n    ce: HTMLDivElement|null=null;\r\n    @ViewChild(LevelBar, { static: true }) liveLevel!: LevelBar;\r\n    @Input() streamingMode: boolean=false;\r\n    @Input() audioSignalCollapsed: boolean=true;\r\n    private _displayAudioBuffer: AudioBuffer | null|undefined;\r\n    @Input() enableDownload: boolean=false;\r\n\r\n    peakDbLvl = MIN_DB_LEVEL;\r\n\r\n    _displayLevelInfos: LevelInfos | null=null;\r\n\r\n    _agc:boolean|null|undefined=undefined;\r\n    agcString='n/a';\r\n\r\n    @Input() set agc(agc:boolean|null|undefined){\r\n      this._agc=agc;\r\n    }\r\n\r\n    @Output() onShowRecordingDetails: EventEmitter<void> = new EventEmitter<void>();\r\n    @Output() onDownloadRecording: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    //@Input() controlAudioPlayer: AudioPlayer;\r\n    @Input() playStartAction:Action<void>|undefined;\r\n    @Input() playStopAction:Action<void>|undefined;\r\n    playStartEnabled = false;\r\n    playStopEnabled = false;\r\n    private updateTimerId: number|null=null;\r\n\r\n    private destroyed = false;\r\n\r\n    warnDbLevel = DEFAULT_WARN_DB_LEVEL;\r\n\r\n    constructor(private ref: ElementRef, private changeDetectorRef: ChangeDetectorRef) {\r\n\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.destroyed = true;\r\n    }\r\n\r\n\r\n    @Input()\r\n    set displayAudioBuffer(displayAudioBuffer: AudioBuffer | null| undefined) {\r\n        this._displayAudioBuffer = displayAudioBuffer;\r\n    }\r\n\r\n    get displayAudioBuffer() {\r\n        return this._displayAudioBuffer;\r\n    }\r\n\r\n    showRecordingDetails() {\r\n        this.onShowRecordingDetails.emit();\r\n    }\r\n\r\n    downloadRecording() {\r\n        this.onDownloadRecording.emit();\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        this.ce = this.ref.nativeElement;\r\n        //this.controlAudioPlayer.listener=this;\r\n    }\r\n\r\n    @Input()\r\n    set displayLevelInfos(levelInfos: LevelInfos | null) {\r\n        this._displayLevelInfos = levelInfos;\r\n    }\r\n\r\n    set channelCount(channelCount: number) {\r\n        this.reset();\r\n        this.liveLevel.channelCount = channelCount;\r\n    }\r\n\r\n  set playFramePosition(playFramePosition: number) {\r\n    this.liveLevel.playFramePosition=playFramePosition;\r\n  }\r\n\r\n    update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo) {\r\n        let peakDBVal = levelInfo.powerLevelDB();\r\n        if (this.peakDbLvl < peakDBVal) {\r\n            this.peakDbLvl = peakDBVal;\r\n            // the event comes from outside of an Angular zone\r\n            this.changeDetectorRef.detectChanges();\r\n        }\r\n        this.liveLevel.update(levelInfo);\r\n    }\r\n\r\n    error() {\r\n        // this.status = 'ERROR';\r\n    }\r\n\r\n    streamFinished() {\r\n        this.liveLevel.streamFinished();\r\n    }\r\n\r\n    reset() {\r\n        this.peakDbLvl = MIN_DB_LEVEL;\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n\r\n}\r\n"]}
|