From 9b51a95fa8bc9b3a86108c6900e17fc55f8db467 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Mon, 19 May 2025 17:02:07 +0800
Subject: [PATCH] refactor(vip): 优化积分和返佣计算逻辑

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java |  219 +++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 180 insertions(+), 39 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 1a3f1b3..7761620 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
@@ -1,10 +1,7 @@
 package cc.mrbird.febs.mall.service.impl;
 
 import cc.mrbird.febs.common.entity.FebsResponse;
-import cc.mrbird.febs.common.enumerates.DataDictionaryEnum;
-import cc.mrbird.febs.common.enumerates.FlowTypeEnum;
-import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
-import cc.mrbird.febs.common.enumerates.ScoreFlowTypeEnum;
+import cc.mrbird.febs.common.enumerates.*;
 import cc.mrbird.febs.common.exception.FebsException;
 import cc.mrbird.febs.common.properties.XcxProperties;
 import cc.mrbird.febs.common.utils.*;
@@ -12,6 +9,7 @@
 import cc.mrbird.febs.mall.conversion.MallShopApplyConversion;
 import cc.mrbird.febs.mall.conversion.MallStoreConversion;
 import cc.mrbird.febs.mall.dto.*;
+import cc.mrbird.febs.mall.dto.signActivity.ApiNewGiftSettingDto;
 import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.*;
 import cc.mrbird.febs.mall.service.*;
@@ -49,6 +47,7 @@
 
 import java.io.IOException;
 import java.math.BigDecimal;
+import java.math.RoundingMode;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -89,6 +88,7 @@
     private final MallStoreItemMapper mallStoreItemMapper;
     private final MallStoreMemberMapper mallStoreMemberMapper;
     private final MallDoctorMapper mallDoctorMapper;
+    private final HappyMemberLevelMapper happyMemberLevelMapper;
 
 
     @Value("${spring.profiles.active}")
@@ -264,12 +264,29 @@
         Long id = LoginUserUtil.getLoginUser().getId();
         MallMember mallMember = this.baseMapper.selectById(id);
 
+
+
         MallMemberVo mallMemberVo = MallMemberConversion.INSTANCE.entityToVo(mallMember);
+
+        HappyMemberLevel happyMemberLevel = happyMemberLevelMapper.selectOne(
+                new LambdaQueryWrapper<HappyMemberLevel>()
+                        .select(HappyMemberLevel::getName)
+                        .eq(HappyMemberLevel::getCode, mallMember.getDirector())
+        );
+        if(happyMemberLevel != null){
+            mallMemberVo.setLevelName(happyMemberLevel.getName());
+            mallMemberVo.setLevelNamePng(happyMemberLevel.getIconPng());
+        }
         if(StrUtil.isNotEmpty(mallMember.getReferrerId())){
             MallMember referMember = this.baseMapper.selectInfoByInviteId(mallMember.getReferrerId());
             if (referMember != null) {
                 mallMemberVo.setReferrerName(referMember.getName());
             }
+        }
+        if(mallMember.getStoreMaster() == 0){
+            mallMemberVo.setIsTeamLeader(2);
+        }else{
+            mallMemberVo.setIsTeamLeader(1);
         }
 
         if (StrUtil.isNotBlank(mallMember.getTradePassword())) {
@@ -302,7 +319,7 @@
 
         mallMemberVo.setVipInfo(mallVipConfig);
         mallMemberVo.setBalance(wallet.getBalance());
-//        mallMemberVo.setScore(wallet.getScore());
+        mallMemberVo.setScore(wallet.getScore());
         mallMemberVo.setPrizeScore(wallet.getPrizeScore());
 //        mallMemberVo.setTotalCost(mallOrderInfoMapper.selectTotalAmount(id));
         return new FebsResponse().success().data(mallMemberVo);
@@ -343,6 +360,11 @@
         mallMember.setTradePassword(SecureUtil.md5(forgetPwdDto.getPassword()));
         this.baseMapper.updateById(mallMember);
         return new FebsResponse().success().message("设置成功");
+    }
+
+    public static void main(String[] args) {
+        String pwd = SecureUtil.md5("123456");
+        System.out.println(pwd);
     }
 
     @Override
