| | |
| | | <template> |
| | | <el-form-item label="患者编号"> |
| | | <el-input v-model="queryParams.patId" placeholder="请输入患者编号" clearable @input="searchBookInfo"/> |
| | | </el-form-item> |
| | | <div style="display: flex; justify-content: center; "> |
| | | <el-form-item label="患者编号" > |
| | | <el-input v-model="queryParams.patId" placeholder="请输入患者编号" clearable @input="searchBookInfo" /> |
| | | </el-form-item> |
| | | </div> |
| | | |
| | | <el-button @click="_confirmAppointment"><Icon icon="ep:refresh" class="mr-5px" /> 排队 </el-button> |
| | | <div style="display: flex; flex-wrap: wrap; justify-content: center; margin-bottom: 20px"> |
| | | <div v-for="_appointment in appointmentVOList" :key="_appointment.applyNo"> |
| | | <CheckItemPanel :appointment="_appointment" /> |
| | | </div> |
| | | </div> |
| | | |
| | | <el-divider/> |
| | | |
| | |
| | | > |
| | | <div class="form-row"> |
| | | <el-form-item label="患者姓名" prop="patName"> |
| | | <el-input v-model="formData.patName" placeholder="请输入患者姓名" /> |
| | | <el-input v-model="formData.patName" placeholder="患者姓名" readonly /> |
| | | </el-form-item> |
| | | </div> |
| | | <div class="form-row"> |
| | | <el-form-item label="患者性别" prop="patGender"> |
| | | <el-radio-group v-model="formData.patGender"> |
| | | <el-radio-group v-model="formData.patGender" readonly> |
| | | <el-radio |
| | | v-for="dict in getIntDictOptions(DICT_TYPE.SYSTEM_USER_SEX)" |
| | | :key="dict.value" |
| | | :value="dict.value" |
| | | v-for="dict in getIntDictOptions(DICT_TYPE.SYSTEM_USER_SEX)" |
| | | :key="dict.value" |
| | | :value="dict.value" |
| | | > |
| | | {{ dict.label }} |
| | | </el-radio> |
| | | </el-radio-group> |
| | | </el-form-item> |
| | | <el-form-item label="预约日期" prop="bookDate"> |
| | | <el-date-picker |
| | | v-model="formData.bookDate" |
| | | type="date" |
| | | value-format="x" |
| | | placeholder="选择预约日期" |
| | | /> |
| | | </el-form-item> |
| | | </div> |
| | | <div class="form-row"> |
| | | <el-form-item label="预约时间" prop="bookTimeslot"> |
| | | <el-select v-model="formData.bookTimeslot" placeholder="请选择预约时间段"> |
| | | <el-option |
| | | v-for="dict in getIntDictOptions(DICT_TYPE.ECG_BOOK_TIMESLOT)" |
| | | :key="dict.value" |
| | | :label="dict.label" |
| | | :value="dict.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="检查项目" prop="bookCheckType"> |
| | | <el-select v-model="formData.bookCheckType" placeholder="请选择预约检查项目"> |
| | | <el-option |
| | | v-for="dict in checkTypeStore.getCheckTypeOptions()" |
| | | :key="dict.value" |
| | | :label="dict.label" |
| | | :value="dict.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | </div> |
| | | <div class="form-row"> |
| | | <el-form-item label="患者生日" prop="patBirthday"> |
| | | <el-date-picker |
| | | v-model="formData.patBirthday" |
| | | type="date" |
| | | value-format="x" |
| | | placeholder="选择患者生日" |
| | | v-model="formData.patBirthday" |
| | | type="date" |
| | | value-format="x" |
| | | placeholder="选择患者生日" |
| | | readonly |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="患者手机" prop="patMobile"> |
| | | <el-input v-model="formData.patMobile" placeholder="请输入患者手机" /> |
| | | </el-form-item> |
| | | </div> |
| | | <div class="form-row"> |
| | | <el-form-item label="患者电话" prop="patPhone"> |
| | | <el-form-item label="患者手机" prop="patMobile" > |
| | | <el-input v-model="formData.patMobile" placeholder="请输入患者手机" readonly /> |
| | | </el-form-item> |
| | | <!-- |
| | | <el-form-item label="患者电话" prop="patPhone" readonly> |
| | | <el-input v-model="formData.patPhone" placeholder="请输入患者电话" /> |
| | | </el-form-item> |
| | | <el-form-item label="身份证号" prop="patIdentityId"> |
| | | <el-input v-model="formData.patIdentityId" placeholder="请输入身份证号" /> |
| | | --> |
| | | <el-form-item label="身份证号" prop="patIdentityId" > |
| | | <el-input v-model="formData.patIdentityId" placeholder="请输入身份证号" readonly /> |
| | | </el-form-item> |
| | | </div> |
| | | <div class="form-row"> |
| | | <el-form-item label="患者地址" prop="patAddr"> |
| | | <el-input v-model="formData.patAddr" placeholder="请输入患者地址" /> |
| | | </el-form-item> |
| | | <el-form-item label="科室代码" prop="patDeptCode"> |
| | | <el-input v-model="formData.patDeptCode" placeholder="请输入科室代码" /> |
| | | </el-form-item> |
| | | </div> |
| | | <div class="form-row"> |
| | | <el-form-item label="科室名称" prop="patDeptDesc"> |
| | | <el-input v-model="formData.patDeptDesc" placeholder="请输入科室名称" /> |
| | | </el-form-item> |
| | | <el-form-item label="病区代码" prop="patWardCode"> |
| | | <!-- |
| | | <el-form-item label="病区代码" prop="patWardCode" readonly> |
| | | <el-input v-model="formData.patWardCode" placeholder="请输入病区代码" /> |
| | | </el-form-item> |
| | | --> |
| | | <el-form-item label="病区名称" prop="patWardDesc" > |
| | | <el-input v-model="formData.patWardDesc" placeholder="请输入病区名称" readonly /> |
| | | </el-form-item> |
| | | <el-form-item label="床号" prop="patBedNo" > |
| | | <el-input v-model="formData.patBedNo" placeholder="请输入床号" readonly /> |
| | | </el-form-item> |
| | | </div> |
| | | <div class="form-row"> |
| | | <el-form-item label="病区名称" prop="patWardDesc"> |
| | | <el-input v-model="formData.patWardDesc" placeholder="请输入病区名称" /> |
| | | <!-- |
| | | <el-form-item label="科室代码" prop="patDeptCode" readonly> |
| | | <el-input v-model="formData.patDeptCode" placeholder="请输入科室代码" /> |
| | | </el-form-item> |
| | | --> |
| | | <el-form-item label="科室名称" prop="patDeptDesc" > |
| | | <el-input v-model="formData.patDeptDesc" placeholder="请输入科室名称" readonly/> |
| | | </el-form-item> |
| | | <el-form-item label="床号" prop="patBedNo"> |
| | | <el-input v-model="formData.patBedNo" placeholder="请输入床号" /> |
| | | <el-form-item label="患者地址" prop="patAddr"> |
| | | <el-input v-model="formData.patAddr" placeholder="请输入患者地址" readonly/> |
| | | </el-form-item> |
| | | </div> |
| | | </el-form> |
| | |
| | | import {DICT_TYPE, getIntDictOptions} from '@/utils/dict' |
| | | import { AppointmentApi, AppointmentVO } from '@/api/ecg/appointment' |
| | | import {useCheckTypeStore} from "@/store/modules/checkType"; |
| | | import CheckItemPanel from "@/views/ecg/appointment/CheckItemPanel.vue"; |
| | | import {RoomStatus} from "@/components/RoomStatus"; |
| | | |
| | | /** 预约确认 表单 */ |
| | | defineOptions({ name: 'AppointmentConfirm' }) |
| | |
| | | patId: undefined |
| | | }) |
| | | |
| | | const appointmentVOList = ref<AppointmentVO[]>([]) |
| | | |
| | | const formData = ref<AppointmentVO>({ |
| | | id: 0, |
| | | applyNo: "", |
| | | patSrc: 0, |
| | | patId: "", |
| | | patName: "", |
| | | patGender: 1, // 1 男 2 女 |
| | |
| | | bookId: "", |
| | | bookTime: new Date(), |
| | | bookDate: new Date(), |
| | | bookTimeslot: 9000930, |
| | | bookTimeslot: 9301030, |
| | | bookCheckType: checkTypeStore.getCheckTypeName(100) |
| | | }) |
| | | const formRef = ref() // 表单 Ref |
| | |
| | | |
| | | const data = await AppointmentApi.queryAndCreateAppointmentByPatId(queryParams.patId) // 对应数据库中 pat_id |
| | | console.info( data ) |
| | | appointmentVOList.value = data |
| | | if (null !== data) { |
| | | formData.value = data |
| | | formData.value = data[0] |
| | | console.info( formData.value ) |
| | | return |
| | | } |
| | | |
| | |
| | | }) |
| | | } |
| | | |
| | | const _confirmAppointment = async () => { |
| | | const data = await AppointmentApi.confirmAppointment(formData.value) |
| | | ElNotification({ |
| | | title: '温馨提示', |
| | | message: data, |
| | | type: 'warning' |
| | | }) |
| | | } |
| | | |
| | | /** 重置表单 */ |
| | | const resetForm = () => { |
| | | formData.value = { |
| | | id: 0, |
| | | applyNo: "", |
| | | patSrc: 0, |
| | | patId: "", |
| | | patName: "", |
| | | patGender: 1, // 1 男 2 女 |
| | |
| | | bookId: "", |
| | | bookTime: new Date(), |
| | | bookDate: new Date(), |
| | | bookTimeslot: 9000930, |
| | | bookCheckType: 10 |
| | | bookTimeslot: 9301030, |
| | | bookCheckType: checkTypeStore.getCheckTypeName(100) |
| | | } |
| | | formRef.value?.resetFields() |
| | | } |
| | |
| | | .two-column-form .form-row .el-form-item { |
| | | width: 48%; |
| | | } |
| | | |
| | | .el-form-item { |
| | | margin-bottom: 5px; |
| | | } |
| | | |
| | | </style> |