From 150b02fb27bf7bbcf3cb3653be484f8fab5b3999 Mon Sep 17 00:00:00 2001
From: zhangchen <1652267879@qq.com>
Date: 星期六, 19 七月 2025 16:55:31 +0800
Subject: [PATCH] ID1825-未排班页面初步完成

---
 src/views/mobile/bedsideAuxiliaryScreen/index.vue |   65 +++++++++++++++++++++++++++-----
 1 files changed, 54 insertions(+), 11 deletions(-)

diff --git a/src/views/mobile/bedsideAuxiliaryScreen/index.vue b/src/views/mobile/bedsideAuxiliaryScreen/index.vue
index f098537..3aecc92 100644
--- a/src/views/mobile/bedsideAuxiliaryScreen/index.vue
+++ b/src/views/mobile/bedsideAuxiliaryScreen/index.vue
@@ -1,24 +1,67 @@
 <template>
-    <div class="bedside-auxiliary-screen-container">
-        <Header :type="0" device-no="03" />
-        <div class="bedside-auxiliary-screen-content"></div>
+  <div class="bedside-auxiliary-screen-container">
+    <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>
+  </div>
 </template>
 
 <script lang="ts" setup>
+import { ref, watch, computed, onMounted, defineAsyncComponent } from "vue";
 // @ts-ignore
-import Header from './components/Header.vue';
+import Header from "./components/Header.vue";
+import { useBedsideAuxiliaryScreenStore } from "@/store/bedsideAuxiliaryScreen";
+import { EPageType } from '@/store/type/bedsideAuxiliaryScreen.type';
+import { getAvailableHeightByClass } from '@/utils/utils';
+// 未排班时的组件
+const UnplannedSchedule = defineAsyncComponent(() => import('./components/UnplannedSchedule.vue'));
+// 未签到时的组件
+const NotSignedIn = defineAsyncComponent(() => import('./components/NotSignedIn.vue'));
+
+const bedsideAuxiliaryScreenStore = useBedsideAuxiliaryScreenStore();
+const cotentHeight = ref(0);
+
+const currentComponent = computed(() => {
+  let name: any = UnplannedSchedule;
+  // 未签到
+  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
+  }
+  return name;
+});
+
+watch(
+  () => bedsideAuxiliaryScreenStore.deviceCode,
+  (newVal: string) => {}
+);
+
+onMounted(() => {
+  if (bedsideAuxiliaryScreenStore.deviceCode) {
+    bedsideAuxiliaryScreenStore.connect(
+      `${import.meta.env.VITE_SSE_BASE_URL}${
+        bedsideAuxiliaryScreenStore.deviceCode
+      }`
+    );
+  }
+  cotentHeight.value = getAvailableHeightByClass('content-position')
+});
 </script>
 
 <style lang="less" scoped>
-*{
-    margin: 0;
-    padding: 0;
-    box-sizing: border-box;
+* {
+  margin: 0;
+  padding: 0;
+  box-sizing: border-box;
 }
 .bedside-auxiliary-screen-container {
-    .bedside-auxiliary-screen-content {
-        padding: 6px 12px 0;
-    }
+  .bedside-auxiliary-screen-content {
+    padding: 6px 12px 0;
+  }
 }
 </style>
\ No newline at end of file

--
Gitblit v1.8.0