¶Ô±ÈÐÂÎļþ |
| | |
| | | /* |
| | | * Copyright (c) 2018-2028, Chill Zhuang All rights reserved. |
| | | * |
| | | * Redistribution and use in source and binary forms, with or without |
| | | * modification, are permitted provided that the following conditions are met: |
| | | * |
| | | * Redistributions of source code must retain the above copyright notice, |
| | | * this list of conditions and the following disclaimer. |
| | | * Redistributions in binary form must reproduce the above copyright |
| | | * notice, this list of conditions and the following disclaimer in the |
| | | * documentation and/or other materials provided with the distribution. |
| | | * Neither the name of the dreamlu.net developer nor the names of its |
| | | * contributors may be used to endorse or promote products derived from |
| | | * this software without specific prior written permission. |
| | | * Author: Chill åºéª (smallchill@163.com) |
| | | */ |
| | | package org.springblade.develop.support; |
| | | |
| | | import com.baomidou.mybatisplus.core.toolkit.IdWorker; |
| | | import com.baomidou.mybatisplus.core.toolkit.StringPool; |
| | | import com.baomidou.mybatisplus.generator.config.OutputFile; |
| | | import com.baomidou.mybatisplus.generator.config.builder.CustomFile; |
| | | import com.baomidou.mybatisplus.generator.config.po.TableInfo; |
| | | import com.baomidou.mybatisplus.generator.engine.BeetlTemplateEngine; |
| | | import lombok.AllArgsConstructor; |
| | | import org.springblade.core.tool.utils.StringUtil; |
| | | |
| | | import java.io.File; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | |
| | | /** |
| | | * ä»£ç æ¨¡ççæå®ç°ç±» |
| | | * |
| | | * @author Chill |
| | | */ |
| | | @AllArgsConstructor |
| | | public class BladeTemplateEngine extends BeetlTemplateEngine { |
| | | |
| | | private String outputDir; |
| | | private String outputWebDir; |
| | | |
| | | @Override |
| | | protected void outputCustomFile(List<CustomFile> customFiles, TableInfo tableInfo, Map<String, Object> objectMap) { |
| | | String packageName = String.valueOf(objectMap.get("packageName")); |
| | | String serviceCode = String.valueOf(objectMap.get("serviceCode")); |
| | | String modelCode = String.valueOf(objectMap.get("modelCode")); |
| | | String entityName = String.valueOf(objectMap.get("modelClass")); |
| | | String entityNameLower = entityName.toLowerCase(); |
| | | |
| | | customFiles.forEach(customFile -> { |
| | | String key = customFile.getFileName(); |
| | | String value = customFile.getTemplatePath(); |
| | | String outputPath = getPathInfo(OutputFile.parent); |
| | | objectMap.put("entityKey", entityNameLower); |
| | | if (StringUtil.equals(key, "menu.sql")) { |
| | | objectMap.put("menuId", IdWorker.getId()); |
| | | objectMap.put("addMenuId", IdWorker.getId()); |
| | | objectMap.put("editMenuId", IdWorker.getId()); |
| | | objectMap.put("removeMenuId", IdWorker.getId()); |
| | | objectMap.put("viewMenuId", IdWorker.getId()); |
| | | outputPath = outputDir + StringPool.SLASH + "sql" + StringPool.SLASH + entityNameLower + ".menu.sql"; |
| | | } |
| | | if (StringUtil.equals(key, "entityVO.java")) { |
| | | outputPath = outputDir + StringPool.SLASH + packageName.replace(StringPool.DOT, StringPool.SLASH) + StringPool.SLASH + "vo" + StringPool.SLASH + entityName + "VO" + StringPool.DOT_JAVA; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "entityDTO.java")) { |
| | | outputPath = outputDir + StringPool.SLASH + packageName.replace(StringPool.DOT, StringPool.SLASH) + StringPool.SLASH + "dto" + StringPool.SLASH + entityName + "DTO" + StringPool.DOT_JAVA; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "wrapper.java")) { |
| | | outputPath = outputDir + StringPool.SLASH + packageName.replace(StringPool.DOT, StringPool.SLASH) + StringPool.SLASH + "wrapper" + StringPool.SLASH + entityName + "Wrapper" + StringPool.DOT_JAVA; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "feign.java")) { |
| | | outputPath = outputDir + StringPool.SLASH + packageName.replace(StringPool.DOT, StringPool.SLASH) + StringPool.SLASH + "feign" + StringPool.SLASH + "I" + entityName + "Client" + StringPool.DOT_JAVA; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "feignclient.java")) { |
| | | outputPath = outputDir + StringPool.SLASH + packageName.replace(StringPool.DOT, StringPool.SLASH) + StringPool.SLASH + "feign" + StringPool.SLASH + entityName + "Client" + StringPool.DOT_JAVA; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "action.js")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "actions" + StringPool.SLASH + entityNameLower + ".js"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "model.js")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "models" + StringPool.SLASH + entityNameLower + ".js"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "service.js")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "services" + StringPool.SLASH + entityNameLower + ".js"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "list.js")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "pages" + StringPool.SLASH + StringUtil.firstCharToUpper(modelCode) + StringPool.SLASH + entityName + StringPool.SLASH + entityName + ".js"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "add.js")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "pages" + StringPool.SLASH + StringUtil.firstCharToUpper(modelCode) + StringPool.SLASH + entityName + StringPool.SLASH + entityName + "Add.js"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "edit.js")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "pages" + StringPool.SLASH + StringUtil.firstCharToUpper(modelCode) + StringPool.SLASH + entityName + StringPool.SLASH + entityName + "Edit.js"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "view.js")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "pages" + StringPool.SLASH + StringUtil.firstCharToUpper(modelCode) + StringPool.SLASH + entityName + StringPool.SLASH + entityName + "View.js"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "api.js")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "api" + StringPool.SLASH + serviceCode + StringPool.SLASH + modelCode + ".js"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "const.js")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "const" + StringPool.SLASH + serviceCode + StringPool.SLASH + modelCode + ".js"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "crud.vue")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "views" + StringPool.SLASH + serviceCode + StringPool.SLASH + modelCode + ".vue"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "sub.vue")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "views" + StringPool.SLASH + serviceCode + StringPool.SLASH + modelCode + "Sub.vue"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "data.ts")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "api" + StringPool.SLASH + serviceCode + StringPool.SLASH + modelCode + ".ts"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "data.data.ts")) { |
| | | |
| | | outputPath = outputWebDir + StringPool.SLASH + "views" + StringPool.SLASH + serviceCode + StringPool.SLASH + modelCode + StringPool.SLASH + modelCode + ".data.ts"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "index.vue")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "views" + StringPool.SLASH + serviceCode + StringPool.SLASH + modelCode + StringPool.SLASH + "index.vue"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "Modal.vue")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "views" + StringPool.SLASH + serviceCode + StringPool.SLASH + modelCode + StringPool.SLASH + entityName + "Modal.vue"; |
| | | } |
| | | |
| | | if (StringUtil.equals(key, "lemonSub.vue")) { |
| | | outputPath = outputWebDir + StringPool.SLASH + "views" + StringPool.SLASH + serviceCode + StringPool.SLASH + modelCode + StringPool.SLASH + entityName + "Sub.vue"; |
| | | } |
| | | outputFile(new File(String.valueOf(outputPath)), objectMap, value, Boolean.TRUE); |
| | | }); |
| | | } |
| | | |
| | | |
| | | } |