修改正式检测,使其能按照通道进行页面展示

This commit is contained in:
caozehui
2024-12-20 10:19:58 +08:00
parent ebc2ac1a41
commit 93b67fe845
8 changed files with 2206 additions and 2172 deletions

View File

@@ -1,4 +1,4 @@
export interface DataCheck{ export interface DataCheck {
testScriptName: string, testScriptName: string,
errorSysName: string, errorSysName: string,
dataRule: string, dataRule: string,
@@ -32,10 +32,65 @@ export interface RawDataItem {
L3: number L3: number
} }
/**
* 用于定义 (设备)通道的原始数据 // 用来描述检测脚本类型
*/ export interface ScriptItem {
export interface RawData { id: string,
chnNum: string, scriptItemName: string,
rawDataItems: RawDataItem[] children?: ScriptItem[]
} }
// 用来描述 通道检测结果
export enum ChnCheckResultEnum {
UNKNOWN = -1,
FAIL = 0,
SUCCESS = 1,
}
//用来描述 某个脚本测试项对所有通道的检测结果
export interface ScriptChnItem {
scriptID: string
scriptItemName: string
// 设备
devices: Array<{
deviceID: string,
deviceName: string,
chnResult: ChnCheckResultEnum[] //通道检测结果
}>
}
/**
* 用于描述 (设备)通道检测结果展示的按钮类型
*/
export interface ButtonResult {
resultType: 'info' | 'success' | 'danger',
resultValue: '-' | '√' | '×'
}
/**
* 用于描述 脚本检测结果展示的按钮类型
*/
export interface ScriptChnViewItem {
scriptID: string,
scriptItemName: string //脚本项名称
// 设备
devices:Array<{
deviceID: string,
deviceName: string,
chnResult: ButtonResult[],
}>
}
/**
* 定义检测日志类型
*/
export interface LogItem {
type: 'info' | 'error'
log: string
}

View File

@@ -1,42 +1,28 @@
<template> <template>
<div class="table-main"> <div class="table-main">
<el-collapse v-model="activeName" accordion style="width: 100%;height:335px"> <el-table :data="tableData" stripe border :header-cell-style="{ textAlign: 'center' } "
<el-collapse-item v-for="(item, index) in tableData" :key="index+1" :title="'通道'+ (index+1)" :name="'通道'+ (index+1)"> :cell-style="{ textAlign: 'center' }" height="335px"
style="width: 100%;">
<el-table :data="item.rawDataItems" stripe border :header-cell-style="{ textAlign: 'center' } " <el-table-column type="index" label="序号" width="70" fixed="left"/>
:cell-style="{ textAlign: 'center' }" height="335px" style="width: 100%;max-height: 250px;overflow-y: auto;"> <el-table-column prop="updateTime" label="数据时间"/>
<el-table-column type="index" fixed="left" label="序号" width="70"/> <el-table-column prop="L1" label="L1V"/>
<el-table-column prop="updateTime" label="数据时间"/> <el-table-column prop="L2" label="L2V"/>
<el-table-column prop="L1" label="L1V"/> <el-table-column prop="L3" label="L3V"/>
<el-table-column prop="L2" label="L2V"/> </el-table>
<el-table-column prop="L3" label="L3V"/>
</el-table>
</el-collapse-item>
</el-collapse>
</div> </div>
</template> </template>
<script lang="tsx" setup> <script lang="tsx" setup>
import type {RawData} from "@/api/check/interface"; import type {RawDataItem} from "@/api/check/interface";
const {tableData} = defineProps<{ const {tableData} = defineProps<{
tableData:RawData[] tableData: RawDataItem[]
}>() }>()
const activeName = ref('通道1')
// 清空数据
const clear = () => {
activeName.value = '通道1'
}
defineExpose({
clear
})
</script> </script>
<style scoped> <style scoped>

View File

@@ -3,7 +3,11 @@
<div class="table-main"> <div class="table-main">
<el-table :data="tableData" height="335px" :header-cell-style="{ textAlign: 'center' } " <el-table :data="tableData" height="335px" :header-cell-style="{ textAlign: 'center' } "
:cell-style="{ textAlign: 'center' }"> :cell-style="{ textAlign: 'center' }">
<el-table-column prop="chnNum" label="号" width="70"/> <el-table-column prop="chnNum" label="通道号" width="80">
<template #default="{row}">
{{ '通道' + row.chnNum }}
</template>
</el-table-column>
<el-table-column prop="standardValue" label="标准值V"/> <el-table-column prop="standardValue" label="标准值V"/>
<el-table-column label="L1V"> <el-table-column label="L1V">
<el-table-column prop="L1" width="80" label="被检值"> <el-table-column prop="L1" width="80" label="被检值">
@@ -33,9 +37,6 @@
</el-table-column> </el-table-column>
<el-table-column prop="result" label="检测结果"> <el-table-column prop="result" label="检测结果">
<!-- <template #default="scope">
<el-tag :type="scope.row.Result === '合格' ? 'success' : 'danger'">{{ scope.row.Result }}</el-tag>
</template> -->
<template #default="scope"> <template #default="scope">
<el-tag type="danger" v-if="scope.row.result === '不合格'">{{ scope.row.result }}</el-tag> <el-tag type="danger" v-if="scope.row.result === '不合格'">{{ scope.row.result }}</el-tag>
<span v-if="scope.row.result != '不合格'">{{ scope.row.result }}</span> <span v-if="scope.row.result != '不合格'">{{ scope.row.result }}</span>

View File

@@ -17,7 +17,7 @@
<el-input v-model='formContent.deviceName' :disabled="true"/> <el-input v-model='formContent.deviceName' :disabled="true"/>
</el-form-item> </el-form-item>
<el-form-item label='通道号'> <el-form-item label='通道号'>
<el-select v-model="formContent.monitorIdx"> <el-select v-model="formContent.monitorIdx" @change="handleChnNumChange">
<el-option v-for="item in monitorIdxList" :key="item.value" :label="item.value" <el-option v-for="item in monitorIdxList" :key="item.value" :label="item.value"
:value="item.value"/> :value="item.value"/>
</el-select> </el-select>
@@ -28,9 +28,9 @@
<div class="data-check-body"> <div class="data-check-body">
<div class="content-left-tree"> <div class="content-left-tree">
<div> <div>
<el-radio-group v-model="scriptSwitch"> <el-radio-group v-model="checkItemSwitch" @change="handleCheckItemSwitch">
<el-radio-button label="不合格测试项" value="0"/> <el-radio-button label="不合格测试项" :value="0"/>
<el-radio-button label="全部测试项" value="1"/> <el-radio-button label="全部测试项" :value="1"/>
</el-radio-group> </el-radio-group>
</div> </div>
<div class="content-tree"> <div class="content-tree">
@@ -65,12 +65,12 @@ import {dialogBig} from '@/utils/elementBind'
import {reactive, ref} from 'vue' import {reactive, ref} from 'vue'
import DataCheckResultTable from './dataCheckResultTable.vue' import DataCheckResultTable from './dataCheckResultTable.vue'
import DataCheckRawDataTable from './dataCheckRawDataTable.vue' import DataCheckRawDataTable from './dataCheckRawDataTable.vue'
import type {CheckResult, DataCheck, RawData} from "@/api/check/interface"; import type {CheckResult, DataCheck, RawDataItem} from "@/api/check/interface";
import {data as treeData} from "@/api/plan/autoTest.json"; import {data as treeData} from "@/api/plan/autoTest.json";
const {appendToBody} = defineProps<{ const {appendToBody} = withDefaults(defineProps<{
appendToBody:boolean appendToBody: boolean
}>() }>(), {appendToBody: false})
const formContent = reactive<DataCheck>({ const formContent = reactive<DataCheck>({
@@ -83,7 +83,7 @@ const formContent = reactive<DataCheck>({
const activeName = ref('resultTab') const activeName = ref('resultTab')
const scriptSwitch = ref('0'); const checkItemSwitch = ref(0)
const currentScriptDsc = ref('电压准确度检测频率42.5Hz Ua=46.192V 0° Ub=46.192V -120° Uc=46.192V 120° Ia=1A 0° Ib=1A -120° Ic=1A 120°'); const currentScriptDsc = ref('电压准确度检测频率42.5Hz Ua=46.192V 0° Ub=46.192V -120° Uc=46.192V 120° Ia=1A 0° Ib=1A -120° Ic=1A 120°');
@@ -108,6 +108,20 @@ const monitorIdxList = [
}, },
] ]
// 改变通道号下拉框触发事件
const handleChnNumChange = (data: any) => {
console.log(data);
}
// 切换不合格测试项、全部测试项 触发事件
const handleCheckItemSwitch = (data: any) => {
// 0 不合格测试项、1 全部测试项
if (data === 0) {
} else {
}
}
// 点击左侧树节点触发事件 // 点击左侧树节点触发事件
const handleNodeClick = (data: any) => { const handleNodeClick = (data: any) => {
@@ -126,396 +140,129 @@ const checkResultTableData = reactive<CheckResult[]>([
L3_errValue: 0.01, L3_errValue: 0.01,
maxErrVaule: 0.05774, maxErrVaule: 0.05774,
result: '合格', result: '合格',
},
{
chnNum: '2',
standardValue: 57.74,
L1: 57.73,
L1_errValue: 0.01,
L2: 57.73,
L2_errValue: 0.01,
L3: 57.73,
L3_errValue: 0.01,
maxErrVaule: 0.05774,
result: '合格',
} }
]) ])
const rawTableData = reactive<RawData[]>([ const rawTableData = reactive<RawDataItem[]>([
{ {
chnNum: '1', updateTime: "2024-10-10 09:30:00",
rawDataItems: [ L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:00", L3: 57.73,
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:03",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:06",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:09",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:12",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:15",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:18",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:21",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:24",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:27",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:30",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:33",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:36",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:39",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:42",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:45",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:48",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:51",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:54",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:57",
L1: 57.73,
L2: 57.73,
L3: 57.73,
}
]
}, },
{ {
chnNum: '2', updateTime: "2024-10-10 09:30:03",
rawDataItems: [ L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:00", L3: 57.73,
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:03",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:06",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:09",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:12",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:15",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:18",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:21",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:24",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:27",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:30",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:33",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:36",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:39",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:42",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:45",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:48",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:51",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:54",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:57",
L1: 57.73,
L2: 57.73,
L3: 57.73,
}
]
}, },
{ {
chnNum: '3', updateTime: "2024-10-10 09:30:06",
rawDataItems: [ L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:00", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:09",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:03", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:12",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:06", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:15",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:09", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:18",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:12", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:21",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:15", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:24",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:18", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:27",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:21", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:30",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:24", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:33",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:27", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:36",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:30", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:39",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:33", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:42",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:36", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:45",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:39", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:48",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:42", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:51",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:45", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:54",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:48", L3: 57.73,
L1: 57.73, },
L2: 57.73, {
L3: 57.73, updateTime: "2024-10-10 09:30:57",
}, L1: 57.73,
{ L2: 57.73,
updateTime: "2024-10-10 09:30:51", L3: 57.73,
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:54",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:57",
L1: 57.73,
L2: 57.73,
L3: 57.73,
}
]
} }
]) ])
@@ -528,12 +275,11 @@ const close = () => {
//数据清空 //数据清空
activeName.value = 'rawDataTab' activeName.value = 'rawDataTab'
rawDataTableRef.value?.clear()
visible.value = false; visible.value = false;
}; };
const open = (deviceItem: any, chnNum: number) => { const open = (deviceItem: any, chnNum?: number) => {
// 发起后端请求,查询详细信息 // 发起后端请求,查询详细信息
// const deviceItem = await getDetail(planId,checkItemId,deviceItem.id, chnNum) // const deviceItem = await getDetail(planId,checkItemId,deviceItem.id, chnNum)
@@ -610,7 +356,6 @@ defineExpose({
margin-bottom: 10px; margin-bottom: 10px;
max-height: 400px; max-height: 400px;
} }
} }
} }
} }

