From 6c8082f57b73967a34396f1eccff2943460e2004 Mon Sep 17 00:00:00 2001
From: liyong <18434998025@163.com>
Date: 星期四, 15 一月 2026 17:04:32 +0800
Subject: [PATCH] feat(product): 生产出库和入库接口

---
 src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java |   99 ++++++++++++++++++++++++++++++-------------------
 1 files changed, 60 insertions(+), 39 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
index 2664ea8..9722fb3 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
@@ -2,6 +2,7 @@
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -12,6 +13,9 @@
 import com.ruoyi.basic.pojo.ProductModel;
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.bean.BeanUtils;
+import com.ruoyi.procurementrecord.mapper.ProcurementRecordOutMapper;
+import com.ruoyi.procurementrecord.pojo.ProcurementRecordOut;
+import com.ruoyi.procurementrecord.utils.StockUtils;
 import com.ruoyi.production.controller.ProductWorkOrderController;
 import com.ruoyi.production.dto.ProductStructureDto;
 import com.ruoyi.production.dto.ProductionProductMainDto;
@@ -25,6 +29,7 @@
 import com.ruoyi.quality.pojo.QualityInspect;
 import com.ruoyi.quality.pojo.QualityInspectParam;
 import com.ruoyi.quality.pojo.QualityTestStandard;
+import io.swagger.models.auth.In;
 import lombok.AllArgsConstructor;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -32,7 +37,10 @@
 
 import java.math.BigDecimal;
 import java.time.LocalDate;
+import java.time.LocalDateTime;
+import java.time.LocalTime;
 import java.time.format.DateTimeFormatter;
+import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
 
