From 0e4272399c014a3c6987ef4bd7d70f6ad90610ce Mon Sep 17 00:00:00 2001
From: maven <2163098428@qq.com>
Date: 星期三, 15 十月 2025 18:02:20 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java |   43 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 43 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java b/src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java
index 37c2f7c..ec1f077 100644
--- a/src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java
+++ b/src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java
@@ -22,6 +22,7 @@
 
 import javax.servlet.http.HttpServletResponse;
 import java.math.BigDecimal;
+import java.time.DayOfWeek;
 import java.time.LocalDate;
 import java.time.format.DateTimeFormatter;
 import java.util.ArrayList;
@@ -115,5 +116,47 @@
         return accountDto3s;
     }
 
+    @Override
+    public Map<String, List<String>> analysis() {
+        // 鑾峰彇鏈懆鐨勬椂闂磋寖鍥�
+        LocalDate startOfWeek = LocalDate.now().with(DayOfWeek.MONDAY);
+        LocalDate endOfWeek = LocalDate.now().with(DayOfWeek.SUNDAY);
+        Map<String, List<String>> result = new HashMap<>();
+        List<String> days = new ArrayList<>();
+        List<String> totalIncomeList = new ArrayList<>();
+        List<String> totalExpenseList = new ArrayList<>();
+        List<String> netIncomeList = new ArrayList<>();
+        // 鏍规嵁鏃堕棿鑼冨洿寰幆鏌ヨ姣忎竴澶╃殑鎬绘敹鍏ワ紝鎬绘敮鍑�,鍑�鏀跺叆锛堟�绘敹鍏�-鎬绘敮鍑猴級
+        for (LocalDate date = startOfWeek; date.isBefore(endOfWeek) || date.isEqual(endOfWeek); date = date.plusDays(1)) {
+            BigDecimal totalIncome = accountIncomeMapper.selectList(Wrappers.<AccountIncome>lambdaQuery()
+                    .eq(AccountIncome::getInputTime, date.toString()))
+                    .stream()
+                    .map(AccountIncome::getIncomeMoney)
+                    .reduce(BigDecimal.ZERO, BigDecimal::add);
+            BigDecimal totalExpense = accountExpenseMapper.selectList(Wrappers.<AccountExpense>lambdaQuery()
+                    .eq(AccountExpense::getInputTime, date.toString()))
+                    .stream()
+                    .map(AccountExpense::getExpenseMoney)
+                    .reduce(BigDecimal.ZERO, BigDecimal::add);
+            BigDecimal netIncome = totalIncome.subtract(totalExpense);
+            days.add(date.toString());
+            totalIncomeList.add(totalIncome.toString());
+            totalExpenseList.add(totalExpense.toString());
+            netIncomeList.add(netIncome.toString());
+        }
+        result.put("days", days);  //  澶�
+        result.put("totalIncome", totalIncomeList); // 鏀跺叆
+        result.put("totalExpense", totalExpenseList); // 鏀嚭
+        result.put("netIncome", netIncomeList); // 鍑�鏀跺叆
+
+        return result;
+    }
+
+    @Override
+    public AccountExpense getByInvoiceNumber(String purchaseContractNumber) {
+        return accountExpenseMapper.selectOne(Wrappers.<AccountExpense>lambdaQuery()
+                .eq(AccountExpense::getInvoiceNumber, purchaseContractNumber));
+    }
+
 
 }

--
Gitblit v1.9.3