@elderbyte/ngx-starter 15.2.3 → 15.2.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.
@@ -1,8 +1,10 @@
1
1
  import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
- import { map } from 'rxjs/operators';
2
+ import { BehaviorSubject, switchMap } from 'rxjs';
3
+ import { filter, map } from 'rxjs/operators';
3
4
  import { LoggerFactory } from '@elderbyte/ts-logger';
4
5
  import { BytesPerSecondFormat } from '../../../common/format/bytes-per-second-format';
5
6
  import { BytesFormat } from '../../../common/format/bytes-format';
7
+ import { DataTransferStatus } from '../../../common/http/transfer/data-transfer-status';
6
8
  import * as i0 from "@angular/core";
7
9
  import * as i1 from "@angular/common";
8
10
  import * as i2 from "@angular/material/icon";
@@ -21,7 +23,10 @@ export class HttpDataTransferComponent {
21
23
  * Fields *
22
24
  * *
23
25
  **************************************************************************/
24
- this.logger = LoggerFactory.getLogger('HttpDataTransferComponent');
26
+ this.logger = LoggerFactory.getLogger(this.constructor.name);
27
+ this._transfer$ = new BehaviorSubject(null);
28
+ this.$state = this._transfer$.pipe(filter(transfer => !!transfer), switchMap(transfer => transfer.state$));
29
+ this.$detail = this.$state.pipe(map(state => this.renderTransferProgress(state)));
25
30
  }
26
31
  /***************************************************************************
27
32
  * *
@@ -29,39 +34,58 @@ export class HttpDataTransferComponent {
29
34
  * *
30
35
  **************************************************************************/
31
36
  get transfer() {
32
- return this._transfer;
37
+ return this._transfer$.getValue();
33
38
  }
34
39
  set transfer(value) {
35
- this._transfer = value;
36
- this.$state = value.state$;
37
- this.$detail = value.state$.pipe(map(state => {
38
- if (state.isAborted) {
39
- return 'Canceled.';
40
- }
41
- if (state.hasFailed) {
42
- return 'Failed!';
43
- }
44
- const e = state.progress;
45
- // 100Mb of 332Mb (1200Kb/sec)
46
- if (e.percentDone === 100) {
47
- return BytesFormat.format(e.doneBytes) + '( ' + BytesPerSecondFormat.formatAsBitsPerSecond(e.avgBytesPerSec) + ')';
48
- }
49
- else {
50
- let progress = BytesFormat.format(e.doneBytes) + ' of ' + BytesFormat.format(e.totalBytes);
51
- if (e.bytesPerSec) {
52
- progress += ' (' + BytesPerSecondFormat.formatAsBitsPerSecond(e.bytesPerSec) + ')';
53
- }
54
- return progress;
40
+ this._transfer$.next(value);
41
+ }
42
+ /***************************************************************************
43
+ * *
44
+ * Public API *
45
+ * *
46
+ **************************************************************************/
47
+ statusIcon(state) {
48
+ switch (state.status) {
49
+ case DataTransferStatus.Pending: return 'pending';
50
+ case DataTransferStatus.Transferring: return 'cloud_sync';
51
+ case DataTransferStatus.Completed: return 'check';
52
+ case DataTransferStatus.Aborted: return 'block';
53
+ case DataTransferStatus.Failed: return 'error';
54
+ default: return 'help_outline';
55
+ }
56
+ }
57
+ /***************************************************************************
58
+ * *
59
+ * Private methods *
60
+ * *
61
+ **************************************************************************/
62
+ renderTransferProgress(state) {
63
+ if (state.isAborted) {
64
+ return 'Canceled.';
65
+ }
66
+ if (state.hasFailed) {
67
+ return 'Failed!';
68
+ }
69
+ const e = state.progress;
70
+ // 100Mb of 332Mb (1200Kb/sec)
71
+ if (e.percentDone === 100) {
72
+ return BytesFormat.format(e.doneBytes) + '( ' + BytesPerSecondFormat.formatAsBitsPerSecond(e.avgBytesPerSec) + ')';
73
+ }
74
+ else {
75
+ let progress = BytesFormat.format(e.doneBytes) + ' of ' + BytesFormat.format(e.totalBytes);
76
+ if (e.bytesPerSec) {
77
+ progress += ' (' + BytesPerSecondFormat.formatAsBitsPerSecond(e.bytesPerSec) + ')';
55
78
  }
56
- }));
79
+ return progress;
80
+ }
57
81
  }
58
82
  }
59
83
  HttpDataTransferComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: HttpDataTransferComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
