From 187a712b4bb1ec10e2fd545e023ea4c551a2926e Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Mon, 08 Jul 2024 11:12:08 +0800 Subject: [PATCH] 逻辑 --- src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java | 53 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 53 insertions(+), 0 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java index f5fd2de..dc84574 100644 --- a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappWalletServiceImpl.java @@ -761,6 +761,59 @@ return apiStorageInfoVos; } + @Override + public List<ApiDirectInfoVo> directNumIndex() { + List<ApiDirectInfoVo> apiDirectInfoVos = new ArrayList<>(); + /** + * 存放直推人数<上级的memberId,直推人数> + */ + HashMap<Long, BigDecimal> map = new HashMap<>(); + + List<DappMemberEntity> dappMemberEntityList = dappMemberDao.selectListByDate(new Date()); + if(CollUtil.isNotEmpty(dappMemberEntityList)){ + for(DappMemberEntity member : dappMemberEntityList){ + if(StrUtil.isEmpty(member.getRefererId())){ + continue; + } + DappMemberEntity memberRef = dappMemberDao.selectMemberInfoByInviteId(member.getRefererId()); + if(ObjectUtil.isEmpty(memberRef)){ + continue; + } + Long id = memberRef.getId(); + if(map.containsKey(id)){ + BigDecimal bigDecimal = map.get(id); + BigDecimal add = bigDecimal.add(new BigDecimal("1")); + map.put(id,add); + }else{ + map.put(id,new BigDecimal("1")); + } + } + } + /** + * 获取这个map的直推人数前十,分发奖励 + */ + if(!map.isEmpty()){ + // 使用Stream API按照BigDecimal从大到小排序 + List<Map.Entry<Long, BigDecimal>> topTenEntries = map.entrySet().stream() + .sorted(Map.Entry.comparingByValue(Comparator.reverseOrder())) + .limit(10) + .collect(Collectors.toList()); + for (Map.Entry<Long, BigDecimal> entry : topTenEntries) { + + Long memberId = entry.getKey(); + BigDecimal directCnt = entry.getValue(); + ApiDirectInfoVo apiDirectInfoVo = new ApiDirectInfoVo(); + apiDirectInfoVo.setAddress(dappMemberDao.selectById(memberId).getAddress()); + apiDirectInfoVo.setAmount(directCnt); + + apiDirectInfoVos.add(apiDirectInfoVo); + } + } + + + return apiDirectInfoVos; + } + public MemberNodeVo buildTeamMatrix(DbMemberNode dbMemberNode) { Long id = dbMemberNode.getId(); -- Gitblit v1.9.1