2025-08-26 09:45:01 +08:00
|
|
|
|
<template>
|
|
|
|
|
|
<el-dialog v-model="Views" draggable title="评估策略配置" width="1000" :before-close="handleClose">
|
|
|
|
|
|
<div style="display: flex; justify-content: end">
|
|
|
|
|
|
<el-button icon="el-icon-Refresh" type="primary" @click="restores">一键还原</el-button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<el-divider content-position="left">光伏电站评估策略配置</el-divider>
|
|
|
|
|
|
<vxe-table v-bind="defaultAttribute" :loading="loading" :data="photovoltaicData" :span-method="mergeRowMethod">
|
|
|
|
|
|
<vxe-colgroup field="group0" title="等级">
|
|
|
|
|
|
<vxe-column field="name" width="180" title="结果"></vxe-column>
|
|
|
|
|
|
</vxe-colgroup>
|
|
|
|
|
|
<vxe-column field="comparisonOperators1" title="安全(个)">
|
|
|
|
|
|
<template #default="row">
|
|
|
|
|
|
<div class="cellBox" @click="cells(row, row.row.comparisonOperators1, row.row.count1, 0)">
|
|
|
|
|
|
{{ symbolJudgment(row.row.comparisonOperators1)
|
|
|
|
|
|
}}{{ row.row.comparisonOperators1 == '/' ? '' : row.row.count1 }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</vxe-column>
|
|
|
|
|
|
<vxe-column field="comparisonOperators2" title="III级预警(个)">
|
|
|
|
|
|
<template #default="row">
|
|
|
|
|
|
<div class="cellBox" @click="cells(row, row.row.comparisonOperators2, row.row.count2, 0)">
|
|
|
|
|
|
{{ symbolJudgment(row.row.comparisonOperators2)
|
|
|
|
|
|
}}{{ row.row.comparisonOperators2 == '/' ? '' : row.row.count2 }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</vxe-column>
|
|
|
|
|
|
<vxe-column field="comparisonOperators3" title="II级预警(个)">
|
|
|
|
|
|
<template #default="row">
|
|
|
|
|
|
<div class="cellBox" @click="cells(row, row.row.comparisonOperators3, row.row.count3, 0)">
|
|
|
|
|
|
{{ symbolJudgment(row.row.comparisonOperators3)
|
|
|
|
|
|
}}{{ row.row.comparisonOperators3 == '/' ? '' : row.row.count3 }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</vxe-column>
|
|
|
|
|
|
<vxe-column field="comparisonOperators4" title="I级预警(个)">
|
|
|
|
|
|
<template #default="row">
|
|
|
|
|
|
<div class="cellBox" @click="cells(row, row.row.comparisonOperators4, row.row.count4, 0)">
|
|
|
|
|
|
{{ symbolJudgment(row.row.comparisonOperators4)
|
|
|
|
|
|
}}{{ row.row.comparisonOperators4 == '/' ? '' : row.row.count4 }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</vxe-column>
|
|
|
|
|
|
</vxe-table>
|
|
|
|
|
|
<el-divider content-position="left">充电站、电加热负荷、电气化铁路评估策略配置</el-divider>
|
|
|
|
|
|
<vxe-table v-bind="defaultAttribute" ref="xTable" :loading="loading" :data="tableData">
|
|
|
|
|
|
<vxe-colgroup field="group0" title="等级">
|
|
|
|
|
|
<vxe-column field="name" width="180" title="结果"></vxe-column>
|
|
|
|
|
|
</vxe-colgroup>
|
|
|
|
|
|
|
|
|
|
|
|
<vxe-column field="comparisonOperators1" title="THD(%)">
|
|
|
|
|
|
<template #default="row">
|
|
|
|
|
|
<div class="cellBox" @click="cells(row, row.row.comparisonOperators1, row.row.count1, 1)">
|
|
|
|
|
|
{{ symbolJudgment(row.row.comparisonOperators1)
|
|
|
|
|
|
}}{{ row.row.comparisonOperators1 == '/' ? '' : row.row.count1 }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</vxe-column>
|
|
|
|
|
|
|
|
|
|
|
|
<vxe-column field="comparisonOperators2" title="2~25次谐波合格个数">
|
|
|
|
|
|
<template #default="row">
|
|
|
|
|
|
<div class="cellBox" @click="cells(row, row.row.comparisonOperators2, row.row.count2, 2)">
|
|
|
|
|
|
{{ symbolJudgment(row.row.comparisonOperators2)
|
|
|
|
|
|
}}{{ row.row.comparisonOperators2 == '/' ? '' : row.row.count2 }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</vxe-column>
|
|
|
|
|
|
<vxe-column field="comparisonOperators3" title="奇次谐波合格个数">
|
|
|
|
|
|
<template #default="row">
|
|
|
|
|
|
<div class="cellBox" @click="cells(row, row.row.comparisonOperators3, row.row.count3, 3)">
|
|
|
|
|
|
{{ symbolJudgment(row.row.comparisonOperators3)
|
|
|
|
|
|
}}{{ row.row.comparisonOperators3 == '/' ? '' : row.row.count3 }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</vxe-column>
|
|
|
|
|
|
<vxe-column field="comparisonOperators4" title="偶次谐波合格个数">
|
|
|
|
|
|
<template #default="row">
|
|
|
|
|
|
<div class="cellBox" @click="cells(row, row.row.comparisonOperators4, row.row.count4, 4)">
|
|
|
|
|
|
{{ symbolJudgment(row.row.comparisonOperators4)
|
|
|
|
|
|
}}{{ row.row.comparisonOperators4 == '/' ? '' : row.row.count4 }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</vxe-column>
|
|
|
|
|
|
</vxe-table>
|
|
|
|
|
|
<!-- 修改 -->
|
|
|
|
|
|
|
|
|
|
|
|
<el-dialog class="dialogBox" draggable v-model="dialogVisible" title="安全等级配置" width="500">
|
|
|
|
|
|
<el-form :model="form" label-width="auto">
|
|
|
|
|
|
<el-form-item label="运算符号:">
|
|
|
|
|
|
<el-radio-group v-model="form.comparisonOperators" @change="groupChang">
|
|
|
|
|
|
<el-radio v-for="item in sign" :label="item.name">{{ item.name }}</el-radio>
|
|
|
|
|
|
</el-radio-group>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="数量:">
|
|
|
|
|
|
<el-input-number
|
|
|
|
|
|
v-model="form.count"
|
|
|
|
|
|
:disabled="disabled"
|
|
|
|
|
|
:min="0"
|
|
|
|
|
|
:precision="0"
|
|
|
|
|
|
:max="10000000"
|
|
|
|
|
|
style="width: 200px"
|
|
|
|
|
|
/>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
</el-form>
|
|
|
|
|
|
<template #footer>
|
|
|
|
|
|
<div class="dialog-footer">
|
|
|
|
|
|
<el-button @click="dialogVisible = false">取消</el-button>
|
|
|
|
|
|
<el-button type="primary" @click="add">确定</el-button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</el-dialog>
|
|
|
|
|
|
</el-dialog>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
<script setup lang="ts">
|
|
|
|
|
|
import { ref, onMounted, provide, reactive } from 'vue'
|
|
|
|
|
|
import { defaultAttribute } from '@/components/table/defaultAttribute'
|
|
|
|
|
|
import { mainHeight } from '@/utils/layout'
|
|
|
|
|
|
import { queyDetail, addCarryc, restore, queyDetailDhl, adddhl } from '@/api/advance-boot/bearingCapacity'
|
|
|
|
|
|
import { ElMessage, ElMessageBox } from 'element-plus'
|
|
|
|
|
|
import { VxeTablePropTypes } from 'vxe-table'
|
|
|
|
|
|
defineOptions({
|
|
|
|
|
|
name: 'Advancedanalysis/eventcorrelation'
|
|
|
|
|
|
})
|
|
|
|
|
|
const emit = defineEmits(['View'])
|
|
|
|
|
|
|
|
|
|
|
|
const Views = ref(true)
|
|
|
|
|
|
|
|
|
|
|
|
const xTable = ref()
|
|
|
|
|
|
const loading = ref(false)
|
|
|
|
|
|
const photovoltaicData: any = ref([])
|
|
|
|
|
|
const sum = ref(0)
|
|
|
|
|
|
const tableData: any = ref([])
|
|
|
|
|
|
const list: any = ref({})
|
|
|
|
|
|
const form: any = ref({
|
|
|
|
|
|
comparisonOperators: '',
|
|
|
|
|
|
count: ''
|
|
|
|
|
|
})
|
|
|
|
|
|
const sign = ref([
|
|
|
|
|
|
{
|
|
|
|
|
|
name: '>'
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
name: '<'
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
name: '>='
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
name: '<='
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
name: '=='
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
name: '/'
|
|
|
|
|
|
}
|
|
|
|
|
|
])
|
|
|
|
|
|
const dialogVisible = ref(false)
|
|
|
|
|
|
const disabled = ref(false)
|
|
|
|
|
|
const info = () => {
|
|
|
|
|
|
// 光伏
|
|
|
|
|
|
queyDetail().then(res => {
|
|
|
|
|
|
photovoltaicData.value = []
|
|
|
|
|
|
let title = ['安全', 'III级预警', 'II级预警', 'I级预警']
|
|
|
|
|
|
let p = 0
|
|
|
|
|
|
res.data.forEach((item: any, i: any) => {
|
|
|
|
|
|
item.capacityStrategysingleVOList.forEach((item1: any, i1: any) => {
|
|
|
|
|
|
photovoltaicData.value.push({
|
|
|
|
|
|
name: title[i],
|
|
|
|
|
|
id: item1.id,
|
|
|
|
|
|
result: item.result
|
|
|
|
|
|
})
|
|
|
|
|
|
p++
|
|
|
|
|
|
item1.carryCapacityStrategyIndexVOList.forEach((item2: any) => {
|
|
|
|
|
|
photovoltaicData.value[p - 1]['comparisonOperators' + item2.indexResult] = item2.comparisonOperators
|
|
|
|
|
|
photovoltaicData.value[p - 1]['count' + item2.indexResult] = item2.count
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
2026-01-06 08:35:36 +08:00
|
|
|
|
// console.log('🚀 ~ queyDetail ~ photovoltaicData.value:', photovoltaicData.value)
|
2025-08-26 09:45:01 +08:00
|
|
|
|
})
|
|
|
|
|
|
// 电弧炉
|
|
|
|
|
|
queyDetailDhl().then(res => {
|
|
|
|
|
|
tableData.value = res.data
|
|
|
|
|
|
tableData.value[0].name = '电弧炉'
|
|
|
|
|
|
tableData.value[1].name = '充电桩'
|
|
|
|
|
|
tableData.value[2].name = '电气化铁路'
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// <span @click="cells(row,comparisonOperators2,count2)">
|
|
|
|
|
|
const cells = (row: any, comparisonOperators: any, count: any, num: number) => {
|
|
|
|
|
|
form.value = {
|
|
|
|
|
|
comparisonOperators: comparisonOperators,
|
|
|
|
|
|
count: count,
|
|
|
|
|
|
result: row.row.result,
|
|
|
|
|
|
id: row.row.id,
|
|
|
|
|
|
indexResult: row.columnIndex
|
|
|
|
|
|
}
|
|
|
|
|
|
sum.value = num
|
|
|
|
|
|
if (num != 0) {
|
|
|
|
|
|
list.value = JSON.parse(JSON.stringify(row.row))
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
groupChang(comparisonOperators)
|
|
|
|
|
|
dialogVisible.value = true
|
|
|
|
|
|
}
|
|
|
|
|
|
// 运算符变化
|
|
|
|
|
|
const groupChang = e => {
|
|
|
|
|
|
if (e == '/') {
|
|
|
|
|
|
form.value.count = 0
|
|
|
|
|
|
disabled.value = true
|
|
|
|
|
|
} else {
|
|
|
|
|
|
disabled.value = false
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
// 安全等级配置确认
|
|
|
|
|
|
const add = () => {
|
|
|
|
|
|
if (sum.value == 0) {
|
|
|
|
|
|
addCarryc(form.value).then(res => {
|
|
|
|
|
|
ElMessage.success('修改成功!')
|
|
|
|
|
|
dialogVisible.value = false
|
|
|
|
|
|
info()
|
|
|
|
|
|
})
|
|
|
|
|
|
} else {
|
|
|
|
|
|
// sum.value = num
|
|
|
|
|
|
// list.value = row
|
|
|
|
|
|
list.value['comparisonOperators' + sum.value] = form.value.comparisonOperators
|
|
|
|
|
|
list.value['count' + sum.value] = form.value.count
|
|
|
|
|
|
list.value.userFlag = 0
|
|
|
|
|
|
list.value.protoFlag = 0
|
|
|
|
|
|
adddhl(list.value).then(res => {
|
|
|
|
|
|
ElMessage.success('修改成功!')
|
|
|
|
|
|
dialogVisible.value = false
|
|
|
|
|
|
info()
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
// 还原
|
|
|
|
|
|
const restores = () => {
|
|
|
|
|
|
restore().then(res => {
|
|
|
|
|
|
ElMessage.success('还原成功!')
|
|
|
|
|
|
info()
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
// 通用行合并函数(将相同多列数据合并为一行)
|
|
|
|
|
|
const mergeRowMethod = ({ row, _rowIndex, column, visibleData }) => {
|
|
|
|
|
|
const fields = ['name']
|
|
|
|
|
|
const cellValue = row[column.field]
|
|
|
|
|
|
if (cellValue && fields.includes(column.field)) {
|
|
|
|
|
|
const prevRow = visibleData[_rowIndex - 1]
|
|
|
|
|
|
let nextRow = visibleData[_rowIndex + 1]
|
|
|
|
|
|
if (prevRow && prevRow[column.field] === cellValue) {
|
|
|
|
|
|
return { rowspan: 0, colspan: 0 }
|
|
|
|
|
|
} else {
|
|
|
|
|
|
let countRowspan = 1
|
|
|
|
|
|
while (nextRow && nextRow[column.field] === cellValue) {
|
|
|
|
|
|
nextRow = visibleData[++countRowspan + _rowIndex]
|
|
|
|
|
|
}
|
|
|
|
|
|
if (countRowspan > 1) {
|
|
|
|
|
|
return { rowspan: countRowspan, colspan: 1 }
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
const symbolJudgment = (value: string) => {
|
|
|
|
|
|
if (value == '==') {
|
|
|
|
|
|
return '='
|
|
|
|
|
|
} else {
|
|
|
|
|
|
return value
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
onMounted(() => {
|
|
|
|
|
|
info()
|
|
|
|
|
|
})
|
|
|
|
|
|
// 取消
|
|
|
|
|
|
const handleClose = () => {
|
|
|
|
|
|
emit('View')
|
|
|
|
|
|
}
|
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
|
|
:deep(.vxe-table--header thead tr:first-of-type th:first-of-type) {
|
|
|
|
|
|
// background: var(--vxe-table-header-background-color);
|
|
|
|
|
|
background-image: linear-gradient(var(--vxe-table-border-color), var(--vxe-table-border-color)),
|
|
|
|
|
|
linear-gradient(#e8eaec00, #e8eaec00);
|
|
|
|
|
|
}
|
|
|
|
|
|
:deep(.vxe-table--header thead tr:first-of-type th:first-of-type:before) {
|
|
|
|
|
|
content: '';
|
|
|
|
|
|
position: absolute;
|
|
|
|
|
|
width: 1px;
|
|
|
|
|
|
height: 98px; /*这里需要自己调整,根据td的宽度和高度*/
|
|
|
|
|
|
top: 0;
|
|
|
|
|
|
left: 0;
|
|
|
|
|
|
background-color: grey;
|
|
|
|
|
|
opacity: 0.3;
|
|
|
|
|
|
display: block;
|
|
|
|
|
|
transform: rotate(-66deg); /*这里需要自己调整,根据线的位置*/
|
|
|
|
|
|
transform-origin: top;
|
|
|
|
|
|
}
|
|
|
|
|
|
:deep(.vxe-table--header thead tr:last-of-type th:first-of-type:before) {
|
|
|
|
|
|
content: '';
|
|
|
|
|
|
position: absolute;
|
|
|
|
|
|
width: 1px;
|
|
|
|
|
|
height: 98px; /*这里需要自己调整,根据td的宽度和高度*/
|
|
|
|
|
|
bottom: 0;
|
|
|
|
|
|
right: 0;
|
|
|
|
|
|
background-color: grey;
|
|
|
|
|
|
opacity: 0.3;
|
|
|
|
|
|
display: block;
|
|
|
|
|
|
transform: rotate(-66deg); /*这里需要自己调整,根据线的位置*/
|
|
|
|
|
|
transform-origin: bottom;
|
|
|
|
|
|
}
|
|
|
|
|
|
.cellBox {
|
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
|
color: var(--el-color-primary);
|
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
|
text-decoration: underline;
|
|
|
|
|
|
}
|
|
|
|
|
|
</style>
|
|
|
|
|
|
<style lang="scss">
|
|
|
|
|
|
.el-dialog__body {
|
|
|
|
|
|
max-height: none !important;
|
|
|
|
|
|
}
|
|
|
|
|
|
.dialogBox {
|
|
|
|
|
|
margin-top: calc(15vh + 200px) !important;
|
|
|
|
|
|
}
|
|
|
|
|
|
/* 确保对话框在页面居中 */
|
|
|
|
|
|
// .el-dialog {
|
|
|
|
|
|
// display: flex;
|
|
|
|
|
|
// flex-direction: column;
|
|
|
|
|
|
// margin: 0 !important;
|
|
|
|
|
|
// position: absolute;
|
|
|
|
|
|
// top: 50%;
|
|
|
|
|
|
// left: 50%;
|
|
|
|
|
|
// transform: translate(-50%, -50%);
|
|
|
|
|
|
// max-height: calc(100% - 30px);
|
|
|
|
|
|
// max-width: calc(100% - 30px);
|
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
|
|
// /* 确保遮罩层全屏显示 */
|
|
|
|
|
|
// .el-dialog__wrapper {
|
|
|
|
|
|
// display: flex;
|
|
|
|
|
|
// align-items: center;
|
|
|
|
|
|
// justify-content: center;
|
|
|
|
|
|
// }
|
|
|
|
|
|
</style>
|