From 07a2f9c762efb3be3a29e2e8cc7004d4164cc9d8 Mon Sep 17 00:00:00 2001
From: fei <791364011@qq.com>
Date: 星期一, 22 十二月 2025 20:15:58 +0800
Subject: [PATCH] 修改了对应代码

---
 archiveManager/src/main/java/com/ruoyi/service/impl/DocumentMaterialsServiceImpl.java |  196 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 193 insertions(+), 3 deletions(-)

diff --git a/archiveManager/src/main/java/com/ruoyi/service/impl/DocumentMaterialsServiceImpl.java b/archiveManager/src/main/java/com/ruoyi/service/impl/DocumentMaterialsServiceImpl.java
index c98e310..90cc40f 100644
--- a/archiveManager/src/main/java/com/ruoyi/service/impl/DocumentMaterialsServiceImpl.java
+++ b/archiveManager/src/main/java/com/ruoyi/service/impl/DocumentMaterialsServiceImpl.java
@@ -2,14 +2,17 @@
 
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.common.core.domain.AjaxResult;
 import com.ruoyi.common.utils.MapUtils;
+import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.common.utils.bean.BeanUtils;
 import com.ruoyi.common.utils.poi.ExcelUtil;
 import com.ruoyi.domain.ArchiveCategory;
+import com.ruoyi.domain.ArchiveRecords;
 import com.ruoyi.domain.DocumentMaterials;
 import com.ruoyi.domain.vo.*;
 import com.ruoyi.mapper.DocumentMaterialsMapper;
@@ -40,6 +43,9 @@
                 .like(!StringUtils.isEmpty(documentMaterials.getPublicity()), DocumentMaterials::getPublicity, documentMaterials.getPublicity())
                 .like(!StringUtils.isEmpty(documentMaterials.getRetentionPeriod()), DocumentMaterials::getRetentionPeriod, documentMaterials.getRetentionPeriod())
                 .like(!StringUtils.isEmpty(documentMaterials.getSecurityLevel()), DocumentMaterials::getSecurityLevel, documentMaterials.getSecurityLevel())
+                .like(!StringUtils.isEmpty(documentMaterials.getTitle()), DocumentMaterials::getTitle, documentMaterials.getTitle())
+
+
                 .eq(documentMaterials.getDate()!=null, DocumentMaterials::getDate, documentMaterials.getDate())
                 .eq(documentMaterials.getRecordId()!=null, DocumentMaterials::getRecordId, documentMaterials.getRecordId())
         .eq(documentMaterials.getPageNumber()!=null, DocumentMaterials::getPageNumber, documentMaterials.getPageNumber());
@@ -148,9 +154,66 @@
     }
 
     @Override
