From 562f929655f3144d253e3b8d678d8ae7a930eaf9 Mon Sep 17 00:00:00 2001 From: eight <641137800@qq.com> Date: 星期三, 16 十月 2024 10:46:54 +0800 Subject: [PATCH] update --- src/views/ecg/doctor/components/DevReadyPanel.vue | 98 ++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 77 insertions(+), 21 deletions(-) diff --git a/src/views/ecg/doctor/components/DevReadyPanel.vue b/src/views/ecg/doctor/components/DevReadyPanel.vue index 2247d38..ef0fbfb 100644 --- a/src/views/ecg/doctor/components/DevReadyPanel.vue +++ b/src/views/ecg/doctor/components/DevReadyPanel.vue @@ -1,5 +1,7 @@ <template> - 褰撳墠鎮h��: {{patient?.patId}} {{isStringEmpty(patient?.patName)?'鏃�':patient.patName}} + +<!-- 褰撳墠鎮h��: {{patient?.patId}} {{isStringEmpty(patient?.patName)?'鏃�':patient.patName}}--> + <el-form ref="formRef" :model="formData" @@ -7,11 +9,22 @@ label-width="100px" v-loading="formLoading" > + <el-form-item label="鎮h�呯紪鍙�" 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 /> + </el-form-item> + <el-form-item label="鎮h�呭悕绉�" prop="patName"> + <el-input v-model="formData.patName" placeholder="璇疯緭鍏ユ偅鑰呭悕绉�" /> + </el-form-item> + + <el-form-item label="鎮h�呮弿杩�" prop="patDeptDesc"> + {{formData.patDetails}} + </el-form-item> <el-form-item label="璁惧缂栧彿" prop="devId"> <el-input v-model="formData.devId" placeholder="璇疯緭鍏ヨ澶囩紪鍙�" @input="getDevInfo"/> </el-form-item> <el-form-item label="璁惧鎻忚堪" prop=""> - {{deviceInfo.brand + " " + deviceInfo.model}} + {{deviceInfo.brand + " " + deviceInfo.model + " " + deviceInfo.state}} </el-form-item> <el-form-item label="瑁呮満鏃堕棿" prop="rentTime"> <el-date-picker @@ -117,11 +130,19 @@ import {JobRecordApi, JobRecordVO} from "@/api/ecg/jobrecord"; import {DeviceApi, DeviceVO} from "@/api/ecg/devmanage"; import {curDayEnd, curDayStart} from "@/utils/dateUtil"; +import {PatientStatisticVO, RoomBedVO} from "@/api/ecg/doctor"; -/** 瑁呮満鎷嗘満 琛ㄥ崟 */ +/** 璁惧棰嗙敤 琛ㄥ崟 */ defineComponent({ name: 'DevReadyPanel' }) -const emit = defineEmits(['success-ready']) // 瀹氫箟 success 浜嬩欢锛岀敤浜庢搷浣滄垚鍔熷悗鐨勫洖璋� +const props = defineProps({ + room: { + type: Object as PropType<RoomBedVO>, + required: true + } +}) + +const emit = defineEmits(['event_dev_ready']) // 瀹氫箟 success 浜嬩欢锛岀敤浜庢搷浣滄垚鍔熷悗鐨勫洖璋� const { t } = useI18n() // 鍥介檯鍖� const message = useMessage() // 娑堟伅寮圭獥 @@ -131,23 +152,26 @@ const formLoading = ref(false) // 琛ㄥ崟鐨勫姞杞戒腑锛�1锛変慨鏀规椂鐨勬暟鎹姞杞斤紱2锛夋彁浜ょ殑鎸夐挳绂佺敤 const formType = ref('create') // 琛ㄥ崟鐨勭被鍨嬶細create - 鏂板锛泆pdate - 淇敼 -const patient = ref<QueueVO>({ - patId: '', - patName: '' -}) - const formData = ref({ id: undefined, devId: undefined, - patId: patient.value?.patId, - patName: patient.value?.patName, + patId: undefined, + patName: undefined, + patDeptCode: undefined, + patDeptDesc: undefined, + patWardCode: undefined, + patWardDesc: undefined, + patBedNo: undefined, + patDetails: undefined, rentTime: new Date().getTime(), returnTime: undefined, interference: undefined, baseline: undefined, detachment: undefined, remark: undefined, - paid: undefined + paid: undefined, + roomId: props.room.roomId, + bedNo: props.room.bedNo }) const formRules = reactive({ devId: [{ required: true, message: '璁惧缂栧彿涓嶈兘涓虹┖', trigger: 'blur' }], @@ -164,8 +188,27 @@ brand: '', model: '', purchaseDate: 0, - lost: 0, + state: 0, }) + +const getRentInfoByPatId = () => { + const tempPatId = formData.value.patId; + resetForm() + if (isStringEmpty(tempPatId)) + return + + formData.value.patId = tempPatId; + getFreeRentInfo() +} + +const getFreeRentInfo = async () => { + const data = await DevRentApi.getFreeRent(formData.value) + if (null === data) + return + + // formDate 瀵瑰簲 DevRent + formData.value = data +} /** 鎻愪氦琛ㄥ崟 */ const submitForm = async () => { @@ -174,7 +217,11 @@ // 鎻愪氦璇锋眰 formLoading.value = true try { + formData.value.roomId = props.room.roomId + formData.value.bedNo = props.room.bedNo const data = formData.value as unknown as DevRentVO + console.info( data ) + if (formData.value.id === null || formData.value.id === undefined) { const result = await DevRentApi.devReady(data) formData.value.id = result @@ -185,7 +232,7 @@ } dialogVisible.value = false // 鍙戦�佹搷浣滄垚鍔熺殑浜嬩欢 - emit('success-ready') + emit('event_dev_ready') resetForm() getList() } finally { @@ -194,17 +241,19 @@ } const cancelInstall = async () => { + formData.value.roomId = props.room.roomId + formData.value.bedNo = props.room.bedNo const data = formData.value as unknown as DevRentVO if (formData.value.id === null || formData.value.id === undefined) { - const result = await DevRentApi.devCancel(data) + const result = await DevRentApi.devReadyCancel(data) formData.value.id = result message.success(t('鎿嶄綔鎴愬姛')) } else { - await DevRentApi.devCancel(data) + await DevRentApi.devReadyCancel(data) message.success(t('鎿嶄綔鎴愬姛')) } // 鍙戦�佹搷浣滄垚鍔熺殑浜嬩欢 - emit('success-ready') + emit('event_dev_ready') resetForm() getList() } @@ -214,8 +263,8 @@ formData.value = { id: undefined, devId: undefined, - patId: patient.value?.patId, - patName: patient.value?.patName, + patId: undefined, + patName: undefined, rentTime: new Date().getTime(), returnTime: undefined, interference: undefined, @@ -228,11 +277,17 @@ deviceInfo.value.category = '' deviceInfo.value.brand = '' deviceInfo.value.model = '' + deviceInfo.value.state = 0 } +// const setPatient = (queueVO: QueueVO | undefined) => { +// resetForm() +// formData.value.patId = queueVO?.patId +// formData.value.patName = queueVO?.patName +// } const setPatient = (queueVO: QueueVO | undefined) => { - patient.value = queueVO - resetForm() + formData.value.patId = queueVO?.patId + getRentInfoByPatId() } defineExpose({ setPatient }) // 鎻愪緵 setPatient 鏂规硶锛岀敤浜庤缃偅鑰� @@ -288,6 +343,7 @@ deviceInfo.value.category = '' deviceInfo.value.brand = '' deviceInfo.value.model = '' + deviceInfo.value.state = 0 if (isStringEmpty(formData.value.devId)) return -- Gitblit v1.9.3