2022-11-09 18:38:05 -08:00
|
|
|
"use client"
|
|
|
|
|
2022-11-12 18:39:03 -08:00
|
|
|
import Header from "@components/header"
|
2022-11-09 23:11:36 -08:00
|
|
|
import { CssBaseline, GeistProvider, Page, Themes } from "@geist-ui/core/dist"
|
2022-11-09 18:38:05 -08:00
|
|
|
import { ThemeProvider } from "next-themes"
|
2022-11-12 18:39:03 -08:00
|
|
|
import * as RadixTooltip from "@radix-ui/react-tooltip"
|
2022-11-09 18:38:05 -08:00
|
|
|
|
2022-11-11 19:17:44 -08:00
|
|
|
export function LayoutWrapper({
|
|
|
|
children,
|
2022-11-14 01:28:40 -08:00
|
|
|
signedIn,
|
|
|
|
isAdmin,
|
2022-11-11 19:17:44 -08:00
|
|
|
}: {
|
|
|
|
children: React.ReactNode
|
2022-11-12 18:39:03 -08:00
|
|
|
signedIn?: boolean
|
2022-11-14 01:28:40 -08:00
|
|
|
isAdmin?: boolean
|
2022-11-11 19:17:44 -08:00
|
|
|
}) {
|
2022-11-09 18:38:05 -08:00
|
|
|
const customTheme = Themes.createFromLight({
|
|
|
|
type: "custom",
|
|
|
|
palette: {
|
|
|
|
background: "var(--bg)",
|
|
|
|
foreground: "var(--fg)",
|
|
|
|
accents_1: "var(--lightest-gray)",
|
|
|
|
accents_2: "var(--lighter-gray)",
|
|
|
|
accents_3: "var(--light-gray)",
|
|
|
|
accents_4: "var(--gray)",
|
|
|
|
accents_5: "var(--darker-gray)",
|
|
|
|
accents_6: "var(--darker-gray)",
|
|
|
|
accents_7: "var(--darkest-gray)",
|
|
|
|
accents_8: "var(--darkest-gray)",
|
|
|
|
border: "var(--light-gray)",
|
|
|
|
warning: "var(--warning)"
|
|
|
|
},
|
|
|
|
expressiveness: {
|
2022-11-11 16:33:43 -08:00
|
|
|
dropdownBoxShadow: "0 0 0 1px var(--lighter-gray)",
|
|
|
|
shadowSmall: "0 0 0 1px var(--lighter-gray)",
|
|
|
|
shadowLarge: "0 0 0 1px var(--lighter-gray)",
|
2022-11-11 19:17:44 -08:00
|
|
|
shadowMedium: "0 0 0 1px var(--lighter-gray)"
|
2022-11-09 18:38:05 -08:00
|
|
|
},
|
|
|
|
layout: {
|
|
|
|
gap: "var(--gap)",
|
|
|
|
gapHalf: "var(--gap-half)",
|
|
|
|
gapQuarter: "var(--gap-quarter)",
|
|
|
|
gapNegative: "var(--gap-negative)",
|
|
|
|
gapHalfNegative: "var(--gap-half-negative)",
|
|
|
|
gapQuarterNegative: "var(--gap-quarter-negative)",
|
|
|
|
radius: "var(--radius)"
|
|
|
|
},
|
|
|
|
font: {
|
|
|
|
mono: "var(--font-mono)",
|
|
|
|
sans: "var(--font-sans)"
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
return (
|
2022-11-12 18:39:03 -08:00
|
|
|
<RadixTooltip.Provider delayDuration={200}>
|
|
|
|
<GeistProvider themes={[customTheme]} themeType={"custom"}>
|
2022-11-13 23:02:31 -08:00
|
|
|
<ThemeProvider
|
|
|
|
disableTransitionOnChange
|
|
|
|
cookieName="drift-theme"
|
|
|
|
attribute="data-theme"
|
2022-11-09 18:38:05 -08:00
|
|
|
>
|
2022-11-13 23:02:31 -08:00
|
|
|
<CssBaseline />
|
|
|
|
<Page width={"100%"}>
|
|
|
|
<Page.Header>
|
2022-11-14 01:28:40 -08:00
|
|
|
<Header isAdmin={isAdmin} signedIn={signedIn} />
|
2022-11-13 23:02:31 -08:00
|
|
|
</Page.Header>
|
|
|
|
{children}
|
|
|
|
</Page>
|
|
|
|
</ThemeProvider>
|
2022-11-12 18:39:03 -08:00
|
|
|
</GeistProvider>
|
|
|
|
</RadixTooltip.Provider>
|
2022-11-09 18:38:05 -08:00
|
|
|
)
|
|
|
|
}
|