BianJiJianChaJianYanShenQing.vue 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  1. <template>
  2. <el-dialog v-model="dialog" title="编辑检验" @close="guanBi">
  3. <el-pagination :current-page="index" :page-size="1" :total="count" background layout="total, prev, pager, next"
  4. @current-change="bianJiFenYe"/>
  5. <el-form label-width="100px" size="small" :model="bianJiJianChaShuJu">
  6. <el-row>
  7. <el-col :span="12">
  8. <el-form-item label="检查项目编码:">
  9. {{ bianJiJianChaShuJu.orderCode }}
  10. </el-form-item>
  11. </el-col>
  12. <el-col :span="12">
  13. <el-form-item label="检查项目名称:">
  14. {{ bianJiJianChaShuJu.orderName }}
  15. </el-form-item>
  16. </el-col>
  17. <el-col :span="12">
  18. <el-form-item class="bi_tian" label="检查时间:">
  19. <el-date-picker
  20. v-model="bianJiJianChaShuJu.startTime"
  21. ref="checkTheTimeRef"
  22. format="YYYY-MM-DD HH:mm:ss"
  23. style="width: 180px"
  24. type="datetime"
  25. value-format="YYYY-MM-DD HH:mm:ss"
  26. >
  27. </el-date-picker>
  28. </el-form-item>
  29. </el-col>
  30. <el-col :span="12">
  31. <el-form-item class="bi_tian" label="执行科室:">
  32. <xc-select-v3
  33. style="width: 120px"
  34. v-model="bianJiJianChaShuJu"
  35. :data="zhiXingKeShiData"
  36. code="execDept"
  37. name="execDeptName"
  38. :remote-method="metZhiXingKeShi"/>
  39. </el-form-item>
  40. </el-col>
  41. <el-col :span="12">
  42. <el-form-item label="急诊:">
  43. <el-switch
  44. v-model="bianJiJianChaShuJu.jzFlag"
  45. :active-value="1"
  46. :inactive-value="0"
  47. active-color="#13ce66"
  48. active-text="急诊"
  49. inactive-color="#ff4949"
  50. inactive-text="普通"
  51. >
  52. </el-switch>
  53. </el-form-item>
  54. </el-col>
  55. <el-col :span="12">
  56. <el-form-item label="自费:">
  57. <el-switch
  58. v-model="bianJiJianChaShuJu.ybSelfFlag"
  59. :active-value="1"
  60. :inactive-value="0"
  61. active-color="#13ce66"
  62. active-text="急诊"
  63. inactive-color="#ff4949"
  64. inactive-text="普通"
  65. >
  66. </el-switch>
  67. </el-form-item>
  68. </el-col>
  69. <el-col v-if="jianCha" :span="12">
  70. <el-form-item class="bi_tian" label="临床诊断:" prop="diagCode">
  71. <xc-select-v3
  72. v-model="bianJiJianChaShuJu"
  73. :data="linChuangZhenDuanShuJu"
  74. :remote-method="linChuangZhenDuanSuoSou"
  75. code="diagCode"
  76. name="diagText"
  77. />
  78. </el-form-item>
  79. </el-col>
  80. <el-col v-if="jianCha" :span="12">
  81. <el-switch v-model="zhenDuanLaiYuan" :active-value="true" :inactive-value="false" active-color="#13ce66"
  82. active-text="医保" inactive-color="#ff4949" inactive-text="本院">
  83. </el-switch>
  84. </el-col>
  85. <el-col :span="24">
  86. <el-form-item v-if="!jianCha" class="bi_tian" label="标本:">
  87. <el-select v-model="bianJiJianChaShuJu.inspectStuff" :remote-method="biaoBenSouSuo" clearable filterable
  88. remote @change="bianBenMing">
  89. <el-option v-for="item in biaoBenShuJu" :key="item.code" :label="item.name" :value="item.code">
  90. <span style="color: #8492a6; font-size: 12px">{{ item.code }}</span>
  91. <el-divider direction="vertical"></el-divider>
  92. <span>{{ item.name }}</span>
  93. </el-option>
  94. </el-select>
  95. </el-form-item>
  96. </el-col>
  97. <el-col :span="12">
  98. <el-form-item :label="jianCha ? '病室摘要:' : '申请说明'" class="bi_tian">
  99. <el-input v-model="bianJiJianChaShuJu.reqComment" :rows="6" maxlength="125" show-word-limit
  100. type="textarea"></el-input>
  101. </el-form-item>
  102. </el-col>
  103. <el-col v-if="jianCha" :span="12">
  104. <el-button @click="daKaiShuoMingMuBan">说明模板</el-button>
  105. </el-col>
  106. <el-col v-if="jianCha" :span="24">
  107. <el-form-item class="bi_tian" label="体征信息:">
  108. <el-input v-model="bianJiJianChaShuJu.reqTzComment" :rows="6" maxlength="125" show-word-limit
  109. type="textarea"></el-input>
  110. </el-form-item>
  111. </el-col>
  112. <el-col v-if="jianCha" :span="24">
  113. <el-form-item class="bi_tian" label="相关辅检结果:">
  114. <el-input v-model="bianJiJianChaShuJu.reqOtherResult" :rows="6" maxlength="125" show-word-limit
  115. type="textarea"></el-input>
  116. </el-form-item>
  117. </el-col>
  118. <el-col :offset="20" :span="24">
  119. <el-button icon="Check" type="primary" @click="guanBi">确定</el-button>
  120. </el-col>
  121. </el-row>
  122. </el-form>
  123. </el-dialog>
  124. <shuo-ming-mu-ban ref="shouMingMuBan" @huoQuXuanZhongShuJu="xuanZhongMuBan"></shuo-ming-mu-ban>
  125. </template>
  126. <script setup name="BianJiJianChaShenQing">
  127. import {computed, ref} from 'vue'
  128. import store from '@/store'
  129. import ShuoMingMuBan from '@/components/zhu-yuan-yi-sheng/jian-cha-shen-qing/ShuoMingMuBan.vue'
  130. import {ElMessage} from 'element-plus'
  131. import {stringIsBlank, stringNotBlank} from '@/utils/blank-utils'
  132. import {biaoBenApi, diagnosisInOurHospital} from '@/api/zhu-yuan-yi-sheng/jian-yan-jian-cha-shen-qing'
  133. import {logoutShortcut, xcHotKey} from '@/utils/xckeydown'
  134. import XcSelectV3 from "@/components/xiao-chan/select-v3/XcSelectV3.vue";
  135. import XcCode from "@/components/xiao-chan/code/XcCode";
  136. import {huoQuZhiXinKeShi} from "@/api/zhu-yuan-yi-sheng/yi-zhu-lu-ru";
  137. const props = defineProps({
  138. jianCha: {
  139. type: Boolean,
  140. default: true,
  141. },
  142. })
  143. const emit = defineEmits(['fan-ye', 'dialogCloses'])
  144. const nextPage = () => {
  145. bianJiFenYe(index.value === count.value ? 1 : (index.value += 1))
  146. }
  147. const previousPage = () => {
  148. bianJiFenYe(index.value === 1 ? count.value : (index.value -= 1))
  149. }
  150. const guanBi = () => {
  151. biaoBenShuJu.value = []
  152. linChuangZhenDuanShuJu.value = []
  153. bianJiJianChaShuJu.value = {}
  154. dialog.value = false
  155. logoutShortcut()
  156. emit('dialogCloses', {bianJiJianChaShuJu})
  157. }
  158. const windowSize = computed(() => {
  159. return store.state.app.windowSize
  160. })
  161. const dialog = ref(false)
  162. const bianJiJianChaShuJu = ref({})
  163. const shouMingMuBan = ref(null)
  164. const linChuangZhenDuanShuJu = ref([])
  165. const biaoBenShuJu = ref([])
  166. let checkTheTimeRef = $ref(null)
  167. const count = ref(0)
  168. const index = ref(0)
  169. // 诊断来源
  170. const zhenDuanLaiYuan = ref(false)
  171. const daKaiBenDuiHua = async (val, xiaBiao, zhongShu) => {
  172. dialog.value = true
  173. index.value = xiaBiao + 1
  174. count.value = zhongShu
  175. bianJiJianChaShuJu.value = val
  176. if (!props.jianCha) {
  177. if (stringNotBlank(val.inspectStuff)) {
  178. let index = biaoBenShuJu.value.findIndex(item => {
  179. return item.code === val.inspectStuff
  180. })
  181. if (index === -1) {
  182. biaoBenShuJu.value.push({code: val.inspectStuff, name: val.inspectStuffName})
  183. }
  184. }
  185. }
  186. }
  187. const daKaiShuoMingMuBan = () => {
  188. shouMingMuBan.value.dialog = true
  189. shouMingMuBan.value.huoQuShuoMingMuBan(0)
  190. }
  191. const xuanZhongMuBan = (val) => {
  192. if (stringIsBlank(bianJiJianChaShuJu.value.reqComment)) {
  193. bianJiJianChaShuJu.value.reqComment = ''
  194. }
  195. if (val.length + bianJiJianChaShuJu.value.reqComment.length > 125) {
  196. return ElMessage.error('字符超长无法添加,病室摘要最多125个字。')
  197. }
  198. bianJiJianChaShuJu.value.reqComment += val + ','
  199. ElMessage.success('复制成功。')
  200. }
  201. /**
  202. * 临床诊断搜索
  203. * @param val
  204. */
  205. const linChuangZhenDuanSuoSou = (val) => {
  206. diagnosisInOurHospital(val).then((res) => {
  207. linChuangZhenDuanShuJu.value = res
  208. })
  209. }
  210. const bianJiFenYe = async (val) => {
  211. biaoBenShuJu.value = []
  212. linChuangZhenDuanShuJu.value = []
  213. index.value = val
  214. emit('fan-ye', {val})
  215. }
  216. const bianBenMing = (val) => {
  217. for (let item of biaoBenShuJu.value) {
  218. if (item.code === val) {
  219. return (bianJiJianChaShuJu.value.inspectStuffName = item.name)
  220. }
  221. }
  222. }
  223. const biaoBenSouSuo = (val) => {
  224. if (val.length > 1) {
  225. biaoBenApi(val).then((res) => {
  226. biaoBenShuJu.value = res
  227. })
  228. }
  229. }
  230. /* 获取执行科室 */
  231. const zhiXingKeShiData = ref([])
  232. const metZhiXingKeShi = (val) => {
  233. huoQuZhiXinKeShi(val).then((res) => {
  234. zhiXingKeShiData.value = res
  235. })
  236. }
  237. defineExpose({daKaiBenDuiHua})
  238. </script>
  239. <style scoped></style>