mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-25 21:56:08 +00:00
* feat: update dark colors * feat(v4): update dark mode colors * fix * fix * fix: slate and stone mismatches * feat(v4): update skeleton and switch colors * feat(v4): add dashboard example * fix(v4): update dashboard components * fix: themes * feat: update sonner * feat(v4): update dashboard buttons * fix: test new colors * fix: build commands * feat(v4): more color updates * feat(v4): update theme selector * fix(v4): minor component fixes
63 lines
1.4 KiB
TypeScript
63 lines
1.4 KiB
TypeScript
"use client"
|
|
|
|
import {
|
|
ReactNode,
|
|
createContext,
|
|
useContext,
|
|
useEffect,
|
|
useState,
|
|
} from "react"
|
|
|
|
const COOKIE_NAME = "active_theme"
|
|
const DEFAULT_THEME = "default"
|
|
|
|
function setThemeCookie(theme: string) {
|
|
if (typeof window === "undefined") return
|
|
|
|
document.cookie = `${COOKIE_NAME}=${theme}; path=/; max-age=31536000; SameSite=Lax; ${window.location.protocol === "https:" ? "Secure;" : ""}`
|
|
}
|
|
|
|
type ThemeContextType = {
|
|
activeTheme: string
|
|
setActiveTheme: (theme: string) => void
|
|
}
|
|
|
|
const ThemeContext = createContext<ThemeContextType | undefined>(undefined)
|
|
|
|
export function ActiveThemeProvider({
|
|
children,
|
|
initialTheme,
|
|
}: {
|
|
children: ReactNode
|
|
initialTheme?: string
|
|
}) {
|
|
const [activeTheme, setActiveTheme] = useState<string>(
|
|
() => initialTheme || DEFAULT_THEME
|
|
)
|
|
|
|
useEffect(() => {
|
|
setThemeCookie(activeTheme)
|
|
|
|
document.body.classList.forEach((className) => {
|
|
if (className.startsWith("theme-")) {
|
|
document.body.classList.remove(className)
|
|
}
|
|
})
|
|
document.body.classList.add(`theme-${activeTheme}`)
|
|
}, [activeTheme])
|
|
|
|
return (
|
|
<ThemeContext.Provider value={{ activeTheme, setActiveTheme }}>
|
|
{children}
|
|
</ThemeContext.Provider>
|
|
)
|
|
}
|
|
|
|
export function useThemeConfig() {
|
|
const context = useContext(ThemeContext)
|
|
if (context === undefined) {
|
|
throw new Error("useThemeConfig must be used within an ActiveThemeProvider")
|
|
}
|
|
return context
|
|
}
|