From c383c8ca7053005ffa3ee58efd89956fbf52c9ea Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期四, 07 五月 2026 11:34:19 +0800
Subject: [PATCH] 重构客户档案

---
 src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java |  157 ++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 139 insertions(+), 18 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..73e9ab2 100644
--- a/src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java
+++ b/src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java
@@ -1,41 +1,162 @@
 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.pojo.DocumentationBorrowManagement;
-import com.ruoyi.warehouse.service.DocumentationBorrowManagementService;
+import com.ruoyi.warehouse.dto.DocumentationBorrowManagementDto;
+import com.ruoyi.warehouse.dto.ReturnExportDto;
 import com.ruoyi.warehouse.mapper.DocumentationBorrowManagementMapper;
-import org.springframework.beans.factory.annotation.Autowired;
+import com.ruoyi.warehouse.mapper.DocumentationReturnManagementMapper;
+import com.ruoyi.warehouse.pojo.Documentation;
+import com.ruoyi.warehouse.pojo.DocumentationBorrowManagement;
+import com.ruoyi.warehouse.pojo.DocumentationReturnManagement;
+import com.ruoyi.warehouse.service.DocumentationBorrowManagementService;
+import com.ruoyi.warehouse.service.DocumentationService;
+import jakarta.servlet.http.HttpServletResponse;
+import lombok.RequiredArgsConstructor;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 
-import javax.servlet.http.HttpServletResponse;
+import java.time.LocalDate;
 import java.util.List;
 
 /**
-* @author 86151
-* @description 閽堝琛ㄣ�恉ocumentation_borrow_management(鏂囨。鍊熼槄-褰掕繕琛�)銆戠殑鏁版嵁搴撴搷浣淪ervice瀹炵幇
-* @createDate 2025-08-14 15:55:45
-*/
+ * @author 86151
+ * @description 閽堝琛ㄣ�恉ocumentation_borrow_management(鏂囨。鍊熼槄-褰掕繕琛�)銆戠殑鏁版嵁搴撴搷浣淪ervice瀹炵幇
+ * @createDate 2025-08-14 15:55:45
+ */
 @Service
+@Transactional(rollbackFor = Exception.class)
+@RequiredArgsConstructor
 public class DocumentationBorrowManagementServiceImpl extends ServiceImpl<DocumentationBorrowManagementMapper, DocumentationBorrowManagement>
