From e93aad02d2dd2a6e624e81ea0adb3611a8fc43e5 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期四, 26 十二月 2024 17:16:19 +0800
Subject: [PATCH] 合并代码

---
 ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/VipCenterController.java |   43 ++++++++++++++++++-------------------------
 1 files changed, 18 insertions(+), 25 deletions(-)

diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/VipCenterController.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/VipCenterController.java
index 056a580..9bcf7c1 100644
--- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/VipCenterController.java
+++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/VipCenterController.java
@@ -1,18 +1,17 @@
 package com.ruoyi.account.controller;
 
+import com.alibaba.fastjson2.JSON;
 import com.alibaba.fastjson2.JSONObject;
 import com.ruoyi.account.service.VipCenterService;
 import com.ruoyi.account.service.VipSettingService;
 import com.ruoyi.account.vo.vip.Level;
 import com.ruoyi.account.vo.vip.VipLevel;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.exception.ServiceException;
 import com.ruoyi.common.core.utils.bean.BeanUtils;
 import com.ruoyi.common.security.service.TokenService;
 import com.ruoyi.other.api.domain.*;
-import com.ruoyi.other.api.feignClient.BaseSettingClient;
-import com.ruoyi.other.api.feignClient.GoodsVipClient;
-import com.ruoyi.other.api.feignClient.RemoteVipSettingClient;
-import com.ruoyi.other.api.feignClient.VipGoodClient;
+import com.ruoyi.other.api.feignClient.*;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import io.swagger.annotations.ApiParam;
@@ -45,6 +44,8 @@
     private VipCenterService vipCenterService;
     @Resource
     private VipGoodClient vipGoodClient;
+    @Resource
+    private GoodsClient goodsClient;
 
 
     @GetMapping("getVipLevelList")
@@ -79,7 +80,6 @@
 
             // 批量获取 goodsVip 和 vipGoods
             List<Integer> vipIds = vipSettingList.stream().map(VipSetting::getId).collect(Collectors.toList());
-            Map<Integer, R<GoodsVip>> goodsVipMap = getGoodsVips(vipIds);
             Map<Integer, R<List<VipGood>>> vipGoodsMap = getVipGoods(vipIds);
 
             vipSettingList.forEach(vipSetting -> {
@@ -87,25 +87,18 @@
                 BeanUtils.copyBeanProp(level, vipSetting);
                 level.setVipDesc(baseSetting.getContent());
 
-                R<GoodsVip> goodsVipR = goodsVipMap.get(vipSetting.getId());
-                if (R.isSuccess(goodsVipR)) {
-                    R<List<VipGood>> vipGoodR = vipGoodsMap.get(vipSetting.getId());
-                    if (R.isSuccess(vipGoodR)) {
-                        List<VipGood> vipGoodList = vipGoodR.getData();
-                        if (vipGoodList != null && !vipGoodList.isEmpty()) {
-                            List<String> goodsNames = new ArrayList<>();
-                            vipGoodList.forEach(vipGood -> {
-                                String goodJson = vipGood.getGoodJson();
-                                if (isValidJson(goodJson)) {
-                                    Goods goods = JSONObject.parseObject(goodJson, Goods.class);
-                                    goodsNames.add(goods.getName());
-                                } else {
-                                    log.warn("JSON无效: " + goodJson);
-                                }
-                            });
-                            level.setGoodsNames(goodsNames);
-                        }
-                    }
+                R<List<VipGood>> vipGoodR = vipGoodsMap.get(vipSetting.getId());
+                if (R.isError(vipGoodR)) {
+                    throw new ServiceException("会员商品获取失败");
+                }
+                List<VipGood> vipGoodList = vipGoodR.getData();
+                if (vipGoodList != null && !vipGoodList.isEmpty()) {
+                    List<String> goodsNames = new ArrayList<>();
+                    vipGoodList.forEach(vipGood -> {
+                        Goods goods = JSON.parseObject(vipGood.getGood_json(), Goods.class);
+                        goodsNames.add(goods.getName());
+                    });
+                    level.setGoodsNames(goodsNames);
                 }
                 levelList.add(level);
             });
@@ -133,7 +126,7 @@
     private Map<Integer, R<GoodsVip>> getGoodsVips(List<Integer> vipIds) {
         Map<Integer, R<GoodsVip>> result = new HashMap<>();
         for (Integer vipId : vipIds) {
-            R<GoodsVip> goodsVipR = goodsVipClient.getGoodsVip(vipId);
+            R<GoodsVip> goodsVipR = goodsVipClient.getGoodsVip(null, vipId);
             result.put(vipId, goodsVipR);
         }
         return result;

--
Gitblit v1.7.1