FeatureController.java 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. package cn.cslg.pas.controller;
  2. import cn.cslg.pas.common.core.base.Constants;
  3. import cn.cslg.pas.common.dto.QueryPatentClaimDTO;
  4. import cn.cslg.pas.common.dto.QuerySplitDTO;
  5. import cn.cslg.pas.common.dto.invalidDTO.QueryClaimSplitHistoryDTO;
  6. import cn.cslg.pas.common.dto.invalidDTO.UpdateFeatureDTO;
  7. import cn.cslg.pas.common.model.cronModel.Records;
  8. import cn.cslg.pas.common.utils.Response;
  9. import cn.cslg.pas.common.vo.business.SplitVO;
  10. import cn.cslg.pas.domain.business.ReportProject;
  11. import cn.cslg.pas.exception.XiaoShiException;
  12. import cn.cslg.pas.service.business.FeatureService;
  13. import cn.cslg.pas.service.business.ReportProjectService;
  14. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  15. import io.swagger.v3.oas.annotations.Operation;
  16. import lombok.extern.slf4j.Slf4j;
  17. import org.springframework.beans.factory.annotation.Autowired;
  18. import org.springframework.transaction.annotation.Transactional;
  19. import org.springframework.web.bind.annotation.*;
  20. import java.util.List;
  21. /**
  22. * 特征Controller层
  23. *
  24. * @Author lrj
  25. * @Date 2023/12/5
  26. */
  27. @Slf4j
  28. @RequestMapping(Constants.API_XiaoSHI + "/feature")
  29. @RestController
  30. public class FeatureController {
  31. @Autowired
  32. private FeatureService featureService;
  33. @Autowired
  34. private ReportProjectService reportProjectService;
  35. @Operation(summary = "拆分查询特征")
  36. @PostMapping("/spiltFeature")
  37. public Response spiltFeature(@RequestBody SplitVO splitVO) throws Exception {
  38. try {
  39. Records records = new Records();
  40. records.setData(featureService.splitPatentFeature(splitVO));
  41. return Response.success(records);
  42. } catch (Exception e) {
  43. return Response.error(e.getMessage());
  44. }
  45. }
  46. @Operation(summary = "查询拆分信息")
  47. @PostMapping("/getSplitMessage")
  48. public Response getSplitMessage(@RequestBody QuerySplitDTO splitDTO) throws Exception {
  49. try {
  50. Records records = new Records();
  51. records.setData(featureService.getSplitMessage(splitDTO));
  52. return Response.success(records);
  53. } catch (Exception e) {
  54. return Response.error(e.getMessage());
  55. }
  56. }
  57. @Operation(summary = "查询权要")
  58. @GetMapping("/getPatentRight")
  59. public Response getPatentRight(String patentNo) throws Exception {
  60. try {
  61. Records records = new Records();
  62. records.setData(featureService.getPatentRight(patentNo));
  63. return Response.success(records);
  64. } catch (Exception e) {
  65. return Response.error(e.getMessage());
  66. }
  67. }
  68. @Operation(summary = "查询权要")
  69. @PostMapping("/getPatentRight")
  70. public Response getPatentRight(QueryPatentClaimDTO queryPatentClaimDTO) throws Exception {
  71. try {
  72. Records records = new Records();
  73. records.setData(featureService.getPatentRight(queryPatentClaimDTO));
  74. return Response.success(records);
  75. } catch (Exception e) {
  76. return Response.error(e.getMessage());
  77. }
  78. }
  79. @Operation(summary = "查询权要树")
  80. @GetMapping("/getPatentRightTree")
  81. public Response getPatentRightTree(String patentNo,String appNo) throws Exception {
  82. try {
  83. Records records = new Records();
  84. records.setData(featureService.getPatentRightTree(patentNo,appNo));
  85. return Response.success(records);
  86. } catch (Exception e) {
  87. return Response.error(e.getMessage());
  88. }
  89. }
  90. @Operation(summary = "查询特征")
  91. @PostMapping("/getFeatrues")
  92. public Response getFeatrues(@RequestBody SplitVO splitVO) throws Exception {
  93. try {
  94. Records records = new Records();
  95. splitVO.setIfReSplit(false);
  96. if (splitVO.getProjectId() != null) {
  97. LambdaQueryWrapper<ReportProject> queryWrapper = new LambdaQueryWrapper();
  98. queryWrapper.eq(ReportProject::getProjectId, splitVO.getProjectId());
  99. ReportProject reportProject = reportProjectService.getOne(queryWrapper, false);
  100. if (reportProject != null) {
  101. splitVO.setPatentNo(reportProject.getSignPatentNo());
  102. } else {
  103. throw new XiaoShiException("未查询到报告");
  104. }
  105. }
  106. records.setData(featureService.splitPatentFeature(splitVO));
  107. return Response.success(records);
  108. } catch (Exception e) {
  109. return Response.error(e.getMessage());
  110. }
  111. }
  112. @Operation(summary = "查询权要拆分历史")
  113. @PostMapping("/queryClaimSplitHistory")
  114. public Response queryClaimSplitHistory(@RequestBody QueryClaimSplitHistoryDTO queryClaimSplitHistoryDTO) throws Exception {
  115. try {
  116. Records records = featureService.queryClaimSplitHistory(queryClaimSplitHistoryDTO);
  117. return Response.success(records);
  118. } catch (Exception e) {
  119. return Response.error(e.getMessage());
  120. }
  121. }
  122. @Operation(summary = "批量添加特征")
  123. @PostMapping("/saveBatchFeature")
  124. public Response saveBatchFeature(@RequestBody UpdateFeatureDTO updateFeatureDTO) throws Exception {
  125. try {
  126. Records records = new Records();
  127. List<Integer> ids = featureService.saveBatchFeature(updateFeatureDTO);
  128. records.setData(ids);
  129. return Response.success(records);
  130. } catch (Exception e) {
  131. return Response.error(e.getMessage());
  132. }
  133. }
  134. }