|  |  |  | 
|---|
|  |  |  | import com.doumee.core.utils.Utils; | 
|---|
|  |  |  | import com.doumee.dao.business.*; | 
|---|
|  |  |  | import com.doumee.dao.business.dto.*; | 
|---|
|  |  |  | import com.doumee.dao.business.join.DispatchUnitJoinMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.join.DuLogJoinMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.join.DuSolutionJoinMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.join.DuWorkTypeJoinMapper; | 
|---|
|  |  |  | import com.doumee.dao.business.join.*; | 
|---|
|  |  |  | import com.doumee.dao.business.model.*; | 
|---|
|  |  |  | import com.doumee.dao.system.model.SystemUser; | 
|---|
|  |  |  | import com.doumee.service.business.DispatchUnitService; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private DuSolutionMapper duSolutionMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SolutionWorktypeJoinMapper solutionWorktypeJoinMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private DuWorktypeMapper    duWorktypeMapper; | 
|---|
|  |  |  | 
|---|
|  |  |  | .eq(DispatchUnit::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .eq(DispatchUnit::getBaseId,model.getId())); | 
|---|
|  |  |  | BeanUtils.copyProperties(model, newVersion); | 
|---|
|  |  |  | newVersion.setId(null); | 
|---|
|  |  |  | newVersion.setWorktypeStatus(Constants.ONE); | 
|---|
|  |  |  | newVersion.setCheckDate(update.getEditDate()); | 
|---|
|  |  |  | newVersion.setCheckUserId(update.getCheckUserId()); | 
|---|
|  |  |  | newVersion.setCheckInfo(update.getCheckInfo()); | 
|---|
|  |  |  | newVersion.setStatus(Constants.ZERO); | 
|---|
|  |  |  | newVersion.setCreateDate(update.getCreateDate()); | 
|---|
|  |  |  | newVersion.setCreator(update.getEditor()); | 
|---|
|  |  |  | newVersion.setBaseId(model.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | newVersion = dispatchUnitMapper.selectOne(new QueryWrapper<DispatchUnit>().lambda() | 
|---|
|  |  |  | .eq(DispatchUnit::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .eq(DispatchUnit::getDataType,Constants.TWO) | 
|---|
|  |  |  | .eq(DispatchUnit::getBaseId,model.getId()).last(" limit 1")); | 
|---|
|  |  |  | .eq(DispatchUnit::getBaseId,model.getId()) | 
|---|
|  |  |  | .last(" limit 1")); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(Objects.isNull(newVersion)){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询到派遣单位最新版本"); | 
|---|
|  |  |  | 
|---|
|  |  |  | for (DuSolution s : solutions){ | 
|---|
|  |  |  | DuSolution ns = new DuSolution(); | 
|---|
|  |  |  | BeanUtils.copyProperties(s, ns); | 
|---|
|  |  |  | ns.setId(null); | 
|---|
|  |  |  | ns.setDispatchUnitId(newVersion.getId()); | 
|---|
|  |  |  | ns.setCheckDate(update.getEditDate()); | 
|---|
|  |  |  | ns.setStatus(Constants.ONE); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (DuWorktype w : worktypes) { | 
|---|
|  |  |  | if(Constants.equalsInteger(w.getStatus(),Constants.TWO)){ | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | DuWorktype nw = new DuWorktype(); | 
|---|
|  |  |  | BeanUtils.copyProperties(w, nw); | 
|---|
|  |  |  | nw.setId(null); | 
|---|
|  |  |  | nw.setCreateDate(new Date()); | 
|---|
|  |  |  | nw.setCheckDate(update.getEditDate()); | 
|---|
|  |  |  | nw.setStatus(Constants.ONE); | 
|---|
|  |  |  | nw.setDuSolutionId(ns.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(newWorktypes!=null &&newWorktypes.size()>0){ | 
|---|
|  |  |  | //批量查询工种关联记录 | 
|---|
|  |  |  | duWorktypeMapper.insertBatchSomeColumn(newWorktypes); | 
|---|
|  |  |  | duWorktypeMapper.insert(newWorktypes); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | //删除其他待办 | 
|---|
|  |  |  | noticesMapper.delete(new QueryWrapper<Notices>().lambda().eq(Notices::getObjType,noticeObjectType.getKey()).eq(Notices::getObjId,dispatchUnit.getId())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return  1; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | .eq(DispatchUnit::getCompanyId,loginUserInfo.getCompanyId()) | 
|---|
|  |  |  | .eq(DispatchUnit::getName,saveDispatchUnitDTO.getName()) | 
|---|
|  |  |  | .eq(DispatchUnit::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .eq(DispatchUnit::getDataType,Constants.ZERO) | 
|---|
|  |  |  | )> Constants.ZERO){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"【派遣单位名称】已存在"); | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(dispatchUnitMapper.selectCount(new QueryWrapper<DispatchUnit>().lambda() | 
|---|
|  |  |  | .ne(DispatchUnit::getId,saveDispatchUnitDTO.getId()) | 
|---|
|  |  |  | .ne(DispatchUnit::getBaseId,saveDispatchUnitDTO.getId()) | 
|---|
|  |  |  | .eq(DispatchUnit::getCompanyId,loginUserInfo.getCompanyId()) | 
|---|
|  |  |  | .eq(DispatchUnit::getName,saveDispatchUnitDTO.getName()) | 
|---|
|  |  |  | .eq(DispatchUnit::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .eq(DispatchUnit::getDataType,Constants.ZERO) | 
|---|
|  |  |  | )> Constants.ZERO){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"【派遣单位名称】已存在"); | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | 
|---|
|  |  |  | dispatchUnit.setEditDate(new Date()); | 
|---|
|  |  |  | dispatchUnit.setEditor(loginUserInfo.getId()); | 
|---|
|  |  |  | dispatchUnitMapper.updateById(dispatchUnit); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | dispatchUnitMapper.update(null,new UpdateWrapper<DispatchUnit>().lambda().set(DispatchUnit::getDataType,Constants.ONE).eq(DispatchUnit::getBaseId,dispatchUnit.getId()) | 
|---|
|  |  |  | .eq(DispatchUnit::getDataType,Constants.TWO) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //存储操作记录 | 
|---|
|  |  |  | this.saveDuLog(dispatchUnit,Constants.DispatchUnitLogType.EDIT_UNIT,null); | 
|---|
|  |  |  | 
|---|
|  |  |  | DuSolution duSolution = duSolutionMapper.selectOne(new QueryWrapper<DuSolution>().lambda().eq(DuSolution::getDispatchUnitId,saveDispatchUnitDTO.getId()) | 
|---|
|  |  |  | .eq(DuSolution::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .eq(DuSolution::getSolutionId,saveDuSolutionDTO.getSolutionId()).last("limit 1")); | 
|---|
|  |  |  | Integer duSolutionNum = duSolutionMapper.selectCount(new QueryWrapper<DuSolution>().lambda().eq(DuSolution::getDispatchUnitId,saveDuSolutionDTO.getId())); | 
|---|
|  |  |  | Integer duSolutionNum = duSolutionMapper.selectCount(new QueryWrapper<DuSolution>().lambda().eq(DuSolution::getDispatchUnitId,saveDuSolutionDTO.getId())).intValue(); | 
|---|
|  |  |  | if(Objects.isNull(duSolution)){ | 
|---|
|  |  |  | duSolution = new DuSolution(); | 
|---|
|  |  |  | duSolution.setCreateDate(new Date()); | 
|---|
|  |  |  | 
|---|
|  |  |  | if(Objects.isNull(saveDuWorkTypeDTO.getWorkTypeId())){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"【"+saveDuSolutionDTO.getSolutionName()+"】该方案下"+saveDuWorkTypeDTO.getWorkTypeName()+"该工种信息异常"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //验证方案与工种的关系 | 
|---|
|  |  |  | if(solutionWorktypeJoinMapper.selectCount(new QueryWrapper<SolutionWorktype>().lambda().eq(SolutionWorktype::getSolutionId,saveDuSolutionDTO.getSolutionId()) | 
|---|
|  |  |  | .eq(SolutionWorktype::getWorktypeId,saveDuWorkTypeDTO.getWorkTypeId()))<=0){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"【"+saveDuSolutionDTO.getSolutionName()+"】该方案下"+saveDuWorkTypeDTO.getWorkTypeName()+"该工种信息无绑定关系"); | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | if(duWorktypeMapper.selectCount(new QueryWrapper<DuWorktype>() | 
|---|
|  |  |  | .lambda().eq(DuWorktype::getDuSolutionId,duSolution.getId()) | 
|---|
|  |  |  | .eq(DuWorktype::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .eq(DuWorktype::getWorkTypeId,saveDuWorkTypeDTO.getWorkTypeId()))>0){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"【"+saveDuSolutionDTO.getSolutionName()+"】该方案下"+saveDuWorkTypeDTO.getWorkTypeName()+"该工种已存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Integer duWorkTypeNum = duWorktypeMapper.selectCount(new QueryWrapper<DuWorktype>().lambda().eq(DuWorktype::getDuSolutionId,duSolution.getId())); | 
|---|
|  |  |  | Integer duWorkTypeNum = duWorktypeMapper.selectCount(new QueryWrapper<DuWorktype>().lambda().eq(DuWorktype::getDuSolutionId,duSolution.getId())).intValue(); | 
|---|
|  |  |  | DuWorktype duWorktype = new DuWorktype(); | 
|---|
|  |  |  | duWorktype.setCreateDate(new Date()); | 
|---|
|  |  |  | duWorktype.setCreator(loginUserInfo.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void deleteById(Integer id) { | 
|---|
|  |  |  | dispatchUnitMapper.deleteById(id); | 
|---|
|  |  |  | LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); | 
|---|
|  |  |  | DispatchUnit dispatchUnit = dispatchUnitMapper.selectById(id); | 
|---|
|  |  |  | if(Objects.isNull(dispatchUnit)){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.DATA_EMPTY); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(dispatchUnit.getUnitStatus().equals(Constants.TWO)){ | 
|---|
|  |  |  | dispatchUnitMapper.update(null,new UpdateWrapper<DispatchUnit>().lambda() | 
|---|
|  |  |  | .set(DispatchUnit::getEditor,loginUserInfo.getId()) | 
|---|
|  |  |  | .set(DispatchUnit::getEditDate,new Date()) | 
|---|
|  |  |  | .set(DispatchUnit::getIsdeleted,Constants.ONE) | 
|---|
|  |  |  | .eq(DispatchUnit::getId,id)); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"当前派遣单位状态无法进行该操作"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void updateById(DispatchUnit dispatchUnit) { | 
|---|
|  |  |  | dispatchUnitMapper.updateById(dispatchUnit); | 
|---|
|  |  |  | //更新历史表状态 | 
|---|
|  |  |  | if(Objects.nonNull(dispatchUnit.getId())&& Objects.nonNull(dispatchUnit.getStatus())){ | 
|---|
|  |  |  | dispatchUnitMapper.update(null,new UpdateWrapper<DispatchUnit>().lambda() | 
|---|
|  |  |  | .set(DispatchUnit::getStatus,dispatchUnit.getStatus()) | 
|---|
|  |  |  | .eq(DispatchUnit::getDataType,Constants.TWO) | 
|---|
|  |  |  | .eq(DispatchUnit::getBaseId,dispatchUnit.getId()) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | .selectAll(DuSolution.class) | 
|---|
|  |  |  | .selectAs(Solutions::getName,DuSolution::getSolutionName) | 
|---|
|  |  |  | .leftJoin(Solutions.class,Solutions::getId,DuSolution::getSolutionId) | 
|---|
|  |  |  | .leftJoin(CompanySolution.class,CompanySolution::getSolutionId,Solutions::getId) | 
|---|
|  |  |  | .eq(DuSolution::getDispatchUnitId,dispatchUnit.getId()) | 
|---|
|  |  |  | .eq(CompanySolution::getCompanyId,dispatchUnit.getCompanyId()) | 
|---|
|  |  |  | .orderByAsc(DuSolution::getSortnum) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | if(CollectionUtils.isNotEmpty(duSolutionList)){ | 
|---|
|  |  |  | 
|---|
|  |  |  | new MPJLambdaWrapper<DispatchUnit>().selectAll(DispatchUnit.class) | 
|---|
|  |  |  | .eq(DispatchUnit::getIsdeleted,Constants.ZERO) | 
|---|
|  |  |  | .eq(DispatchUnit::getStatus,Constants.ZERO) | 
|---|
|  |  |  | .select("(select b.id from du_solution b where b.isdeleted=0 and b.dispatch_unit_id=t.id and b.solution_id="+dispatchUnitQueryDTO.getSolutionId()+" limit 1) as du_solution_id" ) | 
|---|
|  |  |  | .select("(select b.id from du_solution b where b.isdeleted=0 and b.dispatch_unit_id=t.id and b.solution_id="+dispatchUnitQueryDTO.getSolutionId()+"  order by b.CHECK_DATE desc  limit 1) as du_solution_id" ) | 
|---|
|  |  |  | .eq(loginUserInfo.getType().equals(Constants.ONE),DispatchUnit::getCompanyId,loginUserInfo.getCompanyId()) | 
|---|
|  |  |  | .eq(Objects.nonNull(dispatchUnitQueryDTO.getCompanyId()),DispatchUnit::getCompanyId,dispatchUnitQueryDTO.getCompanyId()) | 
|---|
|  |  |  | .eq(Objects.isNull(dispatchUnitQueryDTO.getDataType()),DispatchUnit::getDataType,Constants.TWO) | 
|---|
|  |  |  | .eq(!Objects.isNull(dispatchUnitQueryDTO.getDataType()),DispatchUnit::getDataType,dispatchUnitQueryDTO.getDataType()) | 
|---|
|  |  |  | .exists(!Objects.isNull(dispatchUnitQueryDTO.getSolutionId()), | 
|---|