From 9b51a95fa8bc9b3a86108c6900e17fc55f8db467 Mon Sep 17 00:00:00 2001 From: Administrator <15274802129@163.com> Date: Mon, 19 May 2025 17:02:07 +0800 Subject: [PATCH] refactor(vip): 优化积分和返佣计算逻辑 --- src/main/java/cc/mrbird/febs/mall/service/impl/HappyActivityServiceImpl.java | 33 ++++++++++++++++++++------------- 1 files changed, 20 insertions(+), 13 deletions(-) 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 6ab4751..404035b 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 @@ -552,7 +552,11 @@ happyActivityOrder.setNumCnt(dto.getNumCnt()); happyActivityOrder.setAmount(amount); happyActivityOrder.setPayState(StateUpDownEnum.PAY_STATE_NOT_PAY.getCode()); - happyActivityOrder.setPayType(StateUpDownEnum.PAY_METHOD_WECHAT.getCode()); + if(BigDecimal.ZERO.compareTo(amount) == 0){ + happyActivityOrder.setPayType(StateUpDownEnum.PAY_METHOD_NO_PAY.getCode()); + }else{ + happyActivityOrder.setPayType(StateUpDownEnum.PAY_METHOD_WECHAT.getCode()); + } happyActivityOrder.setFailTime(failTime); log.info("创建订单,订单号="+JSONUtil.parse(happyActivityOrder)); happyActivityOrderMapper.insert(happyActivityOrder); @@ -578,6 +582,7 @@ HashMap<String, Object> stringObjectHashMap = new HashMap<>(); stringObjectHashMap.put("orderId",happyActivityOrder.getId()); stringObjectHashMap.put("amount",amount); + stringObjectHashMap.put("payType",happyActivityOrder.getPayType()); stringObjectHashMap.put("failTime",failTime); return new FebsResponse().success().data(stringObjectHashMap); @@ -618,8 +623,8 @@ try { // 根据支付类型处理不同的支付逻辑 -// if (StateUpDownEnum.PAY_METHOD_NO_PAY.getCode() == payType) { - if (BigDecimal.ZERO.compareTo(happyActivityOrder.getAmount()) == 0) { + if (StateUpDownEnum.PAY_METHOD_NO_PAY.getCode() == payType) { +// if (BigDecimal.ZERO.compareTo(happyActivityOrder.getAmount()) == 0) { // 处理无需支付的订单逻辑 processNoPayOrder(happyActivityOrder, orderId); } else if (StateUpDownEnum.PAY_METHOD_WECHAT.getCode() == payType) { @@ -903,7 +908,7 @@ .last("limit 1") ); if(happyActivityOrderItem == null){ - throw new FebsException("票号异常!"); + throw new FebsException("票号不存在!"); } HappyActivity happyActivity = this.baseMapper.selectById(happyActivityOrderItem.getActivityId()); @@ -939,16 +944,18 @@ .eq(HappyActivityOrderItem::getCode, orderItemCode) .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()); + if(happyActivityOrderItem == null){ + throw new FebsException("票号不存在!"); } + if(StateUpDownEnum.UP.getCode() == happyActivityOrderItem.getState()){ + throw new FebsException("票号已核销!"); + } + + happyActivityOrderItem.setState(StateUpDownEnum.UP.getCode()); + happyActivityOrderItem.setTransferItemId(memberId); + happyActivityOrderItem.setUpdatedTime(DateUtil.date()); + happyActivityOrderItemMapper.updateById(happyActivityOrderItem); + agentProducer.sendCheckActivityItem(happyActivityOrderItem.getOrderId()); return new FebsResponse().success().message("操作成功"); } -- Gitblit v1.9.1