From 2e1553e8a7120c2d38d69a8f400dcca2557b09fb Mon Sep 17 00:00:00 2001
From: chenlu <1320612696@qq.com>
Date: 星期五, 26 十二月 2025 15:59:29 +0800
Subject: [PATCH] Merge branch 'master' of http://10.153.19.25:10105/r/ERP_override

---
 north-glass-erp/src/main/java/com/example/erp/service/mm/FinishedGoodsInventoryService.java |  283 ++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 204 insertions(+), 79 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 478ac43..5cdac8c 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
@@ -38,6 +38,8 @@
 import java.text.SimpleDateFormat;
 import java.time.LocalDate;
 import java.time.LocalDateTime;
+import java.time.LocalTime;
+import java.time.format.DateTimeFormatter;
 import java.util.*;
 
 @Service
@@ -702,8 +704,8 @@
         }
 
         Map<String, Object> map = new HashMap<>();
-        map.put("data", finishedOperateLogMapper.getSelectFinishedOperateLogReport(offset, pageSize,startDate, endDate, finishedOperateLog,type));
-        map.put("total", finishedOperateLogMapper.getSelectFinishedOperateLogReportPageTotal(offset, pageSize,startDate, endDate, finishedOperateLog,type));
+        map.put("data", finishedOperateLogMapper.getSelectFinishedOperateLogReport(offset, pageSize,startDate, endDate, finishedOperateLog,type,"date"));
+        map.put("total", finishedOperateLogMapper.getSelectFinishedOperateLogReportPageTotal(offset, pageSize,startDate, endDate, finishedOperateLog,type,"date"));
         List<String> list = new ArrayList<>();
         list.add(startDate);
         list.add(endDate);
@@ -762,91 +764,162 @@
             Order order = orderMapper.selectOne(new QueryWrapper<Order>().eq("order_id",orderId));
             if(order.getWarehousing()!=2){
                 List<OrderDetail> orderDetailList=finishedGoodsInventoryMapper.getSelectOrderDetail(orderId);
-                for (OrderDetail orderDetail:orderDetailList){
-                    FlowCard flowCard  =flowCardMapper.selectOne(
+                for (OrderDetail orderDetail:orderDetailList) {
+                    List<FlowCard> flowCards = flowCardMapper.selectList(
                             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());
+                                    .eq(FlowCard::getOrderId, orderDetail.getOrderId())
+                                    .eq(FlowCard::getOrderNumber, orderDetail.getOrderNumber())
+                                    .groupBy(FlowCard::getOrderId, FlowCard::getOrderNumber,FlowCard::getProcessId));
+                    if (flowCards.isEmpty()) {
+                            FinishedGoodsInventory finishedGoodsInventory = finishedGoodsInventoryMapper.findOrderNumberd(orderDetail.getOrderId(), orderDetail.getOrderNumber());
+                            // 璁$畻鍓╀綑鏁伴噺
+                            long quantity;
+                            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 {
+                                finishedGoodsInventoryMapper.insertOrderFinishedGoodsInventory(orderDetail);
+                            }
+
+                            // 璁板綍鎿嶄綔鏃ュ織
+                            String processId =  "";
+                            finishedOperateLogMapper.insertOrderFinishedOperateLog(orderDetail, userName, oddNumber, processId);
+                            finishedGoodsInventoryMapper.updateOrderNumberConut(orderDetail.getOrderId(), orderDetail.getOrderNumber(), orderDetail.getQuantity());
 
 
-                    // 璁$畻鍓╀綑鏁伴噺
-                    long quantity;
-                    if (flowCard != null) {
-                        quantity = flowCard.getQuantity() - flowCard.getReceivedQuantity();
-                    } else {
-                        quantity = orderDetail.getQuantity() - orderDetail.getWarehouseNum();
-                    }
 
-                    if (quantity <= 0) continue ;
+                    }else{
+                        for (FlowCard flowCard:flowCards){
+                            FinishedGoodsInventory finishedGoodsInventory = finishedGoodsInventoryMapper.findOrderNumberd(orderDetail.getOrderId(), orderDetail.getOrderNumber());
+                            // 璁$畻鍓╀綑鏁伴噺
+                            long quantity;
+                            if (flowCard != null) {
+                                quantity = flowCard.getQuantity() - flowCard.getReceivedQuantity();
+                            } else {
+                                quantity = orderDetail.getQuantity() - orderDetail.getWarehouseNum();
+                            }
 
-                    int calculateType=order.getCalculateType();
-                    double deliveryDetailMoney = 0.0;
-                    double deliveryDetailArea = 0.0;
+                            if (quantity <= 0) continue;
 
-                    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();
+                            int calculateType = order.getCalculateType();
+                            double deliveryDetailMoney = 0.0;
+                            double deliveryDetailArea = 0.0;
 
-                    }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();
+                            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 {
+                                finishedGoodsInventoryMapper.insertOrderFinishedGoodsInventory(orderDetail);
+                            }
+
+                            // 璁板綍鎿嶄綔鏃ュ織
+                            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);
+                            }
                         }
-                    }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 {
-                        finishedGoodsInventoryMapper.insertOrderFinishedGoodsInventory(orderDetail);
-                    }
-
-                    // 璁板綍鎿嶄綔鏃ュ織
-                    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);
                     }
 
                 }
