From 91b7e532e7c785bf4a891dc416a6094a14fa7acb Mon Sep 17 00:00:00 2001
From: rentaiming <806181062@qq.com>
Date: 星期一, 03 六月 2024 14:05:25 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionGoodsServiceImpl.java |   39 ++++++++++++++++++++++++++++++++++++++-
 1 files changed, 38 insertions(+), 1 deletions(-)

diff --git a/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionGoodsServiceImpl.java b/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionGoodsServiceImpl.java
index 5973f5b..e5d9bda 100644
--- a/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionGoodsServiceImpl.java
+++ b/ruoyi-modules/ruoyi-auction/src/main/java/com/ruoyi/auction/service/impl/AuctionGoodsServiceImpl.java
@@ -44,6 +44,7 @@
 import com.ruoyi.system.api.domain.dto.AuctionGoodsListDTO;
 import com.ruoyi.system.api.domain.dto.AuctionGoodsListPageDTO;
 import com.ruoyi.system.api.domain.dto.GoodsStockUpdDTO;
+import com.ruoyi.system.api.domain.dto.ListStatusDTO;
 import com.ruoyi.system.api.domain.dto.MemberAuctionSalesroomDTO;
 import com.ruoyi.system.api.domain.dto.OrderDTO;
 import com.ruoyi.system.api.domain.dto.RefundDTO;
@@ -127,7 +128,28 @@
                 .eq(StringUtils.isNotNull(query.getStartStatus()), AuctionGoods::getStartStatus,
                         query.getStartStatus())
                 .page(new Page<>(query.getPageCurr(), query.getPageSize()));
-        return PageDTO.of(page, MgtAuctionGoodsVO.class);
+        if (StringUtils.isEmpty(page.getRecords())) {
+            return PageDTO.empty(page.getTotal(), page.getPages());
+        }
+        // 查询商品信息
+        Set<Long> goodsIdList = page.getRecords().stream().map(AuctionGoods::getGoodsSkuId)
+                .collect(Collectors.toSet());
+        List<GoodsSku> data = goodsSkuClient.getGoodsListByIds(goodsIdList, SecurityConstants.INNER)
+                .getData();
+        PageDTO<MgtAuctionGoodsVO> pageDTO = PageDTO.of(page,
+                MgtAuctionGoodsVO.class);
+        if (StringUtils.isNotEmpty(data)) {
+            Map<Long, GoodsSku> goodsSkuMap = data.stream()
+                    .collect(Collectors.toMap(GoodsSku::getId, e -> e));
+            for (MgtAuctionGoodsVO mgtAuctionGoodsVO : pageDTO.getList()) {
+                GoodsSku goodsSku = goodsSkuMap.get(mgtAuctionGoodsVO.getGoodsSkuId());
+                if (StringUtils.isNotNull(goodsSku)) {
+                    mgtAuctionGoodsVO.setGoodsSkuName(goodsSku.getSkuName());
+                    mgtAuctionGoodsVO.setSpec(goodsSku.getSpec());
+                }
+            }
+        }
+        return pageDTO;
     }
 
     @Override
@@ -567,4 +589,19 @@
             log.info("===================>发送websocket通知,消息体{}", msg);
         }
     }
+
+    /**
+     * 下架/上架 拍卖商品
+     *
+     * @param dto 商品上下架状态对象
+     */
+    @Override
+    public void updStatus(ListStatusDTO dto) {
+        AuctionGoods auctionGoods = this.getById(dto.getId());
+        if (StringUtils.isNull(auctionGoods)) {
+            throw new ServiceException("拍卖商品不存在");
+        }
+        auctionGoods.setListingStatus(dto.getListingStatus());
+        this.updateById(auctionGoods);
+    }
 }

--
Gitblit v1.7.1