feat(SW-717) Multiple requests if adult differ between rooms
This commit is contained in:
@@ -61,7 +61,7 @@ export default async function SelectRatePage({
|
|||||||
searchTerm: selectHotelParams.city ?? hotel?.name,
|
searchTerm: selectHotelParams.city ?? hotel?.name,
|
||||||
arrivalDate: format(arrivalDate, "yyyy-MM-dd"),
|
arrivalDate: format(arrivalDate, "yyyy-MM-dd"),
|
||||||
departureDate: format(departureDate, "yyyy-MM-dd"),
|
departureDate: format(departureDate, "yyyy-MM-dd"),
|
||||||
noOfAdults: adultsInRoom,
|
noOfAdults: adultsInRoom[0], // TODO: Handle multiple rooms
|
||||||
noOfChildren: childrenInRoom?.length,
|
noOfChildren: childrenInRoom?.length,
|
||||||
ageOfChildren: childrenInRoom?.map((c) => c.age).join(","),
|
ageOfChildren: childrenInRoom?.map((c) => c.age).join(","),
|
||||||
childBedPreference: childrenInRoom
|
childBedPreference: childrenInRoom
|
||||||
@@ -86,7 +86,7 @@ export default async function SelectRatePage({
|
|||||||
lang={params.lang}
|
lang={params.lang}
|
||||||
fromDate={fromDate.toDate()}
|
fromDate={fromDate.toDate()}
|
||||||
toDate={toDate.toDate()}
|
toDate={toDate.toDate()}
|
||||||
adultCount={adultsInRoom}
|
adultArray={adultsInRoom}
|
||||||
childArray={childrenInRoom}
|
childArray={childrenInRoom}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
@@ -99,7 +99,7 @@ export default async function SelectRatePage({
|
|||||||
lang={params.lang}
|
lang={params.lang}
|
||||||
fromDate={fromDate.toDate()}
|
fromDate={fromDate.toDate()}
|
||||||
toDate={toDate.toDate()}
|
toDate={toDate.toDate()}
|
||||||
adultCount={adultsInRoom}
|
adultArray={adultsInRoom}
|
||||||
childArray={childrenInRoom}
|
childArray={childrenInRoom}
|
||||||
/>
|
/>
|
||||||
</Suspense>
|
</Suspense>
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ interface HotelSearchDetails<T> {
|
|||||||
city: Location | null
|
city: Location | null
|
||||||
hotel: HotelLocation | null
|
hotel: HotelLocation | null
|
||||||
selectHotelParams: SelectHotelParams<T> & { city: string | undefined }
|
selectHotelParams: SelectHotelParams<T> & { city: string | undefined }
|
||||||
adultsInRoom: number
|
adultsInRoom: number[]
|
||||||
childrenInRoomString?: string
|
childrenInRoomString?: string
|
||||||
childrenInRoom?: Child[]
|
childrenInRoom?: Child[]
|
||||||
}
|
}
|
||||||
@@ -79,7 +79,7 @@ export async function getHotelSearchDetails<
|
|||||||
if (!city && !hotel) return notFound()
|
if (!city && !hotel) return notFound()
|
||||||
if (isAlternativeHotels && (!city || !hotel)) return notFound()
|
if (isAlternativeHotels && (!city || !hotel)) return notFound()
|
||||||
|
|
||||||
let adultsInRoom = 1
|
let adultsInRoom: number[] = []
|
||||||
let childrenInRoomString: HotelSearchDetails<T>["childrenInRoomString"] =
|
let childrenInRoomString: HotelSearchDetails<T>["childrenInRoomString"] =
|
||||||
undefined
|
undefined
|
||||||
let childrenInRoom: HotelSearchDetails<T>["childrenInRoom"] = undefined
|
let childrenInRoom: HotelSearchDetails<T>["childrenInRoom"] = undefined
|
||||||
@@ -87,7 +87,7 @@ export async function getHotelSearchDetails<
|
|||||||
const { rooms } = selectHotelParams
|
const { rooms } = selectHotelParams
|
||||||
|
|
||||||
if (rooms && rooms.length > 0) {
|
if (rooms && rooms.length > 0) {
|
||||||
adultsInRoom = rooms[0].adults // TODO: Handle multiple rooms
|
adultsInRoom = rooms.map((room) => room.adults?.[0] ?? 0)
|
||||||
childrenInRoomString = rooms[0].childrenInRoom
|
childrenInRoomString = rooms[0].childrenInRoom
|
||||||
? generateChildrenString(rooms[0].childrenInRoom)
|
? generateChildrenString(rooms[0].childrenInRoom)
|
||||||
: undefined // TODO: Handle multiple rooms
|
: undefined // TODO: Handle multiple rooms
|
||||||
|
|||||||
@@ -69,7 +69,7 @@ export async function SelectHotelMapContainer({
|
|||||||
fetchAlternativeHotels(isAlternativeFor.id, {
|
fetchAlternativeHotels(isAlternativeFor.id, {
|
||||||
roomStayStartDate: selectHotelParams.fromDate,
|
roomStayStartDate: selectHotelParams.fromDate,
|
||||||
roomStayEndDate: selectHotelParams.toDate,
|
roomStayEndDate: selectHotelParams.toDate,
|
||||||
adults: adultsInRoom,
|
adults: adultsInRoom[0],
|
||||||
children: childrenInRoomString,
|
children: childrenInRoomString,
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
@@ -78,7 +78,7 @@ export async function SelectHotelMapContainer({
|
|||||||
cityId: city.id,
|
cityId: city.id,
|
||||||
roomStayStartDate: selectHotelParams.fromDate,
|
roomStayStartDate: selectHotelParams.fromDate,
|
||||||
roomStayEndDate: selectHotelParams.toDate,
|
roomStayEndDate: selectHotelParams.toDate,
|
||||||
adults: adultsInRoom,
|
adults: adultsInRoom[0],
|
||||||
children: childrenInRoomString,
|
children: childrenInRoomString,
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
@@ -118,7 +118,7 @@ export async function SelectHotelMapContainer({
|
|||||||
: (selectHotelParams.city as string),
|
: (selectHotelParams.city as string),
|
||||||
arrivalDate: format(arrivalDate, "yyyy-MM-dd"),
|
arrivalDate: format(arrivalDate, "yyyy-MM-dd"),
|
||||||
departureDate: format(departureDate, "yyyy-MM-dd"),
|
departureDate: format(departureDate, "yyyy-MM-dd"),
|
||||||
noOfAdults: adultsInRoom,
|
noOfAdults: adultsInRoom[0], // TODO: Handle multiple rooms
|
||||||
noOfChildren: childrenInRoom?.length,
|
noOfChildren: childrenInRoom?.length,
|
||||||
ageOfChildren: childrenInRoom?.map((c) => c.age).join(","),
|
ageOfChildren: childrenInRoom?.map((c) => c.age).join(","),
|
||||||
childBedPreference: childrenInRoom
|
childBedPreference: childrenInRoom
|
||||||
|
|||||||
@@ -83,7 +83,7 @@ export default async function SelectHotel({
|
|||||||
fetchAlternativeHotels(isAlternativeFor.id, {
|
fetchAlternativeHotels(isAlternativeFor.id, {
|
||||||
roomStayStartDate: selectHotelParams.fromDate,
|
roomStayStartDate: selectHotelParams.fromDate,
|
||||||
roomStayEndDate: selectHotelParams.toDate,
|
roomStayEndDate: selectHotelParams.toDate,
|
||||||
adults: adultsInRoom,
|
adults: adultsInRoom[0],
|
||||||
children: childrenInRoomString,
|
children: childrenInRoomString,
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
@@ -92,7 +92,7 @@ export default async function SelectHotel({
|
|||||||
cityId: city.id,
|
cityId: city.id,
|
||||||
roomStayStartDate: selectHotelParams.fromDate,
|
roomStayStartDate: selectHotelParams.fromDate,
|
||||||
roomStayEndDate: selectHotelParams.toDate,
|
roomStayEndDate: selectHotelParams.toDate,
|
||||||
adults: adultsInRoom,
|
adults: adultsInRoom[0],
|
||||||
children: childrenInRoomString,
|
children: childrenInRoomString,
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
@@ -167,7 +167,7 @@ export default async function SelectHotel({
|
|||||||
: (selectHotelParams.city as string),
|
: (selectHotelParams.city as string),
|
||||||
arrivalDate: format(arrivalDate, "yyyy-MM-dd"),
|
arrivalDate: format(arrivalDate, "yyyy-MM-dd"),
|
||||||
departureDate: format(departureDate, "yyyy-MM-dd"),
|
departureDate: format(departureDate, "yyyy-MM-dd"),
|
||||||
noOfAdults: adultsInRoom,
|
noOfAdults: adultsInRoom[0], // TODO: Handle multiple rooms,
|
||||||
noOfChildren: childrenInRoom?.length,
|
noOfChildren: childrenInRoom?.length,
|
||||||
ageOfChildren: childrenInRoom?.map((c) => c.age).join(","),
|
ageOfChildren: childrenInRoom?.map((c) => c.age).join(","),
|
||||||
childBedPreference: childrenInRoom
|
childBedPreference: childrenInRoom
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ import type { Lang } from "@/constants/languages"
|
|||||||
type Props = {
|
type Props = {
|
||||||
hotelId: number
|
hotelId: number
|
||||||
lang: Lang
|
lang: Lang
|
||||||
adultCount: number
|
adultArray: number[]
|
||||||
childArray?: Child[]
|
childArray?: Child[]
|
||||||
fromDate: Date
|
fromDate: Date
|
||||||
toDate: Date
|
toDate: Date
|
||||||
@@ -27,24 +27,53 @@ export async function NoRoomsAlert({
|
|||||||
fromDate,
|
fromDate,
|
||||||
toDate,
|
toDate,
|
||||||
childArray,
|
childArray,
|
||||||
adultCount,
|
adultArray,
|
||||||
lang,
|
lang,
|
||||||
}: Props) {
|
}: Props) {
|
||||||
const [availability, availabilityError] = await safeTry(
|
const fromDateString = dt(fromDate).format("YYYY-MM-DD")
|
||||||
|
const toDateString = dt(toDate).format("YYYY-MM-DD")
|
||||||
|
|
||||||
|
const uniqueAdultCounts = [...new Set(adultArray)]
|
||||||
|
const roomsAvailabilityPromises = uniqueAdultCounts.map((adultCount) => {
|
||||||
|
return safeTry(
|
||||||
getRoomsAvailability({
|
getRoomsAvailability({
|
||||||
hotelId: hotelId,
|
hotelId: hotelId,
|
||||||
roomStayStartDate: dt(fromDate).format("YYYY-MM-DD"),
|
roomStayStartDate: fromDateString,
|
||||||
roomStayEndDate: dt(toDate).format("YYYY-MM-DD"),
|
roomStayEndDate: toDateString,
|
||||||
adults: adultCount,
|
adults: adultCount,
|
||||||
children: childArray ? generateChildrenString(childArray) : undefined, // TODO: Handle multiple rooms,
|
children:
|
||||||
|
childArray && childArray.length > 0
|
||||||
|
? generateChildrenString(childArray)
|
||||||
|
: undefined,
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
|
})
|
||||||
|
|
||||||
if (!availability || availabilityError) {
|
const roomsAvailabilityResults = await Promise.all(roomsAvailabilityPromises)
|
||||||
|
|
||||||
|
const roomsAvailability = roomsAvailabilityResults.reduce<
|
||||||
|
(typeof roomsAvailabilityResults)[0][0]
|
||||||
|
>((acc, [result, error]) => {
|
||||||
|
if (error) {
|
||||||
|
console.error("[RoomsContainer] unable to fetch room availability")
|
||||||
|
return acc
|
||||||
|
}
|
||||||
|
if (!acc) return result
|
||||||
|
if (!result) return acc
|
||||||
|
return {
|
||||||
|
...result,
|
||||||
|
roomConfigurations: [
|
||||||
|
...acc.roomConfigurations,
|
||||||
|
...result.roomConfigurations,
|
||||||
|
],
|
||||||
|
}
|
||||||
|
}, null)
|
||||||
|
|
||||||
|
if (!roomsAvailability) {
|
||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
|
|
||||||
const noRoomsAvailable = availability.roomConfigurations.reduce(
|
const noRoomsAvailable = roomsAvailability.roomConfigurations.reduce(
|
||||||
(acc, room) => {
|
(acc, room) => {
|
||||||
return acc && room.status === "NotAvailable"
|
return acc && room.status === "NotAvailable"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ import { RoomPackageCodeEnum } from "@/types/components/hotelReservation/selectR
|
|||||||
import type { RoomsContainerProps } from "@/types/components/hotelReservation/selectRate/roomsContainer"
|
import type { RoomsContainerProps } from "@/types/components/hotelReservation/selectRate/roomsContainer"
|
||||||
|
|
||||||
export async function RoomsContainer({
|
export async function RoomsContainer({
|
||||||
adultCount,
|
adultArray,
|
||||||
childArray,
|
childArray,
|
||||||
fromDate,
|
fromDate,
|
||||||
hotelId,
|
hotelId,
|
||||||
@@ -42,7 +42,7 @@ export async function RoomsContainer({
|
|||||||
hotelId: hotelId.toString(),
|
hotelId: hotelId.toString(),
|
||||||
startDate: fromDateString,
|
startDate: fromDateString,
|
||||||
endDate: toDateString,
|
endDate: toDateString,
|
||||||
adults: adultCount,
|
adults: adultArray[0],
|
||||||
children: childArray ? childArray.length : undefined,
|
children: childArray ? childArray.length : undefined,
|
||||||
packageCodes: [
|
packageCodes: [
|
||||||
RoomPackageCodeEnum.ACCESSIBILITY_ROOM,
|
RoomPackageCodeEnum.ACCESSIBILITY_ROOM,
|
||||||
@@ -52,7 +52,9 @@ export async function RoomsContainer({
|
|||||||
})
|
})
|
||||||
)
|
)
|
||||||
|
|
||||||
const roomsAvailabilityPromise = safeTry(
|
const uniqueAdultCounts = [...new Set(adultArray)]
|
||||||
|
const roomsAvailabilityPromises = uniqueAdultCounts.map((adultCount) => {
|
||||||
|
return safeTry(
|
||||||
getRoomsAvailability({
|
getRoomsAvailability({
|
||||||
hotelId: hotelId,
|
hotelId: hotelId,
|
||||||
roomStayStartDate: fromDateString,
|
roomStayStartDate: fromDateString,
|
||||||
@@ -64,23 +66,35 @@ export async function RoomsContainer({
|
|||||||
: undefined,
|
: undefined,
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
|
})
|
||||||
|
|
||||||
const [hotelData, hotelDataError] = await hotelDataPromise
|
const [hotelData, hotelDataError] = await hotelDataPromise
|
||||||
const [packages, packagesError] = await packagesPromise
|
const [packages, packagesError] = await packagesPromise
|
||||||
const [roomsAvailability, roomsAvailabilityError] =
|
const roomsAvailabilityResults = await Promise.all(roomsAvailabilityPromises)
|
||||||
await roomsAvailabilityPromise
|
|
||||||
|
const roomsAvailability = roomsAvailabilityResults.reduce<
|
||||||
|
(typeof roomsAvailabilityResults)[0][0]
|
||||||
|
>((acc, [result, error]) => {
|
||||||
|
if (error) {
|
||||||
|
console.error("[RoomsContainer] unable to fetch room availability")
|
||||||
|
return acc
|
||||||
|
}
|
||||||
|
if (!acc) return result
|
||||||
|
if (!result) return acc
|
||||||
|
return {
|
||||||
|
...result,
|
||||||
|
roomConfigurations: [
|
||||||
|
...acc.roomConfigurations,
|
||||||
|
...result.roomConfigurations,
|
||||||
|
],
|
||||||
|
}
|
||||||
|
}, null)
|
||||||
|
|
||||||
if (packagesError) {
|
if (packagesError) {
|
||||||
// TODO: Log packages error
|
// TODO: Log packages error
|
||||||
console.error("[RoomsContainer] unable to fetch packages")
|
console.error("[RoomsContainer] unable to fetch packages")
|
||||||
}
|
}
|
||||||
|
|
||||||
if (roomsAvailabilityError) {
|
|
||||||
// TODO: show proper error component
|
|
||||||
console.error("[RoomsContainer] unable to fetch room availability")
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!roomsAvailability) {
|
if (!roomsAvailability) {
|
||||||
// HotelInfoCard has the logic for displaying when there are no rooms available
|
// HotelInfoCard has the logic for displaying when there are no rooms available
|
||||||
return null
|
return null
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ import type { Child } from "./selectRate"
|
|||||||
|
|
||||||
export interface HotelInfoCardProps {
|
export interface HotelInfoCardProps {
|
||||||
adultCount: number
|
adultCount: number
|
||||||
|
adultArray: number[]
|
||||||
childArray?: Child[]
|
childArray?: Child[]
|
||||||
fromDate: Date
|
fromDate: Date
|
||||||
hotelId: number
|
hotelId: number
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ import type { Child } from "./selectRate"
|
|||||||
|
|
||||||
export interface RoomsContainerProps {
|
export interface RoomsContainerProps {
|
||||||
adultCount: number
|
adultCount: number
|
||||||
|
adultArray: number[]
|
||||||
childArray?: Child[]
|
childArray?: Child[]
|
||||||
fromDate: Date
|
fromDate: Date
|
||||||
hotelId: number
|
hotelId: number
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ export interface Child {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export interface Room {
|
export interface Room {
|
||||||
adults: number
|
adults: number[]
|
||||||
roomTypeCode: string
|
roomTypeCode: string
|
||||||
rateCode: string
|
rateCode: string
|
||||||
counterRateCode: string
|
counterRateCode: string
|
||||||
|
|||||||
Reference in New Issue
Block a user