ThemeContext component
Themable HIG components within a ThemeContext.Provider
will have access to the provided theme.
Getting started
yarn add @hig/themes
Provide a theme to components
import HIGDarkBlueTheme from '@hig/theme-data/build/esm/darkBlueMediumDensityTheme';
import ThemeContext from '@hig/theme-context';
function MyApp() {
<ThemeContext.Provider value={HIGDarkBlueTheme}>
<TheRestOfMyApp />
</ThemeContext.Provider>
}
For information on customizing a theme or importing theme data in different formats, see the theme-data README.
Consume theme values in a component
import ThemeContext from '@hig/themes';
function MyThemedComponent() {
<ThemeContext.Consumer>{({ resolvedRoles, metadata }) => (
<div style={{
backgroundColor: resolvedRoles["colorScheme.surfaceLevel200Color"],
borderRadius: resolvedRoles["basics.borderRadii.small"],
color: resolvedRoles["colorScheme.textColor"],
padding: resolvedRoles["density.spacings.medium"],
}}>
The current theme is "${metadata.name}".
</div>
)}</ThemeContext.Consumer>
}