JianYanJianChaShenQingServer.java 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478
  1. package thyyxxk.webserver.service.zhuyuanyisheng;
  2. import com.alibaba.fastjson.JSON;
  3. import com.baomidou.mybatisplus.core.metadata.IPage;
  4. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  5. import lombok.extern.slf4j.Slf4j;
  6. import org.springframework.stereotype.Service;
  7. import org.springframework.transaction.annotation.Transactional;
  8. import thyyxxk.webserver.config.exception.BizException;
  9. import thyyxxk.webserver.config.exception.ExceptionEnum;
  10. import thyyxxk.webserver.dao.his.zhuyuanyisheng.JianYanJianChaDao;
  11. import thyyxxk.webserver.dao.his.zhuyuanyisheng.YiZhuLuRuDao;
  12. import thyyxxk.webserver.entity.ResultVo;
  13. import thyyxxk.webserver.entity.datamodify.GetDropdownBox;
  14. import thyyxxk.webserver.entity.zhuyuanyisheng.jianyanjiancha.*;
  15. import thyyxxk.webserver.entity.zhuyuanyisheng.query.ChaXunJianChaHeJianYan;
  16. import thyyxxk.webserver.entity.zhuyuanyisheng.yizhuluru.PatientTemp;
  17. import thyyxxk.webserver.entity.zhuyuanyisheng.yizhuluru.XinZhenYiZhu;
  18. import thyyxxk.webserver.service.PublicServer;
  19. import thyyxxk.webserver.utils.*;
  20. import java.lang.reflect.Field;
  21. import java.math.BigDecimal;
  22. import java.util.ArrayList;
  23. import java.util.HashMap;
  24. import java.util.List;
  25. import java.util.Map;
  26. /**
  27. * <p>
  28. * 描述: 住院医生,检查申请
  29. * </p>
  30. *
  31. * @author xc
  32. * @date 2022-02-10 15:37
  33. */
  34. @Service
  35. @Slf4j
  36. public class JianYanJianChaShenQingServer {
  37. private final JianYanJianChaDao dao;
  38. private final PublicServer publicServer;
  39. private final YiZhuLuRuDao yiZhuLuRuDao;
  40. public JianYanJianChaShenQingServer(JianYanJianChaDao dao, PublicServer publicServer, YiZhuLuRuDao yiZhuLuRuDao) {
  41. this.dao = dao;
  42. this.publicServer = publicServer;
  43. this.yiZhuLuRuDao = yiZhuLuRuDao;
  44. }
  45. /*-------------------------------------------------------------- 下面是检查的逻辑 -----------------------------------------------------------------------------------------------------*/
  46. /**
  47. * 获取检验检查的名字
  48. *
  49. * @param name 姓名
  50. * @param patNo 住院号
  51. * @param times 住院次数
  52. * @param bedNo 床位
  53. * @param reqType 2-检验 3-检查
  54. * @return 返回数据
  55. */
  56. public ResultVo<List<Map<String, String>>> huoQuJianYanJianChaMing(String name, String patNo, Integer times, String bedNo, String reqType) {
  57. return ResultVoUtil.success(dao.huoQuJianJianChaMing(patNo, times, bedNo, StringUtil.isContainChinese(name), reqType));
  58. }
  59. /**
  60. * 获取检查申请
  61. *
  62. * @param param 检查申请
  63. * @return 返回数据
  64. */
  65. public ResultVo<IPage<YshYjReq>> huoQuJianChaShenQing(ChaXunJianChaHeJianYan param) {
  66. IPage<YshYjReq> page = new Page<>(param.getCurrentPage(), param.getPageSize(), param.getTotal() == 0);
  67. page = dao.huoQuJianChaShenQing(page, param.getPatNo(), param.getTimes(), param.getOrderName(), param.getStartTime(), param.getEndTime());
  68. return ResultVoUtil.success(page);
  69. }
  70. public ResultVo<Map<String, Object>> huoQuShengQingXiangQing(Integer reqNo) {
  71. YshYjReq req = dao.huoQuShengQingXiangQing(reqNo);
  72. if (req == null) {
  73. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_HTML_ERROR, "没有查询到有效信息,可能已经被删除了。");
  74. }
  75. Map<String, Object> map = new HashMap<>();
  76. StringBuilder zhuYiShiXiang = new StringBuilder();
  77. JcZdClass jc = dao.daYingXiangQing(req.getOrderType());
  78. // 获取患者的住址和性别
  79. PatientTemp patient = dao.huoQuHuanZheXinXi(req.getInpatientNo());
  80. req.setSex(patient.getSex());
  81. // 地址
  82. req.setHomeStreet(patient.getHomeStreet());
  83. //联系电话
  84. req.setHomeTel(patient.getHomeTel());
  85. // 医保身份
  86. req.setResponceTypeName(dao.huoQuHuanZheShenFen(req.getInpatientNo()));
  87. map.put("biaoTi", jc.getComm());
  88. Field[] fields = jc.getClass().getDeclaredFields();
  89. for (Field field : fields) {
  90. field.setAccessible(true);
  91. // 输出属性名和属性值
  92. try {
  93. String key = field.getName();
  94. Object value = EntityStringTrim.getFieldValue(jc, key);
  95. if (key.startsWith("comment") && StringUtil.notBlank((String) value)) {
  96. zhuYiShiXiang.append(((String) value).trim()).append("\n");
  97. }
  98. } catch (Exception e) {
  99. e.printStackTrace();
  100. }
  101. }
  102. map.put("zhuYiShiXiang", zhuYiShiXiang.toString());
  103. map.put("shuJu", req);
  104. return ResultVoUtil.success(map);
  105. }
  106. /**
  107. * 查询检查检验分类
  108. *
  109. * @param total 总条数
  110. * @param currentPage 当前页
  111. * @param leiXing 类型 1-新申请 2-个人 3-科室
  112. * @param jianCha true 检查 false 检验
  113. * @return 返回分页数据
  114. */
  115. public ResultVo<IPage<JcZdClass>> jianChaJianYanFenLei(long total, long currentPage, Integer leiXing, Boolean jianCha) {
  116. IPage<JcZdClass> page = new Page<>();
  117. if (leiXing == 1) {
  118. if (jianCha) {
  119. if (total == 0) {
  120. page.setTotal(dao.jianChaMingTiaoShu());
  121. }
  122. page.setRecords(dao.jianChaMing(currentPage));
  123. } else {
  124. page = new Page<>(currentPage, 20, total == 0);
  125. page = dao.jianYanFenLei(page);
  126. return ResultVoUtil.success(page);
  127. }
  128. } else {
  129. page = new Page<>(currentPage, 20, total == 0);
  130. page = dao.jianChaJianYanMuBan(page, leiXing, TokenUtil.getTokenUserId(), jianCha ? "3" : "2");
  131. }
  132. return ResultVoUtil.success(page);
  133. }
  134. /**
  135. * 检验检查的分类详细信息
  136. *
  137. * @param code 编码
  138. * @param bwCode 不是个人编码的话就需要这个
  139. * @param jianCha true 检查 false 检验
  140. * @return 返回详细的内容
  141. */
  142. public ResultVo<List<Map<String, String>>> chaKanFenLeiXiangQing(String code, String bwCode, Boolean jianCha) {
  143. if (jianCha) {
  144. if (StringUtil.notBlank(bwCode) && bwCode.equals("mb")) {
  145. return ResultVoUtil.success(dao.chaKanMuBanNeiRong(code, "3"));
  146. }
  147. return ResultVoUtil.success(dao.chaKanFenLeiXiangQing(code, bwCode));
  148. }
  149. if (StringUtil.notBlank(bwCode) && bwCode.equals("mb")) {
  150. return ResultVoUtil.success(dao.chaKanMuBanNeiRong(code, "2"));
  151. }
  152. return ResultVoUtil.success(dao.chaKanJianYanXiangQing(code));
  153. }
  154. /**
  155. * 删除检查或检验模板
  156. *
  157. * @param code 要删除的模板 code
  158. * @param deptCode 当前患者的科室编码
  159. * @return 返回提示
  160. */
  161. public ResultVo<String> shanShuJianChaMuBan(String code, String deptCode) {
  162. ZyTcYj yj = dao.jianChaLuRuRen(code);
  163. if (yj == null) {
  164. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "没有找对应的记录可能已经被删除了。");
  165. }
  166. if (jianChaMuBanPanDuan(yj.getOpId(), yj.getTcExec(), deptCode)) {
  167. dao.shanChuJianChaMuBan(code);
  168. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION);
  169. }
  170. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "您没有权限修改。");
  171. }
  172. /**
  173. * 检查模板的判断
  174. *
  175. * @param opId 录入人
  176. * @param tcExec 模板的科室
  177. * @param deptCode 当前用户的科室
  178. * @return boolean
  179. */
  180. public boolean jianChaMuBanPanDuan(String opId, String tcExec, String deptCode) {
  181. List<Integer> userRole = publicServer.getRoleCode().getData();
  182. // 医务部
  183. if (userRole.contains(38)) {
  184. return true;
  185. }
  186. // 科主任 可以删除自己科室任意模板
  187. if (userRole.contains(11) && tcExec.trim().equals(deptCode)) {
  188. return true;
  189. }
  190. // 普通的只能删除自己的
  191. return opId.trim().equals(TokenUtil.getTokenUserId());
  192. }
  193. /**
  194. * 获取说明,模板的一下信息
  195. *
  196. * @param name 根据说明模板来 搜索
  197. * @param fenLei 分类
  198. * @param total 总数
  199. * @param currentPage 当前页
  200. * @return 返回提示
  201. */
  202. public ResultVo<IPage<YshZdYjTemplate>> huoMuShuoMingMuBan(String name, Integer fenLei, long total, long currentPage) {
  203. Page<YshZdYjTemplate> page = new Page<>(currentPage, 20, total == 0);
  204. page = dao.huoQuShuoMingMuBan(page, StringUtil.isContainChinese(name), fenLei, TokenUtil.getTokenUserId());
  205. return ResultVoUtil.success(page);
  206. }
  207. /**
  208. * 对于说明模板的操作
  209. *
  210. * @param param 说明模板的内容
  211. * @return 返回提示
  212. */
  213. @Transactional(rollbackFor = Exception.class)
  214. public ResultVo<String> shouMingMuBanChaoZuo(YshZdYjTemplate param) {
  215. switch (param.getLeiXing()) {
  216. case "修改":
  217. return xiuGaiMuBan(param, dao.muBanShuJu(param.getCode()));
  218. case "删除":
  219. return shanChuMuBan(dao.muBanShuJu(param.getCode()));
  220. case "新增":
  221. return xinZengShouMingMuBan(param);
  222. }
  223. return ResultVoUtil.success();
  224. }
  225. /**
  226. * 修改说明模板
  227. *
  228. * @param param 修改的数据
  229. * @param mb 原来的数据
  230. * @return 返回提示
  231. */
  232. private ResultVo<String> xiuGaiMuBan(YshZdYjTemplate param, YshZdYjTemplate mb) {
  233. if (publicServer.noNeedRule(38)) {
  234. if (!TokenUtil.getTokenUserId().equals(mb.getOpId().trim())) {
  235. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "该模板创建人不是你,无法操作。");
  236. }
  237. }
  238. dao.genXingShouMingMuBan(param.getJcText(), param.getName(),
  239. PingYinUtils.pyShouZiMuDaXie(param.getName()),
  240. PingYinUtils.getWBCode(param.getName()), param.getCode());
  241. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION);
  242. }
  243. /**
  244. * 删除说明模板
  245. *
  246. * @param mb 通过数据库查找 原来的模板
  247. * @return 返回提示
  248. */
  249. private ResultVo<String> shanChuMuBan(YshZdYjTemplate mb) {
  250. List<Integer> userRole = publicServer.getRoleCode().getData();
  251. if (publicServer.noNeedRule(userRole, 38)) {
  252. if (TokenUtil.getTokenUserId().equals(mb.getOpId().trim()) || (userRole.contains(11) && mb.getDeptCode().trim().equals(mb.getUserDeptCode().trim()))) {
  253. dao.shanChuShouMingMuBan(mb.getCode());
  254. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION);
  255. } else {
  256. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "您没有权限修改。");
  257. }
  258. }
  259. dao.shanChuShouMingMuBan(mb.getCode());
  260. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION);
  261. }
  262. /**
  263. * 新增说明模板
  264. *
  265. * @param param 新增的数据
  266. * @return 返回提示
  267. */
  268. private ResultVo<String> xinZengShouMingMuBan(YshZdYjTemplate param) {
  269. if (param.getWhFlag().trim().equals("3") && publicServer.noNeedRule(38)) {
  270. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "您没有权限创建全院模板。");
  271. } else if (param.getWhFlag().trim().equals("2") && publicServer.noNeedRule(11)) {
  272. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "科主任才可以创建科室模板。");
  273. }
  274. param.setCode(publicServer.getYjTemplateNo().toString());
  275. param.setPyCode(PingYinUtils.pyShouZiMuDaXie(param.getName()));
  276. param.setDCode(PingYinUtils.getWBCode(param.getName()));
  277. param.setOpId(TokenUtil.getTokenUserId());
  278. dao.xinZengShouMingMuBan(param);
  279. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION);
  280. }
  281. /**
  282. * 搜索临床诊断
  283. *
  284. * @param name 搜索的名字
  285. * @param laiYuan true 医保 false 本院
  286. * @return 返回搜索的数据
  287. */
  288. public ResultVo<List<GetDropdownBox>> huoQuLinChuangZhenDuan(String name, Boolean laiYuan) {
  289. return laiYuan ? ResultVoUtil.success(dao.yiBaoZhenDuan(StringUtil.isContainChinese(name))) :
  290. ResultVoUtil.success(dao.benYuanLinChuangZhenDuan(StringUtil.isContainChinese(name)));
  291. }
  292. /**
  293. * 判断检查模板是否有重复的
  294. *
  295. * @param name 名称
  296. * @return 返回有没有
  297. */
  298. public ResultVo<Boolean> jianChaJianYanMuBanMing(String name, String reqType) {
  299. return ResultVoUtil.success(dao.huoQuJianChaJianYanChongFuMuBanMing(name, TokenUtil.getTokenUserId(), reqType).size() > 0);
  300. }
  301. /**
  302. * 保存检查或检验模板
  303. *
  304. * @param param 数据
  305. * @return 返回提示
  306. */
  307. @Transactional(rollbackFor = Exception.class)
  308. public ResultVo<String> baoCunJianChaJianYanMuBan(ZyTcYj param) {
  309. if (publicServer.noNeedRule(11)) {
  310. if (param.getOrderType().equals("2")) {
  311. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "您没有权限创建科室模板。");
  312. }
  313. }
  314. // TODO 新增模板的时候要先删除
  315. param.setOpId(TokenUtil.getTokenUserId());
  316. param.setTcNo(publicServer.huoQuJianYanJianChaXuHao().toString());
  317. param.setPyCode(PingYinUtils.pyShouZiMuDaXie(param.getTcName()));
  318. param.setDCode(PingYinUtils.getWBCode(param.getTcName()));
  319. List<String> yuanShuJu = dao.huoQuJianChaJianYanChongFuMuBanMing(param.getTcName(), param.getOpId(), param.getReqType());
  320. if (ListUtil.notBlank(yuanShuJu)) {
  321. for (String s : yuanShuJu) {
  322. dao.shanChuJianChaMuBan(s);
  323. }
  324. }
  325. dao.chaRuJCJYMuBan(param);
  326. dao.chaRuJCJYMuBanNeiRong(param.getList(), param.getTcNo(), param.getReqType().trim());
  327. log.info("模板数据:{}", JSON.toJSONString(param.getList()));
  328. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION);
  329. }
  330. public ResultVo<String> baoCunJianYanJianCha(TianJiaJianChaJianYan param) {
  331. log.info("param:{}", JSON.toJSONString(param));
  332. if (ListUtil.isBlank(param.getList())) {
  333. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "请选择需要保存的数据。");
  334. }
  335. XinZhenYiZhu huanZheXinXi = yiZhuLuRuDao.huoQuHuanZheXinXi(param.getInpatientNo(), param.getAdmissTimes());
  336. publicServer.huanZheJieSuan(param.getInpatientNo(), param.getAdmissTimes());
  337. List<String> xm = new ArrayList<>();
  338. int index = 1;
  339. List<String> content = new ArrayList<>();
  340. StringBuilder cuoWuXinXi = new StringBuilder();
  341. for (YshYjReq item : param.getList()) {
  342. if (StringUtil.isBlank(item.getOrderCode())) {
  343. cuoWuXinXi.append(baoCunCuoWuXinXi(index, "项目编码不能为空"));
  344. }
  345. if (StringUtil.isBlank(item.getOrderName())) {
  346. cuoWuXinXi.append(baoCunCuoWuXinXi(index, "项目名称不能为空"));
  347. }
  348. if (item.getStartTime() == null) {
  349. cuoWuXinXi.append(baoCunCuoWuXinXi(index, "检查时间不能为空"));
  350. } else if (DateUtil.shiJianDaXiao(huanZheXinXi.getAdmissDate(), item.getStartTime(), ">")) {
  351. cuoWuXinXi.append(baoCunCuoWuXinXi(index, "检查时间不能在入院时间之前。"));
  352. }
  353. if (StringUtil.isBlank(item.getExecDept())) {
  354. cuoWuXinXi.append(baoCunCuoWuXinXi(index, "执行科室不能为空。"));
  355. }
  356. if (param.getReqType().equals("3")) {
  357. if (StringUtil.isBlank(item.getReqComment())) {
  358. cuoWuXinXi.append(baoCunCuoWuXinXi(index, "病室摘要不能为空。"));
  359. }
  360. if (StringUtil.isBlank(item.getReqTzComment())) {
  361. cuoWuXinXi.append(baoCunCuoWuXinXi(index, "体征信息不能为空。"));
  362. }
  363. if (StringUtil.isBlank(item.getReqOtherResult())) {
  364. cuoWuXinXi.append(baoCunCuoWuXinXi(index, "相关辅检结果不能为空。"));
  365. }
  366. if (StringUtil.isBlank(item.getDiagCode())) {
  367. cuoWuXinXi.append(baoCunCuoWuXinXi(index, "临床诊断不能为空。"));
  368. }
  369. } else {
  370. if (StringUtil.isBlank(item.getInspectStuff())) {
  371. cuoWuXinXi.append(baoCunCuoWuXinXi(index, "标本不能为空。"));
  372. }
  373. }
  374. if (cuoWuXinXi.length() > 0) {
  375. cuoWuXinXi.append("<br>");
  376. } else {
  377. item.setActOrderNo(BigDecimal.valueOf(publicServer.getActOrderNo()));
  378. item.setReqNo(publicServer.getReqPageNo());
  379. }
  380. xm.add(item.getOrderCode().trim());
  381. content.add(String.format("%s:<span style='color:#409eff'>【%s】</span><br>" +
  382. "患者姓名:<span style='color:#409eff'>【%s】</span><br>" +
  383. "床位:<span style='color:#409eff'>【%s】</span>", param.getReqType().equals("2") ? "检查名" : "检验名", item.getOrderName(), huanZheXinXi.getName(), huanZheXinXi.getBedNo()));
  384. index++;
  385. }
  386. String tingYong = publicServer.xiangMuXianZhi(xm, true);
  387. if (StringUtil.notBlank(tingYong)) {
  388. throw new BizException(ExceptionEnum.LOGICAL_HTML_ERROR, tingYong);
  389. }
  390. if (StringUtil.notBlank(cuoWuXinXi.toString())) {
  391. throw new BizException(ExceptionEnum.LOGICAL_HTML_ERROR, String.valueOf(cuoWuXinXi));
  392. }
  393. String userCode = TokenUtil.getTokenUserId();
  394. dao.chaRuShenQing(param.getList(), param.getInpatientNo(), param.getName(), param.getAge() + "岁", param.getAdmissTimes(),
  395. param.getBedNo(), userCode, huanZheXinXi.getDeptCode(), huanZheXinXi.getDeptCode(), param.getReqType());
  396. dao.chaRuShenQingYiZhu(param.getList(), param.getInpatientNo(), param.getAdmissTimes(), userCode, huanZheXinXi.getDeptCode(), huanZheXinXi.getDeptCode(),
  397. publicServer.getInfantFlag(param.getInpatientNo()));
  398. publicServer.faSongXiaoXi(huanZheXinXi, content, param.getReqType().equals("2") ? "新增检查" : "新增检验", TokenUtil.getTokenUserId());
  399. log.info("数据:{}", param.getList());
  400. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION);
  401. }
  402. public String baoCunCuoWuXinXi(int index, String xinXi) {
  403. return String.format("第【%d】行%s<br>", index, xinXi);
  404. }
  405. /*-------------------------------------------------------------- 下面是检验的逻辑 -----------------------------------------------------------------------------------------------------*/
  406. public ResultVo<IPage<YshYjReq>> huoQuJianYan(ChaXunJianChaHeJianYan param) {
  407. IPage<YshYjReq> page = new Page<>(param.getCurrentPage(), param.getPageSize(), param.getTotal() == 0);
  408. page = dao.huoQuJianYan(page, param.getPatNo(), param.getTimes(), param.getStartTime(), param.getEndTime(), param.getOrderName());
  409. return ResultVoUtil.success(page);
  410. }
  411. public ResultVo<IPage<JcZdClass>> huoQuJianYanMing(long total, long currentPage, Integer leiXing) {
  412. IPage<JcZdClass> page = new Page<>(currentPage, 20, total == 0);
  413. if (leiXing == 1) {
  414. page = dao.jianYanFenLei(page);
  415. return ResultVoUtil.success(page);
  416. }
  417. return ResultVoUtil.success();
  418. }
  419. public ResultVo<List<GetDropdownBox>> biaoBenShuJu(String name) {
  420. return ResultVoUtil.success(dao.biaoBenLeiXing(StringUtil.isContainChinese(name)));
  421. }
  422. public ResultVo<String> shanChuJianChaJianYan(Integer reqNo, String patNo, Integer times) {
  423. if (StringUtil.isBlank(patNo)) {
  424. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "住院号不能为空。");
  425. }
  426. YshYjReq yj = dao.huoQuJianYanJianCha(reqNo, patNo, times);
  427. if (yj == null) {
  428. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "没有查询到该数据的具体信息,已经被删除了。");
  429. }
  430. if (yj.getReceiveFlag().trim().equals("2")) {
  431. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "结果已返回,无法删除。");
  432. }
  433. dao.shanChuJianYanJianCha(reqNo, patNo, times);
  434. dao.shanChuYiZhu(yj.getActOrderNo());
  435. log.info("删除医技申请==》操作人:{},医技数据:{}", TokenUtil.getTokenUserId(), JSON.toJSONString(yj));
  436. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION);
  437. }
  438. }