From 43c263df4d8ce0cc830f287780c29db8a2b47f0f Mon Sep 17 00:00:00 2001 From: rentaiming <806181062@qq.com> Date: 星期一, 27 五月 2024 08:44:34 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsGroupPurchaseServiceImpl.java | 77 ++++++++++++++++++++++++++++++++++++-- 1 files changed, 72 insertions(+), 5 deletions(-) diff --git a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsGroupPurchaseServiceImpl.java b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsGroupPurchaseServiceImpl.java index 237b1b1..dbb37c1 100644 --- a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsGroupPurchaseServiceImpl.java +++ b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsGroupPurchaseServiceImpl.java @@ -2,20 +2,28 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.ruoyi.common.core.enums.GroupStatusEnum; import com.ruoyi.common.core.enums.ListingStatusEnum; +import com.ruoyi.common.core.enums.PaymentMethodEnum; import com.ruoyi.common.core.enums.StartStatusEnum; import com.ruoyi.common.core.exception.ServiceException; import com.ruoyi.common.core.utils.StringUtils; import com.ruoyi.common.core.utils.page.BeanUtils; import com.ruoyi.common.core.utils.page.PageDTO; -import com.ruoyi.goods.controller.management.DTO.GoodsGroupPurchaseDTO; -import com.ruoyi.goods.controller.management.DTO.GoodsGroupPurchaseQuery; -import com.ruoyi.goods.controller.management.VO.GoodsGroupPurchaseVO; +import com.ruoyi.goods.controller.management.dto.GoodsGroupPurchaseDTO; +import com.ruoyi.goods.controller.management.dto.GoodsGroupPurchaseQuery; +import com.ruoyi.goods.controller.management.vo.GoodsGroupPurchaseVO; import com.ruoyi.goods.domain.GoodsGroupPurchase; import com.ruoyi.goods.mapper.GoodsGroupPurchaseMapper; import com.ruoyi.goods.service.IGoodsGroupPurchaseService; +import com.ruoyi.goods.service.IGoodsSkuService; +import com.ruoyi.goods.service.async.AsyncMethodService; +import com.ruoyi.system.api.WebSocketUsers; +import com.ruoyi.system.api.domain.GoodsSku; +import com.ruoyi.system.api.domain.Order; import com.ruoyi.system.api.domain.dto.ListStatusDTO; import com.ruoyi.system.api.feignClient.OrderClient; +import java.util.List; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; @@ -34,7 +42,8 @@ public class GoodsGroupPurchaseServiceImpl extends ServiceImpl<GoodsGroupPurchaseMapper, GoodsGroupPurchase> implements IGoodsGroupPurchaseService { private final OrderClient orderClient; - + private final IGoodsSkuService goodsSkuService; + private final AsyncMethodService asyncMethodService; /** * 获取团购商品列表的分页数据 * @@ -57,15 +66,39 @@ public void saveGoodsGroupPurchase(GoodsGroupPurchaseDTO dto) { GoodsGroupPurchase goodsGroupPurchase = BeanUtils.copyBean(dto, GoodsGroupPurchase.class); if (StringUtils.isNull(dto.getId())) { + if (StringUtils.isNull(dto.getGoodsSkuId())) { + throw new ServiceException("商品id不能为空"); + } this.save(goodsGroupPurchase); + GoodsSku goodsSku = goodsSkuService.getById(dto.getGoodsSkuId()); + if (StringUtils.isNull(goodsSku)) { + throw new ServiceException("商品不存在"); + } + int groupPurchaseStock = dto.getLimitNumber() * dto.getGroupSize(); + goodsSkuService.lambdaUpdate() + .set(GoodsSku::getStock, goodsSku.getStock() - groupPurchaseStock) + .ge(GoodsSku::getStock, groupPurchaseStock) + .eq(GoodsSku::getId, goodsSku.getId()); } else { GoodsGroupPurchase groupPurchase = this.getById(dto.getId()); if (StringUtils.isNull(groupPurchase)) { throw new ServiceException("团购商品不存在"); } + int originGroupStock = groupPurchase.getLimitNumber() * groupPurchase.getGroupSize(); + GoodsSku goodsSku = goodsSkuService.getById(dto.getGoodsSkuId()); + if (StringUtils.isNull(goodsSku)) { + throw new ServiceException("商品不存在"); + } + int groupPurchaseStock = dto.getLimitNumber() * dto.getGroupSize(); + int latestStock = originGroupStock - groupPurchaseStock; + goodsSkuService.lambdaUpdate() + .set(GoodsSku::getStock, + goodsSku.getStock() + latestStock) + .ge(GoodsSku::getStock, latestStock) + .eq(GoodsSku::getId, goodsSku.getId()); this.updateById(goodsGroupPurchase); + asyncMethodService.groupPurchaseScheduleTask(goodsGroupPurchase); } - //TODO 添加调度任务 处理团购商品开始结束 } /** @@ -122,6 +155,8 @@ this.lambdaUpdate().set(GoodsGroupPurchase::getStartStatus, StartStatusEnum.STARTED) .eq(GoodsGroupPurchase::getId, groupPurchaseId).update(); //TODO 通知小程序 + WebSocketUsers.sendMessageToUsersByText( + "团购商品" + groupPurchase.getGoodsSkuName() + "开始团购"); } } @@ -138,6 +173,38 @@ this.lambdaUpdate().set(GoodsGroupPurchase::getStartStatus, StartStatusEnum.ENDED) .eq(GoodsGroupPurchase::getId, groupPurchaseId).update(); //TODO 通知小程序 + WebSocketUsers.sendMessageToUsersByText( + "团购商品" + groupPurchase.getGoodsSkuName() + "结束团购"); + } + } + + /** + * 立即结束 + * + * @param id 团购商品id + */ + @Override + public void stopImmediately(Long id) { + GoodsGroupPurchase groupPurchase = this.getById(id); + if (StringUtils.isNull(groupPurchase)) { + throw new ServiceException("团购商品不存在"); + } + //判断商品状态,未成团则查询关联订单,进行退款;成团就直接修改状态 + if (groupPurchase.getGroupStatus().equals(GroupStatusEnum.TO_FORM_A_GROUP)) { + //查询关联订单 + List<Order> orderList = orderClient.getOrderByGroupPurchaseId(id).getData(); + for (Order order : orderList) { + if (PaymentMethodEnum.ALIPAY.equals(order.getPaymentMethod())) { + //TODO 退款 + } + if (PaymentMethodEnum.WECHAT.equals(order.getPaymentMethod())) { + //TODO 退款 + } + } + } else { + this.lambdaUpdate() + .set(GoodsGroupPurchase::getStartStatus, StartStatusEnum.ENDED) + .eq(GoodsGroupPurchase::getId, id).update(); } } } -- Gitblit v1.7.1