package thyyxxk.webserver.service; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; import com.baomidou.dynamic.datasource.annotation.DS; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import lombok.extern.slf4j.Slf4j; import org.apache.commons.collections4.ListUtils; import org.jetbrains.annotations.NotNull; import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Isolation; import org.springframework.transaction.annotation.Propagation; import org.springframework.transaction.annotation.Transactional; import thyyxxk.webserver.config.exception.BizException; import thyyxxk.webserver.config.exception.ExceptionEnum; import thyyxxk.webserver.constants.Capacity; import thyyxxk.webserver.constants.Message; import thyyxxk.webserver.constants.RestrictedDrugLevels; import thyyxxk.webserver.constants.Ysjb; import thyyxxk.webserver.dao.his.PublicDao; import thyyxxk.webserver.dao.his.inpatient.TransferInOfExpensesDao; import thyyxxk.webserver.dao.his.settings.SettingsDao; import thyyxxk.webserver.entity.ResultVo; import thyyxxk.webserver.entity.casefrontsheet.YshHzRecord; import thyyxxk.webserver.entity.datamodify.GetDropdownBox; import thyyxxk.webserver.entity.datamodify.ZyDetailCharge; import thyyxxk.webserver.entity.dictionary.CodeName; import thyyxxk.webserver.entity.inpatient.ZyActpatient; import thyyxxk.webserver.entity.login.UserInfo; import thyyxxk.webserver.entity.publicapi.ZkList; import thyyxxk.webserver.entity.settings.notification.SendMessageParam; import thyyxxk.webserver.entity.socketmessage.SocketMessage; import thyyxxk.webserver.entity.zhuyuanyisheng.PatientAllergenInfo; import thyyxxk.webserver.entity.zhuyuanyisheng.caoyaoyizhu.YzActOrderCy; import thyyxxk.webserver.entity.zhuyuanyisheng.jianyanjiancha.YshYjReq; import thyyxxk.webserver.entity.zhuyuanyisheng.shoushu.OpRecord; import thyyxxk.webserver.entity.zhuyuanyisheng.yizhuluru.XinZhenYiZhu; import thyyxxk.webserver.entity.zhuyuanyisheng.yizhuluru.YaoPinXiangMu; import thyyxxk.webserver.service.redislike.RedisLikeService; import thyyxxk.webserver.utils.*; import thyyxxk.webserver.websocket.WebSocketServer; import java.lang.reflect.InvocationTargetException; import java.math.BigDecimal; import java.util.ArrayList; import java.util.Collections; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.stream.Collectors; import java.util.stream.Stream; /** *

* 描述: 公共接口 *

* * @author xc * @date 2021-09-17 10:54 */ @Service @Slf4j public class PublicServer { private final PublicDao dao; private final TransferInOfExpensesDao transferInOfExpensesDao; private final RedisLikeService redisLikeService; private final SettingsDao settingsDao; public PublicServer(PublicDao dao, TransferInOfExpensesDao transferInOfExpensesDao, RedisLikeService redisLikeService, SettingsDao settingsDao) { this.dao = dao; this.transferInOfExpensesDao = transferInOfExpensesDao; this.redisLikeService = redisLikeService; this.settingsDao = settingsDao; } /** * 手术日期格式 * * @param opStartDate 手术开始时间 * @param opEndDate 手术结束时间 * @param anstStartDate 麻醉开始时间 * @param anstEndDate 麻醉结束时间 */ public static void surgeryTimeLimit(String opName, Date opStartDate, Date opEndDate, Date anstStartDate, Date anstEndDate) { if (anstStartDate != null) { if (DateUtil.shiJianDaXiao(opStartDate, anstStartDate, "<")) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, opName + ":麻醉开始时间要大于手术开始时间."); } long opDate = opEndDate.getTime() - opStartDate.getTime(); long anstDate = anstEndDate.getTime() - anstStartDate.getTime(); if (opDate >= anstDate) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, opName + ":手术麻醉时间一定要比手术时间长."); } } } /** * 获取用户的角色信息 * * @return 返回角色 */ public ResultVo> getRoleCode() { return ResultVoUtil.success(redisLikeService.getUserInfoByToken().getRoles()); } /** * @param jueSeBianMa 不需要限制的角色id * @return Boolean */ public Boolean noNeedRule(int... jueSeBianMa) { return getaBoolean(jueSeBianMa, getRoleCode().getData()); } /** * @param jueSeBianMa 不需要限制的角色id * @return Boolean */ public Boolean noNeedRule(List role, int... jueSeBianMa) { return getaBoolean(jueSeBianMa, role); } /** * @param jueSeBianMa 不需要限制的角色id * @return Boolean 如果有就返回true */ public Boolean needRule(int... jueSeBianMa) { return !getaBoolean(jueSeBianMa, getRoleCode().getData()); } /** * @param jueSeBianMa 不需要限制的角色id * @return Boolean */ public Boolean needRule(List role, int... jueSeBianMa) { return !getaBoolean(jueSeBianMa, role); } public Boolean getaBoolean(int[] jueSeBianMa, List roleCode) { if (ListUtil.isBlank(roleCode)) { return true; } if (roleCode.contains(1)) { return false; } for (Integer i : jueSeBianMa) { if (roleCode.contains(i)) { return false; } } return true; } /** * 获取新的医嘱号 * * @return 返回医嘱号 */ @Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.DEFAULT, timeout = 36000, rollbackFor = Exception.class) public BigDecimal getActOrderNo() { BigDecimal oldId = dao.getActOrderNo(); BigDecimal newId = oldId.add(BigDecimal.ONE); int num = dao.updateActOrderNo(newId, oldId); if (num == 0) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "生成医嘱号错误,请重试!"); } return newId; } /** * 获取模板的编码 * * @return 返回编码信息 */ @Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.DEFAULT, timeout = 36000, rollbackFor = Exception.class) public String getPatternCode() { Integer oldId = dao.getPatternCode(); Integer newId = oldId + 1; int num = dao.updatePatternCode(newId, oldId); if (num == 0) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "生成模板编码错误,请重试!"); } return newId.toString(); } /** * 获取医嘱模板下面的 子级 排序号 * * @return 返回序号 */ @Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.DEFAULT, timeout = 36000, rollbackFor = Exception.class) public BigDecimal getPatternOrderCode() { BigDecimal oldId = dao.getPatternOrderCode(); BigDecimal newId = oldId.add(BigDecimal.ONE); int num = dao.updatePatternOrderCode(newId, oldId); if (num == 0) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "生成子医嘱模板编码错误,请重试!"); } return newId; } /** * @return 返回说明模板的编码 */ @Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.DEFAULT, timeout = 36000, rollbackFor = Exception.class) public Integer getYjTemplateNo() { Integer oldId = dao.tempNo(); Integer newId = oldId + 1; int num = dao.updateTempNo(newId, oldId); if (num == 0) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "生成说明模板的编码错误,请重试!"); } return newId; } /** * @return 返回申请号 */ public Integer getReqPageNo() { Integer oldId = dao.getReqNo(); Integer newId = oldId + 1; int num = dao.updateReqNo(newId, oldId); if (num == 0) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "生成申请号错误,请重试!"); } return newId; } /** * 获取药品单号 * * @return 药品单号 */ public Integer getTheDrugListNo() { Integer oldId = dao.caoYaoDanHao(); Integer newId = oldId + 1; int num = dao.genXingCaoYaoDanHao(newId, oldId); if (num == 0) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "生成申请号错误,请重试!"); } return Integer.valueOf(DateUtil.formatDatetime(new Date(), "yyMMdd") + newId); } /** * @param inpatientNo 住院号 * @return 返回婴儿标志 */ public static int getInfantFlag(String inpatientNo) { if (StringUtil.isBlank(inpatientNo)) { return 0; } if (inpatientNo.contains("$")) { return 1; } return 0; } /** * 返回 * * @param inpatientNo 住院号 * @return 返回新住院号 */ public String getInpatientNo(String inpatientNo) { if (StringUtil.isBlank(inpatientNo)) { return ""; } if (inpatientNo.contains("$")) { inpatientNo = inpatientNo.split("\\$")[0]; } return inpatientNo; } /** * 获取最大流水号 * * @param inpatientNo 住院号 * @param admissTimes 住院次数 * @return 返回 流水 */ public Integer getMaxDetailSn(String inpatientNo, Integer admissTimes) { return transferInOfExpensesDao.getMaxDetailSn(inpatientNo, admissTimes); } /** * 获取科室的子科室和本科 * * @param deptCode 科室代码 * @return 返回科室 */ public List getKeShiLieBiaoList(String deptCode) { if (noNeedRule()) { List list = dao.getKeShiLieBiao(deptCode); list.add(deptCode); return list; } return new ArrayList<>(); } /** * 获取科室的子科室和本科 * * @param deptCodeList 科室代码 * @return 返回科室 */ public List getKeShiLieBiaoList(List deptCodeList) { if (ListUtil.isBlank(deptCodeList)) { return new ArrayList<>(); } return dao.getKeShiLieBiaoList(deptCodeList); } /** * 获取人员信息 * * @param code 人员代码 * @return 返回人员 */ public ResultVo> getRenYuan(String code, String deptCode) { return ResultVoUtil.success(dao.getRenYuan(StringUtil.isContainChinese(code), deptCode)); } /** * 搜索项目信息 * * @param pyCode 拼音码 * @return 返回项目信息 */ public ResultVo> getChargeCode(String pyCode) { log.info("获取编码:{}", pyCode); return ResultVoUtil.success(dao.getChargeCode(StringUtil.isContainChinese(pyCode))); } /** * 获取科室信息 * * @return 返回科室 */ public ResultVo> getDept() { return ResultVoUtil.success(dao.getDept()); } public ResultVo> queryDept(String code) { return ResultVoUtil.success(dao.queryDept(StringUtil.isContainChinese(code))); } /** * 获取这个人的账页号 * * @param inpatientNo 住院号 * @param admissTimes 住院次数 * @return 返回有用的账页号 */ public Integer getLedgerSn(String inpatientNo, Integer admissTimes) { if (StringUtil.isBlank(inpatientNo) || admissTimes == null) { return 0; } inpatientNo = getInpatientNo(inpatientNo); return dao.getLedgerSn(inpatientNo, admissTimes); } /** * 更新患者的退费对应的正流水号 * * @param inpatientNo 住院号 * @param admissTimes 住院次数 * @param ledger 账页号 */ public void genXingYuanLiuShuiBiaoZhi(String inpatientNo, Integer admissTimes, Integer ledger) { dao.chongZhiZhenLiuShui(inpatientNo, admissTimes, ledger); // 这里是重置 正流水号 List huoQuTuiFeiYuanLiuShui = dao.huoQuTuiFeiYuanLiuShui(inpatientNo, admissTimes, ledger); if (ListUtil.notBlank(huoQuTuiFeiYuanLiuShui)) { List> fenGeFuLiuShui = ListUtils.partition(huoQuTuiFeiYuanLiuShui, 50); for (List integers : fenGeFuLiuShui) { dao.genXingFuShuDuiYingZhenLiuShui(inpatientNo, admissTimes, ledger, integers); } } // 这里是判断正数的是否没有了,如果正数的没有了 那么负数的就要更新为空 List xuYaoQingKongDeFuLiuShui = new ArrayList<>(); List zhenShuLiuShuiMap = dao.zhenShuLiuShui(inpatientNo, admissTimes, ledger); List fuShuLiuShui = dao.fuShuLiuShui(inpatientNo, admissTimes, ledger); for (Integer integer : fuShuLiuShui) { if (!zhenShuLiuShuiMap.contains(integer) && !xuYaoQingKongDeFuLiuShui.contains(integer)) { xuYaoQingKongDeFuLiuShui.add(integer); } } if (ListUtil.notBlank(xuYaoQingKongDeFuLiuShui)) { List> list = ListUtils.partition(xuYaoQingKongDeFuLiuShui, 50); for (List integers : list) { dao.chongZhiFuShuYuanLiuShui(inpatientNo, admissTimes, ledger, integers); } } // 这里判断是否重复退费,退多了 Map chongFuYuanLiuShuiMap = dao.chongFuTuiFeiLiuShui(inpatientNo, admissTimes, ledger).stream().collect(Collectors.toMap(ZyDetailCharge::getOriDetailSn, a -> a, (k1, k2) -> k1)); if (!chongFuYuanLiuShuiMap.isEmpty()) { List chongFuTuiFeiZhenShu = dao.getZhenShuLiuShui(inpatientNo, admissTimes, ledger, chongFuYuanLiuShuiMap.keySet()); List xuYaoChongZhiLiuShui = new ArrayList<>(); if (ListUtil.notBlank(chongFuTuiFeiZhenShu)) { for (ZyDetailCharge zyDetailCharge : chongFuTuiFeiZhenShu) { ZyDetailCharge zy = chongFuYuanLiuShuiMap.get(zyDetailCharge.getDetailSn()); if (BigUtils.bigXiaoYu(zyDetailCharge.getChargeFee(), zy.getChargeFee().negate())) { xuYaoChongZhiLiuShui.add(zyDetailCharge.getDetailSn()); } } } // 这里更新 if (ListUtil.notBlank(xuYaoChongZhiLiuShui)) { dao.chongFuTuiFeiChongZhi(inpatientNo, admissTimes, ledger, xuYaoChongZhiLiuShui); } } // 这个是判断 trans_flag_yb = 2 费用相加 不为 0 的 就重置一下 if (!BigUtils.dengYu(dao.zhenFuXingDiFeiYong(inpatientNo, admissTimes, ledger), 0)) { dao.chongXingZhengFuXiangDi(inpatientNo, admissTimes, ledger); } } /** * 获取员工信息 * * @param code 编码 * @return 返回 */ public UserInfo huoQuYuanGongXinXi(String code) { if (StringUtil.isBlank(code)) { return new UserInfo(); } return dao.huoQuYuanGongBianMa(code); } public List huoQuBingFangDeKeShi(String deptCode) { if (getRoleCode().getData().contains(1) || getRoleCode().getData().contains(8) || StringUtil.isBlank(deptCode)) { return new ArrayList<>(); } List keShiDaiMa = dao.bingFangSuoSuKeShi(deptCode); if (ListUtil.isBlank(keShiDaiMa)) { keShiDaiMa.add(deptCode); } return keShiDaiMa; } /** * 这里的住院号是没有 处理过得 * * @param inpatientNo 住院号 * @return 返回病人基本信息 */ public ZyActpatient huoQuHuanZheXinXi(String inpatientNo) { if (StringUtil.isBlank(inpatientNo)) { throw new BizException(ExceptionEnum.NULL_POINTER, "住院号为空。"); } ZyActpatient zyActpatient = dao.getHuanZheJiBenXinXi(inpatientNo); log.info("查询患者的信息在院:住院号{}", inpatientNo); if (zyActpatient == null) { throw new BizException(ExceptionEnum.NULL_POINTER, "没有查询到患者的基本信息。"); } zyActpatient.setInfantFlag(getInfantFlag(zyActpatient.getInpatientNo())); zyActpatient.setInpatientNo(getInpatientNo(zyActpatient.getInpatientNo())); return zyActpatient; } /** * 获取麻醉方式 * * @return 返回数据 */ public ResultVo> maZuiFangShi() { return ResultVoUtil.success(dao.maZuiFangShi()); } public Integer huoQuJianYanJianChaXuHao() { dao.jianYanJianChaSuo(); Integer xuHao = dao.jianYanJianChaXuHao() + 1; dao.genXingJianYanJianChaXuHao(xuHao); return xuHao; } public Integer huoQuShouShuHao() { dao.suoZhuShouShu(); Integer index = dao.shouShuXuHao() + 1; dao.genXingShouShuXuHao(index); return index; } public void huanZheJieSuan(String patNo, Integer times) { if (StringUtil.isBlank(patNo) || times == null) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "住院号不能为空。"); } Integer settleType = dao.jieSuanXinXi(patNo, times); if (settleType == null) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "没有查询到患者的信息。"); } if (settleType == 1) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "患者已经结算无法进行操作了。"); } } public void huoQuGaiYiZhuXiaXiangMu(BigDecimal orderNo) { YshHzRecord hz = dao.huiZhen(orderNo); if (hz != null) { if (hz.getStatusFlag().trim().equals("2")) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "该医嘱下的会诊,已经完成无法删除了。"); } return; } YshYjReq yj = dao.yiJi(orderNo); if (yj != null) { if (yj.getReceiveFlag().trim().equals("2")) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, String.format("该医嘱下【%s】,已经完成无法删除了。", yj.getReqType().trim().equals("2") ? "检验" : "检查")); } return; } OpRecord shouShu = dao.shouShu(orderNo); if (shouShu != null) { if (!shouShu.getStatus().trim().equals("1")) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "该医嘱下的手术,无法被删除。"); } return; } YzActOrderCy caoYao = dao.caoYao(orderNo); if (caoYao != null) { if (caoYao.getStatusFlag().trim().equals("4")) { throw new BizException(ExceptionEnum.LOGICAL_ERROR, "该医嘱下的草药已经发药,无法删除。"); } } } /** * 药品限制 * * @param listCode 药品的编码以及规格 做成code * @return 返回提示 */ public String yaoPinXianZhi(List listCode, boolean delFlag) { StringBuilder sb = new StringBuilder(); QueryWrapper qw = new QueryWrapper<>(); qw.in("rtrim(code) + rtrim(serial)", listCode); Map map = dao.huoQuYaoPinPiPeiXinXi(qw).stream().collect(Collectors.toMap(YaoPinXiangMu::getZdCode, a -> a, (k1, k2) -> k1)); return yaoPingXiangMuXianZhi(map, sb, "药品", delFlag); } public String xiangMuXianZhi(List listCode, boolean delFlag) { Map map = dao.huoQuXiangMuXinXi(listCode).stream().collect(Collectors.toMap(YaoPinXiangMu::getZdCode, a -> a, (k1, k2) -> k1)); StringBuilder sb = new StringBuilder(); return yaoPingXiangMuXianZhi(map, sb, "项目", delFlag); } @NotNull public String yaoPingXiangMuXianZhi(Map map, StringBuilder sb, String name, boolean delFlag) { for (YaoPinXiangMu item : map.values()) { if (delFlag && item.getDelFlag() == 1) { sb.append(cuoWuXinXi(item.getZdCode(), "00".equals(item.getSerial().trim()) ? "医嘱名:" + item.getName() + " 项目名:" + item.getZdName() : "" + item.getName(), name + "已被停用")); } if (StringUtil.isBlank(item.getNationalCode()) && !delFlag) { sb.append(cuoWuXinXi(item.getZdCode(), "00".equals(item.getSerial().trim()) ? "医嘱名:" + item.getName() + " 项目名:" + item.getZdName() : "" + item.getName(), name + "没有匹配医保编码")); } } return sb.toString(); } public String cuoWuXinXi(String code, String name, String xinXi) { return "编码:【" + code + "】
" + "名称:【" + name + "】
" + "" + xinXi + "
"; } @Async public void sendDoctorNotification(XinZhenYiZhu huanZheXinXi, String content, String title, String sender, List userCodeList) { sendDoctorNotification(huanZheXinXi, Collections.singletonList(content), title, sender, userCodeList); } /** * @param huanZheXinXi 患者信息 * @param content 内容 * @param title 标题 * @param userCode 发送人id */ public void faSongXiaoXi(XinZhenYiZhu huanZheXinXi, List content, String title, String userCode) { List huShiBianMa = dao.huoQuHuanZheBingFangDeHuShi(huanZheXinXi.getDeptCode()); sendDoctorNotification(huanZheXinXi, content, title, userCode, huShiBianMa); } /** * @param huanZheXinXi 患者信息 * @param content 内容 * @param title 标题 * @param sender 发送人 TokenUtil.getTokenUserId() 不能使用这个因为用的 异步的方法 会导致 okenUtil.getTokenUserId() 为 99999 * @param userCodeList 接收方 */ @Async public void sendDoctorNotification(XinZhenYiZhu huanZheXinXi, List content, String title, String sender, List userCodeList) { int count = content.size(); // 发送通知类 List socketMessage1 = new ArrayList<>(); List socketMessage2 = new ArrayList<>(); for (String s : content) { SocketMessage faSongNeiRong = new SocketMessage(); faSongNeiRong.setSender(sender); faSongNeiRong.setContent(s); // 雪花算法 faSongNeiRong.setId(SnowFlakeId.instance().nextId()); faSongNeiRong.setPatId(huanZheXinXi.getInpatientNo() + "_" + huanZheXinXi.getAdmissTimes()); faSongNeiRong.setTitle(title); socketMessage1.add(faSongNeiRong); for (String huShi : userCodeList) { SocketMessage jieShouFang = new SocketMessage(); jieShouFang.setMsgId(faSongNeiRong.getId()); jieShouFang.setSender(faSongNeiRong.getSender()); jieShouFang.setReceiver(huShi); socketMessage2.add(jieShouFang); } } List> fenGeFaSongFang = ListUtils.partition(socketMessage1, 20); List> fenGeJieShouFang = ListUtils.partition(socketMessage2, 20); for (List item : fenGeFaSongFang) { dao.chaRuTongZhiXinXi(item); } for (List item : fenGeJieShouFang) { dao.chaRuJieShouShuJu(item); } JSONObject json = new JSONObject(); UserInfo userInfo = redisLikeService.getUserInfoByCode(sender); json.put("avatar", userInfo.getAvatar()); json.put("deptName", userInfo.getDeptName()); json.put("name", userInfo.getName()); json.put("msg", "患者:【" + huanZheXinXi.getName() + "】" + "新增数据:" + count + "条"); json.put("title", title); json.put("count", count); userCodeList.forEach(code -> { WebSocketServer.sendMessageByUserCode(code, SocketMsg.socketVo(Message.AVATAR_NOTIFICATION, json)); }); } public ResultVo makePyCode(String tableName, String idColumn, String nameColumn, String pyColumn) { List list = dao.originalList(tableName, idColumn, nameColumn, pyColumn); if (null == list || list.isEmpty()) { return ResultVoUtil.fail(ExceptionEnum.NO_DATA_EXIST, "没有需要更改的数据。"); } for (CodeName item : list) { String pycode = PingYinUtils.pyShouZiMuDaXie(item.getName()); dao.updatePycode(tableName, idColumn, item.getCode(), pyColumn, pycode); log.info("修复:{},{},{}", item.getCode(), item.getName(), pycode); } return ResultVoUtil.success("修复拼音码成功,共修复 " + list.size() + " 条。"); } @DS("his") public ResultVo> getAllergens(String name) { return ResultVoUtil.success(dao.getAllergens(StringUtil.isContainChinese(name))); } public ResultVo> getPatientAllergens(String patNo) { return ResultVoUtil.success(dao.getPatientAllergens(patNo)); } public ResultVo whetherThePatientHasAllergens(String PatNo) { return ResultVoUtil.success(dao.whetherThePatientHasAllergens(PatNo) > 0); } public ResultVo newPatientAllergens(String patNo, String allergenCode, int allergenType) { if (StringUtil.isBlank(patNo)) { return ResultVoUtil.fail(ExceptionEnum.LOGICAL_ERROR, "没有患者住院号"); } PatientAllergenInfo info = new PatientAllergenInfo(); info.setAllergenCode(allergenCode); info.setPatNo(patNo); info.setType(allergenType); dao.newPatientAllergens(info); return ResultVoUtil.success(info.getId()); } public ResultVo removePatientAllergens(Integer id) { dao.removePatientAllergens(id); return ResultVoUtil.success(ExceptionEnum.SUCCESS_AND_NOTIFICATION); } /** * @param name 名称 * @return 获取药品信息 */ public ResultVo> getDrugInfo(String name) { return ResultVoUtil.success(dao.getDrugInfo(StringUtil.isContainChinese(name))); } public ResultVo> getBldCat(String name) { return ResultVoUtil.success(dao.getBldCat(StringUtil.isContainChinese(name))); } /** * 获取转科列表 * * @return */ public ResultVo> getTheTransferList() { List list = dao.getTheTransferList(); for (ZkList zkList : list) { zkList.setValue(JSON.toJSONString(zkList)); } return ResultVoUtil.success(list); } public ResultVo> getPeopleToFillInInformation() throws InvocationTargetException, IllegalAccessException { Map map = new HashMap<>(Capacity.EIGHT); map.put("restrictedDrugLevels", EnumToJson.toJson(RestrictedDrugLevels.values())); map.put("ysjbData", EnumToJson.toJson(Ysjb.values())); map.put("deptData", getDept().getData()); map.put("empPosition", dao.getEmpPosition()); map.put("empInmark", dao.getEmpInmark()); map.put("zdIfcadre", dao.getZdIfcadre()); map.put("zdEmpTitle", dao.getZdEmpTitle()); map.put("mzyZdChargeType", dao.getMzyZdChargeType()); return ResultVoUtil.success(map); } public ResultVo idVerification(String idCard) { return ResultVoUtil.success(IdCardUtil.isValidatedIdCard(idCard)); } public Integer getPersonnelCode() { dao.lockThePersonnelCodeTable(); Integer code = dao.getPersonnelCode(); dao.updateStaffCodeTable(code); return code; } public ResultVo sendMessage(SendMessageParam param) { settingsDao.insertNewMessage(SnowFlakeId.instance().nextId(), param.getMessage()); JSONObject obj = new JSONObject(); obj.put("message", param.getMessage()); if (null != param.getRefreshDelay()) { int delay = param.getRefreshDelay() * 1000; obj.put("refreshDelay", delay); } WebSocketServer.sendMessageToAll(SocketMsg.socketVo(Message.SYSTEM_NOTIFICATION, obj)); log.info("发送全体消息 => 操作员:{},消息体:{}", TokenUtil.getTokenUserId(), obj); return ResultVoUtil.success(); } public void sendSystemAnnouncement() { Map map = redisLikeService.getMessage(); JSONObject obj = new JSONObject(); obj.put("data", map); WebSocketServer.sendMessageToAll(SocketMsg.socketVo(Message.SYSTEM_ANNOUNCEMENT, obj)); } /** * @description: 查询有住院的科室 * @author: lihong * @date: 2022/12/26 16:58 * @return: thyyxxk.webserver.entity.ResultVo> **/ public ResultVo> getZhuYuanDept() { return ResultVoUtil.success(dao.getZhuYuanDept()); } public String getName(String groupNo) { String name = dao.getGroupName(groupNo); return name == null ? "未知" : name; } @Async public void orderRecord(BigDecimal orderCode, String userCode) { if (orderCode == null) { return; } if (dao.selectRecordByOrderNo(orderCode) > 0) { return; } dao.insertOrderNoRecord(orderCode, userCode); } public ResultVo getUserInfoByCode(String code) { return ResultVoUtil.success(redisLikeService.getUserInfoByCode(code)); } }