From a18dde79b1d35bbba46d5f68512dbb617bbc4ecd Mon Sep 17 00:00:00 2001
From: zxh <279049017@qq.com>
Date: Fri, 28 Aug 2020 16:21:35 +0800
Subject: [PATCH] Merge branch 'dev' of ssh://192.168.2.240:29418/kidgrow-microservices-platform into dev

---
 kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-biz/src/main/java/com/kidgrow/oprationcenter/service/impl/ProductOrderDetailServiceImpl.java |  309 ++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 292 insertions(+), 17 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 f04b5c7..96cba5a 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
@@ -1,25 +1,34 @@
 package com.kidgrow.oprationcenter.service.impl;
 
+import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
-import com.kidgrow.common.model.PageResult;
-import com.kidgrow.common.model.ResultBody;
-import com.kidgrow.common.model.SysUser;
+import com.kidgrow.common.constant.CommonConstant;
+import com.kidgrow.common.model.*;
 import com.kidgrow.common.service.impl.SuperServiceImpl;
+import com.kidgrow.common.utils.DateUtils;
+import com.kidgrow.common.utils.StringUtils;
 import com.kidgrow.oprationcenter.feign.DiagnosticService;
-import com.kidgrow.oprationcenter.feign.RoleOrganizationService;
+import com.kidgrow.oprationcenter.mapper.ConsumptionRecordMapper;
 import com.kidgrow.oprationcenter.mapper.ProductOrderDetailMapper;
+import com.kidgrow.oprationcenter.model.ConsumptionRecord;
+import com.kidgrow.oprationcenter.model.ProductOrder;
 import com.kidgrow.oprationcenter.model.ProductOrderDetail;
 import com.kidgrow.oprationcenter.service.IProductOrderDetailService;
-import com.kidgrow.oprationcenter.vo.GroupProductDetail;
-import com.kidgrow.oprationcenter.vo.ProductOrderJoinDetail;
+import com.kidgrow.oprationcenter.service.IProductOrderService;
+import com.kidgrow.oprationcenter.vo.*;
+import com.kidgrow.redis.util.RedisUtils;
+import com.kidgrow.usercenter.feign.SysDoctorService;
+import com.kidgrow.usercenter.feign.SysHospitalService;
+import com.kidgrow.usercenter.model.SysHospital;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.collections4.MapUtils;
+import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.cglib.beans.BeanCopier;
 import org.springframework.stereotype.Service;
 
-import java.util.Date;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
+import java.util.stream.Collectors;
 
 /**
  * 石家庄喜高科技有限责任公司 版权所有 © Copyright 2020<br>
@@ -35,7 +44,15 @@
    @Autowired
     DiagnosticService diagnosticService;
     @Autowired
-    private RoleOrganizationService roleOrganizationService;
+    private SysDoctorService sysDoctorService;
+    @Autowired
+    private SysHospitalService sysHospitalService;
+    @Autowired
+    private ConsumptionRecordMapper consumptionRecordMapper;
+    @Autowired
+    private IProductOrderService iProductOrderService;
+    @Autowired
+    private RedisUtils redisUtils;
     /**
      * 列表
      * @param params
@@ -48,17 +65,143 @@
         return PageResult.<ProductOrderDetail>builder().data(list).code(0).count(page.getTotal()).build();
     }
     /**
-     * 列表
+     * 获取已购买产品列表
      * @param params
      * @return
      */
     @Override
