|
@@ -18,8 +18,17 @@ import com.java110.po.oaWorkflowData.OaWorkflowDataPo;
|
|
|
import com.java110.utils.util.Assert;
|
|
import com.java110.utils.util.Assert;
|
|
|
import com.java110.utils.util.DateUtil;
|
|
import com.java110.utils.util.DateUtil;
|
|
|
import com.java110.utils.util.StringUtil;
|
|
import com.java110.utils.util.StringUtil;
|
|
|
-import org.activiti.bpmn.model.*;
|
|
|
|
|
-import org.activiti.engine.*;
|
|
|
|
|
|
|
+import org.activiti.bpmn.model.BpmnModel;
|
|
|
|
|
+import org.activiti.bpmn.model.EndEvent;
|
|
|
|
|
+import org.activiti.bpmn.model.FlowElement;
|
|
|
|
|
+import org.activiti.bpmn.model.FlowNode;
|
|
|
|
|
+import org.activiti.bpmn.model.SequenceFlow;
|
|
|
|
|
+import org.activiti.bpmn.model.UserTask;
|
|
|
|
|
+import org.activiti.engine.HistoryService;
|
|
|
|
|
+import org.activiti.engine.ProcessEngine;
|
|
|
|
|
+import org.activiti.engine.RepositoryService;
|
|
|
|
|
+import org.activiti.engine.RuntimeService;
|
|
|
|
|
+import org.activiti.engine.TaskService;
|
|
|
import org.activiti.engine.history.HistoricProcessInstance;
|
|
import org.activiti.engine.history.HistoricProcessInstance;
|
|
|
import org.activiti.engine.history.HistoricTaskInstance;
|
|
import org.activiti.engine.history.HistoricTaskInstance;
|
|
|
import org.activiti.engine.history.HistoricTaskInstanceQuery;
|
|
import org.activiti.engine.history.HistoricTaskInstanceQuery;
|
|
@@ -306,7 +315,7 @@ public class OaWorkflowUserInnerServiceSMOImpl extends BaseServiceSMO implements
|
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
|
oaWorkflowDataPo.setBusinessKey(reqJson.getString("id"));
|
|
oaWorkflowDataPo.setBusinessKey(reqJson.getString("id"));
|
|
|
oaWorkflowDataPo.setFlowId(reqJson.getString("flowId"));
|
|
oaWorkflowDataPo.setFlowId(reqJson.getString("flowId"));
|
|
|
- oaWorkflowDataPo.setContext(reqJson.getString("auditMessage"));
|
|
|
|
|
|
|
+ oaWorkflowDataPo.setContext("");
|
|
|
oaWorkflowDataPo.setDataId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_dataId));
|
|
oaWorkflowDataPo.setDataId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_dataId));
|
|
|
oaWorkflowDataPo.setEvent(OaWorkflowDataDto.EVENT_COMMIT);
|
|
oaWorkflowDataPo.setEvent(OaWorkflowDataDto.EVENT_COMMIT);
|
|
|
oaWorkflowDataPo.setPreDataId(preDataId);
|
|
oaWorkflowDataPo.setPreDataId(preDataId);
|
|
@@ -321,6 +330,7 @@ public class OaWorkflowUserInnerServiceSMOImpl extends BaseServiceSMO implements
|
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
|
oaWorkflowDataPo.setDataId(oaWorkflowDataDtos.get(0).getDataId());
|
|
oaWorkflowDataPo.setDataId(oaWorkflowDataDtos.get(0).getDataId());
|
|
|
oaWorkflowDataPo.setEndTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
|
|
oaWorkflowDataPo.setEndTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
|
|
|
|
|
+ oaWorkflowDataPo.setContext(reqJson.getString("auditMessage"));
|
|
|
oaWorkflowDataInnerServiceSMOImpl.updateOaWorkflowData(oaWorkflowDataPo);
|
|
oaWorkflowDataInnerServiceSMOImpl.updateOaWorkflowData(oaWorkflowDataPo);
|
|
|
|
|
|
|
|
//如果为-1 不插入任务
|
|
//如果为-1 不插入任务
|
|
@@ -331,7 +341,7 @@ public class OaWorkflowUserInnerServiceSMOImpl extends BaseServiceSMO implements
|
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
|
oaWorkflowDataPo.setBusinessKey(reqJson.getString("id"));
|
|
oaWorkflowDataPo.setBusinessKey(reqJson.getString("id"));
|
|
|
oaWorkflowDataPo.setFlowId(reqJson.getString("flowId"));
|
|
oaWorkflowDataPo.setFlowId(reqJson.getString("flowId"));
|
|
|
- oaWorkflowDataPo.setContext(reqJson.getString("auditMessage"));
|
|
|
|
|
|
|
+ oaWorkflowDataPo.setContext("");
|
|
|
oaWorkflowDataPo.setDataId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_dataId));
|
|
oaWorkflowDataPo.setDataId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_dataId));
|
|
|
oaWorkflowDataPo.setEvent(OaWorkflowDataDto.EVENT_COMMIT);
|
|
oaWorkflowDataPo.setEvent(OaWorkflowDataDto.EVENT_COMMIT);
|
|
|
oaWorkflowDataPo.setPreDataId(oaWorkflowDataDtos.get(0).getDataId());
|
|
oaWorkflowDataPo.setPreDataId(oaWorkflowDataDtos.get(0).getDataId());
|
|
@@ -378,12 +388,13 @@ public class OaWorkflowUserInnerServiceSMOImpl extends BaseServiceSMO implements
|
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
|
oaWorkflowDataPo.setDataId(oaWorkflowDataDtos.get(0).getDataId());
|
|
oaWorkflowDataPo.setDataId(oaWorkflowDataDtos.get(0).getDataId());
|
|
|
oaWorkflowDataPo.setEndTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
|
|
oaWorkflowDataPo.setEndTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
|
|
|
|
|
+ oaWorkflowDataPo.setContext(reqJson.getString("auditMessage"));
|
|
|
oaWorkflowDataInnerServiceSMOImpl.updateOaWorkflowData(oaWorkflowDataPo);
|
|
oaWorkflowDataInnerServiceSMOImpl.updateOaWorkflowData(oaWorkflowDataPo);
|
|
|
|
|
|
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
|
oaWorkflowDataPo.setBusinessKey(reqJson.getString("id"));
|
|
oaWorkflowDataPo.setBusinessKey(reqJson.getString("id"));
|
|
|
oaWorkflowDataPo.setFlowId(reqJson.getString("flowId"));
|
|
oaWorkflowDataPo.setFlowId(reqJson.getString("flowId"));
|
|
|
- oaWorkflowDataPo.setContext(reqJson.getString("auditMessage"));
|
|
|
|
|
|
|
+ oaWorkflowDataPo.setContext("");
|
|
|
oaWorkflowDataPo.setDataId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_dataId));
|
|
oaWorkflowDataPo.setDataId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_dataId));
|
|
|
oaWorkflowDataPo.setEvent(OaWorkflowDataDto.EVENT_TRANSFER);
|
|
oaWorkflowDataPo.setEvent(OaWorkflowDataDto.EVENT_TRANSFER);
|
|
|
oaWorkflowDataPo.setPreDataId(oaWorkflowDataDtos.get(0).getDataId());
|
|
oaWorkflowDataPo.setPreDataId(oaWorkflowDataDtos.get(0).getDataId());
|
|
@@ -448,6 +459,7 @@ public class OaWorkflowUserInnerServiceSMOImpl extends BaseServiceSMO implements
|
|
|
OaWorkflowDataPo oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
OaWorkflowDataPo oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
|
oaWorkflowDataPo.setDataId(oaWorkflowDataDtos.get(0).getDataId());
|
|
oaWorkflowDataPo.setDataId(oaWorkflowDataDtos.get(0).getDataId());
|
|
|
oaWorkflowDataPo.setEndTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
|
|
oaWorkflowDataPo.setEndTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
|
|
|
|
|
+ oaWorkflowDataPo.setContext(reqJson.getString("auditMessage"));
|
|
|
oaWorkflowDataInnerServiceSMOImpl.updateOaWorkflowData(oaWorkflowDataPo);
|
|
oaWorkflowDataInnerServiceSMOImpl.updateOaWorkflowData(oaWorkflowDataPo);
|
|
|
|
|
|
|
|
reqJson.put("nextUserId", preOaWorkflowDataDtos.get(0).getStaffId());
|
|
reqJson.put("nextUserId", preOaWorkflowDataDtos.get(0).getStaffId());
|
|
@@ -457,7 +469,7 @@ public class OaWorkflowUserInnerServiceSMOImpl extends BaseServiceSMO implements
|
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
oaWorkflowDataPo = new OaWorkflowDataPo();
|
|
|
oaWorkflowDataPo.setBusinessKey(preOaWorkflowDataDtos.get(0).getBusinessKey());
|
|
oaWorkflowDataPo.setBusinessKey(preOaWorkflowDataDtos.get(0).getBusinessKey());
|
|
|
oaWorkflowDataPo.setFlowId(preOaWorkflowDataDtos.get(0).getFlowId());
|
|
oaWorkflowDataPo.setFlowId(preOaWorkflowDataDtos.get(0).getFlowId());
|
|
|
- oaWorkflowDataPo.setContext(reqJson.getString("auditMessage"));
|
|
|
|
|
|
|
+ oaWorkflowDataPo.setContext("");
|
|
|
oaWorkflowDataPo.setDataId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_dataId));
|
|
oaWorkflowDataPo.setDataId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_dataId));
|
|
|
oaWorkflowDataPo.setEvent(preOaWorkflowDataDtos.get(0).getEvent());
|
|
oaWorkflowDataPo.setEvent(preOaWorkflowDataDtos.get(0).getEvent());
|
|
|
oaWorkflowDataPo.setPreDataId(oaWorkflowDataDtos.get(0).getPreDataId());
|
|
oaWorkflowDataPo.setPreDataId(oaWorkflowDataDtos.get(0).getPreDataId());
|
|
@@ -550,10 +562,12 @@ public class OaWorkflowUserInnerServiceSMOImpl extends BaseServiceSMO implements
|
|
|
List<SequenceFlow> outgoingFlows = flowNode.getOutgoingFlows();
|
|
List<SequenceFlow> outgoingFlows = flowNode.getOutgoingFlows();
|
|
|
JSONObject taskObj = null;
|
|
JSONObject taskObj = null;
|
|
|
taskObj = new JSONObject();
|
|
taskObj = new JSONObject();
|
|
|
|
|
+ boolean isReturn = false;
|
|
|
//遍历输出连线
|
|
//遍历输出连线
|
|
|
for (SequenceFlow outgoingFlow : outgoingFlows) {
|
|
for (SequenceFlow outgoingFlow : outgoingFlows) {
|
|
|
//获取输出节点元素
|
|
//获取输出节点元素
|
|
|
FlowElement targetFlowElement = outgoingFlow.getTargetFlowElement();
|
|
FlowElement targetFlowElement = outgoingFlow.getTargetFlowElement();
|
|
|
|
|
+ isReturn = false;
|
|
|
//排除非用户任务接点
|
|
//排除非用户任务接点
|
|
|
if (targetFlowElement instanceof UserTask) {
|
|
if (targetFlowElement instanceof UserTask) {
|
|
|
//判断输出节点的el表达式
|
|
//判断输出节点的el表达式
|
|
@@ -562,16 +576,17 @@ public class OaWorkflowUserInnerServiceSMOImpl extends BaseServiceSMO implements
|
|
|
if (isCondition(outgoingFlow.getConditionExpression(), vars)) {
|
|
if (isCondition(outgoingFlow.getConditionExpression(), vars)) {
|
|
|
//true 获取输出节点名称
|
|
//true 获取输出节点名称
|
|
|
taskObj.put("back", outgoingFlow.getTargetFlowElement().getName());
|
|
taskObj.put("back", outgoingFlow.getTargetFlowElement().getName());
|
|
|
|
|
+ isReturn = true;
|
|
|
}
|
|
}
|
|
|
vars.put("auditCode", "1400");
|
|
vars.put("auditCode", "1400");
|
|
|
if (isCondition(outgoingFlow.getConditionExpression(), vars)) {
|
|
if (isCondition(outgoingFlow.getConditionExpression(), vars)) {
|
|
|
//true 获取输出节点名称
|
|
//true 获取输出节点名称
|
|
|
taskObj.put("backIndex", outgoingFlow.getTargetFlowElement().getName());
|
|
taskObj.put("backIndex", outgoingFlow.getTargetFlowElement().getName());
|
|
|
|
|
+ isReturn = true;
|
|
|
}
|
|
}
|
|
|
- vars.put("auditCode", "1100");
|
|
|
|
|
- if (isCondition(outgoingFlow.getConditionExpression(), vars)) {
|
|
|
|
|
|
|
+ if (!isReturn) {
|
|
|
String assignee = ((UserTask) targetFlowElement).getAssignee();
|
|
String assignee = ((UserTask) targetFlowElement).getAssignee();
|
|
|
- if (!StringUtil.isEmpty(assignee) && assignee.indexOf("${") < -1) {
|
|
|
|
|
|
|
+ if (!StringUtil.isEmpty(assignee) && assignee.indexOf("${") < 0) {
|
|
|
taskObj.put("assignee", assignee); // 下一节点处理人
|
|
taskObj.put("assignee", assignee); // 下一节点处理人
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|