-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvite.config.ts
62 lines (60 loc) · 1.67 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
import react from "@vitejs/plugin-react";
import { resolve } from "path";
import { PreRenderedChunk } from "rollup";
import { defineConfig, loadEnv } from "vite";
import svgr from "vite-plugin-svgr";
import { outputFolderName } from "./utils/constants";
import buildContentScript from "./utils/plugins/build-content-script";
import makeManifest from "./utils/plugins/make-manifest";
const root = resolve(__dirname, "src");
const pagesDir = resolve(root, "pages");
const assetsDir = resolve(root, "assets");
const outDir = resolve(__dirname, outputFolderName);
const publicDir = resolve(__dirname, "public");
export default defineConfig(({ mode }) => {
const env = loadEnv(mode, process.cwd());
return {
resolve: {
alias: {
"@src": root,
"@assets": assetsDir,
"@pages": pagesDir,
"@utils": resolve(root, "utils")
}
},
plugins: [
react({
jsxImportSource: "@emotion/react",
babel: {
plugins: [["@emotion/babel-plugin", { sourceMap: true }]]
}
}),
makeManifest(),
buildContentScript(),
svgr()
],
publicDir,
build: {
outDir,
sourcemap: process.env.__DEV__ === "true",
emptyOutDir: false,
rollupOptions: {
input: {
background: resolve(pagesDir, "background", "index.ts"),
popup: resolve(pagesDir, "popup", "index.html")
},
output: {
entryFileNames: (assetInfo: PreRenderedChunk) => {
return `src/pages/${assetInfo.name}/index.js`;
}
}
},
define: {
"process.env": env,
"process.env.NODE_ENV": JSON.stringify(mode),
"process.env.VITE_SERVER_URI": JSON.stringify(env.VITE_SERVER_URI),
"process.env.VITE_ASSETS_URL": JSON.stringify(env.VITE_ASSETS_URL)
}
}
};
});