From 1750abd11320f8d09ffe1580b7467dba87c86c89 Mon Sep 17 00:00:00 2001
From: guoyujie <guoyujie@ng.com>
Date: 星期三, 10 十二月 2025 14:40:25 +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 |  120 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 109 insertions(+), 11 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 77d5dff..478ac43 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
@@ -21,6 +21,7 @@
 import com.example.erp.mapper.mm.BasicWarehouseTypeMapper;
 import com.example.erp.mapper.mm.FinishedGoodsInventoryMapper;
 import com.example.erp.mapper.mm.FinishedOperateLogMapper;
+import com.example.erp.mapper.pp.FlowCardMapper;
 import com.example.erp.mapper.sd.OrderDetailMapper;
 import com.example.erp.mapper.sd.OrderMapper;
 import com.example.erp.service.userInfo.LogService;
@@ -54,6 +55,8 @@
     @Autowired
     OrderMapper orderMapper;
     @Autowired
+    FlowCardMapper flowCardMapper;
+    @Autowired
     SysErrorService sysErrorService;
     @Autowired
     LogService logService;
@@ -71,6 +74,19 @@
         Map<String, Object> map = new HashMap<>();
         map.put("data", finishedGoodsInventoryMapper.getSelectWarehousing(offset, pageSize, flowCard));
         map.put("total", finishedGoodsInventoryMapper.getSelectWarehousingPageTotal(offset, pageSize, flowCard));
+
+        return map;
+    }
+
+    public Map<String, Object> getSelectWarehousingApp(String processId) {
+        Map<String, Object> map = new HashMap<>();
+        FlowCard flowCard=new FlowCard();
+        if(processId!=null){
+            flowCard.setProcessId(processId.substring(0,14));
+            map.put("data", finishedGoodsInventoryMapper.getSelectWarehousing(0, 999999999, flowCard));
+            map.put("total", finishedGoodsInventoryMapper.getSelectWarehousingPageTotal(0, 999999999, flowCard));
+        }
+
 
         return map;
     }
@@ -248,6 +264,14 @@
         Map<String, Object> map = new HashMap<>();
         map.put("data", finishedGoodsInventoryMapper.getSelectDeliveryDetail(offset, pageSize, orderDetail));
         map.put("total", finishedGoodsInventoryMapper.getSelectDeliveryDetailPageTotal(offset, pageSize, orderDetail));
+        return map;
+    }
+
+    public Map<String, Object> getSelectDeliveryDetailApp() {
+        Map<String, Object> map = new HashMap<>();
+        OrderDetail orderDetail=new OrderDetail();
+        map.put("data", finishedGoodsInventoryMapper.getSelectDeliveryDetail(0, 999999999, orderDetail));
+        map.put("total", finishedGoodsInventoryMapper.getSelectDeliveryDetailPageTotal(0, 999999999, orderDetail));
         return map;
     }
 
