@onemrvapublic/design-system 18.2.14 → 18.2.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/mat-file-upload/src/components/onemrva-mat-file-upload/onemrva-mat-file-upload.component.mjs +43 -32
- package/esm2022/mat-input-iban/src/onemrva-mat-input-iban.component.mjs +10 -6
- package/esm2022/mat-select-search/src/mat-select-search.component.mjs +2 -2
- package/esm2022/shared/index.mjs +2 -3
- package/esm2022/shared/src/lib/constants/date.format.mjs +85 -4
- package/esm2022/shared/src/lib/helpers/translation-helper.mjs +1 -1
- package/esm2022/shared/src/lib/loaders/index.mjs +2 -2
- package/esm2022/shared/src/lib/modules/index.mjs +5 -0
- package/esm2022/shared/src/lib/modules/shared.datepicker.luxon.module.mjs +46 -0
- package/esm2022/shared/src/lib/modules/shared.datepicker.luxon.year.month.module.mjs +46 -0
- package/esm2022/shared/src/lib/modules/shared.datepicker.native.module.mjs +51 -0
- package/esm2022/shared/src/lib/modules/shared.datepicker.native.year.month.module.mjs +51 -0
- 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-input-iban.mjs +9 -5
- package/fesm2022/onemrvapublic-design-system-mat-input-iban.mjs.map +1 -1
- package/fesm2022/onemrvapublic-design-system-mat-select-search.mjs +1 -1
- package/fesm2022/onemrvapublic-design-system-mat-select-search.mjs.map +1 -1
- package/fesm2022/onemrvapublic-design-system-shared.mjs +248 -179
- 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-input-iban/src/onemrva-mat-input-iban.component.d.ts +2 -1
- package/package.json +1 -1
- package/shared/index.d.ts +1 -2
- package/shared/src/lib/constants/date.format.d.ts +4 -1
- package/shared/src/lib/loaders/index.d.ts +1 -1
- package/shared/src/lib/modules/index.d.ts +4 -0
- package/shared/src/lib/modules/shared.datepicker.luxon.module.d.ts +12 -0
- package/shared/src/lib/modules/shared.datepicker.luxon.year.month.module.d.ts +12 -0
- package/shared/src/lib/{shared.datepicker.module.d.ts → modules/shared.datepicker.native.module.d.ts} +3 -0
- package/shared/src/lib/modules/shared.datepicker.native.year.month.module.d.ts +12 -0
- package/esm2022/shared/src/lib/adapters/date.adapter.mjs +0 -62
- package/esm2022/shared/src/lib/adapters/index.mjs +0 -3
- package/esm2022/shared/src/lib/adapters/year-month.adapter.mjs +0 -62
- package/esm2022/shared/src/lib/shared.datepicker.module.mjs +0 -71
- package/shared/src/lib/adapters/date.adapter.d.ts +0 -16
- package/shared/src/lib/adapters/index.d.ts +0 -2
- package/shared/src/lib/adapters/year-month.adapter.d.ts +0 -16
|
@@ -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"]}
|
|
@@ -19,7 +19,8 @@ import * as i4 from "@angular/material/input";
|
|
|
19
19
|
import * as i5 from "@angular/material/select";
|
|
20
20
|
import * as i6 from "@angular/material/core";
|
|
21
21
|
import * as i7 from "@onemrvapublic/design-system/mat-select-search";
|
|
22
|
-
import * as i8 from "@
|
|
22
|
+
import * as i8 from "@ngx-translate/core";
|
|
23
|
+
import * as i9 from "@angular/material/form-field";
|
|
23
24
|
export class OnemrvaMatInputIbanComponent {
|
|
24
25
|
static { this.nextId = 0; }
|
|
25
26
|
get bbanField() {
|
|
@@ -37,6 +38,7 @@ export class OnemrvaMatInputIbanComponent {
|
|
|
37
38
|
this.noEntriesFoundLabel = 'Not found';
|
|
38
39
|
this.placeholderLabel = 'Search';
|
|
39
40
|
this.searchAriaLabel = 'Search';
|
|
41
|
+
this.label = 'IBAN';
|
|
40
42
|
this.getCountry = new EventEmitter();
|
|
41
43
|
this.countryCodes$ = of([]);
|
|
42
44
|
this.filterCtrl = new FormControl('');
|
|
@@ -223,9 +225,9 @@ export class OnemrvaMatInputIbanComponent {
|
|
|
223
225
|
}
|
|
224
226
|
}
|
|
225
227
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: OnemrvaMatInputIbanComponent, deps: [{ token: i1.FormBuilder }, { token: i2.FocusMonitor }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: MAT_FORM_FIELD, optional: true }, { token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
226
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: OnemrvaMatInputIbanComponent, isStandalone: true, selector: "onemrva-mat-input-iban", inputs: { noEntriesFoundLabel: "noEntriesFoundLabel", placeholderLabel: "placeholderLabel", searchAriaLabel: "searchAriaLabel", value: "value", readonly: "readonly", disabled: "disabled", placeholder: "placeholder", required: "required" }, outputs: { getCountry: "getCountry" }, providers: [
|
|
228
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: OnemrvaMatInputIbanComponent, isStandalone: true, selector: "onemrva-mat-input-iban", inputs: { noEntriesFoundLabel: "noEntriesFoundLabel", placeholderLabel: "placeholderLabel", searchAriaLabel: "searchAriaLabel", label: "label", value: "value", readonly: "readonly", disabled: "disabled", placeholder: "placeholder", required: "required" }, outputs: { getCountry: "getCountry" }, providers: [
|
|
227
229
|
{ provide: MatFormFieldControl, useExisting: OnemrvaMatInputIbanComponent },
|
|
228
|
-
], viewQueries: [{ propertyName: "countryCode", first: true, predicate: ["countryCode"], descendants: true }, { propertyName: "bban", first: true, predicate: ["bban"], descendants: true }], ngImport: i0, template: "<ng-container [formGroup]=\"parts\">\n <!-- <mat-form-field class=\"onemrva-input-iban\">-->\n <!-- <mat-label>{{ label }}</mat-label>-->\n <div class=\"iban-fields\">\n <div class=\"iban-prefix\">\n <mat-select\n class=\"onemrva-iban-select\"\n formControlName=\"countryCode\"\n (selectionChange)=\"_handleInput(parts.controls.countryCode)\"\n #countryCode\n >\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n [ariaLabel]=\"searchAriaLabel\"\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n [placeholderLabel]=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n\n <mat-option\n *ngFor=\"let country of countryCodes$ | async\"\n [value]=\"country\"\n >\n <span>{{ country }}</span>\n </mat-option>\n </mat-select>\n </div>\n <input\n (click)=\"handleClick($event)\"\n matInput\n [placeholder]=\"placeholderIban\"\n formControlName=\"bban\"\n class=\"onemrva-text-number\"\n [readOnly]=\"readonly\"\n (input)=\"_handleInput(parts.controls.bban)\"\n (keyup)=\"onKeyup($event)\"\n #bban\n />\n </div>\n <!-- <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>-->\n <!-- <mat-error >{{ 'error' | translate }}</mat-error>-->\n <!-- </mat-form-field>-->\n\n <!-- {{ parts.errors |json }}-->\n</ng-container>\n", styles: ["onemrva-mat-input-iban{width:100%}onemrva-mat-input-iban .iban-fields{display:flex}onemrva-mat-input-iban .iban-fields .iban-prefix{width:40px;margin-right:8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatSelectSearchModule }, { kind: "component", type: i7.MatSelectSearchComponent, selector: "mat-select-search", inputs: ["placeholderLabel", "type", "closeIcon", "closeSvgIcon", "noEntriesFoundLabel", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toggleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: TranslateModule }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
230
|
+
], viewQueries: [{ propertyName: "countryCode", first: true, predicate: ["countryCode"], descendants: true }, { propertyName: "bban", first: true, predicate: ["bban"], descendants: true }], ngImport: i0, template: "<ng-container [formGroup]=\"parts\">\n <!-- <mat-form-field class=\"onemrva-input-iban\">-->\n <!-- <mat-label>{{ label }}</mat-label>-->\n <div class=\"iban-fields\">\n <div class=\"iban-prefix\">\n <mat-select\n class=\"onemrva-iban-select\"\n formControlName=\"countryCode\"\n [attr.aria-label]=\"'Country' | translate\"\n (selectionChange)=\"_handleInput(parts.controls.countryCode)\"\n #countryCode\n >\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n [ariaLabel]=\"searchAriaLabel\"\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n [placeholderLabel]=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n\n <mat-option\n *ngFor=\"let country of countryCodes$ | async\"\n [value]=\"country\"\n >\n <span>{{ country }}</span>\n </mat-option>\n </mat-select>\n </div>\n <input\n [attr.aria-label]=\"label\"\n (click)=\"handleClick($event)\"\n matInput\n [placeholder]=\"placeholderIban\"\n formControlName=\"bban\"\n class=\"onemrva-text-number\"\n [readOnly]=\"readonly\"\n (input)=\"_handleInput(parts.controls.bban)\"\n (keyup)=\"onKeyup($event)\"\n #bban\n />\n </div>\n <!-- <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>-->\n <!-- <mat-error >{{ 'error' | translate }}</mat-error>-->\n <!-- </mat-form-field>-->\n\n <!-- {{ parts.errors |json }}-->\n</ng-container>\n", styles: ["onemrva-mat-input-iban{width:100%}onemrva-mat-input-iban .iban-fields{display:flex}onemrva-mat-input-iban .iban-fields .iban-prefix{width:40px;margin-right:8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatSelectSearchModule }, { kind: "component", type: i7.MatSelectSearchComponent, selector: "mat-select-search", inputs: ["placeholderLabel", "type", "closeIcon", "closeSvgIcon", "noEntriesFoundLabel", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toggleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
229
231
|
}
|
|
230
232
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: OnemrvaMatInputIbanComponent, decorators: [{
|
|
231
233
|
type: Component,
|
|
@@ -240,8 +242,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
240
242
|
MatPrefix,
|
|
241
243
|
], encapsulation: ViewEncapsulation.None, providers: [
|
|
242
244
|
{ provide: MatFormFieldControl, useExisting: OnemrvaMatInputIbanComponent },
|
|
243
|
-
], template: "<ng-container [formGroup]=\"parts\">\n <!-- <mat-form-field class=\"onemrva-input-iban\">-->\n <!-- <mat-label>{{ label }}</mat-label>-->\n <div class=\"iban-fields\">\n <div class=\"iban-prefix\">\n <mat-select\n class=\"onemrva-iban-select\"\n formControlName=\"countryCode\"\n (selectionChange)=\"_handleInput(parts.controls.countryCode)\"\n #countryCode\n >\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n [ariaLabel]=\"searchAriaLabel\"\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n [placeholderLabel]=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n\n <mat-option\n *ngFor=\"let country of countryCodes$ | async\"\n [value]=\"country\"\n >\n <span>{{ country }}</span>\n </mat-option>\n </mat-select>\n </div>\n <input\n (click)=\"handleClick($event)\"\n matInput\n [placeholder]=\"placeholderIban\"\n formControlName=\"bban\"\n class=\"onemrva-text-number\"\n [readOnly]=\"readonly\"\n (input)=\"_handleInput(parts.controls.bban)\"\n (keyup)=\"onKeyup($event)\"\n #bban\n />\n </div>\n <!-- <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>-->\n <!-- <mat-error >{{ 'error' | translate }}</mat-error>-->\n <!-- </mat-form-field>-->\n\n <!-- {{ parts.errors |json }}-->\n</ng-container>\n", styles: ["onemrva-mat-input-iban{width:100%}onemrva-mat-input-iban .iban-fields{display:flex}onemrva-mat-input-iban .iban-fields .iban-prefix{width:40px;margin-right:8px}\n"] }]
|
|
244
|
-
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.FocusMonitor }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type:
|
|
245
|
+
], template: "<ng-container [formGroup]=\"parts\">\n <!-- <mat-form-field class=\"onemrva-input-iban\">-->\n <!-- <mat-label>{{ label }}</mat-label>-->\n <div class=\"iban-fields\">\n <div class=\"iban-prefix\">\n <mat-select\n class=\"onemrva-iban-select\"\n formControlName=\"countryCode\"\n [attr.aria-label]=\"'Country' | translate\"\n (selectionChange)=\"_handleInput(parts.controls.countryCode)\"\n #countryCode\n >\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n [ariaLabel]=\"searchAriaLabel\"\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n [placeholderLabel]=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n\n <mat-option\n *ngFor=\"let country of countryCodes$ | async\"\n [value]=\"country\"\n >\n <span>{{ country }}</span>\n </mat-option>\n </mat-select>\n </div>\n <input\n [attr.aria-label]=\"label\"\n (click)=\"handleClick($event)\"\n matInput\n [placeholder]=\"placeholderIban\"\n formControlName=\"bban\"\n class=\"onemrva-text-number\"\n [readOnly]=\"readonly\"\n (input)=\"_handleInput(parts.controls.bban)\"\n (keyup)=\"onKeyup($event)\"\n #bban\n />\n </div>\n <!-- <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>-->\n <!-- <mat-error >{{ 'error' | translate }}</mat-error>-->\n <!-- </mat-form-field>-->\n\n <!-- {{ parts.errors |json }}-->\n</ng-container>\n", styles: ["onemrva-mat-input-iban{width:100%}onemrva-mat-input-iban .iban-fields{display:flex}onemrva-mat-input-iban .iban-fields .iban-prefix{width:40px;margin-right:8px}\n"] }]
|
|
246
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.FocusMonitor }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i9.MatFormField, decorators: [{
|
|
245
247
|
type: Optional
|
|
246
248
|
}, {
|
|
247
249
|
type: Inject,
|
|
@@ -262,6 +264,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
262
264
|
type: Input
|
|
263
265
|
}], searchAriaLabel: [{
|
|
264
266
|
type: Input
|
|
267
|
+
}], label: [{
|
|
268
|
+
type: Input
|
|
265
269
|
}], getCountry: [{
|
|
266
270
|
type: Output
|
|
267
271
|
}], value: [{
|
|
@@ -275,4 +279,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
275
279
|
}], required: [{
|
|
276
280
|
type: Input
|
|
277
281
|
}] } });
|
|
278
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onemrva-mat-input-iban.component.js","sourceRoot":"","sources":["../../../../../../projects/onemrva/design-system/mat-input-iban/src/onemrva-mat-input-iban.component.ts","../../../../../../projects/onemrva/design-system/mat-input-iban/src/onemrva-mat-input-iban.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  NgControl,\n  ReactiveFormsModule,\n  ValidationErrors,\n  Validators,\n} from '@angular/forms';\nimport {\n  MAT_FORM_FIELD,\n  MatFormField,\n  MatFormFieldControl,\n  MatFormFieldModule,\n  MatPrefix,\n} from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\nimport { TranslateModule } from '@ngx-translate/core';\nimport {\n  combineLatestWith,\n  distinctUntilChanged,\n  Observable,\n  of,\n  pairwise,\n  startWith,\n  Subject,\n  takeUntil,\n} from 'rxjs';\nimport { MatSelectSearchModule } from '@onemrvapublic/design-system/mat-select-search';\nimport { IBAN_SUPPORTED_COUNTRIES } from '@onemrvapublic/design-system/shared';\nimport { map } from 'rxjs/operators';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  countrySpecs,\n  extractIBAN,\n  friendlyFormatIBAN,\n  isValidIBAN,\n} from 'ibantools';\nimport { FocusMonitor } from '@angular/cdk/a11y';\n\n@Component({\n  selector: 'onemrva-mat-input-iban',\n  styleUrls: ['onemrva-mat-input-iban.component.scss'],\n  templateUrl: 'onemrva-mat-input-iban.component.html',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatInputModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    MatSelectSearchModule,\n    ReactiveFormsModule,\n    TranslateModule,\n    MatPrefix,\n  ],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    { provide: MatFormFieldControl, useExisting: OnemrvaMatInputIbanComponent },\n  ],\n})\nexport class OnemrvaMatInputIbanComponent\n  implements\n    ControlValueAccessor,\n    MatFormFieldControl<string>,\n    OnInit,\n    OnDestroy\n{\n  @ViewChild('countryCode') countryCode!: HTMLInputElement;\n  @ViewChild('bban') bban!: HTMLInputElement;\n\n  static nextId = 0;\n\n  @Input() noEntriesFoundLabel = 'Not found';\n  @Input() placeholderLabel = 'Search';\n  @Input() searchAriaLabel = 'Search';\n\n  @Output() getCountry = new EventEmitter<any>();\n\n  countryCodes$: Observable<any> = of([]);\n\n  public filterCtrl: FormControl<string | null> = new FormControl<string>('');\n\n  destroyNotifier$ = new Subject<void>();\n  placeholderIban = '';\n\n  controlType = 'bank-account-input';\n  stateChanges = new Subject<void>();\n  focused = false;\n  id = `bank-account-input-${OnemrvaMatInputIbanComponent.nextId++}`;\n  touched = false;\n\n  parts: FormGroup<{\n    countryCode: FormControl<string | null>;\n    bban: FormControl<string | null>;\n  }>;\n\n  get bbanField() {\n    return this.parts.get('bban') as FormControl;\n  }\n  get countryCodeField() {\n    return this.parts.get('countryCode') as FormControl;\n  }\n\n  constructor(\n    formBuilder: FormBuilder,\n    private _focusMonitor: FocusMonitor,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _cd: ChangeDetectorRef,\n    @Optional() @Inject(MAT_FORM_FIELD) public _formField: MatFormField,\n    @Optional() @Self() public ngControl: NgControl,\n  ) {\n    this.ngControl.valueAccessor = this;\n\n    this.parts = formBuilder.group({\n      countryCode: ['', [Validators.maxLength(2)]],\n      bban: ['', []],\n    });\n  }\n\n  errors(): ValidationErrors | null {\n    return this.parts.errors;\n  }\n\n  onChange = (_: any) => {\n    //\n  };\n  onTouched = () => {\n    //\n  };\n\n  get errorState(): boolean {\n    const control = this.ngControl?.control;\n    return !!(control && control.invalid && (control.dirty || control.touched));\n  }\n\n  get shouldLabelFloat() {\n    return this.focused || !this.empty;\n  }\n\n  get empty() {\n    const {\n      value: { countryCode, bban },\n    } = this.parts;\n\n    return !countryCode && !bban;\n  }\n\n  @Input()\n  get value(): string {\n    const {\n      value: { countryCode, bban },\n    } = this.parts;\n    return `${countryCode ?? ''}${bban ?? ''}`;\n  }\n\n  set value(iban: string | null) {\n    const { countryCode, bban } = extractIBAN(iban || '');\n\n    this.parts.setValue({\n      countryCode: countryCode || null,\n      bban: bban || null,\n    });\n    this.stateChanges.next();\n  }\n\n  @Input()\n  readonly = false;\n\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  set disabled(value: BooleanInput) {\n    this._disabled = coerceBooleanProperty(value);\n    // eslint-disable-next-line @typescript-eslint/no-unused-expressions\n    this._disabled ? this.parts.disable() : this.parts.enable();\n    this.stateChanges.next();\n  }\n\n  private _disabled = false;\n\n  @Input()\n  get placeholder(): string {\n    return this._placeholder;\n  }\n\n  set placeholder(value: string) {\n    this._placeholder = value;\n    this.stateChanges.next();\n  }\n\n  private _placeholder = '';\n\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n\n  set required(value: BooleanInput) {\n    this._required = coerceBooleanProperty(value);\n    this.stateChanges.next();\n  }\n  private _required = false;\n\n  updateNumber(number: string) {\n    let shownValue = number.replace(/[^a-zA-Z0-9]/g, '');\n    // BE45063712751789\n    const fullNumber = this.countryCodeField.value + number;\n    if (isValidIBAN(fullNumber)) {\n      const formattedValue = friendlyFormatIBAN(fullNumber);\n      if (formattedValue !== null) {\n        shownValue = formattedValue.substring(2);\n      }\n    }\n    this.bbanField.patchValue(shownValue, { emitEvent: false });\n  }\n\n  ngOnInit(): void {\n    this.countryCodes$ = this.getCountryCodes();\n\n    this.bbanField.valueChanges\n      .pipe(\n        startWith(this.bbanField.getRawValue()),\n        takeUntil(this.destroyNotifier$),\n      )\n      .subscribe(number => {\n        if (number !== null && number !== '') {\n          if (this.firstTwoCharsAreLetters(number)) {\n            const code = number?.substring(0, 2).toUpperCase();\n            const country = IBAN_SUPPORTED_COUNTRIES.find(\n              country => country == code,\n            );\n            this.countryCodeField.setValue(country);\n            number = number.substring(2);\n          }\n          this.updateNumber(number);\n        }\n      });\n\n    this.countryCodeField.valueChanges\n      .pipe(\n        startWith(''),\n        pairwise(),\n        distinctUntilChanged(),\n        takeUntil(this.destroyNotifier$),\n      )\n      .subscribe(([_prevIban, countryCode]) => {\n        this.placeholderIban = '';\n        this.touched = true;\n        if (!countryCode || countryCode.length < 2) {\n          return;\n        }\n\n        if (this.firstTwoCharsAreLetters(countryCode)) {\n          const r: number | undefined = countrySpecs[countryCode]?.chars;\n          if (r !== undefined)\n            this.placeholderIban = this.generatePlaceholder(r);\n        }\n        if (this.bbanField.value !== null) {\n          this.updateNumber(this.bbanField.value);\n        }\n      });\n  }\n\n  handleClick(e: any) {\n    e.stopPropagation();\n  }\n\n  ngOnDestroy() {\n    this.destroyNotifier$.next();\n    this.destroyNotifier$.complete();\n  }\n\n  getCountryCodes() {\n    return this.filterCtrl.valueChanges.pipe(\n      startWith(''),\n      combineLatestWith(of(IBAN_SUPPORTED_COUNTRIES)),\n      map(([filterVal, countryCodes]) => {\n        return countryCodes.filter(code => {\n          if (!filterVal) {\n            return true;\n          }\n\n          return code.toLowerCase().includes(filterVal.toLowerCase());\n        });\n      }),\n    );\n  }\n\n  autoFocusNext(\n    control: AbstractControl,\n    nextElement?: HTMLInputElement,\n  ): void {\n    if (!control.errors && nextElement) {\n      this._focusMonitor.focusVia(nextElement, 'program');\n    }\n  }\n\n  onContainerClick(event: MouseEvent): void {\n    if ((event.target as Element).tagName.toLowerCase() != 'input') {\n      this._elementRef.nativeElement.querySelector('input')?.focus();\n    }\n  }\n\n  setDescribedByIds(ids: string[]) {\n    const controlElement =\n      this._elementRef.nativeElement.querySelector('.iban-fields')!;\n    controlElement.setAttribute('aria-describedby', ids.join(' '));\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  writeValue(iban: string | null): void {\n    this.value = iban;\n  }\n\n  _handleInput(control: AbstractControl, nextElement?: HTMLInputElement): void {\n    this.autoFocusNext(control, nextElement);\n    this.onChange(this.value);\n  }\n\n  firstTwoCharsAreLetters(input: string): boolean {\n    const regex = /^[a-zA-Z]{2}/;\n    return regex.test(input);\n  }\n\n  generatePlaceholder(chars: number): string {\n    let placeholder = '';\n\n    for (let i = 0; i < chars; i++) {\n      placeholder += '0';\n    }\n    const ph = friendlyFormatIBAN(placeholder)?.substring(2);\n    if (ph) return ph;\n\n    return placeholder.substring(2);\n  }\n\n  onKeyup(event: KeyboardEvent): void {\n    // Clear country when backspace on empty bban\n    if (this.bbanField.value === '' && event.key === 'Backspace') {\n      this.countryCodeField.setValue(null);\n      this.parts.clearValidators();\n    }\n  }\n}\n","<ng-container [formGroup]=\"parts\">\n  <!--  <mat-form-field class=\"onemrva-input-iban\">-->\n  <!--    <mat-label>{{ label }}</mat-label>-->\n  <div class=\"iban-fields\">\n    <div class=\"iban-prefix\">\n      <mat-select\n        class=\"onemrva-iban-select\"\n        formControlName=\"countryCode\"\n        (selectionChange)=\"_handleInput(parts.controls.countryCode)\"\n        #countryCode\n      >\n        <mat-option>\n          <mat-select-search\n            [formControl]=\"filterCtrl\"\n            [ariaLabel]=\"searchAriaLabel\"\n            [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n            [placeholderLabel]=\"placeholderLabel\"\n          ></mat-select-search>\n        </mat-option>\n\n        <mat-option\n          *ngFor=\"let country of countryCodes$ | async\"\n          [value]=\"country\"\n        >\n          <span>{{ country }}</span>\n        </mat-option>\n      </mat-select>\n    </div>\n    <input\n      (click)=\"handleClick($event)\"\n      matInput\n      [placeholder]=\"placeholderIban\"\n      formControlName=\"bban\"\n      class=\"onemrva-text-number\"\n      [readOnly]=\"readonly\"\n      (input)=\"_handleInput(parts.controls.bban)\"\n      (keyup)=\"onKeyup($event)\"\n      #bban\n    />\n  </div>\n  <!--    <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>-->\n  <!--    <mat-error >{{ 'error' | translate }}</mat-error>-->\n  <!--  </mat-form-field>-->\n\n  <!--  {{ parts.errors |json }}-->\n</ng-container>\n"]}
|
|
282
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onemrva-mat-input-iban.component.js","sourceRoot":"","sources":["../../../../../../projects/onemrva/design-system/mat-input-iban/src/onemrva-mat-input-iban.component.ts","../../../../../../projects/onemrva/design-system/mat-input-iban/src/onemrva-mat-input-iban.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,QAAQ,EACR,MAAM,EACN,IAAI,EACJ,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAIL,WAAW,EAGX,mBAAmB,EAEnB,UAAU,GACX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EACL,cAAc,EAEd,mBAAmB,EACnB,kBAAkB,EAClB,SAAS,GACV,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EACL,iBAAiB,EACjB,oBAAoB,EAEpB,EAAE,EACF,QAAQ,EACR,SAAS,EACT,OAAO,EACP,SAAS,GACV,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,qBAAqB,EAAE,MAAM,gDAAgD,CAAC;AACvF,OAAO,EAAE,wBAAwB,EAAE,MAAM,qCAAqC,CAAC;AAC/E,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAgB,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC5E,OAAO,EACL,YAAY,EACZ,WAAW,EACX,kBAAkB,EAClB,WAAW,GACZ,MAAM,WAAW,CAAC;;;;;;;;;;;AAuBnB,MAAM,OAAO,4BAA4B;aAUhC,WAAM,GAAG,CAAC,AAAJ,CAAK;IA2BlB,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAgB,CAAC;IAC/C,CAAC;IACD,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,aAAa,CAAgB,CAAC;IACtD,CAAC;IAED,YACE,WAAwB,EAChB,aAA2B,EAC3B,WAAoC,EACpC,GAAsB,EACa,UAAwB,EACxC,SAAoB;QAJvC,kBAAa,GAAb,aAAa,CAAc;QAC3B,gBAAW,GAAX,WAAW,CAAyB;QACpC,QAAG,GAAH,GAAG,CAAmB;QACa,eAAU,GAAV,UAAU,CAAc;QACxC,cAAS,GAAT,SAAS,CAAW;QAtCxC,wBAAmB,GAAG,WAAW,CAAC;QAClC,qBAAgB,GAAG,QAAQ,CAAC;QAC5B,oBAAe,GAAG,QAAQ,CAAC;QAC3B,UAAK,GAAG,MAAM,CAAC;QAEd,eAAU,GAAG,IAAI,YAAY,EAAO,CAAC;QAE/C,kBAAa,GAAoB,EAAE,CAAC,EAAE,CAAC,CAAC;QAEjC,eAAU,GAA+B,IAAI,WAAW,CAAS,EAAE,CAAC,CAAC;QAE5E,qBAAgB,GAAG,IAAI,OAAO,EAAQ,CAAC;QACvC,oBAAe,GAAG,EAAE,CAAC;QAErB,gBAAW,GAAG,oBAAoB,CAAC;QACnC,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QACnC,YAAO,GAAG,KAAK,CAAC;QAChB,OAAE,GAAG,sBAAsB,4BAA4B,CAAC,MAAM,EAAE,EAAE,CAAC;QACnE,YAAO,GAAG,KAAK,CAAC;QAkChB,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE;YACpB,EAAE;QACJ,CAAC,CAAC;QACF,cAAS,GAAG,GAAG,EAAE;YACf,EAAE;QACJ,CAAC,CAAC;QAsCF,aAAQ,GAAG,KAAK,CAAC;QAcT,cAAS,GAAG,KAAK,CAAC;QAYlB,iBAAY,GAAG,EAAE,CAAC;QAWlB,cAAS,GAAG,KAAK,CAAC;QA5FxB,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,IAAI,CAAC;QAEpC,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC;YAC7B,WAAW,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5C,IAAI,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;SACf,CAAC,CAAC;IACL,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAC3B,CAAC;IASD,IAAI,UAAU;QACZ,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC;QACxC,OAAO,CAAC,CAAC,CAAC,OAAO,IAAI,OAAO,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC;IAC9E,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;IACrC,CAAC;IAED,IAAI,KAAK;QACP,MAAM,EACJ,KAAK,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,GAC7B,GAAG,IAAI,CAAC,KAAK,CAAC;QAEf,OAAO,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC;IAC/B,CAAC;IAED,IACI,KAAK;QACP,MAAM,EACJ,KAAK,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,GAC7B,GAAG,IAAI,CAAC,KAAK,CAAC;QACf,OAAO,GAAG,WAAW,IAAI,EAAE,GAAG,IAAI,IAAI,EAAE,EAAE,CAAC;IAC7C,CAAC;IAED,IAAI,KAAK,CAAC,IAAmB;QAC3B,MAAM,EAAE,WAAW,EAAE,IAAI,EAAE,GAAG,WAAW,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QAEtD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;YAClB,WAAW,EAAE,WAAW,IAAI,IAAI;YAChC,IAAI,EAAE,IAAI,IAAI,IAAI;SACnB,CAAC,CAAC;QACH,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAKD,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,QAAQ,CAAC,KAAmB;QAC9B,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC9C,oEAAoE;QACpE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;QAC5D,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAID,IACI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,IAAI,WAAW,CAAC,KAAa;QAC3B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAID,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,QAAQ,CAAC,KAAmB;QAC9B,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAGD,YAAY,CAAC,MAAc;QACzB,IAAI,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC;QACrD,mBAAmB;QACnB,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,MAAM,CAAC;QACxD,IAAI,WAAW,CAAC,UAAU,CAAC,EAAE,CAAC;YAC5B,MAAM,cAAc,GAAG,kBAAkB,CAAC,UAAU,CAAC,CAAC;YACtD,IAAI,cAAc,KAAK,IAAI,EAAE,CAAC;gBAC5B,UAAU,GAAG,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YAC3C,CAAC;QACH,CAAC;QACD,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAE5C,IAAI,CAAC,SAAS,CAAC,YAAY;aACxB,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,EACvC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CACjC;aACA,SAAS,CAAC,MAAM,CAAC,EAAE;YAClB,IAAI,MAAM,KAAK,IAAI,IAAI,MAAM,KAAK,EAAE,EAAE,CAAC;gBACrC,IAAI,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,EAAE,CAAC;oBACzC,MAAM,IAAI,GAAG,MAAM,EAAE,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;oBACnD,MAAM,OAAO,GAAG,wBAAwB,CAAC,IAAI,CAC3C,OAAO,CAAC,EAAE,CAAC,OAAO,IAAI,IAAI,CAC3B,CAAC;oBACF,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;oBACxC,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBAC/B,CAAC;gBACD,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,gBAAgB,CAAC,YAAY;aAC/B,IAAI,CACH,SAAS,CAAC,EAAE,CAAC,EACb,QAAQ,EAAE,EACV,oBAAoB,EAAE,EACtB,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CACjC;aACA,SAAS,CAAC,CAAC,CAAC,SAAS,EAAE,WAAW,CAAC,EAAE,EAAE;YACtC,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;YAC1B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC3C,OAAO;YACT,CAAC;YAED,IAAI,IAAI,CAAC,uBAAuB,CAAC,WAAW,CAAC,EAAE,CAAC;gBAC9C,MAAM,CAAC,GAAuB,YAAY,CAAC,WAAW,CAAC,EAAE,KAAK,CAAC;gBAC/D,IAAI,CAAC,KAAK,SAAS;oBACjB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;YACvD,CAAC;YACD,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,IAAI,EAAE,CAAC;gBAClC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YAC1C,CAAC;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,CAAM;QAChB,CAAC,CAAC,eAAe,EAAE,CAAC;IACtB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;QAC7B,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC;IACnC,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CACtC,SAAS,CAAC,EAAE,CAAC,EACb,iBAAiB,CAAC,EAAE,CAAC,wBAAwB,CAAC,CAAC,EAC/C,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,YAAY,CAAC,EAAE,EAAE;YAChC,OAAO,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;gBAChC,IAAI,CAAC,SAAS,EAAE,CAAC;oBACf,OAAO,IAAI,CAAC;gBACd,CAAC;gBAED,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC;YAC9D,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,aAAa,CACX,OAAwB,EACxB,WAA8B;QAE9B,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,WAAW,EAAE,CAAC;YACnC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;QACtD,CAAC;IACH,CAAC;IAED,gBAAgB,CAAC,KAAiB;QAChC,IAAK,KAAK,CAAC,MAAkB,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,OAAO,EAAE,CAAC;YAC/D,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,CAAC;QACjE,CAAC;IACH,CAAC;IAED,iBAAiB,CAAC,GAAa;QAC7B,MAAM,cAAc,GAClB,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,cAAc,CAAE,CAAC;QAChE,cAAc,CAAC,YAAY,CAAC,kBAAkB,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IACjE,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,UAAU,CAAC,IAAmB;QAC5B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAED,YAAY,CAAC,OAAwB,EAAE,WAA8B;QACnE,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QACzC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,uBAAuB,CAAC,KAAa;QACnC,MAAM,KAAK,GAAG,cAAc,CAAC;QAC7B,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,mBAAmB,CAAC,KAAa;QAC/B,IAAI,WAAW,GAAG,EAAE,CAAC;QAErB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;YAC/B,WAAW,IAAI,GAAG,CAAC;QACrB,CAAC;QACD,MAAM,EAAE,GAAG,kBAAkB,CAAC,WAAW,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;QACzD,IAAI,EAAE;YAAE,OAAO,EAAE,CAAC;QAElB,OAAO,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IAClC,CAAC;IAED,OAAO,CAAC,KAAoB;QAC1B,6CAA6C;QAC7C,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,EAAE,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE,CAAC;YAC7D,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YACrC,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,CAAC;QAC/B,CAAC;IACH,CAAC;8GApSU,4BAA4B,oIAiDjB,cAAc;kGAjDzB,4BAA4B,4WAJ5B;YACT,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,4BAA4B,EAAE;SAC5E,qNC7EH,miDAgDA,2NDiBI,YAAY,gNACZ,cAAc,0WACd,kBAAkB,8BAClB,eAAe,mrBACf,qBAAqB,inBACrB,mBAAmB,shCACnB,eAAe;;2FAQN,4BAA4B;kBApBxC,SAAS;+BACE,wBAAwB,cAGtB,IAAI,WACP;wBACP,YAAY;wBACZ,cAAc;wBACd,kBAAkB;wBAClB,eAAe;wBACf,qBAAqB;wBACrB,mBAAmB;wBACnB,eAAe;wBACf,SAAS;qBACV,iBACc,iBAAiB,CAAC,IAAI,aAC1B;wBACT,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,8BAA8B,EAAE;qBAC5E;;0BAmDE,QAAQ;;0BAAI,MAAM;2BAAC,cAAc;;0BACjC,QAAQ;;0BAAI,IAAI;yCA3CO,WAAW;sBAApC,SAAS;uBAAC,aAAa;gBACL,IAAI;sBAAtB,SAAS;uBAAC,MAAM;gBAIR,mBAAmB;sBAA3B,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAEI,UAAU;sBAAnB,MAAM;gBAwEH,KAAK;sBADR,KAAK;gBAmBN,QAAQ;sBADP,KAAK;gBAIF,QAAQ;sBADX,KAAK;gBAeF,WAAW;sBADd,KAAK;gBAaF,QAAQ;sBADX,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  NgControl,\n  ReactiveFormsModule,\n  ValidationErrors,\n  Validators,\n} from '@angular/forms';\nimport {\n  MAT_FORM_FIELD,\n  MatFormField,\n  MatFormFieldControl,\n  MatFormFieldModule,\n  MatPrefix,\n} from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\nimport { TranslateModule } from '@ngx-translate/core';\nimport {\n  combineLatestWith,\n  distinctUntilChanged,\n  Observable,\n  of,\n  pairwise,\n  startWith,\n  Subject,\n  takeUntil,\n} from 'rxjs';\nimport { MatSelectSearchModule } from '@onemrvapublic/design-system/mat-select-search';\nimport { IBAN_SUPPORTED_COUNTRIES } from '@onemrvapublic/design-system/shared';\nimport { map } from 'rxjs/operators';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  countrySpecs,\n  extractIBAN,\n  friendlyFormatIBAN,\n  isValidIBAN,\n} from 'ibantools';\nimport { FocusMonitor } from '@angular/cdk/a11y';\n\n@Component({\n  selector: 'onemrva-mat-input-iban',\n  styleUrls: ['onemrva-mat-input-iban.component.scss'],\n  templateUrl: 'onemrva-mat-input-iban.component.html',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatInputModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    MatSelectSearchModule,\n    ReactiveFormsModule,\n    TranslateModule,\n    MatPrefix,\n  ],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    { provide: MatFormFieldControl, useExisting: OnemrvaMatInputIbanComponent },\n  ],\n})\nexport class OnemrvaMatInputIbanComponent\n  implements\n    ControlValueAccessor,\n    MatFormFieldControl<string>,\n    OnInit,\n    OnDestroy\n{\n  @ViewChild('countryCode') countryCode!: HTMLInputElement;\n  @ViewChild('bban') bban!: HTMLInputElement;\n\n  static nextId = 0;\n\n  @Input() noEntriesFoundLabel = 'Not found';\n  @Input() placeholderLabel = 'Search';\n  @Input() searchAriaLabel = 'Search';\n  @Input() label = 'IBAN';\n\n  @Output() getCountry = new EventEmitter<any>();\n\n  countryCodes$: Observable<any> = of([]);\n\n  public filterCtrl: FormControl<string | null> = new FormControl<string>('');\n\n  destroyNotifier$ = new Subject<void>();\n  placeholderIban = '';\n\n  controlType = 'bank-account-input';\n  stateChanges = new Subject<void>();\n  focused = false;\n  id = `bank-account-input-${OnemrvaMatInputIbanComponent.nextId++}`;\n  touched = false;\n\n  parts: FormGroup<{\n    countryCode: FormControl<string | null>;\n    bban: FormControl<string | null>;\n  }>;\n\n  get bbanField() {\n    return this.parts.get('bban') as FormControl;\n  }\n  get countryCodeField() {\n    return this.parts.get('countryCode') as FormControl;\n  }\n\n  constructor(\n    formBuilder: FormBuilder,\n    private _focusMonitor: FocusMonitor,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _cd: ChangeDetectorRef,\n    @Optional() @Inject(MAT_FORM_FIELD) public _formField: MatFormField,\n    @Optional() @Self() public ngControl: NgControl,\n  ) {\n    this.ngControl.valueAccessor = this;\n\n    this.parts = formBuilder.group({\n      countryCode: ['', [Validators.maxLength(2)]],\n      bban: ['', []],\n    });\n  }\n\n  errors(): ValidationErrors | null {\n    return this.parts.errors;\n  }\n\n  onChange = (_: any) => {\n    //\n  };\n  onTouched = () => {\n    //\n  };\n\n  get errorState(): boolean {\n    const control = this.ngControl?.control;\n    return !!(control && control.invalid && (control.dirty || control.touched));\n  }\n\n  get shouldLabelFloat() {\n    return this.focused || !this.empty;\n  }\n\n  get empty() {\n    const {\n      value: { countryCode, bban },\n    } = this.parts;\n\n    return !countryCode && !bban;\n  }\n\n  @Input()\n  get value(): string {\n    const {\n      value: { countryCode, bban },\n    } = this.parts;\n    return `${countryCode ?? ''}${bban ?? ''}`;\n  }\n\n  set value(iban: string | null) {\n    const { countryCode, bban } = extractIBAN(iban || '');\n\n    this.parts.setValue({\n      countryCode: countryCode || null,\n      bban: bban || null,\n    });\n    this.stateChanges.next();\n  }\n\n  @Input()\n  readonly = false;\n\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  set disabled(value: BooleanInput) {\n    this._disabled = coerceBooleanProperty(value);\n    // eslint-disable-next-line @typescript-eslint/no-unused-expressions\n    this._disabled ? this.parts.disable() : this.parts.enable();\n    this.stateChanges.next();\n  }\n\n  private _disabled = false;\n\n  @Input()\n  get placeholder(): string {\n    return this._placeholder;\n  }\n\n  set placeholder(value: string) {\n    this._placeholder = value;\n    this.stateChanges.next();\n  }\n\n  private _placeholder = '';\n\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n\n  set required(value: BooleanInput) {\n    this._required = coerceBooleanProperty(value);\n    this.stateChanges.next();\n  }\n  private _required = false;\n\n  updateNumber(number: string) {\n    let shownValue = number.replace(/[^a-zA-Z0-9]/g, '');\n    // BE45063712751789\n    const fullNumber = this.countryCodeField.value + number;\n    if (isValidIBAN(fullNumber)) {\n      const formattedValue = friendlyFormatIBAN(fullNumber);\n      if (formattedValue !== null) {\n        shownValue = formattedValue.substring(2);\n      }\n    }\n    this.bbanField.patchValue(shownValue, { emitEvent: false });\n  }\n\n  ngOnInit(): void {\n    this.countryCodes$ = this.getCountryCodes();\n\n    this.bbanField.valueChanges\n      .pipe(\n        startWith(this.bbanField.getRawValue()),\n        takeUntil(this.destroyNotifier$),\n      )\n      .subscribe(number => {\n        if (number !== null && number !== '') {\n          if (this.firstTwoCharsAreLetters(number)) {\n            const code = number?.substring(0, 2).toUpperCase();\n            const country = IBAN_SUPPORTED_COUNTRIES.find(\n              country => country == code,\n            );\n            this.countryCodeField.setValue(country);\n            number = number.substring(2);\n          }\n          this.updateNumber(number);\n        }\n      });\n\n    this.countryCodeField.valueChanges\n      .pipe(\n        startWith(''),\n        pairwise(),\n        distinctUntilChanged(),\n        takeUntil(this.destroyNotifier$),\n      )\n      .subscribe(([_prevIban, countryCode]) => {\n        this.placeholderIban = '';\n        this.touched = true;\n        if (!countryCode || countryCode.length < 2) {\n          return;\n        }\n\n        if (this.firstTwoCharsAreLetters(countryCode)) {\n          const r: number | undefined = countrySpecs[countryCode]?.chars;\n          if (r !== undefined)\n            this.placeholderIban = this.generatePlaceholder(r);\n        }\n        if (this.bbanField.value !== null) {\n          this.updateNumber(this.bbanField.value);\n        }\n      });\n  }\n\n  handleClick(e: any) {\n    e.stopPropagation();\n  }\n\n  ngOnDestroy() {\n    this.destroyNotifier$.next();\n    this.destroyNotifier$.complete();\n  }\n\n  getCountryCodes() {\n    return this.filterCtrl.valueChanges.pipe(\n      startWith(''),\n      combineLatestWith(of(IBAN_SUPPORTED_COUNTRIES)),\n      map(([filterVal, countryCodes]) => {\n        return countryCodes.filter(code => {\n          if (!filterVal) {\n            return true;\n          }\n\n          return code.toLowerCase().includes(filterVal.toLowerCase());\n        });\n      }),\n    );\n  }\n\n  autoFocusNext(\n    control: AbstractControl,\n    nextElement?: HTMLInputElement,\n  ): void {\n    if (!control.errors && nextElement) {\n      this._focusMonitor.focusVia(nextElement, 'program');\n    }\n  }\n\n  onContainerClick(event: MouseEvent): void {\n    if ((event.target as Element).tagName.toLowerCase() != 'input') {\n      this._elementRef.nativeElement.querySelector('input')?.focus();\n    }\n  }\n\n  setDescribedByIds(ids: string[]) {\n    const controlElement =\n      this._elementRef.nativeElement.querySelector('.iban-fields')!;\n    controlElement.setAttribute('aria-describedby', ids.join(' '));\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  writeValue(iban: string | null): void {\n    this.value = iban;\n  }\n\n  _handleInput(control: AbstractControl, nextElement?: HTMLInputElement): void {\n    this.autoFocusNext(control, nextElement);\n    this.onChange(this.value);\n  }\n\n  firstTwoCharsAreLetters(input: string): boolean {\n    const regex = /^[a-zA-Z]{2}/;\n    return regex.test(input);\n  }\n\n  generatePlaceholder(chars: number): string {\n    let placeholder = '';\n\n    for (let i = 0; i < chars; i++) {\n      placeholder += '0';\n    }\n    const ph = friendlyFormatIBAN(placeholder)?.substring(2);\n    if (ph) return ph;\n\n    return placeholder.substring(2);\n  }\n\n  onKeyup(event: KeyboardEvent): void {\n    // Clear country when backspace on empty bban\n    if (this.bbanField.value === '' && event.key === 'Backspace') {\n      this.countryCodeField.setValue(null);\n      this.parts.clearValidators();\n    }\n  }\n}\n","<ng-container [formGroup]=\"parts\">\n  <!--  <mat-form-field class=\"onemrva-input-iban\">-->\n  <!--    <mat-label>{{ label }}</mat-label>-->\n  <div class=\"iban-fields\">\n    <div class=\"iban-prefix\">\n      <mat-select\n        class=\"onemrva-iban-select\"\n        formControlName=\"countryCode\"\n        [attr.aria-label]=\"'Country' | translate\"\n        (selectionChange)=\"_handleInput(parts.controls.countryCode)\"\n        #countryCode\n      >\n        <mat-option>\n          <mat-select-search\n            [formControl]=\"filterCtrl\"\n            [ariaLabel]=\"searchAriaLabel\"\n            [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n            [placeholderLabel]=\"placeholderLabel\"\n          ></mat-select-search>\n        </mat-option>\n\n        <mat-option\n          *ngFor=\"let country of countryCodes$ | async\"\n          [value]=\"country\"\n        >\n          <span>{{ country }}</span>\n        </mat-option>\n      </mat-select>\n    </div>\n    <input\n      [attr.aria-label]=\"label\"\n      (click)=\"handleClick($event)\"\n      matInput\n      [placeholder]=\"placeholderIban\"\n      formControlName=\"bban\"\n      class=\"onemrva-text-number\"\n      [readOnly]=\"readonly\"\n      (input)=\"_handleInput(parts.controls.bban)\"\n      (keyup)=\"onKeyup($event)\"\n      #bban\n    />\n  </div>\n  <!--    <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>-->\n  <!--    <mat-error >{{ 'error' | translate }}</mat-error>-->\n  <!--  </mat-form-field>-->\n\n  <!--  {{ parts.errors |json }}-->\n</ng-container>\n"]}
|