-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathvite.config.js
More file actions
82 lines (80 loc) · 3.02 KB
/
vite.config.js
File metadata and controls
82 lines (80 loc) · 3.02 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/// <reference types="vitest/config" />
import {defineConfig} from 'vite';
import {extname, relative, resolve} from 'path';
import {fileURLToPath} from 'node:url';
import {glob} from 'glob';
import react from '@vitejs/plugin-react';
import {libInjectCss} from 'vite-plugin-lib-inject-css';
import dts from 'vite-plugin-dts';
import pkg from './package.json';
import path from 'node:path';
import {storybookTest} from '@storybook/addon-vitest/vitest-plugin';
import {playwright} from '@vitest/browser-playwright';
const dirname = typeof __dirname !== 'undefined' ? __dirname : path.dirname(fileURLToPath(import.meta.url));
// More info at: https://storybook.js.org/docs/next/writing-tests/integrations/vitest-addon
export default defineConfig({
plugins: [react({
babel: {
plugins: ['babel-plugin-react-compiler', ['@babel/plugin-proposal-decorators', {
decoratorsBeforeExport: true
}], '@babel/plugin-transform-class-properties']
}
}), libInjectCss(), dts({
include: ['src'],
exclude: ['src/**/*.stories.tsx'],
afterDiagnostic: diagnostics => {
if (diagnostics.length > 0) {
throw new Error("dts failed");
}
}
})],
build: {
lib: {
entry: resolve(__dirname, 'src/index.ts'),
formats: ['es']
},
rollupOptions: {
external: [...Object.keys(pkg.peerDependencies), 'react/jsx-runtime'],
input: Object.fromEntries(glob.sync('src/**/*.{ts,tsx}', {
ignore: ['src/**/*.stories.tsx', 'src/**/*.test.ts']
}).map(file => [relative('src', file.slice(0, file.length - extname(file).length)), fileURLToPath(new URL(file, import.meta.url))])),
output: {
assetFileNames: 'assets/[name].[ext]',
preserveModules: true,
preserveModulesRoot: 'src',
entryFileNames: '[name].js'
}
}
},
test: {
projects: [{
extends: true,
plugins: [
// The plugin will run tests for the stories defined in your Storybook config
// See options at: https://storybook.js.org/docs/next/writing-tests/integrations/vitest-addon#storybooktest
storybookTest({
configDir: path.join(dirname, '.storybook')
})],
test: {
name: 'storybook',
browser: {
enabled: true,
headless: true,
provider: playwright({}),
instances: [
{
browser: 'chromium',
},
{
browser: 'webkit',
},
{
browser: 'firefox',
}
]
},
setupFiles: ['.storybook/vitest.setup.ts']
}
}]
}
});