@nx/storybook:configuration
Add Storybook configuration to a UI library or an application.
Monorepo World: October 7, 2024Monorepo World: October 7, 2024Join us!
Add Storybook configuration to a UI library or an application.
This is a framework-agnostic generator for setting up Storybook configuration for a project.
1nx g @nx/storybook:configuration
2Nx 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.
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:
name of the project you want to generate the configuration for.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-viteinteractionTests). If you choose yes, 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.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.
1nx g @nx/storybook:configuration ui --uiFramework=@storybook/web-components-vite --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 configuration ...
2By default, Nx will search for configuration in the default collection provisioned in workspace.json.
You can specify the collection explicitly as follows:
1nx g @nx/storybook:configuration ...
2Show what will be generated without writing to disk:
1nx g configuration ... --dry-run
2Project for which to generate Storybook configuration.
@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-viteStorybook UI Framework to use.
trueConfigure your project with TypeScript. Generate main.ts and preview.ts files, instead of main.js and preview.js.
falseAdd a static-storybook to serve the static storybook built files.
trueSet up Storybook interaction tests.
falseGenerate JavaScript story files rather than TypeScript story files.
eslinteslint, noneThe tool to use for running lint checks.
falseSkip formatting files.
Run the cypress-configure generator.
Use interactionTests instead. This option will be removed in v20.
A directory where the Cypress project will be placed. Added at root by default.
Use interactionTests instead. This option will be removed in v20.
trueSplit the project configuration into <projectRoot>/project.json rather than including it inside workspace.json.
Nx only supports standaloneConfig
Join us live for exciting talks on developer tooling and monorepos! Catch the action on YouTube and join the conversation on Discord!