From 82a5de6d2ec80b45660149c84be28734032562f6 Mon Sep 17 00:00:00 2001
From: chenlu <1320612696@qq.com>
Date: 星期五, 11 十月 2024 15:21:53 +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/sd/OrderService.java |   72 ++++++++++++++++++++++++++++++------
 1 files changed, 60 insertions(+), 12 deletions(-)

diff --git a/north-glass-erp/src/main/java/com/example/erp/service/sd/OrderService.java b/north-glass-erp/src/main/java/com/example/erp/service/sd/OrderService.java
index 18404fb..d5311e8 100644
--- a/north-glass-erp/src/main/java/com/example/erp/service/sd/OrderService.java
+++ b/north-glass-erp/src/main/java/com/example/erp/service/sd/OrderService.java
@@ -113,6 +113,9 @@
             log.setContent(orderMap.toString());
             log.setFunction("saveOrderTitle淇濆瓨琛ㄥご:"+order.getOrderId());
 
+            Order order1 = orderMapper.selectOrderId(order.getOrderId());
+            order.setCalculateType(order1.getCalculateType());
+
             LambdaUpdateWrapper<Order> updateWrapper = new LambdaUpdateWrapper<>();
             updateWrapper.eq(Order::getOrderId, order.getOrderId());
             order.setCreateTime(null);
@@ -280,6 +283,8 @@
                 orderOtherMoney.setOrderId(orderId);
                 if(orderOtherMoney.getQuantity()!=null && orderOtherMoney.getPrice()!=null){
                     orderOtherMoney.setMoney((orderOtherMoney.getQuantity()*orderOtherMoney.getPrice()));
+                }else {
+                    orderOtherMoney.setMoney(0.0);
                 }
                 orderOtherMoneyMapper.insert(orderOtherMoney);
             });
@@ -397,26 +402,69 @@
         Order order = JSONObject.parseObject(JSONObject.toJSONString(jsonObject.get("order")), Order.class);
         List<OrderDetail> OrderDetails = JSONArray.parseArray(JSONObject.toJSONString(jsonObject.get("detail")), OrderDetail.class);
         List<OrderOtherMoney> orderOtherMoneyList = JSONArray.parseArray(JSONObject.toJSONString(jsonObject.get("otherMoney")), OrderOtherMoney.class);
-        double money = 0;
-        for (OrderDetail orderDetail : OrderDetails) {
-            orderDetail =  updateOrderMoneyComputed(orderDetail,order.getCalculateType());
-            BigDecimal getGrossAmount= BigDecimal.valueOf(orderDetail.getGrossAmount());
-            money+=getGrossAmount.doubleValue();
+
+        if(orderOtherMoneyList != null ){
+            orderOtherMoneyList = orderOtherMoneyList.stream().filter(o -> o.getColumn().indexOf("M")==0).collect(Collectors.toList());
         }
+        if(orderOtherMoneyList!=null){
+            orderOtherMoneyList.forEach(orderOtherMoney -> {
+                orderOtherMoney.setQuantity(0.0);
+            });
+        }
+
         Log log = new Log();
         log.setOperator(order.getCreator());
         log.setOperatorId(order.getCreatorId());
         log.setContent(jsonObject.toString());
         log.setFunction("updateOrderMoney閲戦閲嶇疆:"+order.getOrderId());
 
-        orderOtherMoneyList.forEach(orderOtherMoney -> {
-            if(orderOtherMoney.getQuantity()!=null && orderOtherMoney.getPrice()!=null){
-                orderOtherMoney.setMoney((orderOtherMoney.getQuantity()*orderOtherMoney.getPrice()));
+        //鍒犻櫎鍏朵粬閲戦鏄庣粏琛�
+        orderOtherMoneyMapper.delete(new LambdaQueryWrapper<OrderOtherMoney>().eq(OrderOtherMoney::getOrderId, order.getOrderId()));
+        List<OrderOtherMoney> orderOtherMoneyLists=orderOtherMoneyList;
+
+        double money = 0;
+        for (OrderDetail orderDetail : OrderDetails) {
+            orderDetail =  updateOrderMoneyComputed(orderDetail,order.getCalculateType());
+            BigDecimal getGrossAmount= BigDecimal.valueOf(orderDetail.getGrossAmount());
+            money+=getGrossAmount.doubleValue();
+
+            Map<String,Object> otherColumns = JSON.parseObject(orderDetail.getOtherColumns(), new TypeReference<Map<String, Object>>(){});
+            if(otherColumns!=null){
+                otherColumns.values().removeIf(value -> value == null || value.equals(""));
+                orderDetail.setOtherColumns(JSON.toJSONString(otherColumns));
+
+                OrderDetail finalOrderDetail = orderDetail;
+                otherColumns.forEach((key, value) ->{
+
+                    if(value!=null && !value.equals("") && key.contains("M")) {
+                        orderOtherMoneyLists.forEach(orderOtherMoney -> {
+                            if (orderOtherMoney.getColumn().equals(key)) {
+                                orderOtherMoney.setQuantity(
+                                        orderOtherMoney.getQuantity()+(Double.parseDouble((String) value)  * finalOrderDetail.getQuantity()));
+                            }
+                        });
+                    }
+
+                });
+            }else{
+                orderDetail.setOtherColumns("{}");
             }
-            orderOtherMoneyMapper.update(orderOtherMoney,new QueryWrapper<OrderOtherMoney>()
-                    .eq("order_id",orderOtherMoney.getOrderId())
-                    .eq("`column`",orderOtherMoney.getColumn()));
-        });
+
+        }
+
+        if(orderOtherMoneyLists!=null){
+            orderOtherMoneyLists.forEach(orderOtherMoney ->{
+                orderOtherMoney.setId(null);
+                orderOtherMoney.setOrderId(order.getOrderId());
+                if(orderOtherMoney.getQuantity()!=null && orderOtherMoney.getPrice()!=null){
+                    orderOtherMoney.setMoney((orderOtherMoney.getQuantity()*orderOtherMoney.getPrice()));
+                }else {
+                    orderOtherMoney.setMoney(0.0);
+                }
+                orderOtherMoneyMapper.insert(orderOtherMoney);
+            });
+        }
+
         order.setMoney(money+orderOtherMoneyMapper.selectGrossAmount(order.getOrderId()));
         order.setOtherMoney(orderOtherMoneyMapper.selectGrossAmount(order.getOrderId()));
         orderMapper.updateMoney(order);

--
Gitblit v1.8.0