diff --git a/addons/actions/ADVANCED.md b/addons/actions/ADVANCED.md new file mode 100644 index 00000000000..7500b97c1e1 --- /dev/null +++ b/addons/actions/ADVANCED.md @@ -0,0 +1,83 @@ +## Advanced/Legacy Actions usage + +For basic usage, see the [documentation](https://storybook.js.org/docs/react/essentials/actions). + +This document describes the pre-6.0 usage of the addon, and as such is no longer recommended (although it will be supported until at least 7.0). + +## Manually-specified actions + +Import the `action` function and use it to create actions handlers. When creating action handlers, provide a **name** to make it easier to identify. + +> _Note: Make sure NOT to use reserved words as function names. [issues#29](https://github.com/storybookjs/storybook-addon-actions/issues/29#issuecomment-288274794)_ + +```js +import { action } from '@storybook/addon-actions'; +import Button from './button'; + +export default { + title: 'Button', + component: Button, +}; + +export const defaultView = () => ; +``` + +## Multiple actions + +If your story requires multiple actions, it may be convenient to use `actions` to create many at once: + +```js +import { actions } from '@storybook/addon-actions'; +import Button from './button'; + +export default { + title: 'Button', + component: Button, +}; + +// This will lead to { onClick: action('onClick'), ... } +const eventsFromNames = actions('onClick', 'onMouseOver'); + +// This will lead to { onClick: action('clicked'), ... } +const eventsFromObject = actions({ onClick: 'clicked', onMouseOver: 'hovered' }); + +export const first = () => ; + +export const second = () => ; +``` + +## Configuration + +Arguments which are passed to the action call will have to be serialized while be "transferred" over the channel. + +This is not very optimal and can cause lag when large objects are being logged, for this reason it is possible to configure a maximum depth. + +The action logger, by default, will log all actions fired during the lifetime of the story. After a while this can make the storybook laggy. As a workaround, you can configure an upper limit to how many actions should be logged. + +To apply the configuration globally use the `configureActions` function in your `preview.js` file. + +```js +import { configureActions } from '@storybook/addon-actions'; + +configureActions({ + depth: 100, + // Limit the number of items logged into the actions panel + limit: 20, +}); +``` + +To apply the configuration per action use: + +```js +action('my-action', { + depth: 5, +}); +``` + +### Available Options + +| Name | Type | Description | Default | +| -------------------- | ------- | ----------------------------------------------------------------------------------- | ------- | +| `depth` | Number | Configures the transferred depth of any logged objects. | `10` | +| `clearOnStoryChange` | Boolean | Flag whether to clear the action logger when switching away from the current story. | `true` | +| `limit` | Number | Limits the number of items logged in the action logger | `50` | diff --git a/addons/actions/README.md b/addons/actions/README.md index ea170685383..983a8241d77 100644 --- a/addons/actions/README.md +++ b/addons/actions/README.md @@ -2,19 +2,21 @@ Storybook Addon Actions can be used to display data received by event handlers in [Storybook](https://storybook.js.org). -[Framework Support](https://github.com/storybookjs/storybook/blob/master/ADDONS_SUPPORT.md) +[Framework Support](https://storybook.js.org/docs/react/api/frameworks-feature-support) ![Screenshot](https://raw.githubusercontent.com/storybookjs/storybook/HEAD/addons/actions/docs/screenshot.png) ## Getting Started +Actions is part of [essentials](https://storybook.js.org/docs/react/essentials/introduction) and so is installed in all new Storybooks by default. If you need to add it to your storybook, you can run: + Install: ```sh npm i -D @storybook/addon-actions ``` -Then, add following content to `.storybook/main.js` +Then, add following content to [`.storybook/main.js`](https://storybook.js.org/docs/react/configure/overview#Configure-your-Storybook-project) ```js module.exports = { @@ -22,132 +24,6 @@ module.exports = { }; ``` -## Actions args +## Usage -Starting in SB6.0, we recommend using story parameters to specify actions which get passed into your story as [Args](https://docs.google.com/document/d/1Mhp1UFRCKCsN8pjlfPdz8ZdisgjNXeMXpXvGoALjxYM/edit?usp=sharing) (passed as the first argument when `passArgsFirst` is set to `true`). - -The first option is to specify `argTypes` for your story with an `action` field. Take the following example: - -```js -import Button from './button'; - -export default { - title: 'Button', - argTypes: { onClick: { action: 'clicked' } }, -}; - -export const Basic = ({ onClick }) => ; -``` - -Alternatively, suppose you have a naming convention, like `onX` for event handlers. The following configuration automatically creates actions for each `onX` `argType` (which you can either specify manually or generate automatically using [Storybook Docs](https://www.npmjs.com/package/@storybook/addon-docs). - -```js -import Button from './button'; - -export default { - title: 'Button', - component: Button, - parameters: { actions: { argTypesRegex: '^on.*' } }, -}; - -export const Basic = ({ onClick }) => ; -``` - -> **NOTE:** If you're generating `argTypes` in using another addon (like Docs, which is the common behavior) you'll need to make sure that the actions addon loads **AFTER** the other addon. You can do this by listing it later in the `addons` registration code in `.storybook/main.js`. - -## Manually-specified actions - -Import the `action` function and use it to create actions handlers. When creating action handlers, provide a **name** to make it easier to identify. - -> _Note: Make sure NOT to use reserved words as function names. [issues#29](https://github.com/storybookjs/storybook-addon-actions/issues/29#issuecomment-288274794)_ - -```js -import { action } from '@storybook/addon-actions'; -import Button from './button'; - -export default { - title: 'Button', - component: Button, -}; - -export const defaultView = () => ; -``` - -## Multiple actions - -If your story requires multiple actions, it may be convenient to use `actions` to create many at once: - -```js -import { actions } from '@storybook/addon-actions'; -import Button from './button'; - -export default { - title: 'Button', - component: Button, -}; - -// This will lead to { onClick: action('onClick'), ... } -const eventsFromNames = actions('onClick', 'onMouseOver'); - -// This will lead to { onClick: action('clicked'), ... } -const eventsFromObject = actions({ onClick: 'clicked', onMouseOver: 'hovered' }); - -export const first = () => ; - -export const second = () => ; -``` - -## Configuration - -Arguments which are passed to the action call will have to be serialized while be "transferred" over the channel. - -This is not very optimal and can cause lag when large objects are being logged, for this reason it is possible to configure a maximum depth. - -The action logger, by default, will log all actions fired during the lifetime of the story. After a while this can make the storybook laggy. As a workaround, you can configure an upper limit to how many actions should be logged. - -To apply the configuration globally use the `configureActions` function in your `preview.js` file. - -```js -import { configureActions } from '@storybook/addon-actions'; - -configureActions({ - depth: 100, - // Limit the number of items logged into the actions panel - limit: 20, -}); -``` - -To apply the configuration per action use: - -```js -action('my-action', { - depth: 5, -}); -``` - -### Available Options - -| Name | Type | Description | Default | -| -------------------- | ------- | ----------------------------------------------------------------------------------- | ------- | -| `depth` | Number | Configures the transferred depth of any logged objects. | `10` | -| `clearOnStoryChange` | Boolean | Flag whether to clear the action logger when switching away from the current story. | `true` | -| `limit` | Number | Limits the number of items logged in the action logger | `50` | - -## Declarative Configuration via Parameters - -You can define action handles in a declarative way using parameters. They accepts the same arguments as [`actions`](#multiple-actions) -Keys have `' '` format, e.g. `'click .btn'`. Selector is optional. This can be used with any framework but is especially useful for `@storybook/html`. - -```js -import Button from './button'; - -export default { - title: 'Button', - parameters: { - actions: { - handles: ['mouseover', 'click .btn'] - } -}; - -export const first = () => ; -``` +The basic usage is documented in the [documentation](https://storybook.js.org/docs/react/essentials/actions). For legacy usage, see the [advanced README](./ADVANCED.md). diff --git a/docs/essentials/actions.md b/docs/essentials/actions.md index 9d441ca2a93..539781e779e 100644 --- a/docs/essentials/actions.md +++ b/docs/essentials/actions.md @@ -53,10 +53,9 @@ NOTE: If you're generating argTypes in using another addon (like [docs](../writi - ### Action event handlers -It is also possible to detect if your component is emitting the correct HTML events using the `parameters.actions.handles` [parameter](../writing-stories/parameters.md). +It is also possible to detect if your component is emitting the correct HTML events using the `parameters.actions.handles` [parameter](../writing-stories/parameters.md). @@ -72,4 +71,4 @@ This will bind a standard HTML event handler to the outermost HTML element rende ### Advanced / legacy usage -There are also some older ways to use actions as documented in the [advanced README](../addons/actions/ADVANCED-README.md). +There are also some older ways to use actions as documented in the [advanced README](../../addons/actions/ADVANCED.md). diff --git a/docs/essentials/introduction.md b/docs/essentials/introduction.md index 6bbf1eb6251..7254bc4d837 100644 --- a/docs/essentials/introduction.md +++ b/docs/essentials/introduction.md @@ -34,4 +34,6 @@ As an example, if the background addon wasn't necessary to your work, you would -You can use the following keys for each individual addon: `actions`, `backgrounds`, `controls`, `docs`, `viewport` +
+ You can use the following keys for each individual addon: `actions`, `backgrounds`, `controls`, `docs`, `viewport`. +