60
- HttpDataTransferComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: HttpDataTransferComponent, selector: "elder-data-transfer", inputs: { transfer: "transfer" }, ngImport: i0, template: "\n\n<div *ngIf=\"($state | async) as state\"\n class=\"layout-row place-start-center gap-lg flex p-md transfer\"\n>\n\n <div class=\"layout-col place-center-center flex-10\">\n <mat-icon class=\"noselect\">\n {{state.isCompleted ? 'check' : 'attachment'}}\n </mat-icon>\n\n <!--\n <mat-icon\n *ngIf=\"!(statusOf(file)?.error | async) && (statusOf(file)?.progress | async) === 100\"\n class=\"green-icon\"\n >check</mat-icon>\n -->\n\n </div>\n\n\n <div class=\"layout-col flex-80\" style=\"overflow: hidden\">\n\n <span class=\"mat-subtitle-2 noselect title\">{{transfer.name}}</span>\n\n <mat-progress-bar\n [matTooltip]=\"state.error?.message\"\n [color]=\"(state.error ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\"\n ></mat-progress-bar>\n\n <span class=\"mat-caption noselect\">{{($detail | async)}}</span>\n\n </div>\n\n\n <div class=\"layout-col place-center-center flex-10\">\n <button mat-icon-button type=\"button\"\n (click)=\"transfer.abort()\" [disabled]=\"state.isDone\">\n <mat-icon>\n close\n </mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".transfer{overflow:hidden}.title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-bottom:5px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
84
+ HttpDataTransferComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: HttpDataTransferComponent, selector: "elder-data-transfer", inputs: { transfer: "transfer" }, ngImport: i0, template: "\n\n<div *ngIf=\"($state | async) as state\"\n class=\"layout-row place-start-center gap-lg flex p-md transfer\"\n>\n\n <div class=\"layout-col place-center-center flex-10\">\n <mat-icon class=\"noselect\">\n {{statusIcon(state)}}\n </mat-icon>\n\n <!--\n <mat-icon\n *ngIf=\"!(statusOf(file)?.error | async) && (statusOf(file)?.progress | async) === 100\"\n class=\"green-icon\"\n >check</mat-icon>\n -->\n\n </div>\n\n\n <div class=\"layout-col flex-80\" style=\"overflow: hidden\">\n\n <span class=\"mat-subtitle-2 noselect title\">{{transfer.name}}</span>\n\n <mat-progress-bar\n [matTooltip]=\"state.error?.message\"\n [color]=\"(state.error ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\"\n ></mat-progress-bar>\n\n <span class=\"mat-caption noselect\">{{($detail | async)}}</span>\n\n </div>\n\n\n <div class=\"layout-col place-center-center flex-10\">\n <button mat-icon-button type=\"button\"\n (click)=\"transfer.abort()\" [disabled]=\"state.isDone\">\n <mat-icon>\n close\n </mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".transfer{overflow:hidden}.title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-bottom:5px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
61
85
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: HttpDataTransferComponent, decorators: [{
62
86
  type: Component,
63
- args: [{ selector: 'elder-data-transfer', changeDetection: ChangeDetectionStrategy.OnPush, template: "\n\n<div *ngIf=\"($state | async) as state\"\n class=\"layout-row place-start-center gap-lg flex p-md transfer\"\n>\n\n <div class=\"layout-col place-center-center flex-10\">\n <mat-icon class=\"noselect\">\n {{state.isCompleted ? 'check' : 'attachment'}}\n </mat-icon>\n\n <!--\n <mat-icon\n *ngIf=\"!(statusOf(file)?.error | async) && (statusOf(file)?.progress | async) === 100\"\n class=\"green-icon\"\n >check</mat-icon>\n -->\n\n </div>\n\n\n <div class=\"layout-col flex-80\" style=\"overflow: hidden\">\n\n <span class=\"mat-subtitle-2 noselect title\">{{transfer.name}}</span>\n\n <mat-progress-bar\n [matTooltip]=\"state.error?.message\"\n [color]=\"(state.error ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\"\n ></mat-progress-bar>\n\n <span class=\"mat-caption noselect\">{{($detail | async)}}</span>\n\n </div>\n\n\n <div class=\"layout-col place-center-center flex-10\">\n <button mat-icon-button type=\"button\"\n (click)=\"transfer.abort()\" [disabled]=\"state.isDone\">\n <mat-icon>\n close\n </mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".transfer{overflow:hidden}.title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-bottom:5px}\n"] }]
87
+ args: [{ selector: 'elder-data-transfer', changeDetection: ChangeDetectionStrategy.OnPush, template: "\n\n<div *ngIf=\"($state | async) as state\"\n class=\"layout-row place-start-center gap-lg flex p-md transfer\"\n>\n\n <div class=\"layout-col place-center-center flex-10\">\n <mat-icon class=\"noselect\">\n {{statusIcon(state)}}\n </mat-icon>\n\n <!--\n <mat-icon\n *ngIf=\"!(statusOf(file)?.error | async) && (statusOf(file)?.progress | async) === 100\"\n class=\"green-icon\"\n >check</mat-icon>\n -->\n\n </div>\n\n\n <div class=\"layout-col flex-80\" style=\"overflow: hidden\">\n\n <span class=\"mat-subtitle-2 noselect title\">{{transfer.name}}</span>\n\n <mat-progress-bar\n [matTooltip]=\"state.error?.message\"\n [color]=\"(state.error ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\"\n ></mat-progress-bar>\n\n <span class=\"mat-caption noselect\">{{($detail | async)}}</span>\n\n </div>\n\n\n <div class=\"layout-col place-center-center flex-10\">\n <button mat-icon-button type=\"button\"\n (click)=\"transfer.abort()\" [disabled]=\"state.isDone\">\n <mat-icon>\n close\n </mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".transfer{overflow:hidden}.title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-bottom:5px}\n"] }]
64
88
  }], ctorParameters: function () { return []; }, propDecorators: { transfer: [{
65
89
  type: Input
66
90
  }] } });
