@onemrvapublic/design-system 18.2.14-develop.1 → 18.2.14-develop.3
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/mat-file-upload/src/components/onemrva-mat-file-upload/onemrva-mat-file-upload.component.mjs +43 -32
- package/esm2022/shared/src/lib/constants/date.format.mjs +22 -3
- package/fesm2022/onemrvapublic-design-system-mat-file-upload.mjs +42 -31
- package/fesm2022/onemrvapublic-design-system-mat-file-upload.mjs.map +1 -1
- package/fesm2022/onemrvapublic-design-system-shared.mjs +22 -3
- package/fesm2022/onemrvapublic-design-system-shared.mjs.map +1 -1
- package/mat-file-upload/src/components/onemrva-mat-file-upload/onemrva-mat-file-upload.component.d.ts +2 -1
- package/package.json +1 -1
- package/shared/src/lib/constants/date.format.d.ts +1 -0
|
@@ -21,6 +21,7 @@ export class OnemrvaMatFileUploadComponent {
|
|
|
21
21
|
this.accept = [];
|
|
22
22
|
this.maxFileSize = 0;
|
|
23
23
|
this.numberOfFiles = 0;
|
|
24
|
+
this.maxTotalFileSize = 0;
|
|
24
25
|
this.uploadOnDrop = true;
|
|
25
26
|
this.initialFiles = [];
|
|
26
27
|
this.errorMessage = '';
|
|
@@ -68,46 +69,54 @@ export class OnemrvaMatFileUploadComponent {
|
|
|
68
69
|
* @param files (Files List)
|
|
69
70
|
*/
|
|
70
71
|
prepareFilesList(files) {
|
|
71
|
-
this.fileUploadStore.files$.pipe(take(1)).subscribe(
|
|
72
|
-
// if numberOffiles is set and the total length of files is
|
|
72
|
+
this.fileUploadStore.files$.pipe(take(1)).subscribe(currentFiles => {
|
|
73
|
+
// if numberOffiles is set and the total length of files is smal
|
|
74
|
+
// ler than it
|
|
73
75
|
if (this.numberOfFiles > 0 &&
|
|
74
|
-
files.length +
|
|
76
|
+
files.length + currentFiles.length > this.numberOfFiles) {
|
|
75
77
|
// too many files
|
|
76
78
|
this.errorMessage = this.translate.instant('file.upload.too.many.files');
|
|
79
|
+
return;
|
|
77
80
|
}
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
if (file === null)
|
|
85
|
-
continue;
|
|
86
|
-
const item = {
|
|
87
|
-
file,
|
|
88
|
-
progress: 0,
|
|
89
|
-
message: '',
|
|
90
|
-
color: 'primary',
|
|
91
|
-
url: null,
|
|
92
|
-
id: null,
|
|
93
|
-
enableProgressBar: this.uploadOnDrop,
|
|
94
|
-
name: file.name,
|
|
95
|
-
lastModified: file.lastModified,
|
|
96
|
-
size: file.size,
|
|
97
|
-
type: file.type,
|
|
98
|
-
};
|
|
99
|
-
fs.push(item);
|
|
81
|
+
if (this.maxTotalFileSize > 0) {
|
|
82
|
+
const total = Object.values(files).reduce((sum, obj) => sum + obj.size, 0) +
|
|
83
|
+
currentFiles.reduce((sum, obj) => sum + obj.size, 0);
|
|
84
|
+
if (total > this.maxTotalFileSize) {
|
|
85
|
+
this.errorMessage = this.translate.instant('file.upload.total.max.size.exceeded');
|
|
86
|
+
return;
|
|
100
87
|
}
|
|
101
|
-
if (this.uploadOnDrop)
|
|
102
|
-
this.fileUploadStore.uploadFiles(fs);
|
|
103
|
-
else
|
|
104
|
-
this.fileUploadStore.addSeveralForPotentialUpload(fs);
|
|
105
|
-
this.fileDropRef.nativeElement.value = null;
|
|
106
88
|
}
|
|
89
|
+
// clear error message
|
|
90
|
+
this.errorMessage = '';
|
|
91
|
+
const fs = [];
|
|
92
|
+
for (let i = 0; i < files.length; i++) {
|
|
93
|
+
const file = files.item(i);
|
|
94
|
+
if (file === null)
|
|
95
|
+
continue;
|
|
96
|
+
const item = {
|
|
97
|
+
file,
|
|
98
|
+
progress: 0,
|
|
99
|
+
message: '',
|
|
100
|
+
color: 'primary',
|
|
101
|
+
url: null,
|
|
102
|
+
id: null,
|
|
103
|
+
enableProgressBar: this.uploadOnDrop,
|
|
104
|
+
name: file.name,
|
|
105
|
+
lastModified: file.lastModified,
|
|
106
|
+
size: file.size,
|
|
107
|
+
type: file.type,
|
|
108
|
+
};
|
|
109
|
+
fs.push(item);
|
|
110
|
+
}
|
|
111
|
+
if (this.uploadOnDrop)
|
|
112
|
+
this.fileUploadStore.uploadFiles(fs);
|
|
113
|
+
else
|
|
114
|
+
this.fileUploadStore.addSeveralForPotentialUpload(fs);
|
|
115
|
+
this.fileDropRef.nativeElement.value = null;
|
|
107
116
|
});
|
|
108
117
|
}
|
|
109
118
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: OnemrvaMatFileUploadComponent, deps: [{ token: i1.MatDialog }, { token: i2.OnemRvaCDNMimeService }, { token: i3.TranslateService }, { token: i4.OnemrvaMatFileUploadStore }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
110
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: OnemrvaMatFileUploadComponent, selector: "onemrva-mat-file-upload", inputs: { accept: "accept", maxFileSize: "maxFileSize", numberOfFiles: "numberOfFiles", uploadOnDrop: "uploadOnDrop", initialFiles: "initialFiles", errorMessage: "errorMessage", dropFilesHereTextTranslationKey: "dropFilesHereTextTranslationKey", filePanelTemplate: "filePanelTemplate", dataCy: "dataCy" }, host: { properties: { "attr.data-cy": "this.dataCy" } }, viewQueries: [{ propertyName: "fileDropRef", first: true, predicate: ["fileDropRef"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"files$ | async as files\">\n <div\n class=\"onemrva-mat-file-upload-drop-area\"\n appDnd\n (fileDropped)=\"onFileDropped($event)\"\n [ngClass]=\"{\n 'fu-error': errorMessage !== '',\n filein: files.length > 0,\n }\"\n >\n <input\n type=\"file\"\n #fileDropRef\n [attr.id]=\"inputId\"\n role=\"button\"\n multiple\n (change)=\"fileBrowseHandler($event)\"\n accept=\"{{ acceptString$ | async }}\"\n />\n <div\n class=\"download-outer\"\n *ngIf=\"numberOfFiles === 0 || numberOfFiles > files.length\"\n >\n <div class=\"download-icon\">\n <mat-icon class=\"onemrva-upload xxlarge\">download</mat-icon>\n </div>\n\n <div class=\"download-text\">\n {{ dropFilesHereTextTranslationKey | translate }}\n {{ 'file.upload.or' | translate }}\n <label for=\"{{ inputId }}\" class=\"content\">\n {{ 'file.upload.browse.for.file' | translate }} </label\n ><br />\n <span class=\"restrictions\" *ngIf=\"maxFileSize > 0\">\n {{ 'file.upload.maximum' | translate }}\n {{ maxFileSizeFormatted }}\n\n <span *ngIf=\"accept.length > 0\">{{ '| ' }}</span>\n\n {{ acceptString$ | async }}\n </span>\n </div>\n </div>\n <ul class=\"files-list\">\n <li *ngFor=\"let file of files\">\n <ng-container\n *ngTemplateOutlet=\"\n filePanelTemplate;\n context: { file, $implicit: file }\n \"\n ></ng-container>\n </li>\n </ul>\n </div>\n\n <mat-error *ngIf=\"errorMessage\">{{ errorMessage | translate }}</mat-error>\n\n <mat-error *ngIf=\"fileUploadErrorMessage$ | async as fileUploadErrorMessage\">\n {{ fileUploadErrorMessage | translate }}\n </mat-error>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i7.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i8.DndDirective, selector: "[appDnd]", outputs: ["fileDropped"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }], animations: [
|
|
119
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: OnemrvaMatFileUploadComponent, selector: "onemrva-mat-file-upload", inputs: { accept: "accept", maxFileSize: "maxFileSize", numberOfFiles: "numberOfFiles", maxTotalFileSize: "maxTotalFileSize", uploadOnDrop: "uploadOnDrop", initialFiles: "initialFiles", errorMessage: "errorMessage", dropFilesHereTextTranslationKey: "dropFilesHereTextTranslationKey", filePanelTemplate: "filePanelTemplate", dataCy: "dataCy" }, host: { properties: { "attr.data-cy": "this.dataCy" } }, viewQueries: [{ propertyName: "fileDropRef", first: true, predicate: ["fileDropRef"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"files$ | async as files\">\n <div\n class=\"onemrva-mat-file-upload-drop-area\"\n appDnd\n (fileDropped)=\"onFileDropped($event)\"\n [ngClass]=\"{\n 'fu-error': errorMessage !== '',\n filein: files.length > 0,\n }\"\n >\n <input\n type=\"file\"\n #fileDropRef\n [attr.id]=\"inputId\"\n role=\"button\"\n multiple\n (change)=\"fileBrowseHandler($event)\"\n accept=\"{{ acceptString$ | async }}\"\n />\n <div\n class=\"download-outer\"\n *ngIf=\"numberOfFiles === 0 || numberOfFiles > files.length\"\n >\n <div class=\"download-icon\">\n <mat-icon class=\"onemrva-upload xxlarge\">download</mat-icon>\n </div>\n\n <div class=\"download-text\">\n {{ dropFilesHereTextTranslationKey | translate }}\n {{ 'file.upload.or' | translate }}\n <label for=\"{{ inputId }}\" class=\"content\">\n {{ 'file.upload.browse.for.file' | translate }} </label\n ><br />\n <span class=\"restrictions\" *ngIf=\"maxFileSize > 0\">\n {{ 'file.upload.maximum' | translate }}\n {{ maxFileSizeFormatted }}\n\n <span *ngIf=\"accept.length > 0\">{{ '| ' }}</span>\n\n {{ acceptString$ | async }}\n </span>\n </div>\n </div>\n <ul class=\"files-list\">\n <li *ngFor=\"let file of files\">\n <ng-container\n *ngTemplateOutlet=\"\n filePanelTemplate;\n context: { file, $implicit: file }\n \"\n ></ng-container>\n </li>\n </ul>\n </div>\n\n <mat-error *ngIf=\"errorMessage\">{{ errorMessage | translate }}</mat-error>\n\n <mat-error *ngIf=\"fileUploadErrorMessage$ | async as fileUploadErrorMessage\">\n {{ fileUploadErrorMessage | translate }}\n </mat-error>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i7.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i8.DndDirective, selector: "[appDnd]", outputs: ["fileDropped"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }], animations: [
|
|
111
120
|
trigger('inOutAnimation', [
|
|
112
121
|
state('in', style({ opacity: 1 })),
|
|
113
122
|
transition(':enter', [
|
|
@@ -162,6 +171,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
162
171
|
type: Input
|
|
163
172
|
}], numberOfFiles: [{
|
|
164
173
|
type: Input
|
|
174
|
+
}], maxTotalFileSize: [{
|
|
175
|
+
type: Input
|
|
165
176
|
}], uploadOnDrop: [{
|
|
166
177
|
type: Input
|
|
167
178
|
}], initialFiles: [{
|
|
@@ -181,4 +192,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
181
192
|
type: ViewChild,
|
|
182
193
|
args: [`fileDropRef`]
|
|
183
194
|
}] } });
|
|
184
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onemrva-mat-file-upload.component.js","sourceRoot":"","sources":["../../../../../../../../projects/onemrva/design-system/mat-file-upload/src/components/onemrva-mat-file-upload/onemrva-mat-file-upload.component.ts","../../../../../../../../projects/onemrva/design-system/mat-file-upload/src/components/onemrva-mat-file-upload/onemrva-mat-file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { map, Observable, take } from 'rxjs';\nimport {\n  state,\n  keyframes,\n  style,\n  animate,\n  trigger,\n  transition,\n} from '@angular/animations';\nimport {\n  formatBytes,\n  ProgressFile,\n  ReferencedProgressFile,\n} from '../../models/progress-file.model';\nimport { OnemrvaMatFileUploadStore } from '../../onemrva-mat-file-upload.store';\nimport { TranslateService } from '@ngx-translate/core';\nimport { OnemRvaCDNMimeService } from '@onemrvapublic/design-system/shared';\n\nlet NEXT_ID = 0;\n\n@Component({\n  selector: 'onemrva-mat-file-upload',\n  templateUrl: 'onemrva-mat-file-upload.component.html',\n  animations: [\n    trigger('inOutAnimation', [\n      state('in', style({ opacity: 1 })),\n      transition(':enter', [\n        animate(\n          300,\n          keyframes([\n            style({ opacity: 0, offset: 0 }),\n            style({ opacity: 0.25, offset: 0.25 }),\n            style({ opacity: 0.5, offset: 0.5 }),\n            style({ opacity: 0.75, offset: 0.75 }),\n            style({ opacity: 1, offset: 1 }),\n          ]),\n        ),\n      ]),\n      transition(':leave', [\n        animate(\n          300,\n          keyframes([\n            style({ opacity: 1, offset: 0 }),\n            style({ opacity: 0.75, offset: 0.25 }),\n            style({ opacity: 0.5, offset: 0.5 }),\n            style({ opacity: 0.25, offset: 0.75 }),\n            style({ opacity: 0, offset: 1 }),\n          ]),\n        ),\n      ]),\n    ]),\n  ],\n})\nexport class OnemrvaMatFileUploadComponent implements OnInit {\n  @Input()\n  accept: string[] = [];\n\n  acceptString$?: Observable<any>;\n\n  @Input()\n  maxFileSize = 0;\n\n  @Input()\n  numberOfFiles = 0;\n\n  @Input()\n  uploadOnDrop = true;\n\n  @Input()\n  initialFiles: ProgressFile[] = [];\n\n  @Input()\n  errorMessage = '';\n\n  @Input()\n  dropFilesHereTextTranslationKey = 'file.upload.drag.and.drop';\n\n  fileUploadErrorMessage$: Observable<string>;\n\n  files$: Observable<ReferencedProgressFile[]>;\n\n  @Input() filePanelTemplate!: TemplateRef<any>;\n\n  retryFile = new EventEmitter<{ index: number; cmpRef: symbol }>();\n\n  /**\n   * Sets the `data-cy` of the element. If not set, the first component instance will have `data-cy` = `\"onemrva-mat-multi-select-0\"`.\n   *\n   * @example\n   * ```html\n   * <onemrva-mat-multi-select id=\"my-first-multi-select\"></onemrva-mat-multi-select>\n   * ```\n   */\n  @HostBinding('attr.data-cy')\n  @Input()\n  public dataCy = `onemrva-mat-multi-select-${NEXT_ID++}`;\n\n  @ViewChild(`fileDropRef`)\n  fileDropRef!: ElementRef;\n\n  inputId = `fileDropRef-${NEXT_ID}`;\n  maxFileSizeFormatted = '';\n\n  constructor(\n    public dialog: MatDialog,\n    public mimeCDN: OnemRvaCDNMimeService,\n    private translate: TranslateService,\n    private fileUploadStore: OnemrvaMatFileUploadStore,\n  ) {\n    this.files$ = fileUploadStore.files$;\n\n    this.fileUploadErrorMessage$ = this.fileUploadStore.fileUploadError$;\n  }\n\n  ngOnInit(): void {\n    if (this.accept.length > 0) {\n      this.acceptString$ = this.mimeCDN\n        .getExtensionsForMime(this.accept)\n        .pipe(map(arr => arr.map(item => `.${item}`).join(', ')));\n      this.fileUploadStore.setAccept(this.accept);\n    }\n\n    this.maxFileSizeFormatted = formatBytes(this.maxFileSize);\n    this.fileUploadStore.setMaxFileSize(this.maxFileSize);\n  }\n\n  /**\n   * on file drop handler\n   */\n  onFileDropped($event: FileList) {\n    this.prepareFilesList($event);\n  }\n\n  /**\n   * handle file from browsing\n   */\n  fileBrowseHandler($event: Event) {\n    const elm = $event.target as HTMLInputElement,\n      files = elm.files as FileList;\n\n    this.prepareFilesList(files);\n  }\n\n  /**\n   * Convert Files list to normal array list\n   * @param files (Files List)\n   */\n  prepareFilesList(files: FileList) {\n    this.fileUploadStore.files$.pipe(take(1)).subscribe(value => {\n      // if numberOffiles is set and the total length of files is smaller than it\n      if (\n        this.numberOfFiles > 0 &&\n        files.length + value.length > this.numberOfFiles\n      ) {\n        // too many files\n        this.errorMessage = this.translate.instant(\n          'file.upload.too.many.files',\n        );\n      } else {\n        // clear error message\n        this.errorMessage = '';\n\n        const fs: ProgressFile[] = [];\n        for (let i = 0; i < files.length; i++) {\n          const file = files.item(i);\n          if (file === null) continue;\n\n          const item: ProgressFile = {\n            file,\n            progress: 0,\n            message: '',\n            color: 'primary',\n            url: null,\n            id: null,\n            enableProgressBar: this.uploadOnDrop,\n\n            name: file!.name,\n            lastModified: file!.lastModified,\n            size: file!.size,\n            type: file!.type,\n          };\n\n          fs.push(item);\n        }\n\n        if (this.uploadOnDrop) this.fileUploadStore.uploadFiles(fs);\n        else this.fileUploadStore.addSeveralForPotentialUpload(fs);\n\n        this.fileDropRef.nativeElement.value = null;\n      }\n    });\n  }\n}\n","<ng-container *ngIf=\"files$ | async as files\">\n  <div\n    class=\"onemrva-mat-file-upload-drop-area\"\n    appDnd\n    (fileDropped)=\"onFileDropped($event)\"\n    [ngClass]=\"{\n      'fu-error': errorMessage !== '',\n      filein: files.length > 0,\n    }\"\n  >\n    <input\n      type=\"file\"\n      #fileDropRef\n      [attr.id]=\"inputId\"\n      role=\"button\"\n      multiple\n      (change)=\"fileBrowseHandler($event)\"\n      accept=\"{{ acceptString$ | async }}\"\n    />\n    <div\n      class=\"download-outer\"\n      *ngIf=\"numberOfFiles === 0 || numberOfFiles > files.length\"\n    >\n      <div class=\"download-icon\">\n        <mat-icon class=\"onemrva-upload xxlarge\">download</mat-icon>\n      </div>\n\n      <div class=\"download-text\">\n        {{ dropFilesHereTextTranslationKey | translate }}\n        {{ 'file.upload.or' | translate }}\n        <label for=\"{{ inputId }}\" class=\"content\">\n          {{ 'file.upload.browse.for.file' | translate }} </label\n        ><br />\n        <span class=\"restrictions\" *ngIf=\"maxFileSize > 0\">\n          {{ 'file.upload.maximum' | translate }}\n          {{ maxFileSizeFormatted }}\n\n          <span *ngIf=\"accept.length > 0\">{{ '| ' }}</span>\n\n          {{ acceptString$ | async }}\n        </span>\n      </div>\n    </div>\n    <ul class=\"files-list\">\n      <li *ngFor=\"let file of files\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            filePanelTemplate;\n            context: { file, $implicit: file }\n          \"\n        ></ng-container>\n      </li>\n    </ul>\n  </div>\n\n  <mat-error *ngIf=\"errorMessage\">{{ errorMessage | translate }}</mat-error>\n\n  <mat-error *ngIf=\"fileUploadErrorMessage$ | async as fileUploadErrorMessage\">\n    {{ fileUploadErrorMessage | translate }}\n  </mat-error>\n</ng-container>\n"]}
|
|
195
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onemrva-mat-file-upload.component.js","sourceRoot":"","sources":["../../../../../../../../projects/onemrva/design-system/mat-file-upload/src/components/onemrva-mat-file-upload/onemrva-mat-file-upload.component.ts","../../../../../../../../projects/onemrva/design-system/mat-file-upload/src/components/onemrva-mat-file-upload/onemrva-mat-file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { map, Observable, take } from 'rxjs';\nimport {\n  state,\n  keyframes,\n  style,\n  animate,\n  trigger,\n  transition,\n} from '@angular/animations';\nimport {\n  formatBytes,\n  ProgressFile,\n  ReferencedProgressFile,\n} from '../../models/progress-file.model';\nimport { OnemrvaMatFileUploadStore } from '../../onemrva-mat-file-upload.store';\nimport { TranslateService } from '@ngx-translate/core';\nimport { OnemRvaCDNMimeService } from '@onemrvapublic/design-system/shared';\n\nlet NEXT_ID = 0;\n\n@Component({\n  selector: 'onemrva-mat-file-upload',\n  templateUrl: 'onemrva-mat-file-upload.component.html',\n  animations: [\n    trigger('inOutAnimation', [\n      state('in', style({ opacity: 1 })),\n      transition(':enter', [\n        animate(\n          300,\n          keyframes([\n            style({ opacity: 0, offset: 0 }),\n            style({ opacity: 0.25, offset: 0.25 }),\n            style({ opacity: 0.5, offset: 0.5 }),\n            style({ opacity: 0.75, offset: 0.75 }),\n            style({ opacity: 1, offset: 1 }),\n          ]),\n        ),\n      ]),\n      transition(':leave', [\n        animate(\n          300,\n          keyframes([\n            style({ opacity: 1, offset: 0 }),\n            style({ opacity: 0.75, offset: 0.25 }),\n            style({ opacity: 0.5, offset: 0.5 }),\n            style({ opacity: 0.25, offset: 0.75 }),\n            style({ opacity: 0, offset: 1 }),\n          ]),\n        ),\n      ]),\n    ]),\n  ],\n})\nexport class OnemrvaMatFileUploadComponent implements OnInit {\n  @Input()\n  accept: string[] = [];\n\n  acceptString$?: Observable<any>;\n\n  @Input()\n  maxFileSize = 0;\n\n  @Input()\n  numberOfFiles = 0;\n\n  @Input()\n  maxTotalFileSize = 0;\n\n  @Input()\n  uploadOnDrop = true;\n\n  @Input()\n  initialFiles: ProgressFile[] = [];\n\n  @Input()\n  errorMessage = '';\n\n  @Input()\n  dropFilesHereTextTranslationKey = 'file.upload.drag.and.drop';\n\n  fileUploadErrorMessage$: Observable<string>;\n\n  files$: Observable<ReferencedProgressFile[]>;\n\n  @Input() filePanelTemplate!: TemplateRef<any>;\n\n  retryFile = new EventEmitter<{ index: number; cmpRef: symbol }>();\n\n  /**\n   * Sets the `data-cy` of the element. If not set, the first component instance will have `data-cy` = `\"onemrva-mat-multi-select-0\"`.\n   *\n   * @example\n   * ```html\n   * <onemrva-mat-multi-select id=\"my-first-multi-select\"></onemrva-mat-multi-select>\n   * ```\n   */\n  @HostBinding('attr.data-cy')\n  @Input()\n  public dataCy = `onemrva-mat-multi-select-${NEXT_ID++}`;\n\n  @ViewChild(`fileDropRef`)\n  fileDropRef!: ElementRef;\n\n  inputId = `fileDropRef-${NEXT_ID}`;\n  maxFileSizeFormatted = '';\n\n  constructor(\n    public dialog: MatDialog,\n    public mimeCDN: OnemRvaCDNMimeService,\n    private translate: TranslateService,\n    private fileUploadStore: OnemrvaMatFileUploadStore,\n  ) {\n    this.files$ = fileUploadStore.files$;\n\n    this.fileUploadErrorMessage$ = this.fileUploadStore.fileUploadError$;\n  }\n\n  ngOnInit(): void {\n    if (this.accept.length > 0) {\n      this.acceptString$ = this.mimeCDN\n        .getExtensionsForMime(this.accept)\n        .pipe(map(arr => arr.map(item => `.${item}`).join(', ')));\n      this.fileUploadStore.setAccept(this.accept);\n    }\n\n    this.maxFileSizeFormatted = formatBytes(this.maxFileSize);\n    this.fileUploadStore.setMaxFileSize(this.maxFileSize);\n  }\n\n  /**\n   * on file drop handler\n   */\n  onFileDropped($event: FileList) {\n    this.prepareFilesList($event);\n  }\n\n  /**\n   * handle file from browsing\n   */\n  fileBrowseHandler($event: Event) {\n    const elm = $event.target as HTMLInputElement,\n      files = elm.files as FileList;\n\n    this.prepareFilesList(files);\n  }\n\n  /**\n   * Convert Files list to normal array list\n   * @param files (Files List)\n   */\n  prepareFilesList(files: FileList) {\n    this.fileUploadStore.files$.pipe(take(1)).subscribe(currentFiles => {\n      // if numberOffiles is set and the total length of files is smal\n      // ler than it\n      if (\n        this.numberOfFiles > 0 &&\n        files.length + currentFiles.length > this.numberOfFiles\n      ) {\n        // too many files\n        this.errorMessage = this.translate.instant(\n          'file.upload.too.many.files',\n        );\n        return;\n      }\n      if (this.maxTotalFileSize > 0) {\n        const total: number =\n          Object.values(files).reduce((sum, obj) => sum + obj.size, 0) +\n          currentFiles.reduce((sum, obj) => sum + obj.size, 0);\n        if (total > this.maxTotalFileSize) {\n          this.errorMessage = this.translate.instant(\n            'file.upload.total.max.size.exceeded',\n          );\n          return;\n        }\n      }\n\n      // clear error message\n      this.errorMessage = '';\n\n      const fs: ProgressFile[] = [];\n      for (let i = 0; i < files.length; i++) {\n        const file = files.item(i);\n        if (file === null) continue;\n\n        const item: ProgressFile = {\n          file,\n          progress: 0,\n          message: '',\n          color: 'primary',\n          url: null,\n          id: null,\n          enableProgressBar: this.uploadOnDrop,\n\n          name: file!.name,\n          lastModified: file!.lastModified,\n          size: file!.size,\n          type: file!.type,\n        };\n\n        fs.push(item);\n      }\n\n      if (this.uploadOnDrop) this.fileUploadStore.uploadFiles(fs);\n      else this.fileUploadStore.addSeveralForPotentialUpload(fs);\n\n      this.fileDropRef.nativeElement.value = null;\n    });\n  }\n}\n","<ng-container *ngIf=\"files$ | async as files\">\n  <div\n    class=\"onemrva-mat-file-upload-drop-area\"\n    appDnd\n    (fileDropped)=\"onFileDropped($event)\"\n    [ngClass]=\"{\n      'fu-error': errorMessage !== '',\n      filein: files.length > 0,\n    }\"\n  >\n    <input\n      type=\"file\"\n      #fileDropRef\n      [attr.id]=\"inputId\"\n      role=\"button\"\n      multiple\n      (change)=\"fileBrowseHandler($event)\"\n      accept=\"{{ acceptString$ | async }}\"\n    />\n    <div\n      class=\"download-outer\"\n      *ngIf=\"numberOfFiles === 0 || numberOfFiles > files.length\"\n    >\n      <div class=\"download-icon\">\n        <mat-icon class=\"onemrva-upload xxlarge\">download</mat-icon>\n      </div>\n\n      <div class=\"download-text\">\n        {{ dropFilesHereTextTranslationKey | translate }}\n        {{ 'file.upload.or' | translate }}\n        <label for=\"{{ inputId }}\" class=\"content\">\n          {{ 'file.upload.browse.for.file' | translate }} </label\n        ><br />\n        <span class=\"restrictions\" *ngIf=\"maxFileSize > 0\">\n          {{ 'file.upload.maximum' | translate }}\n          {{ maxFileSizeFormatted }}\n\n          <span *ngIf=\"accept.length > 0\">{{ '| ' }}</span>\n\n          {{ acceptString$ | async }}\n        </span>\n      </div>\n    </div>\n    <ul class=\"files-list\">\n      <li *ngFor=\"let file of files\">\n        <ng-container\n          *ngTemplateOutlet=\"\n            filePanelTemplate;\n            context: { file, $implicit: file }\n          \"\n        ></ng-container>\n      </li>\n    </ul>\n  </div>\n\n  <mat-error *ngIf=\"errorMessage\">{{ errorMessage | translate }}</mat-error>\n\n  <mat-error *ngIf=\"fileUploadErrorMessage$ | async as fileUploadErrorMessage\">\n    {{ fileUploadErrorMessage | translate }}\n  </mat-error>\n</ng-container>\n"]}
|
|
@@ -1,12 +1,31 @@
|
|
|
1
1
|
export const ONEMRVA_FORMAT = {
|
|
2
2
|
parse: {
|
|
3
|
-
dateInput: '
|
|
3
|
+
dateInput: 'dd/MM/yyyy',
|
|
4
4
|
},
|
|
5
5
|
display: {
|
|
6
6
|
dateInput: 'dd/MM/yyyy',
|
|
7
7
|
monthYearLabel: 'MMM yyyy',
|
|
8
|
-
dateA11yLabel: '
|
|
8
|
+
dateA11yLabel: 'DDD',
|
|
9
9
|
monthYearA11yLabel: 'MMMM yyyy',
|
|
10
10
|
},
|
|
11
11
|
};
|
|
12
|
-
|
|
12
|
+
export const ONEMRVA_MAT_LUXON_DATE_FORMATS = {
|
|
13
|
+
parse: {
|
|
14
|
+
dateInput: [
|
|
15
|
+
'ddLLyyyy',
|
|
16
|
+
'd/L/yyyy',
|
|
17
|
+
'dd/L/yyyy',
|
|
18
|
+
'd/LL/yyyy',
|
|
19
|
+
'd.L.yyyy',
|
|
20
|
+
'dd.L.yyyy',
|
|
21
|
+
'd.LL.yyyy',
|
|
22
|
+
],
|
|
23
|
+
},
|
|
24
|
+
display: {
|
|
25
|
+
dateInput: 'dd/LL/yyyy',
|
|
26
|
+
monthYearLabel: 'LLL yyyy',
|
|
27
|
+
dateA11yLabel: 'DDD',
|
|
28
|
+
monthYearA11yLabel: 'LLL yyyy',
|
|
29
|
+
},
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS5mb3JtYXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vbmVtcnZhL2Rlc2lnbi1zeXN0ZW0vc2hhcmVkL3NyYy9saWIvY29uc3RhbnRzL2RhdGUuZm9ybWF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBbUI7SUFDNUMsS0FBSyxFQUFFO1FBQ0wsU0FBUyxFQUFFLFlBQVk7S0FDeEI7SUFDRCxPQUFPLEVBQUU7UUFDUCxTQUFTLEVBQUUsWUFBWTtRQUN2QixjQUFjLEVBQUUsVUFBVTtRQUMxQixhQUFhLEVBQUUsS0FBSztRQUNwQixrQkFBa0IsRUFBRSxXQUFXO0tBQ2hDO0NBQ0YsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFtQjtJQUM1RCxLQUFLLEVBQUU7UUFDTCxTQUFTLEVBQUU7WUFDVCxVQUFVO1lBQ1YsVUFBVTtZQUNWLFdBQVc7WUFDWCxXQUFXO1lBQ1gsVUFBVTtZQUNWLFdBQVc7WUFDWCxXQUFXO1NBQ1o7S0FDRjtJQUNELE9BQU8sRUFBRTtRQUNQLFNBQVMsRUFBRSxZQUFZO1FBQ3ZCLGNBQWMsRUFBRSxVQUFVO1FBQzFCLGFBQWEsRUFBRSxLQUFLO1FBQ3BCLGtCQUFrQixFQUFFLFVBQVU7S0FDL0I7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWF0RGF0ZUZvcm1hdHMgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcblxuZXhwb3J0IGNvbnN0IE9ORU1SVkFfRk9STUFUOiBNYXREYXRlRm9ybWF0cyA9IHtcbiAgcGFyc2U6IHtcbiAgICBkYXRlSW5wdXQ6ICdkZC9NTS95eXl5JyxcbiAgfSxcbiAgZGlzcGxheToge1xuICAgIGRhdGVJbnB1dDogJ2RkL01NL3l5eXknLFxuICAgIG1vbnRoWWVhckxhYmVsOiAnTU1NIHl5eXknLFxuICAgIGRhdGVBMTF5TGFiZWw6ICdEREQnLFxuICAgIG1vbnRoWWVhckExMXlMYWJlbDogJ01NTU0geXl5eScsXG4gIH0sXG59O1xuXG5leHBvcnQgY29uc3QgT05FTVJWQV9NQVRfTFVYT05fREFURV9GT1JNQVRTOiBNYXREYXRlRm9ybWF0cyA9IHtcbiAgcGFyc2U6IHtcbiAgICBkYXRlSW5wdXQ6IFtcbiAgICAgICdkZExMeXl5eScsXG4gICAgICAnZC9ML3l5eXknLFxuICAgICAgJ2RkL0wveXl5eScsXG4gICAgICAnZC9MTC95eXl5JyxcbiAgICAgICdkLkwueXl5eScsXG4gICAgICAnZGQuTC55eXl5JyxcbiAgICAgICdkLkxMLnl5eXknLFxuICAgIF0sXG4gIH0sXG4gIGRpc3BsYXk6IHtcbiAgICBkYXRlSW5wdXQ6ICdkZC9MTC95eXl5JyxcbiAgICBtb250aFllYXJMYWJlbDogJ0xMTCB5eXl5JyxcbiAgICBkYXRlQTExeUxhYmVsOiAnREREJyxcbiAgICBtb250aFllYXJBMTF5TGFiZWw6ICdMTEwgeXl5eScsXG4gIH0sXG59O1xuIl19
|
|
@@ -565,6 +565,7 @@ class OnemrvaMatFileUploadComponent {
|
|
|
565
565
|
this.accept = [];
|
|
566
566
|
this.maxFileSize = 0;
|
|
567
567
|
this.numberOfFiles = 0;
|
|
568
|
+
this.maxTotalFileSize = 0;
|
|
568
569
|
this.uploadOnDrop = true;
|
|
569
570
|
this.initialFiles = [];
|
|
570
571
|
this.errorMessage = '';
|
|
@@ -612,46 +613,54 @@ class OnemrvaMatFileUploadComponent {
|
|
|
612
613
|
* @param files (Files List)
|
|
613
614
|
*/
|
|
614
615
|
prepareFilesList(files) {
|
|
615
|
-
this.fileUploadStore.files$.pipe(take(1)).subscribe(
|
|
616
|
-
// if numberOffiles is set and the total length of files is
|
|
616
|
+
this.fileUploadStore.files$.pipe(take(1)).subscribe(currentFiles => {
|
|
617
|
+
// if numberOffiles is set and the total length of files is smal
|
|
618
|
+
// ler than it
|
|
617
619
|
if (this.numberOfFiles > 0 &&
|
|
618
|
-
files.length +
|
|
620
|
+
files.length + currentFiles.length > this.numberOfFiles) {
|
|
619
621
|
// too many files
|
|
620
622
|
this.errorMessage = this.translate.instant('file.upload.too.many.files');
|
|
623
|
+
return;
|
|
621
624
|
}
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
if (file === null)
|
|
629
|
-
continue;
|
|
630
|
-
const item = {
|
|
631
|
-
file,
|
|
632
|
-
progress: 0,
|
|
633
|
-
message: '',
|
|
634
|
-
color: 'primary',
|
|
635
|
-
url: null,
|
|
636
|
-
id: null,
|
|
637
|
-
enableProgressBar: this.uploadOnDrop,
|
|
638
|
-
name: file.name,
|
|
639
|
-
lastModified: file.lastModified,
|
|
640
|
-
size: file.size,
|
|
641
|
-
type: file.type,
|
|
642
|
-
};
|
|
643
|
-
fs.push(item);
|
|
625
|
+
if (this.maxTotalFileSize > 0) {
|
|
626
|
+
const total = Object.values(files).reduce((sum, obj) => sum + obj.size, 0) +
|
|
627
|
+
currentFiles.reduce((sum, obj) => sum + obj.size, 0);
|
|
628
|
+
if (total > this.maxTotalFileSize) {
|
|
629
|
+
this.errorMessage = this.translate.instant('file.upload.total.max.size.exceeded');
|
|
630
|
+
return;
|
|
644
631
|
}
|
|
645
|
-
if (this.uploadOnDrop)
|
|
646
|
-
this.fileUploadStore.uploadFiles(fs);
|
|
647
|
-
else
|
|
648
|
-
this.fileUploadStore.addSeveralForPotentialUpload(fs);
|
|
649
|
-
this.fileDropRef.nativeElement.value = null;
|
|
650
632
|
}
|
|
633
|
+
// clear error message
|
|
634
|
+
this.errorMessage = '';
|
|
635
|
+
const fs = [];
|
|
636
|
+
for (let i = 0; i < files.length; i++) {
|
|
637
|
+
const file = files.item(i);
|
|
638
|
+
if (file === null)
|
|
639
|
+
continue;
|
|
640
|
+
const item = {
|
|
641
|
+
file,
|
|
642
|
+
progress: 0,
|
|
643
|
+
message: '',
|
|
644
|
+
color: 'primary',
|
|
645
|
+
url: null,
|
|
646
|
+
id: null,
|
|
647
|
+
enableProgressBar: this.uploadOnDrop,
|
|
648
|
+
name: file.name,
|
|
649
|
+
lastModified: file.lastModified,
|
|
650
|
+
size: file.size,
|
|
651
|
+
type: file.type,
|
|
652
|
+
};
|
|
653
|
+
fs.push(item);
|
|
654
|
+
}
|
|
655
|
+
if (this.uploadOnDrop)
|
|
656
|
+
this.fileUploadStore.uploadFiles(fs);
|
|
657
|
+
else
|
|
658
|
+
this.fileUploadStore.addSeveralForPotentialUpload(fs);
|
|
659
|
+
this.fileDropRef.nativeElement.value = null;
|
|
651
660
|
});
|
|
652
661
|
}
|
|
653
662
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: OnemrvaMatFileUploadComponent, deps: [{ token: i1$1.MatDialog }, { token: i2$1.OnemRvaCDNMimeService }, { token: i3$1.TranslateService }, { token: OnemrvaMatFileUploadStore }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
654
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: OnemrvaMatFileUploadComponent, selector: "onemrva-mat-file-upload", inputs: { accept: "accept", maxFileSize: "maxFileSize", numberOfFiles: "numberOfFiles", uploadOnDrop: "uploadOnDrop", initialFiles: "initialFiles", errorMessage: "errorMessage", dropFilesHereTextTranslationKey: "dropFilesHereTextTranslationKey", filePanelTemplate: "filePanelTemplate", dataCy: "dataCy" }, host: { properties: { "attr.data-cy": "this.dataCy" } }, viewQueries: [{ propertyName: "fileDropRef", first: true, predicate: ["fileDropRef"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"files$ | async as files\">\n <div\n class=\"onemrva-mat-file-upload-drop-area\"\n appDnd\n (fileDropped)=\"onFileDropped($event)\"\n [ngClass]=\"{\n 'fu-error': errorMessage !== '',\n filein: files.length > 0,\n }\"\n >\n <input\n type=\"file\"\n #fileDropRef\n [attr.id]=\"inputId\"\n role=\"button\"\n multiple\n (change)=\"fileBrowseHandler($event)\"\n accept=\"{{ acceptString$ | async }}\"\n />\n <div\n class=\"download-outer\"\n *ngIf=\"numberOfFiles === 0 || numberOfFiles > files.length\"\n >\n <div class=\"download-icon\">\n <mat-icon class=\"onemrva-upload xxlarge\">download</mat-icon>\n </div>\n\n <div class=\"download-text\">\n {{ dropFilesHereTextTranslationKey | translate }}\n {{ 'file.upload.or' | translate }}\n <label for=\"{{ inputId }}\" class=\"content\">\n {{ 'file.upload.browse.for.file' | translate }} </label\n ><br />\n <span class=\"restrictions\" *ngIf=\"maxFileSize > 0\">\n {{ 'file.upload.maximum' | translate }}\n {{ maxFileSizeFormatted }}\n\n <span *ngIf=\"accept.length > 0\">{{ '| ' }}</span>\n\n {{ acceptString$ | async }}\n </span>\n </div>\n </div>\n <ul class=\"files-list\">\n <li *ngFor=\"let file of files\">\n <ng-container\n *ngTemplateOutlet=\"\n filePanelTemplate;\n context: { file, $implicit: file }\n \"\n ></ng-container>\n </li>\n </ul>\n </div>\n\n <mat-error *ngIf=\"errorMessage\">{{ errorMessage | translate }}</mat-error>\n\n <mat-error *ngIf=\"fileUploadErrorMessage$ | async as fileUploadErrorMessage\">\n {{ fileUploadErrorMessage | translate }}\n </mat-error>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i7.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: DndDirective, selector: "[appDnd]", outputs: ["fileDropped"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i3$1.TranslatePipe, name: "translate" }], animations: [
|
|
663
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: OnemrvaMatFileUploadComponent, selector: "onemrva-mat-file-upload", inputs: { accept: "accept", maxFileSize: "maxFileSize", numberOfFiles: "numberOfFiles", maxTotalFileSize: "maxTotalFileSize", uploadOnDrop: "uploadOnDrop", initialFiles: "initialFiles", errorMessage: "errorMessage", dropFilesHereTextTranslationKey: "dropFilesHereTextTranslationKey", filePanelTemplate: "filePanelTemplate", dataCy: "dataCy" }, host: { properties: { "attr.data-cy": "this.dataCy" } }, viewQueries: [{ propertyName: "fileDropRef", first: true, predicate: ["fileDropRef"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"files$ | async as files\">\n <div\n class=\"onemrva-mat-file-upload-drop-area\"\n appDnd\n (fileDropped)=\"onFileDropped($event)\"\n [ngClass]=\"{\n 'fu-error': errorMessage !== '',\n filein: files.length > 0,\n }\"\n >\n <input\n type=\"file\"\n #fileDropRef\n [attr.id]=\"inputId\"\n role=\"button\"\n multiple\n (change)=\"fileBrowseHandler($event)\"\n accept=\"{{ acceptString$ | async }}\"\n />\n <div\n class=\"download-outer\"\n *ngIf=\"numberOfFiles === 0 || numberOfFiles > files.length\"\n >\n <div class=\"download-icon\">\n <mat-icon class=\"onemrva-upload xxlarge\">download</mat-icon>\n </div>\n\n <div class=\"download-text\">\n {{ dropFilesHereTextTranslationKey | translate }}\n {{ 'file.upload.or' | translate }}\n <label for=\"{{ inputId }}\" class=\"content\">\n {{ 'file.upload.browse.for.file' | translate }} </label\n ><br />\n <span class=\"restrictions\" *ngIf=\"maxFileSize > 0\">\n {{ 'file.upload.maximum' | translate }}\n {{ maxFileSizeFormatted }}\n\n <span *ngIf=\"accept.length > 0\">{{ '| ' }}</span>\n\n {{ acceptString$ | async }}\n </span>\n </div>\n </div>\n <ul class=\"files-list\">\n <li *ngFor=\"let file of files\">\n <ng-container\n *ngTemplateOutlet=\"\n filePanelTemplate;\n context: { file, $implicit: file }\n \"\n ></ng-container>\n </li>\n </ul>\n </div>\n\n <mat-error *ngIf=\"errorMessage\">{{ errorMessage | translate }}</mat-error>\n\n <mat-error *ngIf=\"fileUploadErrorMessage$ | async as fileUploadErrorMessage\">\n {{ fileUploadErrorMessage | translate }}\n </mat-error>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i7.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: DndDirective, selector: "[appDnd]", outputs: ["fileDropped"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i3$1.TranslatePipe, name: "translate" }], animations: [
|
|
655
664
|
trigger('inOutAnimation', [
|
|
656
665
|
state('in', style({ opacity: 1 })),
|
|
657
666
|
transition(':enter', [
|
|
@@ -706,6 +715,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
706
715
|
type: Input
|
|
707
716
|
}], numberOfFiles: [{
|
|
708
717
|
type: Input
|
|
718
|
+
}], maxTotalFileSize: [{
|
|
719
|
+
type: Input
|
|
709
720
|
}], uploadOnDrop: [{
|
|
710
721
|
type: Input
|
|
711
722
|
}], initialFiles: [{
|