@storybook/core
Version:
Storybook framework-agnostic API
52 lines (31 loc) • 1.65 kB
Markdown
# Storybook Core
The `package is the core of Storybook. It is responsible for the following:
- the main UI of storybook
- the UI used by addons
- the API used by addons
- the API used by the CLI
- the API used by the server
- prebundled code used by the browser
- static assets used by the browser
- utilities for CSF, MDX & Docs
## Private package
This package is not intended to be used by anyone but storybook internally.
Even though this is where all of the code is located, it is NOT to be the entry point when using functionality within!
Consumers of the code should import like so:
```ts
import { addons } from 'storybook/internal/manager-api';
```
Importing from ` /core` is explicitly NOT supported; it WILL break in a future version of storybook, very likely in a non-major version bump.
# For maintainers
## When to use ` /core`
In the following packages you should import from ` /core` (and ONLY from ` /core`):
- ` /core`
- ` /codemod`
To prevent cyclical dependencies, these packages cannot depend on the `storybook` package.
## When to use `storybook/internal`
In every other package you should import from `storybook/internal` (and ONLY from `storybook/internal`).
The heuristic is simple:
> If you see a peerDependency on `storybook` in the `package.json` of the package you are working on, you should import from `storybook/internal`.
## The 1 exception: the `storybook` package itself
The sole exception is the `storybook` package itself.
Obviously, the `storybook` package cannot depend on itself, so it must import from ` /core`.
/core`