@@ -633,6 +655,7 @@
                     mallMember.setAccountType(MallMember.ACCOUNT_TYPE_NORMAL);
                     mallMember.setOpenId(openId);
                     mallMember.setSessionKey(sessionKey);
+                    mallMember.setTradePassword(SecureUtil.md5("123456"));
 
                     if (StrUtil.isNotBlank(apiXcxLoginDto.getInviteId())) {
                         MallMember member = this.baseMapper.selectInfoByInviteId(apiXcxLoginDto.getInviteId());
@@ -677,7 +700,17 @@
                     wallet.setBalance(BigDecimal.ZERO);
                     wallet.setMemberId(mallMember.getId());
                     mallMemberWalletMapper.insert(wallet);
+
+                    //分销员的邀请码赠送优惠卷
+                    if (StrUtil.isNotBlank(apiXcxLoginDto.getInviteId())) {
+                        GetCouponDto getCouponDto = new GetCouponDto();
+                        getCouponDto.setInviteId(apiXcxLoginDto.getInviteId());
+                        scanCoupon(getCouponDto);
+                    }
                 } else {
+                    if (MallMember.ACCOUNT_STATUS_DISABLED.equals(mallMember.getAccountStatus())) {
+                        throw new FebsException("账号已停用");
+                    }
                     mallMember.setSessionKey(sessionKey);
                     this.baseMapper.updateById(mallMember);
                 }
@@ -741,6 +774,47 @@
 
         mallMember.setSex(1 == apiXcxSaveInfoDto.getGender() ? "女" : "男");
         this.baseMapper.updateById(mallMember);
+
+        //完善信息赠送新人礼
+        if (StrUtil.isNotBlank(mallMember.getPhone())) {
+            DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                    CommonDictionaryEnum.NEW_GIFT_SETTING.getType(),
+                    CommonDictionaryEnum.NEW_GIFT_SETTING.getCode()
+            );
+            ApiNewGiftSettingDto apiNewGiftSettingDto = JSONObject.parseObject(dic.getValue(), ApiNewGiftSettingDto.class);
+            if (apiNewGiftSettingDto.getState() == 1) {
+                String prizeScore = apiNewGiftSettingDto.getPrizeScore();
+                BigDecimal bigDecimal = new BigDecimal(prizeScore).setScale(0, RoundingMode.HALF_DOWN);
+                if (bigDecimal.compareTo(BigDecimal.ZERO) > 0) {
+                    walletService.add(bigDecimal, mallMember.getId(), "prizeScore");
+                    mallMoneyFlowService.addMoneyFlow(
+                            mallMember.getId(),
+                            bigDecimal,
+                            ScoreFlowTypeEnum.MEMBER_INFO_GIFT.getValue(),
+                            MallUtils.getOrderNum(),
+                            FlowTypeEnum.PRIZE_SCORE.getValue(),
+                            StrUtil.format(ScoreFlowTypeEnum.MEMBER_INFO_GIFT.getDesc(),bigDecimal),
+                            2
+                    );
+                }
+                if (apiNewGiftSettingDto.getCouponId() != null) {
+                    MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(apiNewGiftSettingDto.getCouponId());
+                    if(ObjectUtil.isNotEmpty(mallGoodsCoupon)){
+                        MallMemberCoupon memberCoupon = new MallMemberCoupon();
+                        memberCoupon.setCouponId(mallGoodsCoupon.getId());
+                        memberCoupon.setCouponName(mallGoodsCoupon.getName());
+                        memberCoupon.setInviteId(mallMember.getInviteId());
+                        memberCoupon.setCouponUuid(IdUtil.simpleUUID());
+                        memberCoupon.setState(1);
+                        memberCoupon.setFromType(3);
+                        memberCoupon.setExpireTime(DateUtil.offsetDay(DateUtil.date(), mallGoodsCoupon.getExpireDay()));
+                        memberCoupon.setMemberId(mallMember.getId());
+                        mallMemberCouponMapper.insert(memberCoupon);
+                    }
+                }
+
+            }
+        }
         return new FebsResponse().success();
     }
 
