@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.
@@ -74,12 +74,12 @@
74
74
  "invalid": "Feld erforderlich"
75
75
  },
76
76
  "phone": {
77
- "required": "Field required",
78
- "invalid": "Field invalid",
79
- "notFound": "Not found",
80
- "search": "Search",
81
- "label": "Phone number",
82
- "hint": "Start with 0 for belgian phone numbers"
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",
@@ -73,12 +73,12 @@
73
73
  "invalid": "Veld verplicht"
74
74
  },
75
75
  "phone": {
76
- "required": "Field required",
77
- "invalid": "Field invalid",
78
- "notFound": "Not found",
79
- "search": "Search",
80
- "label": "Phone number",
81
- "hint": "Start with 0 for belgian phone numbers"
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(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":"AAAA,OAAO,EACL,SAAS,EAET,YAAY,EACZ,WAAW,EACX,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,GAAG,EAAc,IAAI,EAAE,MAAM,MAAM,CAAC;AAC7C,OAAO,EACL,KAAK,EACL,SAAS,EACT,KAAK,EACL,OAAO,EACP,OAAO,EACP,UAAU,GACX,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EACL,WAAW,GAGZ,MAAM,kCAAkC,CAAC;;;;;;;;;;AAK1C,IAAI,OAAO,GAAG,CAAC,CAAC;AAmChB,MAAM,OAAO,6BAA6B;IAkDxC,YACS,MAAiB,EACjB,OAA8B,EAC7B,SAA2B,EAC3B,eAA0C;QAH3C,WAAM,GAAN,MAAM,CAAW;QACjB,YAAO,GAAP,OAAO,CAAuB;QAC7B,cAAS,GAAT,SAAS,CAAkB;QAC3B,oBAAe,GAAf,eAAe,CAA2B;QApDpD,WAAM,GAAa,EAAE,CAAC;QAKtB,gBAAW,GAAG,CAAC,CAAC;QAGhB,kBAAa,GAAG,CAAC,CAAC;QAGlB,iBAAY,GAAG,IAAI,CAAC;QAGpB,iBAAY,GAAmB,EAAE,CAAC;QAGlC,iBAAY,GAAG,EAAE,CAAC;QAGlB,oCAA+B,GAAG,2BAA2B,CAAC;QAQ9D,cAAS,GAAG,IAAI,YAAY,EAAqC,CAAC;QAElE;;;;;;;WAOG;QAGI,WAAM,GAAG,4BAA4B,OAAO,EAAE,EAAE,CAAC;QAKxD,YAAO,GAAG,eAAe,OAAO,EAAE,CAAC;QACnC,yBAAoB,GAAG,EAAE,CAAC;QAQxB,IAAI,CAAC,MAAM,GAAG,eAAe,CAAC,MAAM,CAAC;QAErC,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC;IACvE,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC3B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO;iBAC9B,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC;iBACjC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAC5D,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9C,CAAC;QAED,IAAI,CAAC,oBAAoB,GAAG,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1D,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACxD,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,MAAgB;QAC5B,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;IAED;;OAEG;IACH,iBAAiB,CAAC,MAAa;QAC7B,MAAM,GAAG,GAAG,MAAM,CAAC,MAA0B,EAC3C,KAAK,GAAG,GAAG,CAAC,KAAiB,CAAC;QAEhC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED;;;OAGG;IACH,gBAAgB,CAAC,KAAe;QAC9B,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAC1D,2EAA2E;YAC3E,IACE,IAAI,CAAC,aAAa,GAAG,CAAC;gBACtB,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,EAChD,CAAC;gBACD,iBAAiB;gBACjB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CACxC,4BAA4B,CAC7B,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,sBAAsB;gBACtB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;gBAEvB,MAAM,EAAE,GAAmB,EAAE,CAAC;gBAC9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;oBACtC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBAC3B,IAAI,IAAI,KAAK,IAAI;wBAAE,SAAS;oBAE5B,MAAM,IAAI,GAAiB;wBACzB,IAAI;wBACJ,QAAQ,EAAE,CAAC;wBACX,OAAO,EAAE,EAAE;wBACX,KAAK,EAAE,SAAS;wBAChB,GAAG,EAAE,IAAI;wBACT,EAAE,EAAE,IAAI;wBACR,iBAAiB,EAAE,IAAI,CAAC,YAAY;wBAEpC,IAAI,EAAE,IAAK,CAAC,IAAI;wBAChB,YAAY,EAAE,IAAK,CAAC,YAAY;wBAChC,IAAI,EAAE,IAAK,CAAC,IAAI;wBAChB,IAAI,EAAE,IAAK,CAAC,IAAI;qBACjB,CAAC;oBAEF,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAChB,CAAC;gBAED,IAAI,IAAI,CAAC,YAAY;oBAAE,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;;oBACvD,IAAI,CAAC,eAAe,CAAC,4BAA4B,CAAC,EAAE,CAAC,CAAC;gBAE3D,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC;YAC9C,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;8GA1IU,6BAA6B;kGAA7B,6BAA6B,shBChE1C,uzDA6DA,s8BD3Bc;YACV,OAAO,CAAC,gBAAgB,EAAE;gBACxB,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;gBAClC,UAAU,CAAC,QAAQ,EAAE;oBACnB,OAAO,CACL,GAAG,EACH,SAAS,CAAC;wBACR,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;wBAChC,KAAK,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;wBACtC,KAAK,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;wBACpC,KAAK,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;wBACtC,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;qBACjC,CAAC,CACH;iBACF,CAAC;gBACF,UAAU,CAAC,QAAQ,EAAE;oBACnB,OAAO,CACL,GAAG,EACH,SAAS,CAAC;wBACR,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;wBAChC,KAAK,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;wBACtC,KAAK,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;wBACpC,KAAK,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;wBACtC,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;qBACjC,CAAC,CACH;iBACF,CAAC;aACH,CAAC;SACH;;2FAEU,6BAA6B;kBAjCzC,SAAS;+BACE,yBAAyB,cAEvB;wBACV,OAAO,CAAC,gBAAgB,EAAE;4BACxB,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;4BAClC,UAAU,CAAC,QAAQ,EAAE;gCACnB,OAAO,CACL,GAAG,EACH,SAAS,CAAC;oCACR,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;oCAChC,KAAK,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;oCACtC,KAAK,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;oCACpC,KAAK,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;oCACtC,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;iCACjC,CAAC,CACH;6BACF,CAAC;4BACF,UAAU,CAAC,QAAQ,EAAE;gCACnB,OAAO,CACL,GAAG,EACH,SAAS,CAAC;oCACR,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;oCAChC,KAAK,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;oCACtC,KAAK,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;oCACpC,KAAK,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;oCACtC,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;iCACjC,CAAC,CACH;6BACF,CAAC;yBACH,CAAC;qBACH;yLAID,MAAM;sBADL,KAAK;gBAMN,WAAW;sBADV,KAAK;gBAIN,aAAa;sBADZ,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,+BAA+B;sBAD9B,KAAK;gBAOG,iBAAiB;sBAAzB,KAAK;gBAcC,MAAM;sBAFZ,WAAW;uBAAC,cAAc;;sBAC1B,KAAK;gBAIN,WAAW;sBADV,SAAS;uBAAC,aAAa","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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS5hZGFwdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb25lbXJ2YS9kZXNpZ24tc3lzdGVtL3NoYXJlZC9zcmMvbGliL2FkYXB0ZXJzL2RhdGUuYWRhcHRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQ3RELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzNELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxPQUFPLENBQUM7QUFFakMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRTFELE9BQU8sRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7QUFHMUMsTUFBTSxPQUFPLGtCQUFtQixTQUFRLGlCQUFpQjtJQUt2RCxZQUFvQixnQkFBa0M7UUFDcEQsS0FBSyxFQUFFLENBQUM7UUFEVSxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBSjlDLGVBQVUsR0FBRyxjQUFjLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQztRQUU5QyxxQkFBZ0IsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO1FBSzdDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ2xELElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZO2FBQy9CLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7YUFDdEMsU0FBUyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFO1lBQ3RCLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdkIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRVEsTUFBTSxDQUFDLElBQVU7UUFDeEIsTUFBTSxFQUFFLEdBQUcsUUFBUSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNyQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFUSxLQUFLLENBQUMsS0FBVTtRQUN2QixJQUFJLEtBQUssSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUN2QyxLQUFLLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDcEMsQ0FBQztRQUVELElBQUksS0FBSyxLQUFLLElBQUksSUFBSSxLQUFLLEtBQUssRUFBRSxFQUFFLENBQUM7WUFDbkMsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBRUQsTUFBTSxFQUFFLEdBQUcsUUFBUSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNyRCxNQUFNLEVBQUUsSUFBSSxDQUFDLE1BQU07U0FDcEIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDZixPQUFPLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUN2QixDQUFDO1FBRUQsTUFBTSxPQUFPLEdBQUcsQ0FBQyxVQUFVLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxXQUFXLENBQUMsQ0FBQztRQUNuRSxLQUFLLE1BQU0sTUFBTSxJQUFJLE9BQU8sRUFBRSxDQUFDO1lBQzdCLE1BQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRTtnQkFDaEQsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNO2FBQ3BCLENBQUMsQ0FBQztZQUNILElBQUksTUFBTSxDQUFDLE9BQU8sRUFBRSxDQUFDO2dCQUNuQixPQUFPLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUMzQixDQUFDO1FBQ0gsQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFUSxpQkFBaUI7UUFDeEIsT0FBTyxDQUFDLENBQUM7SUFDWCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUM3QixJQUFJLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDbkMsQ0FBQzs4R0ExRFUsa0JBQWtCO2tIQUFsQixrQkFBa0I7OzJGQUFsQixrQkFBa0I7a0JBRDlCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5hdGl2ZURhdGVBZGFwdGVyIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5pbXBvcnQgeyBEYXRlVGltZSB9IGZyb20gJ2x1eG9uJztcblxuaW1wb3J0IHsgT05FTVJWQV9GT1JNQVQgfSBmcm9tICcuLi9jb25zdGFudHMvZGF0ZS5mb3JtYXQnO1xuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCwgdGFrZVVudGlsIH0gZnJvbSAncnhqcyc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBPbmVtcnZhRGF0ZUFkYXB0ZXIgZXh0ZW5kcyBOYXRpdmVEYXRlQWRhcHRlciBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gIHByaXZhdGUgZGF0ZUZvcm1hdCA9IE9ORU1SVkFfRk9STUFULmRpc3BsYXkuZGF0ZUlucHV0O1xuXG4gIHByaXZhdGUgZGVzdHJveU5vdGlmaWVyJCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSB0cmFuc2xhdGVTZXJ2aWNlOiBUcmFuc2xhdGVTZXJ2aWNlKSB7XG4gICAgc3VwZXIoKTtcblxuICAgIHRoaXMuc2V0TG9jYWxlKHRoaXMudHJhbnNsYXRlU2VydmljZS5jdXJyZW50TGFuZyk7XG4gICAgdGhpcy50cmFuc2xhdGVTZXJ2aWNlLm9uTGFuZ0NoYW5nZVxuICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMuZGVzdHJveU5vdGlmaWVyJCkpXG4gICAgICAuc3Vic2NyaWJlKCh7IGxhbmcgfSkgPT4ge1xuICAgICAgICB0aGlzLnNldExvY2FsZShsYW5nKTtcbiAgICAgIH0pO1xuICB9XG5cbiAgb3ZlcnJpZGUgZm9ybWF0KGRhdGU6IERhdGUpOiBzdHJpbmcge1xuICAgIGNvbnN0IGR0ID0gRGF0ZVRpbWUuZnJvbUpTRGF0ZShkYXRlKTtcbiAgICByZXR1cm4gZHQudG9Gb3JtYXQodGhpcy5kYXRlRm9ybWF0KTtcbiAgfVxuXG4gIG92ZXJyaWRlIHBhcnNlKHZhbHVlOiBhbnkpOiBEYXRlIHwgbnVsbCB7XG4gICAgaWYgKHZhbHVlICYmIHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHZhbHVlID0gdmFsdWUucmVwbGFjZSgvXFxEL2csICcvJyk7XG4gICAgfVxuXG4gICAgaWYgKHZhbHVlID09PSBudWxsIHx8IHZhbHVlID09PSAnJykge1xuICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuXG4gICAgY29uc3QgZHQgPSBEYXRlVGltZS5mcm9tRm9ybWF0KHZhbHVlLCB0aGlzLmRhdGVGb3JtYXQsIHtcbiAgICAgIGxvY2FsZTogdGhpcy5sb2NhbGUsXG4gICAgfSk7XG5cbiAgICBpZiAoZHQuaXNWYWxpZCkge1xuICAgICAgcmV0dXJuIGR0LnRvSlNEYXRlKCk7XG4gICAgfVxuXG4gICAgY29uc3QgZm9ybWF0cyA9IFsnZGRNTXl5eXknLCAnZC9NL3l5eXknLCAnZGQvTS95eXl5JywgJ2QvTU0veXl5eSddO1xuICAgIGZvciAoY29uc3QgZm9ybWF0IG9mIGZvcm1hdHMpIHtcbiAgICAgIGNvbnN0IHBhcnNlZCA9IERhdGVUaW1lLmZyb21Gb3JtYXQodmFsdWUsIGZvcm1hdCwge1xuICAgICAgICBsb2NhbGU6IHRoaXMubG9jYWxlLFxuICAgICAgfSk7XG4gICAgICBpZiAocGFyc2VkLmlzVmFsaWQpIHtcbiAgICAgICAgcmV0dXJuIHBhcnNlZC50b0pTRGF0ZSgpO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiB0aGlzLmludmFsaWQoKTtcbiAgfVxuXG4gIG92ZXJyaWRlIGdldEZpcnN0RGF5T2ZXZWVrKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIDE7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLmRlc3Ryb3lOb3RpZmllciQubmV4dCgpO1xuICAgIHRoaXMuZGVzdHJveU5vdGlmaWVyJC5jb21wbGV0ZSgpO1xuICB9XG59XG4iXX0=
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.dateInput;
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieWVhci1tb250aC5hZGFwdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb25lbXJ2YS9kZXNpZ24tc3lzdGVtL3NoYXJlZC9zcmMvbGliL2FkYXB0ZXJzL3llYXItbW9udGguYWRhcHRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQ3RELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzNELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxPQUFPLENBQUM7QUFFakMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRTFELE9BQU8sRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7QUFHMUMsTUFBTSxPQUFPLHVCQUNYLFNBQVEsaUJBQWlCO0lBT3pCLFlBQW9CLGdCQUFrQztRQUNwRCxLQUFLLEVBQUUsQ0FBQztRQURVLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFKOUMsZUFBVSxHQUFHLGNBQWMsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDO1FBRTlDLHFCQUFnQixHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFLN0MsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDbEQsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFlBQVk7YUFDL0IsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQzthQUN0QyxTQUFTLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUU7WUFDdEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN2QixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFUSxNQUFNLENBQUMsSUFBVTtRQUN4QixNQUFNLEVBQUUsR0FBRyxRQUFRLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztRQUMxQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFUSxLQUFLLENBQUMsS0FBVTtRQUN2QixJQUFJLEtBQUssSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUN2QyxLQUFLLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDcEMsQ0FBQztRQUNELE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFdEIsSUFBSSxLQUFLLEtBQUssSUFBSSxJQUFJLEtBQUssS0FBSyxFQUFFLEVBQUUsQ0FBQztZQUNuQyxPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFFRCxNQUFNLEVBQUUsR0FBRyxRQUFRLENBQUMsVUFBVSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQ3JELE1BQU0sRUFBRSxJQUFJLENBQUMsTUFBTTtTQUNwQixDQUFDLENBQUM7UUFFSCxJQUFJLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNmLE9BQU8sRUFBRSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ3ZCLENBQUM7UUFFRCxNQUFNLE9BQU8sR0FBRyxDQUFDLFFBQVEsRUFBRSxRQUFRLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDaEQsS0FBSyxNQUFNLE1BQU0sSUFBSSxPQUFPLEVBQUUsQ0FBQztZQUM3QixNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsVUFBVSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUU7Z0JBQ2hELE1BQU0sRUFBRSxJQUFJLENBQUMsTUFBTTthQUNwQixDQUFDLENBQUM7WUFDSCxJQUFJLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDbkIsT0FBTyxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDM0IsQ0FBQztRQUNILENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRVEsaUJBQWlCO1FBQ3hCLE9BQU8sQ0FBQyxDQUFDO0lBQ1gsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDN0IsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ25DLENBQUM7OEdBL0RVLHVCQUF1QjtrSEFBdkIsdUJBQXVCOzsyRkFBdkIsdUJBQXVCO2tCQURuQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOYXRpdmVEYXRlQWRhcHRlciB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHsgRGF0ZVRpbWUgfSBmcm9tICdsdXhvbic7XG5cbmltcG9ydCB7IE9ORU1SVkFfRk9STUFUIH0gZnJvbSAnLi4vY29uc3RhbnRzL2RhdGUuZm9ybWF0JztcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QsIHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgT25lbXJ2YVllYXJNb250aEFkYXB0ZXJcbiAgZXh0ZW5kcyBOYXRpdmVEYXRlQWRhcHRlclxuICBpbXBsZW1lbnRzIE9uRGVzdHJveVxue1xuICBwcml2YXRlIGRhdGVGb3JtYXQgPSBPTkVNUlZBX0ZPUk1BVC5kaXNwbGF5LmRhdGVJbnB1dDtcblxuICBwcml2YXRlIGRlc3Ryb3lOb3RpZmllciQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZSkge1xuICAgIHN1cGVyKCk7XG5cbiAgICB0aGlzLnNldExvY2FsZSh0aGlzLnRyYW5zbGF0ZVNlcnZpY2UuY3VycmVudExhbmcpO1xuICAgIHRoaXMudHJhbnNsYXRlU2VydmljZS5vbkxhbmdDaGFuZ2VcbiAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLmRlc3Ryb3lOb3RpZmllciQpKVxuICAgICAgLnN1YnNjcmliZSgoeyBsYW5nIH0pID0+IHtcbiAgICAgICAgdGhpcy5zZXRMb2NhbGUobGFuZyk7XG4gICAgICB9KTtcbiAgfVxuXG4gIG92ZXJyaWRlIGZvcm1hdChkYXRlOiBEYXRlKTogc3RyaW5nIHtcbiAgICBjb25zdCBkdCA9IERhdGVUaW1lLmZyb21KU0RhdGUoZGF0ZSk7XG4gICAgY29uc29sZS5sb2coZHQudG9Gb3JtYXQodGhpcy5kYXRlRm9ybWF0KSk7XG4gICAgcmV0dXJuIGR0LnRvRm9ybWF0KHRoaXMuZGF0ZUZvcm1hdCk7XG4gIH1cblxuICBvdmVycmlkZSBwYXJzZSh2YWx1ZTogYW55KTogRGF0ZSB8IG51bGwge1xuICAgIGlmICh2YWx1ZSAmJiB0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICB2YWx1ZSA9IHZhbHVlLnJlcGxhY2UoL1xcRC9nLCAnLycpO1xuICAgIH1cbiAgICBjb25zb2xlLndhcm4oJyoqKioqJyk7XG5cbiAgICBpZiAodmFsdWUgPT09IG51bGwgfHwgdmFsdWUgPT09ICcnKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICBjb25zdCBkdCA9IERhdGVUaW1lLmZyb21Gb3JtYXQodmFsdWUsIHRoaXMuZGF0ZUZvcm1hdCwge1xuICAgICAgbG9jYWxlOiB0aGlzLmxvY2FsZSxcbiAgICB9KTtcblxuICAgIGlmIChkdC5pc1ZhbGlkKSB7XG4gICAgICByZXR1cm4gZHQudG9KU0RhdGUoKTtcbiAgICB9XG5cbiAgICBjb25zdCBmb3JtYXRzID0gWydNTXl5eXknLCAnTS95eXl5JywgJ01NL3l5eXknXTtcbiAgICBmb3IgKGNvbnN0IGZvcm1hdCBvZiBmb3JtYXRzKSB7XG4gICAgICBjb25zdCBwYXJzZWQgPSBEYXRlVGltZS5mcm9tRm9ybWF0KHZhbHVlLCBmb3JtYXQsIHtcbiAgICAgICAgbG9jYWxlOiB0aGlzLmxvY2FsZSxcbiAgICAgIH0pO1xuICAgICAgaWYgKHBhcnNlZC5pc1ZhbGlkKSB7XG4gICAgICAgIHJldHVybiBwYXJzZWQudG9KU0RhdGUoKTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcy5pbnZhbGlkKCk7XG4gIH1cblxuICBvdmVycmlkZSBnZXRGaXJzdERheU9mV2VlaygpOiBudW1iZXIge1xuICAgIHJldHVybiAxO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5kZXN0cm95Tm90aWZpZXIkLm5leHQoKTtcbiAgICB0aGlzLmRlc3Ryb3lOb3RpZmllciQuY29tcGxldGUoKTtcbiAgfVxufVxuIl19
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
- // KEEP ?
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(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: [{