|
@@ -0,0 +1,583 @@
|
|
|
+
|
|
|
+package com.jeeplus.modules.workcontractinfo.service;
|
|
|
+
|
|
|
+
|
|
|
+import com.google.common.collect.Maps;
|
|
|
+import com.jeeplus.common.service.CrudService;
|
|
|
+import com.jeeplus.common.utils.StringUtils;
|
|
|
+import com.jeeplus.modules.act.service.ActTaskService;
|
|
|
+import com.jeeplus.modules.alterinfo.service.AlterInfoService;
|
|
|
+import com.jeeplus.modules.contractclient.dao.WorkContractClientDao;
|
|
|
+import com.jeeplus.modules.contractclient.entity.WorkContractClient;
|
|
|
+import com.jeeplus.modules.contractclient.service.WorkContractClientService;
|
|
|
+import com.jeeplus.modules.isignature.service.ISignatureDocumentService;
|
|
|
+import com.jeeplus.modules.serialnum.service.SerialNumTplService;
|
|
|
+import com.jeeplus.modules.sys.dao.RoleDao;
|
|
|
+import com.jeeplus.modules.sys.dao.WorkattachmentDao;
|
|
|
+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.service.WorkattachmentService;
|
|
|
+import com.jeeplus.modules.sys.utils.DictUtils;
|
|
|
+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.workbidproject.dao.WorkBidProjectDao;
|
|
|
+import com.jeeplus.modules.workclientinfo.dao.WorkClientAttachmentDao;
|
|
|
+import com.jeeplus.modules.workclientinfo.entity.WorkClientInfo;
|
|
|
+import com.jeeplus.modules.workclientinfo.service.WorkClientInfoService;
|
|
|
+import com.jeeplus.modules.workcontractinfo.dao.*;
|
|
|
+import com.jeeplus.modules.workcontractinfo.entity.WorkContractInfo;
|
|
|
+import com.jeeplus.modules.workcontractrecord.entity.WorkContractRecord;
|
|
|
+import com.jeeplus.modules.workcontractrecord.service.WorkContractRecordService;
|
|
|
+import com.jeeplus.modules.workfullmanage.dao.WorkFullRecordDao;
|
|
|
+import com.jeeplus.modules.workinvoicedetail.dao.WorkInvoiceDetailDao;
|
|
|
+import com.jeeplus.modules.workprojectnotify.entity.WorkProjectNotify;
|
|
|
+import com.jeeplus.modules.workprojectnotify.service.WorkProjectNotifyService;
|
|
|
+import com.jeeplus.modules.workprojectnotify.util.UtilNotify;
|
|
|
+import org.activiti.engine.HistoryService;
|
|
|
+import org.activiti.engine.IdentityService;
|
|
|
+import org.activiti.engine.RuntimeService;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.stereotype.Service;
|
|
|
+import org.springframework.transaction.annotation.Transactional;
|
|
|
+
|
|
|
+import java.util.*;
|
|
|
+
|
|
|
+/**
|
|
|
+ * 合同管理Service
|
|
|
+ * @author 丁旭
|
|
|
+ * @version 2017-03-21
|
|
|
+ */
|
|
|
+@SuppressWarnings("all")
|
|
|
+@Service
|
|
|
+@Transactional(readOnly = true)
|
|
|
+public class WorkContractInfoTookDisposeService extends CrudService<WorkContractInfoDao, WorkContractInfo> {
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private AlterInfoService alterInfoService;
|
|
|
+ @Autowired
|
|
|
+ private WorkActivityProcessDao workActivityProcessDao;
|
|
|
+ @Autowired
|
|
|
+ private WorkContractAnnexDao workContractAnnexDao;
|
|
|
+ @Autowired
|
|
|
+ private WorkInvoiceDetailDao workInvoiceDetailDao;
|
|
|
+ @Autowired
|
|
|
+ private IdentityService identityService;
|
|
|
+ @Autowired
|
|
|
+ private RuntimeService runtimeService;
|
|
|
+ @Autowired
|
|
|
+ private WorkContractInfoDao workContractInfoDao;
|
|
|
+ @Autowired
|
|
|
+ private WorkClientAttachmentDao workClientAttachmentDao;
|
|
|
+ @Autowired
|
|
|
+ private WorkattachmentService workattachmentService;
|
|
|
+ @Autowired
|
|
|
+ private WorkattachmentDao workattachmentDao;
|
|
|
+ @Autowired
|
|
|
+ protected HistoryService historyService;
|
|
|
+ @Autowired
|
|
|
+ private WorkProjectNotifyService workProjectNotifyService;
|
|
|
+ @Autowired
|
|
|
+ private RoleDao roleDao;
|
|
|
+ @Autowired
|
|
|
+ private WorkFullRecordDao workFullRecordDao;
|
|
|
+ @Autowired
|
|
|
+ private OfficeService officeService;
|
|
|
+ @Autowired
|
|
|
+ private ActTaskService actTaskService;
|
|
|
+ @Autowired
|
|
|
+ private WorkActivityMenuService workActivityMenuService;
|
|
|
+ @Autowired
|
|
|
+ private WorkActivityProcessService workActivityProcessService;
|
|
|
+ @Autowired
|
|
|
+ private ActivityService activityService;
|
|
|
+ @Autowired
|
|
|
+ private WorkContractReviewDao workContractReviewDao;
|
|
|
+ @Autowired
|
|
|
+ private ISignatureDocumentService signatureDocumentService;
|
|
|
+ @Autowired
|
|
|
+ private WorkContractInfoCopyDao workContractInfoCopyDao;
|
|
|
+ @Autowired
|
|
|
+ private SerialNumTplService serialNumTplService;
|
|
|
+ @Autowired
|
|
|
+ private WorkContractClientService workContractClientService;
|
|
|
+ @Autowired
|
|
|
+ private WorkContractClientDao workContractClientDao;
|
|
|
+ @Autowired
|
|
|
+ private WorkClientInfoService workClientInfoService;
|
|
|
+ @Autowired
|
|
|
+ private WorkContractListInfoDao workContractListInfoDao;
|
|
|
+ @Autowired
|
|
|
+ private WorkBidProjectDao workBidProjectDao;
|
|
|
+ @Autowired
|
|
|
+ private WorkContractBorrowDao workContractBorrowDao;
|
|
|
+ @Autowired
|
|
|
+ private WorkContractRecordService workContractRecordService;
|
|
|
+
|
|
|
+ private static byte[] SYN_BYTE = new byte[0];
|
|
|
+
|
|
|
+ //客户列表
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public void updateWorkContractInfo(WorkContractInfo workContractInfo) {
|
|
|
+ String contractId = workContractInfo.getId();
|
|
|
+ WorkClientInfo client = workContractInfo.getClient();
|
|
|
+ WorkClientInfo clientInfo = workClientInfoService.get(client.getId());
|
|
|
+ //根据客户信息查询委托方联系人信息
|
|
|
+ if(workContractInfo.getWorkClientInfoList().size()==0){
|
|
|
+ WorkClientInfo workClientInfo = new WorkClientInfo();
|
|
|
+ workClientInfo.setId(clientInfo.getId());
|
|
|
+ workClientInfo.setName(clientInfo.getName());
|
|
|
+ workClientInfo.setCompanyType(DictUtils.getMainDictLabel(clientInfo.getCompanyType(),"company_type",""));
|
|
|
+ workClientInfo.setCompanyIndustry(DictUtils.getMainDictLabel(clientInfo.getCompanyIndustry(),"company_industry",""));
|
|
|
+ workClientInfo.setArea(clientInfo.getArea());
|
|
|
+ workContractInfo.getWorkClientInfoList().add(workClientInfo);
|
|
|
+ }
|
|
|
+
|
|
|
+ WorkContractClient workContractClient1 = new WorkContractClient();
|
|
|
+ workContractClient1.setContractId(contractId);
|
|
|
+ List<WorkContractClient> list1 =workContractClientService.findList(workContractClient1);
|
|
|
+ if(list1!=null && list1.size()>0){
|
|
|
+ for(WorkContractClient w :list1){
|
|
|
+ workContractClientService.delete(w);
|
|
|
+ }
|
|
|
+ for (WorkClientInfo workClientInfo : workContractInfo.getWorkClientInfoList()){
|
|
|
+ if(workClientInfo.DEL_FLAG_NORMAL.equals(workClientInfo.getDelFlag())){
|
|
|
+ String clientId = workClientInfo.getId();
|
|
|
+ if (clientId == null){
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ WorkContractClient workContractClient = new WorkContractClient();
|
|
|
+ workContractClient.setContractId(contractId);
|
|
|
+ workContractClient.setClientId(clientId);
|
|
|
+ List<WorkContractClient> list2 =workContractClientService.findList(workContractClient);
|
|
|
+ if(list2!=null&&list2.size()>0){
|
|
|
+ logger.info("无法重复添加关联关系");
|
|
|
+ }else{
|
|
|
+ //第一次新增
|
|
|
+ workContractClientService.save(workContractClient);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }else{
|
|
|
+ for (WorkClientInfo workClientInfo : workContractInfo.getWorkClientInfoList()){
|
|
|
+ String clientId = workClientInfo.getId();
|
|
|
+ if (clientId == null){
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ WorkContractClient workContractClient = new WorkContractClient();
|
|
|
+ workContractClient.setContractId(contractId);
|
|
|
+ workContractClient.setClientId(clientId);
|
|
|
+ List<WorkContractClient> list2 =workContractClientService.findList(workContractClient);
|
|
|
+ if(list2!=null&&list2.size()>0){
|
|
|
+ logger.info("无法重复添加关联关系");
|
|
|
+ }else{
|
|
|
+ //第一次新增
|
|
|
+ workContractClientService.save(workContractClient);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 工单执行(完成任务)
|
|
|
+ * @param workContractInfo
|
|
|
+ * @param
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public String newAuditSave(WorkContractInfo workContractInfo,String [] status,List<User> auditUsers){
|
|
|
+ //判断收费标准是否存在
|
|
|
+ if(null!= workContractInfo.getChargeCriterionList() && workContractInfo.getChargeCriterionList().size()>0){
|
|
|
+ String chargeCriterion = String.join(",", workContractInfo.getChargeCriterionList());
|
|
|
+ workContractInfo.setChargeCriterion(chargeCriterion);
|
|
|
+ }
|
|
|
+
|
|
|
+ //Office office = officeService.get(workContractInfo.getChargeCompany());
|
|
|
+ Office office = UserUtils.getUser().getOffice();
|
|
|
+ String str = "合同申请人:" + UserUtils.get(workContractInfo.getCreateBy().getId()).getName() + ",主委托方:" + workContractInfo.getClient().getName() + ",合同所属部门:"+office.getName();
|
|
|
+ String title = "合同名称:"+workContractInfo.getName();
|
|
|
+ // 对不同环节的业务逻辑进行操作
|
|
|
+ String taskDefKey = workContractInfo.getAct().getTaskDefKey();
|
|
|
+ if (!"modifyApply".equals(taskDefKey)) {
|
|
|
+ actTaskService.claim(workContractInfo.getAct().getTaskId(), UserUtils.getUser().getId());
|
|
|
+ }else {
|
|
|
+ workContractInfo.getAct().setFlag("yes");
|
|
|
+ updateWorkContractInfo(workContractInfo);
|
|
|
+ }
|
|
|
+ String comment = "";
|
|
|
+ if (workContractInfo.getContractState().equals("3")){
|
|
|
+ comment = ("yes".equals(workContractInfo.getAct().getFlag())?"[重新申请] ":"[已撤销] ");
|
|
|
+ }else {
|
|
|
+ if(StringUtils.isNotBlank(workContractInfo.getAct().getComment())){
|
|
|
+ comment = ("yes".equals(workContractInfo.getAct().getFlag())?"[同意] ":"[驳回] ")+workContractInfo.getAct().getComment();
|
|
|
+ }else{
|
|
|
+ comment = ("yes".equals(workContractInfo.getAct().getFlag())?"[同意] ":"[驳回] ");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ //yes 的时候状态为审核通过 否则为未通过
|
|
|
+ workContractInfo.setContractState(("yes".equals(workContractInfo.getAct().getFlag())?"2":"4"));
|
|
|
+ //String buffer = UserUtils.getRoleActivityEnname(workContractInfo.getCompanyId(),workContractInfo.getCreateBy());
|
|
|
+ Map<String, Object> vars = Maps.newHashMap();
|
|
|
+ //业务逻辑对应的条件表达式
|
|
|
+ String exp = "";
|
|
|
+ String taskCount = "";
|
|
|
+ String notifyRole = "";
|
|
|
+ int key = 0;
|
|
|
+ String enname = "";
|
|
|
+ List<Activity> activitieList = activityService.getByProcessInstanceId(workContractInfo.getProcessInstanceId());
|
|
|
+ WorkActivityMenu workActivityMenu = new WorkActivityMenu();
|
|
|
+ if (activitieList != null && activitieList.size() != 0) {
|
|
|
+ Iterator<Activity> iterator = activitieList.iterator();
|
|
|
+ while (iterator.hasNext()){
|
|
|
+ Activity activityInfo = iterator.next();
|
|
|
+ if (!"newContractAudit".equals(activityInfo.getProcessKey())){
|
|
|
+ iterator.remove();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ workActivityMenu.setProcessType(activitieList.get(0).getProcessKey());
|
|
|
+ workActivityMenu.setActivities(activitieList);
|
|
|
+ }
|
|
|
+ /*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(workContractInfo.getProcessInstanceId());
|
|
|
+ List<WorkActivityProcess> workActivityProcesses = workActivityProcessService.findList(selectProcess);
|
|
|
+ List<Activity> activities = workActivityMenu.getActivities();
|
|
|
+ if (StringUtils.isNotBlank(workActivityMenu.getProcessType()) && !workActivityMenu.getProcessType().equals("newContractAudit")) {
|
|
|
+ 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(workContractInfo.getAct().getFlag())) {
|
|
|
+ workContractInfo.setContractState("4");
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ String returnBack = "-1";
|
|
|
+ for (Activity activity : activities) {
|
|
|
+ if (activity.getCount() == activityProcess.getCount()) {
|
|
|
+ notifyRole = activity.getName();
|
|
|
+ returnBack = activity.getReturnBack();
|
|
|
+ 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(workContractInfo.getAct().getFlag())) {
|
|
|
+ workContractInfo.setContractState("3");
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ } else {
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }else {
|
|
|
+ workActivityMenu.setProcessType("newContractAudit");
|
|
|
+ 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(workContractInfo.getAct().getFlag())) {
|
|
|
+ workActivityProcessService.insertAuditsByType(auditUsers,workContractInfo.getProcessInstanceId(),2,1);
|
|
|
+
|
|
|
+ notifyRole = "总经理审批";
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ enname = "zjl";
|
|
|
+ vars.put("zjlList", auditUsers);
|
|
|
+ vars.put("zjlCount",auditUsers.size());
|
|
|
+ } else {
|
|
|
+ notifyRole = "调整报告";
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("zjl".equals(taskDefKey) && count.contains("2")) {
|
|
|
+ taskCount = "2";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(workContractInfo.getAct().getFlag())) {
|
|
|
+ notifyRole = "审批通过";
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ } else {
|
|
|
+ notifyRole = "调整合同信息";
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("modifyApply".equals(taskDefKey)&& count.contains("0")) {
|
|
|
+ notifyRole = "部门主任审批";
|
|
|
+ taskCount = "0";
|
|
|
+ exp = "pass";
|
|
|
+ workActivityProcess.setCount(0);
|
|
|
+ enname = "bmzr";
|
|
|
+ if (!"yes".equals(workContractInfo.getAct().getFlag())) {
|
|
|
+ workContractInfo.setContractState("3");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ //workActivityProcessService.updateProcess(workActivityProcess,workActivityMenu,key,taskCount,workContractInfo.getProcessInstanceId(),taskDefKey,"modifyApply",workContractInfo.getAct().getFlag(),comment, activities);
|
|
|
+ // 设置意见
|
|
|
+ workContractInfo.getAct().setComment(("yes".equals(workContractInfo.getAct().getFlag()) ? "[同意] " : "[驳回] ") + workContractInfo.getAct().getComment());
|
|
|
+ workContractInfo.preUpdate();
|
|
|
+ // 提交流程任务
|
|
|
+ vars.put(exp, "yes".equals(workContractInfo.getAct().getFlag())? true : false);
|
|
|
+ vars.put("passs", true);
|
|
|
+ workActivityProcessService.updateProcess(workActivityProcess,workActivityMenu,key,taskCount,workContractInfo.getProcessInstanceId(),taskDefKey,"modifyApply",workContractInfo.getAct().getFlag(),comment, activities);
|
|
|
+ // 提交流程任务
|
|
|
+ actTaskService.complete(workContractInfo.getAct().getTaskId(), workContractInfo.getAct().getProcInsId(), workContractInfo.getAct().getComment(), vars);
|
|
|
+ boolean state = actTaskService.isProcessEnd(workContractInfo.getAct().getProcInsId());
|
|
|
+ List<User> users = new ArrayList<>();
|
|
|
+ List<User> userList = new ArrayList<>();
|
|
|
+ //List<User> zjlList = dao.getUserByRole("总经理");
|
|
|
+ if(!state) {
|
|
|
+ str = "合同编号:" + workContractInfo.getContractNum() + ",主委托方:" + workContractInfo.getClient().getName() + ",合同所属部门:"+office.getName();
|
|
|
+ title = "合同名称:"+workContractInfo.getName();
|
|
|
+ users.add(workContractInfo.getCreateBy());
|
|
|
+ if ("yes".equals(workContractInfo.getAct().getFlag())) {
|
|
|
+ String titleStr = "合同【"+workContractInfo.getName() +"】登记完成";
|
|
|
+ String content = "合同【"+workContractInfo.getName() +"】登记完成,合同编号:" + workContractInfo.getContractNum();
|
|
|
+
|
|
|
+ workContractInfo.setContractState("5");
|
|
|
+ workContractInfo.setAccomplishDate(new Date());
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workContractInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(workContractInfo.getId(),
|
|
|
+ workContractInfo.getCreateBy(),
|
|
|
+ workContractInfo.getCompanyId(),
|
|
|
+ titleStr,
|
|
|
+ content,
|
|
|
+ "143",
|
|
|
+ "0",
|
|
|
+ "待通知",
|
|
|
+ notifyRole));
|
|
|
+ /*for (User user : zjlList) {
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(workContractInfo.getId(),
|
|
|
+ user,
|
|
|
+ workContractInfo.getCompanyId(),
|
|
|
+ titleStr,
|
|
|
+ content,
|
|
|
+ "143",
|
|
|
+ "0",
|
|
|
+ "待通知",
|
|
|
+ notifyRole));
|
|
|
+ }*/
|
|
|
+ //合同审批完成后随即发起归档申请
|
|
|
+ //合同审批完成后随即发起归档申请
|
|
|
+ WorkContractRecord workContractRecord = new WorkContractRecord();
|
|
|
+ workContractRecord.setStatus("2");
|
|
|
+ workContractRecord.setOfficeId(UserUtils.getSelectOffice().getId());
|
|
|
+ workContractRecord.setCompanyId(UserUtils.getSelectCompany().getId());
|
|
|
+ workContractRecord.setWorkContractInfo(workContractInfo);
|
|
|
+ Map<String, Object> variables = Maps.newHashMap();
|
|
|
+ String processInstanceId ="";
|
|
|
+ workContractRecordService.save(workContractRecord,variables,processInstanceId);
|
|
|
+ workContractInfo.setContractRecordState("2");
|
|
|
+
|
|
|
+ } else {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workContractInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ if (StringUtils.isNotBlank(workContractInfo.getContractState()) && !("3").equals(workContractInfo.getContractState())){
|
|
|
+ workContractInfo.setContractState("4");
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(workContractInfo.getId(),
|
|
|
+ workContractInfo.getCreateBy(),
|
|
|
+ workContractInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "143",
|
|
|
+ "0",
|
|
|
+ "待通知",
|
|
|
+ notifyRole));
|
|
|
+ /*for (User user : zjlList) {
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(workContractInfo.getId(),
|
|
|
+ user,
|
|
|
+ workContractInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "143",
|
|
|
+ "0",
|
|
|
+ "待通知",
|
|
|
+ notifyRole));
|
|
|
+ }*/
|
|
|
+ }
|
|
|
+ }
|
|
|
+ workActivityProcessService.deleteProcessIdAuditUsers(workContractInfo.getProcessInstanceId());
|
|
|
+ }else{
|
|
|
+ if (StringUtils.isNotBlank(workActivityMenu.getProcessType()) && !workActivityMenu.getProcessType().equals("newContractAudit")) {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workContractInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ //users.addAll(userList);
|
|
|
+ WorkProjectNotify workProjectNotify = UtilNotify
|
|
|
+ .saveNotify(workContractInfo.getId(),
|
|
|
+ new User(),
|
|
|
+ workContractInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "143",
|
|
|
+ "0",
|
|
|
+ "待审批",
|
|
|
+ notifyRole);
|
|
|
+ List<WorkProjectNotify> workProjectNotifys = activityService.getByFlagAndTaskDefKeyList(
|
|
|
+ activities,
|
|
|
+ workProjectNotify,
|
|
|
+ taskDefKey,
|
|
|
+ workContractInfo.getAct().getFlag(),
|
|
|
+ taskCount,
|
|
|
+ workContractInfo.getCreateBy(),
|
|
|
+ workContractInfo.getChargeCompany(),
|
|
|
+ "2");
|
|
|
+ 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 ("gzr".equals(taskDefKey)){
|
|
|
+ extras.put("type","7001");
|
|
|
+ }else {
|
|
|
+ extras.put("type","7002");
|
|
|
+ }
|
|
|
+ extras.put("id",workProjectNotify.getId());
|
|
|
+ extras.put("procDefKey","143");
|
|
|
+ UserUtils.pushInfoToApp(title,str,extras,workProjectNotify1.getUser().getId());
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ } else {
|
|
|
+ if (!"yes".equals(workContractInfo.getAct().getFlag())) {//驳回待办展示
|
|
|
+ title = "合同【"+workContractInfo.getName() +"】登记被驳回";
|
|
|
+ str = "合同【"+workContractInfo.getName() +"】登记被驳回,请选择重新申请或作废";
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workContractInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ //users.addAll(userList);
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(workContractInfo.getId(),
|
|
|
+ workContractInfo.getCreateBy(),
|
|
|
+ workContractInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "143",
|
|
|
+ "0",
|
|
|
+ "重新申请",
|
|
|
+ notifyRole));
|
|
|
+ users.add( workContractInfo.getCreateBy());
|
|
|
+ } else {
|
|
|
+ if (StringUtils.isNotBlank(enname)) {//驳回重新申请待办展示
|
|
|
+ title = "合同【"+workContractInfo.getName() +"】登记,待审批";
|
|
|
+ str = "合同【"+workContractInfo.getName() +"】登记,待审批";
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workContractInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ //users.addAll(userList1);
|
|
|
+ WorkProjectNotify workProjectNotify = UtilNotify
|
|
|
+ .saveNotify(workContractInfo.getId(),
|
|
|
+ new User(),
|
|
|
+ workContractInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "143",
|
|
|
+ "0",
|
|
|
+ "待审批",
|
|
|
+ notifyRole);
|
|
|
+ users.addAll(auditUsers);
|
|
|
+ for (User user1:auditUsers){
|
|
|
+ workProjectNotify.setUser(user1);
|
|
|
+ workProjectNotify.setId("");
|
|
|
+ workProjectNotify.setIsNewRecord(false);
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(workProjectNotify);
|
|
|
+ if (!"modifyApply".equals(taskDefKey)){
|
|
|
+ Map<String,Object> extras = new HashMap<>();
|
|
|
+ if ("gzr".equals(taskDefKey)){
|
|
|
+ extras.put("type","7001");
|
|
|
+ }else {
|
|
|
+ extras.put("type","7002");
|
|
|
+ }
|
|
|
+ extras.put("id",workProjectNotify.getId());
|
|
|
+ extras.put("procDefKey","143");
|
|
|
+ UserUtils.pushInfoToApp(title,str,extras,user1.getId());
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }else {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(workContractInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ users.addAll(userList);
|
|
|
+ users.add(workContractInfo.getCreateBy());
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(workContractInfo.getId(),
|
|
|
+ workContractInfo.getCreateBy(),
|
|
|
+ workContractInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "143",
|
|
|
+ "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());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ workContractInfoDao.update(workContractInfo);
|
|
|
+ return "保存审核意见成功!";
|
|
|
+ }
|
|
|
+}
|