@@ -1463,4 +1536,56 @@
 
         return map;
     }
+
+    public Map<String, Object> getSelectFinishedOperateLogReportByDateTime(String type, Integer pageNum, Integer pageSize, List<String> selectDate, String reportTime, FinishedOperateLog finishedOperateLog) {
+        Integer offset = (pageNum-1)*pageSize;
+        String startDate = toReportTime(LocalDate.now().minusDays(7).toString(), reportTime);
+        String endDate   = toReportTime(LocalDate.now().toString(), reportTime);
+
+        // 濡傛灉鍓嶇浼犱簡鏃堕棿锛屽氨鐢ㄥ墠绔棩鏈� + reportTime
+        if (selectDate != null && selectDate.size() == 2) {
+            if (selectDate.get(0) != null && !selectDate.get(0).isEmpty()) {
+                startDate = toReportTime(selectDate.get(0), reportTime);
+            }
+            if (selectDate.get(1) != null && !selectDate.get(1).isEmpty()) {
+                endDate = toReportTime(selectDate.get(1), reportTime);
+            }
+        }
+
+        Map<String, Object> map = new HashMap<>();
+        map.put("data", finishedOperateLogMapper.getSelectFinishedOperateLogReport(offset, pageSize,startDate, endDate, finishedOperateLog,type,"datetime"));
+        map.put("total", finishedOperateLogMapper.getSelectFinishedOperateLogReportPageTotal(offset, pageSize,startDate, endDate, finishedOperateLog,type,"datetime"));
+        List<String> list = new ArrayList<>();
+        list.add(startDate);
+        list.add(endDate);
+        map.put("selectDate",list);
+        return map;
+    }
+
+    private static final DateTimeFormatter DATE_TIME_FMT =
+            DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
+
+    private String toReportTime(String dateStr, String reportTime) {
+        if (dateStr == null || dateStr.isEmpty()) {
+            return null;
+        }
+
+        // 鍙繚鐣� yyyy-MM-dd锛岄槻姝㈠墠绔紶瀹屾暣鏃堕棿瀵艰嚧 parse 寮傚父
+        String onlyDate = dateStr.length() > 10 ? dateStr.substring(0, 10) : dateStr;
+
+
+        String[] parts = reportTime.split(":");
+        int hour   = Integer.parseInt(parts[0]);
+        int minute = parts.length > 1 ? Integer.parseInt(parts[1]) : 0;
+        int second = parts.length > 2 ? Integer.parseInt(parts[2]) : 0;
+
+        LocalDate date = LocalDate.parse(onlyDate);
+        LocalTime time = LocalTime.of(hour, minute, second);
+
+        return LocalDateTime.of(date, time).format(DATE_TIME_FMT);
+    }
+
+    public List<FinishedOperateLogDTO>  exportFinishedOperateLogReportByDatetime(List<String> dates, String type) {
+        return finishedOperateLogMapper.exportFinishedOperateLogReportByDatetime(dates,type);
+    }
 }

--
Gitblit v1.8.0