web-humas-fe/app/layout.tsx

83 lines
2.3 KiB
TypeScript
Raw Normal View History

2024-02-05 09:37:05 +00:00
import { fontSans } from "@/config/fonts";
import { siteConfig } from "@/config/site";
2025-02-05 11:23:03 +00:00
import { Inter } from "next/font/google";
2024-01-05 06:57:30 +00:00
import "@/styles/globals.css";
2024-02-05 09:37:05 +00:00
import clsx from "clsx";
2024-01-05 06:57:30 +00:00
import { Metadata } from "next";
import { Providers } from "./providers";
import LoadScript from "@/utils/global";
2024-12-11 10:13:02 +00:00
import { NextIntlClientProvider } from "next-intl";
import storedLanguage from "@/store/language-store";
import { getMessages } from "next-intl/server";
2025-02-05 11:23:03 +00:00
const inter = Inter({ subsets: ["latin"] });
2024-01-05 06:57:30 +00:00
2024-12-11 10:13:02 +00:00
// export const metadata: Metadata = {
// title: {
// default: siteConfig.name,
// template: `%s - ${siteConfig.name}`,
// },
// description: siteConfig.description,
// themeColor: [
// { media: "(prefers-color-scheme: light)", color: "white" },
// { media: "(prefers-color-scheme: dark)", color: "black" },
// ],
// icons: {
// icon: "/logohumas.ico",
// shortcut: "/favicon-16x16.png",
// apple: "/apple-touch-icon.png",
// },
// };
2024-01-05 06:57:30 +00:00
export default async function RootLayout({
children,
params: { locale },
}: Readonly<{
children: React.ReactNode;
params: { locale: string };
}>) {
const messages = await getMessages();
// const locale = storedLanguage((state) => state.locale);
2024-12-11 10:13:02 +00:00
// useEffect(() => {
// if (locale) {
// setLocaleNow(locale);
// }
// }, [locale]);
2024-12-11 10:13:02 +00:00
// const [messages, setMessages] = useState<any>(null);
// useEffect(() => {
// (async () => {
// const loadedMessages = (await import(`../messages/${locale}.json`))
// .default;
// setMessages(loadedMessages);
// })();
// }, [locale]);
return (
<html lang="en" suppressHydrationWarning className="scroll-smooth">
<head>
<meta
name="theme-color"
content="white"
media="(prefers-color-scheme: light)"
/>
<meta
name="theme-color"
content="black"
media="(prefers-color-scheme: dark)"
/>
<LoadScript />
</head>
<body
2025-02-05 11:23:03 +00:00
className={clsx("bg-background font-sans antialiased", inter.className)}
>
<NextIntlClientProvider locale={locale} messages={messages}>
2024-12-11 10:13:02 +00:00
<Providers themeProps={{ attribute: "class", defaultTheme: "dark" }}>
<main className="">{children}</main>
2024-12-11 10:13:02 +00:00
</Providers>
</NextIntlClientProvider>
</body>
</html>
);
2024-01-05 06:57:30 +00:00
}