From 6ecaed01cf576560a31ae960d0cdf1473e03c6b8 Mon Sep 17 00:00:00 2001
From: zhangchen <1652267879@qq.com>
Date: 星期一, 11 八月 2025 15:40:26 +0800
Subject: [PATCH] ID1975-自动更新流程zancun

---
 src/views/mobile/bedsideAuxiliaryScreen/index.vue |  166 +++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 142 insertions(+), 24 deletions(-)

diff --git a/src/views/mobile/bedsideAuxiliaryScreen/index.vue b/src/views/mobile/bedsideAuxiliaryScreen/index.vue
index ab6c350..5aedcc5 100644
--- a/src/views/mobile/bedsideAuxiliaryScreen/index.vue
+++ b/src/views/mobile/bedsideAuxiliaryScreen/index.vue
@@ -1,60 +1,111 @@
 <template>
-  <div class="bedside-auxiliary-screen-container" :style="{ backgroundColor: backgroundColor }">
+  <div
+    class="bedside-auxiliary-screen-container"
+    :style="{ backgroundColor: backgroundColor }"
+  >
     <Header />
     <div class="bedside-auxiliary-screen-content">
-        <div class="content-position"></div>
-        <!-- <UnplannedSchedule v-if="cotentHeight > 0" :height="cotentHeight"  /> -->
-        <component v-if="cotentHeight > 0" :is="currentComponent" :height="cotentHeight" />
+      <div class="content-position"></div>
+      <transition name="fade" mode="out-in">
+        <component
+          v-if="cotentHeight > 0"
+          :is="currentComponent"
+          :height="cotentHeight"
+        />
+      </transition>
     </div>
   </div>
 </template>
 
 <script lang="ts" setup>
-import { ref, watch, computed, onMounted, defineAsyncComponent } from "vue";
+import {
+  ref,
+  watch,
+  computed,
+  onMounted,
+  defineAsyncComponent,
+  onBeforeUnmount,
+} from "vue";
 // @ts-ignore
 import Header from "./components/Header.vue";
 import { useBedsideAuxiliaryScreenStore } from "@/store/bedsideAuxiliaryScreen";
-import { EPageType } from '@/store/type/bedsideAuxiliaryScreen.type';
-import { getAvailableHeightByClass } from '@/utils/utils';
-import { useWindowSize } from '@/composables/useWindowSize';
+import { EPageType } from "@/store/type/bedsideAuxiliaryScreen.type";
+import { getAvailableHeightByClass, delay } from "@/utils/utils";
+import { useWindowSize } from "@/composables/useWindowSize";
+import { getServiceVersionApi } from "@/utils/httpApi";
+import { ElMessage } from "element-plus";
 // 未排班时的组件
-const UnplannedSchedule = defineAsyncComponent(() => import('./pages/UnplannedSchedule.vue'));
+const UnplannedSchedule = defineAsyncComponent(
+  () => import("./pages/UnplannedSchedule.vue")
+);
 // 未签到时的组件
-const NotSignedIn = defineAsyncComponent(() => import('./pages/NotSignedIn.vue'));
+const NotSignedIn = defineAsyncComponent(
+  () => import("./pages/NotSignedIn.vue")
+);
 // 已签到时的组件
-const SignedIn = defineAsyncComponent(() => import('./pages/SignedIn.vue'));
+const SignedIn = defineAsyncComponent(() => import("./pages/SignedIn.vue"));
 // 治疗中的组件
-const UnderTreatment = defineAsyncComponent(() => import('./pages/UnderTreatment.vue'));
+const UnderTreatment = defineAsyncComponent(
+  () => import("./pages/UnderTreatment.vue")
+);
+// 血压计的组件
+const Sphygmomanometer = defineAsyncComponent(
+  () => import("./pages/Sphygmomanometer.vue")
+);
 
 const bedsideAuxiliaryScreenStore = useBedsideAuxiliaryScreenStore();
 const cotentHeight = ref(0);
 const { width, height } = useWindowSize();
 
