From 2a8c4e590db641bbb3c1f5fc016a0b99bb52cdff Mon Sep 17 00:00:00 2001 From: rk <94314517@qq.com> Date: 星期二, 21 十月 2025 16:30:54 +0800 Subject: [PATCH] 月台自动叫号处理问题 --- server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/thrid/BoardServiceImpl.java | 623 +++++++++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 501 insertions(+), 122 deletions(-) diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/thrid/BoardServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/thrid/BoardServiceImpl.java index 9a41523..3cef32f 100644 --- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/thrid/BoardServiceImpl.java +++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/thrid/BoardServiceImpl.java @@ -91,7 +91,10 @@ private PlatformGroupMapper platformGroupMapper; @Autowired private TmsService tmsService; - + @Autowired + private PlatformDeviceMapper platformDeviceMapper; + @Autowired + private CategoryMapper categoryMapper; @Value("${debug_model}") private Boolean isDebug; /** @@ -132,6 +135,7 @@ .select(PlatformJob::getTotalNum) .eq(PlatformJob::getIsdeleted,Constants.ZERO) .eq(PlatformJob::getOrigin,Constants.ONE) + .in(PlatformJob::getType,new Integer[]{0,2,4}) .in(PlatformJob::getStatus, Constants.PlatformJobStatus.DONE.getKey() , Constants.PlatformJobStatus.AUTHED_LEAVE.getKey() , Constants.PlatformJobStatus.LEAVED.getKey()) @@ -148,6 +152,7 @@ List<PlatformJob> jobs = platformJobMapper.selectList (new MPJLambdaWrapper<PlatformJob>() .select(PlatformJob::getTotalNum) .eq(PlatformJob::getIsdeleted,Constants.ZERO) + .apply(" ( origin = 0 or origin is null) ") .eq(PlatformJob::getPlatformGroupId,platformGroupId) .apply("to_days(done_date) = to_days(now())") .in(PlatformJob::getStatus, Constants.PlatformJobStatus.DONE.getKey() @@ -186,7 +191,8 @@ List<WmsInventoryJsonResponse> t= response.getData().get(0).getJson(); if(t!=null &&t.size()>0){ for(WmsInventoryJsonResponse j :t){ - num = num.add (Constants.formatBigdecimal( j.getQty())); + //2025骞�4鏈�9鏃�16:46:40 澶勭悊 鍖呭惈鎵樼洏瀛楃溂鐨勬暟鎹� 涓嶈繘琛屽悎璁� + num = num.add (j.getItemName().indexOf("鎵樼洏")<Constants.ZERO?Constants.formatBigdecimal( j.getQty()):BigDecimal.ZERO); GeneralVO d = new GeneralVO(); d.setNum(Constants.formatBigdecimal(j.getQty())); d.setName(j.getItemName()); @@ -484,6 +490,7 @@ }*/ return list; } + @Override public WaningEventDataVO warningEventData(Integer type){ WaningEventDataVO lastResult = new WaningEventDataVO(); @@ -493,16 +500,39 @@ request.setPageSize(1000); request.setFiledOptions(new ArrayList<>()); request.setSorts(new ArrayList<>()); + request.setFetchImg(true); RuleEventFiledOptionsRequest file = new RuleEventFiledOptionsRequest(); file.setFieldName("event_type"); - file.setFieldValue("131588,131593");//瀹夐槻鍛婅鍜屼汉鍛樺憡璀� + //瀹夐槻浜嬩欢鍒掑垎鏂瑰紡锛� + //閲嶇偣鍖哄煙锛氶噸鐐逛汉鍛�-1644175361銆佸尯鍩熷叆渚�-1644175361銆侀檶鐢熶汉-1644171265銆佽溅杈嗚繚鍋�-1644171265 + //鍗遍櫓琛屼负锛氫汉鍛樺�掑湴-1644171265銆佹湭甯﹀畨鍏ㄥ附-422000002銆佹娊鐑�-422000000銆佹墦鐢佃瘽-422000001銆佺潯宀�-422400001銆佺宀�-422400000 + file.setFieldValue("131588,131593,1644171265,422000002,422000000,422000001,422400001,422400000,1644175361,1644175361,1644171265,1644171265");//瀹夐槻鍛婅鍜屼汉鍛樺憡璀� file.setType("in"); if(type == 1){ - file.setFieldValue("131588");//瀹夐槻鍛婅 + file.setFieldValue("131588,1644175361,1644175361,1644171265,1644171265");//瀹夐槻鍛婅 鍖哄煙鍏ヤ镜 }else if(type == 2){ - file.setFieldValue("131593");//浜哄憳鍛婅 + file.setFieldValue("131593,1644171265,422000002,422000000,422000001,422400001,422400000");//浜哄憳鍛婅 鍗遍櫓琛屼负 } request.getFiledOptions().add(file); + + RuleEventFiledOptionsRequest fileLte = new RuleEventFiledOptionsRequest(); + fileLte.setFieldName("happen_time"); + fileLte.setFieldValue(DateUtil.formatDate(Utils.Date.getEnd(new Date()),"yyyy-MM-dd HH:mm:ss")); + fileLte.setType("lte"); + request.getFiledOptions().add(fileLte); + + RuleEventFiledOptionsRequest fileGte = new RuleEventFiledOptionsRequest(); + fileGte.setFieldName("happen_time"); + fileGte.setFieldValue(DateUtil.formatDate(Utils.Date.getStart(new Date()),"yyyy-MM-dd HH:mm:ss")); + fileGte.setType("gte"); + request.getFiledOptions().add(fileGte); + + RuleEventFiledOptionsRequest fileStatus = new RuleEventFiledOptionsRequest(); + fileStatus.setFieldName("handle_status"); + fileStatus.setFieldValue("99"); + fileStatus.setType("neq"); + request.getFiledOptions().add(fileStatus); + SortRequest sort = new SortRequest(); sort.setSortField("happen_time"); sort.setSortType("desc"); @@ -518,6 +548,9 @@ try { if(DateUtil.getISO8601DateByStr(r.getHappen_time()).getTime() < Utils.Date.getStart(new Date()).getTime()){ continue; + } + if(StringUtils.equals(r.getStatus(),"99")){ + continue; } }catch (Exception e){ } @@ -615,6 +648,9 @@ if(response == null || !StringUtils.equals(response.getCode(), HKConstants.RESPONSE_SUCCEE)){ throw new BusinessException(ResponseStatus.SERVER_ERROR.getCode(), "瀵逛笉璧凤紝娴峰悍鍚屾鏁版嵁澶辫触~"); } + if(Objects.nonNull(response.getData().getList())){ + return data; + } for(FindHomeAlarmInfoPageResponse r : response.getData().getList()){ AlarmEventDataVO t = new AlarmEventDataVO(); BeanUtils.copyProperties(r,t); @@ -642,6 +678,8 @@ } /** * 銆愭秷闃茬鎺с�戠湅鏉�-瀹炴椂鐩戞祴鏁版嵁 + * 娑插帇鍥哄畾鍊硷細254001 + * 姘村帇鍥哄畾鍊硷細253958 * @return * */ @@ -651,6 +689,7 @@ MinitorDataSearchRequest param = new MinitorDataSearchRequest(); param.setResourceTypeCodes(new String[]{}); param.setRegionIndexCode("root000000"); + //60-娑蹭綅 61-姘村帇 param.setResourceTypeCodes("60,61".split(",")); param.setIncludeDown("1"); param.setUserId("admin"); @@ -659,6 +698,8 @@ BaseResponse<BaseListPageResponse<MonitorDataSearchResponse>> response = HKService.minitorDataSearch(param); String pressure = systemDictDataBiz.queryByCode(Constants.WMS_PARAM,Constants.WMS_PRESSURE_LEVEL).getCode(); String liquid = systemDictDataBiz.queryByCode(Constants.WMS_PARAM,Constants.WMS_LIQUID_LEVEL).getCode(); + String pressureUnit = systemDictDataBiz.queryByCode(Constants.HK_PARAM,Constants.PRESSURE_LEVEL_UNIT).getCode(); + String liquidUnit = systemDictDataBiz.queryByCode(Constants.HK_PARAM,Constants.LIQUID_LEVEL_UNIT).getCode(); if(response != null && StringUtils.equals(response.getCode(), HKConstants.RESPONSE_SUCCEE) && response.getData()!=null ) { List<MonitorDataSearchResponse> r = response.getData().getList(); @@ -666,11 +707,15 @@ for(MonitorDataSearchResponse model : r){ MonitorDataVO m = new MonitorDataVO(); m.setName(model.getName()); - m.setLevel(Constants.equalsInteger(model.getType(),60)?liquid:pressure); + m.setType(model.getType()); +// m.setLevel(Constants.equalsInteger(model.getType(),60)?liquid:pressure); + m.setLevel(getLevelDataByDeviceName(m,model.getName(),Constants.equalsInteger(model.getType(),60)?liquidUnit:pressureUnit)); m.setDataList(new ArrayList<>()); if(model.getValues()!=null){ List<MonitorDataInfoVO> dataList = new ArrayList<>(); for(MonitorDataValResponse v : model.getValues()){ + //娑插帇鍥哄畾鍊硷細254001 + //姘村帇鍥哄畾鍊硷細253958 if(Constants.equalsInteger(model.getType(),60)){ if(v.getMonitorTypeCode().equals("254001")){ MonitorDataInfoVO vm = new MonitorDataInfoVO(); @@ -678,7 +723,6 @@ vm.setCateName(v.getMonitorSpecificName()); vm.setCateCode(v.getMonitorTypeKey()); vm.setTypeCode(v.getMonitorTypeCode()); - vm.setTypeName(v.getMonitorTypeName()); dataList.add(vm); } }else{ @@ -701,6 +745,46 @@ } } return list; + } + + private String getLevelDataByDeviceName(MonitorDataVO m,String name,String unit) { + + /** + * { + * "name":"娑�", + * "regionIndexCodes": [ + * "root000000" + * ], + * "isSubRegion": true, + * "resourceType": "fireSensor", + * "pageNo": 1, + * "pageSize": 20, + * "orderBy": "name", + * "orderType": "desc" + * } + */ + String r = ""; + + ResourcesByParamsRequest param = new ResourcesByParamsRequest(); + param.setName(name); + param.setIsSubRegion(Boolean.TRUE); + param.setRegionIndexCodes(new String[]{"root000000"}); + param.setResourceType("fireSensor"); + param.setOrderType("desc"); + param.setOrderBy("name"); + param.setPageNo(1); + param.setPageSize(20); + BaseResponse<BaseListPageResponse<ResourcesByParamsResponse>> response = HKService.resourcesByParams(param); + if(response != null && StringUtils.equals(response.getCode(), HKConstants.RESPONSE_SUCCEE) + && response.getData()!=null ) { + String min = response.getData().getList().get(0).getFireproChannelMinValue(); + String max = response.getData().getList().get(0).getFireproChannelMaxvalue(); + m.setMax(max); + m.setMin(min); + r =StringUtils.defaultString(min,"-")+"锝�"+StringUtils.defaultString(max,"-") +unit; + } + return r; + } @@ -748,6 +832,20 @@ .apply(queryType==0,"to_days(create_date) >= to_days(now()) -7") .apply(queryType==1,"year(create_date) = year(now()) and month(create_date) = month(now())") .apply(queryType==2,"year(create_date) = year(now())")); + + + List<PlatformJob> finishDataList = platformJobMapper.selectJoinList(PlatformJob.class, + new MPJLambdaWrapper<PlatformJob>() + .selectAs(PlatformJob::getId,PlatformJob::getId) + .selectAs(PlatformJob::getCreateDate,PlatformJob::getCreateDate) + .selectAs(PlatformJob::getTotalNum,PlatformJob::getTotalNum) + .selectAs(PlatformJob::getStatus,PlatformJob::getStatus) + .eq(PlatformJob::getIsdeleted,Constants.ZERO) + .in(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey(),Constants.PlatformJobStatus.LEAVED.getKey(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey()) + .apply(queryType==0,"to_days(done_date) >= to_days(now()) -7") + .apply(queryType==1,"year(done_date) = year(now()) and month(done_date) = month(now())") + .apply(queryType==2,"year(done_date) = year(now())")); + for (Date date : dayList) { TransportMeasureVO data = new TransportMeasureVO(); data.setPlanDate(date); @@ -759,23 +857,34 @@ if(DateUtil.formatDate(date,"yyyy-MM").equals(DateUtil.formatDate(job.getCreateDate(),"yyyy-MM"))){ data.setPlanTimes( data.getPlanTimes() +1); data.setPlanTaskNum( data.getPlanTaskNum().add(Constants.formatBigdecimal(job.getTotalNum()))); - if(Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.DONE.getKey()) - ||Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.LEAVED.getKey()) - ||Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey())){ - //瀹屾垚鏁� - data.setFinishTaskNum( data.getFinishTaskNum().add(Constants.formatBigdecimal(job.getTotalNum()))); - } +// if(Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.DONE.getKey()) +// ||Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.LEAVED.getKey()) +// ||Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey())){ +// //瀹屾垚鏁� +// data.setFinishTaskNum( data.getFinishTaskNum().add(Constants.formatBigdecimal(job.getTotalNum()))); +// } } }else{ if(DateUtil.formatDate(date,"yyyy-MM-dd").equals(DateUtil.formatDate(job.getCreateDate(),"yyyy-MM-dd"))){ data.setPlanTimes( data.getPlanTimes() +1); data.setPlanTaskNum( data.getPlanTaskNum().add(Constants.formatBigdecimal(job.getTotalNum()))); - if(Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.DONE.getKey()) - ||Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.LEAVED.getKey()) - ||Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey())){ - //瀹屾垚鏁� +// if(Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.DONE.getKey()) +// ||Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.LEAVED.getKey()) +// ||Constants.equalsInteger(job.getStatus(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey())){ +// //瀹屾垚鏁� +// data.setFinishTaskNum( data.getFinishTaskNum().add(Constants.formatBigdecimal(job.getTotalNum()))); +// } + } + } + } + for (PlatformJob job :finishDataList) { + if(queryType == 2){ + if(DateUtil.formatDate(date,"yyyy-MM").equals(DateUtil.formatDate(job.getDoneDate(),"yyyy-MM"))){ data.setFinishTaskNum( data.getFinishTaskNum().add(Constants.formatBigdecimal(job.getTotalNum()))); - } + } + }else{ + if(DateUtil.formatDate(date,"yyyy-MM-dd").equals(DateUtil.formatDate(job.getDoneDate(),"yyyy-MM-dd"))){ + data.setFinishTaskNum( data.getFinishTaskNum().add(Constants.formatBigdecimal(job.getTotalNum()))); } } } @@ -801,11 +910,13 @@ .selectAll(PlatformJob.class) .eq(PlatformJob::getIsdeleted,Constants.ZERO) .eq(PlatformJob::getCarCodeFront,param.getCarCode()) - .in(PlatformJob::getStatus, + .notIn(PlatformJob::getStatus, Constants.PlatformJobStatus.DONE.getKey(), Constants.PlatformJobStatus.LEAVED.getKey(), Constants.PlatformJobStatus.AUTHED_LEAVE.getKey(), - Constants.PlatformJobStatus.CALLED.getKey()) + Constants.PlatformJobStatus.CANCEL.getKey() + ) + .orderByAsc(PlatformJob::getId) .last("limit 1")); dealJobDetailAndContractBiz(job,data); @@ -920,13 +1031,21 @@ /** * 銆愭秷闃茬鎺с�戠湅鏉�-鍛婅淇℃伅闆嗗悎 - * + * @param type 0/null = 褰撳ぉ锛�1=褰撴湀锛�2=褰撳勾 * @return * */ @Override - public AlarmDataVO alarmDataSumByCate(){ - AlarmDataVO alarmDataVO = getAlertDataByStartEndTime(DateUtil.getPlusTime2(DateUtil.addDaysToDate(new Date(),-1)) + public AlarmDataVO alarmDataSumByCate(Integer type){ + Date startDate = Utils.Date.getStart(new Date()); + if(Objects.nonNull(type)){ + if(Constants.equalsInteger(type,Constants.TWO)){ + startDate = Utils.Date.getStart(DateUtil.getFirstThisYearDate()); + }else if(Constants.equalsInteger(type,Constants.ONE)){ + startDate = Utils.Date.getStart(DateUtil.getFirstThisMonthDate()); + } + } + AlarmDataVO alarmDataVO = getAlertDataByStartEndTime(DateUtil.getPlusTime2(startDate) ,(DateUtil.getPlusTime2(new Date()))); return alarmDataVO; } @@ -944,17 +1063,35 @@ Date lastMonth = DateUtil.addMonthToDate(month,-1);//涓婃湀 Date year = Utils.Date.getStart(new Date());//浠婂勾 Date lastYear = DateUtil.addYearToDate(year,-1);//鍘诲勾 + log.error("1銆�=====================>"+DateUtil.getCurrDateTime()); List<PlatformJob> monthNum = platformJobMapper.selectJoinList(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() - .selectAs(PlatformJob::getId,PlatformJob::getId) - .select(PlatformJob::getType,PlatformJob::getType) - .select(PlatformJob::getTotalNum,PlatformJob::getTotalNum) - .select(PlatformJob::getStatus,PlatformJob::getStatus) + .selectAs(PlatformJob::getId,PlatformJob::getId) + .selectAs(PlatformJob::getTotalNum,PlatformJob::getTotalNum) + .selectAs(PlatformJob::getDoneDate,PlatformJob::getDoneDate) + .select(PlatformJob::getStatus,PlatformJob::getStatus) + .select(PlatformJob::getType,PlatformJob::getType) .eq(PlatformJob::getIsdeleted,Constants.ZERO) +// .in(PlatformJob::getType,Constants.ONE,Constants.THREE) .in(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey(), Constants.PlatformJobStatus.LEAVED.getKey(), Constants.PlatformJobStatus.AUTHED_LEAVE.getKey()) .apply("year(done_date) = year('"+DateUtil.getPlusTime2(month)+"') and month(done_date) = month('"+DateUtil.getPlusTime2(month)+"') ")); + + log.error("2銆�=====================>"+DateUtil.getCurrDateTime()); + List<PlatformJob> yearNum = platformJobMapper.selectJoinList(PlatformJob.class, + new MPJLambdaWrapper<PlatformJob>() + .selectAs(PlatformJob::getId,PlatformJob::getId) + .selectAs(PlatformJob::getTotalNum,PlatformJob::getTotalNum) + .select(PlatformJob::getStatus,PlatformJob::getStatus) + .select(PlatformJob::getType,PlatformJob::getType) +// .selectCount(PlatformJob::getPlatformId,PlatformJob::getCountum) + .eq(PlatformJob::getIsdeleted,Constants.ZERO) + .in(PlatformJob::getType,Constants.ONE,Constants.THREE) + .in(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey(),Constants.PlatformJobStatus.LEAVED.getKey(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey()) + .apply("year(done_date) = year('"+DateUtil.getPlusTime2(year)+"') and done_date<= now() ")); + + log.error("3銆�=====================>"+DateUtil.getCurrDateTime()); List<PlatformJob> monthLastNum = platformJobMapper.selectJoinList(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() .selectAs(PlatformJob::getId,PlatformJob::getId) @@ -967,17 +1104,8 @@ .in(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey(),Constants.PlatformJobStatus.LEAVED.getKey(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey()) .apply("year(done_date) = year('"+DateUtil.getPlusTime2(lastMonth)+"') and month(done_date) = month('"+DateUtil.getPlusTime2(lastMonth)+"') and done_date<= '" +DateUtil.getPlusTime2(lastMonth)+"'")); - List<PlatformJob> yearNum = platformJobMapper.selectJoinList(PlatformJob.class, - new MPJLambdaWrapper<PlatformJob>() - .selectAs(PlatformJob::getId,PlatformJob::getId) - .selectAs(PlatformJob::getTotalNum,PlatformJob::getTotalNum) - .select(PlatformJob::getStatus,PlatformJob::getStatus) - .select(PlatformJob::getType,PlatformJob::getType) -// .selectCount(PlatformJob::getPlatformId,PlatformJob::getCountum) - .eq(PlatformJob::getIsdeleted,Constants.ZERO) - .in(PlatformJob::getType,Constants.ONE,Constants.THREE) - .in(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey(),Constants.PlatformJobStatus.LEAVED.getKey(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey()) - .apply("year(done_date) = year('"+DateUtil.getPlusTime2(year)+"') and done_date<= '"+DateUtil.getPlusTime2(year)+"'")); + + log.error("4銆�=====================>"+DateUtil.getCurrDateTime()); List<PlatformJob> yearLastNum = platformJobMapper.selectJoinList(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() .selectAs(PlatformJob::getId,PlatformJob::getId) @@ -987,15 +1115,16 @@ .eq(PlatformJob::getIsdeleted,Constants.ZERO) .in(PlatformJob::getType,Constants.ONE,Constants.THREE) .in(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey(),Constants.PlatformJobStatus.LEAVED.getKey(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey()) - .apply("year(done_date) = year('"+DateUtil.getPlusTime2(lastYear)+"') and done_date<= '"+DateUtil.getPlusTime2(lastYear)+"'")); + .apply("year(done_date) = year('"+DateUtil.getPlusTime2(lastYear)+"') and done_date<= now() ")); data.setMonthOutTotal(getSumTotalByList(monthNum,0,null));//鏈湀鍑哄簱閲� data.setMonthLastOutTotal(getSumTotalByList(monthLastNum,null,null) );//涓婃湀鍑哄簱閲� data.setYearOutTotal(getSumTotalByList(yearNum,null,null) );//鏈勾鍑哄簱閲� data.setYearLastOutTotal(getSumTotalByList(yearLastNum,null,null) );//鍘诲勾鍑哄簱閲� - data.setMonthOutTimes(monthNum!=null?monthNum.size():0); + data.setMonthOutTimes(monthNum!=null?monthNum.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.ONE)||Constants.equalsInteger(i.getType(),Constants.THREE)).collect(Collectors.toList()).size():0); data.setYearOutTimes(yearNum!=null?yearNum.size():0); + log.error("5銆�=====================>"+DateUtil.getCurrDateTime()); //==========浠婂ぉ涔嬪墠鏈畬鎴愬嚭鍏ュ簱浠诲姟 List<PlatformJob> beforeJobNum = platformJobMapper.selectJoinList(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() @@ -1005,9 +1134,13 @@ .select(PlatformJob::getTotalNum,PlatformJob::getTotalNum) // .select("select sum(io_qty) from platform_wms_details a where a.isdeleted=0 and a.job_id=t.id",create_date) .eq(PlatformJob::getIsdeleted,Constants.ZERO) - .notIn(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey(),Constants.PlatformJobStatus.LEAVED.getKey(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey(),Constants.PlatformJobStatus.CALLED.getKey()) - .apply(" to_days(create_date) <to_days(now())")); + .notIn(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey(), + Constants.PlatformJobStatus.LEAVED.getKey(),Constants.PlatformJobStatus.AUTHED_LEAVE.getKey() + ,Constants.PlatformJobStatus.CANCEL.getKey()) + .apply(" to_days(create_date) < to_days(now()) ") + ); + log.error("6銆�=====================>"+DateUtil.getCurrDateTime()); //==========浠婂ぉ鍑哄叆搴撳畬鎴愰噺 List<PlatformJob> currentDoneNum = platformJobMapper.selectJoinList(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() @@ -1017,9 +1150,11 @@ .select(PlatformJob::getTotalNum,PlatformJob::getTotalNum) // .select("select sum(io_qty) from platform_wms_details a where a.isdeleted=0 and a.job_id=t.id",create_date) .eq(PlatformJob::getIsdeleted,Constants.ZERO) - .notIn(PlatformJob::getStatus,Constants.PlatformJobStatus.CALLED.getKey()) + .notIn(PlatformJob::getStatus,Constants.PlatformJobStatus.CANCEL.getKey()) .apply(" to_days(done_date) = to_days(now())")); - //==========浠婂ぉ涓嬪彂鍑哄叆搴撲换鍔�---- + + log.error("7銆�=====================>"+DateUtil.getCurrDateTime()); + //==========浠婂ぉ涓嬪彂鍑哄叆搴撲换鍔� 鏈畬鎴愮殑---- List<PlatformJob> currentNum = platformJobMapper.selectJoinList(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() .selectAs(PlatformJob::getId,PlatformJob::getId) @@ -1028,38 +1163,63 @@ .select(PlatformJob::getTotalNum,PlatformJob::getTotalNum) // .select("select sum(io_qty) from platform_wms_details a where a.isdeleted=0 and a.job_id=t.id",create_date) .eq(PlatformJob::getIsdeleted,Constants.ZERO) - .notIn(PlatformJob::getStatus,Constants.PlatformJobStatus.CALLED.getKey()) - .apply(" to_days(create_date) = to_days(now())")); + .notIn(PlatformJob::getStatus,Constants.PlatformJobStatus.CANCEL.getKey()) + .apply(" to_days(create_date) = to_days(now()) and done_date is null ")); + log.error("8銆�=====================>"+DateUtil.getCurrDateTime()); BigDecimal beforeOutNum = (getSumTotalByList(beforeJobNum,0,null));//浠婂ぉ涔嬪墠鏈畬鎴愬嚭搴撲换鍔� + log.error("9銆�=====================>"+DateUtil.getCurrDateTime()); BigDecimal currentOutNum = (getSumTotalByList(currentNum,0,null));//浠婂ぉ涓嬪彂鍑哄簱浠诲姟 + log.error("10銆�=====================>"+DateUtil.getCurrDateTime()); BigDecimal beforeInNum = (getSumTotalByList(beforeJobNum,1,null));//浠婂ぉ涔嬪墠鏈畬鎴愬叆搴撲换鍔� + log.error("11銆�=====================>"+DateUtil.getCurrDateTime()); BigDecimal currentInNum = (getSumTotalByList(currentNum,1,null));//浠婂ぉ涓嬪彂鍏ュ簱浠诲姟 - data.setCurrentInNum(beforeInNum.add(currentInNum));//褰撳墠鍏ュ簱鎬讳换鍔℃垚閲� - data.setCurrentOutNum(beforeOutNum.add(currentOutNum));//褰撳墠鍑哄簱鎬讳换鍔℃垚閲� + log.error("12銆�=====================>"+DateUtil.getCurrDateTime()); data.setCurrentInDoneNum(getSumTotalByList(currentDoneNum,1,1));//浠婃棩瀹屾垚閲� + log.error("13銆�=====================>"+DateUtil.getCurrDateTime()); data.setCurrentOutDoneNum(getSumTotalByList(currentDoneNum,0,1));//浠婃棩瀹屾垚閲� + log.error("14銆�=====================>"+DateUtil.getCurrDateTime()); + data.setCurrentInNum(beforeInNum.add(data.getCurrentInDoneNum()).add(currentInNum));//褰撳墠鍏ュ簱鎬讳换鍔℃垚閲� + log.error("15銆�=====================>"+DateUtil.getCurrDateTime()); + data.setCurrentOutNum(beforeOutNum.add(data.getCurrentOutDoneNum()).add(currentOutNum));//褰撳墠鍑哄簱鎬讳换鍔℃垚閲� + log.error("16銆�=====================>"+DateUtil.getCurrDateTime()); + data.setTodayOutRate(getDayTotalRata(data.getCurrentOutDoneNum(),DateUtil.getToday()));//褰撴棩鍑哄簱鏁堢巼 + log.error("17銆�=====================>"+DateUtil.getCurrDateTime()); + data.setTodayInRate(getDayTotalRata(data.getCurrentInDoneNum(),DateUtil.getToday()));//褰撴棩鍏ュ簱鏁堢巼 + log.error("18銆�=====================>"+DateUtil.getCurrDateTime()); + //鏌ヨ鏈湀鍏ㄩ儴鏃ュ織 + List<PlatformLog> monthLogList = platformLogMapper.selectList(new QueryWrapper<PlatformLog>().lambda() + .eq(PlatformLog::getIsdeleted,Constants.ZERO) + .and(i->i.isNotNull(PlatformLog::getParam1).or().isNotNull(PlatformLog::getParam2)) + .apply("year(CREATE_DATE) = year('"+DateUtil.getPlusTime2(month)+"') and month(CREATE_DATE) = month('"+DateUtil.getPlusTime2(month)+"') ") + ); - //------------浠婃棩鍑哄叆搴撴晥鐜�---------------- - BigDecimal outHours = getTotalDoneTimes(currentDoneNum,0);// - BigDecimal inHours = getTotalDoneTimes(currentDoneNum,1);// - if(outHours.compareTo(new BigDecimal(0))>0){ - data.setTodayOutRate(data.getCurrentOutDoneNum().divide(outHours,2));//褰撳墠鍏ュ簱鎬讳换鍔℃垚閲� - } - if(inHours.compareTo(new BigDecimal(0))>0){ - data.setTodayInRate(data.getCurrentInDoneNum().divide(inHours,2));//褰撳墠鍏ュ簱鎬讳换鍔℃垚閲� - } + + data.setMonthOutRate(getMonthRata(monthLogList,monthNum,Constants.ZERO));//鏈湀鍑哄簱鏁堢巼 + log.error("19銆�=====================>"+DateUtil.getCurrDateTime()); + data.setMonthInRate(getMonthRata(monthLogList,monthNum,Constants.ONE));//鏈湀鍏ュ簱鏁堢巼 + log.error("20銆�=====================>"+DateUtil.getCurrDateTime()); + //------------浠婃棩鍑哄叆搴撴晥鐜�---------------- +// BigDecimal outHours = getTotalDoneTimes(currentDoneNum,0);// +// BigDecimal inHours = getTotalDoneTimes(currentDoneNum,1);// +// +// if(outHours.compareTo(new BigDecimal(0))>0){ +// data.setTodayOutRate(data.getCurrentOutDoneNum().divide(outHours,2));//褰撳墠鍏ュ簱鎬讳换鍔℃垚閲� +// } +// if(inHours.compareTo(new BigDecimal(0))>0){ +// data.setTodayInRate(data.getCurrentInDoneNum().divide(inHours,2));//褰撳墠鍏ュ簱鎬讳换鍔℃垚閲� +// } //------------鏈湀鍑哄叆搴撴晥鐜�---------------- // BigDecimal outMonthNum = getSumTotalByList(monthNum,0,null).add(data.getCurrentOutDoneNum()); - BigDecimal inMonthNum = getSumTotalByList(monthNum,1,null).add(data.getCurrentInDoneNum()); - BigDecimal outMonthHours = getTotalDoneTimes(monthNum,0).add(outHours);// - BigDecimal inMonthHours = getTotalDoneTimes(monthNum,1).add(inHours);// - if(outMonthHours.compareTo(new BigDecimal(0))>0){ - data.setMonthOutRate(data.getMonthOutTotal().divide(outMonthHours,0,BigDecimal.ROUND_HALF_UP));//鏈湀鍏ュ簱鏁堢巼 - } - if(inMonthHours.compareTo(new BigDecimal(0))>0){ - data.setMonthInRate(inMonthNum.divide(inMonthHours,0,BigDecimal.ROUND_HALF_UP));//鏈湀鍏ュ簱鏁堢巼 - } +// BigDecimal inMonthNum = getSumTotalByList(monthNum,1,null).add(data.getCurrentInDoneNum()); +// BigDecimal outMonthHours = getTotalDoneTimes(monthNum,0).add(outHours);// +// BigDecimal inMonthHours = getTotalDoneTimes(monthNum,1).add(inHours);// +// if(outMonthHours.compareTo(new BigDecimal(0))>0){ +// data.setMonthOutRate(data.getMonthOutTotal().divide(outMonthHours,0,BigDecimal.ROUND_HALF_UP));//鏈湀鍑哄簱鏁堢巼 +// } +// if(inMonthHours.compareTo(new BigDecimal(0))>0){ +// data.setMonthInRate(inMonthNum.divide(inMonthHours,0,BigDecimal.ROUND_HALF_UP));//鏈湀鍏ュ簱鏁堢巼 +// } return data; } @@ -1071,10 +1231,9 @@ if(platformLogList!=null && platformLogList.size()>0){ return new BigDecimal((double)(platformLogList.stream().map(m->Long.valueOf(m.getParam3())).reduce(Long.valueOf(0),Long::sum))/(double)60); } - return new BigDecimal(0); - } + private BigDecimal getTotalDoneTimes(List<PlatformJob> list, Integer type) { BigDecimal r = new BigDecimal(0); if(list==null || list.size() == 0){ @@ -1109,6 +1268,117 @@ } return r; } + + + private BigDecimal getMonthRata(List<PlatformLog> monthLogList,List<PlatformJob> list, Integer type) { + BigDecimal r = new BigDecimal(0); + if(list==null || list.size() == 0){ + return r; + } + List<PlatformJob> jobList= new ArrayList<>(); + for(PlatformJob job : list) { + if (!(Constants.equalsInteger(job.getStatus(), Constants.PlatformJobStatus.DONE.getKey()) + || Constants.equalsInteger(job.getStatus(), Constants.PlatformJobStatus.LEAVED.getKey()) + || Constants.equalsInteger(job.getStatus(), Constants.PlatformJobStatus.AUTHED_LEAVE.getKey()))) { + //鍙煡璇㈠畬鎴愭暟鎹� + continue; + } + if (type != null && type == 0 && (Constants.equalsInteger(job.getType(), Constants.ONE) || Constants.equalsInteger(job.getType(), Constants.THREE))) { + //鍑哄簱 + jobList.add(job); + } + if (type != null && type == 1 && (Constants.equalsInteger(job.getType(), Constants.ZERO) || Constants.equalsInteger(job.getType(), Constants.TWO) || Constants.equalsInteger(job.getType(), Constants.FOUR))) { + //鍏ュ簱 + jobList.add(job); + } + } + if(CollectionUtils.isNotEmpty(jobList)){ + //鑾峰彇浠诲姟鏁版嵁 + List<String> jobDataList = jobList.stream().filter(i->Objects.nonNull(i.getDoneDate())) + .map(i->DateUtil.formatDate(i.getDoneDate(),"yyyy-MM-dd")).collect(Collectors.toList()); + if(CollectionUtils.isNotEmpty(jobDataList)){ + for (String jobDate:jobDataList) { + //杩囨护褰撳ぉ鐨勬暟鎹� + List<PlatformJob> platformJobList = list.stream(). + filter(i->jobDate.equals(DateUtil.formatDate(i.getDoneDate(),"yyyy-MM-dd"))).collect(Collectors.toList()); + if(CollectionUtils.isNotEmpty(platformJobList)){ + //鑾峰彇浠婂ぉ鐨� + r = r.add(this.getDayTotalForMonthRata(monthLogList,getSumTotalByList(platformJobList,type,null),jobDate)); + } + } + r = r.divide(new BigDecimal(Integer.toString(jobList.size())),2,BigDecimal.ROUND_HALF_UP); + } + } + return r; + } + + private BigDecimal getDayTotalForMonthRata(List<PlatformLog> allList ,BigDecimal totalAmount,String today) { + BigDecimal r = new BigDecimal(0); + //鏌ヨ浠婃棩鏈�鏃�/鏈�鏅氱殑浣滀笟鏁版嵁 + List<PlatformLog> platformLogList = allList.stream().filter(i->DateUtil.formatDate(i.getCreateDate(),"yyyy-MM-dd").equals(today)).collect(Collectors.toList()); +// platformLogMapper.selectList(new QueryWrapper<PlatformLog>() +// .lambda() +// .apply(" ( DATE_FORMAT( param1 ,'%Y-%m-%d' ) = '"+today+"' or DATE_FORMAT( param2 ,'%Y-%m-%d' ) = '"+today+"' ) ") +// ); + if(totalAmount.compareTo(BigDecimal.ZERO)==0||CollectionUtils.isEmpty(platformLogList)){ + return BigDecimal.ZERO; + } + if(platformLogList!=null && platformLogList.size()>0){ + return this.getWorkTime(totalAmount,platformLogList,today); + } + return r; + } + + + private BigDecimal getDayTotalRata(BigDecimal totalAmount,String today) { + BigDecimal r = new BigDecimal(0); + //鏌ヨ浠婃棩鏈�鏃�/鏈�鏅氱殑浣滀笟鏁版嵁 + List<PlatformLog> platformLogList = platformLogMapper.selectList(new QueryWrapper<PlatformLog>() + .lambda() + .apply(" ( DATE_FORMAT( param1 ,'%Y-%m-%d' ) = '"+today+"' or DATE_FORMAT( param2 ,'%Y-%m-%d' ) = '"+today+"' ) ") + ); + if(totalAmount.compareTo(BigDecimal.ZERO)==0||CollectionUtils.isEmpty(platformLogList)){ + return BigDecimal.ZERO; + } + if(platformLogList!=null && platformLogList.size()>0){ + return this.getWorkTime(totalAmount,platformLogList,today); + } + return r; + } + + /** + * 鏌ヨ浣滀笟鏃堕暱锛堝皬鏃讹級 + * @param totalAmount + * @param platformLogList + * @return + */ + public BigDecimal getWorkTime(BigDecimal totalAmount,List<PlatformLog> platformLogList,String today){ + if(CollectionUtils.isEmpty(platformLogList)){ + return BigDecimal.ZERO; + } + //鑾峰彇寮�濮嬫椂闂� + List<Long> startTimeList = platformLogList.stream().filter(i->Objects.nonNull(i.getParam1())) + .filter(i->Objects.nonNull(i.getParam1())&&i.getParam1().indexOf(today)>=0) + .map(i->DateUtil.fromStringToDate("yyyy-MM-dd HH:mm:ss",i.getParam1()).getTime()).collect(Collectors.toList()); + Long startTime = null ; + if(CollectionUtils.isNotEmpty(startTimeList)){ + startTime = Collections.min(startTimeList); + } + //鑾峰彇缁撴潫鏃堕棿 + List<Long> endTimeList = platformLogList.stream() + .filter(i->Objects.nonNull(i.getParam2())&&i.getParam2().indexOf(today)>=0) + .map(i->DateUtil.fromStringToDate("yyyy-MM-dd HH:mm:ss",i.getParam2()).getTime()).collect(Collectors.toList()); + Long endTime = null ; + if(CollectionUtils.isNotEmpty(endTimeList)){ + endTime = Collections.max(endTimeList); + } + if(Objects.isNull(startTime) + || Objects.isNull(endTime) || (startTime>=endTime)){ + return BigDecimal.ZERO; + } + return totalAmount.divide(new BigDecimal(( endTime - startTime )+"").divide(new BigDecimal("3600000"),2,BigDecimal.ROUND_HALF_UP),2,BigDecimal.ROUND_HALF_UP) ; + } + private BigDecimal getSumTotalByList(List<PlatformJob> list,Integer type,Integer status) { BigDecimal r = new BigDecimal(0); @@ -1315,12 +1585,13 @@ data.setDeviceTypeList(list); Long totalNum =hiddenDangerMapper.selectCount(new QueryWrapper<HiddenDanger>().lambda() .eq(HiddenDanger::getIsdeleted,Constants.ZERO ) - .apply("to_days(create_date) = to_days(now())" ) ); + .apply(" DATE_FORMAT(create_date, '%Y-%m') = DATE_FORMAT(now(), '%Y-%m') " ) ); data.setDangerTotalNum(totalNum !=null?totalNum.intValue():0);//浠婃棩闅愭偅鏁伴噺 totalNum =hiddenDangerMapper.selectCount(new QueryWrapper<HiddenDanger>().lambda() .eq(HiddenDanger::getIsdeleted,Constants.ZERO ) - .in(HiddenDanger::getStatus,Constants.ONE,Constants.TWO ) - .apply("to_days(check_date) = to_days(now())" ) ); +// .in(HiddenDanger::getStatus,Constants.ONE,Constants.TWO ) + .eq(HiddenDanger::getStatus,Constants.ZERO ) + .apply(" DATE_FORMAT(create_date, '%Y-%m') = DATE_FORMAT(now(), '%Y-%m') " ) ); data.setDangerDealedNum(totalNum !=null?totalNum.intValue():0);//浠婃棩澶勭悊闅愭偅鏁伴噺 return data; } @@ -1733,17 +2004,16 @@ @Override public VisitDataVO visitSecurityData(){ //寰呰闂�佸凡鐧昏銆佸凡绂诲紑 - VisitDataVO result = new VisitDataVO(); result.setWaitVisitNum(visitsJoinMapper.selectCount(new MPJLambdaWrapper<Visits>() .eq(Visits::getIsdeleted,Constants.ZERO) - .apply("to_days(create_date)=to_days(now())") + .apply(" now() > STARTTIME and now() < ENDTIME") .in(Visits::getStatus,Constants.VisitStatus.pass,Constants.VisitStatus.xfSuccess )));//寰呰闂� - result.setWaitVisitNum(visitsJoinMapper.selectCount(new MPJLambdaWrapper<Visits>() + result.setRegisterVisitNum(visitsJoinMapper.selectCount(new MPJLambdaWrapper<Visits>() .eq(Visits::getIsdeleted,Constants.ZERO) .apply("to_days(create_date)=to_days(now())") .in(Visits::getStatus,Constants.VisitStatus.signout,Constants.VisitStatus.signin )));//宸茬櫥璁� - result.setWaitVisitNum(visitsJoinMapper.selectCount(new MPJLambdaWrapper<Visits>() + result.setLevelNum(visitsJoinMapper.selectCount(new MPJLambdaWrapper<Visits>() .eq(Visits::getIsdeleted,Constants.ZERO) .apply("to_days(create_date)=to_days(now())") .in(Visits::getStatus,Constants.VisitStatus.signout )));//宸茬绂� @@ -1791,6 +2061,7 @@ result.getVisitRetentionDataList().add(t); }); } + result.setRetentionNum(result.getVisitRetentionDataList().size()); return result; } @@ -1813,11 +2084,11 @@ ); //鍦ㄥ洯闀挎湡鐩稿叧鏂逛汉鏁� data.setRelatedTotal( - (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.TWO) && Constants.equalsInteger(i.getCompanyType(),Constants.ZERO)).count() + (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.FOUR) ).count() ); //鍦ㄥ洯鍐呴儴鍛樺伐浜烘暟 data.setInternalTotal( - (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.TWO) && Constants.equalsInteger(i.getCompanyType(),Constants.ONE)).count() + (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.TWO) ).count() ); //鍦ㄥ洯璁垮鏁伴噺 data.setVisitTotal( @@ -1827,7 +2098,13 @@ data.setInParkCarTotal( (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.THREE)).count() ); - //鍦ㄥ洯鐩稿叧鏂硅溅杈� + //2025骞�8鏈�4鏃�09:24:23 鏇存崲鏁版嵁婧� 涓嶄粠娴峰悍鍙� + data.setFreeParkingLot(data.getParkingLotTotal()<data.getInParkCarTotal()?Constants.ZERO:data.getParkingLotTotal() - data.getInParkCarTotal()); + //褰撳墠鍦ㄥ洯璐ц溅鍙告満鎬绘暟 + data.setInParkCarUserTotal( + (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.FIVE)).count() + ); + /* //鍦ㄥ洯鐩稿叧鏂硅溅杈� data.setRelatedCarTotal( (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.THREE) &&Constants.equalsInteger(i.getCarType(),Constants.RetentionCarType.relation)).count() @@ -1836,30 +2113,66 @@ data.setInternalCarTotal( (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.THREE) &&Constants.equalsInteger(i.getCarType(),Constants.RetentionCarType.internal)).count() - ); + );*/ //鏉ヨ杞﹁締 data.setVisitCarTotal( (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.THREE) - &&Constants.equalsInteger(i.getCarType(),Constants.RetentionCarType.visitor)).count() + &&Constants.equalsInteger(i.getCarType(),Constants.RetentionCarType.fkCar)).count() ); //鑷敱鐗╂祦杞︽暟閲� data.setVisitCarTotal( (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.THREE) - &&Constants.equalsInteger(i.getCarType(),Constants.RetentionCarType.selfTruck)).count() + &&Constants.equalsInteger(i.getCarType(),Constants.RetentionCarType.atwlzyCar)).count() ); //甯傚叕鍙稿嵏璐ц溅鏁伴噺 data.setInternalJobCarTotal( (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.THREE) - &&Constants.equalsInteger(i.getCarType(),Constants.RetentionCarType.cityComTruck)).count() + &&Constants.equalsInteger(i.getCarType(),Constants.RetentionCarType.sgsxhCar)).count() ); //澶栧崗杞︽暟閲� data.setRelatedJobCarTotal( (int) retentionList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.THREE) - &&Constants.equalsInteger(i.getCarType(),Constants.RetentionCarType.outTruck)).count() + &&Constants.equalsInteger(i.getCarType(),Constants.RetentionCarType.wxysCar)).count() ); data.setVideoPluginUrl(getVideoUrl()); + + data.setOutHyLotTotal(Integer.valueOf(systemDictDataBiz.queryByCode(Constants.WMS_PARAM,Constants.OUT_HY_LOT_TOTAL).getCode())); + + + data.setInParkCarList(this.getInParkCars(data)); + return data; } + + + public List<Map<String,Object>> getInParkCars(SecurityBoardVO securityBoardVO){ + List<Map<String,Object>> mapList = categoryMapper.selectJoinMaps(new MPJLambdaWrapper<Category>() + .select(Category::getName) + .select(" ( select count(1) from retention r where r.isdeleted = 0 and r.CATEGORY_PARENT_ID = t.id and r.TYPE = 3 ) as total ") + .eq(Category::getType,Constants.ONE) + .eq(Category::getIsdeleted,Constants.ZERO) + .isNull(Category::getParentId) + .groupBy(Category::getName) + + ); + if(CollectionUtils.isEmpty(mapList)){ + mapList = new ArrayList<>(); + } + Map<String,Object> map = new HashMap<>(); + map.put("name","鏈煡杞﹁締"); + map.put("total", retentionMapper.selectCount( + new MPJLambdaWrapper<Retention>() + .eq(Retention::getIsdeleted,Constants.ZERO) + .isNull(Retention::getCategoryId) + .eq(Retention::getCarType,Constants.SIX) + ) + ); + mapList.add(map); + return mapList; + + } + + private String getVideoUrl() { return systemDictDataBiz.queryByCode(Constants.FTP,Constants.FTP_RESOURCE_PATH).getCode()+"plugin/VideoWebPlugin.exe"; @@ -1901,8 +2214,12 @@ .in(PlatformJob ::getStatus,new Integer[]{Constants.PlatformJobStatus.WORKING.getKey(),Constants.PlatformJobStatus.CALLED.getKey() }) // .leftJoin(Platform.class,Platform::getId,PlatformJob::getPlatformId) .orderByDesc(PlatformJob::getStatus ) - .orderByAsc(PlatformJob::getId ) + .orderByAsc(PlatformJob::getSortnum ) ); + List<PlatformDevice> platformDevices = platformDeviceMapper.selectList(new QueryWrapper<PlatformDevice>().lambda().eq(PlatformDevice::getType,Constants.ONE) + .eq(PlatformDevice::getIsdeleted,Constants.ZERO).isNotNull(PlatformDevice::getDeviceId)); + + String videoUrl = getVideoUrl(); //鏈堝彴鐘舵�侊細0=浣滀笟涓紱1=绌洪棽涓紱2=浣滀笟瓒呮椂;3=鍙彿 for(Platform model : platformList){ PlatformWorkDataVO platformDurationVO = new PlatformWorkDataVO(); @@ -1910,6 +2227,13 @@ platformDurationVO.setPlatformId(model.getId()); platformDurationVO.setPlatformCode(model.getCode()); platformDurationVO.setPlatformSort(model.getSortnum()); + if(CollectionUtils.isNotEmpty(platformDevices)){ + List<PlatformDevice> deviceList = platformDevices.stream().filter(i->Constants.equalsInteger(i.getPlatformId(),model.getId())).collect(Collectors.toList()); + if (CollectionUtils.isNotEmpty(deviceList)) { + platformDurationVO.setDeviceId(deviceList.get(Constants.ZERO).getDeviceId()); + platformDurationVO.setVideoPluginUrl(videoUrl); + } + } PlatformJob job = getJobFromListById(model.getId(),jobList); if(job != null){ if(Constants.equalsInteger(job.getType(),Constants.ONE) || Constants.equalsInteger(job.getType(),Constants.THREE)){ @@ -1970,7 +2294,7 @@ List<PlatformJob> jobList = platformJobMapper.selectJoinList(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() .selectAll( PlatformJob.class) // .select("(select sum(ifnull(a.io_qty,0)) from platform_wms_detail a where a.isdeleted=0 and a.job_id =t.id )", create_date) - .apply("to_days(t.create_date) = to_days(now())") + .apply("to_days(t.done_date) = to_days(now())") .eq(Platform::getIsdeleted, Constants.ZERO) .in(PlatformJob::getStatus, Constants.PlatformJobStatus.DONE.getKey() , Constants.PlatformJobStatus.AUTHED_LEAVE.getKey() @@ -1984,7 +2308,7 @@ } int curtotalNum = 0; Date today = Utils.Date.getStart(new Date()); - long curTime=0, lastTime=0; + long curTime=0, lastTime=0 ; for (int i = 0; i < 8; i++) { lastTime = curTime;//涓婃鐨勬椂闂� int curHour = 8+(i*2); @@ -2007,7 +2331,7 @@ curtotalNum += Constants.formatIntegerNum(workEfficiencyVO.getWorkNum()) ; } workEfficiencyVO.setTotalWorkNum(curtotalNum);//绱鍊� - if(System.currentTimeMillis() < curTime){ + if((System.currentTimeMillis() + 2*60*60*1000) < curTime ){ workEfficiencyVO.setTotalWorkNum(0); } workEfficiencyVOList.add(workEfficiencyVO); @@ -2049,7 +2373,8 @@ .selectAs(Platform::getName,PlatformWarnEvent::getPlatformName) .leftJoin(Platform.class,Platform::getId,PlatformJob::getPlatformId) .eq(PlatformWarnEvent::getIsdeleted,Constants.ZERO) - .apply("to_days(t.create_date) = to_days(now())") + //.apply(" to_days(t.create_date) = to_days(now()) ") + .apply(" ( t.create_date > now() - INTERVAL 10 MINUTE ) ") .orderByDesc(PlatformWarnEvent::getCreateDate) .last(" limit "+limit) ); @@ -2190,15 +2515,22 @@ //宸蹭綔涓氭暟 data.setWorkedNum(platformJobMapper.selectCount(new MPJLambdaWrapper<PlatformJob>() .eq(PlatformJob::getIsdeleted,Constants.ZERO) - .and(w->{w.eq(PlatformJob::getStatus,Constants.PlatformJobStatus.WORKING.getKey());}) - .and(w->{w.in(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey() + .and(w-> w.eq(PlatformJob::getStatus,Constants.PlatformJobStatus.WORKING.getKey()) + .or().in(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey() ,Constants.PlatformJobStatus.AUTHED_LEAVE.getKey() - ,Constants.PlatformJobStatus.LEAVED.getKey()) - .apply("to_days(done_date) = to_days(now())");}) - .and(w->{w.eq(PlatformJob::getStatus,Constants.PlatformJobStatus.EXCEPTION.getKey()) - .apply("to_days(error_date) = to_days(now())");}) - .and(w->{w.eq(PlatformJob::getStatus,Constants.PlatformJobStatus.TRANSFERING.getKey()) - .apply("to_days(trans_platform_date) = to_days(now())");}) + ,Constants.PlatformJobStatus.LEAVED.getKey()).apply("to_days(done_date) = to_days(now())") + .or().eq(PlatformJob::getStatus,Constants.PlatformJobStatus.EXCEPTION.getKey()).apply("to_days(done_date) = to_days(now())") + .or().eq(PlatformJob::getStatus,Constants.PlatformJobStatus.TRANSFERING.getKey()).apply("to_days(trans_platform_date) = to_days(now())") + ) +// .and(w->{w.eq(PlatformJob::getStatus,Constants.PlatformJobStatus.WORKING.getKey());}) +// .and(w->{w.in(PlatformJob::getStatus,Constants.PlatformJobStatus.DONE.getKey() +// ,Constants.PlatformJobStatus.AUTHED_LEAVE.getKey() +// ,Constants.PlatformJobStatus.LEAVED.getKey()) +// .apply("to_days(done_date) = to_days(now())");}) +// .and(w->{w.eq(PlatformJob::getStatus,Constants.PlatformJobStatus.EXCEPTION.getKey()) +// .apply("to_days(error_date) = to_days(now())");}) +// .and(w->{w.eq(PlatformJob::getStatus,Constants.PlatformJobStatus.TRANSFERING.getKey()) +// .apply("to_days(trans_platform_date) = to_days(now())");}) ).intValue()); data.setVideoPluginUrl(getVideoUrl()); @@ -2302,6 +2634,36 @@ */ @Override public WholeProvinceBoardVO centerProvinceData(String factoryCode){ + WholeProvinceBoardVO data = initWholeProvinceBoardVOData(factoryCode); + /* Date date = new Date(); + TmsOutQtyAndVehicleQtyRequest param = new TmsOutQtyAndVehicleQtyRequest(); + param.setDateEnd(DateUtil.getShortTime(date)); + param.setDateStart(DateUtil.getShortTime(date)); + if(StringUtils.isNotBlank(code)){ + param.setFacrotyCodeList(new ArrayList<>()); + param.getFacrotyCodeList().add(code);//鏌ヨ鎸囧畾鍘傚尯 + } + List<TmsOutQtyAndVehicleQtyResponse> listSame= tmsService.getOutQtyAndVehicleQty(param); + if(listSame!=null ){ + for(TmsOutQtyAndVehicleQtyResponse model : listSame){ + data.setCrrentOutNum(data.getCrrentOutNum().add(Constants.formatBigdecimal(model.getTotalOutQty())));//浠婃棩鍑哄簱閲� + data.setCrrentOutCarNum(data.getCrrentOutCarNum()+(Constants.formatIntegerNum(model.getVehicleQty())));//浠婃棩鍑哄簱杞︽ + } + }*/ + initOutboundCapability(data,factoryCode); + return data; + + } + @Override + public WholeProvinceBoardVO centerProvinceDataNew(String factoryCode){ + WholeProvinceBoardVO data = initWholeProvinceBoardVOData(factoryCode); + + initOutboundCapabilityNew(data,factoryCode); + return data; + + } + + private WholeProvinceBoardVO initWholeProvinceBoardVOData(String factoryCode) { WholeProvinceBoardVO data = new WholeProvinceBoardVO(); data.setMaxAbility(new BigDecimal(0)); data.setHoursAbility(new BigDecimal(0)); @@ -2330,24 +2692,42 @@ } } } - /* Date date = new Date(); - TmsOutQtyAndVehicleQtyRequest param = new TmsOutQtyAndVehicleQtyRequest(); - param.setDateEnd(DateUtil.getShortTime(date)); - param.setDateStart(DateUtil.getShortTime(date)); + return data; + } + + private void initOutboundCapabilityNew(WholeProvinceBoardVO data, String code) { + TmsFacrotyCodeListRequest param = new TmsFacrotyCodeListRequest(); if(StringUtils.isNotBlank(code)){ param.setFacrotyCodeList(new ArrayList<>()); - param.getFacrotyCodeList().add(code);//鏌ヨ鎸囧畾鍘傚尯 + param.getFacrotyCodeList().add(code); } - List<TmsOutQtyAndVehicleQtyResponse> listSame= tmsService.getOutQtyAndVehicleQty(param); - if(listSame!=null ){ - for(TmsOutQtyAndVehicleQtyResponse model : listSame){ - data.setCrrentOutNum(data.getCrrentOutNum().add(Constants.formatBigdecimal(model.getTotalOutQty())));//浠婃棩鍑哄簱閲� - data.setCrrentOutCarNum(data.getCrrentOutCarNum()+(Constants.formatIntegerNum(model.getVehicleQty())));//浠婃棩鍑哄簱杞︽ - } - }*/ - initOutboundCapability(data,factoryCode); - return data; + TmsGetOutCapabilityResponse result= tmsService.getOutCapacity(param); + if(result !=null){ + data.setCrrentOutNum(Constants.formatBigdecimal(result.getCurrentOutNum()) );//浠婃棩鍑哄簱閲� + data.setNeedTransportOrderNum(Constants.formatBigdecimal(result.getCurrentTransportNum()));//褰撳墠浠诲姟閲�-宸查厤杞芥湭鍑哄簱 + data.setNoNeedTransportOrderNum(Constants.formatBigdecimal(result.getCurrentNotTransportNum()) );//褰撳墠浠诲姟閲�-鏃犻渶璋冨害 + data.setCrrentRestNum(Constants.formatBigdecimal(result.getCurrentTransportNum()));//鍓╀綑浠诲姟閲�-宸查厤杞芥湭鍑哄簱 + data.setCurrentOrderNum(Constants.formatBigdecimal(result.getCurrentOrderNum()) );//褰撳墠璁㈠崟閲� + data.setCurrentPlanCarNum(Constants.formatBigdecimal(result.getCurrentTransportVehicleNum()).intValue() );//褰撳墠浠诲姟杞︽ + data.setCrrentRestCarNum(Constants.formatBigdecimal(result.getCurrentTransportVehicleNum()).intValue() );//鍓╀綑浠诲姟杞︽閲� + data.setCrrentOutCarNum(Constants.formatBigdecimal(result.getCurrentOutVehicleNum()).intValue());//浠婃棩鍑哄簱杞︽ + //褰撳墠浠诲姟閲忓拰鍓╀綑浠诲姟閲忥紝涓猴紙鏃犻渶閰嶈浇+闇�瑕侀厤杞界殑浠诲姟閲忎箣鍜岋級 + data.setCurrentPlanNum(data.getNeedTransportOrderNum().add(data.getNoNeedTransportOrderNum()));//褰撳墠浠诲姟閲� + data.setCrrentRestNum(data.getCurrentPlanNum());//褰撳墠浠诲姟閲� + + } + //澶勭悊鍗曚綅鎴愨�滅鈥濓紝涓�绠�=5涓囨敮 + if(Constants.UNIT_TYPE == 1) { + data.setMaxAbility(Constants.formatBigdecimal(data.getMaxAbility()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); + data.setHoursAbility(Constants.formatBigdecimal(data.getHoursAbility()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); + data.setCrrentRestNum(Constants.formatBigdecimal(data.getCrrentRestNum()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); + data.setCurrentPlanNum(Constants.formatBigdecimal(data.getCurrentPlanNum()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); + data.setCrrentOutNum(Constants.formatBigdecimal(data.getCrrentOutNum()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); + data.setCurrentOrderNum(Constants.formatBigdecimal(data.getCurrentOrderNum()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); + data.setNoNeedTransportOrderNum(Constants.formatBigdecimal(data.getNoNeedTransportOrderNum()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); + data.setNeedTransportOrderNum(Constants.formatBigdecimal(data.getNeedTransportOrderNum()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); + } } private void initOutboundCapability(WholeProvinceBoardVO data, String code) { TmsFacrotyCodeListRequest param = new TmsFacrotyCodeListRequest(); @@ -2443,7 +2823,6 @@ } } } - } private boolean notInList(String transportCode, List<String> planCodes) { @@ -2579,15 +2958,16 @@ t =new WholeProvinceMapVO(); t.setMonthNum( Constants.formatBigdecimal0Float(model.getMonthOutboundQuantity())); t.setYearNum( Constants.formatBigdecimal0Float(model.getYearOutboundQuantity())); - - if(Constants.UNIT_TYPE == 1) { - //澶勭悊鍗曚綅鎴愨�滅鈥濓紝涓�绠�=5涓囨敮 - t.setMonthNum(Constants.formatBigdecimal(t.getMonthNum()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); - t.setYearNum(Constants.formatBigdecimal(t.getYearNum()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); - } t.setProvinceCode(model.getToProvinceCode()); t.setProvinceName(model.getToProvinceName()); result.add(t); + } + } + if(Constants.UNIT_TYPE == 1) { + for(WholeProvinceMapVO t : result){ + //澶勭悊鍗曚綅鎴愨�滅鈥濓紝涓�绠�=5涓囨敮 + t.setMonthNum(Constants.formatBigdecimal(t.getMonthNum()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); + t.setYearNum(Constants.formatBigdecimal(t.getYearNum()).divide(new BigDecimal(5), 2, BigDecimal.ROUND_HALF_UP)); } } } @@ -2633,7 +3013,7 @@ return infoList; } /** - * 杩戜竷鏃ュ埌璐ф儏鍐� + * 杩戜竷鏃ュ埌璐ф儏鍐�-鏀规垚杩�15鏃� * @return */ @Override @@ -2645,17 +3025,17 @@ param.getFacrotyCodeList().add(code);//鏌ヨ鎸囧畾鍘傚尯 } Date date = new Date(); - Date startDate = DateUtil.addDaysToDate(date,-7); + Date startDate = DateUtil.addDaysToDate(date,-15); //鐪嬫澘澶у睆杩�7鏃ュ埌璐ф儏鍐垫棩鏈� 0琛ㄧず褰撳ぉ褰撳墠鎺�7澶╋紝-1琛ㄧず鏈湀鍒�1鍙�-7鍙� String flag = systemDictDataBiz.queryByCode(Constants.TSM_PARAM,Constants.SCREEN_SEVENT_ARRIVAL_STARTDATE).getCode(); if(StringUtils.equals(flag,"-1")){ startDate =DateUtil.getBeginDayOfMonth(0); - date = DateUtil.addDaysToDate(startDate,7); + date = DateUtil.addDaysToDate(startDate,15); } param.setNcCreateDateFrom(DateUtil.getShortTime(startDate)); param.setNcCreateDateThrough(DateUtil.getShortTime(date)); List<TmsSevenArrivalStatusAndDetailsResponse> infoList = tmsService.getSevenArrivalStatusAndDetails(param);//鏌ヨ鍑哄簱閲� - for (int i = 0; i < 7; i++) { + for (int i = 0; i < 15; i++) { LastSevenDaysOrderVo model = new LastSevenDaysOrderVo(); Date td = DateUtil.addDaysToDate(date,-i); model.setDateStr(DateUtil.getShortTime(td)); @@ -2807,7 +3187,6 @@ } } return r ; - } -- Gitblit v1.9.3