From ca19af1898405b969d2d9e8a3d07f9b1ee7fc938 Mon Sep 17 00:00:00 2001
From: Hentua <wangdoubleone@gmail.com>
Date: Sun, 02 Jul 2023 11:24:04 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java |   14 ++++++++------
 1 files changed, 8 insertions(+), 6 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
index 25797ed..c5a16a5 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java
@@ -282,7 +282,9 @@
     @Override
     @Transactional(rollbackFor = Exception.class)
     public Map<String, Object> payOrder(PayOrderDto payOrderDto) {
-        MallMember member = LoginUserUtil.getLoginUser();
+        MallMember mallMember = LoginUserUtil.getLoginUser();
+        MallMember member = memberMapper.selectById(mallMember.getId());
+
         MallOrderInfo orderInfo = this.baseMapper.selectOrderDetailsById(payOrderDto.getId());
         if (orderInfo == null || AppContants.DEL_FLAG_Y == orderInfo.getDelFlag()) {
             throw new FebsException("订单不存在");
@@ -373,14 +375,15 @@
 
                     mallAchieveService.add(item.getId());
                 }
-
-                // 根据用户购买的商品设置其等级
-                member.setLevel(GoodsToLevelEnums.getLevelByAccountLevel(goodsLevel));
                 member.setAccountLevel(goodsLevel);
+
+                String level = GoodsToLevelEnums.getLevelByAccountLevel(goodsLevel);
+                if (MemberLevelEnum.getLevelCode(member.getLevel()) < MemberLevelEnum.getLevelCode(level)) {
+                    member.setLevel(level);
+                }
                 this.memberMapper.updateById(member);
 
                 memberWalletService.add(score, member.getId(), "score");
-
                 if (orderInfo.getScoreCnt().compareTo(BigDecimal.ZERO) > 0) {
                     int reduce = memberWalletService.reduce(orderInfo.getScoreCnt(), member.getId(), "prizeScore");
                     if (reduce == 2) {
@@ -391,7 +394,6 @@
 
                 mallMoneyFlowService.addMoneyFlow(member.getId(), score, MoneyFlowTypeEnum.BUY_TC.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.SCORE.getValue());
                 mallMoneyFlowService.addMoneyFlow(member.getId(), orderInfo.getAmount().subtract(orderInfo.getScoreAmount()).negate(), MoneyFlowTypeEnum.PAY.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.BALANCE.getValue());
-
                 ThreadUtil.execute(() -> {
                     ThreadUtil.sleep(5000);
 

--
Gitblit v1.9.1