From a5d06bcaaf7761b594ee7425206e2732b05c5e16 Mon Sep 17 00:00:00 2001
From: chenyc <501753378@qq.com>
Date: 星期四, 16 一月 2025 15:02:07 +0800
Subject: [PATCH] gx生化显示

---
 src/views/home/index.vue |  961 ++++++++++++++++++++------------------------------------
 1 files changed, 343 insertions(+), 618 deletions(-)

diff --git a/src/views/home/index.vue b/src/views/home/index.vue
index d351e1e..98d4402 100644
--- a/src/views/home/index.vue
+++ b/src/views/home/index.vue
@@ -1,633 +1,358 @@
 <template>
-	<div class="home-container layout-pd">
-		<el-row :gutter="15" class="home-card-one mb15">
-			<el-col
-				:xs="24"
-				:sm="12"
-				:md="12"
-				:lg="6"
-				:xl="6"
-				v-for="(v, k) in state.homeOne"
-				:key="k"
-				:class="{ 'home-media home-media-lg': k > 1, 'home-media-sm': k === 1 }"
-			>
-				<div class="home-card-item flex">
-					<div class="flex-margin flex w100" :class="` home-one-animation${k}`">
-						<div class="flex-auto">
-							<span class="font30">{{ v.num1 }}</span>
-							<span class="ml5 font16" :style="{ color: v.color1 }">{{ v.num2 }}%</span>
-							<div class="mt10">{{ v.num3 }}</div>
-						</div>
-						<div class="home-card-item-icon flex" :style="{ background: `var(${v.color2})` }">
-							<i class="flex-margin font32" :class="v.num4" :style="{ color: `var(${v.color3})` }"></i>
-						</div>
-					</div>
-				</div>
-			</el-col>
-		</el-row>
-		<el-row :gutter="15" class="home-card-two mb15">
-			<el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16">
-				<div class="home-card-item">
-					<div style="height: 100%" ref="homeLineRef"></div>
-				</div>
-			</el-col>
-			<el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8" class="home-media">
-				<div class="home-card-item">
-					<div style="height: 100%" ref="homePieRef"></div>
-				</div>
-			</el-col>
-		</el-row>
-		<el-row :gutter="15" class="home-card-three">
-			<el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8">
-				<div class="home-card-item">
-					<div class="home-card-item-title">快捷导航工具</div>
-					<div class="home-monitor">
-						<div class="flex-warp">
-							<div class="flex-warp-item" v-for="(v, k) in state.homeThree" :key="k">
-								<div class="flex-warp-item-box" :class="`home-animation${k}`">
-									<div class="flex-margin">
-										<i :class="v.icon" :style="{ color: v.iconColor }"></i>
-										<span class="pl5">{{ v.label }}</span>
-										<div class="mt10">{{ v.value }}</div>
-									</div>
-								</div>
-							</div>
-						</div>
-					</div>
-				</div>
-			</el-col>
-			<el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16" class="home-media">
-				<div class="home-card-item">
-					<div style="height: 100%" ref="homeBarRef"></div>
-				</div>
-			</el-col>
-		</el-row>
-	</div>
+    <div class="home-container layout-pd ">
+        <el-row :gutter="10">
+            <el-col class="patTabel" :xs="6" :sm="6" :md="4" :lg="3" :xl="3" v-if="state.isTable">
+                <el-table :data="state.filterTableData" stripe :height="state.tableHeight.left" size="default"
+                    highlight-current-row @current-change="handleCurrentChange" style="width: 100%">
+                    <el-table-column>
+                        <template #header>
+                            <div class="home-title">
+                                <el-avatar shape="square"
+                                    style="width: 16px; height: 16px;background-color: #ffffff;margin-right: 10px;margin-left: 10px;"
+                                    fit="contain" :src="huanzheliebiao" />
+                                <div class="titleHome">患者列表</div>
+                            </div>
+                            <el-input size="default" @change="getPatients" v-model="state.search" placeholder="支持模糊查询"
+                                :prefix-icon="Search" />
+                        </template>
+                        <template #default="scope">
+                            <el-row>
+                                <el-col :span="12">{{ scope.row.patientName }}</el-col>
+                                <el-col :span="6">{{ scope.row.patientGenderText }}</el-col>
+                                <el-col :span="6">{{ scope.row.age }}</el-col>
+                            </el-row>
+                        </template>
+                    </el-table-column>
+                </el-table>
+            </el-col>
+            <el-col :xs="18" :sm="18" :md="20" :lg="21" :xl="21" >
+                <el-tabs v-model="state.activeName" class="demo-tabs" @tab-click="handleClick">
+                    <el-tab-pane label="患者档案" name="患者档案">
+                        <template #label>
+                            <span class="custom-tabs-label home-title">
+                                <el-icon>
+                                    <Avatar />
+                                </el-icon>
+                                <span style="margin-left: 5px">患者档案</span>
+                            </span>
+                        </template>
+                    </el-tab-pane>
+                    
+                    <!-- <el-tab-pane label="历史服务" name="历史服务">
+                        <template #label>
+                            <span class="custom-tabs-label home-title">
+                                <el-icon>
+                                    <ZoomIn />
+                                </el-icon>
+                                <span style="margin-left: 5px">历史服务</span>
+                            </span>
+                        </template>
+                        <el-empty  description="该功能未开发"></el-empty> 
+                    </el-tab-pane> -->
+                    <el-tab-pane label="营养筛查评估" name="营养筛查评估">
+                        <template #label>
+                            <span class="custom-tabs-label home-title">
+                                <el-icon>
+                                    <Histogram />
+                                </el-icon>
+                                <span style="margin-left: 5px">营养筛查评估</span>
+                            </span>
+                        </template>
+                        
+                    </el-tab-pane>
+                    <el-tab-pane label="膳食调查" name="膳食调查">
+                        <template #label>
+                            <span class="custom-tabs-label home-title">
+                                <el-icon>
+                                    <Notification />
+                                </el-icon>
+                                <span style="margin-left: 5px">膳食调查</span>
+                            </span>
+                        </template>
+                        
+                    </el-tab-pane>
+                   
+                    <el-tab-pane label="方案" name="方案">
+                        <template #label>
+                            <span class="custom-tabs-label home-title">
+                                <el-icon>
+                                    <Grid />
+                                </el-icon>
+                                <span style="margin-left: 5px">方案</span>
+                            </span>
+                        </template>
+                        <!-- <el-empty  description="该功能未开发"></el-empty>  -->
+                    </el-tab-pane>
+                    <el-tab-pane label="随访记录" name="随访记录">
+                        <template #label>
+                            <span class="custom-tabs-label home-title">
+                                <el-icon>
+                                    <ChatDotRound />
+                                </el-icon>
+                                <span style="margin-left: 5px">随访记录</span>
+                            </span>
+                        </template>
+                        <!-- <el-empty  description="该功能未开发"></el-empty>  -->
+                    </el-tab-pane>
+                    <el-tab-pane label="生化数据" name="生化数据">
+                        <template #label>
+                            <span class="custom-tabs-label home-title">
+                                <el-icon>
+                                    <Aim />
+                                </el-icon>
+                                <span style="margin-left: 5px">生化数据</span>
+                            </span>
+                        </template>
+                    </el-tab-pane>
+                    <el-tab-pane label="用药记录" name="用药记录">
+                        <template #label>
+                            <span class="custom-tabs-label home-title">
+                                <el-icon>
+                                    <Edit />
+                                </el-icon>
+                                <span style="margin-left: 5px">用药记录</span>
+                            </span>
+                        </template>
+
+                    </el-tab-pane>
+                </el-tabs>
+                <div class="itemDoby">
+                    <patientFile v-show="state.activeName === '患者档案'" :tableHeight="state.tableHeight.detailRight"
+                        ref="patientFileRef" />
+                    <lisUi v-show="state.activeName === '生化数据'" ref="lisUiRef">
+                    </lisUi>
+                    <MedicationRecords v-show="state.activeName === '用药记录'"  :tableHeight="state.tableHeight.detailRight" ref="MedicationRecordsRef">
+                    </MedicationRecords>
+                    <dietarySurvey ref="dietarySurveyRef" v-show="state.activeName === '膳食调查'"  :tableHeight="state.tableHeight.detailRight"></dietarySurvey>
+                    <pinggubiao ref="pinggubiaoRef" v-show="state.activeName === '营养筛查评估'"  :tableHeight="state.tableHeight.detailRight"></pinggubiao>
+                    <fangAn ref="fangAnRef" v-show="state.activeName === '方案'"  :tableHeight="state.tableHeight.detailRight"></fangAn>
+                    <suifangjilu ref="suifangjiluRef" v-show="state.activeName === '随访记录'" :tableHeight="state.tableHeight.detailRight"></suifangjilu>
+
+                </div>
+
+            </el-col>
+        </el-row>
+        <div class="fixed-div" v-show="patientsInfo.patientName">
+            <el-avatar :size="80" :src="patientsInfo.patientAvatarIcon" />
+            <div @click="state.isTable = false">{{ patientsInfo.patientName }}</div>
+        </div>
+    </div>
 </template>
 
 <script setup lang="ts" name="home">
