From 1c5cec37312c58cbc394778bdb649feafd2f8af3 Mon Sep 17 00:00:00 2001
From: guoyuji <guoyujie@ng.com>
Date: 星期五, 30 八月 2024 14:00:58 +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 |  182 +++++++++++++++++++++++++++++++++++++--------
 1 files changed, 150 insertions(+), 32 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 3a1aafb..3a03a09 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
@@ -10,15 +10,22 @@
 import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.example.erp.common.Constants;
 import com.example.erp.dto.sd.OrderDTO;
+import com.example.erp.dto.sd.OrderDetailProductDTO;
 import com.example.erp.entity.sd.*;
+import com.example.erp.entity.userInfo.Log;
 import com.example.erp.entity.userInfo.SysError;
 import com.example.erp.exception.ServiceException;
 import com.example.erp.mapper.sd.*;
+import com.example.erp.service.userInfo.LogService;
 import com.example.erp.service.userInfo.SysErrorService;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.transaction.interceptor.TransactionAspectSupport;
 
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.sql.SQLOutput;
 import java.text.SimpleDateFormat;
 import java.time.LocalDate;
 import java.util.*;
@@ -33,15 +40,19 @@
     private final OrderGlassDetailMapper orderGlassDetailMapper;
     private final SysErrorService sysErrorService;
     private final OrderOtherMoneyMapper orderOtherMoneyMapper;
+    private final ProductMapper productMapper;
+    private final LogService logService;
 
     private final OrderProcessDetailMapper orderProcessDetailMapper;
