Norbert de Langen 35505ecdbd fix dev actually
2025-01-09 16:10:08 +01:00

217 lines
6.2 KiB
TypeScript

import { join } from 'node:path';
import { nodePolyfills } from 'vite-plugin-node-polyfills';
import topLevelAwait from 'vite-plugin-top-level-await';
import type { StorybookConfig } from '../frameworks/react-vite';
const componentsPath = join(__dirname, '../core/src/components');
const managerApiPath = join(__dirname, '../core/src/manager-api');
const imageContextPath = join(__dirname, '..//frameworks/nextjs/src/image-context.ts');
const config: StorybookConfig = {
stories: [
'./*.stories.@(js|jsx|ts|tsx)',
{
directory: '../core/template/stories',
titlePrefix: 'core',
},
{
directory: '../core/src/manager',
titlePrefix: 'manager',
},
{
directory: '../core/src/preview-api',
titlePrefix: 'preview',
},
{
directory: '../core/src/components/brand',
titlePrefix: 'brand',
},
{
directory: '../core/src/components/components',
titlePrefix: 'components',
},
{
directory: '../lib/blocks/src',
titlePrefix: 'blocks',
},
{
directory: '../addons/a11y/template/stories',
titlePrefix: 'addons/a11y',
},
{
directory: '../addons/actions/template/stories',
titlePrefix: 'addons/actions',
},
{
directory: '../addons/backgrounds/template/stories',
titlePrefix: 'addons/backgrounds',
},
{
directory: '../addons/controls/src',
titlePrefix: 'addons/controls',
},
{
directory: '../addons/controls/template/stories',
titlePrefix: 'addons/controls',
},
{
directory: '../addons/docs/template/stories',
titlePrefix: 'addons/docs',
},
{
directory: '../addons/links/template/stories',
titlePrefix: 'addons/links',
},
{
directory: '../addons/viewport/template/stories',
titlePrefix: 'addons/viewport',
},
{
directory: '../addons/toolbars/template/stories',
titlePrefix: 'addons/toolbars',
},
{
directory: '../addons/themes/template/stories',
titlePrefix: 'addons/themes',
},
{
directory: '../addons/onboarding/src',
titlePrefix: 'addons/onboarding',
},
{
directory: '../addons/interactions/src',
titlePrefix: 'addons/interactions',
},
{
directory: '../addons/interactions/template/stories',
titlePrefix: 'addons/interactions/tests',
},
{
directory: '../addons/test/src/components',
titlePrefix: 'addons/test',
},
{
directory: '../addons/test/template/stories',
titlePrefix: 'addons/test',
},
{
directory: '../lib/create-storybook/src/ink',
titlePrefix: 'CLI/create-storybook',
},
],
addons: [
'@storybook/addon-themes',
'@storybook/addon-essentials',
'@storybook/addon-storysource',
'@storybook/addon-designs',
'@storybook/experimental-addon-test',
'@storybook/addon-a11y',
'@chromatic-com/storybook',
],
previewAnnotations: [
'./core/template/stories/preview.ts',
'./addons/toolbars/template/stories/preview.ts',
'./renderers/react/template/components/index.js',
],
build: {
test: {
// we have stories for the blocks here, we can't exclude them
disableBlocks: false,
// some stories in blocks (ArgTypes, Controls) depends on argTypes inference
disableDocgen: false,
},
},
framework: {
name: '@storybook/react-vite',
options: {},
},
refs: {
icons: {
title: 'Icons',
url: 'https://main--64b56e737c0aeefed9d5e675.chromatic.com',
expanded: false,
},
},
core: {
disableTelemetry: true,
},
features: {
viewportStoryGlobals: true,
backgroundsStoryGlobals: true,
developmentModeForBuild: true,
},
viteFinal: async (viteConfig, { configType }) => {
const { mergeConfig } = await import('vite');
return mergeConfig(viteConfig, {
plugins: [
nodePolyfills({
globals: {
process: false,
global: false,
Buffer: false,
},
overrides: {
process: require.resolve(join(__dirname, './mocks/node-process.ts')),
module: require.resolve(join(__dirname, './mocks/node-module.ts')),
util: require.resolve(join(__dirname, './mocks/node-util.ts')),
stream: require.resolve('stream-browserify'),
buffer: require.resolve('buffer/'),
assert: require.resolve('assert/'),
os: require.resolve('os-browserify/browser'),
tty: require.resolve('tty-browserify'),
},
}),
...(configType === 'DEVELOPMENT' ? [topLevelAwait()] : []),
],
resolve: {
alias: {
// ink related
'cli-cursor': require.resolve(join(__dirname, './mocks/cli-cursor.ts')),
'is-in-ci': require.resolve(join(__dirname, './mocks/is-in-ci.ts')),
'yoga-wasm-web/auto': 'https://cdn.jsdelivr.net/npm/yoga-wasm-web@0.3.3/dist/browser.js',
'yoga-wasm-web': 'https://cdn.jsdelivr.net/npm/yoga-wasm-web@0.3.3/+esm',
// storybook related
...(configType === 'DEVELOPMENT'
? {
'@storybook/components': componentsPath,
'storybook/internal/components': componentsPath,
'@storybook/manager-api': managerApiPath,
'storybook/internal/manager-api': managerApiPath,
'sb-original/image-context': imageContextPath,
}
: {}),
},
},
optimizeDeps: {
force: true,
include: [
'@storybook/blocks',
'vite-plugin-node-polyfills/shims/buffer',
'vite-plugin-node-polyfills/shims/global',
'@xterm/xterm',
'ink',
],
},
build: {
// disable sourcemaps in CI to not run out of memory
sourcemap: process.env.CI !== 'true',
target: ['chrome100'],
},
server: {
watch: {
// Something odd happens with tsconfig and nx which causes Storybook to keep reloading, so we ignore them
ignored: ['**/.nx/cache/**', '**/tsconfig.json'],
},
},
} satisfies typeof viteConfig);
},
// logLevel: 'debug',
};
export default config;