From 761d13616d43b147142d7d33da3a646f6ac15397 Mon Sep 17 00:00:00 2001
From: rk <94314517@qq.com>
Date: 星期一, 27 四月 2026 22:25:29 +0800
Subject: [PATCH] 代码生成

---
 server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java |  264 ++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 182 insertions(+), 82 deletions(-)

diff --git a/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java b/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java
index 888e25a..aec4757 100644
--- a/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java
+++ b/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java
@@ -17,6 +17,7 @@
 import com.doumee.core.model.PageData;
 import com.doumee.core.model.PageWrap;
 import com.doumee.core.utils.DateUtil;
+import com.doumee.core.utils.ID;
 import com.doumee.core.utils.geocode.MapUtil;
 import com.doumee.core.utils.Utils;
 import com.doumee.core.utils.aliyun.AliSmsService;
@@ -237,7 +238,14 @@
                 queryWrapper.orderByAsc(sortData.getProperty());
             }
         }
-        return PageData.from(ordersMapper.selectJoinPage(page, Orders.class, queryWrapper));
+        PageData<Orders> pageData = PageData.from(ordersMapper.selectJoinPage(page, Orders.class, queryWrapper));
+        for (Orders o : pageData.getRecords()) {
+            if (o.getStatus() != null) {
+                Constants.OrderStatus os = Constants.OrderStatus.getByKey(o.getStatus());
+                o.setStatusDesc(os != null ? os.getValue() : "");
+            }
+        }
+        return pageData;
     }
 
     @Override
@@ -698,7 +706,7 @@
                 // 鏃犲彇浠堕棬搴楋紝鏍¢獙瀛樹欢鐐逛笌鑷�夊彇浠剁偣鏄惁鍦ㄥ悓涓�鍩庡競
                 if (!MapUtil.isSameCity(depositShop.getLatitude(), depositShop.getLongitude(),
                         dto.getTakeLat().doubleValue(), dto.getTakeLgt().doubleValue())) {
-                    throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "寮傚湴瀵勫瓨璁㈠崟瀛樺彇鐐逛笉鍦ㄥ悓涓�鍩庡競锛屽闇�璇烽�夋嫨鍚屽煄闂ㄥ簵");
+                    throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "瀛樺彇鐐逛笉鍦ㄥ悓涓�鍩庡競锛�");
                 }
                 takeLat = dto.getTakeLat();
                 takeLgt = dto.getTakeLgt();
@@ -785,6 +793,7 @@
             // 寮傚湴锛氬彇浠剁偣淇℃伅
             orders.setTakeShopId(dto.getTakeShopId());
             orders.setTakeLocation(takeLocationValue);
+            orders.setTakeLocationRemark(takeLocationValue);
             orders.setTakeLat(takeLat);
             orders.setTakeLgt(takeLgt);
             orders.setIsUrgent(dto.getIsUrgent());
@@ -793,6 +802,7 @@
             // 灏卞湴锛氬彇浠剁偣鍚屽瘎浠跺簵閾�
             orders.setTakeShopId(dto.getDepositShopId());
             orders.setTakeLocation(depositShop.getAddress());
+            orders.setTakeLocationRemark(depositShop.getAddress());
             orders.setTakeLat(BigDecimal.valueOf(depositShop.getLatitude()));
             orders.setTakeLgt(BigDecimal.valueOf(depositShop.getLongitude()));
             orders.setIsUrgent(Constants.ZERO);
@@ -836,6 +846,19 @@
 
         ordersMapper.insert(orders);
         Integer orderId = orders.getId();