+const versionTimer = 1000 * 60 * 5; // 五分钟请求一次 getServiceVersionApi 接口,防止副屏关屏的时候收不到推送的消息
+let timer: ReturnType<typeof setInterval> | null = null;
 
 const backgroundColor = computed(() => {
-  let color = '#DAE5EC';
+  let color = "#DAE5EC";
   // 如果是未排班、加载中或未签到页面,背景色为白色
-  if ([EPageType.NOT_INIT, EPageType.LOADING, EPageType.UNPLANNED_SCHEDULE].includes(bedsideAuxiliaryScreenStore.deviceData.pageType)) {
-    color = '#fff';
+  if (
+    [
+      EPageType.NOT_INIT,
+      EPageType.LOADING,
+      EPageType.UNPLANNED_SCHEDULE,
+    ].includes(bedsideAuxiliaryScreenStore.deviceData.pageType)
+  ) {
+    color = "#fff";
   }
   return color;
 });
 
 const currentComponent = computed(() => {
   let name: any = UnplannedSchedule;
-  // 未排班
-  if ([EPageType.NOT_INIT, EPageType.LOADING, EPageType.UNPLANNED_SCHEDULE].includes(bedsideAuxiliaryScreenStore.deviceData.pageType)) {
+
+  // 血压计
+  if (
+    bedsideAuxiliaryScreenStore.deviceData.pageType ===
+    EPageType.SPHYGMOMANOMETER
+  ) {
+    name = Sphygmomanometer;
+  } else if (
+    [
+      EPageType.NOT_INIT,
+      EPageType.LOADING,
+      EPageType.UNPLANNED_SCHEDULE,
+    ].includes(bedsideAuxiliaryScreenStore.deviceData.pageType)
+  ) {
     name = UnplannedSchedule;
   }
   // 未签到
-  else if (bedsideAuxiliaryScreenStore.deviceData.pageType === EPageType.NOT_SIGNED_IN) {
-    name = NotSignedIn
-  } 
+  else if (
+    bedsideAuxiliaryScreenStore.deviceData.pageType === EPageType.NOT_SIGNED_IN
+  ) {
+    name = NotSignedIn;
+  }
   // 已签到
-  else if (bedsideAuxiliaryScreenStore.deviceData.pageType === EPageType.SIGNED_IN) {
+  else if (
+    bedsideAuxiliaryScreenStore.deviceData.pageType === EPageType.SIGNED_IN
+  ) {
     name = SignedIn;
   }
-  // 透析中 
+  // 透析中
   else {
     name = UnderTreatment;
   }
@@ -62,9 +113,52 @@
 });
 
 watch([width, height], () => {
-  cotentHeight.value = getAvailableHeightByClass('content-position')
+  cotentHeight.value = getAvailableHeightByClass("content-position");
 });
 
+// 版本更新/手动刷新场景
+watch(
+  [
+    bedsideAuxiliaryScreenStore.version,
+    bedsideAuxiliaryScreenStore.deviceData.isRefresh,
+  ],
+  ([newVersion, newIsRefresh], [oldVersion, oldIsRefresh]) => {
+    // 如果远程版本号存在更新/设备列表页面进行了手动刷新
+    console.log('bedsideAuxiliaryScreenStore.version :', bedsideAuxiliaryScreenStore.version)
+    if (
+      newVersion !== bedsideAuxiliaryScreenStore.version ||
+      newIsRefresh === 1
+    ) {
+      refreshFun();
+    }
+  }
+);
+
+const getServiceVersionFun = async () => {
+  try {
+    const { version } = await getServiceVersionApi();
+    if (version !== bedsideAuxiliaryScreenStore.version) {
+      refreshFun(version);
+    }
+  } catch (error) {
+    ElMessage.error("获取版本号失败,请联系管理员!");
+  }
+};
+
+/** 副屏刷新的方法 */
+const refreshFun = (val?: string) => {
+  if (val) {
+    bedsideAuxiliaryScreenStore.setVersion(val);
+  }
+  ElMessage({
+    type: "success",
+    duration: 1000 * 3,
+    message: "系统更新···",
+    onClose: function () {
+      window.location.reload();
+    },
+  });
+};
 
 onMounted(() => {
   if (bedsideAuxiliaryScreenStore.deviceCode) {
@@ -74,7 +168,21 @@
       }`
     );
   }
-  cotentHeight.value = getAvailableHeightByClass('content-position')
+  // 先立即执行一次
+  getServiceVersionFun();
+
+  // 再每 5 分钟执行一次
+  timer = setInterval(() => {
+    getServiceVersionFun();
+  }, versionTimer);
+  cotentHeight.value = getAvailableHeightByClass("content-position");
+});
+
+onBeforeUnmount(() => {
+  // 把定时器清除掉
+  if (timer) {
+    clearInterval(timer);
+  }
 });
 </script>
 
@@ -90,4 +198,14 @@
     padding: 6px 12px 0;
   }
 }
+</style>
+<style scoped>
+.fade-enter-active,
+.fade-leave-active {
+  transition: opacity 0.3s ease;
+}
+.fade-enter-from,
+.fade-leave-to {
+  opacity: 0;
+}
 </style>
\ No newline at end of file

--
Gitblit v1.8.0