@flower-city-online/itinerary-lib 0.0.50 → 0.0.52

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.
Files changed (61) hide show
  1. package/esm2022/lib/itinerary-app/_services/bottom-navigation.service.mjs +8 -8
  2. package/esm2022/lib/itinerary-app/_services/navigation-helper.service.mjs +128 -0
  3. package/esm2022/lib/itinerary-app/modules/archives/pages/main-archives/main-archives.component.mjs +20 -17
  4. package/esm2022/lib/itinerary-app/modules/itineraries/components/app-sidebar-desktop/app-sidebar-desktop.component.mjs +3 -3
  5. package/esm2022/lib/itinerary-app/modules/itineraries/itineraries.component.mjs +18 -15
  6. package/esm2022/lib/itinerary-app/modules/itineraries/pages/branched-itineraries/branched-itineraries.component.mjs +23 -45
  7. package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/builder.component.mjs +23 -23
  8. package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary/create-itinerary.component.mjs +21 -20
  9. package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-draw-mode/create-itinerary-draw-mode.component.mjs +23 -26
  10. package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/created-itinerary/created-itinerary.component.mjs +17 -15
  11. package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/created-itinerary-preview/created-itinerary-preview.component.mjs +12 -9
  12. package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/location-picker/location-picker.component.mjs +19 -18
  13. package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/select-itinerary-event/select-itinerary-event.component.mjs +16 -14
  14. package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-location/suggested-events-location.component.mjs +17 -15
  15. package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-route-radius/suggested-events-route-radius.component.mjs +13 -13
  16. package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-route-type/suggested-events-route-type.component.mjs +16 -14
  17. package/esm2022/lib/itinerary-app/modules/itineraries/pages/comments/comment-comparison/comment-comparison.component.mjs +13 -10
  18. package/esm2022/lib/itinerary-app/modules/itineraries/pages/comments/comment-search/comment-search.component.mjs +13 -10
  19. package/esm2022/lib/itinerary-app/modules/itineraries/pages/comments/comments-page.component.mjs +15 -12
  20. package/esm2022/lib/itinerary-app/modules/itineraries/pages/explore/explore.component.mjs +28 -43
  21. package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/components/details/details.component.mjs +28 -36
  22. package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/components/summary/summary.component.mjs +27 -31
  23. package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/itinerary-detail.component.mjs +20 -16
  24. package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-members/user-list/user-list.component.mjs +16 -16
  25. package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-upvote-users/itinerary-upvote-users.component.mjs +17 -14
  26. package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-users/itinerary-users.component.mjs +14 -9
  27. package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-watching-users/itinerary-watching-users.component.mjs +14 -9
  28. package/esm2022/lib/itinerary-app/shared/comment/comment.component.mjs +17 -17
  29. package/esm2022/lib/itinerary-app/shared/custom-story-card/custom-story-card.component.mjs +16 -11
  30. package/fesm2022/flower-city-online-itinerary-lib.mjs +628 -531
  31. package/fesm2022/flower-city-online-itinerary-lib.mjs.map +1 -1
  32. package/lib/itinerary-app/_services/bottom-navigation.service.d.ts +3 -3
  33. package/lib/itinerary-app/_services/navigation-helper.service.d.ts +19 -0
  34. package/lib/itinerary-app/modules/archives/pages/main-archives/main-archives.component.d.ts +5 -3
  35. package/lib/itinerary-app/modules/itineraries/itineraries.component.d.ts +3 -1
  36. package/lib/itinerary-app/modules/itineraries/pages/branched-itineraries/branched-itineraries.component.d.ts +4 -3
  37. package/lib/itinerary-app/modules/itineraries/pages/builder/builder.component.d.ts +5 -3
  38. package/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary/create-itinerary.component.d.ts +5 -3
  39. package/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-draw-mode/create-itinerary-draw-mode.component.d.ts +4 -3
  40. package/lib/itinerary-app/modules/itineraries/pages/builder/pages/created-itinerary/created-itinerary.component.d.ts +4 -3
  41. package/lib/itinerary-app/modules/itineraries/pages/builder/pages/created-itinerary-preview/created-itinerary-preview.component.d.ts +3 -1
  42. package/lib/itinerary-app/modules/itineraries/pages/builder/pages/location-picker/location-picker.component.d.ts +4 -3
  43. package/lib/itinerary-app/modules/itineraries/pages/builder/pages/select-itinerary-event/select-itinerary-event.component.d.ts +4 -3
  44. package/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-location/suggested-events-location.component.d.ts +4 -3
  45. package/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-route-radius/suggested-events-route-radius.component.d.ts +4 -3
  46. package/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-route-type/suggested-events-route-type.component.d.ts +4 -3
  47. package/lib/itinerary-app/modules/itineraries/pages/comments/comment-comparison/comment-comparison.component.d.ts +5 -3
  48. package/lib/itinerary-app/modules/itineraries/pages/comments/comment-search/comment-search.component.d.ts +5 -3
  49. package/lib/itinerary-app/modules/itineraries/pages/comments/comments-page.component.d.ts +3 -1
  50. package/lib/itinerary-app/modules/itineraries/pages/explore/explore.component.d.ts +5 -3
  51. package/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/components/details/details.component.d.ts +6 -4
  52. package/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/components/summary/summary.component.d.ts +5 -3
  53. package/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/itinerary-detail.component.d.ts +5 -2
  54. package/lib/itinerary-app/modules/itineraries/pages/itinerary-members/user-list/user-list.component.d.ts +5 -3
  55. package/lib/itinerary-app/modules/itineraries/pages/itinerary-upvote-users/itinerary-upvote-users.component.d.ts +5 -3
  56. package/lib/itinerary-app/modules/itineraries/pages/itinerary-users/itinerary-users.component.d.ts +5 -2
  57. package/lib/itinerary-app/modules/itineraries/pages/itinerary-watching-users/itinerary-watching-users.component.d.ts +5 -2
  58. package/lib/itinerary-app/shared/comment/comment.component.d.ts +5 -3
  59. package/lib/itinerary-app/shared/custom-story-card/custom-story-card.component.d.ts +5 -3
  60. package/package.json +1 -1
  61. package/styles.css +1 -1
@@ -3,24 +3,27 @@ import { Validators, } from '@angular/forms';
3
3
  import { ItinerariesRoutesEnum } from '../../../../../../_enums/ItenariesRoutes.enum';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common";
