From f8e95fc301bf743a55f205bfc40bad9c9bc5dca0 Mon Sep 17 00:00:00 2001 From: Tobias Date: Sun, 4 Feb 2024 05:14:16 +0100 Subject: [PATCH 1/3] add darkmod only atm --- website/src/App.tsx | 32 ++++++++++++++++++++------------ 1 file changed, 20 insertions(+), 12 deletions(-) diff --git a/website/src/App.tsx b/website/src/App.tsx index d3f98fa4..69823146 100644 --- a/website/src/App.tsx +++ b/website/src/App.tsx @@ -8,7 +8,13 @@ import { grpc } from './Api'; import { AppState } from './AppState'; import { YourDevices } from './pages/YourDevices'; import { AllDevices } from './pages/admin/AllDevices'; +import { ThemeProvider, createTheme } from '@mui/material/styles'; +const darkTheme = createTheme({ + palette: { + mode: 'dark', + }, +}); export const App = observer(class App extends React.Component { async componentDidMount() { AppState.info = await grpc.server.info({}); @@ -20,18 +26,20 @@ export const App = observer(class App extends React.Component { } return ( - - - - - } /> - {AppState.info.isAdmin && ( - <> - } /> - - )} - - + + + + + + } /> + {AppState.info.isAdmin && ( + <> + } /> + + )} + + + ); } From 941c704c6b42c6befa053f02ee261ecdfc1e02b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Nico=20Waldisp=C3=BChl?= Date: Sat, 10 Feb 2024 21:12:51 +0100 Subject: [PATCH 2/3] Improves dark mode by: - initializing the theme with the OS setting - adding toggle button in navigation bar - introducing global state - keeping user preference in local storage (if different to OS setting) --- website/src/App.tsx | 14 +++++---- website/src/AppState.ts | 15 +++++++-- website/src/components/Navigation.tsx | 44 ++++++++++++++++++++++++++- 3 files changed, 64 insertions(+), 9 deletions(-) diff --git a/website/src/App.tsx b/website/src/App.tsx index 69823146..f59434f0 100644 --- a/website/src/App.tsx +++ b/website/src/App.tsx @@ -10,11 +10,6 @@ import { YourDevices } from './pages/YourDevices'; import { AllDevices } from './pages/admin/AllDevices'; import { ThemeProvider, createTheme } from '@mui/material/styles'; -const darkTheme = createTheme({ - palette: { - mode: 'dark', - }, -}); export const App = observer(class App extends React.Component { async componentDidMount() { AppState.info = await grpc.server.info({}); @@ -24,9 +19,16 @@ export const App = observer(class App extends React.Component { if (!AppState.info) { return

loading...

; } + + const darkLightTheme = createTheme({ + palette: { + mode: AppState.darkMode ? 'dark' : 'light', + }, + }); + return ( - + diff --git a/website/src/AppState.ts b/website/src/AppState.ts index c7ef1f73..fb4d7220 100644 --- a/website/src/AppState.ts +++ b/website/src/AppState.ts @@ -1,13 +1,24 @@ -import { observable, makeObservable } from 'mobx'; +import {observable, makeObservable, runInAction} from 'mobx'; import { InfoRes } from './sdk/server_pb'; class GlobalAppState { info?: InfoRes.AsObject; + darkMode: boolean; constructor() { makeObservable(this, { - info: observable + info: observable, + darkMode: observable }); + + this.darkMode = false; + } + + setDarkMode(darkMode: boolean) { + runInAction(() => { + this.darkMode = darkMode; + }) + } } diff --git a/website/src/components/Navigation.tsx b/website/src/components/Navigation.tsx index 900e4bfb..6256f4c9 100644 --- a/website/src/components/Navigation.tsx +++ b/website/src/components/Navigation.tsx @@ -1,4 +1,4 @@ -import React from 'react'; +import React, {useEffect} from 'react'; import makeStyles from '@mui/styles/makeStyles'; import { getCookie } from '../Cookies'; import { AppState } from '../AppState'; @@ -10,6 +10,10 @@ import Link from '@mui/material/Link'; import Button from '@mui/material/Button'; import Chip from '@mui/material/Chip'; import VpnKey from '@mui/icons-material/VpnKey'; +import IconButton from "@mui/material/IconButton"; +import Brightness4Icon from '@mui/icons-material/Brightness4'; +import Brightness7Icon from '@mui/icons-material/Brightness7'; +import {useMediaQuery} from "@mui/material"; const useStyles = makeStyles((theme) => ({ title: { @@ -38,6 +42,8 @@ export default function Navigation() { )} + + {AppState.info?.isAdmin && ( @@ -53,3 +59,39 @@ export default function Navigation() { ); } + +function DarkModeToggle() { + + const CUSTOM_DARK_MODE_KEY = "customDarkMode"; + const prefersDarkMode = useMediaQuery('(prefers-color-scheme: dark)'); + + useEffect(()=>{ + let customDarkMode = localStorage.getItem(CUSTOM_DARK_MODE_KEY); + if (customDarkMode) { + AppState.setDarkMode(JSON.parse(customDarkMode)); + } + else { + AppState.setDarkMode(prefersDarkMode); + } + + },[prefersDarkMode]); + + function toggleDarkMode() { + AppState.setDarkMode(!AppState.darkMode); + + // We only persist the preference in the local storage if it is different to the OS setting. + if (prefersDarkMode !== AppState.darkMode) { + localStorage.setItem(CUSTOM_DARK_MODE_KEY, JSON.stringify(AppState.darkMode)); + } + else { + localStorage.removeItem(CUSTOM_DARK_MODE_KEY); + } + } + + return ( + + {AppState.darkMode ? : } + + ); + +} From 102c14c158de8ae1fada954edba9f890e1010bed Mon Sep 17 00:00:00 2001 From: Tobias Date: Sat, 10 Feb 2024 23:06:27 +0100 Subject: [PATCH 3/3] added darkmode for user/device delete --- website/src/components/Present.tsx | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/website/src/components/Present.tsx b/website/src/components/Present.tsx index 5795b38e..14683593 100644 --- a/website/src/components/Present.tsx +++ b/website/src/components/Present.tsx @@ -4,6 +4,8 @@ import DialogActions from '@mui/material/DialogActions'; import DialogContent from '@mui/material/DialogContent'; import DialogContentText from '@mui/material/DialogContentText'; import DialogTitle from '@mui/material/DialogTitle'; +import { ThemeProvider, createTheme } from '@mui/material/styles'; +import { AppState } from '../AppState'; import React from 'react'; import { render, unmountComponentAtNode } from 'react-dom'; @@ -20,7 +22,14 @@ export function present(content: (close: (result: T) => void) => React.ReactN } export function confirm(msg: string): Promise { + const darkLightTheme = createTheme({ + palette: { + mode: AppState.darkMode ? 'dark' : 'light', + }, + }); + return present((close) => ( + close(false)}> Confirm @@ -35,5 +44,6 @@ export function confirm(msg: string): Promise { + )); }