| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- import { getPluginsList } from "./build/plugins";
- import { include, exclude } from "./build/optimize";
- import { type UserConfigExport, type ConfigEnv, loadEnv } from "vite";
- import {
- root,
- alias,
- wrapperEnv,
- pathResolve,
- __APP_INFO__
- } from "./build/utils";
- export default ({ mode }: ConfigEnv): UserConfigExport => {
- const { VITE_CDN, VITE_PORT, VITE_COMPRESSION, VITE_PUBLIC_PATH } =
- wrapperEnv(loadEnv(mode, root));
-
- // 统一的后端服务地址
- const API_BASE_URL = "http://localhost:7070/admin";
-
- // 需要代理的 API 路径列表
- const apiPaths = [
- "/login",
- "/user",
- "/role",
- "/permission",
- "/users",
- "/shops",
- "/devices",
- "/order",
- "/products",
- "/inventory",
- "/marketing",
- "/checkin",
- "/announcement",
- "/operation-log",
- "/sync",
- "/new-product-apply",
- "/dashboard",
- "/dict",
- "/timed-discount",
- "/layer-templates",
- "/distribution",
- "/refund",
- "/replenishers",
- "/menu"
- ];
-
- // 动态生成代理配置
- const proxyConfig: Record<string, any> = {};
- apiPaths.forEach(path => {
- proxyConfig[path] = {
- target: API_BASE_URL,
- changeOrigin: true,
- rewrite: (p: string) => p.replace(new RegExp(`^${path}`), path)
- };
- });
-
- return {
- base: VITE_PUBLIC_PATH,
- root,
- resolve: {
- alias
- },
- // 服务端渲染
- server: {
- port: 8888,
- host: "0.0.0.0",
- proxy: proxyConfig,
- // 预热文件以提前转换和缓存结果,降低启动期间的初始页面加载时长并防止转换瀑布
- warmup: {
- clientFiles: ["./index.html", "./src/{views,components}/*"]
- }
- },
- plugins: getPluginsList(VITE_CDN, VITE_COMPRESSION),
- // https://cn.vitejs.dev/config/dep-optimization-options.html#dep-optimization-options
- optimizeDeps: {
- include,
- exclude
- },
- build: {
- // https://cn.vitejs.dev/guide/build.html#browser-compatibility
- target: "es2015",
- sourcemap: false,
- // 消除打包大小超过500kb警告
- chunkSizeWarningLimit: 4000,
- rollupOptions: {
- input: {
- index: pathResolve("./index.html", import.meta.url)
- },
- // 静态资源分类打包
- output: {
- chunkFileNames: "static/js/[name]-[hash].js",
- entryFileNames: "static/js/[name]-[hash].js",
- assetFileNames: "static/[ext]/[name]-[hash].[ext]"
- }
- }
- },
- define: {
- __INTLIFY_PROD_DEVTOOLS__: false,
- __APP_INFO__: JSON.stringify(__APP_INFO__)
- }
- };
- };
|