From 0a144cc1dd664851638a6a01d030dd6a1585c25a Mon Sep 17 00:00:00 2001
From: yaowanxin <3588231647@qq.com>
Date: 星期五, 25 七月 2025 14:55:34 +0800
Subject: [PATCH] 增添数据库表字段

---
 src/views/business/inspectionTask/inspection.vue |  191 +++++++++++++++++++++++++++++++----------------
 1 files changed, 124 insertions(+), 67 deletions(-)

diff --git a/src/views/business/inspectionTask/inspection.vue b/src/views/business/inspectionTask/inspection.vue
index be1cfd8..b441fb0 100644
--- a/src/views/business/inspectionTask/inspection.vue
+++ b/src/views/business/inspectionTask/inspection.vue
@@ -23,7 +23,7 @@
           @click="openUnPassDialog('add')">涓嶅悎鏍煎鐞�</el-button>
         <el-button size="small" type="primary" @click="sampleVisible = true; uploadSample();">鏍峰搧鍒囨崲</el-button>
         <!--        <el-button v-if="state == 1" size="small" type="primary" @click="taskVisible = true">浠诲姟鍒囨崲</el-button>-->
-        <el-button v-if="state == 1" size="small" type="primary" @click="viewManHour">鎻愪氦</el-button>
+        <el-button v-if="state == 1" size="small" type="primary" @click="addVerifyDia = true">鎻愪氦</el-button>
         <!-- 澶嶆牳 -->
         <el-button v-if="state == 2" size="medium" type="primary" @click="openAddCheck">閫氳繃</el-button>
         <el-button v-if="state == 2" size="medium" @click="upInsReview(0)">涓嶉�氳繃</el-button>
@@ -141,7 +141,7 @@
           <el-button :loading="dataAcquisitionLoading" v-if="state == 1" size="small" type="primary"
             @click="getDataAcquisitionDevice">鏁版嵁閲囬泦</el-button>
           <el-button :type="dataAcquisitionEidtAble ? '' : 'primary'" v-if="state == 1" size="small"
