From b87c5549fe471167882192944db3f2d6b729476c Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Fri, 15 Mar 2024 14:13:55 +0800
Subject: [PATCH] 抽奖

---
 src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java |  299 ++++++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 261 insertions(+), 38 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java
index d7d88f3..10801e2 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java
@@ -2,10 +2,9 @@
 
 import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.common.entity.QueryRequest;
-import cc.mrbird.febs.common.enumerates.AgentLevelEnum;
-import cc.mrbird.febs.common.enumerates.FlowTypeEnum;
-import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
+import cc.mrbird.febs.common.enumerates.*;
 import cc.mrbird.febs.common.exception.FebsException;
+import cc.mrbird.febs.common.utils.AppContants;
 import cc.mrbird.febs.common.utils.LoginUserUtil;
 import cc.mrbird.febs.common.utils.MallUtils;
 import cc.mrbird.febs.mall.dto.*;
@@ -13,10 +12,13 @@
 import cc.mrbird.febs.mall.entity.MallNewsInfo;
 import cc.mrbird.febs.mall.mapper.*;
 import cc.mrbird.febs.mall.service.IAdminMallMemberService;
+import cc.mrbird.febs.mall.service.IApiMallMemberService;
 import cc.mrbird.febs.mall.service.IApiMallMemberWalletService;
 import cc.mrbird.febs.mall.service.IMallMoneyFlowService;
 import cc.mrbird.febs.mall.vo.*;
+import cc.mrbird.febs.pay.model.NBYHResponse;
 import cc.mrbird.febs.pay.model.SinglePayDto;
+import cc.mrbird.febs.pay.service.NBYHService;
 import cc.mrbird.febs.pay.service.UnipayService;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.ObjectUtil;
@@ -30,12 +32,14 @@
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.xmlbeans.impl.store.Query;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import java.math.BigDecimal;
 import java.util.Date;
 import java.util.List;
+import java.util.stream.Collectors;
 
 /**
  * @author wzy
@@ -52,6 +56,9 @@
     private final MallMemberWalletMapper mallMemberWalletMapper;
 
     private final MallMoneyFlowMapper mallMoneyFlowMapper;
+    private final IMallMoneyFlowService mallMemberService;
+    private final IApiMallMemberService iApiMallMemberService;
+    private final IApiMallMemberService apiMallMemberService;
 
     private final MallMemberPaymentMapper mallMemberPaymentMapper;
 
@@ -68,6 +75,9 @@
     private final IMallMoneyFlowService mallMoneyFlowService;
     private final UnipayService unipayService;
     private final MallMemberBankMapper mallMemberBankMapper;
+    private final MallScoreRecordMapper mallScoreRecordMapper;
+    private final MallScoreAchieveReleaseMapper mallScoreAchieveReleaseMapper;
+    private final NBYHService nbyhService;
 
     @Override
     public IPage<MallMember> getMallMemberList(MallMember mallMember, QueryRequest request) {
@@ -110,7 +120,20 @@
         if (type == 1) {
             mallMember.setDirector(value);
         } else if (type == 2){
+            /**
+             * 线下服务商设置
+             *  团队下没有线下服务商,才能成为线下服务商
+             */
+//            List<MallMember> mallMembers = mallMemberMapper.selectAllChildAgentListByInviteIdAndStoreMaster(mallMember.getInviteId(), 1);
+//            if(CollUtil.isNotEmpty(mallMembers)){
+//                List<String> phoneList = mallMembers.stream().map(MallMember::getPhone).collect(Collectors.toList());
+//                throw new FebsException("团队存在线下服务中心,账号为【"+phoneList.toString()+"】");
+//            }
             mallMember.setStoreMaster(value);
+        }else if (type == 3){
+            mallMember.setCreater(value);
+        } else if (type == 4){
+            mallMember.setPartner(value);
         } else {
             throw new FebsException("参数错误");
         }
@@ -157,38 +180,30 @@
             return new FebsResponse().fail().message("当前状态不是提现中");
         }
 
