Skip to content

Globals

The styleOverrides key enables you to customize the appearance of all instances of a component type, while the props key enables you to change the default value(s) of a component's props.

CSS

When the configuration variables aren't powerful enough, you can take advantage of the styleOverrides key of the theme to potentially change every single style injected by Material-UI into the DOM. That's a really powerful feature.

To override lab components styles with TypeScript, check this documentation.

const theme = createMuiTheme({
  components: {
    // Style sheet name ⚛️
    MuiButton: {
      styleOverrides: {
        // Name of the rule
        textPrimary: {
          // Some CSS
          color: 'white',
        },
      },
    },
  },
});

The list of these customization points for each component is documented under the Component API section. For instance, you can have a look at the Button. Alternatively, you can always have a look at the implementation.

Global CSS

If you are using the CssBaseline component to apply global resets, it can also be used to apply global styles. For instance:

const theme = createMuiTheme({
  components: {
    MuiCssBaseline: {
      styleOverrides: {
        '@global': {
          html: {
            WebkitFontSmoothing: 'auto',
          },
        },
      },
    },
  },
});

// ...
return (
  <ThemeProvider theme={theme}>
    <CssBaseline />
    {children}
  </ThemeProvider>
);

Default props

You can change the default props of all the Material-UI components. A deafaultProps key is exposed in the theme's components key for this use case.

To override lab components styles with TypeScript, check this documentation.

const theme = createMuiTheme({
  components: {
    // Name of the component ⚛️
    MuiButtonBase: {
      defaultProps: {
        // The default props to change
        disableRipple: true, // No more ripple, on the whole application 💣!
      },
    },
  },
});