Feat/SW-104 add card * feat: add api endpoints for adding and removing credit card * feat(SW-104): Added Sonner toast lib * feat(SW-104): Add route handlers for add card flow * feat(SW-104): Added link to route handler and trigger toast when query params from callback is set * feat(SW-104): Added translations for add card success toast * feat(SW-104): Refactored to use client request for initiate save card * fix(SW-104): Return proper status codes when initiating save card fails * fix(SW-104): remove delete card endpoint because it was added in SW-245 * fix(SW-104): remove console.log * fix(SW-104): Use api.post for save card request * fix(SW-104): move function declaration above export * fix(SW-104): handle response of save card and use Lang enum * fix(SW-104): added comment for why setTimeout is needed for toast and also removed lang prop * fix(SW-104): added type for AddCreditCardButton props * feat: add toasts * fix(SW-104): start using toasts from ToastHandler and fix problem with duplicate toasts * fix(SW-104): remove unnecessary wrapping div Approved-by: Michael Zetterberg
72 lines
2.0 KiB
TypeScript
72 lines
2.0 KiB
TypeScript
import "@/app/globals.css"
|
|
import "@scandic-hotels/design-system/style.css"
|
|
|
|
import Script from "next/script"
|
|
|
|
import TrpcProvider from "@/lib/trpc/Provider"
|
|
|
|
import TokenRefresher from "@/components/Auth/TokenRefresher"
|
|
import AdobeSDKScript from "@/components/Current/AdobeSDKScript"
|
|
import Footer from "@/components/Current/Footer"
|
|
import VwoScript from "@/components/Current/VwoScript"
|
|
import { ToastHandler } from "@/components/TempDesignSystem/Toasts"
|
|
import { preloadUserTracking } from "@/components/TrackingSDK"
|
|
import { getIntl } from "@/i18n"
|
|
import ServerIntlProvider from "@/i18n/Provider"
|
|
import { getLang, setLang } from "@/i18n/serverContext"
|
|
|
|
import type { Metadata } from "next"
|
|
|
|
import type { LangParams, LayoutArgs } from "@/types/params"
|
|
|
|
export const metadata: Metadata = {
|
|
description: "New web",
|
|
title: "Scandic Hotels",
|
|
}
|
|
|
|
export default async function RootLayout({
|
|
children,
|
|
params,
|
|
header,
|
|
}: React.PropsWithChildren<
|
|
LayoutArgs<LangParams> & {
|
|
header: React.ReactNode
|
|
}
|
|
>) {
|
|
setLang(params.lang)
|
|
preloadUserTracking()
|
|
|
|
const { defaultLocale, locale, messages } = await getIntl()
|
|
return (
|
|
<html lang={getLang()}>
|
|
<head>
|
|
<AdobeSDKScript />
|
|
<Script data-cookieconsent="ignore" src="/_static/js/cookie-bot.js" />
|
|
<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>
|
|
<VwoScript />
|
|
</head>
|
|
<body>
|
|
<ServerIntlProvider intl={{ defaultLocale, locale, messages }}>
|
|
<TrpcProvider>
|
|
{header}
|
|
{children}
|
|
<ToastHandler />
|
|
<Footer />
|
|
<TokenRefresher />
|
|
</TrpcProvider>
|
|
</ServerIntlProvider>
|
|
</body>
|
|
</html>
|
|
)
|
|
}
|