@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.
- package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +51 -27
- package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +1 -8
- package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +1 -1
- package/fesm2015/elderbyte-ngx-starter.mjs +47 -32
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +47 -32
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.d.ts +15 -3
- package/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.d.ts +2 -9
- package/package.json +1 -1
package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
-
import {
|
|
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(
|
|
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
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
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
|
|
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
|
|
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":"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","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,
|
|
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,
|
|
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(
|
|
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
|
|
21216
|
-
|
|
21217
|
-
|
|
21218
|
-
|
|
21219
|
-
|
|
21220
|
-
|
|
21221
|
-
|
|
21222
|
-
|
|
21223
|
-
|
|
21224
|
-
|
|
21225
|
-
|
|
21226
|
-
|
|
21227
|
-
|
|
21228
|
-
|
|
21229
|
-
|
|
21230
|
-
|
|
21231
|
-
|
|
21232
|
-
|
|
21233
|
-
|
|
21234
|
-
|
|
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
|
|
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
|
|
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
|
}
|