paint-brush
Using Storybook's Doc Blocks for Design System Documentation: A Quick Guideby@chantastic
911 reads
911 reads

Using Storybook's Doc Blocks for Design System Documentation: A Quick Guide

by chantasticAugust 9th, 2023
Read on Terminal Reader
Read this story w/o Javascript
tldt arrow

Too Long; Didn't Read

**TL;DR Summary: Doc blocks for design system documentation** 🎛️ **Display design systems with three components from "@storybook/blocks"** 1. 🎨 **`ColorPalette` for color systems**: 2. 🖋️ **`Typeset` for typography sets**: 3. 🔍 **`IconGallery` for icons**: 4. 📚 **Additional Resources**: - [Storybook docs page](https://storybook.js.org/docs/) - [Chromatic YouTube channel](https://www.youtube.com/@chromaticui).
featured image - Using Storybook's Doc Blocks for Design System Documentation: A Quick Guide
chantastic HackerNoon profile picture

If you document design systems, I'm about to save you a ton of time because Storybook comes with lesser-known components for organizing colors, typography, and icons.


ColorPalette

Display color systems with the ColorPalette component.


Storybook component library showing sample color-system documentation.


Import "@storybook/blocks". Then render a ColorPalette with a single ColorItem inside.

// system/colors.mdx
import { ColorPalette, ColorItem } from "@storybook/blocks"

<ColorPalette>
  <ColorItem />
</ColorPalette>

Create an object with a key and color value. And pass it to the ColorItem component via the color prop.


Both key and value are displayed in the UI.

<ColorItem colors={{ Apple: "#66bf3c" }} />

Describe ColorItems with title and subtitle props.

<ColorItem
+  title="Apple"
+  subtitle="A delicious brand color."
  colors={{ Apple: "#66bf3c" }}
/>

Add as many colors to the colors prop as needed.

<ColorItem
  title="Apple"
  subtitle="A delicious brand color."
  colors={{
    Apple: "#66bf3c",
+    AppleDark: "#46991f",
+    AppleLight: "#83da5a"
  }}
/>

Use any CSS-supported color value.


ColorItem adds gray cross-hatches to indicate translucency — where color functions with non-1 alpha values are used.

<ColorItem
  title="Apple"
  subtitle="A delicious brand color."
  colors={{
+    Apple: "rgba(102,191,60,1)",
+    Apple60: "rgba(102,191,60,.6)",
+    Apple30: "rgba(102,191,60,.3)",
  }}
/>

See full ColorPalette API reference.


Typeset

Display typography systems with the Typeset component.


Storybook component library showing sample typography documentation.


Import the Typeset component from @storybook/blocks.

// system/typography.mdx
import { Typeset } from "@storybook/blocks";

<Typeset {/* required props */} />


Typeset requires four props to render: fontSizesfontWeightsampleText, and fontFamily.


fontSizes and fontWeight support any supported CSS value (and numbers).

<Typeset
+  fontSizes={["2.875em", "2em", "1.375em", "1em"]}
+  fontWeight="900"
+  sampleText="Lorem ipsum dolor sit amet, consectetur adipiscing elit."
+  fontFamily='"Nunito Sans", "Helvetica Neue", Helvetica, Arial, sans-serif'
/>

Create a new Typeset block for every discrete typographical subset.

<Typeset
+  fontSizes={["2.875em", "2em", "1.375em", "1em"]}
+  fontWeight="900"
+  sampleText="Lorem ipsum dolor sit amet, consectetur adipiscing elit."
+  fontFamily='"Nunito Sans", "Helvetica Neue", Helvetica, Arial, sans-serif'
/>

See full Typeset API reference.


IconGallery

Display icons with the IconGallery component.


Storybook component library showing sample typography documentation.


Import "@storybook/blocks". Then render a IconGallery with a single IconIteminside it.

// system/icons.mdx
import { IconGallery, IconItem } from "@storybook/blocks"

<IconGallery>
  <IconItem></IconItem>
</IconGallery>


Place an icon inside IconItem. Then display that icon's name with the name prop.

+ import * as Icons from "@storybook/icons";

<IconGallery>
  <IconItem name="Accessibility">
+    <Icons.Accessibility />
  </IconItem>
</IconGallery>

Take this further — in React — by dynamically generating all available icons.

## Storybook icons

<IconGallery>
  {Object.entries(Icons)
    .filter(([name]) => name !== "iconList")
    .map(([name, Icon]) => (
      <IconItem name={name}>
        <Icon />
      </IconItem>
    ))}
</IconGallery>

See full IconGallery API reference.

Learn more…

Find in-depth references for each component on the Storybook docs page and Chromatic YouTube channel.


Also published here.