2022-11-17 22:36:53 -08:00
|
|
|
import type { FunctionComponent, PropsWithChildren } from "react"
|
2022-11-15 20:50:54 -08:00
|
|
|
// @ts-ignore -- createServerContext is not in @types/react atm
|
2022-11-17 22:36:53 -08:00
|
|
|
import { useContext, createServerContext } from "react"
|
|
|
|
import { cookies } from "next/headers"
|
|
|
|
import { Theme, THEME_COOKIE_NAME } from "./theme"
|
|
|
|
import { DEFAULT_THEME } from "./theme"
|
2022-11-15 20:50:54 -08:00
|
|
|
|
2022-11-17 22:36:53 -08:00
|
|
|
const ThemeContext = createServerContext<Theme | null>(null)
|
2022-11-15 20:50:54 -08:00
|
|
|
|
|
|
|
export function useServerTheme(): Theme {
|
2022-11-17 22:36:53 -08:00
|
|
|
return useContext(ThemeContext)
|
2022-11-15 20:50:54 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
const ThemeServerContextProvider: FunctionComponent<PropsWithChildren<{}>> = ({
|
2022-11-17 22:36:53 -08:00
|
|
|
children
|
2022-11-15 20:50:54 -08:00
|
|
|
}) => {
|
2022-11-17 22:36:53 -08:00
|
|
|
const cookiesList = cookies()
|
|
|
|
const theme = cookiesList.get(THEME_COOKIE_NAME)?.value ?? DEFAULT_THEME
|
|
|
|
return <ThemeContext.Provider value={theme}>{children}</ThemeContext.Provider>
|
|
|
|
}
|
2022-11-15 20:50:54 -08:00
|
|
|
|
2022-11-17 22:36:53 -08:00
|
|
|
export default ThemeServerContextProvider
|