From 1d4473f81abe4ef200f23b781756a7da689dc718 Mon Sep 17 00:00:00 2001 From: Pu Zhibing <393733352@qq.com> Date: 星期二, 17 十二月 2024 16:49:13 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/GoodsServiceImpl.java | 41 +++++++++++++++++++++++++++++------------ 1 files changed, 29 insertions(+), 12 deletions(-) diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/GoodsServiceImpl.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/GoodsServiceImpl.java index 0a91761..3ad615f 100644 --- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/GoodsServiceImpl.java +++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/GoodsServiceImpl.java @@ -21,6 +21,7 @@ import com.ruoyi.other.service.*; import com.ruoyi.other.vo.GoodsVO; import com.ruoyi.system.api.model.LoginUser; +import org.jetbrains.annotations.NotNull; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; @@ -29,6 +30,7 @@ import java.math.BigDecimal; import java.util.*; import java.util.stream.Collectors; +import java.util.stream.Stream; /** * <p> @@ -287,6 +289,11 @@ // 会员价格 List<GoodsVip> goodsVipList = goodsVipService.list(new LambdaQueryWrapper<GoodsVip>() .eq(GoodsVip::getGoodsId, goodsId)); + List<VipSetting> vipSettings = getVipSettings(goodsVipList.stream().map(GoodsVip::getVip)); + goodsVipList.forEach(goodsArea -> vipSettings.stream() + .filter(vipSetting -> vipSetting.getId().equals(goodsArea.getVip())) + .findFirst().ifPresent( vipSetting -> goodsArea.setVipName(vipSetting.getVipName()))); + goods.setGoodsVipList(goodsVipList); // 特殊地区售价设置 @@ -300,25 +307,35 @@ List<GoodsArea> goodsAreaList1 = new ArrayList<>(); listMap.forEach((s, goodsAreas) -> { - List<Integer> vipIds = goodsAreas.stream().map(GoodsArea::getVip).collect(Collectors.toList()); - List<VipSetting> vipSettings = vipSettingService.listByIds(vipIds); - goodsAreas.forEach(goodsArea -> vipSettings.stream() + List<VipSetting> vipSettings1 = getVipSettings(goodsAreas.stream().map(GoodsArea::getVip)); + goodsAreas.forEach(goodsArea -> vipSettings1.stream() .filter(vipSetting -> vipSetting.getId().equals(goodsArea.getVip())) .findFirst().ifPresent( vipSetting -> goodsArea.setVipName(vipSetting.getVipName()))); - GoodsArea goodsArea = goodsAreas.get(0); - GoodsArea goodsArea1 = new GoodsArea(); - goodsArea1.setProvinceCode(goodsArea.getProvinceCode()); - goodsArea1.setCityCode(goodsArea.getCityCode()); - goodsArea1.setDistrictsCode(goodsArea.getDistrictsCode()); - goodsArea1.setProvince(goodsArea.getProvince()); - goodsArea1.setCity(goodsArea.getCity()); - goodsArea1.setDistricts(goodsArea.getDistricts()); - goodsArea1.setGoodsAreaList(goodsAreas); + GoodsArea goodsArea1 = getGoodsArea(goodsAreas); goodsAreaList1.add(goodsArea1); }); goods.setGoodsAreaList(goodsAreaList1); return goods; } + + private List<VipSetting> getVipSettings(Stream<Integer> goodsVipList) { + List<Integer> vipIds = goodsVipList.collect(Collectors.toList()); + return vipSettingService.listByIds(vipIds); + } + + @NotNull + private static GoodsArea getGoodsArea(List<GoodsArea> goodsAreas) { + GoodsArea goodsArea = goodsAreas.get(0); + GoodsArea goodsArea1 = new GoodsArea(); + goodsArea1.setProvinceCode(goodsArea.getProvinceCode()); + goodsArea1.setCityCode(goodsArea.getCityCode()); + goodsArea1.setDistrictsCode(goodsArea.getDistrictsCode()); + goodsArea1.setProvince(goodsArea.getProvince()); + goodsArea1.setCity(goodsArea.getCity()); + goodsArea1.setDistricts(goodsArea.getDistricts()); + goodsArea1.setGoodsAreaList(goodsAreas); + return goodsArea1; + } } -- Gitblit v1.7.1