-        Long wtihdrawTypeId = mallMemberWithdraw.getWtihdrawTypeId();
-        MallMemberBank mallMemberBank = mallMemberBankMapper.selectById(wtihdrawTypeId);
-        /**
-         * 调用汇聚代付
-         */
-        SinglePayDto singlePayDto = new SinglePayDto();
-        singlePayDto.setMerchantOrderNo(mallMemberWithdraw.getWithdrawNo());
-        singlePayDto.setReceiverAccountNoEncBankNo(mallMemberBank.getBankNo());
-        singlePayDto.setReceiverAccountNoEncName(mallMemberBank.getName());
-        singlePayDto.setReceiverAccountType("201");
-        BigDecimal paidAmount = mallMemberWithdraw.getAmount().subtract(mallMemberWithdraw.getAmountFee()).setScale(2, BigDecimal.ROUND_DOWN);
-        singlePayDto.setPaidAmount(paidAmount);
-        singlePayDto.setCurrency("201");
-        singlePayDto.setIsChecked("202");
-        singlePayDto.setPaidDesc("用户提现");
-        singlePayDto.setPaidUse("202");
-        String singlePayRep = unipayService.singlePay(singlePayDto);
-        if(!mallMemberWithdraw.getWithdrawNo().equals(singlePayRep)){
-            return new FebsResponse().fail().message("提现失败,请联系技术人员");
-        }
-
         mallMemberWithdraw.setStatus(2);
         mallMemberWithdrawMapper.updateById(mallMemberWithdraw);
-
         QueryWrapper<MallMoneyFlow> objectQueryWrapper = new QueryWrapper<>();
         objectQueryWrapper.eq("order_no",mallMemberWithdraw.getWithdrawNo());
-        objectQueryWrapper.eq("type",MoneyFlowTypeEnum.WITHDRAWAL.getValue());
+        objectQueryWrapper.eq("type",MoneyFlowTypeNewEnum.RANK_BONUS.getValue());
         MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectOne(objectQueryWrapper);
-        mallMoneyFlow.setStatus(2);
-        mallMoneyFlowMapper.updateById(mallMoneyFlow);
-
-        return new FebsResponse().success();
+        if(ObjectUtil.isNotEmpty(mallMoneyFlow)){
+            mallMoneyFlow.setStatus(3);
+            mallMoneyFlowMapper.updateById(mallMoneyFlow);
+        }else{
+            //用户佣金增加对应的余额
+            iApiMallMemberWalletService.add(mallMemberWithdraw.getAmount(),mallMemberWithdraw.getMemberId(),"balance");
+            iApiMallMemberService.addMoneyFlow(
+                    mallMemberWithdraw.getMemberId(),
+                    mallMemberWithdraw.getAmount(),
+                    MoneyFlowTypeNewEnum.AGENT_BONUS.getValue(),
+                    mallMemberWithdraw.getWithdrawNo(),
+                    MoneyFlowTypeNewEnum.AGENT_BONUS.getDescription(),
+                    null,
+                    null,
+                    3,
+                    FlowTypeEnum.BALANCE.getValue());
+        }
+        return new FebsResponse().success().message("操作成功");
     }
 
     @Override
@@ -207,13 +222,26 @@
 
         QueryWrapper<MallMoneyFlow> objectQueryWrapper = new QueryWrapper<>();
         objectQueryWrapper.eq("order_no",mallMemberWithdraw.getWithdrawNo());
-        objectQueryWrapper.eq("type",MoneyFlowTypeEnum.WITHDRAWAL.getValue());
+        objectQueryWrapper.eq("type",MoneyFlowTypeNewEnum.RANK_BONUS.getValue());
         MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectOne(objectQueryWrapper);
-        mallMoneyFlow.setStatus(3);
-        mallMoneyFlowMapper.updateById(mallMoneyFlow);
+        if(ObjectUtil.isNotEmpty(mallMoneyFlow)){
+            mallMoneyFlow.setStatus(3);
+            mallMoneyFlowMapper.updateById(mallMoneyFlow);
+            //用户佣金增加对应的余额
+            iApiMallMemberWalletService.add(mallMemberWithdraw.getAmount(),mallMemberWithdraw.getMemberId(),"balance");
+        }else{
+            iApiMallMemberService.addMoneyFlow(
+                    mallMemberWithdraw.getMemberId(),
+                    mallMemberWithdraw.getAmount(),
+                    MoneyFlowTypeNewEnum.AGENT_BONUS.getValue(),
+                    mallMemberWithdraw.getWithdrawNo(),
+                    MoneyFlowTypeNewEnum.AGENT_BONUS.getDescription(),
+                    null,
+                    null,
+                    3,
+                    FlowTypeEnum.BALANCE.getValue());
+        }
 
