Files
pqs-9100_client/frontend/src/views/home/components/dataCheckSingleChannelSingleTestPopup.vue

365 lines
8.0 KiB
Vue
Raw Normal View History

<template>
2024-12-18 20:26:18 +08:00
<el-dialog :append-to-body="appendToBody" class="dialog" title="数据查询" :model-value='visible' @close="close"
v-bind="dialogBig" :draggable="false" style="margin-left: 20%;">
2024-12-18 18:53:55 +08:00
<div class="data-check-dialog">
<div class="data-check-head">
<el-form :model='formContent' label-width="auto" class="form-three ">
<el-form-item label="检测脚本">
<el-input v-model='formContent.testScriptName' :disabled="true"/>
</el-form-item>
<el-form-item label="误差体系">
<el-input v-model='formContent.errorSysName' :disabled="true"/>
</el-form-item>
<el-form-item label="数据原则">
<el-input v-model='formContent.dataRule' :disabled="true"/>
</el-form-item>
<el-form-item label="设备名称">
<el-input v-model='formContent.deviceName' :disabled="true"/>
</el-form-item>
<el-form-item label='通道号'>
<el-select v-model="formContent.monitorIdx" @change="handleChnNumChange">
2024-12-18 18:53:55 +08:00
<el-option v-for="item in monitorIdxList" :key="item.value" :label="item.value"
:value="item.value"/>
</el-select>
</el-form-item>
</el-form>
</div>
<div class="data-check-body">
<div class="content-left-tree">
2024-12-18 20:26:18 +08:00
<div>
<el-radio-group v-model="checkItemSwitch" @change="handleCheckItemSwitch">
<el-radio-button label="不合格测试项" :value="0"/>
<el-radio-button label="全部测试项" :value="1"/>
2024-12-18 18:53:55 +08:00
</el-radio-group>
</div>
<div class="content-tree">
2024-12-23 13:23:28 +08:00
<el-tree :default-expanded-keys="['0', '0-2']" node-key="id" :data="treeData"
2024-12-18 18:53:55 +08:00
:props="defaultProps" @node-click="handleNodeClick"/>
</div>
</div>
<div class="content-right">
<div class="content-right-title">
<el-divider>当前检测项目</el-divider>
<span>{{ currentScriptDsc }}</span>
</div>
<div class="content-right-Tabs">
<el-tabs type="border-card" v-model="activeName">
<el-tab-pane label="检测结果" name="resultTab">
<DataCheckResultTable :tableData="checkResultTableData" ref="resultTableRef"/>
</el-tab-pane>
<el-tab-pane label="原始数据" name="rawDataTab">
<DataCheckRawDataTable :tableData="rawTableData" ref="rawDataTableRef"/>
</el-tab-pane>
</el-tabs>
</div>
</div>
2024-12-18 18:53:55 +08:00
</div>
</div>
</el-dialog>
</template>
<script setup lang='ts'>
2024-12-18 18:53:55 +08:00
import {dialogBig} from '@/utils/elementBind'
import {reactive, ref} from 'vue'
import DataCheckResultTable from './dataCheckResultTable.vue'
import DataCheckRawDataTable from './dataCheckRawDataTable.vue'
2024-12-23 13:23:28 +08:00
import {CheckData} from "@/api/check/interface";
2024-12-18 18:53:55 +08:00
import {data as treeData} from "@/api/plan/autoTest.json";
const {appendToBody} = withDefaults(defineProps<{
appendToBody: boolean
}>(), {appendToBody: false})
2024-12-18 20:26:18 +08:00
2024-12-23 13:23:28 +08:00
const formContent = reactive<CheckData.DataCheck>({
2024-12-18 18:53:55 +08:00
testScriptName: 'Q/GDW 10650.4-2021 模拟式',
errorSysName: 'Q/GDW 10650.2-2021',
dataRule: '所有值',
deviceName: '被检设备1',
monitorIdx: '1',
})
const activeName = ref('resultTab')
const checkItemSwitch = ref(0)
2024-12-18 18:53:55 +08:00
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 defaultProps = {
children: "children",
label: "name",
pid: "pid",
};
2024-12-18 18:53:55 +08:00
const monitorIdxList = [
{
value: '1',
},
{
value: '2 (不合格)',
},
{
value: '3',
},
{
value: '4 (不合格)',
},
]
// 改变通道号下拉框触发事件
const handleChnNumChange = (data: any) => {
console.log(data);
}
// 切换不合格测试项、全部测试项 触发事件
const handleCheckItemSwitch = (data: any) => {
// 0 不合格测试项、1 全部测试项
if (data === 0) {
} else {
}
}
2024-12-18 18:53:55 +08:00
// 点击左侧树节点触发事件
2024-12-18 20:26:18 +08:00
const handleNodeClick = (data: any) => {
2024-12-18 18:53:55 +08:00
console.log(data);
};
2024-12-18 15:56:59 +08:00
2024-12-23 13:23:28 +08:00
const checkResultTableData = reactive<CheckData.CheckResult[]>([
{
2024-12-18 15:56:59 +08:00
chnNum: '1',
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: '合格',
}
])
2024-12-23 13:23:28 +08:00
const rawTableData = reactive<CheckData.RawDataItem[]>([
{
updateTime: "2024-10-10 09:30:00",
L1: 57.73,
L2: 57.73,
L3: 57.73,
},
{
updateTime: "2024-10-10 09:30:03",
2024-12-18 15:56:59 +08:00
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,
},
2024-12-18 15:56:59 +08:00
{
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,
2024-12-18 15:56:59 +08:00
}
])
2024-12-18 18:53:55 +08:00
const resultTableRef = ref()
2024-12-18 15:56:59 +08:00
const rawDataTableRef = ref()
const visible = ref(false)
const close = () => {
//数据清空
activeName.value = 'rawDataTab'
visible.value = false;
};
2024-12-23 13:23:28 +08:00
const open = (checkItemId: string, deviceId: string, chnNum?: number) => {
console.log(checkItemId, deviceId, chnNum);
2024-12-18 15:56:59 +08:00
// 发起后端请求,查询详细信息
2024-12-23 13:23:28 +08:00
//const result = await getCheckItemDetail({checkItemId,deviceId, chnNum})
2024-12-18 15:56:59 +08:00
// 数据处理
// checkResultTableData=[];
2024-12-18 18:53:55 +08:00
//formContent.value = ...
2024-12-18 15:56:59 +08:00
visible.value = true;
}
defineExpose({
open
})
</script>
2024-12-18 18:53:55 +08:00
<style lang="scss" scoped>
2024-12-18 20:26:18 +08:00
.dialog {
2024-12-18 18:53:55 +08:00
display: flex;
flex-direction: column;
2024-12-18 20:26:18 +08:00
overflow-y: hidden;
overflow-x: hidden;
2024-12-23 13:23:28 +08:00
2024-12-18 18:53:55 +08:00
2024-12-18 20:26:18 +08:00
.data-check-dialog {
display: flex;
2024-12-18 20:26:18 +08:00
flex-direction: column;
2024-12-18 20:26:18 +08:00
.data-check-head {
display: flex;
flex-direction: row;
width: 100%;
2024-12-18 18:53:55 +08:00
}
2024-12-18 20:26:18 +08:00
.data-check-body {
2024-12-23 13:23:28 +08:00
width: 100%;
2024-12-18 20:26:18 +08:00
display: flex;
flex-direction: row;
.content-left-tree {
2024-12-23 13:23:28 +08:00
width: 25%;
2024-12-18 20:26:18 +08:00
display: flex;
flex-direction: column;
align-items: center;
2024-12-23 13:23:28 +08:00
max-height: 473px;
2024-12-18 20:26:18 +08:00
padding: 10px 0;
border: 1px solid #ccc;
2024-12-23 13:23:28 +08:00
overflow: auto;
2024-12-18 20:26:18 +08:00
.content-tree {
2024-12-23 13:23:28 +08:00
min-width: 100%;
height: 100%;
max-height: 100%;
2024-12-18 20:26:18 +08:00
margin-top: 10px;
2024-12-18 18:53:55 +08:00
}
}
2024-12-18 20:26:18 +08:00
.content-right {
2024-12-23 13:23:28 +08:00
width: 75%;
2024-12-18 20:26:18 +08:00
margin-left: 10px;
flex: 1;
.content-right-title {
/*margin-bottom: 10px;*/
div {
font-size: 16px;
font-weight: 600;
}
}
2024-12-18 18:53:55 +08:00
2024-12-18 20:26:18 +08:00
.content-right-Tabs {
box-sizing: border-box;
margin-top: 20px;
margin-bottom: 10px;
max-height: 400px;
}
}
2024-12-18 18:53:55 +08:00
}
}
}
2024-12-23 13:23:28 +08:00
</style>