From c1af5cf94920702b6aa962881365116542e88ab0 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Tue, 30 Jul 2024 09:42:46 +0800
Subject: [PATCH] 后台

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java |   69 +++++++++++++++++++++++++++-------
 1 files changed, 55 insertions(+), 14 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
index a29e916..0022d71 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
@@ -107,16 +107,16 @@
                 throw new FebsException("邀请码不存在");
             }
             /**
-             * 设置成普通会员,则不允许推广
+             * 设置成粉丝,则不允许推广
              */
             if(inviteMember.getLevel().equals(MemberLevelEnum.FANS.getType())){
                 throw new FebsException("邀请码不能推广");
             }
             //购买套餐产生业绩,才能推广会员
-            List<MallAchieveRecord> mallAchieveRecordList = mallAchieveRecordMapper.selectByMemberId(inviteMember.getId());
-            if(CollUtil.isEmpty(mallAchieveRecordList)){
-                throw new FebsException("邀请码不能推广");
-            }
+//            List<MallAchieveRecord> mallAchieveRecordList = mallAchieveRecordMapper.selectByMemberId(inviteMember.getId());
+//            if(CollUtil.isEmpty(mallAchieveRecordList)){
+//                throw new FebsException("邀请码不能推广");
+//            }
 
             mallMember.setReferrerId(registerDto.getInviteId());
 
@@ -236,10 +236,12 @@
         MallMember mallMember = this.baseMapper.selectById(id);
 
         MallMemberVo mallMemberVo = MallMemberConversion.INSTANCE.entityToVo(mallMember);
-
-        MallMember referMember = this.baseMapper.selectInfoByInviteId(mallMember.getReferrerId());
-        if (referMember != null) {
-            mallMemberVo.setReferrerName(referMember.getName());
+//        if(ObjectUtil.isNotEmpty(mallMember.getReferrerId())){
+        if(StrUtil.isNotBlank(mallMember.getReferrerId())){
+            MallMember referMember = this.baseMapper.selectInfoByInviteId(mallMember.getReferrerId());
+            if (referMember != null) {
+                mallMemberVo.setReferrerName(referMember.getName());
+            }
         }
 
         if (StrUtil.isNotBlank(mallMember.getTradePassword())) {
@@ -252,11 +254,20 @@
         }
         mallMemberVo.setLevelName(MemberLevelEnum.NORMAL.getLevelDescription(mallMember.getLevel()));
         mallMemberVo.setPartner(mallMember.getPartner());
+        mallMemberVo.setDirector(mallMember.getDirector());
         MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(mallMemberVo.getId());
         mallMemberVo.setBalance(wallet.getBalance());
         mallMemberVo.setScore(wallet.getScore());
         mallMemberVo.setPrizeScore(wallet.getPrizeScore());
+        mallMemberVo.setEquityLimit(wallet.getEquityLimit());
         mallMemberVo.setTotalCost(mallOrderInfoMapper.selectTotalAmount(id));
+
+        DataDictionaryCustom poolScorePriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                PerkEnum.POOL_SCORE_PRICE.getType(),
+                PerkEnum.POOL_SCORE_PRICE.getCode()
+        );
+        BigDecimal poolScorePrice = new BigDecimal(poolScorePriceDic.getValue()).setScale(8, BigDecimal.ROUND_DOWN);
+        mallMemberVo.setPoolScorePrice(poolScorePrice);
         return new FebsResponse().success().data(mallMemberVo);
     }
 
@@ -391,13 +402,40 @@
         if (!loginMember.getTradePassword().equals(SecureUtil.md5(transferDto.getTradePwd()))) {
             throw new FebsException("支付密码错误");
         }
+        MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(memberId);
+        if(wallet.getBalance().compareTo(BigDecimal.ZERO) <= 0){
+            throw new FebsException("金额不足");
+        }
+        if(wallet.getEquityLimit().compareTo(BigDecimal.ZERO) <= 0){
+            throw new FebsException("权益积分不足");
+        }
+        if(transferDto.getAmount().compareTo(wallet.getBalance()) > 0) {
+            throw new FebsException("金额不足");
+        }
 
