feat: add themes
This commit is contained in:
parent
9ec457bb7a
commit
8191587115
48
src/ThemeProvider.tsx
Normal file
48
src/ThemeProvider.tsx
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
import { normalTheme, Theme } from "./themes";
|
||||||
|
import {
|
||||||
|
createContext,
|
||||||
|
ReactNode,
|
||||||
|
useContext,
|
||||||
|
useEffect,
|
||||||
|
useState,
|
||||||
|
} from "react";
|
||||||
|
|
||||||
|
interface ThemeContextProps {
|
||||||
|
children: ReactNode;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface ThemeContextValue {
|
||||||
|
theme: Theme;
|
||||||
|
setTheme: (theme: Theme) => void;
|
||||||
|
}
|
||||||
|
|
||||||
|
const themeContext = createContext<ThemeContextValue>({
|
||||||
|
theme: normalTheme,
|
||||||
|
setTheme: () => {},
|
||||||
|
});
|
||||||
|
|
||||||
|
const ThemeProvider = ({ children }: ThemeContextProps) => {
|
||||||
|
const [theme, setTheme] = useState(normalTheme);
|
||||||
|
useEffect(() => {
|
||||||
|
if (theme.backgroundColor) {
|
||||||
|
document.body.style.backgroundColor = theme.backgroundColor;
|
||||||
|
document.body.style.backgroundImage = "unset";
|
||||||
|
} else if (theme.backgroundImage) {
|
||||||
|
document.body.style.backgroundColor = "unset";
|
||||||
|
document.body.style.backgroundImage = theme.backgroundImage;
|
||||||
|
}
|
||||||
|
document.body.style.color = theme.textColor;
|
||||||
|
}, [theme]);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<themeContext.Provider value={{ theme, setTheme }}>
|
||||||
|
{children}
|
||||||
|
</themeContext.Provider>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
function useTheme() {
|
||||||
|
return useContext(themeContext);
|
||||||
|
}
|
||||||
|
|
||||||
|
export { ThemeProvider, useTheme };
|
24
src/themes.ts
Normal file
24
src/themes.ts
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
export interface Theme {
|
||||||
|
backgroundColor?: string;
|
||||||
|
backgroundImage?: string;
|
||||||
|
textColor: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export const normalTheme: Theme = {
|
||||||
|
backgroundColor: "aliceblue",
|
||||||
|
textColor: "black",
|
||||||
|
};
|
||||||
|
export const darkTheme: Theme = {
|
||||||
|
backgroundColor: "#444",
|
||||||
|
textColor: "white",
|
||||||
|
};
|
||||||
|
export const colourTheme: Theme = {
|
||||||
|
backgroundImage:
|
||||||
|
"linear-gradient(45deg, magenta, rebeccapurple, dodgerblue, green)",
|
||||||
|
textColor: "white",
|
||||||
|
};
|
||||||
|
export const rainbowTheme: Theme = {
|
||||||
|
backgroundImage:
|
||||||
|
"linear-gradient(135deg, #FF0000, #FFA500, #888800, #008000, #0000FF, #4B0082, #800080 ",
|
||||||
|
textColor: "white",
|
||||||
|
};
|
Loading…
x
Reference in New Issue
Block a user