Learn Storybook teaches you how to use Storybook and Component-Driven Development to build UIs from scratch. We walk through core concepts from building and testing to deployment. Using engaging guides and content, we hope to get you up to speed on Storybook best practices in a fast and approachable way.
Contributions to Learn Storybook are encouraged! If it’s something small like grammar, punctuation or even a code snippet, first check the open pull requests to see if it's already being addressed, if it's not, then open up a pull request. If it’s a bigger change like adding a new guide or chapter, add an issue for discussion before getting started.
You'll find the guides and chapters in the /content
directory. Content is organized at the guide level. Within the /content
directory, you'll find directories for the current guides that are offered. Within each guide directory, you can see the chapters that make up that guide.
We love translations of our guides to new languages. That helps the Storybook community learn in the language they're most comfortable with. Find out more »
Traditional Chinese translation is converted from Simplified Chinese using OpenCC. Please help us correct any idiomatic errors.
The text, code, and production were contributed by Chroma. The tutorial was inspired by Chroma’s popular GraphQL + React tutorial series
Install packages and run with yarn dev
.
- Tom Coleman @tmeasday
- Dominic Nguyen @domyen
- Carlos Iván Suarez @icarlossz
- Luciano M. Guasco @luchux
- yobrave
- Daniel Duan
- Carlos Vega
- Matt Rothenberg
- Kyle Holmberg
- You? Become an OSS contributor
Thanks for taking the time to contribute and add content to Learn Storybook! The tutorials below reference file paths which will be represented in this format:
/content/:guide/:framework?/:language/:chapter.md
Path parts that are prefixed with a colon (:
) are meant to be dynamic names that are chosen by you. :guide
becomes intro-to-storybook
or whatever you decide to use for your content. If a path part is followed by a question mark (?
), then it is optional.
-
Within the
/content
directory, add a directory for your new guide:/content/:guide
. The name you choose for the directory will be used as the slug for the directory when you access it in a browser. -
Add a new file,
index.md
, to your newly created directory:/content/:guide/index.md
. This file will contain the content and metadata for your guide that will be used to populate the site. Usingintro-to-storybook
'sindex.md
as an example, populate the following required frontmatter fields with meaningful content about your guide:
---
title:
heroDescription:
description:
overview:
themeColor:
---
-
See the guide frontmatter section for additional customization options, many of which you'll want to use in order to create a guide that feels complete.
-
Populate the guide content in markdown underneath the frontmatter. This content shows up on the guide page after the table of contents. You can insert images, call out frameworks, or provide details about the project contained within the guide.
-
Visit your guide at
http://localhost:8000/:guide
If you are translating a chapter that already exists in a different language, skip to step 2.
If you are writing a new chapter for a language that already exists, skip to step 3.
-
Decide if your guide should be organized by framework. Will the examples and messaging be specific to the reader's framework of choice? If so, add an additional directory for the framework:
/content/:guide/:framework
. If not, carry on to the next step -- you will put your translation directories and chapters inside the/content/:guide
directory. -
Add a directory for the language that you will use to write your chapter. The naming of this language directory is important and should mirror what has been used in other guides for similar translations. Additionally, a helper is used across the app to transform the language into a human readable name, so make sure to update that helper if you are adding a language which has not yet been used. Know of a better way to convert this language into something more readable? Start an issue and let us know your idea.
-
Add a new file for the chapter that you are going to write:
/content/:guide/:framework?/:language/:chapter.md
- Update the guide's
toc
frontmatter. Each time you add a new chapter, make sure to go back and update the guide'stoc
in order to populate the Table of Contents as well as control the order of the chapters. Using the name of the file that you just created in step 3, go back to the guide frontmatter and update thetoc
:
toc: [":chapter"]
-
Populate the chapter frontmatter.
-
Populate the chapter content in markdown underneath the frontmatter.
-
Visit your chapter at
http://localhost:8000/:guide/:chapter
or by going tohttp://localhost:8000/:guide/
and subsequently navigating to your chapter from the Table of Contents.
Required
The primary name for your guide. What is it called?
A relatively short description of the guide. Used primarily in the primary navigation tooltip menu.
A message about the guide that will live prominently on the guide page. Why is this guide important? What is the context around the guide that helps reinforce the importance of moving forward to read the guide?
A section on the guide page discussing the things you will learn in the guide.
A named color, hex, rgba value, etc. Basically anything you can use in the color
css property.
A list and the corresponding order of the chapters in the guide. Short for "Table of Contents". List items should map to the file name of the chapter.
Suggested
The URL to the repository that has the code examples for your guide. Used in combination with the commit
frontmatter in the chapter to link chapters to their corresponding code examples .
The primary image for the guide. Used on the guide page.
A thumbnail representation of the cover image. Used in smaller places such as the guide list on the index page.
A string representation of the amount of contributors to this guide. Since the Github API only shows contributors to the repo as a whole rather than specific directories, we do this manually for now. Know of a better way? Start an issue and let us know your idea.
A list of authors of the guide. Format:
authors:
[
{
src: "",
name: "",
detail: "",
},
]
A list of contributors to the guide. Format:
contributors:
[
{
src: "",
name: "",
detail: "",
},
]
An animation to use on the guide's hero image which corresponds with a named export from the animation styles file. The export must contain the entire CSS property and value for the animation.
The text content for the tweet that is auto-populated when people choose to share the guide on Twitter. The URL that is included in the tweet is auto-generated based on the guide, but the individual guide can control the messaging before the link.
Required
The primary name for the chapter. What is it called?
Specify a different title to only be used for the Table of Contents sections.
A brief description of the chapter. Shown underneath the chapter title on the chapter page as well as in the Table of Contents on the guide page.
Suggested
The short commit hash that maps to the commit on the code example repo for this chapter.