|
|
|
|
@ -1,6 +1,6 @@
|
|
|
|
|
<template>
|
|
|
|
|
<el-dialog :title="title" v-model="dialogOpen" width="600px" append-to-body>
|
|
|
|
|
<el-form :model="props.form" :rules="rules" ref="deviceRef" label-width="80px">
|
|
|
|
|
<el-form :model="form" :rules="rules" ref="deviceRef" label-width="80px">
|
|
|
|
|
<el-row :gutter="10">
|
|
|
|
|
<el-col :span="24">
|
|
|
|
|
<el-form-item label="设备图片" prop="imgUrl">
|
|
|
|
|
@ -9,46 +9,46 @@
|
|
|
|
|
</el-col>
|
|
|
|
|
<el-col :span="12">
|
|
|
|
|
<el-form-item label="设备类型" prop="type">
|
|
|
|
|
<el-select v-model="props.form.type" placeholder="请选择设备类型" clearable style="width: 200px">
|
|
|
|
|
<el-select v-model="form.type" placeholder="请选择设备类型" clearable style="width: 200px">
|
|
|
|
|
<el-option v-for="dict in deviceTypes" :key="dict.value" :label="dict.label" :value="dict.value" />
|
|
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-col>
|
|
|
|
|
<el-col :span="12">
|
|
|
|
|
<el-form-item label="设备号" prop="deviceNo">
|
|
|
|
|
<el-input v-model="props.form.deviceNo" placeholder="请输入设备号" maxlength="100" />
|
|
|
|
|
<el-input v-model="form.deviceNo" placeholder="请输入设备号" maxlength="100" />
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-col>
|
|
|
|
|
<el-col :span="12">
|
|
|
|
|
<el-form-item label="设备型号" prop="model">
|
|
|
|
|
<el-input v-model="props.form.model" placeholder="请输入设备型号" maxlength="50" />
|
|
|
|
|
<el-input v-model="form.model" placeholder="请输入设备型号" maxlength="50" />
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-col>
|
|
|
|
|
<el-col :span="12">
|
|
|
|
|
<el-form-item label="设备地址" prop="deviceAddr">
|
|
|
|
|
<el-input v-model="props.form.deviceAddr" placeholder="请输入设备地址" maxlength="100" />
|
|
|
|
|
<el-input v-model="form.deviceAddr" placeholder="请输入设备地址" maxlength="100" />
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-col>
|
|
|
|
|
<el-col :span="12">
|
|
|
|
|
<el-form-item label="设备点位" prop="installPointDes">
|
|
|
|
|
<el-input v-model="props.form.installPointDes" placeholder="请输入设备点位" maxlength="100" />
|
|
|
|
|
<el-input v-model="form.installPointDes" placeholder="请输入设备点位" maxlength="100" />
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-col>
|
|
|
|
|
<el-col :span="12">
|
|
|
|
|
<el-form-item label="状态">
|
|
|
|
|
<el-radio-group v-model="props.form.status">
|
|
|
|
|
<el-radio-group v-model="form.status">
|
|
|
|
|
<el-radio v-for="item in statusOptions" :key="item.value" :value="item.value">{{ item.label }}</el-radio>
|
|
|
|
|
</el-radio-group>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-col>
|
|
|
|
|
<el-col :span="24" v-if="props.form.type === '4'">
|
|
|
|
|
<el-col :span="24" v-if="form.type === '4'">
|
|
|
|
|
<el-form-item label="视频流" prop="videoPlayUrl">
|
|
|
|
|
<el-input v-model="props.form.videoPlayUrl" placeholder="请输入视频流地址" maxlength="200" />
|
|
|
|
|
<el-input v-model="form.videoPlayUrl" placeholder="请输入视频流地址" maxlength="200" />
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-col>
|
|
|
|
|
<el-col :span="24">
|
|
|
|
|
<el-form-item label="备注">
|
|
|
|
|
<el-input v-model="props.form.remark" type="textarea" placeholder="请输入备注内容"></el-input>
|
|
|
|
|
<el-input v-model="form.remark" type="textarea" placeholder="请输入备注内容"></el-input>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-col>
|
|
|
|
|
</el-row>
|
|
|
|
|
@ -64,10 +64,15 @@
|
|
|
|
|
|
|
|
|
|
<script setup>
|
|
|
|
|
import { addDevice, updateDevice } from '@/api/device'
|
|
|
|
|
import { defaultForm } from '../config'
|
|
|
|
|
|
|
|
|
|
defineExpose({
|
|
|
|
|
setForm,
|
|
|
|
|
resetForm
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
const props = defineProps({
|
|
|
|
|
open: { type: Boolean, required: true },
|
|
|
|
|
form: { type: Object, required: true },
|
|
|
|
|
title: { type: String, required: true },
|
|
|
|
|
deviceTypes: { type: Array, required: true },
|
|
|
|
|
statusOptions: { type: Array, required: true },
|
|
|
|
|
@ -78,13 +83,15 @@ const emits = defineEmits(['update:open', 'success'])
|
|
|
|
|
// 创建本地状态来响应open属性的变化
|
|
|
|
|
const dialogOpen = ref(props.open)
|
|
|
|
|
|
|
|
|
|
const form = ref({ ...defaultForm })
|
|
|
|
|
|
|
|
|
|
const uploadImg = ref('')
|
|
|
|
|
|
|
|
|
|
watch(() => uploadImg.value, (newVal) => {
|
|
|
|
|
props.form.imgUrl = newVal
|
|
|
|
|
form.value.imgUrl = newVal
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
watch(() => props.form.imgUrl, (newVal) => {
|
|
|
|
|
watch(() => form.value.imgUrl, (newVal) => {
|
|
|
|
|
uploadImg.value = newVal
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
@ -136,15 +143,16 @@ async function submitForm() {
|
|
|
|
|
try {
|
|
|
|
|
await deviceRef.value.validate()
|
|
|
|
|
|
|
|
|
|
if (props.form.id) {
|
|
|
|
|
await updateDevice(props.form)
|
|
|
|
|
if (form.id) {
|
|
|
|
|
await updateDevice(form)
|
|
|
|
|
proxy.$modal.msgSuccess('修改成功')
|
|
|
|
|
} else {
|
|
|
|
|
await addDevice(props.form)
|
|
|
|
|
await addDevice(form)
|
|
|
|
|
proxy.$modal.msgSuccess('新增成功')
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
dialogOpen.value = false
|
|
|
|
|
resetForm()
|
|
|
|
|
emits('success')
|
|
|
|
|
} catch (error) {
|
|
|
|
|
// 表单验证失败不提示错误
|
|
|
|
|
@ -154,6 +162,15 @@ async function submitForm() {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function setForm(data) {
|
|
|
|
|
form.value = { ...data }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function resetForm() {
|
|
|
|
|
form.value = { ...defaultForm }
|
|
|
|
|
deviceRef.value?.resetFields()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 取消按钮操作
|
|
|
|
|
function cancel() {
|
|
|
|
|
dialogOpen.value = false
|
|
|
|
|
|