ecabs-components 1.0.61 → 1.0.62
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/base/services/ecabs-components.service.mjs +17 -9
- package/esm2022/lib/ecabs-phone/ecabs-phone.component.mjs +32 -13
- package/fesm2022/ecabs-components.mjs +93 -70
- package/fesm2022/ecabs-components.mjs.map +1 -1
- package/lib/base/services/ecabs-components.service.d.ts +5 -0
- package/lib/ecabs-phone/ecabs-phone.component.d.ts +5 -1
- package/package.json +1 -1
|
@@ -3,18 +3,20 @@ import { BehaviorSubject } from 'rxjs';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class EcabsComponentsService {
|
|
5
5
|
defaultConfig = {
|
|
6
|
+
defaultCountries: [],
|
|
6
7
|
errorMessages: [
|
|
7
8
|
{ type: 'required', message: '[label] is required' },
|
|
8
|
-
{ type: 'minlength', message: '[label] should be
|
|
9
|
+
{ type: 'minlength', message: '[label] should be at least [requiredLength] character' },
|
|
9
10
|
{ type: 'maxLength', message: '[label] should be maximum [requiredLength] character' },
|
|
10
|
-
{ type: 'min', message: '[label] should be
|
|
11
|
+
{ type: 'min', message: '[label] should be minimum [min]' },
|
|
11
12
|
{ type: 'max', message: '[label] should be maximum [max]' },
|
|
12
|
-
{ type: 'minValue', message: '[label] should be
|
|
13
|
+
{ type: 'minValue', message: '[label] should be minimum [requiredMin]' },
|
|
13
14
|
{ type: 'maxValue', message: '[label] should be maximum [requiredMax]' },
|
|
14
15
|
],
|
|
15
16
|
};
|
|
16
17
|
_config = new BehaviorSubject(this.defaultConfig);
|
|
17
|
-
constructor() {
|
|
18
|
+
constructor() {
|
|
19
|
+
}
|
|
18
20
|
setConfig(config) {
|
|
19
21
|
this._config.next(config);
|
|
20
22
|
}
|
|
@@ -23,10 +25,12 @@ export class EcabsComponentsService {
|
|
|
23
25
|
}
|
|
24
26
|
updateConfig(configUpdate) {
|
|
25
27
|
const currentConfig = this._config.getValue();
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
28
|
+
let updatedConfig = new GenericComponentConfig();
|
|
29
|
+
for (const key in currentConfig) {
|
|
30
|
+
if (currentConfig.hasOwnProperty(key)) {
|
|
31
|
+
updatedConfig[key] = [...currentConfig[key], ...configUpdate[key]];
|
|
32
|
+
}
|
|
33
|
+
}
|
|
30
34
|
this._config.next(updatedConfig);
|
|
31
35
|
}
|
|
32
36
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsComponentsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
@@ -38,4 +42,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
38
42
|
providedIn: 'root',
|
|
39
43
|
}]
|
|
40
44
|
}], ctorParameters: function () { return []; } });
|
|
41
|
-
|
|
45
|
+
export class GenericComponentConfig {
|
|
46
|
+
defaultCountries = [];
|
|
47
|
+
errorMessages = [];
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtY29tcG9uZW50cy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2Jhc2Uvc2VydmljZXMvZWNhYnMtY29tcG9uZW50cy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFDLGVBQWUsRUFBYSxNQUFNLE1BQU0sQ0FBQzs7QUFLakQsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQyxhQUFhLEdBQTBCO1FBQ3JDLGdCQUFnQixFQUFFLEVBQUU7UUFDcEIsYUFBYSxFQUFFO1lBQ2IsRUFBQyxJQUFJLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxxQkFBcUIsRUFBQztZQUNsRCxFQUFDLElBQUksRUFBRSxXQUFXLEVBQUUsT0FBTyxFQUFFLHVEQUF1RCxFQUFDO1lBQ3JGLEVBQUMsSUFBSSxFQUFFLFdBQVcsRUFBRSxPQUFPLEVBQUUsc0RBQXNELEVBQUM7WUFDcEYsRUFBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxpQ0FBaUMsRUFBQztZQUN6RCxFQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLGlDQUFpQyxFQUFDO1lBQ3pELEVBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUseUNBQXlDLEVBQUM7WUFDdEUsRUFBQyxJQUFJLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSx5Q0FBeUMsRUFBQztTQUN2RTtLQUNGLENBQUM7SUFFTSxPQUFPLEdBQTJDLElBQUksZUFBZSxDQUF3QixJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7SUFFekg7SUFDQSxDQUFDO0lBRUQsU0FBUyxDQUFDLE1BQTZCO1FBQ3JDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFRCxTQUFTO1FBQ1AsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxZQUFZLENBQUMsWUFBbUM7UUFDOUMsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUM5QyxJQUFJLGFBQWEsR0FBMEIsSUFBSSxzQkFBc0IsRUFBRSxDQUFDO1FBRXhFLEtBQUssTUFBTSxHQUFHLElBQUksYUFBYSxFQUFFO1lBQy9CLElBQUksYUFBYSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRTtnQkFDckMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxhQUFhLENBQUMsR0FBRyxDQUFDLEVBQUUsR0FBRyxZQUFZLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQzthQUNwRTtTQUNGO1FBRUQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDbkMsQ0FBQzt3R0F0Q1Usc0JBQXNCOzRHQUF0QixzQkFBc0IsY0FGckIsTUFBTTs7NEZBRVAsc0JBQXNCO2tCQUhsQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7QUFvREQsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQyxnQkFBZ0IsR0FBYSxFQUFFLENBQUM7SUFDaEMsYUFBYSxHQUFtQixFQUFFLENBQUM7Q0FDcEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRWNhYnNDb21wb25lbnRzU2VydmljZSB7XHJcbiAgZGVmYXVsdENvbmZpZzogRWNhYnNDb21wb25lbnRzQ29uZmlnID0ge1xyXG4gICAgZGVmYXVsdENvdW50cmllczogW10sXHJcbiAgICBlcnJvck1lc3NhZ2VzOiBbXHJcbiAgICAgIHt0eXBlOiAncmVxdWlyZWQnLCBtZXNzYWdlOiAnW2xhYmVsXSBpcyByZXF1aXJlZCd9LFxyXG4gICAgICB7dHlwZTogJ21pbmxlbmd0aCcsIG1lc3NhZ2U6ICdbbGFiZWxdIHNob3VsZCBiZSBhdCBsZWFzdCBbcmVxdWlyZWRMZW5ndGhdIGNoYXJhY3Rlcid9LFxyXG4gICAgICB7dHlwZTogJ21heExlbmd0aCcsIG1lc3NhZ2U6ICdbbGFiZWxdIHNob3VsZCBiZSBtYXhpbXVtIFtyZXF1aXJlZExlbmd0aF0gY2hhcmFjdGVyJ30sXHJcbiAgICAgIHt0eXBlOiAnbWluJywgbWVzc2FnZTogJ1tsYWJlbF0gc2hvdWxkIGJlIG1pbmltdW0gW21pbl0nfSxcclxuICAgICAge3R5cGU6ICdtYXgnLCBtZXNzYWdlOiAnW2xhYmVsXSBzaG91bGQgYmUgbWF4aW11bSBbbWF4XSd9LFxyXG4gICAgICB7dHlwZTogJ21pblZhbHVlJywgbWVzc2FnZTogJ1tsYWJlbF0gc2hvdWxkIGJlIG1pbmltdW0gW3JlcXVpcmVkTWluXSd9LFxyXG4gICAgICB7dHlwZTogJ21heFZhbHVlJywgbWVzc2FnZTogJ1tsYWJlbF0gc2hvdWxkIGJlIG1heGltdW0gW3JlcXVpcmVkTWF4XSd9LFxyXG4gICAgXSxcclxuICB9O1xyXG5cclxuICBwcml2YXRlIF9jb25maWc6IEJlaGF2aW9yU3ViamVjdDxFY2Fic0NvbXBvbmVudHNDb25maWc+ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxFY2Fic0NvbXBvbmVudHNDb25maWc+KHRoaXMuZGVmYXVsdENvbmZpZyk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gIH1cclxuXHJcbiAgc2V0Q29uZmlnKGNvbmZpZzogRWNhYnNDb21wb25lbnRzQ29uZmlnKTogdm9pZCB7XHJcbiAgICB0aGlzLl9jb25maWcubmV4dChjb25maWcpO1xyXG4gIH1cclxuXHJcbiAgZ2V0Q29uZmlnKCk6IE9ic2VydmFibGU8RWNhYnNDb21wb25lbnRzQ29uZmlnPiB7XHJcbiAgICByZXR1cm4gdGhpcy5fY29uZmlnLmFzT2JzZXJ2YWJsZSgpO1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlQ29uZmlnKGNvbmZpZ1VwZGF0ZTogRWNhYnNDb21wb25lbnRzQ29uZmlnKSB7XHJcbiAgICBjb25zdCBjdXJyZW50Q29uZmlnID0gdGhpcy5fY29uZmlnLmdldFZhbHVlKCk7XHJcbiAgICBsZXQgdXBkYXRlZENvbmZpZzogRWNhYnNDb21wb25lbnRzQ29uZmlnID0gbmV3IEdlbmVyaWNDb21wb25lbnRDb25maWcoKTtcclxuXHJcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBjdXJyZW50Q29uZmlnKSB7XHJcbiAgICAgIGlmIChjdXJyZW50Q29uZmlnLmhhc093blByb3BlcnR5KGtleSkpIHtcclxuICAgICAgICB1cGRhdGVkQ29uZmlnW2tleV0gPSBbLi4uY3VycmVudENvbmZpZ1trZXldLCAuLi5jb25maWdVcGRhdGVba2V5XV07XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICB0aGlzLl9jb25maWcubmV4dCh1cGRhdGVkQ29uZmlnKTtcclxuICB9XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRWNhYnNDb21wb25lbnRzQ29uZmlnIHtcclxuICBkZWZhdWx0Q291bnRyaWVzOiBzdHJpbmdbXTtcclxuICBlcnJvck1lc3NhZ2VzOiBFcnJvck1lc3NhZ2VbXTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBFcnJvck1lc3NhZ2Uge1xyXG4gIHR5cGU6IHN0cmluZztcclxuICBtZXNzYWdlOiBzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBHZW5lcmljQ29tcG9uZW50Q29uZmlnIGltcGxlbWVudHMgRWNhYnNDb21wb25lbnRzQ29uZmlnIHtcclxuICBkZWZhdWx0Q291bnRyaWVzOiBzdHJpbmdbXSA9IFtdO1xyXG4gIGVycm9yTWVzc2FnZXM6IEVycm9yTWVzc2FnZVtdID0gW107XHJcbn1cclxuIl19
|
|
@@ -1,13 +1,19 @@
|
|
|
1
1
|
import { Component, EventEmitter, HostListener, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { NG_VALUE_ACCESSOR, NgControl, UntypedFormControl, UntypedFormGroup, Validators, } from '@angular/forms';
|
|
3
3
|
import ElementBaseComponent from '../base/element-base';
|
|
4
|
+
import { UnsubscribeService } from "../base/services/unsubscribe.service";
|
|
5
|
+
import { takeUntil } from "rxjs";
|
|
4
6
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "
|
|
6
|
-
import * as i2 from "../base/
|
|
7
|
-
import * as i3 from "@angular/
|
|
8
|
-
import * as i4 from "
|
|
7
|
+
import * as i1 from "../base/services/ecabs-components.service";
|
|
8
|
+
import * as i2 from "../base/services/unsubscribe.service";
|
|
9
|
+
import * as i3 from "@angular/common";
|
|
10
|
+
import * as i4 from "../base/element-wrapper/element-wrapper.component";
|
|
11
|
+
import * as i5 from "@angular/forms";
|
|
12
|
+
import * as i6 from "ngx-mat-intl-tel-input";
|
|
9
13
|
export class EcabsPhoneComponent extends ElementBaseComponent {
|
|
10
14
|
injector;
|
|
15
|
+
ecabsComponentsService;
|
|
16
|
+
unsubscribeService;
|
|
11
17
|
preferredCountries;
|
|
12
18
|
enablePlaceholder;
|
|
13
19
|
enableSearch = true;
|
|
@@ -26,9 +32,11 @@ export class EcabsPhoneComponent extends ElementBaseComponent {
|
|
|
26
32
|
this.phoneForm.setValue({ phone: val });
|
|
27
33
|
}
|
|
28
34
|
}
|
|
29
|
-
constructor(injector) {
|
|
35
|
+
constructor(injector, ecabsComponentsService, unsubscribeService) {
|
|
30
36
|
super();
|
|
31
37
|
this.injector = injector;
|
|
38
|
+
this.ecabsComponentsService = ecabsComponentsService;
|
|
39
|
+
this.unsubscribeService = unsubscribeService;
|
|
32
40
|
}
|
|
33
41
|
onInput(event) {
|
|
34
42
|
if (this.prohibitedCharacters.includes(event.key)) {
|
|
@@ -39,6 +47,13 @@ export class EcabsPhoneComponent extends ElementBaseComponent {
|
|
|
39
47
|
this.phoneForm = new UntypedFormGroup({
|
|
40
48
|
phone: new UntypedFormControl(undefined, this.required ? [Validators.required] : []),
|
|
41
49
|
});
|
|
50
|
+
this.ecabsComponentsService.getConfig()
|
|
51
|
+
.pipe(takeUntil(this.unsubscribeService.subscription()))
|
|
52
|
+
.subscribe((val) => {
|
|
53
|
+
if (!this.preferredCountries?.length) {
|
|
54
|
+
this.preferredCountries = val.defaultCountries;
|
|
55
|
+
}
|
|
56
|
+
});
|
|
42
57
|
}
|
|
43
58
|
ngAfterViewInit() {
|
|
44
59
|
const ngControl = this.injector.get(NgControl, null);
|
|
@@ -52,8 +67,10 @@ export class EcabsPhoneComponent extends ElementBaseComponent {
|
|
|
52
67
|
this.handleErrors();
|
|
53
68
|
});
|
|
54
69
|
}
|
|
55
|
-
onChange = () => {
|
|
56
|
-
|
|
70
|
+
onChange = () => {
|
|
71
|
+
};
|
|
72
|
+
onTouch = () => {
|
|
73
|
+
};
|
|
57
74
|
writeValue(value) {
|
|
58
75
|
this.value = value;
|
|
59
76
|
}
|
|
@@ -79,27 +96,29 @@ export class EcabsPhoneComponent extends ElementBaseComponent {
|
|
|
79
96
|
if (this.value === undefined && !this.phoneInput.empty) {
|
|
80
97
|
this.phoneForm.controls['phone'].setErrors({ validatePhoneNumber: true });
|
|
81
98
|
}
|
|
82
|
-
this.control
|
|
99
|
+
this.control?.setErrors(this.phoneForm.get('phone').errors);
|
|
83
100
|
}
|
|
84
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPhoneComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
101
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPhoneComponent, deps: [{ token: i0.Injector }, { token: i1.EcabsComponentsService }, { token: i2.UnsubscribeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
85
102
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsPhoneComponent, selector: "ecabs-phone", inputs: { preferredCountries: "preferredCountries", enablePlaceholder: "enablePlaceholder", enableSearch: "enableSearch", useOnlyDisabledClass: "useOnlyDisabledClass", required: "required" }, outputs: { onblur: "onblur" }, host: { listeners: { "keypress": "onInput($event)" } }, providers: [
|
|
103
|
+
UnsubscribeService,
|
|
86
104
|
{
|
|
87
105
|
provide: NG_VALUE_ACCESSOR,
|
|
88
106
|
useExisting: EcabsPhoneComponent,
|
|
89
107
|
multi: true,
|
|
90
108
|
},
|
|
91
|
-
], viewQueries: [{ propertyName: "phoneInput", first: true, predicate: ["phoneInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<app-element-wrapper [data]=\"getData()\">\r\n <form #f=\"ngForm\" [formGroup]=\"phoneForm\">\r\n <ngx-mat-intl-tel-input\r\n (focusout)=\"onBlur()\"\r\n [ngClass]=\"{ error: phoneForm.invalid && (phoneForm.dirty || phoneForm.touched) }\"\r\n #phoneInput\r\n [preferredCountries]=\"preferredCountries\"\r\n [enablePlaceholder]=\"enablePlaceholder\"\r\n [enableSearch]=\"enableSearch\"\r\n [disabled]=\"disabled\"\r\n [formControlName]=\"'phone'\"\r\n name=\"phone\"\r\n [inputPlaceholder]=\"placeholder\"\r\n >\r\n </ngx-mat-intl-tel-input>\r\n </form>\r\n</app-element-wrapper>\r\n", dependencies: [{ kind: "directive", type:
|
|
109
|
+
], viewQueries: [{ propertyName: "phoneInput", first: true, predicate: ["phoneInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<app-element-wrapper [data]=\"getData()\">\r\n <form #f=\"ngForm\" [formGroup]=\"phoneForm\">\r\n <ngx-mat-intl-tel-input\r\n (focusout)=\"onBlur()\"\r\n [ngClass]=\"{ error: phoneForm.invalid && (phoneForm.dirty || phoneForm.touched) }\"\r\n #phoneInput\r\n [preferredCountries]=\"preferredCountries\"\r\n [enablePlaceholder]=\"enablePlaceholder\"\r\n [enableSearch]=\"enableSearch\"\r\n [disabled]=\"disabled\"\r\n [formControlName]=\"'phone'\"\r\n name=\"phone\"\r\n [inputPlaceholder]=\"placeholder\"\r\n >\r\n </ngx-mat-intl-tel-input>\r\n </form>\r\n</app-element-wrapper>\r\n", dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i4.ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i6.NgxMatIntlTelInputComponent, selector: "ngx-mat-intl-tel-input", inputs: ["preferredCountries", "enablePlaceholder", "inputPlaceholder", "cssClass", "name", "onlyCountries", "errorStateMatcher", "enableSearch", "searchPlaceholder", "describedBy", "format", "placeholder", "required", "disabled"], outputs: ["countryChanged"] }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
|
|
92
110
|
}
|
|
93
111
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPhoneComponent, decorators: [{
|
|
94
112
|
type: Component,
|
|
95
113
|
args: [{ selector: 'ecabs-phone', providers: [
|
|
114
|
+
UnsubscribeService,
|
|
96
115
|
{
|
|
97
116
|
provide: NG_VALUE_ACCESSOR,
|
|
98
117
|
useExisting: EcabsPhoneComponent,
|
|
99
118
|
multi: true,
|
|
100
119
|
},
|
|
101
120
|
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <form #f=\"ngForm\" [formGroup]=\"phoneForm\">\r\n <ngx-mat-intl-tel-input\r\n (focusout)=\"onBlur()\"\r\n [ngClass]=\"{ error: phoneForm.invalid && (phoneForm.dirty || phoneForm.touched) }\"\r\n #phoneInput\r\n [preferredCountries]=\"preferredCountries\"\r\n [enablePlaceholder]=\"enablePlaceholder\"\r\n [enableSearch]=\"enableSearch\"\r\n [disabled]=\"disabled\"\r\n [formControlName]=\"'phone'\"\r\n name=\"phone\"\r\n [inputPlaceholder]=\"placeholder\"\r\n >\r\n </ngx-mat-intl-tel-input>\r\n </form>\r\n</app-element-wrapper>\r\n" }]
|
|
102
|
-
}], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: { preferredCountries: [{
|
|
121
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.EcabsComponentsService }, { type: i2.UnsubscribeService }]; }, propDecorators: { preferredCountries: [{
|
|
103
122
|
type: Input
|
|
104
123
|
}], enablePlaceholder: [{
|
|
105
124
|
type: Input
|
|
@@ -118,4 +137,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
118
137
|
type: HostListener,
|
|
119
138
|
args: ['keypress', ['$event']]
|
|
120
139
|
}] } });
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-phone.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-phone/ecabs-phone.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-phone/ecabs-phone.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, HostListener, Injector, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  UntypedFormControl,\r\n  UntypedFormGroup,\r\n  NG_VALUE_ACCESSOR,\r\n  Validators,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { NgxMatIntlTelInputComponent } from 'ngx-mat-intl-tel-input';\r\nimport ElementBaseComponent from '../base/element-base';\r\n\r\n@Component( {\r\n  selector: 'ecabs-phone',\r\n  templateUrl: './ecabs-phone.component.html',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsPhoneComponent,\r\n      multi: true,\r\n    },\r\n  ],\r\n} )\r\nexport class EcabsPhoneComponent\r\n  extends ElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit {\r\n  @Input() preferredCountries!: string[];\r\n  @Input() enablePlaceholder!: boolean;\r\n  @Input() enableSearch: boolean = true;\r\n  @Input() useOnlyDisabledClass = false;\r\n  @Input() declare required: boolean;\r\n\r\n  @Output() onblur: EventEmitter<{ value: string }> = new EventEmitter();\r\n\r\n  @ViewChild( 'phoneInput' )\r\n  phoneInput!: NgxMatIntlTelInputComponent;\r\n\r\n  phoneForm: UntypedFormGroup;\r\n  phoneSub!: any;\r\n  prohibitedCharacters = [ '-' ];\r\n\r\n  get value(): any {\r\n    return this.phoneForm.get( 'phone' )?.value;\r\n  }\r\n\r\n  set value( val ) {\r\n    if ( val !== undefined && this.value !== val ) {\r\n      this.phoneForm.setValue( { phone: val } );\r\n    }\r\n  }\r\n\r\n  constructor( private readonly injector: Injector ) {\r\n    super();\r\n  }\r\n\r\n  @HostListener( 'keypress', [ '$event' ] ) onInput( event: KeyboardEvent ): void {\r\n    if ( this.prohibitedCharacters.includes( event.key ) ) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.phoneForm = new UntypedFormGroup( {\r\n      phone: new UntypedFormControl( undefined, this.required ? [ Validators.required ] : [] ),\r\n    } );\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get( NgControl, null );\r\n    if ( ngControl ) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n    }\r\n\r\n    this.phoneSub = this.phoneForm.valueChanges.subscribe( ( formVal ) => {\r\n      this.value = formVal?.phone;\r\n      this.onChange( this.value );\r\n      this.onTouch( this.value );\r\n      this.handleErrors();\r\n    } );\r\n  }\r\n\r\n  onChange: any = (): void => { };\r\n  onTouch: any = (): void => { };\r\n\r\n  writeValue( value: any ): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange( fn: any ): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched( fn: any ): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.phoneSub?.unsubscribe();\r\n  }\r\n\r\n  reset(): void {\r\n    this.phoneInput.reset();\r\n  }\r\n\r\n  onBlur(): void {\r\n    this.onTouch( this.value );\r\n    this.onChange( this.value );\r\n    this.handleErrors();\r\n    this.onblur.emit({ value: this.value });\r\n  }\r\n\r\n  handleErrors(): void {\r\n    if (this.value === undefined && !this.phoneInput.empty) {\r\n      this.phoneForm.controls['phone'].setErrors({ validatePhoneNumber: true });\r\n    }\r\n    this.control.setErrors( this.phoneForm.get( 'phone' ).errors );\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <form #f=\"ngForm\" [formGroup]=\"phoneForm\">\r\n      <ngx-mat-intl-tel-input\r\n        (focusout)=\"onBlur()\"\r\n        [ngClass]=\"{ error: phoneForm.invalid && (phoneForm.dirty || phoneForm.touched) }\"\r\n        #phoneInput\r\n        [preferredCountries]=\"preferredCountries\"\r\n        [enablePlaceholder]=\"enablePlaceholder\"\r\n        [enableSearch]=\"enableSearch\"\r\n        [disabled]=\"disabled\"\r\n        [formControlName]=\"'phone'\"\r\n        name=\"phone\"\r\n        [inputPlaceholder]=\"placeholder\"\r\n      >\r\n      </ngx-mat-intl-tel-input>\r\n  </form>\r\n</app-element-wrapper>\r\n"]}
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-phone.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-phone/ecabs-phone.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-phone/ecabs-phone.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  HostListener,\r\n  Injector,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n  UntypedFormGroup,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport {NgxMatIntlTelInputComponent} from 'ngx-mat-intl-tel-input';\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport {EcabsComponentsService} from \"../base/services/ecabs-components.service\";\r\nimport {UnsubscribeService} from \"../base/services/unsubscribe.service\";\r\nimport {takeUntil} from \"rxjs\";\r\n\r\n@Component({\r\n  selector: 'ecabs-phone',\r\n  templateUrl: './ecabs-phone.component.html',\r\n  providers: [\r\n    UnsubscribeService,\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsPhoneComponent,\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class EcabsPhoneComponent\r\n  extends ElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit {\r\n  @Input() preferredCountries!: string[];\r\n  @Input() enablePlaceholder!: boolean;\r\n  @Input() enableSearch: boolean = true;\r\n  @Input() useOnlyDisabledClass = false;\r\n  @Input() declare required: boolean;\r\n\r\n  @Output() onblur: EventEmitter<{ value: string }> = new EventEmitter();\r\n\r\n  @ViewChild('phoneInput')\r\n  phoneInput!: NgxMatIntlTelInputComponent;\r\n\r\n  phoneForm: UntypedFormGroup;\r\n  phoneSub!: any;\r\n  prohibitedCharacters = ['-'];\r\n\r\n  get value(): any {\r\n    return this.phoneForm.get('phone')?.value;\r\n  }\r\n\r\n  set value(val) {\r\n    if (val !== undefined && this.value !== val) {\r\n      this.phoneForm.setValue({phone: val});\r\n    }\r\n  }\r\n\r\n  constructor(private readonly injector: Injector,\r\n              private readonly ecabsComponentsService: EcabsComponentsService,\r\n              private unsubscribeService: UnsubscribeService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  @HostListener('keypress', ['$event']) onInput(event: KeyboardEvent): void {\r\n    if (this.prohibitedCharacters.includes(event.key)) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.phoneForm = new UntypedFormGroup({\r\n      phone: new UntypedFormControl(undefined, this.required ? [Validators.required] : []),\r\n    });\r\n\r\n    this.ecabsComponentsService.getConfig()\r\n      .pipe(takeUntil(this.unsubscribeService.subscription()))\r\n      .subscribe((val) => {\r\n        if (!this.preferredCountries?.length) {\r\n          this.preferredCountries = val.defaultCountries;\r\n        }\r\n      });\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get(NgControl, null);\r\n    if (ngControl) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n    }\r\n\r\n    this.phoneSub = this.phoneForm.valueChanges.subscribe((formVal) => {\r\n      this.value = formVal?.phone;\r\n      this.onChange(this.value);\r\n      this.onTouch(this.value);\r\n      this.handleErrors();\r\n    });\r\n  }\r\n\r\n  onChange: any = (): void => {\r\n  };\r\n  onTouch: any = (): void => {\r\n  };\r\n\r\n  writeValue(value: any): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.phoneSub?.unsubscribe();\r\n  }\r\n\r\n  reset(): void {\r\n    this.phoneInput.reset();\r\n  }\r\n\r\n  onBlur(): void {\r\n    this.onTouch(this.value);\r\n    this.onChange(this.value);\r\n    this.handleErrors();\r\n    this.onblur.emit({value: this.value});\r\n  }\r\n\r\n  handleErrors(): void {\r\n    if (this.value === undefined && !this.phoneInput.empty) {\r\n      this.phoneForm.controls['phone'].setErrors({validatePhoneNumber: true});\r\n    }\r\n    this.control?.setErrors(this.phoneForm.get('phone').errors);\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <form #f=\"ngForm\" [formGroup]=\"phoneForm\">\r\n      <ngx-mat-intl-tel-input\r\n        (focusout)=\"onBlur()\"\r\n        [ngClass]=\"{ error: phoneForm.invalid && (phoneForm.dirty || phoneForm.touched) }\"\r\n        #phoneInput\r\n        [preferredCountries]=\"preferredCountries\"\r\n        [enablePlaceholder]=\"enablePlaceholder\"\r\n        [enableSearch]=\"enableSearch\"\r\n        [disabled]=\"disabled\"\r\n        [formControlName]=\"'phone'\"\r\n        name=\"phone\"\r\n        [inputPlaceholder]=\"placeholder\"\r\n      >\r\n      </ngx-mat-intl-tel-input>\r\n  </form>\r\n</app-element-wrapper>\r\n"]}
|