feat(SW-2879): Move BookingWidget to booking-flow package * Fix lockfile * Fix styling * a tiny little booking widget test * Tiny fixes * Merge branch 'master' into feat/sw-2879-booking-widget-to-booking-flow-package * Remove unused scripts * lint:fix * Merge branch 'master' into feat/sw-2879-booking-widget-to-booking-flow-package * Tiny lint fixes * update test * Update Input in booking-flow * Clean up comments etc * Merge branch 'master' into feat/sw-2879-booking-widget-to-booking-flow-package * Setup tracking context for booking-flow * Add missing use client * Fix temp tracking function * Pass booking to booking-widget * Remove comment * Add use client to booking widget tracking provider * Add use client to tracking functions * Merge branch 'master' into feat/sw-2879-booking-widget-to-booking-flow-package * Move debug page * Merge branch 'master' into feat/sw-2879-booking-widget-to-booking-flow-package * Merge branch 'master' into feat/sw-2879-booking-widget-to-booking-flow-package * Merge branch 'master' into feat/sw-2879-booking-widget-to-booking-flow-package Approved-by: Bianca Widstam
71 lines
1.6 KiB
TypeScript
71 lines
1.6 KiB
TypeScript
"use client"
|
|
|
|
import { useSearchParams } from "next/navigation"
|
|
import React from "react"
|
|
|
|
import {
|
|
parseSelectRateSearchParams,
|
|
searchParamsToRecord,
|
|
} from "@scandic-hotels/booking-flow/utils/url"
|
|
import { SEARCH_TYPE_REDEMPTION } from "@scandic-hotels/trpc/constants/booking"
|
|
|
|
import TrackingSDK from "@/components/TrackingSDK"
|
|
import useLang from "@/hooks/useLang"
|
|
|
|
import { getValidDates } from "../getValidDates"
|
|
import { getTracking } from "./tracking"
|
|
|
|
import type { ChildrenInRoom } from "@/utils/hotelSearchDetails"
|
|
|
|
export default function Tracking({
|
|
adultsInRoom,
|
|
childrenInRoom,
|
|
hotelId,
|
|
hotelName,
|
|
noOfRooms,
|
|
country,
|
|
city,
|
|
}: {
|
|
adultsInRoom: number[]
|
|
childrenInRoom: ChildrenInRoom
|
|
hotelId: string
|
|
hotelName: string
|
|
noOfRooms: number
|
|
country: string
|
|
city: string
|
|
}) {
|
|
const lang = useLang()
|
|
const params = useSearchParams()
|
|
const booking = parseSelectRateSearchParams(searchParamsToRecord(params))
|
|
|
|
if (!booking) return null
|
|
|
|
const { fromDate, toDate } = getValidDates(booking.fromDate, booking.toDate)
|
|
|
|
const { rooms, searchType, bookingCode, city: paramCity } = booking
|
|
|
|
const arrivalDate = fromDate.toDate()
|
|
const departureDate = toDate.toDate()
|
|
|
|
const { hotelsTrackingData, pageTrackingData } = getTracking(
|
|
lang,
|
|
arrivalDate,
|
|
departureDate,
|
|
adultsInRoom,
|
|
childrenInRoom,
|
|
hotelId,
|
|
hotelName,
|
|
noOfRooms,
|
|
country,
|
|
city,
|
|
paramCity,
|
|
bookingCode,
|
|
searchType === SEARCH_TYPE_REDEMPTION,
|
|
rooms
|
|
)
|
|
|
|
return (
|
|
<TrackingSDK pageData={pageTrackingData} hotelInfo={hotelsTrackingData} />
|
|
)
|
|
}
|