From b68348c51d17bee1952a2316d37da7775dac2dd8 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期五, 13 九月 2024 11:28:39 +0800
Subject: [PATCH] 修改接口

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TOrderSaleServiceImpl.java |   24 ++++++++++--------------
 1 files changed, 10 insertions(+), 14 deletions(-)

diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TOrderSaleServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TOrderSaleServiceImpl.java
index 62f8b4b..4a2dc22 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TOrderSaleServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TOrderSaleServiceImpl.java
@@ -9,6 +9,7 @@
 import com.ruoyi.system.domain.*;
 import com.ruoyi.system.dto.CheckoutDTO;
 import com.ruoyi.system.dto.TOrderSaleDTO;
+import com.ruoyi.system.mapper.TOrderSaleGoodsMapper;
 import com.ruoyi.system.mapper.TOrderSaleMapper;
 import com.ruoyi.system.query.*;
 import com.ruoyi.system.service.TGoodsService;
@@ -42,6 +43,8 @@
 
     @Autowired
     private TOrderSaleGoodsService orderSaleGoodsService;
+    @Autowired
+    private TOrderSaleGoodsMapper orderSaleGoodsMapper;
     @Autowired
     private TGoodsTypeService goodsTypeService;
     @Autowired
@@ -135,25 +138,18 @@
     }
 
     @Override
-    public List<SalesRankingVO> salesRanking(TDataStatisticsQuery query) {
+    public PageInfo<SalesRankingVO> salesRanking(TDataStatisticsQuery query) {
+        PageInfo<SalesRankingVO> pageInfo = new PageInfo<>(query.getPageNum(),query.getPageSize());
         List<TOrderSale> list = this.list(Wrappers.lambdaQuery(TOrderSale.class)
                 .eq(TOrderSale::getShopId, query.getShopId())
                 .between(TOrderSale::getOrderTime, query.getStartTime(), query.getEndTime()));
         List<Long> ids = list.stream().map(TOrderSale::getId).collect(Collectors.toList());
-        List<SalesRankingVO> salesRankingVOS = new ArrayList<>();
-        if(!CollectionUtils.isEmpty(ids)){
-            List<TOrderSaleGoods> list1 = orderSaleGoodsService.list(Wrappers.lambdaQuery(TOrderSaleGoods.class)
-                    .in(TOrderSaleGoods::getOrderId, ids));
-            Map<Long, List<TOrderSaleGoods>> listMap = list1.stream().collect(Collectors.groupingBy(TOrderSaleGoods::getTypeId));
-            List<TGoodsType> list2 = goodsTypeService.list();
-            listMap.forEach((k,v)->{
-                SalesRankingVO salesRankingVO = new SalesRankingVO();
-                salesRankingVO.setTypeName(list2.stream().filter(e->e.getId().equals(k)).findFirst().get().getTypeName());
-                salesRankingVO.setSalesVolume(v.stream().map(item->item.getGoodsSalePrice().multiply(new BigDecimal(item.getGoodsCount()))).reduce(BigDecimal.ZERO, BigDecimal::add));
-                salesRankingVOS.add(salesRankingVO);
-            });
+        if(CollectionUtils.isEmpty(ids)){
+            return new PageInfo<>();
         }
-        return salesRankingVOS;
+        List<SalesRankingVO> salesRankingVOS = orderSaleGoodsMapper.salesRanking(ids,pageInfo);
+        pageInfo.setRecords(salesRankingVOS);
+        return pageInfo;
     }
 
     @Override

--
Gitblit v1.7.1