Files
electron-4/electron.vite.config.ts

57 lines
1.6 KiB
TypeScript
Raw Normal View History

2025-10-31 11:01:59 +08:00
import {resolve} from 'path'
import {defineConfig, externalizeDepsPlugin} from 'electron-vite'
2025-08-29 09:35:52 +08:00
import vue from '@vitejs/plugin-vue'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
2025-10-31 11:01:59 +08:00
import {ElementPlusResolver} from 'unplugin-vue-components/resolvers'
import {createSvgIconsPlugin} from 'vite-plugin-svg-icons'
2025-08-29 09:35:52 +08:00
import path from 'path'
export default defineConfig({
main: {
plugins: [externalizeDepsPlugin()]
},
preload: {
plugins: [externalizeDepsPlugin()]
},
renderer: {
resolve: {
alias: {
'@renderer': resolve('src/renderer/src'),
'@': resolve('src/renderer/src')
}
},
plugins: [
vue(),
AutoImport({
imports: ['vue'],
dts: 'src/auto-imports.d.ts', // 自动生成类型声明文件
resolvers: [ElementPlusResolver()]
}),
Components({
resolvers: [ElementPlusResolver()]
}),
// SVG图标插件配置
// 配置SVG图标插件
createSvgIconsPlugin({
iconDirs: [path.resolve(process.cwd(), 'src/renderer/src/icons/svg')],
symbolId: 'icon-[name]',
// 自动清除 SVG 中的 fill 和 stroke 属性
svgoOptions: {
2025-10-31 11:01:59 +08:00
plugins: [{name: 'removeAttrs', params: {attrs: ['fill', 'stroke', 'stroke-width']}}]
2025-08-29 09:35:52 +08:00
}
})
2025-10-31 11:01:59 +08:00
],
/*server: {
port: 8848,
proxy: {
'/api': {
target: localStorage.getItem('ip') || 'http://127.0.0.1:8848',
changeOrigin: true,
rewrite: (path) => path.replace(/^\/api/, '')
}
}
}*/
2025-08-29 09:35:52 +08:00
}
})