From 6bb66501148afcd970188ed122e2ee37908e3127 Mon Sep 17 00:00:00 2001
From: liding <756868258@qq.com>
Date: 星期一, 25 五月 2026 13:45:17 +0800
Subject: [PATCH] feat: 报工投入用“投入重量/数量”

---
 src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java |  120 ++++++++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 108 insertions(+), 12 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 47e7fcd..2ab812a 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductionProductMainServiceImpl.java
@@ -1,5 +1,8 @@
 package com.ruoyi.production.service.impl;
 
+import com.alibaba.fastjson2.JSON;
+import com.alibaba.fastjson2.JSONArray;
+import com.alibaba.fastjson2.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
@@ -37,7 +40,6 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
-import java.math.RoundingMode;
 import java.time.LocalDate;
 import java.time.LocalDateTime;
 import java.time.format.DateTimeFormatter;
@@ -53,6 +55,8 @@
     private static final String PROCESS_VOLTAGE_SORT = "鐢靛帇鍒嗛��";
     private static final String PROCESS_OPTICAL_INSPECTION = "鍏夋澶栬";
     private static final String PROCESS_PACKAGING = "鍖呰";
+    private static final String INPUT_WEIGHT_PARAMETER = "鎶曞叆閲嶉噺/鏁伴噺";
+    private static final String INPUT_WEIGHT_FIELD = "inputWeight";
     private static final Object PRODUCT_MAIN_NO_LOCK = new Object();
 
     private IQualityInspectService qualityInspectService;
@@ -99,6 +103,10 @@
 
         BigDecimal reportQty = dto.getQuantity();
         BigDecimal scrapQty = dto.getScrapQty() == null ? BigDecimal.ZERO : dto.getScrapQty();
+        BigDecimal bomInputQty = dto.getInputWeight();
+        if (bomInputQty == null) {
+            bomInputQty = resolveInputWeight(dto.getOtherData());
+        }
         if (reportQty == null || reportQty.compareTo(BigDecimal.ZERO) <= 0) {
             throw new ServiceException("鎶ュ伐鏁伴噺蹇呴』澶т簬0");
         }
@@ -107,6 +115,9 @@
         }
         if (scrapQty.compareTo(reportQty) > 0) {
             throw new ServiceException("鎶ュ簾鏁伴噺涓嶈兘澶т簬鎶ュ伐鏁伴噺");
+        }
+        if (bomInputQty == null || bomInputQty.compareTo(BigDecimal.ZERO) < 0) {
+            throw new ServiceException("浜у搧缁撴瀯鎶曞叆鏁伴噺涓嶈兘灏忎簬0");
         }
 
         // 绗簩姝ワ細鍔犺浇褰撳墠宸ュ簭銆佸伐鍗曘�佸伐鑹鸿矾绾垮拰璁㈠崟鏁版嵁锛屽苟鏍¢獙鍩虹鍏宠仈鍏崇郴
@@ -193,9 +204,9 @@
 
             BigDecimal previousCompleteQty =
                     previousWorkOrder.getCompleteQuantity() == null ? BigDecimal.ZERO : previousWorkOrder.getCompleteQuantity();
-            if (currentReportedQty.add(reportQty).compareTo(previousCompleteQty) > 0) {
-                throw new ServiceException("鏈鎶ュ伐鏁伴噺瓒呰繃涓婇亾宸ュ簭鍙祦杞暟閲�");
-            }
+//            if (currentReportedQty.add(reportQty).compareTo(previousCompleteQty) > 0) {
+//                throw new ServiceException("鏈鎶ュ伐鏁伴噺瓒呰繃涓婇亾宸ュ簭鍙祦杞暟閲�");
+//            }
 
             List<ProductProcessRouteItem> previousItems = productProcessRouteItemMapper.selectList(
                     Wrappers.<ProductProcessRouteItem>lambdaQuery()
@@ -239,10 +250,10 @@
                     .filter(Objects::nonNull)
                     .reduce(BigDecimal.ZERO, BigDecimal::add);
         }
-        if (productWorkOrder.getPlanQuantity() != null
-                && currentWorkOrderReportedQty.add(reportQty).compareTo(productWorkOrder.getPlanQuantity()) > 0) {
-            throw new ServiceException("鏈鎶ュ伐鏁伴噺瓒呰繃宸ュ崟鍙姤鏁伴噺");
-        }
+//        if (productWorkOrder.getPlanQuantity() != null
+//                && currentWorkOrderReportedQty.add(reportQty).compareTo(productWorkOrder.getPlanQuantity()) > 0) {
+//            throw new ServiceException("鏈鎶ュ伐鏁伴噺瓒呰繃宸ュ崟鍙姤鏁伴噺");
+//        }
 
         // 绗簲姝ワ細鐢熸垚鎶ュ伐鍗曞彿骞剁‘瀹氭姤宸ヤ汉淇℃伅
         String productNo;