View File

@@ -114,8 +114,7 @@
:icon="View" :icon="View"
@click="openDrawer('查看', scope.row)" @click="openDrawer('查看', scope.row)"
v-if="form.activeTabs === 3 && form.activeChildTabs === 1" v-if="form.activeTabs === 3 && form.activeChildTabs === 1"
>查看</el-button >查看</el-button>
>
<el-button <el-button
type="primary" type="primary"
@@ -123,8 +122,7 @@
:icon="Download" :icon="Download"
@click="openDrawer('报告下载', scope.row)" @click="openDrawer('报告下载', scope.row)"
v-if="form.activeTabs === 3 && form.activeChildTabs === 0 && scope.row.reportState === 1" v-if="form.activeTabs === 3 && form.activeChildTabs === 0 && scope.row.reportState === 1"
>报告下载</el-button >报告下载</el-button>
>
<!-- <div class='cn-render-buttons' v-if="form.activeTabs === 3 && form.activeChildTabs === 0"> <!-- <div class='cn-render-buttons' v-if="form.activeTabs === 3 && form.activeChildTabs === 0">
<el-dropdown trigger='click'> <el-dropdown trigger='click'>
@@ -147,8 +145,7 @@
:icon="Postcard" :icon="Postcard"
@click="openDrawer('生成', scope.row)" @click="openDrawer('生成', scope.row)"
v-if="form.activeTabs === 3" v-if="form.activeTabs === 3"
>报告生成</el-button >报告生成</el-button>
>
<!-- <el-button <!-- <el-button
type="primary" type="primary"
link link
@@ -164,24 +161,23 @@
@click="openDrawer('归档', scope.row)" @click="openDrawer('归档', scope.row)"
v-if="form.activeTabs === 4" v-if="form.activeTabs === 4"
:disabled = "scope.row.checkState != 2" :disabled = "scope.row.checkState != 2"
>归档</el-button >归档</el-button>
>
<el-button <el-button
type="primary" type="primary"
link link
:icon="PieChart" :icon="PieChart"
@click="openDrawer('检测数据查询', scope.row)" @click="openDrawer('检测数据查询', scope.row)"
v-if="form.activeTabs === 5" v-if="form.activeTabs === 5"
>检测数据查询</el-button >检测数据查询</el-button>
>
<el-button <el-button
type="primary" type="primary"
link link
:icon="Switch" :icon="Switch"
@click="openDrawer('误差体系更换', scope.row)" @click="openDrawer('误差体系更换', scope.row)"
v-if="form.activeTabs === 5 && scope.row.documentState === 1" v-if="form.activeTabs === 5 && scope.row.documentState === 1"
>误差体系更换</el-button >误差体系更换</el-button>
>
<div class='cn-render-buttons' v-if="form.activeTabs === 5 && scope.row.documentState === 1"> <div class='cn-render-buttons' v-if="form.activeTabs === 5 && scope.row.documentState === 1">
<el-dropdown trigger='click'> <el-dropdown trigger='click'>
@@ -214,17 +210,14 @@
:dialogTitle="dialogTitle" :dialogTitle="dialogTitle"
@update:visible="dialogFormVisible = $event" @update:visible="dialogFormVisible = $event"
/> --> /> -->
<TestPopup ref="testPopup"></TestPopup> <TestPopup ref="testPopup"></TestPopup>
<reportPopup <reportPopup
:visible="reportDialogVisible" :visible="reportDialogVisible"
@update:visible="reportDialogVisible = $event" @update:visible="reportDialogVisible = $event"
></reportPopup> ></reportPopup>
<dataCheckPopup <dataCheckPopup ref="dataCheckPopupRef"/>
:visible="dataCheckDialogVisible"
@update:visible="dataCheckDialogVisible = $event"
></dataCheckPopup>
<dataCheckChangeErrSysPopup <dataCheckChangeErrSysPopup
:visible="dataCheckChangeErrSysDialogVisible" :visible="dataCheckChangeErrSysDialogVisible"
@@ -236,7 +229,7 @@
@update:visible="matchDialogVisible = $event" @update:visible="matchDialogVisible = $event"
></matchPopup> ></matchPopup>
<!--系数校准-->> <!--系数校准-->
<ChannelsTest ref="channelsTest"></ChannelsTest> <ChannelsTest ref="channelsTest"></ChannelsTest>
</div> </div>
</template> </template>
@@ -255,7 +248,7 @@ import { getPlanList } from "@/api/plan/planList";
import deviceDataList from '@/api/device/device/deviceData' import deviceDataList from '@/api/device/device/deviceData'
import TestPopup from "./testPopup.vue"; import TestPopup from "./testPopup.vue";
import reportPopup from "./reportPopup.vue"; import reportPopup from "./reportPopup.vue";
import dataCheckPopup from "./dataCheckPopup.vue"; import dataCheckPopup from "./dataCheckSingleChannelSingleTestPopup.vue";
import dataCheckChangeErrSysPopup from "./dataCheckChangeErrSysPopup.vue"; import dataCheckChangeErrSysPopup from "./dataCheckChangeErrSysPopup.vue";
import { getBoundPqDevList } from '@/api/plan/plan.ts' import { getBoundPqDevList } from '@/api/plan/plan.ts'
import { onMounted, reactive, ref, watch } from "vue"; import { onMounted, reactive, ref, watch } from "vue";
@@ -273,7 +266,9 @@ const value1 = ref("");
const value2 = ref(""); const value2 = ref("");
const tableHeight = ref(0); const tableHeight = ref(0);
const reportDialogVisible = ref(false) const reportDialogVisible = ref(false)
const dataCheckDialogVisible = ref(false)
const dataCheckPopupRef=ref<InstanceType<typeof dataCheckPopup>>()
const dataCheckChangeErrSysDialogVisible = ref(false) const dataCheckChangeErrSysDialogVisible = ref(false)
const matchDialogVisible = ref(false) const matchDialogVisible = ref(false)
const dialogTitle = ref('手动检测') const dialogTitle = ref('手动检测')
@@ -404,7 +399,7 @@ const getTableList = async (params: any) => {
}else{ }else{
checkStateList.value = checkStateTable.value checkStateList.value = checkStateTable.value
} }
return getBoundPqDevList({'planId': props.id,  return getBoundPqDevList({'planId': props.id,
'checkStateList': checkStateList.value, 'checkStateList': checkStateList.value,
'checkResult': form.value.checkResult, 'checkResult': form.value.checkResult,
'reportState': form.value.checkReportStatus, 'reportState': form.value.checkReportStatus,
@@ -866,7 +861,8 @@ const openDrawer = (title: string, row: any) => {
if(title === '检测数据查询') if(title === '检测数据查询')
{ {
dataCheckDialogVisible.value = true; let device={}
dataCheckPopupRef.value?.open(device)
} }
if (title === '误差体系更换') if (title === '误差体系更换')
{ {

File diff suppressed because it is too large Load Diff

View File

@@ -10,12 +10,12 @@
<div class="error-dsc"> <div class="error-dsc">
<div class="green-div"></div> <div class="green-div"></div>
<span style=" color: #606266; font-size: 16px;font-weight: 600;"> <span style=" color: #606266; font-size: 16px;font-weight: 600;">
守时误差1000ms 符合1000ms
</span> </span>
<div class="red-div"></div> <div class="red-div"></div>
<span style=" color: #F56C6c; font-size: 16px;font-weight: 600;"> <span style=" color: #F56C6c; font-size: 16px;font-weight: 600;">
守时误差>1000ms 不符合>1000ms
</span> </span>
</div> </div>
</div> </div>

View File

@@ -2,23 +2,23 @@
<template> <template>
<div class="static"> <div class="static">
<div class="left_tree"> <div class="left_tree">
<tree ref="treeRef" :updateSelectedTreeNode="getPieData || (() => {})" /> <tree ref="treeRef" :updateSelectedTreeNode="getPieData || (() => {})"/>
</div> </div>
<!-- <span class="new_span">测试scss颜色</span> --> <!-- <span class="new_span">测试scss颜色</span> -->
<div class="right_container"> <div class="right_container">
<!-- 功能选择 --> <!-- 功能选择 -->
<div class="container_function"> <div class="container_function">
<div <div
class="function_item" class="function_item"
:class=" :class="
item.checked ? 'function_item checked_function' : 'function_item' item.checked ? 'function_item checked_function' : 'function_item'
" "
v-for="(item, index) in tabsList" v-for="(item, index) in tabsList"
:key="index" :key="index"
@click="handleCheckFunction(item.value)" @click="handleCheckFunction(item.value)"
> >
<div class="item_img"> <div class="item_img">
<img :src="item.img" alt="" /> <img :src="item.img" alt=""/>
</div> </div>
<div class="item_text"> <div class="item_text">
<p>{{ item.label }}</p> <p>{{ item.label }}</p>
@@ -26,46 +26,46 @@
</div> </div>
</div> </div>
<!-- <el-collapse v-model="activeNames" @change="handleChange"> <!-- <el-collapse v-model="activeNames" @change="handleChange">
<el-collapse-item title="检测进度展示" name="1"> --> <el-collapse-item title="检测进度展示" name="1"> -->
<div class="container_pieShow"> <div class="container_pieShow">
<el-collapse model-value="1" accordion @change="handleCollapseChange"> <el-collapse model-value="1" accordion @change="handleCollapseChange">
<el-collapse-item title="&nbsp&nbsp&nbsp&nbsp&nbsp检测计划统计" name="1"> <el-collapse-item title="&nbsp&nbsp&nbsp&nbsp&nbsp检测计划统计" name="1">
<!-- 饼图 --> <!-- 饼图 -->
<div class="container_charts"> <div class="container_charts">
<div class="charts_info" ref="chartsInfoRef"> <div class="charts_info" ref="chartsInfoRef">
<pie <pie
:customData="{ :customData="{
title: '设备检测状态', title: '设备检测状态',
textAlign: 'left', textAlign: 'left',
}" }"
:legendData="{ :legendData="{
icon: 'circle', icon: 'circle',
left: 'left', left: 'left',
top: 'bottom', top: 'bottom',
}" }"
:chartsData="chartsData1" :chartsData="chartsData1"
ref="pieRef1" ref="pieRef1"
></pie> ></pie>
</div> </div>
<div class="charts_info"> <div class="charts_info">
<pie <pie
:customData="{ :customData="{
title: '设备检测结果', title: '设备检测结果',
textAlign: 'left', textAlign: 'left',
}" }"
:legendData="{ :legendData="{
icon: 'circle', icon: 'circle',
left: 'left', left: 'left',
top: 'bottom', top: 'bottom',
}" }"
:chartsData="chartsData2" :chartsData="chartsData2"
ref="pieRef2" ref="pieRef2"
></pie> ></pie>
</div> </div>
<div class="charts_info"> <div class="charts_info">
<pie <pie
:customData="{ :customData="{
title: '设备报告状态', title: '设备报告状态',
textAlign: 'left', textAlign: 'left',
label: { label: {
@@ -74,56 +74,52 @@
}, },
}, },
}" }"
:legendData="{ :legendData="{
icon: 'circle', icon: 'circle',
left: 'left', left: 'left',
top: 'bottom', top: 'bottom',
}" }"
:chartsData="chartsData3" :chartsData="chartsData3"
ref="pieRef3" ref="pieRef3"
></pie> ></pie>
</div> </div>
</div> </div>
</el-collapse-item> </el-collapse-item>
</el-collapse> </el-collapse>
</div>
<el-tabs class="tabs-menu" type="border-card" @tab-change="handleTabsChange" v-model="editableTabsValue" :style="{ height: tabsHeight }">
<el-tab-pane :label="tabLabel1" :style="{ height: tabPaneHeight }">
<!-- 列表数据 -->
<div class="container_table" :style="{ height: tableHeight }">
<Table ref="tableRef1" :id='currentId' :isTimeCheck = 'isTimeCheck'></Table>
</div>
</el-tab-pane>
<!-- <el-tab-pane label="已检设备" v-if="tabShow" :style="{ height: tabPaneHeight }">-->
<!-- &lt;!&ndash; 列表数据 &ndash;&gt;-->
<!-- <div class="container_table" :style="{ height: tableHeight }">-->
<!-- <Table ref="tableRef2" :id='currentId'></Table>-->
<!-- </div>-->
<!-- </el-tab-pane>-->
</el-tabs>
</div> </div>
<el-tabs class="tabs-menu" type="border-card" @tab-change="handleTabsChange" v-model="editableTabsValue" :style="{ height: tabsHeight }">
<el-tab-pane :label="tabLabel1" :style="{ height: tabPaneHeight }">
<!-- 列表数据 -->
<div class="container_table" :style="{ height: tableHeight }">
<Table ref="tableRef1" :id='currentId' :isTimeCheck='isTimeCheck'></Table>
</div>
</el-tab-pane>
<!-- <el-tab-pane label="已检设备" v-if="tabShow" :style="{ height: tabPaneHeight }">-->
<!-- &lt;!&ndash; 列表数据 &ndash;&gt;-->
<!-- <div class="container_table" :style="{ height: tableHeight }">-->
<!-- <Table ref="tableRef2" :id='currentId'></Table>-->
<!-- </div>-->
<!-- </el-tab-pane>-->
</el-tabs>
</div>
</div> </div>
</template> </template>
<script lang="ts" setup> <script lang="ts" setup>
import { getStaticTreeData } from "@/api/plan/static";
import pie from "@/components/echarts/pie/default.vue"; import pie from "@/components/echarts/pie/default.vue";
import { useRouter } from "vue-router"; import {useRouter} from "vue-router";
import tree from "../components/tree.vue"; import tree from "../components/tree.vue";
import Table from "../components/table.vue"; import Table from "../components/table.vue";
//import { data } from "@/api/plan/static.json"; //import { data } from "@/api/plan/static.json";
import deviceDataList from '@/api/device/device/deviceData' import deviceDataList from '@/api/device/device/deviceData'
import {getPlanListByPattern } from '@/api/plan/plan.ts' import {getBoundPqDevList, getPlanListByPattern} from '@/api/plan/plan.ts'
import { onBeforeMount, onMounted, onUnmounted, ref, watch } from "vue"; import {onBeforeMount, onUnmounted, ref, watch} from "vue";
import { useModeStore } from '@/stores/modules/mode'; // 引入模式 store import {useModeStore} from '@/stores/modules/mode'; // 引入模式 store
import { useDictStore } from '@/stores/modules/dict' import {useDictStore} from '@/stores/modules/dict'
import { type Plan } from "@/api/plan/interface"; import {type Plan} from "@/api/plan/interface";
import type { CollapseModelValue } from "element-plus/es/components/collapse/src/collapse.mjs"; import type {CollapseModelValue} from "element-plus/es/components/collapse/src/collapse.mjs";
import { type Device } from "@/api/device/interface/device"; import {type Device} from "@/api/device/interface/device";
import { getBoundPqDevList } from '@/api/plan/plan.ts' import {ResultData} from "@/api/interface";
import { CENTERED_ALIGNMENT } from "element-plus/es/components/virtual-list/src/defaults";
import { ResultData } from "@/api/interface";
const dictStore = useDictStore() const dictStore = useDictStore()
const modeStore = useModeStore(); const modeStore = useModeStore();
@@ -143,10 +139,10 @@ const form: any = ref({
}); });
const router = useRouter(); const router = useRouter();
const activeNames = ref(['2']) const activeNames = ref(['2'])
const tabShow= ref(false); const tabShow = ref(false);
const tabLabel1 = ref('设备检测') const tabLabel1 = ref('设备检测')
const editableTabsValue = ref('0') const editableTabsValue = ref('0')
const checkStateTable = ref<number[]>([0,1,2]) const checkStateTable = ref<number[]>([0, 1, 2])
const tabsHeight = ref('calc(100vh - 538px)'); // 初始高度 const tabsHeight = ref('calc(100vh - 538px)'); // 初始高度
const tabPaneHeight = ref('calc(100% - 5px)'); // 初始高度 const tabPaneHeight = ref('calc(100% - 5px)'); // 初始高度
@@ -220,53 +216,51 @@ const tableRef2 = ref();
const currentId = ref(''); const currentId = ref('');
watch( watch(
() => form.value, () => form.value,
(val, oldVal) => { (val, oldVal) => {
if (val) { if (val) {
if(form.value.activeTabs === 0 )//设备检测 if (form.value.activeTabs === 0)//设备检测
{
const tabledata = deviceData.filter((item) => item.document_State === "未归档")
tableRef1.value && tableRef1.value.changeActiveTabs(form.value.activeTabs, form.value.activeChildTabs, tabledata);
} else if (form.value.activeTabs === 4)//设备归档
{
const tabledata = deviceData.filter((item) => item.check_State === "检测完成" && item.document_State === "未归档")
tableRef1.value && tableRef1.value.changeActiveTabs(form.value.activeTabs, form.value.activeChildTabs, tabledata);
} else if (form.value.activeTabs === 3 || form.value.activeTabs === 5)//报告生成、数据查询
{
const tabledata = deviceData.filter((item) => item.check_State === "检测完成");
tableRef1.value && tableRef1.value.changeActiveTabs(form.value.activeTabs, form.value.activeChildTabs, tabledata);
}
}
},
{ {
const tabledata = deviceData.filter((item) => item.document_State === "未归档") immediate: true,
tableRef1.value && tableRef1.value.changeActiveTabs(form.value.activeTabs,form.value.activeChildTabs,tabledata); deep: true,
} }
else if(form.value.activeTabs === 4)//设备归档
{
const tabledata = deviceData.filter((item) => item.check_State === "检测完成" && item.document_State === "未归档")
tableRef1.value && tableRef1.value.changeActiveTabs(form.value.activeTabs,form.value.activeChildTabs,tabledata);
}
else if(form.value.activeTabs === 3 || form.value.activeTabs === 5)//报告生成、数据查询
{
const tabledata = deviceData.filter((item) => item.check_State === "检测完成");
tableRef1.value && tableRef1.value.changeActiveTabs(form.value.activeTabs,form.value.activeChildTabs,tabledata);
}
}
},
{
immediate: true,
deep: true,
}
); );
watch( watch(
() => form.value, () => form.value,
(val, oldVal) => { (val, oldVal) => {
if (val) { if (val) {
tableRef2.value && tableRef2.value.changeActiveTabs(form.value.activeTabs,form.value.activeChildTabs); tableRef2.value && tableRef2.value.changeActiveTabs(form.value.activeTabs, form.value.activeChildTabs);
}
},
{
immediate: true,
deep: true,
} }
},
{
immediate: true,
deep: true,
}
); );
const pieRef1 = ref(), const pieRef1 = ref(),
pieRef2 = ref(), pieRef2 = ref(),
pieRef3 = ref(); pieRef3 = ref();
const chartsData1: any = ref([]), const chartsData1: any = ref([]),
chartsData2: any = ref([]), chartsData2: any = ref([]),
chartsData3: any = ref([]); chartsData3: any = ref([]);
const findPlanById = (plans: Plan.ReqPlan[], id: string): Plan.ReqPlan | undefined => { const findPlanById = (plans: Plan.ReqPlan[], id: string): Plan.ReqPlan | undefined => {
for (const plan of plans) { for (const plan of plans) {
if (plan.id === id) { if (plan.id === id) {
return plan; return plan;
@@ -287,14 +281,14 @@ const getPieData = async (id: string) => {
//handleCheckFunction(0)//切换左侧树默认css功能是设备检测 //handleCheckFunction(0)//切换左侧树默认css功能是设备检测
// 初始化计数对象 // 初始化计数对象
const checkStateCount: { [key: number]: number } = { 0: 0, 1: 0, 2: 0, 3: 0 }; const checkStateCount: { [key: number]: number } = {0: 0, 1: 0, 2: 0, 3: 0};
const checkResultCount: { [key: number]: number } = { 0: 0, 1: 0, 2: 0 }; const checkResultCount: { [key: number]: number } = {0: 0, 1: 0, 2: 0};
const reportStateCount: { [key: number]: number } = { 0: 0, 1: 0, 2: 0 }; const reportStateCount: { [key: number]: number } = {0: 0, 1: 0, 2: 0};
if (id) { if (id) {
const boundPqDevList = ref<Device.ResPqDev[]>([])//根据检测计划id查询出所有已绑定的设备 const boundPqDevList = ref<Device.ResPqDev[]>([])//根据检测计划id查询出所有已绑定的设备
const plan = findPlanById(planList.value?.data || [], id); const plan = findPlanById(planList.value?.data || [], id);
if (plan) { if (plan) {
isTimeCheck.value = plan.timeCheck ===1; // 将 1 转换为 true0 转换为 false isTimeCheck.value = plan.timeCheck === 1; // 将 1 转换为 true0 转换为 false
} else { } else {
// 处理未找到计划的情况 // 处理未找到计划的情况
isTimeCheck.value = false; // 或者其他默认值 isTimeCheck.value = false; // 或者其他默认值
@@ -320,20 +314,20 @@ const getPieData = async (id: string) => {
} }
chartsData1.value = [ chartsData1.value = [
{ value: checkStateCount[0], name: "未检", itemStyle: { color: '#fac858' } }, {value: checkStateCount[0], name: "未检", itemStyle: {color: '#fac858'}},
{ value: checkStateCount[1], name: "检测中", itemStyle: { color: '#ee6666' } }, {value: checkStateCount[1], name: "检测中", itemStyle: {color: '#ee6666'}},
{ value: checkStateCount[2], name: "检测完成", itemStyle: { color: '#91cc75' } }, {value: checkStateCount[2], name: "检测完成", itemStyle: {color: '#91cc75'}},
{ value: checkStateCount[3], name: "归档", itemStyle: { color: '#5470c6' } }, {value: checkStateCount[3], name: "归档", itemStyle: {color: '#5470c6'}},
]; ];
chartsData2.value = [ chartsData2.value = [
{ value: checkResultCount[2], name: "未检" , itemStyle: { color: '#fac858' } }, {value: checkResultCount[2], name: "未检", itemStyle: {color: '#fac858'}},
{ value: checkResultCount[0], name: "不符合" , itemStyle: { color: '#ee6666' } }, {value: checkResultCount[0], name: "不符合", itemStyle: {color: '#ee6666'}},
{ value: checkResultCount[1], name: "符合", itemStyle: { color: '#91cc75' } }, {value: checkResultCount[1], name: "符合", itemStyle: {color: '#91cc75'}},
]; ];
chartsData3.value = [ chartsData3.value = [
{ value: reportStateCount[2], name: "未检" , itemStyle: { color: '#fac858' } }, {value: reportStateCount[2], name: "未检", itemStyle: {color: '#fac858'}},
{ value: reportStateCount[0], name: "未生成" , itemStyle: { color: '#ee6666' } }, {value: reportStateCount[0], name: "未生成", itemStyle: {color: '#ee6666'}},
{ value: reportStateCount[1], name: "已生成", itemStyle: { color: '#91cc75' } }, {value: reportStateCount[1], name: "已生成", itemStyle: {color: '#91cc75'}},
]; ];
pieRef1.value.init(); pieRef1.value.init();
@@ -344,7 +338,7 @@ const getPieData = async (id: string) => {
// pieRef3.value.reSize(470,145,true); // pieRef3.value.reSize(470,145,true);
}; };
const getTree = (data?: any) => { const getTree = (data?: any) => {
treeRef.value.getTreeData(data); treeRef.value.getTreeData(data);
}; };
//前往检测 //前往检测
const handleDetection = () => { const handleDetection = () => {
@@ -374,76 +368,75 @@ const handleCheckFunction = (val: any) => {
switch (val) { switch (val) {
case 0://自动检测 case 0://自动检测
checkStateTable.value = [0,1,2] checkStateTable.value = [0, 1, 2]
tabLabel1.value = "设备检测"; tabLabel1.value = "设备检测";
break; break;
case 1://手动检测 case 1://手动检测
tabLabel1.value = "手动检测"; tabLabel1.value = "手动检测";
break; break;
case 2://设备复检 case 2://设备复检
tabLabel1.value = "设备复检"; tabLabel1.value = "设备复检";
break; break;
case 3://报告生成 case 3://报告生成
checkStateTable.value = [2,3] checkStateTable.value = [2, 3]
tabLabel1.value = "报告生成"; tabLabel1.value = "报告生成";
//tabShow.value = true; //tabShow.value = true;
break; break;
case 4://设备归档 case 4://设备归档
checkStateTable.value = [2] checkStateTable.value = [2]
tabLabel1.value = "设备归档"; tabLabel1.value = "设备归档";
break; break;
case 5://数据查询 case 5://数据查询
checkStateTable.value = [2,3] checkStateTable.value = [2, 3]
tabLabel1.value = "数据查询"; tabLabel1.value = "数据查询";
break; break;
} }
form.value.activeTabs = val; form.value.activeTabs = val;
}; };
const resizeObserver = new ResizeObserver(entries => { const resizeObserver = new ResizeObserver(entries => {
for (let entry of entries) { for (let entry of entries) {
chartsWidth.value = entry.contentRect.width; chartsWidth.value = entry.contentRect.width;
//console.log('Charts Info Width:', chartsWidth.value); //console.log('Charts Info Width:', chartsWidth.value);
pieRef1.value.reSize(chartsWidth.value * 0.95,180,true); pieRef1.value.reSize(chartsWidth.value * 0.95, 180, true);
pieRef2.value.reSize(chartsWidth.value * 0.95,180,true); pieRef2.value.reSize(chartsWidth.value * 0.95, 180, true);
pieRef3.value.reSize(chartsWidth.value * 0.95,180,true); pieRef3.value.reSize(chartsWidth.value * 0.95, 180, true);
} }
}); });
onBeforeMount(async () => { onBeforeMount(async () => {
const patternId = dictStore.getDictData('Pattern').find(item=>item.name=== modeStore.currentMode)?.id ?? ''//获取数据字典中对应的id const patternId = dictStore.getDictData('Pattern').find(item => item.name === modeStore.currentMode)?.id ?? ''//获取数据字典中对应的id
const reqPlan: Plan.ReqPlan = { const reqPlan: Plan.ReqPlan = {
pattern: patternId, pattern: patternId,
datasourceIds: "", datasourceIds: "",
sourceIds: "", sourceIds: "",
planId: "", planId: "",
scriptName: "", scriptName: "",
errorSysName: "", errorSysName: "",
sourceName: "", sourceName: "",
devIds: [], devIds: [],
id: "", id: "",
name: "", name: "",
dataSourceId: "", dataSourceId: "",
scriptId: "", scriptId: "",
errorSysId: "", errorSysId: "",
timeCheck: 0, timeCheck: 0,
testState: 0, testState: 0,
reportState: 0, reportState: 0,
result: 0, result: 0,
code: 0, code: 0,
state: 0 state: 0
}; };
planList.value = (await getPlanListByPattern(reqPlan)) as ResultData<Plan.ReqPlan[]>; planList.value = (await getPlanListByPattern(reqPlan)) as ResultData<Plan.ReqPlan[]>;
console.log('qqq',planList.value) console.log('qqq', planList.value)
if (planList.value.data[0].children[0]) { if (planList.value.data[0].children[0]) {
currentId.value = planList.value.data[0].children[0].id; currentId.value = planList.value.data[0].children[0].id;
} }
if (chartsInfoRef.value) { if (chartsInfoRef.value) {
resizeObserver.observe(chartsInfoRef.value); resizeObserver.observe(chartsInfoRef.value);
} }
getTree(planList.value.data); getTree(planList.value.data);
@@ -458,7 +451,6 @@ onUnmounted(() => {
}); });
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.static { .static {
@@ -467,7 +459,7 @@ onUnmounted(() => {
height: 100%; height: 100%;
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
//background-color: #eee; //background-color: #eee;
.left_tree { .left_tree {
width: 14% !important; width: 14% !important;
@@ -513,6 +505,7 @@ onUnmounted(() => {
border-radius: 8px; border-radius: 8px;
padding: 0px 30px; padding: 0px 30px;
margin-right: 50px;; margin-right: 50px;;
.item_img { .item_img {
width: 60px; width: 60px;
height: 60px; height: 60px;
@@ -542,7 +535,7 @@ onUnmounted(() => {
p { p {
margin: 0; margin: 0;
font-weight: 800; font-weight: 800;
color:#fff; color: #fff;
font-size: 14px; font-size: 14px;
font-family: "Microsoft YaHei", "微软雅黑", "Arial", sans-serif; font-family: "Microsoft YaHei", "微软雅黑", "Arial", sans-serif;
} }
@@ -565,6 +558,7 @@ onUnmounted(() => {
} }
} }
} }
// .container_function { // .container_function {
// width: 100%; // width: 100%;
// height: auto; // height: auto;
@@ -646,20 +640,21 @@ onUnmounted(() => {
// } // }
// } // }
.container_pieShow{ .container_pieShow {
width: 100% !important; width: 100% !important;
//min-height: 200px !important; //min-height: 200px !important;
height:auto; height: auto;
background-color: #eee; background-color: #eee;
// display: flex; // display: flex;
// justify-content: space-between; // justify-content: space-between;
// padding-left: 2ch; // padding-left: 2ch;
margin-bottom: 10px; margin-bottom: 10px;
} }
.el-collapse { .el-collapse {
width: 100% !important; width: 100% !important;
// min-height: 200px !important; // min-height: 200px !important;
height:100% !important; height: 100% !important;
background-color: #eee; background-color: #eee;
// display: flex; // display: flex;
// justify-content: space-between; // justify-content: space-between;
@@ -667,10 +662,10 @@ onUnmounted(() => {
// margin-bottom: 10px; // margin-bottom: 10px;
} }
.el-collapse-item{ .el-collapse-item {
width: 100% !important; width: 100% !important;
// min-height: 200px !important; // min-height: 200px !important;
height:100% !important; height: 100% !important;
background-color: #eee; background-color: #eee;
// display: flex !important; // display: flex !important;
} }
@@ -678,7 +673,7 @@ onUnmounted(() => {
.container_charts { .container_charts {
width: 100%; width: 100%;
//min-height: 180px !important; //min-height: 180px !important;
height:100%; height: 100%;
background-color: #eee; background-color: #eee;
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
@@ -695,14 +690,15 @@ onUnmounted(() => {
} }
} }
.el-tabs{ .el-tabs {
width: 100% !important; width: 100% !important;
border-radius: 4px; border-radius: 4px;
} }
.tabs-menu{ .tabs-menu {
height: 100%; height: 100%;
} }
.container_table { .container_table {
// width: 100%; // width: 100%;
flex: 1 !important; flex: 1 !important;
@@ -718,16 +714,19 @@ onUnmounted(() => {
} }
} }
} }
:deep(.el-collapse-item__header){
:deep(.el-collapse-item__header) {
color: var(--el-color-primary); color: var(--el-color-primary);
font-size: 14px; font-size: 14px;
font-family: "Microsoft YaHei", "微软雅黑", "Arial", sans-serif; font-family: "Microsoft YaHei", "微软雅黑", "Arial", sans-serif;
} }
:deep(.el-collapse-item__conten){
:deep(.el-collapse-item__conten) {
// background-color:#f6f6f6; // background-color:#f6f6f6;
padding-bottom: 0px !important; padding-bottom: 0px !important;
} }
:deep(.el-collapse-item__content ){
:deep(.el-collapse-item__content ) {
// background-color:#f6f6f6; // background-color:#f6f6f6;
padding-bottom: 0px !important; padding-bottom: 0px !important;
} }