From 8c3e76d3712fb0497cb3088fe4f4f5c645dee970 Mon Sep 17 00:00:00 2001 From: Administrator <15274802129@163.com> Date: Thu, 15 May 2025 11:14:58 +0800 Subject: [PATCH] feat(mall): 新增新人礼功能 --- src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java | 72 ++++++++++++++++++++++++++++++++++-- 1 files changed, 68 insertions(+), 4 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 6b83062..879af4e 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; @@ -761,6 +760,47 @@ 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); + } + } + + } + } return new FebsResponse().success(); } @@ -1526,6 +1566,30 @@ return new FebsResponse().success().data(apiMoneyFlowHeaderVo); } + @Override + public FebsResponse newGiftEvent() { + DataDictionaryCustom dic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( + CommonDictionaryEnum.NEW_GIFT_SETTING.getType(), + CommonDictionaryEnum.NEW_GIFT_SETTING.getCode() + ); + ApiNewGiftSettingDto apiNewGiftSettingDto = JSONObject.parseObject(dic.getValue(), ApiNewGiftSettingDto.class); + + ApiMemberNewGiftSettingVo apiMemberNewGiftSettingVo = new ApiMemberNewGiftSettingVo(); + 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()); + } + + return new FebsResponse().success().data(apiMemberNewGiftSettingVo); + } + // public static void main(String[] args) { // Long userld = 16425L; // String shopAccount = "爱和美医疗"; -- Gitblit v1.9.1