From 7fd770011e638950ef61edab1a8da176f45da77b Mon Sep 17 00:00:00 2001
From: zhangchen <1652267879@qq.com>
Date: 星期一, 28 七月 2025 12:00:50 +0800
Subject: [PATCH] ID2690-缓存修改

---
 src/store/type/bedsideAuxiliaryScreen.type.ts |  118 +++++++++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 91 insertions(+), 27 deletions(-)

diff --git a/src/store/type/bedsideAuxiliaryScreen.type.ts b/src/store/type/bedsideAuxiliaryScreen.type.ts
index 13631fa..67defc8 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;
@@ -57,7 +57,10 @@
   分区编号: string;
   处方脱水量: number | null;
   实时ktv: string;
-  实时ktv计算结果列表: null | { realTimeKtvCalcDetailResultInfo: KtvItem[], 透析单编号: string };
+  实时ktv计算结果列表: null | {
+    realTimeKtvCalcDetailResultInfo: KtvItem[];
+    透析单编号: string;
+  };
   实时脱水量: number | null;
   干体重: number | null;
   年龄: number | null;
@@ -117,7 +120,8 @@
   透析状态: string; // '0.0'这种格式的,得格式化一下
   透析结束时间: number | null;
   透析处方备注: string;
-  最近最大脱水量透析时长: string
+  最近最大脱水量透析时长: string;
+  透析龄: number | null;
 }
 
 export interface VascularAccess {
@@ -156,15 +160,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;
@@ -180,7 +199,16 @@
   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, // 未初始化(没有设备编号)
@@ -280,6 +308,7 @@
   weightAfterLastDialysis: number | null; // 上次透后称重
   weightIncrease: number | null; // 体重增加
   weightIncreaseRate: number | null; // 体重增长率
+  maximumDehydrationDuration: string;
 }
 
 export const defaultSignedIn = (): SignedIn => {
@@ -294,8 +323,9 @@
     dryWeight: null, // 干体重
     preDialysisWeight: null, // 透前称重
     weightAfterLastDialysis: null, // 上次透后称重
-    weightIncrease: null, // 体重增加  
+    weightIncrease: null, // 体重增加
     weightIncreaseRate: null, // 体重增长率
+    maximumDehydrationDuration: '',
   };
 };
 
@@ -309,7 +339,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; // 已透析时长(单位:分钟)
@@ -322,13 +354,14 @@
   ktv: string; // 实时ktv
   monitoringRecord: MonitoringRecord[]; // 监测记录列表
   doctorAdvice: any[]; // 透析单医嘱列表
-  bloodFlow: string; // 血流量
+  bloodFlow: number | null; // 血流量
   bloodVolumeMonitoring: number | null; // 血容量监测
   dialysisFluidFlowRate: number | null; // 透析液流量
   ktvList: KtvItem[]; // 实时ktv计算结果列表
+  dialysisAge: number | null, // 透析龄
 }
 
