From 3baddff99987a5a98b5d55504853f4995018533b Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Mon, 18 Mar 2024 16:03:02 +0800
Subject: [PATCH] 抽奖

---
 src/main/java/cc/mrbird/febs/mall/entity/MallMemberAmount.java               |    1 +
 src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java         |   32 +++++++++++++++++++++++++++++---
 src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java  |    3 +++
 src/main/resources/mapper/modules/MallMemberAmountMapper.xml                 |    7 +++++++
 src/main/resources/mapper/modules/MallProductBuyMapper.xml                   |    2 +-
 src/main/java/cc/mrbird/febs/mall/mapper/MallMemberAmountMapper.java         |    1 +
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java |    5 +++--
 7 files changed, 45 insertions(+), 6 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/entity/MallMemberAmount.java b/src/main/java/cc/mrbird/febs/mall/entity/MallMemberAmount.java
index c93e52c..e7fe294 100644
--- a/src/main/java/cc/mrbird/febs/mall/entity/MallMemberAmount.java
+++ b/src/main/java/cc/mrbird/febs/mall/entity/MallMemberAmount.java
@@ -37,4 +37,5 @@
     private BigDecimal tokenAva;//令牌可用
     private BigDecimal tokenFrozen;//令牌冻结
     private BigDecimal gsd;//gsd积分-用来商城购物
+    private BigDecimal totalPerk;//gsd积分-用来商城购物
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberAmountMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberAmountMapper.java
index a297e5e..47eb3af 100644
--- a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberAmountMapper.java
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberAmountMapper.java
@@ -17,6 +17,7 @@
     void updateTokenAvaAndTokenFrozenById(@Param("record")MallMemberAmount mallMemberAmount);
 
     void updateTrendsNftById(@Param("record")MallMemberAmount mallMemberAmount);
+    void updateTotalPerkById(@Param("record")MallMemberAmount mallMemberAmount);
     void updateGsdById(@Param("record")MallMemberAmount mallMemberAmount);
 
     void updateFrozenNftById(@Param("record")MallMemberAmount mallMemberAmount);
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
index 30dd97d..e9db01c 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java
@@ -925,6 +925,10 @@
                     mallMemberAmountMine.setTrendsNft(mallMemberAmountMine.getTrendsNft().add(profit));
                     mallMemberAmountMapper.updateTrendsNftById(mallMemberAmountMine);
 