@@ -739,16 +763,92 @@
             if(order.getWarehousing()!=2){
                 List<OrderDetail> orderDetailList=finishedGoodsInventoryMapper.getSelectOrderDetail(orderId);
                 for (OrderDetail orderDetail:orderDetailList){
+                    FlowCard flowCard  =flowCardMapper.selectOne(
+                            new LambdaQueryWrapper<FlowCard>()
+                            .eq(FlowCard::getOrderId, orderDetail.getOrderId())
+                            .eq(FlowCard::getOrderNumber, orderDetail.getOrderNumber())
+                            .groupBy(FlowCard::getOrderId,FlowCard::getOrderNumber));
                     FinishedGoodsInventory finishedGoodsInventory = finishedGoodsInventoryMapper.findOrderNumberd(orderDetail.getOrderId(),orderDetail.getOrderNumber());
-                    if(finishedGoodsInventory!=null){
-                        finishedOperateLogMapper.updateOrderFinishedOperateLog(orderDetail,userName,oddNumber);
-                        //淇敼搴撳瓨琛ㄥ叆搴撴暟閲�
+
+
+                    // 璁$畻鍓╀綑鏁伴噺
+                    long quantity;
+                    if (flowCard != null) {
+                        quantity = flowCard.getQuantity() - flowCard.getReceivedQuantity();
+                    } else {
+                        quantity = orderDetail.getQuantity() - orderDetail.getWarehouseNum();
+                    }
+
+                    if (quantity <= 0) continue ;
+
+                    int calculateType=order.getCalculateType();
+                    double deliveryDetailMoney = 0.0;
+                    double deliveryDetailArea = 0.0;
+
+                    BigDecimal getComputeArea= BigDecimal.valueOf(orderDetail.getComputeArea());
+                    BigDecimal getQuantity= BigDecimal.valueOf(quantity);
+                    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();
+                        }
+                    }
+
+                    // 鏇存柊璁㈠崟鏄庣粏
+                    orderDetail.setQuantity(quantity);
+                    orderDetail.setGrossAmount(deliveryDetailMoney);
+                    orderDetail.setComputeGrossArea(deliveryDetailArea);
+
+                    // 鏇存柊搴撳瓨
+                    if (finishedGoodsInventory != null) {
                         finishedGoodsInventoryMapper.updateOrderInventory(orderDetail);
-                    }else{
+                    } else {
                         finishedGoodsInventoryMapper.insertOrderFinishedGoodsInventory(orderDetail);
                     }
-                    finishedOperateLogMapper.insertOrderFinishedOperateLog(orderDetail,userName,oddNumber);
-                    finishedGoodsInventoryMapper.updateOrderNumberConut(orderDetail.getOrderId(),orderDetail.getOrderNumber(),orderDetail.getQuantity());
+
+                    // 璁板綍鎿嶄綔鏃ュ織
+                    String processId = flowCard != null ? flowCard.getProcessId() : "";
+                    finishedOperateLogMapper.insertOrderFinishedOperateLog(orderDetail, userName, oddNumber, processId);
+                    finishedGoodsInventoryMapper.updateOrderNumberConut(orderDetail.getOrderId(), orderDetail.getOrderNumber(), orderDetail.getQuantity());
+
+                    // 鏇存柊娴佺▼鍗�
+                    if (flowCard != null) {
+                        flowCard.setInventoryQuantity((int) quantity);
+                        Order order1 = new Order();
+                        order1.setOrderId(flowCard.getOrderId());
+                        flowCard.setOrder(order1);
+                        finishedGoodsInventoryMapper.updateflowcard(flowCard);
+                    }
+
                 }
                 finishedGoodsInventoryMapper.updateOrderWarehousingState(orderId,2);
             }
@@ -1104,11 +1204,9 @@
 
                     //淇敼璁㈠崟鏄庣粏琛ㄥ叆搴撴暟閲�
                     finishedGoodsInventoryMapper.updateOutOrderNumberConut(finishedOperateLog.getOrderId(),finishedOperateLog.getOperationNumber(),finishedOperateLog.getCancelAvailable());
-                    //鍒ゆ柇璁㈠崟鏄惁鍏ㄩ儴鍏ュ簱
-                    if (Objects.equals(ordersum, ordernumbersum)) {
-                        //淇敼璁㈠崟琛ㄥ叆搴撶姸鎬�
-                        finishedGoodsInventoryMapper.updateOrderWarehousingState(finishedOperateLog.getOrderId(),1);
-                    }
+
+                    //淇敼璁㈠崟琛ㄥ叆搴撶姸鎬�
+                    finishedGoodsInventoryMapper.updateOrderWarehousingState(finishedOperateLog.getOrderId(),1);
                     if (ordernumbersum-finishedOperateLog.getQuantity()==0) {
                         //淇敼璁㈠崟琛ㄥ叆搴撶姸鎬�
                         finishedGoodsInventoryMapper.updateOrderWarehousingState(finishedOperateLog.getOrderId(),0);

--
Gitblit v1.8.0