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:
<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:
<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:
// Preferred approach for defaults<ThemeProvider themeDefaults={{ button: { filled: true, rounded: true }}}>Combining with Other Props
Use themeOverride alongside themeDefaults and extraClasses:
<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:
<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
themeOverridewhen you need to add base CSS classes to all component instances - Use
themeDefaultswhen you want to change default boolean props (simpler syntax) - Use
extraClasseswhen you want to add classes based on active props