36 lines
903 B
TypeScript
36 lines
903 B
TypeScript
import "@styles/globals.css"
|
|
import { LayoutWrapper } from "./root-layout-wrapper"
|
|
import styles from "@styles/Home.module.css"
|
|
import { getSession } from "@lib/server/session"
|
|
import { ServerThemeProvider } from "@wits/next-themes"
|
|
|
|
interface RootLayoutProps {
|
|
children: React.ReactNode
|
|
}
|
|
|
|
export default async function RootLayout({ children }: RootLayoutProps) {
|
|
// TODO: this opts out of SSG
|
|
const session = await getSession()
|
|
return (
|
|
<ServerThemeProvider
|
|
enableSystem={true}
|
|
defaultTheme="dark"
|
|
disableTransitionOnChange
|
|
cookieName={"drift-theme"}
|
|
attribute="data-theme"
|
|
enableColorScheme={true}
|
|
>
|
|
<html lang="en">
|
|
<head />
|
|
<body className={styles.main}>
|
|
<LayoutWrapper
|
|
signedIn={Boolean(session?.user)}
|
|
isAdmin={session?.user.role === "admin"}
|
|
>
|
|
{children}
|
|
</LayoutWrapper>
|
|
</body>
|
|
</html>
|
|
</ServerThemeProvider>
|
|
)
|
|
}
|