package com.kidgrow.oprationcenter.service.impl;
import com.alibaba.fastjson.JSON;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.kidgrow.common.constant.ConsumptionConstant;
import com.kidgrow.common.model.*;
import com.kidgrow.common.service.impl.SuperServiceImpl;
import com.kidgrow.common.utils.DateUtils;
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.ProductOrderDetail;
import com.kidgrow.oprationcenter.service.IProductOrderDetailService;
import com.kidgrow.oprationcenter.vo.*;
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.factory.annotation.Autowired;
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;
/**
* 列表
* @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
* @return
*/
public ResultBody UserProductDetailData(Long hospitalId,Long departmentId)
{
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());
}
}
return ResultBody.ok().data(userProductData);
}
/**
* 获取诊断列表
* @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() == false)).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.stream().collect(Collectors.summingInt(ProductOrderJoinDetail::getAilightCount));
//本科室私有读片总量
int depCount = productOrderJoinDetailsListDep.stream().collect(Collectors.summingInt(ProductOrderJoinDetail::getAilightCount));
//可用的总量
userAICount = shareCount + depCount;
//计算预扣费的总量
Map selectMap = new HashMap<>();
selectMap.put("recordType", ConsumptionConstant.BEFORE_DEDUCTION);
List consumptionRecordList = consumptionRecordMapper.findList(selectMap);;
if (consumptionRecordList.size() > 0) {
//共享套餐里面的detailid
List shareDetailId = productOrderJoinDetailListShare.stream().map(m -> m.getId()).collect(Collectors.toList());
//私有套餐里面的detailid
List depDetailId = productOrderJoinDetailsListDep.stream().map(m -> m.getId()).collect(Collectors.toList());
//共享套餐里面预扣费总数
int shareConCount = consumptionRecordList.stream().filter(f -> shareDetailId.contains(f.getProOrderDetailId())).collect(Collectors.summingInt(ConsumptionRecord::getConsumptionCount));
//共享套餐里面预扣费总数
int depConCount = consumptionRecordList.stream().filter(f -> depDetailId.contains(f.getProOrderDetailId())).collect(Collectors.summingInt(ConsumptionRecord::getConsumptionCount));
userAICount -= (shareConCount + depConCount);
}
}
return ResultBody.ok().data(userAICount);
} else {
return ResultBody.failed("医院和科室数据有误!");
}
}
}