From ba17eded418c7eb1a14cdcd16a4d60619da8db73 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Fri, 23 Sep 2022 19:28:11 +0800
Subject: [PATCH] fix

---
 src/main/java/cc/mrbird/febs/mall/quartz/OrderSettlementJob.java |   84 ++++++++++++++++++++++-------------------
 1 files changed, 45 insertions(+), 39 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/quartz/OrderSettlementJob.java b/src/main/java/cc/mrbird/febs/mall/quartz/OrderSettlementJob.java
index 0a09cb7..5e4b456 100644
--- a/src/main/java/cc/mrbird/febs/mall/quartz/OrderSettlementJob.java
+++ b/src/main/java/cc/mrbird/febs/mall/quartz/OrderSettlementJob.java
@@ -17,6 +17,7 @@
 import cn.hutool.core.util.ObjectUtil;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
 
@@ -32,6 +33,7 @@
  **/
 @Slf4j
 @Component
+@ConditionalOnProperty(prefix = "system", name = "job", havingValue = "true")
 public class OrderSettlementJob {
 
     @Autowired
@@ -110,26 +112,31 @@
         List<MallOrderInfo> orderInfos = mallOrderInfoMapper.selectOrderByStatusAndPayTime(3,DateUtil.offsetDay(new Date(), -value));
         if(CollUtil.isNotEmpty(orderInfos)){
             for(MallOrderInfo orderInfo : orderInfos){
-                DataDictionaryCustom dicBonusPercent = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.BONUS_PERCENT.getType(), DataDictionaryEnum.BONUS_PERCENT.getCode());
-                BigDecimal bonusPercent = new BigDecimal(dicBonusPercent.getValue()).setScale(2,BigDecimal.ROUND_DOWN);
-                //生成一条团长提成记录
-                Long id = orderInfo.getId();
-                List<MallOrderItem> mallOrderItemList = mallOrderItemMapper.selectListByOrderId(id);
-                if(CollUtil.isNotEmpty(mallOrderItemList)){
-                    for(MallOrderItem mallOrderItem : mallOrderItemList){
-                        Integer state = mallOrderItem.getState() == null ? 1 : mallOrderItem.getState();
-                        if(1 == state){
-                            MallLeaderAchieve mallLeaderAchieve = new MallLeaderAchieve();
-                            mallLeaderAchieve.setMemberId(orderInfo.getMemberId());
-                            mallLeaderAchieve.setOrderNo(orderInfo.getOrderNo());
-                            mallLeaderAchieve.setOrderItemId(mallOrderItem.getId());
-                            BigDecimal itemAmount = mallOrderItem.getAmount();
-                            mallLeaderAchieve.setAmount(itemAmount);
-                            BigDecimal bigDecimal = bonusPercent.multiply(itemAmount).setScale(2, BigDecimal.ROUND_DOWN);
-                            mallLeaderAchieve.setProfitAmount(bigDecimal);
-                            mallLeaderAchieve.setUniqueCode(orderInfo.getTakeUniqueCode());
-                            mallLeaderAchieve.setState(MallLeaderAchieve.STATE_ONE);
-                            mallLeaderAchieveMapper.insert(mallLeaderAchieve);
+                MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCode(orderInfo.getTakeUniqueCode());
+                Integer profitSwitch = mallTeamLeader.getProfitSwitch()==null?2:mallTeamLeader.getProfitSwitch();
+                if(1 == profitSwitch){
+                    BigDecimal bonusPercent =new BigDecimal(mallTeamLeader.getBonusPercent()==null?"0":mallTeamLeader.getBonusPercent());
+//                DataDictionaryCustom dicBonusPercent = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.BONUS_PERCENT.getType(), DataDictionaryEnum.BONUS_PERCENT.getCode());
+//                BigDecimal bonusPercent = new BigDecimal(dicBonusPercent.getValue()).setScale(2,BigDecimal.ROUND_DOWN);
+                    //生成一条团长提成记录
+                    Long id = orderInfo.getId();
+                    List<MallOrderItem> mallOrderItemList = mallOrderItemMapper.selectListByOrderId(id);
+                    if(CollUtil.isNotEmpty(mallOrderItemList)){
+                        for(MallOrderItem mallOrderItem : mallOrderItemList){
+                            Integer state = mallOrderItem.getState() == null ? 1 : mallOrderItem.getState();
+                            if(1 == state){
+                                MallLeaderAchieve mallLeaderAchieve = new MallLeaderAchieve();
+                                mallLeaderAchieve.setMemberId(orderInfo.getMemberId());
+                                mallLeaderAchieve.setOrderNo(orderInfo.getOrderNo());
+                                mallLeaderAchieve.setOrderItemId(mallOrderItem.getId());
+                                BigDecimal itemAmount = mallOrderItem.getAmount();
+                                mallLeaderAchieve.setAmount(itemAmount);
+                                BigDecimal bigDecimal = bonusPercent.multiply(itemAmount).setScale(2, BigDecimal.ROUND_DOWN);
+                                mallLeaderAchieve.setProfitAmount(bigDecimal);
+                                mallLeaderAchieve.setUniqueCode(orderInfo.getTakeUniqueCode());
+                                mallLeaderAchieve.setState(MallLeaderAchieve.STATE_ONE);
+                                mallLeaderAchieveMapper.insert(mallLeaderAchieve);
+                            }
                         }
                     }
                 }
@@ -143,27 +150,26 @@
      * 修改业绩的状态
      * 并生成一条提成流水
      */
-//    @Scheduled(cron = "0 0 1 * * ?")
-    @Scheduled(cron = "1 * * * * ?")
+    @Scheduled(cron = "0 0 1 * * ?")
+//    @Scheduled(cron = "1 * * * * ?")
     public void leaderAchieveAuto() {
         log.info("团长每日提成");
-        DataDictionaryCustom dicBonusSwitch = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.BONUS_SWITCH.getType(), DataDictionaryEnum.BONUS_SWITCH.getCode());
-        String bonusSwitch = dicBonusSwitch.getValue();
-        if("1".equals(bonusSwitch)){
-//            DataDictionaryCustom dicBonusPercent = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.BONUS_PERCENT.getType(), DataDictionaryEnum.BONUS_PERCENT.getCode());
-//            BigDecimal bonusPercent = new BigDecimal(dicBonusPercent.getValue()).setScale(2,BigDecimal.ROUND_DOWN);
-            //获取每日提成总数
-            /**
-             * a.unique_code uniqueCode 团长特征码
-             * , IFNULL(sum(a.amount),0) amount 每日提成总金额
-             */
-//            DateTime dateTime = DateUtil.offsetDay(new Date(), -1);
-            DateTime dateTime = DateUtil.offsetDay(new Date(), 0);
-            List<Map<String, String>> allLeaderAchieve = mallLeaderAchieveMapper.selectListByStateAndCreateTimeAndUniqueCode(MallLeaderAchieve.STATE_ONE,dateTime);
-            if (CollUtil.isNotEmpty(allLeaderAchieve)) {
-                for (Map<String, String> map : allLeaderAchieve) {
-                    String uniqueCode = map.get("uniqueCode");
-                    Object profitAmount = map.get("profitAmount");
+        //获取每日提成总数
+        /**
+         * a.unique_code uniqueCode 团长特征码
+         * , IFNULL(sum(a.amount),0) amount 每日提成总金额
+         */
+            DateTime dateTime = DateUtil.offsetDay(new Date(), -1);
+//        DateTime dateTime = DateUtil.offsetDay(new Date(), 0);
+        List<Map<String, String>> allLeaderAchieve = mallLeaderAchieveMapper.selectListByStateAndCreateTimeAndUniqueCode(MallLeaderAchieve.STATE_ONE,dateTime);
+        if (CollUtil.isNotEmpty(allLeaderAchieve)) {
+            for (Map<String, String> map : allLeaderAchieve) {
+                String uniqueCode = map.get("uniqueCode");
+                Object profitAmount = map.get("profitAmount");
+
+                MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCode(uniqueCode);
+                Integer profitSwitch = mallTeamLeader.getProfitSwitch();
+                if(1 == profitSwitch){
                     //直接舍弃小数点的第三位
                     BigDecimal achieveMoney = new BigDecimal(String.valueOf(profitAmount)).setScale(2,BigDecimal.ROUND_DOWN);
                     MallMember mallMember = mallMemberMapper.selectInfoByInviteId(uniqueCode);

--
Gitblit v1.9.1