-interface MonitoringRecord {
+export interface MonitoringRecord {
   伸缩压: string; // 血压伸缩压
   舒张压: string; // 血压舒张压
   脉搏: string; // 脉搏
@@ -345,7 +378,8 @@
     maximumDehydrationDuration: "",
     prescriptionRemarks: "",
     abnormalItems: [],
-    prescriptionDialysisDuration: "",
+    prescriptionDialysisDurationHour: "",
+    prescriptionDialysisDurationMin: "",
     dialysisStartTime: null,
     dialysisEndTime: null,
     dialysisDuration: null,
@@ -358,18 +392,21 @@
     ktv: "",
     monitoringRecord: [],
     doctorAdvice: [],
-    bloodFlow: "",
+    bloodFlow: null,
     bloodVolumeMonitoring: null,
     dialysisFluidFlowRate: null,
     ktvList: [],
+    prescriptionDialysisDuration: null, // 透析处方的时长(单位:小时)
+    dialysisAge: 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
@@ -386,19 +423,32 @@
     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.透析状态) {
@@ -452,9 +502,12 @@
           seeMsg.透析状态?.最近最大脱水量日期 ?? "";
         signedIn.dryWeight = seeMsg.透析状态?.干体重 ?? null;
         signedIn.preDialysisWeight = seeMsg.透析状态?.透前称重 ?? null;
-        signedIn.weightAfterLastDialysis = seeMsg.透析状态?.上次透后称重 ?? null;
+        signedIn.weightAfterLastDialysis =
+          seeMsg.透析状态?.上次透后称重 ?? null;
         signedIn.weightIncrease = seeMsg.透析状态?.体重增加 ?? null;
         signedIn.weightIncreaseRate = seeMsg.透析状态?.体重增长率 ?? null;
+        signedIn.maximumDehydrationDuration =
+          seeMsg.透析状态?.最近最大脱水量透析时长 ?? "";
 
         result.signedIn = signedIn;
       }
@@ -471,19 +524,25 @@
           seeMsg.透析状态?.最近最大脱水量 ?? "";
         underTreatment.maximumDehydrationCapacityDate =
           seeMsg.透析状态?.最近最大脱水量日期 ?? "";
-        underTreatment.maximumDehydrationDuration = seeMsg.透析状态?.最近最大脱水量透析时长 ?? "";
-        underTreatment.prescriptionRemarks = seeMsg.透析状态?.透析处方备注 ?? "";
+        underTreatment.maximumDehydrationDuration =
+          seeMsg.透析状态?.最近最大脱水量透析时长 ?? "";
+        underTreatment.prescriptionRemarks =
+          seeMsg.透析状态?.透析处方备注 ?? "";
         underTreatment.abnormalItems = seeMsg.透析状态?.异常检验指标 ?? [];
         underTreatment.prescriptionDialysisDuration =
+          seeMsg.透析状态?.透析处方的时长 ?? null;
+        underTreatment.prescriptionDialysisDurationHour =
           seeMsg.透析状态?.透析处方的时长_小时 ?? "";
+        underTreatment.prescriptionDialysisDurationMin =
+          seeMsg.透析状态?.透析处方的时长_分钟 ?? "";
         underTreatment.dialysisStartTime =
           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;
         underTreatment.currentBloodTemperature =
@@ -494,10 +553,15 @@
         underTreatment.ktv = seeMsg.透析状态?.实时ktv ?? "";
         underTreatment.monitoringRecord = seeMsg.透析状态?.监测记录列表 ?? [];
         underTreatment.doctorAdvice = seeMsg.透析状态?.透析单医嘱列表 ?? [];
-        underTreatment.bloodFlow = "";
-        underTreatment.dialysisFluidFlowRate = seeMsg.透析状态?.iot_血流量 ?? null;
-        underTreatment.bloodVolumeMonitoring = seeMsg.透析状态?.iot_透析液流速 ?? null;
-        underTreatment.ktvList = seeMsg.透析状态?.实时ktv计算结果列表?.realTimeKtvCalcDetailResultInfo ?? [];
+        underTreatment.bloodFlow = seeMsg.透析状态?.iot_血流量 ?? null;
+        underTreatment.dialysisFluidFlowRate =
+          seeMsg.透析状态?.iot_血流量 ?? null;
+        underTreatment.bloodVolumeMonitoring =  null;
+        underTreatment.ktvList =
+          seeMsg.透析状态?.实时ktv计算结果列表
+            ?.realTimeKtvCalcDetailResultInfo ?? [];
+        underTreatment.dialysisAge = seeMsg.透析状态?.透析龄 ?? null;
+
         result.underTreatment = underTreatment;
       }
     }
@@ -555,10 +619,10 @@
 
 export const formatSubstituteMode = (mode: string) => {
   let result = "";
-  if (mode === '前置换') {
-    result = '前'
-  } else if (mode === '后置换') {
-    result = '后'
+  if (mode === "前置换") {
+    result = "前";
+  } else if (mode === "后置换") {
+    result = "后";
   }
   return result;
-}
+};

--
Gitblit v1.8.0