yujian
2020-04-11 17e98d7bcc27072f97976d24eb504abb02914891
fanli/src/main/java/com/yeshi/fanli/service/impl/order/InviteOrderSubsidyServiceImplV2.java
@@ -4,11 +4,9 @@
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
import javax.annotation.Resource;
@@ -18,13 +16,10 @@
import com.yeshi.fanli.dao.mybatis.order.InviteOrderSubsidyMapper;
import com.yeshi.fanli.entity.bus.user.HongBaoV2;
import com.yeshi.fanli.entity.bus.user.ThreeSale;
import com.yeshi.fanli.entity.bus.user.UserInfo;
import com.yeshi.fanli.entity.bus.user.vip.UserLevelEnum;
import com.yeshi.fanli.entity.order.CommonOrder;
import com.yeshi.fanli.entity.order.HongBaoOrder;
import com.yeshi.fanli.entity.order.InviteOrderSubsidy;
import com.yeshi.fanli.entity.order.OrderTeamReward;
import com.yeshi.fanli.exception.order.CommonOrderException;
import com.yeshi.fanli.exception.order.InviteOrderSubsidyException;
import com.yeshi.fanli.exception.order.OrderTeamRewardException;
@@ -34,7 +29,6 @@
import com.yeshi.fanli.service.inter.order.InviteOrderSubsidyServiceV2;
import com.yeshi.fanli.service.inter.order.OrderHongBaoMapService;
import com.yeshi.fanli.service.inter.order.OrderHongBaoMoneyComputeService;
import com.yeshi.fanli.service.inter.order.OrderTeamRewardService;
import com.yeshi.fanli.service.inter.order.config.HongBaoManageService;
import com.yeshi.fanli.service.inter.user.invite.ThreeSaleSerivce;
import com.yeshi.fanli.service.inter.user.vip.UserVIPInfoService;
@@ -73,9 +67,6 @@
   private OrderHongBaoMoneyComputeService orderHongBaoMoneyComputeService;
   @Resource
   private OrderTeamRewardService orderTeamRewardService;
   @Resource
   private ThreeSaleSerivce threeSaleSerivce;
   @Override
