From 8e39f175ef26827d08904a65b10748e736eeca21 Mon Sep 17 00:00:00 2001 From: liyong <18434998025@163.com> Date: 星期一, 23 六月 2025 10:20:08 +0800 Subject: [PATCH] 2025-06-23 【销售台账】 增加客户合同号、销售合同号、项目名称模糊查询 增加客户名称、客户合同号、项目名称查询,不显示待回款为0,默认为打钩。 销售管理】-【回款流水】,增加合同号、项目名称列查询,增加客户名称、项目名称、合同号查询条件。 【销售管理】-【回款登记】,增加导出功能 --- src/main/java/com/ruoyi/sales/service/impl/ReceiptPaymentServiceImpl.java | 102 ++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 97 insertions(+), 5 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 16cc5e9..01a72b8 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.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.mapper.ReceiptPaymentMapper; @@ -16,13 +18,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.HashMap; -import java.util.List; -import java.util.Map; -import java.util.Objects; +import java.util.*; +import java.util.stream.Collectors; @Service public class ReceiptPaymentServiceImpl extends ServiceImpl<ReceiptPaymentMapper,ReceiptPayment> implements ReceiptPaymentService { @@ -135,7 +136,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; } /** @@ -177,4 +182,91 @@ result.put("contractAmount", contractAmount); return result; } + + /** + * 鏌ヨ鍥炴璁板綍 + */ + @Override + 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, ArrayList<Long> ids) { + List<ReceiptPaymentDto> receiptPaymentDtoList = receiptPaymentMapper.bindInvoiceNoRegListByIds(ids); + ExcelUtil<ReceiptPaymentDto> util = new ExcelUtil<ReceiptPaymentDto>(ReceiptPaymentDto.class); + util.exportExcel(response, receiptPaymentDtoList, "鍥炴鐧昏"); + } } -- Gitblit v1.9.3