From a5201d322eff02c959d76028d3deb4a0d8af454a Mon Sep 17 00:00:00 2001
From: chenyincheng <501753378@qq.com>
Date: 星期二, 25 四月 2023 10:02:53 +0800
Subject: [PATCH] 45
---
src/views/home/index.vue | 161 +++++++++++++++++++++++++++++++++++------------------
1 files changed, 105 insertions(+), 56 deletions(-)
diff --git a/src/views/home/index.vue b/src/views/home/index.vue
index 35ed034..5787982 100644
--- a/src/views/home/index.vue
+++ b/src/views/home/index.vue
@@ -13,13 +13,6 @@
import state2 from '@/assets/state2.png'
import state3 from '@/assets/state3.png'
import logo from '@/assets/LOGO.png'
-import step6 from '@/assets/mp3/step6.mp3'
-import step5 from '@/assets/mp3/step5.mp3'
-import step4 from '@/assets/mp3/step4.mp3'
-import step3 from '@/assets/mp3/step3.mp3'
-import step2 from '@/assets/mp3/step2.mp3'
-import step1 from '@/assets/mp3/step1.mp3'
-import step7 from '@/assets/mp3/chongfuchengzhong.mp3'
import login from '@/views/login/index.vue'
import { confingInfoStore } from '@/stores/StoresConfing'
import { ElMessage } from 'element-plus'
@@ -41,6 +34,11 @@
return !sockte.isLink
})
const netLink = computed(() => {
+ if(!sockte.netLink){
+ ipcRenderer.invoke('logger', '网络已经断开')
+ }else{
+ ipcRenderer.invoke('logger', '网络已经恢复')
+ }
return !sockte.netLink
})
const weightInfo = computed(() => {
@@ -67,7 +65,6 @@
state.clockNum = patientInfoStore().viewNumber
// 清除定时器
clearInterval(state.timerNum)
- console.log('------------------')
timer = setInterval(() => {
if (state.clockNum > 0) {
state.clockNum--
@@ -157,13 +154,6 @@
fasongNum:0,
caozuo: 0,// 点击10下才能关闭
logo: logo,
- step5: step5,
- step4: step4,
- step3: step3,
- step7: step7,
- step2: step2,
- step1: step1,
- step6: step6,
state1: state1,
state2: state2,
state3: state3,
@@ -179,42 +169,42 @@
mai_bu: "",//脉搏,
haodu: "0px",
})
+ // 监控患者信息变化
watch(
() => patientInfo.value.datetime,
() => {
- console.log('患者信息变化,置空临时患者code', patientInfo.value)
patientCodeLs = ''
patientCodeLsXy = ''
- console.log(patientCodeLs, '患者codec初始化')
state.aimTSL = ''
- sockteStore().setweightSockte({
- type: "体重秤",
- state: 2,
- deviceName: "",
- result: "0",
- resultTime: ""
- })
- sockteStore().setxyjSockte({
- type: "血压计",
- state: 2,
- deviceName: "",
- result: "",
- resultTime: ""
- })
+ // 定时数秒器
settime()
if (patientInfo.value.id !== 0 && patientInfo.value.name !== '' && patientInfo.value.isScheduled === 1) {
+ // console.log(`患者信息识别成功:${patientInfo.value.name}`)
+ ipcRenderer.invoke('logger', `患者信息识别成功:${patientInfo.value.name}`)
let str = `${patientInfo.value.name}识别成功。`
state.dialogVisible = false
speech.value?.speak({ text: str }).then(() => {
- console.log("播报完成...")
+ })
+ sockteStore().setweightSockte({
+ type: "体重秤",
+ state: 2,
+ deviceName: "",
+ result: "0",
+ resultTime: ""
+ })
+ sockteStore().setxyjSockte({
+ type: "血压计",
+ state: 2,
+ deviceName: "",
+ result: "",
+ resultTime: ""
})
}
// 没有找到患者
else if (patientInfo.value.name === '') {
- // speech.value?.speak({ text: "没有找到患者,请重新刷卡" }).then(() => {
- // console.log("播报完成...")
- // })
+ ipcRenderer.invoke('logger', '接收到的患者为空')
+ // console.log('接收到的患者为空')
if (isUseFaceRecogService.value) {
state.dialogVisible = true
}
@@ -222,24 +212,39 @@
}
// 没有排班
else if (patientInfo.value.isScheduled === 0) {
+ ipcRenderer.invoke('logger', `患者没有排班:${patientInfo.value.name}`)
+ // console.log( `患者没有排班:${patientInfo.value.name}`)
//关闭人脸弹框
state.dialogVisible = false
speech.value?.speak({ text: `${patientInfo.value.name}今日没有排班,不能自助签到` }).then(() => {
- console.log("播报完成...")
+ // console.log("播报完成...")
})
- // if (isUseFaceRecogService.value) {
- // state.dialogVisible = true
- // }
+ sockteStore().setweightSockte({
+ type: "体重秤",
+ state: 2,
+ deviceName: "",
+ result: "0",
+ resultTime: ""
+ })
+ sockteStore().setxyjSockte({
+ type: "血压计",
+ state: 2,
+ deviceName: "",
+ result: "",
+ resultTime: ""
+ })
return
}
}
);
+ // 体重发生了变化
watch(
() => weightInfo.value.resultTime,
async () => {
- console.log("体重变化了", weightInfo.value)
// 体重不能0
if (weightInfo.value.result !== "0"&&patientInfo.value.code!=='') {
+ ipcRenderer.invoke('logger', `体重变化了:${weightInfo.value.result}`)
+ console.log(`体重变化了:${weightInfo.value.result}`)
// 发送结果到sockte服务
const mode = {
patientCode: patientInfo.value.code,
@@ -248,13 +253,15 @@
}
if (patientCodeLs !== mode.patientCode) {
const tt = mode.weight.replace('.', '点')
- console.log('发送患者结果', tt)
speech.value?.speak({ text: `称重完成,${tt}kg` }).then(() => {
console.log("播报完成...")
})
patientCodeLs = mode.patientCode
state.fasongNum=0
- sundMode(mode)
+ // console.log(`开始发送结果到服务器:患者:${patientInfo.value.name},体重结果:${weightInfo.value.result}`)
+ ipcRenderer.invoke('logger', `开始发送结果到服务器:患者:${patientInfo.value.name},体重结果:${weightInfo.value.result}`)
+ console.log(`开始发送结果到服务器:患者:${patientInfo.value.name},体重结果:${weightInfo.value.result}`)
+ sundModeTz()
}
else {
// 临时患者code=当前患者code
@@ -267,34 +274,38 @@
}
}
);
+ // 血压发送了变化
watch(
() => xyjInfo.value.resultTime,
async () => {
if (xyjInfo.value.result !== '') {
+ ipcRenderer.invoke('logger', `血压发生变化了:${weightInfo.value.result}`)
+ console.log(`血压发生变化了:${weightInfo.value.result}`)
const list = xyjInfo.value.result.split(',')
if (list.length === 3) {
state.gao_ya = list[0]
state.di_ya = list[1]
state.mai_bu = list[2]
}
+ // 患者信息为空
if (patientInfo.value.id === 0) {
speech.value?.speak({ text: "没有识别的患者,请先验证患者" }).then(() => {
- console.log("播报完成...")
+ // console.log("播报完成...")
})
+ // 有患者信息
} else {
speech.value?.speak({ text: `收缩压:${state.gao_ya},舒张压:${state.di_ya},脉搏:${state.mai_bu}` }).then(() => {
- console.log("播报完成...")
+ // console.log("播报完成...")
})
const mode = {
patientCode: patientInfo.value.code,
weight: '',
bloodPressure: xyjInfo.value.result
-
}
- // 写入vuex
- // sendPationSet(mode)
state.fasongNum=0
- sundMode(mode)
+ // console.log(`开始发送结果到服务器:患者:${patientInfo.value.name},血压结果:${mode.bloodPressure}`)
+ ipcRenderer.invoke('logger', `开始发送结果到服务器:患者:${patientInfo.value.name},血压结果:${mode.bloodPressure}`)
+ sundModeXyj()
}
} else {
state.gao_ya = ""
@@ -310,7 +321,7 @@
console.log(dkqInfo.value, '读卡器')
if (dkqInfo.value.result !== '' && dkqInfo.value.result !== undefined) {
const code = dkqInfo.value.result.split(",")[0]
- console.log('获取读卡器的code', code)
+ console.log(`获取读卡器的code=${code},发送到服务请求患者信息`)
sendPationCodeApi(code)
}
}
@@ -319,8 +330,8 @@
watch(
()=>faceInfo.value.result,
()=>{
- console.log('页面收到了人脸识别')
if(faceInfo.value.result!==''){
+ console.log(`获取人脸识别code=${faceInfo.value.result},发送到服务请求患者信息`)
sendPationCodeApi(faceInfo.value.result)
}
}
@@ -330,21 +341,60 @@
state.clockNum = viewNumber.value
}
);
- const sundMode= (mode:any)=>{
+ const sundModeTz= ()=>{
+ const mode = {
+ patientCode: patientInfo.value.code,
+ weight: weightInfo.value.result,
+ bloodPressure: ''
+ }
state.fasongNum++
- // const res= await updatePatient(mode)
+ ipcRenderer.invoke('logger', `患者结果上传,第${state.fasongNum}次`)
+ ipcRenderer.invoke('logger', '参数:'+JSON.stringify(mode))
updatePatient(mode).then(re=>{
ElMessage.success('结果发送成功')
+ ipcRenderer.invoke('logger', '结果上传成功')
setTimeout(() => {
fuxuan()
- },5000)
+ },8000)
return false
}).catch(re=>{
ElMessage('结果发送失败')
+ console.log('结果发送失败')
+ ipcRenderer.invoke('logger', `结果发送失败:第${state.fasongNum}次,3秒后重新发送`)
if(state.fasongNum<3){
- setTimeout(sundMode,1000);
+ setTimeout(sundModeTz,5000);
}
else{
+ ipcRenderer.invoke('logger', '3次结果上传都失败放弃本次请求')
+ return false
+ }
+ })
+ }
+ const sundModeXyj= ()=>{
+ const mode = {
+ patientCode: patientInfo.value.code,
+ weight: '',
+ bloodPressure: xyjInfo.value.result
+ }
+ state.fasongNum++
+ ipcRenderer.invoke('logger', `患者结果上传,第${state.fasongNum}次`)
+ ipcRenderer.invoke('logger', '参数:'+JSON.stringify(mode))
+ updatePatient(mode).then(re=>{
+ ElMessage.success('结果发送成功')
+ ipcRenderer.invoke('logger', '结果上传成功')
+ setTimeout(() => {
+ fuxuan()
+ },8000)
+ return false
+ }).catch(re=>{
+ ElMessage('结果发送失败')
+ console.log('结果发送失败')
+ ipcRenderer.invoke('logger', `结果发送失败:第${state.fasongNum}次,3秒后重新发送`)
+ if(state.fasongNum<3){
+ setTimeout(sundModeXyj,5000);
+ }
+ else{
+ ipcRenderer.invoke('logger', '3次结果上传都失败放弃本次请求')
return false
}
})
@@ -360,7 +410,6 @@
if (state.caozuo > 10) {
ipcRenderer.send('winClose')
}
- console.log(state.caozuo)
}
onMounted(() => {
console.log('页面初始化', os.hostname())
@@ -397,7 +446,7 @@
<template>
<div class="devcont">
<div class="pagehome" v-if="isUseFaceRecogService">
- <el-dialog v-model="dialogVisible" width="800px" center :show-close="false">
+ <el-dialog v-model="dialogVisible" :close-on-click-modal="false" width="800px" center :show-close="false">
<template>
<div class="my-header">
<h4>人脸识别中。。。</h4>
--
Gitblit v1.8.0