-    public PageResult<ProductOrderJoinDetail> findAllList(Map<String, Object> params, SysUser sysUser) {
-        Page<ProductOrderJoinDetail> page = new Page<>(MapUtils.getInteger(params, "page"), MapUtils.getInteger(params, "limit"));
-        Map<String, Object> roleOrgMap = roleOrganizationService.getRoleOrgMap(sysUser.getRoles());
-        params.putAll(roleOrgMap);
-        List<ProductOrderJoinDetail> list  =  baseMapper.findAllList(page,params);
-        return PageResult.<ProductOrderJoinDetail>builder().data(list).code(0).count(page.getTotal()).build();
+    public List<ProductOrderJoinDetail> findAllList(Map<String, Object> params){
+        return baseMapper.findAllList(params);
+    }
+
+    /**
+     * 判定医院科室的套餐是否到期 以及到期时间
+     * @param hospitalId
+     * @param departmentId
+     * @param diagnosticId
+     * @return
+     */
+    public ResultBody<UserProductData> UserProductDetailData(Long hospitalId,Long departmentId,String diagnosticId)
+    {
+        UserProductData userProductData=new UserProductData();
+        userProductData.setEnd(true);
+        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);
+                //合并后按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());
+            }
+        }
+        //是否已经结束
+        if (userProductData.isEnd()&& StringUtils.isNotBlank(diagnosticId)) {
+            //写入redis中,防止扣非后不能生成报告
+            redisUtils.lSet(CommonConstant.SAAS_LAST_SERVER+diagnosticId,diagnosticId);
+        }
+        return ResultBody.ok().data(userProductData);
+    }
+
+    /**
+     * 获取需要审核的套餐
+     * @param params
+     * @return
+     */
+    @Override
+    public PageResult all(Map<String, Object> params) {
+        Page<ProductOrderDetail> page = new Page<>(MapUtils.getInteger(params, "page"), MapUtils.getInteger(params, "limit"));
+        List<ProductOrderDetail> list  =  baseMapper.findList(page, params);
+        List<ProductOrderDetailVo> volist=new ArrayList<>();
+        for (ProductOrderDetail productOrderDetail : list) {
+            ProductOrderDetailVo productOrderDetailVo=new ProductOrderDetailVo();
+            BeanCopier beanCopier = BeanCopier.create(ProductOrderDetail.class, ProductOrderDetailVo.class, false);
+            beanCopier.copy(productOrderDetail,productOrderDetailVo,null);
+            //查询医院
+            if(productOrderDetail.getOrderId()!=null){
+                ProductOrder productOrder = iProductOrderService.getById(productOrderDetail.getOrderId());
+                if(productOrder!=null){
+                    productOrderDetailVo.setDepartmentId(productOrder.getDepartmentId());
+                    productOrderDetailVo.setDepartmentName(productOrder.getDepartmentName());
+                    productOrderDetailVo.setHospitalId(productOrder.getHospitalId());
+                    productOrderDetailVo.setHospitalName(productOrder.getHospitalName());
+                }
+               volist.add(productOrderDetailVo);
+            }
+        }
+        return PageResult.<ProductOrderDetailVo>builder().data(volist).code(0).count(page.getTotal()).build();
+    }
+
+    /**
+     * 获取科室试用次数
+     * @param departmentId  科室ID
+     * @return
+     */
+    @Override
+    public int getEnabledCount(Long departmentId) {
+        int counts=baseMapper.getEnabledCount(departmentId);
+        return counts;
+    }
+    /**
+     * 统计获取数据量
+     * @param datatype
+     * 0 试用审核量
+     * 1 套餐总量
+     * 2 未处理用户反馈
+     * 3 未处理数据需求
+     * @return
+     */
+    @Override
+    public int oprationChart(int datatype) {
+        return baseMapper.oprationChart(datatype);
+    }
+    /**
+     * 按指定类型统计合同数量
+     * @param params
+     *    datatype     1 按年
+     *                 2 按月
+     *                 3 按天
+     *                 4 按周
+     *    beginTime 查询时间段的开始时间
+     *    endTime   结束时间
+     * @return
+             */
+    @Override
+    public List<OrderChartVo> productOrderChart(Map<String, Object> params) {
+        return baseMapper.productOrderChart(params);
+    }
+    /**
+     * 统计产品的使用数量
+     * @return  ccount 是数量
+     *          units 是产品名称
+     */
+    @Override
+    public List<OrderChartVo> proCountChart() {
+        return baseMapper.proCountChart();
+    }
+    /**
+     *获取该科室下的所有的套餐信息
+     * @param params
+     * @return
+     */
+    @Override
+    public PageResult<ProductOrderDetail> departmentProductDetail(Map<String, Object> params) {
+        Page<ProductOrderDetail> page = new Page<>(MapUtils.getInteger(params, "page"), MapUtils.getInteger(params, "limit"));
+        List<ProductOrderDetail> list  =
+                baseMapper.departmentProductDetail(page, Long.parseLong(params.get("hospitalId").toString()),Long.parseLong(params.get("departmentId").toString()));
+        return PageResult.<ProductOrderDetail>builder().data(list).code(0).count(page.getTotal()).build();
+    }
+
+    /**
+     * 获取诊断列表
+     * @param params
+     * @return
+     */
+    @Override
+    public PageResult<DiagnosisRecord> findAllDataList(Map<String, Object> params){
+        return  diagnosticService.getDiagnosticItemList(params).getData();
     }
 
     /**
@@ -66,6 +209,7 @@
      * @param params
      * @return
      */
