@onemrvapublic/design-system 18.2.10-develop.2 → 18.2.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/i18n/de.json +10 -4
- package/assets/i18n/en.json +10 -4
- package/assets/i18n/fr.json +10 -4
- package/assets/i18n/nl.json +10 -4
- package/esm2022/layout/src/components/layout/layout.component.mjs +3 -3
- package/esm2022/layout/src/components/layout-route/layout-route.component.mjs +3 -3
- package/esm2022/layout/src/components/layout-subroute/layout-subroute.component.mjs +1 -1
- package/esm2022/mat-carousel/src/onemrva-mat-carousel.component.mjs +4 -1
- package/esm2022/mat-input-bank-account/index.mjs +2 -2
- package/esm2022/mat-input-bank-account/src/onemrva-mat-input-iban.component.mjs +288 -0
- package/esm2022/shared/src/lib/services/country-cdn.service.mjs +5 -2
- package/fesm2022/onemrvapublic-design-system-layout.mjs +4 -4
- package/fesm2022/onemrvapublic-design-system-layout.mjs.map +1 -1
- package/fesm2022/onemrvapublic-design-system-mat-carousel.mjs +3 -0
- package/fesm2022/onemrvapublic-design-system-mat-carousel.mjs.map +1 -1
- package/fesm2022/onemrvapublic-design-system-mat-input-bank-account.mjs +173 -160
- package/fesm2022/onemrvapublic-design-system-mat-input-bank-account.mjs.map +1 -1
- package/fesm2022/onemrvapublic-design-system-shared.mjs +4 -1
- package/fesm2022/onemrvapublic-design-system-shared.mjs.map +1 -1
- package/layout/src/components/layout/layout.component.scss +11 -0
- package/mat-input-bank-account/index.d.ts +1 -1
- package/mat-input-bank-account/src/{bank-account.component.d.ts → onemrva-mat-input-iban.component.d.ts} +41 -28
- package/mat-input-bank-account/src/onemrva-mat-input-iban.component.scss +10 -0
- package/package.json +1 -1
- package/shared/src/lib/services/country-cdn.service.d.ts +5 -65
- package/esm2022/mat-input-bank-account/src/bank-account.component.mjs +0 -223
- package/esm2022/mat-input-bank-account/src/onemrva-mat-input-bank-account.component.mjs +0 -66
- package/mat-input-bank-account/src/bank-account.component.scss +0 -42
- package/mat-input-bank-account/src/onemrva-mat-input-bank-account.component.d.ts +0 -15
- package/mat-input-bank-account/src/onemrva-mat-input-bank-account.component.scss +0 -14
|
@@ -18,72 +18,12 @@ export declare class OnemRvaCDNCountryService {
|
|
|
18
18
|
private cdnService;
|
|
19
19
|
private translateService;
|
|
20
20
|
constructor(cdnService: OnemRvaCDNService, translateService: TranslateService);
|
|
21
|
-
getCountries(): import("rxjs").Observable<
|
|
22
|
-
|
|
23
|
-
code: string;
|
|
24
|
-
dial_code: string;
|
|
25
|
-
zone: string;
|
|
26
|
-
pattern: string;
|
|
27
|
-
placeholder: string;
|
|
28
|
-
translations: {
|
|
29
|
-
fr: string;
|
|
30
|
-
nl: string;
|
|
31
|
-
de: string;
|
|
32
|
-
};
|
|
33
|
-
}[]>;
|
|
34
|
-
getCountriesByZone(zone: string): import("rxjs").Observable<{
|
|
35
|
-
name: string;
|
|
36
|
-
code: string;
|
|
37
|
-
dial_code: string;
|
|
38
|
-
zone: string;
|
|
39
|
-
pattern: string;
|
|
40
|
-
placeholder: string;
|
|
41
|
-
translations: {
|
|
42
|
-
fr: string;
|
|
43
|
-
nl: string;
|
|
44
|
-
de: string;
|
|
45
|
-
};
|
|
46
|
-
}[]>;
|
|
21
|
+
getCountries(): import("rxjs").Observable<OnemrvaMaterialCountry[]>;
|
|
22
|
+
getCountriesByZone(zone: string): import("rxjs").Observable<OnemrvaMaterialCountry[]>;
|
|
47
23
|
getTranslatedCountryName(country: OnemrvaMaterialCountry, languageCode?: string): string;
|
|
48
|
-
findCountryFromCode(code: any): import("rxjs").Observable<
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
dial_code: string;
|
|
52
|
-
zone: string;
|
|
53
|
-
pattern: string;
|
|
54
|
-
placeholder: string;
|
|
55
|
-
translations: {
|
|
56
|
-
fr: string;
|
|
57
|
-
nl: string;
|
|
58
|
-
de: string;
|
|
59
|
-
};
|
|
60
|
-
} | undefined>;
|
|
61
|
-
findCountryFromVIESCode(code: any): import("rxjs").Observable<{
|
|
62
|
-
name: string;
|
|
63
|
-
code: string;
|
|
64
|
-
dial_code: string;
|
|
65
|
-
zone: string;
|
|
66
|
-
pattern: string;
|
|
67
|
-
placeholder: string;
|
|
68
|
-
translations: {
|
|
69
|
-
fr: string;
|
|
70
|
-
nl: string;
|
|
71
|
-
de: string;
|
|
72
|
-
};
|
|
73
|
-
} | undefined>;
|
|
74
|
-
findCountryFromPrefix(number: any): import("rxjs").Observable<{
|
|
75
|
-
name: string;
|
|
76
|
-
code: string;
|
|
77
|
-
dial_code: string;
|
|
78
|
-
zone: string;
|
|
79
|
-
pattern: string;
|
|
80
|
-
placeholder: string;
|
|
81
|
-
translations: {
|
|
82
|
-
fr: string;
|
|
83
|
-
nl: string;
|
|
84
|
-
de: string;
|
|
85
|
-
};
|
|
86
|
-
} | undefined>;
|
|
24
|
+
findCountryFromCode(code: any): import("rxjs").Observable<OnemrvaMaterialCountry | undefined>;
|
|
25
|
+
findCountryFromVIESCode(code: any): import("rxjs").Observable<OnemrvaMaterialCountry | undefined>;
|
|
26
|
+
findCountryFromPrefix(number: any): import("rxjs").Observable<OnemrvaMaterialCountry | undefined>;
|
|
87
27
|
static ɵfac: i0.ɵɵFactoryDeclaration<OnemRvaCDNCountryService, never>;
|
|
88
28
|
static ɵprov: i0.ɵɵInjectableDeclaration<OnemRvaCDNCountryService>;
|
|
89
29
|
}
|
|
@@ -1,223 +0,0 @@
|
|
|
1
|
-
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
2
|
-
import { Component, Inject, Input, Optional, Self, ViewChild, } from '@angular/core';
|
|
3
|
-
import { FormControl, FormsModule, ReactiveFormsModule, Validators, } from '@angular/forms';
|
|
4
|
-
import { MAT_FORM_FIELD, MatFormFieldControl, } from '@angular/material/form-field';
|
|
5
|
-
import { combineLatestWith, distinctUntilChanged, map, of, pairwise, startWith, Subject, takeUntil, } from 'rxjs';
|
|
6
|
-
import { MatSelectModule } from '@angular/material/select';
|
|
7
|
-
import { MatSelectSearchModule } from '@onemrvapublic/design-system/mat-select-search';
|
|
8
|
-
import { bankAccountValidator, IBAN_SUPPORTED_COUNTRIES, } from '@onemrvapublic/design-system/shared';
|
|
9
|
-
import { CommonModule } from '@angular/common';
|
|
10
|
-
import { extractIBAN, friendlyFormatIBAN } from 'ibantools';
|
|
11
|
-
import * as i0 from "@angular/core";
|
|
12
|
-
import * as i1 from "@angular/forms";
|
|
13
|
-
import * as i2 from "@angular/cdk/a11y";
|
|
14
|
-
import * as i3 from "@angular/common";
|
|
15
|
-
import * as i4 from "@angular/material/form-field";
|
|
16
|
-
import * as i5 from "@angular/material/select";
|
|
17
|
-
import * as i6 from "@angular/material/core";
|
|
18
|
-
import * as i7 from "@onemrvapublic/design-system/mat-select-search";
|
|
19
|
-
/** Custom `MatFormFieldControl` for bank account number input. */
|
|
20
|
-
export class BankAccountComponent {
|
|
21
|
-
static { this.nextId = 0; }
|
|
22
|
-
get empty() {
|
|
23
|
-
const { value: { countryCode, bban }, } = this.parts;
|
|
24
|
-
return !countryCode && !bban;
|
|
25
|
-
}
|
|
26
|
-
get shouldLabelFloat() {
|
|
27
|
-
return this.focused || !this.empty;
|
|
28
|
-
}
|
|
29
|
-
get placeholder() {
|
|
30
|
-
return this._placeholder;
|
|
31
|
-
}
|
|
32
|
-
set placeholder(value) {
|
|
33
|
-
this._placeholder = value;
|
|
34
|
-
this.stateChanges.next();
|
|
35
|
-
}
|
|
36
|
-
get required() {
|
|
37
|
-
return this._required;
|
|
38
|
-
}
|
|
39
|
-
set required(value) {
|
|
40
|
-
this._required = coerceBooleanProperty(value);
|
|
41
|
-
this.stateChanges.next();
|
|
42
|
-
}
|
|
43
|
-
get disabled() {
|
|
44
|
-
return this._disabled;
|
|
45
|
-
}
|
|
46
|
-
set disabled(value) {
|
|
47
|
-
this._disabled = coerceBooleanProperty(value);
|
|
48
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-expressions
|
|
49
|
-
this._disabled ? this.parts.disable() : this.parts.enable();
|
|
50
|
-
this.stateChanges.next();
|
|
51
|
-
}
|
|
52
|
-
get value() {
|
|
53
|
-
const { value: { countryCode, bban }, } = this.parts;
|
|
54
|
-
return `${countryCode ?? ''}${bban ?? ''}`;
|
|
55
|
-
}
|
|
56
|
-
set value(iban) {
|
|
57
|
-
const { countryCode, bban } = extractIBAN(iban || '');
|
|
58
|
-
this.parts.setValue({
|
|
59
|
-
countryCode: countryCode || null,
|
|
60
|
-
bban: bban || null,
|
|
61
|
-
});
|
|
62
|
-
this.stateChanges.next();
|
|
63
|
-
}
|
|
64
|
-
get errorState() {
|
|
65
|
-
return this.parts.invalid && this.touched;
|
|
66
|
-
}
|
|
67
|
-
constructor(formBuilder, _focusMonitor, _elementRef, _cd, _formField, ngControl) {
|
|
68
|
-
this._focusMonitor = _focusMonitor;
|
|
69
|
-
this._elementRef = _elementRef;
|
|
70
|
-
this._cd = _cd;
|
|
71
|
-
this._formField = _formField;
|
|
72
|
-
this.ngControl = ngControl;
|
|
73
|
-
this.filterCtrl = new FormControl('');
|
|
74
|
-
this.countryCodes$ = of([]);
|
|
75
|
-
this.stateChanges = new Subject();
|
|
76
|
-
this.destroyNotifier$ = new Subject();
|
|
77
|
-
this.focused = false;
|
|
78
|
-
this.touched = false;
|
|
79
|
-
this.controlType = 'bank-account-input';
|
|
80
|
-
this.id = `bank-account-input-${BankAccountComponent.nextId++}`;
|
|
81
|
-
this.onChange = (_) => {
|
|
82
|
-
//
|
|
83
|
-
};
|
|
84
|
-
this.onTouched = () => {
|
|
85
|
-
//
|
|
86
|
-
};
|
|
87
|
-
this._placeholder = '';
|
|
88
|
-
this._required = false;
|
|
89
|
-
this._disabled = false;
|
|
90
|
-
if (this.ngControl != null) {
|
|
91
|
-
this.ngControl.valueAccessor = this;
|
|
92
|
-
}
|
|
93
|
-
this.parts = formBuilder.group({
|
|
94
|
-
countryCode: ['', [Validators.maxLength(2)]],
|
|
95
|
-
bban: ['', [Validators.required]],
|
|
96
|
-
}, {
|
|
97
|
-
validators: [bankAccountValidator()],
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
ngOnInit() {
|
|
101
|
-
this.countryCodes$ = this.getCountryCodes();
|
|
102
|
-
this.parts.valueChanges
|
|
103
|
-
.pipe(startWith({ countryCode: '', bban: '' }), pairwise(), distinctUntilChanged(), takeUntil(this.destroyNotifier$))
|
|
104
|
-
.subscribe(([_prevIban, { countryCode, bban }]) => {
|
|
105
|
-
this.touched = true;
|
|
106
|
-
if (!bban || bban.length <= 2) {
|
|
107
|
-
return;
|
|
108
|
-
}
|
|
109
|
-
const potentialCountryCode = bban?.substring(0, 2);
|
|
110
|
-
if (potentialCountryCode?.match(/^[A-Za-z]{2}/)) {
|
|
111
|
-
const restOfTheBankNumber = bban?.substring(2);
|
|
112
|
-
return this.parts.setValue({
|
|
113
|
-
countryCode: potentialCountryCode,
|
|
114
|
-
...getBban(potentialCountryCode, restOfTheBankNumber),
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
return this.parts.patchValue({
|
|
118
|
-
...getBban(countryCode, bban),
|
|
119
|
-
}, { emitEvent: false });
|
|
120
|
-
});
|
|
121
|
-
}
|
|
122
|
-
ngOnDestroy() {
|
|
123
|
-
this.destroyNotifier$.next();
|
|
124
|
-
this.destroyNotifier$.complete();
|
|
125
|
-
this.stateChanges.complete();
|
|
126
|
-
this._focusMonitor.stopMonitoring(this._elementRef);
|
|
127
|
-
}
|
|
128
|
-
getCountryCodes() {
|
|
129
|
-
return this.filterCtrl.valueChanges.pipe(startWith(''), combineLatestWith(of(IBAN_SUPPORTED_COUNTRIES)), map(([filterVal, countryCodes]) => {
|
|
130
|
-
return countryCodes.filter(code => {
|
|
131
|
-
if (!filterVal) {
|
|
132
|
-
return true;
|
|
133
|
-
}
|
|
134
|
-
return code.toLowerCase().includes(filterVal.toLowerCase());
|
|
135
|
-
});
|
|
136
|
-
}));
|
|
137
|
-
}
|
|
138
|
-
autoFocusNext(control, nextElement) {
|
|
139
|
-
if (!control.errors && nextElement) {
|
|
140
|
-
this._focusMonitor.focusVia(nextElement, 'program');
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
//
|
|
144
|
-
// autoFocusPrev(control: AbstractControl, prevElement: HTMLInputElement): void {
|
|
145
|
-
// if (control.value.length < 1) {
|
|
146
|
-
// this._focusMonitor.focusVia(prevElement, 'program');
|
|
147
|
-
// }
|
|
148
|
-
// }
|
|
149
|
-
setDescribedByIds(ids) {
|
|
150
|
-
const controlElement = this._elementRef.nativeElement.querySelector('.bank-account-input-group');
|
|
151
|
-
controlElement.setAttribute('aria-describedby', ids.join(' '));
|
|
152
|
-
}
|
|
153
|
-
onContainerClick() {
|
|
154
|
-
//
|
|
155
|
-
}
|
|
156
|
-
writeValue(iban) {
|
|
157
|
-
this.value = iban;
|
|
158
|
-
}
|
|
159
|
-
registerOnChange(fn) {
|
|
160
|
-
this.onChange = fn;
|
|
161
|
-
}
|
|
162
|
-
registerOnTouched(fn) {
|
|
163
|
-
this.onTouched = fn;
|
|
164
|
-
}
|
|
165
|
-
setDisabledState(isDisabled) {
|
|
166
|
-
this.disabled = isDisabled;
|
|
167
|
-
}
|
|
168
|
-
_handleInput(control, nextElement) {
|
|
169
|
-
this.autoFocusNext(control, nextElement);
|
|
170
|
-
this.onChange(this.value);
|
|
171
|
-
}
|
|
172
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: BankAccountComponent, 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 }); }
|
|
173
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: BankAccountComponent, isStandalone: true, selector: "bank-account", inputs: { userAriaDescribedBy: ["aria-describedby", "userAriaDescribedBy"], placeholder: "placeholder", required: "required", disabled: "disabled", value: "value" }, host: { properties: { "class.example-floating": "shouldLabelFloat", "id": "id" } }, providers: [
|
|
174
|
-
{ provide: MatFormFieldControl, useExisting: BankAccountComponent },
|
|
175
|
-
], viewQueries: [{ propertyName: "countryCode", first: true, predicate: ["countryCode "], descendants: true }, { propertyName: "bban", first: true, predicate: ["bban"], descendants: true }], ngImport: i0, template: "<div\n role=\"group\"\n class=\"bank-account-input-group\"\n [formGroup]=\"parts\"\n [attr.aria-labelledby]=\"_formField.getLabelId()\"\n>\n <mat-select\n class=\"country-code-select\"\n matTextPrefix\n formControlName=\"countryCode\"\n placeholder=\"XX\"\n (selectionChange)=\"_handleInput(parts.controls.countryCode)\"\n #countryCode\n >\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n noEntriesFoundLabel=\"no-entries-label\"\n placeholderLabel=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n\n <mat-option *ngFor=\"let country of countryCodes$ | async\" [value]=\"country\">\n <span>{{ country }}</span>\n </mat-option>\n </mat-select>\n\n <input\n id=\"bban-input\"\n name=\"bban-input\"\n class=\"bban-input\"\n formControlName=\"bban\"\n (input)=\"_handleInput(parts.controls.bban)\"\n #bban\n />\n</div>\n", styles: [".bank-account-input-group{display:flex;width:100%}.bank-account-input-group .country-code-input,.bank-account-input-group .bban-input{border:none;background:none;padding:0;outline:none;font:inherit;text-align:left;color:currentcolor}.bank-account-input-group .bban-input{padding-left:4px}\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: FormsModule }, { 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: "ngmodule", type: ReactiveFormsModule }, { 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: MatSelectModule }, { kind: "directive", type: i4.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { 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"] }] }); }
|
|
176
|
-
}
|
|
177
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: BankAccountComponent, decorators: [{
|
|
178
|
-
type: Component,
|
|
179
|
-
args: [{ selector: 'bank-account', providers: [
|
|
180
|
-
{ provide: MatFormFieldControl, useExisting: BankAccountComponent },
|
|
181
|
-
], host: {
|
|
182
|
-
'[class.example-floating]': 'shouldLabelFloat',
|
|
183
|
-
'[id]': 'id',
|
|
184
|
-
}, standalone: true, imports: [
|
|
185
|
-
CommonModule,
|
|
186
|
-
FormsModule,
|
|
187
|
-
ReactiveFormsModule,
|
|
188
|
-
MatSelectModule,
|
|
189
|
-
MatSelectSearchModule,
|
|
190
|
-
], template: "<div\n role=\"group\"\n class=\"bank-account-input-group\"\n [formGroup]=\"parts\"\n [attr.aria-labelledby]=\"_formField.getLabelId()\"\n>\n <mat-select\n class=\"country-code-select\"\n matTextPrefix\n formControlName=\"countryCode\"\n placeholder=\"XX\"\n (selectionChange)=\"_handleInput(parts.controls.countryCode)\"\n #countryCode\n >\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n noEntriesFoundLabel=\"no-entries-label\"\n placeholderLabel=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n\n <mat-option *ngFor=\"let country of countryCodes$ | async\" [value]=\"country\">\n <span>{{ country }}</span>\n </mat-option>\n </mat-select>\n\n <input\n id=\"bban-input\"\n name=\"bban-input\"\n class=\"bban-input\"\n formControlName=\"bban\"\n (input)=\"_handleInput(parts.controls.bban)\"\n #bban\n />\n</div>\n", styles: [".bank-account-input-group{display:flex;width:100%}.bank-account-input-group .country-code-input,.bank-account-input-group .bban-input{border:none;background:none;padding:0;outline:none;font:inherit;text-align:left;color:currentcolor}.bank-account-input-group .bban-input{padding-left:4px}\n"] }]
|
|
191
|
-
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.FocusMonitor }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i4.MatFormField, decorators: [{
|
|
192
|
-
type: Optional
|
|
193
|
-
}, {
|
|
194
|
-
type: Inject,
|
|
195
|
-
args: [MAT_FORM_FIELD]
|
|
196
|
-
}] }, { type: i1.NgControl, decorators: [{
|
|
197
|
-
type: Optional
|
|
198
|
-
}, {
|
|
199
|
-
type: Self
|
|
200
|
-
}] }], propDecorators: { countryCode: [{
|
|
201
|
-
type: ViewChild,
|
|
202
|
-
args: ['countryCode ']
|
|
203
|
-
}], bban: [{
|
|
204
|
-
type: ViewChild,
|
|
205
|
-
args: ['bban']
|
|
206
|
-
}], userAriaDescribedBy: [{
|
|
207
|
-
type: Input,
|
|
208
|
-
args: ['aria-describedby']
|
|
209
|
-
}], placeholder: [{
|
|
210
|
-
type: Input
|
|
211
|
-
}], required: [{
|
|
212
|
-
type: Input
|
|
213
|
-
}], disabled: [{
|
|
214
|
-
type: Input
|
|
215
|
-
}], value: [{
|
|
216
|
-
type: Input
|
|
217
|
-
}] } });
|
|
218
|
-
const getBban = (countryCode = '', bban) => {
|
|
219
|
-
return {
|
|
220
|
-
bban: friendlyFormatIBAN(`${countryCode}${bban}`)?.substring(2) || null,
|
|
221
|
-
};
|
|
222
|
-
};
|
|
223
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bank-account.component.js","sourceRoot":"","sources":["../../../../../../projects/onemrva/design-system/mat-input-bank-account/src/bank-account.component.ts","../../../../../../projects/onemrva/design-system/mat-input-bank-account/src/bank-account.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Self,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  NgControl,\n  FormsModule,\n  ReactiveFormsModule,\n  AbstractControl,\n  Validators,\n} from '@angular/forms';\nimport {\n  MAT_FORM_FIELD,\n  MatFormField,\n  MatFormFieldControl,\n} from '@angular/material/form-field';\nimport {\n  combineLatestWith,\n  distinctUntilChanged,\n  map,\n  Observable,\n  of,\n  pairwise,\n  startWith,\n  Subject,\n  takeUntil,\n} from 'rxjs';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatSelectSearchModule } from '@onemrvapublic/design-system/mat-select-search';\nimport {\n  bankAccountValidator,\n  IBAN_SUPPORTED_COUNTRIES,\n} from '@onemrvapublic/design-system/shared';\nimport { CommonModule } from '@angular/common';\nimport { extractIBAN, friendlyFormatIBAN } from 'ibantools';\n\n/** Custom `MatFormFieldControl` for bank account number input. */\n@Component({\n  selector: 'bank-account',\n  templateUrl: 'bank-account.component.html',\n  styleUrl: 'bank-account.component.scss',\n  providers: [\n    { provide: MatFormFieldControl, useExisting: BankAccountComponent },\n  ],\n\n  host: {\n    '[class.example-floating]': 'shouldLabelFloat',\n    '[id]': 'id',\n  },\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    MatSelectModule,\n    MatSelectSearchModule,\n  ],\n})\nexport class BankAccountComponent\n  implements\n    ControlValueAccessor,\n    MatFormFieldControl<string>,\n    OnDestroy,\n    OnInit\n{\n  static nextId = 0;\n\n  @ViewChild('countryCode ') countryCode!: HTMLInputElement;\n  @ViewChild('bban') bban!: HTMLInputElement;\n\n  filterCtrl: FormControl<string | null> = new FormControl<string>('');\n  parts: FormGroup<{\n    countryCode: FormControl<string | null>;\n    bban: FormControl<string | null>;\n  }>;\n\n  countryCodes$: Observable<any> = of([]);\n  stateChanges = new Subject<void>();\n  destroyNotifier$ = new Subject<void>();\n  focused = false;\n  touched = false;\n  controlType = 'bank-account-input';\n  id = `bank-account-input-${BankAccountComponent.nextId++}`;\n  onChange = (_: any) => {\n    //\n  };\n  onTouched = () => {\n    //\n  };\n\n  get empty() {\n    const {\n      value: { countryCode, bban },\n    } = this.parts;\n\n    return !countryCode && !bban;\n  }\n\n  get shouldLabelFloat() {\n    return this.focused || !this.empty;\n  }\n\n  // @ts-expect-error test\n  // eslint-disable-next-line\n  @Input('aria-describedby') userAriaDescribedBy: string;\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\n  private _required = 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 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  get errorState(): boolean {\n    return this.parts.invalid && this.touched;\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    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    this.parts = formBuilder.group(\n      {\n        countryCode: ['', [Validators.maxLength(2)]],\n        bban: ['', [Validators.required]],\n      },\n      {\n        validators: [bankAccountValidator()],\n      },\n    );\n  }\n\n  ngOnInit() {\n    this.countryCodes$ = this.getCountryCodes();\n\n    this.parts.valueChanges\n      .pipe(\n        startWith({ countryCode: '', bban: '' }),\n        pairwise(),\n        distinctUntilChanged(),\n        takeUntil(this.destroyNotifier$),\n      )\n      .subscribe(([_prevIban, { countryCode, bban }]) => {\n        this.touched = true;\n        if (!bban || bban.length <= 2) {\n          return;\n        }\n\n        const potentialCountryCode = bban?.substring(0, 2);\n\n        if (potentialCountryCode?.match(/^[A-Za-z]{2}/)) {\n          const restOfTheBankNumber = bban?.substring(2);\n          return this.parts.setValue({\n            countryCode: potentialCountryCode,\n            ...getBban(potentialCountryCode, restOfTheBankNumber),\n          });\n        }\n\n        return this.parts.patchValue(\n          {\n            ...getBban(countryCode, bban),\n          },\n          { emitEvent: false },\n        );\n      });\n  }\n\n  ngOnDestroy() {\n    this.destroyNotifier$.next();\n    this.destroyNotifier$.complete();\n    this.stateChanges.complete();\n    this._focusMonitor.stopMonitoring(this._elementRef);\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  //\n  // autoFocusPrev(control: AbstractControl, prevElement: HTMLInputElement): void {\n  //   if (control.value.length < 1) {\n  //     this._focusMonitor.focusVia(prevElement, 'program');\n  //   }\n  // }\n\n  setDescribedByIds(ids: string[]) {\n    const controlElement = this._elementRef.nativeElement.querySelector(\n      '.bank-account-input-group',\n    )!;\n    controlElement.setAttribute('aria-describedby', ids.join(' '));\n  }\n\n  onContainerClick() {\n    //\n  }\n\n  writeValue(iban: string | null): void {\n    this.value = iban;\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  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  _handleInput(control: AbstractControl, nextElement?: HTMLInputElement): void {\n    this.autoFocusNext(control, nextElement);\n    this.onChange(this.value);\n  }\n}\n\nconst getBban = (countryCode: string | null | undefined = '', bban: string) => {\n  return {\n    bban: friendlyFormatIBAN(`${countryCode}${bban}`)?.substring(2) || null,\n  };\n};\n","<div\n  role=\"group\"\n  class=\"bank-account-input-group\"\n  [formGroup]=\"parts\"\n  [attr.aria-labelledby]=\"_formField.getLabelId()\"\n>\n  <mat-select\n    class=\"country-code-select\"\n    matTextPrefix\n    formControlName=\"countryCode\"\n    placeholder=\"XX\"\n    (selectionChange)=\"_handleInput(parts.controls.countryCode)\"\n    #countryCode\n  >\n    <mat-option>\n      <mat-select-search\n        [formControl]=\"filterCtrl\"\n        noEntriesFoundLabel=\"no-entries-label\"\n        placeholderLabel=\"placeholderLabel\"\n      ></mat-select-search>\n    </mat-option>\n\n    <mat-option *ngFor=\"let country of countryCodes$ | async\" [value]=\"country\">\n      <span>{{ country }}</span>\n    </mat-option>\n  </mat-select>\n\n  <input\n    id=\"bban-input\"\n    name=\"bban-input\"\n    class=\"bban-input\"\n    formControlName=\"bban\"\n    (input)=\"_handleInput(parts.controls.bban)\"\n    #bban\n  />\n</div>\n"]}
|
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
import { CommonModule } from '@angular/common';
|
|
2
|
-
import { Component, Input, ViewEncapsulation, } from '@angular/core';
|
|
3
|
-
import { ReactiveFormsModule } from '@angular/forms';
|
|
4
|
-
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
5
|
-
import { MatInputModule } from '@angular/material/input';
|
|
6
|
-
import { MatSelectModule } from '@angular/material/select';
|
|
7
|
-
import { TranslateModule } from '@ngx-translate/core';
|
|
8
|
-
import { Subject } from 'rxjs';
|
|
9
|
-
import { MatSelectSearchModule } from '@onemrvapublic/design-system/mat-select-search';
|
|
10
|
-
import { BankAccountComponent } from './bank-account.component';
|
|
11
|
-
import { bankAccountValidator } from '@onemrvapublic/design-system/shared';
|
|
12
|
-
import { ValidationErrorsIBAN } from 'ibantools';
|
|
13
|
-
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "@angular/common";
|
|
15
|
-
import * as i2 from "@angular/material/form-field";
|
|
16
|
-
import * as i3 from "@angular/forms";
|
|
17
|
-
import * as i4 from "@ngx-translate/core";
|
|
18
|
-
export class OnemrvaMatInputBankAccountComponent {
|
|
19
|
-
constructor() {
|
|
20
|
-
this.key = 'accountNumber';
|
|
21
|
-
this.hint = '';
|
|
22
|
-
this.destroyNotifier$ = new Subject();
|
|
23
|
-
}
|
|
24
|
-
ngOnInit() {
|
|
25
|
-
this.accountNumber.addValidators(bankAccountValidator());
|
|
26
|
-
}
|
|
27
|
-
errors() {
|
|
28
|
-
const bankNumberErrors = this.accountNumber.errors;
|
|
29
|
-
if (!bankNumberErrors) {
|
|
30
|
-
return '';
|
|
31
|
-
}
|
|
32
|
-
if (bankNumberErrors[ValidationErrorsIBAN[ValidationErrorsIBAN.WrongBBANLength]]) {
|
|
33
|
-
return 'input.bank.length';
|
|
34
|
-
}
|
|
35
|
-
if (bankNumberErrors[ValidationErrorsIBAN[ValidationErrorsIBAN.WrongIBANChecksum]]) {
|
|
36
|
-
return 'input.bank.checksum';
|
|
37
|
-
}
|
|
38
|
-
return 'input.bank.invalid';
|
|
39
|
-
}
|
|
40
|
-
ngOnDestroy() {
|
|
41
|
-
this.destroyNotifier$.next();
|
|
42
|
-
this.destroyNotifier$.complete();
|
|
43
|
-
}
|
|
44
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: OnemrvaMatInputBankAccountComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
45
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: OnemrvaMatInputBankAccountComponent, isStandalone: true, selector: "onemrva-mat-input-bank-account", inputs: { accountNumber: "accountNumber", key: "key", hint: "hint" }, ngImport: i0, template: "<mat-form-field class=\"onemrva-bank-account-input\">\n <mat-label>{{ key | translate }}</mat-label>\n\n <bank-account [formControl]=\"accountNumber\" />\n\n <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n\n <mat-error>\n {{ errors() | translate }}\n </mat-error>\n</mat-form-field>\n", styles: [".onemrva-bank-account-input .mat-mdc-select-arrow-wrapper{margin-left:4px}.onemrva-bank-account-input .mat-mdc-form-field-infix{min-width:320px!important}.onemrva-bank-account-input .mat-mdc-form-field-infix .onemrva-bank-account-text{padding-left:4px;vertical-align:middle}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i2.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSelectModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatSelectSearchModule }, { kind: "component", type: BankAccountComponent, selector: "bank-account", inputs: ["aria-describedby", "placeholder", "required", "disabled", "value"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
46
|
-
}
|
|
47
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: OnemrvaMatInputBankAccountComponent, decorators: [{
|
|
48
|
-
type: Component,
|
|
49
|
-
args: [{ selector: 'onemrva-mat-input-bank-account', standalone: true, imports: [
|
|
50
|
-
CommonModule,
|
|
51
|
-
MatInputModule,
|
|
52
|
-
MatFormFieldModule,
|
|
53
|
-
MatSelectModule,
|
|
54
|
-
ReactiveFormsModule,
|
|
55
|
-
TranslateModule,
|
|
56
|
-
MatSelectSearchModule,
|
|
57
|
-
BankAccountComponent,
|
|
58
|
-
], encapsulation: ViewEncapsulation.None, template: "<mat-form-field class=\"onemrva-bank-account-input\">\n <mat-label>{{ key | translate }}</mat-label>\n\n <bank-account [formControl]=\"accountNumber\" />\n\n <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n\n <mat-error>\n {{ errors() | translate }}\n </mat-error>\n</mat-form-field>\n", styles: [".onemrva-bank-account-input .mat-mdc-select-arrow-wrapper{margin-left:4px}.onemrva-bank-account-input .mat-mdc-form-field-infix{min-width:320px!important}.onemrva-bank-account-input .mat-mdc-form-field-infix .onemrva-bank-account-text{padding-left:4px;vertical-align:middle}\n"] }]
|
|
59
|
-
}], propDecorators: { accountNumber: [{
|
|
60
|
-
type: Input
|
|
61
|
-
}], key: [{
|
|
62
|
-
type: Input
|
|
63
|
-
}], hint: [{
|
|
64
|
-
type: Input
|
|
65
|
-
}] } });
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib25lbXJ2YS1tYXQtaW5wdXQtYmFuay1hY2NvdW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL29uZW1ydmEvZGVzaWduLXN5c3RlbS9tYXQtaW5wdXQtYmFuay1hY2NvdW50L3NyYy9vbmVtcnZhLW1hdC1pbnB1dC1iYW5rLWFjY291bnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb25lbXJ2YS9kZXNpZ24tc3lzdGVtL21hdC1pbnB1dC1iYW5rLWFjY291bnQvc3JjL29uZW1ydmEtbWF0LWlucHV0LWJhbmstYWNjb3VudC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUNMLFNBQVMsRUFDVCxLQUFLLEVBR0wsaUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBZSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRXRELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFL0IsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDdkYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDM0UsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sV0FBVyxDQUFDOzs7Ozs7QUFtQmpELE1BQU0sT0FBTyxtQ0FBbUM7SUFqQmhEO1FBbUJXLFFBQUcsR0FBRyxlQUFlLENBQUM7UUFDdEIsU0FBSSxHQUFHLEVBQUUsQ0FBQztRQUVuQixxQkFBZ0IsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO0tBb0N4QztJQWxDQyxRQUFRO1FBQ04sSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsb0JBQW9CLEVBQUUsQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFFRCxNQUFNO1FBQ0osTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQztRQUVuRCxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztZQUN0QixPQUFPLEVBQUUsQ0FBQztRQUNaLENBQUM7UUFFRCxJQUNFLGdCQUFnQixDQUNkLG9CQUFvQixDQUFDLG9CQUFvQixDQUFDLGVBQWUsQ0FBQyxDQUMzRCxFQUNELENBQUM7WUFDRCxPQUFPLG1CQUFtQixDQUFDO1FBQzdCLENBQUM7UUFFRCxJQUNFLGdCQUFnQixDQUNkLG9CQUFvQixDQUFDLG9CQUFvQixDQUFDLGlCQUFpQixDQUFDLENBQzdELEVBQ0QsQ0FBQztZQUNELE9BQU8scUJBQXFCLENBQUM7UUFDL0IsQ0FBQztRQUVELE9BQU8sb0JBQW9CLENBQUM7SUFDOUIsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDN0IsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ25DLENBQUM7OEdBeENVLG1DQUFtQztrR0FBbkMsbUNBQW1DLGdLQ3RDaEQsOFNBV0EsNlVEZ0JJLFlBQVksa0lBQ1osY0FBYywrZEFDZCxrQkFBa0IsOEJBQ2xCLGVBQWUsOEJBQ2YsbUJBQW1CLHlUQUNuQixlQUFlLDJGQUNmLHFCQUFxQiwrQkFDckIsb0JBQW9COzsyRkFJWCxtQ0FBbUM7a0JBakIvQyxTQUFTOytCQUNFLGdDQUFnQyxjQUc5QixJQUFJLFdBQ1A7d0JBQ1AsWUFBWTt3QkFDWixjQUFjO3dCQUNkLGtCQUFrQjt3QkFDbEIsZUFBZTt3QkFDZixtQkFBbUI7d0JBQ25CLGVBQWU7d0JBQ2YscUJBQXFCO3dCQUNyQixvQkFBb0I7cUJBQ3JCLGlCQUNjLGlCQUFpQixDQUFDLElBQUk7OEJBRzVCLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csR0FBRztzQkFBWCxLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1xuICBDb21wb25lbnQsXG4gIElucHV0LFxuICBPbkRlc3Ryb3ksXG4gIE9uSW5pdCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUNvbnRyb2wsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHsgTWF0U2VsZWN0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2VsZWN0JztcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuXG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IE1hdFNlbGVjdFNlYXJjaE1vZHVsZSB9IGZyb20gJ0BvbmVtcnZhcHVibGljL2Rlc2lnbi1zeXN0ZW0vbWF0LXNlbGVjdC1zZWFyY2gnO1xuaW1wb3J0IHsgQmFua0FjY291bnRDb21wb25lbnQgfSBmcm9tICcuL2JhbmstYWNjb3VudC5jb21wb25lbnQnO1xuaW1wb3J0IHsgYmFua0FjY291bnRWYWxpZGF0b3IgfSBmcm9tICdAb25lbXJ2YXB1YmxpYy9kZXNpZ24tc3lzdGVtL3NoYXJlZCc7XG5pbXBvcnQgeyBWYWxpZGF0aW9uRXJyb3JzSUJBTiB9IGZyb20gJ2liYW50b29scyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ29uZW1ydmEtbWF0LWlucHV0LWJhbmstYWNjb3VudCcsXG4gIHN0eWxlVXJsczogWydvbmVtcnZhLW1hdC1pbnB1dC1iYW5rLWFjY291bnQuY29tcG9uZW50LnNjc3MnXSxcbiAgdGVtcGxhdGVVcmw6ICdvbmVtcnZhLW1hdC1pbnB1dC1iYW5rLWFjY291bnQuY29tcG9uZW50Lmh0bWwnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE1hdElucHV0TW9kdWxlLFxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcbiAgICBNYXRTZWxlY3RNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBUcmFuc2xhdGVNb2R1bGUsXG4gICAgTWF0U2VsZWN0U2VhcmNoTW9kdWxlLFxuICAgIEJhbmtBY2NvdW50Q29tcG9uZW50LFxuICBdLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxufSlcbmV4cG9ydCBjbGFzcyBPbmVtcnZhTWF0SW5wdXRCYW5rQWNjb3VudENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgQElucHV0KCkgYWNjb3VudE51bWJlciE6IEZvcm1Db250cm9sPHN0cmluZyB8IG51bGw+O1xuICBASW5wdXQoKSBrZXkgPSAnYWNjb3VudE51bWJlcic7XG4gIEBJbnB1dCgpIGhpbnQgPSAnJztcblxuICBkZXN0cm95Tm90aWZpZXIkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLmFjY291bnROdW1iZXIuYWRkVmFsaWRhdG9ycyhiYW5rQWNjb3VudFZhbGlkYXRvcigpKTtcbiAgfVxuXG4gIGVycm9ycygpIHtcbiAgICBjb25zdCBiYW5rTnVtYmVyRXJyb3JzID0gdGhpcy5hY2NvdW50TnVtYmVyLmVycm9ycztcblxuICAgIGlmICghYmFua051bWJlckVycm9ycykge1xuICAgICAgcmV0dXJuICcnO1xuICAgIH1cblxuICAgIGlmIChcbiAgICAgIGJhbmtOdW1iZXJFcnJvcnNbXG4gICAgICAgIFZhbGlkYXRpb25FcnJvcnNJQkFOW1ZhbGlkYXRpb25FcnJvcnNJQkFOLldyb25nQkJBTkxlbmd0aF1cbiAgICAgIF1cbiAgICApIHtcbiAgICAgIHJldHVybiAnaW5wdXQuYmFuay5sZW5ndGgnO1xuICAgIH1cblxuICAgIGlmIChcbiAgICAgIGJhbmtOdW1iZXJFcnJvcnNbXG4gICAgICAgIFZhbGlkYXRpb25FcnJvcnNJQkFOW1ZhbGlkYXRpb25FcnJvcnNJQkFOLldyb25nSUJBTkNoZWNrc3VtXVxuICAgICAgXVxuICAgICkge1xuICAgICAgcmV0dXJuICdpbnB1dC5iYW5rLmNoZWNrc3VtJztcbiAgICB9XG5cbiAgICByZXR1cm4gJ2lucHV0LmJhbmsuaW52YWxpZCc7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLmRlc3Ryb3lOb3RpZmllciQubmV4dCgpO1xuICAgIHRoaXMuZGVzdHJveU5vdGlmaWVyJC5jb21wbGV0ZSgpO1xuICB9XG59XG4iLCI8bWF0LWZvcm0tZmllbGQgY2xhc3M9XCJvbmVtcnZhLWJhbmstYWNjb3VudC1pbnB1dFwiPlxuICA8bWF0LWxhYmVsPnt7IGtleSB8IHRyYW5zbGF0ZSB9fTwvbWF0LWxhYmVsPlxuXG4gIDxiYW5rLWFjY291bnQgW2Zvcm1Db250cm9sXT1cImFjY291bnROdW1iZXJcIiAvPlxuXG4gIDxtYXQtaGludCAqbmdJZj1cImhpbnQgIT09ICcnXCI+e3sgaGludCB9fTwvbWF0LWhpbnQ+XG5cbiAgPG1hdC1lcnJvcj5cbiAgICB7eyBlcnJvcnMoKSB8IHRyYW5zbGF0ZSB9fVxuICA8L21hdC1lcnJvcj5cbjwvbWF0LWZvcm0tZmllbGQ+XG4iXX0=
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
.bank-account-input-group {
|
|
2
|
-
display: flex;
|
|
3
|
-
width: 100%;
|
|
4
|
-
|
|
5
|
-
.country-code-input,
|
|
6
|
-
.bban-input {
|
|
7
|
-
border: none;
|
|
8
|
-
background: none;
|
|
9
|
-
padding: 0;
|
|
10
|
-
outline: none;
|
|
11
|
-
font: inherit;
|
|
12
|
-
text-align: left;
|
|
13
|
-
color: currentcolor;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
.bban-input {
|
|
17
|
-
padding-left: 4px;
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
//.example-tel-input-container {
|
|
22
|
-
// display: flex;
|
|
23
|
-
//}
|
|
24
|
-
//
|
|
25
|
-
//.example-tel-input-element {
|
|
26
|
-
// border: none;
|
|
27
|
-
// background: none;
|
|
28
|
-
// padding: 0;
|
|
29
|
-
// outline: none;
|
|
30
|
-
// font: inherit;
|
|
31
|
-
// text-align: center;
|
|
32
|
-
// color: currentcolor;
|
|
33
|
-
//}
|
|
34
|
-
//
|
|
35
|
-
//.example-tel-input-spacer {
|
|
36
|
-
// opacity: 0;
|
|
37
|
-
// transition: opacity 200ms;
|
|
38
|
-
//}
|
|
39
|
-
|
|
40
|
-
//:host.example-floating .example-tel-input-spacer {
|
|
41
|
-
// opacity: 1;
|
|
42
|
-
//}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
|
-
import { FormControl } from '@angular/forms';
|
|
3
|
-
import { Subject } from 'rxjs';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class OnemrvaMatInputBankAccountComponent implements OnInit, OnDestroy {
|
|
6
|
-
accountNumber: FormControl<string | null>;
|
|
7
|
-
key: string;
|
|
8
|
-
hint: string;
|
|
9
|
-
destroyNotifier$: Subject<void>;
|
|
10
|
-
ngOnInit(): void;
|
|
11
|
-
errors(): "" | "input.bank.length" | "input.bank.checksum" | "input.bank.invalid";
|
|
12
|
-
ngOnDestroy(): void;
|
|
13
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<OnemrvaMatInputBankAccountComponent, never>;
|
|
14
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<OnemrvaMatInputBankAccountComponent, "onemrva-mat-input-bank-account", never, { "accountNumber": { "alias": "accountNumber"; "required": false; }; "key": { "alias": "key"; "required": false; }; "hint": { "alias": "hint"; "required": false; }; }, {}, never, never, true, never>;
|
|
15
|
-
}
|