系统相关配置
This commit is contained in:
107
src/views/pqs/business/terminal/sensitiveLoadMange/detail.vue
Normal file
107
src/views/pqs/business/terminal/sensitiveLoadMange/detail.vue
Normal file
@@ -0,0 +1,107 @@
|
||||
<template>
|
||||
<el-dialog class="cn-operate-dialog" width="600px" v-model.trim="dialogVisible" :title="title">
|
||||
<el-form :model="form" class="form-one" label-width="auto" ref="formRef" :rules="rules">
|
||||
<el-form-item label="所属厂站名称" prop="substationName">
|
||||
<el-input v-model.trim="form.substationName" placeholder="请输入所属厂站名称"></el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="敏感用户名称" prop="name">
|
||||
<el-input v-model.trim="form.name" placeholder="请输入敏感用户名称"></el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="敏感负荷类型" prop="loadType">
|
||||
<el-select v-model.trim="form.loadType" filterable clearable placeholder="请选择数据分类">
|
||||
<el-option
|
||||
v-for="item in DataTypeSelect"
|
||||
:key="item.id"
|
||||
:label="item.name"
|
||||
:value="item.id"
|
||||
></el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="用户协议容量(MVA)" prop="userAgreementCapacity">
|
||||
<el-input-number style="width: 100%;" :min="0" maxlength="32" show-word-limit v-model.number="form.userAgreementCapacity" placeholder="请输入用户协议容量"></el-input-number>
|
||||
</el-form-item>
|
||||
<el-form-item label="装机容量(MW)" prop="installedCapacity">
|
||||
<el-input-number style="width: 100%;" :min="0" maxlength="32" show-word-limit v-model.number="form.installedCapacity" placeholder="请输入装机容量"></el-input-number>
|
||||
</el-form-item>
|
||||
<el-form-item label="排序" prop="sort">
|
||||
<el-input-number style="width: 100%;" :min="0" maxlength="32" show-word-limit v-model.number="form.sort" placeholder="请输入排序"></el-input-number>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
|
||||
<template #footer>
|
||||
<span class="dialog-footer">
|
||||
<el-button @click="dialogVisible = false">取消</el-button>
|
||||
<el-button type="primary" @click="submit">确认</el-button>
|
||||
</span>
|
||||
</template>
|
||||
</el-dialog>
|
||||
</template>
|
||||
<script lang="ts" setup>
|
||||
import { ref,inject } from 'vue'
|
||||
import { reactive } from 'vue'
|
||||
import { ElMessage } from 'element-plus'
|
||||
import TableStore from '@/utils/tableStore'
|
||||
import { queryByCode, queryCsDictTree } from '@/api/system-boot/dictTree'
|
||||
import { saveUser, updateUser } from '@/api/device-boot/sensitiveLoadMange'
|
||||
import { useDictData } from '@/stores/dictData'
|
||||
|
||||
const TypeOptions = ref()
|
||||
|
||||
const dictData = useDictData()
|
||||
const DataTypeSelect = dictData.getBasicData('Interference_Source')
|
||||
|
||||
const tableStore = inject('tableStore') as TableStore
|
||||
|
||||
const formRef = ref()
|
||||
const form = reactive<any>({
|
||||
loadType: [],
|
||||
substationName: null,
|
||||
installedCapacity: null,
|
||||
name: null,
|
||||
userAgreementCapacity:null,
|
||||
id: null,
|
||||
sort:100
|
||||
})
|
||||
const rules = {
|
||||
substationName: [{ required: true, message: '请输入所属厂站名称', trigger: 'blur' }],
|
||||
name: [{ required: true, message: '请输入敏感用户名称', trigger: 'blur' }],
|
||||
loadType: [{ required: true, message: '请输入请选择敏感负荷类型', trigger: 'blur' }],
|
||||
installedCapacity: [{ required: true, message: '请输入用户协议容量', trigger: 'blur' }],
|
||||
userAgreementCapacity: [{ required: true, message: '请输入装机容量', trigger: 'blur' }],
|
||||
sort: [{ required: true, message: '请输入排序', trigger: 'blur' }]
|
||||
}
|
||||
|
||||
const dialogVisible = ref(false)
|
||||
const title = ref('新增')
|
||||
const open = (text: string, data?: anyObj) => {
|
||||
formRef.value?.resetFields()
|
||||
title.value = text
|
||||
dialogVisible.value = true
|
||||
if (data) {
|
||||
for (let key in form) {
|
||||
form[key] = data[key]
|
||||
}
|
||||
} else {
|
||||
for (let key in form) {
|
||||
form[key] = null
|
||||
form.sort = 100
|
||||
}
|
||||
}
|
||||
}
|
||||
const submit = () => {
|
||||
formRef.value.validate(async (valid: boolean) => {
|
||||
if (valid) {
|
||||
if (form.id) {
|
||||
await updateUser(form)
|
||||
} else {
|
||||
await saveUser(form)
|
||||
}
|
||||
ElMessage.success('操作成功')
|
||||
tableStore.index()
|
||||
dialogVisible.value = false
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
defineExpose({ open })
|
||||
</script>
|
||||
117
src/views/pqs/business/terminal/sensitiveLoadMange/index.vue
Normal file
117
src/views/pqs/business/terminal/sensitiveLoadMange/index.vue
Normal file
@@ -0,0 +1,117 @@
|
||||
<template>
|
||||
<div class="default-main">
|
||||
<TableHeader :showReset="false" showExport>
|
||||
<template #select>
|
||||
<el-form-item label="关键字筛选">
|
||||
<el-input
|
||||
maxlength="32"
|
||||
show-word-limit
|
||||
style="width: 240px"
|
||||
v-model.trim="tableStore.table.params.searchValue"
|
||||
clearable
|
||||
placeholder="请输入敏感负荷名称"
|
||||
/>
|
||||
</el-form-item>
|
||||
</template>
|
||||
<template #operation>
|
||||
<el-button :icon="Plus" type="primary" @click="addMenu" class="ml10">新增</el-button>
|
||||
</template>
|
||||
</TableHeader>
|
||||
<Table ref="tableRef" />
|
||||
<detail ref="detail"></detail>
|
||||
</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 TableHeader from '@/components/table/header/index.vue'
|
||||
import Detail from './detail.vue'
|
||||
import { ElMessage } from 'element-plus'
|
||||
import { deleteUser } from '@/api/device-boot/sensitiveLoadMange'
|
||||
import { Plus } from '@element-plus/icons-vue'
|
||||
import { useDictData } from '@/stores/dictData'
|
||||
|
||||
defineOptions({
|
||||
name: 'govern/sensitiveLoadMange/index'
|
||||
})
|
||||
const detail = ref()
|
||||
|
||||
const dictData = useDictData()
|
||||
const interferenceType = dictData.getBasicData('Interference_Source')
|
||||
|
||||
const tableStore: any = new TableStore({
|
||||
url: '/device-boot/pqSensitiveUser/getList',
|
||||
method: 'POST',
|
||||
column: [
|
||||
{
|
||||
title: '序号',
|
||||
width: 80,
|
||||
formatter: (row: any) => {
|
||||
return (tableStore.table.params.pageNum - 1) * tableStore.table.params.pageSize + row.rowIndex + 1
|
||||
}
|
||||
},
|
||||
{ title: '所属厂站名称', field: 'substationName', minWidth: 180 },
|
||||
{ title: '敏感用户名称', field: 'name', minWidth: 180 },
|
||||
{
|
||||
title: '敏感负荷类型',
|
||||
field: 'loadType',
|
||||
minWidth: 120,
|
||||
formatter: row => {
|
||||
return interferenceType.filter(item => item.id == row.cellValue)[0]?.name
|
||||
}
|
||||
},
|
||||
{ title: '用户协议容量(MVA)', field: 'userAgreementCapacity', minWidth: 100 },
|
||||
{ title: '装机容量(MW)', field: 'installedCapacity', minWidth: 100 },
|
||||
{
|
||||
title: '操作', fixed: 'right',
|
||||
align: 'center',
|
||||
width: '180',
|
||||
|
||||
render: 'buttons',
|
||||
buttons: [
|
||||
{
|
||||
name: 'edit',
|
||||
title: '编辑',
|
||||
type: 'primary',
|
||||
icon: 'el-icon-EditPen',
|
||||
render: 'basicButton',
|
||||
click: row => {
|
||||
detail.value.open('编辑', row)
|
||||
}
|
||||
},
|
||||
{
|
||||
name: 'del',
|
||||
title: '删除',
|
||||
type: 'danger',
|
||||
icon: 'el-icon-Delete',
|
||||
render: 'confirmButton',
|
||||
popconfirm: {
|
||||
confirmButtonText: '确认',
|
||||
cancelButtonText: '取消',
|
||||
confirmButtonType: 'danger',
|
||||
title: '确定删除吗?'
|
||||
},
|
||||
click: row => {
|
||||
deleteUser([row.id]).then(res => {
|
||||
ElMessage.success('删除成功')
|
||||
tableStore.index()
|
||||
})
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
],
|
||||
loadCallback: () => {}
|
||||
})
|
||||
|
||||
tableStore.table.params.searchValue = ''
|
||||
provide('tableStore', tableStore)
|
||||
onMounted(() => {
|
||||
tableStore.index()
|
||||
})
|
||||
|
||||
const addMenu = () => {
|
||||
detail.value.open('新增')
|
||||
}
|
||||
</script>
|
||||
@@ -129,14 +129,22 @@ const tableStore = new TableStore({
|
||||
{ field: 'subName', title: '变电站', minWidth: '150' },
|
||||
{ field: 'ip', title: '网络参数' ,width:'120px' },
|
||||
{ field: 'scale', title: '电压等级', minWidth: '110' },
|
||||
// {
|
||||
// field: 'advanceType',
|
||||
// title: '触发类型',
|
||||
// minWidth: '90',
|
||||
// formatter: (row: any) => {
|
||||
// return row.cellValue || '其他'
|
||||
// }
|
||||
// },
|
||||
{
|
||||
field: 'advanceType',
|
||||
title: '暂降类型',
|
||||
minWidth: '90',
|
||||
formatter: (row: any) => {
|
||||
return row.cellValue || '其他'
|
||||
}
|
||||
},
|
||||
{
|
||||
field: 'eventType',
|
||||
title: '触发类型',
|
||||
minWidth: '120',
|
||||
formatter: (row: any) => {
|
||||
return eventList.filter(item => item.id === row.cellValue)[0]?.name
|
||||
}
|
||||
},
|
||||
{
|
||||
field: 'advanceReason',
|
||||
title: '暂降原因',
|
||||
@@ -145,14 +153,7 @@ const tableStore = new TableStore({
|
||||
return row.cellValue || '其他'
|
||||
}
|
||||
},
|
||||
{
|
||||
field: 'eventType',
|
||||
title: '触发类型',
|
||||
minWidth: '120',
|
||||
formatter: (row: any) => {
|
||||
return eventList.filter(item => item.id === row.cellValue)[0]?.name
|
||||
}
|
||||
},
|
||||
|
||||
// {
|
||||
// field: 'severity', title: '严重度', minWidth: "80", formatter: (row: any) => {
|
||||
// return row.cellValue.toFixed(2)
|
||||
|
||||
@@ -55,7 +55,7 @@
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="关键字筛选:">
|
||||
<el-input v-model="tableStore.table.params.searchValue" clearable placeholder="请输入关键字"></el-input>
|
||||
<el-input v-model="tableStore.table.params.searchValue" clearable placeholder="请输入关键字"></el-input>
|
||||
</el-form-item>
|
||||
</template>
|
||||
<template #operation>
|
||||
|
||||
@@ -103,7 +103,11 @@ const init = () => {
|
||||
)
|
||||
}
|
||||
options.value = {
|
||||
title: {
|
||||
text: formData.harmState == 0 ? '谐波电压频谱' : '谐波电流频谱'
|
||||
},
|
||||
xAxis: {
|
||||
|
||||
name: '次数',
|
||||
type: 'category',
|
||||
data: Array.from({ length: 49 }, (_, i) => `${i + 2}次`)
|
||||
|
||||
@@ -35,8 +35,8 @@ defineOptions({
|
||||
name: 'harmonic-boot/reate/word'
|
||||
})
|
||||
const dictData = useDictData()
|
||||
//区域联级选择
|
||||
const industry = dictData.getBasicData('Interference_Source')
|
||||
//行业类型选择
|
||||
const industry = dictData.getBasicData('Business_Type')
|
||||
//用户信息弹出框
|
||||
const tableRef = ref()
|
||||
|
||||
|
||||
@@ -8621,6 +8621,91 @@ const 葫芦岛 = [
|
||||
]
|
||||
]
|
||||
|
||||
const 海口 = [
|
||||
[
|
||||
{ lng: 110.106525, lat:20.026851},
|
||||
{ lng: 110.161895, lat:19.977693},
|
||||
{ lng: 110.143932, lat:19.889106},
|
||||
{ lng: 110.186246, lat:19.864193},
|
||||
{ lng: 110.228283, lat:19.753767},
|
||||
{ lng: 110.208468, lat:19.716679},
|
||||
{ lng: 110.222357, lat:19.67974},
|
||||
{ lng: 110.262449, lat:19.687318},
|
||||
{ lng: 110.314208, lat:19.697421},
|
||||
{ lng: 110.340041, lat:19.720625},
|
||||
{ lng: 110.393373, lat:19.698053},
|
||||
{ lng: 110.372633, lat:19.654004},
|
||||
{ lng: 110.401151, lat:19.606626},
|
||||
{ lng: 110.455687, lat:19.574559},
|
||||
{ lng: 110.486705, lat:19.593357},
|
||||
{ lng: 110.519297, lat:19.563341},
|
||||
{ lng: 110.540223, lat:19.535532},
|
||||
{ lng: 110.611518, lat:19.526841},
|
||||
{ lng: 110.641333, lat:19.549122},
|
||||
{ lng: 110.636148, lat:19.593989},
|
||||
{ lng: 110.672814, lat:19.647214},
|
||||
{ lng: 110.623463, lat:19.664109},
|
||||
{ lng: 110.623, lat:19.735461},
|
||||
{ lng: 110.670314, lat:19.812776},
|
||||
{ lng: 110.704665, lat:19.805992},
|
||||
{ lng: 110.699573, lat:19.861512},
|
||||
{ lng: 110.676147, lat:19.860092},
|
||||
{ lng: 110.675314, lat:19.907868},
|
||||
{ lng: 110.634666, lat:19.965401},
|
||||
{ lng: 110.598, lat:19.98305},
|
||||
{ lng: 110.526612, lat:20.075206},
|
||||
{ lng: 110.495039, lat:20.077253},
|
||||
{ lng: 110.387355, lat:20.11347},
|
||||
{ lng: 110.318467, lat:20.109061},
|
||||
{ lng: 110.293282, lat:20.059614},
|
||||
{ lng: 110.24319, lat:20.077568},
|
||||
{ lng: 110.144395, lat:20.074418},
|
||||
{ lng: 110.106525, lat:20.026851}
|
||||
]
|
||||
]
|
||||
const 三亚=[
|
||||
[
|
||||
{ lng: 108.932374, lat:18.335288},
|
||||
{ lng: 108.956448, lat:18.307433},
|
||||
{ lng: 109.006632, lat:18.323032},
|
||||
{ lng: 109.108298, lat:18.323828},
|
||||
{ lng: 109.138668, lat:18.267791},
|
||||
{ lng: 109.174686, lat:18.260149},
|
||||
{ lng: 109.28811, lat:18.264925},
|
||||
{ lng: 109.355887, lat:18.214922},
|
||||
{ lng: 109.441349, lat:18.199153},
|
||||
{ lng: 109.4632, lat:18.177171},
|
||||
{ lng: 109.527366, lat:18.169046},
|
||||
{ lng: 109.561718, lat:18.143554},
|
||||
{ lng: 109.63792, lat:18.171595},
|
||||
{ lng: 109.72616, lat:18.177808},
|
||||
{ lng: 109.749863, lat:18.19326},
|
||||
{ lng: 109.783381, lat:18.337516},
|
||||
{ lng: 109.805418, lat:18.347543},
|
||||
{ lng: 109.785048, lat:18.426622},
|
||||
{ lng: 109.809955, lat:18.459388},
|
||||
{ lng: 109.781159, lat:18.51107},
|
||||
{ lng: 109.725234, lat:18.493102},
|
||||
{ lng: 109.710882, lat:18.426462},
|
||||
{ lng: 109.665883, lat:18.391462},
|
||||
{ lng: 109.539866, lat:18.396713},
|
||||
{ lng: 109.515607, lat:18.429008},
|
||||
{ lng: 109.536996, lat:18.490717},
|
||||
{ lng: 109.535237, lat:18.53142},
|
||||
{ lng: 109.506163, lat:18.551291},
|
||||
{ lng: 109.423386, lat:18.574657},
|
||||
{ lng: 109.405146, lat:18.623443},
|
||||
{ lng: 109.332832, lat:18.575451},
|
||||
{ lng: 109.313295, lat:18.517429},
|
||||
{ lng: 109.246537, lat:18.558921},
|
||||
{ lng: 109.203574, lat:18.553517},
|
||||
{ lng: 109.185056, lat:18.507095},
|
||||
{ lng: 109.195148, lat:18.469407},
|
||||
{ lng: 109.072557, lat:18.452231},
|
||||
{ lng: 109.015243, lat:18.422645},
|
||||
{ lng: 108.932374, lat:18.335288}
|
||||
]
|
||||
]
|
||||
export default {
|
||||
zjkJSON,
|
||||
lfJSON,
|
||||
@@ -8640,5 +8725,7 @@ export default {
|
||||
铁岭,
|
||||
朝阳,
|
||||
葫芦岛,
|
||||
沈阳
|
||||
沈阳,
|
||||
海口,
|
||||
三亚
|
||||
}
|
||||
|
||||
@@ -53,6 +53,10 @@
|
||||
</div>
|
||||
<div class="collapse_none" style="color: red; cursor: pointer" @click="showWrap = false">关闭</div>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
|
||||
<baidu-map
|
||||
class="map"
|
||||
:style="height"
|
||||
@@ -329,6 +333,16 @@ const boundaryList: any = ref([
|
||||
orgName: '鞍山',
|
||||
LngLat: [122.808845, 40.840049],
|
||||
boundary: mapJson['鞍山']
|
||||
},
|
||||
{
|
||||
orgName: '海口',
|
||||
LngLat: [110.32, 20.03],
|
||||
boundary: mapJson['海口']
|
||||
},
|
||||
{
|
||||
orgName: '三亚',
|
||||
LngLat: [109.51, 18.25],
|
||||
boundary: mapJson['三亚']
|
||||
}
|
||||
])
|
||||
|
||||
@@ -338,8 +352,10 @@ const siteList = ref<any>([])
|
||||
const polyline = ref<any>([])
|
||||
const lineId = ref('')
|
||||
const center = ref({
|
||||
lng: 122.42588,
|
||||
lat: 40.810977
|
||||
lng: 122.42588,
|
||||
lat: 40.810977
|
||||
// lng: 109.5, // 海南经度
|
||||
// lat: 18.5 // 海南纬度
|
||||
})
|
||||
const infoWindowPoint = ref<anyObj>({
|
||||
lng: 0,
|
||||
|
||||
@@ -28,6 +28,7 @@
|
||||
</el-collapse-item>
|
||||
<el-collapse-item :title="item.name" v-for="(item, index) in column" :key="index" :name="index + 3">
|
||||
<div style="height: 200px">
|
||||
|
||||
<vxe-table height="auto" :data="form[item.key]" v-bind="defaultAttribute" v-loading="item.loading">
|
||||
<vxe-column type="seq" title="序号" width="80px"></vxe-column>
|
||||
<vxe-column
|
||||
|
||||
@@ -467,6 +467,7 @@ const dictionary = () => {
|
||||
|
||||
}
|
||||
onBeforeMount(async () => {
|
||||
|
||||
await dictionary()
|
||||
info(0) // 变压器参数维护
|
||||
info(1) // 电容器参数维护
|
||||
|
||||
@@ -85,6 +85,7 @@ const eliminate = (name: string) => {
|
||||
|
||||
// 地图数处理
|
||||
const map = (res: any) => {
|
||||
|
||||
echartMapList.value = {
|
||||
name: '',
|
||||
title: {
|
||||
|
||||
Reference in New Issue
Block a user