+
     @Override
     public PageResult<GroupProductDetail> groupList(Map<String, Object> params) {
         Page<GroupProductDetail> page = new Page<>(MapUtils.getInteger(params, "page"), MapUtils.getInteger(params, "limit"));
@@ -101,4 +245,135 @@
         int i = baseMapper.updateById(productOrder);
         return i > 0 ? ResultBody.ok().data(productOrder).msg("更新成功") : ResultBody.failed("更新失败");
     }
+
+    @Override
+    public ResultBody getTypeByUser(SysUser sysUser) {
+        List<SysOrganization> organizations = sysUser.getOrganizations();
+        if(organizations.size()>0){
+            SysOrganization sysOrganization = organizations.get(0);
+            List<ProductOrderJoinDetail> list=baseMapper.getTypeByUser(sysOrganization.getId());
+            if (list.size()>0) {
+                ProductOrderJoinDetail productOrderJoinDetail = list.get(0);
+                //查询用户的真实姓名
+                Map<String,Object> selectMap=new HashMap<>();
+                selectMap.put("user_id",sysUser.getId());
+                ResultBody listByMap = sysDoctorService.getListByMap(selectMap);
+                List<SysDoctor> sysDoctors = JSON.parseArray(JSON.toJSONString(listByMap.getData()), SysDoctor.class);
+                String str="";
+                if(sysDoctors!=null&&sysDoctors.size()>0){
+                    str= sysDoctors.get(0).getDoctorName();
+                }
+                //查询医院的 logo
+                Map<String,Object> map=new HashMap<>();
+                map.put("id",sysOrganization.getId());
+                ResultBody allByMap = sysHospitalService.findAllByMap(map);
+                List<SysHospital> hospitals = JSON.parseArray(JSON.toJSONString(allByMap.getData()), SysHospital.class);
+                String logo="";
+                if(hospitals.size()>0){
+                    logo = hospitals.get(0).getHospitalLogo();
+                }
+                Map<String,Object> mapVo=new HashMap<>();
+                mapVo.put("type",productOrderJoinDetail.getProType());
+                mapVo.put("realName",str);
+                //剩余时间
+                Date proEndtime = productOrderJoinDetail.getProEndtime();
+                Double surplusDay=DateUtils.getDays(proEndtime, new Date());
+                int surplus = surplusDay.intValue();
+                mapVo.put("surplus",surplus);
+                mapVo.put("logo",logo);
+                //获取 售后服务工程师********不能从sysOrganization获取,从department获取
+               /* mapVo.put("saleUserName",sysOrganization.getSaleUserName());
+                mapVo.put("saleUserTel",sysOrganization.getSaleUserTel());*/
+                return ResultBody.ok().data(mapVo);
+            }else {
+                return ResultBody.failed("该用户套餐已经失效");
+            }
+        }else {
+            return ResultBody.failed("该用户的组织已经失效");
+        }
+    }
+    /**
+     *获取医院的套餐数据
+     * @param hospitalId
+     * @param departmentId
+     * @return
+     */
+    @Override
+    public UserProductDetail getUserProductDetail(Long hospitalId, Long departmentId)
+    {
+        //查询当前医院正在使用的套餐
+        Map<String, Object> selectMap = new HashMap<>();
+        selectMap.put("hospitalId", hospitalId);
+        List<ProductOrderJoinDetail> productOrderDetailList = this.findAllList(selectMap);
+        if (productOrderDetailList.size() > 0) {
+            UserProductDetail userProductDetail=new UserProductDetail();
+            //包含共享的数据
+            userProductDetail.setProductOrderJoinDetailListShare(productOrderDetailList.stream().filter(f -> f.getIsShare()).collect(Collectors.toList()));
+            //科室私有的数据
+            userProductDetail.setProductOrderJoinDetailsListDep(productOrderDetailList.stream().filter((f -> departmentId.equals(f.getDepartmentId()) && !f.getIsShare())).collect(Collectors.toList()));
+            return userProductDetail;
+        }
+        return null;
+    }
+    /**
+     * 统计用户所有套餐剩余  套餐剩余量=(有效期内的医院所有共享+科室私有的套餐的读片量)-预扣费的读片量
+     *
+     * @param hospitalId
+     * @param departmentId
+     * @return
+     */
+    @Override
+    public ResultBody biUserNowProduct(Long hospitalId, Long departmentId) {
+        if (hospitalId > 0 && departmentId > 0) {
+            UserProductDetail userProductDetail=getUserProductDetail(hospitalId,departmentId);
+            int userAICount = 0;
+            if (userProductDetail!=null) {
+                //包含共享的数据
+                List<ProductOrderJoinDetail> productOrderJoinDetailListShare = userProductDetail.getProductOrderJoinDetailListShare();
+                //科室私有的数据
+                List<ProductOrderJoinDetail> productOrderJoinDetailsListDep = userProductDetail.getProductOrderJoinDetailsListDep();
+                //本医院可共享的读片总量
+                int shareCount = (productOrderJoinDetailListShare.size()>0)?
+                        productOrderJoinDetailListShare.stream().collect(Collectors.summingInt(ProductOrderJoinDetail::getAilightCount))
+                        :0;
+                //本科室私有读片总量
+                int depCount = (productOrderJoinDetailsListDep.size()>0)?
+                        productOrderJoinDetailsListDep.stream().collect(Collectors.summingInt(ProductOrderJoinDetail::getAilightCount))
+                        :0;
+                //可用的总量
+                userAICount = shareCount + depCount;
+
+                //共享套餐里面的detailid
+                List<Long> shareDetailId = (productOrderJoinDetailListShare.size()>0)
+                        ?productOrderJoinDetailListShare.stream().map(m -> m.getId()).collect(Collectors.toList())
+                        :new ArrayList<>();
+                //私有套餐里面的detailid
+                List<Long> depDetailId = (productOrderJoinDetailsListDep.size()>0)
+                        ?productOrderJoinDetailsListDep.stream().map(m -> m.getId()).collect(Collectors.toList())
+                        :new ArrayList<>();
+                //获取所有有效的套餐id
+                List<Long> nowDetailList=new ArrayList<>();
+                BeanUtils.copyProperties(shareDetailId,nowDetailList);
+                nowDetailList.addAll(depDetailId);
+                //查询已预扣 未退还  未扣费的数据
+                List<ConsumptionRecord> consumptionRecordList = consumptionRecordMapper.findDetailList(nowDetailList);
+                //计算预扣费的总量
+                if (consumptionRecordList.size() > 0) {
+                    //共享套餐里面预扣费总数
+                    int shareConCount = (shareDetailId.size()>0)?consumptionRecordList.stream()
+                            .filter(f -> shareDetailId.contains(f.getProOrderDetailId()))
+                            .collect(Collectors.summingInt(ConsumptionRecord::getConsumptionCount)):0;
+                    //私有套餐里面预扣费总数
+                    int depConCount = (depDetailId.size()>0)?consumptionRecordList.stream()
+                            .filter(f -> depDetailId.contains(f.getProOrderDetailId()))
+                            .collect(Collectors.summingInt(ConsumptionRecord::getConsumptionCount)):0;
+                    userAICount -= (shareConCount + depConCount);
+                }
+            }
+
+            return ResultBody.ok().data(userAICount);
+        } else {
+            return ResultBody.failed("医院和科室数据有误!");
+        }
+    }
 }

--
Gitblit v1.8.0