update - 处理加签或转交的事件问题
This commit is contained in:
parent
7ad2c0090f
commit
b2ac834a9f
@ -590,6 +590,7 @@ public class BpmnProcessTaskServiceImpl implements BpmnProcessTaskService {
|
|||||||
.filter(i -> Objects.equals(COMMENT_TYPE_OPERATION_COUNTERSIGN, i.getType())).findFirst();
|
.filter(i -> Objects.equals(COMMENT_TYPE_OPERATION_COUNTERSIGN, i.getType())).findFirst();
|
||||||
operation.ifPresent(i -> {
|
operation.ifPresent(i -> {
|
||||||
vo.setOperationDesc(i.getFullMessage());
|
vo.setOperationDesc(i.getFullMessage());
|
||||||
|
vo.setEndTime(i.getTime());
|
||||||
vo.setResult(COUNTERSIGN);
|
vo.setResult(COUNTERSIGN);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -599,6 +600,7 @@ public class BpmnProcessTaskServiceImpl implements BpmnProcessTaskService {
|
|||||||
.filter(i -> Objects.equals(COMMENT_TYPE_OPERATION_TRANSFER, i.getType())).findFirst();
|
.filter(i -> Objects.equals(COMMENT_TYPE_OPERATION_TRANSFER, i.getType())).findFirst();
|
||||||
transfer.ifPresent(i -> {
|
transfer.ifPresent(i -> {
|
||||||
vo.setOperationDesc(i.getFullMessage());
|
vo.setOperationDesc(i.getFullMessage());
|
||||||
|
vo.setEndTime(i.getTime());
|
||||||
vo.setResult(TRANSFER);
|
vo.setResult(TRANSFER);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -718,14 +720,13 @@ public class BpmnProcessTaskServiceImpl implements BpmnProcessTaskService {
|
|||||||
((TaskEntity) task).setScopeType("TRANSFER");
|
((TaskEntity) task).setScopeType("TRANSFER");
|
||||||
taskService.saveTask(task);
|
taskService.saveTask(task);
|
||||||
|
|
||||||
|
Authentication.setAuthenticatedUserId(dto.getOriginAssigner().buildAssigneeId());
|
||||||
taskService.addComment(task.getId(), task.getProcessInstanceId(), COMMENT_TYPE_OPERATION_TRANSFER,
|
taskService.addComment(task.getId(), task.getProcessInstanceId(), COMMENT_TYPE_OPERATION_TRANSFER,
|
||||||
"转交给 " + dto.getTargetAssigner().getAssignerName());
|
"转交给 " + dto.getTargetAssigner().getAssignerName());
|
||||||
|
|
||||||
if (StringUtils.hasLength(dto.getAdvice())) {
|
if (StringUtils.hasLength(dto.getAdvice())) {
|
||||||
Authentication.setAuthenticatedUserId(dto.getOriginAssigner().buildAssigneeId());
|
|
||||||
taskService.addComment(dto.getTaskId(), task.getProcessInstanceId(), COMMENT_TYPE_ADVICE, dto.getAdvice());
|
taskService.addComment(dto.getTaskId(), task.getProcessInstanceId(), COMMENT_TYPE_ADVICE, dto.getAdvice());
|
||||||
Authentication.setAuthenticatedUserId(null);
|
|
||||||
}
|
}
|
||||||
|
Authentication.setAuthenticatedUserId(null);
|
||||||
|
|
||||||
List<BpmnTaskDelegateAssigner> originAssingeeList = runtimeService.getVariable(task.getProcessInstanceId(),
|
List<BpmnTaskDelegateAssigner> originAssingeeList = runtimeService.getVariable(task.getProcessInstanceId(),
|
||||||
INTERNAL_ACTIVITY_RELATION_ASSIGNEE_LIST_INFO_SNAPSHOT + task.getTaskDefinitionKey(), List.class);
|
INTERNAL_ACTIVITY_RELATION_ASSIGNEE_LIST_INFO_SNAPSHOT + task.getTaskDefinitionKey(), List.class);
|
||||||
|
|||||||
@ -4,12 +4,9 @@ import cn.axzo.workflow.common.model.request.bpmn.task.BpmnTaskDelegateAssigner;
|
|||||||
import cn.axzo.workflow.core.listener.BpmnTaskEventListener;
|
import cn.axzo.workflow.core.listener.BpmnTaskEventListener;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.flowable.engine.RuntimeService;
|
import org.flowable.engine.RuntimeService;
|
||||||
import org.flowable.engine.TaskService;
|
|
||||||
import org.flowable.engine.impl.util.CommandContextUtil;
|
|
||||||
import org.flowable.task.service.delegate.DelegateTask;
|
import org.flowable.task.service.delegate.DelegateTask;
|
||||||
import org.springframework.core.Ordered;
|
import org.springframework.core.Ordered;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
import org.springframework.util.CollectionUtils;
|
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -40,17 +37,6 @@ public class SnapshotBpmnTaskTaskEventListener implements BpmnTaskEventListener,
|
|||||||
List<BpmnTaskDelegateAssigner> assignerList = runtimeService.getVariable(delegateTask.getProcessInstanceId(),
|
List<BpmnTaskDelegateAssigner> assignerList = runtimeService.getVariable(delegateTask.getProcessInstanceId(),
|
||||||
INTERNAL_ACTIVITY_RELATION_ASSIGNEE_LIST_INFO_SNAPSHOT + delegateTask.getTaskDefinitionKey(),
|
INTERNAL_ACTIVITY_RELATION_ASSIGNEE_LIST_INFO_SNAPSHOT + delegateTask.getTaskDefinitionKey(),
|
||||||
List.class);
|
List.class);
|
||||||
if (CollectionUtils.isEmpty(assignerList)) {
|
|
||||||
// 加签
|
|
||||||
TaskService taskService = CommandContextUtil.getProcessEngineConfiguration().getTaskService();
|
|
||||||
BpmnTaskDelegateAssigner assigner = taskService.getVariable(delegateTask.getId(),
|
|
||||||
INTERNAL_TASK_RELATION_ASSIGNEE_INFO, BpmnTaskDelegateAssigner.class);
|
|
||||||
if (Objects.isNull(assigner)) {
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
assignerList.add(assigner);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// identityId_identityType
|
// identityId_identityType
|
||||||
assignerList.stream().filter(i -> Objects.equals(delegateTask.getAssignee(), i.buildAssigneeId())).findFirst().ifPresent(i -> {
|
assignerList.stream().filter(i -> Objects.equals(delegateTask.getAssignee(), i.buildAssigneeId())).findFirst().ifPresent(i -> {
|
||||||
// 保存每个 taskId 的审批人
|
// 保存每个 taskId 的审批人
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user