+import huanzheliebiao from '/@/assets/imgs/huanzheliebiao.png'
 import { reactive, onMounted, ref, watch, nextTick, onActivated, markRaw } from 'vue';
-import * as echarts from 'echarts';
+import { QueryList } from '/@/api/Patients'
 import { storeToRefs } from 'pinia';
-import { useThemeConfig } from '/@/stores/themeConfig';
-import { useTagsViewRoutes } from '/@/stores/tagsViewRoutes';
-
-// 定义变量内容
-const homeLineRef = ref();
-const homePieRef = ref();
-const homeBarRef = ref();
-const storesTagsViewRoutes = useTagsViewRoutes();
-const storesThemeConfig = useThemeConfig();
-const { themeConfig } = storeToRefs(storesThemeConfig);
-const { isTagsViewCurrenFull } = storeToRefs(storesTagsViewRoutes);
+import { useUserInfo } from '/@/stores/userInfo';
+import { usePatientsInfo } from '/@/stores/patientsInfo';
+const stores = useUserInfo();
+const storesPat = usePatientsInfo();
+const { userInfos } = storeToRefs(stores);
+const { patientsInfo } = storeToRefs(storesPat);
+import { ElLoading, TabsPaneContext } from 'element-plus'
+import { Search } from '@element-plus/icons-vue'
+// 用药记录
+import MedicationRecords from './components/Medication_records.vue'
+// 膳食调查
+import dietarySurvey from './components/dietary_survey.vue'
+// 患者档案
+import patientFile from './components/patient_file.vue'
+// 化验结果
+import lisUi from './components/lis_.ui.vue'
+// 评估表
+import pinggubiao from './components/pingubiao/index.vue'
+// 方案
+import fangAn from './components/fangAn/index.vue'
+// 随访记录
+import suifangjilu from './components/suifangjilu/index.vue'
+interface User {
+    code: string,
+    patientName: string
+    patientGenderText: string
+    age: string
+}
+const MedicationRecordsRef = ref()
+const patientFileRef = ref()
+const currentRow = ref()
+const lisUiRef = ref()
+const pinggubiaoRef=ref()
+const dietarySurveyRef=ref()// 膳食调查
+const fangAnRef=ref()
+const suifangjiluRef=ref()
 const state = reactive({
-	global: {
-		homeChartOne: null,
-		homeChartTwo: null,
-		homeCharThree: null,
-		dispose: [null, '', undefined],
-	} as any,
-	homeOne: [
-		{
-			num1: '125,12',
-			num2: '-12.32',
-			num3: '订单统计信息',
-			num4: 'fa fa-meetup',
-			color1: '#FF6462',
-			color2: '--next-color-primary-lighter',
-			color3: '--el-color-primary',
-		},
-		{
-			num1: '653,33',
-			num2: '+42.32',
-			num3: '月度计划信息',
-			num4: 'iconfont icon-ditu',
-			color1: '#6690F9',
-			color2: '--next-color-success-lighter',
-			color3: '--el-color-success',
-		},
-		{
-			num1: '125,65',
-			num2: '+17.32',
-			num3: '年度计划信息',
-			num4: 'iconfont icon-zaosheng',
-			color1: '#6690F9',
-			color2: '--next-color-warning-lighter',
-			color3: '--el-color-warning',
-		},
-		{
-			num1: '520,43',
-			num2: '-10.01',
-			num3: '访问统计信息',
-			num4: 'fa fa-github-alt',
-			color1: '#FF6462',
-			color2: '--next-color-danger-lighter',
-			color3: '--el-color-danger',
-		},
-	],
-	homeThree: [
-		{
-			icon: 'iconfont icon-yangan',
-			label: '浅粉红',
-			value: '2.1%OBS/M',
-			iconColor: '#F72B3F',
-		},
-		{
-			icon: 'iconfont icon-wendu',
-			label: '深红(猩红)',
-			value: '30℃',
-			iconColor: '#91BFF8',
-		},
-		{
-			icon: 'iconfont icon-shidu',
-			label: '淡紫红',
-			value: '57%RH',
-			iconColor: '#88D565',
-		},
-		{
-			icon: 'iconfont icon-shidu',
-			label: '弱紫罗兰红',
-			value: '107w',
-			iconColor: '#88D565',
-		},
-		{
-			icon: 'iconfont icon-zaosheng',
-			label: '中紫罗兰红',
-			value: '57DB',
-			iconColor: '#FBD4A0',
-		},
-		{
-			icon: 'iconfont icon-zaosheng',
-			label: '紫罗兰',
-			value: '57PV',
-			iconColor: '#FBD4A0',
-		},
-		{
-			icon: 'iconfont icon-zaosheng',
-			label: '暗紫罗兰',
-			value: '517Cpd',
-			iconColor: '#FBD4A0',
-		},
-		{
-			icon: 'iconfont icon-zaosheng',
-			label: '幽灵白',
-			value: '12kg',
-			iconColor: '#FBD4A0',
-		},
-		{
-			icon: 'iconfont icon-zaosheng',
-			label: '海军蓝',
-			value: '64fm',
-			iconColor: '#FBD4A0',
-		},
-	],
-	myCharts: [] as EmptyArrayType,
-	charts: {
-		theme: '',
-		bgColor: '',
-		color: '#303133',
-	},
+    global: {
+        homeChartOne: null,
+        homeChartTwo: null,
+        homeCharThree: null,
+        dispose: [null, '', undefined],
+    } as any,
+    filterTableData: [],
+    activeName: '患者档案',
+    tableHeight: {
+        left: 0,
+        detailRight: 0
+    },
+    search: '',
+    isTable: true,
 });
