Storybook Info Addon
Storybook Info Addon will show additional information for your stories in Storybook.
Useful when you want to display usage or other types of documentation alongside your story.
This addon works with Storybook for:
Installation
Install the following npm module:
npm i -D @storybook/addon-info
Basic usage
Then wrap your story with the withInfo
, which is a function that takes either
documentation text or an options object:
import { withInfo } from '@storybook/addon-info';
storiesOf('Component', module)
.add('simple info',
withInfo(`
description or documentation about my component, supports markdown
~~~js
<Button>Click Here</Button>
~~~
`)(() =>
<Component>Click the "?" mark at top-right to view the info.</Component>
)
)
Usage with options
withInfo
can also take an options object in case you want to configure how
the info panel looks on a per-story basis:
import { withInfo } from '@storybook/addon-info';
storiesOf('Component', module)
.add('simple info',
withInfo({
styles: {
header: {
h1: {
color: 'red'
}
}
},
text: 'String or React Element with docs about my component',
})(() =>
<Component>Click the "?" mark at top-right to view the info.</Component>
)
)
The styles
prop can also accept a function. The default stylesheet is passed as argument:
import { withInfo } from '@storybook/addon-info';
storiesOf('Component', module)
.add('custom info styles using a function',
withInfo({
styles: stylesheet => ({
...stylesheet,
header: {
...stylesheet.header,
h1: {
...stylesheet.header.h1,
color: 'red'
}
}
})
})(() =>
<Component>Click the "?" mark at top-right to view the info.</Component>
)
)
Usage as decorator
It is possible to add infos by default to all components by using a global or story decorator. The drawback is you won't be able to display a distinct info message per story.
It is important to declare this decorator as the first decorator, otherwise it won't work well.
addDecorator((story, context) => withInfo('common info')(story)(context));
Global options
To configure default options for all usage of the info option, use setDefaults
in .storybook/config.js
:
import { setDefaults } from '@storybook/addon-info';
setDefaults({
header: false,
});
Options and Defaults
{
header: false,
inline: true,
source: true,
propTables: [],
propTablesExclude: [],
styles: {},
components: {},
maxPropsIntoLine: 1,
maxPropObjectKeys: 10,
maxPropArrayLength: 10,
maxPropStringLength: 100,
TableComponent: props => {},
}
Deprecated usage
There is also a deprecated API that is slated for removal in Storybook 4.0.
import { configure, setAddon } from '@storybook/react';
import infoAddon from '@storybook/addon-info';
setAddon(infoAddon);
configure(function () {
}, module);
Then create your stories with the .addWithInfo
API.
import React from 'react';
import { storiesOf } from '@storybook/react';
import Component from './Component';
storiesOf('Component')
.addWithInfo(
'simple usage',
`This is the basic usage with the button with providing a label to show the text.`,
() => (
<Component>Click the "?" mark at top-right to view the info.</Component>
),
);
Have a look at this example stories to learn more about the addWithInfo
API.
To customize your defaults:
import infoAddon, { setDefaults } from '@storybook/addon-info';
setDefaults({
inline: true,
maxPropsIntoLine: 1,
maxPropObjectKeys: 10,
maxPropArrayLength: 10,
maxPropStringLength: 100,
});
setAddon(infoAddon);
Rendering a Custom Table
The TableComponent
option allows you to define how the prop table should be rendered. Your component will be rendered with the following props.
{
propDefinitions: Array<{
property: string,
propType: Object | string,
required: boolean,
description: string,
defaultValue: any
}>
}
Example:
import React from 'react'
const paddingStyles = {
small: '4px 8px',
medium: '8px 16px'
}
const Button = ({
size,
...rest
}: {
/** The size of the button */
size: 'small' | 'medium'
}) => {
const style = {
padding: paddingStyles[size] || ''
}
return <button style={style} {...rest} />
}
Button.defaultProps = {
size: 'medium'
}
export default Button
import React from "react";
import { storiesOf } from "@storybook/react";
import { withInfo } from "@storybook/addon-info";
import Button from "./button";
const Red = props => <span style={{ color: "red" }} {...props} />;
const TableComponent = ({ propDefinitions }) => {
const props = propDefinitions.map(
({ property, propType, required, description, defaultValue }) => {
return (
<tr key={property}>
<td>
{property}
{required ? <Red>*</Red> : null}
</td>
<td>{propType.name}</td>
<td>{defaultValue}</td>
<td>{description}</td>
</tr>
);
}
);
return (
<table>
<thead>
<tr>
<th>name</th>
<th>type</th>
<th>default</th>
<th>description</th>
</tr>
</thead>
<tbody>{props}</tbody>
</table>
);
};
storiesOf("Button", module).add(
"with text",
withInfo({
TableComponent
})(() => <Button>Hello Button</Button>)
);
React Docgen Integration
React Docgen is included as part of the @storybook/react package through the use of babel-plugin-react-docgen
during babel compile time.
When rendering a story with a React component commented in this supported format, the Addon Info description will render the comments above the component declaration and the prop table will display the prop's comment in the description column.
import React from 'react';
import PropTypes from 'prop-types';
const DocgenButton = ({ disabled, label, style, onClick }) =>
<button disabled={disabled} style={style} onClick={onClick}>
{label}
</button>;
DocgenButton.defaultProps = {
disabled: false,
onClick: () => {},
style: {},
};
DocgenButton.propTypes = {
disabled: PropTypes.bool,
label: PropTypes.string.isRequired,
onClick: PropTypes.func,
style: PropTypes.shape,
};
export default DocgenButton;
Comments above flow types are also supported. Storybook Info Addon should now render all the correct types for your component if the PropTypes are in the same file as the React component.
The FAQ
Components lose their names on static build
Component names also get minified with other javascript code when building for production.
When creating components, set the displayName
static property to show the correct component name on static builds.