From a5a0a3c29a97c807cda8846994d1d8df6adeb9e5 Mon Sep 17 00:00:00 2001 From: xin <1099200748@qq.com> Date: Mon, 14 Jul 2025 21:09:57 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/pxb' into xin --- oying-system/src/main/java/com/oying/modules/rider/service/impl/RiderOrderRecordServiceImpl.java | 108 +++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 94 insertions(+), 14 deletions(-) diff --git a/oying-system/src/main/java/com/oying/modules/rider/service/impl/RiderOrderRecordServiceImpl.java b/oying-system/src/main/java/com/oying/modules/rider/service/impl/RiderOrderRecordServiceImpl.java index ea3d97a..4065fe9 100644 --- a/oying-system/src/main/java/com/oying/modules/rider/service/impl/RiderOrderRecordServiceImpl.java +++ b/oying-system/src/main/java/com/oying/modules/rider/service/impl/RiderOrderRecordServiceImpl.java @@ -1,8 +1,17 @@ package com.oying.modules.rider.service.impl; import cn.hutool.core.lang.UUID; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.oying.exception.BadRequestException; +import com.oying.modules.pc.store.domain.Store; +import com.oying.modules.pc.store.service.StoreService; +import com.oying.modules.rider.domain.RiderInfo; import com.oying.modules.rider.domain.RiderOrderRecord; +import com.oying.modules.rider.domain.vo.OrderRiderOperationVo; +import com.oying.modules.rider.service.RiderInfoService; +import com.oying.modules.rider.utils.Constants; +import com.oying.modules.sh.domain.vo.OrderResponse; +import com.oying.modules.sh.service.OrderService; import com.oying.utils.*; import lombok.RequiredArgsConstructor; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; @@ -13,6 +22,7 @@ import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; +import java.sql.Timestamp; import java.util.List; import java.util.Map; import java.io.IOException; @@ -21,24 +31,27 @@ import java.util.LinkedHashMap; /** -* @description 服务实现 -* @author pxb -* @date 2025-07-01 -**/ + * @author pxb + * @description 服务实现 + * @date 2025-07-01 + **/ @Service @RequiredArgsConstructor public class RiderOrderRecordServiceImpl extends ServiceImpl<RiderOrderRecordMapper, RiderOrderRecord> implements RiderOrderRecordService { private final RiderOrderRecordMapper riderOrderRecordMapper; private final RedisUtils redisUtils; + private final OrderService orderService; + private final RiderInfoService riderInfoService; + private final StoreService storeService; @Override - public PageResult<RiderOrderRecord> queryAll(RiderOrderRecordQueryCriteria criteria, Page<Object> page){ + public PageResult<RiderOrderRecord> queryAll(RiderOrderRecordQueryCriteria criteria, Page<Object> page) { return PageUtil.toPage(riderOrderRecordMapper.findAll(criteria, page)); } @Override - public List<RiderOrderRecord> queryAll(RiderOrderRecordQueryCriteria criteria){ + public List<RiderOrderRecord> queryAll(RiderOrderRecordQueryCriteria criteria) { return riderOrderRecordMapper.findAll(criteria); } @@ -92,6 +105,19 @@ @Override @Transactional(rollbackFor = Exception.class) + public void updateRiderOrderStatus(String orderNum, String orderStatus) { + // 当前为接单 设置为待取货状态 1-待取货 2-配送中 3-已完成 4-商家取消 5-骑手取消 6-客户取消 7-系统取消 + RiderOrderRecord riderOrderRecord = new RiderOrderRecord(); + riderOrderRecord.setOrderNum(orderNum); + riderOrderRecord.setOrderStatus(orderStatus); + QueryWrapper<RiderOrderRecord> queryWrapper = new QueryWrapper<>(); + queryWrapper.eq(RiderOrderRecord.COL_ORDER_NUM, orderNum); + // 更新订单状态 + riderOrderRecordMapper.update(riderOrderRecord, queryWrapper); + } + + @Override + @Transactional(rollbackFor = Exception.class) public R riderGrabOrder(String orderNum) { // 唯一标识当前线程/客户端 String clientId = UUID.randomUUID().toString(); @@ -101,19 +127,25 @@ // 获取分布式锁,设置超时时间10秒 boolean isLocked = redisUtils.setIfAbsent(lockKey, clientId, 10); if (!isLocked) { - return R.fail(400, "请稍后重试"); + return R.fail(400, "订单已经被其他骑手接单,请稍后重试"); } // 查询当前订单 检查订单是否已经被其他骑手抢到或取消 直接返回 - + OrderResponse orderResponse = orderService.getByOrderNum(orderNum); + // 2商家已接单 4商家已备货 这两个状态可以接单 + if (orderResponse == null || orderResponse.getOrder().getOrderStatus() != 2 || orderResponse.getOrder().getOrderStatus() != 4) { + return R.fail(400, "订单已经被其他骑手接单或顾客取消,请稍后重试"); + } // 订单没有被接单或取消的情况下,进行接单操作 - // 1.修改订单状态 - + // 查询骑手信息 + Long riderId = SecurityUtils.getCurrentUserId(); + RiderInfo riderInfo = riderInfoService.getRiderSourceInfo(riderId); + // 查询商家信息 + Store store = storeService.getById(orderResponse.getOrder().getStoreId()); + // 1.新增骑手接单记录 + addRiderOrderRecord(riderInfo, orderResponse, store); // 2.新增订单接单流程信息 - - // 3.新增骑手端订单记录详情 - // 返回成功信息 - return R.success(null, "接单成功"); + return R.success(orderResponse, "接单成功"); } catch (Exception e) { throw new BadRequestException("接单失败,请稍后重试"); } finally { @@ -127,9 +159,47 @@ } } + /** + * 功能描述: <添加接单记录> + * + * @Date: 2025/7/14 17:48 + */ + public void addRiderOrderRecord(RiderInfo riderInfo, OrderResponse orderResponse, Store store) { + RiderOrderRecord riderOrderRecord = new RiderOrderRecord(); + riderOrderRecord.setOrderId(orderResponse.getOrder().getOrderId()); + riderOrderRecord.setOrderNum(orderResponse.getOrder().getOrderNum()); + riderOrderRecord.setMerchantId(orderResponse.getOrder().getStoreId()); + riderOrderRecord.setMerchantName(orderResponse.getOrder().getStoreName()); + riderOrderRecord.setMerchantAddress(store.getAddress()); + riderOrderRecord.setReceiverAddress(orderResponse.getAddress().getDetail()); + // 当前为接单 设置为待取货状态 0-已接单 1-已到店 2-配送中 3-已完成 4-商家取消 5-骑手取消 6-客户取消 7-系统取消 + riderOrderRecord.setOrderStatus(Constants.ORDER_STATUS_OK); + riderOrderRecord.setAcceptTime(new Timestamp(System.currentTimeMillis())); + // 取单编号 + riderOrderRecord.setAcceptNum(orderResponse.getOrder().getOrderStoreNum()); + // 是否超时:1-是 0-否 + riderOrderRecord.setIsOvertime(Constants.IS_OVERTIME_NO); + // 订单来源: 1-平台派单 2-骑手抢单 3-商家直派 4-其他 + riderOrderRecord.setOrderSource(Constants.ORDER_SOURCE_DIRECT); + riderOrderRecord.setRiderId(riderInfo.getRiderId()); + riderOrderRecord.setRiderName(riderInfo.getCardName()); + riderOrderRecord.setPhone(riderInfo.getPhone()); + riderOrderRecord.setUserId(orderResponse.getOrder().getUserId()); + riderOrderRecord.setUserLongitude(String.valueOf(orderResponse.getAddress().getLongitude())); + riderOrderRecord.setUserLatitude(String.valueOf(orderResponse.getAddress().getLatitude())); + riderOrderRecord.setMerchantLongitude(String.valueOf(store.getLongitude())); + riderOrderRecord.setMerchantLatitude(String.valueOf(store.getLatitude())); + // 配送费详情Id + // riderOrderRecord.setDeliveryFeeId(orderResponse.getOrder().getDeliveryFeeId()); + riderOrderRecord.setOrderIncome(orderResponse.getOrder().getSendPrice()); + create(riderOrderRecord); + } + + @Override public R riderCancelOrder(String orderNum) { // 查询当前订单信息 + OrderResponse orderResponse = orderService.getByOrderNum(orderNum); // 根据信息判断当前订单信息是否满足取消条件 // 满足取消订单 // 不满足取消订单条件,返回错误信息 @@ -137,4 +207,14 @@ return null; } + @Override + @Transactional(rollbackFor = Exception.class) + public R riderOperationOrder(OrderRiderOperationVo orderRiderOperationVo){ + // 判断骑手操作类型 + // 添加订单操作记录 + // 修改骑手端的订单状态 + updateRiderOrderStatus(orderRiderOperationVo.getOrderNum(), Constants.ORDER_STATUS_StORE); + return R.success(); + } + } -- Gitblit v1.9.3