2023-12-04 11:32:19 +03:00
|
|
|
import { StorybookConfig } from '@storybook/react-vite';
|
|
|
|
import { vanillaExtractPlugin } from '@vanilla-extract/vite-plugin';
|
|
|
|
import { mergeConfig } from 'vite';
|
2024-03-19 10:48:56 +03:00
|
|
|
import { getRuntimeConfig } from '@affine/cli/src/webpack/runtime-config';
|
2023-12-04 11:32:19 +03:00
|
|
|
|
|
|
|
export default {
|
|
|
|
stories: ['../src/ui/**/*.stories.@(js|jsx|ts|tsx|mdx)'],
|
|
|
|
addons: [
|
|
|
|
'@storybook/addon-links',
|
|
|
|
'@storybook/addon-essentials',
|
|
|
|
'@storybook/addon-interactions',
|
|
|
|
'@storybook/addon-mdx-gfm',
|
|
|
|
'storybook-dark-mode',
|
|
|
|
],
|
|
|
|
framework: {
|
|
|
|
name: '@storybook/react-vite',
|
|
|
|
options: {},
|
|
|
|
},
|
|
|
|
features: {
|
|
|
|
storyStoreV7: true,
|
|
|
|
},
|
|
|
|
docs: {
|
|
|
|
autodocs: true,
|
|
|
|
},
|
|
|
|
async viteFinal(config, _options) {
|
|
|
|
return mergeConfig(config, {
|
2024-02-29 10:58:41 +03:00
|
|
|
plugins: [vanillaExtractPlugin()],
|
2024-03-23 09:33:25 +03:00
|
|
|
esbuild: {
|
|
|
|
target: 'ES2022',
|
|
|
|
},
|
2023-12-04 11:32:19 +03:00
|
|
|
define: {
|
|
|
|
'process.env': {},
|
|
|
|
'process.env.COVERAGE': JSON.stringify(!!process.env.COVERAGE),
|
|
|
|
'process.env.SHOULD_REPORT_TRACE': `${Boolean(
|
|
|
|
process.env.SHOULD_REPORT_TRACE === 'true'
|
|
|
|
)}`,
|
|
|
|
'process.env.TRACE_REPORT_ENDPOINT': `"${process.env.TRACE_REPORT_ENDPOINT}"`,
|
|
|
|
'process.env.CAPTCHA_SITE_KEY': `"${process.env.CAPTCHA_SITE_KEY}"`,
|
|
|
|
runtimeConfig: getRuntimeConfig({
|
|
|
|
distribution: 'browser',
|
|
|
|
mode: 'development',
|
|
|
|
channel: 'canary',
|
|
|
|
coverage: false,
|
|
|
|
}),
|
|
|
|
},
|
|
|
|
});
|
|
|
|
},
|
|
|
|
} satisfies StorybookConfig;
|