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)

## 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`
+