6
- import * as i2 from "@angular/router";
7
- import * as i3 from "../../../../../../_services/itinerary.service";
8
- import * as i4 from "@angular/forms";
9
- import * as i5 from "../../../../../../shared/users-stack/users-stack.component";
10
- import * as i6 from "../../../../../../shared/header/header.component";
11
- import * as i7 from "@naniteninja/ionic-lib";
6
+ import * as i2 from "../../../../../../_services/itinerary.service";
7
+ import * as i3 from "@angular/forms";
8
+ import * as i4 from "@angular/router";
9
+ import * as i5 from "../../../../../../_services/navigation-helper.service";
10
+ import * as i6 from "../../../../../../shared/users-stack/users-stack.component";
11
+ import * as i7 from "../../../../../../shared/header/header.component";
12
+ import * as i8 from "@naniteninja/ionic-lib";
12
13
  export class CreateItineraryComponent {
13
14
  location;
14
- router;
15
15
  itineraryService;
16
16
  fb;
17
+ route;
18
+ navHelper;
17
19
  form;
18
20
  settings = true;
19
- constructor(location, router, itineraryService, fb) {
21
+ constructor(location, itineraryService, fb, route, navHelper) {
20
22
  this.location = location;
21
- this.router = router;
22
23
  this.itineraryService = itineraryService;
23
24
  this.fb = fb;
25
+ this.route = route;
26
+ this.navHelper = navHelper;
24
27
  }
25
28
  ngOnInit() {
26
29
  this.form = this.fb.group({
@@ -66,24 +69,22 @@ export class CreateItineraryComponent {
66
69
  this.location.back();
67
70
  }
68
71
  navToStartLocation() {
69
- this.router.navigate([
70
- ItinerariesRoutesEnum.ITINERARY,
72
+ this.navHelper.navigate([
71
73
  ItinerariesRoutesEnum.CREATE_ITINERARY_ORIGIN,
72
74
  this.id.value,
73
- ]);
75
+ ], this.route);
74
76
  }
75
77
  navToMemberSearch() {
76
- this.router.navigate([
77
- ItinerariesRoutesEnum.ITINERARY,
78
+ this.navHelper.navigate([
78
79
  ItinerariesRoutesEnum.CREATE_ITINERARY_USER_SEARCH,
79
- 1,
80
- ]);
80
+ '1',
81
+ ], this.route);
81
82
  }
82
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateItineraryComponent, deps: [{ token: i1.Location }, { token: i2.Router }, { token: i3.ItineraryService }, { token: i4.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
83
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CreateItineraryComponent, selector: "app-create-itinerary", ngImport: i0, template: "<app-header (firstButton)=\"back()\" heading=\"Create Itinerary\"></app-header>\r\n<form [formGroup]=\"form\" class=\"mb-32\">\r\n <div class=\"mt-4 ml-3 mr-2 mb-5\">\r\n <p class=\"mb-4\">\r\n Start creating your itinerary with a title and continue to the route\r\n details.\r\n </p>\r\n <lib-text-box\r\n formControlName=\"name\"\r\n class=\"textbox-1\"\r\n label=\"Itinerary Title\"\r\n ></lib-text-box>\r\n <hr style=\"margin: 40px 0px 20px 0px\" class=\"divider\" />\r\n\r\n <h1 class=\"text-lg font-Calistoga\">Members</h1>\r\n <p class=\"mb-4\">The users included will effect the suggested activities.</p>\r\n <lib-text-box class=\"textbox-1\" label=\"User Search\"></lib-text-box>\r\n <app-users-stack [size]=\"41\" class=\"mt-2\"></app-users-stack>\r\n <hr style=\"margin: 40px 0px 20px 0px\" class=\"divider\" />\r\n\r\n <h1 class=\"text-lg font-Calistoga\">Settings</h1>\r\n <div class=\"mt-3 flex items-center justify-between\">\r\n <div style=\"width: 85%\">\r\n <h1>100% Match</h1>\r\n <p>\r\n Do all the members need to be interested in each experience for it to\r\n be suggested?\r\n </p>\r\n </div>\r\n <div style=\"width: 15%\" class=\"flex justify-end\">\r\n <lib-dashed-checkbox\r\n class=\"checkbox-sm\"\r\n formControlName=\"fullMatch\"\r\n ></lib-dashed-checkbox>\r\n </div>\r\n </div>\r\n <div class=\"mt-3 flex items-center justify-between\">\r\n <div style=\"width: 85%\">\r\n <h1>Another Setting</h1>\r\n <p>Lorem Ipsum</p>\r\n </div>\r\n <div style=\"width: 15%\" class=\"flex justify-end\">\r\n <lib-dashed-checkbox\r\n class=\"checkbox-sm\"\r\n formControlName=\"anotherSettings\"\r\n ></lib-dashed-checkbox>\r\n </div>\r\n </div>\r\n </div>\r\n</form>\r\n\r\n<div class=\"builder-footer\">\r\n <lib-footer-shared\r\n (continueButtonClick)=\"create()\"\r\n [canContinue]=\"true\"\r\n continueButtonText=\"Continue\"\r\n ></lib-footer-shared>\r\n</div>\r\n", styles: [".builder-footer{position:fixed;width:100%;bottom:0;z-index:1000}\n"], dependencies: [{ kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i5.UsersStackComponent, selector: "app-users-stack", inputs: ["images", "maxVisible", "size", "loading", "class", "isSelectableVisible", "selectableOption"] }, { kind: "component", type: i6.HeaderComponent, selector: "app-header", inputs: ["heading", "headerRightIcon", "titleIcon", "cssClass", "headerSuffixTemplate"], outputs: ["firstButton", "titleIconClick"] }, { kind: "component", type: i7.TextBoxComponent, selector: "lib-text-box", inputs: ["label", "maxLength", "includeEmojiPicker", "emojiPickerConfig", "includeImageAttachment", "maxImageAttachmentLength"] }, { kind: "component", type: i7.DashedCheckboxComponent, selector: "lib-dashed-checkbox", inputs: ["checked", "disabled"], outputs: ["toggle"] }, { kind: "component", type: i7.FooterSharedComponent, selector: "lib-footer-shared", inputs: ["loading$", "canContinue", "continueButtonText", "secondaryButtonText", "showBackButton", "continueButtonParameter$"], outputs: ["secondaryButtonClick", "continueButtonClick"] }] });
83
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateItineraryComponent, deps: [{ token: i1.Location }, { token: i2.ItineraryService }, { token: i3.FormBuilder }, { token: i4.ActivatedRoute }, { token: i5.NavigationHelperService }], target: i0.ɵɵFactoryTarget.Component });
84
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CreateItineraryComponent, selector: "app-create-itinerary", ngImport: i0, template: "<app-header (firstButton)=\"back()\" heading=\"Create Itinerary\"></app-header>\r\n<form [formGroup]=\"form\" class=\"mb-32\">\r\n <div class=\"mt-4 ml-3 mr-2 mb-5\">\r\n <p class=\"mb-4\">\r\n Start creating your itinerary with a title and continue to the route\r\n details.\r\n </p>\r\n <lib-text-box\r\n formControlName=\"name\"\r\n class=\"textbox-1\"\r\n label=\"Itinerary Title\"\r\n ></lib-text-box>\r\n <hr style=\"margin: 40px 0px 20px 0px\" class=\"divider\" />\r\n\r\n <h1 class=\"text-lg font-Calistoga\">Members</h1>\r\n <p class=\"mb-4\">The users included will effect the suggested activities.</p>\r\n <lib-text-box class=\"textbox-1\" label=\"User Search\"></lib-text-box>\r\n <app-users-stack [size]=\"41\" class=\"mt-2\"></app-users-stack>\r\n <hr style=\"margin: 40px 0px 20px 0px\" class=\"divider\" />\r\n\r\n <h1 class=\"text-lg font-Calistoga\">Settings</h1>\r\n <div class=\"mt-3 flex items-center justify-between\">\r\n <div style=\"width: 85%\">\r\n <h1>100% Match</h1>\r\n <p>\r\n Do all the members need to be interested in each experience for it to\r\n be suggested?\r\n </p>\r\n </div>\r\n <div style=\"width: 15%\" class=\"flex justify-end\">\r\n <lib-dashed-checkbox\r\n class=\"checkbox-sm\"\r\n formControlName=\"fullMatch\"\r\n ></lib-dashed-checkbox>\r\n </div>\r\n </div>\r\n <div class=\"mt-3 flex items-center justify-between\">\r\n <div style=\"width: 85%\">\r\n <h1>Another Setting</h1>\r\n <p>Lorem Ipsum</p>\r\n </div>\r\n <div style=\"width: 15%\" class=\"flex justify-end\">\r\n <lib-dashed-checkbox\r\n class=\"checkbox-sm\"\r\n formControlName=\"anotherSettings\"\r\n ></lib-dashed-checkbox>\r\n </div>\r\n </div>\r\n </div>\r\n</form>\r\n\r\n<div class=\"builder-footer\">\r\n <lib-footer-shared\r\n (continueButtonClick)=\"create()\"\r\n [canContinue]=\"true\"\r\n continueButtonText=\"Continue\"\r\n ></lib-footer-shared>\r\n</div>\r\n", styles: [".builder-footer{position:fixed;width:100%;bottom:0;z-index:1000}\n"], dependencies: [{ kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i6.UsersStackComponent, selector: "app-users-stack", inputs: ["images", "maxVisible", "size", "loading", "class", "isSelectableVisible", "selectableOption"] }, { kind: "component", type: i7.HeaderComponent, selector: "app-header", inputs: ["heading", "headerRightIcon", "titleIcon", "cssClass", "headerSuffixTemplate"], outputs: ["firstButton", "titleIconClick"] }, { kind: "component", type: i8.TextBoxComponent, selector: "lib-text-box", inputs: ["label", "maxLength", "includeEmojiPicker", "emojiPickerConfig", "includeImageAttachment", "maxImageAttachmentLength"] }, { kind: "component", type: i8.DashedCheckboxComponent, selector: "lib-dashed-checkbox", inputs: ["checked", "disabled"], outputs: ["toggle"] }, { kind: "component", type: i8.FooterSharedComponent, selector: "lib-footer-shared", inputs: ["loading$", "canContinue", "continueButtonText", "secondaryButtonText", "showBackButton", "continueButtonParameter$"], outputs: ["secondaryButtonClick", "continueButtonClick"] }] });
84
85
  }
