From 609d2e5f259aeb07b9579fb0ea0c01dd36b482d0 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Tue, 06 Aug 2024 16:04:48 +0800
Subject: [PATCH] 逻辑

---
 src/main/java/cc/mrbird/febs/job/ProfitDailyJob.java |  101 +++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 90 insertions(+), 11 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/job/ProfitDailyJob.java b/src/main/java/cc/mrbird/febs/job/ProfitDailyJob.java
index 6161e8c..7e64049 100644
--- a/src/main/java/cc/mrbird/febs/job/ProfitDailyJob.java
+++ b/src/main/java/cc/mrbird/febs/job/ProfitDailyJob.java
@@ -6,10 +6,12 @@
 import cc.mrbird.febs.dapp.entity.DataDictionaryCustom;
 import cc.mrbird.febs.dapp.enumerate.DataDictionaryEnum;
 import cc.mrbird.febs.dapp.enumerate.MoneyFlowEnum;
+import cc.mrbird.febs.dapp.mapper.DappFundFlowDao;
 import cc.mrbird.febs.dapp.mapper.DappMemberDao;
 import cc.mrbird.febs.dapp.mapper.DappStorageMapper;
 import cc.mrbird.febs.dapp.mapper.DataDictionaryCustomMapper;
 import cc.mrbird.febs.dapp.service.DappSystemService;
+import cc.mrbird.febs.dapp.vo.ApidirectNumVo;
 import cc.mrbird.febs.rabbit.producer.ChainProducer;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.date.DateTime;
@@ -42,6 +44,8 @@
     private DappMemberDao dappMemberDao;
     @Resource
     private ChainProducer chainProducer;
+    @Resource
+    private DappFundFlowDao dappFundFlowDao;
 
     /**
      * 每天释放1%的静态释放
@@ -84,8 +88,27 @@
      * (其中50%给予当天大单排名激励前4名,40%、30%、20、10%;
      * 另外50% 给予当天直推总业绩排名激励前10名,第1名40%,2-4名30%,5-10名30%)
      */
-    @Scheduled(cron = "0 0 0 * * ?")
+    @Scheduled(cron = "0 0/1 0 * * ?")
     public void profitDailyJobOne() {
+
+        Date date = new Date();
+        DappStorage dappStorageLast = dappStorageMapper.selectOneByCreateTimeDesc(0, 1);
+        DateTime dateTime1 = DateUtil.offsetHour(dappStorageLast.getCreateTime(), 24);
+        int compare = DateUtil.compare(dateTime1, date);
+        if(compare > 0){
+            return;
+        }
+
+        DataDictionaryCustom symbolDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                DataDictionaryEnum.BUCHANG_SYMBOL.getType(),
+                DataDictionaryEnum.BUCHANG_SYMBOL.getCode()
+        );
+        if(2 == Integer.parseInt(symbolDic.getValue())){
+            return;
+        }
+        symbolDic.setValue("2");
+        dataDictionaryCustomMapper.updateById(symbolDic);
+
         DataDictionaryCustom buChangChiDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
                 DataDictionaryEnum.BUCAHNG_CHI.getType(),
                 DataDictionaryEnum.BUCAHNG_CHI.getCode()
