@nx/storybook

Storybook is a development environment for UI components. It allows you to browse a component library, view the different states of each component, and interactively develop and test components.

This guide will briefly walk you through using Storybook within an Nx workspace.

Setting Up Storybook

Installation

Keep Nx Package Versions In Sync

Make sure to install the @nx/storybook version that matches the version of nx in your repository. If the version numbers get out of sync, you can encounter some difficult to debug errors. You can fix Nx version mismatches with this recipe.

In any Nx workspace, you can install @nx/storybook by running the following command:

nx add @nx/storybook

This will install the correct version of @nx/storybook.

How @nx/storybook Infers Tasks

The @nx/storybook plugin will create a task for any project that has a Storybook configuration file present. Any of the following files will be recognized as a Storybook configuration file:

  • .storybook/main.js
  • .storybook/main.ts
  • .storybook/main.cjs
  • .storybook/main.cts
  • .storybook/main.mjs
  • .storybook/main.mts

View Inferred Tasks

To view inferred tasks for a project, open the project details view in Nx Console or run nx show project my-project --web in the command line.

@nx/storybook Configuration

The @nx/storybook/plugin is configured in the plugins array in nx.json.

nx.json
1{ 2 "plugins": [ 3 { 4 "plugin": "@nx/storybook/plugin", 5 "options": { 6 "buildStorybookTargetName": "build-storybook", 7 "serveStorybookTargetName": "storybook", 8 "testStorybookTargetName": "test-storybook", 9 "staticStorybookTargetName": "static-storybook" 10 } 11 } 12 ] 13} 14

The builtStorybookTargetName, serveStorybookTargetName, testStorybookTargetName and staticStorybookTargetName options control the names of the inferred Storybook tasks. The default names are build-storybook, storybook, test-storybook and static-storybook.

Using Storybook

Generating Storybook Configuration

You can generate Storybook configuration for an individual project with this command:

nx g @nx/storybook:configuration project-name

or

nx g @nx/angular:storybook-configuration my-angular-project

These framework-specific generators will also generate stories and interaction tests for you.

If you are NOT using a framework-specific generator (for Angular, React, React Native, Vue), in the field uiFramework you must choose one of the following Storybook frameworks:

  • @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

Choosing one of these frameworks will have the following effects on your workspace:

  1. Nx will install all the required Storybook packages that go with it.

  2. Nx will generate a project-level .storybook folder (located under libs/your-project/.storybook or apps/your-project/.storybook) containing the essential configuration files for Storybook.

  3. Nx will create new targets in your project's project.json, called storybook, test-storybook and build-storybook, containing all the necessary configuration to serve, test and build Storybook.

Make sure to use the framework-specific generators if your project is using Angular, React, Next.js, Vue, Nuxt, or React Native: @nx/angular:storybook-configuration, @nx/react:storybook-configuration, @nx/react-native:storybook-configuration, @nx/vue:storybook-configuration as shown above.

Running Storybook

Serve Storybook using this command:

nx run project-name:storybook

or

nx storybook project-name

Building Storybook

Build Storybook using this command:

nx run project-name:build-storybook

or

nx build-storybook project-name

Testing Storybook

With the Storybook server running, you can test Storybook (run all the interaction tests) using this command:

nx run project-name:test-storybook

or

nx test-storybook project-name

Anatomy of the Storybook setup

When running the Nx Storybook generator, it'll configure the Nx workspace to be able to run Storybook seamlessly. It'll create a project specific Storybook configuration.

The project-specific Storybook configuration is pretty much similar to what you would have for a non-Nx setup of Storybook. There's a .storybook folder within the project root folder.

1<project root>/ 2├── .storybook/ 3│ ├── main.ts 4│ └── preview.ts 5├── src/ 6├── README.md 7├── tsconfig.json 8├── tsconfig.storybook.json 9└── etc... 10

Using Addons

To register a Storybook addon for all Storybook instances in your workspace:

  1. In your project's .storybook/main.ts file, in the addons array of the module.exports object, add the new addon:
<project-path>/.storybook/main.ts
1import type { StorybookConfig } from '@storybook/react-vite'; 2 3const config: StorybookConfig = { 4 ... 5 addons: ['@storybook/addon-essentials', '@storybook/addon-interactions', ...], 6 ... 7}; 8 9export default config; 10
  1. If a decorator is required, in each project's <project-path>/.storybook/preview.ts, you can export an array called decorators.

    <project-path>/.storybook/preview.ts
    1import someDecorator from 'some-storybook-addon'; 2export const decorators = [someDecorator]; 3

Setting up documentation

To set up documentation, you can use Storybook Autodocs. For Angular, you can use compodoc to infer argTypes. You can read more about argTypes in the official Storybook argTypes documentation.

You can read more about how to best set up documentation using Storybook for your project in the official Storybook documentation.

More Documentation

You can find dedicated information for React and Angular:

You can find all Storybook-related Nx documentation in the Storybook recipes section.

For more on using Storybook, see the official Storybook documentation.

Migration Scenarios

Here's more information on common migration scenarios for Storybook with Nx. For Storybook specific migrations that are not automatically handled by Nx please refer to the official Storybook page

Package reference

Here is a list of all the executors, generators and migrations available from this package.

Guides

Executors

Generators

  • initInternal

    Add Storybook configuration to the workspace.

  • configuration

    Add Storybook configuration to a UI library or an application.

  • cypress-project

    Add cypress E2E app to test a ui library that is set up for Storybook.

  • 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.

  • migrate-7

    Migrate to Storybook version 7.

  • migrate-8

    Migrate to Storybook version 8.