@@ -40,6 +48,7 @@
 @AllArgsConstructor
 public class ProductionProductMainServiceImpl extends ServiceImpl<ProductionProductMainMapper, ProductionProductMain> implements ProductionProductMainService {
 
+    private final ProcurementRecordOutMapper procurementRecordOutMapper;
     private ProductionProductMainMapper productionProductMainMapper;
 
     private ProductWorkOrderController productWorkOrderController;
@@ -72,6 +81,8 @@
 
     private SalesLedgerProductionAccountingMapper salesLedgerProductionAccountingMapper;
 
+    private StockUtils stockUtils;
+
 
     @Override
     public IPage<ProductionProductMainDto> listPageProductionProductMainDto(Page page, ProductionProductMainDto productionProductMainDto) {
@@ -87,34 +98,6 @@
 
         SysUser user = SecurityUtils.getLoginUser().getUser();
 
-        if (dto.isReportWork()) {
-            // 鏇存柊閫昏緫 - 鍙洿鏂版暟閲�
-            QueryWrapper<ProductionProductOutput> outputWrapper = new QueryWrapper<>();
-            outputWrapper.eq("product_main_id", dto.getProductMainId());
-
-            ProductionProductOutput output = productionProductOutputMapper.selectOne(outputWrapper);
-            if (output == null) {
-                throw new RuntimeException("浜у嚭璁板綍涓嶅瓨鍦�");
-            }
-
-            // 鏌ヨ鐢熶骇鏍哥畻璁板綍
-            QueryWrapper<SalesLedgerProductionAccounting> accountingWrapper = new QueryWrapper<>();
-            accountingWrapper.eq("sales_ledger_work_id", dto.getProductMainId());
-            SalesLedgerProductionAccounting accounting = salesLedgerProductionAccountingMapper.selectOne(accountingWrapper);
-            if (accounting == null) {
-                throw new RuntimeException("鐢熶骇鏍哥畻璁板綍涓嶅瓨鍦�");
-            }
-
-            // 鍙洿鏂版暟閲�
-            if (dto.getQuantity() != null) {
-                output.setQuantity(dto.getQuantity());
-                productionProductOutputMapper.updateById(output);
-                // 鏇存柊鐢熶骇鏍哥畻璁板綍
-                accounting.setFinishedNum(dto.getQuantity());
-                salesLedgerProductionAccountingMapper.updateById(accounting);
-            }
-            return true;
-        }
 
         // 鏂板閫昏緫
         ProductionProductMain productionProductMain = new ProductionProductMain();
@@ -159,18 +142,18 @@
         productionProductMain.setProductProcessRouteItemId(dto.getProductProcessRouteItemId());
         productionProductMain.setWorkOrderId(dto.getWorkOrderId());
         productionProductMain.setStatus(0);
-
         // 娣诲姞鎶ュ伐涓昏〃
         int insert = productionProductMainMapper.insert(productionProductMain);
 
         //鏇存柊宸ュ崟
         if (insert > 0) {
-            UpdateWrapper<ProductWorkOrder> wrapper = new UpdateWrapper<>();
-            wrapper.set("report_work", true)
-                    .set("quantity", dto.getQuantity())
-                    .set("product_main_id", productionProductMain.getId())
-                    .eq("id", dto.getWorkOrderId());
-            productWorkOrderMapper.update(null, wrapper);
+            Map<String, Object> params = new HashMap<>();
+            params.put("quantity", dto.getQuantity());
+            params.put("productMainId", productionProductMain.getId());
+            params.put("workOrderId", dto.getWorkOrderId());
+            params.put("deductQuantity", dto.getQuantity());
+
+            productWorkOrderMapper.updatePlanQuantity(params);
         }
         ProductProcess productProcess = productProcessMapper.selectById(productProcessRouteItem.getProcessId());
         ProductModel productModel = productProcessRouteItem.getProductModelId() != null ?
@@ -190,6 +173,7 @@
             qualityInspect.setInspectState(0);
             qualityInspect.setInspectType(inspectType);
             qualityInspect.setProductMainId(productionProductMain.getId());
+            qualityInspect.setProductModelId(productModel.getId());
             qualityInspectMapper.insert(qualityInspect);
 
             qualityTestStandardMapper.selectList(
@@ -207,11 +191,41 @@
         if (productModel != null) {
             List<ProductStructureDto> productStructureDtos = productStructureMapper.listByproductModelId(productModel.getId());
             for (ProductStructureDto productStructureDto : productStructureDtos) {
+                ProductModel productModel1 = productModelMapper.selectById(productStructureDto.getProductModelId());
+                Product product = productMapper.selectById(productModel1.getProductId());
+                BigDecimal stockQuantity = stockUtils.getStockQuantity(productModel1.getId()).get("stockQuantity");
+                if (!(stockQuantity.compareTo(BigDecimal.ZERO) > 0)) {
+                    throw new RuntimeException(product.getProductName() + "搴撳瓨涓�0");
+                }
+                if (stockQuantity.compareTo(productStructureDto.getUnitQuantity().multiply(dto.getQuantity())) < 0) {
+                    throw new RuntimeException(product.getProductName() + "搴撳瓨涓嶈冻");
+                }
                 ProductionProductInput productionProductInput = new ProductionProductInput();
                 productionProductInput.setProductModelId(productStructureDto.getProductModelId());
-                productionProductInput.setQuantity(productStructureDto.getUnitQuantity());
+                productionProductInput.setQuantity(productStructureDto.getUnitQuantity().multiply(dto.getQuantity()));
                 productionProductInput.setProductMainId(productionProductMain.getId());
                 productionProductInputMapper.insert(productionProductInput);
+
+
+                DateTimeFormatter dateFormat = DateTimeFormatter.ofPattern("yyyyMMdd");
+                LocalDate now = LocalDate.now();
+                ProcurementRecordOut procurementRecordOut1 = procurementRecordOutMapper.selectCode(dateFormat.format(now));
+                Long aLong = procurementRecordOut1 == null ? 1L : Long.valueOf(procurementRecordOut1.getCode().split("LS"+dateFormat.format(now))[1]);
+                //娣诲姞鍑哄簱澶勭悊
+                ProcurementRecordOut.ProcurementRecordOutBuilder procurementRecordOut = ProcurementRecordOut.builder()
+                        .procurementRecordStorageId(0)
+                        .code("LS" + dateFormat.format(now) + String.format("%03d", aLong + 1))
+                        .salesLedgerProductId(0)
+                        .inboundBatches(aLong.equals(0L) ? "绗�1鎵规" : "绗�"+ (aLong + 1) + "鎵规")
+                        .inboundNum(productionProductInput.getQuantity())
+                        .type(4)
+                        .createTime(LocalDateTime.now())
+                        .createUser(user.getUserId())
+                        .createBy(user.getNickName())
+                        .updateUser(user.getUserId())
+                        .updateTime(LocalDateTime.now())
+                        .productModelId(productModel1.getId());
+                procurementRecordOutMapper.insert(procurementRecordOut.build());
             }
         }
 
@@ -224,6 +238,11 @@
 
         // 鑾峰彇鐢熶骇璁㈠崟
         ProductWorkOrder productWorkOrder = productWorkOrderMapper.selectById(dto.getWorkOrderId());
+        List<ProductionProductMain> productionProductMains = productionProductMainMapper.selectList(new QueryWrapper<ProductionProductMain>().lambda().eq(ProductionProductMain::getWorkOrderId, dto.getWorkOrderId()));
+
+        if (productionProductMains.isEmpty()) {
+            productWorkOrder.setActualStartTime(LocalDate.now());
+        }
         ProductOrder productOrder = productOrderMapper.selectById(productWorkOrder.getProductOrderId());
         if (productOrder == null) {
             throw new RuntimeException("鐢熶骇璁㈠崟涓嶅瓨鍦�");
@@ -252,6 +271,8 @@
     public Boolean removeProductMain(ProductionProductMainDto dto) {
         Long id = dto.getId();
 
+        // 鏇存柊宸ュ崟
+        productWorkOrderMapper.rollbackPlanQuantity(id);
         // 鍒犻櫎璐ㄦ鍙傛暟鍜岃川妫�璁板綍
         qualityInspectMapper.selectList(
                 new LambdaQueryWrapper<QualityInspect>()
@@ -270,9 +291,9 @@
 
         // 鍒犻櫎鍏宠仈鐨勬牳绠楁暟鎹�
         salesLedgerProductionAccountingMapper.delete(
-                        new LambdaQueryWrapper<SalesLedgerProductionAccounting>()
-                                .eq(SalesLedgerProductionAccounting::getSalesLedgerWorkId, id)
-                );
+                new LambdaQueryWrapper<SalesLedgerProductionAccounting>()
+                        .eq(SalesLedgerProductionAccounting::getSalesLedgerWorkId, id)
+        );
 
         // 鍒犻櫎涓昏〃
         return productionProductMainMapper.deleteById(id) > 0;

--
Gitblit v1.9.3