+
+        // 鍒涘缓璁㈠崟鏃ュ織
+        OrderLog createLog = new OrderLog();
+        createLog.setOrderId(orderId);
+        createLog.setTitle(Constants.OrderLogType.createOrder.getTitle());
+        createLog.setLogInfo(Constants.OrderLogType.createOrder.format(orderCode));
+        createLog.setObjType(Constants.OrderLogType.createOrder.getStatus());
+        createLog.setOrderStatus(orders.getStatus());
+        createLog.setOptUserId(memberId);
+        createLog.setOptUserType(0);
+        createLog.setCreateTime(now);
+        createLog.setDeleted(Constants.ZERO);
+        orderLogService.create(createLog);
 
         // ========== 7. 鍒涘缓璁㈠崟鏄庣粏 ==========
         for (ItemPriceVO itemVO : priceResult.getItemList()) {
@@ -987,6 +1010,12 @@
         OrderDetailVO vo = new OrderDetailVO();
         vo.setOrder(order);
 
+        // 璁㈠崟鐘舵�佹弿杩�
+        if (order.getStatus() != null) {
+            Constants.OrderStatus os = Constants.OrderStatus.getByKey(order.getStatus());
+            vo.setStatusDesc(os != null ? os.getValue() : "");
+        }
+
         // 鍥剧墖璺緞鍓嶇紑
         String imgPrefix = getOrdersPrefix();
 
@@ -1111,19 +1140,6 @@
 
         String optUserName = getCurrentUserName();
 
-        // 鍔犳�ヨ垂鏃ュ織
-        OrderLog feeLog = new OrderLog();
-        feeLog.setOrderId(order.getId());
-        feeLog.setTitle(Constants.OrderLogType.urgent.getTitle());
-        feeLog.setLogInfo(Constants.OrderLogType.urgent.format(dto.getUrgentFee().toPlainString()));
-        feeLog.setObjType(Constants.OrderLogType.urgent.getStatus());
-        feeLog.setOrderStatus(order.getStatus());
-        feeLog.setOptUserType(3);
-        feeLog.setOptUserName(optUserName);
-        feeLog.setCreateTime(new Date());
-        feeLog.setDeleted(Constants.ZERO);
-        orderLogService.create(feeLog);
-
         // 鍔犳�ヨ垂鐢� 鍏冣啋鍒�
         long urgentFeeFen = dto.getUrgentFee().multiply(new BigDecimal(100)).longValue();
 
@@ -1148,9 +1164,30 @@
             updateWrapper.set(Orders::getRemark, dto.getRemark());
         }
 
-        // 鎸囨淳鍙告満锛堥潪蹇呭~锛�
+        // 鏃ュ織锛氬彧瀛樹竴鏉★紝鏈夊徃鏈虹敤 assignDriver锛屾棤鍙告満鐢� urgent
         if (dto.getDriverId() != null) {
+            // 鏍¢獙鍙告満淇℃伅
+            DriverInfo driverInfo = driverInfoMapper.selectOne(new QueryWrapper<DriverInfo>().lambda()
+                    .eq(DriverInfo::getMemberId, dto.getDriverId())
+                    .eq(DriverInfo::getDeleted, Constants.ZERO)
+                    .last("limit 1"));
+            if (driverInfo == null) {
+                throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(), "鍙告満淇℃伅涓嶅瓨鍦�");
+            }
+            if (!Integer.valueOf(3).equals(driverInfo.getAuditStatus())) {
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "鍙告満鏈敮浠樻娂閲戯紝鏃犳硶娲惧崟");
+            }
+            if (!Constants.ZERO.equals(driverInfo.getStatus())) {
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "鍙告満宸茶绂佺敤锛屾棤娉曟淳鍗�");
+            }
+
+            // 鏇存柊鎺ュ崟鍙告満淇℃伅鍙婅鍗曠姸鎬�
+            Date now = new Date();
             updateWrapper.set(Orders::getAssignDriverId, dto.getDriverId());
+            updateWrapper.set(Orders::getAcceptDriver, dto.getDriverId());
+            updateWrapper.set(Orders::getAcceptTime, now);
+            updateWrapper.set(Orders::getAcceptType, 1); // 1=绯荤粺娲惧崟
+            updateWrapper.set(Orders::getStatus, Constants.OrderStatus.accepted.getStatus());
 
             Member driver = memberMapper.selectById(dto.getDriverId());
             String driverName = driver != null ? driver.getName() : String.valueOf(dto.getDriverId());
