aboutsummaryrefslogtreecommitdiffstats
path: root/webui/src/components
diff options
context:
space:
mode:
authorSascha <GlancingMind@outlook.com>2021-02-23 16:03:07 +0100
committerSascha <GlancingMind@outlook.com>2021-03-04 20:53:27 +0100
commit8c17d730eff3bb59313a2f9f7aa469fe6fff95b2 (patch)
treed03ca941c588fe1719298c41853b4552012e1ab8 /webui/src/components
parent87bc42fb4695872b82cfa9a922d423df7ff21132 (diff)
downloadgit-bug-8c17d730eff3bb59313a2f9f7aa469fe6fff95b2.tar.gz
Add button to toggle between light- and dark-mode
Diffstat (limited to 'webui/src/components')
-rw-r--r--webui/src/components/Header/Header.tsx7
-rw-r--r--webui/src/components/Themer.tsx64
2 files changed, 71 insertions, 0 deletions
diff --git a/webui/src/components/Header/Header.tsx b/webui/src/components/Header/Header.tsx
index 3e39b5f3..3bdb252f 100644
--- a/webui/src/components/Header/Header.tsx
+++ b/webui/src/components/Header/Header.tsx
@@ -5,6 +5,7 @@ import AppBar from '@material-ui/core/AppBar';
import Toolbar from '@material-ui/core/Toolbar';
import { makeStyles } from '@material-ui/core/styles';
+import { LightSwitch } from '../../components/Themer';
import CurrentIdentity from '../CurrentIdentity/CurrentIdentity';
const useStyles = makeStyles((theme) => ({
@@ -21,6 +22,9 @@ const useStyles = makeStyles((theme) => ({
display: 'flex',
alignItems: 'center',
},
+ lightSwitch: {
+ padding: '0 20px',
+ },
logo: {
height: '42px',
marginRight: theme.spacing(2),
@@ -39,6 +43,9 @@ function Header() {
git-bug
</Link>
<div className={classes.filler}></div>
+ <div className={classes.lightSwitch}>
+ <LightSwitch />
+ </div>
<CurrentIdentity />
</Toolbar>
</AppBar>
diff --git a/webui/src/components/Themer.tsx b/webui/src/components/Themer.tsx
new file mode 100644
index 00000000..13d098da
--- /dev/null
+++ b/webui/src/components/Themer.tsx
@@ -0,0 +1,64 @@
+import React, { createContext, useCallback, useContext, useState } from 'react';
+
+import { ThemeProvider } from '@material-ui/core';
+import IconButton from '@material-ui/core/IconButton/IconButton';
+import Tooltip from '@material-ui/core/Tooltip/Tooltip';
+import { createMuiTheme, ThemeOptions } from '@material-ui/core/styles';
+import { NightsStayRounded, WbSunnyRounded } from '@material-ui/icons';
+
+const defaultTheme: ThemeOptions = {
+ palette: {
+ type: 'light',
+ primary: {
+ main: '#263238',
+ },
+ },
+};
+
+const ThemeContext = createContext({
+ toggleMode: () => {},
+ mode: '',
+});
+
+const LightSwitch = () => {
+ const { mode, toggleMode } = useContext(ThemeContext);
+
+ return (
+ <Tooltip title="Toggle Dark-/Lightmode">
+ <IconButton onClick={toggleMode} aria-label="Toggle Dark-/Lightmode">
+ {mode === 'light' ? (
+ <WbSunnyRounded color="secondary" />
+ ) : (
+ <NightsStayRounded color="secondary" />
+ )}
+ </IconButton>
+ </Tooltip>
+ );
+};
+
+type Props = { children: React.ReactNode };
+const Themer = ({ children }: Props) => {
+ const [theme, setTheme] = useState(defaultTheme);
+
+ const toggleMode = useCallback(() => {
+ const newMode = theme.palette?.type === 'dark' ? 'light' : 'dark';
+ const adjustedTheme: ThemeOptions = {
+ ...theme,
+ palette: {
+ ...theme.palette,
+ type: newMode,
+ },
+ };
+ setTheme(adjustedTheme);
+ }, [theme, setTheme]);
+
+ const newMode = theme.palette?.type === 'dark' ? 'light' : 'dark';
+
+ return (
+ <ThemeContext.Provider value={{ toggleMode: toggleMode, mode: newMode }}>
+ <ThemeProvider theme={createMuiTheme(theme)}> {children} </ThemeProvider>
+ </ThemeContext.Provider>
+ );
+};
+
+export { Themer as default, LightSwitch };