vite.config.js 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. import path from 'path'
  2. import { defineConfig } from 'vite'
  3. import vue from '@vitejs/plugin-vue'
  4. import vueJsx from '@vitejs/plugin-vue-jsx'
  5. import AutoImport from 'unplugin-auto-import/vite'
  6. import Components from 'unplugin-vue-components/vite'
  7. import Icons from 'unplugin-icons/vite'
  8. // import basicSsl from '@vitejs/plugin-basic-ssl'
  9. import Unocss from 'unocss/vite'
  10. import { presetUno, presetAttributify, presetIcons } from 'unocss'
  11. import { PrimeVueResolver } from '@primevue/auto-import-resolver'
  12. // https://vitejs.dev/config/
  13. export default ({ mode, command }) => {
  14. // const env = loadEnv(mode, process.cwd())
  15. return defineConfig({
  16. base: './',
  17. build: {
  18. outDir: 'dist',
  19. sourcemap: false,
  20. minify: true,
  21. emptyOutDir: true,
  22. rollupOptions: {
  23. output: {
  24. chunkFileNames: 'js/[hash].js',
  25. entryFileNames: 'js/[hash].js',
  26. assetFileNames: (assetsFile) => {
  27. if (/\.(vue|scss)$/i.test(assetsFile.name)) {
  28. return 'del/[name]-[hash].[ext]'
  29. } else {
  30. return 'static/[hash].[ext]'
  31. }
  32. }
  33. }
  34. }
  35. },
  36. plugins: [
  37. vue(),
  38. vueJsx(),
  39. // basicSsl(),
  40. Unocss({
  41. presets: [presetUno(), presetAttributify(), presetIcons()]
  42. }),
  43. AutoImport({
  44. imports: [
  45. 'vue',
  46. 'vue-router',
  47. 'pinia',
  48. '@vueuse/core',
  49. {
  50. '@/api': ['useRequest']
  51. },
  52. {
  53. '@/locales': ['useI18n', 'locale']
  54. }
  55. ],
  56. eslintrc: {
  57. enabled: false, // Default `false`
  58. filepath: './.eslintrc-auto-import.json', // Default `./.eslintrc-auto-import.json`
  59. globalsPropValue: true // Default `true`, (true | false | 'readonly' | 'readable' | 'writable' | 'writeable')
  60. }
  61. }),
  62. Components({
  63. dirs: ['src/components'],
  64. dts: false,
  65. resolvers: [PrimeVueResolver()],
  66. include: [/\.vue$/, /\.vue\?vue/, /\.jsx$/]
  67. }),
  68. Icons({
  69. compiler: 'vue3'
  70. })
  71. ],
  72. resolve: {
  73. alias: {
  74. '@': path.resolve(__dirname, 'src'),
  75. assets: path.resolve(__dirname, 'src/assets'),
  76. util: path.resolve(__dirname, 'src/util'),
  77. views: path.resolve(__dirname, 'src/views'),
  78. layout: path.resolve(__dirname, 'src/layout'),
  79. 'vue-i18n': 'vue-i18n/dist/vue-i18n.cjs.js'
  80. }
  81. },
  82. preprocessorOptions: {
  83. scss: {
  84. // additionalData: `@import "@/assets/base.scss";`
  85. }
  86. },
  87. define: {
  88. __DEV__: mode === 'development',
  89. __TEST__: mode === 'test'
  90. }
  91. // server:{
  92. // proxy:{
  93. // '/alarm':{
  94. // target: 'https://127.0.0.1',
  95. // changeOrigin: true,
  96. // rewrite: (path) => path.replace(/^api/, ''),
  97. // }
  98. // }
  99. // }
  100. })
  101. }