diff options
author | Anton Tananaev <anton@traccar.org> | 2024-04-06 09:22:10 -0700 |
---|---|---|
committer | Anton Tananaev <anton@traccar.org> | 2024-04-06 09:22:10 -0700 |
commit | f418231b6b2f5e030a0d2dcc390c314602b1f740 (patch) | |
tree | 10326adf3792bc2697e06bb5f2b8ef2a8f7e55fe /src/AppThemeProvider.jsx | |
parent | b392a4af78e01c8e0f50aad5468e9583675b24be (diff) | |
download | trackermap-web-f418231b6b2f5e030a0d2dcc390c314602b1f740.tar.gz trackermap-web-f418231b6b2f5e030a0d2dcc390c314602b1f740.tar.bz2 trackermap-web-f418231b6b2f5e030a0d2dcc390c314602b1f740.zip |
Move modern to the top
Diffstat (limited to 'src/AppThemeProvider.jsx')
-rw-r--r-- | src/AppThemeProvider.jsx | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/AppThemeProvider.jsx b/src/AppThemeProvider.jsx new file mode 100644 index 00000000..109d25c4 --- /dev/null +++ b/src/AppThemeProvider.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import { useSelector } from 'react-redux'; +import { ThemeProvider, useMediaQuery } from '@mui/material'; +import theme from './common/theme'; + +const AppThemeProvider = ({ children }) => { + const server = useSelector((state) => state.session.server); + + const serverDarkMode = server?.attributes?.darkMode; + const preferDarkMode = useMediaQuery('(prefers-color-scheme: dark)'); + const darkMode = serverDarkMode !== undefined ? serverDarkMode : preferDarkMode; + + const themeInstance = theme(server, darkMode); + + return ( + <ThemeProvider theme={themeInstance}> + {children} + </ThemeProvider> + ); +}; + +export default AppThemeProvider; |