A VS Code extension that lets you browse and preview stories with Storybook, right inside your editor.
Install from the Visual Studio Marketplace
Browse your project's stories via a dedicated sidebar view. See all of your stories at a glance and quickly jump to their source. You don't even need to start a Storybook server.
See live previews of your stories directly within your editor. Focus on one, or open several side-by-side and see how they change as you code. And it works for docs, too. Story Explorer can automatically start a Storybook development server on-demand, or you can point it toward one you launch yourself.
Plus:
- Open stories and docs via CodeLens
- Jump to story source from a story preview for easy navigation
- Launch stories in an external browser when you want the full Storybook environment
- Get Intellisense suggestions for story titles
Controls whether to display CodeLens results for docs. When enabled, CodeLens results for docs appear at the top of story files.
Controls whether to display CodeLens results for stories. When enabled, CodeLens results for stories appear above story definitions.
Log level to use for logging. Logs are available via the Story Explorer output channel in the output panel.
-
none
: Do not log -
error
: Log errors only -
warn
: Log warnings and errors -
info
: Log general operational information, warnings, and errors -
debug
: Log debugging information, general operational information, warnings, and errors
Controls the presentation of the story in the embedded story preview.
-
canvas
: Displays the story's canvas, without any additional toolbars or Storybook UI. -
full
: Displays the story within the full Storybook UI.
URL of an externally launched and managed Storybook instance, used when storyExplorer.server.internal.enabled
is disabled. Defaults to http://localhost:6006
.
Controls when to automatically start a Storybook development server. This setting only applies when storyExplorer.server.internal.enabled
is enabled.
-
immediate
: Start the server automatically when opening the workspace. -
deferred
: Wait to start the server automatically until a story preview is opened.
storyExplorer.server.internal.startStorybook.args
. If you used this option to run a script other than start-storybook
, consider switching to a different launch strategy.
Array of command line arguments to pass to the start-storybook
script.
Array of command line arguments to pass to the custom script. Only used when storyExplorer.server.internal.launchStrategy
is set to custom
or detect
.
Path to a custom script used to start the Storybook development server. Only used when storyExplorer.server.internal.launchStrategy
is set to custom
or detect
.
Controls whether to enable the internal Storybook development server. When unchecked, you will have to run the server externally.
Object with environment variables that will be added to the Storybook server process.
The method to use to launch the Storybook development server.
-
detect
: Detect automatically -
npm
: Run an npm script -
storybook
: Runstorybook dev
directly, for use with Storybook 7 -
start-storybook
: Runstart-storybook
directly, for use with Storybook 6 -
task
: Run a VS Code task -
custom
: Run a custom command
Optional path to the directory containing the package.json
file with the npm script to use. If your workspace contains multiple package.json
files with the same script name, you can set this to specify which one to use. Only used when storyExplorer.server.internal.launchStrategy
is set to npm
or detect
.
Name of the npm script to use to launch the Storybook development server. Defaults to storybook
. Only used when storyExplorer.server.internal.launchStrategy
is set to npm
or detect
.
Array of command line arguments to pass to the start-storybook
script. Only used when storyExplorer.server.internal.launchStrategy
is set to start-storybook
or detect
.
Path to the start-storybook
script used to start the Storybook 6 development server. By default, Story Explorer will attempt to auto-detect the path inside node_modules
. Only used when storyExplorer.server.internal.launchStrategy
is set to start-storybook
or detect
.
Array of command line arguments to pass to the storybook
CLI when launching a development server. The dev
argument is always included. Only used when storyExplorer.server.internal.launchStrategy
is set to storybook
or detect
.
Path to the storybook
CLI used to start the Storybook 7 development server. By default, Story Explorer will attempt to auto-detect the path inside node_modules
. Only used when storyExplorer.server.internal.launchStrategy
is set to storybook
or detect
.
storyExplorer.server.internal.startStorybook.path
. If you used this option to run a script other than start-storybook
, consider switching to a different launch strategy.
Path to the start-storybook
script used to start the Storybook development server. By default, Story Explorer will attempt to auto-detect the path inside node_modules
.
Label of the task to run to launch the Storybook development server. Only used when storyExplorer.server.internal.launchStrategy
is set to task
or detect
.
Optional type of the task to run to launch the Storybook development server. Only used when storyExplorer.server.internal.launchStrategy
is set to task
or detect
.
Globs specifying the location of stories in the project relative to the workspace root. By default, stories globs are read from the Storybook configuration file. If specified, this takes precedence over the Storybook configuration file.
Controls whether to display story kinds in the stories view that do not contain any valid stories. These items do not appear in Storybook.
Overrides the docs.autodocs
portion of the Storybook configuration. This property configures auto-generated documentation pages.
-
null
: Use the same settings as detected in the Storybook configuration file -
tag
: Show auto-generated documentation entries for files with theautodocs
tag -
true
: Show auto-generated documentation entries for all files -
false
: Do not show auto-generated documentation entries
Overrides the docs.defaultName
portion of the Storybook configuration. This property controls the name of the auto-generated documentation page.
Location of the Storybook configuration directory containing main.js
. By default, Story Explorer will attempt to auto-detect a .storybook
configuration directory that contains a main.js
file. If your configuration directory is named something other than .storybook
or your workspace contains more than one configuration directory, you should manually specify a path to the configuration directory you wish to use.
Controls whether to offer suggestions for story IDs when using <Story id="..." />
in MDX files. Suggestions are based on the IDs of other stories in the project.
Controls whether to offer suggestions for titles when specifying a Meta
object in CSF or MDX files. Suggestions are based on other titles used in the project.
Much like Storybook's storyStoreV7
(which is enabled by default in Storybook 7), Story Explorer uses static analysis to identify stories and extract metadata from source files.
Static analysis is faster and safer than running arbitrary code, but its evaluation capabilities are more limited. As a result, its behavior may differ from what happens at runtime.
In practice, if your project is compatible with Storybook's storyStoreV7
, it should be fully supported. Even if your project isn't fully compliant with storyStoreV7
, you may not notice any discrepancies.
However, if you rely on nontrivial runtime behavior when defining or naming stories, they may not be recognized correctly.
Some advanced Storybook features aren't supported, including:
- Story indexers
storySort
configuration- Sidebar options set via
addons.setConfig
(includingcollapsedRoots
andrenderLabel
)
Story Explorer supports:
- Component Story Format (CSF) stories, including:
- MDX stories and docs (v1 and v2).
The legacy storiesOf
API is not supported.
Story previews are rendered in an iframe
embedded in a VS Code webview
. This imposes some restrictions inherent to the use of cross-origin iframe
s. For example, attempts to access window.top
in a story will cause an exception to be thrown.
Story Explorer attempts to suppress any uncaught exceptions so that they don't interfere with the preview, but some functionality may not work as expected. You can always open stories in an external browser instead of the built-in preview.
Story previews use isolated views of each story. These previews don't include the toolbar or addon panels, so addons that decorate the manager, such as controls, actions, and backgrounds, aren't available.
Story Explorer currently doesn't work with untrusted workspaces.