package com.ltkj.web.controller.system; import java.security.Security; import java.util.*; import java.util.stream.Collectors; import javax.annotation.Resource; import javax.servlet.http.HttpServletResponse; import cn.hutool.core.date.DateUtil; import cn.hutool.core.io.unit.DataUnit; 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.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.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; /** * 查询体检心电图管理列表 */ //@PreAuthorize("@ss.hasPermi('picture:picture:list')") @GetMapping("/list") @ApiOperation(value = "查询体检心电图管理列表(自带默认)") public TableDataInfo list(TjXdPicture tjXdPicture) { startPage(); List 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) { LambdaQueryWrapperwq=new LambdaQueryWrapper<>(); if(null !=tjNum)wq.eq(TjXdPicture::getTjNum,tjNum); if(null !=name)wq.like(TjXdPicture::getCusName,name); wq.orderByDesc(TjXdPicture::getCreateTime); List list = tjXdPictureService.list(wq); List> arrayList=new ArrayList<>(); if(null !=list && !list.isEmpty()){ Map> stringListMap = list.stream().collect(Collectors.groupingBy(TjXdPicture::getCusId)); for (Map.Entry> entry : stringListMap.entrySet()) { Mapmap=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> collect =null; Mapmap=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 list = tjXdPictureService.selectTjXdPictureList(tjXdPicture); ExcelUtil util = new ExcelUtil(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()); LambdaQueryWrapperwq=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()); LambdaQueryWrapperwq1=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 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) { // DateTime beginTimes = null; // DateTime endTimes = null; // if (null != beginTime && null != endTime) { // beginTimes = DateUtil.beginOfDay(DateUtil.parse(beginTime)); // endTimes = DateUtil.endOfDay(DateUtil.parse(endTime)); // } // //初始化体检订单表 // List orderList = null; // List customerList = new ArrayList<>(); // Map map = new HashMap<>(); // // if (checkStatus == 0) // asyncService.wCScheckSetCustomerLisByRedis(orderService.getCsTjOrderList(tjNumber, checkStatus, compId, beginTimes, endTimes)); // if (checkStatus == 1) // asyncService.yCScheckSetCustomerLisByRedis(orderService.getCsTjOrderList(tjNumber, checkStatus, compId, beginTimes, endTimes)); // // //根据姓名查询 // if (null != name && !"".equals(name)) { // List list = customerService.getTjCustomerList(name); // if (null != list && list.size() > 0) { // List lists = new ArrayList<>(); // for (TjCustomer customer : list) { // orderList = orderService.getCsTjOrderListByCusId(customer.getCusId()); // if (null != orderList && orderList.size() > 0) { // for (TjOrder tjOrder : orderList) { // customer.setTjNumber(tjOrder.getTjNumber()); // customer.setTjStatus(Long.valueOf(tjOrder.getCheckStatus())); // customer.setOrderId(tjOrder.getOrderId()); // customer.setTjTime(tjOrder.getCreateTime()); // customer.setFinishTime(tjOrder.getFinishTime()); // customer.setCusName(MatchUtils.hideCusName(customer.getCusName())); // customer.setCusPhone(MatchUtils.hidePhoneNum(customer.getCusPhone())); // customer.setCusIdcard(MatchUtils.hideIdCardNum(customer.getCusIdcard())); // customer.setConfirmStatus(String.valueOf(tjOrder.getStatus())); // if (tjOrder.getFirmId().equals("0")) { // customer.setTjCompName(null); // } else { // customer.setTjCompName(compService.selectDictCompByDrugManufacturerId(tjOrder.getFirmId()).getCnName()); // } // lists.add(customer); // } // } // } // List customers = null; // if (lists.size() > 0) { // customers = lists.stream().skip((long) (page - 1) * pageSize).limit(pageSize).collect(Collectors.toList()); // } // map.put("customers", customers); // map.put("total", lists.size()); // return AjaxResult.success(map); // } // return AjaxResult.success("暂无数据"); // } // // //条件查询 // if (null != tjNumber || null != compId || (null != beginTime && null != endTime)) { // orderList = orderService.getCsTjOrderList(tjNumber, checkStatus, compId, beginTimes, endTimes); // return getResult(page, pageSize, orderList, customerList, map); // } // // List customers = null; // if (checkStatus == 0) { // customers = redisCache.getCacheMapValue("cScheck", "ws"); // } // if (checkStatus == 1) { // customers = redisCache.getCacheMapValue("cScheck", "ys"); // } // if (customers != null && customers.size() > 0) { // List customerLists = customers.stream().skip((long) (page - 1) * pageSize).limit(pageSize).collect(Collectors.toList()); // map.put("customers", customerLists); // map.put("total", customers.size()); // return AjaxResult.success(map); // } else { // orderList = orderService.getCsTjOrderList(tjNumber, checkStatus, compId, beginTimes, endTimes); // return getResult(page, pageSize, orderList, customerList, map); // } 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 list = remarkService.getYxJcXx(tjNumber,deptId.toString()); 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) { try { SysUser user = SecurityUtils.getLoginUser().getUser(); TjOrder order = orderService.getOrderByTjNum(tjNumber); if(null !=order){ TjProject project = projectService.getById(proId); if(null !=project){ List projects = projectService.getTjProjectListBySoneId(proId); LambdaQueryWrapperwq1=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); LambdaQueryWrapperwq2=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()); 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()); 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.setSqsj(DateUtil.format(date,"yyyy-MM-dd")); jcbgd.setLx("1"); jcbgd.setCreateTime(date); jcbgdService.save(jcbgd); jcsqdService.saveLtkjExamJcsqdxdt(xdtgmdjg.getCardId()); } 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 wq=new LambdaQueryWrapper<>(); wq.eq(TjXdtgmdjg::getTjh,tjNumber); wq.eq(TjXdtgmdjg::getProId,proId); TjXdtgmdjg xdtgmdjg = xdtgmdjgService.getOne(wq); Mapmap=new HashMap<>(); if(null !=xdtgmdjg ){ map.put("jcsj",xdtgmdjg.getJcsj()); map.put("jcjl",xdtgmdjg.getJcjl()); return AjaxResult.success(map); } return AjaxResult.success(map); } return AjaxResult.error("暂无体检记录"); } }