vite.config.ts 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. import dayjs from "dayjs";
  2. import { resolve } from "path";
  3. import pkg from "./package.json";
  4. import { warpperEnv, regExps } from "./build";
  5. import { getPluginsList } from "./build/plugins";
  6. import { UserConfigExport, ConfigEnv, loadEnv } from "vite";
  7. import { createHash } from "crypto"
  8. // 当前执行node命令时文件夹的地址(工作目录)
  9. const root: string = process.cwd();
  10. // 路径查找
  11. const pathResolve = (dir: string): string => {
  12. return resolve(__dirname, ".", dir);
  13. };
  14. // 设置别名
  15. const alias: Record<string, string> = {
  16. "/@": pathResolve("src"),
  17. "@build": pathResolve("build"),
  18. "@views": pathResolve("src/views")
  19. };
  20. const { dependencies, devDependencies, name, version } = pkg;
  21. const __APP_INFO__ = {
  22. pkg: { dependencies, devDependencies, name, version },
  23. lastBuildTime: dayjs(new Date()).format("YYYY-MM-DD HH:mm:ss")
  24. };
  25. export default ({ command, mode }: ConfigEnv): UserConfigExport => {
  26. const {
  27. VITE_PORT,
  28. VITE_LEGACY,
  29. VITE_PUBLIC_PATH,
  30. VITE_PROXY_DOMAIN,
  31. VITE_PROXY_DOMAIN_REAL
  32. } = warpperEnv(loadEnv(mode, root));
  33. return {
  34. base: VITE_PUBLIC_PATH,
  35. root,
  36. resolve: {
  37. alias
  38. },
  39. // 服务端渲染
  40. server: {
  41. // 是否开启 https
  42. https: false,
  43. // 端口号
  44. port: VITE_PORT,
  45. host: "0.0.0.0",
  46. // 本地跨域代理
  47. proxy:
  48. VITE_PROXY_DOMAIN_REAL.length > 0
  49. ? {
  50. [VITE_PROXY_DOMAIN]: {
  51. target: VITE_PROXY_DOMAIN_REAL,
  52. // ws: true,
  53. changeOrigin: true,
  54. rewrite: (path: string) => regExps(path, VITE_PROXY_DOMAIN)
  55. }
  56. }
  57. : null
  58. },
  59. plugins: getPluginsList(command, VITE_LEGACY),
  60. optimizeDeps: {
  61. include: ["pinia", "lodash-es", "@vueuse/core"],
  62. exclude: ["@pureadmin/theme/dist/browser-utils"]
  63. },
  64. build: {
  65. rollupOptions: {
  66. output: {
  67. entryFileNames: 'assets/[name].js',
  68. chunkFileNames: chunkInfo => {
  69. if (chunkInfo.isDynamicEntry) {
  70. const hash = createHash('sha256')
  71. .update(Object.values(chunkInfo.modules).map(m => m.code).join())
  72. .digest('hex')
  73. .substr(0, 6)
  74. return 'assets/[name].' + hash + '.js'
  75. } else {
  76. return 'assets/[name].[hash].js'
  77. }
  78. }
  79. }
  80. }
  81. },
  82. define: {
  83. __INTLIFY_PROD_DEVTOOLS__: false,
  84. __APP_INFO__: JSON.stringify(__APP_INFO__)
  85. }
  86. };
  87. };