-    public int updateDocumentMaterials(DocumentMaterials documentMaterials) {
+    public List<DocumentMaterials> selectDocumentMaterialsByIds(Long[] ids) {
+        // 鑾峰彇褰撳墠鐢ㄦ埛ID
+        Long userid = SecurityUtils.getUserId();
 
-        boolean result = updateById(documentMaterials);
+        // 鍒涘缓鏌ヨ鏉′欢
+        LambdaQueryWrapper<DocumentMaterials> lambdaQueryWrapper = new LambdaQueryWrapper<>();
+
+        // 鏍规嵁ids鏌ヨ
+        lambdaQueryWrapper.in(DocumentMaterials::getMaterialId, Arrays.asList(ids));
+        lambdaQueryWrapper.orderByAsc(DocumentMaterials::getPageNumber);
+        // 濡傛灉涓嶆槸绠$悊鍛橈紝闇�瑕佽�冭檻鏉冮檺杩囨护锛堝彲鏍规嵁瀹為檯鏉冮檺闇�姹傝皟鏁达級
+        if (userid != 1) {
+            // 杩欓噷鍙互娣诲姞鏉冮檺鐩稿叧鐨勮繃婊ゆ潯浠�
+        }
+
+        List<DocumentMaterials> beanRecords = list(lambdaQueryWrapper);
+        return beanRecords;
+    }
+
+    @Override
+    public int updateDocumentMaterials(DocumentMaterials documentMaterials) {
+        boolean result = false;
+        try {
+            // 浣跨敤LambdaUpdateWrapper鏋勯�犳洿鏂版潯浠讹紝纭繚null鍊间篃鑳芥洿鏂板埌鏁版嵁搴�
+            LambdaUpdateWrapper<DocumentMaterials> updateWrapper = new LambdaUpdateWrapper<>();
+            updateWrapper.eq(DocumentMaterials::getMaterialId, documentMaterials.getMaterialId());
+            
+            // 鏄庣‘璁剧疆闇�瑕佹洿鏂扮殑瀛楁
+            updateWrapper.set(DocumentMaterials::getFileNumber, documentMaterials.getFileNumber());
+            updateWrapper.set(DocumentMaterials::getDocumentNumber, documentMaterials.getDocumentNumber());
+            updateWrapper.set(DocumentMaterials::getCreator, documentMaterials.getCreator());
+            updateWrapper.set(DocumentMaterials::getTitle, documentMaterials.getTitle());
+            updateWrapper.set(DocumentMaterials::getDate, documentMaterials.getDate());
+            updateWrapper.set(DocumentMaterials::getPageNumber, documentMaterials.getPageNumber()); // 鍏佽鏇存柊涓簄ull
+            updateWrapper.set(DocumentMaterials::getPageOrder, documentMaterials.getPageOrder());
+            updateWrapper.set(DocumentMaterials::getStage, documentMaterials.getStage());
+            updateWrapper.set(DocumentMaterials::getPublicity, documentMaterials.getPublicity());
+            updateWrapper.set(DocumentMaterials::getIsAttachment, documentMaterials.getIsAttachment());
+            updateWrapper.set(DocumentMaterials::getIsDiagram, documentMaterials.getIsDiagram());
+            updateWrapper.set(DocumentMaterials::getRetentionPeriod, documentMaterials.getRetentionPeriod());
+            updateWrapper.set(DocumentMaterials::getSecurityLevel, documentMaterials.getSecurityLevel());
+            updateWrapper.set(DocumentMaterials::getIsSensitive, documentMaterials.getIsSensitive());
+            updateWrapper.set(DocumentMaterials::getIsCanceled, documentMaterials.getIsCanceled());
+            updateWrapper.set(DocumentMaterials::getFormat, documentMaterials.getFormat());
+            updateWrapper.set(DocumentMaterials::getSizeType, documentMaterials.getSizeType());
+            updateWrapper.set(DocumentMaterials::getHorizontalResolution, documentMaterials.getHorizontalResolution());
+            updateWrapper.set(DocumentMaterials::getVerticalResolution, documentMaterials.getVerticalResolution());
+            updateWrapper.set(DocumentMaterials::getWidth, documentMaterials.getWidth());
+            updateWrapper.set(DocumentMaterials::getHeight, documentMaterials.getHeight());
+            updateWrapper.set(DocumentMaterials::getFileSize, documentMaterials.getFileSize());
+            updateWrapper.set(DocumentMaterials::getAttachmentHistoryNumbers, documentMaterials.getAttachmentHistoryNumbers());
+            updateWrapper.set(DocumentMaterials::getRemarks, documentMaterials.getRemarks());
+            updateWrapper.set(DocumentMaterials::getVisible, documentMaterials.getVisible());
+            updateWrapper.set(DocumentMaterials::getFileStyle, documentMaterials.getFileStyle());
+            // 鎵ц鏇存柊鎿嶄綔
+            result = update(updateWrapper);
+        } catch (Exception e) {
+            System.out.println(e);
+            throw new ErrorcodeExceptionextends(500, "鍚屼竴涓鍗峰唴锛屼笉鍏佽椤电爜閲嶅锛�");
+        }
         if(result)
             return 1;
         else
@@ -173,16 +236,19 @@
 
     @Override
     public Long getFiNum(Long pageNumber, Long recordId) {
-        return this.baseMapper.getFileNumber(pageNumber, recordId);
+        return this.baseMapper.getFileNumber(pageNumber, recordId)+1;
     }
 
     @Override
     public int updateByPageNumber(Long pageNumber, String sizeType, Long fileNumber, int width, int height, int horizontalResolution, int verticalResolution, double fileSize, String url, String format, Long recordId) {
         //鏍规嵁pageNumber鎷垮埌title锛岀劧鍚庤绠梡ageOrder
         LambdaQueryWrapper<DocumentMaterials> lqw = new LambdaQueryWrapper<>();
+        lqw.eq(recordId!=null, DocumentMaterials::getRecordId, recordId);
         lqw.eq(pageNumber!=null, DocumentMaterials::getPageNumber, pageNumber);
         List<DocumentMaterials> records = list(lqw);
 
+
+        //璁$畻pageOrder
         Long pageOrder = 1L;
         if(pageNumber.equals(1))
             pageOrder = 1L;
@@ -224,6 +290,7 @@
             DocumentMaterials documentMaterials = new DocumentMaterials();
             BeanUtils.copyProperties(archiveCategory, documentMaterials);
             documentMaterials.setRecordId(Long.parseLong(recordId));
+            documentMaterials.setVisible(1);
             this.insertDocumentMaterials(documentMaterials);
         }
 
@@ -240,4 +307,127 @@
         else
             return null;
     }
+
+    @Override
+    public boolean isPageNumberIslegal(Integer recordId) {
+        return this.baseMapper.isPageNumberLegal(recordId);
+    }
+
+    @Override
+    public int getFileCount(Integer recordId) {
+        return this.baseMapper.getCount(recordId);
+    }
+    
+    @Override
+    public AjaxResult addMiddleRecordsByPageNumbers(Long recordId, Long maxPageNumber) {
+        try {
+            // 鑾峰彇鎸囧畾recordId涓嬬殑鎵�鏈夎褰曪紝鎸夐〉鍙峰崌搴忔帓鍒�
+            LambdaQueryWrapper<DocumentMaterials> lqw = new LambdaQueryWrapper<>();
+            lqw.eq(DocumentMaterials::getRecordId, recordId);
+            lqw.ne(DocumentMaterials::getFileStyle, "鍏朵粬鏉愭枡");
+            lqw.orderByAsc(DocumentMaterials::getPageNumber);
+            List<DocumentMaterials> records = this.list(lqw);
+
+            if (records == null || records.isEmpty()) {
+                return AjaxResult.success("娌℃湁鎵惧埌鎸囧畾璁板綍");
+            }
+            
+            List<DocumentMaterials> middleRecords = new ArrayList<>();
+            
+            // 閬嶅巻璁板綍锛屾壘鍑洪渶瑕佹坊鍔犱腑闂撮〉鍙风殑浣嶇疆
+            for (int i = 0; i < records.size() - 1; i++) {
+                DocumentMaterials currentRecord = records.get(i);
+                DocumentMaterials nextRecord = records.get(i + 1);
+                
+                long currentPage = currentRecord.getPageNumber();
+                long nextPage = nextRecord.getPageNumber();
+                
+                // 濡傛灉褰撳墠椤靛彿鍜屼笅涓�椤靛彿涔嬮棿鏈夐棿闅�
+                if (nextPage - currentPage > 1) {
+                    // 娣诲姞涓棿椤靛彿鐨勮褰曪紝淇℃伅涓庡綋鍓嶈褰曚繚鎸佷竴鑷�
+                    for (long page = currentPage + 1; page < nextPage; page++) {
+                        DocumentMaterials newRecord = new DocumentMaterials();
+                        // 澶嶅埗褰撳墠璁板綍鐨勬墍鏈夊睘鎬�
+                        BeanUtils.copyBeanProp(newRecord, currentRecord);
+                        // 璁剧疆鏂扮殑椤靛彿
+                        newRecord.setPageNumber(page);
+                        // 娓呴櫎ID锛岀‘淇濇槸鏂拌褰�
+                        newRecord.setMaterialId(null);
+                        // 璁剧疆鍒涘缓鏃堕棿
+                        newRecord.setCreatedAt(new Date());
+                        // 閲嶇疆鏂囦欢鏉愭枡搴忓彿涓簄ull锛岃绯荤粺鑷姩鐢熸垚
+                        newRecord.setFileNumber(null);
+                        // 閲嶇疆椤垫涓簄ull锛岃绯荤粺鑷姩鐢熸垚
+                        newRecord.setPageOrder(null);
+                        // 閲嶇疆鍥惧儚鐩稿叧瀛楁锛屼互渚夸笂浼犳枃浠舵椂鏇存柊
+                        newRecord.setSizeType(null);
+                        newRecord.setWidth(null);
+                        newRecord.setHeight(null);
+                        newRecord.setHorizontalResolution(null);
+                        newRecord.setVerticalResolution(null);
+                        newRecord.setFileSize(null);
+                        newRecord.setFormat(null);
+                        newRecord.setUrl(null);
+                        //涓嶅湪鍓嶇鏄剧ず
+                        newRecord.setVisible(0);
+                        // 娣诲姞鍒颁腑闂磋褰曞垪琛�
+                        middleRecords.add(newRecord);
+                    }
+                }
+            }
+            
+            // 澶勭悊鏈�鍚庝竴鏉¤褰曞埌maxPageNumber涔嬮棿鐨勯棿闅�
+            DocumentMaterials lastRecord = records.get(records.size() - 1);
+            long lastPage = lastRecord.getPageNumber();
+            
+            if (maxPageNumber > lastPage) {
+                // 娣诲姞浠巐astPage+1鍒癿axPageNumber涔嬮棿鐨勪腑闂磋褰�
+                for (long page = lastPage + 1; page <= maxPageNumber; page++) {
+                    DocumentMaterials newRecord = new DocumentMaterials();
+                    // 澶嶅埗鏈�鍚庝竴鏉¤褰曠殑鎵�鏈夊睘鎬�
+                    BeanUtils.copyBeanProp(newRecord, lastRecord);
+                    // 璁剧疆鏂扮殑椤靛彿
+                    newRecord.setPageNumber(page);
+                    // 娓呴櫎ID锛岀‘淇濇槸鏂拌褰�
+                    newRecord.setMaterialId(null);
+                    // 璁剧疆鍒涘缓鏃堕棿
+                    newRecord.setCreatedAt(new Date());
+                    // 閲嶇疆鏂囦欢鏉愭枡搴忓彿涓簄ull锛岃绯荤粺鑷姩鐢熸垚
+                    newRecord.setFileNumber(null);
+                    // 閲嶇疆椤垫涓簄ull锛岃绯荤粺鑷姩鐢熸垚
+                    newRecord.setPageOrder(null);
+                    // 閲嶇疆鍥惧儚鐩稿叧瀛楁锛屼互渚夸笂浼犳枃浠舵椂鏇存柊
+                    newRecord.setSizeType(null);
+                    newRecord.setWidth(null);
+                    newRecord.setHeight(null);
+                    newRecord.setHorizontalResolution(null);
+                    newRecord.setVerticalResolution(null);
+                    newRecord.setFileSize(null);
+                    newRecord.setFormat(null);
+                    newRecord.setUrl(null);
+                    // 娣诲姞鍒颁腑闂磋褰曞垪琛�
+                    middleRecords.add(newRecord);
+                }
+            }
+            
+            // 鎵归噺淇濆瓨涓棿璁板綍
+            if (!middleRecords.isEmpty()) {
+                this.saveBatch(middleRecords);
+                return AjaxResult.success("鎴愬姛娣诲姞涓棿璁板綍", "娣诲姞鏁伴噺锛�" + middleRecords.size());
+            } else {
+                return AjaxResult.success("娌℃湁闇�瑕佹坊鍔犵殑涓棿璁板綍");
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+            return AjaxResult.error("娣诲姞涓棿璁板綍澶辫触锛�" + e.getMessage());
+        }
+    }
+
+    @Override
+    public Boolean judgeInfo(int recordId) {
+
+            return  this.baseMapper.judgeArchiveInfo(recordId);
+    }
 }
+
+

--
Gitblit v1.9.1