-
Notifications
You must be signed in to change notification settings - Fork 5
/
vite.config.ts
71 lines (67 loc) · 2.31 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
import { crx } from "@crxjs/vite-plugin";
import { resolve } from "path";
// import devtools from "solid-devtools/vite";
import { defineConfig } from "vite";
import solidPlugin from "vite-plugin-solid";
import manifest from "./src/manifest";
const root = resolve(__dirname, "src");
const pagesDir = resolve(root, "pages");
const popupDir = resolve(pagesDir, "popup");
const assetsDir = resolve(root, "assets");
const outDir = resolve(__dirname, "dist");
const publicDir = resolve(__dirname, "public");
const isDev = process.env.__DEV__ === "true";
export default defineConfig(({ command }) => {
return {
plugins: [
// devtools({
// /* features options - all disabled by default */
// autoname: true, // e.g. enable autoname
// }),
solidPlugin(),
crx({ manifest }),
],
resolve: {
alias: {
"@src": root,
"@assets": assetsDir,
"@pages": pagesDir,
"~": popupDir,
"webextension-polyfill":
command === "serve"
? resolve(popupDir, "util/mock-browser")
: "webextension-polyfill",
},
},
publicDir,
build: {
outDir,
sourcemap: isDev,
target: "esnext",
rollupOptions: {
// input: {
// devtools: resolve(pagesDir, "devtools", "index.html"),
// panel: resolve(pagesDir, "panel", "index.html"),
// content: resolve(pagesDir, "content", "index.ts"),
// background: resolve(pagesDir, "background", "index.ts"),
// contentStyle: resolve(pagesDir, "content", "style.scss"),
// popup: resolve(pagesDir, "popup", "index.html"),
// newtab: resolve(pagesDir, "newtab", "index.html"),
// options: resolve(pagesDir, "options", "index.html"),
// },
// output: {
// entryFileNames: "src/pages/[name]/index.js",
// chunkFileNames: isDev
// ? "assets/js/[name].js"
// : "assets/js/[name].[hash].js",
// assetFileNames: (assetInfo) => {
// const { dir, name: _name } = path.parse(assetInfo.name);
// // const assetFolder = getLastElement(dir.split("/"));
// // const name = assetFolder + firstUpperCase(_name);
// return `assets/[ext]/${name}.chunk.[ext]`;
// },
// },
},
},
};
});