@@ -858,10 +932,12 @@
         mallMoneyFlowService.addMoneyFlow(
                 memberId,
                 amount,
-                MoneyFlowTypeEnum.RECHARGE.getValue(),
+                ScoreFlowTypeEnum.RECHARGE_ING.getValue(),
                 rechargeNo,
                 FlowTypeEnum.BALANCE.getValue(),
-                "余额充值",1);
+                StrUtil.format(ScoreFlowTypeEnum.RECHARGE_ING.getDesc(),amount),
+                1
+        );
 
         String wxResultStr = JSONUtil.toJsonStr(brandWCPayRequestData);
         String payResultStr = brandWCPayRequestData.getPrepay_id();
@@ -1342,18 +1418,19 @@
 
         // 获取当前登录用户的ID
         Long memberId = LoginUserUtil.getLoginUser().getId();
+        log.info("开始绑定医生{}",memberId);
         // 从DTO中提取邀请ID和门店会员ID
         String inviteId = dto.getInviteId();
         Long storeMemberId = dto.getStoreMemberId();
 
         // 根据门店会员ID查询门店会员信息
-        MallStoreMember mallStoreMember = mallStoreMemberMapper.selectById(storeMemberId);
+        MallStoreMember mallStoreMember = mallStoreMemberMapper.selectOne(
+                new LambdaQueryWrapper<MallStoreMember>()
+                .eq(MallStoreMember::getId,storeMemberId)
+                .eq(MallStoreMember::getMemberId,memberId)
+                );
         // 如果门店会员信息为空,抛出异常
         if(null == mallStoreMember){
-            throw new FebsException("当前检测记录无法绑定!");
-        }
-        // 如果门店会员的会员ID与当前登录用户ID不匹配,抛出异常
-        if(mallStoreMember.getMemberId() != memberId){
             throw new FebsException("当前检测记录无法绑定!");
         }
 
@@ -1478,46 +1555,110 @@
         Long memberId = LoginUserUtil.getLoginUser().getId();
 
         MallDoctor mallDoctor = mallDoctorMapper.selectById(dto.getId());
-        if(memberId != mallDoctor.getBindMemberId()){
+        if(!memberId.equals(mallDoctor.getBindMemberId())){
             throw new FebsException("当前授权无法删除!");
         }
         mallDoctorMapper.deleteById(dto.getId());
         return new FebsResponse().success().message("操作成功");
     }
 
