From 89a782697ae5df39bbb27e896369cd076e4f2c9b Mon Sep 17 00:00:00 2001
From: wujianwei <wjw@11.com>
Date: 星期四, 15 一月 2026 17:14:14 +0800
Subject: [PATCH] 修改bug

---
 service/src/main/java/com/ruoyi/cwgl/service/impl/FundFlowClaimDetailServiceImpl.java |  165 ++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 158 insertions(+), 7 deletions(-)

diff --git a/service/src/main/java/com/ruoyi/cwgl/service/impl/FundFlowClaimDetailServiceImpl.java b/service/src/main/java/com/ruoyi/cwgl/service/impl/FundFlowClaimDetailServiceImpl.java
index 54a98f0..a2d2646 100644
--- a/service/src/main/java/com/ruoyi/cwgl/service/impl/FundFlowClaimDetailServiceImpl.java
+++ b/service/src/main/java/com/ruoyi/cwgl/service/impl/FundFlowClaimDetailServiceImpl.java
@@ -21,11 +21,13 @@
 import com.ruoyi.cwgl.mapper.FundFlowMapper;
 import com.ruoyi.cwgl.domain.FundFlowClaimDetail;
 import com.ruoyi.cwgl.domain.FundFlow;
+import com.ruoyi.cwgl.domain.FundFlowLog;
 import com.ruoyi.cwgl.domain.ReceivableBillSettlementDetail;
 import com.ruoyi.cwgl.domain.PayableBillSettlementDetail;
 import com.ruoyi.cwgl.domain.ReceivableBillManagement;
 import com.ruoyi.cwgl.domain.PayableBillManagement;
 import com.ruoyi.cwgl.service.IFundFlowClaimDetailService;
+import com.ruoyi.cwgl.service.IFundFlowLogService;
 import com.ruoyi.cwgl.service.IReceivableBillSettlementDetailService;
 import com.ruoyi.cwgl.service.IPayableBillSettlementDetailService;
 import com.ruoyi.cwgl.service.IReceivableBillManagementService;
@@ -62,6 +64,9 @@
     
     @Resource
     private IPayableBillManagementService payableBillManagementService;
