nuxeo-development-framework 5.8.0 → 5.8.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/nuxeo-development-framework.umd.js +1794 -156
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/documents/components/document-scan/document-scan.component.js +1 -1
- package/esm2015/lib/components/ndf-scanner/index.js +3 -0
- package/esm2015/lib/components/ndf-scanner/ndf-scanner.component.js +966 -0
- package/esm2015/lib/components/ndf-scanner/ndf-scanner.module.js +23 -0
- package/esm2015/lib/components/ndf-uploader/components/bottom-sheet/ndf-uploader-bottom-sheet.component.js +124 -0
- package/esm2015/lib/components/ndf-uploader/components/index.js +2 -0
- package/esm2015/lib/components/ndf-uploader/config/index.js +2 -0
- package/esm2015/lib/components/ndf-uploader/config/uploader.config.js +10 -0
- package/esm2015/lib/components/ndf-uploader/constant/file-content.js +6 -0
- package/esm2015/lib/components/ndf-uploader/constant/index.js +2 -0
- package/esm2015/lib/components/ndf-uploader/helpers/index.js +2 -0
- package/esm2015/lib/components/ndf-uploader/helpers/uploader.helper.js +100 -0
- package/esm2015/lib/components/ndf-uploader/index.js +6 -0
- package/esm2015/lib/components/ndf-uploader/models/batch.model.js +2 -0
- package/esm2015/lib/components/ndf-uploader/models/index.js +4 -0
- package/esm2015/lib/components/ndf-uploader/models/ndf-file.model.js +20 -0
- package/esm2015/lib/components/ndf-uploader/models/provider.model.js +2 -0
- package/esm2015/lib/components/ndf-uploader/ndf-uploader-bottom-sheet.service.js +72 -0
- package/esm2015/lib/components/ndf-uploader/ndf-uploader.module.js +53 -0
- package/esm2015/lib/components/ndf-uploader/ndf-uploader.service.js +241 -0
- package/esm2015/lib/components/ndf-uploader/providers/index.js +3 -0
- package/esm2015/lib/components/ndf-uploader/providers/nuxeo-provider.service.js +32 -0
- package/esm2015/lib/components/ndf-uploader/providers/s3-provider.service.js +26 -0
- package/esm2015/public-api.js +3 -1
- package/fesm2015/nuxeo-development-framework.js +1633 -51
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/ndf-scanner/index.d.ts +2 -0
- package/lib/components/ndf-scanner/ndf-scanner.component.d.ts +104 -0
- package/lib/components/ndf-scanner/ndf-scanner.module.d.ts +13 -0
- package/lib/components/ndf-uploader/components/bottom-sheet/ndf-uploader-bottom-sheet.component.d.ts +27 -0
- package/lib/components/ndf-uploader/components/index.d.ts +1 -0
- package/lib/components/ndf-uploader/config/index.d.ts +1 -0
- package/lib/components/ndf-uploader/config/uploader.config.d.ts +9 -0
- package/lib/components/ndf-uploader/constant/file-content.d.ts +5 -0
- package/lib/components/ndf-uploader/constant/index.d.ts +1 -0
- package/lib/components/ndf-uploader/helpers/index.d.ts +1 -0
- package/lib/components/ndf-uploader/helpers/uploader.helper.d.ts +10 -0
- package/lib/components/ndf-uploader/index.d.ts +5 -0
- package/lib/components/ndf-uploader/models/batch.model.d.ts +28 -0
- package/lib/components/ndf-uploader/models/index.d.ts +3 -0
- package/lib/components/ndf-uploader/models/ndf-file.model.d.ts +46 -0
- package/lib/components/ndf-uploader/models/provider.model.d.ts +7 -0
- package/lib/components/ndf-uploader/ndf-uploader-bottom-sheet.service.d.ts +30 -0
- package/lib/components/ndf-uploader/ndf-uploader.module.d.ts +16 -0
- package/lib/components/ndf-uploader/ndf-uploader.service.d.ts +25 -0
- package/lib/components/ndf-uploader/providers/index.d.ts +2 -0
- package/lib/components/ndf-uploader/providers/nuxeo-provider.service.d.ts +13 -0
- package/lib/components/ndf-uploader/providers/s3-provider.service.d.ts +13 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
4
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
5
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
6
|
+
import { NdfScannerComponent } from './ndf-scanner.component';
|
|
7
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
8
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
export class NdfScannerModule {
|
|
11
|
+
}
|
|
12
|
+
NdfScannerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfScannerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
NdfScannerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfScannerModule, declarations: [NdfScannerComponent], imports: [CommonModule, TranslateModule, MatIconModule, MatButtonModule, MatTooltipModule, MatProgressSpinnerModule], exports: [NdfScannerComponent] });
|
|
14
|
+
NdfScannerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfScannerModule, imports: [[CommonModule, TranslateModule, MatIconModule, MatButtonModule, MatTooltipModule, MatProgressSpinnerModule]] });
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfScannerModule, decorators: [{
|
|
16
|
+
type: NgModule,
|
|
17
|
+
args: [{
|
|
18
|
+
imports: [CommonModule, TranslateModule, MatIconModule, MatButtonModule, MatTooltipModule, MatProgressSpinnerModule],
|
|
19
|
+
declarations: [NdfScannerComponent],
|
|
20
|
+
exports: [NdfScannerComponent]
|
|
21
|
+
}]
|
|
22
|
+
}] });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmRmLXNjYW5uZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9uZGYtc2Nhbm5lci9uZGYtc2Nhbm5lci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sb0NBQW9DLENBQUM7O0FBTzlFLE1BQU0sT0FBTyxnQkFBZ0I7OzhHQUFoQixnQkFBZ0I7K0dBQWhCLGdCQUFnQixpQkFIYixtQkFBbUIsYUFEeEIsWUFBWSxFQUFFLGVBQWUsRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLHdCQUF3QixhQUV6RyxtQkFBbUI7K0dBRWpCLGdCQUFnQixZQUpuQixDQUFDLFlBQVksRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSx3QkFBd0IsQ0FBQzs0RkFJeEcsZ0JBQWdCO2tCQUw1QixRQUFRO21CQUFDO29CQUNULE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSx3QkFBd0IsQ0FBQztvQkFDcEgsWUFBWSxFQUFFLENBQUMsbUJBQW1CLENBQUM7b0JBQ25DLE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO2lCQUM5QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XHJcbmltcG9ydCB7IE5kZlNjYW5uZXJDb21wb25lbnQgfSBmcm9tICcuL25kZi1zY2FubmVyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcclxuaW1wb3J0IHsgTWF0UHJvZ3Jlc3NTcGlubmVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3Mtc3Bpbm5lcic7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG5cdGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFRyYW5zbGF0ZU1vZHVsZSwgTWF0SWNvbk1vZHVsZSwgTWF0QnV0dG9uTW9kdWxlLCBNYXRUb29sdGlwTW9kdWxlLCBNYXRQcm9ncmVzc1NwaW5uZXJNb2R1bGVdLFxyXG5cdGRlY2xhcmF0aW9uczogW05kZlNjYW5uZXJDb21wb25lbnRdLFxyXG5cdGV4cG9ydHM6IFtOZGZTY2FubmVyQ29tcG9uZW50XVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTmRmU2Nhbm5lck1vZHVsZSB7fVxyXG4iXX0=
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { Component, Inject, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { MAT_BOTTOM_SHEET_DATA } from '@angular/material/bottom-sheet';
|
|
3
|
+
import { distinctUntilChanged, takeUntil } from 'rxjs/operators';
|
|
4
|
+
import { BehaviorSubject, of, Subject } from 'rxjs';
|
|
5
|
+
import { BaseComponent } from '../../../../shared/components/base';
|
|
6
|
+
import { FileEventType, FileStatus } from '../../models';
|
|
7
|
+
import { NdfUploaderSheetEventType } from '../../ndf-uploader-bottom-sheet.service';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../../../../shared/components/nuxeo-dialog/services/nuxeo-dialog.service";
|
|
10
|
+
import * as i2 from "../../ndf-uploader.service";
|
|
11
|
+
import * as i3 from "../../ndf-uploader-bottom-sheet.service";
|
|
12
|
+
import * as i4 from "@angular/material/expansion";
|
|
13
|
+
import * as i5 from "@angular/material/icon";
|
|
14
|
+
import * as i6 from "@angular/material/progress-spinner";
|
|
15
|
+
import * as i7 from "@angular/common";
|
|
16
|
+
import * as i8 from "@angular/material/tooltip";
|
|
17
|
+
import * as i9 from "@ngx-translate/core";
|
|
18
|
+
export class NdfUploaderBottomSheetComponent extends BaseComponent {
|
|
19
|
+
constructor(injector, nuxeoDialogService, uploaderService, uploaderBottomSheetService, files) {
|
|
20
|
+
super(injector);
|
|
21
|
+
this.nuxeoDialogService = nuxeoDialogService;
|
|
22
|
+
this.uploaderService = uploaderService;
|
|
23
|
+
this.uploaderBottomSheetService = uploaderBottomSheetService;
|
|
24
|
+
this.files = files;
|
|
25
|
+
this.expanded = true;
|
|
26
|
+
this.completed$ = new Subject();
|
|
27
|
+
this.fileStatus = FileStatus;
|
|
28
|
+
this.uploaderBottomSheetService.filesInfo$ = new BehaviorSubject([]);
|
|
29
|
+
this.uploaderService.reset();
|
|
30
|
+
}
|
|
31
|
+
ngOnInit() {
|
|
32
|
+
if (this.files.length) {
|
|
33
|
+
this.uploaderService
|
|
34
|
+
.upload(this.files)
|
|
35
|
+
.pipe(takeUntil(this.destroy$), distinctUntilChanged())
|
|
36
|
+
.subscribe((event) => {
|
|
37
|
+
if (event.type == FileEventType.Changes) {
|
|
38
|
+
const data = event.data;
|
|
39
|
+
this.uploaderBottomSheetService.filesInfo$.value.forEach((item) => {
|
|
40
|
+
const updatedFile = data.find((q) => q.batchId == item.batchId);
|
|
41
|
+
if (updatedFile) {
|
|
42
|
+
updatedFile.documentId = item.documentId;
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
this.uploaderBottomSheetService.filesInfo$.next(data);
|
|
46
|
+
this.completed$.next(data.filter((q) => q.status == FileStatus.Completed).length);
|
|
47
|
+
}
|
|
48
|
+
else if (event.type == FileEventType.Complete) {
|
|
49
|
+
this.uploaderBottomSheetService.notify({
|
|
50
|
+
type: NdfUploaderSheetEventType.Submit,
|
|
51
|
+
data: event.data[0]
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
open(fileInfo) {
|
|
58
|
+
const ids = fileInfo
|
|
59
|
+
? [fileInfo.documentId]
|
|
60
|
+
: this.uploaderBottomSheetService.filesInfo$.value
|
|
61
|
+
.filter((f) => f.status == FileStatus.Completed)
|
|
62
|
+
.map((f) => f.documentId);
|
|
63
|
+
this.uploaderBottomSheetService.notify({
|
|
64
|
+
type: NdfUploaderSheetEventType.Open,
|
|
65
|
+
data: ids
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
add(event) {
|
|
69
|
+
const input = event.target;
|
|
70
|
+
this.uploaderBottomSheetService.open(Array.from(input.files));
|
|
71
|
+
this.expanded = true;
|
|
72
|
+
}
|
|
73
|
+
dismiss() {
|
|
74
|
+
const allFilesCompleted = this.uploaderBottomSheetService.filesInfo$.value.every((f) => f.status === FileStatus.Completed);
|
|
75
|
+
if (allFilesCompleted) {
|
|
76
|
+
this.uploaderService.reset();
|
|
77
|
+
return this.uploaderBottomSheetService.close();
|
|
78
|
+
}
|
|
79
|
+
this.nuxeoDialogService.showConfirm({
|
|
80
|
+
message: 'confirmDialog.closeUploading',
|
|
81
|
+
actions: {
|
|
82
|
+
confirm: {
|
|
83
|
+
label: 'BUTTONS.confirm',
|
|
84
|
+
fn: () => {
|
|
85
|
+
this.uploaderBottomSheetService.close();
|
|
86
|
+
// const hasNotCompleted = this.filesInfo$.value.every(
|
|
87
|
+
// (f) => f.status != FileStatus.Completed
|
|
88
|
+
// );
|
|
89
|
+
// if (hasNotCompleted) {
|
|
90
|
+
// // will delete all not completed batches or not
|
|
91
|
+
// return this.uploaderService.cancel();
|
|
92
|
+
// }
|
|
93
|
+
this.uploaderService.reset();
|
|
94
|
+
return of(true);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
retry(fileInfo) {
|
|
101
|
+
this.uploaderService.resume(fileInfo.id);
|
|
102
|
+
}
|
|
103
|
+
cancel(fileInfo) {
|
|
104
|
+
this.uploaderService.stop(fileInfo.id);
|
|
105
|
+
}
|
|
106
|
+
trackFile(index, item) {
|
|
107
|
+
return item.id;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
NdfUploaderBottomSheetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfUploaderBottomSheetComponent, deps: [{ token: i0.Injector }, { token: i1.NuxeoDialogService }, { token: i2.NdfUploaderService }, { token: i3.NdfUploaderBottomSheetService }, { token: MAT_BOTTOM_SHEET_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
111
|
+
NdfUploaderBottomSheetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: NdfUploaderBottomSheetComponent, selector: "ndf-uploader-bottom-sheet", usesInheritance: true, ngImport: i0, template: "<mat-expansion-panel [expanded]=\"expanded\" hideToggle>\r\n\t<mat-expansion-panel-header #panelH (click)=\"panelH._toggle()\">\r\n\t\t<div class=\"w-full d-flex justify-content-between\">\r\n\t\t\t<ng-container *ngIf=\"completed$ | async as completed; else generalMsg\">\r\n\t\t\t\t<ng-container *ngIf=\"completed > 1; else single\">\r\n\t\t\t\t\t<div class=\"flex items-center justify-center font-weight-bold\">\r\n\t\t\t\t\t\t{{ 'UploaderBottomSheet.MultiUploadsComplete' | translate : { completed: completed } }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-container>\r\n\t\t\t\t<ng-template #single>\r\n\t\t\t\t\t<div class=\"flex items-center justify-center font-weight-bold\">\r\n\t\t\t\t\t\t{{ 'UploaderBottomSheet.SingleUploadsComplete' | translate }}\r\n\t\t\t\t\t</div></ng-template\r\n\t\t\t\t>\r\n\t\t\t</ng-container>\r\n\t\t\t<ng-template #generalMsg>\r\n\t\t\t\t<div class=\"flex items-center justify-center font-weight-bold\">\r\n\t\t\t\t\t{{ 'UploaderBottomSheet.UploadingData' | translate }}\r\n\t\t\t\t</div>\r\n\t\t\t</ng-template>\r\n\r\n\t\t\t<div>\r\n\t\t\t\t<mat-icon\r\n\t\t\t\t\tclass=\"icon-size-3.5 mx-2\"\r\n\t\t\t\t\t[svgIcon]=\"'icons:plus'\"\r\n\t\t\t\t\t(click)=\"$event.stopPropagation(); fileInput.click()\"\r\n\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.CREATE' | translate }}\"\r\n\t\t\t\t>\r\n\t\t\t\t</mat-icon>\r\n\t\t\t\t<input type=\"file\" hidden #fileInput (change)=\"add($event)\" multiple />\r\n\r\n\t\t\t\t<mat-icon\r\n\t\t\t\t\tclass=\"icon-size-3.5 mx-2\"\r\n\t\t\t\t\t[svgIcon]=\"'icons:open-folder'\"\r\n\t\t\t\t\t(click)=\"$event.stopPropagation(); open()\"\r\n\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.ShowUploadedFiles' | translate }}\"\r\n\t\t\t\t>\r\n\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t<mat-icon\r\n\t\t\t\t\tclass=\"icon-size-3.5 mx-2\"\r\n\t\t\t\t\t[svgIcon]=\"'icons:expand'\"\r\n\t\t\t\t\t[ngClass]=\"{\r\n\t\t\t\t\t\tcontainerOpened: !expanded,\r\n\t\t\t\t\t\tcontainerClosed: expanded\r\n\t\t\t\t\t}\"\r\n\t\t\t\t\t(click)=\"$event.stopPropagation(); expanded = !expanded\"\r\n\t\t\t\t\tmatTooltip=\"{{ (expanded ? 'UploaderBottomSheet.MINIMIZED' : 'UploaderBottomSheet.MAXIMIZED') | translate }}\"\r\n\t\t\t\t>\r\n\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t<mat-icon\r\n\t\t\t\t\tclass=\"icon-size-3.5 close-sheet\"\r\n\t\t\t\t\t[svgIcon]=\"'icons:cancel-icon'\"\r\n\t\t\t\t\t(click)=\"$event.stopPropagation(); dismiss()\"\r\n\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.CLOSE' | translate }}\"\r\n\t\t\t\t>\r\n\t\t\t\t</mat-icon>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</mat-expansion-panel-header>\r\n\r\n\t<div>\r\n\t\t<div\r\n\t\t\tclass=\"file-item d-flex justify-content-between align-items-center py-2 px-5\"\r\n\t\t\t*ngFor=\"let fileInfo of uploaderBottomSheetService.filesInfo$ | async; trackBy: trackFile\"\r\n\t\t>\r\n\t\t\t<div class=\"d-flex align-items-center truncate\">\r\n\t\t\t\t<img src=\"{{ fileInfo.icon }}\" class=\"file-icon\" alt=\"{{ fileInfo.data.name }}\" />\r\n\t\t\t\t<span class=\"truncate file-name\">{{ fileInfo.data.name }}</span>\r\n\t\t\t</div>\r\n\t\t\t<div>\r\n\t\t\t\t<!-- only if user hover the row -->\r\n\t\t\t\t<span class=\"more-upload-actions align-items-center\">\r\n\t\t\t\t\t<!-- cancel if file : pending or uploading + hover -->\r\n\t\t\t\t\t<mat-icon\r\n\t\t\t\t\t\tclass=\"icon-size-3.5\"\r\n\t\t\t\t\t\t[svgIcon]=\"'icons:cancel-icon'\"\r\n\t\t\t\t\t\t(click)=\"$event.stopPropagation(); cancel(fileInfo)\"\r\n\t\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.CANCEL' | translate }}\"\r\n\t\t\t\t\t\t*ngIf=\"fileInfo.status == fileStatus.Pending || fileInfo.status == fileStatus.InProgress\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t\t<!-- retry if file : canceled or error + hover -->\r\n\t\t\t\t\t<mat-icon\r\n\t\t\t\t\t\tclass=\"icon-size-4.5\"\r\n\t\t\t\t\t\t[svgIcon]=\"'icons:retry'\"\r\n\t\t\t\t\t\t(click)=\"$event.stopPropagation(); retry(fileInfo)\"\r\n\t\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.RETRY' | translate }}\"\r\n\t\t\t\t\t\t*ngIf=\"fileInfo.status == fileStatus.Canceled || fileInfo.status == fileStatus.Error\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t\t<!-- open file : hover + completed -->\r\n\t\t\t\t\t<mat-icon\r\n\t\t\t\t\t\tclass=\"icon-size-4.5\"\r\n\t\t\t\t\t\t[svgIcon]=\"'icons:open-folder'\"\r\n\t\t\t\t\t\t(click)=\"$event.stopPropagation(); open(fileInfo)\"\r\n\t\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.OPEN' | translate }}\"\r\n\t\t\t\t\t\t*ngIf=\"fileInfo.status == fileStatus.Completed\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t</mat-icon>\r\n\t\t\t\t</span>\r\n\r\n\t\t\t\t<span class=\"base-upload-actions align-items-center\">\r\n\t\t\t\t\t<!-- file completed -->\r\n\t\t\t\t\t<mat-icon class=\"icon-size-4.5\" [svgIcon]=\"'icons:complete'\" *ngIf=\"fileInfo.status == fileStatus.Completed\">\r\n\t\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t\t<!-- file has error -->\r\n\t\t\t\t\t<mat-icon class=\"icon-size-4.5\" [svgIcon]=\"'icons:error'\" *ngIf=\"fileInfo.status == fileStatus.Error\">\r\n\t\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t\t<!-- user cancle the file -->\r\n\t\t\t\t\t<mat-icon class=\"icon-size-4.5\" [svgIcon]=\"'icons:error'\" *ngIf=\"fileInfo.status == fileStatus.Canceled\">\r\n\t\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\tclass=\"spinner-container\"\r\n\t\t\t\t\t\t*ngIf=\"fileInfo.status == fileStatus.Pending || fileInfo.status == fileStatus.InProgress\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<mat-spinner [value]=\"fileInfo.progress\" diameter=\"20\" strokeWidth=\"2\" color=\"primary\"></mat-spinner>\r\n\t\t\t\t\t\t<div class=\"spinner-percentage\" *ngIf=\"fileInfo.status == fileStatus.InProgress\">\r\n\t\t\t\t\t\t\t{{ fileInfo.progress | number : '1.0-0' }}\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</span>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n</mat-expansion-panel>\r\n", styles: [".upload-bottom-sheet{width:var(--upload-bottom-sheet-width, 30vw)!important;padding:var(--upload-bottom-sheet-padding, 0)!important;border-width:var(--upload-bottom-sheet-border-width, 1px);border-radius:var(--upload-bottom-sheet-border-radius, 16px 16px 0 0)!important;position:fixed!important;bottom:var(--upload-bottom-sheet-bottom, 0)!important}.upload-bottom-sheet .mat-icon-button{height:var(--upload-bottom-sheet-mat-icon-button-height, 1.125rem)!important;line-height:var(--upload-bottom-sheet-mat-icon-button-line-height, 1.125rem)!important}.upload-bottom-sheet .mat-expansion-panel-content{overflow-y:auto!important;max-height:var(--upload-bottom-sheet-mat-expansion-panel-max-height, 20vh)!important}.upload-bottom-sheet .mat-expansion-panel-body{padding:var(--upload-bottom-sheet-mat-expansion-panel-body-padding, 0)!important}.upload-bottom-sheet .file-icon{width:var(--upload-bottom-sheet-file-icon-width, 24px);margin-inline-end:var(--upload-bottom-sheet-file-icon-margin-inline-end, 6px);padding:var(--upload-bottom-sheet-file-icon-padding, 2px)}.upload-bottom-sheet .spinner-container{position:relative;display:inline-flex;align-items:center;justify-content:center}.upload-bottom-sheet .spinner-percentage{position:absolute;font-size:var(--upload-bottom-sheet-spinner-percentage-font-size, 10px)}.upload-bottom-sheet .file-name{height:var(--upload-bottom-sheet-file-name-height, 24px)}.upload-bottom-sheet .base-upload-actions{display:inline-block}.upload-bottom-sheet .more-upload-actions{display:none}.upload-bottom-sheet .file-item:hover{cursor:pointer;background:var(--upload-bottom-sheet-file-item-hover-background, #f5f5f5)}.upload-bottom-sheet .file-item:hover .base-upload-actions{display:none}.upload-bottom-sheet .file-item:hover .more-upload-actions{display:flex}.upload-bottom-sheet .close-sheet{margin-inline-start:var(--upload-bottom-sheet-close-sheet-margin-inline-start, .5rem)}[lang=ar] .upload-bottom-sheet{left:1rem!important}[lang=en] .upload-bottom-sheet{right:1rem!important}\n"], components: [{ type: i4.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { type: i4.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["expandedHeight", "collapsedHeight"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i6.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltipPosition", "matTooltipDisabled", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i7.AsyncPipe, "translate": i9.TranslatePipe, "number": i7.DecimalPipe }, encapsulation: i0.ViewEncapsulation.None });
|
|
112
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfUploaderBottomSheetComponent, decorators: [{
|
|
113
|
+
type: Component,
|
|
114
|
+
args: [{
|
|
115
|
+
selector: 'ndf-uploader-bottom-sheet',
|
|
116
|
+
styleUrls: ['./ndf-uploader-bottom-sheet.component.scss'],
|
|
117
|
+
templateUrl: './ndf-uploader-bottom-sheet.component.html',
|
|
118
|
+
encapsulation: ViewEncapsulation.None
|
|
119
|
+
}]
|
|
120
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.NuxeoDialogService }, { type: i2.NdfUploaderService }, { type: i3.NdfUploaderBottomSheetService }, { type: Array, decorators: [{
|
|
121
|
+
type: Inject,
|
|
122
|
+
args: [MAT_BOTTOM_SHEET_DATA]
|
|
123
|
+
}] }]; } });
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ndf-uploader-bottom-sheet.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/ndf-uploader/components/bottom-sheet/ndf-uploader-bottom-sheet.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/ndf-uploader/components/bottom-sheet/ndf-uploader-bottom-sheet.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Injector, OnInit, ViewEncapsulation } from '@angular/core';\r\nimport { MAT_BOTTOM_SHEET_DATA } from '@angular/material/bottom-sheet';\r\nimport { distinctUntilChanged, takeUntil } from 'rxjs/operators';\r\nimport { BehaviorSubject, of, Subject } from 'rxjs';\r\nimport { BaseComponent } from '../../../../shared/components/base';\r\nimport { FileEventType, FileInfo, FileStatus } from '../../models';\r\nimport { NuxeoDialogService } from '../../../../shared/components/nuxeo-dialog/services/nuxeo-dialog.service';\r\nimport { NdfUploaderService } from '../../ndf-uploader.service';\r\nimport { NdfUploaderBottomSheetService, NdfUploaderSheetEventType } from '../../ndf-uploader-bottom-sheet.service';\r\n\r\n@Component({\r\n\tselector: 'ndf-uploader-bottom-sheet',\r\n\tstyleUrls: ['./ndf-uploader-bottom-sheet.component.scss'],\r\n\ttemplateUrl: './ndf-uploader-bottom-sheet.component.html',\r\n\tencapsulation: ViewEncapsulation.None\r\n})\r\nexport class NdfUploaderBottomSheetComponent extends BaseComponent implements OnInit {\r\n\texpanded = true;\r\n\r\n\tcompleted$ = new Subject<number>();\r\n\tfileStatus = FileStatus;\r\n\r\n\tconstructor(\r\n\t\tinjector: Injector,\r\n\t\tprivate nuxeoDialogService: NuxeoDialogService,\r\n\t\tprivate readonly uploaderService: NdfUploaderService,\r\n\t\tpublic readonly uploaderBottomSheetService: NdfUploaderBottomSheetService,\r\n\t\t@Inject(MAT_BOTTOM_SHEET_DATA) private readonly files: Array<File>\r\n\t) {\r\n\t\tsuper(injector);\r\n\t\tthis.uploaderBottomSheetService.filesInfo$ = new BehaviorSubject([]);\r\n\t\tthis.uploaderService.reset();\r\n\t}\r\n\r\n\tngOnInit(): void {\r\n\t\tif (this.files.length) {\r\n\t\t\tthis.uploaderService\r\n\t\t\t\t.upload(this.files)\r\n\t\t\t\t.pipe(takeUntil(this.destroy$), distinctUntilChanged())\r\n\t\t\t\t.subscribe((event) => {\r\n\t\t\t\t\tif (event.type == FileEventType.Changes) {\r\n\t\t\t\t\t\tconst data = event.data;\r\n\t\t\t\t\t\tthis.uploaderBottomSheetService.filesInfo$.value.forEach((item) => {\r\n\t\t\t\t\t\t\tconst updatedFile = data.find((q) => q.batchId == item.batchId);\r\n\t\t\t\t\t\t\tif (updatedFile) {\r\n\t\t\t\t\t\t\t\tupdatedFile.documentId = item.documentId;\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tthis.uploaderBottomSheetService.filesInfo$.next(data);\r\n\t\t\t\t\t\tthis.completed$.next(data.filter((q) => q.status == FileStatus.Completed).length);\r\n\t\t\t\t\t} else if (event.type == FileEventType.Complete) {\r\n\t\t\t\t\t\tthis.uploaderBottomSheetService.notify({\r\n\t\t\t\t\t\t\ttype: NdfUploaderSheetEventType.Submit,\r\n\t\t\t\t\t\t\tdata: event.data[0]\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\topen(fileInfo?: FileInfo) {\r\n\t\tconst ids = fileInfo\r\n\t\t\t? [fileInfo.documentId]\r\n\t\t\t: this.uploaderBottomSheetService.filesInfo$.value\r\n\t\t\t\t\t.filter((f) => f.status == FileStatus.Completed)\r\n\t\t\t\t\t.map((f) => f.documentId);\r\n\r\n\t\tthis.uploaderBottomSheetService.notify({\r\n\t\t\ttype: NdfUploaderSheetEventType.Open,\r\n\t\t\tdata: ids\r\n\t\t});\r\n\t}\r\n\r\n\tadd(event: Event) {\r\n\t\tconst input = event.target as HTMLInputElement;\r\n\t\tthis.uploaderBottomSheetService.open(Array.from(input.files));\r\n\t\tthis.expanded = true;\r\n\t}\r\n\tdismiss() {\r\n\t\tconst allFilesCompleted = this.uploaderBottomSheetService.filesInfo$.value.every(\r\n\t\t\t(f) => f.status === FileStatus.Completed\r\n\t\t);\r\n\t\tif (allFilesCompleted) {\r\n\t\t\tthis.uploaderService.reset();\r\n\t\t\treturn this.uploaderBottomSheetService.close();\r\n\t\t}\r\n\r\n\t\tthis.nuxeoDialogService.showConfirm({\r\n\t\t\tmessage: 'confirmDialog.closeUploading',\r\n\t\t\tactions: {\r\n\t\t\t\tconfirm: {\r\n\t\t\t\t\tlabel: 'BUTTONS.confirm',\r\n\t\t\t\t\tfn: () => {\r\n\t\t\t\t\t\tthis.uploaderBottomSheetService.close();\r\n\t\t\t\t\t\t// const hasNotCompleted = this.filesInfo$.value.every(\r\n\t\t\t\t\t\t// \t(f) => f.status != FileStatus.Completed\r\n\t\t\t\t\t\t// );\r\n\t\t\t\t\t\t// if (hasNotCompleted) {\r\n\t\t\t\t\t\t// \t// will delete all not completed batches or not\r\n\t\t\t\t\t\t// \treturn this.uploaderService.cancel();\r\n\t\t\t\t\t\t// }\r\n\t\t\t\t\t\tthis.uploaderService.reset();\r\n\t\t\t\t\t\treturn of(true);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tretry(fileInfo: FileInfo) {\r\n\t\tthis.uploaderService.resume(fileInfo.id);\r\n\t}\r\n\r\n\tcancel(fileInfo: FileInfo) {\r\n\t\tthis.uploaderService.stop(fileInfo.id);\r\n\t}\r\n\r\n\ttrackFile(index: number, item: FileInfo): string {\r\n\t\treturn item.id;\r\n\t}\r\n}\r\n","<mat-expansion-panel [expanded]=\"expanded\" hideToggle>\r\n\t<mat-expansion-panel-header #panelH (click)=\"panelH._toggle()\">\r\n\t\t<div class=\"w-full d-flex justify-content-between\">\r\n\t\t\t<ng-container *ngIf=\"completed$ | async as completed; else generalMsg\">\r\n\t\t\t\t<ng-container *ngIf=\"completed > 1; else single\">\r\n\t\t\t\t\t<div class=\"flex items-center justify-center font-weight-bold\">\r\n\t\t\t\t\t\t{{ 'UploaderBottomSheet.MultiUploadsComplete' | translate : { completed: completed } }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-container>\r\n\t\t\t\t<ng-template #single>\r\n\t\t\t\t\t<div class=\"flex items-center justify-center font-weight-bold\">\r\n\t\t\t\t\t\t{{ 'UploaderBottomSheet.SingleUploadsComplete' | translate }}\r\n\t\t\t\t\t</div></ng-template\r\n\t\t\t\t>\r\n\t\t\t</ng-container>\r\n\t\t\t<ng-template #generalMsg>\r\n\t\t\t\t<div class=\"flex items-center justify-center font-weight-bold\">\r\n\t\t\t\t\t{{ 'UploaderBottomSheet.UploadingData' | translate }}\r\n\t\t\t\t</div>\r\n\t\t\t</ng-template>\r\n\r\n\t\t\t<div>\r\n\t\t\t\t<mat-icon\r\n\t\t\t\t\tclass=\"icon-size-3.5 mx-2\"\r\n\t\t\t\t\t[svgIcon]=\"'icons:plus'\"\r\n\t\t\t\t\t(click)=\"$event.stopPropagation(); fileInput.click()\"\r\n\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.CREATE' | translate }}\"\r\n\t\t\t\t>\r\n\t\t\t\t</mat-icon>\r\n\t\t\t\t<input type=\"file\" hidden #fileInput (change)=\"add($event)\" multiple />\r\n\r\n\t\t\t\t<mat-icon\r\n\t\t\t\t\tclass=\"icon-size-3.5 mx-2\"\r\n\t\t\t\t\t[svgIcon]=\"'icons:open-folder'\"\r\n\t\t\t\t\t(click)=\"$event.stopPropagation(); open()\"\r\n\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.ShowUploadedFiles' | translate }}\"\r\n\t\t\t\t>\r\n\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t<mat-icon\r\n\t\t\t\t\tclass=\"icon-size-3.5 mx-2\"\r\n\t\t\t\t\t[svgIcon]=\"'icons:expand'\"\r\n\t\t\t\t\t[ngClass]=\"{\r\n\t\t\t\t\t\tcontainerOpened: !expanded,\r\n\t\t\t\t\t\tcontainerClosed: expanded\r\n\t\t\t\t\t}\"\r\n\t\t\t\t\t(click)=\"$event.stopPropagation(); expanded = !expanded\"\r\n\t\t\t\t\tmatTooltip=\"{{ (expanded ? 'UploaderBottomSheet.MINIMIZED' : 'UploaderBottomSheet.MAXIMIZED') | translate }}\"\r\n\t\t\t\t>\r\n\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t<mat-icon\r\n\t\t\t\t\tclass=\"icon-size-3.5 close-sheet\"\r\n\t\t\t\t\t[svgIcon]=\"'icons:cancel-icon'\"\r\n\t\t\t\t\t(click)=\"$event.stopPropagation(); dismiss()\"\r\n\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.CLOSE' | translate }}\"\r\n\t\t\t\t>\r\n\t\t\t\t</mat-icon>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</mat-expansion-panel-header>\r\n\r\n\t<div>\r\n\t\t<div\r\n\t\t\tclass=\"file-item d-flex justify-content-between align-items-center py-2 px-5\"\r\n\t\t\t*ngFor=\"let fileInfo of uploaderBottomSheetService.filesInfo$ | async; trackBy: trackFile\"\r\n\t\t>\r\n\t\t\t<div class=\"d-flex align-items-center truncate\">\r\n\t\t\t\t<img src=\"{{ fileInfo.icon }}\" class=\"file-icon\" alt=\"{{ fileInfo.data.name }}\" />\r\n\t\t\t\t<span class=\"truncate file-name\">{{ fileInfo.data.name }}</span>\r\n\t\t\t</div>\r\n\t\t\t<div>\r\n\t\t\t\t<!-- only if user hover the row -->\r\n\t\t\t\t<span class=\"more-upload-actions align-items-center\">\r\n\t\t\t\t\t<!-- cancel if file : pending or uploading + hover -->\r\n\t\t\t\t\t<mat-icon\r\n\t\t\t\t\t\tclass=\"icon-size-3.5\"\r\n\t\t\t\t\t\t[svgIcon]=\"'icons:cancel-icon'\"\r\n\t\t\t\t\t\t(click)=\"$event.stopPropagation(); cancel(fileInfo)\"\r\n\t\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.CANCEL' | translate }}\"\r\n\t\t\t\t\t\t*ngIf=\"fileInfo.status == fileStatus.Pending || fileInfo.status == fileStatus.InProgress\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t\t<!-- retry if file : canceled or error + hover -->\r\n\t\t\t\t\t<mat-icon\r\n\t\t\t\t\t\tclass=\"icon-size-4.5\"\r\n\t\t\t\t\t\t[svgIcon]=\"'icons:retry'\"\r\n\t\t\t\t\t\t(click)=\"$event.stopPropagation(); retry(fileInfo)\"\r\n\t\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.RETRY' | translate }}\"\r\n\t\t\t\t\t\t*ngIf=\"fileInfo.status == fileStatus.Canceled || fileInfo.status == fileStatus.Error\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t\t<!-- open file : hover + completed -->\r\n\t\t\t\t\t<mat-icon\r\n\t\t\t\t\t\tclass=\"icon-size-4.5\"\r\n\t\t\t\t\t\t[svgIcon]=\"'icons:open-folder'\"\r\n\t\t\t\t\t\t(click)=\"$event.stopPropagation(); open(fileInfo)\"\r\n\t\t\t\t\t\tmatTooltip=\"{{ 'UploaderBottomSheet.OPEN' | translate }}\"\r\n\t\t\t\t\t\t*ngIf=\"fileInfo.status == fileStatus.Completed\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t</mat-icon>\r\n\t\t\t\t</span>\r\n\r\n\t\t\t\t<span class=\"base-upload-actions align-items-center\">\r\n\t\t\t\t\t<!-- file completed -->\r\n\t\t\t\t\t<mat-icon class=\"icon-size-4.5\" [svgIcon]=\"'icons:complete'\" *ngIf=\"fileInfo.status == fileStatus.Completed\">\r\n\t\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t\t<!-- file has error -->\r\n\t\t\t\t\t<mat-icon class=\"icon-size-4.5\" [svgIcon]=\"'icons:error'\" *ngIf=\"fileInfo.status == fileStatus.Error\">\r\n\t\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t\t<!-- user cancle the file -->\r\n\t\t\t\t\t<mat-icon class=\"icon-size-4.5\" [svgIcon]=\"'icons:error'\" *ngIf=\"fileInfo.status == fileStatus.Canceled\">\r\n\t\t\t\t\t</mat-icon>\r\n\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\tclass=\"spinner-container\"\r\n\t\t\t\t\t\t*ngIf=\"fileInfo.status == fileStatus.Pending || fileInfo.status == fileStatus.InProgress\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<mat-spinner [value]=\"fileInfo.progress\" diameter=\"20\" strokeWidth=\"2\" color=\"primary\"></mat-spinner>\r\n\t\t\t\t\t\t<div class=\"spinner-percentage\" *ngIf=\"fileInfo.status == fileStatus.InProgress\">\r\n\t\t\t\t\t\t\t{{ fileInfo.progress | number : '1.0-0' }}\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</span>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n</mat-expansion-panel>\r\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './bottom-sheet/ndf-uploader-bottom-sheet.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL25kZi11cGxvYWRlci9jb21wb25lbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0RBQW9ELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2JvdHRvbS1zaGVldC9uZGYtdXBsb2FkZXItYm90dG9tLXNoZWV0LmNvbXBvbmVudCc7XHJcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './uploader.config';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL25kZi11cGxvYWRlci9jb25maWcvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vdXBsb2FkZXIuY29uZmlnJztcclxuIl19
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export const UPLOADER_CONFIG = {
|
|
2
|
+
DEFAULT_PROVIDER: 'nuxeo',
|
|
3
|
+
MAX_CONCURRENT_REQUESTS: 5,
|
|
4
|
+
IS_CHUNKED_ENABLED: true,
|
|
5
|
+
MIN_File_SIZE: 1024 * 1024 * 5,
|
|
6
|
+
CHUNK_SIZE: 1024 * 1024 * 5,
|
|
7
|
+
DELAY_RETRY_ATTEMPTS: 500,
|
|
8
|
+
MAX_RETRY_ATTEMPTS: 3 // maximum number of retry attempts if an upload request fails
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsb2FkZXIuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9uZGYtdXBsb2FkZXIvY29uZmlnL3VwbG9hZGVyLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUc7SUFDOUIsZ0JBQWdCLEVBQUUsT0FBTztJQUN6Qix1QkFBdUIsRUFBRSxDQUFDO0lBQzFCLGtCQUFrQixFQUFFLElBQUk7SUFDeEIsYUFBYSxFQUFFLElBQUksR0FBRyxJQUFJLEdBQUcsQ0FBQztJQUM5QixVQUFVLEVBQUUsSUFBSSxHQUFHLElBQUksR0FBRyxDQUFDO0lBQzNCLG9CQUFvQixFQUFFLEdBQUc7SUFDekIsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDLDhEQUE4RDtDQUNwRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IFVQTE9BREVSX0NPTkZJRyA9IHtcclxuXHRERUZBVUxUX1BST1ZJREVSOiAnbnV4ZW8nLCAvLyBkZWZhdWx0IHVwbG9hZCBwcm92aWRlciBuYW1lXHJcblx0TUFYX0NPTkNVUlJFTlRfUkVRVUVTVFM6IDUsIC8vIG1heGltdW0gbnVtYmVyIG9mIGNvbmN1cnJlbnQgdXBsb2FkIHJlcXVlc3RzXHJcblx0SVNfQ0hVTktFRF9FTkFCTEVEOiB0cnVlLCAvLyB0b2dnbGUgdG8gZW5hYmxlIG9yIGRpc2FibGUgY2h1bmtlZCB1cGxvYWRzXHJcblx0TUlOX0ZpbGVfU0laRTogMTAyNCAqIDEwMjQgKiA1LCAvLyBtaW5pbXVtIGZpbGUgc2l6ZSAoaW4gYnl0ZXMpIGZvciBjaHVua2VkIHVwbG9hZCB0byBiZSBhcHBsaWVkXHJcblx0Q0hVTktfU0laRTogMTAyNCAqIDEwMjQgKiA1LCAvLyBzaXplIChpbiBieXRlcykgb2YgZWFjaCBjaHVuayBmb3IgY2h1bmtlZCB1cGxvYWRcclxuXHRERUxBWV9SRVRSWV9BVFRFTVBUUzogNTAwLCAvLyBkZWxheSAoaW4gbWlsbGlzZWNvbmRzKSBiZXR3ZWVuIHJldHJ5IGF0dGVtcHRzIGFmdGVyIGEgZmFpbHVyZVxyXG5cdE1BWF9SRVRSWV9BVFRFTVBUUzogMyAvLyBtYXhpbXVtIG51bWJlciBvZiByZXRyeSBhdHRlbXB0cyBpZiBhbiB1cGxvYWQgcmVxdWVzdCBmYWlsc1xyXG59O1xyXG4iXX0=
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export const FILE_CONTENT = {
|
|
2
|
+
CONTENT: 'file:content',
|
|
3
|
+
BATCH: 'upload-batch',
|
|
4
|
+
FILE_INDEX: 'upload-fileId'
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1jb250ZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9uZGYtdXBsb2FkZXIvY29uc3RhbnQvZmlsZS1jb250ZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRztJQUMzQixPQUFPLEVBQUUsY0FBYztJQUN2QixLQUFLLEVBQUUsY0FBYztJQUNyQixVQUFVLEVBQUUsZUFBZTtDQUMzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IEZJTEVfQ09OVEVOVCA9IHtcclxuXHRDT05URU5UOiAnZmlsZTpjb250ZW50JyxcclxuXHRCQVRDSDogJ3VwbG9hZC1iYXRjaCcsXHJcblx0RklMRV9JTkRFWDogJ3VwbG9hZC1maWxlSWQnXHJcbn07XHJcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './file-content';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL25kZi11cGxvYWRlci9jb25zdGFudC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9maWxlLWNvbnRlbnQnO1xyXG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './uploader.helper';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL25kZi11cGxvYWRlci9oZWxwZXJzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbUJBQW1CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3VwbG9hZGVyLmhlbHBlcic7XHJcbiJdfQ==
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
var _a, _UploaderHelper_prepareChunks;
|
|
2
|
+
import { __classPrivateFieldGet } from "tslib";
|
|
3
|
+
import { UPLOADER_CONFIG } from '../config';
|
|
4
|
+
import { FileStatus } from '../models';
|
|
5
|
+
import { FormioUtils } from 'angular-formio';
|
|
6
|
+
import { concatMap, retryWhen, delay, catchError } from 'rxjs/operators';
|
|
7
|
+
import { EMPTY, of, throwError } from 'rxjs';
|
|
8
|
+
import { EnvManager } from '../../../core/env';
|
|
9
|
+
export class UploaderHelper {
|
|
10
|
+
static catchError() {
|
|
11
|
+
return catchError((error) => {
|
|
12
|
+
if (error.status === 308 /* PermanentRedirect */) {
|
|
13
|
+
return of(error === null || error === void 0 ? void 0 : error.error);
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
return EMPTY;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
static retryWhen() {
|
|
21
|
+
return retryWhen((errors) => errors.pipe(concatMap((error, index) => {
|
|
22
|
+
if (index >= UPLOADER_CONFIG.MAX_RETRY_ATTEMPTS - 1) {
|
|
23
|
+
return throwError(() => new Error('Failed after retries'));
|
|
24
|
+
}
|
|
25
|
+
return of(error).pipe(delay(UPLOADER_CONFIG.DELAY_RETRY_ATTEMPTS));
|
|
26
|
+
})));
|
|
27
|
+
}
|
|
28
|
+
static createFileHeader(file, chunk) {
|
|
29
|
+
const headers = {
|
|
30
|
+
'Cache-Control': 'no-cache',
|
|
31
|
+
'X-File-Name': encodeURIComponent(file.data.name),
|
|
32
|
+
'X-File-Type': file.data.type,
|
|
33
|
+
'Content-Type': 'application/octet-stream',
|
|
34
|
+
'Content-Length': file.data.size,
|
|
35
|
+
'X-File-Size': file.data.size.toString()
|
|
36
|
+
};
|
|
37
|
+
if (file.chunks.length > 1) {
|
|
38
|
+
Object.assign(headers, {
|
|
39
|
+
'X-Upload-Type': 'chunked',
|
|
40
|
+
'X-Upload-Chunk-Index': file.chunks.findIndex((c) => c.index == chunk.index).toString(),
|
|
41
|
+
'X-Upload-Chunk-Count': file.chunks.length.toString(),
|
|
42
|
+
'Content-Length': chunk.blob.size
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
return headers;
|
|
46
|
+
}
|
|
47
|
+
static prepareConfig() {
|
|
48
|
+
var _b, _c, _d, _e, _f, _g, _h;
|
|
49
|
+
UPLOADER_CONFIG.DEFAULT_PROVIDER =
|
|
50
|
+
((_b = EnvManager.environment.uploader) === null || _b === void 0 ? void 0 : _b.defaultUploader) || UPLOADER_CONFIG.DEFAULT_PROVIDER;
|
|
51
|
+
UPLOADER_CONFIG.MAX_CONCURRENT_REQUESTS =
|
|
52
|
+
((_c = EnvManager.environment.uploader) === null || _c === void 0 ? void 0 : _c.maxConcurrentRequests) || UPLOADER_CONFIG.MAX_CONCURRENT_REQUESTS;
|
|
53
|
+
UPLOADER_CONFIG.IS_CHUNKED_ENABLED = ((_d = EnvManager.environment.uploader) === null || _d === void 0 ? void 0 : _d.isChunkedEnabled) == 'YES';
|
|
54
|
+
UPLOADER_CONFIG.MIN_File_SIZE = ((_e = EnvManager.environment.uploader) === null || _e === void 0 ? void 0 : _e.minFileSize) || UPLOADER_CONFIG.MIN_File_SIZE;
|
|
55
|
+
UPLOADER_CONFIG.CHUNK_SIZE = ((_f = EnvManager.environment.uploader) === null || _f === void 0 ? void 0 : _f.chunkSize) || UPLOADER_CONFIG.CHUNK_SIZE;
|
|
56
|
+
UPLOADER_CONFIG.DELAY_RETRY_ATTEMPTS =
|
|
57
|
+
((_g = EnvManager.environment.uploader) === null || _g === void 0 ? void 0 : _g.delayRetryAttempts) || UPLOADER_CONFIG.DELAY_RETRY_ATTEMPTS;
|
|
58
|
+
UPLOADER_CONFIG.MAX_RETRY_ATTEMPTS =
|
|
59
|
+
((_h = EnvManager.environment.uploader) === null || _h === void 0 ? void 0 : _h.maxRetryAttempts) || UPLOADER_CONFIG.MAX_RETRY_ATTEMPTS;
|
|
60
|
+
}
|
|
61
|
+
static prepareFiles(options, startFromIndex = 0) {
|
|
62
|
+
const batchsFile = options.files.map((file, index) => {
|
|
63
|
+
const id = FormioUtils.guid();
|
|
64
|
+
const batchFile = {
|
|
65
|
+
id,
|
|
66
|
+
index: startFromIndex + index,
|
|
67
|
+
data: file,
|
|
68
|
+
progress: 0,
|
|
69
|
+
status: FileStatus.Pending,
|
|
70
|
+
provider: (options.provider || UPLOADER_CONFIG.DEFAULT_PROVIDER),
|
|
71
|
+
chunks: __classPrivateFieldGet(this, _a, "m", _UploaderHelper_prepareChunks).call(this, id, file),
|
|
72
|
+
metadata: options.metadata
|
|
73
|
+
};
|
|
74
|
+
return batchFile;
|
|
75
|
+
});
|
|
76
|
+
return batchsFile;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
_a = UploaderHelper, _UploaderHelper_prepareChunks = function _UploaderHelper_prepareChunks(fileId, file) {
|
|
80
|
+
const { CHUNK_SIZE, MIN_File_SIZE } = UPLOADER_CONFIG;
|
|
81
|
+
if (file.size <= MIN_File_SIZE) {
|
|
82
|
+
return [
|
|
83
|
+
{
|
|
84
|
+
fileId,
|
|
85
|
+
index: 0,
|
|
86
|
+
start: 0,
|
|
87
|
+
end: file.size,
|
|
88
|
+
status: FileStatus.Pending
|
|
89
|
+
}
|
|
90
|
+
];
|
|
91
|
+
}
|
|
92
|
+
return Array.from({ length: Math.ceil(file.size / CHUNK_SIZE) }, (_, index) => ({
|
|
93
|
+
fileId,
|
|
94
|
+
index,
|
|
95
|
+
start: index * CHUNK_SIZE,
|
|
96
|
+
end: Math.min((index + 1) * CHUNK_SIZE, file.size),
|
|
97
|
+
status: FileStatus.Pending
|
|
98
|
+
}));
|
|
99
|
+
};
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uploader.helper.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/ndf-uploader/helpers/uploader.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { UPLOADER_CONFIG } from '../config';\r\nimport { BatchFile, Chunk, FileHeaders, FileOption, FileStatus, UploadProvider } from '../models';\r\nimport { FormioUtils } from 'angular-formio';\r\nimport { concatMap, retryWhen, delay, catchError } from 'rxjs/operators';\r\nimport { EMPTY, MonoTypeOperatorFunction, of, OperatorFunction, throwError } from 'rxjs';\r\nimport { HttpStatusCode } from '@angular/common/http';\r\nimport { EnvManager } from '../../../core/env';\r\n\r\nexport class UploaderHelper {\r\n\tstatic catchError<T>(): OperatorFunction<T, any> {\r\n\t\treturn catchError((error) => {\r\n\t\t\tif (error.status === HttpStatusCode.PermanentRedirect) {\r\n\t\t\t\treturn of(error?.error);\r\n\t\t\t} else {\r\n\t\t\t\treturn EMPTY;\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\tstatic retryWhen<T>(): MonoTypeOperatorFunction<T> {\r\n\t\treturn retryWhen((errors) =>\r\n\t\t\terrors.pipe(\r\n\t\t\t\tconcatMap((error, index) => {\r\n\t\t\t\t\tif (index >= UPLOADER_CONFIG.MAX_RETRY_ATTEMPTS - 1) {\r\n\t\t\t\t\t\treturn throwError(() => new Error('Failed after retries'));\r\n\t\t\t\t\t}\r\n\t\t\t\t\treturn of(error).pipe(delay(UPLOADER_CONFIG.DELAY_RETRY_ATTEMPTS));\r\n\t\t\t\t})\r\n\t\t\t)\r\n\t\t);\r\n\t}\r\n\tstatic createFileHeader(file: BatchFile, chunk: Chunk): FileHeaders {\r\n\t\tconst headers: FileHeaders = {\r\n\t\t\t'Cache-Control': 'no-cache',\r\n\t\t\t'X-File-Name': encodeURIComponent(file.data.name),\r\n\t\t\t'X-File-Type': file.data.type,\r\n\t\t\t'Content-Type': 'application/octet-stream',\r\n\t\t\t'Content-Length': file.data.size,\r\n\t\t\t'X-File-Size': file.data.size.toString()\r\n\t\t};\r\n\t\tif (file.chunks.length > 1) {\r\n\t\t\tObject.assign(headers, {\r\n\t\t\t\t'X-Upload-Type': 'chunked',\r\n\t\t\t\t'X-Upload-Chunk-Index': file.chunks.findIndex((c) => c.index == chunk.index).toString(),\r\n\t\t\t\t'X-Upload-Chunk-Count': file.chunks.length.toString(),\r\n\t\t\t\t'Content-Length': chunk.blob.size\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn headers;\r\n\t}\r\n\tstatic prepareConfig() {\r\n\t\tUPLOADER_CONFIG.DEFAULT_PROVIDER =\r\n\t\t\tEnvManager.environment.uploader?.defaultUploader || UPLOADER_CONFIG.DEFAULT_PROVIDER;\r\n\t\tUPLOADER_CONFIG.MAX_CONCURRENT_REQUESTS =\r\n\t\t\tEnvManager.environment.uploader?.maxConcurrentRequests || UPLOADER_CONFIG.MAX_CONCURRENT_REQUESTS;\r\n\t\tUPLOADER_CONFIG.IS_CHUNKED_ENABLED = EnvManager.environment.uploader?.isChunkedEnabled == 'YES';\r\n\t\tUPLOADER_CONFIG.MIN_File_SIZE = EnvManager.environment.uploader?.minFileSize || UPLOADER_CONFIG.MIN_File_SIZE;\r\n\t\tUPLOADER_CONFIG.CHUNK_SIZE = EnvManager.environment.uploader?.chunkSize || UPLOADER_CONFIG.CHUNK_SIZE;\r\n\t\tUPLOADER_CONFIG.DELAY_RETRY_ATTEMPTS =\r\n\t\t\tEnvManager.environment.uploader?.delayRetryAttempts || UPLOADER_CONFIG.DELAY_RETRY_ATTEMPTS;\r\n\t\tUPLOADER_CONFIG.MAX_RETRY_ATTEMPTS =\r\n\t\t\tEnvManager.environment.uploader?.maxRetryAttempts || UPLOADER_CONFIG.MAX_RETRY_ATTEMPTS;\r\n\t}\r\n\tstatic prepareFiles(options: FileOption, startFromIndex: number = 0) {\r\n\t\tconst batchsFile = options.files.map((file, index) => {\r\n\t\t\tconst id = FormioUtils.guid();\r\n\t\t\tconst batchFile: BatchFile = {\r\n\t\t\t\tid,\r\n\t\t\t\tindex: startFromIndex + index,\r\n\t\t\t\tdata: file,\r\n\t\t\t\tprogress: 0,\r\n\t\t\t\tstatus: FileStatus.Pending,\r\n\t\t\t\tprovider: (options.provider || UPLOADER_CONFIG.DEFAULT_PROVIDER) as UploadProvider,\r\n\t\t\t\tchunks: this.#prepareChunks(id, file),\r\n\t\t\t\tmetadata: options.metadata\r\n\t\t\t};\r\n\r\n\t\t\treturn batchFile;\r\n\t\t});\r\n\t\treturn batchsFile;\r\n\t}\r\n\tstatic #prepareChunks(fileId: string, file: File): Array<Chunk> {\r\n\t\tconst { CHUNK_SIZE, MIN_File_SIZE } = UPLOADER_CONFIG;\r\n\t\tif (file.size <= MIN_File_SIZE) {\r\n\t\t\treturn [\r\n\t\t\t\t{\r\n\t\t\t\t\tfileId,\r\n\t\t\t\t\tindex: 0,\r\n\t\t\t\t\tstart: 0,\r\n\t\t\t\t\tend: file.size,\r\n\t\t\t\t\tstatus: FileStatus.Pending\r\n\t\t\t\t}\r\n\t\t\t];\r\n\t\t}\r\n\r\n\t\treturn Array.from({ length: Math.ceil(file.size / CHUNK_SIZE) }, (_, index) => ({\r\n\t\t\tfileId,\r\n\t\t\tindex,\r\n\t\t\tstart: index * CHUNK_SIZE,\r\n\t\t\tend: Math.min((index + 1) * CHUNK_SIZE, file.size),\r\n\t\t\tstatus: FileStatus.Pending\r\n\t\t}));\r\n\t}\r\n}\r\n"]}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export * from './ndf-uploader.service';
|
|
2
|
+
export * from './ndf-uploader-bottom-sheet.service';
|
|
3
|
+
export * from './models/index';
|
|
4
|
+
export * from './constant/index';
|
|
5
|
+
export * from './ndf-uploader.module';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL25kZi11cGxvYWRlci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL25kZi11cGxvYWRlci5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9uZGYtdXBsb2FkZXItYm90dG9tLXNoZWV0LnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL21vZGVscy9pbmRleCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29uc3RhbnQvaW5kZXgnO1xyXG5leHBvcnQgKiBmcm9tICcuL25kZi11cGxvYWRlci5tb2R1bGUnO1xyXG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmF0Y2gubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL25kZi11cGxvYWRlci9tb2RlbHMvYmF0Y2gubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVwbG9hZFByb3ZpZGVyIH0gZnJvbSAnLi9uZGYtZmlsZS5tb2RlbCc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEJhdGNoIHtcclxuXHRiYXRjaElkOiBzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRmlsZU9wdGlvbiB7XHJcblx0ZmlsZXM6IEZpbGVbXTtcclxuXHRwcm92aWRlcj86IFVwbG9hZFByb3ZpZGVyO1xyXG5cdG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55PjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBVcGxvYWRlUmVzcG9uc2Uge1xyXG5cdGJhdGNoSWQ6IHN0cmluZztcclxuXHRmaWxlSWR4OiBzdHJpbmc7XHJcblx0dXBsb2FkVHlwZTogc3RyaW5nO1xyXG5cdHVwbG9hZGVkU2l6ZTogbnVtYmVyO1xyXG5cdHVwbG9hZGVkQ2h1bmtJZHM6IG51bWJlcltdO1xyXG5cdGNodW5rQ291bnQ6IG51bWJlcjtcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgRmlsZUhlYWRlcnMgPSB7XHJcblx0J0NhY2hlLUNvbnRyb2wnOiAnbm8tY2FjaGUnO1xyXG5cdCdYLUZpbGUtTmFtZSc6IHN0cmluZztcclxuXHQnWC1GaWxlLVR5cGUnOiBzdHJpbmc7XHJcblx0J0NvbnRlbnQtVHlwZSc6IHN0cmluZztcclxuXHQnQ29udGVudC1MZW5ndGgnOiBudW1iZXI7XHJcblx0J1gtVXBsb2FkLVR5cGUnPzogJ2NodW5rZWQnO1xyXG5cdCdYLVVwbG9hZC1DaHVuay1JbmRleCc/OiBzdHJpbmc7XHJcblx0J1gtVXBsb2FkLUNodW5rLUNvdW50Jz86IHN0cmluZztcclxuXHQnWC1GaWxlLVNpemUnPzogc3RyaW5nO1xyXG59O1xyXG4iXX0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './ndf-file.model';
|
|
2
|
+
export * from './provider.model';
|
|
3
|
+
export * from './batch.model';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL25kZi11cGxvYWRlci9tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9uZGYtZmlsZS5tb2RlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcHJvdmlkZXIubW9kZWwnO1xyXG5leHBvcnQgKiBmcm9tICcuL2JhdGNoLm1vZGVsJztcclxuIl19
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export var FileStatus;
|
|
2
|
+
(function (FileStatus) {
|
|
3
|
+
FileStatus[FileStatus["Pending"] = 0] = "Pending";
|
|
4
|
+
FileStatus[FileStatus["InProgress"] = 1] = "InProgress";
|
|
5
|
+
FileStatus[FileStatus["Canceled"] = 2] = "Canceled";
|
|
6
|
+
FileStatus[FileStatus["Error"] = 3] = "Error";
|
|
7
|
+
FileStatus[FileStatus["Completed"] = 4] = "Completed";
|
|
8
|
+
})(FileStatus || (FileStatus = {}));
|
|
9
|
+
export var UploadProvider;
|
|
10
|
+
(function (UploadProvider) {
|
|
11
|
+
UploadProvider["Nuxeo"] = "nuxeo";
|
|
12
|
+
UploadProvider["S3"] = "s3";
|
|
13
|
+
})(UploadProvider || (UploadProvider = {}));
|
|
14
|
+
export var FileEventType;
|
|
15
|
+
(function (FileEventType) {
|
|
16
|
+
FileEventType[FileEventType["Changes"] = 0] = "Changes";
|
|
17
|
+
FileEventType[FileEventType["Complete"] = 1] = "Complete";
|
|
18
|
+
FileEventType[FileEventType["Reset"] = 2] = "Reset";
|
|
19
|
+
})(FileEventType || (FileEventType = {}));
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmRmLWZpbGUubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL25kZi11cGxvYWRlci9tb2RlbHMvbmRmLWZpbGUubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksVUFNWDtBQU5ELFdBQVksVUFBVTtJQUNyQixpREFBTyxDQUFBO0lBQ1AsdURBQVUsQ0FBQTtJQUNWLG1EQUFRLENBQUE7SUFDUiw2Q0FBSyxDQUFBO0lBQ0wscURBQVMsQ0FBQTtBQUNWLENBQUMsRUFOVyxVQUFVLEtBQVYsVUFBVSxRQU1yQjtBQUNELE1BQU0sQ0FBTixJQUFZLGNBR1g7QUFIRCxXQUFZLGNBQWM7SUFDekIsaUNBQWUsQ0FBQTtJQUNmLDJCQUFTLENBQUE7QUFDVixDQUFDLEVBSFcsY0FBYyxLQUFkLGNBQWMsUUFHekI7QUFpQ0QsTUFBTSxDQUFOLElBQVksYUFJWDtBQUpELFdBQVksYUFBYTtJQUN4Qix1REFBTyxDQUFBO0lBQ1AseURBQVEsQ0FBQTtJQUNSLG1EQUFLLENBQUE7QUFDTixDQUFDLEVBSlcsYUFBYSxLQUFiLGFBQWEsUUFJeEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBGaWxlU3RhdHVzIHtcclxuXHRQZW5kaW5nLFxyXG5cdEluUHJvZ3Jlc3MsXHJcblx0Q2FuY2VsZWQsXHJcblx0RXJyb3IsXHJcblx0Q29tcGxldGVkXHJcbn1cclxuZXhwb3J0IGVudW0gVXBsb2FkUHJvdmlkZXIge1xyXG5cdE51eGVvID0gJ251eGVvJyxcclxuXHRTMyA9ICdzMydcclxufVxyXG5leHBvcnQgaW50ZXJmYWNlIEJhc2VGaWxlSW5mbyB7XHJcblx0YmF0Y2hJZD86IHN0cmluZztcclxuXHRpZDogc3RyaW5nO1xyXG5cdGluZGV4OiBudW1iZXI7XHJcblx0ZGF0YTogRmlsZTtcclxuXHRzdGF0dXM6IEZpbGVTdGF0dXM7XHJcblx0cHJvZ3Jlc3M6IG51bWJlcjtcclxuXHRwcm92aWRlcjogVXBsb2FkUHJvdmlkZXI7XHJcblx0bWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgRmlsZUluZm8gZXh0ZW5kcyBCYXNlRmlsZUluZm8ge1xyXG5cdGljb246IHN0cmluZztcclxuXHRkb2N1bWVudElkPzogc3RyaW5nO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgQmF0Y2hGaWxlIGV4dGVuZHMgQmFzZUZpbGVJbmZvIHtcclxuXHRjaHVua3M6IEFycmF5PENodW5rPjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDaHVuayB7XHJcblx0YmF0Y2hJZD86IHN0cmluZztcclxuXHRmaWxlSWQ6IHN0cmluZztcclxuXHRpbmRleDogbnVtYmVyO1xyXG5cdHN0YXJ0OiBudW1iZXI7XHJcblx0ZW5kOiBudW1iZXI7XHJcblx0YmxvYj86IEJsb2I7XHJcblx0c3RhdHVzOiBGaWxlU3RhdHVzO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEZpbGVFdmVudCB7XHJcblx0dHlwZTogRmlsZUV2ZW50VHlwZTtcclxuXHRkYXRhOiBGaWxlSW5mb1tdO1xyXG59XHJcbmV4cG9ydCBlbnVtIEZpbGVFdmVudFR5cGUge1xyXG5cdENoYW5nZXMsXHJcblx0Q29tcGxldGUsXHJcblx0UmVzZXRcclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL25kZi11cGxvYWRlci9tb2RlbHMvcHJvdmlkZXIubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQmF0Y2hGaWxlLCBDaHVuayB9IGZyb20gJy4vbmRmLWZpbGUubW9kZWwnO1xyXG5pbXBvcnQgeyBVcGxvYWRlUmVzcG9uc2UgfSBmcm9tICcuL2JhdGNoLm1vZGVsJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgUHJvdmlkZXIge1xyXG5cdHVwbG9hZChmaWxlOiBCYXRjaEZpbGUsIGNodW5rOiBDaHVuayk6IE9ic2VydmFibGU8VXBsb2FkZVJlc3BvbnNlPjtcclxuXHRjb21wbGV0ZShmaWxlOiBCYXRjaEZpbGUpOiBPYnNlcnZhYmxlPFJlY29yZDxzdHJpbmcsIGFueT4+O1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
var _NdfUploaderBottomSheetService_instances, _NdfUploaderBottomSheetService_events, _NdfUploaderBottomSheetService_isBottomSheetOpen_get;
|
|
2
|
+
import { __classPrivateFieldGet } from "tslib";
|
|
3
|
+
import { Injectable } from '@angular/core';
|
|
4
|
+
import { BehaviorSubject, Subject } from 'rxjs';
|
|
5
|
+
import { NdfUploaderBottomSheetComponent } from './components';
|
|
6
|
+
import { tap } from 'rxjs/operators';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/material/bottom-sheet";
|
|
9
|
+
import * as i2 from "./ndf-uploader.service";
|
|
10
|
+
import * as i3 from "@ngx-translate/core";
|
|
11
|
+
const CUSTOM_PANEL_CLASS = 'upload-bottom-sheet';
|
|
12
|
+
export var NdfUploaderSheetEventType;
|
|
13
|
+
(function (NdfUploaderSheetEventType) {
|
|
14
|
+
NdfUploaderSheetEventType["Open"] = "Open";
|
|
15
|
+
NdfUploaderSheetEventType["Submit"] = "Submit";
|
|
16
|
+
})(NdfUploaderSheetEventType || (NdfUploaderSheetEventType = {}));
|
|
17
|
+
export class NdfUploaderBottomSheetService {
|
|
18
|
+
constructor(bottomSheetService, uploaderService, translateService) {
|
|
19
|
+
this.bottomSheetService = bottomSheetService;
|
|
20
|
+
this.uploaderService = uploaderService;
|
|
21
|
+
this.translateService = translateService;
|
|
22
|
+
_NdfUploaderBottomSheetService_instances.add(this);
|
|
23
|
+
this.filesInfo$ = new BehaviorSubject([]);
|
|
24
|
+
_NdfUploaderBottomSheetService_events.set(this, new Subject());
|
|
25
|
+
this.events$ = __classPrivateFieldGet(this, _NdfUploaderBottomSheetService_events, "f").asObservable();
|
|
26
|
+
}
|
|
27
|
+
open(files) {
|
|
28
|
+
if (__classPrivateFieldGet(this, _NdfUploaderBottomSheetService_instances, "a", _NdfUploaderBottomSheetService_isBottomSheetOpen_get)) {
|
|
29
|
+
this.uploaderService.upload(files);
|
|
30
|
+
return this.events$;
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
this.bottomSheetService.open(NdfUploaderBottomSheetComponent, {
|
|
34
|
+
panelClass: CUSTOM_PANEL_CLASS,
|
|
35
|
+
direction: this.translateService.currentLang == 'ar' ? 'rtl' : 'ltr',
|
|
36
|
+
disableClose: true,
|
|
37
|
+
hasBackdrop: false,
|
|
38
|
+
data: files
|
|
39
|
+
});
|
|
40
|
+
return this.events$;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
close() {
|
|
44
|
+
if (!__classPrivateFieldGet(this, _NdfUploaderBottomSheetService_instances, "a", _NdfUploaderBottomSheetService_isBottomSheetOpen_get))
|
|
45
|
+
return;
|
|
46
|
+
this.uploaderService.reset();
|
|
47
|
+
this.bottomSheetService.dismiss();
|
|
48
|
+
}
|
|
49
|
+
notify(event) {
|
|
50
|
+
__classPrivateFieldGet(this, _NdfUploaderBottomSheetService_events, "f").next(event);
|
|
51
|
+
}
|
|
52
|
+
submit(batchId, options) {
|
|
53
|
+
return this.uploaderService.submit(options).pipe(tap((data) => {
|
|
54
|
+
var _a;
|
|
55
|
+
const files = this.filesInfo$.getValue();
|
|
56
|
+
files.find((f) => f.batchId == batchId).documentId = (_a = data.entries[0]) === null || _a === void 0 ? void 0 : _a.uid;
|
|
57
|
+
this.filesInfo$.next(files);
|
|
58
|
+
}));
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
_NdfUploaderBottomSheetService_events = new WeakMap(), _NdfUploaderBottomSheetService_instances = new WeakSet(), _NdfUploaderBottomSheetService_isBottomSheetOpen_get = function _NdfUploaderBottomSheetService_isBottomSheetOpen_get() {
|
|
62
|
+
return this.bottomSheetService._openedBottomSheetRef !== null;
|
|
63
|
+
};
|
|
64
|
+
NdfUploaderBottomSheetService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfUploaderBottomSheetService, deps: [{ token: i1.MatBottomSheet }, { token: i2.NdfUploaderService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
65
|
+
NdfUploaderBottomSheetService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfUploaderBottomSheetService, providedIn: 'root' });
|
|
66
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfUploaderBottomSheetService, decorators: [{
|
|
67
|
+
type: Injectable,
|
|
68
|
+
args: [{
|
|
69
|
+
providedIn: 'root'
|
|
70
|
+
}]
|
|
71
|
+
}], ctorParameters: function () { return [{ type: i1.MatBottomSheet }, { type: i2.NdfUploaderService }, { type: i3.TranslateService }]; } });
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmRmLXVwbG9hZGVyLWJvdHRvbS1zaGVldC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9uZGYtdXBsb2FkZXIvbmRmLXVwbG9hZGVyLWJvdHRvbS1zaGVldC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUczQyxPQUFPLEVBQUUsZUFBZSxFQUFjLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUc1RCxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFL0QsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7OztBQUVyQyxNQUFNLGtCQUFrQixHQUFHLHFCQUFxQixDQUFDO0FBQ2pELE1BQU0sQ0FBTixJQUFZLHlCQUdYO0FBSEQsV0FBWSx5QkFBeUI7SUFDcEMsMENBQWEsQ0FBQTtJQUNiLDhDQUFpQixDQUFBO0FBQ2xCLENBQUMsRUFIVyx5QkFBeUIsS0FBekIseUJBQXlCLFFBR3BDO0FBU0QsTUFBTSxPQUFPLDZCQUE2QjtJQVV6QyxZQUNrQixrQkFBa0MsRUFDbEMsZUFBbUMsRUFDbkMsZ0JBQWtDO1FBRmxDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBZ0I7UUFDbEMsb0JBQWUsR0FBZixlQUFlLENBQW9CO1FBQ25DLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7O1FBWnBELGVBQVUsR0FBRyxJQUFJLGVBQWUsQ0FBYSxFQUFFLENBQUMsQ0FBQztRQUVqRCxnREFBbUIsSUFBSSxPQUFPLEVBQXlCLEVBQUM7UUFDeEQsWUFBTyxHQUFHLHVCQUFBLElBQUksNkNBQVEsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQVVuQyxDQUFDO0lBRUosSUFBSSxDQUFDLEtBQWtCO1FBQ3RCLElBQUksdUJBQUEsSUFBSSxzR0FBbUIsRUFBRTtZQUM1QixJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNuQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7U0FDcEI7YUFBTTtZQUNOLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsK0JBQStCLEVBQUU7Z0JBQzdELFVBQVUsRUFBRSxrQkFBa0I7Z0JBQzlCLFNBQVMsRUFBRSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLO2dCQUNwRSxZQUFZLEVBQUUsSUFBSTtnQkFDbEIsV0FBVyxFQUFFLEtBQUs7Z0JBQ2xCLElBQUksRUFBRSxLQUFLO2FBQ1gsQ0FBQyxDQUFDO1lBQ0gsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO1NBQ3BCO0lBQ0YsQ0FBQztJQUVELEtBQUs7UUFDSixJQUFJLENBQUMsdUJBQUEsSUFBSSxzR0FBbUI7WUFBRSxPQUFPO1FBQ3JDLElBQUksQ0FBQyxlQUFlLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDN0IsSUFBSSxDQUFDLGtCQUFrQixDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ25DLENBQUM7SUFFRCxNQUFNLENBQUMsS0FBNEI7UUFDbEMsdUJBQUEsSUFBSSw2Q0FBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBRUQsTUFBTSxDQUFDLE9BQWUsRUFBRSxPQUF5QjtRQUNoRCxPQUFPLElBQUksQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FDL0MsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7O1lBQ1osTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUN6QyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLFVBQVUsR0FBRyxNQUFBLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLDBDQUFFLEdBQUcsQ0FBQztZQUMxRSxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3QixDQUFDLENBQUMsQ0FDRixDQUFDO0lBQ0gsQ0FBQzs7O0lBM0NBLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLHFCQUFxQixLQUFLLElBQUksQ0FBQztBQUMvRCxDQUFDOzJIQVJXLDZCQUE2QjsrSEFBN0IsNkJBQTZCLGNBRjdCLE1BQU07NEZBRU4sNkJBQTZCO2tCQUh6QyxVQUFVO21CQUFDO29CQUNYLFVBQVUsRUFBRSxNQUFNO2lCQUNsQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWF0Qm90dG9tU2hlZXQgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9ib3R0b20tc2hlZXQnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBOZGZVcGxvYWRlclNlcnZpY2UgfSBmcm9tICcuL25kZi11cGxvYWRlci5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRmlsZUluZm8gfSBmcm9tICcuL21vZGVscyc7XHJcbmltcG9ydCB7IE5kZlVwbG9hZGVyQm90dG9tU2hlZXRDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBPcGVyYXRpb25PcHRpb25zIH0gZnJvbSAnLi4vLi4vc2hhcmVkJztcclxuaW1wb3J0IHsgdGFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5cclxuY29uc3QgQ1VTVE9NX1BBTkVMX0NMQVNTID0gJ3VwbG9hZC1ib3R0b20tc2hlZXQnO1xyXG5leHBvcnQgZW51bSBOZGZVcGxvYWRlclNoZWV0RXZlbnRUeXBlIHtcclxuXHRPcGVuID0gJ09wZW4nLFxyXG5cdFN1Ym1pdCA9ICdTdWJtaXQnXHJcbn1cclxuZXhwb3J0IGludGVyZmFjZSBOZGZVcGxvYWRlclNoZWV0RXZlbnQge1xyXG5cdHR5cGU6IE5kZlVwbG9hZGVyU2hlZXRFdmVudFR5cGU7XHJcblx0ZGF0YT86IEZpbGVJbmZvIHwgQXJyYXk8c3RyaW5nPjtcclxufVxyXG5cclxuQEluamVjdGFibGUoe1xyXG5cdHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgTmRmVXBsb2FkZXJCb3R0b21TaGVldFNlcnZpY2Uge1xyXG5cdGZpbGVzSW5mbyQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PEZpbGVJbmZvW10+KFtdKTtcclxuXHJcblx0cmVhZG9ubHkgI2V2ZW50cyA9IG5ldyBTdWJqZWN0PE5kZlVwbG9hZGVyU2hlZXRFdmVudD4oKTtcclxuXHRldmVudHMkID0gdGhpcy4jZXZlbnRzLmFzT2JzZXJ2YWJsZSgpO1xyXG5cclxuXHRnZXQgI2lzQm90dG9tU2hlZXRPcGVuKCk6IGJvb2xlYW4ge1xyXG5cdFx0cmV0dXJuIHRoaXMuYm90dG9tU2hlZXRTZXJ2aWNlLl9vcGVuZWRCb3R0b21TaGVldFJlZiAhPT0gbnVsbDtcclxuXHR9XHJcblxyXG5cdGNvbnN0cnVjdG9yKFxyXG5cdFx0cHJpdmF0ZSByZWFkb25seSBib3R0b21TaGVldFNlcnZpY2U6IE1hdEJvdHRvbVNoZWV0LFxyXG5cdFx0cHJpdmF0ZSByZWFkb25seSB1cGxvYWRlclNlcnZpY2U6IE5kZlVwbG9hZGVyU2VydmljZSxcclxuXHRcdHByaXZhdGUgcmVhZG9ubHkgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZVxyXG5cdCkge31cclxuXHJcblx0b3BlbihmaWxlczogQXJyYXk8RmlsZT4pOiBPYnNlcnZhYmxlPE5kZlVwbG9hZGVyU2hlZXRFdmVudD4ge1xyXG5cdFx0aWYgKHRoaXMuI2lzQm90dG9tU2hlZXRPcGVuKSB7XHJcblx0XHRcdHRoaXMudXBsb2FkZXJTZXJ2aWNlLnVwbG9hZChmaWxlcyk7XHJcblx0XHRcdHJldHVybiB0aGlzLmV2ZW50cyQ7XHJcblx0XHR9IGVsc2Uge1xyXG5cdFx0XHR0aGlzLmJvdHRvbVNoZWV0U2VydmljZS5vcGVuKE5kZlVwbG9hZGVyQm90dG9tU2hlZXRDb21wb25lbnQsIHtcclxuXHRcdFx0XHRwYW5lbENsYXNzOiBDVVNUT01fUEFORUxfQ0xBU1MsXHJcblx0XHRcdFx0ZGlyZWN0aW9uOiB0aGlzLnRyYW5zbGF0ZVNlcnZpY2UuY3VycmVudExhbmcgPT0gJ2FyJyA/ICdydGwnIDogJ2x0cicsXHJcblx0XHRcdFx0ZGlzYWJsZUNsb3NlOiB0cnVlLFxyXG5cdFx0XHRcdGhhc0JhY2tkcm9wOiBmYWxzZSxcclxuXHRcdFx0XHRkYXRhOiBmaWxlc1xyXG5cdFx0XHR9KTtcclxuXHRcdFx0cmV0dXJuIHRoaXMuZXZlbnRzJDtcclxuXHRcdH1cclxuXHR9XHJcblxyXG5cdGNsb3NlKCk6IHZvaWQge1xyXG5cdFx0aWYgKCF0aGlzLiNpc0JvdHRvbVNoZWV0T3BlbikgcmV0dXJuO1xyXG5cdFx0dGhpcy51cGxvYWRlclNlcnZpY2UucmVzZXQoKTtcclxuXHRcdHRoaXMuYm90dG9tU2hlZXRTZXJ2aWNlLmRpc21pc3MoKTtcclxuXHR9XHJcblxyXG5cdG5vdGlmeShldmVudDogTmRmVXBsb2FkZXJTaGVldEV2ZW50KTogdm9pZCB7XHJcblx0XHR0aGlzLiNldmVudHMubmV4dChldmVudCk7XHJcblx0fVxyXG5cclxuXHRzdWJtaXQoYmF0Y2hJZDogc3RyaW5nLCBvcHRpb25zOiBPcGVyYXRpb25PcHRpb25zKSB7XHJcblx0XHRyZXR1cm4gdGhpcy51cGxvYWRlclNlcnZpY2Uuc3VibWl0KG9wdGlvbnMpLnBpcGUoXHJcblx0XHRcdHRhcCgoZGF0YSkgPT4ge1xyXG5cdFx0XHRcdGNvbnN0IGZpbGVzID0gdGhpcy5maWxlc0luZm8kLmdldFZhbHVlKCk7XHJcblx0XHRcdFx0ZmlsZXMuZmluZCgoZikgPT4gZi5iYXRjaElkID09IGJhdGNoSWQpLmRvY3VtZW50SWQgPSBkYXRhLmVudHJpZXNbMF0/LnVpZDtcclxuXHRcdFx0XHR0aGlzLmZpbGVzSW5mbyQubmV4dChmaWxlcyk7XHJcblx0XHRcdH0pXHJcblx0XHQpO1xyXG5cdH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
4
|
+
import { MatBottomSheetModule } from '@angular/material/bottom-sheet';
|
|
5
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
6
|
+
import { MatExpansionModule } from '@angular/material/expansion';
|
|
7
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
8
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
9
|
+
import { MatDialogModule } from '@angular/material/dialog';
|
|
10
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
11
|
+
import { NdfUploaderBottomSheetComponent } from './components/bottom-sheet/ndf-uploader-bottom-sheet.component';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
export class NdfUploaderModule {
|
|
14
|
+
}
|
|
15
|
+
NdfUploaderModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfUploaderModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
16
|
+
NdfUploaderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfUploaderModule, declarations: [NdfUploaderBottomSheetComponent], imports: [CommonModule,
|
|
17
|
+
TranslateModule,
|
|
18
|
+
MatDialogModule,
|
|
19
|
+
MatIconModule,
|
|
20
|
+
MatButtonModule,
|
|
21
|
+
MatBottomSheetModule,
|
|
22
|
+
MatExpansionModule,
|
|
23
|
+
MatTooltipModule,
|
|
24
|
+
MatProgressSpinnerModule] });
|
|
25
|
+
NdfUploaderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfUploaderModule, imports: [[
|
|
26
|
+
CommonModule,
|
|
27
|
+
TranslateModule,
|
|
28
|
+
MatDialogModule,
|
|
29
|
+
MatIconModule,
|
|
30
|
+
MatButtonModule,
|
|
31
|
+
MatBottomSheetModule,
|
|
32
|
+
MatExpansionModule,
|
|
33
|
+
MatTooltipModule,
|
|
34
|
+
MatProgressSpinnerModule
|
|
35
|
+
]] });
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NdfUploaderModule, decorators: [{
|
|
37
|
+
type: NgModule,
|
|
38
|
+
args: [{
|
|
39
|
+
imports: [
|
|
40
|
+
CommonModule,
|
|
41
|
+
TranslateModule,
|
|
42
|
+
MatDialogModule,
|
|
43
|
+
MatIconModule,
|
|
44
|
+
MatButtonModule,
|
|
45
|
+
MatBottomSheetModule,
|
|
46
|
+
MatExpansionModule,
|
|
47
|
+
MatTooltipModule,
|
|
48
|
+
MatProgressSpinnerModule
|
|
49
|
+
],
|
|
50
|
+
declarations: [NdfUploaderBottomSheetComponent]
|
|
51
|
+
}]
|
|
52
|
+
}] });
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmRmLXVwbG9hZGVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvbmRmLXVwbG9hZGVyL25kZi11cGxvYWRlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3RFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNqRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM5RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxNQUFNLCtEQUErRCxDQUFDOztBQWdCaEgsTUFBTSxPQUFPLGlCQUFpQjs7K0dBQWpCLGlCQUFpQjtnSEFBakIsaUJBQWlCLGlCQUZkLCtCQUErQixhQVY3QyxZQUFZO1FBQ1osZUFBZTtRQUNmLGVBQWU7UUFDZixhQUFhO1FBQ2IsZUFBZTtRQUNmLG9CQUFvQjtRQUNwQixrQkFBa0I7UUFDbEIsZ0JBQWdCO1FBQ2hCLHdCQUF3QjtnSEFJYixpQkFBaUIsWUFicEI7WUFDUixZQUFZO1lBQ1osZUFBZTtZQUNmLGVBQWU7WUFDZixhQUFhO1lBQ2IsZUFBZTtZQUNmLG9CQUFvQjtZQUNwQixrQkFBa0I7WUFDbEIsZ0JBQWdCO1lBQ2hCLHdCQUF3QjtTQUN4Qjs0RkFHVyxpQkFBaUI7a0JBZDdCLFFBQVE7bUJBQUM7b0JBQ1QsT0FBTyxFQUFFO3dCQUNSLFlBQVk7d0JBQ1osZUFBZTt3QkFDZixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixvQkFBb0I7d0JBQ3BCLGtCQUFrQjt3QkFDbEIsZ0JBQWdCO3dCQUNoQix3QkFBd0I7cUJBQ3hCO29CQUNELFlBQVksRUFBRSxDQUFDLCtCQUErQixDQUFDO2lCQUMvQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuaW1wb3J0IHsgTWF0Qm90dG9tU2hlZXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9ib3R0b20tc2hlZXQnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcclxuaW1wb3J0IHsgTWF0RXhwYW5zaW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZXhwYW5zaW9uJztcclxuaW1wb3J0IHsgTWF0VG9vbHRpcE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Rvb2x0aXAnO1xyXG5pbXBvcnQgeyBNYXRQcm9ncmVzc1NwaW5uZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wcm9ncmVzcy1zcGlubmVyJztcclxuaW1wb3J0IHsgTWF0RGlhbG9nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcclxuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcclxuaW1wb3J0IHsgTmRmVXBsb2FkZXJCb3R0b21TaGVldENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9ib3R0b20tc2hlZXQvbmRmLXVwbG9hZGVyLWJvdHRvbS1zaGVldC5jb21wb25lbnQnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuXHRpbXBvcnRzOiBbXHJcblx0XHRDb21tb25Nb2R1bGUsXHJcblx0XHRUcmFuc2xhdGVNb2R1bGUsXHJcblx0XHRNYXREaWFsb2dNb2R1bGUsXHJcblx0XHRNYXRJY29uTW9kdWxlLFxyXG5cdFx0TWF0QnV0dG9uTW9kdWxlLFxyXG5cdFx0TWF0Qm90dG9tU2hlZXRNb2R1bGUsXHJcblx0XHRNYXRFeHBhbnNpb25Nb2R1bGUsXHJcblx0XHRNYXRUb29sdGlwTW9kdWxlLFxyXG5cdFx0TWF0UHJvZ3Jlc3NTcGlubmVyTW9kdWxlXHJcblx0XSxcclxuXHRkZWNsYXJhdGlvbnM6IFtOZGZVcGxvYWRlckJvdHRvbVNoZWV0Q29tcG9uZW50XVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTmRmVXBsb2FkZXJNb2R1bGUge31cclxuIl19
|