edit.vue 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  1. <template>
  2. <el-dialog class="api-edit" v-model="showDialog" :title="`${formData.id ? '编辑设备档案' : '新增设备档案'}`" width="800px" :close-on-click-modal="false" :close-on-press-escape="false">
  3. <el-form class="inline-form" ref="formRef" :model="formData" :rules="ruleForm" label-width="120px">
  4. <el-row>
  5. <el-col :span="12">
  6. <el-form-item label="选择产品" prop="productKey">
  7. <el-select v-model="formData.productKey" placeholder="请选择产品" class="w100" disabled>
  8. <el-option v-for="item in productData" :key="item.key" :label="item.name" :value="item.key">
  9. <span style="float: left">{{ item.name }}</span>
  10. <span style="float: right; font-size: 13px">{{ item.key }}</span>
  11. </el-option>
  12. </el-select>
  13. </el-form-item>
  14. </el-col>
  15. <el-col :span="12">
  16. <el-form-item label="选择设备" prop="deviceKey">
  17. <el-select v-model="formData.deviceKey" placeholder="请选择设备" class="w100" clearable @change="handleSelectionChange">
  18. <el-option v-for="item in deviceList" :key="item.key" :label="item.name" :value="item.key">
  19. <span style="float: left">{{ item.name }}</span>
  20. <span style="float: right; font-size: 13px">{{ item.key }}</span>
  21. </el-option>
  22. </el-select>
  23. </el-form-item>
  24. </el-col>
  25. </el-row>
  26. <el-row>
  27. <el-col :span="12">
  28. <el-form-item label="设备名称" prop="deviceName">
  29. <el-input v-model.trim="formData.deviceName" placeholder="请输入设备名称" disabled />
  30. </el-form-item>
  31. </el-col>
  32. <el-col :span="12">
  33. <el-form-item label="设备编码" prop="deviceNumber">
  34. <el-input v-model.trim="formData.deviceNumber" placeholder="请输入设备编码" />
  35. </el-form-item>
  36. </el-col>
  37. </el-row>
  38. <el-row>
  39. <el-col :span="12">
  40. <el-form-item label="所属区域" prop="area">
  41. <el-cascader :options="orgData" :props="{ checkStrictly: true, emitPath: false, value: 'id', label: 'name' }" placeholder="请选择区域" clearable class="w100" v-model="formData.area">
  42. <template #default="{ node, data }">
  43. <span>{{ data.name }}</span>
  44. <span v-if="!node.isLeaf"> ({{ data.children.length }}) </span>
  45. </template>
  46. </el-cascader>
  47. </el-form-item>
  48. </el-col>
  49. <el-col :span="12">
  50. <el-form-item label="安装时间">
  51. <el-date-picker v-model="formData.installTime" type="date" value-format="YYYY-MM-DD" placeholder="请选择时间" class="w100" clearable />
  52. </el-form-item>
  53. </el-col>
  54. </el-row>
  55. <el-row>
  56. <el-col :span="12">
  57. <el-form-item label="所属部门" prop="deptId">
  58. <el-cascader :options="deptData" :props="{ checkStrictly: true, emitPath: false, value: 'deptId', label: 'deptName' }" placeholder="请选择所属部门" clearable class="w100" v-model="formData.deptId">
  59. <template #default="{ node, data }">
  60. <span>{{ data.deptName }}</span>
  61. <span v-if="!node.isLeaf"> ({{ data.children.length }}) </span>
  62. </template>
  63. </el-cascader>
  64. </el-form-item>
  65. </el-col>
  66. <el-col :span="12">
  67. <el-form-item label="设备类型">
  68. <el-input v-model.trim="formData.deviceCategory" placeholder="请输入设备类型" />
  69. </el-form-item>
  70. </el-col>
  71. </el-row>
  72. <el-divider content-position="left" v-if="Datalist">自定义属性</el-divider>
  73. <FromData :Datalist="Datalist" @SetSaveData="SetSaveData" v-if="Datalist && Datalist.length > 0"></FromData>
  74. </el-form>
  75. <template #footer>
  76. <div class="dialog-footer">
  77. <el-button @click="showDialog = false">取消</el-button>
  78. <el-button type="primary" @click="onSubmit">确定</el-button>
  79. </div>
  80. </template>
  81. </el-dialog>
  82. </template>
  83. <script lang="ts" setup>
  84. import { ref, reactive, nextTick } from 'vue';
  85. import api from '/@/api/device'
  86. import system from '/@/api/system';
  87. import FromData from './component/from.vue';
  88. import { ruleRequired } from '/@/utils/validator';
  89. import { ElMessage } from 'element-plus';
  90. const emit = defineEmits(['getList']);
  91. const showDialog = ref(false);
  92. const formRef = ref();
  93. const orgData = ref();
  94. const deviceList = ref();
  95. const productData = ref();
  96. const deptData = ref();
  97. const Datalist = ref();
  98. const newData = ref([]);
  99. const baseForm = {
  100. id: undefined,
  101. productKey: '',
  102. deviceKey: '',
  103. deviceName: '',
  104. area: "",
  105. deviceNumber: '',
  106. deviceCategory: '',
  107. installTime: '',
  108. deptId: '',
  109. data: [],
  110. };
  111. const SetSaveData = (data: any) => {
  112. formData.data = data;
  113. }
  114. const formData = reactive({
  115. ...baseForm,
  116. });
  117. const ruleForm = {
  118. productKey: [ruleRequired('所属产品不能为空')],
  119. deviceName: [ruleRequired('设备名称不能为空')],
  120. deviceKey: [ruleRequired('设备不能为空')],
  121. };
  122. const handleSelectionChange = (value: any) => {
  123. const selectedOption = deviceList.value.find(option => option.key === value);
  124. if (selectedOption) {
  125. formData.deviceName = selectedOption.name;
  126. } else {
  127. formData.deviceName = '';
  128. }
  129. }
  130. const onSubmit = async () => {
  131. await formRef.value.validate();
  132. const theApi = formData.id ? api.dev_asset.edit : api.dev_asset.add;
  133. await theApi(formData);
  134. ElMessage.success('操作成功');
  135. resetForm();
  136. showDialog.value = false;
  137. emit('getList');
  138. };
  139. const resetForm = async () => {
  140. Object.assign(formData, { ...baseForm });
  141. Datalist.value = ''
  142. formRef.value && formRef.value.resetFields();
  143. };
  144. const getIdByKey = (key: string) => {
  145. for (let i = 0; i < productData.value.length; i++) {
  146. if (productData.value[i].key === key) {
  147. return productData.value[i].id;
  148. }
  149. }
  150. return null; // 如果没有找到匹配的key,则返回null(或者其他合适的值)
  151. }
  152. const open = async (row: any, productInfo: any) => {
  153. resetForm();
  154. showDialog.value = true;
  155. nextTick(() => {
  156. system.org.getList({ status: 1 }).then((res: any) => {
  157. res.forEach((item:any) => {
  158. item.id = item.id.toString();
  159. });
  160. orgData.value = res || [];
  161. });
  162. //获取 所有的产品
  163. api.product.getLists({}).then((resp: any) => {
  164. productData.value = resp.product;
  165. if (row.id) {
  166. productInfo = {
  167. id: getIdByKey(row.productKey),
  168. key: row.productKey,
  169. }
  170. }
  171. //根据产品ID获取设备列表
  172. api.device.allList({ productId: productInfo.id }).then((resd: any) => {
  173. deviceList.value = resd.device || [];
  174. });
  175. })
  176. //获取部门
  177. api.dept.getList({ status: -1 }).then((res: any) => {
  178. res.forEach((item:any) => {
  179. item.deptId = item.deptId.toString();
  180. });
  181. deptData.value = res || [];
  182. });
  183. if (row.id) {
  184. api.dev_asset.detail({ deviceKey: row.deviceKey }).then((resde: any) => {
  185. Object.assign(formData, { ...resde });
  186. formData.productKey = row.productKey
  187. const newArray = resde.data.map(obj => {
  188. const { name, value, ...rest } = obj;
  189. const newObj = { name, value, ...rest };
  190. newObj[name] = value ? value : '';
  191. return newObj;
  192. });
  193. Datalist.value = newArray
  194. });
  195. } else {
  196. //获取档案属性
  197. api.dev_asset_metadata.getList({ productKey: productInfo.key, pageSize: 50, pageNum: 1, status: -1, total: 0 }).then((res: any) => {
  198. const sortedArray = res.Data.sort((a, b) => a.id - b.id);
  199. Datalist.value = sortedArray || [];
  200. });
  201. formData.productKey = productInfo.key
  202. }
  203. });
  204. };
  205. defineExpose({ open });
  206. </script>
  207. <style scoped lang="scss">
  208. .demo-form-inline .el-input {
  209. --el-input-width: 320px;
  210. }
  211. </style>