ecabs-components 1.1.47 → 1.1.49
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.
- package/README.md +2 -0
- package/esm2022/lib/base/models/waypoint.models.mjs +26 -0
- package/esm2022/lib/base/pipes/separator-append.pipe.mjs +17 -0
- package/esm2022/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.mjs +3 -3
- package/esm2022/lib/ecabs-place-autocomplete-v2/ecabs-place-autocomplete-v2.component.mjs +237 -0
- package/esm2022/lib/ecabs-place-autocomplete-v2/ecabs-place-autocomplete-v2.module.mjs +40 -0
- package/esm2022/public-api.mjs +5 -1
- package/fesm2022/ecabs-components.mjs +337 -39
- package/fesm2022/ecabs-components.mjs.map +1 -1
- package/lib/base/models/waypoint.models.d.ts +29 -0
- package/lib/base/pipes/separator-append.pipe.d.ts +7 -0
- package/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.d.ts +1 -0
- package/lib/ecabs-place-autocomplete-v2/ecabs-place-autocomplete-v2.component.d.ts +55 -0
- package/lib/ecabs-place-autocomplete-v2/ecabs-place-autocomplete-v2.module.d.ts +13 -0
- package/package.json +1 -1
- package/public-api.d.ts +4 -0
- package/src/assets/styles/material/overrides/_form.scss +4 -0
- package/src/assets/styles/scss/modules/_autocomplete.scss +20 -7
- package/src/assets/styles/tailwind/index.scss +1 -1
package/README.md
CHANGED
|
@@ -107,3 +107,5 @@ To get more help on the Angular CLI use `ng help` or go check out the [Angular C
|
|
|
107
107
|
- **v1.1.45** — Added default validation of date range
|
|
108
108
|
- **v1.1.46** — Add `ViewChild` reference for `MatRadioGroup` and update event type in `EcabsRadioButtonListComponent`.
|
|
109
109
|
- **v1.1.47** — Add `Title` and `dynamic` content support to `EcabsEmptyPlaceholderComponent`.
|
|
110
|
+
- **v1.1.48** — Implement `EcabsPlaceAutocompleteV2Component` to support waypoints history, query change handling, and dropdown suggestions display.
|
|
111
|
+
- **v1.1.49** — Add support for `splitButtonsWidth` in `EcabsDialogConfirmComponent` and update button styling.`.
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export const WAYPOINT_SUGGESTIONS = [
|
|
2
|
+
{
|
|
3
|
+
suggestion_id: '123',
|
|
4
|
+
additional_info: 'Fastlane Ltd.',
|
|
5
|
+
location: { lat: 35.9038623, lng: 14.4129533 },
|
|
6
|
+
place_id: 'ChIJk9v0xtlRDhMRhrtrt2ChIic',
|
|
7
|
+
source: 'history',
|
|
8
|
+
},
|
|
9
|
+
];
|
|
10
|
+
export const WAYPOINT_SUGGESTIONS2 = [
|
|
11
|
+
{
|
|
12
|
+
suggestion_id: '1234',
|
|
13
|
+
additional_info: 'Fastlane Ltd. 2000',
|
|
14
|
+
location: { lat: 35.9038623, lng: 14.4129533 },
|
|
15
|
+
place_id: 'ChIJk9v0xtlRDhMRhrtrt2ChIic',
|
|
16
|
+
source: 'history',
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
suggestion_id: '1234',
|
|
20
|
+
additional_info: '448 D’Argens Garden, Leyland, Sliema, Malta',
|
|
21
|
+
location: { lat: 35.9095011, lng: 14.4945982 },
|
|
22
|
+
place_id: 'ChIJk9v0xtlRDhMRhrtrt2ChIic',
|
|
23
|
+
source: 'history',
|
|
24
|
+
},
|
|
25
|
+
];
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F5cG9pbnQubW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2Jhc2UvbW9kZWxzL3dheXBvaW50Lm1vZGVscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQkEsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQXlCO0lBQ3hEO1FBQ0UsYUFBYSxFQUFFLEtBQUs7UUFDcEIsZUFBZSxFQUFFLGVBQWU7UUFDaEMsUUFBUSxFQUFFLEVBQUUsR0FBRyxFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsVUFBVSxFQUFFO1FBQzlDLFFBQVEsRUFBRSw2QkFBNkI7UUFDdkMsTUFBTSxFQUFFLFNBQVM7S0FDbEI7Q0FDRixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQXlCO0lBQ3pEO1FBQ0UsYUFBYSxFQUFFLE1BQU07UUFDckIsZUFBZSxFQUFFLG9CQUFvQjtRQUNyQyxRQUFRLEVBQUUsRUFBRSxHQUFHLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxVQUFVLEVBQUU7UUFDOUMsUUFBUSxFQUFFLDZCQUE2QjtRQUN2QyxNQUFNLEVBQUUsU0FBUztLQUNsQjtJQUNEO1FBQ0UsYUFBYSxFQUFFLE1BQU07UUFDckIsZUFBZSxFQUFFLDZDQUE2QztRQUM5RCxRQUFRLEVBQUUsRUFBRSxHQUFHLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxVQUFVLEVBQUU7UUFDOUMsUUFBUSxFQUFFLDZCQUE2QjtRQUN2QyxNQUFNLEVBQUUsU0FBUztLQUNsQjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUGxhY2VSZXN1bHQgPSBnb29nbGUubWFwcy5wbGFjZXMuUGxhY2VSZXN1bHQ7XHJcbmltcG9ydCB7IFdheXBvaW50VHlwZUVudW0gfSBmcm9tICcuLi9jb25zdHMvd2F5cG9pbnQuY29uc3RzJztcclxuaW1wb3J0IFByZWRpY3Rpb25UZXJtID0gZ29vZ2xlLm1hcHMucGxhY2VzLlByZWRpY3Rpb25UZXJtO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBXYXlwb2ludFN1Z2dlc3Rpb24ge1xyXG4gIHN1Z2dlc3Rpb25faWQ/OiBzdHJpbmc7XHJcbiAgYWRkaXRpb25hbF9pbmZvPzogc3RyaW5nO1xyXG4gIGxvY2F0aW9uPzogR2VvUG9pbnQ7XHJcbiAgcGxhY2VfaWQ6IHN0cmluZztcclxuICBzb3VyY2U/OiBzdHJpbmc7XHJcbiAgZnJlcXVlbmN5PzogbnVtYmVyO1xyXG4gIGxhc3RfdmlzaXQ/OiBzdHJpbmcgfCBEYXRlO1xyXG4gIGdlb19rZXk/OiBzdHJpbmc7XHJcbiAgcHJlZGljdGlvbl90ZXJtPzogUHJlZGljdGlvblRlcm1bXTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBHZW9Qb2ludCB7XHJcbiAgbGF0OiBudW1iZXI7XHJcbiAgbG5nOiBudW1iZXI7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgR29vZ2xlUGxhY2VSZXN1bHQge1xyXG4gIHBsYWNlOiBQbGFjZVJlc3VsdDtcclxuICB0ZXh0OiBzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgV2F5cG9pbnRRdWVyeUNoYW5nZSB7XHJcbiAgd2F5cG9pbnRfdHlwZTogV2F5cG9pbnRUeXBlRW51bTtcclxuICBxdWVyeTogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgV0FZUE9JTlRfU1VHR0VTVElPTlM6IFdheXBvaW50U3VnZ2VzdGlvbltdID0gW1xyXG4gIHtcclxuICAgIHN1Z2dlc3Rpb25faWQ6ICcxMjMnLFxyXG4gICAgYWRkaXRpb25hbF9pbmZvOiAnRmFzdGxhbmUgTHRkLicsXHJcbiAgICBsb2NhdGlvbjogeyBsYXQ6IDM1LjkwMzg2MjMsIGxuZzogMTQuNDEyOTUzMyB9LFxyXG4gICAgcGxhY2VfaWQ6ICdDaElKazl2MHh0bFJEaE1SaHJ0cnQyQ2hJaWMnLFxyXG4gICAgc291cmNlOiAnaGlzdG9yeScsXHJcbiAgfSxcclxuXTtcclxuXHJcbmV4cG9ydCBjb25zdCBXQVlQT0lOVF9TVUdHRVNUSU9OUzI6IFdheXBvaW50U3VnZ2VzdGlvbltdID0gW1xyXG4gIHtcclxuICAgIHN1Z2dlc3Rpb25faWQ6ICcxMjM0JyxcclxuICAgIGFkZGl0aW9uYWxfaW5mbzogJ0Zhc3RsYW5lIEx0ZC4gMjAwMCcsXHJcbiAgICBsb2NhdGlvbjogeyBsYXQ6IDM1LjkwMzg2MjMsIGxuZzogMTQuNDEyOTUzMyB9LFxyXG4gICAgcGxhY2VfaWQ6ICdDaElKazl2MHh0bFJEaE1SaHJ0cnQyQ2hJaWMnLFxyXG4gICAgc291cmNlOiAnaGlzdG9yeScsXHJcbiAgfSxcclxuICB7XHJcbiAgICBzdWdnZXN0aW9uX2lkOiAnMTIzNCcsXHJcbiAgICBhZGRpdGlvbmFsX2luZm86ICc0NDggROKAmUFyZ2VucyBHYXJkZW4sIExleWxhbmQsIFNsaWVtYSwgTWFsdGEnLFxyXG4gICAgbG9jYXRpb246IHsgbGF0OiAzNS45MDk1MDExLCBsbmc6IDE0LjQ5NDU5ODIgfSxcclxuICAgIHBsYWNlX2lkOiAnQ2hJSms5djB4dGxSRGhNUmhydHJ0MkNoSWljJyxcclxuICAgIHNvdXJjZTogJ2hpc3RvcnknLFxyXG4gIH0sXHJcbl07XHJcbiJdfQ==
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class SeparatorAppendPipe {
|
|
4
|
+
transform(value, nextSibling, separator = ', ') {
|
|
5
|
+
return value && nextSibling ? `${value}${separator}` : value;
|
|
6
|
+
}
|
|
7
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SeparatorAppendPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
8
|
+
static ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: SeparatorAppendPipe, isStandalone: true, name: "separatorAppend" });
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SeparatorAppendPipe, decorators: [{
|
|
11
|
+
type: Pipe,
|
|
12
|
+
args: [{
|
|
13
|
+
name: 'separatorAppend',
|
|
14
|
+
standalone: true,
|
|
15
|
+
}]
|
|
16
|
+
}] });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VwYXJhdG9yLWFwcGVuZC5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2Jhc2UvcGlwZXMvc2VwYXJhdG9yLWFwcGVuZC5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQU1wRCxNQUFNLE9BQU8sbUJBQW1CO0lBQzlCLFNBQVMsQ0FBQyxLQUFhLEVBQUUsV0FBb0IsRUFBRSxTQUFTLEdBQUcsSUFBSTtRQUM3RCxPQUFPLEtBQUssSUFBSSxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxHQUFHLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDL0QsQ0FBQzt3R0FIVSxtQkFBbUI7c0dBQW5CLG1CQUFtQjs7NEZBQW5CLG1CQUFtQjtrQkFKL0IsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsaUJBQWlCO29CQUN2QixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AUGlwZSh7XHJcbiAgbmFtZTogJ3NlcGFyYXRvckFwcGVuZCcsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNlcGFyYXRvckFwcGVuZFBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcclxuICB0cmFuc2Zvcm0odmFsdWU6IHN0cmluZywgbmV4dFNpYmxpbmc/OiBzdHJpbmcsIHNlcGFyYXRvciA9ICcsICcpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHZhbHVlICYmIG5leHRTaWJsaW5nID8gYCR7dmFsdWV9JHtzZXBhcmF0b3J9YCA6IHZhbHVlO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -67,13 +67,13 @@ export class EcabsDialogConfirmComponent {
|
|
|
67
67
|
this.dialogRef.close(this.data.popoverResult ?? false);
|
|
68
68
|
}
|
|
69
69
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDialogConfirmComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i2.UnsubscribeService }, { token: i3.EcabsComponentsService }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
70
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsDialogConfirmComponent, selector: "ecabs-dialog-confirm", providers: [UnsubscribeService], ngImport: i0, template: "<div matDialogTitle *ngIf=\"data?.titleTemplate; else title\">\r\n <div class=\"flex items-center justify-between modal-title\">\r\n <ng-container *ngTemplateOutlet=\"data?.titleTemplate\"></ng-container>\r\n\r\n <mat-icon *ngIf=\"!!data?.isPopover\" (click)=\"closeOnPopover()\"\r\n (keydown.enter)=\"closeOnPopover()\"\r\n class=\"mat-icon material-icons-outlined justify-end icon--close\">\r\n close\r\n </mat-icon>\r\n </div>\r\n</div>\r\n\r\n\r\n<ng-template #title>\r\n <div matDialogTitle *ngIf=\"data?.title || !!data?.isPopover\" class=\"flex flex-column\">\r\n <div *ngIf=\"!!data?.isPopover\" class=\"w-full flex justify-end\">\r\n <mat-icon (click)=\"closeOnPopover()\"\r\n (keydown.enter)=\"closeOnPopover()\"\r\n class=\"mat-icon material-icons-outlined float-right icon--close mb-2\">\r\n close\r\n </mat-icon>\r\n </div>\r\n\r\n <div class=\"font-semibold heading--xs modal-title {{ data.titleColor }}\" *ngIf=\"data.title\">\r\n {{ data.title }}\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n<div mat-dialog-content>\r\n <div *ngIf=\"data?.content\">{{ data?.content }}</div>\r\n <ng-container *ngTemplateOutlet=\"data?.message\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"(!!data?.cancelLabel || !!data?.confirmLabel) && !data?.hideCtaButtons\">\r\n <div mat-dialog-actions\r\n [ngClass]=\"{'gap-y-4': data?.useFullButtonSize}\"\r\n class=\"btn__group flex justify-end w-full\">\r\n <ecabs-buttons *ngIf=\"!!data?.cancelLabel\"\r\n [full]=\"data?.useFullButtonSize\"\r\n (click)=\"closeFalsey()\"\r\n (keydown.enter)=\"closeFalsey()\"\r\n [style]=\"data?.cancelStyle || 'stroked'\">\r\n {{ data?.cancelLabel }}\r\n </ecabs-buttons>\r\n\r\n <ecabs-buttons *ngIf=\"!!data?.confirmLabel\"\r\n [full]=\"data?.useFullButtonSize\"\r\n [color]=\"data?.color || color\"\r\n [style]=\"data?.confirmStyle || 'flat'\"\r\n [loading]=\"data?.loading$ | async\"\r\n (click)=\"closeDialog()\"\r\n [disabled]=\"data?.disableConfirm$ | async\"\r\n (keydown.enter)=\"closeDialog()\">\r\n {{ data?.confirmLabel }}\r\n </ecabs-buttons>\r\n </div>\r\n</div>\r\n", styles: [":host .mat-icon.icon--close,:host ::ng-deep .mat-icon.icon--close{cursor:pointer;color:var(--color-gray-500)}.modal-title.warn{color:var(--color-error)!important}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i5.ButtonsComponent, selector: "ecabs-buttons", inputs: ["disabled", "loading", "size", "type", "style", "full", "color"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] });
|
|
70
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsDialogConfirmComponent, selector: "ecabs-dialog-confirm", providers: [UnsubscribeService], ngImport: i0, template: "<div matDialogTitle *ngIf=\"data?.titleTemplate; else title\">\r\n <div class=\"flex items-center justify-between modal-title\">\r\n <ng-container *ngTemplateOutlet=\"data?.titleTemplate\"></ng-container>\r\n\r\n <mat-icon *ngIf=\"!!data?.isPopover\" (click)=\"closeOnPopover()\"\r\n (keydown.enter)=\"closeOnPopover()\"\r\n class=\"mat-icon material-icons-outlined justify-end icon--close\">\r\n close\r\n </mat-icon>\r\n </div>\r\n</div>\r\n\r\n\r\n<ng-template #title>\r\n <div matDialogTitle *ngIf=\"data?.title || !!data?.isPopover\" class=\"flex flex-column\">\r\n <div *ngIf=\"!!data?.isPopover\" class=\"w-full flex justify-end\">\r\n <mat-icon (click)=\"closeOnPopover()\"\r\n (keydown.enter)=\"closeOnPopover()\"\r\n class=\"mat-icon material-icons-outlined float-right icon--close mb-2\">\r\n close\r\n </mat-icon>\r\n </div>\r\n\r\n <div class=\"font-semibold heading--xs modal-title {{ data.titleColor }}\" *ngIf=\"data.title\">\r\n {{ data.title }}\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n<div mat-dialog-content>\r\n <div *ngIf=\"data?.content\">{{ data?.content }}</div>\r\n <ng-container *ngTemplateOutlet=\"data?.message\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"(!!data?.cancelLabel || !!data?.confirmLabel) && !data?.hideCtaButtons\">\r\n <div mat-dialog-actions\r\n [ngClass]=\"{'gap-y-4': data?.useFullButtonSize || data?.splitButtonsWidth}\"\r\n class=\"btn__group flex justify-end w-full\">\r\n <ecabs-buttons *ngIf=\"!!data?.cancelLabel\"\r\n [ngClass]=\"{'flex-1': data?.splitButtonsWidth}\"\r\n [full]=\"data?.useFullButtonSize\"\r\n (click)=\"closeFalsey()\"\r\n (keydown.enter)=\"closeFalsey()\"\r\n [style]=\"data?.cancelStyle || 'stroked'\">\r\n {{ data?.cancelLabel }}\r\n </ecabs-buttons>\r\n\r\n <ecabs-buttons *ngIf=\"!!data?.confirmLabel\"\r\n [ngClass]=\"{'flex-1': data?.splitButtonsWidth}\"\r\n [full]=\"data?.useFullButtonSize\"\r\n [color]=\"data?.color || color\"\r\n [style]=\"data?.confirmStyle || 'flat'\"\r\n [loading]=\"data?.loading$ | async\"\r\n (click)=\"closeDialog()\"\r\n [disabled]=\"data?.disableConfirm$ | async\"\r\n (keydown.enter)=\"closeDialog()\">\r\n {{ data?.confirmLabel }}\r\n </ecabs-buttons>\r\n </div>\r\n</div>\r\n", styles: [":host .mat-icon.icon--close,:host ::ng-deep .mat-icon.icon--close{cursor:pointer;color:var(--color-gray-500)}.modal-title.warn{color:var(--color-error)!important}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i5.ButtonsComponent, selector: "ecabs-buttons", inputs: ["disabled", "loading", "size", "type", "style", "full", "color"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] });
|
|
71
71
|
}
|
|
72
72
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDialogConfirmComponent, decorators: [{
|
|
73
73
|
type: Component,
|
|
74
|
-
args: [{ selector: 'ecabs-dialog-confirm', providers: [UnsubscribeService], template: "<div matDialogTitle *ngIf=\"data?.titleTemplate; else title\">\r\n <div class=\"flex items-center justify-between modal-title\">\r\n <ng-container *ngTemplateOutlet=\"data?.titleTemplate\"></ng-container>\r\n\r\n <mat-icon *ngIf=\"!!data?.isPopover\" (click)=\"closeOnPopover()\"\r\n (keydown.enter)=\"closeOnPopover()\"\r\n class=\"mat-icon material-icons-outlined justify-end icon--close\">\r\n close\r\n </mat-icon>\r\n </div>\r\n</div>\r\n\r\n\r\n<ng-template #title>\r\n <div matDialogTitle *ngIf=\"data?.title || !!data?.isPopover\" class=\"flex flex-column\">\r\n <div *ngIf=\"!!data?.isPopover\" class=\"w-full flex justify-end\">\r\n <mat-icon (click)=\"closeOnPopover()\"\r\n (keydown.enter)=\"closeOnPopover()\"\r\n class=\"mat-icon material-icons-outlined float-right icon--close mb-2\">\r\n close\r\n </mat-icon>\r\n </div>\r\n\r\n <div class=\"font-semibold heading--xs modal-title {{ data.titleColor }}\" *ngIf=\"data.title\">\r\n {{ data.title }}\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n<div mat-dialog-content>\r\n <div *ngIf=\"data?.content\">{{ data?.content }}</div>\r\n <ng-container *ngTemplateOutlet=\"data?.message\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"(!!data?.cancelLabel || !!data?.confirmLabel) && !data?.hideCtaButtons\">\r\n <div mat-dialog-actions\r\n [ngClass]=\"{'gap-y-4': data?.useFullButtonSize}\"\r\n class=\"btn__group flex justify-end w-full\">\r\n <ecabs-buttons *ngIf=\"!!data?.cancelLabel\"\r\n [full]=\"data?.useFullButtonSize\"\r\n (click)=\"closeFalsey()\"\r\n (keydown.enter)=\"closeFalsey()\"\r\n [style]=\"data?.cancelStyle || 'stroked'\">\r\n {{ data?.cancelLabel }}\r\n </ecabs-buttons>\r\n\r\n <ecabs-buttons *ngIf=\"!!data?.confirmLabel\"\r\n [full]=\"data?.useFullButtonSize\"\r\n [color]=\"data?.color || color\"\r\n [style]=\"data?.confirmStyle || 'flat'\"\r\n [loading]=\"data?.loading$ | async\"\r\n (click)=\"closeDialog()\"\r\n [disabled]=\"data?.disableConfirm$ | async\"\r\n (keydown.enter)=\"closeDialog()\">\r\n {{ data?.confirmLabel }}\r\n </ecabs-buttons>\r\n </div>\r\n</div>\r\n", styles: [":host .mat-icon.icon--close,:host ::ng-deep .mat-icon.icon--close{cursor:pointer;color:var(--color-gray-500)}.modal-title.warn{color:var(--color-error)!important}\n"] }]
|
|
74
|
+
args: [{ selector: 'ecabs-dialog-confirm', providers: [UnsubscribeService], template: "<div matDialogTitle *ngIf=\"data?.titleTemplate; else title\">\r\n <div class=\"flex items-center justify-between modal-title\">\r\n <ng-container *ngTemplateOutlet=\"data?.titleTemplate\"></ng-container>\r\n\r\n <mat-icon *ngIf=\"!!data?.isPopover\" (click)=\"closeOnPopover()\"\r\n (keydown.enter)=\"closeOnPopover()\"\r\n class=\"mat-icon material-icons-outlined justify-end icon--close\">\r\n close\r\n </mat-icon>\r\n </div>\r\n</div>\r\n\r\n\r\n<ng-template #title>\r\n <div matDialogTitle *ngIf=\"data?.title || !!data?.isPopover\" class=\"flex flex-column\">\r\n <div *ngIf=\"!!data?.isPopover\" class=\"w-full flex justify-end\">\r\n <mat-icon (click)=\"closeOnPopover()\"\r\n (keydown.enter)=\"closeOnPopover()\"\r\n class=\"mat-icon material-icons-outlined float-right icon--close mb-2\">\r\n close\r\n </mat-icon>\r\n </div>\r\n\r\n <div class=\"font-semibold heading--xs modal-title {{ data.titleColor }}\" *ngIf=\"data.title\">\r\n {{ data.title }}\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n<div mat-dialog-content>\r\n <div *ngIf=\"data?.content\">{{ data?.content }}</div>\r\n <ng-container *ngTemplateOutlet=\"data?.message\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"(!!data?.cancelLabel || !!data?.confirmLabel) && !data?.hideCtaButtons\">\r\n <div mat-dialog-actions\r\n [ngClass]=\"{'gap-y-4': data?.useFullButtonSize || data?.splitButtonsWidth}\"\r\n class=\"btn__group flex justify-end w-full\">\r\n <ecabs-buttons *ngIf=\"!!data?.cancelLabel\"\r\n [ngClass]=\"{'flex-1': data?.splitButtonsWidth}\"\r\n [full]=\"data?.useFullButtonSize\"\r\n (click)=\"closeFalsey()\"\r\n (keydown.enter)=\"closeFalsey()\"\r\n [style]=\"data?.cancelStyle || 'stroked'\">\r\n {{ data?.cancelLabel }}\r\n </ecabs-buttons>\r\n\r\n <ecabs-buttons *ngIf=\"!!data?.confirmLabel\"\r\n [ngClass]=\"{'flex-1': data?.splitButtonsWidth}\"\r\n [full]=\"data?.useFullButtonSize\"\r\n [color]=\"data?.color || color\"\r\n [style]=\"data?.confirmStyle || 'flat'\"\r\n [loading]=\"data?.loading$ | async\"\r\n (click)=\"closeDialog()\"\r\n [disabled]=\"data?.disableConfirm$ | async\"\r\n (keydown.enter)=\"closeDialog()\">\r\n {{ data?.confirmLabel }}\r\n </ecabs-buttons>\r\n </div>\r\n</div>\r\n", styles: [":host .mat-icon.icon--close,:host ::ng-deep .mat-icon.icon--close{cursor:pointer;color:var(--color-gray-500)}.modal-title.warn{color:var(--color-error)!important}\n"] }]
|
|
75
75
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
76
76
|
type: Inject,
|
|
77
77
|
args: [MAT_DIALOG_DATA]
|
|
78
78
|
}] }, { type: i1.MatDialogRef }, { type: i2.UnsubscribeService }, { type: i3.EcabsComponentsService }, { type: i0.DestroyRef }]; } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-dialog-confirm.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,MAAM,GAIP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAgB,MAAM,0BAA0B,CAAC;AAEzE,OAAO,EAAc,SAAS,EAAE,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAM1E,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;;;;;;;;AAQhE,MAAM,OAAO,2BAA2B;IAKJ;IACzB;IACU;IACA;IACA;IARnB,OAAO,CAAS;IAChB,KAAK,GAAiB,SAAS,CAAC;IAEhC,YACkC,IAAuC,EAChE,SAA0D,EAChD,kBAAsC,EACtC,iBAAyC,EACzC,UAAsB;QAJP,SAAI,GAAJ,IAAI,CAAmC;QAChE,cAAS,GAAT,SAAS,CAAiD;QAChD,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,sBAAiB,GAAjB,iBAAiB,CAAwB;QACzC,eAAU,GAAV,UAAU,CAAY;IACtC,CAAC;IAEJ,YAAY,CAAY;IAExB,QAAQ;QACN,IAAI,CAAC,iBAAiB;aACnB,SAAS,EAAE;aACX,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aACzC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACpB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,EAAE,CAAC;YAC9B,MAAM,EACJ,YAAY,EACZ,WAAW,EACX,iBAAiB,EACjB,gBAAgB,GACjB,GAAG,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;YAEpB,IAAI,IAAI,EAAE;gBACR,IAAI,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,iBAAiB;oBACzC,CAAC,CAAC,YAAY,IAAI,IAAI,EAAE,YAAY;oBACpC,CAAC,CAAC,SAAS,CAAC;gBACd,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,gBAAgB;oBACvC,CAAC,CAAC,WAAW,IAAI,IAAI,EAAE,WAAW;oBAClC,CAAC,CAAC,SAAS,CAAC;aACf;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACT,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,CAAC;IACpC,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACtB,IAAI,CAAC,IAAI,CAAC,QAAQ;gBAChB,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC,CAAC;iBACxD,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;gBACrB,IAAI,CAAC,OAAO,EAAE;oBACZ,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,CAAC;iBACvD;YACH,CAAC,CAAC,CAAC;SACN;aAAM;YACL,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,CAAC;SACvD;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,KAAK,CAAC,CAAC;IACxD,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,KAAK,CAAC,CAAC;IACzD,CAAC;wGA9DU,2BAA2B,kBAK5B,eAAe;4FALd,2BAA2B,+CAF3B,CAAC,kBAAkB,CAAC,0BCvBjC,42EA2DA;;4FDlCa,2BAA2B;kBANvC,SAAS;+BACE,sBAAsB,aAGrB,CAAC,kBAAkB,CAAC;;0BAO5B,MAAM;2BAAC,eAAe","sourcesContent":["import {\r\n  Component,\r\n  DestroyRef,\r\n  Inject,\r\n  OnDestroy,\r\n  OnInit,\r\n  TemplateRef,\r\n} from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { ThemePalette } from '@angular/material/core';\r\nimport { Observable, takeUntil } from 'rxjs';\r\nimport { UnsubscribeService } from '../base/services/unsubscribe.service';\r\nimport { ButtonStyle } from '../base/consts/buttons.consts';\r\nimport {\r\n  EcabsComponentsService,\r\n  Ecabsi18n,\r\n} from '../base/services/ecabs-components.service';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Component({\r\n  selector: 'ecabs-dialog-confirm',\r\n  templateUrl: './ecabs-dialog-confirm.component.html',\r\n  styleUrls: ['./ecabs-dialog-confirm.component.scss'],\r\n  providers: [UnsubscribeService],\r\n})\r\nexport class EcabsDialogConfirmComponent implements OnInit, OnDestroy {\r\n  message: string;\r\n  color: ThemePalette = 'primary';\r\n\r\n  constructor(\r\n    @Inject(MAT_DIALOG_DATA) public data: EcabsDialogConfirmComponentConfig,\r\n    public dialogRef: MatDialogRef<EcabsDialogConfirmComponentConfig>,\r\n    private readonly unsubscribeService: UnsubscribeService,\r\n    private readonly componentsService: EcabsComponentsService,\r\n    private readonly destroyRef: DestroyRef,\r\n  ) {}\r\n\r\n  translations: Ecabsi18n;\r\n\r\n  ngOnInit(): void {\r\n    this.componentsService\r\n      .getConfig()\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe((config) => {\r\n        const { i18n } = config ?? {};\r\n        const {\r\n          confirmLabel,\r\n          cancelLabel,\r\n          hideConfirmButton,\r\n          hideCancelButton,\r\n        } = this.data ?? {};\r\n\r\n        if (i18n) {\r\n          this.data.confirmLabel = !hideConfirmButton\r\n            ? confirmLabel || i18n?.confirmLabel\r\n            : undefined;\r\n          this.data.cancelLabel = !hideCancelButton\r\n            ? cancelLabel || i18n?.cancelLabel\r\n            : undefined;\r\n        }\r\n      });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.unsubscribeService.destroy();\r\n  }\r\n\r\n  closeDialog(): void {\r\n    if (this.data.loading$) {\r\n      this.data.loading$\r\n        ?.pipe(takeUntil(this.unsubscribeService.subscription()))\r\n        .subscribe((loading) => {\r\n          if (!loading) {\r\n            this.dialogRef.close(this.data.confirmResult ?? true);\r\n          }\r\n        });\r\n    } else {\r\n      this.dialogRef.close(this.data.confirmResult ?? true);\r\n    }\r\n  }\r\n\r\n  closeFalsey(): void {\r\n    this.dialogRef.close(this.data.cancelResult ?? false);\r\n  }\r\n\r\n  closeOnPopover(): void {\r\n    this.dialogRef.close(this.data.popoverResult ?? false);\r\n  }\r\n}\r\n\r\nexport interface EcabsDialogConfirmComponentConfig {\r\n  title?: string;\r\n  titleTemplate?: TemplateRef<NonNullable<unknown>>;\r\n  message?: TemplateRef<NonNullable<unknown>>;\r\n  color?: ThemePalette;\r\n  titleColor?: ThemePalette;\r\n  confirmLabel?: string;\r\n  confirmStyle?: ButtonStyle;\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  confirmResult?: any;\r\n  cancelLabel?: string;\r\n  cancelStyle?: ButtonStyle;\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  cancelResult?: any;\r\n  hideCtaButtons?: boolean;\r\n  hideConfirmButton?: boolean;\r\n  hideCancelButton?: boolean;\r\n  isPopover?: boolean;\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  popoverResult?: any;\r\n  content?: string;\r\n  useFullButtonSize?: boolean;\r\n  loading$?: Observable<boolean>;\r\n  disableConfirm$?: Observable<boolean>;\r\n}\r\n","<div matDialogTitle *ngIf=\"data?.titleTemplate; else title\">\r\n  <div class=\"flex items-center justify-between modal-title\">\r\n    <ng-container *ngTemplateOutlet=\"data?.titleTemplate\"></ng-container>\r\n\r\n    <mat-icon *ngIf=\"!!data?.isPopover\" (click)=\"closeOnPopover()\"\r\n              (keydown.enter)=\"closeOnPopover()\"\r\n              class=\"mat-icon material-icons-outlined justify-end icon--close\">\r\n      close\r\n    </mat-icon>\r\n  </div>\r\n</div>\r\n\r\n\r\n<ng-template #title>\r\n  <div matDialogTitle *ngIf=\"data?.title || !!data?.isPopover\" class=\"flex flex-column\">\r\n    <div *ngIf=\"!!data?.isPopover\" class=\"w-full flex justify-end\">\r\n      <mat-icon (click)=\"closeOnPopover()\"\r\n                (keydown.enter)=\"closeOnPopover()\"\r\n                class=\"mat-icon material-icons-outlined float-right icon--close mb-2\">\r\n        close\r\n      </mat-icon>\r\n    </div>\r\n\r\n    <div class=\"font-semibold heading--xs modal-title {{ data.titleColor }}\" *ngIf=\"data.title\">\r\n      {{ data.title }}\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n\r\n<div mat-dialog-content>\r\n  <div *ngIf=\"data?.content\">{{ data?.content }}</div>\r\n  <ng-container *ngTemplateOutlet=\"data?.message\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"(!!data?.cancelLabel || !!data?.confirmLabel) && !data?.hideCtaButtons\">\r\n  <div mat-dialog-actions\r\n       [ngClass]=\"{'gap-y-4': data?.useFullButtonSize}\"\r\n       class=\"btn__group flex justify-end w-full\">\r\n    <ecabs-buttons *ngIf=\"!!data?.cancelLabel\"\r\n                   [full]=\"data?.useFullButtonSize\"\r\n                   (click)=\"closeFalsey()\"\r\n                   (keydown.enter)=\"closeFalsey()\"\r\n                   [style]=\"data?.cancelStyle || 'stroked'\">\r\n      {{ data?.cancelLabel }}\r\n    </ecabs-buttons>\r\n\r\n    <ecabs-buttons *ngIf=\"!!data?.confirmLabel\"\r\n                   [full]=\"data?.useFullButtonSize\"\r\n                   [color]=\"data?.color || color\"\r\n                   [style]=\"data?.confirmStyle || 'flat'\"\r\n                   [loading]=\"data?.loading$ | async\"\r\n                   (click)=\"closeDialog()\"\r\n                   [disabled]=\"data?.disableConfirm$ | async\"\r\n                   (keydown.enter)=\"closeDialog()\">\r\n      {{ data?.confirmLabel }}\r\n    </ecabs-buttons>\r\n  </div>\r\n</div>\r\n"]}
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-dialog-confirm.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,MAAM,GAIP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAgB,MAAM,0BAA0B,CAAC;AAEzE,OAAO,EAAc,SAAS,EAAE,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAM1E,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;;;;;;;;AAQhE,MAAM,OAAO,2BAA2B;IAKJ;IACzB;IACU;IACA;IACA;IARnB,OAAO,CAAS;IAChB,KAAK,GAAiB,SAAS,CAAC;IAEhC,YACkC,IAAuC,EAChE,SAA0D,EAChD,kBAAsC,EACtC,iBAAyC,EACzC,UAAsB;QAJP,SAAI,GAAJ,IAAI,CAAmC;QAChE,cAAS,GAAT,SAAS,CAAiD;QAChD,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,sBAAiB,GAAjB,iBAAiB,CAAwB;QACzC,eAAU,GAAV,UAAU,CAAY;IACtC,CAAC;IAEJ,YAAY,CAAY;IAExB,QAAQ;QACN,IAAI,CAAC,iBAAiB;aACnB,SAAS,EAAE;aACX,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aACzC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACpB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,EAAE,CAAC;YAC9B,MAAM,EACJ,YAAY,EACZ,WAAW,EACX,iBAAiB,EACjB,gBAAgB,GACjB,GAAG,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;YAEpB,IAAI,IAAI,EAAE;gBACR,IAAI,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,iBAAiB;oBACzC,CAAC,CAAC,YAAY,IAAI,IAAI,EAAE,YAAY;oBACpC,CAAC,CAAC,SAAS,CAAC;gBACd,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,gBAAgB;oBACvC,CAAC,CAAC,WAAW,IAAI,IAAI,EAAE,WAAW;oBAClC,CAAC,CAAC,SAAS,CAAC;aACf;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACT,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,CAAC;IACpC,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACtB,IAAI,CAAC,IAAI,CAAC,QAAQ;gBAChB,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC,CAAC;iBACxD,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;gBACrB,IAAI,CAAC,OAAO,EAAE;oBACZ,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,CAAC;iBACvD;YACH,CAAC,CAAC,CAAC;SACN;aAAM;YACL,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,CAAC;SACvD;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,KAAK,CAAC,CAAC;IACxD,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,KAAK,CAAC,CAAC;IACzD,CAAC;wGA9DU,2BAA2B,kBAK5B,eAAe;4FALd,2BAA2B,+CAF3B,CAAC,kBAAkB,CAAC,0BCvBjC,whFA6DA;;4FDpCa,2BAA2B;kBANvC,SAAS;+BACE,sBAAsB,aAGrB,CAAC,kBAAkB,CAAC;;0BAO5B,MAAM;2BAAC,eAAe","sourcesContent":["import {\r\n  Component,\r\n  DestroyRef,\r\n  Inject,\r\n  OnDestroy,\r\n  OnInit,\r\n  TemplateRef,\r\n} from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { ThemePalette } from '@angular/material/core';\r\nimport { Observable, takeUntil } from 'rxjs';\r\nimport { UnsubscribeService } from '../base/services/unsubscribe.service';\r\nimport { ButtonStyle } from '../base/consts/buttons.consts';\r\nimport {\r\n  EcabsComponentsService,\r\n  Ecabsi18n,\r\n} from '../base/services/ecabs-components.service';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\n\r\n@Component({\r\n  selector: 'ecabs-dialog-confirm',\r\n  templateUrl: './ecabs-dialog-confirm.component.html',\r\n  styleUrls: ['./ecabs-dialog-confirm.component.scss'],\r\n  providers: [UnsubscribeService],\r\n})\r\nexport class EcabsDialogConfirmComponent implements OnInit, OnDestroy {\r\n  message: string;\r\n  color: ThemePalette = 'primary';\r\n\r\n  constructor(\r\n    @Inject(MAT_DIALOG_DATA) public data: EcabsDialogConfirmComponentConfig,\r\n    public dialogRef: MatDialogRef<EcabsDialogConfirmComponentConfig>,\r\n    private readonly unsubscribeService: UnsubscribeService,\r\n    private readonly componentsService: EcabsComponentsService,\r\n    private readonly destroyRef: DestroyRef,\r\n  ) {}\r\n\r\n  translations: Ecabsi18n;\r\n\r\n  ngOnInit(): void {\r\n    this.componentsService\r\n      .getConfig()\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe((config) => {\r\n        const { i18n } = config ?? {};\r\n        const {\r\n          confirmLabel,\r\n          cancelLabel,\r\n          hideConfirmButton,\r\n          hideCancelButton,\r\n        } = this.data ?? {};\r\n\r\n        if (i18n) {\r\n          this.data.confirmLabel = !hideConfirmButton\r\n            ? confirmLabel || i18n?.confirmLabel\r\n            : undefined;\r\n          this.data.cancelLabel = !hideCancelButton\r\n            ? cancelLabel || i18n?.cancelLabel\r\n            : undefined;\r\n        }\r\n      });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.unsubscribeService.destroy();\r\n  }\r\n\r\n  closeDialog(): void {\r\n    if (this.data.loading$) {\r\n      this.data.loading$\r\n        ?.pipe(takeUntil(this.unsubscribeService.subscription()))\r\n        .subscribe((loading) => {\r\n          if (!loading) {\r\n            this.dialogRef.close(this.data.confirmResult ?? true);\r\n          }\r\n        });\r\n    } else {\r\n      this.dialogRef.close(this.data.confirmResult ?? true);\r\n    }\r\n  }\r\n\r\n  closeFalsey(): void {\r\n    this.dialogRef.close(this.data.cancelResult ?? false);\r\n  }\r\n\r\n  closeOnPopover(): void {\r\n    this.dialogRef.close(this.data.popoverResult ?? false);\r\n  }\r\n}\r\n\r\nexport interface EcabsDialogConfirmComponentConfig {\r\n  title?: string;\r\n  titleTemplate?: TemplateRef<NonNullable<unknown>>;\r\n  message?: TemplateRef<NonNullable<unknown>>;\r\n  color?: ThemePalette;\r\n  titleColor?: ThemePalette;\r\n  confirmLabel?: string;\r\n  confirmStyle?: ButtonStyle;\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  confirmResult?: any;\r\n  cancelLabel?: string;\r\n  cancelStyle?: ButtonStyle;\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  cancelResult?: any;\r\n  hideCtaButtons?: boolean;\r\n  hideConfirmButton?: boolean;\r\n  hideCancelButton?: boolean;\r\n  isPopover?: boolean;\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  popoverResult?: any;\r\n  content?: string;\r\n  useFullButtonSize?: boolean;\r\n  splitButtonsWidth?: boolean;\r\n  loading$?: Observable<boolean>;\r\n  disableConfirm$?: Observable<boolean>;\r\n}\r\n","<div matDialogTitle *ngIf=\"data?.titleTemplate; else title\">\r\n  <div class=\"flex items-center justify-between modal-title\">\r\n    <ng-container *ngTemplateOutlet=\"data?.titleTemplate\"></ng-container>\r\n\r\n    <mat-icon *ngIf=\"!!data?.isPopover\" (click)=\"closeOnPopover()\"\r\n              (keydown.enter)=\"closeOnPopover()\"\r\n              class=\"mat-icon material-icons-outlined justify-end icon--close\">\r\n      close\r\n    </mat-icon>\r\n  </div>\r\n</div>\r\n\r\n\r\n<ng-template #title>\r\n  <div matDialogTitle *ngIf=\"data?.title || !!data?.isPopover\" class=\"flex flex-column\">\r\n    <div *ngIf=\"!!data?.isPopover\" class=\"w-full flex justify-end\">\r\n      <mat-icon (click)=\"closeOnPopover()\"\r\n                (keydown.enter)=\"closeOnPopover()\"\r\n                class=\"mat-icon material-icons-outlined float-right icon--close mb-2\">\r\n        close\r\n      </mat-icon>\r\n    </div>\r\n\r\n    <div class=\"font-semibold heading--xs modal-title {{ data.titleColor }}\" *ngIf=\"data.title\">\r\n      {{ data.title }}\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n\r\n<div mat-dialog-content>\r\n  <div *ngIf=\"data?.content\">{{ data?.content }}</div>\r\n  <ng-container *ngTemplateOutlet=\"data?.message\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"(!!data?.cancelLabel || !!data?.confirmLabel) && !data?.hideCtaButtons\">\r\n  <div mat-dialog-actions\r\n       [ngClass]=\"{'gap-y-4': data?.useFullButtonSize || data?.splitButtonsWidth}\"\r\n       class=\"btn__group flex justify-end w-full\">\r\n    <ecabs-buttons *ngIf=\"!!data?.cancelLabel\"\r\n                   [ngClass]=\"{'flex-1': data?.splitButtonsWidth}\"\r\n                   [full]=\"data?.useFullButtonSize\"\r\n                   (click)=\"closeFalsey()\"\r\n                   (keydown.enter)=\"closeFalsey()\"\r\n                   [style]=\"data?.cancelStyle || 'stroked'\">\r\n      {{ data?.cancelLabel }}\r\n    </ecabs-buttons>\r\n\r\n    <ecabs-buttons *ngIf=\"!!data?.confirmLabel\"\r\n                   [ngClass]=\"{'flex-1':  data?.splitButtonsWidth}\"\r\n                   [full]=\"data?.useFullButtonSize\"\r\n                   [color]=\"data?.color || color\"\r\n                   [style]=\"data?.confirmStyle || 'flat'\"\r\n                   [loading]=\"data?.loading$ | async\"\r\n                   (click)=\"closeDialog()\"\r\n                   [disabled]=\"data?.disableConfirm$ | async\"\r\n                   (keydown.enter)=\"closeDialog()\">\r\n      {{ data?.confirmLabel }}\r\n    </ecabs-buttons>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR, NgControl, } from '@angular/forms';
|
|
3
|
+
import EcabsElementBaseComponent from '../base/element-base';
|
|
4
|
+
import { BehaviorSubject, combineLatest, debounceTime, map, Observable, of, } from 'rxjs';
|
|
5
|
+
import { switchMap } from 'rxjs/operators';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
import * as i2 from "../base/element-wrapper/element-wrapper.component";
|
|
9
|
+
import * as i3 from "@angular/forms";
|
|
10
|
+
import * as i4 from "@angular/material/icon";
|
|
11
|
+
import * as i5 from "@angular/cdk/overlay";
|
|
12
|
+
import * as i6 from "../base/pipes/separator-append.pipe";
|
|
13
|
+
export class EcabsPlaceAutocompleteV2Component extends EcabsElementBaseComponent {
|
|
14
|
+
ngZone;
|
|
15
|
+
injector;
|
|
16
|
+
matCustomInput;
|
|
17
|
+
showDeleteItem = false;
|
|
18
|
+
waypointsHistory = [];
|
|
19
|
+
showSuffix = false;
|
|
20
|
+
countryCode = 'MT';
|
|
21
|
+
googleLoaded;
|
|
22
|
+
waypointType;
|
|
23
|
+
placeResult = new EventEmitter();
|
|
24
|
+
deleteItem = new EventEmitter();
|
|
25
|
+
queryChanged = new EventEmitter();
|
|
26
|
+
isFocused$ = new BehaviorSubject(false);
|
|
27
|
+
value$ = new BehaviorSubject('');
|
|
28
|
+
waypointSuggestions$;
|
|
29
|
+
selectedIndex = -1;
|
|
30
|
+
displayedSuggestions = [];
|
|
31
|
+
val;
|
|
32
|
+
listener;
|
|
33
|
+
mapAutocompleteService;
|
|
34
|
+
placesService;
|
|
35
|
+
sessionToken;
|
|
36
|
+
get value() {
|
|
37
|
+
return this.val;
|
|
38
|
+
}
|
|
39
|
+
set value(val) {
|
|
40
|
+
if (this.val !== val) {
|
|
41
|
+
this.val = val;
|
|
42
|
+
this.value$.next(val);
|
|
43
|
+
this.onChange(val);
|
|
44
|
+
this.onTouch(val);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
constructor(ngZone, injector) {
|
|
48
|
+
super();
|
|
49
|
+
this.ngZone = ngZone;
|
|
50
|
+
this.injector = injector;
|
|
51
|
+
}
|
|
52
|
+
ngOnChanges(changes) {
|
|
53
|
+
const { googleLoaded } = changes ?? {};
|
|
54
|
+
if (googleLoaded?.currentValue) {
|
|
55
|
+
this.initGoogle();
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
ngAfterViewInit() {
|
|
59
|
+
const ngControl = this.injector.get(NgControl, null);
|
|
60
|
+
if (ngControl) {
|
|
61
|
+
this.control = ngControl.control;
|
|
62
|
+
}
|
|
63
|
+
this.waypointSuggestions$ = combineLatest([
|
|
64
|
+
this.isFocused$,
|
|
65
|
+
this.value$,
|
|
66
|
+
]).pipe(debounceTime(500), switchMap(([isFocused, value]) => {
|
|
67
|
+
if (!isFocused) {
|
|
68
|
+
return of([]);
|
|
69
|
+
}
|
|
70
|
+
if (!value) {
|
|
71
|
+
return of(this.waypointsHistory);
|
|
72
|
+
}
|
|
73
|
+
return this.getWaypointResults(value);
|
|
74
|
+
}), map((results) => {
|
|
75
|
+
this.displayedSuggestions = results;
|
|
76
|
+
this.selectedIndex = results?.length ? 0 : -1;
|
|
77
|
+
return results;
|
|
78
|
+
}));
|
|
79
|
+
}
|
|
80
|
+
getWaypointResults(query) {
|
|
81
|
+
this.queryChanged.emit({ waypoint_type: this.waypointType, query });
|
|
82
|
+
return combineLatest([
|
|
83
|
+
of(this.waypointsHistory),
|
|
84
|
+
this.getPlacesResults(query),
|
|
85
|
+
]).pipe(map(([history, google]) => {
|
|
86
|
+
const historyItems = history ?? [], googleItems = google ?? [];
|
|
87
|
+
return [...historyItems, ...googleItems];
|
|
88
|
+
}));
|
|
89
|
+
}
|
|
90
|
+
getPlacesResults(query) {
|
|
91
|
+
return new Observable((observer) => {
|
|
92
|
+
this.mapAutocompleteService.getPlacePredictions({
|
|
93
|
+
input: query,
|
|
94
|
+
componentRestrictions: { country: this.countryCode },
|
|
95
|
+
sessionToken: this.sessionToken,
|
|
96
|
+
}, (predictions) => {
|
|
97
|
+
observer.next((predictions ?? []).map((prediction) => {
|
|
98
|
+
return {
|
|
99
|
+
additional_info: prediction.description,
|
|
100
|
+
place_id: prediction.place_id,
|
|
101
|
+
source: 'google',
|
|
102
|
+
prediction_term: prediction.terms,
|
|
103
|
+
};
|
|
104
|
+
}));
|
|
105
|
+
observer.complete();
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
onSelectSuggestion(suggestion) {
|
|
110
|
+
const { additional_info, place_id } = suggestion ?? {};
|
|
111
|
+
this.value = additional_info;
|
|
112
|
+
this.placesService.getDetails({
|
|
113
|
+
placeId: place_id,
|
|
114
|
+
sessionToken: this.sessionToken,
|
|
115
|
+
fields: ['address_components', 'geometry.location'],
|
|
116
|
+
}, (place, status) => {
|
|
117
|
+
if (status === google.maps.places.PlacesServiceStatus.OK && place) {
|
|
118
|
+
this.ngZone.run(() => {
|
|
119
|
+
this.placeResult.emit({
|
|
120
|
+
place,
|
|
121
|
+
text: additional_info,
|
|
122
|
+
});
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
this.resetSessionToken();
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
onKeyDown(event) {
|
|
129
|
+
if (!this.displayedSuggestions?.length) {
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
switch (event.key) {
|
|
133
|
+
case 'ArrowDown':
|
|
134
|
+
event.preventDefault();
|
|
135
|
+
this.selectedIndex =
|
|
136
|
+
(this.selectedIndex + 1) % this.displayedSuggestions.length;
|
|
137
|
+
break;
|
|
138
|
+
case 'ArrowUp':
|
|
139
|
+
event.preventDefault();
|
|
140
|
+
this.selectedIndex =
|
|
141
|
+
(this.selectedIndex - 1 + this.displayedSuggestions.length) %
|
|
142
|
+
this.displayedSuggestions.length;
|
|
143
|
+
break;
|
|
144
|
+
case 'Enter':
|
|
145
|
+
event.preventDefault();
|
|
146
|
+
if (this.selectedIndex >= 0) {
|
|
147
|
+
this.onSelectSuggestion(this.displayedSuggestions[this.selectedIndex]);
|
|
148
|
+
}
|
|
149
|
+
break;
|
|
150
|
+
case 'Escape':
|
|
151
|
+
this.isFocused$.next(false);
|
|
152
|
+
this.selectedIndex = -1;
|
|
153
|
+
break;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
ngOnDestroy() {
|
|
157
|
+
if (this.listener) {
|
|
158
|
+
this.listener.remove();
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
onChange = () => { };
|
|
162
|
+
onTouch = () => { };
|
|
163
|
+
onBlur() {
|
|
164
|
+
this.isFocused$.next(false);
|
|
165
|
+
this.onTouch;
|
|
166
|
+
}
|
|
167
|
+
onFocus() {
|
|
168
|
+
this.isFocused$.next(true);
|
|
169
|
+
if (!this.value) {
|
|
170
|
+
this.resetSessionToken();
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
writeValue(value) {
|
|
174
|
+
this.value = value;
|
|
175
|
+
}
|
|
176
|
+
registerOnChange(fn) {
|
|
177
|
+
this.onChange = fn;
|
|
178
|
+
}
|
|
179
|
+
registerOnTouched(fn) {
|
|
180
|
+
this.onTouch = fn;
|
|
181
|
+
}
|
|
182
|
+
onDeleteItem() {
|
|
183
|
+
this.deleteItem.emit();
|
|
184
|
+
}
|
|
185
|
+
onClean() {
|
|
186
|
+
this.value = '';
|
|
187
|
+
this.onTouch();
|
|
188
|
+
}
|
|
189
|
+
initGoogle() {
|
|
190
|
+
this.mapAutocompleteService = new google.maps.places.AutocompleteService();
|
|
191
|
+
this.placesService = new google.maps.places.PlacesService(document.createElement('div'));
|
|
192
|
+
this.resetSessionToken();
|
|
193
|
+
}
|
|
194
|
+
resetSessionToken() {
|
|
195
|
+
this.sessionToken = new google.maps.places.AutocompleteSessionToken();
|
|
196
|
+
}
|
|
197
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPlaceAutocompleteV2Component, deps: [{ token: i0.NgZone }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
198
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsPlaceAutocompleteV2Component, selector: "ecabs-place-autocomplete-v2", inputs: { showDeleteItem: "showDeleteItem", waypointsHistory: "waypointsHistory", showSuffix: "showSuffix", countryCode: "countryCode", googleLoaded: "googleLoaded", waypointType: "waypointType" }, outputs: { placeResult: "placeResult", deleteItem: "deleteItem", queryChanged: "queryChanged" }, providers: [
|
|
199
|
+
{
|
|
200
|
+
provide: NG_VALUE_ACCESSOR,
|
|
201
|
+
useExisting: EcabsPlaceAutocompleteV2Component,
|
|
202
|
+
multi: true,
|
|
203
|
+
},
|
|
204
|
+
], viewQueries: [{ propertyName: "matCustomInput", first: true, predicate: ["matCustomAutocompleteInput"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <div class=\"autocomplete-ui w-full\">\r\n <section class=\"form-field__input--wrapper w-full\">\r\n <input #matCustomAutocompleteInput\r\n cdkOverlayOrigin\r\n #trigger=\"cdkOverlayOrigin\"\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 (focus)=\"onFocus()\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (blur)=\"onBlur()\"\r\n />\r\n <div class=\"form-field__input--suffix\" *ngIf=\"showSuffix\">\r\n <mat-icon *ngIf=\"showDeleteItem\"\r\n class=\"suffix cursor-pointer delete-button\"\r\n (click)=\"onDeleteItem()\">\r\n delete\r\n </mat-icon>\r\n <mat-icon class=\"suffix cursor-pointer\" *ngIf=\"!showDeleteItem && value\" (click)=\"onClean()\">close</mat-icon>\r\n </div>\r\n </section>\r\n <!-- Custom dropdown -->\r\n <ng-template cdkConnectedOverlay\r\n [cdkConnectedOverlayWidth]=\"trigger.elementRef.nativeElement.offsetWidth\"\r\n [cdkConnectedOverlayFlexibleDimensions]=\"false\"\r\n [cdkConnectedOverlayOrigin]=\"trigger\"\r\n [cdkConnectedOverlayOpen]=\"isFocused$ | async\">\r\n <ul class=\"autocomplete-ui__container\">\r\n <li *ngFor=\"let suggestion of waypointSuggestions$ | async | slice:0:10; let i = index\"\r\n class=\"autocomplete-ui--item flex items-center justify-between hover:bg-gray-100\"\r\n [class.active]=\"i === selectedIndex\"\r\n (mousedown)=\"onSelectSuggestion(suggestion)\">\r\n <ng-container *ngIf=\"suggestion?.source === 'history'; else purePlaceResultTpl\">\r\n <div class=\"w-full truncate\">\r\n {{ suggestion?.additional_info }}\r\n </div>\r\n <mat-icon *ngIf=\"suggestion?.source === 'history'\"\r\n class=\"w-5 h-5 text-xl text-gray-400 !hover:text-gray-400\">\r\n history\r\n </mat-icon>\r\n </ng-container>\r\n\r\n <ng-template #purePlaceResultTpl>\r\n <ul class=\"w-full flex items-center gap-x-1 leading-0 overflow-hidden whitespace-nowrap\">\r\n <li>\r\n {{ suggestion?.prediction_term[0]?.value }}\r\n </li>\r\n <li *ngIf=\"suggestion?.prediction_term[1]?.value\"\r\n class=\"text-xs text-gray-600 truncate\">\r\n {{ suggestion?.prediction_term[1]?.value | separatorAppend: suggestion?.prediction_term[2]?.value }}\r\n </li>\r\n <li *ngIf=\"suggestion?.prediction_term[2]?.value\"\r\n class=\"text-xs text-gray-600 font-semibold truncate\">\r\n {{ suggestion?.prediction_term[2]?.value }}\r\n </li>\r\n </ul>\r\n </ng-template>\r\n </li>\r\n </ul>\r\n </ng-template>\r\n </div>\r\n</ecabs-element-wrapper>\r\n", styles: ["mat-form-field{margin-bottom:0!important}.delete-button{color:var(--color-error)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.EcabsElementWrapperComponent, selector: "ecabs-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: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "directive", type: i5.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.SlicePipe, name: "slice" }, { kind: "pipe", type: i6.SeparatorAppendPipe, name: "separatorAppend" }] });
|
|
205
|
+
}
|
|
206
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPlaceAutocompleteV2Component, decorators: [{
|
|
207
|
+
type: Component,
|
|
208
|
+
args: [{ selector: 'ecabs-place-autocomplete-v2', providers: [
|
|
209
|
+
{
|
|
210
|
+
provide: NG_VALUE_ACCESSOR,
|
|
211
|
+
useExisting: EcabsPlaceAutocompleteV2Component,
|
|
212
|
+
multi: true,
|
|
213
|
+
},
|
|
214
|
+
], template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <div class=\"autocomplete-ui w-full\">\r\n <section class=\"form-field__input--wrapper w-full\">\r\n <input #matCustomAutocompleteInput\r\n cdkOverlayOrigin\r\n #trigger=\"cdkOverlayOrigin\"\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 (focus)=\"onFocus()\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (blur)=\"onBlur()\"\r\n />\r\n <div class=\"form-field__input--suffix\" *ngIf=\"showSuffix\">\r\n <mat-icon *ngIf=\"showDeleteItem\"\r\n class=\"suffix cursor-pointer delete-button\"\r\n (click)=\"onDeleteItem()\">\r\n delete\r\n </mat-icon>\r\n <mat-icon class=\"suffix cursor-pointer\" *ngIf=\"!showDeleteItem && value\" (click)=\"onClean()\">close</mat-icon>\r\n </div>\r\n </section>\r\n <!-- Custom dropdown -->\r\n <ng-template cdkConnectedOverlay\r\n [cdkConnectedOverlayWidth]=\"trigger.elementRef.nativeElement.offsetWidth\"\r\n [cdkConnectedOverlayFlexibleDimensions]=\"false\"\r\n [cdkConnectedOverlayOrigin]=\"trigger\"\r\n [cdkConnectedOverlayOpen]=\"isFocused$ | async\">\r\n <ul class=\"autocomplete-ui__container\">\r\n <li *ngFor=\"let suggestion of waypointSuggestions$ | async | slice:0:10; let i = index\"\r\n class=\"autocomplete-ui--item flex items-center justify-between hover:bg-gray-100\"\r\n [class.active]=\"i === selectedIndex\"\r\n (mousedown)=\"onSelectSuggestion(suggestion)\">\r\n <ng-container *ngIf=\"suggestion?.source === 'history'; else purePlaceResultTpl\">\r\n <div class=\"w-full truncate\">\r\n {{ suggestion?.additional_info }}\r\n </div>\r\n <mat-icon *ngIf=\"suggestion?.source === 'history'\"\r\n class=\"w-5 h-5 text-xl text-gray-400 !hover:text-gray-400\">\r\n history\r\n </mat-icon>\r\n </ng-container>\r\n\r\n <ng-template #purePlaceResultTpl>\r\n <ul class=\"w-full flex items-center gap-x-1 leading-0 overflow-hidden whitespace-nowrap\">\r\n <li>\r\n {{ suggestion?.prediction_term[0]?.value }}\r\n </li>\r\n <li *ngIf=\"suggestion?.prediction_term[1]?.value\"\r\n class=\"text-xs text-gray-600 truncate\">\r\n {{ suggestion?.prediction_term[1]?.value | separatorAppend: suggestion?.prediction_term[2]?.value }}\r\n </li>\r\n <li *ngIf=\"suggestion?.prediction_term[2]?.value\"\r\n class=\"text-xs text-gray-600 font-semibold truncate\">\r\n {{ suggestion?.prediction_term[2]?.value }}\r\n </li>\r\n </ul>\r\n </ng-template>\r\n </li>\r\n </ul>\r\n </ng-template>\r\n </div>\r\n</ecabs-element-wrapper>\r\n", styles: ["mat-form-field{margin-bottom:0!important}.delete-button{color:var(--color-error)}\n"] }]
|
|
215
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.Injector }]; }, propDecorators: { matCustomInput: [{
|
|
216
|
+
type: ViewChild,
|
|
217
|
+
args: ['matCustomAutocompleteInput', { static: false }]
|
|
218
|
+
}], showDeleteItem: [{
|
|
219
|
+
type: Input
|
|
220
|
+
}], waypointsHistory: [{
|
|
221
|
+
type: Input
|
|
222
|
+
}], showSuffix: [{
|
|
223
|
+
type: Input
|
|
224
|
+
}], countryCode: [{
|
|
225
|
+
type: Input
|
|
226
|
+
}], googleLoaded: [{
|
|
227
|
+
type: Input
|
|
228
|
+
}], waypointType: [{
|
|
229
|
+
type: Input
|
|
230
|
+
}], placeResult: [{
|
|
231
|
+
type: Output
|
|
232
|
+
}], deleteItem: [{
|
|
233
|
+
type: Output
|
|
234
|
+
}], queryChanged: [{
|
|
235
|
+
type: Output
|
|
236
|
+
}] } });
|
|
237
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-place-autocomplete-v2.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-place-autocomplete-v2/ecabs-place-autocomplete-v2.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-place-autocomplete-v2/ecabs-place-autocomplete-v2.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  NgZone,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n} from '@angular/forms';\r\nimport EcabsElementBaseComponent from '../base/element-base';\r\nimport { WaypointTypeEnum } from '../base/consts/waypoint.consts';\r\nimport {\r\n  GooglePlaceResult,\r\n  WaypointQueryChange,\r\n  WaypointSuggestion,\r\n} from '../base/models/waypoint.models';\r\nimport {\r\n  BehaviorSubject,\r\n  combineLatest,\r\n  debounceTime,\r\n  map,\r\n  Observable,\r\n  of,\r\n} from 'rxjs';\r\nimport { switchMap } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: 'ecabs-place-autocomplete-v2',\r\n  templateUrl: './ecabs-place-autocomplete-v2.component.html',\r\n  styleUrls: ['./ecabs-place-autocomplete-v2.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsPlaceAutocompleteV2Component,\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class EcabsPlaceAutocompleteV2Component\r\n  extends EcabsElementBaseComponent\r\n  implements OnDestroy, OnChanges, AfterViewInit, ControlValueAccessor\r\n{\r\n  @ViewChild('matCustomAutocompleteInput', { static: false })\r\n  matCustomInput: ElementRef;\r\n\r\n  @Input()\r\n  showDeleteItem = false;\r\n\r\n  @Input()\r\n  waypointsHistory: WaypointSuggestion[] = [];\r\n\r\n  @Input()\r\n  showSuffix = false;\r\n\r\n  @Input()\r\n  countryCode = 'MT';\r\n\r\n  @Input()\r\n  googleLoaded: boolean;\r\n\r\n  @Input()\r\n  waypointType: WaypointTypeEnum;\r\n\r\n  @Output()\r\n  readonly placeResult: EventEmitter<GooglePlaceResult> = new EventEmitter();\r\n\r\n  @Output()\r\n  readonly deleteItem = new EventEmitter();\r\n\r\n  @Output()\r\n  readonly queryChanged = new EventEmitter<WaypointQueryChange>();\r\n\r\n  isFocused$ = new BehaviorSubject<boolean>(false);\r\n  value$ = new BehaviorSubject<string>('');\r\n  waypointSuggestions$: Observable<WaypointSuggestion[]>;\r\n\r\n  selectedIndex = -1;\r\n  displayedSuggestions: WaypointSuggestion[] = [];\r\n\r\n  val!: string;\r\n  listener: google.maps.MapsEventListener;\r\n\r\n  private mapAutocompleteService: google.maps.places.AutocompleteService;\r\n  private placesService: google.maps.places.PlacesService;\r\n  private sessionToken: google.maps.places.AutocompleteSessionToken;\r\n\r\n  get value(): string {\r\n    return this.val;\r\n  }\r\n\r\n  set value(val: string) {\r\n    if (this.val !== val) {\r\n      this.val = val;\r\n      this.value$.next(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 injector: Injector,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { googleLoaded } = changes ?? {};\r\n\r\n    if (googleLoaded?.currentValue) {\r\n      this.initGoogle();\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get(\r\n      NgControl,\r\n      null,\r\n    ) as NgControl;\r\n\r\n    if (ngControl) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n    }\r\n\r\n    this.waypointSuggestions$ = combineLatest([\r\n      this.isFocused$,\r\n      this.value$,\r\n    ]).pipe(\r\n      debounceTime(500),\r\n      switchMap(([isFocused, value]) => {\r\n        if (!isFocused) {\r\n          return of([] as WaypointSuggestion[]);\r\n        }\r\n\r\n        if (!value) {\r\n          return of(this.waypointsHistory);\r\n        }\r\n\r\n        return this.getWaypointResults(value);\r\n      }),\r\n      map((results) => {\r\n        this.displayedSuggestions = results;\r\n        this.selectedIndex = results?.length ? 0 : -1;\r\n\r\n        return results;\r\n      }),\r\n    );\r\n  }\r\n\r\n  private getWaypointResults(query: string): Observable<WaypointSuggestion[]> {\r\n    this.queryChanged.emit({ waypoint_type: this.waypointType, query });\r\n\r\n    return combineLatest([\r\n      of(this.waypointsHistory),\r\n      this.getPlacesResults(query),\r\n    ]).pipe(\r\n      map(([history, google]) => {\r\n        const historyItems = history ?? [],\r\n          googleItems = google ?? [];\r\n\r\n        return [...historyItems, ...googleItems];\r\n      }),\r\n    );\r\n  }\r\n\r\n  private getPlacesResults(query: string): Observable<WaypointSuggestion[]> {\r\n    return new Observable((observer) => {\r\n      this.mapAutocompleteService.getPlacePredictions(\r\n        {\r\n          input: query,\r\n          componentRestrictions: { country: this.countryCode },\r\n          sessionToken: this.sessionToken,\r\n        },\r\n        (predictions) => {\r\n          observer.next(\r\n            (predictions ?? []).map((prediction) => {\r\n              return {\r\n                additional_info: prediction.description,\r\n                place_id: prediction.place_id!,\r\n                source: 'google',\r\n                prediction_term: prediction.terms,\r\n              };\r\n            }),\r\n          );\r\n          observer.complete();\r\n        },\r\n      );\r\n    });\r\n  }\r\n\r\n  onSelectSuggestion(suggestion: WaypointSuggestion): void {\r\n    const { additional_info, place_id } = suggestion ?? {};\r\n\r\n    this.value = additional_info;\r\n    this.placesService.getDetails(\r\n      {\r\n        placeId: place_id!,\r\n        sessionToken: this.sessionToken,\r\n        fields: ['address_components', 'geometry.location'],\r\n      },\r\n      (place, status) => {\r\n        if (status === google.maps.places.PlacesServiceStatus.OK && place) {\r\n          this.ngZone.run(() => {\r\n            this.placeResult.emit({\r\n              place,\r\n              text: additional_info,\r\n            });\r\n          });\r\n        }\r\n\r\n        this.resetSessionToken();\r\n      },\r\n    );\r\n  }\r\n\r\n  onKeyDown(event: KeyboardEvent): void {\r\n    if (!this.displayedSuggestions?.length) {\r\n      return;\r\n    }\r\n\r\n    switch (event.key) {\r\n      case 'ArrowDown':\r\n        event.preventDefault();\r\n        this.selectedIndex =\r\n          (this.selectedIndex + 1) % this.displayedSuggestions.length;\r\n        break;\r\n\r\n      case 'ArrowUp':\r\n        event.preventDefault();\r\n        this.selectedIndex =\r\n          (this.selectedIndex - 1 + this.displayedSuggestions.length) %\r\n          this.displayedSuggestions.length;\r\n        break;\r\n\r\n      case 'Enter':\r\n        event.preventDefault();\r\n\r\n        if (this.selectedIndex >= 0) {\r\n          this.onSelectSuggestion(\r\n            this.displayedSuggestions[this.selectedIndex],\r\n          );\r\n        }\r\n        break;\r\n\r\n      case 'Escape':\r\n        this.isFocused$.next(false);\r\n        this.selectedIndex = -1;\r\n        break;\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.listener) {\r\n      this.listener.remove();\r\n    }\r\n  }\r\n\r\n  onChange: any = () => {};\r\n\r\n  onTouch: any = () => {};\r\n\r\n  onBlur(): void {\r\n    this.isFocused$.next(false);\r\n    this.onTouch;\r\n  }\r\n\r\n  onFocus(): void {\r\n    this.isFocused$.next(true);\r\n\r\n    if (!this.value) {\r\n      this.resetSessionToken();\r\n    }\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  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    this.mapAutocompleteService = new google.maps.places.AutocompleteService();\r\n\r\n    this.placesService = new google.maps.places.PlacesService(\r\n      document.createElement('div'),\r\n    );\r\n\r\n    this.resetSessionToken();\r\n  }\r\n\r\n  private resetSessionToken(): void {\r\n    this.sessionToken = new google.maps.places.AutocompleteSessionToken();\r\n  }\r\n}\r\n","<ecabs-element-wrapper [data]=\"getData()\">\r\n  <div class=\"autocomplete-ui w-full\">\r\n    <section class=\"form-field__input--wrapper w-full\">\r\n      <input #matCustomAutocompleteInput\r\n             cdkOverlayOrigin\r\n             #trigger=\"cdkOverlayOrigin\"\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             (focus)=\"onFocus()\"\r\n             (keydown)=\"onKeyDown($event)\"\r\n             (blur)=\"onBlur()\"\r\n      />\r\n      <div class=\"form-field__input--suffix\" *ngIf=\"showSuffix\">\r\n        <mat-icon *ngIf=\"showDeleteItem\"\r\n                  class=\"suffix cursor-pointer delete-button\"\r\n                  (click)=\"onDeleteItem()\">\r\n          delete\r\n        </mat-icon>\r\n        <mat-icon class=\"suffix cursor-pointer\" *ngIf=\"!showDeleteItem && value\" (click)=\"onClean()\">close</mat-icon>\r\n      </div>\r\n    </section>\r\n    <!-- Custom dropdown -->\r\n    <ng-template cdkConnectedOverlay\r\n                 [cdkConnectedOverlayWidth]=\"trigger.elementRef.nativeElement.offsetWidth\"\r\n                 [cdkConnectedOverlayFlexibleDimensions]=\"false\"\r\n                 [cdkConnectedOverlayOrigin]=\"trigger\"\r\n                 [cdkConnectedOverlayOpen]=\"isFocused$ | async\">\r\n      <ul class=\"autocomplete-ui__container\">\r\n        <li *ngFor=\"let suggestion of waypointSuggestions$ | async | slice:0:10; let i = index\"\r\n            class=\"autocomplete-ui--item flex items-center justify-between hover:bg-gray-100\"\r\n            [class.active]=\"i === selectedIndex\"\r\n            (mousedown)=\"onSelectSuggestion(suggestion)\">\r\n          <ng-container *ngIf=\"suggestion?.source === 'history'; else purePlaceResultTpl\">\r\n            <div class=\"w-full truncate\">\r\n              {{ suggestion?.additional_info }}\r\n            </div>\r\n            <mat-icon *ngIf=\"suggestion?.source === 'history'\"\r\n                      class=\"w-5 h-5 text-xl text-gray-400 !hover:text-gray-400\">\r\n              history\r\n            </mat-icon>\r\n          </ng-container>\r\n\r\n          <ng-template #purePlaceResultTpl>\r\n            <ul class=\"w-full flex items-center gap-x-1 leading-0 overflow-hidden whitespace-nowrap\">\r\n              <li>\r\n                {{ suggestion?.prediction_term[0]?.value }}\r\n              </li>\r\n              <li *ngIf=\"suggestion?.prediction_term[1]?.value\"\r\n                  class=\"text-xs text-gray-600 truncate\">\r\n                {{ suggestion?.prediction_term[1]?.value | separatorAppend: suggestion?.prediction_term[2]?.value }}\r\n              </li>\r\n              <li *ngIf=\"suggestion?.prediction_term[2]?.value\"\r\n                  class=\"text-xs text-gray-600 font-semibold truncate\">\r\n                {{ suggestion?.prediction_term[2]?.value }}\r\n              </li>\r\n            </ul>\r\n          </ng-template>\r\n        </li>\r\n      </ul>\r\n    </ng-template>\r\n  </div>\r\n</ecabs-element-wrapper>\r\n"]}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { EcabsPlaceAutocompleteV2Component } from './ecabs-place-autocomplete-v2.component';
|
|
4
|
+
import { FormsModule } from '@angular/forms';
|
|
5
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
6
|
+
import { ElementWrapperModule } from '../base/element-wrapper/element-wrapper.module';
|
|
7
|
+
import { SeparatorAppendPipe } from '../base/pipes/separator-append.pipe';
|
|
8
|
+
import { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
export class EcabsPlaceAutocompleteV2Module {
|
|
11
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPlaceAutocompleteV2Module, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
12
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: EcabsPlaceAutocompleteV2Module, declarations: [EcabsPlaceAutocompleteV2Component], imports: [CommonModule,
|
|
13
|
+
ElementWrapperModule,
|
|
14
|
+
FormsModule,
|
|
15
|
+
MatIconModule,
|
|
16
|
+
SeparatorAppendPipe,
|
|
17
|
+
CdkOverlayOrigin,
|
|
18
|
+
CdkConnectedOverlay], exports: [EcabsPlaceAutocompleteV2Component] });
|
|
19
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPlaceAutocompleteV2Module, imports: [CommonModule,
|
|
20
|
+
ElementWrapperModule,
|
|
21
|
+
FormsModule,
|
|
22
|
+
MatIconModule] });
|
|
23
|
+
}
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsPlaceAutocompleteV2Module, decorators: [{
|
|
25
|
+
type: NgModule,
|
|
26
|
+
args: [{
|
|
27
|
+
declarations: [EcabsPlaceAutocompleteV2Component],
|
|
28
|
+
imports: [
|
|
29
|
+
CommonModule,
|
|
30
|
+
ElementWrapperModule,
|
|
31
|
+
FormsModule,
|
|
32
|
+
MatIconModule,
|
|
33
|
+
SeparatorAppendPipe,
|
|
34
|
+
CdkOverlayOrigin,
|
|
35
|
+
CdkConnectedOverlay,
|
|
36
|
+
],
|
|
37
|
+
exports: [EcabsPlaceAutocompleteV2Component],
|
|
38
|
+
}]
|
|
39
|
+
}] });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtcGxhY2UtYXV0b2NvbXBsZXRlLXYyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1wbGFjZS1hdXRvY29tcGxldGUtdjIvZWNhYnMtcGxhY2UtYXV0b2NvbXBsZXRlLXYyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUM1RixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDOztBQWU3RSxNQUFNLE9BQU8sOEJBQThCO3dHQUE5Qiw4QkFBOEI7eUdBQTlCLDhCQUE4QixpQkFaMUIsaUNBQWlDLGFBRTlDLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsV0FBVztZQUNYLGFBQWE7WUFDYixtQkFBbUI7WUFDbkIsZ0JBQWdCO1lBQ2hCLG1CQUFtQixhQUVYLGlDQUFpQzt5R0FFaEMsOEJBQThCLFlBVnZDLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsV0FBVztZQUNYLGFBQWE7OzRGQU9KLDhCQUE4QjtrQkFiMUMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxpQ0FBaUMsQ0FBQztvQkFDakQsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osb0JBQW9CO3dCQUNwQixXQUFXO3dCQUNYLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixnQkFBZ0I7d0JBQ2hCLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsaUNBQWlDLENBQUM7aUJBQzdDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRWNhYnNQbGFjZUF1dG9jb21wbGV0ZVYyQ29tcG9uZW50IH0gZnJvbSAnLi9lY2Ficy1wbGFjZS1hdXRvY29tcGxldGUtdjIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuaW1wb3J0IHsgRWxlbWVudFdyYXBwZXJNb2R1bGUgfSBmcm9tICcuLi9iYXNlL2VsZW1lbnQtd3JhcHBlci9lbGVtZW50LXdyYXBwZXIubW9kdWxlJztcclxuaW1wb3J0IHsgU2VwYXJhdG9yQXBwZW5kUGlwZSB9IGZyb20gJy4uL2Jhc2UvcGlwZXMvc2VwYXJhdG9yLWFwcGVuZC5waXBlJztcclxuaW1wb3J0IHsgQ2RrQ29ubmVjdGVkT3ZlcmxheSwgQ2RrT3ZlcmxheU9yaWdpbiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbRWNhYnNQbGFjZUF1dG9jb21wbGV0ZVYyQ29tcG9uZW50XSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBFbGVtZW50V3JhcHBlck1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIFNlcGFyYXRvckFwcGVuZFBpcGUsXHJcbiAgICBDZGtPdmVybGF5T3JpZ2luLFxyXG4gICAgQ2RrQ29ubmVjdGVkT3ZlcmxheSxcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtFY2Fic1BsYWNlQXV0b2NvbXBsZXRlVjJDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRWNhYnNQbGFjZUF1dG9jb21wbGV0ZVYyTW9kdWxlIHt9XHJcbiJdfQ==
|