-    public OrderService(OrderMapper orderMapper, OrderDetailMapper orderDetailMapper, OrderGlassDetailMapper orderGlassDetailMapper, OrderProcessDetailMapper orderProcessDetailMapper, SysErrorService sysErrorService, OrderOtherMoneyMapper orderOtherMoneyMapper) {
+    public OrderService(OrderMapper orderMapper, OrderDetailMapper orderDetailMapper, OrderGlassDetailMapper orderGlassDetailMapper, OrderProcessDetailMapper orderProcessDetailMapper, SysErrorService sysErrorService, OrderOtherMoneyMapper orderOtherMoneyMapper, ProductMapper productMapper, LogService logService) {
         this.orderMapper = orderMapper;
         this.orderDetailMapper = orderDetailMapper;
         this.orderGlassDetailMapper = orderGlassDetailMapper;
         this.orderProcessDetailMapper = orderProcessDetailMapper;
         this.sysErrorService = sysErrorService;
         this.orderOtherMoneyMapper = orderOtherMoneyMapper;
+        this.productMapper = productMapper;
+        this.logService = logService;
     }
 
     public boolean saveOrder(Map<String,Object> orderMap) throws Exception {
@@ -50,22 +61,34 @@
         Order order = JSONObject.parseObject(JSONObject.toJSONString(orderJson.get("title")), Order.class);
         List<OrderDetail> OrderDetails = JSONArray.parseArray(JSONObject.toJSONString(orderJson.get("detail")), OrderDetail.class);
         List<OrderOtherMoney> orderOtherMoneyList = JSONArray.parseArray(JSONObject.toJSONString(orderJson.get("otherMoney")), OrderOtherMoney.class);
-        orderOtherMoneyList = orderOtherMoneyList.stream().filter(o -> o.getColumn().indexOf("M")==0).collect(Collectors.toList());
+        if(orderOtherMoneyList != null ){
+            orderOtherMoneyList = orderOtherMoneyList.stream().filter(o -> o.getColumn().indexOf("M")==0).collect(Collectors.toList());
+        }
+
         boolean saveState = true;
         //璁剧疆鍥炴粴鐐�
         Object savePoint = TransactionAspectSupport.currentTransactionStatus().createSavepoint();
         //鍒ゆ柇浼犲叆id鍙傛暟鏄惁涓虹┖锛屾湭浼犲叆id涓虹┖鎻掑叆璁㈠崟琛紝浼犲叆鏇存柊琛�
         try{
+            Log log = new Log();
+            log.setOperator(orderJson.getString("creator"));
+            log.setOperatorId(orderJson.getString("creatorId"));
+            log.setContent(orderMap.toString());
+
             if(order.getOrderId() == null || order.getOrderId().isEmpty()){
                 insertOrder(order,OrderDetails,orderOtherMoneyList,orderIdType);
+                log.setFunction("saveOrder鍒涘缓:"+order.getOrderId());
             }else {
                 updateOrder(order,OrderDetails,orderOtherMoneyList);
+                log.setFunction("saveOrder淇敼:"+order.getOrderId());
             }
+
+            logService.saveLog(log);
         }catch (Exception e){
             TransactionAspectSupport.currentTransactionStatus().rollbackToSavepoint(savePoint);
             //灏嗗紓甯镐紶鍏ユ暟鎹簱
             SysError sysError = new SysError();
-            sysError.setError(e.toString());
+            sysError.setError(e.toString()+Arrays.toString(e.getStackTrace()));
             sysError.setFunc("saveOrder");
             sysErrorService.insert(sysError);
             saveState = false;
@@ -86,6 +109,7 @@
         try{
             LambdaUpdateWrapper<Order> updateWrapper = new LambdaUpdateWrapper<>();
             updateWrapper.eq(Order::getOrderId, order.getOrderId());
+            order.setCreateTime(null);
             orderMapper.update(order,updateWrapper);
             //淇敼璁㈠崟涓昏〃闈㈢Н涓庡懆闀夸互鍙婇噸閲�
             orderMapper.updateOrderParameter(order.getOrderId());
@@ -148,6 +172,13 @@
             String formattedDate = dateFormat.format(currentDate);
             orderId =  "NG"+formattedDate+formattedNumber;
 
+        }else if(dateType.equals("year")){
+            Integer maxOrderId = orderMapper.selectMaxOrderIdByYear();
+            String formattedNumber = String.format("%06d", maxOrderId+1);
+            Date currentDate = new Date();
+            SimpleDateFormat dateFormat = new SimpleDateFormat("yy");
+            String formattedDate = dateFormat.format(currentDate);
+            orderId =  "NG"+formattedDate+formattedNumber;
         }
 
         return orderId;
@@ -156,6 +187,7 @@
 
     //淇敼璁㈠崟鏁版嵁锛屽苟涓旈噸鏂扮敓鎴愬涓壇琛ㄦ暟鎹�
     public void updateOrder(Order order,List<OrderDetail> OrderDetails,List<OrderOtherMoney> orderOtherMoneyList) {
+        order.setCreateTime(null);
         LambdaUpdateWrapper<Order> updateWrapper = new LambdaUpdateWrapper<>();
         updateWrapper.eq(Order::getOrderId, order.getOrderId());
         orderMapper.update(order,updateWrapper);
@@ -175,7 +207,6 @@
 
     //鎻掑叆鍏朵粬鍓〃鏁版嵁锛岃鍏朵粬鏂规硶寮曠敤
     public void insertOtherDetail(String orderId,List<OrderDetail> OrderDetails,List<OrderOtherMoney> orderOtherMoneyList) {
-
         //鍏堟妸鍏朵粬閲戦鍓〃鐨勯噾棰濅笌鏁伴噺缃�0
         orderOtherMoneyList.forEach(orderOtherMoney -> {
             orderOtherMoney.setQuantity(0.0);
@@ -185,8 +216,10 @@
         for (int i = 0; i < OrderDetails.size(); i++) {
             OrderDetails.get(i).setOrderNumber(i+1);
             OrderDetails.get(i).setOrderId(orderId);
-            OrderDetails.get(i).setPerimeter(Double.valueOf(String.format("%.3f",(OrderDetails.get(i).getWidth()+OrderDetails.get(i).getHeight())*2/1000)));
-            OrderDetails.get(i).setWeight(1.0);
+            OrderDetails.get(i).setPerimeter(Double.valueOf(String.format("%.3f",(OrderDetails.get(i).getWidth()+OrderDetails.get(i).getHeight())*2/1000*OrderDetails.get(i).getQuantity())));
+            Product product = productMapper.selectById(OrderDetails.get(i).getProductId());
+
+            OrderDetails.get(i).setWeight(Double.valueOf(String.format("%.2f",product.getThickness()*OrderDetails.get(i).getWidth()*OrderDetails.get(i).getHeight()/1000000*2.5)));
             if(OrderDetails.get(i).getBendRadius()!=null && OrderDetails.get(i).getBendRadius()!=0){
                 //鑾峰彇寮挗寮у害
                 Double bendRadius = OrderDetails.get(i).getBendRadius();
@@ -200,19 +233,26 @@
 
             Map<String,Object> otherColumns = JSON.parseObject(OrderDetails.get(i).getOtherColumns(), new TypeReference<Map<String, Object>>(){});
             int finalI = i;
-
             if(otherColumns!=null){
+                otherColumns.values().removeIf(value -> value == null || value.equals(""));
+                OrderDetails.get(i).setOtherColumns(JSON.toJSONString(otherColumns));
+
                 otherColumns.forEach((key, value) ->{
-                    if(value!=null && key.contains("M")) {
+
+                    if(value!=null && !value.equals("") && key.contains("M")) {
                         orderOtherMoneyList.forEach(orderOtherMoney -> {
                             if (orderOtherMoney.getColumn().equals(key)) {
-                                orderOtherMoney.setQuantity(orderOtherMoney.getQuantity()+(Double.parseDouble((String) value)  * OrderDetails.get(finalI).getQuantity()));
+                                orderOtherMoney.setQuantity(
+                                        orderOtherMoney.getQuantity()+(Double.parseDouble((String) value)  * OrderDetails.get(finalI).getQuantity()));
                             }
                         });
                     }
 
                 });
+            }else{
+                OrderDetails.get(i).setOtherColumns("{}");
             }
+
         }
 
 
@@ -345,8 +385,15 @@
         double money = 0;
         for (OrderDetail orderDetail : OrderDetails) {
             orderDetail =  updateOrderMoneyComputed(orderDetail,order.getCalculateType());
-            money+= orderDetail.getGrossAmount();
+            BigDecimal getGrossAmount= BigDecimal.valueOf(orderDetail.getGrossAmount());
+            money+=getGrossAmount.doubleValue();
         }
+        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()));
@@ -356,16 +403,21 @@
                     .eq("`column`",orderOtherMoney.getColumn()));
         });
         order.setMoney(money+orderOtherMoneyMapper.selectGrossAmount(order.getOrderId()));
+        order.setOtherMoney(orderOtherMoneyMapper.selectGrossAmount(order.getOrderId()));
         orderMapper.updateMoney(order);
         orderDetailMapper.updateOrderMoney(OrderDetails);
+        logService.saveLog(log);
         return false;
     }
 
     private OrderDetail updateOrderMoneyComputed(OrderDetail orderDetail, Integer calculateType) {
+        BigDecimal getPrice= BigDecimal.valueOf(orderDetail.getPrice());
+        BigDecimal getQuantity= BigDecimal.valueOf(orderDetail.getQuantity());
+        BigDecimal getComputeGrossArea= BigDecimal.valueOf(orderDetail.getComputeGrossArea());
         if (calculateType == 3) {
-            orderDetail.setGrossAmount(orderDetail.getPrice() * orderDetail.getQuantity());
+            orderDetail.setGrossAmount(getPrice.multiply(getQuantity).setScale(2, RoundingMode.HALF_UP).doubleValue());
         } else {
-            orderDetail.setGrossAmount(orderDetail.getComputeGrossArea() * orderDetail.getPrice());
+            orderDetail.setGrossAmount(getPrice.multiply(getComputeGrossArea).setScale(2, RoundingMode.HALF_UP).doubleValue());
         }
         return orderDetail;
     }
@@ -404,6 +456,34 @@
         return orderDetailMapper.exportOrderReport(dates);
     }
 
+    public Map<String,Object> getOrderSummaryReport(Integer pageNum, Integer pageSize, List<String> selectDate, Order order) {
+        Integer offset = (pageNum-1)*pageSize;
+        String endDate = LocalDate.now().toString();
+        String startDate = LocalDate.now().minusDays(15).toString();
+        if(selectDate !=null && selectDate.size()==2){
+            if(!selectDate.get(0).isEmpty()){
+                startDate = selectDate.get(0);
+            }
+            if(!selectDate.get(1).isEmpty()){
+                endDate = selectDate.get(1);
+            }
+        }
+
+        Map<String,Object> map = new HashMap<>();
+        map.put("data",orderDetailMapper.getOrderSummaryReport(offset, pageSize, startDate, endDate, order));
+        map.put("total",orderDetailMapper.getOrderSummaryReportTotal(offset, pageSize, startDate, endDate, order,"order"));
+        List<String> list = new ArrayList<>();
+        list.add(startDate);
+        list.add(endDate);
+        map.put("selectDate",list);
+//        map.put("total",orderMapper.getPageTotal(offset, pageSize, startDate, endDate, orderDetail));
+        return map;
+    }
+
+    public List<Order> exportOrderSummary(List<LocalDate> dates) {
+        return orderDetailMapper.exportOrderSummary(dates);
+    }
+
     public Map<String,Object> getOrderProductSummary(Integer pageNum, Integer pageSize, List<String> selectDate, OrderDetail orderDetail) {
         Integer offset = (pageNum-1)*pageSize;
         String endDate = LocalDate.now().toString();
@@ -432,6 +512,7 @@
         return orderDetailMapper.exportOrderProductSummary(dates);
     }
 
+
     public Map<String,String> getOrderProductDetailTag(String orderId) {
         return orderDetailMapper.getOrderProductDetailTag(orderId);
     }
@@ -453,16 +534,6 @@
             orderProductDetailMap.put("productId",map.get("productId"));
             orderProductDetailMap.put("productName",map.get("productName"));
             List<OrderDetail> orderDetails = orderDetailMapper.getOrderProductByProductId(map.get("productId"),orderId);
-            orderDetails.forEach(orderDetail->{
-
-                orderDetail.setGrossArea(
-                        Double.parseDouble(String.format("%.3f",Double.parseDouble(
-                                String.format("%.3f",
-                                orderDetail.getWidth()*orderDetail.getHeight()/1000000)
-                                ) * orderDetail.getQuantity()))
-                );
-            });
-
             orderProductDetailMap.put("productDetail",orderDetails);
             orderProductDetail.add(orderProductDetailMap);
         });