-            @click="dataAcquisitionEidtAble = !dataAcquisitionEidtAble">{{ dataAcquisitionEidtAble ? "鍏抽棴缂栬緫" : "缂栬緫鏁伴噰"
+            @click="dataAcquisitionEidtAble = !dataAcquisitionEidtAble,disconnect()">{{ dataAcquisitionEidtAble ? "鍏抽棴缂栬緫" : "缂栬緫鏁伴噰"
             }}</el-button>
         </div>
       </div>
@@ -406,83 +406,92 @@
         <el-button :loading="submitLoading" type="primary" @click="submit()">纭� 瀹�</el-button>
       </span>
     </el-dialog>
-    <el-dialog :close-on-click-modal="false" :close-on-press-escape="false" :show-close="false"
-      :visible.sync="dataGetDia" title="鏁版嵁閲囬泦" width="80%">
-      <div>
-        <table border="1" cellpadding="10" class="thermal-table">
+     <el-dialog :close-on-click-modal="false" :close-on-press-escape="false" :show-close="false"
+    :visible.sync="dataGetDia" title="鏁版嵁閲囬泦" width="80%">
+    <div>
+      <table border="1" cellpadding="10" class="thermal-table">
+        <tr>
+          <td style="width: 120px">妫�楠岄」鍒嗙被</td>
+          <td style="width: 120px">妫�楠岄」</td>
+          <td style="width: 120px">妫�楠屽瓙椤�</td>
+          <td>鏁伴噰鏁版嵁</td>
+        </tr>
+        <template v-for="(item, index) in getData">
           <tr>
-            <td style="width: 120px">妫�楠岄」鍒嗙被</td>
-            <td style="width: 120px">妫�楠岄」</td>
-            <td style="width: 120px">妫�楠屽瓙椤�</td>
-            <td>鏁伴噰鏁版嵁</td>
-          </tr>
-          <template v-for="(item, index) in getData">
-            <tr>
-              <td :rowspan="item.child.length">{{ item.sortName }}</td>
-              <td :rowspan="item.child.length">{{ item.faName }}</td>
-              <td>{{ item.child[0].name }}</td>
-              <td style="text-align: left">
+            <td :rowspan="item.child.length">{{ item.sortName }}</td>
+            <td :rowspan="item.child.length">{{ item.faName }}</td>
+            <td>{{ item.child[0].name }}</td>
+            <td style="text-align: left">
+              <!-- 娣诲姞瀹瑰櫒 div -->
+              <div class="data-collection-items">
                 <el-select v-if="item.child[0].isShowSelect" v-model="item.child[0].getDataIndex1"
                   :multiple-limit="item.child[0].maxNum" clearable filterable multiple placeholder="璇烽�夋嫨"
                   @change="setData(item)">
-                  <el-option v-for="(item, index) in item.child[0].arr" :key="index" :filter-method="filterMethod"
-                    :label="index + 1 + '^' + item.result" :value="index + '^' + item.result">
+                  <el-option v-for="(subItem, subIndex) in item.child[0].arr" :key="index + '-' + subIndex" :filter-method="filterMethod"
+                    :label="subIndex + 1 + '^' + subItem.result" :value="subIndex + '^' + subItem.result">
                     <span>{{
                       "搴忓彿锛�" +
-                      (index + 1) +
+                      (subIndex + 1) +
                       "锛�" +
                       "缁撴灉锛�" +
-                      item.result +
+                      subItem.result +
                       "锛�" +
                       "鍘氬害锛�" +
-                      item.thickness +
+                      subItem.thickness +
                       "锛�" +
                       "鏃堕棿锛�" +
-                      item.mergedDateTime
+                      subItem.mergedDateTime
                     }}</span>
                   </el-option>
                 </el-select>
                 <el-checkbox-group v-if="!item.child[0].isShowSelect" v-model="item.child[0].getDataIndex1"
                   :max="item.child[0].maxNum">
-                  <el-checkbox v-for="(n, j) in item.child[0].arr" :key="j" :label="j + '^' + n">{{ n }}</el-checkbox>
+                  <el-checkbox v-for="(n, j) in item.child[0].arr" :key="index + '-' + j + 'aaaaaa'" :label="j + '^' + n"
+                  @change="handleGroupSelect(item.child[0], j)" >{{ n }}</el-checkbox>
                 </el-checkbox-group>
-              </td>
-            </tr>
-            <tr v-for="(m, i) in item.child" v-show="i > 0" :key="i + 'bbbbbbbbbbbbbb'">
-              <td>{{ m.name }}</td>
-              <td style="text-align: left">
+              </div>
+            </td>
+          </tr>
+          <tr v-for="(m, i) in item.child" v-show="i > 0" :key="index + '-' + i + 'bbbbbbbbbbbbbb'">
+            <td>{{ m.name }}</td>
+            <td style="text-align: left">
+              <!-- 娣诲姞瀹瑰櫒 div -->
+              <div class="data-collection-items">
                 <el-select v-if="m.isShowSelect" v-model="m.getDataIndex1" :multiple-limit="m.maxNum" clearable
                   filterable multiple placeholder="璇烽�夋嫨">
-                  <el-option v-for="(item, index1) in m.arr" :key="index1" :label="index + 1 + '^' + item.result"
-                    :value="index1 + '^' + item.result">
+                  <el-option v-for="(subItem, index1) in m.arr" :key="index + '-' + index1 + 'cccccccc'"
+                    :label="index1 + 1 + '^' + subItem.result" :value="index1 + '^' + subItem.result">
                     <span>{{
                       "搴忓彿锛�" +
                       (index1 + 1) +
                       "锛�" +
                       "缁撴灉锛�" +
-                      item.result +
+                      subItem.result +
                       "锛�" +
                       "鍘氬害锛�" +
-                      item.thickness +
+                      subItem.thickness +
                       "锛�" +
                       "鏃堕棿锛�" +
-                      item.mergedDateTime
+                      subItem.mergedDateTime
                     }}</span>
                   </el-option>
                 </el-select>
                 <el-checkbox-group v-if="!m.isShowSelect" v-model="m.getDataIndex1" :max="m.maxNum">
-                  <el-checkbox v-for="(n, j) in m.arr" :key="j" :label="j + '^' + n">{{ n }}</el-checkbox>
+                  <el-checkbox v-for="(n, j) in m.arr" :key="index + '-' + j + 'dddddddd'" :label="j + '^' + n"
+                  @change="handleGroupSelect(m, j)" >{{ n }}</el-checkbox>
                 </el-checkbox-group>
-              </td>
-            </tr>
-          </template>
-        </table>
-      </div>
-      <span slot="footer" class="dialog-footer">
-        <el-button @click="dataGetDia = false">鍙� 娑�</el-button>
-        <el-button :loading="getDataIndexLoading" type="primary" @click="submitDataGet()">纭� 瀹�</el-button>
-      </span>
-    </el-dialog>
+              </div>
+            </td>
+          </tr>
+        </template>
+      </table>
+    </div>
+    <span slot="footer" class="dialog-footer">
+      <el-button @click="dataGetDia = false">鍙� 娑�</el-button>
+      <el-button :loading="getDataIndexLoading" type="primary" @click="submitDataGet()">纭� 瀹�</el-button>
+    </span>
+  </el-dialog>
+
     <el-dialog :close-on-click-modal="false" :visible.sync="addCheck" title="鎸囧畾鎶ュ憡瀹℃牳浜哄憳" width="400px"
       @close="closeAddVerifyDia">
       <div class="body" style="display: flex; padding: 10px; align-items: center">
@@ -501,13 +510,18 @@
         <el-button :loading="reviewLoading" type="primary" @click="upInsReview(1)">纭� 瀹�</el-button>
       </span>
     </el-dialog>
+    <!-- 娣诲姞涓嶅悎鏍煎娴嬪脊妗�-->
     <add-un-pass v-if="addUnPassDialog" ref="addUnPassDialog" :addUnPassDialog="addUnPassDialog"
       @resetAddUnPass="resetAddUnPass"></add-un-pass>
+    <!-- 涓嶅悎鏍煎鐞嗗脊妗�-->
     <UnPassDialog v-if="unPassDialog" ref="unPassDialog" :orderId="orderId" :unPassDialog="unPassDialog"
       @resetForm="resetForm"></UnPassDialog>
+    <!-- 涓嶅悎鏍煎娴嬪脊妗�-->
     <InspectionWord v-if="unPassCheck" :inspectorList="inspectorList" :orderId="orderId"
+                    :cableTag="temCableTag" :repetitionTag="repetitionTag"
       :rawMaterialTag="rawMaterialTag" :sonLaboratory="sonLaboratory" :state="state" :typeSource="typeSource"
       :unPassCheck="unPassCheck" @closeUnPassCheckDialog="closeUnPassCheckDialog" @refreshView="refreshView" />
+    <!-- 杩涜揣楠岃瘉寮规-->
     <purchase-verification v-if="purchaseDialog" ref="purchaseDialog" :orderId="orderId"
       :purchaseDialog="purchaseDialog" @resetPurchaseDialog="resetPurchaseDialog"></purchase-verification>
     <!--鏌ョ湅宸ユ椂寮规-->
@@ -522,6 +536,8 @@
 import AddUnPass from "../unpass/components/addUnPass.vue";
 import InspectionWord from "./components/InspectionWord.vue";
 import PurchaseVerification from "../unpass/components/PurchaseVerification.vue";
+import { connect,disconnect } from "@/utils/connect.js";
+
 import {
   doInsOrder,
   getCableTag,
@@ -541,8 +557,8 @@
   delfile,
   inspectionOrderDetailsTaskSwitching
 } from "@/api/business/inspectionTask.js";
-import InspectionWorker from '../../../InspectionWorker.worker';
-import DataWorker from '../../../DataWorker.worker';
+import InspectionWorker from '@/workers/InspectionWorker.worker.js';
+import DataWorker from '@/workers/DataWorker.worker.js';
 import html2canvas from "html2canvas";
 import { mapGetters } from "vuex";
 import viewManHourDia from "@/views/business/inspectionTask/components/viewManHourDia.vue";
@@ -647,10 +663,18 @@
             {
               name: "1285nm~1330nm",
               arr: [12, 13, 14, 15],
+              // 鍒濆鍖� getDataIndex1 涓烘暟缁�
+              getDataIndex1: [],
+              isShowSelect: false,
+              maxNum: 5
             },
             {
               name: "1525nm~1575nm",
               arr: [12, 13, 14, 15],
+              // 鍒濆鍖� getDataIndex1 涓烘暟缁�
+              getDataIndex1: [],
+              isShowSelect: false,
+              maxNum: 5
             },
           ],
         },
