From e5454b769d44a34af423bf87ac8a740bf8c20341 Mon Sep 17 00:00:00 2001
From: Crunchy <3114200645@qq.com>
Date: 星期二, 29 四月 2025 13:25:29 +0800
Subject: [PATCH] Merge branch 'dev' into dev_tides

---
 src/views/structural/capabilityAndLaboratory/capabilityComponents/EditForm.vue |   68 +++++++++++++++++++++++++++------
 1 files changed, 55 insertions(+), 13 deletions(-)

diff --git a/src/views/structural/capabilityAndLaboratory/capabilityComponents/EditForm.vue b/src/views/structural/capabilityAndLaboratory/capabilityComponents/EditForm.vue
index 3543847..bb55b02 100644
--- a/src/views/structural/capabilityAndLaboratory/capabilityComponents/EditForm.vue
+++ b/src/views/structural/capabilityAndLaboratory/capabilityComponents/EditForm.vue
@@ -103,6 +103,18 @@
               </el-select>
             </el-form-item>
           </el-col>
+          <el-col :span="12" v-if="editForm.inspectionItemType == 1">
+            <el-form-item label="璁惧缁戝畾锛�" prop="deviceId">
+              <el-select v-model="editForm.deviceId" clearable placeholder="璇烽�夋嫨"
+                         size="small" style="width: 100%" multiple filterable>
+                <el-option v-for="item in equipOptions" :key="item.value" :label="item.label" :value="item.value">
+                  {{item.label + ' - ' + item.managementNumber}}
+                </el-option>
+              </el-select>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row>
           <el-col :span="12">
             <el-form-item label="妫�楠屽�肩被鍨嬶細" prop="inspectionValueType">
               <el-select v-model="editForm.inspectionValueType" clearable placeholder="璇烽�夋嫨" size="small" style="width: 100%">
@@ -110,8 +122,6 @@
               </el-select>
             </el-form-item>
           </el-col>
-        </el-row>
-        <el-row>
           <el-col :span="12">
             <el-form-item label="鐗规畩鏍囪瘑锛�" prop="bsm">
               <el-select v-model="editForm.bsm" clearable placeholder="璇烽�夋嫨" size="small" style="width: 100%">
@@ -119,6 +129,8 @@
               </el-select>
             </el-form-item>
           </el-col>
+        </el-row>
+        <el-row>
           <el-col :span="12">
             <el-form-item label="鍘熷璁板綍妯℃澘锛�" prop="templateId">
               <el-select v-model="editForm.templateId" clearable placeholder="璇烽�夋嫨" size="small" style="width: 100%">
@@ -126,27 +138,27 @@
               </el-select>
             </el-form-item>
           </el-col>
-        </el-row>
-        <el-row>
           <el-col :span="12">
             <el-form-item label="妫�楠岄」鍒嗙被锛�" prop="inspectionItemClass">
               <el-input v-model="editForm.inspectionItemClass" clearable size="small"></el-input>
             </el-form-item>
           </el-col>
+        </el-row>
+        <el-row>
           <el-col :span="12">
             <el-form-item label="妫�楠岄」鍒嗙被EN锛�" prop="inspectionItemClassEn">
               <el-input v-model="editForm.inspectionItemClassEn" clearable size="small"></el-input>
             </el-form-item>
           </el-col>
-        </el-row>
-        <el-row>
           <el-col :span="12">
             <el-form-item label="璇曢獙鏂规硶锛�" prop="method">
               <el-select v-model="editForm.method" clearable multiple placeholder="璇烽�夋嫨" size="small" style="width: 100%">
-                <el-option v-for="item in methodList" :key="item.value" :label="item.label" :value="item.value"></el-option>
+                <el-option v-for="item in methodList" :key="item.value" :label="item.label" :value="item.label"></el-option>
               </el-select>
             </el-form-item>
           </el-col>
+        </el-row>
+        <el-row>
           <el-col :span="12">
             <el-form-item label="鏉′欢锛�" prop="radiusList">
               <el-select v-model="editForm.radiusList" allow-create default-first-option filterable multiple
