From a76e1d17d67641993dea6335cb8e1465a94df58d Mon Sep 17 00:00:00 2001
From: liding <756868258@qq.com>
Date: 星期四, 21 五月 2026 15:39:05 +0800
Subject: [PATCH] feat(stock): 优化库存管理和成品树结构功能 1- 为ApproveProcessMapper.xml和ProductBomMapper.xml添加排序功能 2- 在ProductionProductMainDto中新增bomInputQty字段用于产品结构投入数量 3- 修改ProductionProductMainServiceImpl中投入数量计算逻辑,使用前端传入的bomInputQty值 4- 在ProductWorkOrderDto中添加bomInputQty字段并在服务实现中计算标准投入数量 5- 更新SalesLedgerMapper.xml查询逻辑,从product_summary获取电压信息 6- 为SalesLedgerProduct添加stockId字段并修改库存扣减逻辑使用具体库存ID 7- 重构StockInventoryController中的成品库存树查询接口和导入导出功能 8- 新增成品和非成品库存导入导出的数据模型和Excel工具类 9- 优化StockInventoryServiceImpl中的库存扣减逻辑,支持按特定库存ID操作 10- 更新库存导入导出功能,区分成品和非成品类型并提供相应模板

---
 src/main/java/com/ruoyi/account/service/impl/AccountIncomeServiceImpl.java |   38 ++++++++++++++++++++++++++++++--------
 1 files changed, 30 insertions(+), 8 deletions(-)

diff --git a/src/main/java/com/ruoyi/account/service/impl/AccountIncomeServiceImpl.java b/src/main/java/com/ruoyi/account/service/impl/AccountIncomeServiceImpl.java
index b4188e5..4a83ecb 100644
--- a/src/main/java/com/ruoyi/account/service/impl/AccountIncomeServiceImpl.java
+++ b/src/main/java/com/ruoyi/account/service/impl/AccountIncomeServiceImpl.java
@@ -7,9 +7,11 @@
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.account.dto.AccountDto2;
 import com.ruoyi.account.dto.AccountDto3;
+import com.ruoyi.account.dto.ReportDateDto;
 import com.ruoyi.account.mapper.AccountIncomeMapper;
 import com.ruoyi.account.pojo.AccountIncome;
 import com.ruoyi.account.service.AccountIncomeService;
+import com.ruoyi.common.utils.DateUtils;
 import com.ruoyi.common.utils.poi.ExcelUtil;
 import com.ruoyi.dto.DateQueryDto;
 import com.ruoyi.project.system.domain.SysDictData;
@@ -51,24 +53,38 @@
 
     //璐㈠姟鎶ヨ〃骞存煡璇�
     @Override
-    public List<AccountDto3> reportIncome() {
+    public List<AccountDto3> reportIncome(ReportDateDto reportDateDto) {
         List<AccountDto3> accountDto3s = new ArrayList<>();
         //鍏堟煡璇㈡敹鍏ョ被鍨嬫湁鍝簺
         List<SysDictData> incomeTypes = sysDictDataMapper.selectDictDataByType("income_types");
         DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
-        int currentYear = LocalDate.now().getYear(); // 鑾峰彇褰撳墠骞翠唤锛堝2025锛�
+//        int currentYear = LocalDate.now().getYear(); // 鑾峰彇褰撳墠骞翠唤锛堝2025锛�
         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);
+            LocalDate startDate = reportDateDto.getEntryDateStart();
+            LocalDate endDate = reportDateDto.getEntryDateEnd();
+
+            // 鍒濆鍖栧惊鐜彉閲忎负璧峰鏃ユ湡
+            LocalDate currentDate = startDate;
+
+            // 寰幆锛氬綋鍓嶆棩鏈熶笉瓒呰繃缁撴潫鏃ユ湡鏃剁户缁�
+            while (!currentDate.isAfter(endDate)) {
+                // 褰撴湀绗竴澶�
+                LocalDate firstDay = currentDate.withDayOfMonth(1);
                 DateQueryDto dateQueryDto = new DateQueryDto();
                 dateQueryDto.setEntryDateStart(firstDay.format(formatter));
-                // 褰撴湀鏈�鍚庝竴澶╋細绗竴澶╃殑鏈堜唤鐨勬渶鍚庝竴澶�
-                dateQueryDto.setEntryDateEnd(firstDay.plusMonths(1).minusDays(1).format(formatter));
-                account.add(accountIncomeMapper.report1(dateQueryDto,incomeType.getDictValue()));
+
+                // 褰撴湀鏈�鍚庝竴澶�
+                LocalDate lastDay = firstDay.plusMonths(1).minusDays(1);
+                dateQueryDto.setEntryDateEnd(lastDay.format(formatter));
+
+                // 绱姞鏁版嵁
+                account.add(accountIncomeMapper.report1(dateQueryDto, incomeType.getDictValue()));
+
+                // 鏈堜唤鍔犱竴锛堣嚜鍔ㄥ鐞嗚法骞达紝姣斿12鏈堝姞1涓湀浼氬彉鎴愪笅涓�骞�1鏈堬級
+                currentDate = currentDate.plusMonths(1);
             }
             accountDto3.setAccount(account);//绫诲瀷
             accountDto3s.add(accountDto3);
@@ -82,4 +98,10 @@
                 .eq(AccountIncome::getInvoiceNumber, purchaseContractNumber));
         return accountIncome;
     }
+
+    @Override
+    public List<AccountIncome> getByInvoiceNumberList(String purchaseContractNumber) {
+        return accountIncomeMapper.selectList(new LambdaQueryWrapper<AccountIncome>()
+                .eq(AccountIncome::getInvoiceNumber, purchaseContractNumber));
+    }
 }

--
Gitblit v1.9.3