generated from moreant/vite-vue-template
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathvite.config.ts
More file actions
76 lines (71 loc) · 1.81 KB
/
vite.config.ts
File metadata and controls
76 lines (71 loc) · 1.81 KB
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
import { resolve } from 'path'
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import replace from '@rollup/plugin-replace'
import { VitePWA, VitePWAOptions } from 'vite-plugin-pwa'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { NaiveUiResolver } from 'unplugin-vue-components/resolvers'
import UnoCSS from 'unocss/vite'
const replaceOptions = {
__DATA__: new Date().toLocaleString('zh-CN', { hour12: false, timeZone: 'Asia/Shanghai' })
}
const pwaOptions: Partial<VitePWAOptions> = {
registerType: 'prompt',
includeAssets: ['favicon.ico', 'apple-touch-icon.png', 'masked-icon.svg'],
manifest: {
name: 'Devify - tools for web developers',
short_name: 'Devify',
description: 'tools for web developers',
theme_color: '#2563eb',
background_color: '#2563eb',
display: 'fullscreen',
icons: [
{
src: 'pwa-192x192.png',
sizes: '192x192',
type: 'image/png'
},
{
src: 'pwa-512x512.png',
sizes: '512x512',
type: 'image/png'
}
]
},
devOptions: {
enabled: true,
type: 'module',
navigateFallback: 'index.html',
navigateFallbackAllowlist: [/^index.html$/]
}
}
// https://vitejs.dev/config/
export default defineConfig({
plugins: [
vue(),
UnoCSS(),
AutoImport({
imports: [
'vue',
'vue-router',
'@vueuse/core',
{ 'naive-ui': ['useDialog', 'useMessage', 'useNotification', 'useLoadingBar'] }
]
}),
Components({
dirs: ['src/components', 'src/layout'],
resolvers: [NaiveUiResolver()]
}),
VitePWA(pwaOptions),
replace(replaceOptions)
],
server: {
host: true
},
resolve: {
alias: {
'@': resolve(__dirname, './src')
}
}
})