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
|
-
|
|
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,
|
|
43
|
+
const { value, apiKey } = changes ?? {};
|
|
42
44
|
if (!value?.firstChange && !value?.currentValue) {
|
|
43
45
|
this.onClean();
|
|
44
46
|
}
|
|
45
|
-
if (
|
|
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",
|
|
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
|
-
}],
|
|
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
|
-
|
|
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,
|
|
4536
|
+
const { value, apiKey } = changes ?? {};
|
|
4535
4537
|
if (!value?.firstChange && !value?.currentValue) {
|
|
4536
4538
|
this.onClean();
|
|
4537
4539
|
}
|
|
4538
|
-
if (
|
|
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",
|
|
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
|
-
}],
|
|
4634
|
+
}], apiKey: [{
|
|
4622
4635
|
type: Input
|
|
4623
4636
|
}], placeResult: [{
|
|
4624
4637
|
type: Output
|