mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-15 11:51:34 +00:00
* feat: init * fix * fix * fix * feat * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: implement icons * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: update init command * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: dialog * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add registry:base item type * feat: rename frame to canva * fix * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fi * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add all colors * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add outfit font * fix * fix * fix * fix * fix * chore: changeset * fix * fix * fix * fix * fix * fix * fix * fix
57 lines
1.2 KiB
TypeScript
57 lines
1.2 KiB
TypeScript
"use client"
|
|
|
|
import {
|
|
createContext,
|
|
useContext,
|
|
useEffect,
|
|
useState,
|
|
type ReactNode,
|
|
} from "react"
|
|
|
|
const DEFAULT_THEME = "default"
|
|
|
|
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(() => {
|
|
Array.from(document.body.classList)
|
|
.filter((className) => className.startsWith("theme-"))
|
|
.forEach((className) => {
|
|
document.body.classList.remove(className)
|
|
})
|
|
document.body.classList.add(`theme-${activeTheme}`)
|
|
if (activeTheme.endsWith("-scaled")) {
|
|
document.body.classList.add("theme-scaled")
|
|
}
|
|
}, [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
|
|
}
|