From a506c2cebc89e0367714db2e4d43e694a8d24015 Mon Sep 17 00:00:00 2001
From: zhaoxiaohao <279049017@qq.com>
Date: Wed, 02 Dec 2020 14:59:44 +0800
Subject: [PATCH] 添加 条件
---
kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-server/src/main/java/com/kidgrow/oprationcenter/controller/ProductOrderDetailController.java | 299 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-----
1 files changed, 272 insertions(+), 27 deletions(-)
diff --git a/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-server/src/main/java/com/kidgrow/oprationcenter/controller/ProductOrderDetailController.java b/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-server/src/main/java/com/kidgrow/oprationcenter/controller/ProductOrderDetailController.java
index 4020c8d..e6311d1 100644
--- a/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-server/src/main/java/com/kidgrow/oprationcenter/controller/ProductOrderDetailController.java
+++ b/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-server/src/main/java/com/kidgrow/oprationcenter/controller/ProductOrderDetailController.java
@@ -1,15 +1,22 @@
package com.kidgrow.oprationcenter.controller;
import com.kidgrow.common.annotation.LoginUser;
+import com.kidgrow.common.constant.CommonConstant;
import com.kidgrow.common.controller.BaseController;
-import com.kidgrow.common.model.PageResult;
-import com.kidgrow.common.model.ResultBody;
-import com.kidgrow.common.model.SysOrganization;
-import com.kidgrow.common.model.SysUser;
+import com.kidgrow.common.model.*;
+import com.kidgrow.common.utils.DateUtils;
+import com.kidgrow.oprationcenter.model.HospitalInfo;
+import com.kidgrow.oprationcenter.model.ProductOrder;
import com.kidgrow.oprationcenter.model.ProductOrderDetail;
+import com.kidgrow.oprationcenter.model.ProductOrderRecord;
import com.kidgrow.oprationcenter.service.IBusinessRecordsService;
import com.kidgrow.oprationcenter.service.IProductOrderDetailService;
+import com.kidgrow.oprationcenter.service.IProductOrderRecordService;
import com.kidgrow.oprationcenter.service.IProductOrderService;
+import com.kidgrow.oprationcenter.vo.OrderChartVo;
+import com.kidgrow.oprationcenter.vo.ProductOrderJoinDetail;
+import com.kidgrow.oprationcenter.vo.UserProductData;
+import com.kidgrow.usercenter.feign.SysUserService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
@@ -24,9 +31,7 @@
import javax.servlet.http.HttpServletRequest;
import javax.validation.Valid;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
/**
@@ -46,10 +51,13 @@
@Autowired
private IProductOrderDetailService productOrderDetailService;
@Autowired
+ private IProductOrderRecordService productOrderRecordService;
+ @Autowired
private IBusinessRecordsService businessRecordsService;
@Autowired
private IProductOrderService productOrderService;
-
+ @Autowired
+ private SysUserService sysUserServiceFeign;
/**
* 列表
*/
@@ -75,13 +83,48 @@
@ApiImplicitParam(name = "page", value = "分页起始位置", required = true, dataType = "Integer"),
@ApiImplicitParam(name = "limit", value = "分页结束位置", required = true, dataType = "Integer")
})
- @GetMapping("/all")
- public PageResult findAllList(@RequestParam Map<String, Object> params,@LoginUser SysUser sysUser) {
+ @GetMapping("all")
+ public PageResult all(@RequestParam Map<String, Object> params) {
if (params.size() == 0) {
params.put("page", 1);
params.put("limit", 10);
}
- return productOrderDetailService.findAllList(params,sysUser);
+ return productOrderDetailService.all(params);
+ }
+ /**
+ * 列表
+ */
+ @ApiOperation(value = "查询列表")
+ @ApiImplicitParams({
+ @ApiImplicitParam(name = "page", value = "分页起始位置", required = true, dataType = "Integer"),
+ @ApiImplicitParam(name = "limit", value = "分页结束位置", required = true, dataType = "Integer")
+ })
+ @GetMapping("alldetail")
+ public PageResult alldetail(@RequestParam Map<String, Object> params) {
+ if (params.size() == 0) {
+ params.put("page", 1);
+ params.put("limit", 10);
+ }
+ return productOrderDetailService.departmentProductDetail(params);
+ }
+
+ /**
+ * 列表
+ */
+ @ApiOperation(value = "查询列表")
+ @ApiImplicitParams({
+ @ApiImplicitParam(name = "page", value = "分页起始位置", required = true, dataType = "Integer"),
+ @ApiImplicitParam(name = "limit", value = "分页结束位置", required = true, dataType = "Integer")
+ })
+ @PostMapping("/alldata")
+ public PageResult findAllDataList(@RequestParam Map<String, Object> params) {
+ if (params.size() == 0) {
+ params.put("page", 1);
+ params.put("limit", 10);
+ }
+ if (params.get("diagnosticHospitalId") == null)
+ return PageResult.<ProductOrderJoinDetail>builder().data(null).code(0).count(0L).build();
+ return productOrderDetailService.findAllDataList(params);
}
/**
@@ -99,6 +142,52 @@
params.put("limit", 10);
}
return productOrderDetailService.groupList(params);
+ }
+ /**
+ * 查询到期列表
+ */
+ @ApiOperation(value = "查询到期列表")
+ @ApiImplicitParams({
+ @ApiImplicitParam(name = "page", value = "分页起始位置", required = true, dataType = "Integer"),
+ @ApiImplicitParam(name = "limit", value = "分页结束位置", required = true, dataType = "Integer")
+ })
+ @GetMapping("/productEnd")
+ public PageResult productEndList(@RequestParam Map<String, Object> params) {
+ if (params.size() == 0) {
+ params.put("page", 1);
+ params.put("limit", 10);
+ }
+ return productOrderDetailService.productEndList(params);
+ }
+ /**
+ * 获取医院套餐是否到期和到期时间
+ * data内 isend为true说明套餐到期
+ * endtime上套餐的到期时间
+ *
+ * @param hospitalId
+ * @param departmentId
+ * @param diagnosticId
+ * @return
+ */
+
+ @ApiOperation(value = "获取医院套餐是否到期和到期时间")
+ @GetMapping("/UserProductDetailData")
+ public ResultBody<UserProductData> serProductDetailData(@RequestParam Long hospitalId, @RequestParam Long departmentId,@RequestParam String diagnosticId) {
+ return productOrderDetailService.userProductDetailData(hospitalId, departmentId,diagnosticId);
+ }
+
+ /**
+ * 获取医院套餐是否到期和到期时间
+ * data内 isend为true说明套餐到期
+ * endtime上套餐的到期时间
+ *
+ * @return
+ */
+
+ @ApiOperation(value = "获取医院套餐是否到期和到期时间")
+ @PostMapping("/serviceperiod")
+ public ResultBody<UserProductData> servicePeriod(@RequestBody HospitalInfo hospitalInfo) {
+ return productOrderDetailService.userProductDetailData(hospitalInfo.getHospitalId(), hospitalInfo.getDepartmentId(),hospitalInfo.getDiagnosticId());
}
/**
@@ -126,7 +215,7 @@
*/
@ApiOperation(value = "保存")
@PostMapping
- public ResultBody save(@Valid @RequestBody ProductOrderDetail productOrderDetail, BindingResult bindingResult,@LoginUser SysUser sysUser) {
+ public ResultBody save(@Valid @RequestBody ProductOrderDetail productOrderDetail, BindingResult bindingResult, @LoginUser SysUser sysUser) {
List<String> errMsg = new ArrayList<>();
if (bindingResult.hasErrors()) {
for (ObjectError error : bindingResult.getAllErrors()) {
@@ -135,8 +224,8 @@
return ResultBody.failed().msg(errMsg.toString());
} else {
List<SysOrganization> organizations = sysUser.getOrganizations();
- if(organizations.size()>0){
- productOrderDetail.setCreateUserOrgCode(organizations.get(organizations.size()-1).getOrgCode());
+ if (organizations.size() > 0) {
+ productOrderDetail.setCreateUserOrgCode(organizations.get(organizations.size() - 1).getOrgCode());
}
boolean v = productOrderDetailService.saveOrUpdate(productOrderDetail);
if (v) {
@@ -148,12 +237,12 @@
}
/**
- * 新增or更新
+ * 新增or更新 套餐充值
*/
@ApiOperation(value = "保存")
@PostMapping("/saveall")
@Transactional(rollbackFor = Exception.class)
- public ResultBody batchInsert(@Valid @RequestBody List<ProductOrderDetail> list, BindingResult bindingResult) {
+ public ResultBody batchInsert(@Valid @RequestBody List<ProductOrderDetail> list,BindingResult bindingResult) {
List<String> errMsg = new ArrayList<>();
if (bindingResult.hasErrors()) {
for (ObjectError error : bindingResult.getAllErrors()) {
@@ -161,16 +250,91 @@
}
return ResultBody.failed().msg(errMsg.toString());
} else {
- Boolean v = productOrderDetailService.saveBatch(list);
- if (v) {
- return ResultBody.ok().data(list.size()).msg("产品充值成功");
+ //先检查科室试用数量是否已经超
+ ProductOrder productOrder = productOrderService.getById(list.get(0).getOrderId());
+ if (productOrder != null) {
+ //是否管理人员
+ boolean ismanager=false,
+ //是否有待审核套餐
+ isenabled=false;
+ //如果是超管,高管,销售部门管理 则不受次数限制
+ ResultBody<LoginAppUser> loginAppUserTemp=sysUserServiceFeign.getLoginAppUser();
+ LoginAppUser loginAppUser=loginAppUserTemp.getData();
+ if (loginAppUser != null) {
+
+ List<SysRole> sysRoleList = loginAppUser.getRoles();
+ if (sysRoleList != null && sysRoleList.size() > 0) {
+ for (int i = 0; i < sysRoleList.size(); i++) {
+ String roleName = sysRoleList.get(i).getCode();
+ if (roleName.equals(CommonConstant.SYSTEM_ADMIN_ROLE_CODE) ||
+ roleName.equals(CommonConstant.SALE_MANAGER_ROLE_CODE) ||
+ roleName.equals(CommonConstant.PC_ADMIN_ROLE_CODE) ||
+ roleName.equals(CommonConstant.OPRATIONMANAGER_ROLE_CODE)) {
+ ismanager=true;
+ break;
+ }
+ }
+ }
+ }
+ if (!ismanager) {
+ int counts = productOrderDetailService.getEnabledCount(productOrder.getDepartmentId());
+ if (counts >= CommonConstant.MAX_FREE_COUNT) {
+ //超过了限定次数 将试用套餐改为禁用 待审核
+ for (int i = 0; i <list.size() ; i++) {
+ if (list.get(i).getProType()==0) {
+ //试用套餐
+ list.get(i).setEnabled(false);
+ isenabled=true;
+ }
+ }
+ }
+ }
+ //写充值套餐给用户
+ Boolean v = productOrderDetailService.saveBatch(list);
+ //写充值记录
+ //对象转换
+ List<ProductOrderRecord> productOrderRecordList = new ArrayList<ProductOrderRecord>();
+ ;
+ list.forEach(item -> {
+ ProductOrderRecord productOrderRecord = new ProductOrderRecord();
+ productOrderRecord.setAilightCount(item.getAilightCount());
+ productOrderRecord.setOrderId(item.getOrderId());
+ productOrderRecord.setProId(item.getProId());
+ productOrderRecord.setProName(item.getProName());
+ productOrderRecord.setProType(item.getProType());
+ productOrderRecord.setIsShare(item.getIsShare());
+ productOrderRecord.setIsDel(item.getIsDel());
+ productOrderRecord.setRecordCount(item.getRecordCount());
+ productOrderRecord.setProBegintime(item.getProBegintime());
+ productOrderRecord.setProEndtime(item.getProEndtime());
+ productOrderRecord.setEnabled(item.getEnabled());
+ productOrderRecordList.add(productOrderRecord);
+ });
+ Boolean r = productOrderRecordService.saveBatch(productOrderRecordList);
+ //更新合同
+ Boolean p = false;
+ if (productOrder != null) {
+ productOrder.setIsDel(false);
+ p = productOrderService.saveOrUpdate(productOrder);
+ }
+ if (v && r && p) {
+ if (isenabled) {
+ return ResultBody.ok().data(list.size()).msg("充值成功,但是试用套餐需要管理审核才可使用!");
+ }
+ else
+ {
+ return ResultBody.ok().data(list.size()).msg("产品充值成功...");
+ }
+ } else {
+ //写入订单明细失败,则删除订单记录数据
+ Boolean e = productOrderService.removeById(list.get(0).getOrderId());
+ if (e)
+ return ResultBody.failed().msg("充值数据保存失败,订单已撤回!");
+ else
+ return ResultBody.failed().msg("充值数据保存失败,订单撤回失败!");
+ }
} else {
- //写入订单明细失败,则删除订单记录数据
- Boolean e = productOrderService.removeById(list.get(0).getOrderId());
- if (e)
- return ResultBody.failed().msg("充值数据保存失败,订单已撤回!");
- else
- return ResultBody.failed().msg("充值数据保存失败,订单撤回失败!");
+ return ResultBody.failed().msg("充值数据关联订单不存在!");
}
}
}
@@ -184,7 +348,7 @@
boolean v = productOrderDetailService.removeById(id);
if (v) {
if (!businessRecordsService.recordBusinessData("删除订单明细:" + id, id.toString())) {
- //log.error(String.format("删除订单明细id为:{1}",id));
+ log.error(String.format("删除订单明细id为:{1}", id));
}
return ResultBody.ok().msg("删除成功");
} else {
@@ -213,9 +377,90 @@
if (resultBody.getCode() == 0) {
String enablad = (MapUtils.getBoolean(params, "enabled")) ? "启用" : "禁用";
if (!businessRecordsService.recordBusinessData("修改订单明细状态为:" + enablad, enablad)) {
- //log.error(String.format("修改合同状态为:{0},写入业务日志失败!合同管理id为:{1}",enablad,MapUtils.getString(params,"id")));
+ log.error(String.format("修改合同状态为:{0},写入业务日志失败!合同管理id为:{1}", enablad, MapUtils.getString(params, "id")));
}
}
return resultBody;
}
+
+ /**
+ * 获取 用户的状态 为试用状态还是 启用状态
+ *
+ * @return
+ */
+ @ApiOperation(value = "获取 用户的状态")
+ @GetMapping("/getTypeByUser")
+ public ResultBody getTypeByUser(@LoginUser SysUser sysUser) {
+ return productOrderDetailService.getTypeByUser(sysUser);
+ }
+
+ /**
+ * 统计获取数据量
+ * @param datatype
+ * 0 试用审核量
+ * 1 套餐总量
+ * 2 未处理用户反馈
+ * 3 未处理数据需求
+ * @return
+ */
+ @ApiOperation(value = "统计获取数据量")
+ @GetMapping("/oprationChart")
+ public ResultBody oprationChart(int datatype) {
+ int counts=productOrderDetailService.oprationChart(datatype);
+ return ResultBody.ok().data(counts).msg("数据获取成功!") ;
+ }
+
+ /**
+ * 按指定类型统计合同数量
+ * @param params
+ * datatype 1 按年
+ * 2 按月
+ * 3 按天
+ * 4 按周
+ * beginTime 查询时间段的开始时间
+ * endTime 结束时间
+ * @return
+ */
+ @ApiOperation(value = "按指定类型统计合同数量")
+ @GetMapping("/productOrderChart")
+ public ResultBody productOrderChart(@RequestParam Map<String, Object> params) {
+ List<OrderChartVo> orderChartVo=productOrderDetailService.productOrderChart(params);
+ return ResultBody.ok().data(orderChartVo).msg("数据获取成功!") ;
+ }
+
+ /**
+ * 统计产品的使用数量
+ * @return ccount 是数量
+ * units 是产品名称
+ */
+ @ApiOperation(value = "统计产品的使用数量")
+ @GetMapping("/proCountChart")
+ public ResultBody proCountChart() {
+ List<OrderChartVo> orderChartVo=productOrderDetailService.proCountChart();
+ return ResultBody.ok().data(orderChartVo).msg("数据获取成功!") ;
+ }
+
+ /**
+ * 获取软件服务周期 和 读片总量
+ *
+ */
+ @ApiOperation(value = "获取软件服务周期")
+ @GetMapping("/getContractBeginEndTimeAndNum")
+ public ResultBody getContractBeginEndTimeAndNum(@RequestParam("departmentId") Long departmentId) {
+ Map<String,Object> map = new HashMap<>();
+ map.put("department_id",departmentId);
+ map.put("enabled",true);
+ map.put("is_del",false);
+ List<ProductOrder> productOrders = productOrderService.listByMap(map);
+ map = new HashMap<>();
+ if(productOrders!=null&&productOrders.size()>0){
+ IntSummaryStatistics intSummaryStatistics = productOrders.stream().filter(a-> a.getContractNum()!=null&&a.getEnabled()).mapToInt((x) -> x.getContractNum()).summaryStatistics();
+ Date minDate = productOrders.stream().filter(a->a.getEnabled()).map(e -> e.getContractBeginTime()).min((e1, e2) -> e1.compareTo(e2)).get();
+ Date manDate = productOrders.stream().filter(a->a.getEnabled()).map(e -> e.getContractEndTime()).max((e1, e2) -> e1.compareTo(e2)).get();
+ map.put("count", intSummaryStatistics.getSum());
+ map.put("beginTime",DateUtils.formatDate(minDate,"yyyy-MM-dd HH:mm:ss"));
+ map.put("endTime",DateUtils.formatDate(manDate,"yyyy-MM-dd HH:mm:ss"));
+ }
+ return ResultBody.ok().data(map);
+ }
}
--
Gitblit v1.8.0