From 205ecdcba56836a14fdd83b41c65869900c936eb Mon Sep 17 00:00:00 2001
From: 彭雪彬 <1724387007@qq.com>
Date: Mon, 14 Jul 2025 18:23:05 +0800
Subject: [PATCH] 骑手接单
---
oying-system/src/main/java/com/oying/modules/rider/service/RiderInfoService.java | 2
oying-system/src/main/java/com/oying/modules/rider/service/impl/RiderOrderRecordServiceImpl.java | 85 +++++++++++++++++++++++++++++++++++-------
oying-system/src/main/java/com/oying/modules/rider/rest/WxRiderController.java | 14 ++++++
oying-system/src/main/java/com/oying/modules/rider/service/impl/RiderInfoServiceImpl.java | 3 +
4 files changed, 87 insertions(+), 17 deletions(-)
diff --git a/oying-system/src/main/java/com/oying/modules/rider/rest/WxRiderController.java b/oying-system/src/main/java/com/oying/modules/rider/rest/WxRiderController.java
index 89a1ecc..9def780 100644
--- a/oying-system/src/main/java/com/oying/modules/rider/rest/WxRiderController.java
+++ b/oying-system/src/main/java/com/oying/modules/rider/rest/WxRiderController.java
@@ -41,7 +41,7 @@
@GetMapping("getRiderSourceInfo/{riderId}")
@ApiOperation("查询第三方数据骑手信息")
@PreAuthorize("@el.check('riderInfo:list')")
- public ResponseEntity<?> getRiderSourceInfo(@PathVariable String riderId) {
+ public ResponseEntity<?> getRiderSourceInfo(@PathVariable Long riderId) {
RiderInfo riderInfo = riderInfoService.getRiderSourceInfo(riderId);
return ResponseEntity.ok(R.success(riderInfo));
}
@@ -114,4 +114,16 @@
return ResponseEntity.ok(R.success(result));
}
+ // @GetMapping("riderCancelOrder/{orderNum}")
+ // @ApiOperation("骑手订单已送达")
+ // @PreAuthorize("@el.check('riderOrderRecord:list')")
+ // public ResponseEntity<?> riderCancelOrder(@PathVariable String orderNum) {
+ // // 订单号不能为空
+ // if (orderNum == null || orderNum.equals("")) {
+ // return ResponseEntity.ok(R.fail(Constants.HTTP_CODE_FAIL, "订单号不能为空"));
+ // }
+ // R result = riderOrderRecordService.riderCancelOrder(orderNum);
+ // return ResponseEntity.ok(R.success(result));
+ // }
+
}
diff --git a/oying-system/src/main/java/com/oying/modules/rider/service/RiderInfoService.java b/oying-system/src/main/java/com/oying/modules/rider/service/RiderInfoService.java
index e4d1e96..4ab7577 100644
--- a/oying-system/src/main/java/com/oying/modules/rider/service/RiderInfoService.java
+++ b/oying-system/src/main/java/com/oying/modules/rider/service/RiderInfoService.java
@@ -68,5 +68,5 @@
* @return RiderInfo
* @param riderId /
*/
- RiderInfo getRiderSourceInfo(String riderId);
+ RiderInfo getRiderSourceInfo(Long riderId);
}
diff --git a/oying-system/src/main/java/com/oying/modules/rider/service/impl/RiderInfoServiceImpl.java b/oying-system/src/main/java/com/oying/modules/rider/service/impl/RiderInfoServiceImpl.java
index 490c1b3..26ed831 100644
--- a/oying-system/src/main/java/com/oying/modules/rider/service/impl/RiderInfoServiceImpl.java
+++ b/oying-system/src/main/java/com/oying/modules/rider/service/impl/RiderInfoServiceImpl.java
@@ -96,6 +96,7 @@
}
@Override
+ @Transactional(rollbackFor = Exception.class)
public void syncRiderSourceInfo(String sourcePlatform) {
Long riderId = SecurityUtils.getCurrentUserId();
// 查询其他平台的数据
@@ -164,7 +165,7 @@
}
@Override
- public RiderInfo getRiderSourceInfo(String riderId) {
+ public RiderInfo getRiderSourceInfo(Long riderId) {
QueryWrapper<RiderInfo> riderInfoQueryWrapper = new QueryWrapper<>();
riderInfoQueryWrapper.eq(RiderInfo.COL_RIDER_ID, riderId);
return riderInfoMapper.selectOne(riderInfoQueryWrapper);
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..cbbf0cd 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
@@ -2,7 +2,15 @@
import cn.hutool.core.lang.UUID;
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.service.RiderInfoService;
+import com.oying.modules.sh.domain.OrderOperationLog;
+import com.oying.modules.sh.domain.vo.OrderResponse;
+import com.oying.modules.sh.service.OrderOperationLogService;
+import com.oying.modules.sh.service.OrderService;
import com.oying.utils.*;
import lombok.RequiredArgsConstructor;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -13,6 +21,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 +30,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);
}
@@ -101,19 +113,25 @@
// 获取分布式锁,设置超时时间10秒
boolean isLocked = redisUtils.setIfAbsent(lockKey, clientId, 10);
if (!isLocked) {
- return R.fail(400, "请稍后重试");
+ return R.fail(400, "订单已经被其他骑手接单,请稍后重试");
}
// 查询当前订单 检查订单是否已经被其他骑手抢到或取消 直接返回
-
+ OrderResponse orderResponse = orderService.getByOrderNum(orderNum);
+ // 商家已接单 商家已备货 这两个状态可以接单
+ 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 +145,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());
+ // 当前为接单 设置为待取货状态 1-待取货 2-配送中 3-已完成 4-商家取消 5-骑手取消 6-客户取消 7-系统取消
+ riderOrderRecord.setOrderStatus("1");
+ riderOrderRecord.setAcceptTime(new Timestamp(System.currentTimeMillis()));
+ // 取单编号
+ riderOrderRecord.setAcceptNum(orderResponse.getOrder().getOrderStoreNum());
+ // 是否超时:1-是 0-否
+ riderOrderRecord.setIsOvertime("0");
+ // 订单来源: 1-平台派单 2-骑手抢单 3-商家直派 4-其他
+ riderOrderRecord.setOrderSource("3");
+ 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 +193,5 @@
return null;
}
+
}
--
Gitblit v1.9.3