From 4b9dc71d162f3fcd79bc88b170154b7516fc4962 Mon Sep 17 00:00:00 2001
From: chenhj <1263187585@qq.com>
Date: 星期四, 18 十二月 2025 13:37:14 +0800
Subject: [PATCH] 新增设备维修保养过程描述,上传对应附件

---
 src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java |  150 ++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 127 insertions(+), 23 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 7871fb4..6017793 100644
--- a/src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java
+++ b/src/main/java/com/ruoyi/account/service/impl/AccountExpenseServiceImpl.java
@@ -9,25 +9,25 @@
 import com.ruoyi.account.dto.AccountDto2;
 import com.ruoyi.account.dto.AccountDto3;
 import com.ruoyi.account.mapper.AccountExpenseMapper;
-import com.ruoyi.account.mapper.AccountFileMapper;
 import com.ruoyi.account.mapper.AccountIncomeMapper;
 import com.ruoyi.account.pojo.AccountExpense;
 import com.ruoyi.account.pojo.AccountIncome;
 import com.ruoyi.account.service.AccountExpenseService;
-import com.ruoyi.account.service.AccountIncomeService;
 import com.ruoyi.common.utils.poi.ExcelUtil;
 import com.ruoyi.dto.DateQueryDto;
+import com.ruoyi.project.system.domain.SysDictData;
+import com.ruoyi.project.system.mapper.SysDictDataMapper;
 import lombok.AllArgsConstructor;
 import org.springframework.stereotype.Service;
 
 import javax.servlet.http.HttpServletResponse;
 import java.math.BigDecimal;
+import java.time.DayOfWeek;
 import java.time.LocalDate;
+import java.time.ZoneId;
 import java.time.format.DateTimeFormatter;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
+import java.util.stream.Collectors;
 
 @AllArgsConstructor
 @Service
@@ -36,6 +36,8 @@
     private AccountExpenseMapper accountExpenseMapper;
 
     private AccountIncomeMapper accountIncomeMapper;
+
+    private SysDictDataMapper sysDictDataMapper;
 
 
     //鍒嗛〉鏌ヨ
@@ -88,26 +90,128 @@
 
     //璐㈠姟鎶ヨ〃骞存煡璇�
     @Override
