@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.
@@ -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(value => {
72
- // if numberOffiles is set and the total length of files is smaller than it
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 + value.length > this.numberOfFiles) {
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
- else {
79
- // clear error message
80
- this.errorMessage = '';
81
- const fs = [];
82
- for (let i = 0; i < files.length; i++) {
83
- const file = files.item(i);
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: 'LL',
3
+ dateInput: 'dd/MM/yyyy',
4
4
  },
5
5
  display: {
6
6
  dateInput: 'dd/MM/yyyy',
7
7
  monthYearLabel: 'MMM yyyy',
8
- dateA11yLabel: 'LL',
8
+ dateA11yLabel: 'DDD',
9
9
  monthYearA11yLabel: 'MMMM yyyy',
10
10
  },
11
11
  };
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS5mb3JtYXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vbmVtcnZhL2Rlc2lnbi1zeXN0ZW0vc2hhcmVkL3NyYy9saWIvY29uc3RhbnRzL2RhdGUuZm9ybWF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBbUI7SUFDNUMsS0FBSyxFQUFFO1FBQ0wsU0FBUyxFQUFFLElBQUk7S0FDaEI7SUFDRCxPQUFPLEVBQUU7UUFDUCxTQUFTLEVBQUUsWUFBWTtRQUN2QixjQUFjLEVBQUUsVUFBVTtRQUMxQixhQUFhLEVBQUUsSUFBSTtRQUNuQixrQkFBa0IsRUFBRSxXQUFXO0tBQ2hDO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1hdERhdGVGb3JtYXRzIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBPTkVNUlZBX0ZPUk1BVDogTWF0RGF0ZUZvcm1hdHMgPSB7XG4gIHBhcnNlOiB7XG4gICAgZGF0ZUlucHV0OiAnTEwnLFxuICB9LFxuICBkaXNwbGF5OiB7XG4gICAgZGF0ZUlucHV0OiAnZGQvTU0veXl5eScsXG4gICAgbW9udGhZZWFyTGFiZWw6ICdNTU0geXl5eScsXG4gICAgZGF0ZUExMXlMYWJlbDogJ0xMJyxcbiAgICBtb250aFllYXJBMTF5TGFiZWw6ICdNTU1NIHl5eXknLFxuICB9LFxufTtcbiJdfQ==
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(value => {
616
- // if numberOffiles is set and the total length of files is smaller than it
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 + value.length > this.numberOfFiles) {
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
- else {
623
- // clear error message
624
- this.errorMessage = '';
625
- const fs = [];
626
- for (let i = 0; i < files.length; i++) {
627
- const file = files.item(i);
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: [{