From 16b9e8b2690e8cc2b7f2262d1fa2ec65ee5dc590 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Mon, 17 Apr 2023 16:27:34 +0800
Subject: [PATCH] 只针对一星会员做修改: 按购买业绩(不按权益积分)每天静态释0.6%~1.2%

---
 src/main/java/cc/mrbird/febs/mall/service/impl/AgentServiceImpl.java |   45 +++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 45 insertions(+), 0 deletions(-)

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 b61b090..9190cce 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
@@ -1,6 +1,7 @@
 package cc.mrbird.febs.mall.service.impl;
 
 import cc.mrbird.febs.common.enumerates.*;
+import cc.mrbird.febs.common.utils.AppContants;
 import cc.mrbird.febs.common.utils.MallUtils;
 import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.*;
@@ -9,6 +10,7 @@
 import cc.mrbird.febs.mall.vo.AdminTeamEqualsPerkVo;
 import cc.mrbird.febs.system.mapper.UserMapper;
 import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.math.MathUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import cn.hutool.json.JSONUtil;
@@ -39,6 +41,7 @@
 
     private final DataDictionaryCustomMapper dataDictionaryCustomMapper;
     private final MallMemberMapper memberMapper;
+    private final MallAchieveRecordMapper mallAchieveRecordMapper;
     private final MallOrderInfoMapper mallOrderInfoMapper;
 
     private final IApiMallMemberWalletService iApiMallMemberWalletService;
@@ -580,5 +583,47 @@
         }
     }
 
+    @Override
+    public void achieveReleasePercent() {
+        DataDictionaryCustom jobAchieveReleasePercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                GreenScoreEnum.JOB_ACHIEVE_RELEASE_PERCENT.getType(),
+                GreenScoreEnum.JOB_ACHIEVE_RELEASE_PERCENT.getCode()
+        );
+
+        List<MallMember> mallMembers = memberMapper.selectByLevel(MemberLevelEnum.SECOND_LEVEL.getType());
+        if(CollUtil.isNotEmpty(mallMembers)){
+            for(MallMember mallMember : mallMembers){
+                //总业绩
+                BigDecimal sumAchieve = mallAchieveRecordMapper.selectSumAchieveByMemberId(mallMember.getId());
+                BigDecimal jobAchieveReleasePercent = new BigDecimal(jobAchieveReleasePercentDic.getValue())
+                        .multiply(new BigDecimal(0.001));
+                //每个人的补贴额度
+                BigDecimal multiply = sumAchieve.multiply(jobAchieveReleasePercent);
+                if(multiply.compareTo(new BigDecimal(50)) < 0){
+                    MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(mallMember.getId());
+                    BigDecimal totalScore = mallMemberWallet.getTotalScore();
+                    if(BigDecimal.ZERO.compareTo(totalScore) < 0){
+                        if(totalScore.compareTo(multiply) < 0){
+                            multiply = totalScore;
+                        }
+                        //减少补贴额度
+                        mallMemberWalletMapper.reduceTotalScoreById(multiply, mallMemberWallet.getId());
+
+                        reduceStar(mallMember.getId(),multiply);
+
+                        mallMemberWalletMapper.addBalanceById(multiply, mallMemberWallet.getId());
+
+                        mallMoneyFlowService.addMoneyFlow(
+                                mallMember.getId(),
+                                multiply,
+                                MoneyFlowTypeEnum.STATIC_BONUS.getValue(),
+                                MallUtils.getOrderNum(),
+                                FlowTypeEnum.BALANCE.getValue());
+                    }
+                }
+            }
+        }
+    }
+
 
 }

--
Gitblit v1.9.1