mirror of
https://github.com/SomboChea/ui
synced 2024-05-04 02:21:36 +07:00
39 lines
1.3 KiB
TypeScript
39 lines
1.3 KiB
TypeScript
import React, { useEffect } from 'react';
|
|
import { ThemeProvider as MuiThemeProvider } from '@material-ui/core/styles';
|
|
import { ThemeProvider as EmotionThemeProvider } from 'emotion-theming';
|
|
import i18next from 'i18next';
|
|
|
|
import loadDayJSLocale from './load-dayjs-locale';
|
|
import ThemeContext from './ThemeContext';
|
|
import { getTheme, ThemeMode } from './theme';
|
|
import useLocalStorage from './useLocalStorage';
|
|
|
|
const ThemeProvider: React.FC = ({ children }) => {
|
|
const isDarkModeDefault = window?.__VERDACCIO_BASENAME_UI_OPTIONS?.darkMode;
|
|
const currentLanguage = i18next.languages?.[0];
|
|
|
|
const [isDarkMode, setIsDarkMode] = useLocalStorage('darkMode', !!isDarkModeDefault);
|
|
const [language, setLanguage] = useLocalStorage('language', currentLanguage);
|
|
|
|
const themeMode: ThemeMode = isDarkMode ? 'dark' : 'light';
|
|
|
|
const changeLanguage = async () => {
|
|
await i18next.changeLanguage(language);
|
|
};
|
|
|
|
useEffect(() => {
|
|
changeLanguage();
|
|
loadDayJSLocale();
|
|
}, [language, changeLanguage, loadDayJSLocale]);
|
|
|
|
return (
|
|
<ThemeContext.Provider value={{ isDarkMode, setIsDarkMode, language, setLanguage }}>
|
|
<EmotionThemeProvider theme={getTheme(themeMode)}>
|
|
<MuiThemeProvider theme={getTheme(themeMode)}>{children}</MuiThemeProvider>
|
|
</EmotionThemeProvider>
|
|
</ThemeContext.Provider>
|
|
);
|
|
};
|
|
|
|
export default ThemeProvider;
|