feat(SW-2873): Move HotelReservationSidePeek to booking-flow * Move sidepeek store to booking-flow * Begin move of HotelReservationSidePeek to booking-flow * Copy Link * Update AccessibilityAccordionItem * Split AccessibilityAccordionItem into two components * Fix tracking for Accordion * Duplicate ButtonLink to booking-flow TEMP * AdditionalAmeneties * wip * Move sidepeek accordion items * Remove temp ButtonLink * Merge branch 'master' into feat/sw-3218-move-hotelreservationsidepeek-to-booking-flow * Fix accordion tracking * Merge branch 'master' into feat/sw-3218-move-hotelreservationsidepeek-to-booking-flow * Update exports * Fix self-referencing import * Merge branch 'master' into feat/sw-3218-move-hotelreservationsidepeek-to-booking-flow * Add 'use client' to tracking function * Merge branch 'master' into feat/sw-3218-move-hotelreservationsidepeek-to-booking-flow * Fix TEMP folder * Refactor sidepeek tracking * Merge branch 'master' into feat/sw-3218-move-hotelreservationsidepeek-to-booking-flow Approved-by: Joakim Jäderberg
111 lines
3.9 KiB
TypeScript
111 lines
3.9 KiB
TypeScript
import "@scandic-hotels/design-system/fonts.css"
|
|
import "@/app/globals.css"
|
|
import "@/public/_static/css/design-system-new-deprecated.css"
|
|
import "@scandic-hotels/design-system/style.css"
|
|
|
|
import { ReactQueryDevtools } from "@tanstack/react-query-devtools"
|
|
import Script from "next/script"
|
|
import { SessionProvider } from "next-auth/react"
|
|
import { NuqsAdapter } from "nuqs/adapters/next/app"
|
|
|
|
import { BookingFlowTrackingProvider } from "@scandic-hotels/booking-flow/BookingFlowTrackingProvider"
|
|
import { Lang } from "@scandic-hotels/common/constants/language"
|
|
|
|
import TrpcProvider from "@/lib/trpc/Provider"
|
|
|
|
import { SessionRefresher } from "@/components/Auth/TokenRefresher"
|
|
import CookieBotConsent from "@/components/CookieBot"
|
|
import Footer from "@/components/Footer"
|
|
import Header from "@/components/Header"
|
|
import StorageCleaner from "@/components/HotelReservation/EnterDetails/StorageCleaner"
|
|
import { RACRouterProvider } from "@/components/RACRouterProvider"
|
|
import RouteChange from "@/components/RouteChange"
|
|
import SitewideAlert from "@/components/SitewideAlert"
|
|
import { ToastHandler } from "@/components/TempDesignSystem/Toasts"
|
|
import AdobeSDKScript from "@/components/TrackingSDK/AdobeSDKScript"
|
|
import GTMScript from "@/components/TrackingSDK/GTMScript"
|
|
import { FontPreload } from "@/fonts/font-preloading"
|
|
import { getMessages } from "@/i18n"
|
|
import ClientIntlProvider from "@/i18n/Provider"
|
|
import { setLang } from "@/i18n/serverContext"
|
|
import { trackAccordionClick } from "@/utils/tracking"
|
|
import { trackBookingSearchClick } from "@/utils/tracking/booking"
|
|
|
|
import type { LangParams, LayoutArgs } from "@/types/params"
|
|
|
|
export default async function RootLayout(
|
|
props: React.PropsWithChildren<
|
|
LayoutArgs<LangParams> & {
|
|
bookingwidget: React.ReactNode
|
|
}
|
|
>
|
|
) {
|
|
const params = await props.params
|
|
|
|
const { bookingwidget, children } = props
|
|
|
|
setLang(params.lang)
|
|
const messages = await getMessages(params.lang)
|
|
|
|
return (
|
|
<html lang={params.lang}>
|
|
<head>
|
|
<FontPreload />
|
|
<AdobeSDKScript />
|
|
<GTMScript />
|
|
{/* eslint-disable-next-line formatjs/no-literal-string-in-jsx */}
|
|
<Script id="ensure-adobeDataLayer">{`
|
|
window.adobeDataLayer = window.adobeDataLayer || []
|
|
window.dataLayer = window.dataLayer || []
|
|
`}</Script>
|
|
</head>
|
|
<body className="scandic">
|
|
<div className="root">
|
|
<SessionProvider basePath="/api/web/auth">
|
|
<ClientIntlProvider
|
|
defaultLocale={Lang.en}
|
|
locale={params.lang}
|
|
messages={messages}
|
|
>
|
|
<NuqsAdapter>
|
|
<TrpcProvider>
|
|
<RACRouterProvider>
|
|
<BookingFlowTrackingProvider
|
|
trackingFunctions={{
|
|
trackBookingSearchClick,
|
|
trackAccordionItemOpen: trackAccordionClick,
|
|
}}
|
|
>
|
|
<RouteChange />
|
|
<SitewideAlert />
|
|
<Header />
|
|
{bookingwidget}
|
|
{children}
|
|
<Footer />
|
|
<ToastHandler />
|
|
<SessionRefresher />
|
|
<StorageCleaner />
|
|
<CookieBotConsent />
|
|
<ReactQueryDevtools initialIsOpen={false} />
|
|
</BookingFlowTrackingProvider>
|
|
</RACRouterProvider>
|
|
</TrpcProvider>
|
|
</NuqsAdapter>
|
|
</ClientIntlProvider>
|
|
</SessionProvider>
|
|
</div>
|
|
|
|
<Script
|
|
strategy="beforeInteractive"
|
|
data-blockingmode="auto"
|
|
data-cbid="6d539de8-3e67-4f0f-a0df-8cef9070f712"
|
|
data-culture={params.lang}
|
|
id="Cookiebot"
|
|
src="https://consent.cookiebot.com/uc.js"
|
|
async={true}
|
|
/>
|
|
</body>
|
|
</html>
|
|
)
|
|
}
|