From 7cf8f8fc1abca63423c1fb4618363f8a9d283f9d Mon Sep 17 00:00:00 2001
From: 于杰 <1210123631@qq.com>
Date: 星期二, 04 十一月 2025 14:56:40 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java |  103 ++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 97 insertions(+), 6 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 3074266..77d5dff 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
@@ -10,6 +10,7 @@
 import com.example.erp.dto.mm.FinishedOperateLogDTO;
 import com.example.erp.entity.mm.FinishedGoodsInventory;
 import com.example.erp.entity.mm.FinishedOperateLog;
+import com.example.erp.entity.mm.MaterialInventory;
 import com.example.erp.entity.pp.FlowCard;
 import com.example.erp.entity.sd.Delivery;
 import com.example.erp.entity.sd.DeliveryDetail;
@@ -32,6 +33,7 @@
 import java.math.BigDecimal;
 import java.math.RoundingMode;
 import java.sql.SQLOutput;
+import java.text.DecimalFormat;
 import java.text.SimpleDateFormat;
 import java.time.LocalDate;
 import java.time.LocalDateTime;
@@ -1025,15 +1027,74 @@
                                 .eq(FinishedGoodsInventory::getOrderNumber, finishedOperateLog.getOperationNumber())
                                 .eq(FinishedGoodsInventory::getBoxNo, finishedOperateLog.getRemarks())
                         );
