From 9b276fecad68c5d5483bfb29a2eaf203f4bb371b Mon Sep 17 00:00:00 2001 From: rk <94314517@qq.com> Date: 星期二, 14 十月 2025 18:12:13 +0800 Subject: [PATCH] 定时自动叫号 与 WMS获取车辆是否在园接口开发 --- server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/thrid/BoardServiceImpl.java | 368 ++++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 299 insertions(+), 69 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 80e5ec4..552d487 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 @@ -93,7 +93,8 @@ private TmsService tmsService; @Autowired private PlatformDeviceMapper platformDeviceMapper; - + @Autowired + private CategoryMapper categoryMapper; @Value("${debug_model}") private Boolean isDebug; /** @@ -489,6 +490,7 @@ }*/ return list; } + @Override public WaningEventDataVO warningEventData(Integer type){ WaningEventDataVO lastResult = new WaningEventDataVO(); @@ -498,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"); @@ -523,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){ } @@ -620,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); @@ -647,6 +678,8 @@ } /** * 銆愭秷闃茬鎺с�戠湅鏉�-瀹炴椂鐩戞祴鏁版嵁 + * 娑插帇鍥哄畾鍊硷細254001 + * 姘村帇鍥哄畾鍊硷細253958 * @return * */ @@ -656,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"); @@ -664,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(); @@ -671,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(); @@ -683,7 +723,6 @@ vm.setCateName(v.getMonitorSpecificName()); vm.setCateCode(v.getMonitorTypeKey()); vm.setTypeCode(v.getMonitorTypeCode()); - vm.setTypeName(v.getMonitorTypeName()); dataList.add(vm); } }else{ @@ -706,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; + } @@ -952,13 +1031,21 @@ /** * 銆愭秷闃茬鎺с�戠湅鏉�-鍛婅淇℃伅闆嗗悎 - * + * @param type 0/null = 褰撳ぉ锛�1=褰撴湀锛�2=褰撳勾 * @return * */ @Override - public AlarmDataVO alarmDataSumByCate(){ - AlarmDataVO alarmDataVO = getAlertDataByStartEndTime(DateUtil.getPlusTime2(Utils.Date.getStart(new Date())) + 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; } @@ -976,19 +1063,22 @@ 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::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) @@ -1000,6 +1090,8 @@ .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) @@ -1012,7 +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)+"'")); - + + log.error("4銆�=====================>"+DateUtil.getCurrDateTime()); List<PlatformJob> yearLastNum = platformJobMapper.selectJoinList(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() .selectAs(PlatformJob::getId,PlatformJob::getId) @@ -1028,9 +1121,10 @@ 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>() @@ -1046,6 +1140,7 @@ .apply(" to_days(create_date) < to_days(now()) ") ); + log.error("6銆�=====================>"+DateUtil.getCurrDateTime()); //==========浠婂ぉ鍑哄叆搴撳畬鎴愰噺 List<PlatformJob> currentDoneNum = platformJobMapper.selectJoinList(PlatformJob.class, new MPJLambdaWrapper<PlatformJob>() @@ -1058,6 +1153,7 @@ .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>() @@ -1070,18 +1166,39 @@ .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));//浠婂ぉ涓嬪彂鍏ュ簱浠诲姟 + 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()));//褰撴棩鍏ュ簱鏁堢巼 - data.setMonthOutRate(getMonthRata(monthNum,Constants.ZERO));//鏈湀鍑哄簱鏁堢巼 - data.setMonthInRate(getMonthRata(monthNum,Constants.ONE));//鏈湀鍑哄簱鏁堢巼 + 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)+"') ") + ); + + + 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);// @@ -1153,7 +1270,7 @@ } - private BigDecimal getMonthRata(List<PlatformJob> list, Integer type) { + private BigDecimal getMonthRata(List<PlatformLog> monthLogList,List<PlatformJob> list, Integer type) { BigDecimal r = new BigDecimal(0); if(list==null || list.size() == 0){ return r; @@ -1177,16 +1294,37 @@ } if(CollectionUtils.isNotEmpty(jobList)){ //鑾峰彇浠诲姟鏁版嵁 - List<String> jobDataList = list.stream().filter(i->Objects.nonNull(i.getDoneDate())).map(i->DateUtil.formatDate(i.getDoneDate(),"yyyy-MM-dd")).collect(Collectors.toList()); - 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.getDayTotalRata(getSumTotalByList(platformJobList,type,null),jobDate)); + 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; } @@ -1197,13 +1335,13 @@ //鏌ヨ浠婃棩鏈�鏃�/鏈�鏅氱殑浣滀笟鏁版嵁 List<PlatformLog> platformLogList = platformLogMapper.selectList(new QueryWrapper<PlatformLog>() .lambda() - .apply(" ( to_days(param1) = '"+today+"' or to_days(param2) = '"+today+"' ) ") + .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); + return this.getWorkTime(totalAmount,platformLogList,today); } return r; } @@ -1214,30 +1352,32 @@ * @param platformLogList * @return */ - public BigDecimal getWorkTime(BigDecimal totalAmount,List<PlatformLog> platformLogList){ + 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())).map(i->DateUtil.fromStringToDate("yyyy-MM-dd HH:mm:ss",i.getParam1()).getTime()).collect(Collectors.toList()); - Long startTime = Collections.min(startTimeList); + 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())).map(i->DateUtil.fromStringToDate("yyyy-MM-dd HH:mm:ss",i.getParam2()).getTime()).collect(Collectors.toList()); - Long endTime = Collections.max(endTimeList); + 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) { @@ -1445,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; } @@ -1943,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( @@ -1956,6 +2097,12 @@ //鍦ㄥ洯杞﹁締 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( @@ -1988,8 +2135,44 @@ &&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"; @@ -2450,6 +2633,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)); @@ -2478,24 +2691,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(); @@ -2591,7 +2822,6 @@ } } } - } private boolean notInList(String transportCode, List<String> planCodes) { @@ -2727,15 +2957,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)); } } } @@ -2955,7 +3186,6 @@ } } return r ; - } -- Gitblit v1.9.3