@@ -660,6 +684,10 @@
             {
               name: "鎴嚦娉㈤暱",
               arr: [12, 13, 14, 15],
+              // 鍒濆鍖� getDataIndex1 涓烘暟缁�
+              getDataIndex1: [],
+              isShowSelect: false,
+              maxNum: 5
             },
           ],
         },
@@ -792,6 +820,7 @@
     this.startWorker();
     // this.getList0() // 浠诲姟鍒囨崲
     this.scrollInit();
+    disconnect()
   },
   activated() {
     this.getTypeDicts(); // 鑾峰彇绱ф�ョ▼搴︿笅鎷夋閫夐」
@@ -871,6 +900,7 @@
   beforeDestroy() {
     // 鍦ㄧ粍浠堕攢姣佸墠纭繚鍋滄 Worker锛岄伩鍏嶅唴瀛樻硠婕�
     this.stopWorker();
+    disconnect()
   },
   methods: {
     // 鏂囦欢绠$悊--寮�濮�
@@ -908,6 +938,17 @@
       }).catch(() => { });
     },
     // 鏂囦欢绠$悊--缁撴潫
+  // 澶勭悊鏁寸粍鍕鹃�夐�昏緫鐨勬柟娉�
+    handleGroupSelect(childItem, clickedIndex) {
+      // 璁$畻鎵�鍦ㄧ粍鐨勮捣濮嬬储寮�
+      const groupStartIndex = Math.floor(clickedIndex / 5) * 5;
+      // 娓呯┖褰撳墠宸查��
+      childItem.getDataIndex1 = [];
+      // 閬嶅巻褰撳墠缁勭殑 5 涓厓绱狅紝娣诲姞鍒伴�変腑鍒楄〃
+      for (let i = groupStartIndex; i < groupStartIndex + 5 && i < childItem.arr.length; i++) {
+        childItem.getDataIndex1.push(i + '^' + childItem.arr[i]);
+      }
+    },
 
     // 浠诲姟鍒囨崲--寮�濮�
     getList0() {
@@ -1038,8 +1079,9 @@
         id: this.currentSample.id,
         type: this.type,
         laboratory: this.sonLaboratory,
-        cableTag: "",
+        cableTag: this.temCableTag,
         rawMaterialTag: this.rawMaterialTag,
+        repetitionTag: this.repetitionTag,
       };
       this.$nextTick(() => {
         this.$refs.addUnPassDialog.getInsOrder(info);
@@ -1090,6 +1132,8 @@
     },
     // 鏁版嵁閲囬泦
     getDataAcquisitionDevice() {
+      // connect()
+      // return
       let itemIds = [];
       this.currentSample.insProduct.forEach((item) => {
         if (item.inspectionItemType === "1") {
@@ -1133,7 +1177,6 @@
       this.dataAcquisitionInfo = {};
       this.getData = [];
       for (let i in this.objectOrder(data)) {
-        console.log("i---", i);
         let obj = {};
         if (i.includes("@")) {
           obj = {
@@ -1242,8 +1285,9 @@
               } else {
                 str0 = i + "," + j;
               }
-            }
+            };
             let list = this.tableList[0].arr;
+            console.log(this.tableList[0]);
             let maxNum = 0;
             list.forEach((item, index) => {
               let num0 = 0;
@@ -1275,6 +1319,7 @@
                   }
                   let num = 0;
                   list[index].forEach((n) => {
+                    // console.log(n.v.ps.value);
                     if (
                       n.v.ps &&
                       n.v.ps.value &&
@@ -1347,6 +1392,7 @@
       } else {
         // 濡傛灉閮戒笉瀛樺湪锛屽垯锛岃繘鍏ュ鐞嗘暟閲囩嚎绋嬮噷鍘诲鐞嗘暟鎹�
         try {
+          console.log(this.dataAcquisitionInfo);
           // 鍚� Worker 鍙戦�佹秷鎭紝寮�濮嬪鐞嗛�昏緫
           this.getDataIndexLoading = false;
           this.dataGetDia = false;
@@ -1476,7 +1522,6 @@
     },
     // 淇濆瓨婀垮害銆佹俯搴︽暟鎹�
     subOtherForm(m, type) {
-      console.log("m---", m);
       write({
         [type]: type === "remark" ? m : Number(m),
         id: this.insOrder.id,
@@ -1637,20 +1682,6 @@
         this.comparisonList = this.dictToValue(response.data);
       });
     },
-    // 鑾峰彇妫�楠屽�间负涓嬫媺鏃剁殑涓嬫媺鍒楄〃
-    // selectEnumByCategoryOfSelect(val) {
-    //   this.enumList = [];
-    //   if (val === undefined || val === null) {
-    //     return;
-    //   }
-    //   this.$axios
-    //     .post(this.$api.enums.selectEnumByCategory, {
-    //       category: val,
-    //     })
-    //     .then((res) => {
-    //       this.enumList = res.data;
-    //     });
-    // },
     tableRowClassName({ row, rowIndex }) {
       row.index = rowIndex + 1;
     },
@@ -2673,12 +2704,23 @@
           } else {
             param = this.param;
           }
+          let isNoTestValue = ''
+          for (let key in param) {
+            if (param[key]) {
+              if (param[key].insValue?.length === 0) {
+                isNoTestValue = 1
+              } else {
+                isNoTestValue = ''
+              }
+            }
+          }
           saveInsContext({
             param: JSON.stringify(param),
             currentTable: this.currentTable,
             sampleId: this.currentSample.id,
             orderId: this.orderId,
-            sonLaboratory: this.sonLaboratory
+            sonLaboratory: this.sonLaboratory,
+            isNoTestValue: isNoTestValue
           }).then((res) => {
             this.$message.success("宸蹭繚瀛�");
           });
@@ -2747,7 +2789,7 @@
       }
     },
     getAuthorizedPerson() {
-      selectUserCondition({ type: 0 }).then((res) => {
+      selectUserCondition({ type: 1 }).then((res) => {
         let data = [];
         res.data.forEach((a) => {
           data.push({
@@ -2877,6 +2919,9 @@
     goback() {
       this.$router.go(-1)
     }
+  },
+  destroyed() {
+    disconnect()
   },
 };
 </script>
@@ -3150,4 +3195,16 @@
   max-width: 1000px;
   /* 璁剧疆鏈�澶у搴� */
 }
+
+
+.data-collection-items {
+  display: flex;
+  flex-wrap: wrap; 
+}
+.data-collection-items .el-select,
+.data-collection-items .el-checkbox {
+  flex-basis: 20% ; 
+  box-sizing: border-box;
+  padding: 5px 2%;
+}
 </style>

--
Gitblit v1.9.3