-                if(delivery!=null){
+                /*if(delivery!=null){
                     return "false1";
-                }
-                if(existFinishedGoodsInventory.getQuantityAvailable()<finishedOperateLog.getQuantity()){
+                }*/
+                if(existFinishedGoodsInventory.getQuantityAvailable()<finishedOperateLog.getCancelAvailable()){
                     return "false2";
                 }
-
                     //淇敼璁板綍琛�
-                    finishedOperateLogMapper.updateFinishedOperateLogState(finishedOperateLog,"宸蹭綔搴�");
+                    if(existFinishedGoodsInventory.getQuantityAvailable()>finishedOperateLog.getCancelAvailable()
+                        && finishedOperateLog.getQuantity()>finishedOperateLog.getCancelAvailable()){
+
+                        Order order=orderMapper.selectOne(new LambdaQueryWrapper<Order>().eq(Order::getOrderId,finishedOperateLog.getOrderId()));
+                        OrderDetail orderDetail=orderDetailMapper.selectOne(new LambdaQueryWrapper<OrderDetail>()
+                                .eq(OrderDetail::getOrderId,finishedOperateLog.getOrderId())
+                                .eq(OrderDetail::getOrderNumber,finishedOperateLog.getOperationNumber())
+                        );
+                        if(order != null && orderDetail != null){
+                            Integer calculateType=order.getCalculateType();
+                            double deliveryDetailMoney = 0.0;
+                            double deliveryDetailArea = 0.0;
+
+                            BigDecimal getComputeArea= BigDecimal.valueOf(orderDetail.getComputeArea());
+                            BigDecimal getQuantity= BigDecimal.valueOf(finishedOperateLog.getCancelAvailable());
+                            BigDecimal getPrice= BigDecimal.valueOf(orderDetail.getPrice());
+                            BigDecimal getWidth= BigDecimal.valueOf(orderDetail.getWidth());
+                            BigDecimal getHeight= BigDecimal.valueOf(orderDetail.getHeight());
+                            BigDecimal singlePieceArea =getComputeArea.multiply(getQuantity).setScale(2, RoundingMode.HALF_UP)
+                                    .multiply(getPrice).setScale(2, RoundingMode.HALF_UP);
+                            //鏍规嵁璁㈠崟璁$畻鏂瑰紡杩涜閲戦璁$畻
+                            if (calculateType==1){
+                                deliveryDetailMoney=singlePieceArea.doubleValue();
+                                deliveryDetailArea=getComputeArea.multiply(getQuantity).doubleValue();
+
+                            }else if (calculateType==2){
+                                //鍒ゆ柇瀹為檯鍗曠墖闈㈢Н璺熺粨绠楀崟鐗囬潰绉槸鍚︾浉绛� 缁撶畻鎬婚潰绉窡瀹為檯鎬婚潰绉槸鍚︾浉绛�
+                                if(Objects.equals(orderDetail.getArea(), orderDetail.getComputeArea())&&Objects.equals(orderDetail.getGrossArea(), orderDetail.getComputeGrossArea())){
+                                    deliveryDetailMoney=getWidth.multiply(getHeight).multiply(getQuantity).divide(BigDecimal.valueOf(1000000), 2, RoundingMode.HALF_UP)
+                                            .multiply(getPrice).setScale(2, RoundingMode.HALF_UP).doubleValue();
+                                    deliveryDetailArea=getWidth.multiply(getHeight).multiply(getQuantity).divide(BigDecimal.valueOf(1000000), 2, RoundingMode.HALF_UP).doubleValue();
+                                }else{
+                                    deliveryDetailMoney=singlePieceArea.doubleValue();
+                                    deliveryDetailArea=getComputeArea.multiply(getQuantity).doubleValue();
+                                }
+                            }else if (calculateType==3){
+                                deliveryDetailMoney=getQuantity.multiply(getPrice).setScale(2, RoundingMode.HALF_UP).doubleValue();
+                                deliveryDetailArea=getComputeArea.multiply(getQuantity).doubleValue();
+
+                            }else if (calculateType==4){
+                                //鍒ゆ柇瀹為檯鍗曠墖闈㈢Н璺熺粨绠楀崟鐗囬潰绉槸鍚︾浉绛� 缁撶畻鎬婚潰绉窡瀹為檯鎬婚潰绉槸鍚︾浉绛�
+                                if(Objects.equals(orderDetail.getArea(), orderDetail.getComputeArea())&&Objects.equals(orderDetail.getGrossArea(), orderDetail.getComputeGrossArea())){
+                                    deliveryDetailMoney=getWidth.multiply(getHeight).multiply(getQuantity).multiply(getPrice).
+                                            divide(BigDecimal.valueOf(1000000), 2, RoundingMode.HALF_UP).doubleValue();
+                                    deliveryDetailArea=getWidth.multiply(getHeight).multiply(getQuantity).divide(BigDecimal.valueOf(1000000), 2, RoundingMode.HALF_UP).doubleValue();
+                                }else{
+                                    deliveryDetailMoney=getComputeArea.multiply(getQuantity).multiply(getPrice).setScale(2, RoundingMode.HALF_UP).doubleValue();
+                                    deliveryDetailArea=getComputeArea.multiply(getQuantity).doubleValue();
+                                }
+                            }
+
+                            finishedOperateLogMapper.updateFinishedOperateLogQuantity(finishedOperateLog,deliveryDetailMoney,deliveryDetailArea);
+                        }else{
+                            return "false3";
+                        }
+
+
+
+                    }else{
+                        finishedOperateLogMapper.updateFinishedOperateLogState(finishedOperateLog,"宸蹭綔搴�");
+                    }
                     //淇敼搴撳瓨琛ㄥ叆搴撴暟閲�
                     finishedGoodsInventoryMapper.updateInventoryOut(finishedOperateLog);
                     if(finishedOperateLog.getProcessId()!=null){
@@ -1042,7 +1103,7 @@
                     }
 
                     //淇敼璁㈠崟鏄庣粏琛ㄥ叆搴撴暟閲�
-                    finishedGoodsInventoryMapper.updateOutOrderNumberConut(finishedOperateLog.getOrderId(),finishedOperateLog.getOperationNumber(),finishedOperateLog.getQuantity());
+                    finishedGoodsInventoryMapper.updateOutOrderNumberConut(finishedOperateLog.getOrderId(),finishedOperateLog.getOperationNumber(),finishedOperateLog.getCancelAvailable());
                     //鍒ゆ柇璁㈠崟鏄惁鍏ㄩ儴鍏ュ簱
                     if (Objects.equals(ordersum, ordernumbersum)) {
                         //淇敼璁㈠崟琛ㄥ叆搴撶姸鎬�
@@ -1274,4 +1335,34 @@
         map.put("data", list);
         return map;
     }
+
+
+    public Map<String, Object> appFinishedGoodsInventoryList() {
+        Map<String, Object> map = new HashMap<>();
+        Map<String, Object> totalSum  = new HashMap<>();
+        Integer inventory = 0;
+        Integer quantityAvailable = 0;
+        Double area = 0.00;
+        Double computeGrossArea = 0.00;
+
+        List<FinishedGoodsInventory> finishedGoodsInventoryList=finishedGoodsInventoryMapper.getFinishedGoodsInventoryList();
+        if(!finishedGoodsInventoryList.isEmpty()){
+            for(FinishedGoodsInventory finishedGoodsInventory:finishedGoodsInventoryList){
+                inventory += finishedGoodsInventory.getInventory();
+                quantityAvailable += finishedGoodsInventory.getQuantityAvailable();
+                area += finishedGoodsInventory.getArea();
+                computeGrossArea+=finishedGoodsInventory.getComputeGrossArea();
+            }
+            DecimalFormat df = new DecimalFormat("#.00");
+            totalSum.put("inventory",inventory);
+            totalSum.put("quantityAvailable",quantityAvailable);
+            totalSum.put("area", df.format(area));
+            totalSum.put("computeGrossArea", df.format(computeGrossArea));
+
+            map.put("data", finishedGoodsInventoryList);
+            map.put("total", totalSum);
+        }
+
+        return map;
+    }
 }

--
Gitblit v1.8.0