-
Notifications
You must be signed in to change notification settings - Fork 0
/
vite.config.ts
48 lines (45 loc) · 1.08 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
import reactPlugin from "@vitejs/plugin-react";
import browserslist from "browserslist";
import { Features, browserslistToTargets } from "lightningcss";
import { fileURLToPath } from "node:url";
import { type ConfigEnv, defineConfig, loadEnv } from "vite";
import svgr from "vite-plugin-svgr";
const config = ({ mode }: ConfigEnv): ReturnType<typeof defineConfig> => {
const {
VITE_APP_API_ORIGIN_URL,
VITE_APP_DEVELOPMENT_PORT,
VITE_APP_PROXY_SERVER_URL,
} = loadEnv(mode, process.cwd());
return defineConfig({
build: {
cssMinify: "lightningcss",
outDir: "build",
},
css: {
lightningcss: {
drafts: {
customMedia: true,
},
include: Features.MediaQueries,
targets: browserslistToTargets(
browserslist(["last 2 version", "not dead"]),
),
},
transformer: "lightningcss",
},
plugins: [reactPlugin(), svgr()],
resolve: {
alias: [
{
find: "~",
replacement: fileURLToPath(new URL("src", import.meta.url)),
},
],
},
server: {
host: true,
port: Number(VITE_APP_DEVELOPMENT_PORT),
},
});
};
export default config;