2024-11-19 19:34:00 +08:00
|
|
|
|
<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="检测脚本">
|
2024-12-25 13:22:54 +08:00
|
|
|
|
<el-input v-model='formContent.scriptName' :disabled="true"/>
|
2024-12-18 18:53:55 +08:00
|
|
|
|
</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='通道号'>
|
2024-12-31 19:03:52 +08:00
|
|
|
|
<el-select v-model="formContent.chnNum">
|
2024-12-28 16:50:32 +08:00
|
|
|
|
<el-option v-for="item in chnList" :key="item.value" :label="item.label"
|
2024-12-18 18:53:55 +08:00
|
|
|
|
: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>
|
2024-12-31 19:03:52 +08:00
|
|
|
|
<el-radio-group v-model="switchItem" @change="handleSwitchChange">
|
2024-12-25 13:22:54 +08:00
|
|
|
|
<el-radio-button label="不符合测试项" :value="0"/>
|
2024-12-20 10:19:58 +08:00
|
|
|
|
<el-radio-button label="全部测试项" :value="1"/>
|
2024-12-18 18:53:55 +08:00
|
|
|
|
</el-radio-group>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="content-tree">
|
2025-01-02 18:00:58 +08:00
|
|
|
|
<el-tree v-if="switchItem === 0" :default-expanded-keys="defaultExpandedKeys" node-key="scriptType"
|
2024-12-31 19:54:27 +08:00
|
|
|
|
:data="treeDataUnqualified" :props="defaultProps" @node-click="handleNodeClick"
|
|
|
|
|
|
class="custom-tree">
|
|
|
|
|
|
<template #default="{ node, data }">
|
|
|
|
|
|
<span class="custom-tree-node">{{ data.scriptName }}</span>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</el-tree>
|
2025-01-02 18:00:58 +08:00
|
|
|
|
<el-tree v-if="switchItem === 1" :default-expanded-keys="defaultExpandedKeys" node-key="scriptType"
|
2024-12-31 19:54:27 +08:00
|
|
|
|
:data="treeDataAll" :props="defaultProps" @node-click="handleNodeClick" class="custom-tree">
|
|
|
|
|
|
<template #default="{ node, data }">
|
|
|
|
|
|
<span class="custom-tree-node">{{ data.scriptName }}</span>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</el-tree>
|
2024-12-18 18:53:55 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div class="content-right">
|
|
|
|
|
|
<div class="content-right-title">
|
|
|
|
|
|
<el-divider>当前检测项目</el-divider>
|
|
|
|
|
|
<span>{{ currentScriptDsc }}</span>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="content-right-Tabs">
|
2024-12-25 18:04:16 +08:00
|
|
|
|
<el-tabs type="border-card" v-model="activeTab">
|
2024-12-18 18:53:55 +08:00
|
|
|
|
<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>
|
2024-11-19 19:34:00 +08:00
|
|
|
|
</div>
|
2024-12-18 18:53:55 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-dialog>
|
2024-11-19 19:34:00 +08:00
|
|
|
|
|
|
|
|
|
|
</template>
|
|
|
|
|
|
<script setup lang='ts'>
|
2024-12-18 18:53:55 +08:00
|
|
|
|
import {dialogBig} from '@/utils/elementBind'
|
|
|
|
|
|
import {reactive, ref} from 'vue'
|
2024-11-19 19:34:00 +08:00
|
|
|
|
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-30 14:41:34 +08:00
|
|
|
|
import {useDictStore} from "@/stores/modules/dict";
|
2024-12-30 20:55:11 +08:00
|
|
|
|
import {useCheckStore} from "@/stores/modules/check";
|
2025-01-02 18:00:58 +08:00
|
|
|
|
import {getFormData, getTreeData, getTableData} from "@/api/check/test";
|
2024-12-18 18:53:55 +08:00
|
|
|
|
|
2024-12-20 10:19:58 +08:00
|
|
|
|
const {appendToBody} = withDefaults(defineProps<{
|
|
|
|
|
|
appendToBody: boolean
|
2025-01-02 18:00:58 +08:00
|
|
|
|
}>(), {appendToBody: true})
|
2024-12-18 20:26:18 +08:00
|
|
|
|
|
2024-12-25 18:04:16 +08:00
|
|
|
|
const defaultProps = {
|
|
|
|
|
|
label: "scriptName",
|
|
|
|
|
|
children: "children",
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2024-12-30 14:41:34 +08:00
|
|
|
|
const dictStore = useDictStore()
|
2024-12-30 20:55:11 +08:00
|
|
|
|
const checkStore = useCheckStore()
|
2024-12-30 14:41:34 +08:00
|
|
|
|
|
2024-12-28 16:50:32 +08:00
|
|
|
|
const visible = ref(false)
|
|
|
|
|
|
|
2024-12-25 18:04:16 +08:00
|
|
|
|
// 表单数据
|
2024-12-23 13:23:28 +08:00
|
|
|
|
const formContent = reactive<CheckData.DataCheck>({
|
2024-12-25 13:22:54 +08:00
|
|
|
|
scriptName: '',
|
|
|
|
|
|
errorSysName: '',
|
|
|
|
|
|
dataRule: '',
|
|
|
|
|
|
deviceName: '',
|
2024-12-31 19:03:52 +08:00
|
|
|
|
chnNum: '',
|
2024-12-18 18:53:55 +08:00
|
|
|
|
})
|
2024-12-28 16:50:32 +08:00
|
|
|
|
let deviceId: string = ''
|
2024-12-31 14:27:36 +08:00
|
|
|
|
let scriptType: string | null = null
|
2024-12-28 16:50:32 +08:00
|
|
|
|
|
2024-12-25 18:04:16 +08:00
|
|
|
|
// 通道下拉列表
|
2024-12-28 16:50:32 +08:00
|
|
|
|
let chnList: any[] = []
|
2024-12-25 18:04:16 +08:00
|
|
|
|
|
|
|
|
|
|
// 不符合测试项、全部测试项切换
|
2024-12-31 19:03:52 +08:00
|
|
|
|
const switchItem = ref<number>(0)
|
|
|
|
|
|
// 左侧树数据
|
|
|
|
|
|
let treeDataUnqualified: CheckData.ScriptItem[] = []
|
2024-12-25 18:04:16 +08:00
|
|
|
|
let treeDataAll: CheckData.ScriptItem[] = []
|
2024-12-31 19:03:52 +08:00
|
|
|
|
|
2024-12-25 13:22:54 +08:00
|
|
|
|
// 左侧树被选中的叶子节点id
|
2025-01-02 18:00:58 +08:00
|
|
|
|
const checkedScriptType = ref<string>('')
|
2024-12-18 18:53:55 +08:00
|
|
|
|
|
2024-12-28 16:50:32 +08:00
|
|
|
|
const currentScriptDsc = ref('');
|
2024-12-25 18:04:16 +08:00
|
|
|
|
// 右侧Tab选中项
|
|
|
|
|
|
const activeTab = ref<string>('resultTab')
|
2024-12-25 13:22:54 +08:00
|
|
|
|
// 检测结果表格数据
|
2024-12-31 19:03:52 +08:00
|
|
|
|
let checkResultTableData: CheckData.CheckResult = []
|
2024-12-25 13:22:54 +08:00
|
|
|
|
// 原始数据表格数据
|
2024-12-31 19:03:52 +08:00
|
|
|
|
let rawTableData: CheckData.RawDataItem[] = []
|
2024-12-18 15:56:59 +08:00
|
|
|
|
|
2024-12-25 18:04:16 +08:00
|
|
|
|
const resultTableRef = ref()
|
|
|
|
|
|
const rawDataTableRef = ref()
|
2024-12-25 13:22:54 +08:00
|
|
|
|
|
2024-12-25 18:04:16 +08:00
|
|
|
|
// 左侧树默认展开节点id
|
2024-12-28 16:50:32 +08:00
|
|
|
|
let defaultExpandedKeys: string[] = []
|
2024-12-25 13:22:54 +08:00
|
|
|
|
|
|
|
|
|
|
// 点击左侧树节点触发事件
|
2024-12-31 19:03:52 +08:00
|
|
|
|
const handleNodeClick = async (data: any) => {
|
2024-12-25 13:22:54 +08:00
|
|
|
|
if (!data.children) {
|
2025-01-02 18:00:58 +08:00
|
|
|
|
checkedScriptType.value = data.scriptType
|
2024-12-28 16:50:32 +08:00
|
|
|
|
currentScriptDsc.value = data.scriptName
|
2024-12-31 19:03:52 +08:00
|
|
|
|
|
2025-01-02 18:00:58 +08:00
|
|
|
|
if (checkedScriptType.value) {
|
2024-12-31 19:03:52 +08:00
|
|
|
|
await updateTableData()
|
|
|
|
|
|
}
|
2024-12-25 13:22:54 +08:00
|
|
|
|
}
|
|
|
|
|
|
};
|
2024-12-25 18:04:16 +08:00
|
|
|
|
|
2024-12-31 19:03:52 +08:00
|
|
|
|
watch(() => formContent.chnNum, async (newVal, oldVal) => {
|
|
|
|
|
|
console.log("通道号", newVal);
|
|
|
|
|
|
|
|
|
|
|
|
switchItem.value = 0
|
|
|
|
|
|
await handleSwitchChange(0)
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
const handleSwitchChange = async (data: any) => {
|
|
|
|
|
|
console.log("切换不合格测试项、全部测试项", data);
|
|
|
|
|
|
|
|
|
|
|
|
if (data === 0) {
|
2024-12-28 16:50:32 +08:00
|
|
|
|
// 发起请求,查询该测试项的检测结果
|
2025-01-02 18:00:58 +08:00
|
|
|
|
// const result = await getTreeData({scriptId:checkStore.scriptId,deviceId, chnNum: formContent.chnNum+'', scriptType,0})
|
2024-12-31 19:03:52 +08:00
|
|
|
|
treeDataUnqualified = [{
|
|
|
|
|
|
"scriptName": "频率准确度检测",
|
|
|
|
|
|
"children": [
|
|
|
|
|
|
{
|
|
|
|
|
|
"scriptName": "电压对频率测量的影响",
|
|
|
|
|
|
"children": [
|
|
|
|
|
|
{
|
2025-01-02 18:00:58 +08:00
|
|
|
|
"scriptName": "输入:频率 50.05Hz Ua =10%Un...",
|
|
|
|
|
|
"scriptType": '2346adafdf'
|
2024-12-31 19:03:52 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
2025-01-02 18:00:58 +08:00
|
|
|
|
"scriptName": "输入:频率 51.05Hz Ua =10%Un...",
|
|
|
|
|
|
"scriptType": '1246adaafdf'
|
2024-12-31 19:03:52 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
2025-01-02 18:00:58 +08:00
|
|
|
|
"scriptName": "输入:频率 52.05Hz Ua =10%Un...",
|
|
|
|
|
|
"scriptType": '2136ada3fdf'
|
2024-12-31 19:03:52 +08:00
|
|
|
|
}
|
|
|
|
|
|
]
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
"scriptName": "谐波对频率测量的影响",
|
|
|
|
|
|
"children": [
|
|
|
|
|
|
{
|
2025-01-02 18:00:58 +08:00
|
|
|
|
"scriptName": "输入:频率 50.05Hz Ua =100%Un...",
|
|
|
|
|
|
"scriptType": '234246adafdf'
|
2024-12-31 19:03:52 +08:00
|
|
|
|
}
|
|
|
|
|
|
]
|
|
|
|
|
|
}
|
|
|
|
|
|
]
|
|
|
|
|
|
}]
|
|
|
|
|
|
} else {
|
|
|
|
|
|
// 发起请求,查询该测试项的检测结果
|
2025-01-02 18:00:58 +08:00
|
|
|
|
// const result = await getTreeData({scriptId:checkStore.scriptId,deviceId, chnNum: formContent.chnNum+'', scriptType,1})
|
2024-12-31 19:54:27 +08:00
|
|
|
|
treeDataAll = [
|
|
|
|
|
|
{
|
|
|
|
|
|
"scriptName": "频率准确度检测",
|
|
|
|
|
|
"children": [
|
|
|
|
|
|
{
|
|
|
|
|
|
"scriptName": "额定工作条件下的检测",
|
|
|
|
|
|
"children": [
|
|
|
|
|
|
{
|
2025-01-02 18:00:58 +08:00
|
|
|
|
"scriptName": "输入:频率 42.5Hz...",
|
|
|
|
|
|
"scriptType": '2246ada2fdf'
|
2024-12-31 19:54:27 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
2025-01-02 18:00:58 +08:00
|
|
|
|
"scriptName": "输入:频率 50.0Hz...",
|
|
|
|
|
|
"scriptType": '2246a3dafdf'
|
2024-12-31 19:54:27 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
2025-01-02 18:00:58 +08:00
|
|
|
|
"scriptName": "输入:频率 50.05Hz....",
|
|
|
|
|
|
"scriptType": '22246adafdf'
|
2024-12-31 19:54:27 +08:00
|
|
|
|
}
|
|
|
|
|
|
]
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
"scriptName": "电压对频率测量的影响",
|
|
|
|
|
|
"children": [
|
|
|
|
|
|
{
|
2025-01-02 18:00:58 +08:00
|
|
|
|
"scriptName": "输入:频率 50.05Hz Ua =10%Un...",
|
|
|
|
|
|
"scriptType": '224a6adafdf'
|
2024-12-31 19:54:27 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
2025-01-02 18:00:58 +08:00
|
|
|
|
"scriptName": "输入:频率 51.05Hz Ua =10%Un...",
|
|
|
|
|
|
"scriptType": '2246aadafdf'
|
2024-12-31 19:54:27 +08:00
|
|
|
|
},
|
|
|
|
|
|
{
|
2025-01-02 18:00:58 +08:00
|
|
|
|
"scriptName": "输入:频率 52.05Hz Ua =10%Un...",
|
|
|
|
|
|
"scriptType": '2246adaffdf'
|
2024-12-31 19:54:27 +08:00
|
|
|
|
}
|
|
|
|
|
|
]
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
"scriptName": "谐波对频率测量的影响",
|
|
|
|
|
|
"children": [
|
|
|
|
|
|
{
|
2025-01-02 18:00:58 +08:00
|
|
|
|
"scriptName": "输入:频率 50.05Hz Ua =100%Un...",
|
|
|
|
|
|
"scriptType": '2246aadafdf'
|
2024-12-31 19:54:27 +08:00
|
|
|
|
}
|
|
|
|
|
|
]
|
|
|
|
|
|
}
|
|
|
|
|
|
]
|
2025-01-02 18:00:58 +08:00
|
|
|
|
}
|
2024-12-31 19:54:27 +08:00
|
|
|
|
]
|
2024-12-31 14:27:36 +08:00
|
|
|
|
|
2024-12-25 13:22:54 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2024-12-31 19:03:52 +08:00
|
|
|
|
defaultOperate()
|
|
|
|
|
|
await updateTableData()
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 默认操作
|
|
|
|
|
|
const defaultOperate = () => {
|
2024-12-28 16:50:32 +08:00
|
|
|
|
let node = null
|
2024-12-31 19:03:52 +08:00
|
|
|
|
if (switchItem.value === 0) {
|
|
|
|
|
|
node = getDefaultNode(treeDataUnqualified)
|
|
|
|
|
|
} else {
|
2024-12-28 16:50:32 +08:00
|
|
|
|
node = getDefaultNode(treeDataAll)
|
2024-12-25 18:04:16 +08:00
|
|
|
|
}
|
2024-12-28 16:50:32 +08:00
|
|
|
|
currentScriptDsc.value = node?.scriptName
|
2025-01-02 18:00:58 +08:00
|
|
|
|
checkedScriptType.value = node?.scriptType
|
|
|
|
|
|
defaultExpandedKeys = [node?.scriptType]
|
2024-12-31 19:03:52 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const updateTableData = async () => {
|
2025-01-02 18:00:58 +08:00
|
|
|
|
console.log("左侧树被选中的叶子节点scriptType", checkedScriptType.value);
|
2024-12-31 19:03:52 +08:00
|
|
|
|
// 发起请求,查询该测试项的检测结果
|
|
|
|
|
|
// const result = await getTableData({checkStore.scriptId,deviceId, formContent.chnNum, scriptType})
|
|
|
|
|
|
|
|
|
|
|
|
checkResultTableData = [{
|
|
|
|
|
|
chnNum: '1',
|
|
|
|
|
|
standardValue: 57.74,
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
A_errValue: 0.01,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
B_errValue: 0.01,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
C_errValue: 0.01,
|
|
|
|
|
|
maxErrVaule: 0.05774,
|
|
|
|
|
|
result: '合格',
|
|
|
|
|
|
}]
|
|
|
|
|
|
|
|
|
|
|
|
rawTableData = [
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:00",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:03",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:06",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:09",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:12",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:15",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:18",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:21",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:24",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:27",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:30",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:33",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:36",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:39",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:42",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:45",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:48",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:51",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:54",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
updateTime: "2024-10-10 09:30:57",
|
|
|
|
|
|
A: 57.73,
|
|
|
|
|
|
B: 57.73,
|
|
|
|
|
|
C: 57.73,
|
|
|
|
|
|
}
|
|
|
|
|
|
]
|
|
|
|
|
|
}
|
2024-11-19 19:34:00 +08:00
|
|
|
|
|
2025-01-02 18:00:58 +08:00
|
|
|
|
const open = async (_deviceId: string, chnNum: string, _scriptType: string | null) => {
|
|
|
|
|
|
// console.log(checkStore.scriptId, _deviceId, chnNum, _scriptType);
|
2024-12-28 16:50:32 +08:00
|
|
|
|
deviceId = _deviceId
|
2024-12-31 14:27:36 +08:00
|
|
|
|
scriptType = _scriptType
|
2024-12-31 19:03:52 +08:00
|
|
|
|
|
2024-12-28 16:50:32 +08:00
|
|
|
|
// 发起后端请求,查询详细信息 当chnNum为-1时,查询所有通道号
|
2025-01-02 18:00:58 +08:00
|
|
|
|
const {data: resFormContent} = await getFormData({planId: checkStore.planId, deviceId, chnNum, scriptType})
|
2024-12-18 15:56:59 +08:00
|
|
|
|
|
|
|
|
|
|
// 数据处理
|
2025-01-02 18:00:58 +08:00
|
|
|
|
// let resFormContent = {
|
|
|
|
|
|
// scriptName: 'Q/GDW 10650.4-2021 模拟式',
|
|
|
|
|
|
// errorSysName: 'Q/GDW 10650.2-2021',
|
|
|
|
|
|
// dataRule: '505f063f9f91ab108d895a9fe96b5dce',
|
|
|
|
|
|
// deviceName: '被检设备1',
|
|
|
|
|
|
// chnList: [
|
|
|
|
|
|
// {value: '1', label: '1'},
|
|
|
|
|
|
// {value: '2', label: '0'},
|
|
|
|
|
|
// {value: '3', label: '1'},
|
|
|
|
|
|
// {value: '4', label: '0'}],
|
|
|
|
|
|
// }
|
2024-12-30 14:41:34 +08:00
|
|
|
|
chnList = resFormContent.chnList.map(item => ({
|
|
|
|
|
|
value: item.value,
|
|
|
|
|
|
label: item.label == '1' ? `${item.value}` : `${item.value}(不符合)`
|
|
|
|
|
|
}))
|
|
|
|
|
|
|
2024-12-31 14:27:36 +08:00
|
|
|
|
let dataRuleName = dictStore.getDictData('Data_Rule').find(item => item.id == resFormContent.dataRule)?.name
|
2024-12-30 14:41:34 +08:00
|
|
|
|
|
2025-01-02 18:00:58 +08:00
|
|
|
|
Object.assign(formContent, {
|
|
|
|
|
|
...resFormContent,
|
|
|
|
|
|
dataRule: dataRuleName,
|
|
|
|
|
|
chnNum: chnList[0].value
|
|
|
|
|
|
})
|
2024-12-31 19:03:52 +08:00
|
|
|
|
|
2024-11-19 19:34:00 +08:00
|
|
|
|
|
2024-12-18 15:56:59 +08:00
|
|
|
|
visible.value = true;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2024-12-28 16:50:32 +08:00
|
|
|
|
const close = () => {
|
|
|
|
|
|
//数据清空
|
|
|
|
|
|
Object.assign(formContent, {
|
|
|
|
|
|
scriptName: '',
|
|
|
|
|
|
errorSysName: '',
|
|
|
|
|
|
dataRule: '',
|
|
|
|
|
|
deviceName: '',
|
2024-12-31 19:03:52 +08:00
|
|
|
|
chnNum: '',
|
2024-12-28 16:50:32 +08:00
|
|
|
|
})
|
2024-12-31 19:03:52 +08:00
|
|
|
|
treeDataUnqualified = []
|
2024-12-28 16:50:32 +08:00
|
|
|
|
treeDataAll = []
|
2025-01-02 18:00:58 +08:00
|
|
|
|
checkedScriptType.value = ''
|
2024-12-28 16:50:32 +08:00
|
|
|
|
activeTab.value = 'rawDataTab'
|
|
|
|
|
|
currentScriptDsc.value = ''
|
2024-12-31 19:03:52 +08:00
|
|
|
|
switchItem.value = 0
|
2024-12-28 16:50:32 +08:00
|
|
|
|
|
|
|
|
|
|
visible.value = false;
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const findFirstLeafNode = (node: any): any => {
|
2024-12-25 18:04:16 +08:00
|
|
|
|
if (!node.children || node.children.length === 0) {
|
2024-12-28 16:50:32 +08:00
|
|
|
|
return node;
|
2024-12-25 18:04:16 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return findFirstLeafNode(node.children[0]);
|
|
|
|
|
|
}
|
2024-12-28 16:50:32 +08:00
|
|
|
|
const getDefaultNode = (data: any[]) => {
|
2024-12-25 18:04:16 +08:00
|
|
|
|
if (!data || data.length === 0) {
|
|
|
|
|
|
return null;
|
2024-12-25 13:22:54 +08:00
|
|
|
|
}
|
2024-12-25 18:04:16 +08:00
|
|
|
|
|
|
|
|
|
|
const firstElement = data[0];
|
|
|
|
|
|
|
|
|
|
|
|
return findFirstLeafNode(firstElement);
|
2024-12-25 13:22:54 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2024-12-18 15:56:59 +08:00
|
|
|
|
defineExpose({
|
|
|
|
|
|
open
|
|
|
|
|
|
})
|
2024-11-19 19:34:00 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
|
2024-12-18 18:53:55 +08:00
|
|
|
|
<style lang="scss" scoped>
|
2024-11-19 19:34:00 +08:00
|
|
|
|
|
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 {
|
2024-11-19 19:34:00 +08:00
|
|
|
|
display: flex;
|
2024-12-18 20:26:18 +08:00
|
|
|
|
flex-direction: column;
|
2024-11-19 19:34:00 +08:00
|
|
|
|
|
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-31 19:54:27 +08:00
|
|
|
|
overflow-y: auto;
|
2024-12-24 19:21:43 +08:00
|
|
|
|
|
2024-12-18 20:26:18 +08:00
|
|
|
|
.content-tree {
|
2024-12-31 19:54:27 +08:00
|
|
|
|
width: 100%;
|
2024-12-23 13:23:28 +08:00
|
|
|
|
height: 100%;
|
|
|
|
|
|
max-height: 100%;
|
2024-12-18 20:26:18 +08:00
|
|
|
|
margin-top: 10px;
|
2024-12-31 19:54:27 +08:00
|
|
|
|
|
|
|
|
|
|
.custom-tree-node {
|
|
|
|
|
|
overflow-x: hidden !important; // 溢出部分隐藏
|
|
|
|
|
|
white-space: nowrap !important; //禁止自动换行
|
|
|
|
|
|
text-overflow: ellipsis !important; // 使溢出部分以省略号显示
|
|
|
|
|
|
}
|
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-11-19 19:34:00 +08:00
|
|
|
|
}
|
2024-12-23 13:23:28 +08:00
|
|
|
|
|
2024-11-19 19:34:00 +08:00
|
|
|
|
</style>
|