From 06ddb489776d6d3859238ae89724efc9db8d7e9d Mon Sep 17 00:00:00 2001
From: Houjie <714924425@qq.com>
Date: 星期一, 26 五月 2025 17:35:17 +0800
Subject: [PATCH] 工具报损-审批提交(扣减库存/更新台账状态/更新单据审批状态)

---
 lxzn-module-tms/src/main/java/org/jeecg/modules/tms/service/impl/ToolsLossBoundServiceImpl.java |   73 +++++++++++++++++++++++++++++++++---
 1 files changed, 67 insertions(+), 6 deletions(-)

diff --git a/lxzn-module-tms/src/main/java/org/jeecg/modules/tms/service/impl/ToolsLossBoundServiceImpl.java b/lxzn-module-tms/src/main/java/org/jeecg/modules/tms/service/impl/ToolsLossBoundServiceImpl.java
index 8e3ff5b..534804b 100644
--- a/lxzn-module-tms/src/main/java/org/jeecg/modules/tms/service/impl/ToolsLossBoundServiceImpl.java
+++ b/lxzn-module-tms/src/main/java/org/jeecg/modules/tms/service/impl/ToolsLossBoundServiceImpl.java
@@ -7,6 +7,7 @@
 import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
@@ -25,6 +26,8 @@
 import org.jeecg.modules.flowable.service.IFlowDefinitionService;
 import org.jeecg.modules.flowable.service.IFlowTaskService;
 import org.jeecg.modules.system.service.ISysBusinessCodeRuleService;
+import org.jeecg.modules.tms.entity.ToolLedger;
+import org.jeecg.modules.tms.entity.ToolLedgerDetail;
 import org.jeecg.modules.tms.entity.ToolsLossBound;
 import org.jeecg.modules.tms.entity.ToolsLossBoundDetail;
 import org.jeecg.modules.tms.entity.dto.LossBoundFlowDto;
@@ -32,6 +35,8 @@
 import org.jeecg.modules.tms.enums.OutBoundStatusEnum;
 import org.jeecg.modules.tms.mapper.ToolsLossBoundDetailMapper;
 import org.jeecg.modules.tms.mapper.ToolsLossBoundMapper;
+import org.jeecg.modules.tms.service.IToolLedgerDetailService;
+import org.jeecg.modules.tms.service.IToolLedgerService;
 import org.jeecg.modules.tms.service.IToolsLossBoundDetailService;
 import org.jeecg.modules.tms.service.IToolsLossBoundService;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -39,6 +44,7 @@
 
 import javax.annotation.Resource;
 import java.io.Serializable;
+import java.math.BigDecimal;
 import java.util.*;
 
 /**
@@ -69,6 +75,12 @@
     private IFlowMyBusinessService flowMyBusinessService;
     @Autowired
     private TaskService taskService;
+
+    @Autowired
+    private IToolLedgerService toolLedgerService;
+
+    @Autowired
+    private IToolLedgerDetailService toolLedgerDetailService;
 
     @Override
     public void delMain(String id) {
@@ -125,8 +137,7 @@
     @Override
     public void editTotal(ToolsLossBound toolsLossBound) {
         //鍒犻櫎鎵�鏈夋槑缁�
-        toolsLossBoundDetailService.remove(new LambdaQueryWrapper<ToolsLossBoundDetail>()
-                .eq(ToolsLossBoundDetail::getLossBoundId, toolsLossBound.getId()));
+        toolsLossBoundDetailService.remove(new LambdaQueryWrapper<ToolsLossBoundDetail>().eq(ToolsLossBoundDetail::getLossBoundId, toolsLossBound.getId()));
         ToolsLossBound toolsLossBound1 = BeanUtil.copyProperties(toolsLossBound, ToolsLossBound.class);
         this.baseMapper.updateById(toolsLossBound1);
         List<ToolsLossBoundDetail> detailList = CollectionUtil.newArrayList();
@@ -147,8 +158,7 @@
         } else {
             toolsLossBound.setReviewer(toolsLossBound.getReviewer());
 
-            flowCommonService.initActBusiness("鎶ユ崯鍗曞彿:" + toolsLossBound.getOrderCode() + ";鎶ユ崯浜�: " + toolsLossBound.getLosser() + ";杩涜鎶ユ崯",
-                    toolsLossBound.getId(), "IToolsStocktakingBoundService", "tools_Loss_Approval", null);
+            flowCommonService.initActBusiness("鎶ユ崯鍗曞彿:" + toolsLossBound.getOrderCode() + ";鎶ユ崯浜�: " + toolsLossBound.getLosser() + ";杩涜鎶ユ崯", toolsLossBound.getId(), "IToolsStocktakingBoundService", "tools_Loss_Approval", null);
             Map<String, Object> variables = new HashMap<>();
             variables.put("dataId", toolsLossBound.getId());
             if (StrUtil.isEmpty(toolsLossBound.getReviewer())) {
@@ -220,6 +230,58 @@
             if (OutBillStatus.APPROVED.getValue().equals(lossBoundFlowDto.getStatus())) {
                 toolsLossBound.setOrderStatus(OutBoundStatusEnum.NOT_OUTBOUND.getValue());
             }
+            /**
+             * 鏇存柊瀹℃壒鏃堕棿銆佸鎵规剰瑙� 鏇存柊搴撳瓨鎵e噺 搴撳瓨鎬绘暟
+             * 鑾峰彇宸ュ叿鏄庣粏鍒楄〃锛岄亶鍘嗘瘡涓伐鍏锋槑缁嗭紝鏇存柊瀵瑰簲鐨勫伐鍏峰簱瀛樿褰曘��
+             * 瀵逛簬姣忎釜宸ュ叿锛岃幏鍙栧搴旂殑宸ュ叿搴撳瓨璁板綍锛圱oolLedger锛夛紝骞舵洿鏂版�诲簱瀛樻暟閲忥紙totalCount锛夊拰鎹熷け鏁伴噺锛坙ossCount锛夈��
+             * 纭繚鍦ㄦ洿鏂版�诲簱瀛樻暟閲忎箣鍓嶏紝妫�鏌ユ�诲簱瀛樻暟閲忔槸鍚﹀ぇ浜庢垨绛変簬鎹熷け鏁伴噺銆傚鏋滀笉婊¤冻鏉′欢锛屾姏鍑哄紓甯告垨杩涜鍏朵粬澶勭悊銆�
+             * 鏈�鍚庯紝淇濆瓨鏇存柊鍚庣殑宸ュ叿搴撳瓨璁板綍銆�
+             */
+
+            List<ToolsLossBoundDetail> detailList = toolsLossBound.getToolsLossBoundDetailList();
+
+            if (CollectionUtils.isEmpty(detailList)) {
+                throw new JeecgBootException("鎶ユ崯鏄庣粏涓虹┖锛屾棤娉曡繘琛屽簱瀛樻墸鍑�");
+            }
+            Map<String, BigDecimal> toolLossMap = new HashMap<>();
+            for (ToolsLossBoundDetail item : detailList) {
+                if (item.getToolId() == null || item.getLossNumber() == null) {
+                    continue; //
+                }
+                toolLossMap.put(item.getToolId(), toolLossMap.getOrDefault(item.getToolId(), BigDecimal.ZERO).add(item.getLossNumber()));
+            }
+            /**
+             * 閬嶅巻姣忎釜 toolId锛屾洿鏂板搴旂殑 ToolLedger
+             */
+            for (Map.Entry<String, BigDecimal> entry : toolLossMap.entrySet()) {
+                String toolId = entry.getKey();
+                BigDecimal totalLossNumber = entry.getValue();
+
+                ToolLedger toolLedger = toolLedgerService.getOne(new QueryWrapper<ToolLedger>().eq("id", toolId));
+                if (toolLedger == null) {
+                    throw new JeecgBootException("鏈壘鍒板搴旂殑宸ュ叿搴撳瓨璁板綍锛宼oolId锛�" + toolId);
+                }
+
+                // 鎵e噺鎬诲簱瀛�
+                if (toolLedger.getTotalCount() != null && toolLedger.getTotalCount().compareTo(totalLossNumber) >= 0) {
+                    toolLedger.setTotalCount(toolLedger.getTotalCount().subtract(totalLossNumber));
+                    toolLedger.setLossCount(toolLedger.getLossCount().add(totalLossNumber));
+                } else {
+                    throw new JeecgBootException("搴撳瓨涓嶈冻锛屾棤娉曞畬鎴愭姤鎹熸搷浣滐紝toolId锛�" + toolId);
+                }
+
+                // 鏇存柊鏁版嵁搴撲腑鐨� ToolLedger
+                toolLedgerService.updateById(toolLedger);
+                /**
+                 * 鏂板閫昏緫锛氭洿鏂板彴璐︽槑缁嗚〃 ToolLedgerDetail 涓殑鐘舵�佸瓧娈典负 6
+                 */
+                UpdateWrapper<ToolLedgerDetail> updateWrapper = new UpdateWrapper<>();
+                updateWrapper.eq("tool_id", toolId)
+                        .set("status", 6);         // 鐘舵�佽缃负 6
+
+                toolLedgerDetailService.update(updateWrapper);
+            }
+
             toolsLossBound.setApprovalDate(new Date());
             toolsLossBound.setApprovalOpinion(lossBoundFlowDto.getApprovalOpinion());
             updateById(toolsLossBound);
@@ -239,8 +301,7 @@
     }
 
     private FlowMyBusiness getFlowMyBusiness(String instanceId) {
-        List<FlowMyBusiness> businessList = flowMyBusinessService.list(
-                new LambdaQueryWrapper<FlowMyBusiness>().eq(FlowMyBusiness::getProcessInstanceId, instanceId));
+        List<FlowMyBusiness> businessList = flowMyBusinessService.list(new LambdaQueryWrapper<FlowMyBusiness>().eq(FlowMyBusiness::getProcessInstanceId, instanceId));
         return businessList.isEmpty() ? null : businessList.get(0);
     }
 

--
Gitblit v1.9.3