vite.config.ts 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. import { fileURLToPath, URL } from 'node:url'
  2. import path from 'path'
  3. import { defineConfig, loadEnv, splitVendorChunkPlugin } from 'vite'
  4. import vue from '@vitejs/plugin-vue'
  5. import vueJsx from '@vitejs/plugin-vue-jsx'
  6. import AutoImport from 'unplugin-auto-import/vite'
  7. import Components from 'unplugin-vue-components/vite'
  8. import DefineOptions from 'unplugin-vue-define-options/vite'
  9. import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'
  10. import Unocss from 'unocss/vite'
  11. export default defineConfig(({ mode }) => {
  12. const env = loadEnv(mode, process.cwd(), '')
  13. return {
  14. plugins: [
  15. vue(),
  16. vueJsx(),
  17. Unocss(),
  18. DefineOptions(),
  19. AutoImport({
  20. imports: ['vue', 'vue-router', 'pinia', '@vueuse/core'],
  21. dts: 'src/auto-import.d.ts'
  22. }),
  23. Components({
  24. dirs: ['src/components'],
  25. extensions: ['vue'],
  26. dts: 'src/components.d.ts'
  27. }),
  28. createSvgIconsPlugin({
  29. iconDirs: [path.resolve(process.cwd(), 'src/assets/svg')],
  30. symbolId: 'icon-[dir]-[name]'
  31. }),
  32. splitVendorChunkPlugin()
  33. ],
  34. resolve: {
  35. alias: {
  36. '@': fileURLToPath(new URL('./src', import.meta.url))
  37. }
  38. },
  39. server: {
  40. proxy: {
  41. [env.VITE_BASE_API]: {
  42. target: env.VITE_BASE_PATH,
  43. changeOrigin: true
  44. }
  45. }
  46. }
  47. }
  48. })