+                    MallMemberAmount mallMemberAmountPerk = mallMemberAmountMapper.selectByMemberId(mallProductBuy.getMemberId());
+                    mallMemberAmountPerk.setTotalPerk(mallMemberAmountPerk.getTotalPerk().subtract(profit));
+                    mallMemberAmountMapper.updateTotalPerkById(mallMemberAmountPerk);
+
 
                     BigDecimal remainderDirect = bigDecimal.divide(new BigDecimal(String.valueOf(cycle)),0,BigDecimal.ROUND_DOWN);//取余
                     if(remainderDirect.compareTo(BigDecimal.ONE) == 0){
@@ -1241,6 +1245,13 @@
                         AppContants.MEMBER_FLOW_ING);
 
             }else {
+                MallMemberAmount mallMemberAmountMine = mallMemberAmountMapper.selectByMemberId(memberId);
+                if(BigDecimal.ZERO.compareTo(mallMemberAmountMine.getTotalPerk().subtract(mallMoneyFlow.getAmount())) >= 0){
+                    continue;
+                }
+                mallMemberAmountMine.setTotalPerk(mallMemberAmountMine.getTotalPerk().subtract(mallMoneyFlow.getAmount()));
+                mallMemberAmountMapper.updateTrendsNftAndFrozenNftById(mallMemberAmountMine);
+
                 MallMemberAmount mallMemberAmount = mallMemberAmountMapper.selectByMemberId(memberId);
                 mallMemberAmount.setFrozenNft(mallMemberAmount.getFrozenNft().subtract(mallMoneyFlow.getAmount()));
                 mallMemberAmount.setTrendsNft(mallMemberAmount.getTrendsNft().add(mallMoneyFlow.getAmount()));
@@ -1250,7 +1261,7 @@
                 String orderNo = MallUtils.getOrderNum("NFT");
                 mallMoneyFlowService.addMoneyFlow(
                         memberId,
-                        mallMoneyFlow.getAmount().negate(),
+                        mallMoneyFlow.getAmount(),
                         MoneyFlowTypeNewEnum.BASIC_PERK_DIRECT_DONE.getValue(),
                         orderNo,
                         null,
@@ -1308,6 +1319,13 @@
                         AppContants.MEMBER_FLOW_ING);
 
             }else {
+                MallMemberAmount mallMemberAmountMine = mallMemberAmountMapper.selectByMemberId(memberId);
+                if(BigDecimal.ZERO.compareTo(mallMemberAmountMine.getTotalPerk().subtract(mallMoneyFlow.getAmount())) >= 0){
+                    continue;
+                }
+                mallMemberAmountMine.setTotalPerk(mallMemberAmountMine.getTotalPerk().subtract(mallMoneyFlow.getAmount()));
+                mallMemberAmountMapper.updateTrendsNftAndFrozenNftById(mallMemberAmountMine);
+
                 MallMemberAmount mallMemberAmount = mallMemberAmountMapper.selectByMemberId(memberId);
                 mallMemberAmount.setFrozenNft(mallMemberAmount.getFrozenNft().subtract(mallMoneyFlow.getAmount()));
                 mallMemberAmount.setTrendsNft(mallMemberAmount.getTrendsNft().add(mallMoneyFlow.getAmount()));
@@ -1317,7 +1335,7 @@
                 String orderNo = MallUtils.getOrderNum("NFT");
                 mallMoneyFlowService.addMoneyFlow(
                         memberId,
-                        mallMoneyFlow.getAmount().negate(),
+                        mallMoneyFlow.getAmount(),
                         MoneyFlowTypeNewEnum.TEAM_PERK_DIRECT_DONE.getValue(),
                         orderNo,
                         null,
@@ -1375,6 +1393,14 @@
                         AppContants.MEMBER_FLOW_ING);
 
             }else {
+
+                MallMemberAmount mallMemberAmountMine = mallMemberAmountMapper.selectByMemberId(memberId);
+                if(BigDecimal.ZERO.compareTo(mallMemberAmountMine.getTotalPerk().subtract(mallMoneyFlow.getAmount())) >= 0){
+                    continue;
+                }
+                mallMemberAmountMine.setTotalPerk(mallMemberAmountMine.getTotalPerk().subtract(mallMoneyFlow.getAmount()));
+                mallMemberAmountMapper.updateTrendsNftAndFrozenNftById(mallMemberAmountMine);
+
                 MallMemberAmount mallMemberAmount = mallMemberAmountMapper.selectByMemberId(memberId);
                 mallMemberAmount.setFrozenNft(mallMemberAmount.getFrozenNft().subtract(mallMoneyFlow.getAmount()));
                 mallMemberAmount.setTrendsNft(mallMemberAmount.getTrendsNft().add(mallMoneyFlow.getAmount()));
@@ -1384,7 +1410,7 @@
                 String orderNo = MallUtils.getOrderNum("NFT");
                 mallMoneyFlowService.addMoneyFlow(
                         memberId,
-                        mallMoneyFlow.getAmount().negate(),
+                        mallMoneyFlow.getAmount(),
                         MoneyFlowTypeNewEnum.TEAM_PERK_EQUALS_DONE.getValue(),
                         orderNo,
                         null,
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
index 9cc8a5b..88126a3 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
@@ -299,6 +299,7 @@
         mallMemberVo.setFcmCntFrozen(mallMemberAmount.getFcmCntFrozen());
         mallMemberVo.setTokenAva(mallMemberAmount.getTokenAva());
         mallMemberVo.setTokenFrozen(mallMemberAmount.getTokenFrozen());
+        mallMemberVo.setTotalPerk(mallMemberAmount.getTotalPerk());
         DataDictionaryCustom startTimeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
                 DataDictionaryEnum.YU_YUE_START_TIME.getType(),
                 DataDictionaryEnum.YU_YUE_START_TIME.getCode()
@@ -313,8 +314,8 @@
         Integer pickCount = mallProductBuyMapper.selectListByMemberIdAndState(id);
         mallMemberVo.setPickCount(pickCount);
 
-        BigDecimal totalPerk = mallProductBuyMapper.selectTotalPerkByMemberId(mallMember.getId());
-        mallMemberVo.setTotalPerk(totalPerk);
+//        BigDecimal totalPerk = mallProductBuyMapper.selectTotalPerkByMemberId(mallMember.getId());
+//        mallMemberVo.setTotalPerk(totalPerk);
 
         DataDictionaryCustom insideNFTPercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
                 DataDictionaryEnum.FCM_INSIDE_NFT_PERCENT.getType(),
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java
index a042cff..c18c8a4 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/MemberProfitServiceImpl.java
@@ -1274,6 +1274,9 @@
                 mallProductBuy.setPayTime(DateUtil.date());
                 mallProductBuyMapper.updateById(mallProductBuy);
 
+                MallMemberAmount mallMemberAmount = mallMemberAmountMapper.selectByMemberId(mallProductBuy.getMemberId());
+                mallMemberAmount.setTotalPerk(mallMemberAmount.getTotalPerk().add(totalPerk));
+                mallMemberAmountMapper.updateTotalPerkById(mallMemberAmount);
             }
         }
     }
diff --git a/src/main/resources/mapper/modules/MallMemberAmountMapper.xml b/src/main/resources/mapper/modules/MallMemberAmountMapper.xml
index 0b3f92a..f691f8b 100644
--- a/src/main/resources/mapper/modules/MallMemberAmountMapper.xml
+++ b/src/main/resources/mapper/modules/MallMemberAmountMapper.xml
@@ -35,6 +35,13 @@
         where id = #{record.id} and revision=#{record.revision}
     </update>
 
+    <update id="updateTotalPerkById">
+        update mall_member_amount
+        set revision = revision + 1,
+            total_perk = #{record.totalPerk}
+        where id = #{record.id} and revision=#{record.revision}
+    </update>
+
     <update id="updateGsdById">
         update mall_member_amount
         set revision = revision + 1,
diff --git a/src/main/resources/mapper/modules/MallProductBuyMapper.xml b/src/main/resources/mapper/modules/MallProductBuyMapper.xml
index 96999cd..2e763e5 100644
--- a/src/main/resources/mapper/modules/MallProductBuyMapper.xml
+++ b/src/main/resources/mapper/modules/MallProductBuyMapper.xml
@@ -63,7 +63,7 @@
     </select>
 
     <select id="selectTotalPerk" resultType="cc.mrbird.febs.mall.entity.MallProductBuy">
-        select SUM(total_perk) from mall_product_buy
+        select IFNULL(sum(total_perk), 0) from mall_product_buy
         where state = 3
         GROUP BY member_id;
     </select>

--
Gitblit v1.9.1