asynqmon/ui/src/theme.tsx

32 lines
926 B
TypeScript
Raw Normal View History

2021-12-19 23:30:16 +08:00
import { createTheme, Theme } from "@material-ui/core/styles";
import { ThemePreference } from "./reducers/settingsReducer";
import useMediaQuery from "@material-ui/core/useMediaQuery";
2020-11-24 22:54:00 +08:00
export function useTheme(themePreference: ThemePreference): Theme {
let prefersDarkMode = useMediaQuery("(prefers-color-scheme: dark)");
if (themePreference === ThemePreference.Always) {
prefersDarkMode = true;
} else if (themePreference === ThemePreference.Never) {
prefersDarkMode = false;
}
2021-12-19 23:30:16 +08:00
return createTheme({
2021-01-13 07:55:56 +08:00
// Got color palette from https://htmlcolors.com/palette/31/stripe
palette: {
primary: {
main: "#4379FF",
},
secondary: {
main: "#97FBD1",
},
background: {
default: "#f5f7f9",
},
type: prefersDarkMode ? "dark" : "light",
2020-11-24 22:54:00 +08:00
},
2021-01-13 07:55:56 +08:00
});
}
2021-04-19 21:56:00 +08:00
export function isDarkTheme(theme: Theme): boolean {
return theme.palette.type === "dark";
}