From 438d1b156d1eb038bb54ad92cb12a6bf28889011 Mon Sep 17 00:00:00 2001
From: eight <641137800@qq.com>
Date: 星期五, 06 九月 2024 17:57:01 +0800
Subject: [PATCH] 拆装机功能

---
 src/views/ecg/appointment/AppointmentConfirm.vue |    1 
 src/views/ecg/doctor/index.vue                   |   23 +++++++
 src/views/ecg/doctor/components/DevRentPanel.vue |  147 +++++++++++++++++++++++++++++++++++++++++++++++++
 3 files changed, 168 insertions(+), 3 deletions(-)

diff --git a/src/views/ecg/appointment/AppointmentConfirm.vue b/src/views/ecg/appointment/AppointmentConfirm.vue
index 38dd2f9..95f981c 100644
--- a/src/views/ecg/appointment/AppointmentConfirm.vue
+++ b/src/views/ecg/appointment/AppointmentConfirm.vue
@@ -179,7 +179,6 @@
     message.info(data)
 }
 
-
 /** 閲嶇疆琛ㄥ崟 */
 const resetForm = () => {
   formData.value = {
diff --git a/src/views/ecg/doctor/components/DevRentPanel.vue b/src/views/ecg/doctor/components/DevRentPanel.vue
new file mode 100644
index 0000000..4a7d045
--- /dev/null
+++ b/src/views/ecg/doctor/components/DevRentPanel.vue
@@ -0,0 +1,147 @@
+<template>
+  褰撳墠鎮h��: {{patient.patId}} {{patient.patName}}
+    <el-form
+      ref="formRef"
+      :model="formData"
+      :rules="formRules"
+      label-width="100px"
+      v-loading="formLoading"
+    >
+      <el-form-item label="璁惧缂栧彿" prop="devId">
+        <el-input v-model="formData.devId" placeholder="璇疯緭鍏ヨ澶囩紪鍙�" />
+      </el-form-item>
+      <el-form-item label="瑁呮満鏃堕棿" prop="rentTime">
+        <el-date-picker
+          v-model="formData.rentTime"
+          type="date"
+          value-format="x"
+          placeholder="閫夋嫨瑁呮満鏃堕棿"
+        />
+      </el-form-item>
+      <el-form-item label="鎷嗘満鏃堕棿" prop="returnTime">
+        <el-date-picker
+          v-model="formData.returnTime"
+          type="date"
+          value-format="x"
+          placeholder="閫夋嫨鎷嗘満鏃堕棿"
+        />
+      </el-form-item>
+      <el-form-item label="骞叉壈鏁�" prop="interference">
+        <el-input v-model="formData.interference" placeholder="璇疯緭鍏ュ共鎵版暟" />
+      </el-form-item>
+      <el-form-item label="鍩虹嚎绮�" prop="baseline">
+        <el-input v-model="formData.baseline" placeholder="璇疯緭鍏ュ熀绾跨矖" />
+      </el-form-item>
+      <el-form-item label="鑴辩" prop="detachment">
+        <el-input v-model="formData.detachment" placeholder="璇疯緭鍏ヨ劚绂�" />
+      </el-form-item>
+      <el-form-item label="澶囨敞" prop="remark">
+        <el-input v-model="formData.remark" placeholder="璇疯緭鍏ュ娉�" />
+      </el-form-item>
+    </el-form>
+    <el-button @click="submitForm" type="primary" :disabled="formLoading">纭� 瀹�</el-button>
+    <el-button @click="dialogVisible = false">鍙� 娑�</el-button>
+</template>
+<script setup lang="ts">
+import {defineComponent, PropType} from "vue";
+import { DevRentApi, DevRentVO } from '@/api/ecg/devrent'
+import {QueueVO} from "@/api/ecg/queue";
+
+/** 瑁呮満鎷嗘満 琛ㄥ崟 */
+defineComponent({ name: 'DevRentPanel' })
+
+const emit = defineEmits(['success']) // 瀹氫箟 success 浜嬩欢锛岀敤浜庢搷浣滄垚鍔熷悗鐨勫洖璋�
+
+const  props = defineProps({
+  patient: {
+    type: Object as PropType<QueueVO>,
+    required: true
+  }
+})
+
+const { t } = useI18n() // 鍥介檯鍖�
+const message = useMessage() // 娑堟伅寮圭獥
+
+const dialogVisible = ref(false) // 寮圭獥鐨勬槸鍚﹀睍绀�
+
+const formLoading = ref(false) // 琛ㄥ崟鐨勫姞杞戒腑锛�1锛変慨鏀规椂鐨勬暟鎹姞杞斤紱2锛夋彁浜ょ殑鎸夐挳绂佺敤
+const formType = ref('create') // 琛ㄥ崟鐨勭被鍨嬶細create - 鏂板锛泆pdate - 淇敼
+const formData = ref({
+  id: undefined,
+  devId: undefined,
+  patId: props.patient.patId,
+  patName: props.patient.patName,
+  rentTime: undefined,
+  returnTime: undefined,
+  interference: undefined,
+  baseline: undefined,
+  detachment: undefined,
+  remark: undefined
+})
+const formRules = reactive({
+  devId: [{ required: true, message: '璁惧缂栧彿涓嶈兘涓虹┖', trigger: 'blur' }],
+  patId: [{ required: true, message: '鎮h�呯紪鍙蜂笉鑳戒负绌�', trigger: 'blur' }],
+  patName: [{ required: true, message: '鎮h�呭悕绉颁笉鑳戒负绌�', trigger: 'blur' }]
+})
+const formRef = ref() // 琛ㄥ崟 Ref
+
+/** 鎵撳紑寮圭獥 */
+const open = async (type: string, id?: number) => {
+  dialogVisible.value = true
+  formType.value = type
+  resetForm()
+  // 淇敼鏃讹紝璁剧疆鏁版嵁
+  if (id) {
+    formLoading.value = true
+    try {
+      formData.value = await DevRentApi.getDevRent(id)
+    } finally {
+      formLoading.value = false
+    }
+  }
+}
+defineExpose({ open }) // 鎻愪緵 open 鏂规硶锛岀敤浜庢墦寮�寮圭獥
+
+/** 鎻愪氦琛ㄥ崟 */
+
+const submitForm = async () => {
+  // 鏍¢獙琛ㄥ崟
+  await formRef.value.validate()
+  // 鎻愪氦璇锋眰
+  formLoading.value = true
+  try {
+    const data = formData.value as unknown as DevRentVO
+    data.patId = props.patient.patId
+    data.patName = props.patient.patName
+    if (formType.value === 'create') {
+      await DevRentApi.createDevRent(data)
+      message.success(t('common.createSuccess'))
+    } else {
+      await DevRentApi.updateDevRent(data)
+      message.success(t('common.updateSuccess'))
+    }
+    dialogVisible.value = false
+    // 鍙戦�佹搷浣滄垚鍔熺殑浜嬩欢
+    emit('success')
+  } finally {
+    formLoading.value = false
+  }
+}
+
+/** 閲嶇疆琛ㄥ崟 */
+const resetForm = () => {
+  formData.value = {
+    id: undefined,
+    devId: undefined,
+    patId: undefined,
+    patName: undefined,
+    rentTime: undefined,
+    returnTime: undefined,
+    interference: undefined,
+    baseline: undefined,
+    detachment: undefined,
+    remark: undefined
+  }
+  formRef.value?.resetFields()
+}
+</script>
\ No newline at end of file
diff --git a/src/views/ecg/doctor/index.vue b/src/views/ecg/doctor/index.vue
index 1aeba57..4358d23 100644
--- a/src/views/ecg/doctor/index.vue
+++ b/src/views/ecg/doctor/index.vue
@@ -5,6 +5,7 @@
 import {useUserStore} from "@/store/modules/user";
 import {QueueVO} from "@/api/ecg/queue";
 import {ElNotification} from "element-plus";
+import DevRentPanel from "@/views/ecg/doctor/components/DevRentPanel.vue";
 
 const userStore = useUserStore();
 
@@ -13,6 +14,11 @@
     roomName: null,
     bedNo: null
 }
+
+const onStagePatient = ref<QueueVO>({
+  bedNo: "", bookCheckType: 0, bookTimeslot: 0, expired: 0, id: 0, jumpFlag: 0, passed: 0,
+  patGender: 0, patId: "1", patName: "OKK", roomId: 0, roomName: "", seqNum: 0, status: 0
+})
 
 const patientStat = ref<PatientStatisticVO>({
     finishedNum: 0,
@@ -50,6 +56,14 @@
   }
 }
 
+const getOnstagePatient = () => {
+  const tempPatient : QueueVO | undefined = patientList.value.find(item => item.status === 30)
+  if (tempPatient !== undefined) {
+    onStagePatient.value= tempPatient
+    //onStagePatient.value.patName = tempPatient.patName
+  }
+}
+
 const initLoad = async () => {
   if (roomBedVO.roomId == null) {
     ElNotification.error({
@@ -61,6 +75,7 @@
   }
 
   patientList.value = await DoctorApi.getPatientList(roomBedVO)
+  getOnstagePatient()
   patientStat.value = await DoctorApi.getPatientStatistic(roomBedVO)
   const queueVO2 = await DoctorApi.bedDoctorGet(roomBedVO)
   if (queueVO2.status === 20)
@@ -85,7 +100,7 @@
 }
 
 const doctorTimer = () => {
-  console.log('doctor ...')
+  console.log('doctorTimer ...')
   initLoad()
   if (timerRunFlag)
     setTimeout(doctorTimer, 5000) // five seconds
@@ -119,6 +134,10 @@
   timerRunFlag = false
 })
 
+const onEvent = () => {
+  console.info("onDevRentPanelEvent...")
+}
+
 </script>
 
 <template>
@@ -128,7 +147,7 @@
     </el-header>
     <el-container>
       <el-main>
-        瑁呮満鐣岄潰
+        <DevRentPanel :patient="onStagePatient"  @success="onEvent"/>
       </el-main>
       <el-aside width="300px" style="background-color: var(--el-color-primary-light-7);">
         <QueuePanel :queue="patientList"/>

--
Gitblit v1.9.3