<!-- 新增事件弹窗 --> <script lang="ts" setup name="addNotice"> import type { FormInstance, FormRules } from 'element-plus' import { ElLoading, ElMessage } from 'element-plus' import type { IForm, IList } from './list-interface' import { addEventList, updateEventList } from '@/api/laboratory/alarm/event' import useUserStore from '@/store/modules/user' import { getDictByCode } from '@/api/system/dict' import type { deptType, dictType } from '@/global' const emits = defineEmits(['refresh']) const textMap: { [key: string]: string } = { edit: '编辑', add: '新建', detail: '详情', }// 字典 const user = useUserStore() // 用户信息 const ruleFormRef = ref<FormInstance>() // from组件 const form = ref<IForm>({ createUser: '', // 创建人 createUserId: '', // 创建人id deviceType: '', // 智能模型类型(字典code) eventDesc: '', // 事件描述 eventName: '', // 事件名称 eventNo: '', // 事件编号 firstLevelAlarm: 0, // 一级报警(%) secondLevelAlarm: 0, // 二级报警(%) thirdLevelAlarm: 0, // 三级报警(%) }) // 表单 const rules = ref<FormRules>({ deviceType: [{ required: true, message: '智能模型类型不能为空', trigger: 'blur' }], eventNo: [{ required: true, message: '事件编号不能为空', trigger: 'blur' }], eventName: [{ required: true, message: '事件名称不能为空', trigger: 'blur' }], firstLevelAlarm: [{ required: true, message: '一级报警不能为空', trigger: 'blur' }], secondLevelAlarm: [{ required: true, message: '二级报警不能为空', trigger: 'blur' }], thirdLevelAlarm: [{ required: true, message: '三级报警不能为空', trigger: 'blur' }], }) // 表单验证规则 const dialogVisible = ref(false) // 弹窗显示 const pageType = ref('') // 页面类型 add新增、edit编辑 const infoId = ref('') // id,主键 const loading = ref(false) // -------------------------------------------字典------------------------------------------ const typeList = ref<dictType[]>([]) // 智能模型类型 // 获取字典值 async function getDict() { // 智能模型类型 getDictByCode('deviceType').then((response) => { typeList.value = response.data }) } getDict() // ----------------------------------------方法------------------------------------------------- // 清空表单 const clear = () => { form.value = { createUser: '', // 创建人 createUserId: '', // 创建人id deviceType: '', // 智能模型类型(字典code) eventDesc: '', // 事件描述 eventName: '', // 事件名称 eventNo: '', // 事件编号 firstLevelAlarm: 0, // 一级报警(%) secondLevelAlarm: 0, // 二级报警(%) thirdLevelAlarm: 0, // 三级报警(%) } } // 弹窗初始化 const initDialog = (pageTypeParam = 'detail', row: IList) => { dialogVisible.value = true // 打开弹窗 pageType.value = pageTypeParam // 页面类型 form.value.createUserId = user.id// 创建人id form.value.createUser = user.name // 创建人名字 if (pageTypeParam === 'edit' || pageTypeParam === 'detail') { // 编辑时初始化数据 form.value.deviceType = row.deviceType // 智能模型类型(字典code) form.value.eventDesc = row.eventDesc // 事件描述 form.value.eventName = row.eventName // 事件名称 form.value.eventNo = row.eventNo // 事件编号 form.value.firstLevelAlarm = row.firstLevelAlarm // 一级报警(%) form.value.secondLevelAlarm = row.secondLevelAlarm // 二级报警(%) form.value.thirdLevelAlarm = row.thirdLevelAlarm // 三级报警(%) infoId.value = row.id // 主键 } else if (pageTypeParam === 'add') { clear() infoId.value = '' // 主键 } } // 提交 const submitForm = async (formEl: FormInstance | undefined) => { ruleFormRef.value!.validate((valid: boolean) => { if (valid) { const params = { ...form.value, id: infoId.value, } loading.value = true // 新建 if (pageType.value === 'add') { // 新建 addEventList(params).then((res) => { ElMessage.success('保存成功') pageType.value = 'detail' loading.value = false resetForm(ruleFormRef.value) emits('refresh') }).catch(() => { loading.value = false resetForm(ruleFormRef.value) }) } // 保存 else if (pageType.value === 'edit') { // 编辑 updateEventList(params).then((res) => { ElMessage.success('保存成功') pageType.value = 'detail' loading.value = false emits('refresh') resetForm(ruleFormRef.value) }).catch(() => { loading.value = false resetForm(ruleFormRef.value) }) } } else { console.log('表单校验不通过') } }) } // 取消 function resetForm(formEl: FormInstance | undefined) { formEl?.resetFields() dialogVisible.value = false } defineExpose({ initDialog }) </script> <template> <el-dialog v-if="dialogVisible" v-model="dialogVisible" :title="`事件管理-${textMap[pageType]}`" append-to-body width="600px" class="container" @close="resetForm"> <el-form ref="ruleFormRef" v-loading="loading" :model="form" :rules="rules" label-position="right" label-width="110px"> <el-form-item label="智能模型类型:" prop="deviceType"> <el-select v-model.trim="form.deviceType" clearable :placeholder="pageType === 'detail' ? '' : '请选择智能模型类型'" size="default" :disabled="pageType === 'detail'" class="full-width-input" > <el-option v-for="item in typeList" :key="item.id" :label="item.name" :value="item.value" /> </el-select> </el-form-item> <el-form-item label="事件编号:" prop="eventNo"> <el-input v-model="form.eventNo" :disabled="pageType === 'detail'" placeholder="请输入地点编号" /> </el-form-item> <el-form-item label="事件名称:" prop="eventName"> <el-input v-model="form.eventName" :disabled="pageType === 'detail'" placeholder="请输入地点名称" /> </el-form-item> <el-form-item label="一级报警(%):" prop="firstLevelAlarm"> <el-input-number v-model="form.firstLevelAlarm" :placeholder="pageType === 'detail' ? '' : '一级报警(%)'" :disabled="pageType === 'detail'" :min="0" :max="100" /> </el-form-item> <el-form-item label="二级报警(%):" prop="secondLevelAlarm"> <el-input-number v-model="form.secondLevelAlarm" :placeholder="pageType === 'detail' ? '' : '二级报警(%)'" :disabled="pageType === 'detail'" :min="0" :max="100" /> </el-form-item> <el-form-item label="三级报警(%):" prop="thirdLevelAlarm"> <el-input-number v-model="form.thirdLevelAlarm" :placeholder="pageType === 'detail' ? '' : '三级报警(%)'" :disabled="pageType === 'detail'" :min="0" :max="100" /> </el-form-item> <el-form-item label="事件描述:" prop="eventDesc"> <el-input v-model="form.eventDesc" type="textarea" autosize :disabled="pageType === 'detail'" placeholder="请输入地点编号" /> </el-form-item> </el-form> <template #footer> <div class="dialog-footer footer"> <el-button v-if="pageType !== 'detail'" :loading="loading" type="primary" @click="submitForm(ruleFormRef)"> 确定 </el-button> <el-button :disabled="loading" type="info" @click="resetForm(ruleFormRef)"> 关闭 </el-button> </div> </template> </el-dialog> </template> <style lang="scss" scoped> .container { .isDetail { ::v-deep { .el-form-item.is-required:not(.is-no-asterisk) .el-form-item__label-wrap > .el-form-item__label::before, .el-form-item.is-required:not(.is-no-asterisk) > .el-form-item__label::before { content: ""; display: none; } } } .center { display: flex; align-items: flex-end; } } </style>