|
@@ -1,6 +1,5 @@
|
|
|
package cn.cslg.pas.service.business;
|
|
|
|
|
|
-import cn.cslg.pas.common.dto.ComparedPatentVO;
|
|
|
import cn.cslg.pas.common.dto.business.GetFeatureSplitDTO;
|
|
|
import cn.cslg.pas.common.dto.business.TortCompareRecordDTO;
|
|
|
import cn.cslg.pas.common.dto.business.TortDTO;
|
|
@@ -15,16 +14,14 @@ import cn.cslg.pas.domain.business.CompareLiterature;
|
|
|
import cn.cslg.pas.domain.business.FTOCompareRecord;
|
|
|
import cn.cslg.pas.domain.business.Feature;
|
|
|
import cn.cslg.pas.domain.business.ProjectTask;
|
|
|
-import cn.cslg.pas.domain.es.Patent;
|
|
|
import cn.cslg.pas.exception.UnLoginException;
|
|
|
import cn.cslg.pas.exception.XiaoShiException;
|
|
|
import cn.cslg.pas.mapper.FTOCompareRecordMapper;
|
|
|
-import cn.cslg.pas.service.business.es.EsFamilyService;
|
|
|
-import cn.cslg.pas.service.business.es.EsPatentService;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
import com.spire.pdf.packages.sprcxq;
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
+import org.apache.poi.ss.formula.functions.T;
|
|
|
import org.springframework.beans.BeanUtils;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.context.annotation.Lazy;
|
|
@@ -32,13 +29,11 @@ import org.springframework.stereotype.Service;
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
import java.util.List;
|
|
|
-import java.util.Map;
|
|
|
import java.util.function.Function;
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
/**
|
|
|
* FTO
|
|
|
- *
|
|
|
* @Author xiexiang
|
|
|
* @Date 2023/12/13
|
|
|
*/
|
|
@@ -67,19 +62,12 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
@Autowired
|
|
|
private TortCompareRecordService tortCompareRecordService;
|
|
|
|
|
|
- @Autowired
|
|
|
- private EsPatentService esPatentService;
|
|
|
-
|
|
|
- @Autowired
|
|
|
- private EsFamilyService esFamilyService;
|
|
|
-
|
|
|
/**
|
|
|
* 查询FTO对比结果VO
|
|
|
- *
|
|
|
* @param getFeatureSplitDTO
|
|
|
* @return
|
|
|
*/
|
|
|
- public TortCompareRecordVO getTortCompareRecord(GetFeatureSplitDTO getFeatureSplitDTO) {
|
|
|
+ public TortCompareRecordVO getTortCompareRecord(GetFeatureSplitDTO getFeatureSplitDTO){
|
|
|
// 判断参数不能为空
|
|
|
// 分配任务id
|
|
|
Integer taskId = getFeatureSplitDTO.getTaskId();
|
|
@@ -138,11 +126,10 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
|
|
|
/**
|
|
|
* 装载权要层
|
|
|
- *
|
|
|
* @param patentRightVos
|
|
|
* @return
|
|
|
*/
|
|
|
- public List<TortRightVO> loadTortRightVO(String patentNo, Integer taskId, List<PatentRightVo> patentRightVos) {
|
|
|
+ public List<TortRightVO> loadTortRightVO(String patentNo, Integer taskId, List<PatentRightVo> patentRightVos){
|
|
|
//新建权要层信息
|
|
|
List<TortRightVO> tortRightVOS = new ArrayList<>();
|
|
|
//遍历装载权要层信息
|
|
@@ -166,13 +153,12 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
/**
|
|
|
* 发起人查询
|
|
|
* 装载特征与对比结果
|
|
|
- *
|
|
|
* @param taskId
|
|
|
* @param features
|
|
|
* @param ftoCompareRecords
|
|
|
* @return
|
|
|
*/
|
|
|
- public List<TortVO> loadAllTortVO(Integer taskId, List<Feature> features, List<FTOCompareRecord> ftoCompareRecords) {
|
|
|
+ public List<TortVO> loadAllTortVO(Integer taskId, List<Feature> features, List<FTOCompareRecord> ftoCompareRecords){
|
|
|
List<TortVO> tortVOS = new ArrayList<>();
|
|
|
for (Feature feature : features) {
|
|
|
//新建特征与侵权分析对比结果VO
|
|
@@ -253,8 +239,8 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
LambdaQueryWrapper<Feature> queryWrapper = new LambdaQueryWrapper<>();
|
|
|
queryWrapper.select(Feature::getId)
|
|
|
.eq(Feature::getProjectTaskId, taskId);
|
|
|
- Function<Object, Integer> f = (o -> Integer.parseInt(o.toString()));
|
|
|
- List<Integer> featureIds = featureService.listObjs(queryWrapper, f);
|
|
|
+ Function<Object,Integer> f = (o -> Integer.parseInt(o.toString()));
|
|
|
+ List<Integer> featureIds = featureService.listObjs(queryWrapper,f);
|
|
|
// 删除特征
|
|
|
List<Integer> ids = new ArrayList<>();
|
|
|
if (!featureIds.isEmpty()) {
|
|
@@ -273,13 +259,12 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
|
|
|
/**
|
|
|
* 更新剩余特征和对比结果
|
|
|
- *
|
|
|
* @param patentNo
|
|
|
* @param taskId
|
|
|
* @param featureIds
|
|
|
* @param tortDTOS
|
|
|
*/
|
|
|
- public List<Integer> updateFeatures(String patentNo, Integer taskId, List<Integer> featureIds, List<TortDTO> tortDTOS) {
|
|
|
+ public List<Integer> updateFeatures(String patentNo, Integer taskId, List<Integer> featureIds, List<TortDTO> tortDTOS){
|
|
|
// 获取登录人信息
|
|
|
PersonnelVO personnelVO = new PersonnelVO();
|
|
|
try {
|
|
@@ -328,20 +313,19 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
ftoIds.add(id);
|
|
|
}
|
|
|
}
|
|
|
- order++;
|
|
|
+ order++ ;
|
|
|
}
|
|
|
return ftoIds;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 对比结果入库
|
|
|
- *
|
|
|
* @param patentNo
|
|
|
* @param projectId
|
|
|
* @param taskId
|
|
|
* @param tortDTO
|
|
|
*/
|
|
|
- public Integer addCompareRecords(String patentNo, Integer projectId, Integer taskId, TortDTO tortDTO) {
|
|
|
+ public Integer addCompareRecords(String patentNo, Integer projectId, Integer taskId, TortDTO tortDTO){
|
|
|
Integer featureId = tortDTO.getFeatureId();
|
|
|
//获取登录人信息
|
|
|
PersonnelVO personnelVO = new PersonnelVO();
|
|
@@ -370,10 +354,9 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
|
|
|
/**
|
|
|
* 保存协同任务对比结果
|
|
|
- *
|
|
|
* @param tortCompareRecordDTO
|
|
|
*/
|
|
|
- public List<Integer> addFTOAssitTaskResult(TortCompareRecordDTO tortCompareRecordDTO) {
|
|
|
+ public List<Integer> addFTOAssitTaskResult(TortCompareRecordDTO tortCompareRecordDTO){
|
|
|
if (tortCompareRecordDTO == null) {
|
|
|
throw new XiaoShiException("入参不能为空");
|
|
|
}
|
|
@@ -439,7 +422,6 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
/**
|
|
|
* 查询侵权分析协同前后对比结果
|
|
|
* 三份结果:原始、协同处理、最终
|
|
|
- *
|
|
|
* @param taskId
|
|
|
* @return
|
|
|
*/
|
|
@@ -463,7 +445,7 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
if (type == 1) {//查询协同前后对比结果
|
|
|
tortRightVOS = this.loadBeforeAndAfter(taskId, patentNo, patentRightVos);
|
|
|
} else if (type == 2) {//发起人的查询
|
|
|
- tortRightVOS = this.loadTortRightVOS2(taskId, projectId, patentRightVos);
|
|
|
+ tortRightVOS = this.loadTortRightVOS2(taskId, patentRightVos);
|
|
|
}
|
|
|
tortCompareRecordVO.setTortRightVOS(tortRightVOS);
|
|
|
} catch (Exception e) {
|
|
@@ -474,13 +456,12 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
|
|
|
/**
|
|
|
* 协同前后对比结果
|
|
|
- *
|
|
|
* @param patentNo
|
|
|
* @param taskId
|
|
|
* @param patentRightVos
|
|
|
* @return
|
|
|
*/
|
|
|
- public List<TortRightVO> loadBeforeAndAfter(Integer taskId, String patentNo, List<PatentRightVo> patentRightVos) {
|
|
|
+ public List<TortRightVO> loadBeforeAndAfter(Integer taskId, String patentNo, List<PatentRightVo> patentRightVos){
|
|
|
if (patentRightVos != null && !patentRightVos.isEmpty()) {
|
|
|
//新建权要层信息
|
|
|
List<TortRightVO> tortRightVOS = new ArrayList<>();
|
|
@@ -507,12 +488,11 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
/**
|
|
|
* 协同前后对比结果
|
|
|
* 装载特征与对比结果
|
|
|
- *
|
|
|
* @param features
|
|
|
* @param ftoCompareRecords
|
|
|
* @return
|
|
|
*/
|
|
|
- public List<TortVO> loadBeforeAndAfterTortVO(List<Feature> features, List<FTOCompareRecord> ftoCompareRecords) {
|
|
|
+ public List<TortVO> loadBeforeAndAfterTortVO(List<Feature> features, List<FTOCompareRecord> ftoCompareRecords){
|
|
|
List<TortVO> tortVOS = new ArrayList<>();
|
|
|
for (Feature feature : features) {
|
|
|
//新建特征与侵权分析对比结果VO
|
|
@@ -552,13 +532,11 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
|
|
|
/**
|
|
|
* 根据projectId和权要集合装载返回侵权分析对比结果页面VO
|
|
|
- *
|
|
|
* @param taskId
|
|
|
- * @param projectId
|
|
|
* @param patentRightVos
|
|
|
* @return
|
|
|
*/
|
|
|
- public List<TortRightVO> loadTortRightVOS2(Integer taskId, Integer projectId, List<PatentRightVo> patentRightVos) {
|
|
|
+ public List<TortRightVO> loadTortRightVOS2(Integer taskId, List<PatentRightVo> patentRightVos){
|
|
|
if (patentRightVos != null && !patentRightVos.isEmpty()) {
|
|
|
//新建权要层信息
|
|
|
List<TortRightVO> tortRightVOS = new ArrayList<>();
|
|
@@ -571,7 +549,7 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
LambdaQueryWrapper<FTOCompareRecord> queryWrapper = new LambdaQueryWrapper<>();
|
|
|
queryWrapper.eq(FTOCompareRecord::getProjectTaskId, taskId);
|
|
|
List<FTOCompareRecord> ftoCompareRecords = this.list(queryWrapper);
|
|
|
- List<TortVO> tortVOS = this.loadTortVO2(taskId, features, ftoCompareRecords);
|
|
|
+ List<TortVO> tortVOS = this.loadTortVO2(features, ftoCompareRecords);
|
|
|
tortRightVO.setTortVOS(tortVOS);
|
|
|
tortRightVOS.add(tortRightVO);
|
|
|
});
|
|
@@ -584,13 +562,11 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
/**
|
|
|
* 发起人查询
|
|
|
* 装载特征与对比结果
|
|
|
- *
|
|
|
- * @param taskId
|
|
|
* @param features
|
|
|
* @param ftoCompareRecords
|
|
|
* @return
|
|
|
*/
|
|
|
- public List<TortVO> loadTortVO2(Integer taskId, List<Feature> features, List<FTOCompareRecord> ftoCompareRecords) {
|
|
|
+ public List<TortVO> loadTortVO2(List<Feature> features, List<FTOCompareRecord> ftoCompareRecords){
|
|
|
List<TortVO> tortVOS = new ArrayList<>();
|
|
|
for (Feature feature : features) {
|
|
|
//新建特征与侵权分析对比结果VO
|
|
@@ -649,11 +625,10 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
|
|
|
/**
|
|
|
* 保存最终对比结果接口
|
|
|
- *
|
|
|
* @param tortCompareRecordDTO
|
|
|
* @return
|
|
|
*/
|
|
|
- public List<Integer> addFinalAssitResult(TortCompareRecordDTO tortCompareRecordDTO) {
|
|
|
+ public List<Integer> addFinalAssitResult(TortCompareRecordDTO tortCompareRecordDTO){
|
|
|
List<Integer> ids = new ArrayList<>();
|
|
|
Integer taskId = tortCompareRecordDTO.getTaskId();
|
|
|
if (taskId == null) {
|
|
@@ -713,13 +688,12 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
|
|
|
/**
|
|
|
* 从侵权分析中获得对比结果,并复制保存
|
|
|
- *
|
|
|
* @param projectId
|
|
|
* @param taskId
|
|
|
* @param createId
|
|
|
* @param patentNo
|
|
|
*/
|
|
|
- public void copyTortCompareRecords(Integer projectId, Integer taskId, String createId, String patentNo) {
|
|
|
+ public void copyTortCompareRecords(Integer projectId, Integer taskId, String createId, String patentNo){
|
|
|
if (projectId != null && taskId != null) {
|
|
|
LambdaQueryWrapper<FTOCompareRecord> queryWrapper = new LambdaQueryWrapper<>();
|
|
|
queryWrapper.eq(FTOCompareRecord::getProjectTaskId, taskId)
|
|
@@ -748,41 +722,103 @@ public class FTOCompareRecordService extends ServiceImpl<FTOCompareRecordMapper,
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- public void getLastRecord(Integer projectId, String patentNo) {
|
|
|
+ /**
|
|
|
+ * 根据报告id和专利号查询最新的对比结果
|
|
|
+ * @param projectId
|
|
|
+ * @param patentNo
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public TortCompareRecordVO getLastRecord(Integer projectId, String patentNo){
|
|
|
+ TortCompareRecordVO tortCompareRecordVO = new TortCompareRecordVO();
|
|
|
+ tortCompareRecordVO.setProjectId(projectId);
|
|
|
+ //根据报告id,专利号,ifFinal为true,createTime为最新的查询一条最新的结果
|
|
|
LambdaQueryWrapper<FTOCompareRecord> queryWrapper = new LambdaQueryWrapper<>();
|
|
|
- queryWrapper.eq(FTOCompareRecord::getCompareFileNumber, patentNo)
|
|
|
+ queryWrapper
|
|
|
+ .eq(FTOCompareRecord::getCompareFileNumber, patentNo)
|
|
|
.eq(FTOCompareRecord::getProjectId, projectId)
|
|
|
.eq(FTOCompareRecord::getIfFinal, true)
|
|
|
.eq(FTOCompareRecord::getIfOriginal, false)
|
|
|
.orderByDesc(FTOCompareRecord::getCreateTime);
|
|
|
- List<FTOCompareRecord> ftoCompareRecords = this.list(queryWrapper);
|
|
|
-
|
|
|
+ List<FTOCompareRecord> lastFTORecords = this.list(queryWrapper);
|
|
|
+ List<Integer> taskIds = lastFTORecords.stream()
|
|
|
+ .map(FTOCompareRecord::getProjectTaskId)
|
|
|
+ .distinct() // 去除重复的任务ID
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ Integer taskId = null;
|
|
|
+ if (taskIds.size() == 1) {
|
|
|
+ taskId = taskIds.get(0); // 获取唯一的任务ID
|
|
|
+ } else {
|
|
|
+ throw new XiaoShiException("查询任务id错误,多个或者没有");
|
|
|
+ }
|
|
|
+ //根据专利号查询权要
|
|
|
+ try {
|
|
|
+ List<PatentRightVo> patentRightVos = new ArrayList<>();
|
|
|
+ List<RePatentClaim> patentRights = featureService.getRightListByNo(patentNo);
|
|
|
+ LambdaQueryWrapper<Feature> wrapper = new LambdaQueryWrapper<>();
|
|
|
+ wrapper.eq(Feature::getProjectTaskId, taskId)
|
|
|
+ .eq(Feature::getPatentNo, patentNo);
|
|
|
+ List<Feature> allFeatures = featureService.list(wrapper);
|
|
|
+ patentRightVos = featureService.loadPatentRightVO(patentRights, allFeatures, projectId, patentNo);
|
|
|
+ //装载权要层下的特征与对比结果
|
|
|
+ List<TortRightVO> tortRightVOS = new ArrayList<>();
|
|
|
+ tortRightVOS = this.loadLastRecord(lastFTORecords, patentRightVos);
|
|
|
+ tortCompareRecordVO.setTortRightVOS(tortRightVOS);
|
|
|
+ return tortCompareRecordVO;
|
|
|
+ } catch (Exception e) {
|
|
|
+ throw new XiaoShiException("根据专利号查询权要失败");
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
+ /**
|
|
|
+ * 查询最新的对比结果
|
|
|
+ * @param lastFTORecords
|
|
|
+ * @param patentRightVos
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public List<TortRightVO> loadLastRecord(List<FTOCompareRecord> lastFTORecords, List<PatentRightVo> patentRightVos){
|
|
|
+ if (patentRightVos != null && !patentRightVos.isEmpty()) {
|
|
|
+ //新建权要层信息
|
|
|
+ List<TortRightVO> tortRightVOS = new ArrayList<>();
|
|
|
+ //遍历装载权要层信息
|
|
|
+ patentRightVos.forEach(item -> {
|
|
|
+ TortRightVO tortRightVO = new TortRightVO();
|
|
|
+ BeanUtils.copyProperties(item, tortRightVO);
|
|
|
+ //新建特征与侵权分析对比结果VOS
|
|
|
+ List<Feature> features = item.getFeatures();
|
|
|
+ List<TortVO> tortVOS = this.loadLastVO(features, lastFTORecords);
|
|
|
+ tortRightVO.setTortVOS(tortVOS);
|
|
|
+ tortRightVOS.add(tortRightVO);
|
|
|
+ });
|
|
|
+ return tortRightVOS;
|
|
|
+ } else {
|
|
|
+ throw new XiaoShiException("传入权要为空");
|
|
|
+ }
|
|
|
+ }
|
|
|
|
|
|
- public List<ComparedPatentVO> getComparedPatent(Integer projectId,Integer compareResult) {
|
|
|
- //根据projectId 查询出对比过的专利号
|
|
|
- List<String> patentNos = this.getBaseMapper().getComparedPatents(projectId,compareResult);
|
|
|
- List<ComparedPatentVO> comparedPatentVOS = new ArrayList<>();
|
|
|
- //根据专利号查询专利信息
|
|
|
- List<Patent> patents = new ArrayList<>();
|
|
|
- try {
|
|
|
- if (patentNos != null && patentNos.size() != 0) {
|
|
|
- patents = esPatentService.getPatentsByNo(patentNos, true);
|
|
|
- List<Map<String, Object>> maps = esFamilyService.getPatentFamilyByNos(patentNos, "inpadoc");
|
|
|
- patents.forEach(item -> {
|
|
|
- ComparedPatentVO comparedPatentVO = new ComparedPatentVO();
|
|
|
- BeanUtils.copyProperties(item, comparedPatentVO);
|
|
|
- Map<String, Object> map = maps.stream().filter(i -> i.get("id").toString().equals(item.getInpadocFamilyId())).findFirst().orElse(null);
|
|
|
- if(map!=null){
|
|
|
- comparedPatentVO.setInpadocFamilyNos((List<String>)map.get("nos"));
|
|
|
- }
|
|
|
- comparedPatentVOS.add(comparedPatentVO);
|
|
|
- });
|
|
|
+ public List<TortVO> loadLastVO(List<Feature> features, List<FTOCompareRecord> ftoCompareRecords){
|
|
|
+ List<TortVO> tortVOS = new ArrayList<>();
|
|
|
+ for (Feature feature : features) {
|
|
|
+ //新建特征与侵权分析对比结果VO
|
|
|
+ //装载特征部分的信息
|
|
|
+ TortVO tortVO = tortCompareRecordService.loadFeature(feature);
|
|
|
+ //装载侵权分析对比结果的部分
|
|
|
+ FTOCompareRecordVO originalRecordVO = new FTOCompareRecordVO();
|
|
|
+ if (!ftoCompareRecords.isEmpty()) {
|
|
|
+ // 原始数据的装载
|
|
|
+ // 原始数据应该是ifOriginal为true的数据
|
|
|
+ FTOCompareRecord originalRecord = ftoCompareRecords
|
|
|
+ .stream()
|
|
|
+ .filter(item -> item.getFeatureId() != null && item.getFeatureId().equals(feature.getId()))
|
|
|
+ .findFirst()
|
|
|
+ .orElse(null);
|
|
|
+ if (originalRecord != null) {
|
|
|
+ originalRecordVO = tortCompareRecordService.loadVO(originalRecord);
|
|
|
+ }
|
|
|
}
|
|
|
- } catch (Exception e) {
|
|
|
+ tortVO.setOriginalRecordVO(originalRecordVO);
|
|
|
+ tortVOS.add(tortVO);
|
|
|
}
|
|
|
- return comparedPatentVOS;
|
|
|
+ return tortVOS;
|
|
|
}
|
|
|
|
|
|
}
|