|
@@ -1,12 +1,16 @@
|
|
|
package cn.cslg.report.service.business;
|
|
|
|
|
|
+import cn.cslg.report.common.model.vo.PersonnelVO;
|
|
|
+import cn.cslg.report.common.utils.CacheUtils;
|
|
|
import cn.cslg.report.common.utils.Response;
|
|
|
import cn.cslg.report.common.utils.SecurityUtils.LoginUtils;
|
|
|
import cn.cslg.report.entity.InvalidRecord;
|
|
|
import cn.cslg.report.entity.LitigationHistory;
|
|
|
import cn.cslg.report.entity.ReportFiles;
|
|
|
import cn.cslg.report.entity.ReportReferences;
|
|
|
+import cn.cslg.report.entity.asso.AssoLitigationHisFile;
|
|
|
import cn.cslg.report.entity.asso.AssoReportFile;
|
|
|
+import cn.cslg.report.entity.asso.AssoReportReferences;
|
|
|
import cn.cslg.report.mapper.ReportFileMapper;
|
|
|
import cn.cslg.report.mapper.ReportReferencesMapper;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
@@ -22,8 +26,11 @@ import org.springframework.stereotype.Service;
|
|
|
import org.springframework.web.multipart.MultipartFile;
|
|
|
|
|
|
import java.io.IOException;
|
|
|
+import java.util.ArrayList;
|
|
|
import java.util.Date;
|
|
|
import java.util.List;
|
|
|
+import java.util.stream.Collectors;
|
|
|
+import java.util.stream.Stream;
|
|
|
|
|
|
@Service
|
|
|
@Slf4j
|
|
@@ -32,6 +39,9 @@ public class ReportReferencesService extends ServiceImpl<ReportReferencesMapper,
|
|
|
private final ReportFileService reportFileService;
|
|
|
private final LoginUtils loginUtils;
|
|
|
private final AssoReportFileService assoReportFileService;
|
|
|
+ private final CacheUtils cacheUtils;
|
|
|
+ private final ReportService reportService;
|
|
|
+ private final AssoReportReferencesService assoReportReferencesService;
|
|
|
public String add(ReportReferences reportReferences, List<MultipartFile> files)throws IOException{
|
|
|
ReportReferences i = new ReportReferences();
|
|
|
i.setReportID(reportReferences.getReportID());
|
|
@@ -44,10 +54,10 @@ public class ReportReferencesService extends ServiceImpl<ReportReferencesMapper,
|
|
|
i.setType(reportReferences.getType());
|
|
|
i.setReferName(reportReferences.getReferName());
|
|
|
i.insert();
|
|
|
- if (files == null && files.size() != 0) {
|
|
|
+ if (files != null && files.size() != 0) {
|
|
|
//将文档上传并返回文件入库的Id
|
|
|
List<Integer> fileIds = reportFileService.uploadFiles(files);
|
|
|
- assoReportFileService.add(reportReferences.getReportID(),fileIds);
|
|
|
+ assoReportReferencesService.add(i.getId(),fileIds);
|
|
|
return Response.success();
|
|
|
}
|
|
|
|
|
@@ -55,31 +65,108 @@ public class ReportReferencesService extends ServiceImpl<ReportReferencesMapper,
|
|
|
}
|
|
|
public String queryReportReferences(ReportReferences reportReferences)throws IOException{
|
|
|
LambdaQueryWrapper<ReportReferences> wrapper = new LambdaQueryWrapper<>();
|
|
|
- wrapper.eq(ReportReferences::getReportID,reportReferences.getReportID())
|
|
|
- .eq(ReportReferences::getRemark,reportReferences.getRemark());
|
|
|
+ PersonnelVO personnelVO =cacheUtils.getLoginUser(loginUtils.getId());
|
|
|
+ String name = reportService.getName(reportReferences.getReportID());
|
|
|
+ //根据报告id 查询报告文档上传表
|
|
|
+ wrapper.eq(ReportReferences::getReportID,reportReferences.getReportID());
|
|
|
+
|
|
|
+ wrapper.orderByDesc(ReportReferences::getId);
|
|
|
+
|
|
|
+ List<ReportReferences> list=new ArrayList<>();
|
|
|
|
|
|
if(reportReferences.getSize()!=null&&reportReferences.getCurrent()!=null){
|
|
|
IPage<ReportReferences> pages = this.page(new Page<>(reportReferences.getCurrent(), reportReferences.getSize()), wrapper);
|
|
|
+ List<ReportReferences> records = pages.getRecords();
|
|
|
+
|
|
|
+ for(ReportReferences references :records) {
|
|
|
+ List<ReportFiles> reportFiles = this.ReportReferences(references.getId(), reportReferences.getFileName());
|
|
|
+ if (reportFiles.size() != 0) {
|
|
|
+
|
|
|
+ references.setPersonName(personnelVO.getName());
|
|
|
+
|
|
|
+ references.setReportName(name);
|
|
|
+ references.setReportFiles(reportFiles);
|
|
|
+ list.add(references);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ pages.setRecords(list);
|
|
|
return Response.success(pages);
|
|
|
}
|
|
|
|
|
|
|
|
|
- return Response.success(this.list(wrapper));
|
|
|
+ List<ReportReferences> list1 = this.list(wrapper);
|
|
|
+ for(ReportReferences references:list1){
|
|
|
+ List<ReportFiles> reportFiles = this.ReportReferences(references.getId(), reportReferences.getFileName());
|
|
|
+ if (reportFiles.size() != 0) {
|
|
|
+
|
|
|
+ references.setPersonName(personnelVO.getName());
|
|
|
+
|
|
|
+ references.setReportName(name);
|
|
|
+ references.setReportFiles(reportFiles);
|
|
|
+ list.add(references);
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ List<ReportReferences> l=new ArrayList<>(list);
|
|
|
+
|
|
|
+ return Response.success(list);
|
|
|
|
|
|
}
|
|
|
public String delete(int id)throws IOException{
|
|
|
-
|
|
|
this.removeById(id);
|
|
|
- LambdaQueryWrapper<AssoReportFile> wrapper = new LambdaQueryWrapper<>();
|
|
|
- wrapper.eq(AssoReportFile::getFileId,id);
|
|
|
+ LambdaQueryWrapper<AssoReportReferences> wrapper =new LambdaQueryWrapper<>();
|
|
|
+ wrapper.eq(AssoReportReferences::getReportReferencesID,id);
|
|
|
+ List<AssoReportReferences> list = assoReportReferencesService.list(wrapper);
|
|
|
+ reportFileService.removeByIds( list.stream().map(AssoReportReferences::getFileID).collect(Collectors.toList()));
|
|
|
+ assoReportReferencesService.remove(wrapper);
|
|
|
+ return Response.success();
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ public List<ReportFiles> ReportReferences(int id ,String str){
|
|
|
+ List<AssoReportReferences> select = assoReportReferencesService.select(id);
|
|
|
+ List<Integer> collect = select.stream().map(AssoReportReferences::getFileID).collect(Collectors.toList());
|
|
|
+ if(collect.size()==0){
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+ LambdaQueryWrapper<ReportFiles> wrapper = new LambdaQueryWrapper<>();
|
|
|
+
|
|
|
+ wrapper.in(ReportFiles::getId, collect);
|
|
|
+ if(str!=null&&str!=""){
|
|
|
+ wrapper.like(ReportFiles::getName,str);
|
|
|
+ }
|
|
|
+ List<ReportFiles> reportFiles = reportFileService.list(wrapper);
|
|
|
+ return reportFiles;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ public Boolean updateReportReferences(ReportReferences reportReferences,List<MultipartFile> files)throws IOException{
|
|
|
+ if(files!=null && files.size() != 0 ){
|
|
|
|
|
|
- assoReportFileService.remove(wrapper);
|
|
|
- return Response.success();
|
|
|
+ LambdaQueryWrapper<AssoReportReferences> wrapper =new LambdaQueryWrapper<>();
|
|
|
+ wrapper.eq(AssoReportReferences::getReportReferencesID,reportReferences.getId());
|
|
|
+ List<AssoReportReferences> list = assoReportReferencesService.list(wrapper);
|
|
|
+ List<Integer> collect = list.stream().map(AssoReportReferences::getFileID).collect(Collectors.toList());
|
|
|
+ assoReportReferencesService.remove(wrapper);
|
|
|
+ reportFileService.removeByIds(collect);
|
|
|
+ List<Integer> fileIdList = reportFileService.uploadFiles(files);
|
|
|
+ assoReportReferencesService.add(reportReferences.getId(),fileIdList);
|
|
|
|
|
|
|
|
|
|
|
|
+
|
|
|
+ }
|
|
|
+ return reportReferences.updateById();
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
}
|