提交
This commit is contained in:
42
src/api/algorithm-boot/scopeConfig.ts
Normal file
42
src/api/algorithm-boot/scopeConfig.ts
Normal file
@@ -0,0 +1,42 @@
|
||||
import createAxios from '@/utils/request'
|
||||
|
||||
/**
|
||||
* 删除数据合理范围
|
||||
**/
|
||||
export const pqDelete = (data: any) => {
|
||||
return createAxios({
|
||||
url: '/algorithm-boot/pqReasonableRange/delete',
|
||||
method: 'post',
|
||||
params: data
|
||||
})
|
||||
}
|
||||
/**
|
||||
* 按条件获取数据合理范围
|
||||
**/
|
||||
export const getData = (data: any) => {
|
||||
return createAxios({
|
||||
url: '/algorithm-boot/pqReasonableRange/getData',
|
||||
method: 'post',
|
||||
data
|
||||
})
|
||||
}
|
||||
/**
|
||||
* 新增数据合理范围
|
||||
**/
|
||||
export const save = (data: any) => {
|
||||
return createAxios({
|
||||
url: '/algorithm-boot/pqReasonableRange/save',
|
||||
method: 'post',
|
||||
data
|
||||
})
|
||||
}
|
||||
/**
|
||||
* 更新数据合理范围
|
||||
**/
|
||||
export const update = (data: any) => {
|
||||
return createAxios({
|
||||
url: '/algorithm-boot/pqReasonableRange/update',
|
||||
method: 'post',
|
||||
data
|
||||
})
|
||||
}
|
||||
@@ -1,30 +1,69 @@
|
||||
import createAxios from '@/utils/request'
|
||||
|
||||
/**
|
||||
* 查询app个人中心信息详情
|
||||
* @param id
|
||||
*/
|
||||
export const queryAppInfo = (type: string) => {
|
||||
let form = new FormData()
|
||||
form.append('type', type)
|
||||
return createAxios({
|
||||
url: '/cs-system-boot/appinfo/queryAppInfoByType',
|
||||
method: 'post',
|
||||
headers: {
|
||||
'Content-Type': 'application/x-www-form-urlencoded'
|
||||
},
|
||||
data: form
|
||||
})
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 新增app基础信息
|
||||
**/
|
||||
export const addAppInfo = (data: { type: string, content: string }) => {
|
||||
return createAxios({
|
||||
url: '/cs-system-boot/appinfo/addAppInfo',
|
||||
method: 'post',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
import createAxios from '@/utils/request'
|
||||
|
||||
/**
|
||||
* 查询app个人中心信息详情
|
||||
* @param id
|
||||
*/
|
||||
export const queryAppInfo = (type: string) => {
|
||||
let form = new FormData()
|
||||
form.append('type', type)
|
||||
return createAxios({
|
||||
url: '/cs-system-boot/appinfo/queryAppInfoByType',
|
||||
method: 'post',
|
||||
headers: {
|
||||
'Content-Type': 'application/x-www-form-urlencoded'
|
||||
},
|
||||
data: form
|
||||
})
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增app基础信息
|
||||
**/
|
||||
export const addAppInfo = (data: { type: string; content: string }) => {
|
||||
return createAxios({
|
||||
url: '/cs-system-boot/appinfo/addAppInfo',
|
||||
method: 'post',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
/**
|
||||
* 切换告警配置启用状态
|
||||
**/
|
||||
export const toggleActive = (data: any) => {
|
||||
return createAxios({
|
||||
url: '/cs-system-boot/csAlarmSet/toggleActive',
|
||||
method: 'post',
|
||||
params: data
|
||||
})
|
||||
}
|
||||
/**
|
||||
* 切换告警配置启用状态
|
||||
**/
|
||||
export const csDelete = (data: any) => {
|
||||
return createAxios({
|
||||
url: '/cs-system-boot/csAlarmSet/delete',
|
||||
method: 'post',
|
||||
params: data
|
||||
})
|
||||
}
|
||||
/**
|
||||
* 新增告警配置
|
||||
**/
|
||||
export const add = (data: any) => {
|
||||
return createAxios({
|
||||
url: '/cs-system-boot/csAlarmSet/add',
|
||||
method: 'post',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
/**
|
||||
* 修改告警配置
|
||||
**/
|
||||
export const update = (data: any) => {
|
||||
return createAxios({
|
||||
url: '/cs-system-boot/csAlarmSet/update',
|
||||
method: 'post',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
|
||||
@@ -1,51 +1,51 @@
|
||||
<template>
|
||||
<el-dialog draggable width="600px" v-model.trim="dialogVisible" :title="title">
|
||||
|
||||
<el-form :inline="false" :model="form" label-width="auto" class="form-one">
|
||||
<el-form-item label="用户名称:">
|
||||
<el-input v-model.trim="form.name" :disabled="true"></el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="登录名称:" class="top">
|
||||
<el-input v-model.trim="form.loginName" :disabled="true"></el-input>
|
||||
</el-form-item>
|
||||
<!-- <el-form-item label="归属部门名称:" class="top">
|
||||
<el-input v-model.trim="form.deptName" :disabled="true"></el-input>
|
||||
</el-form-item> -->
|
||||
<el-form-item label="拥有的角色:" class="top">
|
||||
<el-input v-model.trim="form.role" :disabled="true"></el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="电话号码:" class="top">
|
||||
<el-input v-model.trim="form.phone" :disabled="true"></el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="电子邮箱:" class="top">
|
||||
<el-input v-model.trim="form.email" :disabled="true"></el-input>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</el-dialog>
|
||||
</template>
|
||||
<script lang="ts" setup>
|
||||
import { ref, inject } from 'vue'
|
||||
import { reactive } from 'vue'
|
||||
import { useAdminInfo } from '@/stores/adminInfo'
|
||||
|
||||
const dialogVisible = ref(false)
|
||||
const title = ref('用户信息')
|
||||
const adminInfo = useAdminInfo()
|
||||
const formRef = ref()
|
||||
const form = reactive({
|
||||
name: '',
|
||||
deptName: '',
|
||||
phone: '',
|
||||
email: '',
|
||||
role: '',
|
||||
loginName: ''
|
||||
})
|
||||
|
||||
const open = () => {
|
||||
dialogVisible.value = true
|
||||
for (const key in form) {
|
||||
form[key] = Array.isArray(adminInfo.$state[key]) ? adminInfo.$state[key].join(',') : adminInfo.$state[key]
|
||||
}
|
||||
}
|
||||
defineExpose({ open })
|
||||
</script>
|
||||
<template>
|
||||
<el-dialog draggable width="500px" v-model.trim="dialogVisible" :title="title">
|
||||
|
||||
<el-form :inline="false" :model="form" label-width="auto" class="form-one">
|
||||
<el-form-item label="用户名称:">
|
||||
<el-input v-model.trim="form.name" :disabled="true"></el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="登录名称:" class="top">
|
||||
<el-input v-model.trim="form.loginName" :disabled="true"></el-input>
|
||||
</el-form-item>
|
||||
<!-- <el-form-item label="归属部门名称:" class="top">
|
||||
<el-input v-model.trim="form.deptName" :disabled="true"></el-input>
|
||||
</el-form-item> -->
|
||||
<el-form-item label="拥有的角色:" class="top">
|
||||
<el-input v-model.trim="form.role" :disabled="true"></el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="电话号码:" class="top">
|
||||
<el-input v-model.trim="form.phone" :disabled="true"></el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="电子邮箱:" class="top">
|
||||
<el-input v-model.trim="form.email" :disabled="true"></el-input>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</el-dialog>
|
||||
</template>
|
||||
<script lang="ts" setup>
|
||||
import { ref, inject } from 'vue'
|
||||
import { reactive } from 'vue'
|
||||
import { useAdminInfo } from '@/stores/adminInfo'
|
||||
|
||||
const dialogVisible = ref(false)
|
||||
const title = ref('用户信息')
|
||||
const adminInfo = useAdminInfo()
|
||||
const formRef = ref()
|
||||
const form = reactive({
|
||||
name: '',
|
||||
deptName: '',
|
||||
phone: '',
|
||||
email: '',
|
||||
role: '',
|
||||
loginName: ''
|
||||
})
|
||||
|
||||
const open = () => {
|
||||
dialogVisible.value = true
|
||||
for (const key in form) {
|
||||
form[key] = Array.isArray(adminInfo.$state[key]) ? adminInfo.$state[key].join(',') : adminInfo.$state[key]
|
||||
}
|
||||
}
|
||||
defineExpose({ open })
|
||||
</script>
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
<template>
|
||||
<el-dialog width="600px" v-model.trim='dialogVisible' :title='title'>
|
||||
<el-dialog width="500px" v-model.trim='dialogVisible' :title='title'>
|
||||
<el-scrollbar>
|
||||
<el-form :inline='false' :model='form' label-width='auto' class="form-one" :rules='rules' ref='formRef'>
|
||||
<el-form-item label='角色名称'>
|
||||
|
||||
@@ -57,7 +57,7 @@
|
||||
<el-input maxlength="32" show-word-limit v-model.trim="form.email" placeholder="请输入描述" />
|
||||
</el-form-item>
|
||||
<el-form-item label="时间段" prop="limitTime">
|
||||
<el-slider v-model.trim="form.limitTime" style="width: 95%" range show-stops :max="24" />
|
||||
<el-slider v-model.trim="form.limitTime" style="width: 95%" range :max="24" />
|
||||
</el-form-item>
|
||||
<el-form-item label="起始IP" prop="limitIpStart">
|
||||
<el-input maxlength="32" show-word-limit v-model.trim="form.limitIpStart" placeholder="请输入描述" />
|
||||
|
||||
129
src/views/govern/alarm/alarmConfig/form.vue
Normal file
129
src/views/govern/alarm/alarmConfig/form.vue
Normal file
@@ -0,0 +1,129 @@
|
||||
<template>
|
||||
<el-dialog class="cn-operate-dialog" draggable v-model="dialogVisible" :title="title" width="500px"
|
||||
@closed="handleClosed">
|
||||
<el-form ref="formRef" :model="form" :rules="rules" label-width="auto" class="form-one">
|
||||
<el-form-item label="方案名称" prop="name">
|
||||
<el-input v-model.trim="form.name" maxlength="64" show-word-limit placeholder="请输入方案名称" clearable />
|
||||
</el-form-item>
|
||||
<el-form-item label="在线率阈值" prop="onlineRateLimit">
|
||||
<el-input-number v-model="form.onlineRateLimit" :min="0" :max="100" :precision="0" style="width: 100%"
|
||||
placeholder="0-100" />
|
||||
</el-form-item>
|
||||
<el-form-item label="完整性阈值" prop="integrityLimit">
|
||||
<el-input-number v-model="form.integrityLimit" :min="0" :max="100" :precision="0" style="width: 100%"
|
||||
placeholder="0-100" />
|
||||
</el-form-item>
|
||||
<!-- <el-form-item label="是否启用" prop="active">
|
||||
<el-select v-model="form.active" placeholder="请选择" style="width: 100%">
|
||||
<el-option label="启用" value="1" />
|
||||
<el-option label="停用" value="0" />
|
||||
</el-select>
|
||||
</el-form-item> -->
|
||||
</el-form>
|
||||
<template #footer>
|
||||
<el-button @click="handleCancel">取消</el-button>
|
||||
<el-button type="primary" @click="onSubmit">确定</el-button>
|
||||
</template>
|
||||
</el-dialog>
|
||||
</template>
|
||||
|
||||
<script lang="ts" setup>
|
||||
import { ref, reactive } from 'vue'
|
||||
import { ElMessage } from 'element-plus'
|
||||
import { inject } from 'vue'
|
||||
import { add, update } from '@/api/cs-system-boot/appinfo'
|
||||
|
||||
const emit = defineEmits(['Cancels'])
|
||||
|
||||
const dialogVisible = ref(false)
|
||||
const title = ref('')
|
||||
const formRef = ref()
|
||||
|
||||
const defaultForm = () => ({
|
||||
id: '',
|
||||
name: '',
|
||||
onlineRateLimit: undefined as number | undefined,
|
||||
integrityLimit: undefined as number | undefined,
|
||||
active: '0' as string
|
||||
})
|
||||
|
||||
const form = reactive(defaultForm())
|
||||
|
||||
const percentRule = (label: string) => [
|
||||
{ required: true, message: `请输入${label}`, trigger: 'blur' },
|
||||
{
|
||||
type: 'number',
|
||||
min: 0,
|
||||
max: 100,
|
||||
message: `${label}范围为 0-100`,
|
||||
trigger: 'blur'
|
||||
}
|
||||
]
|
||||
|
||||
const rules: any = {
|
||||
name: [
|
||||
{ required: true, message: '请输入方案名称', trigger: 'blur' },
|
||||
{ min: 1, max: 64, message: '长度 1-64 个字符', trigger: 'blur' }
|
||||
],
|
||||
onlineRateLimit: percentRule('在线率阈值'),
|
||||
integrityLimit: percentRule('完整性阈值'),
|
||||
active: [{ required: true, message: '请选择是否启用', trigger: 'change' }]
|
||||
}
|
||||
|
||||
const isEdit = () => title.value.includes('修改')
|
||||
|
||||
const resetForm = () => {
|
||||
Object.assign(form, defaultForm())
|
||||
}
|
||||
|
||||
const open = (e: { text: string; row?: any }) => {
|
||||
formRef.value?.resetFields()
|
||||
title.value = e.text
|
||||
dialogVisible.value = true
|
||||
resetForm()
|
||||
if (e.row) {
|
||||
form.id = e.row.id ?? ''
|
||||
form.name = e.row.name ?? ''
|
||||
form.onlineRateLimit = e.row.onlineRateLimit != null ? Number(e.row.onlineRateLimit) : undefined
|
||||
form.integrityLimit = e.row.integrityLimit != null ? Number(e.row.integrityLimit) : undefined
|
||||
form.active = String(e.row.active ?? '0')
|
||||
}
|
||||
}
|
||||
|
||||
const handleCancel = () => {
|
||||
dialogVisible.value = false
|
||||
emit('Cancels')
|
||||
}
|
||||
|
||||
const handleClosed = () => {
|
||||
resetForm()
|
||||
}
|
||||
|
||||
const onSubmit = () => {
|
||||
formRef.value?.validate(async (valid: boolean) => {
|
||||
if (!valid) return
|
||||
const payload = {
|
||||
id: form.id,
|
||||
name: form.name,
|
||||
onlineRateLimit: form.onlineRateLimit,
|
||||
integrityLimit: form.integrityLimit,
|
||||
active: form.active
|
||||
}
|
||||
try {
|
||||
if (isEdit()) {
|
||||
await update(payload)
|
||||
ElMessage.success('修改成功')
|
||||
} else {
|
||||
await add(payload)
|
||||
ElMessage.success('新增成功')
|
||||
}
|
||||
dialogVisible.value = false
|
||||
emit('Cancels')
|
||||
} catch {
|
||||
/* 请求层一般会统一提示 */
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
defineExpose({ open })
|
||||
</script>
|
||||
152
src/views/govern/alarm/alarmConfig/index.vue
Normal file
152
src/views/govern/alarm/alarmConfig/index.vue
Normal file
@@ -0,0 +1,152 @@
|
||||
<template>
|
||||
<div class="default-main">
|
||||
<TableHeader select :showReset="false" ref="TableHeaderRef">
|
||||
<template #operation>
|
||||
<el-button icon="el-icon-Plus" type="primary" @click="add">新增</el-button>
|
||||
</template>
|
||||
</TableHeader>
|
||||
<Table ref="tableRef" />
|
||||
<Form ref="formRef" @Cancels="tableStore.index()" />
|
||||
</div>
|
||||
</template>
|
||||
<script setup lang="ts">
|
||||
import { ref, onMounted, provide, nextTick } from 'vue'
|
||||
import TableStore from '@/utils/tableStore'
|
||||
import Table from '@/components/table/index.vue'
|
||||
import TableHeader from '@/components/table/header/index.vue'
|
||||
import { ElMessage } from 'element-plus'
|
||||
import { toggleActive, csDelete } from '@/api/cs-system-boot/appinfo'
|
||||
import Form from './form.vue'
|
||||
defineOptions({
|
||||
name: 'govern/alarmConfig'
|
||||
})
|
||||
const formTabRef = ref()
|
||||
const formRef = ref()
|
||||
const tableStore: any = new TableStore({
|
||||
url: '/cs-system-boot/csAlarmSet/listAll',
|
||||
method: 'POST',
|
||||
showPage: false,
|
||||
column: [
|
||||
{
|
||||
field: 'index',
|
||||
title: '序号',
|
||||
width: '80',
|
||||
formatter: (row: any) => {
|
||||
return (tableStore.table.params.pageNum - 1) * tableStore.table.params.pageSize + row.rowIndex + 1
|
||||
}
|
||||
},
|
||||
{ field: 'name', title: '名称' },
|
||||
{ field: 'onlineRateLimit', title: '在线率阈值' },
|
||||
{ field: 'integrityLimit', title: '完整性阈值' },
|
||||
{ field: 'updateTime', title: '创建时间' },
|
||||
{
|
||||
title: '是否启用',
|
||||
render: 'switch',
|
||||
width: 100,
|
||||
field: 'active',
|
||||
activeText: '启用',
|
||||
inactiveText: '停用',
|
||||
inactiveValue: '0',
|
||||
activeValue: '1',
|
||||
onChangeField: (row: any, value: any) => {
|
||||
if (row.active == 1) {
|
||||
return ElMessage({ message: '至少需要保留一条启用的配置!', type: 'warning' })
|
||||
// 至少需要保留一条启用的配置
|
||||
}
|
||||
toggleActive({
|
||||
id: row.id
|
||||
}).then(res => {
|
||||
ElMessage({ message: '启用成功!', type: 'success' })
|
||||
tableStore.index()
|
||||
})
|
||||
}
|
||||
},
|
||||
|
||||
{
|
||||
title: '操作',
|
||||
fixed: 'right',
|
||||
width: '180',
|
||||
render: 'buttons',
|
||||
buttons: [
|
||||
// {
|
||||
// name: 'edit',
|
||||
// title: '启用 ',
|
||||
// type: 'primary',
|
||||
// icon: 'el-icon-Plus',
|
||||
// render: 'basicButton',
|
||||
// disabled: row => {
|
||||
// return row.active == 1
|
||||
// },
|
||||
// click: row => {
|
||||
// toggleActive({ id: row.id }).then(res => {
|
||||
// ElMessage({
|
||||
// message: '启用成功!',
|
||||
// type: 'success'
|
||||
// })
|
||||
// tableStore.index()
|
||||
// })
|
||||
// }
|
||||
// },
|
||||
{
|
||||
name: 'edit',
|
||||
title: '修改 ',
|
||||
type: 'primary',
|
||||
icon: 'el-icon-Plus',
|
||||
render: 'basicButton',
|
||||
click: row => {
|
||||
setTimeout(() => {
|
||||
formRef.value.open({
|
||||
text: '修改配置',
|
||||
row: row
|
||||
})
|
||||
}, 10)
|
||||
}
|
||||
},
|
||||
{
|
||||
name: 'edit',
|
||||
title: '删除',
|
||||
type: 'danger',
|
||||
icon: 'el-icon-Delete',
|
||||
render: 'confirmButton',
|
||||
disabled: row => {
|
||||
return row.active == 1
|
||||
},
|
||||
popconfirm: {
|
||||
confirmButtonText: '确认',
|
||||
cancelButtonText: '取消',
|
||||
confirmButtonType: 'danger',
|
||||
title: '确定删除吗?'
|
||||
},
|
||||
click: row => {
|
||||
csDelete({ id: row.id }).then(res => {
|
||||
ElMessage({
|
||||
message: '删除成功!',
|
||||
type: 'success'
|
||||
})
|
||||
tableStore.index()
|
||||
})
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
],
|
||||
|
||||
loadCallback: () => {
|
||||
|
||||
|
||||
}
|
||||
})
|
||||
|
||||
provide('tableStore', tableStore)
|
||||
// 新增主题
|
||||
const add = () => {
|
||||
setTimeout(() => {
|
||||
formRef.value.open({
|
||||
text: '新增配置'
|
||||
})
|
||||
}, 10)
|
||||
}
|
||||
onMounted(() => {
|
||||
tableStore.index()
|
||||
})
|
||||
</script>
|
||||
270
src/views/govern/alarm/scopeConfig/form.vue
Normal file
270
src/views/govern/alarm/scopeConfig/form.vue
Normal file
@@ -0,0 +1,270 @@
|
||||
<template>
|
||||
<el-dialog class="cn-operate-dialog" draggable v-model="dialogVisible" :title="title" width="900px"
|
||||
@closed="handleClosed">
|
||||
<el-scrollbar max-height="60vh">
|
||||
<el-form ref="formRef" :model="form" :rules="rules" label-width="auto" class="form-two">
|
||||
<el-form-item label="指标名称" prop="indexName">
|
||||
<el-input v-model.trim="form.indexName" placeholder="请输入指标名称" clearable maxlength="128" />
|
||||
</el-form-item>
|
||||
|
||||
<el-form-item label="指标code" prop="indexCode">
|
||||
<el-input v-model.trim="form.indexCode" placeholder="请输入指标code" clearable maxlength="64" />
|
||||
</el-form-item>
|
||||
|
||||
|
||||
<el-form-item label="表名" prop="influxdbTableName">
|
||||
<el-input v-model.trim="form.influxdbTableName" placeholder="请输入表名" clearable />
|
||||
</el-form-item>
|
||||
<el-form-item label="列属性" prop="influxdbColumnName">
|
||||
<el-input v-model.trim="form.influxdbColumnName" placeholder="实体类属性名" clearable maxlength="128" />
|
||||
</el-form-item>
|
||||
<el-form-item label="谐波次数">
|
||||
<el-slider v-model.trim="form.harmSlider" range :max="50" style="width: 90%" />
|
||||
</el-form-item>
|
||||
<el-form-item label="相别" prop="phaseList">
|
||||
<el-select v-model.trim="form.phaseList" filterable multiple clearable collapse-tags
|
||||
collapse-tags-tooltip placeholder="请选择相别">
|
||||
<el-option v-for="item in phaseSelect" :key="item.id" :label="item.name"
|
||||
:value="item.id"></el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="指标下限" prop="minValue">
|
||||
<el-input-number v-model="form.minValue" style="width: 100%" placeholder="下限" />
|
||||
</el-form-item>
|
||||
<el-form-item label="指标上限" prop="maxValue">
|
||||
<el-input-number v-model="form.maxValue" style="width: 100%" placeholder="上限" />
|
||||
</el-form-item>
|
||||
<el-form-item label="电压等级参与" prop="isVoltage">
|
||||
<el-radio-group v-model="form.isVoltage">
|
||||
<el-radio :value="0">不参与</el-radio>
|
||||
<el-radio :value="1">参与</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
<el-form-item label="Ct变比参与" prop="ctAttendFlag">
|
||||
<el-radio-group v-model="form.ctAttendFlag">
|
||||
<el-radio :value="0">不参与</el-radio>
|
||||
<el-radio :value="1">参与</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
<el-form-item label="数据来源" prop="dataSource">
|
||||
<el-select v-model="form.dataSource" placeholder="请选择" clearable style="width: 100%">
|
||||
<el-option label="InfluxDB" value="InfluxDB" />
|
||||
<!-- <el-option label="oracle" value="oracle" /> -->
|
||||
<el-option label="MySql" value="MySql" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="所属系统" prop="belongingSystem">
|
||||
<el-select v-model="form.belongingSystem" placeholder="请选择" clearable style="width: 100%">
|
||||
<el-option label="pqs" value="pqs" />
|
||||
<el-option label="govern" value="govern" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="单位" prop="unit">
|
||||
<el-input v-model.trim="form.unit" placeholder="请输入单位" clearable maxlength="32" />
|
||||
</el-form-item>
|
||||
<el-form-item label="排序" prop="sort">
|
||||
<el-input-number v-model="form.sort" :min="0" :precision="0" style="width: 100%" />
|
||||
</el-form-item>
|
||||
<!-- <el-form-item label="状态" prop="state">
|
||||
<el-select v-model="form.state" placeholder="请选择" style="width: 100%">
|
||||
<el-option label="正常" :value="1" />
|
||||
<el-option label="删除" :value="0" />
|
||||
</el-select>
|
||||
</el-form-item> -->
|
||||
<el-form-item label="条件描述" prop="otherAlgorithm" class="form-item-full">
|
||||
<el-input v-model.trim="form.otherAlgorithm" type="textarea" :rows="2" placeholder="无具体范围时的判断条件描述"
|
||||
maxlength="500" show-word-limit />
|
||||
</el-form-item>
|
||||
<el-form-item label="备注" prop="remark" class="form-item-full">
|
||||
<el-input v-model.trim="form.remark" type="textarea" :rows="2" placeholder="备注" maxlength="500"
|
||||
show-word-limit />
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</el-scrollbar>
|
||||
<template #footer>
|
||||
<el-button @click="handleCancel">取消</el-button>
|
||||
<el-button type="primary" @click="onSubmit">确定</el-button>
|
||||
</template>
|
||||
</el-dialog>
|
||||
</template>
|
||||
|
||||
<script lang="ts" setup>
|
||||
import { ref, reactive } from 'vue'
|
||||
import { ElMessage } from 'element-plus'
|
||||
import { save, update } from '@/api/algorithm-boot/scopeConfig'
|
||||
const emit = defineEmits(['Cancels'])
|
||||
|
||||
const dialogVisible = ref(false)
|
||||
const title = ref('')
|
||||
const formRef = ref()
|
||||
const phaseSelect = [
|
||||
{
|
||||
name: 'A相',
|
||||
id: 'A'
|
||||
},
|
||||
{
|
||||
name: 'B相',
|
||||
id: 'B'
|
||||
},
|
||||
{
|
||||
name: 'C相',
|
||||
id: 'C'
|
||||
},
|
||||
{
|
||||
name: '无相别',
|
||||
id: 'T'
|
||||
},
|
||||
{
|
||||
name: 'AB相',
|
||||
id: 'AB'
|
||||
},
|
||||
{
|
||||
name: 'BC相',
|
||||
id: 'BC'
|
||||
},
|
||||
{
|
||||
name: 'CA相',
|
||||
id: 'CA'
|
||||
},
|
||||
// {
|
||||
// name: '无相别',
|
||||
// id: 'M'
|
||||
// },
|
||||
]
|
||||
const defaultForm = () => ({
|
||||
id: '',
|
||||
indexCode: '',
|
||||
indexName: '',
|
||||
harmSlider: [0, 0],
|
||||
harmStart: undefined as number | undefined,
|
||||
harmEnd: undefined as number | undefined,
|
||||
phaseType: '',
|
||||
phaseList: [] as any,
|
||||
influxdbTableName: '',
|
||||
influxdbColumnName: '',
|
||||
minValue: undefined as number | undefined,
|
||||
maxValue: undefined as number | undefined,
|
||||
isVoltage: 0,
|
||||
ctAttendFlag: 0,
|
||||
dataSource: '',
|
||||
otherAlgorithm: '',
|
||||
remark: '',
|
||||
unit: '',
|
||||
sort: 100,
|
||||
belongingSystem: 'govern',
|
||||
state: 1
|
||||
})
|
||||
|
||||
const form = reactive(defaultForm())
|
||||
|
||||
|
||||
|
||||
const validateMinMax = (_rule: any, _value: any, callback: (e?: Error) => void) => {
|
||||
if (form.minValue == null || form.maxValue == null) {
|
||||
callback()
|
||||
return
|
||||
}
|
||||
if (form.minValue > form.maxValue) {
|
||||
callback(new Error('指标下限不能大于指标上限'))
|
||||
} else {
|
||||
callback()
|
||||
}
|
||||
}
|
||||
|
||||
const rules: any = {
|
||||
indexCode: [{ required: true, message: '请输入指标code', trigger: 'blur' }],
|
||||
indexName: [{ required: true, message: '请输入指标名称', trigger: 'blur' }],
|
||||
phaseList: [{ required: true, message: '请输入指标名称', trigger: 'change' }],
|
||||
|
||||
influxdbTableName: [{ required: true, message: '请输入表名', trigger: 'blur' }],
|
||||
influxdbColumnName: [{ required: true, message: '请输入列属性', trigger: 'blur' }],
|
||||
minValue: [
|
||||
{ required: true, message: '请输入指标下限', trigger: 'blur' },
|
||||
{ validator: validateMinMax, trigger: 'change' }
|
||||
],
|
||||
maxValue: [
|
||||
{ required: true, message: '请输入指标上限', trigger: 'blur' },
|
||||
{ validator: validateMinMax, trigger: 'change' }
|
||||
],
|
||||
isVoltage: [{ required: true, message: '请选择电压等级是否参与', trigger: 'change' }],
|
||||
ctAttendFlag: [{ required: true, message: '请选择Ct变比是否参与', trigger: 'change' }],
|
||||
dataSource: [{ required: true, message: '请选择数据来源', trigger: 'change' }],
|
||||
belongingSystem: [{ required: true, message: '请选择所属系统', trigger: 'change' }],
|
||||
sort: [{ required: true, message: '请输入排序', trigger: 'blur' }],
|
||||
state: [{ required: true, message: '请选择状态', trigger: 'change' }]
|
||||
}
|
||||
|
||||
const isEdit = () => title.value.includes('修改')
|
||||
|
||||
const resetForm = () => {
|
||||
Object.assign(form, defaultForm())
|
||||
}
|
||||
|
||||
const fillForm = (row: any) => {
|
||||
const keys = Object.keys(defaultForm()) as (keyof ReturnType<typeof defaultForm>)[]
|
||||
keys.forEach(key => {
|
||||
if (row[key] === undefined || row[key] === null) return
|
||||
if (['harmStart', 'harmEnd', 'sort', 'isVoltage', 'ctAttendFlag', 'state'].includes(key)) {
|
||||
; (form as any)[key] = Number(row[key])
|
||||
} else if (['minValue', 'maxValue'].includes(key)) {
|
||||
; (form as any)[key] = Number(row[key])
|
||||
} else {
|
||||
; (form as any)[key] = row[key]
|
||||
}
|
||||
})
|
||||
form.phaseList = form.phaseType.split(',')
|
||||
|
||||
form.harmSlider = [form.harmStart || 0, form.harmEnd || 0]
|
||||
}
|
||||
|
||||
const open = (e: { text: string; row?: any }) => {
|
||||
formRef.value?.resetFields()
|
||||
title.value = e.text
|
||||
dialogVisible.value = true
|
||||
resetForm()
|
||||
if (e.row) {
|
||||
|
||||
fillForm(e.row)
|
||||
}
|
||||
}
|
||||
|
||||
const handleCancel = () => {
|
||||
dialogVisible.value = false
|
||||
emit('Cancels')
|
||||
}
|
||||
|
||||
const handleClosed = () => {
|
||||
resetForm()
|
||||
}
|
||||
|
||||
const onSubmit = () => {
|
||||
formRef.value?.validate(async (valid: boolean) => {
|
||||
if (!valid) return
|
||||
form.harmStart = form.harmSlider[0]
|
||||
form.harmEnd = form.harmSlider[1]
|
||||
form.phaseType = form.phaseList.join(',')
|
||||
const payload = { ...form }
|
||||
try {
|
||||
if (isEdit()) {
|
||||
await update(payload)
|
||||
ElMessage.success('修改成功!')
|
||||
} else {
|
||||
await save({ ...payload, id: '' })
|
||||
ElMessage.success('新增成功!')
|
||||
}
|
||||
dialogVisible.value = false
|
||||
emit('Cancels')
|
||||
} catch {
|
||||
/* 统一错误提示 */
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
defineExpose({ open })
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.form-item-full {
|
||||
grid-column: 1 / -1;
|
||||
}
|
||||
</style>
|
||||
193
src/views/govern/alarm/scopeConfig/index.vue
Normal file
193
src/views/govern/alarm/scopeConfig/index.vue
Normal file
@@ -0,0 +1,193 @@
|
||||
<template>
|
||||
<div class="default-main">
|
||||
<TableHeader ref="TableHeaderRef">
|
||||
<template #select>
|
||||
<el-form-item label="数据来源">
|
||||
<el-select v-model="tableStore.table.params.dataSource" clearable placeholder="请选择数据来源">
|
||||
<el-option v-for="item in dataSourceOptions" :key="item.value" :label="item.label"
|
||||
:value="item.value" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="系统类型">
|
||||
<el-select v-model="tableStore.table.params.systemType" clearable placeholder="请选择系统类型">
|
||||
<el-option v-for="item in systemTypeOptions" :key="item.value" :label="item.label"
|
||||
:value="item.value" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="表名">
|
||||
<el-input v-model.trim="tableStore.table.params.tableName" placeholder="请输入表名" clearable
|
||||
maxlength="64" />
|
||||
</el-form-item>
|
||||
</template>
|
||||
<template #operation>
|
||||
<el-button icon="el-icon-Plus" type="primary" @click="add">新增</el-button>
|
||||
</template>
|
||||
</TableHeader>
|
||||
<Table ref="tableRef" />
|
||||
<Form ref="formRef" @Cancels="tableStore.index()" />
|
||||
</div>
|
||||
</template>
|
||||
<script setup lang="ts">
|
||||
import { ref, onMounted, provide, nextTick } from 'vue'
|
||||
import TableStore from '@/utils/tableStore'
|
||||
import Table from '@/components/table/index.vue'
|
||||
import TableHeader from '@/components/table/header/index.vue'
|
||||
import { ElMessage } from 'element-plus'
|
||||
import { pqDelete } from '@/api/algorithm-boot/scopeConfig'
|
||||
import Form from './form.vue'
|
||||
defineOptions({
|
||||
name: 'govern/alarmConfig'
|
||||
})
|
||||
const dataSourceOptions = [
|
||||
{ label: 'InfluxDB', value: 'InfluxDB' },
|
||||
// { label: 'oracle', value: 'oracle' },
|
||||
{ label: 'MySql', value: 'MySql' }
|
||||
]
|
||||
const systemTypeOptions = [
|
||||
{ label: 'pqs', value: 'pqs' },
|
||||
{ label: 'govern', value: 'govern' }
|
||||
]
|
||||
const yesNo = (v: number) => (v === 1 ? '是' : v === 0 ? '否' : '/')
|
||||
const stateMap: Record<number, string> = { 0: '删除', 1: '正常' }
|
||||
const formRef = ref()
|
||||
const tableStore: any = new TableStore({
|
||||
url: '/algorithm-boot/pqReasonableRange/getData',
|
||||
method: 'POST',
|
||||
showPage: false,
|
||||
column: [
|
||||
{
|
||||
field: 'index',
|
||||
title: '序号',
|
||||
width: '80',
|
||||
formatter: (row: any) => {
|
||||
return (tableStore.table.params.pageNum - 1) * tableStore.table.params.pageSize + row.rowIndex + 1
|
||||
}
|
||||
},
|
||||
{ field: 'indexName', title: '指标名称', minWidth: 200 },
|
||||
{ field: 'indexCode', title: '指标code', minWidth: 150 },
|
||||
|
||||
{ field: 'influxdbTableName', title: '表名', minWidth: 150 },
|
||||
{ field: 'influxdbColumnName', title: '列属性', minWidth: 150 },
|
||||
{
|
||||
field: 'harmStart', title: '谐波次数', width: 90,
|
||||
formatter: (row: any) => {
|
||||
return row.cellValue == null ? '/' : row.cellValue + '-' + row.row.harmEnd
|
||||
}
|
||||
},
|
||||
{
|
||||
field: 'phaseType', title: '相别', width: 100, formatter: (row: any) => {
|
||||
return row.cellValue == 'T' ? '/' : row.cellValue
|
||||
|
||||
|
||||
}
|
||||
},
|
||||
{ field: 'minValue', title: '指标下限', width: 100 },
|
||||
{ field: 'maxValue', title: '指标上限', width: 100 },
|
||||
{
|
||||
field: 'isVoltage',
|
||||
title: '电压等级参与',
|
||||
width: 110,
|
||||
formatter: (row: any) => yesNo(row.cellValue)
|
||||
},
|
||||
{
|
||||
field: 'ctAttendFlag',
|
||||
title: 'Ct变比参与',
|
||||
width: 100,
|
||||
formatter: (row: any) => yesNo(row.cellValue)
|
||||
},
|
||||
{ field: 'dataSource', title: '数据来源', width: 100 },
|
||||
{ field: 'belongingSystem', title: '所属系统', width: 100 },
|
||||
|
||||
|
||||
{
|
||||
field: 'unit', title: '单位', width: 80,
|
||||
formatter: (row: any) => {
|
||||
return row.cellValue || '/'
|
||||
}
|
||||
},
|
||||
{ field: 'sort', title: '排序', width: 70 },
|
||||
{
|
||||
field: 'otherAlgorithm', title: '条件描述', minWidth: 200,
|
||||
formatter: (row: any) => {
|
||||
return row.cellValue || '/'
|
||||
}
|
||||
},
|
||||
{
|
||||
field: 'remark', title: '备注', minWidth: 200,
|
||||
formatter: (row: any) => {
|
||||
return row.cellValue || '/'
|
||||
}
|
||||
},
|
||||
|
||||
{
|
||||
title: '操作',
|
||||
fixed: 'right',
|
||||
width: '180',
|
||||
render: 'buttons',
|
||||
buttons: [
|
||||
|
||||
{
|
||||
name: 'edit',
|
||||
title: '修改 ',
|
||||
type: 'primary',
|
||||
icon: 'el-icon-Plus',
|
||||
render: 'basicButton',
|
||||
click: row => {
|
||||
setTimeout(() => {
|
||||
formRef.value.open({
|
||||
text: '修改配置',
|
||||
row: row
|
||||
})
|
||||
}, 10)
|
||||
}
|
||||
},
|
||||
{
|
||||
name: 'edit',
|
||||
title: '删除',
|
||||
type: 'danger',
|
||||
icon: 'el-icon-Delete',
|
||||
render: 'confirmButton',
|
||||
disabled: row => {
|
||||
return row.active == 1
|
||||
},
|
||||
popconfirm: {
|
||||
confirmButtonText: '确认',
|
||||
cancelButtonText: '取消',
|
||||
confirmButtonType: 'danger',
|
||||
title: '确定删除吗?'
|
||||
},
|
||||
click: row => {
|
||||
pqDelete({ id: row.id }).then(res => {
|
||||
ElMessage({
|
||||
message: '删除成功!',
|
||||
type: 'success'
|
||||
})
|
||||
tableStore.index()
|
||||
})
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
],
|
||||
|
||||
loadCallback: () => {
|
||||
|
||||
|
||||
}
|
||||
})
|
||||
tableStore.table.params.dataSource = ''
|
||||
tableStore.table.params.tableName = ''
|
||||
tableStore.table.params.systemType = ''
|
||||
provide('tableStore', tableStore)
|
||||
// 新增主题
|
||||
const add = () => {
|
||||
setTimeout(() => {
|
||||
formRef.value.open({
|
||||
text: '新增配置'
|
||||
})
|
||||
}, 10)
|
||||
}
|
||||
onMounted(() => {
|
||||
tableStore.index()
|
||||
})
|
||||
</script>
|
||||
@@ -182,7 +182,7 @@ const tableStore: any = new TableStore({
|
||||
icon: 'el-icon-Check',
|
||||
render: 'basicButton',
|
||||
disabled: row => {
|
||||
return (props.deviceType === '2' && row.wavePath) || row.showName === '未知'
|
||||
return !(props.deviceType === '2' && row.wavePath) || row.showName === '未知'
|
||||
},
|
||||
click: row => {
|
||||
getFileByEventId(row.id).then(res => {
|
||||
|
||||
@@ -3,47 +3,22 @@
|
||||
<TableHeader>
|
||||
<template #select>
|
||||
<el-form-item label="数据分类">
|
||||
<el-select
|
||||
v-model.trim="tableStore.table.params.dataType"
|
||||
multiple
|
||||
filterable
|
||||
collapse-tags
|
||||
clearable
|
||||
placeholder="请选择数据分类"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in DataTypeSelect"
|
||||
:key="item.id"
|
||||
:label="item.name"
|
||||
:value="item.id"
|
||||
></el-option>
|
||||
<el-select v-model.trim="tableStore.table.params.dataType" multiple filterable collapse-tags
|
||||
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="数据存储">
|
||||
<el-select
|
||||
v-model.trim="tableStore.table.params.classId"
|
||||
multiple
|
||||
filterable
|
||||
collapse-tags
|
||||
clearable
|
||||
placeholder="请选择数据存储"
|
||||
>
|
||||
<el-option
|
||||
v-for="item in DataSelect"
|
||||
:key="item.id"
|
||||
:label="item.name"
|
||||
:value="item.id"
|
||||
></el-option>
|
||||
<el-select v-model.trim="tableStore.table.params.classId" multiple filterable collapse-tags
|
||||
clearable placeholder="请选择数据存储">
|
||||
<el-option v-for="item in DataSelect" :key="item.id" :label="item.name"
|
||||
:value="item.id"></el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="关键字筛选">
|
||||
<el-input
|
||||
maxlength="32"
|
||||
show-word-limit
|
||||
v-model.trim="tableStore.table.params.searchValue"
|
||||
placeholder="数据名称、别名、展示名称"
|
||||
clearable
|
||||
></el-input>
|
||||
<el-input maxlength="32" show-word-limit v-model.trim="tableStore.table.params.searchValue"
|
||||
placeholder="数据名称、别名、展示名称" clearable></el-input>
|
||||
</el-form-item>
|
||||
</template>
|
||||
<template #operation>
|
||||
@@ -99,8 +74,9 @@ const tableStore = new TableStore({
|
||||
? row.cellValue == '/'
|
||||
? '/'
|
||||
: row.cellValue == 'M'
|
||||
? '无相别'
|
||||
: row.cellValue + '相'
|
||||
? '/' : row.cellValue == 'T'
|
||||
? '/'
|
||||
: row.cellValue + '相'
|
||||
: '/'
|
||||
}
|
||||
},
|
||||
@@ -114,7 +90,7 @@ const tableStore = new TableStore({
|
||||
title: '操作', fixed: 'right',
|
||||
align: 'center',
|
||||
width: '180',
|
||||
|
||||
|
||||
render: 'buttons',
|
||||
buttons: [
|
||||
{
|
||||
|
||||
@@ -1,10 +1,10 @@
|
||||
<template>
|
||||
<el-dialog class="cn-operate-dialog" draggable v-model.trim="dialogVisible" :title="title" @close="emit('close')">
|
||||
<el-dialog class="cn-operate-dialog" draggable v-model.trim="dialogVisible" width="900px" :title="title" @close="emit('close')">
|
||||
<el-scrollbar>
|
||||
<div style="padding-left: 50px">
|
||||
<el-divider content-position="center">基础数据</el-divider>
|
||||
</div>
|
||||
<el-form :model="form" label-width="140px" ref="formRef" class="form-two" :rules="rules">
|
||||
<el-form :model="form" label-width="130px" ref="formRef" class="form-two" :rules="rules">
|
||||
<el-form-item label="数据分类:" prop="dataType">
|
||||
<el-select v-model.trim="form.dataType" filterable clearable placeholder="请选择数据分类">
|
||||
<el-option
|
||||
@@ -71,7 +71,7 @@
|
||||
></el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="开始结束次数:">
|
||||
<el-slider v-model.trim="form.harm" range show-stops :max="50" style="width: 95%" />
|
||||
<el-slider v-model.trim="form.harm" range :max="50" style="width: 90%" />
|
||||
</el-form-item>
|
||||
<el-form-item label="统计方法:">
|
||||
<el-select
|
||||
@@ -155,7 +155,7 @@
|
||||
<div style="padding-left: 50px">
|
||||
<el-divider content-position="center">拓展数据</el-divider>
|
||||
</div>
|
||||
<el-form class="form-two" :model="form" label-width="140px" ref="formRef2">
|
||||
<el-form class="form-two" :model="form" label-width="130px" ref="formRef2">
|
||||
<el-form-item label="告警码(缺省值):">
|
||||
<el-input
|
||||
maxlength="32"
|
||||
@@ -282,7 +282,7 @@ const phaseSelect = [
|
||||
id: 'C'
|
||||
},
|
||||
{
|
||||
name: 'T相',
|
||||
name: '无相别',
|
||||
id: 'T'
|
||||
},
|
||||
{
|
||||
@@ -297,10 +297,10 @@ const phaseSelect = [
|
||||
name: 'CA相',
|
||||
id: 'CA'
|
||||
},
|
||||
{
|
||||
name: '无相别',
|
||||
id: 'M'
|
||||
},
|
||||
// {
|
||||
// name: '无相别',
|
||||
// id: 'M'
|
||||
// },
|
||||
]
|
||||
const StatMethodSelect = [
|
||||
{
|
||||
|
||||
@@ -722,7 +722,7 @@ const tableStore = new TableStore({
|
||||
},
|
||||
{
|
||||
name: 'edit',
|
||||
title: '重启',
|
||||
title: '重置',
|
||||
type: 'primary',
|
||||
icon: 'el-icon-EditPen',
|
||||
render: 'basicButton',
|
||||
@@ -731,7 +731,7 @@ const tableStore = new TableStore({
|
||||
resetFactory({
|
||||
nDid: row.ndid
|
||||
}).then(res => {
|
||||
ElMessage.success('重启成功!')
|
||||
ElMessage.success('重置成功!')
|
||||
tableStore.onTableAction('search', {})
|
||||
})
|
||||
}
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
<template>
|
||||
<el-dialog class="cn-operate-dialog" width="600px" v-model.trim="dialogVisible" :title="title">
|
||||
<el-dialog class="cn-operate-dialog" width="500px" 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>
|
||||
|
||||
@@ -60,7 +60,7 @@ const tableStore = new TableStore({
|
||||
{
|
||||
title: '类型',
|
||||
field: 'type',
|
||||
width: 200,
|
||||
width: 250,
|
||||
formatter: row => {
|
||||
return options.value.filter((item: any) => item.value == row.cellValue)[0]?.name
|
||||
}
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
<template>
|
||||
<el-dialog width="600px" v-model.trim="dialogVisible" :title="title">
|
||||
<el-dialog width="500px" v-model.trim="dialogVisible" :title="title">
|
||||
<el-scrollbar>
|
||||
<el-form :inline="false" :model="form" label-width="auto" class="form-one" :rules="rules" ref="formRef">
|
||||
<el-form-item label="名称:" class="top" prop="name">
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
<template>
|
||||
<el-dialog class="cn-operate-dialog" width="500px" v-model.trim="dialogVisible" :title="title">
|
||||
<el-scrollbar>
|
||||
<el-form :inline="false" :model="form" ref="formRef" label-width="120px" :rules="rules">
|
||||
<el-form :inline="false" :model="form" ref="formRef" label-width="auto" :rules="rules">
|
||||
<el-form-item label="字典名称:" prop="name">
|
||||
<el-input
|
||||
maxlength="32"
|
||||
|
||||
@@ -27,7 +27,7 @@
|
||||
></vxe-column>
|
||||
</template>
|
||||
</Table>
|
||||
<el-dialog width="600px" v-model.trim="dialogVisible" title="新增版本">
|
||||
<el-dialog width="500px" v-model.trim="dialogVisible" title="新增版本">
|
||||
<el-form :inline="false" :model="form" ref="formRef" label-width="auto" class="form-one" :rules="rules">
|
||||
<el-form-item label="版本号:" prop="appVersion">
|
||||
<el-input
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
<template>
|
||||
<el-dialog draggable width="600px" v-model="dialogVisible" :title="title">
|
||||
<el-dialog draggable width="500px" v-model="dialogVisible" :title="title">
|
||||
|
||||
<el-form :inline="false" :model="form" label-width="auto" class="form-one" :rules="rules" ref="formRef">
|
||||
<el-form-item label="任务名称" prop="timerName">
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
<template>
|
||||
<el-dialog draggable v-model.trim="dialogVisible" :title="title" :before-close="Cancel">
|
||||
<el-dialog draggable v-model.trim="dialogVisible" :title="title" width="800px" :before-close="Cancel">
|
||||
<el-form :inline="false" :model="configStore" ref="formRef" label-width="auto" :rules="rules">
|
||||
<el-divider border-style="dashed">全局</el-divider>
|
||||
<div class="layout-config-global form-two">
|
||||
|
||||
Reference in New Issue
Block a user