2024-10-21 19:15:45 +08:00
|
|
|
<template>
|
|
|
|
|
<div class="default-main">
|
2024-12-27 08:47:47 +08:00
|
|
|
<TableHeader area showExport>
|
2024-10-21 19:15:45 +08:00
|
|
|
<template #select>
|
2024-10-24 08:51:29 +08:00
|
|
|
<!-- <el-form-item label="统计类型:">
|
2024-10-21 19:15:45 +08:00
|
|
|
<el-select v-model="tableStore.table.params.statisticalType" placeholder="请选择统计类型" value-key="id">
|
|
|
|
|
<el-option v-for="item in classificationData" :key="item.id" :label="item.name" :value="item">
|
|
|
|
|
</el-option>
|
|
|
|
|
</el-select>
|
2024-12-23 09:29:59 +08:00
|
|
|
|
2024-10-24 08:51:29 +08:00
|
|
|
</el-form-item> -->
|
2024-10-21 19:15:45 +08:00
|
|
|
<el-form-item label="电压等级:">
|
2025-04-16 09:43:27 +08:00
|
|
|
<el-select
|
|
|
|
|
v-model="tableStore.table.params.scale"
|
|
|
|
|
filterable
|
|
|
|
|
multiple
|
|
|
|
|
collapse-tags
|
|
|
|
|
clearable
|
|
|
|
|
placeholder="请选择电压等级"
|
|
|
|
|
value-key="id"
|
|
|
|
|
>
|
|
|
|
|
<el-option
|
|
|
|
|
v-for="item in voltageleveloption"
|
|
|
|
|
:key="item.id"
|
|
|
|
|
:label="item.name"
|
|
|
|
|
:value="item"
|
|
|
|
|
></el-option>
|
2024-10-21 19:15:45 +08:00
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="终端厂家:">
|
2025-04-16 09:43:27 +08:00
|
|
|
<el-select
|
|
|
|
|
v-model="tableStore.table.params.manufacturer"
|
|
|
|
|
filterable
|
|
|
|
|
multiple
|
|
|
|
|
collapse-tags
|
|
|
|
|
clearable
|
|
|
|
|
placeholder="请选择终端厂家"
|
|
|
|
|
value-key="id"
|
|
|
|
|
>
|
|
|
|
|
<el-option
|
|
|
|
|
v-for="item in terminaloption"
|
|
|
|
|
:key="item.id"
|
|
|
|
|
:label="item.name"
|
|
|
|
|
:value="item"
|
|
|
|
|
></el-option>
|
2024-10-21 19:15:45 +08:00
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="干扰源类型:">
|
2025-04-16 09:43:27 +08:00
|
|
|
<el-select
|
|
|
|
|
v-model="tableStore.table.params.loadType"
|
|
|
|
|
filterable
|
|
|
|
|
multiple
|
|
|
|
|
collapse-tags
|
|
|
|
|
clearable
|
|
|
|
|
placeholder="请选择干扰源类型"
|
|
|
|
|
value-key="id"
|
|
|
|
|
>
|
|
|
|
|
<el-option
|
|
|
|
|
v-for="item in interfereoption"
|
|
|
|
|
:key="item.id"
|
|
|
|
|
:label="item.name"
|
|
|
|
|
:value="item"
|
|
|
|
|
></el-option>
|
2024-10-21 19:15:45 +08:00
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
|
|
|
|
<el-form-item label="通讯状态:">
|
2025-04-16 09:43:27 +08:00
|
|
|
<el-select
|
|
|
|
|
v-model="tableStore.table.params.comFlag"
|
|
|
|
|
filterable
|
|
|
|
|
multiple
|
|
|
|
|
collapse-tags
|
|
|
|
|
clearable
|
|
|
|
|
placeholder="请选择通讯状态"
|
|
|
|
|
>
|
|
|
|
|
<el-option
|
|
|
|
|
v-for="item in communicationstatus"
|
|
|
|
|
:key="item.value"
|
|
|
|
|
:label="item.label"
|
|
|
|
|
:value="item.value"
|
|
|
|
|
></el-option>
|
2024-10-21 19:15:45 +08:00
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="终端状态:">
|
2025-04-16 09:43:27 +08:00
|
|
|
<el-select
|
|
|
|
|
v-model="tableStore.table.params.runFlag"
|
|
|
|
|
filterable
|
|
|
|
|
multiple
|
|
|
|
|
collapse-tags
|
|
|
|
|
clearable
|
|
|
|
|
placeholder="请选择终端状态"
|
|
|
|
|
>
|
|
|
|
|
<el-option
|
|
|
|
|
v-for="item in terminalstatus"
|
|
|
|
|
:key="item.value"
|
|
|
|
|
:label="item.label"
|
|
|
|
|
:value="item.value"
|
|
|
|
|
></el-option>
|
2024-10-21 19:15:45 +08:00
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="评价筛选">
|
|
|
|
|
<el-input v-model="tableStore.table.params.evaluate" clearable placeholder="输入关键字筛选" />
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</template>
|
|
|
|
|
</TableHeader>
|
|
|
|
|
<Table ref="tableRef" />
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
<script setup lang="ts">
|
|
|
|
|
import { ref, onMounted, provide } from 'vue'
|
|
|
|
|
import TableStore from '@/utils/tableStore'
|
|
|
|
|
import Table from '@/components/table/index.vue'
|
|
|
|
|
import { useDictData } from '@/stores/dictData'
|
|
|
|
|
import TableHeader from '@/components/table/header/index.vue'
|
|
|
|
|
const dictData = useDictData()
|
|
|
|
|
defineOptions({
|
|
|
|
|
name: 'harmonic-boot/run/terminalmessage'
|
|
|
|
|
})
|
|
|
|
|
const view = ref(true)
|
2025-04-16 09:43:27 +08:00
|
|
|
const classificationData = dictData.getBasicData('Statistical_Type', ['Report_Type', 'Voltage_Level', 'Load_Type'])
|
2024-10-21 19:15:45 +08:00
|
|
|
const voltageleveloption = dictData.getBasicData('Dev_Voltage_Stand')
|
|
|
|
|
const terminaloption = dictData.getBasicData('Dev_Manufacturers')
|
|
|
|
|
const interfereoption = dictData.getBasicData('Interference_Source')
|
|
|
|
|
|
|
|
|
|
const communicationstatus = [
|
2025-04-16 09:43:27 +08:00
|
|
|
{ value: 0, label: '中断' },
|
|
|
|
|
{ value: 1, label: '正常' }
|
2024-10-21 19:15:45 +08:00
|
|
|
]
|
|
|
|
|
const terminalstatus = [
|
2025-04-16 09:43:27 +08:00
|
|
|
{ value: 0, label: '投运' },
|
|
|
|
|
{ value: 1, label: '热备用' },
|
|
|
|
|
{ value: 2, label: '停运' }
|
2024-10-21 19:15:45 +08:00
|
|
|
]
|
|
|
|
|
const tableStore = new TableStore({
|
|
|
|
|
url: '/device-boot/runManage/getRuntimeData',
|
|
|
|
|
method: 'POST',
|
|
|
|
|
isWebPaging: true,
|
|
|
|
|
column: [
|
|
|
|
|
{
|
|
|
|
|
field: 'index',
|
|
|
|
|
title: '序号',
|
2024-12-09 09:22:43 +08:00
|
|
|
width: '80',
|
2024-10-21 19:15:45 +08:00
|
|
|
formatter: (row: any) => {
|
|
|
|
|
return (tableStore.table.params.pageNum - 1) * tableStore.table.params.pageSize + row.rowIndex + 1
|
|
|
|
|
}
|
|
|
|
|
},
|
2025-04-16 09:43:27 +08:00
|
|
|
{ field: 'areaName', title: '区域', minWidth: 100 },
|
|
|
|
|
{ field: 'gdName', title: '地级区', minWidth: 100 },
|
2024-10-21 19:15:45 +08:00
|
|
|
{
|
|
|
|
|
field: 'bdName',
|
|
|
|
|
title: '供电公司',
|
2025-04-16 09:43:27 +08:00
|
|
|
minWidth: 100
|
2024-10-21 19:15:45 +08:00
|
|
|
},
|
2025-04-16 09:43:27 +08:00
|
|
|
{ field: 'manufacturer', title: '厂家', minWidth: 100 },
|
2024-10-21 19:15:45 +08:00
|
|
|
|
|
|
|
|
{ field: 'devName', title: '终端名称', minWidth: 80 },
|
2025-04-16 09:43:27 +08:00
|
|
|
{ field: 'ip', title: '网络参数', minWidth: 100 },
|
2024-10-21 19:15:45 +08:00
|
|
|
{ field: 'loginTime', title: '投运时间', minWidth: 100 },
|
|
|
|
|
{ field: 'devType', title: '终端型号', minWidth: 100 },
|
|
|
|
|
{ field: 'port', title: '端口', minWidth: 100 },
|
|
|
|
|
{ field: 'updateTime', title: '最新数据', minWidth: 100 },
|
|
|
|
|
{
|
|
|
|
|
field: 'runFlag',
|
|
|
|
|
title: '终端状态',
|
2025-04-16 09:43:27 +08:00
|
|
|
// effect: 'dark',
|
|
|
|
|
render: 'tag',
|
|
|
|
|
minWidth: 100,
|
2024-10-21 19:15:45 +08:00
|
|
|
custom: {
|
2025-04-16 09:43:27 +08:00
|
|
|
投运: 'success',
|
|
|
|
|
热备用: 'warning',
|
|
|
|
|
停运: 'danger'
|
|
|
|
|
}
|
2024-10-21 19:15:45 +08:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
field: 'comFlag',
|
|
|
|
|
title: '通讯状态',
|
|
|
|
|
render: 'tag',
|
2025-04-16 09:43:27 +08:00
|
|
|
// effect: 'dark',
|
|
|
|
|
minWidth: 100,
|
2024-10-21 19:15:45 +08:00
|
|
|
custom: {
|
2025-04-16 09:43:27 +08:00
|
|
|
正常: 'success',
|
|
|
|
|
中断: 'danger'
|
|
|
|
|
}
|
2024-10-21 19:15:45 +08:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
field: 'onlineEvaluate',
|
|
|
|
|
title: '在线率评价',
|
|
|
|
|
render: 'tag',
|
2025-04-16 09:43:27 +08:00
|
|
|
// effect: 'dark',
|
|
|
|
|
minWidth: 100,
|
2024-10-21 19:15:45 +08:00
|
|
|
custom: {
|
|
|
|
|
'/': 'info',
|
2025-04-16 09:43:27 +08:00
|
|
|
优: 'success',
|
|
|
|
|
良: 'warning',
|
|
|
|
|
差: 'danger'
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-10-21 19:15:45 +08:00
|
|
|
],
|
|
|
|
|
|
|
|
|
|
loadCallback: () => {
|
2025-04-16 09:43:27 +08:00
|
|
|
tableStore.table.webPagingData.map((item1: any) => {
|
|
|
|
|
item1.map((item: any) => {
|
|
|
|
|
item.onlineEvaluate == 3.14159
|
|
|
|
|
? (item.onlineEvaluate = '/')
|
|
|
|
|
: item.onlineEvaluate <= 0.6
|
|
|
|
|
? (item.onlineEvaluate = '差')
|
|
|
|
|
: item.onlineEvaluate <= 0.9
|
|
|
|
|
? (item.onlineEvaluate = '良')
|
|
|
|
|
: item.onlineEvaluate <= 1
|
|
|
|
|
? (item.onlineEvaluate = '优')
|
|
|
|
|
: '/'
|
|
|
|
|
})
|
2024-10-21 19:15:45 +08:00
|
|
|
})
|
2025-04-16 09:43:27 +08:00
|
|
|
|
|
|
|
|
|
2024-10-21 19:15:45 +08:00
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
tableStore.table.params.statisticalType = classificationData[0]
|
2025-04-16 09:43:27 +08:00
|
|
|
tableStore.table.params.serverName = 'harmonic-boot'
|
2024-10-21 19:15:45 +08:00
|
|
|
tableStore.table.params.comFlag = []
|
|
|
|
|
tableStore.table.params.runFlag = []
|
|
|
|
|
tableStore.table.params.evaluate = ''
|
|
|
|
|
tableStore.table.params.powerFlag = 2
|
|
|
|
|
tableStore.table.params.monitorFlag = 2
|
|
|
|
|
tableStore.table.params.scale = []
|
|
|
|
|
tableStore.table.params.manufacturer = []
|
|
|
|
|
tableStore.table.params.loadType = []
|
|
|
|
|
const wp = ref({})
|
|
|
|
|
|
|
|
|
|
provide('tableStore', tableStore)
|
|
|
|
|
onMounted(() => {
|
|
|
|
|
tableStore.index()
|
|
|
|
|
})
|
|
|
|
|
</script>
|