-
-// 折线图
-const initLineChart = () => {
-	if (!state.global.dispose.some((b: any) => b === state.global.homeChartOne)) state.global.homeChartOne.dispose();
-	state.global.homeChartOne = markRaw(echarts.init(homeLineRef.value, state.charts.theme));
-	const option = {
-		backgroundColor: state.charts.bgColor,
-		title: {
-			text: '政策补贴额度',
-			x: 'left',
-			textStyle: { fontSize: '15', color: state.charts.color },
-		},
-		grid: { top: 70, right: 20, bottom: 30, left: 30 },
-		tooltip: { trigger: 'axis' },
-		legend: { data: ['预购队列', '最新成交价'], right: 0 },
-		xAxis: {
-			data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'],
-		},
-		yAxis: [
-			{
-				type: 'value',
-				name: '价格',
-				splitLine: { show: true, lineStyle: { type: 'dashed', color: '#f5f5f5' } },
-			},
-		],
-		series: [
-			{
-				name: '预购队列',
-				type: 'line',
-				symbolSize: 6,
-				symbol: 'circle',
-				smooth: true,
-				data: [0, 41.1, 30.4, 65.1, 53.3, 53.3, 53.3, 41.1, 30.4, 65.1, 53.3, 10],
-				lineStyle: { color: '#fe9a8b' },
-				itemStyle: { color: '#fe9a8b', borderColor: '#fe9a8b' },
-				areaStyle: {
-					color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
-						{ offset: 0, color: '#fe9a8bb3' },
-						{ offset: 1, color: '#fe9a8b03' },
-					]),
-				},
-			},
-			{
-				name: '最新成交价',
-				type: 'line',
-				symbolSize: 6,
-				symbol: 'circle',
-				smooth: true,
-				data: [0, 24.1, 7.2, 15.5, 42.4, 42.4, 42.4, 24.1, 7.2, 15.5, 42.4, 0],
-				lineStyle: { color: '#9E87FF' },
-				itemStyle: { color: '#9E87FF', borderColor: '#9E87FF' },
-				areaStyle: {
-					color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
-						{ offset: 0, color: '#9E87FFb3' },
-						{ offset: 1, color: '#9E87FF03' },
-					]),
-				},
-				emphasis: {
-					itemStyle: {
-						color: {
-							type: 'radial',
-							x: 0.5,
-							y: 0.5,
-							r: 0.5,
-							colorStops: [
-								{ offset: 0, color: '#9E87FF' },
-								{ offset: 0.4, color: '#9E87FF' },
-								{ offset: 0.5, color: '#fff' },
-								{ offset: 0.7, color: '#fff' },
-								{ offset: 0.8, color: '#fff' },
-								{ offset: 1, color: '#fff' },
-							],
-						},
-						borderColor: '#9E87FF',
-						borderWidth: 2,
-					},
-				},
-			},
-		],
-	};
-	state.global.homeChartOne.setOption(option);
-	state.myCharts.push(state.global.homeChartOne);
-};
-// 饼图
-const initPieChart = () => {
-	if (!state.global.dispose.some((b: any) => b === state.global.homeChartTwo)) state.global.homeChartTwo.dispose();
-	state.global.homeChartTwo = markRaw(echarts.init(homePieRef.value, state.charts.theme));
-	var getname = ['房屋及结构物', '专用设备', '通用设备', '文物和陈列品', '图书、档案'];
-	var getvalue = [34.2, 38.87, 17.88, 9.05, 2.05];
-	var data = [];
-	for (var i = 0; i < getname.length; i++) {
-		data.push({ name: getname[i], value: getvalue[i] });
-	}
-	const colorList = ['#51A3FC', '#36C78B', '#FEC279', '#968AF5', '#E790E8'];
-	const option = {
-		backgroundColor: state.charts.bgColor,
-		title: {
-			text: '房屋建筑工程',
-			x: 'left',
-			textStyle: { fontSize: '15', color: state.charts.color },
-		},
-		tooltip: { trigger: 'item', formatter: '{b} <br/> {c}%' },
-		graphic: {
-			elements: [
-				{
-					type: 'image',
-					z: -1,
-					style: {
-						image: themeConfig.value.isIsDark
-							? ''
-							: '',
-						width: 230,
-						height: 230,
-					},
-					left: '16.5%',
-					top: 'center',
-				},
-			],
-		},
-		legend: {
-			type: 'scroll',
-			orient: 'vertical',
-			right: '0%',
-			left: '65%',
-			top: 'center',
-			itemWidth: 14,
-			itemHeight: 14,
-			data: getname,
-			textStyle: {
-				rich: {
-					name: {
-						fontSize: 14,
-						fontWeight: 400,
-						width: 200,
-						height: 35,
-						padding: [0, 0, 0, 60],
-						color: state.charts.color,
-					},
-					rate: {
-						fontSize: 15,
-						fontWeight: 500,
-						height: 35,
-						width: 40,
-						padding: [0, 0, 0, 30],
-						color: state.charts.color,
-					},
-				},
-			},
-		},
-		series: [
-			{
-				type: 'pie',
-				radius: ['82', themeConfig.value.isIsDark ? '50' : '102'],
-				center: ['32%', '50%'],
-				itemStyle: {
-					color: function (params: any) {
-						return colorList[params.dataIndex];
-					},
-				},
-				label: { show: false },
-				labelLine: { show: false },
-				data: data,
-			},
-		],
-	};
-	state.global.homeChartTwo.setOption(option);
-	state.myCharts.push(state.global.homeChartTwo);
-};
-// 柱状图
-const initBarChart = () => {
-	if (!state.global.dispose.some((b: any) => b === state.global.homeCharThree)) state.global.homeCharThree.dispose();
-	state.global.homeCharThree = markRaw(echarts.init(homeBarRef.value, state.charts.theme));
-	const option = {
-		backgroundColor: state.charts.bgColor,
-		title: {
-			text: '地热开发利用',
-			x: 'left',
-			textStyle: { fontSize: '15', color: state.charts.color },
-		},
-		tooltip: { trigger: 'axis' },
-		legend: { data: ['供温', '回温', '压力值(Mpa)'], right: 0 },
-		grid: { top: 70, right: 80, bottom: 30, left: 80 },
-		xAxis: [
-			{
-				type: 'category',
-				data: ['1km', '2km', '3km', '4km', '5km', '6km'],
-				boundaryGap: true,
-				axisTick: { show: false },
-			},
-		],
-		yAxis: [
-			{
-				name: '供回温度(℃)',
-				nameLocation: 'middle',
-				nameTextStyle: { padding: [3, 4, 50, 6] },
-				splitLine: { show: true, lineStyle: { type: 'dashed', color: '#f5f5f5' } },
-				axisLine: { show: false },
-				axisTick: { show: false },
-				axisLabel: { color: state.charts.color, formatter: '{value} ' },
-			},
-			{
-				name: '压力值(Mpa)',
-				nameLocation: 'middle',
-				nameTextStyle: { padding: [50, 4, 5, 6] },
-				splitLine: { show: false },
-				axisLine: { show: false },
-				axisTick: { show: false },
-				axisLabel: { color: state.charts.color, formatter: '{value} ' },
-			},
-		],
-		series: [
-			{
-				name: '供温',
-				type: 'line',
-				smooth: true,
-				showSymbol: true,
-				// 矢量画五角星
-				symbol: 'path://M150 0 L80 175 L250 75 L50 75 L220 175 Z',
-				symbolSize: 12,
-				yAxisIndex: 0,
-				areaStyle: {
-					color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
-						{ offset: 0, color: 'rgba(250,180,101,0.3)' },
-						{ offset: 1, color: 'rgba(250,180,101,0)' },
-					]),
-					shadowColor: 'rgba(250,180,101,0.2)',
-					shadowBlur: 20,
-				},
-				itemStyle: { color: '#FF8000' },
-				// data中可以使用对象,value代表相应的值,另外可加入自定义的属性
-				data: [
-					{ value: 1, stationName: 's1' },
-					{ value: 3, stationName: 's2' },
-					{ value: 4, stationName: 's3' },
-					{ value: 9, stationName: 's4' },
-					{ value: 3, stationName: 's5' },
-					{ value: 2, stationName: 's6' },
-				],
-			},
-			{
-				name: '回温',
-				type: 'line',
-				smooth: true,
-				showSymbol: true,
-				symbol: 'emptyCircle',
-				symbolSize: 12,
-				yAxisIndex: 0,
-				areaStyle: {
-					color: new echarts.graphic.LinearGradient(
-						0,
-						0,
-						0,
-						1,
-						[
-							{ offset: 0, color: 'rgba(199, 237, 250,0.5)' },
-							{ offset: 1, color: 'rgba(199, 237, 250,0.2)' },
-						],
-						false
-					),
-				},
-				itemStyle: {
-					color: '#3bbc86',
-				},
-				data: [
-					{ value: 31, stationName: 's1' },
-					{ value: 36, stationName: 's2' },
-					{ value: 54, stationName: 's3' },
-					{ value: 24, stationName: 's4' },
-					{ value: 73, stationName: 's5' },
-					{ value: 22, stationName: 's6' },
-				],
-			},
-			{
-				name: '压力值(Mpa)',
-				type: 'bar',
-				barWidth: 30,
-				yAxisIndex: 1,
-				itemStyle: {
-					color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
-						{ offset: 0, color: 'rgba(108,80,243,0.3)' },
-						{ offset: 1, color: 'rgba(108,80,243,0)' },
-					]),
-					//柱状图圆角
-					borderRadius: [30, 30, 0, 0],
-				},
-				data: [
-					{ value: 11, stationName: 's1' },
-					{ value: 34, stationName: 's2' },
-					{ value: 54, stationName: 's3' },
-					{ value: 39, stationName: 's4' },
-					{ value: 63, stationName: 's5' },
-					{ value: 24, stationName: 's6' },
-				],
-			},
-		],
-	};
-	state.global.homeCharThree.setOption(option);
-	state.myCharts.push(state.global.homeCharThree);
-};
-// 批量设置 echarts resize
-const initEchartsResizeFun = () => {
-	nextTick(() => {
-		for (let i = 0; i < state.myCharts.length; i++) {
-			setTimeout(() => {
-				state.myCharts[i].resize();
-			}, i * 1000);
-		}
-	});
-};
-// 批量设置 echarts resize
-const initEchartsResize = () => {
-	window.addEventListener('resize', initEchartsResizeFun);
-};
-// 页面加载时
 onMounted(() => {
-	initEchartsResize();
-});
-// 由于页面缓存原因,keep-alive
-onActivated(() => {
-	initEchartsResizeFun();
-});
-// 监听 pinia 中的 tagsview 开启全屏变化,重新 resize 图表,防止不出现/大小不变等
-watch(
-	() => isTagsViewCurrenFull.value,
-	() => {
-		initEchartsResizeFun();
-	}
-);
-// 监听 pinia 中是否开启深色主题
-watch(
-	() => themeConfig.value.isIsDark,
-	(isIsDark) => {
-		nextTick(() => {
-			state.charts.theme = isIsDark ? 'dark' : '';
-			state.charts.bgColor = isIsDark ? 'transparent' : '';
-			state.charts.color = isIsDark ? '#dadada' : '#303133';
-			setTimeout(() => {
-				initLineChart();
-			}, 500);
-			setTimeout(() => {
-				initPieChart();
-			}, 700);
-			setTimeout(() => {
-				initBarChart();
-			}, 1000);
-		});
-	},
-	{
-		deep: true,
-		immediate: true,
-	}
-);
+    setTableHeight()
+    getPatients()
+})
+const handleCurrentChange = (val: any | undefined) => {
+    if (val) {
+        currentRow.value = val
+        //缓存到vuex 中
+        storesPat.setPatientsInfo(val)
+        console.log(val)
+        getTabsData()
+    }
+}
+/**获取患者列表 */
+const getPatients = () => {
+    const loading = ElLoading.service({
+        lock: true,
+        text: 'Loading',
+        background: 'rgba(0, 0, 0, 0.7)',
+    })
+    var ps = {
+        page: 0,
+        size: 0,
+        wherecondition: `client_code="${userInfos.value.clientCode}" and (patient_name like "%${state.search.toLowerCase()}%"
+        OR patient_name_py like "%${state.search.toLowerCase()}%")`
+    }
+    storesPat.setPatientsInfo({
+        id: '',
+        code: '',
+        age: 0,
+        patientName: '',
+        patientGenderText: '',
+        patientAvatarIcon: '',
+        clientCode:''
+
+    })
+    QueryList(ps).then(res => {
+        console.log('----------------患者--------')
+        console.log(res.data)
+        state.filterTableData = res.data.list
+    }).finally(() => {
+        loading.close()
+    })
+}
+/**设置高度 */
+const setTableHeight = () => {
+    let height = document.documentElement.clientHeight;
+    console.log('窗口高度')
+    const navDom = document.querySelector('.layout-navbars-breadcrumb-index');
+    if (navDom) {
+        height -= navDom.scrollHeight;
+    }
+    state.tableHeight.detailRight = height
+    state.tableHeight.left = height - 77;
+    // const demoFormDom = document.querySelector('.card_box_search')
+
+};
+/** 切换明细tabs*/
+const handleClick = (tab: TabsPaneContext, event: Event) => {
+    state.activeName = tab.paneName as string
+    getTabsData()
+}
+/** 获取明细项数据 */
+const getTabsData = () => {
+    if (patientsInfo.value.id) {
+        if (state.activeName === '用药记录') {
+            MedicationRecordsRef.value.getData()
+        } else if (state.activeName === '患者档案') {
+            patientFileRef.value.getData()
+        } else if(state.activeName === '膳食调查'){
+            dietarySurveyRef.value.getData()
+           
+        }else if(state.activeName === '营养筛查评估'){
+            pinggubiaoRef.value.getData()
+           
+        }else if(state.activeName==='方案'){
+            fangAnRef.value.getData()
+        }else if(state.activeName==='随访记录'){
+            suifangjiluRef.value.getData()
+        }
+    }
+}
 </script>
 
