forked from w3champions/website
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvite.config.ts
50 lines (48 loc) · 1.34 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
import { fileURLToPath, URL } from "node:url";
import { defineConfig } from "vite";
import vue from "@vitejs/plugin-vue2";
import Components from "unplugin-vue-components/vite";
import { ComponentResolver } from "unplugin-vue-components";
import legacy from "@vitejs/plugin-legacy";
// Vuetify addons cause an import error. Custom loader excludes them.
// https://github.com/antfu/unplugin-vue-components/blob/a495847dd0e7c9955bf5c756280482b007e46f49/src/core/resolvers/vuetify.ts#L3-L16
export function VuetifyResolverMod(): ComponentResolver {
return {
type: "component",
resolve: (name: string) => {
if (name.match(/^V[A-Z]/)) {
return { name, from: "vuetify/lib" };
}
},
};
}
export default defineConfig({
plugins: [
vue(),
Components({
resolvers: [VuetifyResolverMod()],
}),
legacy(), // Build for old browser.
],
server: {
port: 8080,
},
resolve: {
alias: {
"@": fileURLToPath(new URL("./src", import.meta.url)),
},
extensions: [".mjs", ".js", ".ts", ".vue", ".jsx", ".tsx", ".json"],
},
css: {
// https://vitejs.dev/config/#css-preprocessoroptions
preprocessorOptions: {
sass: {
additionalData: [
// vuetify variable overrides
'@import "@/scss/variables.scss"',
"",
].join("\n"),
},
},
},
});