@flower-city-online/itinerary-lib 0.0.51 → 0.0.54
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/esm2022/lib/itinerary-app/_services/bottom-navigation.service.mjs +8 -8
- package/esm2022/lib/itinerary-app/_services/navigation-helper.service.mjs +128 -0
- package/esm2022/lib/itinerary-app/modules/archives/pages/main-archives/main-archives.component.mjs +20 -17
- package/esm2022/lib/itinerary-app/modules/dashboard/components/navbar/navbar.component.mjs +5 -4
- package/esm2022/lib/itinerary-app/modules/itineraries/components/app-header-desktop/app-header-desktop.component.mjs +6 -5
- package/esm2022/lib/itinerary-app/modules/itineraries/components/share-popup/share-popup.component.mjs +6 -5
- package/esm2022/lib/itinerary-app/modules/itineraries/itineraries.component.mjs +18 -15
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/advanced-filters/advanced-filters.component.mjs +5 -4
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/branched-itineraries/branched-itineraries.component.mjs +23 -45
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/builder.component.mjs +22 -23
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary/create-itinerary.component.mjs +21 -20
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-destination/create-itinerary-destination.component.mjs +5 -4
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-draw-mode/create-itinerary-draw-mode.component.mjs +25 -27
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-draw-preview/create-itinerary-draw-preview.component.mjs +7 -6
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-header/create-itinerary-header.component.mjs +3 -3
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-no-visual-filter/create-itinerary-no-visual-filter.component.mjs +8 -7
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-no-visual-preview/create-itinerary-no-visual-preview.component.mjs +7 -6
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-start-location/create-itinerary-start-location.component.mjs +6 -5
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-user-search/create-itinerary-user-search.component.mjs +4 -3
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/created-itinerary/created-itinerary.component.mjs +19 -16
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/created-itinerary-preview/created-itinerary-preview.component.mjs +12 -9
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/itinerary-add-place/itinerary-add-place.component.mjs +6 -5
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/location-picker/location-picker.component.mjs +19 -18
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/select-itinerary-event/select-itinerary-event.component.mjs +18 -15
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-location/suggested-events-location.component.mjs +19 -16
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-route-radius/suggested-events-route-radius.component.mjs +15 -14
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-route-type/suggested-events-route-type.component.mjs +18 -15
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/comment-replies/components/comment-single/comment-single.component.mjs +5 -4
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/comments/comment-comparison/comment-comparison.component.mjs +13 -10
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/comments/comment-search/comment-search.component.mjs +13 -10
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/comments/comments-page.component.mjs +15 -12
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/explore/explore.component.mjs +30 -44
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/components/details/details.component.mjs +28 -36
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/components/summary/summary.component.mjs +27 -31
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/itinerary-detail.component.mjs +22 -17
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-friends/existing-friends/existing-friends.component.mjs +4 -3
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-friends/list-friend-users/list-friend-users.component.mjs +5 -4
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-friends/send-friend-request/send-friend-request.component.mjs +5 -4
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-members/all-people/all-people.component.mjs +5 -4
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-members/existing-members/existing-members.component.mjs +4 -3
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-members/send-invite/send-invite.component.mjs +5 -4
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-members/user-list/user-list.component.mjs +18 -17
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-upvote-users/itinerary-upvote-users.component.mjs +17 -14
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-users/itinerary-users.component.mjs +14 -9
- package/esm2022/lib/itinerary-app/modules/itineraries/pages/itinerary-watching-users/itinerary-watching-users.component.mjs +14 -9
- package/esm2022/lib/itinerary-app/modules/search/pages/main-search/main-search.component.mjs +4 -4
- package/esm2022/lib/itinerary-app/shared/bottom-modal/bottom-modal.component.mjs +65 -0
- package/esm2022/lib/itinerary-app/shared/card-component/card-component.component.mjs +5 -4
- package/esm2022/lib/itinerary-app/shared/comment/comment.component.mjs +19 -18
- package/esm2022/lib/itinerary-app/shared/custom-story-card/custom-story-card.component.mjs +17 -12
- package/esm2022/lib/itinerary-app/shared/cutom-card/cutom-card.component.mjs +6 -5
- package/esm2022/lib/itinerary-app/shared/footer/footer.component.mjs +6 -6
- package/esm2022/lib/itinerary-app/shared/header/header.component.mjs +2 -2
- package/esm2022/lib/itinerary-app/shared/icon-button/icon-button.component.mjs +37 -10
- package/esm2022/lib/itinerary-app/shared/input-field-select/input-field-select.component.mjs +109 -0
- package/esm2022/lib/itinerary-app/shared/notification-tile/notification-tile.component.mjs +4 -4
- package/esm2022/lib/itinerary-app/shared/popup-modal/popup-modal.component.mjs +85 -0
- package/esm2022/lib/itinerary-app/shared/search-bar/search-bar.component.mjs +30 -0
- package/esm2022/lib/itinerary-app/shared/search-popup/search-popup.component.mjs +4 -4
- package/esm2022/lib/itinerary-app/shared/shared.module.mjs +29 -6
- package/fesm2022/flower-city-online-itinerary-lib.mjs +1009 -594
- package/fesm2022/flower-city-online-itinerary-lib.mjs.map +1 -1
- package/lib/itinerary-app/_services/bottom-navigation.service.d.ts +3 -3
- package/lib/itinerary-app/_services/navigation-helper.service.d.ts +19 -0
- package/lib/itinerary-app/modules/archives/pages/main-archives/main-archives.component.d.ts +5 -3
- package/lib/itinerary-app/modules/itineraries/itineraries.component.d.ts +3 -1
- package/lib/itinerary-app/modules/itineraries/pages/branched-itineraries/branched-itineraries.component.d.ts +4 -3
- package/lib/itinerary-app/modules/itineraries/pages/builder/builder.component.d.ts +5 -3
- package/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary/create-itinerary.component.d.ts +5 -3
- package/lib/itinerary-app/modules/itineraries/pages/builder/pages/create-itinerary-draw-mode/create-itinerary-draw-mode.component.d.ts +4 -3
- package/lib/itinerary-app/modules/itineraries/pages/builder/pages/created-itinerary/created-itinerary.component.d.ts +4 -3
- package/lib/itinerary-app/modules/itineraries/pages/builder/pages/created-itinerary-preview/created-itinerary-preview.component.d.ts +3 -1
- package/lib/itinerary-app/modules/itineraries/pages/builder/pages/location-picker/location-picker.component.d.ts +4 -3
- package/lib/itinerary-app/modules/itineraries/pages/builder/pages/select-itinerary-event/select-itinerary-event.component.d.ts +4 -3
- package/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-location/suggested-events-location.component.d.ts +4 -3
- package/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-route-radius/suggested-events-route-radius.component.d.ts +4 -3
- package/lib/itinerary-app/modules/itineraries/pages/builder/pages/suggested-events-route-type/suggested-events-route-type.component.d.ts +4 -3
- package/lib/itinerary-app/modules/itineraries/pages/comments/comment-comparison/comment-comparison.component.d.ts +5 -3
- package/lib/itinerary-app/modules/itineraries/pages/comments/comment-search/comment-search.component.d.ts +5 -3
- package/lib/itinerary-app/modules/itineraries/pages/comments/comments-page.component.d.ts +3 -1
- package/lib/itinerary-app/modules/itineraries/pages/explore/explore.component.d.ts +5 -3
- package/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/components/details/details.component.d.ts +6 -4
- package/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/components/summary/summary.component.d.ts +5 -3
- package/lib/itinerary-app/modules/itineraries/pages/itinerary-detail/itinerary-detail.component.d.ts +5 -2
- package/lib/itinerary-app/modules/itineraries/pages/itinerary-members/user-list/user-list.component.d.ts +5 -3
- package/lib/itinerary-app/modules/itineraries/pages/itinerary-upvote-users/itinerary-upvote-users.component.d.ts +5 -3
- package/lib/itinerary-app/modules/itineraries/pages/itinerary-users/itinerary-users.component.d.ts +5 -2
- package/lib/itinerary-app/modules/itineraries/pages/itinerary-watching-users/itinerary-watching-users.component.d.ts +5 -2
- package/lib/itinerary-app/shared/bottom-modal/bottom-modal.component.d.ts +20 -0
- package/lib/itinerary-app/shared/comment/comment.component.d.ts +5 -3
- package/lib/itinerary-app/shared/custom-story-card/custom-story-card.component.d.ts +5 -3
- package/lib/itinerary-app/shared/icon-button/icon-button.component.d.ts +13 -4
- package/lib/itinerary-app/shared/input-field-select/input-field-select.component.d.ts +35 -0
- package/lib/itinerary-app/shared/popup-modal/popup-modal.component.d.ts +30 -0
- package/lib/itinerary-app/shared/search-bar/search-bar.component.d.ts +12 -0
- package/lib/itinerary-app/shared/shared.module.d.ts +11 -7
- package/package.json +1 -1
- package/src/lib/itinerary-app/_styles/modal.scss +2 -2
- package/src/lib/itinerary-app/_styles/styles.scss +327 -327
- package/src/lib/itinerary-app/styles.scss +237 -289
- package/styles.css +1 -1
- package/src/lib/itinerary-app/_styles/component-global-styles/bottom-navigation.scss +0 -19
- package/src/lib/itinerary-app/_styles/component-global-styles/create-itinerary.scss +0 -16
- package/src/lib/itinerary-app/_styles/component-global-styles/custom-button.scss +0 -32
- package/src/lib/itinerary-app/_styles/component-global-styles/custom-menu.scss +0 -38
- package/src/lib/itinerary-app/_styles/component-global-styles/dashboard.scss +0 -5
- package/src/lib/itinerary-app/_styles/component-global-styles/delete-itineraries.scss +0 -7
- package/src/lib/itinerary-app/_styles/component-global-styles/filter-menu.scss +0 -36
- package/src/lib/itinerary-app/_styles/component-global-styles/header.scss +0 -22
- package/src/lib/itinerary-app/_styles/component-global-styles/navbar.scss +0 -47
- package/src/lib/itinerary-app/_styles/component-global-styles/search-bar.scss +0 -17
- package/src/lib/itinerary-app/_styles/component-global-styles/side-bar.scss +0 -28
- package/src/lib/itinerary-app/_styles/component-global-styles/tab-bar.scss +0 -21
|
@@ -6,7 +6,8 @@ import * as i1 from "@angular/common";
|
|
|
6
6
|
import * as i2 from "@angular/router";
|
|
7
7
|
import * as i3 from "../../../../../../_services/itinerary.service";
|
|
8
8
|
import * as i4 from "@naniteninja/ionic-lib";
|
|
9
|
-
import * as i5 from "
|
|
9
|
+
import * as i5 from "../../../../../../shared/bottom-modal/bottom-modal.component";
|
|
10
|
+
import * as i6 from "../create-itinerary-header/create-itinerary-header.component";
|
|
10
11
|
export class CreateItineraryDestinationComponent {
|
|
11
12
|
location;
|
|
12
13
|
router;
|
|
@@ -44,10 +45,10 @@ export class CreateItineraryDestinationComponent {
|
|
|
44
45
|
this.location.back();
|
|
45
46
|
}
|
|
46
47
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateItineraryDestinationComponent, deps: [{ token: i1.Location }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i3.ItineraryService }], target: i0.ɵɵFactoryTarget.Component });
|
|
47
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CreateItineraryDestinationComponent, selector: "app-create-itinerary-destination", ngImport: i0, template: "<app-create-itinerary-header\r\n [progressBarValue]=\"15\"\r\n heading=\"Create Itinerary\"\r\n></app-create-itinerary-header>\r\n<lib-map class=\"maps-100vh\"></lib-map>\r\n<
|
|
48
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CreateItineraryDestinationComponent, selector: "app-create-itinerary-destination", ngImport: i0, template: "<app-create-itinerary-header\r\n [progressBarValue]=\"15\"\r\n heading=\"Create Itinerary\"\r\n></app-create-itinerary-header>\r\n<lib-map class=\"maps-100vh\"></lib-map>\r\n<app-bottom-modal\r\n (submitModal)=\"navToPickStartLocation()\"\r\n submitButtonTitle=\"Continue\"\r\n [showArrow]=\"true\"\r\n [(isOpen)]=\"isOpen\"\r\n [adaptToContentHeight]=\"true\"\r\n>\r\n <div class=\"pl-4 pr-4\">\r\n <div class=\"flex items-center justify-between\">\r\n <div class=\"flex items-center\">\r\n <lib-icon-btn class=\"checkmark-icon-button\">\r\n <img\r\n [src]=\"ICONS['startMarkerImage']\"\r\n alt=\"icon\"\r\n height=\"16\"\r\n width=\"16\"\r\n />\r\n </lib-icon-btn>\r\n <div class=\"ml-4\">\r\n <span>Shan-ul-haq haqee road</span>\r\n <p>Starting location</p>\r\n </div>\r\n </div>\r\n <img [src]=\"ICONS['editPink']\" alt=\"edit\" height=\"13\" width=\"13\" />\r\n </div>\r\n\r\n <h1 class=\"font-Calistoga text-lg mt-5\">Destination</h1>\r\n <p class=\"mt-3\">Select final destination for itinenary route.</p>\r\n\r\n <div class=\"mt-3\"> \r\n <lib-text-box (click)=\"navToPickStartLocation()\" class=\"textbox-1\" label=\"Where To?\"></lib-text-box>\r\n </div>\r\n </div>\r\n</app-bottom-modal>\r\n\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: [""], dependencies: [{ kind: "component", type: i4.IconBtnComponent, selector: "lib-icon-btn", inputs: ["hoverOutline", "disabled", "type", "form", "label", "showArrowIcon", "disableTextShadow", "notificationCount", "loading$", "illuminateIcon"] }, { kind: "component", type: i5.BottomModalComponent, selector: "app-bottom-modal", inputs: ["isOpen", "submitButtonTitle", "showArrow", "adaptToContentHeight", "customClass"], outputs: ["isOpenChange", "submitModal"] }, { kind: "directive", type: i4.LazyImageDirective, selector: "img" }, { kind: "component", type: i4.TextBoxComponent, selector: "lib-text-box", inputs: ["label", "maxLength", "includeEmojiPicker", "emojiPickerConfig", "includeImageAttachment", "maxImageAttachmentLength"] }, { kind: "component", type: i4.LibMapsComponent, selector: "lib-map", inputs: ["disableNotification", "markers", "initialLocation", "mapType", "enableDrag", "locations", "searchMapsString", "mapOptions", "directions$", "directionRenderOptions"], outputs: ["mapActionEvent"] }, { kind: "component", type: i6.CreateItineraryHeaderComponent, selector: "app-create-itinerary-header", inputs: ["heading", "progressBarValue", "discardItineraryId", "class"] }] });
|
|
48
49
|
}
|
|
49
50
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateItineraryDestinationComponent, decorators: [{
|
|
50
51
|
type: Component,
|
|
51
|
-
args: [{ selector: 'app-create-itinerary-destination', standalone: false, template: "<app-create-itinerary-header\r\n [progressBarValue]=\"15\"\r\n heading=\"Create Itinerary\"\r\n></app-create-itinerary-header>\r\n<lib-map class=\"maps-100vh\"></lib-map>\r\n<
|
|
52
|
+
args: [{ selector: 'app-create-itinerary-destination', standalone: false, template: "<app-create-itinerary-header\r\n [progressBarValue]=\"15\"\r\n heading=\"Create Itinerary\"\r\n></app-create-itinerary-header>\r\n<lib-map class=\"maps-100vh\"></lib-map>\r\n<app-bottom-modal\r\n (submitModal)=\"navToPickStartLocation()\"\r\n submitButtonTitle=\"Continue\"\r\n [showArrow]=\"true\"\r\n [(isOpen)]=\"isOpen\"\r\n [adaptToContentHeight]=\"true\"\r\n>\r\n <div class=\"pl-4 pr-4\">\r\n <div class=\"flex items-center justify-between\">\r\n <div class=\"flex items-center\">\r\n <lib-icon-btn class=\"checkmark-icon-button\">\r\n <img\r\n [src]=\"ICONS['startMarkerImage']\"\r\n alt=\"icon\"\r\n height=\"16\"\r\n width=\"16\"\r\n />\r\n </lib-icon-btn>\r\n <div class=\"ml-4\">\r\n <span>Shan-ul-haq haqee road</span>\r\n <p>Starting location</p>\r\n </div>\r\n </div>\r\n <img [src]=\"ICONS['editPink']\" alt=\"edit\" height=\"13\" width=\"13\" />\r\n </div>\r\n\r\n <h1 class=\"font-Calistoga text-lg mt-5\">Destination</h1>\r\n <p class=\"mt-3\">Select final destination for itinenary route.</p>\r\n\r\n <div class=\"mt-3\"> \r\n <lib-text-box (click)=\"navToPickStartLocation()\" class=\"textbox-1\" label=\"Where To?\"></lib-text-box>\r\n </div>\r\n </div>\r\n</app-bottom-modal>\r\n\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" }]
|
|
52
53
|
}], ctorParameters: () => [{ type: i1.Location }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i3.ItineraryService }] });
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWl0aW5lcmFyeS1kZXN0aW5hdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pdGluZXJhcnktbGliL3NyYy9saWIvaXRpbmVyYXJ5LWFwcC9tb2R1bGVzL2l0aW5lcmFyaWVzL3BhZ2VzL2J1aWxkZXIvcGFnZXMvY3JlYXRlLWl0aW5lcmFyeS1kZXN0aW5hdGlvbi9jcmVhdGUtaXRpbmVyYXJ5LWRlc3RpbmF0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2l0aW5lcmFyeS1saWIvc3JjL2xpYi9pdGluZXJhcnktYXBwL21vZHVsZXMvaXRpbmVyYXJpZXMvcGFnZXMvYnVpbGRlci9wYWdlcy9jcmVhdGUtaXRpbmVyYXJ5LWRlc3RpbmF0aW9uL2NyZWF0ZS1pdGluZXJhcnktZGVzdGluYXRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUVsRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUl0RixPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sd0NBQXdDLENBQUM7Ozs7Ozs7O0FBUS9ELE1BQU0sT0FBTyxtQ0FBbUM7SUFPcEM7SUFDQTtJQUNBO0lBQ0E7SUFUVixLQUFLLEdBQVUsS0FBSyxDQUFDO0lBQ3JCLE1BQU0sR0FBWSxJQUFJLENBQUM7SUFDdkIsU0FBUyxDQUF3QjtJQUVqQyxZQUFZO0lBQ1osWUFDVSxRQUFrQixFQUNsQixNQUFjLEVBQ2QsS0FBcUIsRUFDckIsZ0JBQWtDO1FBSGxDLGFBQVEsR0FBUixRQUFRLENBQVU7UUFDbEIsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLFVBQUssR0FBTCxLQUFLLENBQWdCO1FBQ3JCLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFDekMsQ0FBQztJQUVKLFFBQVE7UUFDTixNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDNUMsSUFBSSxFQUFFLEVBQUU7WUFDTixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUM7U0FDcEQ7SUFDSCxDQUFDO0lBRUQsVUFBVTtJQUNWLGVBQWU7UUFDYixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQztJQUNyQixDQUFDO0lBRUQsYUFBYTtJQUNiLHNCQUFzQjtRQUNwQixJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FDbEI7WUFDRSxxQkFBcUIsQ0FBQyxTQUFTO1lBQy9CLHFCQUFxQixDQUFDLGVBQWU7WUFDckMsSUFBSSxDQUFDLFNBQVMsRUFBRSxFQUFFO1NBQ25CLEVBQ0QsRUFBRSxXQUFXLEVBQUUsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FDakMsQ0FBQztJQUNKLENBQUM7SUFFRCxJQUFJO1FBQ0YsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN2QixDQUFDO3dHQXZDVSxtQ0FBbUM7NEZBQW5DLG1DQUFtQyx3RUNmaEQsMG5EQXFEQTs7NEZEdENhLG1DQUFtQztrQkFOL0MsU0FBUzsrQkFDSSxrQ0FBa0MsY0FHaEMsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExvY2F0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGUsIFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7ICBcclxuaW1wb3J0IHsgSXRpbmVyYXJpZXNSb3V0ZXNFbnVtIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vX2VudW1zL0l0ZW5hcmllc1JvdXRlcy5lbnVtJztcclxuaW1wb3J0IHsgSWljb24gfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9faW50ZXJmYWNlL2ljb24nO1xyXG5pbXBvcnQgeyBJdGluZXJhcnkgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9fbW9kZWxzL0l0aW5lcmFyeSc7XHJcbmltcG9ydCB7IEl0aW5lcmFyeVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9fc2VydmljZXMvaXRpbmVyYXJ5LnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBJQ09OUyB9IGZyb20gJy4uLy4uLy4uLy4uLy4uLy4uL19jb25zdGFudHMvY29uc3RhbnRzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdhcHAtY3JlYXRlLWl0aW5lcmFyeS1kZXN0aW5hdGlvbicsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vY3JlYXRlLWl0aW5lcmFyeS1kZXN0aW5hdGlvbi5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybDogJy4vY3JlYXRlLWl0aW5lcmFyeS1kZXN0aW5hdGlvbi5jb21wb25lbnQuY3NzJyxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDcmVhdGVJdGluZXJhcnlEZXN0aW5hdGlvbkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgSUNPTlM6IElpY29uID0gSUNPTlM7XHJcbiAgaXNPcGVuOiBib29sZWFuID0gdHJ1ZTtcclxuICBpdGluZXJhcnk6IEl0aW5lcmFyeSB8IHVuZGVmaW5lZDtcclxuXHJcbiAgLy9MSUZFIENZQ0xFXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGxvY2F0aW9uOiBMb2NhdGlvbixcclxuICAgIHByaXZhdGUgcm91dGVyOiBSb3V0ZXIsXHJcbiAgICBwcml2YXRlIHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSxcclxuICAgIHByaXZhdGUgaXRpbmVyYXJ5U2VydmljZTogSXRpbmVyYXJ5U2VydmljZSxcclxuICApIHt9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgY29uc3QgaWQgPSB0aGlzLnJvdXRlLnNuYXBzaG90LnBhcmFtc1snaWQnXTtcclxuICAgIGlmIChpZCkge1xyXG4gICAgICB0aGlzLml0aW5lcmFyeSA9IHRoaXMuaXRpbmVyYXJ5U2VydmljZS5nZXRCeUlkKGlkKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIC8vVUkgTE9HSUNcclxuICBzaG93Qm90dG9tTW9kYWwoKTogdm9pZCB7XHJcbiAgICB0aGlzLmlzT3BlbiA9IHRydWU7XHJcbiAgfVxyXG5cclxuICAvL05BVklHQVRJT05TXHJcbiAgbmF2VG9QaWNrU3RhcnRMb2NhdGlvbigpIHtcclxuICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFxyXG4gICAgICBbXHJcbiAgICAgICAgSXRpbmVyYXJpZXNSb3V0ZXNFbnVtLklUSU5FUkFSWSxcclxuICAgICAgICBJdGluZXJhcmllc1JvdXRlc0VudW0uTE9DQVRJT05fUElDS0VSLFxyXG4gICAgICAgIHRoaXMuaXRpbmVyYXJ5Py5pZCxcclxuICAgICAgXSxcclxuICAgICAgeyBxdWVyeVBhcmFtczogeyBtb2RlOiAnZW5kJyB9IH0sXHJcbiAgICApO1xyXG4gIH1cclxuXHJcbiAgYmFjaygpOiB2b2lkIHtcclxuICAgIHRoaXMubG9jYXRpb24uYmFjaygpO1xyXG4gIH1cclxufVxyXG4iLCI8YXBwLWNyZWF0ZS1pdGluZXJhcnktaGVhZGVyXHJcbiAgW3Byb2dyZXNzQmFyVmFsdWVdPVwiMTVcIlxyXG4gIGhlYWRpbmc9XCJDcmVhdGUgSXRpbmVyYXJ5XCJcclxuPjwvYXBwLWNyZWF0ZS1pdGluZXJhcnktaGVhZGVyPlxyXG48bGliLW1hcCBjbGFzcz1cIm1hcHMtMTAwdmhcIj48L2xpYi1tYXA+XHJcbjxhcHAtYm90dG9tLW1vZGFsXHJcbiAgKHN1Ym1pdE1vZGFsKT1cIm5hdlRvUGlja1N0YXJ0TG9jYXRpb24oKVwiXHJcbiAgc3VibWl0QnV0dG9uVGl0bGU9XCJDb250aW51ZVwiXHJcbiAgW3Nob3dBcnJvd109XCJ0cnVlXCJcclxuICBbKGlzT3BlbildPVwiaXNPcGVuXCJcclxuICBbYWRhcHRUb0NvbnRlbnRIZWlnaHRdPVwidHJ1ZVwiXHJcbj5cclxuICA8ZGl2IGNsYXNzPVwicGwtNCBwci00XCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiZmxleCBpdGVtcy1jZW50ZXIganVzdGlmeS1iZXR3ZWVuXCI+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJmbGV4IGl0ZW1zLWNlbnRlclwiPlxyXG4gICAgICAgIDxsaWItaWNvbi1idG4gY2xhc3M9XCJjaGVja21hcmstaWNvbi1idXR0b25cIj5cclxuICAgICAgICAgIDxpbWdcclxuICAgICAgICAgICAgW3NyY109XCJJQ09OU1snc3RhcnRNYXJrZXJJbWFnZSddXCJcclxuICAgICAgICAgICAgYWx0PVwiaWNvblwiXHJcbiAgICAgICAgICAgIGhlaWdodD1cIjE2XCJcclxuICAgICAgICAgICAgd2lkdGg9XCIxNlwiXHJcbiAgICAgICAgICAvPlxyXG4gICAgICAgIDwvbGliLWljb24tYnRuPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJtbC00XCI+XHJcbiAgICAgICAgICA8c3Bhbj5TaGFuLXVsLWhhcSBoYXFlZSByb2FkPC9zcGFuPlxyXG4gICAgICAgICAgPHA+U3RhcnRpbmcgbG9jYXRpb248L3A+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgICA8aW1nIFtzcmNdPVwiSUNPTlNbJ2VkaXRQaW5rJ11cIiBhbHQ9XCJlZGl0XCIgaGVpZ2h0PVwiMTNcIiB3aWR0aD1cIjEzXCIgLz5cclxuICAgIDwvZGl2PlxyXG5cclxuICAgIDxoMSBjbGFzcz1cImZvbnQtQ2FsaXN0b2dhIHRleHQtbGcgbXQtNVwiPkRlc3RpbmF0aW9uPC9oMT5cclxuICAgIDxwIGNsYXNzPVwibXQtM1wiPlNlbGVjdCBmaW5hbCBkZXN0aW5hdGlvbiBmb3IgaXRpbmVuYXJ5IHJvdXRlLjwvcD5cclxuXHJcbiAgICA8ZGl2IGNsYXNzPVwibXQtM1wiPiBcclxuICAgICAgPGxpYi10ZXh0LWJveCAoY2xpY2spPVwibmF2VG9QaWNrU3RhcnRMb2NhdGlvbigpXCIgY2xhc3M9XCJ0ZXh0Ym94LTFcIiBsYWJlbD1cIldoZXJlIFRvP1wiPjwvbGliLXRleHQtYm94PlxyXG4gICAgPC9kaXY+XHJcbiAgPC9kaXY+XHJcbjwvYXBwLWJvdHRvbS1tb2RhbD5cclxuXHJcbjxkaXZcclxuICAoY2xpY2spPVwic2hvd0JvdHRvbU1vZGFsKClcIlxyXG4gIGNsYXNzPVwiYWJzb2x1dGUgYm90dG9tLTAgY3Vyc29yLXBvaW50ZXIgei0xMFwiXHJcbiAgc3R5bGU9XCJsZWZ0OiA1MCVcIlxyXG4+XHJcbiAgPGltZ1xyXG4gICAgc3R5bGU9XCJ0cmFuc2Zvcm06IHJvdGF0ZSgyNzBkZWcpXCJcclxuICAgIFtzcmNdPVwiSUNPTlNbJ3JpZ2h0QXJyb3cnXVwiXHJcbiAgICBhbHQ9XCJpY29uXCJcclxuICAgIGhlaWdodD1cIjE1XCJcclxuICAgIHdpZHRoPVwiMTVcIlxyXG4gIC8+XHJcbjwvZGl2PlxyXG4iXX0=
|
|
@@ -7,19 +7,21 @@ 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 "
|
|
11
|
-
import * as i7 from "
|
|
12
|
-
import * as i8 from "@
|
|
10
|
+
import * as i6 from "../../../../../../_services/navigation-helper.service";
|
|
11
|
+
import * as i7 from "../../../../../../shared/bottom-modal/bottom-modal.component";
|
|
12
|
+
import * as i8 from "@naniteninja/ionic-lib";
|
|
13
|
+
import * as i9 from "../create-itinerary-header/create-itinerary-header.component";
|
|
14
|
+
import * as i10 from "@ngx-translate/core";
|
|
13
15
|
const defaultIcon = 'assets/icons/map-markers-yellow.svg';
|
|
14
16
|
const selectedIcon = 'assets/icons/restu-icon-large.svg';
|
|
15
17
|
export class CreateItineraryDrawModeComponent {
|
|
16
18
|
location;
|
|
17
19
|
cdr;
|
|
18
|
-
router;
|
|
19
20
|
activatedRoute;
|
|
20
21
|
itineraryService;
|
|
21
22
|
locationService;
|
|
22
23
|
transferService;
|
|
24
|
+
navHelper;
|
|
23
25
|
ICONS = ICONS;
|
|
24
26
|
actions = [ICONS['location'], ICONS['pencil'], ICONS['ban']];
|
|
25
27
|
selected = this.actions[1];
|
|
@@ -34,14 +36,14 @@ export class CreateItineraryDrawModeComponent {
|
|
|
34
36
|
placesResult; //Places result required for preview
|
|
35
37
|
placeMarkers = [];
|
|
36
38
|
//LIFE CYCLES
|
|
37
|
-
constructor(location, cdr,
|
|
39
|
+
constructor(location, cdr, activatedRoute, itineraryService, locationService, transferService, navHelper) {
|
|
38
40
|
this.location = location;
|
|
39
41
|
this.cdr = cdr;
|
|
40
|
-
this.router = router;
|
|
41
42
|
this.activatedRoute = activatedRoute;
|
|
42
43
|
this.itineraryService = itineraryService;
|
|
43
44
|
this.locationService = locationService;
|
|
44
45
|
this.transferService = transferService;
|
|
46
|
+
this.navHelper = navHelper;
|
|
45
47
|
}
|
|
46
48
|
ngOnInit() {
|
|
47
49
|
const id = this.activatedRoute.snapshot.params['id'];
|
|
@@ -53,19 +55,17 @@ export class CreateItineraryDrawModeComponent {
|
|
|
53
55
|
updateAction(action) {
|
|
54
56
|
this.selected = action;
|
|
55
57
|
if (action === this.actions[0]) {
|
|
56
|
-
this.
|
|
57
|
-
ItinerariesRoutesEnum.ITINERARY,
|
|
58
|
+
this.navHelper.navigate([
|
|
58
59
|
ItinerariesRoutesEnum.CREATE_ITINERARY_ORIGIN,
|
|
59
|
-
this.itinerary
|
|
60
|
-
]);
|
|
60
|
+
this.itinerary.id
|
|
61
|
+
], this.activatedRoute);
|
|
61
62
|
}
|
|
62
63
|
if (action === this.actions[2]) {
|
|
63
|
-
this.
|
|
64
|
-
ItinerariesRoutesEnum.ITINERARY,
|
|
64
|
+
this.navHelper.navigate([
|
|
65
65
|
ItinerariesRoutesEnum.CREATE_ITINERARY_NO_VISUAL_FILTER_MODE,
|
|
66
66
|
ItinerariesRoutesEnum.CREATE_ITINERARY_NO_VISUAL_FILTER_MODE_CREATE,
|
|
67
|
-
this.itinerary
|
|
68
|
-
]);
|
|
67
|
+
this.itinerary.id
|
|
68
|
+
], this.activatedRoute);
|
|
69
69
|
}
|
|
70
70
|
}
|
|
71
71
|
showBottomModal() {
|
|
@@ -148,12 +148,11 @@ export class CreateItineraryDrawModeComponent {
|
|
|
148
148
|
this.transferService.setPlaces(allPlaces);
|
|
149
149
|
this.transferService.setSelectedPlaces(selectedPlaces);
|
|
150
150
|
this.transferService.setCurrentLocation(this.initialLocation);
|
|
151
|
-
this.
|
|
152
|
-
ItinerariesRoutesEnum.ITINERARY,
|
|
151
|
+
this.navHelper.navigate([
|
|
153
152
|
ItinerariesRoutesEnum.CREATE_ITINERARY_DRAW_MODE,
|
|
154
153
|
ItinerariesRoutesEnum.CREATE_ITINERARY_DRAW_MODE_PREVIEW,
|
|
155
|
-
this.itinerary
|
|
156
|
-
]);
|
|
154
|
+
this.itinerary.id
|
|
155
|
+
], this.activatedRoute);
|
|
157
156
|
}
|
|
158
157
|
clearPolygonIfExist() {
|
|
159
158
|
if (this.polygon) {
|
|
@@ -240,11 +239,10 @@ export class CreateItineraryDrawModeComponent {
|
|
|
240
239
|
this.location.back();
|
|
241
240
|
}
|
|
242
241
|
navToPickStartLocation() {
|
|
243
|
-
this.
|
|
244
|
-
ItinerariesRoutesEnum.ITINERARY,
|
|
242
|
+
this.navHelper.navigate([
|
|
245
243
|
ItinerariesRoutesEnum.LOCATION_PICKER,
|
|
246
|
-
this.itinerary
|
|
247
|
-
], { queryParams: { mode: 'start' } });
|
|
244
|
+
this.itinerary.id,
|
|
245
|
+
], this.activatedRoute, { queryParams: { mode: 'start' } });
|
|
248
246
|
}
|
|
249
247
|
getClosestPointOnPolygon(polygon, point) {
|
|
250
248
|
const path = polygon.getPath();
|
|
@@ -265,14 +263,14 @@ export class CreateItineraryDrawModeComponent {
|
|
|
265
263
|
}
|
|
266
264
|
return closestPoint;
|
|
267
265
|
}
|
|
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.
|
|
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<
|
|
266
|
+
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 });
|
|
267
|
+
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<app-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> {{ \"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> 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</app-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{--app-popup-modal-radius: 16px;--border-radius: var(--app-popup-modal-radius);--app-popup-modal-background: #28252d !important;--background: #28252d !important;--overflow: hidden !important;--app-popup-modal-color: #a8a8a8;--color: var(--app-popup-modal-color, #a8a8a8);--max-width: var(--app-bottom-modal-max-width, 500px);--app-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( --app-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: "app-bottom-modal", inputs: ["isOpen", "submitButtonTitle", "showArrow", "adaptToContentHeight", "customClass"], outputs: ["isOpenChange", "submitModal"] }, { kind: "directive", type: i8.LazyImageDirective, selector: "img" }, { kind: "component", type: i8.FooterSharedComponent, selector: "lib-footer-shared", inputs: ["loading$", "canContinue", "continueButtonText", "secondaryButtonText", "showBackButton", "continueButtonParameter$"], outputs: ["secondaryButtonClick", "continueButtonClick"] }, { kind: "component", type: i8.LibMapsComponent, selector: "lib-map", inputs: ["disableNotification", "markers", "initialLocation", "mapType", "enableDrag", "locations", "searchMapsString", "mapOptions", "directions$", "directionRenderOptions"], outputs: ["mapActionEvent"] }, { kind: "component", type: i9.CreateItineraryHeaderComponent, selector: "app-create-itinerary-header", inputs: ["heading", "progressBarValue", "discardItineraryId", "class"] }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }] });
|
|
270
268
|
}
|
|
271
269
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateItineraryDrawModeComponent, decorators: [{
|
|
272
270
|
type: Component,
|
|
273
|
-
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<
|
|
274
|
-
}], ctorParameters: () => [{ type: i1.Location }, { type: i0.ChangeDetectorRef }, { type: i2.
|
|
271
|
+
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<app-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> {{ \"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> 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</app-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{--app-popup-modal-radius: 16px;--border-radius: var(--app-popup-modal-radius);--app-popup-modal-background: #28252d !important;--background: #28252d !important;--overflow: hidden !important;--app-popup-modal-color: #a8a8a8;--color: var(--app-popup-modal-color, #a8a8a8);--max-width: var(--app-bottom-modal-max-width, 500px);--app-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( --app-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"] }]
|
|
272
|
+
}], 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
273
|
type: ViewChild,
|
|
276
274
|
args: ['libMap']
|
|
277
275
|
}] } });
|
|
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"]}
|
|
276
|
+
//# 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<app-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</app-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"]}
|