-<style scoped lang="scss">
+<style lang="scss">
 $homeNavLengh: 8;
+
 .home-container {
-	overflow: hidden;
-	.home-card-one,
-	.home-card-two,
-	.home-card-three {
-		.home-card-item {
-			width: 100%;
-			height: 130px;
-			border-radius: 4px;
-			transition: all ease 0.3s;
-			padding: 20px;
-			overflow: hidden;
-			background: var(--el-color-white);
-			color: var(--el-text-color-primary);
-			border: 1px solid var(--next-border-color-light);
-			&:hover {
-				box-shadow: 0 2px 12px var(--next-color-dark-hover);
-				transition: all ease 0.3s;
-			}
-			&-icon {
-				width: 70px;
-				height: 70px;
-				border-radius: 100%;
-				flex-shrink: 1;
-				i {
-					color: var(--el-text-color-placeholder);
-				}
-			}
-			&-title {
-				font-size: 15px;
-				font-weight: bold;
-				height: 30px;
-			}
-		}
-	}
-	.home-card-one {
-		@for $i from 0 through 3 {
-			.home-one-animation#{$i} {
-				opacity: 0;
-				animation-name: error-num;
-				animation-duration: 0.5s;
-				animation-fill-mode: forwards;
-				animation-delay: calc($i/4) + s;
-			}
-		}
-	}
-	.home-card-two,
-	.home-card-three {
-		.home-card-item {
-			height: 400px;
-			width: 100%;
-			overflow: hidden;
-			.home-monitor {
-				height: 100%;
-				.flex-warp-item {
-					width: 25%;
-					height: 111px;
-					display: flex;
-					.flex-warp-item-box {
-						margin: auto;
-						text-align: center;
-						color: var(--el-text-color-primary);
-						display: flex;
-						border-radius: 5px;
-						background: var(--next-bg-color);
-						cursor: pointer;
-						transition: all 0.3s ease;
-						&:hover {
-							background: var(--el-color-primary-light-9);
-							transition: all 0.3s ease;
-						}
-					}
-					@for $i from 0 through $homeNavLengh {
-						.home-animation#{$i} {
-							opacity: 0;
-							animation-name: error-num;
-							animation-duration: 0.5s;
-							animation-fill-mode: forwards;
-							animation-delay: calc($i/10) + s;
-						}
-					}
-				}
-			}
-		}
-	}
+    overflow: hidden;
+
+    .patTabel {
+        .el-table th.el-table__cell {
+            background-color: #6babfa;
+            color: #ffffff;
+        }
+
+        .el-table__body tr.current-row>td.el-table__cell {
+            background: rgb(197.7, 225.9, 255);
+            color: #409EFF;
+            /* height: 25px; */
+            /* border: tomato solid 1px; */
+        }
+    }
+
+}
+
+.patTitle {
+    height: 25px;
+    font-family: AlibabaPuHuiTi, AlibabaPuHuiTi;
+    font-weight: 500;
+    font-size: 18px;
+    color: #333333;
+    line-height: 20px;
+    letter-spacing: 1px;
+    text-align: left;
+    font-style: normal;
+    // margin-top: -10px;
+}
+
+.home-title {
+    margin-bottom: 4px;
+    flex: 1;
+    height: inherit;
+    display: flex;
+    align-items: center;
+}
+
+.detailRight {
+    margin-left: 10px;
+    background-color: #ffffff;
+}
+.itemDoby{
+    width: 100%; /* 设置容器宽度 */
+    overflow-x: auto; /* 横向内容溢出时显示滚动条 */
+}
+.fixed-div {
+    position: fixed;
+    flex: 1;
+    display: flex;
+    align-items: center;
+    bottom: 10px;
+    right: 30px;
+    width: 200px;
+    height: 100px;
+    color: rgb(16, 3, 3);
+    padding: 10px;
+    z-index: 999;
+
+    div {
+        font-weight: 800;
+        margin-left: 10px;
+        font-size: 20px;
+    }
+}
+
+.parent {
+    display: grid;
+    grid-template-columns: minmax(150px, 20%) 1fr;
 }
 </style>

--
Gitblit v1.8.0