// vite.config.ts import vue from "file:///E:/softstoneFile/ry-das/ui/dasadmin/node_modules/@vitejs/plugin-vue/dist/index.mjs"; import { resolve } from "path"; import { loadEnv } from "file:///E:/softstoneFile/ry-das/ui/dasadmin/node_modules/vite/dist/node/index.js"; // src/utils/vite.ts var customHotUpdate = () => { const closeHmr = /* @__PURE__ */ new Map(); return { name: "vite-plugin-custom-hot-update", configureServer(server) { server.ws.on("custom:close-hot", (data) => { closeHmr.set(data.type, true); server.watcher.removeAllListeners("add"); server.watcher.removeAllListeners("unlink"); }); server.ws.on("custom:open-hot", (data) => { closeHmr.set(data.type, false); server.watcher.on("add", () => { server.restart(); }); server.watcher.on("unlink", () => { server.restart(); }); }); server.ws.on("custom:reload-hot", () => { server.restart(); }); }, handleHotUpdate() { const closeHmrs = Array.from(closeHmr.values()); let closeHmrsBool = false; for (const key in closeHmrs) { closeHmrsBool = closeHmrsBool || closeHmrs[key]; } if (closeHmrsBool) return []; } }; }; // src/components/icon/svg/index.ts import { readFileSync, readdirSync } from "fs"; var idPerfix = ""; var iconNames = []; var svgTitle = /+].*?)>/; var clearHeightWidth = /(width|height)="([^>+].*?)"/g; var hasViewBox = /(viewBox="[^>+].*?")/g; var clearReturn = /(\r)|(\n)/g; var clearFill = /(fill="[^>+].*?")/g; function findSvgFile(dir) { const svgRes = []; const dirents = readdirSync(dir, { withFileTypes: true }); for (const dirent of dirents) { iconNames.push(`${idPerfix}-${dirent.name.replace(".svg", "")}`); if (dirent.isDirectory()) { svgRes.push(...findSvgFile(dir + dirent.name + "/")); } else { const svg = readFileSync(dir + dirent.name).toString().replace(clearReturn, "").replace(clearFill, 'fill=""').replace(svgTitle, ($1, $2) => { let width = 0; let height = 0; let content = $2.replace(clearHeightWidth, (s1, s2, s3) => { if (s2 === "width") { width = s3; } else if (s2 === "height") { height = s3; } return ""; }); if (!hasViewBox.test($2)) { content += `viewBox="0 0 ${width} ${height}"`; } return ``; }).replace("", ""); svgRes.push(svg); } } return svgRes; } var svgBuilder = (path, perfix = "local") => { if (path === "") return; idPerfix = perfix; const res = findSvgFile(path); return { name: "svg-transform", transformIndexHtml(html) { return html.replace( "", ` ${res.join("")} ` ); } }; }; // vite.config.ts var __vite_injected_original_dirname = "E:\\softstoneFile\\ry-das\\ui\\dasadmin"; var pathResolve = (dir) => { return resolve(__vite_injected_original_dirname, ".", dir); }; var viteConfig = ({ mode }) => { const { VITE_PORT, VITE_OPEN, VITE_BASE_PATH, VITE_OUT_DIR, VITE_APP_PROXY } = loadEnv(mode, process.cwd()); const alias = { "/@": pathResolve("./src/"), assets: pathResolve("./src/assets"), "vue-i18n": "vue-i18n/dist/vue-i18n.cjs.js" }; const createProxy = (proxyList) => { const ret = {}; if (proxyList) { proxyList = JSON.parse(proxyList); for (const [prefix, target] of proxyList) { ret[prefix] = { target, changeOrigin: true, rewrite: (path) => path.replace(new RegExp(`^${prefix}`), "") }; } } return ret; }; return { plugins: [vue(), svgBuilder("./src/assets/icons/"), customHotUpdate()], root: process.cwd(), resolve: { alias }, base: VITE_BASE_PATH, server: { port: parseInt(VITE_PORT), open: VITE_OPEN != "false", proxy: { ...createProxy(VITE_APP_PROXY) } }, build: { cssCodeSplit: false, sourcemap: false, outDir: VITE_OUT_DIR, emptyOutDir: true, chunkSizeWarningLimit: 1500, terserOptions: { compress: { keep_infinity: true, // Used to delete console in production environment drop_console: true, drop_debugger: true }, output: { comments: true // 去掉注释内容 } }, rollupOptions: { output: { manualChunks: { // 分包配置,配置完成自动按需加载 vue: ["vue", "vue-router", "pinia", "vue-i18n", "element-plus"], echarts: ["echarts"] } } } } }; }; var vite_config_default = viteConfig; export { vite_config_default as default }; //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.ts", "src/utils/vite.ts", "src/components/icon/svg/index.ts"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"E:\\\\softstoneFile\\\\ry-das\\\\ui\\\\dasadmin\";const __vite_injected_original_filename = \"E:\\\\softstoneFile\\\\ry-das\\\\ui\\\\dasadmin\\\\vite.config.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/softstoneFile/ry-das/ui/dasadmin/vite.config.ts\";import vue from '@vitejs/plugin-vue'\r\nimport { resolve } from 'path'\r\nimport { loadEnv } from 'vite'\r\nimport type { UserConfig, ConfigEnv, ProxyOptions } from 'vite'\r\nimport { isProd, customHotUpdate } from '/@/utils/vite'\r\nimport { svgBuilder } from '/@/components/icon/svg/index'\r\n\r\nconst pathResolve = (dir: string): any => {\r\n    return resolve(__dirname, '.', dir)\r\n}\r\n\r\n// https://vitejs.cn/config/\r\nconst viteConfig = ({ mode }: ConfigEnv): UserConfig => {\r\n    const { VITE_PORT, VITE_OPEN, VITE_BASE_PATH, VITE_OUT_DIR, VITE_APP_PROXY } = loadEnv(mode, process.cwd())\r\n\r\n    const alias: Record<string, string> = {\r\n        '/@': pathResolve('./src/'),\r\n        assets: pathResolve('./src/assets'),\r\n        'vue-i18n': 'vue-i18n/dist/vue-i18n.cjs.js',\r\n    }\r\n\r\n    const createProxy = (proxyList: any) => {\r\n        const ret = {} as Record<string, ProxyOptions>\r\n        if (proxyList) {\r\n            proxyList = JSON.parse(proxyList)\r\n            for (const [prefix, target] of proxyList) {\r\n                ret[prefix] = {\r\n                    target: target,\r\n                    changeOrigin: true,\r\n                    rewrite: (path) => path.replace(new RegExp(`^${prefix}`), ''),\r\n                }\r\n            }\r\n        }\r\n\r\n        return ret\r\n    }\r\n\r\n    // let proxy: Record<string, string | ProxyOptions> = {}\r\n    // if (VITE_PROXY_URL) {\r\n    //     proxy = {\r\n    //         '/': {\r\n    //             target: VITE_PROXY_URL,\r\n    //             changeOrigin: true,\r\n    //         },\r\n    //     }\r\n    // }\r\n\r\n    return {\r\n        plugins: [vue(), svgBuilder('./src/assets/icons/'), customHotUpdate()],\r\n        root: process.cwd(),\r\n        resolve: { alias },\r\n        base: VITE_BASE_PATH,\r\n        server: {\r\n            port: parseInt(VITE_PORT),\r\n            open: VITE_OPEN != 'false',\r\n            proxy: {\r\n                ...createProxy(VITE_APP_PROXY),\r\n            },\r\n        },\r\n        build: {\r\n            cssCodeSplit: false,\r\n            sourcemap: false,\r\n            outDir: VITE_OUT_DIR,\r\n            emptyOutDir: true,\r\n            chunkSizeWarningLimit: 1500,\r\n            terserOptions: {\r\n                compress: {\r\n                    keep_infinity: true,\r\n                    // Used to delete console in production environment\r\n                    drop_console: true,\r\n                    drop_debugger: true,\r\n                },\r\n                output: {\r\n                    comments: true, // \u53BB\u6389\u6CE8\u91CA\u5185\u5BB9\r\n                },\r\n            },\r\n            rollupOptions: {\r\n                output: {\r\n                    manualChunks: {\r\n                        // \u5206\u5305\u914D\u7F6E\uFF0C\u914D\u7F6E\u5B8C\u6210\u81EA\u52A8\u6309\u9700\u52A0\u8F7D\r\n                        vue: ['vue', 'vue-router', 'pinia', 'vue-i18n', 'element-plus'],\r\n                        echarts: ['echarts'],\r\n                    },\r\n                },\r\n            },\r\n        },\r\n    }\r\n}\r\n\r\nexport default viteConfig\r\n", "const __vite_injected_original_dirname = \"E:\\\\softstoneFile\\\\ry-das\\\\ui\\\\dasadmin\\\\src\\\\utils\";const __vite_injected_original_filename = \"E:\\\\softstoneFile\\\\ry-das\\\\ui\\\\dasadmin\\\\src\\\\utils\\\\vite.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/softstoneFile/ry-das/ui/dasadmin/src/utils/vite.ts\";import { Plugin } from 'vite'\r\n\r\n/**\r\n * \u662F\u5426\u5728\u5F00\u53D1\u73AF\u5883\r\n */\r\nexport function isDev(mode: string): boolean {\r\n    return mode === 'development'\r\n}\r\n\r\n/**\r\n * \u662F\u5426\u5728\u751F\u4EA7\u73AF\u5883\r\n */\r\nexport function isProd(mode: string | undefined): boolean {\r\n    return mode === 'production'\r\n}\r\n\r\n/**\r\n * \u81EA\u5B9A\u4E49\u70ED\u66F4\u65B0\u5904\u7406\u63D2\u4EF6\r\n */\r\nexport const customHotUpdate = (): Plugin => {\r\n    const closeHmr = new Map<string, boolean>()\r\n\r\n    return {\r\n        name: 'vite-plugin-custom-hot-update',\r\n        configureServer(server) {\r\n            server.ws.on('custom:close-hot', (data) => {\r\n                closeHmr.set(data.type, true)\r\n\r\n                // \u5173\u95ED\u6587\u4EF6\u6DFB\u52A0\u548C\u5220\u9664\u7684\u76D1\u542C\r\n                server.watcher.removeAllListeners('add')\r\n                server.watcher.removeAllListeners('unlink')\r\n            })\r\n            server.ws.on('custom:open-hot', (data) => {\r\n                closeHmr.set(data.type, false)\r\n\r\n                server.watcher.on('add', () => {\r\n                    server.restart()\r\n                })\r\n                server.watcher.on('unlink', () => {\r\n                    server.restart()\r\n                })\r\n            })\r\n            server.ws.on('custom:reload-hot', () => {\r\n                server.restart()\r\n            })\r\n        },\r\n        handleHotUpdate() {\r\n            const closeHmrs = Array.from(closeHmr.values())\r\n            let closeHmrsBool = false\r\n            for (const key in closeHmrs) {\r\n                closeHmrsBool = closeHmrsBool || closeHmrs[key]\r\n            }\r\n            if (closeHmrsBool) return []\r\n        },\r\n    }\r\n}\r\n", "const __vite_injected_original_dirname = \"E:\\\\softstoneFile\\\\ry-das\\\\ui\\\\dasadmin\\\\src\\\\components\\\\icon\\\\svg\";const __vite_injected_original_filename = \"E:\\\\softstoneFile\\\\ry-das\\\\ui\\\\dasadmin\\\\src\\\\components\\\\icon\\\\svg\\\\index.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/softstoneFile/ry-das/ui/dasadmin/src/components/icon/svg/index.ts\";import { readFileSync, readdirSync } from 'fs'\r\n\r\nlet idPerfix = ''\r\nconst iconNames: string[] = []\r\nconst svgTitle = /<svg([^>+].*?)>/\r\nconst clearHeightWidth = /(width|height)=\"([^>+].*?)\"/g\r\nconst hasViewBox = /(viewBox=\"[^>+].*?\")/g\r\nconst clearReturn = /(\\r)|(\\n)/g\r\n// \u6E05\u7406 svg \u7684 fill\r\nconst clearFill = /(fill=\"[^>+].*?\")/g\r\n\r\nfunction findSvgFile(dir: string): string[] {\r\n    const svgRes = []\r\n    const dirents = readdirSync(dir, {\r\n        withFileTypes: true,\r\n    })\r\n    for (const dirent of dirents) {\r\n        iconNames.push(`${idPerfix}-${dirent.name.replace('.svg', '')}`)\r\n        if (dirent.isDirectory()) {\r\n            svgRes.push(...findSvgFile(dir + dirent.name + '/'))\r\n        } else {\r\n            const svg = readFileSync(dir + dirent.name)\r\n                .toString()\r\n                .replace(clearReturn, '')\r\n                .replace(clearFill, 'fill=\"\"')\r\n                .replace(svgTitle, ($1, $2) => {\r\n                    let width = 0\r\n                    let height = 0\r\n                    let content = $2.replace(clearHeightWidth, (s1: string, s2: string, s3: number) => {\r\n                        if (s2 === 'width') {\r\n                            width = s3\r\n                        } else if (s2 === 'height') {\r\n                            height = s3\r\n                        }\r\n                        return ''\r\n                    })\r\n                    if (!hasViewBox.test($2)) {\r\n                        content += `viewBox=\"0 0 ${width} ${height}\"`\r\n                    }\r\n                    return `<symbol id=\"${idPerfix}-${dirent.name.replace('.svg', '')}\" ${content}>`\r\n                })\r\n                .replace('</svg>', '</symbol>')\r\n            svgRes.push(svg)\r\n        }\r\n    }\r\n    return svgRes\r\n}\r\n\r\nexport const svgBuilder = (path: string, perfix = 'local') => {\r\n    if (path === '') return\r\n    idPerfix = perfix\r\n    const res = findSvgFile(path)\r\n    return {\r\n        name: 'svg-transform',\r\n        transformIndexHtml(html: string) {\r\n            /* eslint-disable */\r\n            return html.replace(\r\n                '<body>',\r\n                `\r\n                <body>\r\n                <svg id=\"local-icon\" data-icon-name=\"${iconNames.join(\r\n                    ','\r\n                )}\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" style=\"position: absolute; width: 0; height: 0\">\r\n                ${res.join('')}\r\n                </svg>\r\n                `\r\n            )\r\n            /* eslint-enable */\r\n        },\r\n    }\r\n}\r\n"],
  "mappings": "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",
  "names": []
}
