178 lines
21 KiB
JavaScript
178 lines
21 KiB
JavaScript
// 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 = /<svg([^>+].*?)>/;
|
|
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 `<symbol id="${idPerfix}-${dirent.name.replace(".svg", "")}" ${content}>`;
|
|
}).replace("</svg>", "</symbol>");
|
|
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(
|
|
"<body>",
|
|
`
|
|
<body>
|
|
<svg id="local-icon" data-icon-name="${iconNames.join(
|
|
","
|
|
)}" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" style="position: absolute; width: 0; height: 0">
|
|
${res.join("")}
|
|
</svg>
|
|
`
|
|
);
|
|
}
|
|
};
|
|
};
|
|
|
|
// 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": []
}

|