mirror of
				https://gitee.com/hhyykk/ipms-sjy.git
				synced 2025-11-04 12:18:42 +08:00 
			
		
		
		
	订单:
1、移除 deliverStatus 发货状态,暂时没作用 2、无需发货时,使用 logisticsId 进行实现 3、订单详情,增加 logisticsId 和 logisticsName 返回
This commit is contained in:
		@@ -10,10 +10,12 @@ import cn.iocoder.yudao.module.trade.controller.app.order.vo.*;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.controller.app.order.vo.item.AppTradeOrderItemCommentCreateReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.controller.app.order.vo.item.AppTradeOrderItemRespVO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.convert.order.TradeOrderConvert;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.dal.dataobject.delivery.DeliveryExpressDO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.dal.dataobject.order.TradeOrderDO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.dal.dataobject.order.TradeOrderItemDO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.enums.order.TradeOrderStatusEnum;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.framework.order.config.TradeOrderProperties;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.service.delivery.DeliveryExpressService;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.service.order.TradeOrderService;
 | 
			
		||||
import com.google.common.collect.Maps;
 | 
			
		||||
import io.swagger.v3.oas.annotations.Operation;
 | 
			
		||||
@@ -42,8 +44,12 @@ public class AppTradeOrderController {
 | 
			
		||||
 | 
			
		||||
    @Resource
 | 
			
		||||
    private TradeOrderService tradeOrderService;
 | 
			
		||||
    @Resource
 | 
			
		||||
    private DeliveryExpressService deliveryExpressService;
 | 
			
		||||
 | 
			
		||||
    @Resource
 | 
			
		||||
    private ProductPropertyValueApi productPropertyValueApi;
 | 
			
		||||
 | 
			
		||||
    @Resource
 | 
			
		||||
    private TradeOrderProperties tradeOrderProperties;
 | 
			
		||||
 | 
			
		||||
@@ -76,14 +82,21 @@ public class AppTradeOrderController {
 | 
			
		||||
    public CommonResult<AppTradeOrderDetailRespVO> getOrder(@RequestParam("id") Long id) {
 | 
			
		||||
        // 查询订单
 | 
			
		||||
        TradeOrderDO order = tradeOrderService.getOrder(getLoginUserId(), id);
 | 
			
		||||
        if (order == null) {
 | 
			
		||||
            return success(null);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // 查询订单项
 | 
			
		||||
        List<TradeOrderItemDO> orderItems = tradeOrderService.getOrderItemListByOrderId(order.getId());
 | 
			
		||||
        // 查询商品属性
 | 
			
		||||
        List<ProductPropertyValueDetailRespDTO> propertyValueDetails = productPropertyValueApi
 | 
			
		||||
                .getPropertyValueDetailList(TradeOrderConvert.INSTANCE.convertPropertyValueIds(orderItems));
 | 
			
		||||
        // 查询物流公司
 | 
			
		||||
        DeliveryExpressDO express = order.getLogisticsId() != null && order.getLogisticsId() > 0 ?
 | 
			
		||||
                deliveryExpressService.getDeliveryExpress(order.getLogisticsId()) : null;
 | 
			
		||||
        // 最终组合
 | 
			
		||||
        return success(TradeOrderConvert.INSTANCE.convert02(order, orderItems,
 | 
			
		||||
                propertyValueDetails, tradeOrderProperties));
 | 
			
		||||
                propertyValueDetails, tradeOrderProperties, express));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @GetMapping("/page")
 | 
			
		||||
 
 | 
			
		||||
@@ -80,6 +80,12 @@ public class AppTradeOrderDetailRespVO {
 | 
			
		||||
    @Schema(description = "配送方式", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
 | 
			
		||||
    private Integer deliveryType;
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "发货物流公司编号", example = "10")
 | 
			
		||||
    private Long logisticsId;
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "发货物流名称", example = "顺丰快递")
 | 
			
		||||
    private String logisticsName;
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "发货物流单号", example = "1024")
 | 
			
		||||
    private String logisticsNo;
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -25,6 +25,7 @@ import cn.iocoder.yudao.module.trade.controller.app.order.vo.*;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.controller.app.order.vo.item.AppTradeOrderItemCommentCreateReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.controller.app.order.vo.item.AppTradeOrderItemRespVO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.dal.dataobject.cart.TradeCartDO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.dal.dataobject.delivery.DeliveryExpressDO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.dal.dataobject.order.TradeOrderDO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.dal.dataobject.order.TradeOrderItemDO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.enums.order.TradeOrderItemAfterSaleStatusEnum;
 | 
			
		||||
@@ -234,7 +235,8 @@ public interface TradeOrderConvert {
 | 
			
		||||
 | 
			
		||||
    // TODO 芋艿:可简化
 | 
			
		||||
    default AppTradeOrderDetailRespVO convert02(TradeOrderDO order, List<TradeOrderItemDO> orderItems,
 | 
			
		||||
                                                List<ProductPropertyValueDetailRespDTO> propertyValueDetails, TradeOrderProperties tradeOrderProperties) {
 | 
			
		||||
                                                List<ProductPropertyValueDetailRespDTO> propertyValueDetails, TradeOrderProperties tradeOrderProperties,
 | 
			
		||||
                                                DeliveryExpressDO express) {
 | 
			
		||||
        AppTradeOrderDetailRespVO orderVO = convert3(order, orderItems);
 | 
			
		||||
        orderVO.setPayExpireTime(addTime(tradeOrderProperties.getExpireTime()));
 | 
			
		||||
        if (StrUtil.isNotEmpty(order.getPayChannelCode())) {
 | 
			
		||||
@@ -260,6 +262,9 @@ public interface TradeOrderConvert {
 | 
			
		||||
        }
 | 
			
		||||
        // 处理收货地址
 | 
			
		||||
        orderVO.setReceiverAreaName(AreaUtils.format(order.getReceiverAreaId()));
 | 
			
		||||
        if (express != null) {
 | 
			
		||||
            orderVO.setLogisticsId(express.getId()).setLogisticsName(express.getName());
 | 
			
		||||
        }
 | 
			
		||||
        return orderVO;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -2,6 +2,7 @@ package cn.iocoder.yudao.module.trade.dal.dataobject.order;
 | 
			
		||||
 | 
			
		||||
import cn.iocoder.yudao.framework.common.enums.TerminalEnum;
 | 
			
		||||
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.dal.dataobject.delivery.DeliveryExpressDO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.dal.dataobject.delivery.DeliveryPickUpStoreDO;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.enums.delivery.DeliveryTypeEnum;
 | 
			
		||||
import cn.iocoder.yudao.module.trade.enums.order.*;
 | 
			
		||||
@@ -174,18 +175,18 @@ public class TradeOrderDO extends BaseDO {
 | 
			
		||||
    private Integer deliveryType;
 | 
			
		||||
    /**
 | 
			
		||||
     * 发货物流公司编号
 | 
			
		||||
     *
 | 
			
		||||
     * 如果无需发货,则 logisticsId 设置为 0。原因是,不想再添加额外字段
 | 
			
		||||
     *
 | 
			
		||||
     * 关联 {@link DeliveryExpressDO#getId()}
 | 
			
		||||
     */
 | 
			
		||||
    private Long logisticsId;
 | 
			
		||||
    /**
 | 
			
		||||
     * 发货物流单号
 | 
			
		||||
     *
 | 
			
		||||
     * 如果无需发货,则 logisticsNo 设置 ""。原因是,不想再添加额外字段
 | 
			
		||||
     */
 | 
			
		||||
    private String logisticsNo;
 | 
			
		||||
    /**
 | 
			
		||||
     * 发货状态
 | 
			
		||||
     *
 | 
			
		||||
     * 枚举 {@link TradeOrderDeliveryStatusEnum}
 | 
			
		||||
     */
 | 
			
		||||
    private Integer deliveryStatus;
 | 
			
		||||
    /**
 | 
			
		||||
     * 发货时间
 | 
			
		||||
     */
 | 
			
		||||
 
 | 
			
		||||
@@ -217,8 +217,8 @@ public class TradeOrderServiceImpl implements TradeOrderService {
 | 
			
		||||
        order.setTerminal(TerminalEnum.H5.getTerminal()); // todo 数据来源?
 | 
			
		||||
        // 支付信息
 | 
			
		||||
        order.setAdjustPrice(0).setPayStatus(false);
 | 
			
		||||
        // 物流信息 TODO 芋艿:暂时写死物流方式;应该是前端选择的
 | 
			
		||||
        order.setDeliveryType(createReqVO.getDeliveryType()).setDeliveryStatus(TradeOrderDeliveryStatusEnum.UNDELIVERED.getStatus());
 | 
			
		||||
        // 物流信息
 | 
			
		||||
        order.setDeliveryType(createReqVO.getDeliveryType());
 | 
			
		||||
        // 退款信息
 | 
			
		||||
        order.setRefundStatus(TradeOrderRefundStatusEnum.NONE.getStatus()).setRefundPrice(0);
 | 
			
		||||
        tradeOrderMapper.insert(order);
 | 
			
		||||
@@ -412,8 +412,7 @@ public class TradeOrderServiceImpl implements TradeOrderService {
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // 更新 TradeOrderDO 状态为已发货,等待收货
 | 
			
		||||
        updateOrderObj.setStatus(TradeOrderStatusEnum.DELIVERED.getStatus())
 | 
			
		||||
                .setDeliveryStatus(TradeOrderDeliveryStatusEnum.DELIVERED.getStatus()).setDeliveryTime(LocalDateTime.now());
 | 
			
		||||
        updateOrderObj.setStatus(TradeOrderStatusEnum.DELIVERED.getStatus()).setDeliveryTime(LocalDateTime.now());
 | 
			
		||||
        int updateCount = tradeOrderMapper.updateByIdAndStatus(order.getId(), order.getStatus(), updateOrderObj);
 | 
			
		||||
        if (updateCount == 0) {
 | 
			
		||||
            throw exception(ORDER_DELIVERY_FAIL_STATUS_NOT_UNDELIVERED);
 | 
			
		||||
@@ -422,7 +421,7 @@ public class TradeOrderServiceImpl implements TradeOrderService {
 | 
			
		||||
 | 
			
		||||
        // 发送站内信
 | 
			
		||||
        tradeMessageService.sendMessageWhenDeliveryOrder(new TradeOrderMessageWhenDeliveryOrderReqBO().setOrderId(order.getId())
 | 
			
		||||
                .setUserId(userId).setMessage(TradeOrderDeliveryStatusEnum.DELIVERED.getName()));
 | 
			
		||||
                .setUserId(userId).setMessage(null));
 | 
			
		||||
 | 
			
		||||
        // TODO 芋艿:OrderLog
 | 
			
		||||
        // TODO 设计:lili:是不是发货后,才支持售后?
 | 
			
		||||
@@ -453,8 +452,7 @@ public class TradeOrderServiceImpl implements TradeOrderService {
 | 
			
		||||
            throw exception(ORDER_NOT_FOUND);
 | 
			
		||||
        }
 | 
			
		||||
        // 校验订单是否是待发货状态
 | 
			
		||||
        if (!TradeOrderStatusEnum.isUndelivered(order.getStatus())
 | 
			
		||||
                || ObjectUtil.notEqual(order.getDeliveryStatus(), TradeOrderDeliveryStatusEnum.UNDELIVERED.getStatus())) {
 | 
			
		||||
        if (!TradeOrderStatusEnum.isUndelivered(order.getStatus())) {
 | 
			
		||||
            throw exception(ORDER_DELIVERY_FAIL_STATUS_NOT_UNDELIVERED);
 | 
			
		||||
        }
 | 
			
		||||
        // 校验订单是否退款
 | 
			
		||||
@@ -480,8 +478,7 @@ public class TradeOrderServiceImpl implements TradeOrderService {
 | 
			
		||||
 | 
			
		||||
        // 更新 TradeOrderDO 状态为已完成
 | 
			
		||||
        int updateCount = tradeOrderMapper.updateByIdAndStatus(order.getId(), order.getStatus(),
 | 
			
		||||
                new TradeOrderDO().setStatus(TradeOrderStatusEnum.COMPLETED.getStatus())
 | 
			
		||||
                        .setDeliveryStatus(TradeOrderDeliveryStatusEnum.RECEIVED.getStatus()).setReceiveTime(LocalDateTime.now()));
 | 
			
		||||
                new TradeOrderDO().setStatus(TradeOrderStatusEnum.COMPLETED.getStatus()).setReceiveTime(LocalDateTime.now()));
 | 
			
		||||
        if (updateCount == 0) {
 | 
			
		||||
            throw exception(ORDER_RECEIVE_FAIL_STATUS_NOT_DELIVERED);
 | 
			
		||||
        }
 | 
			
		||||
@@ -513,8 +510,7 @@ public class TradeOrderServiceImpl implements TradeOrderService {
 | 
			
		||||
            throw exception(ORDER_NOT_FOUND);
 | 
			
		||||
        }
 | 
			
		||||
        // 校验订单是否是待收货状态
 | 
			
		||||
        if (!TradeOrderStatusEnum.isDelivered(order.getStatus())
 | 
			
		||||
                || ObjectUtil.notEqual(order.getDeliveryStatus(), TradeOrderDeliveryStatusEnum.DELIVERED.getStatus())) {
 | 
			
		||||
        if (!TradeOrderStatusEnum.isDelivered(order.getStatus())) {
 | 
			
		||||
            throw exception(ORDER_RECEIVE_FAIL_STATUS_NOT_DELIVERED);
 | 
			
		||||
        }
 | 
			
		||||
        return order;
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user