refactor: 代码生成重构
This commit is contained in:
@@ -55,7 +55,7 @@ public class GeneratorProperties {
|
||||
|
||||
private String templatePath;
|
||||
|
||||
private String packageName;
|
||||
private String subpackageName;
|
||||
|
||||
/**
|
||||
* 文件扩展名,如 .java
|
||||
|
||||
@@ -3,10 +3,12 @@ package com.youlai.system.controller;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.youlai.system.common.result.PageResult;
|
||||
import com.youlai.system.common.result.Result;
|
||||
import com.youlai.system.enums.LogModuleEnum;
|
||||
import com.youlai.system.model.form.GenConfigForm;
|
||||
import com.youlai.system.model.query.TablePageQuery;
|
||||
import com.youlai.system.model.vo.GeneratorPreviewVO;
|
||||
import com.youlai.system.model.vo.TablePageVO;
|
||||
import com.youlai.system.plugin.syslog.annotation.LogAnnotation;
|
||||
import com.youlai.system.service.GeneratorService;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
import io.swagger.v3.oas.annotations.Parameter;
|
||||
@@ -35,6 +37,7 @@ public class GeneratorController {
|
||||
|
||||
@Operation(summary = "获取数据表分页列表")
|
||||
@GetMapping("/table/page")
|
||||
@LogAnnotation(value = "代码生成分页列表", module = LogModuleEnum.OTHER)
|
||||
public PageResult<TablePageVO> getTablePage(
|
||||
TablePageQuery queryParams
|
||||
) {
|
||||
@@ -53,6 +56,7 @@ public class GeneratorController {
|
||||
|
||||
@Operation(summary = "保存代码生成配置")
|
||||
@PostMapping("/{tableName}/config")
|
||||
@LogAnnotation(value = "生成代码", module = LogModuleEnum.OTHER)
|
||||
public Result saveGenConfig(@RequestBody GenConfigForm formData) {
|
||||
generatorService.saveGenConfig(formData);
|
||||
return Result.success();
|
||||
@@ -69,15 +73,15 @@ public class GeneratorController {
|
||||
|
||||
@Operation(summary = "获取预览生成代码")
|
||||
@GetMapping("/{tableName}/preview")
|
||||
@LogAnnotation(value = "预览生成代码", module = LogModuleEnum.OTHER)
|
||||
public Result<List<GeneratorPreviewVO>> getTablePreviewData(@PathVariable String tableName) {
|
||||
List<GeneratorPreviewVO> list = generatorService.getTablePreviewData(tableName);
|
||||
return Result.success(list);
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Operation(summary = "下载代码zip")
|
||||
@GetMapping("/{tableName}/downloadZip")
|
||||
@Operation(summary = "下载代码")
|
||||
@GetMapping("/{tableName}/download")
|
||||
@LogAnnotation(value = "下载代码", module = LogModuleEnum.OTHER)
|
||||
public void downloadZip(HttpServletResponse response, @PathVariable String tableName) throws IOException {
|
||||
String[] tableNames = tableName.split(",");
|
||||
byte[] data = generatorService.downloadCode(tableNames);
|
||||
|
||||
@@ -270,12 +270,14 @@ public class GeneratorServiceImpl implements GeneratorService {
|
||||
|
||||
|
||||
/* 2. 生成文件路径 */
|
||||
// com.youlai.system
|
||||
// com.youlai
|
||||
String packageName = genConfig.getPackageName();
|
||||
// system
|
||||
String moduleName = genConfig.getModuleName();
|
||||
// controller
|
||||
String subPackageName = templateConfig.getPackageName();
|
||||
// 文件路径 com.youlai.system.controller
|
||||
String filePath = getFilePath(templateName, packageName, subPackageName, entityName);
|
||||
String subpackageName = templateConfig.getSubpackageName();
|
||||
// 文件路径 src/main/java/com/youlai/system/controller
|
||||
String filePath = getFilePath(templateName,moduleName, packageName, subpackageName, entityName);
|
||||
previewVO.setPath(filePath);
|
||||
|
||||
/* 3. 生成文件内容 */
|
||||
@@ -309,7 +311,7 @@ public class GeneratorServiceImpl implements GeneratorService {
|
||||
return entityName + templateName + extension;
|
||||
}
|
||||
|
||||
private String getFilePath(String templateName, String packageName, String subPackageName, String entityName) {
|
||||
private String getFilePath(String templateName,String moduleName, String packageName, String subPackageName, String entityName) {
|
||||
String path;
|
||||
if ("MapperXml".equals(templateName)) {
|
||||
path = (generatorProperties.getBackendAppName()
|
||||
@@ -324,16 +326,18 @@ public class GeneratorServiceImpl implements GeneratorService {
|
||||
);
|
||||
} else if ("VIEW".equals(templateName)) {
|
||||
path = (generatorProperties.getFrontendAppName()
|
||||
+ File.separator
|
||||
+ "src" + File.separator + subPackageName
|
||||
+ File.separator
|
||||
+ StrUtil.toSymbolCase(entityName, '-')
|
||||
+ File.separator + "src"
|
||||
+ File.separator + moduleName
|
||||
+ File.separator + subPackageName
|
||||
+ File.separator + StrUtil.toSymbolCase(entityName, '-')
|
||||
);
|
||||
} else {
|
||||
path = (generatorProperties.getBackendAppName()
|
||||
+ File.separator
|
||||
+ "src" + File.separator + "main" + File.separator + "java"
|
||||
+ File.separator + packageName + File.separator + subPackageName
|
||||
+ File.separator + packageName
|
||||
+ File.separator + moduleName
|
||||
+ File.separator + subPackageName
|
||||
);
|
||||
}
|
||||
|
||||
@@ -357,8 +361,8 @@ public class GeneratorServiceImpl implements GeneratorService {
|
||||
|
||||
String entityName = genConfig.getEntityName();
|
||||
|
||||
bindMap.put("package", genConfig.getPackageName());
|
||||
bindMap.put("subPackage", templateConfig.getPackageName());
|
||||
bindMap.put("packageName", genConfig.getPackageName());
|
||||
bindMap.put("moduleName", genConfig.getModuleName());
|
||||
bindMap.put("date", DateUtil.format(new Date(), "yyyy-MM-dd HH:mm"));
|
||||
bindMap.put("entityName", entityName);
|
||||
bindMap.put("tableName", genConfig.getTableName());
|
||||
|
||||
@@ -15,42 +15,42 @@ generator:
|
||||
templateConfigs:
|
||||
Controller:
|
||||
templatePath: generator/controller.java.vm
|
||||
packageName: controller
|
||||
subpackageName: controller
|
||||
Service:
|
||||
templatePath: generator/service.java.vm
|
||||
packageName: service
|
||||
subpackageName: service
|
||||
ServiceImpl:
|
||||
templatePath: generator/serviceImpl.java.vm
|
||||
packageName: service.impl
|
||||
subpackageName: service.impl
|
||||
Mapper:
|
||||
templatePath: generator/mapper.java.vm
|
||||
packageName: mapper
|
||||
subpackageName: mapper
|
||||
MapperXml:
|
||||
templatePath: generator/mapper.xml.vm
|
||||
packageName: mapper
|
||||
subpackageName: mapper
|
||||
extension: .xml
|
||||
Converter:
|
||||
templatePath: generator/converter.java.vm
|
||||
packageName: converter
|
||||
subpackageName: converter
|
||||
Query:
|
||||
templatePath: generator/query.java.vm
|
||||
packageName: model.query
|
||||
subpackageName: model.query
|
||||
Form:
|
||||
templatePath: generator/form.java.vm
|
||||
packageName: model.form
|
||||
subpackageName: model.form
|
||||
VO:
|
||||
templatePath: generator/vo.java.vm
|
||||
packageName: model.vo
|
||||
subpackageName: model.vo
|
||||
Entity:
|
||||
templatePath: generator/entity.java.vm
|
||||
packageName: model.entity
|
||||
subpackageName: model.entity
|
||||
API:
|
||||
templatePath: generator/api.ts.vm
|
||||
packageName: api
|
||||
subpackageName: api
|
||||
extension: .ts
|
||||
VIEW:
|
||||
templatePath: generator/index.vue.vm
|
||||
packageName: views
|
||||
subpackageName: views
|
||||
extension: .vue
|
||||
|
||||
|
||||
|
||||
@@ -1,11 +1,11 @@
|
||||
package ${package}.controller;
|
||||
package ${packageName}.${moduleName}.${subpackageName};
|
||||
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.web.bind.annotation.RequestMapping;
|
||||
import org.springframework.web.bind.annotation.RestController;
|
||||
import ${package}.model.form.${entityName}Form;
|
||||
import ${package}.model.query.${entityName}PageQuery;
|
||||
import ${package}.model.vo.${entityName}PageVO;
|
||||
import ${packageName}.${moduleName}.model.form.${entityName}Form;
|
||||
import ${packageName}.${moduleName}.model.query.${entityName}PageQuery;
|
||||
import ${packageName}.${moduleName}.model.vo.${entityName}PageVO;
|
||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||
import com.youlai.common.result.PageResult;
|
||||
import com.youlai.common.result.Result;
|
||||
|
||||
@@ -1,9 +1,9 @@
|
||||
package ${package}.converter;
|
||||
package ${packageName}.${moduleName}.${subpackageName};
|
||||
|
||||
import org.mapstruct.Mapper;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import ${package}.model.entity.${entityName};
|
||||
import ${package}.model.form.${entityName}Form;
|
||||
import ${packageName}.${moduleName}.model.entity.${entityName};
|
||||
import ${packageName}.${moduleName}.model.form.${entityName}Form;
|
||||
|
||||
/**
|
||||
* $!{businessName}对象转换器
|
||||
@@ -16,5 +16,5 @@ public interface ${entityName}Converter{
|
||||
|
||||
${entityName}Form toForm(${entityName} entity);
|
||||
|
||||
${entityName} toEntity(${entityName}Form entity);
|
||||
${entityName} toEntity(${entityName}Form formData);
|
||||
}
|
||||
@@ -1,4 +1,4 @@
|
||||
package ${package}.model.entity;
|
||||
package ${packageName}.${moduleName}.${subpackageName};
|
||||
|
||||
import lombok.Getter;
|
||||
import lombok.Setter;
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
package ${package}.${subPackage};
|
||||
package ${packageName}.${moduleName}.${subpackageName};
|
||||
|
||||
import java.io.Serial;
|
||||
import java.io.Serializable;
|
||||
|
||||
@@ -1,9 +1,9 @@
|
||||
package ${package}.mapper;
|
||||
package ${packageName}.${moduleName}.${subpackageName};
|
||||
|
||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||
import ${package}.model.entity.${entityName};
|
||||
import ${packageName}.${moduleName}.model.entity.${entityName};
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import ${package}.model.query.${entityName}Query;
|
||||
import ${packageName}.${moduleName}.model.query.${entityName}Query;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
/**
|
||||
|
||||
@@ -1,9 +1,9 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||
<mapper namespace="${package}.mapper.${entityName}Mapper">
|
||||
<mapper namespace="${packageName}.${moduleName}.mapper.${entityName}Mapper">
|
||||
|
||||
<!-- 获取${businessName}分页列表 -->
|
||||
<select id="get${entityName}Page" resultType="${package}.model.vo.${entityName}VO">
|
||||
<select id="get${entityName}Page" resultType="${packageName}.${moduleName}.model.vo.${entityName}VO">
|
||||
SELECT
|
||||
#if($fieldConfigs)
|
||||
#set ($fields = [])
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
package ${package}.model.query;
|
||||
package ${packageName}.${moduleName}.${subpackageName};
|
||||
|
||||
import com.youlai.common.base.BasePageQuery;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
|
||||
@@ -1,9 +1,9 @@
|
||||
package ${package}.Service;
|
||||
package ${packageName}.${moduleName}.${subpackageName};
|
||||
|
||||
import ${package}.model.entity.${entityName};
|
||||
import ${package}.model.form.${entityName}Form;
|
||||
import ${package}.model.query.${entityName}PageQuery;
|
||||
import ${package}.model.vo.${entityName}PageVO;
|
||||
import ${packageName}.${moduleName}.model.entity.${entityName};
|
||||
import ${packageName}.${moduleName}.model.form.${entityName}Form;
|
||||
import ${packageName}.${moduleName}.model.query.${entityName}PageQuery;
|
||||
import ${packageName}.${moduleName}.model.vo.${entityName}PageVO;
|
||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||
import com.baomidou.mybatisplus.extension.service.IService;
|
||||
|
||||
|
||||
@@ -1,17 +1,17 @@
|
||||
package ${package}.service.impl;
|
||||
package ${packageName}.${moduleName}.${subpackageName};
|
||||
|
||||
import ${package}.model.entity.${entityName};
|
||||
import ${package}.mapper.${entityName}Mapper;
|
||||
import ${package}.service.${entityName}Service;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.stereotype.Service;
|
||||
import ${package}.model.form.${entityName}Form;
|
||||
import ${package}.model.query.${entityName}Query;
|
||||
import ${package}.model.vo.${entityName}PageVO;
|
||||
import ${package}.converter.${entityName}Converter;
|
||||
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||
import ${packageName}.${moduleName}.mapper.${entityName}Mapper;
|
||||
import ${packageName}.${moduleName}.service.${entityName}Service;
|
||||
import ${packageName}.${moduleName}.model.entity.${entityName};
|
||||
import ${packageName}.${moduleName}.model.form.${entityName}Form;
|
||||
import ${packageName}.${moduleName}.model.query.${entityName}Query;
|
||||
import ${packageName}.${moduleName}.model.vo.${entityName}PageVO;
|
||||
import ${packageName}.${moduleName}.converter.${entityName}Converter;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
package ${package}.model.vo;
|
||||
package ${packageName}.${moduleName}.model.vo;
|
||||
|
||||
import java.io.Serial;
|
||||
import java.io.Serializable;
|
||||
|
||||
Reference in New Issue
Block a user