统一修改包

This commit is contained in:
chenbowen
2025-09-22 03:44:58 +08:00
parent f014ca7cf3
commit 58e2827a21
289 changed files with 1485 additions and 1485 deletions

View 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>-->
<!-- &lt;!&ndash; 打包 &ndash;&gt;-->
<!-- <plugin>-->
<!-- <groupId>org.springframework.boot</groupId>-->
<!-- <artifactId>spring-boot-maven-plugin</artifactId>-->
<!-- <version>${spring.boot.version}</version>-->
<!-- <executions>-->
<!-- <execution>-->
<!-- <goals>-->
<!-- <goal>repackage</goal> &lt;!&ndash; 将引入的 jar 打入其中 &ndash;&gt;-->
<!-- </goals>-->
<!-- </execution>-->
<!-- </executions>-->
<!-- </plugin>-->
<!-- </plugins>-->
</build>
</project>

View File

@@ -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);
}
}

View File

@@ -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!");
}
}

View File

@@ -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));
}
}

View File

@@ -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));
}
}

View File

@@ -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));
}
}

View File

@@ -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));
}
}

View File

@@ -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));
}
}

View File

@@ -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);
}
}

View File

@@ -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));
}
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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;
}

View File

@@ -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));
}
}

View File

@@ -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));
}
}

View File

@@ -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));
}
}

View File

@@ -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));
}
}

View File

@@ -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> {
}

View File

@@ -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));
}
}

View File

@@ -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> {
}

View File

@@ -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));
}
}

View File

@@ -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);
}

View File

@@ -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 {
}

View File

@@ -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();
}
};
}
}

View File

@@ -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);
}

View File

@@ -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);
}
}

View File

@@ -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);
}

View File

@@ -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;
}
}

View File

@@ -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);
}

View File

@@ -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);
}
}

View File

@@ -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);
}

View File

@@ -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);
}
}

View File

@@ -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);
}

View File

@@ -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);
}
}

View File

@@ -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);
}

View File

@@ -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);
}
}

View File

@@ -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);
}

View File

@@ -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);
}
}
}

View File

@@ -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 分钟

View File

@@ -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

View File

@@ -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

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>