chenyc
2024-08-21 59ba223820054f296191f581bd413f5b9cff9e7f
src/views/home/index.vue
@@ -1,85 +1,148 @@
<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 class="home-container layout-pd ">
        <el-row :gutter="15" >
            <el-col :xs="8" :sm="6" :md="4" :lg="3" class="patTabel">
                <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="14" :sm="18" :md="20" :lg="21" class="detailRight">
                <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>
                        <patientFile :tableHeight="state.tableHeight.detailRight"  ref="patientFileRef"></patientFile>
                    </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>
                        <lisUi ref="lisUiRef"></lisUi>
                    </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>
                        <MedicationRecords :tableHeight="state.tableHeight.detailRight" ref="MedicationRecordsRef"></MedicationRecords>
                    </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>
                        Task
                    </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>
                        <dietarySurvey></dietarySurvey>
                    </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>
                        Task
                    </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>
                        Task
                    </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>
                        Task
                    </el-tab-pane>
                </el-tabs>
            </el-col>
        </el-row>
        <div class="fixed-div" v-show="patientsInfo.patientName">
            <el-avatar :size="80" :src="patientsInfo.patientAvatarIcon" />
            <div>{{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'
interface User {
    code:string,
    patientName: string
    patientGenderText: string
    age: string
}
const MedicationRecordsRef=ref()
const patientFileRef=ref()
const currentRow=ref()
const lisUiRef=ref()
const state = reactive({
   global: {
      homeChartOne: null,
@@ -87,547 +150,150 @@
      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',
   },
    filterTableData:[],
    activeName:'患者档案',
    tableHeight:{
        left:0,
        detailRight:0
    },
    search:''
});
onMounted(()=>{
    setTableHeight()
    getPatients()
})
const handleCurrentChange = (val: any | undefined) => {
    console.log('-----------------333')
    console.log(val)
    if(val){
        currentRow.value = val
        //缓存到vuex 中
        storesPat.setPatientsInfo(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: ''
    })
    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')
// 折线图
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,
   }
);
/** 切换明细tabs*/
const handleClick=(tab: TabsPaneContext, event: Event)=>{
    alert('1')
    state.activeName=tab.paneName as string
    getTabsData()
}
/** 获取明细项数据 */
const getTabsData=()=>{
    if(MedicationRecordsRef.value&&patientsInfo.value.id){
        if(state.activeName==='用药记录'){
            MedicationRecordsRef.value.getData()
        }else if(state.activeName==='患者档案'){
            console.log(patientFileRef.value)
            patientFileRef.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;
                  }
               }
            }
         }
      }
   }
    .patTabel{
        .el-table th.el-table__cell {
            background-color: #6babfa;
            color:#606266;
        }
        .el-table__body tr.current-row>td.el-table__cell{
            background: #E4F6DE;
            color: #5FCD00;
            /* 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{
    background-color: #ffffff;
}
.fixed-div {
    position: fixed;
    flex: 1;
    display: flex;
    align-items: center;
    bottom: 10px;
    right: 30px;
    width: 200px;
    height: 100px;
    background-color:#ffffff;
    color: rgb(16, 3, 3);
    padding: 10px;
    z-index: 999;
    div{
        font-weight: 800;
        margin-left: 10px;
        font-size: 20px;
    }
  }
</style>