Переглянути джерело

替换报告系统涉及文件代码

chenyu 2 роки тому
батько
коміт
ed256500ed

+ 12 - 8
RMS/src/main/java/cn/cslg/report/controller/ReferencesController.java

@@ -24,33 +24,37 @@ import java.util.List;
 @SuppressWarnings({"all"})
 public class ReferencesController {
     public final ReferencesService referencesService;
+
     @RequestMapping(value = "/addReferences", method = RequestMethod.POST)
     @Operation(summary = "增加参考资料")
-    public  String addReferences( String jsons, List<MultipartFile> files) throws IOException{
-        References references = JSONObject.parseObject(jsons,References.class);
-        return referencesService.addReferences(references,files);
+    public String addReferences(String jsons, List<MultipartFile> files) throws IOException {
+        References references = JSONObject.parseObject(jsons, References.class);
+        return referencesService.addReferences(references, files);
     }
+
     @RequestMapping(value = "/updateReferences", method = RequestMethod.POST)
     @Operation(summary = "修改参考资料")
     @Transactional(rollbackFor = Exception.class)
-    public String updateReferences( String jsons, List<MultipartFile> files)throws IOException{
-        References references = JSONObject.parseObject(jsons,References.class);
-        Boolean flag=referencesService.updateReferences(references,files);
+    public String updateReferences(String jsons, List<MultipartFile> files) throws IOException {
+        References references = JSONObject.parseObject(jsons, References.class);
+        Boolean flag = referencesService.updateReferences(references, files);
         if (flag) {
             return Response.success();
         }
         return Response.error();
 
     }
+
     @GetMapping(value = "/deleReferences")
     @Operation(summary = "删除参考资料")
-    public String deleReferences(int id)throws IOException{
+    public String deleReferences(int id) throws IOException {
         return referencesService.deleteReferences(id);
     }
+
     @PostMapping(value = "/queryReferences")
     @Operation(summary = "查询参考资料")
     @Transactional(rollbackFor = Exception.class)
-    public String queryReferences(@RequestBody References references)throws IOException{
+    public String queryReferences(@RequestBody References references) throws IOException {
         return referencesService.queryReferences(references);
     }
 

+ 73 - 47
RMS/src/main/java/cn/cslg/report/service/business/ReferencesService.java

@@ -1,13 +1,18 @@
 package cn.cslg.report.service.business;
 
 import cn.cslg.report.common.utils.Response;
+import cn.cslg.report.common.utils.SystemFileToReportFile;
 import cn.cslg.report.entity.ReportFiles;
 
 import cn.cslg.report.entity.References;
 
+import cn.cslg.report.entity.SystemFile;
 import cn.cslg.report.entity.asso.AssoReferenceFile;
 
 import cn.cslg.report.mapper.ReferencesMapper;
+import cn.cslg.report.service.file.FileManagerService;
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -28,113 +33,126 @@ import java.util.stream.Collectors;
 @RequiredArgsConstructor(onConstructor_ = {@Lazy})
 @SuppressWarnings({"all"})
 public class ReferencesService extends ServiceImpl<ReferencesMapper, References> {
-  private  final ReportFileService reportFileService;
-  private final AssoReferenceFileService assoReferenceFileService;
+    private final ReportFileService reportFileService;
+    private final AssoReferenceFileService assoReferenceFileService;
+    private final FileManagerService fileManagerService;
 
     /**
-     * @function: 根据无效记录的id 删除无效记录(关联的对比方案与对比记录 文件 也要删除)
      * @param id
      * @return
      * @throws IOException
+     * @function: 根据无效记录的id 删除无效记录(关联的对比方案与对比记录 文件 也要删除)
      */
     public String deleteReferences(int id) throws IOException {
-        References references =this.getById(id);
+        References references = this.getById(id);
         this.removeById(id);
-        LambdaQueryWrapper<AssoReferenceFile> wrapper =new LambdaQueryWrapper<>();
-        wrapper.eq(AssoReferenceFile::getReferenceId,references.getId());
-        List<AssoReferenceFile> assoes= assoReferenceFileService.list(wrapper);
-        List<Integer> fileIds =assoes.stream().map(AssoReferenceFile::getFileId).collect(Collectors.toList());
-        //删除对应的对比文件
-        reportFileService.removeByIds(fileIds);
-        //关联的对比方案与对比记录的删除
-        assoReferenceFileService.remove(wrapper);
+        LambdaQueryWrapper<AssoReferenceFile> wrapper = new LambdaQueryWrapper<>();
+        wrapper.eq(AssoReferenceFile::getReferenceId, references.getId());
+        List<AssoReferenceFile> assoes = assoReferenceFileService.list(wrapper);
+        if (assoes != null && assoes.size() > 0) {
+            List<Integer> fileIds = assoes.stream().map(AssoReferenceFile::getFileId).collect(Collectors.toList());
+            //删除对应的对比文件
+            //reportFileService.removeByIds(fileIds);
+            fileManagerService.deleteFileFromFMS(fileIds);
+            //关联的对比方案与对比记录的删除
+            assoReferenceFileService.remove(wrapper);
+        }
         return Response.success();
     }
 
     /**
-     * @function: 修改无效记录 (关联的对比方案与对比记录 文件 也要修改)
      * @param references 无效记录
-     * @param files 对比文件
+     * @param files      对比文件
      * @return
      * @throws IOException
+     * @function: 修改无效记录 (关联的对比方案与对比记录 文件 也要修改)
      */
 
     public Boolean updateReferences(References references, List<MultipartFile> files) throws IOException {
 
         // 根据无效Id查询对应的附件Id
-        LambdaQueryWrapper<AssoReferenceFile> wrapper =new LambdaQueryWrapper<>();
-        wrapper.eq(AssoReferenceFile::getReferenceId,references.getId());
-        List<AssoReferenceFile> assoes= assoReferenceFileService.list(wrapper);
-        List<Integer> fileIds =assoes.stream().map(AssoReferenceFile::getFileId).collect(Collectors.toList());
+        LambdaQueryWrapper<AssoReferenceFile> wrapper = new LambdaQueryWrapper<>();
+        wrapper.eq(AssoReferenceFile::getReferenceId, references.getId());
+        List<AssoReferenceFile> assoes = assoReferenceFileService.list(wrapper);
+        List<Integer> fileIds = assoes.stream().map(AssoReferenceFile::getFileId).collect(Collectors.toList());
         // 获得更新后的附件Id
-        List<Integer> updateFileId =new ArrayList<>();
-        if(references.getReportFiles()!=null){
+        List<Integer> updateFileId = new ArrayList<>();
+        if (references.getReportFiles() != null) {
             updateFileId = references.getReportFiles().stream().map(ReportFiles::getId).collect(Collectors.toList());
-            fileIds.removeAll(updateFileId);}
+            fileIds.removeAll(updateFileId);
+        }
         //做差获得被删除的文件Id
-        if(fileIds.size()!=0){
+        if (fileIds.size() != 0) {
             //根据文件Id删除报告文件关联表记录
             LambdaQueryWrapper<AssoReferenceFile> deleteWrapper = new LambdaQueryWrapper<>();
-            deleteWrapper.in(AssoReferenceFile::getFileId,fileIds);
+            deleteWrapper.in(AssoReferenceFile::getFileId, fileIds);
             assoReferenceFileService.remove(deleteWrapper);
             //根据文件Id删除文件表记录
-            reportFileService.removeByIds(fileIds);
+            //reportFileService.removeByIds(fileIds);
+            fileManagerService.deleteFileFromFMS(fileIds);
         }
-            //添加附件
-        if (files!=null&&files.size() != 0) {
+        //添加附件
+        if (files != null && files.size() != 0) {
             //将文档上传并返回文件入库的Id
-            List<Integer> fileIdList = reportFileService.uploadFiles(files);
+            //List<Integer> fileIdList = reportFileService.uploadFiles(files);
+            String res = fileManagerService.uploadFile(files);
+            JSONObject jsonObject = JSONObject.parseObject(res);
+            List<Integer> fileIdList = JSONArray.parseArray(jsonObject.get("data").toString(), Integer.class);
             assoReferenceFileService.addAsso(references.getId(), fileIdList);
 
         }
         return references.updateById();
     }
+
     /**
-     * @function: 增加无效记录(关联的对比方案与对比记录 文件 也要增加)
      * @param references 无效记录
-     * @param files 对比文件
+     * @param files      对比文件
      * @return
      * @throws IOException
+     * @function: 增加无效记录(关联的对比方案与对比记录 文件 也要增加)
      */
 
-    public String addReferences(References references,List<MultipartFile> files) throws IOException {
+    public String addReferences(References references, List<MultipartFile> files) throws IOException {
         references.insert();
-        if (files!=null&&files.size() != 0) {
+        if (files != null && files.size() != 0) {
             //将文档上传并返回文件入库的Id
-            List<Integer> fileIds = reportFileService.uploadFiles(files);
-            assoReferenceFileService.addAsso(references.getId(),fileIds);
+            //List<Integer> fileIds = reportFileService.uploadFiles(files);
+            String res = fileManagerService.uploadFile(files);
+            JSONObject jsonObject = JSONObject.parseObject(res);
+            List<Integer> fileIds = JSONArray.parseArray(jsonObject.get("data").toString(), Integer.class);
+            assoReferenceFileService.addAsso(references.getId(), fileIds);
         }
         return Response.success();
     }
 
     /**
-     * @function: 根据专利号查询无效分析(分页)
      * @param references
      * @return
+     * @function: 根据专利号查询无效分析(分页)
      */
-    public String queryReferences(References references){
-        LambdaQueryWrapper<References> wrapper =new LambdaQueryWrapper<>();
-        wrapper.eq(References::getPatentNo,references.getPatentNo());
+    public String queryReferences(References references) throws IOException {
+        LambdaQueryWrapper<References> wrapper = new LambdaQueryWrapper<>();
+        wrapper.eq(References::getPatentNo, references.getPatentNo());
         //分页
         if (references.getSize() != null && references.getCurrent() != null) {
             IPage<References> pages = this.page(new Page<>(references.getCurrent(), references.getSize()), wrapper);
             pages.setRecords(this.thisReference(pages.getRecords()));
             return Response.success(pages);
         } else {
-            List<References> referencesList= this.list(wrapper);
-            referencesList =this.thisReference(referencesList);
+            List<References> referencesList = this.list(wrapper);
+            referencesList = this.thisReference(referencesList);
             return Response.success(referencesList);
         }
     }
 
     /**
-     * @function: 装载其他参考资料
      * @param references
      * @return
+     * @function: 装载其他参考资料
      */
 
 
-    public List<References> thisReference(List<References> references) {
+    public List<References> thisReference(List<References> references) throws IOException {
         //获得无效记录的Id
         List<Integer> ids = references.stream().map(References::getId).collect(Collectors.toList());
         if (ids.size() != 0) {
@@ -143,19 +161,27 @@ public class ReferencesService extends ServiceImpl<ReferencesMapper, References>
             queryWrapper.in(AssoReferenceFile::getReferenceId, ids);
             List<AssoReferenceFile> assoReferenceFiles = assoReferenceFileService.list();
             //根据关联信息查询附件信息
-            if (assoReferenceFiles.size() != 0) {
+            if (assoReferenceFiles.size() > 0) {
                 List<Integer> fileIds = assoReferenceFiles.stream().map(AssoReferenceFile::getFileId).collect(Collectors.toList());
-                LambdaQueryWrapper<ReportFiles> wrapper = new LambdaQueryWrapper<>();
-                wrapper.in(ReportFiles::getId, fileIds);
-                List<ReportFiles> reportFiles = reportFileService.list(wrapper);
+//                LambdaQueryWrapper<ReportFiles> wrapper = new LambdaQueryWrapper<>();
+//                wrapper.in(ReportFiles::getId, fileIds);
+//                List<ReportFiles> reportFiles = reportFileService.list(wrapper);
+                String res = fileManagerService.getSystemFileFromFMS(fileIds);
+                List<SystemFile> systemFiles = JSONArray.parseArray(res, SystemFile.class);
                 //遍历装载文件信息
                 references.forEach(item -> {
                     List<AssoReferenceFile> partAsso = assoReferenceFiles.stream().filter(tem -> tem.getReferenceId().equals(item.getId())).collect(Collectors.toList());
                     List<ReportFiles> reportFilesList = new ArrayList<>();
                     if (partAsso.size() != 0) {
                         List<Integer> partFileIds = partAsso.stream().map(AssoReferenceFile::getFileId).collect(Collectors.toList());
-                        List<ReportFiles> reportFiles1 = reportFiles.stream().filter(tem -> partFileIds.contains(tem.getId())).collect(Collectors.toList());
-                        reportFilesList = reportFiles1;
+//                        List<ReportFiles> reportFiles1 = reportFiles.stream().filter(tem -> partFileIds.contains(tem.getId())).collect(Collectors.toList());
+//                        reportFilesList = reportFiles1;
+                        List<SystemFile> systemFiles1 = systemFiles.stream().filter(tem -> partFileIds.contains(tem.getId())).collect(Collectors.toList());
+                        systemFiles1.forEach(systemFile -> {
+                            ReportFiles reportFile = new ReportFiles();
+                            SystemFileToReportFile.systemFileToReportFile(systemFile, reportFile);
+                            reportFilesList.add(reportFile);
+                        });
                     }
                     item.setReportFiles(reportFilesList);
                 });