From 60f70f7409ec1ece8905e088fb43e0cb0258a70b Mon Sep 17 00:00:00 2001
From: luodangjia <luodangjia>
Date: 星期四, 19 十二月 2024 10:10:57 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/ShopBalanceStatementServiceImpl.java |   49 ++++++++++++++++++++++---------------------------
 1 files changed, 22 insertions(+), 27 deletions(-)

diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/ShopBalanceStatementServiceImpl.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/ShopBalanceStatementServiceImpl.java
index 9e265b5..8a94449 100644
--- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/ShopBalanceStatementServiceImpl.java
+++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/ShopBalanceStatementServiceImpl.java
@@ -1,19 +1,17 @@
 package com.ruoyi.other.service.impl;
 
-import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
-import com.ruoyi.other.api.domain.Shop;
-import com.ruoyi.other.mapper.ShopBalanceStatementMapper;
 import com.ruoyi.other.api.domain.ShopBalanceStatement;
+import com.ruoyi.other.api.domain.ShopPoint;
+import com.ruoyi.other.mapper.ShopBalanceStatementMapper;
 import com.ruoyi.other.service.ShopBalanceStatementService;
-import com.ruoyi.other.service.ShopService;
 import com.ruoyi.other.vo.ShopCommissionStatisticsVO;
 import org.springframework.stereotype.Service;
-import org.springframework.util.CollectionUtils;
 
-import javax.annotation.Resource;
+import java.math.BigDecimal;
 import java.util.List;
+import java.util.Map;
 import java.util.stream.Collectors;
 
 /**
@@ -26,32 +24,29 @@
  */
 @Service
 public class ShopBalanceStatementServiceImpl extends ServiceImpl<ShopBalanceStatementMapper, ShopBalanceStatement> implements ShopBalanceStatementService {
-    @Resource
-    private ShopBalanceStatementMapper shopBalanceStatementMapper;
-    @Resource
-    private ShopService shopService;
 
 
     @Override
     public ShopCommissionStatisticsVO shopCommissionStatistics(IPage<ShopBalanceStatement> page, ShopBalanceStatement shopBalanceStatement) {
-        List<ShopBalanceStatement> latestChangeByType = shopBalanceStatementMapper.findLatestChangeByType(shopBalanceStatement);
         ShopCommissionStatisticsVO shopCommissionStatisticsVO = new ShopCommissionStatisticsVO();
-        for (ShopBalanceStatement sp : latestChangeByType) {
-            switch (sp.getType()) {
-                case 1:
-                    shopCommissionStatisticsVO.setTotalCommission(sp.getBalance());
-                    break;
-                case 2:
-                    shopCommissionStatisticsVO.setTotalSubordinateCommission(sp.getBalance());
-                    break;
-                case 3:
-                    shopCommissionStatisticsVO.setTotalServiceCharge(sp.getBalance());
-                    break;
-           }
-        }
-        shopCommissionStatisticsVO.setTotalAmount(shopCommissionStatisticsVO.getTotalCommission()
-                .add(shopCommissionStatisticsVO.getTotalSubordinateCommission())
-                .add(shopCommissionStatisticsVO.getTotalServiceCharge()));
+        List<ShopBalanceStatement> shopBalanceStatements = this.baseMapper.selectShopBalanceStatementList(shopBalanceStatement);
+
+        Map<Integer, BigDecimal> shopCommissionMap = shopBalanceStatements.stream()
+                .collect(Collectors.groupingBy(
+                        ShopBalanceStatement::getType,
+                        Collectors.reducing(
+                                BigDecimal.ZERO,
+                                ShopBalanceStatement::getVariableAmount,
+                                BigDecimal::add
+                        )
+                ));
+
+        BigDecimal totalCommission = shopCommissionMap.get(1);
+        BigDecimal totalSubordinateCommission = shopCommissionMap.get(2);
+        BigDecimal totalServiceCharge = shopCommissionMap.get(3);
+
+        BigDecimal totalAmount = totalCommission.add(totalSubordinateCommission).add(totalServiceCharge);
+        shopCommissionStatisticsVO.setTotalAmount(totalAmount);
 
         IPage<ShopBalanceStatement> statementIPage = this.baseMapper.queryShopBalanceStatementPage(page, shopBalanceStatement);
         shopCommissionStatisticsVO.setStatementIPage(statementIPage);

--
Gitblit v1.7.1