Thanks for your interest in improving Storybook! We are a community-driven project and welcome contributions of all kinds: from discussion to documentation to bugfixes to feature improvements.
Please review this document to help to streamline the process and save everyone's precious time.
This repo uses yarn workspaces, so you should install yarn
as the package manager. See installation guide.
No software is bug-free. So, if you got an issue, follow these steps:
- Search the issue list for current and old issues.
- If you find an existing issue, please UPVOTE the issue by adding a "thumbs-up reaction". We use this to help prioritize issues!
- If none of that is helping, create an issue with the following information:
- Clear title (shorter is better).
- Describe the issue in clear language.
- Share error logs, screenshots and etc.
- To speed up the issue fixing process, send us a sample repo with the issue you faced:
To test your project against the current latest version of storybook, you can clone the repository and link it with yarn
. Try following these steps:
git clone https://github.com/storybookjs/storybook.git
cd storybook
yarn bootstrap
Note: On Windows, you may need to run
yarn
beforeyarn bootstrap
!
The bootstrap command might ask which sections of the codebase you want to bootstrap. Unless you're doing something special you can keep the default.
You can also pick directly from CLI:
yarn bootstrap --core
You can use one of the example projects in examples/
to develop on.
This command will list all the suites and options for running tests.
yarn test
The options for running tests can be selected from the cli or be passed to yarn test
with specific parameters. Available modes include --watch
, --coverage
, and --runInBand
, which will respectively run tests in watch mode, output code coverage, and run selected test suites serially in the current process.
You can use the --update
flag (or jest -u
) to update snapshots or screenshots as needed.
Note: On Windows, remember to make sure git config
core.autocrlf
is set to false, in order to not override EOL in snapshots (git config --global core.autocrlf false
to set it globally). It is also recommended to run tests from WSL2 to avoid errors with unix-style paths.
You can also pick suites from CLI. Suites available are listed below.
yarn test
This option executes tests from <rootdir>/app/react
, <rootdir>/app/vue
, and <rootdir>/lib
.
Before the tests are run, the project must be bootstrapped with core. You can accomplish this with yarn bootstrap --core
We use eslint as a linter for all code (including typescript code).
All you have to run is:
yarn lint
It can be immensely helpful to get feedback in your editor, if you're using VsCode, you should install the eslint
plugin and configure it with these settings:
{
"editor.codeActionsOnSave": {
"source.fixAll.eslint": true
},
"eslint.packageManager": "yarn",
"eslint.options": {
"cache": true,
"cacheLocation": ".cache/eslint",
"extensions": [".js", ".jsx", ".json", ".html", ".ts", ".tsx", ".mjs"]
},
"eslint.alwaysShowStatus": true
}
This should enable auto-fix for all source files, and give linting warnings and errors within your editor.
The best way to help figure out an issue you are having is to produce a minimal reproduction against the main
branch.
A good way to do that is using the example official-storybook
app embedded in this repository:
# Download and build this repository:
git clone https://github.com/storybookjs/storybook.git
cd storybook
yarn
yarn bootstrap --core
# make changes to try and reproduce the problem, such as adding components + stories
cd examples/official-storybook
yarn storybook
# see if you can see the problem, if so, commit it:
git checkout "branch-describing-issue"
git add -A
git commit -m "reproduction for issue #123"
# fork the storybook repo to your account, then add the resulting remote
git remote add <your-username> https://github.com/<your-username>/storybook.git
git push -u <your-username> next
If you follow that process, you can then link to the GitHub repository in the issue. See #708 (comment) for an example.
Note: If your issue involves a webpack config, create-react-app will prevent you from modifying the app's webpack config, however, you can still modify storybook's to mirror your app's version of the storybook. Alternatively, use yarn eject
in the CRA app to get a modifiable webpack config.
Sometimes your storybook is deeply ingrained in your own setup and it's hard to create a minimal viable reproduction somewhere else.
Inside the storybook repo we have a script that allows you to test the packages inside this repo in your own separate project.
You can use npm link
on all packages, but npm linking is cumbersome and has subtle differences from what happens in a registry-based installation.
So the way our script works is that it:
- sets up a npm registry running on your own local machine
- changes your default registry to this local one
- builds all packages in the storybook repo
- publishes all packages as latest
Our script leaves the local registry running, for as long as you keep it running you can install storybook packages from this local registry.
- Navigate to your own project and then change
package.json
so the storybook packages match the version of the one you just published. - Then you can install using
yarn
ornpm
- Start using your storybook as normally.
If you've made a change to storybook's codebase and would want this change to be reflected in your app:
- Ensure the storybook packages are transpiled, by either having run
yarn dev
oryarn bootstrap --core
. - Go to the terminal where the local registry is running and press
<Enter>
. This will kick off a new publish. - Run the install procedure again in your local repo, (you may need to clean out node_modules first).
- Restart your storybook.
Before any contributions are submitted in a PR, make sure to add or update meaningful tests. A PR that has failing tests will be regarded as a “Work in Progress” and will not be merged until all tests pass.
When creating new unit test files, the tests should adhere to a particular folder structure and naming convention, as defined below.
# Proper naming convention and structure for js tests files
+-- parentFolder
| +-- [filename].js
| +-- [filename].test.js
We welcome all contributions. There are many ways you can help us. This is few of those ways:
Before you submit a new PR, make sure you run yarn test
. Do not submit a PR if tests are failing. If you need any help, the best way is to join the discord server and ask in the maintenance channel.
As a PR submitter, you should reference the issue if there is one, include a short description of what you contributed and, if it is a code change, instructions for how to manually test out the change. This is informally enforced by our PR template. If your PR is reviewed as only needing trivial changes (e.g. small typos etc), and you have commit access then you can merge the PR after making those changes.
Note: Although the latest stable version of storybook corresponds to the
main
branch, nearly all Storybook development happens in thenext
branch. If you submit a PR, branch offnext
and target your PR tonext
.
As a PR reviewer, you should read through the changes and comment on any potential problems. If you see something cool, a kind word never hurts either! Additionally, you should follow the testing instructions and manually test the changes. If the instructions are missing, unclear, or overly complex, feel free to request better instructions from the submitter. Unless the PR is tagged with the do not merge
label, if you approve the review and there is no other required discussion or changes, you should also go ahead and merge the PR.
If you are looking for a way to help the project, triaging issues is a great place to start. Here's how you can help:
Issues that are tagged question / support
or needs reproduction
are great places to help. If you can answer a question, it will help the asker as well as anyone who has a similar question. Also in the future if anyone has that same question they can easily find it by searching. If an issue needs reproduction, you may be able to guide the reporter toward one, or even reproduce it yourself using this technique.
Once you've helped out on a few issues, if you'd like triage access you can help label issues and respond to reporters.
We use the following label scheme to categorize issues:
- type -
bug
,feature
,question / support
,discussion
,dependencies
,maintenance
. - area -
addon: x
,addons-api
,stories-api
,ui
, etc. - status -
needs reproduction
,needs PR
,in progress
, etc.
All issues should have a type
label. bug
/feature
/question
/discussion
are self-explanatory. dependencies
is for keeping package dependencies up to date. maintenance
is a catch-all for any kind of cleanup or refactoring.
They should also have one or more area
/status
labels. We use these labels to filter issues down so we can see all of the issues for a particular area, and keep the total number of open issues under control.
For example, here is the list of open, untyped issues, or here is a list of bugs that have not been modified since 2017-04-01. For more info see searching issues in the GitHub docs.
If an issue is a bug
, and it doesn't have a clear reproduction that you have personally confirmed, label it needs reproduction
and ask the author to try and create a reproduction, or have a go yourself.
- Duplicate issues should be closed with a link to the original.
- Unreproducible issues should be closed if it's not possible to reproduce them (if the reporter drops offline, it is reasonable to wait 2 weeks before closing).
bug
s should be labelledmerged
when merged, and be closed when the issue is fixed and released.feature
s,maintenance
s,greenkeeper
s should be labelledmerged
when merged, and closed when released or if the feature is deemed not appropriate.question / support
s should be closed when the question has been answered. If the questioner drops offline, a reasonable period to wait is two weeks.discussion
s should be closed at a maintainer's discretion.
Please have the latest stable versions of the following on your machine
- node
- yarn
If you run into trouble here, make sure your node, npm, and yarn are on the latest versions (yarn at least v1.3.2).
cd ~
(optional)git clone https://github.com/storybookjs/storybook.git
bonus: use your own fork for this stepcd storybook
yarn bootstrap --core
Note: On Windows, you may need to run
yarn
beforeyarn bootstrap
(between steps 3 and 4).
This builds the entire project statically, but when you're updating Storybook code it's nice to see those changes show up in the example apps under examples
. There are two ways to do this:
yarn dev
- OR
yarn build <package1> <package2> --watch
The former watches ALL packages, which is extremely slow. The latter only watches a fixed list of packages, e.g. yarn build add-docs components --watch
to build @storybook/addon-docs
and @storybook/components
. This is much more practical on slower machines or if you know ahead of time the packages you'll be updating.
This method is slow
yarn bootstrap --all
- Take a break 🍵
yarn test
(to verify everything worked)
If you're working on one or several packages, for every change that you make, you have to rebuild those packages. To make the process easier, there is a CLI command for that:
- Run
yarn build
to bring you a list of packages to select from. There will be also an option to run in watch mode. - Run
yarn build <package-name>
to build that package specifically.
For the package name, use its short version. Example: for@storybook/addon-docs
, runyarn build addon-docs
. - Run
yarn build --all
to build everything. - Add
--watch
to run automatically in watch mode if you are either building a selection of packages by name or building all. Example:yarn build core addon-docs --watch
oryarn build --all --watch
.
Within the examples
folder of the Storybook repo, you will find kitchen sink examples of storybook implementations for the various platforms that storybook supports.
Not only do these show many of the options and add-ons available, they are also automatically linked to all the development packages. We highly encourage you to use these to develop/test contributions on.
cd examples/official-storybook
yarn storybook
- Verify that your local version works
Storybook is broken up into sub-projects that you can install as you need them. For this example, we will be working with @storybook/react
.
Note: You need to yarn link
from inside the subproject you are working on NOT the storybook root directory.
cd app/react
yarn link
Note: If you aren't seeing addons after linking storybook, you probably have a versioning issue which can be fixed by linking each addon you want to use. This applies for the kitchen sink apps as well as your own projects.
Make sure yarn dev
is running
First we are going to install storybook, then we are going to link @storybook/react
into our project. This will replace node_modules/@storybook/react
with a symlink to our local version of storybook.
getstorybook
yarn storybook
- Verify that your local version works
Note: This process is the same for @storybook/vue
, @storybook/addon-foo
, etc
- Go to your storybook root directory
yarn dev
- Wait until the output stops (changes you make will be transpiled into dist and logged here)
- Go to your storybook-sandbox-app directory
yarn link @storybook/react
yarn storybook
You should now have a working storybook dev environment up and running.
Save and go to http://localhost:9011
(or wherever storybook is running).
If you don't see the changes rerun yarn storybook
again in your sandbox app.
The documentation for Storybook is served by the frontpage, but the docs files are in this repository.
To see changes in a development version of the docs, use the "linking" method documented here.
This section is for Storybook maintainers who will be creating releases. It assumes:
- yarn >= 1.3.2
- you've yarn linked
pr-log
from storybookjs/pr-log#2
The current manual release sequence is as follows:
- Generate a changelog and verify the release by hand
- Push the changelog to main or the release branch
- Clean, build and publish the release
- Cut and paste the changelog to the GitHub release page, and mark it as a (pre-) release
Note: The very first time you publish a scoped package (@storybook/x
) you need to make sure that its package.json contains the following
"publishConfig": {
"access": "public"
}
This sequence applies to both releases and pre-releases, but differs slightly between the two.
Note: This is a work in progress. Don't try this unless you know what you're doing. We hope to automate this in CI, so this process is designed with that in mind.
# make sure you current with origin/next.
git checkout next
git status
# generate changelog and edit as appropriate
# generates a Next section
yarn changelog:next x.y.z-alpha.a
# Edit the changelog/PRs as needed, then commit
git commit -m "x.y.z-alpha.a changelog"
# clean build
yarn bootstrap --reset --core
# publish and tag the release
yarn run publish:next
# update the release page
open https://github.com/storybookjs/storybook/releases
# make sure you current with origin/main.
git checkout main
git status
# generate changelog and edit as appropriate
# generates a vNext section
yarn changelog x.y.z
# Edit the changelog/PRs as needed, then commit
git commit -m "x.y.z changelog"
# clean build
yarn bootstrap --reset --core
# publish and tag the release
yarn run publish:latest
# update the release page
open https://github.com/storybookjs/storybook/releases