mirror of
https://github.com/cool-team-official/cool-admin-vue.git
synced 2024-11-01 06:02:38 +08:00
70 lines
1.3 KiB
TypeScript
70 lines
1.3 KiB
TypeScript
import { Plugin } from "vite";
|
|
import { parseJson } from "./utils";
|
|
import { createEps, createMenu, createSvg, createTag, getEps, getModules } from "./lib";
|
|
|
|
export function cool(): Plugin {
|
|
return {
|
|
name: "vite-cool",
|
|
enforce: "pre",
|
|
configureServer(server) {
|
|
server.middlewares.use(async (req, res, next) => {
|
|
function done(data: any) {
|
|
res.writeHead(200, { "Content-Type": "text/html;charset=UTF-8" });
|
|
res.end(JSON.stringify(data));
|
|
}
|
|
|
|
if (req.url?.includes("__cool")) {
|
|
const body = await parseJson(req);
|
|
let next: any;
|
|
|
|
switch (req.url) {
|
|
// 快速创建菜单
|
|
case "/__cool_createMenu":
|
|
next = createMenu(body);
|
|
break;
|
|
|
|
// 获取模块列表
|
|
case "/__cool_modules":
|
|
next = getModules();
|
|
break;
|
|
|
|
// 创建描述文件
|
|
case "/__cool_eps":
|
|
next = createEps(body);
|
|
break;
|
|
}
|
|
|
|
if (next) {
|
|
next.then((data: any) => {
|
|
done({
|
|
code: 1000,
|
|
data
|
|
});
|
|
}).catch((message: string) => {
|
|
done({
|
|
code: 1001,
|
|
message
|
|
});
|
|
});
|
|
}
|
|
} else {
|
|
next();
|
|
}
|
|
});
|
|
},
|
|
transform(code, id) {
|
|
return createTag(code, id);
|
|
},
|
|
transformIndexHtml(html) {
|
|
return createSvg(html);
|
|
},
|
|
config() {
|
|
return {
|
|
define: {
|
|
__EPS__: getEps()
|
|
}
|
|
};
|
|
}
|
|
};
|
|
}
|