123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- /**
- * 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'
- // ant-design-vue 的 less 变量,通过兼容包将 v4 变量转译成 v3 版本,并通过 less-loader 注入
- import { theme } from 'ant-design-vue/lib';
- import convertLegacyToken from 'ant-design-vue/lib/theme/convertLegacyToken';
- const { defaultAlgorithm, defaultSeed } = theme;
- const mapToken = defaultAlgorithm(defaultSeed);
- const v3Token = convertLegacyToken.default(mapToken);
- const time = new Date().getTime()
- export const r = (...args) => resolve(__dirname, '.', ...args)
- 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,
- __VUE_PROD_HYDRATION_MISMATCH_DETAILS__: true
- },
- build: {
- // sourcemap: true,
- outDir: "yqyc-web",
- manifest: true,
- brotliSize: false,
- rollupOptions: {
- output: {
- // manualChunks: {
- // echarts: ['echarts'],
- // 'ant-design-vue': ['ant-design-vue'],
- // vue: ['vue', 'vue-router', 'pinia', 'vue-i18n']
- // }
- manualChunks(id) {
- if (id.includes('node_modules')) {
- return time + id.toString().split('node_modules/')[1].split('/')[0].toString();
- } else {
- return time + id.toString();
- }
- // if(id.indexOf('node_modules') > -1) {
- // return 'vendor'
- // }
- }
- }
- },
- 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({
- // TODO:有必要用的情况下,是否需要传入 variables,可能会造成重复引用
- variables: { ...v3Token }
- })],
- modifyVars: v3Token
- }
- }
- },
- optimizeDeps: {}
- }
- })
|