@elderbyte/ngx-starter 15.7.0 → 15.7.2
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/common/http/upload/file-upload-client.mjs +1 -1
- package/esm2020/lib/components/files/elder-file-drop-zone.directive.mjs +2 -2
- package/esm2020/lib/components/files/elder-file-select.directive.mjs +36 -13
- package/esm2020/lib/components/files/elder-file.module.mjs +1 -2
- package/esm2020/lib/components/files/file-select/file-select.component.mjs +2 -2
- package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +8 -14
- package/esm2020/lib/components/files/listing/file-entry.mjs +58 -12
- package/esm2020/lib/components/files/listing/file-listing-rx.mjs +10 -2
- package/fesm2015/elderbyte-ngx-starter.mjs +127 -99
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +127 -99
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/common/http/upload/file-upload-client.d.ts +2 -2
- package/lib/components/files/elder-file-select.directive.d.ts +13 -4
- package/lib/components/files/elder-file.module.d.ts +0 -1
- package/lib/components/files/file-select/file-select.component.d.ts +5 -3
- package/lib/components/files/file-upload/file-upload.component.d.ts +3 -9
- package/lib/components/files/listing/file-entry.d.ts +37 -8
- package/lib/components/files/listing/file-listing-rx.d.ts +1 -0
- package/package.json +1 -1
- package/esm2020/lib/components/files/file-proxy.mjs +0 -41
- package/lib/components/files/file-proxy.d.ts +0 -21
|
@@ -39,4 +39,4 @@ export class FileUploadClient {
|
|
|
39
39
|
return this.dataTransferFactory.buildFileFormDataUpload(this.requestMethod, this.endpointUrl, file);
|
|
40
40
|
}
|
|
41
41
|
}
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQtY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tbW9uL2h0dHAvdXBsb2FkL2ZpbGUtdXBsb2FkLWNsaWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQVN0RSxNQUFNLE9BQU8sZ0JBQWdCO0lBVTNCOzs7O2dGQUk0RTtJQUU1RSxZQUNVLElBQWdCLEVBQ2hCLGVBQXlDLEVBQzlCLFdBQW1CLEVBQzlCLGFBQXVDO1FBSHZDLFNBQUksR0FBSixJQUFJLENBQVk7UUFDaEIsb0JBQWUsR0FBZixlQUFlLENBQTBCO1FBQzlCLGdCQUFXLEdBQVgsV0FBVyxDQUFRO1FBQzlCLGtCQUFhLEdBQWIsYUFBYSxDQUEwQjtRQUUvQyxJQUFJLENBQUMsbUJBQW1CLEdBQUcsSUFBSSxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRUQ7Ozs7Z0ZBSTRFO0lBRXJFLFdBQVcsQ0FBQyxLQUFhO1FBRTlCLE1BQU0sV0FBVyxHQUFHLElBQUksR0FBRyxFQUEwQixDQUFDO1FBRXRELEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDbkIseUNBQXlDO1lBQ3pDLFdBQVcsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBQ3pELENBQUMsQ0FBQyxDQUFDO1FBRUgsTUFBTSxTQUFTLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUVuRCxJQUFJLENBQUMsZUFBZSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUUzQyxPQUFPLFdBQVcsQ0FBQztJQUNyQixDQUFDO0lBRU0sVUFBVSxDQUFDLElBQVU7UUFDMUIsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FDakMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxDQUNoQyxDQUFDO0lBQ0osQ0FBQztJQUVEOzs7O2dGQUk0RTtJQUVwRSxvQkFBb0IsQ0FBQyxJQUFVO1FBQ3JDLE9BQU8sSUFBSSxDQUFDLG1CQUFtQixDQUFDLHVCQUF1QixDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUN0RyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0h0dHBDbGllbnR9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7SHR0cERhdGFUcmFuc2Zlcn0gZnJvbSAnLi4vdHJhbnNmZXIvaHR0cC1kYXRhLXRyYW5zZmVyJztcbmltcG9ydCB7RGF0YVRyYW5zZmVyRmFjdG9yeX0gZnJvbSAnLi4vdHJhbnNmZXIvZGF0YS10cmFuc2Zlci1mYWN0b3J5JztcbmltcG9ydCB7RWxkZXJEYXRhVHJhbnNmZXJTZXJ2aWNlfSBmcm9tICcuLi8uLi8uLi9jb21wb25lbnRzL2RhdGEtdHJhbnNmZXIvZWxkZXItZGF0YS10cmFuc2Zlci5zZXJ2aWNlJztcblxuXG5leHBvcnQgaW50ZXJmYWNlIElGaWxlVXBsb2FkQ2xpZW50IHtcbiAgdXBsb2FkRmlsZXMoZmlsZXM6IEZpbGVbXSk6IE1hcDxGaWxlLCBIdHRwRGF0YVRyYW5zZmVyPjtcbiAgdXBsb2FkRmlsZShmaWxlOiBGaWxlKTogSHR0cERhdGFUcmFuc2Zlcjtcbn1cblxuZXhwb3J0IGNsYXNzIEZpbGVVcGxvYWRDbGllbnQgaW1wbGVtZW50cyBJRmlsZVVwbG9hZENsaWVudCB7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIEZpZWxkcyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHJpdmF0ZSByZWFkb25seSBkYXRhVHJhbnNmZXJGYWN0b3J5OiBEYXRhVHJhbnNmZXJGYWN0b3J5O1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb25zdHJ1Y3RvciAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgaHR0cDogSHR0cENsaWVudCxcbiAgICBwcml2YXRlIHRyYW5zZmVyTWFuYWdlcjogRWxkZXJEYXRhVHJhbnNmZXJTZXJ2aWNlLFxuICAgIHByb3RlY3RlZCByZWFkb25seSBlbmRwb2ludFVybDogc3RyaW5nLFxuICAgIHByaXZhdGUgcmVxdWVzdE1ldGhvZDogJ1BPU1QnIHwgJ1BVVCcgfCAnUEFUQ0gnXG4gICkge1xuICAgIHRoaXMuZGF0YVRyYW5zZmVyRmFjdG9yeSA9IG5ldyBEYXRhVHJhbnNmZXJGYWN0b3J5KGh0dHApO1xuICB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIFB1YmxpYyBBUEkgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIHVwbG9hZEZpbGVzKGZpbGVzOiBGaWxlW10pOiBNYXA8RmlsZSwgSHR0cERhdGFUcmFuc2Zlcj4ge1xuXG4gICAgY29uc3QgYWxsUHJvZ3Jlc3MgPSBuZXcgTWFwPEZpbGUsIEh0dHBEYXRhVHJhbnNmZXI+KCk7XG5cbiAgICBmaWxlcy5mb3JFYWNoKGZpbGUgPT4ge1xuICAgICAgLy8gY3JlYXRlIGEgbmV3IHVwbG9hZCBqb2IgZm9yIGV2ZXJ5IGZpbGVcbiAgICAgIGFsbFByb2dyZXNzLnNldChmaWxlLCB0aGlzLmNyZWF0ZVVwbG9hZFRyYW5zZmVyKGZpbGUpKTtcbiAgICB9KTtcblxuICAgIGNvbnN0IHRyYW5zZmVycyA9IEFycmF5LmZyb20oYWxsUHJvZ3Jlc3MudmFsdWVzKCkpO1xuXG4gICAgdGhpcy50cmFuc2Zlck1hbmFnZXIuZW5xdWV1ZUFsbCh0cmFuc2ZlcnMpO1xuXG4gICAgcmV0dXJuIGFsbFByb2dyZXNzO1xuICB9XG5cbiAgcHVibGljIHVwbG9hZEZpbGUoZmlsZTogRmlsZSk6IEh0dHBEYXRhVHJhbnNmZXIge1xuICAgIHJldHVybiB0aGlzLnRyYW5zZmVyTWFuYWdlci5lbnF1ZXVlKFxuICAgICAgdGhpcy5jcmVhdGVVcGxvYWRUcmFuc2ZlcihmaWxlKVxuICAgICk7XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogUHJpdmF0ZSBtZXRob2RzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIGNyZWF0ZVVwbG9hZFRyYW5zZmVyKGZpbGU6IEZpbGUpOiBIdHRwRGF0YVRyYW5zZmVyIHtcbiAgICByZXR1cm4gdGhpcy5kYXRhVHJhbnNmZXJGYWN0b3J5LmJ1aWxkRmlsZUZvcm1EYXRhVXBsb2FkKHRoaXMucmVxdWVzdE1ldGhvZCwgdGhpcy5lbmRwb2ludFVybCwgZmlsZSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -77,7 +77,7 @@ export class ElderFileDropZoneDirective {
|
|
|
77
77
|
obs.push(FileListingRx.INSTANCE.listFilesRecursive(entry));
|
|
78
78
|
}
|
|
79
79
|
else {
|
|
80
|
-
obs.push(of([
|
|
80
|
+
obs.push(of([FileEntry.ofFile(transferItem.getAsFile())]));
|
|
81
81
|
}
|
|
82
82
|
}
|
|
83
83
|
return zip(obs).pipe(map(files => files.flat()));
|
|
@@ -107,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
|
|
|
107
107
|
type: HostListener,
|
|
108
108
|
args: ['drop', ['$event']]
|
|
109
109
|
}] } });
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-file-drop-zone.directive.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/files/elder-file-drop-zone.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, EventEmitter, HostListener, Input, NgZone, OnDestroy, OnInit, Output, Renderer2} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {\n  Observable, of,\n  zip\n} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {FileEntry} from './listing/file-entry';\nimport {FileListingRx} from './listing/file-listing-rx';\n\n\n\n\n@Directive({\n  selector: '[elderFileDropZone]'\n})\nexport class ElderFileDropZoneDirective {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  @Output()\n  public readonly elderFileDropZoneChange = new EventEmitter<FileEntry[]>();\n\n  @Input()\n  public dragOverClass = 'is-dragover';\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private hostRef: ElementRef,\n    private renderer: Renderer2,\n    private ngZone: NgZone\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('dragover', ['$event'])\n  public onDragOver(evt: DragEvent): void {\n    evt.preventDefault(); // Prevent default browser action\n    this.renderer.addClass(this.hostRef.nativeElement, this.dragOverClass);\n  }\n\n  @HostListener('dragend', ['$event'])\n  @HostListener('dragleave', ['$event'])\n  public onDragEnd(evt: DragEvent): void {\n    evt.preventDefault(); // Prevent default browser action\n    this.dragEnd(evt);\n  }\n\n  @HostListener('drop', ['$event'])\n  public onDrop(evt: DragEvent): void {\n\n    this.logger.debug('Drop event!', evt);\n\n    evt.preventDefault();\n    evt.stopPropagation();\n    this.dragEnd(evt); // TODO Do this later\n\n    this.collectFilesAsync(evt);\n    // this.logger.debug('User dropped ' + files.size + 'files!', files);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private dragEnd(evt: DragEvent): void {\n    this.renderer.removeClass(this.hostRef.nativeElement, this.dragOverClass);\n  }\n\n  private collectFilesAsync(event: DragEvent): void {\n    this.ngZone.runOutsideAngular(() => {\n      try {\n        const items = event.dataTransfer.items;\n        this.toFileList(items).subscribe({\n            next: files => this.ngZone.run(() =>\n              this.elderFileDropZoneChange.emit(files)\n            ),\n            error: err => this.logger.error('Failed to list Files from DataTransferItemList', err)\n          }\n        );\n      } catch (error) {\n        this.logger.error('Failed to handle DragEvent!', error);\n        // this.ngZone.run(() => this.error.emit('Folder upload is unsupported by this browser'));\n      }\n    });\n  }\n\n  private toFileList(transferItemList: DataTransferItemList): Observable<FileEntry[]> {\n    const obs: Observable<FileEntry[]>[] = [];\n    for (let i = 0; i < transferItemList.length; i++) {\n      const transferItem = transferItemList[i];\n      const entry = transferItem.webkitGetAsEntry();\n      if (entry) {\n        obs.push(FileListingRx.INSTANCE.listFilesRecursive(entry));\n      } else {\n        obs.push(of([new FileEntry(transferItem.getAsFile(), null)]));\n      }\n    }\n    return zip(obs).pipe(\n      map(files => files.flat()),\n    );\n  }\n}\n"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-file-drop-zone.directive.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/files/elder-file-drop-zone.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, EventEmitter, HostListener, Input, NgZone, OnDestroy, OnInit, Output, Renderer2} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {\n  Observable, of,\n  zip\n} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {FileEntry} from './listing/file-entry';\nimport {FileListingRx} from './listing/file-listing-rx';\n\n@Directive({\n  selector: '[elderFileDropZone]'\n})\nexport class ElderFileDropZoneDirective {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  @Output()\n  public readonly elderFileDropZoneChange = new EventEmitter<FileEntry[]>();\n\n  @Input()\n  public dragOverClass = 'is-dragover';\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private hostRef: ElementRef,\n    private renderer: Renderer2,\n    private ngZone: NgZone\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('dragover', ['$event'])\n  public onDragOver(evt: DragEvent): void {\n    evt.preventDefault(); // Prevent default browser action\n    this.renderer.addClass(this.hostRef.nativeElement, this.dragOverClass);\n  }\n\n  @HostListener('dragend', ['$event'])\n  @HostListener('dragleave', ['$event'])\n  public onDragEnd(evt: DragEvent): void {\n    evt.preventDefault(); // Prevent default browser action\n    this.dragEnd(evt);\n  }\n\n  @HostListener('drop', ['$event'])\n  public onDrop(evt: DragEvent): void {\n\n    this.logger.debug('Drop event!', evt);\n\n    evt.preventDefault();\n    evt.stopPropagation();\n    this.dragEnd(evt); // TODO Do this later\n\n    this.collectFilesAsync(evt);\n    // this.logger.debug('User dropped ' + files.size + 'files!', files);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private dragEnd(evt: DragEvent): void {\n    this.renderer.removeClass(this.hostRef.nativeElement, this.dragOverClass);\n  }\n\n  private collectFilesAsync(event: DragEvent): void {\n    this.ngZone.runOutsideAngular(() => {\n      try {\n        const items = event.dataTransfer.items;\n        this.toFileList(items).subscribe({\n            next: files => this.ngZone.run(() =>\n              this.elderFileDropZoneChange.emit(files)\n            ),\n            error: err => this.logger.error('Failed to list Files from DataTransferItemList', err)\n          }\n        );\n      } catch (error) {\n        this.logger.error('Failed to handle DragEvent!', error);\n        // this.ngZone.run(() => this.error.emit('Folder upload is unsupported by this browser'));\n      }\n    });\n  }\n\n  private toFileList(transferItemList: DataTransferItemList): Observable<FileEntry[]> {\n    const obs: Observable<FileEntry[]>[] = [];\n    for (let i = 0; i < transferItemList.length; i++) {\n      const transferItem = transferItemList[i];\n      const entry = transferItem.webkitGetAsEntry();\n      if (entry) {\n        obs.push(FileListingRx.INSTANCE.listFilesRecursive(entry));\n      } else {\n        obs.push(of([FileEntry.ofFile(transferItem.getAsFile())]));\n      }\n    }\n    return zip(obs).pipe(\n      map(files => files.flat()),\n    );\n  }\n}\n"]}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
|
2
2
|
import { LoggerFactory } from '@elderbyte/ts-logger';
|
|
3
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
4
|
+
import { FileEntry } from './listing/file-entry';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
4
6
|
export class ElderFileSelectDirective {
|
|
5
7
|
/***************************************************************************
|
|
@@ -42,11 +44,23 @@ export class ElderFileSelectDirective {
|
|
|
42
44
|
}
|
|
43
45
|
}
|
|
44
46
|
set elderFileSelectMultiple(value) {
|
|
45
|
-
this._multiple = value;
|
|
47
|
+
this._multiple = coerceBooleanProperty(value);
|
|
46
48
|
if (this._fileInput) {
|
|
47
49
|
this.renderer.setProperty(this._fileInput, 'multiple', value);
|
|
48
50
|
}
|
|
49
51
|
}
|
|
52
|
+
/**
|
|
53
|
+
* Allow the user to select a directory. All files that are recursively contained are selected.
|
|
54
|
+
* However, the user will no longer be able to select individual files if this is enabled.
|
|
55
|
+
* @param value
|
|
56
|
+
*/
|
|
57
|
+
set elderFileSelectDirectory(value) {
|
|
58
|
+
this._directory = coerceBooleanProperty(value);
|
|
59
|
+
if (this._fileInput) {
|
|
60
|
+
this.renderer.setAttribute(this._fileInput, 'webkitdirectory', 'true');
|
|
61
|
+
this.renderer.setAttribute(this._fileInput, 'directory', 'true');
|
|
62
|
+
}
|
|
63
|
+
}
|
|
50
64
|
/***************************************************************************
|
|
51
65
|
* *
|
|
52
66
|
* Public API *
|
|
@@ -82,6 +96,10 @@ export class ElderFileSelectDirective {
|
|
|
82
96
|
if (this._multiple) {
|
|
83
97
|
this.renderer.setProperty(this._fileInput, 'multiple', this._multiple);
|
|
84
98
|
}
|
|
99
|
+
if (this._directory) {
|
|
100
|
+
this.renderer.setAttribute(this._fileInput, 'webkitdirectory', 'true');
|
|
101
|
+
this.renderer.setAttribute(this._fileInput, 'directory', 'true');
|
|
102
|
+
}
|
|
85
103
|
this._unlisten = this.renderer.listen(this._fileInput, 'change', event => this.fileInputChanged(event));
|
|
86
104
|
}
|
|
87
105
|
removeFileSelect() {
|
|
@@ -96,33 +114,36 @@ export class ElderFileSelectDirective {
|
|
|
96
114
|
}
|
|
97
115
|
fileInputChanged(event) {
|
|
98
116
|
const fileList = this._fileInput.files;
|
|
99
|
-
this.
|
|
117
|
+
const files = this.toFileEntries(fileList);
|
|
118
|
+
this.logger.debug('fileInputChanged, files:', files);
|
|
119
|
+
this.emitFileList(files);
|
|
100
120
|
this.clearFileList();
|
|
101
121
|
}
|
|
102
122
|
clearFileList() {
|
|
103
123
|
// not nice but works
|
|
104
124
|
this._fileInput.value = null;
|
|
105
125
|
}
|
|
106
|
-
emitFileList(
|
|
107
|
-
if (
|
|
108
|
-
this.elderFileSelectChange.next(
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
126
|
+
emitFileList(files) {
|
|
127
|
+
if (files.length > 0) {
|
|
128
|
+
this.elderFileSelectChange.next(files);
|
|
129
|
+
this.elderSingleFileSelectChange.emit(files[0].file);
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
this.logger.warn('User did not select any File or the Folder was empty.');
|
|
112
133
|
}
|
|
113
134
|
}
|
|
114
|
-
|
|
115
|
-
const files =
|
|
135
|
+
toFileEntries(fileList) {
|
|
136
|
+
const files = [];
|
|
116
137
|
for (const key in fileList) {
|
|
117
138
|
if (!isNaN(parseInt(key, 0))) {
|
|
118
|
-
files.
|
|
139
|
+
files.push(FileEntry.ofFile(fileList[key]));
|
|
119
140
|
}
|
|
120
141
|
}
|
|
121
142
|
return files;
|
|
122
143
|
}
|
|
123
144
|
}
|
|
124
145
|
ElderFileSelectDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: ElderFileSelectDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
125
|
-
ElderFileSelectDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.0", type: ElderFileSelectDirective, selector: "[elderFileSelect]", inputs: { elderFileSelect: "elderFileSelect", elderFileSelectMultiple: "elderFileSelectMultiple" }, outputs: { elderFileSelectChange: "elderFileSelectChange", elderSingleFileSelectChange: "elderSingleFileSelectChange" }, host: { listeners: { "click": "onClick($event)" } }, ngImport: i0 });
|
|
146
|
+
ElderFileSelectDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.0", type: ElderFileSelectDirective, selector: "[elderFileSelect]", inputs: { elderFileSelect: "elderFileSelect", elderFileSelectMultiple: "elderFileSelectMultiple", elderFileSelectDirectory: "elderFileSelectDirectory" }, outputs: { elderFileSelectChange: "elderFileSelectChange", elderSingleFileSelectChange: "elderSingleFileSelectChange" }, host: { listeners: { "click": "onClick($event)" } }, ngImport: i0 });
|
|
126
147
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: ElderFileSelectDirective, decorators: [{
|
|
127
148
|
type: Directive,
|
|
128
149
|
args: [{
|
|
@@ -136,8 +157,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
|
|
|
136
157
|
type: Input
|
|
137
158
|
}], elderFileSelectMultiple: [{
|
|
138
159
|
type: Input
|
|
160
|
+
}], elderFileSelectDirectory: [{
|
|
161
|
+
type: Input
|
|
139
162
|
}], onClick: [{
|
|
140
163
|
type: HostListener,
|
|
141
164
|
args: ['click', ['$event']]
|
|
142
165
|
}] } });
|
|
143
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-file-select.directive.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/files/elder-file-select.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2\n} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\n\n@Directive({\n  selector: '[elderFileSelect]'\n})\nexport class ElderFileSelectDirective implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private _fileInput: HTMLInputElement;\n  private _unlisten: () => void;\n\n  @Output()\n  public readonly elderFileSelectChange = new EventEmitter<Set<File>>();\n\n  @Output()\n  public readonly elderSingleFileSelectChange = new EventEmitter<File>();\n\n  private _multiple: boolean;\n  private _accept: string;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private el: ElementRef,\n    private renderer: Renderer2\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    this.createFileSelect();\n  }\n\n  public ngOnDestroy(): void {\n    this.removeFileSelect();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set elderFileSelect(value: string) {\n    this._accept = value;\n    if (this._fileInput) {\n      this.renderer.setProperty(this._fileInput, 'accept', value);\n    }\n  }\n\n  @Input()\n  public set elderFileSelectMultiple(value: boolean) {\n    this._multiple = value;\n    if (this._fileInput) {\n      this.renderer.setProperty(this._fileInput, 'multiple', value);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('click', ['$event'])\n  public onClick(event: any): void {\n    this.openFileSelectDialog();\n  }\n\n  public openFileSelectDialog(): void {\n    this._fileInput.click();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * <input type=\"file\"\n   *     hidden #fileInput\n   *     [multiple]=\"multiple\"\n   *     [accept]=\"accept\"\n   *     (change)=\"fileInputChanged()\"\n   * />\n   */\n  private createFileSelect(): void {\n\n    this._fileInput = this.renderer.createElement('input');\n    this.renderer.setAttribute(this._fileInput, 'hidden', 'true');\n    this.renderer.setAttribute(this._fileInput, 'type', 'file');\n    this.renderer.appendChild(this.el.nativeElement, this._fileInput);\n\n    if (this._accept) {\n      this.renderer.setProperty(this._fileInput, 'accept', this._accept);\n    }\n    if (this._multiple) {\n      this.renderer.setProperty(this._fileInput, 'multiple', this._multiple);\n    }\n\n    this._unlisten = this.renderer.listen(\n      this._fileInput,\n      'change',\n      event => this.fileInputChanged(event)\n    );\n  }\n\n  private removeFileSelect(): void {\n    if (this._unlisten) {\n      this._unlisten();\n      this._unlisten = null;\n    }\n    if (this._fileInput) {\n      this.renderer.removeChild(this.el.nativeElement, this._fileInput);\n      this._fileInput = null;\n    }\n  }\n\n  private fileInputChanged(event: any): void {\n    const fileList = this._fileInput.files;\n    this.emitFileList(fileList);\n    this.clearFileList();\n  }\n\n  private clearFileList() {\n    // not nice but works\n    this._fileInput.value = null;\n  }\n\n  private emitFileList(fileList: FileList): void {\n    if (fileList.length > 0) {\n\n      this.elderFileSelectChange.next(\n        this.toSet(fileList)\n      );\n      if (!this.elderFileSelectMultiple) {\n        this.elderSingleFileSelectChange.emit(\n          fileList.item(0)\n        );\n      }\n    }\n  }\n\n  private toSet(fileList: FileList): Set<File> {\n    const files = new Set<File>();\n\n    for (const key in fileList) {\n      if (!isNaN(parseInt(key, 0))) {\n        files.add(fileList[key]);\n      }\n    }\n    return files;\n  }\n\n}\n"]}
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-file-select.directive.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/files/elder-file-select.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2\n} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {FileEntry} from './listing/file-entry';\n\n@Directive({\n  selector: '[elderFileSelect]'\n})\nexport class ElderFileSelectDirective implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private _fileInput: HTMLInputElement;\n  private _unlisten: () => void;\n\n  @Output()\n  public readonly elderFileSelectChange = new EventEmitter<FileEntry[]>();\n\n  @Output()\n  public readonly elderSingleFileSelectChange = new EventEmitter<File>();\n\n  private _multiple: boolean;\n  private _directory: boolean;\n  private _accept: string;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private el: ElementRef,\n    private renderer: Renderer2\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    this.createFileSelect();\n  }\n\n  public ngOnDestroy(): void {\n    this.removeFileSelect();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set elderFileSelect(value: string) {\n    this._accept = value;\n    if (this._fileInput) {\n      this.renderer.setProperty(this._fileInput, 'accept', value);\n    }\n  }\n\n  @Input()\n  public set elderFileSelectMultiple(value: BooleanInput) {\n    this._multiple = coerceBooleanProperty(value);\n    if (this._fileInput) {\n      this.renderer.setProperty(this._fileInput, 'multiple', value);\n    }\n  }\n\n  /**\n   * Allow the user to select a directory. All files that are recursively contained are selected.\n   * However, the user will no longer be able to select individual files if this is enabled.\n   * @param value\n   */\n  @Input()\n  public set elderFileSelectDirectory(value: BooleanInput) {\n    this._directory = coerceBooleanProperty(value);\n    if (this._fileInput) {\n      this.renderer.setAttribute(this._fileInput, 'webkitdirectory', 'true');\n      this.renderer.setAttribute(this._fileInput, 'directory', 'true');\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('click', ['$event'])\n  public onClick(event: any): void {\n    this.openFileSelectDialog();\n  }\n\n  public openFileSelectDialog(): void {\n    this._fileInput.click();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * <input type=\"file\"\n   *     hidden #fileInput\n   *     [multiple]=\"multiple\"\n   *     [accept]=\"accept\"\n   *     (change)=\"fileInputChanged()\"\n   * />\n   */\n  private createFileSelect(): void {\n\n    this._fileInput = this.renderer.createElement('input');\n    this.renderer.setAttribute(this._fileInput, 'hidden', 'true');\n    this.renderer.setAttribute(this._fileInput, 'type', 'file');\n    this.renderer.appendChild(this.el.nativeElement, this._fileInput);\n\n    if (this._accept) {\n      this.renderer.setProperty(this._fileInput, 'accept', this._accept);\n    }\n    if (this._multiple) {\n      this.renderer.setProperty(this._fileInput, 'multiple', this._multiple);\n    }\n    if (this._directory) {\n      this.renderer.setAttribute(this._fileInput, 'webkitdirectory', 'true');\n      this.renderer.setAttribute(this._fileInput, 'directory', 'true');\n    }\n\n    this._unlisten = this.renderer.listen(\n      this._fileInput,\n      'change',\n      event => this.fileInputChanged(event)\n    );\n  }\n\n  private removeFileSelect(): void {\n    if (this._unlisten) {\n      this._unlisten();\n      this._unlisten = null;\n    }\n    if (this._fileInput) {\n      this.renderer.removeChild(this.el.nativeElement, this._fileInput);\n      this._fileInput = null;\n    }\n  }\n\n  private fileInputChanged(event: any): void {\n    const fileList = this._fileInput.files;\n    const files = this.toFileEntries(fileList);\n    this.logger.debug('fileInputChanged, files:', files);\n    this.emitFileList(files);\n    this.clearFileList();\n  }\n\n  private clearFileList() {\n    // not nice but works\n    this._fileInput.value = null;\n  }\n\n  private emitFileList(files: FileEntry[]): void {\n    if (files.length > 0) {\n      this.elderFileSelectChange.next(files);\n      this.elderSingleFileSelectChange.emit(\n        files[0].file\n      );\n    } else {\n      this.logger.warn('User did not select any File or the Folder was empty.');\n    }\n  }\n\n  private toFileEntries(fileList: FileList): FileEntry[] {\n    const files: FileEntry[] = [];\n    for (const key in fileList) {\n      if (!isNaN(parseInt(key, 0))) {\n        files.push(FileEntry.ofFile(fileList[key]));\n      }\n    }\n    return files;\n  }\n\n}\n"]}
|
|
@@ -17,7 +17,6 @@ export { ElderFileSelectDirective } from './elder-file-select.directive';
|
|
|
17
17
|
export { ElderFileDropZoneDirective } from './elder-file-drop-zone.directive';
|
|
18
18
|
export { ElderBlobViewerComponent } from './blob-viewer/elder-blob-viewer.component';
|
|
19
19
|
export * from './blob-url';
|
|
20
|
-
export * from './file-proxy';
|
|
21
20
|
export * from './listing/file-entry';
|
|
22
21
|
export * from './listing/file-listing-rx';
|
|
23
22
|
export class ElderFileModule {
|
|
@@ -67,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
|
|
|
67
66
|
]
|
|
68
67
|
}]
|
|
69
68
|
}] });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItZmlsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2ZpbGVzL2VsZGVyLWZpbGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzdFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDckQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQ3BFLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQ2hFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzdFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQ3ZFLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQzVFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLDJDQUEyQyxDQUFDOztBQUVuRixPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUN2RSxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUM1RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUNuRixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsMkJBQTJCLENBQUM7QUE2QjFDLE1BQU0sT0FBTyxlQUFlOzs0R0FBZixlQUFlOzZHQUFmLGVBQWUsaUJBZHhCLHdCQUF3QjtRQUN4Qix3QkFBd0I7UUFDeEIsd0JBQXdCO1FBQ3hCLDBCQUEwQjtRQUMxQix3QkFBd0IsYUFmeEIsWUFBWTtRQUVaLGFBQWE7UUFFYixlQUFlLEVBQUUsYUFBYTtRQUU5QixvQkFBb0I7UUFFcEIsZ0JBQWdCLGFBVWhCLHdCQUF3QjtRQUN4Qix3QkFBd0I7UUFDeEIsd0JBQXdCO1FBQ3hCLDBCQUEwQjtRQUMxQix3QkFBd0I7NkdBR2YsZUFBZSxZQXpCeEIsWUFBWTtRQUVaLGFBQWE7UUFFYixlQUFlLEVBQUUsYUFBYTtRQUU5QixvQkFBb0I7UUFFcEIsZ0JBQWdCOzJGQWlCUCxlQUFlO2tCQTNCM0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFFWixhQUFhO3dCQUViLGVBQWUsRUFBRSxhQUFhO3dCQUU5QixvQkFBb0I7d0JBRXBCLGdCQUFnQjtxQkFDakI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLHdCQUF3Qjt3QkFDeEIsd0JBQXdCO3dCQUN4Qix3QkFBd0I7d0JBQ3hCLDBCQUEwQjt3QkFDMUIsd0JBQXdCO3FCQUN6QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1Asd0JBQXdCO3dCQUN4Qix3QkFBd0I7d0JBQ3hCLHdCQUF3Qjt3QkFDeEIsMEJBQTBCO3dCQUMxQix3QkFBd0I7cUJBQ3pCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7RWxkZXJGaWxlU2VsZWN0Q29tcG9uZW50fSBmcm9tICcuL2ZpbGUtc2VsZWN0L2ZpbGUtc2VsZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQge01hdEJ1dHRvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7TWF0SWNvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQge01hdExpc3RNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2xpc3QnO1xuaW1wb3J0IHtNYXRQcm9ncmVzc0Jhck1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3MtYmFyJztcbmltcG9ydCB7RWxkZXJQaXBlc01vZHVsZX0gZnJvbSAnLi4vLi4vcGlwZXMvZWxkZXItcGlwZXMubW9kdWxlJztcbmltcG9ydCB7RWxkZXJGaWxlVXBsb2FkQ29tcG9uZW50fSBmcm9tICcuL2ZpbGUtdXBsb2FkL2ZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XG5pbXBvcnQge0VsZGVyRmlsZVNlbGVjdERpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1maWxlLXNlbGVjdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtFbGRlckZpbGVEcm9wWm9uZURpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1maWxlLWRyb3Atem9uZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHtFbGRlckJsb2JWaWV3ZXJDb21wb25lbnR9IGZyb20gJy4vYmxvYi12aWV3ZXIvZWxkZXItYmxvYi12aWV3ZXIuY29tcG9uZW50JztcblxuZXhwb3J0IHtFbGRlckZpbGVTZWxlY3RDb21wb25lbnR9IGZyb20gJy4vZmlsZS1zZWxlY3QvZmlsZS1zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCB7RWxkZXJGaWxlVXBsb2FkQ29tcG9uZW50fSBmcm9tICcuL2ZpbGUtdXBsb2FkL2ZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XG5leHBvcnQge0VsZGVyRmlsZVNlbGVjdERpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1maWxlLXNlbGVjdC5kaXJlY3RpdmUnO1xuZXhwb3J0IHtFbGRlckZpbGVEcm9wWm9uZURpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci1maWxlLWRyb3Atem9uZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHtFbGRlckJsb2JWaWV3ZXJDb21wb25lbnR9IGZyb20gJy4vYmxvYi12aWV3ZXIvZWxkZXItYmxvYi12aWV3ZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vYmxvYi11cmwnO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0aW5nL2ZpbGUtZW50cnknO1xuZXhwb3J0ICogZnJvbSAnLi9saXN0aW5nL2ZpbGUtbGlzdGluZy1yeCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG5cbiAgICBNYXRMaXN0TW9kdWxlLFxuXG4gICAgTWF0QnV0dG9uTW9kdWxlLCBNYXRJY29uTW9kdWxlLFxuXG4gICAgTWF0UHJvZ3Jlc3NCYXJNb2R1bGUsXG5cbiAgICBFbGRlclBpcGVzTW9kdWxlXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEVsZGVyRmlsZVNlbGVjdENvbXBvbmVudCxcbiAgICBFbGRlckZpbGVVcGxvYWRDb21wb25lbnQsXG4gICAgRWxkZXJGaWxlU2VsZWN0RGlyZWN0aXZlLFxuICAgIEVsZGVyRmlsZURyb3Bab25lRGlyZWN0aXZlLFxuICAgIEVsZGVyQmxvYlZpZXdlckNvbXBvbmVudFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgRWxkZXJGaWxlU2VsZWN0Q29tcG9uZW50LFxuICAgIEVsZGVyRmlsZVVwbG9hZENvbXBvbmVudCxcbiAgICBFbGRlckZpbGVTZWxlY3REaXJlY3RpdmUsXG4gICAgRWxkZXJGaWxlRHJvcFpvbmVEaXJlY3RpdmUsXG4gICAgRWxkZXJCbG9iVmlld2VyQ29tcG9uZW50XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJGaWxlTW9kdWxlIHtcbn1cbiJdfQ==
|
|
@@ -37,7 +37,7 @@ export class ElderFileSelectComponent {
|
|
|
37
37
|
}
|
|
38
38
|
}
|
|
39
39
|
ElderFileSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: ElderFileSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
40
|
-
ElderFileSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: ElderFileSelectComponent, selector: "elder-file-select", inputs: { multiple: "multiple", accept: "accept", icon: "icon", color: "color" }, outputs: { filesChange: "filesChange" }, ngImport: i0, template: "\n\n<button mat-icon-button type=\"button\"\n [elderFileSelect]=\"accept\"\n [elderFileSelectMultiple]=\"multiple\"\n (elderFileSelectChange)=\"fileInputChanged($event)\"\n>\n <mat-icon [color]=\"color\">{{icon}}</mat-icon>\n</button>\n", styles: [""], dependencies: [{ kind: "component", type: i1.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i3.ElderFileSelectDirective, selector: "[elderFileSelect]", inputs: ["elderFileSelect", "elderFileSelectMultiple"], outputs: ["elderFileSelectChange", "elderSingleFileSelectChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
40
|
+
ElderFileSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: ElderFileSelectComponent, selector: "elder-file-select", inputs: { multiple: "multiple", accept: "accept", icon: "icon", color: "color" }, outputs: { filesChange: "filesChange" }, ngImport: i0, template: "\n\n<button mat-icon-button type=\"button\"\n [elderFileSelect]=\"accept\"\n [elderFileSelectMultiple]=\"multiple\"\n (elderFileSelectChange)=\"fileInputChanged($event)\"\n>\n <mat-icon [color]=\"color\">{{icon}}</mat-icon>\n</button>\n", styles: [""], dependencies: [{ kind: "component", type: i1.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i3.ElderFileSelectDirective, selector: "[elderFileSelect]", inputs: ["elderFileSelect", "elderFileSelectMultiple", "elderFileSelectDirectory"], outputs: ["elderFileSelectChange", "elderSingleFileSelectChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
41
41
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: ElderFileSelectComponent, decorators: [{
|
|
42
42
|
type: Component,
|
|
43
43
|
args: [{ selector: 'elder-file-select', changeDetection: ChangeDetectionStrategy.OnPush, template: "\n\n<button mat-icon-button type=\"button\"\n [elderFileSelect]=\"accept\"\n [elderFileSelectMultiple]=\"multiple\"\n (elderFileSelectChange)=\"fileInputChanged($event)\"\n>\n <mat-icon [color]=\"color\">{{icon}}</mat-icon>\n</button>\n" }]
|
|
@@ -52,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
|
|
|
52
52
|
}], filesChange: [{
|
|
53
53
|
type: Output
|
|
54
54
|
}] } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1zZWxlY3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9maWxlcy9maWxlLXNlbGVjdC9maWxlLXNlbGVjdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2ZpbGVzL2ZpbGUtc2VsZWN0L2ZpbGUtc2VsZWN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7Ozs7O0FBVXRHLE1BQU0sT0FBTyx3QkFBd0I7SUF1Qm5DOzs7O2dGQUk0RTtJQUU1RTtRQTNCQTs7OztvRkFJNEU7UUFHckUsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUdqQixXQUFNLEdBQVcsU0FBUyxDQUFDO1FBRzNCLFNBQUksR0FBRyxLQUFLLENBQUM7UUFNSixnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFlLENBQUM7SUFTOUQsQ0FBQztJQUVEOzs7O2dGQUk0RTtJQUVyRSxRQUFRO0lBRWYsQ0FBQztJQUVEOzs7O2dGQUk0RTtJQUVyRSxnQkFBZ0IsQ0FBQyxLQUFrQjtRQUN4QyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvQixDQUFDOztxSEFsRFUsd0JBQXdCO3lHQUF4Qix3QkFBd0Isb0xDVnJDLG9RQVNBOzJGRENhLHdCQUF3QjtrQkFOcEMsU0FBUzsrQkFDRSxtQkFBbUIsbUJBR1osdUJBQXVCLENBQUMsTUFBTTswRUFXeEMsUUFBUTtzQkFEZCxLQUFLO2dCQUlDLE1BQU07c0JBRFosS0FBSztnQkFJQyxJQUFJO3NCQURWLEtBQUs7Z0JBSUMsS0FBSztzQkFEWCxLQUFLO2dCQUlVLFdBQVc7c0JBRDFCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7RmlsZUVudHJ5fSBmcm9tICcuLi9saXN0aW5nL2ZpbGUtZW50cnknO1xuaW1wb3J0IHtUaGVtZVBhbGV0dGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdlbGRlci1maWxlLXNlbGVjdCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9maWxlLXNlbGVjdC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2ZpbGUtc2VsZWN0LmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyRmlsZVNlbGVjdENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIEZpZWxkcyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgQElucHV0KClcbiAgcHVibGljIG11bHRpcGxlID0gZmFsc2U7XG5cbiAgQElucHV0KClcbiAgcHVibGljIGFjY2VwdDogc3RyaW5nID0gdW5kZWZpbmVkO1xuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBpY29uID0gJ2FkZCc7XG5cbiAgQElucHV0KClcbiAgcHVibGljIGNvbG9yOiBUaGVtZVBhbGV0dGU7XG5cbiAgQE91dHB1dCgpXG4gIHB1YmxpYyByZWFkb25seSBmaWxlc0NoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8RmlsZUVudHJ5W10+KCk7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIENvbnN0cnVjdG9yICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgY29uc3RydWN0b3IoKSB7XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogTGlmZSBDeWNsZSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG5cbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQdWJsaWMgQVBJICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHB1YmxpYyBmaWxlSW5wdXRDaGFuZ2VkKGZpbGVzOiBGaWxlRW50cnlbXSk6IHZvaWQge1xuICAgIHRoaXMuZmlsZXNDaGFuZ2UubmV4dChmaWxlcyk7XG4gIH1cblxufVxuIiwiXG5cbjxidXR0b24gbWF0LWljb24tYnV0dG9uIHR5cGU9XCJidXR0b25cIlxuICAgICAgICBbZWxkZXJGaWxlU2VsZWN0XT1cImFjY2VwdFwiXG4gICAgICAgIFtlbGRlckZpbGVTZWxlY3RNdWx0aXBsZV09XCJtdWx0aXBsZVwiXG4gICAgICAgIChlbGRlckZpbGVTZWxlY3RDaGFuZ2UpPVwiZmlsZUlucHV0Q2hhbmdlZCgkZXZlbnQpXCJcbj5cbiAgPG1hdC1pY29uIFtjb2xvcl09XCJjb2xvclwiPnt7aWNvbn19PC9tYXQtaWNvbj5cbjwvYnV0dG9uPlxuIl19
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
2
|
import { forkJoin } from 'rxjs';
|
|
3
|
+
import { FileEntry } from '../listing/file-entry';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "@angular/common";
|
|
5
6
|
import * as i2 from "@angular/material/list";
|
|
@@ -21,17 +22,10 @@ export class ElderFileUploadComponent {
|
|
|
21
22
|
* Fields *
|
|
22
23
|
* *
|
|
23
24
|
**************************************************************************/
|
|
24
|
-
this.files =
|
|
25
|
+
this.files = [];
|
|
25
26
|
this.multiple = false;
|
|
26
27
|
this.accept = undefined;
|
|
27
28
|
}
|
|
28
|
-
/***************************************************************************
|
|
29
|
-
* *
|
|
30
|
-
* Life Cycle *
|
|
31
|
-
* *
|
|
32
|
-
**************************************************************************/
|
|
33
|
-
ngOnInit() {
|
|
34
|
-
}
|
|
35
29
|
/***************************************************************************
|
|
36
30
|
* *
|
|
37
31
|
* Public API *
|
|
@@ -51,16 +45,16 @@ export class ElderFileUploadComponent {
|
|
|
51
45
|
* Private methods *
|
|
52
46
|
* *
|
|
53
47
|
**************************************************************************/
|
|
54
|
-
uploadAllFiles(
|
|
55
|
-
this.uploadProgress = this.uploadClient.uploadFiles(
|
|
56
|
-
return forkJoin(this.uploadProgress.values());
|
|
48
|
+
uploadAllFiles(entries) {
|
|
49
|
+
this.uploadProgress = this.uploadClient.uploadFiles(FileEntry.toFileArray(entries));
|
|
50
|
+
return forkJoin(Array.from(this.uploadProgress.values()));
|
|
57
51
|
}
|
|
58
52
|
}
|
|
59
53
|
ElderFileUploadComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: ElderFileUploadComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
60
|
-
ElderFileUploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: ElderFileUploadComponent, selector: "elder-file-upload", inputs: { files: "files", multiple: "multiple", accept: "accept", uploadClient: "uploadClient" }, ngImport: i0, template: "\n\n<div class=\"layout-col\">\n\n <div class=\"layout-row gap-md\">\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n *ngIf=\"uploadClient\" (click)=\"startUpload($event)\" [disabled]=\"files.
|
|
54
|
+
ElderFileUploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: ElderFileUploadComponent, selector: "elder-file-upload", inputs: { files: "files", multiple: "multiple", accept: "accept", uploadClient: "uploadClient" }, ngImport: i0, template: "\n\n<div class=\"layout-col\">\n\n <div class=\"layout-row gap-md\">\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n *ngIf=\"uploadClient\" (click)=\"startUpload($event)\" [disabled]=\"files.length === 0\">\n <mat-icon>cloud_upload</mat-icon>\n </button>\n\n <elder-file-select\n [multiple]=\"multiple\"\n [accept]=\"accept\"\n (filesChange)=\"files = $event\"\n ></elder-file-select>\n\n </div>\n\n <mat-list>\n <h2 mat-subheader>Selected Files ({{files.length}})</h2>\n <mat-list-item *ngFor=\"let fileEntry of files\">\n <mat-icon mat-list-icon>attach_file</mat-icon>\n <h4 mat-line>{{fileEntry.relativePath}}</h4>\n <p mat-line> {{fileEntry.file.size | bytes}} - {{fileEntry.file.lastModified | timeAgo}}</p>\n\n <mat-progress-bar *ngIf=\"(transferOf(fileEntry.file)?.state$ | async) as state\"\n [color]=\"(state.hasFailed ? 'warn' : undefined)\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\">\n </mat-progress-bar>\n\n </mat-list-item>\n </mat-list>\n\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatList, selector: "mat-list", exportAs: ["matList"] }, { kind: "component", type: i2.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }, { kind: "directive", type: i2.MatListSubheaderCssMatStyler, selector: "[mat-subheader], [matSubheader]" }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i6.ElderFileSelectComponent, selector: "elder-file-select", inputs: ["multiple", "accept", "icon", "color"], outputs: ["filesChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.BytesPipe, name: "bytes" }, { kind: "pipe", type: i8.TimeAgoPipe, name: "timeAgo" }] });
|
|
61
55
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: ElderFileUploadComponent, decorators: [{
|
|
62
56
|
type: Component,
|
|
63
|
-
args: [{ selector: 'elder-file-upload', template: "\n\n<div class=\"layout-col\">\n\n <div class=\"layout-row gap-md\">\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n *ngIf=\"uploadClient\" (click)=\"startUpload($event)\" [disabled]=\"files.
|
|
57
|
+
args: [{ selector: 'elder-file-upload', template: "\n\n<div class=\"layout-col\">\n\n <div class=\"layout-row gap-md\">\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n *ngIf=\"uploadClient\" (click)=\"startUpload($event)\" [disabled]=\"files.length === 0\">\n <mat-icon>cloud_upload</mat-icon>\n </button>\n\n <elder-file-select\n [multiple]=\"multiple\"\n [accept]=\"accept\"\n (filesChange)=\"files = $event\"\n ></elder-file-select>\n\n </div>\n\n <mat-list>\n <h2 mat-subheader>Selected Files ({{files.length}})</h2>\n <mat-list-item *ngFor=\"let fileEntry of files\">\n <mat-icon mat-list-icon>attach_file</mat-icon>\n <h4 mat-line>{{fileEntry.relativePath}}</h4>\n <p mat-line> {{fileEntry.file.size | bytes}} - {{fileEntry.file.lastModified | timeAgo}}</p>\n\n <mat-progress-bar *ngIf=\"(transferOf(fileEntry.file)?.state$ | async) as state\"\n [color]=\"(state.hasFailed ? 'warn' : undefined)\"\n mode=\"determinate\"\n [value]=\"state.progress.percentDone\">\n </mat-progress-bar>\n\n </mat-list-item>\n </mat-list>\n\n</div>\n" }]
|
|
64
58
|
}], ctorParameters: function () { return []; }, propDecorators: { files: [{
|
|
65
59
|
type: Input
|
|
66
60
|
}], multiple: [{
|
|
@@ -70,4 +64,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
|
|
|
70
64
|
}], uploadClient: [{
|
|
71
65
|
type: Input
|
|
72
66
|
}] } });
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9maWxlcy9maWxlLXVwbG9hZC9maWxlLXVwbG9hZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2ZpbGVzL2ZpbGUtdXBsb2FkL2ZpbGUtdXBsb2FkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsS0FBSyxFQUFTLE1BQU0sZUFBZSxDQUFDO0FBQ3ZELE9BQU8sRUFBQyxRQUFRLEVBQWEsTUFBTSxNQUFNLENBQUM7QUFHMUMsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLHVCQUF1QixDQUFDOzs7Ozs7Ozs7O0FBT2hELE1BQU0sT0FBTyx3QkFBd0I7SUF1Qm5DOzs7O2dGQUk0RTtJQUU1RTtRQTFCQTs7OztvRkFJNEU7UUFHckUsVUFBSyxHQUFnQixFQUFFLENBQUM7UUFLeEIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUdqQixXQUFNLEdBQVcsU0FBUyxDQUFDO0lBWWxDLENBQUM7SUFFRDs7OztnRkFJNEU7SUFFckUsV0FBVyxDQUFDLEtBQVU7UUFDM0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRU0sVUFBVSxDQUFDLElBQVU7UUFDMUIsSUFBSSxJQUFJLENBQUMsY0FBYyxFQUFFO1lBQ3ZCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDdEM7UUFDRCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRUQ7Ozs7Z0ZBSTRFO0lBRXBFLGNBQWMsQ0FBQyxPQUFvQjtRQUN6QyxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUNqRCxTQUFTLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUMvQixDQUFDO1FBQ0YsT0FBTyxRQUFRLENBQ2IsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQ3pDLENBQUM7SUFDSixDQUFDOztxSEE5RFUsd0JBQXdCO3lHQUF4Qix3QkFBd0IsMkpDWHJDLHFwQ0FvQ0E7MkZEekJhLHdCQUF3QjtrQkFMcEMsU0FBUzsrQkFDRSxtQkFBbUI7MEVBY3RCLEtBQUs7c0JBRFgsS0FBSztnQkFNQyxRQUFRO3NCQURkLEtBQUs7Z0JBSUMsTUFBTTtzQkFEWixLQUFLO2dCQUlDLFlBQVk7c0JBRGxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5wdXQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge2ZvcmtKb2luLCBPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcbmltcG9ydCB7SUZpbGVVcGxvYWRDbGllbnR9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9odHRwL3VwbG9hZC9maWxlLXVwbG9hZC1jbGllbnQnO1xuaW1wb3J0IHtIdHRwRGF0YVRyYW5zZmVyfSBmcm9tICcuLi8uLi8uLi9jb21tb24vaHR0cC90cmFuc2Zlci9odHRwLWRhdGEtdHJhbnNmZXInO1xuaW1wb3J0IHtGaWxlRW50cnl9IGZyb20gJy4uL2xpc3RpbmcvZmlsZS1lbnRyeSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VsZGVyLWZpbGUtdXBsb2FkJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2ZpbGUtdXBsb2FkLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmlsZS11cGxvYWQuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckZpbGVVcGxvYWRDb21wb25lbnQge1xuXG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIEZpZWxkcyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgQElucHV0KClcbiAgcHVibGljIGZpbGVzOiBGaWxlRW50cnlbXSA9IFtdO1xuICBwdWJsaWMgdXBsb2FkUHJvZ3Jlc3M6IE1hcDxGaWxlLCBIdHRwRGF0YVRyYW5zZmVyPjtcbiAgcHVibGljIHRvdGFsUHJvZ3Jlc3M6IE9ic2VydmFibGU8YW55PjtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgbXVsdGlwbGUgPSBmYWxzZTtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgYWNjZXB0OiBzdHJpbmcgPSB1bmRlZmluZWQ7XG5cbiAgQElucHV0KClcbiAgcHVibGljIHVwbG9hZENsaWVudDogSUZpbGVVcGxvYWRDbGllbnQ7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIENvbnN0cnVjdG9yICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgY29uc3RydWN0b3IoKSB7XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogUHVibGljIEFQSSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwdWJsaWMgc3RhcnRVcGxvYWQoZXZlbnQ6IGFueSk6IHZvaWQge1xuICAgIHRoaXMudG90YWxQcm9ncmVzcyA9IHRoaXMudXBsb2FkQWxsRmlsZXModGhpcy5maWxlcyk7XG4gIH1cblxuICBwdWJsaWMgdHJhbnNmZXJPZihmaWxlOiBGaWxlKTogSHR0cERhdGFUcmFuc2ZlciB7XG4gICAgaWYgKHRoaXMudXBsb2FkUHJvZ3Jlc3MpIHtcbiAgICAgIHJldHVybiB0aGlzLnVwbG9hZFByb2dyZXNzLmdldChmaWxlKTtcbiAgICB9XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQcml2YXRlIG1ldGhvZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByaXZhdGUgdXBsb2FkQWxsRmlsZXMoZW50cmllczogRmlsZUVudHJ5W10pOiBPYnNlcnZhYmxlPGFueT4ge1xuICAgIHRoaXMudXBsb2FkUHJvZ3Jlc3MgPSB0aGlzLnVwbG9hZENsaWVudC51cGxvYWRGaWxlcyhcbiAgICAgIEZpbGVFbnRyeS50b0ZpbGVBcnJheShlbnRyaWVzKVxuICAgICk7XG4gICAgcmV0dXJuIGZvcmtKb2luKFxuICAgICAgQXJyYXkuZnJvbSh0aGlzLnVwbG9hZFByb2dyZXNzLnZhbHVlcygpKVxuICAgICk7XG4gIH1cblxufVxuIiwiXG5cbjxkaXYgY2xhc3M9XCJsYXlvdXQtY29sXCI+XG5cbiAgPGRpdiBjbGFzcz1cImxheW91dC1yb3cgZ2FwLW1kXCI+XG5cbiAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiB0eXBlPVwiYnV0dG9uXCIgY29sb3I9XCJwcmltYXJ5XCJcbiAgICAgICAgICAgICpuZ0lmPVwidXBsb2FkQ2xpZW50XCIgIChjbGljayk9XCJzdGFydFVwbG9hZCgkZXZlbnQpXCIgW2Rpc2FibGVkXT1cImZpbGVzLmxlbmd0aCA9PT0gMFwiPlxuICAgICAgPG1hdC1pY29uPmNsb3VkX3VwbG9hZDwvbWF0LWljb24+XG4gICAgPC9idXR0b24+XG5cbiAgICA8ZWxkZXItZmlsZS1zZWxlY3RcbiAgICAgICAgICAgIFttdWx0aXBsZV09XCJtdWx0aXBsZVwiXG4gICAgICAgICAgICBbYWNjZXB0XT1cImFjY2VwdFwiXG4gICAgICAgICAgICAoZmlsZXNDaGFuZ2UpPVwiZmlsZXMgPSAkZXZlbnRcIlxuICAgID48L2VsZGVyLWZpbGUtc2VsZWN0PlxuXG4gIDwvZGl2PlxuXG4gIDxtYXQtbGlzdD5cbiAgICA8aDIgbWF0LXN1YmhlYWRlcj5TZWxlY3RlZCBGaWxlcyAoe3tmaWxlcy5sZW5ndGh9fSk8L2gyPlxuICAgIDxtYXQtbGlzdC1pdGVtICpuZ0Zvcj1cImxldCBmaWxlRW50cnkgb2YgZmlsZXNcIj5cbiAgICAgIDxtYXQtaWNvbiBtYXQtbGlzdC1pY29uPmF0dGFjaF9maWxlPC9tYXQtaWNvbj5cbiAgICAgIDxoNCBtYXQtbGluZT57e2ZpbGVFbnRyeS5yZWxhdGl2ZVBhdGh9fTwvaDQ+XG4gICAgICA8cCBtYXQtbGluZT4ge3tmaWxlRW50cnkuZmlsZS5zaXplIHwgYnl0ZXN9fSAgLSB7e2ZpbGVFbnRyeS5maWxlLmxhc3RNb2RpZmllZCB8IHRpbWVBZ299fTwvcD5cblxuICAgICAgPG1hdC1wcm9ncmVzcy1iYXIgKm5nSWY9XCIodHJhbnNmZXJPZihmaWxlRW50cnkuZmlsZSk/LnN0YXRlJCB8IGFzeW5jKSBhcyBzdGF0ZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICBbY29sb3JdPVwiKHN0YXRlLmhhc0ZhaWxlZCA/ICd3YXJuJyA6IHVuZGVmaW5lZClcIlxuICAgICAgICAgICAgICAgICAgICAgICAgbW9kZT1cImRldGVybWluYXRlXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIFt2YWx1ZV09XCJzdGF0ZS5wcm9ncmVzcy5wZXJjZW50RG9uZVwiPlxuICAgICAgPC9tYXQtcHJvZ3Jlc3MtYmFyPlxuXG4gICAgPC9tYXQtbGlzdC1pdGVtPlxuICA8L21hdC1saXN0PlxuXG48L2Rpdj5cbiJdfQ==
|
|
@@ -1,30 +1,76 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Represents a file and the relative path where the user has selected it.
|
|
3
|
+
* This is useful if the user has selected a folder and files
|
|
4
|
+
* are listed recursively.
|
|
5
|
+
*/
|
|
6
|
+
export class FileEntry {
|
|
7
|
+
/***************************************************************************
|
|
8
|
+
* *
|
|
9
|
+
* Constructor *
|
|
10
|
+
* *
|
|
11
|
+
**************************************************************************/
|
|
3
12
|
constructor(file,
|
|
4
13
|
/**
|
|
5
14
|
* Contains the relative path from the selected folder
|
|
6
15
|
* to this file. Only relevant if the user has selected a folder.
|
|
7
16
|
*/
|
|
8
17
|
relativeParent) {
|
|
9
|
-
|
|
18
|
+
this.file = file;
|
|
10
19
|
this.relativeParent = relativeParent;
|
|
20
|
+
this.relativePath = FileEntry.buildRelativePath(relativeParent, file);
|
|
11
21
|
}
|
|
12
22
|
/**
|
|
13
|
-
*
|
|
23
|
+
* Creates a file Entry without an explicit relative parent.
|
|
24
|
+
*
|
|
25
|
+
* However, depending how the file was selected, some browsers
|
|
26
|
+
* encode the relative parent path in the property 'webkitRelativePath'
|
|
27
|
+
* which is also supported by this method.
|
|
14
28
|
*/
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
29
|
+
static ofFile(file) {
|
|
30
|
+
let relativeParent = null;
|
|
31
|
+
if (file.webkitRelativePath) {
|
|
32
|
+
if (file.webkitRelativePath.endsWith(file.name)) {
|
|
33
|
+
var nameStart = file.webkitRelativePath.length - file.name.length;
|
|
34
|
+
relativeParent = file.webkitRelativePath.substring(0, nameStart);
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
relativeParent = file.webkitRelativePath;
|
|
38
|
+
}
|
|
18
39
|
}
|
|
19
|
-
|
|
20
|
-
|
|
40
|
+
return FileEntry.relativeFile(file, relativeParent);
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Creates a file Entry with a relative parent path
|
|
44
|
+
*/
|
|
45
|
+
static relativeFile(file, relativeParent) {
|
|
46
|
+
if (relativeParent && relativeParent.endsWith('/')) {
|
|
47
|
+
relativeParent = relativeParent.substring(0, relativeParent.length - 1);
|
|
21
48
|
}
|
|
49
|
+
return new FileEntry(file, relativeParent);
|
|
22
50
|
}
|
|
51
|
+
static toFileMap(entries) {
|
|
52
|
+
const map = new Map();
|
|
53
|
+
entries.forEach(e => map.set(e.file, e));
|
|
54
|
+
return map;
|
|
55
|
+
}
|
|
56
|
+
static toFileArray(entries) {
|
|
57
|
+
return entries.map(e => e.file);
|
|
58
|
+
}
|
|
59
|
+
/***************************************************************************
|
|
60
|
+
* *
|
|
61
|
+
* Private methods *
|
|
62
|
+
* *
|
|
63
|
+
**************************************************************************/
|
|
23
64
|
/**
|
|
24
65
|
* Returns a string which specifies the file's path relative to the directory selected by the user.
|
|
25
66
|
*/
|
|
26
|
-
|
|
27
|
-
|
|
67
|
+
static buildRelativePath(relativeParent, file) {
|
|
68
|
+
if (relativeParent != null) {
|
|
69
|
+
return relativeParent + '/' + file.name;
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
return file.name;
|
|
73
|
+
}
|
|
28
74
|
}
|
|
29
75
|
}
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1lbnRyeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvZmlsZXMvbGlzdGluZy9maWxlLWVudHJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0dBSUc7QUFDSCxNQUFNLE9BQU8sU0FBUztJQTJEcEI7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ2tCLElBQVU7SUFDMUI7OztPQUdHO0lBQ2EsY0FBNkI7UUFMN0IsU0FBSSxHQUFKLElBQUksQ0FBTTtRQUtWLG1CQUFjLEdBQWQsY0FBYyxDQUFlO1FBRTdDLElBQUksQ0FBQyxZQUFZLEdBQUcsU0FBUyxDQUFDLGlCQUFpQixDQUFDLGNBQWMsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUN4RSxDQUFDO0lBeEVEOzs7Ozs7T0FNRztJQUNJLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBVTtRQUU3QixJQUFJLGNBQWMsR0FBVyxJQUFJLENBQUM7UUFFbEMsSUFBSSxJQUFJLENBQUMsa0JBQWtCLEVBQUU7WUFDM0IsSUFBSSxJQUFJLENBQUMsa0JBQWtCLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRTtnQkFDL0MsSUFBSSxTQUFTLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztnQkFDbEUsY0FBYyxHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxDQUFDO2FBQ2xFO2lCQUFNO2dCQUNMLGNBQWMsR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUM7YUFDMUM7U0FDRjtRQUVELE9BQU8sU0FBUyxDQUFDLFlBQVksQ0FDM0IsSUFBSSxFQUNKLGNBQWMsQ0FDZixDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0ksTUFBTSxDQUFDLFlBQVksQ0FBQyxJQUFVLEVBQUUsY0FBNkI7UUFDbEUsSUFBSSxjQUFjLElBQUksY0FBYyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUNsRCxjQUFjLEdBQUcsY0FBYyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsY0FBYyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztTQUN6RTtRQUNELE9BQU8sSUFBSSxTQUFTLENBQUMsSUFBSSxFQUFFLGNBQWMsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFTSxNQUFNLENBQUMsU0FBUyxDQUFDLE9BQW9CO1FBQzFDLE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxFQUFtQixDQUFDO1FBQ3ZDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN6QyxPQUFPLEdBQUcsQ0FBQztJQUNiLENBQUM7SUFFTSxNQUFNLENBQUMsV0FBVyxDQUFDLE9BQW9CO1FBQzVDLE9BQU8sT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBOEJEOzs7O2dGQUk0RTtJQUU1RTs7T0FFRztJQUNLLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxjQUFzQixFQUFFLElBQVU7UUFDakUsSUFBSSxjQUFjLElBQUksSUFBSSxFQUFFO1lBQzFCLE9BQU8sY0FBYyxHQUFHLEdBQUcsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO1NBQ3pDO2FBQU07WUFDTCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7U0FDbEI7SUFDSCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFJlcHJlc2VudHMgYSBmaWxlIGFuZCB0aGUgcmVsYXRpdmUgcGF0aCB3aGVyZSB0aGUgdXNlciBoYXMgc2VsZWN0ZWQgaXQuXG4gKiBUaGlzIGlzIHVzZWZ1bCBpZiB0aGUgdXNlciBoYXMgc2VsZWN0ZWQgYSBmb2xkZXIgYW5kIGZpbGVzXG4gKiBhcmUgbGlzdGVkIHJlY3Vyc2l2ZWx5LlxuICovXG5leHBvcnQgY2xhc3MgRmlsZUVudHJ5IHtcblxuICAvKipcbiAgICogQ3JlYXRlcyBhIGZpbGUgRW50cnkgd2l0aG91dCBhbiBleHBsaWNpdCByZWxhdGl2ZSBwYXJlbnQuXG4gICAqXG4gICAqIEhvd2V2ZXIsIGRlcGVuZGluZyBob3cgdGhlIGZpbGUgd2FzIHNlbGVjdGVkLCBzb21lIGJyb3dzZXJzXG4gICAqIGVuY29kZSB0aGUgcmVsYXRpdmUgcGFyZW50IHBhdGggaW4gdGhlIHByb3BlcnR5ICd3ZWJraXRSZWxhdGl2ZVBhdGgnXG4gICAqIHdoaWNoIGlzIGFsc28gc3VwcG9ydGVkIGJ5IHRoaXMgbWV0aG9kLlxuICAgKi9cbiAgcHVibGljIHN0YXRpYyBvZkZpbGUoZmlsZTogRmlsZSk6IEZpbGVFbnRyeSB7XG5cbiAgICBsZXQgcmVsYXRpdmVQYXJlbnQ6IHN0cmluZyA9IG51bGw7XG5cbiAgICBpZiAoZmlsZS53ZWJraXRSZWxhdGl2ZVBhdGgpIHtcbiAgICAgIGlmIChmaWxlLndlYmtpdFJlbGF0aXZlUGF0aC5lbmRzV2l0aChmaWxlLm5hbWUpKSB7XG4gICAgICAgIHZhciBuYW1lU3RhcnQgPSBmaWxlLndlYmtpdFJlbGF0aXZlUGF0aC5sZW5ndGggLSBmaWxlLm5hbWUubGVuZ3RoO1xuICAgICAgICByZWxhdGl2ZVBhcmVudCA9IGZpbGUud2Via2l0UmVsYXRpdmVQYXRoLnN1YnN0cmluZygwLCBuYW1lU3RhcnQpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmVsYXRpdmVQYXJlbnQgPSBmaWxlLndlYmtpdFJlbGF0aXZlUGF0aDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gRmlsZUVudHJ5LnJlbGF0aXZlRmlsZShcbiAgICAgIGZpbGUsXG4gICAgICByZWxhdGl2ZVBhcmVudFxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhIGZpbGUgRW50cnkgd2l0aCBhIHJlbGF0aXZlIHBhcmVudCBwYXRoXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIHJlbGF0aXZlRmlsZShmaWxlOiBGaWxlLCByZWxhdGl2ZVBhcmVudDogc3RyaW5nIHwgbnVsbCkge1xuICAgIGlmIChyZWxhdGl2ZVBhcmVudCAmJiByZWxhdGl2ZVBhcmVudC5lbmRzV2l0aCgnLycpKSB7XG4gICAgICByZWxhdGl2ZVBhcmVudCA9IHJlbGF0aXZlUGFyZW50LnN1YnN0cmluZygwLCByZWxhdGl2ZVBhcmVudC5sZW5ndGggLSAxKTtcbiAgICB9XG4gICAgcmV0dXJuIG5ldyBGaWxlRW50cnkoZmlsZSwgcmVsYXRpdmVQYXJlbnQpO1xuICB9XG5cbiAgcHVibGljIHN0YXRpYyB0b0ZpbGVNYXAoZW50cmllczogRmlsZUVudHJ5W10pOiBNYXA8RmlsZSwgRmlsZUVudHJ5PiB7XG4gICAgY29uc3QgbWFwID0gbmV3IE1hcDxGaWxlLCBGaWxlRW50cnk+KCk7XG4gICAgZW50cmllcy5mb3JFYWNoKGUgPT4gbWFwLnNldChlLmZpbGUsIGUpKTtcbiAgICByZXR1cm4gbWFwO1xuICB9XG5cbiAgcHVibGljIHN0YXRpYyB0b0ZpbGVBcnJheShlbnRyaWVzOiBGaWxlRW50cnlbXSk6IEZpbGVbXSB7XG4gICAgcmV0dXJuIGVudHJpZXMubWFwKGUgPT4gZS5maWxlKTtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBGaWVsZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGEgc3RyaW5nIHdoaWNoIHNwZWNpZmllcyB0aGUgZmlsZSdzIHBhdGggcmVsYXRpdmUgdG8gdGhlIGRpcmVjdG9yeSBzZWxlY3RlZCBieSB0aGUgdXNlci5cbiAgICovXG4gIHB1YmxpYyByZWFkb25seSByZWxhdGl2ZVBhdGg6IHN0cmluZztcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogQ29uc3RydWN0b3IgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyByZWFkb25seSBmaWxlOiBGaWxlLFxuICAgIC8qKlxuICAgICAqIENvbnRhaW5zIHRoZSByZWxhdGl2ZSBwYXRoIGZyb20gdGhlIHNlbGVjdGVkIGZvbGRlclxuICAgICAqIHRvIHRoaXMgZmlsZS4gT25seSByZWxldmFudCBpZiB0aGUgdXNlciBoYXMgc2VsZWN0ZWQgYSBmb2xkZXIuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IHJlbGF0aXZlUGFyZW50OiBzdHJpbmcgfCBudWxsXG4gICkge1xuICAgIHRoaXMucmVsYXRpdmVQYXRoID0gRmlsZUVudHJ5LmJ1aWxkUmVsYXRpdmVQYXRoKHJlbGF0aXZlUGFyZW50LCBmaWxlKTtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQcml2YXRlIG1ldGhvZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGEgc3RyaW5nIHdoaWNoIHNwZWNpZmllcyB0aGUgZmlsZSdzIHBhdGggcmVsYXRpdmUgdG8gdGhlIGRpcmVjdG9yeSBzZWxlY3RlZCBieSB0aGUgdXNlci5cbiAgICovXG4gIHByaXZhdGUgc3RhdGljIGJ1aWxkUmVsYXRpdmVQYXRoKHJlbGF0aXZlUGFyZW50OiBzdHJpbmcsIGZpbGU6IEZpbGUpOiBzdHJpbmcge1xuICAgIGlmIChyZWxhdGl2ZVBhcmVudCAhPSBudWxsKSB7XG4gICAgICByZXR1cm4gcmVsYXRpdmVQYXJlbnQgKyAnLycgKyBmaWxlLm5hbWU7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBmaWxlLm5hbWU7XG4gICAgfVxuICB9XG59XG4iXX0=
|