First steps towards the SAS partnership * otp flow now pretends to do the linking * Update LinkAccountForm header * Update redirect times * Clean up comments * Set maxAge on sas cookies * make all SAS routes protected * Merge remote-tracking branch 'refs/remotes/origin/feature/sas-login' into feature/sas-login * Require auth for sas link flow * Fix resend otp * Add error support to OneTimePasswordForm * Add Sentry to SAS error boundary * Move SAS_REQUEST_OTP_STATE_STORAGE_COOKIE_NAME * Add missing translations * Merge branch 'master' of bitbucket.org:scandic-swap/web into feature/sas-login * Merge branch 'feature/sas-login' of bitbucket.org:scandic-swap/web into feature/sas-login * Add TooManyCodesError component * Refactor GenericError to support new errors * Add FailedAttemptsError * remove removed component <VWOScript/> * Merge branch 'feature/sas-login' of bitbucket.org:scandic-swap/web into feature/sas-login * remove local cookie-bot reference * Fix sas campaign logo scaling * feature toggle the SAS stuff * Merge branch 'feature/sas-login' of bitbucket.org:scandic-swap/web into feature/sas-login * fix: use env vars for SAS endpoints Approved-by: Linus Flood
69 lines
2.2 KiB
TypeScript
69 lines
2.2 KiB
TypeScript
import "@/app/globals.css"
|
|
import "@scandic-hotels/design-system/style.css"
|
|
|
|
import { ReactQueryDevtools } from "@tanstack/react-query-devtools"
|
|
import Script from "next/script"
|
|
|
|
import { env } from "@/env/server"
|
|
import TrpcProvider from "@/lib/trpc/Provider"
|
|
|
|
import TokenRefresher from "@/components/Auth/TokenRefresher"
|
|
import CookieBotConsent from "@/components/CookieBot"
|
|
import StorageCleaner from "@/components/HotelReservation/EnterDetails/StorageCleaner"
|
|
import { ToastHandler } from "@/components/TempDesignSystem/Toasts"
|
|
import { preloadUserTracking } from "@/components/TrackingSDK"
|
|
import AdobeSDKScript from "@/components/TrackingSDK/AdobeSDKScript"
|
|
import GTMScript from "@/components/TrackingSDK/GTMScript"
|
|
import RouterTracking from "@/components/TrackingSDK/RouterTracking"
|
|
import { getIntl } from "@/i18n"
|
|
import ServerIntlProvider from "@/i18n/Provider"
|
|
import { setLang } from "@/i18n/serverContext"
|
|
|
|
import type { LangParams, LayoutArgs } from "@/types/params"
|
|
|
|
export default async function RootLayout({
|
|
children,
|
|
params,
|
|
}: React.PropsWithChildren<LayoutArgs<LangParams>>) {
|
|
if (!env.SAS_ENABLED) {
|
|
return null
|
|
}
|
|
|
|
setLang(params.lang)
|
|
preloadUserTracking()
|
|
const { defaultLocale, locale, messages } = await getIntl()
|
|
|
|
return (
|
|
<html lang={params.lang}>
|
|
<head>
|
|
<AdobeSDKScript />
|
|
<GTMScript />
|
|
<Script
|
|
strategy="beforeInteractive"
|
|
data-blockingmode="auto"
|
|
data-cbid="6d539de8-3e67-4f0f-a0df-8cef9070f712"
|
|
data-culture="@cultureCode"
|
|
id="Cookiebot"
|
|
src="https://consent.cookiebot.com/uc.js"
|
|
/>
|
|
<Script id="ensure-adobeDataLayer">{`
|
|
window.adobeDataLayer = window.adobeDataLayer || []
|
|
`}</Script>
|
|
</head>
|
|
<body>
|
|
<ServerIntlProvider intl={{ defaultLocale, locale, messages }}>
|
|
<TrpcProvider>
|
|
<RouterTracking />
|
|
{children}
|
|
<ToastHandler />
|
|
<TokenRefresher />
|
|
<StorageCleaner />
|
|
<CookieBotConsent />
|
|
<ReactQueryDevtools initialIsOpen={false} />
|
|
</TrpcProvider>
|
|
</ServerIntlProvider>
|
|
</body>
|
|
</html>
|
|
)
|
|
}
|