联调二级评估页面
This commit is contained in:
@@ -1,169 +1,163 @@
|
||||
<template>
|
||||
<div>
|
||||
<el-row :gutter="30" class="mb20">
|
||||
<el-col :span="10">
|
||||
<el-card>
|
||||
<template #header>
|
||||
<div class="card-header">
|
||||
<span>公共连接点参数</span>
|
||||
</div>
|
||||
</template>
|
||||
<div :style="`height: calc(${height} / 2 - 117px);overflow-y: auto`">
|
||||
<el-form
|
||||
ref="formRef"
|
||||
:model="form"
|
||||
label-width="150px"
|
||||
:rules="rules"
|
||||
:disabled="props.rowList.id != undefined"
|
||||
style="max-width: 500px; margin: auto"
|
||||
>
|
||||
<el-form-item label="用户模式" prop="userMode">
|
||||
<el-select v-model="form.userMode" placeholder="请选择用户模式">
|
||||
<el-option
|
||||
v-for="item in ModeList"
|
||||
:key="item.id"
|
||||
:label="item.name"
|
||||
:value="item.id"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="接线类型" prop="ptType">
|
||||
<el-select
|
||||
v-model="form.ptType"
|
||||
@change="form.connectionMode = ''"
|
||||
placeholder="请选择接线类型"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in connection"
|
||||
:key="item.value"
|
||||
:label="item.name"
|
||||
:value="item.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="连接方式" v-if="form.ptType == 0" prop="connectionMode">
|
||||
<el-select v-model="form.connectionMode" clearable placeholder="请选择连接方式">
|
||||
<el-option
|
||||
v-for="item in method"
|
||||
:key="item.id"
|
||||
:label="item.name"
|
||||
:value="item.id"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="功率因数" prop="k">
|
||||
<el-select v-model="form.k" clearable placeholder="请选择功率因数">
|
||||
<el-option
|
||||
v-for="item in factor"
|
||||
:key="item.id"
|
||||
:label="item.name"
|
||||
:value="item.id"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="电压等级" prop="scale">
|
||||
<el-select v-model="form.scale" clearable placeholder="请选择电压等级">
|
||||
<el-option
|
||||
v-for="item in levelList"
|
||||
:key="item.id"
|
||||
:label="item.name"
|
||||
:value="item.id"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="供电终端容量(MVA)" prop="deviceCapacity">
|
||||
<el-input-number
|
||||
v-model="form.deviceCapacity"
|
||||
style="width: 100%"
|
||||
:min="0.000001"
|
||||
placeholder="请填入供电终端容量"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="最小短路容量(MVA)" prop="shortCapacity">
|
||||
<el-input-number
|
||||
v-model="form.shortCapacity"
|
||||
style="width: 100%"
|
||||
:min="0.000001"
|
||||
placeholder="请填入最小短路容量"
|
||||
/>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
<div v-loading="loading">
|
||||
<div class="card-container mb10">
|
||||
<el-card style="width: 700px">
|
||||
<template #header>
|
||||
<div class="card-header">
|
||||
<span style="line-height: 32px">公共连接点参数</span>
|
||||
</div>
|
||||
</el-card>
|
||||
</el-col>
|
||||
<el-col :span="14">
|
||||
<el-card>
|
||||
<template #header>
|
||||
<div class="card-header">
|
||||
<span>干扰源用户:</span>
|
||||
<el-select
|
||||
v-model="userId"
|
||||
placeholder="请选择用户"
|
||||
style="width: 240px; font-weight: normal"
|
||||
:disabled="props.rowList.id != undefined"
|
||||
@change="selChange"
|
||||
>
|
||||
</template>
|
||||
<div :style="`height: calc(${height} - 380px);overflow-y: auto;max-height:350px`">
|
||||
<el-form
|
||||
ref="formRef"
|
||||
:model="form"
|
||||
label-width="150px"
|
||||
:rules="rules"
|
||||
:disabled="props.rowList.id != undefined"
|
||||
style="max-width: 500px; margin: auto"
|
||||
>
|
||||
<el-form-item label="用户模式" prop="userMode">
|
||||
<el-select v-model="form.userMode" placeholder="请选择用户模式">
|
||||
<el-option
|
||||
v-for="item in userData"
|
||||
:key="item.userId"
|
||||
:label="item.userName"
|
||||
:value="item.userId"
|
||||
v-for="item in ModeList"
|
||||
:key="item.id"
|
||||
:label="item.name"
|
||||
:value="item.id"
|
||||
/>
|
||||
</el-select>
|
||||
</div>
|
||||
</template>
|
||||
<div :style="`height: calc(${height} / 2 - 128px);overflow-y: auto`">
|
||||
<vxe-table
|
||||
v-bind="defaultAttribute"
|
||||
ref="vxeRef"
|
||||
height="auto"
|
||||
v-loading="loading"
|
||||
:data="equipmentList"
|
||||
>
|
||||
<vxe-column field="devName" title="终端名称"></vxe-column>
|
||||
<vxe-column field="devScale" title="电压等级" :formatter="formatter"></vxe-column>
|
||||
<vxe-column field="protocolCapacity" title="终端容量(MVA)"></vxe-column>
|
||||
</vxe-table>
|
||||
</div>
|
||||
</el-card>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form-item>
|
||||
<el-form-item label="接线类型" prop="ptType">
|
||||
<el-select
|
||||
v-model="form.ptType"
|
||||
@change="form.connectionMode = ''"
|
||||
placeholder="请选择接线类型"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in connection"
|
||||
:key="item.value"
|
||||
:label="item.name"
|
||||
:value="item.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="连接方式" v-if="form.ptType == 0" prop="connectionMode">
|
||||
<el-select v-model="form.connectionMode" clearable placeholder="请选择连接方式">
|
||||
<el-option v-for="item in method" :key="item.id" :label="item.name" :value="item.id" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="功率因数" prop="k">
|
||||
<el-select v-model="form.k" clearable placeholder="请选择功率因数">
|
||||
<el-option v-for="item in factor" :key="item.id" :label="item.name" :value="item.id" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="电压等级" prop="scale">
|
||||
<el-select v-model="form.scale" clearable placeholder="请选择电压等级">
|
||||
<el-option
|
||||
v-for="item in levelList"
|
||||
:key="item.id"
|
||||
:label="item.name"
|
||||
:value="item.id"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="供电终端容量(MVA)" prop="deviceCapacity">
|
||||
<el-input-number
|
||||
v-model="form.deviceCapacity"
|
||||
style="width: 100%"
|
||||
:min="0.000001"
|
||||
placeholder="请填入供电终端容量"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="最小短路容量(MVA)" prop="shortCapacity">
|
||||
<el-input-number
|
||||
v-model="form.shortCapacity"
|
||||
style="width: 100%"
|
||||
:min="0.000001"
|
||||
placeholder="请填入最小短路容量"
|
||||
/>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</div>
|
||||
</el-card>
|
||||
|
||||
<div class="bottomBox">
|
||||
<el-card class="ml10" style="flex: 1">
|
||||
<template #header>
|
||||
<div>
|
||||
<span>干扰源用户:</span>
|
||||
<el-select
|
||||
v-model="userId"
|
||||
placeholder="请选择用户"
|
||||
size="small"
|
||||
style="width: 240px"
|
||||
:disabled="props.rowList.id != undefined"
|
||||
@change="selChange"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in userData"
|
||||
:key="item.userId"
|
||||
:label="item.userName"
|
||||
:value="item.userId"
|
||||
/>
|
||||
</el-select>
|
||||
</div>
|
||||
</template>
|
||||
<div :style="`height: calc(${height} - 380px);overflow-y: auto;max-height:350px`">
|
||||
<vxe-table v-bind="defaultAttribute" ref="vxeRef" height="auto" :data="equipmentList">
|
||||
<vxe-column field="devName" title="终端名称"></vxe-column>
|
||||
<vxe-column field="devScale" title="电压等级" :formatter="formatter"></vxe-column>
|
||||
<vxe-column field="protocolCapacity" title="终端容量(MVA)"></vxe-column>
|
||||
</vxe-table>
|
||||
</div>
|
||||
</el-card>
|
||||
</div>
|
||||
|
||||
<div class="bottomBox pt1" id="exportId">
|
||||
<div v-if="showFlag">
|
||||
<div style="height: 70px">
|
||||
一级评估:{{ outcome.firstResult }}%
|
||||
<el-divider content-position="left">一级评估</el-divider>
|
||||
<div style="height: 40px" class="pl30">
|
||||
结果: {{ outcome.firstResult }}%
|
||||
{{ outcome.firstResult > 0.1 ? '>' : (outcome.firstResult = 0.1 ? '=' : '<') }} 0.1%
|
||||
<!-- <span>{{ 0.02 < outcome.firstResult && outcome.firstResult < 0.1 ? '满足' : '不满足' }}</span> -->
|
||||
|
||||
<el-tag v-if="outcome.firstResult < 0.1" type="success" effect="dark">满足</el-tag>
|
||||
<el-tag v-else type="warning" effect="dark">不满足</el-tag>
|
||||
</div>
|
||||
<div style="height: 20px" v-if="!(outcome.firstResult < 0.1)" class="mb10">
|
||||
二级评估:
|
||||
<el-row>
|
||||
<el-col :span="16" :style="`height: calc(${height} / 2 - 100px)`">
|
||||
<div style="height: 220px" v-if="!(outcome.firstResult < 0.1)" class="mb10">
|
||||
<el-divider content-position="left">二级评估</el-divider>
|
||||
<div class="evaluateTheResults">
|
||||
<div style="height: 200px; flex: 1">
|
||||
<vxe-table style="flex: 1.5" v-bind="defaultAttribute" height="auto" :data="level2Data">
|
||||
<vxe-column field="name" title="谐波次数" width="180"></vxe-column>
|
||||
<vxe-column v-for="item in column" :field="item.field" :title="item.title">
|
||||
<template #default="row">
|
||||
<span v-if="row.row.name == '是否允许值'">
|
||||
<Select v-if="row.row[row.column.field]" class="SelectIcon" />
|
||||
<InfoFilled v-else class="SelectIcon" style="color: #f38d07" />
|
||||
<CloseBold v-else class="SelectIcon" style="color: #f38d07" />
|
||||
</span>
|
||||
<span v-else>{{ row.row[row.column.field] }}</span>
|
||||
</template>
|
||||
</vxe-column>
|
||||
</vxe-table>
|
||||
</el-col>
|
||||
<el-col :span="8" :style="`height: calc(${height} / 2 - 100px)`">
|
||||
</div>
|
||||
<div style="height: 200px; width: 350px">
|
||||
<MyEChart style="flex: 1" :options="pieCharts" />
|
||||
</el-col>
|
||||
</el-row>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<el-button type="primary" icon="el-icon-Document" @click="assess" v-if="props.rowList.id == undefined">
|
||||
承载能力评估
|
||||
</el-button>
|
||||
<div class="button-group">
|
||||
<el-button
|
||||
type="primary"
|
||||
icon="el-icon-VideoPlay"
|
||||
@click="assess"
|
||||
class="mt10"
|
||||
v-if="props.rowList.id == undefined"
|
||||
>
|
||||
启动评估
|
||||
</el-button>
|
||||
<el-button type="primary" icon="el-icon-Download" @click="onExport" class="mt10" v-if="showFlag">
|
||||
导出结果
|
||||
</el-button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<el-dialog draggable v-model="dialogVisible" title="新增干扰源类型" width="70%">
|
||||
@@ -189,7 +183,8 @@ import { defaultAttribute } from '@/components/table/defaultAttribute'
|
||||
import MyEChart from '@/components/echarts/MyEchart.vue'
|
||||
import { useDictData } from '@/stores/dictData'
|
||||
import { mainHeight } from '@/utils/layout'
|
||||
import { Select, InfoFilled } from '@element-plus/icons-vue'
|
||||
import html2canvas from 'html2canvas'
|
||||
import { Select, CloseBold } from '@element-plus/icons-vue'
|
||||
import { ElMessage } from 'element-plus'
|
||||
import { queyDetailUser, carryCapacityEvaluate, queyDeviceList } from '@/api/advance-boot/bearingCapacity'
|
||||
const props = defineProps(['rowList'])
|
||||
@@ -232,6 +227,7 @@ const factor = [
|
||||
id: 1.0
|
||||
}
|
||||
]
|
||||
|
||||
const dialogVisible = ref(false)
|
||||
const showFlag = ref(false)
|
||||
const tableData = ref([])
|
||||
@@ -296,11 +292,13 @@ const assess = () => {
|
||||
if (equipmentList.value.length == null) {
|
||||
return ElMessage.warning('请选择用户')
|
||||
}
|
||||
loading.value = true
|
||||
formRef.value.validate((valid: any) => {
|
||||
if (valid) {
|
||||
form.value.devList = equipmentList.value
|
||||
carryCapacityEvaluate(form.value).then(res => {
|
||||
rendering(res.data)
|
||||
loading.value = false
|
||||
})
|
||||
}
|
||||
})
|
||||
@@ -314,15 +312,15 @@ const rendering = (row: any) => {
|
||||
value: 0
|
||||
},
|
||||
{
|
||||
name: 'III级',
|
||||
name: 'III级预警',
|
||||
value: 0
|
||||
},
|
||||
{
|
||||
name: 'II级',
|
||||
name: 'II级预警',
|
||||
value: 0
|
||||
},
|
||||
{
|
||||
name: 'I级',
|
||||
name: 'I级预警',
|
||||
value: 0
|
||||
},
|
||||
{
|
||||
@@ -348,34 +346,34 @@ const rendering = (row: any) => {
|
||||
showFlag.value = true
|
||||
row.reslutLevel == null ? '' : (ChartsList[row.reslutLevel - 1].value = 1)
|
||||
pieCharts.value = {
|
||||
title: {
|
||||
text: '承载能力评估结果',
|
||||
x: 'center',
|
||||
top: `30px`,
|
||||
textStyle: {
|
||||
fontWeight: 'normal'
|
||||
}
|
||||
},
|
||||
// title: {
|
||||
// text: '评估结果',
|
||||
// x: 'center',
|
||||
|
||||
// textStyle: {
|
||||
// fontWeight: 'normal'
|
||||
// }
|
||||
// },
|
||||
legend: {
|
||||
type: 'scroll',
|
||||
orient: 'vertical',
|
||||
left: 10,
|
||||
top: '10%'
|
||||
right: '10px',
|
||||
selectedMode: false // 是否允许点击
|
||||
},
|
||||
|
||||
toolbox: { show: false },
|
||||
xAxis: {
|
||||
show: false
|
||||
},
|
||||
yAxis: {
|
||||
show: false
|
||||
},
|
||||
color: ['#339966', '#00BFF5', '#FFBF00', '#Ff6600', '#ff0000', '#07CCCA'],
|
||||
color: ['#2E7D32', '#0288D1', '#F57C00', '#E64A19', '#C62828', '#00897B'],
|
||||
dataZoom: { show: false },
|
||||
series: [
|
||||
{
|
||||
type: 'pie',
|
||||
center: ['60%', '70%'],
|
||||
radius: ['35%', '48%'],
|
||||
center: ['40%', '55%'],
|
||||
radius: ['55%', '68%'],
|
||||
label: {
|
||||
normal: {
|
||||
show: false
|
||||
@@ -383,7 +381,48 @@ const rendering = (row: any) => {
|
||||
},
|
||||
data: ChartsList
|
||||
}
|
||||
]
|
||||
],
|
||||
options: {
|
||||
title: [
|
||||
{
|
||||
text: '评估结果',
|
||||
left: '27%'
|
||||
},
|
||||
{
|
||||
text:
|
||||
row.reslutLevel == 6
|
||||
? '允许接入'
|
||||
: row.reslutLevel == 5
|
||||
? '禁止接入'
|
||||
: row.reslutLevel == 4
|
||||
? 'I级预警'
|
||||
: row.reslutLevel == 3
|
||||
? 'II级预警'
|
||||
: row.reslutLevel == 2
|
||||
? 'III级预警'
|
||||
: row.reslutLevel == 1
|
||||
? '安全'
|
||||
: '',
|
||||
left: row.reslutLevel == 1 ? '33%' : '29%',
|
||||
top: '48%',
|
||||
textStyle: {
|
||||
color:
|
||||
row.reslutLevel == 6
|
||||
? '#00897B'
|
||||
: row.reslutLevel == 5
|
||||
? '#C62828'
|
||||
: row.reslutLevel == 4
|
||||
? '#E64A19'
|
||||
: row.reslutLevel == 3
|
||||
? '#F57C00'
|
||||
: row.reslutLevel == 2
|
||||
? '#0288D1'
|
||||
: '#2E7D32',
|
||||
foontWeight: '500'
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -400,21 +439,34 @@ const formatter = (row: any) => {
|
||||
}
|
||||
}
|
||||
// 查询终端
|
||||
const selChange = (e: any) => {
|
||||
const selChange = async (e: any) => {
|
||||
loading.value = true
|
||||
queyDeviceList({
|
||||
await queyDeviceList({
|
||||
userId: e
|
||||
}).then(res => {
|
||||
loading.value = false
|
||||
equipmentList.value = res.data
|
||||
})
|
||||
loading.value = false
|
||||
}
|
||||
// 导出
|
||||
const onExport = () => {
|
||||
// 转换成canvas
|
||||
html2canvas(document.getElementById('exportId'), {
|
||||
scale: 2
|
||||
}).then(function (canvas) {
|
||||
// 创建a标签,实现下载
|
||||
let creatIMg = document.createElement('a')
|
||||
creatIMg.download = '光伏电站承载能力评估结果.png' // 设置下载的文件名,
|
||||
creatIMg.href = canvas.toDataURL() // 下载url
|
||||
creatIMg.click()
|
||||
creatIMg.remove() // 下载之后把创建的元素删除
|
||||
})
|
||||
}
|
||||
|
||||
onMounted(() => {
|
||||
getUser()
|
||||
formRef.value?.resetFields()
|
||||
// 查看
|
||||
console.log('🚀 ~ onMounted ~ props.rowList:', props.rowList)
|
||||
|
||||
if (props.rowList.userId != undefined) {
|
||||
form.value = props.rowList
|
||||
@@ -427,18 +479,30 @@ onMounted(() => {
|
||||
<style lang="scss" scoped>
|
||||
.bottomBox {
|
||||
position: relative;
|
||||
.el-button {
|
||||
.button-group {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
top: 0px;
|
||||
right: 10px;
|
||||
}
|
||||
}
|
||||
.card-header {
|
||||
font-weight: 600;
|
||||
}
|
||||
// .card-header {
|
||||
// font-weight: 600;
|
||||
// }
|
||||
.SelectIcon {
|
||||
height: 30px;
|
||||
height: 18px;
|
||||
margin-top: 5px;
|
||||
color: blue;
|
||||
}
|
||||
:deep(.el-select__placeholder) {
|
||||
span {
|
||||
font-size: 14px;
|
||||
font-weight: 500;
|
||||
}
|
||||
}
|
||||
.card-container {
|
||||
display: flex;
|
||||
}
|
||||
.evaluateTheResults {
|
||||
display: flex;
|
||||
}
|
||||
</style>
|
||||
|
||||
Reference in New Issue
Block a user