Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | import { ThemeProvider } from '@mui/material/styles';
import CssBaseline from '@mui/material/CssBaseline';
import { useSelector } from 'react-redux';
import { selectTheme, selectFontSize } from '@/store/reducers/settings/settings-selectors';
import { createLightTheme, createDarkTheme } from '@/theme/theme';
import { ThemeMode } from '@/enums/settings';
import { ReactNode, useMemo } from 'react';
interface MuiThemeProviderProps {
children: ReactNode;
}
function MuiThemeProvider({ children }: MuiThemeProviderProps) {
const themeMode = useSelector(selectTheme);
const fontSize = useSelector(selectFontSize);
const theme = useMemo(() => {
return themeMode === ThemeMode.Dark ? createDarkTheme(fontSize) : createLightTheme(fontSize);
}, [themeMode, fontSize]);
return (
<ThemeProvider theme={theme}>
<CssBaseline />
{children}
</ThemeProvider>
);
}
export default MuiThemeProvider;
|