|
@@ -1,9 +1,9 @@
|
|
package cn.cslg.report.service.business;
|
|
package cn.cslg.report.service.business;
|
|
|
|
|
|
import cn.cslg.report.common.utils.Response;
|
|
import cn.cslg.report.common.utils.Response;
|
|
-import cn.cslg.report.entity.ImportTask;
|
|
|
|
-import cn.cslg.report.entity.InvalidRecord;
|
|
|
|
-import cn.cslg.report.entity.LitigationHistory;
|
|
|
|
|
|
+import cn.cslg.report.entity.*;
|
|
|
|
+import cn.cslg.report.entity.asso.AssoInvalidRecordFile;
|
|
|
|
+import cn.cslg.report.entity.asso.AssoReportFile;
|
|
import cn.cslg.report.mapper.ImportTaskMapper;
|
|
import cn.cslg.report.mapper.ImportTaskMapper;
|
|
import cn.cslg.report.mapper.InvalidRecordMapper;
|
|
import cn.cslg.report.mapper.InvalidRecordMapper;
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
@@ -17,7 +17,9 @@ import org.springframework.stereotype.Service;
|
|
import org.springframework.web.multipart.MultipartFile;
|
|
import org.springframework.web.multipart.MultipartFile;
|
|
|
|
|
|
import java.io.IOException;
|
|
import java.io.IOException;
|
|
|
|
+import java.util.ArrayList;
|
|
import java.util.List;
|
|
import java.util.List;
|
|
|
|
+import java.util.stream.Collectors;
|
|
|
|
|
|
@Service
|
|
@Service
|
|
@Slf4j
|
|
@Slf4j
|
|
@@ -25,39 +27,108 @@ import java.util.List;
|
|
public class InvalidRecordService extends ServiceImpl<InvalidRecordMapper, InvalidRecord> {
|
|
public class InvalidRecordService extends ServiceImpl<InvalidRecordMapper, InvalidRecord> {
|
|
public final InvalidRecordMapper invalidRecordMapper;
|
|
public final InvalidRecordMapper invalidRecordMapper;
|
|
private final ReportFileService reportFileService;
|
|
private final ReportFileService reportFileService;
|
|
- private final AssoInvalidRecordFileService assoInvalidRecordFileService;
|
|
|
|
|
|
+ private final AssoInvalidRecordFileService assoInvalidRecordFileService;
|
|
|
|
+
|
|
public String deleteInvalidRecord(int id) throws IOException {
|
|
public String deleteInvalidRecord(int id) throws IOException {
|
|
|
|
+ InvalidRecord invalidRecord =this.getById(id);
|
|
this.removeById(id);
|
|
this.removeById(id);
|
|
|
|
+ LambdaQueryWrapper<AssoInvalidRecordFile> wrapper =new LambdaQueryWrapper<>();
|
|
|
|
+ wrapper.eq(AssoInvalidRecordFile::getInvalidId,invalidRecord.getId());
|
|
|
|
+ List<AssoInvalidRecordFile> assoes= assoInvalidRecordFileService.list(wrapper);
|
|
|
|
+ List<Integer> fileIds =assoes.stream().map(AssoInvalidRecordFile::getFileId).collect(Collectors.toList());
|
|
|
|
+ reportFileService.removeByIds(fileIds);
|
|
|
|
+ assoInvalidRecordFileService.remove(wrapper);
|
|
return Response.success();
|
|
return Response.success();
|
|
}
|
|
}
|
|
|
|
|
|
- public String updateInvalidRecord(InvalidRecord invalidRecord) throws IOException {
|
|
|
|
- invalidRecord.updateById();
|
|
|
|
- return Response.success();
|
|
|
|
|
|
+ public Boolean updateInvalidRecord(InvalidRecord invalidRecord, List<MultipartFile> files) throws IOException {
|
|
|
|
+ // 根据无效Id查询对应的附件Id
|
|
|
|
+ LambdaQueryWrapper<AssoInvalidRecordFile> wrapper =new LambdaQueryWrapper<>();
|
|
|
|
+ wrapper.eq(AssoInvalidRecordFile::getInvalidId,invalidRecord.getId());
|
|
|
|
+ List<AssoInvalidRecordFile> assoes= assoInvalidRecordFileService.list(wrapper);
|
|
|
|
+ List<Integer> fileIds =assoes.stream().map(AssoInvalidRecordFile::getFileId).collect(Collectors.toList());
|
|
|
|
+ // 获得更新后的附件Id
|
|
|
|
+ List<Integer> updateFileId =new ArrayList<>();
|
|
|
|
+ if(invalidRecord.getReportFiles()!=null){
|
|
|
|
+ updateFileId = invalidRecord.getReportFiles().stream().map(ReportFiles::getId).collect(Collectors.toList());
|
|
|
|
+ fileIds.removeAll(updateFileId);}
|
|
|
|
+ //做差获得被删除的文件Id
|
|
|
|
+ if(fileIds.size()!=0){
|
|
|
|
+ //根据文件Id删除报告文件关联表记录
|
|
|
|
+ LambdaQueryWrapper<AssoInvalidRecordFile> deleteWrapper = new LambdaQueryWrapper<>();
|
|
|
|
+ deleteWrapper.in(AssoInvalidRecordFile::getFileId,fileIds);
|
|
|
|
+ assoInvalidRecordFileService.remove(deleteWrapper);
|
|
|
|
+ //根据文件Id删除文件表记录
|
|
|
|
+ reportFileService.removeByIds(fileIds);
|
|
|
|
+ }
|
|
|
|
+//添加附件
|
|
|
|
+ if (files!=null&&files.size() != 0) {
|
|
|
|
+ //将文档上传并返回文件入库的Id
|
|
|
|
+ List<Integer> fileIdList = reportFileService.uploadFiles(files);
|
|
|
|
+ assoInvalidRecordFileService.addAsso(invalidRecord.getId(), fileIdList);
|
|
|
|
+
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return invalidRecord.updateById();
|
|
}
|
|
}
|
|
|
|
|
|
- public String addInvalidRecord(InvalidRecord invalidRecord,List<MultipartFile> files) throws IOException {
|
|
|
|
|
|
+ public String addInvalidRecord(InvalidRecord invalidRecord, List<MultipartFile> files) throws IOException {
|
|
invalidRecord.insert();
|
|
invalidRecord.insert();
|
|
- if (files==null&&files.size() != 0) {
|
|
|
|
|
|
+ if (files == null && files.size() != 0) {
|
|
//将文档上传并返回文件入库的Id
|
|
//将文档上传并返回文件入库的Id
|
|
List<Integer> fileIds = reportFileService.uploadFiles(files);
|
|
List<Integer> fileIds = reportFileService.uploadFiles(files);
|
|
- assoInvalidRecordFileService.addAsso(invalidRecord.getId(),fileIds);
|
|
|
|
|
|
+ assoInvalidRecordFileService.addAsso(invalidRecord.getId(), fileIds);
|
|
}
|
|
}
|
|
return Response.success();
|
|
return Response.success();
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ //查找无效记录
|
|
public String queryInvalidRecord(InvalidRecord invalidRecord) {
|
|
public String queryInvalidRecord(InvalidRecord invalidRecord) {
|
|
LambdaQueryWrapper<InvalidRecord> wrapper = new LambdaQueryWrapper<>();
|
|
LambdaQueryWrapper<InvalidRecord> wrapper = new LambdaQueryWrapper<>();
|
|
wrapper.eq(InvalidRecord::getPatentNo, invalidRecord.getPatentNo());
|
|
wrapper.eq(InvalidRecord::getPatentNo, invalidRecord.getPatentNo());
|
|
if (invalidRecord.getSize() != null && invalidRecord.getSize() != null) {
|
|
if (invalidRecord.getSize() != null && invalidRecord.getSize() != null) {
|
|
IPage<InvalidRecord> pages = this.page(new Page<>(invalidRecord.getCurrent(), invalidRecord.getSize()), wrapper);
|
|
IPage<InvalidRecord> pages = this.page(new Page<>(invalidRecord.getCurrent(), invalidRecord.getSize()), wrapper);
|
|
|
|
+ pages.setRecords(this.thisInvaliRecord(pages.getRecords()));
|
|
return Response.success(pages);
|
|
return Response.success(pages);
|
|
} else {
|
|
} else {
|
|
List<InvalidRecord> invalidRecords = this.list(wrapper);
|
|
List<InvalidRecord> invalidRecords = this.list(wrapper);
|
|
|
|
+ invalidRecords =thisInvaliRecord(invalidRecords);
|
|
return Response.success(invalidRecords);
|
|
return Response.success(invalidRecords);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ //装载无效记录
|
|
|
|
+ public List<InvalidRecord> thisInvaliRecord(List<InvalidRecord> invalidRecords) {
|
|
|
|
+ //获得无效记录的Id
|
|
|
|
+ List<Integer> ids = invalidRecords.stream().map(InvalidRecord::getId).collect(Collectors.toList());
|
|
|
|
+ if (ids.size() != 0) {
|
|
|
|
+ //根据无效记录Id获得无效记录和文件的关联信息
|
|
|
|
+ LambdaQueryWrapper<AssoInvalidRecordFile> queryWrapper = new LambdaQueryWrapper<>();
|
|
|
|
+ queryWrapper.in(AssoInvalidRecordFile::getInvalidId, ids);
|
|
|
|
+ List<AssoInvalidRecordFile> assoInvalidRecordFiles = assoInvalidRecordFileService.list();
|
|
|
|
+ //根据关联信息查询附件信息
|
|
|
|
+ if (assoInvalidRecordFiles.size() != 0) {
|
|
|
|
+ List<Integer> fileIds = assoInvalidRecordFiles.stream().map(AssoInvalidRecordFile::getFileId).collect(Collectors.toList());
|
|
|
|
+ LambdaQueryWrapper<ReportFiles> wrapper = new LambdaQueryWrapper<>();
|
|
|
|
+ wrapper.in(ReportFiles::getId, fileIds);
|
|
|
|
+ List<ReportFiles> reportFiles = reportFileService.list(wrapper);
|
|
|
|
+ //遍历装载文件信息
|
|
|
|
+ invalidRecords.forEach(item -> {
|
|
|
|
+ List<AssoInvalidRecordFile> partAsso = assoInvalidRecordFiles.stream().filter(tem -> tem.getInvalidId().equals(item.getId())).collect(Collectors.toList());
|
|
|
|
+ List<ReportFiles> reportFilesList = new ArrayList<>();
|
|
|
|
+ if (partAsso.size() != 0) {
|
|
|
|
+ List<Integer> partFileIds = partAsso.stream().map(AssoInvalidRecordFile::getFileId).collect(Collectors.toList());
|
|
|
|
+ List<ReportFiles> reportFiles1 = reportFiles.stream().filter(tem -> partFileIds.contains(tem.getId())).collect(Collectors.toList());
|
|
|
|
+ reportFilesList = reportFiles1;
|
|
|
|
+ }
|
|
|
|
+ item.setReportFiles(reportFilesList);
|
|
|
|
+ });
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ }
|
|
|
|
+ return invalidRecords;
|
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+}
|
|
|
|
+
|