From 3512270362c77fe45bc68ab7b6f28bd1bd2f8bfb Mon Sep 17 00:00:00 2001 From: chenrui <1187576398@qq.com> Date: 星期一, 09 六月 2025 11:58:56 +0800 Subject: [PATCH] 分页修改 --- src/main/java/com/ruoyi/sales/service/impl/ReceiptPaymentServiceImpl.java | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 52 insertions(+), 0 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 1e84cec..3e4de3d 100644 --- a/src/main/java/com/ruoyi/sales/service/impl/ReceiptPaymentServiceImpl.java +++ b/src/main/java/com/ruoyi/sales/service/impl/ReceiptPaymentServiceImpl.java @@ -4,6 +4,8 @@ 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.purchase.dto.PaymentHistoryRecordVo; +import com.ruoyi.sales.dto.CustomerInteractionDto; import com.ruoyi.sales.dto.InvoiceLedgerDto; import com.ruoyi.sales.dto.ReceiptPaymentDto; import com.ruoyi.sales.mapper.ReceiptPaymentMapper; @@ -20,6 +22,7 @@ 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 { @@ -190,4 +193,53 @@ 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 = amountTotal.add(currentDateTotal); + customerInteractionDto.setUnReceiptAmount(amountTotal); + result.add(customerInteractionDto); + } + return result; + } } -- Gitblit v1.9.3