ecabs-components 1.1.15 → 1.1.16
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/README.md +1 -0
- package/esm2022/lib/base/consts/country-codes.mjs +559 -0
- package/esm2022/lib/base/models/phone.models.mjs +2 -0
- package/esm2022/lib/base/pipes/search.pipe.mjs +22 -0
- package/esm2022/lib/base/validators/phone-number.validator.mjs +23 -0
- package/esm2022/lib/ecabs-base-phone-input/ecabs-base-phone.component.mjs +415 -0
- package/esm2022/lib/ecabs-base-phone-input/ecabs-base-phone.module.mjs +58 -0
- package/esm2022/lib/ecabs-phone/ecabs-phone.component.mjs +4 -4
- package/esm2022/lib/ecabs-phone/ecabs-phone.module.mjs +7 -7
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/ecabs-components.mjs +1098 -53
- package/fesm2022/ecabs-components.mjs.map +1 -1
- package/lib/base/consts/country-codes.d.ts +7 -0
- package/lib/base/models/phone.models.d.ts +10 -0
- package/lib/base/pipes/search.pipe.d.ts +8 -0
- package/lib/base/validators/phone-number.validator.d.ts +4 -0
- package/lib/ecabs-base-phone-input/ecabs-base-phone.component.d.ts +96 -0
- package/lib/ecabs-base-phone-input/ecabs-base-phone.module.d.ts +17 -0
- package/lib/ecabs-phone/ecabs-phone.component.d.ts +2 -2
- package/lib/ecabs-phone/ecabs-phone.module.d.ts +2 -2
- package/package.json +1 -2
- package/public-api.d.ts +2 -0
- package/src/assets/styles/material/overrides/_phone.scss +5 -5
- package/src/assets/styles/scss/modules/_phone.scss +3 -3
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGhvbmUubW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2Jhc2UvbW9kZWxzL3Bob25lLm1vZGVscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgUGhvbmVOdW1iZXJGb3JtYXQgPSAnZGVmYXVsdCcgfCAnbmF0aW9uYWwnIHwgJ2ludGVybmF0aW9uYWwnO1xyXG5cclxuZXhwb3J0IHR5cGUgQ291bnRyeSA9IHtcclxuICBuYW1lOiBzdHJpbmc7XHJcbiAgaXNvMjogc3RyaW5nO1xyXG4gIGRpYWxDb2RlOiBzdHJpbmc7XHJcbiAgcHJpb3JpdHk6IG51bWJlcjtcclxuICBhcmVhQ29kZXM/OiBzdHJpbmdbXTtcclxuICBmbGFnQ2xhc3M6IHN0cmluZztcclxuICBwbGFjZUhvbGRlcj86IHN0cmluZztcclxufTtcclxuIl19
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class SearchPipe {
|
|
4
|
+
transform(country, searchCriteria) {
|
|
5
|
+
if (!searchCriteria || searchCriteria === '') {
|
|
6
|
+
return true;
|
|
7
|
+
}
|
|
8
|
+
return `${country.name}+${country.dialCode}`
|
|
9
|
+
.toLowerCase()
|
|
10
|
+
.includes(searchCriteria.toLowerCase());
|
|
11
|
+
}
|
|
12
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SearchPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
13
|
+
static ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: SearchPipe, isStandalone: true, name: "search" });
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SearchPipe, decorators: [{
|
|
16
|
+
type: Pipe,
|
|
17
|
+
args: [{
|
|
18
|
+
name: 'search',
|
|
19
|
+
standalone: true,
|
|
20
|
+
}]
|
|
21
|
+
}] });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvYmFzZS9waXBlcy9zZWFyY2gucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFPcEQsTUFBTSxPQUFPLFVBQVU7SUFDckIsU0FBUyxDQUFDLE9BQWdCLEVBQUUsY0FBdUI7UUFDakQsSUFBSSxDQUFDLGNBQWMsSUFBSSxjQUFjLEtBQUssRUFBRSxFQUFFO1lBQzVDLE9BQU8sSUFBSSxDQUFDO1NBQ2I7UUFFRCxPQUFPLEdBQUcsT0FBTyxDQUFDLElBQUksSUFBSSxPQUFPLENBQUMsUUFBUSxFQUFFO2FBQ3pDLFdBQVcsRUFBRTthQUNiLFFBQVEsQ0FBQyxjQUFjLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUM1QyxDQUFDO3dHQVRVLFVBQVU7c0dBQVYsVUFBVTs7NEZBQVYsVUFBVTtrQkFKdEIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsUUFBUTtvQkFDZCxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvdW50cnkgfSBmcm9tICcuLi9tb2RlbHMvcGhvbmUubW9kZWxzJztcclxuXHJcbkBQaXBlKHtcclxuICBuYW1lOiAnc2VhcmNoJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2VhcmNoUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG4gIHRyYW5zZm9ybShjb3VudHJ5OiBDb3VudHJ5LCBzZWFyY2hDcml0ZXJpYT86IHN0cmluZyk6IGJvb2xlYW4ge1xyXG4gICAgaWYgKCFzZWFyY2hDcml0ZXJpYSB8fCBzZWFyY2hDcml0ZXJpYSA9PT0gJycpIHtcclxuICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIGAke2NvdW50cnkubmFtZX0rJHtjb3VudHJ5LmRpYWxDb2RlfWBcclxuICAgICAgLnRvTG93ZXJDYXNlKClcclxuICAgICAgLmluY2x1ZGVzKHNlYXJjaENyaXRlcmlhLnRvTG93ZXJDYXNlKCkpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { parsePhoneNumber } from 'libphonenumber-js';
|
|
2
|
+
export const phoneNumberValidator = (control) => {
|
|
3
|
+
const error = { validatePhoneNumber: true };
|
|
4
|
+
let numberInstance;
|
|
5
|
+
if (control.value) {
|
|
6
|
+
try {
|
|
7
|
+
numberInstance = parsePhoneNumber(control.value);
|
|
8
|
+
}
|
|
9
|
+
catch (e) {
|
|
10
|
+
control.setValue(null);
|
|
11
|
+
return error;
|
|
12
|
+
}
|
|
13
|
+
if (numberInstance && !numberInstance.isValid()) {
|
|
14
|
+
control.setValue(null);
|
|
15
|
+
if (!control.touched) {
|
|
16
|
+
control.markAsTouched();
|
|
17
|
+
}
|
|
18
|
+
return error;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return null;
|
|
22
|
+
};
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGhvbmUtbnVtYmVyLnZhbGlkYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9iYXNlL3ZhbGlkYXRvcnMvcGhvbmUtbnVtYmVyLnZhbGlkYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQWUsTUFBTSxtQkFBbUIsQ0FBQztBQUVsRSxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxDQUFDLE9BQTJCLEVBQUUsRUFBRTtJQUNsRSxNQUFNLEtBQUssR0FBRyxFQUFFLG1CQUFtQixFQUFFLElBQUksRUFBRSxDQUFDO0lBQzVDLElBQUksY0FBMkIsQ0FBQztJQUNoQyxJQUFJLE9BQU8sQ0FBQyxLQUFLLEVBQUU7UUFDakIsSUFBSTtZQUNGLGNBQWMsR0FBRyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDbEQ7UUFBQyxPQUFPLENBQUMsRUFBRTtZQUNWLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7WUFFdkIsT0FBTyxLQUFLLENBQUM7U0FDZDtRQUVELElBQUksY0FBYyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sRUFBRSxFQUFFO1lBQy9DLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDdkIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUU7Z0JBQ3BCLE9BQU8sQ0FBQyxhQUFhLEVBQUUsQ0FBQzthQUN6QjtZQUVELE9BQU8sS0FBSyxDQUFDO1NBQ2Q7S0FDRjtJQUVELE9BQU8sSUFBSSxDQUFDO0FBQ2QsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVW50eXBlZEZvcm1Db250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBwYXJzZVBob25lTnVtYmVyLCBQaG9uZU51bWJlciB9IGZyb20gJ2xpYnBob25lbnVtYmVyLWpzJztcclxuXHJcbmV4cG9ydCBjb25zdCBwaG9uZU51bWJlclZhbGlkYXRvciA9IChjb250cm9sOiBVbnR5cGVkRm9ybUNvbnRyb2wpID0+IHtcclxuICBjb25zdCBlcnJvciA9IHsgdmFsaWRhdGVQaG9uZU51bWJlcjogdHJ1ZSB9O1xyXG4gIGxldCBudW1iZXJJbnN0YW5jZTogUGhvbmVOdW1iZXI7XHJcbiAgaWYgKGNvbnRyb2wudmFsdWUpIHtcclxuICAgIHRyeSB7XHJcbiAgICAgIG51bWJlckluc3RhbmNlID0gcGFyc2VQaG9uZU51bWJlcihjb250cm9sLnZhbHVlKTtcclxuICAgIH0gY2F0Y2ggKGUpIHtcclxuICAgICAgY29udHJvbC5zZXRWYWx1ZShudWxsKTtcclxuXHJcbiAgICAgIHJldHVybiBlcnJvcjtcclxuICAgIH1cclxuXHJcbiAgICBpZiAobnVtYmVySW5zdGFuY2UgJiYgIW51bWJlckluc3RhbmNlLmlzVmFsaWQoKSkge1xyXG4gICAgICBjb250cm9sLnNldFZhbHVlKG51bGwpO1xyXG4gICAgICBpZiAoIWNvbnRyb2wudG91Y2hlZCkge1xyXG4gICAgICAgIGNvbnRyb2wubWFya0FzVG91Y2hlZCgpO1xyXG4gICAgICB9XHJcblxyXG4gICAgICByZXR1cm4gZXJyb3I7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICByZXR1cm4gbnVsbDtcclxufTtcclxuIl19
|
|
@@ -0,0 +1,415 @@
|
|
|
1
|
+
// eslint-disable @typescript-eslint/no-explicit-any
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Optional, Output, Self, ViewChild, } from '@angular/core';
|
|
3
|
+
import { MatFormFieldControl } from '@angular/material/form-field';
|
|
4
|
+
import { NG_VALIDATORS, } from '@angular/forms';
|
|
5
|
+
import { AsYouType, getExampleNumber, parsePhoneNumberFromString, } from 'libphonenumber-js';
|
|
6
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
7
|
+
import { ErrorStateMatcher, mixinErrorState, } from '@angular/material/core';
|
|
8
|
+
import { MatMenu } from '@angular/material/menu';
|
|
9
|
+
import { debounceTime, Subject } from 'rxjs';
|
|
10
|
+
import { CountryCode, Examples } from '../base/consts/country-codes';
|
|
11
|
+
import { phoneNumberValidator } from '../base/validators/phone-number.validator';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "../base/consts/country-codes";
|
|
14
|
+
import * as i2 from "@angular/cdk/a11y";
|
|
15
|
+
import * as i3 from "@angular/forms";
|
|
16
|
+
import * as i4 from "@angular/material/core";
|
|
17
|
+
import * as i5 from "@angular/common";
|
|
18
|
+
import * as i6 from "@angular/material/input";
|
|
19
|
+
import * as i7 from "@angular/material/menu";
|
|
20
|
+
import * as i8 from "@angular/material/button";
|
|
21
|
+
import * as i9 from "@angular/material/divider";
|
|
22
|
+
import * as i10 from "../base/pipes/search.pipe";
|
|
23
|
+
class NgxMatIntlTelInputBase {
|
|
24
|
+
_defaultErrorStateMatcher;
|
|
25
|
+
_parentForm;
|
|
26
|
+
_parentFormGroup;
|
|
27
|
+
ngControl;
|
|
28
|
+
stateChanges = new Subject();
|
|
29
|
+
constructor(_defaultErrorStateMatcher, _parentForm, _parentFormGroup, ngControl) {
|
|
30
|
+
this._defaultErrorStateMatcher = _defaultErrorStateMatcher;
|
|
31
|
+
this._parentForm = _parentForm;
|
|
32
|
+
this._parentFormGroup = _parentFormGroup;
|
|
33
|
+
this.ngControl = ngControl;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
const _NgxMatIntlTelInputMixinBase = mixinErrorState(NgxMatIntlTelInputBase);
|
|
37
|
+
export class EcabsBasePhoneComponent extends _NgxMatIntlTelInputMixinBase {
|
|
38
|
+
changeDetectorRef;
|
|
39
|
+
countryCodeData;
|
|
40
|
+
fm;
|
|
41
|
+
elRef;
|
|
42
|
+
ngControl;
|
|
43
|
+
preferredCountries = [];
|
|
44
|
+
enablePlaceholder = true;
|
|
45
|
+
inputPlaceholder;
|
|
46
|
+
cssClass;
|
|
47
|
+
name;
|
|
48
|
+
onlyCountries = [];
|
|
49
|
+
errorStateMatcher = new ErrorStateMatcher();
|
|
50
|
+
enableSearch = false;
|
|
51
|
+
searchPlaceholder;
|
|
52
|
+
describedBy = '';
|
|
53
|
+
debounceTimeMs = 500;
|
|
54
|
+
get format() {
|
|
55
|
+
return this._format;
|
|
56
|
+
}
|
|
57
|
+
get placeholder() {
|
|
58
|
+
return this._placeholder || '';
|
|
59
|
+
}
|
|
60
|
+
get required() {
|
|
61
|
+
return this._required;
|
|
62
|
+
}
|
|
63
|
+
get disabled() {
|
|
64
|
+
return this._disabled;
|
|
65
|
+
}
|
|
66
|
+
countryChanged = new EventEmitter();
|
|
67
|
+
matMenu;
|
|
68
|
+
searchInput;
|
|
69
|
+
id = `ecabs-intl-tel-input-${EcabsBasePhoneComponent.nextId++}`;
|
|
70
|
+
get shouldLabelFloat() {
|
|
71
|
+
return this.focused || !this.empty;
|
|
72
|
+
}
|
|
73
|
+
static nextId = 0;
|
|
74
|
+
_changeSubject = new Subject();
|
|
75
|
+
_placeholder;
|
|
76
|
+
_required = false;
|
|
77
|
+
_disabled = false;
|
|
78
|
+
_previousFormattedNumber;
|
|
79
|
+
_format = 'default';
|
|
80
|
+
stateChanges = new Subject();
|
|
81
|
+
focused = false;
|
|
82
|
+
phoneNumber;
|
|
83
|
+
allCountries = [];
|
|
84
|
+
preferredCountriesInDropDown = [];
|
|
85
|
+
selectedCountry;
|
|
86
|
+
numberInstance;
|
|
87
|
+
value;
|
|
88
|
+
searchCriteria;
|
|
89
|
+
get empty() {
|
|
90
|
+
return !this.phoneNumber;
|
|
91
|
+
}
|
|
92
|
+
set format(value) {
|
|
93
|
+
this._format = value;
|
|
94
|
+
this.phoneNumber = this.formattedPhoneNumber;
|
|
95
|
+
this.stateChanges.next(undefined);
|
|
96
|
+
}
|
|
97
|
+
set placeholder(value) {
|
|
98
|
+
this._placeholder = value;
|
|
99
|
+
this.stateChanges.next(undefined);
|
|
100
|
+
}
|
|
101
|
+
set required(value) {
|
|
102
|
+
this._required = coerceBooleanProperty(value);
|
|
103
|
+
this.stateChanges.next(undefined);
|
|
104
|
+
}
|
|
105
|
+
set disabled(value) {
|
|
106
|
+
this._disabled = coerceBooleanProperty(value);
|
|
107
|
+
this.stateChanges.next(undefined);
|
|
108
|
+
}
|
|
109
|
+
static getPhoneNumberPlaceHolder(countryISOCode) {
|
|
110
|
+
const result = getExampleNumber(countryISOCode, Examples);
|
|
111
|
+
// eslint-disable-next-line no-extra-boolean-cast
|
|
112
|
+
return !!result ? result.number.toString() : undefined;
|
|
113
|
+
}
|
|
114
|
+
onTouched = () => { };
|
|
115
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
116
|
+
propagateChange = (_) => { };
|
|
117
|
+
constructor(changeDetectorRef, countryCodeData, fm, elRef, ngControl, parentForm, parentFormGroup, defaultErrorStateMatcher) {
|
|
118
|
+
super(defaultErrorStateMatcher, parentForm, parentFormGroup, ngControl);
|
|
119
|
+
this.changeDetectorRef = changeDetectorRef;
|
|
120
|
+
this.countryCodeData = countryCodeData;
|
|
121
|
+
this.fm = fm;
|
|
122
|
+
this.elRef = elRef;
|
|
123
|
+
this.ngControl = ngControl;
|
|
124
|
+
fm.monitor(elRef, true).subscribe((origin) => {
|
|
125
|
+
if (this.focused && !origin) {
|
|
126
|
+
this.onTouched();
|
|
127
|
+
}
|
|
128
|
+
this.focused = !!origin;
|
|
129
|
+
this.stateChanges.next(undefined);
|
|
130
|
+
});
|
|
131
|
+
this.fetchCountryData();
|
|
132
|
+
if (this.ngControl != null) {
|
|
133
|
+
this.ngControl.valueAccessor = this;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
ngOnInit() {
|
|
137
|
+
if (!this.searchPlaceholder) {
|
|
138
|
+
this.searchPlaceholder = 'Search ...';
|
|
139
|
+
}
|
|
140
|
+
if (this.preferredCountries.length) {
|
|
141
|
+
this.preferredCountries.forEach((iso2) => {
|
|
142
|
+
const preferredCountry = this.allCountries
|
|
143
|
+
.filter((c) => c.iso2 === iso2)
|
|
144
|
+
.shift();
|
|
145
|
+
if (preferredCountry) {
|
|
146
|
+
this.preferredCountriesInDropDown.push(preferredCountry);
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
if (this.onlyCountries.length) {
|
|
151
|
+
this.allCountries = this.allCountries.filter((c) => this.onlyCountries.includes(c.iso2));
|
|
152
|
+
}
|
|
153
|
+
if (this.numberInstance && this.numberInstance.country) {
|
|
154
|
+
// If an existing number is present, we use it to determine selectedCountry
|
|
155
|
+
this.selectedCountry = this.getCountry(this.numberInstance.country);
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
if (this.preferredCountriesInDropDown.length) {
|
|
159
|
+
this.selectedCountry = this.preferredCountriesInDropDown[0];
|
|
160
|
+
}
|
|
161
|
+
else {
|
|
162
|
+
this.selectedCountry = this.allCountries[0];
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
this._changeSubject
|
|
166
|
+
.pipe(debounceTime(this.debounceTimeMs))
|
|
167
|
+
.subscribe(() => {
|
|
168
|
+
this.onPhoneNumberChange();
|
|
169
|
+
});
|
|
170
|
+
this.countryChanged.emit(this.selectedCountry);
|
|
171
|
+
this.changeDetectorRef.markForCheck();
|
|
172
|
+
this.stateChanges.next(undefined);
|
|
173
|
+
}
|
|
174
|
+
ngDoCheck() {
|
|
175
|
+
if (this.ngControl) {
|
|
176
|
+
this.updateErrorState();
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
ngOnDestroy() {
|
|
180
|
+
this.stateChanges.complete();
|
|
181
|
+
this.fm.stopMonitoring(this.elRef);
|
|
182
|
+
this._changeSubject.complete();
|
|
183
|
+
}
|
|
184
|
+
onPhoneNumberChangeDebounce() {
|
|
185
|
+
this._changeSubject.next(undefined);
|
|
186
|
+
}
|
|
187
|
+
onPhoneNumberChange() {
|
|
188
|
+
try {
|
|
189
|
+
this.numberInstance = parsePhoneNumberFromString(this.phoneNumber?.toString() || '', this.selectedCountry?.iso2.toUpperCase());
|
|
190
|
+
this.formatAsYouTypeIfEnabled();
|
|
191
|
+
this.value = this.numberInstance?.number;
|
|
192
|
+
if (this.numberInstance && this.numberInstance.isValid()) {
|
|
193
|
+
if (this.phoneNumber !== this.formattedPhoneNumber) {
|
|
194
|
+
this.phoneNumber = this.formattedPhoneNumber;
|
|
195
|
+
}
|
|
196
|
+
if (this.selectedCountry?.iso2 !== this.numberInstance.country &&
|
|
197
|
+
!!this.numberInstance.country) {
|
|
198
|
+
this.selectedCountry = this.getCountry(this.numberInstance.country);
|
|
199
|
+
this.countryChanged.emit(this.selectedCountry);
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
catch {
|
|
204
|
+
// if no possible numbers are there,
|
|
205
|
+
// then the full number is passed so that validator could be triggered and proper error could be shown
|
|
206
|
+
this.value = this.phoneNumber?.toString();
|
|
207
|
+
}
|
|
208
|
+
this.propagateChange(this.value);
|
|
209
|
+
this.changeDetectorRef.markForCheck();
|
|
210
|
+
}
|
|
211
|
+
onCountrySelect(country) {
|
|
212
|
+
if (this.phoneNumber) {
|
|
213
|
+
this.phoneNumber = this.numberInstance?.nationalNumber;
|
|
214
|
+
}
|
|
215
|
+
this.selectedCountry = country;
|
|
216
|
+
this.countryChanged.emit(this.selectedCountry);
|
|
217
|
+
this.onPhoneNumberChange();
|
|
218
|
+
}
|
|
219
|
+
getCountry(code) {
|
|
220
|
+
return (this.allCountries.find((c) => c.iso2 === code.toLowerCase()) || {
|
|
221
|
+
name: 'UN',
|
|
222
|
+
iso2: 'UN',
|
|
223
|
+
dialCode: '',
|
|
224
|
+
priority: 0,
|
|
225
|
+
areaCodes: undefined,
|
|
226
|
+
flagClass: 'UN',
|
|
227
|
+
placeHolder: '',
|
|
228
|
+
});
|
|
229
|
+
}
|
|
230
|
+
onInputKeyPress(event) {
|
|
231
|
+
const pattern = /[0-9+\- ]/;
|
|
232
|
+
if (!pattern.test(event.key)) {
|
|
233
|
+
event.preventDefault();
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
flagClass(lang) {
|
|
237
|
+
return `fi fi-${lang?.slice(-2).toLowerCase()}`;
|
|
238
|
+
}
|
|
239
|
+
registerOnChange(fn) {
|
|
240
|
+
this.propagateChange = fn;
|
|
241
|
+
}
|
|
242
|
+
registerOnTouched(fn) {
|
|
243
|
+
this.onTouched = fn;
|
|
244
|
+
}
|
|
245
|
+
setDisabledState(isDisabled) {
|
|
246
|
+
this.disabled = isDisabled;
|
|
247
|
+
this.changeDetectorRef.markForCheck();
|
|
248
|
+
this.stateChanges.next(undefined);
|
|
249
|
+
}
|
|
250
|
+
writeValue(value) {
|
|
251
|
+
if (value) {
|
|
252
|
+
this.numberInstance = parsePhoneNumberFromString(value);
|
|
253
|
+
if (this.numberInstance) {
|
|
254
|
+
const countryCode = this.numberInstance.country;
|
|
255
|
+
this.phoneNumber = this.formattedPhoneNumber;
|
|
256
|
+
if (!countryCode) {
|
|
257
|
+
return;
|
|
258
|
+
}
|
|
259
|
+
setTimeout(() => {
|
|
260
|
+
this.selectedCountry = this.getCountry(countryCode);
|
|
261
|
+
if (this.selectedCountry.dialCode &&
|
|
262
|
+
!this.preferredCountries.includes(this.selectedCountry.iso2)) {
|
|
263
|
+
this.preferredCountriesInDropDown.push(this.selectedCountry);
|
|
264
|
+
}
|
|
265
|
+
this.countryChanged.emit(this.selectedCountry);
|
|
266
|
+
// Initial value is set
|
|
267
|
+
this.changeDetectorRef.markForCheck();
|
|
268
|
+
this.stateChanges.next(undefined);
|
|
269
|
+
}, 1);
|
|
270
|
+
}
|
|
271
|
+
else {
|
|
272
|
+
this.phoneNumber = value;
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
// Value is set from outside using setValue()
|
|
276
|
+
this.changeDetectorRef.markForCheck();
|
|
277
|
+
this.stateChanges.next(undefined);
|
|
278
|
+
}
|
|
279
|
+
setDescribedByIds(ids) {
|
|
280
|
+
this.describedBy = ids.join(' ');
|
|
281
|
+
}
|
|
282
|
+
onContainerClick(event) {
|
|
283
|
+
if (event.target.tagName.toLowerCase() !== 'input') {
|
|
284
|
+
this.elRef.nativeElement.querySelector('input').focus();
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
reset() {
|
|
288
|
+
this.phoneNumber = '';
|
|
289
|
+
this.propagateChange(null);
|
|
290
|
+
this.changeDetectorRef.markForCheck();
|
|
291
|
+
this.stateChanges.next(undefined);
|
|
292
|
+
}
|
|
293
|
+
onSearchInput() {
|
|
294
|
+
setTimeout(() => {
|
|
295
|
+
this.searchInput?.nativeElement?.focus();
|
|
296
|
+
}, 200);
|
|
297
|
+
}
|
|
298
|
+
fetchCountryData() {
|
|
299
|
+
this.countryCodeData.allCountries.forEach((c) => {
|
|
300
|
+
const country = {
|
|
301
|
+
name: c[0].toString(),
|
|
302
|
+
iso2: c[1].toString(),
|
|
303
|
+
dialCode: c[2].toString(),
|
|
304
|
+
priority: +c[3] || 0,
|
|
305
|
+
areaCodes: c[4] || undefined,
|
|
306
|
+
flagClass: c[1].toString().toUpperCase(),
|
|
307
|
+
placeHolder: '',
|
|
308
|
+
};
|
|
309
|
+
if (this.enablePlaceholder) {
|
|
310
|
+
country.placeHolder = EcabsBasePhoneComponent.getPhoneNumberPlaceHolder(country.iso2.toUpperCase());
|
|
311
|
+
}
|
|
312
|
+
this.allCountries.push(country);
|
|
313
|
+
});
|
|
314
|
+
}
|
|
315
|
+
get formattedPhoneNumber() {
|
|
316
|
+
if (!this.numberInstance) {
|
|
317
|
+
return this.phoneNumber?.toString() || '';
|
|
318
|
+
}
|
|
319
|
+
switch (this.format) {
|
|
320
|
+
case 'national':
|
|
321
|
+
return this.numberInstance.formatNational();
|
|
322
|
+
case 'international':
|
|
323
|
+
return this.numberInstance.formatInternational();
|
|
324
|
+
default:
|
|
325
|
+
return this.numberInstance.nationalNumber.toString();
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
formatAsYouTypeIfEnabled() {
|
|
329
|
+
if (this.format === 'default') {
|
|
330
|
+
return;
|
|
331
|
+
}
|
|
332
|
+
const asYouType = new AsYouType(this.selectedCountry?.iso2.toUpperCase());
|
|
333
|
+
// To avoid caret positioning we apply formatting only if the caret is at the end:
|
|
334
|
+
if (this.phoneNumber
|
|
335
|
+
?.toString()
|
|
336
|
+
.startsWith(this._previousFormattedNumber || '')) {
|
|
337
|
+
this.phoneNumber = asYouType.input(this.phoneNumber.toString());
|
|
338
|
+
}
|
|
339
|
+
this._previousFormattedNumber = this.phoneNumber?.toString();
|
|
340
|
+
}
|
|
341
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsBasePhoneComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.CountryCode }, { token: i2.FocusMonitor }, { token: i0.ElementRef }, { token: i3.NgControl, optional: true, self: true }, { token: i3.NgForm, optional: true }, { token: i3.FormGroupDirective, optional: true }, { token: i4.ErrorStateMatcher }], target: i0.ɵɵFactoryTarget.Component });
|
|
342
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsBasePhoneComponent, selector: "ecabs-base-phone", inputs: { preferredCountries: "preferredCountries", enablePlaceholder: "enablePlaceholder", inputPlaceholder: "inputPlaceholder", cssClass: "cssClass", name: "name", onlyCountries: "onlyCountries", errorStateMatcher: "errorStateMatcher", enableSearch: "enableSearch", searchPlaceholder: "searchPlaceholder", describedBy: "describedBy", debounceTimeMs: "debounceTimeMs", format: "format", placeholder: "placeholder", required: "required", disabled: "disabled" }, outputs: { countryChanged: "countryChanged" }, host: { properties: { "id": "this.id", "class.ngx-floating": "this.shouldLabelFloat" } }, providers: [
|
|
343
|
+
CountryCode,
|
|
344
|
+
{ provide: MatFormFieldControl, useExisting: EcabsBasePhoneComponent },
|
|
345
|
+
{
|
|
346
|
+
provide: NG_VALIDATORS,
|
|
347
|
+
useValue: phoneNumberValidator,
|
|
348
|
+
multi: true,
|
|
349
|
+
},
|
|
350
|
+
], viewQueries: [{ propertyName: "matMenu", first: true, predicate: MatMenu, descendants: true }, { propertyName: "searchInput", first: true, predicate: ["searchInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"ecabs-tel-input-container\">\r\n <button\r\n type=\"button\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n class=\"country-selector\"\r\n [disabled]=\"disabled\"\r\n >\r\n <span\r\n class=\"country-selector-flag flag\"\r\n [ngClass]=\"flagClass(selectedCountry?.flagClass)\"\r\n ></span>\r\n <span class=\"country-selector-code\" *ngIf=\"selectedCountry?.dialCode\"\r\n >+{{ selectedCountry.dialCode }}</span\r\n >\r\n </button>\r\n <mat-menu #menu=\"matMenu\"\r\n class=\"ecabs-tel-input-mat-menu-panel\"\r\n backdropClass=\"ecabs-tel-input-overlay-backdrop\"\r\n overlayPanelClass=\"ecabs-tel-input-overlay-pane\">\r\n <input\r\n #searchInput\r\n *ngIf=\"enableSearch\"\r\n class=\"country-search\"\r\n [(ngModel)]=\"searchCriteria\"\r\n (ngModelChange)=\"onSearchInput()\"\r\n type=\"text\"\r\n [placeholder]=\"searchPlaceholder\"\r\n (click)=\"$event.stopPropagation()\"\r\n />\r\n <ng-container *ngIf=\"!searchCriteria\">\r\n <button\r\n type=\"button\"\r\n mat-menu-item\r\n class=\"country-list-button\"\r\n *ngFor=\"let country of preferredCountriesInDropDown\"\r\n (click)=\"onCountrySelect(country)\"\r\n >\r\n <div class=\"icon-wrapper\">\r\n <div class=\"flag\" \r\n [ngClass]=\"flagClass(country.flagClass)\"></div>\r\n </div>\r\n <div class=\"label-wrapper\">\r\n {{ country.name }}\r\n <span *ngIf=\"country?.dialCode\">+{{ country.dialCode }}</span>\r\n </div>\r\n </button>\r\n <mat-divider *ngIf=\"preferredCountriesInDropDown?.length\"></mat-divider>\r\n </ng-container>\r\n <ng-container *ngFor=\"let country of allCountries\">\r\n <button\r\n type=\"button\"\r\n mat-menu-item\r\n class=\"country-list-button\"\r\n *ngIf=\"country | search: searchCriteria\"\r\n (click)=\"onCountrySelect(country)\"\r\n >\r\n <div class=\"icon-wrapper\">\r\n <div class=\"flag\" [ngClass]=\"flagClass(country.flagClass)\"></div>\r\n </div>\r\n <div class=\"label-wrapper\">\r\n {{ country.name }} +{{ country.dialCode }}\r\n </div>\r\n </button>\r\n </ng-container>\r\n </mat-menu>\r\n\r\n <input\r\n matInput\r\n type=\"tel\"\r\n autocomplete=\"tel\"\r\n [ngClass]=\"cssClass\"\r\n (blur)=\"onTouched()\"\r\n (keypress)=\"onInputKeyPress($event)\"\r\n [(ngModel)]=\"phoneNumber\"\r\n (ngModelChange)=\"onPhoneNumberChangeDebounce()\"\r\n [errorStateMatcher]=\"errorStateMatcher\"\r\n [placeholder]=\"inputPlaceholder\"\r\n [disabled]=\"disabled\"\r\n [aria-describedby]=\"describedBy\"\r\n />\r\n</div>", styles: ["input:not(.country-search){border:none;background:none;outline:none;font:inherit;width:100%;box-sizing:border-box;padding:0 6px 0 90px;position:relative;z-index:0;margin-top:0!important;margin-bottom:0!important;margin-right:0;margin-left:0}input.country-search{width:100%;height:34px;border:none;border-bottom:1px solid #ddd;font-size:14px;padding:20px 20px 24px;position:sticky;top:0;background-color:#fff;z-index:9}.icon-wrapper{padding-right:24px}.flag{background-size:100% auto;filter:drop-shadow(1px 1px 1px rgba(0,0,0,.54));height:14px;width:24px}.icon-wrapper,.label-wrapper{display:table-cell;vertical-align:middle}.country-selector{border-radius:0;color:#000000de;flex-shrink:0;height:initial;line-height:unset;width:90px;padding:1px;opacity:0;transition:opacity .2s;position:absolute;z-index:1;inset:0 auto 0 0;font-size:inherit;font-weight:inherit;background-position:right center;background-repeat:no-repeat;background-size:18px auto}.country-selector:disabled{color:#00000061}:host.ngx-floating .country-selector{opacity:1!important}.country-selector-flag{display:inline-block;margin-right:.5ex}.country-list-button{color:#000000de;direction:ltr;font-size:16px;font-weight:400;height:initial;line-height:normal;min-height:48px;padding:14px 24px;text-align:left;text-transform:none;width:100%}\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: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.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: "component", type: i7.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i7.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i7.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i8.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i9.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "pipe", type: i10.SearchPipe, name: "search" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
351
|
+
}
|
|
352
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsBasePhoneComponent, decorators: [{
|
|
353
|
+
type: Component,
|
|
354
|
+
args: [{ selector: 'ecabs-base-phone', standalone: false, providers: [
|
|
355
|
+
CountryCode,
|
|
356
|
+
{ provide: MatFormFieldControl, useExisting: EcabsBasePhoneComponent },
|
|
357
|
+
{
|
|
358
|
+
provide: NG_VALIDATORS,
|
|
359
|
+
useValue: phoneNumberValidator,
|
|
360
|
+
multi: true,
|
|
361
|
+
},
|
|
362
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"ecabs-tel-input-container\">\r\n <button\r\n type=\"button\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n class=\"country-selector\"\r\n [disabled]=\"disabled\"\r\n >\r\n <span\r\n class=\"country-selector-flag flag\"\r\n [ngClass]=\"flagClass(selectedCountry?.flagClass)\"\r\n ></span>\r\n <span class=\"country-selector-code\" *ngIf=\"selectedCountry?.dialCode\"\r\n >+{{ selectedCountry.dialCode }}</span\r\n >\r\n </button>\r\n <mat-menu #menu=\"matMenu\"\r\n class=\"ecabs-tel-input-mat-menu-panel\"\r\n backdropClass=\"ecabs-tel-input-overlay-backdrop\"\r\n overlayPanelClass=\"ecabs-tel-input-overlay-pane\">\r\n <input\r\n #searchInput\r\n *ngIf=\"enableSearch\"\r\n class=\"country-search\"\r\n [(ngModel)]=\"searchCriteria\"\r\n (ngModelChange)=\"onSearchInput()\"\r\n type=\"text\"\r\n [placeholder]=\"searchPlaceholder\"\r\n (click)=\"$event.stopPropagation()\"\r\n />\r\n <ng-container *ngIf=\"!searchCriteria\">\r\n <button\r\n type=\"button\"\r\n mat-menu-item\r\n class=\"country-list-button\"\r\n *ngFor=\"let country of preferredCountriesInDropDown\"\r\n (click)=\"onCountrySelect(country)\"\r\n >\r\n <div class=\"icon-wrapper\">\r\n <div class=\"flag\" \r\n [ngClass]=\"flagClass(country.flagClass)\"></div>\r\n </div>\r\n <div class=\"label-wrapper\">\r\n {{ country.name }}\r\n <span *ngIf=\"country?.dialCode\">+{{ country.dialCode }}</span>\r\n </div>\r\n </button>\r\n <mat-divider *ngIf=\"preferredCountriesInDropDown?.length\"></mat-divider>\r\n </ng-container>\r\n <ng-container *ngFor=\"let country of allCountries\">\r\n <button\r\n type=\"button\"\r\n mat-menu-item\r\n class=\"country-list-button\"\r\n *ngIf=\"country | search: searchCriteria\"\r\n (click)=\"onCountrySelect(country)\"\r\n >\r\n <div class=\"icon-wrapper\">\r\n <div class=\"flag\" [ngClass]=\"flagClass(country.flagClass)\"></div>\r\n </div>\r\n <div class=\"label-wrapper\">\r\n {{ country.name }} +{{ country.dialCode }}\r\n </div>\r\n </button>\r\n </ng-container>\r\n </mat-menu>\r\n\r\n <input\r\n matInput\r\n type=\"tel\"\r\n autocomplete=\"tel\"\r\n [ngClass]=\"cssClass\"\r\n (blur)=\"onTouched()\"\r\n (keypress)=\"onInputKeyPress($event)\"\r\n [(ngModel)]=\"phoneNumber\"\r\n (ngModelChange)=\"onPhoneNumberChangeDebounce()\"\r\n [errorStateMatcher]=\"errorStateMatcher\"\r\n [placeholder]=\"inputPlaceholder\"\r\n [disabled]=\"disabled\"\r\n [aria-describedby]=\"describedBy\"\r\n />\r\n</div>", styles: ["input:not(.country-search){border:none;background:none;outline:none;font:inherit;width:100%;box-sizing:border-box;padding:0 6px 0 90px;position:relative;z-index:0;margin-top:0!important;margin-bottom:0!important;margin-right:0;margin-left:0}input.country-search{width:100%;height:34px;border:none;border-bottom:1px solid #ddd;font-size:14px;padding:20px 20px 24px;position:sticky;top:0;background-color:#fff;z-index:9}.icon-wrapper{padding-right:24px}.flag{background-size:100% auto;filter:drop-shadow(1px 1px 1px rgba(0,0,0,.54));height:14px;width:24px}.icon-wrapper,.label-wrapper{display:table-cell;vertical-align:middle}.country-selector{border-radius:0;color:#000000de;flex-shrink:0;height:initial;line-height:unset;width:90px;padding:1px;opacity:0;transition:opacity .2s;position:absolute;z-index:1;inset:0 auto 0 0;font-size:inherit;font-weight:inherit;background-position:right center;background-repeat:no-repeat;background-size:18px auto}.country-selector:disabled{color:#00000061}:host.ngx-floating .country-selector{opacity:1!important}.country-selector-flag{display:inline-block;margin-right:.5ex}.country-list-button{color:#000000de;direction:ltr;font-size:16px;font-weight:400;height:initial;line-height:normal;min-height:48px;padding:14px 24px;text-align:left;text-transform:none;width:100%}\n"] }]
|
|
363
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.CountryCode }, { type: i2.FocusMonitor }, { type: i0.ElementRef }, { type: i3.NgControl, decorators: [{
|
|
364
|
+
type: Optional
|
|
365
|
+
}, {
|
|
366
|
+
type: Self
|
|
367
|
+
}] }, { type: i3.NgForm, decorators: [{
|
|
368
|
+
type: Optional
|
|
369
|
+
}] }, { type: i3.FormGroupDirective, decorators: [{
|
|
370
|
+
type: Optional
|
|
371
|
+
}] }, { type: i4.ErrorStateMatcher }]; }, propDecorators: { preferredCountries: [{
|
|
372
|
+
type: Input
|
|
373
|
+
}], enablePlaceholder: [{
|
|
374
|
+
type: Input
|
|
375
|
+
}], inputPlaceholder: [{
|
|
376
|
+
type: Input
|
|
377
|
+
}], cssClass: [{
|
|
378
|
+
type: Input
|
|
379
|
+
}], name: [{
|
|
380
|
+
type: Input
|
|
381
|
+
}], onlyCountries: [{
|
|
382
|
+
type: Input
|
|
383
|
+
}], errorStateMatcher: [{
|
|
384
|
+
type: Input
|
|
385
|
+
}], enableSearch: [{
|
|
386
|
+
type: Input
|
|
387
|
+
}], searchPlaceholder: [{
|
|
388
|
+
type: Input
|
|
389
|
+
}], describedBy: [{
|
|
390
|
+
type: Input
|
|
391
|
+
}], debounceTimeMs: [{
|
|
392
|
+
type: Input
|
|
393
|
+
}], format: [{
|
|
394
|
+
type: Input
|
|
395
|
+
}], placeholder: [{
|
|
396
|
+
type: Input
|
|
397
|
+
}], required: [{
|
|
398
|
+
type: Input
|
|
399
|
+
}], disabled: [{
|
|
400
|
+
type: Input
|
|
401
|
+
}], countryChanged: [{
|
|
402
|
+
type: Output
|
|
403
|
+
}], matMenu: [{
|
|
404
|
+
type: ViewChild,
|
|
405
|
+
args: [MatMenu]
|
|
406
|
+
}], searchInput: [{
|
|
407
|
+
type: ViewChild,
|
|
408
|
+
args: ['searchInput', { static: false }]
|
|
409
|
+
}], id: [{
|
|
410
|
+
type: HostBinding
|
|
411
|
+
}], shouldLabelFloat: [{
|
|
412
|
+
type: HostBinding,
|
|
413
|
+
args: ['class.ngx-floating']
|
|
414
|
+
}] } });
|
|
415
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-base-phone.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-base-phone-input/ecabs-base-phone.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-base-phone-input/ecabs-base-phone.component.html"],"names":[],"mappings":"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","sourcesContent":["// eslint-disable @typescript-eslint/no-explicit-any\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  DoCheck,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  Self,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { MatFormFieldControl } from '@angular/material/form-field';\r\n\r\nimport {\r\n  FormGroupDirective,\r\n  NgControl,\r\n  NgForm,\r\n  NG_VALIDATORS,\r\n} from '@angular/forms';\r\nimport {\r\n  AsYouType,\r\n  CountryCode as CC,\r\n  E164Number,\r\n  getExampleNumber,\r\n  NationalNumber,\r\n  parsePhoneNumberFromString,\r\n  PhoneNumber,\r\n} from 'libphonenumber-js';\r\n\r\nimport { FocusMonitor } from '@angular/cdk/a11y';\r\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\r\nimport {\r\n  CanUpdateErrorState,\r\n  ErrorStateMatcher,\r\n  mixinErrorState,\r\n  _AbstractConstructor,\r\n  _Constructor,\r\n} from '@angular/material/core';\r\nimport { MatMenu } from '@angular/material/menu';\r\nimport { debounceTime, Subject } from 'rxjs';\r\nimport { CountryCode, Examples } from '../base/consts/country-codes';\r\nimport { phoneNumberValidator } from '../base/validators/phone-number.validator';\r\nimport { Country, PhoneNumberFormat } from '../base/models/phone.models';\r\n\r\nclass NgxMatIntlTelInputBase {\r\n  readonly stateChanges = new Subject<void>();\r\n\r\n  constructor(\r\n    public _defaultErrorStateMatcher: ErrorStateMatcher,\r\n    public _parentForm: NgForm,\r\n    public _parentFormGroup: FormGroupDirective,\r\n    public ngControl: NgControl,\r\n  ) {}\r\n}\r\n\r\ndeclare type CanUpdateErrorStateCtor = _Constructor<CanUpdateErrorState> &\r\n  _AbstractConstructor<CanUpdateErrorState>;\r\n\r\nconst _NgxMatIntlTelInputMixinBase: CanUpdateErrorStateCtor &\r\n  typeof NgxMatIntlTelInputBase = mixinErrorState(NgxMatIntlTelInputBase);\r\n\r\n@Component({\r\n  selector: 'ecabs-base-phone',\r\n  templateUrl: './ecabs-base-phone.component.html',\r\n  styleUrls: ['./ecabs-base-phone.component.scss'],\r\n  standalone: false,\r\n  providers: [\r\n    CountryCode,\r\n    { provide: MatFormFieldControl, useExisting: EcabsBasePhoneComponent },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      useValue: phoneNumberValidator,\r\n      multi: true,\r\n    },\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\n\r\nexport class EcabsBasePhoneComponent\r\n  extends _NgxMatIntlTelInputMixinBase\r\n  implements\r\n    OnInit,\r\n    OnDestroy,\r\n    DoCheck,\r\n    CanUpdateErrorState,\r\n    MatFormFieldControl<any>\r\n{\r\n  @Input() preferredCountries: string[] = [];\r\n  @Input() enablePlaceholder = true;\r\n  @Input() inputPlaceholder: string | undefined;\r\n  @Input() cssClass: string | undefined;\r\n  @Input() name: string | undefined;\r\n  @Input() onlyCountries: string[] = [];\r\n  @Input() override errorStateMatcher: ErrorStateMatcher =\r\n    new ErrorStateMatcher();\r\n  @Input() enableSearch = false;\r\n  @Input() searchPlaceholder: string | undefined;\r\n  @Input() describedBy = '';\r\n  @Input() debounceTimeMs = 500;\r\n  @Input()\r\n  get format(): PhoneNumberFormat {\r\n    return this._format;\r\n  }\r\n\r\n  @Input()\r\n  get placeholder(): string {\r\n    return this._placeholder || '';\r\n  }\r\n\r\n  @Input()\r\n  get required(): boolean {\r\n    return this._required;\r\n  }\r\n\r\n  @Input()\r\n  get disabled(): boolean {\r\n    return this._disabled;\r\n  }\r\n\r\n  @Output() countryChanged = new EventEmitter<Country>();\r\n\r\n  @ViewChild(MatMenu) matMenu: MatMenu | undefined;\r\n  @ViewChild('searchInput', { static: false })\r\n  searchInput: ElementRef;\r\n\r\n  @HostBinding()\r\n  id = `ecabs-intl-tel-input-${EcabsBasePhoneComponent.nextId++}`;\r\n\r\n  @HostBinding('class.ngx-floating')\r\n  get shouldLabelFloat(): boolean {\r\n    return this.focused || !this.empty;\r\n  }\r\n\r\n  static nextId = 0;\r\n\r\n  private _changeSubject = new Subject();\r\n  private _placeholder: string | undefined;\r\n  private _required = false;\r\n  private _disabled = false;\r\n  private _previousFormattedNumber: string | undefined;\r\n  private _format: PhoneNumberFormat = 'default';\r\n  override stateChanges = new Subject<void>();\r\n\r\n  focused = false;\r\n  phoneNumber: NationalNumber | string | undefined;\r\n  allCountries: Country[] = [];\r\n  preferredCountriesInDropDown: Country[] = [];\r\n  selectedCountry: Country | undefined;\r\n  numberInstance: PhoneNumber | undefined;\r\n  value: E164Number | string | undefined;\r\n  searchCriteria: string | undefined;\r\n\r\n  get empty(): boolean {\r\n    return !this.phoneNumber;\r\n  }\r\n\r\n  set format(value: PhoneNumberFormat) {\r\n    this._format = value;\r\n    this.phoneNumber = this.formattedPhoneNumber;\r\n    this.stateChanges.next(undefined);\r\n  }\r\n\r\n  set placeholder(value: string) {\r\n    this._placeholder = value;\r\n    this.stateChanges.next(undefined);\r\n  }\r\n\r\n  set required(value: boolean) {\r\n    this._required = coerceBooleanProperty(value);\r\n    this.stateChanges.next(undefined);\r\n  }\r\n\r\n  set disabled(value: boolean) {\r\n    this._disabled = coerceBooleanProperty(value);\r\n    this.stateChanges.next(undefined);\r\n  }\r\n\r\n  static getPhoneNumberPlaceHolder(countryISOCode: CC): string | undefined {\r\n    const result = getExampleNumber(countryISOCode, Examples);\r\n\r\n    // eslint-disable-next-line no-extra-boolean-cast\r\n    return !!result ? result.number.toString() : undefined;\r\n  }\r\n\r\n  onTouched = () => {};\r\n\r\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n  propagateChange = (_: unknown) => {};\r\n\r\n  constructor(\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    private countryCodeData: CountryCode,\r\n    private fm: FocusMonitor,\r\n    private elRef: ElementRef<HTMLElement>,\r\n    @Optional() @Self() public override ngControl: NgControl,\r\n    @Optional() parentForm: NgForm,\r\n    @Optional() parentFormGroup: FormGroupDirective,\r\n    defaultErrorStateMatcher: ErrorStateMatcher,\r\n  ) {\r\n    super(defaultErrorStateMatcher, parentForm, parentFormGroup, ngControl);\r\n\r\n    fm.monitor(elRef, true).subscribe((origin) => {\r\n      if (this.focused && !origin) {\r\n        this.onTouched();\r\n      }\r\n      this.focused = !!origin;\r\n      this.stateChanges.next(undefined);\r\n    });\r\n    this.fetchCountryData();\r\n    if (this.ngControl != null) {\r\n      this.ngControl.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.searchPlaceholder) {\r\n      this.searchPlaceholder = 'Search ...';\r\n    }\r\n    if (this.preferredCountries.length) {\r\n      this.preferredCountries.forEach((iso2) => {\r\n        const preferredCountry = this.allCountries\r\n          .filter((c) => c.iso2 === iso2)\r\n          .shift();\r\n        if (preferredCountry) {\r\n          this.preferredCountriesInDropDown.push(preferredCountry);\r\n        }\r\n      });\r\n    }\r\n    if (this.onlyCountries.length) {\r\n      this.allCountries = this.allCountries.filter((c) =>\r\n        this.onlyCountries.includes(c.iso2),\r\n      );\r\n    }\r\n    if (this.numberInstance && this.numberInstance.country) {\r\n      // If an existing number is present, we use it to determine selectedCountry\r\n      this.selectedCountry = this.getCountry(this.numberInstance.country);\r\n    } else {\r\n      if (this.preferredCountriesInDropDown.length) {\r\n        this.selectedCountry = this.preferredCountriesInDropDown[0];\r\n      } else {\r\n        this.selectedCountry = this.allCountries[0];\r\n      }\r\n    }\r\n    this._changeSubject\r\n      .pipe(debounceTime(this.debounceTimeMs))\r\n      .subscribe(() => {\r\n        this.onPhoneNumberChange();\r\n      });\r\n    this.countryChanged.emit(this.selectedCountry);\r\n    this.changeDetectorRef.markForCheck();\r\n    this.stateChanges.next(undefined);\r\n  }\r\n\r\n  ngDoCheck(): void {\r\n    if (this.ngControl) {\r\n      this.updateErrorState();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.stateChanges.complete();\r\n    this.fm.stopMonitoring(this.elRef);\r\n    this._changeSubject.complete();\r\n  }\r\n\r\n  onPhoneNumberChangeDebounce(): void {\r\n    this._changeSubject.next(undefined);\r\n  }\r\n\r\n  onPhoneNumberChange(): void {\r\n    try {\r\n      this.numberInstance = parsePhoneNumberFromString(\r\n        this.phoneNumber?.toString() || '',\r\n        this.selectedCountry?.iso2.toUpperCase() as CC,\r\n      );\r\n      this.formatAsYouTypeIfEnabled();\r\n      this.value = this.numberInstance?.number;\r\n      if (this.numberInstance && this.numberInstance.isValid()) {\r\n        if (this.phoneNumber !== this.formattedPhoneNumber) {\r\n          this.phoneNumber = this.formattedPhoneNumber;\r\n        }\r\n        if (\r\n          this.selectedCountry?.iso2 !== this.numberInstance.country &&\r\n          !!this.numberInstance.country\r\n        ) {\r\n          this.selectedCountry = this.getCountry(this.numberInstance.country);\r\n          this.countryChanged.emit(this.selectedCountry);\r\n        }\r\n      }\r\n    } catch {\r\n      // if no possible numbers are there,\r\n      // then the full number is passed so that validator could be triggered and proper error could be shown\r\n      this.value = this.phoneNumber?.toString();\r\n    }\r\n    this.propagateChange(this.value);\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  onCountrySelect(country: Country): void {\r\n    if (this.phoneNumber) {\r\n      this.phoneNumber = this.numberInstance?.nationalNumber;\r\n    }\r\n    this.selectedCountry = country;\r\n    this.countryChanged.emit(this.selectedCountry);\r\n    this.onPhoneNumberChange();\r\n  }\r\n\r\n  getCountry(code: string): Country {\r\n    return (\r\n      this.allCountries.find((c) => c.iso2 === code.toLowerCase()) || {\r\n        name: 'UN',\r\n        iso2: 'UN',\r\n        dialCode: '',\r\n        priority: 0,\r\n        areaCodes: undefined,\r\n        flagClass: 'UN',\r\n        placeHolder: '',\r\n      }\r\n    );\r\n  }\r\n\r\n  onInputKeyPress(event: KeyboardEvent): void {\r\n    const pattern = /[0-9+\\- ]/;\r\n    if (!pattern.test(event.key)) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  flagClass(lang: string): string {\r\n    return `fi fi-${lang?.slice(-2).toLowerCase()}`;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n    this.changeDetectorRef.markForCheck();\r\n    this.stateChanges.next(undefined);\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    if (value) {\r\n      this.numberInstance = parsePhoneNumberFromString(value);\r\n      if (this.numberInstance) {\r\n        const countryCode = this.numberInstance.country;\r\n        this.phoneNumber = this.formattedPhoneNumber;\r\n        if (!countryCode) {\r\n          return;\r\n        }\r\n        setTimeout(() => {\r\n          this.selectedCountry = this.getCountry(countryCode);\r\n          if (\r\n            this.selectedCountry.dialCode &&\r\n            !this.preferredCountries.includes(this.selectedCountry.iso2)\r\n          ) {\r\n            this.preferredCountriesInDropDown.push(this.selectedCountry);\r\n          }\r\n          this.countryChanged.emit(this.selectedCountry);\r\n\r\n          // Initial value is set\r\n          this.changeDetectorRef.markForCheck();\r\n          this.stateChanges.next(undefined);\r\n        }, 1);\r\n      } else {\r\n        this.phoneNumber = value;\r\n      }\r\n    }\r\n\r\n    // Value is set from outside using setValue()\r\n    this.changeDetectorRef.markForCheck();\r\n    this.stateChanges.next(undefined);\r\n  }\r\n\r\n  setDescribedByIds(ids: string[]) {\r\n    this.describedBy = ids.join(' ');\r\n  }\r\n\r\n  onContainerClick(event: MouseEvent): void {\r\n    if ((event.target as Element).tagName.toLowerCase() !== 'input') {\r\n      this.elRef.nativeElement.querySelector('input')!.focus();\r\n    }\r\n  }\r\n\r\n  reset(): void {\r\n    this.phoneNumber = '';\r\n    this.propagateChange(null);\r\n\r\n    this.changeDetectorRef.markForCheck();\r\n    this.stateChanges.next(undefined);\r\n  }\r\n\r\n  onSearchInput(): void {\r\n    setTimeout(() => {\r\n      this.searchInput?.nativeElement?.focus();\r\n    }, 200);\r\n  }\r\n\r\n  protected fetchCountryData(): void {\r\n    this.countryCodeData.allCountries.forEach((c) => {\r\n      const country: Country = {\r\n        name: c[0].toString(),\r\n        iso2: c[1].toString(),\r\n        dialCode: c[2].toString(),\r\n        priority: +c[3] || 0,\r\n        areaCodes: (c[4] as string[]) || undefined,\r\n        flagClass: c[1].toString().toUpperCase(),\r\n        placeHolder: '',\r\n      };\r\n\r\n      if (this.enablePlaceholder) {\r\n        country.placeHolder = EcabsBasePhoneComponent.getPhoneNumberPlaceHolder(\r\n          country.iso2.toUpperCase() as CC,\r\n        );\r\n      }\r\n\r\n      this.allCountries.push(country);\r\n    });\r\n  }\r\n\r\n  private get formattedPhoneNumber(): string {\r\n    if (!this.numberInstance) {\r\n      return this.phoneNumber?.toString() || '';\r\n    }\r\n    switch (this.format) {\r\n      case 'national':\r\n        return this.numberInstance.formatNational();\r\n\r\n      case 'international':\r\n        return this.numberInstance.formatInternational();\r\n\r\n      default:\r\n        return this.numberInstance.nationalNumber.toString();\r\n    }\r\n  }\r\n\r\n  private formatAsYouTypeIfEnabled(): void {\r\n    if (this.format === 'default') {\r\n      return;\r\n    }\r\n    const asYouType: AsYouType = new AsYouType(\r\n      this.selectedCountry?.iso2.toUpperCase() as CC,\r\n    );\r\n    // To avoid caret positioning we apply formatting only if the caret is at the end:\r\n    if (\r\n      this.phoneNumber\r\n        ?.toString()\r\n        .startsWith(this._previousFormattedNumber || '')\r\n    ) {\r\n      this.phoneNumber = asYouType.input(this.phoneNumber.toString());\r\n    }\r\n    this._previousFormattedNumber = this.phoneNumber?.toString();\r\n  }\r\n}\r\n","<div class=\"ecabs-tel-input-container\">\r\n  <button\r\n    type=\"button\"\r\n    mat-button\r\n    [matMenuTriggerFor]=\"menu\"\r\n    class=\"country-selector\"\r\n    [disabled]=\"disabled\"\r\n  >\r\n    <span\r\n      class=\"country-selector-flag flag\"\r\n      [ngClass]=\"flagClass(selectedCountry?.flagClass)\"\r\n    ></span>\r\n    <span class=\"country-selector-code\" *ngIf=\"selectedCountry?.dialCode\"\r\n    >+{{ selectedCountry.dialCode }}</span\r\n    >\r\n  </button>\r\n  <mat-menu #menu=\"matMenu\"\r\n            class=\"ecabs-tel-input-mat-menu-panel\"\r\n            backdropClass=\"ecabs-tel-input-overlay-backdrop\"\r\n            overlayPanelClass=\"ecabs-tel-input-overlay-pane\">\r\n    <input\r\n      #searchInput\r\n      *ngIf=\"enableSearch\"\r\n      class=\"country-search\"\r\n      [(ngModel)]=\"searchCriteria\"\r\n      (ngModelChange)=\"onSearchInput()\"\r\n      type=\"text\"\r\n      [placeholder]=\"searchPlaceholder\"\r\n      (click)=\"$event.stopPropagation()\"\r\n    />\r\n    <ng-container *ngIf=\"!searchCriteria\">\r\n      <button\r\n        type=\"button\"\r\n        mat-menu-item\r\n        class=\"country-list-button\"\r\n        *ngFor=\"let country of preferredCountriesInDropDown\"\r\n        (click)=\"onCountrySelect(country)\"\r\n      >\r\n        <div class=\"icon-wrapper\">\r\n          <div class=\"flag\"    \r\n          [ngClass]=\"flagClass(country.flagClass)\"></div>\r\n        </div>\r\n        <div class=\"label-wrapper\">\r\n          {{ country.name }}\r\n          <span *ngIf=\"country?.dialCode\">+{{ country.dialCode }}</span>\r\n        </div>\r\n      </button>\r\n      <mat-divider *ngIf=\"preferredCountriesInDropDown?.length\"></mat-divider>\r\n    </ng-container>\r\n    <ng-container *ngFor=\"let country of allCountries\">\r\n      <button\r\n        type=\"button\"\r\n        mat-menu-item\r\n        class=\"country-list-button\"\r\n        *ngIf=\"country | search: searchCriteria\"\r\n        (click)=\"onCountrySelect(country)\"\r\n      >\r\n        <div class=\"icon-wrapper\">\r\n          <div class=\"flag\" [ngClass]=\"flagClass(country.flagClass)\"></div>\r\n        </div>\r\n        <div class=\"label-wrapper\">\r\n          {{ country.name }} +{{ country.dialCode }}\r\n        </div>\r\n      </button>\r\n    </ng-container>\r\n  </mat-menu>\r\n\r\n  <input\r\n    matInput\r\n    type=\"tel\"\r\n    autocomplete=\"tel\"\r\n    [ngClass]=\"cssClass\"\r\n    (blur)=\"onTouched()\"\r\n    (keypress)=\"onInputKeyPress($event)\"\r\n    [(ngModel)]=\"phoneNumber\"\r\n    (ngModelChange)=\"onPhoneNumberChangeDebounce()\"\r\n    [errorStateMatcher]=\"errorStateMatcher\"\r\n    [placeholder]=\"inputPlaceholder\"\r\n    [disabled]=\"disabled\"\r\n    [aria-describedby]=\"describedBy\"\r\n  />\r\n</div>"]}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
4
|
+
import { RouterModule } from '@angular/router';
|
|
5
|
+
import { EcabsBasePhoneComponent } from './ecabs-base-phone.component';
|
|
6
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
7
|
+
import { MatInputModule } from '@angular/material/input';
|
|
8
|
+
import { MatMenuModule } from '@angular/material/menu';
|
|
9
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
10
|
+
import { MatDividerModule } from '@angular/material/divider';
|
|
11
|
+
import { SearchPipe } from '../base/pipes/search.pipe';
|
|
12
|
+
import { ElementWrapperModule } from '../base/element-wrapper/element-wrapper.module';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
export class EcabsBasePhoneModule {
|
|
15
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsBasePhoneModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
16
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: EcabsBasePhoneModule, declarations: [EcabsBasePhoneComponent], imports: [CommonModule,
|
|
17
|
+
MatIconModule,
|
|
18
|
+
RouterModule,
|
|
19
|
+
FormsModule,
|
|
20
|
+
MatInputModule,
|
|
21
|
+
MatMenuModule,
|
|
22
|
+
MatButtonModule,
|
|
23
|
+
MatDividerModule,
|
|
24
|
+
ReactiveFormsModule,
|
|
25
|
+
SearchPipe,
|
|
26
|
+
ElementWrapperModule], exports: [EcabsBasePhoneComponent] });
|
|
27
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsBasePhoneModule, imports: [CommonModule,
|
|
28
|
+
MatIconModule,
|
|
29
|
+
RouterModule,
|
|
30
|
+
FormsModule,
|
|
31
|
+
MatInputModule,
|
|
32
|
+
MatMenuModule,
|
|
33
|
+
MatButtonModule,
|
|
34
|
+
MatDividerModule,
|
|
35
|
+
ReactiveFormsModule,
|
|
36
|
+
ElementWrapperModule] });
|
|
37
|
+
}
|
|
38
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsBasePhoneModule, decorators: [{
|
|
39
|
+
type: NgModule,
|
|
40
|
+
args: [{
|
|
41
|
+
declarations: [EcabsBasePhoneComponent],
|
|
42
|
+
imports: [
|
|
43
|
+
CommonModule,
|
|
44
|
+
MatIconModule,
|
|
45
|
+
RouterModule,
|
|
46
|
+
FormsModule,
|
|
47
|
+
MatInputModule,
|
|
48
|
+
MatMenuModule,
|
|
49
|
+
MatButtonModule,
|
|
50
|
+
MatDividerModule,
|
|
51
|
+
ReactiveFormsModule,
|
|
52
|
+
SearchPipe,
|
|
53
|
+
ElementWrapperModule,
|
|
54
|
+
],
|
|
55
|
+
exports: [EcabsBasePhoneComponent],
|
|
56
|
+
}]
|
|
57
|
+
}] });
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtYmFzZS1waG9uZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvZWNhYnMtYmFzZS1waG9uZS1pbnB1dC9lY2Ficy1iYXNlLXBob25lLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDdkQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7O0FBbUJ0RixNQUFNLE9BQU8sb0JBQW9CO3dHQUFwQixvQkFBb0I7eUdBQXBCLG9CQUFvQixpQkFoQmhCLHVCQUF1QixhQUVwQyxZQUFZO1lBQ1osYUFBYTtZQUNiLFlBQVk7WUFDWixXQUFXO1lBQ1gsY0FBYztZQUNkLGFBQWE7WUFDYixlQUFlO1lBQ2YsZ0JBQWdCO1lBQ2hCLG1CQUFtQjtZQUNuQixVQUFVO1lBQ1Ysb0JBQW9CLGFBRVosdUJBQXVCO3lHQUV0QixvQkFBb0IsWUFkN0IsWUFBWTtZQUNaLGFBQWE7WUFDYixZQUFZO1lBQ1osV0FBVztZQUNYLGNBQWM7WUFDZCxhQUFhO1lBQ2IsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixtQkFBbUI7WUFFbkIsb0JBQW9COzs0RkFJWCxvQkFBb0I7a0JBakJoQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHVCQUF1QixDQUFDO29CQUN2QyxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3dCQUNiLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxjQUFjO3dCQUNkLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixnQkFBZ0I7d0JBQ2hCLG1CQUFtQjt3QkFDbkIsVUFBVTt3QkFDVixvQkFBb0I7cUJBQ3JCO29CQUNELE9BQU8sRUFBRSxDQUFDLHVCQUF1QixDQUFDO2lCQUNuQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuaW1wb3J0IHsgUm91dGVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgRWNhYnNCYXNlUGhvbmVDb21wb25lbnQgfSBmcm9tICcuL2VjYWJzLWJhc2UtcGhvbmUuY29tcG9uZW50JztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xyXG5pbXBvcnQgeyBNYXRNZW51TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbWVudSc7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XHJcbmltcG9ydCB7IE1hdERpdmlkZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaXZpZGVyJztcclxuaW1wb3J0IHsgU2VhcmNoUGlwZSB9IGZyb20gJy4uL2Jhc2UvcGlwZXMvc2VhcmNoLnBpcGUnO1xyXG5pbXBvcnQgeyBFbGVtZW50V3JhcHBlck1vZHVsZSB9IGZyb20gJy4uL2Jhc2UvZWxlbWVudC13cmFwcGVyL2VsZW1lbnQtd3JhcHBlci5tb2R1bGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtFY2Fic0Jhc2VQaG9uZUNvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIFJvdXRlck1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgTWF0SW5wdXRNb2R1bGUsXHJcbiAgICBNYXRNZW51TW9kdWxlLFxyXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxyXG4gICAgTWF0RGl2aWRlck1vZHVsZSxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBTZWFyY2hQaXBlLFxyXG4gICAgRWxlbWVudFdyYXBwZXJNb2R1bGUsXHJcbiAgXSxcclxuICBleHBvcnRzOiBbRWNhYnNCYXNlUGhvbmVDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRWNhYnNCYXNlUGhvbmVNb2R1bGUge31cclxuIl19
|