chore (SW-834): Upgrade to Next 15 * wip: apply codemod and upgrade swc plugin * wip: design-system to react 19, fix issues from async (search)params * wip: fix remaining issues from codemod serverClient is now async because context use headers() getLang is now async because it uses headers() * Minor cleanup * Inline react-material-symbols package Package is seemingly not maintained any more and doesn't support React 19. This copies the package source into `design-system`, makes the necessary changes for 19 and export it for others to use. * Fix missing awaits * Disable modal exit animations Enabling modal exit animations via isExiting prop is causing modals to be rendered in "hidden" state and never unmount. Seems to be an issue with react-aria-components, see https://github.com/adobe/react-spectrum/issues/7563. Can probably be fixed by rewriting to a solution similar to https://react-spectrum.adobe.com/react-aria/examples/framer-modal-sheet.html * Remove unstable cache implementation and use in memory cache locally * Fix ref type in SelectFilter * Use cloneElement to add key prop to element Approved-by: Linus Flood
44 lines
1.2 KiB
TypeScript
44 lines
1.2 KiB
TypeScript
import { type NextRequest, NextResponse } from "next/server"
|
|
|
|
import { env } from "@/env/server"
|
|
import { serverClient } from "@/lib/trpc/server"
|
|
|
|
import { languageSchema } from "@/utils/languages"
|
|
|
|
export const dynamic = "force-dynamic"
|
|
|
|
export async function GET(request: NextRequest) {
|
|
if (!env.ENABLE_WARMUP_HOTEL) {
|
|
console.log("[WARMUP] Warmup hotel data is disabled")
|
|
return NextResponse.json(
|
|
{ message: "Warmup hotel data is disabled" },
|
|
{ status: 200 }
|
|
)
|
|
}
|
|
|
|
try {
|
|
const searchParams = request.nextUrl.searchParams
|
|
const lang = searchParams.get("lang")
|
|
const parsedLang = languageSchema.safeParse(lang)
|
|
|
|
if (!parsedLang.success) {
|
|
throw new Error("[WARMUP] Invalid language provided")
|
|
}
|
|
|
|
const caller = await serverClient()
|
|
const hotels = await caller.hotel.hotels.getDestinationsMapData({
|
|
lang: parsedLang.data,
|
|
warmup: true,
|
|
})
|
|
return NextResponse.json(hotels)
|
|
} catch (error) {
|
|
console.error("[WARMUP] error", error)
|
|
return NextResponse.json(
|
|
{
|
|
error: "Failed to fetch all hotels",
|
|
},
|
|
{ status: 500, statusText: "Internal Server Error" }
|
|
)
|
|
}
|
|
}
|