From 5fea0979a485fde02e3a76d6d3786f4182c9c9e2 Mon Sep 17 00:00:00 2001 From: Administrator <15274802129@163.com> Date: Wed, 21 May 2025 14:47:48 +0800 Subject: [PATCH] fix(mall): 修正团队累计消费金额的计算逻辑 --- src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java | 33 +++++++++++++++++++++++++++------ 1 files changed, 27 insertions(+), 6 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 d17b877..ff49561 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 @@ -271,7 +271,7 @@ HappyMemberLevel happyMemberLevel = happyMemberLevelMapper.selectOne( new LambdaQueryWrapper<HappyMemberLevel>() - .select(HappyMemberLevel::getName) + .select(HappyMemberLevel::getName, HappyMemberLevel::getIconPng) .eq(HappyMemberLevel::getCode, mallMember.getDirector()) ); if(happyMemberLevel != null){ @@ -704,9 +704,29 @@ //分销员的邀请码赠送优惠卷 if (StrUtil.isNotBlank(apiXcxLoginDto.getInviteId())) { - GetCouponDto getCouponDto = new GetCouponDto(); - getCouponDto.setInviteId(apiXcxLoginDto.getInviteId()); - scanCoupon(getCouponDto); + String couponUUID = IdUtil.simpleUUID(); + //通过邀请人信息,获取能领取的优惠卷信息 + MallMember refMember = this.baseMapper.selectInfoByInviteId(apiXcxLoginDto.getInviteId()); + if(ObjectUtil.isNotEmpty(refMember)){ + SalemanCoupon salemanCoupon = salemanCouponMapper.selectByMemberId(refMember.getId()); + if(ObjectUtil.isNotEmpty(salemanCoupon)){ + Long couponId = salemanCoupon.getCouponId(); + List<MallMemberCoupon> mallMemberCoupons = mallMemberCouponMapper.selectListByMemberIdCouponIdWithOutInviteId(mallMember.getId(), couponId); + if(CollUtil.isEmpty(mallMemberCoupons)){ + //商品优惠卷如果绑定了,那么当前登陆者获取一张卷 + MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(couponId); + MallMemberCoupon mallMemberCoupon = new MallMemberCoupon(); + mallMemberCoupon.setCouponId(couponId); + mallMemberCoupon.setCouponName(mallGoodsCoupon.getName()); + mallMemberCoupon.setMemberId(mallMember.getId()); + mallMemberCoupon.setCouponUuid(couponUUID); + mallMemberCoupon.setInviteId(refMember.getInviteId()); + mallMemberCoupon.setState(1); + mallMemberCoupon.setExpireTime(DateUtil.offsetDay(DateUtil.date(),mallGoodsCoupon.getExpireDay())); + mallMemberCouponMapper.insert(mallMemberCoupon); + } + } + } } } else { if (MallMember.ACCOUNT_STATUS_DISABLED.equals(mallMember.getAccountStatus())) { @@ -1611,8 +1631,6 @@ if(apiMemberNewGiftSettingVo.getState() == 1 && apiMemberNewGiftSettingVo.getOpenState() == 1){ mallMember.setNewGift(1); - mallMember.setLastLoginTime(new Date()); - this.baseMapper.updateById(mallMember); BigDecimal prizeScore = new BigDecimal(StrUtil.isBlank(apiNewGiftSettingDto.getPrizeScore()) ? "0" : apiNewGiftSettingDto.getPrizeScore()) .setScale(0, RoundingMode.HALF_DOWN); @@ -1664,6 +1682,9 @@ } } + mallMember.setLastLoginTime(new Date()); + this.baseMapper.updateById(mallMember); + // this.baseMapper.updateLastLoginTime(memberId,new Date()); return new FebsResponse().success().data(apiMemberNewGiftSettingVo); -- Gitblit v1.9.1