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 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==