@elderbyte/ngx-starter 18.1.0-beta → 18.1.0-beta2
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/esm2022/lib/components/files/elder-file-select.directive.mjs +11 -10
- package/esm2022/lib/components/files/file-system-api.mjs +9 -1
- package/esm2022/lib/components/files/listing/file-listing-rx.mjs +7 -4
- package/fesm2022/elderbyte-ngx-starter.mjs +24 -12
- package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/components/files/elder-file-select.directive.d.ts +1 -0
- package/lib/components/files/file-system-api.d.ts +5 -1
- package/lib/components/files/listing/file-listing-rx.d.ts +1 -0
- package/package.json +1 -1
|
@@ -39,13 +39,7 @@ export class ElderFileSelectDirective {
|
|
|
39
39
|
this.logger.warn('showOpenFilePicker or showDirectoryPicker is not supported for this browser, falling back to legacy file picker');
|
|
40
40
|
this._legacyInput.createFileSelect();
|
|
41
41
|
this._legacyInput.filesSelected.pipe(takeUntilDestroyed(this.destroyRef)).subscribe({
|
|
42
|
-
next: multiFileChange =>
|
|
43
|
-
this.elderFileSelectChange.next(multiFileChange);
|
|
44
|
-
const file = multiFileChange[0]?.file;
|
|
45
|
-
if (file) {
|
|
46
|
-
this.elderSingleFileSelectChange.next(file);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
42
|
+
next: multiFileChange => this.pushFileChanges(multiFileChange)
|
|
49
43
|
});
|
|
50
44
|
}
|
|
51
45
|
}
|
|
@@ -119,12 +113,12 @@ export class ElderFileSelectDirective {
|
|
|
119
113
|
onClick(event) {
|
|
120
114
|
if (!this._useDirectoryPicker && FileSystemApi.isFileSystemSupported()) {
|
|
121
115
|
this.openFilePicker(this._filePickerOptions).subscribe({
|
|
122
|
-
next:
|
|
116
|
+
next: multiFileChange => this.pushFileChanges(multiFileChange)
|
|
123
117
|
});
|
|
124
118
|
}
|
|
125
119
|
else if (this._useDirectoryPicker && FileSystemApi.isDirectoryPickerSupported()) {
|
|
126
120
|
this.openDirectoryPicker(this._directoryPickerOptions).subscribe({
|
|
127
|
-
next:
|
|
121
|
+
next: multiFileChange => this.pushFileChanges(multiFileChange)
|
|
128
122
|
});
|
|
129
123
|
}
|
|
130
124
|
else {
|
|
@@ -136,6 +130,13 @@ export class ElderFileSelectDirective {
|
|
|
136
130
|
* Private methods *
|
|
137
131
|
* *
|
|
138
132
|
**************************************************************************/
|
|
133
|
+
pushFileChanges(multiFileChange) {
|
|
134
|
+
this.elderFileSelectChange.next(multiFileChange);
|
|
135
|
+
const file = multiFileChange[0]?.file;
|
|
136
|
+
if (file) {
|
|
137
|
+
this.elderSingleFileSelectChange.next(file);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
139
140
|
openFilePicker(pickerOpts) {
|
|
140
141
|
return FileSystemApi.openFilePicker(pickerOpts).pipe(switchMap(files => combineLatest(files.map(file => FileEntry.ofFileHandle(file)))));
|
|
141
142
|
}
|
|
@@ -165,4 +166,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImpor
|
|
|
165
166
|
type: HostListener,
|
|
166
167
|
args: ['click', ['$event']]
|
|
167
168
|
}] } });
|
|
168
|
-
//# 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  DestroyRef,\n  Directive, ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output, Renderer2\n} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {FileEntry} from './listing/file-entry';\nimport {ElderFileSelectInput} from './elder-file-select-input';\nimport {\n  FileSystemApi,\n  FileSystemDirectoryPickerOptions,\n  FileSystemFilePickerOptions,\n  FileSystemFilePickerTypeOptions\n} from './file-system-api';\nimport {combineLatest, Observable, switchMap} from 'rxjs';\nimport {FileListingSystemHandle} from './listing/file-listing-system-handle';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\n\n\n@Directive({\n  selector: '[elderFileSelect]',\n  standalone: true\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  @Output()\n  public readonly elderFileSelectChange = new EventEmitter<FileEntry[]>();\n\n  @Output()\n  public readonly elderSingleFileSelectChange = new EventEmitter<File>();\n\n  private _legacyInput: ElderFileSelectInput;\n  private _filePickerOptions: FileSystemFilePickerOptions;\n  private _directoryPickerOptions: FileSystemDirectoryPickerOptions;\n  private _useDirectoryPicker: boolean = false;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private renderer: Renderer2,\n    private el: ElementRef,\n    private destroyRef: DestroyRef\n  ) {\n    this._legacyInput = new ElderFileSelectInput(this.renderer, this.el);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    if (!FileSystemApi.isFileSystemSupported() || !FileSystemApi.isDirectoryPickerSupported()) {\n      this.logger.warn('showOpenFilePicker or showDirectoryPicker is not supported for this browser, falling back to legacy file picker');\n      this._legacyInput.createFileSelect();\n      this._legacyInput.filesSelected.pipe(\n        takeUntilDestroyed(this.destroyRef)\n      ).subscribe({\n        next: multiFileChange => {\n          this.elderFileSelectChange.next(multiFileChange);\n          const file = multiFileChange[0]?.file;\n          if(file){\n            this.elderSingleFileSelectChange.next(file);\n          }\n        }\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this._legacyInput.removeFileSelect();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set elderFileSelect(value: string) {\n\n    this._filePickerOptions = {\n      excludeAcceptAllOptions: true,\n      id: this._filePickerOptions?.id,\n      multiple: this._filePickerOptions?.multiple,\n      startIn: this._filePickerOptions?.startIn,\n      types: [this.buildTypeOption(value)]\n    };\n\n    this._legacyInput.elderFileSelect = value;\n  }\n\n  private buildTypeOption(value: string): FileSystemFilePickerTypeOptions {\n    if (this.isFileExtension(value)) {\n      return {\n        accept: {\n          '*/*': value.trim()\n            .replace(/\\s+/g, '')\n            .split(',')\n        }\n      };\n    } else if (this.isMimeType(value)) {\n      return {\n        accept: {[value]: []}\n      };\n    }\n    return null;\n  }\n\n  private isFileExtension(input: string): boolean {\n    const regex = new RegExp(/^(\\.\\w+)(, ?\\.\\w+)*$/);\n    return regex.test(input);\n  }\n\n  private isMimeType(input: string): boolean {\n    const regex = new RegExp(/^.+\\/.+$/);\n    return regex.test(input);\n  }\n\n\n  @Input()\n  public set elderFileSelectMultiple(value: BooleanInput) {\n\n    this._filePickerOptions = {\n      excludeAcceptAllOptions: this._filePickerOptions?.excludeAcceptAllOptions,\n      id: this._filePickerOptions?.id,\n      multiple: coerceBooleanProperty(value),\n      startIn: this._filePickerOptions?.startIn,\n      types: this._filePickerOptions?.types\n    };\n\n    this._legacyInput.elderFileSelectMultiple = value;\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._useDirectoryPicker = coerceBooleanProperty(value);\n    this._legacyInput.elderFileSelectDirectory = value;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('click', ['$event'])\n  public onClick(event: any): void {\n    if (!this._useDirectoryPicker && FileSystemApi.isFileSystemSupported()) {\n      this.openFilePicker(this._filePickerOptions).subscribe({\n        next: fileList => this.elderFileSelectChange.next(fileList)\n      });\n    } else if (this._useDirectoryPicker && FileSystemApi.isDirectoryPickerSupported()) {\n      this.openDirectoryPicker(this._directoryPickerOptions).subscribe({\n        next: fileList => this.elderFileSelectChange.next(fileList)\n      });\n    } else {\n      this._legacyInput.openFileSelectDialog();\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  public openFilePicker(pickerOpts: FileSystemFilePickerOptions): Observable<FileEntry[]> {\n    return FileSystemApi.openFilePicker(pickerOpts).pipe(\n      switchMap(files =>\n        combineLatest(files.map(file => FileEntry.ofFileHandle(file)))\n      )\n    );\n  }\n\n  public openDirectoryPicker(pickerOpts: FileSystemDirectoryPickerOptions): Observable<FileEntry[]> {\n    return FileSystemApi.openDirectoryPicker(pickerOpts).pipe(\n      switchMap(dir => FileListingSystemHandle.listFiles(dir))\n    );\n  }\n\n}\n\n\n\n"]}
|
|
169
|
+
//# 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  DestroyRef,\n  Directive, ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output, Renderer2\n} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {FileEntry} from './listing/file-entry';\nimport {ElderFileSelectInput} from './elder-file-select-input';\nimport {\n  FileSystemApi,\n  FileSystemDirectoryPickerOptions,\n  FileSystemFilePickerOptions,\n  FileSystemFilePickerTypeOptions\n} from './file-system-api';\nimport {combineLatest, Observable, switchMap} from 'rxjs';\nimport {FileListingSystemHandle} from './listing/file-listing-system-handle';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\n\n\n@Directive({\n  selector: '[elderFileSelect]',\n  standalone: true\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  @Output()\n  public readonly elderFileSelectChange = new EventEmitter<FileEntry[]>();\n\n  @Output()\n  public readonly elderSingleFileSelectChange = new EventEmitter<File>();\n\n  private _legacyInput: ElderFileSelectInput;\n  private _filePickerOptions: FileSystemFilePickerOptions;\n  private _directoryPickerOptions: FileSystemDirectoryPickerOptions;\n  private _useDirectoryPicker: boolean = false;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private renderer: Renderer2,\n    private el: ElementRef,\n    private destroyRef: DestroyRef\n  ) {\n    this._legacyInput = new ElderFileSelectInput(this.renderer, this.el);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    if (!FileSystemApi.isFileSystemSupported() || !FileSystemApi.isDirectoryPickerSupported()) {\n      this.logger.warn('showOpenFilePicker or showDirectoryPicker is not supported for this browser, falling back to legacy file picker');\n      this._legacyInput.createFileSelect();\n      this._legacyInput.filesSelected.pipe(\n        takeUntilDestroyed(this.destroyRef)\n      ).subscribe({\n        next: multiFileChange => this.pushFileChanges(multiFileChange)\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this._legacyInput.removeFileSelect();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set elderFileSelect(value: string) {\n\n    this._filePickerOptions = {\n      excludeAcceptAllOptions: true,\n      id: this._filePickerOptions?.id,\n      multiple: this._filePickerOptions?.multiple,\n      startIn: this._filePickerOptions?.startIn,\n      types: [this.buildTypeOption(value)]\n    };\n\n    this._legacyInput.elderFileSelect = value;\n  }\n\n  private buildTypeOption(value: string): FileSystemFilePickerTypeOptions {\n    if (this.isFileExtension(value)) {\n      return {\n        accept: {\n          '*/*': value.trim()\n            .replace(/\\s+/g, '')\n            .split(',')\n        }\n      };\n    } else if (this.isMimeType(value)) {\n      return {\n        accept: {[value]: []}\n      };\n    }\n    return null;\n  }\n\n  private isFileExtension(input: string): boolean {\n    const regex = new RegExp(/^(\\.\\w+)(, ?\\.\\w+)*$/);\n    return regex.test(input);\n  }\n\n  private isMimeType(input: string): boolean {\n    const regex = new RegExp(/^.+\\/.+$/);\n    return regex.test(input);\n  }\n\n\n  @Input()\n  public set elderFileSelectMultiple(value: BooleanInput) {\n\n    this._filePickerOptions = {\n      excludeAcceptAllOptions: this._filePickerOptions?.excludeAcceptAllOptions,\n      id: this._filePickerOptions?.id,\n      multiple: coerceBooleanProperty(value),\n      startIn: this._filePickerOptions?.startIn,\n      types: this._filePickerOptions?.types\n    };\n\n    this._legacyInput.elderFileSelectMultiple = value;\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._useDirectoryPicker = coerceBooleanProperty(value);\n    this._legacyInput.elderFileSelectDirectory = value;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('click', ['$event'])\n  public onClick(event: any): void {\n    if (!this._useDirectoryPicker && FileSystemApi.isFileSystemSupported()) {\n      this.openFilePicker(this._filePickerOptions).subscribe({\n        next: multiFileChange => this.pushFileChanges(multiFileChange)\n      });\n    } else if (this._useDirectoryPicker && FileSystemApi.isDirectoryPickerSupported()) {\n      this.openDirectoryPicker(this._directoryPickerOptions).subscribe({\n        next: multiFileChange => this.pushFileChanges(multiFileChange)\n      });\n    } else {\n      this._legacyInput.openFileSelectDialog();\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private pushFileChanges(multiFileChange: FileEntry[]): void {\n    this.elderFileSelectChange.next(multiFileChange);\n    const file = multiFileChange[0]?.file;\n    if (file) {\n      this.elderSingleFileSelectChange.next(file);\n    }\n  }\n\n  public openFilePicker(pickerOpts: FileSystemFilePickerOptions): Observable<FileEntry[]> {\n    return FileSystemApi.openFilePicker(pickerOpts).pipe(\n      switchMap(files =>\n        combineLatest(files.map(file => FileEntry.ofFileHandle(file)))\n      )\n    );\n  }\n\n  public openDirectoryPicker(pickerOpts: FileSystemDirectoryPickerOptions): Observable<FileEntry[]> {\n    return FileSystemApi.openDirectoryPicker(pickerOpts).pipe(\n      switchMap(dir => FileListingSystemHandle.listFiles(dir))\n    );\n  }\n\n}\n\n\n\n"]}
|
|
@@ -19,6 +19,10 @@ export class FileSystemApi {
|
|
|
19
19
|
// @ts-ignore
|
|
20
20
|
return transferItem.getAsFileSystemHandle !== undefined;
|
|
21
21
|
}
|
|
22
|
+
/**
|
|
23
|
+
* Returns an FileSystemHandle Observable of the given DataTransferItem. The FileSystemHandle can only be accessed in the `dragstart`
|
|
24
|
+
* or `drop` event. Otherwise, it will return null!
|
|
25
|
+
*/
|
|
22
26
|
static getAsFileSystemHandle(transferItem) {
|
|
23
27
|
// @ts-ignore
|
|
24
28
|
return from(transferItem.getAsFileSystemHandle());
|
|
@@ -71,7 +75,11 @@ export class FileSystemApi {
|
|
|
71
75
|
}
|
|
72
76
|
const relativeParents$ = from(rootDirectory.resolve(fileOrDirHandle));
|
|
73
77
|
return relativeParents$.pipe(map(parents => {
|
|
78
|
+
// path/to/folder/file.jpg
|
|
74
79
|
const path = parents;
|
|
80
|
+
// root/path/to/folder/file.jpg
|
|
81
|
+
path.unshift(rootDirectory.name);
|
|
82
|
+
// root/path/to/folder
|
|
75
83
|
path.pop();
|
|
76
84
|
return path.join('/');
|
|
77
85
|
}));
|
|
@@ -85,4 +93,4 @@ export class FileSystemApi {
|
|
|
85
93
|
return handles;
|
|
86
94
|
}
|
|
87
95
|
}
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-system-api.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/files/file-system-api.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAc,EAAE,EAAE,UAAU,EAAC,MAAM,MAAM,CAAC;AACtD,OAAO,EAAC,GAAG,EAAC,MAAM,gBAAgB,CAAC;AAiDnC;;;;4EAI4E;AAE5E;;;GAGG;AACH,MAAM,OAAO,aAAa;IAExB;;;;gFAI4E;IAErE,MAAM,CAAC,gCAAgC,CAAC,YAA8B;QAC3E,aAAa;QACb,OAAO,YAAY,CAAC,qBAAqB,KAAK,SAAS,CAAC;IAC1D,CAAC;IAEM,MAAM,CAAC,qBAAqB,CAAC,YAA8B;QAChE,aAAa;QACb,OAAO,IAAI,CAAC,YAAY,CAAC,qBAAqB,EAAE,CAAC,CAAC;IACpD,CAAC;IAED;;;;gFAI4E;IAErE,MAAM,CAAC,qBAAqB;QACjC,OAAO,oBAAoB,IAAI,MAAM,CAAC;IACxC,CAAC;IAEM,MAAM,CAAC,cAAc,CAAC,UAAuC;QAClE,IAAI,CAAC;YACH,aAAa;YACb,OAAO,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC,CAAC;QACrD,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAED;;;;gFAI4E;IAErE,MAAM,CAAC,0BAA0B;QACtC,OAAO,qBAAqB,IAAI,MAAM,CAAC;IACzC,CAAC;IAEM,MAAM,CAAC,mBAAmB,CAAC,UAA4C;QAC5E,IAAI,CAAC;YACH,aAAa;YACb,OAAO,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC,CAAC;QACtD,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAED;;;;gFAI4E;IAErE,MAAM,CAAC,uBAAuB,CAAC,SAAoC;QACxE,OAAO,IAAI,CAAC,aAAa,CAAC,4BAA4B,CAAC,SAAS,CAAC,CAAC,CAAC;IACrE,CAAC;IAEM,MAAM,CAAC,mBAAmB,CAC/B,eAAiC,EACjC,aAAyC;QAGzC,IAAI,aAAa,IAAI,IAAI,EAAE,CAAC;YACxB,OAAO,EAAE,CAAC,SAAS,CAAC,CAAC;QACzB,CAAC;QAED,MAAM,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC;QACtE,OAAO,gBAAgB,CAAC,IAAI,CAC1B,GAAG,CAAC,OAAO,CAAC,EAAE;YACZ,MAAM,IAAI,GAAG,OAAO,CAAC;YACrB,IAAI,CAAC,GAAG,EAAE,CAAC;YACX,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACxB,CAAC,CACF,CAAC,CAAA;IACJ,CAAC;IAEO,MAAM,CAAC,KAAK,CAAC,4BAA4B,CAAC,SAAoC;QACpF,MAAM,OAAO,GAAuB,EAAE,CAAC;QACvC,aAAa;QACb,IAAI,KAAK,EAAE,MAAM,MAAM,IAAI,SAAS,CAAC,MAAM,EAAE,EAAE,CAAC;YAC9C,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvB,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;CACF","sourcesContent":["import {from, Observable, of, throwError} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n/***************************************************************************\n *                                                                         *\n * File Picker Options                                                     *\n *                                                                         *\n **************************************************************************/\n\nexport interface FileSystemFilePickerOptions {\n  /**\n   *\n   * ```\n   *   types: [\n   *     {\n   *       description: \"Images\",\n   *       accept: {\n   *         \"image/*\": [\".png\", \".gif\", \".jpeg\", \".jpg\"],\n   *       },\n   *     },\n   *   ],\n   *   excludeAcceptAllOption: true,\n   *   multiple: false,\n   * ```\n   */\n  excludeAcceptAllOptions?: boolean,\n  id?: string,\n  multiple?: boolean,\n  startIn?: FileSystemHandle | 'desktop' | 'documents' | 'downloads' | 'music' | 'pictures' | 'videos',\n  types?: FileSystemFilePickerTypeOptions[]\n}\n\nexport interface FileSystemFilePickerTypeOptions {\n  accept: Record<string,string[]>,\n  description?: string\n}\n\n/***************************************************************************\n *                                                                         *\n * Directory Picker Options                                                *\n *                                                                         *\n **************************************************************************/\n\nexport interface FileSystemDirectoryPickerOptions {\n  id?: string,\n  mode?: string,\n  startIn?: FileSystemHandle | 'desktop' | 'documents' | 'downloads' | 'music' | 'pictures' | 'videos'\n}\n\n\n/***************************************************************************\n *                                                                         *\n * FileSystem API                                                          *\n *                                                                         *\n **************************************************************************/\n\n/**\n * Holds experimental features of the browser `File System API`. No typescript lint checks\n * are performed here!\n */\nexport class FileSystemApi {\n\n  /***************************************************************************\n   *                                                                         *\n   * DataTransferItem                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  public static isGetAsFileSystemHandleSupported(transferItem: DataTransferItem): boolean {\n    // @ts-ignore\n    return transferItem.getAsFileSystemHandle !== undefined;\n  }\n\n  public static getAsFileSystemHandle(transferItem: DataTransferItem): Observable<FileSystemHandle> {\n    // @ts-ignore\n    return from(transferItem.getAsFileSystemHandle());\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * File Picker                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  public static isFileSystemSupported(): boolean {\n    return 'showOpenFilePicker' in window;\n  }\n\n  public static openFilePicker(pickerOpts: FileSystemFilePickerOptions): Observable<FileSystemFileHandle[]> {\n    try {\n      // @ts-ignore\n      return from(window.showOpenFilePicker(pickerOpts));\n    } catch (e) {\n      return throwError(() => new Error(e));\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Directory Picker                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  public static isDirectoryPickerSupported(): boolean {\n    return 'showDirectoryPicker' in window;\n  }\n\n  public static openDirectoryPicker(pickerOpts: FileSystemDirectoryPickerOptions): Observable<FileSystemDirectoryHandle> {\n    try {\n      // @ts-ignore\n      return from(window.showDirectoryPicker(pickerOpts));\n    } catch (e) {\n      return throwError(() => new Error(e));\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * FileSystemDirectoryHandle                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  public static getHandlesFromDirectory(dirHandle: FileSystemDirectoryHandle): Observable<FileSystemHandle[]> {\n    return from(FileSystemApi.getHandlesFromDirectoryAsync(dirHandle));\n  }\n\n  public static buildRelativeParent(\n    fileOrDirHandle: FileSystemHandle,\n    rootDirectory?: FileSystemDirectoryHandle\n  ): Observable<string | undefined> {\n\n    if (rootDirectory == null) {\n        return of(undefined);\n    }\n\n    const relativeParents$ = from(rootDirectory.resolve(fileOrDirHandle));\n    return relativeParents$.pipe(\n      map(parents => {\n        const path = parents;\n        path.pop();\n        return path.join('/');\n      }\n    ))\n  }\n\n  private static async getHandlesFromDirectoryAsync(dirHandle: FileSystemDirectoryHandle): Promise<FileSystemHandle[]> {\n    const handles: FileSystemHandle[] = [];\n    // @ts-ignore\n    for await (const handle of dirHandle.values()) {\n      handles.push(handle);\n    }\n    return handles;\n  }\n}\n"]}
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-system-api.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/files/file-system-api.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAc,EAAE,EAAE,UAAU,EAAC,MAAM,MAAM,CAAC;AACtD,OAAO,EAAC,GAAG,EAAC,MAAM,gBAAgB,CAAC;AAiDnC;;;;4EAI4E;AAE5E;;;GAGG;AACH,MAAM,OAAO,aAAa;IAExB;;;;gFAI4E;IAErE,MAAM,CAAC,gCAAgC,CAAC,YAA8B;QAC3E,aAAa;QACb,OAAO,YAAY,CAAC,qBAAqB,KAAK,SAAS,CAAC;IAC1D,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,qBAAqB,CAAC,YAA8B;QAChE,aAAa;QACb,OAAO,IAAI,CAAC,YAAY,CAAC,qBAAqB,EAAE,CAAC,CAAC;IACpD,CAAC;IAED;;;;gFAI4E;IAErE,MAAM,CAAC,qBAAqB;QACjC,OAAO,oBAAoB,IAAI,MAAM,CAAC;IACxC,CAAC;IAEM,MAAM,CAAC,cAAc,CAAC,UAAuC;QAClE,IAAI,CAAC;YACH,aAAa;YACb,OAAO,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC,CAAC;QACrD,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAED;;;;gFAI4E;IAErE,MAAM,CAAC,0BAA0B;QACtC,OAAO,qBAAqB,IAAI,MAAM,CAAC;IACzC,CAAC;IAEM,MAAM,CAAC,mBAAmB,CAAC,UAA4C;QAC5E,IAAI,CAAC;YACH,aAAa;YACb,OAAO,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC,CAAC;QACtD,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAED;;;;gFAI4E;IAErE,MAAM,CAAC,uBAAuB,CAAC,SAAoC;QACxE,OAAO,IAAI,CAAC,aAAa,CAAC,4BAA4B,CAAC,SAAS,CAAC,CAAC,CAAC;IACrE,CAAC;IAEM,MAAM,CAAC,mBAAmB,CAC/B,eAAiC,EACjC,aAAyC;QAGzC,IAAI,aAAa,IAAI,IAAI,EAAE,CAAC;YACxB,OAAO,EAAE,CAAC,SAAS,CAAC,CAAC;QACzB,CAAC;QAED,MAAM,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC;QACtE,OAAO,gBAAgB,CAAC,IAAI,CAC1B,GAAG,CAAC,OAAO,CAAC,EAAE;YACZ,0BAA0B;YAC1B,MAAM,IAAI,GAAG,OAAO,CAAC;YAErB,+BAA+B;YAC/B,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAEjC,sBAAsB;YACtB,IAAI,CAAC,GAAG,EAAE,CAAC;YACX,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACxB,CAAC,CACF,CAAC,CAAA;IACJ,CAAC;IAEO,MAAM,CAAC,KAAK,CAAC,4BAA4B,CAAC,SAAoC;QACpF,MAAM,OAAO,GAAuB,EAAE,CAAC;QACvC,aAAa;QACb,IAAI,KAAK,EAAE,MAAM,MAAM,IAAI,SAAS,CAAC,MAAM,EAAE,EAAE,CAAC;YAC9C,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvB,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;CACF","sourcesContent":["import {from, Observable, of, throwError} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n/***************************************************************************\n *                                                                         *\n * File Picker Options                                                     *\n *                                                                         *\n **************************************************************************/\n\nexport interface FileSystemFilePickerOptions {\n  /**\n   *\n   * ```\n   *   types: [\n   *     {\n   *       description: \"Images\",\n   *       accept: {\n   *         \"image/*\": [\".png\", \".gif\", \".jpeg\", \".jpg\"],\n   *       },\n   *     },\n   *   ],\n   *   excludeAcceptAllOption: true,\n   *   multiple: false,\n   * ```\n   */\n  excludeAcceptAllOptions?: boolean,\n  id?: string,\n  multiple?: boolean,\n  startIn?: FileSystemHandle | 'desktop' | 'documents' | 'downloads' | 'music' | 'pictures' | 'videos',\n  types?: FileSystemFilePickerTypeOptions[]\n}\n\nexport interface FileSystemFilePickerTypeOptions {\n  accept: Record<string,string[]>,\n  description?: string\n}\n\n/***************************************************************************\n *                                                                         *\n * Directory Picker Options                                                *\n *                                                                         *\n **************************************************************************/\n\nexport interface FileSystemDirectoryPickerOptions {\n  id?: string,\n  mode?: string,\n  startIn?: FileSystemHandle | 'desktop' | 'documents' | 'downloads' | 'music' | 'pictures' | 'videos'\n}\n\n\n/***************************************************************************\n *                                                                         *\n * FileSystem API                                                          *\n *                                                                         *\n **************************************************************************/\n\n/**\n * Holds experimental features of the browser `File System API`. No typescript lint checks\n * are performed here!\n */\nexport class FileSystemApi {\n\n  /***************************************************************************\n   *                                                                         *\n   * DataTransferItem                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  public static isGetAsFileSystemHandleSupported(transferItem: DataTransferItem): boolean {\n    // @ts-ignore\n    return transferItem.getAsFileSystemHandle !== undefined;\n  }\n\n  /**\n   * Returns an FileSystemHandle Observable of the given DataTransferItem. The FileSystemHandle can only be accessed in the `dragstart`\n   * or `drop` event. Otherwise, it will return null!\n   */\n  public static getAsFileSystemHandle(transferItem: DataTransferItem): Observable<FileSystemHandle | null> {\n    // @ts-ignore\n    return from(transferItem.getAsFileSystemHandle());\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * File Picker                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  public static isFileSystemSupported(): boolean {\n    return 'showOpenFilePicker' in window;\n  }\n\n  public static openFilePicker(pickerOpts: FileSystemFilePickerOptions): Observable<FileSystemFileHandle[]> {\n    try {\n      // @ts-ignore\n      return from(window.showOpenFilePicker(pickerOpts));\n    } catch (e) {\n      return throwError(() => new Error(e));\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Directory Picker                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  public static isDirectoryPickerSupported(): boolean {\n    return 'showDirectoryPicker' in window;\n  }\n\n  public static openDirectoryPicker(pickerOpts: FileSystemDirectoryPickerOptions): Observable<FileSystemDirectoryHandle> {\n    try {\n      // @ts-ignore\n      return from(window.showDirectoryPicker(pickerOpts));\n    } catch (e) {\n      return throwError(() => new Error(e));\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * FileSystemDirectoryHandle                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  public static getHandlesFromDirectory(dirHandle: FileSystemDirectoryHandle): Observable<FileSystemHandle[]> {\n    return from(FileSystemApi.getHandlesFromDirectoryAsync(dirHandle));\n  }\n\n  public static buildRelativeParent(\n    fileOrDirHandle: FileSystemHandle,\n    rootDirectory?: FileSystemDirectoryHandle\n  ): Observable<string | undefined> {\n\n    if (rootDirectory == null) {\n        return of(undefined);\n    }\n\n    const relativeParents$ = from(rootDirectory.resolve(fileOrDirHandle));\n    return relativeParents$.pipe(\n      map(parents => {\n        // path/to/folder/file.jpg\n        const path = parents;\n\n        // root/path/to/folder/file.jpg\n        path.unshift(rootDirectory.name);\n\n        // root/path/to/folder\n        path.pop();\n        return path.join('/');\n      }\n    ))\n  }\n\n  private static async getHandlesFromDirectoryAsync(dirHandle: FileSystemDirectoryHandle): Promise<FileSystemHandle[]> {\n    const handles: FileSystemHandle[] = [];\n    // @ts-ignore\n    for await (const handle of dirHandle.values()) {\n      handles.push(handle);\n    }\n    return handles;\n  }\n}\n"]}
|
|
@@ -30,15 +30,18 @@ export class FileListingRx {
|
|
|
30
30
|
**************************************************************************/
|
|
31
31
|
resolveTransferItem(transferItem) {
|
|
32
32
|
if (FileSystemApi.isGetAsFileSystemHandleSupported(transferItem)) {
|
|
33
|
-
return FileSystemApi.getAsFileSystemHandle(transferItem).pipe(switchMap(handle => FileListingSystemHandle.listFiles(handle)));
|
|
33
|
+
return FileSystemApi.getAsFileSystemHandle(transferItem).pipe(switchMap(handle => handle ? FileListingSystemHandle.listFiles(handle) : this.legacyFileListing(transferItem)));
|
|
34
34
|
}
|
|
35
|
+
return this.legacyFileListing(transferItem);
|
|
36
|
+
}
|
|
37
|
+
legacyFileListing(transferItem) {
|
|
35
38
|
const entry = transferItem.webkitGetAsEntry();
|
|
36
39
|
if (entry) {
|
|
37
40
|
return FileListingWebkit.listFilesRecursive(entry);
|
|
38
41
|
}
|
|
39
|
-
return this.
|
|
42
|
+
return this.fallbackFileListing(transferItem);
|
|
40
43
|
}
|
|
41
|
-
|
|
44
|
+
fallbackFileListing(transferItem) {
|
|
42
45
|
const itemAsFile = transferItem.getAsFile();
|
|
43
46
|
if (itemAsFile) {
|
|
44
47
|
return of([FileEntry.ofFile(itemAsFile)]);
|
|
@@ -58,4 +61,4 @@ export class FileListingRx {
|
|
|
58
61
|
}
|
|
59
62
|
}
|
|
60
63
|
}
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1saXN0aW5nLXJ4LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9maWxlcy9saXN0aW5nL2ZpbGUtbGlzdGluZy1yeC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWEsRUFBRSxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUMsTUFBTSxNQUFNLENBQUM7QUFDcEQsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGNBQWMsQ0FBQztBQUN2QyxPQUFPLEVBQUMsR0FBRyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDbkMsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQ3hELE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ3JFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUVqRCxNQUFNLE9BQU8sYUFBYTtJQUExQjtRQUltQixRQUFHLEdBQUcsYUFBYSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBK0R4RSxDQUFDO2FBakV3QixhQUFRLEdBQUcsSUFBSSxhQUFhLEVBQUUsQUFBdEIsQ0FBdUI7SUFJdEQ7Ozs7Z0ZBSTRFO0lBRXJFLFVBQVUsQ0FBQyxnQkFBc0M7UUFDdEQsTUFBTSxHQUFHLEdBQThCLEVBQUUsQ0FBQztRQUMxQyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7WUFDakQsTUFBTSxZQUFZLEdBQUcsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDekMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQztRQUNuRCxDQUFDO1FBQ0QsT0FBTyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUNsQixHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FDM0IsQ0FBQztJQUNKLENBQUM7SUFFRDs7OztnRkFJNEU7SUFFcEUsbUJBQW1CLENBQUMsWUFBOEI7UUFFeEQsSUFBSSxhQUFhLENBQUMsZ0NBQWdDLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQztZQUNqRSxPQUFPLGFBQWEsQ0FBQyxxQkFBcUIsQ0FBQyxZQUFZLENBQUMsQ0FBQyxJQUFJLENBQzNELFNBQVMsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsdUJBQXVCLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FDL0csQ0FBQztRQUNKLENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBR08saUJBQWlCLENBQUMsWUFBOEI7UUFDdEQsTUFBTSxLQUFLLEdBQUcsWUFBWSxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFDOUMsSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUNWLE9BQU8saUJBQWlCLENBQUMsa0JBQWtCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDckQsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDLG1CQUFtQixDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFTyxtQkFBbUIsQ0FBQyxZQUE4QjtRQUN4RCxNQUFNLFVBQVUsR0FBRyxZQUFZLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDNUMsSUFBSSxVQUFVLEVBQUUsQ0FBQztZQUNmLE9BQU8sRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDNUMsQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLFlBQVksQ0FBQyxJQUFJLElBQUksTUFBTSxFQUFFLENBQUM7Z0JBQ2hDLE9BQU8sRUFBRSxDQUFDO29CQUNSLFNBQVMsQ0FBQyxNQUFNLENBQ2QsSUFBSSxJQUFJLENBQUMsRUFBRSxFQUFFLEVBQUUsRUFBRTt3QkFDZixJQUFJLEVBQUUsWUFBWSxDQUFDLElBQUk7cUJBQ3hCLENBQUMsQ0FDSDtpQkFDRixDQUFDLENBQUM7WUFDTCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsb0NBQW9DLEVBQUUsWUFBWSxDQUFDLENBQUM7Z0JBQ2xFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1lBQ2hCLENBQUM7UUFDSCxDQUFDO0lBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7T2JzZXJ2YWJsZSwgb2YsIHN3aXRjaE1hcCwgemlwfSBmcm9tICdyeGpzJztcbmltcG9ydCB7RmlsZUVudHJ5fSBmcm9tICcuL2ZpbGUtZW50cnknO1xuaW1wb3J0IHttYXB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7TG9nZ2VyRmFjdG9yeX0gZnJvbSAnQGVsZGVyYnl0ZS90cy1sb2dnZXInO1xuaW1wb3J0IHtGaWxlTGlzdGluZ1dlYmtpdH0gZnJvbSAnLi9maWxlLWxpc3Rpbmctd2Via2l0JztcbmltcG9ydCB7RmlsZUxpc3RpbmdTeXN0ZW1IYW5kbGV9IGZyb20gJy4vZmlsZS1saXN0aW5nLXN5c3RlbS1oYW5kbGUnO1xuaW1wb3J0IHtGaWxlU3lzdGVtQXBpfSBmcm9tICcuLi9maWxlLXN5c3RlbS1hcGknO1xuXG5leHBvcnQgY2xhc3MgRmlsZUxpc3RpbmdSeCB7XG5cbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBJTlNUQU5DRSA9IG5ldyBGaWxlTGlzdGluZ1J4KCk7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBsb2cgPSBMb2dnZXJGYWN0b3J5LmdldExvZ2dlcih0aGlzLmNvbnN0cnVjdG9yLm5hbWUpO1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQdWJsaWMgQVBJICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHB1YmxpYyB0b0ZpbGVMaXN0KHRyYW5zZmVySXRlbUxpc3Q6IERhdGFUcmFuc2Zlckl0ZW1MaXN0KTogT2JzZXJ2YWJsZTxGaWxlRW50cnlbXT4ge1xuICAgIGNvbnN0IG9iczogT2JzZXJ2YWJsZTxGaWxlRW50cnlbXT5bXSA9IFtdO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdHJhbnNmZXJJdGVtTGlzdC5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgdHJhbnNmZXJJdGVtID0gdHJhbnNmZXJJdGVtTGlzdFtpXTtcbiAgICAgIG9icy5wdXNoKHRoaXMucmVzb2x2ZVRyYW5zZmVySXRlbSh0cmFuc2Zlckl0ZW0pKTtcbiAgICB9XG4gICAgcmV0dXJuIHppcChvYnMpLnBpcGUoXG4gICAgICBtYXAoZmlsZXMgPT4gZmlsZXMuZmxhdCgpKVxuICAgICk7XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogUHJpdmF0ZSBtZXRob2RzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIHJlc29sdmVUcmFuc2Zlckl0ZW0odHJhbnNmZXJJdGVtOiBEYXRhVHJhbnNmZXJJdGVtKTogT2JzZXJ2YWJsZTxGaWxlRW50cnlbXT4ge1xuXG4gICAgaWYgKEZpbGVTeXN0ZW1BcGkuaXNHZXRBc0ZpbGVTeXN0ZW1IYW5kbGVTdXBwb3J0ZWQodHJhbnNmZXJJdGVtKSkge1xuICAgICAgcmV0dXJuIEZpbGVTeXN0ZW1BcGkuZ2V0QXNGaWxlU3lzdGVtSGFuZGxlKHRyYW5zZmVySXRlbSkucGlwZShcbiAgICAgICAgc3dpdGNoTWFwKGhhbmRsZSA9PiBoYW5kbGUgPyBGaWxlTGlzdGluZ1N5c3RlbUhhbmRsZS5saXN0RmlsZXMoaGFuZGxlKSA6IHRoaXMubGVnYWN5RmlsZUxpc3RpbmcodHJhbnNmZXJJdGVtKSlcbiAgICAgICk7XG4gICAgfVxuICAgIHJldHVybiB0aGlzLmxlZ2FjeUZpbGVMaXN0aW5nKHRyYW5zZmVySXRlbSk7XG4gIH1cblxuXG4gIHByaXZhdGUgbGVnYWN5RmlsZUxpc3RpbmcodHJhbnNmZXJJdGVtOiBEYXRhVHJhbnNmZXJJdGVtKTogT2JzZXJ2YWJsZTxGaWxlRW50cnlbXT4ge1xuICAgIGNvbnN0IGVudHJ5ID0gdHJhbnNmZXJJdGVtLndlYmtpdEdldEFzRW50cnkoKTtcbiAgICBpZiAoZW50cnkpIHtcbiAgICAgIHJldHVybiBGaWxlTGlzdGluZ1dlYmtpdC5saXN0RmlsZXNSZWN1cnNpdmUoZW50cnkpO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5mYWxsYmFja0ZpbGVMaXN0aW5nKHRyYW5zZmVySXRlbSk7XG4gIH1cblxuICBwcml2YXRlIGZhbGxiYWNrRmlsZUxpc3RpbmcodHJhbnNmZXJJdGVtOiBEYXRhVHJhbnNmZXJJdGVtKTogT2JzZXJ2YWJsZTxGaWxlRW50cnlbXT4ge1xuICAgIGNvbnN0IGl0ZW1Bc0ZpbGUgPSB0cmFuc2Zlckl0ZW0uZ2V0QXNGaWxlKCk7XG4gICAgaWYgKGl0ZW1Bc0ZpbGUpIHtcbiAgICAgIHJldHVybiBvZihbRmlsZUVudHJ5Lm9mRmlsZShpdGVtQXNGaWxlKV0pO1xuICAgIH0gZWxzZSB7XG4gICAgICBpZiAodHJhbnNmZXJJdGVtLmtpbmQgPT0gJ2ZpbGUnKSB7XG4gICAgICAgIHJldHVybiBvZihbXG4gICAgICAgICAgRmlsZUVudHJ5Lm9mRmlsZShcbiAgICAgICAgICAgIG5ldyBGaWxlKFtdLCAnJywge1xuICAgICAgICAgICAgICB0eXBlOiB0cmFuc2Zlckl0ZW0udHlwZVxuICAgICAgICAgICAgfSlcbiAgICAgICAgICApXG4gICAgICAgIF0pO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhpcy5sb2cud2FybignQ291bGQgbm90IGhhbmRsZSBEYXRhVHJhbnNmZXJJdGVtIScsIHRyYW5zZmVySXRlbSk7XG4gICAgICAgIHJldHVybiBvZihbXSk7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -9734,6 +9734,10 @@ class FileSystemApi {
|
|
|
9734
9734
|
// @ts-ignore
|
|
9735
9735
|
return transferItem.getAsFileSystemHandle !== undefined;
|
|
9736
9736
|
}
|
|
9737
|
+
/**
|
|
9738
|
+
* Returns an FileSystemHandle Observable of the given DataTransferItem. The FileSystemHandle can only be accessed in the `dragstart`
|
|
9739
|
+
* or `drop` event. Otherwise, it will return null!
|
|
9740
|
+
*/
|
|
9737
9741
|
static getAsFileSystemHandle(transferItem) {
|
|
9738
9742
|
// @ts-ignore
|
|
9739
9743
|
return from(transferItem.getAsFileSystemHandle());
|
|
@@ -9786,7 +9790,11 @@ class FileSystemApi {
|
|
|
9786
9790
|
}
|
|
9787
9791
|
const relativeParents$ = from(rootDirectory.resolve(fileOrDirHandle));
|
|
9788
9792
|
return relativeParents$.pipe(map(parents => {
|
|
9793
|
+
// path/to/folder/file.jpg
|
|
9789
9794
|
const path = parents;
|
|
9795
|
+
// root/path/to/folder/file.jpg
|
|
9796
|
+
path.unshift(rootDirectory.name);
|
|
9797
|
+
// root/path/to/folder
|
|
9790
9798
|
path.pop();
|
|
9791
9799
|
return path.join('/');
|
|
9792
9800
|
}));
|
|
@@ -10066,13 +10074,7 @@ class ElderFileSelectDirective {
|
|
|
10066
10074
|
this.logger.warn('showOpenFilePicker or showDirectoryPicker is not supported for this browser, falling back to legacy file picker');
|
|
10067
10075
|
this._legacyInput.createFileSelect();
|
|
10068
10076
|
this._legacyInput.filesSelected.pipe(takeUntilDestroyed(this.destroyRef)).subscribe({
|
|
10069
|
-
next: multiFileChange =>
|
|
10070
|
-
this.elderFileSelectChange.next(multiFileChange);
|
|
10071
|
-
const file = multiFileChange[0]?.file;
|
|
10072
|
-
if (file) {
|
|
10073
|
-
this.elderSingleFileSelectChange.next(file);
|
|
10074
|
-
}
|
|
10075
|
-
}
|
|
10077
|
+
next: multiFileChange => this.pushFileChanges(multiFileChange)
|
|
10076
10078
|
});
|
|
10077
10079
|
}
|
|
10078
10080
|
}
|
|
@@ -10146,12 +10148,12 @@ class ElderFileSelectDirective {
|
|
|
10146
10148
|
onClick(event) {
|
|
10147
10149
|
if (!this._useDirectoryPicker && FileSystemApi.isFileSystemSupported()) {
|
|
10148
10150
|
this.openFilePicker(this._filePickerOptions).subscribe({
|
|
10149
|
-
next:
|
|
10151
|
+
next: multiFileChange => this.pushFileChanges(multiFileChange)
|
|
10150
10152
|
});
|
|
10151
10153
|
}
|
|
10152
10154
|
else if (this._useDirectoryPicker && FileSystemApi.isDirectoryPickerSupported()) {
|
|
10153
10155
|
this.openDirectoryPicker(this._directoryPickerOptions).subscribe({
|
|
10154
|
-
next:
|
|
10156
|
+
next: multiFileChange => this.pushFileChanges(multiFileChange)
|
|
10155
10157
|
});
|
|
10156
10158
|
}
|
|
10157
10159
|
else {
|
|
@@ -10163,6 +10165,13 @@ class ElderFileSelectDirective {
|
|
|
10163
10165
|
* Private methods *
|
|
10164
10166
|
* *
|
|
10165
10167
|
**************************************************************************/
|
|
10168
|
+
pushFileChanges(multiFileChange) {
|
|
10169
|
+
this.elderFileSelectChange.next(multiFileChange);
|
|
10170
|
+
const file = multiFileChange[0]?.file;
|
|
10171
|
+
if (file) {
|
|
10172
|
+
this.elderSingleFileSelectChange.next(file);
|
|
10173
|
+
}
|
|
10174
|
+
}
|
|
10166
10175
|
openFilePicker(pickerOpts) {
|
|
10167
10176
|
return FileSystemApi.openFilePicker(pickerOpts).pipe(switchMap(files => combineLatest(files.map(file => FileEntry.ofFileHandle(file)))));
|
|
10168
10177
|
}
|
|
@@ -10397,15 +10406,18 @@ class FileListingRx {
|
|
|
10397
10406
|
**************************************************************************/
|
|
10398
10407
|
resolveTransferItem(transferItem) {
|
|
10399
10408
|
if (FileSystemApi.isGetAsFileSystemHandleSupported(transferItem)) {
|
|
10400
|
-
return FileSystemApi.getAsFileSystemHandle(transferItem).pipe(switchMap(handle => FileListingSystemHandle.listFiles(handle)));
|
|
10409
|
+
return FileSystemApi.getAsFileSystemHandle(transferItem).pipe(switchMap(handle => handle ? FileListingSystemHandle.listFiles(handle) : this.legacyFileListing(transferItem)));
|
|
10401
10410
|
}
|
|
10411
|
+
return this.legacyFileListing(transferItem);
|
|
10412
|
+
}
|
|
10413
|
+
legacyFileListing(transferItem) {
|
|
10402
10414
|
const entry = transferItem.webkitGetAsEntry();
|
|
10403
10415
|
if (entry) {
|
|
10404
10416
|
return FileListingWebkit.listFilesRecursive(entry);
|
|
10405
10417
|
}
|
|
10406
|
-
return this.
|
|
10418
|
+
return this.fallbackFileListing(transferItem);
|
|
10407
10419
|
}
|
|
10408
|
-
|
|
10420
|
+
fallbackFileListing(transferItem) {
|
|
10409
10421
|
const itemAsFile = transferItem.getAsFile();
|
|
10410
10422
|
if (itemAsFile) {
|
|
10411
10423
|
return of([FileEntry.ofFile(itemAsFile)]);
|