CaoYaoYiZhuService.java 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283
  1. package thyyxxk.webserver.service.zhuyuanyisheng;
  2. import com.alibaba.fastjson.JSON;
  3. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  4. import com.baomidou.mybatisplus.core.metadata.IPage;
  5. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  6. import lombok.extern.slf4j.Slf4j;
  7. import org.jetbrains.annotations.NotNull;
  8. import org.springframework.stereotype.Service;
  9. import thyyxxk.webserver.config.exception.ExceptionEnum;
  10. import thyyxxk.webserver.constants.GetDateFormat;
  11. import thyyxxk.webserver.dao.his.inpatient.XiangMuLuRuDao;
  12. import thyyxxk.webserver.dao.his.zhuyuanyisheng.CaoYaoYiZhuDao;
  13. import thyyxxk.webserver.dao.his.zhuyuanyisheng.YiZhuLuRuDao;
  14. import thyyxxk.webserver.entity.ResultVo;
  15. import thyyxxk.webserver.entity.datamodify.GetDropdownBox;
  16. import thyyxxk.webserver.entity.zhuyuanyisheng.caoyaoyizhu.CaoYaoChaXunTiaoJian;
  17. import thyyxxk.webserver.entity.zhuyuanyisheng.caoyaoyizhu.YzActOrderCy;
  18. import thyyxxk.webserver.entity.zhuyuanyisheng.caoyaoyizhu.YzActOrderCyDetail;
  19. import thyyxxk.webserver.entity.zhuyuanyisheng.caoyaoyizhu.YzOrderPatternCy;
  20. import thyyxxk.webserver.entity.zhuyuanyisheng.yizhuluru.XinZhenYiZhu;
  21. import thyyxxk.webserver.entity.zhuyuanyisheng.yizhuluru.XinZhenYzActOrder;
  22. import thyyxxk.webserver.entity.zhuyuanyisheng.yizhuluru.YiZhuMingChen;
  23. import thyyxxk.webserver.service.PublicServer;
  24. import thyyxxk.webserver.service.hospitalizationCosts.HospitalizationCostsService;
  25. import thyyxxk.webserver.utils.*;
  26. import java.math.BigDecimal;
  27. import java.util.*;
  28. /**
  29. * <p>
  30. * 描述:
  31. * </p>
  32. *
  33. * @author xc
  34. * @date 2022-02-26 08:39
  35. */
  36. @Service
  37. @Slf4j
  38. public class CaoYaoYiZhuService {
  39. private final CaoYaoYiZhuDao dao;
  40. private final PublicServer publicServer;
  41. private final YiZhuLuRuDao yiZhuLuRuDao;
  42. private final YiZhuLuRuServer yiZhuLuRuServer;
  43. private final XiangMuLuRuDao xiangMuLuRuDao;
  44. private final HospitalizationCostsService hospitalizationCostsService;
  45. public CaoYaoYiZhuService(CaoYaoYiZhuDao dao, PublicServer publicServer, YiZhuLuRuDao yiZhuLuRuDao, YiZhuLuRuServer yiZhuLuRuServer, XiangMuLuRuDao xiangMuLuRuDao, HospitalizationCostsService hospitalizationCostsService) {
  46. this.dao = dao;
  47. this.publicServer = publicServer;
  48. this.yiZhuLuRuDao = yiZhuLuRuDao;
  49. this.yiZhuLuRuServer = yiZhuLuRuServer;
  50. this.xiangMuLuRuDao = xiangMuLuRuDao;
  51. this.hospitalizationCostsService = hospitalizationCostsService;
  52. }
  53. public ResultVo<List<YzActOrderCy>> huoQuCaoYaoShuJu(CaoYaoChaXunTiaoJian param) {
  54. QueryWrapper<?> qw = new QueryWrapper<>();
  55. qw.eq("inpatient_no", param.getPatNo());
  56. qw.eq("admiss_times", param.getTimes());
  57. qw.orderByDesc("input_date");
  58. if (StringUtil.notBlank(param.getStartTime())) {
  59. qw.ge("input_date", param.getStartTime());
  60. qw.le("input_date", param.getEndTime());
  61. }
  62. List<YzActOrderCy> list = dao.huoQuCaoYaoShuJu(qw);
  63. if (ListUtil.notBlank(list)) {
  64. for (YzActOrderCy item : list) {
  65. item.setDaiJianFei(item.getQuantityDj().multiply(item.getOrderJeDj()));
  66. item.setJiaGe(item.getQuantity().multiply(item.getOrderJe()));
  67. item.setZongJia(item.getDaiJianFei().add(item.getJiaGe()));
  68. }
  69. }
  70. return ResultVoUtil.success(list);
  71. }
  72. public ResultVo<List<YzActOrderCyDetail>> huoQuChaoYaoMingXi(BigDecimal orderNo) {
  73. return ResultVoUtil.success(dao.huoQuChaoYaoMingXi(orderNo));
  74. }
  75. public ResultVo<List<GetDropdownBox>> fuYongFangFa() {
  76. return ResultVoUtil.success(dao.fuYongFangFa());
  77. }
  78. public ResultVo<List<YiZhuMingChen>> huoQuCaoYao(String queryName, Integer groupNo) {
  79. String name = StringUtil.englishToCapital(queryName);
  80. QueryWrapper<?> qw = new QueryWrapper<>();
  81. qw.and(q -> q
  82. .like("py_code", name)
  83. .or()
  84. .like("name", name)
  85. .or()
  86. .like("d_code", name)
  87. .or()
  88. .like("code", name)
  89. )
  90. .eq("group_no", groupNo);
  91. return ResultVoUtil.success(dao.huoQuCaoYao(qw));
  92. }
  93. public ResultVo<IPage<YzOrderPatternCy>> huoQuMuBan(String queryName, String deptCode, long currentPage, long pageSize, long total) {
  94. IPage<YzOrderPatternCy> page = new Page<>(currentPage, pageSize, total == 0);
  95. String name = StringUtil.englishToCapital(queryName);
  96. QueryWrapper<?> qw = new QueryWrapper<>();
  97. qw.and(q -> q
  98. .like("py_code", name)
  99. .or()
  100. .like("d_code", name)
  101. .or()
  102. .like("pattern_name", name)
  103. );
  104. if (publicServer.noNeedRule(38)) {
  105. if (StringUtil.notBlank(deptCode)) {
  106. qw.eq("dept_code", deptCode);
  107. }
  108. }
  109. qw.groupBy("pattern_name");
  110. dao.huoQuMuBan(page, qw);
  111. return ResultVoUtil.success(page);
  112. }
  113. public ResultVo<List<YzOrderPatternCy>> muBanXiangQing(String name, String deptCode) {
  114. return ResultVoUtil.success(dao.muBanXiangQing(name, deptCode));
  115. }
  116. public ResultVo<Boolean> chongFuMuBanMing(String name) {
  117. return ResultVoUtil.success(dao.chongFuMuBanMing(name) > 1);
  118. }
  119. public ResultVo<String> cunMuBan(YzOrderPatternCy param) {
  120. log.info("插入模板草药模板:{}", JSON.toJSONString(param));
  121. String py = PingYinUtils.pyShouZiMuDaXie(param.getPatternName());
  122. if (py.length() > 7) {
  123. py = py.substring(0, 7);
  124. }
  125. String wb = PingYinUtils.getWBCode(param.getPatternName());
  126. if (wb.length() > 7) {
  127. wb = wb.substring(0, 7);
  128. }
  129. dao.chaRuMuBan(param.getList(), param.getPatternName(),
  130. TokenUtil.getInstance().getTokenUserId(), py, wb,
  131. param.getDeptCode());
  132. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_EL_MESSAGE);
  133. }
  134. public ResultVo<Map<String, List<String>>> baoCunCaoYao(YzActOrderCy param) {
  135. log.info("上传的数据:{}", JSON.toJSONString(param));
  136. if (ListUtil.isBlank(param.getList())) {
  137. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "请先选择需要上传的数据。");
  138. }
  139. // 药品 code
  140. Set<String> yaoPingCode = new HashSet<>(param.getList().size());
  141. publicServer.huanZheJieSuan(param.getInpatientNo(), param.getAdmissTimes());
  142. BigDecimal sum = new BigDecimal(0);
  143. for (YzActOrderCyDetail item : param.getList()) {
  144. sum = sum.add(item.getQuantity().multiply(item.getRetprice()));
  145. yaoPingCode.add(item.getChargeCode().trim() + item.getSerial().trim() + item.getGroupNo().trim());
  146. }
  147. XinZhenYiZhu patInfo = yiZhuLuRuDao.queryPatientInfo(param.getInpatientNo(), param.getAdmissTimes());
  148. Map<String, XinZhenYzActOrder> drug = yiZhuLuRuServer.getDrugInformation(yaoPingCode, patInfo.getZkWard());
  149. // 错误信息
  150. Map<String, List<String>> errorMap = new HashMap<>(param.getList().size());
  151. // 获取医生开药品的权限
  152. Integer doctorLevel = yiZhuLuRuDao.huoQuYiShenDengJi(TokenUtil.getInstance().getTokenUserId());
  153. for (int i = 0; i < param.getList().size(); i++) {
  154. YzActOrderCyDetail item = param.getList().get(i);
  155. XinZhenYzActOrder feiYongXinXi = drug.get(item.getChargeCode().trim() + item.getSerial().trim() + item.getGroupNo().trim());
  156. List<String> errorMessage = limitation(feiYongXinXi, doctorLevel, item);
  157. if (ListUtil.notBlank(errorMessage)) {
  158. errorMap.put("第" + (i + 1) + "个,名称:" + item.getChargeCodeName(), errorMessage);
  159. }
  160. }
  161. if (!errorMap.isEmpty()) {
  162. return ResultVoUtil.fail(ExceptionEnum.ERROR_MESSAGE, "请修改有错误的数据。", errorMap);
  163. }
  164. param.setOrderJe(sum);
  165. param.setInputId(TokenUtil.getInstance().getTokenUserId());
  166. // 设置代煎费
  167. param.setOrderJeDj(dao.huoQuDaiJianFei());
  168. param.setPageNo(publicServer.getTheDrugListNo());
  169. XinZhenYiZhu huanZheXinXi = yiZhuLuRuDao.queryPatientInfo(param.getInpatientNo(), param.getAdmissTimes());
  170. param.setOrderNo(publicServer.getActOrderNo());
  171. // 生成草药和医嘱
  172. generateHerbs(param, huanZheXinXi);
  173. List<String> content = new ArrayList<>();
  174. content.add(String.format("草药医嘱名:<span style='color:#409eff'>【%s】</span><br>" +
  175. "剂数:<span style='color:#409eff'>【%s】</span><br>" +
  176. "患者名:<span style='color:#409eff'>【%s】<br></span>" +
  177. "床位:<span style='color:#409eff'>【%s】</span>", param.getOrderName(), param.getQuantity().toString(), huanZheXinXi.getName(), huanZheXinXi.getBedNo()));
  178. publicServer.faSongXiaoXi(huanZheXinXi, content, "新增草药或颗粒医嘱", TokenUtil.getInstance().getTokenUserId());
  179. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_EL_MESSAGE);
  180. }
  181. public void generateHerbs(YzActOrderCy param, XinZhenYiZhu huanZheXinXi) {
  182. dao.chaRuCaoYaoYiZhu(param, huanZheXinXi.getDeptCode(), huanZheXinXi.getDeptCode(), param.getExecDept());
  183. dao.chaRuCaoYaoXiangQing(param.getList(), param.getOrderNo());
  184. String orderName = param.getGroupNo().equals("81") ? "草药医嘱:" : "草药颗粒医嘱:" + param.getOrderName() + param.getQuantity() + "剂";
  185. dao.chaRuYiZhu(param, orderName,
  186. huanZheXinXi.getDeptCode(),
  187. huanZheXinXi.getDeptCode(),
  188. param.getExecDept(),
  189. PublicServer.getInfantFlag(huanZheXinXi.getInpatientNo()));
  190. }
  191. @NotNull
  192. private static List<String> limitation(XinZhenYzActOrder feiYongXinXi, Integer doctorLevel, YzActOrderCyDetail item) {
  193. List<String> errorMessage = new ArrayList<>();
  194. if (feiYongXinXi == null) {
  195. errorMessage.add("没有找到药品信息,请联系药剂药房。");
  196. } else {
  197. if (feiYongXinXi.getDelFlag() == 1) {
  198. errorMessage.add("药品已经被停用了,请联系药剂科");
  199. }
  200. if (feiYongXinXi.getYpLevel() > doctorLevel) {
  201. errorMessage.add("您没有开此药品的权限");
  202. }
  203. if (BigUtils.bigDaYu(item.getQuantity(), feiYongXinXi.getStockAmount())) {
  204. errorMessage.add("药品领量大于药品的库存,当前库存量" + feiYongXinXi.getStockAmount().stripTrailingZeros().toPlainString());
  205. }
  206. if (feiYongXinXi.getDeptRestrictions() > 0) {
  207. errorMessage.add("该药品禁止在患者所在的科室使用。");
  208. }
  209. if (feiYongXinXi.getVisibleFlagZy() == 1) {
  210. errorMessage.add("该药品禁止住院患者使用。");
  211. }
  212. }
  213. return errorMessage;
  214. }
  215. /**
  216. * 删除草药模板
  217. * 管理员和有医嘱模板编辑,权限的可以直接删除
  218. * 科室主任有权限删除本科室的模板
  219. *
  220. * @param name 模板名称
  221. * @param deptCode 科室编码
  222. * @return 返回提示
  223. */
  224. public ResultVo<String> shanChuMuBan(String name, String deptCode) {
  225. YzOrderPatternCy mb = dao.caoYaoMuBanXiangQing(name);
  226. // 如果有这个权限直接删除
  227. if (publicServer.needRule(YiZhuPublicService.MU_BAN_BIAN_JI_QUAN_XIAN)) {
  228. // 本人创建的也可以直接删除
  229. if (mb.getCreateId().equals(TokenUtil.getInstance().getTokenUserId())) {
  230. return shanChuCaoYaoMuBan(name);
  231. }
  232. // 科主任 可以删除自己科室的模板
  233. if (publicServer.needRule(YiZhuPublicService.KE_ZHU_REN_BIAN_MA)) {
  234. if (mb.getDeptCode().trim().equals(deptCode)) {
  235. return shanChuCaoYaoMuBan(name);
  236. }
  237. }
  238. } else {
  239. return shanChuCaoYaoMuBan(name);
  240. }
  241. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "您没有权限删除。");
  242. }
  243. private ResultVo<String> shanChuCaoYaoMuBan(String name) {
  244. dao.shanChuMuBan(name);
  245. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_EL_MESSAGE);
  246. }
  247. public ResultVo<String> shanChuCaoYao(String patNo, Integer times, BigDecimal orderNo) {
  248. YzActOrderCy cy = dao.caoYaoXinXi(patNo, times, orderNo);
  249. if (cy == null) {
  250. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "没有查询到原来的信息。");
  251. }
  252. log.info("删除草药==》操作人:{},数据:{}", TokenUtil.getInstance().getTokenUserId(), JSON.toJSONStringWithDateFormat(cy, GetDateFormat.DATE_TIME));
  253. dao.genXingCaoYaoShanChuBiaoZhi(patNo, times, orderNo);
  254. dao.shanChuYiZhu(orderNo);
  255. // 根据医嘱号退费
  256. hospitalizationCostsService.refundsByPatientOrder(cy.getInpatientNo(), cy.getAdmissTimes(), cy.getOrderNo());
  257. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_EL_MESSAGE);
  258. }
  259. }