speechrecorderng 2.22.0 → 2.22.1

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.
@@ -19,15 +19,44 @@ export class RecordingList {
19
19
  this.recordingListDataSource = new MatTableDataSource();
20
20
  }
21
21
  ngAfterViewInit() {
22
- this.recordingListDataSource.data = this.recordingList.reverse();
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.recordingListDataSource.data = this.recordingList.reverse();
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-sort-header>#</th>
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-sort-header>Started</th>
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-sort-header>Length</th>
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-sort-header>#</th>
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-sort-header>Started</th>
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-sort-header>Length</th>
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":"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","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"]}
@@ -1,2 +1,2 @@
1
- export const VERSION = '2.22.0';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ByLm1vZHVsZS52ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL3Nwci5tb2R1bGUudmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUMsUUFBUSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFZFUlNJT049JzIuMjIuMCciXX0=
1
+ export const VERSION = '2.22.1';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ByLm1vZHVsZS52ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL3Nwci5tb2R1bGUudmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUMsUUFBUSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFZFUlNJT049JzIuMjIuMSciXX0=
@@ -1448,6 +1448,7 @@ class RecordingFile {
1448
1448
  this.date = null;
1449
1449
  this._dateAsDateObj = null;
1450
1450
  this.startedDate = null;
1451
+ this._startedAsDateObj = null;
1451
1452
  this.audioBuffer = null;
1452
1453
  this.session = null;
1453
1454
  this.frames = null;
@@ -10669,15 +10670,44 @@ class RecordingList {
10669
10670
  this.recordingListDataSource = new MatTableDataSource();
10670
10671
  }
10671
10672
  ngAfterViewInit() {
10672
- this.recordingListDataSource.data = this.recordingList.reverse();
10673
+ this.buildDataSource();
10674
+ }
10675
+ buildDataSource() {
10676
+ this.recordingList.sort((a, b) => {
10677
+ let cmp = 0;
10678
+ let aD = null;
10679
+ let bD = null;
10680
+ if (a._startedAsDateObj && b._startedAsDateObj) {
10681
+ aD = a._startedAsDateObj;
10682
+ bD = b._startedAsDateObj;
10683
+ }
10684
+ else if (a.startedDate && b.startedDate) {
10685
+ aD = new Date(a.startedDate);
10686
+ bD = new Date(b.startedDate);
10687
+ }
10688
+ else if (a.date && b.date) {
10689
+ aD = new Date(a.date);
10690
+ bD = new Date(b.date);
10691
+ }
10692
+ if (aD !== null && bD !== null) {
10693
+ cmp = bD.getTime() - aD.getTime();
10694
+ }
10695
+ return cmp;
10696
+ });
10697
+ this.recordingListDataSource.data = this.recordingList;
10673
10698
  }
10674
10699
  push(rf) {
10675
10700
  this.recordingList.push(rf);
10676
- this.recordingListDataSource.data = this.recordingList.reverse();
10701
+ this.buildDataSource();
10677
10702
  }
10678
10703
  selectRecordingFile(rf) {
10679
10704
  this.selectedRecordingFileChanged.emit(rf);
10680
10705
  }
10706
+ selectTop() {
10707
+ if (this.recordingList.length > 0) {
10708
+ this.selectRecordingFile(this.recordingList[0]);
10709
+ }
10710
+ }
10681
10711
  lengthTimeFormatted(rf) {
10682
10712
  var _a;
10683
10713
  let str = '--:--:--';
@@ -10698,15 +10728,15 @@ RecordingList.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version:
10698
10728
  <tr mat-header-row *matHeaderRowDef="cols;sticky:true"></tr>
10699
10729
  <tr mat-row *matRowDef="let element; columns: cols;" [scrollIntoViewToBottom]="element.uuid===selectedRecordingFile?.uuid"></tr>
10700
10730
  <ng-container matColumnDef="index">
10701
- <th mat-header-cell *matHeaderCellDef mat-sort-header>#</th>
10731
+ <th mat-header-cell *matHeaderCellDef mat-header>#</th>
10702
10732
  <td mat-cell class="monospaced" *matCellDef="let element;let i = index">{{recordingListDataSource.data.length-i}}</td>
10703
10733
  </ng-container>
10704
10734
  <ng-container matColumnDef="startedDate">
10705
- <th mat-header-cell *matHeaderCellDef mat-sort-header>Started</th>
10735
+ <th mat-header-cell *matHeaderCellDef mat-header>Started</th>
10706
10736
  <td mat-cell class="monospaced" *matCellDef="let element">{{element.startedDate | date:'YYYY-MM-dd HH:mm:ss'}}</td>
10707
10737
  </ng-container>
10708
10738
  <ng-container matColumnDef="length">
10709
- <th mat-header-cell *matHeaderCellDef mat-sort-header>Length</th>
10739
+ <th mat-header-cell *matHeaderCellDef mat-header>Length</th>
10710
10740
  <td mat-cell class="monospaced" *matCellDef="let element">{{lengthTimeFormatted(element)}}</td>
10711
10741
  </ng-container>
10712
10742
  <ng-container matColumnDef="action">
@@ -10730,15 +10760,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
10730
10760
  <tr mat-header-row *matHeaderRowDef="cols;sticky:true"></tr>
10731
10761
  <tr mat-row *matRowDef="let element; columns: cols;" [scrollIntoViewToBottom]="element.uuid===selectedRecordingFile?.uuid"></tr>
10732
10762
  <ng-container matColumnDef="index">
10733
- <th mat-header-cell *matHeaderCellDef mat-sort-header>#</th>
10763
+ <th mat-header-cell *matHeaderCellDef mat-header>#</th>
10734
10764
  <td mat-cell class="monospaced" *matCellDef="let element;let i = index">{{recordingListDataSource.data.length-i}}</td>
10735
10765
  </ng-container>
10736
10766
  <ng-container matColumnDef="startedDate">
10737
- <th mat-header-cell *matHeaderCellDef mat-sort-header>Started</th>
10767
+ <th mat-header-cell *matHeaderCellDef mat-header>Started</th>
10738
10768
  <td mat-cell class="monospaced" *matCellDef="let element">{{element.startedDate | date:'YYYY-MM-dd HH:mm:ss'}}</td>
10739
10769
  </ng-container>
10740
10770
  <ng-container matColumnDef="length">
10741
- <th mat-header-cell *matHeaderCellDef mat-sort-header>Length</th>
10771
+ <th mat-header-cell *matHeaderCellDef mat-header>Length</th>
10742
10772
  <td mat-cell class="monospaced" *matCellDef="let element">{{lengthTimeFormatted(element)}}</td>
10743
10773
  </ng-container>
10744
10774
  <ng-container matColumnDef="action">
@@ -10774,6 +10804,9 @@ class RecorderCombiPane {
10774
10804
  selectRecordingFile(rf) {
10775
10805
  this.selectedRecordingFileChanged.emit(rf);
10776
10806
  }
10807
+ selectTop() {
10808
+ this.recordingListComp.selectTop();
10809
+ }
10777
10810
  }
10778
10811
  RecorderCombiPane.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: RecorderCombiPane, deps: [], target: i0.ɵɵFactoryTarget.Component });
10779
10812
  RecorderCombiPane.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.1", type: RecorderCombiPane, selector: "app-recordercombipane", inputs: { selectDisabled: "selectDisabled", selectedRecordingFile: "selectedRecordingFile", audioSignalCollapsed: "audioSignalCollapsed", displayAudioClip: "displayAudioClip", playStartAction: "playStartAction", playSelectionAction: "playSelectionAction", autoPlayOnSelectToggleAction: "autoPlayOnSelectToggleAction", playStopAction: "playStopAction" }, outputs: { selectedRecordingFileChanged: "selectedRecordingFileChanged" }, viewQueries: [{ propertyName: "recordingListComp", first: true, predicate: RecordingList, descendants: true }, { propertyName: "audioDisplay", first: true, predicate: AudioDisplay, descendants: true, static: true }], ngImport: i0, template: `
@@ -11073,8 +11106,12 @@ class AudioRecorder {
11073
11106
  if (rfs) {
11074
11107
  if (rfs instanceof Array) {
11075
11108
  rfs.forEach((rf) => {
11076
- //console.debug("Already recorded: " + rf+ " "+rf.recording.itemcode);
11077
- //this.addRecordingFileByDescriptor(rf);
11109
+ if (rf.startedDate) {
11110
+ rf._startedAsDateObj = new Date(rf.startedDate);
11111
+ }
11112
+ if (rf.date) {
11113
+ rf._dateAsDateObj = new Date(rf.date);
11114
+ }
11078
11115
  this.recorderCombiPane.push(rf);
11079
11116
  });
11080
11117
  }
@@ -11538,9 +11575,10 @@ class AudioRecorder {
11538
11575
  }
11539
11576
  });
11540
11577
  }
