package com.ruoyi.account.service.impl.purchase; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.github.xiaoymin.knife4j.core.util.CollectionUtils; import com.ruoyi.account.bean.dto.purchase.AccountPurchasePaymentDto; import com.ruoyi.account.bean.vo.purchase.AccountPurchasePaymentVo; import com.ruoyi.account.mapper.AccountStatementDetailsMapper; import com.ruoyi.account.mapper.purchase.AccountPaymentApplicationMapper; import com.ruoyi.account.mapper.purchase.AccountPurchasePaymentMapper; import com.ruoyi.account.pojo.AccountStatementDetails; import com.ruoyi.account.pojo.purchase.AccountPaymentApplication; import com.ruoyi.account.pojo.purchase.AccountPurchasePayment; import com.ruoyi.account.service.purchase.AccountPurchasePaymentService; import com.ruoyi.common.exception.ServiceException; import com.ruoyi.common.utils.StringUtils; import com.ruoyi.common.utils.poi.ExcelUtil; import jakarta.servlet.http.HttpServletResponse; import lombok.RequiredArgsConstructor; import org.springframework.stereotype.Service; import java.math.BigDecimal; import java.time.LocalDateTime; import java.time.format.DateTimeFormatter; import java.util.List; import java.util.Random; /** *

* 财务管理--付款单 服务实现类 *

* * @author 芯导软件(江苏)有限公司 * @since 2026-05-19 04:14:51 */ @Service @RequiredArgsConstructor public class AccountPurchasePaymentServiceImpl extends ServiceImpl implements AccountPurchasePaymentService { private static final DateTimeFormatter CODE_TIME_FORMATTER = DateTimeFormatter.ofPattern("yyMMddHHmmss"); private final AccountPurchasePaymentMapper accountPurchasePaymentMapper; private final AccountStatementDetailsMapper accountStatementDetailsMapper; private final AccountPaymentApplicationMapper accountPaymentApplicationMapper; @Override public IPage listPageAccountPurchasePayment(Page page, AccountPurchasePaymentDto accountPurchasePaymentDto) { return accountPurchasePaymentMapper.listPageAccountPurchasePayment(page, accountPurchasePaymentDto); } @Override public boolean addAccountPurchasePayment(AccountPurchasePayment accountPurchasePayment) { if (StringUtils.isEmpty(accountPurchasePayment.getPaymentNumber())) { accountPurchasePayment.setPaymentNumber(genAccountPurchasePaymentNo()); } //校验累计付款金额不能超过申请金额 AccountPaymentApplication accountPaymentApplication = accountPaymentApplicationMapper.selectById(accountPurchasePayment.getAccountPaymentApplicationId()); List accountPurchasePayments = accountPurchasePaymentMapper.selectList(Wrappers.lambdaQuery().eq(AccountPurchasePayment::getAccountPaymentApplicationId, accountPurchasePayment.getAccountPaymentApplicationId())); BigDecimal totalPaymentAmount = accountPurchasePayments.stream().map(AccountPurchasePayment::getPaymentAmount).reduce(BigDecimal.ZERO, BigDecimal::add); if (accountPaymentApplication.getPaymentAmount().compareTo(totalPaymentAmount) < 0) { throw new ServiceException("累计付款金额不能超过申请金额"); } return save(accountPurchasePayment); } @Override public void exportAccountPurchasePayment(HttpServletResponse response, AccountPurchasePaymentDto accountPurchasePaymentDto) { List list = accountPurchasePaymentMapper.listPageAccountPurchasePayment(new Page(1,-1),accountPurchasePaymentDto).getRecords(); ExcelUtil util = new ExcelUtil<>(AccountPurchasePaymentVo.class); util.exportExcel(response, list , "付款单"); } @Override public boolean deleteAccountPurchasePayment(List ids) { //如果该付款单已经生成对账单则无法删除 List accountPurchasePayments = accountPurchasePaymentMapper.selectByIds(ids); List strings = accountPurchasePayments.stream().map(AccountPurchasePayment::getPaymentNumber).toList(); List accountStatementDetails = accountStatementDetailsMapper.selectList(Wrappers.lambdaQuery() .in(AccountStatementDetails::getReceiptNumber, strings)); if (CollectionUtils.isNotEmpty(accountStatementDetails)){ throw new ServiceException("该付款单已经生成对账单,无法删除"); } return removeByIds(ids); } private String genAccountPurchasePaymentNo() { return "SK" + LocalDateTime.now().format(CODE_TIME_FORMATTER) + new Random().nextInt(10); } }