From bd04819722a54b11749c040dda40f64ddf5da7e2 Mon Sep 17 00:00:00 2001
From: zhangchen <1652267879@qq.com>
Date: 星期六, 09 八月 2025 17:42:42 +0800
Subject: [PATCH] Merge branch 'master' of http://dh.leon056.com:7499/r/data2/Single_application into ID1963-透析中状态的血压监测修改
---
src/store/type/bedsideAuxiliaryScreen.type.ts | 332 ++++++++++++++++++++++++++++++++++++++++++-------------
1 files changed, 252 insertions(+), 80 deletions(-)
diff --git a/src/store/type/bedsideAuxiliaryScreen.type.ts b/src/store/type/bedsideAuxiliaryScreen.type.ts
index 01f3425..8cdade3 100644
--- a/src/store/type/bedsideAuxiliaryScreen.type.ts
+++ b/src/store/type/bedsideAuxiliaryScreen.type.ts
@@ -1,5 +1,5 @@
-import { tryConvertToInt } from "@/utils/utils";
-import cache from "@/utils/cache";
+import { tryConvertToInt, deepClone } from "@/utils/utils";
+import { Local } from "@/utils/storage";
export interface IotInfo {
属性历史列表: any[];
床号: string;
@@ -32,6 +32,11 @@
type PushType = "床旁血压计" | "中央监控大屏信息";
+export interface KtvItem {
+ 时间: string;
+ ktv: string;
+}
+
export interface DialysisStatus {
clientCode: string;
deviceHospitalCode: string;
@@ -39,9 +44,11 @@
iot_当前脱水量: number | null;
iot_脱水目标量: number | null;
iot_脱水速率: number | null;
+ iot_透析液流速: number | null;
iot_跨膜压: number | null;
iot_透析时间: number | null;
iot_静脉压: number | null;
+ iot_血流量: number | null;
sortOrder: number | null;
txTime: number | null;
上次透后称重: number | null;
@@ -50,7 +57,10 @@
分区编号: string;
处方脱水量: number | null;
实时ktv: string;
- 实时ktv计算结果列表: null | string[];
+ 实时ktv计算结果列表: null | {
+ realTimeKtvCalcDetailResultInfo: KtvItem[];
+ 透析单编号: string;
+ };
实时脱水量: number | null;
干体重: number | null;
年龄: number | null;
@@ -109,6 +119,11 @@
透析液列表: any[];
透析状态: string; // '0.0'这种格式的,得格式化一下
透析结束时间: number | null;
+ 透析处方备注: string;
+ 最近最大脱水量透析时长: string;
+ 透析龄: number | null;
+ iot_血液流速: number | null;
+ 透析液流量: number | null;
}
export interface VascularAccess {
@@ -129,14 +144,14 @@
}
export interface Anticoagulant {
- name: string;
- 单位: string;
- 数量: number | null;
- 总量: number | null;
- 是否为追加: number | null;
- 维持剂量: number | null;
- 追加剂量: number | null;
- 首剂: number | null;
+ name: string;
+ 单位: string;
+ 数量: number | null;
+ 总量: number | null;
+ 是否为追加: number | null;
+ 维持剂量: number | null;
+ 追加剂量: number | null;
+ 首剂: number | null;
}
export interface AnomalyIndex {
@@ -147,15 +162,30 @@
项目结果: string;
}
+export interface Countdown {
+ 当前服务器时间?: string;
+ 提醒文本?: string;
+ 提醒文本字典?: any[];
+ 设定提醒倒计时?: number;
+}
+
export interface SseMsgData {
IOT信息: IotInfo | null;
使用耗材字典: ConsumablesCollection | null; // 当透析状态为治疗中时该字段为null
- 倒计时: "";
+ 倒计时: Countdown | null;
推送类型: PushType;
透析状态: DialysisStatus | null;
+ 床旁血压结果?: any;
+}
+
+export interface Sphygmomanometer {
+ sbp: number | null; // 高压
+ dbp: number | null; // 低压
+ pulseRate: number | null; // 心率
}
export interface BedsideAuxiliaryScreen {
+ deviceCode: string;
devicdeNo: string | number;
recordCode: string;
patientCode: string;
@@ -169,8 +199,18 @@
consumablesCollection: ConsumablesCollection;
pageType: PageType;
notSignedIn: NotSignedIn;
+ signedIn: SignedIn;
underTreatment: UnderTreatment;
+ sphygmomanometer: Sphygmomanometer;
}
+
+export const defaultSphygmomanometer = () :Sphygmomanometer => {
+ return {
+ sbp: null,
+ dbp: null,
+ pulseRate: null,
+ }
+}
export enum EPageType {
NOT_INIT = 0, // 未初始化(没有设备编号)
@@ -259,11 +299,35 @@
export interface SignedIn {
abnormalItems: AnomalyIndex[];
+ dialysisPlan: string; // 透析方案
+ prescriptionDehydrationVolume: number | null; // 透析处方脱水量
+ dialyzer: string; // 透析器
+ averageDehydrationRate: string; // 最近平均脱水量
+ maximumDehydrationCapacity: string; // 最近最大脱水量
+ maximumDehydrationCapacityDate: string; // 最近最大脱水量日期
+ dryWeight: number | null; // 干体重
+ preDialysisWeight: number | null; // 透前称重
+ weightAfterLastDialysis: number | null; // 上次透后称重
+ weightIncrease: number | null; // 体重增加
+ weightIncreaseRate: number | null; // 体重增长率
+ maximumDehydrationDuration: string;
}
export const defaultSignedIn = (): SignedIn => {
return {
abnormalItems: [], // 异常指标列表
+ dialysisPlan: "", // 透析方案
+ prescriptionDehydrationVolume: null, // 透析处方脱水量
+ dialyzer: "", // 透析器
+ averageDehydrationRate: "", // 最近平均脱水量
+ maximumDehydrationCapacity: "", // 最近最大脱水量
+ maximumDehydrationCapacityDate: "", // 最近最大脱水量日期
+ dryWeight: null, // 干体重
+ preDialysisWeight: null, // 透前称重
+ weightAfterLastDialysis: null, // 上次透后称重
+ weightIncrease: null, // 体重增加
+ weightIncreaseRate: null, // 体重增长率
+ maximumDehydrationDuration: '',
};
};
@@ -277,7 +341,9 @@
maximumDehydrationDuration: string; // 最大脱水量那天的时长
prescriptionRemarks: string; // 透析处方备注
abnormalItems: AnomalyIndex[]; // 异常指标列表
- prescriptionDialysisDuration: string; // 透析处方的时长(单位:小时)
+ prescriptionDialysisDurationHour: string; // 透析处方的时长(小时部分)
+ prescriptionDialysisDurationMin: string; // 透析处方的时长(分钟部分)
+ prescriptionDialysisDuration: number | null; // 透析处方的时长(单位:小时)
dialysisStartTime: number | null; // 透析开始时间(时间戳)
dialysisEndTime: number | null; // 透析结束时间(时间戳)
dialysisDuration: number | null; // 已透析时长(单位:分钟)
@@ -290,13 +356,16 @@
ktv: string; // 实时ktv
monitoringRecord: MonitoringRecord[]; // 监测记录列表
doctorAdvice: any[]; // 透析单医嘱列表
- bloodFlow: string; // 血流量
- bloodVolumeMonitoring: string; // 血容量监测
- dialysisFluidFlowRate: string; // 透析液流速
- ktvList: string[]; // 实时ktv计算结果列表
+ bloodFlow: number | null; // 血流量
+ bloodVolumeMonitoring: number | null; // 血容量监测
+ dialysisFluidFlowRate: number | null; // 透析液流量
+ ktvList: KtvItem[]; // 实时ktv计算结果列表
+ dialysisAge: number | null, // 透析龄
+ venousPressure2: number | null; // 静脉压
+ transmembranePressure2: number | null; // 跨膜压
}
-interface MonitoringRecord {
+export interface MonitoringRecord {
伸缩压: string; // 血压伸缩压
舒张压: string; // 血压舒张压
脉搏: string; // 脉搏
@@ -313,7 +382,8 @@
maximumDehydrationDuration: "",
prescriptionRemarks: "",
abnormalItems: [],
- prescriptionDialysisDuration: "",
+ prescriptionDialysisDurationHour: "",
+ prescriptionDialysisDurationMin: "",
dialysisStartTime: null,
dialysisEndTime: null,
dialysisDuration: null,
@@ -326,18 +396,23 @@
ktv: "",
monitoringRecord: [],
doctorAdvice: [],
- bloodFlow: "",
- bloodVolumeMonitoring: "",
- dialysisFluidFlowRate: "",
+ bloodFlow: null,
+ bloodVolumeMonitoring: null,
+ 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: "", // 设备号
recordCode: "", // 透析单code
patientCode: "", // 患者code
@@ -352,26 +427,40 @@
treatmentStatus: EMedStatus.NOT_CHECKED_IN, // 透析状态
consumablesCollection: defaultconsumablesCollection(), // 未排班时需要的数据
notSignedIn: defalutNotSignedIn(), // 未签到时需要的数据
+ signedIn: defaultSignedIn(), // 已签到时需要的数据
underTreatment: defaultUnderTreatment(), // 治疗中需要的数据
+ sphygmomanometer: defaultSphygmomanometer(), // 血压计传过来的数据
};
};
export const formatDeviceData = (
+ data: BedsideAuxiliaryScreen,
seeMsg: SseMsgData
): BedsideAuxiliaryScreen => {
- const result = defaultDeviceData();
+
+ const result = deepClone(data);
+
// 默认床号(设备号)
result.devicdeNo = seeMsg.IOT信息?.床号;
+ result.deviceCode = seeMsg.IOT信息?.设备唯一编号;
if (seeMsg.推送类型 === EPushType.SPHYGMOMANOMETR) {
result.pageType = EPageType.SPHYGMOMANOMETER;
+
+ const sphygmomanometer = defaultSphygmomanometer();
+ sphygmomanometer.sbp = seeMsg?.床旁血压结果?.sbp;
+ sphygmomanometer.pulseRate = seeMsg?.床旁血压结果?.pulseRate;
+ sphygmomanometer.dbp = seeMsg?.床旁血压结果?.dbp;
+
+ result.sphygmomanometer = sphygmomanometer;
+
} else if (seeMsg.推送类型 === EPushType.CENTRAL_MONITORING) {
// 判断是否存在透析状态,如果不存在就是没有排班
if (seeMsg.透析状态 === null || !seeMsg.透析状态) {
result.pageType = EPageType.UNPLANNED_SCHEDULE;
result.consumablesCollection =
- seeMsg?.使用耗材字典 || defaultconsumablesCollection();
+ seeMsg?.使用耗材字典 ?? defaultconsumablesCollection();
} else {
const treatmentStatus = tryConvertToInt(
seeMsg.透析状态?.透析状态
@@ -388,85 +477,168 @@
result.patForm = seeMsg.透析状态?.患者来源;
result.patFormNumber = seeMsg.透析状态?.患者门诊住院号;
- // switch(treatmentStatus) {
- // case EMedStatus.NOT_CHECKED_IN:
- // result.pageType = EPageType.NOT_SIGNED_IN;
- // const notSignedIn = {
- // dialysisMode: seeMsg.透析状态?.透析方案,
- // dialyzerList: seeMsg.透析状态?.透析器列表,
- // pipingList: seeMsg.透析状态?.管路列表,
- // dialysateList: seeMsg.透析状态?.透析液列表,
- // carePackage: seeMsg.透析状态?.护理包列表,
- // punctureNeedle: seeMsg.透析状态?.穿刺针列表,
- // vascularAccess: seeMsg.透析状态?.血管通路列表,
- // anticoagulant: [],
- // }
- // result.notSignedIn = notSignedIn;
- // break
- // }
// 未签到页面需要显示的
if (treatmentStatus === EMedStatus.NOT_CHECKED_IN) {
result.pageType = EPageType.NOT_SIGNED_IN;
const notSignedIn = defalutNotSignedIn();
- notSignedIn.dialysisMode = seeMsg.透析状态?.透析方案 || "";
- notSignedIn.dialyzerList = seeMsg.透析状态?.透析器列表 || [];
- notSignedIn.pipingList = seeMsg.透析状态?.管路列表 || [];
- notSignedIn.dialysateList = seeMsg.透析状态?.透析液列表 || [];
- notSignedIn.carePackage = seeMsg.透析状态?.护理包列表 || [];
- notSignedIn.punctureNeedle = seeMsg.透析状态?.穿刺针列表 || [];
- notSignedIn.vascularAccess = seeMsg.透析状态?.血管通路列表 || [];
- notSignedIn.anticoagulant = seeMsg.透析状态?.抗凝剂列表 || [];
+ notSignedIn.dialysisMode = seeMsg.透析状态?.透析方案 ?? "";
+ notSignedIn.dialyzerList = seeMsg.透析状态?.透析器列表 ?? [];
+ notSignedIn.pipingList = seeMsg.透析状态?.管路列表 ?? [];
+ notSignedIn.dialysateList = seeMsg.透析状态?.透析液列表 ?? [];
+ notSignedIn.carePackage = seeMsg.透析状态?.护理包列表 ?? [];
+ notSignedIn.punctureNeedle = seeMsg.透析状态?.穿刺针列表 ?? [];
+ notSignedIn.vascularAccess = seeMsg.透析状态?.血管通路列表 ?? [];
+ notSignedIn.anticoagulant = seeMsg.透析状态?.抗凝剂列表 ?? [];
result.notSignedIn = notSignedIn;
}
// 已签到未开始透析需要显示的
- else if (treatmentStatus === EMedStatus.SIGNED_IN) {}
+ else if (treatmentStatus === EMedStatus.SIGNED_IN) {
+ result.pageType = EPageType.SIGNED_IN;
+ const signedIn = defaultSignedIn();
+ signedIn.abnormalItems = seeMsg.透析状态?.异常检验指标 ?? [];
+ signedIn.dialysisPlan = seeMsg.透析状态?.透析方案 ?? "";
+ signedIn.prescriptionDehydrationVolume =
+ seeMsg.透析状态?.处方脱水量 ?? null;
+ signedIn.dialyzer = seeMsg.透析状态?.透析器 ?? "";
+ signedIn.averageDehydrationRate = seeMsg.透析状态?.最近平均脱水量 ?? "";
+ signedIn.maximumDehydrationCapacity =
+ seeMsg.透析状态?.最近最大脱水量 ?? "";
+ signedIn.maximumDehydrationCapacityDate =
+ seeMsg.透析状态?.最近最大脱水量日期 ?? "";
+ signedIn.dryWeight = seeMsg.透析状态?.干体重 ?? null;
+ signedIn.preDialysisWeight = seeMsg.透析状态?.透前称重 ?? null;
+ signedIn.weightAfterLastDialysis =
+ seeMsg.透析状态?.上次透后称重 ?? null;
+ signedIn.weightIncrease = seeMsg.透析状态?.体重增加 ?? null;
+ signedIn.weightIncreaseRate = seeMsg.透析状态?.体重增长率 ?? null;
+ signedIn.maximumDehydrationDuration =
+ seeMsg.透析状态?.最近最大脱水量透析时长 ?? "";
+
+ result.signedIn = signedIn;
+ }
// 剩下的全使用治疗中的页面
else {
result.pageType = EPageType.DURING_DIALYSIS;
const underTreatment = defaultUnderTreatment();
- underTreatment.substituteMode = seeMsg.透析状态?.置换方式 || "";
- underTreatment.dialysisPlan = seeMsg.透析状态?.透析方案 || "";
- underTreatment.dialyzer = seeMsg.透析状态?.透析器 || "";
+ underTreatment.substituteMode = seeMsg.透析状态?.置换方式 ?? "";
+ underTreatment.dialysisPlan = seeMsg.透析状态?.透析方案 ?? "";
+ underTreatment.dialyzer = seeMsg.透析状态?.透析器 ?? "";
underTreatment.averageDehydrationRate =
- seeMsg.透析状态?.最近平均脱水量 || "";
+ seeMsg.透析状态?.最近平均脱水量 ?? "";
underTreatment.maximumDehydrationCapacity =
- seeMsg.透析状态?.最近最大脱水量 || "";
+ seeMsg.透析状态?.最近最大脱水量 ?? "";
underTreatment.maximumDehydrationCapacityDate =
- seeMsg.透析状态?.最近最大脱水量日期 || "";
- underTreatment.maximumDehydrationDuration = ""
+ seeMsg.透析状态?.最近最大脱水量日期 ?? "";
+ underTreatment.maximumDehydrationDuration =
+ seeMsg.透析状态?.最近最大脱水量透析时长 ?? "";
underTreatment.prescriptionRemarks =
- seeMsg.透析状态?.处方备注 || "";
- underTreatment.abnormalItems = seeMsg.透析状态?.异常检验指标 || [];
+ seeMsg.透析状态?.透析处方备注 ?? "";
+ underTreatment.abnormalItems = seeMsg.透析状态?.异常检验指标 ?? [];
underTreatment.prescriptionDialysisDuration =
- seeMsg.透析状态?.透析处方的时长_小时 || "";
+ seeMsg.透析状态?.透析处方的时长 ?? null;
+ underTreatment.prescriptionDialysisDurationHour =
+ seeMsg.透析状态?.透析处方的时长_小时 ?? "";
+ underTreatment.prescriptionDialysisDurationMin =
+ seeMsg.透析状态?.透析处方的时长_分钟 ?? "";
underTreatment.dialysisStartTime =
- seeMsg.透析状态?.透析开始时间 || null;
- underTreatment.dialysisEndTime =
- seeMsg.透析状态?.透析结束时间 || null;
- underTreatment.dialysisDuration =
- seeMsg.透析状态?.iot_透析时间 || null;
+ seeMsg.透析状态?.透析开始时间 ?? null;
+ underTreatment.dialysisEndTime = seeMsg.透析状态?.透析结束时间 ?? null;
+ underTreatment.dialysisDuration = seeMsg.透析状态?.iot_透析时间 ?? null;
underTreatment.prescriptionDehydrationVolume =
- seeMsg.透析状态?.处方脱水量 || null;
+ seeMsg.透析状态?.iot_脱水目标量 ?? null;
underTreatment.currentDehydrationVolume =
- seeMsg.透析状态?.实时脱水量 || null;
+ seeMsg.透析状态?.iot_当前脱水量 ?? null;
underTreatment.currentUltrafiltrationRate =
- seeMsg.透析状态?.iot_脱水速率 || null;
+ seeMsg.透析状态?.iot_脱水速率 ?? null;
underTreatment.currentBloodTemperature =
- seeMsg.透析状态?.当前血温 || null;
- underTreatment.venousPressure = seeMsg.透析状态?.iot_静脉压 || null;
- underTreatment.transmembranePressure =
- seeMsg.透析状态?.iot_跨膜压 || null;
- underTreatment.ktv = seeMsg.透析状态?.实时ktv || "";
- underTreatment.monitoringRecord = seeMsg.透析状态
- ?.监测记录列表 || [];
- underTreatment.doctorAdvice = seeMsg.透析状态?.透析单医嘱列表 || [];
- underTreatment.bloodFlow = "";
- underTreatment.dialysisFluidFlowRate = "";
- underTreatment.bloodVolumeMonitoring = "";
- underTreatment.ktvList = seeMsg.透析状态?.实时ktv计算结果列表 || [];
+ seeMsg.透析状态?.当前血温 ?? null;
+ // 血压取监测记录的最后一条数据
+ 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.dialysisFluidFlowRate =
+ seeMsg.透析状态?.透析液流量 ?? null;
+ underTreatment.bloodVolumeMonitoring = null;
+ underTreatment.ktvList =
+ seeMsg.透析状态?.实时ktv计算结果列表
+ ?.realTimeKtvCalcDetailResultInfo ?? [];
+ underTreatment.dialysisAge = seeMsg.透析状态?.透析龄 ?? null;
+
+ result.underTreatment = underTreatment;
}
}
}
return result;
};
+
+export const getItemName = (name: string) => {
+ if (name) {
+ if (name === "血红蛋白") {
+ return "HGB ";
+ } else if (name === "铁蛋白") {
+ return "FER ";
+ } else if (name === "白蛋白") {
+ return "ALB ";
+ } else if (name === "钙") {
+ return "Ca ";
+ } else if (name === "钾") {
+ return "K ";
+ } else if (name === "无机磷") {
+ return "P ";
+ } else if (name === "甲状旁腺激素") {
+ return "PTH ";
+ } else {
+ return name;
+ }
+ } else {
+ return "";
+ }
+};
+
+export const formatTestColr = (reg: string) => {
+ const heightFlag = ["↑", "g"];
+ const lowFlag = ["d", "↓"];
+ let color = "#333";
+ if (heightFlag.includes(reg)) {
+ color = "#CA7070";
+ } else if (lowFlag.includes(reg)) {
+ color = "#409eff";
+ }
+ return color;
+};
+
+export const formatTestFlag = (reg: string) => {
+ const heightFlag = ["↑", "g"];
+ const lowFlag = ["d", "↓"];
+ if (heightFlag.includes(reg)) {
+ return "↑";
+ } else if (lowFlag.includes(reg)) {
+ return "↓";
+ } else {
+ return "";
+ }
+};
+
+export const formatSubstituteMode = (mode: string) => {
+ let result = "";
+ if (mode === "前置换") {
+ result = "前";
+ } else if (mode === "后置换") {
+ result = "后";
+ }
+ return result;
+};
--
Gitblit v1.8.0