11541
- if (this.recorderCombiPane.recordingListComp.recordingList.length > 0) {
11542
- this.selectRecordingFile(this.recorderCombiPane.recordingListComp.recordingList[0]);
11543
- }
11578
+ // if(this.recorderCombiPane.recordingListComp.recordingList.length>0){
11579
+ // this.selectRecordingFile(this.recorderCombiPane.recordingListComp.recordingList[0]);
11580
+ // }
11581
+ this.recorderCombiPane.selectTop();
11544
11582
  this.enableNavigation();
11545
11583
  }
11546
11584
  isRecording() {
@@ -11644,7 +11682,10 @@ class AudioRecorder {
11644
11682
  // it.recs = new Array<RecordingFile>();
11645
11683
  // }
11646
11684
  let rf = new RecordingFile(UUID.generate(), sessId, ad);
11647
- rf.startedDate = this.startedDate;
11685
+ rf._startedAsDateObj = this.startedDate;
11686
+ if (rf._startedAsDateObj) {
11687
+ rf.startedDate = rf._startedAsDateObj.toString();
11688
+ }
11648
11689
  // it.recs.push(rf);
11649
11690
  //
11650
11691
  // if (this.enableUploadRecordings) {
@@ -11676,7 +11717,7 @@ class AudioRecorder {
11676
11717
  this.displayRecFile = rf;
11677
11718
  //this.recordingListComp.recordingList.push(rf);
11678
11719
  this.recorderCombiPane.push(rf);
11679
- this.postRecordingMultipart(wavFile, rf.uuid, rf.session, rf.startedDate, recUrl);
11720
+ this.postRecordingMultipart(wavFile, rf.uuid, rf.session, rf._startedAsDateObj, recUrl);
11680
11721
  this.processingRecording = false;
11681
11722
  this.changeDetectorRef.detectChanges();
11682
11723
  });
@@ -11977,7 +12018,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImpor
11977
12018
  }]
11978
12019
  }] });
11979
12020
 
11980
- const VERSION = '2.22.0';
12021
+ const VERSION = '2.22.1';
11981
12022
 
11982
12023
  /*
11983
12024
  * Public API Surface of speechrecorderng