Themes for applying color in the Carbon Design System
To install @carbon/themes
in your project, you will need to run the following
command using npm:
npm install -S @carbon/themes
If you prefer Yarn, use the following command instead:
yarn add @carbon/themes
You can use @carbon/themes
in JavaScript or Sass by including this package in
your project. By default, @carbon/themes
provides a set of color tokens that
are pre-defined for a specific theme. Currently, we offer the following color
themes: white, gray 10, gray 90, gray 100 .
You can preview all of the token values for this on the Carbon Design System website .
If your project is using Sass, you can include this package and the corresponding default theme by writing the following in your Sass file:
@use '@carbon/themes/scss/themes';
By default, the white theme will be initialized. If you would like to include another theme, you can do so by setting the global theme variable in the import. For example:
@use '@carbon/themes/scss/themes' as *;
@use '@carbon/themes' with (
$theme: $g100
);
Inline theming can be done by using the mixin. For example:
@use '@carbon/themes/scss/themes';
@use '@carbon/themes/scss/theme';
// Use the default white theme here
.my-dark-theme {
@include theme.theme(themes.$g90) {
// Use the dark theme here
}
}
.my-darker-theme {
@include theme.theme(themes.$g100) {
// Use the darker theme here
}
}
If you're looking to use these themes in JavaScript, we export a variety of bindings for you to use, including:
import {
// An object of all themes
themes,
// Direct theme values
white,
g10,
g90,
g100,
// Specific token values
interactive01,
interactive02,
} from '@carbon/themes';
If you're looking for @carbon/themes
API documentation, check out:
If you're looking for more examples on how to use @carbon/themes
, we have some
examples that you can check out:
We're always looking for contributors to help us fix bugs, build new features, or help us improve the project documentation. If you're interested, definitely check out our Contributing Guide! 👀
Licensed under the Apache 2.0 License.