# Storybook Controls Addon [Storybook](https://storybook.js.org) Controls gives you a graphical UI to interact with a component's arguments dynamically, without needing to code. It creates an addon panel next to your component examples ("stories"), so you can edit them live. [Framework Support](https://storybook.js.org/docs/react/api/frameworks-feature-support) ![Screenshot](https://raw.githubusercontent.com/storybookjs/storybook/next/addons/controls/docs/media/addon-controls-hero.gif) ## Installation Controls 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: ```sh npm i -D @storybook/addon-controls ``` Then, add following content to [`.storybook/main.js`](https://storybook.js.org/docs/react/configure/overview#configure-your-storybook-project): ```js module.exports = { addons: ['@storybook/addon-controls'], }; ``` ## Usage The usage is documented in the [documentation](https://storybook.js.org/docs/react/essentials/controls). ## FAQs - [Storybook Controls Addon](#storybook-controls-addon) - [Installation](#installation) - [Usage](#usage) - [FAQs](#faqs) - [How will this replace addon-knobs?](#how-will-this-replace-addon-knobs) - [How do I migrate from addon-knobs?](#how-do-i-migrate-from-addon-knobs) - [My controls aren't being auto-generated. What should I do?](#my-controls-arent-being-auto-generated-what-should-i-do) - [How can I disable controls for certain fields on a particular story?](#how-can-i-disable-controls-for-certain-fields-on-a-particular-story) - [How do controls work with MDX?](#how-do-controls-work-with-mdx) ### How will this replace addon-knobs? Addon-knobs is one of Storybook's most popular addons with over 1M weekly downloads, so we know lots of users will be affected by this change. Knobs is also a mature addon, with various options that are not available in addon-controls. Therefore, rather than deprecating addon-knobs immediately, we will continue to release knobs with the Storybook core distribution until 7.0. This will give us time to improve Controls based on user feedback, and also give knobs users ample time to migrate. If you are somehow tied to knobs or prefer the knobs interface, we are happy to take on maintainers for the knobs project. If this interests you, hop on our [Discord](https://discord.gg/storybook). ### How do I migrate from addon-knobs? If you're already using [Storybook Knobs](https://github.com/storybookjs/storybook/tree/master/addons/knobs) you should consider migrating to Controls. You're probably using it for something that can be satisfied by one of the cases [described above](#writing-stories). Let's walk through two examples: migrating [knobs to auto-generated args](#knobs-to-custom-args) and [knobs to custom args](#knobs-to-custom-args).

Knobs to auto-generated args

First, let's consider a knobs version of a basic story that fills in the props for a component: ```jsx import { text } from '@storybook/addon-knobs'; import { Button } from './Button'; export const Basic = () =>