From d5f06dbd22de83d9ecbd5ad70bc37decda91bb4d Mon Sep 17 00:00:00 2001
From: zhangchen <1652267879@qq.com>
Date: 星期四, 24 七月 2025 23:15:08 +0800
Subject: [PATCH] ID1625-时间选择组件完成

---
 src/views/mobile/bedsideAuxiliaryScreen/index.vue |   62 ++++++++++++++++++++++++++-----
 1 files changed, 52 insertions(+), 10 deletions(-)

diff --git a/src/views/mobile/bedsideAuxiliaryScreen/index.vue b/src/views/mobile/bedsideAuxiliaryScreen/index.vue
index b555a83..ab6c350 100644
--- a/src/views/mobile/bedsideAuxiliaryScreen/index.vue
+++ b/src/views/mobile/bedsideAuxiliaryScreen/index.vue
@@ -1,29 +1,70 @@
 <template>
-  <div class="bedside-auxiliary-screen-container">
-    <Header :type="0" device-no="03" />
+  <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"  />
+        <!-- <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, onMounted, defineAsyncComponent } from "vue";
+import { ref, watch, computed, onMounted, defineAsyncComponent } 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';
 // 未排班时的组件
-const UnplannedSchedule = defineAsyncComponent(() => import('./components/UnplannedSchedule.vue'));
+const UnplannedSchedule = defineAsyncComponent(() => import('./pages/UnplannedSchedule.vue'));
+// 未签到时的组件
+const NotSignedIn = defineAsyncComponent(() => import('./pages/NotSignedIn.vue'));
+// 已签到时的组件
+const SignedIn = defineAsyncComponent(() => import('./pages/SignedIn.vue'));
+// 治疗中的组件
+const UnderTreatment = defineAsyncComponent(() => import('./pages/UnderTreatment.vue'));
 
 const bedsideAuxiliaryScreenStore = useBedsideAuxiliaryScreenStore();
-
 const cotentHeight = ref(0);
-watch(
-  () => bedsideAuxiliaryScreenStore.deviceCode,
-  (newVal: string) => {}
-);
+const { width, height } = useWindowSize();
+
+
+const backgroundColor = computed(() => {
+  let color = '#DAE5EC';
+  // 如果是未排班、加载中或未签到页面,背景色为白色
+  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)) {
+    name = UnplannedSchedule;
+  }
+  // 未签到
+  else if (bedsideAuxiliaryScreenStore.deviceData.pageType === EPageType.NOT_SIGNED_IN) {
+    name = NotSignedIn
+  } 
+  // 已签到
+  else if (bedsideAuxiliaryScreenStore.deviceData.pageType === EPageType.SIGNED_IN) {
+    name = SignedIn;
+  }
+  // 透析中 
+  else {
+    name = UnderTreatment;
+  }
+  return name;
+});
+
+watch([width, height], () => {
+  cotentHeight.value = getAvailableHeightByClass('content-position')
+});
+
 
 onMounted(() => {
   if (bedsideAuxiliaryScreenStore.deviceCode) {
@@ -44,6 +85,7 @@
   box-sizing: border-box;
 }
 .bedside-auxiliary-screen-container {
+  background-color: #409eff;
   .bedside-auxiliary-screen-content {
     padding: 6px 12px 0;
   }

--
Gitblit v1.8.0