Нет описания

VelocityUtils.java 14KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402
  1. package com.smartSteward.service.generator;
  2. import java.util.ArrayList;
  3. import java.util.HashSet;
  4. import java.util.List;
  5. import java.util.Set;
  6. import com.alibaba.fastjson2.JSON;
  7. import com.alibaba.fastjson2.JSONObject;
  8. import com.smartSteward.common.constant.GenConstants;
  9. import com.smartSteward.common.utils.DateUtils;
  10. import com.smartSteward.common.utils.StringUtils;
  11. import com.smartSteward.entity.database.generator.GenTable;
  12. import com.smartSteward.entity.database.generator.GenTableColumn;
  13. import org.apache.velocity.VelocityContext;
  14. /**
  15. * 模板处理工具类
  16. *
  17. * @author smart-steward
  18. */
  19. public class VelocityUtils
  20. {
  21. /** 实体类路径 */
  22. private static final String PROJECT_ENTITY = "smart-steward-entity/src/main/java";
  23. /** mapper接口路径 */
  24. private static final String PROJECT_MAPPER = "smart-steward-mapper/src/main/java";
  25. /** service接口路径 */
  26. private static final String PROJECT_SERVICE = "smart-steward-service/src/main/java";
  27. /** controller路径 */
  28. private static final String PROJECT_CONTROLLER = "smart-steward-api/src/main/java";
  29. /** mybatis映射文件路径 */
  30. private static final String MYBATIS_PATH = "smart-steward-mapper/src/main/resources/mapper";
  31. /** 默认上级菜单,系统工具 */
  32. private static final String DEFAULT_PARENT_MENU_ID = "3";
  33. /**
  34. * 设置模板变量信息
  35. *
  36. * @return 模板列表
  37. */
  38. public static VelocityContext prepareContext(GenTable genTable)
  39. {
  40. String businessName = genTable.getBusinessName();
  41. String packageName = genTable.getPackageName();
  42. String tplCategory = genTable.getTplCategory();
  43. String functionName = genTable.getFunctionName();
  44. // 大写类名
  45. String className = genTable.getClassName();
  46. StringBuilder sb = new StringBuilder(className);
  47. sb.setCharAt(0, Character.toLowerCase(sb.charAt(0)));
  48. //首字母小写类名
  49. String lowerClass=sb.toString();
  50. VelocityContext velocityContext = new VelocityContext();
  51. velocityContext.put("tplCategory", genTable.getTplCategory());
  52. velocityContext.put("tableName", genTable.getTableName());
  53. velocityContext.put("functionName", StringUtils.isNotEmpty(functionName) ? functionName : "【请填写功能名称】");
  54. velocityContext.put("ClassName", genTable.getClassName());
  55. velocityContext.put("className", StringUtils.uncapitalize(genTable.getClassName()));
  56. velocityContext.put("moduleName", genTable.getModuleName());
  57. velocityContext.put("BusinessName", StringUtils.capitalize(genTable.getBusinessName()));
  58. velocityContext.put("businessName", genTable.getBusinessName());
  59. velocityContext.put("basePackage", getPackagePrefix(packageName));
  60. velocityContext.put("packageName", packageName);
  61. velocityContext.put("author", genTable.getFunctionAuthor());
  62. velocityContext.put("datetime", DateUtils.getDate());
  63. velocityContext.put("pkColumn", genTable.getPkColumn());
  64. velocityContext.put("importList", getImportList(genTable));
  65. velocityContext.put("permissionPrefix", getPermissionPrefix(lowerClass, businessName));
  66. velocityContext.put("columns", genTable.getColumns());
  67. velocityContext.put("table", genTable);
  68. velocityContext.put("dicts", getDicts(genTable));
  69. velocityContext.put("lowerClass", lowerClass);
  70. setMenuVelocityContext(velocityContext, genTable);
  71. if (GenConstants.TPL_TREE.equals(tplCategory))
  72. {
  73. setTreeVelocityContext(velocityContext, genTable);
  74. }
  75. if (GenConstants.TPL_SUB.equals(tplCategory))
  76. {
  77. setSubVelocityContext(velocityContext, genTable);
  78. }
  79. return velocityContext;
  80. }
  81. public static void setMenuVelocityContext(VelocityContext context, GenTable genTable)
  82. {
  83. String options = genTable.getOptions();
  84. JSONObject paramsObj = JSON.parseObject(options);
  85. String parentMenuId = getParentMenuId(paramsObj);
  86. context.put("parentMenuId", parentMenuId);
  87. }
  88. public static void setTreeVelocityContext(VelocityContext context, GenTable genTable)
  89. {
  90. String options = genTable.getOptions();
  91. JSONObject paramsObj = JSON.parseObject(options);
  92. String treeCode = getTreecode(paramsObj);
  93. String treeParentCode = getTreeParentCode(paramsObj);
  94. String treeName = getTreeName(paramsObj);
  95. context.put("treeCode", treeCode);
  96. context.put("treeParentCode", treeParentCode);
  97. context.put("treeName", treeName);
  98. context.put("expandColumn", getExpandColumn(genTable));
  99. if (paramsObj.containsKey(GenConstants.TREE_PARENT_CODE))
  100. {
  101. context.put("tree_parent_code", paramsObj.getString(GenConstants.TREE_PARENT_CODE));
  102. }
  103. if (paramsObj.containsKey(GenConstants.TREE_NAME))
  104. {
  105. context.put("tree_name", paramsObj.getString(GenConstants.TREE_NAME));
  106. }
  107. }
  108. public static void setSubVelocityContext(VelocityContext context, GenTable genTable)
  109. {
  110. GenTable subTable = genTable.getSubTable();
  111. String subTableName = genTable.getSubTableName();
  112. String subTableFkName = genTable.getSubTableFkName();
  113. String subClassName = genTable.getSubTable().getClassName();
  114. String subTableFkClassName = StringUtils.convertToCamelCase(subTableFkName);
  115. context.put("subTable", subTable);
  116. context.put("subTableName", subTableName);
  117. context.put("subTableFkName", subTableFkName);
  118. context.put("subTableFkClassName", subTableFkClassName);
  119. context.put("subTableFkclassName", StringUtils.uncapitalize(subTableFkClassName));
  120. context.put("subClassName", subClassName);
  121. context.put("subclassName", StringUtils.uncapitalize(subClassName));
  122. context.put("subImportList", getImportList(genTable.getSubTable()));
  123. }
  124. /**
  125. * 获取模板信息
  126. * @param tplCategory 生成的模板
  127. * @return 模板列表
  128. */
  129. public static List<String> getTemplateList(String tplCategory)
  130. {
  131. List<String> templates = new ArrayList<String>();
  132. templates.add("vm/java/database.java.vm");
  133. templates.add("vm/java/mapper.java.vm");
  134. templates.add("vm/java/service.java.vm");
  135. templates.add("vm/java/serviceImpl.java.vm");
  136. templates.add("vm/java/controller.java.vm");
  137. templates.add("vm/xml/mapper.xml.vm");
  138. // 移除前端相关模板:sql/sql.vm, js/api.js.vm, vue相关模板
  139. if (GenConstants.TPL_SUB.equals(tplCategory))
  140. {
  141. templates.add("vm/java/sub-database.java.vm");
  142. }
  143. return templates;
  144. }
  145. /**
  146. * 获取文件名
  147. */
  148. public static String getFileName(String template, GenTable genTable)
  149. {
  150. // 文件名称
  151. String fileName = "";
  152. // 包路径
  153. String packageName = genTable.getPackageName();
  154. // 大写类名
  155. String className = genTable.getClassName();
  156. StringBuilder sb = new StringBuilder(className);
  157. sb.setCharAt(0, Character.toLowerCase(sb.charAt(0)));
  158. //首字母小写类名
  159. String lowerClass=sb.toString();
  160. // 实体类路径
  161. String entityPath = PROJECT_ENTITY + "/" + StringUtils.replace(packageName, ".", "/")+"/entity/";
  162. // mapper接口路径
  163. String mapperPath = PROJECT_MAPPER + "/" + StringUtils.replace(packageName, ".", "/");
  164. // service接口路径
  165. String servicePath = PROJECT_SERVICE + "/" + StringUtils.replace(packageName, ".", "/");
  166. // controller路径
  167. String controllerPath = PROJECT_CONTROLLER + "/" + StringUtils.replace(packageName, ".", "/")+"/web/";
  168. if (template.contains("database.java.vm"))
  169. {
  170. fileName = StringUtils.format("{}/database/{}/{}.java", entityPath,lowerClass, className);
  171. }
  172. if (template.contains("sub-database.java.vm") && StringUtils.equals(GenConstants.TPL_SUB, genTable.getTplCategory()))
  173. {
  174. fileName = StringUtils.format("{}/database/{}/{}.java",
  175. entityPath,lowerClass, genTable.getSubTable().getClassName());
  176. }
  177. else if (template.contains("mapper.java.vm"))
  178. {
  179. fileName = StringUtils.format("{}/mapper/{}/{}Mapper.java", mapperPath,lowerClass, className);
  180. }
  181. else if (template.contains("service.java.vm"))
  182. {
  183. fileName = StringUtils.format("{}/service/{}/I{}Service.java", servicePath,lowerClass, className);
  184. }
  185. else if (template.contains("serviceImpl.java.vm"))
  186. {
  187. fileName = StringUtils.format("{}/service/{}/impl/{}ServiceImpl.java", servicePath,lowerClass, className);
  188. }
  189. else if (template.contains("controller.java.vm"))
  190. {
  191. fileName = StringUtils.format("{}/controller/{}/{}Controller.java", controllerPath,lowerClass, className);
  192. }
  193. else if (template.contains("mapper.xml.vm"))
  194. {
  195. fileName = StringUtils.format("{}/{}/{}Mapper.xml", MYBATIS_PATH,lowerClass, className);
  196. }
  197. return fileName;
  198. }
  199. /**
  200. * 获取包前缀
  201. *
  202. * @param packageName 包名称
  203. * @return 包前缀名称
  204. */
  205. public static String getPackagePrefix(String packageName)
  206. {
  207. int lastIndex = packageName.lastIndexOf(".");
  208. return StringUtils.substring(packageName, 0, lastIndex);
  209. }
  210. /**
  211. * 根据列类型获取导入包
  212. *
  213. * @param genTable 业务表对象
  214. * @return 返回需要导入的包列表
  215. */
  216. public static HashSet<String> getImportList(GenTable genTable)
  217. {
  218. List<GenTableColumn> columns = genTable.getColumns();
  219. GenTable subGenTable = genTable.getSubTable();
  220. HashSet<String> importList = new HashSet<String>();
  221. if (StringUtils.isNotNull(subGenTable))
  222. {
  223. importList.add("java.util.List");
  224. }
  225. for (GenTableColumn column : columns)
  226. {
  227. if (!column.isSuperColumn() && GenConstants.TYPE_DATE.equals(column.getJavaType()))
  228. {
  229. importList.add("java.util.Date");
  230. importList.add("com.fasterxml.jackson.annotation.JsonFormat");
  231. }
  232. else if (!column.isSuperColumn() && GenConstants.TYPE_BIGDECIMAL.equals(column.getJavaType()))
  233. {
  234. importList.add("java.math.BigDecimal");
  235. }
  236. }
  237. return importList;
  238. }
  239. /**
  240. * 根据列类型获取字典组
  241. *
  242. * @param genTable 业务表对象
  243. * @return 返回字典组
  244. */
  245. public static String getDicts(GenTable genTable)
  246. {
  247. List<GenTableColumn> columns = genTable.getColumns();
  248. Set<String> dicts = new HashSet<String>();
  249. addDicts(dicts, columns);
  250. if (StringUtils.isNotNull(genTable.getSubTable()))
  251. {
  252. List<GenTableColumn> subColumns = genTable.getSubTable().getColumns();
  253. addDicts(dicts, subColumns);
  254. }
  255. return StringUtils.join(dicts, ", ");
  256. }
  257. /**
  258. * 添加字典列表
  259. *
  260. * @param dicts 字典列表
  261. * @param columns 列集合
  262. */
  263. public static void addDicts(Set<String> dicts, List<GenTableColumn> columns)
  264. {
  265. for (GenTableColumn column : columns)
  266. {
  267. if (!column.isSuperColumn() && StringUtils.isNotEmpty(column.getDictType()) && StringUtils.equalsAny(
  268. column.getHtmlType(),
  269. new String[] { GenConstants.HTML_SELECT, GenConstants.HTML_RADIO, GenConstants.HTML_CHECKBOX }))
  270. {
  271. dicts.add("'" + column.getDictType() + "'");
  272. }
  273. }
  274. }
  275. /**
  276. * 获取权限前缀
  277. *
  278. * @param moduleName 模块名称
  279. * @param businessName 业务名称
  280. * @return 返回权限前缀
  281. */
  282. public static String getPermissionPrefix(String moduleName, String businessName)
  283. {
  284. return StringUtils.format("{}:{}", moduleName, businessName);
  285. }
  286. /**
  287. * 获取上级菜单ID字段
  288. *
  289. * @param paramsObj 生成其他选项
  290. * @return 上级菜单ID字段
  291. */
  292. public static String getParentMenuId(JSONObject paramsObj)
  293. {
  294. if (StringUtils.isNotEmpty(paramsObj) && paramsObj.containsKey(GenConstants.PARENT_MENU_ID)
  295. && StringUtils.isNotEmpty(paramsObj.getString(GenConstants.PARENT_MENU_ID)))
  296. {
  297. return paramsObj.getString(GenConstants.PARENT_MENU_ID);
  298. }
  299. return DEFAULT_PARENT_MENU_ID;
  300. }
  301. /**
  302. * 获取树编码
  303. *
  304. * @param paramsObj 生成其他选项
  305. * @return 树编码
  306. */
  307. public static String getTreecode(JSONObject paramsObj)
  308. {
  309. if (paramsObj.containsKey(GenConstants.TREE_CODE))
  310. {
  311. return StringUtils.toCamelCase(paramsObj.getString(GenConstants.TREE_CODE));
  312. }
  313. return StringUtils.EMPTY;
  314. }
  315. /**
  316. * 获取树父编码
  317. *
  318. * @param paramsObj 生成其他选项
  319. * @return 树父编码
  320. */
  321. public static String getTreeParentCode(JSONObject paramsObj)
  322. {
  323. if (paramsObj.containsKey(GenConstants.TREE_PARENT_CODE))
  324. {
  325. return StringUtils.toCamelCase(paramsObj.getString(GenConstants.TREE_PARENT_CODE));
  326. }
  327. return StringUtils.EMPTY;
  328. }
  329. /**
  330. * 获取树名称
  331. *
  332. * @param paramsObj 生成其他选项
  333. * @return 树名称
  334. */
  335. public static String getTreeName(JSONObject paramsObj)
  336. {
  337. if (paramsObj.containsKey(GenConstants.TREE_NAME))
  338. {
  339. return StringUtils.toCamelCase(paramsObj.getString(GenConstants.TREE_NAME));
  340. }
  341. return StringUtils.EMPTY;
  342. }
  343. /**
  344. * 获取需要在哪一列上面显示展开按钮
  345. *
  346. * @param genTable 业务表对象
  347. * @return 展开按钮列序号
  348. */
  349. public static int getExpandColumn(GenTable genTable)
  350. {
  351. String options = genTable.getOptions();
  352. JSONObject paramsObj = JSON.parseObject(options);
  353. String treeName = paramsObj.getString(GenConstants.TREE_NAME);
  354. int num = 0;
  355. for (GenTableColumn column : genTable.getColumns())
  356. {
  357. if (column.isList())
  358. {
  359. num++;
  360. String columnName = column.getColumnName();
  361. if (columnName.equals(treeName))
  362. {
  363. break;
  364. }
  365. }
  366. }
  367. return num;
  368. }
  369. }