feat: add multiroom tracking to booking flow

This commit is contained in:
Simon Emanuelsson
2025-03-05 11:53:05 +01:00
parent 540402b969
commit 1812591903
72 changed files with 2277 additions and 1308 deletions

View File

@@ -19,7 +19,7 @@ import { DetailsContext } from "@/contexts/Details"
import type { DetailsStore } from "@/types/contexts/enter-details"
import { StepEnum } from "@/types/enums/step"
import type { DetailsProviderProps } from "@/types/providers/enter-details"
import type { InitialState } from "@/types/stores/enter-details"
import type { InitialState, RoomState } from "@/types/stores/enter-details"
export default function EnterDetailsProvider({
booking,
@@ -50,9 +50,9 @@ export default function EnterDetailsProvider({
bedType:
room.bedTypes?.length === 1
? {
roomTypeCode: room.bedTypes[0].value,
description: room.bedTypes[0].description,
}
roomTypeCode: room.bedTypes[0].value,
description: room.bedTypes[0].description,
}
: undefined,
mustBeGuaranteed: room.mustBeGuaranteed,
isFlexRate: room.isFlexRate,
@@ -85,9 +85,13 @@ export default function EnterDetailsProvider({
}
const updatedRooms = storedValues.rooms.map((storedRoom, idx) => {
const room = store.rooms[idx]
if (!room) {
return null
}
// Need to create a deep new copy
// since store is readonly
const currentRoom = deepmerge({}, store.rooms[idx])
const currentRoom = deepmerge({}, room)
if (!currentRoom.room.isAvailable) {
return currentRoom
@@ -142,27 +146,38 @@ export default function EnterDetailsProvider({
})
const canProceedToPayment = updatedRooms.every(
(room) => room.isComplete && room.room.isAvailable
(room) => room?.isComplete && room?.room.isAvailable
)
const filteredOutMissingRooms = updatedRooms.filter(
(room): room is RoomState => !!room
)
const nights = dt(booking.toDate).diff(booking.fromDate, "days")
const currency = (updatedRooms[0].room.roomRate.publicRate?.localPrice
.currency ||
updatedRooms[0].room.roomRate.memberRate?.localPrice.currency)!
const totalPrice = calcTotalPrice(updatedRooms, currency, !!user, nights)
const currency = (filteredOutMissingRooms[0].room.roomRate.publicRate
?.localPrice.currency ||
filteredOutMissingRooms[0].room.roomRate.memberRate?.localPrice.currency)!
const totalPrice = calcTotalPrice(
filteredOutMissingRooms,
currency,
!!user,
nights
)
const activeRoom = updatedRooms.findIndex((room) => !room.isComplete)
const activeRoom = filteredOutMissingRooms.findIndex(
(room) => !room.isComplete
)
writeToSessionStorage({
activeRoom,
booking,
rooms: updatedRooms,
rooms: filteredOutMissingRooms,
})
storeRef.current?.setState({
activeRoom: storedValues.activeRoom,
canProceedToPayment,
rooms: updatedRooms,
rooms: filteredOutMissingRooms,
totalPrice,
})
}, [booking, rooms, user])

View File

@@ -14,9 +14,11 @@ export default function RoomProvider({
const activeRoom = useRatesStore((state) => state.activeRoom)
const closeSection = useRatesStore((state) => state.actions.closeSection(idx))
const modifyRate = useRatesStore((state) => state.actions.modifyRate(idx))
const roomAvailability = useRatesStore(
(state) => state.roomsAvailability?.[idx]
)
const selectFilter = useRatesStore((state) => state.actions.selectFilter(idx))
const selectRate = useRatesStore((state) => state.actions.selectRate(idx))
const totalRooms = useRatesStore((state) => state.allRooms.length)
const roomNr = idx + 1
return (
<RoomContext.Provider
@@ -30,8 +32,9 @@ export default function RoomProvider({
},
isActiveRoom: activeRoom === idx,
isMainRoom: roomNr === 1,
roomAvailability,
roomNr,
totalRooms,
totalRooms: room.rooms.length,
}}
>
{children}