forked from logue/vite-vue2-ts-starter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
vite.config.ts
117 lines (110 loc) · 3.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
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
import { writeFileSync } from 'node:fs';
import { fileURLToPath, URL } from 'node:url';
import vue from '@vitejs/plugin-vue2';
import { defineConfig, type UserConfig } from 'vite';
import { visualizer } from 'rollup-plugin-visualizer';
import { checker } from 'vite-plugin-checker';
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: './',
plugins: [
// Vue2
// https://github.com/vitejs/vite-plugin-vue2
vue(),
// vite-plugin-checker
// https://github.com/fi3ework/vite-plugin-checker
checker({
typescript: true,
// vueTsc: true,
// eslint: {lintCommand: 'eslint'},
// stylelint: {lintCommand: 'stylelint'},
}),
// compress assets
// https://github.com/vbenjs/vite-plugin-compression
// viteCompression(),
],
// 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'],
},
// https://vitejs.dev/config/server-options.html
server: {
fs: {
// Allow serving files from one level up to the project root
allow: ['..'],
},
},
// Build Options
// https://vitejs.dev/config/build-options.html
build: {
// Build Target
// https://vitejs.dev/config/build-options.html#build-target
target: 'esnext',
// Rollup Options
// https://vitejs.dev/config/build-options.html#build-rollupoptions
rollupOptions: {
output: {
manualChunks: {
// Split external library from transpiled code.
vue: [
'vue',
'vue-router',
'vue-router/composables',
'vuex',
// 'vuex-persist',
// 'deepmerge',
'@logue/vue2-helpers',
'@logue/vue2-helpers/teleport',
'@logue/vue2-helpers/vue-router',
'@logue/vue2-helpers/vuex',
],
},
plugins: [
mode === 'analyze'
? // rollup-plugin-visualizer
// https://github.com/btd/rollup-plugin-visualizer
visualizer({
open: true,
filename: 'dist/stats.html',
// gzipSize: true,
// brotliSize: true,
})
: undefined,
],
},
},
// Minify option
// https://vitejs.dev/config/build-options.html#build-minify
minify: 'esbuild',
},
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;
});