--- title: 'Canvas' --- Storybook's `Canvas` Doc Block is a wrapper featuring a toolbar that allows you to interact with its content while automatically providing the required [Source](./doc-block-source.md) snippets. ![Docs block with a story preview](./docblock-preview.png) ## Working with the DocsPage Storybook's [DocsPage](./docs-page.md) wraps each story inside a `Canvas` Doc Block. The first story rendered in the DocsPage is automatically configured with a toolbar and set as _primary_. All other existing stories will not feature the toolbar. It also includes a [Source](./doc-block-source.md) Doc Block to visualize the story code snippet. ## Working with MDX The `Canvas` Doc Block includes additional customization options if you're writing MDX stories. Below is a condensed example and table featuring all the available options. | Option | Description | | ------------- | ------------------------------------------------------------------------------------------------ | | `columns` | Splits the stories based on the number of defined columns.
`` | | `isColumn` | Displays the stories one above the other.
`` | | `withSource` | Controls the source code block visibility.
`Canvas withSource="open">` | | `withToolbar` | Sets the `Canvas` toolbar visibility.
`` | ### Rendering multiple stories If you want, you can also group multiple stories and render them inside a single `Canvas` Doc Block. For example: ### Non-story content Additionally, you can also place non-story related content inside `Canvas` Doc Block allowing you to render the JSX content precisely as it would if you placed it inside an MDX file, for example: When rendered, Storybook will automatically generate the code snippet for this inside the [Source](./doc-block-source.md) block beneath the block.