|
@@ -0,0 +1,895 @@
|
|
|
+/**
|
|
|
+ * Copyright © 2015-2020 <a href="http://www.jeeplus.org/">JeePlus</a> All rights reserved.
|
|
|
+ */
|
|
|
+package com.jeeplus.modules.workloan.service;
|
|
|
+
|
|
|
+import java.util.ArrayList;
|
|
|
+import java.util.HashMap;
|
|
|
+import java.util.List;
|
|
|
+import java.util.Map;
|
|
|
+
|
|
|
+import com.google.common.collect.Maps;
|
|
|
+import com.jeeplus.common.utils.MenuStatusEnum;
|
|
|
+import com.jeeplus.common.utils.StringUtils;
|
|
|
+import com.jeeplus.modules.act.service.ActTaskService;
|
|
|
+import com.jeeplus.modules.act.utils.ActUtils;
|
|
|
+import com.jeeplus.modules.projectrecord.dao.WorkProjectUserDao;
|
|
|
+import com.jeeplus.modules.serialnum.service.SerialNumTplService;
|
|
|
+import com.jeeplus.modules.sys.entity.Office;
|
|
|
+import com.jeeplus.modules.sys.entity.User;
|
|
|
+import com.jeeplus.modules.sys.service.OfficeService;
|
|
|
+import com.jeeplus.modules.sys.utils.UserUtils;
|
|
|
+import com.jeeplus.modules.workactivity.dao.WorkActivityProcessDao;
|
|
|
+import com.jeeplus.modules.workactivity.entity.Activity;
|
|
|
+import com.jeeplus.modules.workactivity.entity.WorkActivityProcess;
|
|
|
+import com.jeeplus.modules.workactivity.service.ActivityService;
|
|
|
+import com.jeeplus.modules.workactivity.service.WorkActivityProcessService;
|
|
|
+import com.jeeplus.modules.workactivitymenu.entity.WorkActivityMenu;
|
|
|
+import com.jeeplus.modules.workactivitymenu.service.WorkActivityMenuService;
|
|
|
+import com.jeeplus.modules.workclientinfo.dao.WorkClientAttachmentDao;
|
|
|
+import com.jeeplus.modules.workcontractinfo.entity.WorkContractInfo;
|
|
|
+import com.jeeplus.modules.workprojectnotify.entity.WorkProjectNotify;
|
|
|
+import com.jeeplus.modules.workprojectnotify.service.WorkProjectNotifyService;
|
|
|
+import com.jeeplus.modules.workprojectnotify.util.UtilNotify;
|
|
|
+import com.jeeplus.modules.workrepay.dao.WorkRepayDao;
|
|
|
+import com.jeeplus.modules.workrepay.entity.WorkRepay;
|
|
|
+import com.jeeplus.modules.workrepay.service.WorkRepayService;
|
|
|
+import com.jeeplus.modules.workstaff.entity.WorkStaffBasicInfo;
|
|
|
+import com.jeeplus.modules.workstaff.service.WorkStaffBasicInfoService;
|
|
|
+import org.activiti.engine.*;
|
|
|
+import org.activiti.engine.runtime.ProcessInstance;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.context.annotation.Lazy;
|
|
|
+import org.springframework.stereotype.Service;
|
|
|
+import org.springframework.transaction.annotation.Transactional;
|
|
|
+
|
|
|
+import com.jeeplus.common.persistence.Page;
|
|
|
+import com.jeeplus.common.service.CrudService;
|
|
|
+import com.jeeplus.modules.workloan.entity.WorkLoan;
|
|
|
+import com.jeeplus.modules.workloan.dao.WorkLoanDao;
|
|
|
+
|
|
|
+/**
|
|
|
+ * 借款Service
|
|
|
+ * @author ssrh
|
|
|
+ * @version 2018-10-16
|
|
|
+ */
|
|
|
+@Service
|
|
|
+@Transactional(readOnly = true)
|
|
|
+public class WorkLoanService extends CrudService<WorkLoanDao, WorkLoan> {
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private RuntimeService runtimeService;
|
|
|
+ @Autowired
|
|
|
+ protected TaskService taskService;
|
|
|
+ @Autowired
|
|
|
+ protected HistoryService historyService;
|
|
|
+ @Autowired
|
|
|
+ protected RepositoryService repositoryService;
|
|
|
+ @Autowired
|
|
|
+ private IdentityService identityService;
|
|
|
+ @Autowired
|
|
|
+ private ActTaskService actTaskService;
|
|
|
+ @Autowired
|
|
|
+ private WorkProjectNotifyService workProjectNotifyService;
|
|
|
+ @Autowired
|
|
|
+ private WorkActivityMenuService workActivityMenuService;
|
|
|
+ @Autowired
|
|
|
+ private WorkActivityProcessService workActivityProcessService;
|
|
|
+ @Autowired
|
|
|
+ private ActivityService activityService;
|
|
|
+ @Autowired
|
|
|
+ private WorkActivityProcessDao workActivityProcessDao;
|
|
|
+ @Autowired
|
|
|
+ private SerialNumTplService serialNumTplService;
|
|
|
+ @Autowired
|
|
|
+ private OfficeService officeService;
|
|
|
+ @Autowired
|
|
|
+ private WorkLoanDao workLoanDao;
|
|
|
+ @Autowired
|
|
|
+ @Lazy
|
|
|
+ private WorkRepayService workRepayService;
|
|
|
+ @Autowired
|
|
|
+ private WorkStaffBasicInfoService workStaffBasicInfoService;
|
|
|
+ @Autowired
|
|
|
+ private WorkRepayDao workRepayDao;
|
|
|
+
|
|
|
+ @SuppressWarnings("unchecked")
|
|
|
+ public WorkLoan get(String id) {
|
|
|
+ WorkLoan workLoan = super.get(id);
|
|
|
+ if(workLoan!=null){
|
|
|
+ WorkRepay workRepay = new WorkRepay();
|
|
|
+ workRepay.setStatus("5");
|
|
|
+ workRepay.setWorkLoan(workLoan);
|
|
|
+ List<WorkRepay> list = workRepayService.findList(workRepay);
|
|
|
+ workLoan.setWorkRepays(list);
|
|
|
+ //合同未还款累计
|
|
|
+ if(workLoan.getProjectRecords()!=null && workLoan.getProjectRecords().getWorkContractInfo()!=null && StringUtils.isNotBlank(workLoan.getProjectRecords().getWorkContractInfo().getId())){
|
|
|
+ Double contractNotRepay = this.getContractRepay(workLoan.getProjectRecords().getWorkContractInfo());
|
|
|
+ workLoan.setContractNotRepay(contractNotRepay+"");
|
|
|
+ }
|
|
|
+ //未还借款累计
|
|
|
+ if(workLoan.getWorkStaffBasicInfo()!=null && StringUtils.isNotBlank(workLoan.getWorkStaffBasicInfo().getUserId())){
|
|
|
+ Double notRepay = this.getnotRepay(workLoan.getWorkStaffBasicInfo());
|
|
|
+ workLoan.setNotRepay(notRepay+"");
|
|
|
+ }
|
|
|
+ //还款金额
|
|
|
+ if(StringUtils.isNotBlank(workLoan.getId())){
|
|
|
+ Double repay = this.getRepay(workLoan);
|
|
|
+ workLoan.setRepay(repay+"");
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ return workLoan;
|
|
|
+ }
|
|
|
+ public WorkLoan getLon(String id) {
|
|
|
+ WorkLoan workLoan = super.get(id);
|
|
|
+ if(workLoan!=null){
|
|
|
+ WorkRepay workRepay = new WorkRepay();
|
|
|
+ workRepay.setStatus("5");
|
|
|
+ workRepay.setWorkLoan(workLoan);
|
|
|
+ List<WorkRepay> list = workRepayService.findList(workRepay);
|
|
|
+ workLoan.setWorkRepays(list);
|
|
|
+ //合同未还款累计
|
|
|
+ if(workLoan.getProjectRecords()!=null && workLoan.getProjectRecords().getWorkContractInfo()!=null && StringUtils.isNotBlank(workLoan.getProjectRecords().getWorkContractInfo().getId())){
|
|
|
+ Double contractNotRepay = this.getContractRepay(workLoan.getProjectRecords().getWorkContractInfo());
|
|
|
+ workLoan.setContractNotRepay(contractNotRepay+"");
|
|
|
+ }
|
|
|
+ //未还借款累计
|
|
|
+ String notRepay=workRepayDao.findSumRepayList(workLoan.getId());
|
|
|
+ workLoan.setNotRepay(String.valueOf(Double.parseDouble(workLoan.getMoney()) - Double.parseDouble(notRepay)));
|
|
|
+ }
|
|
|
+ return workLoan;
|
|
|
+ }
|
|
|
+ public Double getnotRepay(WorkStaffBasicInfo workStaffBasicInfo){
|
|
|
+ //未还借款累计
|
|
|
+ List<WorkLoan> list1 = this.findListByUser(workStaffBasicInfo.getUserId(),"3");
|
|
|
+ double moneyCount= 0.00;//借款
|
|
|
+ for(int i=0;i<list1.size();i++){
|
|
|
+ WorkLoan workLoan = list1.get(i);
|
|
|
+ if(StringUtils.isNotBlank(workLoan.getMoney())){
|
|
|
+ moneyCount = moneyCount + Double.parseDouble(workLoan.getMoney());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ //部分还款
|
|
|
+ List<WorkLoan> list2 = this.findListByUser(workStaffBasicInfo.getUserId(),"2");
|
|
|
+ for(int i=0;i<list2.size();i++){
|
|
|
+ WorkLoan workLoan = list2.get(i);
|
|
|
+ Double repay = this.getRepay(workLoan);
|
|
|
+ if(StringUtils.isNotBlank(workLoan.getMoney()) && repay!=null){
|
|
|
+ moneyCount = moneyCount + (Double.parseDouble(workLoan.getMoney()) - repay);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return moneyCount;
|
|
|
+ }
|
|
|
+
|
|
|
+ public Double getContractRepay(WorkContractInfo workContractInfo){
|
|
|
+ //合同未还累计
|
|
|
+ //未还款
|
|
|
+ List<WorkLoan> list1 = this.findListByContract(workContractInfo.getId(),"3");
|
|
|
+ double moneyCount= 0.00;//借款
|
|
|
+ for(int i=0;i<list1.size();i++){
|
|
|
+ WorkLoan workLoan = list1.get(i);
|
|
|
+ if(StringUtils.isNotBlank(workLoan.getMoney())){
|
|
|
+ moneyCount = moneyCount + Double.parseDouble(workLoan.getMoney());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ //部分还款
|
|
|
+ List<WorkLoan> list2 = this.findListByContract(workContractInfo.getId(),"2");
|
|
|
+ for(int i=0;i<list2.size();i++){
|
|
|
+ WorkLoan workLoan = list2.get(i);
|
|
|
+ if(StringUtils.isNotBlank(workLoan.getMoney()) && StringUtils.isNotBlank(workLoan.getRepay())){
|
|
|
+ moneyCount = moneyCount + (Double.parseDouble(workLoan.getMoney()) - Double.parseDouble(workLoan.getRepay()));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return moneyCount;
|
|
|
+ }
|
|
|
+ public Double getRepay(WorkLoan workLoan){
|
|
|
+ //借款-还款累计
|
|
|
+ double moneyCount= 0.00;
|
|
|
+ WorkRepay workRepay = new WorkRepay();
|
|
|
+ workRepay.setStatus("5");
|
|
|
+ workRepay.setWorkLoan(workLoan);
|
|
|
+ List<WorkRepay> list = workRepayService.findList(workRepay);
|
|
|
+ for(int i=0;i<list.size();i++){
|
|
|
+ WorkRepay w = list.get(i);
|
|
|
+ if(StringUtils.isNotBlank(w.getMoney())){
|
|
|
+ moneyCount = moneyCount+(Double.parseDouble(w.getMoney()));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return moneyCount;
|
|
|
+ }
|
|
|
+ public List<WorkLoan> findList(WorkLoan workLoan) {
|
|
|
+ return super.findList(workLoan);
|
|
|
+ }
|
|
|
+
|
|
|
+ public Page<WorkLoan> findPage(Page<WorkLoan> page, WorkLoan workLoan) {
|
|
|
+ workLoan.getSqlMap().put("dsf", dataScopeFilter(workLoan.getCurrentUser(), "o", "u","s", MenuStatusEnum.WORK_REIMBURSEMENT.getValue()));
|
|
|
+ workLoan.setPage(page);
|
|
|
+ page.setList(findList(workLoan));
|
|
|
+ return page;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 暂存
|
|
|
+ * @param
|
|
|
+ */
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public void save(WorkLoan workLoan){
|
|
|
+ if (StringUtils.isBlank(workLoan.getNum())) {
|
|
|
+ User user = UserUtils.getUser();
|
|
|
+ workLoan.setNum(serialNumTplService.genSerialNum(user.getCompany(), workLoan.SERIAL_BIZCODE));
|
|
|
+ }
|
|
|
+ super.save(workLoan);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public String save(WorkLoan workLoan, Map<String, Object> variables, String processInstanceId) {
|
|
|
+ User user = UserUtils.getUser();
|
|
|
+ if (StringUtils.isBlank(workLoan.getNum())) {
|
|
|
+ workLoan.setNum(serialNumTplService.genSerialNum(user.getCompany(), workLoan.SERIAL_BIZCODE));
|
|
|
+ }
|
|
|
+ super.save(workLoan);
|
|
|
+ Office office = null;
|
|
|
+ if(workLoan!=null && workLoan.getWorkStaffBasicInfo()!=null && StringUtils.isNotBlank(workLoan.getWorkStaffBasicInfo().getId())){
|
|
|
+ WorkStaffBasicInfo workStaffBasicInfo=workStaffBasicInfoService.getAchives(workLoan.getWorkStaffBasicInfo().getId());
|
|
|
+ if(workStaffBasicInfo!=null){
|
|
|
+ office = workStaffBasicInfo.getOffice();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if(office == null || StringUtils.isBlank(office.getId())){
|
|
|
+ return "借款人档案信息有误,请确认!";
|
|
|
+ }
|
|
|
+ String str = "借款申请编号:"+workLoan.getNum()+",借款人:"+workLoan.getWorkStaffBasicInfo().getName()+",所属部门:"+office.getName();
|
|
|
+ String title = "借款人:"+workLoan.getWorkStaffBasicInfo().getName();
|
|
|
+ // 用来设置启动流程的人员ID,引擎会自动把用户ID保存到activiti:initiator中
|
|
|
+ identityService.setAuthenticatedUserId(user.getId());
|
|
|
+ // 启动流程
|
|
|
+ String businessKey = workLoan.getId().toString();
|
|
|
+ WorkActivityMenu workActivityMenu = workActivityMenuService.findByParentAndOffice("ggh3125f1f194c82bdea93555c75edfv", office);
|
|
|
+ // 启动流程
|
|
|
+ String processType = workActivityMenu.getProcessType();
|
|
|
+ StringBuffer buffer = new StringBuffer();
|
|
|
+ Activity activity = new Activity();
|
|
|
+ WorkProjectNotify workProjectNotify = UtilNotify
|
|
|
+ .saveNotify(workLoan.getId(),
|
|
|
+ null,
|
|
|
+ workLoan.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "87",
|
|
|
+ "0",
|
|
|
+ "待审批",
|
|
|
+ ""
|
|
|
+ );
|
|
|
+ List<User> users = new ArrayList<>();
|
|
|
+ List<User> bmzrs = UserUtils.getByRoleActivityEnname("bmzr",2,office.getId(),"29",workLoan.getCreateBy());
|
|
|
+ List<User> fglds = UserUtils.getByRoleActivityEnname("fgld",2,office.getId(),"29",workLoan.getCreateBy());
|
|
|
+ List<User> cws = UserUtils.getByRoleActivityEnname("cwzg",3,office.getId(),"29",workLoan.getCreateBy());
|
|
|
+ List<User> zjls = UserUtils.getByRoleActivityEnname("zjl",3,office.getId(),"29",workLoan.getCreateBy());
|
|
|
+ List<User> cwzjs = UserUtils.getByRoleActivityEnname("cwfgld",3,office.getId(),"29",workLoan.getCreateBy());
|
|
|
+ List<User> cns = UserUtils.getByRoleActivityEnname("cn",3,office.getId(),"29",workLoan.getCreateBy());
|
|
|
+ if (StringUtils.isNotBlank(workActivityMenu.getId())) {
|
|
|
+ workProjectNotify.setNotifyRole("");
|
|
|
+ workActivityMenu = workActivityMenuService.get(workActivityMenu.getId());
|
|
|
+ List<Activity> activities = workActivityMenu.getActivities();
|
|
|
+ for (Activity a : activities) {
|
|
|
+ String encount = a.getEncount();
|
|
|
+ String enlist = a.getEnlist();
|
|
|
+ if (a.getRole()!=null && StringUtils.isNotBlank(a.getRole().getEnname())){
|
|
|
+ List enusers = UserUtils.getByRoleActivityEnnames(a.getRole().getEnname(),office.getId(),"29",workLoan.getCreateBy());
|
|
|
+ if (enusers.size()==0){
|
|
|
+ workLoan.setStatus("1");
|
|
|
+ super.save(workLoan);
|
|
|
+ return "流程审批人不能为空,角色"+a.getRole().getName()+"下无用户,请联系管理员!";
|
|
|
+ }
|
|
|
+ variables.put(enlist, enusers);
|
|
|
+ variables.put(encount, enusers.size());
|
|
|
+ }
|
|
|
+ if (a.getDelFlag().equals("0") && a.getCount() == 1) {
|
|
|
+ activity = a;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ buffer.append(activity.getRole().getEnname());
|
|
|
+ if (activity != null && StringUtils.isNotBlank(activity.getId())) {
|
|
|
+ //角色审批
|
|
|
+ if (StringUtils.isNotBlank(activity.getRole().getEnname())) {
|
|
|
+ users = UserUtils.getByRoleActivityEnnames(activity.getRole().getEnname(),office.getId(),"29",workLoan.getCreateBy());
|
|
|
+ }
|
|
|
+ //人员审批
|
|
|
+ if (StringUtils.isNotBlank(activity.getUser().getId())) {
|
|
|
+ users.add(activity.getUser());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ workProjectNotify.setId("");
|
|
|
+ } else {
|
|
|
+ variables.put("bmzrList", bmzrs);
|
|
|
+ /*variables.put("fgldList", fglds);
|
|
|
+ variables.put("cwList", cws);
|
|
|
+ variables.put("zjlList", zjls);
|
|
|
+ variables.put("cwzjList", cwzjs);
|
|
|
+ variables.put("cnList", cns);*/
|
|
|
+ //|| fglds.size()==0 || cws.size()==0 || zjls.size()==0 || cwzjs.size()==0 || cns.size()==0
|
|
|
+ if (bmzrs.size()==0 ){
|
|
|
+ workLoan.setStatus("1");
|
|
|
+ super.save(workLoan);
|
|
|
+ }
|
|
|
+ if (bmzrs.size()==0){
|
|
|
+ return "流程审批人不能为空,角色部门负责人下无用户,请联系管理员!";
|
|
|
+ }
|
|
|
+ /* if (fglds.size()==0){
|
|
|
+ return "流程审批人不能为空,角色分管领导下无用户,请联系管理员!";
|
|
|
+ }
|
|
|
+ if (cws.size()==0){
|
|
|
+ return "流程审批人不能为空,角色财务主管下无用户,请联系管理员!";
|
|
|
+ }
|
|
|
+ if (zjls.size()==0){
|
|
|
+ return "流程审批人不能为空,角色总经理下无用户,请联系管理员!";
|
|
|
+ }
|
|
|
+ if (cwzjs.size()==0){
|
|
|
+ return "流程审批人不能为空,角色财务分管领导下无用户,请联系管理员!";
|
|
|
+ }
|
|
|
+ if (cns.size()==0){
|
|
|
+ return "流程审批人不能为空,角色出纳下无用户,请联系管理员!";
|
|
|
+ }*/
|
|
|
+ variables.put("bmzrcount",bmzrs.size());
|
|
|
+ /*variables.put("fgldcount",fglds.size());
|
|
|
+ variables.put("cwcount",cws.size());
|
|
|
+ variables.put("zjlcount",zjls.size());
|
|
|
+ variables.put("cwzjcount",cwzjs.size());
|
|
|
+ variables.put("cncount",cns.size());*/
|
|
|
+ processType = "workloan";
|
|
|
+ users.addAll(bmzrs);
|
|
|
+ }
|
|
|
+ for (User u : users){
|
|
|
+ workProjectNotify.setUser(u);
|
|
|
+ workProjectNotify.setId("");
|
|
|
+ workProjectNotify.setNotifyRole("部门负责人审批");
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(workProjectNotify);
|
|
|
+ /* List<WebSocket> toUserConns = ChatServerPool.getWebSocketByUser(u.getId());
|
|
|
+ for (WebSocket toUserConn:toUserConns) {
|
|
|
+ String message = "{\"to\":\""+u.getId()+"\"," +
|
|
|
+ "\"msg\":\"审批信息 报销人:" + user.getName() + ",报销编号:"+ workReimbursement.getNumber() + " 待审批!\"," +
|
|
|
+ "\"useType\":\"sys\"}";
|
|
|
+ ChatServerPool.sendMessageToUser(toUserConn, message);//同时向本人发送消息
|
|
|
+ }*/
|
|
|
+ Map<String,Object> extras = new HashMap<>();
|
|
|
+ extras.put("type","7002");
|
|
|
+ extras.put("id",workProjectNotify.getId());
|
|
|
+ extras.put("procDefKey","13");
|
|
|
+ UserUtils.pushInfoToApp(title,str,extras,u.getId());
|
|
|
+ UserUtils.pushIm(u.getId(),str);
|
|
|
+ }
|
|
|
+ variables.put("type", processType);
|
|
|
+ variables.put("busId", businessKey);
|
|
|
+ variables.put("title", "审批单:" + workLoan.getNum());//设置标题;
|
|
|
+
|
|
|
+ ProcessInstance processInstance = runtimeService.startProcessInstanceByKey(processType, businessKey, variables);
|
|
|
+ workLoan.setProcessInstance(processInstance);
|
|
|
+ if (StringUtils.isNotBlank(processInstanceId)) {
|
|
|
+ workActivityProcessService.updateProcessInstanceId(processInstance.getId(),processInstanceId);
|
|
|
+ workActivityProcessService.deleteProcessInstanceId(processInstanceId);
|
|
|
+ workActivityProcessService.deleteProcessIdAuditUsers(processInstanceId);
|
|
|
+ }
|
|
|
+ // 更新流程实例ID
|
|
|
+ workLoan.setProcessInstanceId(processInstance.getId());
|
|
|
+ workLoanDao.updateProcessInstanceId(workLoan);
|
|
|
+ List<Activity> list = workActivityMenu.getActivities();
|
|
|
+ if (list != null && list.size() != 0) {
|
|
|
+ workActivityProcessService.saveList(list, processInstance.getId());
|
|
|
+ } else {
|
|
|
+ WorkActivityProcess workActivityProcess = new WorkActivityProcess();
|
|
|
+ workActivityProcess.setProcessKey("workloan");
|
|
|
+ workActivityProcess.setCount(1);
|
|
|
+ workActivityProcess.setProcessInstanceId(processInstance.getId());
|
|
|
+ workActivityProcess.setIsApproval("0");
|
|
|
+ workActivityProcessService.save(workActivityProcess);
|
|
|
+ workActivityProcess.setCount(2);
|
|
|
+ workActivityProcess.setId("");
|
|
|
+ workActivityProcessService.save(workActivityProcess);
|
|
|
+ workActivityProcess.setCount(3);
|
|
|
+ workActivityProcess.setId("");
|
|
|
+ workActivityProcessService.save(workActivityProcess);
|
|
|
+ workActivityProcess.setCount(4);
|
|
|
+ workActivityProcess.setId("");
|
|
|
+ workActivityProcessService.save(workActivityProcess);
|
|
|
+ workActivityProcess.setCount(5);
|
|
|
+ workActivityProcess.setId("");
|
|
|
+ workActivityProcessService.save(workActivityProcess);
|
|
|
+ workActivityProcess.setCount(6);
|
|
|
+ workActivityProcess.setId("");
|
|
|
+ workActivityProcessService.save(workActivityProcess);
|
|
|
+ workActivityProcessService.insertAuditsByType(bmzrs,processInstance.getId(),1,1);
|
|
|
+ workActivityProcessService.insertAuditsByType(fglds,processInstance.getId(),2,0);
|
|
|
+ workActivityProcessService.insertAuditsByType(cws,processInstance.getId(),3,0);
|
|
|
+ workActivityProcessService.insertAuditsByType(zjls,processInstance.getId(),4,0);
|
|
|
+ workActivityProcessService.insertAuditsByType(cwzjs,processInstance.getId(),5,0);
|
|
|
+ workActivityProcessService.insertAuditsByType(cns,processInstance.getId(),6,0);
|
|
|
+ }
|
|
|
+ logger.debug("start process of {key={}, bkey={}, pid={}, variables={}}", new Object[]{
|
|
|
+ ActUtils.PD_REIMBURSEMENT[0], businessKey, processInstance.getId(), variables});
|
|
|
+ return "";
|
|
|
+ }
|
|
|
+
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public void delete(WorkLoan workLoan) {
|
|
|
+ super.delete(workLoan);
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workLoan.getId());
|
|
|
+ List<User> users = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ if (users!=null && users.size()!=0){
|
|
|
+ for (User user:users){
|
|
|
+ UserUtils.pushMeIm(user.getId());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 审核流程
|
|
|
+ * @param
|
|
|
+ */
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public String auditSave(WorkLoan workLoan,List<User> auditUsers) {
|
|
|
+ Office office = null;
|
|
|
+ if(workLoan!=null && workLoan.getWorkStaffBasicInfo()!=null && StringUtils.isNotBlank(workLoan.getWorkStaffBasicInfo().getId())){
|
|
|
+ WorkStaffBasicInfo workStaffBasicInfo=workStaffBasicInfoService.getAchives(workLoan.getWorkStaffBasicInfo().getId());
|
|
|
+ if(workStaffBasicInfo!=null){
|
|
|
+ office = workStaffBasicInfo.getOffice();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if(office == null || StringUtils.isBlank(office.getId())){
|
|
|
+ return "借款人档案信息有误,请确认!";
|
|
|
+ }
|
|
|
+ String str = "借款申请编号:"+workLoan.getNum()+",借款人:"+workLoan.getWorkStaffBasicInfo().getName()+",所属部门:"+office.getName();
|
|
|
+ String title = "借款人:"+workLoan.getWorkStaffBasicInfo().getName();
|
|
|
+
|
|
|
+ // 对不同环节的业务逻辑进行操作
|
|
|
+ String taskDefKey = workLoan.getAct().getTaskDefKey();
|
|
|
+ if (!"modifyApply".equals(taskDefKey)) {
|
|
|
+ actTaskService.claim(workLoan.getAct().getTaskId(), UserUtils.getUser().getId());
|
|
|
+ }else{
|
|
|
+ workLoan.getAct().setFlag("yes");
|
|
|
+ }
|
|
|
+ String comment = "";
|
|
|
+ if (workLoan.getStatus().equals("4")){
|
|
|
+ comment = ("yes".equals(workLoan.getAct().getFlag())?"[重新申请] ":"[已撤销] ");
|
|
|
+ }else {
|
|
|
+ comment = ("yes".equals(workLoan.getAct().getFlag())?"[同意] ":"[驳回] ")+workLoan.getAct().getComment();
|
|
|
+ }
|
|
|
+ //yes 的时候状态为审核通过 否则为未通过
|
|
|
+ //1 审核中 2 未通过
|
|
|
+ workLoan.setStatus(("yes".equals(workLoan.getAct().getFlag()) ? "2" : "4"));
|
|
|
+ Map<String, Object> vars = Maps.newHashMap();
|
|
|
+ //业务逻辑对应的条件表达式
|
|
|
+ String exp = "";
|
|
|
+ String taskCount = "";
|
|
|
+ String notifyRole = "";
|
|
|
+ int key = 0;
|
|
|
+ String enname = "";
|
|
|
+ List<Activity> activitieList = activityService.getByProcessInstanceId(workLoan.getProcessInstanceId());
|
|
|
+ WorkActivityMenu workActivityMenu = new WorkActivityMenu();
|
|
|
+ if (activitieList != null && activitieList.size() != 0) {
|
|
|
+ workActivityMenu.setProcessType(activitieList.get(0).getProcessKey());
|
|
|
+ workActivityMenu.setActivities(activitieList);
|
|
|
+ }
|
|
|
+
|
|
|
+ WorkActivityProcess workActivityProcess = new WorkActivityProcess();
|
|
|
+ WorkActivityProcess selectProcess = new WorkActivityProcess();
|
|
|
+ selectProcess.setProcessInstanceId(workLoan.getProcessInstanceId());
|
|
|
+ List<WorkActivityProcess> workActivityProcesses = workActivityProcessService.findList(selectProcess);
|
|
|
+ List<Activity> activities = workActivityMenu.getActivities();
|
|
|
+ if (StringUtils.isNotBlank(workActivityMenu.getProcessType()) && !workActivityMenu.getProcessType().equals("workloan")) {
|
|
|
+ key = 1;
|
|
|
+ for (int i = 0; i < workActivityProcesses.size(); i++) {
|
|
|
+ WorkActivityProcess activityProcess = workActivityProcesses.get(i);
|
|
|
+ if (taskDefKey.equals(activityProcess.getActivityTask()) && !taskDefKey.equals("modifyApply")) {
|
|
|
+ taskCount = activityProcess.getCount()+"";
|
|
|
+ workActivityProcess = activityProcess;
|
|
|
+ if (!workActivityProcess.getIsApproval().equals("0")) {
|
|
|
+ workActivityProcess.setId("");
|
|
|
+ }
|
|
|
+ exp = "pass";
|
|
|
+ if (!"yes".equals(workLoan.getAct().getFlag())) {
|
|
|
+ workLoan.setStatus("4");
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ String returnBack = "-1";
|
|
|
+ for (Activity activity : activities) {
|
|
|
+ if (activity.getCount() == activityProcess.getCount()) {
|
|
|
+ returnBack = activity.getReturnBack();
|
|
|
+ notifyRole = activity.getName();
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (returnBack.equals("0")) {
|
|
|
+ workActivityProcess.setId("");
|
|
|
+ }
|
|
|
+
|
|
|
+ } else {
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ }
|
|
|
+ }else if(taskDefKey.equals("modifyApply")){
|
|
|
+ notifyRole = "调整申请";
|
|
|
+ taskCount = "0";
|
|
|
+ exp = "pass";
|
|
|
+ workActivityProcess.setId("");
|
|
|
+ workActivityProcess.setCount(0);
|
|
|
+ if (!"yes".equals(workLoan.getAct().getFlag())) {
|
|
|
+ workLoan.setStatus("3");
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ } else {
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ workActivityMenu.setProcessType("workloan");
|
|
|
+ for (int i = 0; i < workActivityProcesses.size(); i++) {
|
|
|
+ WorkActivityProcess activityProcess = workActivityProcesses.get(i);
|
|
|
+ String count = activityProcess.getCount() + "";
|
|
|
+ workActivityProcess = activityProcess;
|
|
|
+ if (!workActivityProcess.getIsApproval().equals("0")) {
|
|
|
+ workActivityProcess.setId("");
|
|
|
+ }
|
|
|
+ // 审核环节
|
|
|
+ if ("bmzr".equals(taskDefKey) && count.contains("1")) {
|
|
|
+ taskCount = "1";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(workLoan.getAct().getFlag())) {
|
|
|
+ vars.put("fgldList", auditUsers);
|
|
|
+ vars.put("fgldcount",auditUsers.size());
|
|
|
+ workActivityProcessService.insertAuditsByType(auditUsers,workLoan.getProcessInstanceId(),2,1);
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ notifyRole = "分管领导审核";
|
|
|
+ enname = "fgld";
|
|
|
+ } else {
|
|
|
+ notifyRole = "调整申请";
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("fgld".equals(taskDefKey) && count.contains("2")) {
|
|
|
+ taskCount = "2";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(workLoan.getAct().getFlag())) {
|
|
|
+ vars.put("cwList", auditUsers);
|
|
|
+ vars.put("cwcount",auditUsers.size());
|
|
|
+ workActivityProcessService.insertAuditsByType(auditUsers,workLoan.getProcessInstanceId(),3,1);
|
|
|
+ notifyRole = "财务审核";
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ enname = "cwzg";
|
|
|
+ } else {
|
|
|
+ notifyRole = "调整申请";
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("cw".equals(taskDefKey) && count.contains("3")) {
|
|
|
+ taskCount = "3";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(workLoan.getAct().getFlag())) {
|
|
|
+ vars.put("zjlList", auditUsers);
|
|
|
+ vars.put("zjlcount",auditUsers.size());
|
|
|
+ workActivityProcessService.insertAuditsByType(auditUsers,workLoan.getProcessInstanceId(),4,1);
|
|
|
+ notifyRole = "总经理审核";
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ enname = "zjl";
|
|
|
+ } else {
|
|
|
+ notifyRole = "调整申请";
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("zjl".equals(taskDefKey) && count.contains("4")) {
|
|
|
+ taskCount = "4";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(workLoan.getAct().getFlag())) {
|
|
|
+ vars.put("cwzjList", auditUsers);
|
|
|
+ vars.put("cwzjcount",auditUsers.size());
|
|
|
+ notifyRole = "财务分管领导审核";
|
|
|
+ workActivityProcessService.insertAuditsByType(auditUsers,workLoan.getProcessInstanceId(),5,1);
|
|
|
+
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ enname = "cwfgld";
|
|
|
+ } else {
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ notifyRole = "调整申请";
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("cwzj".equals(taskDefKey) && count.contains("5")) {
|
|
|
+ taskCount = "5";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(workLoan.getAct().getFlag())) {
|
|
|
+ vars.put("cnList", auditUsers);
|
|
|
+ vars.put("cncount",auditUsers.size());
|
|
|
+ workActivityProcessService.insertAuditsByType(auditUsers,workLoan.getProcessInstanceId(),6,1);
|
|
|
+ notifyRole = "报销付款";
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ enname = "cn";
|
|
|
+ } else {
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ notifyRole = "调整申请";
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("cn".equals(taskDefKey) && count.contains("6")) {
|
|
|
+ taskCount = "6";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(workLoan.getAct().getFlag())) {
|
|
|
+ notifyRole = "审批通过";
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ } else {
|
|
|
+ notifyRole = "调整申请";
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("modifyApply".equals(taskDefKey)&& count.contains("0")) {
|
|
|
+ taskCount = "0";
|
|
|
+ notifyRole = "部门负责人审批";
|
|
|
+ exp = "pass";
|
|
|
+ workActivityProcess.setCount(0);
|
|
|
+ enname = "bmzr";
|
|
|
+ if (!"yes".equals(workLoan.getAct().getFlag())) {
|
|
|
+ workLoan.setStatus("3");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("apply_end".equals(taskDefKey)) {
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+ // 设置意见
|
|
|
+ workLoan.getAct().setComment(("yes".equals(workLoan.getAct().getFlag()) ? "[同意] " : "[驳回] ") + workLoan.getAct().getComment());
|
|
|
+ workLoan.preUpdate();
|
|
|
+ // 提交流程任务
|
|
|
+ vars.put(exp, "yes".equals(workLoan.getAct().getFlag()) ? true : false);
|
|
|
+ vars.put("passs", true);
|
|
|
+ workActivityProcessService.updateProcess(workActivityProcess,workActivityMenu,key,taskCount,workLoan.getProcessInstanceId(),taskDefKey,"modifyApply",workLoan.getAct().getFlag(),comment, activities);
|
|
|
+ // 提交流程任务
|
|
|
+ actTaskService.complete(workLoan.getAct().getTaskId(), workLoan.getAct().getProcInsId(), workLoan.getAct().getComment(), vars);
|
|
|
+ boolean state = actTaskService.isProcessEnd(workLoan.getAct().getProcInsId());
|
|
|
+ List<User> users = new ArrayList<>();
|
|
|
+ List<User> userList = new ArrayList<>();
|
|
|
+ if (!state) {
|
|
|
+ users.add(workLoan.getCreateBy());
|
|
|
+ if ("yes".equals(workLoan.getAct().getFlag())) {
|
|
|
+ workLoan.setStatus("5");
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workLoan.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(workLoan.getId(),
|
|
|
+ workLoan.getCreateBy(),
|
|
|
+ workLoan.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "87",
|
|
|
+ "0",
|
|
|
+ "待通知",
|
|
|
+ notifyRole));
|
|
|
+ } else {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workLoan.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ if (StringUtils.isNotBlank(workLoan.getStatus()) && !workLoan.getStatus().equals("3")){
|
|
|
+ workLoan.setStatus("4");
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(workLoan.getId(),
|
|
|
+ workLoan.getCreateBy(),
|
|
|
+ workLoan.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "87",
|
|
|
+ "0",
|
|
|
+ "待通知",
|
|
|
+ notifyRole));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ workActivityProcessService.deleteProcessIdAuditUsers(workLoan.getProcessInstanceId());
|
|
|
+ } else {
|
|
|
+ if (StringUtils.isNotBlank(workActivityMenu.getProcessType()) && !workActivityMenu.getProcessType().equals("workloan")) {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workLoan.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ //users.addAll(userList);
|
|
|
+ WorkProjectNotify workProjectNotify = UtilNotify
|
|
|
+ .saveNotify(workLoan.getId(),
|
|
|
+ new User(),
|
|
|
+ workLoan.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "87",
|
|
|
+ "0",
|
|
|
+ "待审批",
|
|
|
+ notifyRole);
|
|
|
+ List<WorkProjectNotify> workProjectNotifys = activityService.getByFlagAndTaskDefKeyList(
|
|
|
+ activities,
|
|
|
+ workProjectNotify,
|
|
|
+ taskDefKey,
|
|
|
+ workLoan.getAct().getFlag(),
|
|
|
+ taskCount,
|
|
|
+ workLoan.getCreateBy(),
|
|
|
+ workLoan.getOfficeId(),
|
|
|
+ "29");
|
|
|
+ for (WorkProjectNotify workProjectNotify1:workProjectNotifys){
|
|
|
+ users.add(workProjectNotify1.getUser());
|
|
|
+ workProjectNotify1.setId("");
|
|
|
+ workProjectNotify1.setIsNewRecord(false);
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(workProjectNotify1);
|
|
|
+ if (!"modifyApply".equals(taskDefKey)){
|
|
|
+ Map<String,Object> extras = new HashMap<>();
|
|
|
+ if ( "cn".equals(taskDefKey) ){
|
|
|
+ extras.put("type","7001");
|
|
|
+ }else {
|
|
|
+ extras.put("type","7002");
|
|
|
+ }
|
|
|
+ extras.put("id",workProjectNotify.getId());
|
|
|
+ extras.put("procDefKey","87");
|
|
|
+ UserUtils.pushInfoToApp(title,str,extras,workProjectNotify1.getUser().getId());
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ } else {
|
|
|
+ if (!"yes".equals(workLoan.getAct().getFlag())) {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workLoan.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ //users.addAll(userList);
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(workLoan.getId(),
|
|
|
+ workLoan.getCreateBy(),
|
|
|
+ workLoan.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "87",
|
|
|
+ "0",
|
|
|
+ "重新申请",
|
|
|
+ notifyRole));
|
|
|
+ users.add( workLoan.getCreateBy());
|
|
|
+ } else {
|
|
|
+ if (StringUtils.isNotBlank(enname)) {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workLoan.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ //users.addAll(userList1);
|
|
|
+ WorkProjectNotify workProjectNotify = UtilNotify
|
|
|
+ .saveNotify(workLoan.getId(),
|
|
|
+ new User(),
|
|
|
+ workLoan.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "87",
|
|
|
+ "0",
|
|
|
+ "待审批",
|
|
|
+ notifyRole);
|
|
|
+ users.addAll(auditUsers);
|
|
|
+ for (User user1:auditUsers){
|
|
|
+ workProjectNotify.setId("");
|
|
|
+ workProjectNotify.setUser(user1);
|
|
|
+ workProjectNotify.setIsNewRecord(false);
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(workProjectNotify);
|
|
|
+ if (!"modifyApply".equals(taskDefKey)){
|
|
|
+ Map<String,Object> extras = new HashMap<>();
|
|
|
+ if ("cn".equals(taskDefKey) ){
|
|
|
+ extras.put("type","7001");
|
|
|
+ }else {
|
|
|
+ extras.put("type","7002");
|
|
|
+ }
|
|
|
+ extras.put("id",workProjectNotify.getId());
|
|
|
+ extras.put("procDefKey","87");
|
|
|
+ UserUtils.pushInfoToApp(title,str,extras,user1.getId());
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }else {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workLoan.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ users.addAll(userList);
|
|
|
+ users.add(workLoan.getCreateBy());
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(workLoan.getId(),
|
|
|
+ workLoan.getCreateBy(),
|
|
|
+ workLoan.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "87",
|
|
|
+ "0",
|
|
|
+ "重新申请",
|
|
|
+ notifyRole));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (users!=null && users.size()!=0) {
|
|
|
+ for (User u : users) {
|
|
|
+ UserUtils.pushIm(u.getId(),str);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (userList!=null && userList.size()!=0) {
|
|
|
+ for (User u : userList) {
|
|
|
+ UserUtils.pushMeIm(u.getId());
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ workLoanDao.update(workLoan);
|
|
|
+ return "保存审核意见成功!";
|
|
|
+ }
|
|
|
+ /**
|
|
|
+ * 获取流程详细信息
|
|
|
+ * @param processInstanceId
|
|
|
+ */
|
|
|
+ @SuppressWarnings("unchecked")
|
|
|
+ public WorkLoan getByProcessInstanceId(String processInstanceId) {
|
|
|
+ WorkLoan workLoan = workLoanDao.getByProcessInstanceId(processInstanceId);
|
|
|
+ return workLoan;
|
|
|
+ }
|
|
|
+ /**
|
|
|
+ * 强制撤销
|
|
|
+ * @param
|
|
|
+ */
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public void cancelInvalidate(WorkLoan workLoan) {
|
|
|
+ String invalidateProcessInstanceId = workLoan.getProcessInstanceId();
|
|
|
+ try {
|
|
|
+ //将流程图中尚未走到的task的流程追踪信息逻辑删除,添加一条"撤销"流程追踪信息
|
|
|
+ WorkActivityProcess process = new WorkActivityProcess();
|
|
|
+ process.setProcessInstanceId(workLoan.getProcessInstanceId());
|
|
|
+ process.setIsApproval("0");
|
|
|
+ //List<WorkActivityProcess> processList1 = workActivityProcessService.findByProcInsId(process);
|
|
|
+ WorkActivityProcess workActivityProcess = new WorkActivityProcess();
|
|
|
+ workActivityProcess.setProcessInstanceId(workLoan.getProcessInstanceId());
|
|
|
+ List<WorkActivityProcess> processList = workActivityProcessService.findList(workActivityProcess);
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workLoan.getId());
|
|
|
+ List<User> userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ if (userList!=null && userList.size()!=0) {
|
|
|
+ for (User u : userList) {
|
|
|
+ User user = UserUtils.get(u.getId());
|
|
|
+ UserUtils.pushMeIm(user.getId());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if(processList!=null && processList.size()>0){
|
|
|
+ for (int i =0;i<processList.size();i++) {
|
|
|
+ WorkActivityProcess p = processList.get(i);
|
|
|
+ if(StringUtils.isNotBlank(p.getIsApproval()) && "0".equals(p.getIsApproval())){
|
|
|
+ p.setDelFlag("1");
|
|
|
+ p.setIsApproval("-1");
|
|
|
+ workActivityProcessDao.updateDelFlagAndIsApproval(p);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ WorkActivityProcess pro = new WorkActivityProcess();
|
|
|
+ pro.setId("");
|
|
|
+ pro.setDelFlag("0");
|
|
|
+ pro.preInsert();
|
|
|
+ pro.setRemarks("[强制撤销]");
|
|
|
+ pro.setProcessKey(processList.get(0).getProcessKey());
|
|
|
+ pro.setIsApproval("1");
|
|
|
+ pro.setProcessInstanceId(processList.get(0).getProcessInstanceId());
|
|
|
+ pro.setCount(0);
|
|
|
+ workActivityProcessDao.insert(pro);
|
|
|
+ }
|
|
|
+
|
|
|
+ //结束该流程,设为"撤销"状态
|
|
|
+ actTaskService.endProcessInstance(invalidateProcessInstanceId,"强制撤销");
|
|
|
+ workLoan.setStatus("3");
|
|
|
+ workLoan.preUpdate();
|
|
|
+ workLoanDao.update(workLoan);
|
|
|
+ }catch (ActivitiObjectNotFoundException e){
|
|
|
+ System.err.println("撤销异常,因为这个流程已不存在!");
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ catch (Exception e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ public List<WorkLoan> findListByContract(String contractId,String repayState){
|
|
|
+ return workLoanDao.findListByContract(contractId,repayState);
|
|
|
+ }
|
|
|
+ public List<WorkLoan> findListByUser(String userId,String repayState){
|
|
|
+ return workLoanDao.findListByUser(userId,repayState);
|
|
|
+ }
|
|
|
+}
|