@@ -1160,32 +1197,37 @@
             driverLog.setTitle(Constants.OrderLogType.assignDriver.getTitle());
             driverLog.setLogInfo(Constants.OrderLogType.assignDriver.format(driverName, dto.getUrgentFee().toPlainString()));
             driverLog.setObjType(Constants.OrderLogType.assignDriver.getStatus());
-            driverLog.setOrderStatus(order.getStatus());
+            driverLog.setOrderStatus(Constants.OrderStatus.accepted.getStatus());
             driverLog.setOptUserType(3);
             driverLog.setOptUserName(optUserName);
-            driverLog.setCreateTime(new Date());
+            driverLog.setCreateTime(now);
             driverLog.setDeleted(Constants.ZERO);
             orderLogService.create(driverLog);
 
             // 鐭俊閫氱煡鎸囨淳鍙告満锛堝姞鎬ユ淳鍗曪級
-            DriverInfo driverInfo = driverInfoMapper.selectOne(new QueryWrapper<DriverInfo>().lambda()
-                    .eq(DriverInfo::getMemberId, dto.getDriverId())
-                    .eq(DriverInfo::getDeleted, Constants.ZERO)
-                    .last("limit 1"));
-            if (driverInfo != null) {
-                String address1 = order.getDepositShopAddress() != null ? order.getDepositShopAddress() : order.getDepositShopName();
-                String address2 = order.getTakeShopAddress() != null ? order.getTakeShopAddress() :
-                        (order.getTakeLocation() != null ? order.getTakeLocation() : "");
-                // 閰嶉�佽垂 = 鍙告満閰嶉�佽垂 + 鍔犳�ヨ垂
-                long totalDriverFee = (order.getDriverFee() != null ? order.getDriverFee() : 0L) + urgentFeeFen;
-                sendSmsNotify(driverInfo.getTelephone(),
-                        Constants.SmsNotify.DRIVER_URGENT_DISPATCH,
-                        "orderNo", order.getCode(),
-                        "address1", address1,
-                        "address2", address2,
-                        "money1", String.valueOf(totalDriverFee / 100.0),
-                        "money2", String.valueOf(urgentFeeFen / 100.0));
-            }
+            String address1 = order.getDepositLocationRemark();
+            String address2 = order.getTakeLocationRemark();
+            long totalDriverFee = (order.getDriverFee() != null ? order.getDriverFee() : 0L) + urgentFeeFen;
+            sendSmsNotify(driverInfo.getTelephone(),
+                    Constants.SmsNotify.DRIVER_URGENT_DISPATCH,
+                    "orderNo", order.getCode(),
+                    "address1", address1,
+                    "address2", address2,
+                    "money1", String.valueOf(totalDriverFee / 100.0),
+                    "money2", String.valueOf(urgentFeeFen / 100.0));
+        } else {
+            // 鏈寚娲惧徃鏈猴紝鍙褰曞姞鎬ユ棩蹇�
+            OrderLog feeLog = new OrderLog();
+            feeLog.setOrderId(order.getId());
+            feeLog.setTitle(Constants.OrderLogType.urgent.getTitle());
+            feeLog.setLogInfo(Constants.OrderLogType.urgent.format(dto.getUrgentFee().toPlainString()));
+            feeLog.setObjType(Constants.OrderLogType.urgent.getStatus());
+            feeLog.setOrderStatus(order.getStatus());
+            feeLog.setOptUserType(3);
+            feeLog.setOptUserName(optUserName);
+            feeLog.setCreateTime(new Date());
+            feeLog.setDeleted(Constants.ZERO);
+            orderLogService.create(feeLog);
         }
 
         ordersMapper.update(updateWrapper);
@@ -1526,7 +1568,7 @@
 
         wrapper.eq(status != null, Orders::getStatus, status)
                 .in(statusList != null && !Constants.equalsInteger(combinedStatus, Constants.SEVEN), Orders::getStatus, statusList)
-                .orderByDesc(Orders::getCreateTime);
+                .orderByDesc(Orders::getId);
 
         IPage<Orders> orderPage = ordersMapper.selectJoinPage(p, Orders.class, wrapper);
         List<MyOrderVO> voList = new ArrayList<>();
