From e2aa651db9f17d58819329de571037edc0f9eba2 Mon Sep 17 00:00:00 2001
From: yaowanxin <3588231647@qq.com>
Date: 星期一, 23 六月 2025 18:13:37 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 src/main/java/com/ruoyi/sales/service/impl/ReceiptPaymentServiceImpl.java |   98 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 97 insertions(+), 1 deletions(-)

diff --git a/src/main/java/com/ruoyi/sales/service/impl/ReceiptPaymentServiceImpl.java b/src/main/java/com/ruoyi/sales/service/impl/ReceiptPaymentServiceImpl.java
index 62add42..fe9550b 100644
--- a/src/main/java/com/ruoyi/sales/service/impl/ReceiptPaymentServiceImpl.java
+++ b/src/main/java/com/ruoyi/sales/service/impl/ReceiptPaymentServiceImpl.java
@@ -4,8 +4,12 @@
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.utils.SecurityUtils;
+import com.ruoyi.common.utils.poi.ExcelUtil;
+import com.ruoyi.sales.dto.CustomerInteractionDto;
 import com.ruoyi.sales.dto.InvoiceLedgerDto;
 import com.ruoyi.sales.dto.ReceiptPaymentDto;
+import com.ruoyi.sales.dto.ReceiptPaymentExeclDto;
 import com.ruoyi.sales.mapper.ReceiptPaymentMapper;
 import com.ruoyi.sales.mapper.SalesLedgerMapper;
 import com.ruoyi.sales.pojo.ReceiptPayment;
@@ -16,10 +20,12 @@
 import org.springframework.util.CollectionUtils;
 import org.springframework.util.ObjectUtils;
 
+import javax.servlet.http.HttpServletResponse;
 import java.math.BigDecimal;
 import java.time.LocalDate;
 import java.time.YearMonth;
 import java.util.*;
