From 3b2e941a83ad49d3167df864a5a06a81ef944470 Mon Sep 17 00:00:00 2001
From: zhangchen <1652267879@qq.com>
Date: 星期三, 24 九月 2025 23:55:45 +0800
Subject: [PATCH] Merge branch 'ID2130-未签到页面优化' into test

---
 src/views/mobile/bedsideAuxiliaryScreen/index.vue |   63 ++++++++++++++++++++++++++++++-
 1 files changed, 61 insertions(+), 2 deletions(-)

diff --git a/src/views/mobile/bedsideAuxiliaryScreen/index.vue b/src/views/mobile/bedsideAuxiliaryScreen/index.vue
index 3154799..cdf3c55 100644
--- a/src/views/mobile/bedsideAuxiliaryScreen/index.vue
+++ b/src/views/mobile/bedsideAuxiliaryScreen/index.vue
@@ -18,13 +18,22 @@
 </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 { 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")
@@ -48,6 +57,9 @@
 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";
   // 如果是未排班、加载中或未签到页面,背景色为白色
@@ -56,6 +68,7 @@
       EPageType.NOT_INIT,
       EPageType.LOADING,
       EPageType.UNPLANNED_SCHEDULE,
+      EPageType.NOT_SIGNED_IN,
     ].includes(bedsideAuxiliaryScreenStore.deviceData.pageType)
   ) {
     color = "#fff";
@@ -104,6 +117,38 @@
   cotentHeight.value = getAvailableHeightByClass("content-position");
 });
 
+// 版本更新/手动刷新场景
+// watch(
+//   [
+//     bedsideAuxiliaryScreenStore.version,
+//     bedsideAuxiliaryScreenStore.deviceData.isRefresh,
+//   ],
+//   ([newVersion, newIsRefresh], [oldVersion, oldIsRefresh]) => {
+//     // 如果远程版本号存在更新/设备列表页面进行了手动刷新
+//     console.log('bedsideAuxiliaryScreenStore.version :', bedsideAuxiliaryScreenStore.version)
+//     if (
+//       newVersion !== oldVersion||
+//       newIsRefresh === 1
+//     ) {
+//       refreshFun();
+//     }
+//   }
+// );
+
+const getServiceVersionFun = async () => {
+  try {
+    const { data } = await getServiceVersionApi(bedsideAuxiliaryScreenStore.version);
+    if (data?.version && data?.version !== bedsideAuxiliaryScreenStore.version) {
+      bedsideAuxiliaryScreenStore.refreshVersion(data.version);
+    } else if (!data?.version) {
+      ElMessage.error("获取版本号失败,请联系管理员!");
+    }
+  } catch (error) {
+    ElMessage.error("获取版本号失败,请联系管理员!");
+  }
+};
+
+
 onMounted(() => {
   if (bedsideAuxiliaryScreenStore.deviceCode) {
     bedsideAuxiliaryScreenStore.connect(
@@ -112,8 +157,22 @@
       }`
     );
   }
+  // 先立即执行一次
+  getServiceVersionFun();
+
+  // 再每 5 分钟执行一次
+  timer = setInterval(() => {
+    getServiceVersionFun();
+  }, versionTimer);
   cotentHeight.value = getAvailableHeightByClass("content-position");
 });
+
+onBeforeUnmount(() => {
+  // 把定时器清除掉
+  if (timer) {
+    clearInterval(timer);
+  }
+});
 </script>
 
 <style lang="less" scoped>

--
Gitblit v1.8.0