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
58 lines
1.4 KiB
TypeScript
58 lines
1.4 KiB
TypeScript
"use client"
|
|
|
|
import { useSearchHistory } from "@scandic-hotels/booking-flow/hooks/useSearchHistory"
|
|
|
|
import { useEnterDetailsStore } from "@/stores/enter-details"
|
|
|
|
import TrackingSDK from "@/components/TrackingSDK"
|
|
|
|
import { getTracking } from "./tracking"
|
|
|
|
import type { Lang } from "@scandic-hotels/common/constants/language"
|
|
import type { Hotel } from "@scandic-hotels/trpc/types/hotel"
|
|
import type { Room } from "@scandic-hotels/trpc/types/room"
|
|
|
|
import type { DetailsBooking } from "@/types/components/hotelReservation/enterDetails/details"
|
|
|
|
interface TrackingWrapperProps {
|
|
booking: DetailsBooking
|
|
hotel: Hotel
|
|
rooms: Room[]
|
|
isMember: boolean
|
|
lang: Lang
|
|
}
|
|
|
|
export default function EnterDetailsTrackingWrapper({
|
|
booking,
|
|
hotel,
|
|
rooms,
|
|
isMember,
|
|
lang,
|
|
}: TrackingWrapperProps) {
|
|
const { storedRooms, breakfastPackages } = useEnterDetailsStore((state) => ({
|
|
storedRooms: state.rooms,
|
|
breakfastPackages: state.breakfastPackages,
|
|
}))
|
|
|
|
const searchHistory = useSearchHistory()
|
|
const searchTerm = searchHistory.searchHistory[0]?.name
|
|
|
|
const { hotelsTrackingData, pageTrackingData, ancillaries } = getTracking(
|
|
booking,
|
|
hotel,
|
|
rooms,
|
|
isMember,
|
|
lang,
|
|
storedRooms,
|
|
breakfastPackages,
|
|
searchTerm
|
|
)
|
|
return (
|
|
<TrackingSDK
|
|
hotelInfo={hotelsTrackingData}
|
|
pageData={pageTrackingData}
|
|
ancillaries={ancillaries}
|
|
/>
|
|
)
|
|
}
|