From 2dbcfaf286a171f6fc4fbe48a38b9191ce70cde2 Mon Sep 17 00:00:00 2001
From: zhangchen <1652267879@qq.com>
Date: 星期四, 24 七月 2025 16:26:13 +0800
Subject: [PATCH] ID1625-开发中功能提醒
---
src/views/mobile/bedsideAuxiliaryScreen/index.vue | 88 +++++++++++++++++++++++++++++++++++++++----
1 files changed, 79 insertions(+), 9 deletions(-)
diff --git a/src/views/mobile/bedsideAuxiliaryScreen/index.vue b/src/views/mobile/bedsideAuxiliaryScreen/index.vue
index f5ff428..c66c775 100644
--- a/src/views/mobile/bedsideAuxiliaryScreen/index.vue
+++ b/src/views/mobile/bedsideAuxiliaryScreen/index.vue
@@ -1,21 +1,91 @@
<template>
- <div class="bedside-auxiliary-screen-container">
- 张三
- <Header />
+ <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>
+ </div>
</template>
<script lang="ts" setup>
-import Header from './components/Header.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';
+// 未排班时的组件
+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);
+
+
+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(
+ () => 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 {
- font-size: 48px;
+ background-color: #409eff;
+ .bedside-auxiliary-screen-content {
+ padding: 6px 12px 0;
+ }
}
</style>
\ No newline at end of file
--
Gitblit v1.8.0