@@ -488,15 +559,7 @@
             orderProductDetailMap.put("productId",map.get("productId"));
             orderProductDetailMap.put("productName",map.get("productName"));
             List<OrderDetail> orderDetails = orderDetailMapper.getOrderProductByProductId(map.get("productId"),orderId);
-            orderDetails.forEach(orderDetail->{
 
-                orderDetail.setGrossArea(
-                        Double.parseDouble(String.format("%.3f",Double.parseDouble(
-                                String.format("%.3f",
-                                        orderDetail.getWidth()*orderDetail.getHeight()/1000000)
-                        ) * orderDetail.getQuantity()))
-                );
-            });
 
             orderProductDetailMap.put("productDetail",orderDetails);
             orderProductDetail.add(orderProductDetailMap);
@@ -506,6 +569,56 @@
 
         returns.put("orderProductDetail",orderProductDetail);
         returns.put("order",orderMapper.selectOne(new QueryWrapper<Order>().eq("order_id",orderId)));
+        return returns;
+    }
+
+    public Object printOrderProductGlassDetailMonolithic(String orderId,List<String> productId) {
+        List<Map<String,Object>> orderProductDistinct;
+        if (productId.size()>0){
+            orderProductDistinct = orderDetailMapper.getOrderProductDistinctByIds(orderId,productId);
+        }else{
+            orderProductDistinct = orderDetailMapper.getOrderProductDistinctById(orderId);
+        }
+
+        Map<String,Object> returns = new HashMap<>();
+        returns.put("order",orderMapper.selectOne(new QueryWrapper<Order>().eq("order_id",orderId)));
+
+        List<Map<String,Object>> orderProductDetail = new ArrayList<>();
+
+        orderProductDistinct.forEach(map->{
+            Map<String,Object> orderProductDetailMap = new HashMap<>();
+            orderProductDetailMap.put("productId",map.get("productId"));
+            orderProductDetailMap.put("productName",map.get("productName"));
+            List<Map<String,Object>> orderDetails = orderDetailMapper.getOrderProductByProductIds(map.get("productId"),orderId);
+            List<Map<String,Object>> orderProductDetail1 = new ArrayList<>();
+
+            for(Map<String,Object> objectMap:orderDetails){
+                Map<String,Object> orderProductDetailMap1 = new HashMap<>();
+                orderProductDetailMap1.put("detail",objectMap.get("detail").toString());
+                List<Map<String,Object>> orderGlassDetails =orderGlassDetailMapper.getOrderGlassDetailByProductId(objectMap.get("order_id").toString(),
+                        objectMap.get("detail").toString(), Long.valueOf(objectMap.get("product_id").toString()));
+                orderProductDetailMap1.put("orderGlassDetails",orderGlassDetails);
+                orderProductDetail1.add(orderProductDetailMap1);
+            }
+
+            /*orderDetails.forEach(orderDetail->{
+                List<OrderGlassDetail> glassChildList=orderGlassDetailMapper.getOrderGlassDetailByProductIdGlassChild(orderDetail.getOrderId(),orderDetail.getOrderNumber());
+
+                for (OrderGlassDetail glassChildLists:glassChildList){
+                    orderProductDetailMap1.put("glassChild",glassChildLists.getGlassChild());
+                    List<OrderGlassDetail> orderGlassDetails =orderGlassDetailMapper.getOrderGlassDetailByProductId(orderDetail.getOrderId(),orderDetail.getOrderNumber(),glassChildLists.getGlassChild());
+                    Integer differentSize = orderGlassDetailMapper.getDifferentSizeNumber(orderId,orderDetail.getOrderNumber());
+                    orderDetail.setDifferentSize(differentSize);
+                    orderDetail.setOrderGlassDetails(orderGlassDetails);
+                    orderProductDetailMap1.put("orderGlassDetail",orderGlassDetails);
+                }
+                orderProductDetail1.add(orderProductDetailMap1);
+
+            });*/
+            orderProductDetailMap.put("productDetail",orderProductDetail1);
+            orderProductDetail.add(orderProductDetailMap);
+        });
+        returns.put("orderDetail",orderProductDetail);
         return returns;
     }
 
@@ -522,10 +635,11 @@
             List<OrderDetail> orderDetails = orderDetailMapper.getOrderProductByProductId(map.get("productId"),orderId);
             orderDetails.forEach(orderDetail->{
                 orderDetail.setGrossArea(
-                        Double.parseDouble(String.format("%.3f",Double.parseDouble(
+                        /*Double.parseDouble(String.format("%.3f",Double.parseDouble(
                                 String.format("%.3f",
                                         orderDetail.getWidth()*orderDetail.getHeight()/1000000)
-                        ) * orderDetail.getQuantity()))
+                        ) * orderDetail.getQuantity()))*/
+                        orderDetail.getComputeGrossArea()
                 );
 
                 List<OrderGlassDetail> orderGlassDetails =
@@ -555,4 +669,8 @@
 
 
     }
+
+    public boolean updateOrderPrintNumber(String orderId) {
+        return orderMapper.updateOrderPrintNumber(orderId);
+    }
 }

--
Gitblit v1.8.0