@@ -1888,9 +1930,10 @@
                     Constants.SmsNotify.MEMBER_CANCELLED, "orderNo", order.getCode());
 
             // 璋冪敤寰俊閫�娆綱3锛屽叏棰濋��娆�
+            String outRefundNo = ID.nextGUID();
             com.wechat.pay.java.service.refund.model.Refund refundResult;
             try {
-                refundResult = wxPayV3Service.refund(order.getOutTradeNo(), order.getPayAmount(), order.getPayAmount(),
+                refundResult = wxPayV3Service.refund(outRefundNo, order.getOutTradeNo(), order.getPayAmount(), order.getPayAmount(),
                         "璁㈠崟閫�娆�", wxPayProperties.getV3RefundNotifyUrl());
             } catch (Exception e) {
                 log.error("寰呭瘎瀛樿鍗曢��娆捐皟鐢ㄥ紓甯�, orderId={}", orderId, e);
@@ -1908,7 +1951,7 @@
             refund.setDeleted(Constants.ZERO);
             refund.setBeforeStatus(Constants.OrderStatus.waitDeposit.getStatus());
             refund.setRefundAmount(order.getPayAmount());
-            refund.setRefundCode(refundResult.getOutRefundNo());
+            refund.setRefundCode(outRefundNo);
 
             if (com.wechat.pay.java.service.refund.model.Status.SUCCESS.equals(refundStatus)) {
                 // 閫�娆炬垚鍔�
@@ -1950,7 +1993,8 @@
                     .set(Orders::getTakeLocation, order.getDepositLocation())
                     .set(Orders::getTakeLocationRemark, order.getDepositLocationRemark())
                     .set(Orders::getTakeLat, order.getDepositLat())
-                    .set(Orders::getTakeLgt, order.getDepositLgt());
+                    .set(Orders::getTakeLgt, order.getDepositLgt())
+                    .set(Orders::getExpectedTakeTime, new Date());
             if (Constants.equalsInteger(status, Constants.OrderStatus.accepted.getStatus())) {
                 updateWrapper.lambda()
                         .set(Orders::getAcceptDriver, null)
@@ -2116,6 +2160,20 @@
             }
         }
         ordersMapper.updateById(order);
+
+        // 鏀粯鎴愬姛鏃ュ織
+        OrderLog payLog = new OrderLog();
+        payLog.setOrderId(order.getId());
+        payLog.setTitle(Constants.OrderLogType.payOrder.getTitle());
+        payLog.setLogInfo(Constants.OrderLogType.payOrder.format(
+                String.valueOf(order.getTotalAmount() != null ? order.getTotalAmount() / 100.0 : 0)));
+        payLog.setObjType(Constants.OrderLogType.payOrder.getStatus());
+        payLog.setOrderStatus(order.getStatus());
+        payLog.setOptUserId(order.getMemberId());
+        payLog.setOptUserType(0);
+        payLog.setCreateTime(now);
+        payLog.setDeleted(Constants.ZERO);
+        orderLogService.create(payLog);
 
         // 閫氱煡浼氬憳锛氳鍗曞緟鏍搁獙
         sendOrderNotice(order.getMemberId(), Constants.MemberOrderNotify.WAIT_VERIFY, order.getId(),
@@ -2665,7 +2723,7 @@
             if (!shopId.equals(order.getDepositShopId())) {
                 throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "璇ヨ鍗曚笉灞炰簬褰撳墠闂ㄥ簵锛屾棤娉曟牳閿�");
             }
-            order.setStatus(Constants.OrderStatus.deposited.getStatus());
+            order.setStatus(Constants.equalsInteger(order.getType(),Constants.ZERO)?Constants.OrderStatus.arrived.getStatus():Constants.OrderStatus.deposited.getStatus());
             order.setDepositTime(now);
             // 閲婃斁褰撳墠鏍搁攢鐮侊紝鐢熸垚鏂扮殑鏍搁攢鐮佷緵鍙栦欢鏃朵娇鐢�
             String verifyCode = order.getMemberVerifyCode();
@@ -2735,7 +2793,64 @@
                         "orderNo", order.getCode(),
                         "settleDays", settleDays != null ? settleDays : "7");
             }
