Newer
Older
xc-metering-front / src / views / laboratory / alarm / event / addEventDialog.vue
dutingting on 29 Nov 8 KB 临时提交
<!-- 新增事件弹窗 -->
<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>