|
@@ -0,0 +1,830 @@
|
|
|
+package com.jeeplus.modules.projectAssess.service;
|
|
|
+
|
|
|
+import com.google.common.collect.Maps;
|
|
|
+import com.jeeplus.common.persistence.Page;
|
|
|
+import com.jeeplus.common.service.CrudService;
|
|
|
+import com.jeeplus.common.utils.*;
|
|
|
+import com.jeeplus.modules.act.entity.Act;
|
|
|
+import com.jeeplus.modules.act.service.ActTaskService;
|
|
|
+import com.jeeplus.modules.projectAssess.dao.ProjectAssessDao;
|
|
|
+import com.jeeplus.modules.projectAssess.entity.ProjectAssessInfo;
|
|
|
+import com.jeeplus.modules.projectrecord.dao.ProjectRecordsDao;
|
|
|
+import com.jeeplus.modules.projectrecord.dao.WorkProjectUserDao;
|
|
|
+import com.jeeplus.modules.projectrecord.entity.ProjectRecords;
|
|
|
+import com.jeeplus.modules.projectrecord.enums.ProjectStatusEnum;
|
|
|
+import com.jeeplus.modules.projectrecord.service.ProjectRecordsService;
|
|
|
+import com.jeeplus.modules.serialnum.service.SerialNumTplService;
|
|
|
+import com.jeeplus.modules.sys.entity.MainDictDetail;
|
|
|
+import com.jeeplus.modules.sys.entity.Office;
|
|
|
+import com.jeeplus.modules.sys.entity.Role;
|
|
|
+import com.jeeplus.modules.sys.entity.User;
|
|
|
+import com.jeeplus.modules.sys.service.OfficeService;
|
|
|
+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.workclientinfo.entity.WorkClientInfo;
|
|
|
+import com.jeeplus.modules.workclientinfo.entity.WorkClientLinkman;
|
|
|
+import com.jeeplus.modules.workcontractinfo.entity.WorkContractInfo;
|
|
|
+import com.jeeplus.modules.workcontractinfo.service.WorkContractInfoService;
|
|
|
+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.IdentityService;
|
|
|
+import org.activiti.engine.RuntimeService;
|
|
|
+import org.activiti.engine.runtime.ProcessInstance;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.stereotype.Service;
|
|
|
+import org.springframework.transaction.annotation.Propagation;
|
|
|
+import org.springframework.transaction.annotation.Transactional;
|
|
|
+
|
|
|
+import java.util.ArrayList;
|
|
|
+import java.util.HashMap;
|
|
|
+import java.util.List;
|
|
|
+import java.util.Map;
|
|
|
+
|
|
|
+/**
|
|
|
+ * 项目评估Service
|
|
|
+ * @author 徐滕
|
|
|
+ * @version 2020-05-08
|
|
|
+ */
|
|
|
+@Service
|
|
|
+@Transactional(readOnly = true)
|
|
|
+public class ProjectAssessService extends CrudService<ProjectAssessDao, ProjectAssessInfo> {
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IdentityService identityService;
|
|
|
+ @Autowired
|
|
|
+ private WorkActivityMenuService workActivityMenuService;
|
|
|
+ @Autowired
|
|
|
+ private ActTaskService actTaskService;
|
|
|
+ @Autowired
|
|
|
+ private RuntimeService runtimeService;
|
|
|
+ @Autowired
|
|
|
+ private WorkActivityProcessService workActivityProcessService;
|
|
|
+ @Autowired
|
|
|
+ private WorkProjectNotifyService workProjectNotifyService;
|
|
|
+ @Autowired
|
|
|
+ private SerialNumTplService serialNumTplService;
|
|
|
+ @Autowired
|
|
|
+ protected ProjectRecordsService projectRecordsService;
|
|
|
+ @Autowired
|
|
|
+ protected WorkContractInfoService workContractInfoService;
|
|
|
+ @Autowired
|
|
|
+ protected OfficeService officeService;
|
|
|
+ @Autowired
|
|
|
+ private ActivityService activityService;
|
|
|
+ @Autowired
|
|
|
+ private ProjectRecordsDao projectRecordsDao;
|
|
|
+ @Autowired
|
|
|
+ private WorkActivityProcessDao workActivityProcessDao;
|
|
|
+ @Autowired
|
|
|
+ private WorkProjectUserDao workProjectUserDao;
|
|
|
+
|
|
|
+ public ProjectAssessInfo get(String id) {
|
|
|
+ return super.get(id);
|
|
|
+ }
|
|
|
+
|
|
|
+ public Page<ProjectAssessInfo> findPage(Page<ProjectAssessInfo> page, ProjectAssessInfo projectAssessInfo) {
|
|
|
+ //设置数据权限
|
|
|
+ if(!UserUtils.getUser().isAdmin()) {
|
|
|
+ String dataScopeSql = dataScopeFilterOR(projectAssessInfo.getCurrentUser(), "o", "u", "s", MenuStatusEnum.WORK_RECORDS.getValue());
|
|
|
+ projectAssessInfo.getSqlMap().put("dsf", dataScopeSql);
|
|
|
+ }
|
|
|
+ int count = dao.queryCount(projectAssessInfo);
|
|
|
+ page.setCount(count);
|
|
|
+ page.setCountFlag(false);
|
|
|
+ projectAssessInfo.setPage(page);
|
|
|
+ List<ProjectAssessInfo> projectAssessList = findList(projectAssessInfo);
|
|
|
+ if (null != projectAssessList){
|
|
|
+ for (ProjectAssessInfo projectAssess : projectAssessList) {
|
|
|
+ List<MainDictDetail> informationSupplyTypeList = DictUtils.getMainDictList("information_supply_type");
|
|
|
+ for (MainDictDetail informationSupplyType : informationSupplyTypeList) {
|
|
|
+ if (projectAssess.getInformationSupplyType().equals(informationSupplyType.getValue().toString())){
|
|
|
+ projectAssess.setInformationSupplyType(informationSupplyType.getLabel());
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ List<MainDictDetail> projectTypeList = DictUtils.getMainDictList("project_type");
|
|
|
+ for (MainDictDetail projectType : projectTypeList) {
|
|
|
+ if (projectAssess.getProjectType().equals(projectType.getValue().toString())){
|
|
|
+ projectAssess.setProjectType(projectType.getLabel());
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ page.setList(projectAssessList);
|
|
|
+ return page;
|
|
|
+ }
|
|
|
+
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public String saveProjectAssess(ProjectAssessInfo projectAssessInfo) {
|
|
|
+ save(projectAssessInfo);
|
|
|
+ return this.startAudit(projectAssessInfo,projectAssessInfo.getProcessInstanceId());
|
|
|
+ }
|
|
|
+
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public void saveProjectAssessTstore(ProjectAssessInfo projectAssessInfo,ProjectStatusEnum status) {
|
|
|
+ Office company= new Office();
|
|
|
+ Office office = new Office();
|
|
|
+ company.setId(UserUtils.getUser().getCompany().getId());
|
|
|
+ office.setId(UserUtils.getUser().getOffice().getId());
|
|
|
+ projectAssessInfo.setCompany(company);
|
|
|
+ projectAssessInfo.setOffice(office);
|
|
|
+
|
|
|
+ Integer oldStatus = projectAssessInfo.getStatus();
|
|
|
+ projectAssessInfo.setStatus(status.getValue());
|
|
|
+ User createBy = projectAssessInfo.getCreateBy();
|
|
|
+ if(createBy != null){
|
|
|
+ createBy = UserUtils.get(createBy.getId());
|
|
|
+ }else {
|
|
|
+ createBy = UserUtils.getUser();
|
|
|
+ }
|
|
|
+ projectAssessInfo.setCreateBy(createBy);
|
|
|
+ if(projectAssessInfo.getStatus()==ProjectStatusEnum.INVALID.getValue()){
|
|
|
+ projectAssessInfo.setId(IdGen.uuid());
|
|
|
+ dao.insert(projectAssessInfo);
|
|
|
+ }else {
|
|
|
+ super.save(projectAssessInfo);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public void save(ProjectAssessInfo projectAssessInfo) {
|
|
|
+ long t1 = System.currentTimeMillis();
|
|
|
+ preSave(projectAssessInfo);
|
|
|
+ if (StringUtils.isNotBlank(projectAssessInfo.getId())){
|
|
|
+ dao.update(projectAssessInfo);
|
|
|
+ projectAssessInfo.setProjectIdStr(projectAssessInfo.getProjectId());
|
|
|
+ }else{
|
|
|
+ super.save(projectAssessInfo);
|
|
|
+ }
|
|
|
+ logger.info("保存项目评估申请耗时:{}ms",System.currentTimeMillis()-t1);
|
|
|
+ }
|
|
|
+
|
|
|
+ private void preSave(ProjectAssessInfo projectAssessInfo) {
|
|
|
+ if(projectAssessInfo.getOffice()==null|| StringUtils.isBlank(projectAssessInfo.getOffice().getId())){
|
|
|
+ projectAssessInfo.setOffice(UserUtils.getSelectOffice());
|
|
|
+ }
|
|
|
+ if(projectAssessInfo.getCompany()==null||StringUtils.isBlank(projectAssessInfo.getCompany().getId())){
|
|
|
+ projectAssessInfo.setCompany(UserUtils.getSelectCompany());
|
|
|
+ }
|
|
|
+ if (StringUtils.isBlank(projectAssessInfo.getNum())){
|
|
|
+ String serialNum = serialNumTplService.genSerialNum(UserUtils.getUser().getCompany(), projectAssessInfo.ASSESS_BIZCODE);
|
|
|
+ projectAssessInfo.setNum(serialNum);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 启动审批流程
|
|
|
+ */
|
|
|
+ private String startAudit(ProjectAssessInfo projectAssessInfo, String processInstanceId){
|
|
|
+ long t1 = System.currentTimeMillis();
|
|
|
+ Map<String, Object> variables = new HashMap<String, Object>();
|
|
|
+ identityService.setAuthenticatedUserId(projectAssessInfo.getCurrentUser().getId());
|
|
|
+ String contentStr = "申请编号:"+projectAssessInfo.getNum()+",申请日期:"+ DateUtils.formatDate(projectAssessInfo.getCreateDate());
|
|
|
+ ProjectRecords projectRecords = projectRecordsDao.get(projectAssessInfo.getProjectIdStr());
|
|
|
+ String titleStr = "项目名称:"+ projectRecords.getProjectName();
|
|
|
+
|
|
|
+ String businessKey = projectAssessInfo.getId();
|
|
|
+ Office office = UserUtils.getSelectOffice();
|
|
|
+ WorkActivityMenu workActivityMenu = workActivityMenuService.findByParentAndOffice("ggh3125fwef194582bdda9abcew750904", office);
|
|
|
+ // 启动流程
|
|
|
+ String processType = workActivityMenu.getProcessType();
|
|
|
+ StringBuffer buffer = new StringBuffer();
|
|
|
+ Activity activity = new Activity();
|
|
|
+ WorkProjectNotify workProjectNotify = UtilNotify
|
|
|
+ .saveNotify(projectAssessInfo.getId(),
|
|
|
+ null,
|
|
|
+ projectAssessInfo.getCompany().getId(),
|
|
|
+ titleStr,
|
|
|
+ contentStr,
|
|
|
+ "137",
|
|
|
+ "0",
|
|
|
+ "待审批",
|
|
|
+ ""
|
|
|
+ );
|
|
|
+
|
|
|
+ List<User> users = new ArrayList<>();
|
|
|
+ //总工
|
|
|
+ List<User> bzshbList = UserUtils.getByRoleActivityEnname("bzshb",3,office.getId(),"23",projectAssessInfo.getCreateBy());
|
|
|
+ //获取项目负责人信息
|
|
|
+ List<User> bmzrList = dao.getProjectUser(projectAssessInfo.getProjectIdStr());
|
|
|
+ //财务
|
|
|
+ List<User> cwzgList = UserUtils.getByRoleActivityEnname("cwzg",3,office.getId(),"23",projectAssessInfo.getCreateBy());
|
|
|
+ //副总经理
|
|
|
+ List<User> fgldList = UserUtils.getByRoleActivityEnname("fzjl",3,office.getId(),"23",projectAssessInfo.getCreateBy());
|
|
|
+ //总经理
|
|
|
+ List<User> zjlList = UserUtils.getByRoleActivityEnname("zjl",3,office.getId(),"23",projectAssessInfo.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(),"11",projectAssessInfo.getCreateBy());
|
|
|
+ if (enusers.size()==0){
|
|
|
+ projectAssessInfo.setStatus(ProjectStatusEnum.TSTORE.getValue());
|
|
|
+ this.updateStateById(projectAssessInfo);
|
|
|
+ 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(),"11",projectAssessInfo.getCreateBy());
|
|
|
+ }
|
|
|
+ //人员审批
|
|
|
+ if (StringUtils.isNotBlank(activity.getUser().getId())) {
|
|
|
+ users.add(activity.getUser());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ workProjectNotify.setId("");
|
|
|
+ } else {
|
|
|
+ if (bmzrList.size()==0){
|
|
|
+ projectAssessInfo.setStatus(ProjectStatusEnum.TSTORE.getValue());
|
|
|
+ this.updateStateById(projectAssessInfo);
|
|
|
+ return "流程审批人不能为空,部门负责人下无用户,请联系管理员!";
|
|
|
+ }
|
|
|
+ variables.put("bzshbList", bzshbList);
|
|
|
+ variables.put("bzshbCount",bzshbList.size());
|
|
|
+ processType = "projectAssess";
|
|
|
+ users.addAll(bzshbList);
|
|
|
+ }
|
|
|
+ List<String> userIds = new ArrayList<>(users.size());
|
|
|
+ for (User u : users){
|
|
|
+ userIds.add(u.getId());
|
|
|
+ workProjectNotify.setUser(u);
|
|
|
+ workProjectNotify.setId("");
|
|
|
+ workProjectNotify.setNotifyRole("总工审批");
|
|
|
+ workProjectNotifyService.save(workProjectNotify);
|
|
|
+ Map<String,Object> extras = new HashMap<>();
|
|
|
+ extras.put("type","7002");
|
|
|
+ extras.put("procDefKey","137");
|
|
|
+ extras.put("id",workProjectNotify.getId());
|
|
|
+ UserUtils.pushInfoToApp(titleStr, contentStr,extras,u.getId());
|
|
|
+ }
|
|
|
+ long t2 = System.currentTimeMillis();
|
|
|
+ UserUtils.pushIm(userIds,contentStr);
|
|
|
+ logger.info("项目评估推送消息耗时:{}ms",System.currentTimeMillis()-t2);
|
|
|
+
|
|
|
+ variables.put("busId", businessKey);
|
|
|
+ variables.put("type", processType);
|
|
|
+ variables.put("title", "审批单:" + projectAssessInfo.getNum());//设置标题;
|
|
|
+
|
|
|
+ ProcessInstance processInstance = runtimeService.startProcessInstanceByKey(processType, businessKey, variables);
|
|
|
+ if (org.apache.commons.lang3.StringUtils.isNotBlank(processInstanceId)) {
|
|
|
+ workActivityProcessService.updateProcessInstanceId(processInstance.getId(),processInstanceId);
|
|
|
+ workActivityProcessService.deleteProcessInstanceId(processInstanceId);
|
|
|
+ workActivityProcessService.deleteProcessIdAuditUsers(processInstanceId);
|
|
|
+ }
|
|
|
+ List<Activity> list = workActivityMenu.getActivities();
|
|
|
+ if (list != null && list.size() != 0) {
|
|
|
+ workActivityProcessService.saveList(list, processInstance.getId());
|
|
|
+ } else {
|
|
|
+ WorkActivityProcess workActivityProcess = new WorkActivityProcess();
|
|
|
+ workActivityProcess.setProcessKey(processType);
|
|
|
+ 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);
|
|
|
+ workActivityProcessService.insertAuditsByType(bzshbList,processInstance.getId(),1,1);
|
|
|
+ workActivityProcessService.insertAuditsByType(bmzrList,processInstance.getId(),2,0);
|
|
|
+ workActivityProcessService.insertAuditsByType(cwzgList,processInstance.getId(),3,0);
|
|
|
+ workActivityProcessService.insertAuditsByType(fgldList,processInstance.getId(),4,0);
|
|
|
+ workActivityProcessService.insertAuditsByType(zjlList,processInstance.getId(),5,0);
|
|
|
+ }
|
|
|
+ projectAssessInfo.setProcessInstanceId(processInstance.getId());
|
|
|
+ projectAssessInfo.setStatus(ProjectStatusEnum.IN_APRL.getValue());
|
|
|
+ dao.updateProcessIdAndStatus(projectAssessInfo);
|
|
|
+ logger.info("启动项目评估审批流程耗时:{}ms",System.currentTimeMillis()-t1);
|
|
|
+ return "";
|
|
|
+ }
|
|
|
+
|
|
|
+ private void updateStateById(ProjectAssessInfo projectAssessInfo) {
|
|
|
+ dao.updateProcessIdAndStatus(projectAssessInfo);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 获取项目负责人信息
|
|
|
+ * @param projectId
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public List<User> getMasterUserList(String projectId){
|
|
|
+ return dao.getProjectUser(projectId);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 获取部门名称
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public Office getOfficeName(String projectId) {
|
|
|
+ ProjectRecords projectRecords = projectRecordsService.getInfo(projectId);
|
|
|
+ WorkContractInfo workContractInfo = workContractInfoService.get(projectRecords.getWorkContractInfo().getId());
|
|
|
+ Office office = new Office();
|
|
|
+ if(workContractInfo!=null){
|
|
|
+ String oid = workContractInfo.getChargeCompany();
|
|
|
+ office = officeService.get(oid);
|
|
|
+ if(office!=null){
|
|
|
+ return office;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+
|
|
|
+ public ProjectAssessInfo queryProjectAssessDetail(ProjectAssessInfo projectAssess){
|
|
|
+ ProjectAssessInfo projectAssessInfo = this.get(projectAssess.getId());
|
|
|
+ if (null != projectAssessInfo){
|
|
|
+ List<MainDictDetail> informationSupplyTypeList = DictUtils.getMainDictList("information_supply_type");
|
|
|
+ for (MainDictDetail informationSupplyType : informationSupplyTypeList) {
|
|
|
+ if (projectAssessInfo.getInformationSupplyType().equals(informationSupplyType.getValue().toString())){
|
|
|
+ projectAssessInfo.setInformationSupplyType(informationSupplyType.getLabel());
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ List<MainDictDetail> projectTypeList = DictUtils.getMainDictList("project_type");
|
|
|
+ for (MainDictDetail projectType : projectTypeList) {
|
|
|
+ if (projectAssessInfo.getProjectType().equals(projectType.getValue().toString())){
|
|
|
+ projectAssessInfo.setProjectType(projectType.getLabel());
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (StringUtils.isNotBlank(projectAssessInfo.getProjectId())){
|
|
|
+ Office office = this.getOfficeName(projectAssessInfo.getProjectId());
|
|
|
+ if (null != office){
|
|
|
+ projectAssessInfo.setOfficeName(office.getTopCompany());
|
|
|
+ }else{
|
|
|
+ projectAssessInfo.setOfficeName("");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ projectAssessInfo.setHome("home");
|
|
|
+ return projectAssessInfo;
|
|
|
+ }
|
|
|
+
|
|
|
+ public ProjectAssessInfo queryProjectAssess(ProjectAssessInfo projectAssess){
|
|
|
+ ProjectAssessInfo projectAssessInfo = this.get(projectAssess.getId());
|
|
|
+ if (StringUtils.isNotBlank(projectAssessInfo.getProjectId())){
|
|
|
+ Office office = this.getOfficeName(projectAssessInfo.getProjectId());
|
|
|
+ if (null != office){
|
|
|
+ projectAssessInfo.setOfficeName(office.getTopCompany());
|
|
|
+ }else{
|
|
|
+ projectAssessInfo.setOfficeName("");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ projectAssessInfo.setHome("home");
|
|
|
+ return projectAssessInfo;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 审核流程
|
|
|
+ */
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public String auditProjectAssess(ProjectAssessInfo projectAssessInfo, List<User> auditUsers) {
|
|
|
+ String str = "申请编号:"+projectAssessInfo.getNum()+",申请日期:"+ DateUtils.formatDate(projectAssessInfo.getCreateDate());
|
|
|
+ ProjectRecords projectRecords = projectRecordsDao.get(projectAssessInfo.getProjectId());
|
|
|
+ String title = "项目名称:"+ projectRecords.getProjectName();
|
|
|
+ // 对不同环节的业务逻辑进行操作
|
|
|
+ String taskDefKey = projectAssessInfo.getAct().getTaskDefKey();
|
|
|
+ if (!"modifyApply".equals(taskDefKey) && !taskDefKey.contains("audit")) {
|
|
|
+ actTaskService.claim(projectAssessInfo.getAct().getTaskId(), UserUtils.getUser().getId());
|
|
|
+ }else {
|
|
|
+ projectAssessInfo.getAct().setFlag("yes");
|
|
|
+ }
|
|
|
+ String comment = "";
|
|
|
+ if (ProjectStatusEnum.REJECTED.getValue() == projectAssessInfo.getStatus()){
|
|
|
+ comment = ("yes".equals(projectAssessInfo.getAct().getFlag())?"[重新申请] ":"[已撤销] ");
|
|
|
+ }else {
|
|
|
+ comment = ("yes".equals(projectAssessInfo.getAct().getFlag())?"[同意] ":"[驳回] ")+ projectAssessInfo.getAct().getComment();
|
|
|
+ }
|
|
|
+ //yes 的时候状态为审核通过 否则为未通过
|
|
|
+ //1 审核中 2 未通过
|
|
|
+ projectAssessInfo.setStatus(("yes".equals(projectAssessInfo.getAct().getFlag()) ? ProjectStatusEnum.IN_APRL.getValue() : ProjectStatusEnum.REJECTED.getValue()));
|
|
|
+ Map<String, Object> vars = Maps.newHashMap();
|
|
|
+ //业务逻辑对应的条件表达式
|
|
|
+ String exp = "";
|
|
|
+ String taskCount = "";
|
|
|
+ String notifyRole = "";
|
|
|
+ int key = 0;
|
|
|
+ String enname = "";
|
|
|
+ List<Activity> activitieList = activityService.getByProcessInstanceId(projectAssessInfo.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(projectAssessInfo.getProcessInstanceId());
|
|
|
+ List<WorkActivityProcess> workActivityProcesses = workActivityProcessService.findList(selectProcess);
|
|
|
+ List<Activity> activities = workActivityMenu.getActivities();
|
|
|
+ if (StringUtils.isNotBlank(workActivityMenu.getProcessType()) && !workActivityMenu.getProcessType().equals("projectAssess")) {
|
|
|
+ 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(projectAssessInfo.getAct().getFlag())) {
|
|
|
+ notifyRole = "调整项目评审信息";
|
|
|
+ projectAssessInfo.setStatus(ProjectStatusEnum.REJECTED.getValue());
|
|
|
+ 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")){
|
|
|
+ taskCount = "0";
|
|
|
+ exp = "pass";
|
|
|
+ workActivityProcess.setId("");
|
|
|
+ workActivityProcess.setCount(0);
|
|
|
+ if (!"yes".equals(projectAssessInfo.getAct().getFlag())) {
|
|
|
+ projectAssessInfo.setStatus(ProjectStatusEnum.RECALL.getValue());
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ } else {
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ workActivityMenu.setProcessType("projectAssess");
|
|
|
+ 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 ("bzshb".equals(taskDefKey) && count.contains("1")) {
|
|
|
+ taskCount = "1";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(projectAssessInfo.getAct().getFlag())) {
|
|
|
+ workActivityProcessService.insertAuditsByType(auditUsers,projectAssessInfo.getProcessInstanceId(),2,1);
|
|
|
+
|
|
|
+ notifyRole = "项目负责人审核";
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ enname = "master";
|
|
|
+ vars.put("masterCount",auditUsers.size());
|
|
|
+ vars.put("masterList", auditUsers);
|
|
|
+ } else {
|
|
|
+ notifyRole = "调整申请2";
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("master".equals(taskDefKey) && count.contains("2")) {
|
|
|
+ taskCount = "2";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(projectAssessInfo.getAct().getFlag())) {
|
|
|
+ workActivityProcessService.insertAuditsByType(auditUsers,projectAssessInfo.getProcessInstanceId(),3,1);
|
|
|
+
|
|
|
+ notifyRole = "财务审核";
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ enname = "cwzg";
|
|
|
+ vars.put("cwzgCount",auditUsers.size());
|
|
|
+ vars.put("cwzgList", auditUsers);
|
|
|
+ } else {
|
|
|
+ notifyRole = "调整申请3";
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("cwzg".equals(taskDefKey) && count.contains("3")) {
|
|
|
+ taskCount = "3";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(projectAssessInfo.getAct().getFlag())) {
|
|
|
+ workActivityProcessService.insertAuditsByType(auditUsers,projectAssessInfo.getProcessInstanceId(),4,1);
|
|
|
+
|
|
|
+ notifyRole = "副总经理审核";
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ enname = "fzjl";
|
|
|
+ vars.put("fzjlCount",auditUsers.size());
|
|
|
+ vars.put("fzjlList", auditUsers);
|
|
|
+ } else {
|
|
|
+ notifyRole = "调整申请4";
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("fzjl".equals(taskDefKey) && count.contains("4")) {
|
|
|
+ taskCount = "4";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(projectAssessInfo.getAct().getFlag())) {
|
|
|
+ workActivityProcessService.insertAuditsByType(auditUsers,projectAssessInfo.getProcessInstanceId(),5,1);
|
|
|
+
|
|
|
+ notifyRole = "总经理审核";
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ enname = "zjl";
|
|
|
+ vars.put("zjlCount",auditUsers.size());
|
|
|
+ vars.put("zjlList", auditUsers);
|
|
|
+ } else {
|
|
|
+ notifyRole = "调整申请";
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ vars.put("pass",false);
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("zjl".equals(taskDefKey) && count.contains("5")) {
|
|
|
+ taskCount = "5";
|
|
|
+ exp = "pass";
|
|
|
+ if ("yes".equals(projectAssessInfo.getAct().getFlag())) {
|
|
|
+ notifyRole = "审批通过";
|
|
|
+ workActivityProcess.setIsApproval("1");
|
|
|
+ } else {
|
|
|
+ notifyRole = "调整项目评估信息";
|
|
|
+ workActivityProcess.setIsApproval("2");
|
|
|
+ vars.put("pass",false);
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("modifyApply".equals(taskDefKey)&& count.contains("0")) {
|
|
|
+ notifyRole = "部门负责人审批";
|
|
|
+ taskCount = "0";
|
|
|
+ exp = "pass";
|
|
|
+ workActivityProcess.setCount(0);
|
|
|
+ enname = "bzshb";
|
|
|
+ if (!"yes".equals(projectAssessInfo.getAct().getFlag())) {
|
|
|
+ projectAssessInfo.setStatus(ProjectStatusEnum.RECALL.getValue());
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ } else if ("apply_end".equals(taskDefKey)) {
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+ // 设置意见
|
|
|
+ projectAssessInfo.getAct().setComment(("yes".equals(projectAssessInfo.getAct().getFlag()) ? "[同意] " : "[驳回] ") + projectAssessInfo.getAct().getComment());
|
|
|
+ projectAssessInfo.preUpdate();
|
|
|
+ // 提交流程任务
|
|
|
+ vars.put(exp, "yes".equals(projectAssessInfo.getAct().getFlag()) ? true : false);
|
|
|
+ vars.put("passs", true);
|
|
|
+ workActivityProcessService.updateProcess(workActivityProcess,workActivityMenu,key,taskCount, projectAssessInfo.getProcessInstanceId(),taskDefKey,"modifyApply", projectAssessInfo.getAct().getFlag(),comment, activities);
|
|
|
+ // 提交流程任务
|
|
|
+ actTaskService.complete(projectAssessInfo.getAct().getTaskId(), projectAssessInfo.getAct().getProcInsId(), projectAssessInfo.getAct().getComment(), vars);
|
|
|
+ boolean state = actTaskService.isProcessEnd(projectAssessInfo.getAct().getProcInsId());
|
|
|
+ List<User> users = new ArrayList<>();
|
|
|
+ List<User> userList = new ArrayList<>();
|
|
|
+ if (!state) {
|
|
|
+ users.add(projectAssessInfo.getCreateBy());
|
|
|
+ if ("yes".equals(projectAssessInfo.getAct().getFlag())) {
|
|
|
+ projectAssessInfo.setStatus(ProjectStatusEnum.SIGNED.getValue());
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(projectAssessInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(projectAssessInfo.getId(),
|
|
|
+ projectAssessInfo.getCreateBy(),
|
|
|
+ projectAssessInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "137",
|
|
|
+ "0",
|
|
|
+ "待通知",
|
|
|
+ notifyRole));
|
|
|
+
|
|
|
+ } else {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(projectAssessInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ if (ProjectStatusEnum.RECALL.getValue() != projectAssessInfo.getStatus()){
|
|
|
+ projectAssessInfo.setStatus(ProjectStatusEnum.REJECTED.getValue());
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(projectAssessInfo.getId(),
|
|
|
+ projectAssessInfo.getCreateBy(),
|
|
|
+ projectAssessInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "137",
|
|
|
+ "0",
|
|
|
+ "待通知",
|
|
|
+ notifyRole));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ workActivityProcessService.deleteProcessIdAuditUsers(projectAssessInfo.getProcessInstanceId());
|
|
|
+ } else {
|
|
|
+ if (StringUtils.isNotBlank(workActivityMenu.getProcessType()) && !workActivityMenu.getProcessType().equals("projectAssess")) {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(projectAssessInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ //users.addAll(userList);
|
|
|
+ WorkProjectNotify workProjectNotify = UtilNotify
|
|
|
+ .saveNotify(projectAssessInfo.getId(),
|
|
|
+ new User(),
|
|
|
+ projectAssessInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "137",
|
|
|
+ "0",
|
|
|
+ "待审批",
|
|
|
+ notifyRole);
|
|
|
+ List<WorkProjectNotify> workProjectNotifys = activityService.getByFlagAndTaskDefKeyList(
|
|
|
+ activities,
|
|
|
+ workProjectNotify,
|
|
|
+ taskDefKey,
|
|
|
+ projectAssessInfo.getAct().getFlag(),
|
|
|
+ taskCount,
|
|
|
+ projectAssessInfo.getCreateBy(),
|
|
|
+ projectAssessInfo.getOffice().getId(),
|
|
|
+ "137");
|
|
|
+ for (WorkProjectNotify workProjectNotify1:workProjectNotifys){
|
|
|
+ users.add(workProjectNotify1.getUser());
|
|
|
+ workProjectNotify1.setId("");
|
|
|
+ workProjectNotify1.setIsNewRecord(false);
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(workProjectNotify1);
|
|
|
+ }
|
|
|
+
|
|
|
+ } else {
|
|
|
+ if (!"yes".equals(projectAssessInfo.getAct().getFlag())) {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(projectAssessInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ //users.addAll(userList);
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(projectAssessInfo.getId(),
|
|
|
+ projectAssessInfo.getCreateBy(),
|
|
|
+ projectAssessInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "137",
|
|
|
+ "0",
|
|
|
+ "重新申请",
|
|
|
+ notifyRole));
|
|
|
+ users.add( projectAssessInfo.getCreateBy());
|
|
|
+ } else {
|
|
|
+ if (StringUtils.isNotBlank(enname)) {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(projectAssessInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ //users.addAll(userList1);
|
|
|
+ WorkProjectNotify workProjectNotify = UtilNotify
|
|
|
+ .saveNotify(projectAssessInfo.getId(),
|
|
|
+ new User(),
|
|
|
+ projectAssessInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "137",
|
|
|
+ "0",
|
|
|
+ "待审批",
|
|
|
+ notifyRole);
|
|
|
+ users.addAll(auditUsers);
|
|
|
+ for (User user1:auditUsers){
|
|
|
+ workProjectNotify.setUser(user1);
|
|
|
+ workProjectNotify.setId("");
|
|
|
+ workProjectNotify.setIsNewRecord(false);
|
|
|
+ workProjectNotifyService.save(workProjectNotify);
|
|
|
+ Map<String,Object> extras = new HashMap<>();
|
|
|
+ if(enname.contains("bzshb")||enname.contains("master")||enname.contains("cwzg")||enname.contains("fzjl")||enname.contains("zjl")) {
|
|
|
+ extras.put("type", "7002");
|
|
|
+ }else {
|
|
|
+ extras.put("type", "7001");
|
|
|
+ }
|
|
|
+ extras.put("procDefKey","137");
|
|
|
+ extras.put("id",workProjectNotify.getId());
|
|
|
+ UserUtils.pushInfoToApp(title, str,extras,user1.getId());
|
|
|
+ }
|
|
|
+ }else {
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(projectAssessInfo.getId());
|
|
|
+ userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ users.add(projectAssessInfo.getCreateBy());
|
|
|
+ workProjectNotifyService
|
|
|
+ .save(UtilNotify
|
|
|
+ .saveNotify(projectAssessInfo.getId(),
|
|
|
+ projectAssessInfo.getCreateBy(),
|
|
|
+ projectAssessInfo.getCompanyId(),
|
|
|
+ title,
|
|
|
+ str,
|
|
|
+ "137",
|
|
|
+ "0",
|
|
|
+ "重新申请",
|
|
|
+ notifyRole));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (StringUtils.isNotBlank(title) && users!=null && users.size()!=0) {
|
|
|
+ for (User u : users) {
|
|
|
+ UserUtils.pushIm(u.getId(),title);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (StringUtils.isNotBlank(title) && userList!=null && userList.size()!=0) {
|
|
|
+ for (User u : userList) {
|
|
|
+ UserUtils.pushMeIm(u.getId());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ projectAssessInfo.setInformationSupplyType(null);
|
|
|
+ projectAssessInfo.setProjectType(null);
|
|
|
+ dao.update(projectAssessInfo);
|
|
|
+ return "保存审核意见成功!";
|
|
|
+ }
|
|
|
+
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public void cancelProcess(ProjectAssessInfo projectAssessInfo) throws Exception {
|
|
|
+ WorkActivityProcess process = new WorkActivityProcess();
|
|
|
+ process.setProcessInstanceId(projectAssessInfo.getProcessInstanceId());
|
|
|
+ process.setIsApproval("0");
|
|
|
+ WorkActivityProcess workActivityProcess = new WorkActivityProcess();
|
|
|
+ workActivityProcess.setProcessInstanceId(projectAssessInfo.getProcessInstanceId());
|
|
|
+ List<WorkActivityProcess> processList = workActivityProcessService.findList(workActivityProcess);
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(projectAssessInfo.getId());
|
|
|
+ List<User> userList = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ if (userList!=null && userList.size()!=0) {
|
|
|
+ for (User u : userList) {
|
|
|
+ User user = UserUtils.get(u.getId());
|
|
|
+ UserUtils.pushIm(u.getId(),"申请人 "+user.getName() +",项目登记审批:"+projectAssessInfo.getProjectName() +" 强制撤销!");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if(processList!=null && processList.size()>0) {
|
|
|
+ for (int i = 0; i < processList.size(); i++) {
|
|
|
+ WorkActivityProcess p = processList.get(i);
|
|
|
+ if (org.apache.commons.lang3.StringUtils.isNotBlank(p.getIsApproval()) && "0".equals(p.getIsApproval())) {
|
|
|
+ p.setIsApproval("-1");
|
|
|
+ p.setDelFlag("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);
|
|
|
+
|
|
|
+ //结束该流程,设为"撤销"状态月
|
|
|
+ ProjectAssessInfo newProjectAssessInfo = new ProjectAssessInfo();
|
|
|
+ newProjectAssessInfo.setId(projectAssessInfo.getId());
|
|
|
+ newProjectAssessInfo.setStatus(ProjectStatusEnum.RECALL.getValue());
|
|
|
+ newProjectAssessInfo.preUpdate();
|
|
|
+ dao.update(newProjectAssessInfo);
|
|
|
+ actTaskService.endProcessInstance(projectAssessInfo.getProcessInstanceId(), "项目登记-撤回");
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ @Transactional(readOnly = false)
|
|
|
+ public void delete(ProjectAssessInfo projectAssessInfo) {
|
|
|
+ //删除项目负责人
|
|
|
+ //workProjectUserDao.deleteProjectMembers(projectAssessInfo.getId(), "1");
|
|
|
+ dao.delete(projectAssessInfo);
|
|
|
+ WorkProjectNotify notify = new WorkProjectNotify();
|
|
|
+ notify.setNotifyId(projectAssessInfo.getId());
|
|
|
+ List<User> users = workProjectNotifyService.readByNotifyId(notify);
|
|
|
+ if (users!=null && users.size()!=0){
|
|
|
+ for (User user:users){
|
|
|
+ UserUtils.pushMeIm(user.getId());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|