From 81cad8df0f1b33700e7fc80f271eda7f1180efb0 Mon Sep 17 00:00:00 2001
From: guoyujie <guoyujie@ng.com>
Date: 星期二, 14 十月 2025 14:51:17 +0800
Subject: [PATCH] Merge branch 'master' of http://10.153.19.25:10101/r/ERP_override

---
 north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java |   67 +++++++++++++++++++++++++++------
 1 files changed, 55 insertions(+), 12 deletions(-)

diff --git a/north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java b/north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java
index 0b548c2..b946507 100644
--- a/north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java
+++ b/north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java
@@ -6,6 +6,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.example.erp.dto.mm.FinishedOperateLogDTO;
 import com.example.erp.entity.mm.FinishedGoodsInventory;
 import com.example.erp.entity.mm.FinishedOperateLog;
@@ -30,8 +31,10 @@
 
 import java.math.BigDecimal;
 import java.math.RoundingMode;
+import java.sql.SQLOutput;
 import java.text.SimpleDateFormat;
 import java.time.LocalDate;
+import java.time.LocalDateTime;
 import java.util.*;
 
 @Service
@@ -100,6 +103,11 @@
             if (object.get("decValue") != null) {
                 decValue = Integer.parseInt(object.get("decValue").toString());
             }
+            String createTime = null;
+            if(object.get("createTime")!=null){
+                createTime =  object.get("createTime").toString();
+            }
+
             Log log = new Log();
             log.setOperator(userName);
             log.setOperatorId(userId);
@@ -160,7 +168,7 @@
 
 
                     //娣诲姞鍑哄叆搴撹褰�
-                    finishedOperateLogMapper.insertIntFinishedOperateLog(flowCard,userName,oddNumber,container,deliveryDetailMoney,deliveryDetailArea);
+                    finishedOperateLogMapper.insertIntFinishedOperateLog(flowCard,userName,oddNumber,container,deliveryDetailMoney,deliveryDetailArea,createTime,getComputeArea.doubleValue());
                     Integer finishedGoodsInventorycount = 0;
                     finishedGoodsInventorycount = finishedGoodsInventoryMapper.findOrderNumberdContainercount(flowCard.getOrder().getOrderId(),flowCard.getOrderNumber(),container);
 
