| | |
| | | package com.ruoyi.sales.service.impl; |
| | | |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | | import com.baomidou.mybatisplus.core.mapper.BaseMapper; |
| | | import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; |
| | | import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
| | |
| | | import com.ruoyi.common.utils.StringUtils; |
| | | import com.ruoyi.other.mapper.TempFileMapper; |
| | | import com.ruoyi.other.pojo.TempFile; |
| | | import com.ruoyi.sales.dto.MonthlyAmountDto; |
| | | import com.ruoyi.sales.dto.SalesLedgerDto; |
| | | import com.ruoyi.sales.mapper.CommonFileMapper; |
| | | import com.ruoyi.sales.mapper.InvoiceRegistrationProductMapper; |
| | | import com.ruoyi.sales.mapper.SalesLedgerMapper; |
| | | import com.ruoyi.sales.mapper.SalesLedgerProductMapper; |
| | | import com.ruoyi.sales.pojo.CommonFile; |
| | | import com.ruoyi.sales.pojo.InvoiceRegistrationProduct; |
| | | import com.ruoyi.sales.pojo.SalesLedger; |
| | | import com.ruoyi.sales.pojo.SalesLedgerProduct; |
| | | import com.ruoyi.sales.mapper.*; |
| | | import com.ruoyi.sales.pojo.*; |
| | | import com.ruoyi.sales.service.ISalesLedgerService; |
| | | import lombok.RequiredArgsConstructor; |
| | | import lombok.extern.slf4j.Slf4j; |
| | |
| | | import org.springframework.data.redis.core.script.DefaultRedisScript; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import org.springframework.util.ObjectUtils; |
| | | |
| | | import java.io.IOException; |
| | | import java.lang.reflect.Field; |
| | |
| | | private final CommonFileMapper commonFileMapper; |
| | | |
| | | private final TempFileMapper tempFileMapper; |
| | | |
| | | private final ReceiptPaymentMapper receiptPaymentMapper; |
| | | |
| | | private final InvoiceLedgerMapper invoiceLedgerMapper; |
| | | |
| | | @Autowired |
| | | private InvoiceRegistrationProductMapper invoiceRegistrationProductMapper; |
| | |
| | | |
| | | @Override |
| | | public List getTopFiveList() { |
| | | |
| | | return null; |
| | | // 查询原始数据 |
| | | LambdaQueryWrapper<SalesLedger> queryWrapper = Wrappers.lambdaQuery(); |
| | | queryWrapper.select(SalesLedger::getCustomerId, |
| | | SalesLedger::getCustomerName, |
| | | SalesLedger::getContractAmount) |
| | | .orderByDesc(SalesLedger::getContractAmount); |
| | | List<SalesLedger> records = salesLedgerMapper.selectList(queryWrapper); |
| | | |
| | | // 按客户ID分组并聚合金额 |
| | | Map<Long, GroupedCustomer> groupedMap = new LinkedHashMap<>(); // 使用LinkedHashMap保持排序 |
| | | for (SalesLedger record : records) { |
| | | groupedMap.computeIfAbsent(record.getCustomerId(), |
| | | k -> new GroupedCustomer(record.getCustomerId(), record.getCustomerName())) |
| | | .addAmount(record.getContractAmount()); |
| | | } |
| | | |
| | | // 转换为结果列表并取前5 |
| | | return groupedMap.values().stream() |
| | | .sorted(Comparator.comparing(GroupedCustomer::getTotalAmount).reversed()) |
| | | .limit(5) |
| | | .map(customer -> { |
| | | Map<String, Object> result = new HashMap<>(); |
| | | result.put("customerId", customer.getCustomerId()); |
| | | result.put("customerName", customer.getCustomerName()); |
| | | result.put("totalAmount", customer.getTotalAmount()); |
| | | return result; |
| | | }) |
| | | .collect(Collectors.toList()); |
| | | } |
| | | |
| | | @Override |
| | | public List<MonthlyAmountDto> getAmountHalfYear() { |
| | | LocalDate now = LocalDate.now(); |
| | | YearMonth currentMonth = YearMonth.from(now); |
| | | |
| | | List<MonthlyAmountDto> monthlyAmounts = new ArrayList<>(); |
| | | |
| | | for (int i = 0; i < 6; i++) { |
| | | YearMonth targetMonth = currentMonth.minusMonths(i); |
| | | LocalDate firstDayOfMonth = targetMonth.atDay(1); |
| | | LocalDate firstDayOfNextMonth = targetMonth.plusMonths(1).atDay(1); |
| | | |
| | | LocalDateTime startOfMonth = firstDayOfMonth.atStartOfDay(); |
| | | LocalDateTime startOfNextMonth = firstDayOfNextMonth.atStartOfDay(); |
| | | |
| | | LambdaQueryWrapper<ReceiptPayment> receiptPaymentLambdaQueryWrapper = new LambdaQueryWrapper<>(); |
| | | receiptPaymentLambdaQueryWrapper.ge(ReceiptPayment::getCreateTime, startOfMonth) |
| | | .lt(ReceiptPayment::getCreateTime, startOfNextMonth); |
| | | |
| | | LambdaQueryWrapper<InvoiceLedger> invoiceLedgerLambdaQueryWrapper = new LambdaQueryWrapper<>(); |
| | | invoiceLedgerLambdaQueryWrapper.ge(InvoiceLedger::getCreateTime, startOfMonth) |
| | | .lt(InvoiceLedger::getCreateTime, startOfNextMonth); |
| | | |
| | | // 获取回款金额 |
| | | List<ReceiptPayment> receiptPaymentList = receiptPaymentMapper.selectList(receiptPaymentLambdaQueryWrapper); |
| | | //开票金额 |
| | | List<InvoiceLedger> invoiceLedgerList = invoiceLedgerMapper.selectList(invoiceLedgerLambdaQueryWrapper); |
| | | |
| | | // 使用 Stream 求和 |
| | | BigDecimal invoiceAmount = invoiceLedgerList.stream() |
| | | .map(InvoiceLedger::getInvoiceTotal) |
| | | .filter(Objects::nonNull) |
| | | .reduce(BigDecimal.ZERO, BigDecimal::add); |
| | | |
| | | BigDecimal receiptAmount = receiptPaymentList.stream() |
| | | .map(ReceiptPayment::getReceiptPaymentAmount) |
| | | .filter(Objects::nonNull) |
| | | .reduce(BigDecimal.ZERO, BigDecimal::add); |
| | | |
| | | MonthlyAmountDto monthlyAmount = new MonthlyAmountDto(); |
| | | monthlyAmount.setMonth(targetMonth.format(DateTimeFormatter.ofPattern("yyyy-MM"))); |
| | | monthlyAmount.setInvoiceAmount(invoiceAmount); |
| | | monthlyAmount.setReceiptAmount(receiptAmount); |
| | | |
| | | monthlyAmounts.add(monthlyAmount); |
| | | } |
| | | |
| | | return monthlyAmounts; |
| | | } |
| | | |
| | | // 内部类用于存储聚合结果 |
| | | private static class GroupedCustomer { |
| | | private final Long customerId; |
| | | private final String customerName; |
| | | private BigDecimal totalAmount = BigDecimal.ZERO; |
| | | |
| | | public GroupedCustomer(Long customerId, String customerName) { |
| | | this.customerId = customerId; |
| | | this.customerName = customerName; |
| | | } |
| | | |
| | | public void addAmount(BigDecimal amount) { |
| | | if (amount != null) { |
| | | this.totalAmount = this.totalAmount.add(amount); |
| | | } |
| | | } |
| | | |
| | | public Long getCustomerId() { |
| | | return customerId; |
| | | } |
| | | |
| | | public String getCustomerName() { |
| | | return customerName; |
| | | } |
| | | |
| | | public BigDecimal getTotalAmount() { |
| | | return totalAmount; |
| | | } |
| | | } |
| | | |
| | | /** |