From 1c518e10a50050d383e714b581c94dea58ec4d67 Mon Sep 17 00:00:00 2001
From: liyong <18434998025@163.com>
Date: 星期五, 22 五月 2026 18:01:34 +0800
Subject: [PATCH] fix(approve): 修复审批实例查询条件及流程控制问题
---
src/main/java/com/ruoyi/approve/service/impl/FinReimbursementServiceImpl.java | 15 +++++++++++----
1 files changed, 11 insertions(+), 4 deletions(-)
diff --git a/src/main/java/com/ruoyi/approve/service/impl/FinReimbursementServiceImpl.java b/src/main/java/com/ruoyi/approve/service/impl/FinReimbursementServiceImpl.java
index a69bb76..1861d83 100644
--- a/src/main/java/com/ruoyi/approve/service/impl/FinReimbursementServiceImpl.java
+++ b/src/main/java/com/ruoyi/approve/service/impl/FinReimbursementServiceImpl.java
@@ -199,7 +199,7 @@
}
}
- resetApprovalFlow(existing.getApprovalInstanceId(), reimbursementId);
+ resetApprovalFlow(existing, reimbursementId);
if (BILL_STATUS_IN_APPROVAL.equals(billStatus)) {
reimbursement.setApprovalInstanceId(null);
startApproval(reimbursement, finReimbursementDto);
@@ -498,11 +498,18 @@
sysNoticeService.simpleNoticeByUser(title, message, approverIds, jumpPath);
}
- private void resetApprovalFlow(Long approvalInstanceId, Long reimbursementId) {
- if (approvalInstanceId == null) {
+ private void resetApprovalFlow(FinReimbursement existing, Long reimbursementId) {
+ if (existing == null || existing.getApprovalInstanceId() == null) {
return;
}
- approvalInstanceService.delete(Collections.singletonList(approvalInstanceId));
+ Long approvalInstanceId = existing.getApprovalInstanceId();
+ if (!"REJECTED".equals(existing.getBillStatus())) {
+ approvalInstanceService.delete(Collections.singletonList(approvalInstanceId));
+ }
+ clearApprovalBinding(reimbursementId);
+ }
+
+ private void clearApprovalBinding(Long reimbursementId) {
int rows = finReimbursementMapper.update(
null,
Wrappers.<FinReimbursement>lambdaUpdate()
--
Gitblit v1.9.3