storybook/docs/configure/sidebar-and-urls.md
2021-11-06 03:20:29 +00:00

2.9 KiB
Raw Blame History

title
Sidebar & URLS

Storybooks sidebar lists all your stories grouped by component. When you have many components, you may also wish to group those components. To do so, you can add the / separator to the title of your CSF file and Storybook will group the stories into groups based on common prefixes:

Storybook sidebar anatomy

We recommend using a nesting scheme that mirrors the filesystem path of the components. For example, if you have a file components/modals/Alert.js name the CSF file components/modals/Alert.stories.js and title it Components/Modals/Alert.

Roots

By default, Storybook will treat your top-level nodes as “roots”. Roots are displayed in the UI as “sections” of the hierarchy. Lower level groups will show up as folders:

Storybook sidebar story roots

If youd prefer to show top-level nodes as folders rather than roots, you can set the sidebar.showRoots option to false in ./storybook/manager.js:

<CodeSnippets paths={[ 'common/storybook-manager-disable-roots.js.mdx', ]} />

Generating titles based on __dirname

As a CSF file is a JavaScript file, all exports (including the default export) can be generated dynamically. In particular you can use the __dirname variable to create the title based on the path name (this example uses the paths.macro):

<CodeSnippets paths={[ 'common/component-story-dynamic-title.js.mdx', ]} />

If you need, you can also generate automatic titles for all your stories using a configuration object. See the story loading documentation to learn how you can use this feature.

Permalinking to stories

By default, Storybook generates an id for each story based on the component title and the story name. This id in particular is used in the URL for each story, and that URL can serve as a permalink (primarily when you publish your Storybook).

Consider the following story:

<CodeSnippets paths={[ 'common/foo-bar-baz-story.js.mdx', ]} />

Storybook's ID-generation logic will give this the id foo-bar--baz, so the link would be ?path=/story/foo-bar--baz.

It is possible to manually set the id of a story, which is helpful if you want to rename stories without breaking permalinks. Suppose you want to change the position in the hierarchy to OtherFoo/Bar and the story name to Moo. Here's how to do that:

<CodeSnippets paths={[ 'common/other-foo-bar-story.js.mdx', ]} />

Storybook will prioritize the id over the title for ID generation if provided and prioritize the story.name over the export key for display.