-    public static void main(String[] args) {
-        Long userld = 16425L;
-        String shopAccount = "爱和美医疗";
-        String shopPwd = "blnka2005";
+    @Override
+    public FebsResponse flowList(ApiMoneyFlowDto dto) {
+        Long id = LoginUserUtil.getLoginUser().getId();
+        IPage<ApiMoneyFlowVo> page = new Page<>(dto.getPageNum(), dto.getPageSize());
+        dto.setMemberId(id);
+        IPage<ApiMoneyFlowVo> pages = mallMoneyFlowMapper.selectFlowInPage(page, dto);
+        return new FebsResponse().success().data(pages);
+    }
 
-        HashMap<String, String> objectObjectHashMap = new HashMap<>();
+    @Override
+    public FebsResponse flowHeader() {
+        // 获取当前登录用户的ID
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        ApiMoneyFlowHeaderVo apiMoneyFlowHeaderVo = new ApiMoneyFlowHeaderVo();
+        MallMemberWallet mallMemberWallet = mallMemberWalletMapper.selectWalletByMemberId(memberId);
+        apiMoneyFlowHeaderVo.setBalance(mallMemberWallet.getBalance());
+        apiMoneyFlowHeaderVo.setPrizeScore(mallMemberWallet.getPrizeScore());
+        return new FebsResponse().success().data(apiMoneyFlowHeaderVo);
+    }
 
-        objectObjectHashMap.put("shopAccount",shopAccount);
-        objectObjectHashMap.put("shopPwd",shopPwd);
-        objectObjectHashMap.put("userId",userld.toString());
+    @Override
+    public FebsResponse newGiftEvent() {
+        // 获取当前登录用户的ID
+        Long memberId = LoginUserUtil.getLoginUser().getId();
 
-        //sign= MD5(shopAccount+shopPwd+userId)
-        StringBuffer stringBuffer = new StringBuffer();
-        stringBuffer.append(shopAccount);
-        stringBuffer.append(shopPwd);
-        stringBuffer.append(userld);
-        String sign = MD5.MD5Encode(stringBuffer.toString());
-        objectObjectHashMap.put("sign",sign);
+        ApiMemberNewGiftSettingVo apiMemberNewGiftSettingVo = new ApiMemberNewGiftSettingVo();
 
-        System.out.println(sign);
-
-        System.out.println(objectObjectHashMap);
-        String url = "https://data.muchun.co/api/getCustomerCheckRecords";
-        String result = HttpCurlUtil.sendPost(url, objectObjectHashMap);
-        Integer retCode = JSONUtil.parseObj(result).getInt("retCode");
-        String message = JSONUtil.parseObj(result).getStr("message");
-        if(0 != retCode){
-            System.out.println(message);
+        MallMember mallMember = this.baseMapper.selectById(memberId);
+        Date lastLoginTime = mallMember.getLastLoginTime();
+        if(lastLoginTime == null){
+            apiMemberNewGiftSettingVo.setOpenState(1);
+        }
+        if(lastLoginTime != null){
+            Date now = new Date();
+            long between = DateUtil.between(lastLoginTime, now, DateUnit.DAY);
+            if(between > 0){
+                apiMemberNewGiftSettingVo.setOpenState(1);
+            }else{
+                apiMemberNewGiftSettingVo.setOpenState(0);
+            }
         }
 
-        JSONArray data = JSONUtil.parseObj(result).getJSONArray("data");
-        System.out.println(data);
+        DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(
+                CommonDictionaryEnum.NEW_GIFT_SETTING.getType(),
+                CommonDictionaryEnum.NEW_GIFT_SETTING.getCode()
+        );
+        ApiNewGiftSettingDto apiNewGiftSettingDto = JSONObject.parseObject(dic.getValue(), ApiNewGiftSettingDto.class);
+        apiMemberNewGiftSettingVo.setState(apiNewGiftSettingDto.getState());
+        apiMemberNewGiftSettingVo.setPrizeScore(apiNewGiftSettingDto.getPrizeScore());
+
+
+        LambdaQueryWrapper<MallGoodsCoupon> query = new LambdaQueryWrapper<>();
+        query.eq(MallGoodsCoupon::getId, apiNewGiftSettingDto.getCouponId())
+                .eq(MallGoodsCoupon::getState, 2);
+        List<MallGoodsCoupon> coupons = mallGoodsCouponMapper.selectList(query);
+        if(CollUtil.isNotEmpty(coupons)){
+            apiMemberNewGiftSettingVo.setCouponName(coupons.get(0).getName());
+        }
+
+        this.baseMapper.updateLastLoginTime(memberId,new Date());
+
+        return new FebsResponse().success().data(apiMemberNewGiftSettingVo);
     }
 
+//    public static void main(String[] args) {
+//        Long userld = 16425L;
+//        String shopAccount = "爱和美医疗";
+//        String shopPwd = "blnka2005";
+//
+//        HashMap<String, String> objectObjectHashMap = new HashMap<>();
+//
+//        objectObjectHashMap.put("shopAccount",shopAccount);
+//        objectObjectHashMap.put("shopPwd",shopPwd);
+//        objectObjectHashMap.put("userId",userld.toString());
+//
+//        //sign= MD5(shopAccount+shopPwd+userId)
+//        StringBuffer stringBuffer = new StringBuffer();
+//        stringBuffer.append(shopAccount);
+//        stringBuffer.append(shopPwd);
+//        stringBuffer.append(userld);
+//        String sign = MD5.MD5Encode(stringBuffer.toString());
+//        objectObjectHashMap.put("sign",sign);
+//
+//        System.out.println(sign);
+//
+//        System.out.println(objectObjectHashMap);
+//        String url = "https://data.muchun.co/api/getCustomerCheckRecords";
+//        String result = HttpCurlUtil.sendPost(url, objectObjectHashMap);
+//        Integer retCode = JSONUtil.parseObj(result).getInt("retCode");
+//        String message = JSONUtil.parseObj(result).getStr("message");
+//        if(0 != retCode){
+//            System.out.println(message);
+//        }
+//
+//        JSONArray data = JSONUtil.parseObj(result).getJSONArray("data");
+//        System.out.println(data);
+//    }
+
 
 }

--
Gitblit v1.9.1