TianJiaYiZhu.vue 33 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040
  1. <template>
  2. <!-- 这里是获取模板的 -->
  3. <huo-qu-mu-ban v-if="muBanDuiHuaKuang" @close="muBanDuiHuaKuang = false" @muBanShuJu="muBanShuJu"></huo-qu-mu-ban>
  4. <bao-cun-mu-ban ref="baoCunMuBanRef"></bao-cun-mu-ban>
  5. <template v-for="(item, index) in tiShiBiaoTi" :key="index">
  6. <el-alert :title="item.title" :type="item.type" effect="dark"></el-alert>
  7. </template>
  8. <el-button icon="ArrowLeft" style="font-size: 14px" text type="primary" @click="router.go(-1)">返回</el-button>
  9. <el-button type="primary" @click="muBanDuiHuaKuang = true">获取模板</el-button>
  10. <el-button :disabled="yiZhuList.length === 0" type="primary" @click="baoCunMuBanClick">保存模板</el-button>
  11. <el-button icon="Check" type="success" @click="baoCunYiZhuClick">保存</el-button>
  12. {{ count }}
  13. <cuo-wu-xin-xi/>
  14. <el-divider direction="vertical"></el-divider>
  15. <el-button :disabled="yiZhuData.serial === '00' || stringIsBlank(yiZhuData.serial)" icon="View" type="success"
  16. @click="HeLiYongYao.dialog = true"> 药品用法
  17. </el-button>
  18. <el-divider direction="vertical"></el-divider>
  19. <el-button @click="tiaoZhuanZhiHeLiYongYao">合理用药</el-button>
  20. <el-button @click="allergenDialog = true">患者过敏信息</el-button>
  21. <yao-ping-xiang-qing v-if="HeLiYongYao.dialog" :code="HeLiYongYao.code"
  22. @close="HeLiYongYao.dialog = false"></yao-ping-xiang-qing>
  23. <el-form ref="yiZhuRef" v-model="yiZhuData" label-width="90px" size="small">
  24. <el-row>
  25. <el-col :span="span" @click="yiZhuMingDialog = true">
  26. <el-form-item class="bi_tian" label="医嘱名称:" prop="orderName">
  27. <div style="border-bottom: 1px solid #000; height: 29px">
  28. {{ yiZhuData.orderName }}
  29. </div>
  30. </el-form-item>
  31. </el-col>
  32. <el-col :span="span">
  33. <el-form-item label="规格:" prop="orderName">
  34. <div style="border-bottom: 1px solid #000; height: 29px">
  35. {{ yiZhuData.drugSpecification }}
  36. </div>
  37. </el-form-item>
  38. </el-col>
  39. <el-col :span="span">
  40. <el-form-item class="bi_tian" label="频率:" prop="frequCode">
  41. <XcSelect v-model="yiZhuData" :data="yaoPinPingLvData" :name="['frequCode', 'frequCodeName']" clearable remote
  42. @method="pinLvRemoteMethod" ref="pingLv"></XcSelect>
  43. </el-form-item>
  44. </el-col>
  45. <el-col :span="span">
  46. <el-form-item class="bi_tian" label="一次剂量:" prop="dose">
  47. <el-input-number v-model="yiZhuData.dose" :min="0" :precision="2" style="width: 110px"
  48. @change="jiSuanLingLiang"></el-input-number>
  49. <XcSelect v-model="yiZhuData" :data="yaoPinJiLiangData" :name="['doseUnit', 'doseUnitName']" :width="80"
  50. @change="xuanZheJiLiang">
  51. <XcOption label="value"></XcOption>
  52. <XcOption label="name"></XcOption>
  53. </XcSelect>
  54. </el-form-item>
  55. </el-col>
  56. <el-col :span="span">
  57. <el-form-item label="领量:"> {{ yiZhuData.drugQuan }} {{ yiZhuData.miniUnitName }}</el-form-item>
  58. </el-col>
  59. <el-col :span="span">
  60. <el-form-item class="bi_tian" label="给药方式:" prop="supplyCode">
  61. <XcSelect v-model="yiZhuData" :data="geiYaoFangShiData" :name="['supplyCode', 'supplyCodeName']" clearable
  62. remote @method="geiYaoFangShiRemoteMethod"></XcSelect>
  63. </el-form-item>
  64. </el-col>
  65. <el-col :span="span">
  66. <el-form-item label="医嘱时间:" prop="orderName">
  67. {{ yiZhuData.orderTime }}
  68. </el-form-item>
  69. </el-col>
  70. <el-col :span="span">
  71. <el-form-item class="bi_tian" label="开始时间:" prop="startTime">
  72. <el-date-picker
  73. v-model="yiZhuData.startTime"
  74. :disabled-date="disabledDate"
  75. format="YYYY-MM-DD HH:mm:ss"
  76. type="datetime"
  77. value-format="YYYY-MM-DD HH:mm:ss"
  78. ></el-date-picker>
  79. </el-form-item>
  80. </el-col>
  81. <el-col :span="span">
  82. <el-form-item class="bi_tian" label="停止时间:" prop="endTime">
  83. <el-date-picker
  84. v-model="yiZhuData.endTime"
  85. :disabled="yiZhuData.frequCode === 'ONCE'"
  86. :disabled-date="disabledDate"
  87. format="YYYY-MM-DD HH:mm:ss"
  88. type="datetime"
  89. value-format="YYYY-MM-DD HH:mm:ss"
  90. ></el-date-picker>
  91. </el-form-item>
  92. </el-col>
  93. <el-col :span="span">
  94. <el-form-item label="医生:" prop="orderName">
  95. {{ store.state.user.info.name }}
  96. </el-form-item>
  97. </el-col>
  98. <el-col :span="span">
  99. <el-form-item class="bi_tian" label="执行科室:" prop="execUnit">
  100. <XcSelect v-model="yiZhuData" :data="zhiXingKeShiData" :name="['execUnit', 'execUnitName']" remote
  101. @method="metZhiXingKeShi"></XcSelect>
  102. </el-form-item>
  103. </el-col>
  104. <el-col :span="span">
  105. <el-form-item label="父医嘱:" prop="orderName">
  106. <el-select v-model="yiZhuData.parentNo" :disabled="yiZhuData.serial === '00'" clearable
  107. @clear="yiZhuData.parentNo = null" @focus="fuYiZhuClick">
  108. <el-option v-for="item in fuYiZhuData" :key="item.code" :label="item.name" :value="item.code">
  109. <span style="color: #8492a6; font-size: 12px">{{ item.code }}</span>
  110. <el-divider direction="vertical"></el-divider>
  111. <span>{{ item.name }}</span>
  112. </el-option>
  113. </el-select>
  114. </el-form-item>
  115. </el-col>
  116. <el-col :span="span" :title="yiZhuData.discription">
  117. <el-form-item label="医嘱描述:" prop="orderName">
  118. <el-input v-model="yiZhuData.discription" disabled type="textarea"></el-input>
  119. </el-form-item>
  120. </el-col>
  121. <el-col :span="span">
  122. <el-form-item label="医生嘱托:">
  123. <el-input v-model="yiZhuData.instruction" clearable maxlength="50" show-word-limit type="textarea"></el-input>
  124. </el-form-item>
  125. </el-col>
  126. <el-col :span="span">
  127. <el-form-item label="服用时间">
  128. <el-select v-model="yiZhuData.kfFlag" clearable style="width: 80px" @clear="yiZhuData.kfFlag = null">
  129. <el-option key="1" label="饭前" value="1"></el-option>
  130. <el-option key="2" label="饭后" value="2"></el-option>
  131. </el-select>
  132. </el-form-item>
  133. </el-col>
  134. <el-col :span="span">
  135. <el-form-item label="费用标志:">
  136. <el-select v-model="yiZhuData.selfBuy" clearable style="width: 120px" @clear="yiZhuData.selfBuy = null">
  137. <el-option key="1" label="自备" value="1"></el-option>
  138. <el-option key="2" label="嘱托" value="2"></el-option>
  139. <el-option key="3" label="基数药" value="3"></el-option>
  140. </el-select>
  141. </el-form-item>
  142. </el-col>
  143. <el-col :span="span">
  144. <el-form-item label="医保自费:">
  145. <el-switch v-model="yiZhuData.ybSelfFlag" active-color="#13ce66" active-text="自费" active-value="1"
  146. inactive-color="#ff4949" inactive-text="记账" inactive-value="0">
  147. </el-switch>
  148. </el-form-item>
  149. </el-col>
  150. <el-col :span="span">
  151. <el-form-item label="是否紧急:">
  152. <el-switch v-model="yiZhuData.emergencyFlag" active-color="#13ce66" active-text="是" active-value="1"
  153. inactive-color="#ff4949" inactive-text="否" inactive-value="0">
  154. </el-switch>
  155. </el-form-item>
  156. </el-col>
  157. <el-col v-if="yiZhuData.orderCode === zkCode" :span="span">
  158. <el-form-item label="转科:" class="bi_tian">
  159. <el-select v-model="yiZhuData.zkObj">
  160. <el-option v-for="(item, index) in zkList" :key="item.value" :label="item.wardName + '|' + item.smallName"
  161. :value="item.value">
  162. <span>{{ item.wardName }}</span>
  163. <el-divider direction="vertical"></el-divider>
  164. <span>{{ item.smallName }}</span>
  165. </el-option>
  166. </el-select>
  167. </el-form-item>
  168. </el-col>
  169. <el-col v-if="yiZhuData.kjywFlag !== 0" :span="span">
  170. <el-form-item label="用药方式:">
  171. <el-select v-model="yiZhuData.yyfs" style="width: 120px" @change="kangJunYaoYongYaoFangShiGaiBian">
  172. <el-option v-for="item in kangJunYaoWuYongYaoFangShi" :key="item.code" :label="item.name"
  173. :value="item.code">
  174. <span style="color: #8492a6; font-size: 12px">{{ item.code }}</span>
  175. <el-divider direction="vertical"></el-divider>
  176. <span>{{ item.name }}</span>
  177. </el-option>
  178. </el-select>
  179. </el-form-item>
  180. </el-col>
  181. <el-col :span="span">
  182. <el-form-item v-if="yiZhuData.kjywFlag !== 0" label="切口等级:">
  183. <el-select
  184. v-model="yiZhuData.ssqk"
  185. :disabled="yiZhuData.yyfs !== 1 && yiZhuData.yyfs !== 2 && yiZhuData.yyfs !== null"
  186. clearable
  187. style="width: 120px"
  188. @clear="yiZhuData.ssqk = null"
  189. >
  190. <el-option v-for="item in kangJunYaoWuQieKou" :key="item.code" :label="item.name" :value="item.code">
  191. <span style="color: #8492a6; font-size: 12px">{{ item.code }}</span>
  192. <el-divider direction="vertical"></el-divider>
  193. <span>{{ item.name }}</span></el-option
  194. >
  195. </el-select>
  196. </el-form-item>
  197. </el-col>
  198. <el-col :span="span">
  199. <el-form-item v-if="yiZhuData.kjywFlag !== 0" label="用药时间:">
  200. <el-select
  201. v-model="yiZhuData.yysj"
  202. :disabled="yiZhuData.yyfs !== 1 && yiZhuData.yyfs !== 2 && yiZhuData.yyfs !== null"
  203. clearable
  204. style="width: 120px"
  205. @clear="yiZhuData.yysj = null"
  206. >
  207. <el-option v-for="item in kangJunYaoWuYongYaoShiJian" :key="item.code" :label="item.name"
  208. :value="item.code">
  209. <span style="color: #8492a6; font-size: 12px">{{ item.code }}</span>
  210. <el-divider direction="vertical"></el-divider>
  211. <span>{{ item.name }}</span></el-option
  212. >
  213. </el-select>
  214. </el-form-item>
  215. </el-col>
  216. </el-row>
  217. </el-form>
  218. <el-button icon="Plus" type="primary" @click="tianJiaYiZhu">添加</el-button>
  219. <xc-code code="Ctrl + S" description="键盘添加"/>
  220. <xc-code code="Ctrl + F" description="打开搜索框"/>
  221. <xc-code code="Ctrl + 1" description="回到第一个输入框(数字1)"/>
  222. <xc-code code="Alt + PgUp / PgDn" description="医嘱上下"/>
  223. <xc-code code="Alt + ← / →" description="编辑(←) / 复制 (→)"/>
  224. <xc-code code="Alt + D " description="删除选中的医嘱"/>
  225. <el-button @click="dianJiXiuGaiZhiXingKeShi">修改执行科室</el-button>
  226. <el-table
  227. :data="yiZhuList"
  228. ref="elTableRef"
  229. :height="windowSize.h / 2.4"
  230. @selection-change="dianJiXuanZhongShuJu"
  231. :row-class-name="doctorSOrderForm"
  232. @row-click="whenClickingOnTheForm"
  233. >
  234. <el-table-column type="selection"></el-table-column>
  235. <el-table-column label="排序" type="index"></el-table-column>
  236. <el-table-column label="uuid" prop="id"></el-table-column>
  237. <el-table-column label="医嘱编码" prop="orderCode"></el-table-column>
  238. <el-table-column label="医嘱名称" prop="orderName" show-overflow-tooltip></el-table-column>
  239. <el-table-column label="医嘱时间" prop="orderTime" width="70"></el-table-column>
  240. <el-table-column label="开始时间" prop="startTime" width="70"></el-table-column>
  241. <el-table-column label="结束时间" prop="endTime" width="70"></el-table-column>
  242. <el-table-column label="规格" prop="drugSpecification"></el-table-column>
  243. <el-table-column label="频率" prop="frequCodeName"></el-table-column>
  244. <el-table-column label="一次剂量" prop="dose">
  245. <template #default="scope"> {{ scope.row.dose }} {{ scope.row.doseUnitName }}</template>
  246. </el-table-column>
  247. <el-table-column label="领量" prop="drugQuan">
  248. <template #default="scope"> {{ scope.row.drugQuan }} {{ scope.row.miniUnitName }}</template>
  249. </el-table-column>
  250. <el-table-column label="给药方式" prop="supplyCodeName"></el-table-column>
  251. <el-table-column label="执行科室" prop="execUnitName"></el-table-column>
  252. <el-table-column label="父医嘱" prop="parentNo"></el-table-column>
  253. <el-table-column label="类型" prop="drugFlag"></el-table-column>
  254. <el-table-column label="费用标志" prop="selfBuy">
  255. <template #default="scope">
  256. {{ getSelfBuy(scope.row.selfBuy) }}
  257. </template>
  258. </el-table-column>
  259. <el-table-column label="医保自费">
  260. <template #default="scope">
  261. <el-tag v-if="scope.row.ybSelfFlag === '1'">是</el-tag>
  262. </template>
  263. </el-table-column>
  264. <el-table-column label="是否紧急">
  265. <template #default="scope">
  266. <el-tag v-if="scope.row.emergencyFlag === '1'">是</el-tag>
  267. </template>
  268. </el-table-column>
  269. <el-table-column fixed="right" label="操作" width="120">
  270. <template #default="scope">
  271. <el-button circle icon="Edit" type="warning" @click="xiuGaiYiZhu(scope.row)"></el-button>
  272. <el-button circle icon="Delete" type="danger" @click="shanChuBiaoGeYiZhu(scope.$index)"></el-button>
  273. <el-button circle class="iconfont icon-fuzhi" type="info" @click="dianJiFuZhiYiZhu(scope.row)"></el-button>
  274. </template>
  275. </el-table-column>
  276. </el-table>
  277. <!-- 这里是搜索医嘱的 -->
  278. <sou-suo-yi-zhu v-if="yiZhuMingDialog" @close="closeTheDoctorSOrderSearchBox()"
  279. @xuanZhongFeiYong="xuanZhongFeiYong"></sou-suo-yi-zhu>
  280. <AllergenEntry v-if="allergenDialog" :pat-no="huanZheXinXi.inpatientNo"
  281. @close="allergenDialog = false"></AllergenEntry>
  282. </template>
  283. <script name="TianJiaYiZhu" setup>
  284. import {
  285. huoQuFeiYongXinXi,
  286. huoQuGeiYaoFangShi,
  287. huoQuZhiXinKeShi,
  288. huoQuZhuYuanPinLv,
  289. jiaoYan,
  290. shangChuanYiZhu
  291. } from '@/api/zhu-yuan-yi-sheng/yi-zhu-lu-ru'
  292. import {
  293. cuoWuXinXi,
  294. fuZhiYiZhu,
  295. getSelfBuy,
  296. huanZheXinXi,
  297. youWuXuanZheHuanZhe,
  298. zkList
  299. } from '@/views/hospitalization/zhu-yuan-yi-sheng/public-js/zhu-yuan-yi-sheng'
  300. import store from '../../../../store'
  301. import {listIsBlank, listNotBlank, stringIsBlank, stringNotBlank} from '@/utils/blank-utils'
  302. import {kangJunYaoWuQieKou, kangJunYaoWuYongYaoFangShi, kangJunYaoWuYongYaoShiJian} from '@/data'
  303. import {ElMessage, ElMessageBox} from 'element-plus'
  304. import {clone} from '@/utils/clone'
  305. import HuoQuMuBan from '../../../../components/zhu-yuan-yi-sheng/yi-zhu-lu-ru/HuoQuMuBan.vue'
  306. import {uuid} from '@/utils/getUuid'
  307. import BaoCunMuBan from '../../../../components/zhu-yuan-yi-sheng/yi-zhu-lu-ru/BaoCunMuBan.vue'
  308. import {getServerDateApi, whetherThePatientHasAllergens, yaoPinXiangMuPiPeiYiBao} from '@/api/public-api'
  309. import router from '@/router'
  310. import SouSuoYiZhu from '@/components/zhu-yuan-yi-sheng/yi-zhu-lu-ru/SouSuoYiZhu.vue'
  311. import CuoWuXinXi from '@/components/zhu-yuan-yi-sheng/CuoWuXinXi.vue'
  312. import YaoPingXiangQing from '@/components/zhu-yuan-yi-sheng/he-li-yong-yao/YaoPingXiangQing.vue'
  313. import AllergenEntry from '@/components/zhu-yuan-yi-sheng/AllergenEntry.vue'
  314. import Sleep from '@/utils/sleep'
  315. import {logoutShortcut, xcHotKey} from '@/utils/xckeydown'
  316. import {BizException, ExceptionEnum} from '@/utils/BizException'
  317. import {setScrollTop} from "@/utils/el-table-scroll";
  318. const windowSize = computed(() => {
  319. return store.state.app.windowSize
  320. })
  321. // 设置倒计时
  322. const seconds = ref(600)
  323. // 倒计时提示
  324. const count = ref('')
  325. // 转科医嘱 编码
  326. const zkCode = '06286'
  327. // 当前的下标
  328. let dataIndex = $ref(-1)
  329. // 表格的 ref
  330. let elTableRef = $ref(null)
  331. const yiZhuData = ref({
  332. id: '',
  333. actOrderNo: null,
  334. orderName: '',
  335. orderCode: '',
  336. // 频率
  337. frequCode: '',
  338. frequCodeName: '',
  339. drugSpecification: '',
  340. dose: 0,
  341. // 领量
  342. doseUnit: '',
  343. doseUnitName: '',
  344. supplyCode: '',
  345. supplyCodeName: '',
  346. startTime: '',
  347. endTime: '',
  348. orderTime: '',
  349. doctorName: '',
  350. drugFlag: '',
  351. execUnit: '',
  352. execUnitName: '',
  353. parentNo: '',
  354. parentNoName: '',
  355. physicianName: '',
  356. discription: '',
  357. instruction: null,
  358. kfFlag: null,
  359. selfBuy: null,
  360. ybSelfFlag: '0',
  361. emergencyFlag: '0',
  362. drugQuan: 0,
  363. miniUnitName: '',
  364. serial: '',
  365. miniUnit: '',
  366. psFlag: false,
  367. kjywFlag: 0,
  368. yyfs: null,
  369. ssqk: null,
  370. yysj: null,
  371. zkObj: '',
  372. zkWardCode: '',
  373. zkDeptCode: '',
  374. })
  375. /*提示信息*/
  376. const tiShiBiaoTi = ref([])
  377. const span = ref(6)
  378. const spanSize = (val) => {
  379. if (val > 1200) {
  380. span.value = 6
  381. } else if (930 < val || val > 1200) {
  382. span.value = 8
  383. } else if (val < 930) {
  384. span.value = 12
  385. }
  386. }
  387. spanSize(windowSize.value.w)
  388. watch(
  389. () => windowSize.value,
  390. () => {
  391. spanSize(windowSize.value.w)
  392. }
  393. )
  394. // 搜索医嘱
  395. let yiZhuMingDialog = $ref(false)
  396. const xuanZhongFeiYong = async (row) => {
  397. qingKong()
  398. await Sleep(600)
  399. closeTheDoctorSOrderSearchBox()
  400. yiZhuData.value = row
  401. if (row.serial !== '00') {
  402. huoQuFeiYongXinXi(row.orderCode, row.serial)
  403. .then((res) => {
  404. yiZhuData.value.drugFlag = row.orderType
  405. // 判断是否 是皮试的药 如果是就只能有这些 给药方式
  406. if (res.data.psFlag === 1) {
  407. geiYaoFangShiData.value = res.piShi
  408. tiShiBiaoTi.value.push({title: '该药品为皮试药品给药方式只能是皮试类型', type: 'warning'})
  409. yiZhuData.value.psFlag = true
  410. } else {
  411. yiZhuData.value.psFlag = false
  412. }
  413. yiZhuData.value.kjywFlag = res.data.kjywFlag
  414. if (yiZhuData.value.kjywFlag === 1) {
  415. tiShiBiaoTi.value.push({title: '该药品为抗菌药物,请填写抗菌药物医嘱附注信息录入。', type: 'error'})
  416. }
  417. if (res.data.selfFlagYb === 1) {
  418. tiShiBiaoTi.value.push({title: '该药品医保自费药品,如符合条件请填写记账,不是请填写自费。'})
  419. }
  420. yiZhuData.value.miniUnitName = res.data.miniUnitName
  421. yaoPinJiLiangData.value = res.yaoPingJiLiang
  422. // 加载 剂量单位
  423. if (stringNotBlank(yiZhuData.value.doseUnit)) {
  424. yaoPinJiLiangData.value.forEach((item) => {
  425. if (item.code === yiZhuData.value.doseUnit) {
  426. jiLiangValue.value = item.value
  427. }
  428. })
  429. } else if (listNotBlank(yaoPinJiLiangData.value)) {
  430. // 没有剂量单位的时候默认加载第一个计量单位 并且计算
  431. yiZhuData.value.doseUnit = yaoPinJiLiangData.value[0].code
  432. yiZhuData.value.dose = yaoPinJiLiangData.value[0].value
  433. jiLiangValue.value = yaoPinJiLiangData.value[0].value
  434. jiSuanLingLiang(yaoPinJiLiangData.value[0].value)
  435. }
  436. // 加载默认频率 如果已经填写了 就用有的
  437. if (stringIsBlank(row.frequCode)) {
  438. if (stringNotBlank(res.data.frequCode)) {
  439. yiZhuData.value.frequCode = res.data.frequCode
  440. } else {
  441. yiZhuData.value.frequCode = 'ONCE'
  442. }
  443. }
  444. // 加载给药方式
  445. if (stringIsBlank(yiZhuData.value.supplyCode)) {
  446. if (stringNotBlank(res.data.supplyCode)) {
  447. yiZhuData.value.supplyCode = res.data.supplyCode
  448. }
  449. }
  450. })
  451. .catch(async () => {
  452. await Sleep(500)
  453. qingKong()
  454. })
  455. } else {
  456. yiZhuData.value.kjywFlag = 0
  457. huoQuFeiYongXinXi(row.orderCode, '00')
  458. .then((res) => {
  459. yiZhuData.value.drugFlag = row.orderType
  460. yiZhuData.value.frequCode = 'ONCE'
  461. if (stringNotBlank(res.paiChiYiZhu)) {
  462. tiShiBiaoTi.value.push({title: res.paiChiYiZhu, type: 'error'})
  463. }
  464. if (!res.dose) {
  465. yiZhuData.value.dose = 1
  466. }
  467. })
  468. .catch(async () => {
  469. await Sleep(500)
  470. qingKong()
  471. })
  472. }
  473. // 判断这个是不是 新添加的数据 如果是空的就是 新数据
  474. getServerDateApi().then((res) => {
  475. if (!yiZhuData.value.orderTime) {
  476. yiZhuData.value.orderTime = res
  477. }
  478. if (!yiZhuData.value.startTime) {
  479. yiZhuData.value.startTime = res
  480. }
  481. })
  482. // 用来加载默认的执行科室
  483. if (stringIsBlank(row.execUnit)) {
  484. if (stringNotBlank(huanZheXinXi.value.smallDept)) {
  485. yiZhuData.value.execUnit = huanZheXinXi.value.smallDept
  486. }
  487. }
  488. if (stringIsBlank(row.id)) {
  489. yiZhuData.value.id = uuid(8, 10)
  490. }
  491. try {
  492. pingLv.focus()
  493. } catch (e) {
  494. console.log(e)
  495. }
  496. }
  497. const closeTheDoctorSOrderSearchBox = () => {
  498. yiZhuMingDialog = false
  499. xcHotKey(shortcutKeyRegistration)
  500. }
  501. /* 频率 */
  502. let pingLv = $ref(null)
  503. const yaoPinPingLvData = ref([])
  504. const pinLvRemoteMethod = (val) => {
  505. huoQuZhuYuanPinLv(val).then((res) => {
  506. yaoPinPingLvData.value = res
  507. })
  508. }
  509. /* 选择剂量 */
  510. const yaoPinJiLiangData = ref([])
  511. const jiLiangValue = ref(0)
  512. const xuanZheJiLiang = (val) => {
  513. jiLiangValue.value = val.value
  514. yiZhuData.value.dose = val.value
  515. yiZhuData.value.drugQuan = 1
  516. }
  517. /*计算领量*/
  518. const jiSuanLingLiang = (val) => {
  519. if (jiLiangValue.value > 0) {
  520. yiZhuData.value.drugQuan = Math.ceil(val / jiLiangValue.value)
  521. }
  522. }
  523. /* 给药方式 */
  524. const geiYaoFangShiData = ref([])
  525. const geiYaoFangShiRemoteMethod = (val) => {
  526. /*如果是皮试的那么就不可以用别的给药方式*/
  527. if (yiZhuData.value.psFlag) return
  528. huoQuGeiYaoFangShi(val).then((res) => {
  529. geiYaoFangShiData.value = res
  530. })
  531. }
  532. /* 父医嘱 */
  533. const fuYiZhuData = ref([])
  534. const fuYiZhuClick = () => {
  535. fuYiZhuData.value = yiZhuList.value.filter(item => {
  536. return stringNotBlank(item.drugFlag) && item.drugFlag === 'i' && item.id !== yiZhuData.value.id && stringIsBlank(item.parentNo)
  537. })
  538. }
  539. /* 获取执行科室 */
  540. const zhiXingKeShiData = ref([])
  541. const metZhiXingKeShi = (val) => {
  542. huoQuZhiXinKeShi(val).then((res) => {
  543. zhiXingKeShiData.value = res
  544. })
  545. }
  546. /* 这里是添加信息 */
  547. const yiZhuList = ref([])
  548. const tianJiaYiZhuWeiYiBiaoShi = ref([])
  549. const tianJiaYiZhu = () => {
  550. if (stringIsBlank(yiZhuData.value.orderCode)) {
  551. return ElMessage.error('请先选择数据')
  552. }
  553. if (stringNotBlank(yiZhuData.value.parentNo)) {
  554. yiZhuData.value.supplyCode = '044'
  555. yiZhuData.value.supplyCodeName = '副药'
  556. }
  557. if (yiZhuData.value.orderCode === zkCode) {
  558. if (yiZhuData.value.zkObj) {
  559. let zk = JSON.parse(yiZhuData.value.zkObj)
  560. yiZhuData.value.zkWardCode = zk.wardCode
  561. yiZhuData.value.zkDeptCode = zk.smallCode
  562. yiZhuData.value.orderName = `转科医嘱转至${zk.wardName}(小科室:${zk.smallName})`
  563. } else {
  564. return ElMessage.error('请选择转科科室.')
  565. }
  566. }
  567. const list = []
  568. list.push(yiZhuData.value)
  569. let data = {
  570. inpatientNo: huanZheXinXi.value.inpatientNo,
  571. admissTimes: huanZheXinXi.value.admissTimes,
  572. list: list,
  573. }
  574. shangChuanYiZhu(data)
  575. .then((res) => {
  576. let index = tianJiaYiZhuWeiYiBiaoShi.value.indexOf(yiZhuData.value.id)
  577. if (index > -1) {
  578. yiZhuList.value.splice(index, 1)
  579. tianJiaYiZhuWeiYiBiaoShi.value.splice(index, 1)
  580. ElMessage.error('重复添加,老记录已删除。')
  581. }
  582. tianJiaYiZhuWeiYiBiaoShi.value.push(yiZhuData.value.id)
  583. yiZhuList.value.push(clone(yiZhuData.value))
  584. qingKong()
  585. })
  586. .catch((e) => {
  587. cuoWuXinXi.value = e
  588. })
  589. }
  590. /**
  591. * 是否重置数据下标,这个是用来判断需不需要 回到默认值
  592. */
  593. const whetherToResetTheDataSubscript = () => {
  594. if (dataIndex >= yiZhuList.value.length) {
  595. dataIndex--
  596. }
  597. }
  598. /* 这个是点击单个修改的 */
  599. const xiuGaiYiZhu = (val) => {
  600. xuanZhongFeiYong(val)
  601. ElMessage.success('你点击了修改')
  602. yiZhuList.value.splice(val, 1)
  603. tianJiaYiZhuWeiYiBiaoShi.value.splice(val, 1)
  604. whetherToResetTheDataSubscript()
  605. }
  606. /* 删除表格医嘱 */
  607. const shanChuBiaoGeYiZhu = (val) => {
  608. yiZhuList.value.splice(val, 1)
  609. tianJiaYiZhuWeiYiBiaoShi.value.splice(val, 1)
  610. ElMessage.success('删除成功')
  611. whetherToResetTheDataSubscript()
  612. }
  613. /* 复制医嘱 */
  614. const dianJiFuZhiYiZhu = (val) => {
  615. yiZhuData.value = clone(val)
  616. yiZhuData.value.id = uuid(8, 10)
  617. ElMessage.success('复制成功')
  618. }
  619. /* 保存信息 */
  620. const baoCunYiZhuClick = () => {
  621. if (listIsBlank(yiZhuList.value)) {
  622. return ElMessage.error('请先选择数据')
  623. }
  624. if (youWuXuanZheHuanZhe()) return
  625. let yiBaoBianMaTiShi = []
  626. yiZhuList.value.forEach((item) => {
  627. yiBaoBianMaTiShi.push(item.orderCode + '-' + item.serial)
  628. })
  629. yaoPinXiangMuPiPeiYiBao(yiBaoBianMaTiShi).then((res) => {
  630. if (stringNotBlank(res)) {
  631. cuoWuXinXi.value = res
  632. ElMessageBox.confirm(res, '提示', {
  633. type: 'warning',
  634. dangerouslyUseHTMLString: true,
  635. confirmButtonText: '继续录入',
  636. })
  637. .then(() => {
  638. baoCunYiZhu()
  639. })
  640. .catch(() => {
  641. })
  642. } else {
  643. baoCunYiZhu()
  644. }
  645. })
  646. }
  647. function baoCunYiZhu() {
  648. let list = yiZhuList.value.filter((item) => {
  649. return item.serial !== '00'
  650. })
  651. let data = {
  652. inpatientNo: huanZheXinXi.value.inpatientNo,
  653. admissTimes: huanZheXinXi.value.admissTimes,
  654. chaRuYiZhu: true,
  655. cfType: '1',
  656. list: yiZhuList.value,
  657. }
  658. // if (listNotBlank(list)) {
  659. // // 合理用药校验
  660. // jiaoYan(data).then((res) => {
  661. // console.log(res)
  662. // })
  663. // }
  664. ElMessageBox.confirm('您确定要保存这些数据吗?请仔细检查数据。', '提示', {
  665. type: 'warning',
  666. closeOnClickModal: false,
  667. })
  668. .then(() => {
  669. shangChuanYiZhu(data)
  670. .then((res) => {
  671. fuZhiYiZhu.value = []
  672. router.go(-1)
  673. })
  674. .catch((e) => {
  675. cuoWuXinXi.value = e
  676. })
  677. })
  678. .catch(() => {
  679. })
  680. }
  681. /* 这里是抗菌药物,选择了除了 1和 2 的其他都可以不用填写 */
  682. const kangJunYaoYongYaoFangShiGaiBian = (val) => {
  683. if (val !== 1 || val !== 2) {
  684. yiZhuData.value.ssqk = null
  685. yiZhuData.value.yysj = null
  686. }
  687. }
  688. // 模板数据
  689. let muBanDuiHuaKuang = $ref(false)
  690. // 这里是返回的模板数据
  691. const muBanShuJu = (val) => {
  692. let tongZhiCiShu = 0
  693. val.forEach((item) => {
  694. let index = tianJiaYiZhuWeiYiBiaoShi.value.indexOf(item.id)
  695. if (index > -1) {
  696. yiZhuList.value.splice(index, 1)
  697. tianJiaYiZhuWeiYiBiaoShi.value.splice(index, 1)
  698. tongZhi(tongZhiCiShu)
  699. tongZhiCiShu++
  700. }
  701. tianJiaYiZhuWeiYiBiaoShi.value.push(item.id)
  702. yiZhuList.value.push(item)
  703. })
  704. function tongZhi(val) {
  705. if (val === 0) {
  706. setTimeout(() => {
  707. ElMessage.error('重复添加,老记录已删除。')
  708. }, 200)
  709. }
  710. }
  711. ElMessage.success('添加成功。')
  712. }
  713. // 保存模板
  714. const baoCunMuBanRef = ref(null)
  715. const baoCunMuBanClick = () => {
  716. if (listIsBlank(yiZhuList.value)) {
  717. return ElMessage.error('请先选择数据')
  718. }
  719. let data = {
  720. inpatientNo: huanZheXinXi.value.inpatientNo,
  721. admissTimes: huanZheXinXi.value.admissTimes,
  722. list: yiZhuList.value,
  723. }
  724. shangChuanYiZhu(data)
  725. .then((res) => {
  726. baoCunMuBanRef.value.daKaiBaoCunMuBan(yiZhuList.value)
  727. cuoWuXinXi.value = ''
  728. })
  729. .catch((e) => {
  730. cuoWuXinXi.value = e
  731. })
  732. }
  733. // 医嘱限制时间不能在之前
  734. const disabledDate = (time) => {
  735. return time.getTime() < Date.now() - 8.64e7
  736. }
  737. const xuanZhongShuJu = ref([])
  738. const dianJiXuanZhongShuJu = (selection) => {
  739. xuanZhongShuJu.value = selection
  740. }
  741. const dianJiXiuGaiZhiXingKeShi = () => {
  742. if (listIsBlank(xuanZhongShuJu.value)) {
  743. return ElMessage.error('请先选择数据。')
  744. } else {
  745. zhiXingKeShiData.value.forEach((item) => {
  746. if (item.code === yiZhuData.value.execUnit) {
  747. yiZhuData.value.execUnitName = item.name
  748. }
  749. })
  750. xuanZhongShuJu.value.forEach((item) => {
  751. item.execUnit = yiZhuData.value.execUnit
  752. item.execUnitName = yiZhuData.value.execUnitName
  753. })
  754. }
  755. }
  756. const qingKong = () => {
  757. cuoWuXinXi.value = ''
  758. yaoPinJiLiangData.value = []
  759. jiLiangValue.value = 0
  760. tiShiBiaoTi.value = []
  761. yiZhuData.value = {
  762. index: '',
  763. actOrderNo: null,
  764. orderName: '',
  765. orderCode: '',
  766. // 频率
  767. frequCode: '',
  768. frequCodeName: '',
  769. drugSpecification: '',
  770. dose: 0,
  771. // 领量
  772. doseUnit: '',
  773. doseUnitName: '',
  774. supplyCode: '',
  775. supplyCodeName: '',
  776. startTime: '',
  777. endTime: '',
  778. orderTime: '',
  779. doctorName: '',
  780. execUnit: '',
  781. execUnitName: '',
  782. parentNo: '',
  783. parentNoName: '',
  784. physicianName: '',
  785. discription: '',
  786. instruction: null,
  787. kfFlag: null,
  788. selfBuy: null,
  789. ybSelfFlag: '0',
  790. emergencyFlag: '0',
  791. drugQuan: 0,
  792. miniUnitName: '',
  793. serial: '',
  794. miniUnit: '',
  795. psFlag: false,
  796. kjywFlag: 0,
  797. yyfs: null,
  798. ssqk: null,
  799. yysj: null,
  800. zkWardCode: '',
  801. zkDeptCode: '',
  802. }
  803. }
  804. let daoJiShi = null
  805. onUnmounted(() => {
  806. ElMessageBox.close()
  807. clearInterval(daoJiShi)
  808. logoutShortcut()
  809. })
  810. // 倒计时功能
  811. const kaiQiDaoJiShi = () => {
  812. seconds.value = 600
  813. clearInterval(daoJiShi)
  814. daoJiShi = setInterval(() => {
  815. seconds.value--
  816. countDown()
  817. }, 1000)
  818. }
  819. const countDown = () => {
  820. let m = parseInt(((seconds.value / 60) % 60).toString())
  821. m = m < 10 ? '0' + m : m
  822. let s = parseInt((seconds.value % 60).toString())
  823. s = s < 10 ? '0' + s : s
  824. count.value = '剩余操作时间 ' + m + '分' + s + '秒'
  825. if (seconds.value === 300) {
  826. ElMessageBox.alert('您的操作时间过半', '提示', {
  827. type: 'warning',
  828. }).then((res) => {
  829. })
  830. } else if (seconds.value === 60 || seconds.value === 30 || seconds.value === 20) {
  831. ElMessage({
  832. message: '剩余操作时间' + seconds.value + '秒',
  833. showClose: true,
  834. type: 'error',
  835. title: '成功',
  836. duration: 4500,
  837. })
  838. } else if (seconds.value === 0) {
  839. clearInterval(daoJiShi)
  840. router.go(-1)
  841. }
  842. }
  843. let HeLiYongYao = $ref({
  844. dialog: false,
  845. code: '',
  846. })
  847. const tiaoZhuanZhiHeLiYongYao = () => {
  848. window.open('http://172.16.32.121:9097/index.html')
  849. }
  850. //// 下面都是过敏源信息
  851. let allergenDialog = $ref(false)
  852. ///// 过敏源结束
  853. /// 这里是 ctrl 快捷键
  854. /**
  855. * 保存或添加医嘱
  856. */
  857. const saveOrAddADoctorSOrder = () => {
  858. if (yiZhuData.value.orderCode) {
  859. tianJiaYiZhu()
  860. } else {
  861. baoCunYiZhuClick()
  862. }
  863. }
  864. /**
  865. * 打开医嘱搜索框
  866. */
  867. const openSearchBox = () => {
  868. yiZhuMingDialog = true
  869. }
  870. /// 这里是 ctrl 快捷键 结束
  871. const regainFocus = () => {
  872. pingLv.focus()
  873. }
  874. // 这里是表格事件
  875. /**
  876. * 表格样式
  877. * @param row 行
  878. * @param rowIndex 下标
  879. * @returns {string} 样式
  880. */
  881. const doctorSOrderForm = ({row, rowIndex}) => {
  882. row.tableIndex = rowIndex
  883. if (dataIndex === rowIndex) {
  884. return 'input_and_table_to_be_selected'
  885. }
  886. }
  887. /**
  888. * 点击表格时触发的事件
  889. * @param row 当前表格数据
  890. * @param column 当前行
  891. * @param event 事件
  892. */
  893. const whenClickingOnTheForm = (row, column, event) => {
  894. dataIndex = row.tableIndex
  895. }
  896. // 这里是表格事件 结束
  897. // 这里是 alt 快捷键
  898. /**
  899. * 检查是否存在医嘱数据
  900. * @param checkJudgment 判断是否检查选中数据
  901. */
  902. const dataJudgmentIsEmpty = (checkJudgment) => {
  903. let pageDataLength = yiZhuList.value.length
  904. if (pageDataLength <= 0) {
  905. BizException(ExceptionEnum.MESSAGE_ERROR, '请选选择数据')
  906. }
  907. if (checkJudgment) {
  908. if (dataIndex === -1) {
  909. BizException(ExceptionEnum.MESSAGE_ERROR, '请选选择数据')
  910. }
  911. }
  912. }
  913. const scrollBarSynchronization = () => {
  914. setScrollTop(elTableRef, dataIndex)
  915. }
  916. const upData = () => {
  917. dataJudgmentIsEmpty(false)
  918. let pageDataLength = yiZhuList.value.length
  919. dataIndex <= 0 ? (dataIndex = pageDataLength - 1) : dataIndex--
  920. scrollBarSynchronization()
  921. }
  922. const downData = () => {
  923. dataJudgmentIsEmpty(false)
  924. let pageDataLength = yiZhuList.value.length
  925. dataIndex === pageDataLength - 1 ? (dataIndex = 0) : dataIndex++
  926. scrollBarSynchronization()
  927. }
  928. const copyData = () => {
  929. dataJudgmentIsEmpty(true)
  930. dianJiFuZhiYiZhu(yiZhuList.value[dataIndex])
  931. }
  932. const editData = () => {
  933. dataJudgmentIsEmpty(true)
  934. xiuGaiYiZhu(yiZhuList.value[dataIndex])
  935. }
  936. const deleteSelectedOrders = () => {
  937. dataJudgmentIsEmpty(true)
  938. shanChuBiaoGeYiZhu(yiZhuList.value[dataIndex])
  939. }
  940. // alt 快捷键结束
  941. // 注册快捷键的 list
  942. let shortcutKeyRegistration = {
  943. ctrl: {s: saveOrAddADoctorSOrder, f: openSearchBox, 1: regainFocus},
  944. alt: {
  945. PageUp: upData,
  946. PageDown: downData,
  947. ArrowRight: copyData,
  948. ArrowLeft: editData,
  949. d: deleteSelectedOrders,
  950. },
  951. }
  952. onMounted(() => {
  953. xcHotKey(shortcutKeyRegistration)
  954. yiZhuList.value = clone(fuZhiYiZhu.value)
  955. for (let i = 0; i < yiZhuList.value.length; i++) {
  956. yiZhuList.value[i].id = yiZhuList.value[i].actOrderNo
  957. }
  958. if (stringIsBlank(huanZheXinXi.value.inpatientNo)) {
  959. ElMessage.warning('您现在进入的是医嘱模板编辑')
  960. } else {
  961. ElMessage.warning('您现在进入的是医嘱编辑模块,' + '您的编辑时间有 10 分钟,你准备好了吗?Are ya ready kids?')
  962. kaiQiDaoJiShi()
  963. whetherThePatientHasAllergens(huanZheXinXi.value.inpatientNo).then((res) => {
  964. allergenDialog = res
  965. })
  966. }
  967. if (stringNotBlank(huanZheXinXi.value.inpatientNo)) {
  968. zhiXingKeShiData.value = [
  969. {
  970. code: huanZheXinXi.value.smallDept,
  971. name: huanZheXinXi.value.smallDeptName,
  972. },
  973. ]
  974. }
  975. fuZhiYiZhu.value = []
  976. })
  977. </script>
  978. <style scoped>
  979. .el-popover {
  980. height: 240px;
  981. overflow: auto;
  982. }
  983. :deep(.el-textarea.is-disabled .el-textarea__inner) {
  984. color: #0a84fd;
  985. }
  986. </style>