@@ -157,8 +169,6 @@
               </el-select>
             </el-form-item>
           </el-col>
-        </el-row>
-        <el-row>
           <el-col :span="12">
             <el-form-item label="鏀惰垂鏍囧噯(鍏�/娆�)锛�" prop="rates">
               <el-input v-model="editForm.rates" clearable size="small"></el-input>
@@ -191,6 +201,7 @@
   upItemParameter
 } from "@/api/structural/capability";
 import {selectStandardMethods} from "@/api/structural/standardMethod";
+import {search} from "@/api/business/inspectionTask";
 
 export default {
   name: "EditForm",
@@ -227,6 +238,7 @@
         method: '', // 璇曢獙鏂规硶
         radiusList: [], // 鏉′欢
         rates: '', // 鏉′欢
+        deviceId: [], // 璁惧
       },
       sampleList: [], // 妫�楠屽璞′笅鎷夋
       laboratoryList: [], // 鍦烘墍涓嬫媺妗�
@@ -262,7 +274,8 @@
           { required: true, message: '璇烽�夋嫨鍘熷璁板綍妯℃澘', trigger: 'change' }
         ]
       },
-      operationType: ''
+      operationType: '',
+      equipOptions: []
     }
   },
   // 鏂规硶闆嗗悎
@@ -270,6 +283,7 @@
     openDia (type, row) {
       this.operationType = type
       this.editFormDia = true
+      this.getEquipOptions() // 鑾峰彇鎵�鏈夎澶�
       this.obtainItemParameterList() // 鍦烘墍绫诲瀷
       this.getStandardTemplate() // 鍘熷璁板綍妯℃澘涓嬫媺妗�
       this.getSelectStandardMethods() // 璇曢獙鏂规硶
@@ -305,8 +319,11 @@
       } else {
         this.editForm = this.HaveJson(row)
         this.editForm.sample = JSON.parse(this.editForm.sample)
-        this.editForm.radiusList = JSON.parse(this.editForm.radiusList)
+        this.editForm.radiusList = this.editForm.radiusList && JSON.parse(this.editForm.radiusList)
         this.editForm.method = JSON.parse(this.editForm.method)
+        const ids = this.editForm.deviceIds && this.editForm.deviceIds.split(",") || [];
+        const numericIds = ids.map(Number);
+        this.$set(this.editForm, 'deviceId', numericIds);
       }
     },
     // 鎻愪氦缂栬緫
@@ -317,7 +334,16 @@
           let obj = this.HaveJson(this.editForm)
           obj.method = JSON.stringify(obj.method)
           obj.sample = JSON.stringify(obj.sample)
-          obj.radiusList = JSON.stringify(obj.radiusList)
+          if (obj.radiusList?.length > 0) {
+            obj.radiusList = JSON.stringify(obj.radiusList)
+          } else {
+            obj.radiusList = null
+          }
+          if (obj.deviceId?.length > 0) {
+            obj.deviceIds = obj.deviceId.join(',')
+          } else {
+            obj.deviceIds = null
+          }
           if(obj.id){
             // 淇敼
             upItemParameter(obj).then(res => {
@@ -387,7 +413,7 @@
             res.data.forEach(a => {
               data.push({
                 label: a.code,
-                value: a.code
+                value: a.id,
               })
             })
             this.methodList = data
@@ -421,6 +447,22 @@
         this.templateIdList = data
       })
     },
+    // 鑾峰彇鎵�鏈夎澶�
+    getEquipOptions() {
+      this.equipOptions = [];
+      search({ status: 0 }).then((res) => {
+        if (res.code === 200 && res.data) {
+          this.equipOptions = res.data.map((m) => {
+            m.value = m.id;
+            m.label = m.deviceName;
+            m.managementNumber = m.managementNumber;
+            return m;
+          });
+        }
+      }).catch((error) => {
+        console.error(error);
+      });
+    },
   },
 }
 </script>

--
Gitblit v1.9.3