-
Notifications
You must be signed in to change notification settings - Fork 32
/
vite.config.mts
95 lines (94 loc) · 2.27 KB
/
vite.config.mts
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
import tsconfigPaths from 'vite-tsconfig-paths'
import { configDefaults, defineConfig } from 'vitest/config'
import vue from '@vitejs/plugin-vue'
import Icons from 'unplugin-icons/vite'
import IconsResolver from 'unplugin-icons/resolver'
import { HeadlessUiResolver, VueUseComponentsResolver } from 'unplugin-vue-components/resolvers'
import Components from 'unplugin-vue-components/vite'
import Unfonts from 'unplugin-fonts/vite'
import AutoImport from 'unplugin-auto-import/vite'
export default defineConfig({
plugins: [
vue(),
AutoImport({
dts: true,
imports: ['vue', 'vue-router', '@vueuse/core', 'pinia', 'vitest'],
eslintrc: {
enabled: true,
},
dirs: ['./src/composables', './src/utils'],
}),
Components({
dts: true,
resolvers: [HeadlessUiResolver({ prefix: '' }), IconsResolver({ prefix: '' }), VueUseComponentsResolver()],
}),
Icons({ autoInstall: true }),
Unfonts({
custom: {
families: [
{
name: 'Rubik',
local: 'Rubik',
src: './src/assets/fonts/*.ttf',
},
],
display: 'auto',
preload: true,
prefetch: false,
},
}),
tsconfigPaths(),
{
name: 'configure-token',
configureServer(server) {
return () => {
server.middlewares.use(async (_, res, next) => {
const output = await (
await fetch('http://localhost:1865/auth/token', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({
username: 'admin',
password: 'admin',
}),
})
).json()
res.setHeader('Set-Cookie', `ccat_user_token=${output.access_token}`)
next()
})
}
},
},
],
test: {
environment: 'jsdom',
globals: true,
exclude: [...configDefaults.exclude, 'e2e/*'],
},
server: {
port: 3000,
open: false,
host: true,
},
build: {
outDir: 'dist',
assetsDir: 'assets',
cssCodeSplit: false,
rollupOptions: {
output: {
minifyInternalExports: true,
entryFileNames: 'assets/cat.js',
assetFileNames: info => `assets/${info.name?.endsWith('css') ? 'cat' : '[name]'}[extname]`,
chunkFileNames: 'chunk.js',
manualChunks: () => 'chunk.js',
generatedCode: {
preset: 'es2015',
constBindings: true,
objectShorthand: true,
},
},
},
},
})