-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvite.config.ts
86 lines (81 loc) · 1.91 KB
/
vite.config.ts
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
83
84
85
86
import { NodeGlobalsPolyfillPlugin } from "@esbuild-plugins/node-globals-polyfill"
import react from "@vitejs/plugin-react"
import nodePolyfills from "rollup-plugin-polyfill-node"
import { defineConfig, loadEnv } from "vite"
import checker from "vite-plugin-checker"
import { createHtmlPlugin } from "vite-plugin-html"
import tsconfigPaths from "vite-tsconfig-paths"
import mkcert from "vite-plugin-mkcert"
// function renderChunks(deps) {
// const chunks = {}
// for (const key of Object.keys(deps)) {
// if (["react", "react-router-dom", "react-dom"].includes(key)) {
// continue
// }
// chunks[key] = [key]
// }
// return chunks
// }
export default defineConfig(({ mode }) => {
const environment = loadEnv(mode, "env")
return {
build: {
commonjsOptions: {
transformMixedEsModules: true
},
rollupOptions: {
// output: {
// manualChunks: {
// vendor: [
// 'react',
// 'react-router-dom',
// 'react-dom',
// ],
// ...renderChunks(dependencies),
// },
// },
plugins: [nodePolyfills()]
},
sourcemap: false
},
optimizeDeps: {
esbuildOptions: {
define: {
global: "globalThis"
},
plugins: [
NodeGlobalsPolyfillPlugin({
buffer: true,
process: true
})
// NodeModulesPolyfillPlugin(),
],
target: "esnext"
}
},
plugins: [
react({
include: ["**/*.tsx", "**/*.ts"]
}),
tsconfigPaths(),
createHtmlPlugin({
inject: {
data: {
...environment,
MODE: mode
}
},
minify: true
}),
checker({
typescript: true
}),
mkcert()
],
server: {
hmr: true,
host: true,
https: true
}
}
})