ecabs-components 1.0.56-alpha → 1.0.56-beta

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.
@@ -1,8 +1,9 @@
1
- import { filter, takeUntil } from 'rxjs';
1
+ import { catchError, filter, from, map, of, shareReplay, takeUntil } from 'rxjs';
2
2
  import { Component, EventEmitter, Input, Output } from '@angular/core';
3
3
  import { NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';
4
4
  import { UnsubscribeService } from '../../public-api';
5
5
  import ElementBaseComponent from '../base/element-base';
6
+ import { Loader } from '@googlemaps/js-api-loader';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "../../public-api";
8
9
  import * as i2 from "@angular/common";
@@ -17,15 +18,16 @@ export class EcabsPlaceAutocompleteComponent extends ElementBaseComponent {
17
18
  showDeleteItem = false;
18
19
  showSuffix = false;
19
20
  countryCode = 'MT';
20
- apiLoaded$;
21
+ apiKey;
21
22
  placeResult = new EventEmitter();
22
23
  deleteItem = new EventEmitter();
24
+ apiLoaded$;
23
25
  val;
24
26
  get value() {
25
27
  return this.val;
26
28
  }
27
29
  set value(val) {
28
- if (this.val !== val) {
30
+ if (val !== undefined && this.val !== val) {
29
31
  this.val = val;
30
32
  this.onChange(val);
31
33
  }
@@ -38,11 +40,12 @@ export class EcabsPlaceAutocompleteComponent extends ElementBaseComponent {
38
40
  this.injector = injector;
39
41
  }
40
42
  ngOnChanges(changes) {
41
- const { value, apiLoaded$ } = changes ?? {};
43
+ const { value, apiKey } = changes ?? {};
42
44
  if (!value?.firstChange && !value?.currentValue) {
43
45
  this.onClean();
44
46
  }
45
- if (apiLoaded$?.currentValue) {
47
+ if (apiKey?.currentValue) {
48
+ this.apiLoaded$ = this.loadGoogleMap(this.apiKey);
46
49
  this.apiLoaded$.pipe(takeUntil(this.unsubscribeService.subscription()), filter((value) => !!value))
47
50
  .subscribe(() => {
48
51
  this.initGoogle();
@@ -74,7 +77,6 @@ export class EcabsPlaceAutocompleteComponent extends ElementBaseComponent {
74
77
  }
75
78
  onClean() {
76
79
  this.value = '';
77
- this.onTouch();
78
80
  }
79
81
  initGoogle() {
80
82
  const autocomplete = new google.maps.places.Autocomplete(this.getElement(), {
@@ -99,15 +101,26 @@ export class EcabsPlaceAutocompleteComponent extends ElementBaseComponent {
99
101
  getElement() {
100
102
  return this.elementRef.nativeElement.querySelector('.form-field__input');
101
103
  }
104
+ loadGoogleMap(apiKey) {
105
+ if (this.apiLoaded$) {
106
+ return this.apiLoaded$;
107
+ }
108
+ const loader = new Loader({
109
+ apiKey: apiKey,
110
+ version: 'weekly',
111
+ libraries: ['places', 'drawing'],
112
+ });
113
+ return from(loader.importLibrary('maps')).pipe(map(() => true), shareReplay(), catchError(() => of(false)));
114
+ }
102
115
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPlaceAutocompleteComponent, deps: [{ token: i0.NgZone }, { token: i1.UnsubscribeService }, { token: i0.ElementRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
103
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsPlaceAutocompleteComponent, selector: "ecabs-place-autocomplete", inputs: { showDeleteItem: "showDeleteItem", showSuffix: "showSuffix", countryCode: "countryCode", apiLoaded$: "apiLoaded$" }, outputs: { placeResult: "placeResult", deleteItem: "deleteItem" }, providers: [
116
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsPlaceAutocompleteComponent, selector: "ecabs-place-autocomplete", inputs: { showDeleteItem: "showDeleteItem", showSuffix: "showSuffix", countryCode: "countryCode", apiKey: "apiKey" }, outputs: { placeResult: "placeResult", deleteItem: "deleteItem" }, providers: [
104
117
  UnsubscribeService,
105
118
  {
106
119
  provide: NG_VALUE_ACCESSOR,
107
120
  useExisting: EcabsPlaceAutocompleteComponent,
108
121
  multi: true,
109
122
  },
110
- ], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<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", styles: ["mat-form-field{margin-bottom:0!important}.delete-button{color:var(--color-error)}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] });
123
+ ], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<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(); onTouch()\">close</mat-icon>\r\n </div>\r\n </div>\r\n</app-element-wrapper>\r\n", styles: ["mat-form-field{margin-bottom:0!important}.delete-button{color:var(--color-error)}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] });
111
124
  }
112
125
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPlaceAutocompleteComponent, decorators: [{
113
126
  type: Component,
@@ -118,18 +131,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
118
131
  useExisting: EcabsPlaceAutocompleteComponent,
119
132
  multi: true,
120
133
  },
121
- ], template: "<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", styles: ["mat-form-field{margin-bottom:0!important}.delete-button{color:var(--color-error)}\n"] }]
134
+ ], template: "<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(); onTouch()\">close</mat-icon>\r\n </div>\r\n </div>\r\n</app-element-wrapper>\r\n", styles: ["mat-form-field{margin-bottom:0!important}.delete-button{color:var(--color-error)}\n"] }]
122
135
  }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i1.UnsubscribeService }, { type: i0.ElementRef }, { type: i0.Injector }]; }, propDecorators: { showDeleteItem: [{
123
136
  type: Input
124
137
  }], showSuffix: [{
125
138
  type: Input
126
139
  }], countryCode: [{
127
140
  type: Input
128
- }], apiLoaded$: [{
141
+ }], apiKey: [{
129
142
  type: Input
130
143
  }], placeResult: [{
131
144
  type: Output
132
145
  }], deleteItem: [{
133
146
  type: Output
134
147
  }] } });
135
- //# 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 { filter, Observable, 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\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() apiLoaded$: Observable<boolean>;\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  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 ( this.val !== val ) {\r\n      this.val = val;\r\n      this.onChange( 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, apiLoaded$ } = changes ?? {};\r\n\r\n    if ( !value?.firstChange && !value?.currentValue ) {\r\n      this.onClean();\r\n    }\r\n\r\n    if ( apiLoaded$?.currentValue ) {\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","<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"]}
148
+ //# 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  }\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  }\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(); onTouch()\">close</mat-icon>\r\n      </div>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
@@ -8,7 +8,7 @@ import * as i2$1 from '@angular/material/icon';
8
8
  import { MatIconModule } from '@angular/material/icon';
9
9
  import * as i3 from '@angular/forms';
10
10
  import { NgControl, NG_VALUE_ACCESSOR, FormsModule, UntypedFormControl, ReactiveFormsModule, UntypedFormGroup, Validators } from '@angular/forms';
11
- import { BehaviorSubject, Subscription, combineLatest, map, debounceTime, Subject, takeUntil, first, filter } from 'rxjs';
11
+ import { BehaviorSubject, Subscription, combineLatest, map, debounceTime, Subject, takeUntil, first, filter, from, shareReplay, catchError, of } from 'rxjs';
12
12
  import * as i5 from '@angular/material/legacy-tooltip';
13
13
  import { MatLegacyTooltipModule } from '@angular/material/legacy-tooltip';
14
14
  import { MatLegacyInputModule } from '@angular/material/legacy-input';
@@ -49,6 +49,7 @@ import { MAT_LEGACY_DIALOG_DATA, MatLegacyDialogModule } from '@angular/material
49
49
  import { map as map$1 } from 'rxjs/operators';
50
50
  import * as i3$5 from '@angular/platform-browser';
51
51
  import { MatSidenavModule } from '@angular/material/sidenav';
52
+ import { Loader } from '@googlemaps/js-api-loader';
52
53
 
53
54
  class EcabsSpinnerComponent {
54
55
  size = 'medium';
@@ -4510,15 +4511,16 @@ class EcabsPlaceAutocompleteComponent extends ElementBaseComponent {
4510
4511
  showDeleteItem = false;
4511
4512
  showSuffix = false;
4512
4513
  countryCode = 'MT';
4513
- apiLoaded$;
4514
+ apiKey;
4514
4515
  placeResult = new EventEmitter();
4515
4516
  deleteItem = new EventEmitter();
4517
+ apiLoaded$;
4516
4518
  val;
4517
4519
  get value() {
4518
4520
  return this.val;
4519
4521
  }
4520
4522
  set value(val) {
4521
- if (this.val !== val) {
4523
+ if (val !== undefined && this.val !== val) {
4522
4524
  this.val = val;
4523
4525
  this.onChange(val);
4524
4526
  }
@@ -4531,11 +4533,12 @@ class EcabsPlaceAutocompleteComponent extends ElementBaseComponent {
4531
4533
  this.injector = injector;
4532
4534
  }
4533
4535
  ngOnChanges(changes) {
4534
- const { value, apiLoaded$ } = changes ?? {};
4536
+ const { value, apiKey } = changes ?? {};
4535
4537
  if (!value?.firstChange && !value?.currentValue) {
4536
4538
  this.onClean();
4537
4539
  }
4538
- if (apiLoaded$?.currentValue) {
4540
+ if (apiKey?.currentValue) {
4541
+ this.apiLoaded$ = this.loadGoogleMap(this.apiKey);
4539
4542
  this.apiLoaded$.pipe(takeUntil(this.unsubscribeService.subscription()), filter((value) => !!value))
4540
4543
  .subscribe(() => {
4541
4544
  this.initGoogle();
@@ -4567,7 +4570,6 @@ class EcabsPlaceAutocompleteComponent extends ElementBaseComponent {
4567
4570
  }
4568
4571
  onClean() {
4569
4572
  this.value = '';
4570
- this.onTouch();
4571
4573
  }
4572
4574
  initGoogle() {
4573
4575
  const autocomplete = new google.maps.places.Autocomplete(this.getElement(), {
@@ -4592,15 +4594,26 @@ class EcabsPlaceAutocompleteComponent extends ElementBaseComponent {
4592
4594
  getElement() {
4593
4595
  return this.elementRef.nativeElement.querySelector('.form-field__input');
4594
4596
  }
4597
+ loadGoogleMap(apiKey) {
4598
+ if (this.apiLoaded$) {
4599
+ return this.apiLoaded$;
4600
+ }
4601
+ const loader = new Loader({
4602
+ apiKey: apiKey,
4603
+ version: 'weekly',
4604
+ libraries: ['places', 'drawing'],
4605
+ });
4606
+ return from(loader.importLibrary('maps')).pipe(map(() => true), shareReplay(), catchError(() => of(false)));
4607
+ }
4595
4608
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPlaceAutocompleteComponent, deps: [{ token: i0.NgZone }, { token: UnsubscribeService }, { token: i0.ElementRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
4596
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsPlaceAutocompleteComponent, selector: "ecabs-place-autocomplete", inputs: { showDeleteItem: "showDeleteItem", showSuffix: "showSuffix", countryCode: "countryCode", apiLoaded$: "apiLoaded$" }, outputs: { placeResult: "placeResult", deleteItem: "deleteItem" }, providers: [
4609
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsPlaceAutocompleteComponent, selector: "ecabs-place-autocomplete", inputs: { showDeleteItem: "showDeleteItem", showSuffix: "showSuffix", countryCode: "countryCode", apiKey: "apiKey" }, outputs: { placeResult: "placeResult", deleteItem: "deleteItem" }, providers: [
4597
4610
  UnsubscribeService,
4598
4611
  {
4599
4612
  provide: NG_VALUE_ACCESSOR,
4600
4613
  useExisting: EcabsPlaceAutocompleteComponent,
4601
4614
  multi: true,
4602
4615
  },
4603
- ], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<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", styles: ["mat-form-field{margin-bottom:0!important}.delete-button{color:var(--color-error)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { 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: "component", type: i2$1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] });
4616
+ ], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<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(); onTouch()\">close</mat-icon>\r\n </div>\r\n </div>\r\n</app-element-wrapper>\r\n", styles: ["mat-form-field{margin-bottom:0!important}.delete-button{color:var(--color-error)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { 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: "component", type: i2$1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] });
4604
4617
  }
4605
4618
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPlaceAutocompleteComponent, decorators: [{
4606
4619
  type: Component,
@@ -4611,14 +4624,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
4611
4624
  useExisting: EcabsPlaceAutocompleteComponent,
4612
4625
  multi: true,
4613
4626
  },
4614
- ], template: "<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", styles: ["mat-form-field{margin-bottom:0!important}.delete-button{color:var(--color-error)}\n"] }]
4627
+ ], template: "<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(); onTouch()\">close</mat-icon>\r\n </div>\r\n </div>\r\n</app-element-wrapper>\r\n", styles: ["mat-form-field{margin-bottom:0!important}.delete-button{color:var(--color-error)}\n"] }]
4615
4628
  }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: UnsubscribeService }, { type: i0.ElementRef }, { type: i0.Injector }]; }, propDecorators: { showDeleteItem: [{
4616
4629
  type: Input
4617
4630
  }], showSuffix: [{
4618
4631
  type: Input
4619
4632
  }], countryCode: [{
4620
4633
  type: Input
4621
- }], apiLoaded$: [{
4634
+ }], apiKey: [{
4622
4635
  type: Input
4623
4636
  }], placeResult: [{
4624
4637
  type: Output