From 5f51a29343d6021e5d2745163c07afe1a67d35cc Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Mon, 21 Nov 2022 16:10:11 +0800
Subject: [PATCH] 20221117

---
 src/main/java/cc/mrbird/febs/dapp/service/impl/DappMemberServiceImpl.java |   77 +++++++++++++++++++++++++++++++++++++-
 1 files changed, 75 insertions(+), 2 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappMemberServiceImpl.java
index 49c4a91..d90468a 100644
--- a/src/main/java/cc/mrbird/febs/dapp/service/impl/DappMemberServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/dapp/service/impl/DappMemberServiceImpl.java
@@ -31,6 +31,7 @@
 import cn.hutool.crypto.asymmetric.RSA;
 import cn.hutool.json.JSONUtil;
 import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
@@ -69,6 +70,8 @@
     private final IgtOnHookPlanOrderDao igtOnHookPlanOrderDao;
     private final AppVersionMapper appVersionMapper;
     private final DappMessageDao dappMessageDao;
+    private final MemberCoinChargeDao memberCoinChargeDao;
+    private final MemberCoinWithdrawDao memberCoinWithdrawDao;
 
     private final RedisTemplate<String, Object> redisTemplate;
 
@@ -1024,7 +1027,7 @@
         dappWalletCoinDao.addTotalAndaddAvailableById(dappWalletCoinEntity.getId(),coinNumber);
 
         DappAccountMoneyChangeEntity dappAccountMoneyChangeEntity = new DappAccountMoneyChangeEntity(memberEntity.getId(),
-                availableAmount,coinNumber,availableAmount.add(coinNumber) ,"充值", 10);
+                availableAmount,coinNumber,availableAmount.add(coinNumber) ,"充值(手动)", 10);
         dappAccountMoneyChangeDao.insert(dappAccountMoneyChangeEntity);
         return new FebsResponse().success().message("操作成功");
     }
@@ -1070,7 +1073,7 @@
             dappAccountMoneyChangeDao.insert(addFlow);
 
             dappAccountMoneyChangeDao.deleteById(dappAccountMoneyChangeEntity.getId());
-            return new FebsResponse().fail().message("操作成功");
+            return new FebsResponse().success().message("操作成功");
         }else{
             return new FebsResponse().fail().message("只允许回退【盈利分成】和【流水佣金】");
         }
@@ -1113,6 +1116,76 @@
         return adminMemberCoinWithdrawVos;
     }
 
+    @Override
+    public IPage<AdminTeamInfoVo> getTeamInfo(DappMemberEntity dappMemberEntity, QueryRequest request) {
+        Page<AdminTeamInfoVo> page = new Page<>(request.getPageNum(), request.getPageSize());
+        dappMemberEntity = this.baseMapper.selectById(dappMemberEntity.getId());
+        IPage<AdminTeamInfoVo> adminTeamInfoVoIPage = this.baseMapper.findTeamInfoListInPage(page, dappMemberEntity);
+        List<AdminTeamInfoVo> records = adminTeamInfoVoIPage.getRecords();
+        if(CollUtil.isNotEmpty(records)){
+            for(AdminTeamInfoVo adminTeamInfoVo : records){
+                Long memberId = adminTeamInfoVo.getId();
+                //获取团队成员的主要信息
+                DappWalletCoinEntity dappWalletCoinEntity = dappWalletCoinDao.selectByMemberId(memberId);
+                adminTeamInfoVo.setTotalAmount(dappWalletCoinEntity.getTotalAmount());
+                adminTeamInfoVo.setAvaAmount(dappWalletCoinEntity.getAvailableAmount());
+                adminTeamInfoVo.setFrozenAmount(dappWalletCoinEntity.getFrozenAmount());
+
+                BigDecimal chargeAmount = memberCoinChargeDao.selectTotalAmountByMemberId(memberId);
+                adminTeamInfoVo.setChargeAmount(chargeAmount);
+
+                BigDecimal withDrawAmount = memberCoinWithdrawDao.selectTotalAmountByMemberIdAndType(memberId,"N");
+                adminTeamInfoVo.setWithDrawAmount(withDrawAmount);
+                BigDecimal insideAmount = memberCoinWithdrawDao.selectTotalAmountByMemberIdAndType(memberId,"Y");
+                adminTeamInfoVo.setInsideAmount(insideAmount);
+
+                QueryWrapper<IgtOnHookPlanOrder> objectQueryWrapper = new QueryWrapper<>();
+                objectQueryWrapper.eq("member_id",memberId);
+                Integer onHookTimes = igtOnHookPlanOrderDao.selectCount(objectQueryWrapper);
+                adminTeamInfoVo.setOnHookTimes(onHookTimes);
+                BigDecimal totalProfit = igtOnHookPlanOrderDao.selectSumProfitByMemberId(memberId);
+                adminTeamInfoVo.setTotalProfit(totalProfit);
+            }
+        }
+        return adminTeamInfoVoIPage;
+    }
+
+    @Override
+    public FebsResponse sendBackMessage(DappMessageEntity dappMessageEntity) {
+        if(ObjectUtil.isEmpty(dappMessageEntity.getBackMessage())){
+            return new FebsResponse().fail().message("回复不能为空。");
+        }
+        Long id = dappMessageEntity.getId();
+        DappMessageEntity dappMessage = dappMessageDao.selectById(id);
+        DappMessageEntity dappMessageEntityBack = new DappMessageEntity();
+        dappMessageEntityBack.setMemberId(dappMessage.getMemberId());
+        StringBuffer stringBuffer = new StringBuffer();
+        stringBuffer.append("客服回复:");
+        stringBuffer.append(dappMessageEntity.getBackMessage());
+        dappMessageEntityBack.setBackMessage(stringBuffer.toString());
+        dappMessageDao.insert(dappMessageEntityBack);
+        return new FebsResponse().success().message("操作成功");
+    }
+
+    @Override
+    public IPage<DappMessageEntity> showMessageList(DappMessageEntity dappMessageEntity, QueryRequest request) {
+        dappMessageEntity = dappMessageDao.selectById(dappMessageEntity.getId());
+        Page<DappMessageEntity> page = new Page<>(request.getPageNum(), request.getPageSize());
+        IPage<DappMessageEntity> dappMessageEntitys = dappMemberDao.showMessageListInPage(page, dappMessageEntity);
+        return dappMessageEntitys;
+    }
+
+    @Override
+    public IPage<ApiMessageListVo> getMessageListInPage(ApiMessageListDto apiMessageListDto) {
+        Page<ApiMessageListVo> page = new Page<>(apiMessageListDto.getPageNum(), apiMessageListDto.getPageSize());
+
+        DappMemberEntity member = LoginUserUtil.getAppUser();
+        DappMessageEntity dappMessageEntity = new DappMessageEntity();
+        dappMessageEntity.setMemberId(member.getId());
+        IPage<ApiMessageListVo> records = dappMemberDao.getMessageListInPage(page, dappMessageEntity);
+        return records;
+    }
+
     public String generateAsaToken(String token) {
         RSA rsa = new RSA(null, AppContants.PUBLIC_KEY);
         return rsa.encryptBase64(token + "_" + System.currentTimeMillis(), KeyType.PublicKey);

--
Gitblit v1.9.1