From ae106d4b363018dcfaa4359b57b61f3a7043fcad Mon Sep 17 00:00:00 2001
From: 廖井涛 <2265517004@qq.com>
Date: 星期一, 01 七月 2024 15:23:36 +0800
Subject: [PATCH] Merge branch 'master' of http://bore.pub:10439/r/ERP_override

---
 north-glass-erp/src/main/java/com/example/erp/service/sd/DeliveryService.java |   70 +++++++++++++++++++++++++++++++----
 1 files changed, 62 insertions(+), 8 deletions(-)

diff --git a/north-glass-erp/src/main/java/com/example/erp/service/sd/DeliveryService.java b/north-glass-erp/src/main/java/com/example/erp/service/sd/DeliveryService.java
index 6e1fa78..166c1a6 100644
--- a/north-glass-erp/src/main/java/com/example/erp/service/sd/DeliveryService.java
+++ b/north-glass-erp/src/main/java/com/example/erp/service/sd/DeliveryService.java
@@ -19,6 +19,7 @@
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.transaction.interceptor.TransactionAspectSupport;
 
+import java.lang.reflect.Field;
 import java.text.SimpleDateFormat;
 import java.time.LocalDate;
 import java.util.*;
@@ -221,12 +222,27 @@
             //鑾峰彇瀵硅薄闆嗗悎寰幆杩涜鏂板淇敼
             if (!orderDetaillist.isEmpty()) {
                 for (OrderDetail orderDetail : orderDetaillist) {
+                    //鏍规嵁璁㈠崟璁$畻鏂瑰紡杩涜閲戦璁$畻
+                    double deliveryDetailMoney = 0.0;
+                    if (orderDetail.getOrder().getCalculateType()==1){
+                        deliveryDetailMoney=Double.valueOf(String.format("%.2f",Double.valueOf(String.format("%.2f", (orderDetail.getWidth()*orderDetail.getHeight()/1000000)))
+                                *orderDetail.getDeliveryDetail().getQuantity()*orderDetail.getPrice()));
+                    }else if (orderDetail.getOrder().getCalculateType()==2){
+                        deliveryDetailMoney=Double.valueOf(String.format("%.2f",Double.valueOf(
+                                String.format("%.2f", (orderDetail.getWidth()*orderDetail.getHeight()/1000000)*orderDetail.getDeliveryDetail().getQuantity())
+                                )*orderDetail.getPrice()));
+                    }else if (orderDetail.getOrder().getCalculateType()==3){
+                        deliveryDetailMoney=Double.valueOf(String.format("%.2f",orderDetail.getPrice() * orderDetail.getDeliveryDetail().getQuantity()));
 
+                    }
+
+                    //瀵瑰惊鐜槑缁嗙殑鏁版嵁杩涜绱姞
                     quantity += orderDetail.getDeliveryDetail().getQuantity();
-                    area += orderDetail.getFinishedGoodsInventory().getActualSignalArea() * orderDetail.getDeliveryDetail().getQuantity();
-                    money += orderDetail.getPrice() * orderDetail.getDeliveryDetail().getQuantity();
+                    area += orderDetail.getComputeArea() * orderDetail.getDeliveryDetail().getQuantity();
+                    money += deliveryDetailMoney;
                     Integer deliveryDetailmaximum = deliveryDetailMapper.getdeliveryDetailmaximum(oddNumber);
 
+                    //棰濆閲戦淇敼
                     Map<String,Double> otherColumns = JSON.parseObject(orderDetail.getOtherColumns(), new TypeReference<Map<String, Double>>(){});
                     if(otherColumns!=null){
                         otherColumns.forEach((key, value) ->{
@@ -242,7 +258,7 @@
                     }
 
                     //鏂板鍙戣揣鏄庣粏鏁版嵁
-                    deliveryDetailMapper.insertDeliveryDetail(orderDetail, oddNumber, deliveryDetailmaximum + 1);
+                    deliveryDetailMapper.insertDeliveryDetail(orderDetail, oddNumber, deliveryDetailmaximum + 1,deliveryDetailMoney);
                     //淇敼璁㈠崟鏄庣粏
                     deliveryDetailMapper.updateOrderDetailDeliveryNum(orderDetail);
                     //淇敼搴撳瓨琛ㄥ嚭搴撴暟閲�
@@ -328,25 +344,63 @@
 
     }
 
-    public Map<String, Object> getSelectDeliveryPrinting( DeliveryDetail deliveryDetail) {
+    public Map<String, Object> getSelectDeliveryPrinting( DeliveryDetail deliveryDetail) throws IllegalAccessException {
         Map<String, Object> map = new HashMap<>();
         List <Map<String, Object>> list=new ArrayList<Map<String, Object>>();//鏈�缁堢粨鏋�
+        List <Map<String, Object>> moneryList=new ArrayList<Map<String, Object>>();//鏈�缁堢粨鏋�
         List<DeliveryDetail> deliveryDetailList=deliveryDetailMapper.getSelectDeliveryPrinting(deliveryDetail);
+        String orderId="";
         for (DeliveryDetail detail : deliveryDetailList) {
-
+            orderId=detail.getOrderDetail().getOrderId();
             Map<String, Object> itemmap = new HashMap<>();
+
             List<Map<String, Object>> deliveryDetailList2 = deliveryDetailMapper.getSelectDeliveryDetailPrinting(detail.getDeliveryId(),
                     detail.getOrderDetail().getProductId(), detail.getOrderDetail().getOrderId());
+            for (Map<String, Object> stringObjectMap : deliveryDetailList2) {
+                if(stringObjectMap.get("other_columns")!=null){
+                    JSONObject jsonObject = JSON.parseObject(stringObjectMap.get("other_columns").toString());
+                    for(String key : jsonObject.keySet()){
+                        Map<String, Object> moneryItemmap = new HashMap<>();
+                        List<Map<String, Object>> deliveryDetailOtherMoney = deliveryDetailMapper.getSelectotherMoney(detail.getOrderDetail().getOrderId(),detail.getDeliveryId(),key,jsonObject.get(key).toString());
+                        moneryItemmap.put("DeliveryDetailOtherMoney", deliveryDetailOtherMoney);
+                        moneryList.add(moneryItemmap);
+                    }
+
+                }
+            }
+            itemmap.put("DeliveryDetail", detail);
+            itemmap.put("DeliveryDetailList", deliveryDetailList2);
+            list.add(itemmap);
+
+        }
+        Delivery delivery=deliveryMapper.getSelectShippingOrderDetailDeliveryPrinting(deliveryDetail);
+        map.put("data", list);
+        map.put("otherMoney",moneryList);
+        map.put("delivery", deliveryMapper.getSelectShippingOrderDetailDeliveryPrinting(deliveryDetail));
+        map.put("money", toChinese(delivery.getMoney().toString(), false));
+        return map;
+
+    }
+
+    public Map<String, Object> getSelectOrderPrinting(OrderDetail orderDetail) {
+        Map<String, Object> map = new HashMap<>();
+        List <Map<String, Object>> list=new ArrayList<Map<String, Object>>();//鏈�缁堢粨鏋�
+        List<OrderDetail> orderDetailList=deliveryDetailMapper.getSelectOrderPrinting(orderDetail);
+        for (OrderDetail detail : orderDetailList) {
+
+            Map<String, Object> itemmap = new HashMap<>();
+            List<Map<String, Object>> deliveryDetailList2 = deliveryDetailMapper.getSelectOrderDetailPrinting(
+                    detail.getProductId(), detail.getOrderId());
             itemmap.put("DeliveryDetail", detail);
             itemmap.put("DeliveryDetailList", deliveryDetailList2);
             list.add(itemmap);
 
 
         }
-        Delivery delivery=deliveryMapper.getSelectShippingOrderDetailDeliveryPrinting(deliveryDetail);
+        Order order=deliveryMapper.getSelectShippingOrderDetailPrinting(orderDetail);
         map.put("data", list);
-        map.put("delivery", deliveryMapper.getSelectShippingOrderDetailDeliveryPrinting(deliveryDetail));
-        map.put("money", toChinese(delivery.getMoney().toString(), false));
+        map.put("delivery", deliveryMapper.getSelectShippingOrderDetailPrinting(orderDetail));
+        map.put("money", toChinese(order.getMoney().toString(), false));
         return map;
 
     }

--
Gitblit v1.8.0