3 - [React component stories](#react-component-stories)
4 - [React component props](#react-component-props)
5 - [Storybook Canvas block](#storybook-canvas-block)
7 ## React component stories
9 The main way we intend to convey documentation about React Components in this Storybook is via Storybook's [MDX Docs Support](https://storybook.js.org/docs/react/writing-docs/mdx).
11 For that we employ the pattern of writing a couple of stories in a `Component.stories.tsx` file and linking them to an mdx documentation page through the `<Story />` Storybook Block by referencing the story's id like so:
14 import { Canvas, Story } from '@storybook/addon-docs/blocks';
16 <Story id="story-id" />;
19 The name you call your mdx file does not matter as it has to be linked manually to the respective component stories file like so (however `Component.mdx` seems like a convenient pattern for mdx pages that are directly linked to a stories file of the same component):
22 import mdx from './Component.mdx';
23 import Component from './Component.tsx';
36 The easiest way to find a story-id is by going to a running storybook instance and checking the url when on a story in the canvas:
38 <img src="./src/assets/storybook-story-id.png" width="400" alt="" />
40 However the story-id is computed from your story's title and its name, soit is also possible to predict it.
42 This pattern is documented in the following storybook 'recipe': [CSF Stories with arbitrary MDX](https://github.com/storybookjs/storybook/blob/next/addons/docs/docs/recipes.md#csf-stories-with-arbitrary-mdx)
44 ## React component props
46 To show the arguments (props) for a certain component in the documentation page use the ArgsTable Storybook Block
49 import { Alert } from 'react-components';
51 import { ArgsTable } from '@storybook/addon-docs/blocks';
53 <ArgsTable of={Alert} />;
56 <img src="./src/assets/storybook-argstable.png" alt="" />
58 Note: If you comment your props this way in your component in `react-components`:
61 interface Props extends React.HTMLProps<HTMLSpanElement> {
64 * Here is a super useful comment.
66 charsToDisplayEnd?: number;
69 This comment will be present in StoryBook:
71 <img src="./src/assets/storybook-props-comments.png" alt="Comment available" />
73 There have been issues with typescript-docgen not being able to correctly extract the args/props for the ArgsTable. The following scenarios cause problems with that.
75 Importing a component under a different name than it was exported as
79 import Baz from './foo';
85 Exporting the component as an anonymous value, for example when wrapped in higher order functions and directly exported.
92 export default forwardRef(A);
95 One option to deal with this is to wrap the component definition itself so that the wrapped component is named by a variable.
98 const A = forwardRef(() => {
105 ## Storybook Canvas block
107 Usually you'll see a `<Story />` wrapped inside the `<Canvas />` Storybook Block. This is done to show the source code alongside the inline story:
110 import { Canvas, Story } from '@storybook/addon-docs/blocks';
113 <Story id="story-id" />
117 <img src="./src/assets/storybook-canvas-block.png" alt="" />