-        //用户佣金增加对应的余额
-        iApiMallMemberWalletService.add(mallMemberWithdraw.getAmount().negate(),mallMemberWithdraw.getMemberId(),"commission");
         return new FebsResponse().success();
     }
 
@@ -369,7 +397,7 @@
         if(StrUtil.isEmpty(level) || !AgentLevelEnum.ZERO_LEVEL.name().equals(mallMember.getLevel())){
             return new FebsResponse().fail().message("该用户无法激活");
         }
-        mallMember.setLevel(AgentLevelEnum.FIRST_LEVEL.name());
+        mallMember.setLevel(AgentLevelEnum.SECOND_LEVEL.name());
         mallMemberMapper.updateById(mallMember);
         return new FebsResponse().success();
     }
@@ -410,7 +438,17 @@
         } else {
             iApiMallMemberWalletService.add(mallSystemPayDto.getAddBalance(), mallSystemPayDto.getId(), filedType);
         }
-        mallMoneyFlowService.addMoneyFlow(memberId, bigDecimal, MoneyFlowTypeEnum.SYSTEM.getValue(), null, type);
+        String orderNo = MallUtils.getOrderNum("C");
+        apiMallMemberService.addMoneyFlow(
+                memberId,
+                bigDecimal,
+                MoneyFlowTypeNewEnum.AGENT_BONUS.getValue(),
+                orderNo,
+                MoneyFlowTypeNewEnum.AGENT_BONUS.getDescription(),
+                null,
+                null,
+                2,
+                FlowTypeEnum.BALANCE.getValue());
         return new FebsResponse().success();
     }
 
@@ -460,7 +498,7 @@
 
             // 重置交易密码
             if (type == 1) {
-                String payPwd = SecureUtil.md5("654321");
+                String payPwd = SecureUtil.md5("123456");
                 member.setTradePassword(payPwd);
                 // 重置登录密码
             } else {
@@ -615,6 +653,191 @@
         mallShopApplyMapper.updateById(mallShopApply);
     }
 
