storybook/docs/configure/environment-variables.md
2022-03-18 01:00:17 +00:00

3.9 KiB

title
Environment variables

You can use environment variables in Storybook to change its behavior in different “modes”. If you supply an environment variable prefixed with STORYBOOK_, it will be available in process.env:

STORYBOOK_THEME=red STORYBOOK_DATA_KEY=12345 npm run storybook

Then we can access these environment variables anywhere inside our preview JavaScript code like below:

<CodeSnippets paths={[ 'common/storybook-read-environment-variables.js.mdx', ]} />

You can also access these variables in your custom <head>/<body> using the substitution %STORYBOOK_X%, for example: %STORYBOOK_THEME% will become red.

💡 If using the environment variables as attributes or values in JavaScript, you may need to add quotes, as the value will be inserted directly. e.g. <link rel="stylesheet" href="%STORYBOOK_STYLE_URL%" />

Using .env files

You can also use .env files to change Storybook's behavior in different modes. For example, if you add a .env file to your project with the following:

STORYBOOK_DATA_KEY=12345

Then you can access this environment variable anywhere, even within your stories:

<CodeSnippets paths={[ 'react/my-component-with-env-variables.js.mdx', 'react/my-component-with-env-variables.ts.mdx', 'react/my-component-with-env-variables.mdx.mdx', 'vue/my-component-with-env-variables.2.js.mdx', 'vue/my-component-with-env-variables.mdx-2.mdx.mdx', 'vue/my-component-with-env-variables.3.js.mdx', 'vue/my-component-with-env-variables.mdx-3.mdx.mdx', 'angular/my-component-with-env-variables.ts.mdx', 'angular/my-component-with-env-variables.mdx.mdx', 'web-components/my-component-with-env-variables.js.mdx', 'svelte/my-component-with-env-variables.js.mdx', 'svelte/my-component-with-env-variables.native-format.mdx', 'svelte/my-component-with-env-variables.mdx.mdx', ]} />

You can also use specific files for specific modes. Add a .env.development or .env.production to apply different values to your environment variables.

You can also pass these environment variables when you are building your Storybook with build-storybook.

Then they'll be hardcoded to the static version of your Storybook.

Using Storybook configuration

Additionally, you can extend your Storybook configuration file (i.e., .storybook/main.js) and provide a configuration field that you can use to define specific variables (e.g., API URLs). For example:

<CodeSnippets paths={[ 'common/storybook-main-env-field-config.js.mdx', ]} />

When Storybook loads, it will enable you to access them in your stories similar as you would do if you were working with an env file:

<CodeSnippets paths={[ 'common/my-component-env-var-config.js.mdx', 'common/my-component-env-var-config.mdx.mdx', ]} />

Using environment variables to choose the browser

Storybook allows you to choose the browser you want to preview your stories. Either through a .env file entry or directly in your storybook script.

The table below lists the available options:

Browser Example
Safari BROWSER="safari"
Firefox BROWSER="firefox"
Chromium BROWSER="chromium"
💡 By default, Storybook will open a new Chrome window as part of its startup process. If you don't have Chrome installed, make sure to include one of the following options, or set your default browser accordingly.