-        } else {
+        }else if(Constants.equalsInteger(order.getStatus(), Constants.OrderStatus.delivering.getKey())){
+            // 浠呭紓鍦板瘎瀛� + 鏈夊彇浠堕棬搴� + 娲鹃�佷腑(4) 鍙牳閿�
+            if (!Constants.equalsInteger(order.getType(), Constants.ONE)) {
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "浠呭紓鍦板瘎瀛樿鍗曟敮鎸佸徃鏈烘牳閿�");
+            }
+            if (order.getTakeShopId() == null) {
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "璇ヨ鍗曟棤鍙栦欢闂ㄥ簵锛屾棤闇�鍙告満鏍搁攢");
+            }
+            if (!Constants.equalsInteger(order.getStatus(), Constants.OrderStatus.delivering.getStatus())) {
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "褰撳墠璁㈠崟鐘舵�佷笉鍏佽鏍搁攢");
+            }
+            // 鏍¢獙鍙栦欢闂ㄥ簵涓庡綋鍓嶇櫥褰曢棬搴椾竴鑷�
+            if (!shopId.equals(order.getTakeShopId())) {
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "璇ヨ鍗曚笉灞炰簬褰撳墠闂ㄥ簵锛屾棤娉曟牳閿�");
+            }
+            // 娲鹃�佷腑(4) 鈫� 宸插埌搴�(5)
+            order.setStatus(Constants.OrderStatus.arrived.getStatus());
+            order.setArriveTime(new Date());
+            if (StringUtils.isNotBlank(remark)) {
+                order.setRemark(remark);
+            }
+            ordersMapper.updateById(order);
+
+            // 閲婃斁鍙告満鏍搁攢鐮�
+            releaseVerifyCode(order.getDriverVerifyCode());
+
+            // 淇濆瓨闄勪欢锛坥bj_type=3 闂ㄥ簵鍏ュ簱鍥剧墖锛屾渶澶�3寮狅級
+            saveVerifyImages(order.getId(), images, Constants.FileType.ORDER_TAKE.getKey(), order.getAcceptDriver());
+
+            // 閫氱煡浼氬憳锛氳鍗曞凡閫佽揪
+            String destination = order.getTakeShopAddress() != null ? order.getTakeShopAddress() : "";
+            if (order.getMemberVerifyCode() != null) {
+                sendOrderNotice(order.getMemberId(), Constants.MemberOrderNotify.ARRIVED_HAS_SHOP, order.getId(),
+                        "orderNo", order.getCode(),
+                        "destination", destination,
+                        "pickupCode", order.getMemberVerifyCode());
+            } else {
+                sendOrderNotice(order.getMemberId(), Constants.MemberOrderNotify.ARRIVED_NO_SHOP, order.getId(),
+                        "orderNo", order.getCode(),
+                        "destination", destination);
+            }
+
+            // 閫氱煡鍙栦欢闂ㄥ簵锛氳鍗曞凡閫佽揪
+            if (order.getTakeShopId() != null) {
+                sendShopNotice(order.getTakeShopId(), Constants.ShopOrderNotify.ARRIVED, order.getId(),
+                        "orderNo", order.getCode(),
+                        "destination", destination);
+            }
+
+            // 鐭俊閫氱煡浼氬憳锛氳鏉庡凡閫佽揪
+            Member arrivedMember = memberMapper.selectById(order.getMemberId());
+            if (arrivedMember != null) {
+                sendSmsNotify(arrivedMember.getTelephone(), Constants.SmsNotify.MEMBER_ARRIVED,
+                        "orderNo", order.getCode(),
+                        "address", destination,
+                        "code", order.getMemberVerifyCode() != null ? order.getMemberVerifyCode() : "");
+            }
+        }else {
             throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "褰撳墠璁㈠崟鐘舵�佷笉鍏佽鏍搁攢");
         }
     }
@@ -2913,12 +3028,13 @@
             ordersRefundMapper.insert(refundRecord);
 
             // 璋冪敤寰俊閫�娆綱3锛堟斁鍦ㄦ渶鍚庯紝纭繚鍓嶇疆鎿嶄綔鍏ㄩ儴鎴愬姛锛�
