eight
2024-12-18 8ce35ee72e52f51f93e61d2dec6084c3cfd397b6
src/views/ecg/doctor/components/DevInstallPanel.vue
@@ -6,17 +6,23 @@
      label-width="100px"
      v-loading="formLoading"
    >
      <el-form-item label="检查项目" prop="">
        {{formData.checkType && checkTypeStore.getCheckTypeName(formData.checkType)}}
      </el-form-item>
      <el-row :gutter="20">
        <el-col :span="12">
          <el-form-item label="患者编号" prop="patId">
            <el-input v-model="formData.patId" placeholder="请输入患者编号" @input="getRentInfoByPatId" />
            <Qrcode v-if="formData.patId !== undefined && formData.patId !== ''" :text="formData.patId" logo="/logo.gif" width=100 />
<!--        <Qrcode v-if="formData.patId !== undefined && formData.patId !== ''" :text="formData.patId" logo="/logo.gif" width=100 />-->
            <Barcode v-if="displayBarCode" :value="displayBarCode" :width=100 />
            <el-button @click="copyBarcode()">复制</el-button>
          </el-form-item>
          <el-form-item label="患者名称" prop="patName">
            <el-input v-model="formData.patName" placeholder="请输入患者名称" />
          </el-form-item>
          <el-form-item label="患者描述" prop="patDeptDesc">
            {{formData.patDetails}}
            <dict-tag :type="DICT_TYPE.ECG_PAT_SOURCE" :value="formData.patSrc" />
            {{formData.patDetails?.deptDesc}} {{formData.patDetails?.wardDesc}} {{formData.patDetails?.bedNo}}
          </el-form-item>
          <el-form-item label="装机时间" prop="rentTime">
            <el-date-picker
@@ -119,6 +125,9 @@
import {DeviceApi} from "@/api/ecg/devmanage";
import {QueueVO} from "@/api/ecg/queue";
import {RoomBedVO} from "@/api/ecg/doctor";
import {Barcode} from "@/components/Barcode";
import {useCheckTypeStore} from "@/store/modules/checkType";
import {DICT_TYPE} from "@/utils/dict";
/** 设备装机 表单 */
defineComponent({ name: 'DevInstallPanel' })
@@ -132,12 +141,18 @@
const emit = defineEmits(['event_dev_install']) // 定义 success 事件,用于操作成功后的回调
const checkTypeStore = useCheckTypeStore()
const setPatient = (queueVO: QueueVO | undefined) => {
  resetForm()
  formData.value.applyNo = queueVO?.applyNo
  formData.value.episodeId = queueVO?.episodeId
  formData.value.patId = queueVO?.patId
  formData.value.patName = queueVO?.patName
  formData.value.checkType = queueVO?.bookCheckType
  formData.value.patSrc = queueVO?.patDetails.source
  getReadyRentInfo(formData.value)
  copyBarcode()
}
defineExpose({ setPatient }) // 提供 setPatient 方法,用于设置患者
@@ -157,6 +172,8 @@
  patName: [{ required: true, message: '患者名不能为空', trigger: 'blur' }]
})
const formRef = ref() // 表单 Ref
const displayBarCode = ref<string> ()
/** 提交表单 */
const submitForm = async () => {
@@ -228,6 +245,7 @@
  formData.value.patId = tempPatId;
  getReadyRentInfo(formData.value)
  copyBarcode()
}
const getReadyRentInfo = async (devRentVO) => {
@@ -237,7 +255,9 @@
  // formData.value = data  //不能整个赋值, 默认装机时间被清空
  formData.value.id = data.id;
  formData.value.devId = data.devId
  formData.value.applyNo = data.applyNo;
  formData.value.episodeId = data.episodeId;
  //formData.value.devId = data.devId      // 让医生手动输入,避免出错
  formData.value.category = data.category
  formData.value.brand = data.brand
  formData.value.model = data.model
@@ -300,6 +320,34 @@
  getList()
}
const getDisplayBarcode = (): string => {
  if (!formData.value.checkType)
    return ""
  const displayBarcode: number[] = checkTypeStore.getCheckTypeDispBarCode(formData.value.checkType!)
  if (!displayBarcode.includes( formData.value.patSrc ))
    return ""
  return getBarcode()
}
const getBarcode = (): string => {
  if (!formData.value.checkType)
    return ""
  if (1 === formData.value.patSrc || 2 === formData.value.patSrc)
    return formData.value.applyNo??""
  else if (3 === formData.value.patSrc || 4 === formData.value.patSrc)
    return formData.value.episodeId??""
  return ""
}
const copyBarcode = async () => {
  displayBarCode.value = getDisplayBarcode()
  await navigator.clipboard.writeText( getBarcode() );
}
/** 初始化 **/
onMounted(() => {
  resetForm()