+    @Override
+    public AdminMallMemberPaymentVo getMallBankInfoById(long id) {
+
+        MallMemberWithdraw mallMemberWithdraw = mallMemberWithdrawMapper.selectById(id);
+        Long wtihdrawTypeId = mallMemberWithdraw.getWtihdrawTypeId();
+        MallMemberBank mallMemberBank = mallMemberBankMapper.selectById(wtihdrawTypeId);
+        AdminMallMemberPaymentVo adminMallMemberPaymentVo = new AdminMallMemberPaymentVo();
+        if(ObjectUtil.isNotEmpty(mallMemberBank)){
+            adminMallMemberPaymentVo.setBankNo(mallMemberBank.getBankNo());
+            adminMallMemberPaymentVo.setBankName(mallMemberBank.getName());
+            adminMallMemberPaymentVo.setDigitalNo(mallMemberBank.getDigitalNo());
+            adminMallMemberPaymentVo.setSubbranchName(mallMemberBank.getSubbranchName());
+            adminMallMemberPaymentVo.setBank(mallMemberBank.getBankName());
+            adminMallMemberPaymentVo.setIdCardNum(mallMemberBank.getIdCardNum());
+            adminMallMemberPaymentVo.setPhone(mallMemberBank.getPhone());
+            adminMallMemberPaymentVo.setName(mallMemberBank.getName());
+        }
+        return adminMallMemberPaymentVo;
+    }
+
+    @Override
+    public FebsResponse updateVoucher(MallSystemPayDto mallSystemPayDto) {
+        Long memberId = mallSystemPayDto.getId();
+        MallMember mallMember = mallMemberMapper.selectById(memberId);
+        if(ObjectUtil.isEmpty(mallMember)){
+            return new FebsResponse().fail().message("系统繁忙,请刷新页面重试");
+        }
+
+        BigDecimal addBalance = mallSystemPayDto.getAddBalance();
+        if(addBalance.compareTo(BigDecimal.ZERO) <= 0){
+            return new FebsResponse().fail().message("请输入正确的数量");
+        }
+
+        DataDictionaryCustom totalCntDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                GreenScoreEnum.TOTAL_CNT.getType(),
+                GreenScoreEnum.TOTAL_CNT.getCode()
+        );
+
+        BigDecimal totalCnt = new BigDecimal(totalCntDic.getValue());
+        //凭证占总数的10%
+        BigDecimal roleCnt = totalCnt.multiply(new BigDecimal(0.1));
+        //获取已卖出的凭证数量
+        BigDecimal roleCntSale = mallScoreRecordMapper.selectSumScoreCnt().setScale(2,BigDecimal.ROUND_DOWN);
+        roleCntSale = roleCntSale.add(addBalance);
+
+        if(roleCnt.compareTo(roleCntSale) < 0){
+            return new FebsResponse().fail().message("已拨付:"+roleCntSale);
+        }
+        /**
+         * 增加一条会员购买记录
+         * mall_score_record
+         */
+        MallScoreRecord mallScoreRecord = new MallScoreRecord();
+        mallScoreRecord.setMemberId(memberId);
+        mallScoreRecord.setScoreNo(MallUtils.getOrderNum("MSR"));
+        mallScoreRecord.setScoreCnt(addBalance);
+        mallScoreRecord.setSurplusCnt(addBalance);
+        mallScoreRecordMapper.insert(mallScoreRecord);
+        /**
+         * 减少剩余绿色凭证数量
+         */
+        DataDictionaryCustom surplusCntDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                GreenScoreEnum.SURPLUS_CNT.getType(),
+                GreenScoreEnum.SURPLUS_CNT.getCode()
+        );
+        BigDecimal surplusCnt = new BigDecimal(surplusCntDic.getValue());
+        surplusCnt = surplusCnt.subtract(addBalance);
+        surplusCntDic.setValue(surplusCnt.toString());
+        dataDictionaryCustomMapper.updateById(surplusCntDic);
+        return new FebsResponse().success();
+    }
+
+    @Override
+    public IPage<MallScoreRecord> gerRoleReleaseList(AdminRoleReleaseDto roleReleaseDto, QueryRequest request) {
+        Page<MallScoreRecord> page = new Page<>(request.getPageNum(), request.getPageSize());
+        IPage<MallScoreRecord> mallScoreRecordIPage = mallScoreRecordMapper.gerRoleReleaseListInPage(page, roleReleaseDto);
+        return mallScoreRecordIPage;
+    }
+
+    @Override
+    public IPage<MallMoneyFlow> roleReleaseChild(QueryRequest request, MallScoreRecord mallScoreRecord) {
+        Page<MallMoneyFlow> page = new Page<>(request.getPageNum(), request.getPageSize());
+        MallScoreRecord mallScore = mallScoreRecordMapper.selectById(mallScoreRecord.getId());
+        IPage<MallMoneyFlow> mallMoneyFlowIPage = mallScoreRecordMapper.gerRoleReleaseChildInPage(page, mallScore);
+        return mallMoneyFlowIPage;
+    }
+
+    @Override
+    public IPage<MallScoreAchieveRelease> gerAchieveReleaseList(AdminRoleReleaseDto roleReleaseDto, QueryRequest request) {
+        Page<MallScoreAchieveRelease> page = new Page<>(request.getPageNum(), request.getPageSize());
+        IPage<MallScoreAchieveRelease> MallScoreAchieveReleases = mallScoreAchieveReleaseMapper.gerAchieveReleaseListInPage(page, roleReleaseDto);
+        return MallScoreAchieveReleases;
+    }
+
+    @Override
+    public IPage<MallMoneyFlow> achieveReleaseChild(QueryRequest request, MallScoreAchieveRelease mallScoreAchieveRelease) {
+        Page<MallMoneyFlow> page = new Page<>(request.getPageNum(), request.getPageSize());
+        MallScoreAchieveRelease mallScoreAchieve = mallScoreAchieveReleaseMapper.selectById(mallScoreAchieveRelease.getId());
+        IPage<MallMoneyFlow> mallMoneyFlowIPage = mallScoreAchieveReleaseMapper.gerAchieveReleaseChildInPage(page, mallScoreAchieve);
+        return mallMoneyFlowIPage;
+    }
+
+    @Override
+    public FebsResponse insideWithType(Long id, int i) {
+        MallMember mallMember = mallMemberMapper.selectById(id);
+        if(ObjectUtil.isEmpty(mallMember)) {
+            return new FebsResponse().fail().message("会员信息不存在");
+        }
+        mallMember.setInsideWith(i);
+        mallMemberMapper.updateById(mallMember);
+        return new FebsResponse().success();
+    }
+
+    @Override
+    public FebsResponse searchInfo(Long id) {
+        NBYHResponse nbyhResponse1 = nbyhService.transferResultInfoQuery(id);
+        return new FebsResponse().success().message(nbyhResponse1.getMsg());
+    }
+
+    @Override
+    public FebsResponse accountInfo(Long id) {
+        boolean b = nbyhService.accountInfoQuery(id);
+        if(!b){
+            return new FebsResponse().fail().message("银行账户余额不足");
+        }
+        return new FebsResponse().success().message("可以转账");
+    }
+
+    @Override
+    public FebsResponse outsideWithType(Long id, int i) {
+        MallMember mallMember = mallMemberMapper.selectById(id);
+        if(ObjectUtil.isEmpty(mallMember)) {
+            return new FebsResponse().fail().message("会员信息不存在");
+        }
+        mallMember.setOutsideWith(i);
+        mallMemberMapper.updateById(mallMember);
+        return new FebsResponse().success();
+    }
+
+    @Override
+    @Transactional
+    public FebsResponse chargeAgreeWithType(MallMemberWithdraw mallMemberWithdrawInfo) {
+        MallMemberWithdraw mallMemberWithdraw = mallMemberWithdrawMapper.selectById(mallMemberWithdrawInfo.getId());
+
+        if(ObjectUtil.isEmpty(mallMemberWithdraw)){
+            return new FebsResponse().fail().message("系统繁忙,请刷新后重试");
+        }
+        if(1 != mallMemberWithdraw.getStatus()){
+            return new FebsResponse().fail().message("当前状态不是提现中");
+        }
+
+        Long wtihdrawTypeId = mallMemberWithdraw.getWtihdrawTypeId();
+        MallMemberBank mallMemberBank = mallMemberBankMapper.selectById(wtihdrawTypeId);
+        if(ObjectUtil.isEmpty(mallMemberBank)){
+            return new FebsResponse().fail().message("提现银行卡已删除");
+        }
+        mallMemberWithdraw.setStatus(2);
+        mallMemberWithdrawMapper.updateById(mallMemberWithdraw);
+
+        QueryWrapper<MallMoneyFlow> flowQueryWrapper = new QueryWrapper<>();
+        flowQueryWrapper.eq("order_no",mallMemberWithdraw.getWithdrawNo());
+        flowQueryWrapper.eq("type",MoneyFlowTypeEnum.WITHDRAWAL.getValue());
+        MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectOne(flowQueryWrapper);
+        if(ObjectUtil.isNotEmpty(mallMoneyFlow)){
+            mallMoneyFlow.setStatus(2);
+            mallMoneyFlowMapper.updateById(mallMoneyFlow);
+        }
+        if(MoneyFlowTypeNewEnum.AGENT_BONUS.getDescription().equals(mallMemberWithdraw.getRemark())){
+            //用户佣金增加对应的余额
+            iApiMallMemberWalletService.add(mallMemberWithdraw.getAmount(),mallMemberWithdraw.getMemberId(),"balance");
+            iApiMallMemberService.addMoneyFlow(
+                    mallMemberWithdraw.getMemberId(),
+                    mallMemberWithdraw.getAmount(),
+                    MoneyFlowTypeNewEnum.AGENT_BONUS.getValue(),
+                    mallMemberWithdraw.getWithdrawNo(),
+                    MoneyFlowTypeNewEnum.AGENT_BONUS.getDescription(),
+                    null,
+                    null,
+                    2,
+                    FlowTypeEnum.BALANCE.getValue());
+        }
+        return new FebsResponse().success();
+
+    }
+
     private String refererIds(String parentId) {
         boolean flag = false;
         if (StrUtil.isBlank(parentId)) {

--
Gitblit v1.9.1