| package com.dy.pmsStation.workOrder; | 
|   | 
| import com.alibaba.excel.util.StringUtils; | 
| import com.dy.common.webUtil.BaseResponseUtils; | 
| import com.dy.pmsGlobal.daoBa.BaUserMapper; | 
| import com.dy.pmsGlobal.daoOth.OthFileMapper; | 
| import com.dy.pmsGlobal.daoPlt.PltStationMapper; | 
| import com.dy.pmsGlobal.daoPr.PrAssemblyPlanMapper; | 
| import com.dy.pmsGlobal.daoSta.StaAssemblyWorkHistoryMapper; | 
| import com.dy.pmsGlobal.daoSta.StaAssemblyWorkLastMapper; | 
| import com.dy.pmsGlobal.dyFile.FileOperate; | 
| import com.dy.pmsGlobal.dyFile.FileRestVo; | 
| import com.dy.pmsGlobal.pojoBa.BaUser; | 
| import com.dy.pmsGlobal.pojoOth.OthFile; | 
| import com.dy.pmsGlobal.pojoPlt.PltStation; | 
| import com.dy.pmsGlobal.pojoPr.PrAssemblyPlan; | 
| import com.dy.pmsGlobal.pojoPr.PrProductionNode; | 
| import com.dy.pmsGlobal.pojoPr.PrWorkingInstruction; | 
| import com.dy.pmsGlobal.pojoSta.StaAssemblyWorkHistory; | 
| import com.dy.pmsGlobal.pojoSta.StaAssemblyWorkLast; | 
| import lombok.extern.slf4j.Slf4j; | 
| import org.springframework.beans.BeanUtils; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.beans.factory.annotation.Value; | 
| import org.springframework.stereotype.Service; | 
| import org.springframework.transaction.annotation.Transactional; | 
|   | 
| import java.util.Date; | 
| import java.util.List; | 
| import java.util.concurrent.atomic.AtomicLong; | 
| import java.util.stream.Collectors; | 
|   | 
| @Slf4j | 
| @Service | 
| public class WorkOrderSv { | 
|     private static final int STATUS_NORMAL = 1; | 
|     private static final int STATUS_WORK_LAST_LOGOUT = 2; | 
|     private static final int STATUS_REPAIR = 3; | 
|     private static final int STATUS_WASTE = 4; | 
|   | 
|     private static final String USER_PREFIX = "101"; | 
|     private static final String STATION_PREFIX = "103"; | 
|   | 
|     private PrAssemblyPlanMapper assemblyDao; | 
|     private BaUserMapper baUserDao; | 
|     private PltStationMapper pltStationDao; | 
|     private StaAssemblyWorkLastMapper assemblyWorkLastDao; | 
|     private StaAssemblyWorkHistoryMapper assemblyWorkHistoryDao; | 
|     private FileOperate fileOperate; | 
|     private OthFileMapper othFileMapper; | 
|     @Value("${dy.webFile.fmUrl}") | 
|     private String fmUrl ; | 
|     @Autowired | 
|     public void setAssemblyDao(PrAssemblyPlanMapper assemblyDao) { | 
|         this.assemblyDao = assemblyDao; | 
|     } | 
|     @Autowired | 
|     private void setBaUserDao(BaUserMapper baUserDao){ | 
|         this.baUserDao = baUserDao; | 
|     } | 
|     @Autowired | 
|     private void setPltStationDao(PltStationMapper pltStationDao){ | 
|         this.pltStationDao = pltStationDao; | 
|     } | 
|     @Autowired | 
|     private void setStaAssemblyWorkHistoryDao(StaAssemblyWorkHistoryMapper assemblyWorkHistoryDao){ | 
|         this.assemblyWorkHistoryDao = assemblyWorkHistoryDao; | 
|     } | 
|     @Autowired | 
|     private void setStaAssemblyWorkLastDao(StaAssemblyWorkLastMapper assemblyWorkLastDao){ | 
|         this.assemblyWorkLastDao = assemblyWorkLastDao; | 
|     } | 
|     @Autowired | 
|     public void setFileOperate(FileOperate fileOperate){ | 
|         this.fileOperate = fileOperate; | 
|     } | 
|     @Autowired | 
|     public void setOthFileMapper(OthFileMapper othFileMapper){ | 
|         this.othFileMapper = othFileMapper; | 
|     } | 
|   | 
|     public BaUser getUserInfo(String id){ | 
|         Long userId = null; | 
|         if(StringUtils.isBlank(id)){ | 
|             throw new RuntimeException("员工编码不能为空"); | 
|         } | 
|         //用户101 | 
|         if(id.startsWith(USER_PREFIX)){ | 
|             userId = Long.parseLong(id.toString().substring(3)); | 
|         }else{ | 
|             userId = Long.parseLong(id.toString()); | 
|         } | 
|         BaUser userInfo = baUserDao.selectByPrimaryKey(userId); | 
|         if(userInfo == null){ | 
|             throw new RuntimeException("员工编码:"+ userId +"不在系统中,请先维护员工信息"); | 
|         }else if(userInfo.getDisabled()){ | 
|             throw new RuntimeException("员工("+userInfo.getName()+")编码:"+ userId +"在系统已禁用,请先启用员工"); | 
|         } | 
|         return userInfo; | 
|     } | 
|     public PltStation getStationInfo(String id){ | 
|         //仅检查工站信息以及工站占用情况 | 
|         Long stationId = null; | 
|         if(StringUtils.isBlank(id)){ | 
|             throw new RuntimeException("工站编码不能为空"); | 
|         } | 
|         //工站103 | 
|         if(id.startsWith(STATION_PREFIX)){ | 
|             stationId = Long.parseLong(id.toString().substring(3)); | 
|         }else{ | 
|             stationId = Long.parseLong(id.toString()); | 
|         } | 
|         PltStation stationInfo = pltStationDao.selectByPrimaryKey(stationId); | 
|         if(stationInfo == null){ | 
|             throw new RuntimeException("工站编码:"+ stationId +"不在系统中,请先维护工站信息"); | 
|         }else if(stationInfo.getDisabled()){ | 
|             throw new RuntimeException("工站("+stationInfo.getName()+")编码:"+ stationId +"在系统已禁用,请先启用工站"); | 
|         } | 
|         return stationInfo; | 
|     } | 
|     public StaAssemblyWorkLast checkStationUsed(String id){ | 
|         StaAssemblyWorkLast result = new StaAssemblyWorkLast(); | 
|         PltStation stationInfo = null; | 
|         if(StringUtils.isBlank(id)){ | 
|             throw new RuntimeException("工站编码不能为空,请检查"); | 
|         } | 
|         stationInfo = getStationInfo(id); | 
|         //检查表中stationId是否已经存在 | 
|         StaAssemblyWorkLast param = new StaAssemblyWorkLast(); | 
|         param.setStationId(stationInfo.getId()); | 
|         param.setStatus(STATUS_NORMAL); | 
|         List<StaAssemblyWorkLast> workLasts = assemblyWorkLastDao.selectList(param); | 
|         if(workLasts.size() > 0){ | 
|             BeanUtils.copyProperties(workLasts.get(0),result); | 
|         }else{ | 
|             result.setStationId(stationInfo.getId()); | 
|             result.setStationName(stationInfo.getName()); | 
|             result.setLineId(stationInfo.getLineId()); | 
|             result.setLineName(stationInfo.getLineName()); | 
|         } | 
|         return result; | 
|     } | 
|   | 
|     public StaAssemblyWorkLast checkUserAndStationUsed(QueryVo vo){ | 
|         StaAssemblyWorkLast result = new StaAssemblyWorkLast(); | 
|         PltStation stationInfo = null; | 
|         BaUser userInfo = null; | 
|         if(StringUtils.isBlank(vo.getStationId()) || StringUtils.isBlank(vo.getUserId())){ | 
|             throw new RuntimeException("工站编码或员工编码均不能为空,请检查"); | 
|         } | 
|         //工站103 | 
|         if(vo.getStationId().startsWith(USER_PREFIX)){ | 
|             userInfo = getUserInfo(vo.getStationId()); | 
|         }else{ | 
|             stationInfo = getStationInfo(vo.getStationId()); | 
|         } | 
|         if(vo.getUserId().startsWith(STATION_PREFIX)){ | 
|             stationInfo = getStationInfo(vo.getUserId()); | 
|         }else{ | 
|             userInfo = getUserInfo(vo.getUserId()); | 
|         } | 
|         if(userInfo == null && stationInfo == null){ | 
|             throw new RuntimeException("员工编码:"+ vo.getUserId() + "和工站编码:" + vo.getStationId() + "不正确,请检查"); | 
|         }else if(userInfo == null){ | 
|             throw new RuntimeException("员工编码:"+ vo.getUserId() + "不正确,请检查"); | 
|         }else if(stationInfo == null){ | 
|             throw new RuntimeException("工站编码:" + vo.getStationId() + "不正确,请检查"); | 
|         } | 
|         //检查表中stationId是否已经存在 | 
|         StaAssemblyWorkLast param = new StaAssemblyWorkLast(); | 
|         param.setStationId(stationInfo.getId()); | 
|         param.setStatus(STATUS_NORMAL); | 
|         List<StaAssemblyWorkLast> workLasts = assemblyWorkLastDao.selectList(param); | 
|         long userId = userInfo.getId(); | 
|         if(workLasts.size() > 0){ | 
|             List<StaAssemblyWorkLast>  userStationList =  workLasts.stream().filter(item->userId == item.getUserId()).collect(Collectors.toList()); | 
|             if(userStationList.size() == 0){ | 
|                 throw new RuntimeException("员工("+workLasts.get(0).getUserName()+")编码:"+ workLasts.get(0).getUserId() + "已经绑定该工站("+workLasts.get(0).getStationName()+")编码:" + workLasts.get(0).getStationId() + ".请先让其解绑"); | 
|             }else{ | 
|                 BeanUtils.copyProperties(userStationList.get(0),result); | 
|             } | 
|         }else{ | 
|             result.setUserId(userInfo.getId()); | 
|             result.setUserName(userInfo.getName()); | 
|             result.setStationId(stationInfo.getId()); | 
|             result.setStationName(stationInfo.getName()); | 
|             result.setLineId(stationInfo.getLineId()); | 
|         } | 
|         return result; | 
|     } | 
|     @Transactional | 
|     public StaAssemblyWorkLast save(QueryVo vo) { | 
|         //先check | 
|         StaAssemblyWorkLast checkResult = checkUserAndStationUsed(vo); | 
|         //校验planId processId nodeId | 
|         PrAssemblyPlan params = new PrAssemblyPlan(); | 
|         params.setStatus(STATUS_NORMAL); | 
|         params.setId(vo.getPlanId()); | 
|         params.setProcessId(vo.getProcessId()); | 
|         List<PrAssemblyPlan> planList = selectAssyPlanList(params); | 
|         boolean hasNodeId= planList.stream() | 
|                 .flatMap(process -> process.getProcess().getNodes().stream()) | 
|                 .anyMatch(node -> node.id.equals(vo.getNodeId())); | 
|         if(!hasNodeId){ | 
|             throw new RuntimeException("节点信息有误或被其他人员修改,请重新选择节点信息"); | 
|         } | 
|         vo.setLineId(checkResult.getLineId()); | 
|         StaAssemblyWorkLast staLast = new StaAssemblyWorkLast(); | 
|         BeanUtils.copyProperties(vo,staLast); | 
|         staLast.setUserId(checkResult.getUserId()); | 
|         staLast.setStationId(checkResult.getStationId()); | 
|         int count = 0; | 
|         if(checkResult.getId() == null){ | 
|             BeanUtils.copyProperties(vo,staLast); | 
|             staLast.setUserId(checkResult.getUserId()); | 
|             staLast.setStationId(checkResult.getStationId()); | 
|             staLast.setStatus(STATUS_NORMAL); | 
|             staLast.setStartTime(new Date()); | 
|             count = assemblyWorkLastDao.insertSelective(staLast); | 
|         }else{ | 
|             //保存一条history? | 
|             BeanUtils.copyProperties(checkResult,staLast); | 
|             staLast.setPlanId(vo.getPlanId()); | 
|             staLast.setProcessId(vo.getProcessId()); | 
|             staLast.setNodeId(vo.getNodeId()); | 
|             staLast.setStatus(STATUS_NORMAL); | 
|             staLast.setStartTime(new Date()); | 
|             count = assemblyWorkLastDao.updateByPrimaryKeySelective(staLast); | 
|         } | 
|         if (count <= 0) { | 
|             throw new RuntimeException("数据库存储失败"); | 
|         } | 
|         StaAssemblyWorkLast result = assemblyWorkLastDao.selectByPrimaryKey(staLast.getId()); | 
|         return result; | 
|     } | 
|     @Transactional | 
|     public int logout(String id) { | 
|         //找到登录记录 | 
|         StaAssemblyWorkLast workLast = assemblyWorkLastDao.selectByPrimaryKey(Long.parseLong(id)); | 
|         if(workLast == null){ | 
|             throw new RuntimeException("系统中没有该条登录信息"); | 
|         } | 
|         //更新登录记录 | 
|         workLast.setStatus(STATUS_WORK_LAST_LOGOUT); | 
|         workLast.setEndTime(new Date()); | 
|         // 保存history | 
|         StaAssemblyWorkHistory history = new StaAssemblyWorkHistory(); | 
|         BeanUtils.copyProperties(workLast,history); | 
|         //history.setId(null); | 
|         int count = assemblyWorkHistoryDao.insertSelective(history); | 
|         //删除last | 
|         assemblyWorkLastDao.deleteByPrimaryKey(Long.parseLong(id)); | 
|         return count; | 
|     } | 
|     public List<PrAssemblyPlan> selectAssyPlanList(PrAssemblyPlan params){ | 
|         List<PrAssemblyPlan> planList = assemblyDao.selectAssyPlanList(params); | 
|         planList.stream().forEach(process -> { | 
|             process.getProcess().getNodes().forEach(node -> { | 
|                 if(node.instruction != null){ | 
|                     addUrl(node.instruction); | 
|                 } | 
|             }); | 
|         }); | 
|         return planList; | 
|     } | 
|     private void addUrl(PrWorkingInstruction ins){ | 
|         if (ins == null || ins.fileId == null) { | 
|             return; | 
|         } | 
|         OthFile file = othFileMapper.selectByPrimaryKey(ins.fileId); | 
|         if (file == null) { | 
|             return; | 
|         } | 
|         FileRestVo fileRestVo = fileOperate.parseHashcode(fmUrl, file.hash); | 
|         ins.webUrl = fileRestVo.fileSysRestUrl + fileRestVo.fileWebDownloadPath + ins.fileId; | 
|         ins.orgName = file.orgName; | 
|         ins.extName = file.extName; | 
|     } | 
|     //workId   assistants 传的是单个的userId  必传参数 | 
|     public List<BaUser> updateAssistant(QueryVo vo) { | 
|         //找到workId | 
|         StaAssemblyWorkLast workLast = assemblyWorkLastDao.selectByPrimaryKey(vo.getWorkId()); | 
|         if(workLast == null){ | 
|             throw new RuntimeException("系统中没有该条登录信息,请检查或重新登录"); | 
|         } | 
|         //如果assistants 有101 则删掉 | 
|         StringBuilder sb = new StringBuilder(); | 
|         String[] assistantArr = vo.getAssistants().split(","); | 
|         for (String item : assistantArr) { | 
|             if(item.startsWith(USER_PREFIX)){ | 
|                 sb.append(item.substring(3)).append(","); | 
|             }else{ | 
|                 sb.append(item).append(","); | 
|             } | 
|         } | 
|         String assistantStr = assistantArr.length > 0 ? sb.deleteCharAt(sb.length() - 1).toString() : ""; | 
|         List<BaUser> userInfo = baUserDao.selectByAssistants(vo.getAssistants()); | 
|         return userInfo; | 
|     } | 
|   | 
|     public int addAssistant(String workId ,String assistant) { | 
|         //找到workId | 
|         StaAssemblyWorkLast workLast = assemblyWorkLastDao.selectByPrimaryKey(Long.parseLong(workId)); | 
|         if(workLast == null){ | 
|             throw new RuntimeException("系统中没有当前登录信息,请检查或重新登录"); | 
|         } | 
|         BaUser userInfo = getUserInfo(assistant); | 
|         //当前登录人不能是辅助人员 | 
|         if(workLast.getUserId() == userInfo.getId()){ | 
|             throw new RuntimeException(userInfo.getName() +"是当前登录人员,不必添加为辅助人员."); | 
|         } | 
|         String userId = userInfo.getId().toString(); | 
|         if(StringUtils.isBlank(workLast.getAssistants())){ | 
|             workLast.setAssistants(userId); | 
|         }else{ | 
|             //已经添加的辅助人员 不必重复添加 | 
|             String assistants = workLast.getAssistants(); | 
|             String[] assistantArr = assistants.split(","); | 
|             for (String item : assistantArr) { | 
|                 if(userId.equals(item)){ | 
|                     throw new RuntimeException(userInfo.getName() +"已经添加为辅助人员,不必重复添加."); | 
|                 } | 
|             } | 
|             workLast.setAssistants(assistants +","+ userId); | 
|         } | 
|         int count = assemblyWorkLastDao.updateByPrimaryKey(workLast); | 
|         return count; | 
|     } | 
|     public int removeAssistant(String workId ,String assistant) { | 
|         //找到workId | 
|         StaAssemblyWorkLast workLast = assemblyWorkLastDao.selectByPrimaryKey(Long.parseLong(workId)); | 
|         if(workLast == null){ | 
|             throw new RuntimeException("系统中没有当前登录信息,请检查或重新登录"); | 
|         } | 
|         if((!StringUtils.isBlank(assistant)) && assistant.startsWith(USER_PREFIX)){ | 
|             assistant = assistant.substring(3); | 
|         } | 
|         if(!StringUtils.isBlank(workLast.getAssistants())){ | 
|             StringBuilder sb = new StringBuilder(); | 
|             String[] assistantArr = workLast.getAssistants().split(","); | 
|             for (String item : assistantArr) { | 
|                 if((!StringUtils.isBlank(assistant)) && (!assistant.equals(item))){ | 
|                     sb.append(item).append(","); | 
|                 } | 
|             } | 
|             String assistantStr = sb.length() > 0 ? sb.deleteCharAt(sb.length() - 1).toString() : ""; | 
|             workLast.setAssistants(assistantStr); | 
|         } | 
|         int count = assemblyWorkLastDao.updateByPrimaryKey(workLast); | 
|         return count; | 
|     } | 
|     public List<BaUser> getAssistantList(String workId) { | 
|         //找到workId | 
|         StaAssemblyWorkLast workLast = assemblyWorkLastDao.selectByPrimaryKey(Long.parseLong(workId)); | 
|         if(workLast == null){ | 
|             throw new RuntimeException("系统中没有当前登录信息,请检查或重新登录"); | 
|         } | 
|         List<BaUser> assistantList = baUserDao.selectByAssistants(workLast.getAssistants()); | 
|         return assistantList; | 
|     } | 
| } |