mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-05 08:01:20 +08:00
Merge branch 'next' into test-polish
This commit is contained in:
commit
82bd173418
@ -878,10 +878,11 @@ workflows:
|
||||
parallelism: 4
|
||||
requires:
|
||||
- create-sandboxes
|
||||
- bench-sandboxes:
|
||||
parallelism: 5
|
||||
requires:
|
||||
- create-sandboxes
|
||||
# TODO: don't forget to reenable this
|
||||
# - bench-sandboxes:
|
||||
# parallelism: 5
|
||||
# requires:
|
||||
# - create-sandboxes
|
||||
- test-ui-testing-module:
|
||||
requires:
|
||||
- build
|
||||
@ -965,10 +966,11 @@ workflows:
|
||||
- test-init-features:
|
||||
requires:
|
||||
- build
|
||||
- bench-sandboxes:
|
||||
parallelism: 5
|
||||
requires:
|
||||
- create-sandboxes
|
||||
# TODO: don't forget to reenable this
|
||||
# - bench-sandboxes:
|
||||
# parallelism: 5
|
||||
# requires:
|
||||
# - create-sandboxes
|
||||
# TODO: reenable once we find out the source of flakyness
|
||||
# - test-runner-dev:
|
||||
# parallelism: 4
|
||||
@ -1059,10 +1061,11 @@ workflows:
|
||||
# --smoke-test is not supported for the angular builder right now
|
||||
# - "angular-cli"
|
||||
- "lit-vite-ts"
|
||||
- bench-sandboxes:
|
||||
parallelism: 5
|
||||
requires:
|
||||
- create-sandboxes
|
||||
# TODO: don't forget to reenable this
|
||||
# - bench-sandboxes:
|
||||
# parallelism: 5
|
||||
# requires:
|
||||
# - create-sandboxes
|
||||
|
||||
# TODO: reenable once we find out the source of flakyness
|
||||
# - test-runner-dev:
|
||||
|
@ -1,3 +1,8 @@
|
||||
## 8.6.4
|
||||
|
||||
- Manager: Add Content-Type to fix Cloud IDEs - [#30606](https://github.com/storybookjs/storybook/pull/30606), thanks @GCHQDeveloper548!
|
||||
- Vite: Include `node_modules` in stats file - [#30711](https://github.com/storybookjs/storybook/pull/30711), thanks @JReinhold!
|
||||
|
||||
## 8.6.3
|
||||
|
||||
- CSF Factories: Align addon-essentials import with other addons - [#30716](https://github.com/storybookjs/storybook/pull/30716), thanks @kasperpeulen!
|
||||
@ -37,7 +42,6 @@ Here’s what’s new:
|
||||
- Addon-Test: Add telemetry data for Focused Tests - [#30568](https://github.com/storybookjs/storybook/pull/30568), thanks @JReinhold!
|
||||
- Addon-Test: Fix config and watch mode inconsistencies - [#30491](https://github.com/storybookjs/storybook/pull/30491), thanks @JReinhold!
|
||||
- Addon-Test: Fix console error in build mode - [#30625](https://github.com/storybookjs/storybook/pull/30625), thanks @JReinhold!
|
||||
- Addon Test: Fix printing Date object in MethodCall for test/interactions log - [#30507](https://github.com/storybookjs/storybook/pull/30507), thanks @ghengeveld!
|
||||
- Addon-Test: Make sure that only one global portable story config is ever loaded - [#30582](https://github.com/storybookjs/storybook/pull/30582), thanks @kasperpeulen!
|
||||
- Angular: Fix accent character issue - [#30276](https://github.com/storybookjs/storybook/pull/30276), thanks @valentinpalkovic!
|
||||
- Angular: Support experimental zoneless mode - [#28657](https://github.com/storybookjs/storybook/pull/28657), thanks @anedomansky!
|
||||
@ -46,7 +50,6 @@ Here’s what’s new:
|
||||
- Builder-Vite: Fix runtime and iframe 404 on first load - [#30567](https://github.com/storybookjs/storybook/pull/30567), thanks @valentinpalkovic!
|
||||
- Bun: Add support for text lock file - [#30160](https://github.com/storybookjs/storybook/pull/30160), thanks @Arctomachine!
|
||||
- Cleanup: Remove unused constants in viewport addon - [#30479](https://github.com/storybookjs/storybook/pull/30479), thanks @Guria!
|
||||
- CLI: Add "features" question & auto-install test addon & improve test-addon compatibility - [#30202](https://github.com/storybookjs/storybook/pull/30202), thanks @ndelangen!
|
||||
- CLI: Don't initially select Documentation and Testing features - [#30599](https://github.com/storybookjs/storybook/pull/30599), thanks @ghengeveld!
|
||||
- CLI: Fix peer dep issues for npm users during upgrade - [#30616](https://github.com/storybookjs/storybook/pull/30616), thanks @valentinpalkovic!
|
||||
- CLI: Fix printing of selected features - [#30605](https://github.com/storybookjs/storybook/pull/30605), thanks @ghengeveld!
|
||||
|
@ -1,3 +1,46 @@
|
||||
## 9.0.0-alpha.3
|
||||
|
||||
- Addon A11y: Promote @storybook/global to full dependency - [#30723](https://github.com/storybookjs/storybook/pull/30723), thanks @mrginglymus!
|
||||
- Addon Test: Improve unhandled error messages - [#30755](https://github.com/storybookjs/storybook/pull/30755), thanks @yannbf!
|
||||
- Angular: Add @angular-devkit/build-angular to default installed pacakages in angular - [#30790](https://github.com/storybookjs/storybook/pull/30790), thanks @kasperpeulen!
|
||||
- Automigrate: Disable `missingStorybookDependencies` for 9.0 - [#30769](https://github.com/storybookjs/storybook/pull/30769), thanks @ndelangen!
|
||||
- CLI: Fix test install in RNW projects - [#30786](https://github.com/storybookjs/storybook/pull/30786), thanks @shilman!
|
||||
- Core: Re-Export renderers from frameworks - [#30771](https://github.com/storybookjs/storybook/pull/30771), thanks @ndelangen!
|
||||
- Core: Replace 'min' instead of 'm' in printDuration - [#30668](https://github.com/storybookjs/storybook/pull/30668), thanks @wlewis-formative!
|
||||
- Migration: Add auto-automigration for merged packages - [#30753](https://github.com/storybookjs/storybook/pull/30753), thanks @ndelangen!
|
||||
- Next.js: Upgrade image-size to 2.0 - [#30741](https://github.com/storybookjs/storybook/pull/30741), thanks @valentinpalkovic!
|
||||
- Next.js: Use latest version when init in empty directory - [#30659](https://github.com/storybookjs/storybook/pull/30659), thanks @valentinpalkovic!
|
||||
- Svelte: Fix Vite crashing on virtual module imports - [#26838](https://github.com/storybookjs/storybook/pull/26838), thanks @rChaoz!
|
||||
- Svelte: Fix automatic argTypes inference coming up empty with `svelte2tsx@0.7.35` - [#30784](https://github.com/storybookjs/storybook/pull/30784), thanks @JReinhold!
|
||||
- Svelte: Pin svelte2tsx to solve argType regression - [#30783](https://github.com/storybookjs/storybook/pull/30783), thanks @kasperpeulen!
|
||||
- Test: Move `@storybook/test` into `storybook/test` - [#30742](https://github.com/storybookjs/storybook/pull/30742), thanks @valentinpalkovic!
|
||||
- Universal Store: Don't use `crypto.randomUUID` - [#30781](https://github.com/storybookjs/storybook/pull/30781), thanks @JReinhold!
|
||||
|
||||
## 9.0.0-alpha.2
|
||||
|
||||
- AutoBlocker: Add major version upgrade blocker - [#30714](https://github.com/storybookjs/storybook/pull/30714), thanks @ndelangen!
|
||||
- CLI: Add index command / API - [#30071](https://github.com/storybookjs/storybook/pull/30071), thanks @shilman!
|
||||
- CSF Factories: Align addon-essentials import with other addons - [#30716](https://github.com/storybookjs/storybook/pull/30716), thanks @kasperpeulen!
|
||||
- Core: Move @storybook/instrumenter into core - [#30740](https://github.com/storybookjs/storybook/pull/30740), thanks @valentinpalkovic!
|
||||
- Core: Support TS3.8+ again - [#30700](https://github.com/storybookjs/storybook/pull/30700), thanks @kasperpeulen!
|
||||
- Maintenance: Merge `@storybook/core` with `storybook` - [#30168](https://github.com/storybookjs/storybook/pull/30168), thanks @ndelangen!
|
||||
- Maintenance: Remove deprecated packages - [#30690](https://github.com/storybookjs/storybook/pull/30690), thanks @ndelangen!
|
||||
- Manager: Add Content-Type to prevent reliance on content type sniffing, fixing Cloud IDEs - [#30606](https://github.com/storybookjs/storybook/pull/30606), thanks @GCHQDeveloper548!
|
||||
- Next: Support Next 15.2 - [#30702](https://github.com/storybookjs/storybook/pull/30702), thanks @kasperpeulen!
|
||||
- React: Export returntype of ReactMeta#story - [#30580](https://github.com/storybookjs/storybook/pull/30580), thanks @mrginglymus!
|
||||
- Revert "CLI: Don't initially select Documentation and Testing features" - [#30694](https://github.com/storybookjs/storybook/pull/30694), thanks @shilman!
|
||||
- Test Addon: Stabilize and remove experimental status - [#30727](https://github.com/storybookjs/storybook/pull/30727), thanks @valentinpalkovic!
|
||||
- Typescript: Drop Typescript < 4.9 support - [#30736](https://github.com/storybookjs/storybook/pull/30736), thanks @valentinpalkovic!
|
||||
- Vite: Improve handling of preview annotations - [#28798](https://github.com/storybookjs/storybook/pull/28798), thanks @tobiasdiez!
|
||||
- Vite: Include `node_modules` in stats file - [#30711](https://github.com/storybookjs/storybook/pull/30711), thanks @JReinhold!
|
||||
|
||||
## 9.0.0-alpha.1
|
||||
|
||||
- CLI: Install prereleases of `@chromatic-com/storybook` - [#30662](https://github.com/storybookjs/storybook/pull/30662), thanks @JReinhold!
|
||||
- CSF: Only export definePreview from the framework - [#30676](https://github.com/storybookjs/storybook/pull/30676), thanks @kasperpeulen!
|
||||
- Codemod: Only remove types when they are unused - [#30644](https://github.com/storybookjs/storybook/pull/30644), thanks @yannbf!
|
||||
- Dependencies: Upgrades - [#30515](https://github.com/storybookjs/storybook/pull/30515), thanks @ndelangen!
|
||||
|
||||
## 9.0.0-alpha.0
|
||||
|
||||
## 8.6.0-beta.10
|
||||
|
40
MIGRATION.md
40
MIGRATION.md
@ -1,6 +1,7 @@
|
||||
<h1>Migration</h1>
|
||||
|
||||
- [From version 8.x to 9.0.0](#from-version-8x-to-900)
|
||||
- [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)
|
||||
- [From version 8.5.x to 8.6.x](#from-version-85x-to-86x)
|
||||
@ -436,6 +437,45 @@
|
||||
|
||||
## From version 8.x to 9.0.0
|
||||
|
||||
### 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 |
|
||||
|
||||
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.
|
||||
|
@ -1,6 +1,6 @@
|
||||
import React from 'react';
|
||||
|
||||
import type { Meta } from '@storybook/react';
|
||||
import type { Meta } from '@storybook/react-vite';
|
||||
|
||||
// @ts-expect-error - TS doesn't know about import.meta.glob from Vite
|
||||
const allMetafiles = import.meta.glob([
|
||||
|
@ -16,8 +16,8 @@ import {
|
||||
|
||||
import { DocsContext } from '@storybook/blocks';
|
||||
import { global } from '@storybook/global';
|
||||
import type { Decorator, Loader, ReactRenderer } from '@storybook/react';
|
||||
|
||||
import type { Decorator, Loader, ReactRenderer } from '@storybook/react-vite';
|
||||
// TODO add empty preview
|
||||
// import * as storysource from '@storybook/addon-storysource';
|
||||
// import * as designs from '@storybook/addon-designs/preview';
|
||||
|
@ -1,7 +1,8 @@
|
||||
import { beforeAll, vi, expect as vitestExpect } from 'vitest';
|
||||
|
||||
import { setProjectAnnotations } from '@storybook/react';
|
||||
import { userEvent as storybookEvent, expect as storybookExpect } from '@storybook/test';
|
||||
|
||||
import { userEvent as storybookEvent, expect as storybookExpect } from 'storybook/test';
|
||||
|
||||
import preview from './preview';
|
||||
|
||||
|
@ -1,5 +1,7 @@
|
||||
import { defaultExclude, defineProject, mergeConfig } from 'vitest/config';
|
||||
|
||||
import { storybookTest } from '@storybook/addon-test/vitest-plugin';
|
||||
|
||||
import Inspect from 'vite-plugin-inspect';
|
||||
|
||||
import { vitestCommonConfig } from '../vitest.workspace';
|
||||
@ -22,14 +24,12 @@ export default mergeConfig(
|
||||
// @ts-expect-error added this because of testNamePattern below
|
||||
defineProject({
|
||||
plugins: [
|
||||
import('@storybook/addon-test/vitest-plugin').then(({ storybookTest }) =>
|
||||
storybookTest({
|
||||
configDir: __dirname,
|
||||
tags: {
|
||||
include: ['vitest'],
|
||||
},
|
||||
})
|
||||
),
|
||||
storybookTest({
|
||||
configDir: __dirname,
|
||||
tags: {
|
||||
include: ['vitest'],
|
||||
},
|
||||
}),
|
||||
...extraPlugins,
|
||||
],
|
||||
test: {
|
||||
@ -40,7 +40,7 @@ export default mergeConfig(
|
||||
'**/__mockdata__/**',
|
||||
'../**/__mockdata__/**',
|
||||
'**/Zoom.stories.tsx', // expected to fail in Vitest because of fetching /iframe.html to cause ECONNREFUSED
|
||||
'**/lib/blocks/src/**', // won't work because of https://github.com/storybookjs/storybook/issues/29783
|
||||
'../lib/blocks/src/**', // won't work because of https://github.com/storybookjs/storybook/issues/29783
|
||||
],
|
||||
// TODO: bring this back once portable stories support storybook/internal/preview-api hooks
|
||||
// @ts-expect-error this type does not exist but the property does!
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-a11y",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Test component compliance with web accessibility standards",
|
||||
"keywords": [
|
||||
"a11y",
|
||||
@ -67,11 +67,10 @@
|
||||
},
|
||||
"dependencies": {
|
||||
"@storybook/addon-highlight": "workspace:*",
|
||||
"@storybook/test": "workspace:*",
|
||||
"@storybook/global": "^5.0.0",
|
||||
"axe-core": "^4.2.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@storybook/global": "^5.0.0",
|
||||
"@storybook/icons": "^1.4.0",
|
||||
"@testing-library/react": "^14.0.0",
|
||||
"execa": "^9.5.2",
|
||||
|
@ -3,10 +3,10 @@ import React from 'react';
|
||||
import { ManagerContext } from 'storybook/internal/manager-api';
|
||||
import { ThemeProvider, convert, themes } from 'storybook/internal/theming';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { fn } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import type axe from 'axe-core';
|
||||
import { fn } from 'storybook/test';
|
||||
|
||||
import { A11YPanel } from './A11YPanel';
|
||||
import { A11yContext } from './A11yContext';
|
||||
|
@ -2,8 +2,9 @@ import React from 'react';
|
||||
|
||||
import { ManagerContext } from 'storybook/internal/manager-api';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { fn } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { fn } from 'storybook/test';
|
||||
|
||||
import { TestDiscrepancyMessage } from './TestDiscrepancyMessage';
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
import type { AfterEach } from 'storybook/internal/types';
|
||||
|
||||
import { expect } from '@storybook/test';
|
||||
import { expect } from 'storybook/test';
|
||||
|
||||
import { run } from './a11yRunner';
|
||||
import type { A11yParameters } from './params';
|
||||
@ -64,7 +64,7 @@ export const experimental_afterEach: AfterEach<any> = async ({
|
||||
vitestMatchersExtended = true;
|
||||
}
|
||||
|
||||
// @ts-expect-error - todo - fix type extension of expect from @storybook/test
|
||||
// @ts-expect-error - todo - fix type extension of expect from storybook/test
|
||||
expect(result).toHaveNoViolations();
|
||||
}
|
||||
}
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-actions",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Get UI feedback when an action is performed on an interactive element",
|
||||
"keywords": [
|
||||
"storybook",
|
||||
@ -74,7 +74,6 @@
|
||||
"uuid": "^9.0.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@storybook/test": "workspace:*",
|
||||
"react": "^18.2.0",
|
||||
"react-dom": "^18.2.0",
|
||||
"react-inspector": "^6.0.0",
|
||||
|
@ -2,7 +2,8 @@
|
||||
import type { LoaderFunction } from 'storybook/internal/types';
|
||||
|
||||
import { global } from '@storybook/global';
|
||||
import type { onMockCall as onMockCallType } from '@storybook/test';
|
||||
|
||||
import type { onMockCall as onMockCallType } from 'storybook/test';
|
||||
|
||||
import { action } from './runtime';
|
||||
|
||||
|
@ -1,5 +1,6 @@
|
||||
import { global as globalThis } from '@storybook/global';
|
||||
import { spyOn } from '@storybook/test';
|
||||
|
||||
import { spyOn } from 'storybook/test';
|
||||
|
||||
const meta = {
|
||||
component: globalThis.Components.Button,
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-backgrounds",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Switch backgrounds to view components in different settings",
|
||||
"keywords": [
|
||||
"addon",
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-controls",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Interact with component inputs dynamically in the Storybook UI",
|
||||
"keywords": [
|
||||
"addon",
|
||||
|
@ -1,10 +1,11 @@
|
||||
import React from 'react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { expect, fireEvent, fn, userEvent, within } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { action } from '@storybook/addon-actions';
|
||||
|
||||
import { expect, fireEvent, fn, userEvent, within } from 'storybook/test';
|
||||
|
||||
import { SaveStory } from './SaveStory';
|
||||
|
||||
const meta = {
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-docs",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Document component usage and properties in Markdown",
|
||||
"keywords": [
|
||||
"addon",
|
||||
|
@ -2,7 +2,7 @@ import * as ReactExport from 'react';
|
||||
import * as ReactDom from 'react-dom';
|
||||
import * as ReactDomServer from 'react-dom/server';
|
||||
|
||||
import { expect, within } from '@storybook/test';
|
||||
import { expect, within } from 'storybook/test';
|
||||
|
||||
/**
|
||||
* This component is used to display the resolved version of React and its related packages. As long
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { expect, within } from '@storybook/test';
|
||||
import { expect, within } from 'storybook/test';
|
||||
|
||||
export default {
|
||||
component: globalThis.Components.Pre,
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { fn } from '@storybook/test';
|
||||
import { fn } from 'storybook/test';
|
||||
|
||||
export default {
|
||||
component: globalThis.Components.Button,
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-essentials",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Curated addons to bring out the best of Storybook",
|
||||
"keywords": [
|
||||
"addon",
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-mdx-gfm",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "GitHub Flavored Markdown in Storybook",
|
||||
"keywords": [
|
||||
"addon",
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-highlight",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Highlight DOM nodes within your stories",
|
||||
"keywords": [
|
||||
"storybook-addons",
|
||||
|
@ -9,7 +9,7 @@ Storybook Addon Interactions enables visual debugging of interactions and tests
|
||||
Install this addon by adding the `@storybook/addon-interactions` dependency:
|
||||
|
||||
```sh
|
||||
yarn add -D @storybook/addon-interactions @storybook/test
|
||||
yarn add -D @storybook/addon-interactions
|
||||
```
|
||||
|
||||
within `.storybook/main.js`:
|
||||
@ -24,10 +24,10 @@ Note that `@storybook/addon-interactions` must be listed **after** `@storybook/a
|
||||
|
||||
## Usage
|
||||
|
||||
Interactions relies on "instrumented" versions of Vitest and Testing Library, that you import from `@storybook/test` instead of their original package. You can then use these libraries in your `play` function.
|
||||
Interactions relies on "instrumented" versions of Vitest and Testing Library, that you import from `storybook/test` instead of their original package. You can then use these libraries in your `play` function.
|
||||
|
||||
```js
|
||||
import { expect, fn, userEvent, within } from '@storybook/test';
|
||||
import { expect, fn, userEvent, within } from 'storybook/test';
|
||||
import { Button } from './Button';
|
||||
|
||||
export default {
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-interactions",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Automate, test and debug user interactions",
|
||||
"keywords": [
|
||||
"storybook-addons",
|
||||
@ -63,7 +63,6 @@
|
||||
},
|
||||
"dependencies": {
|
||||
"@storybook/global": "^5.0.0",
|
||||
"@storybook/test": "workspace:*",
|
||||
"polished": "^4.2.2",
|
||||
"ts-dedent": "^2.2.0"
|
||||
},
|
||||
|
@ -1,7 +1,8 @@
|
||||
import { CallStates } from 'storybook/internal/instrumenter';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { expect, userEvent, within } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { expect, userEvent, within } from 'storybook/test';
|
||||
|
||||
import { getCalls } from '../mocks';
|
||||
import { Interaction } from './Interaction';
|
||||
|
@ -3,8 +3,9 @@ import React from 'react';
|
||||
import { CallStates } from 'storybook/internal/instrumenter';
|
||||
import { styled } from 'storybook/internal/theming';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { expect, userEvent, waitFor, within } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { expect, userEvent, waitFor, within } from 'storybook/test';
|
||||
|
||||
import { isChromatic } from '../../../../.storybook/isChromatic';
|
||||
import { getCalls, getInteractions } from '../mocks';
|
||||
|
@ -3,7 +3,7 @@ import type { PlayFunction, StepLabel, StepRunner, StoryContext } from 'storyboo
|
||||
|
||||
// This makes sure that storybook test loaders are always loaded when addon-interactions is used
|
||||
// For 9.0 we want to merge storybook/test and addon-interactions into one addon.
|
||||
import '@storybook/test';
|
||||
import 'storybook/test';
|
||||
|
||||
import type { InteractionsParameters } from './types';
|
||||
|
||||
|
@ -1,4 +1,5 @@
|
||||
import { global as globalThis } from '@storybook/global';
|
||||
|
||||
import {
|
||||
expect,
|
||||
fireEvent,
|
||||
@ -7,7 +8,7 @@ import {
|
||||
waitFor,
|
||||
waitForElementToBeRemoved,
|
||||
within,
|
||||
} from '@storybook/test';
|
||||
} from 'storybook/test';
|
||||
|
||||
export default {
|
||||
component: globalThis.Components.Form,
|
||||
|
@ -1,5 +1,6 @@
|
||||
import { global as globalThis } from '@storybook/global';
|
||||
import { userEvent, within } from '@storybook/test';
|
||||
|
||||
import { userEvent, within } from 'storybook/test';
|
||||
|
||||
export default {
|
||||
component: globalThis.Components.Button,
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-jest",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "React storybook addon that show component jest report",
|
||||
"keywords": [
|
||||
"addon",
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-links",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Link stories together to build demos and prototypes with your UI components",
|
||||
"keywords": [
|
||||
"storybook-addons",
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-measure",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Inspect layouts by visualizing the box model",
|
||||
"keywords": [
|
||||
"storybook-addons",
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-onboarding",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Storybook Addon Onboarding - Introduces a new onboarding experience",
|
||||
"keywords": [
|
||||
"storybook-addons",
|
||||
@ -48,7 +48,6 @@
|
||||
"@neoconfetti/react": "^1.0.0",
|
||||
"@radix-ui/react-dialog": "^1.0.5",
|
||||
"@storybook/icons": "^1.4.0",
|
||||
"@storybook/react": "workspace:*",
|
||||
"framer-motion": "^11.0.3",
|
||||
"react": "^18.2.0",
|
||||
"react-dom": "^18.2.0",
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { Button } from './Button';
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
import React from 'react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { Confetti } from './Confetti';
|
||||
|
||||
|
@ -1,7 +1,8 @@
|
||||
import React from 'react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { expect, waitFor, within } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { expect, waitFor, within } from 'storybook/test';
|
||||
|
||||
import { HighlightElement } from './HighlightElement';
|
||||
|
||||
|
@ -1,7 +1,8 @@
|
||||
import React, { useState } from 'react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { expect, userEvent, waitFor, within } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { expect, userEvent, waitFor, within } from 'storybook/test';
|
||||
|
||||
import { List } from './List';
|
||||
import { ListItem } from './ListItem/ListItem';
|
||||
|
@ -1,5 +1,6 @@
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { fn } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { fn } from 'storybook/test';
|
||||
|
||||
import { GuidedTour } from './GuidedTour';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { SplashScreen } from './SplashScreen';
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-outline",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Outline all elements with CSS to help with layout placement and alignment",
|
||||
"keywords": [
|
||||
"storybook-addons",
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-storysource",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "View a story’s source code to see how it works and paste into your app",
|
||||
"keywords": [
|
||||
"addon",
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-test",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Storybook addon for testing components",
|
||||
"keywords": [
|
||||
"storybook-addons",
|
||||
@ -100,7 +100,6 @@
|
||||
"dependencies": {
|
||||
"@storybook/global": "^5.0.0",
|
||||
"@storybook/icons": "^1.4.0",
|
||||
"@storybook/test": "workspace:*",
|
||||
"polished": "^4.2.2",
|
||||
"prompts": "^2.4.0",
|
||||
"ts-dedent": "^2.2.0"
|
||||
@ -110,8 +109,8 @@
|
||||
"@types/istanbul-lib-report": "^3.0.3",
|
||||
"@types/node": "^22.0.0",
|
||||
"@types/semver": "^7",
|
||||
"@vitest/browser": "^3.0.2",
|
||||
"@vitest/runner": "^3.0.2",
|
||||
"@vitest/browser": "^3.0.8",
|
||||
"@vitest/runner": "^3.0.8",
|
||||
"ansi-to-html": "^0.7.2",
|
||||
"boxen": "^8.0.1",
|
||||
"es-toolkit": "^1.22.0",
|
||||
@ -131,7 +130,7 @@
|
||||
"tree-kill": "^1.2.2",
|
||||
"ts-dedent": "^2.2.0",
|
||||
"typescript": "^5.7.3",
|
||||
"vitest": "^3.0.2"
|
||||
"vitest": "^3.0.8"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"@vitest/browser": "^2.1.1 || ^3.0.0",
|
||||
|
@ -2,9 +2,9 @@ import React, { useState } from 'react';
|
||||
|
||||
import { ManagerContext } from 'storybook/internal/manager-api';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { expect, fn, userEvent, within } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { expect, fn, userEvent, within } from 'storybook/test';
|
||||
import dedent from 'ts-dedent';
|
||||
|
||||
import { GlobalErrorContext, GlobalErrorModal } from './GlobalErrorModal';
|
||||
|
@ -1,7 +1,8 @@
|
||||
import { CallStates } from 'storybook/internal/instrumenter';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { expect, userEvent, within } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { expect, userEvent, within } from 'storybook/test';
|
||||
|
||||
import { getCalls } from '../mocks';
|
||||
import { Interaction } from './Interaction';
|
||||
|
@ -4,8 +4,9 @@ import { CallStates } from 'storybook/internal/instrumenter';
|
||||
import { ManagerContext } from 'storybook/internal/manager-api';
|
||||
import { styled } from 'storybook/internal/theming';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { expect, fn, userEvent, waitFor, within } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { expect, fn, userEvent, waitFor, within } from 'storybook/test';
|
||||
|
||||
import { isChromatic } from '../../../../.storybook/isChromatic';
|
||||
import { getCalls, getInteractions } from '../mocks';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { RelativeTime } from './RelativeTime';
|
||||
|
||||
|
@ -3,8 +3,9 @@ import React from 'react';
|
||||
import { CallStates } from 'storybook/internal/instrumenter';
|
||||
import { ManagerContext } from 'storybook/internal/manager-api';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { fn } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { fn } from 'storybook/test';
|
||||
|
||||
import { TestDiscrepancyMessage } from './TestDiscrepancyMessage';
|
||||
|
||||
|
@ -5,8 +5,9 @@ import { ManagerContext, addons } from 'storybook/internal/manager-api';
|
||||
import { styled } from 'storybook/internal/theming';
|
||||
import { Addon_TypesEnum } from 'storybook/internal/types';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { expect, fn, userEvent } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { expect, fn, userEvent } from 'storybook/test';
|
||||
|
||||
import { ADDON_ID as A11Y_ADDON_ID } from '../../../a11y/src/constants';
|
||||
import { type Details, storeOptions } from '../constants';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { TestStatusIcon } from './TestStatusIcon';
|
||||
|
||||
|
@ -1,16 +1,7 @@
|
||||
import { definePreview } from 'storybook/internal/preview-api';
|
||||
|
||||
import * as addonAnnotations from './preview';
|
||||
import type { storybookTest as storybookTestImport } from './vitest-plugin';
|
||||
|
||||
export default () => definePreview(addonAnnotations);
|
||||
|
||||
export type { TestParameters } from './types';
|
||||
|
||||
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
||||
// @ts-ignore-error - this is a hack to make the module's sub-path augmentable
|
||||
declare module '@storybook/addon-test/vitest-plugin' {
|
||||
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
||||
// @ts-ignore-error - this is a hack to make the module's sub-path augmentable
|
||||
export const storybookTest: typeof storybookTestImport;
|
||||
}
|
||||
|
@ -1,6 +1,6 @@
|
||||
import { experimental_MockUniversalStore } from 'storybook/internal/manager-api';
|
||||
|
||||
import * as testUtils from '@storybook/test';
|
||||
import * as testUtils from 'storybook/test';
|
||||
|
||||
import { storeOptions } from './constants';
|
||||
|
||||
|
@ -13,6 +13,7 @@ import type { API_StatusUpdate } from 'storybook/internal/types';
|
||||
import type { Suite } from '@vitest/runner';
|
||||
import { throttle } from 'es-toolkit';
|
||||
import { satisfies } from 'semver';
|
||||
import { dedent } from 'ts-dedent';
|
||||
|
||||
import { TEST_PROVIDER_ID } from '../constants';
|
||||
import type { TestManager } from './test-manager';
|
||||
@ -60,6 +61,36 @@ const isVitest3OrLater = vitestVersion
|
||||
? satisfies(vitestVersion, '>=3.0.0-beta.3', { includePrerelease: true })
|
||||
: false;
|
||||
|
||||
interface VitestError extends Error {
|
||||
VITEST_TEST_PATH?: string;
|
||||
VITEST_TEST_NAME?: string;
|
||||
}
|
||||
|
||||
const getErrorOrigin = (error: VitestError): string => {
|
||||
const parts: string[] = [];
|
||||
|
||||
if (error.VITEST_TEST_PATH) {
|
||||
parts.push(
|
||||
dedent`
|
||||
\nThis error originated in "${error.VITEST_TEST_PATH}". It doesn't mean the error was thrown inside the file itself, but while it was running.
|
||||
`
|
||||
);
|
||||
}
|
||||
|
||||
if (error.VITEST_TEST_NAME) {
|
||||
parts.push(
|
||||
dedent`
|
||||
The latest test that might've caused the error is "${error.VITEST_TEST_NAME}".
|
||||
It might mean one of the following:
|
||||
- The error was thrown, while Vitest was running this test.
|
||||
- If the error occurred after the test had been completed, this was the last documented test before it was thrown.
|
||||
`
|
||||
);
|
||||
}
|
||||
|
||||
return parts.join('\n');
|
||||
};
|
||||
|
||||
export class StorybookReporter implements Reporter {
|
||||
testStatusData: API_StatusUpdate = {};
|
||||
|
||||
@ -219,6 +250,14 @@ export class StorybookReporter implements Reporter {
|
||||
|
||||
async onFinished() {
|
||||
const unhandledErrors = this.ctx.state.getUnhandledErrors();
|
||||
unhandledErrors.forEach((e: unknown) => {
|
||||
const error = e as VitestError;
|
||||
const origin = getErrorOrigin(error);
|
||||
if (origin) {
|
||||
error.message = `${error.message}\n${origin}`;
|
||||
error.stack = `${error.stack}\n${origin}`;
|
||||
}
|
||||
});
|
||||
|
||||
const isCancelled = isVitest3OrLater
|
||||
? this.testManager.vitestManager.isCancelling
|
||||
@ -256,7 +295,7 @@ export class StorybookReporter implements Reporter {
|
||||
name: `${unhandledErrors.length} unhandled error${unhandledErrors?.length > 1 ? 's' : ''}`,
|
||||
message: unhandledErrors
|
||||
.map((e, index) => `[${index}]: ${(e as any).stack || (e as any).message}`)
|
||||
.join('\n----------\n'),
|
||||
.join('\n\n----------\n\n'),
|
||||
};
|
||||
|
||||
this.sendReport({
|
||||
|
@ -3,7 +3,7 @@ import type { PlayFunction, StepLabel, StoryContext } from 'storybook/internal/t
|
||||
|
||||
// This makes sure that storybook test loaders are always loaded when addon-interactions is used
|
||||
// For 9.0 we want to merge storybook/test and addon-interactions into one addon.
|
||||
import '@storybook/test';
|
||||
import 'storybook/test';
|
||||
|
||||
export const { step: runStep } = instrument(
|
||||
{
|
||||
|
@ -1,4 +1,5 @@
|
||||
import { global as globalThis } from '@storybook/global';
|
||||
|
||||
import {
|
||||
expect,
|
||||
fireEvent,
|
||||
@ -7,7 +8,7 @@ import {
|
||||
waitFor,
|
||||
waitForElementToBeRemoved,
|
||||
within,
|
||||
} from '@storybook/test';
|
||||
} from 'storybook/test';
|
||||
|
||||
export default {
|
||||
component: globalThis.Components.Form,
|
||||
|
@ -1,5 +1,6 @@
|
||||
import { global as globalThis } from '@storybook/global';
|
||||
import { userEvent, within } from '@storybook/test';
|
||||
|
||||
import { userEvent, within } from 'storybook/test';
|
||||
|
||||
export default {
|
||||
component: globalThis.Components.Button,
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-themes",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Switch between multiple themes for you components in Storybook",
|
||||
"keywords": [
|
||||
"css",
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-toolbars",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Create your own toolbar items that control story rendering",
|
||||
"keywords": [
|
||||
"addon",
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/addon-viewport",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Build responsive components by adjusting Storybook’s viewport size and orientation",
|
||||
"keywords": [
|
||||
"addon",
|
||||
|
@ -1,8 +1,9 @@
|
||||
import { global as globalThis } from '@storybook/global';
|
||||
import { expect } from '@storybook/test';
|
||||
|
||||
import { MINIMAL_VIEWPORTS } from '@storybook/addon-viewport';
|
||||
|
||||
import { expect } from 'storybook/test';
|
||||
|
||||
// these stories only work with `viewportStoryGlobals` set to false
|
||||
// because the `default` prop is dropped and because, `values` changed to `options` and is now an object
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/builder-vite",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "A plugin to run and build Storybooks with Vite",
|
||||
"homepage": "https://github.com/storybookjs/storybook/tree/next/code/builders/builder-vite/#readme",
|
||||
"bugs": {
|
||||
|
@ -9,10 +9,12 @@ import { listStories } from './list-stories';
|
||||
// It ensures that vite converts cjs deps into esm without vite having to find them during startup and then having to log a message about them and restart
|
||||
// TODO: Many of the deps might be prebundled now though, so probably worth trying to remove and see what happens
|
||||
const INCLUDE_CANDIDATES = [
|
||||
'@ampproject/remapping',
|
||||
'@base2/pretty-print-object',
|
||||
'@emotion/core',
|
||||
'@emotion/is-prop-valid',
|
||||
'@emotion/styled',
|
||||
'@jridgewell/sourcemap-codec',
|
||||
'@storybook/addon-a11y/preview',
|
||||
'@storybook/addon-backgrounds/preview',
|
||||
'@storybook/addon-designs/blocks',
|
||||
@ -62,7 +64,9 @@ const INCLUDE_CANDIDATES = [
|
||||
'acorn',
|
||||
'airbnb-js-shims',
|
||||
'ansi-to-html',
|
||||
'aria-query',
|
||||
'axe-core',
|
||||
'axobject-query',
|
||||
'chromatic/isChromatic',
|
||||
'color-convert',
|
||||
'deep-object-diff',
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@storybook/builder-webpack5",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Storybook framework-agnostic API",
|
||||
"keywords": [
|
||||
"storybook"
|
||||
|
@ -29,7 +29,7 @@ export const printDuration = (startTime: [number, number]) =>
|
||||
prettyTime(process.hrtime(startTime))
|
||||
.replace(' ms', ' milliseconds')
|
||||
.replace(' s', ' seconds')
|
||||
.replace(' m', ' minutes');
|
||||
.replace(' min', ' minutes');
|
||||
|
||||
const corePath = dirname(require.resolve('storybook/package.json'));
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "storybook",
|
||||
"version": "9.0.0-alpha.0",
|
||||
"version": "9.0.0-alpha.3",
|
||||
"description": "Storybook framework-agnostic API",
|
||||
"keywords": [
|
||||
"storybook"
|
||||
@ -21,6 +21,12 @@
|
||||
"license": "MIT",
|
||||
"sideEffects": false,
|
||||
"type": "module",
|
||||
"imports": {
|
||||
"#utils": {
|
||||
"storybook": "./template/stories/utils.mock.ts",
|
||||
"default": "./template/stories/utils.ts"
|
||||
}
|
||||
},
|
||||
"exports": {
|
||||
".": {
|
||||
"types": "./dist/index.d.ts",
|
||||
@ -181,6 +187,11 @@
|
||||
"import": "./dist/instrumenter/index.js",
|
||||
"require": "./dist/instrumenter/index.cjs"
|
||||
},
|
||||
"./test": {
|
||||
"types": "./dist/test/index.d.ts",
|
||||
"import": "./dist/test/index.js",
|
||||
"require": "./dist/test/index.cjs"
|
||||
},
|
||||
"./internal/preview/runtime": {
|
||||
"import": "./dist/preview/runtime.js"
|
||||
},
|
||||
@ -280,6 +291,9 @@
|
||||
],
|
||||
"internal/instrumenter": [
|
||||
"./dist/instrumenter/index.d.ts"
|
||||
],
|
||||
"test": [
|
||||
"./dist/test/index.d.ts"
|
||||
]
|
||||
}
|
||||
},
|
||||
@ -295,6 +309,11 @@
|
||||
"prep": "jiti ./scripts/prep.ts"
|
||||
},
|
||||
"dependencies": {
|
||||
"@testing-library/dom": "10.4.0",
|
||||
"@testing-library/jest-dom": "^6.6.3",
|
||||
"@testing-library/user-event": "14.5.2",
|
||||
"@vitest/expect": "2.0.5",
|
||||
"@vitest/spy": "2.0.5",
|
||||
"better-opn": "^3.0.2",
|
||||
"browser-assert": "^1.2.1",
|
||||
"esbuild": "^0.18.0 || ^0.19.0 || ^0.20.0 || ^0.21.0 || ^0.22.0 || ^0.23.0 || ^0.24.0 || ^0.25.0",
|
||||
@ -358,7 +377,9 @@
|
||||
"babel-plugin-react-docgen": "4.2.1",
|
||||
"boxen": "^7.1.1",
|
||||
"browser-dtector": "^3.4.0",
|
||||
"bundle-require": "^5.1.0",
|
||||
"camelcase": "^8.0.0",
|
||||
"chai": "^5.1.1",
|
||||
"cli-table3": "^0.6.1",
|
||||
"commander": "^12.1.0",
|
||||
"comment-parser": "^1.4.1",
|
||||
@ -423,7 +444,7 @@
|
||||
"strip-json-comments": "^5.0.1",
|
||||
"telejson": "^7.2.0",
|
||||
"tiny-invariant": "^1.3.1",
|
||||
"tinyspy": "^2.2.0",
|
||||
"tinyspy": "^3.0.2",
|
||||
"ts-dedent": "^2.0.0",
|
||||
"tsconfig-paths": "^4.2.0",
|
||||
"type-fest": "^4.18.1",
|
||||
|
@ -50,6 +50,23 @@ export const getEntries = (cwd: string) => {
|
||||
define('src/bin/index.ts', ['node'], false),
|
||||
|
||||
define('src/instrumenter/index.ts', ['browser', 'node'], true),
|
||||
define(
|
||||
'src/test/index.ts',
|
||||
['browser', 'node'],
|
||||
true,
|
||||
['util'],
|
||||
[],
|
||||
[
|
||||
'@testing-library/dom',
|
||||
'@testing-library/jest-dom',
|
||||
'@testing-library/user-event',
|
||||
'chai',
|
||||
'@vitest/expect',
|
||||
'@vitest/spy',
|
||||
'@vitest/utils',
|
||||
],
|
||||
true
|
||||
),
|
||||
];
|
||||
};
|
||||
|
||||
|
@ -40,7 +40,7 @@ export async function generatePackageJsonFile(entries: ReturnType<typeof getEntr
|
||||
main
|
||||
.replace(/\/index\.tsx?/, '')
|
||||
.replace(/\.tsx?/, '')
|
||||
.replace('dist/', 'internal/')
|
||||
.replace('dist/', entry.isPublic ? '' : 'internal/')
|
||||
] = content;
|
||||
return acc;
|
||||
}, {});
|
||||
@ -73,7 +73,7 @@ export async function generatePackageJsonFile(entries: ReturnType<typeof getEntr
|
||||
}
|
||||
|
||||
const content = ['./' + main.replace(/\.tsx?/, '.d.ts')];
|
||||
acc[key.replace('dist/', 'internal/')] = content;
|
||||
acc[key.replace('dist/', entry.isPublic ? '' : 'internal/')] = content;
|
||||
return acc;
|
||||
}, {}),
|
||||
},
|
||||
|
@ -83,7 +83,8 @@ async function generateFrameworksFile(prettierConfig: prettier.Options | null):
|
||||
const localAlias = {
|
||||
'@storybook/core': join(__dirname, '..', '..', 'src'),
|
||||
'storybook/internal': join(__dirname, '..', '..', 'src'),
|
||||
storybook: join(__dirname, '..', '..', 'src'),
|
||||
'storybook/test': join(__dirname, '..', '..', 'src'),
|
||||
storybook: join(__dirname, '..', '..', 'src', 'test'),
|
||||
};
|
||||
async function generateExportsFile(prettierConfig: prettier.Options | null): Promise<void> {
|
||||
function removeDefault(input: string) {
|
||||
|
21
code/core/scripts/no-externals-plugin.ts
Normal file
21
code/core/scripts/no-externals-plugin.ts
Normal file
@ -0,0 +1,21 @@
|
||||
// eslint-disable-next-line import/no-extraneous-dependencies
|
||||
import { match } from 'bundle-require';
|
||||
import type { Plugin } from 'esbuild';
|
||||
|
||||
// Must not start with "/" or "./" or "../" or "C:\" or be the exact strings ".." or "."
|
||||
const NON_NODE_MODULE_RE = /^[A-Z]:[/\\]|^\.{0,2}\/|^\.{1,2}$/;
|
||||
|
||||
export const externalPlugin = ({ noExternal }: { noExternal?: (string | RegExp)[] }): Plugin => {
|
||||
return {
|
||||
name: `external`,
|
||||
|
||||
setup(build) {
|
||||
build.onResolve({ filter: /.*/ }, (args) => {
|
||||
// Respect explicit external/noExternal conditions
|
||||
if (match(args.path, noExternal)) {
|
||||
return undefined;
|
||||
}
|
||||
});
|
||||
},
|
||||
};
|
||||
};
|
@ -25,6 +25,7 @@ import { generateTypesMapperFiles } from './helpers/generateTypesMapperFiles';
|
||||
import { isBrowser, isNode, noExternals } from './helpers/isEntryType';
|
||||
import { modifyThemeTypes } from './helpers/modifyThemeTypes';
|
||||
import { generateSourceFiles } from './helpers/sourcefiles';
|
||||
import { externalPlugin } from './no-externals-plugin';
|
||||
|
||||
async function run() {
|
||||
const flags = process.argv.slice(2);
|
||||
@ -253,9 +254,14 @@ async function run() {
|
||||
entryPoints: [entry.file],
|
||||
external: [
|
||||
...nodeInternals,
|
||||
...esbuildDefaultOptions.external,
|
||||
...esbuildDefaultOptions.external.filter((e) => !entry.noExternal.includes(e)),
|
||||
...entry.externals,
|
||||
].filter((e) => !entry.internals.includes(e)),
|
||||
plugins: [
|
||||
externalPlugin({
|
||||
noExternal: entry.noExternal,
|
||||
}),
|
||||
],
|
||||
format: 'cjs',
|
||||
outdir: dirname(entry.file).replace('src', 'dist'),
|
||||
outExtension: {
|
||||
@ -272,10 +278,15 @@ async function run() {
|
||||
entryPoints: [entry.file],
|
||||
external: [
|
||||
...nodeInternals,
|
||||
...esbuildDefaultOptions.external,
|
||||
...esbuildDefaultOptions.external.filter((e) => !entry.noExternal.includes(e)),
|
||||
...entry.externals,
|
||||
].filter((e) => !entry.internals.includes(e)),
|
||||
outdir: dirname(entry.file).replace('src', 'dist'),
|
||||
plugins: [
|
||||
externalPlugin({
|
||||
noExternal: entry.noExternal,
|
||||
}),
|
||||
],
|
||||
outExtension: {
|
||||
'.js': '.js',
|
||||
},
|
||||
@ -289,9 +300,14 @@ async function run() {
|
||||
entryPoints: [entry.file],
|
||||
external: [
|
||||
...nodeInternals,
|
||||
...esbuildDefaultOptions.external,
|
||||
...esbuildDefaultOptions.external.filter((e) => !entry.noExternal.includes(e)),
|
||||
...entry.externals,
|
||||
].filter((e) => !entry.internals.includes(e)),
|
||||
plugins: [
|
||||
externalPlugin({
|
||||
noExternal: entry.noExternal,
|
||||
}),
|
||||
],
|
||||
format: 'esm',
|
||||
outdir: dirname(entry.file).replace('src', 'dist'),
|
||||
outExtension: {
|
||||
|
@ -158,7 +158,7 @@ describe('Helpers', () => {
|
||||
filePath === normalizePath('@storybook/react/template/cli')
|
||||
);
|
||||
await helpers.copyTemplateFiles({
|
||||
renderer: 'react',
|
||||
templateLocation: 'react',
|
||||
language,
|
||||
packageManager: packageManagerMock,
|
||||
commonAssetsDir: normalizePath('create-storybook/rendererAssets/common'),
|
||||
@ -182,7 +182,7 @@ describe('Helpers', () => {
|
||||
return filePath === normalizePath('@storybook/react/template/cli') || filePath === './src';
|
||||
});
|
||||
await helpers.copyTemplateFiles({
|
||||
renderer: 'react',
|
||||
templateLocation: 'react',
|
||||
language: SupportedLanguage.JAVASCRIPT,
|
||||
packageManager: packageManagerMock,
|
||||
features: ['dev', 'docs', 'test'],
|
||||
@ -195,7 +195,7 @@ describe('Helpers', () => {
|
||||
return filePath === normalizePath('@storybook/react/template/cli');
|
||||
});
|
||||
await helpers.copyTemplateFiles({
|
||||
renderer: 'react',
|
||||
templateLocation: 'react',
|
||||
language: SupportedLanguage.JAVASCRIPT,
|
||||
packageManager: packageManagerMock,
|
||||
features: ['dev', 'docs', 'test'],
|
||||
@ -208,7 +208,7 @@ describe('Helpers', () => {
|
||||
const expectedMessage = `Unsupported renderer: ${renderer}`;
|
||||
await expect(
|
||||
helpers.copyTemplateFiles({
|
||||
renderer,
|
||||
templateLocation: renderer,
|
||||
language: SupportedLanguage.JAVASCRIPT,
|
||||
packageManager: packageManagerMock,
|
||||
features: ['dev', 'docs', 'test'],
|
||||
|
@ -135,7 +135,7 @@ export function copyTemplate(templateRoot: string, destination = '.') {
|
||||
|
||||
type CopyTemplateFilesOptions = {
|
||||
packageManager: JsPackageManager;
|
||||
renderer: SupportedFrameworks | SupportedRenderers;
|
||||
templateLocation: SupportedFrameworks | SupportedRenderers;
|
||||
language: SupportedLanguage;
|
||||
commonAssetsDir?: string;
|
||||
destination?: string;
|
||||
@ -205,7 +205,7 @@ export const cliStoriesTargetPath = async () => {
|
||||
|
||||
export async function copyTemplateFiles({
|
||||
packageManager,
|
||||
renderer,
|
||||
templateLocation,
|
||||
language,
|
||||
destination,
|
||||
commonAssetsDir,
|
||||
@ -218,7 +218,7 @@ export async function copyTemplateFiles({
|
||||
[SupportedLanguage.TYPESCRIPT_4_9]: 'ts-4-9',
|
||||
};
|
||||
// FIXME: remove after 9.0
|
||||
if (renderer === 'svelte') {
|
||||
if (templateLocation === 'svelte') {
|
||||
const svelteVersion = await getVersionSafe(packageManager, 'svelte');
|
||||
if (svelteVersion && major(svelteVersion) >= 5) {
|
||||
languageFolderMapping = {
|
||||
@ -230,7 +230,7 @@ export async function copyTemplateFiles({
|
||||
}
|
||||
}
|
||||
const templatePath = async () => {
|
||||
const baseDir = await getRendererDir(packageManager, renderer);
|
||||
const baseDir = await getRendererDir(packageManager, templateLocation);
|
||||
const assetsDir = join(baseDir, 'template', 'cli');
|
||||
|
||||
const assetsLanguage = join(assetsDir, languageFolderMapping[language]);
|
||||
@ -253,7 +253,7 @@ export async function copyTemplateFiles({
|
||||
if (existsSync(assetsDir)) {
|
||||
return assetsDir;
|
||||
}
|
||||
throw new Error(`Unsupported renderer: ${renderer} (${baseDir})`);
|
||||
throw new Error(`Unsupported renderer: ${templateLocation} (${baseDir})`);
|
||||
};
|
||||
|
||||
const destinationPath = destination ?? (await cliStoriesTargetPath());
|
||||
@ -264,7 +264,7 @@ export async function copyTemplateFiles({
|
||||
await cp(await templatePath(), destinationPath, { recursive: true, filter });
|
||||
|
||||
if (commonAssetsDir && features.includes('docs')) {
|
||||
let rendererType = frameworkToRenderer[renderer] || 'react';
|
||||
let rendererType = frameworkToRenderer[templateLocation] || 'react';
|
||||
|
||||
// This is only used for docs links and the docs site uses `vue` for both `vue` & `vue3` renderers
|
||||
if (rendererType === 'vue3') {
|
||||
|
@ -47,4 +47,4 @@ export * from './js-package-manager';
|
||||
|
||||
export { versions };
|
||||
|
||||
export { createFileSystemCache } from './utils/file-cache';
|
||||
export { createFileSystemCache, FileSystemCache } from './utils/file-cache';
|
||||
|
@ -43,12 +43,12 @@ describe('JsPackageManager', () => {
|
||||
expect(result).toEqual(['@storybook/react@8.3.0']);
|
||||
});
|
||||
|
||||
it('should return the latest stable release version when there is no current version', async () => {
|
||||
it('should get the requested version when the package is not in the monorepo', async () => {
|
||||
mockLatestVersion.mockResolvedValue('2.0.0');
|
||||
|
||||
const result = await jsPackageManager.getVersionedPackages(['@storybook/new-addon@^8.3.0']);
|
||||
const result = await jsPackageManager.getVersionedPackages(['@storybook/new-addon@^next']);
|
||||
|
||||
expect(result).toEqual(['@storybook/new-addon@^2.0.0']);
|
||||
expect(result).toEqual(['@storybook/new-addon@^next']);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
@ -333,6 +333,13 @@ export abstract class JsPackageManager {
|
||||
return Promise.all(
|
||||
packages.map(async (pkg) => {
|
||||
const [packageName, packageVersion] = getPackageDetails(pkg);
|
||||
|
||||
// If the packageVersion is specified and we are not dealing with a storybook package,
|
||||
// just return the requested version.
|
||||
if (packageVersion && !(packageName in storybookPackagesVersions)) {
|
||||
return pkg;
|
||||
}
|
||||
|
||||
const latestInRange = await this.latestVersion(packageName, packageVersion);
|
||||
|
||||
const k = packageName as keyof typeof storybookPackagesVersions;
|
||||
|
@ -4,4 +4,4 @@ export const printDuration = (startTime: [number, number]) =>
|
||||
prettyTime(process.hrtime(startTime))
|
||||
.replace(' ms', ' milliseconds')
|
||||
.replace(' s', ' seconds')
|
||||
.replace(' m', ' minutes');
|
||||
.replace(' min', ' minutes');
|
||||
|
@ -1,68 +1,67 @@
|
||||
// auto generated file, do not edit
|
||||
export default {
|
||||
'@storybook/addon-a11y': '9.0.0-alpha.0',
|
||||
'@storybook/addon-actions': '9.0.0-alpha.0',
|
||||
'@storybook/addon-backgrounds': '9.0.0-alpha.0',
|
||||
'@storybook/addon-controls': '9.0.0-alpha.0',
|
||||
'@storybook/addon-docs': '9.0.0-alpha.0',
|
||||
'@storybook/addon-essentials': '9.0.0-alpha.0',
|
||||
'@storybook/addon-mdx-gfm': '9.0.0-alpha.0',
|
||||
'@storybook/addon-highlight': '9.0.0-alpha.0',
|
||||
'@storybook/addon-interactions': '9.0.0-alpha.0',
|
||||
'@storybook/addon-jest': '9.0.0-alpha.0',
|
||||
'@storybook/addon-links': '9.0.0-alpha.0',
|
||||
'@storybook/addon-measure': '9.0.0-alpha.0',
|
||||
'@storybook/addon-onboarding': '9.0.0-alpha.0',
|
||||
'@storybook/addon-outline': '9.0.0-alpha.0',
|
||||
'@storybook/addon-storysource': '9.0.0-alpha.0',
|
||||
'@storybook/addon-test': '9.0.0-alpha.0',
|
||||
'@storybook/addon-themes': '9.0.0-alpha.0',
|
||||
'@storybook/addon-toolbars': '9.0.0-alpha.0',
|
||||
'@storybook/addon-viewport': '9.0.0-alpha.0',
|
||||
'@storybook/builder-vite': '9.0.0-alpha.0',
|
||||
'@storybook/builder-webpack5': '9.0.0-alpha.0',
|
||||
storybook: '9.0.0-alpha.0',
|
||||
'@storybook/angular': '9.0.0-alpha.0',
|
||||
'@storybook/ember': '9.0.0-alpha.0',
|
||||
'@storybook/experimental-nextjs-vite': '9.0.0-alpha.0',
|
||||
'@storybook/html-vite': '9.0.0-alpha.0',
|
||||
'@storybook/html-webpack5': '9.0.0-alpha.0',
|
||||
'@storybook/nextjs': '9.0.0-alpha.0',
|
||||
'@storybook/preact-vite': '9.0.0-alpha.0',
|
||||
'@storybook/preact-webpack5': '9.0.0-alpha.0',
|
||||
'@storybook/react-native-web-vite': '9.0.0-alpha.0',
|
||||
'@storybook/react-vite': '9.0.0-alpha.0',
|
||||
'@storybook/react-webpack5': '9.0.0-alpha.0',
|
||||
'@storybook/server-webpack5': '9.0.0-alpha.0',
|
||||
'@storybook/svelte-vite': '9.0.0-alpha.0',
|
||||
'@storybook/svelte-webpack5': '9.0.0-alpha.0',
|
||||
'@storybook/sveltekit': '9.0.0-alpha.0',
|
||||
'@storybook/vue3-vite': '9.0.0-alpha.0',
|
||||
'@storybook/vue3-webpack5': '9.0.0-alpha.0',
|
||||
'@storybook/web-components-vite': '9.0.0-alpha.0',
|
||||
'@storybook/web-components-webpack5': '9.0.0-alpha.0',
|
||||
'@storybook/blocks': '9.0.0-alpha.0',
|
||||
sb: '9.0.0-alpha.0',
|
||||
'@storybook/cli': '9.0.0-alpha.0',
|
||||
'@storybook/codemod': '9.0.0-alpha.0',
|
||||
'@storybook/core-webpack': '9.0.0-alpha.0',
|
||||
'create-storybook': '9.0.0-alpha.0',
|
||||
'@storybook/csf-plugin': '9.0.0-alpha.0',
|
||||
'@storybook/react-dom-shim': '9.0.0-alpha.0',
|
||||
'@storybook/source-loader': '9.0.0-alpha.0',
|
||||
'@storybook/test': '9.0.0-alpha.0',
|
||||
'@storybook/preset-create-react-app': '9.0.0-alpha.0',
|
||||
'@storybook/preset-html-webpack': '9.0.0-alpha.0',
|
||||
'@storybook/preset-preact-webpack': '9.0.0-alpha.0',
|
||||
'@storybook/preset-react-webpack': '9.0.0-alpha.0',
|
||||
'@storybook/preset-server-webpack': '9.0.0-alpha.0',
|
||||
'@storybook/preset-svelte-webpack': '9.0.0-alpha.0',
|
||||
'@storybook/preset-vue3-webpack': '9.0.0-alpha.0',
|
||||
'@storybook/html': '9.0.0-alpha.0',
|
||||
'@storybook/preact': '9.0.0-alpha.0',
|
||||
'@storybook/react': '9.0.0-alpha.0',
|
||||
'@storybook/server': '9.0.0-alpha.0',
|
||||
'@storybook/svelte': '9.0.0-alpha.0',
|
||||
'@storybook/vue3': '9.0.0-alpha.0',
|
||||
'@storybook/web-components': '9.0.0-alpha.0',
|
||||
'@storybook/addon-a11y': '9.0.0-alpha.3',
|
||||
'@storybook/addon-actions': '9.0.0-alpha.3',
|
||||
'@storybook/addon-backgrounds': '9.0.0-alpha.3',
|
||||
'@storybook/addon-controls': '9.0.0-alpha.3',
|
||||
'@storybook/addon-docs': '9.0.0-alpha.3',
|
||||
'@storybook/addon-essentials': '9.0.0-alpha.3',
|
||||
'@storybook/addon-mdx-gfm': '9.0.0-alpha.3',
|
||||
'@storybook/addon-highlight': '9.0.0-alpha.3',
|
||||
'@storybook/addon-interactions': '9.0.0-alpha.3',
|
||||
'@storybook/addon-jest': '9.0.0-alpha.3',
|
||||
'@storybook/addon-links': '9.0.0-alpha.3',
|
||||
'@storybook/addon-measure': '9.0.0-alpha.3',
|
||||
'@storybook/addon-onboarding': '9.0.0-alpha.3',
|
||||
'@storybook/addon-outline': '9.0.0-alpha.3',
|
||||
'@storybook/addon-storysource': '9.0.0-alpha.3',
|
||||
'@storybook/addon-test': '9.0.0-alpha.3',
|
||||
'@storybook/addon-themes': '9.0.0-alpha.3',
|
||||
'@storybook/addon-toolbars': '9.0.0-alpha.3',
|
||||
'@storybook/addon-viewport': '9.0.0-alpha.3',
|
||||
'@storybook/builder-vite': '9.0.0-alpha.3',
|
||||
'@storybook/builder-webpack5': '9.0.0-alpha.3',
|
||||
storybook: '9.0.0-alpha.3',
|
||||
'@storybook/angular': '9.0.0-alpha.3',
|
||||
'@storybook/ember': '9.0.0-alpha.3',
|
||||
'@storybook/experimental-nextjs-vite': '9.0.0-alpha.3',
|
||||
'@storybook/html-vite': '9.0.0-alpha.3',
|
||||
'@storybook/html-webpack5': '9.0.0-alpha.3',
|
||||
'@storybook/nextjs': '9.0.0-alpha.3',
|
||||
'@storybook/preact-vite': '9.0.0-alpha.3',
|
||||
'@storybook/preact-webpack5': '9.0.0-alpha.3',
|
||||
'@storybook/react-native-web-vite': '9.0.0-alpha.3',
|
||||
'@storybook/react-vite': '9.0.0-alpha.3',
|
||||
'@storybook/react-webpack5': '9.0.0-alpha.3',
|
||||
'@storybook/server-webpack5': '9.0.0-alpha.3',
|
||||
'@storybook/svelte-vite': '9.0.0-alpha.3',
|
||||
'@storybook/svelte-webpack5': '9.0.0-alpha.3',
|
||||
'@storybook/sveltekit': '9.0.0-alpha.3',
|
||||
'@storybook/vue3-vite': '9.0.0-alpha.3',
|
||||
'@storybook/vue3-webpack5': '9.0.0-alpha.3',
|
||||
'@storybook/web-components-vite': '9.0.0-alpha.3',
|
||||
'@storybook/web-components-webpack5': '9.0.0-alpha.3',
|
||||
'@storybook/blocks': '9.0.0-alpha.3',
|
||||
sb: '9.0.0-alpha.3',
|
||||
'@storybook/cli': '9.0.0-alpha.3',
|
||||
'@storybook/codemod': '9.0.0-alpha.3',
|
||||
'@storybook/core-webpack': '9.0.0-alpha.3',
|
||||
'create-storybook': '9.0.0-alpha.3',
|
||||
'@storybook/csf-plugin': '9.0.0-alpha.3',
|
||||
'@storybook/react-dom-shim': '9.0.0-alpha.3',
|
||||
'@storybook/source-loader': '9.0.0-alpha.3',
|
||||
'@storybook/preset-create-react-app': '9.0.0-alpha.3',
|
||||
'@storybook/preset-html-webpack': '9.0.0-alpha.3',
|
||||
'@storybook/preset-preact-webpack': '9.0.0-alpha.3',
|
||||
'@storybook/preset-react-webpack': '9.0.0-alpha.3',
|
||||
'@storybook/preset-server-webpack': '9.0.0-alpha.3',
|
||||
'@storybook/preset-svelte-webpack': '9.0.0-alpha.3',
|
||||
'@storybook/preset-vue3-webpack': '9.0.0-alpha.3',
|
||||
'@storybook/html': '9.0.0-alpha.3',
|
||||
'@storybook/preact': '9.0.0-alpha.3',
|
||||
'@storybook/react': '9.0.0-alpha.3',
|
||||
'@storybook/server': '9.0.0-alpha.3',
|
||||
'@storybook/svelte': '9.0.0-alpha.3',
|
||||
'@storybook/vue3': '9.0.0-alpha.3',
|
||||
'@storybook/web-components': '9.0.0-alpha.3',
|
||||
};
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { Badge } from './Badge';
|
||||
|
||||
|
@ -1,7 +1,8 @@
|
||||
import React from 'react';
|
||||
|
||||
import { LinkIcon } from '@storybook/icons';
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { Form } from '../form';
|
||||
import { Button } from './Button';
|
||||
|
@ -1,6 +1,6 @@
|
||||
import React from 'react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { dedent } from 'ts-dedent';
|
||||
|
||||
|
@ -1,7 +1,8 @@
|
||||
import React from 'react';
|
||||
|
||||
import { FaceHappyIcon } from '@storybook/icons';
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { IconButton } from './IconButton';
|
||||
|
||||
|
@ -1,7 +1,8 @@
|
||||
import React, { useState } from 'react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { expect, userEvent, within } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { expect, userEvent, within } from 'storybook/test';
|
||||
|
||||
import { Button } from '../Button/Button';
|
||||
import { Modal } from './Modal';
|
||||
|
@ -1,7 +1,8 @@
|
||||
import React from 'react';
|
||||
|
||||
import { StopAltIcon } from '@storybook/icons';
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { ProgressSpinner } from './ProgressSpinner';
|
||||
|
||||
|
@ -180,7 +180,7 @@ export const UnsupportedDark = {
|
||||
export const Story = {
|
||||
args: {
|
||||
language: 'jsx',
|
||||
children: `import type { Meta, StoryObj } from '@storybook/react';
|
||||
children: `import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { Header } from './Header';
|
||||
|
||||
|
@ -3,7 +3,8 @@ import React from 'react';
|
||||
import { Link } from 'storybook/internal/components';
|
||||
|
||||
import { DocumentIcon } from '@storybook/icons';
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { EmptyTabContent } from './EmptyTabContent';
|
||||
|
||||
|
@ -1,12 +1,14 @@
|
||||
import React from 'react';
|
||||
|
||||
import { BottomBarIcon, CloseIcon } from '@storybook/icons';
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { expect } from '@storybook/test';
|
||||
import { findByText, fireEvent, screen, userEvent, waitFor, within } from '@storybook/test';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { action } from '@storybook/addon-actions';
|
||||
|
||||
import { expect } from 'storybook/test';
|
||||
import { findByText, fireEvent, screen, userEvent, waitFor, within } from 'storybook/test';
|
||||
|
||||
import { IconButton } from '../IconButton/IconButton';
|
||||
import { TabWrapper, Tabs, TabsState } from './tabs';
|
||||
import type { ChildrenList } from './tabs.helpers';
|
||||
|
@ -1,7 +1,8 @@
|
||||
import React from 'react';
|
||||
|
||||
import { LinkIcon, LinuxIcon } from '@storybook/icons';
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { action } from '@storybook/addon-actions';
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
import React from 'react';
|
||||
|
||||
import type { Meta } from '@storybook/react';
|
||||
import type { Meta } from '@storybook/react-vite';
|
||||
|
||||
import { TooltipMessage } from './TooltipMessage';
|
||||
import { WithTooltip } from './WithTooltip';
|
||||
|
@ -3,8 +3,9 @@ import React from 'react';
|
||||
|
||||
import { styled } from 'storybook/internal/theming';
|
||||
|
||||
import type { StoryObj } from '@storybook/react';
|
||||
import { expect, screen } from '@storybook/test';
|
||||
import type { StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { expect, screen } from 'storybook/test';
|
||||
|
||||
import { TooltipMessage } from './TooltipMessage';
|
||||
import { WithToolTipState as WithTooltip } from './WithTooltip';
|
||||
|
@ -1,7 +1,7 @@
|
||||
import React from 'react';
|
||||
import type { FC } from 'react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
export default {
|
||||
title: 'MyComponent',
|
||||
|
@ -1,7 +1,7 @@
|
||||
import React from 'react';
|
||||
import type { FC } from 'react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
export default {
|
||||
title: 'MyComponent',
|
||||
|
@ -1,7 +1,7 @@
|
||||
import React from 'react';
|
||||
import type { FC } from 'react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
export default {
|
||||
title: 'MyComponent',
|
||||
|
@ -1,7 +1,7 @@
|
||||
import React from 'react';
|
||||
import type { FC } from 'react';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
export default {
|
||||
title: 'MyComponent',
|
||||
|
@ -1,7 +1,7 @@
|
||||
import React from 'react';
|
||||
import type { FC } from 'react';
|
||||
|
||||
import type { Meta } from '@storybook/react';
|
||||
import type { Meta } from '@storybook/react-vite';
|
||||
|
||||
export default {
|
||||
title: 'MyComponent',
|
||||
|
@ -43,7 +43,7 @@ export async function warnWhenUsingArgTypesRegex(
|
||||
'argTypesRegex'
|
||||
)} and assigning explicit action with the ${picocolors.cyan(
|
||||
'fn'
|
||||
)} function from ${picocolors.cyan('@storybook/test')} instead:
|
||||
)} function from ${picocolors.cyan('storybook/test')} instead:
|
||||
https://storybook.js.org/docs/essentials/actions#via-storybooktest-fn-spy-function
|
||||
|
||||
The build used by the addon for snapshot testing doesn't take the regex into account, which can cause hard to debug problems when a snapshot depends on the presence of action props.
|
||||
|
@ -31,7 +31,7 @@ Depending on the library and functions to be instrumented, you may want to confi
|
||||
|
||||
`intercept` can take either a boolean (default `false`) or a function which returns a boolean. This enables you to only make specific library functions interceptable. This function receives a `method` and `path`, referring to the name of the function and the path to that function in the object tree. Some functions may return an object which is then instrumented as well, in which case the `path` will contain a "call ref", which is a plain object containing a `__callId__` property referencing the originating call.
|
||||
|
||||
Here's an example `intercept` function (from `@storybook/test`):
|
||||
Here's an example `intercept` function (from `storybook/test`):
|
||||
|
||||
```js
|
||||
(method, path) => path[0] === 'fireEvent' || method.startsWith('findBy') || method.startsWith('waitFor'),
|
||||
|
@ -1 +1 @@
|
||||
export const version = '9.0.0-alpha.0';
|
||||
export const version = '9.0.0-alpha.3';
|
||||
|
@ -4,11 +4,12 @@ import React, { useState } from 'react';
|
||||
import { LocationProvider } from 'storybook/internal/router';
|
||||
import { styled } from 'storybook/internal/theming';
|
||||
|
||||
import type { Meta, StoryObj } from '@storybook/react';
|
||||
import { fn } from '@storybook/test';
|
||||
import type { Meta, StoryObj } from '@storybook/react-vite';
|
||||
|
||||
import { action } from '@storybook/addon-actions';
|
||||
|
||||
import { fn } from 'storybook/test';
|
||||
|
||||
import MobileNavigationStoriesMeta from '../mobile/navigation/MobileNavigation.stories';
|
||||
import { Layout } from './Layout';
|
||||
import { LayoutProvider } from './LayoutProvider';
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user