CoastalCommitsPastes/client/app/root-layout-wrapper.tsx

74 lines
1.9 KiB
TypeScript
Raw Normal View History

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
export function LayoutWrapper({
children,
signedIn,
isAdmin,
}: {
children: React.ReactNode
2022-11-12 18:39:03 -08:00
signedIn?: boolean
isAdmin?: boolean
}) {
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)",
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"}>
<ThemeProvider
disableTransitionOnChange
cookieName="drift-theme"
attribute="data-theme"
2022-11-09 18:38:05 -08:00
>
<CssBaseline />
<Page width={"100%"}>
<Page.Header>
<Header isAdmin={isAdmin} signedIn={signedIn} />
</Page.Header>
{children}
</Page>
</ThemeProvider>
2022-11-12 18:39:03 -08:00
</GeistProvider>
</RadixTooltip.Provider>
2022-11-09 18:38:05 -08:00
)
}