VaneUI

VaneUI

Customization

Theme & ThemeOverride

Customize themes using ThemeProvider's theme and themeOverride properties (applied to providers, not components).

The themeOverride property allows programmatic modifications to component themes. Use it to add base classes or change defaults for any subtree of your application.

Basic Usage

Modifying Base Classes

Add CSS classes that apply to all instances of a component:

react-icon
<ThemeProvider themeOverride={(theme) => {
theme.button.base += ' uppercase tracking-wide';
theme.card.base += ' shadow-sm';
return theme;
}}>
<Button primary>Uppercase Button</Button>
<Card>Card with Shadow</Card>
</ThemeProvider>

Modifying Default Props

Change the default boolean props for components:

react-icon
<ThemeProvider themeOverride={(theme) => {
theme.button.defaults = {
...theme.button.defaults,
filled: true,
rounded: true
};
return theme;
}}>
<Button primary>Filled Rounded Button</Button>
</ThemeProvider>

Note: For changing defaults, prefer using themeDefaults instead - it's simpler:

react-icon
// Preferred approach for defaults
<ThemeProvider themeDefaults={{
button: { filled: true, rounded: true }
}}>

Combining with Other Props

Use themeOverride alongside themeDefaults and extraClasses:

react-icon
<ThemeProvider
themeDefaults={{ button: { primary: true } }}
themeOverride={(theme) => {
theme.button.base += ' font-semibold';
return theme;
}}
extraClasses={{
button: { primary: 'hover:shadow-lg' }
}}
>
<Button>Fully Customized</Button>
</ThemeProvider>

Nested ThemeProviders

Child overrides build on parent modifications:

react-icon
<ThemeProvider themeOverride={(theme) => {
theme.button.base += ' uppercase';
return theme;
}}>
<Button>Uppercase</Button>
<ThemeProvider themeOverride={(theme) => {
theme.button.base += ' tracking-widest';
return theme;
}}>
<Button>Uppercase + Wide Tracking</Button>
</ThemeProvider>
</ThemeProvider>

When to Use themeOverride

  • Use themeOverride when you need to add base CSS classes to all component instances
  • Use themeDefaults when you want to change default boolean props (simpler syntax)
  • Use extraClasses when you want to add classes based on active props