src/api/ecg/queue/index.ts | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/api/ecg/screen/index.ts | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/views/ecg/callingscreen/roomscreen.vue | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/views/ecg/queue/QueueForm.vue | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 |
src/api/ecg/queue/index.ts
@@ -9,7 +9,7 @@ bookTimeslot: number // 预约时间段 bookCheckType: number // 预约检查类型 seqNum: number // 排队序号 status: number // 10:排队中 20:候诊准备 30:就诊中 40:就诊完成 50:过号 60:过期 status: number // 10:排队中 15:已召回 20:候诊准备 30:就诊中 40:就诊完成 50:过号 passed: number // 过号标记 expired: number // 预约过期标记 jumpFlag: number //插队标记 src/api/ecg/screen/index.ts
@@ -14,7 +14,7 @@ bookDate: Date // 预约日期 bookCheckType: number // 预约检查类型 seqNum: number // 排队序号 status: number // 10:排队中 20:候诊准备 30:就诊中 40:就诊完成 50:过号 60:过期 status: number // 10:排队中 15:已召回 20:候诊准备 30:就诊中 40:就诊完成 50:过号 passed: number // 过号标记 expired: number // 预约过期标记 called: number src/views/ecg/callingscreen/roomscreen.vue
@@ -1,15 +1,15 @@ <script setup lang="ts"> import {RoomBedVO} from "@/api/ecg/doctor"; import {DICT_TYPE} from "@/utils/dict"; import {RoomApi} from "@/api/ecg/room"; import {CallingVO, statusMap, ScreenApi} from "@/api/ecg/screen"; defineOptions({ name: 'roomscreen' }) const list = ref<CallingVO[]>([]) // 列表的数据 const listPassed = ref<CallingVO[]>([]) // 过号列表的数据 const roomBed : RoomBedVO = ref<RoomBedVO>({ const roomBed = ref<RoomBedVO>({ roomId : null, roomName: null, bedNo: null @@ -17,7 +17,8 @@ const getList = async () => { const data = await ScreenApi.getRoomScreenData() list.value = data list.value = data[1] listPassed.value = data[2] } const getRoomByIp = async () => { @@ -30,6 +31,21 @@ // console.info("...") getList() }, 3000); // 每两秒滚动一次 } const nameDesensitize = (patName) => { if (patName.length == 2) { //截取name 字符串截取第一个字符, return patName.substring(0, 1) + '*'; } else if (patName.length == 3) { //截取第一个和第三个字符 return patName.substring(0, 1) + '*' + patName.substring(2, 3); } else if (patName.length > 3) { //截取第一个和大于第4个字符 return ( patName.substring(0, 1) + '*' + '*' + patName.substring(3, patName.length) ); } } onMounted( () => { @@ -51,7 +67,11 @@ <el-table-column prop="patName" label="患者姓名" width="80"/> width="80"> <template #default="scope"> {{ nameDesensitize(scope.row.patName) }} </template> </el-table-column> <el-table-column label="状态" align="center" :prop="status" width="80"> <template #default="scope"> {{ statusMap.get(scope.row.status) }} @@ -59,6 +79,12 @@ </el-table-column> </el-table> </el-main> <el-footer height="100px" style="padding: 0 0"> <el-header height="30px" style="background-color: #98b8e5; line-height: 30px;">过号区</el-header> <span v-for="(passedItem, index) in listPassed" :key="index"> {{nameDesensitize(passedItem.patName) + " "}} </span> </el-footer> </el-container> </template> src/views/ecg/queue/QueueForm.vue
@@ -29,7 +29,7 @@ <el-form-item label="排队序号" prop="seqNum"> <el-input v-model="formData.seqNum" placeholder="请输入排队序号" /> </el-form-item> <el-form-item label="10:排队中 20:候诊准备 30:就诊中 40:就诊完成 50:过号 60:过期" prop="status"> <el-form-item label="10:排队中 15:已召回 20:候诊准备 30:就诊中 40:就诊完成 50:过号" prop="status"> <el-radio-group v-model="formData.status"> <el-radio label="1">请选择字典生成</el-radio> </el-radio-group> @@ -89,7 +89,7 @@ patName: [{ required: true, message: '患者姓名不能为空', trigger: 'blur' }], bookTimeslot: [{ required: true, message: '预约时间段不能为空', trigger: 'blur' }], seqNum: [{ required: true, message: '排队序号不能为空', trigger: 'blur' }], status: [{ required: true, message: '10:排队中 20:候诊准备 30:就诊中 40:就诊完成 50:过号 60:过期不能为空', trigger: 'blur' }], status: [{ required: true, message: '10:排队中 15:已召回 20:候诊准备 30:就诊中 40:就诊完成 50:过号', trigger: 'blur' }], passed: [{ required: true, message: '过号标记不能为空', trigger: 'blur' }], expired: [{ required: true, message: '预约过期标记不能为空', trigger: 'blur' }] })