Files
Dorod-Sky/skyvern-frontend/src/components/ThemeProvider.tsx

46 lines
989 B
TypeScript
Raw Normal View History

2024-03-21 00:07:02 +03:00
import { useEffect, useState } from "react";
import { Theme, ThemeProviderContext } from "./themeProviderContext";
export type ThemeProviderProps = {
children: React.ReactNode;
defaultTheme?: Theme;
};
export function ThemeProvider({
children,
defaultTheme = "system",
...props
}: ThemeProviderProps) {
2024-05-07 12:54:59 -07:00
const [theme, setTheme] = useState<Theme>(defaultTheme);
2024-03-21 00:07:02 +03:00
useEffect(() => {
const root = window.document.documentElement;
root.classList.remove("light", "dark");
if (theme === "system") {
const systemTheme = window.matchMedia("(prefers-color-scheme: dark)")
.matches
? "dark"
: "light";
root.classList.add(systemTheme);
return;
}
root.classList.add(theme);
}, [theme]);
const value = {
theme,
setTheme: (theme: Theme) => {
setTheme(theme);
},
};
return (
<ThemeProviderContext.Provider {...props} value={value}>
{children}
</ThemeProviderContext.Provider>
);
}