-
Notifications
You must be signed in to change notification settings - Fork 37
/
vite.config.ts
125 lines (117 loc) · 3.69 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
120
121
122
123
124
125
import { writeFileSync } from 'node:fs';
import { fileURLToPath, URL } from 'node:url';
import vue from '@vitejs/plugin-vue';
import { defineConfig, type UserConfig } from 'vite';
import { visualizer } from 'rollup-plugin-visualizer';
import { checker } from 'vite-plugin-checker';
import vueDevTools from 'vite-plugin-vue-devtools';
import vuetify, { transformAssetUrls } from 'vite-plugin-vuetify';
import pkg from './package.json';
/**
* Vite Configure
*
* @see {@link https://vitejs.dev/config/}
*/
export default defineConfig(({ command, mode }): UserConfig => {
const config: UserConfig = {
// https://vitejs.dev/config/shared-options.html#base
base: './',
// https://vitejs.dev/config/shared-options.html#define
define: { 'process.env': {} },
plugins: [
// Vue3
vue({
template: {
// https://github.com/vuetifyjs/vuetify-loader/tree/next/packages/vite-plugin#image-loading
transformAssetUrls
}
}),
vueDevTools(),
// Vuetify Loader
// https://github.com/vuetifyjs/vuetify-loader/tree/master/packages/vite-plugin
vuetify({
autoImport: true,
styles: { configFile: 'src/styles/settings.scss' }
}),
// vite-plugin-checker
// https://github.com/fi3ework/vite-plugin-checker
checker({
typescript: true
// vueTsc: true,
// eslint: { lintCommand: 'eslint' },
// stylelint: { lintCommand: 'stylelint' },
})
],
// https://vitejs.dev/config/server-options.html
server: {
fs: {
// Allow serving files from one level up to the project root
allow: ['..']
}
},
// Resolver
resolve: {
// https://vitejs.dev/config/shared-options.html#resolve-alias
alias: {
'@': fileURLToPath(new URL('./src', import.meta.url)),
'~': fileURLToPath(new URL('./node_modules', import.meta.url))
},
extensions: ['.js', '.json', '.jsx', '.mjs', '.ts', '.tsx', '.vue']
},
// Build Options
// https://vitejs.dev/config/build-options.html
build: {
// Build Target
// https://vitejs.dev/config/build-options.html#build-target
target: 'esnext',
// Minify option
// https://vitejs.dev/config/build-options.html#build-minify
minify: 'esbuild',
// Rollup Options
// https://vitejs.dev/config/build-options.html#build-rollupoptions
rollupOptions: {
output: {
manualChunks: {
// Split external library from transpiled code.
vue: ['vue', 'vue-router', 'pinia', 'pinia-plugin-persistedstate'],
vuetify: [
'vuetify',
'vuetify/components',
'vuetify/directives',
// 'vuetify/lib/labs',
'webfontloader'
],
materialdesignicons: ['@mdi/font/css/materialdesignicons.css']
},
plugins: [
mode === 'analyze'
? // rollup-plugin-visualizer
// https://github.com/btd/rollup-plugin-visualizer
visualizer({
open: true,
filename: 'dist/stats.html'
})
: undefined
]
}
}
},
esbuild: {
// Drop console when production build.
drop: command === 'serve' ? [] : ['console']
}
};
// Write meta data.
writeFileSync(
fileURLToPath(new URL('./src/Meta.ts', import.meta.url)),
`import type MetaInterface from '@/interfaces/MetaInterface';
// This file is auto-generated by the build system.
const meta: MetaInterface = {
version: '${pkg.version}',
date: '${new Date().toISOString()}',
};
export default meta;
`
);
return config;
});