package com.ltkj.web.controller.system;
|
|
import java.io.File;
|
import java.io.IOException;
|
import java.nio.file.Files;
|
import java.nio.file.Path;
|
import java.nio.file.Paths;
|
import java.util.*;
|
import java.util.stream.Collectors;
|
import javax.annotation.Resource;
|
import javax.servlet.http.HttpServletResponse;
|
|
import cn.hutool.core.date.DateUtil;
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.ltkj.common.core.domain.entity.SysUser;
|
import com.ltkj.common.core.redis.RedisCache;
|
import com.ltkj.common.utils.SecurityUtils;
|
import com.ltkj.common.utils.file.FileUploadUtils;
|
import com.ltkj.db.DataSourceContextHolder;
|
import com.ltkj.framework.config.MatchUtils;
|
import com.ltkj.hosp.domain.*;
|
import com.ltkj.hosp.service.*;
|
import com.ltkj.hosp.sqlDomain.LtkjExamJcbgd;
|
import com.ltkj.hosp.vodomain.CsProVo;
|
import com.ltkj.system.service.ISysConfigService;
|
import io.swagger.annotations.Api;
|
import io.swagger.annotations.ApiOperation;
|
import io.swagger.annotations.ApiParam;
|
import jodd.util.StringUtil;
|
import lombok.extern.slf4j.Slf4j;
|
import org.springframework.beans.factory.annotation.Value;
|
import org.springframework.security.access.prepost.PreAuthorize;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.transaction.annotation.Isolation;
|
import org.springframework.transaction.annotation.Propagation;
|
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.interceptor.TransactionAspectSupport;
|
import org.springframework.web.bind.annotation.*;
|
import com.ltkj.common.annotation.Log;
|
import com.ltkj.common.core.controller.BaseController;
|
import com.ltkj.common.core.domain.AjaxResult;
|
import com.ltkj.common.enums.BusinessType;
|
import com.ltkj.common.utils.poi.ExcelUtil;
|
import com.ltkj.common.core.page.TableDataInfo;
|
|
/**
|
* 体检心电图管理Controller
|
*
|
* @author ltkj_赵佳豪&李格
|
* @date 2023-04-11
|
*/
|
@RestController
|
@RequestMapping("/picture/picture")
|
@Api(tags = "体检心电图管理")
|
@Slf4j
|
public class TjXdPictureController extends BaseController {
|
@Resource
|
private ITjXdPictureService tjXdPictureService;
|
@Resource
|
private ITjCustomerService customerService;
|
@Autowired
|
private ISysConfigService configService;
|
@Resource
|
private ITjOrderService orderService;
|
@Resource
|
private ITjOrderDetailService detailService;
|
@Resource
|
private ITjOrderRemarkService remarkService;
|
@Resource
|
private ITjProjectService projectService;
|
@Resource
|
private TjXdtgmdjgService xdtgmdjgService;
|
@Resource
|
private LtkjExamJcbgdService jcbgdService;
|
@Resource
|
private LtkjExamJcsqdService jcsqdService;
|
@Autowired
|
private TjJcycxmService jcycxmService;
|
/**
|
* 查询体检心电图管理列表
|
*/
|
//@PreAuthorize("@ss.hasPermi('picture:picture:list')")
|
@GetMapping("/list")
|
@ApiOperation(value = "查询体检心电图管理列表(自带默认)")
|
public TableDataInfo list(TjXdPicture tjXdPicture) {
|
startPage();
|
List<TjXdPicture> list = tjXdPictureService.selectTjXdPictureList(tjXdPicture);
|
return getDataTable(list);
|
}
|
|
@GetMapping("/getList")
|
@ApiOperation(value = "查询体检客户心电图列表(非自带)")
|
public AjaxResult getList(@RequestParam(required = false) @ApiParam(value = "体检号") String tjNum,
|
@RequestParam(required = false) @ApiParam(value = "客户姓名") String name,
|
@ApiParam(value = "页码数(默认1)") @RequestParam(defaultValue = "1") Integer pageNum,
|
@ApiParam(value = "显示条数(默认10)") @RequestParam(defaultValue = "10") Integer pageSize) {
|
LambdaQueryWrapper<TjXdPicture>wq=new LambdaQueryWrapper<>();
|
if(null !=tjNum)wq.eq(TjXdPicture::getTjNum,tjNum);
|
if(null !=name)wq.like(TjXdPicture::getCusName,name);
|
wq.orderByDesc(TjXdPicture::getCreateTime);
|
List<TjXdPicture> list = tjXdPictureService.list(wq);
|
List<Map<String,Object>> arrayList=new ArrayList<>();
|
if(null !=list && !list.isEmpty()){
|
Map<String, List<TjXdPicture>> stringListMap = list.stream().collect(Collectors.groupingBy(TjXdPicture::getCusId));
|
for (Map.Entry<String, List<TjXdPicture>> entry : stringListMap.entrySet()) {
|
Map<String,Object>map=new HashMap<>();
|
TjCustomer customer = customerService.getById(entry.getKey());
|
if(null !=customer){
|
customer.setCusName(MatchUtils.hideCusName(customer.getCusName()));
|
customer.setCusPhone(MatchUtils.hidePhoneNum(customer.getCusPhone()));
|
customer.setCusIdcard(MatchUtils.hideIdCardNum(customer.getCusIdcard()));
|
customer.setTjNumber(entry.getValue().get(0).getTjNum());
|
map.put("list",entry.getValue());
|
map.put("customer",customer);
|
map.put("picturePath",configService.selectConfigByKey("TjXdPicture"));
|
arrayList.add(map);
|
}
|
|
}
|
}
|
List<Map<String, Object>> collect =null;
|
Map<String,Object>map=new HashMap<>();
|
if(!arrayList.isEmpty()){
|
collect = arrayList.stream().skip((long) (pageNum - 1) * pageSize).limit(pageSize).collect(Collectors.toList());
|
}
|
map.put("list",collect);
|
map.put("total",arrayList.size());
|
return AjaxResult.success(map);
|
}
|
|
/**
|
* 导出体检心电图管理列表
|
*/
|
//@PreAuthorize("@ss.hasPermi('picture:picture:export')")
|
@Log(title = "体检心电图管理", businessType = BusinessType.EXPORT)
|
@PostMapping("/export")
|
@ApiOperation(value = "导出体检心电图管理列表")
|
public void export(HttpServletResponse response, TjXdPicture tjXdPicture) {
|
List<TjXdPicture> list = tjXdPictureService.selectTjXdPictureList(tjXdPicture);
|
ExcelUtil<TjXdPicture> util = new ExcelUtil<TjXdPicture>(TjXdPicture.class);
|
util.exportExcel(response, list, "体检心电图管理数据");
|
}
|
|
/**
|
* 获取体检心电图管理详细信息
|
*/
|
//@PreAuthorize("@ss.hasPermi('picture:picture:query')")
|
@GetMapping(value = "/{id}")
|
@ApiOperation(value = "获取体检心电图管理详细信息")
|
public AjaxResult getInfo(@PathVariable("id") String id) {
|
return success(tjXdPictureService.selectTjXdPictureById(id));
|
}
|
|
/**
|
* 新增体检心电图管理
|
*/
|
//@PreAuthorize("@ss.hasPermi('picture:picture:add')")
|
@Log(title = "体检心电图管理", businessType = BusinessType.INSERT)
|
@PostMapping
|
@ApiOperation(value = "新增体检心电图管理")
|
public AjaxResult add(@RequestBody TjXdPicture tjXdPicture) {
|
return toAjax(tjXdPictureService.insertTjXdPicture(tjXdPicture));
|
}
|
|
/**
|
* 修改体检心电图管理
|
*/
|
//@PreAuthorize("@ss.hasPermi('picture:picture:edit')")
|
@Log(title = "体检心电图管理", businessType = BusinessType.UPDATE)
|
@PutMapping
|
@ApiOperation(value = "修改体检心电图管理")
|
public AjaxResult edit(@RequestBody TjXdPicture tjXdPicture) {
|
if (tjXdPictureService.updateById(tjXdPicture)) {
|
TjOrder order = orderService.getOrderByTjNum(tjXdPicture.getTjNum());
|
LambdaQueryWrapper<TjOrderDetail>wq=new LambdaQueryWrapper<>();
|
wq.eq(TjOrderDetail::getOrderId,order.getOrderId());
|
wq.eq(TjOrderDetail::getProId,tjXdPicture.getProId());
|
TjOrderDetail detail = detailService.getOne(wq);
|
detail.setProResult(tjXdPicture.getProResult());
|
detail.setConclusion(tjXdPicture.getConclusion());
|
detail.setTjStatus(1L);
|
detailService.updateById(detail);
|
|
TjProject tjProject = projectService.getById(tjXdPicture.getProId());
|
TjProject tjProjectp = projectService.getById(tjProject.getProParentId());
|
|
LambdaQueryWrapper<TjOrderDetail>wq1=new LambdaQueryWrapper<>();
|
wq1.eq(TjOrderDetail::getOrderId,order.getOrderId());
|
wq1.eq(TjOrderDetail::getProId,tjProjectp.getProId());
|
TjOrderDetail detailp = detailService.getOne(wq);
|
detailp.setTjStatus(1L);
|
detailService.updateById(detailp);
|
|
LambdaQueryWrapper<TjOrderRemark> wq2=new LambdaQueryWrapper<>();
|
wq2.eq(TjOrderRemark::getTjNumber,tjXdPicture.getTjNum());
|
wq2.eq(TjOrderRemark::getProId,tjProjectp.getProId());
|
TjOrderRemark remark = remarkService.getOne(wq2);
|
remark.setType(1);
|
remark.setRemark(tjXdPicture.getConclusion());
|
remarkService.updateById(remark);
|
return AjaxResult.success();
|
}
|
return AjaxResult.error();
|
}
|
|
/**
|
* 删除体检心电图管理
|
*/
|
//@PreAuthorize("@ss.hasPermi('picture:picture:remove')")
|
@Log(title = "体检心电图管理", businessType = BusinessType.DELETE)
|
@DeleteMapping("/{ids}")
|
@ApiOperation(value = "删除体检心电图管理")
|
public AjaxResult remove(@PathVariable String[] ids) {
|
return toAjax(tjXdPictureService.deleteTjXdPictureByIds(ids));
|
}
|
|
|
|
|
@GetMapping ("/getYxJcList")
|
@ApiOperation (value = "影像检查列表(骨密度和心电图)")//0待1已
|
@Transactional
|
public AjaxResult getYxJcList(@ApiParam (value = "审核状态 0待审核 1已审核") @RequestParam Integer checkStatus,
|
@ApiParam (value = "页码数(默认1)") @RequestParam (defaultValue = "1") Integer page,
|
@ApiParam (value = "显示条数(默认10)") @RequestParam (defaultValue = "10") Integer pageSize,
|
@ApiParam (value = "体检单号") @RequestParam (required = false) String tjNumber,
|
@ApiParam (value = "单位") @RequestParam (required = false) Long compId,
|
@ApiParam (value = "姓名)") @RequestParam (required = false) String name,
|
@ApiParam (value = "套餐名)") @RequestParam (required = false) String tcm,
|
@ApiParam (value = "开始时间") @RequestParam (required = false) String beginTime,
|
@ApiParam (value = "结束时间") @RequestParam (required = false) String endTime) {
|
|
Long deptId = SecurityUtils.getDeptId();
|
log.info("影像检查列表(骨密度和心电图)接口 当前登录人科室"+deptId);
|
String value = String.valueOf(compId);
|
if (tjNumber == null) tjNumber = "";
|
if (compId == null) value = "";
|
if (name == null) name = "";
|
if (beginTime == null) beginTime = "";
|
if (endTime == null) endTime = "";
|
if (tcm == null) tcm = "";
|
return AjaxResult.success(orderService.getYxJcList(checkStatus,tjNumber, page, pageSize, value, beginTime, endTime, name,tcm,deptId.toString()));
|
}
|
|
@GetMapping ("/getYxJcXx")
|
@ApiOperation (value = "影像检查骨密度心电图页面点击体检人员展示体检项目接口")
|
public AjaxResult getYxJcXx(@ApiParam (value = "体检号") @RequestParam String tjNumber) {
|
Long deptId = SecurityUtils.getDeptId();
|
log.info("影像检查骨密度心电图页面点击体检人员展示体检项目接口当前登录人科室"+deptId);
|
List<CsProVo> list = remarkService.getYxJcXx(tjNumber,deptId.toString());
|
if(null !=list && !list.isEmpty()){
|
for (CsProVo vo : list) {
|
LambdaQueryWrapper<TjXdtgmdjg> wq=new LambdaQueryWrapper<>();
|
wq.eq(TjXdtgmdjg::getTjh,tjNumber);
|
wq.eq(TjXdtgmdjg::getProId,vo.getProId());
|
TjXdtgmdjg xdtgmdjg = xdtgmdjgService.getOne(wq);
|
if(null !=xdtgmdjg){
|
if(StringUtil.isNotBlank(xdtgmdjg.getUrl())){
|
Path path = Paths.get(xdtgmdjg.getUrl());
|
byte[] data = null;
|
try {
|
data = Files.readAllBytes(path);
|
} catch (IOException e) {
|
throw new RuntimeException(e);
|
}
|
String base64 = Base64.getEncoder().encodeToString(data);
|
if(StringUtil.isNotBlank(base64)) vo.setImageUrl(base64);
|
}
|
}
|
}
|
|
}
|
return AjaxResult.success(list);
|
}
|
|
@GetMapping ("/addYxJcXx")
|
@ApiOperation (value = "提交影像检查骨密度心电图结果接口")
|
@Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.READ_COMMITTED)
|
public AjaxResult addYxJcXx(@ApiParam (value = "体检号") @RequestParam String tjNumber,
|
@ApiParam (value = "项目id") @RequestParam String proId,
|
@ApiParam (value = "检查所见") @RequestParam String jcsj,
|
@ApiParam (value = "检查结论") @RequestParam String jcjl,
|
@ApiParam (value = "图片地址") @RequestParam(required = false) String url) {
|
try {
|
SysUser user = SecurityUtils.getLoginUser().getUser();
|
TjOrder order = orderService.getOrderByTjNum(tjNumber);
|
if(null !=order){
|
TjProject project = projectService.getById(proId);
|
if(null !=project){
|
List<TjProject> projects = projectService.getTjProjectListBySoneId(proId);
|
LambdaQueryWrapper<TjOrderDetail>wq1=new LambdaQueryWrapper<>();
|
wq1.eq(TjOrderDetail::getProId,projects.get(0).getProParentId());
|
wq1.eq(TjOrderDetail::getOrderId,order.getOrderId());
|
TjOrderDetail detail = detailService.getOne(wq1);
|
if(null !=detail){
|
detail.setProResult(jcjl+"。"+jcsj);
|
detail.setTjStatus(1L);
|
detailService.updateById(detail);
|
LambdaQueryWrapper<TjOrderRemark>wq2=new LambdaQueryWrapper<>();
|
wq2.eq(TjOrderRemark::getProId,proId);
|
wq2.eq(TjOrderRemark::getTjNumber,tjNumber);
|
TjOrderRemark orderRemark = remarkService.getOne(wq2);
|
if(null !=orderRemark){
|
orderRemark.setType(1);
|
remarkService.updateById(orderRemark);
|
xdtgmdjgService.deletedByTJhAndProId(tjNumber, proId);
|
TjXdtgmdjg xdtgmdjg=new TjXdtgmdjg();
|
xdtgmdjg.setTjh(tjNumber);
|
xdtgmdjg.setCardId(order.getCardId());
|
xdtgmdjg.setProId(proId);
|
xdtgmdjg.setProName(project.getProName());
|
xdtgmdjg.setJcsj(jcsj);
|
xdtgmdjg.setJcjl(jcjl);
|
xdtgmdjg.setCreateBy(user.getNickName());
|
xdtgmdjg.setCreateId(user.getUserId().toString());
|
if(StringUtil.isNotBlank(url)) xdtgmdjg.setUrl(url);
|
xdtgmdjgService.save(xdtgmdjg);
|
saveTjXdtgmdjgByJcbgd(xdtgmdjg);
|
}
|
}
|
}
|
return AjaxResult.success();
|
}
|
return AjaxResult.error("暂无体检记录");
|
} catch (Exception e) {
|
TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
|
log.error("提交影像检查骨密度心电图结果接口"+e.getMessage());
|
throw new RuntimeException("提交影像检查骨密度心电图结果接口");
|
}
|
}
|
@Transactional(propagation = Propagation.REQUIRED) // 共享事务
|
public void saveTjXdtgmdjgByJcbgd(TjXdtgmdjg xdtgmdjg) {
|
try {
|
int length = xdtgmdjg.getProId().length();
|
// 确保字符串长度至少为6
|
String last6 = length >= 6 ? xdtgmdjg.getProId().substring(length - 6) : xdtgmdjg.getProId();
|
Date date = new Date();
|
LtkjExamJcbgd jcbgd=new LtkjExamJcbgd();
|
jcsqdService.deletedLtkjJcsqdByTjhandtmh(xdtgmdjg.getCardId(),xdtgmdjg.getTjh()+last6);
|
jcbgdService.deletedLtkjJcbgdByTjhandtmh(xdtgmdjg.getCardId(),xdtgmdjg.getTjh()+last6);
|
jcbgd.setTjh(xdtgmdjg.getCardId());
|
jcbgd.setTmh(xdtgmdjg.getTjh()+last6);
|
jcbgd.setXmdm(xdtgmdjg.getProId());
|
jcbgd.setXmmc(xdtgmdjg.getProName());
|
jcbgd.setBgNr(xdtgmdjg.getJcsj());
|
if(StringUtil.isNotBlank(xdtgmdjg.getUrl())){
|
jcbgd.setBgUrl(xdtgmdjg.getUrl());
|
}else {
|
jcbgd.setBgUrl("");
|
}
|
jcbgd.setShysxm(xdtgmdjg.getCreateBy());
|
jcbgd.setShysdm(xdtgmdjg.getCreateId());
|
jcbgd.setYxzd(xdtgmdjg.getJcjl());
|
jcbgd.setYxbx(xdtgmdjg.getJcjl());
|
jcbgd.setZdsj(DateUtil.format(date,"yyyy-MM-dd"));
|
jcbgd.setJcbw("");
|
jcbgd.setLx("1");
|
jcbgd.setSqsj(DateUtil.format(date,"yyyy-MM-dd"));
|
jcbgd.setCreateTime(date);
|
jcbgdService.save(jcbgd);
|
jcsqdService.saveXdtLtkjExamJcsqd(xdtgmdjg.getCardId(),jcbgd.getTmh());
|
|
LambdaQueryWrapper<TjJcycxm> wq=new LambdaQueryWrapper<>();
|
wq.eq(TjJcycxm::getTjh,xdtgmdjg.getTjh());
|
wq.eq(TjJcycxm::getProId,xdtgmdjg.getProId());
|
jcycxmService.remove(wq);
|
if(StringUtil.isNotBlank(xdtgmdjg.getJcjl())){
|
String[] split = xdtgmdjg.getJcjl().replaceAll("\n", "").split("。|;|;|,|,");
|
for (String jg : split) {
|
if(StringUtil.isNotBlank(jg) && !jg.contains("未见异常")
|
&& !jg.contains("未见明显异常") && !jg.contains("未见占位") && !jg.contains("未见")
|
&& !jg.contains("未见明显")&& !jg.contains("正常")&& !jg.contains("双侧椎间孔无狭窄")){
|
TjJcycxm jcycxm=new TjJcycxm();
|
jcycxm.setTjh(xdtgmdjg.getTjh());
|
jcycxm.setYqid("");
|
jcycxm.setProId(xdtgmdjg.getProId());
|
jcycxm.setProName(xdtgmdjg.getProName());
|
jcycxm.setCreateTime(new Date());
|
jcycxm.setJcjg(jg);
|
jcycxmService.save(jcycxm);
|
}
|
}
|
}
|
} catch (Exception e) {
|
throw new RuntimeException(e);
|
}
|
}
|
|
|
@GetMapping ("/getYxJcXxJg")
|
@ApiOperation (value = "获取影像检查骨密度心电图结果接口")
|
@Transactional
|
public AjaxResult getYxJcXxJg(@ApiParam (value = "体检号") @RequestParam String tjNumber,
|
@ApiParam (value = "项目id") @RequestParam String proId) {
|
TjOrder order = orderService.getOrderByTjNum(tjNumber);
|
if(null !=order){
|
LambdaQueryWrapper<TjXdtgmdjg> wq=new LambdaQueryWrapper<>();
|
wq.eq(TjXdtgmdjg::getTjh,tjNumber);
|
wq.eq(TjXdtgmdjg::getProId,proId);
|
TjXdtgmdjg xdtgmdjg = xdtgmdjgService.getOne(wq);
|
Map<String,Object>map=new HashMap<>();
|
if(null !=xdtgmdjg ){
|
map.put("jcsj",xdtgmdjg.getJcsj());
|
map.put("jcjl",xdtgmdjg.getJcjl());
|
if(StringUtil.isNotBlank(xdtgmdjg.getUrl())){
|
Path path = Paths.get(xdtgmdjg.getUrl());
|
byte[] data = null;
|
try {
|
data = Files.readAllBytes(path);
|
} catch (IOException e) {
|
throw new RuntimeException(e);
|
}
|
String base64 = Base64.getEncoder().encodeToString(data);
|
map.put("tp",base64);
|
}else {
|
map.put("tp",null);
|
}
|
return AjaxResult.success(map);
|
}else {
|
TjProject tjProject = projectService.getById(proId);
|
map.put("jcsj","");
|
map.put("jcjl",tjProject.getProDefault()==null ? "":tjProject.getProDefault());
|
map.put("tp",null);
|
}
|
return AjaxResult.success(map);
|
}
|
return AjaxResult.error("暂无体检记录");
|
}
|
}
|