Security News
Weekly Downloads Now Available in npm Package Search Results
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.
react-storybook-addon-props-combinations
Advanced tools
Given possible values for each prop, renders your component with all combinations of prop values. Useful for finding edge cases or just seeing all component states at once.
Install it:
npm i -D react-storybook-addon-props-combinations
Then set the addon in your .storybook/config.js
:
import { configure } from '@storybook/react'
import { setDefaults } from 'react-storybook-addon-props-combinations'
setDefaults({
// overwrite global defaults here
})
configure(() => {
// ...
}, module)
import React from 'react';
import { storiesOf } from '@storybook/react';
import { action } from '@storybook/addon-actions';
import withPropsCombinations from 'react-storybook-addon-props-combinations'
import YourComponent from './somewhere'
storiesOf('Basics', module)
.add('Standard usage', withPropsCombinations(
// provide your component
YourComponent,
// and an object with the shape
// {propName: arrayOfPossiblevalues}
{
disabled: [false, true],
onClick: [action('clicked')],
children: ['hello world', <b>some elements</b>]
}
)
Are provided as 4th argument to addWithPropsCombinations
or set globally using setDefaults
showSource
default: true
Toggles rendering of sample source for each combination.
mustProvideAllProps
default: false
Ensures that possible values are provided for all props listed in propTypes.
CombinationRenderer
A component that renders a single props combination for your component. Receives Component
, props
and options
as props.
combinationsModifier
default: x => x
(identity function)
A function that takes an array of generated prop combinations, does something with it(adds new combinations, removes or modifies some of existing ones, etc), and returns that modified array. (See a list of included modifiers below)
(If you'd like to expand this list, PRs are welcome!)
withOneOfBool
Takes an array of property names and adds more combination with one of these props set to true.
For example, if we had [{ label: 'my button' }]
, withOneOfBool(['small', 'big'])
will add { label: 'my button', small: true }
and { label: 'my button', big: true }
.
See this story for a more detailed example.
FAQs
Props Combinations addon for React Storybook
We found that react-storybook-addon-props-combinations demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.
Security News
A Stanford study reveals 9.5% of engineers contribute almost nothing, costing tech $90B annually, with remote work fueling the rise of "ghost engineers."
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.