package com.kidgrow.oprationcenter.service.impl; import com.alibaba.fastjson.JSON; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; 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.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.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.*; import java.util.stream.Collectors; /** * 石家庄喜高科技有限责任公司 版权所有 © Copyright 2020
* @Description: 产品/明显的充值记录
* @Project: 用户中心
* @CreateDate: Created in 2020-04-01 09:37:05
* @Author: liuke * @version 1.0 */ @Slf4j @Service public class ProductOrderDetailServiceImpl extends SuperServiceImpl implements IProductOrderDetailService { @Autowired DiagnosticService diagnosticService; @Autowired private SysDoctorService sysDoctorService; @Autowired private SysHospitalService sysHospitalService; @Autowired private ConsumptionRecordMapper consumptionRecordMapper; @Autowired private IProductOrderService iProductOrderService; @Autowired private RedisUtils redisUtils; /** * 列表 * @param params * @return */ @Override public PageResult findList(Map params){ Page page = new Page<>(MapUtils.getInteger(params, "page"), MapUtils.getInteger(params, "limit")); List list = baseMapper.findList(page, params); return PageResult.builder().data(list).code(0).count(page.getTotal()).build(); } /** * 获取已购买产品列表 * @param params * @return */ @Override public List findAllList(Map params){ return baseMapper.findAllList(params); } /** * 判定医院科室的套餐是否到期 以及到期时间 * @param hospitalId * @param departmentId * @param diagnosticId * @return */ public ResultBody 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 productOrderJoinDetailList = userProductDetail.getProductOrderJoinDetailListShare(); if (productOrderJoinDetailList.size() > 0) { userProductData.setEnd(false); //合并后按id排序并筛除已用完的套餐 List 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 params) { Page page = new Page<>(MapUtils.getInteger(params, "page"), MapUtils.getInteger(params, "limit")); List list = baseMapper.findList(page, params); List 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.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 productOrderChart(Map params) { return baseMapper.productOrderChart(params); } /** * 统计产品的使用数量 * @return ccount 是数量 * units 是产品名称 */ @Override public List proCountChart() { return baseMapper.proCountChart(); } /** *获取该科室下的所有的套餐信息 * @param params * @return */ @Override public PageResult departmentProductDetail(Map params) { Page page = new Page<>(MapUtils.getInteger(params, "page"), MapUtils.getInteger(params, "limit")); List list = baseMapper.departmentProductDetail(page, Long.parseLong(params.get("hospitalId").toString()),Long.parseLong(params.get("departmentId").toString())); return PageResult.builder().data(list).code(0).count(page.getTotal()).build(); } /** * 获取诊断列表 * @param params * @return */ @Override public PageResult findAllDataList(Map params){ return diagnosticService.getDiagnosticItemList(params).getData(); } /** * 获取统计数据 * @param params * @return */ @Override public PageResult groupList(Map params) { Page page = new Page<>(MapUtils.getInteger(params, "page"), MapUtils.getInteger(params, "limit")); List list = baseMapper.groupProductDetail(page,params); return PageResult.builder().data(list).code(0).count(page.getTotal()).build(); } /** * 根据ProductOrderDetail对象当做查询条件进行查询 * @param productOrderDetail * @return ProductOrderDetail */ @Override public ProductOrderDetail findByObject(ProductOrderDetail productOrderDetail){ return baseMapper.findByObject(productOrderDetail); } /** * 修改数据状态 启用 禁用 * @param params * @return */ @Override public ResultBody updateEnabled(Map params) { Long id = MapUtils.getLong(params, "id"); Boolean enabled = MapUtils.getBoolean(params, "enabled"); ProductOrderDetail productOrder = baseMapper.selectById(id); if (productOrder == null) { return ResultBody.failed("该数据不存在!"); } productOrder.setEnabled(enabled); productOrder.setUpdateTime(new Date()); int i = baseMapper.updateById(productOrder); return i > 0 ? ResultBody.ok().data(productOrder).msg("更新成功") : ResultBody.failed("更新失败"); } @Override public ResultBody getTypeByUser(SysUser sysUser) { List organizations = sysUser.getOrganizations(); if(organizations.size()>0){ SysOrganization sysOrganization = organizations.get(0); List list=baseMapper.getTypeByUser(sysOrganization.getId()); if (list.size()>0) { ProductOrderJoinDetail productOrderJoinDetail = list.get(0); //查询用户的真实姓名 Map selectMap=new HashMap<>(); selectMap.put("user_id",sysUser.getId()); ResultBody listByMap = sysDoctorService.getListByMap(selectMap); List sysDoctors = JSON.parseArray(JSON.toJSONString(listByMap.getData()), SysDoctor.class); String str=""; if(sysDoctors!=null&&sysDoctors.size()>0){ str= sysDoctors.get(0).getDoctorName(); } //查询医院的 logo Map map=new HashMap<>(); map.put("id",sysOrganization.getId()); ResultBody allByMap = sysHospitalService.findAllByMap(map); List hospitals = JSON.parseArray(JSON.toJSONString(allByMap.getData()), SysHospital.class); String logo=""; if(hospitals.size()>0){ logo = hospitals.get(0).getHospitalLogo(); } Map 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 selectMap = new HashMap<>(); selectMap.put("hospitalId", hospitalId); List 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 productOrderJoinDetailListShare = userProductDetail.getProductOrderJoinDetailListShare(); //科室私有的数据 List 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 shareDetailId = (productOrderJoinDetailListShare.size()>0) ?productOrderJoinDetailListShare.stream().map(m -> m.getId()).collect(Collectors.toList()) :new ArrayList<>(); //私有套餐里面的detailid List depDetailId = (productOrderJoinDetailsListDep.size()>0) ?productOrderJoinDetailsListDep.stream().map(m -> m.getId()).collect(Collectors.toList()) :new ArrayList<>(); //获取所有有效的套餐id List nowDetailList=new ArrayList<>(); BeanUtils.copyProperties(shareDetailId,nowDetailList); nowDetailList.addAll(depDetailId); //查询已预扣 未退还 未扣费的数据 List 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("医院和科室数据有误!"); } } }