ecabs-components 0.0.8 → 0.0.9

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.
@@ -12,14 +12,10 @@ export class EcabsPhoneComponent extends ElementBaseComponent {
12
12
  this.injector = injector;
13
13
  this.enableSearch = true;
14
14
  this.useOnlyDisabledClass = false;
15
- this.phoneForm = new UntypedFormGroup({
16
- phone: new UntypedFormControl(undefined, this.required ? [Validators.required] : []),
17
- });
18
15
  this.prohibitedCharacters = ['-'];
19
16
  this.onChange = () => { };
20
17
  this.onTouch = () => { };
21
18
  }
22
- ;
23
19
  get value() {
24
20
  return this.phoneForm.get('phone')?.value;
25
21
  }
@@ -33,6 +29,11 @@ export class EcabsPhoneComponent extends ElementBaseComponent {
33
29
  event.preventDefault();
34
30
  }
35
31
  }
32
+ ngOnInit() {
33
+ this.phoneForm = new UntypedFormGroup({
34
+ phone: new UntypedFormControl(undefined, this.required ? [Validators.required] : []),
35
+ });
36
+ }
36
37
  ngAfterViewInit() {
37
38
  const ngControl = this.injector.get(NgControl, null);
38
39
  if (ngControl) {
@@ -42,8 +43,7 @@ export class EcabsPhoneComponent extends ElementBaseComponent {
42
43
  this.value = formVal?.phone;
43
44
  this.onChange(this.value);
44
45
  this.onTouch(this.value);
45
- const errors = this.phoneForm?.get('phone')?.errors;
46
- this.control.setErrors(errors ? errors : null);
46
+ this.control.setErrors(this.phoneForm.get('phone').errors);
47
47
  });
48
48
  }
49
49
  writeValue(value) {
@@ -62,9 +62,9 @@ export class EcabsPhoneComponent extends ElementBaseComponent {
62
62
  this.phoneInput.reset();
63
63
  }
64
64
  onBlur() {
65
+ this.control.setErrors(this.phoneForm.get('phone').errors);
65
66
  this.onTouch(this.value);
66
- const errors = this.phoneForm?.get('phone')?.errors;
67
- this.control.setErrors(errors ? errors : null);
67
+ this.onChange(this.value);
68
68
  }
69
69
  }
70
70
  EcabsPhoneComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: EcabsPhoneComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
@@ -101,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
101
101
  type: HostListener,
102
102
  args: ['keypress', ['$event']]
103
103
  }] } });
104
- //# 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, HostListener, Injector, Input, OnDestroy, 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 {\r\n  @Input() preferredCountries!: string[];\r\n  @Input() enablePlaceholder!: boolean;\r\n  @Input() enableSearch: boolean = true;\r\n  @Input() useOnlyDisabledClass = false;\r\n  @Input() override required!: boolean;\r\n\r\n  @ViewChild( 'phoneInput' )\r\n  phoneInput!: NgxMatIntlTelInputComponent;\r\n\r\n  phoneForm: UntypedFormGroup = new UntypedFormGroup( {\r\n    phone: new UntypedFormControl( undefined, this.required ? [ Validators.required ] : [] ),\r\n  } );;\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  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get( NgControl, null ) as NgControl;\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      const errors = this.phoneForm?.get( 'phone' )?.errors;\r\n      this.control.setErrors( errors ? errors : null );\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    const errors = this.phoneForm?.get( 'phone' )?.errors;\r\n    this.control.setErrors( errors ? errors : null );\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"]}
104
+ //# 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, HostListener, Injector, Input, OnDestroy, OnInit, 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() override required!: boolean;\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.control.setErrors( this.phoneForm.get( 'phone' ).errors );\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.control.setErrors( this.phoneForm.get( 'phone' ).errors );\r\n    this.onTouch( this.value );\r\n    this.onChange( this.value );\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"]}
@@ -1864,14 +1864,10 @@ class EcabsPhoneComponent extends ElementBaseComponent {
1864
1864
  this.injector = injector;
1865
1865
  this.enableSearch = true;
1866
1866
  this.useOnlyDisabledClass = false;
1867
- this.phoneForm = new UntypedFormGroup({
1868
- phone: new UntypedFormControl(undefined, this.required ? [Validators.required] : []),
1869
- });
1870
1867
  this.prohibitedCharacters = ['-'];
1871
1868
  this.onChange = () => { };
1872
1869
  this.onTouch = () => { };
1873
1870
  }
1874
- ;
1875
1871
  get value() {
1876
1872
  var _a;
1877
1873
  return (_a = this.phoneForm.get('phone')) === null || _a === void 0 ? void 0 : _a.value;
@@ -1886,18 +1882,21 @@ class EcabsPhoneComponent extends ElementBaseComponent {
1886
1882
  event.preventDefault();
1887
1883
  }
1888
1884
  }
1885
+ ngOnInit() {
1886
+ this.phoneForm = new UntypedFormGroup({
1887
+ phone: new UntypedFormControl(undefined, this.required ? [Validators.required] : []),
1888
+ });
1889
+ }
1889
1890
  ngAfterViewInit() {
1890
1891
  const ngControl = this.injector.get(NgControl, null);
1891
1892
  if (ngControl) {
1892
1893
  this.control = ngControl.control;
1893
1894
  }
1894
1895
  this.phoneSub = this.phoneForm.valueChanges.subscribe((formVal) => {
1895
- var _a, _b;
1896
1896
  this.value = formVal === null || formVal === void 0 ? void 0 : formVal.phone;
1897
1897
  this.onChange(this.value);
1898
1898
  this.onTouch(this.value);
1899
- const errors = (_b = (_a = this.phoneForm) === null || _a === void 0 ? void 0 : _a.get('phone')) === null || _b === void 0 ? void 0 : _b.errors;
1900
- this.control.setErrors(errors ? errors : null);
1899
+ this.control.setErrors(this.phoneForm.get('phone').errors);
1901
1900
  });
1902
1901
  }
1903
1902
  writeValue(value) {
@@ -1917,10 +1916,9 @@ class EcabsPhoneComponent extends ElementBaseComponent {
1917
1916
  this.phoneInput.reset();
1918
1917
  }
1919
1918
  onBlur() {
1920
- var _a, _b;
1919
+ this.control.setErrors(this.phoneForm.get('phone').errors);
1921
1920
  this.onTouch(this.value);
1922
- const errors = (_b = (_a = this.phoneForm) === null || _a === void 0 ? void 0 : _a.get('phone')) === null || _b === void 0 ? void 0 : _b.errors;
1923
- this.control.setErrors(errors ? errors : null);
1921
+ this.onChange(this.value);
1924
1922
  }
1925
1923
  }
1926
1924
  EcabsPhoneComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: EcabsPhoneComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });