From 71fba5328a35b449b11088e540932787220f91d8 Mon Sep 17 00:00:00 2001
From: liding <756868258@qq.com>
Date: 星期三, 18 六月 2025 17:28:50 +0800
Subject: [PATCH] 1.生产加工变更库存回滚 2.巡检,档案上传完善

---
 main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java |  112 ++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 108 insertions(+), 4 deletions(-)

diff --git a/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java b/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java
index 84bed74..0a9dcc1 100644
--- a/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java
+++ b/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java
@@ -2,6 +2,7 @@
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.business.dto.ProductionMasterDto;
@@ -14,16 +15,16 @@
 import com.ruoyi.business.mapper.ProductionMapper;
 import com.ruoyi.business.mapper.ProductionMasterMapper;
 import com.ruoyi.business.service.ProductionMasterService;
+import com.ruoyi.common.core.domain.entity.SysUser;
 import com.ruoyi.common.exception.base.BaseException;
 import com.ruoyi.common.utils.bean.BeanUtils;
+import com.ruoyi.system.mapper.SysUserMapper;
 import lombok.RequiredArgsConstructor;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
-import java.util.Collections;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 import java.util.stream.Collectors;
 
 /**
@@ -45,6 +46,8 @@
     private final ProductionMapper productionMapper;
 
     private final OfficialInventoryMapper officialInventoryMapper;
+
+    private final SysUserMapper sysUserMapper;
 
     @Override
     public IPage<ProductionMasterDto> selectPMList(Page page, ProductionMasterDto productionMasterDto) {
@@ -153,6 +156,12 @@
         productionMaster.setId(masterId);
 
         // 3. 缁熶竴瀛愯〃澶勭悊閫昏緫
+        Long producerId = productionMasterDto.getProducerId();
+        if (producerId == null) {
+            throw new BaseException("璇烽�夋嫨鐢熶骇鑰�");
+        }
+        SysUser sysUser = sysUserMapper.selectUserById(producerId);
+        productionMaster.setProducer(sysUser.getUserName());
         if (masterId == null) {
             productionMasterMapper.insert(productionMaster);
             masterId = productionMaster.getId(); // 鑾峰彇鏂扮敓鎴愮殑ID
@@ -221,7 +230,102 @@
     }
 
     @Override
+    @Transactional(rollbackFor = Exception.class)
     public int delByIds(Long[] ids) {
-        return 0;
+        if (ids == null || ids.length == 0) {
+            return 0;
+        }
+
+        List<Long> idList = Arrays.asList(ids);
+
+        // 1. 棰勫姞杞芥墍鏈夊叧鑱旀暟鎹�
+        List<ProductionInventory> allInventoryList = productionInventoryMapper.selectList(
+                new LambdaQueryWrapper<ProductionInventory>()
+                        .in(ProductionInventory::getProductionMasterId, idList)
+        );
+
+        // 2. 鎸夊畼鏂瑰簱瀛業D鍒嗙粍骞惰绠楀簱瀛樿皟鏁撮噺
+        Map<Long, BigDecimal> inventoryAdjustMap = allInventoryList.stream()
+                .collect(Collectors.groupingBy(
+                        ProductionInventory::getOfficialId,
+                        Collectors.reducing(
+                                BigDecimal.ZERO,
+                                inv -> new BigDecimal(inv.getUsedQuantity()),
+                                BigDecimal::add
+                        )
+                ));
+
+        // 3. 鎵归噺鏇存柊瀹樻柟搴撳瓨 (浣跨敤SQL鐩存帴鏇存柊)
+        if (!inventoryAdjustMap.isEmpty()) {
+            inventoryAdjustMap.forEach((officialId, adjustAmount) ->
+                    officialInventoryMapper.addInventoryQuantity(officialId, adjustAmount)
+            );
+        }
+
+        // 4. 鎵归噺鍒犻櫎鍏宠仈鏁版嵁
+        if (!allInventoryList.isEmpty()) {
+            List<Long> inventoryIds = allInventoryList.stream()
+                    .map(ProductionInventory::getId)
+                    .collect(Collectors.toList());
+            productionInventoryMapper.deleteBatchIds(inventoryIds);
+        }
+
+        // 鍒犻櫎鐢熶骇鏄庣粏
+        productionMapper.delete(
+                new LambdaQueryWrapper<Production>()
+                        .in(Production::getProductionMasterId, idList)
+        );
+
+        // 5. 鍒犻櫎涓昏褰�
+        return productionMasterMapper.deleteBatchIds(idList);
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public int deleteProductionInventory(ProductionMasterDto productionMasterDto) {
+        List<ProductionInventory> inventories = productionMasterDto.getProductionInventoryList();
+        if (CollectionUtils.isEmpty(inventories)) {
+            return 0;
+        }
+
+        // 棰勬敹闆嗘暟鎹敤浜庢壒閲忔搷浣�
+        Map<Long, BigDecimal> inventoryAdjustMap = new HashMap<>();
+        List<Long> productionIdsToDelete = new ArrayList<>(inventories.size());
+
+        for (ProductionInventory inventory : inventories) {
+            // 鏀堕泦闇�瑕佸垹闄ょ殑鐢熶骇搴撳瓨ID
+            productionIdsToDelete.add(inventory.getId());
+
+            // 绱搴撳瓨璋冩暣閲忥紙鐩稿悓officialId鐨勭敤閲忕疮鍔狅級
+            BigDecimal adjustment = new BigDecimal(inventory.getUsedQuantity());
+            inventoryAdjustMap.merge(
+                    inventory.getOfficialId(),
+                    adjustment,
+                    BigDecimal::add
+            );
+        }
+
+        // 鎵归噺鏇存柊瀹樻柟搴撳瓨
+        for (Map.Entry<Long, BigDecimal> entry : inventoryAdjustMap.entrySet()) {
+            OfficialInventory official = officialInventoryMapper.selectById(entry.getKey());
+            if (official == null) {
+                throw new BaseException("瀹樻柟搴撳瓨涓嶅瓨鍦紝ID: " + entry.getKey());
+            }
+
+            // 浣跨敤绾跨▼瀹夊叏鐨凚igDecimal鎿嶄綔
+            official.setInventoryQuantity(
+                    Optional.ofNullable(official.getInventoryQuantity())
+                            .orElse(BigDecimal.ZERO)
+                            .add(entry.getValue())
+            );
+            officialInventoryMapper.updateById(official);
+        }
+
+        // 鎵归噺鍒犻櫎鐢熶骇搴撳瓨
+        if (!productionIdsToDelete.isEmpty()) {
+            productionInventoryMapper.deleteBatchIds(productionIdsToDelete);
+        }
+
+        return productionIdsToDelete.size();
     }
 }

--
Gitblit v1.9.3