JSPM

@storybook/addon-docs

5.2.0-alpha.17
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 6528343
  • Score
    100M100P100Q207692F
  • License MIT

Superior documentation for your components

Package Exports

  • @storybook/addon-docs
  • @storybook/addon-docs/blocks
  • @storybook/addon-docs/dist/blocks
  • @storybook/addon-docs/dist/shared
  • @storybook/addon-docs/mdx-compiler-plugin
  • @storybook/addon-docs/react/preset
  • @storybook/addon-docs/register

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@storybook/addon-docs) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Storybook Docs

Living documentation for your components.

View layer support

Docs supports all view layers that Storybook supports except for React Native (currently). There are some view-layer specific features as well. This chart captures the current state of support

React Vue Angular Polymer Mithril HTML Marko Svelte Riot Ember Preact
MDX stories + + + + + + + + + + +
Module stories + + + + + + + + + + +
Legacy stories + + + + + + + + + + +
Source * + + + + + + + + + + +
Notes / Info + + + + + + + + + + +
Props table + # #
Docgen + # #
Inline stories + #

Notes:

  • # denotes planned/WIP support
  • * Source supports legacy JS storiesOf and MDX stories. Typescript and new module format support is WIP

Installation

First add the package. Make sure that the versions for your @storybook/* packages match:

yarn add -D @storybooks/addon-docs

The add the following line to your .storybook/presets.js file:

module.exports = ['@storybook/addon-docs/react/preset'];

Finally, import your stories and MDX files in .storybook/config.js:

import { load } from '@storybook/react';

// standard configuration here
// ...

// wherever your story files are located
load(require.context('../src', true, /\.stories\.js$/), module);
load(require.context('../src', true, /\.stories\.mdx$/), module);

Manual configuration

Docs uses Storybook presets as a configuration shortcut. To configure "the long way", first register the addon in .storybook/addons.js:

import '@storybook/addon-docs/register';

Then configure Storybook's webpack loader to understand MDX files in .storybook/webpack.config.js:

const createCompiler = require('@storybook/addon-docs/mdx-compiler-plugin');

module.exports = async ({ config }) => {
  config.module.rules.push({
    test: /\.mdx$/,
    use: [
      {
        loader: 'babel-loader',
        // may or may not need this line depending on your app's setup
        plugins: ['@babel/plugin-transform-react-jsx'],
      },
      {
        loader: '@mdx-js/loader',
        options: {
          compilers: [createCompiler({})],
        },
      },
    ],
  });
  return config;
};