Files
web/apps/scandic-web/app/[lang]/webview/(views)/layout.tsx
Linus Flood 800b329998 Merged in fix/my-stay-webview-3 (pull request #2281)
feat/my-stay-webview - check if user else redirect to refresh page

* feat/my-stay-webview - check if user else redirect to refresh page


Approved-by: Joakim Jäderberg
2025-06-04 06:26:42 +00:00

64 lines
1.7 KiB
TypeScript

import { headers } from "next/headers"
import { redirect } from "next/navigation"
import { getProfile } from "@/lib/trpc/memoizedRequests"
import { getIntl } from "@/i18n"
import type { LangParams, LayoutArgs } from "@/types/params"
export default async function Layout(
props: React.PropsWithChildren<LayoutArgs<LangParams>>
) {
const params = await props.params
const { children } = props
const intl = await getIntl()
const user = await getProfile()
if (!user) {
console.log(`[webview:page] unable to load user`)
return (
<p>
{intl.formatMessage({
defaultMessage: "Error: No user could be loaded",
})}
</p>
)
}
if ("error" in user) {
switch (user.cause) {
case "unauthorized": // fall through
case "forbidden": // fall through
case "token_expired":
const headersList = await headers()
const returnURL = `/${params.lang}/webview${headersList.get("x-pathname")!}`
const redirectURL = `/${params.lang}/webview/refresh?returnUrl=${encodeURIComponent(returnURL)}`
console.log(`[webview:page] user error, redirecting to: ${redirectURL}`)
redirect(redirectURL)
case "notfound":
return (
<p>
{intl.formatMessage({
defaultMessage: "Error: user not found",
})}
</p>
)
case "unknown":
return (
<p>
{intl.formatMessage({
defaultMessage: "Unknown error occurred loading user",
})}
</p>
)
default:
const u: never = user
console.log("[webview:page] unhandled user loading error", u)
}
}
return <>{children}</>
}