-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy pathvite.config.ts
119 lines (114 loc) · 3.52 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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
import { fileURLToPath, URL } from "node:url";
import path from "path";
import graphql from "@rollup/plugin-graphql";
import vue from "@vitejs/plugin-vue";
import { visualizer } from "rollup-plugin-visualizer";
import { defineConfig, loadEnv, splitVendorChunkPlugin } from "vite";
import { checker } from "vite-plugin-checker";
import mkcert from "vite-plugin-mkcert";
import type { ProxyOptions, UserConfig, PluginOption } from "vite";
function getProxy(target: ProxyOptions["target"], options: Omit<ProxyOptions, "target"> = {}): ProxyOptions {
const dontTrustSelfSignedCertificate = false;
return {
target,
changeOrigin: true,
secure: dontTrustSelfSignedCertificate,
...options,
};
}
// https://vitejs.dev/config/
export default defineConfig(({ command, mode }): UserConfig => {
const isServe = command == "serve";
// https://stackoverflow.com/a/66389044
process.env = {
...process.env,
...loadEnv(mode, process.cwd(), "APP_"),
};
return {
envPrefix: "APP_",
publicDir: "./client-app/public",
plugins: [
isServe
? mkcert({
force: true,
savePath: path.resolve(__dirname, ".certificates"),
keyFileName: "private.pem",
certFileName: "public.pem",
})
: undefined,
vue(),
graphql() as PluginOption,
isServe
? checker({
enableBuild: false,
typescript: true,
vueTsc: {
tsconfigPath: path.resolve(__dirname, "tsconfig.app.json"),
},
eslint: {
lintCommand: "eslint client-app",
dev: {
overrideConfig: {
cache: true,
cacheLocation: "node_modules/.cache/.eslintcache",
cwd: process.cwd(),
extensions: ["js", "ts", "vue"],
ignore: true,
ignorePath: ".eslintignore",
useEslintrc: true,
},
logLevel: ["error"],
},
},
})
: undefined,
splitVendorChunkPlugin(),
process.env.GENERATE_BUNDLE_MAP
? (visualizer({
filename: path.resolve(__dirname, "artifacts/bundle-map.html"),
brotliSize: true,
gzipSize: true,
sourcemap: true,
}) as PluginOption)
: undefined,
],
assetsInclude: ["**/*.svg"],
resolve: {
alias: {
"@": fileURLToPath(new URL("./client-app", import.meta.url)),
},
},
define: {
// https://vue-i18n.intlify.dev/guide/advanced/optimization.html#reduce-bundle-size-with-feature-build-flags
__VUE_I18N_FULL_INSTALL__: true,
__VUE_I18N_LEGACY_API__: false,
},
build: {
emptyOutDir: true,
sourcemap: true,
},
optimizeDeps: {
exclude: ["swiper/vue", "swiper/types"],
},
server: {
port: 3000,
proxy: {
"^/api": getProxy(process.env.APP_BACKEND_URL),
"^/graphql": getProxy(process.env.APP_BACKEND_URL, { ws: true }),
"^/(connect|revoke)/token": getProxy(process.env.APP_BACKEND_URL),
"^/cms-content": getProxy(process.env.APP_BACKEND_URL),
"^/externalsignin": getProxy(process.env.APP_BACKEND_URL),
"^/signin-oidc": getProxy(process.env.APP_BACKEND_URL),
"^/signin-google": getProxy(process.env.APP_BACKEND_URL),
},
},
css: {
preprocessorOptions: {
scss: {
api: "modern-compiler",
quietDeps: true,
},
},
},
};
});