|
|
@@ -0,0 +1,123 @@
|
|
|
+package com.xjrsoft.module.liteflow.node;
|
|
|
+
|
|
|
+import cn.hutool.core.convert.Convert;
|
|
|
+import cn.hutool.db.Entity;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
+import com.xjrsoft.common.enums.ArchivesStatusEnum;
|
|
|
+import com.xjrsoft.common.enums.DeleteMark;
|
|
|
+import com.xjrsoft.common.enums.StudentChangeTypeEnum;
|
|
|
+import com.xjrsoft.common.enums.WorkflowApproveType;
|
|
|
+import com.xjrsoft.common.mybatis.SqlRunnerAdapter;
|
|
|
+import com.xjrsoft.module.student.entity.BaseStudentSchoolRoll;
|
|
|
+import com.xjrsoft.module.student.service.IBaseStudentSchoolRollService;
|
|
|
+import com.xjrsoft.module.student.service.IStudentChangeRecordService;
|
|
|
+import com.xjrsoft.module.workflow.entity.WorkflowRecord;
|
|
|
+import com.xjrsoft.module.workflow.mapper.WorkflowRecordMapper;
|
|
|
+import com.xjrsoft.module.workflow.service.IWorkflowExecuteService;
|
|
|
+import com.yomahub.liteflow.core.NodeComponent;
|
|
|
+import org.apache.commons.lang.StringUtils;
|
|
|
+import org.camunda.bpm.engine.history.HistoricProcessInstance;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.stereotype.Component;
|
|
|
+import org.springframework.transaction.support.TransactionSynchronization;
|
|
|
+import org.springframework.transaction.support.TransactionSynchronizationManager;
|
|
|
+
|
|
|
+import java.util.List;
|
|
|
+import java.util.Map;
|
|
|
+import java.util.Optional;
|
|
|
+import java.util.concurrent.CompletableFuture;
|
|
|
+
|
|
|
+/**
|
|
|
+ * 学生复学
|
|
|
+ */
|
|
|
+@Component("student_resume_schooling_node")
|
|
|
+public class StudentResumeSchoolingNode extends NodeComponent {
|
|
|
+ @Autowired
|
|
|
+ private IBaseStudentSchoolRollService studentSchoolRollService;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IWorkflowExecuteService workflowExecuteService;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private WorkflowRecordMapper workflowRecordMapper;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IStudentChangeRecordService changeRecordService;
|
|
|
+
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void process() throws Exception {
|
|
|
+ // 获取表单中数据编号
|
|
|
+ Map<String, Object> params = this.getFirstContextBean();
|
|
|
+ Object value = util.getFormDatKey(params, "id");
|
|
|
+ Long formId = Convert.toLong(value);
|
|
|
+ Object processInstanceId = params.get("processInstanceId");
|
|
|
+ if (processInstanceId == null) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ String processInstanceIdStr = Convert.toStr(processInstanceId);
|
|
|
+ if (formId != null && StringUtils.isNotEmpty(processInstanceIdStr)) {
|
|
|
+ TransactionSynchronizationManager.registerSynchronization(new TransactionSynchronization() {
|
|
|
+ @Override
|
|
|
+ public void afterCommit() {
|
|
|
+ CompletableFuture.runAsync(() -> {
|
|
|
+ Optional<HistoricProcessInstance> historicProcessInstanceOptional = workflowExecuteService.getHistoricProcessInstance(processInstanceId.toString());
|
|
|
+
|
|
|
+ if (historicProcessInstanceOptional.isEmpty()) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ HistoricProcessInstance historicProcessInstance = historicProcessInstanceOptional.get();
|
|
|
+ if (!historicProcessInstance.getState().equals(HistoricProcessInstance.STATE_ACTIVE)) {
|
|
|
+ // 获取流程记录中的非正常结束
|
|
|
+ LambdaQueryWrapper<WorkflowRecord> workflowRecordLambdaQueryWrapper = new LambdaQueryWrapper<>();
|
|
|
+ workflowRecordLambdaQueryWrapper
|
|
|
+ .and(wq -> wq.eq(WorkflowRecord::getWorkflowApproveType, WorkflowApproveType.DISAGREE.getCode())
|
|
|
+ .or()
|
|
|
+ .eq(WorkflowRecord::getWorkflowApproveType, WorkflowApproveType.WITHDRAW.getCode())
|
|
|
+ )
|
|
|
+ .eq(WorkflowRecord::getProcessId, processInstanceId)
|
|
|
+ ;
|
|
|
+ List<WorkflowRecord> workflowRecordList = workflowRecordMapper.selectList(workflowRecordLambdaQueryWrapper);
|
|
|
+
|
|
|
+ if (!workflowRecordList.isEmpty()) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ //查询出数据
|
|
|
+ String tableName = "wf_student_resume_schooling";
|
|
|
+ Entity where = Entity.create(tableName);
|
|
|
+ where.set("id", formId);
|
|
|
+ Map<String, Object> objectMap = SqlRunnerAdapter.db().dynamicSelectOne(tableName, where);
|
|
|
+ long studentUserId = Long.parseLong(objectMap.get("user_id").toString());
|
|
|
+ //跟新学籍信息
|
|
|
+ BaseStudentSchoolRoll schoolRoll = studentSchoolRollService.getOne(
|
|
|
+ new QueryWrapper<BaseStudentSchoolRoll>().lambda()
|
|
|
+ .eq(BaseStudentSchoolRoll::getClassId, Long.parseLong(objectMap.get("class_id").toString()))
|
|
|
+ .eq(BaseStudentSchoolRoll::getUserId, studentUserId)
|
|
|
+ .eq(BaseStudentSchoolRoll::getDeleteMark, DeleteMark.NODELETE.getCode())
|
|
|
+ );
|
|
|
+
|
|
|
+ //记录异动
|
|
|
+ changeRecordService.insertData(
|
|
|
+ schoolRoll.getArchivesStatus(),
|
|
|
+ ArchivesStatusEnum.fromCode(schoolRoll.getArchivesStatus()),
|
|
|
+ ArchivesStatusEnum.FB2904.getCode(),
|
|
|
+ ArchivesStatusEnum.FB2904.getValue(),
|
|
|
+ studentUserId,
|
|
|
+ Long.parseLong(objectMap.get("create_user_id").toString()),
|
|
|
+ StudentChangeTypeEnum.ArchivesStatus.getCode(),
|
|
|
+ 2
|
|
|
+ );
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ schoolRoll.setArchivesStatus(ArchivesStatusEnum.FB2901.getCode());
|
|
|
+ studentSchoolRollService.updateById(schoolRoll);
|
|
|
+ });
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|