generated from MarcosSantosDev/template-react-tailwind-css
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvite.config.ts
54 lines (49 loc) · 1.17 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
import vitePluginReact from '@vitejs/plugin-react';
import path from 'path';
import { visualizer } from 'rollup-plugin-visualizer';
import { defineConfig, loadEnv } from 'vite';
import vitePluginSvgr from 'vite-plugin-svgr';
import vitePluginTsconfigPaths from 'vite-tsconfig-paths';
export default defineConfig(({ mode }) => {
const env = loadEnv(mode, process.cwd());
const PORT = parseInt(`${env.VITE_PORT ?? '3001'}`);
const htmlPlugin = () => {
return {
name: 'html-transform',
transformIndexHtml(html: string) {
return html.replace(/%(.*?)%/g, function (match, p1) {
return env[p1];
});
},
};
};
return {
server: {
port: PORT,
},
build: {
outDir: 'build',
},
plugins: [
htmlPlugin(),
vitePluginReact(),
vitePluginTsconfigPaths(),
vitePluginSvgr(),
visualizer({
template: 'treemap',
open: false,
gzipSize: true,
brotliSize: true,
filename: 'analyse/index.html',
}),
],
define: {
global: 'window',
},
resolve: {
alias: {
'@': path.resolve(__dirname, './src'),
},
},
};
});