统一修改包
This commit is contained in:
151
zt-module-base/zt-module-base-server/pom.xml
Normal file
151
zt-module-base/zt-module-base-server/pom.xml
Normal file
@@ -0,0 +1,151 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<parent>
|
||||
<artifactId>cloud-module-base</artifactId>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<version>${revision}</version>
|
||||
</parent>
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<packaging>jar</packaging>
|
||||
|
||||
<artifactId>cloud-module-base-server</artifactId>
|
||||
|
||||
<name>${project.artifactId}</name>
|
||||
<description>
|
||||
Base 模块。
|
||||
</description>
|
||||
|
||||
<dependencies>
|
||||
<!-- Spring Cloud 基础 -->
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-env</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- 依赖服务 -->
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-module-system-api</artifactId>
|
||||
<version>${revision}</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-module-infra-api</artifactId>
|
||||
<version>${revision}</version>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-module-base-api</artifactId>
|
||||
<version>${revision}</version>
|
||||
</dependency>
|
||||
|
||||
<!-- 业务组件 -->
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-biz-data-permission</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-biz-tenant</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- Web 相关 -->
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-web</artifactId>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-security</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- DB 相关 -->
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-mybatis</artifactId>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-redis</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- RPC 远程调用相关 -->
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-rpc</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- Registry 注册中心相关 -->
|
||||
<dependency>
|
||||
<groupId>com.alibaba.cloud</groupId>
|
||||
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- Config 配置中心相关 -->
|
||||
<dependency>
|
||||
<groupId>com.alibaba.cloud</groupId>
|
||||
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- Job 定时任务相关 -->
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-job</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- 消息队列相关 -->
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-mq</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- Test 测试相关 -->
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-test</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- 工具类相关 -->
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-excel</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- 监控相关 -->
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-monitor</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.zt.plat</groupId>
|
||||
<artifactId>cloud-spring-boot-starter-biz-business</artifactId>
|
||||
<version>${revision}</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
|
||||
<build>
|
||||
<!-- 设置构建的 jar 包名 -->
|
||||
<finalName>${project.artifactId}</finalName>
|
||||
<!-- <plugins>-->
|
||||
<!-- <!– 打包 –>-->
|
||||
<!-- <plugin>-->
|
||||
<!-- <groupId>org.springframework.boot</groupId>-->
|
||||
<!-- <artifactId>spring-boot-maven-plugin</artifactId>-->
|
||||
<!-- <version>${spring.boot.version}</version>-->
|
||||
<!-- <executions>-->
|
||||
<!-- <execution>-->
|
||||
<!-- <goals>-->
|
||||
<!-- <goal>repackage</goal> <!– 将引入的 jar 打入其中 –>-->
|
||||
<!-- </goals>-->
|
||||
<!-- </execution>-->
|
||||
<!-- </executions>-->
|
||||
<!-- </plugin>-->
|
||||
<!-- </plugins>-->
|
||||
</build>
|
||||
|
||||
</project>
|
||||
@@ -0,0 +1,18 @@
|
||||
package com.zt.plat.module.base;
|
||||
|
||||
import org.springframework.boot.SpringApplication;
|
||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||
|
||||
/**
|
||||
* Base 模块的启动类
|
||||
*
|
||||
* @author ZT
|
||||
*/
|
||||
//@SpringBootApplication
|
||||
public class BaseServerApplication {
|
||||
|
||||
public static void main(String[] args) {
|
||||
SpringApplication.run(BaseServerApplication.class, args);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,29 @@
|
||||
package com.zt.plat.module.base.controller.admin.base;
|
||||
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import org.springframework.web.bind.annotation.GetMapping;
|
||||
import org.springframework.web.bind.annotation.RequestMapping;
|
||||
import org.springframework.web.bind.annotation.RestController;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.CommonResult;
|
||||
|
||||
import static com.zt.plat.framework.common.pojo.CommonResult.success;
|
||||
|
||||
/**
|
||||
* Base 控制器
|
||||
*
|
||||
* @author ZT
|
||||
*/
|
||||
@Tag(name = "管理后台 - Base")
|
||||
@RestController
|
||||
@RequestMapping("/admin/base/base")
|
||||
public class BaseTestController {
|
||||
|
||||
@GetMapping("/hello")
|
||||
@Operation(summary = "Hello Base")
|
||||
public CommonResult<String> hello() {
|
||||
return success("Hello, Base!");
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,120 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.DepartmentInstanceRelativityPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.DepartmentInstanceRelativityRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.DepartmentInstanceRelativitySaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.DepartmentInstanceRelativityDO;
|
||||
import com.zt.plat.module.base.service.tmpltp.DepartmentInstanceRelativityService;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import jakarta.annotation.Resource;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import com.zt.plat.framework.business.interceptor.BusinessControllerMarker;
|
||||
import com.zt.plat.framework.business.annotation.FileUploadController;
|
||||
import com.zt.plat.framework.business.controller.AbstractFileUploadController;
|
||||
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import io.swagger.v3.oas.annotations.Parameter;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
|
||||
import jakarta.validation.constraints.*;
|
||||
import jakarta.validation.*;
|
||||
import jakarta.servlet.http.*;
|
||||
import java.util.*;
|
||||
import java.io.IOException;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.vo.BatchDeleteReqVO;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.CommonResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
import static com.zt.plat.framework.common.pojo.CommonResult.success;
|
||||
|
||||
import com.zt.plat.framework.excel.core.util.ExcelUtils;
|
||||
|
||||
import com.zt.plat.framework.apilog.core.annotation.ApiAccessLog;
|
||||
import static com.zt.plat.framework.apilog.core.enums.OperateTypeEnum.*;
|
||||
|
||||
|
||||
|
||||
@Tag(name = "管理后台 - 部门与实例关联")
|
||||
@RestController
|
||||
@RequestMapping("/bse/department-instance-relativity")
|
||||
@Validated
|
||||
@FileUploadController(source = "bse.departmentinstancerelativity")
|
||||
public class DepartmentInstanceRelativityController extends AbstractFileUploadController implements BusinessControllerMarker{
|
||||
|
||||
static {
|
||||
FileUploadController annotation = DepartmentInstanceRelativityController.class.getAnnotation(FileUploadController.class);
|
||||
if (annotation != null) {
|
||||
setFileUploadInfo(annotation);
|
||||
}
|
||||
}
|
||||
|
||||
@Resource
|
||||
private DepartmentInstanceRelativityService departmentInstanceRelativityService;
|
||||
|
||||
@PostMapping("/create")
|
||||
@Operation(summary = "创建部门与实例关联")
|
||||
@PreAuthorize("@ss.hasPermission('bse:department-instance-relativity:create')")
|
||||
public CommonResult<DepartmentInstanceRelativityRespVO> createDepartmentInstanceRelativity(@Valid @RequestBody DepartmentInstanceRelativitySaveReqVO createReqVO) {
|
||||
return success(departmentInstanceRelativityService.createDepartmentInstanceRelativity(createReqVO));
|
||||
}
|
||||
|
||||
@PutMapping("/update")
|
||||
@Operation(summary = "更新部门与实例关联")
|
||||
@PreAuthorize("@ss.hasPermission('bse:department-instance-relativity:update')")
|
||||
public CommonResult<Boolean> updateDepartmentInstanceRelativity(@Valid @RequestBody DepartmentInstanceRelativitySaveReqVO updateReqVO) {
|
||||
departmentInstanceRelativityService.updateDepartmentInstanceRelativity(updateReqVO);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete")
|
||||
@Operation(summary = "删除部门与实例关联")
|
||||
@Parameter(name = "id", description = "编号", required = true)
|
||||
@PreAuthorize("@ss.hasPermission('bse:department-instance-relativity:delete')")
|
||||
public CommonResult<Boolean> deleteDepartmentInstanceRelativity(@RequestParam("id") String id) {
|
||||
departmentInstanceRelativityService.deleteDepartmentInstanceRelativity(id);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete-list")
|
||||
@Parameter(name = "ids", description = "编号", required = true)
|
||||
@Operation(summary = "批量删除部门与实例关联")
|
||||
@PreAuthorize("@ss.hasPermission('bse:department-instance-relativity:delete')")
|
||||
public CommonResult<Boolean> deleteDepartmentInstanceRelativityList(@RequestBody BatchDeleteReqVO req) {
|
||||
departmentInstanceRelativityService.deleteDepartmentInstanceRelativityListByIds(req.getIds());
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@GetMapping("/get")
|
||||
@Operation(summary = "获得部门与实例关联")
|
||||
@Parameter(name = "id", description = "编号", required = true, example = "1024")
|
||||
@PreAuthorize("@ss.hasPermission('bse:department-instance-relativity:query')")
|
||||
public CommonResult<DepartmentInstanceRelativityRespVO> getDepartmentInstanceRelativity(@RequestParam("id") String id) {
|
||||
DepartmentInstanceRelativityDO departmentInstanceRelativity = departmentInstanceRelativityService.getDepartmentInstanceRelativity(id);
|
||||
return success(BeanUtils.toBean(departmentInstanceRelativity, DepartmentInstanceRelativityRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/page")
|
||||
@Operation(summary = "获得部门与实例关联分页")
|
||||
@PreAuthorize("@ss.hasPermission('bse:department-instance-relativity:query')")
|
||||
public CommonResult<PageResult<DepartmentInstanceRelativityRespVO>> getDepartmentInstanceRelativityPage(@Valid DepartmentInstanceRelativityPageReqVO pageReqVO) {
|
||||
PageResult<DepartmentInstanceRelativityDO> pageResult = departmentInstanceRelativityService.getDepartmentInstanceRelativityPage(pageReqVO);
|
||||
return success(BeanUtils.toBean(pageResult, DepartmentInstanceRelativityRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/export-excel")
|
||||
@Operation(summary = "导出部门与实例关联 Excel")
|
||||
@PreAuthorize("@ss.hasPermission('bse:department-instance-relativity:export')")
|
||||
@ApiAccessLog(operateType = EXPORT)
|
||||
public void exportDepartmentInstanceRelativityExcel(@Valid DepartmentInstanceRelativityPageReqVO pageReqVO,
|
||||
HttpServletResponse response) throws IOException {
|
||||
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
|
||||
List<DepartmentInstanceRelativityDO> list = departmentInstanceRelativityService.getDepartmentInstanceRelativityPage(pageReqVO).getList();
|
||||
// 导出 Excel
|
||||
ExcelUtils.write(response, "部门与实例关联.xls", "数据", DepartmentInstanceRelativityRespVO.class,
|
||||
BeanUtils.toBean(list, DepartmentInstanceRelativityRespVO.class));
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,138 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp;
|
||||
|
||||
import cn.hutool.core.io.IoUtil;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstancePageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceDO;
|
||||
import com.zt.plat.module.base.service.tmpltp.TemplateInstanceService;
|
||||
import com.zt.plat.module.infra.api.file.FileApi;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import jakarta.annotation.Resource;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import com.zt.plat.framework.business.annotation.FileUploadController;
|
||||
import com.zt.plat.framework.business.controller.AbstractFileUploadController;
|
||||
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import io.swagger.v3.oas.annotations.Parameter;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
|
||||
import jakarta.validation.constraints.*;
|
||||
import jakarta.validation.*;
|
||||
import jakarta.servlet.http.*;
|
||||
import java.util.*;
|
||||
import java.io.IOException;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.vo.BatchDeleteReqVO;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.CommonResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
import static com.zt.plat.framework.common.pojo.CommonResult.success;
|
||||
|
||||
import com.zt.plat.framework.excel.core.util.ExcelUtils;
|
||||
|
||||
import com.zt.plat.framework.apilog.core.annotation.ApiAccessLog;
|
||||
import org.springframework.web.multipart.MultipartFile;
|
||||
|
||||
import static com.zt.plat.framework.apilog.core.enums.OperateTypeEnum.*;
|
||||
|
||||
|
||||
|
||||
@Tag(name = "管理后台 - 模板实例")
|
||||
@RestController
|
||||
@RequestMapping("/base/template-instance")
|
||||
@Validated
|
||||
@FileUploadController(source = "bse.templateinstance")
|
||||
public class TemplateInstanceController extends AbstractFileUploadController {
|
||||
|
||||
static {
|
||||
FileUploadController annotation = TemplateInstanceController.class.getAnnotation(FileUploadController.class);
|
||||
if (annotation != null) {
|
||||
setFileUploadInfo(annotation);
|
||||
}
|
||||
}
|
||||
|
||||
@Resource
|
||||
private TemplateInstanceService templateInstanceService;
|
||||
|
||||
@Resource
|
||||
private FileApi fileApi;
|
||||
|
||||
// @PostMapping("/upload-file")
|
||||
// @Operation(summary = "上传模板实例文件")
|
||||
// public CommonResult<Map<String, String> >upload(MultipartFile file) {
|
||||
// Map<String, String> fileMap = new HashMap<>();
|
||||
// try {
|
||||
// String fileWhitReturn = fileApi.createFile(file.getBytes(), file.getOriginalFilename());
|
||||
// fileMap.put("fileUrl", fileWhitReturn);
|
||||
// } catch (IOException e) {
|
||||
// throw new RuntimeException(e);
|
||||
// }
|
||||
// return success(fileMap);
|
||||
// }
|
||||
@PostMapping("/create")
|
||||
@Operation(summary = "创建模板实例")
|
||||
@PreAuthorize("@ss.hasPermission('bse:template-instance:create')")
|
||||
public CommonResult<TemplateInstanceRespVO> createTemplateInstance(@Valid @RequestBody TemplateInstanceSaveReqVO createReqVO) {
|
||||
return success(templateInstanceService.createTemplateInstance(createReqVO));
|
||||
}
|
||||
|
||||
@PutMapping("/update")
|
||||
@Operation(summary = "更新模板实例")
|
||||
@PreAuthorize("@ss.hasPermission('bse:template-instance:update')")
|
||||
public CommonResult<Boolean> updateTemplateInstance(@Valid @RequestBody TemplateInstanceSaveReqVO updateReqVO) {
|
||||
templateInstanceService.updateTemplateInstance(updateReqVO);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete")
|
||||
@Operation(summary = "删除模板实例")
|
||||
@Parameter(name = "id", description = "编号", required = true)
|
||||
@PreAuthorize("@ss.hasPermission('bse:template-instance:delete')")
|
||||
public CommonResult<Boolean> deleteTemplateInstance(@RequestParam("id") Long id) {
|
||||
templateInstanceService.deleteTemplateInstance(id);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete-list")
|
||||
@Parameter(name = "ids", description = "编号", required = true)
|
||||
@Operation(summary = "批量删除模板实例")
|
||||
@PreAuthorize("@ss.hasPermission('bse:template-instance:delete')")
|
||||
public CommonResult<Boolean> deleteTemplateInstanceList(@RequestBody BatchDeleteReqVO req) {
|
||||
templateInstanceService.deleteTemplateInstanceListByIds(req.getIds());
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@GetMapping("/get")
|
||||
@Operation(summary = "获得模板实例")
|
||||
@Parameter(name = "id", description = "编号", required = true, example = "1024")
|
||||
@PreAuthorize("@ss.hasPermission('bse:template-instance:query')")
|
||||
public CommonResult<TemplateInstanceRespVO> getTemplateInstance(@RequestParam("id") Long id) {
|
||||
TemplateInstanceDO templateInstance = templateInstanceService.getTemplateInstance(id);
|
||||
return success(BeanUtils.toBean(templateInstance, TemplateInstanceRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/page")
|
||||
@Operation(summary = "获得模板实例分页")
|
||||
@PreAuthorize("@ss.hasPermission('bse:template-instance:query')")
|
||||
public CommonResult<PageResult<TemplateInstanceRespVO>> getTemplateInstancePage(@Valid TemplateInstancePageReqVO pageReqVO) {
|
||||
PageResult<TemplateInstanceDO> pageResult = templateInstanceService.getTemplateInstancePage(pageReqVO);
|
||||
return success(BeanUtils.toBean(pageResult, TemplateInstanceRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/export-excel")
|
||||
@Operation(summary = "导出模板实例 Excel")
|
||||
@PreAuthorize("@ss.hasPermission('bse:template-instance:export')")
|
||||
@ApiAccessLog(operateType = EXPORT)
|
||||
public void exportTemplateInstanceExcel(@Valid TemplateInstancePageReqVO pageReqVO,
|
||||
HttpServletResponse response) throws IOException {
|
||||
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
|
||||
List<TemplateInstanceDO> list = templateInstanceService.getTemplateInstancePage(pageReqVO).getList();
|
||||
// 导出 Excel
|
||||
ExcelUtils.write(response, "模板实例.xls", "数据", TemplateInstanceRespVO.class,
|
||||
BeanUtils.toBean(list, TemplateInstanceRespVO.class));
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,112 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceDataPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceDataRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceDataSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceDataDO;
|
||||
import com.zt.plat.module.base.service.tmpltp.TemplateInstanceDataService;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import jakarta.annotation.Resource;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import com.zt.plat.framework.business.interceptor.BusinessControllerMarker;
|
||||
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import io.swagger.v3.oas.annotations.Parameter;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
|
||||
import jakarta.validation.constraints.*;
|
||||
import jakarta.validation.*;
|
||||
import jakarta.servlet.http.*;
|
||||
import java.util.*;
|
||||
import java.io.IOException;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.vo.BatchDeleteReqVO;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.CommonResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
import static com.zt.plat.framework.common.pojo.CommonResult.success;
|
||||
|
||||
import com.zt.plat.framework.excel.core.util.ExcelUtils;
|
||||
|
||||
import com.zt.plat.framework.apilog.core.annotation.ApiAccessLog;
|
||||
import static com.zt.plat.framework.apilog.core.enums.OperateTypeEnum.*;
|
||||
|
||||
|
||||
|
||||
@Tag(name = "管理后台 - 实例字段值")
|
||||
@RestController
|
||||
@RequestMapping("/base/template-instance-data")
|
||||
@Validated
|
||||
public class TemplateInstanceDataController implements BusinessControllerMarker {
|
||||
|
||||
|
||||
@Resource
|
||||
private TemplateInstanceDataService templateInstanceDataService;
|
||||
|
||||
@PostMapping("/create")
|
||||
@Operation(summary = "创建实例字段值")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-data:create')")
|
||||
public CommonResult<TemplateInstanceDataRespVO> createTemplateInstanceData(@Valid @RequestBody TemplateInstanceDataSaveReqVO createReqVO) {
|
||||
return success(templateInstanceDataService.createTemplateInstanceData(createReqVO));
|
||||
}
|
||||
|
||||
@PutMapping("/update")
|
||||
@Operation(summary = "更新实例字段值")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-data:update')")
|
||||
public CommonResult<Boolean> updateTemplateInstanceData(@Valid @RequestBody TemplateInstanceDataSaveReqVO updateReqVO) {
|
||||
templateInstanceDataService.updateTemplateInstanceData(updateReqVO);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete")
|
||||
@Operation(summary = "删除实例字段值")
|
||||
@Parameter(name = "id", description = "编号", required = true)
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-data:delete')")
|
||||
public CommonResult<Boolean> deleteTemplateInstanceData(@RequestParam("id") Long id) {
|
||||
templateInstanceDataService.deleteTemplateInstanceData(id);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete-list")
|
||||
@Parameter(name = "ids", description = "编号", required = true)
|
||||
@Operation(summary = "批量删除实例字段值")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-data:delete')")
|
||||
public CommonResult<Boolean> deleteTemplateInstanceDataList(@RequestBody BatchDeleteReqVO req) {
|
||||
templateInstanceDataService.deleteTemplateInstanceDataListByIds(req.getIds());
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@GetMapping("/get")
|
||||
@Operation(summary = "获得实例字段值")
|
||||
@Parameter(name = "id", description = "编号", required = true, example = "1024")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-data:query')")
|
||||
public CommonResult<TemplateInstanceDataRespVO> getTemplateInstanceData(@RequestParam("id") Long id) {
|
||||
TemplateInstanceDataDO templateInstanceData = templateInstanceDataService.getTemplateInstanceData(id);
|
||||
return success(BeanUtils.toBean(templateInstanceData, TemplateInstanceDataRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/page")
|
||||
@Operation(summary = "获得实例字段值分页")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-data:query')")
|
||||
public CommonResult<PageResult<TemplateInstanceDataRespVO>> getTemplateInstanceDataPage(@Valid TemplateInstanceDataPageReqVO pageReqVO) {
|
||||
PageResult<TemplateInstanceDataDO> pageResult = templateInstanceDataService.getTemplateInstanceDataPage(pageReqVO);
|
||||
return success(BeanUtils.toBean(pageResult, TemplateInstanceDataRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/export-excel")
|
||||
@Operation(summary = "导出实例字段值 Excel")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-data:export')")
|
||||
@ApiAccessLog(operateType = EXPORT)
|
||||
public void exportTemplateInstanceDataExcel(@Valid TemplateInstanceDataPageReqVO pageReqVO,
|
||||
HttpServletResponse response) throws IOException {
|
||||
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
|
||||
List<TemplateInstanceDataDO> list = templateInstanceDataService.getTemplateInstanceDataPage(pageReqVO).getList();
|
||||
// 导出 Excel
|
||||
ExcelUtils.write(response, "实例字段值.xls", "数据", TemplateInstanceDataRespVO.class,
|
||||
BeanUtils.toBean(list, TemplateInstanceDataRespVO.class));
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
@@ -0,0 +1,111 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceItemPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceItemRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceItemSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceItemDO;
|
||||
import com.zt.plat.module.base.service.tmpltp.TemplateInstanceItemService;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import jakarta.annotation.Resource;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import com.zt.plat.framework.business.interceptor.BusinessControllerMarker;
|
||||
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import io.swagger.v3.oas.annotations.Parameter;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
|
||||
import jakarta.validation.constraints.*;
|
||||
import jakarta.validation.*;
|
||||
import jakarta.servlet.http.*;
|
||||
import java.util.*;
|
||||
import java.io.IOException;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.vo.BatchDeleteReqVO;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.CommonResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
import static com.zt.plat.framework.common.pojo.CommonResult.success;
|
||||
|
||||
import com.zt.plat.framework.excel.core.util.ExcelUtils;
|
||||
|
||||
import com.zt.plat.framework.apilog.core.annotation.ApiAccessLog;
|
||||
import static com.zt.plat.framework.apilog.core.enums.OperateTypeEnum.*;
|
||||
|
||||
|
||||
@Tag(name = "管理后台 - 实例条款值")
|
||||
@RestController
|
||||
@RequestMapping("/base/template-instance-item")
|
||||
@Validated
|
||||
public class TemplateInstanceItemController implements BusinessControllerMarker {
|
||||
|
||||
|
||||
@Resource
|
||||
private TemplateInstanceItemService templateInstanceItemService;
|
||||
|
||||
@PostMapping("/create")
|
||||
@Operation(summary = "创建实例条款值")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-item:create')")
|
||||
public CommonResult<TemplateInstanceItemRespVO> createTemplateInstanceItem(@Valid @RequestBody TemplateInstanceItemSaveReqVO createReqVO) {
|
||||
return success(templateInstanceItemService.createTemplateInstanceItem(createReqVO));
|
||||
}
|
||||
|
||||
@PutMapping("/update")
|
||||
@Operation(summary = "更新实例条款值")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-item:update')")
|
||||
public CommonResult<Boolean> updateTemplateInstanceItem(@Valid @RequestBody TemplateInstanceItemSaveReqVO updateReqVO) {
|
||||
templateInstanceItemService.updateTemplateInstanceItem(updateReqVO);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete")
|
||||
@Operation(summary = "删除实例条款值")
|
||||
@Parameter(name = "id", description = "编号", required = true)
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-item:delete')")
|
||||
public CommonResult<Boolean> deleteTemplateInstanceItem(@RequestParam("id") String id) {
|
||||
templateInstanceItemService.deleteTemplateInstanceItem(id);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete-list")
|
||||
@Parameter(name = "ids", description = "编号", required = true)
|
||||
@Operation(summary = "批量删除实例条款值")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-item:delete')")
|
||||
public CommonResult<Boolean> deleteTemplateInstanceItemList(@RequestBody BatchDeleteReqVO req) {
|
||||
List<String> ids = req.getIds().stream().map(String::valueOf).toList();
|
||||
templateInstanceItemService.deleteTemplateInstanceItemListByIds(ids);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@GetMapping("/get")
|
||||
@Operation(summary = "获得实例条款值")
|
||||
@Parameter(name = "id", description = "编号", required = true, example = "1024")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-item:query')")
|
||||
public CommonResult<TemplateInstanceItemRespVO> getTemplateInstanceItem(@RequestParam("id") String id) {
|
||||
TemplateInstanceItemDO templateInstanceItem = templateInstanceItemService.getTemplateInstanceItem(id);
|
||||
return success(BeanUtils.toBean(templateInstanceItem, TemplateInstanceItemRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/page")
|
||||
@Operation(summary = "获得实例条款值分页")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-item:query')")
|
||||
public CommonResult<PageResult<TemplateInstanceItemRespVO>> getTemplateInstanceItemPage(@Valid TemplateInstanceItemPageReqVO pageReqVO) {
|
||||
PageResult<TemplateInstanceItemDO> pageResult = templateInstanceItemService.getTemplateInstanceItemPage(pageReqVO);
|
||||
return success(BeanUtils.toBean(pageResult, TemplateInstanceItemRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/export-excel")
|
||||
@Operation(summary = "导出实例条款值 Excel")
|
||||
@PreAuthorize("@ss.hasPermission('base:template-instance-item:export')")
|
||||
@ApiAccessLog(operateType = EXPORT)
|
||||
public void exportTemplateInstanceItemExcel(@Valid TemplateInstanceItemPageReqVO pageReqVO,
|
||||
HttpServletResponse response) throws IOException {
|
||||
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
|
||||
List<TemplateInstanceItemDO> list = templateInstanceItemService.getTemplateInstanceItemPage(pageReqVO).getList();
|
||||
// 导出 Excel
|
||||
ExcelUtils.write(response, "实例条款值.xls", "数据", TemplateInstanceItemRespVO.class,
|
||||
BeanUtils.toBean(list, TemplateInstanceItemRespVO.class));
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,91 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp;
|
||||
|
||||
import static com.zt.plat.framework.common.pojo.CommonResult.success;
|
||||
|
||||
import com.zt.plat.framework.business.annotation.FileUploadController;
|
||||
import com.zt.plat.framework.common.pojo.CommonResult;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.vo.BatchDeleteReqVO;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmpItmPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplItmRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplItmSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplItmDO;
|
||||
import com.zt.plat.module.base.service.tmpltp.TmplItmService;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import jakarta.validation.Valid;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.apache.commons.lang3.StringUtils;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
@Tag(name = "管理后台 - 模板条款")
|
||||
@RestController
|
||||
@RequestMapping("/base/tmpl-ltm")
|
||||
@Validated
|
||||
@FileUploadController(source = "bse.tmplltm")
|
||||
@RequiredArgsConstructor
|
||||
public class TmplItmController {
|
||||
private final TmplItmService tmplItmService;
|
||||
|
||||
@PostMapping("/create")
|
||||
@Operation(summary = "创建模板条款")
|
||||
public CommonResult<TmplItmRespVO> createTmplItm(@Valid @RequestBody TmplItmSaveReqVO createReqVO) {
|
||||
TmplItmRespVO tmplItm = tmplItmService.createTmplItm(createReqVO);
|
||||
return success(tmplItm);
|
||||
}
|
||||
|
||||
@PutMapping("/update")
|
||||
@Operation(summary = "更新模板条款")
|
||||
public CommonResult<Boolean> updateTmplItm(@Valid @RequestBody TmplItmSaveReqVO updateReqVO) {
|
||||
tmplItmService.updateTmplItm(updateReqVO);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete")
|
||||
@Operation(summary = "删除模板条款", description = "")
|
||||
public CommonResult<Boolean> deleteTmplItm(@RequestBody BatchDeleteReqVO req) {
|
||||
return success(tmplItmService.deleteTmplItm(req.getIds()));
|
||||
}
|
||||
|
||||
@GetMapping("/id")
|
||||
@Operation(summary = "根据id获得模板条款")
|
||||
public CommonResult<TmplItmRespVO> getTmplItm(@RequestBody String id) {
|
||||
return success(BeanUtils.toBean(tmplItmService.getById(id), TmplItmRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/list")
|
||||
public CommonResult<List<TmplItmRespVO>> listTmplItm(Map<String, Object> params) {
|
||||
// 创建查询条件构造器
|
||||
QueryWrapper<TmplItmDO> queryWrapper = new QueryWrapper<>();
|
||||
|
||||
// 遍历Map参数,动态添加查询条件
|
||||
if (params != null && !params.isEmpty()) {
|
||||
for (Map.Entry<String, Object> entry : params.entrySet()) {
|
||||
String key = entry.getKey();
|
||||
Object value = entry.getValue();
|
||||
|
||||
// 过滤掉空值和空字符串
|
||||
if (value != null &&
|
||||
!(value instanceof String && StringUtils.isBlank((String) value))) {
|
||||
queryWrapper.eq(key, value);
|
||||
}
|
||||
}
|
||||
}
|
||||
// 执行带条件的查询
|
||||
List<TmplItmDO> list = tmplItmService.list(queryWrapper);
|
||||
return success(BeanUtils.toBean(list, TmplItmRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/page")
|
||||
@Operation(summary = "分页获得模板条款")
|
||||
public CommonResult<PageResult<TmplItmRespVO>> pageTmplItm(@Validated TmpItmPageReqVO pageReqVO) {
|
||||
PageResult<TmplItmDO> pageResult = tmplItmService.pageTmplItm(pageReqVO);
|
||||
return success(BeanUtils.toBean(pageResult, TmplItmRespVO.class));
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,171 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp;
|
||||
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.*;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplTpDO;
|
||||
import com.zt.plat.module.base.service.tmpltp.TmplTpService;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import jakarta.annotation.Resource;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import com.zt.plat.framework.business.interceptor.BusinessControllerMarker;
|
||||
import com.zt.plat.framework.business.annotation.FileUploadController;
|
||||
import com.zt.plat.framework.business.controller.AbstractFileUploadController;
|
||||
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import io.swagger.v3.oas.annotations.Parameter;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
|
||||
import jakarta.validation.*;
|
||||
import jakarta.servlet.http.*;
|
||||
import java.util.*;
|
||||
import java.io.IOException;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.vo.BatchDeleteReqVO;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.CommonResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
|
||||
import static com.zt.plat.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.zt.plat.framework.common.pojo.CommonResult.success;
|
||||
|
||||
import com.zt.plat.framework.excel.core.util.ExcelUtils;
|
||||
|
||||
import com.zt.plat.framework.apilog.core.annotation.ApiAccessLog;
|
||||
import static com.zt.plat.framework.apilog.core.enums.OperateTypeEnum.*;
|
||||
|
||||
import static com.zt.plat.module.tmpltp.enums.ErrorCodeConstants.PARAMS_IS_NULL_OR_ERR;
|
||||
|
||||
|
||||
@Tag(name = "管理后台 - 模板分类")
|
||||
@RestController
|
||||
@RequestMapping("/base/tmpl-tp")
|
||||
@Validated
|
||||
@FileUploadController(source = "bse.tmpltp")
|
||||
public class TmplTpController extends AbstractFileUploadController implements BusinessControllerMarker{
|
||||
|
||||
@Resource
|
||||
private TmplTpService tmplTpService;
|
||||
|
||||
@PostMapping("/create")
|
||||
@Operation(summary = "创建模板分类")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp:create')")
|
||||
public CommonResult<TmplTpRespVO> createTmplTp(@Valid @RequestBody TmplTpSaveReqVO createReqVO) {
|
||||
return success(tmplTpService.createTmplTp(createReqVO));
|
||||
}
|
||||
|
||||
@PutMapping("/update")
|
||||
@Operation(summary = "更新模板分类")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp:update')")
|
||||
public CommonResult<Boolean> updateTmplTp(@Valid @RequestBody TmplTpSaveReqVO updateReqVO) {
|
||||
tmplTpService.updateTmplTp(updateReqVO);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete")
|
||||
@Operation(summary = "删除模板分类")
|
||||
@Parameter(name = "id", description = "编号", required = true)
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp:delete')")
|
||||
public CommonResult<Boolean> deleteTmplTp(@RequestBody BatchDeleteReqVO req) {
|
||||
tmplTpService.deleteTmplTp(req.getIds());
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete-list")
|
||||
@Parameter(name = "ids", description = "编号", required = true)
|
||||
@Operation(summary = "批量删除模板分类")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp:delete')")
|
||||
public CommonResult<Boolean> deleteTmplTpList(@RequestBody BatchDeleteReqVO req) {
|
||||
tmplTpService.deleteTmplTpListByIds(req.getIds());
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@GetMapping("/get")
|
||||
@Operation(summary = "获得模板分类")
|
||||
@Parameter(name = "id", description = "编号", required = true, example = "1024")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp:query')")
|
||||
public CommonResult<TmplTpRespVO> getTmplTp(@RequestParam("id") Long id) {
|
||||
TmplTpDO tmplTp = tmplTpService.getTmplTp(id);
|
||||
return success(BeanUtils.toBean(tmplTp, TmplTpRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/page")
|
||||
@Operation(summary = "获得模板分类分页")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp:query')")
|
||||
public CommonResult<PageResult<TmplTpRespVO>> getTmplTpPage(@Valid TmplTpPageReqVO pageReqVO) {
|
||||
PageResult<TmplTpDO> pageResult = tmplTpService.getTmplTpPage(pageReqVO);
|
||||
return success(BeanUtils.toBean(pageResult, TmplTpRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/export-excel")
|
||||
@Operation(summary = "导出模板分类 Excel")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp:export')")
|
||||
@ApiAccessLog(operateType = EXPORT)
|
||||
public void exportTmplTpExcel(@Valid TmplTpPageReqVO pageReqVO,
|
||||
HttpServletResponse response) throws IOException {
|
||||
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
|
||||
List<TmplTpDO> list = tmplTpService.getTmplTpPage(pageReqVO).getList();
|
||||
// 导出 Excel
|
||||
ExcelUtils.write(response, "模板分类.xls", "数据", TmplTpRespVO.class,
|
||||
BeanUtils.toBean(list, TmplTpRespVO.class));
|
||||
}
|
||||
//字段和条款回显
|
||||
@GetMapping("/field-and-clause")
|
||||
@Operation(summary = "获得字段和条款",description = "字段和条款回显,传入模版分类的id")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp:query')")
|
||||
public CommonResult<Map<String, Object>> getFieldAndClause(@RequestParam("id") Long id) {
|
||||
Map<String, Object> map = new HashMap<>();
|
||||
map.put("field", tmplTpService.getField(id));
|
||||
map.put("clause", tmplTpService.getClause(id));
|
||||
return success(map);
|
||||
}
|
||||
//获取分类树
|
||||
@GetMapping("/tree")
|
||||
@Operation(summary = "获得分类树--上级")
|
||||
public CommonResult<List<TmplTpTreeVO>> getTree() {
|
||||
List<TmplTpTreeVO> tree = tmplTpService.buildTree();
|
||||
return success(tree);
|
||||
}
|
||||
|
||||
//更新类型状态
|
||||
@PutMapping("/updateStatus")
|
||||
@Operation(summary = "更新模板类型状态")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp:update')")
|
||||
public CommonResult<Boolean> updateStatus(@RequestBody Map<String,Object> params) {
|
||||
if (params == null){
|
||||
throw exception(PARAMS_IS_NULL_OR_ERR);
|
||||
}
|
||||
if (!params.containsKey("id") || !params.containsKey("sts")){
|
||||
throw exception(PARAMS_IS_NULL_OR_ERR);
|
||||
}
|
||||
tmplTpService.updateStatus(Long.valueOf(params.get("id").toString()), params.get("sts").toString());
|
||||
return success(true);
|
||||
}
|
||||
|
||||
//表单预览
|
||||
// @GetMapping("/preview")
|
||||
// @Operation(summary = "表单预览",description = "传入模版分类的id")
|
||||
// @PreAuthorize("@ss.hasPermission('bse:tmpl-tp:query')")
|
||||
// public CommonResult< List<TmplFldRespVO>> preview(@Valid @RequestParam("id") Long id) {
|
||||
// List<TmplFldRespVO> field = tmplTpService.getField(id);
|
||||
// return success(field);
|
||||
// }
|
||||
|
||||
// 字段编辑新增或者删除
|
||||
@PostMapping("/field-edit")
|
||||
@Operation(summary = "字段编辑新增或者删除")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp:update')")
|
||||
public CommonResult<Boolean> fieldEdit(@Valid @RequestBody TmplTpEditOrDeleteReqVO reqVO) {
|
||||
tmplTpService.fieldEdit(reqVO);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@PostMapping("/ltm-edit")
|
||||
@Operation(summary = "条款编辑新增或者删除")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp:update')")
|
||||
public CommonResult<Boolean> ltmEdit(@Valid @RequestBody TmplTpEditOrDeleteReqVO reqVO) {
|
||||
tmplTpService.ltmEdit(reqVO);
|
||||
return success(true);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,62 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp;
|
||||
|
||||
import com.zt.plat.framework.business.annotation.FileUploadController;
|
||||
import com.zt.plat.framework.common.pojo.CommonResult;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.vo.BatchDeleteReqVO;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplFldPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplFldRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplTpFldSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplTpFldDO;
|
||||
import com.zt.plat.module.base.service.tmpltp.TmplTpFldService;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import jakarta.validation.Valid;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import static com.zt.plat.framework.common.pojo.CommonResult.success;
|
||||
|
||||
@Tag(name = "管理后台 - 模板字段")
|
||||
@RestController
|
||||
@RequestMapping("/base/tmpl-fld")
|
||||
@Validated
|
||||
@FileUploadController(source = "bse.tmplfld")
|
||||
@RequiredArgsConstructor
|
||||
public class TmplTpFldController {
|
||||
private final TmplTpFldService tmplTpFldService;
|
||||
@PostMapping("/create")
|
||||
@Operation(summary = "创建模板字段")
|
||||
// @PreAuthorize("@ss.hasPermission('bse:tmpl-tp-fld:create')")
|
||||
public CommonResult<TmplFldRespVO> createTmplFld(@Valid @RequestBody TmplTpFldSaveReqVO tmplTpFldSaveReqVO) {
|
||||
return success(tmplTpFldService.createTmplFld(tmplTpFldSaveReqVO));
|
||||
}
|
||||
|
||||
@PutMapping("/update")
|
||||
@Operation(summary = "更新模板字段")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp-fld:update')")
|
||||
public CommonResult<Boolean> updateTmplTp(@Valid @RequestBody TmplTpFldSaveReqVO updateReqVO) {
|
||||
tmplTpFldService.updateTmplFld(updateReqVO);
|
||||
return success(true);
|
||||
}
|
||||
@DeleteMapping("/delete")
|
||||
@Operation(summary = "删除模板字段")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp-fld:delete')")
|
||||
public CommonResult<Boolean> deleteTmplTp(@RequestBody BatchDeleteReqVO req) {
|
||||
tmplTpFldService.deleteTmplTpByIds(req.getIds());
|
||||
return success(true);
|
||||
}
|
||||
@GetMapping("/page")
|
||||
@Operation(summary = "获得模板字段列表")
|
||||
@PreAuthorize("@ss.hasPermission('bse:tmpl-tp-fld:list')")
|
||||
public CommonResult<PageResult<TmplFldRespVO>> getTmplTpList( @Valid TmplFldPageReqVO pageReqVO) {
|
||||
PageResult<TmplTpFldDO> pageResult = tmplTpFldService.tmplTpFldPage(pageReqVO);
|
||||
return success(BeanUtils.toBean(pageResult, TmplFldRespVO.class));
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,27 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import lombok.*;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.*;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
|
||||
import static com.zt.plat.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
|
||||
|
||||
@Schema(description = "管理后台 - 部门与实例关联分页 Request VO")
|
||||
@Data
|
||||
public class DepartmentInstanceRelativityPageReqVO extends PageParam {
|
||||
|
||||
@Schema(description = "部门主键", example = "2450")
|
||||
private String companyDepartmentId;
|
||||
|
||||
@Schema(description = "模板实例主键", example = "17846")
|
||||
private String templateInstanceId;
|
||||
|
||||
@Schema(description = "创建时间")
|
||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
||||
private LocalDate[] createTime;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,31 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.*;
|
||||
import com.alibaba.excel.annotation.*;
|
||||
|
||||
@Schema(description = "管理后台 - 部门与实例关联 Response VO")
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
public class DepartmentInstanceRelativityRespVO {
|
||||
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "4864")
|
||||
@ExcelProperty("主键")
|
||||
private String id;
|
||||
|
||||
@Schema(description = "部门主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "2450")
|
||||
@ExcelProperty("部门主键")
|
||||
private String companyDepartmentId;
|
||||
|
||||
@Schema(description = "模板实例主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "17846")
|
||||
@ExcelProperty("模板实例主键")
|
||||
private String templateInstanceId;
|
||||
|
||||
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("创建时间")
|
||||
private LocalDate createTime;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,23 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import jakarta.validation.constraints.*;
|
||||
|
||||
@Schema(description = "管理后台 - 部门与实例关联新增/修改 Request VO")
|
||||
@Data
|
||||
public class DepartmentInstanceRelativitySaveReqVO {
|
||||
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "4864")
|
||||
private String id;
|
||||
|
||||
@Schema(description = "部门主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "2450")
|
||||
@NotEmpty(message = "部门主键不能为空")
|
||||
private String companyDepartmentId;
|
||||
|
||||
@Schema(description = "模板实例主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "17846")
|
||||
@NotEmpty(message = "模板实例主键不能为空")
|
||||
private String templateInstanceId;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,29 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
import static com.zt.plat.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
|
||||
|
||||
@Schema(description = "管理后台 - 实例字段值分页 Request VO")
|
||||
@Data
|
||||
public class TemplateInstanceDataPageReqVO extends PageParam {
|
||||
|
||||
@Schema(description = "关联实例主键", example = "25824")
|
||||
private String inscId;
|
||||
|
||||
@Schema(description = "字段标识;关联字段库")
|
||||
private String fldKy;
|
||||
|
||||
@Schema(description = "用户填写的值")
|
||||
private String fldVal;
|
||||
|
||||
@Schema(description = "创建时间")
|
||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
||||
private LocalDateTime[] createTime;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,35 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
import java.time.LocalDateTime;
|
||||
import com.alibaba.excel.annotation.*;
|
||||
|
||||
@Schema(description = "管理后台 - 实例字段值 Response VO")
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
public class TemplateInstanceDataRespVO {
|
||||
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "10920")
|
||||
@ExcelProperty("主键")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "关联实例主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "25824")
|
||||
@ExcelProperty("关联实例主键")
|
||||
private String inscId;
|
||||
|
||||
@Schema(description = "字段标识;关联字段库", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("字段标识;关联字段库")
|
||||
private String fldKy;
|
||||
|
||||
@Schema(description = "用户填写的值", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("用户填写的值")
|
||||
private String fldVal;
|
||||
|
||||
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("创建时间")
|
||||
private LocalDateTime createTime;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,27 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import jakarta.validation.constraints.*;
|
||||
|
||||
@Schema(description = "管理后台 - 实例字段值新增/修改 Request VO")
|
||||
@Data
|
||||
public class TemplateInstanceDataSaveReqVO {
|
||||
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "10920")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "关联实例主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "25824")
|
||||
@NotEmpty(message = "关联实例主键不能为空")
|
||||
private String inscId;
|
||||
|
||||
@Schema(description = "字段标识;关联字段库", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotEmpty(message = "字段标识;关联字段库不能为空")
|
||||
private String fldKy;
|
||||
|
||||
@Schema(description = "用户填写的值", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotEmpty(message = "用户填写的值不能为空")
|
||||
private String fldVal;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,30 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import lombok.*;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.*;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
|
||||
import static com.zt.plat.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
|
||||
|
||||
@Schema(description = "管理后台 - 实例条款值分页 Request VO")
|
||||
@Data
|
||||
public class TemplateInstanceItemPageReqVO extends PageParam {
|
||||
|
||||
@Schema(description = "关联实例主键", example = "28964")
|
||||
private String inscId;
|
||||
|
||||
@Schema(description = "条款库主键;关联字段库", example = "11278")
|
||||
private String itmId;
|
||||
|
||||
@Schema(description = "用户填写的值")
|
||||
private String val;
|
||||
|
||||
@Schema(description = "创建时间")
|
||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
||||
private LocalDate[] createTime;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,35 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.*;
|
||||
import com.alibaba.excel.annotation.*;
|
||||
|
||||
@Schema(description = "管理后台 - 实例条款值 Response VO")
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
public class TemplateInstanceItemRespVO {
|
||||
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "25152")
|
||||
@ExcelProperty("主键")
|
||||
private String id;
|
||||
|
||||
@Schema(description = "关联实例主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "28964")
|
||||
@ExcelProperty("关联实例主键")
|
||||
private String inscId;
|
||||
|
||||
@Schema(description = "条款库主键;关联字段库", requiredMode = Schema.RequiredMode.REQUIRED, example = "11278")
|
||||
@ExcelProperty("条款库主键;关联字段库")
|
||||
private String itmId;
|
||||
|
||||
@Schema(description = "用户填写的值", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("用户填写的值")
|
||||
private String val;
|
||||
|
||||
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("创建时间")
|
||||
private LocalDate createTime;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,27 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import jakarta.validation.constraints.*;
|
||||
|
||||
@Schema(description = "管理后台 - 实例条款值新增/修改 Request VO")
|
||||
@Data
|
||||
public class TemplateInstanceItemSaveReqVO {
|
||||
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "25152")
|
||||
private String id;
|
||||
|
||||
@Schema(description = "关联实例主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "28964")
|
||||
@NotEmpty(message = "关联实例主键不能为空")
|
||||
private String inscId;
|
||||
|
||||
@Schema(description = "条款库主键;关联字段库", requiredMode = Schema.RequiredMode.REQUIRED, example = "11278")
|
||||
@NotEmpty(message = "条款库主键;关联字段库不能为空")
|
||||
private String itmId;
|
||||
|
||||
@Schema(description = "用户填写的值", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotEmpty(message = "用户填写的值不能为空")
|
||||
private String val;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,47 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
import static com.zt.plat.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
|
||||
|
||||
@Schema(description = "管理后台 - 模板实例分页 Request VO")
|
||||
@Data
|
||||
public class TemplateInstancePageReqVO extends PageParam {
|
||||
|
||||
@Schema(description = "分类树主键", example = "7804")
|
||||
private Long tpId;
|
||||
|
||||
@Schema(description = "模板名称", example = "王五")
|
||||
private String name;
|
||||
|
||||
@Schema(description = "模板编码")
|
||||
private String cdg;
|
||||
|
||||
@Schema(description = "模板描述")
|
||||
private String dsp;
|
||||
|
||||
@Schema(description = "实例文件内容")
|
||||
private String cntt;
|
||||
|
||||
@Schema(description = "原始文件内容")
|
||||
private String origCntt;
|
||||
|
||||
@Schema(description = "文件类型", example = "1")
|
||||
private String fileTp;
|
||||
|
||||
@Schema(description = "版本号;如v1.0")
|
||||
private String ver;
|
||||
|
||||
@Schema(description = "状态", example = "2")
|
||||
private String sts;
|
||||
|
||||
@Schema(description = "创建时间")
|
||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
||||
private LocalDateTime[] createTime;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,59 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
import java.time.LocalDateTime;
|
||||
import com.alibaba.excel.annotation.*;
|
||||
|
||||
@Schema(description = "管理后台 - 模板实例 Response VO")
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
public class TemplateInstanceRespVO {
|
||||
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "29024")
|
||||
@ExcelProperty("主键")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "分类树主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "7804")
|
||||
@ExcelProperty("分类树主键")
|
||||
private Long tpId;
|
||||
|
||||
@Schema(description = "模板名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "王五")
|
||||
@ExcelProperty("模板名称")
|
||||
private String name;
|
||||
|
||||
@Schema(description = "模板编码", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("模板编码")
|
||||
private String cdg;
|
||||
|
||||
@Schema(description = "模板描述")
|
||||
@ExcelProperty("模板描述")
|
||||
private String dsp;
|
||||
|
||||
@Schema(description = "实例文件内容")
|
||||
@ExcelProperty("实例文件内容")
|
||||
private String cntt;
|
||||
|
||||
@Schema(description = "原始文件内容", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("原始文件内容")
|
||||
private String origCntt;
|
||||
|
||||
@Schema(description = "文件类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
|
||||
@ExcelProperty("文件类型")
|
||||
private String fileTp;
|
||||
|
||||
@Schema(description = "版本号;如v1.0", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("版本号;如v1.0")
|
||||
private String ver;
|
||||
|
||||
@Schema(description = "状态", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
|
||||
@ExcelProperty("状态")
|
||||
private String sts;
|
||||
|
||||
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("创建时间")
|
||||
private LocalDateTime createTime;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,54 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import jakarta.validation.constraints.*;
|
||||
|
||||
@Schema(description = "管理后台 - 模板实例新增/修改 Request VO")
|
||||
@Data
|
||||
public class TemplateInstanceSaveReqVO {
|
||||
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "29024")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "分类树主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "7804")
|
||||
@NotNull(message = "分类树主键不能为空")
|
||||
private Long tpId;
|
||||
|
||||
@Schema(description = "模板名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "王五")
|
||||
@NotEmpty(message = "模板名称不能为空")
|
||||
private String name;
|
||||
|
||||
@Schema(description = "模板编码", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotEmpty(message = "模板编码不能为空")
|
||||
private String cdg;
|
||||
|
||||
@Schema(description = "模板描述")
|
||||
private String dsp;
|
||||
|
||||
@Schema(description = "实例文件内容")
|
||||
private String cntt;
|
||||
|
||||
@Schema(description = "原始文件内容", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
// @NotEmpty(message = "原始文件内容不能为空")
|
||||
private String origCntt;
|
||||
|
||||
@Schema(description = "文件类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
|
||||
@NotEmpty(message = "文件类型不能为空")
|
||||
private String fileTp;
|
||||
|
||||
@Schema(description = "版本号;如v1.0", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotEmpty(message = "版本号;如v1.0不能为空")
|
||||
private String ver;
|
||||
|
||||
@Schema(description = "状态", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
|
||||
@NotEmpty(message = "状态不能为空")
|
||||
private String sts;
|
||||
|
||||
|
||||
@Schema(description = "使用部门编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
|
||||
@NotEmpty(message = "使用部门编号不能为空")
|
||||
private List<Long> deptIds;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,35 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.Data;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
|
||||
import java.time.LocalDate;
|
||||
|
||||
import static com.zt.plat.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
|
||||
|
||||
|
||||
@Schema(description = "管理后台 - 模板条款分页 Request VO")
|
||||
@Data
|
||||
public class TmpItmPageReqVO extends PageParam {
|
||||
|
||||
@Schema(description = "主键", example = "")
|
||||
private String id;
|
||||
|
||||
@Schema(description = "条款编号")
|
||||
private String itmNum;
|
||||
|
||||
@Schema(description = "条款名称", example = "")
|
||||
private String itmName;
|
||||
|
||||
@Schema(description = "备注")
|
||||
private String rmk;
|
||||
|
||||
@Schema(description = "条款值")
|
||||
private String itmVal;
|
||||
|
||||
@Schema(description = "创建时间")
|
||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
||||
private LocalDate[] createTime;
|
||||
}
|
||||
@@ -0,0 +1,38 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.Data;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
|
||||
import java.time.LocalDate;
|
||||
|
||||
import static com.zt.plat.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
|
||||
|
||||
|
||||
@Schema(description = "管理后台 - 模板字段分页 Request VO")
|
||||
@Data
|
||||
public class TmplFldPageReqVO extends PageParam {
|
||||
|
||||
@Schema(description = "字段编码", example = "")
|
||||
private String fldKy;
|
||||
|
||||
@Schema(description = "字段名称")
|
||||
private String fldName;
|
||||
|
||||
@Schema(description = "数据类型", example = "")
|
||||
private String datTp;
|
||||
|
||||
@Schema(description = "字段结构")
|
||||
private String fldDoc;
|
||||
|
||||
@Schema(description = "备注")
|
||||
private String rmk;
|
||||
@Schema(description = "是否必填")
|
||||
private String isMust;
|
||||
|
||||
@Schema(description = "创建时间")
|
||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
||||
private LocalDate[] createTime;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,43 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
|
||||
import com.alibaba.excel.annotation.ExcelProperty;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.Data;
|
||||
|
||||
import java.time.LocalDate;
|
||||
|
||||
@Schema(description = "管理后台 - 模板分类 Response VO")
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
public class TmplFldRespVO {
|
||||
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
@ExcelProperty("主键")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "类型字段编码", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
@ExcelProperty("类型字段编码")
|
||||
private String fldKy;
|
||||
|
||||
@Schema(description = "字段名称", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("字段名称")
|
||||
private String fldName;
|
||||
|
||||
@Schema(description = "数据类型", example = "")
|
||||
@ExcelProperty("数据类型")
|
||||
private String datTp;
|
||||
|
||||
@Schema(description = "字段结构", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("字段结构")
|
||||
private String fldDoc;
|
||||
|
||||
@Schema(description = "备注", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("备注")
|
||||
private String rmk;
|
||||
|
||||
@Schema(description = "是否必填, 建议值:Y(是)、N(否),需在业务层做枚举校验", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("是否必填")
|
||||
private String isMust;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,47 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
|
||||
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
|
||||
import com.alibaba.excel.annotation.ExcelProperty;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.Data;
|
||||
|
||||
import java.time.LocalDate;
|
||||
|
||||
@Schema(description = "管理后台 - 模板分类 Response VO")
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
public class TmplItmRespVO {
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
@ExcelProperty("主键")
|
||||
private String id;
|
||||
|
||||
|
||||
@Schema(description = "条款编码", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
@ExcelProperty("条款编码")
|
||||
private String itmNum;
|
||||
|
||||
|
||||
@Schema(description = "条款名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
@ExcelProperty("条款名称")
|
||||
private String itmName;
|
||||
|
||||
|
||||
@Schema(description = "备注", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
@ExcelProperty("备注")
|
||||
private String rmk;
|
||||
|
||||
|
||||
@Schema(description = "条款结构", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
@ExcelProperty("条款结构")
|
||||
private String itmVal;
|
||||
|
||||
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("创建时间")
|
||||
private LocalDate createTime;
|
||||
|
||||
|
||||
@Schema(description = "创建人", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("创建人")
|
||||
private String creator;
|
||||
}
|
||||
@@ -0,0 +1,26 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import com.baomidou.mybatisplus.annotation.IdType;
|
||||
import com.baomidou.mybatisplus.annotation.TableField;
|
||||
import com.baomidou.mybatisplus.annotation.TableId;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.Data;
|
||||
|
||||
@Schema(description = "管理后台 - 模板条款新增/修改 Request VO")
|
||||
@Data
|
||||
public class TmplItmSaveReqVO {
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "条款编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
private String itmNum;
|
||||
|
||||
@Schema(description = "条款名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
private String itmName;
|
||||
|
||||
@Schema(description = "备注", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
private String rmk;
|
||||
|
||||
@Schema(description = "条款值", requiredMode = Schema.RequiredMode.REQUIRED, example = "")
|
||||
private String itmVal;
|
||||
}
|
||||
@@ -0,0 +1,28 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import com.alibaba.excel.annotation.ExcelProperty;
|
||||
import groovyjarjarantlr4.v4.runtime.misc.NotNull;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import jakarta.validation.constraints.NotEmpty;
|
||||
import lombok.Data;
|
||||
import lombok.NonNull;
|
||||
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Schema(description = "管理后台 - 模板编辑字段新增/删除 Request VO")
|
||||
@Data
|
||||
public class TmplTpEditOrDeleteReqVO {
|
||||
|
||||
@Schema(description = "模版ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "20895")
|
||||
@NotEmpty(message = "模版id不能为空")
|
||||
private String tpId;
|
||||
|
||||
@Schema(description = "操作类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "create or delete")
|
||||
@NotEmpty(message = "操作类型不能为空")
|
||||
private String type;
|
||||
|
||||
@Schema(description = "变更的ids", requiredMode = Schema.RequiredMode.REQUIRED, example = "[20895,23231]")
|
||||
@NotEmpty(message = "变更的ids不能为空")
|
||||
private List<String> ids;
|
||||
}
|
||||
@@ -0,0 +1,25 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import com.alibaba.fastjson2.JSONObject;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.Data;
|
||||
|
||||
@Schema(description = "管理后台 - 模板字段新增/修改 Request VO")
|
||||
@Data
|
||||
public class TmplTpFldSaveReqVO {
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "20895")
|
||||
private Long id;
|
||||
@Schema(description = "字段编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "code")
|
||||
private String fldKy;
|
||||
@Schema(description = "字段名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "代码")
|
||||
private String fldName;
|
||||
@Schema(description = "字段数据类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "string")
|
||||
private String datTp;
|
||||
@Schema(description = "字段描述", requiredMode = Schema.RequiredMode.REQUIRED, example = "代码")
|
||||
private JSONObject fldDoc;
|
||||
@Schema(description = "字段备注", requiredMode = Schema.RequiredMode.REQUIRED, example = "代码")
|
||||
private String rmk;
|
||||
@Schema(description = "是否必填", requiredMode = Schema.RequiredMode.REQUIRED, example = "Y or N")
|
||||
private String isMust;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,37 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import lombok.*;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.*;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
|
||||
import static com.zt.plat.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
|
||||
|
||||
|
||||
@Schema(description = "管理后台 - 模板分类分页 Request VO")
|
||||
@Data
|
||||
public class TmplTpPageReqVO extends PageParam {
|
||||
|
||||
@Schema(description = "类型名称", example = "王五")
|
||||
private String name;
|
||||
|
||||
@Schema(description = "类型编码")
|
||||
private String num;
|
||||
|
||||
@Schema(description = "父类型主键;顶级为NULL", example = "20414")
|
||||
private Long prnId;
|
||||
|
||||
@Schema(description = "同级排序序号")
|
||||
private Long srt;
|
||||
|
||||
@Schema(description = "状态")
|
||||
private String sts;
|
||||
|
||||
@Schema(description = "创建时间")
|
||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
||||
private LocalDate[] createTime;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,43 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.*;
|
||||
import com.alibaba.excel.annotation.*;
|
||||
|
||||
@Schema(description = "管理后台 - 模板分类 Response VO")
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
public class TmplTpRespVO {
|
||||
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "20895")
|
||||
@ExcelProperty("主键")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "类型名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "王五")
|
||||
@ExcelProperty("类型名称")
|
||||
private String name;
|
||||
|
||||
@Schema(description = "类型编码", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("类型编码")
|
||||
private String num;
|
||||
|
||||
@Schema(description = "父类型主键;顶级为NULL", example = "20414")
|
||||
@ExcelProperty("父类型主键;顶级为NULL")
|
||||
private Long prnId;
|
||||
|
||||
@Schema(description = "同级排序序号", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("同级排序序号")
|
||||
private Long srt;
|
||||
|
||||
@Schema(description = "状态", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("状态")
|
||||
private String sts;
|
||||
|
||||
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("创建时间")
|
||||
private LocalDate createTime;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,37 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import jakarta.validation.constraints.*;
|
||||
|
||||
@Schema(description = "管理后台 - 模板分类新增/修改 Request VO")
|
||||
@Data
|
||||
public class TmplTpSaveReqVO {
|
||||
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "20895")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "类型名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "王五")
|
||||
@NotEmpty(message = "类型名称不能为空")
|
||||
private String name;
|
||||
|
||||
@Schema(description = "类型编码", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotEmpty(message = "类型编码不能为空")
|
||||
private String num;
|
||||
|
||||
@Schema(description = "父类型主键;顶级为NULL", example = "20414")
|
||||
private Long prnId;
|
||||
|
||||
@Schema(description = "同级排序序号", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotNull(message = "同级排序序号不能为空")
|
||||
private Long srt;
|
||||
|
||||
@Schema(description = "状态", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
private String sts;
|
||||
|
||||
private List<String> tmplItmIds ;
|
||||
|
||||
private List<String> tmplTpFldIds;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,33 @@
|
||||
package com.zt.plat.module.base.controller.admin.templtp.vo;
|
||||
|
||||
import com.alibaba.excel.annotation.ExcelProperty;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.Data;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.List;
|
||||
@Data
|
||||
public class TmplTpTreeVO{
|
||||
@Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "20895")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "类型名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "王五")
|
||||
private String name;
|
||||
|
||||
@Schema(description = "类型编码", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
private String num;
|
||||
|
||||
@Schema(description = "父类型主键;顶级为NULL", example = "20414")
|
||||
private Long prnId;
|
||||
|
||||
@Schema(description = "同级排序序号", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
private Long srt;
|
||||
|
||||
@Schema(description = "状态", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
private String sts;
|
||||
|
||||
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
private LocalDate createTime;
|
||||
|
||||
private List<TmplTpTreeVO> children;
|
||||
}
|
||||
@@ -0,0 +1,43 @@
|
||||
package com.zt.plat.module.base.dal.dataobject.tmpltp;
|
||||
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import com.zt.plat.framework.mybatis.core.dataobject.BusinessBaseDO;
|
||||
/**
|
||||
* 部门与实例关联 DO
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@TableName("bse_dept_insc_rel")
|
||||
@KeySequence("bse_dept_insc_rel_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
@Builder
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
/**
|
||||
* 支持业务基类继承:isBusiness=true 时继承 BusinessBaseDO,否则继承 BaseDO
|
||||
*/
|
||||
public class DepartmentInstanceRelativityDO extends BusinessBaseDO {
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 主键
|
||||
*/
|
||||
@TableId(type = IdType.INPUT)
|
||||
private String id;
|
||||
/**
|
||||
* 部门主键
|
||||
*/
|
||||
@TableField("CPN_DEPT_ID")
|
||||
private String companyDepartmentId;
|
||||
/**
|
||||
* 模板实例主键
|
||||
*/
|
||||
@TableField("TMPL_INSC_ID")
|
||||
private String templateInstanceId;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,92 @@
|
||||
package com.zt.plat.module.base.dal.dataobject.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.mybatis.core.dataobject.BusinessBaseDO;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import java.time.LocalDateTime;
|
||||
import java.time.LocalDateTime;
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import com.zt.plat.framework.mybatis.core.dataobject.BaseDO;
|
||||
/**
|
||||
* 模板实例 DO
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@TableName("bse_tmpl_insc")
|
||||
@KeySequence("bse_tmpl_insc_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
@Builder
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
/**
|
||||
* 支持业务基类继承:isBusiness=true 时继承 BusinessBaseDO,否则继承 BaseDO
|
||||
*/
|
||||
public class TemplateInstanceDO extends BusinessBaseDO {
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 主键
|
||||
*/
|
||||
@TableId(type = IdType.ASSIGN_ID)
|
||||
private Long id;
|
||||
/**
|
||||
* 分类树主键
|
||||
*/
|
||||
private Long tpId;
|
||||
/**
|
||||
* 模板名称
|
||||
*/
|
||||
private String name;
|
||||
/**
|
||||
* 模板编码
|
||||
*/
|
||||
private String cdg;
|
||||
/**
|
||||
* 模板描述
|
||||
*/
|
||||
private String dsp;
|
||||
/**
|
||||
* 实例文件内容
|
||||
*/
|
||||
private String cntt;
|
||||
/**
|
||||
* 原始文件内容
|
||||
*/
|
||||
private String origCntt;
|
||||
/**
|
||||
* 文件类型
|
||||
*/
|
||||
private String fileTp;
|
||||
/**
|
||||
* 版本号;如v1.0
|
||||
*/
|
||||
private String ver;
|
||||
/**
|
||||
* 状态
|
||||
*/
|
||||
private String sts;
|
||||
// /**
|
||||
// * 公司编号
|
||||
// */
|
||||
// private Long companyId;
|
||||
// /**
|
||||
// * 公司名称
|
||||
// */
|
||||
// private String companyName;
|
||||
// /**
|
||||
// * 部门编号
|
||||
// */
|
||||
// private Long deptId;
|
||||
// /**
|
||||
// * 部门名称
|
||||
// */
|
||||
// private String deptName;
|
||||
// /**
|
||||
// * 岗位编号
|
||||
// */
|
||||
// private Long postId;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,50 @@
|
||||
package com.zt.plat.module.base.dal.dataobject.tmpltp;
|
||||
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import java.time.LocalDateTime;
|
||||
import java.time.LocalDateTime;
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import com.zt.plat.framework.mybatis.core.dataobject.BusinessBaseDO;
|
||||
/**
|
||||
* 实例字段值 DO
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@TableName("bse_tmpl_insc_dat")
|
||||
@KeySequence("bse_tmpl_insc_dat_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
@Builder
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
/**
|
||||
* 支持业务基类继承:isBusiness=true 时继承 BusinessBaseDO,否则继承 BaseDO
|
||||
*/
|
||||
public class TemplateInstanceDataDO extends BusinessBaseDO {
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 主键
|
||||
*/
|
||||
@TableId(type = IdType.ASSIGN_ID)
|
||||
private Long id;
|
||||
/**
|
||||
* 关联实例主键
|
||||
*/
|
||||
@TableField("INSC_ID")
|
||||
private String inscId;
|
||||
/**
|
||||
* 字段标识;关联字段库
|
||||
*/
|
||||
@TableField("FLD_KY")
|
||||
private String fldKy;
|
||||
/**
|
||||
* 用户填写的值
|
||||
*/
|
||||
@TableField("FLD_VAL")
|
||||
private String fldVal;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,48 @@
|
||||
package com.zt.plat.module.base.dal.dataobject.tmpltp;
|
||||
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import com.zt.plat.framework.mybatis.core.dataobject.BusinessBaseDO;
|
||||
/**
|
||||
* 实例条款值 DO
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@TableName("bse_tmpl_insc_itm")
|
||||
@KeySequence("bse_tmpl_insc_itm_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
@Builder
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
/**
|
||||
* 支持业务基类继承:isBusiness=true 时继承 BusinessBaseDO,否则继承 BaseDO
|
||||
*/
|
||||
public class TemplateInstanceItemDO extends BusinessBaseDO {
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 主键
|
||||
*/
|
||||
@TableId(type = IdType.INPUT)
|
||||
private String id;
|
||||
/**
|
||||
* 关联实例主键
|
||||
*/
|
||||
@TableField("INSC_ID")
|
||||
private String inscId;
|
||||
/**
|
||||
* 条款库主键;关联字段库
|
||||
*/
|
||||
@TableField("ITM_ID")
|
||||
private String itmId;
|
||||
/**
|
||||
* 用户填写的值
|
||||
*/
|
||||
@TableField("VAL")
|
||||
private String val;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,35 @@
|
||||
package com.zt.plat.module.base.dal.dataobject.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.mybatis.core.dataobject.BusinessBaseDO;
|
||||
import com.baomidou.mybatisplus.annotation.IdType;
|
||||
import com.baomidou.mybatisplus.annotation.KeySequence;
|
||||
import com.baomidou.mybatisplus.annotation.TableField;
|
||||
import com.baomidou.mybatisplus.annotation.TableId;
|
||||
import com.baomidou.mybatisplus.annotation.TableName;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Builder;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import lombok.NoArgsConstructor;
|
||||
import lombok.ToString;
|
||||
|
||||
@TableName("BSE_TMPL_FLD_REL")
|
||||
@KeySequence("BSE_TMPL_FLD_REL_SEQ")
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
@Builder
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
public class TmplFldRelDO extends BusinessBaseDO {
|
||||
|
||||
@TableId(type = IdType.ASSIGN_ID)
|
||||
private String id;
|
||||
|
||||
@TableField("TMPL_TP_ID")
|
||||
private String tmplTpId;
|
||||
|
||||
@TableField("TP_FLD_ID")
|
||||
private String tpFldId;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,41 @@
|
||||
package com.zt.plat.module.base.dal.dataobject.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.mybatis.core.dataobject.BusinessBaseDO;
|
||||
import com.baomidou.mybatisplus.annotation.IdType;
|
||||
import com.baomidou.mybatisplus.annotation.KeySequence;
|
||||
import com.baomidou.mybatisplus.annotation.TableField;
|
||||
import com.baomidou.mybatisplus.annotation.TableId;
|
||||
import com.baomidou.mybatisplus.annotation.TableName;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Builder;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import lombok.NoArgsConstructor;
|
||||
import lombok.ToString;
|
||||
|
||||
@TableName("BSE_TMPL_ITM")
|
||||
@KeySequence("BSE_TMPL_ITM_SEQ")
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
@Builder
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
public class TmplItmDO extends BusinessBaseDO {
|
||||
|
||||
@TableId(type = IdType.ASSIGN_ID)
|
||||
private String id;
|
||||
|
||||
@TableField("ITM_NUM")
|
||||
private String itmNum;
|
||||
|
||||
@TableField("ITM_NAME")
|
||||
private String itmName;
|
||||
|
||||
@TableField("RMK")
|
||||
private String rmk;
|
||||
|
||||
@TableField("ITM_VAL")
|
||||
private String itmVal;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,35 @@
|
||||
package com.zt.plat.module.base.dal.dataobject.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.mybatis.core.dataobject.BusinessBaseDO;
|
||||
import com.baomidou.mybatisplus.annotation.IdType;
|
||||
import com.baomidou.mybatisplus.annotation.KeySequence;
|
||||
import com.baomidou.mybatisplus.annotation.TableField;
|
||||
import com.baomidou.mybatisplus.annotation.TableId;
|
||||
import com.baomidou.mybatisplus.annotation.TableName;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Builder;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import lombok.NoArgsConstructor;
|
||||
import lombok.ToString;
|
||||
|
||||
@TableName("BSE_TMPL_ITM_REL")
|
||||
@KeySequence("BSE_TMPL_ITM_REL_SEQ")
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
@Builder
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
public class TmplItmRelDO extends BusinessBaseDO {
|
||||
|
||||
@TableId(type = IdType.ASSIGN_ID)
|
||||
private String id;
|
||||
|
||||
@TableField("TMPL_TP_ID")
|
||||
private String tmplTpId;
|
||||
|
||||
@TableField("ITM_FLD_ID")
|
||||
private String itmFldId;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,58 @@
|
||||
package com.zt.plat.module.base.dal.dataobject.tmpltp;
|
||||
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import com.zt.plat.framework.mybatis.core.dataobject.BusinessBaseDO;
|
||||
/**
|
||||
* 模板分类 DO
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@TableName("bse_tmpl_tp")
|
||||
@KeySequence("bse_tmpl_tp_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
@Builder
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
/**
|
||||
* 支持业务基类继承:isBusiness=true 时继承 BusinessBaseDO,否则继承 BaseDO
|
||||
*/
|
||||
public class TmplTpDO extends BusinessBaseDO {
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 主键
|
||||
*/
|
||||
@TableId(type = IdType.ASSIGN_ID)
|
||||
private Long id;
|
||||
/**
|
||||
* 类型名称
|
||||
*/
|
||||
@TableField("NAME")
|
||||
private String name;
|
||||
/**
|
||||
* 类型编码
|
||||
*/
|
||||
@TableField("NUM")
|
||||
private String num;
|
||||
/**
|
||||
* 父类型主键;顶级为NULL
|
||||
*/
|
||||
@TableField("PRN_ID")
|
||||
private Long prnId;
|
||||
/**
|
||||
* 同级排序序号
|
||||
*/
|
||||
@TableField("SRT")
|
||||
private Long srt;
|
||||
/**
|
||||
* 状态
|
||||
*/
|
||||
@TableField("STS")
|
||||
private String sts;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,71 @@
|
||||
package com.zt.plat.module.base.dal.dataobject.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.mybatis.core.dataobject.BusinessBaseDO;
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import lombok.*;
|
||||
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
/**
|
||||
* 字段库 DO
|
||||
* 对应数据库表:BIZ_TMPL_TP_FLD
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@TableName("BIZ_TMPL_TP_FLD")
|
||||
@KeySequence("BIZ_TMPL_TP_FLD_SEQ")
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
@Builder
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
public class TmplTpFldDO extends BusinessBaseDO { // 继承业务基类,自动获取公司/部门/租户等公共字段
|
||||
|
||||
/**
|
||||
* 主键(对应表中 ID 字段,VARCHAR2(64) 类型)
|
||||
* 注意:表中 ID 为字符串类型,此处使用 String 而非 Long,与 TmplTpDO 区分
|
||||
*/
|
||||
@TableId(type = IdType.ASSIGN_ID) // 手动输入主键(因表中 ID 是 VARCHAR2,非自增 Long)
|
||||
private String id;
|
||||
|
||||
/**
|
||||
* 字段编码(对应表中 FLD_KY 字段,VARCHAR2(64) 类型,非空)
|
||||
*/
|
||||
@TableField("FLD_KY")
|
||||
private String fldKy;
|
||||
|
||||
/**
|
||||
* 字段名称(对应表中 FLD_NAME 字段,VARCHAR2(90) 类型,非空)
|
||||
*/
|
||||
@TableField("FLD_NAME")
|
||||
private String fldName;
|
||||
|
||||
/**
|
||||
* 数据类型(对应表中 DAT_TP 字段,VARCHAR2(10) 类型,非空)
|
||||
* 示例值:VARCHAR、INT、DATE、CLOB 等,需与前端/后端数据类型映射
|
||||
*/
|
||||
@TableField("DAT_TP")
|
||||
private String datTp;
|
||||
|
||||
/**
|
||||
* 字段结构(对应表中 FLD_DOC 字段,CLOB(900) 类型,可空)
|
||||
* 存储格式:JSON 字符串(前端传入的字段结构配置),后端可通过 JSON 工具反序列化为对象
|
||||
*/
|
||||
@TableField("FLD_DOC")
|
||||
private String fldDoc;
|
||||
|
||||
/**
|
||||
* 备注(对应表中 RMK 字段,CLOB(900) 类型,非空)
|
||||
* 说明:用于区分同一公司下重复的条款名称
|
||||
*/
|
||||
@TableField("RMK")
|
||||
private String rmk; // 同 FLD_DOC,用 String 接收 CLOB 内容
|
||||
|
||||
/**
|
||||
* 是否必填(对应表中 IS_MUST 字段,VARCHAR2(10) 类型,非空)
|
||||
* 建议值:Y(是)、N(否),需在业务层做枚举校验
|
||||
*/
|
||||
@TableField("IS_MUST")
|
||||
private String isMust;
|
||||
}
|
||||
@@ -0,0 +1,30 @@
|
||||
package com.zt.plat.module.base.dal.mysql.tmpltp;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||
import com.zt.plat.framework.mybatis.core.mapper.BaseMapperX;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.DepartmentInstanceRelativityPageReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.DepartmentInstanceRelativityDO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
|
||||
/**
|
||||
* 部门与实例关联 Mapper
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@Mapper
|
||||
public interface DepartmentInstanceRelativityMapper extends BaseMapperX<DepartmentInstanceRelativityDO> {
|
||||
|
||||
default PageResult<DepartmentInstanceRelativityDO> selectPage(DepartmentInstanceRelativityPageReqVO reqVO) {
|
||||
return selectPage(reqVO, new LambdaQueryWrapperX<DepartmentInstanceRelativityDO>()
|
||||
.eqIfPresent(DepartmentInstanceRelativityDO::getCompanyDepartmentId, reqVO.getCompanyDepartmentId())
|
||||
.eqIfPresent(DepartmentInstanceRelativityDO::getTemplateInstanceId, reqVO.getTemplateInstanceId())
|
||||
.betweenIfPresent(DepartmentInstanceRelativityDO::getCreateTime, reqVO.getCreateTime())
|
||||
.orderByDesc(DepartmentInstanceRelativityDO::getId));
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,31 @@
|
||||
package com.zt.plat.module.base.dal.mysql.tmpltp;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||
import com.zt.plat.framework.mybatis.core.mapper.BaseMapperX;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceDataPageReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceDataDO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
|
||||
/**
|
||||
* 实例字段值 Mapper
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@Mapper
|
||||
public interface TemplateInstanceDataMapper extends BaseMapperX<TemplateInstanceDataDO> {
|
||||
|
||||
default PageResult<TemplateInstanceDataDO> selectPage(TemplateInstanceDataPageReqVO reqVO) {
|
||||
return selectPage(reqVO, new LambdaQueryWrapperX<TemplateInstanceDataDO>()
|
||||
.eqIfPresent(TemplateInstanceDataDO::getInscId, reqVO.getInscId())
|
||||
.eqIfPresent(TemplateInstanceDataDO::getFldKy, reqVO.getFldKy())
|
||||
.eqIfPresent(TemplateInstanceDataDO::getFldVal, reqVO.getFldVal())
|
||||
.betweenIfPresent(TemplateInstanceDataDO::getCreateTime, reqVO.getCreateTime())
|
||||
.orderByDesc(TemplateInstanceDataDO::getId));
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,31 @@
|
||||
package com.zt.plat.module.base.dal.mysql.tmpltp;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||
import com.zt.plat.framework.mybatis.core.mapper.BaseMapperX;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceItemPageReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceItemDO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
|
||||
/**
|
||||
* 实例条款值 Mapper
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@Mapper
|
||||
public interface TemplateInstanceItemMapper extends BaseMapperX<TemplateInstanceItemDO> {
|
||||
|
||||
default PageResult<TemplateInstanceItemDO> selectPage(TemplateInstanceItemPageReqVO reqVO) {
|
||||
return selectPage(reqVO, new LambdaQueryWrapperX<TemplateInstanceItemDO>()
|
||||
.eqIfPresent(TemplateInstanceItemDO::getInscId, reqVO.getInscId())
|
||||
.eqIfPresent(TemplateInstanceItemDO::getItmId, reqVO.getItmId())
|
||||
.eqIfPresent(TemplateInstanceItemDO::getVal, reqVO.getVal())
|
||||
.betweenIfPresent(TemplateInstanceItemDO::getCreateTime, reqVO.getCreateTime())
|
||||
.orderByDesc(TemplateInstanceItemDO::getId));
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,37 @@
|
||||
package com.zt.plat.module.base.dal.mysql.tmpltp;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||
import com.zt.plat.framework.mybatis.core.mapper.BaseMapperX;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstancePageReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceDO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
|
||||
/**
|
||||
* 模板实例 Mapper
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@Mapper
|
||||
public interface TemplateInstanceMapper extends BaseMapperX<TemplateInstanceDO> {
|
||||
|
||||
default PageResult<TemplateInstanceDO> selectPage(TemplateInstancePageReqVO reqVO) {
|
||||
return selectPage(reqVO, new LambdaQueryWrapperX<TemplateInstanceDO>()
|
||||
.eqIfPresent(TemplateInstanceDO::getTpId, reqVO.getTpId())
|
||||
.likeIfPresent(TemplateInstanceDO::getName, reqVO.getName())
|
||||
.eqIfPresent(TemplateInstanceDO::getCdg, reqVO.getCdg())
|
||||
.eqIfPresent(TemplateInstanceDO::getDsp, reqVO.getDsp())
|
||||
.eqIfPresent(TemplateInstanceDO::getCntt, reqVO.getCntt())
|
||||
.eqIfPresent(TemplateInstanceDO::getOrigCntt, reqVO.getOrigCntt())
|
||||
.eqIfPresent(TemplateInstanceDO::getFileTp, reqVO.getFileTp())
|
||||
.eqIfPresent(TemplateInstanceDO::getVer, reqVO.getVer())
|
||||
.eqIfPresent(TemplateInstanceDO::getSts, reqVO.getSts())
|
||||
.betweenIfPresent(TemplateInstanceDO::getCreateTime, reqVO.getCreateTime())
|
||||
.orderByDesc(TemplateInstanceDO::getId));
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,10 @@
|
||||
package com.zt.plat.module.base.dal.mysql.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.mybatis.core.mapper.BaseMapperX;
|
||||
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplFldRelDO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
@Mapper
|
||||
public interface TmplFldRelMapper extends BaseMapperX<TmplFldRelDO> {
|
||||
}
|
||||
@@ -0,0 +1,22 @@
|
||||
package com.zt.plat.module.base.dal.mysql.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.mybatis.core.mapper.BaseMapperX;
|
||||
import com.zt.plat.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmpItmPageReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplItmDO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
@Mapper
|
||||
public interface TmplItmMapper extends BaseMapperX<TmplItmDO> {
|
||||
default PageResult<TmplItmDO> selectPage(TmpItmPageReqVO reqVO) {
|
||||
return selectPage(reqVO, new LambdaQueryWrapperX<TmplItmDO>()
|
||||
.eqIfPresent(TmplItmDO::getItmVal, reqVO.getItmVal())
|
||||
.likeIfPresent(TmplItmDO::getItmName, reqVO.getItmName())
|
||||
.eqIfPresent(TmplItmDO::getItmNum, reqVO.getItmNum())
|
||||
.eqIfPresent(TmplItmDO::getRmk, reqVO.getRmk())
|
||||
.betweenIfPresent(TmplItmDO::getCreateTime, reqVO.getCreateTime())
|
||||
.orderByDesc(TmplItmDO::getId));
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,10 @@
|
||||
package com.zt.plat.module.base.dal.mysql.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.mybatis.core.mapper.BaseMapperX;
|
||||
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplItmRelDO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
@Mapper
|
||||
public interface TmplItmRelMapper extends BaseMapperX<TmplItmRelDO> {
|
||||
}
|
||||
@@ -0,0 +1,24 @@
|
||||
package com.zt.plat.module.base.dal.mysql.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.mybatis.core.mapper.BaseMapperX;
|
||||
import com.zt.plat.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplFldPageReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplTpFldDO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
@Mapper
|
||||
public interface TmplTpFldMapper extends BaseMapperX<TmplTpFldDO> {
|
||||
|
||||
default PageResult<TmplTpFldDO> selectPage(TmplFldPageReqVO reqVO) {
|
||||
return selectPage(reqVO, new LambdaQueryWrapperX<TmplTpFldDO>()
|
||||
.likeIfPresent(TmplTpFldDO::getFldName, reqVO.getFldName())
|
||||
.eqIfPresent(TmplTpFldDO::getFldKy, reqVO.getFldKy())
|
||||
.eqIfPresent(TmplTpFldDO::getFldDoc, reqVO.getFldDoc())
|
||||
.eqIfPresent(TmplTpFldDO::getIsMust, reqVO.getIsMust())
|
||||
.eqIfPresent(TmplTpFldDO::getDatTp, reqVO.getDatTp())
|
||||
.betweenIfPresent(TmplTpFldDO::getCreateTime, reqVO.getCreateTime())
|
||||
.orderByDesc(TmplTpFldDO::getId));
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,47 @@
|
||||
package com.zt.plat.module.base.dal.mysql.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||
import com.zt.plat.framework.mybatis.core.mapper.BaseMapperX;
|
||||
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplFldRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplItmRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplTpPageReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplTpDO;
|
||||
import org.apache.ibatis.annotations.MapKey;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
import org.apache.ibatis.annotations.Param;
|
||||
import org.apache.ibatis.annotations.Select;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
|
||||
/**
|
||||
* 模板分类 Mapper
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@Mapper
|
||||
public interface TmplTpMapper extends BaseMapperX<TmplTpDO> {
|
||||
|
||||
default PageResult<TmplTpDO> selectPage(TmplTpPageReqVO reqVO) {
|
||||
return selectPage(reqVO, new LambdaQueryWrapperX<TmplTpDO>()
|
||||
.likeIfPresent(TmplTpDO::getName, reqVO.getName())
|
||||
.eqIfPresent(TmplTpDO::getNum, reqVO.getNum())
|
||||
.eqIfPresent(TmplTpDO::getPrnId, reqVO.getPrnId())
|
||||
.eqIfPresent(TmplTpDO::getSrt, reqVO.getSrt())
|
||||
.eqIfPresent(TmplTpDO::getSts, reqVO.getSts())
|
||||
.betweenIfPresent(TmplTpDO::getCreateTime, reqVO.getCreateTime())
|
||||
.orderByDesc(TmplTpDO::getId));
|
||||
}
|
||||
|
||||
@MapKey("id")
|
||||
List<TmplFldRespVO> getField(@Param("id") Long id);
|
||||
|
||||
@MapKey("id")
|
||||
List<TmplItmRespVO> getClause(@Param("id") Long id);
|
||||
|
||||
TmplTpDO getTmplTpById(@Param("id") Long id);
|
||||
}
|
||||
@@ -0,0 +1,11 @@
|
||||
package com.zt.plat.module.base.framework.rpc.config;
|
||||
|
||||
import com.zt.plat.module.infra.api.file.FileApi;
|
||||
import com.zt.plat.module.system.api.dept.DeptApi;
|
||||
import org.springframework.cloud.openfeign.EnableFeignClients;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
|
||||
@Configuration(value = "baseRpcConfiguration", proxyBeanMethods = false)
|
||||
@EnableFeignClients(clients = {DeptApi.class, FileApi.class})
|
||||
public class RpcConfiguration {
|
||||
}
|
||||
@@ -0,0 +1,40 @@
|
||||
package com.zt.plat.module.base.framework.security.config;
|
||||
|
||||
import com.zt.plat.framework.security.config.AuthorizeRequestsCustomizer;
|
||||
import com.zt.plat.module.infra.enums.ApiConstants;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
|
||||
import org.springframework.security.config.annotation.web.configurers.AuthorizeHttpRequestsConfigurer;
|
||||
|
||||
|
||||
/**
|
||||
* Template 模块的 Security 配置
|
||||
*/
|
||||
@Configuration("baseSecurityConfiguration")
|
||||
public class SecurityConfiguration {
|
||||
|
||||
@Bean
|
||||
public AuthorizeRequestsCustomizer authorizeRequestsCustomizer() {
|
||||
return new AuthorizeRequestsCustomizer() {
|
||||
|
||||
@Override
|
||||
public void customize(AuthorizeHttpRequestsConfigurer<HttpSecurity>.AuthorizationManagerRequestMatcherRegistry registry) {
|
||||
// Swagger 接口文档
|
||||
registry.requestMatchers("/v3/api-docs/**").permitAll()
|
||||
.requestMatchers("/webjars/**").permitAll()
|
||||
.requestMatchers("/swagger-ui").permitAll()
|
||||
.requestMatchers("/swagger-ui/**").permitAll();
|
||||
// Druid 监控
|
||||
registry.requestMatchers("/druid/**").permitAll();
|
||||
// Spring Boot Actuator 的安全配置
|
||||
registry.requestMatchers("/actuator").permitAll()
|
||||
.requestMatchers("/actuator/**").permitAll();
|
||||
// RPC 服务的安全配置
|
||||
registry.requestMatchers(ApiConstants.PREFIX + "/**").permitAll();
|
||||
}
|
||||
|
||||
};
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,65 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.DepartmentInstanceRelativityPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.DepartmentInstanceRelativityRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.DepartmentInstanceRelativitySaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.DepartmentInstanceRelativityDO;
|
||||
import jakarta.validation.*;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
|
||||
/**
|
||||
* 部门与实例关联 Service 接口
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
public interface DepartmentInstanceRelativityService {
|
||||
|
||||
/**
|
||||
* 创建部门与实例关联
|
||||
*
|
||||
* @param createReqVO 创建信息
|
||||
* @return 编号
|
||||
*/
|
||||
DepartmentInstanceRelativityRespVO createDepartmentInstanceRelativity(@Valid DepartmentInstanceRelativitySaveReqVO createReqVO);
|
||||
|
||||
/**
|
||||
* 更新部门与实例关联
|
||||
*
|
||||
* @param updateReqVO 更新信息
|
||||
*/
|
||||
void updateDepartmentInstanceRelativity(@Valid DepartmentInstanceRelativitySaveReqVO updateReqVO);
|
||||
|
||||
/**
|
||||
* 删除部门与实例关联
|
||||
*
|
||||
* @param id 编号
|
||||
*/
|
||||
void deleteDepartmentInstanceRelativity(String id);
|
||||
|
||||
/**
|
||||
* 批量删除部门与实例关联
|
||||
*
|
||||
* @param ids 编号
|
||||
*/
|
||||
void deleteDepartmentInstanceRelativityListByIds(List<Long> ids);
|
||||
|
||||
/**
|
||||
* 获得部门与实例关联
|
||||
*
|
||||
* @param id 编号
|
||||
* @return 部门与实例关联
|
||||
*/
|
||||
DepartmentInstanceRelativityDO getDepartmentInstanceRelativity(String id);
|
||||
|
||||
/**
|
||||
* 获得部门与实例关联分页
|
||||
*
|
||||
* @param pageReqVO 分页查询
|
||||
* @return 部门与实例关联分页
|
||||
*/
|
||||
PageResult<DepartmentInstanceRelativityDO> getDepartmentInstanceRelativityPage(DepartmentInstanceRelativityPageReqVO pageReqVO);
|
||||
|
||||
}
|
||||
@@ -0,0 +1,97 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import cn.hutool.core.collection.CollUtil;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.DepartmentInstanceRelativityPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.DepartmentInstanceRelativityRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.DepartmentInstanceRelativitySaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.DepartmentInstanceRelativityDO;
|
||||
import com.zt.plat.module.base.dal.mysql.tmpltp.DepartmentInstanceRelativityMapper;
|
||||
import org.springframework.stereotype.Service;
|
||||
import jakarta.annotation.Resource;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
|
||||
|
||||
|
||||
import static com.zt.plat.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.zt.plat.framework.common.util.collection.CollectionUtils.convertList;
|
||||
import static com.zt.plat.framework.common.util.collection.CollectionUtils.diffList;
|
||||
import static com.zt.plat.module.tmpltp.enums.ErrorCodeConstants.DEPARTMENT_INSTANCE_RELATIVITY_NOT_EXISTS;
|
||||
|
||||
|
||||
/**
|
||||
* 部门与实例关联 Service 实现类
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@Service
|
||||
@Validated
|
||||
public class DepartmentInstanceRelativityServiceImpl implements DepartmentInstanceRelativityService {
|
||||
|
||||
@Resource
|
||||
private DepartmentInstanceRelativityMapper departmentInstanceRelativityMapper;
|
||||
|
||||
@Override
|
||||
public DepartmentInstanceRelativityRespVO createDepartmentInstanceRelativity(DepartmentInstanceRelativitySaveReqVO createReqVO) {
|
||||
// 插入
|
||||
DepartmentInstanceRelativityDO departmentInstanceRelativity = BeanUtils.toBean(createReqVO, DepartmentInstanceRelativityDO.class);
|
||||
departmentInstanceRelativityMapper.insert(departmentInstanceRelativity);
|
||||
// 返回
|
||||
return BeanUtils.toBean(departmentInstanceRelativity, DepartmentInstanceRelativityRespVO.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateDepartmentInstanceRelativity(DepartmentInstanceRelativitySaveReqVO updateReqVO) {
|
||||
// 校验存在
|
||||
validateDepartmentInstanceRelativityExists(updateReqVO.getId());
|
||||
// 更新
|
||||
DepartmentInstanceRelativityDO updateObj = BeanUtils.toBean(updateReqVO, DepartmentInstanceRelativityDO.class);
|
||||
departmentInstanceRelativityMapper.updateById(updateObj);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteDepartmentInstanceRelativity(String id) {
|
||||
// 校验存在
|
||||
validateDepartmentInstanceRelativityExists(id);
|
||||
// 删除
|
||||
departmentInstanceRelativityMapper.deleteById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteDepartmentInstanceRelativityListByIds(List<Long> ids) {
|
||||
// 校验存在
|
||||
validateDepartmentInstanceRelativityExists(ids);
|
||||
// 删除
|
||||
departmentInstanceRelativityMapper.deleteByIds(ids);
|
||||
}
|
||||
|
||||
private void validateDepartmentInstanceRelativityExists(List<Long> ids) {
|
||||
List<DepartmentInstanceRelativityDO> list = departmentInstanceRelativityMapper.selectByIds(ids);
|
||||
if (CollUtil.isEmpty(list) || list.size() != ids.size()) {
|
||||
throw exception(DEPARTMENT_INSTANCE_RELATIVITY_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
private void validateDepartmentInstanceRelativityExists(String id) {
|
||||
if (departmentInstanceRelativityMapper.selectById(id) == null) {
|
||||
throw exception(DEPARTMENT_INSTANCE_RELATIVITY_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public DepartmentInstanceRelativityDO getDepartmentInstanceRelativity(String id) {
|
||||
return departmentInstanceRelativityMapper.selectById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PageResult<DepartmentInstanceRelativityDO> getDepartmentInstanceRelativityPage(DepartmentInstanceRelativityPageReqVO pageReqVO) {
|
||||
return departmentInstanceRelativityMapper.selectPage(pageReqVO);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,83 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceDataPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceDataRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceDataSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceDataDO;
|
||||
import jakarta.validation.*;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
|
||||
/**
|
||||
* 实例字段值 Service 接口
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
public interface TemplateInstanceDataService {
|
||||
|
||||
/**
|
||||
* 创建实例字段值
|
||||
*
|
||||
* @param createReqVO 创建信息
|
||||
* @return 编号
|
||||
*/
|
||||
TemplateInstanceDataRespVO createTemplateInstanceData(@Valid TemplateInstanceDataSaveReqVO createReqVO);
|
||||
|
||||
/**
|
||||
* 更新实例字段值
|
||||
*
|
||||
* @param updateReqVO 更新信息
|
||||
*/
|
||||
void updateTemplateInstanceData(@Valid TemplateInstanceDataSaveReqVO updateReqVO);
|
||||
|
||||
/**
|
||||
* 删除实例字段值
|
||||
*
|
||||
* @param id 编号
|
||||
*/
|
||||
void deleteTemplateInstanceData(Long id);
|
||||
|
||||
/**
|
||||
* 批量删除实例字段值
|
||||
*
|
||||
* @param ids 编号
|
||||
*/
|
||||
void deleteTemplateInstanceDataListByIds(List<Long> ids);
|
||||
|
||||
/**
|
||||
* 获得实例字段值
|
||||
*
|
||||
* @param id 编号
|
||||
* @return 实例字段值
|
||||
*/
|
||||
TemplateInstanceDataDO getTemplateInstanceData(Long id);
|
||||
|
||||
/**
|
||||
* 获得实例字段值分页
|
||||
*
|
||||
* @param pageReqVO 分页查询
|
||||
* @return 实例字段值分页
|
||||
*/
|
||||
PageResult<TemplateInstanceDataDO> getTemplateInstanceDataPage(TemplateInstanceDataPageReqVO pageReqVO);
|
||||
|
||||
/**
|
||||
* 设置实例字段值
|
||||
*
|
||||
* @param pageReqVOS 保存参数
|
||||
* @return 布尔类型
|
||||
*/
|
||||
boolean setTemplateInstanceData(List<TemplateInstanceDataDO> pageReqVOS);
|
||||
|
||||
|
||||
/**
|
||||
* 清空实例字段值
|
||||
*
|
||||
* @param instanceId ids
|
||||
* @return 布尔类型
|
||||
*/
|
||||
boolean clearTemplateInstanceData(String instanceId,List<Long> valIds);
|
||||
|
||||
}
|
||||
@@ -0,0 +1,123 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import cn.hutool.core.collection.CollUtil;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceDataPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceDataRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceDataSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceDataDO;
|
||||
import com.zt.plat.module.base.dal.mysql.tmpltp.TemplateInstanceDataMapper;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
||||
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
|
||||
import org.springframework.stereotype.Service;
|
||||
import jakarta.annotation.Resource;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
|
||||
|
||||
|
||||
import static com.zt.plat.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.zt.plat.framework.common.util.collection.CollectionUtils.convertList;
|
||||
import static com.zt.plat.framework.common.util.collection.CollectionUtils.diffList;
|
||||
import static com.zt.plat.module.base.enums.ErrorCodeConstants.*;
|
||||
import static com.zt.plat.module.tmpltp.enums.ErrorCodeConstants.*;
|
||||
import static com.zt.plat.module.tmpltp.enums.ErrorCodeConstants.TEMPLATE_INSTANCE_DATA_NOT_EXISTS;
|
||||
|
||||
/**
|
||||
* 实例字段值 Service 实现类
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@Service
|
||||
@Validated
|
||||
public class TemplateInstanceDataServiceImpl implements TemplateInstanceDataService {
|
||||
|
||||
@Resource
|
||||
private TemplateInstanceDataMapper templateInstanceDataMapper;
|
||||
|
||||
@Override
|
||||
public TemplateInstanceDataRespVO createTemplateInstanceData(TemplateInstanceDataSaveReqVO createReqVO) {
|
||||
// 插入
|
||||
TemplateInstanceDataDO templateInstanceData = BeanUtils.toBean(createReqVO, TemplateInstanceDataDO.class);
|
||||
templateInstanceDataMapper.insert(templateInstanceData);
|
||||
// 返回
|
||||
return BeanUtils.toBean(templateInstanceData, TemplateInstanceDataRespVO.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateTemplateInstanceData(TemplateInstanceDataSaveReqVO updateReqVO) {
|
||||
// 校验存在
|
||||
validateTemplateInstanceDataExists(updateReqVO.getId());
|
||||
// 更新
|
||||
TemplateInstanceDataDO updateObj = BeanUtils.toBean(updateReqVO, TemplateInstanceDataDO.class);
|
||||
templateInstanceDataMapper.updateById(updateObj);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteTemplateInstanceData(Long id) {
|
||||
// 校验存在
|
||||
validateTemplateInstanceDataExists(id);
|
||||
// 删除
|
||||
templateInstanceDataMapper.deleteById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteTemplateInstanceDataListByIds(List<Long> ids) {
|
||||
// 校验存在
|
||||
validateTemplateInstanceDataExists(ids);
|
||||
// 删除
|
||||
templateInstanceDataMapper.deleteByIds(ids);
|
||||
}
|
||||
|
||||
private void validateTemplateInstanceDataExists(List<Long> ids) {
|
||||
List<TemplateInstanceDataDO> list = templateInstanceDataMapper.selectByIds(ids);
|
||||
if (CollUtil.isEmpty(list) || list.size() != ids.size()) {
|
||||
throw exception(TEMPLATE_INSTANCE_DATA_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
private void validateTemplateInstanceDataExists(Long id) {
|
||||
if (templateInstanceDataMapper.selectById(id) == null) {
|
||||
throw exception(TEMPLATE_INSTANCE_DATA_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public TemplateInstanceDataDO getTemplateInstanceData(Long id) {
|
||||
return templateInstanceDataMapper.selectById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PageResult<TemplateInstanceDataDO> getTemplateInstanceDataPage(TemplateInstanceDataPageReqVO pageReqVO) {
|
||||
return templateInstanceDataMapper.selectPage(pageReqVO);
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional
|
||||
public boolean setTemplateInstanceData(List<TemplateInstanceDataDO> pageReqVOS) {
|
||||
if (CollUtil.isEmpty(pageReqVOS)) {
|
||||
throw exception(PARAMS_IS_NULL_OR_ERR);
|
||||
}
|
||||
return templateInstanceDataMapper.insertBatch(pageReqVOS);
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional
|
||||
public boolean clearTemplateInstanceData(String instanceId, List<Long> valIds) {
|
||||
if (CollUtil.isEmpty(valIds)|| instanceId.isEmpty()) {
|
||||
throw exception(PARAMS_IS_NULL_OR_ERR);
|
||||
}
|
||||
int update = templateInstanceDataMapper.update(new LambdaUpdateWrapper<TemplateInstanceDataDO>().eq(TemplateInstanceDataDO::getInscId, instanceId).in(TemplateInstanceDataDO::getFldKy).set(TemplateInstanceDataDO::getFldVal, ""));
|
||||
if (valIds.size()!= update){
|
||||
throw exception(OPERATION_FAIL);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
@@ -0,0 +1,66 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceItemPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceItemRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceItemSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceItemDO;
|
||||
import jakarta.validation.*;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
|
||||
/**
|
||||
* 实例条款值 Service 接口
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
public interface TemplateInstanceItemService {
|
||||
|
||||
/**
|
||||
* 创建实例条款值
|
||||
*
|
||||
* @param createReqVO 创建信息
|
||||
* @return 编号
|
||||
*/
|
||||
TemplateInstanceItemRespVO createTemplateInstanceItem(@Valid TemplateInstanceItemSaveReqVO createReqVO);
|
||||
|
||||
/**
|
||||
* 更新实例条款值
|
||||
*
|
||||
* @param updateReqVO 更新信息
|
||||
*/
|
||||
void updateTemplateInstanceItem(@Valid TemplateInstanceItemSaveReqVO updateReqVO);
|
||||
|
||||
/**
|
||||
* 删除实例条款值
|
||||
*
|
||||
* @param id 编号
|
||||
*/
|
||||
void deleteTemplateInstanceItem(String id);
|
||||
|
||||
/**
|
||||
* 批量删除实例条款值
|
||||
*
|
||||
* @param ids 编号
|
||||
*/
|
||||
void deleteTemplateInstanceItemListByIds(List<String> ids);
|
||||
|
||||
/**
|
||||
* 获得实例条款值
|
||||
*
|
||||
* @param id 编号
|
||||
* @return 实例条款值
|
||||
*/
|
||||
TemplateInstanceItemDO getTemplateInstanceItem(String id);
|
||||
|
||||
/**
|
||||
* 获得实例条款值分页
|
||||
*
|
||||
* @param pageReqVO 分页查询
|
||||
* @return 实例条款值分页
|
||||
*/
|
||||
PageResult<TemplateInstanceItemDO> getTemplateInstanceItemPage(TemplateInstanceItemPageReqVO pageReqVO);
|
||||
|
||||
}
|
||||
@@ -0,0 +1,87 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import cn.hutool.core.collection.CollUtil;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceItemPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceItemRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceItemSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceItemDO;
|
||||
import com.zt.plat.module.base.dal.mysql.tmpltp.TemplateInstanceItemMapper;
|
||||
import org.springframework.stereotype.Service;
|
||||
import jakarta.annotation.Resource;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import java.util.*;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
import static com.zt.plat.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.zt.plat.module.tmpltp.enums.ErrorCodeConstants.TEMPLATE_INSTANCE_ITEM_NOT_EXISTS;
|
||||
|
||||
/**
|
||||
* 实例条款值 Service 实现类
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@Service
|
||||
@Validated
|
||||
public class TemplateInstanceItemServiceImpl implements TemplateInstanceItemService {
|
||||
|
||||
@Resource
|
||||
private TemplateInstanceItemMapper templateInstanceItemMapper;
|
||||
|
||||
@Override
|
||||
public TemplateInstanceItemRespVO createTemplateInstanceItem(TemplateInstanceItemSaveReqVO createReqVO) {
|
||||
// 插入
|
||||
TemplateInstanceItemDO templateInstanceItem = BeanUtils.toBean(createReqVO, TemplateInstanceItemDO.class);
|
||||
templateInstanceItemMapper.insert(templateInstanceItem);
|
||||
// 返回
|
||||
return BeanUtils.toBean(templateInstanceItem, TemplateInstanceItemRespVO.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateTemplateInstanceItem(TemplateInstanceItemSaveReqVO updateReqVO) {
|
||||
// 校验存在
|
||||
validateTemplateInstanceItemExists(updateReqVO.getId());
|
||||
// 更新
|
||||
TemplateInstanceItemDO updateObj = BeanUtils.toBean(updateReqVO, TemplateInstanceItemDO.class);
|
||||
templateInstanceItemMapper.updateById(updateObj);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteTemplateInstanceItem(String id) {
|
||||
// 校验存在
|
||||
validateTemplateInstanceItemExists(id);
|
||||
// 删除
|
||||
templateInstanceItemMapper.deleteById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteTemplateInstanceItemListByIds(List<String> ids) {
|
||||
// 校验存在
|
||||
validateTemplateInstanceItemExists(ids);
|
||||
// 删除
|
||||
templateInstanceItemMapper.deleteByIds(ids);
|
||||
}
|
||||
|
||||
private void validateTemplateInstanceItemExists(List<String> ids) {
|
||||
List<TemplateInstanceItemDO> list = templateInstanceItemMapper.selectByIds(ids);
|
||||
if (CollUtil.isEmpty(list) || list.size() != ids.size()) {
|
||||
throw exception(TEMPLATE_INSTANCE_ITEM_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
private void validateTemplateInstanceItemExists(String id) {
|
||||
if (templateInstanceItemMapper.selectById(id) == null) {
|
||||
throw exception(TEMPLATE_INSTANCE_ITEM_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public TemplateInstanceItemDO getTemplateInstanceItem(String id) {
|
||||
return templateInstanceItemMapper.selectById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PageResult<TemplateInstanceItemDO> getTemplateInstanceItemPage(TemplateInstanceItemPageReqVO pageReqVO) {
|
||||
return templateInstanceItemMapper.selectPage(pageReqVO);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,66 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstancePageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceDO;
|
||||
import jakarta.validation.*;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.pojo.PageParam;
|
||||
|
||||
/**
|
||||
* 模板实例 Service 接口
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
public interface TemplateInstanceService {
|
||||
|
||||
/**
|
||||
* 创建模板实例
|
||||
*
|
||||
* @param createReqVO 创建信息
|
||||
* @return 编号
|
||||
*/
|
||||
TemplateInstanceRespVO createTemplateInstance(@Valid TemplateInstanceSaveReqVO createReqVO);
|
||||
|
||||
/**
|
||||
* 更新模板实例
|
||||
*
|
||||
* @param updateReqVO 更新信息
|
||||
*/
|
||||
void updateTemplateInstance(@Valid TemplateInstanceSaveReqVO updateReqVO);
|
||||
|
||||
/**
|
||||
* 删除模板实例
|
||||
*
|
||||
* @param id 编号
|
||||
*/
|
||||
void deleteTemplateInstance(Long id);
|
||||
|
||||
/**
|
||||
* 批量删除模板实例
|
||||
*
|
||||
* @param ids 编号
|
||||
*/
|
||||
void deleteTemplateInstanceListByIds(List<Long> ids);
|
||||
|
||||
/**
|
||||
* 获得模板实例
|
||||
*
|
||||
* @param id 编号
|
||||
* @return 模板实例
|
||||
*/
|
||||
TemplateInstanceDO getTemplateInstance(Long id);
|
||||
|
||||
/**
|
||||
* 获得模板实例分页
|
||||
*
|
||||
* @param pageReqVO 分页查询
|
||||
* @return 模板实例分页
|
||||
*/
|
||||
PageResult<TemplateInstanceDO> getTemplateInstancePage(TemplateInstancePageReqVO pageReqVO);
|
||||
|
||||
}
|
||||
@@ -0,0 +1,109 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import cn.hutool.core.collection.CollUtil;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstancePageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TemplateInstanceSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.DepartmentInstanceRelativityDO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TemplateInstanceDO;
|
||||
import com.zt.plat.module.base.dal.mysql.tmpltp.DepartmentInstanceRelativityMapper;
|
||||
import com.zt.plat.module.base.dal.mysql.tmpltp.TemplateInstanceMapper;
|
||||
import jakarta.annotation.Resource;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import static com.zt.plat.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.zt.plat.module.tmpltp.enums.ErrorCodeConstants.TEMPLATE_INSTANCE_NOT_EXISTS;
|
||||
|
||||
|
||||
/**
|
||||
* 模板实例 Service 实现类
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@Service
|
||||
@Validated
|
||||
public class TemplateInstanceServiceImpl implements TemplateInstanceService {
|
||||
|
||||
@Resource
|
||||
private TemplateInstanceMapper templateInstanceMapper;
|
||||
@Resource
|
||||
private DepartmentInstanceRelativityMapper departmentInstanceRelativityMapper;
|
||||
|
||||
@Override
|
||||
public TemplateInstanceRespVO createTemplateInstance(TemplateInstanceSaveReqVO createReqVO) {
|
||||
// 插入
|
||||
TemplateInstanceDO templateInstance = BeanUtils.toBean(createReqVO, TemplateInstanceDO.class);
|
||||
templateInstanceMapper.insert(templateInstance);
|
||||
|
||||
//构建使用部门
|
||||
List<DepartmentInstanceRelativityDO> departmentInstanceRelativityDOS = new ArrayList<>();
|
||||
createReqVO.getDeptIds().forEach(deptId ->{
|
||||
DepartmentInstanceRelativityDO departmentInstanceRelativityDO = new DepartmentInstanceRelativityDO();
|
||||
departmentInstanceRelativityDO.setTemplateInstanceId(String.valueOf(templateInstance.getId()));
|
||||
departmentInstanceRelativityDO.setCompanyId(deptId);
|
||||
departmentInstanceRelativityDOS.add(departmentInstanceRelativityDO);
|
||||
});
|
||||
departmentInstanceRelativityMapper.insertBatch(departmentInstanceRelativityDOS);
|
||||
// 插入使用范围
|
||||
return BeanUtils.toBean(templateInstance, TemplateInstanceRespVO.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateTemplateInstance(TemplateInstanceSaveReqVO updateReqVO) {
|
||||
// 校验存在
|
||||
validateTemplateInstanceExists(updateReqVO.getId());
|
||||
// TemplateInstanceDO templateInstanceDO = templateInstanceMapper.selectById(updateReqVO.getId());
|
||||
// //获取保存旧文件内容防止被更新
|
||||
// String originalContent = templateInstanceDO.getOriginalContent();
|
||||
// 更新
|
||||
TemplateInstanceDO updateObj = BeanUtils.toBean(updateReqVO, TemplateInstanceDO.class);
|
||||
updateObj.setOrigCntt(null); //重新赋值,防止原始文件被更改
|
||||
templateInstanceMapper.updateById(updateObj);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteTemplateInstance(Long id) {
|
||||
// 校验存在
|
||||
validateTemplateInstanceExists(id);
|
||||
// 删除
|
||||
templateInstanceMapper.deleteById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteTemplateInstanceListByIds(List<Long> ids) {
|
||||
// 校验存在
|
||||
validateTemplateInstanceExists(ids);
|
||||
// 删除
|
||||
templateInstanceMapper.deleteByIds(ids);
|
||||
}
|
||||
|
||||
private void validateTemplateInstanceExists(List<Long> ids) {
|
||||
List<TemplateInstanceDO> list = templateInstanceMapper.selectByIds(ids);
|
||||
if (CollUtil.isEmpty(list) || list.size() != ids.size()) {
|
||||
throw exception(TEMPLATE_INSTANCE_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
private void validateTemplateInstanceExists(Long id) {
|
||||
if (templateInstanceMapper.selectById(id) == null) {
|
||||
throw exception(TEMPLATE_INSTANCE_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public TemplateInstanceDO getTemplateInstance(Long id) {
|
||||
return templateInstanceMapper.selectById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PageResult<TemplateInstanceDO> getTemplateInstancePage(TemplateInstancePageReqVO pageReqVO) {
|
||||
return templateInstanceMapper.selectPage(pageReqVO);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,20 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmpItmPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplItmRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplItmSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplItmDO;
|
||||
import com.baomidou.mybatisplus.extension.service.IService;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public interface TmplItmService extends IService<TmplItmDO> {
|
||||
|
||||
TmplItmRespVO createTmplItm(TmplItmSaveReqVO tmplItmSaveReqVO) ;
|
||||
void updateTmplItm(TmplItmSaveReqVO tmplItmSaveReqVO) ;
|
||||
boolean deleteTmplItm(List<Long> ids);
|
||||
|
||||
PageResult<TmplItmDO> pageTmplItm(TmpItmPageReqVO pageReqVO);
|
||||
}
|
||||
@@ -0,0 +1,66 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import cn.hutool.core.collection.CollUtil;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmpItmPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplItmRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplItmSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplItmDO;
|
||||
import com.zt.plat.module.base.dal.mysql.tmpltp.TmplItmMapper;
|
||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import static com.zt.plat.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.zt.plat.module.tmpltp.enums.ErrorCodeConstants.TMPL_ITM_NOT_EXISTS;
|
||||
|
||||
@Service
|
||||
@Validated
|
||||
public class TmplItmServiceImpl extends ServiceImpl<TmplItmMapper, TmplItmDO> implements TmplItmService{
|
||||
@Override
|
||||
public TmplItmRespVO createTmplItm(TmplItmSaveReqVO tmplItmSaveReqVO) {
|
||||
tmplItmSaveReqVO.setId(null);
|
||||
TmplItmDO bean = BeanUtils.toBean(tmplItmSaveReqVO, TmplItmDO.class);
|
||||
baseMapper.insert(bean);
|
||||
return BeanUtils.toBean(bean, TmplItmRespVO.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateTmplItm(TmplItmSaveReqVO tmplItmSaveReqVO) {
|
||||
validateTmplLtmExists(tmplItmSaveReqVO.getId());
|
||||
TmplItmDO bean = BeanUtils.toBean(tmplItmSaveReqVO, TmplItmDO.class);
|
||||
this.updateById(bean);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
private void validateTmplLtmExists(List<Long> ids) {
|
||||
List<TmplItmDO> list = baseMapper.selectByIds(ids);
|
||||
if (CollUtil.isEmpty(list) || list.size() != ids.size()) {
|
||||
throw exception(TMPL_ITM_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
private void validateTmplLtmExists(Long id) {
|
||||
if (baseMapper.selectById(id) == null) {
|
||||
throw exception(TMPL_ITM_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional
|
||||
public boolean deleteTmplItm(List<Long> ids) {
|
||||
validateTmplLtmExists(ids);
|
||||
return removeBatchByIds(ids);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PageResult<TmplItmDO> pageTmplItm(TmpItmPageReqVO pageReqVO) {
|
||||
return baseMapper.selectPage(pageReqVO);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,20 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplFldPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplFldRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplTpFldSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplTpFldDO;
|
||||
import com.baomidou.mybatisplus.extension.service.IService;
|
||||
import jakarta.validation.Valid;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public interface TmplTpFldService extends IService<TmplTpFldDO> {
|
||||
TmplFldRespVO createTmplFld(@Valid TmplTpFldSaveReqVO tmplTpFldSaveReqVO);
|
||||
void updateTmplFld(@Valid TmplTpFldSaveReqVO tmplTpFldSaveReqVO);
|
||||
PageResult<TmplTpFldDO> tmplTpFldPage(@Valid TmplFldPageReqVO pageReqVO);
|
||||
void deleteTmplTpByIds(List< Long> ids);
|
||||
|
||||
}
|
||||
@@ -0,0 +1,76 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import cn.hutool.core.collection.CollUtil;
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
import com.zt.plat.framework.security.core.LoginUser;
|
||||
import com.zt.plat.framework.security.core.util.SecurityFrameworkUtils;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplFldPageReqVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplFldRespVO;
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.TmplTpFldSaveReqVO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplTpFldDO;
|
||||
import com.zt.plat.module.base.dal.mysql.tmpltp.TmplTpFldMapper;
|
||||
import com.alibaba.fastjson2.JSONObject;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import static com.zt.plat.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.zt.plat.module.tmpltp.enums.ErrorCodeConstants.TMPL_FLD_CODE_EXISTS;
|
||||
import static com.zt.plat.module.tmpltp.enums.ErrorCodeConstants.TMPL_FLD_NOT_EXISTS;
|
||||
|
||||
|
||||
@Service
|
||||
@Validated
|
||||
public class TmplTpFldServiceImpl extends ServiceImpl<TmplTpFldMapper, TmplTpFldDO> implements TmplTpFldService {
|
||||
@Override
|
||||
public TmplFldRespVO createTmplFld(TmplTpFldSaveReqVO tmplTpFldSaveReqVO) {
|
||||
TmplTpFldDO tmplTpFldDO = BeanUtils.toBean(tmplTpFldSaveReqVO, TmplTpFldDO.class);
|
||||
validateTmplFldCodeExists(tmplTpFldSaveReqVO.getFldKy());
|
||||
baseMapper.insert(tmplTpFldDO);
|
||||
return BeanUtils.toBean(tmplTpFldDO, TmplFldRespVO.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateTmplFld(TmplTpFldSaveReqVO tmplTpFldSaveReqVO) {
|
||||
// 校验存在
|
||||
validateTmplFldExists(tmplTpFldSaveReqVO.getId());
|
||||
// 更新
|
||||
TmplTpFldDO updateObj = BeanUtils.toBean(tmplTpFldSaveReqVO, TmplTpFldDO.class);
|
||||
baseMapper.updateById(updateObj);
|
||||
}
|
||||
|
||||
private void validateTmplFldCodeExists(String code){
|
||||
Long loginUserCompanyId = SecurityFrameworkUtils.getLoginUserCompanyId();
|
||||
if (baseMapper.selectCount(Wrappers.<TmplTpFldDO>lambdaQuery().eq(TmplTpFldDO::getFldKy, code).eq(TmplTpFldDO::getCompanyId, loginUserCompanyId)) > 0) {
|
||||
throw exception(TMPL_FLD_CODE_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
private void validateTmplFldExists(List<Long> ids) {
|
||||
List<TmplTpFldDO> list = baseMapper.selectByIds(ids);
|
||||
if (CollUtil.isEmpty(list) || list.size() != ids.size()) {
|
||||
throw exception(TMPL_FLD_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
private void validateTmplFldExists(Long id) {
|
||||
if (baseMapper.selectById(id) == null) {
|
||||
throw exception(TMPL_FLD_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public PageResult<TmplTpFldDO> tmplTpFldPage(TmplFldPageReqVO pageReqVO) {
|
||||
return baseMapper.selectPage(pageReqVO);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteTmplTpByIds(List<Long> ids) {
|
||||
validateTmplFldExists(ids);
|
||||
baseMapper.deleteByIds(ids);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,109 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.*;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplTpDO;
|
||||
import com.baomidou.mybatisplus.extension.service.IService;
|
||||
import jakarta.validation.*;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
|
||||
/**
|
||||
* 模板分类 Service 接口
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
public interface TmplTpService extends IService<TmplTpDO> {
|
||||
|
||||
/**
|
||||
* 创建模板分类
|
||||
*
|
||||
* @param createReqVO 创建信息
|
||||
* @return 编号
|
||||
*/
|
||||
TmplTpRespVO createTmplTp(@Valid TmplTpSaveReqVO createReqVO);
|
||||
|
||||
/**
|
||||
* 更新模板分类
|
||||
*
|
||||
* @param updateReqVO 更新信息
|
||||
*/
|
||||
void updateTmplTp(@Valid TmplTpSaveReqVO updateReqVO);
|
||||
|
||||
/**
|
||||
* 删除模板分类
|
||||
*
|
||||
* @param ids 编号
|
||||
*/
|
||||
void deleteTmplTp(List<Long> ids);
|
||||
|
||||
/**
|
||||
* 批量删除模板分类
|
||||
*
|
||||
* @param ids 编号
|
||||
*/
|
||||
void deleteTmplTpListByIds(List<Long> ids);
|
||||
|
||||
/**
|
||||
* 获得模板分类
|
||||
*
|
||||
* @param id 编号
|
||||
* @return 模板分类
|
||||
*/
|
||||
TmplTpDO getTmplTp(Long id);
|
||||
|
||||
/**
|
||||
* 获得模板分类分页
|
||||
*
|
||||
* @param pageReqVO 分页查询
|
||||
* @return 模板分类分页
|
||||
*/
|
||||
PageResult<TmplTpDO> getTmplTpPage(TmplTpPageReqVO pageReqVO);
|
||||
|
||||
/**
|
||||
* 获得字段回显
|
||||
*
|
||||
* @param id 编号
|
||||
* @return 模板分类
|
||||
*/
|
||||
List<TmplFldRespVO> getField(Long id);
|
||||
|
||||
/**
|
||||
* 获得条款回显
|
||||
*
|
||||
* @param id 编号
|
||||
* @return 模板分类
|
||||
*/
|
||||
List<TmplItmRespVO> getClause(Long id);
|
||||
|
||||
/**
|
||||
* 树结构
|
||||
*
|
||||
* @return 模板分类
|
||||
*/
|
||||
List<TmplTpTreeVO> buildTree();
|
||||
|
||||
/**
|
||||
* 更新模板分类状态
|
||||
*
|
||||
* @param id 编号
|
||||
* @param status 状态
|
||||
*/
|
||||
void updateStatus(Long id, String status);
|
||||
|
||||
/**
|
||||
* 字段编辑
|
||||
*
|
||||
* @param reqVO 状态
|
||||
*/
|
||||
void fieldEdit(TmplTpEditOrDeleteReqVO reqVO);
|
||||
|
||||
/**
|
||||
* 条款编辑
|
||||
*
|
||||
* @param reqVO 状态
|
||||
*/
|
||||
void ltmEdit(TmplTpEditOrDeleteReqVO reqVO);
|
||||
}
|
||||
@@ -0,0 +1,268 @@
|
||||
package com.zt.plat.module.base.service.tmpltp;
|
||||
|
||||
import cn.hutool.core.collection.CollUtil;
|
||||
|
||||
import com.zt.plat.module.base.controller.admin.templtp.vo.*;
|
||||
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplFldRelDO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplItmRelDO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplTpDO;
|
||||
import com.zt.plat.module.base.dal.dataobject.tmpltp.TmplTpFldDO;
|
||||
import com.zt.plat.module.base.dal.mysql.tmpltp.TmplFldRelMapper;
|
||||
import com.zt.plat.module.base.dal.mysql.tmpltp.TmplItmRelMapper;
|
||||
import com.zt.plat.module.base.dal.mysql.tmpltp.TmplTpMapper;
|
||||
import com.zt.plat.module.tmpltp.enums.StatusEnum;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.stereotype.Service;
|
||||
import jakarta.annotation.Resource;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
|
||||
import java.util.*;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
import com.zt.plat.framework.common.pojo.PageResult;
|
||||
import com.zt.plat.framework.common.util.object.BeanUtils;
|
||||
|
||||
|
||||
import static com.zt.plat.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.zt.plat.module.tmpltp.enums.ErrorCodeConstants.*;
|
||||
|
||||
/**
|
||||
* 模板分类 Service 实现类
|
||||
*
|
||||
* @author 后台管理
|
||||
*/
|
||||
@Service
|
||||
@Validated
|
||||
@RequiredArgsConstructor
|
||||
public class TmplTpServiceImpl extends ServiceImpl<TmplTpMapper, TmplTpDO> implements TmplTpService {
|
||||
private final TmplFldRelMapper tmplFldRelMapper;
|
||||
private final TmplItmRelMapper tmplItmRelMapper;
|
||||
|
||||
|
||||
@Override
|
||||
@Transactional
|
||||
public TmplTpRespVO createTmplTp(TmplTpSaveReqVO createReqVO) {
|
||||
//置空id
|
||||
createReqVO.setId(null);
|
||||
// 插入
|
||||
TmplTpDO tmplTp = BeanUtils.toBean(createReqVO, TmplTpDO.class);
|
||||
tmplTp.setSts("Y");
|
||||
baseMapper.insert(tmplTp);
|
||||
// 返回
|
||||
List<TmplFldRelDO> tmplFldRelDOS = new ArrayList<>();
|
||||
List<TmplItmRelDO> tmplItmRelDOS = new ArrayList<>();
|
||||
createReqVO.getTmplTpFldIds().forEach(tmplItmId -> {
|
||||
TmplFldRelDO tmplFldRelDO = new TmplFldRelDO();
|
||||
tmplFldRelDO.setTmplTpId(String.valueOf(tmplTp.getId()));
|
||||
tmplFldRelDO.setTpFldId(String.valueOf(tmplItmId));
|
||||
tmplFldRelDOS.add(tmplFldRelDO);
|
||||
});
|
||||
createReqVO.getTmplItmIds().forEach(tmplFldId -> {
|
||||
TmplItmRelDO tmplItmRelDO = new TmplItmRelDO();
|
||||
tmplItmRelDO.setTmplTpId(String.valueOf(tmplTp.getId()));
|
||||
tmplItmRelDO.setItmFldId(String.valueOf(tmplFldId));
|
||||
tmplItmRelDOS.add(tmplItmRelDO);
|
||||
});
|
||||
tmplFldRelMapper.insertBatch(tmplFldRelDOS);
|
||||
tmplItmRelMapper.insertBatch(tmplItmRelDOS);
|
||||
return BeanUtils.toBean(tmplTp, TmplTpRespVO.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateTmplTp(TmplTpSaveReqVO updateReqVO) {
|
||||
// 校验存在
|
||||
validateTmplTpExists(updateReqVO.getId());
|
||||
// 更新
|
||||
TmplTpDO updateObj = BeanUtils.toBean(updateReqVO, TmplTpDO.class);
|
||||
baseMapper.updateById(updateObj);
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional
|
||||
public void deleteTmplTp(List<Long> ids) {
|
||||
// 校验存在
|
||||
validateTmplTpExists(ids);
|
||||
//校验能否进行删除
|
||||
// if (!validateStatusCanDelete(ids)){
|
||||
// throw exception(TMPL_TP_DEl_ERROR);
|
||||
// }
|
||||
// 删除
|
||||
baseMapper.deleteByIds(ids);
|
||||
//删除对应的关联信息
|
||||
tmplFldRelMapper.delete(Wrappers.<TmplFldRelDO>lambdaQuery().in(TmplFldRelDO::getTmplTpId, ids));
|
||||
tmplItmRelMapper.delete(Wrappers.<TmplItmRelDO>lambdaQuery().in(TmplItmRelDO::getTmplTpId, ids));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteTmplTpListByIds(List<Long> ids) {
|
||||
// 校验存在
|
||||
validateTmplTpExists(ids);
|
||||
// 删除
|
||||
baseMapper.deleteByIds(ids);
|
||||
}
|
||||
|
||||
private void validateTmplTpExists(List<Long> ids) {
|
||||
List<TmplTpDO> list = baseMapper.selectByIds(ids);
|
||||
if (CollUtil.isEmpty(list) || list.size() != ids.size()) {
|
||||
throw exception(TMPL_TP_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
private void validateTmplTpExists(Long id) {
|
||||
if (baseMapper.selectById(id) == null) {
|
||||
throw exception(TMPL_TP_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public TmplTpDO getTmplTp(Long id) {
|
||||
return baseMapper.selectById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PageResult<TmplTpDO> getTmplTpPage(TmplTpPageReqVO pageReqVO) {
|
||||
return baseMapper.selectPage(pageReqVO);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<TmplFldRespVO> getField(Long id) {
|
||||
return baseMapper.getField(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<TmplItmRespVO> getClause(Long id) {
|
||||
return baseMapper.getClause(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<TmplTpTreeVO> buildTree() {
|
||||
// 1. 查询所有数据
|
||||
List<TmplTpDO> allNodes = baseMapper.selectList(new QueryWrapper<>());
|
||||
|
||||
// 2. 转换为树节点VO
|
||||
List<TmplTpTreeVO> treeNodes = allNodes.stream()
|
||||
.map(this::convertToTreeVO)
|
||||
.collect(Collectors.toList());
|
||||
|
||||
// 3. 构建树形结构
|
||||
return buildTreeStructure(treeNodes);
|
||||
}
|
||||
|
||||
/**
|
||||
* 转换实体类到树节点VO
|
||||
*/
|
||||
private TmplTpTreeVO convertToTreeVO(TmplTpDO entity) {
|
||||
return BeanUtils.toBean(entity, TmplTpTreeVO.class);
|
||||
}
|
||||
|
||||
/**
|
||||
* 构建树形结构
|
||||
*/
|
||||
private List<TmplTpTreeVO> buildTreeStructure(List<TmplTpTreeVO> treeNodes) {
|
||||
Map<String, List<TmplTpTreeVO>> groupByPrnId = treeNodes.stream()
|
||||
.collect(Collectors.groupingBy(node ->
|
||||
node.getPrnId() != null ? node.getPrnId().toString() : "null"));
|
||||
|
||||
// 2. 设置子节点并排序
|
||||
treeNodes.forEach(node -> {
|
||||
List<TmplTpTreeVO> children = groupByPrnId.get(node.getId().toString());
|
||||
if (children != null && !children.isEmpty()) {
|
||||
// 按排序序号升序排列
|
||||
children.sort(Comparator.comparing(TmplTpTreeVO::getSrt));
|
||||
node.setChildren(children);
|
||||
}
|
||||
});
|
||||
|
||||
// 3. 返回根节点(父ID为NULL的节点)
|
||||
return groupByPrnId.getOrDefault("0", new ArrayList<>());
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void updateStatus(Long id, String status) {
|
||||
//验证当前的能否变更为之后的状态
|
||||
// if (!validateStatusUpdate(id, status)) {
|
||||
// throw exception(TMPL_TP_SATUS_ERROR);
|
||||
// }
|
||||
baseMapper.update(Wrappers.<TmplTpDO>lambdaUpdate().set(TmplTpDO::getSts, status).eq(TmplTpDO::getId, id));
|
||||
}
|
||||
|
||||
|
||||
private boolean validateStatusUpdate(Long id, String status) {
|
||||
TmplTpDO tmplTpDO = baseMapper.getTmplTpById(id);
|
||||
String currentSts = tmplTpDO.getSts();
|
||||
|
||||
// 获取当前状态对应的枚举实例
|
||||
StatusEnum currentStatus = StatusEnum.fromCode(currentSts);
|
||||
|
||||
// 如果当前状态不合法,直接返回false
|
||||
if (currentStatus == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// 校验状态转换是否合法
|
||||
return currentStatus.isTransitionAllowed(status);
|
||||
}
|
||||
|
||||
// private boolean validateStatusCanDelete(List<Long> ids) {
|
||||
// Set<String> sts = listByIds(ids).stream().map(TmplTpDO::getSts).collect(Collectors.toSet());
|
||||
// List<Boolean> result = new ArrayList<>();
|
||||
// sts.forEach(status -> {
|
||||
// StatusEnum currentStatus = StatusEnum.fromCode(status);
|
||||
// boolean transitionAllowed = false;
|
||||
// if (currentStatus != null) {
|
||||
// transitionAllowed = currentStatus.isTransitionAllowed(status);
|
||||
// } else {
|
||||
// result.add(false);
|
||||
// }
|
||||
// result.add(transitionAllowed);
|
||||
// });
|
||||
// return !result.contains(false);
|
||||
// }
|
||||
|
||||
@Override
|
||||
public void fieldEdit(TmplTpEditOrDeleteReqVO reqVO) {
|
||||
if ("create".equals(reqVO.getType())) {
|
||||
List<TmplFldRelDO> tmplFldRelDOS = new ArrayList<>();
|
||||
reqVO.getIds().forEach(id -> {
|
||||
TmplFldRelDO tmplFldRelDO = new TmplFldRelDO();
|
||||
tmplFldRelDO.setTmplTpId(reqVO.getTpId());
|
||||
tmplFldRelDO.setTpFldId(id);
|
||||
tmplFldRelDOS.add(tmplFldRelDO);
|
||||
});
|
||||
tmplFldRelMapper.insertBatch(tmplFldRelDOS);
|
||||
}else if ("delete".equals(reqVO.getType())) {
|
||||
tmplFldRelMapper.delete(Wrappers.<TmplFldRelDO>lambdaQuery()
|
||||
.eq(TmplFldRelDO::getTmplTpId, reqVO.getTpId())
|
||||
.in(TmplFldRelDO::getTpFldId, reqVO.getIds()));
|
||||
}else {
|
||||
throw exception(ILLEGAL_OPERATION_TYPE);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void ltmEdit(TmplTpEditOrDeleteReqVO reqVO) {
|
||||
if ("create".equals(reqVO.getType())) {
|
||||
List<TmplItmRelDO> tmplItmRelDOS = new ArrayList<>();
|
||||
reqVO.getIds().forEach(id -> {
|
||||
TmplItmRelDO tmplItmRelDO = new TmplItmRelDO();
|
||||
tmplItmRelDO.setTmplTpId(reqVO.getTpId());
|
||||
tmplItmRelDO.setItmFldId(id);
|
||||
tmplItmRelDOS.add(tmplItmRelDO);
|
||||
});
|
||||
tmplItmRelMapper.insertBatch(tmplItmRelDOS);
|
||||
}else if ("delete".equals(reqVO.getType())) {
|
||||
tmplItmRelMapper.delete(Wrappers.<TmplItmRelDO>lambdaQuery()
|
||||
.eq(TmplItmRelDO::getTmplTpId, reqVO.getTpId())
|
||||
.in(TmplItmRelDO::getItmFldId, reqVO.getIds()));
|
||||
}else {
|
||||
throw exception(ILLEGAL_OPERATION_TYPE);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,107 @@
|
||||
spring:
|
||||
# 数据源配置项
|
||||
autoconfigure:
|
||||
exclude:
|
||||
datasource:
|
||||
druid: # Druid 【监控】相关的全局配置
|
||||
web-stat-filter:
|
||||
enabled: true
|
||||
stat-view-servlet:
|
||||
enabled: true
|
||||
allow: # 设置白名单,不填则允许所有访问
|
||||
url-pattern: /druid/*
|
||||
login-username: # 控制台管理用户名和密码
|
||||
login-password:
|
||||
filter:
|
||||
stat:
|
||||
enabled: true
|
||||
log-slow-sql: true # 慢 SQL 记录
|
||||
slow-sql-millis: 100
|
||||
merge-sql: true
|
||||
wall:
|
||||
config:
|
||||
multi-statement-allow: true
|
||||
dynamic: # 多数据源配置
|
||||
druid: # Druid 【连接池】相关的全局配置
|
||||
initial-size: 5 # 初始连接数
|
||||
min-idle: 10 # 最小连接池数量
|
||||
max-active: 20 # 最大连接池数量
|
||||
max-wait: 600000 # 配置获取连接等待超时的时间,单位:毫秒
|
||||
time-between-eviction-runs-millis: 60000 # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位:毫秒
|
||||
min-evictable-idle-time-millis: 300000 # 配置一个连接在池中最小生存的时间,单位:毫秒
|
||||
max-evictable-idle-time-millis: 900000 # 配置一个连接在池中最大生存的时间,单位:毫秒
|
||||
validation-query: SELECT 1 FROM DUAL # 配置检测连接是否有效
|
||||
test-while-idle: true
|
||||
test-on-borrow: false
|
||||
test-on-return: false
|
||||
primary: master
|
||||
datasource:
|
||||
master:
|
||||
url: jdbc:dm://172.16.46.247:1050?schema=RUOYI-VUE-PRO
|
||||
username: SYSDBA
|
||||
password: pgbsci6ddJ6Sqj@e
|
||||
slave: # 模拟从库,可根据自己需要修改 # 模拟从库,可根据自己需要修改
|
||||
lazy: true # 开启懒加载,保证启动速度
|
||||
url: jdbc:dm://172.16.46.247:1050?schema=RUOYI-VUE-PRO
|
||||
username: SYSDBA
|
||||
password: pgbsci6ddJ6Sqj@e
|
||||
|
||||
# Redis 配置。Redisson 默认的配置足够使用,一般不需要进行调优
|
||||
data:
|
||||
redis:
|
||||
host: 172.16.46.63 # 地址
|
||||
port: 30379 # 端口
|
||||
database: 0 # 数据库索引
|
||||
# password: 123456 # 密码,建议生产环境开启
|
||||
|
||||
xxl:
|
||||
job:
|
||||
admin:
|
||||
addresses: http://172.16.46.63:30082/xxl-job-admin # 调度中心部署跟地址
|
||||
|
||||
# Lock4j 配置项
|
||||
lock4j:
|
||||
acquire-timeout: 3000 # 获取分布式锁超时时间,默认为 3000 毫秒
|
||||
expire: 30000 # 分布式锁的超时时间,默认为 30 毫秒
|
||||
|
||||
# Actuator 监控端点的配置项
|
||||
management:
|
||||
endpoints:
|
||||
web:
|
||||
base-path: /actuator # Actuator 提供的 API 接口的根目录。默认为 /actuator
|
||||
exposure:
|
||||
include: '*' # 需要开放的端点。默认值只打开 health 和 info 两个端点。通过设置 * ,可以开放所有端点。
|
||||
|
||||
# 日志文件配置
|
||||
logging:
|
||||
file:
|
||||
name: ${user.home}/logs/${spring.application.name}.log # 日志文件名,全路径
|
||||
|
||||
|
||||
justauth:
|
||||
enabled: true
|
||||
type:
|
||||
DINGTALK: # 钉钉
|
||||
client-id: dingvrnreaje3yqvzhxg
|
||||
client-secret: i8E6iZyDvZj51JIb0tYsYfVQYOks9Cq1lgryEjFRqC79P3iJcrxEwT6Qk2QvLrLI
|
||||
ignore-check-redirect-uri: true
|
||||
WECHAT_ENTERPRISE: # 企业微信
|
||||
client-id: wwd411c69a39ad2e54
|
||||
client-secret: 1wTb7hYxnpT2TUbIeHGXGo7T0odav1ic10mLdyyATOw
|
||||
agent-id: 1000004
|
||||
ignore-check-redirect-uri: true
|
||||
# noinspection SpringBootApplicationYaml
|
||||
WECHAT_MINI_PROGRAM: # 微信小程序
|
||||
client-id: ${dollar}{wx.miniapp.appid}
|
||||
client-secret: ${dollar}{wx.miniapp.secret}
|
||||
ignore-check-redirect-uri: true
|
||||
ignore-check-state: true # 微信小程序,不会使用到 state,所以不进行校验
|
||||
WECHAT_MP: # 微信公众号
|
||||
client-id: ${dollar}{wx.mp.app-id}
|
||||
client-secret: ${dollar}{wx.mp.secret}
|
||||
ignore-check-redirect-uri: true
|
||||
cache:
|
||||
type: REDIS
|
||||
prefix: 'social_auth_state:' # 缓存前缀,目前只对 Redis 缓存生效,默认 JUSTAUTH::STATE::
|
||||
timeout: 24h # 超时时长,目前只对 Redis 缓存生效,默认 3 分钟
|
||||
|
||||
@@ -0,0 +1,97 @@
|
||||
spring:
|
||||
# 数据源配置项
|
||||
autoconfigure:
|
||||
# noinspection SpringBootApplicationYaml
|
||||
exclude:
|
||||
- com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure # 排除 Druid 的自动配置,使用 dynamic-datasource-spring-boot-starter 配置多数据源
|
||||
datasource:
|
||||
druid: # Druid 【监控】相关的全局配置
|
||||
web-stat-filter:
|
||||
enabled: true
|
||||
stat-view-servlet:
|
||||
enabled: true
|
||||
allow: # 设置白名单,不填则允许所有访问
|
||||
url-pattern: /druid/*
|
||||
login-username: # 控制台管理用户名和密码
|
||||
login-password:
|
||||
filter:
|
||||
stat:
|
||||
enabled: true
|
||||
log-slow-sql: true # 慢 SQL 记录
|
||||
slow-sql-millis: 100
|
||||
merge-sql: true
|
||||
wall:
|
||||
config:
|
||||
multi-statement-allow: true
|
||||
dynamic: # 多数据源配置
|
||||
druid: # Druid 【连接池】相关的全局配置
|
||||
initial-size: 1 # 初始连接数
|
||||
min-idle: 1 # 最小连接池数量
|
||||
max-active: 20 # 最大连接池数量
|
||||
max-wait: 600000 # 配置获取连接等待超时的时间,单位:毫秒
|
||||
time-between-eviction-runs-millis: 60000 # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位:毫秒
|
||||
min-evictable-idle-time-millis: 300000 # 配置一个连接在池中最小生存的时间,单位:毫秒
|
||||
max-evictable-idle-time-millis: 900000 # 配置一个连接在池中最大生存的时间,单位:毫秒
|
||||
validation-query: SELECT 1 FROM DUAL # 配置检测连接是否有效
|
||||
test-while-idle: true
|
||||
test-on-borrow: false
|
||||
test-on-return: false
|
||||
primary: master
|
||||
datasource:
|
||||
master:
|
||||
url: jdbc:dm://172.16.46.247:1050?schema=RUOYI-VUE-PRO
|
||||
username: SYSDBA
|
||||
password: pgbsci6ddJ6Sqj@e
|
||||
slave: # 模拟从库,可根据自己需要修改 # 模拟从库,可根据自己需要修改
|
||||
lazy: true # 开启懒加载,保证启动速度
|
||||
url: jdbc:dm://172.16.46.247:1050?schema=RUOYI-VUE-PRO
|
||||
username: SYSDBA
|
||||
password: pgbsci6ddJ6Sqj@e
|
||||
|
||||
# Redis 配置。Redisson 默认的配置足够使用,一般不需要进行调优
|
||||
data:
|
||||
redis:
|
||||
host: 172.16.46.63 # 地址
|
||||
port: 30379 # 端口
|
||||
database: 0 # 数据库索引
|
||||
# password: 123456 # 密码,建议生产环境开启
|
||||
|
||||
xxl:
|
||||
job:
|
||||
admin:
|
||||
addresses: http://172.16.46.63:30082/xxl-job-admin # 调度中心部署跟地址
|
||||
|
||||
# Lock4j 配置项
|
||||
lock4j:
|
||||
acquire-timeout: 3000 # 获取分布式锁超时时间,默认为 3000 毫秒
|
||||
expire: 30000 # 分布式锁的超时时间,默认为 30 毫秒
|
||||
|
||||
# Actuator 监控端点的配置项
|
||||
management:
|
||||
endpoints:
|
||||
web:
|
||||
base-path: /actuator # Actuator 提供的 API 接口的根目录。默认为 /actuator
|
||||
exposure:
|
||||
include: '*' # 需要开放的端点。默认值只打开 health 和 info 两个端点。通过设置 * ,可以开放所有端点。
|
||||
|
||||
# 日志文件配置
|
||||
logging:
|
||||
level:
|
||||
# 配置自己写的 MyBatis Mapper 打印日志
|
||||
com.zt.plat.module.base.dal.mysql: debug
|
||||
org.springframework.context.support.PostProcessorRegistrationDelegate: ERROR
|
||||
|
||||
mybatis-plus:
|
||||
configuration:
|
||||
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
|
||||
|
||||
|
||||
# 芋道配置项,设置当前项目所有自定义的配置
|
||||
cloud:
|
||||
env: # 多环境的配置项
|
||||
tag: ${HOSTNAME}
|
||||
security:
|
||||
mock-enable: true
|
||||
access-log: # 访问日志的配置项
|
||||
enable: true
|
||||
|
||||
@@ -0,0 +1,123 @@
|
||||
spring:
|
||||
application:
|
||||
name: base-server
|
||||
|
||||
profiles:
|
||||
active: ${env.name}
|
||||
#统一nacos配置,使用 profile 管理
|
||||
cloud:
|
||||
nacos:
|
||||
server-addr: ${config.server-addr} # Nacos 服务器地址
|
||||
username: ${config.username} # Nacos 账号
|
||||
password: ${config.password} # Nacos 密码
|
||||
discovery: # 【配置中心】配置项
|
||||
namespace: ${config.namespace} # 命名空间。这里使用 maven Profile 资源过滤进行动态替换
|
||||
group: ${config.group} # 使用的 Nacos 配置分组,默认为 DEFAULT_GROUP
|
||||
metadata:
|
||||
version: 1.0.0 # 服务实例的版本号,可用于灰度发布
|
||||
config: # 【注册中心】配置项
|
||||
namespace: ${config.namespace} # 命名空间。这里使用 maven Profile 资源过滤进行动态替换
|
||||
group: ${config.group} # 使用的 Nacos 配置分组,默认为 DEFAULT_GROUP
|
||||
main:
|
||||
allow-circular-references: true # 允许循环依赖,因为项目是三层架构,无法避免这个情况。
|
||||
allow-bean-definition-overriding: true # 允许 Bean 覆盖,例如说 Feign 等会存在重复定义的服务
|
||||
|
||||
config:
|
||||
import:
|
||||
- optional:classpath:application-${spring.profiles.active}.yaml # 加载【本地】配置
|
||||
- optional:nacos:${spring.application.name}-${spring.profiles.active}.yaml # 加载【Nacos】的配置
|
||||
|
||||
# Servlet 配置
|
||||
servlet:
|
||||
# 文件上传相关配置项
|
||||
multipart:
|
||||
max-file-size: 16MB # 单个文件大小
|
||||
max-request-size: 32MB # 设置总上传的文件大小
|
||||
|
||||
# Jackson 配置项
|
||||
jackson:
|
||||
serialization:
|
||||
write-dates-as-timestamps: true # 设置 LocalDateTime 的格式,使用时间戳
|
||||
write-date-timestamps-as-nanoseconds: false # 设置不使用 nanoseconds 的格式。例如说 1611460870.401,而是直接 1611460870401
|
||||
write-durations-as-timestamps: true # 设置 Duration 的格式,使用时间戳
|
||||
fail-on-empty-beans: false # 允许序列化无属性的 Bean
|
||||
time-zone: Asia/Shanghai
|
||||
|
||||
# Cache 配置项
|
||||
cache:
|
||||
type: REDIS
|
||||
redis:
|
||||
time-to-live: 1h # 设置过期时间为 1 小时
|
||||
|
||||
server:
|
||||
port: 48100
|
||||
|
||||
logging:
|
||||
file:
|
||||
name: ${user.home}/logs/${spring.application.name}.log # 日志文件名,全路径
|
||||
|
||||
springdoc:
|
||||
api-docs:
|
||||
enabled: true # 1. 是否开启 Swagger 接文档的元数据
|
||||
path: /v3/api-docs
|
||||
swagger-ui:
|
||||
enabled: true # 2.1 是否开启 Swagger 文档的官方 UI 界面
|
||||
path: /swagger-ui.html
|
||||
default-flat-param-object: true # 参见 https://doc.xiaominfo.com/docs/faq/v4/knife4j-parameterobject-flat-param 文档
|
||||
|
||||
knife4j:
|
||||
enable: true # 2.2 是否开启 Swagger 文档的 Knife4j UI 界面
|
||||
setting:
|
||||
language: zh_cn
|
||||
|
||||
# MyBatis Plus 的配置项
|
||||
mybatis-plus:
|
||||
configuration:
|
||||
map-underscore-to-camel-case: true # 虽然默认为 true ,但是还是显示去指定下。
|
||||
global-config:
|
||||
db-config:
|
||||
id-type: NONE # “智能”模式,基于 IdTypeEnvironmentPostProcessor + 数据源的类型,自动适配成 AUTO、INPUT 模式。
|
||||
# id-type: AUTO # 自增 ID,适合 MySQL 等直接自增的数据库
|
||||
# id-type: INPUT # 用户输入 ID,适合 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库
|
||||
# id-type: ASSIGN_ID # 分配 ID,默认使用雪花算法。注意,Oracle、PostgreSQL、Kingbase、DB2、H2 数据库时,需要去除实体类上的 @KeySequence 注解
|
||||
logic-delete-value: 1 # 逻辑已删除值(默认为 1)
|
||||
logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)
|
||||
banner: false # 关闭控制台的 Banner 打印
|
||||
type-aliases-package: com.zt.plat.module.*.dal.dataobject
|
||||
encryptor:
|
||||
password: XDV71a+xqStEA3WH # 加解密的秘钥,可使用 https://www.imaegoo.com/2020/aes-key-generator/ 网站生成
|
||||
|
||||
mybatis-plus-join:
|
||||
banner: false # 关闭控制台的 Banner 打印
|
||||
|
||||
# VO 转换(数据翻译)相关
|
||||
easy-trans:
|
||||
is-enable-global: false # 启用全局翻译(拦截所有 SpringMVC ResponseBody 进行自动翻译 )。如果对于性能要求很高可关闭此配置,或通过 @IgnoreTrans 忽略某个接口
|
||||
|
||||
xxl:
|
||||
job:
|
||||
executor:
|
||||
appname: ${spring.application.name} # 执行器 AppName
|
||||
logpath: ${user.home}/logs/xxl-job/${spring.application.name} # 执行器运行日志文件存储磁盘路径
|
||||
accessToken: default_token # 执行器通讯TOKEN
|
||||
|
||||
cloud:
|
||||
info:
|
||||
version: 1.0.0
|
||||
base-package: com.zt.plat.module.base
|
||||
web:
|
||||
admin-ui:
|
||||
url: http://dashboard.zt.iocoder.cn # Admin 管理后台 UI 的地址
|
||||
xss:
|
||||
enable: false
|
||||
exclude-urls: # 如下两个 url,仅仅是为了演示,去掉配置也没关系
|
||||
- ${spring.boot.admin.context-path}/** # 不处理 Spring Boot Admin 的请求
|
||||
- ${management.endpoints.web.base-path}/** # 不处理 Actuator 的请求
|
||||
swagger:
|
||||
title: 管理后台
|
||||
description: 提供管理员管理的所有功能
|
||||
version: ${cloud.info.version}
|
||||
tenant: # 多租户相关配置项
|
||||
enable: true
|
||||
|
||||
debug: false
|
||||
@@ -0,0 +1,12 @@
|
||||
<?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="com.zt.plat.module.base.dal.mysql.tmpltp.DepartmentInstanceRelativityMapper">
|
||||
|
||||
<!--
|
||||
一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。
|
||||
无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。
|
||||
代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。
|
||||
文档可见:https://www.iocoder.cn/MyBatis/x-plugins/
|
||||
-->
|
||||
|
||||
</mapper>
|
||||
@@ -0,0 +1,12 @@
|
||||
<?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="com.zt.plat.module.base.dal.mysql.tmpltp.TemplateInstanceDataMapper">
|
||||
|
||||
<!--
|
||||
一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。
|
||||
无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。
|
||||
代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。
|
||||
文档可见:https://www.iocoder.cn/MyBatis/x-plugins/
|
||||
-->
|
||||
|
||||
</mapper>
|
||||
@@ -0,0 +1,12 @@
|
||||
<?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="com.zt.plat.module.base.dal.mysql.tmpltp.TemplateInstanceItemMapper">
|
||||
|
||||
<!--
|
||||
一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。
|
||||
无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。
|
||||
代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。
|
||||
文档可见:https://www.iocoder.cn/MyBatis/x-plugins/
|
||||
-->
|
||||
|
||||
</mapper>
|
||||
@@ -0,0 +1,5 @@
|
||||
<?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="com.zt.plat.module.base.dal.mysql.tmpltp.TemplateInstanceMapper">
|
||||
|
||||
</mapper>
|
||||
@@ -0,0 +1,5 @@
|
||||
<?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="com.zt.plat.module.base.dal.mysql.tmpltp.TmplFldRelMapper">
|
||||
|
||||
</mapper>
|
||||
@@ -0,0 +1,5 @@
|
||||
<?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="com.zt.plat.module.base.dal.mysql.tmpltp.TmplItmMapper">
|
||||
|
||||
</mapper>
|
||||
@@ -0,0 +1,5 @@
|
||||
<?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="com.zt.plat.module.base.dal.mysql.tmpltp.TmplItmRelMapper">
|
||||
|
||||
</mapper>
|
||||
@@ -0,0 +1,5 @@
|
||||
<?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="com.zt.plat.module.base.dal.mysql.tmpltp.TmplTpFldMapper">
|
||||
|
||||
</mapper>
|
||||
@@ -0,0 +1,44 @@
|
||||
<?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="com.zt.plat.module.base.dal.mysql.tmpltp.TmplTpMapper">
|
||||
|
||||
<!--
|
||||
一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。
|
||||
无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。
|
||||
代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。
|
||||
文档可见:https://www.iocoder.cn/MyBatis/x-plugins/
|
||||
-->
|
||||
|
||||
<select id="getClause" resultType="com.zt.plat.module.base.controller.admin.templtp.vo.TmplItmRespVO">
|
||||
SELECT itm.*
|
||||
FROM BSE_TMPL_ITM itm
|
||||
INNER JOIN BSE_TMPL_ITM_REL rel ON itm.ID = rel.ITM_FLD_ID
|
||||
AND itm.tenant_id = 1
|
||||
AND rel.tenant_id = 1
|
||||
INNER JOIN BSE_TMPL_TP tp ON rel.TMPL_TP_ID = tp.ID
|
||||
AND tp.tenant_id = 1
|
||||
WHERE itm.DELETED = 0
|
||||
AND rel.DELETED = 0
|
||||
AND tp.DELETED = 0
|
||||
AND tp.id = #{id}
|
||||
|
||||
</select>
|
||||
<select id="getField" resultType="com.zt.plat.module.base.controller.admin.templtp.vo.TmplFldRespVO">
|
||||
|
||||
SELECT f.*
|
||||
FROM BIZ_TMPL_TP_FLD f
|
||||
INNER JOIN BSE_TMPL_FLD_REL r ON f.ID = r.TP_FLD_ID
|
||||
INNER JOIN BSE_TMPL_TP t ON r.TMPL_TP_ID = t.ID
|
||||
WHERE f.DELETED = '0'
|
||||
AND r.DELETED = '0'
|
||||
AND t.DELETED = '0'
|
||||
AND t.id = #{id}
|
||||
ORDER BY t.SRT, f.FLD_KY
|
||||
</select>
|
||||
|
||||
<select id="getTmplTpById" resultType="com.zt.plat.module.base.dal.dataobject.tmpltp.TmplTpDO">
|
||||
select *
|
||||
from bse_tmpl_tp
|
||||
where id = #{id}
|
||||
</select>
|
||||
</mapper>
|
||||
Reference in New Issue
Block a user