@nx/angular:storybook-configuration
Adds Storybook configuration to a project to be able to use and create stories.
Monorepo World: October 7, 2024Monorepo World: October 7, 2024Join us!
Adds Storybook configuration to a project to be able to use and create stories.
This generator will set up Storybook for your Angular project. By default, starting Nx 16, Storybook v7 is used.
1nx g @nx/angular:storybook-configuration project-name
2You can read more about how this generator works, in the Storybook for Angular overview page.
When running this generator, you will be prompted to provide the following:
name of the project you want to generate the configuration for.interactionTests). If you choose yes, a play function will be added to your stories, and all the necessary dependencies will be installed. Also, a test-storybook target will be generated in your project's project.json, with a command to invoke the Storybook test-runner. You can read more about this in the Nx Storybook interaction tests documentation page.generateStories for the components in your project. If you choose yes, a .stories.ts file will be generated next to each of your components in your project.You must provide a name for the generator to work.
By default, this generator will also set up Storybook interaction tests. If you don't want to set up Storybook interaction tests, you can pass the --interactionTests=false option, but it's not recommended.
There are a number of other options available. Let's take a look at some examples.
1nx g @nx/angular:storybook-configuration ui
2This will generate Storybook configuration for the ui project using TypeScript for the Storybook configuration files (the files inside the .storybook directory, eg. .storybook/main.ts).
1nx g @nx/angular:storybook-configuration ui --generateStories=true --ignorePaths=libs/ui/src/not-stories/**,**/**/src/**/*.other.*,apps/my-app/**/*.something.ts
2This will generate a Storybook configuration for the ui project and generate stories for all components in the libs/ui/src/lib directory, except for the ones in the libs/ui/src/not-stories directory, and the ones in the apps/my-app directory that end with .something.ts, and also for components that their file name is of the pattern *.other.*.
This is useful if you have a project that contains components that are not meant to be used in isolation, but rather as part of a larger component.
By default, Nx will ignore the following paths:
1*.stories.ts, *.stories.tsx, *.stories.js, *.stories.jsx, *.stories.mdx
2but you can change this behaviour easily, as explained above.
1nx g @nx/angular:storybook-configuration ui --tsConfiguration=false
2By 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).
1nx generate storybook-configuration ...
2By default, Nx will search for storybook-configuration in the default collection provisioned in workspace.json.
You can specify the collection explicitly as follows:
1nx g @nx/angular:storybook-configuration ...
2Show what will be generated without writing to disk:
1nx g storybook-configuration ... --dry-run
2Project for which to generate Storybook configuration.
trueSpecifies whether to configure a static file server target for serving storybook. Helpful for speeding up CI build/test times.
trueSpecifies whether to automatically generate *.stories.ts files for components declared in this project or not.
trueSet up Storybook interaction tests.
trueConfigure your project with TypeScript. Generate main.ts and preview.ts files, instead of main.js and preview.js.
[*.stories.ts,*.stories.tsx,*.stories.js,*.stories.jsx,*.stories.mdx]Paths to ignore when looking for components.
eslinteslint, noneThe tool to use for running lint checks.
falseSkip formatting files.
Specifies whether to configure Cypress or not.
Use interactionTests instead. This option will be removed in v20.
A directory where the Cypress project will be placed. Placed at the root by default.
Use interactionTests instead. This option will be removed in v20.
Specifies whether to automatically generate test files in the generated Cypress e2e app.
Use interactionTests instead. This option will be removed in v20.
Join us live for exciting talks on developer tooling and monorepos! Catch the action on YouTube and join the conversation on Discord!