zhangwencui
7 天以前 19f0e68b3fe3cf5244a2b936bfef4e0712bdf025
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
<template>
  <el-dialog v-model="visible" :title="title" width="520px" @close="closeDia">
    <el-form ref="formRef" :model="form" :rules="rules" label-width="100px">
      <el-form-item label="电表名称" prop="meterName">
        <el-input v-model="form.meterName" placeholder="请输入电表名称" />
      </el-form-item>
      <el-form-item label="表地址" prop="address">
        <el-input v-model="form.address" placeholder="请输入表地址" />
      </el-form-item>
      <el-form-item label="备注">
        <el-input v-model="form.description" type="textarea" :rows="2" placeholder="备注" />
      </el-form-item>
      <el-form-item label="继电器状态" prop="relayState">
        <el-select v-model="form.relayState" style="width: 100%">
          <el-option label="合闸" value="1" />
          <el-option label="拉闸" value="0" />
        </el-select>
      </el-form-item>
      <el-form-item v-if="showRate" label="倍率">
        <el-input-number v-model="form.rate" :min="1" style="width: 100%" />
      </el-form-item>
      <el-form-item v-if="operationType === 'edit' && form.source === 'sync'" label="档案ID">
        <el-input :model-value="form.meterId" disabled />
      </el-form-item>
      <el-form-item v-if="operationType === 'edit' && form.source === 'sync'">
        <el-text type="info" size="small">同步电表仅可修改名称、表地址、备注、继电器状态(不同步到能源平台)</el-text>
      </el-form-item>
    </el-form>
    <template #footer>
      <el-button @click="visible = false">取消</el-button>
      <el-button type="primary" :loading="submitting" @click="submit">确定</el-button>
    </template>
  </el-dialog>
</template>
 
<script setup>
import { computed, reactive, ref } from "vue";
import { ElMessage } from "element-plus";
import { meterAdd, meterUpdate } from "@/api/energyManagement/tqdianbiao.js";
 
const emit = defineEmits(["close"]);
const visible = ref(false);
const submitting = ref(false);
const operationType = ref("add");
const title = ref("");
const formRef = ref(null);
 
const defaultForm = () => ({
  id: null,
  meterId: null,
  meterName: "",
  address: "",
  description: "",
  relayState: "1",
  rate: 1,
  source: "manual",
});
 
const form = reactive(defaultForm());
 
const showRate = computed(() => operationType.value === "edit" && form.source === "manual");
 
const rules = {
  address: [{ required: true, message: "请输入表地址", trigger: "blur" }],
  relayState: [{ required: true, message: "请选择继电器状态", trigger: "change" }],
};
 
function open(type, row) {
  operationType.value = type;
  title.value = type === "add" ? "新增电表" : "编辑电表";
  Object.assign(form, defaultForm());
  if (type === "edit" && row) {
    Object.assign(form, {
      id: row.id,
      meterId: row.meterId,
      meterName: row.meterName || row.address || "",
      address: row.address || "",
      description: row.description || "",
      relayState: row.relayState || "1",
      rate: row.rate || 1,
      source: row.source || "sync",
    });
  }
  visible.value = true;
}
 
function closeDia() {
  emit("close");
}
 
async function submit() {
  await formRef.value.validate();
  submitting.value = true;
  try {
    const payload = { ...form };
    if (!payload.meterName) {
      payload.meterName = payload.address;
    }
    if (operationType.value === "add") {
      await meterAdd(payload);
      ElMessage.success("新增成功");
    } else {
      await meterUpdate(payload);
      ElMessage.success("修改成功");
    }
    visible.value = false;
    emit("close");
  } finally {
    submitting.value = false;
  }
}
 
defineExpose({ open });
</script>