speechrecorderng 2.22.0 → 2.22.4
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/recording.mjs +2 -1
- package/esm2020/lib/speechrecorder/session/audiorecorder.mjs +33 -13
- package/esm2020/lib/speechrecorder/session/controlpanel.mjs +6 -3
- package/esm2020/lib/speechrecorder/session/prompting.mjs +5 -5
- package/esm2020/lib/speechrecorder/session/recorder_combi_pane.mjs +14 -7
- package/esm2020/lib/speechrecorder/session/recording_list.mjs +38 -9
- package/esm2020/lib/speechrecorder/session/sessionmanager.mjs +10 -3
- package/esm2020/lib/spr.module.version.mjs +2 -2
- package/esm2020/lib/ui/recordingitem_display.mjs +6 -3
- package/fesm2015/speechrecorderng.mjs +107 -37
- package/fesm2015/speechrecorderng.mjs.map +1 -1
- package/fesm2020/speechrecorderng.mjs +107 -37
- package/fesm2020/speechrecorderng.mjs.map +1 -1
- package/lib/speechrecorder/recording.d.ts +2 -1
- package/lib/speechrecorder/session/recorder_combi_pane.d.ts +1 -0
- package/lib/speechrecorder/session/recording_list.d.ts +3 -1
- package/lib/spr.module.version.d.ts +1 -1
- package/package.json +1 -1
|
@@ -19,15 +19,44 @@ export class RecordingList {
|
|
|
19
19
|
this.recordingListDataSource = new MatTableDataSource();
|
|
20
20
|
}
|
|
21
21
|
ngAfterViewInit() {
|
|
22
|
-
this.
|
|
22
|
+
this.buildDataSource();
|
|
23
|
+
}
|
|
24
|
+
buildDataSource() {
|
|
25
|
+
this.recordingList.sort((a, b) => {
|
|
26
|
+
let cmp = 0;
|
|
27
|
+
let aD = null;
|
|
28
|
+
let bD = null;
|
|
29
|
+
if (a._startedAsDateObj && b._startedAsDateObj) {
|
|
30
|
+
aD = a._startedAsDateObj;
|
|
31
|
+
bD = b._startedAsDateObj;
|
|
32
|
+
}
|
|
33
|
+
else if (a.startedDate && b.startedDate) {
|
|
34
|
+
aD = new Date(a.startedDate);
|
|
35
|
+
bD = new Date(b.startedDate);
|
|
36
|
+
}
|
|
37
|
+
else if (a.date && b.date) {
|
|
38
|
+
aD = new Date(a.date);
|
|
39
|
+
bD = new Date(b.date);
|
|
40
|
+
}
|
|
41
|
+
if (aD !== null && bD !== null) {
|
|
42
|
+
cmp = bD.getTime() - aD.getTime();
|
|
43
|
+
}
|
|
44
|
+
return cmp;
|
|
45
|
+
});
|
|
46
|
+
this.recordingListDataSource.data = this.recordingList;
|
|
23
47
|
}
|
|
24
48
|
push(rf) {
|
|
25
49
|
this.recordingList.push(rf);
|
|
26
|
-
this.
|
|
50
|
+
this.buildDataSource();
|
|
27
51
|
}
|
|
28
52
|
selectRecordingFile(rf) {
|
|
29
53
|
this.selectedRecordingFileChanged.emit(rf);
|
|
30
54
|
}
|
|
55
|
+
selectTop() {
|
|
56
|
+
if (this.recordingList.length > 0) {
|
|
57
|
+
this.selectRecordingFile(this.recordingList[0]);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
31
60
|
lengthTimeFormatted(rf) {
|
|
32
61
|
let str = '--:--:--';
|
|
33
62
|
if (rf.frames && rf.audioBuffer) {
|
|
@@ -47,15 +76,15 @@ RecordingList.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version:
|
|
|
47
76
|
<tr mat-header-row *matHeaderRowDef="cols;sticky:true"></tr>
|
|
48
77
|
<tr mat-row *matRowDef="let element; columns: cols;" [scrollIntoViewToBottom]="element.uuid===selectedRecordingFile?.uuid"></tr>
|
|
49
78
|
<ng-container matColumnDef="index">
|
|
50
|
-
<th mat-header-cell *matHeaderCellDef mat-
|
|
79
|
+
<th mat-header-cell *matHeaderCellDef mat-header>#</th>
|
|
51
80
|
<td mat-cell class="monospaced" *matCellDef="let element;let i = index">{{recordingListDataSource.data.length-i}}</td>
|
|
52
81
|
</ng-container>
|
|
53
82
|
<ng-container matColumnDef="startedDate">
|
|
54
|
-
<th mat-header-cell *matHeaderCellDef mat-
|
|
83
|
+
<th mat-header-cell *matHeaderCellDef mat-header>Started</th>
|
|
55
84
|
<td mat-cell class="monospaced" *matCellDef="let element">{{element.startedDate | date:'YYYY-MM-dd HH:mm:ss'}}</td>
|
|
56
85
|
</ng-container>
|
|
57
86
|
<ng-container matColumnDef="length">
|
|
58
|
-
<th mat-header-cell *matHeaderCellDef mat-
|
|
87
|
+
<th mat-header-cell *matHeaderCellDef mat-header>Length</th>
|
|
59
88
|
<td mat-cell class="monospaced" *matCellDef="let element">{{lengthTimeFormatted(element)}}</td>
|
|
60
89
|
</ng-container>
|
|
61
90
|
<ng-container matColumnDef="action">
|
|
@@ -79,15 +108,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
|
|
|
79
108
|
<tr mat-header-row *matHeaderRowDef="cols;sticky:true"></tr>
|
|
80
109
|
<tr mat-row *matRowDef="let element; columns: cols;" [scrollIntoViewToBottom]="element.uuid===selectedRecordingFile?.uuid"></tr>
|
|
81
110
|
<ng-container matColumnDef="index">
|
|
82
|
-
<th mat-header-cell *matHeaderCellDef mat-
|
|
111
|
+
<th mat-header-cell *matHeaderCellDef mat-header>#</th>
|
|
83
112
|
<td mat-cell class="monospaced" *matCellDef="let element;let i = index">{{recordingListDataSource.data.length-i}}</td>
|
|
84
113
|
</ng-container>
|
|
85
114
|
<ng-container matColumnDef="startedDate">
|
|
86
|
-
<th mat-header-cell *matHeaderCellDef mat-
|
|
115
|
+
<th mat-header-cell *matHeaderCellDef mat-header>Started</th>
|
|
87
116
|
<td mat-cell class="monospaced" *matCellDef="let element">{{element.startedDate | date:'YYYY-MM-dd HH:mm:ss'}}</td>
|
|
88
117
|
</ng-container>
|
|
89
118
|
<ng-container matColumnDef="length">
|
|
90
|
-
<th mat-header-cell *matHeaderCellDef mat-
|
|
119
|
+
<th mat-header-cell *matHeaderCellDef mat-header>Length</th>
|
|
91
120
|
<td mat-cell class="monospaced" *matCellDef="let element">{{lengthTimeFormatted(element)}}</td>
|
|
92
121
|
</ng-container>
|
|
93
122
|
<ng-container matColumnDef="action">
|
|
@@ -106,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
|
|
|
106
135
|
}], selectedRecordingFile: [{
|
|
107
136
|
type: Input
|
|
108
137
|
}] } });
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkaW5nX2xpc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zcGVlY2hyZWNvcmRlcm5nL3NyYy9saWIvc3BlZWNocmVjb3JkZXIvc2Vzc2lvbi9yZWNvcmRpbmdfbGlzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWdCLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUVwRixPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFDN0MsT0FBTyxFQUFXLGtCQUFrQixFQUFDLE1BQU0seUJBQXlCLENBQUM7Ozs7Ozs7O0FBNkRyRSxNQUFNLE9BQU8sYUFBYTtJQVV4QjtRQVRBLGtCQUFhLEdBQXNCLElBQUksS0FBSyxFQUFpQixDQUFDO1FBRzlELDBEQUEwRDtRQUMxRCxTQUFJLEdBQUMsQ0FBQyxPQUFPLEVBQUMsYUFBYSxFQUFDLFFBQVEsRUFBQyxRQUFRLENBQUMsQ0FBQztRQUN0QyxtQkFBYyxHQUFTLEtBQUssQ0FBQztRQUM1QixpQ0FBNEIsR0FBRyxJQUFJLFlBQVksRUFBaUIsQ0FBQztRQUNsRSwwQkFBcUIsR0FBb0IsSUFBSSxDQUFDO1FBR3JELElBQUksQ0FBQyx1QkFBdUIsR0FBQyxJQUFJLGtCQUFrQixFQUFpQixDQUFDO0lBRXZFLENBQUM7SUFFRCxlQUFlO1FBQ2IsSUFBSSxDQUFDLHVCQUF1QixDQUFDLElBQUksR0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ2pFLENBQUM7SUFFRCxJQUFJLENBQUMsRUFBZ0I7UUFDbkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDNUIsSUFBSSxDQUFDLHVCQUF1QixDQUFDLElBQUksR0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ2pFLENBQUM7SUFFRCxtQkFBbUIsQ0FBQyxFQUFnQjtRQUNsQyxJQUFJLENBQUMsNEJBQTRCLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFRCxtQkFBbUIsQ0FBQyxFQUFnQjtRQUNsQyxJQUFJLEdBQUcsR0FBQyxVQUFVLENBQUM7UUFDbkIsSUFBRyxFQUFFLENBQUMsTUFBTSxJQUFJLEVBQUUsQ0FBQyxXQUFXLEVBQUU7WUFDOUIsR0FBRyxHQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDLE1BQU0sR0FBRyxFQUFFLENBQUMsV0FBVyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1NBQ3BFO1FBQ0QsT0FBTyxHQUFHLENBQUM7SUFDYixDQUFDOzswR0FsQ1UsYUFBYTs4RkFBYixhQUFhLGtPQXREZDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E2QlQ7MkZBeUJVLGFBQWE7a0JBMUR6QixTQUFTOytCQUVFLG1CQUFtQixZQUVuQjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E2QlQ7MEVBK0JRLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0ksNEJBQTRCO3NCQUFyQyxNQUFNO2dCQUNFLHFCQUFxQjtzQkFBN0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QWZ0ZXJWaWV3SW5pdCwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXR9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7UmVjb3JkaW5nRmlsZSwgU3ByUmVjb3JkaW5nRmlsZX0gZnJvbSBcIi4uL3JlY29yZGluZ1wiO1xyXG5pbXBvcnQge01lZGlhVXRpbHN9IGZyb20gXCIuLi8uLi9tZWRpYS91dGlsc1wiO1xyXG5pbXBvcnQge01hdFRhYmxlLCBNYXRUYWJsZURhdGFTb3VyY2V9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC90YWJsZVwiO1xyXG5pbXBvcnQge09ic2VydmFibGUsIFN1YmplY3R9IGZyb20gXCJyeGpzXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuXHJcbiAgc2VsZWN0b3I6ICdhcHAtcmVjb3JkaW5nbGlzdCcsXHJcblxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8bWF0LWNhcmQ+XHJcbiAgICAgICAgPG1hdC1jYXJkLWhlYWRlcj5cclxuICAgICAgICAgIDxoMj5SZWNvcmRpbmcgbGlzdDwvaDI+XHJcbiAgICAgICAgPC9tYXQtY2FyZC1oZWFkZXI+XHJcbiAgICAgIDxtYXQtY2FyZC1jb250ZW50PlxyXG4gICAgPHRhYmxlIG1hdC10YWJsZSBbZGF0YVNvdXJjZV09XCJyZWNvcmRpbmdMaXN0RGF0YVNvdXJjZVwiIGNsYXNzPVwibWF0LWVsZXZhdGlvbi16MFwiPlxyXG4gICAgICA8dHIgbWF0LWhlYWRlci1yb3cgKm1hdEhlYWRlclJvd0RlZj1cImNvbHM7c3RpY2t5OnRydWVcIj48L3RyPlxyXG4gICAgICA8dHIgbWF0LXJvdyAqbWF0Um93RGVmPVwibGV0IGVsZW1lbnQ7IGNvbHVtbnM6IGNvbHM7XCIgW3Njcm9sbEludG9WaWV3VG9Cb3R0b21dPVwiZWxlbWVudC51dWlkPT09c2VsZWN0ZWRSZWNvcmRpbmdGaWxlPy51dWlkXCI+PC90cj5cclxuICAgICAgPG5nLWNvbnRhaW5lciBtYXRDb2x1bW5EZWY9XCJpbmRleFwiPlxyXG4gICAgICAgIDx0aCBtYXQtaGVhZGVyLWNlbGwgKm1hdEhlYWRlckNlbGxEZWYgbWF0LXNvcnQtaGVhZGVyPiM8L3RoPlxyXG4gICAgICAgIDx0ZCBtYXQtY2VsbCBjbGFzcz1cIm1vbm9zcGFjZWRcIiAqbWF0Q2VsbERlZj1cImxldCBlbGVtZW50O2xldCBpID0gaW5kZXhcIj57e3JlY29yZGluZ0xpc3REYXRhU291cmNlLmRhdGEubGVuZ3RoLWl9fTwvdGQ+XHJcbiAgICAgIDwvbmctY29udGFpbmVyPlxyXG4gICAgICA8bmctY29udGFpbmVyIG1hdENvbHVtbkRlZj1cInN0YXJ0ZWREYXRlXCI+XHJcbiAgICAgICAgPHRoIG1hdC1oZWFkZXItY2VsbCAqbWF0SGVhZGVyQ2VsbERlZiBtYXQtc29ydC1oZWFkZXI+U3RhcnRlZDwvdGg+XHJcbiAgICAgICAgPHRkIG1hdC1jZWxsIGNsYXNzPVwibW9ub3NwYWNlZFwiICptYXRDZWxsRGVmPVwibGV0IGVsZW1lbnRcIj57e2VsZW1lbnQuc3RhcnRlZERhdGUgfCBkYXRlOidZWVlZLU1NLWRkIEhIOm1tOnNzJ319PC90ZD5cclxuICAgICAgPC9uZy1jb250YWluZXI+XHJcbiAgICAgIDxuZy1jb250YWluZXIgbWF0Q29sdW1uRGVmPVwibGVuZ3RoXCI+XHJcbiAgICAgICAgPHRoIG1hdC1oZWFkZXItY2VsbCAqbWF0SGVhZGVyQ2VsbERlZiBtYXQtc29ydC1oZWFkZXI+TGVuZ3RoPC90aD5cclxuICAgICAgICA8dGQgbWF0LWNlbGwgY2xhc3M9XCJtb25vc3BhY2VkXCIgKm1hdENlbGxEZWY9XCJsZXQgZWxlbWVudFwiPnt7bGVuZ3RoVGltZUZvcm1hdHRlZChlbGVtZW50KX19PC90ZD5cclxuICAgICAgPC9uZy1jb250YWluZXI+XHJcbiAgICAgIDxuZy1jb250YWluZXIgbWF0Q29sdW1uRGVmPVwiYWN0aW9uXCI+XHJcbiAgICAgICAgPHRoIG1hdC1oZWFkZXItY2VsbCAqbWF0SGVhZGVyQ2VsbERlZj5BY3Rpb248L3RoPlxyXG4gICAgICAgIDx0ZCBtYXQtY2VsbCAqbWF0Q2VsbERlZj1cImxldCBlbGVtZW50XCI+PGJ1dHRvbiBtYXQtc3Ryb2tlZC1idXR0b24gY29sb3I9XCJwcmltYXJ5XCIgKGNsaWNrKT1cInNlbGVjdFJlY29yZGluZ0ZpbGUoZWxlbWVudClcIiBbZGlzYWJsZWRdPVwic2VsZWN0RGlzYWJsZWQgfHwgZWxlbWVudC51dWlkPT09c2VsZWN0ZWRSZWNvcmRpbmdGaWxlPy51dWlkXCI+PG1hdC1pY29uPmVkaXRfYXR0cmlidXRlczwvbWF0LWljb24+IFNlbGVjdDwvYnV0dG9uPjwvdGQ+XHJcbiAgICAgIDwvbmctY29udGFpbmVyPlxyXG4gICAgPC90YWJsZT5cclxuICAgICAgPC9tYXQtY2FyZC1jb250ZW50PlxyXG4gICAgPC9tYXQtY2FyZD5cclxuXHJcbiAgYCxcclxuICBzdHlsZXM6IFtgOmhvc3Qge1xyXG4gICAgcG9zaXRpb246IHJlbGF0aXZlO1xyXG4gICAgbWFyZ2luOiAwO1xyXG4gICAgcGFkZGluZzogMDtcclxuICAgIGJhY2tncm91bmQ6IGxpZ2h0Z3JleTtcclxuICAgIHdpZHRoOiAxMDAlOyAvKiB1c2UgYWxsIGhvcml6b250YWwgYXZhaWxhYmxlIHNwYWNlICovXHJcbiAgICBmbGV4OiAxOyAvKiAuLi4gYW5kIGZpbGwgcmVzdCBvZiB2ZXJ0aWNhbCBhdmFpbGFibGUgc3BhY2UgKG90aGVyIGNvbXBvbmVudHMgaGF2ZSBmbGV4IDApICovXHJcbiAgICBvdmVyZmxvdy15OiBhdXRvO1xyXG5cclxuICAgIC8qIFdvcmthcm91bmQgZm9yIEZpcmVmb3hcclxuICAgIElmIHRoZSBwcm9ncmVzcyB0YWJsZSBnZXRzIGxvbmcgKHNjcmlwdCB3aXRoIG1hbnkgaXRlbXMpIEZGIGluY3JlYXNlcyB0aGUgaGVpZ2h0IG9mIHRoZSBvdmVyZmxvdyBwcm9ncmVzc0NvbnRhaW5lciBhbmRcclxuICAgIHRoZSB3aG9sZSBhcHAgZG9lcyBub3QgZml0IGludG8gdGhlIHBhZ2UgYW55bW9yZS4gVGhlIGFwcCBvdmVyZmxvd3MgYW5kIHNob3dzIGEgdmVydGljYWwgc2Nyb2xsYmFyIGZvciB0aGUgd2hvbGUgYXBwLlxyXG4gICAgU2VlIGh0dHA6Ly9zdGFja292ZXJmbG93LmNvbS9xdWVzdGlvbnMvMjg2MzY4MzIvZmlyZWZveC1vdmVyZmxvdy15LW5vdC13b3JraW5nLXdpdGgtbmVzdGVkLWZsZXhib3hcclxuICAgICovXHJcbiAgICBtaW4taGVpZ2h0OiAwcHg7XHJcblxyXG4gIH1gLGBcclxuICAgIC5zZWxlY3RlZHtcclxuICAgICAgZm9udC13ZWlnaHQ6IGJvbGQ7XHJcbiAgICB9XHJcbiAgYF0sXHJcbiAgc3R5bGVVcmxzOiBbJy4uLy4uL3NwZWVjaHJlY29yZGVyX21hdC5zY3NzJ11cclxuXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSZWNvcmRpbmdMaXN0IGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdHtcclxuICByZWNvcmRpbmdMaXN0OkFycmF5PFJlY29yZGluZ0ZpbGU+PW5ldyBBcnJheTxSZWNvcmRpbmdGaWxlPigpO1xyXG4gIC8vcmVjb3JkaW5nTGlzdFN1YmplY3Q6U3ViamVjdDxBcnJheTxSZWNvcmRpbmdGaWxlPj4gPSBuZXcgU3ViamVjdDxBcnJheTxSZWNvcmRpbmdGaWxlPj4oKTtcclxuICByZWNvcmRpbmdMaXN0RGF0YVNvdXJjZTpNYXRUYWJsZURhdGFTb3VyY2U8UmVjb3JkaW5nRmlsZT47XHJcbiAgLy9jb2xzPVsnaW5kZXgnLCdsZW5ndGgnLCdzYW1wbGVzJywnc2FtcGxlcmF0ZScsJ2FjdGlvbiddO1xyXG4gIGNvbHM9WydpbmRleCcsJ3N0YXJ0ZWREYXRlJywnbGVuZ3RoJywnYWN0aW9uJ107XHJcbiAgQElucHV0KCkgc2VsZWN0RGlzYWJsZWQ6Ym9vbGVhbj1mYWxzZTtcclxuICBAT3V0cHV0KCkgc2VsZWN0ZWRSZWNvcmRpbmdGaWxlQ2hhbmdlZCA9IG5ldyBFdmVudEVtaXR0ZXI8UmVjb3JkaW5nRmlsZT4oKTtcclxuICBASW5wdXQoKSBzZWxlY3RlZFJlY29yZGluZ0ZpbGU6UmVjb3JkaW5nRmlsZXxudWxsPW51bGw7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gICAgdGhpcy5yZWNvcmRpbmdMaXN0RGF0YVNvdXJjZT1uZXcgTWF0VGFibGVEYXRhU291cmNlPFJlY29yZGluZ0ZpbGU+KCk7XHJcblxyXG4gIH1cclxuXHJcbiAgbmdBZnRlclZpZXdJbml0KCkge1xyXG4gICAgdGhpcy5yZWNvcmRpbmdMaXN0RGF0YVNvdXJjZS5kYXRhPXRoaXMucmVjb3JkaW5nTGlzdC5yZXZlcnNlKCk7XHJcbiAgfVxyXG5cclxuICBwdXNoKHJmOlJlY29yZGluZ0ZpbGUpe1xyXG4gICAgdGhpcy5yZWNvcmRpbmdMaXN0LnB1c2gocmYpO1xyXG4gICAgdGhpcy5yZWNvcmRpbmdMaXN0RGF0YVNvdXJjZS5kYXRhPXRoaXMucmVjb3JkaW5nTGlzdC5yZXZlcnNlKCk7XHJcbiAgfVxyXG5cclxuICBzZWxlY3RSZWNvcmRpbmdGaWxlKHJmOlJlY29yZGluZ0ZpbGUpe1xyXG4gICAgdGhpcy5zZWxlY3RlZFJlY29yZGluZ0ZpbGVDaGFuZ2VkLmVtaXQocmYpO1xyXG4gIH1cclxuXHJcbiAgbGVuZ3RoVGltZUZvcm1hdHRlZChyZjpSZWNvcmRpbmdGaWxlKXtcclxuICAgIGxldCBzdHI9Jy0tOi0tOi0tJztcclxuICAgIGlmKHJmLmZyYW1lcyAmJiByZi5hdWRpb0J1ZmZlcikge1xyXG4gICAgICBzdHI9TWVkaWFVdGlscy50b01lZGlhVGltZShyZi5mcmFtZXMgLyByZi5hdWRpb0J1ZmZlcj8uc2FtcGxlUmF0ZSk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gc3RyO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recording_list.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/speechrecorder/session/recording_list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAC,MAAM,eAAe,CAAC;AAEpF,OAAO,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAW,kBAAkB,EAAC,MAAM,yBAAyB,CAAC;;;;;;;;AA6DrE,MAAM,OAAO,aAAa;IAUxB;QATQ,kBAAa,GAAsB,IAAI,KAAK,EAAiB,CAAC;QAGtE,0DAA0D;QAC1D,SAAI,GAAC,CAAC,OAAO,EAAC,aAAa,EAAC,QAAQ,EAAC,QAAQ,CAAC,CAAC;QACtC,mBAAc,GAAS,KAAK,CAAC;QAC5B,iCAA4B,GAAG,IAAI,YAAY,EAAiB,CAAC;QAClE,0BAAqB,GAAoB,IAAI,CAAC;QAGrD,IAAI,CAAC,uBAAuB,GAAC,IAAI,kBAAkB,EAAiB,CAAC;IACvE,CAAC;IAED,eAAe;QACb,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YAC/B,IAAI,GAAG,GAAQ,CAAC,CAAC;YACjB,IAAI,EAAE,GAAW,IAAI,CAAC;YACtB,IAAI,EAAE,GAAW,IAAI,CAAC;YACtB,IAAG,CAAC,CAAC,iBAAiB,IAAI,CAAC,CAAC,iBAAiB,EAAC;gBAC5C,EAAE,GAAC,CAAC,CAAC,iBAAiB,CAAA;gBACtB,EAAE,GAAC,CAAC,CAAC,iBAAiB,CAAA;aACvB;iBAAK,IAAG,CAAC,CAAC,WAAW,IAAI,CAAC,CAAC,WAAW,EAAC;gBACtC,EAAE,GAAC,IAAI,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;gBAC3B,EAAE,GAAC,IAAI,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;aAC5B;iBAAK,IAAG,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,EAAE;gBACzB,EAAE,GAAC,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;gBACpB,EAAE,GAAC,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;aACrB;YACD,IAAG,EAAE,KAAG,IAAI,IAAI,EAAE,KAAG,IAAI,EAAC;gBACxB,GAAG,GAAC,EAAE,CAAC,OAAO,EAAE,GAAC,EAAE,CAAC,OAAO,EAAE,CAAC;aAC/B;YACD,OAAO,GAAG,CAAC;QACb,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,uBAAuB,CAAC,IAAI,GAAC,IAAI,CAAC,aAAa,CAAC;IACvD,CAAC;IAED,IAAI,CAAC,EAAgB;QACnB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC5B,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,mBAAmB,CAAC,EAAgB;QAClC,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC7C,CAAC;IAED,SAAS;QACP,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;YACjC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;SACjD;IACH,CAAC;IAED,mBAAmB,CAAC,EAAgB;QAClC,IAAI,GAAG,GAAC,UAAU,CAAC;QACnB,IAAG,EAAE,CAAC,MAAM,IAAI,EAAE,CAAC,WAAW,EAAE;YAC9B,GAAG,GAAC,UAAU,CAAC,WAAW,CAAC,EAAE,CAAC,MAAM,GAAG,EAAE,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;SACpE;QACD,OAAO,GAAG,CAAC;IACb,CAAC;;0GA9DU,aAAa;8FAAb,aAAa,kOAtDd;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BT;2FAyBU,aAAa;kBA1DzB,SAAS;+BAEE,mBAAmB,YAEnB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BT;0EA+BQ,cAAc;sBAAtB,KAAK;gBACI,4BAA4B;sBAArC,MAAM;gBACE,qBAAqB;sBAA7B,KAAK","sourcesContent":["import {AfterViewInit, Component, EventEmitter, Input, Output} from \"@angular/core\";\r\nimport {RecordingFile, SprRecordingFile} from \"../recording\";\r\nimport {MediaUtils} from \"../../media/utils\";\r\nimport {MatTable, MatTableDataSource} from \"@angular/material/table\";\r\nimport {Observable, Subject} from \"rxjs\";\r\n\r\n@Component({\r\n\r\n  selector: 'app-recordinglist',\r\n\r\n  template: `\r\n    <mat-card>\r\n        <mat-card-header>\r\n          <h2>Recording list</h2>\r\n        </mat-card-header>\r\n      <mat-card-content>\r\n    <table mat-table [dataSource]=\"recordingListDataSource\" class=\"mat-elevation-z0\">\r\n      <tr mat-header-row *matHeaderRowDef=\"cols;sticky:true\"></tr>\r\n      <tr mat-row *matRowDef=\"let element; columns: cols;\" [scrollIntoViewToBottom]=\"element.uuid===selectedRecordingFile?.uuid\"></tr>\r\n      <ng-container matColumnDef=\"index\">\r\n        <th mat-header-cell *matHeaderCellDef mat-header>#</th>\r\n        <td mat-cell class=\"monospaced\" *matCellDef=\"let element;let i = index\">{{recordingListDataSource.data.length-i}}</td>\r\n      </ng-container>\r\n      <ng-container matColumnDef=\"startedDate\">\r\n        <th mat-header-cell *matHeaderCellDef mat-header>Started</th>\r\n        <td mat-cell class=\"monospaced\" *matCellDef=\"let element\">{{element.startedDate | date:'YYYY-MM-dd HH:mm:ss'}}</td>\r\n      </ng-container>\r\n      <ng-container matColumnDef=\"length\">\r\n        <th mat-header-cell *matHeaderCellDef mat-header>Length</th>\r\n        <td mat-cell class=\"monospaced\" *matCellDef=\"let element\">{{lengthTimeFormatted(element)}}</td>\r\n      </ng-container>\r\n      <ng-container matColumnDef=\"action\">\r\n        <th mat-header-cell *matHeaderCellDef>Action</th>\r\n        <td mat-cell *matCellDef=\"let element\"><button mat-stroked-button color=\"primary\" (click)=\"selectRecordingFile(element)\" [disabled]=\"selectDisabled || element.uuid===selectedRecordingFile?.uuid\"><mat-icon>edit_attributes</mat-icon> Select</button></td>\r\n      </ng-container>\r\n    </table>\r\n      </mat-card-content>\r\n    </mat-card>\r\n\r\n  `,\r\n  styles: [`:host {\r\n    position: relative;\r\n    margin: 0;\r\n    padding: 0;\r\n    background: lightgrey;\r\n    width: 100%; /* use all horizontal available space */\r\n    flex: 1; /* ... and fill rest of vertical available space (other components have flex 0) */\r\n    overflow-y: auto;\r\n\r\n    /* Workaround for Firefox\r\n    If the progress table gets long (script with many items) FF increases the height of the overflow progressContainer and\r\n    the whole app does not fit into the page anymore. The app overflows and shows a vertical scrollbar for the whole app.\r\n    See http://stackoverflow.com/questions/28636832/firefox-overflow-y-not-working-with-nested-flexbox\r\n    */\r\n    min-height: 0px;\r\n\r\n  }`,`\r\n    .selected{\r\n      font-weight: bold;\r\n    }\r\n  `],\r\n  styleUrls: ['../../speechrecorder_mat.scss']\r\n\r\n})\r\nexport class RecordingList implements AfterViewInit{\r\n  private recordingList:Array<RecordingFile>=new Array<RecordingFile>();\r\n  //recordingListSubject:Subject<Array<RecordingFile>> = new Subject<Array<RecordingFile>>();\r\n  recordingListDataSource:MatTableDataSource<RecordingFile>;\r\n  //cols=['index','length','samples','samplerate','action'];\r\n  cols=['index','startedDate','length','action'];\r\n  @Input() selectDisabled:boolean=false;\r\n  @Output() selectedRecordingFileChanged = new EventEmitter<RecordingFile>();\r\n  @Input() selectedRecordingFile:RecordingFile|null=null;\r\n\r\n  constructor() {\r\n    this.recordingListDataSource=new MatTableDataSource<RecordingFile>();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.buildDataSource();\r\n  }\r\n\r\n  private buildDataSource(){\r\n    this.recordingList.sort((a, b) => {\r\n      let cmp:number=0;\r\n      let aD:Date|null=null;\r\n      let bD:Date|null=null;\r\n      if(a._startedAsDateObj && b._startedAsDateObj){\r\n        aD=a._startedAsDateObj\r\n        bD=b._startedAsDateObj\r\n      }else if(a.startedDate && b.startedDate){\r\n        aD=new Date(a.startedDate);\r\n        bD=new Date(b.startedDate);\r\n      }else if(a.date && b.date) {\r\n        aD=new Date(a.date);\r\n        bD=new Date(b.date);\r\n      }\r\n      if(aD!==null && bD!==null){\r\n        cmp=bD.getTime()-aD.getTime();\r\n      }\r\n      return cmp;\r\n    });\r\n    this.recordingListDataSource.data=this.recordingList;\r\n  }\r\n\r\n  push(rf:RecordingFile){\r\n    this.recordingList.push(rf);\r\n    this.buildDataSource();\r\n  }\r\n\r\n  selectRecordingFile(rf:RecordingFile){\r\n    this.selectedRecordingFileChanged.emit(rf);\r\n  }\r\n\r\n  selectTop() {\r\n    if (this.recordingList.length > 0) {\r\n      this.selectRecordingFile(this.recordingList[0]);\r\n    }\r\n  }\r\n\r\n  lengthTimeFormatted(rf:RecordingFile){\r\n    let str='--:--:--';\r\n    if(rf.frames && rf.audioBuffer) {\r\n      str=MediaUtils.toMediaTime(rf.frames / rf.audioBuffer?.sampleRate);\r\n    }\r\n    return str;\r\n  }\r\n}\r\n"]}
|