ecabs-components 1.0.56-delta → 1.0.56-gamma

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.
@@ -30,9 +30,7 @@ export class EcabsPlaceAutocompleteComponent extends ElementBaseComponent {
30
30
  if (val !== undefined && this.val !== val) {
31
31
  this.val = val;
32
32
  this.onChange(val);
33
- if (this.getData()?.control?.updateOn !== 'blur') {
34
- this.onTouch(val);
35
- }
33
+ this.onTouch(val);
36
34
  }
37
35
  }
38
36
  constructor(ngZone, unsubscribeService, elementRef, injector) {
@@ -149,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
149
147
  }], deleteItem: [{
150
148
  type: Output
151
149
  }] } });
152
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-place-autocomplete.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-place-autocomplete/ecabs-place-autocomplete.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-place-autocomplete/ecabs-place-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { catchError, filter, from, map, Observable, of, shareReplay, takeUntil } from 'rxjs';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  Component, ElementRef, EventEmitter, Injector, Input, NgZone, OnChanges, OnDestroy,\r\n  Output, SimpleChanges\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl, UntypedFormControl } from '@angular/forms';\r\n\r\nimport { UnsubscribeService } from '../../public-api';\r\nimport ElementBaseComponent from '../base/element-base';\r\n\r\nimport PlaceResult = google.maps.places.PlaceResult;\r\nimport { Loader } from '@googlemaps/js-api-loader';\r\n\r\n@Component( {\r\n  selector: 'ecabs-place-autocomplete',\r\n  templateUrl: './ecabs-place-autocomplete.component.html',\r\n  styleUrls: [ './ecabs-place-autocomplete.component.scss' ],\r\n  providers: [\r\n    UnsubscribeService,\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsPlaceAutocompleteComponent,\r\n      multi: true,\r\n    },\r\n  ],\r\n} )\r\nexport class EcabsPlaceAutocompleteComponent\r\n  extends ElementBaseComponent\r\n  implements OnDestroy, OnChanges, AfterViewInit, ControlValueAccessor {\r\n  @Input() showDeleteItem = false;\r\n  @Input() showSuffix = false;\r\n  @Input() countryCode = 'MT';\r\n  @Input() apiKey: string;\r\n\r\n  @Output() readonly placeResult: EventEmitter<{\r\n    place: PlaceResult;\r\n    text: string;\r\n  }> = new EventEmitter();\r\n\r\n  @Output() deleteItem = new EventEmitter();\r\n\r\n  apiLoaded$: Observable<boolean>;\r\n  val!: string;\r\n\r\n  get value(): string {\r\n    return this.val;\r\n  }\r\n\r\n  set value( val ) {\r\n    if ( val !== undefined && this.val !== val ) {\r\n      this.val = val;\r\n      this.onChange( val );\r\n\r\n      if ( this.getData()?.control?.updateOn !== 'blur' ) {\r\n        this.onTouch( val );\r\n      }\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private readonly ngZone: NgZone,\r\n    private readonly unsubscribeService: UnsubscribeService,\r\n    private readonly elementRef: ElementRef,\r\n    private readonly injector: Injector\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnChanges( changes: SimpleChanges ): void {\r\n    const { value, apiKey } = changes ?? {};\r\n\r\n    if ( !value?.firstChange && !value?.currentValue ) {\r\n      this.onClean();\r\n    }\r\n\r\n    if ( apiKey?.currentValue ) {\r\n      this.apiLoaded$ = this.loadGoogleMap( this.apiKey );\r\n\r\n      this.apiLoaded$.pipe(\r\n        takeUntil( this.unsubscribeService.subscription() ),\r\n        filter( ( value ) => !!value )\r\n      )\r\n        .subscribe( () => {\r\n          this.initGoogle();\r\n        } );\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\r\n  ngOnDestroy(): void {\r\n    this.unsubscribeService.destroy();\r\n  }\r\n\r\n  onChange: any = () => { };\r\n\r\n  onTouch: any = () => { };\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  onDeleteItem(): void {\r\n    this.deleteItem.emit();\r\n  }\r\n\r\n  onClean(): void {\r\n    this.value = '';\r\n    this.onTouch();\r\n  }\r\n\r\n  private initGoogle(): void {\r\n    const autocomplete = new google.maps.places.Autocomplete( this.getElement(), {\r\n      types: [],\r\n      componentRestrictions: { country: [ this.countryCode ] },\r\n      fields: [ 'address_components', 'geometry.location' ],\r\n    } );\r\n\r\n    autocomplete.addListener( 'place_changed', () => {\r\n      this.ngZone.run( () => {\r\n        const place = autocomplete.getPlace();\r\n\r\n        // verify result\r\n        if ( place.geometry === undefined || place.geometry === null ) {\r\n          return;\r\n        }\r\n\r\n        this.placeResult.emit( {\r\n          place: place,\r\n          text: this.getElement().value,\r\n        } );\r\n      } );\r\n    } );\r\n  }\r\n\r\n  private getElement(): any {\r\n    return this.elementRef.nativeElement.querySelector( '.form-field__input' );\r\n  }\r\n\r\n  private loadGoogleMap( apiKey: string ): Observable<boolean> {\r\n    if ( this.apiLoaded$ ) {\r\n      return this.apiLoaded$;\r\n    }\r\n\r\n    const loader = new Loader( {\r\n      apiKey: apiKey,\r\n      version: 'weekly',\r\n      libraries: [ 'places', 'drawing' ],\r\n    } );\r\n\r\n    return from( loader.importLibrary( 'maps' ) ).pipe(\r\n      map( () => true ),\r\n      shareReplay(),\r\n      catchError( () => of( false ) )\r\n    );\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper w-full\">\r\n    <input\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      [(ngModel)]=\"value\"\r\n      [id]=\"name\"\r\n      class=\"form-field__input w-full\"\r\n      autocorrect=\"off\"\r\n      autocapitalize=\"off\"\r\n      spellcheck=\"off\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n      <div class=\"form-field__input--suffix\" *ngIf=\"showSuffix\">\r\n        <mat-icon class=\"suffix\" *ngIf=\"!showDeleteItem && !value\">search</mat-icon>\r\n        <mat-icon class=\"suffix cursor-pointer delete-button\" *ngIf=\"showDeleteItem\" (click)=\"onDeleteItem()\"\r\n        >delete</mat-icon\r\n        >\r\n        <mat-icon class=\"suffix cursor-pointer\" *ngIf=\"!showDeleteItem && value\" (click)=\"onClean()\">close</mat-icon>\r\n      </div>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-place-autocomplete.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-place-autocomplete/ecabs-place-autocomplete.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-place-autocomplete/ecabs-place-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { catchError, filter, from, map, Observable, of, shareReplay, takeUntil } from 'rxjs';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  Component, ElementRef, EventEmitter, Injector, Input, NgZone, OnChanges, OnDestroy,\r\n  Output, SimpleChanges\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl, UntypedFormControl } from '@angular/forms';\r\n\r\nimport { UnsubscribeService } from '../../public-api';\r\nimport ElementBaseComponent from '../base/element-base';\r\n\r\nimport PlaceResult = google.maps.places.PlaceResult;\r\nimport { Loader } from '@googlemaps/js-api-loader';\r\n\r\n@Component( {\r\n  selector: 'ecabs-place-autocomplete',\r\n  templateUrl: './ecabs-place-autocomplete.component.html',\r\n  styleUrls: [ './ecabs-place-autocomplete.component.scss' ],\r\n  providers: [\r\n    UnsubscribeService,\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsPlaceAutocompleteComponent,\r\n      multi: true,\r\n    },\r\n  ],\r\n} )\r\nexport class EcabsPlaceAutocompleteComponent\r\n  extends ElementBaseComponent\r\n  implements OnDestroy, OnChanges, AfterViewInit, ControlValueAccessor {\r\n  @Input() showDeleteItem = false;\r\n  @Input() showSuffix = false;\r\n  @Input() countryCode = 'MT';\r\n  @Input() apiKey: string;\r\n\r\n  @Output() readonly placeResult: EventEmitter<{\r\n    place: PlaceResult;\r\n    text: string;\r\n  }> = new EventEmitter();\r\n\r\n  @Output() deleteItem = new EventEmitter();\r\n\r\n  apiLoaded$: Observable<boolean>;\r\n  val!: string;\r\n\r\n  get value(): string {\r\n    return this.val;\r\n  }\r\n\r\n  set value( val ) {\r\n    if ( val !== undefined && this.val !== val ) {\r\n      this.val = val;\r\n      this.onChange( val );\r\n      this.onTouch( val );\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private readonly ngZone: NgZone,\r\n    private readonly unsubscribeService: UnsubscribeService,\r\n    private readonly elementRef: ElementRef,\r\n    private readonly injector: Injector\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnChanges( changes: SimpleChanges ): void {\r\n    const { value, apiKey } = changes ?? {};\r\n\r\n    if ( !value?.firstChange && !value?.currentValue ) {\r\n      this.onClean();\r\n    }\r\n\r\n    if ( apiKey?.currentValue ) {\r\n      this.apiLoaded$ = this.loadGoogleMap( this.apiKey );\r\n\r\n      this.apiLoaded$.pipe(\r\n        takeUntil( this.unsubscribeService.subscription() ),\r\n        filter( ( value ) => !!value )\r\n      )\r\n        .subscribe( () => {\r\n          this.initGoogle();\r\n        } );\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\r\n  ngOnDestroy(): void {\r\n    this.unsubscribeService.destroy();\r\n  }\r\n\r\n  onChange: any = () => { };\r\n\r\n  onTouch: any = () => { };\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  onDeleteItem(): void {\r\n    this.deleteItem.emit();\r\n  }\r\n\r\n  onClean(): void {\r\n    this.value = '';\r\n    this.onTouch();\r\n  }\r\n\r\n  private initGoogle(): void {\r\n    const autocomplete = new google.maps.places.Autocomplete( this.getElement(), {\r\n      types: [],\r\n      componentRestrictions: { country: [ this.countryCode ] },\r\n      fields: [ 'address_components', 'geometry.location' ],\r\n    } );\r\n\r\n    autocomplete.addListener( 'place_changed', () => {\r\n      this.ngZone.run( () => {\r\n        const place = autocomplete.getPlace();\r\n\r\n        // verify result\r\n        if ( place.geometry === undefined || place.geometry === null ) {\r\n          return;\r\n        }\r\n\r\n        this.placeResult.emit( {\r\n          place: place,\r\n          text: this.getElement().value,\r\n        } );\r\n      } );\r\n    } );\r\n  }\r\n\r\n  private getElement(): any {\r\n    return this.elementRef.nativeElement.querySelector( '.form-field__input' );\r\n  }\r\n\r\n  private loadGoogleMap( apiKey: string ): Observable<boolean> {\r\n    if ( this.apiLoaded$ ) {\r\n      return this.apiLoaded$;\r\n    }\r\n\r\n    const loader = new Loader( {\r\n      apiKey: apiKey,\r\n      version: 'weekly',\r\n      libraries: [ 'places', 'drawing' ],\r\n    } );\r\n\r\n    return from( loader.importLibrary( 'maps' ) ).pipe(\r\n      map( () => true ),\r\n      shareReplay(),\r\n      catchError( () => of( false ) )\r\n    );\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper w-full\">\r\n    <input\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      [(ngModel)]=\"value\"\r\n      [id]=\"name\"\r\n      class=\"form-field__input w-full\"\r\n      autocorrect=\"off\"\r\n      autocapitalize=\"off\"\r\n      spellcheck=\"off\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n      <div class=\"form-field__input--suffix\" *ngIf=\"showSuffix\">\r\n        <mat-icon class=\"suffix\" *ngIf=\"!showDeleteItem && !value\">search</mat-icon>\r\n        <mat-icon class=\"suffix cursor-pointer delete-button\" *ngIf=\"showDeleteItem\" (click)=\"onDeleteItem()\"\r\n        >delete</mat-icon\r\n        >\r\n        <mat-icon class=\"suffix cursor-pointer\" *ngIf=\"!showDeleteItem && value\" (click)=\"onClean()\">close</mat-icon>\r\n      </div>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
@@ -4523,9 +4523,7 @@ class EcabsPlaceAutocompleteComponent extends ElementBaseComponent {
4523
4523
  if (val !== undefined && this.val !== val) {
4524
4524
  this.val = val;
4525
4525
  this.onChange(val);
4526
- if (this.getData()?.control?.updateOn !== 'blur') {
4527
- this.onTouch(val);
4528
- }
4526
+ this.onTouch(val);
4529
4527
  }
4530
4528
  }
4531
4529
  constructor(ngZone, unsubscribeService, elementRef, injector) {