Migration

- [From version 8.x to 9.0.0](#from-version-8x-to-900) - [Package Manager Support](#package-manager-support) - [A11y addon: Removed deprecated manual parameter](#a11y-addon-removed-deprecated-manual-parameter) - [Button Component API Changes](#button-component-api-changes) - [Documentation Generation Changes](#documentation-generation-changes) - [Global State Management](#global-state-management) - [Icon System Updates](#icon-system-updates) - [Sidebar Component Changes](#sidebar-component-changes) - [Testing Module Changes](#testing-module-changes) - [Type System Updates](#type-system-updates) - [Story Store API Changes](#story-store-api-changes) - [CSF File Changes](#csf-file-changes) - [The parameter docs.source.excludeDecorators has no effect in React](#the-parameter-docssourceexcludedecorators-has-no-effect-in-react) - [Addon Viewport is moved to core](#addon-viewport-is-moved-to-core) - [Addon Controls is moved to core](#addon-controls-is-moved-to-core) - [Addon Actions is moved to core](#addon-actions-is-moved-to-core) - [React-Native config dir renamed](#react-native-config-dir-renamed) - [Addon viewport and addon backgrounds synchronized configuration and use globals](#addon-viewport-and-addon-backgrounds-synchronized-configuration-and-use-globals) - [Manager builder removed alias for `util`, `assert` and `process`](#manager-builder-removed-alias-for-util-assert-and-process) - [Docs addon moved out of addon-essentials](#docs-addon-moved-out-of-addon-essentials) - [Interactions addon moved to core](#interactions-addon-moved-to-core) - [Dropped support for legacy packages](#dropped-support-for-legacy-packages) - [Dropped support for TypeScript \< 4.9](#dropped-support-for-typescript--49) - [Test addon renamed from experimental to stable](#test-addon-renamed-from-experimental-to-stable) - [Experimental Status API has turned into a Status Store](#experimental-status-api-has-turned-into-a-status-store) - [Dropped support for Vite 4](#dropped-support-for-vite-4) - [Framework-specific changes](#framework-specific-changes) - [Angular = Require v18 and up](#angular--require-v18-and-up) - [Next.js = Require v14 and up](#nextjs--require-v14-and-up) - [Preact = Dropped webpack5 builder support](#preact--dropped-webpack5-builder-support) - [Vue3 = Dropped webpack5 builder support](#vue3--dropped-webpack5-builder-support) - [From version 8.5.x to 8.6.x](#from-version-85x-to-86x) - [Angular: Support experimental zoneless support](#angular-support-experimental-zoneless-support) - [Framework-specific Vite plugins have to be explicitly added](#framework-specific-vite-plugins-have-to-be-explicitly-added) - [For React:](#for-react) - [For Vue:](#for-vue) - [For Svelte (without Sveltekit):](#for-svelte-without-sveltekit) - [For Preact:](#for-preact) - [For Solid:](#for-solid) - [For Qwik:](#for-qwik) - [TurboSnap Vite plugin is no longer needed](#turbosnap-vite-plugin-is-no-longer-needed) - [`--webpack-stats-json` option renamed `--stats-json`](#--webpack-stats-json-option-renamed---stats-json) - [Implicit actions can not be used during rendering (for example in the play function)](#implicit-actions-can-not-be-used-during-rendering-for-example-in-the-play-function) - [MDX related changes](#mdx-related-changes) - [MDX is upgraded to v3](#mdx-is-upgraded-to-v3) - [Dropping support for \*.stories.mdx (CSF in MDX) format and MDX1 support](#dropping-support-for-storiesmdx-csf-in-mdx-format-and-mdx1-support) - [Dropping support for id, name and story in Story block](#dropping-support-for-id-name-and-story-in-story-block) - [Core changes](#core-changes) - [`framework.options.builder.useSWC` for Webpack5-based projects removed](#frameworkoptionsbuilderuseswc-for-webpack5-based-projects-removed) - [Removed `@babel/core` and `babel-loader` from `@storybook/builder-webpack5`](#removed-babelcore-and-babel-loader-from-storybookbuilder-webpack5) - [`framework.options.fastRefresh` for Webpack5-based projects removed](#frameworkoptionsfastrefresh-for-webpack5-based-projects-removed) - [`typescript.skipBabel` removed](#typescriptskipbabel-removed) - [Dropping support for Yarn 1](#dropping-support-for-yarn-1) - [Dropping support for Node.js 16](#dropping-support-for-nodejs-16) - [Autotitle breaking fixes](#autotitle-breaking-fixes) - [Storyshots has been removed](#storyshots-has-been-removed) - [UI layout state has changed shape](#ui-layout-state-has-changed-shape) - [New UI and props for Button and IconButton components](#new-ui-and-props-for-button-and-iconbutton-components) - [Icons is deprecated](#icons-is-deprecated) - [Removed postinstall](#removed-postinstall) - [Removed stories.json](#removed-storiesjson) - [Removed `sb babelrc` command](#removed-sb-babelrc-command) - [Changed interfaces for `@storybook/router` components](#changed-interfaces-for-storybookrouter-components) - [Extract no longer batches](#extract-no-longer-batches) - [Framework-specific changes](#framework-specific-changes-1) - [React](#react) - [`react-docgen` component analysis by default](#react-docgen-component-analysis-by-default) - [Next.js](#nextjs) - [Require Next.js 13.5 and up](#require-nextjs-135-and-up) - [Automatic SWC mode detection](#automatic-swc-mode-detection) - [RSC config moved to React renderer](#rsc-config-moved-to-react-renderer) - [Vue](#vue) - [Require Vue 3 and up](#require-vue-3-and-up) - [Angular](#angular) - [Require Angular 15 and up](#require-angular-15-and-up) - [Svelte](#svelte) - [Require Svelte 4 and up](#require-svelte-4-and-up) - [Preact](#preact) - [Require Preact 10 and up](#require-preact-10-and-up) - [No longer adds default Babel plugins](#no-longer-adds-default-babel-plugins) - [Web Components](#web-components) - [Dropping default babel plugins in Webpack5-based projects](#dropping-default-babel-plugins-in-webpack5-based-projects) - [Deprecations which are now removed](#deprecations-which-are-now-removed) - [Removed `config` preset](#removed-config-preset) - [Removed `passArgsFirst` option](#removed-passargsfirst-option) - [Methods and properties from AddonStore](#methods-and-properties-from-addonstore) - [Methods and properties from PreviewAPI](#methods-and-properties-from-previewapi) - [Removals in @storybook/components](#removals-in-storybookcomponents) - [Removals in @storybook/types](#removals-in-storybooktypes) - [--use-npm flag in storybook CLI](#--use-npm-flag-in-storybook-cli) - [hideNoControlsWarning parameter from addon controls](#hidenocontrolswarning-parameter-from-addon-controls) - [`setGlobalConfig` from `@storybook/react`](#setglobalconfig-from-storybookreact) - [StorybookViteConfig type from @storybook/builder-vite](#storybookviteconfig-type-from-storybookbuilder-vite) - [props from WithTooltipComponent from @storybook/components](#props-from-withtooltipcomponent-from-storybookcomponents) - [LinkTo direct import from addon-links](#linkto-direct-import-from-addon-links) - [DecoratorFn, Story, ComponentStory, ComponentStoryObj, ComponentStoryFn and ComponentMeta TypeScript types](#decoratorfn-story-componentstory-componentstoryobj-componentstoryfn-and-componentmeta-typescript-types) - ["Framework" TypeScript types](#framework-typescript-types) - [`navigateToSettingsPage` method from Storybook's manager-api](#navigatetosettingspage-method-from-storybooks-manager-api) - [storyIndexers](#storyindexers) - [Deprecated docs parameters](#deprecated-docs-parameters) - [Description Doc block properties](#description-doc-block-properties) - [Story Doc block properties](#story-doc-block-properties) - [Manager API expandAll and collapseAll methods](#manager-api-expandall-and-collapseall-methods) - [`ArgsTable` Doc block removed](#argstable-doc-block-removed) - [`Source` Doc block properties](#source-doc-block-properties) - [`Canvas` Doc block properties](#canvas-doc-block-properties) - [`Primary` Doc block properties](#primary-doc-block-properties) - [`createChannel` from `@storybook/postmessage` and `@storybook/channel-websocket`](#createchannel-from-storybookpostmessage-and-storybookchannel-websocket) - [StoryStore and methods deprecated](#storystore-and-methods-deprecated) - [Addon author changes](#addon-author-changes) - [Tab addons cannot manually route, Tool addons can filter their visibility via tabId](#tab-addons-cannot-manually-route-tool-addons-can-filter-their-visibility-via-tabid) - [Removed `config` preset](#removed-config-preset-1) - [From version 7.5.0 to 7.6.0](#from-version-750-to-760) - [CommonJS with Vite is deprecated](#commonjs-with-vite-is-deprecated) - [Using implicit actions during rendering is deprecated](#using-implicit-actions-during-rendering-is-deprecated) - [typescript.skipBabel deprecated](#typescriptskipbabel-deprecated) - [Primary doc block accepts of prop](#primary-doc-block-accepts-of-prop) - [Addons no longer need a peer dependency on React](#addons-no-longer-need-a-peer-dependency-on-react) - [From version 7.4.0 to 7.5.0](#from-version-740-to-750) - [`storyStoreV6` and `storiesOf` is deprecated](#storystorev6-and-storiesof-is-deprecated) - [`storyIndexers` is replaced with `experimental_indexers`](#storyindexers-is-replaced-with-experimental_indexers) - [From version 7.0.0 to 7.2.0](#from-version-700-to-720) - [Addon API is more type-strict](#addon-api-is-more-type-strict) - [Addon-controls hideNoControlsWarning parameter is deprecated](#addon-controls-hidenocontrolswarning-parameter-is-deprecated) - [From version 6.5.x to 7.0.0](#from-version-65x-to-700) - [7.0 breaking changes](#70-breaking-changes) - [Dropped support for Node 15 and below](#dropped-support-for-node-15-and-below) - [Default export in Preview.js](#default-export-in-previewjs) - [ESM format in Main.js](#esm-format-in-mainjs) - [Modern browser support](#modern-browser-support) - [React peer dependencies required](#react-peer-dependencies-required) - [start-storybook / build-storybook binaries removed](#start-storybook--build-storybook-binaries-removed) - [New Framework API](#new-framework-api) - [Available framework packages](#available-framework-packages) - [Framework field mandatory](#framework-field-mandatory) - [frameworkOptions renamed](#frameworkoptions-renamed) - [builderOptions renamed](#builderoptions-renamed) - [TypeScript: StorybookConfig type moved](#typescript-storybookconfig-type-moved) - [Titles are statically computed](#titles-are-statically-computed) - [Framework standalone build moved](#framework-standalone-build-moved) - [Change of root html IDs](#change-of-root-html-ids) - [Stories glob matches MDX files](#stories-glob-matches-mdx-files) - [Add strict mode](#add-strict-mode) - [Importing plain markdown files with `transcludeMarkdown` has changed](#importing-plain-markdown-files-with-transcludemarkdown-has-changed) - [Stories field in .storybook/main.js is mandatory](#stories-field-in-storybookmainjs-is-mandatory) - [Stricter global types](#stricter-global-types) - [Deploying build artifacts](#deploying-build-artifacts) - [Dropped support for file URLs](#dropped-support-for-file-urls) - [Serving with nginx](#serving-with-nginx) - [Ignore story files from node\_modules](#ignore-story-files-from-node_modules) - [7.0 Core changes](#70-core-changes) - [7.0 feature flags removed](#70-feature-flags-removed) - [Story context is prepared before for supporting fine grained updates](#story-context-is-prepared-before-for-supporting-fine-grained-updates) - [Changed decorator order between preview.js and addons/frameworks](#changed-decorator-order-between-previewjs-and-addonsframeworks) - [Dark mode detection](#dark-mode-detection) - [`addons.setConfig` should now be imported from `@storybook/manager-api`.](#addonssetconfig-should-now-be-imported-from-storybookmanager-api) - [7.0 core addons changes](#70-core-addons-changes) - [Removed auto injection of @storybook/addon-actions decorator](#removed-auto-injection-of-storybookaddon-actions-decorator) - [Addon-backgrounds: Removed deprecated grid parameter](#addon-backgrounds-removed-deprecated-grid-parameter) - [Addon-a11y: Removed deprecated withA11y decorator](#addon-a11y-removed-deprecated-witha11y-decorator) - [Addon-interactions: Interactions debugger is now default](#addon-interactions-interactions-debugger-is-now-default) - [7.0 Vite changes](#70-vite-changes) - [Vite builder uses Vite config automatically](#vite-builder-uses-vite-config-automatically) - [Vite cache moved to node\_modules/.cache/.vite-storybook](#vite-cache-moved-to-node_modulescachevite-storybook) - [7.0 Webpack changes](#70-webpack-changes) - [Webpack4 support discontinued](#webpack4-support-discontinued) - [Babel mode v7 exclusively](#babel-mode-v7-exclusively) - [Postcss removed](#postcss-removed) - [Removed DLL flags](#removed-dll-flags) - [7.0 Framework-specific changes](#70-framework-specific-changes) - [Angular: Removed deprecated `component` and `propsMeta` field](#angular-removed-deprecated-component-and-propsmeta-field) - [Angular: Drop support for Angular \< 14](#angular-drop-support-for-angular--14) - [Angular: Drop support for calling Storybook directly](#angular-drop-support-for-calling-storybook-directly) - [Angular: Application providers and ModuleWithProviders](#angular-application-providers-and-modulewithproviders) - [Angular: Removed legacy renderer](#angular-removed-legacy-renderer) - [Angular: Initializer functions](#angular-initializer-functions) - [Next.js: use the `@storybook/nextjs` framework](#nextjs-use-the-storybooknextjs-framework) - [SvelteKit: needs the `@storybook/sveltekit` framework](#sveltekit-needs-the-storybooksveltekit-framework) - [Vue3: replaced app export with setup](#vue3-replaced-app-export-with-setup) - [Web-components: dropped lit-html v1 support](#web-components-dropped-lit-html-v1-support) - [Create React App: dropped CRA4 support](#create-react-app-dropped-cra4-support) - [HTML: No longer auto-dedents source code](#html-no-longer-auto-dedents-source-code) - [7.0 Addon authors changes](#70-addon-authors-changes) - [New Addons API](#new-addons-api) - [Specific instructions for addon creators](#specific-instructions-for-addon-creators) - [Specific instructions for addon users](#specific-instructions-for-addon-users) - [register.js removed](#registerjs-removed) - [No more default export from `@storybook/addons`](#no-more-default-export-from-storybookaddons) - [No more configuration for manager](#no-more-configuration-for-manager) - [Icons API changed](#icons-api-changed) - [Removed global client APIs](#removed-global-client-apis) - [framework parameter renamed to renderer](#framework-parameter-renamed-to-renderer) - [7.0 Docs changes](#70-docs-changes) - [Autodocs changes](#autodocs-changes) - [MDX docs files](#mdx-docs-files) - [Unattached docs files](#unattached-docs-files) - [Doc Blocks](#doc-blocks) - [Meta block](#meta-block) - [Description block, `parameters.notes` and `parameters.info`](#description-block-parametersnotes-and-parametersinfo) - [Story block](#story-block) - [Source block](#source-block) - [Canvas block](#canvas-block) - [ArgsTable block](#argstable-block) - [Configuring Autodocs](#configuring-autodocs) - [MDX2 upgrade](#mdx2-upgrade) - [Legacy MDX1 support](#legacy-mdx1-support) - [Default docs styles will leak into non-story user components](#default-docs-styles-will-leak-into-non-story-user-components) - [Explicit `` elements are no longer syntax highlighted](#explicit-code-elements-are-no-longer-syntax-highlighted) - [Dropped source loader / storiesOf static snippets](#dropped-source-loader--storiesof-static-snippets) - [Removed docs.getContainer and getPage parameters](#removed-docsgetcontainer-and-getpage-parameters) - [Addon-docs: Removed deprecated blocks.js entry](#addon-docs-removed-deprecated-blocksjs-entry) - [Dropped addon-docs manual babel configuration](#dropped-addon-docs-manual-babel-configuration) - [Dropped addon-docs manual configuration](#dropped-addon-docs-manual-configuration) - [Autoplay in docs](#autoplay-in-docs) - [Removed STORYBOOK\_REACT\_CLASSES global](#removed-storybook_react_classes-global) - [7.0 Deprecations and default changes](#70-deprecations-and-default-changes) - [storyStoreV7 enabled by default](#storystorev7-enabled-by-default) - [`Story` type deprecated](#story-type-deprecated) - [`ComponentStory`, `ComponentStoryObj`, `ComponentStoryFn` and `ComponentMeta` types are deprecated](#componentstory-componentstoryobj-componentstoryfn-and-componentmeta-types-are-deprecated) - [Renamed `renderToDOM` to `renderToCanvas`](#renamed-rendertodom-to-rendertocanvas) - [Renamed `XFramework` to `XRenderer`](#renamed-xframework-to-xrenderer) - [Renamed `DecoratorFn` to `Decorator`](#renamed-decoratorfn-to-decorator) - [CLI option `--use-npm` deprecated](#cli-option---use-npm-deprecated) - ['config' preset entry replaced with 'previewAnnotations'](#config-preset-entry-replaced-with-previewannotations) - [From version 6.4.x to 6.5.0](#from-version-64x-to-650) - [Vue 3 upgrade](#vue-3-upgrade) - [React18 new root API](#react18-new-root-api) - [Renamed isToolshown to showToolbar](#renamed-istoolshown-to-showtoolbar) - [Dropped support for addon-actions addDecorators](#dropped-support-for-addon-actions-adddecorators) - [Vite builder renamed](#vite-builder-renamed) - [Docs framework refactor for React](#docs-framework-refactor-for-react) - [Opt-in MDX2 support](#opt-in-mdx2-support) - [CSF3 auto-title improvements](#csf3-auto-title-improvements) - [Auto-title filename case](#auto-title-filename-case) - [Auto-title redundant filename](#auto-title-redundant-filename) - [Auto-title always prefixes](#auto-title-always-prefixes) - [6.5 Deprecations](#65-deprecations) - [Deprecated register.js](#deprecated-registerjs) - [From version 6.3.x to 6.4.0](#from-version-63x-to-640) - [Automigrate](#automigrate) - [CRA5 upgrade](#cra5-upgrade) - [CSF3 enabled](#csf3-enabled) - [Optional titles](#optional-titles) - [String literal titles](#string-literal-titles) - [StoryObj type](#storyobj-type) - [Story Store v7](#story-store-v7) - [Behavioral differences](#behavioral-differences) - [Main.js framework field](#mainjs-framework-field) - [Using the v7 store](#using-the-v7-store) - [v7-style story sort](#v7-style-story-sort) - [v7 default sort behavior](#v7-default-sort-behavior) - [v7 Store API changes for addon authors](#v7-store-api-changes-for-addon-authors) - [Storyshots compatibility in the v7 store](#storyshots-compatibility-in-the-v7-store) - [Emotion11 quasi-compatibility](#emotion11-quasi-compatibility) - [Babel mode v7](#babel-mode-v7) - [Loader behavior with args changes](#loader-behavior-with-args-changes) - [6.4 Angular changes](#64-angular-changes) - [SB Angular builder](#sb-angular-builder) - [Angular13](#angular13) - [Angular component parameter removed](#angular-component-parameter-removed) - [6.4 deprecations](#64-deprecations) - [Deprecated --static-dir CLI flag](#deprecated---static-dir-cli-flag) - [From version 6.2.x to 6.3.0](#from-version-62x-to-630) - [Webpack 5](#webpack-5) - [Fixing hoisting issues](#fixing-hoisting-issues) - [Webpack 5 manager build](#webpack-5-manager-build) - [Wrong webpack version](#wrong-webpack-version) - [Angular 12 upgrade](#angular-12-upgrade) - [Lit support](#lit-support) - [No longer inferring default values of args](#no-longer-inferring-default-values-of-args) - [6.3 deprecations](#63-deprecations) - [Deprecated addon-knobs](#deprecated-addon-knobs) - [Deprecated scoped blocks imports](#deprecated-scoped-blocks-imports) - [Deprecated layout URL params](#deprecated-layout-url-params) - [From version 6.1.x to 6.2.0](#from-version-61x-to-620) - [MDX pattern tweaked](#mdx-pattern-tweaked) - [6.2 Angular overhaul](#62-angular-overhaul) - [New Angular storyshots format](#new-angular-storyshots-format) - [Deprecated Angular story component](#deprecated-angular-story-component) - [New Angular renderer](#new-angular-renderer) - [Components without selectors](#components-without-selectors) - [Packages now available as ESModules](#packages-now-available-as-esmodules) - [6.2 Deprecations](#62-deprecations) - [Deprecated implicit PostCSS loader](#deprecated-implicit-postcss-loader) - [Deprecated default PostCSS plugins](#deprecated-default-postcss-plugins) - [Deprecated showRoots config option](#deprecated-showroots-config-option) - [Deprecated control.options](#deprecated-controloptions) - [Deprecated storybook components html entry point](#deprecated-storybook-components-html-entry-point) - [From version 6.0.x to 6.1.0](#from-version-60x-to-610) - [Addon-backgrounds preset](#addon-backgrounds-preset) - [Single story hoisting](#single-story-hoisting) - [React peer dependencies](#react-peer-dependencies) - [6.1 deprecations](#61-deprecations) - [Deprecated DLL flags](#deprecated-dll-flags) - [Deprecated storyFn](#deprecated-storyfn) - [Deprecated onBeforeRender](#deprecated-onbeforerender) - [Deprecated grid parameter](#deprecated-grid-parameter) - [Deprecated package-composition disabled parameter](#deprecated-package-composition-disabled-parameter) - [From version 5.3.x to 6.0.x](#from-version-53x-to-60x) - [Hoisted CSF annotations](#hoisted-csf-annotations) - [Zero config typescript](#zero-config-typescript) - [Correct globs in main.js](#correct-globs-in-mainjs) - [CRA preset removed](#cra-preset-removed) - [Core-JS dependency errors](#core-js-dependency-errors) - [Args passed as first argument to story](#args-passed-as-first-argument-to-story) - [6.0 Docs breaking changes](#60-docs-breaking-changes) - [Remove framework-specific docs presets](#remove-framework-specific-docs-presets) - [Preview/Props renamed](#previewprops-renamed) - [Docs theme separated](#docs-theme-separated) - [DocsPage slots removed](#docspage-slots-removed) - [React prop tables with Typescript](#react-prop-tables-with-typescript) - [ConfigureJSX true by default in React](#configurejsx-true-by-default-in-react) - [User babelrc disabled by default in MDX](#user-babelrc-disabled-by-default-in-mdx) - [Docs description parameter](#docs-description-parameter) - [6.0 Inline stories](#60-inline-stories) - [New addon presets](#new-addon-presets) - [Removed babel-preset-vue from Vue preset](#removed-babel-preset-vue-from-vue-preset) - [Removed Deprecated APIs](#removed-deprecated-apis) - [New setStories event](#new-setstories-event) - [Removed renderCurrentStory event](#removed-rendercurrentstory-event) - [Removed hierarchy separators](#removed-hierarchy-separators) - [No longer pass denormalized parameters to storySort](#no-longer-pass-denormalized-parameters-to-storysort) - [Client API changes](#client-api-changes) - [Removed Legacy Story APIs](#removed-legacy-story-apis) - [Can no longer add decorators/parameters after stories](#can-no-longer-add-decoratorsparameters-after-stories) - [Changed Parameter Handling](#changed-parameter-handling) - [Simplified Render Context](#simplified-render-context) - [Story Store immutable outside of configuration](#story-store-immutable-outside-of-configuration) - [Improved story source handling](#improved-story-source-handling) - [6.0 Addon API changes](#60-addon-api-changes) - [Consistent local addon paths in main.js](#consistent-local-addon-paths-in-mainjs) - [Deprecated setAddon](#deprecated-setaddon) - [Deprecated disabled parameter](#deprecated-disabled-parameter) - [Actions addon uses parameters](#actions-addon-uses-parameters) - [Removed action decorator APIs](#removed-action-decorator-apis) - [Removed withA11y decorator](#removed-witha11y-decorator) - [Essentials addon disables differently](#essentials-addon-disables-differently) - [Backgrounds addon has a new api](#backgrounds-addon-has-a-new-api) - [6.0 Deprecations](#60-deprecations) - [Deprecated addon-info, addon-notes](#deprecated-addon-info-addon-notes) - [Deprecated addon-contexts](#deprecated-addon-contexts) - [Removed addon-centered](#removed-addon-centered) - [Deprecated polymer](#deprecated-polymer) - [Deprecated immutable options parameters](#deprecated-immutable-options-parameters) - [Deprecated addParameters and addDecorator](#deprecated-addparameters-and-adddecorator) - [Deprecated clearDecorators](#deprecated-cleardecorators) - [Deprecated configure](#deprecated-configure) - [Deprecated support for duplicate kinds](#deprecated-support-for-duplicate-kinds) - [From version 5.2.x to 5.3.x](#from-version-52x-to-53x) - [To main.js configuration](#to-mainjs-configuration) - [Using main.js](#using-mainjs) - [Using preview.js](#using-previewjs) - [Using manager.js](#using-managerjs) - [Create React App preset](#create-react-app-preset) - [Description doc block](#description-doc-block) - [React Native Async Storage](#react-native-async-storage) - [Deprecate displayName parameter](#deprecate-displayname-parameter) - [Unified docs preset](#unified-docs-preset) - [Simplified hierarchy separators](#simplified-hierarchy-separators) - [Addon StoryShots Puppeteer uses external puppeteer](#addon-storyshots-puppeteer-uses-external-puppeteer) - [From version 5.1.x to 5.2.x](#from-version-51x-to-52x) - [Source-loader](#source-loader) - [Default viewports](#default-viewports) - [Grid toolbar-feature](#grid-toolbar-feature) - [Docs mode docgen](#docs-mode-docgen) - [storySort option](#storysort-option) - [From version 5.1.x to 5.1.10](#from-version-51x-to-5110) - [babel.config.js support](#babelconfigjs-support) - [From version 5.0.x to 5.1.x](#from-version-50x-to-51x) - [React native server](#react-native-server) - [Angular 7](#angular-7) - [CoreJS 3](#corejs-3) - [From version 5.0.1 to 5.0.2](#from-version-501-to-502) - [Deprecate webpack extend mode](#deprecate-webpack-extend-mode) - [From version 4.1.x to 5.0.x](#from-version-41x-to-50x) - [sortStoriesByKind](#sortstoriesbykind) - [Webpack config simplification](#webpack-config-simplification) - [Theming overhaul](#theming-overhaul) - [Story hierarchy defaults](#story-hierarchy-defaults) - [Options addon deprecated](#options-addon-deprecated) - [Individual story decorators](#individual-story-decorators) - [Addon backgrounds uses parameters](#addon-backgrounds-uses-parameters) - [Addon cssresources name attribute renamed](#addon-cssresources-name-attribute-renamed) - [Addon viewport uses parameters](#addon-viewport-uses-parameters) - [Addon a11y uses parameters, decorator renamed](#addon-a11y-uses-parameters-decorator-renamed) - [Addon centered decorator deprecated](#addon-centered-decorator-deprecated) - [New keyboard shortcuts defaults](#new-keyboard-shortcuts-defaults) - [New URL structure](#new-url-structure) - [Rename of the `--secure` cli parameter to `--https`](#rename-of-the---secure-cli-parameter-to---https) - [Vue integration](#vue-integration) - [From version 4.0.x to 4.1.x](#from-version-40x-to-41x) - [Private addon config](#private-addon-config) - [React 15.x](#react-15x) - [From version 3.4.x to 4.0.x](#from-version-34x-to-40x) - [React 16.3+](#react-163) - [Generic addons](#generic-addons) - [Knobs select ordering](#knobs-select-ordering) - [Knobs URL parameters](#knobs-url-parameters) - [Keyboard shortcuts moved](#keyboard-shortcuts-moved) - [Removed addWithInfo](#removed-addwithinfo) - [Removed RN packager](#removed-rn-packager) - [Removed RN addons](#removed-rn-addons) - [Storyshots Changes](#storyshots-changes) - [Webpack 4](#webpack-4) - [Babel 7](#babel-7) - [Create-react-app](#create-react-app) - [Upgrade CRA1 to babel 7](#upgrade-cra1-to-babel-7) - [Migrate CRA1 while keeping babel 6](#migrate-cra1-while-keeping-babel-6) - [start-storybook opens browser](#start-storybook-opens-browser) - [CLI Rename](#cli-rename) - [Addon story parameters](#addon-story-parameters) - [From version 3.3.x to 3.4.x](#from-version-33x-to-34x) - [From version 3.2.x to 3.3.x](#from-version-32x-to-33x) - [`babel-core` is now a peer dependency #2494](#babel-core-is-now-a-peer-dependency-2494) - [Base webpack config now contains vital plugins #1775](#base-webpack-config-now-contains-vital-plugins-1775) - [Refactored Knobs](#refactored-knobs) - [From version 3.1.x to 3.2.x](#from-version-31x-to-32x) - [Moved TypeScript addons definitions](#moved-typescript-addons-definitions) - [Updated Addons API](#updated-addons-api) - [From version 3.0.x to 3.1.x](#from-version-30x-to-31x) - [Moved TypeScript definitions](#moved-typescript-definitions) - [Deprecated head.html](#deprecated-headhtml) - [From version 2.x.x to 3.x.x](#from-version-2xx-to-3xx) - [Webpack upgrade](#webpack-upgrade) - [Packages renaming](#packages-renaming) - [Deprecated embedded addons](#deprecated-embedded-addons) ## From version 8.x to 9.0.0 ### Package Manager Support Storybook 9.0 drops official support and maintenance for older package manager versions: - npm v8 and v9 are no longer supported - yarn v3 is no longer supported - pnpm v7 and v8 are no longer supported The minimum supported versions are now: - npm v10+ - yarn v4+ - pnpm v9+ While Storybook may still work with older versions, we recommend upgrading to the latest supported versions for the best experience and to ensure compatibility. ### A11y addon: Removed deprecated manual parameter The deprecated `manual` parameter from the A11y addon's parameters has been removed. Instead, use the `globals.a11y.manual` setting to control manual mode. For example: ```js // Old way (no longer works) export const MyStory = { parameters: { a11y: { manual: true } } }; // New way export const MyStory = { parameters: { a11y: { // other a11y parameters } } globals: { a11y: { manual: true } } }; // To enable manual mode globally, use .storybook/preview.js: export const initialGlobals = { a11y: { manual: true } }; ``` ### Button Component API Changes The Button component has been updated to use a more modern props API. The following props have been removed: - `isLink` - `primary` - `secondary` - `tertiary` - `gray` - `inForm` - `small` - `outline` - `containsIcon` Use the new `variant` and `size` props instead: ```diff - + ``` ### Documentation Generation Changes The `autodocs` configuration option has been removed in favor of using tags: ```diff // .storybook/preview.js export default { - docs: { autodocs: true } }; // In your CSF files: + export default { + tags: ['autodocs'] + }; ``` ### Global State Management The `globals` field in project annotations has been renamed to `initialGlobals`: ```diff export const preview = { - globals: { + initialGlobals: { theme: 'light' } }; ``` Additionally loading the defaultValue from `globalTypes` isn't supported anymore. Use `initialGlobals` instead to define the defaultValue. ```diff // .storybook/preview.js export default { + initialGlobals: { + locale: 'en' + }, globalTypes: { locale: { description: 'Locale for components', - defaultValue: 'en', toolbar: { title: 'Locale', icon: 'circlehollow', items: ['es', 'en'], }, }, }, } ``` ### Icon System Updates Several icon-related exports have been removed: - `IconButtonSkeleton` - `Icons` - `Symbols` - Legacy icon exports Use the new icon system from `@storybook/icons` instead: ```diff - import { Icons, IconButtonSkeleton } from '@storybook/components'; + import { ZoomIcon } from '@storybook/icons'; ``` ### Sidebar Component Changes 1. The 'extra' prop has been removed from the Sidebar's Heading component 2. Experimental sidebar features have been removed: - `experimental_SIDEBAR_BOTTOM` - `experimental_SIDEBAR_TOP` ### Testing Module Changes The `TESTING_MODULE_RUN_ALL_REQUEST` event has been removed: ```diff - import { TESTING_MODULE_RUN_ALL_REQUEST } from '@storybook/core-events'; + import { TESTING_MODULE_RUN_REQUEST } from '@storybook/core-events'; ``` ### Type System Updates The following types have been removed: - `Addon_SidebarBottomType` - `Addon_SidebarTopType` - `DeprecatedState` Import paths have been updated: ```diff - import { SupportedRenderers } from './project_types'; + import { SupportedRenderers } from 'storybook/internal/types'; ``` ### Story Store API Changes Several deprecated methods have been removed from the StoryStore: - `getSetStoriesPayload` - `getStoriesJsonData` - `raw` - `fromId` ### CSF File Changes Deprecated getters have been removed from the CsfFile class: - `_fileName` - `_makeTitle` ### The parameter docs.source.excludeDecorators has no effect in React In React, the parameter `docs.source.excludeDecorators` option is no longer used. Decorators are always excluded as it causes performance issues and doc source snippets not showing the actual component. ### Addon Viewport is moved to core The viewport addon has been moved from `@storybook/addon-viewport` to Storybook core. You no longer need to install it separately or include it in your addons list. As a consequence, `@storybook/addon-viewport` is not part of `@storybook/addon-essentials` anymore. ### Addon Controls is moved to core The controls addon has been moved from `@storybook/addon-controls` to Storybook core. You no longer need to install it separately or include it in your addons list. As a consequence, `@storybook/addon-controls` is not part of `@storybook/addon-essentials` anymore. ### Addon Actions is moved to core The actions addon has been moved from `@storybook/addon-actions` to Storybook core. You no longer need to install it separately or include it in your addons list. As a consequence, `@storybook/addon-actions` is not part of `@storybook/addon-essentials` anymore. Furthermore, we have deprecated the usage of `withActions` from `@storybook/addon-actions` and we will remove it in Storybook v10. Please file an issue if you need this API. ### React-Native config dir renamed In Storybook 9, React Native (RN) projects use the `.rnstorybook` config directory instead of `.storybook`. That makes it easier for RN and React Native Web (RNW) storybooks to co-exist in the same project. To upgrade, either rename your `.storybook` directory to `.rnstorybook` or if you wish to continue using `.storybook` (not recommended), you can use the [`configPath`](https://github.com/storybookjs/react-native#configpath) option to specify `.storybook` manually. ### Addon viewport and addon backgrounds synchronized configuration and use globals The feature flags: `viewportStoryGlobals` and `backgroundsStoryGlobals` have been removed, please remove these from your `.storybook/main.ts` file. See here for the ways you have to configure addon viewports & backgrounds: - [New parameters format for addon backgrounds](#new-parameters-format-for-addon-backgrounds) - [New parameters format for addon viewport](#new-parameters-format-for-addon-viewport) ### Manager builder removed alias for `util`, `assert` and `process` These dependencies (often used accidentally) were polyfilled to mocks or browser equivalents by storybook's manager builder. Starting with Storybook `9.0`, we no longer alias these anymore. Adding these aliases meant storybook core, had to depend on these packages, which have a deep dependency graph, added to every storybook project. If you addon fails to load after this change, we recommend looking at implementing the alias at compile time of your addon, or alternatively look at other bundling config to ensure the correct entries/packages/dependencies are used. ### Docs addon moved out of addon-essentials Addon docs is now no longer part of `@storybook/addon-essentials`, because Storybook is moving towards a more customizable & personally optimized approach. If you are using addon-docs via addon-essentials, you will need to add addon-docs to your project, by installing it and adding it to your `.storybook/main.ts`'s `addons` field; or run this command: `npx storybook add @storybook/addon-docs`. ### Interactions addon moved to core The interactions addon has been moved from `@storybook/addon-interactions` to Storybook core. You no longer need to install it separately or include it in your addons list. If you manually migrate to Storybook 9, please ensure to uninstall the addon as a dependency and to remove its registration in your `.storybook/main.ts` file. ### Dropped support for legacy packages The following packages are no longer published as part of `9.0.0`: The following packages have been consolidated into the main `storybook` package: | Old Package | New Path | | ------------------------ | --------------------- | | @storybook/manager-api | storybook/manager-api | | @storybook/preview-api | storybook/preview-api | | @storybook/theming | storybook/theming | | @storybook/test | storybook/test | | @storybook/addon-actions | storybook/actions | Please un-install these packages, and ensure you have the `storybook` package installed. Replace any imports with the path listed in the second column. Additionally the following packages were also consolidated and placed under a `/internal` sub-path, to indicate they are for internal usage only. If you're depending on these packages, they will continue to work for `9.0`, but they will likely be removed in `10.0`. | Old Package | New Path | | -------------------------- | ---------------------------------- | | @storybook/channels | storybook/internal/channels | | @storybook/client-logger | storybook/internal/client-logger | | @storybook/core-common | storybook/internal/common | | @storybook/core-events | storybook/internal/core-events | | @storybook/csf-tools | storybook/internal/csf-tools | | @storybook/docs-tools | storybook/internal/docs-tools | | @storybook/node-logger | storybook/internal/node-logger | | @storybook/router | storybook/internal/router | | @storybook/telemetry | storybook/internal/telemetry | | @storybook/types | storybook/internal/types | | @storybook/manager | storybook/internal/manager | | @storybook/preview | storybook/internal/preview | | @storybook/core-server | storybook/internal/core-server | | @storybook/builder-manager | storybook/internal/builder-manager | | @storybook/components | storybook/internal/components | Addon authors may continue to use the internal packages, there is currently not yet any replacement. ### Dropped support for TypeScript < 4.9 Storybook now requires TypeScript 4.9 or later. If you're using an older version of TypeScript, you'll need to upgrade to continue using Storybook. ### Test addon renamed from experimental to stable In Storybook 9.0, we've officially stabilized the Test addon. The package has been renamed from `@storybook/experimental-addon-test` to `@storybook/addon-test`, reflecting its production-ready status. If you were using the experimental addon, you'll need to update your dependencies and imports: ```diff - npm install --save-dev @storybook/experimental-addon-test + npm install --save-dev @storybook/addon-test ``` Update your imports in any custom configuration or test files: ```diff - import { ... } from '@storybook/experimental-addon-test'; + import { ... } from '@storybook/addon-test'; ``` If you're using the addon in your Storybook configuration, update your `.storybook/main.js` or `.storybook/main.ts`: ```diff export default { addons: [ - '@storybook/experimental-addon-test', + '@storybook/addon-test', ], }; ``` The public API remains the same, so no additional changes should be needed in your test files or configuration. ### Experimental Status API has turned into a Status Store The experimental status API previously available at `api.experimental_updateStatus` and `api.getCurrentStoryStatus` has changed, to a store that works both on the server, in the manager and in the preview. You can use the new Status Store by importing `experimental_getStatusStore` from either `storybook/internal/core-server`, `storybook/manager-api` or `storybook/preview-api`: ```diff + import { experimental_getStatusStore } from 'storybook/manager-api'; + import { StatusValue } from 'storybook/internal/types'; + const myStatusStore = experimental_getStatusStore(MY_ADDON_ID); addons.register(MY_ADDON_ID, (api) => { - api.experimental_updateStatus({ - someStoryId: { - status: 'success', - title: 'Component tests', - description: 'Works!', - } - }); + myStatusStore.set([{ + value: StatusValue.SUCCESS + title: 'Component tests', + description: 'Works!', + }]); ``` ### Dropped support for Vite 4 Storybook 9.0 drops support for Vite 4. The minimum supported version is now Vite 5.0.0. This change affects all Vite-based frameworks and builders: - `@storybook/builder-vite` - `@storybook/react-vite` - `@storybook/vue-vite` - `@storybook/vue3-vite` - `@storybook/svelte-vite` - `@storybook/web-components-vite` - `@storybook/preact-vite` - `@storybook/html-vite` - `@storybook/experimental-nextjs-vite` To upgrade: 1. Update your project's Vite version to 5.0.0 or higher 2. Update your Storybook configuration to use Vite 5: ```js // vite.config.js or vite.config.ts export default { // ... your other config // Make sure you're using Vite 5 compatible plugins } ``` If you're using framework-specific Vite plugins, ensure they are compatible with Vite 5: - `@vitejs/plugin-react` - `@vitejs/plugin-vue` - `@sveltejs/vite-plugin-svelte` - etc. For more information on upgrading to Vite 5, see the [Vite Migration Guide](https://vitejs.dev/guide/migration). ### Framework-specific changes #### Angular = Require v18 and up Storybook has dropped support for Angular versions 15-17. The minimum supported version is now Angular 18. If you're using an older version of Angular, you'll need to upgrade to Angular 18 or newer to use the latest version of Storybook. Key changes: - All Angular packages in peerDependencies now require `>=18.0.0 < 20.0.0` - Removed legacy code supporting Angular < 18 - Standalone components are now the default (can be opted out by explicitly setting `standalone: false` in component decorators) - Updated RxJS requirement to `^7.4.0` - Updated TypeScript requirement to `^4.9.0 || ^5.0.0` - Updated Zone.js requirement to `^0.14.0 || ^0.15.0` #### Next.js = Require v14 and up Storybook has dropped support for Next.js versions below 14. The minimum supported version is now Next.js 14. If you're using an older version of Next.js, you'll need to upgrade to Next.js 14 or newer to use the latest version of Storybook. For help upgrading your Next.js application, see the [Next.js upgrade guide](https://nextjs.org/docs/app/building-your-application/upgrading). #### Preact = Dropped webpack5 builder support The `@storybook/preact-webpack5` and `@storybook/preset-preact-webpack5` packages have been removed. For Preact projects, please use the Vite builder instead: ```bash npm remove @storybook/preact-webpack5 @storybook/preset-preact-webpack npm install @storybook/preact-vite --save-dev ``` Then update your `.storybook/main.js|ts`: ```js export default { framework: { name: '@storybook/preact-vite', options: {}, }, // ... other configurations }; ``` #### Vue3 = Dropped webpack5 builder support The `@storybook/vue3-webpack5` package has been removed. For Vue3 projects, please use the Vite builder instead: ```bash npm remove @storybook/vue3-webpack5 @storybook/preset-vue3-webpack npm install @storybook/vue3-vite --save-dev ``` Then update your `.storybook/main.js|ts`: ```js export default { framework: { name: '@storybook/vue3-vite', options: {}, }, // ... other configurations }; ``` ## From version 8.5.x to 8.6.x ### Angular: Support experimental zoneless support Angular 16 introduced support for zoneless mode. Storybook now supports this mode in experimental mode. To enable zoneless mode, set the `experimental_zoneless` flag to `true` in your `.storybook/main.ts` file: ````

Migration

- [From version 8.x to 9.0.0](#from-version-8x-to-900) - [Addon Toolbars is now part of the core](#addon-toolbars-is-now-part-of-the-core) - [Addon Controls is now part of the core](#addon-controls-is-now-part-of-the-core) - [Actions addon moved to core](#actions-addon-moved-to-core) - [Viewport addon moved to core](#viewport-addon-moved-to-core) - [Addon viewport and addon backgrounds synchronized configuration and use globals](#addon-viewport-and-addon-backgrounds-synchronized-configuration-and-use-globals) - [Manager builder removed alias for `util`, `assert` and `process`](#manager-builder-removed-alias-for-util-assert-and-process) - [Docs addon moved out of addon-essentials](#docs-addon-moved-out-of-addon-essentials) - [Dropped support for legacy packages](#dropped-support-for-legacy-packages) - [Dropped support for TypeScript \< 4.9](#dropped-support-for-typescript--49) - [Test addon renamed from experimental to stable](#test-addon-renamed-from-experimental-to-stable) - [Experimental Status API has turned into a Status Store](#experimental-status-api-has-turned-into-a-status-store) - [From version 8.5.x to 8.6.x](#from-version-85x-to-86x) - [Angular: Support experimental zoneless support](#angular-support-experimental-zoneless-support) - [Addon-a11y: Replaced experimental `ally-test` tag behavior with `parameters.a11y.test`](#addon-a11y-replaced-experimental-ally-test-tag-behavior-with-parametersa11ytest) - [From version 8.4.x to 8.5.x](#from-version-84x-to-85x) - [React Vite: react-docgen-typescript is updated](#react-vite-react-docgen-typescript-is-updated) - [Introducing features.developmentModeForBuild](#introducing-featuresdevelopmentmodeforbuild) - [Added source code panel to docs](#added-source-code-panel-to-docs) - [Addon-a11y: Component test integration](#addon-a11y-component-test-integration) - [Addon-a11y: Changing the default element selector](#addon-a11y-changing-the-default-element-selector) - [Addon-a11y: Deprecated `parameters.a11y.manual`](#addon-a11y-deprecated-parametersa11ymanual) - [Addon-test: You should no longer copy the content of `viteFinal` to your configuration](#addon-test-you-should-no-longer-copy-the-content-of-vitefinal-to-your-configuration) - [Addon-test: Indexing behavior of @storybook/experimental-addon-test is changed](#addon-test-indexing-behavior-of-storybookexperimental-addon-test-is-changed) - [From version 8.2.x to 8.3.x](#from-version-82x-to-83x) - [Removed `experimental_SIDEBAR_BOTTOM` and deprecated `experimental_SIDEBAR_TOP` addon types](#removed-experimental_sidebar_bottom-and-deprecated-experimental_sidebar_top-addon-types) - [New parameters format for addon backgrounds](#new-parameters-format-for-addon-backgrounds) - [New parameters format for addon viewport](#new-parameters-format-for-addon-viewport) - [From version 8.1.x to 8.2.x](#from-version-81x-to-82x) - [Failed to resolve import "@storybook/X" error](#failed-to-resolve-import-storybookx-error) - [Preview.js globals renamed to initialGlobals](#previewjs-globals-renamed-to-initialglobals) - [From version 8.0.x to 8.1.x](#from-version-80x-to-81x) - [Portable stories](#portable-stories) - [@storybook/nextjs requires specific path aliases to be setup](#storybooknextjs-requires-specific-path-aliases-to-be-setup) - [main.js `docs.autodocs` is deprecated](#mainjs-docsautodocs-is-deprecated) - [`docs` and `story` system tags removed](#docs-and-story-system-tags-removed) - [Subtitle block and `parameters.componentSubtitle`](#subtitle-block-and-parameterscomponentsubtitle) - [Title block `of` prop](#title-block-of-prop) - [From version 7.x to 8.0.0](#from-version-7x-to-800) - [Portable stories](#portable-stories-1) - [Project annotations are now merged instead of overwritten in composeStory](#project-annotations-are-now-merged-instead-of-overwritten-in-composestory) - [Type change in `composeStories` API](#type-change-in-composestories-api) - [Composed Vue stories are now components instead of functions](#composed-vue-stories-are-now-components-instead-of-functions) - [Tab addons are now routed to a query parameter](#tab-addons-are-now-routed-to-a-query-parameter) - [Default keyboard shortcuts changed](#default-keyboard-shortcuts-changed) - [Manager addons are now rendered with React 18](#manager-addons-are-now-rendered-with-react-18) - [Removal of `storiesOf`-API](#removal-of-storiesof-api) - [Removed deprecated shim packages](#removed-deprecated-shim-packages) - [Deprecated `@storybook/testing-library` package](#deprecated-storybooktesting-library-package) - [Framework-specific Vite plugins have to be explicitly added](#framework-specific-vite-plugins-have-to-be-explicitly-added) - [For React:](#for-react) - [For Vue:](#for-vue) - [For Svelte (without Sveltekit):](#for-svelte-without-sveltekit) - [For Preact:](#for-preact) - [For Solid:](#for-solid) - [For Qwik:](#for-qwik) - [TurboSnap Vite plugin is no longer needed](#turbosnap-vite-plugin-is-no-longer-needed) - [`--webpack-stats-json` option renamed `--stats-json`](#--webpack-stats-json-option-renamed---stats-json) - [Implicit actions can not be used during rendering (for example in the play function)](#implicit-actions-can-not-be-used-during-rendering-for-example-in-the-play-function) - [MDX related changes](#mdx-related-changes) - [MDX is upgraded to v3](#mdx-is-upgraded-to-v3) - [Dropping support for \*.stories.mdx (CSF in MDX) format and MDX1 support](#dropping-support-for-storiesmdx-csf-in-mdx-format-and-mdx1-support) - [Dropping support for id, name and story in Story block](#dropping-support-for-id-name-and-story-in-story-block) - [Core changes](#core-changes) - [`framework.options.builder.useSWC` for Webpack5-based projects removed](#frameworkoptionsbuilderuseswc-for-webpack5-based-projects-removed) - [Removed `@babel/core` and `babel-loader` from `@storybook/builder-webpack5`](#removed-babelcore-and-babel-loader-from-storybookbuilder-webpack5) - [`framework.options.fastRefresh` for Webpack5-based projects removed](#frameworkoptionsfastrefresh-for-webpack5-based-projects-removed) - [`typescript.skipBabel` removed](#typescriptskipbabel-removed) - [Dropping support for Yarn 1](#dropping-support-for-yarn-1) - [Dropping support for Node.js 16](#dropping-support-for-nodejs-16) - [Autotitle breaking fixes](#autotitle-breaking-fixes) - [Storyshots has been removed](#storyshots-has-been-removed) - [UI layout state has changed shape](#ui-layout-state-has-changed-shape) - [New UI and props for Button and IconButton components](#new-ui-and-props-for-button-and-iconbutton-components) - [Icons is deprecated](#icons-is-deprecated) - [Removed postinstall](#removed-postinstall) - [Removed stories.json](#removed-storiesjson) - [Removed `sb babelrc` command](#removed-sb-babelrc-command) - [Changed interfaces for `@storybook/router` components](#changed-interfaces-for-storybookrouter-components) - [Extract no longer batches](#extract-no-longer-batches) - [Framework-specific changes](#framework-specific-changes) - [React](#react) - [`react-docgen` component analysis by default](#react-docgen-component-analysis-by-default) - [Next.js](#nextjs) - [Require Next.js 13.5 and up](#require-nextjs-135-and-up) - [Automatic SWC mode detection](#automatic-swc-mode-detection) - [RSC config moved to React renderer](#rsc-config-moved-to-react-renderer) - [Vue](#vue) - [Require Vue 3 and up](#require-vue-3-and-up) - [Angular](#angular) - [Require Angular 15 and up](#require-angular-15-and-up) - [Svelte](#svelte) - [Require Svelte 4 and up](#require-svelte-4-and-up) - [Preact](#preact) - [Require Preact 10 and up](#require-preact-10-and-up) - [No longer adds default Babel plugins](#no-longer-adds-default-babel-plugins) - [Web Components](#web-components) - [Dropping default babel plugins in Webpack5-based projects](#dropping-default-babel-plugins-in-webpack5-based-projects) - [Deprecations which are now removed](#deprecations-which-are-now-removed) - [Removed `config` preset](#removed-config-preset) - [Removed `passArgsFirst` option](#removed-passargsfirst-option) - [Methods and properties from AddonStore](#methods-and-properties-from-addonstore) - [Methods and properties from PreviewAPI](#methods-and-properties-from-previewapi) - [Removals in @storybook/components](#removals-in-storybookcomponents) - [Removals in @storybook/types](#removals-in-storybooktypes) - [--use-npm flag in storybook CLI](#--use-npm-flag-in-storybook-cli) - [hideNoControlsWarning parameter from addon controls](#hidenocontrolswarning-parameter-from-addon-controls) - [`setGlobalConfig` from `@storybook/react`](#setglobalconfig-from-storybookreact) - [StorybookViteConfig type from @storybook/builder-vite](#storybookviteconfig-type-from-storybookbuilder-vite) - [props from WithTooltipComponent from @storybook/components](#props-from-withtooltipcomponent-from-storybookcomponents) - [LinkTo direct import from addon-links](#linkto-direct-import-from-addon-links) - [DecoratorFn, Story, ComponentStory, ComponentStoryObj, ComponentStoryFn and ComponentMeta TypeScript types](#decoratorfn-story-componentstory-componentstoryobj-componentstoryfn-and-componentmeta-typescript-types) - ["Framework" TypeScript types](#framework-typescript-types) - [`navigateToSettingsPage` method from Storybook's manager-api](#navigatetosettingspage-method-from-storybooks-manager-api) - [storyIndexers](#storyindexers) - [Deprecated docs parameters](#deprecated-docs-parameters) - [Description Doc block properties](#description-doc-block-properties) - [Story Doc block properties](#story-doc-block-properties) - [Manager API expandAll and collapseAll methods](#manager-api-expandall-and-collapseall-methods) - [`ArgsTable` Doc block removed](#argstable-doc-block-removed) - [`Source` Doc block properties](#source-doc-block-properties) - [`Canvas` Doc block properties](#canvas-doc-block-properties) - [`Primary` Doc block properties](#primary-doc-block-properties) - [`createChannel` from `@storybook/postmessage` and `@storybook/channel-websocket`](#createchannel-from-storybookpostmessage-and-storybookchannel-websocket) - [StoryStore and methods deprecated](#storystore-and-methods-deprecated) - [Addon author changes](#addon-author-changes) - [Tab addons cannot manually route, Tool addons can filter their visibility via tabId](#tab-addons-cannot-manually-route-tool-addons-can-filter-their-visibility-via-tabid) - [Removed `config` preset](#removed-config-preset-1) - [From version 7.5.0 to 7.6.0](#from-version-750-to-760) - [CommonJS with Vite is deprecated](#commonjs-with-vite-is-deprecated) - [Using implicit actions during rendering is deprecated](#using-implicit-actions-during-rendering-is-deprecated) - [typescript.skipBabel deprecated](#typescriptskipbabel-deprecated) - [Primary doc block accepts of prop](#primary-doc-block-accepts-of-prop) - [Addons no longer need a peer dependency on React](#addons-no-longer-need-a-peer-dependency-on-react) - [From version 7.4.0 to 7.5.0](#from-version-740-to-750) - [`storyStoreV6` and `storiesOf` is deprecated](#storystorev6-and-storiesof-is-deprecated) - [`storyIndexers` is replaced with `experimental_indexers`](#storyindexers-is-replaced-with-experimental_indexers) - [From version 7.0.0 to 7.2.0](#from-version-700-to-720) - [Addon API is more type-strict](#addon-api-is-more-type-strict) - [Addon-controls hideNoControlsWarning parameter is deprecated](#addon-controls-hidenocontrolswarning-parameter-is-deprecated) - [From version 6.5.x to 7.0.0](#from-version-65x-to-700) - [7.0 breaking changes](#70-breaking-changes) - [Dropped support for Node 15 and below](#dropped-support-for-node-15-and-below) - [Default export in Preview.js](#default-export-in-previewjs) - [ESM format in Main.js](#esm-format-in-mainjs) - [Modern browser support](#modern-browser-support) - [React peer dependencies required](#react-peer-dependencies-required) - [start-storybook / build-storybook binaries removed](#start-storybook--build-storybook-binaries-removed) - [New Framework API](#new-framework-api) - [Available framework packages](#available-framework-packages) - [Framework field mandatory](#framework-field-mandatory) - [frameworkOptions renamed](#frameworkoptions-renamed) - [builderOptions renamed](#builderoptions-renamed) - [TypeScript: StorybookConfig type moved](#typescript-storybookconfig-type-moved) - [Titles are statically computed](#titles-are-statically-computed) - [Framework standalone build moved](#framework-standalone-build-moved) - [Change of root html IDs](#change-of-root-html-ids) - [Stories glob matches MDX files](#stories-glob-matches-mdx-files) - [Add strict mode](#add-strict-mode) - [Importing plain markdown files with `transcludeMarkdown` has changed](#importing-plain-markdown-files-with-transcludemarkdown-has-changed) - [Stories field in .storybook/main.js is mandatory](#stories-field-in-storybookmainjs-is-mandatory) - [Stricter global types](#stricter-global-types) - [Deploying build artifacts](#deploying-build-artifacts) - [Dropped support for file URLs](#dropped-support-for-file-urls) - [Serving with nginx](#serving-with-nginx) - [Ignore story files from node_modules](#ignore-story-files-from-node_modules) - [7.0 Core changes](#70-core-changes) - [7.0 feature flags removed](#70-feature-flags-removed) - [Story context is prepared before for supporting fine grained updates](#story-context-is-prepared-before-for-supporting-fine-grained-updates) - [Changed decorator order between preview.js and addons/frameworks](#changed-decorator-order-between-previewjs-and-addonsframeworks) - [Dark mode detection](#dark-mode-detection) - [`addons.setConfig` should now be imported from `@storybook/manager-api`.](#addonssetconfig-should-now-be-imported-from-storybookmanager-api) - [7.0 core addons changes](#70-core-addons-changes) - [Removed auto injection of @storybook/addon-actions decorator](#removed-auto-injection-of-storybookaddon-actions-decorator) - [Addon-backgrounds: Removed deprecated grid parameter](#addon-backgrounds-removed-deprecated-grid-parameter) - [Addon-a11y: Removed deprecated withA11y decorator](#addon-a11y-removed-deprecated-witha11y-decorator) - [Addon-interactions: Interactions debugger is now default](#addon-interactions-interactions-debugger-is-now-default) - [7.0 Vite changes](#70-vite-changes) - [Vite builder uses Vite config automatically](#vite-builder-uses-vite-config-automatically) - [Vite cache moved to node_modules/.cache/.vite-storybook](#vite-cache-moved-to-node_modulescachevite-storybook) - [7.0 Webpack changes](#70-webpack-changes) - [Webpack4 support discontinued](#webpack4-support-discontinued) - [Babel mode v7 exclusively](#babel-mode-v7-exclusively) - [Postcss removed](#postcss-removed) - [Removed DLL flags](#removed-dll-flags) - [7.0 Framework-specific changes](#70-framework-specific-changes) - [Angular: Removed deprecated `component` and `propsMeta` field](#angular-removed-deprecated-component-and-propsmeta-field) - [Angular: Drop support for Angular \< 14](#angular-drop-support-for-angular--14) - [Angular: Drop support for calling Storybook directly](#angular-drop-support-for-calling-storybook-directly) - [Angular: Application providers and ModuleWithProviders](#angular-application-providers-and-modulewithproviders) - [Angular: Removed legacy renderer](#angular-removed-legacy-renderer) - [Angular: Initializer functions](#angular-initializer-functions) - [Next.js: use the `@storybook/nextjs` framework](#nextjs-use-the-storybooknextjs-framework) - [SvelteKit: needs the `@storybook/sveltekit` framework](#sveltekit-needs-the-storybooksveltekit-framework) - [Vue3: replaced app export with setup](#vue3-replaced-app-export-with-setup) - [Web-components: dropped lit-html v1 support](#web-components-dropped-lit-html-v1-support) - [Create React App: dropped CRA4 support](#create-react-app-dropped-cra4-support) - [HTML: No longer auto-dedents source code](#html-no-longer-auto-dedents-source-code) - [7.0 Addon authors changes](#70-addon-authors-changes) - [New Addons API](#new-addons-api) - [Specific instructions for addon creators](#specific-instructions-for-addon-creators) - [Specific instructions for addon users](#specific-instructions-for-addon-users) - [register.js removed](#registerjs-removed) - [No more default export from `@storybook/addons`](#no-more-default-export-from-storybookaddons) - [No more configuration for manager](#no-more-configuration-for-manager) - [Icons API changed](#icons-api-changed) - [Removed global client APIs](#removed-global-client-apis) - [framework parameter renamed to renderer](#framework-parameter-renamed-to-renderer) - [7.0 Docs changes](#70-docs-changes) - [Autodocs changes](#autodocs-changes) - [MDX docs files](#mdx-docs-files) - [Unattached docs files](#unattached-docs-files) - [Doc Blocks](#doc-blocks) - [Meta block](#meta-block) - [Description block, `parameters.notes` and `parameters.info`](#description-block-parametersnotes-and-parametersinfo) - [Story block](#story-block) - [Source block](#source-block) - [Canvas block](#canvas-block) - [ArgsTable block](#argstable-block) - [Configuring Autodocs](#configuring-autodocs) - [MDX2 upgrade](#mdx2-upgrade) - [Legacy MDX1 support](#legacy-mdx1-support) - [Default docs styles will leak into non-story user components](#default-docs-styles-will-leak-into-non-story-user-components) ### Deprecated `@storybook/testing-library` package In Storybook 8, `@storybook/testing-library` has been integrated to a new package called `@storybook/test`, which uses Vitest APIs for an improved experience. When upgrading to Storybook 8 with 'npx storybook@latest upgrade', you will get prompted and will get an automigration for the new package. Please migrate when you can. To migrate by hand, install `@storybook/test` and replace `@storybook/testing-libary` imports globally: ```ts - import { userEvent } from '@storybook/testing-library'; + import { userEvent } from '@storybook/test'; ```` For more information on the change, see the [announcement post](https://storybook.js.org/blog/storybook-test/). ### Framework-specific Vite plugins have to be explicitly added In Storybook 7, we would automatically add frameworks-specific Vite plugins, e.g. `@vitejs/plugin-react` if not installed. In Storybook 8 those plugins have to be added explicitly in the user's `vite.config.ts`: #### For React: ```ts import { defineConfig } from "vite"; import react from "@vitejs/plugin-react"; export default defineConfig({ plugins: [react()], }); ``` #### For Vue: ```ts import { defineConfig } from "vite"; import vue from "@vitejs/plugin-vue"; export default defineConfig({ plugins: [vue()], }); ``` #### For Svelte (without Sveltekit): ```ts import { defineConfig } from "vite"; import { svelte } from "@sveltejs/vite-plugin-svelte"; export default defineConfig({ plugins: [svelte()], }); ``` #### For Preact: ```ts import { defineConfig } from "vite"; import preact from "@preact/preset-vite"; export default defineConfig({ plugins: [preact()], }); ``` #### For Solid: ```ts import { defineConfig } from "vite"; import solid from "vite-plugin-solid"; export default defineConfig({ plugins: [solid()], }); ``` #### For Qwik: ```ts import { defineConfig } from "vite"; import qwik from "vite-plugin-qwik"; export default defineConfig({ plugins: [qwik()], }); ``` ### TurboSnap Vite plugin is no longer needed At least in build mode, `builder-vite` now supports the `--webpack-stats-json` flag and will output `preview-stats.json`. This means https://github.com/IanVS/vite-plugin-turbosnap is no longer necessary, and duplicative, and the plugin will automatically be removed if found. ### `--webpack-stats-json` option renamed `--stats-json` Now that both Vite and Webpack support the `preview-stats.json` file, the flag has been renamed. The old flag will continue to work. ### Implicit actions can not be used during rendering (for example in the play function) In Storybook 7, we inferred if the component accepts any action props, by checking if it starts with `onX` (for example `onClick`), or as configured by `actions.argTypesRegex`. If that was the case, we would fill in jest spies for those args automatically. ```ts export default { component: Button, }; export const ButtonClick = { play: async ({ args, canvasElement }) => { await userEvent.click(within(canvasElement).getByRole("button")); // args.onClick is a jest spy in 7.0 await expect(args.onClick).toHaveBeenCalled(); }, }; ``` In Storybook 8 this feature is removed, and spies have to added explicitly: ```ts import { fn } from "@storybook/test"; export default { component: Button, args: { onClick: fn(), }, }; export const ButtonClick = { play: async ({ args, canvasElement }) => { await userEvent.click(within(canvasElement).getByRole("button")); await expect(args.onClick).toHaveBeenCalled(); }, }; ``` For more context, see this RFC: https://github.com/storybookjs/storybook/discussions/23649 To summarize: - This makes CSF files less magical and more portable, so that CSF files will render the same in a test environment where docgen is not available. - This allows users and (test) integrators to run or build storybook without docgen, boosting the user performance and allows tools to give quicker feedback. - This will make sure that we can one day lazy load docgen, without changing how stories are rendered. ### MDX related changes #### MDX is upgraded to v3 Storybook now uses MDX3 under the hood. This change contains many improvements and a few small breaking changes that probably won't affect you. However we recommend checking the [migration notes from MDX here](https://mdxjs.com/blog/v3/). #### Dropping support for \*.stories.mdx (CSF in MDX) format and MDX1 support In Storybook 7, we deprecated the ability of using MDX both for documentation and for defining stories in the same .stories.mdx file. It is now removed, and Storybook won't support .stories.mdx files anymore. We provide migration scripts to help you onto the new format. If you were using the [legacy MDX1 format](#legacy-mdx1-support), you will have to remove the `legacyMdx1` main.js feature flag and the `@storybook/mdx1-csf` package. Alongside with this change, the `jsxOptions` configuration was removed as it is not used anymore. [More info here](https://storybook.js.org/docs/migration-guide#storiesmdx-to-mdxcsf). #### Dropping support for id, name and story in Story block Referencing stories by `id`, `name` or `story` in the Story block is not possible anymore. [More info here](#story-block). ### Core changes #### `framework.options.builder.useSWC` for Webpack5-based projects removed In Storybook 8.0, we have removed the `framework.options.builder.useSWC` option. The `@storybook/builder-webpack5` package is now compiler-agnostic and does not depend on Babel or SWC. If you want to use SWC, you can add the necessary addon: ```sh npx storybook@latest add @storybook/addon-webpack5-compiler-swc ``` The goal is to make @storybook/builder-webpack5 lighter and more flexible. We are not locked into a specific compiler or compiler version anymore. This allows us to support Babel 7/8, SWC, and other compilers simultaneously. #### Removed `@babel/core` and `babel-loader` from `@storybook/builder-webpack5` In Storybook 8.0, we have removed the `@storybook/builder-webpack5` package's dependency on Babel. This means that Babel is not preconfigured in `@storybook/builder-webpack5`. If you want to use Babel, you can add the necessary addon: ```sh npx storybook@latest add @storybook/addon-webpack5-compiler-babel ``` We are doing this to make Storybook more flexible and to allow users to use a variety of compilers like SWC, Babel or even pure TypeScript. #### `framework.options.fastRefresh` for Webpack5-based projects removed In Storybook 8.0, we have removed the `framework.options.fastRefresh` option. The fast-refresh implementation currently relies on the `react-refresh/babel` package. While this has served us well, integrating this dependency could pose challenges. Specifically, it locks users into a specific Babel version. This could become a problem when Babel 8 is released. There is uncertainty about whether react-refresh/babel will seamlessly support Babel 8, potentially hindering users from updating smoothly. Furthermore, the existing implementation does not account for cases where fast-refresh might already be configured in a user's Babel configuration. Rather than filtering out existing configurations, our current approach could lead to duplications, resulting in a sub-optimal development experience. We believe in empowering our users, and setting up fast-refresh manually is a straightforward process. The following configuration will configure fast-refresh if Storybook does not automatically pick up your fast-refresh configuration: `package.json`: ```diff { "devDependencies": { + "@pmmmwh/react-refresh-webpack-plugin": "^0.5.11", + "react-refresh": "^0.14.0", } } ``` `babel.config.js` (optionally, add it to `.storybook/main.js`): ```diff +const isProdBuild = process.env.NODE_ENV === 'production'; module.exports = (api) => { return { plugins: [ + !isProdBuild && 'react-refresh/babel', ].filter(Boolean), }; }; ``` `.storybook/main.js`: ```diff +import ReactRefreshWebpackPlugin from "@pmmmwh/react-refresh-webpack-plugin"; +const isProdBuild = process.env.NODE_ENV === 'production'; const config = { webpackFinal: (config) => { + config.plugins = [ + !isProdBuild && new ReactRefreshWebpackPlugin({ + overlay: { + sockIntegration: 'whm', + }, + }), + ...config.plugins, + ].filter(Boolean); return config; }, }; export default config; ``` This approach aligns with our philosophy of transparency and puts users in control of their Webpack and Babel configurations. We want to minimize magic behind the scenes. By removing `framework.options.fastRefresh`, we are reducing unnecessary configuration. Instead, we encourage users to leverage their existing Webpack and Babel setups, fostering a more transparent and customizable development environment. You don't have to add fast refresh to `@storybook/nextjs` since it is already configured there as a default to match the same experience as `next dev`. #### `typescript.skipBabel` removed We have removed the `typescript.skipBabel` option in Storybook 8.0. Please use `typescript.skipCompiler` instead. #### Dropping support for Yarn 1 Storybook will stop providing fixes aimed at Yarn 1 projects. This does not necessarily mean that Storybook will stop working for Yarn 1 projects, just that the team won't provide more fixes aimed at it. For context, it's been 6 years since the release of Yarn 1, and Yarn is currently in version 4, which was [released in October 2023](https://yarnpkg.com/blog/release/4.0). #### Dropping support for Node.js 16 In Storybook 8, we have dropped Node.js 16 support since it reached end-of-life on 2023-09-11. Storybook 8 supports Node.js 18 and above. #### Autotitle breaking fixes In Storybook 7, the file name `path/to/foo.bar.stories.js` would result in the [autotitle](https://storybook.js.org/docs/react/configure/overview#configure-story-loading) `path/to/foo`. In 8.0, this has been changed to generate `path/to/foo.bar`. We consider this a bugfix but it is also a breaking change if you depended on the old behavior. To get the old titles, you can manually specify the desired title in the default export of your story file. For example: ```js export default { title: "path/to/foo", }; ``` Alternatively, if you need to achieve a different behavior for a large number of files, you can provide a [custom indexer](https://storybook.js.org/docs/7.0/vue/configure/sidebar-and-urls#processing-custom-titles) to generate the titles dynamically. #### Storyshots has been removed Storyshots was an addon for Storybook which allowed users to turn their stories into automated snapshot tests. Every story would automatically be taken into account and create a snapshot file. Snapshot testing has since fallen out of favor and is no longer recommended. In addition to its limited use, and high chance of false positives, Storyshots ran code developed to run in the browser in NodeJS via JSDOM. JSDOM has limitations and is not a perfect emulation of the browser environment; therefore, Storyshots was always a pain to set up and maintain. The Storybook team has built the test-runner as a direct replacement, which utilizes Playwright to connect to an actual browser where Storybook runs the code. In addition, CSF has expanded to allow for play functions to be defined on stories, which allows for more complex testing scenarios, fully integrated within Storybook itself (and supported by the test-runner, and not Storyshots). Finally, storyStoreV7: true (the default and only option in Storybook 8), was not supported by Storyshots. By removing Storyshots, the Storybook team was unblocked from moving (eventually) to an ESM-only Storybook, which is a big step towards a more modern Storybook. Please check the [migration guide](https://storybook.js.org/docs/writing-tests/storyshots-migration-guide) that we prepared. #### UI layout state has changed shape In Storybook 7 it was possible to use `addons.setConfig({...});` to configure Storybook UI features and behavior as documented [here (v7)](https://storybook.js.org/docs/7.3/react/configure/features-and-behavior), [(latest)](https://storybook.js.org/docs/react/configure/features-and-behavior). The state and API for the UI layout has changed: - `showNav: boolean` is now `navSize: number`, where the number represents the size of the sidebar in pixels. - `showPanel: boolean` is now split into `bottomPanelHeight: number` and `rightPanelWidth: number`, where the numbers represents the size of the panel in pixels. - `isFullscreen: boolean` is no longer supported, but can be achieved by setting a combination of the above. #### New UI and props for Button and IconButton components We used to have a lot of different buttons in `@storybook/components` that were not used anywhere. In Storybook 8.0 we are deprecating `Form.Button` and added a new `Button` component that can be used in all places. The `IconButton` component has also been updated to use the new `Button` component under the hood. Going forward addon creators and Storybook maintainers should use the new `Button` component instead of `Form.Button`. For the `Button` component, the following props are now deprecated: - `isLink` - Please use the `asChild` prop instead like this: `` - `primary` - Please use the `variant` prop instead. - `secondary` - Please use the `variant` prop instead. - `tertiary` - Please use the `variant` prop instead. - `gray` - Please use the `variant` prop instead. - `inForm` - Please use the `variant` prop instead. - `small` - Please use the `size` prop instead. - `outline` - Please use the `variant` prop instead. - `containsIcon`. Please add your icon as a child directly. No need for this prop anymore. The `IconButton` doesn't have any deprecated props but it now uses the new `Button` component under the hood so all props for `IconButton` will be the same as `Button`. #### Icons is deprecated In Storybook 8.0 we are introducing a new icon library available with `@storybook/icons`. We are deprecating the `Icons` component in `@storybook/components` and recommend that addon creators and Storybook maintainers use the new `@storybook/icons` component instead. #### Removed postinstall We removed the `@storybook/postinstall` package, which provided some utilities for addons to programmatically modify user configuration files on install. This package was years out of date, so this should be a non-disruptive change. If your addon used the package, you can view the old source code [here](https://github.com/storybookjs/storybook/tree/release-7-5/code/lib/postinstall) and adapt it into your addon. #### Removed stories.json In addition to the built storybook, `storybook build` generates two files, `index.json` and `stories.json`, that list out the contents of the Storybook. `stories.json` is a legacy format and we included it for backwards compatibility. As of 8.0 we no longer build `stories.json` by default, and we will remove it completely in 9.0. In the meantime if you have code that relies on `stories.json`, you can find code that transforms the "v4" `index.json` to the "v3" `stories.json` format (and their respective TS types): https://github.com/storybookjs/storybook/blob/release-7-5/code/lib/core-server/src/utils/stories-json.ts#L71-L91 #### Removed `sb babelrc` command The `sb babelrc` command was used to generate a `.babelrc` file for Storybook. This command is now removed. From version 8.0 onwards, Storybook is compiler-agnostic and does not depend on Babel or SWC if you use Webpack 5. This move was made to make Storybook more flexible and allow users to configure their own Babel setup according to their project needs and setup. If you need a custom Babel configuration, you can create a `.babelrc` file yourself and configure it according to your project setup. The reasoning behind is to condense and provide some clarity to what's happened to both the command and what's shifted with the upcoming release. #### Changed interfaces for `@storybook/router` components The `hideOnly` prop has been removed from the `` component in `@storybook/router`. If needed this can be implemented manually with the `` component. #### Extract no longer batches `Preview.extract()` no longer loads CSF files in batches. This was a workaround for resource limitations that slowed down extract. This shouldn't affect behaviour. ### Framework-specific changes #### React ##### `react-docgen` component analysis by default In Storybook 7, we used `react-docgen-typescript` to analyze React component props and auto-generate controls. In Storybook 8, we have moved to `react-docgen` as the new default. `react-docgen` is dramatically more efficient, shaving seconds off of dev startup times. However, it only analyzes basic TypeScript constructs. We feel `react-docgen` is the right tradeoff for most React projects. However, if you need the full fidelity of `react-docgen-typescript`, you can opt-in using the following setting in `.storybook/main.js`: ```js export default { typescript: { reactDocgen: "react-docgen-typescript", }, }; ``` For more information see: https://storybook.js.org/docs/react/api/main-config-typescript#reactdocgen #### Next.js ##### Require Next.js 13.5 and up Starting in 8.0, Storybook requires Next.js 13.5 and up. ##### Automatic SWC mode detection Similar to how Next.js detects if SWC should be used, Storybook will follow more or less the same rules: - If you use Next.js 14 or higher and you don't have a .babelrc file, Storybook will use SWC to transpile your code. - Even if you have a .babelrc file, Storybook will still use SWC to transpile your code if you set the experimental `experimental.forceSwcTransforms` flag to `true` in your `next.config.js`. ##### RSC config moved to React renderer Storybook 7.6 introduced a new feature flag, `experimentalNextRSC`, to enable React Server Components in a Next.js project. It also introduced a parameter `nextjs.rsc` to selectively disable it on particular components or stories. These flags have been renamed to `experimentalRSC` and `react.rsc`, respectively. This is a breaking change to accommodate RSC support in other, non-Next.js frameworks. For now, `@storybook/nextjs` is the only framework that supports it, and does so experimentally. #### Vue ##### Require Vue 3 and up Starting in 8.0, Storybook requires Vue 3 and up. #### Angular ##### Require Angular 15 and up Starting in 8.0, Storybook requires Angular 15 and up. #### Svelte ##### Require Svelte 4 and up Starting in 8.0, Storybook requires Svelte 4 and up. #### Preact ##### Require Preact 10 and up Starting in 8.0, Storybook requires Preact 10 and up. ##### No longer adds default Babel plugins Until now, Storybook provided a set of default Babel plugins that were applied to Preact projects using Webpack, including the runtime automatic import plugin to allow Preact's `h` pragma to render JSX. However, this is no longer the case in Storybook 8.0. If you want to use this plugin, or if you're going to use TypeScript with Preact, you will need to add it to your Babel config. ```js .babelrc { "plugins": [ [ // Add this to automatically import `h` from `preact` when needed "@babel/plugin-transform-react-jsx", { "importSource": "preact", "runtime": "automatic" } ], // Add this if you want to use TypeScript with Preact "@babel/preset-typescript" ], } ``` If you want to configure the plugins only for Storybook, you can add the same setting to your `.storybook/main.js` file. ```js const config = { ... babel: async (options) => { options.plugins.push( [ "@babel/plugin-transform-react-jsx", { "importSource": "preact", "runtime": "automatic" } ], "@babel/preset-typescript" ) return options; }, } export default config ``` We are doing this to apply the same configuration you defined in your project. This streamlines the experience of using Storybook with Preact. Additionally, we are not vendor-locked to a specific Babel version anymore, which means that you can upgrade Babel without breaking your Storybook. #### Web Components ##### Dropping default babel plugins in Webpack5-based projects Until the 8.0 release, Storybook provided the `@babel/preset-env` preset for Web Component projects by default. This is no longer the case, as any Web Components project will use the configuration you've included. Additionally, if you're using either the `@babel/plugin-syntax-dynamic-import` or `@babel/plugin-syntax-import-meta` plugins, you no longer have to include them as they are now part of `@babel/preset-env`. ### Deprecations which are now removed #### Removed `config` preset In Storybook 7.0 we have deprecated the preset field `config` and it has been replaced with 'previewAnnotations'. The `config` preset is now completely removed in Storybook 8.0. ```diff // .storybook/main.js // before const config = { framework: "@storybook/your-framework", - config: (entries) => [...entries, yourEntry], + previewAnnotations: (entries) => [...entries, yourEntry], }; export default config; ``` #### Removed `passArgsFirst` option Since Storybook 6, we have had an option called `parameters.passArgsFirst` (default=`true`), which sallows you to pass the context to the story function first when set to `false.` We have removed this option. In Storybook 8.0, the args are always passed first, and as a second argument, the context is passed. ```js // Storybook < 8 export default { parameters: { passArgsFirst: false, }, }; export const Button = (context) =>