From 5fe42ada08e210d6535289fcd3f913be7d3df189 Mon Sep 17 00:00:00 2001 From: wujianwei <wjw@11.com> Date: 星期五, 15 八月 2025 17:25:43 +0800 Subject: [PATCH] 新增字段 --- service/src/main/java/com/ruoyi/cwgl/service/impl/EstimatedReceivableBillServiceImpl.java | 59 ++++++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 54 insertions(+), 5 deletions(-) diff --git a/service/src/main/java/com/ruoyi/cwgl/service/impl/EstimatedReceivableBillServiceImpl.java b/service/src/main/java/com/ruoyi/cwgl/service/impl/EstimatedReceivableBillServiceImpl.java index 516d3e3..45c4a2b 100644 --- a/service/src/main/java/com/ruoyi/cwgl/service/impl/EstimatedReceivableBillServiceImpl.java +++ b/service/src/main/java/com/ruoyi/cwgl/service/impl/EstimatedReceivableBillServiceImpl.java @@ -1,8 +1,11 @@ package com.ruoyi.cwgl.service.impl; +import java.math.BigDecimal; +import java.util.ArrayList; import java.util.Date; import java.util.List; +import com.ruoyi.common.exception.ServiceException; import com.ruoyi.common.utils.DateUtils; import javax.annotation.Resource; @@ -144,6 +147,19 @@ public int updateEstimatedReceivableBill(EstimatedReceivableBill estimatedReceivableBill) { estimatedReceivableBill.setUpdateTime(DateUtils.getNowDate()); + + return estimatedReceivableBillMapper.updateEstimatedReceivableBill(estimatedReceivableBill); + } + + @Override + public int updateEstimatedReceivableBillName(EstimatedReceivableBill estimatedReceivableBill) { + EstimatedReceivableBillLog estimatedReceivableBillLog = new EstimatedReceivableBillLog(); + estimatedReceivableBillLog.setCreateTime(new Date()); + estimatedReceivableBillLog.setBillId(estimatedReceivableBill.getId()); + estimatedReceivableBillLog.setCreateBy(SecurityUtils.getUsername()); + estimatedReceivableBillLog.setOperation("淇敼璐﹀崟鍚嶇О涓�"+estimatedReceivableBill.getBillName()); + logService.insertEstimatedReceivableBillLog(estimatedReceivableBillLog); + pendingSettlementBusinessMapper.updatePendingSettlementBusinessByBillId(estimatedReceivableBill.getId(),estimatedReceivableBill.getBillName()); return estimatedReceivableBillMapper.updateEstimatedReceivableBill(estimatedReceivableBill); } @@ -200,11 +216,11 @@ Integer id = estimatedReceivableBill.getId(); EstimatedReceivableBill oldData = estimatedReceivableBillMapper.selectEstimatedReceivableBillById(id); //搴旂粨绠楅噾棰� - Long totalAmount = oldData.getTotalAmount()==null?0L:oldData.getTotalAmount(); + BigDecimal totalAmount = oldData.getTotalAmount()==null?BigDecimal.ZERO:oldData.getTotalAmount(); //宸茬粨绠楅噾棰� - Long settledAmount = oldData.getSettledAmount()==null?0L:oldData.getSettledAmount(); + BigDecimal settledAmount = oldData.getSettledAmount()==null?BigDecimal.ZERO:oldData.getSettledAmount(); //褰撳墠鎻愪氦閲戦 - Long settlementAmount = estimatedReceivableBill.getSettlementAmount(); + BigDecimal settlementAmount = estimatedReceivableBill.getSettlementAmount(); EstimatedReceivableBillLog estimatedReceivableBillLog = new EstimatedReceivableBillLog(); estimatedReceivableBill.setSettledAmount(settlementAmount); @@ -212,10 +228,16 @@ estimatedReceivableBillLog.setBillId(estimatedReceivableBill.getId()); estimatedReceivableBillLog.setCreateBy(SecurityUtils.getUsername()); estimatedReceivableBillLog.setOperation("鏈鎻愪氦閲戦"+ settlementAmount); + estimatedReceivableBillLog.setFileName(estimatedReceivableBill.getAttachment()); logService.insertEstimatedReceivableBillLog(estimatedReceivableBillLog); - settledAmount = settledAmount+settlementAmount; + settledAmount = settledAmount.add(settlementAmount); List<String>dispatchNos =pendingSettlementBusinessMapper.selectPendingSettlementBusinessDispatchNos(estimatedReceivableBill.getId()); - if (settledAmount>totalAmount){ + // 妫�鏌ュ綋鍓嶆彁浜ら噾棰�+宸茬粨绠楅噾棰濇槸鍚﹁秴杩囧簲缁撶畻閲戦 + if (settlementAmount.add(settledAmount).compareTo(totalAmount) > 0) { + // 瓒呰繃搴旂粨绠楅噾棰濓紝鎶涘嚭寮傚父鎴栧鐞嗛敊璇� + throw new RuntimeException("褰撳墠鎻愪氦閲戦鍔犱笂宸茬粨绠楅噾棰濅笉鑳借秴杩囧簲缁撶畻閲戦"); + } + if (settlementAmount.add(settledAmount).compareTo(totalAmount) == 0) { //宸茬粨绠楀ぇ浜庡簲璁$畻閲戦涓哄凡缁撶畻 estimatedReceivableBill.setStatus(2); estimatedReceivableMapper.updateEstimatedReceivableBillStatus(dispatchNos,3); @@ -226,4 +248,31 @@ } return estimatedReceivableBillMapper.updateEstimatedReceivableBill(estimatedReceivableBill); } + + @Override + public int cancelRelevancy(Integer id) { + PendingSettlementBusiness pendingSettlementBusiness = pendingSettlementBusinessMapper.selectPendingSettlementBusinessById(id); + if (pendingSettlementBusiness==null){ + throw new ServiceException("寰呭叆璐︿笟鍔′笉瀛樺湪"); + } + Integer billId = pendingSettlementBusiness.getBillId(); + EstimatedReceivableBill estimatedReceivableBill = estimatedReceivableBillMapper.selectEstimatedReceivableBillById(billId); + estimatedReceivableBill.setDispatchCount(estimatedReceivableBill.getDispatchCount()-1); + //搴旂粨绠楅噾棰濅慨鏀� + BigDecimal totalAmount = estimatedReceivableBill.getTotalAmount(); + estimatedReceivableBill.setTotalAmount(totalAmount.subtract(pendingSettlementBusiness.getEstimatedTotalIncome())); + EstimatedReceivableBillLog estimatedReceivableBillLog = new EstimatedReceivableBillLog(); + estimatedReceivableBillLog.setCreateTime(new Date()); + estimatedReceivableBillLog.setBillId(billId); + estimatedReceivableBillLog.setCreateBy(SecurityUtils.getUsername()); + String dispatchNo = pendingSettlementBusiness.getDispatchNo(); + estimatedReceivableBillLog.setOperation("鍙栨秷璋冨害鍗�"+ dispatchNo +"鍏宠仈"); + logService.insertEstimatedReceivableBillLog(estimatedReceivableBillLog); + List<String> dispatchNos = new ArrayList<>(); + dispatchNos.add(dispatchNo); + estimatedReceivableMapper.updateEstimatedReceivableBillStatus(dispatchNos,0); + + return pendingSettlementBusinessMapper.cancelRelevancy(id); + + } } -- Gitblit v1.8.0