From 6d959c0e2c777f3cb1f4f9d692eb8997eb736ba5 Mon Sep 17 00:00:00 2001 From: Hentua <wangdoubleone@gmail.com> Date: Thu, 25 Jan 2024 00:14:54 +0800 Subject: [PATCH] fix --- src/main/java/cc/mrbird/febs/vip/controller/ApiMallVipConfigController.java | 1 src/main/java/cc/mrbird/febs/vip/service/IMallVipBenefitsService.java | 2 src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java | 121 +++++++++++++++++++++++++++++++++++++++- 3 files changed, 121 insertions(+), 3 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/vip/controller/ApiMallVipConfigController.java b/src/main/java/cc/mrbird/febs/vip/controller/ApiMallVipConfigController.java index b8af531..60a38ac 100644 --- a/src/main/java/cc/mrbird/febs/vip/controller/ApiMallVipConfigController.java +++ b/src/main/java/cc/mrbird/febs/vip/controller/ApiMallVipConfigController.java @@ -51,6 +51,7 @@ @ApiOperation(value = "领取权益") @PostMapping(value = "/getBenefitsData/{id}") public FebsResponse getBenefitsData(@PathVariable("id") Long id) { + mallVipBenefitsService.getBenefits(id); return new FebsResponse().success().message("领取成功"); } } diff --git a/src/main/java/cc/mrbird/febs/vip/service/IMallVipBenefitsService.java b/src/main/java/cc/mrbird/febs/vip/service/IMallVipBenefitsService.java index 5187343..df60c35 100644 --- a/src/main/java/cc/mrbird/febs/vip/service/IMallVipBenefitsService.java +++ b/src/main/java/cc/mrbird/febs/vip/service/IMallVipBenefitsService.java @@ -16,4 +16,6 @@ void delVipBenefits(Long id); void editVipBenefits(MallVipBenefits mallVipBenefits); + + void getBenefits(Long id); } diff --git a/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java b/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java index 07d20cb..636c8c4 100644 --- a/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/vip/service/impl/MallVipBenefitsServiceImpl.java @@ -1,8 +1,13 @@ package cc.mrbird.febs.vip.service.impl; import cc.mrbird.febs.common.entity.QueryRequest; +import cc.mrbird.febs.common.enumerates.OrderStatusEnum; import cc.mrbird.febs.common.exception.FebsException; -import cc.mrbird.febs.mall.entity.MallNewsInfo; +import cc.mrbird.febs.common.utils.LoginUserUtil; +import cc.mrbird.febs.common.utils.MallUtils; +import cc.mrbird.febs.mall.entity.*; +import cc.mrbird.febs.mall.mapper.*; +import cc.mrbird.febs.mall.vo.AdminMailGoodsDetailVo; import cc.mrbird.febs.mall.vo.AdminMallNewsInfoVo; import cc.mrbird.febs.vip.entity.MallVipBenefits; import cc.mrbird.febs.vip.entity.MallVipBenefitsDetails; @@ -11,8 +16,12 @@ import cc.mrbird.febs.vip.service.IMallVipBenefitsDetailsService; import cc.mrbird.febs.vip.service.IMallVipBenefitsService; import cn.hutool.core.collection.CollUtil; +import cn.hutool.core.date.DateUtil; +import cn.hutool.core.util.IdUtil; +import cn.hutool.core.util.ObjectUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.core.metadata.OrderItem; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import lombok.RequiredArgsConstructor; @@ -20,12 +29,21 @@ import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; +import java.math.BigDecimal; +import java.util.Date; + @Slf4j @Service @RequiredArgsConstructor public class MallVipBenefitsServiceImpl extends ServiceImpl<MallVipBenefitsMapper, MallVipBenefits> implements IMallVipBenefitsService { private final IMallVipBenefitsDetailsService mallVipBenefitsDetailsService; + private final MallMemberCouponMapper mallMemberCouponMapper; + private final MallGoodsCouponMapper mallGoodsCouponMapper; + private final MallGoodsMapper mallGoodsMapper; + private final MallAddressInfoMapper mallAddressInfoMapper; + private final MallOrderInfoMapper mallOrderInfoMapper; + private final MallOrderItemMapper mallOrderItemMapper; @Override public IPage<MallVipBenefits> vipBenefitsListInPage(QueryRequest request) { @@ -58,7 +76,7 @@ } @Override - @Transactional + @Transactional(rollbackFor = Exception.class) public void delVipBenefits(Long id) { this.baseMapper.deleteById(id); @@ -68,7 +86,7 @@ } @Override - @Transactional + @Transactional(rollbackFor = Exception.class) public void editVipBenefits(MallVipBenefits mallVipBenefits) { if (mallVipBenefits.getId() == null) { throw new FebsException("缺少重要参数"); @@ -88,4 +106,101 @@ } + @Override + public void getBenefits(Long id) { + MallMember member = LoginUserUtil.getLoginUser(); + + MallVipBenefitsDetails benefits = mallVipBenefitsDetailsService.getById(id); + if (benefits == null) { + throw new FebsException("权益不存在"); + } + + Integer linkType = benefits.getLinkType(); + + // 商品 + if (linkType == 2) { + MallGoods goods = mallGoodsMapper.selectGoodsDetailById(Long.parseLong(benefits.getContent())); + if (goods == null) { + throw new FebsException("商品不存在"); + } + + LambdaQueryWrapper<MallAddressInfo> query = new LambdaQueryWrapper<>(); + query.eq(MallAddressInfo::getMemberId, member.getId()) + .eq(MallAddressInfo::getIsDefault, 1) + .last("limit 1"); + MallAddressInfo address = mallAddressInfoMapper.selectOne(query); + if (address == null) { + throw new FebsException("请设置默认地址"); + } + + String orderNo = MallUtils.getOrderNum(); + MallOrderInfo orderInfo = new MallOrderInfo(); + orderInfo.setOrderNo(orderNo); + orderInfo.setOrderTime(new Date()); + orderInfo.setMemberId(member.getId()); + orderInfo.setStatus(OrderStatusEnum.WAIT_SHIPPING.getValue()); + orderInfo.setOrderType(goods.getGoodsType()); + orderInfo.setDeliveryType(2); + orderInfo.setCarriage(BigDecimal.ZERO); + orderInfo.setAmount(BigDecimal.ZERO); + orderInfo.setAddressId(address.getId()); + orderInfo.setName(address.getName()); + orderInfo.setPhone(address.getPhone()); + orderInfo.setIsHome(2); + orderInfo.setAddress(address.getProvince()+address.getCity()+address.getArea() + address.getAddress()); + orderInfo.setLatitude(address.getLatitude()); + orderInfo.setLongitude(address.getLongitude()); + + MallOrderItem orderItem = new MallOrderItem(); + if (goods.getGoodsType() == 2) { + orderItem.setAmount(BigDecimal.ZERO); + orderItem.setCnt(1); + orderItem.setOrderId(orderInfo.getId()); + orderItem.setPrice(goods.getScore()); + orderItem.setGoodsId(goods.getId()); + orderItem.setGoodsName(goods.getGoodsName()); + orderItem.setStyleName(goods.getGoodsName()); + orderItem.setSkuName(goods.getGoodsName()); + orderItem.setSkuImage(goods.getThumb()); + orderItem.setState(1); + } else { + MallGoodsSku sku = goods.getStyles().get(0).getSkus().get(0); + + orderItem.setAmount(BigDecimal.ZERO); + orderItem.setCnt(1); + orderItem.setOrderId(orderInfo.getId()); + orderItem.setPrice(sku.getPresentPrice()); + orderItem.setGoodsId(sku.getGoodsId()); + orderItem.setGoodsName(sku.getGoodsName()); + orderItem.setSkuId(sku.getId()); + orderItem.setState(1); + orderItem.setStyleName(sku.getStyleName()); + orderItem.setSkuName(sku.getSkuName()); + orderItem.setSkuImage(sku.getSkuImage()); + orderItem.setIsNormal(goods.getIsNormal()); + orderItem.setCostPrice(sku.getCostPrice()); + } + + mallOrderInfoMapper.insert(orderInfo); + mallOrderItemMapper.insert(orderItem); + } + + // 优惠券 + if (linkType == 3) { + MallGoodsCoupon coupon = mallGoodsCouponMapper.selectById(Long.parseLong(benefits.getContent())); + if (coupon == null) { + throw new FebsException("优惠券"); + } + MallMemberCoupon memberCoupon = new MallMemberCoupon(); + memberCoupon.setCouponId(coupon.getId()); + memberCoupon.setCouponName(coupon.getName()); + memberCoupon.setInviteId(member.getInviteId()); + memberCoupon.setCouponUuid(IdUtil.simpleUUID()); + memberCoupon.setState(1); + memberCoupon.setExpireTime(DateUtil.offsetDay(DateUtil.date(), coupon.getExpireDay())); + memberCoupon.setMemberId(member.getId()); + mallMemberCouponMapper.insert(memberCoupon); + } + } + } -- Gitblit v1.9.1