@@ -173,7 +196,7 @@
             BigDecimal everyAmount = daDanTotal.divide(new BigDecimal(count));
 
             if(everyAmount.compareTo(BigDecimal.ZERO) > 0){
-                List<DappStorage> dappStorageOne = dappStorageMapper.selectSumByAmountDesc(new Date(),0,1);
+                List<DappStorage> dappStorageOne = dappStorageMapper.selectSumByAmountDescFiveToFive(DateUtil.offsetHour(new Date(),-24),0,1);
                 if(CollUtil.isNotEmpty(dappStorageOne)){
                     BigDecimal multiply = everyAmount.multiply(new BigDecimal(oneCount));
                     dappSystemService.updateBalanceInsertFlow(
@@ -184,7 +207,7 @@
 
                     realAmount = realAmount.add(multiply);
                 }
-                List<DappStorage> dappStorageTwo = dappStorageMapper.selectSumByAmountDesc(new Date(),1,1);
+                List<DappStorage> dappStorageTwo = dappStorageMapper.selectSumByAmountDescFiveToFive(DateUtil.offsetHour(new Date(),-24),1,1);
                 if(CollUtil.isNotEmpty(dappStorageTwo)){
                     BigDecimal multiply = everyAmount.multiply(new BigDecimal(twoCount));
                     dappSystemService.updateBalanceInsertFlow(
@@ -195,7 +218,7 @@
 
                     realAmount = realAmount.add(multiply);
                 }
-                List<DappStorage> dappStorageThree = dappStorageMapper.selectSumByAmountDesc(new Date(),2,1);
+                List<DappStorage> dappStorageThree = dappStorageMapper.selectSumByAmountDescFiveToFive(DateUtil.offsetHour(new Date(),-24),2,1);
                 if(CollUtil.isNotEmpty(dappStorageThree)){
                     BigDecimal multiply = everyAmount.multiply(new BigDecimal(threeCount));
                     dappSystemService.updateBalanceInsertFlow(
@@ -206,7 +229,7 @@
 
                     realAmount = realAmount.add(multiply);
                 }
-                List<DappStorage> dappStorageFour = dappStorageMapper.selectSumByAmountDesc(new Date(),3,1);
+                List<DappStorage> dappStorageFour = dappStorageMapper.selectSumByAmountDescFiveToFive(DateUtil.offsetHour(new Date(),-24),3,1);
                 if(CollUtil.isNotEmpty(dappStorageFour)){
                     BigDecimal multiply = everyAmount.multiply(new BigDecimal(fourCount));
                     dappSystemService.updateBalanceInsertFlow(
@@ -256,9 +279,17 @@
          */
         HashMap<Long, BigDecimal> map = new HashMap<>();
 
-        List<DappMemberEntity> dappMemberEntityList = dappMemberDao.selectListByDate(new Date());
-        if(CollUtil.isNotEmpty(dappMemberEntityList)){
-            for(DappMemberEntity member : dappMemberEntityList){
+        DateTime startTime = DateUtil.offsetHour(new Date(), -24);
+//        DateTime startTime = DateUtil.parseDateTime(startTimeStr);
+//        List<DappMemberEntity> dappMemberEntityList = dappMemberDao.selectListByDateFiveToFiver(startTime);
+
+        List<DappStorage> dappStorages = dappStorageMapper.selectListByDateFiveToFiver(startTime);
+        Set<Long> collect = dappStorages.stream().map(DappStorage::getMemberId).collect(Collectors.toSet());
+
+//        List<DappMemberEntity> dappMemberEntityList = dappMemberDao.selectListByDate(new Date());
+        if(CollUtil.isNotEmpty(collect)){
+            for(Long memberId : collect){
+                DappMemberEntity member = dappMemberDao.selectById(memberId);
                 if(StrUtil.isEmpty(member.getRefererId())){
                     continue;
                 }
@@ -289,11 +320,36 @@
                     .limit(10)
                     .collect(Collectors.toList());
 
-            int startNum = 1;
+            List<ApidirectNumVo> apiDirectInfoVos = new ArrayList<>();
             for (Map.Entry<Long, BigDecimal> entry : topTenEntries) {
-
                 Long memberId = entry.getKey();
-                BigDecimal directAchieve = entry.getValue();
+                BigDecimal directCnt = entry.getValue();
+                ApidirectNumVo apiDirectInfoVo = new ApidirectNumVo();
+                apiDirectInfoVo.setMemberId(memberId);
+                apiDirectInfoVo.setDirectCnt(directCnt);
+                DappStorage dappStorage = dappStorageMapper.selectNewRecordByRefMemberId(memberId);
+                apiDirectInfoVo.setCreateTime(dappStorage.getCreateTime());
+                apiDirectInfoVos.add(apiDirectInfoVo);
+            }
+
+            if(CollUtil.isNotEmpty(apiDirectInfoVos)){
+                apiDirectInfoVos = apiDirectInfoVos.stream()
+                        .sorted((a, b) -> {
+                            // 先按照amount从大到小排序
+                            int compare = b.getDirectCnt().compareTo(a.getDirectCnt());
+                            if (compare != 0) {
+                                return compare;
+                            }
+                            // 如果amount相同,则按照createTime从小到大排序
+                            return a.getCreateTime().compareTo(b.getCreateTime());
+                        })
+                        .collect(Collectors.toList());
+            }
+
+            int startNum = 1;
+            for (ApidirectNumVo numVo : apiDirectInfoVos) {
+                Long memberId = numVo.getMemberId();
+                BigDecimal directAchieve = numVo.getDirectCnt();
                 //第一名
                 if(startNum == 1){
                     BigDecimal bigDecimal = directTotal.multiply(new BigDecimal("0.4")).setScale(2, BigDecimal.ROUND_DOWN);
@@ -337,8 +393,31 @@
     }
 
     public static void main(String[] args) {
+
+        Date date = new Date();
+        System.out.println(date);
+        DateTime dateTime1 = DateUtil.offsetHour(date, 24);
+        System.out.println(dateTime1);
+
+        int compare = DateUtil.compare(date, dateTime1);
+        System.out.println(compare);
+
+
+
         DateTime dateTime = DateUtil.offsetHour(new Date(), -24);
         System.out.println(dateTime);
+        DateTime nowTime = DateUtil.parseTime(DateUtil.formatTime(new Date()));
+        DateTime perkTime = DateUtil.parseTime("17:00:00");
+
+        String startTimeStr = null;
+        if(DateUtil.compare(nowTime,perkTime) >= 0){
+            startTimeStr = DateUtil.formatDate(DateUtil.offsetDay(new Date(), 0)) + " 17:00:00";
+        }else{
+            startTimeStr = DateUtil.formatDate(DateUtil.offsetDay(new Date(), -1)) + " 17:00:00";
+        }
+
+        DateTime startTime = DateUtil.parseDateTime(startTimeStr);
+
 
 
         // 创建一个HashMap示例

--
Gitblit v1.9.1