+            String outRefundNo2 = ID.nextGUID();
             Refund refundResult = wxPayV3Service.refund(
-                    order.getOutTradeNo(), order.getPayAmount(), order.getRefundAmount(),
+                    outRefundNo2, order.getOutTradeNo(), order.getPayAmount(), order.getRefundAmount(),
                     "璁㈠崟閫�娆�", wxPayProperties.getV3RefundNotifyUrl());
 
             // 閫�娆炬垚鍔熷悗鍥炲~閫�娆惧崟鍙凤紝鏍囪閫�娆句腑
-            refundRecord.setRefundCode(refundResult.getOutRefundNo());
+            refundRecord.setRefundCode(outRefundNo2);
             refundRecord.setStatus(Constants.ZERO); // 閫�娆句腑
             ordersRefundMapper.updateById(refundRecord);
         }
@@ -3544,26 +3660,20 @@
 
     /**
      * 灏卞湴瀵勫瓨閫炬湡澶╂暟璁$畻
-     * 杩囦簡棰勮鍙栦欢鏃堕棿褰撳ぉ鐨�24:00锛堟鏃�00:00锛夊悗鎵嶇畻绗竴澶�
+     * 杩囦簡棰勮鍙栦欢鏃ユ湡鐨勬鏃ワ紙鍙瘮杈冨勾鏈堟棩锛夊悗寮�濮嬭閫炬湡澶╂暟
      */
     private int calcLocalOverdueDays(Date now, Date expectedTakeTime) {
-        if (expectedTakeTime == null || !now.after(expectedTakeTime)) {
+        if (expectedTakeTime == null) {
             return 0;
         }
-        // 鍩哄噯鏃堕棿 = 棰勮鍙栦欢鏃ユ湡鐨勬鏃� 00:00锛堝嵆褰撳ぉ24:00锛�
+        // 鍙彇骞存湀鏃�
         Calendar baseCal = Calendar.getInstance();
         baseCal.setTime(expectedTakeTime);
         baseCal.set(Calendar.HOUR_OF_DAY, 0);
         baseCal.set(Calendar.MINUTE, 0);
         baseCal.set(Calendar.SECOND, 0);
         baseCal.set(Calendar.MILLISECOND, 0);
-        baseCal.add(Calendar.DAY_OF_MONTH, 1); // 娆℃棩00:00 = 褰撳ぉ24:00
-        Date baseTime = baseCal.getTime();
 
-        if (!now.after(baseTime)) {
-            return 0;
-        }
-        // 閫炬湡澶╂暟 = 褰撳墠鏃ユ湡 - 鍩哄噯鏃ユ湡锛堟寜澶╁彇宸級
         Calendar nowCal = Calendar.getInstance();
         nowCal.setTime(now);
         nowCal.set(Calendar.HOUR_OF_DAY, 0);
@@ -3571,40 +3681,31 @@
         nowCal.set(Calendar.SECOND, 0);
         nowCal.set(Calendar.MILLISECOND, 0);
 
-        Calendar baseDateCal = Calendar.getInstance();
-        baseDateCal.setTime(baseTime);
-        baseDateCal.set(Calendar.HOUR_OF_DAY, 0);
-        baseDateCal.set(Calendar.MINUTE, 0);
-        baseDateCal.set(Calendar.SECOND, 0);
-        baseDateCal.set(Calendar.MILLISECOND, 0);
-
-        long diffMs = nowCal.getTimeInMillis() - baseDateCal.getTimeInMillis();
-        int days = (int) (diffMs / (1000 * 60 * 60 * 24));
-        return Math.max(days, 0);
+        // 鍩哄噯鏃ユ湡 = 棰勮鍙栦欢鏃ユ湡鐨勬鏃ワ紝褰撳ぉ鍙婁箣鍓嶄笉绠楅�炬湡
+        if (nowCal.before(baseCal)) {
+            return 0;
+        }
+        // 閫炬湡澶╂暟 = 褰撳墠鏃ユ湡 - 鍩哄噯鏃ユ湡
+        long diffMs = nowCal.getTimeInMillis() - baseCal.getTimeInMillis();
+        return (int) (diffMs / (1000 * 60 * 60 * 24));
     }
 
     /**
      * 寮傚湴瀵勫瓨閫炬湡澶╂暟璁$畻
-     * 杩囦簡杞Щ鍒板簵鏃堕棿褰撳ぉ鐨勬櫄涓�12鐐癸紙24:00锛夊悗鎵嶇畻绗竴澶�
+     * 杩囦簡杞Щ鍒板簵鏃ユ湡鐨勬鏃ワ紙鍙瘮杈冨勾鏈堟棩锛夊悗寮�濮嬭閫炬湡澶╂暟
      */
     private int calcRemoteOverdueDays(Date now, Date arriveTime) {
-        if (arriveTime == null || !now.after(arriveTime)) {
+        if (arriveTime == null) {
             return 0;
         }
-        // 鍩哄噯鏃堕棿 = 杞Щ鍒板簵鏃ユ湡鐨勬鏃� 00:00锛堝嵆褰撳ぉ24:00锛�
+        // 鍙彇骞存湀鏃�
         Calendar baseCal = Calendar.getInstance();
         baseCal.setTime(arriveTime);
         baseCal.set(Calendar.HOUR_OF_DAY, 0);
         baseCal.set(Calendar.MINUTE, 0);
         baseCal.set(Calendar.SECOND, 0);
         baseCal.set(Calendar.MILLISECOND, 0);
-        baseCal.add(Calendar.DAY_OF_MONTH, 1); // 娆℃棩00:00 = 褰撳ぉ24:00
-        Date baseTime = baseCal.getTime();
 
-        if (!now.after(baseTime)) {
-            return 0;
-        }
-        // 閫炬湡澶╂暟 = 褰撳墠鏃ユ湡 - 鍩哄噯鏃ユ湡
         Calendar nowCal = Calendar.getInstance();
         nowCal.setTime(now);
         nowCal.set(Calendar.HOUR_OF_DAY, 0);
@@ -3612,16 +3713,14 @@
         nowCal.set(Calendar.SECOND, 0);
         nowCal.set(Calendar.MILLISECOND, 0);
 
-        Calendar baseDateCal = Calendar.getInstance();
-        baseDateCal.setTime(baseTime);
-        baseDateCal.set(Calendar.HOUR_OF_DAY, 0);
-        baseDateCal.set(Calendar.MINUTE, 0);
-        baseDateCal.set(Calendar.SECOND, 0);
-        baseDateCal.set(Calendar.MILLISECOND, 0);
-
-        long diffMs = nowCal.getTimeInMillis() - baseDateCal.getTimeInMillis();
-        int days = (int) (diffMs / (1000 * 60 * 60 * 24));
-        return Math.max(days, 0);
+        // 鍩哄噯鏃ユ湡 = 鍒板簵鏃ユ湡鐨勬鏃ワ紝褰撳ぉ鍙婁箣鍓嶄笉绠楅�炬湡
+        baseCal.add(Calendar.DAY_OF_MONTH, 1);
+        if (nowCal.before(baseCal)) {
+            return 0;
+        }
+        // 閫炬湡澶╂暟 = 褰撳墠鏃ユ湡 - 鍩哄噯鏃ユ湡
+        long diffMs = nowCal.getTimeInMillis() - baseCal.getTimeInMillis();
+        return (int) (diffMs / (1000 * 60 * 60 * 24));
     }
 
     @Override
@@ -3640,6 +3739,7 @@
         ActiveOrderTipVO vo = new ActiveOrderTipVO();
         vo.setOrderId(order.getId());
         vo.setStatus(order.getStatus());
+        vo.setStatusDesc(Constants.OrderStatus.getDescByKey(order.getStatus(), order.getType()));
 
         // 鏋勫缓鎻愮ず鏂囨
         boolean isLocal = Constants.equalsInteger(order.getType(), Constants.ZERO);

--
Gitblit v1.9.3