From 28cf328a098334b51a3e9d2d56f983fb8c862211 Mon Sep 17 00:00:00 2001 From: yujian <yujian@163.com> Date: 星期六, 23 五月 2020 09:54:38 +0800 Subject: [PATCH] 足迹、收藏订单兼容新需求 --- fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/TeamUserLevelStatisticServiceImpl.java | 143 ++++++++++++++++++++++++++++++++++------------- 1 files changed, 104 insertions(+), 39 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/TeamUserLevelStatisticServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/TeamUserLevelStatisticServiceImpl.java index a071386..b236a26 100644 --- a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/TeamUserLevelStatisticServiceImpl.java +++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/TeamUserLevelStatisticServiceImpl.java @@ -1,25 +1,27 @@ package com.yeshi.fanli.service.impl.user.vip; +import java.util.ArrayList; import java.util.Date; +import java.util.HashMap; import java.util.List; +import java.util.Map; import javax.annotation.Resource; import org.springframework.stereotype.Service; import com.yeshi.fanli.dao.mybatis.user.vip.TeamUserLevelStatisticMapper; -import com.yeshi.fanli.entity.bus.user.ThreeSale; +import com.yeshi.fanli.dao.mybatis.user.vip.UserLevelStatisticMapper; +import com.yeshi.fanli.dto.vip.UserLevelStatisticDTO; import com.yeshi.fanli.entity.bus.user.vip.TeamUserLevelStatistic; import com.yeshi.fanli.entity.bus.user.vip.UserLevelEnum; import com.yeshi.fanli.service.inter.user.invite.ThreeSaleSerivce; import com.yeshi.fanli.service.inter.user.vip.TeamUserLevelStatisticService; import com.yeshi.fanli.service.manger.user.UserLevelManager; +import com.yeshi.fanli.util.user.UserLevelUtil; @Service public class TeamUserLevelStatisticServiceImpl implements TeamUserLevelStatisticService { - - @Resource - private ThreeSaleSerivce threeSaleSerivce; @Resource private UserLevelManager userLevelManager; @@ -27,70 +29,123 @@ @Resource private TeamUserLevelStatisticMapper teamUserLevelStatisticMapper; + @Resource + private ThreeSaleSerivce threeSaleSerivce; + + @Resource + private UserLevelStatisticMapper userLevelStatisticMapper; + @Override public TeamUserLevelStatistic selectByUid(Long uid) { return teamUserLevelStatisticMapper.selectByPrimaryKey(uid); } @Override - public void initData(Long uid) { - int state = ThreeSale.STATE_SUCCESS; - long count = threeSaleSerivce.countFirstTeam(uid, state); - List<ThreeSale> list = threeSaleSerivce.listFirstTeam(0L, (int) count, uid, state); - int normalFirstCount = 0; - int highFirstCount = 0; - int superFirstCount = 0; - for (ThreeSale ts : list) { - UserLevelEnum level = userLevelManager.getUserLevel(ts.getWorker().getId()); - if (level == UserLevelEnum.normalVIP) { - normalFirstCount++; - } else if (level == UserLevelEnum.highVIP) { - highFirstCount++; - } else if (level == UserLevelEnum.superVIP) { - superFirstCount++; + public List<TeamUserLevelStatistic> listByUids(List<Long> uids) { + + List<TeamUserLevelStatistic> resultList = new ArrayList<>(); + + List<TeamUserLevelStatistic> list = teamUserLevelStatisticMapper.listByUids(uids); + // 鏀惧叆Map涓� + Map<Long, TeamUserLevelStatistic> map = new HashMap<>(); + if (list != null) + for (TeamUserLevelStatistic s : list) { + map.put(s.getId(), s); + } + + for (Long uid : uids) { + if (map.get(uid) == null) { + initData(uid); + TeamUserLevelStatistic statistic = selectByUid(uid); + resultList.add(statistic); + } else { + resultList.add(map.get(uid)); } } - int normalSecondCount = 0; + return resultList; + } + + @Override + public void initData(Long uid) { + List<UserLevelStatisticDTO> firstList = userLevelStatisticMapper.statisticFirstTeamLevelCount(uid); + List<UserLevelStatisticDTO> secondList = userLevelStatisticMapper.statisticSecondTeamLevelCount(uid); + int daRenFirstCount = 0; + int highFirstCount = 0; + int superFirstCount = 0; + int tearcherFirstCount = 0; + + for (UserLevelStatisticDTO dto : firstList) { + UserLevelEnum level = UserLevelUtil.getByLevel(dto.getLevel()); + if (level == null) + level = UserLevelEnum.daRen; + + if (level == UserLevelEnum.daRen || level == UserLevelEnum.normalVIP) { + daRenFirstCount += dto.getNum(); + } else if (level == UserLevelEnum.highVIP) + highFirstCount += dto.getNum(); + else if (level == UserLevelEnum.superVIP) + superFirstCount += dto.getNum(); + else if (level == UserLevelEnum.tearcher) + tearcherFirstCount += dto.getNum(); + } + + int daRenSecondCount = 0; int highSecondCount = 0; int superSecondCount = 0; + int tearcherSecondCount = 0; - long secondCount = threeSaleSerivce.countSecondTeam(uid, state); - int pageSize = 1000; - int toalPage = (int) (secondCount % pageSize == 0 ? secondCount / pageSize : secondCount / pageSize + 1); - for (int i = 0; i < toalPage; i++) { - list = threeSaleSerivce.listSecondTeam(i * pageSize, pageSize, uid, state); - if (list != null) - for (ThreeSale ts : list) { - UserLevelEnum level = userLevelManager.getUserLevel(ts.getWorker().getId()); - if (level == UserLevelEnum.normalVIP) { - normalSecondCount++; - } else if (level == UserLevelEnum.highVIP) { - highSecondCount++; - } else if (level == UserLevelEnum.superVIP) { - superSecondCount++; - } - } + for (UserLevelStatisticDTO dto : secondList) { + UserLevelEnum level = UserLevelUtil.getByLevel(dto.getLevel()); + if (level == null) + level = UserLevelEnum.daRen; + + if (level == UserLevelEnum.daRen || level == UserLevelEnum.normalVIP) { + daRenSecondCount += dto.getNum(); + } else if (level == UserLevelEnum.highVIP) + highSecondCount += dto.getNum(); + else if (level == UserLevelEnum.superVIP) + superSecondCount += dto.getNum(); + else if (level == UserLevelEnum.tearcher) + tearcherSecondCount += dto.getNum(); } UserLevelEnum level = userLevelManager.getUserLevel(uid); TeamUserLevelStatistic statistic = new TeamUserLevelStatistic(); - statistic.setNormalFirstCount(normalFirstCount); - statistic.setNormalSecondCount(normalSecondCount); + statistic.setDaRenFirstCount(daRenFirstCount); + statistic.setDaRenSecondCount(daRenSecondCount); statistic.setHighFirstCount(highFirstCount); statistic.setHighSecondCount(highSecondCount); statistic.setSuperFirstCount(superFirstCount); statistic.setSuperSecondCount(superSecondCount); + statistic.setTearcherFirstCount(tearcherFirstCount); + statistic.setTearcherSecondCount(tearcherSecondCount); statistic.setId(uid); statistic.setLevel(level); add(statistic); } @Override + public void setUserLevel(Long uid, UserLevelEnum level) { + + TeamUserLevelStatistic old = selectByUid(uid); + if (old == null) { + initData(uid); + old = selectByUid(uid); + } + + TeamUserLevelStatistic update = new TeamUserLevelStatistic(); + update.setId(old.getId()); + update.setLevel(level); + update.setUpdateTime(new Date()); + teamUserLevelStatisticMapper.updateByPrimaryKeySelective(update); + } + + @Override public void add(TeamUserLevelStatistic statistic) { TeamUserLevelStatistic old = selectByUid(statistic.getId()); if (old == null) { - if(statistic.getCreateTime()==null) + if (statistic.getCreateTime() == null) statistic.setCreateTime(new Date()); teamUserLevelStatisticMapper.insertSelective(statistic); } else { @@ -99,4 +154,14 @@ } } + @Override + public void updateUserLevel(Long uid) { + UserLevelEnum level = userLevelManager.getUserLevel(uid); + TeamUserLevelStatistic statistic = new TeamUserLevelStatistic(); + statistic.setId(uid); + statistic.setLevel(level); + statistic.setUpdateTime(new Date()); + teamUserLevelStatisticMapper.updateByPrimaryKeySelective(statistic); + } + } -- Gitblit v1.8.0