Added tracking to hotelreservation step
This commit is contained in:
@@ -1,7 +1,9 @@
|
|||||||
import "./enterDetailsLayout.css"
|
import "./enterDetailsLayout.css"
|
||||||
|
|
||||||
|
import { differenceInCalendarDays, format, isWeekend } from "date-fns"
|
||||||
import { notFound } from "next/navigation"
|
import { notFound } from "next/navigation"
|
||||||
|
|
||||||
|
import { Lang } from "@/constants/languages"
|
||||||
import {
|
import {
|
||||||
getBreakfastPackages,
|
getBreakfastPackages,
|
||||||
getCreditCardsSafely,
|
getCreditCardsSafely,
|
||||||
@@ -21,10 +23,16 @@ import {
|
|||||||
generateChildrenString,
|
generateChildrenString,
|
||||||
getQueryParamsForEnterDetails,
|
getQueryParamsForEnterDetails,
|
||||||
} from "@/components/HotelReservation/SelectRate/RoomSelection/utils"
|
} from "@/components/HotelReservation/SelectRate/RoomSelection/utils"
|
||||||
|
import TrackingSDK from "@/components/TrackingSDK"
|
||||||
import { getIntl } from "@/i18n"
|
import { getIntl } from "@/i18n"
|
||||||
|
|
||||||
import { StepEnum } from "@/types/components/hotelReservation/enterDetails/step"
|
import { StepEnum } from "@/types/components/hotelReservation/enterDetails/step"
|
||||||
import { SelectRateSearchParams } from "@/types/components/hotelReservation/selectRate/selectRate"
|
import { SelectRateSearchParams } from "@/types/components/hotelReservation/selectRate/selectRate"
|
||||||
|
import {
|
||||||
|
TrackingChannelEnum,
|
||||||
|
TrackingSDKHotelInfo,
|
||||||
|
TrackingSDKPageData,
|
||||||
|
} from "@/types/components/tracking"
|
||||||
import type { LangParams, PageArgs } from "@/types/params"
|
import type { LangParams, PageArgs } from "@/types/params"
|
||||||
|
|
||||||
function isValidStep(step: string): step is StepEnum {
|
function isValidStep(step: string): step is StepEnum {
|
||||||
@@ -112,8 +120,37 @@ export default async function StepPage({
|
|||||||
? roomAvailability.memberRate?.localPrice.pricePerStay
|
? roomAvailability.memberRate?.localPrice.pricePerStay
|
||||||
: roomAvailability.publicRate!.localPrice.pricePerStay
|
: roomAvailability.publicRate!.localPrice.pricePerStay
|
||||||
|
|
||||||
|
const arrivalDate = new Date(searchParams.fromDate)
|
||||||
|
const departureDate = new Date(searchParams.toDate)
|
||||||
|
const hotelAttributes = hotelData?.data.attributes
|
||||||
|
|
||||||
|
const pageTrackingData: TrackingSDKPageData = {
|
||||||
|
pageId: "select-rate",
|
||||||
|
domainLanguage: params.lang as Lang,
|
||||||
|
channel: TrackingChannelEnum["hotelreservation"],
|
||||||
|
pageName: "hotelreservation|select-rate",
|
||||||
|
siteSections: "hotelreservation|select-rate",
|
||||||
|
pageType: "bookingroomsandratespage",
|
||||||
|
}
|
||||||
|
|
||||||
|
const hotelsTrackingData: TrackingSDKHotelInfo = {
|
||||||
|
searchTerm: searchParams.city,
|
||||||
|
arrivalDate: format(arrivalDate, "yyyy-MM-dd"),
|
||||||
|
departureDate: format(departureDate, "yyyy-MM-dd"),
|
||||||
|
noOfAdults: adults,
|
||||||
|
noOfChildren: children?.length,
|
||||||
|
//childBedPreference // "adults|adults|extra|adults"
|
||||||
|
noOfRooms: 1, // // TODO: Handle multiple rooms
|
||||||
|
duration: differenceInCalendarDays(departureDate, arrivalDate),
|
||||||
|
leadTime: differenceInCalendarDays(arrivalDate, new Date()),
|
||||||
|
searchType: "hotel",
|
||||||
|
bookingTypeofDay: isWeekend(arrivalDate) ? "weekend" : "weekday",
|
||||||
|
country: hotelAttributes?.address.country,
|
||||||
|
region: hotelAttributes?.address.city,
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<section>
|
<>
|
||||||
<HistoryStateManager />
|
<HistoryStateManager />
|
||||||
<SelectedRoom
|
<SelectedRoom
|
||||||
hotelId={hotelId}
|
hotelId={hotelId}
|
||||||
@@ -161,6 +198,7 @@ export default async function StepPage({
|
|||||||
mustBeGuaranteed={mustBeGuaranteed}
|
mustBeGuaranteed={mustBeGuaranteed}
|
||||||
/>
|
/>
|
||||||
</SectionAccordion>
|
</SectionAccordion>
|
||||||
</section>
|
<TrackingSDK pageData={pageTrackingData} hotelInfo={hotelsTrackingData} />
|
||||||
|
</>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user