|  |  | 
 |  |  | 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.BasDevpService; | 
 |  |  | import com.zy.asrs.service.DeviceErrorService; | 
 |  |  | import com.zy.asrs.service.WrkMastService; | 
 |  |  | import com.zy.common.CodeRes; | 
 |  |  | import com.zy.core.CrnThread; | 
 |  |  | 
 |  |  | 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; | 
 |  |  |  | 
 |  |  |     @PostMapping("/system/running/status") | 
 |  |  |     @ManagerAuth(memo = "系统运行状态") | 
 |  |  | 
 |  |  |         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); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /****************************************************************/ | 
 |  |  |     /************************** 详情操作 ******************************/ | 
 |  |  |     /****************************************************************/ | 
 |  |  | 
 |  |  |         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); | 
 |  |  |     } | 
 |  |  |  | 
 |  |  | } |