ecabs-components 1.0.61 → 1.0.63

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.
@@ -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 atleast [requiredLength] character' },
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 minmum [min]' },
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 minmum [requiredMin]' },
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
- const updatedConfig = {
27
- ...currentConfig,
28
- errorMessages: [...currentConfig.errorMessages, ...configUpdate.errorMessages],
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtY29tcG9uZW50cy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2Jhc2Uvc2VydmljZXMvZWNhYnMtY29tcG9uZW50cy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGVBQWUsRUFBYyxNQUFNLE1BQU0sQ0FBQzs7QUFLbkQsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQyxhQUFhLEdBQTBCO1FBQ3JDLGFBQWEsRUFBRTtZQUNiLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUscUJBQXFCLEVBQUU7WUFDcEQsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLE9BQU8sRUFBRSxzREFBc0QsRUFBRTtZQUN0RixFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsT0FBTyxFQUFFLHNEQUFzRCxFQUFFO1lBQ3RGLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsZ0NBQWdDLEVBQUU7WUFDMUQsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxpQ0FBaUMsRUFBRTtZQUMzRCxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLHdDQUF3QyxFQUFFO1lBQ3ZFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUseUNBQXlDLEVBQUU7U0FDekU7S0FDRixDQUFDO0lBRU0sT0FBTyxHQUEyQyxJQUFJLGVBQWUsQ0FBd0IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBRXpILGdCQUFlLENBQUM7SUFFaEIsU0FBUyxDQUFDLE1BQTZCO1FBQ3JDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFRCxTQUFTO1FBQ1AsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxZQUFZLENBQUMsWUFBbUM7UUFDOUMsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUM5QyxNQUFNLGFBQWEsR0FBRztZQUNwQixHQUFHLGFBQWE7WUFDaEIsYUFBYSxFQUFFLENBQUMsR0FBRyxhQUFhLENBQUMsYUFBYSxFQUFFLEdBQUcsWUFBWSxDQUFDLGFBQWEsQ0FBQztTQUMvRSxDQUFDO1FBRUYsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDbkMsQ0FBQzt3R0FqQ1Usc0JBQXNCOzRHQUF0QixzQkFBc0IsY0FGckIsTUFBTTs7NEZBRVAsc0JBQXNCO2tCQUhsQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRWNhYnNDb21wb25lbnRzU2VydmljZSB7XHJcbiAgZGVmYXVsdENvbmZpZzogRWNhYnNDb21wb25lbnRzQ29uZmlnID0ge1xyXG4gICAgZXJyb3JNZXNzYWdlczogW1xyXG4gICAgICB7IHR5cGU6ICdyZXF1aXJlZCcsIG1lc3NhZ2U6ICdbbGFiZWxdIGlzIHJlcXVpcmVkJyB9LFxyXG4gICAgICB7IHR5cGU6ICdtaW5sZW5ndGgnLCBtZXNzYWdlOiAnW2xhYmVsXSBzaG91bGQgYmUgYXRsZWFzdCBbcmVxdWlyZWRMZW5ndGhdIGNoYXJhY3RlcicgfSxcclxuICAgICAgeyB0eXBlOiAnbWF4TGVuZ3RoJywgbWVzc2FnZTogJ1tsYWJlbF0gc2hvdWxkIGJlIG1heGltdW0gW3JlcXVpcmVkTGVuZ3RoXSBjaGFyYWN0ZXInIH0sXHJcbiAgICAgIHsgdHlwZTogJ21pbicsIG1lc3NhZ2U6ICdbbGFiZWxdIHNob3VsZCBiZSBtaW5tdW0gW21pbl0nIH0sXHJcbiAgICAgIHsgdHlwZTogJ21heCcsIG1lc3NhZ2U6ICdbbGFiZWxdIHNob3VsZCBiZSBtYXhpbXVtIFttYXhdJyB9LFxyXG4gICAgICB7IHR5cGU6ICdtaW5WYWx1ZScsIG1lc3NhZ2U6ICdbbGFiZWxdIHNob3VsZCBiZSBtaW5tdW0gW3JlcXVpcmVkTWluXScgfSxcclxuICAgICAgeyB0eXBlOiAnbWF4VmFsdWUnLCBtZXNzYWdlOiAnW2xhYmVsXSBzaG91bGQgYmUgbWF4aW11bSBbcmVxdWlyZWRNYXhdJyB9LFxyXG4gICAgXSxcclxuICB9O1xyXG5cclxuICBwcml2YXRlIF9jb25maWc6IEJlaGF2aW9yU3ViamVjdDxFY2Fic0NvbXBvbmVudHNDb25maWc+ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxFY2Fic0NvbXBvbmVudHNDb25maWc+KHRoaXMuZGVmYXVsdENvbmZpZyk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkge31cclxuXHJcbiAgc2V0Q29uZmlnKGNvbmZpZzogRWNhYnNDb21wb25lbnRzQ29uZmlnKTogdm9pZCB7XHJcbiAgICB0aGlzLl9jb25maWcubmV4dChjb25maWcpO1xyXG4gIH1cclxuXHJcbiAgZ2V0Q29uZmlnKCk6IE9ic2VydmFibGU8RWNhYnNDb21wb25lbnRzQ29uZmlnPiB7XHJcbiAgICByZXR1cm4gdGhpcy5fY29uZmlnLmFzT2JzZXJ2YWJsZSgpO1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlQ29uZmlnKGNvbmZpZ1VwZGF0ZTogRWNhYnNDb21wb25lbnRzQ29uZmlnKSB7XHJcbiAgICBjb25zdCBjdXJyZW50Q29uZmlnID0gdGhpcy5fY29uZmlnLmdldFZhbHVlKCk7XHJcbiAgICBjb25zdCB1cGRhdGVkQ29uZmlnID0ge1xyXG4gICAgICAuLi5jdXJyZW50Q29uZmlnLFxyXG4gICAgICBlcnJvck1lc3NhZ2VzOiBbLi4uY3VycmVudENvbmZpZy5lcnJvck1lc3NhZ2VzLCAuLi5jb25maWdVcGRhdGUuZXJyb3JNZXNzYWdlc10sXHJcbiAgICB9O1xyXG5cclxuICAgIHRoaXMuX2NvbmZpZy5uZXh0KHVwZGF0ZWRDb25maWcpO1xyXG4gIH1cclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBFY2Fic0NvbXBvbmVudHNDb25maWcge1xyXG4gIGVycm9yTWVzc2FnZXM6IEVycm9yTWVzc2FnZVtdO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgRXJyb3JNZXNzYWdlIHtcclxuICB0eXBlOiBzdHJpbmc7XHJcbiAgbWVzc2FnZTogc3RyaW5nO1xyXG59XHJcbiJdfQ==
45
+ export class GenericComponentConfig {
46
+ defaultCountries = [];
47
+ errorMessages = [];
48
+ }
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtY29tcG9uZW50cy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2Jhc2Uvc2VydmljZXMvZWNhYnMtY29tcG9uZW50cy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFDLGVBQWUsRUFBYSxNQUFNLE1BQU0sQ0FBQzs7QUFLakQsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQyxhQUFhLEdBQTBCO1FBQ3JDLGdCQUFnQixFQUFFLEVBQUU7UUFDcEIsYUFBYSxFQUFFO1lBQ2IsRUFBQyxJQUFJLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxxQkFBcUIsRUFBQztZQUNsRCxFQUFDLElBQUksRUFBRSxXQUFXLEVBQUUsT0FBTyxFQUFFLHVEQUF1RCxFQUFDO1lBQ3JGLEVBQUMsSUFBSSxFQUFFLFdBQVcsRUFBRSxPQUFPLEVBQUUsc0RBQXNELEVBQUM7WUFDcEYsRUFBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxpQ0FBaUMsRUFBQztZQUN6RCxFQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLGlDQUFpQyxFQUFDO1lBQ3pELEVBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUseUNBQXlDLEVBQUM7WUFDdEUsRUFBQyxJQUFJLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSx5Q0FBeUMsRUFBQztTQUN2RTtLQUNGLENBQUM7SUFFTSxPQUFPLEdBQTJDLElBQUksZUFBZSxDQUF3QixJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7SUFFekg7SUFDQSxDQUFDO0lBRUQsU0FBUyxDQUFDLE1BQTZCO1FBQ3JDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFRCxTQUFTO1FBQ1AsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxZQUFZLENBQUMsWUFBbUM7UUFDOUMsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUM5QyxJQUFJLGFBQWEsR0FBMEIsSUFBSSxzQkFBc0IsRUFBRSxDQUFDO1FBRXhFLEtBQUssTUFBTSxHQUFHLElBQUksYUFBYSxFQUFFO1lBQy9CLElBQUksYUFBYSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRTtnQkFDckMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxhQUFhLENBQUMsR0FBRyxDQUFDLEVBQUUsR0FBRyxZQUFZLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQzthQUNwRTtTQUNGO1FBRUQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDbkMsQ0FBQzt3R0F0Q1Usc0JBQXNCOzRHQUF0QixzQkFBc0IsY0FGckIsTUFBTTs7NEZBRVAsc0JBQXNCO2tCQUhsQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7QUFvREQsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQyxnQkFBZ0IsR0FBYSxFQUFFLENBQUM7SUFDaEMsYUFBYSxHQUFtQixFQUFFLENBQUM7Q0FDcEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRWNhYnNDb21wb25lbnRzU2VydmljZSB7XHJcbiAgZGVmYXVsdENvbmZpZzogRWNhYnNDb21wb25lbnRzQ29uZmlnID0ge1xyXG4gICAgZGVmYXVsdENvdW50cmllczogW10sXHJcbiAgICBlcnJvck1lc3NhZ2VzOiBbXHJcbiAgICAgIHt0eXBlOiAncmVxdWlyZWQnLCBtZXNzYWdlOiAnW2xhYmVsXSBpcyByZXF1aXJlZCd9LFxyXG4gICAgICB7dHlwZTogJ21pbmxlbmd0aCcsIG1lc3NhZ2U6ICdbbGFiZWxdIHNob3VsZCBiZSBhdCBsZWFzdCBbcmVxdWlyZWRMZW5ndGhdIGNoYXJhY3Rlcid9LFxyXG4gICAgICB7dHlwZTogJ21heExlbmd0aCcsIG1lc3NhZ2U6ICdbbGFiZWxdIHNob3VsZCBiZSBtYXhpbXVtIFtyZXF1aXJlZExlbmd0aF0gY2hhcmFjdGVyJ30sXHJcbiAgICAgIHt0eXBlOiAnbWluJywgbWVzc2FnZTogJ1tsYWJlbF0gc2hvdWxkIGJlIG1pbmltdW0gW21pbl0nfSxcclxuICAgICAge3R5cGU6ICdtYXgnLCBtZXNzYWdlOiAnW2xhYmVsXSBzaG91bGQgYmUgbWF4aW11bSBbbWF4XSd9LFxyXG4gICAgICB7dHlwZTogJ21pblZhbHVlJywgbWVzc2FnZTogJ1tsYWJlbF0gc2hvdWxkIGJlIG1pbmltdW0gW3JlcXVpcmVkTWluXSd9LFxyXG4gICAgICB7dHlwZTogJ21heFZhbHVlJywgbWVzc2FnZTogJ1tsYWJlbF0gc2hvdWxkIGJlIG1heGltdW0gW3JlcXVpcmVkTWF4XSd9LFxyXG4gICAgXSxcclxuICB9O1xyXG5cclxuICBwcml2YXRlIF9jb25maWc6IEJlaGF2aW9yU3ViamVjdDxFY2Fic0NvbXBvbmVudHNDb25maWc+ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxFY2Fic0NvbXBvbmVudHNDb25maWc+KHRoaXMuZGVmYXVsdENvbmZpZyk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gIH1cclxuXHJcbiAgc2V0Q29uZmlnKGNvbmZpZzogRWNhYnNDb21wb25lbnRzQ29uZmlnKTogdm9pZCB7XHJcbiAgICB0aGlzLl9jb25maWcubmV4dChjb25maWcpO1xyXG4gIH1cclxuXHJcbiAgZ2V0Q29uZmlnKCk6IE9ic2VydmFibGU8RWNhYnNDb21wb25lbnRzQ29uZmlnPiB7XHJcbiAgICByZXR1cm4gdGhpcy5fY29uZmlnLmFzT2JzZXJ2YWJsZSgpO1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlQ29uZmlnKGNvbmZpZ1VwZGF0ZTogRWNhYnNDb21wb25lbnRzQ29uZmlnKSB7XHJcbiAgICBjb25zdCBjdXJyZW50Q29uZmlnID0gdGhpcy5fY29uZmlnLmdldFZhbHVlKCk7XHJcbiAgICBsZXQgdXBkYXRlZENvbmZpZzogRWNhYnNDb21wb25lbnRzQ29uZmlnID0gbmV3IEdlbmVyaWNDb21wb25lbnRDb25maWcoKTtcclxuXHJcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBjdXJyZW50Q29uZmlnKSB7XHJcbiAgICAgIGlmIChjdXJyZW50Q29uZmlnLmhhc093blByb3BlcnR5KGtleSkpIHtcclxuICAgICAgICB1cGRhdGVkQ29uZmlnW2tleV0gPSBbLi4uY3VycmVudENvbmZpZ1trZXldLCAuLi5jb25maWdVcGRhdGVba2V5XV07XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICB0aGlzLl9jb25maWcubmV4dCh1cGRhdGVkQ29uZmlnKTtcclxuICB9XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRWNhYnNDb21wb25lbnRzQ29uZmlnIHtcclxuICBkZWZhdWx0Q291bnRyaWVzPzogc3RyaW5nW107XHJcbiAgZXJyb3JNZXNzYWdlcz86IEVycm9yTWVzc2FnZVtdO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEVycm9yTWVzc2FnZSB7XHJcbiAgdHlwZTogc3RyaW5nO1xyXG4gIG1lc3NhZ2U6IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIEdlbmVyaWNDb21wb25lbnRDb25maWcgaW1wbGVtZW50cyBFY2Fic0NvbXBvbmVudHNDb25maWcge1xyXG4gIGRlZmF1bHRDb3VudHJpZXM6IHN0cmluZ1tdID0gW107XHJcbiAgZXJyb3JNZXNzYWdlczogRXJyb3JNZXNzYWdlW10gPSBbXTtcclxufVxyXG4iXX0=
@@ -1,13 +1,19 @@
1
1
  import { Component, EventEmitter, HostListener, Input, Output, ViewChild } from '@angular/core';
2
- import { UntypedFormControl, UntypedFormGroup, NG_VALUE_ACCESSOR, Validators, NgControl, } from '@angular/forms';
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 "@angular/common";
6
- import * as i2 from "../base/element-wrapper/element-wrapper.component";
7
- import * as i3 from "@angular/forms";
8
- import * as i4 from "ngx-mat-intl-tel-input";
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
- onTouch = () => { };
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.setErrors(this.phoneForm.get('phone').errors);
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: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i4.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: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
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"]}