|
@@ -14,10 +14,18 @@
|
|
<el-input v-model="formData.deviceName" disabled />
|
|
<el-input v-model="formData.deviceName" disabled />
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<el-form-item label="告警属性" prop="alarmProperty">
|
|
<el-form-item label="告警属性" prop="alarmProperty">
|
|
- <el-input v-model="formData.alarmProperty" placeholder="请输入告警属性" />
|
|
|
|
|
|
+<!-- <el-input v-model="formData.alarmProperty" placeholder="请输入告警属性" />-->
|
|
|
|
+ <el-select v-model="formData.alarmProperty" placeholder="请选择告警属性" clearable filterable @change="propertyChange">
|
|
|
|
+ <el-option
|
|
|
|
+ v-for="dict in specs"
|
|
|
|
+ :key="dict.identifier"
|
|
|
|
+ :label="dict.modelName"
|
|
|
|
+ :value="dict.modelName"
|
|
|
|
+ />
|
|
|
|
+ </el-select>
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<el-form-item label="属性标识" prop="propertyCode">
|
|
<el-form-item label="属性标识" prop="propertyCode">
|
|
- <el-input v-model="formData.propertyCode" placeholder="请输入属性标识" />
|
|
|
|
|
|
+ <el-input v-model="formData.propertyCode" placeholder="请输入属性标识" disabled />
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<el-form-item label="上限值" prop="maxValue">
|
|
<el-form-item label="上限值" prop="maxValue">
|
|
<el-input v-model="formData.maxValue" placeholder="请输入上限" />
|
|
<el-input v-model="formData.maxValue" placeholder="请输入上限" />
|
|
@@ -34,6 +42,8 @@
|
|
</template>
|
|
</template>
|
|
<script setup lang="ts">
|
|
<script setup lang="ts">
|
|
import { IotAlarmSettingApi, IotAlarmSettingVO } from '@/api/pms/alarm'
|
|
import { IotAlarmSettingApi, IotAlarmSettingVO } from '@/api/pms/alarm'
|
|
|
|
+import {IotDeviceApi} from "@/api/pms/device";
|
|
|
|
+import {DICT_TYPE, getStrDictOptions} from "@/utils/dict";
|
|
|
|
|
|
/** 告警设置 表单 */
|
|
/** 告警设置 表单 */
|
|
defineOptions({ name: 'IotAlarmSettingForm' })
|
|
defineOptions({ name: 'IotAlarmSettingForm' })
|
|
@@ -45,6 +55,7 @@ const dialogVisible = ref(false) // 弹窗的是否展示
|
|
const dialogTitle = ref('') // 弹窗的标题
|
|
const dialogTitle = ref('') // 弹窗的标题
|
|
const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
|
|
const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
|
|
const formType = ref('') // 表单的类型:create - 新增;update - 修改
|
|
const formType = ref('') // 表单的类型:create - 新增;update - 修改
|
|
|
|
+const specs = ref([])
|
|
const formData = ref({
|
|
const formData = ref({
|
|
id: undefined,
|
|
id: undefined,
|
|
classifyId: undefined,
|
|
classifyId: undefined,
|
|
@@ -54,13 +65,14 @@ const formData = ref({
|
|
maxValue: undefined,
|
|
maxValue: undefined,
|
|
minValue: undefined,
|
|
minValue: undefined,
|
|
alarmProperty: undefined,
|
|
alarmProperty: undefined,
|
|
|
|
+ propertyCode: undefined,
|
|
})
|
|
})
|
|
const formRules = reactive({
|
|
const formRules = reactive({
|
|
classifyName: [{ required: true, message: '分类不能为空', trigger: 'blur' }],
|
|
classifyName: [{ required: true, message: '分类不能为空', trigger: 'blur' }],
|
|
alarmProperty: [{ required: true, message: '告警属性不能为空', trigger: 'blur' }],
|
|
alarmProperty: [{ required: true, message: '告警属性不能为空', trigger: 'blur' }],
|
|
propertyCode: [{ required: true, message: '属性标识不能为空', trigger: 'blur' }],
|
|
propertyCode: [{ required: true, message: '属性标识不能为空', trigger: 'blur' }],
|
|
- maxValue: [{ required: true, message: '上限不能为空', trigger: 'blur' }],
|
|
|
|
- minValue: [{ required: true, message: '下限不能为空', trigger: 'blur' }],
|
|
|
|
|
|
+ // maxValue: [{ required: true, message: '上限不能为空', trigger: 'blur' }],
|
|
|
|
+ // minValue: [{ required: true, message: '下限不能为空', trigger: 'blur' }],
|
|
})
|
|
})
|
|
const formRef = ref() // 表单 Ref
|
|
const formRef = ref() // 表单 Ref
|
|
const ifDevice = ref(false)
|
|
const ifDevice = ref(false)
|
|
@@ -87,6 +99,14 @@ const open = async (type: string, id?: number,classId:any, className:any,deviceI
|
|
formLoading.value = false
|
|
formLoading.value = false
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
+ if (deviceId) {
|
|
|
|
+ await IotDeviceApi.getIotDeviceTds(deviceId).then(res => {
|
|
|
|
+ specs.value = res
|
|
|
|
+ specs.value = specs.value.sort((a, b) => {
|
|
|
|
+ return b.modelOrder - a.modelOrder
|
|
|
|
+ })
|
|
|
|
+ })
|
|
|
|
+ }
|
|
}
|
|
}
|
|
defineExpose({ open }) // 提供 open 方法,用于打开弹窗
|
|
defineExpose({ open }) // 提供 open 方法,用于打开弹窗
|
|
|
|
|
|
@@ -114,6 +134,12 @@ const submitForm = async () => {
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+const propertyChange = (value) =>{
|
|
|
|
+ debugger
|
|
|
|
+ const model = specs.value.filter((item) => item.modelName === value)
|
|
|
|
+ formData.value.propertyCode = model[0].identifier
|
|
|
|
+}
|
|
|
|
+
|
|
/** 重置表单 */
|
|
/** 重置表单 */
|
|
const resetForm = () => {
|
|
const resetForm = () => {
|
|
formData.value = {
|
|
formData.value = {
|