-
Notifications
You must be signed in to change notification settings - Fork 60
/
vite.config.js
76 lines (70 loc) · 2.06 KB
/
vite.config.js
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
import path from 'path'
import react from '@vitejs/plugin-react'
import { defineConfig } from 'vite'
import { nodeResolve } from '@rollup/plugin-node-resolve'
import { terser } from 'rollup-plugin-terser'
import analyze from 'rollup-plugin-analyzer'
const devMode = process.env.NODE_ENV === 'development'
// ref: https://blog.openreplay.com/the-ultimate-guide-to-getting-started-with-the-rollup-js-javascript-bundler
function terserConfig() {
return terser({
ecma: 2020,
mangle: { toplevel: true },
compress: {
module: true,
toplevel: true,
unsafe_arrows: true,
drop_console: !devMode,
drop_debugger: !devMode,
},
output: { quote_style: 1 },
})
}
// ref: https://vitejs.dev/guide/build.html#library-mode
module.exports = defineConfig({
plugins: [react()],
build: {
lib: {
entry: path.resolve(__dirname, 'src/index.jsx'),
name: 'ReactSpeedometer',
fileName: format => `react-d3-speedometer.${format}.js`,
},
rollupOptions: {
// make sure to externalize deps that shouldn't be bundled
// into your library
external: ['react', 'react/jsx-runtime', 'react-dom', 'react-dom/client', 'window'],
output: {
// Provide global variables to use in the UMD build
// for externalized deps
globals: {
react: 'React',
window: 'window',
},
sourcemap: devMode ? 'inline' : false,
plugins: [terserConfig()],
},
// ref: https://blog.logrocket.com/does-my-bundle-look-big-in-this/
treeshake: {
moduleSideEffects: false,
},
// IMPORTANT: This plugins is different from output plugins
plugins: [
nodeResolve(),
// analyze({
// summaryOnly: true,
// filterSummary: true,
// }),
],
},
},
test: {
globals: true,
setupFiles: ['./setupVitest.js'],
include: [
// '**/*.{test,spec}.{js,mjs,cjs,ts,mts,cts,jsx,tsx}',
// '**/__tests__/*.{test}.{js,jsx}',
'**/__tests__/*.test.{js,jsx}',
'**/*.test.js',
],
},
})