85
86
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateItineraryComponent, decorators: [{
86
87
  type: Component,
87
88
  args: [{ selector: 'app-create-itinerary', standalone: false, template: "<app-header (firstButton)=\"back()\" heading=\"Create Itinerary\"></app-header>\r\n<form [formGroup]=\"form\" class=\"mb-32\">\r\n <div class=\"mt-4 ml-3 mr-2 mb-5\">\r\n <p class=\"mb-4\">\r\n Start creating your itinerary with a title and continue to the route\r\n details.\r\n </p>\r\n <lib-text-box\r\n formControlName=\"name\"\r\n class=\"textbox-1\"\r\n label=\"Itinerary Title\"\r\n ></lib-text-box>\r\n <hr style=\"margin: 40px 0px 20px 0px\" class=\"divider\" />\r\n\r\n <h1 class=\"text-lg font-Calistoga\">Members</h1>\r\n <p class=\"mb-4\">The users included will effect the suggested activities.</p>\r\n <lib-text-box class=\"textbox-1\" label=\"User Search\"></lib-text-box>\r\n <app-users-stack [size]=\"41\" class=\"mt-2\"></app-users-stack>\r\n <hr style=\"margin: 40px 0px 20px 0px\" class=\"divider\" />\r\n\r\n <h1 class=\"text-lg font-Calistoga\">Settings</h1>\r\n <div class=\"mt-3 flex items-center justify-between\">\r\n <div style=\"width: 85%\">\r\n <h1>100% Match</h1>\r\n <p>\r\n Do all the members need to be interested in each experience for it to\r\n be suggested?\r\n </p>\r\n </div>\r\n <div style=\"width: 15%\" class=\"flex justify-end\">\r\n <lib-dashed-checkbox\r\n class=\"checkbox-sm\"\r\n formControlName=\"fullMatch\"\r\n ></lib-dashed-checkbox>\r\n </div>\r\n </div>\r\n <div class=\"mt-3 flex items-center justify-between\">\r\n <div style=\"width: 85%\">\r\n <h1>Another Setting</h1>\r\n <p>Lorem Ipsum</p>\r\n </div>\r\n <div style=\"width: 15%\" class=\"flex justify-end\">\r\n <lib-dashed-checkbox\r\n class=\"checkbox-sm\"\r\n formControlName=\"anotherSettings\"\r\n ></lib-dashed-checkbox>\r\n </div>\r\n </div>\r\n </div>\r\n</form>\r\n\r\n<div class=\"builder-footer\">\r\n <lib-footer-shared\r\n (continueButtonClick)=\"create()\"\r\n [canContinue]=\"true\"\r\n continueButtonText=\"Continue\"\r\n ></lib-footer-shared>\r\n</div>\r\n", styles: [".builder-footer{position:fixed;width:100%;bottom:0;z-index:1000}\n"] }]
88
- }], ctorParameters: () => [{ type: i1.Location }, { type: i2.Router }, { type: i3.ItineraryService }, { type: i4.FormBuilder }] });
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-itinerary.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/itinerary-lib/src/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary/create-itinerary.component.ts","../../../../../../../../../../../projects/itinerary-lib/src/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary/create-itinerary.component.html"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAClD,OAAO,EAIL,UAAU,GACX,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,qBAAqB,EAAE,MAAM,+CAA+C,CAAC;;;;;;;;;AAUtF,MAAM,OAAO,wBAAwB;IAKzB;IACA;IACA;IACA;IAPV,IAAI,CAAa;IACjB,QAAQ,GAAY,IAAI,CAAC;IAEzB,YACU,QAAkB,EAClB,MAAc,EACd,gBAAkC,EAClC,EAAe;QAHf,aAAQ,GAAR,QAAQ,CAAU;QAClB,WAAM,GAAN,MAAM,CAAQ;QACd,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,OAAE,GAAF,EAAE,CAAa;IACtB,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YACxB,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;YACzB,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACjC,SAAS,EAAE,CAAC,KAAK,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACzC,eAAe,EAAE,CAAC,KAAK,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SAChD,CAAC,CAAC;IACL,CAAC;IAED,UAAU;IACV,IAAI,EAAE;QACJ,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAgB,CAAC;IAC5C,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAgB,CAAC;IAC9C,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,CAAgB,CAAC;IACnD,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAgB,CAAC;IACzD,CAAC;IAED,MAAM;QACJ,MAAM,SAAS,GAAc;YAC3B,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK;YACjB,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO;YAC7B,WAAW,EAAE,KAAK;YAClB,WAAW,EAAE,EAAE;YACf,QAAQ,EAAE,EAAE;YACZ,aAAa,EAAE,EAAE;YACjB,aAAa,EAAE,SAAS;YACxB,WAAW,EAAE,SAAS;YACtB,UAAU,EAAE,EAAE;YACd,WAAW,EAAE,CAAC;YACd,cAAc,EAAE,EAAE;YAClB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACpC,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QAChD,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,aAAa;IACb,IAAI;QACF,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;YACnB,qBAAqB,CAAC,SAAS;YAC/B,qBAAqB,CAAC,uBAAuB;YAC7C,IAAI,CAAC,EAAE,CAAC,KAAK;SACd,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;YACnB,qBAAqB,CAAC,SAAS;YAC/B,qBAAqB,CAAC,4BAA4B;YAClD,CAAC;SACF,CAAC,CAAC;IACL,CAAC;wGA3EU,wBAAwB;4FAAxB,wBAAwB,4DCnBrC,+kEA0DA;;4FDvCa,wBAAwB;kBANpC,SAAS;+BACI,sBAAsB,cAGpB,KAAK","sourcesContent":["import { Location } from '@angular/common';\r\nimport { Component, OnInit } from '@angular/core';\r\nimport {\r\n  FormBuilder,\r\n  FormControl,\r\n  FormGroup,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport { Router } from '@angular/router'; \r\nimport { ItinerariesRoutesEnum } from '../../../../../../_enums/ItenariesRoutes.enum';\r\nimport { Itinerary } from '../../../../../../_models/Itinerary';\r\nimport { ItineraryService } from '../../../../../../_services/itinerary.service';\r\n\r\n@Component({\r\n    selector: 'app-create-itinerary',\r\n    templateUrl: './create-itinerary.component.html',\r\n    styleUrl: './create-itinerary.component.css',\r\n    standalone: false\r\n})\r\nexport class CreateItineraryComponent implements OnInit {\r\n  form!: FormGroup;\r\n  settings: boolean = true;\r\n\r\n  constructor(\r\n    private location: Location,\r\n    private router: Router,\r\n    private itineraryService: ItineraryService,\r\n    private fb: FormBuilder,\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.form = this.fb.group({\r\n      id: [crypto.randomUUID()],\r\n      name: ['', [Validators.required]],\r\n      fullMatch: [false, [Validators.required]],\r\n      anotherSettings: [false, [Validators.required]],\r\n    });\r\n  }\r\n\r\n  //UI LOGIC\r\n  get id(): FormControl {\r\n    return this.form.get('id') as FormControl;\r\n  }\r\n\r\n  get name(): FormControl {\r\n    return this.form.get('name') as FormControl;\r\n  }\r\n\r\n  get fullMatch(): FormControl {\r\n    return this.form.get('fullMatch') as FormControl;\r\n  }\r\n\r\n  get anotherSettings(): FormControl {\r\n    return this.form.get('anotherSettings') as FormControl;\r\n  }\r\n\r\n  create(): void {\r\n    const itinerary: Itinerary = {\r\n      id: this.id.value,\r\n      name: this.name.value.message,\r\n      isCompleted: false,\r\n      description: '',\r\n      distance: '',\r\n      distanceValue: '',\r\n      startLocation: undefined,\r\n      endLocation: undefined,\r\n      routeTypes: [],\r\n      routeRadius: 0,\r\n      visitingPlaces: [],\r\n      createdAt: new Date().toISOString(),\r\n    };\r\n    this.itineraryService.createOrUpdate(itinerary);\r\n    this.navToStartLocation();\r\n  }\r\n\r\n  //NAVIGATIONS\r\n  back(): void {\r\n    this.location.back();\r\n  }\r\n\r\n  navToStartLocation(): void {\r\n    this.router.navigate([\r\n      ItinerariesRoutesEnum.ITINERARY,\r\n      ItinerariesRoutesEnum.CREATE_ITINERARY_ORIGIN,\r\n      this.id.value,\r\n    ]);\r\n  }\r\n\r\n  navToMemberSearch(): void {\r\n    this.router.navigate([\r\n      ItinerariesRoutesEnum.ITINERARY,\r\n      ItinerariesRoutesEnum.CREATE_ITINERARY_USER_SEARCH,\r\n      1,\r\n    ]);\r\n  }\r\n}\r\n","<app-header (firstButton)=\"back()\" heading=\"Create Itinerary\"></app-header>\r\n<form [formGroup]=\"form\" class=\"mb-32\">\r\n  <div class=\"mt-4 ml-3 mr-2 mb-5\">\r\n    <p class=\"mb-4\">\r\n      Start creating your itinerary with a title and continue to the route\r\n      details.\r\n    </p>\r\n    <lib-text-box\r\n      formControlName=\"name\"\r\n      class=\"textbox-1\"\r\n      label=\"Itinerary Title\"\r\n    ></lib-text-box>\r\n    <hr style=\"margin: 40px 0px 20px 0px\" class=\"divider\" />\r\n\r\n    <h1 class=\"text-lg font-Calistoga\">Members</h1>\r\n    <p class=\"mb-4\">The users included will effect the suggested activities.</p>\r\n    <lib-text-box class=\"textbox-1\" label=\"User Search\"></lib-text-box>\r\n    <app-users-stack [size]=\"41\" class=\"mt-2\"></app-users-stack>\r\n    <hr style=\"margin: 40px 0px 20px 0px\" class=\"divider\" />\r\n\r\n    <h1 class=\"text-lg font-Calistoga\">Settings</h1>\r\n    <div class=\"mt-3 flex items-center justify-between\">\r\n      <div style=\"width: 85%\">\r\n        <h1>100% Match</h1>\r\n        <p>\r\n          Do all the members need to be interested in each experience for it to\r\n          be suggested?\r\n        </p>\r\n      </div>\r\n      <div style=\"width: 15%\" class=\"flex justify-end\">\r\n        <lib-dashed-checkbox\r\n          class=\"checkbox-sm\"\r\n          formControlName=\"fullMatch\"\r\n        ></lib-dashed-checkbox>\r\n      </div>\r\n    </div>\r\n    <div class=\"mt-3 flex items-center justify-between\">\r\n      <div style=\"width: 85%\">\r\n        <h1>Another Setting</h1>\r\n        <p>Lorem Ipsum</p>\r\n      </div>\r\n      <div style=\"width: 15%\" class=\"flex justify-end\">\r\n        <lib-dashed-checkbox\r\n          class=\"checkbox-sm\"\r\n          formControlName=\"anotherSettings\"\r\n        ></lib-dashed-checkbox>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</form>\r\n\r\n<div class=\"builder-footer\">\r\n  <lib-footer-shared\r\n    (continueButtonClick)=\"create()\"\r\n    [canContinue]=\"true\"\r\n    continueButtonText=\"Continue\"\r\n  ></lib-footer-shared>\r\n</div>\r\n"]}
89
+ }], ctorParameters: () => [{ type: i1.Location }, { type: i2.ItineraryService }, { type: i3.FormBuilder }, { type: i4.ActivatedRoute }, { type: i5.NavigationHelperService }] });
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-itinerary.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/itinerary-lib/src/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary/create-itinerary.component.ts","../../../../../../../../../../../projects/itinerary-lib/src/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary/create-itinerary.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Location } from '@angular/common';\r\nimport { Component, OnInit } from '@angular/core';\r\nimport {\r\n  FormBuilder,\r\n  FormControl,\r\n  FormGroup,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport { ActivatedRoute } from '@angular/router'; \r\nimport { ItinerariesRoutesEnum } from '../../../../../../_enums/ItenariesRoutes.enum';\r\nimport { Itinerary } from '../../../../../../_models/Itinerary';\r\nimport { ItineraryService } from '../../../../../../_services/itinerary.service';\r\nimport { NavigationHelperService } from '../../../../../../_services/navigation-helper.service';\r\n\r\n@Component({\r\n    selector: 'app-create-itinerary',\r\n    templateUrl: './create-itinerary.component.html',\r\n    styleUrl: './create-itinerary.component.css',\r\n    standalone: false\r\n})\r\nexport class CreateItineraryComponent implements OnInit {\r\n  form!: FormGroup;\r\n  settings: boolean = true;\r\n\r\n  constructor(\r\n    private location: Location,\r\n    private itineraryService: ItineraryService,\r\n    private fb: FormBuilder,\r\n    private route: ActivatedRoute,\r\n    private navHelper: NavigationHelperService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.form = this.fb.group({\r\n      id: [crypto.randomUUID()],\r\n      name: ['', [Validators.required]],\r\n      fullMatch: [false, [Validators.required]],\r\n      anotherSettings: [false, [Validators.required]],\r\n    });\r\n  }\r\n\r\n  //UI LOGIC\r\n  get id(): FormControl {\r\n    return this.form.get('id') as FormControl;\r\n  }\r\n\r\n  get name(): FormControl {\r\n    return this.form.get('name') as FormControl;\r\n  }\r\n\r\n  get fullMatch(): FormControl {\r\n    return this.form.get('fullMatch') as FormControl;\r\n  }\r\n\r\n  get anotherSettings(): FormControl {\r\n    return this.form.get('anotherSettings') as FormControl;\r\n  }\r\n\r\n  create(): void {\r\n    const itinerary: Itinerary = {\r\n      id: this.id.value,\r\n      name: this.name.value.message,\r\n      isCompleted: false,\r\n      description: '',\r\n      distance: '',\r\n      distanceValue: '',\r\n      startLocation: undefined,\r\n      endLocation: undefined,\r\n      routeTypes: [],\r\n      routeRadius: 0,\r\n      visitingPlaces: [],\r\n      createdAt: new Date().toISOString(),\r\n    };\r\n    this.itineraryService.createOrUpdate(itinerary);\r\n    this.navToStartLocation();\r\n  }\r\n\r\n  //NAVIGATIONS\r\n  back(): void {\r\n    this.location.back();\r\n  }\r\n\r\n  navToStartLocation(): void {\r\n    this.navHelper.navigate([\r\n      ItinerariesRoutesEnum.CREATE_ITINERARY_ORIGIN,\r\n      this.id.value,\r\n    ], this.route);\r\n  }\r\n\r\n  navToMemberSearch(): void {\r\n    this.navHelper.navigate([\r\n      ItinerariesRoutesEnum.CREATE_ITINERARY_USER_SEARCH,\r\n      '1',\r\n    ], this.route);\r\n  }\r\n}\r\n","<app-header (firstButton)=\"back()\" heading=\"Create Itinerary\"></app-header>\r\n<form [formGroup]=\"form\" class=\"mb-32\">\r\n  <div class=\"mt-4 ml-3 mr-2 mb-5\">\r\n    <p class=\"mb-4\">\r\n      Start creating your itinerary with a title and continue to the route\r\n      details.\r\n    </p>\r\n    <lib-text-box\r\n      formControlName=\"name\"\r\n      class=\"textbox-1\"\r\n      label=\"Itinerary Title\"\r\n    ></lib-text-box>\r\n    <hr style=\"margin: 40px 0px 20px 0px\" class=\"divider\" />\r\n\r\n    <h1 class=\"text-lg font-Calistoga\">Members</h1>\r\n    <p class=\"mb-4\">The users included will effect the suggested activities.</p>\r\n    <lib-text-box class=\"textbox-1\" label=\"User Search\"></lib-text-box>\r\n    <app-users-stack [size]=\"41\" class=\"mt-2\"></app-users-stack>\r\n    <hr style=\"margin: 40px 0px 20px 0px\" class=\"divider\" />\r\n\r\n    <h1 class=\"text-lg font-Calistoga\">Settings</h1>\r\n    <div class=\"mt-3 flex items-center justify-between\">\r\n      <div style=\"width: 85%\">\r\n        <h1>100% Match</h1>\r\n        <p>\r\n          Do all the members need to be interested in each experience for it to\r\n          be suggested?\r\n        </p>\r\n      </div>\r\n      <div style=\"width: 15%\" class=\"flex justify-end\">\r\n        <lib-dashed-checkbox\r\n          class=\"checkbox-sm\"\r\n          formControlName=\"fullMatch\"\r\n        ></lib-dashed-checkbox>\r\n      </div>\r\n    </div>\r\n    <div class=\"mt-3 flex items-center justify-between\">\r\n      <div style=\"width: 85%\">\r\n        <h1>Another Setting</h1>\r\n        <p>Lorem Ipsum</p>\r\n      </div>\r\n      <div style=\"width: 15%\" class=\"flex justify-end\">\r\n        <lib-dashed-checkbox\r\n          class=\"checkbox-sm\"\r\n          formControlName=\"anotherSettings\"\r\n        ></lib-dashed-checkbox>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</form>\r\n\r\n<div class=\"builder-footer\">\r\n  <lib-footer-shared\r\n    (continueButtonClick)=\"create()\"\r\n    [canContinue]=\"true\"\r\n    continueButtonText=\"Continue\"\r\n  ></lib-footer-shared>\r\n</div>\r\n"]}
@@ -7,19 +7,20 @@ import * as i2 from "@angular/router";
7
7
  import * as i3 from "../../../../../../_services/itinerary.service";
8
8
  import * as i4 from "../../../../../../_services/location.service";
9
9
  import * as i5 from "../../../../../../_services/itinerary.drawmode.transfer";
10
- import * as i6 from "@naniteninja/ionic-lib";
11
- import * as i7 from "../create-itinerary-header/create-itinerary-header.component";
12
- import * as i8 from "@ngx-translate/core";
10
+ import * as i6 from "../../../../../../_services/navigation-helper.service";
11
+ import * as i7 from "@naniteninja/ionic-lib";
12
+ import * as i8 from "../create-itinerary-header/create-itinerary-header.component";
13
+ import * as i9 from "@ngx-translate/core";
13
14
  const defaultIcon = 'assets/icons/map-markers-yellow.svg';
14
15
  const selectedIcon = 'assets/icons/restu-icon-large.svg';
15
16
  export class CreateItineraryDrawModeComponent {
16
17
  location;
17
18
  cdr;
18
- router;
19
19
  activatedRoute;
20
20
  itineraryService;
21
21
  locationService;
22
22
  transferService;
23
+ navHelper;
23
24
  ICONS = ICONS;
24
25
  actions = [ICONS['location'], ICONS['pencil'], ICONS['ban']];
25
26
  selected = this.actions[1];
@@ -34,14 +35,14 @@ export class CreateItineraryDrawModeComponent {
34
35
  placesResult; //Places result required for preview
35
36
  placeMarkers = [];
36
37
  //LIFE CYCLES
37
- constructor(location, cdr, router, activatedRoute, itineraryService, locationService, transferService) {
38
+ constructor(location, cdr, activatedRoute, itineraryService, locationService, transferService, navHelper) {
38
39
  this.location = location;
39
40
  this.cdr = cdr;
40
- this.router = router;
41
41
  this.activatedRoute = activatedRoute;
42
42
  this.itineraryService = itineraryService;
43
43
  this.locationService = locationService;
44
44
  this.transferService = transferService;
45
+ this.navHelper = navHelper;
45
46
  }
46
47
  ngOnInit() {
47
48
  const id = this.activatedRoute.snapshot.params['id'];
@@ -53,19 +54,17 @@ export class CreateItineraryDrawModeComponent {
53
54
  updateAction(action) {
54
55
  this.selected = action;
55
56
  if (action === this.actions[0]) {
56
- this.router.navigate([
57
- ItinerariesRoutesEnum.ITINERARY,
57
+ this.navHelper.navigate([
58
58
  ItinerariesRoutesEnum.CREATE_ITINERARY_ORIGIN,
59
- this.itinerary?.id
60
- ]);
59
+ this.itinerary.id
60
+ ], this.activatedRoute);
61
61
  }
62
62
  if (action === this.actions[2]) {
63
- this.router.navigate([
64
- ItinerariesRoutesEnum.ITINERARY,
63
+ this.navHelper.navigate([
65
64
  ItinerariesRoutesEnum.CREATE_ITINERARY_NO_VISUAL_FILTER_MODE,
66
65
  ItinerariesRoutesEnum.CREATE_ITINERARY_NO_VISUAL_FILTER_MODE_CREATE,
67
- this.itinerary?.id
68
- ]);
66
+ this.itinerary.id
67
+ ], this.activatedRoute);
69
68
  }
70
69
  }
71
70
  showBottomModal() {
@@ -148,12 +147,11 @@ export class CreateItineraryDrawModeComponent {
148
147
  this.transferService.setPlaces(allPlaces);
149
148
  this.transferService.setSelectedPlaces(selectedPlaces);
150
149
  this.transferService.setCurrentLocation(this.initialLocation);
151
- this.router.navigate([
152
- ItinerariesRoutesEnum.ITINERARY,
150
+ this.navHelper.navigate([
153
151
  ItinerariesRoutesEnum.CREATE_ITINERARY_DRAW_MODE,
154
152
  ItinerariesRoutesEnum.CREATE_ITINERARY_DRAW_MODE_PREVIEW,
155
- this.itinerary?.id
156
- ]);
153
+ this.itinerary.id
154
+ ], this.activatedRoute);
157
155
  }
158
156
  clearPolygonIfExist() {
159
157
  if (this.polygon) {
@@ -240,11 +238,10 @@ export class CreateItineraryDrawModeComponent {
240
238
  this.location.back();
241
239
  }
242
240
  navToPickStartLocation() {
243
- this.router.navigate([
244
- ItinerariesRoutesEnum.ITINERARY,
241
+ this.navHelper.navigate([
245
242
  ItinerariesRoutesEnum.LOCATION_PICKER,
246
- this.itinerary?.id,
247
- ], { queryParams: { mode: 'start' } });
243
+ this.itinerary.id,
244
+ ], this.activatedRoute, { queryParams: { mode: 'start' } });
248
245
  }
249
246
  getClosestPointOnPolygon(polygon, point) {
250
247
  const path = polygon.getPath();
@@ -265,14 +262,14 @@ export class CreateItineraryDrawModeComponent {
265
262
  }
266
263
  return closestPoint;
267
264
  }
268
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateItineraryDrawModeComponent, deps: [{ token: i1.Location }, { token: i0.ChangeDetectorRef }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i3.ItineraryService }, { token: i4.LocationService }, { token: i5.ItineraryDrawModeTransferService }], target: i0.ɵɵFactoryTarget.Component });
269
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CreateItineraryDrawModeComponent, selector: "lib-create-itinerary-draw-mode", viewQueries: [{ propertyName: "libMap", first: true, predicate: ["libMap"], descendants: true }], ngImport: i0, template: "<app-create-itinerary-header\r\n [progressBarValue]=\"50\"\r\n heading=\"Create Itinerary\"\r\n></app-create-itinerary-header>\r\n<lib-map #libMap class=\"maps-100vh\"></lib-map>\r\n<lib-bottom-modal\r\n [showArrow]=\"true\"\r\n [(isOpen)]=\"isOpen\"\r\n [adaptToContentHeight]=\"true\"\r\n>\r\n <div class=\"\">\r\n <ng-container *ngIf=\"!mapDrawn\">\r\n <div class=\"flex items-center justify-between pl-4 pr-4\">\r\n <h3 class=\"font-Calistoga text-lg\">{{ \"ITINERARY.DRAW\" | translate }}</h3>\r\n <div class=\"selectables flex items-center\">\r\n <div\r\n (click)=\"updateAction(a)\"\r\n class=\"flex items-center justify-center actions\"\r\n *ngFor=\"let a of actions\"\r\n [ngClass]=\"{ selected: a === selected }\"\r\n >\r\n <img [src]=\"a\" alt=\"icon\" loading=\"lazy\" />\r\n </div>\r\n </div>\r\n </div>\r\n <p class=\"mt-3 px-4 mb-4\">{{ \"ITINERARY.DRAW_DESCRIPTION\" | translate }}</p>\r\n </ng-container>\r\n <ng-container *ngIf=\"mapDrawn\">\r\n <div class=\"ml-auto flex items-center justify-center gap-x-2\">\r\n <div class=\"flex items-center gap-x-1 text-xs\">\r\n <img\r\n loading=\"lazy\"\r\n [src]=\"ICONS['locationWhite']\"\r\n alt=\"location\"\r\n />\r\n <span>&nbsp;{{ \"ITINERARY.SELECT_MIN_PLACES\" | translate }}</span>\r\n </div>\r\n <div class=\"h-4 border w-0 border-secondary\"></div>\r\n <div class=\"flex items-center justify-center gap-x-2 text-xs\">\r\n <img loading=\"lazy\" [src]=\"ICONS['clock']\" alt=\"\" />\r\n <span>&nbsp;0 minutes</span>\r\n <span class=\"text-secondary font-thin\">(0.0 km)</span>\r\n </div>\r\n </div>\r\n <div class=\"select-places-description mt-5 text-center mb-4\">\r\n {{ \"ITINERARY.SELECT_PLACES_INSTRUCTION\" | translate }}\r\n </div>\r\n </ng-container>\r\n\r\n <lib-footer-shared\r\n (continueButtonClick)=\"continue()\"\r\n (secondaryButtonClick)=\"clearMap()\"\r\n [canContinue]=\"true\"\r\n [continueButtonText]=\"'COMMON.CONTINUE' | translate\"\r\n [secondaryButtonText]=\"'COMMON.CLEAR' | translate\"\r\n ></lib-footer-shared>\r\n </div>\r\n</lib-bottom-modal>\r\n<div\r\n (click)=\"showBottomModal()\"\r\n class=\"absolute bottom-0 cursor-pointer z-10\"\r\n style=\"left: 50%\"\r\n>\r\n <img\r\n style=\"transform: rotate(270deg)\"\r\n [src]=\"ICONS['rightArrow']\"\r\n alt=\"icon\"\r\n height=\"15\"\r\n width=\"15\"\r\n />\r\n</div>\r\n", styles: [":host{--lib-popup-modal-radius: 16px;--border-radius: var(--lib-popup-modal-radius);--lib-popup-modal-background: #28252d !important;--background: #28252d !important;--overflow: hidden !important;--lib-popup-modal-color: #a8a8a8;--color: var(--lib-popup-modal-color, #a8a8a8);--max-width: var(--lib-bottom-modal-max-width, 500px);--lib-popup-modal-shadow: 5px 5px 95px 0px rgba(255, 255, 255, .32), -3px -3px 16px 0px rgba(255, 255, 255, .1) !important;--box-shadow: var( --lib-popup-modal-shadow, 5px 5px 95px 0px rgba(255, 255, 255, .32), -3px -3px 16px 0px rgba(255, 255, 255, .1) )}.selectables{background:#28252d;box-shadow:4.1px 4.1px 8.2px #00000052 inset;box-shadow:-2.46px -2.46px 3.28px #ffffff1a inset;border-radius:27.9px}.actions{width:42px;height:28px;border-radius:82.05px}.selected{background:linear-gradient(94.44deg,#fe3c72 1.26%,#e15561);box-shadow:3.28px 3.28px 6.56px #00000040;box-shadow:-1.64px -1.64px 8.2px #ffffff40}.select-places-text,.select-places-description{font-size:var(--font-size-small)}.button-container{background-color:#27242c;box-shadow:inset 0 6px 6px -6px #8a8a8aab}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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: i6.BottomModalComponent, selector: "lib-bottom-modal", inputs: ["breakpoints", "initialBreakpoint", "isOpen", "canDismiss", "showArrow", "showBackBtn", "showConfirm", "showCloseBtn", "loading", "showHeaderSeparator", "title", "confirmationTitle", "confirmationMsg", "confirmButton", "confirmCancelButton", "description", "secondaryButtonTitle", "submitButtonTitle", "cancelButtonTitle", "validModal", "adaptToContentHeight", "customClass"], outputs: ["isOpenChange", "breakpointChange", "closeModal", "submitModal", "secondaryButtonClick", "backClick", "showConfirmChange", "confirmEvent"] }, { kind: "directive", type: i6.LazyImageDirective, selector: "img" }, { kind: "component", type: i6.FooterSharedComponent, selector: "lib-footer-shared", inputs: ["loading$", "canContinue", "continueButtonText", "secondaryButtonText", "showBackButton", "continueButtonParameter$"], outputs: ["secondaryButtonClick", "continueButtonClick"] }, { kind: "component", type: i6.LibMapsComponent, selector: "lib-map", inputs: ["disableNotification", "markers", "initialLocation", "mapType", "enableDrag", "locations", "searchMapsString", "mapOptions", "directions$", "directionRenderOptions"], outputs: ["mapActionEvent"] }, { kind: "component", type: i7.CreateItineraryHeaderComponent, selector: "app-create-itinerary-header", inputs: ["heading", "progressBarValue", "discardItineraryId", "class"] }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] });
265
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateItineraryDrawModeComponent, deps: [{ token: i1.Location }, { token: i0.ChangeDetectorRef }, { token: i2.ActivatedRoute }, { token: i3.ItineraryService }, { token: i4.LocationService }, { token: i5.ItineraryDrawModeTransferService }, { token: i6.NavigationHelperService }], target: i0.ɵɵFactoryTarget.Component });
266
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CreateItineraryDrawModeComponent, selector: "lib-create-itinerary-draw-mode", viewQueries: [{ propertyName: "libMap", first: true, predicate: ["libMap"], descendants: true }], ngImport: i0, template: "<app-create-itinerary-header\r\n [progressBarValue]=\"50\"\r\n heading=\"Create Itinerary\"\r\n></app-create-itinerary-header>\r\n<lib-map #libMap class=\"maps-100vh\"></lib-map>\r\n<lib-bottom-modal\r\n [showArrow]=\"true\"\r\n [(isOpen)]=\"isOpen\"\r\n [adaptToContentHeight]=\"true\"\r\n>\r\n <div class=\"\">\r\n <ng-container *ngIf=\"!mapDrawn\">\r\n <div class=\"flex items-center justify-between pl-4 pr-4\">\r\n <h3 class=\"font-Calistoga text-lg\">{{ \"ITINERARY.DRAW\" | translate }}</h3>\r\n <div class=\"selectables flex items-center\">\r\n <div\r\n (click)=\"updateAction(a)\"\r\n class=\"flex items-center justify-center actions\"\r\n *ngFor=\"let a of actions\"\r\n [ngClass]=\"{ selected: a === selected }\"\r\n >\r\n <img [src]=\"a\" alt=\"icon\" loading=\"lazy\" />\r\n </div>\r\n </div>\r\n </div>\r\n <p class=\"mt-3 px-4 mb-4\">{{ \"ITINERARY.DRAW_DESCRIPTION\" | translate }}</p>\r\n </ng-container>\r\n <ng-container *ngIf=\"mapDrawn\">\r\n <div class=\"ml-auto flex items-center justify-center gap-x-2\">\r\n <div class=\"flex items-center gap-x-1 text-xs\">\r\n <img\r\n loading=\"lazy\"\r\n [src]=\"ICONS['locationWhite']\"\r\n alt=\"location\"\r\n />\r\n <span>&nbsp;{{ \"ITINERARY.SELECT_MIN_PLACES\" | translate }}</span>\r\n </div>\r\n <div class=\"h-4 border w-0 border-secondary\"></div>\r\n <div class=\"flex items-center justify-center gap-x-2 text-xs\">\r\n <img loading=\"lazy\" [src]=\"ICONS['clock']\" alt=\"\" />\r\n <span>&nbsp;0 minutes</span>\r\n <span class=\"text-secondary font-thin\">(0.0 km)</span>\r\n </div>\r\n </div>\r\n <div class=\"select-places-description mt-5 text-center mb-4\">\r\n {{ \"ITINERARY.SELECT_PLACES_INSTRUCTION\" | translate }}\r\n </div>\r\n </ng-container>\r\n\r\n <lib-footer-shared\r\n (continueButtonClick)=\"continue()\"\r\n (secondaryButtonClick)=\"clearMap()\"\r\n [canContinue]=\"true\"\r\n [continueButtonText]=\"'COMMON.CONTINUE' | translate\"\r\n [secondaryButtonText]=\"'COMMON.CLEAR' | translate\"\r\n ></lib-footer-shared>\r\n </div>\r\n</lib-bottom-modal>\r\n<div\r\n (click)=\"showBottomModal()\"\r\n class=\"absolute bottom-0 cursor-pointer z-10\"\r\n style=\"left: 50%\"\r\n>\r\n <img\r\n style=\"transform: rotate(270deg)\"\r\n [src]=\"ICONS['rightArrow']\"\r\n alt=\"icon\"\r\n height=\"15\"\r\n width=\"15\"\r\n />\r\n</div>\r\n", styles: [":host{--lib-popup-modal-radius: 16px;--border-radius: var(--lib-popup-modal-radius);--lib-popup-modal-background: #28252d !important;--background: #28252d !important;--overflow: hidden !important;--lib-popup-modal-color: #a8a8a8;--color: var(--lib-popup-modal-color, #a8a8a8);--max-width: var(--lib-bottom-modal-max-width, 500px);--lib-popup-modal-shadow: 5px 5px 95px 0px rgba(255, 255, 255, .32), -3px -3px 16px 0px rgba(255, 255, 255, .1) !important;--box-shadow: var( --lib-popup-modal-shadow, 5px 5px 95px 0px rgba(255, 255, 255, .32), -3px -3px 16px 0px rgba(255, 255, 255, .1) )}.selectables{background:#28252d;box-shadow:4.1px 4.1px 8.2px #00000052 inset;box-shadow:-2.46px -2.46px 3.28px #ffffff1a inset;border-radius:27.9px}.actions{width:42px;height:28px;border-radius:82.05px}.selected{background:linear-gradient(94.44deg,#fe3c72 1.26%,#e15561);box-shadow:3.28px 3.28px 6.56px #00000040;box-shadow:-1.64px -1.64px 8.2px #ffffff40}.select-places-text,.select-places-description{font-size:var(--font-size-small)}.button-container{background-color:#27242c;box-shadow:inset 0 6px 6px -6px #8a8a8aab}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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: i7.BottomModalComponent, selector: "lib-bottom-modal", inputs: ["breakpoints", "initialBreakpoint", "isOpen", "canDismiss", "showArrow", "showBackBtn", "showConfirm", "showCloseBtn", "loading", "showHeaderSeparator", "title", "confirmationTitle", "confirmationMsg", "confirmButton", "confirmCancelButton", "description", "secondaryButtonTitle", "submitButtonTitle", "cancelButtonTitle", "validModal", "adaptToContentHeight", "customClass"], outputs: ["isOpenChange", "breakpointChange", "closeModal", "submitModal", "secondaryButtonClick", "backClick", "showConfirmChange", "confirmEvent"] }, { kind: "directive", type: i7.LazyImageDirective, selector: "img" }, { kind: "component", type: i7.FooterSharedComponent, selector: "lib-footer-shared", inputs: ["loading$", "canContinue", "continueButtonText", "secondaryButtonText", "showBackButton", "continueButtonParameter$"], outputs: ["secondaryButtonClick", "continueButtonClick"] }, { kind: "component", type: i7.LibMapsComponent, selector: "lib-map", inputs: ["disableNotification", "markers", "initialLocation", "mapType", "enableDrag", "locations", "searchMapsString", "mapOptions", "directions$", "directionRenderOptions"], outputs: ["mapActionEvent"] }, { kind: "component", type: i8.CreateItineraryHeaderComponent, selector: "app-create-itinerary-header", inputs: ["heading", "progressBarValue", "discardItineraryId", "class"] }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }] });
270
267
  }
271
268
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateItineraryDrawModeComponent, decorators: [{
272
269
  type: Component,
273
270
  args: [{ selector: 'lib-create-itinerary-draw-mode', standalone: false, template: "<app-create-itinerary-header\r\n [progressBarValue]=\"50\"\r\n heading=\"Create Itinerary\"\r\n></app-create-itinerary-header>\r\n<lib-map #libMap class=\"maps-100vh\"></lib-map>\r\n<lib-bottom-modal\r\n [showArrow]=\"true\"\r\n [(isOpen)]=\"isOpen\"\r\n [adaptToContentHeight]=\"true\"\r\n>\r\n <div class=\"\">\r\n <ng-container *ngIf=\"!mapDrawn\">\r\n <div class=\"flex items-center justify-between pl-4 pr-4\">\r\n <h3 class=\"font-Calistoga text-lg\">{{ \"ITINERARY.DRAW\" | translate }}</h3>\r\n <div class=\"selectables flex items-center\">\r\n <div\r\n (click)=\"updateAction(a)\"\r\n class=\"flex items-center justify-center actions\"\r\n *ngFor=\"let a of actions\"\r\n [ngClass]=\"{ selected: a === selected }\"\r\n >\r\n <img [src]=\"a\" alt=\"icon\" loading=\"lazy\" />\r\n </div>\r\n </div>\r\n </div>\r\n <p class=\"mt-3 px-4 mb-4\">{{ \"ITINERARY.DRAW_DESCRIPTION\" | translate }}</p>\r\n </ng-container>\r\n <ng-container *ngIf=\"mapDrawn\">\r\n <div class=\"ml-auto flex items-center justify-center gap-x-2\">\r\n <div class=\"flex items-center gap-x-1 text-xs\">\r\n <img\r\n loading=\"lazy\"\r\n [src]=\"ICONS['locationWhite']\"\r\n alt=\"location\"\r\n />\r\n <span>&nbsp;{{ \"ITINERARY.SELECT_MIN_PLACES\" | translate }}</span>\r\n </div>\r\n <div class=\"h-4 border w-0 border-secondary\"></div>\r\n <div class=\"flex items-center justify-center gap-x-2 text-xs\">\r\n <img loading=\"lazy\" [src]=\"ICONS['clock']\" alt=\"\" />\r\n <span>&nbsp;0 minutes</span>\r\n <span class=\"text-secondary font-thin\">(0.0 km)</span>\r\n </div>\r\n </div>\r\n <div class=\"select-places-description mt-5 text-center mb-4\">\r\n {{ \"ITINERARY.SELECT_PLACES_INSTRUCTION\" | translate }}\r\n </div>\r\n </ng-container>\r\n\r\n <lib-footer-shared\r\n (continueButtonClick)=\"continue()\"\r\n (secondaryButtonClick)=\"clearMap()\"\r\n [canContinue]=\"true\"\r\n [continueButtonText]=\"'COMMON.CONTINUE' | translate\"\r\n [secondaryButtonText]=\"'COMMON.CLEAR' | translate\"\r\n ></lib-footer-shared>\r\n </div>\r\n</lib-bottom-modal>\r\n<div\r\n (click)=\"showBottomModal()\"\r\n class=\"absolute bottom-0 cursor-pointer z-10\"\r\n style=\"left: 50%\"\r\n>\r\n <img\r\n style=\"transform: rotate(270deg)\"\r\n [src]=\"ICONS['rightArrow']\"\r\n alt=\"icon\"\r\n height=\"15\"\r\n width=\"15\"\r\n />\r\n</div>\r\n", styles: [":host{--lib-popup-modal-radius: 16px;--border-radius: var(--lib-popup-modal-radius);--lib-popup-modal-background: #28252d !important;--background: #28252d !important;--overflow: hidden !important;--lib-popup-modal-color: #a8a8a8;--color: var(--lib-popup-modal-color, #a8a8a8);--max-width: var(--lib-bottom-modal-max-width, 500px);--lib-popup-modal-shadow: 5px 5px 95px 0px rgba(255, 255, 255, .32), -3px -3px 16px 0px rgba(255, 255, 255, .1) !important;--box-shadow: var( --lib-popup-modal-shadow, 5px 5px 95px 0px rgba(255, 255, 255, .32), -3px -3px 16px 0px rgba(255, 255, 255, .1) )}.selectables{background:#28252d;box-shadow:4.1px 4.1px 8.2px #00000052 inset;box-shadow:-2.46px -2.46px 3.28px #ffffff1a inset;border-radius:27.9px}.actions{width:42px;height:28px;border-radius:82.05px}.selected{background:linear-gradient(94.44deg,#fe3c72 1.26%,#e15561);box-shadow:3.28px 3.28px 6.56px #00000040;box-shadow:-1.64px -1.64px 8.2px #ffffff40}.select-places-text,.select-places-description{font-size:var(--font-size-small)}.button-container{background-color:#27242c;box-shadow:inset 0 6px 6px -6px #8a8a8aab}\n"] }]
274
- }], ctorParameters: () => [{ type: i1.Location }, { type: i0.ChangeDetectorRef }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i3.ItineraryService }, { type: i4.LocationService }, { type: i5.ItineraryDrawModeTransferService }], propDecorators: { libMap: [{
271
+ }], ctorParameters: () => [{ type: i1.Location }, { type: i0.ChangeDetectorRef }, { type: i2.ActivatedRoute }, { type: i3.ItineraryService }, { type: i4.LocationService }, { type: i5.ItineraryDrawModeTransferService }, { type: i6.NavigationHelperService }], propDecorators: { libMap: [{
275
272
  type: ViewChild,
276
273
  args: ['libMap']
277
274
  }] } });
278
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-itinerary-draw-mode.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/itinerary-lib/src/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-draw-mode/create-itinerary-draw-mode.component.ts","../../../../../../../../../../../projects/itinerary-lib/src/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-draw-mode/create-itinerary-draw-mode.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Location } from '@angular/common';\r\nimport { ChangeDetectorRef, Component, ViewChild } from '@angular/core';\r\nimport { ICONS } from '../../../../../../_constants/constants';\r\nimport { Iicon } from '../../../../../../_interface/icon';\r\nimport { Itinerary } from '../../../../../../_models/Itinerary';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { ItineraryService } from '../../../../../../_services/itinerary.service';\r\nimport { ItinerariesRoutesEnum } from '../../../../../../_enums/ItenariesRoutes.enum';\r\nimport { LibMapsComponent } from '@naniteninja/ionic-lib';\r\nimport { LocationService } from '../../../../../../_services/location.service';\r\nimport { ItineraryDrawModeTransferService } from '../../../../../../_services/itinerary.drawmode.transfer';\r\nconst defaultIcon = 'assets/icons/map-markers-yellow.svg';\r\nconst selectedIcon = 'assets/icons/restu-icon-large.svg';\r\n\r\n@Component({\r\n    selector: 'lib-create-itinerary-draw-mode',\r\n    templateUrl: './create-itinerary-draw-mode.component.html',\r\n    styleUrl: './create-itinerary-draw-mode.component.css',\r\n    standalone: false\r\n})\r\nexport class CreateItineraryDrawModeComponent {\r\n  ICONS: Iicon = ICONS;\r\n  actions: string[] = [ICONS['location'], ICONS['pencil'], ICONS['ban']];\r\n  selected: string = this.actions[1];\r\n  isOpen: boolean = true;\r\n  itinerary!: Itinerary | undefined;\r\n  @ViewChild('libMap') libMap!: LibMapsComponent;\r\n  mapDrawn: boolean = false;\r\n\r\n  polygon!: google.maps.Polygon;//The polygon rendered on map\r\n  initialLocation = { lat: 24.8607, lng: 67.0011 };//Location of the user\r\n  plottedMarkers: google.maps.Marker[] = [];//Plotted markers on the map\r\n  selectedMarkers: google.maps.Marker[] = [];//Selected markers on the map\r\n  placesResult!: google.maps.places.PlaceResult[];//Places result required for preview\r\n  placeMarkers: {\r\n    marker: google.maps.Marker,\r\n    place: google.maps.places.PlaceResult\r\n  }[] = [];\r\n\r\n  //LIFE CYCLES\r\n  constructor(\r\n    private location: Location,\r\n    private cdr: ChangeDetectorRef,\r\n    private router: Router,\r\n    private activatedRoute: ActivatedRoute,\r\n    private itineraryService: ItineraryService,\r\n    private locationService: LocationService,\r\n    private transferService: ItineraryDrawModeTransferService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    const id = this.activatedRoute.snapshot.params['id'];\r\n    if (id) {\r\n      this.itinerary = this.itineraryService.getById(id);\r\n    }\r\n  }\r\n\r\n  //UI LOGIC\r\n  updateAction(action: string) {\r\n    this.selected = action;\r\n    if(action === this.actions[0]) {\r\n      this.router.navigate([\r\n        ItinerariesRoutesEnum.ITINERARY,\r\n        ItinerariesRoutesEnum.CREATE_ITINERARY_ORIGIN,\r\n        this.itinerary?.id\r\n      ]);\r\n    }\r\n    if(action === this.actions[2]) {\r\n      this.router.navigate([\r\n        ItinerariesRoutesEnum.ITINERARY,\r\n        ItinerariesRoutesEnum.CREATE_ITINERARY_NO_VISUAL_FILTER_MODE,\r\n        ItinerariesRoutesEnum.CREATE_ITINERARY_NO_VISUAL_FILTER_MODE_CREATE,\r\n        this.itinerary?.id\r\n      ]);\r\n    }\r\n  }\r\n\r\n  showBottomModal(): void {\r\n    this.isOpen = true;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  searchRestaurantsInPolygon(\r\n    polygonCoords:\r\n      | Array<{\r\n          lat: number;\r\n          lng: number;\r\n        }>\r\n      | undefined,\r\n  ) {\r\n    if (polygonCoords) {\r\n      this.mapDrawn = true;\r\n      const bounds = new google.maps.LatLngBounds();\r\n      polygonCoords.forEach((coord) => bounds.extend(coord));\r\n\r\n      const service = new google.maps.places.PlacesService(\r\n        this.libMap.map.googleMap!,\r\n      );\r\n\r\n      service.nearbySearch(\r\n        {\r\n          bounds: bounds,\r\n          type: 'restaurant',\r\n        },\r\n        (\r\n          results: google.maps.places.PlaceResult[] | null,\r\n          status: google.maps.places.PlacesServiceStatus,\r\n        ) => {\r\n          if (status === google.maps.places.PlacesServiceStatus.OK && results) {\r\n            const filteredResults = results.filter((place) => {\r\n              const location = place.geometry?.location;\r\n              if (!location) return false;\r\n              return google.maps.geometry.poly.containsLocation(location, this.polygon);\r\n            });\r\n\r\n            this.placesResult = filteredResults;\r\n            filteredResults.forEach((place: google.maps.places.PlaceResult) => {\r\n              this.addCustomMarker(place);\r\n            });\r\n            this.mapDrawn = true;\r\n          }\r\n        },\r\n      );\r\n    }\r\n  }\r\n\r\n  addCustomMarker(place: google.maps.places.PlaceResult) {\r\n    const marker = new google.maps.Marker({\r\n      map: this.libMap.map.googleMap,\r\n      position: place.geometry?.location,\r\n      title: place.name,\r\n      icon: {\r\n        url: 'assets/icons/map-markers-yellow.svg',\r\n      },\r\n    });\r\n    this.plottedMarkers.push(marker);\r\n    this.placeMarkers.push({\r\n      place: place,\r\n      marker: marker\r\n    });\r\n    marker.addListener('click', () => {\r\n      // Toggle selection\r\n      const index = this.selectedMarkers.indexOf(marker);\r\n\r\n      if (index > -1) {\r\n        // Marker was already selected → deselect\r\n        marker.setIcon(defaultIcon);\r\n        this.selectedMarkers.splice(index, 1);\r\n      } else {\r\n        // Select marker\r\n        marker.setIcon(selectedIcon);\r\n        this.selectedMarkers.push(marker);\r\n      }\r\n    });\r\n  }\r\n\r\n  clearMap() {\r\n    this.mapDrawn = false;\r\n    if(this.polygon) {\r\n      this.polygon.setMap(null);\r\n    }\r\n    this.clearMarkers();\r\n  }\r\n\r\n  continue() {\r\n    const coordinates: Array<{ lat: number; lng: number }> = [];\r\n    this.polygon.getPath().forEach(coord => {\r\n      coordinates.push({ lat: coord.lat(), lng: coord.lng() });\r\n    });\r\n    this.transferService.setPolygon(coordinates);\r\n\r\n    const selectedPlaces = this.selectedMarkers.map((selectedMarker) => {\r\n      const placeMarker = this.placeMarkers.find(placeMarker => placeMarker.marker === selectedMarker);\r\n      return placeMarker!.place;\r\n    });\r\n\r\n    const allPlaces = this.placeMarkers.map(placeMarker => placeMarker.place);\r\n\r\n    this.transferService.setPlaces(allPlaces);\r\n    this.transferService.setSelectedPlaces(selectedPlaces);\r\n    this.transferService.setCurrentLocation(this.initialLocation);\r\n\r\n    this.router.navigate([\r\n      ItinerariesRoutesEnum.ITINERARY,\r\n      ItinerariesRoutesEnum.CREATE_ITINERARY_DRAW_MODE,\r\n      ItinerariesRoutesEnum.CREATE_ITINERARY_DRAW_MODE_PREVIEW,\r\n      this.itinerary?.id\r\n    ]);\r\n  }\r\n\r\n  clearPolygonIfExist() {\r\n    if(this.polygon) {\r\n      this.polygon.setMap(null);\r\n    }\r\n  }\r\n\r\n  clearMarkers() {\r\n    if(this.plottedMarkers?.length) {\r\n      this.plottedMarkers?.forEach((plottedMarker) => plottedMarker.setMap(null));\r\n    } \r\n  }\r\n\r\n  ngAfterViewInit() {\r\n      this.locationService.getCurrentLocation()\r\n      .subscribe((location) => {\r\n        this.libMap.map.googleMap?.setCenter({\r\n          lat: location.lat,\r\n          lng: location.long\r\n        });\r\n\r\n        //Set the initial location of the user\r\n        this.initialLocation = {\r\n          lat: location.lat,\r\n          lng: location.long\r\n        }\r\n        this.libMap.map.googleMap?.setZoom(15);\r\n\r\n        //Add marker for user position\r\n        new google.maps.Marker({\r\n          map: this.libMap.map.googleMap,\r\n          position: {\r\n            lat: location.lat,\r\n            lng: location.long\r\n          },\r\n          title: 'You are here',\r\n          icon: {\r\n            url: 'assets/current_location.svg',\r\n            scaledSize: new google.maps.Size(40, 40),\r\n          },\r\n        });\r\n\r\n        // Enable polygon drawing\r\n        const drawingManager = new google.maps.drawing.DrawingManager({\r\n          drawingMode: google.maps.drawing.OverlayType.POLYGON,\r\n          drawingControl: true,\r\n          drawingControlOptions: {\r\n            position: google.maps.ControlPosition.RIGHT_CENTER,\r\n            drawingModes: [google.maps.drawing.OverlayType.POLYGON],\r\n          },\r\n          polygonOptions: {\r\n            strokeColor: '#E17575',\r\n            strokeOpacity: 0,\r\n            strokeWeight: 0,\r\n            fillColor: '#E17575',\r\n            fillOpacity: 0.3,\r\n            clickable: true,\r\n            editable: true,\r\n            zIndex: 1,\r\n          },\r\n        });\r\n        drawingManager.setMap(this.libMap.map.googleMap!);\r\n\r\n        google.maps.event.addListener(drawingManager, 'drawingmode_changed', () => {\r\n          const mode = drawingManager.getDrawingMode();\r\n          if (mode === google.maps.drawing.OverlayType.POLYGON) {\r\n            this.clearPolygonIfExist();\r\n          }\r\n        });\r\n\r\n        // Listen for polygon completion\r\n        google.maps.event.addListener(drawingManager, 'overlaycomplete', (event: google.maps.drawing.OverlayCompleteEvent) => {\r\n          if (event.type === google.maps.drawing.OverlayType.POLYGON) {\r\n            const polygon = event.overlay as google.maps.Polygon;\r\n            this.polygon = polygon;\r\n            // Disable drawing after one polygon\r\n            drawingManager.setDrawingMode(null);\r\n\r\n            // Access the polygon coordinates\r\n            const path = polygon.getPath();\r\n            const coordinates: Array<{ lat: number; lng: number }> = [];\r\n            path.forEach((coord: google.maps.LatLng) => {\r\n              coordinates.push({ lat: coord.lat(), lng: coord.lng() });\r\n            });\r\n\r\n            this.searchRestaurantsInPolygon(coordinates);\r\n          }\r\n        });\r\n    });\r\n  }\r\n\r\n  //NAVIGATIONS\r\n  back(): void {\r\n    this.location.back();\r\n  }\r\n\r\n  navToPickStartLocation() {\r\n    this.router.navigate(\r\n      [\r\n        ItinerariesRoutesEnum.ITINERARY,\r\n        ItinerariesRoutesEnum.LOCATION_PICKER,\r\n        this.itinerary?.id,\r\n      ],\r\n      { queryParams: { mode: 'start' } },\r\n    );\r\n  }\r\n\r\n  getClosestPointOnPolygon(polygon: google.maps.Polygon, point: google.maps.LatLng): google.maps.LatLng {\r\n    const path = polygon.getPath();\r\n    let closestPoint = null;\r\n    let minDistance = Infinity;\r\n\r\n    for (let i = 0; i < path.getLength(); i++) {\r\n      const start = path.getAt(i);\r\n      const end = path.getAt((i + 1) % path.getLength());\r\n\r\n      // Interpolate points along the segment\r\n      for (let t = 0; t <= 1; t += 0.05) {\r\n        const interp = google.maps.geometry.spherical.interpolate(start, end, t);\r\n        const dist = google.maps.geometry.spherical.computeDistanceBetween(point, interp);\r\n        if (dist < minDistance) {\r\n          minDistance = dist;\r\n          closestPoint = interp;\r\n        }\r\n      }\r\n    }\r\n\r\n    return closestPoint!;\r\n  }\r\n}\r\n","<app-create-itinerary-header\r\n  [progressBarValue]=\"50\"\r\n  heading=\"Create Itinerary\"\r\n></app-create-itinerary-header>\r\n<lib-map #libMap class=\"maps-100vh\"></lib-map>\r\n<lib-bottom-modal\r\n  [showArrow]=\"true\"\r\n  [(isOpen)]=\"isOpen\"\r\n  [adaptToContentHeight]=\"true\"\r\n>\r\n  <div class=\"\">\r\n    <ng-container *ngIf=\"!mapDrawn\">\r\n      <div class=\"flex items-center justify-between pl-4 pr-4\">\r\n        <h3 class=\"font-Calistoga text-lg\">{{ \"ITINERARY.DRAW\" | translate }}</h3>\r\n        <div class=\"selectables flex items-center\">\r\n          <div\r\n            (click)=\"updateAction(a)\"\r\n            class=\"flex items-center justify-center actions\"\r\n            *ngFor=\"let a of actions\"\r\n            [ngClass]=\"{ selected: a === selected }\"\r\n          >\r\n            <img [src]=\"a\" alt=\"icon\" loading=\"lazy\" />\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <p class=\"mt-3 px-4 mb-4\">{{ \"ITINERARY.DRAW_DESCRIPTION\" | translate }}</p>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"mapDrawn\">\r\n      <div class=\"ml-auto flex items-center justify-center gap-x-2\">\r\n        <div class=\"flex items-center gap-x-1 text-xs\">\r\n            <img\r\n            loading=\"lazy\"\r\n            [src]=\"ICONS['locationWhite']\"\r\n            alt=\"location\"\r\n            />\r\n            <span>&nbsp;{{ \"ITINERARY.SELECT_MIN_PLACES\" | translate }}</span>\r\n        </div>\r\n        <div class=\"h-4 border w-0 border-secondary\"></div>\r\n        <div class=\"flex items-center justify-center gap-x-2 text-xs\">\r\n            <img loading=\"lazy\" [src]=\"ICONS['clock']\" alt=\"\" />\r\n            <span>&nbsp;0 minutes</span>\r\n            <span class=\"text-secondary font-thin\">(0.0 km)</span>\r\n        </div>\r\n      </div>\r\n      <div class=\"select-places-description mt-5 text-center mb-4\">\r\n        {{ \"ITINERARY.SELECT_PLACES_INSTRUCTION\" | translate }}\r\n      </div>\r\n    </ng-container>\r\n\r\n    <lib-footer-shared\r\n    (continueButtonClick)=\"continue()\"\r\n    (secondaryButtonClick)=\"clearMap()\"\r\n    [canContinue]=\"true\"\r\n    [continueButtonText]=\"'COMMON.CONTINUE' | translate\"\r\n    [secondaryButtonText]=\"'COMMON.CLEAR' | translate\"\r\n    ></lib-footer-shared>\r\n  </div>\r\n</lib-bottom-modal>\r\n<div\r\n  (click)=\"showBottomModal()\"\r\n  class=\"absolute bottom-0 cursor-pointer z-10\"\r\n  style=\"left: 50%\"\r\n>\r\n  <img\r\n    style=\"transform: rotate(270deg)\"\r\n    [src]=\"ICONS['rightArrow']\"\r\n    alt=\"icon\"\r\n    height=\"15\"\r\n    width=\"15\"\r\n  />\r\n</div>\r\n"]}
275
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-itinerary-draw-mode.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/itinerary-lib/src/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-draw-mode/create-itinerary-draw-mode.component.ts","../../../../../../../../../../../projects/itinerary-lib/src/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-draw-mode/create-itinerary-draw-mode.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Location } from '@angular/common';\r\nimport { ChangeDetectorRef, Component, ViewChild } from '@angular/core';\r\nimport { ICONS } from '../../../../../../_constants/constants';\r\nimport { Iicon } from '../../../../../../_interface/icon';\r\nimport { Itinerary } from '../../../../../../_models/Itinerary';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { ItineraryService } from '../../../../../../_services/itinerary.service';\r\nimport { ItinerariesRoutesEnum } from '../../../../../../_enums/ItenariesRoutes.enum';\r\nimport { LibMapsComponent } from '@naniteninja/ionic-lib';\r\nimport { LocationService } from '../../../../../../_services/location.service';\r\nimport { ItineraryDrawModeTransferService } from '../../../../../../_services/itinerary.drawmode.transfer';\r\nimport { NavigationHelperService } from '../../../../../../_services/navigation-helper.service';\r\nconst defaultIcon = 'assets/icons/map-markers-yellow.svg';\r\nconst selectedIcon = 'assets/icons/restu-icon-large.svg';\r\n\r\n@Component({\r\n    selector: 'lib-create-itinerary-draw-mode',\r\n    templateUrl: './create-itinerary-draw-mode.component.html',\r\n    styleUrl: './create-itinerary-draw-mode.component.css',\r\n    standalone: false\r\n})\r\nexport class CreateItineraryDrawModeComponent {\r\n  ICONS: Iicon = ICONS;\r\n  actions: string[] = [ICONS['location'], ICONS['pencil'], ICONS['ban']];\r\n  selected: string = this.actions[1];\r\n  isOpen: boolean = true;\r\n  itinerary!: Itinerary | undefined;\r\n  @ViewChild('libMap') libMap!: LibMapsComponent;\r\n  mapDrawn: boolean = false;\r\n\r\n  polygon!: google.maps.Polygon;//The polygon rendered on map\r\n  initialLocation = { lat: 24.8607, lng: 67.0011 };//Location of the user\r\n  plottedMarkers: google.maps.Marker[] = [];//Plotted markers on the map\r\n  selectedMarkers: google.maps.Marker[] = [];//Selected markers on the map\r\n  placesResult!: google.maps.places.PlaceResult[];//Places result required for preview\r\n  placeMarkers: {\r\n    marker: google.maps.Marker,\r\n    place: google.maps.places.PlaceResult\r\n  }[] = [];\r\n\r\n  //LIFE CYCLES\r\n  constructor(\r\n    private location: Location,\r\n    private cdr: ChangeDetectorRef,\r\n    private activatedRoute: ActivatedRoute,\r\n    private itineraryService: ItineraryService,\r\n    private locationService: LocationService,\r\n    private transferService: ItineraryDrawModeTransferService,\r\n    private navHelper: NavigationHelperService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    const id = this.activatedRoute.snapshot.params['id'];\r\n    if (id) {\r\n      this.itinerary = this.itineraryService.getById(id);\r\n    }\r\n  }\r\n\r\n  //UI LOGIC\r\n  updateAction(action: string) {\r\n    this.selected = action;\r\n    if(action === this.actions[0]) {\r\n      this.navHelper.navigate([\r\n        ItinerariesRoutesEnum.CREATE_ITINERARY_ORIGIN,\r\n        this.itinerary!.id\r\n      ], this.activatedRoute);\r\n    }\r\n    if(action === this.actions[2]) {\r\n      this.navHelper.navigate([\r\n        ItinerariesRoutesEnum.CREATE_ITINERARY_NO_VISUAL_FILTER_MODE,\r\n        ItinerariesRoutesEnum.CREATE_ITINERARY_NO_VISUAL_FILTER_MODE_CREATE,\r\n        this.itinerary!.id\r\n      ], this.activatedRoute);\r\n    }\r\n  }\r\n\r\n  showBottomModal(): void {\r\n    this.isOpen = true;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  searchRestaurantsInPolygon(\r\n    polygonCoords:\r\n      | Array<{\r\n          lat: number;\r\n          lng: number;\r\n        }>\r\n      | undefined,\r\n  ) {\r\n    if (polygonCoords) {\r\n      this.mapDrawn = true;\r\n      const bounds = new google.maps.LatLngBounds();\r\n      polygonCoords.forEach((coord) => bounds.extend(coord));\r\n\r\n      const service = new google.maps.places.PlacesService(\r\n        this.libMap.map.googleMap!,\r\n      );\r\n\r\n      service.nearbySearch(\r\n        {\r\n          bounds: bounds,\r\n          type: 'restaurant',\r\n        },\r\n        (\r\n          results: google.maps.places.PlaceResult[] | null,\r\n          status: google.maps.places.PlacesServiceStatus,\r\n        ) => {\r\n          if (status === google.maps.places.PlacesServiceStatus.OK && results) {\r\n            const filteredResults = results.filter((place) => {\r\n              const location = place.geometry?.location;\r\n              if (!location) return false;\r\n              return google.maps.geometry.poly.containsLocation(location, this.polygon);\r\n            });\r\n\r\n            this.placesResult = filteredResults;\r\n            filteredResults.forEach((place: google.maps.places.PlaceResult) => {\r\n              this.addCustomMarker(place);\r\n            });\r\n            this.mapDrawn = true;\r\n          }\r\n        },\r\n      );\r\n    }\r\n  }\r\n\r\n  addCustomMarker(place: google.maps.places.PlaceResult) {\r\n    const marker = new google.maps.Marker({\r\n      map: this.libMap.map.googleMap,\r\n      position: place.geometry?.location,\r\n      title: place.name,\r\n      icon: {\r\n        url: 'assets/icons/map-markers-yellow.svg',\r\n      },\r\n    });\r\n    this.plottedMarkers.push(marker);\r\n    this.placeMarkers.push({\r\n      place: place,\r\n      marker: marker\r\n    });\r\n    marker.addListener('click', () => {\r\n      // Toggle selection\r\n      const index = this.selectedMarkers.indexOf(marker);\r\n\r\n      if (index > -1) {\r\n        // Marker was already selected → deselect\r\n        marker.setIcon(defaultIcon);\r\n        this.selectedMarkers.splice(index, 1);\r\n      } else {\r\n        // Select marker\r\n        marker.setIcon(selectedIcon);\r\n        this.selectedMarkers.push(marker);\r\n      }\r\n    });\r\n  }\r\n\r\n  clearMap() {\r\n    this.mapDrawn = false;\r\n    if(this.polygon) {\r\n      this.polygon.setMap(null);\r\n    }\r\n    this.clearMarkers();\r\n  }\r\n\r\n  continue() {\r\n    const coordinates: Array<{ lat: number; lng: number }> = [];\r\n    this.polygon.getPath().forEach(coord => {\r\n      coordinates.push({ lat: coord.lat(), lng: coord.lng() });\r\n    });\r\n    this.transferService.setPolygon(coordinates);\r\n\r\n    const selectedPlaces = this.selectedMarkers.map((selectedMarker) => {\r\n      const placeMarker = this.placeMarkers.find(placeMarker => placeMarker.marker === selectedMarker);\r\n      return placeMarker!.place;\r\n    });\r\n\r\n    const allPlaces = this.placeMarkers.map(placeMarker => placeMarker.place);\r\n\r\n    this.transferService.setPlaces(allPlaces);\r\n    this.transferService.setSelectedPlaces(selectedPlaces);\r\n    this.transferService.setCurrentLocation(this.initialLocation);\r\n\r\n    this.navHelper.navigate([\r\n      ItinerariesRoutesEnum.CREATE_ITINERARY_DRAW_MODE,\r\n      ItinerariesRoutesEnum.CREATE_ITINERARY_DRAW_MODE_PREVIEW,\r\n      this.itinerary!.id\r\n    ], this.activatedRoute);\r\n  }\r\n\r\n  clearPolygonIfExist() {\r\n    if(this.polygon) {\r\n      this.polygon.setMap(null);\r\n    }\r\n  }\r\n\r\n  clearMarkers() {\r\n    if(this.plottedMarkers?.length) {\r\n      this.plottedMarkers?.forEach((plottedMarker) => plottedMarker.setMap(null));\r\n    } \r\n  }\r\n\r\n  ngAfterViewInit() {\r\n      this.locationService.getCurrentLocation()\r\n      .subscribe((location) => {\r\n        this.libMap.map.googleMap?.setCenter({\r\n          lat: location.lat,\r\n          lng: location.long\r\n        });\r\n\r\n        //Set the initial location of the user\r\n        this.initialLocation = {\r\n          lat: location.lat,\r\n          lng: location.long\r\n        }\r\n        this.libMap.map.googleMap?.setZoom(15);\r\n\r\n        //Add marker for user position\r\n        new google.maps.Marker({\r\n          map: this.libMap.map.googleMap,\r\n          position: {\r\n            lat: location.lat,\r\n            lng: location.long\r\n          },\r\n          title: 'You are here',\r\n          icon: {\r\n            url: 'assets/current_location.svg',\r\n            scaledSize: new google.maps.Size(40, 40),\r\n          },\r\n        });\r\n\r\n        // Enable polygon drawing\r\n        const drawingManager = new google.maps.drawing.DrawingManager({\r\n          drawingMode: google.maps.drawing.OverlayType.POLYGON,\r\n          drawingControl: true,\r\n          drawingControlOptions: {\r\n            position: google.maps.ControlPosition.RIGHT_CENTER,\r\n            drawingModes: [google.maps.drawing.OverlayType.POLYGON],\r\n          },\r\n          polygonOptions: {\r\n            strokeColor: '#E17575',\r\n            strokeOpacity: 0,\r\n            strokeWeight: 0,\r\n            fillColor: '#E17575',\r\n            fillOpacity: 0.3,\r\n            clickable: true,\r\n            editable: true,\r\n            zIndex: 1,\r\n          },\r\n        });\r\n        drawingManager.setMap(this.libMap.map.googleMap!);\r\n\r\n        google.maps.event.addListener(drawingManager, 'drawingmode_changed', () => {\r\n          const mode = drawingManager.getDrawingMode();\r\n          if (mode === google.maps.drawing.OverlayType.POLYGON) {\r\n            this.clearPolygonIfExist();\r\n          }\r\n        });\r\n\r\n        // Listen for polygon completion\r\n        google.maps.event.addListener(drawingManager, 'overlaycomplete', (event: google.maps.drawing.OverlayCompleteEvent) => {\r\n          if (event.type === google.maps.drawing.OverlayType.POLYGON) {\r\n            const polygon = event.overlay as google.maps.Polygon;\r\n            this.polygon = polygon;\r\n            // Disable drawing after one polygon\r\n            drawingManager.setDrawingMode(null);\r\n\r\n            // Access the polygon coordinates\r\n            const path = polygon.getPath();\r\n            const coordinates: Array<{ lat: number; lng: number }> = [];\r\n            path.forEach((coord: google.maps.LatLng) => {\r\n              coordinates.push({ lat: coord.lat(), lng: coord.lng() });\r\n            });\r\n\r\n            this.searchRestaurantsInPolygon(coordinates);\r\n          }\r\n        });\r\n    });\r\n  }\r\n\r\n  //NAVIGATIONS\r\n  back(): void {\r\n    this.location.back();\r\n  }\r\n\r\n  navToPickStartLocation() {\r\n    this.navHelper.navigate(\r\n      [\r\n        ItinerariesRoutesEnum.LOCATION_PICKER,\r\n        this.itinerary!.id,\r\n      ],\r\n      this.activatedRoute,\r\n      { queryParams: { mode: 'start' } }\r\n    );\r\n  }\r\n\r\n  getClosestPointOnPolygon(polygon: google.maps.Polygon, point: google.maps.LatLng): google.maps.LatLng {\r\n    const path = polygon.getPath();\r\n    let closestPoint = null;\r\n    let minDistance = Infinity;\r\n\r\n    for (let i = 0; i < path.getLength(); i++) {\r\n      const start = path.getAt(i);\r\n      const end = path.getAt((i + 1) % path.getLength());\r\n\r\n      // Interpolate points along the segment\r\n      for (let t = 0; t <= 1; t += 0.05) {\r\n        const interp = google.maps.geometry.spherical.interpolate(start, end, t);\r\n        const dist = google.maps.geometry.spherical.computeDistanceBetween(point, interp);\r\n        if (dist < minDistance) {\r\n          minDistance = dist;\r\n          closestPoint = interp;\r\n        }\r\n      }\r\n    }\r\n\r\n    return closestPoint!;\r\n  }\r\n}\r\n","<app-create-itinerary-header\r\n  [progressBarValue]=\"50\"\r\n  heading=\"Create Itinerary\"\r\n></app-create-itinerary-header>\r\n<lib-map #libMap class=\"maps-100vh\"></lib-map>\r\n<lib-bottom-modal\r\n  [showArrow]=\"true\"\r\n  [(isOpen)]=\"isOpen\"\r\n  [adaptToContentHeight]=\"true\"\r\n>\r\n  <div class=\"\">\r\n    <ng-container *ngIf=\"!mapDrawn\">\r\n      <div class=\"flex items-center justify-between pl-4 pr-4\">\r\n        <h3 class=\"font-Calistoga text-lg\">{{ \"ITINERARY.DRAW\" | translate }}</h3>\r\n        <div class=\"selectables flex items-center\">\r\n          <div\r\n            (click)=\"updateAction(a)\"\r\n            class=\"flex items-center justify-center actions\"\r\n            *ngFor=\"let a of actions\"\r\n            [ngClass]=\"{ selected: a === selected }\"\r\n          >\r\n            <img [src]=\"a\" alt=\"icon\" loading=\"lazy\" />\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <p class=\"mt-3 px-4 mb-4\">{{ \"ITINERARY.DRAW_DESCRIPTION\" | translate }}</p>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"mapDrawn\">\r\n      <div class=\"ml-auto flex items-center justify-center gap-x-2\">\r\n        <div class=\"flex items-center gap-x-1 text-xs\">\r\n            <img\r\n            loading=\"lazy\"\r\n            [src]=\"ICONS['locationWhite']\"\r\n            alt=\"location\"\r\n            />\r\n            <span>&nbsp;{{ \"ITINERARY.SELECT_MIN_PLACES\" | translate }}</span>\r\n        </div>\r\n        <div class=\"h-4 border w-0 border-secondary\"></div>\r\n        <div class=\"flex items-center justify-center gap-x-2 text-xs\">\r\n            <img loading=\"lazy\" [src]=\"ICONS['clock']\" alt=\"\" />\r\n            <span>&nbsp;0 minutes</span>\r\n            <span class=\"text-secondary font-thin\">(0.0 km)</span>\r\n        </div>\r\n      </div>\r\n      <div class=\"select-places-description mt-5 text-center mb-4\">\r\n        {{ \"ITINERARY.SELECT_PLACES_INSTRUCTION\" | translate }}\r\n      </div>\r\n    </ng-container>\r\n\r\n    <lib-footer-shared\r\n    (continueButtonClick)=\"continue()\"\r\n    (secondaryButtonClick)=\"clearMap()\"\r\n    [canContinue]=\"true\"\r\n    [continueButtonText]=\"'COMMON.CONTINUE' | translate\"\r\n    [secondaryButtonText]=\"'COMMON.CLEAR' | translate\"\r\n    ></lib-footer-shared>\r\n  </div>\r\n</lib-bottom-modal>\r\n<div\r\n  (click)=\"showBottomModal()\"\r\n  class=\"absolute bottom-0 cursor-pointer z-10\"\r\n  style=\"left: 50%\"\r\n>\r\n  <img\r\n    style=\"transform: rotate(270deg)\"\r\n    [src]=\"ICONS['rightArrow']\"\r\n    alt=\"icon\"\r\n    height=\"15\"\r\n    width=\"15\"\r\n  />\r\n</div>\r\n"]}