|  |  |  | 
|---|
|  |  |  | import com.core.common.Cools; | 
|---|
|  |  |  | import com.core.common.DateUtils; | 
|---|
|  |  |  | import com.core.common.R; | 
|---|
|  |  |  | import com.zy.asrs.domain.dto.AxisBean; | 
|---|
|  |  |  | import com.zy.asrs.domain.dto.WorkChartAxis; | 
|---|
|  |  |  | import com.zy.asrs.domain.enums.CrnStatusType; | 
|---|
|  |  |  | import com.zy.asrs.domain.enums.SiteStatusType; | 
|---|
|  |  |  | import com.zy.asrs.domain.param.SystemSwitchParam; | 
|---|
|  |  |  | import com.zy.asrs.domain.vo.*; | 
|---|
|  |  |  | import com.zy.asrs.entity.BasCrnError; | 
|---|
|  |  |  | import com.zy.asrs.entity.BasDevp; | 
|---|
|  |  |  | import com.zy.asrs.entity.WrkMast; | 
|---|
|  |  |  | import com.zy.asrs.entity.*; | 
|---|
|  |  |  | import com.zy.asrs.mapper.BasCrnErrorMapper; | 
|---|
|  |  |  | import com.zy.asrs.mapper.LocMastMapper; | 
|---|
|  |  |  | import com.zy.asrs.mapper.ReportQueryMapper; | 
|---|
|  |  |  | import com.zy.asrs.service.BasCrnpService; | 
|---|
|  |  |  | import com.zy.asrs.service.BasDevpService; | 
|---|
|  |  |  | import com.zy.asrs.service.DeviceErrorService; | 
|---|
|  |  |  | import com.zy.asrs.service.WrkMastService; | 
|---|
|  |  |  | import com.zy.asrs.service.impl.TaskWrkServiceImpl; | 
|---|
|  |  |  | import com.zy.common.CodeRes; | 
|---|
|  |  |  | import com.zy.core.CrnThread; | 
|---|
|  |  |  | import com.zy.core.DevpThread; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.zy.core.properties.SlaveProperties; | 
|---|
|  |  |  | import com.zy.core.properties.SystemProperties; | 
|---|
|  |  |  | import com.zy.core.thread.BarcodeThread; | 
|---|
|  |  |  | import com.zy.core.thread.MelsecCrnThread; | 
|---|
|  |  |  | import com.zy.core.thread.ScaleThread; | 
|---|
|  |  |  | import com.zy.core.thread.SiemensCrnThread; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.text.SimpleDateFormat; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | private LocMastMapper locMastMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BasCrnErrorMapper basCrnErrorMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ReportQueryMapper reportQueryMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private DeviceErrorService deviceErrorService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BasCrnpService basCrnpService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private TaskWrkServiceImpl taskWrkService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/system/running/status") | 
|---|
|  |  |  | @ManagerAuth(memo = "系统运行状态") | 
|---|
|  |  |  | 
|---|
|  |  |  | vo.setSiteId(String.valueOf(entry.getKey())); // 站点编号 | 
|---|
|  |  |  | vo.setWorkNo(staProtocol.getWorkNo()); // 工作号 | 
|---|
|  |  |  | vo.setSiteStatus(SiteStatusType.process(staProtocol));  // 状态 | 
|---|
|  |  |  | vo.setNearbySta(staProtocol.getNearbySta());  //RGV位置 | 
|---|
|  |  |  | vos.add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok().add(vos); | 
|---|
|  |  |  | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | CrnProtocol crnProtocol = crnThread.getCrnProtocol(); | 
|---|
|  |  |  | if (crnProtocol == null) { | 
|---|
|  |  |  | if (crnProtocol == null || Cools.isEmpty(crnProtocol.getLaneNo())) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | CrnLatestDataVo vo = new CrnLatestDataVo(); | 
|---|
|  |  |  | vo.setCrnId(crn.getId());   //  堆垛机编号 | 
|---|
|  |  |  | vo.setCrnId(crnProtocol.getLaneNo());   //  堆垛机编号 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            Short totalBay = locMastMapper.selectTotalBay(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | vo.setCrnStatus(CrnStatusType.MACHINE_ERROR); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | if (crnProtocol.getTaskNo()>0) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(crnProtocol.getTaskNo()); | 
|---|
|  |  |  | if (wrkMast != null) { | 
|---|
|  |  |  | vo.setCrnStatus(CrnStatusType.process(wrkMast.getIoType())); | 
|---|
|  |  |  | TaskWrk taskWrk = taskWrkService.selectByWrkNo(crnProtocol.getTaskNo().intValue()); | 
|---|
|  |  |  | //                    WrkMast wrkMast = wrkMastService.selectById(crnProtocol.getTaskNo()); | 
|---|
|  |  |  | if (taskWrk != null) { | 
|---|
|  |  |  | vo.setCrnStatus(CrnStatusType.process(taskWrk.getIoType())); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | vo.setCrnStatus(crnProtocol.modeType.equals(CrnModeType.AUTO)? CrnStatusType.MACHINE_AUTO: CrnStatusType.MACHINE_UN_AUTO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | return R.ok().add(list); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 获取设备详情 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @GetMapping("/deviceInfo") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R getDeviceInfo() { | 
|---|
|  |  |  | ArrayList<HashMap<String, Object>> list = new ArrayList<>(); | 
|---|
|  |  |  | for (CrnSlave crn : slaveProperties.getCrn()) { | 
|---|
|  |  |  | // 获取堆垛机信息 | 
|---|
|  |  |  | CrnThread crnThread = (CrnThread) SlaveConnection.get(SlaveType.Crn, crn.getId()); | 
|---|
|  |  |  | if (crnThread == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | CrnProtocol crnProtocol = crnThread.getCrnProtocol(); | 
|---|
|  |  |  | if (crnProtocol == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | HashMap<String, Object> map = new HashMap<>(); | 
|---|
|  |  |  | map.put("device", "堆垛机"); | 
|---|
|  |  |  | map.put("deviceId", crn.getId()); | 
|---|
|  |  |  | map.put("battery", ""); | 
|---|
|  |  |  | map.put("error", crnProtocol.getFault()); | 
|---|
|  |  |  | map.put("status", crnProtocol.getStatusType().desc); | 
|---|
|  |  |  | list.add(map); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (DevpSlave devp : slaveProperties.getDevp()) { | 
|---|
|  |  |  | DeviceError deviceError = deviceErrorService.selectByDeviceAndDeviceId("devp", devp.getId()); | 
|---|
|  |  |  | HashMap<String, Object> map = new HashMap<>(); | 
|---|
|  |  |  | map.put("device", "输送线"); | 
|---|
|  |  |  | map.put("deviceId", devp.getId()); | 
|---|
|  |  |  | map.put("battery", ""); | 
|---|
|  |  |  | map.put("error", deviceError != null); | 
|---|
|  |  |  | map.put("status", deviceError == null ? "" : deviceError.getMsg()); | 
|---|
|  |  |  | list.add(map); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (Slave scale : slaveProperties.getScale()) { | 
|---|
|  |  |  | DeviceError deviceError = deviceErrorService.selectByDeviceAndDeviceId("scale", scale.getId()); | 
|---|
|  |  |  | HashMap<String, Object> map = new HashMap<>(); | 
|---|
|  |  |  | map.put("device", "磅秤"); | 
|---|
|  |  |  | map.put("deviceId", scale.getId()); | 
|---|
|  |  |  | map.put("battery", ""); | 
|---|
|  |  |  | map.put("error", deviceError != null); | 
|---|
|  |  |  | map.put("status", deviceError == null ? "" : deviceError.getMsg()); | 
|---|
|  |  |  | list.add(map); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | HashMap<String, Object> hashMap = new HashMap<>(); | 
|---|
|  |  |  | hashMap.put("records", list); | 
|---|
|  |  |  | return R.ok().add(hashMap); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /****************************************************************/ | 
|---|
|  |  |  | /************************** 详情操作 ******************************/ | 
|---|
|  |  |  | /****************************************************************/ | 
|---|
|  |  |  | 
|---|
|  |  |  | vo.setWorkNo(staProtocol.getWorkNo());   // 工作号 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (staProtocol.getWorkNo() > 0) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(staProtocol.getWorkNo()); | 
|---|
|  |  |  | if (wrkMast != null) { | 
|---|
|  |  |  | vo.setWrkSts(wrkMast.getWrkSts$());   // 工作状态 | 
|---|
|  |  |  | vo.setIoType(wrkMast.getIoType$());   //  入出库类型 | 
|---|
|  |  |  | vo.setSourceStaNo(wrkMast.getSourceStaNo$()); | 
|---|
|  |  |  | vo.setStaNo(wrkMast.getStaNo$()); | 
|---|
|  |  |  | vo.setSourceLocNo(wrkMast.getSourceLocNo$()); | 
|---|
|  |  |  | vo.setLocNo(wrkMast.getLocNo$()); | 
|---|
|  |  |  | TaskWrk taskWrk = taskWrkService.selectByWrkNo(staProtocol.getWorkNo()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //                        WrkMast wrkMast = wrkMastService.selectById(staProtocol.getWorkNo()); | 
|---|
|  |  |  | if (taskWrk != null) { | 
|---|
|  |  |  | vo.setWrkSts(taskWrk.getWrkSts$());   // 工作状态 | 
|---|
|  |  |  | vo.setIoType(taskWrk.getIoType$());   //  入出库类型 | 
|---|
|  |  |  | vo.setSourceStaNo(taskWrk.getStartPoint()); | 
|---|
|  |  |  | vo.setStaNo(taskWrk.getTargetPoint()); | 
|---|
|  |  |  | //                            vo.setSourceLocNo(wrkMast.getSourceLocNo$()); | 
|---|
|  |  |  | //                            vo.setLocNo(wrkMast.getLocNo$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | CrnDetailVo vo = new CrnDetailVo(); | 
|---|
|  |  |  | for (CrnSlave crnSlave : slaveProperties.getCrn()) { | 
|---|
|  |  |  | if (crnSlave.getId().equals(crnNo)) { | 
|---|
|  |  |  | MelsecCrnThread crnThread = (MelsecCrnThread) SlaveConnection.get(SlaveType.Crn, crnSlave.getId()); | 
|---|
|  |  |  | CrnProtocol crnProtocol = crnThread.getCrnProtocol(); | 
|---|
|  |  |  | vo.setCrnNo(crnNo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取堆垛机信息 | 
|---|
|  |  |  | CrnThread crnThread = (CrnThread) SlaveConnection.get(SlaveType.Crn, crnSlave.getId()); | 
|---|
|  |  |  | CrnProtocol crnProtocol = crnThread.getCrnProtocol(); | 
|---|
|  |  |  | if (crnProtocol == null || Cools.isEmpty(crnProtocol.getLaneNo())) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (crnProtocol.getLaneNo().equals(crnNo)) { | 
|---|
|  |  |  | BasCrnp basCrnp = basCrnpService.selectById(crnProtocol.getCrnNo()); | 
|---|
|  |  |  | if (basCrnp == null) { | 
|---|
|  |  |  | return R.error("数据库维护异常"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | vo.setCrnNo(crnProtocol.getCrnNo()); | 
|---|
|  |  |  | vo.setLaneNo(crnProtocol.getLaneNo()); | 
|---|
|  |  |  | vo.setWorkNo(crnProtocol.getTaskNo()); | 
|---|
|  |  |  | vo.setCrnStatus(crnProtocol.getStatusType().desc); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (crnProtocol.getTaskNo() > 0) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(crnProtocol.getTaskNo()); | 
|---|
|  |  |  | if (wrkMast != null) { | 
|---|
|  |  |  | vo.setSourceStaNo(wrkMast.getSourceStaNo$()); | 
|---|
|  |  |  | vo.setStaNo(wrkMast.getStaNo$()); | 
|---|
|  |  |  | vo.setWrkSts(wrkMast.getWrkSts$());   // 工作状态 | 
|---|
|  |  |  | vo.setIoType(wrkMast.getIoType$());   //  入出库类型 | 
|---|
|  |  |  | vo.setSourceLocNo(wrkMast.getSourceLocNo$()); | 
|---|
|  |  |  | vo.setLocNo(wrkMast.getLocNo$()); | 
|---|
|  |  |  | vo.setCrnStatus(crnProtocol.getStatusType().desc); | 
|---|
|  |  |  | vo.setError("");    // todo | 
|---|
|  |  |  | TaskWrk taskWrk = taskWrkService.selectByWrkNo(crnProtocol.getTaskNo().intValue()); | 
|---|
|  |  |  | if (taskWrk != null) { | 
|---|
|  |  |  | vo.setWrkSts(taskWrk.getWrkSts$());   // 工作状态 | 
|---|
|  |  |  | vo.setIoType(taskWrk.getIoType$());   //  入出库类型 | 
|---|
|  |  |  | vo.setSourceStaNo(taskWrk.getStartPoint()); | 
|---|
|  |  |  | vo.setStaNo(taskWrk.getTargetPoint()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | vo.setInEnable(basCrnp.getInEnable());//可入 | 
|---|
|  |  |  | vo.setOutEnable(basCrnp.getOutEnable());//可出 | 
|---|
|  |  |  | return R.ok().add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @GetMapping("/barcode/output/site") | 
|---|
|  |  |  | public R crnOutput(){ | 
|---|
|  |  |  | ArrayList<JSONObject> jsonObjects = new ArrayList<>(OutputQueue.BARCODE); | 
|---|
|  |  |  | ArrayList<JSONObject> jsonObjects = new ArrayList<>(OutputQueue.SCALE); | 
|---|
|  |  |  | jsonObjects.sort(new Comparator<JSONObject>() { | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public int compare(JSONObject o1, JSONObject o2) { | 
|---|
|  |  |  | 
|---|
|  |  |  | return R.ok().add(JSON.toJSONString(jsonObjects)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("loc/pie/charts") | 
|---|
|  |  |  | public R dsa(){ | 
|---|
|  |  |  | Map<String,Object> map=new HashMap<String, Object>(); | 
|---|
|  |  |  | List<ChartBean>  list = new ArrayList<ChartBean>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | LocChartPie locUseRate = reportQueryMapper.getLocUseRate(); | 
|---|
|  |  |  | if(locUseRate!=null) { | 
|---|
|  |  |  | ChartBean fqty = new ChartBean(); | 
|---|
|  |  |  | fqty.setName("在库库位"); | 
|---|
|  |  |  | fqty.setY(locUseRate.getFqty()); | 
|---|
|  |  |  | list.add(fqty); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ChartBean oqty = new ChartBean(); | 
|---|
|  |  |  | oqty.setName("空库位"); | 
|---|
|  |  |  | oqty.setY(locUseRate.getOqty()); | 
|---|
|  |  |  | list.add(oqty); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ChartBean uqty = new ChartBean(); | 
|---|
|  |  |  | uqty.setName("使用库位"); | 
|---|
|  |  |  | uqty.setY(locUseRate.getUqty()); | 
|---|
|  |  |  | list.add(uqty); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ChartBean xqty = new ChartBean(); | 
|---|
|  |  |  | xqty.setName("禁用库位"); | 
|---|
|  |  |  | xqty.setY(locUseRate.getXqty()); | 
|---|
|  |  |  | list.add(xqty); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | map.put("rows",list); | 
|---|
|  |  |  | return R.ok(map); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("locIo/line/charts") | 
|---|
|  |  |  | public R locIoLineCharts(){ | 
|---|
|  |  |  | Map<String,Object> map=new HashMap<String, Object>(); | 
|---|
|  |  |  | List<AxisBean> list = new ArrayList<AxisBean>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<WorkChartAxis> listChart = reportQueryMapper.getChartAxis(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(listChart!=null) { | 
|---|
|  |  |  | ArrayList<Integer> data1 = new ArrayList<Integer>(); | 
|---|
|  |  |  | ArrayList<Integer> data2 = new ArrayList<Integer>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd"); | 
|---|
|  |  |  | Calendar calendar = Calendar.getInstance(); | 
|---|
|  |  |  | calendar.add(Calendar.DATE, -12); | 
|---|
|  |  |  | for(int i=0;i<12;i++) { | 
|---|
|  |  |  | boolean flag = true; | 
|---|
|  |  |  | calendar.add(Calendar.DATE, 1); | 
|---|
|  |  |  | String str = sf.format(calendar.getTime()); | 
|---|
|  |  |  | for(WorkChartAxis workChart : listChart) { | 
|---|
|  |  |  | if(str.equals(workChart.getYmd())) { | 
|---|
|  |  |  | data1.add(workChart.getInqty()); | 
|---|
|  |  |  | data2.add(workChart.getOutqty()); | 
|---|
|  |  |  | flag = false; | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(flag) { | 
|---|
|  |  |  | data1.add(0); | 
|---|
|  |  |  | data2.add(0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | AxisBean inqty = new AxisBean(); | 
|---|
|  |  |  | inqty.setName("入库数量"); | 
|---|
|  |  |  | Integer[] array1 = new Integer[data1.size()]; | 
|---|
|  |  |  | inqty.setData(data1.toArray(array1)); | 
|---|
|  |  |  | list.add(inqty); | 
|---|
|  |  |  | AxisBean outqty = new AxisBean(); | 
|---|
|  |  |  | outqty.setName("出库数量"); | 
|---|
|  |  |  | Integer[] array2 = new Integer[data2.size()]; | 
|---|
|  |  |  | outqty.setData(data2.toArray(array2)); | 
|---|
|  |  |  | list.add(outqty); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | map.put("rows",list); | 
|---|
|  |  |  | return R.ok(map); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|