CaoYaoYiZhuServer.java 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  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.springframework.stereotype.Service;
  8. import org.springframework.transaction.annotation.Transactional;
  9. import thyyxxk.webserver.config.exception.ExceptionEnum;
  10. import thyyxxk.webserver.constants.GetDateFormat;
  11. import thyyxxk.webserver.dao.his.zhuyuanyisheng.CaoYaoYiZhuDao;
  12. import thyyxxk.webserver.dao.his.zhuyuanyisheng.YiZhuLuRuDao;
  13. import thyyxxk.webserver.entity.ResultVo;
  14. import thyyxxk.webserver.entity.datamodify.GetDropdownBox;
  15. import thyyxxk.webserver.entity.zhuyuanyisheng.caoyaoyizhu.CaoYaoChaXunTiaoJian;
  16. import thyyxxk.webserver.entity.zhuyuanyisheng.caoyaoyizhu.YzActOrderCy;
  17. import thyyxxk.webserver.entity.zhuyuanyisheng.caoyaoyizhu.YzActOrderCyDetail;
  18. import thyyxxk.webserver.entity.zhuyuanyisheng.caoyaoyizhu.YzOrderPatternCy;
  19. import thyyxxk.webserver.entity.zhuyuanyisheng.yizhuluru.XinZhenYiZhu;
  20. import thyyxxk.webserver.entity.zhuyuanyisheng.yizhuluru.YiZhuMingChen;
  21. import thyyxxk.webserver.service.PublicServer;
  22. import thyyxxk.webserver.utils.*;
  23. import java.math.BigDecimal;
  24. import java.util.ArrayList;
  25. import java.util.Date;
  26. import java.util.List;
  27. /**
  28. * <p>
  29. * 描述:
  30. * </p>
  31. *
  32. * @author xc
  33. * @date 2022-02-26 08:39
  34. */
  35. @Service
  36. @Slf4j
  37. public class CaoYaoYiZhuServer {
  38. private final CaoYaoYiZhuDao dao;
  39. private final PublicServer publicServer;
  40. private final YiZhuLuRuDao yiZhuLuRuDao;
  41. public CaoYaoYiZhuServer(CaoYaoYiZhuDao dao, PublicServer publicServer, YiZhuLuRuDao yiZhuLuRuDao) {
  42. this.dao = dao;
  43. this.publicServer = publicServer;
  44. this.yiZhuLuRuDao = yiZhuLuRuDao;
  45. }
  46. public ResultVo<IPage<YzActOrderCy>> huoQuCaoYaoShuJu(CaoYaoChaXunTiaoJian param) {
  47. IPage<YzActOrderCy> page = new Page<>(param.getCurrentPage(), param.getPageSize(), param.getTotal() == 0);
  48. QueryWrapper<?> qw = new QueryWrapper<>();
  49. qw.eq("inpatient_no", param.getPatNo());
  50. qw.eq("admiss_times", param.getTimes());
  51. if (param.getShiFouFaYao()) {
  52. qw.eq("status_flag", "4");
  53. } else {
  54. qw.le("status_flag", "3");
  55. }
  56. if (StringUtil.notBlank(param.getStartTime())) {
  57. qw.ge("input_date", param.getStartTime());
  58. qw.le("input_date", param.getEndTime());
  59. }
  60. dao.huoQuCaoYaoShuJu(page, qw);
  61. for (YzActOrderCy item : page.getRecords()) {
  62. item.setDaiJianFei(item.getQuantityDj().multiply(item.getOrderJeDj()));
  63. item.setJiaGe(item.getQuantity().multiply(item.getOrderJe()));
  64. item.setZongJia(item.getDaiJianFei().add(item.getJiaGe()));
  65. }
  66. return ResultVoUtil.success(page);
  67. }
  68. public ResultVo<List<YzActOrderCyDetail>> huoQuChaoYaoMingXi(BigDecimal orderNo) {
  69. return ResultVoUtil.success(dao.huoQuChaoYaoMingXi(orderNo));
  70. }
  71. public ResultVo<List<GetDropdownBox>> fuYongFangFa() {
  72. return ResultVoUtil.success(dao.fuYongFangFa());
  73. }
  74. public ResultVo<IPage<YiZhuMingChen>> huoQuCaoYao(String queryName, Integer groupNo, long currentPage, long pageSize, long total) {
  75. IPage<YiZhuMingChen> page = new Page<>(currentPage, pageSize, total == 0);
  76. String name = StringUtil.EnglishToCapital(queryName);
  77. QueryWrapper<?> qw = new QueryWrapper<>();
  78. qw.and(QueryWrapper -> QueryWrapper
  79. .like("py_code", name)
  80. .or()
  81. .like("name", name)
  82. .or()
  83. .like("d_code", name)
  84. .or()
  85. .like("code", name)
  86. )
  87. .eq("group_no", groupNo);
  88. dao.huoQuCaoYao(page, qw);
  89. return ResultVoUtil.success(page);
  90. }
  91. public ResultVo<IPage<YzOrderPatternCy>> huoQuMuBan(String queryName, String deptCode, long currentPage, long pageSize, long total) {
  92. IPage<YzOrderPatternCy> page = new Page<>(currentPage, pageSize, total == 0);
  93. String name = StringUtil.EnglishToCapital(queryName);
  94. QueryWrapper<?> qw = new QueryWrapper<>();
  95. qw.and(QueryWrapper -> QueryWrapper
  96. .like("py_code", name)
  97. .or()
  98. .like("d_code", name)
  99. .or()
  100. .like("pattern_name", name)
  101. );
  102. if (publicServer.noNeedRule(1, 38)) {
  103. qw.eq("dept_code", deptCode);
  104. }
  105. qw.groupBy("pattern_name");
  106. dao.huoQuMuBan(page, qw);
  107. return ResultVoUtil.success(page);
  108. }
  109. public ResultVo<List<YzOrderPatternCy>> muBanXiangQing(String name, String deptCode) {
  110. return ResultVoUtil.success(dao.muBanXiangQing(name, deptCode));
  111. }
  112. public ResultVo<Boolean> chongFuMuBanMing(String name) {
  113. return ResultVoUtil.success(dao.chongFuMuBanMing(name) > 1);
  114. }
  115. public ResultVo<String> cunMuBan(YzOrderPatternCy param) {
  116. log.info("插入模板草药模板:{}", JSON.toJSONString(param));
  117. dao.chaRuMuBan(param.getList(), param.getPatternName(), TokenUtil.getTokenUserId(),
  118. PingYinUtils.pyShouZiMuDaXie(param.getPatternName()), PingYinUtils.getWBCode(param.getPatternName()),
  119. param.getDeptCode());
  120. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION);
  121. }
  122. @Transactional(rollbackFor = Exception.class)
  123. public ResultVo<String> baoCunCaoYao(YzActOrderCy param) {
  124. log.info("上传的数据:{}", JSON.toJSONString(param));
  125. if (ListUtil.isBlank(param.getList())) {
  126. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "请先选择需要上传的数据。");
  127. }
  128. publicServer.huanZheJieSuan(param.getInpatientNo(), param.getAdmissTimes());
  129. BigDecimal sum = new BigDecimal(0);
  130. for (YzActOrderCyDetail item : param.getList()) {
  131. sum = sum.add(item.getQuantity().multiply(item.getRetprice()));
  132. }
  133. param.setOrderJe(sum);
  134. param.setInputId(TokenUtil.getTokenUserId());
  135. param.setOrderJeDj(dao.huoQuDaiJianFei());
  136. param.setPageNo(Integer.valueOf(DateUtil.formatDatetime(new Date(), "yyMMdd") + publicServer.huoQuCaoYaoShenQingDanHao()));
  137. XinZhenYiZhu huanZheXinXi = yiZhuLuRuDao.huoQuHuanZheXinXi(param.getInpatientNo(), param.getAdmissTimes());
  138. param.setOrderNo(BigDecimal.valueOf(publicServer.getActOrderNo()));
  139. dao.chaRuCaoYaoYiZhu(param, huanZheXinXi.getDeptCode(), huanZheXinXi.getDeptCode(), huanZheXinXi.getSmallDept());
  140. dao.chaRuCaoYaoXiangQing(param.getList(), param.getOrderNo());
  141. dao.chaRuYiZhu(param, "草药医嘱:" + param.getOrderName() + param.getQuantity() + "剂", huanZheXinXi.getDeptCode(), huanZheXinXi.getDeptCode(), huanZheXinXi.getSmallDept(), publicServer.getInfantFlag(huanZheXinXi.getInpatientNo()));
  142. List<String> content = new ArrayList<>();
  143. content.add(String.format("草药医嘱名:<span style='color:#409eff'>【%s】</span><br>" +
  144. "剂数:<span style='color:#409eff'>【%s】</span><br>" +
  145. "患者名:<span style='color:#409eff'>【%s】<br></span>" +
  146. "床位:<span style='color:#409eff'>【%s】</span>", param.getOrderName(), param.getQuantity().toString(), huanZheXinXi.getName(), huanZheXinXi.getBedNo()));
  147. publicServer.faSongXiaoXi(huanZheXinXi, content, "新增草药医嘱", TokenUtil.getTokenUserId());
  148. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION);
  149. }
  150. public ResultVo<String> shanChuMuBan(String name, String deptCode) {
  151. YzOrderPatternCy mb = dao.caoYaoMuBanXiangQing(name);
  152. List<Integer> rolse = publicServer.getRoleCode().getData();
  153. boolean flag;
  154. if (publicServer.noNeedRule(rolse, 1, 38)) {
  155. flag = mb.getCreateId().equals(TokenUtil.getTokenUserId());
  156. if (!publicServer.noNeedRule(rolse, 11)) {
  157. flag = mb.getDeptCode().trim().equals(deptCode);
  158. }
  159. } else {
  160. flag = true;
  161. }
  162. if (flag) {
  163. dao.shanChuMuBan(name);
  164. return ResultVoUtil.success();
  165. } else {
  166. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "您没有权限删除。");
  167. }
  168. }
  169. public ResultVo<String> shanChuCaoYao(String patNo, Integer times, BigDecimal orderNo) {
  170. YzActOrderCy cy = dao.caoYaoXinXi(patNo, times, orderNo);
  171. if (cy == null) {
  172. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "没有查询到原来的信息。");
  173. }
  174. if (!cy.getStatusFlag().trim().equals("1")) {
  175. return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "该草药无法删除。");
  176. }
  177. log.info("删除草药==》操作人:{},数据:{}", TokenUtil.getTokenUserId(), JSON.toJSONStringWithDateFormat(cy, GetDateFormat.DATE_TIME));
  178. dao.genXingCaoYaoShanChuBiaoZhi(patNo, times, orderNo);
  179. return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION);
  180. }
  181. }