-    public AccountDto3 reportExpense() {
-        AccountDto3 accountDto3 = new AccountDto3();
+    public  List<AccountDto3> reportExpense() {
+        List<AccountDto3> accountDto3s = new ArrayList<>();
+        //鍏堟煡璇㈡敹鍏ョ被鍨嬫湁鍝簺
+        List<SysDictData> incomeTypes = sysDictDataMapper.selectDictDataByType("expense_types");
         DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
         int currentYear = LocalDate.now().getYear(); // 鑾峰彇褰撳墠骞翠唤锛堝2025锛�
-        List<String> months = new ArrayList<>();
-        Map<String, List<AccountDto2>> map = new HashMap<>();
-        for (int i = 1; i <= 12; i++) {
-            months.add(i + "鏈�");
-            // 褰撴湀绗竴澶╋細骞翠唤涓哄綋鍓嶅勾锛屾湀浠戒负i锛屾棩鏈熶负1
-            LocalDate firstDay = LocalDate.of(currentYear, i, 1);
-            DateQueryDto dateQueryDto = new DateQueryDto();
-            dateQueryDto.setEntryDateStart(firstDay.format(formatter));
-            // 褰撴湀鏈�鍚庝竴澶╋細绗竴澶╃殑鏈堜唤鐨勬渶鍚庝竴澶�
-            dateQueryDto.setEntryDateEnd(firstDay.plusMonths(1).minusDays(1).format(formatter));
-            List<AccountDto2> report = accountExpenseMapper.report(dateQueryDto);
-            map.put(i + "鏈�",report);
+        for (SysDictData incomeType : incomeTypes) {
+            AccountDto3 accountDto3 = new AccountDto3();
+            accountDto3.setTypeName(incomeType.getDictLabel());//绫诲瀷
+            List<BigDecimal> account=new ArrayList<>();
+            for (int i = 1; i <= 12; i++) {
+                // 褰撴湀绗竴澶╋細骞翠唤涓哄綋鍓嶅勾锛屾湀浠戒负i锛屾棩鏈熶负1
+                LocalDate firstDay = LocalDate.of(currentYear, i, 1);
+                DateQueryDto dateQueryDto = new DateQueryDto();
+                dateQueryDto.setEntryDateStart(firstDay.format(formatter));
+                // 褰撴湀鏈�鍚庝竴澶╋細绗竴澶╃殑鏈堜唤鐨勬渶鍚庝竴澶�
+                dateQueryDto.setEntryDateEnd(firstDay.plusMonths(1).minusDays(1).format(formatter));
+                account.add(accountExpenseMapper.report1(dateQueryDto,incomeType.getDictValue()));
+            }
+            accountDto3.setAccount(account);//绫诲瀷
+            accountDto3s.add(accountDto3);
         }
-        accountDto3.setMonth(months);
-        accountDto3.setAccountType(map);
-        return accountDto3;
+        return accountDto3s;
+    }
+
+    @Override
+    public Map<String, List<String>> analysis() {
+        // 鑾峰彇鏈�杩戝洓涓湀锛堝綋鍓嶆湀 + 鍓�3涓湀锛夌殑鏃堕棿鑼冨洿
+        LocalDate today = LocalDate.now();
+        DateTimeFormatter monthFormatter = DateTimeFormatter.ofPattern("yyyy-MM"); // 骞存湀鏍煎紡鍖栧櫒
+        Map<String, List<String>> result = new HashMap<>();
+        List<String> months = new ArrayList<>(); // 瀛樺偍骞存湀锛堝 2025-12銆�2025-11锛�
+        List<String> totalIncomeList = new ArrayList<>(); // 姣忔湀鎬绘敹鍏�
+        List<String> totalExpenseList = new ArrayList<>(); // 姣忔湀鎬绘敮鍑�
+        List<String> netIncomeList = new ArrayList<>(); // 姣忔湀鍑�鏀跺叆锛堟敹鍏�-鏀嚭锛�
+
+        // 姝ラ1锛氳绠楄繎4涓湀鐨勫勾鏈堝垪琛紙褰撳墠鏈堛�佸墠1鏈堛�佸墠2鏈堛�佸墠3鏈堬級
+        List<String> targetMonths = new ArrayList<>();
+        for (int i = 0; i < 4; i++) {
+            LocalDate currentMonth = today.minusMonths(i);
+            String monthStr = currentMonth.format(monthFormatter);
+            targetMonths.add(monthStr);
+        }
+        // 鍙嶈浆鍒楄〃锛岀‘淇濋『搴忎负銆屽墠3鏈� 鈫� 褰撳墠鏈堛�嶏紙鍙�夛紝鎸夐渶姹傝皟鏁撮『搴忥級
+        Collections.reverse(targetMonths);
+
+        // 姝ラ2锛氫竴娆℃�ф煡璇㈣繎4涓湀鎵�鏈夋敹鍏ユ暟鎹紝鎸夆�滃勾鏈堚�濆垎缁勬眹鎬�
+        LocalDate fourMonthsAgo = today.minusMonths(3).withDayOfMonth(1); // 杩�4涓湀璧峰鏃ワ紙鍓�3鏈�1鍙凤級
+        LocalDate currentMonthEnd = today.withDayOfMonth(today.lengthOfMonth()); // 褰撳墠鏈堢粨鏉熸棩
+        ZoneId zoneId = ZoneId.of("Asia/Shanghai");
+        // 鏌ヨ杩�4涓湀鎵�鏈夋敹鍏�
+        List<AccountIncome> allIncomes = accountIncomeMapper.selectList(
+                Wrappers.<AccountIncome>lambdaQuery()
+                        .ge(AccountIncome::getIncomeDate, fourMonthsAgo.toString()) // 澶т簬绛変簬璧峰鏃�
+                        .le(AccountIncome::getIncomeDate, currentMonthEnd.toString()) // 灏忎簬绛変簬缁撴潫鏃�
+        );
+
+        // 鏀跺叆鎸夆�滃勾鏈堚�濆垎缁勬眹鎬伙紙key锛氬勾鏈堝瓧绗︿覆锛寁alue锛氬綋鏈堟�绘敹鍏ワ級
+        Map<String, BigDecimal> monthlyIncomeMap = allIncomes.stream()
+                .filter(income -> income.getIncomeMoney() != null) // 杩囨护绌洪噾棰�
+                .collect(Collectors.groupingBy(
+                        income -> {
+                            // 灏嗚緭鍏ユ椂闂达紙瀛楃涓诧級杞崲涓篖ocalDate锛屽啀鏍煎紡鍖栦负骞存湀
+                            LocalDate inputDate = income.getIncomeDate().toInstant().atZone(zoneId).toLocalDate();
+                            return inputDate.format(monthFormatter);
+                        },
+                        Collectors.reducing(BigDecimal.ZERO, AccountIncome::getIncomeMoney, BigDecimal::add)
+                ));
+
+        // 姝ラ3锛氫竴娆℃�ф煡璇㈣繎4涓湀鎵�鏈夋敮鍑烘暟鎹紝鎸夆�滃勾鏈堚�濆垎缁勬眹鎬�
+        List<AccountExpense> allExpenses = accountExpenseMapper.selectList(
+                Wrappers.<AccountExpense>lambdaQuery()
+                        .ge(AccountExpense::getExpenseDate, fourMonthsAgo.toString())
+                        .le(AccountExpense::getExpenseDate, currentMonthEnd.toString())
+        );
+
+        // 鏀嚭鎸夆�滃勾鏈堚�濆垎缁勬眹鎬�
+        Map<String, BigDecimal> monthlyExpenseMap = allExpenses.stream()
+                .filter(expense -> expense.getExpenseMoney() != null) // 杩囨护绌洪噾棰�
+                .collect(Collectors.groupingBy(
+                        expense -> {
+                            LocalDate inputDate = expense.getExpenseDate().toInstant().atZone(zoneId).toLocalDate();
+                            return inputDate.format(monthFormatter);
+                        },
+                        Collectors.reducing(BigDecimal.ZERO, AccountExpense::getExpenseMoney, BigDecimal::add)
+                ));
+
+        // 姝ラ4锛氬惊鐜�4涓洰鏍囨湀浠斤紝濉厖缁熻鏁版嵁锛堟棤鏁版嵁鏃堕粯璁や负0锛�
+        for (String month : targetMonths) {
+            // 褰撴湀鎬绘敹鍏ワ紙鏃犳暟鎹垯涓�0锛�
+            BigDecimal totalIncome = monthlyIncomeMap.getOrDefault(month, BigDecimal.ZERO);
+            // 褰撴湀鎬绘敮鍑猴紙鏃犳暟鎹垯涓�0锛�
+            BigDecimal totalExpense = monthlyExpenseMap.getOrDefault(month, BigDecimal.ZERO);
+            // 褰撴湀鍑�鏀跺叆锛堟敹鍏� - 鏀嚭锛�
+            BigDecimal netIncome = totalIncome.subtract(totalExpense);
+
+            // 濉厖鍒楄〃
+            months.add(month);
+            totalIncomeList.add(totalIncome.toString());
+            totalExpenseList.add(totalExpense.toString());
+            netIncomeList.add(netIncome.toString());
+        }
+
+        // 缁勮缁撴灉
+        result.put("days", months); // 骞存湀锛堝 ["2025-09", "2025-10", "2025-11", "2025-12"]锛�
+        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));
+    }
+
+    @Override
+    public List<AccountExpense> getByInvoiceNumberList(String purchaseContractNumber) {
+        return accountExpenseMapper.selectList(Wrappers.<AccountExpense>lambdaQuery()
+                .eq(AccountExpense::getInvoiceNumber, purchaseContractNumber));
     }
 
 

--
Gitblit v1.9.3