From 1d17d5432a2fb64be9f6f7dc424cdd757d748fea Mon Sep 17 00:00:00 2001
From: zhangchen <1652267879@qq.com>
Date: 星期六, 06 九月 2025 15:45:29 +0800
Subject: [PATCH] ID2040-x
---
src/store/type/bedsideAuxiliaryScreen.type.ts | 69 +++++++++++++++++++++++++++++++---
1 files changed, 63 insertions(+), 6 deletions(-)
diff --git a/src/store/type/bedsideAuxiliaryScreen.type.ts b/src/store/type/bedsideAuxiliaryScreen.type.ts
index 20b3abf..7659f7d 100644
--- a/src/store/type/bedsideAuxiliaryScreen.type.ts
+++ b/src/store/type/bedsideAuxiliaryScreen.type.ts
@@ -1,5 +1,5 @@
import { tryConvertToInt, deepClone } from "@/utils/utils";
-import cache from "@/utils/cache";
+import { Local } from "@/utils/storage";
export interface IotInfo {
属性历史列表: any[];
床号: string;
@@ -121,6 +121,10 @@
透析结束时间: number | null;
透析处方备注: string;
最近最大脱水量透析时长: string;
+ 透析龄: number | null;
+ iot_血液流速: number | null;
+ 透析液流量: number | null;
+ 患者出生日期: string;
}
export interface VascularAccess {
@@ -173,6 +177,14 @@
推送类型: PushType;
透析状态: DialysisStatus | null;
床旁血压结果?: any;
+ 自定义配置项: Customconfiguration;
+ 服务端版本号: string;
+ 是否需要立即刷新: 0 | 1;
+}
+
+interface Customconfiguration {
+ 患者信息是否加密显示: number;
+ 是否显示患者出生年月日: number;
}
export interface Sphygmomanometer {
@@ -184,6 +196,8 @@
export interface BedsideAuxiliaryScreen {
deviceCode: string;
devicdeNo: string | number;
+ version: string;
+ isRefresh: number;
recordCode: string;
patientCode: string;
patientName: string;
@@ -199,6 +213,8 @@
signedIn: SignedIn;
underTreatment: UnderTreatment;
sphygmomanometer: Sphygmomanometer;
+ customConfiguration: Customconfiguration;
+ 患者出生日期: string;
}
export const defaultSphygmomanometer = () :Sphygmomanometer => {
@@ -307,6 +323,7 @@
weightAfterLastDialysis: number | null; // 上次透后称重
weightIncrease: number | null; // 体重增加
weightIncreaseRate: number | null; // 体重增长率
+ maximumDehydrationDuration: string;
}
export const defaultSignedIn = (): SignedIn => {
@@ -323,6 +340,7 @@
weightAfterLastDialysis: null, // 上次透后称重
weightIncrease: null, // 体重增加
weightIncreaseRate: null, // 体重增长率
+ maximumDehydrationDuration: '',
};
};
@@ -355,6 +373,9 @@
bloodVolumeMonitoring: number | null; // 血容量监测
dialysisFluidFlowRate: number | null; // 透析液流量
ktvList: KtvItem[]; // 实时ktv计算结果列表
+ dialysisAge: number | null, // 透析龄
+ venousPressure2: number | null; // 静脉压
+ transmembranePressure2: number | null; // 跨膜压
}
export interface MonitoringRecord {
@@ -393,16 +414,21 @@
dialysisFluidFlowRate: null,
ktvList: [],
prescriptionDialysisDuration: null, // 透析处方的时长(单位:小时)
+ dialysisAge: null,
+ venousPressure2: null, // 静脉压
+ transmembranePressure2: null, // 跨膜压
};
};
export const defaultDeviceData = (): BedsideAuxiliaryScreen => {
- const pageType = cache.get("devcieCode")
+ const pageType = Local.get("devcieCode")
? EPageType.LOADING
: EPatForm.OUTPATIENT_SERVICE;
return {
deviceCode: "", // 设备code
devicdeNo: "", // 设备号
+ version: "0.0.0", // 版本号
+ isRefresh: 0, // 是否立即刷新
recordCode: "", // 透析单code
patientCode: "", // 患者code
patientName: "", // 患者姓名
@@ -411,6 +437,7 @@
gender: "", // 性别
patForm: EPatForm.OUTPATIENT_SERVICE, // 患者来源
patFormNumber: "", // 住院门诊号
+ customConfiguration: defaultCustomconfiguration(), // 自定义配置项
// @ts-ignore
pageType, // 当前要展示的页面
treatmentStatus: EMedStatus.NOT_CHECKED_IN, // 透析状态
@@ -419,8 +446,16 @@
signedIn: defaultSignedIn(), // 已签到时需要的数据
underTreatment: defaultUnderTreatment(), // 治疗中需要的数据
sphygmomanometer: defaultSphygmomanometer(), // 血压计传过来的数据
+ 患者出生日期: '',
};
};
+
+export const defaultCustomconfiguration = (): Customconfiguration => {
+ return {
+ 患者信息是否加密显示: 0,
+ 是否显示患者出生年月日: 0
+ }
+}
export const formatDeviceData = (
data: BedsideAuxiliaryScreen,
@@ -429,10 +464,17 @@
const result = deepClone(data);
+ // 版本号/是否立即刷新
+ result.version = seeMsg.服务端版本号;
+ result.isRefresh = seeMsg.是否需要立即刷新;
+
// 默认床号(设备号)
result.devicdeNo = seeMsg.IOT信息?.床号;
result.deviceCode = seeMsg.IOT信息?.设备唯一编号;
+
+ // 自定义配置项
+ result.customConfiguration = seeMsg.自定义配置项 ?? defaultCustomconfiguration();
if (seeMsg.推送类型 === EPushType.SPHYGMOMANOMETR) {
result.pageType = EPageType.SPHYGMOMANOMETER;
@@ -465,6 +507,7 @@
result.gender = seeMsg.透析状态?.性别 + "";
result.patForm = seeMsg.透析状态?.患者来源;
result.patFormNumber = seeMsg.透析状态?.患者门诊住院号;
+ result.patFormNumber = seeMsg.透析状态?.患者出生日期;
// 未签到页面需要显示的
if (treatmentStatus === EMedStatus.NOT_CHECKED_IN) {
@@ -501,6 +544,8 @@
seeMsg.透析状态?.上次透后称重 ?? null;
signedIn.weightIncrease = seeMsg.透析状态?.体重增加 ?? null;
signedIn.weightIncreaseRate = seeMsg.透析状态?.体重增长率 ?? null;
+ signedIn.maximumDehydrationDuration =
+ seeMsg.透析状态?.最近最大脱水量透析时长 ?? "";
result.signedIn = signedIn;
}
@@ -540,19 +585,31 @@
seeMsg.透析状态?.iot_脱水速率 ?? null;
underTreatment.currentBloodTemperature =
seeMsg.透析状态?.当前血温 ?? null;
- underTreatment.venousPressure = seeMsg.透析状态?.iot_静脉压 ?? null;
- underTreatment.transmembranePressure =
+ // 血压取监测记录的最后一条数据
+ if (seeMsg.透析状态?.监测记录列表 && seeMsg.透析状态?.监测记录列表.length > 0) {
+ const lastItem = seeMsg.透析状态?.监测记录列表[seeMsg.透析状态?.监测记录列表.length -1];
+ underTreatment.venousPressure = lastItem?.伸缩压 ?? null;
+ underTreatment.transmembranePressure = lastItem?.舒张压 ?? null;
+ } else {
+ underTreatment.venousPressure = null;
+ underTreatment.transmembranePressure = null;
+ }
+ underTreatment.venousPressure2 = seeMsg.透析状态?.iot_静脉压 ?? null;
+ underTreatment.transmembranePressure2 =
seeMsg.透析状态?.iot_跨膜压 ?? null;
underTreatment.ktv = seeMsg.透析状态?.实时ktv ?? "";
underTreatment.monitoringRecord = seeMsg.透析状态?.监测记录列表 ?? [];
underTreatment.doctorAdvice = seeMsg.透析状态?.透析单医嘱列表 ?? [];
- underTreatment.bloodFlow = seeMsg.透析状态?.iot_血流量 ?? null;
+ // underTreatment.bloodFlow = seeMsg.透析状态?.iot_血流量 ?? null;
+ underTreatment.bloodFlow = seeMsg.透析状态?.iot_血液流速 ?? null;
underTreatment.dialysisFluidFlowRate =
- seeMsg.透析状态?.iot_血流量 ?? null;
+ seeMsg.透析状态?.透析液流量 ?? null;
underTreatment.bloodVolumeMonitoring = null;
underTreatment.ktvList =
seeMsg.透析状态?.实时ktv计算结果列表
?.realTimeKtvCalcDetailResultInfo ?? [];
+ underTreatment.dialysisAge = seeMsg.透析状态?.透析龄 ?? null;
+
result.underTreatment = underTreatment;
}
}
--
Gitblit v1.8.0