67
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-data-transfer.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAC,MAAM,eAAe,CAAC;AAExE,OAAO,EAAC,GAAG,EAAC,MAAM,gBAAgB,CAAC;AACnC,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AAGnD,OAAO,EAAC,oBAAoB,EAAC,MAAM,gDAAgD,CAAC;AACpF,OAAO,EAAC,WAAW,EAAC,MAAM,qCAAqC,CAAC;;;;;;;AAQhE,MAAM,OAAO,yBAAyB;IAcpC;;;;gFAI4E;IAE5E;QAlBA;;;;oFAI4E;QAEpE,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,2BAA2B,CAAC,CAAC;IAatE,CAAC;IAED;;;;gFAI4E;IAE5E,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IACW,QAAQ,CAAC,KAAuB;QACzC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAEvB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAE3B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAC9B,GAAG,CAAC,KAAK,CAAC,EAAE;YAEV,IAAI,KAAK,CAAC,SAAS,EAAE;gBAAE,OAAO,WAAW,CAAC;aAAE;YAC5C,IAAI,KAAK,CAAC,SAAS,EAAE;gBAAE,OAAO,SAAS,CAAC;aAAE;YAE1C,MAAM,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC;YAEzB,8BAA8B;YAC9B,IAAI,CAAC,CAAC,WAAW,KAAK,GAAG,EAAE;gBACzB,OAAO,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,IAAI,GAAG,oBAAoB,CAAC,qBAAqB,CAAC,CAAC,CAAC,cAAc,CAAC,GAAG,GAAG,CAAC;aACpH;iBAAM;gBACL,IAAI,QAAQ,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;gBAE3F,IAAI,CAAC,CAAC,WAAW,EAAE;oBACjB,QAAQ,IAAI,IAAI,GAAG,oBAAoB,CAAC,qBAAqB,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,GAAG,CAAC;iBACpF;gBACD,OAAO,QAAQ,CAAC;aACjB;QACH,CAAC,CAAC,CAEH,CAAC;IAEJ,CAAC;;sHA9DU,yBAAyB;0GAAzB,yBAAyB,6FCftC,2qCA+CA;2FDhCa,yBAAyB;kBANrC,SAAS;+BACE,qBAAqB,mBAGd,uBAAuB,CAAC,MAAM;0EAoCpC,QAAQ;sBADlB,KAAK","sourcesContent":["import {ChangeDetectionStrategy, Component, Input} from '@angular/core';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {HttpDataTransfer} from '../../../common/http/transfer/http-data-transfer';\nimport {DataTransferState} from '../../../common/http/transfer/data-transfer-state';\nimport {BytesPerSecondFormat} from '../../../common/format/bytes-per-second-format';\nimport {BytesFormat} from '../../../common/format/bytes-format';\n\n@Component({\n  selector: 'elder-data-transfer',\n  templateUrl: './http-data-transfer.component.html',\n  styleUrls: ['./http-data-transfer.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class HttpDataTransferComponent {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private logger = LoggerFactory.getLogger('HttpDataTransferComponent');\n  private _transfer: HttpDataTransfer;\n\n  public $state: Observable<DataTransferState>;\n  public $detail: Observable<string>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get transfer(): HttpDataTransfer {\n    return this._transfer;\n  }\n\n  @Input()\n  public set transfer(value: HttpDataTransfer) {\n    this._transfer = value;\n\n    this.$state = value.state$;\n\n    this.$detail = value.state$.pipe(\n      map(state => {\n\n        if (state.isAborted) { return 'Canceled.'; }\n        if (state.hasFailed) { return 'Failed!'; }\n\n        const e = state.progress;\n\n        // 100Mb of 332Mb (1200Kb/sec)\n        if (e.percentDone === 100) {\n          return BytesFormat.format(e.doneBytes) + '( ' + BytesPerSecondFormat.formatAsBitsPerSecond(e.avgBytesPerSec) + ')';\n        } else {\n          let progress = BytesFormat.format(e.doneBytes) + ' of ' + BytesFormat.format(e.totalBytes);\n\n          if (e.bytesPerSec) {\n            progress += ' (' + BytesPerSecondFormat.formatAsBitsPerSecond(e.bytesPerSec) + ')';\n          }\n          return progress;\n        }\n      }),\n      // tap(message => this.logger.info(message))\n    );\n\n  }\n\n\n\n}\n","\n\n<div *ngIf=\"($state | async) as state\"\n  class=\"layout-row place-start-center gap-lg flex p-md transfer\"\n>\n\n  <div class=\"layout-col place-center-center flex-10\">\n    <mat-icon class=\"noselect\">\n      {{state.isCompleted ? 'check' : 'attachment'}}\n    </mat-icon>\n\n    <!--\n    <mat-icon\n      *ngIf=\"!(statusOf(file)?.error | async) && (statusOf(file)?.progress | async) === 100\"\n      class=\"green-icon\"\n    >check</mat-icon>\n    -->\n\n  </div>\n\n\n  <div class=\"layout-col flex-80\" style=\"overflow: hidden\">\n\n    <span class=\"mat-subtitle-2 noselect title\">{{transfer.name}}</span>\n\n    <mat-progress-bar\n      [matTooltip]=\"state.error?.message\"\n      [color]=\"(state.error ? 'warn' : '')\"\n      mode=\"determinate\"\n      [value]=\"state.progress.percentDone\"\n    ></mat-progress-bar>\n\n    <span class=\"mat-caption noselect\">{{($detail | async)}}</span>\n\n  </div>\n\n\n  <div class=\"layout-col place-center-center flex-10\">\n    <button mat-icon-button type=\"button\"\n            (click)=\"transfer.abort()\" [disabled]=\"state.isDone\">\n      <mat-icon>\n        close\n      </mat-icon>\n    </button>\n  </div>\n\n</div>\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-data-transfer.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAC,MAAM,eAAe,CAAC;AACxE,OAAO,EAAC,eAAe,EAAc,SAAS,EAAC,MAAM,MAAM,CAAC;AAC5D,OAAO,EAAC,MAAM,EAAE,GAAG,EAAC,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AAGnD,OAAO,EAAC,oBAAoB,EAAC,MAAM,gDAAgD,CAAC;AACpF,OAAO,EAAC,WAAW,EAAC,MAAM,qCAAqC,CAAC;AAChE,OAAO,EAAC,kBAAkB,EAAC,MAAM,oDAAoD,CAAC;;;;;;;AAQtF,MAAM,OAAO,yBAAyB;IAcpC;;;;gFAI4E;IAE5E;QAlBA;;;;oFAI4E;QAEpE,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACxD,eAAU,GAAG,IAAI,eAAe,CAAmB,IAAI,CAAC,CAAC;QAY/D,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAChC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAC9B,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,CACvC,CAAC;QACF,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAC7B,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC,CAEjD,CAAC;IACJ,CAAC;IAGD;;;;gFAI4E;IAE5E,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;IAED,IACW,QAAQ,CAAC,KAAuB;QACzC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED;;;;gFAI4E;IAErE,UAAU,CAAC,KAAwB;QACxC,QAAQ,KAAK,CAAC,MAAM,EAAE;YACpB,KAAK,kBAAkB,CAAC,OAAO,CAAC,CAAC,OAAQ,SAAS,CAAC;YACnD,KAAK,kBAAkB,CAAC,YAAY,CAAC,CAAC,OAAQ,YAAY,CAAC;YAC3D,KAAK,kBAAkB,CAAC,SAAS,CAAC,CAAC,OAAQ,OAAO,CAAC;YACnD,KAAK,kBAAkB,CAAC,OAAO,CAAC,CAAC,OAAQ,OAAO,CAAC;YACjD,KAAK,kBAAkB,CAAC,MAAM,CAAC,CAAC,OAAQ,OAAO,CAAC;YAChD,OAAO,CAAC,CAAC,OAAO,cAAc,CAAA;SAC/B;IACH,CAAC;IAED;;;;gFAI4E;IAEpE,sBAAsB,CAAC,KAAwB;QACrD,IAAI,KAAK,CAAC,SAAS,EAAE;YAAE,OAAO,WAAW,CAAC;SAAE;QAC5C,IAAI,KAAK,CAAC,SAAS,EAAE;YAAE,OAAO,SAAS,CAAC;SAAE;QAE1C,MAAM,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC;QAEzB,8BAA8B;QAC9B,IAAI,CAAC,CAAC,WAAW,KAAK,GAAG,EAAE;YACzB,OAAO,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,IAAI,GAAG,oBAAoB,CAAC,qBAAqB,CAAC,CAAC,CAAC,cAAc,CAAC,GAAG,GAAG,CAAC;SACpH;aAAM;YACL,IAAI,QAAQ,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;YAE3F,IAAI,CAAC,CAAC,WAAW,EAAE;gBACjB,QAAQ,IAAI,IAAI,GAAG,oBAAoB,CAAC,qBAAqB,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,GAAG,CAAC;aACpF;YACD,OAAO,QAAQ,CAAC;SACjB;IACH,CAAC;;sHAvFU,yBAAyB;0GAAzB,yBAAyB,6FChBtC,kpCA+CA;2FD/Ba,yBAAyB;kBANrC,SAAS;+BACE,qBAAqB,mBAGd,uBAAuB,CAAC,MAAM;0EA6CpC,QAAQ;sBADlB,KAAK","sourcesContent":["import {ChangeDetectionStrategy, Component, Input} from '@angular/core';\nimport {BehaviorSubject, Observable, switchMap} from 'rxjs';\nimport {filter, map} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {HttpDataTransfer} from '../../../common/http/transfer/http-data-transfer';\nimport {DataTransferState} from '../../../common/http/transfer/data-transfer-state';\nimport {BytesPerSecondFormat} from '../../../common/format/bytes-per-second-format';\nimport {BytesFormat} from '../../../common/format/bytes-format';\nimport {DataTransferStatus} from '../../../common/http/transfer/data-transfer-status';\n\n@Component({\n  selector: 'elder-data-transfer',\n  templateUrl: './http-data-transfer.component.html',\n  styleUrls: ['./http-data-transfer.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class HttpDataTransferComponent {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private logger = LoggerFactory.getLogger(this.constructor.name);\n  private _transfer$ = new BehaviorSubject<HttpDataTransfer>(null);\n\n  public readonly $state: Observable<DataTransferState>;\n  public readonly $detail: Observable<string>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    this.$state = this._transfer$.pipe(\n      filter(transfer => !!transfer),\n      switchMap(transfer => transfer.state$)\n    );\n    this.$detail = this.$state.pipe(\n      map(state => this.renderTransferProgress(state)),\n      // tap(message => this.logger.info(message))\n    );\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get transfer(): HttpDataTransfer {\n    return this._transfer$.getValue();\n  }\n\n  @Input()\n  public set transfer(value: HttpDataTransfer) {\n    this._transfer$.next(value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public statusIcon(state: DataTransferState): string {\n    switch (state.status) {\n      case DataTransferStatus.Pending: return  'pending';\n      case DataTransferStatus.Transferring: return  'cloud_sync';\n      case DataTransferStatus.Completed: return  'check';\n      case DataTransferStatus.Aborted: return  'block';\n      case DataTransferStatus.Failed: return  'error';\n      default: return 'help_outline'\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private renderTransferProgress(state: DataTransferState): string {\n    if (state.isAborted) { return 'Canceled.'; }\n    if (state.hasFailed) { return 'Failed!'; }\n\n    const e = state.progress;\n\n    // 100Mb of 332Mb (1200Kb/sec)\n    if (e.percentDone === 100) {\n      return BytesFormat.format(e.doneBytes) + '( ' + BytesPerSecondFormat.formatAsBitsPerSecond(e.avgBytesPerSec) + ')';\n    } else {\n      let progress = BytesFormat.format(e.doneBytes) + ' of ' + BytesFormat.format(e.totalBytes);\n\n      if (e.bytesPerSec) {\n        progress += ' (' + BytesPerSecondFormat.formatAsBitsPerSecond(e.bytesPerSec) + ')';\n      }\n      return progress;\n    }\n  }\n\n}\n","\n\n<div *ngIf=\"($state | async) as state\"\n  class=\"layout-row place-start-center gap-lg flex p-md transfer\"\n>\n\n  <div class=\"layout-col place-center-center flex-10\">\n    <mat-icon class=\"noselect\">\n      {{statusIcon(state)}}\n    </mat-icon>\n\n    <!--\n    <mat-icon\n      *ngIf=\"!(statusOf(file)?.error | async) && (statusOf(file)?.progress | async) === 100\"\n      class=\"green-icon\"\n    >check</mat-icon>\n    -->\n\n  </div>\n\n\n  <div class=\"layout-col flex-80\" style=\"overflow: hidden\">\n\n    <span class=\"mat-subtitle-2 noselect title\">{{transfer.name}}</span>\n\n    <mat-progress-bar\n      [matTooltip]=\"state.error?.message\"\n      [color]=\"(state.error ? 'warn' : '')\"\n      mode=\"determinate\"\n      [value]=\"state.progress.percentDone\"\n    ></mat-progress-bar>\n\n    <span class=\"mat-caption noselect\">{{($detail | async)}}</span>\n\n  </div>\n\n\n  <div class=\"layout-col place-center-center flex-10\">\n    <button mat-icon-button type=\"button\"\n            (click)=\"transfer.abort()\" [disabled]=\"state.isDone\">\n      <mat-icon>\n        close\n      </mat-icon>\n    </button>\n  </div>\n\n</div>\n"]}
@@ -14,13 +14,6 @@ export class HttpDataTransferOverviewComponent {
14
14
  **************************************************************************/
15
15
  constructor(transferService) {
16
16
  this.transferService = transferService;
17
- }
18
- /***************************************************************************
19
- * *
20
- * Life Cycle *
21
- * *
22
- **************************************************************************/
23
- ngOnInit() {
24
17
  this.transfers$ = this.transferService.transfers;
25
18
  }
26
19
  }
@@ -30,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImpor
30
23
  type: Component,
31
24
  args: [{ selector: 'elder-data-transfer-overview', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-card appearance=\"raised\" class=\"layout-col full\">\n\n <div class=\"layout-col flex\" *ngIf=\"transfers$ | async as transfers\">\n\n <div *ngIf=\"transfers.length > 0 else noData\" class=\"layout-col flex scroll-list\">\n <elder-data-transfer class=\"flex-none\"\n *ngFor=\"let transfer of transfers\"\n [transfer]=\"transfer\">\n </elder-data-transfer>\n </div>\n\n <ng-template #noData>\n <div class=\"layout-col place-center-center flex\">\n <span class=\"mat-subtitle-2 noselect\" style=\"color: gray\">No data transfers.</span>\n </div>\n </ng-template>\n\n </div>\n\n\n <mat-toolbar class=\"flex-none mat-elevation-z5\">\n <elder-data-transfer-aggregate class=\"flex\" [hiddenWhenInactive]=\"false\"></elder-data-transfer-aggregate>\n </mat-toolbar>\n</mat-card>\n", styles: [":host{min-width:0;min-height:0}.scroll-list{overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.scroll-fix{min-width:0;min-height:0}\n"] }]
32
25
  }], ctorParameters: function () { return [{ type: i1.ElderDataTransferService }]; } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1kYXRhLXRyYW5zZmVyLW92ZXJ2aWV3LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvZGF0YS10cmFuc2Zlci9odHRwLWRhdGEtdHJhbnNmZXItb3ZlcnZpZXcvaHR0cC1kYXRhLXRyYW5zZmVyLW92ZXJ2aWV3LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvZGF0YS10cmFuc2Zlci9odHRwLWRhdGEtdHJhbnNmZXItb3ZlcnZpZXcvaHR0cC1kYXRhLXRyYW5zZmVyLW92ZXJ2aWV3LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQVMsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7O0FBV3pFLE1BQU0sT0FBTyxpQ0FBaUM7SUFVNUM7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ1UsZUFBeUM7UUFBekMsb0JBQWUsR0FBZixlQUFlLENBQTBCO0lBQy9DLENBQUM7SUFFTDs7OztnRkFJNEU7SUFFckUsUUFBUTtRQUNiLElBQUksQ0FBQyxVQUFVLEdBQUksSUFBSSxDQUFDLGVBQWUsQ0FBQyxTQUFTLENBQUM7SUFDcEQsQ0FBQzs7OEhBNUJVLGlDQUFpQztrSEFBakMsaUNBQWlDLG9FQ1g5QywwMkJBd0JBOzJGRGJhLGlDQUFpQztrQkFON0MsU0FBUzsrQkFDRSw4QkFBOEIsbUJBR3ZCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge09ic2VydmFibGV9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtFbGRlckRhdGFUcmFuc2ZlclNlcnZpY2V9IGZyb20gJy4uL2VsZGVyLWRhdGEtdHJhbnNmZXIuc2VydmljZSc7XG5pbXBvcnQge0h0dHBEYXRhVHJhbnNmZXJ9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9odHRwL3RyYW5zZmVyL2h0dHAtZGF0YS10cmFuc2Zlcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VsZGVyLWRhdGEtdHJhbnNmZXItb3ZlcnZpZXcnLFxuICB0ZW1wbGF0ZVVybDogJy4vaHR0cC1kYXRhLXRyYW5zZmVyLW92ZXJ2aWV3LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vaHR0cC1kYXRhLXRyYW5zZmVyLW92ZXJ2aWV3LmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEh0dHBEYXRhVHJhbnNmZXJPdmVydmlld0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIEZpZWxkcyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIHRyYW5zZmVycyQ6IE9ic2VydmFibGU8SHR0cERhdGFUcmFuc2ZlcltdPjtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogQ29uc3RydWN0b3IgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHRyYW5zZmVyU2VydmljZTogRWxkZXJEYXRhVHJhbnNmZXJTZXJ2aWNlXG4gICkgeyB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIExpZmUgQ3ljbGUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMudHJhbnNmZXJzJCA9ICB0aGlzLnRyYW5zZmVyU2VydmljZS50cmFuc2ZlcnM7XG4gIH1cbn1cbiIsIjxtYXQtY2FyZCBhcHBlYXJhbmNlPVwicmFpc2VkXCIgY2xhc3M9XCJsYXlvdXQtY29sIGZ1bGxcIj5cblxuICA8ZGl2IGNsYXNzPVwibGF5b3V0LWNvbCBmbGV4XCIgKm5nSWY9XCJ0cmFuc2ZlcnMkIHwgYXN5bmMgYXMgdHJhbnNmZXJzXCI+XG5cbiAgICA8ZGl2ICpuZ0lmPVwidHJhbnNmZXJzLmxlbmd0aCA+IDAgZWxzZSBub0RhdGFcIiBjbGFzcz1cImxheW91dC1jb2wgZmxleCBzY3JvbGwtbGlzdFwiPlxuICAgICAgPGVsZGVyLWRhdGEtdHJhbnNmZXIgY2xhc3M9XCJmbGV4LW5vbmVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICpuZ0Zvcj1cImxldCB0cmFuc2ZlciBvZiB0cmFuc2ZlcnNcIlxuICAgICAgICAgICAgICAgICAgICAgICAgIFt0cmFuc2Zlcl09XCJ0cmFuc2ZlclwiPlxuICAgICAgPC9lbGRlci1kYXRhLXRyYW5zZmVyPlxuICAgIDwvZGl2PlxuXG4gICAgPG5nLXRlbXBsYXRlICNub0RhdGE+XG4gICAgICA8ZGl2IGNsYXNzPVwibGF5b3V0LWNvbCBwbGFjZS1jZW50ZXItY2VudGVyIGZsZXhcIj5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJtYXQtc3VidGl0bGUtMiBub3NlbGVjdFwiIHN0eWxlPVwiY29sb3I6IGdyYXlcIj5ObyBkYXRhIHRyYW5zZmVycy48L3NwYW4+XG4gICAgICA8L2Rpdj5cbiAgICA8L25nLXRlbXBsYXRlPlxuXG4gIDwvZGl2PlxuXG5cbiAgPG1hdC10b29sYmFyIGNsYXNzPVwiZmxleC1ub25lIG1hdC1lbGV2YXRpb24tejVcIj5cbiAgICA8ZWxkZXItZGF0YS10cmFuc2Zlci1hZ2dyZWdhdGUgY2xhc3M9XCJmbGV4XCIgW2hpZGRlbldoZW5JbmFjdGl2ZV09XCJmYWxzZVwiPjwvZWxkZXItZGF0YS10cmFuc2Zlci1hZ2dyZWdhdGU+XG4gIDwvbWF0LXRvb2xiYXI+XG48L21hdC1jYXJkPlxuIl19
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1kYXRhLXRyYW5zZmVyLW92ZXJ2aWV3LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvZGF0YS10cmFuc2Zlci9odHRwLWRhdGEtdHJhbnNmZXItb3ZlcnZpZXcvaHR0cC1kYXRhLXRyYW5zZmVyLW92ZXJ2aWV3LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvZGF0YS10cmFuc2Zlci9odHRwLWRhdGEtdHJhbnNmZXItb3ZlcnZpZXcvaHR0cC1kYXRhLXRyYW5zZmVyLW92ZXJ2aWV3LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQVMsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7O0FBV3pFLE1BQU0sT0FBTyxpQ0FBaUM7SUFVNUM7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ1UsZUFBeUM7UUFBekMsb0JBQWUsR0FBZixlQUFlLENBQTBCO1FBRWpELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxTQUFTLENBQUM7SUFDbkQsQ0FBQzs7OEhBcEJVLGlDQUFpQztrSEFBakMsaUNBQWlDLG9FQ1g5QywwMkJBd0JBOzJGRGJhLGlDQUFpQztrQkFON0MsU0FBUzsrQkFDRSw4QkFBOEIsbUJBR3ZCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge09ic2VydmFibGV9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtFbGRlckRhdGFUcmFuc2ZlclNlcnZpY2V9IGZyb20gJy4uL2VsZGVyLWRhdGEtdHJhbnNmZXIuc2VydmljZSc7XG5pbXBvcnQge0h0dHBEYXRhVHJhbnNmZXJ9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9odHRwL3RyYW5zZmVyL2h0dHAtZGF0YS10cmFuc2Zlcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VsZGVyLWRhdGEtdHJhbnNmZXItb3ZlcnZpZXcnLFxuICB0ZW1wbGF0ZVVybDogJy4vaHR0cC1kYXRhLXRyYW5zZmVyLW92ZXJ2aWV3LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vaHR0cC1kYXRhLXRyYW5zZmVyLW92ZXJ2aWV3LmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEh0dHBEYXRhVHJhbnNmZXJPdmVydmlld0NvbXBvbmVudCB7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIEZpZWxkcyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIHJlYWRvbmx5IHRyYW5zZmVycyQ6IE9ic2VydmFibGU8SHR0cERhdGFUcmFuc2ZlcltdPjtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogQ29uc3RydWN0b3IgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHRyYW5zZmVyU2VydmljZTogRWxkZXJEYXRhVHJhbnNmZXJTZXJ2aWNlXG4gICkge1xuICAgIHRoaXMudHJhbnNmZXJzJCA9IHRoaXMudHJhbnNmZXJTZXJ2aWNlLnRyYW5zZmVycztcbiAgfVxufVxuIiwiPG1hdC1jYXJkIGFwcGVhcmFuY2U9XCJyYWlzZWRcIiBjbGFzcz1cImxheW91dC1jb2wgZnVsbFwiPlxuXG4gIDxkaXYgY2xhc3M9XCJsYXlvdXQtY29sIGZsZXhcIiAqbmdJZj1cInRyYW5zZmVycyQgfCBhc3luYyBhcyB0cmFuc2ZlcnNcIj5cblxuICAgIDxkaXYgKm5nSWY9XCJ0cmFuc2ZlcnMubGVuZ3RoID4gMCBlbHNlIG5vRGF0YVwiIGNsYXNzPVwibGF5b3V0LWNvbCBmbGV4IHNjcm9sbC1saXN0XCI+XG4gICAgICA8ZWxkZXItZGF0YS10cmFuc2ZlciBjbGFzcz1cImZsZXgtbm9uZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgKm5nRm9yPVwibGV0IHRyYW5zZmVyIG9mIHRyYW5zZmVyc1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAgW3RyYW5zZmVyXT1cInRyYW5zZmVyXCI+XG4gICAgICA8L2VsZGVyLWRhdGEtdHJhbnNmZXI+XG4gICAgPC9kaXY+XG5cbiAgICA8bmctdGVtcGxhdGUgI25vRGF0YT5cbiAgICAgIDxkaXYgY2xhc3M9XCJsYXlvdXQtY29sIHBsYWNlLWNlbnRlci1jZW50ZXIgZmxleFwiPlxuICAgICAgICA8c3BhbiBjbGFzcz1cIm1hdC1zdWJ0aXRsZS0yIG5vc2VsZWN0XCIgc3R5bGU9XCJjb2xvcjogZ3JheVwiPk5vIGRhdGEgdHJhbnNmZXJzLjwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgIDwvbmctdGVtcGxhdGU+XG5cbiAgPC9kaXY+XG5cblxuICA8bWF0LXRvb2xiYXIgY2xhc3M9XCJmbGV4LW5vbmUgbWF0LWVsZXZhdGlvbi16NVwiPlxuICAgIDxlbGRlci1kYXRhLXRyYW5zZmVyLWFnZ3JlZ2F0ZSBjbGFzcz1cImZsZXhcIiBbaGlkZGVuV2hlbkluYWN0aXZlXT1cImZhbHNlXCI+PC9lbGRlci1kYXRhLXRyYW5zZmVyLWFnZ3JlZ2F0ZT5cbiAgPC9tYXQtdG9vbGJhcj5cbjwvbWF0LWNhcmQ+XG4iXX0=
@@ -81,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImpor
81
81
  }], windowOpenIn: [{
82
82
  type: Input
83
83
  }] } });