@@ -313,6 +324,9 @@
                     .collect(Collectors.toMap(ProductStructureDto::getId, Function.identity(), (a, b) -> a));
         }
 
+        // 绗竷姝�-1锛氭姇鍏ユ暟閲忓己鍒跺彇鍓嶇浼犲叆鐨� bomInputQty
+        BigDecimal inputBaseQty = bomInputQty;
+
         for (ProductStructureDto productStructureDto : productStructureDtos) {
             if (productStructureDto.getProductModelId() == null) {
                 throw new ServiceException("鎶曞叆鐗╂枡浜у搧鍨嬪彿涓嶈兘涓虹┖");
@@ -335,13 +349,11 @@
                 throw new ServiceException("鐖剁骇鐗╂枡鐢ㄩ噺蹇呴』澶т簬0");
             }
 
-            BigDecimal needQty = childQty
-                    .divide(parentQty, 6, RoundingMode.HALF_UP)
-                    .multiply(reportQty);
+            BigDecimal needQty = inputBaseQty;
 
             ProductionProductInput productionProductInput = new ProductionProductInput();
             productionProductInput.setProductModelId(productStructureDto.getProductModelId());
-            productionProductInput.setQuantity(needQty);
+            productionProductInput.setQuantity(needQty == null ? BigDecimal.ZERO : needQty);
             productionProductInput.setProductMainId(productionProductMain.getId());
             productionProductInputMapper.insert(productionProductInput);
 
@@ -350,6 +362,7 @@
                     needQty,
                     StockOutQualifiedRecordTypeEnum.PRODUCTION_REPORT_STOCK_OUT.getCode(),
                     productionProductMain.getId(),
+                    null,
                     null
             );
         }
@@ -756,4 +769,87 @@
 
         return productionProductMainDtos;
     }
+
+    private BigDecimal resolveInputWeight(String otherData) {
+        if (StringUtils.isBlank(otherData)) {
+            return null;
+        }
+        Object parsed;
+        try {
+            parsed = JSON.parse(otherData);
+        } catch (Exception ex) {
+            throw new ServiceException("鎶ュ伐鍙傛暟鏍煎紡閿欒锛屾棤娉曡В鏋愭姇鍏ラ噸閲�/鏁伴噺");
+        }
+        String inputWeight = StringUtils.trim(findParameterValue(parsed, INPUT_WEIGHT_PARAMETER));
+        if (StringUtils.isBlank(inputWeight)) {
+            inputWeight = StringUtils.trim(findFieldValue(parsed, INPUT_WEIGHT_FIELD));
+        }
+        if (StringUtils.isBlank(inputWeight)) {
+            return null;
+        }
+        try {
+            return new BigDecimal(inputWeight);
+        } catch (NumberFormatException ex) {
+            throw new ServiceException("鎶ュ伐鍙傛暟涓殑鎶曞叆閲嶉噺/鏁伴噺鏍煎紡閿欒");
+        }
+    }
+
+    private String findParameterValue(Object node, String parameterItem) {
+        if (node instanceof JSONArray) {
+            JSONArray array = (JSONArray) node;
+            for (Object item : array) {
+                String value = findParameterValue(item, parameterItem);
+                if (StringUtils.isNotBlank(value)) {
+                    return value;
+                }
+            }
+            return null;
+        }
+        if (node instanceof JSONObject) {
+            JSONObject object = (JSONObject) node;
+            if (parameterItem.equals(StringUtils.trim(object.getString("parameterItem")))) {
+                String value = StringUtils.trim(object.getString("value"));
+                if (StringUtils.isNotBlank(value)) {
+                    return value;
+                }
+            }
+            for (Object value : object.values()) {
+                String matched = findParameterValue(value, parameterItem);
+                if (StringUtils.isNotBlank(matched)) {
+                    return matched;
+                }
+            }
+        }
+        return null;
+    }
+
+    private String findFieldValue(Object node, String fieldName) {
+        if (node instanceof JSONArray) {
+            JSONArray array = (JSONArray) node;
+            for (Object item : array) {
+                String value = findFieldValue(item, fieldName);
+                if (StringUtils.isNotBlank(value)) {
+                    return value;
+                }
+            }
+            return null;
+        }
+        if (node instanceof JSONObject) {
+            JSONObject object = (JSONObject) node;
+            Object fieldValue = object.get(fieldName);
+            if (fieldValue != null) {
+                String value = StringUtils.trim(String.valueOf(fieldValue));
+                if (StringUtils.isNotBlank(value)) {
+                    return value;
+                }
+            }
+            for (Object value : object.values()) {
+                String matched = findFieldValue(value, fieldName);
+                if (StringUtils.isNotBlank(matched)) {
+                    return matched;
+                }
+            }
+        }
+        return null;
+    }
 }

--
Gitblit v1.9.3