@@ -187,7 +195,7 @@
                                 finishedGoodsInventoryMapper.updateOrderWarehousingState(flowCard.getOrder().getOrderId(),2);
                             }
                         } else {
-                            if (finishedGoodsInventoryMapper.insertFinishedGoodsInventory(flowCard, storageRegion, remark,container)) {
+                            if (finishedGoodsInventoryMapper.insertFinishedGoodsInventory(flowCard, storageRegion, remark,container,getComputeArea.doubleValue())) {
                                 //淇敼娴佺▼鍗¤〃鍏ュ簱鏁伴噺
                                 finishedGoodsInventoryMapper.updateflowcard(flowCard);
                                 //淇敼璁㈠崟鏄庣粏琛ㄥ叆搴撴暟閲�
@@ -906,10 +914,20 @@
         for (OrderDetail orderDetail : list) {
             //鑾峰彇鍗曞彿
             String oddNumber= orderNumberSetting("鍑哄簱");
-            OrderDetail orderDetailNew= finishedGoodsInventoryMapper.findOrderDetailNumberd(orderDetail.getDeliveryDetail().getOrderId(),orderDetail.getDeliveryDetail().getOrderNumber());
+            OrderDetail orderDetailNew= finishedGoodsInventoryMapper.
+                    findOrderDetailNumberd(
+                            orderDetail.getDeliveryDetail().getOrderId(),
+                            orderDetail.getDeliveryDetail().getOrderNumber());
+
+
             //娣诲姞鍑哄叆搴撹褰�
             finishedOperateLogMapper.insertOutFinishedOperateLog(orderDetail,userName,oddNumber,orderDetail.getDeliveryDetail().getBoxNo());
-
+            orderDetailMapper.update(null,
+                    new UpdateWrapper<OrderDetail>()
+                            .setSql("out_stock_num = ifnull(out_stock_num,0)+"+orderDetail.getDeliveryDetail().getQuantity())
+                            .eq("order_id",orderDetail.getDeliveryDetail().getOrderId())
+                            .eq("order_number",orderDetail.getDeliveryDetail().getOrderNumber())
+            );
             //鍒ゆ柇鍙戣揣鍗曠殑搴撳瓨鏄惁瀛樺湪
             Integer finishedGoodsInventorycount = finishedGoodsInventoryMapper.findOrderNumberdcount(orderDetail.getDeliveryDetail().getOrderId(),orderDetail.getDeliveryDetail().getOrderNumber(),orderDetail.getDeliveryDetail().getBoxNo());
 
@@ -924,11 +942,14 @@
             Integer deliverysum = finishedGoodsInventoryMapper.findDeliveryQuantity(orderDetail.getDeliveryDetail().getDeliveryId());
             //鑾峰彇宸茬粡鍑哄簱鐨勬暟閲�
             Integer deliverydetailsum = finishedGoodsInventoryMapper.findDeliverydetailsum(orderDetail.getDeliveryDetail().getDeliveryId(),0);
+            //鑾峰彇璁㈠崟宸茬粡鍑哄簱鐨勬暟閲�
+            OrderDetail orderDetail1  = orderDetailMapper.
+                    selectOne(new QueryWrapper<OrderDetail>()
+                            .select("ifnull(sum(out_stock_num),0) as out_stock_num")
+                            .eq("order_id",orderDetail.getDeliveryDetail().getOrderId())
+                    );
 
-            Integer finishedOperateLogQuantitySum = finishedGoodsInventoryMapper.findFinishedOperateLogQuantity(orderDetail.getDeliveryDetail().getOrderId());
-            if(finishedOperateLogQuantitySum==null){
-                finishedOperateLogQuantitySum=0;
-            }
+
             if(deliverydetailsum==null){
                 deliverydetailsum=0;
             }
@@ -959,10 +980,11 @@
                         //淇敼璁㈠崟琛ㄥ彂璐х姸鎬�
                         finishedGoodsInventoryMapper.updateOrderDeliveryState(orderDetail.getDeliveryDetail().getOrderId(),1);
                         //鍒ゆ柇璁㈠崟鏄惁鍏ㄩ儴鍙戣揣
-                        if (ordersum==finishedOperateLogQuantitySum) {
+                        if (Objects.equals(ordersum, orderDetail1.getOutStockNum())) {
                             //if (ordersum == (orderDeliveryQuantitySum + orderDetail.getWarehouseNum())) {
                             //淇敼璁㈠崟琛ㄥ彂璐х姸鎬�
-                            finishedGoodsInventoryMapper.updateOrderDeliveryState(orderDetail.getDeliveryDetail().getOrderId(),2);
+                            finishedGoodsInventoryMapper.
+                                    updateOrderDeliveryState(orderDetail.getDeliveryDetail().getOrderId(),2);
                         }
                         if (deliverysum==deliverydetailsum+orderDetail.getDeliveryDetail().getQuantity()) {
                             //淇敼鍙戣揣琛ㄧ姸鎬�
@@ -1043,6 +1065,20 @@
                         finishedOperateLog.getQuantity(),
                         finishedOperateLog.getRemarks()
                 );
+                //淇敼璁㈠崟鏄庣粏 鍑哄簱鏁伴噺
+                orderDetailMapper.update(null,
+                        new LambdaUpdateWrapper<OrderDetail>().
+                                setSql("out_stock_num = ifnull(out_stock_num,0)-"+finishedOperateLog.getQuantity())
+                        .eq(OrderDetail::getOrderId, finishedOperateLog.getOrderId())
+                        .eq(OrderDetail::getOrderNumber, finishedOperateLog.getOperationNumber())
+                );
+
+                OrderDetail orderDetail1  = orderDetailMapper.
+                        selectOne(new QueryWrapper<OrderDetail>()
+                                .select("ifnull(sum(out_stock_num),0) as out_stock_num")
+                                .eq("order_id",finishedOperateLog.getOrderId())
+                        );
+
                 //淇敼鍙戣揣鏄庣粏琛ㄧ姸鎬�
                 finishedGoodsInventoryMapper.updateDeliveryDetailState(
                         finishedOperateLog.getOrderId(),
@@ -1057,7 +1093,7 @@
                 //淇敼璁㈠崟琛ㄥ彂璐х姸鎬�
                 finishedGoodsInventoryMapper.updateOrderDeliveryState(finishedOperateLog.getOrderId(),1);
                 //鍒ゆ柇璁㈠崟鏄惁鍏ㄩ儴鍙戣揣
-                if (ordersum==finishedOperateLog.getQuantity()+ordernumbersum){
+                if (orderDetail1.getOutStockNum()==0){
                     //淇敼璁㈠崟琛ㄥ彂璐х姸鎬�
                     finishedGoodsInventoryMapper.updateOrderDeliveryState(finishedOperateLog.getOrderId(),0);
 
@@ -1106,12 +1142,14 @@
             oldFinishedGoodsInventory.setInventory(oldFinishedGoodsInventory.getInventory()-finishedGoodsInventory.getQuantityAvailable());
             oldFinishedGoodsInventory.setQuantityAvailable(oldFinishedGoodsInventory.getQuantityAvailable()-finishedGoodsInventory.getQuantityAvailable());
             oldFinishedGoodsInventory.setArea(oldFinishedGoodsInventory.getInventory()*oldFinishedGoodsInventory.getActualSignalArea());
+            oldFinishedGoodsInventory.setComputeGrossArea(oldFinishedGoodsInventory.getInventory()*oldFinishedGoodsInventory.getComputeArea());
 
             //鏂板簱瀛樻暟鎹鍔�
             finishedGoodsInventory.setId(null);
             finishedGoodsInventory.setInventory(finishedGoodsInventory.getQuantityAvailable());
             finishedGoodsInventory.setArea(finishedGoodsInventory.getQuantityAvailable()*finishedGoodsInventory.getActualSignalArea());
-
+            finishedGoodsInventory.setComputeGrossArea(finishedGoodsInventory.getQuantityAvailable()*finishedGoodsInventory.getComputeArea());
+            finishedGoodsInventory.setEnterStorageTime(null);
             finishedGoodsInventoryMapper.
                     update(oldFinishedGoodsInventory,
                             new LambdaUpdateWrapper<FinishedGoodsInventory>()
@@ -1122,6 +1160,8 @@
 
             //寰�鎿嶄綔鏃ュ織琛ㄦ坊鍔犳暟鎹�
             finishedOperateLog.setQuantity(finishedGoodsInventory.getQuantityAvailable());
+            finishedOperateLog.setArea(finishedGoodsInventory.getQuantityAvailable()*finishedGoodsInventory.getComputeArea());
+            finishedOperateLog.setComputeArea(finishedGoodsInventory.getComputeArea());
             finishedOperateLog.setRemarks(oldFinishedGoodsInventory.getBoxNo()+"->"+finishedGoodsInventory.getBoxNo());
             finishedOperateLogMapper.insert(finishedOperateLog);
 
@@ -1142,10 +1182,12 @@
                 oldFinishedGoodsInventory.setInventory(oldFinishedGoodsInventory.getInventory()-finishedGoodsInventory.getQuantityAvailable());
                 oldFinishedGoodsInventory.setQuantityAvailable(oldFinishedGoodsInventory.getQuantityAvailable()-finishedGoodsInventory.getQuantityAvailable());
                 oldFinishedGoodsInventory.setArea(oldFinishedGoodsInventory.getInventory()*oldFinishedGoodsInventory.getActualSignalArea());
+                oldFinishedGoodsInventory.setComputeGrossArea(oldFinishedGoodsInventory.getInventory()*oldFinishedGoodsInventory.getComputeArea());
 
                 existFinishedGoodsInventory.setInventory(existFinishedGoodsInventory.getInventory()+finishedGoodsInventory.getQuantityAvailable());
                 existFinishedGoodsInventory.setQuantityAvailable(existFinishedGoodsInventory.getQuantityAvailable()+finishedGoodsInventory.getQuantityAvailable());
                 existFinishedGoodsInventory.setArea(existFinishedGoodsInventory.getInventory()*existFinishedGoodsInventory.getActualSignalArea());
+                existFinishedGoodsInventory.setComputeGrossArea(existFinishedGoodsInventory.getInventory()*existFinishedGoodsInventory.getComputeArea());
 
                 finishedGoodsInventoryMapper.
                         update(oldFinishedGoodsInventory,
@@ -1160,6 +1202,7 @@
 
                 //寰�鎿嶄綔鏃ュ織琛ㄦ坊鍔犳暟鎹�
                 finishedOperateLog.setQuantity(finishedGoodsInventory.getQuantityAvailable());
+                finishedOperateLog.setComputeArea(existFinishedGoodsInventory.getComputeArea());
                 finishedOperateLog.setRemarks(oldFinishedGoodsInventory.getBoxNo()+"->"+existFinishedGoodsInventory.getBoxNo());
                 finishedOperateLogMapper.insert(finishedOperateLog);
 

--
Gitblit v1.8.0