84
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-url-fragment-switcher.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAS,MAAM,eAAe,CAAC;AAChF,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AAEnD,OAAO,EAAC,eAAe,EAAiB,MAAM,MAAM,CAAC;AAErD,OAAO,EAAC,gBAAgB,EAAC,MAAM,uBAAuB,CAAC;;;;;;;AAQvD,MAAM,OAAO,iCAAiC;IAwC5C;;;;gFAI4E;IAC5E;QA1CiB,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,mCAAmC,CAAC,CAAC;QAEvF;;;;oFAI4E;QAE5D,YAAO,GAAY,IAAI,CAAC;QAOxC;;WAEG;QAEI,aAAQ,GAAW,IAAI,MAAM,CAAC,YAAY,CAAC,CAAC;QAQ5C,oBAAe,GAAW,CAAC,CAAC;QAEnC;;WAEG;QAEI,iBAAY,GAAW,OAAO,CAAC;QAEtB,uBAAkB,GAAG,IAAI,eAAe,CAAC,IAAI,gBAAgB,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,CAAC;IAS/F,CAAC;IAGD;;;;gFAI4E;IAE5E,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CACtC,CAAC,CAAC,EAAE;gBACF,IAAI;oBACF,OAAO,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;iBACtF;gBAAC,OAAO,CAAC,EAAE;oBACV,OAAO,KAAK,CAAC;iBACd;YACH,CAAC,CAAC,CAAC;YACL,IAAI,WAAW,EAAE;gBACf,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAC3C;SACF;IAEH,CAAC;IAGD;;;;gFAI4E;IAErE,oBAAoB,CAAC,WAAmB;QAC7C,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC/B,MAAM,CAAC,IAAI,CACT,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,WAAW,CAAC,EACzG,IAAI,CAAC,YAAY,CAAC,CAAC;IACvB,CAAC;;8HArFU,iCAAiC;kHAAjC,iCAAiC,yNCb9C,ogCAyBA;2FDZa,iCAAiC;kBAN7C,SAAS;+BACE,6BAA6B,mBAGtB,uBAAuB,CAAC,MAAM;0EAa/B,OAAO;sBADtB,KAAK;gBAOC,YAAY;sBADlB,KAAK;gBAMC,QAAQ;sBADd,KAAK;gBASC,eAAe;sBANrB,KAAK;;sBAKL,KAAK;gBAOC,YAAY;sBADlB,KAAK","sourcesContent":["import {ChangeDetectionStrategy, Component, Input, OnInit} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ActivatedRoute, Router, UrlSegment} from '@angular/router';\nimport {BehaviorSubject, Observable, of} from 'rxjs';\nimport {filter, first, flatMap, map, tap} from 'rxjs/operators';\nimport {ElderUrlFragment} from '../elder-url-fragment';\n\n@Component({\n  selector: 'elder-url-fragment-switcher',\n  templateUrl: './elder-url-fragment-switcher.component.html',\n  styleUrls: ['./elder-url-fragment-switcher.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderUrlFragmentSwitcherComponent implements OnInit {\n\n\n  private readonly logger = LoggerFactory.getLogger('ElderUrlFragmentSwitcherComponent');\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n  @Input()\n  public readonly disable: boolean = true;\n\n  /*\n    List of url fragments which can replace a part of the window location\n   */\n  @Input()\n  public urlFragments: ElderUrlFragment[];\n  /*\n  Regex which matches the part of the url which will get replaced\n   */\n  @Input()\n  public urlRegex: RegExp = new RegExp('[\\.](\\\\w+)');\n\n  @Input()\n\n  /*\n  Index of the regex group which will be replaced\n   */\n  @Input()\n  public regexArrayIndex: number = 0;\n\n  /*\n  Window which will open the created url\n   */\n  @Input()\n  public windowOpenIn: string = \"_self\";\n\n  public readonly activeUrlFragment$ = new BehaviorSubject(new ElderUrlFragment('No match', ''));\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n  constructor() {\n\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  ngOnInit(): void {\n    if (!this.disable) {\n      let urlFragment = this.urlFragments.find(\n        c => {\n          try {\n            return c.fragment === this.urlRegex.exec(window.location.href)[this.regexArrayIndex];\n          } catch (e) {\n            return false;\n          }\n        });\n      if (urlFragment) {\n        this.activeUrlFragment$.next(urlFragment);\n      }\n    }\n\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public setActiveUrlFragment(urlFragment: string) {\n    this.logger.debug(urlFragment);\n    window.open(\n      window.location.href.replace(this.urlRegex.exec(window.location.href)[this.regexArrayIndex], urlFragment),\n      this.windowOpenIn);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n}\n","<ng-container *ngIf=\"activeUrlFragment$ | async as activeUrlFragment\">\n  <elder-button-group>\n    <button mat-stroked-button type=\"button\" disabled [ngStyle]=\"{'background-color': activeUrlFragment.color}\">\n      <div class=\"layout-col\">\n        <span *ngIf=\"!disable\" class=\"caption\">{{activeUrlFragment.name}}</span>\n      </div>\n    </button>\n\n    <button mat-stroked-button type=\"button\"\n            *ngIf=\"!disable \"  [matMenuTriggerFor]=\"fragmentMenu\"\n            [ngStyle]=\"{'background-color': activeUrlFragment.color}\">\n      <mat-icon>flip_camera_android</mat-icon>\n    </button>\n  </elder-button-group>\n</ng-container>\n\n<mat-menu #fragmentMenu=\"matMenu\">\n  <button mat-menu-item type=\"button\"\n          *ngFor=\"let urlFragment of urlFragments\"\n          (click)=\"setActiveUrlFragment(urlFragment.fragment)\">\n    <mat-icon [ngStyle]=\"{'color': urlFragment.color}\">flip_camera_android</mat-icon>\n    <span>{{  urlFragment.name }}</span>\n  </button>\n\n</mat-menu>\n"]}
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-url-fragment-switcher.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAS,MAAM,eAAe,CAAC;AAChF,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,eAAe,EAAC,MAAM,MAAM,CAAC;AACrC,OAAO,EAAC,gBAAgB,EAAC,MAAM,uBAAuB,CAAC;;;;;;;AAQvD,MAAM,OAAO,iCAAiC;IAwC5C;;;;gFAI4E;IAC5E;QA1CiB,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,mCAAmC,CAAC,CAAC;QAEvF;;;;oFAI4E;QAE5D,YAAO,GAAY,IAAI,CAAC;QAOxC;;WAEG;QAEI,aAAQ,GAAW,IAAI,MAAM,CAAC,YAAY,CAAC,CAAC;QAQ5C,oBAAe,GAAW,CAAC,CAAC;QAEnC;;WAEG;QAEI,iBAAY,GAAW,OAAO,CAAC;QAEtB,uBAAkB,GAAG,IAAI,eAAe,CAAC,IAAI,gBAAgB,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,CAAC;IAS/F,CAAC;IAGD;;;;gFAI4E;IAE5E,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CACtC,CAAC,CAAC,EAAE;gBACF,IAAI;oBACF,OAAO,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;iBACtF;gBAAC,OAAO,CAAC,EAAE;oBACV,OAAO,KAAK,CAAC;iBACd;YACH,CAAC,CAAC,CAAC;YACL,IAAI,WAAW,EAAE;gBACf,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAC3C;SACF;IAEH,CAAC;IAGD;;;;gFAI4E;IAErE,oBAAoB,CAAC,WAAmB;QAC7C,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC/B,MAAM,CAAC,IAAI,CACT,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,WAAW,CAAC,EACzG,IAAI,CAAC,YAAY,CAAC,CAAC;IACvB,CAAC;;8HArFU,iCAAiC;kHAAjC,iCAAiC,yNCX9C,ogCAyBA;2FDda,iCAAiC;kBAN7C,SAAS;+BACE,6BAA6B,mBAGtB,uBAAuB,CAAC,MAAM;0EAa/B,OAAO;sBADtB,KAAK;gBAOC,YAAY;sBADlB,KAAK;gBAMC,QAAQ;sBADd,KAAK;gBASC,eAAe;sBANrB,KAAK;;sBAKL,KAAK;gBAOC,YAAY;sBADlB,KAAK","sourcesContent":["import {ChangeDetectionStrategy, Component, Input, OnInit} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject} from 'rxjs';\nimport {ElderUrlFragment} from '../elder-url-fragment';\n\n@Component({\n  selector: 'elder-url-fragment-switcher',\n  templateUrl: './elder-url-fragment-switcher.component.html',\n  styleUrls: ['./elder-url-fragment-switcher.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderUrlFragmentSwitcherComponent implements OnInit {\n\n\n  private readonly logger = LoggerFactory.getLogger('ElderUrlFragmentSwitcherComponent');\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n  @Input()\n  public readonly disable: boolean = true;\n\n  /*\n    List of url fragments which can replace a part of the window location\n   */\n  @Input()\n  public urlFragments: ElderUrlFragment[];\n  /*\n  Regex which matches the part of the url which will get replaced\n   */\n  @Input()\n  public urlRegex: RegExp = new RegExp('[\\.](\\\\w+)');\n\n  @Input()\n\n  /*\n  Index of the regex group which will be replaced\n   */\n  @Input()\n  public regexArrayIndex: number = 0;\n\n  /*\n  Window which will open the created url\n   */\n  @Input()\n  public windowOpenIn: string = \"_self\";\n\n  public readonly activeUrlFragment$ = new BehaviorSubject(new ElderUrlFragment('No match', ''));\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n  constructor() {\n\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  ngOnInit(): void {\n    if (!this.disable) {\n      let urlFragment = this.urlFragments.find(\n        c => {\n          try {\n            return c.fragment === this.urlRegex.exec(window.location.href)[this.regexArrayIndex];\n          } catch (e) {\n            return false;\n          }\n        });\n      if (urlFragment) {\n        this.activeUrlFragment$.next(urlFragment);\n      }\n    }\n\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public setActiveUrlFragment(urlFragment: string) {\n    this.logger.debug(urlFragment);\n    window.open(\n      window.location.href.replace(this.urlRegex.exec(window.location.href)[this.regexArrayIndex], urlFragment),\n      this.windowOpenIn);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n}\n","<ng-container *ngIf=\"activeUrlFragment$ | async as activeUrlFragment\">\n  <elder-button-group>\n    <button mat-stroked-button type=\"button\" disabled [ngStyle]=\"{'background-color': activeUrlFragment.color}\">\n      <div class=\"layout-col\">\n        <span *ngIf=\"!disable\" class=\"caption\">{{activeUrlFragment.name}}</span>\n      </div>\n    </button>\n\n    <button mat-stroked-button type=\"button\"\n            *ngIf=\"!disable \"  [matMenuTriggerFor]=\"fragmentMenu\"\n            [ngStyle]=\"{'background-color': activeUrlFragment.color}\">\n      <mat-icon>flip_camera_android</mat-icon>\n    </button>\n  </elder-button-group>\n</ng-container>\n\n<mat-menu #fragmentMenu=\"matMenu\">\n  <button mat-menu-item type=\"button\"\n          *ngFor=\"let urlFragment of urlFragments\"\n          (click)=\"setActiveUrlFragment(urlFragment.fragment)\">\n    <mat-icon [ngStyle]=\"{'color': urlFragment.color}\">flip_camera_android</mat-icon>\n    <span>{{  urlFragment.name }}</span>\n  </button>\n\n</mat-menu>\n"]}
@@ -21201,7 +21201,10 @@ class HttpDataTransferComponent {
21201
21201
  * Fields *
21202
21202
  * *
21203
21203
  **************************************************************************/
21204
- this.logger = LoggerFactory.getLogger('HttpDataTransferComponent');
21204
+ this.logger = LoggerFactory.getLogger(this.constructor.name);
21205
+ this._transfer$ = new BehaviorSubject(null);
21206
+ this.$state = this._transfer$.pipe(filter(transfer => !!transfer), switchMap$1(transfer => transfer.state$));
21207
+ this.$detail = this.$state.pipe(map(state => this.renderTransferProgress(state)));
21205
21208
  }
21206
21209
  /***************************************************************************
21207
21210
  * *
@@ -21209,38 +21212,57 @@ class HttpDataTransferComponent {
21209
21212
  * *
21210
21213
  **************************************************************************/
21211
21214
  get transfer() {
21212
- return this._transfer;
21215
+ return this._transfer$.getValue();
21213
21216
  }
21214
21217
  set transfer(value) {
21215
- this._transfer = value;
21216
- this.$state = value.state$;
21217
- this.$detail = value.state$.pipe(map(state => {
21218
- if (state.isAborted) {
21219
- return 'Canceled.';
21220
- }
21221
- if (state.hasFailed) {
21222
- return 'Failed!';
21223
- }
21224
- const e = state.progress;
21225
- // 100Mb of 332Mb (1200Kb/sec)
21226
- if (e.percentDone === 100) {
21227
- return BytesFormat.format(e.doneBytes) + '( ' + BytesPerSecondFormat.formatAsBitsPerSecond(e.avgBytesPerSec) + ')';
21228
- }
21229
- else {
21230
- let progress = BytesFormat.format(e.doneBytes) + ' of ' + BytesFormat.format(e.totalBytes);
21231
- if (e.bytesPerSec) {
21232
- progress += ' (' + BytesPerSecondFormat.formatAsBitsPerSecond(e.bytesPerSec) + ')';
21233
- }
21234
- return progress;
21218
+ this._transfer$.next(value);
21219
+ }
21220
+ /***************************************************************************
21221
+ * *
21222
+ * Public API *
21223
+ * *
21224
+ **************************************************************************/
21225
+ statusIcon(state) {
21226
+ switch (state.status) {
21227
+ case DataTransferStatus.Pending: return 'pending';
21228
+ case DataTransferStatus.Transferring: return 'cloud_sync';
21229
+ case DataTransferStatus.Completed: return 'check';
21230
+ case DataTransferStatus.Aborted: return 'block';
21231
+ case DataTransferStatus.Failed: return 'error';
21232
+ default: return 'help_outline';
21233
+ }
21234
+ }
21235
+ /***************************************************************************
21236
+ * *
21237
+ * Private methods *
21238
+ * *
21239
+ **************************************************************************/
21240
+ renderTransferProgress(state) {
21241
+ if (state.isAborted) {
21242
+ return 'Canceled.';
21243
+ }
21244
+ if (state.hasFailed) {
21245
+ return 'Failed!';
21246
+ }
21247
+ const e = state.progress;
21248
+ // 100Mb of 332Mb (1200Kb/sec)
21249
+ if (e.percentDone === 100) {
21250
+ return BytesFormat.format(e.doneBytes) + '( ' + BytesPerSecondFormat.formatAsBitsPerSecond(e.avgBytesPerSec) + ')';
21251
+ }
21252
+ else {
21253
+ let progress = BytesFormat.format(e.doneBytes) + ' of ' + BytesFormat.format(e.totalBytes);
21254
+ if (e.bytesPerSec) {
21255
+ progress += ' (' + BytesPerSecondFormat.formatAsBitsPerSecond(e.bytesPerSec) + ')';
21235
21256
  }
21236
- }));
21257
+ return progress;
21258
+ }
21237
21259
  }
21238
21260
  }
21239
21261
  HttpDataTransferComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: HttpDataTransferComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
21240
- HttpDataTransferComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: HttpDataTransferComponent, selector: "elder-data-transfer", inputs: { transfer: "transfer" }, ngImport: i0, template: "\n\n<div *ngIf=\"($state | async) as state\"\n class=\"layout-row place-start-center gap-lg flex p-md transfer\"\n>\n\n <div class=\"layout-col place-center-center flex-10\">\n <mat-icon class=\"noselect\">\n {{state.isCompleted ? 'check' : 'attachment'}}\n </mat-icon>\n\n <!--\n <mat-icon\n *ngIf=\"!(statusOf(file)?.error | async) && (statusOf(file)?.progress | async) === 100\"\n class=\"green-icon\"\n >check</mat-icon>\n -->\n\n </div>\n\n\n <div class=\"layout-col flex-80\" style=\"overflow: hidden\">\n\n <span class=\"mat-subtitle-2 noselect title\">{{transfer.name}}</span>\n\n <mat-progress-bar\n [matTooltip]=\"state.error?.message\"\n [color]=\"(state.error ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\"\n ></mat-progress-bar>\n\n <span class=\"mat-caption noselect\">{{($detail | async)}}</span>\n\n </div>\n\n\n <div class=\"layout-col place-center-center flex-10\">\n <button mat-icon-button type=\"button\"\n (click)=\"transfer.abort()\" [disabled]=\"state.isDone\">\n <mat-icon>\n close\n </mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".transfer{overflow:hidden}.title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-bottom:5px}\n"], dependencies: [{ kind: "directive", type: i1$4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3$1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5$3.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "directive", type: i4$6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i5$2.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "pipe", type: i1$4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
21262
+ HttpDataTransferComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.1", type: HttpDataTransferComponent, selector: "elder-data-transfer", inputs: { transfer: "transfer" }, ngImport: i0, template: "\n\n<div *ngIf=\"($state | async) as state\"\n class=\"layout-row place-start-center gap-lg flex p-md transfer\"\n>\n\n <div class=\"layout-col place-center-center flex-10\">\n <mat-icon class=\"noselect\">\n {{statusIcon(state)}}\n </mat-icon>\n\n <!--\n <mat-icon\n *ngIf=\"!(statusOf(file)?.error | async) && (statusOf(file)?.progress | async) === 100\"\n class=\"green-icon\"\n >check</mat-icon>\n -->\n\n </div>\n\n\n <div class=\"layout-col flex-80\" style=\"overflow: hidden\">\n\n <span class=\"mat-subtitle-2 noselect title\">{{transfer.name}}</span>\n\n <mat-progress-bar\n [matTooltip]=\"state.error?.message\"\n [color]=\"(state.error ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\"\n ></mat-progress-bar>\n\n <span class=\"mat-caption noselect\">{{($detail | async)}}</span>\n\n </div>\n\n\n <div class=\"layout-col place-center-center flex-10\">\n <button mat-icon-button type=\"button\"\n (click)=\"transfer.abort()\" [disabled]=\"state.isDone\">\n <mat-icon>\n close\n </mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".transfer{overflow:hidden}.title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-bottom:5px}\n"], dependencies: [{ kind: "directive", type: i1$4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3$1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5$3.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "directive", type: i4$6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i5$2.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "pipe", type: i1$4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
21241
21263
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: HttpDataTransferComponent, decorators: [{
21242
21264
  type: Component,
21243
- args: [{ selector: 'elder-data-transfer', changeDetection: ChangeDetectionStrategy.OnPush, template: "\n\n<div *ngIf=\"($state | async) as state\"\n class=\"layout-row place-start-center gap-lg flex p-md transfer\"\n>\n\n <div class=\"layout-col place-center-center flex-10\">\n <mat-icon class=\"noselect\">\n {{state.isCompleted ? 'check' : 'attachment'}}\n </mat-icon>\n\n <!--\n <mat-icon\n *ngIf=\"!(statusOf(file)?.error | async) && (statusOf(file)?.progress | async) === 100\"\n class=\"green-icon\"\n >check</mat-icon>\n -->\n\n </div>\n\n\n <div class=\"layout-col flex-80\" style=\"overflow: hidden\">\n\n <span class=\"mat-subtitle-2 noselect title\">{{transfer.name}}</span>\n\n <mat-progress-bar\n [matTooltip]=\"state.error?.message\"\n [color]=\"(state.error ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\"\n ></mat-progress-bar>\n\n <span class=\"mat-caption noselect\">{{($detail | async)}}</span>\n\n </div>\n\n\n <div class=\"layout-col place-center-center flex-10\">\n <button mat-icon-button type=\"button\"\n (click)=\"transfer.abort()\" [disabled]=\"state.isDone\">\n <mat-icon>\n close\n </mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".transfer{overflow:hidden}.title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-bottom:5px}\n"] }]
21265
+ args: [{ selector: 'elder-data-transfer', changeDetection: ChangeDetectionStrategy.OnPush, template: "\n\n<div *ngIf=\"($state | async) as state\"\n class=\"layout-row place-start-center gap-lg flex p-md transfer\"\n>\n\n <div class=\"layout-col place-center-center flex-10\">\n <mat-icon class=\"noselect\">\n {{statusIcon(state)}}\n </mat-icon>\n\n <!--\n <mat-icon\n *ngIf=\"!(statusOf(file)?.error | async) && (statusOf(file)?.progress | async) === 100\"\n class=\"green-icon\"\n >check</mat-icon>\n -->\n\n </div>\n\n\n <div class=\"layout-col flex-80\" style=\"overflow: hidden\">\n\n <span class=\"mat-subtitle-2 noselect title\">{{transfer.name}}</span>\n\n <mat-progress-bar\n [matTooltip]=\"state.error?.message\"\n [color]=\"(state.error ? 'warn' : '')\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\"\n ></mat-progress-bar>\n\n <span class=\"mat-caption noselect\">{{($detail | async)}}</span>\n\n </div>\n\n\n <div class=\"layout-col place-center-center flex-10\">\n <button mat-icon-button type=\"button\"\n (click)=\"transfer.abort()\" [disabled]=\"state.isDone\">\n <mat-icon>\n close\n </mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".transfer{overflow:hidden}.title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-bottom:5px}\n"] }]
21244
21266
  }], ctorParameters: function () { return []; }, propDecorators: { transfer: [{
21245
21267
  type: Input
21246
21268
  }] } });
@@ -21366,13 +21388,6 @@ class HttpDataTransferOverviewComponent {
21366
21388
  **************************************************************************/
21367
21389
  constructor(transferService) {
21368
21390
  this.transferService = transferService;
21369
- }
21370
- /***************************************************************************
21371
- * *
21372
- * Life Cycle *
21373
- * *
21374
- **************************************************************************/
21375
- ngOnInit() {
21376
21391
  this.transfers$ = this.transferService.transfers;
21377
21392
  }
21378
21393
  }