import { serverClient } from "@/lib/trpc/server" import { getLang } from "@/i18n/serverContext" import { AvailabilityInput } from "@/types/components/hotelReservation/selectHotel/availabilityInput" import { HotelData } from "@/types/components/hotelReservation/selectHotel/hotelCardListingProps" import { Filter } from "@/types/components/hotelReservation/selectHotel/hotelFilters" export async function fetchAvailableHotels( input: AvailabilityInput ): Promise { const availableHotels = await serverClient().hotel.availability.hotels(input) if (!availableHotels) throw new Error() const language = getLang() const hotels = availableHotels.availability.map(async (hotel) => { const hotelData = await serverClient().hotel.hotelData.get({ hotelId: hotel.hotelId.toString(), language, }) if (!hotelData) throw new Error() return { hotelData: hotelData.data.attributes, price: hotel.bestPricePerNight, } }) return await Promise.all(hotels) } export function getFiltersFromHotels(hotels: HotelData[]) { const filters = hotels.flatMap((hotel) => hotel.hotelData.detailedFacilities) const uniqueFilterIds = [...new Set(filters.map((filter) => filter.id))] const filterList: Filter[] = uniqueFilterIds .map((filterId) => filters.find((filter) => filter.id === filterId)) .filter((filter): filter is Filter => filter !== undefined) return filterList }