From 9d5128803ebebb5788f13924a5775ac16494dfef Mon Sep 17 00:00:00 2001
From: yaowanxin <3588231647@qq.com>
Date: 星期一, 18 八月 2025 10:05:05 +0800
Subject: [PATCH] 仓库,树,文档,借出修改

---
 src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java |   98 ++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 92 insertions(+), 6 deletions(-)

diff --git a/src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java b/src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java
index 2f793a1..05a075e 100644
--- a/src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java
+++ b/src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java
@@ -1,18 +1,26 @@
 package com.ruoyi.warehouse.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.common.utils.poi.ExcelUtil;
-import com.ruoyi.procurementrecord.dto.ProcurementRecordOutPageDto;
+import com.ruoyi.warehouse.dto.DocumentationBorrowManagementDto;
+import com.ruoyi.warehouse.dto.ReturnExportDto;
+import com.ruoyi.warehouse.pojo.Documentation;
 import com.ruoyi.warehouse.pojo.DocumentationBorrowManagement;
 import com.ruoyi.warehouse.service.DocumentationBorrowManagementService;
 import com.ruoyi.warehouse.mapper.DocumentationBorrowManagementMapper;
+import com.ruoyi.warehouse.service.DocumentationService;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 
 import javax.servlet.http.HttpServletResponse;
+import java.time.LocalDateTime;
 import java.util.List;
+import java.util.stream.Collectors;
 
 /**
 * @author 86151
@@ -20,22 +28,100 @@
 * @createDate 2025-08-14 15:55:45
 */
 @Service
+@Transactional(rollbackFor = Exception.class)
 public class DocumentationBorrowManagementServiceImpl extends ServiceImpl<DocumentationBorrowManagementMapper, DocumentationBorrowManagement>
     implements DocumentationBorrowManagementService{
     @Autowired
     private DocumentationBorrowManagementMapper documentationBorrowManagementMapper;
+    @Autowired
+    private DocumentationService documentationService;
     @Override
     public IPage<DocumentationBorrowManagement> listPage(Page page, DocumentationBorrowManagement documentationBorrowManagement) {
+        IPage<DocumentationBorrowManagement> listPage = documentationBorrowManagementMapper.listPage(page, documentationBorrowManagement);
+        return listPage;
+    }
 
-        return null;
+
+    @Override
+    public boolean add(DocumentationBorrowManagement documentationBorrowManagement) {
+        documentationBorrowManagementMapper.insert(documentationBorrowManagement);
+        Documentation documentation = documentationService.getById(documentationBorrowManagement.getDocumentationId());
+        documentation.setDocStatus("鍊熷嚭");
+        documentationService.updateById(documentation);
+        return true;
+    }
+    @Override
+    public boolean reventdbm(DocumentationBorrowManagement documentationBorrowManagement) {
+        DocumentationBorrowManagement documentationBorrowManagement1 = new DocumentationBorrowManagement();
+        // 鏇存柊鍊熼槄璁板綍鐘舵�佷负褰掕繕
+        documentationBorrowManagement1.setBorrowStatus("褰掕繕");
+        documentationBorrowManagement1.setReturnDate(LocalDateTime.now());
+        documentationBorrowManagementMapper.updateById(documentationBorrowManagement1);
+        documentationBorrowManagementMapper.update(documentationBorrowManagement1,new LambdaQueryWrapper<DocumentationBorrowManagement>().eq(DocumentationBorrowManagement::getId,documentationBorrowManagement.getId()));
+
+        // 鏇存柊鏂囨。鐘舵�佷负姝e父
+        Documentation documentation = documentationService.getById(documentationBorrowManagement.getDocumentationId());
+        documentation.setDocStatus("姝e父");
+        documentationService.updateById(documentation);
+        return true;
     }
 
     @Override
-    public void export(HttpServletResponse response) {
-//        List<DocumentationBorrowManagement> list =documentationBorrowManagementMapper.list();
-//        ExcelUtil<DocumentationBorrowManagement> util = new ExcelUtil<>(DocumentationBorrowManagement.class);
-//        util.exportExcel(response, list, "鏂囨。鍊熼槄-褰掕繕璁板綍");
+    public boolean reventDeleteByIds(List<Long> ids) {
+        QueryWrapper<DocumentationBorrowManagement> queryWrapper = new QueryWrapper<>();
+        queryWrapper.in("id", ids);
+        queryWrapper.eq("borrow_status", "褰掕繕");
+        List<DocumentationBorrowManagement> list = documentationBorrowManagementMapper.selectList(queryWrapper);
+        for (DocumentationBorrowManagement documentationBorrowManagement : list) {
+            try {
+                documentationBorrowManagement.setBorrowStatus("鍊熼槄");
+                documentationBorrowManagement.setReturnDate(null);
+                documentationBorrowManagementMapper.updateById(documentationBorrowManagement);
+
+                Documentation documentation = documentationService.getById(documentationBorrowManagement.getDocumentationId());
+                if (documentation != null) {
+                    documentation.setDocStatus("鍊熷嚭");
+                    documentationService.updateById(documentation);
+                }
+            } catch (Exception e) {
+                throw new RuntimeException("鏇存柊鍊熼槄璁板綍鍜屾枃妗g姸鎬佹椂鍑洪敊", e);
+            }
+        }
+        return true;
     }
+
+    @Override
+    public void export(HttpServletResponse response, DocumentationBorrowManagement documentationBorrowManagement) {
+        List<DocumentationBorrowManagementDto> documentationBorrowManagements = documentationBorrowManagementMapper.export(documentationBorrowManagement);
+        ExcelUtil<DocumentationBorrowManagementDto> util = new ExcelUtil<>(DocumentationBorrowManagementDto.class);
+        util.exportExcel(response, documentationBorrowManagements, "鏂囨。鍊熼槄-鍊熼槄璁板綍");
+    }
+
+    @Override
+    public void exportrevent(HttpServletResponse response, DocumentationBorrowManagement documentationBorrowManagement) {
+        List<ReturnExportDto> documentationBorrowManagements = documentationBorrowManagementMapper.exportrevent(documentationBorrowManagement);
+        ExcelUtil<ReturnExportDto> util = new ExcelUtil<>(ReturnExportDto.class);
+        util.exportExcel(response, documentationBorrowManagements, "鏂囨。鍊熼槄-褰掕繕璁板綍");
+    }
+
+    @Override
+    public boolean deleteByIds(List<Long> ids) {
+        List<DocumentationBorrowManagement> list = documentationBorrowManagementMapper.selectList(new LambdaQueryWrapper<DocumentationBorrowManagement>().in(DocumentationBorrowManagement::getId, ids));
+        for (DocumentationBorrowManagement documentationBorrowManagement : list) {
+            Documentation documentation = documentationService.getById(documentationBorrowManagement.getDocumentationId());
+            documentation.setDocStatus("姝e父");
+            boolean b = documentationService.updateById(documentation);
+            if (!b){
+                throw new RuntimeException("鏇存柊鏂囨。鐘舵�佸け璐�");
+            }
+        }
+        documentationBorrowManagementMapper.deleteBatchIds(ids);
+        return true;
+    }
+
+
+
+
 }
 
 

--
Gitblit v1.9.3