Source view

Source code viewer addon for Storybook

View on Github

Storybook source view addon

What is it?

This is an upgraded version of the original Storybook-source-code-addon by Gauthier Fiorentino for Storybook. It allows anyone navigating your Storybook to access the source code of your components. This addon provides an alternative to traditional libraries by enabling users to directly copy and paste your code instead of using it as a library.

How do I install it?

The installation is straightforward:

  • First, install the dependency:
$ npm i -D @epicuristic/storybook-source-view
  • Then add it to your .storybook/main.js
module.exports = {
  addons: ['@epicuristic/storybook-source-view']
}

Getting Started

Using a string

If your source code is stored as a string, add it to your story like this:

export default {
  title: 'Your story',
  parameters: {
    componentSource: {
      code: 'export default "This is my code"',
      language: 'javascript',
    }
  },
};

For better organization, you can store the code in a separate file:

// MyComponent.code.js
export default `
const MyComponent = () => "Hello World"
`
import MyComponentCode from './MyComponent.code'

export default {
  title: 'Your story',
  parameters: {
    componentSource: {
      code: MyComponentCode,
      language: 'javascript',
    }
  },
};

Using a URL

If your repository is publicly accessible, you can provide a URL to the addon:

export default {
  title: 'Your story',
  parameters: {
    componentSource: {
      url: 'https://path.to.your.repository/file%2Etsx',
      language: 'javascript',
    }
  },
};

Common API patterns for repositories include:

  • GitLab: https://gitlab.com/api/v4/projects/<ProjectID>/repository/files/<file path URL encoded>/raw?ref=master

Multiple files

To expose multiple files, you can use an array of URLs:

export default {
  title: 'Your story',
  parameters: {
    componentSource: {
      url: [
        'https://path.to.your.repository/file%2Etsx',
        'https://path.to.your.repository/file2%2Etsx',        
      ],
      language: 'javascript',
    }
  },
};

Alternatively, if you prefer using code strings:

export default {
  title: 'Your story',
  parameters: {
    componentSource: {
      code: [
        'export default "This is my code"',
        'export default "This is also my code"',
      ],
      language: 'javascript',
    }
  },
};