-    implements DocumentationBorrowManagementService{
-    @Autowired
-    private DocumentationBorrowManagementMapper documentationBorrowManagementMapper;
-    @Override
+        implements DocumentationBorrowManagementService {
+
+    private final DocumentationBorrowManagementMapper documentationBorrowManagementMapper;
+    private final DocumentationReturnManagementMapper documentationReturnManagementMapper;
+    private final DocumentationService documentationService;
+
     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) {
+        documentationBorrowManagement.setBorrowStatus("鍊熼槄");
+        documentationBorrowManagementMapper.insert(documentationBorrowManagement);
+        Documentation documentation = documentationService.getById(documentationBorrowManagement.getDocumentationId());
+        documentation.setDocStatus("鍊熷嚭");
+        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 reventdbm(DocumentationReturnManagement documentationReturnManagement) {
+        // 鏇存柊鍊熼槄璁板綍鐘舵�佷负褰掕繕
+        DocumentationBorrowManagement documentationBorrowManagement1 = documentationBorrowManagementMapper.selectById(documentationReturnManagement.getBorrowId());
+
+        DocumentationReturnManagement returnManagement = new DocumentationReturnManagement();
+        returnManagement.setDocumentationId(documentationBorrowManagement1.getDocumentationId());
+        returnManagement.setBorrower(documentationBorrowManagement1.getBorrower());
+        returnManagement.setBorrowPurpose(documentationBorrowManagement1.getBorrowPurpose());
+        returnManagement.setBorrowDate(documentationBorrowManagement1.getBorrowDate());
+        returnManagement.setDueReturnDate(documentationBorrowManagement1.getDueReturnDate());
+        returnManagement.setBorrowStatus("褰掕繕");
+        returnManagement.setBorrowId(documentationReturnManagement.getBorrowId());
+        returnManagement.setReturner(documentationReturnManagement.getReturner());
+        returnManagement.setReturnDate(LocalDate.now());
+        returnManagement.setRemark(documentationReturnManagement.getRemark());
+
+        documentationReturnManagementMapper.insert(returnManagement);
+        documentationBorrowManagement1.setBorrowStatus("褰掕繕");
+        documentationBorrowManagement1.setReturner(documentationReturnManagement.getReturner());
+        documentationBorrowManagement1.setReturnDate(LocalDate.now());
+        documentationBorrowManagementMapper.updateById(documentationBorrowManagement1);
+        // 鏇存柊鏂囨。鐘舵�佷负姝e父
+        Documentation documentation = documentationService.getById(documentationBorrowManagement1.getDocumentationId());
+        documentation.setDocStatus("姝e父");
+        documentationService.updateById(documentation);
+        return true;
     }
+
+    @Override
+    public boolean reventDeleteByIds(List<Long> ids) {
+        QueryWrapper<DocumentationReturnManagement> queryWrapper = new QueryWrapper<>();
+        queryWrapper.in("id", ids);
+//        queryWrapper.eq("borrow_status", "褰掕繕");
+        List<DocumentationReturnManagement> list = documentationReturnManagementMapper.selectList(queryWrapper);
+
+        for (DocumentationReturnManagement documentationReturnManagement : list) {
+
+            try {
+                documentationReturnManagementMapper.deleteById(documentationReturnManagement);
+                DocumentationBorrowManagement documentationBorrowManagement = documentationBorrowManagementMapper.selectById(documentationReturnManagement.getBorrowId());
+                documentationBorrowManagement.setBorrowStatus("鍊熼槄");
+                documentationBorrowManagement.setReturner(null);
+                documentationBorrowManagement.setReturnDate(null);
+                documentationBorrowManagementMapper.updateById(documentationBorrowManagement);
+
+                Documentation documentation = documentationService.getById(documentationReturnManagement.getDocumentationId());
+                documentation.setDocStatus("鍊熷嚭");
+                documentationService.updateById(documentation);
+            } catch (Exception e) {
+                throw new RuntimeException("鍒犻櫎褰掕繕璁板綍鍜屾枃妗g姸鎬佹椂鍑洪敊", e);
+            }
+        }
+//        documentationReturnManagementMapper.deleteBatchIds(ids);
+        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, DocumentationReturnManagement documentationReturnManagement) {
+        List<ReturnExportDto> documentationReturnManagements = documentationReturnManagementMapper.exportrevent(documentationReturnManagement);
+        ExcelUtil<ReturnExportDto> util = new ExcelUtil<>(ReturnExportDto.class);
+        util.exportExcel(response, documentationReturnManagements, "鏂囨。鍊熼槄-褰掕繕璁板綍");
+    }
+
+    @Override
+    public List<DocumentationBorrowManagementDto> listAll() {
+        return documentationBorrowManagementMapper.list(new LambdaQueryWrapper<DocumentationBorrowManagementDto>().eq(DocumentationBorrowManagementDto::getBorrowStatus, "鍊熼槄"));
+    }
+
+    @Override
+    public List<DocumentationBorrowManagementDto> selectByDocumentationId(Long id) {
+        List<DocumentationBorrowManagementDto> list = documentationBorrowManagementMapper.list(new LambdaQueryWrapper<DocumentationBorrowManagementDto>()
+                .eq(DocumentationBorrowManagementDto::getDocumentationId, id)
+                .eq(DocumentationBorrowManagementDto::getBorrowStatus, "鍊熼槄"));
+        if (list.isEmpty()) {
+            throw new RuntimeException("鏂囨。鏈鍊熼槄");
+        }
+        return list;
+    }
+
+    @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