Files
admin-sjzx/src/views/pqs/runManage/assessment/components/uese/addform.vue

152 lines
6.0 KiB
Vue
Raw Normal View History

2025-03-31 14:33:05 +08:00
<template>
<el-dialog draggable width="800px" v-model="dialogVisible" :title="title">
<el-scrollbar>
2025-06-17 15:48:22 +08:00
<el-form :inline="false" ref="formRef" :model="form" label-width="auto" :rules="rules" class="form-two">
<!-- 变压器参数维护 -->
<el-form-item v-for="(item, index) in child" :key="index" :label="item.title" :prop="item.field">
<el-select
v-if="item.field == 'transtypeId'"
v-model="form[item.field]"
filterable
clearable
placeholder="请选择接入变电站"
>
<el-option
v-for="item in transformer"
:key="item.transtypeId"
:label="item.transtypeName"
:value="item.transtypeId"
></el-option>
</el-select>
2025-06-18 16:39:28 +08:00
2025-06-17 15:48:22 +08:00
<el-input-number
2025-06-18 16:39:28 +08:00
v-else-if="
item.field == 'transNum' ||
item.field == 'capacitorNum' ||
item.field == 'capacitorCapacity' ||
item.field == 'capacitorReactance'
"
2025-06-17 15:48:22 +08:00
style="width: 100%"
v-model="form[item.field]"
show-word-limit
placeholder="请输入值"
></el-input-number>
2025-06-18 16:39:28 +08:00
<el-select
v-else-if="item.field == 'capacitorScale'"
v-model="form[item.field]"
filterable
placeholder="请选择接入变电站"
>
<el-option
v-for="item in voltageleveloption"
:key="item.id"
:label="item.name"
:value="item.id"
></el-option>
</el-select>
2025-06-17 15:48:22 +08:00
<el-input v-else v-model.trim="form[item.field]" placeholder="请输入内容" />
2025-03-31 14:33:05 +08:00
</el-form-item>
</el-form>
</el-scrollbar>
<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'
2025-06-18 16:39:28 +08:00
import { useDictData } from '@/stores/dictData'
import {
transformerList,
assessTransformerParamAdd,
assessTransformerParamEdit,
capacitorAdd,
capacitorEdit
} from '@/api/advance-boot/assess'
2025-06-17 15:48:22 +08:00
import { ElMessage, ElMessageBox, ElDatePicker } from 'element-plus'
2025-06-18 16:39:28 +08:00
const emits = defineEmits(['init'])
2025-03-31 14:33:05 +08:00
const child: any = ref([])
2025-06-17 15:48:22 +08:00
const transformer: any = ref([])
2025-06-18 16:39:28 +08:00
const form: any = ref({})
const dictData = useDictData()
//字典获取电压等级
const voltageleveloption = dictData.getBasicData('Dev_Voltage_Stand')
2025-06-17 15:48:22 +08:00
const rules = {
transName: [{ required: true, message: '请输入用户变压器名称', trigger: 'blur' }],
transtypeId: [{ required: true, message: '请选择变压器型号', trigger: 'change' }],
2025-06-18 16:39:28 +08:00
transNum: [{ required: true, message: '请输入变压器台数', trigger: 'blur' }],
capacitorName: [{ required: true, message: '请输入用户电容器名称', trigger: 'blur' }],
capacitorNum: [{ required: true, message: '请输入电容器组数量', trigger: 'blur' }],
capacitorCapacity: [{ required: true, message: '请输入单组容量', trigger: 'blur' }],
capacitorReactance: [{ required: true, message: '请输入电抗率', trigger: 'blur' }],
capacitorScale: [{ required: true, message: '请选择电压等级', trigger: 'change' }],
2025-06-17 15:48:22 +08:00
}
const formRef = ref()
2025-03-31 14:33:05 +08:00
const dialogVisible = ref(false)
2025-06-17 15:48:22 +08:00
const title = ref('')
2025-03-31 14:33:05 +08:00
const open = (row: any) => {
2025-06-18 16:39:28 +08:00
console.log('🚀 ~ open ~ row:', row)
2025-06-17 15:48:22 +08:00
info()
2025-03-31 14:33:05 +08:00
title.value = row.title + `_${row.item.name}`
child.value = row.item.child
2025-06-17 15:48:22 +08:00
2025-03-31 14:33:05 +08:00
if (row.title == '新增') {
row.item.child.forEach((item: any) => {
2025-06-18 16:39:28 +08:00
form.value[item.field] = ''
2025-03-31 14:33:05 +08:00
})
2025-06-18 16:39:28 +08:00
form.value.assessId = row.assessId
2025-03-31 14:33:05 +08:00
} else {
row.item.child.forEach((item: any) => {
2025-06-18 16:39:28 +08:00
form.value = JSON.parse(JSON.stringify(row.row))
2025-03-31 14:33:05 +08:00
})
}
2025-06-18 16:39:28 +08:00
2025-03-31 14:33:05 +08:00
dialogVisible.value = true
}
2025-06-17 15:48:22 +08:00
const info = async () => {
// 获取变压器参数字典列表
transformerList({}).then((res: any) => {
transformer.value = res.data
})
}
2025-03-31 14:33:05 +08:00
const submit = async () => {
2025-06-17 15:48:22 +08:00
formRef.value.validate((valid: any) => {
if (valid) {
2025-06-18 16:39:28 +08:00
if (title.value == '新增_变压器参数维护') {
assessTransformerParamAdd(form.value).then((res: any) => {
2025-06-17 15:48:22 +08:00
ElMessage.success('新增成功')
2025-06-18 16:39:28 +08:00
emits('init', 0)
dialogVisible.value = false
})
} else if (title.value == '编辑_变压器参数维护') {
assessTransformerParamEdit(form.value).then((res: any) => {
ElMessage.success('修改成功')
emits('init', 0)
dialogVisible.value = false
})
} else if (title.value == '新增_电容器组参数维护') {
capacitorAdd(form.value).then((res: any) => {
ElMessage.success('新增成功')
emits('init', 1)
dialogVisible.value = false
})
} else if (title.value == '编辑_电容器组参数维护') {
capacitorEdit(form.value).then((res: any) => {
ElMessage.success('修改成功')
emits('init', 1)
2025-06-17 15:48:22 +08:00
dialogVisible.value = false
})
2025-06-18 16:39:28 +08:00
}
2025-06-17 15:48:22 +08:00
}
})
2025-03-31 14:33:05 +08:00
}
defineExpose({ open })
</script>