From a0bf7c7be9e52bf179db59117fc3660c24604a96 Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Wed, 08 Jan 2025 11:05:45 +0800 Subject: [PATCH] feat(mall): 新增活动管理功能 --- src/main/java/cc/mrbird/febs/mall/service/impl/ActivityServiceImpl.java | 95 +++++++++++++++++++++++++++++++++++------------ 1 files changed, 71 insertions(+), 24 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ActivityServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ActivityServiceImpl.java index 53b8341..57dbb83 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/ActivityServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ActivityServiceImpl.java @@ -1,5 +1,6 @@ package cc.mrbird.febs.mall.service.impl; +import cc.mrbird.febs.common.configure.FebsConfigure; import cc.mrbird.febs.common.entity.FebsResponse; import cc.mrbird.febs.common.entity.QueryRequest; import cc.mrbird.febs.common.enumerates.ActivityTypeEnum; @@ -11,6 +12,7 @@ import cc.mrbird.febs.mall.service.IActivityService; import cc.mrbird.febs.mall.vo.AdminActivityAddDto; import cc.mrbird.febs.mall.vo.AdminDiscountVO; +import cc.mrbird.febs.mall.vo.AdminMallActivityListVo; import cn.hutool.core.collection.CollUtil; import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.StrUtil; @@ -25,7 +27,9 @@ import java.math.BigDecimal; import java.math.RoundingMode; +import java.util.ArrayList; import java.util.List; +import java.util.concurrent.CompletableFuture; import java.util.stream.Collectors; @Slf4j @@ -38,6 +42,7 @@ private final MallGoodsMapper mallGoodsMapper; private final MallGoodsSkuMapper mallGoodsSkuMapper; private final MallGoodsStyleMapper mallGoodsStyleMapper; + private final FebsConfigure febsConfigure; @Override public IPage<MallActivity> getAdminListInPage(MallActivity mallActivity, QueryRequest request) { Page<MallActivity> page = new Page<>(request.getPageNum(), request.getPageSize()); @@ -55,7 +60,7 @@ } @Override - public FebsResponse addActivity(AdminActivityAddDto adminActivityAddDto) { + public FebsResponse addAdminActivity(AdminActivityAddDto adminActivityAddDto) { MallActivity mallActivity = new MallActivity(); mallActivity.setName(adminActivityAddDto.getName()); @@ -90,6 +95,7 @@ } private void addDiscountGoods(Long activityId,BigDecimal discountSize, List<Long> goodsIds){ + MallActivity mallActivity = this.baseMapper.selectById(activityId); //将对应选中的商品按照这个折扣力度重新计算一遍 List<MallGoods> mallGoods = mallGoodsMapper.selectList( new LambdaQueryWrapper<MallGoods>() @@ -97,42 +103,49 @@ .in(MallGoods::getId, goodsIds) ); if(CollUtil.isNotEmpty(mallGoods)){ + List<CompletableFuture<Void>> futures = new ArrayList<>(); //复制对应的商品的规则 for(MallGoods mallGoodsItem:mallGoods){ - Long goodsId = mallGoodsItem.getId(); - //新增活动商品 - Long goodsIdNew = addGoodsEntity(activityId, discountSize, mallGoodsItem); + CompletableFuture<Void> uCompletableFuture = CompletableFuture.runAsync(() -> { + Long goodsId = mallGoodsItem.getId(); + //新增活动商品 + Long goodsIdNew = addGoodsEntity(mallActivity, discountSize, mallGoodsItem); - List<MallGoodsStyle> mallGoodsStyles = mallGoodsStyleMapper.selectList( - new LambdaQueryWrapper<MallGoodsStyle>() - .eq(MallGoodsStyle::getGoodsId, goodsId) - ); + List<MallGoodsStyle> mallGoodsStyles = mallGoodsStyleMapper.selectList( + new LambdaQueryWrapper<MallGoodsStyle>() + .eq(MallGoodsStyle::getGoodsId, goodsId) + ); - if(CollUtil.isNotEmpty(mallGoodsStyles)){ - for(MallGoodsStyle mallGoodsStyleItem:mallGoodsStyles){ - Long styleItemId = mallGoodsStyleItem.getId(); + if(CollUtil.isNotEmpty(mallGoodsStyles)){ + for(MallGoodsStyle mallGoodsStyleItem:mallGoodsStyles){ + Long styleItemId = mallGoodsStyleItem.getId(); - Long styleItemIdNew = addGoodsStyleEntity(goodsIdNew, mallGoodsStyleItem); - List<MallGoodsSku> mallGoodsSkus = mallGoodsSkuMapper.selectList( - new LambdaQueryWrapper<MallGoodsSku>() - .eq(MallGoodsSku::getStyleId, styleItemId) - .eq(MallGoodsSku::getGoodsId, goodsId) - ); - if(CollUtil.isNotEmpty(mallGoodsSkus)){ - for(MallGoodsSku mallGoodsSkuItem:mallGoodsSkus){ - addGoodsSkuEntity(goodsIdNew,styleItemIdNew,discountSize,mallGoodsSkuItem); + Long styleItemIdNew = addGoodsStyleEntity(goodsIdNew, mallGoodsStyleItem); + List<MallGoodsSku> mallGoodsSkus = mallGoodsSkuMapper.selectList( + new LambdaQueryWrapper<MallGoodsSku>() + .eq(MallGoodsSku::getStyleId, styleItemId) + .eq(MallGoodsSku::getGoodsId, goodsId) + ); + if(CollUtil.isNotEmpty(mallGoodsSkus)){ + for(MallGoodsSku mallGoodsSkuItem:mallGoodsSkus){ + addGoodsSkuEntity(goodsIdNew,styleItemIdNew,discountSize,mallGoodsSkuItem); + } } } } - } + },febsConfigure.asyncThreadPoolTaskExecutor()); + futures.add(uCompletableFuture); } + // 等待所有任务完成 + CompletableFuture<Void> allOf = CompletableFuture.allOf(futures.toArray(new CompletableFuture[0])); + allOf.join(); } } - private Long addGoodsEntity(Long activityId,BigDecimal discountSize,MallGoods mallGoodsItem){ - MallActivity mallActivity = this.baseMapper.selectById(activityId); + private Long addGoodsEntity(MallActivity mallActivity,BigDecimal discountSize,MallGoods mallGoodsItem){ mallGoodsItem.setIsNormal(GoodsTypeEnum.HUO_DONG.getValue()); - mallGoodsItem.setGoodsName(mallActivity.getName()+mallGoodsItem.getGoodsName()); + mallGoodsItem.setGoodsName(mallActivity.getName()+"-"+(StrUtil.isEmpty(mallGoodsItem.getGoodsName()) ? "":mallGoodsItem.getGoodsName())); + mallGoodsItem.setGoodsNo(mallGoodsItem.getGoodsNo()+"-"+mallActivity.getCode()); mallGoodsItem.setActivityId(mallActivity.getId()); BigDecimal presentPrice = new BigDecimal(mallGoodsItem.getPresentPrice()).multiply(discountSize).setScale(2, RoundingMode.DOWN); mallGoodsItem.setPresentPrice(presentPrice.toString()); @@ -179,4 +192,38 @@ public FebsResponse discountUpdate(AdminDiscountVO adminDiscountVO) { return null; } + + @Override + public List<AdminMallActivityListVo> getAdminActivityList() { + List<AdminMallActivityListVo> mallActivityList = new ArrayList<>(); + + List<MallActivity> mallActivities = this.baseMapper.selectList( + new LambdaQueryWrapper<MallActivity>() + .select(MallActivity::getId, MallActivity::getName) + .eq(MallActivity::getState, YesOrNoOrIngEnum.YES.getValue()) + ); + if(CollUtil.isNotEmpty(mallActivities)){ + for (MallActivity mallActivity : mallActivities) { + AdminMallActivityListVo adminMallActivityListVo = new AdminMallActivityListVo(); + adminMallActivityListVo.setId(mallActivity.getId()); + adminMallActivityListVo.setName(mallActivity.getName()); + mallActivityList.add(adminMallActivityListVo); + } + } + return mallActivityList; + } + + @Override + public FebsResponse changeAdminState(Long id, Integer state) { + MallActivity mallActivity = this.baseMapper.selectById(id); + mallActivity.setState(state); + this.baseMapper.updateById(mallActivity); + return new FebsResponse().success().message("操作成功"); + } + + @Override + public FebsResponse delAdminActivity(Long id) { + this.baseMapper.deleteById(id); + return new FebsResponse().success().message("操作成功"); + } } -- Gitblit v1.9.1