+import java.util.stream.Collectors;
 
 @Service
 public class ReceiptPaymentServiceImpl extends ServiceImpl<ReceiptPaymentMapper,ReceiptPayment> implements ReceiptPaymentService {
@@ -132,7 +138,11 @@
      */
     @Override
     public IPage<ReceiptPaymentDto> bindInvoiceNoRegPage(Page page, ReceiptPaymentDto receiptPaymentDto) {
-        return receiptPaymentMapper.bindInvoiceNoRegPage(page, receiptPaymentDto);
+        IPage<ReceiptPaymentDto> receiptPaymentDtoIPage = receiptPaymentMapper.bindInvoiceNoRegPage(page, receiptPaymentDto);
+        if (receiptPaymentDto.getStatus()) {
+            receiptPaymentDtoIPage.getRecords().removeIf(receiptPaymentDto1 -> new BigDecimal("0.00").equals(receiptPaymentDto1.getNoReceiptAmount()));
+        }
+        return receiptPaymentDtoIPage;
     }
 
     /**
@@ -182,4 +192,90 @@
     public List<ReceiptPaymentDto> receiptPaymentHistoryList(ReceiptPaymentDto receiptPaymentDto) {
         return receiptPaymentMapper.receiptPaymentHistoryList(receiptPaymentDto);
     }
+
+    /**
+     * 鏌ヨ鍥炴璁板綍鍒嗛〉
+     */
+    @Override
+    public IPage<ReceiptPaymentDto> receiptPaymentHistoryListPage(Page page, ReceiptPaymentDto receiptPaymentDto) {
+        return receiptPaymentMapper.receiptPaymentHistoryListPage(page, receiptPaymentDto);
+    }
+
+    /**
+     * 瀹㈡埛寰�鏉ヨ褰曟煡璇�
+     * @param receiptPaymentDto
+     * @return
+     */
+    @Override
+    public List<CustomerInteractionDto> customerInteractions(ReceiptPaymentDto receiptPaymentDto) {
+        ArrayList<CustomerInteractionDto> result = new ArrayList<>();
+        List<CustomerInteractionDto> customerInteractionDtos = receiptPaymentMapper.customerInteractions(receiptPaymentDto);
+        if(CollectionUtils.isEmpty(customerInteractionDtos)){
+            return result;
+        }
+        // 搴旀敹鎬婚噾棰濋噾棰濊绠�
+        BigDecimal amountTotal = BigDecimal.ZERO;
+        Map<LocalDate, List<CustomerInteractionDto>> dateListMap = customerInteractionDtos.stream().collect(
+                Collectors.groupingBy(
+                        CustomerInteractionDto::getHappenTime,
+                        LinkedHashMap::new,
+                        Collectors.toList()
+                )
+        );
+        for (LocalDate localDate : dateListMap.keySet()) {
+            BigDecimal currentReceiptAmount = BigDecimal.ZERO;
+            BigDecimal invoiceAmount = BigDecimal.ZERO;
+            BigDecimal currentDateTotal = BigDecimal.ZERO;
+            List<CustomerInteractionDto> customerInteractionDtoList = dateListMap.get(localDate);
+            // 璁$畻褰撳ぉ鏀舵鏁�
+            currentReceiptAmount = customerInteractionDtoList.stream()
+                    .filter(item ->item.getType() == 0)
+                    .map(CustomerInteractionDto::getReceiptAmount)
+                    .reduce(BigDecimal.ZERO,BigDecimal::add);
+            // 璁$畻褰撳ぉ寮�绁ㄦ暟
+            invoiceAmount = customerInteractionDtoList.stream()
+                    .filter(item ->item.getType() == 1)
+                    .map(CustomerInteractionDto::getInvoiceAmount)
+                    .reduce(BigDecimal.ZERO,BigDecimal::add);
+            // 璁$畻褰撴棩姹囨��
+            currentDateTotal = currentDateTotal.add(invoiceAmount).subtract(currentReceiptAmount);
+            CustomerInteractionDto customerInteractionDto = new CustomerInteractionDto();
+            customerInteractionDto.setHappenTime(localDate);
+            customerInteractionDto.setInvoiceAmount(invoiceAmount);
+            customerInteractionDto.setReceiptAmount(currentReceiptAmount);
+            amountTotal = customerInteractionDto.getInvoiceAmount().subtract(customerInteractionDto.getReceiptAmount());
+            customerInteractionDto.setUnReceiptAmount(amountTotal);
+            result.add(customerInteractionDto);
+        }
+        return result;
+    }
+
+    /**
+     * 鏌ヨ鍥炴璁板綍鍒嗛〉
+     */
+    @Override
+    public List<ReceiptPaymentDto> receiptPaymentHistoryListNoPage(ReceiptPaymentDto receiptPaymentDto) {
+        return receiptPaymentMapper.receiptPaymentHistoryListNoPage( receiptPaymentDto);
+    }
+
+    @Override
+    public void exportPaymentList(HttpServletResponse response) {
+       List<ReceiptPaymentDto> receiptPaymentDtoList =  receiptPaymentMapper.bindInvoiceNoRegListAll();
+        ExcelUtil<ReceiptPaymentDto> util = new ExcelUtil<ReceiptPaymentDto>(ReceiptPaymentDto.class);
+        util.exportExcel(response, receiptPaymentDtoList, "鍥炴鐧昏");
+    }
+
+    @Override
+    public void exportPaymentList(HttpServletResponse response, List<Long> ids) {
+        if (ids == null) {
+            List<ReceiptPaymentExeclDto> receiptPaymentDtoList =  receiptPaymentMapper.bindInvoiceNoRegListByIds(new ArrayList<>(), SecurityUtils.getLoginUser().getTenantId());
+            ExcelUtil<ReceiptPaymentExeclDto> util = new ExcelUtil<ReceiptPaymentExeclDto>(ReceiptPaymentExeclDto.class);
+            util.exportExcel(response, receiptPaymentDtoList, "鍥炴鐧昏");
+        }else {
+            List<ReceiptPaymentExeclDto> receiptPaymentDtoList =  receiptPaymentMapper.bindInvoiceNoRegListByIds(ids,SecurityUtils.getLoginUser().getTenantId());
+            ExcelUtil<ReceiptPaymentExeclDto> util = new ExcelUtil<ReceiptPaymentExeclDto>(ReceiptPaymentExeclDto.class);
+            util.exportExcel(response, receiptPaymentDtoList, "鍥炴鐧昏");
+        }
+
+    }
 }

--
Gitblit v1.9.3