-        walletService.reduceBalance(transferDto.getAmount(), memberId);
-        String orderNo = MallUtils.getOrderNum("T");
-        this.addMoneyFlow(memberId, transferDto.getAmount().negate(), MoneyFlowTypeEnum.TRANSFER.getValue(), orderNo, null, null, mallMember.getId(), null, FlowTypeEnum.BALANCE.getValue());
+        if(transferDto.getAmount().compareTo(wallet.getEquityLimit()) > 0) {
+            throw new FebsException("权益积分不足");
+        }
+        if(1 == transferDto.getType()){
+            walletService.reduceBalance(transferDto.getAmount(), memberId);
+            walletService.reduce(transferDto.getAmount(), memberId, "equityLimit");//减少权益积分
+            String orderNo = MallUtils.getOrderNum("T");
+            this.addMoneyFlow(memberId, transferDto.getAmount().negate(), MoneyFlowTypeEnum.TRANSFER.getValue(), orderNo, null, null, mallMember.getId(), null, FlowTypeEnum.BALANCE.getValue());
 
-        walletService.addBalance(transferDto.getAmount(), mallMember.getId());
-        this.addMoneyFlow(mallMember.getId(), transferDto.getAmount(), MoneyFlowTypeEnum.TRANSFER.getValue(), orderNo, null, null, memberId, null, FlowTypeEnum.BALANCE.getValue());
+            walletService.addBalance(transferDto.getAmount(), mallMember.getId());
+            this.addMoneyFlow(mallMember.getId(), transferDto.getAmount(), MoneyFlowTypeEnum.TRANSFER.getValue(), orderNo, null, null, memberId, null, FlowTypeEnum.BALANCE.getValue());
+        }
+        if(2 == transferDto.getType()){
+            throw new FebsException("暂未开通");
+//            walletService.reduce(transferDto.getAmount(), memberId, "score");
+//            String orderNo = MallUtils.getOrderNum("T");
+//            this.addMoneyFlow(memberId, transferDto.getAmount().negate(), MoneyFlowTypeEnum.TRANSFER.getValue(), orderNo, null, null, mallMember.getId(), null, FlowTypeEnum.SCORE.getValue());
+//
+//            walletService.add(transferDto.getAmount(), mallMember.getId(), "score");
+//            this.addMoneyFlow(mallMember.getId(), transferDto.getAmount(), MoneyFlowTypeEnum.TRANSFER.getValue(), orderNo, null, null, memberId, null, FlowTypeEnum.SCORE.getValue());
+        }
+
+
     }
 
     @Override
@@ -486,6 +524,7 @@
         MallMemberWallet wallet = mallMemberWalletMapper.selectWalletByMemberId(id);
         commissionVo.setCommissionBalance(wallet.getBalance());
         commissionVo.setCommissionScore(wallet.getScore());
+        commissionVo.setCommission(wallet.getCommission());
         commissionVo.setTodayBalance(mallMoneyFlowMapper.selectCommissionIncome(1,1, new Date(), id));
         commissionVo.setMonthBalance(mallMoneyFlowMapper.selectCommissionIncome(1,2, new Date(), id));
         commissionVo.setTotalBalance(mallMoneyFlowMapper.selectCommissionIncome(1, null,null, id));
@@ -597,6 +636,8 @@
         mallMemberBank.setIdCardNum(updateMemberBankDto.getIdCardNum());
         mallMemberBank.setBankNo(updateMemberBankDto.getBankNo());
         mallMemberBank.setPhone(updateMemberBankDto.getPhone());
+        mallMemberBank.setBankName(updateMemberBankDto.getBankName());
+        mallMemberBank.setBankNameS(updateMemberBankDto.getBankNameS());
         mallMemberBankMapper.updateById(mallMemberBank);
         return new FebsResponse().success();
     }

--
Gitblit v1.9.1