All files / components/providers/MuiThemeProvider MuiThemeProvider.tsx

0% Statements 0/5
0% Branches 0/2
0% Functions 0/2
0% Lines 0/5

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;