From 99001b4d8f246d12c409e14dcb7fb3e26b7cfaaf Mon Sep 17 00:00:00 2001
From: guoyuji <guoyujie@ng.com>
Date: 星期五, 05 七月 2024 13:16:10 +0800
Subject: [PATCH] 提交错误信息方式

---
 north-glass-erp/src/main/java/com/example/erp/service/sd/OrderService.java |   71 ++++++++++++++++++-----------------
 1 files changed, 36 insertions(+), 35 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 eb47703..54b978a 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,6 +10,7 @@
 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.SysError;
 import com.example.erp.exception.ServiceException;
@@ -46,6 +47,7 @@
 
     public boolean saveOrder(Map<String,Object> orderMap) throws Exception {
         JSONObject orderJson = new JSONObject(orderMap);
+        String orderIdType = orderJson.getString("orderIdType");
         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);
@@ -56,7 +58,7 @@
         //鍒ゆ柇浼犲叆id鍙傛暟鏄惁涓虹┖锛屾湭浼犲叆id涓虹┖鎻掑叆璁㈠崟琛紝浼犲叆鏇存柊琛�
         try{
             if(order.getOrderId() == null || order.getOrderId().isEmpty()){
-                insertOrder(order,OrderDetails,orderOtherMoneyList);
+                insertOrder(order,OrderDetails,orderOtherMoneyList,orderIdType);
             }else {
                 updateOrder(order,OrderDetails,orderOtherMoneyList);
             }
@@ -64,7 +66,7 @@
             TransactionAspectSupport.currentTransactionStatus().rollbackToSavepoint(savePoint);
             //灏嗗紓甯镐紶鍏ユ暟鎹簱
             SysError sysError = new SysError();
-            sysError.setError(e.toString());
+            sysError.setError(Arrays.toString(e.getStackTrace()));
             sysError.setFunc("saveOrder");
             sysErrorService.insert(sysError);
             saveState = false;
@@ -117,24 +119,42 @@
         return map;
     }
     //鐢熸垚璁㈠崟鏁版嵁
-    public void insertOrder(Order order,List<OrderDetail> OrderDetails,List<OrderOtherMoney> orderOtherMoneyList) {
-        Integer maxOrderId = orderMapper.selectMaxOrderId();
-        //鏌ヨ璁㈠崟id锛屽苟涓旇嚜澧�
-        String formattedNumber = String.format("%02d", maxOrderId+1);
-        //鏍煎紡鍖栧綋鍓嶆棩鏈�
-        Date currentDate = new Date();
-        SimpleDateFormat dateFormat = new SimpleDateFormat("yyMMdd");
-        String formattedDate = dateFormat.format(currentDate);
-        String orderId =  "NG"+formattedDate+formattedNumber;
+    public void insertOrder(Order order, List<OrderDetail> OrderDetails, List<OrderOtherMoney> orderOtherMoneyList, String orderIdType) {
+        //鏍规嵁浼犲叆鐨勫綋鍓嶆湀浠芥垨鑰呭綋澶╃敓鎴愯鍗昳d
+        String orderId =  getOrderId(orderIdType);
         //寰�涓昏〃鎻掓暟鎹�
         order.setOrderId(orderId);
         order.setCreateOrder(2);
         orderMapper.insert(order);
 
         insertOtherDetail(orderId,OrderDetails,orderOtherMoneyList);
-
-
     }
+
+    private String getOrderId(String dateType){
+        String orderId = null;
+        if(dateType.equals("day")){
+            Integer maxOrderId = orderMapper.selectMaxOrderId();
+            //鏌ヨ璁㈠崟id锛屽苟涓旇嚜澧�
+            String formattedNumber = String.format("%02d", maxOrderId+1);
+            //鏍煎紡鍖栧綋鍓嶆棩鏈�
+            Date currentDate = new Date();
+            SimpleDateFormat dateFormat = new SimpleDateFormat("yyMMdd");
+            String formattedDate = dateFormat.format(currentDate);
+            orderId =  "NG"+formattedDate+formattedNumber;
+        }else if(dateType.equals("month")){
+            Integer maxOrderId = orderMapper.selectMaxOrderIdByMonth();
+            String formattedNumber = String.format("%04d", maxOrderId+1);
+            Date currentDate = new Date();
+            SimpleDateFormat dateFormat = new SimpleDateFormat("yyMM");
+            String formattedDate = dateFormat.format(currentDate);
+            orderId =  "NG"+formattedDate+formattedNumber;
+
+        }
+
+        return orderId;
+    }
+
+
     //淇敼璁㈠崟鏁版嵁锛屽苟涓旈噸鏂扮敓鎴愬涓壇琛ㄦ暟鎹�
     public void updateOrder(Order order,List<OrderDetail> OrderDetails,List<OrderOtherMoney> orderOtherMoneyList) {
         LambdaUpdateWrapper<Order> updateWrapper = new LambdaUpdateWrapper<>();
@@ -166,7 +186,7 @@
         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).setPerimeter(Double.valueOf(String.format("%.3f",(OrderDetails.get(i).getWidth()+OrderDetails.get(i).getHeight())*2/1000*OrderDetails.get(i).getQuantity())));
             OrderDetails.get(i).setWeight(1.0);
             if(OrderDetails.get(i).getBendRadius()!=null && OrderDetails.get(i).getBendRadius()!=0){
                 //鑾峰彇寮挗寮у害
@@ -269,19 +289,7 @@
         Order order = orderMapper.selectOne(new QueryWrapper<Order>().eq("order_id",id));
         List<OrderDetail> orderDetails = orderDetailMapper.selectList(new QueryWrapper<OrderDetail>().eq("order_id",id));
         List<OrderOtherMoney> orderOtherMoneyList = orderOtherMoneyMapper.findById(id);
-        orderDetails.forEach(orderDetail -> {
-            List<OrderGlassDetail> orderGlassDetails = orderGlassDetailMapper.selectList(
-                    new QueryWrapper<OrderGlassDetail>()
-                            .eq("order_id",orderDetail.getOrderId())
-                            .eq("order_number",orderDetail.getOrderNumber())
-            );
-            orderGlassDetails.forEach(orderGlassDetail -> {
-                orderGlassDetail.setProductId(orderDetail.getProductId());
-                orderGlassDetail.setWidth(orderDetail.getWidth());
-                orderGlassDetail.setHeight(orderDetail.getHeight());
-            });
-            orderDetail.setOrderGlassDetails(orderGlassDetails);
-        });
+
 
         Map<String,Object> map = new HashMap<>();
         map.put("order",order);
@@ -425,6 +433,7 @@
         return orderDetailMapper.exportOrderProductSummary(dates);
     }
 
+
     public Map<String,String> getOrderProductDetailTag(String orderId) {
         return orderDetailMapper.getOrderProductDetailTag(orderId);
     }
@@ -481,15 +490,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);

--
Gitblit v1.8.0