Migrations

  • 20.2.x

  • 20.2.0-package-updates

    Version: 20.2.0-beta.5

    Packages

    NameVersionAlways Add to package.json
    @storybook/test-runner^0.19.0Update only
    @storybook/core-server^8.4.6Update only
    @storybook/angular^8.4.6Update only
    @storybook/react^8.4.6Update only
    @storybook/react-vite^8.4.6Update only
    @storybook/react-webpack5^8.4.6Update only
    @storybook/web-components-vite^8.4.6Update only
    @storybook/web-components-webpack5^8.4.6Update only
    @storybook/addon-a11y^8.4.6Update only
    @storybook/addon-actions^8.4.6Update only
    @storybook/addon-backgrounds^8.4.6Update only
    @storybook/addon-controls^8.4.6Update only
    @storybook/addon-docs^8.4.6Update only
    @storybook/addon-essentials^8.4.6Update only
    @storybook/addon-interactions^8.4.6Update only
    @storybook/addon-mdx-gfm^8.4.6Update only
    @storybook/addon-highlight^8.4.6Update only
    @storybook/addon-jest^8.4.6Update only
    @storybook/addon-links^8.4.6Update only
    @storybook/addon-measure^8.4.6Update only
    @storybook/addon-outline^8.4.6Update only
    @storybook/addon-storysource^8.4.6Update only
    @storybook/addon-toolbars^8.4.6Update only
    @storybook/addon-viewport^8.4.6Update only
    @storybook/vue3^8.4.6Update only
    @storybook/vue3-vite^8.4.6Update only
  • 19.6.x

  • 19.6.0-package-updates

    Version: 19.6.0-beta.1

    Packages

    NameVersionAlways Add to package.json
    @storybook/core-server^8.2.8Update only
    @storybook/angular^8.2.8Update only
    @storybook/react^8.2.8Update only
    @storybook/addon-essentials^8.2.8Update only
    @storybook/addon-interactions^8.2.8Add if not installed
    storybook^8.2.8Add if not installed
    @storybook/test-runner^0.19.0Update only

    update-19-6-0-add-nx-packages

    Update workspace to use Storybook v8

    Version: 19.6.0-beta.0
  • 18.2.x

  • 18.2.0-package-updates

    Version: 18.2.0-beta.1

    Packages

    NameVersionAlways Add to package.json
    core-js3.36.1Update only
  • 17.2.x

  • 17.2.0-beta.2-package-updates

    Version: 17.2.0-beta.2

    Packages

    NameVersionAlways Add to package.json
    vite^5.0.0Update only
  • 17.1.x

  • 17.1.0-beta.4-package-updates

    Version: 17.1.0-beta.4

    Packages

    NameVersionAlways Add to package.json
    @storybook/testing-library^0.2.2Update only
    @storybook/jest^0.2.3Update only

    17.1.0-package-updates

    Version: 17.1.0-beta.3

    Packages

    NameVersionAlways Add to package.json
    @storybook/test-runner^0.13.0Update only
    @storybook/core-server^7.5.3Update only
    @storybook/angular^7.5.3Update only
    @storybook/react^7.5.3Update only
    @storybook/react-vite^7.5.3Update only
    @storybook/react-webpack5^7.5.3Update only
    @storybook/web-components-vite^7.5.3Update only
    @storybook/web-components-webpack5^7.5.3Update only
    @storybook/addon-a11y^7.5.3Update only
    @storybook/addon-actions^7.5.3Update only
    @storybook/addon-backgrounds^7.5.3Update only
    @storybook/addon-controls^7.5.3Update only
    @storybook/addon-docs^7.5.3Update only
    @storybook/addon-essentials^7.5.3Update only
    @storybook/addon-interactions^7.5.3Update only
    @storybook/addon-mdx-gfm^7.5.3Update only
    @storybook/addon-highlight^7.5.3Update only
    @storybook/addon-jest^7.5.3Update only
    @storybook/addon-links^7.5.3Update only
    @storybook/addon-measure^7.5.3Update only
    @storybook/addon-outline^7.5.3Update only
    @storybook/addon-storyshots^7.5.3Update only
    @storybook/addon-storyshots-puppeteer^7.5.3Update only
    @storybook/addon-storysource^7.5.3Update only
    @storybook/addon-toolbars^7.5.3Update only
    @storybook/addon-viewport^7.5.3Update only
  • 17.0.x

  • 17.0.0-package-updates

    Version: 17.0.0-rc.3

    Packages

    NameVersionAlways Add to package.json
    @storybook/test-runner^0.13.0Update only
    @storybook/core-server^7.5.1Update only
    @storybook/angular^7.5.1Update only
    @storybook/react^7.5.1Update only
    @storybook/react-vite^7.5.1Update only
    @storybook/react-webpack5^7.5.1Update only
    @storybook/web-components-vite^7.5.1Update only
    @storybook/web-components-webpack5^7.5.1Update only
    @storybook/addon-a11y^7.5.1Update only
    @storybook/addon-actions^7.5.1Update only
    @storybook/addon-backgrounds^7.5.1Update only
    @storybook/addon-controls^7.5.1Update only
    @storybook/addon-docs^7.5.1Update only
    @storybook/addon-essentials^7.5.1Update only
    @storybook/addon-interactions^7.5.1Update only
    @storybook/addon-mdx-gfm^7.5.1Update only
    @storybook/addon-highlight^7.5.1Update only
    @storybook/addon-jest^7.5.1Update only
    @storybook/addon-links^7.5.1Update only
    @storybook/addon-measure^7.5.1Update only
    @storybook/addon-outline^7.5.1Update only
    @storybook/addon-storyshots^7.5.1Update only
    @storybook/addon-storyshots-puppeteer^7.5.1Update only
    @storybook/addon-storysource^7.5.1Update only
    @storybook/addon-toolbars^7.5.1Update only
    @storybook/addon-viewport^7.5.1Update only