vite.config.js 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  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 deletePlugin from 'rollup-plugin-delete'
  9. import basicSsl from '@vitejs/plugin-basic-ssl'
  10. import Unocss from 'unocss/vite'
  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: '/background/',
  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. AutoImport({
  42. imports: [
  43. 'vue',
  44. 'vue-router',
  45. 'pinia',
  46. '@vueuse/core',
  47. {
  48. '@/api': ['useRequest']
  49. },
  50. {
  51. '@/locales': ['useI18n', 'locale']
  52. }
  53. ],
  54. eslintrc: {
  55. enabled: false, // Default `false`
  56. filepath: './.eslintrc-auto-import.json', // Default `./.eslintrc-auto-import.json`
  57. globalsPropValue: true // Default `true`, (true | false | 'readonly' | 'readable' | 'writable' | 'writeable')
  58. }
  59. }),
  60. Components({
  61. dirs: ['src/components'],
  62. dts: false,
  63. resolvers: [PrimeVueResolver()],
  64. include: [/\.vue$/, /\.vue\?vue/, /\.jsx$/]
  65. }),
  66. Icons({
  67. compiler: 'vue3'
  68. }),
  69. deletePlugin({
  70. targets: ['dist/del'],
  71. hook: 'writeBundle'
  72. })
  73. ],
  74. resolve: {
  75. alias: {
  76. '@': path.resolve(__dirname, 'src'),
  77. assets: path.resolve(__dirname, 'src/assets'),
  78. util: path.resolve(__dirname, 'src/util'),
  79. views: path.resolve(__dirname, 'src/views'),
  80. layout: path.resolve(__dirname, 'src/layout'),
  81. 'vue-i18n': 'vue-i18n/dist/vue-i18n.cjs.js'
  82. }
  83. },
  84. preprocessorOptions: {
  85. scss: {
  86. // additionalData: `@import "@/assets/base.scss";`
  87. }
  88. },
  89. define: {
  90. __DEV__: mode === 'development',
  91. __TEST__: mode === 'test'
  92. }
  93. // server:{
  94. // proxy:{
  95. // '/alarm':{
  96. // target: 'https://127.0.0.1',
  97. // changeOrigin: true,
  98. // rewrite: (path) => path.replace(/^api/, ''),
  99. // }
  100. // }
  101. // }
  102. })
  103. }