+    
+    @Resource
+    private IFundFlowLogService fundFlowLogService;
 
 
     /**
@@ -195,9 +200,65 @@
     @Override
     public int deleteFundFlowClaimDetailByIds(Integer[] ids)
     {
-
-
-        return fundFlowClaimDetailMapper.deleteFundFlowClaimDetailByIds(ids);
+        if (ids == null || ids.length == 0) {
+            throw new RuntimeException("鍒犻櫎鐨勮棰嗘槑缁咺D涓嶈兘涓虹┖");
+        }
+        
+        // 鐢变簬鍒犻櫎鍙細鏈変竴鏉¤褰曪紝鍙栫涓�鏉¤繘琛屽鐞�
+        Integer id = ids[0];
+        FundFlowClaimDetail claimDetail = fundFlowClaimDetailMapper.selectFundFlowClaimDetailById(id);
+        if (claimDetail == null) {
+            throw new RuntimeException("鏈壘鍒拌鍒犻櫎鐨勮棰嗘槑缁嗚褰曪紝ID: " + id);
+        }
+        
+        Integer fundFlowId = claimDetail.getFundFlowId();
+        BigDecimal deleteAmount = claimDetail.getClaimAmount();
+        
+        // 鏌ヨ璧勯噾娴佹按淇℃伅
+        FundFlow fundFlow = fundFlowMapper.selectFundFlowById(fundFlowId);
+        if (fundFlow == null) {
+            throw new RuntimeException("璧勯噾娴佹按涓嶅瓨鍦紝ID: " + fundFlowId);
+        }
+        
+        // 鏇存柊璧勯噾娴佹按鐨勫凡璁ら閲戦
+        BigDecimal newClaimedAmount = fundFlow.getClaimedAmount().subtract(deleteAmount);
+        if (newClaimedAmount.compareTo(BigDecimal.ZERO) < 0) {
+            newClaimedAmount = BigDecimal.ZERO;
+        }
+        
+        // 鏍规嵁鏂扮殑璁ら閲戦璁剧疆鐘舵��
+        String newStatus =fundFlow.getStatus();
+        if (newClaimedAmount.compareTo(BigDecimal.ZERO) == 0) {
+            // 宸茶棰嗛噾棰濅负0锛岀姸鎬佹敼涓�1锛堟湭璁ら锛�
+            newStatus = "1";
+        } else if (newClaimedAmount.compareTo(fundFlow.getTransactionAmount()) < 0) {
+            // 宸茶棰嗛噾棰濆皬浜庝氦鏄撻噾棰濓紝鐘舵�佹敼涓�2锛堥儴鍒嗚棰嗭級
+            newStatus = "2";
+        }
+        
+        // 鏇存柊璧勯噾娴佹按鐘舵�佸拰宸茶棰嗛噾棰�
+        fundFlow.setStatus(newStatus);
+        fundFlow.setClaimedAmount(newClaimedAmount);
+        fundFlow.setUpdateTime(DateUtils.getNowDate());
+        int updateResult = fundFlowMapper.updateFundFlow(fundFlow);
+        if (updateResult <= 0) {
+            throw new RuntimeException("鏇存柊璧勯噾娴佹按鐘舵�佸け璐ワ紝ID: " + fundFlowId);
+        }
+        
+        // 鍒犻櫎缁撶畻鏄庣粏骞舵洿鏂拌处鍗曠姸鎬�
+        deleteSettlementDetailsAndUpdateBillStatus(claimDetail,fundFlow);
+        
+        int result = fundFlowClaimDetailMapper.deleteFundFlowClaimDetailByIds(ids);
+        
+        // 璁板綍鎿嶄綔鏃ュ織
+        if (result > 0) {
+            FundFlowLog log = new FundFlowLog();
+            log.setFlowId(fundFlowId);
+            log.setOperation("鍒犻櫎璐﹀崟璁ら鏄庣粏锛岃处鍗曠紪鍙凤細" + claimDetail.getBillNo() + "锛岃棰嗛噾棰濓細" + deleteAmount + "锛岃祫閲戞祦姘村彿锛�" + fundFlow.getBankFlowNo());
+            fundFlowLogService.insertFundFlowLog(log);
+        }
+        
+        return result;
     }
 
     /**
@@ -268,9 +329,14 @@
         
         // 鏂板锛氬垱寤虹粨绠楁槑缁嗗苟鏇存柊璐﹀崟鐘舵��
         if (insertResult > 0) {
-
             
             createSettlementDetailsAndUpdateBillStatus(claimDetail, fundFlow);
+            
+            // 璁板綍鎿嶄綔鏃ュ織
+            FundFlowLog log = new FundFlowLog();
+            log.setFlowId(fundFlowId);
+            log.setOperation("鏂板璐﹀崟璁ら鏄庣粏锛岃处鍗曠紪鍙凤細" + claimDetail.getBillNo() + "锛岃棰嗛噾棰濓細" + claimAmount + "锛岃祫閲戞祦姘村彿锛�" + fundFlow.getBankFlowNo());
+            fundFlowLogService.insertFundFlowLog(log);
         }
         
         return insertResult;
@@ -326,7 +392,7 @@
             BigDecimal claimAmount = claimDetail.getClaimAmount();
             Integer claimDetailId = claimDetail.getId();
             
-            // 鏍规嵁鍏宠仈浼佷笟绫诲瀷鍒ゆ柇鏄簲鏀惰处鍗曡繕鏄簲浠樿处鍗�
+            // 鏍规嵁鏀舵敮鏍囪瘑鍊熻捶鏍囧織鍒ゆ柇鏄簲鏀惰处鍗曡繕鏄簲浠樿处鍗�
             if (fundFlow.getIncomeExpenseFlag().equals(0)) {
                 // 搴旀敹璐﹀崟
                 createReceivableSettlementDetail(billNo, claimAmount, fundFlow, claimDetailId);
@@ -351,7 +417,14 @@
                 settlementDetail.setClaimDetailId(claimDetailId); // 璁剧疆璁ら鏄庣粏ID
                 settlementDetail.setReceiptAmount(claimAmount);
                 settlementDetail.setReceiptDate(fundFlow.getTransactionDate());
-                settlementDetail.setSettlementMethod("閾惰杞处"); // 鏍规嵁瀹為檯鎯呭喌璁剧疆
+                settlementDetail.setSettlementMethod("0"); // 鏍规嵁瀹為檯鎯呭喌璁剧疆
+                
+                // 璁剧疆閾惰璐︽埛淇℃伅
+                settlementDetail.setCustomerBank(fundFlow.getOurBankName()); // 瀹㈡埛寮�鎴疯锛堟湰鏂硅处鎴峰紑鎴疯锛�
+                settlementDetail.setCustomerBankAccount(fundFlow.getOurAccount()); // 瀹㈡埛閾惰璐﹀彿锛堟湰鏂硅处鍙凤級
+                settlementDetail.setReceivingBank(fundFlow.getCounterpartyName()); // 鏀舵璐︽埛寮�鎴疯锛堝鏂规埛鍚嶏級
+                settlementDetail.setReceivingBankAccount(fundFlow.getCounterpartyAccount()); // 鏀舵閾惰璐﹀彿锛堝鏂硅处鍙凤級
+                
                 settlementDetail.setCreateBy(SecurityUtils.getUsername());
                 settlementDetail.setCreateTime(DateUtils.getNowDate());
                 
@@ -382,7 +455,14 @@
                 settlementDetail.setClaimDetailId(claimDetailId); // 璁剧疆璁ら鏄庣粏ID
                 settlementDetail.setPaymentAmount(claimAmount);
                 settlementDetail.setPaymentDate(fundFlow.getTransactionDate());
-                settlementDetail.setSettlementMethod("閾惰杞处"); // 鏍规嵁瀹為檯鎯呭喌璁剧疆
+                settlementDetail.setSettlementMethod("0"); // 鏍规嵁瀹為檯鎯呭喌璁剧疆
+                
+                // 璁剧疆閾惰璐︽埛淇℃伅
+                settlementDetail.setPaymentBank(fundFlow.getOurBankName()); // 浠樻璐︽埛寮�鎴疯锛堟湰鏂硅处鎴峰紑鎴疯锛�
+                settlementDetail.setPaymentBankAccount(fundFlow.getOurAccount()); // 浠樻璐︽埛閾惰璐﹀彿锛堟湰鏂硅处鍙凤級
+                settlementDetail.setSupplierReceivingBank(fundFlow.getCounterpartyName()); // 渚涘簲鍟嗘敹娆捐处鎴峰紑鎴疯锛堝鏂规埛鍚嶏級
+                settlementDetail.setSupplierReceivingAccount(fundFlow.getCounterpartyAccount()); // 渚涘簲鍟嗘敹娆鹃摱琛岃处鎴凤紙瀵规柟璐﹀彿锛�
+                
                 settlementDetail.setCreateBy(SecurityUtils.getUsername());
                 settlementDetail.setCreateTime(DateUtils.getNowDate());
                 
@@ -399,5 +479,76 @@
         }
     }
     
+    /**
+     * 鍒犻櫎缁撶畻鏄庣粏骞舵洿鏂拌处鍗曠姸鎬�
+     */
+    private void deleteSettlementDetailsAndUpdateBillStatus(FundFlowClaimDetail claimDetail, FundFlow fundFlow) {
+        String billNo = claimDetail.getBillNo();
+        Integer claimDetailId = claimDetail.getId();
+        
+        try {
+
+            
+            // 鏍规嵁鏀舵敮鏍囪瘑鍊熻捶鏍囧織鍒ゆ柇鏄簲鏀惰处鍗曡繕鏄簲浠樿处鍗�
+            if (fundFlow.getIncomeExpenseFlag().equals(0)) {
+                // 搴旀敹璐﹀崟
+                deleteReceivableSettlementDetail(claimDetailId);
+            } else {
+                // 搴斾粯璐﹀崟
+                deletePayableSettlementDetail(claimDetailId);
+            }
+            
+            logger.info("鎴愬姛鍒犻櫎缁撶畻鏄庣粏锛岃棰嗘槑缁咺D锛歿}", claimDetailId);
+        } catch (Exception e) {
+            logger.error("鍒犻櫎缁撶畻鏄庣粏澶辫触锛岃棰嗘槑缁咺D锛歿}", claimDetailId, e);
+            // 杩欓噷鍙互閫夋嫨鎶涘嚭寮傚父鎴栬褰曟棩蹇楋紝浣嗕笉涓柇鏁翠釜鍒犻櫎娴佺▼
+        }
+    }
+    
+    /**
+     * 鍒犻櫎搴旀敹璐﹀崟缁撶畻鏄庣粏
+     */
+    private void deleteReceivableSettlementDetail(Integer claimDetailId) {
+        try {
+            // 鏍规嵁璁ら鏄庣粏ID鏌ヨ搴旀敹璐﹀崟缁撶畻鏄庣粏
+            ReceivableBillSettlementDetail receivableQuery = new ReceivableBillSettlementDetail();
+            receivableQuery.setClaimDetailId(claimDetailId);
+            List<ReceivableBillSettlementDetail> receivableDetails = receivableBillSettlementDetailService.selectReceivableBillSettlementDetailList(receivableQuery);
+            
+            if (!receivableDetails.isEmpty()) {
+                Integer[] receivableIds = receivableDetails.stream()
+                        .map(ReceivableBillSettlementDetail::getId)
+                        .toArray(Integer[]::new);
+                receivableBillSettlementDetailService.deleteReceivableBillSettlementDetailByIds(receivableIds);
+                logger.info("鎴愬姛鍒犻櫎搴旀敹璐﹀崟缁撶畻鏄庣粏锛岃棰嗘槑缁咺D锛歿}", claimDetailId);
+            }
+        } catch (Exception e) {
+            logger.error("鍒犻櫎搴旀敹璐﹀崟缁撶畻鏄庣粏澶辫触锛岃棰嗘槑缁咺D锛歿}", claimDetailId, e);
+            throw e;
+        }
+    }
+    
+    /**
+     * 鍒犻櫎搴斾粯璐﹀崟缁撶畻鏄庣粏
+     */
+    private void deletePayableSettlementDetail(Integer claimDetailId) {
+        try {
+            // 鏍规嵁璁ら鏄庣粏ID鏌ヨ搴斾粯璐﹀崟缁撶畻鏄庣粏
+            PayableBillSettlementDetail payableQuery = new PayableBillSettlementDetail();
+            payableQuery.setClaimDetailId(claimDetailId);
+            List<PayableBillSettlementDetail> payableDetails = payableBillSettlementDetailService.selectPayableBillSettlementDetailList(payableQuery);
+            
+            if (!payableDetails.isEmpty()) {
+                Integer[] payableIds = payableDetails.stream()
+                        .map(PayableBillSettlementDetail::getId)
+                        .toArray(Integer[]::new);
+                payableBillSettlementDetailService.deletePayableBillSettlementDetailByIds(payableIds);
+                logger.info("鎴愬姛鍒犻櫎搴斾粯璐﹀崟缁撶畻鏄庣粏锛岃棰嗘槑缁咺D锛歿}", claimDetailId);
+            }
+        } catch (Exception e) {
+            logger.error("鍒犻櫎搴斾粯璐﹀崟缁撶畻鏄庣粏澶辫触锛岃棰嗘槑缁咺D锛歿}", claimDetailId, e);
+            throw e;
+        }
+    }
 
 }

--
Gitblit v1.8.0