@dereekb/dbx-firebase 12.6.21 → 12.7.0
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/auth/login/login.email.form.component.mjs +1 -1
- package/esm2022/lib/development/development.directive.mjs +6 -5
- package/esm2022/lib/development/development.popup.content.component.mjs +7 -13
- package/esm2022/lib/model/modules/model/entities/model.entities.component.mjs +4 -6
- package/esm2022/lib/model/modules/model/entities/model.entities.entity.component.mjs +4 -7
- package/esm2022/lib/model/modules/model/entities/model.entities.widget.entity.debug.component.mjs +3 -6
- package/esm2022/lib/model/modules/model/model.types.view.directive.mjs +9 -9
- package/esm2022/lib/model/modules/store/store.collection.change.directive.mjs +6 -9
- package/esm2022/lib/model/modules/store/store.collection.directive.mjs +6 -10
- package/esm2022/lib/model/modules/store/store.collection.list.directive.mjs +9 -10
- package/esm2022/lib/model/modules/store/store.document.directive.mjs +6 -11
- package/esm2022/lib/model/modules/store/store.document.twoway.key.directive.mjs +5 -6
- package/esm2022/lib/model/modules/store/store.subcollection.directive.mjs +5 -9
- package/esm2022/lib/model/system/systemstate.document.store.accessor.mjs +1 -4
- package/esm2022/lib/modules/notification/store/notification.item.store.mjs +1 -1
- package/esm2022/lib/modules/storagefile/container/storagefile.upload.action.handler.directive.mjs +12 -19
- package/esm2022/lib/modules/storagefile/container/storagefile.upload.initialize.document.directive.mjs +7 -12
- package/esm2022/lib/modules/storagefile/container/storagefile.upload.store.directive.mjs +5 -10
- package/esm2022/lib/modules/storagefile/container/storagefile.upload.sync.directive.mjs +5 -13
- package/esm2022/lib/modules/storagefile/store/storagefile.upload.store.mjs +1 -1
- package/fesm2022/dereekb-dbx-firebase.mjs +62 -126
- package/fesm2022/dereekb-dbx-firebase.mjs.map +1 -1
- package/lib/auth/login/login.email.form.component.d.ts +1 -2
- package/lib/development/development.directive.d.ts +3 -3
- package/lib/development/development.popup.content.component.d.ts +2 -5
- package/lib/model/modules/model/entities/model.entities.component.d.ts +1 -3
- package/lib/model/modules/model/entities/model.entities.entity.component.d.ts +1 -3
- package/lib/model/modules/model/entities/model.entities.widget.entity.debug.component.d.ts +3 -4
- package/lib/model/modules/model/model.types.view.directive.d.ts +2 -4
- package/lib/model/modules/store/store.collection.change.directive.d.ts +2 -4
- package/lib/model/modules/store/store.collection.directive.d.ts +2 -4
- package/lib/model/modules/store/store.collection.list.directive.d.ts +1 -4
- package/lib/model/modules/store/store.document.directive.d.ts +2 -4
- package/lib/model/modules/store/store.document.twoway.key.directive.d.ts +1 -2
- package/lib/model/modules/store/store.subcollection.directive.d.ts +2 -4
- package/lib/model/system/systemstate.document.store.accessor.d.ts +1 -3
- package/lib/modules/notification/store/notification.item.store.d.ts +1 -2
- package/lib/modules/storagefile/container/storagefile.upload.action.handler.directive.d.ts +2 -8
- package/lib/modules/storagefile/container/storagefile.upload.initialize.document.directive.d.ts +1 -4
- package/lib/modules/storagefile/container/storagefile.upload.store.directive.d.ts +1 -5
- package/lib/modules/storagefile/container/storagefile.upload.sync.directive.d.ts +1 -6
- package/lib/modules/storagefile/store/storagefile.upload.store.d.ts +1 -2
- package/package.json +1 -1
package/esm2022/lib/modules/storagefile/container/storagefile.upload.action.handler.directive.mjs
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { Directive, effect, inject, input } from '@angular/core';
|
|
2
2
|
import { DbxFirebaseStorageFileUploadStore } from '../store/storagefile.upload.store';
|
|
3
3
|
import { storageFileUploadFiles } from './storagefile.upload.handler';
|
|
4
|
-
import { DbxActionContextStoreSourceInstance, DbxActionHandlerInstance } from '@dereekb/dbx-core';
|
|
5
|
-
import { errorResult, startWithBeginLoading,
|
|
4
|
+
import { clean, cleanSubscription, DbxActionContextStoreSourceInstance, DbxActionHandlerInstance } from '@dereekb/dbx-core';
|
|
5
|
+
import { errorResult, startWithBeginLoading, successResult } from '@dereekb/rxjs';
|
|
6
6
|
import { toObservable } from '@angular/core/rxjs-interop';
|
|
7
7
|
import { distinctUntilChanged, filter, map, of, switchMap, tap, throttleTime } from 'rxjs';
|
|
8
8
|
import { StorageFileUploadFilesError } from './storagefile.upload.error';
|
|
@@ -11,13 +11,9 @@ import * as i0 from "@angular/core";
|
|
|
11
11
|
* Connects a DbxFirebaseStorageFileUploadStore to a DbxActionContext, and handles the upload action.
|
|
12
12
|
*/
|
|
13
13
|
export class DbxFirebaseStorageFileUploadActionHandlerDirective {
|
|
14
|
-
_triggerSub = new SubscriptionObject();
|
|
15
|
-
_readySub = new SubscriptionObject();
|
|
16
|
-
_isWorkingSub = new SubscriptionObject();
|
|
17
|
-
_progressSub = new SubscriptionObject();
|
|
18
14
|
source = inject((DbxActionContextStoreSourceInstance));
|
|
19
15
|
uploadStore = inject(DbxFirebaseStorageFileUploadStore);
|
|
20
|
-
_dbxActionHandlerInstance = new DbxActionHandlerInstance(this.source);
|
|
16
|
+
_dbxActionHandlerInstance = clean(new DbxActionHandlerInstance(this.source));
|
|
21
17
|
/**
|
|
22
18
|
* If true, the action will be triggered when files are set.
|
|
23
19
|
*
|
|
@@ -76,10 +72,10 @@ export class DbxFirebaseStorageFileUploadActionHandlerDirective {
|
|
|
76
72
|
});
|
|
77
73
|
files$ = this.uploadStore.files$;
|
|
78
74
|
uploadHandler$ = toObservable(this.uploadHandler);
|
|
79
|
-
|
|
75
|
+
constructor() {
|
|
80
76
|
this._dbxActionHandlerInstance.init();
|
|
81
77
|
// trigger the action if files are available
|
|
82
|
-
this.
|
|
78
|
+
cleanSubscription(this.triggerOnFiles$
|
|
83
79
|
.pipe(switchMap((triggerOnFiles) => {
|
|
84
80
|
if (triggerOnFiles) {
|
|
85
81
|
return this.files$.pipe(map((x) => x?.length));
|
|
@@ -92,18 +88,15 @@ export class DbxFirebaseStorageFileUploadActionHandlerDirective {
|
|
|
92
88
|
if (canTrigger) {
|
|
93
89
|
this.source.trigger();
|
|
94
90
|
}
|
|
95
|
-
});
|
|
91
|
+
}));
|
|
96
92
|
// ready the source with files after trigger is called and files are available
|
|
97
|
-
this.
|
|
93
|
+
cleanSubscription(this.files$.pipe(switchMap((files) => this.source.triggered$.pipe(map(() => files)))).subscribe((files) => {
|
|
98
94
|
this.source.readyValue(files);
|
|
99
|
-
});
|
|
95
|
+
}));
|
|
100
96
|
// sync isWorking
|
|
101
|
-
this.
|
|
97
|
+
cleanSubscription(this.uploadStore.setIsUploadHandlerWorking(this.source.isWorking$));
|
|
102
98
|
// sync progress amount
|
|
103
|
-
this.
|
|
104
|
-
}
|
|
105
|
-
ngOnDestroy() {
|
|
106
|
-
this._dbxActionHandlerInstance.destroy();
|
|
99
|
+
this.source.setWorkProgress(this.uploadStore.latestProgressEvent$.pipe(throttleTime(100, undefined, { leading: true, trailing: true }), map((x) => x?.overallProgress), distinctUntilChanged()));
|
|
107
100
|
}
|
|
108
101
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseStorageFileUploadActionHandlerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
109
102
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxFirebaseStorageFileUploadActionHandlerDirective, isStandalone: true, selector: "[dbxFirebaseStorageFileUploadActionHandler]", inputs: { triggerOnFiles: { classPropertyName: "triggerOnFiles", publicName: "triggerOnFiles", isSignal: true, isRequired: false, transformFunction: null }, cancelUploadsOnUploadError: { classPropertyName: "cancelUploadsOnUploadError", publicName: "cancelUploadsOnUploadError", isSignal: true, isRequired: false, transformFunction: null }, actionFailureOnUploadError: { classPropertyName: "actionFailureOnUploadError", publicName: "actionFailureOnUploadError", isSignal: true, isRequired: false, transformFunction: null }, uploadHandler: { classPropertyName: "uploadHandler", publicName: "dbxFirebaseStorageFileUploadActionHandler", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0 });
|
|
@@ -114,5 +107,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
114
107
|
selector: '[dbxFirebaseStorageFileUploadActionHandler]',
|
|
115
108
|
standalone: true
|
|
116
109
|
}]
|
|
117
|
-
}] });
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storagefile.upload.action.handler.directive.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-firebase/src/lib/modules/storagefile/container/storagefile.upload.action.handler.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, effect, inject, input, OnInit, OnDestroy } from '@angular/core';\nimport { Maybe } from '@dereekb/util';\nimport { DbxFirebaseStorageFileUploadStore } from '../store/storagefile.upload.store';\nimport { storageFileUploadFiles, StorageFileUploadFilesFinalResult, StorageFileUploadHandler } from './storagefile.upload.handler';\nimport { DbxActionContextStoreSourceInstance, DbxActionHandlerInstance } from '@dereekb/dbx-core';\nimport { errorResult, LoadingState, startWithBeginLoading, SubscriptionObject, successResult, WorkUsingContext } from '@dereekb/rxjs';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { distinctUntilChanged, filter, map, of, switchMap, tap, throttleTime } from 'rxjs';\nimport { StorageFileUploadFilesError } from './storagefile.upload.error';\n\n/**\n * Connects a DbxFirebaseStorageFileUploadStore to a DbxActionContext, and handles the upload action.\n */\n@Directive({\n  selector: '[dbxFirebaseStorageFileUploadActionHandler]',\n  standalone: true\n})\nexport class DbxFirebaseStorageFileUploadActionHandlerDirective implements OnInit, OnDestroy {\n  private readonly _triggerSub = new SubscriptionObject();\n  private readonly _readySub = new SubscriptionObject();\n  private readonly _isWorkingSub = new SubscriptionObject();\n  private readonly _progressSub = new SubscriptionObject();\n\n  readonly source = inject(DbxActionContextStoreSourceInstance<File[], StorageFileUploadFilesFinalResult>);\n  readonly uploadStore = inject(DbxFirebaseStorageFileUploadStore);\n\n  readonly _dbxActionHandlerInstance = new DbxActionHandlerInstance<File[], StorageFileUploadFilesFinalResult>(this.source);\n\n  /**\n   * If true, the action will be triggered when files are set.\n   *\n   * Defaults to false.\n   */\n  readonly triggerOnFiles = input<boolean>(false);\n  readonly triggerOnFiles$ = toObservable(this.triggerOnFiles);\n\n  /**\n   * Uploading of all/any files should be cancelled if any file fails to upload.\n   *\n   * Any file that was successfully uploaded will not be reverted.\n   *\n   * Defaults to false.\n   */\n  readonly cancelUploadsOnUploadError = input<boolean>(false);\n\n  /**\n   * The upload should fail if any file fails to upload, rather than if all files fail to upload.\n   *\n   * Defaults to false.\n   */\n  readonly actionFailureOnUploadError = input<boolean>(false);\n\n  readonly uploadHandler = input.required<Maybe<StorageFileUploadHandler>>({ alias: 'dbxFirebaseStorageFileUploadActionHandler' });\n\n  protected readonly _uploadHandlerEffect = effect(() => {\n    const uploadHandler = this.uploadHandler();\n    let handlerFunction: Maybe<WorkUsingContext<File[], StorageFileUploadFilesFinalResult>>;\n\n    if (uploadHandler) {\n      handlerFunction = (files, context) => {\n        const { upload, cancel } = storageFileUploadFiles({\n          files,\n          uploadHandler\n        });\n\n        const loadingStateObs = upload.pipe(\n          tap((x) => {\n            this.uploadStore.setLatestProgressEvent(x);\n          }),\n          filter((x) => x.isComplete),\n          tap((x) => {\n            this.uploadStore.setUploadResult(x.result as StorageFileUploadFilesFinalResult);\n          }),\n          map((x) => {\n            const result = x.result as StorageFileUploadFilesFinalResult;\n            const { successFileResults, errorFileResults } = result;\n\n            const actionFailureOnUploadError = this.actionFailureOnUploadError();\n\n            let finalLoadingState: LoadingState<StorageFileUploadFilesFinalResult>;\n\n            if ((errorFileResults.length > 0 && actionFailureOnUploadError) || (successFileResults.length === 0 && errorFileResults.length > 0)) {\n              finalLoadingState = errorResult(new StorageFileUploadFilesError(result));\n            } else {\n              finalLoadingState = successResult(x.result as StorageFileUploadFilesFinalResult);\n            }\n\n            return finalLoadingState;\n          }),\n          startWithBeginLoading()\n        );\n\n        context.startWorkingWithLoadingStateObservable(loadingStateObs);\n      };\n    } else {\n      handlerFunction = undefined;\n    }\n\n    this._dbxActionHandlerInstance.setHandlerFunction(handlerFunction);\n  });\n\n  readonly files$ = this.uploadStore.files$;\n  readonly uploadHandler$ = toObservable(this.uploadHandler);\n\n  ngOnInit(): void {\n    this._dbxActionHandlerInstance.init();\n\n    // trigger the action if files are available\n    this._triggerSub.subscription = this.triggerOnFiles$\n      .pipe(\n        switchMap((triggerOnFiles) => {\n          if (triggerOnFiles) {\n            return this.files$.pipe(map((x) => x?.length));\n          } else {\n            return of(false);\n          }\n        })\n      )\n      .subscribe((canTrigger) => {\n        if (canTrigger) {\n          this.source.trigger();\n        }\n      });\n\n    // ready the source with files after trigger is called and files are available\n    this._readySub.subscription = this.files$.pipe(switchMap((files) => this.source.triggered$.pipe(map(() => files)))).subscribe((files) => {\n      this.source.readyValue(files);\n    });\n\n    // sync isWorking\n    this._isWorkingSub.subscription = this.uploadStore.setIsUploadHandlerWorking(this.source.isWorking$);\n\n    // sync progress amount\n    this._progressSub.subscription = this.source.setWorkProgress(\n      this.uploadStore.latestProgressEvent$.pipe(\n        throttleTime(100, undefined, { leading: true, trailing: true }),\n        map((x) => x?.overallProgress),\n        distinctUntilChanged()\n      )\n    );\n  }\n\n  ngOnDestroy(): void {\n    this._dbxActionHandlerInstance.destroy();\n  }\n}\n"]}
|
|
110
|
+
}], ctorParameters: () => [] });
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storagefile.upload.action.handler.directive.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-firebase/src/lib/modules/storagefile/container/storagefile.upload.action.handler.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, effect, inject, input } from '@angular/core';\nimport { Maybe } from '@dereekb/util';\nimport { DbxFirebaseStorageFileUploadStore } from '../store/storagefile.upload.store';\nimport { storageFileUploadFiles, StorageFileUploadFilesFinalResult, StorageFileUploadHandler } from './storagefile.upload.handler';\nimport { clean, cleanSubscription, DbxActionContextStoreSourceInstance, DbxActionHandlerInstance } from '@dereekb/dbx-core';\nimport { errorResult, LoadingState, startWithBeginLoading, successResult, WorkUsingContext } from '@dereekb/rxjs';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { distinctUntilChanged, filter, map, of, switchMap, tap, throttleTime } from 'rxjs';\nimport { StorageFileUploadFilesError } from './storagefile.upload.error';\n\n/**\n * Connects a DbxFirebaseStorageFileUploadStore to a DbxActionContext, and handles the upload action.\n */\n@Directive({\n  selector: '[dbxFirebaseStorageFileUploadActionHandler]',\n  standalone: true\n})\nexport class DbxFirebaseStorageFileUploadActionHandlerDirective {\n  readonly source = inject(DbxActionContextStoreSourceInstance<File[], StorageFileUploadFilesFinalResult>);\n  readonly uploadStore = inject(DbxFirebaseStorageFileUploadStore);\n\n  readonly _dbxActionHandlerInstance = clean(new DbxActionHandlerInstance<File[], StorageFileUploadFilesFinalResult>(this.source));\n\n  /**\n   * If true, the action will be triggered when files are set.\n   *\n   * Defaults to false.\n   */\n  readonly triggerOnFiles = input<boolean>(false);\n  readonly triggerOnFiles$ = toObservable(this.triggerOnFiles);\n\n  /**\n   * Uploading of all/any files should be cancelled if any file fails to upload.\n   *\n   * Any file that was successfully uploaded will not be reverted.\n   *\n   * Defaults to false.\n   */\n  readonly cancelUploadsOnUploadError = input<boolean>(false);\n\n  /**\n   * The upload should fail if any file fails to upload, rather than if all files fail to upload.\n   *\n   * Defaults to false.\n   */\n  readonly actionFailureOnUploadError = input<boolean>(false);\n\n  readonly uploadHandler = input.required<Maybe<StorageFileUploadHandler>>({ alias: 'dbxFirebaseStorageFileUploadActionHandler' });\n\n  protected readonly _uploadHandlerEffect = effect(() => {\n    const uploadHandler = this.uploadHandler();\n    let handlerFunction: Maybe<WorkUsingContext<File[], StorageFileUploadFilesFinalResult>>;\n\n    if (uploadHandler) {\n      handlerFunction = (files, context) => {\n        const { upload, cancel } = storageFileUploadFiles({\n          files,\n          uploadHandler\n        });\n\n        const loadingStateObs = upload.pipe(\n          tap((x) => {\n            this.uploadStore.setLatestProgressEvent(x);\n          }),\n          filter((x) => x.isComplete),\n          tap((x) => {\n            this.uploadStore.setUploadResult(x.result as StorageFileUploadFilesFinalResult);\n          }),\n          map((x) => {\n            const result = x.result as StorageFileUploadFilesFinalResult;\n            const { successFileResults, errorFileResults } = result;\n\n            const actionFailureOnUploadError = this.actionFailureOnUploadError();\n\n            let finalLoadingState: LoadingState<StorageFileUploadFilesFinalResult>;\n\n            if ((errorFileResults.length > 0 && actionFailureOnUploadError) || (successFileResults.length === 0 && errorFileResults.length > 0)) {\n              finalLoadingState = errorResult(new StorageFileUploadFilesError(result));\n            } else {\n              finalLoadingState = successResult(x.result as StorageFileUploadFilesFinalResult);\n            }\n\n            return finalLoadingState;\n          }),\n          startWithBeginLoading()\n        );\n\n        context.startWorkingWithLoadingStateObservable(loadingStateObs);\n      };\n    } else {\n      handlerFunction = undefined;\n    }\n\n    this._dbxActionHandlerInstance.setHandlerFunction(handlerFunction);\n  });\n\n  readonly files$ = this.uploadStore.files$;\n  readonly uploadHandler$ = toObservable(this.uploadHandler);\n\n  constructor() {\n    this._dbxActionHandlerInstance.init();\n\n    // trigger the action if files are available\n    cleanSubscription(\n      this.triggerOnFiles$\n        .pipe(\n          switchMap((triggerOnFiles) => {\n            if (triggerOnFiles) {\n              return this.files$.pipe(map((x) => x?.length));\n            } else {\n              return of(false);\n            }\n          })\n        )\n        .subscribe((canTrigger) => {\n          if (canTrigger) {\n            this.source.trigger();\n          }\n        })\n    );\n\n    // ready the source with files after trigger is called and files are available\n    cleanSubscription(\n      this.files$.pipe(switchMap((files) => this.source.triggered$.pipe(map(() => files)))).subscribe((files) => {\n        this.source.readyValue(files);\n      })\n    );\n\n    // sync isWorking\n    cleanSubscription(this.uploadStore.setIsUploadHandlerWorking(this.source.isWorking$));\n\n    // sync progress amount\n    this.source.setWorkProgress(\n      this.uploadStore.latestProgressEvent$.pipe(\n        throttleTime(100, undefined, { leading: true, trailing: true }),\n        map((x) => x?.overallProgress),\n        distinctUntilChanged()\n      )\n    );\n  }\n}\n"]}
|
|
@@ -1,28 +1,27 @@
|
|
|
1
1
|
import { Directive, inject, input } from '@angular/core';
|
|
2
2
|
import { DbxFirebaseStorageFileUploadStore, StorageFileDocumentStore } from '../store';
|
|
3
|
-
import {
|
|
3
|
+
import { DbxActionContextStoreSourceInstance, DbxActionHandlerInstance, clean, cleanSubscription } from '@dereekb/dbx-core';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
/**
|
|
6
6
|
* Directive that passes the upload result to a StorageFileDocumentStore to initialize the document immediately.
|
|
7
7
|
*
|
|
8
8
|
* Use with a DbxAction instance.
|
|
9
9
|
*/
|
|
10
|
-
export class DbxFirebaseStorageFileUploadInitializeDocumentDirective
|
|
10
|
+
export class DbxFirebaseStorageFileUploadInitializeDocumentDirective {
|
|
11
11
|
uploadStore = inject(DbxFirebaseStorageFileUploadStore);
|
|
12
12
|
storageFileDocumentStore = inject(StorageFileDocumentStore);
|
|
13
13
|
initializeWithExpediteProcessing = input();
|
|
14
14
|
source = inject((DbxActionContextStoreSourceInstance), { host: true });
|
|
15
|
-
_dbxActionHandlerInstance = new DbxActionHandlerInstance(this.source);
|
|
15
|
+
_dbxActionHandlerInstance = clean(new DbxActionHandlerInstance(this.source));
|
|
16
16
|
constructor() {
|
|
17
|
-
super();
|
|
18
17
|
// set the trigger
|
|
19
|
-
this.
|
|
18
|
+
cleanSubscription(this.uploadStore.uploadResult$.subscribe(async (result) => {
|
|
20
19
|
const successFileResult = result.successFileResults.find((x) => x.fileRef != null);
|
|
21
20
|
const fileRef = successFileResult?.fileRef;
|
|
22
21
|
if (fileRef) {
|
|
23
22
|
this.source.triggerWithValue(fileRef);
|
|
24
23
|
}
|
|
25
|
-
});
|
|
24
|
+
}));
|
|
26
25
|
// set the handler function
|
|
27
26
|
this._dbxActionHandlerInstance.setHandlerFunction((fileRef, context) => {
|
|
28
27
|
context.startWorkingWithLoadingStateObservable(this.storageFileDocumentStore.initializeStorageFileFromUpload({
|
|
@@ -33,12 +32,8 @@ export class DbxFirebaseStorageFileUploadInitializeDocumentDirective extends Abs
|
|
|
33
32
|
});
|
|
34
33
|
this._dbxActionHandlerInstance.init();
|
|
35
34
|
}
|
|
36
|
-
ngOnDestroy() {
|
|
37
|
-
super.ngOnDestroy();
|
|
38
|
-
this._dbxActionHandlerInstance.destroy();
|
|
39
|
-
}
|
|
40
35
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseStorageFileUploadInitializeDocumentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
41
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxFirebaseStorageFileUploadInitializeDocumentDirective, isStandalone: true, selector: "[dbxFirebaseStorageFileUploadInitializeDocument]", inputs: { initializeWithExpediteProcessing: { classPropertyName: "initializeWithExpediteProcessing", publicName: "initializeWithExpediteProcessing", isSignal: true, isRequired: false, transformFunction: null } }, exportAs: ["dbxFirebaseStorageFileUploadInitializeDocument"],
|
|
36
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxFirebaseStorageFileUploadInitializeDocumentDirective, isStandalone: true, selector: "[dbxFirebaseStorageFileUploadInitializeDocument]", inputs: { initializeWithExpediteProcessing: { classPropertyName: "initializeWithExpediteProcessing", publicName: "initializeWithExpediteProcessing", isSignal: true, isRequired: false, transformFunction: null } }, exportAs: ["dbxFirebaseStorageFileUploadInitializeDocument"], ngImport: i0 });
|
|
42
37
|
}
|
|
43
38
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseStorageFileUploadInitializeDocumentDirective, decorators: [{
|
|
44
39
|
type: Directive,
|
|
@@ -48,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
48
43
|
standalone: true
|
|
49
44
|
}]
|
|
50
45
|
}], ctorParameters: () => [] });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZWZpbGUudXBsb2FkLmluaXRpYWxpemUuZG9jdW1lbnQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZpcmViYXNlL3NyYy9saWIvbW9kdWxlcy9zdG9yYWdlZmlsZS9jb250YWluZXIvc3RvcmFnZWZpbGUudXBsb2FkLmluaXRpYWxpemUuZG9jdW1lbnQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDdkYsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLHdCQUF3QixFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQUk1SDs7OztHQUlHO0FBTUgsTUFBTSxPQUFPLHVEQUF1RDtJQUN6RCxXQUFXLEdBQUcsTUFBTSxDQUFDLGlDQUFpQyxDQUFDLENBQUM7SUFDeEQsd0JBQXdCLEdBQUcsTUFBTSxDQUFDLHdCQUF3QixDQUFDLENBQUM7SUFFNUQsZ0NBQWdDLEdBQUcsS0FBSyxFQUFrQixDQUFDO0lBRW5ELE1BQU0sR0FBOEYsTUFBTSxDQUFDLENBQUEsbUNBQXlGLENBQUEsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ3ROLHlCQUF5QixHQUFHLEtBQUssQ0FBQyxJQUFJLHdCQUF3QixDQUF1RCxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztJQUVwSjtRQUNFLGtCQUFrQjtRQUNsQixpQkFBaUIsQ0FDZixJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxFQUFFO1lBQ3hELE1BQU0saUJBQWlCLEdBQUcsTUFBTSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsQ0FBQztZQUNuRixNQUFNLE9BQU8sR0FBRyxpQkFBaUIsRUFBRSxPQUFPLENBQUM7WUFFM0MsSUFBSSxPQUFPLEVBQUUsQ0FBQztnQkFDWixJQUFJLENBQUMsTUFBTSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ3hDLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FDSCxDQUFDO1FBRUYsMkJBQTJCO1FBQzNCLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsRUFBRTtZQUNyRSxPQUFPLENBQUMsc0NBQXNDLENBQzVDLElBQUksQ0FBQyx3QkFBd0IsQ0FBQywrQkFBK0IsQ0FBQztnQkFDNUQsVUFBVSxFQUFFLE9BQU8sQ0FBQyxXQUFXLENBQUMsVUFBVTtnQkFDMUMsUUFBUSxFQUFFLE9BQU8sQ0FBQyxXQUFXLENBQUMsUUFBUTtnQkFDdEMsa0JBQWtCLEVBQUUsSUFBSSxDQUFDLGdDQUFnQyxFQUFFLElBQUksU0FBUzthQUN6RSxDQUFDLENBQ0gsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLHlCQUF5QixDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3hDLENBQUM7d0dBbENVLHVEQUF1RDs0RkFBdkQsdURBQXVEOzs0RkFBdkQsdURBQXVEO2tCQUxuRSxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrREFBa0Q7b0JBQzVELFFBQVEsRUFBRSxnREFBZ0Q7b0JBQzFELFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgaW5qZWN0LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4RmlyZWJhc2VTdG9yYWdlRmlsZVVwbG9hZFN0b3JlLCBTdG9yYWdlRmlsZURvY3VtZW50U3RvcmUgfSBmcm9tICcuLi9zdG9yZSc7XG5pbXBvcnQgeyBEYnhBY3Rpb25Db250ZXh0U3RvcmVTb3VyY2VJbnN0YW5jZSwgRGJ4QWN0aW9uSGFuZGxlckluc3RhbmNlLCBjbGVhbiwgY2xlYW5TdWJzY3JpcHRpb24gfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBGaXJlYmFzZVN0b3JhZ2VBY2Nlc3NvckZpbGUsIE9uQ2FsbENyZWF0ZU1vZGVsUmVzdWx0IH0gZnJvbSAnQGRlcmVla2IvZmlyZWJhc2UnO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcblxuLyoqXG4gKiBEaXJlY3RpdmUgdGhhdCBwYXNzZXMgdGhlIHVwbG9hZCByZXN1bHQgdG8gYSBTdG9yYWdlRmlsZURvY3VtZW50U3RvcmUgdG8gaW5pdGlhbGl6ZSB0aGUgZG9jdW1lbnQgaW1tZWRpYXRlbHkuXG4gKlxuICogVXNlIHdpdGggYSBEYnhBY3Rpb24gaW5zdGFuY2UuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tkYnhGaXJlYmFzZVN0b3JhZ2VGaWxlVXBsb2FkSW5pdGlhbGl6ZURvY3VtZW50XScsXG4gIGV4cG9ydEFzOiAnZGJ4RmlyZWJhc2VTdG9yYWdlRmlsZVVwbG9hZEluaXRpYWxpemVEb2N1bWVudCcsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGJ4RmlyZWJhc2VTdG9yYWdlRmlsZVVwbG9hZEluaXRpYWxpemVEb2N1bWVudERpcmVjdGl2ZSB7XG4gIHJlYWRvbmx5IHVwbG9hZFN0b3JlID0gaW5qZWN0KERieEZpcmViYXNlU3RvcmFnZUZpbGVVcGxvYWRTdG9yZSk7XG4gIHJlYWRvbmx5IHN0b3JhZ2VGaWxlRG9jdW1lbnRTdG9yZSA9IGluamVjdChTdG9yYWdlRmlsZURvY3VtZW50U3RvcmUpO1xuXG4gIHJlYWRvbmx5IGluaXRpYWxpemVXaXRoRXhwZWRpdGVQcm9jZXNzaW5nID0gaW5wdXQ8TWF5YmU8Ym9vbGVhbj4+KCk7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBzb3VyY2U6IERieEFjdGlvbkNvbnRleHRTdG9yZVNvdXJjZUluc3RhbmNlPEZpcmViYXNlU3RvcmFnZUFjY2Vzc29yRmlsZSwgT25DYWxsQ3JlYXRlTW9kZWxSZXN1bHQ+ID0gaW5qZWN0KERieEFjdGlvbkNvbnRleHRTdG9yZVNvdXJjZUluc3RhbmNlPEZpcmViYXNlU3RvcmFnZUFjY2Vzc29yRmlsZSwgT25DYWxsQ3JlYXRlTW9kZWxSZXN1bHQ+LCB7IGhvc3Q6IHRydWUgfSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2RieEFjdGlvbkhhbmRsZXJJbnN0YW5jZSA9IGNsZWFuKG5ldyBEYnhBY3Rpb25IYW5kbGVySW5zdGFuY2U8RmlyZWJhc2VTdG9yYWdlQWNjZXNzb3JGaWxlLCBPbkNhbGxDcmVhdGVNb2RlbFJlc3VsdD4odGhpcy5zb3VyY2UpKTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICAvLyBzZXQgdGhlIHRyaWdnZXJcbiAgICBjbGVhblN1YnNjcmlwdGlvbihcbiAgICAgIHRoaXMudXBsb2FkU3RvcmUudXBsb2FkUmVzdWx0JC5zdWJzY3JpYmUoYXN5bmMgKHJlc3VsdCkgPT4ge1xuICAgICAgICBjb25zdCBzdWNjZXNzRmlsZVJlc3VsdCA9IHJlc3VsdC5zdWNjZXNzRmlsZVJlc3VsdHMuZmluZCgoeCkgPT4geC5maWxlUmVmICE9IG51bGwpO1xuICAgICAgICBjb25zdCBmaWxlUmVmID0gc3VjY2Vzc0ZpbGVSZXN1bHQ/LmZpbGVSZWY7XG5cbiAgICAgICAgaWYgKGZpbGVSZWYpIHtcbiAgICAgICAgICB0aGlzLnNvdXJjZS50cmlnZ2VyV2l0aFZhbHVlKGZpbGVSZWYpO1xuICAgICAgICB9XG4gICAgICB9KVxuICAgICk7XG5cbiAgICAvLyBzZXQgdGhlIGhhbmRsZXIgZnVuY3Rpb25cbiAgICB0aGlzLl9kYnhBY3Rpb25IYW5kbGVySW5zdGFuY2Uuc2V0SGFuZGxlckZ1bmN0aW9uKChmaWxlUmVmLCBjb250ZXh0KSA9PiB7XG4gICAgICBjb250ZXh0LnN0YXJ0V29ya2luZ1dpdGhMb2FkaW5nU3RhdGVPYnNlcnZhYmxlKFxuICAgICAgICB0aGlzLnN0b3JhZ2VGaWxlRG9jdW1lbnRTdG9yZS5pbml0aWFsaXplU3RvcmFnZUZpbGVGcm9tVXBsb2FkKHtcbiAgICAgICAgICBwYXRoU3RyaW5nOiBmaWxlUmVmLnN0b3JhZ2VQYXRoLnBhdGhTdHJpbmcsXG4gICAgICAgICAgYnVja2V0SWQ6IGZpbGVSZWYuc3RvcmFnZVBhdGguYnVja2V0SWQsXG4gICAgICAgICAgZXhwZWRpdGVQcm9jZXNzaW5nOiB0aGlzLmluaXRpYWxpemVXaXRoRXhwZWRpdGVQcm9jZXNzaW5nKCkgPz8gdW5kZWZpbmVkXG4gICAgICAgIH0pXG4gICAgICApO1xuICAgIH0pO1xuXG4gICAgdGhpcy5fZGJ4QWN0aW9uSGFuZGxlckluc3RhbmNlLmluaXQoKTtcbiAgfVxufVxuIl19
|
|
@@ -1,27 +1,22 @@
|
|
|
1
1
|
import { Directive, inject, input } from '@angular/core';
|
|
2
|
-
import { skipAllInitialMaybe
|
|
2
|
+
import { skipAllInitialMaybe } from '@dereekb/rxjs';
|
|
3
3
|
import { DbxFirebaseStorageFileUploadStore } from '../store';
|
|
4
4
|
import { toObservable } from '@angular/core/rxjs-interop';
|
|
5
5
|
import { shareReplay } from 'rxjs';
|
|
6
|
+
import { cleanSubscription } from '@dereekb/dbx-core';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
/**
|
|
8
9
|
* Directive that provides a DbxFirebaseStorageFileUploadStore, and sync's the inputs to the store.
|
|
9
10
|
*/
|
|
10
11
|
export class DbxFirebaseStorageFileUploadStoreDirective {
|
|
11
|
-
_allowedSub = new SubscriptionObject();
|
|
12
|
-
_multiSub = new SubscriptionObject();
|
|
13
12
|
uploadStore = inject(DbxFirebaseStorageFileUploadStore);
|
|
14
13
|
multipleUpload = input();
|
|
15
14
|
fileTypesAccepted = input();
|
|
16
15
|
fileTypesAccepted$ = toObservable(this.fileTypesAccepted).pipe(skipAllInitialMaybe(), shareReplay(1));
|
|
17
16
|
isMultiUploadAllowed$ = toObservable(this.multipleUpload).pipe(skipAllInitialMaybe(), shareReplay(1));
|
|
18
17
|
constructor() {
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
}
|
|
22
|
-
ngOnDestroy() {
|
|
23
|
-
this._allowedSub.destroy();
|
|
24
|
-
this._multiSub.destroy();
|
|
18
|
+
cleanSubscription(this.fileTypesAccepted$.subscribe((x) => this.uploadStore.setFileTypesAccepted(x)));
|
|
19
|
+
cleanSubscription(this.isMultiUploadAllowed$.subscribe((x) => this.uploadStore.setIsMultiUploadAllowed(x)));
|
|
25
20
|
}
|
|
26
21
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseStorageFileUploadStoreDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
27
22
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxFirebaseStorageFileUploadStoreDirective, isStandalone: true, selector: "[dbxFirebaseStorageFileUploadStore]", inputs: { multipleUpload: { classPropertyName: "multipleUpload", publicName: "multipleUpload", isSignal: true, isRequired: false, transformFunction: null }, fileTypesAccepted: { classPropertyName: "fileTypesAccepted", publicName: "fileTypesAccepted", isSignal: true, isRequired: false, transformFunction: null } }, providers: [DbxFirebaseStorageFileUploadStore], exportAs: ["dbxFirebaseStorageFileUploadStore"], ngImport: i0 });
|
|
@@ -35,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
35
30
|
standalone: true
|
|
36
31
|
}]
|
|
37
32
|
}], ctorParameters: () => [] });
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZWZpbGUudXBsb2FkLnN0b3JlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1maXJlYmFzZS9zcmMvbGliL21vZHVsZXMvc3RvcmFnZWZpbGUvY29udGFpbmVyL3N0b3JhZ2VmaWxlLnVwbG9hZC5zdG9yZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFFN0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzFELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFbkMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBRXREOztHQUVHO0FBT0gsTUFBTSxPQUFPLDBDQUEwQztJQUM1QyxXQUFXLEdBQUcsTUFBTSxDQUFDLGlDQUFpQyxDQUFDLENBQUM7SUFFeEQsY0FBYyxHQUFHLEtBQUssRUFBa0IsQ0FBQztJQUN6QyxpQkFBaUIsR0FBRyxLQUFLLEVBQW1ELENBQUM7SUFFN0Usa0JBQWtCLEdBQUcsWUFBWSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3RHLHFCQUFxQixHQUFHLFlBQVksQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsSUFBSSxDQUFDLG1CQUFtQixFQUFFLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFFL0c7UUFDRSxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLG9CQUFvQixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN0RyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLHVCQUF1QixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM5RyxDQUFDO3dHQVpVLDBDQUEwQzs0RkFBMUMsMENBQTBDLDZZQUgxQyxDQUFDLGlDQUFpQyxDQUFDOzs0RkFHbkMsMENBQTBDO2tCQU50RCxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxxQ0FBcUM7b0JBQy9DLFFBQVEsRUFBRSxtQ0FBbUM7b0JBQzdDLFNBQVMsRUFBRSxDQUFDLGlDQUFpQyxDQUFDO29CQUM5QyxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHNraXBBbGxJbml0aWFsTWF5YmUgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcbmltcG9ydCB7IERieEZpcmViYXNlU3RvcmFnZUZpbGVVcGxvYWRTdG9yZSB9IGZyb20gJy4uL3N0b3JlJztcbmltcG9ydCB7IEFycmF5T3JWYWx1ZSwgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IHRvT2JzZXJ2YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcbmltcG9ydCB7IHNoYXJlUmVwbGF5IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBGaWxlQWNjZXB0RmlsdGVyVHlwZVN0cmluZyB9IGZyb20gJ0BkZXJlZWtiL2RieC13ZWInO1xuaW1wb3J0IHsgY2xlYW5TdWJzY3JpcHRpb24gfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5cbi8qKlxuICogRGlyZWN0aXZlIHRoYXQgcHJvdmlkZXMgYSBEYnhGaXJlYmFzZVN0b3JhZ2VGaWxlVXBsb2FkU3RvcmUsIGFuZCBzeW5jJ3MgdGhlIGlucHV0cyB0byB0aGUgc3RvcmUuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tkYnhGaXJlYmFzZVN0b3JhZ2VGaWxlVXBsb2FkU3RvcmVdJyxcbiAgZXhwb3J0QXM6ICdkYnhGaXJlYmFzZVN0b3JhZ2VGaWxlVXBsb2FkU3RvcmUnLFxuICBwcm92aWRlcnM6IFtEYnhGaXJlYmFzZVN0b3JhZ2VGaWxlVXBsb2FkU3RvcmVdLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIERieEZpcmViYXNlU3RvcmFnZUZpbGVVcGxvYWRTdG9yZURpcmVjdGl2ZSB7XG4gIHJlYWRvbmx5IHVwbG9hZFN0b3JlID0gaW5qZWN0KERieEZpcmViYXNlU3RvcmFnZUZpbGVVcGxvYWRTdG9yZSk7XG5cbiAgcmVhZG9ubHkgbXVsdGlwbGVVcGxvYWQgPSBpbnB1dDxNYXliZTxib29sZWFuPj4oKTtcbiAgcmVhZG9ubHkgZmlsZVR5cGVzQWNjZXB0ZWQgPSBpbnB1dDxNYXliZTxBcnJheU9yVmFsdWU8RmlsZUFjY2VwdEZpbHRlclR5cGVTdHJpbmc+Pj4oKTtcblxuICByZWFkb25seSBmaWxlVHlwZXNBY2NlcHRlZCQgPSB0b09ic2VydmFibGUodGhpcy5maWxlVHlwZXNBY2NlcHRlZCkucGlwZShza2lwQWxsSW5pdGlhbE1heWJlKCksIHNoYXJlUmVwbGF5KDEpKTtcbiAgcmVhZG9ubHkgaXNNdWx0aVVwbG9hZEFsbG93ZWQkID0gdG9PYnNlcnZhYmxlKHRoaXMubXVsdGlwbGVVcGxvYWQpLnBpcGUoc2tpcEFsbEluaXRpYWxNYXliZSgpLCBzaGFyZVJlcGxheSgxKSk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgY2xlYW5TdWJzY3JpcHRpb24odGhpcy5maWxlVHlwZXNBY2NlcHRlZCQuc3Vic2NyaWJlKCh4KSA9PiB0aGlzLnVwbG9hZFN0b3JlLnNldEZpbGVUeXBlc0FjY2VwdGVkKHgpKSk7XG4gICAgY2xlYW5TdWJzY3JpcHRpb24odGhpcy5pc011bHRpVXBsb2FkQWxsb3dlZCQuc3Vic2NyaWJlKCh4KSA9PiB0aGlzLnVwbG9hZFN0b3JlLnNldElzTXVsdGlVcGxvYWRBbGxvd2VkKHgpKSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,26 +1,18 @@
|
|
|
1
1
|
import { Directive, inject } from '@angular/core';
|
|
2
|
-
import { SubscriptionObject } from '@dereekb/rxjs';
|
|
3
2
|
import { DbxFirebaseStorageFileUploadStore } from '../store';
|
|
4
3
|
import { DbxFileUploadComponent } from '@dereekb/dbx-web';
|
|
4
|
+
import { cleanSubscription } from '@dereekb/dbx-core';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
/**
|
|
7
7
|
* Directive that syncs a DbxFirebaseStorageFileUploadStore's configuration to a DbxFileUploadComponent.
|
|
8
8
|
*/
|
|
9
9
|
export class DbxFirebaseStorageFileUploadSyncDirective {
|
|
10
|
-
_allowedSub = new SubscriptionObject();
|
|
11
|
-
_multiSub = new SubscriptionObject();
|
|
12
|
-
_filesSub = new SubscriptionObject();
|
|
13
10
|
uploadStore = inject(DbxFirebaseStorageFileUploadStore);
|
|
14
11
|
uploadComponent = inject(DbxFileUploadComponent);
|
|
15
12
|
constructor() {
|
|
16
|
-
this.
|
|
17
|
-
this.
|
|
18
|
-
this.
|
|
19
|
-
}
|
|
20
|
-
ngOnDestroy() {
|
|
21
|
-
this._allowedSub.destroy();
|
|
22
|
-
this._multiSub.destroy();
|
|
23
|
-
this._filesSub.destroy();
|
|
13
|
+
cleanSubscription(this.uploadStore.fileTypesAllowed$.subscribe((x) => this.uploadComponent.setAccept(x)));
|
|
14
|
+
cleanSubscription(this.uploadStore.isMultiUploadAllowed$.subscribe((x) => this.uploadComponent.setMultiple(x)));
|
|
15
|
+
cleanSubscription(this.uploadComponent.filesChanged.subscribe((files) => this.uploadStore.setFiles(files.matchResult.accepted)));
|
|
24
16
|
}
|
|
25
17
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseStorageFileUploadSyncDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
26
18
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: DbxFirebaseStorageFileUploadSyncDirective, isStandalone: true, selector: "[dbxFirebaseStorageFileUploadSync]", exportAs: ["dbxFirebaseStorageFileUploadSync"], ngImport: i0 });
|
|
@@ -33,4 +25,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
33
25
|
standalone: true
|
|
34
26
|
}]
|
|
35
27
|
}], ctorParameters: () => [] });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZWZpbGUudXBsb2FkLnN5bmMuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZpcmViYXNlL3NyYy9saWIvbW9kdWxlcy9zdG9yYWdlZmlsZS9jb250YWluZXIvc3RvcmFnZWZpbGUudXBsb2FkLnN5bmMuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUM3RCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUMxRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7QUFFdEQ7O0dBRUc7QUFNSCxNQUFNLE9BQU8seUNBQXlDO0lBQzNDLFdBQVcsR0FBRyxNQUFNLENBQUMsaUNBQWlDLENBQUMsQ0FBQztJQUN4RCxlQUFlLEdBQUcsTUFBTSxDQUFDLHNCQUFzQixDQUFDLENBQUM7SUFFMUQ7UUFDRSxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGlCQUFpQixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzFHLGlCQUFpQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDaEgsaUJBQWlCLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNuSSxDQUFDO3dHQVJVLHlDQUF5Qzs0RkFBekMseUNBQXlDOzs0RkFBekMseUNBQXlDO2tCQUxyRCxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQ0FBb0M7b0JBQzlDLFFBQVEsRUFBRSxrQ0FBa0M7b0JBQzVDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEYnhGaXJlYmFzZVN0b3JhZ2VGaWxlVXBsb2FkU3RvcmUgfSBmcm9tICcuLi9zdG9yZSc7XG5pbXBvcnQgeyBEYnhGaWxlVXBsb2FkQ29tcG9uZW50IH0gZnJvbSAnQGRlcmVla2IvZGJ4LXdlYic7XG5pbXBvcnQgeyBjbGVhblN1YnNjcmlwdGlvbiB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcblxuLyoqXG4gKiBEaXJlY3RpdmUgdGhhdCBzeW5jcyBhIERieEZpcmViYXNlU3RvcmFnZUZpbGVVcGxvYWRTdG9yZSdzIGNvbmZpZ3VyYXRpb24gdG8gYSBEYnhGaWxlVXBsb2FkQ29tcG9uZW50LlxuICovXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZGJ4RmlyZWJhc2VTdG9yYWdlRmlsZVVwbG9hZFN5bmNdJyxcbiAgZXhwb3J0QXM6ICdkYnhGaXJlYmFzZVN0b3JhZ2VGaWxlVXBsb2FkU3luYycsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGJ4RmlyZWJhc2VTdG9yYWdlRmlsZVVwbG9hZFN5bmNEaXJlY3RpdmUge1xuICByZWFkb25seSB1cGxvYWRTdG9yZSA9IGluamVjdChEYnhGaXJlYmFzZVN0b3JhZ2VGaWxlVXBsb2FkU3RvcmUpO1xuICByZWFkb25seSB1cGxvYWRDb21wb25lbnQgPSBpbmplY3QoRGJ4RmlsZVVwbG9hZENvbXBvbmVudCk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgY2xlYW5TdWJzY3JpcHRpb24odGhpcy51cGxvYWRTdG9yZS5maWxlVHlwZXNBbGxvd2VkJC5zdWJzY3JpYmUoKHgpID0+IHRoaXMudXBsb2FkQ29tcG9uZW50LnNldEFjY2VwdCh4KSkpO1xuICAgIGNsZWFuU3Vic2NyaXB0aW9uKHRoaXMudXBsb2FkU3RvcmUuaXNNdWx0aVVwbG9hZEFsbG93ZWQkLnN1YnNjcmliZSgoeCkgPT4gdGhpcy51cGxvYWRDb21wb25lbnQuc2V0TXVsdGlwbGUoeCkpKTtcbiAgICBjbGVhblN1YnNjcmlwdGlvbih0aGlzLnVwbG9hZENvbXBvbmVudC5maWxlc0NoYW5nZWQuc3Vic2NyaWJlKChmaWxlcykgPT4gdGhpcy51cGxvYWRTdG9yZS5zZXRGaWxlcyhmaWxlcy5tYXRjaFJlc3VsdC5hY2NlcHRlZCkpKTtcbiAgfVxufVxuIl19
|
|
@@ -60,4 +60,4 @@ export class DbxFirebaseStorageFileUploadStore extends ComponentStore {
|
|
|
60
60
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseStorageFileUploadStore, decorators: [{
|
|
61
61
|
type: Injectable
|
|
62
62
|
}], ctorParameters: () => [] });
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storagefile.upload.store.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-firebase/src/lib/modules/storagefile/store/storagefile.upload.store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAa,MAAM,eAAe,CAAC;AAGtD,OAAO,EAAE,+BAA+B,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC7E,OAAO,EAAgB,OAAO,EAAyB,MAAM,eAAe,CAAC;AAC7E,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,oBAAoB,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;;AAmI9D;;GAEG;AAEH,MAAM,OAAO,iCAAkC,SAAQ,cAAsD;IAC3G;QACE,KAAK,CAAC,EAAE,CAAC,CAAC;IACZ,CAAC;IAED,kBAAkB;IACT,2BAA2B,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;IACvF,8BAA8B,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IAE1I,iBAAiB,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,iBAAiB,IAAI,KAAK,CAAC,0BAA0B,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,+BAA+B,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IACtK,sBAAsB,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAC3D,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EACvB,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;IAEO,qBAAqB,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,6BAA6B,KAAK,KAAK,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IAEzK,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IACpG,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IACjG,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAEhD,uBAAuB,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5H,oBAAoB,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IACtH,oBAAoB,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/G,aAAa,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAEvE,sBAAsB;IACb,6BAA6B,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,0BAAgF,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,0BAA0B,EAAE,CAAC,CAAC,CAAC;IACtL,gCAAgC,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,6BAA6C,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,6BAA6B,EAAE,CAAC,CAAC,CAAC;IAEzJ,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,UAAmC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;IACzG,oBAAoB,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,iBAAkE,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,iBAAiB,EAAE,iBAAiB,CAAC,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;IAE3N;;;;OAIG;IACM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,KAAoB,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IACpI,uBAAuB,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,oBAAoC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,oBAAoB,EAAE,CAAC,CAAC,CAAC;IAEvI;;;;OAIG;IACM,yBAAyB,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,sBAA+B,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,sBAAsB,EAAE,CAAC,CAAC,CAAC;IAEtI;;OAEG;IACM,sBAAsB,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,mBAAuD,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,mBAAmB,EAAE,CAAC,CAAC,CAAC;IAExJ;;OAEG;IACH,oNAAoN;IAEpN;;OAEG;IACM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,YAAsD,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,sBAAsB,EAAE,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;wGA9DxL,iCAAiC;4GAAjC,iCAAiC;;4FAAjC,iCAAiC;kBAD7C,UAAU","sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\nimport { FileAcceptFilterTypeString } from '@dereekb/dbx-web';\nimport { FirebaseStorageAccessorFile, StoragePathInput } from '@dereekb/firebase';\nimport { distinctUntilHasDifferentValues, filterMaybe } from '@dereekb/rxjs';\nimport { ArrayOrValue, asArray, Maybe, PercentDecimal } from '@dereekb/util';\nimport { ComponentStore } from '@ngrx/component-store';\nimport { distinctUntilChanged, map, shareReplay } from 'rxjs';\nimport { StorageFileUploadFilesEvent, StorageFileUploadFilesFinalResult } from '../container';\n\n/**\n * The stage of the upload process.\n *\n * - configuration: The initial stage where the upload store is being configured.\n * - files: The stage where the files are to be selected.\n * - uploading: The stage where the files are being uploaded.\n * - success: The stage where the files have been successfully uploaded.\n * - error: The stage where the upload has failed.\n */\nexport type DbxFirebaseStorageFileUploadStoreUploadStage = 'configuration' | 'files' | 'uploading' | 'success' | 'error';\n\n/**\n * The accepted file types for the upload.\n *\n * If unset, then all file types are accepted.\n */\nexport type DbxFirebaseStorageFileUploadStoreAllowedTypes = FileAcceptFilterTypeString[];\n\n/**\n * The progress of a file being uploaded.\n *\n * File progresses are automatically created for all files when one file's progress is\n */\nexport interface DbxFirebaseStorageFileUploadStoreFileProgress<T = unknown> {\n  /**\n   * The file being uploaded.\n   */\n  readonly file: File;\n  /**\n   * The accessor file for the file, if available.\n   */\n  readonly fileRef?: Maybe<FirebaseStorageAccessorFile>;\n  /**\n   * The upload reference info for the file, if available.\n   */\n  readonly uploadRef?: Maybe<T>;\n  /**\n   * The number of bytes that have been transferred for this file.\n   */\n  readonly bytesTransferred?: Maybe<number>;\n  /**\n   * The total number of bytes to be uploaded.\n   */\n  readonly totalBytes?: Maybe<number>;\n  /**\n   * The progress of the upload.\n   *\n   * If unset, then the file has not started uploading.\n   */\n  readonly progress?: Maybe<PercentDecimal>;\n  /**\n   * If true, the upload has failed for this file.\n   */\n  readonly failed?: boolean;\n  /**\n   * The error that occurred during the upload for this file.\n   */\n  readonly error?: unknown;\n}\n\nexport interface DbxFirebaseStorageFileUploadStoreState {\n  // Component Configuration\n  /**\n   * The default accepted file types for the upload.\n   *\n   * This may be set by the component.\n   */\n  readonly componentFileTypesAccepted?: Maybe<DbxFirebaseStorageFileUploadStoreAllowedTypes>;\n\n  /**\n   * If true, the component allows multiple files to be selected.\n   *\n   * Defaults to undefined.\n   */\n  readonly isComponentMultiUploadAllowed?: Maybe<boolean>;\n\n  // Configuration Step\n  /**\n   * The accepted file types for the upload.\n   *\n   * Is used to filter the files that can be selected for upload.\n   *\n   * Overrides the componentFileTypesAccepted value if set.\n   */\n  readonly fileTypesAccepted?: Maybe<DbxFirebaseStorageFileUploadStoreAllowedTypes>;\n\n  /**\n   * If true, allow selecting multiple files for upload.\n   *\n   * If isComponentMultiUploadAllowed is false, then this value is ignored.\n   */\n  readonly isMultiUploadAllowed?: Maybe<boolean>;\n\n  /**\n   * Path to upload the file(s) to.\n   *\n   * Must be set before uploading.\n   */\n  readonly uploadPath?: Maybe<StoragePathInput>;\n\n  // Files Step\n  /**\n   * The current file(s) to upload.\n   */\n  readonly files?: Maybe<File[]>;\n\n  // Upload Step\n  /**\n   * The progress of the upload for each file.\n   *\n   * Only set while one or more files are being uploaded.\n   */\n  readonly latestProgressEvent?: Maybe<StorageFileUploadFilesEvent>;\n\n  /**\n   * If true, the upload handler is working.\n   */\n  readonly isUploadHandlerWorking?: Maybe<boolean>;\n\n  // Upload Result\n  /**\n   * The final upload result for the files.\n   *\n   * Only set after the upload has completed.\n   */\n  readonly uploadResult?: Maybe<StorageFileUploadFilesFinalResult>;\n}\n\n/**\n * Store used for selecting a specific NotificationItem from a list of notification items.\n */\n@Injectable()\nexport class DbxFirebaseStorageFileUploadStore extends ComponentStore<DbxFirebaseStorageFileUploadStoreState> implements OnDestroy {\n  constructor() {\n    super({});\n  }\n\n  // MARK: Accessors\n  readonly componentFileTypesAccepted$ = this.select((state) => state.componentFileTypesAccepted);\n  readonly isComponentMultiUploadAllowed$ = this.select((state) => state.isComponentMultiUploadAllowed).pipe(distinctUntilChanged(), shareReplay(1));\n\n  readonly fileTypesAllowed$ = this.select((state) => state.fileTypesAccepted ?? state.componentFileTypesAccepted ?? []).pipe(distinctUntilHasDifferentValues(), shareReplay(1));\n  readonly fileTypesAcceptString$ = this.fileTypesAllowed$.pipe(\n    map((x) => x.join(',')),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly isMultiUploadAllowed$ = this.select((state) => state.isComponentMultiUploadAllowed !== false && state.isMultiUploadAllowed).pipe(distinctUntilChanged(), shareReplay(1));\n\n  readonly uploadPath$ = this.select((state) => state.uploadPath).pipe(distinctUntilChanged(), shareReplay(1));\n  readonly currentFiles$ = this.select((state) => state.files).pipe(distinctUntilChanged(), shareReplay(1));\n  readonly files$ = this.currentFiles$.pipe(filterMaybe());\n\n  readonly isUploadHandlerWorking$ = this.select((state) => state.isUploadHandlerWorking).pipe(distinctUntilChanged(), shareReplay(1));\n  readonly latestProgressEvent$ = this.select((state) => state.latestProgressEvent).pipe(distinctUntilChanged(), shareReplay(1));\n  readonly currentUploadResult$ = this.select((state) => state.uploadResult).pipe(distinctUntilChanged(), shareReplay(1));\n  readonly uploadResult$ = this.currentUploadResult$.pipe(filterMaybe());\n\n  // MARK: State Changes\n  readonly setComponentFileTypesAccepted = this.updater((state, componentFileTypesAccepted: Maybe<DbxFirebaseStorageFileUploadStoreAllowedTypes>) => ({ ...state, componentFileTypesAccepted }));\n  readonly setIsComponentMultiUploadAllowed = this.updater((state, isComponentMultiUploadAllowed: Maybe<boolean>) => ({ ...state, isComponentMultiUploadAllowed }));\n\n  readonly setUploadPath = this.updater((state, uploadPath: Maybe<StoragePathInput>) => ({ ...state, uploadPath }));\n  readonly setFileTypesAccepted = this.updater((state, fileTypesAccepted: Maybe<ArrayOrValue<FileAcceptFilterTypeString>>) => ({ ...state, fileTypesAccepted: fileTypesAccepted ? asArray(fileTypesAccepted) : undefined }));\n\n  /**\n   * Sets the file list to upload.\n   *\n   * If the upload handler is working, the file list cannot be changed.\n   */\n  readonly setFiles = this.updater((state, files: Maybe<File[]>) => ({ ...state, files: state.isUploadHandlerWorking ? state.files : files }));\n  readonly setIsMultiUploadAllowed = this.updater((state, isMultiUploadAllowed: Maybe<boolean>) => ({ ...state, isMultiUploadAllowed }));\n\n  /**\n   * Flags the upload handler to begin working.\n   *\n   * Once the upload handler is flagged, it cannot be unset until the upload handler has finished.\n   */\n  readonly setIsUploadHandlerWorking = this.updater((state, isUploadHandlerWorking: boolean) => ({ ...state, isUploadHandlerWorking }));\n\n  /**\n   * Sets the latest progress event.\n   */\n  readonly setLatestProgressEvent = this.updater((state, latestProgressEvent: Maybe<StorageFileUploadFilesEvent>) => ({ ...state, latestProgressEvent }));\n\n  /**\n   * Updates the upload progress for one or more files.\n   */\n  // readonly updateUploadProgress = this.updater((state, uploadProgress: ArrayOrValue<DbxFirebaseStorageFileUploadStoreFileProgress>) => updateUploadStorageFileStoreStateWithUploadProgress(state, uploadProgress));\n\n  /**\n   * Sets the upload result.\n   */\n  readonly setUploadResult = this.updater((state, uploadResult: Maybe<StorageFileUploadFilesFinalResult>) => ({ ...state, isUploadHandlerWorking: false, uploadProgress: undefined, uploadResult }));\n}\n\n// TODO: Consider moving this back, but might not be needed...\n/*\nexport function updateUploadStorageFileStoreStateWithUploadProgress(state: DbxFirebaseStorageFileUploadStoreState, uploadProgress: ArrayOrValue<DbxFirebaseStorageFileUploadStoreFileProgress>): DbxFirebaseStorageFileUploadStoreState {\n  const { uploadProgress: currentUploadProgress } = state;\n\n  const newUploadProgress = asArray(uploadProgress);\n  const newUploadProgressMap = new Map(newUploadProgress.map((progress) => [progress.file, progress]));\n\n  const updatedUploadProgress = (currentUploadProgress ?? []).map((progress) => {\n    const newProgress = newUploadProgressMap.get(progress.file);\n    return newProgress ?? progress;\n  });\n\n  return { ...state, uploadProgress: updatedUploadProgress };\n}\n*/\n"]}
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storagefile.upload.store.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-firebase/src/lib/modules/storagefile/store/storagefile.upload.store.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { FileAcceptFilterTypeString } from '@dereekb/dbx-web';\nimport { FirebaseStorageAccessorFile, StoragePathInput } from '@dereekb/firebase';\nimport { distinctUntilHasDifferentValues, filterMaybe } from '@dereekb/rxjs';\nimport { ArrayOrValue, asArray, Maybe, PercentDecimal } from '@dereekb/util';\nimport { ComponentStore } from '@ngrx/component-store';\nimport { distinctUntilChanged, map, shareReplay } from 'rxjs';\nimport { StorageFileUploadFilesEvent, StorageFileUploadFilesFinalResult } from '../container';\n\n/**\n * The stage of the upload process.\n *\n * - configuration: The initial stage where the upload store is being configured.\n * - files: The stage where the files are to be selected.\n * - uploading: The stage where the files are being uploaded.\n * - success: The stage where the files have been successfully uploaded.\n * - error: The stage where the upload has failed.\n */\nexport type DbxFirebaseStorageFileUploadStoreUploadStage = 'configuration' | 'files' | 'uploading' | 'success' | 'error';\n\n/**\n * The accepted file types for the upload.\n *\n * If unset, then all file types are accepted.\n */\nexport type DbxFirebaseStorageFileUploadStoreAllowedTypes = FileAcceptFilterTypeString[];\n\n/**\n * The progress of a file being uploaded.\n *\n * File progresses are automatically created for all files when one file's progress is\n */\nexport interface DbxFirebaseStorageFileUploadStoreFileProgress<T = unknown> {\n  /**\n   * The file being uploaded.\n   */\n  readonly file: File;\n  /**\n   * The accessor file for the file, if available.\n   */\n  readonly fileRef?: Maybe<FirebaseStorageAccessorFile>;\n  /**\n   * The upload reference info for the file, if available.\n   */\n  readonly uploadRef?: Maybe<T>;\n  /**\n   * The number of bytes that have been transferred for this file.\n   */\n  readonly bytesTransferred?: Maybe<number>;\n  /**\n   * The total number of bytes to be uploaded.\n   */\n  readonly totalBytes?: Maybe<number>;\n  /**\n   * The progress of the upload.\n   *\n   * If unset, then the file has not started uploading.\n   */\n  readonly progress?: Maybe<PercentDecimal>;\n  /**\n   * If true, the upload has failed for this file.\n   */\n  readonly failed?: boolean;\n  /**\n   * The error that occurred during the upload for this file.\n   */\n  readonly error?: unknown;\n}\n\nexport interface DbxFirebaseStorageFileUploadStoreState {\n  // Component Configuration\n  /**\n   * The default accepted file types for the upload.\n   *\n   * This may be set by the component.\n   */\n  readonly componentFileTypesAccepted?: Maybe<DbxFirebaseStorageFileUploadStoreAllowedTypes>;\n\n  /**\n   * If true, the component allows multiple files to be selected.\n   *\n   * Defaults to undefined.\n   */\n  readonly isComponentMultiUploadAllowed?: Maybe<boolean>;\n\n  // Configuration Step\n  /**\n   * The accepted file types for the upload.\n   *\n   * Is used to filter the files that can be selected for upload.\n   *\n   * Overrides the componentFileTypesAccepted value if set.\n   */\n  readonly fileTypesAccepted?: Maybe<DbxFirebaseStorageFileUploadStoreAllowedTypes>;\n\n  /**\n   * If true, allow selecting multiple files for upload.\n   *\n   * If isComponentMultiUploadAllowed is false, then this value is ignored.\n   */\n  readonly isMultiUploadAllowed?: Maybe<boolean>;\n\n  /**\n   * Path to upload the file(s) to.\n   *\n   * Must be set before uploading.\n   */\n  readonly uploadPath?: Maybe<StoragePathInput>;\n\n  // Files Step\n  /**\n   * The current file(s) to upload.\n   */\n  readonly files?: Maybe<File[]>;\n\n  // Upload Step\n  /**\n   * The progress of the upload for each file.\n   *\n   * Only set while one or more files are being uploaded.\n   */\n  readonly latestProgressEvent?: Maybe<StorageFileUploadFilesEvent>;\n\n  /**\n   * If true, the upload handler is working.\n   */\n  readonly isUploadHandlerWorking?: Maybe<boolean>;\n\n  // Upload Result\n  /**\n   * The final upload result for the files.\n   *\n   * Only set after the upload has completed.\n   */\n  readonly uploadResult?: Maybe<StorageFileUploadFilesFinalResult>;\n}\n\n/**\n * Store used for selecting a specific NotificationItem from a list of notification items.\n */\n@Injectable()\nexport class DbxFirebaseStorageFileUploadStore extends ComponentStore<DbxFirebaseStorageFileUploadStoreState> {\n  constructor() {\n    super({});\n  }\n\n  // MARK: Accessors\n  readonly componentFileTypesAccepted$ = this.select((state) => state.componentFileTypesAccepted);\n  readonly isComponentMultiUploadAllowed$ = this.select((state) => state.isComponentMultiUploadAllowed).pipe(distinctUntilChanged(), shareReplay(1));\n\n  readonly fileTypesAllowed$ = this.select((state) => state.fileTypesAccepted ?? state.componentFileTypesAccepted ?? []).pipe(distinctUntilHasDifferentValues(), shareReplay(1));\n  readonly fileTypesAcceptString$ = this.fileTypesAllowed$.pipe(\n    map((x) => x.join(',')),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly isMultiUploadAllowed$ = this.select((state) => state.isComponentMultiUploadAllowed !== false && state.isMultiUploadAllowed).pipe(distinctUntilChanged(), shareReplay(1));\n\n  readonly uploadPath$ = this.select((state) => state.uploadPath).pipe(distinctUntilChanged(), shareReplay(1));\n  readonly currentFiles$ = this.select((state) => state.files).pipe(distinctUntilChanged(), shareReplay(1));\n  readonly files$ = this.currentFiles$.pipe(filterMaybe());\n\n  readonly isUploadHandlerWorking$ = this.select((state) => state.isUploadHandlerWorking).pipe(distinctUntilChanged(), shareReplay(1));\n  readonly latestProgressEvent$ = this.select((state) => state.latestProgressEvent).pipe(distinctUntilChanged(), shareReplay(1));\n  readonly currentUploadResult$ = this.select((state) => state.uploadResult).pipe(distinctUntilChanged(), shareReplay(1));\n  readonly uploadResult$ = this.currentUploadResult$.pipe(filterMaybe());\n\n  // MARK: State Changes\n  readonly setComponentFileTypesAccepted = this.updater((state, componentFileTypesAccepted: Maybe<DbxFirebaseStorageFileUploadStoreAllowedTypes>) => ({ ...state, componentFileTypesAccepted }));\n  readonly setIsComponentMultiUploadAllowed = this.updater((state, isComponentMultiUploadAllowed: Maybe<boolean>) => ({ ...state, isComponentMultiUploadAllowed }));\n\n  readonly setUploadPath = this.updater((state, uploadPath: Maybe<StoragePathInput>) => ({ ...state, uploadPath }));\n  readonly setFileTypesAccepted = this.updater((state, fileTypesAccepted: Maybe<ArrayOrValue<FileAcceptFilterTypeString>>) => ({ ...state, fileTypesAccepted: fileTypesAccepted ? asArray(fileTypesAccepted) : undefined }));\n\n  /**\n   * Sets the file list to upload.\n   *\n   * If the upload handler is working, the file list cannot be changed.\n   */\n  readonly setFiles = this.updater((state, files: Maybe<File[]>) => ({ ...state, files: state.isUploadHandlerWorking ? state.files : files }));\n  readonly setIsMultiUploadAllowed = this.updater((state, isMultiUploadAllowed: Maybe<boolean>) => ({ ...state, isMultiUploadAllowed }));\n\n  /**\n   * Flags the upload handler to begin working.\n   *\n   * Once the upload handler is flagged, it cannot be unset until the upload handler has finished.\n   */\n  readonly setIsUploadHandlerWorking = this.updater((state, isUploadHandlerWorking: boolean) => ({ ...state, isUploadHandlerWorking }));\n\n  /**\n   * Sets the latest progress event.\n   */\n  readonly setLatestProgressEvent = this.updater((state, latestProgressEvent: Maybe<StorageFileUploadFilesEvent>) => ({ ...state, latestProgressEvent }));\n\n  /**\n   * Updates the upload progress for one or more files.\n   */\n  // readonly updateUploadProgress = this.updater((state, uploadProgress: ArrayOrValue<DbxFirebaseStorageFileUploadStoreFileProgress>) => updateUploadStorageFileStoreStateWithUploadProgress(state, uploadProgress));\n\n  /**\n   * Sets the upload result.\n   */\n  readonly setUploadResult = this.updater((state, uploadResult: Maybe<StorageFileUploadFilesFinalResult>) => ({ ...state, isUploadHandlerWorking: false, uploadProgress: undefined, uploadResult }));\n}\n\n// TODO: Consider moving this back, but might not be needed...\n/*\nexport function updateUploadStorageFileStoreStateWithUploadProgress(state: DbxFirebaseStorageFileUploadStoreState, uploadProgress: ArrayOrValue<DbxFirebaseStorageFileUploadStoreFileProgress>): DbxFirebaseStorageFileUploadStoreState {\n  const { uploadProgress: currentUploadProgress } = state;\n\n  const newUploadProgress = asArray(uploadProgress);\n  const newUploadProgressMap = new Map(newUploadProgress.map((progress) => [progress.file, progress]));\n\n  const updatedUploadProgress = (currentUploadProgress ?? []).map((progress) => {\n    const newProgress = newUploadProgressMap.get(progress.file);\n    return newProgress ?? progress;\n  });\n\n  return { ...state, uploadProgress: updatedUploadProgress };\n}\n*/\n"]}
|