This repository has been archived by the owner on Jul 16, 2024. It is now read-only.
generated from wtchnm/Vitamin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvite.config.ts
118 lines (116 loc) · 2.32 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
/// <reference types="vitest" />
import eslintPlugin from '@nabla/vite-plugin-eslint'
import react from '@vitejs/plugin-react'
import { defineConfig } from 'vite'
import vitePluginImp from 'vite-plugin-imp'
import { viteMockServe } from 'vite-plugin-mock'
import { VitePWA } from 'vite-plugin-pwa'
import tsconfigPaths from 'vite-tsconfig-paths'
export default defineConfig(({ mode }) => {
let proxy
if (mode === 'development') {
proxy = {
'/api': {
target: 'http://127.0.0.1:34765/',
changeOrigin: true
}
}
} else if (mode === 'staging') {
proxy = {
'/api': {
target: 'http://nichujie.xyz/',
changeOrigin: true
}
}
}
return {
server: {
proxy
},
test: {
include: ['src/**/__tests__/*'],
globals: true,
environment: 'jsdom',
setupFiles: 'src/setupTests.ts',
clearMocks: true,
coverage: {
enabled: true,
'100': true,
reporter: ['text', 'lcov'],
reportsDirectory: 'coverage/jest'
}
},
plugins: [
tsconfigPaths(),
react(),
...(mode !== 'test'
? [
eslintPlugin(),
VitePWA({
registerType: 'autoUpdate',
includeAssets: [
'favicon.png',
'robots.txt',
'apple-touch-icon.png',
'icons/*.svg',
'fonts/*.woff2'
],
manifest: {
theme_color: '#BD34FE',
icons: [
{
src: '/android-chrome-192x192.png',
sizes: '192x192',
type: 'image/png',
purpose: 'any maskable'
},
{
src: '/android-chrome-512x512.png',
sizes: '512x512',
type: 'image/png'
}
]
}
})
]
: []),
vitePluginImp({
libList: [
{
libName: 'antd',
style: (name): string => {
if (name === 'col' || name === 'row') {
return 'antd/es/grid/style/index.less'
}
return `antd/es/${name}/style/index.less`
}
}
]
}),
viteMockServe({
mockPath: 'mock',
localEnabled: mode === 'mock',
prodEnabled: false
})
],
css: {
modules: {
localsConvention: 'camelCaseOnly'
},
preprocessorOptions: {
less: {
javascriptEnabled: true,
modifyVars: {
'@primary-color': '#6543a9',
'@border-radius-base': '6px'
}
}
}
},
resolve: {
alias: {
'~antd': 'antd'
}
}
}
})