2019-11-23 19:41:14 +07:00
|
|
|
import React from 'react';
|
|
|
|
import { ThemeProvider as MuiThemeProvider } from '@material-ui/core/styles';
|
|
|
|
import { ThemeProvider as EmotionThemeProvider } from 'emotion-theming';
|
|
|
|
|
2020-03-31 13:44:59 +07:00
|
|
|
import ThemeContext from './ThemeContext';
|
|
|
|
import { getTheme, ThemeMode } from './theme';
|
|
|
|
import useLocalStorage from './useLocalStorage';
|
2019-11-23 19:41:14 +07:00
|
|
|
|
2020-03-31 13:44:59 +07:00
|
|
|
const ThemeProvider: React.FC = ({ children }) => {
|
|
|
|
const isDarkModeDefault = window?.__VERDACCIO_BASENAME_UI_OPTIONS?.darkMode;
|
|
|
|
const [isDarkMode, setIsDarkMode] = useLocalStorage('darkMode', !!isDarkModeDefault);
|
|
|
|
|
|
|
|
const themeMode: ThemeMode = isDarkMode ? 'dark' : 'light';
|
|
|
|
|
|
|
|
return (
|
|
|
|
<ThemeContext.Provider value={{ isDarkMode, setIsDarkMode }}>
|
|
|
|
<EmotionThemeProvider theme={getTheme(themeMode)}>
|
|
|
|
<MuiThemeProvider theme={getTheme(themeMode)}>{children}</MuiThemeProvider>
|
|
|
|
</EmotionThemeProvider>
|
|
|
|
</ThemeContext.Provider>
|
|
|
|
);
|
|
|
|
};
|
2019-11-23 19:41:14 +07:00
|
|
|
|
|
|
|
export default ThemeProvider;
|