@onemrvapublic/design-system 18.2.13 → 18.2.14-develop.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/assets/i18n/de.json +6 -6
- package/assets/i18n/nl.json +6 -6
- package/esm2022/mat-file-upload/src/components/onemrva-mat-file-upload/onemrva-mat-file-upload.component.mjs +43 -32
- package/esm2022/mat-stepper/src/onemrva-mat-stepper.component.mjs +26 -2
- package/esm2022/shared/src/lib/adapters/date.adapter.mjs +2 -2
- package/esm2022/shared/src/lib/adapters/year-month.adapter.mjs +3 -5
- package/esm2022/shared/src/lib/constants/date.format.mjs +1 -13
- 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-mat-stepper.mjs +25 -1
- package/fesm2022/onemrvapublic-design-system-mat-stepper.mjs.map +1 -1
- package/fesm2022/onemrvapublic-design-system-shared.mjs +17 -31
- 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/mat-stepper/src/onemrva-mat-stepper.component.d.ts +6 -2
- package/package.json +1 -1
- package/shared/src/lib/constants/date.format.d.ts +1 -12
package/assets/i18n/de.json
CHANGED
|
@@ -74,12 +74,12 @@
|
|
|
74
74
|
"invalid": "Feld erforderlich"
|
|
75
75
|
},
|
|
76
76
|
"phone": {
|
|
77
|
-
"required": "
|
|
78
|
-
"invalid": "
|
|
79
|
-
"notFound": "
|
|
80
|
-
"search": "
|
|
81
|
-
"label": "
|
|
82
|
-
"hint": "
|
|
77
|
+
"required": "Feld erforderlich",
|
|
78
|
+
"invalid": "Ungültiges Feld",
|
|
79
|
+
"notFound": "Nicht gefunden",
|
|
80
|
+
"search": "Suchen",
|
|
81
|
+
"label": "Telefonnummer",
|
|
82
|
+
"hint": "Beginnen Sie mit 0 für belgische Telefonnummern"
|
|
83
83
|
}
|
|
84
84
|
},
|
|
85
85
|
"copied.to.clipboard": "In Zwischenablage kopiert",
|
package/assets/i18n/nl.json
CHANGED
|
@@ -73,12 +73,12 @@
|
|
|
73
73
|
"invalid": "Veld verplicht"
|
|
74
74
|
},
|
|
75
75
|
"phone": {
|
|
76
|
-
"required": "
|
|
77
|
-
"invalid": "
|
|
78
|
-
"notFound": "
|
|
79
|
-
"search": "
|
|
80
|
-
"label": "
|
|
81
|
-
"hint": "
|
|
76
|
+
"required": "Veld vereist",
|
|
77
|
+
"invalid": "Ongeldig veld",
|
|
78
|
+
"notFound": "Niet gevonden",
|
|
79
|
+
"search": "Zoeken",
|
|
80
|
+
"label": "Telefoonnummer",
|
|
81
|
+
"hint": "Begin met 0 voor Belgische telefoonnummers"
|
|
82
82
|
}
|
|
83
83
|
},
|
|
84
84
|
"copied.to.clipboard": "Naar klembord gekopieerd",
|
|
@@ -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"]}
|
|
@@ -2,6 +2,7 @@ import { CdkStepper } from '@angular/cdk/stepper';
|
|
|
2
2
|
import { ChangeDetectionStrategy, Component, HostBinding, Input, Optional, ViewEncapsulation, } from '@angular/core';
|
|
3
3
|
import { onemrvaMatStepperAnimations } from './onemrva-stepper-animations';
|
|
4
4
|
import { MatStepper } from '@angular/material/stepper';
|
|
5
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "@angular/cdk/bidi";
|
|
7
8
|
import * as i2 from "@angular/common";
|
|
@@ -13,13 +14,36 @@ export class OnemrvaMatStepperComponent extends MatStepper {
|
|
|
13
14
|
}
|
|
14
15
|
// eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures
|
|
15
16
|
set orientation(value) {
|
|
16
|
-
|
|
17
|
+
this.matStepperVertical = true;
|
|
18
|
+
}
|
|
19
|
+
scrollToElement(elementId) {
|
|
20
|
+
const element = document.getElementById(elementId);
|
|
21
|
+
if (element) {
|
|
22
|
+
const yOffset = -100; // Optional: offset from the top for better positioning
|
|
23
|
+
const y = element.getBoundingClientRect().top + window.pageYOffset + yOffset;
|
|
24
|
+
window.scrollTo({ top: y, behavior: 'smooth' });
|
|
25
|
+
}
|
|
17
26
|
}
|
|
18
27
|
constructor(dir, changeDetectorRef, elementRef) {
|
|
19
28
|
super(dir, changeDetectorRef, elementRef);
|
|
29
|
+
this.destroyNotifier$ = new Subject();
|
|
20
30
|
this.matStepperVertical = true;
|
|
21
31
|
this.ariaOrientation = 'vertical';
|
|
22
32
|
this.role = 'tablist';
|
|
33
|
+
this.selectionChange
|
|
34
|
+
.pipe(takeUntil(this.destroyNotifier$))
|
|
35
|
+
.subscribe(value => {
|
|
36
|
+
const timeBeforeScroll = parseInt(this.animationDuration || '0') + 400;
|
|
37
|
+
setTimeout(() => {
|
|
38
|
+
const el = `cdk-step-label-${this._groupId}-${value.selectedIndex}`;
|
|
39
|
+
this.scrollToElement(el);
|
|
40
|
+
}, timeBeforeScroll);
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
ngOnDestroy() {
|
|
44
|
+
super.ngOnDestroy();
|
|
45
|
+
this.destroyNotifier$.next();
|
|
46
|
+
this.destroyNotifier$.complete();
|
|
23
47
|
}
|
|
24
48
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: OnemrvaMatStepperComponent, deps: [{ token: i1.Directionality, optional: true }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
25
49
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: OnemrvaMatStepperComponent, selector: "onemrva-mat-stepper, onemrva-mat-vertical-stepper, [onemrvaMatStepper]", inputs: { selectedIndex: "selectedIndex", orientation: "orientation" }, host: { properties: { "class.mat-stepper-vertical": "this.matStepperVertical", "attr.aria-orientation": "this.ariaOrientation", "role": "this.role" } }, providers: [
|
|
@@ -47,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
47
71
|
type: HostBinding,
|
|
48
72
|
args: ['role']
|
|
49
73
|
}] } });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib25lbXJ2YS1tYXQtc3RlcHBlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vbmVtcnZhL2Rlc2lnbi1zeXN0ZW0vbWF0LXN0ZXBwZXIvc3JjL29uZW1ydmEtbWF0LXN0ZXBwZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb25lbXJ2YS9kZXNpZ24tc3lzdGVtL21hdC1zdGVwcGVyL3NyYy9vbmVtcnZhLW1hdC1zdGVwcGVyLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBc0IsTUFBTSxzQkFBc0IsQ0FBQztBQUN0RSxPQUFPLEVBRUwsdUJBQXVCLEVBRXZCLFNBQVMsRUFFVCxXQUFXLEVBQ1gsS0FBSyxFQUNMLFFBQVEsRUFDUixpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDM0UsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDOzs7OztBQWtCdkQsTUFBTSxPQUFPLDBCQUNYLFNBQVEsVUFBVTtJQUdsQiwwQ0FBMEM7SUFDMUMsSUFDYSxXQUFXO1FBQ3RCLE9BQU8sVUFBVSxDQUFDO0lBQ3BCLENBQUM7SUFNRCwyRUFBMkU7SUFDM0UsSUFBYSxXQUFXLENBQUMsS0FBeUI7UUFDaEQsRUFBRTtJQUNKLENBQUM7SUFFRCxZQUNjLEdBQW1CLEVBQy9CLGlCQUFvQyxFQUNwQyxVQUFtQztRQUVuQyxLQUFLLENBQUMsR0FBRyxFQUFFLGlCQUFpQixFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBZEQsdUJBQWtCLEdBQUcsSUFBSSxDQUFDO1FBQy9CLG9CQUFlLEdBQUcsVUFBVSxDQUFDO1FBQzlDLFNBQUksR0FBRyxTQUFTLENBQUM7SUFhdEMsQ0FBQzs4R0F6QlUsMEJBQTBCO2tHQUExQiwwQkFBMEIsa1VBUDFCO1lBQ1QsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSwwQkFBMEIsRUFBRTtZQUNoRSxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRTtTQUNqRCx5SEM3QkgsdXlFQTZEQSxza0VEcENjLENBQUMsMkJBQTJCLENBQUMsc0JBQXNCLENBQUM7OzJGQVFyRCwwQkFBMEI7a0JBaEJ0QyxTQUFTOytCQUVOLHdFQUF3RSxZQUNoRSxzREFBc0QsVUFJeEQsQ0FBQyxlQUFlLENBQUMsY0FDYixDQUFDLDJCQUEyQixDQUFDLHNCQUFzQixDQUFDLGFBQ3JEO3dCQUNULEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxXQUFXLDRCQUE0QixFQUFFO3dCQUNoRSxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRTtxQkFDakQsaUJBQ2MsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTTs7MEJBc0I1QyxRQUFRO2tHQWRFLFdBQVc7c0JBRHZCLEtBQUs7Z0JBS3FDLGtCQUFrQjtzQkFBNUQsV0FBVzt1QkFBQyw0QkFBNEI7Z0JBQ0gsZUFBZTtzQkFBcEQsV0FBVzt1QkFBQyx1QkFBdUI7Z0JBQ2YsSUFBSTtzQkFBeEIsV0FBVzt1QkFBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aW9uYWxpdHkgfSBmcm9tICdAYW5ndWxhci9jZGsvYmlkaSc7XG5pbXBvcnQgeyBDZGtTdGVwcGVyLCBTdGVwcGVyT3JpZW50YXRpb24gfSBmcm9tICdAYW5ndWxhci9jZGsvc3RlcHBlcic7XG5pbXBvcnQge1xuICBBZnRlckNvbnRlbnRJbml0LFxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgSG9zdEJpbmRpbmcsXG4gIElucHV0LFxuICBPcHRpb25hbCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBvbmVtcnZhTWF0U3RlcHBlckFuaW1hdGlvbnMgfSBmcm9tICcuL29uZW1ydmEtc3RlcHBlci1hbmltYXRpb25zJztcbmltcG9ydCB7IE1hdFN0ZXBwZXIgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zdGVwcGVyJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOlxuICAgICdvbmVtcnZhLW1hdC1zdGVwcGVyLCBvbmVtcnZhLW1hdC12ZXJ0aWNhbC1zdGVwcGVyLCBbb25lbXJ2YU1hdFN0ZXBwZXJdJyxcbiAgZXhwb3J0QXM6ICdtYXRTdGVwcGVyLCBtYXRWZXJ0aWNhbFN0ZXBwZXIsIG1hdEhvcml6b250YWxTdGVwcGVyJyxcbiAgdGVtcGxhdGVVcmw6ICdvbmVtcnZhLW1hdC1zdGVwcGVyLmh0bWwnLFxuICBzdHlsZVVybHM6IFsnb25lbXJ2YS1tYXQtc3RlcHBlci5zY3NzJ10sXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZVxuICBpbnB1dHM6IFsnc2VsZWN0ZWRJbmRleCddLFxuICBhbmltYXRpb25zOiBbb25lbXJ2YU1hdFN0ZXBwZXJBbmltYXRpb25zLnZlcnRpY2FsU3RlcFRyYW5zaXRpb25dLFxuICBwcm92aWRlcnM6IFtcbiAgICB7IHByb3ZpZGU6IE1hdFN0ZXBwZXIsIHVzZUV4aXN0aW5nOiBPbmVtcnZhTWF0U3RlcHBlckNvbXBvbmVudCB9LFxuICAgIHsgcHJvdmlkZTogQ2RrU3RlcHBlciwgdXNlRXhpc3Rpbmc6IE1hdFN0ZXBwZXIgfSxcbiAgXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIE9uZW1ydmFNYXRTdGVwcGVyQ29tcG9uZW50XG4gIGV4dGVuZHMgTWF0U3RlcHBlclxuICBpbXBsZW1lbnRzIEFmdGVyQ29udGVudEluaXRcbntcbiAgLyoqIE9yaWVudGF0aW9uIG9mIHRoZSBzdW1tYXJ5LXN0ZXBwZXIuICovXG4gIEBJbnB1dCgpXG4gIG92ZXJyaWRlIGdldCBvcmllbnRhdGlvbigpOiBTdGVwcGVyT3JpZW50YXRpb24ge1xuICAgIHJldHVybiAndmVydGljYWwnO1xuICB9XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5tYXQtc3RlcHBlci12ZXJ0aWNhbCcpIG1hdFN0ZXBwZXJWZXJ0aWNhbCA9IHRydWU7XG4gIEBIb3N0QmluZGluZygnYXR0ci5hcmlhLW9yaWVudGF0aW9uJykgYXJpYU9yaWVudGF0aW9uID0gJ3ZlcnRpY2FsJztcbiAgQEhvc3RCaW5kaW5nKCdyb2xlJykgcm9sZSA9ICd0YWJsaXN0JztcblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2FkamFjZW50LW92ZXJsb2FkLXNpZ25hdHVyZXNcbiAgb3ZlcnJpZGUgc2V0IG9yaWVudGF0aW9uKHZhbHVlOiBTdGVwcGVyT3JpZW50YXRpb24pIHtcbiAgICAvL1xuICB9XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQE9wdGlvbmFsKCkgZGlyOiBEaXJlY3Rpb25hbGl0eSxcbiAgICBjaGFuZ2VEZXRlY3RvclJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4sXG4gICkge1xuICAgIHN1cGVyKGRpciwgY2hhbmdlRGV0ZWN0b3JSZWYsIGVsZW1lbnRSZWYpO1xuICB9XG59XG4iLCI8IS0tIFZlcnRpY2FsIHN1bW1hcnktc3RlcHBlciAtLT5cbjxuZy1jb250YWluZXI+XG4gIDxkaXZcbiAgICBjbGFzcz1cIm1hdC1zdGVwXCJcbiAgICAqbmdGb3I9XCJsZXQgc3RlcCBvZiBzdGVwczsgbGV0IGkgPSBpbmRleDsgbGV0IGlzTGFzdCA9IGxhc3RcIlxuICA+XG4gICAgPG5nLWNvbnRhaW5lclxuICAgICAgW25nVGVtcGxhdGVPdXRsZXRdPVwic3RlcFRlbXBsYXRlXCJcbiAgICAgIFtuZ1RlbXBsYXRlT3V0bGV0Q29udGV4dF09XCJ7c3RlcDogc3RlcCwgaTogaX1cIlxuICAgID48L25nLWNvbnRhaW5lcj5cbiAgICA8ZGl2XG4gICAgICBjbGFzcz1cIm1hdC12ZXJ0aWNhbC1jb250ZW50LWNvbnRhaW5lclwiXG4gICAgICBbY2xhc3MubWF0LXN0ZXBwZXItdmVydGljYWwtbGluZV09XCIhaXNMYXN0XCJcbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNsYXNzPVwibWF0LXZlcnRpY2FsLXN0ZXBwZXItY29udGVudFwiXG4gICAgICAgIHJvbGU9XCJ0YWJwYW5lbFwiXG4gICAgICAgIFtAdmVydGljYWxTdGVwVHJhbnNpdGlvbl09XCJ7XG4gICAgICAgICAgICAgICd2YWx1ZSc6IF9nZXRBbmltYXRpb25EaXJlY3Rpb24oaSksXG4gICAgICAgICAgICAgICdwYXJhbXMnOiB7J2FuaW1hdGlvbkR1cmF0aW9uJzogX2dldEFuaW1hdGlvbkR1cmF0aW9uKCl9XG4gICAgICAgICAgICB9XCJcbiAgICAgICAgKEB2ZXJ0aWNhbFN0ZXBUcmFuc2l0aW9uLmRvbmUpPVwiX2FuaW1hdGlvbkRvbmUubmV4dCgkZXZlbnQpXCJcbiAgICAgICAgW2lkXT1cIl9nZXRTdGVwQ29udGVudElkKGkpXCJcbiAgICAgICAgW2F0dHIuYXJpYS1sYWJlbGxlZGJ5XT1cIl9nZXRTdGVwTGFiZWxJZChpKVwiXG4gICAgICAgIFthdHRyLmFyaWEtZXhwYW5kZWRdPVwic2VsZWN0ZWRJbmRleCA9PT0gaVwiXG4gICAgICA+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJtYXQtdmVydGljYWwtY29udGVudFwiPlxuICAgICAgICAgIDxuZy1jb250YWluZXIgW25nVGVtcGxhdGVPdXRsZXRdPVwic3RlcC5jb250ZW50XCI+PC9uZy1jb250YWluZXI+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9uZy1jb250YWluZXI+XG5cbjwhLS0gQ29tbW9uIHN0ZXAgdGVtcGxhdGluZyAtLT5cbjxuZy10ZW1wbGF0ZSBsZXQtc3RlcD1cInN0ZXBcIiBsZXQtaT1cImlcIiAjc3RlcFRlbXBsYXRlPlxuICA8bWF0LXN0ZXAtaGVhZGVyXG4gICAgW2NsYXNzLm1hdC1ob3Jpem9udGFsLXN0ZXBwZXItaGVhZGVyXT1cIm9yaWVudGF0aW9uID09PSAnaG9yaXpvbnRhbCdcIlxuICAgIFtjbGFzcy5tYXQtdmVydGljYWwtc3RlcHBlci1oZWFkZXJdPVwib3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCdcIlxuICAgIChjbGljayk9XCJzdGVwLnNlbGVjdCgpXCJcbiAgICAoa2V5ZG93bik9XCJfb25LZXlkb3duKCRldmVudClcIlxuICAgIFt0YWJJbmRleF09XCJfZ2V0Rm9jdXNJbmRleCgpID09PSBpID8gMCA6IC0xXCJcbiAgICBbaWRdPVwiX2dldFN0ZXBMYWJlbElkKGkpXCJcbiAgICBbYXR0ci5hcmlhLXBvc2luc2V0XT1cImkgKyAxXCJcbiAgICBbYXR0ci5hcmlhLXNldHNpemVdPVwic3RlcHMubGVuZ3RoXCJcbiAgICBbYXR0ci5hcmlhLWNvbnRyb2xzXT1cIl9nZXRTdGVwQ29udGVudElkKGkpXCJcbiAgICBbYXR0ci5hcmlhLXNlbGVjdGVkXT1cInNlbGVjdGVkSW5kZXggPT09IGlcIlxuICAgIFthdHRyLmFyaWEtbGFiZWxdPVwic3RlcC5hcmlhTGFiZWwgfHwgbnVsbFwiXG4gICAgW2F0dHIuYXJpYS1sYWJlbGxlZGJ5XT1cIighc3RlcC5hcmlhTGFiZWwgJiYgc3RlcC5hcmlhTGFiZWxsZWRieSkgPyBzdGVwLmFyaWFMYWJlbGxlZGJ5IDogbnVsbFwiXG4gICAgW2F0dHIuYXJpYS1kaXNhYmxlZF09XCJfc3RlcElzTmF2aWdhYmxlKGksIHN0ZXApID8gbnVsbCA6IHRydWVcIlxuICAgIFtpbmRleF09XCJpXCJcbiAgICBbc3RhdGVdPVwiX2dldEluZGljYXRvclR5cGUoaSwgc3RlcC5zdGF0ZSlcIlxuICAgIFtsYWJlbF09XCJzdGVwLnN0ZXBMYWJlbCB8fCBzdGVwLmxhYmVsXCJcbiAgICBbc2VsZWN0ZWRdPVwic2VsZWN0ZWRJbmRleCA9PT0gaVwiXG4gICAgW2FjdGl2ZV09XCJfc3RlcElzTmF2aWdhYmxlKGksIHN0ZXApXCJcbiAgICBbb3B0aW9uYWxdPVwic3RlcC5vcHRpb25hbFwiXG4gICAgW2Vycm9yTWVzc2FnZV09XCJzdGVwLmVycm9yTWVzc2FnZVwiXG4gICAgW2ljb25PdmVycmlkZXNdPVwiX2ljb25PdmVycmlkZXNcIlxuICAgIFtkaXNhYmxlUmlwcGxlXT1cImRpc2FibGVSaXBwbGUgfHwgIV9zdGVwSXNOYXZpZ2FibGUoaSwgc3RlcClcIlxuICA+PC9tYXQtc3RlcC1oZWFkZXI+XG48L25nLXRlbXBsYXRlPlxuIl19
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onemrva-mat-stepper.component.js","sourceRoot":"","sources":["../../../../../../projects/onemrva/design-system/mat-stepper/src/onemrva-mat-stepper.component.ts","../../../../../../projects/onemrva/design-system/mat-stepper/src/onemrva-mat-stepper.html"],"names":[],"mappings":"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","sourcesContent":["import { Directionality } from '@angular/cdk/bidi';\nimport { CdkStepper, StepperOrientation } from '@angular/cdk/stepper';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnDestroy,\n  Optional,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { onemrvaMatStepperAnimations } from './onemrva-stepper-animations';\nimport { MatStepper } from '@angular/material/stepper';\nimport { ObservableInput, Subject, takeUntil } from 'rxjs';\n\n@Component({\n  selector:\n    'onemrva-mat-stepper, onemrva-mat-vertical-stepper, [onemrvaMatStepper]',\n  exportAs: 'matStepper, matVerticalStepper, matHorizontalStepper',\n  templateUrl: 'onemrva-mat-stepper.html',\n  styleUrls: ['onemrva-mat-stepper.scss'],\n  // eslint-disable-next-line\n  inputs: ['selectedIndex'],\n  animations: [onemrvaMatStepperAnimations.verticalStepTransition],\n  providers: [\n    { provide: MatStepper, useExisting: OnemrvaMatStepperComponent },\n    { provide: CdkStepper, useExisting: MatStepper },\n  ],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class OnemrvaMatStepperComponent\n  extends MatStepper\n  implements AfterContentInit, OnDestroy\n{\n  destroyNotifier$: Subject<void> = new Subject<void>();\n\n  /** Orientation of the summary-stepper. */\n  @Input()\n  override get orientation(): StepperOrientation {\n    return 'vertical';\n  }\n\n  @HostBinding('class.mat-stepper-vertical') matStepperVertical = true;\n  @HostBinding('attr.aria-orientation') ariaOrientation = 'vertical';\n  @HostBinding('role') role = 'tablist';\n\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\n  override set orientation(value: StepperOrientation) {\n    this.matStepperVertical = true;\n  }\n\n  scrollToElement(elementId: string): void {\n    const element = document.getElementById(elementId);\n    if (element) {\n      const yOffset = -100; // Optional: offset from the top for better positioning\n      const y =\n        element.getBoundingClientRect().top + window.pageYOffset + yOffset;\n      window.scrollTo({ top: y, behavior: 'smooth' });\n    }\n  }\n\n  constructor(\n    @Optional() dir: Directionality,\n    changeDetectorRef: ChangeDetectorRef,\n    elementRef: ElementRef<HTMLElement>,\n  ) {\n    super(dir, changeDetectorRef, elementRef);\n\n    this.selectionChange\n      .pipe(takeUntil(this.destroyNotifier$))\n      .subscribe(value => {\n        const timeBeforeScroll = parseInt(this.animationDuration || '0') + 400;\n        setTimeout(() => {\n          const el = `cdk-step-label-${this._groupId}-${value.selectedIndex}`;\n          this.scrollToElement(el);\n        }, timeBeforeScroll);\n      });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this.destroyNotifier$.next();\n    this.destroyNotifier$.complete();\n  }\n}\n","<!-- Vertical summary-stepper -->\n<ng-container>\n  <div\n    class=\"mat-step\"\n    *ngFor=\"let step of steps; let i = index; let isLast = last\"\n  >\n    <ng-container\n      [ngTemplateOutlet]=\"stepTemplate\"\n      [ngTemplateOutletContext]=\"{step: step, i: i}\"\n    ></ng-container>\n    <div\n      class=\"mat-vertical-content-container\"\n      [class.mat-stepper-vertical-line]=\"!isLast\"\n    >\n      <div\n        class=\"mat-vertical-stepper-content\"\n        role=\"tabpanel\"\n        [@verticalStepTransition]=\"{\n              'value': _getAnimationDirection(i),\n              'params': {'animationDuration': _getAnimationDuration()}\n            }\"\n        (@verticalStepTransition.done)=\"_animationDone.next($event)\"\n        [id]=\"_getStepContentId(i)\"\n        [attr.aria-labelledby]=\"_getStepLabelId(i)\"\n        [attr.aria-expanded]=\"selectedIndex === i\"\n      >\n        <div class=\"mat-vertical-content\">\n          <ng-container [ngTemplateOutlet]=\"step.content\"></ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n</ng-container>\n\n<!-- Common step templating -->\n<ng-template let-step=\"step\" let-i=\"i\" #stepTemplate>\n  <mat-step-header\n    [class.mat-horizontal-stepper-header]=\"orientation === 'horizontal'\"\n    [class.mat-vertical-stepper-header]=\"orientation === 'vertical'\"\n    (click)=\"step.select()\"\n    (keydown)=\"_onKeydown($event)\"\n    [tabIndex]=\"_getFocusIndex() === i ? 0 : -1\"\n    [id]=\"_getStepLabelId(i)\"\n    [attr.aria-posinset]=\"i + 1\"\n    [attr.aria-setsize]=\"steps.length\"\n    [attr.aria-controls]=\"_getStepContentId(i)\"\n    [attr.aria-selected]=\"selectedIndex === i\"\n    [attr.aria-label]=\"step.ariaLabel || null\"\n    [attr.aria-labelledby]=\"(!step.ariaLabel && step.ariaLabelledby) ? step.ariaLabelledby : null\"\n    [attr.aria-disabled]=\"_stepIsNavigable(i, step) ? null : true\"\n    [index]=\"i\"\n    [state]=\"_getIndicatorType(i, step.state)\"\n    [label]=\"step.stepLabel || step.label\"\n    [selected]=\"selectedIndex === i\"\n    [active]=\"_stepIsNavigable(i, step)\"\n    [optional]=\"step.optional\"\n    [errorMessage]=\"step.errorMessage\"\n    [iconOverrides]=\"_iconOverrides\"\n    [disableRipple]=\"disableRipple || !_stepIsNavigable(i, step)\"\n  ></mat-step-header>\n</ng-template>\n"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import { NativeDateAdapter } from '@angular/material/core';
|
|
3
3
|
import { DateTime } from 'luxon';
|
|
4
|
-
import { ONEMRVA_FORMAT } from '../constants/date.format';
|
|
5
4
|
import { Subject, takeUntil } from 'rxjs';
|
|
5
|
+
import { ONEMRVA_FORMAT } from '../constants';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@ngx-translate/core";
|
|
8
8
|
export class OnemrvaDateAdapter extends NativeDateAdapter {
|
|
@@ -59,4 +59,4 @@ export class OnemrvaDateAdapter extends NativeDateAdapter {
|
|
|
59
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: OnemrvaDateAdapter, decorators: [{
|
|
60
60
|
type: Injectable
|
|
61
61
|
}], ctorParameters: () => [{ type: i1.TranslateService }] });
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS5hZGFwdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb25lbXJ2YS9kZXNpZ24tc3lzdGVtL3NoYXJlZC9zcmMvbGliL2FkYXB0ZXJzL2RhdGUuYWRhcHRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQ3RELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzNELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxPQUFPLENBQUM7QUFHakMsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDMUMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7O0FBRzlDLE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxpQkFBaUI7SUFLdkQsWUFBb0IsZ0JBQWtDO1FBQ3BELEtBQUssRUFBRSxDQUFDO1FBRFUscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUo5QyxlQUFVLEdBQUcsY0FBYyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUM7UUFFOUMscUJBQWdCLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUs3QyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNsRCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsWUFBWTthQUMvQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO2FBQ3RDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRTtZQUN0QixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3ZCLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVRLE1BQU0sQ0FBQyxJQUFVO1FBQ3hCLE1BQU0sRUFBRSxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDckMsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBRVEsS0FBSyxDQUFDLEtBQVU7UUFDdkIsSUFBSSxLQUFLLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDdkMsS0FBSyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQ3BDLENBQUM7UUFFRCxJQUFJLEtBQUssS0FBSyxJQUFJLElBQUksS0FBSyxLQUFLLEVBQUUsRUFBRSxDQUFDO1lBQ25DLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUVELE1BQU0sRUFBRSxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDckQsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNO1NBQ3BCLENBQUMsQ0FBQztRQUVILElBQUksRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ2YsT0FBTyxFQUFFLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDdkIsQ0FBQztRQUVELE1BQU0sT0FBTyxHQUFHLENBQUMsVUFBVSxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsV0FBVyxDQUFDLENBQUM7UUFDbkUsS0FBSyxNQUFNLE1BQU0sSUFBSSxPQUFPLEVBQUUsQ0FBQztZQUM3QixNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsVUFBVSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7Z0JBQ2hELE1BQU0sRUFBRSxJQUFJLENBQUMsTUFBTTthQUNwQixDQUFDLENBQUM7WUFDSCxJQUFJLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDbkIsT0FBTyxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDM0IsQ0FBQztRQUNILENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRVEsaUJBQWlCO1FBQ3hCLE9BQU8sQ0FBQyxDQUFDO0lBQ1gsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDN0IsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ25DLENBQUM7OEdBMURVLGtCQUFrQjtrSEFBbEIsa0JBQWtCOzsyRkFBbEIsa0JBQWtCO2tCQUQ5QixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOYXRpdmVEYXRlQWRhcHRlciB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHsgRGF0ZVRpbWUgfSBmcm9tICdsdXhvbic7XG5cbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QsIHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgT05FTVJWQV9GT1JNQVQgfSBmcm9tICcuLi9jb25zdGFudHMnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgT25lbXJ2YURhdGVBZGFwdGVyIGV4dGVuZHMgTmF0aXZlRGF0ZUFkYXB0ZXIgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICBwcml2YXRlIGRhdGVGb3JtYXQgPSBPTkVNUlZBX0ZPUk1BVC5kaXNwbGF5LmRhdGVJbnB1dDtcblxuICBwcml2YXRlIGRlc3Ryb3lOb3RpZmllciQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZSkge1xuICAgIHN1cGVyKCk7XG5cbiAgICB0aGlzLnNldExvY2FsZSh0aGlzLnRyYW5zbGF0ZVNlcnZpY2UuY3VycmVudExhbmcpO1xuICAgIHRoaXMudHJhbnNsYXRlU2VydmljZS5vbkxhbmdDaGFuZ2VcbiAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLmRlc3Ryb3lOb3RpZmllciQpKVxuICAgICAgLnN1YnNjcmliZSgoeyBsYW5nIH0pID0+IHtcbiAgICAgICAgdGhpcy5zZXRMb2NhbGUobGFuZyk7XG4gICAgICB9KTtcbiAgfVxuXG4gIG92ZXJyaWRlIGZvcm1hdChkYXRlOiBEYXRlKTogc3RyaW5nIHtcbiAgICBjb25zdCBkdCA9IERhdGVUaW1lLmZyb21KU0RhdGUoZGF0ZSk7XG4gICAgcmV0dXJuIGR0LnRvRm9ybWF0KHRoaXMuZGF0ZUZvcm1hdCk7XG4gIH1cblxuICBvdmVycmlkZSBwYXJzZSh2YWx1ZTogYW55KTogRGF0ZSB8IG51bGwge1xuICAgIGlmICh2YWx1ZSAmJiB0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICB2YWx1ZSA9IHZhbHVlLnJlcGxhY2UoL1xcRC9nLCAnLycpO1xuICAgIH1cblxuICAgIGlmICh2YWx1ZSA9PT0gbnVsbCB8fCB2YWx1ZSA9PT0gJycpIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIGNvbnN0IGR0ID0gRGF0ZVRpbWUuZnJvbUZvcm1hdCh2YWx1ZSwgdGhpcy5kYXRlRm9ybWF0LCB7XG4gICAgICBsb2NhbGU6IHRoaXMubG9jYWxlLFxuICAgIH0pO1xuXG4gICAgaWYgKGR0LmlzVmFsaWQpIHtcbiAgICAgIHJldHVybiBkdC50b0pTRGF0ZSgpO1xuICAgIH1cblxuICAgIGNvbnN0IGZvcm1hdHMgPSBbJ2RkTU15eXl5JywgJ2QvTS95eXl5JywgJ2RkL00veXl5eScsICdkL01NL3l5eXknXTtcbiAgICBmb3IgKGNvbnN0IGZvcm1hdCBvZiBmb3JtYXRzKSB7XG4gICAgICBjb25zdCBwYXJzZWQgPSBEYXRlVGltZS5mcm9tRm9ybWF0KHZhbHVlLCBmb3JtYXQsIHtcbiAgICAgICAgbG9jYWxlOiB0aGlzLmxvY2FsZSxcbiAgICAgIH0pO1xuICAgICAgaWYgKHBhcnNlZC5pc1ZhbGlkKSB7XG4gICAgICAgIHJldHVybiBwYXJzZWQudG9KU0RhdGUoKTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcy5pbnZhbGlkKCk7XG4gIH1cblxuICBvdmVycmlkZSBnZXRGaXJzdERheU9mV2VlaygpOiBudW1iZXIge1xuICAgIHJldHVybiAxO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5kZXN0cm95Tm90aWZpZXIkLm5leHQoKTtcbiAgICB0aGlzLmRlc3Ryb3lOb3RpZmllciQuY29tcGxldGUoKTtcbiAgfVxufVxuIl19
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import { NativeDateAdapter } from '@angular/material/core';
|
|
3
3
|
import { DateTime } from 'luxon';
|
|
4
|
-
import { ONEMRVA_FORMAT } from '../constants/date.format';
|
|
5
4
|
import { Subject, takeUntil } from 'rxjs';
|
|
5
|
+
import { ONEMRVA_FORMAT } from '../constants';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@ngx-translate/core";
|
|
8
8
|
export class OnemrvaYearMonthAdapter extends NativeDateAdapter {
|
|
9
9
|
constructor(translateService) {
|
|
10
10
|
super();
|
|
11
11
|
this.translateService = translateService;
|
|
12
|
-
this.dateFormat = ONEMRVA_FORMAT.display.
|
|
12
|
+
this.dateFormat = ONEMRVA_FORMAT.display.monthYearLabel;
|
|
13
13
|
this.destroyNotifier$ = new Subject();
|
|
14
14
|
this.setLocale(this.translateService.currentLang);
|
|
15
15
|
this.translateService.onLangChange
|
|
@@ -20,14 +20,12 @@ export class OnemrvaYearMonthAdapter extends NativeDateAdapter {
|
|
|
20
20
|
}
|
|
21
21
|
format(date) {
|
|
22
22
|
const dt = DateTime.fromJSDate(date);
|
|
23
|
-
console.log(dt.toFormat(this.dateFormat));
|
|
24
23
|
return dt.toFormat(this.dateFormat);
|
|
25
24
|
}
|
|
26
25
|
parse(value) {
|
|
27
26
|
if (value && typeof value === 'string') {
|
|
28
27
|
value = value.replace(/\D/g, '/');
|
|
29
28
|
}
|
|
30
|
-
console.warn('*****');
|
|
31
29
|
if (value === null || value === '') {
|
|
32
30
|
return null;
|
|
33
31
|
}
|
|
@@ -61,4 +59,4 @@ export class OnemrvaYearMonthAdapter extends NativeDateAdapter {
|
|
|
61
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: OnemrvaYearMonthAdapter, decorators: [{
|
|
62
60
|
type: Injectable
|
|
63
61
|
}], ctorParameters: () => [{ type: i1.TranslateService }] });
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieWVhci1tb250aC5hZGFwdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb25lbXJ2YS9kZXNpZ24tc3lzdGVtL3NoYXJlZC9zcmMvbGliL2FkYXB0ZXJzL3llYXItbW9udGguYWRhcHRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQ3RELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzNELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxPQUFPLENBQUM7QUFFakMsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFMUMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7O0FBRzlDLE1BQU0sT0FBTyx1QkFDWCxTQUFRLGlCQUFpQjtJQU96QixZQUFvQixnQkFBa0M7UUFDcEQsS0FBSyxFQUFFLENBQUM7UUFEVSxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBSjlDLGVBQVUsR0FBRyxjQUFjLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQztRQUVuRCxxQkFBZ0IsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO1FBSzdDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ2xELElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZO2FBQy9CLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7YUFDdEMsU0FBUyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFO1lBQ3RCLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdkIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRVEsTUFBTSxDQUFDLElBQVU7UUFDeEIsTUFBTSxFQUFFLEdBQUcsUUFBUSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNyQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFUSxLQUFLLENBQUMsS0FBVTtRQUN2QixJQUFJLEtBQUssSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUN2QyxLQUFLLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDcEMsQ0FBQztRQUVELElBQUksS0FBSyxLQUFLLElBQUksSUFBSSxLQUFLLEtBQUssRUFBRSxFQUFFLENBQUM7WUFDbkMsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBRUQsTUFBTSxFQUFFLEdBQUcsUUFBUSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNyRCxNQUFNLEVBQUUsSUFBSSxDQUFDLE1BQU07U0FDcEIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDZixPQUFPLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUN2QixDQUFDO1FBRUQsTUFBTSxPQUFPLEdBQUcsQ0FBQyxRQUFRLEVBQUUsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ2hELEtBQUssTUFBTSxNQUFNLElBQUksT0FBTyxFQUFFLENBQUM7WUFDN0IsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFO2dCQUNoRCxNQUFNLEVBQUUsSUFBSSxDQUFDLE1BQU07YUFDcEIsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxNQUFNLENBQUMsT0FBTyxFQUFFLENBQUM7Z0JBQ25CLE9BQU8sTUFBTSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQzNCLENBQUM7UUFDSCxDQUFDO1FBRUQsT0FBTyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVRLGlCQUFpQjtRQUN4QixPQUFPLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksRUFBRSxDQUFDO1FBQzdCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNuQyxDQUFDOzhHQTdEVSx1QkFBdUI7a0hBQXZCLHVCQUF1Qjs7MkZBQXZCLHVCQUF1QjtrQkFEbkMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmF0aXZlRGF0ZUFkYXB0ZXIgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7IERhdGVUaW1lIH0gZnJvbSAnbHV4b24nO1xuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCwgdGFrZVVudGlsIH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IE9ORU1SVkFfRk9STUFUIH0gZnJvbSAnLi4vY29uc3RhbnRzJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIE9uZW1ydmFZZWFyTW9udGhBZGFwdGVyXG4gIGV4dGVuZHMgTmF0aXZlRGF0ZUFkYXB0ZXJcbiAgaW1wbGVtZW50cyBPbkRlc3Ryb3lcbntcbiAgcHJpdmF0ZSBkYXRlRm9ybWF0ID0gT05FTVJWQV9GT1JNQVQuZGlzcGxheS5tb250aFllYXJMYWJlbDtcblxuICBwcml2YXRlIGRlc3Ryb3lOb3RpZmllciQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZSkge1xuICAgIHN1cGVyKCk7XG5cbiAgICB0aGlzLnNldExvY2FsZSh0aGlzLnRyYW5zbGF0ZVNlcnZpY2UuY3VycmVudExhbmcpO1xuICAgIHRoaXMudHJhbnNsYXRlU2VydmljZS5vbkxhbmdDaGFuZ2VcbiAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLmRlc3Ryb3lOb3RpZmllciQpKVxuICAgICAgLnN1YnNjcmliZSgoeyBsYW5nIH0pID0+IHtcbiAgICAgICAgdGhpcy5zZXRMb2NhbGUobGFuZyk7XG4gICAgICB9KTtcbiAgfVxuXG4gIG92ZXJyaWRlIGZvcm1hdChkYXRlOiBEYXRlKTogc3RyaW5nIHtcbiAgICBjb25zdCBkdCA9IERhdGVUaW1lLmZyb21KU0RhdGUoZGF0ZSk7XG4gICAgcmV0dXJuIGR0LnRvRm9ybWF0KHRoaXMuZGF0ZUZvcm1hdCk7XG4gIH1cblxuICBvdmVycmlkZSBwYXJzZSh2YWx1ZTogYW55KTogRGF0ZSB8IG51bGwge1xuICAgIGlmICh2YWx1ZSAmJiB0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICB2YWx1ZSA9IHZhbHVlLnJlcGxhY2UoL1xcRC9nLCAnLycpO1xuICAgIH1cblxuICAgIGlmICh2YWx1ZSA9PT0gbnVsbCB8fCB2YWx1ZSA9PT0gJycpIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIGNvbnN0IGR0ID0gRGF0ZVRpbWUuZnJvbUZvcm1hdCh2YWx1ZSwgdGhpcy5kYXRlRm9ybWF0LCB7XG4gICAgICBsb2NhbGU6IHRoaXMubG9jYWxlLFxuICAgIH0pO1xuXG4gICAgaWYgKGR0LmlzVmFsaWQpIHtcbiAgICAgIHJldHVybiBkdC50b0pTRGF0ZSgpO1xuICAgIH1cblxuICAgIGNvbnN0IGZvcm1hdHMgPSBbJ01NeXl5eScsICdNL3l5eXknLCAnTU0veXl5eSddO1xuICAgIGZvciAoY29uc3QgZm9ybWF0IG9mIGZvcm1hdHMpIHtcbiAgICAgIGNvbnN0IHBhcnNlZCA9IERhdGVUaW1lLmZyb21Gb3JtYXQodmFsdWUsIGZvcm1hdCwge1xuICAgICAgICBsb2NhbGU6IHRoaXMubG9jYWxlLFxuICAgICAgfSk7XG4gICAgICBpZiAocGFyc2VkLmlzVmFsaWQpIHtcbiAgICAgICAgcmV0dXJuIHBhcnNlZC50b0pTRGF0ZSgpO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiB0aGlzLmludmFsaWQoKTtcbiAgfVxuXG4gIG92ZXJyaWRlIGdldEZpcnN0RGF5T2ZXZWVrKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIDE7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLmRlc3Ryb3lOb3RpZmllciQubmV4dCgpO1xuICAgIHRoaXMuZGVzdHJveU5vdGlmaWVyJC5jb21wbGV0ZSgpO1xuICB9XG59XG4iXX0=
|
|
@@ -9,16 +9,4 @@ export const ONEMRVA_FORMAT = {
|
|
|
9
9
|
monthYearA11yLabel: 'MMMM yyyy',
|
|
10
10
|
},
|
|
11
11
|
};
|
|
12
|
-
|
|
13
|
-
export const ONEMRVA_YEAR_MONTH_FORMAT = {
|
|
14
|
-
parse: {
|
|
15
|
-
dateInput: 'LL/yyyy',
|
|
16
|
-
},
|
|
17
|
-
display: {
|
|
18
|
-
dateInput: 'LL/yyyy',
|
|
19
|
-
monthYearLabel: 'LL/yyyy',
|
|
20
|
-
dateA11yLabel: 'LL',
|
|
21
|
-
monthYearA11yLabel: 'LLL yyyy',
|
|
22
|
-
},
|
|
23
|
-
};
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS5mb3JtYXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vbmVtcnZhL2Rlc2lnbi1zeXN0ZW0vc2hhcmVkL3NyYy9saWIvY29uc3RhbnRzL2RhdGUuZm9ybWF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM1QixLQUFLLEVBQUU7UUFDTCxTQUFTLEVBQUUsSUFBSTtLQUNoQjtJQUNELE9BQU8sRUFBRTtRQUNQLFNBQVMsRUFBRSxZQUFZO1FBQ3ZCLGNBQWMsRUFBRSxVQUFVO1FBQzFCLGFBQWEsRUFBRSxJQUFJO1FBQ25CLGtCQUFrQixFQUFFLFdBQVc7S0FDaEM7Q0FDRixDQUFDO0FBQ0YsU0FBUztBQUNULE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFtQjtJQUN2RCxLQUFLLEVBQUU7UUFDTCxTQUFTLEVBQUUsU0FBUztLQUNyQjtJQUNELE9BQU8sRUFBRTtRQUNQLFNBQVMsRUFBRSxTQUFTO1FBQ3BCLGNBQWMsRUFBRSxTQUFTO1FBQ3pCLGFBQWEsRUFBRSxJQUFJO1FBQ25CLGtCQUFrQixFQUFFLFVBQVU7S0FDL0I7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWF0RGF0ZUZvcm1hdHMgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcblxuZXhwb3J0IGNvbnN0IE9ORU1SVkFfRk9STUFUID0ge1xuICBwYXJzZToge1xuICAgIGRhdGVJbnB1dDogJ0xMJyxcbiAgfSxcbiAgZGlzcGxheToge1xuICAgIGRhdGVJbnB1dDogJ2RkL01NL3l5eXknLFxuICAgIG1vbnRoWWVhckxhYmVsOiAnTU1NIHl5eXknLFxuICAgIGRhdGVBMTF5TGFiZWw6ICdMTCcsXG4gICAgbW9udGhZZWFyQTExeUxhYmVsOiAnTU1NTSB5eXl5JyxcbiAgfSxcbn07XG4vLyBLRUVQID9cbmV4cG9ydCBjb25zdCBPTkVNUlZBX1lFQVJfTU9OVEhfRk9STUFUOiBNYXREYXRlRm9ybWF0cyA9IHtcbiAgcGFyc2U6IHtcbiAgICBkYXRlSW5wdXQ6ICdMTC95eXl5JyxcbiAgfSxcbiAgZGlzcGxheToge1xuICAgIGRhdGVJbnB1dDogJ0xML3l5eXknLFxuICAgIG1vbnRoWWVhckxhYmVsOiAnTEwveXl5eScsXG4gICAgZGF0ZUExMXlMYWJlbDogJ0xMJyxcbiAgICBtb250aFllYXJBMTF5TGFiZWw6ICdMTEwgeXl5eScsXG4gIH0sXG59O1xuIl19
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS5mb3JtYXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vbmVtcnZhL2Rlc2lnbi1zeXN0ZW0vc2hhcmVkL3NyYy9saWIvY29uc3RhbnRzL2RhdGUuZm9ybWF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBbUI7SUFDNUMsS0FBSyxFQUFFO1FBQ0wsU0FBUyxFQUFFLElBQUk7S0FDaEI7SUFDRCxPQUFPLEVBQUU7UUFDUCxTQUFTLEVBQUUsWUFBWTtRQUN2QixjQUFjLEVBQUUsVUFBVTtRQUMxQixhQUFhLEVBQUUsSUFBSTtRQUNuQixrQkFBa0IsRUFBRSxXQUFXO0tBQ2hDO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1hdERhdGVGb3JtYXRzIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBPTkVNUlZBX0ZPUk1BVDogTWF0RGF0ZUZvcm1hdHMgPSB7XG4gIHBhcnNlOiB7XG4gICAgZGF0ZUlucHV0OiAnTEwnLFxuICB9LFxuICBkaXNwbGF5OiB7XG4gICAgZGF0ZUlucHV0OiAnZGQvTU0veXl5eScsXG4gICAgbW9udGhZZWFyTGFiZWw6ICdNTU0geXl5eScsXG4gICAgZGF0ZUExMXlMYWJlbDogJ0xMJyxcbiAgICBtb250aFllYXJBMTF5TGFiZWw6ICdNTU1NIHl5eXknLFxuICB9LFxufTtcbiJdfQ==
|
|
@@ -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: [{
|