@@ -110,86 +101,12 @@
         update.setState(orderSubsidy.getState());
         update.setUpdateTime(new Date());
         inviteOrderSubsidyMapper.updateByPrimaryKeySelective(update);
         // 添加奖励
         addTeamReward(old.getId());
         //TODO 删除添加奖励
      } else {// 添加
         if (orderSubsidy.getCreateTime() == null)
            orderSubsidy.setCreateTime(new Date());
         inviteOrderSubsidyMapper.insertSelective(orderSubsidy);
         // 添加奖励
         addTeamReward(orderSubsidy.getId());
      }
   }
   // 添加团队奖励
   private void addTeamReward(Long subsidyId) throws OrderTeamRewardException, CommonOrderException {
      // 查询团队奖励的人
      // 计算相应的比例
      InviteOrderSubsidy subsidy = inviteOrderSubsidyMapper.selectByPrimaryKeyForUpdate(subsidyId);
      if (subsidy == null)
         throw new OrderTeamRewardException(20, "补贴不存在");
      // 获取上4级用户
      List<CommonOrder> commonOrderList = commonOrderService.listBySourceTypeAndOrderId(subsidy.getSourceType(),
            subsidy.getOrderNo());
      if (commonOrderList == null || commonOrderList.size() == 0) {
         throw new CommonOrderException(1, "订单不存在");
      }
      Date orderTime = commonOrderList.get(0).getThirdCreateTime();
      Long sourceUid = commonOrderList.get(0).getUserInfo().getId();
      List<ThreeSale> bossList = threeSaleSerivce.getMyBossDeepList(sourceUid, 4);
      // 无需要团队奖励的上级
      if (bossList.size() < 3)
         return;
      Set<Long> rewardUid = new HashSet<>();
      for (int i = 2; i < bossList.size(); i++) {
         rewardUid.add(bossList.get(i).getBoss().getId());
      }
      // 删除补贴用户的下级用户
      for (int i = 0; i < bossList.size(); i++) {
         if (bossList.get(i).getBoss().getId().longValue() == subsidy.getUid()) {
            break;
         } else {
            bossList.remove(i);
            i--;
         }
      }
      for (int i = 1; i < bossList.size(); i++) {
         if (rewardUid.contains(bossList.get(i).getBoss().getId())) {
            UserInfo boss = bossList.get(i).getBoss();
            if (i == 1) {
               if (bossList.get(i).getSucceedTime() < subsidy.getCreateTime().getTime()) {
                  UserLevelEnum userLevel = userLevelManager.getUserLevel(boss.getId(), orderTime);
                  BigDecimal rewardMoney = orderHongBaoMoneyComputeService
                        .computeFirstTeamReward(subsidy.getMoney(), subsidy.getCreateTime(), userLevel);
                  if (rewardMoney != null) {
                     // 添加奖励
                     orderTeamRewardService.addOrUpdate(subsidy, rewardMoney, boss.getId(),
                           OrderTeamReward.LEVEL_ONE);
                  }
               }
            } else if (i == 2) {
               if (bossList.get(i).getSucceedTime() < subsidy.getCreateTime().getTime()) {
                  UserLevelEnum userLevel = userLevelManager.getUserLevel(boss.getId(), orderTime);
                  BigDecimal rewardMoney = orderHongBaoMoneyComputeService
                        .computeSecondTeamReward(subsidy.getMoney(), subsidy.getCreateTime(), userLevel);
                  if (rewardMoney != null) {
                     // 添加奖励
                     orderTeamRewardService.addOrUpdate(subsidy, rewardMoney, boss.getId(),
                           OrderTeamReward.LEVEL_TWO);
                  }
               }
            }
         }
         //TODO 删除添加奖励
      }
   }
@@ -344,8 +261,8 @@
               InviteOrderSubsidy update = new InviteOrderSubsidy(subsidy.getId());
               update.setState(InviteOrderSubsidy.STATE_INVALID);
               update.setUpdateTime(new Date());
               update.setInValidTime(new Date());
               inviteOrderSubsidyMapper.updateByPrimaryKeySelective(update);
               orderTeamRewardService.invalidByOrderIdAndSourceType(subsidy.getId());
            }
         }
   }
@@ -375,9 +292,9 @@
               InviteOrderSubsidy update = new InviteOrderSubsidy(subsidy.getId());
               update.setState(InviteOrderSubsidy.STATE_VALID);
               update.setUpdateTime(new Date());
               update.setValidTime(new Date());
               update.setPreGetTime(preGetTime);
               inviteOrderSubsidyMapper.updateByPrimaryKeySelective(update);
               orderTeamRewardService.validByOrderIdAndSourceType(subsidy.getId(), preGetTime);
            }
         }
   }
@@ -391,4 +308,33 @@
      inviteOrderSubsidyMapper.updateByPrimaryKeySelective(orderSubsidy);
   }
   @Override
   public BigDecimal sumRecievedMoneyByUid(long uid, Integer level) {
      BigDecimal money = inviteOrderSubsidyMapper.sumRecievedMoneyByUid(uid, level);
      if (money == null) {
         money = new BigDecimal(0);
      }
      return money;
   }
   @Override
   public BigDecimal sumValidMoneyByUidAndDate(long uid, Integer day, Integer level) {
      BigDecimal money = inviteOrderSubsidyMapper.sumValidMoneyByUidAndDate(uid, day, level);
      if (money == null) {
         money = new BigDecimal(0);
      }
      return money;
   }
   @Override
   public BigDecimal sumMoneyByUidAndDateAndState(long uid, Integer day, Integer level, Integer state) {
      BigDecimal money = inviteOrderSubsidyMapper.sumMoneyByUidAndDateAndState(uid, day, level, state);
      if (money == null) {
         money = new BigDecimal(0);
      }
      return money;
   }
}