The storybook supports three color modes: dark, light and system.
- The Storybook's styling adapts based on the selected color mode.
- Your components are wrapped in a
<div>
with a custom dark class.
The different modes are handled as follows:
dark
: thedark
class (or custom dark class) is applied to your component's sandboxlight
: no class is appliedsystem
: Thedark
class is added if your system prefers dark mode (as determined by theprefers-color-scheme
media query).
To enable color mode support, you need to configure it in your Storybook setup:
use PhoenixStorybook,
# ...
color_mode: true
This configuration adds a color theme picker to the Storybook header, allowing you to render the Storybook with the selected mode.
When your components are rendered in Storybook, they are wrapped in a sandbox element (read sandboxing guide).
- If the current color mode is dark (or system mode with dark preference), the sandbox will have a
dark
CSS class. - In light mode, no class is applied.
You can customize the default dark class by specifying it in your configuration:
use PhoenixStorybook,
# ...
color_mode_sandbox_dark_class: "my-dark",
If you use Tailwind for your components, update your tailwind.config.js
file as follows:
module.exports = {
// ...
darkMode: "selector",
};
To use a custom dark class, modify the configuration like this:
module.exports = {
// ...
darkMode: ["selector", ".my-dark"],
};
In your application, ensure that the dark mode class is applied to your DOM element, particularly on or under your sandbox element:
<html class="storybook-demo-sandbox dark">
...
</html>