From d3844ee25fbb06b656b5521978f083695d194b07 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 29 Apr 2025 09:56:11 +0800
Subject: [PATCH] feat(mall): 添加门票核销功能
---
src/main/java/cc/mrbird/febs/mall/controller/activity/ApiHappyActivityOrderController.java | 12 +++++++++++-
src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java | 39 +++++++++++++++++++++++++++++++++++----
src/main/java/cc/mrbird/febs/mall/service/HappyActivityService.java | 2 ++
3 files changed, 48 insertions(+), 5 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/mall/controller/activity/ApiHappyActivityOrderController.java b/src/main/java/cc/mrbird/febs/mall/controller/activity/ApiHappyActivityOrderController.java
index 81645a2..6c921d1 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/activity/ApiHappyActivityOrderController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/activity/ApiHappyActivityOrderController.java
@@ -120,7 +120,7 @@
return happyActivityService.orderDelete(id);
}
- @ApiOperation(value = "核销门票", notes = "核销门票")
+ @ApiOperation(value = "核销门票-详细信息", notes = "核销门票-详细信息")
@ApiResponses({
@ApiResponse(code = 200, message = "success", response = ApiCheckOrderVo.class)
})
@@ -130,6 +130,16 @@
return happyActivityService.checkOrder(dto);
}
+ @ApiOperation(value = "核销门票-确认核销", notes = "核销门票-确认核销")
+ @ApiResponses({
+ @ApiResponse(code = 200, message = "success", response = ApiCheckOrderVo.class)
+ })
+ @PostMapping(value = "/insureOrder")
+ public FebsResponse insureOrder(@RequestBody @Validated ApiCheckOrderDto dto) {
+
+ return happyActivityService.insureOrder(dto);
+ }
+
@ApiOperation(value = "我的报名-评价", notes = "我的报名-评价")
@PostMapping(value = "/addComment")
public FebsResponse addComment(@RequestBody @Validated ApiPayOrderAddCommentDto dto) {
diff --git a/src/main/java/cc/mrbird/febs/mall/service/HappyActivityService.java b/src/main/java/cc/mrbird/febs/mall/service/HappyActivityService.java
index ab7af8b..53b5fe9 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/HappyActivityService.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/HappyActivityService.java
@@ -70,6 +70,8 @@
FebsResponse checkOrder(ApiCheckOrderDto dto);
+ FebsResponse insureOrder(ApiCheckOrderDto dto);
+
void checkActivityItem(Long orderId);
void overtimeJob();
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java
index b2d0db8..e3d7a6c 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java
@@ -903,11 +903,10 @@
.last("limit 1")
);
if(happyActivityOrderItem != null){
- happyActivityOrderItem.setState(StateUpDownEnum.UP.getCode());
- happyActivityOrderItem.setTransferItemId(memberId);
- happyActivityOrderItemMapper.updateById(happyActivityOrderItem);
- agentProducer.sendCheckActivityItem(happyActivityOrderItem.getOrderId());
+ if(StateUpDownEnum.UP.getCode() == happyActivityOrderItem.getState()){
+ throw new FebsException("该票号已核销!");
+ }
HappyActivity happyActivity = this.baseMapper.selectById(happyActivityOrderItem.getActivityId());
ApiCheckOrderVo apiCheckOrderVo = new ApiCheckOrderVo();
@@ -926,6 +925,38 @@
return new FebsResponse().fail().message("核销失败!");
}
+ @Override
+ public FebsResponse insureOrder(ApiCheckOrderDto dto) {
+ // 获取当前登录用户的ID
+ Long memberId = LoginUserUtil.getLoginUser().getId();
+
+ MallMember mallMember = mallMemberMapper.selectById(memberId);
+
+ if(StateUpDownEnum.UP.getCode() != mallMember.getCheckOrder()){
+ throw new FebsException("您不是核销员!");
+ }
+
+ String orderItemCode = dto.getOrderItemCode();
+
+ HappyActivityOrderItem happyActivityOrderItem = happyActivityOrderItemMapper.selectOne(
+ new LambdaQueryWrapper<HappyActivityOrderItem>()
+ .eq(HappyActivityOrderItem::getCode, orderItemCode)
+ .eq(HappyActivityOrderItem::getState, StateUpDownEnum.DOWN.getCode())
+ .last("limit 1")
+ );
+ if(happyActivityOrderItem != null){
+ if(StateUpDownEnum.UP.getCode() == happyActivityOrderItem.getState()){
+ throw new FebsException("该票号已核销!");
+ }
+
+ happyActivityOrderItem.setState(StateUpDownEnum.UP.getCode());
+ happyActivityOrderItem.setTransferItemId(memberId);
+ happyActivityOrderItemMapper.updateById(happyActivityOrderItem);
+ agentProducer.sendCheckActivityItem(happyActivityOrderItem.getOrderId());
+ }
+ return new FebsResponse().success().message("操作成功");
+ }
+
/**
* 检查活动订单项的状态
* 当指定订单的所有活动订单项都不处于"未使用"状态时,将订单状态更新为"已使用"
--
Gitblit v1.9.1