From cc51b41fa3dd6c51eef9028fbbb72ec3e7139d74 Mon Sep 17 00:00:00 2001 From: zhaoxiaohao <279049017@qq.com> Date: Thu, 24 Sep 2020 14:10:14 +0800 Subject: [PATCH] 添加字段 --- kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-biz/src/main/java/com/kidgrow/oprationcenter/service/impl/ProductOrderDetailServiceImpl.java | 34 +++++++++++++++++++++++++++------- 1 files changed, 27 insertions(+), 7 deletions(-) diff --git a/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-biz/src/main/java/com/kidgrow/oprationcenter/service/impl/ProductOrderDetailServiceImpl.java b/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-biz/src/main/java/com/kidgrow/oprationcenter/service/impl/ProductOrderDetailServiceImpl.java index 96cba5a..df69cd0 100644 --- a/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-biz/src/main/java/com/kidgrow/oprationcenter/service/impl/ProductOrderDetailServiceImpl.java +++ b/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-biz/src/main/java/com/kidgrow/oprationcenter/service/impl/ProductOrderDetailServiceImpl.java @@ -75,30 +75,50 @@ } /** - * 判定医院科室的套餐是否到期 以及到期时间 + * 判定医院科室的套餐是否到期 以及剩余的读片量 * @param hospitalId * @param departmentId * @param diagnosticId * @return */ - public ResultBody<UserProductData> UserProductDetailData(Long hospitalId,Long departmentId,String diagnosticId) + @Override + public ResultBody<UserProductData> userProductDetailData(Long hospitalId,Long departmentId,String diagnosticId) { UserProductData userProductData=new UserProductData(); - userProductData.setEnd(true); + userProductData.setIsEnd(true); + userProductData.setRecordCount(0); + userProductData.setAilightCount(0); + userProductData.setLimitDays(0); UserProductDetail userProductDetail = this.getUserProductDetail(hospitalId, departmentId); if (userProductDetail != null) { //合并集合 userProductDetail.getProductOrderJoinDetailListShare().addAll(userProductDetail.getProductOrderJoinDetailsListDep()); List<ProductOrderJoinDetail> productOrderJoinDetailList = userProductDetail.getProductOrderJoinDetailListShare(); if (productOrderJoinDetailList.size() > 0) { - userProductData.setEnd(false); + userProductData.setIsEnd(false); //合并后按id排序并筛除已用完的套餐 - List<ProductOrderJoinDetail> productOrderJoinDetailsNewList = productOrderJoinDetailList.stream().filter(f -> f.getAilightCount() >= 0).sorted(Comparator.comparing(ProductOrderJoinDetail::getProEndtime).reversed()).collect(Collectors.toList()); - userProductData.setMaxEndTime(productOrderJoinDetailsNewList.get(0).getProEndtime()); + List<ProductOrderJoinDetail> productOrderJoinDetailsNewList = productOrderJoinDetailList.stream().filter(f -> f.getAilightCount() >= 0).sorted(Comparator.comparing(ProductOrderJoinDetail::getProEndtime)).collect(Collectors.toList()); + for (int i = 0; i <productOrderJoinDetailsNewList.size(); i++) { + userProductData.setAilightCount(productOrderJoinDetailsNewList.get(i).getAilightCount()); + userProductData.setRecordCount(productOrderJoinDetailsNewList.get(i).getRecordCount()); + Double days=DateUtils.getDays(new Date(),productOrderJoinDetailsNewList.get(i).getProEndtime()); + if (i<productOrderJoinDetailsNewList.size()-1) { + //按照结束日期正序排序后,如果第二条的开始时间减去第一条的结束时间 差值大于0 说明套餐间有中断 则以当前这条套餐作为当前套餐的剩余天数 + Double daysTemp=DateUtils.getDays(productOrderJoinDetailsNewList.get(i).getProEndtime(), + productOrderJoinDetailsNewList.get(i+1).getProBegintime()); + if (daysTemp>0) { + userProductData.setLimitDays(Integer.valueOf(Double.valueOf(days).intValue())); + } + } + else + { + userProductData.setLimitDays(Integer.valueOf(Double.valueOf(days).intValue())); + } + } } } //是否已经结束 - if (userProductData.isEnd()&& StringUtils.isNotBlank(diagnosticId)) { + if (userProductData.getIsEnd()&& StringUtils.isNotBlank(diagnosticId)) { //写入redis中,防止扣非后不能生成报告 redisUtils.lSet(CommonConstant.SAAS_LAST_SERVER+diagnosticId,diagnosticId); } -- Gitblit v1.8.0