You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
snowy/snowy-admin-web/vite.config.js

120 lines
3.1 KiB

/**
* Copyright [2022] [https://www.xiaonuo.vip]
* Snowy采用APACHE LICENSE 2.0开源协议您在使用过程中需要注意以下几点
* 1.请不要删除和修改根目录下的LICENSE文件
* 2.请不要删除和修改Snowy源码头部的版权声明
* 3.本项目代码可免费商业使用商业使用请保留源码和相关描述文件的项目出处作者声明等
* 4.分发源码时候请注明软件出处 https://www.xiaonuo.vip
* 5.不可二次分发开源参与同类竞品如有想法可联系团队xiaonuobase@qq.com商议合作
* 6.若您的项目无法满足以上几点需要更多功能代码获取Snowy商业授权许可请在官网购买授权地址为 https://www.xiaonuo.vip
*/
import { resolve } from 'path'
import { defineConfig, loadEnv } from 'vite'
import vue from '@vitejs/plugin-vue'
import Components from 'unplugin-vue-components/vite'
import VueJSX from '@vitejs/plugin-vue-jsx'
import AutoImport from 'unplugin-auto-import/vite'
import vueSetupExtend from 'vite-plugin-vue-setup-extend'
import { visualizer } from 'rollup-plugin-visualizer'
import Less2CssVariablePlugin from 'antd-less-to-css-variable'
import viteCompression from 'vite-plugin-compression'
export const r = (...args) => resolve(__dirname, '.', ...args)
const removeModulePreloadPlugin = (keys) => {
if (!keys || !keys.length) {
return
}
return {
name: 'remove-module-preload',
transformIndexHtml: {
enforce: 'after',
transform(html, ctx) {
let result = html
keys.forEach((key) => {
result = result.replace(new RegExp(`<link rel="modulepreload"?.*${key}?.*`), '')
})
return result
}
}
}
}
export default defineConfig(({ command, mode }) => {
const envConfig = loadEnv(mode, './')
const alias = {
'~': `${resolve(__dirname, './')}`,
'@/': `${resolve(__dirname, 'src')}/`
}
return {
server: {
port: envConfig.VITE_PORT,
proxy: {
'/api': {
target: envConfig.VITE_API_BASEURL,
ws: false,
changeOrigin: true,
rewrite: (path) => path.replace(/^\/api/, '')
}
}
},
resolve: {
alias
},
// 解决警告You are running the esm-bundler build of vue-i18n.
define: {
__VUE_I18N_FULL_INSTALL__: true,
__VUE_I18N_LEGACY_API__: true,
__VUE_I18N_PROD_DEVTOOLS__: true
},
build: {
// sourcemap: true,
manifest: true,
brotliSize: false,
rollupOptions: {
output: {
manualChunks: {
echarts: ['echarts'],
'ant-design-vue': ['ant-design-vue'],
vue: ['vue', 'vue-router', 'vuex', 'vue-i18n']
}
}
},
chunkSizeWarningLimit: 1000
},
plugins: [
vue({
script: {
refTransform: true
}
}),
viteCompression(),
vueSetupExtend(),
VueJSX(),
AutoImport({
imports: ['vue'],
dirs: ['./src/utils/permission'],
dts: r('src/auto-imports.d.ts')
}),
// 组件按需引入
Components({
dirs: [r('src/components')],
dts: false,
resolvers: []
}),
visualizer()
],
css: {
preprocessorOptions: {
less: {
javascriptEnabled: true,
plugins: [new Less2CssVariablePlugin()]
}
}
},
optimizeDeps: {}
}
})