From 2377b0ca8cd1839c80c6271a7067ea43a0b78aa7 Mon Sep 17 00:00:00 2001 From: Administrator <15274802129@163.com> Date: Tue, 27 May 2025 15:49:54 +0800 Subject: [PATCH] fix(order): 修复订单列表中提货方式的显示逻辑 --- src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java | 266 +++++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 205 insertions(+), 61 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 2dd08c5..b5027d5 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 @@ -14,6 +14,8 @@ import cc.mrbird.febs.mall.mapper.*; import cc.mrbird.febs.mall.service.*; import cc.mrbird.febs.mall.vo.*; +import cc.mrbird.febs.mall.vo.memberLevel.ApiLabelInfoVo; +import cc.mrbird.febs.mall.vo.memberLevel.ApiMemberLabelVo; import cc.mrbird.febs.pay.model.BrandWCPayRequestData; import cc.mrbird.febs.pay.service.IXcxPayService; import cc.mrbird.febs.pay.util.MD5; @@ -89,6 +91,9 @@ private final MallStoreMemberMapper mallStoreMemberMapper; private final MallDoctorMapper mallDoctorMapper; private final HappyMemberLevelMapper happyMemberLevelMapper; + private final IApiMallMemberWalletService mallMemberWalletService; + private final HappyMemberLabelRecordMapper happyMemberLabelRecordMapper; + private final HappyMemberLabelMapper happyMemberLabelMapper; @Value("${spring.profiles.active}") @@ -270,17 +275,23 @@ HappyMemberLevel happyMemberLevel = happyMemberLevelMapper.selectOne( new LambdaQueryWrapper<HappyMemberLevel>() - .select(HappyMemberLevel::getName) + .select(HappyMemberLevel::getName, HappyMemberLevel::getIconPng) .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())) { @@ -316,6 +327,31 @@ mallMemberVo.setScore(wallet.getScore()); mallMemberVo.setPrizeScore(wallet.getPrizeScore()); // mallMemberVo.setTotalCost(mallOrderInfoMapper.selectTotalAmount(id)); + + List<HappyMemberLabelRecord> happyMemberLabelRecords = happyMemberLabelRecordMapper.selectList( + new LambdaQueryWrapper<HappyMemberLabelRecord>() + .eq(HappyMemberLabelRecord::getMemberId, id) + .orderByDesc(HappyMemberLabelRecord::getId) + .last("limit 5") + ); + if(CollUtil.isNotEmpty(happyMemberLabelRecords)){ + Set<Long> collect = happyMemberLabelRecords.stream().map(HappyMemberLabelRecord::getLabelId).collect(Collectors.toSet()); + List<HappyMemberLabel> happyMemberLabels = happyMemberLabelMapper.selectList( + new LambdaQueryWrapper<HappyMemberLabel>() + .select(HappyMemberLabel::getIconPng, HappyMemberLabel::getName) + .in(HappyMemberLabel::getId, collect) + ); + if(CollUtil.isNotEmpty(happyMemberLabels)){ + ArrayList<ApiLabelInfoVo> apiMemberLabelVos = new ArrayList<>(); + for (HappyMemberLabel happyMemberLabel : happyMemberLabels) { + ApiLabelInfoVo apiLabelInfoVo = new ApiLabelInfoVo(); + apiLabelInfoVo.setIconPng(happyMemberLabel.getIconPng()); + apiLabelInfoVo.setName(happyMemberLabel.getName()); + apiMemberLabelVos.add(apiLabelInfoVo); + } + mallMemberVo.setLabelList(apiMemberLabelVos); + } + } return new FebsResponse().success().data(mallMemberVo); } @@ -694,6 +730,33 @@ wallet.setBalance(BigDecimal.ZERO); wallet.setMemberId(mallMember.getId()); mallMemberWalletMapper.insert(wallet); + + //分销员的邀请码赠送优惠卷 + if (StrUtil.isNotBlank(apiXcxLoginDto.getInviteId())) { + 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())) { throw new FebsException("账号已停用"); @@ -762,46 +825,49 @@ mallMember.setSex(1 == apiXcxSaveInfoDto.getGender() ? "女" : "男"); this.baseMapper.updateById(mallMember); - //完善信息赠送新人礼 - if (StrUtil.isBlank(mallMember.getLevel())) { - 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); - } - } - - } - } +// //完善信息赠送新人礼 +// if (StrUtil.isNotBlank(mallMember.getPhone()) && mallMember.getNewGift() == 0) { +// DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( +// CommonDictionaryEnum.NEW_GIFT_SETTING.getType(), +// CommonDictionaryEnum.NEW_GIFT_SETTING.getCode() +// ); +// mallMember.setNewGift(1); +// this.baseMapper.updateById(mallMember); +// +// 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(); } @@ -919,10 +985,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(); @@ -1575,18 +1643,12 @@ ApiMemberNewGiftSettingVo apiMemberNewGiftSettingVo = new ApiMemberNewGiftSettingVo(); MallMember mallMember = this.baseMapper.selectById(memberId); - Date lastLoginTime = mallMember.getLastLoginTime(); - if(lastLoginTime == null){ + + Integer newGift = mallMember.getNewGift(); + if(newGift == 0){ 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); - } + }else{ + apiMemberNewGiftSettingVo.setOpenState(0); } DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( @@ -1595,20 +1657,102 @@ ); ApiNewGiftSettingDto apiNewGiftSettingDto = JSONObject.parseObject(dic.getValue(), ApiNewGiftSettingDto.class); apiMemberNewGiftSettingVo.setState(apiNewGiftSettingDto.getState()); - apiMemberNewGiftSettingVo.setPrizeScore(apiNewGiftSettingDto.getPrizeScore()); + if(apiMemberNewGiftSettingVo.getState() == 1 && apiMemberNewGiftSettingVo.getOpenState() == 1){ + mallMember.setNewGift(1); - 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()); + BigDecimal prizeScore = new BigDecimal(StrUtil.isBlank(apiNewGiftSettingDto.getPrizeScore()) ? "0" : apiNewGiftSettingDto.getPrizeScore()) + .setScale(0, RoundingMode.HALF_DOWN); + + if(prizeScore.compareTo(BigDecimal.ZERO) > 0){ + mallMoneyFlowService.addMoneyFlow( + memberId, + prizeScore, + ScoreFlowTypeEnum.NEW_GIFT_PRIZE_SCORE.getValue(), + MallUtils.getOrderNum(), + FlowTypeEnum.PRIZE_SCORE.getValue(), + StrUtil.format( ScoreFlowTypeEnum.NEW_GIFT_PRIZE_SCORE.getDesc(),prizeScore), + 2); + mallMemberWalletService.add(prizeScore,memberId , "prizeScore"); + + apiMemberNewGiftSettingVo.setPrizeScore(prizeScore); + } + + String couponUUID = IdUtil.simpleUUID(); + if(ObjectUtil.isNotEmpty(apiNewGiftSettingDto.getCouponId())){ + Long couponId = apiNewGiftSettingDto.getCouponId(); + MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(couponId); + if(ObjectUtil.isNotEmpty(mallGoodsCoupon) && mallGoodsCoupon.getState() == 2){ + List<MallMemberCoupon> mallMemberCoupons = mallMemberCouponMapper.selectListByMemberIdCouponIdWithOutInviteId(memberId, couponId); + if(CollUtil.isEmpty(mallMemberCoupons)){ + //商品优惠卷如果绑定了,那么当前登陆者获取一张卷 + MallMemberCoupon mallMemberCoupon = new MallMemberCoupon(); + mallMemberCoupon.setCouponId(couponId); + mallMemberCoupon.setCouponName(mallGoodsCoupon.getName()); + mallMemberCoupon.setMemberId(memberId); + mallMemberCoupon.setCouponUuid(couponUUID); + mallMemberCoupon.setInviteId(mallMember.getInviteId()); + mallMemberCoupon.setState(1); + mallMemberCoupon.setExpireTime(DateUtil.offsetDay(DateUtil.date(),mallGoodsCoupon.getExpireDay())); + mallMemberCouponMapper.insert(mallMemberCoupon); + + mallMoneyFlowService.addMoneyFlow( + memberId, + BigDecimal.ONE, + ScoreFlowTypeEnum.NEW_GIFT_COUPON.getValue(), + MallUtils.getOrderNum(), + FlowTypeEnum.BALANCE.getValue(), + StrUtil.format( ScoreFlowTypeEnum.NEW_GIFT_COUPON.getDesc(),mallGoodsCoupon.getName()), + 2); + + apiMemberNewGiftSettingVo.setCouponName(mallGoodsCoupon.getName()); + } + } + } } + mallMember.setLastLoginTime(new Date()); + this.baseMapper.updateById(mallMember); + +// this.baseMapper.updateLastLoginTime(memberId,new Date()); + return new FebsResponse().success().data(apiMemberNewGiftSettingVo); } + @Override + public FebsResponse getLabelList() { + + // 获取当前登录用户的ID + Long memberId = LoginUserUtil.getLoginUser().getId(); + + ArrayList<ApiMemberLabelVo> apiMemberLabelVos = new ArrayList<>(); + + List<HappyMemberLabelRecord> happyMemberLabelRecords = happyMemberLabelRecordMapper.selectList( + new LambdaQueryWrapper<HappyMemberLabelRecord>() + .eq(HappyMemberLabelRecord::getMemberId,memberId) + ); + if(CollUtil.isNotEmpty(happyMemberLabelRecords)){ + Set<Long> collect = happyMemberLabelRecords.stream().map(HappyMemberLabelRecord::getLabelId).collect(Collectors.toSet()); + List<HappyMemberLabel> happyMemberLabels = happyMemberLabelMapper.selectList( + new LambdaQueryWrapper<HappyMemberLabel>() + .select(HappyMemberLabel::getIconPng, HappyMemberLabel::getName, HappyMemberLabel::getContent, HappyMemberLabel::getHeaderPng) + .in(HappyMemberLabel::getId, collect) + ); + if(CollUtil.isNotEmpty(happyMemberLabels)){ + for (HappyMemberLabel happyMemberLabel : happyMemberLabels) { + ApiMemberLabelVo apiMemberLabelVo = new ApiMemberLabelVo(); + apiMemberLabelVo.setName(happyMemberLabel.getName()); + apiMemberLabelVo.setContent(happyMemberLabel.getContent()); + apiMemberLabelVo.setHeaderPng(happyMemberLabel.getHeaderPng()); + apiMemberLabelVo.setIconPng(happyMemberLabel.getIconPng()); + apiMemberLabelVos.add(apiMemberLabelVo); + } + } + } + + return new FebsResponse().success().data(apiMemberLabelVos); + } + // public static void main(String[] args) { // Long userld = 16425L; // String shopAccount = "爱和美医疗"; -- Gitblit v1.9.1