@nx/storybook - Generators
The @nx/storybook plugin provides various generators to help you create and configure storybook projects within your Nx workspace. Below is a complete reference for all available generators and their options.
configuration
Add Storybook configuration to a UI library or an application.
This is a framework-agnostic generator for setting up Storybook configuration for a project.
nx g @nx/storybook:configuration
{% callout type=“info” title=“Nx uses Storybook 7” %} Nx does not support Storybook v6 any more. So, Nx will configure your project to use Storybook v7. If you are not on Storybook 7 yet, please migrate. Please follow our Storybook 7 migration generator guide. {% /callout %}
If you are using Angular, React, Next.js, Vue or React Native in your project, it’s best to use the framework specific Storybook configuration generator:
-
React Storybook Configuration Generator (React and Next.js projects)
If you are not using one of the framework-specific generators mentioned above, when running this generator you will be prompted to provide the following:
- The
name
of the project you want to generate the configuration for. - The
uiFramework
you want to use. Supported values are:@storybook/angular
@storybook/html-webpack5
@storybook/nextjs
@storybook/preact-webpack5
@storybook/react-webpack5
@storybook/react-vite
@storybook/server-webpack5
@storybook/svelte-webpack5
@storybook/svelte-vite
@storybook/sveltekit
@storybook/vue-webpack5
@storybook/vue-vite
@storybook/vue3-webpack5
@storybook/vue3-vite
@storybook/web-components-webpack5
@storybook/web-components-vite
- Whether you want to set up Storybook interaction tests (
interactionTests
). If you chooseyes
, all the necessary dependencies will be installed. Also, atest-storybook
target will be generated in your project’sproject.json
, with a command to invoke the Storybooktest-runner
. You can read more about this in the Nx Storybook interaction tests documentation page.
You must provide a name
and a uiFramework
for the generator to work.
You can read more about how this generator works, in the Storybook package overview page.
Examples
Generate Storybook configuration using JavaScript
nx g @nx/storybook:configuration ui --uiFramework=@storybook/web-components-vite --tsConfiguration=false
By default, our generator generates TypeScript Storybook configuration files. You can choose to use JavaScript for the Storybook configuration files of your project (the files inside the .storybook
directory, eg. .storybook/main.js
).
Usage:
nx generate @nx/storybook:configuration [options]
Arguments:
nx generate @nx/storybook:configuration <project> [options]
Options
Option | Type | Description | Default |
---|---|---|---|
uiFramework | string [required] | Storybook UI Framework to use. | |
configureStaticServe | boolean | Add a static-storybook to serve the static storybook built files. | false |
interactionTests | boolean | Set up Storybook interaction tests. | true |
js | boolean | Generate JavaScript story files rather than TypeScript story files. | false |
linter | string | The tool to use for running lint checks. | "eslint" |
skipFormat | boolean | Skip formatting files. | false |
standaloneConfig | boolean | Split the project configuration into <projectRoot>/project.json rather than including it inside workspace.json . | true |
tsConfiguration | boolean | Configure your project with TypeScript. Generate main.ts and preview.ts files, instead of main.js and preview.js. | true |
convert-to-inferred
Convert existing Storybook project(s) using @nx/storybook:*
executors to use @nx/storybook/plugin
. Defaults to migrating all projects. Pass ‘—project’ to migrate only one target.
Usage:
nx generate @nx/storybook:convert-to-inferred [options]
Options
Option | Type | Description | Default |
---|---|---|---|
project | string | The project to convert from using the @nx/storybook:* executors to use @nx/storybook/plugin . | |
skipFormat | boolean | Whether to format files at the end of the migration. | false |
migrate-8
Migrate Storybook to version 8.
Storybook 8 is a major release that brings a lot of new features and improvements. You can read more about it in the Storybook 8.0.0 release article. Apart from the new features and improvements it introduces, it also brings some breaking changes. You can read more about them in the Storybook 8 migration docs and the Storybook 8.0.0 migration guide.
You can now migrate your existing Nx workspace with Storybook configuration to use Storybook version 8. To help you, Nx offers the @nx/storybook:migrate-8
generator. This generator will help you migrate your existing Storybook setup to version 8.
How to use it
Just call:
npx nx g @nx/storybook:migrate-8
{% callout type=“warning” title=“Commit your changes” %} It is advised that you start with a clean git history before running this generator, since it is going to be making lots of changes to your workspace. {% /callout %}
You can run this generator using the above command, without passing any options. This will start the migration process for all your projects that have Storybook configured. The logs will explain what is happening in every step, and the logs are mixed Nx and Storybook CLI logs. During the process you will be prompted by the Storybook CLI to accept the automigration scripts. You can read more about that in the next section.
When the generator finishes, you will see a summary of the changes that were made to your workspace, and it will also create a new file, called storybook-migration-summary.md
at the root of your project, which will contain a list of all the changes that were made to your workspace.
Accept the automigration prompts
The Storybook CLI (running through our generator) will prompt you to run some code generators and modifiers.
You can say yes
to these prompts, which are usually the following (there may be more or less, depending on your setup,
and depending on the latest versions of the Storybook CLI - this code is NOT managed by Nx, but by Storybook):
mainjsFramework
: It will try to add theframework
field in your project’s.storybook/main.js|ts
file.eslintPlugin
: installs theeslint-plugin-storybook
newFrameworks
: removes unused dependencies (eg.@storybook/builder-webpack5
,@storybook/manager-webpack5
,@storybook/builder-vite
)autodocsTrue
: addsautodocs: true
to your project’s.storybook/main.js|ts
file
Check the result
Once the generator finishes, and the Storybook CLI automigration scripts have run, you should check the result. Examples of migrated .storybook/main.js|ts
files would look like this:
Full example for Angular projects
Here is an example of a project-level .storybook/main.js|ts
file for an Angular project that has been migrated to Storybook version 8:
const config = { stories: ['../src/app/**/*.@(mdx|stories.@(js|jsx|ts|tsx)'], addons: ['@storybook/addon-essentials'], framework: { name: '@storybook/angular', options: {}, },};
export default config;
Full example for React projects with Vite
Here is an example of a project-level .storybook/main.js|ts
file for a React project using Vite that has been migrated to Storybook version 8:
const config = { stories: ['../src/app/**/*.@(mdx|stories.@(js|jsx|ts|tsx)'], addons: ['@storybook/addon-essentials'], framework: { name: '@storybook/react-vite', options: { builder: { viteConfigPath: 'apps/rv1/vite.config.ts', }, }, },};
export default config;
Make sure that all works by running Storybook
You can now use Storybook 8! 🎉
npx nx build-storybook PROJECT_NAME
and
npx nx storybook PROJECT_NAME
Run the generator by automatically accepting the Storybook CLI prompts
You can run the generator with the --autoAcceptAllPrompts
flag, which will automatically accept all the Storybook CLI prompts. This is useful if you want to run the generator in a CI environment, or if you want to run the generator in a script. Or if you are sure that you want to accept all the prompts!
npx nx g @nx/storybook:migrate-8 --autoAcceptAllPrompts
The Storybook CLI may still ask you about some things, but mostly it should just run the whole migration suite uninterrupted.
Run the migration manually
Nx gives you the ability to run all the migration steps one by one, manually, but still with the help of our migrator. To help you out with the commands that you need to run, Nx will print out the instructions if you run the generator with the --onlyShowListOfCommands
flag, like this:
npx nx g @nx/storybook:migrate-8 --onlyShowListOfCommands
Essentially, the way to run the migration manually is the following:
- Call the Nx generator to show you the list of commands:
npx nx g @nx/storybook:migrate-8 --onlyShowListOfCommands
- Call the Storybook upgrade script:
npx storybook@latest upgrade
- Call the Storybook automigrate scripts for each one of the projects using Storybook (the
@nx/storybook:migrate-8
will give you the list of all the commands)
Report any issues and bugs
Please report any issues and bugs you find on the Nx GitHub page or on the Storybook GitHub page.
Usage:
nx generate @nx/storybook:migrate-8 [options]
Options
Option | Type | Description | Default |
---|---|---|---|
autoAcceptAllPrompts | boolean | Say yes to all the prompts from the Storybook CLI migration scripts. | false |
noUpgrade | boolean | Skip upgrading Storybook packages. Only use this option if you are already on version 8, and you do not want the latest beta. | false |
onlyShowListOfCommands | boolean | Only show the steps that you need to follow in order to migrate. This does NOT make any changes to your code. | false |
migrate-9
Migrate Storybook to version 9.
Storybook 9 is a major release that brings a lot of new features and improvements. You can read more about it in the Storybook 9.0.0 release article. Apart from the new features and improvements it introduces, it also brings some breaking changes. You can read more about them in the Storybook 9 migration docs and the Storybook 9.0.0 migration guide.
You can now migrate your existing Nx workspace with Storybook configuration to use Storybook version 8. To help you, Nx offers the @nx/storybook:migrate-9
generator. This generator will help you migrate your existing Storybook setup to version 8.
How to use it
Just call:
npx nx g @nx/storybook:migrate-9
{% callout type=“warning” title=“Commit your changes” %} It is advised that you start with a clean git history before running this generator, since it is going to be making lots of changes to your workspace. {% /callout %}
You can run this generator using the above command, without passing any options. This will start the migration process for all your projects that have Storybook configured. The logs will explain what is happening in every step, and the logs are mixed Nx and Storybook CLI logs. During the process you will be prompted by the Storybook CLI to accept the automigration scripts. You can read more about that in the next section.
When the generator finishes, you will see a summary of the changes that were made to your workspace, and it will also create a new file, called storybook-migration-summary.md
at the root of your project, which will contain a list of all the changes that were made to your workspace.
Accept the automigration prompts
The Storybook CLI (running through our generator) will prompt you to run some code generators and modifiers.
You can say yes
to these prompts, which are usually the following (there may be more or less, depending on your setup,
and depending on the latest versions of the Storybook CLI - this code is NOT managed by Nx, but by Storybook):
mainjsFramework
: It will try to add theframework
field in your project’s.storybook/main.js|ts
file.eslintPlugin
: installs theeslint-plugin-storybook
newFrameworks
: removes unused dependencies (eg.@storybook/builder-webpack5
,@storybook/manager-webpack5
,@storybook/builder-vite
)autodocsTrue
: addsautodocs: true
to your project’s.storybook/main.js|ts
file
Check the result
Once the generator finishes, and the Storybook CLI automigration scripts have run, you should check the result. Examples of migrated .storybook/main.js|ts
files would look like this:
Full example for Angular projects
Here is an example of a project-level .storybook/main.js|ts
file for an Angular project that has been migrated to Storybook version 8:
const config = { stories: ['../src/app/**/*.@(mdx|stories.@(js|jsx|ts|tsx)'], addons: ['@storybook/addon-essentials'], framework: { name: '@storybook/angular', options: {}, },};
export default config;
Full example for React projects with Vite
Here is an example of a project-level .storybook/main.js|ts
file for a React project using Vite that has been migrated to Storybook version 8:
const config = { stories: ['../src/app/**/*.@(mdx|stories.@(js|jsx|ts|tsx)'], addons: ['@storybook/addon-essentials'], framework: { name: '@storybook/react-vite', options: { builder: { viteConfigPath: 'apps/rv1/vite.config.ts', }, }, },};
export default config;
Make sure that all works by running Storybook
You can now use Storybook 9! 🎉
npx nx build-storybook PROJECT_NAME
and
npx nx storybook PROJECT_NAME
Run the generator by automatically accepting the Storybook CLI prompts
You can run the generator with the --autoAcceptAllPrompts
flag, which will automatically accept all the Storybook CLI prompts. This is useful if you want to run the generator in a CI environment, or if you want to run the generator in a script. Or if you are sure that you want to accept all the prompts!
npx nx g @nx/storybook:migrate-9 --autoAcceptAllPrompts
The Storybook CLI may still ask you about some things, but mostly it should just run the whole migration suite uninterrupted.
Run the migration manually
Nx gives you the ability to run all the migration steps one by one, manually, but still with the help of our migrator. To help you out with the commands that you need to run, Nx will print out the instructions if you run the generator with the --onlyShowListOfCommands
flag, like this:
npx nx g @nx/storybook:migrate-9 --onlyShowListOfCommands
Essentially, the way to run the migration manually is the following:
- Call the Nx generator to show you the list of commands:
npx nx g @nx/storybook:migrate-9 --onlyShowListOfCommands
- Call the Storybook upgrade script:
npx storybook@latest upgrade
- Call the Storybook automigrate scripts for each one of the projects using Storybook (the
@nx/storybook:migrate-9
will give you the list of all the commands)
Report any issues and bugs
Please report any issues and bugs you find on the Nx GitHub page or on the Storybook GitHub page.
Usage:
nx generate @nx/storybook:migrate-9 [options]
Options
Option | Type | Description | Default |
---|---|---|---|
autoAcceptAllPrompts | boolean | Say yes to all the prompts from the Storybook CLI migration scripts. | false |
noUpgrade | boolean | Skip upgrading Storybook packages. Only use this option if you are already on version 9, and you do not want to install the packages again. | false |
onlyShowListOfCommands | boolean | Only show the steps that you need to follow in order to migrate. This does NOT make any changes to your code. | false |
versionTag | string | The version of Storybook to use. Use ‘latest’ to use the latest stable version, or ‘next’ to use the latest beta. | "latest" |
## Getting Help
You can get help for any generator by adding the `--help` flag:
```bash nx generate @nx/storybook:<generator> --help ```