From cb57bc6b4abf45dbb0605c94359c63e3b31b4b87 Mon Sep 17 00:00:00 2001
From: licp <lichunping@guanfang.com.cn>
Date: 星期二, 10 九月 2024 15:55:57 +0800
Subject: [PATCH] 优化报告生成、修改电路下单传参

---
 src/components/do/b1-inspect-order-plan/Inspection.vue | 2194 +++++++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 1,759 insertions(+), 435 deletions(-)

diff --git a/src/components/do/b1-inspect-order-plan/Inspection.vue b/src/components/do/b1-inspect-order-plan/Inspection.vue
index 425a9b3..2806de1 100644
--- a/src/components/do/b1-inspect-order-plan/Inspection.vue
+++ b/src/components/do/b1-inspect-order-plan/Inspection.vue
@@ -1,4 +1,16 @@
 <style scoped>
+.custom-table .el-table__header-wrapper th {
+  background-color: #87CEEB; /* 鍙甯︽湁my-custom-table绫荤殑琛ㄦ牸鐢熸晥 */
+  color: #fff;
+}
+ .container {
+    overflow: auto; /* 纭繚瀹瑰櫒鑳藉寘瑁规诞鍔ㄥ厓绱� */
+    margin-bottom: 10px;
+}
+
+.right-button {
+    float: right;
+}
   .inspection {
     height: 100%;
     overflow-y: auto;
@@ -22,7 +34,8 @@
 
   .search .form-inline {
     padding-top: 20px;
-    padding-left: 50px;
+    padding-left: 0px;
+    text-align: left;
   }
 
   .center {
@@ -62,6 +75,24 @@
     font-size: 14px;
     word-wrap: break-word;
     white-space: normal;
+  }
+  .thermal-table{
+    min-width: calc(100% - 10px);
+    margin: 5px 5px 0;
+    table-layout: fixed;
+  }
+  .thermal-table td {
+    min-width: 70px;
+    text-align: center;
+    font-size: 14px;
+    word-wrap: break-word;
+    white-space: normal;
+    padding: 5px;
+  }
+  .table-container {
+      overflow-x: auto; /* 浣垮鍣ㄦ敮鎸佹í鍚戞粴鍔� */
+      max-width: 100%;  /* 闄愬埗瀹瑰櫒鐨勬渶澶у搴� */
+      margin-bottom: 16px;
   }
 
   .content {
@@ -107,6 +138,9 @@
     width: 100%;
     height: 100%;
   }
+  .table_input >>>.el-input__inner{
+    border-color: rgba(0, 0, 0, 0.5) !important;
+  }
 
   .collection {
     width: 50px;
@@ -125,7 +159,7 @@
   .table_caret{
     font-size: 16px;
     margin: 0 5px;
-    color: rgba(0, 0, 0, 0.1);
+    color: rgba(0, 0, 0, 0.5);
   }
   .table_caret:hover{
     color: #409eff;
@@ -166,6 +200,7 @@
 
   .inspection .el-drawer__header {
     color: #303133;
+    text-align: left;
   }
 
   .inspection .el-input-group__append {
@@ -204,43 +239,50 @@
     display: flex;
     align-items: center;
   }
+  .thermal-table .el-input{
+    display: flex;
+    align-items: center;
+  }
+  .custom-dialog .el-dialog__body {
+    max-width: 1000px; /* 璁剧疆鏈�澶у搴� */
+  }
 </style>
 <template>
   <div v-loading="loading" class="inspection">
     <el-row class="title">
-      <el-col :span="12" style="padding-left: 20px;text-align: left;">妫�楠屽崟璇︽儏
-        <!-- <span style="color: #3A7BFA;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;鏍峰搧</span>
-        <span v-if="currentFiberOpticTape" style="color: #3A7BFA;"> - 鍏夌氦甯�</span>
-        <span v-if="currentFiberOptic" style="color: #3A7BFA;"> - 鍏夌氦</span> -->
+      <el-col :span="12" style="padding-left: 20px;text-align: left;" >妫�楠屽崟璇︽儏
       </el-col>
       <el-col :span="12" style="text-align: right;">
-        <!-- <el-button size="small" type="primary" @click="fiberOpticVisible=true" v-if="fiberOptic.length>0">鍏夌氦鍒囨崲</el-button>
-        <el-button size="small" type="primary" @click="fiberOpticTapeVisible=true" v-if="fiberOpticTape.length>0">鍏夌氦甯﹀垏鎹�</el-button>
-        <el-button size="small" type="primary" @click="bushingVisible=true" v-if="bushing.length>0">濂楃鍒囨崲</el-button> -->
-        <el-button size="small" type="primary" @click="sampleVisible=true">鏍峰搧鍒囨崲</el-button>
+        <el-button size="small" type="primary" @click="sampleVisible=true;uploadSample()">鏍峰搧鍒囨崲</el-button>
         <el-button size="small" type="primary" @click="taskVisible=true">浠诲姟鍒囨崲</el-button>
-        <el-button size="small" type="primary" @click="addVerifyDia = true" v-show="state==1"
+        <el-button size="small" type="primary" @click="handleSubmit" v-if="state==1"
           :loading="submitLoading">鎻愪氦</el-button>
         <!-- 澶嶆牳 -->
-        <el-button size="medium" type="primary" @click="upInsReview(1)" :loading="reviewLoading"
-          v-show="state>1">閫氳繃</el-button>
-        <el-button size="medium" @click="upInsReview(0)" v-show="state>1">涓嶉�氳繃</el-button>
+        <el-button size="small" type="primary" @click="upInsReview(1)" :loading="reviewLoading"
+          v-if="state>1">缁х画璇曢獙</el-button>
+        <el-button size="small" @click="upInsReview(0)" v-if="state>1" type="danger">鍐嶆璇曢獙</el-button>
+        <el-button size="small" @click="upInsReview(2)" v-if="state>1">缁撴潫璇曢獙</el-button>
         <el-button size="small" @click="$emit('goback')">杩斿洖</el-button>
       </el-col>
     </el-row>
     <div class="search">
-      <el-form :inline="true" :model="searchForm" class="form-inline" label-width="100px">
+      <el-form :inline="true" :model="searchForm" class="form-inline" label-width="100px" label-position="right">
         <el-form-item label="濮旀墭缂栧彿:">
           <el-input clearable v-model="insOrder.entrustCode" disabled size="small" placeholder="璇疯緭鍏�"></el-input>
         </el-form-item>
         <el-form-item label="鏍峰搧缂栧彿:">
-          <el-input clearable v-model="currentSample.sampleCode" disabled size="small" placeholder="璇疯緭鍏�"></el-input>
+          <el-tooltip :disabled="!currentSample.sampleCode" :content="currentSample.sampleCode">
+            <el-input clearable v-model="currentSample.sampleCode" disabled size="small" placeholder="璇疯緭鍏�" tooltip></el-input>
+          </el-tooltip>
         </el-form-item>
         <el-form-item label="鏍峰搧鍚嶇О:">
           <el-input clearable v-model="currentSample.sample" disabled size="small" placeholder="璇疯緭鍏�"></el-input>
         </el-form-item>
         <el-form-item label="鏍峰搧鏁伴噺:">
-          <el-input clearable v-model="sampleProduct.length" disabled size="small" placeholder="璇疯緭鍏�"></el-input>
+          <el-input clearable v-model="sampleProduct.length" disabled size="small" placeholder="璇疯緭鍏�" ></el-input>
+        </el-form-item>
+        <el-form-item label="璇曢獙鏍囧噯:">
+          <span>{{ currentSample.testRequirements?currentSample.testRequirements:'-' }}</span>
         </el-form-item>
         <el-form-item label="涓嬪彂鏃堕棿:">
           <el-input clearable v-model="insOrder.sendTime" disabled size="small" placeholder="璇疯緭鍏�"></el-input>
@@ -254,65 +296,90 @@
         <el-form-item label="褰撳墠鏍峰搧浣嶆暟:">
           <el-tag v-if="currentKey">{{ `NO.${currentKey}` }}</el-tag>
         </el-form-item>
+        <el-form-item label="澶囨敞:">
+          <span style="color:red">{{ insOrder.remark?insOrder.remark:'-' }}</span>
+        </el-form-item>
       </el-form>
     </div>
     <div class="center">
-      <div class="search" style="text-align: left;display: flex;align-items: center;justify-content: space-between;overflow-x: auto;">
+      <div class="search" style="text-align: left;display: flex;align-items: center;justify-content: space-between;">
         <div style="display: flex;align-items: center;">
           <span v-if="tableList.length>0">妫�楠屾ā鏉匡細</span>
           <el-radio-group v-model="currentTable" size="small">
             <el-radio-button :label="item.templateId" v-for="(item,index) in tableLists" :key="index"
               size="small">{{ item.templateName }}</el-radio-button>
           </el-radio-group>
+          <!-- <span style="margin-left: 20px;margin-right: 10px;">妯℃澘鐗堟湰:</span>
+          <el-radio-group v-model="currentTableState" size="small">
+            <el-radio-button label="0" size="small">鐗堟湰涓�</el-radio-button>
+            <el-radio-button label="1" size="small">鐗堟湰浜�</el-radio-button>
+          </el-radio-group> -->
         </div>
         <div style="display: flex;align-items: center;">
-          <span v-if="fibers.length>0">&nbsp;&nbsp;鍏夌氦甯︼細</span>
-          <el-radio-group v-model="currentTab" size="small" v-if="fibers.length>0" @input="m=>handleChange(m,1)">
-            <el-radio-button :label="item.id" v-for="(item,index) in fibers" :key="index"
-              size="small">{{ item.code }}</el-radio-button>
-          </el-radio-group>
-          <span v-if="fiber.length>0">&nbsp;&nbsp;鍏夌氦锛�</span>
-          <el-radio-group v-model="currentTab" size="small" v-if="fiber.length>0" @input="m=>handleChange(m,2)">
-            <el-radio-button :label="item.id" v-for="(item,index) in fiber" :key="index"
-              size="small">{{ item.color }}</el-radio-button>
-          </el-radio-group>
-          <el-form :inline="true" :model="otherForm" class="form-inline" label-width="50px" style="padding-top: 0;padding-left: 10px;" v-if="PROJECT=='妫�娴嬩腑蹇�'">
-            <el-form-item label="娓╁害:" style="margin-bottom: 0;">
-              <el-input v-model="otherForm.temperature" size="small" placeholder="" style="width: 90px;" @change="m=>subOtherForm(m,'temperature')"></el-input>
-              <span style="margin-left: 4px;">鈩�</span>
-            </el-form-item>
-            <el-form-item label="婀垮害:" style="margin-bottom: 0;">
-              <el-input v-model="otherForm.humidity" size="small" placeholder="" style="width: 90px;" @change="m=>subOtherForm(m,'humidity')"></el-input>
-              <span style="margin-left: 4px;">%</span>
-            </el-form-item>
-          </el-form>
+          <span v-if="casing.length>0&&tableLists.find(m=>m.templateId==currentTable)&&tableLists.find(m=>m.templateId==currentTable).templateName=='鎴愬搧缂嗘楠屽師濮嬭褰�'">&nbsp;&nbsp;濂楃锛�</span>
+          <el-select v-model="currentTab" placeholder="璇烽�夋嫨" @change="m=>handleChange(m,3)" v-if="casing.length>0&&tableLists.find(m=>m.templateId==currentTable)&&tableLists.find(m=>m.templateId==currentTable).templateName=='鎴愬搧缂嗘楠屽師濮嬭褰�'" size="small" :loading="getReportModelLoading" @focus="getReportModel(currentSample.id)">
+            <el-option
+              v-for="item in casing"
+              :key="item.id"
+              :label="item.color"
+              :value="item.id">
+              <span style="float: left">{{ item.color}}</span>
+              <el-tag :type="item.state==1?'success':'danger'" style="float: right;margin-top: 5px;" size="small">{{ item.state==1?'宸叉':'鏈' }}</el-tag>
+            </el-option>
+          </el-select>
+          <span v-if="fibers.length>0&&tableLists.find(m=>m.templateId==currentTable)&&tableLists.find(m=>m.templateId==currentTable).templateName!='娓╁害寰幆妫�楠屽師濮嬭褰�'">&nbsp;&nbsp;鍏夌氦甯︼細</span>
+          <el-select v-model="currentTab" placeholder="璇烽�夋嫨" @change="m=>handleChange(m,1)" v-if="fibers.length>0&&tableLists.find(m=>m.templateId==currentTable)&&tableLists.find(m=>m.templateId==currentTable).templateName!='娓╁害寰幆妫�楠屽師濮嬭褰�'" size="small" :loading="getReportModelLoading" @focus="getReportModel(currentSample.id)">
+            <el-option
+              v-for="item in fibers"
+              :key="item.value"
+              :label="item.code"
+              :value="item.id">
+              <span style="float: left">{{ item.code}}</span>
+              <el-tag :type="item.state==1?'success':'danger'" style="float: right;margin-top: 5px;" size="small">{{ item.state==1?'宸叉':'鏈' }}</el-tag>
+            </el-option>
+          </el-select>
+          <span v-if="fiber.length>0&&tableLists.find(m=>m.templateId==currentTable)&&tableLists.find(m=>m.templateId==currentTable).templateName!='娓╁害寰幆妫�楠屽師濮嬭褰�'">&nbsp;&nbsp;鍏夌氦锛�</span>
+          <el-select v-model="currentTab" placeholder="璇烽�夋嫨" @change="m=>handleChange(m,2)" v-if="fiber.length>0&&tableLists.find(m=>m.templateId==currentTable)&&tableLists.find(m=>m.templateId==currentTable).templateName!='娓╁害寰幆妫�楠屽師濮嬭褰�'" size="small" :loading="getReportModelLoading" @focus="getReportModel(currentSample.id)">
+            <el-option
+              v-for="item in fiber"
+              :label="item.bushColor+'-'+item.color"
+              :key="item.id"
+              :value="item.id">
+              <span style="float: left">{{ item.bushColor+'-'+item.color }}</span>
+              <el-tag :type="item.state==1?'success':'danger'" style="float: right;margin-top: 5px;" size="small">{{ item.state==1?'宸叉':'鏈' }}</el-tag>
+            </el-option>
+          </el-select>
+          <el-button type="primary" size="small" v-if="(isGet||tableLists.find(m=>m.templateId==currentTable)&&tableLists.find(m=>m.templateId==currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'&&temDataAcquisition)&&PROJECT=='妫�娴嬩腑蹇�'&&state==1" @click="getDataAcquisitionDevice" :loading="dataAcquisitionLoading">鏁版嵁閲囬泦</el-button>
+          <el-button :type="dataAcquisitionEidtAble?'':'primary'" size="small" v-if="(isGet||(tableLists.find(m=>m.templateId==currentTable)&&tableLists.find(m=>m.templateId==currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'))&&PROJECT=='妫�娴嬩腑蹇�'&&collected&&state==1" @click="dataAcquisitionEidtAble=!dataAcquisitionEidtAble">{{dataAcquisitionEidtAble?'鍏抽棴缂栬緫':'缂栬緫鏁伴噰'}}</el-button>
         </div>
       </div>
-      <div class="center-box" id="nav" v-loading="tableLoading" v-if="!tableLists.find(m=>m.templateId==currentTable)||tableLists.find(m=>m.templateId==currentTable).templateName!='娓╁害寰幆妫�楠屽師濮嬭褰�'">
-        <table border="1" class="tables" cellpadding="10" v-for="(item,index) in tableList" :key="index">
+      <!-- 甯歌妫�楠屽師濮嬭褰� -->
+      <div class="center-box" id="nav" v-loading="tableLoading" v-if="!tableLists.find(m=>m.templateId==currentTable)||(!tableLists.find(m=>m.templateId==currentTable).templateName.includes('鐢佃矾璇曢獙'))">
+        <table border="1" class="tables" cellpadding="10" v-for="(item,index) in tableList" :key="index+currentTable+currentSample.id">
           <tbody>
             <tr v-for="(m,i) in item.arr" :key="i">
               <td :id='item.templateId+"-"+n.i+"-"+n.r+"-"+n.c' v-for="(n,j) in m" :key="j"
-                v-if="n.v.mc==undefined || Object.keys(n.v.mc).length === 4" :colspan="n.v.mc&&n.v.mc.cs?n.v.mc.cs:1"
+              v-if="n.v.mc==undefined || Object.keys(n.v.mc).length === 4" :colspan="n.v.mc&&n.v.mc.cs?n.v.mc.cs:1"
                 :rowspan="n.v.mc&&n.v.mc.rs?n.v.mc.rs:1"
                 :style="`background:${n.v.bg?n.v.bg:''};color:${n.v.fc};font-size:${n.v.fs}px;width:${handleWidth(n)}px !important;height:${item.style.rowlen[n.r]}px;font-wight:${n.v.bl?'bold':''};`">
                 <div class="content" :class="`content-h-${n.v.ht} content-v-${n.v.vt}`"
                   :style="`width:${handleWidth(n)}px !important;min-height:${item.style.rowlen[n.r]}px;`">
-                  <template v-if="n.v.ps!=undefined && n.v.ps.value==='妫�楠屽��' && state==1">
+                  <template v-if="n.v.ps!=undefined && typeof n.v.ps.value ==='string'&& n.v.ps.value.includes('妫�楠屽��') && state==1">
                     <el-input v-if="getInspectionValueType(n.i) == 1" class="table_input" v-model="n.v.v"
-                              :disabled="getInspectionItemType(n.i) == 1 || (n.u != userId && n.u != undefined && n.u != '')"
+                              :disabled="(getInspectionItemType(n.i) == 1 && !dataAcquisitionEidtAble )|| (n.u != userId && n.u != undefined && n.u != '')"
                               @input="handleInput(n)"
-                              @change="m=>changeInput(m,`${item.templateId}-${n.r}-${n.c}-${n.i}`, n)" @mousewheel.native.prevent :key="'abc-'+'000'+index+'000'+i+'000'+j">
-                      <el-button slot="append" type="primary" icon="el-icon-edit" size="mini"
-                        v-if="getInspectionItemType(n.i) == 1" @click="getSystemValue(n)"></el-button>
+                              @change="m=>changeInput(m,`${item.templateId}-${n.r}-${n.c}-${n.i}`, n,'getDataType')" @mousewheel.native.prevent :key="'abc-'+'000'+index+'000'+i+'000'+j"
+                              @keydown.enter="changeInput('',`${item.templateId}-${n.r}-${n.c}-${n.i}`, n, 'getDataType')">
+                      <!-- <el-button slot="append" type="primary" icon="el-icon-edit" size="mini"
+                        v-if="getInspectionItemType(n.i) == 1" @click="getSystemValue(n)"></el-button> -->
                     </el-input>
                     <el-input v-else-if="getInspectionValueType(n.i) == 2" class="table_input" type="textarea"
                       v-model="n.v.v"
                       :disabled="getInspectionItemType(n.i) == 1 || (n.u != userId && n.u != undefined && n.u != '')"
-                      @change="m=>changeInput(m,`${item.templateId}-${n.r}-${n.c}-${n.i}`)" />
+                      @change="m=>changeInput(m,`${item.templateId}-${n.r}-${n.c}-${n.i}`,n,'getDataType')" />
                     <el-select v-else-if="getInspectionValueType(n.i) == 5" class="table_input" v-model="n.v.v"
-                      :disabled="state>1" @visible-change="e=>getDic(e,n.i)"
-                       @change="m=>changeInput(m,`${item.templateId}-${n.r}-${n.c}-${n.i}`)">
+                      :disabled="state>1||getInspectionItemType(n.i) == 1 || (n.u != userId && n.u != undefined && n.u != '')" @visible-change="e=>getDic(e,n.i)"
+                       @change="m=>changeInput(m,`${item.templateId}-${n.r}-${n.c}-${n.i}`,n,'getDataType')">
                       <el-option v-for="(e, i) in enumList" :key="i" :label="e.label" :value="e.value"></el-option>
                     </el-select>
                     <span :style="`font-family:${n.v.ff} !important;`"
@@ -327,19 +394,25 @@
                     <template v-if="PROJECT=='妫�娴嬩腑蹇�'||PROJECT=='瑁呭鐢电紗'&&getInspectionValueType(n.i) != 2 ">
                       <span v-if="n.v.v===1" :style="`font-family:${n.v.ff} !important;color: green;`">鍚堟牸</span>
                       <span v-else-if="n.v.v===0" :style="`font-family:${n.v.ff} !important;color: red;`">涓嶅悎鏍�</span>
+                      <span v-else-if="n.v.v===3" :style="`font-family:${n.v.ff} !important;color: #3A7BFA;`">涓嶅垽瀹�</span>
                       <span v-else :style="`font-family:${n.v.ff} !important;`">寰呭畾</span>
                     </template>
                   </template>
                   <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='璁惧缂栫爜' && state==1">
-                    <el-select v-model="n.v.v" placeholder="璁惧" @visible-change="e=>getEquipOptions(e,n.i)" remote
+                    <el-select v-model="n.v.v" placeholder="璁惧"
+                    class="table_input" @visible-change="e=>getEquipOptions(e,n.i)" remote
                       @change="(val)=>changeEquip(val, n)">
                       <el-option v-for="item in equipOptions" :key="item.value" :label="item.value" :value="item.value">
                       </el-option>
                     </el-select>
                   </template>
+                  <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='璁惧鍚嶇О' && state==1">
+                  <span>{{ n.v.v }}</span>
+                  </template>
                   <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='瑕佹眰鍊�' && state==1">
                     <span :style="`font-family:${n.v.ff} !important;`">{{getTell(n.i)}}</span>
                   </template>
+                  <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='璁$畻鍊�' && state==1"><span :style="`font-family:${n.v.ff} !important;`">{{ toFixed(n.v.v,n.v.ct) }}</span></template>
                   <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='鏈�缁堝��' && state==1">
                     <!-- <el-input class="table_input" type="textarea"
                       :disabled="getInspectionItemType(n.i) == 1 || (n.u != userId && n.u != undefined && n.u != '')"
@@ -355,11 +428,14 @@
                       <i class="el-icon-caret-left table_caret" style="width: 16px;" @click="caretSample(-1)" v-if="!currentFiberOpticTape&&!currentFiberOptic"></i>
                       <div :style="`font-family:${n.v.ff} !important;overflow: hidden;white-space: nowrap;width: calc(100% - 32px);`">{{currentSample.sampleCode}}</div>
                       <i class="el-icon-caret-right table_caret" style="width: 16px;"
-                      v-if="!currentFiberOpticTape&&!currentFiberOptic"@click="caretSample(1)"></i>
+                      v-if="!currentFiberOpticTape&&!currentFiberOptic" @click="caretSample(1)"></i>
                     </div>
                   </template>
                   <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='鏍峰搧鍨嬪彿'">
                     <div :style="`font-family:${n.v.ff} !important;`" v-if="currentSample.model!==undefined&&currentSample.model!==null">{{currentSample.model}}</div>
+                  </template>
+                  <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='璇曢獙鏍囧噯'">
+                    <div :style="`font-family:${n.v.ff} !important;`" v-if="currentSample.testRequirements!==undefined&&currentSample.testRequirements!==null">{{currentSample.testRequirements}}</div>
                   </template>
                   <template v-else-if="n.v.ps!=undefined && n.v.ps.value==='濂楃'">
                     <div style="display: flex;flex-wrap: nowrap;align-items: center;">
@@ -395,9 +471,91 @@
           </tbody>
         </table>
       </div>
-      <div class="center-box" v-loading="tableLoading" v-else>
+      <!-- 寮у瀭鐗规�ф楠屽師濮嬭褰� -->
+      <div v-loading="tableLoading" v-else-if="tableLists.find(m=>m.templateId==currentTable).templateName=='寮у瀭鐗规�ф楠屽師濮嬭褰�'">
         <el-divider></el-divider>
-        <h4 style="margin-bottom: 20px;font-size: 24px;font-weight: 400;">娓╁害寰幆妫�楠屽師濮嬭褰�</h4>
+        <h4 style="margin-bottom: 20px;font-size: 24px;font-weight: 400;text-align: center;">寮у瀭鐗规�ф楠屽師濮嬭褰�</h4>
+        <el-form :inline="true" :model="sagForm" class="form-inline" label-width="120px" style="justify-content: flex-start;display: flex;align-items: center;width: 100%;">
+          <el-form-item label="鏍峰搧缂栧彿" style="margin-bottom: 0;">
+            <el-input clearable v-model="sagForm.sampleCode" disabled size="small" placeholder=""></el-input>
+          </el-form-item>
+          <el-form-item label="鍨嬪彿" style="margin-bottom: 0;">
+            <el-input clearable v-model="sagForm.model" disabled size="small" placeholder=""></el-input>
+          </el-form-item>
+          <el-form-item label="妫�楠屼緷鎹�" style="margin-bottom: 0;">
+            <el-input clearable v-model="sagForm.inspection" disabled size="small" placeholder=""></el-input>
+          </el-form-item>
+          <el-form-item label="璁惧缂栧彿" style="margin-bottom: 0;">
+            <el-input clearable v-model="sagForm.methodName" disabled size="small" placeholder=""></el-input>
+          </el-form-item>
+          <el-form-item label="棰濆畾鎷夋柇鍔�/kN" style="margin-bottom: 0;">
+            <el-input clearable v-model="sagForm.tensileForce" disabled size="small" placeholder=""></el-input>
+          </el-form-item>
+          <el-form-item label="璺ㄨ窛闀垮害/m" style="margin-bottom: 0;">
+            <el-input clearable v-model="sagForm.spanLength" disabled size="small" placeholder=""></el-input>
+          </el-form-item>
+          <el-form-item label="杞借嵎/kN" style="margin-bottom: 0;">
+            <el-input clearable v-model="sagForm.load" disabled size="small" placeholder=""></el-input>
+          </el-form-item>
+        </el-form>
+        <el-divider></el-divider>
+        <div class="container">
+          <el-button class="right-button" type="primary" size="small" @click="addSag">娣� 鍔�</el-button>
+        </div>
+        <el-table :data="sagData" class="custom-table" border>
+          <el-table-column label="楂樺害 h mm" prop="height" align="center">
+          </el-table-column>
+          <el-table-column label="寮у瀭  mm" prop="sag" align="center">
+          </el-table-column>
+          <el-table-column label="瀵肩嚎娓╁害鈩�" align="center">
+            <el-table-column label="1" prop="one" align="center">
+              <template slot-scope="scope">
+                <el-input v-model="scope.row.one"  style="width: 100%;"></el-input>
+              </template>
+            </el-table-column>
+            <el-table-column label="2" prop="two" align="center">
+              <template slot-scope="scope">
+                <el-input v-model="scope.row.two"  style="width: 100%;"></el-input>
+              </template>
+            </el-table-column>
+            <el-table-column label="3" prop="three" align="center">
+              <template slot-scope="scope">
+                <el-input v-model="scope.row.three"  style="width: 100%;"></el-input>
+              </template>
+            </el-table-column>
+            <el-table-column label="4" prop="four" align="center">
+              <template slot-scope="scope">
+                <el-input v-model="scope.row.four"  style="width: 100%;"></el-input>
+              </template>
+            </el-table-column>
+            <el-table-column label="5" prop="five" align="center">
+              <template slot-scope="scope">
+                <el-input v-model="scope.row.five"  style="width: 100%;"></el-input>
+              </template>
+            </el-table-column>
+            <el-table-column label="6" prop="six" align="center">
+              <template slot-scope="scope">
+                <el-input v-model="scope.row.six"  style="width: 100%;"></el-input>
+              </template>
+            </el-table-column>
+          </el-table-column>
+          <el-table-column label="骞冲潎娓╁害鈩�" prop="average" align="center">
+          </el-table-column>
+          <el-table-column label="瀹ゆ俯鈩�" prop="temperature" align="center">
+          </el-table-column>
+          <el-table-column label="寮犲姏kN" prop="remark" align="center">
+          </el-table-column>
+          <el-table-column label="鎿嶄綔" align="center">
+            <template slot-scope="scope">
+              <el-button type="text" size="small" @click="deleteSag(scope.$index)"><span style="color:red">鍒犻櫎</span></el-button>
+            </template>
+          </el-table-column>
+        </el-table>
+      </div>
+      <!-- 娓╁害寰幆妫�楠屽師濮嬭褰� -->
+      <div v-loading="tableLoading" v-else-if="tableLists.find(m=>m.templateId==currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'">
+        <el-divider></el-divider>
+        <h4 style="margin-bottom: 20px;font-size: 24px;font-weight: 400;text-align: center;">娓╁害寰幆妫�楠屽師濮嬭褰�</h4>
         <el-form :inline="true" :model="wareForm" class="form-inline" label-width="100px" style="justify-content: flex-start;display: flex;align-items: center;width: 100%;">
         <el-form-item label="鍨嬪彿:" style="margin-bottom: 0;">
           <el-input clearable v-model="wareForm0.model" disabled size="small" placeholder=""></el-input>
@@ -436,7 +594,7 @@
             <el-input clearable v-model="equipForm.value0" disabled size="small" placeholder=""></el-input>
           </el-form-item>
           <el-form-item label="浠櫒缂栧彿:">
-            <el-select v-model="equipForm.code0" placeholder="璇烽�夋嫨" size="small">
+            <el-select v-model="equipForm.code0" :disabled="state>1" placeholder="璇烽�夋嫨" size="small">
               <el-option
                 v-for="item in equipOptions"
                 :key="item.value"
@@ -449,7 +607,7 @@
             <el-input clearable v-model="equipForm.value1" disabled size="small" placeholder=""></el-input>
           </el-form-item>
           <el-form-item label="浠櫒缂栧彿:">
-            <el-select v-model="equipForm.code1" placeholder="璇烽�夋嫨" size="small">
+            <el-select v-model="equipForm.code1" :disabled="state>1" placeholder="璇烽�夋嫨" size="small">
               <el-option
                 v-for="item in equipOptions"
                 :key="item.value"
@@ -464,134 +622,202 @@
           ref="wareTableData"
           border
           v-loading="wareTableDataLoading"
-          style="width: 100%;margin-bottom: 30px;" align="center">
+          style="width: 100%;margin-bottom: 30px;" align="center" v-if="wareForm.inspectionItemSubclass!='20(甯告俯)'&&wareForm.inspectionItemSubclass!='20'||(wareForm.inspectionItemSubclass=='20(甯告俯)'&&wareForm.inspectionItem==1)||(wareForm.inspectionItemSubclass=='20'&&wareForm.inspectionItem==numOptions.length)">
           <el-table-column
             label="搴忓彿"
             type="index"
-            width="65"
+            width="59"
             align="center"
             >
           </el-table-column>
           <el-table-column
             prop="bushColor"
             label="绠¤壊鏍�"
-            width="120"
+            width="75"
             align="center">
           </el-table-column>
           <el-table-column
             prop="code"
             label="鍏夌氦甯︾紪鍙�"
-            width="150"
+            width="105"
             align="center">
           </el-table-column>
           <el-table-column
             prop="color"
             label="鍏夌氦鑹叉爣"
             align="center"
-            width="120">
+            width="90">
           </el-table-column>
-          <el-table-column
-            prop="inspectionItemClass"
-            label="鍏夌氦椤圭洰"
-            align="center"
-            width="130">
-          </el-table-column>
-          <el-table-column
-            prop="value0"
-            label="澶栫"
-            align="center"
-            width="130">
-            <template slot-scope="scope">
-              <el-input size="small" v-model="scope.row.value0" placeholder="" @change="m=>changeItem(scope.row)"></el-input>
-            </template>
-          </el-table-column>
-          <el-table-column
-            prop="value1"
-            label="鍐呯"
-            align="center"
-            width="130">
-            <template slot-scope="scope">
-              <el-input size="small" v-model="scope.row.value1" placeholder="" @change="m=>changeItem(scope.row)"></el-input>
-            </template>
-          </el-table-column>
-          <el-table-column
-            prop="comValue"
-            align="center"
-            label="琛板噺绯绘暟"
-            min-width="150">
-          </el-table-column>
-          <el-table-column
-            prop="resValue"
-            label="琛板噺宸�"
-            align="center"
-            v-if="wareForm.inspectionItemSubclass!='20(甯告俯)'"
-            min-width="150">
-          </el-table-column>
-          <el-table-column
-            prop="insResult"
-            label="缁撹"
-            align="center"
-            min-width="150" v-if="wareForm.inspectionItemSubclass!='20(甯告俯)'">
-            <template slot-scope="scope">
-              <span v-if="scope.row.insResult===1" style="color: green;">鍚堟牸</span>
-              <span v-else-if="scope.row.insResult===0" style="color: red;">涓嶅悎鏍�</span>
-              <span v-else>寰呭畾</span>
-            </template>
-          </el-table-column>
+           <template v-for="(item,index) in wareLength">
+            <el-table-column
+              prop="value0"
+              label="澶栫"
+              align="center"
+              width="100" :key="(new Date().getTime())+'1234567'">
+              <template slot="header">
+                {{ '澶栫'+(index+1) }}
+              </template>
+              <template slot-scope="scope">
+                <el-input size="small" v-model="scope.row.arr[index].value0" placeholder="" :disabled="state>1||!dataAcquisitionEidtAble" @change="m=>changeItem(scope.row.arr[index])"></el-input>
+              </template>
+            </el-table-column>
+            <el-table-column
+              prop="value1"
+              label="鍐呯"
+              align="center"
+              width="100" :key="(new Date().getTime())+'23333333'">
+              <template slot="header">
+                {{ '鍐呯'+(index+1) }}
+              </template>
+              <template slot-scope="scope">
+                <el-input size="small" :disabled="state>1||!dataAcquisitionEidtAble"  v-model="scope.row.arr[index].value1" placeholder="" @change="m=>changeItem(scope.row.arr[index])"></el-input>
+              </template>
+            </el-table-column>
+            <el-table-column
+              prop="comValue"
+              align="center"
+              min-width="150" :key="(new Date().getTime())+'364654654'">
+              <template slot="header">
+                {{ '琛板噺绯绘暟'+item }}
+              </template>
+              <template slot-scope="scope">
+                <span>{{ scope.row.arr[index].comValue }}</span>
+              </template>
+            </el-table-column>
+            <el-table-column
+              prop="resValue"
+              label="琛板噺宸�"
+              align="center"
+              v-if="wareForm.inspectionItemSubclass!='20(甯告俯)'"
+              min-width="90" :key="(new Date().getTime())+'434634634634'">
+              <template slot="header">
+                {{ '琛板噺宸�'+(index+1) }}
+              </template>
+              <template slot-scope="scope">
+                <span>{{ scope.row.arr[index].resValue }}</span>
+              </template>
+            </el-table-column>
+            <el-table-column
+              prop="insResult"
+              label="缁撹"
+              align="center"
+              min-width="70" v-if="wareForm.inspectionItemSubclass!='20(甯告俯)'" :key="(new Date().getTime())+'53457689809808-'">
+              <template slot="header">
+                {{ '缁撹'+(index+1) }}
+              </template>
+              <template slot-scope="scope">
+                <span v-if="scope.row.arr[index].insResult===1" style="color: green;">鍚堟牸</span>
+                <span v-else-if="scope.row.arr[index].insResult===0" style="color: red;">涓嶅悎鏍�</span>
+                <span v-else-if="scope.row.arr[index].insResult===3" style="color: #3A7BFA;">涓嶅垽瀹�</span>
+                <span v-else>寰呭畾</span>
+              </template>
+            </el-table-column>
+           </template>
         </el-table>
+      </div>
+      <!-- 鐑惊鐜�/娓╁崌璇曢獙妫�楠屽師濮嬭褰� -->
+      <div v-loading="tableLoading" v-else-if="tableLists.find(m=>m.templateId==currentTable).templateName.includes('鐑惊鐜�')||tableLists.find(m=>m.templateId==currentTable).templateName.includes('娓╁崌璇曢獙')">
+        <el-divider></el-divider>
+        <h4 style="margin-bottom: 20px;font-size: 24px;font-weight: 400;text-align: center;">{{tableLists.find(m=>m.templateId==currentTable).templateName}}</h4>
+        <el-form :inline="true" :model="wareForm" class="form-inline" label-width="100px" style="justify-content: flex-start;display: flex;align-items: center;width: 100%;">
+          <el-form-item label="浠櫒鍚嶇О:" style="margin-bottom: 0;">
+            <el-input clearable v-model="equipForm.value0" disabled size="small" placeholder=""></el-input>
+          </el-form-item>
+          <el-form-item label="浠櫒鍚嶇О:" style="margin-bottom: 0;">
+            <el-input clearable v-model="equipForm.value1" disabled size="small" placeholder=""></el-input>
+          </el-form-item>
+          <el-form-item label="鍨嬪彿:" style="margin-bottom: 0;">
+            <el-input clearable v-model="thermalCyclingInfo.model" disabled size="small" placeholder=""></el-input>
+          </el-form-item>
+          <el-form-item label="璇曢獙鏂规硶:" style="margin-bottom: 0;">
+            <el-input clearable v-model="thermalCyclingInfo.methodName" disabled size="small" placeholder=""></el-input>
+          </el-form-item>
+        </el-form>
+        <el-divider></el-divider>
+        <el-form :inline="true" :model="equipForm" label-width="100px" style="justify-content: flex-start;display: flex;align-items: center;width: 100%;">
+          <el-form-item label="浠櫒缂栧彿:">
+            <el-select v-model="equipForm.code0" :disabled="state>1" placeholder="璇烽�夋嫨" size="small">
+              <el-option
+                v-for="item in equipOptions"
+                :key="item.value"
+                :label="item.value"
+                :value="item.value">
+              </el-option>
+            </el-select>
+          </el-form-item>
+          <el-form-item label="浠櫒缂栧彿:">
+            <el-select v-model="equipForm.code1" :disabled="state>1" placeholder="璇烽�夋嫨" size="small">
+              <el-option
+                v-for="item in equipOptions"
+                :key="item.value"
+                :label="item.value"
+                :value="item.value">
+              </el-option>
+            </el-select>
+          </el-form-item>
+          <el-form-item label="寰幆娆℃暟:" v-if="thermalCyclingInfo.inspectionItemClass=='鐩存祦鐢甸樆'">
+            <el-input-number v-model="thermalCyclingInfo.inspectionItem" :min="1" :max="thermalCyclingInfo.max" label="" style="margin-top:4px;width: 190px;" size="small" @change="thermalCyclingChange"></el-input-number>
+          </el-form-item>
+          <el-button type="primary" size="small" style="margin-bottom: 22px;margin-left: 30px;" @click="handleAddThermal" v-if="state==1">鏂板</el-button>
+          <el-button size="small" style="margin-bottom: 22px;" @click="handleDeleteThermal" v-if="state==1">鍒犻櫎</el-button>
+        </el-form>
+        <div class="table-container" v-loading="thermalCyclingLoading">
+          <table border="1" cellpadding="10" class="thermal-table">
+            <tr>
+              <td>妫�楠岄」鐩�</td>
+              <td :colspan="thermalCyclingInfo.length">妫�楠岃繃绋嬪��</td>
+              <td style="width: 100px;">缁撹</td>
+            </tr>
+            <tr v-for="(item,index) in thermalCyclingInfo.arr">
+              <td style="width: 100px;text-align: center;">{{ item.name }}</td>
+              <td v-for="(m,i) in thermalCyclingInfo.length" style="min-width: 150px;">
+                <div style="display: flex;align-items: center;margin-bottom: 5px;">
+                  <label style="width: 100px;white-space: nowrap;font-size: 12px;">娓╁害:</label>
+                  <el-input clearable size="small" placeholder="" v-model="item.arr[i].value0" :disabled="state>1" @change="m=>saveThermalCycling(m,item,'value0')"></el-input>
+                  <span style="font-size: 12px;margin-left: 13px;margin-right: 13px;"> 鈩�</span>
+                </div>
+                <div style="display: flex;align-items: center;" v-if="item.name!='鐜娓╁害'&&thermalCyclingInfo.inspectionItemClass=='鐩存祦鐢甸樆'">
+                  <label style="width: 100px;white-space: nowrap;font-size: 12px;">鐩存祦鐢甸樆:</label>
+                  <el-input clearable size="small" :disabled="state>1" placeholder="" v-model="item.arr[i].value1" @change="saveThermalCycling"></el-input>
+                  <span style="margin-left: 5px;font-size: 12px;"> 惟/km</span>
+                </div>
+              </td>
+              <td>
+                <template v-if="item.name=='鐜娓╁害'||item.name=='瀵肩嚎娓╁害'">
+                  <span>/</span>
+                </template>
+                <template v-else>
+                  <span v-if="item.insResult===1" style="color: green;">鍚堟牸</span>
+                  <span v-else-if="item.insResult===0" style="color: red;">涓嶅悎鏍�</span>
+                  <span v-else-if="item.insResult===3" style="color: #3A7BFA;">涓嶅垽瀹�</span>
+                  <span v-else>寰呭畾</span>
+                </template>
+              </td>
+            </tr>
+          </table>
+        </div>
+      </div>
+      <!-- 鐢佃矾璇曢獙 -->
+      <div v-else-if="tableLists.find(m=>m.templateId==currentTable).templateName.includes('鐢佃矾璇曢獙')" style="width: 100%;overflow-x: auto;overflow-y: visible;">
+        <!-- <Circuit></Circuit> -->
+        <CircuitParameters1 v-if="currentTableState==0" :insProduct="currentSample.insProduct" :orderId="id" :sampleId="currentSample.id" :state="state" :num="currentSample.num1"></CircuitParameters1>
+        <CircuitParameters2 v-if="currentTableState==1" :insProduct="currentSample.insProduct" :orderId="id" :sampleId="currentSample.id" :state="state" :num="currentSample.num1"></CircuitParameters2>
       </div>
       <el-upload :action="action"
       :data="{
         orderId:id
       }"
-      v-show="state==1&&fileAdd"
+      v-if="state==1&&fileAdd"
       :on-success="handleSuccessUp" :show-file-list="false"
         accept='.jpg,.jpeg,.png,.gif,.doc,.docx,.xls,.xlsx,.ppt,.pptx,.pdf,.zip,.rar' :headers="headers" :on-change="beforeUpload"
         style="width: 80px !important;"
         :on-error="onError" ref='upload'>
-        <el-button size="small" type="primary">闄勪欢涓婁紶</el-button></el-upload>
+        <el-button size="small" type="primary" v-if="state==1">闄勪欢涓婁紶</el-button></el-upload>
       <ValueTable class="value-table" ref="fileList" :url="$api.insOrderPlan.getFileList"
         :componentData="componentData0"
         :delUrl="$api.insOrderPlan.delfile"
         :key="upIndex" style="height: 100%;margin-top: 16px;"/>
     </div>
-    <el-drawer title="鍏夌氦鍒囨崲" :visible.sync="fiberOpticVisible" :size="500">
-      <el-table class="el-table" ref="fiberOpticTable" :data="fiberOptic" height="100%" tooltip-effect="dark" border
-        highlight-current-row @row-click="handleChangeOptic" :row-class-name="tableRowClassName"
-        :current-row-key="currentKey2" :row-key="record=>record.index" v-if="fiberOpticVisible">
-        <el-table-column type="index" align="center" label="搴忓彿" width="70px" :key="Math.random()">
-        </el-table-column>
-        <el-table-column prop="bushColor" label="绠″鑹叉爣" min-width="100px" show-overflow-tooltip></el-table-column>
-        <el-table-column prop="color" label="鍏夌氦鑹叉爣" min-width="100px" show-overflow-tooltip></el-table-column>
-        <el-table-column prop="model" label="鍏夌氦瑙勬牸" min-width="130px" show-overflow-tooltip
-         ></el-table-column>
-        <el-table-column prop="standard" label="鍙傝�冩爣鍑�" width="100px" show-overflow-tooltip></el-table-column>
-      </el-table>
-    </el-drawer>
-    <el-drawer title="鍏夌氦甯﹀垏鎹�" :visible.sync="fiberOpticTapeVisible" :size="500">
-      <el-table class="el-table" ref="fiberOpticTapeTable" :data="fiberOpticTape" height="100%" tooltip-effect="dark" border
-        highlight-current-row @row-click="handleChangeTape" :row-class-name="tableRowClassName"
-        :current-row-key="currentKey1" :row-key="record=>record.index" v-if="fiberOpticTapeVisible">
-        <el-table-column type="index" align="center" label="搴忓彿" width="70px" :key="Math.random()">
-        </el-table-column>
-        <el-table-column prop="code" label="鍏夌氦甯︾紪鍙�" min-width="110px" show-overflow-tooltip></el-table-column>
-        <el-table-column prop="model" label="鍏夌氦甯﹁鏍�" min-width="110px" show-overflow-tooltip></el-table-column>
-        <el-table-column prop="standard" label="鍙傝�冩爣鍑�" width="90px" show-overflow-tooltip></el-table-column>
-        <el-table-column prop="num" label="鍏夌氦妫�娴嬮噺" min-width="110px" show-overflow-tooltip
-          ></el-table-column>
-      </el-table>
-    </el-drawer>
-    <el-drawer title="濂楃鍒囨崲" :visible.sync="bushingVisible" :size="500">
-      <el-table class="el-table" ref="bushingTable" :data="bushing" height="100%" tooltip-effect="dark" border
-        highlight-current-row @row-click="handleChangeBushing" :row-class-name="tableRowClassName"
-        :current-row-key="currentKey0" :row-key="record=>record.index" v-if="bushingVisible">
-        <el-table-column type="index" align="center" label="搴忓彿" width="70px" :key="Math.random()">
-        </el-table-column>
-        <el-table-column prop="color" label="绠¤壊鏍�" min-width="100px" show-overflow-tooltip></el-table-column>
-        <el-table-column prop="standNum" label="鏍囬噺" min-width="100px" show-overflow-tooltip></el-table-column>
-        <el-table-column prop="testNum" label="娴嬭瘯閲�" min-width="100px" show-overflow-tooltip></el-table-column>
-      </el-table>
-    </el-drawer>
     <el-drawer title="鏍峰搧鍒囨崲" :visible.sync="sampleVisible" :size="500">
       <el-table class="el-table" ref="productTable" :data="sampleProduct" height="100%" tooltip-effect="dark" border
         highlight-current-row @row-click="handleChangeSample" :row-class-name="tableRowClassName"
@@ -606,6 +832,7 @@
               size="medium" style="margin-right: 5px;">{{item.label}}</el-tag>
           </template>
         </el-table-column>
+        <el-table-column prop="checkName" label="妫�楠屼汉" min-width="80px" show-overflow-tooltip></el-table-column>
         <el-table-column prop="isLeave" label="鏄惁鐣欐牱" width="95px" show-overflow-tooltip align="center">
           <template slot-scope="scope">
             <span>{{ scope.row.isLeave==0?'鍚�':'鏄�' }}</span>
@@ -613,11 +840,11 @@
         </el-table-column>
         <!-- 妫�楠屽崟浼氭湁涓�涓槸鍚︽湁閰嶅鏍峰搧瀛楁鎺у埗鏄剧ず -->
         <el-table-column prop="joinModel" label="閰嶅鏍峰搧鍨嬪彿" min-width="130px" show-overflow-tooltip
-          v-if="insOrder.mating>0"></el-table-column>
+        v-if="insOrder.mating>0"></el-table-column>
         <el-table-column prop="joinName" label="閰嶅鏍峰搧鍚嶇О" min-width="130px" show-overflow-tooltip
-          v-if="insOrder.mating>0"></el-table-column>
+        v-if="insOrder.mating>0"></el-table-column>
         <el-table-column prop="joinNum" label="閰嶅鏍峰搧鏁伴噺" min-width="130px" show-overflow-tooltip
-          v-if="insOrder.mating>0"></el-table-column>
+        v-if="insOrder.mating>0"></el-table-column>
       </el-table>
     </el-drawer>
     <el-drawer title="浠诲姟鍒囨崲" :visible.sync="taskVisible" :size="500">
@@ -651,20 +878,90 @@
         <el-button type="primary" @click="submit()">纭� 瀹�</el-button>
       </span>
     </el-dialog>
+    <el-dialog title="鏁版嵁閲囬泦" :visible.sync="dataGetDia" :close-on-click-modal="false" :close-on-press-escape="false" :show-close="false" custom-class="custom-dialog">
+      <div>
+        <table border="1" cellpadding="10" class="thermal-table">
+          <tr>
+            <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.faName}}</td>
+              <td>{{ item.child[0].name }}</td>
+              <td style="text-align: left;">
+                <el-checkbox-group
+                  v-model="getDataIndex" :max="item.child[0].maxNum">
+                  <el-checkbox v-for="(n,j) in item.child[0].arr" :label="j" :key="j">{{n}}</el-checkbox>
+                </el-checkbox-group>
+              </td>
+            </tr>
+            <tr v-for="(m,i) in item.child" :key="i+'bbbbbbbbbbbbbb'" v-show="i>0">
+              <td>{{ m.name }}</td>
+              <td style="text-align: left;">
+                <el-checkbox-group
+                  v-model="getDataIndex" :max="m.maxNum">
+                  <el-checkbox v-for="(n,j) in m.arr" :label="j" :key="j">{{n}}</el-checkbox>
+                </el-checkbox-group>
+              </td>
+            </tr>
+          </template>
+        </table>
+      </div>
+      <span slot="footer" class="dialog-footer">
+        <el-button type="primary" @click="submitDataGet()" :loading="getDataIndexLoading">纭� 瀹�</el-button>
+      </span>
+    </el-dialog>
+    <el-dialog
+      title="閫夋嫨鐢佃矾妫�楠屾ā鏉跨増鏈�"
+      :visible.sync="versionDialogVisible"
+      width="30%"
+      :close-on-click-modal="false"
+      :close-on-press-escape="false"
+      :show-close="false">
+      <el-radio-group v-model="currentTableState">
+        <el-radio :label="0">鐢佃皟-鐢佃矾妫�楠屽師濮嬭褰�</el-radio>
+        <el-radio :label="1">闈炵數璋�-鐢佃矾妫�楠屽師濮嬭褰�</el-radio>
+      </el-radio-group>
+      <span slot="footer" class="dialog-footer">
+        <el-button type="primary" :loading="versionLoading" @click="saveVersion">纭� 瀹�</el-button>
+      </span>
+    </el-dialog>
   </div>
 </template>
 
 <script>
   import ValueTable from '../../tool/value-table.vue'
+  import Circuit from './circuit.vue'
   import file from '../../../util/file'
   import excelFunction from '../../../util/excelFountion'
+  import CircuitParameters1 from './circuit-parameters1.vue'
+  import CircuitParameters2 from './circuit-parameters2.vue'
   export default {
-    props: ['sonLaboratory', 'orderId', 'state'],
+    props: ['sonLaboratory', 'orderId', 'state','inspectorList','version','orderStateId'],
     components: {
       ValueTable,
+      Circuit,
+      CircuitParameters1,
+      CircuitParameters2
     },
     data() {
       return {
+        versionLoading:false,
+        versionDialogVisible:false,
+        currentTableState:0,
+        sagData: [],
+        sagForm: {
+          sampleCode: null,
+          model: null,
+          inspection: null,
+          methodName: null,
+          tensileForce: null,
+          spanLength: null,
+          load: null
+        },
+        dataGetDia:false,
         wareTableDataLoading:false,
         fileAdd:false,
         sampleVisible: false,
@@ -748,6 +1045,8 @@
           requiredUp: []
         },
         upIndex: 0,
+        changeType:null,
+        getReportModelLoading:false,
         insOrder: {},
         sampleProduct: [],
         typeList: [],
@@ -776,9 +1075,6 @@
         verifyUser: null,
         personList: [],
         enumList: [],
-        fiberOpticVisible:false,
-        fiberOpticTapeVisible:false,
-        bushingVisible:false,
         fiberOpticTape:[],//鍏夌氦甯﹀垪琛�
         fiberOptic:[],//鍏夌氦鍒楄〃
         bushing:[],//濂楃鍒楄〃
@@ -790,6 +1086,7 @@
         temptList:null,
         fiber:[],
         fibers:[],
+        casing:[],
         currentTab:null,
         wareForm:{
           inspectionItem:1,
@@ -798,13 +1095,7 @@
         wareForm0:{},
         numOptions:[],
         temperatureOptions:[],
-        wareTableData:[
-          {}
-        ],
-        otherForm:{
-          humidity:null,
-          temperature:null,
-        },
+        wareTableData:[],
         equipForm:{
           value0:null,
           code0:null,
@@ -813,8 +1104,33 @@
         },
         result: null,
         worker: null,
+        worker0: null,
+        wareLength:[],
+        dataAcquisitionInfo:{},
+        dataAcquisitionInfoNew:{},
+        dataAcquisitionEidtAble:false,
+        isGet:false,
+        dataAcquisitionLoading:false,
+        collected:false,
+        // 鐑惊鐜�---寮�濮�
+        thermalCyclingInfo:{
+          max:0,
+          inspectionItem:1,
+          arr:[],
+          length:1,
+          inspectionItemClass:null,
+        },
+        thermalCyclingLoading:false,
+        temDataAcquisition:false,
+        getData:[],
+        getDataIndex:[],
+        getDataIndexLoading:false,
+        changeType:null,
+        getDataTypeId:'',
+        getDataType:null,
       }
     },
+    // 鐢ㄤ簬涓婁紶鏂囦欢鐨勪俊鎭�
     computed: {
 			headers() {
 				return {
@@ -837,8 +1153,11 @@
       this.getAuthorizedPerson()
       this.scrollInit()
       this.getPower()
+      this.startWorker()
+      this.currentTableState = this.version
     },
     watch: {
+      // 鐩戝惉浠诲姟id锛岃幏鍙栦换鍔′俊鎭�
       id(val) {
         this.loading = true
         this.$axios.post(this.$api.insOrderPlan.doInsOrder, {
@@ -857,37 +1176,38 @@
           if(!res.data.sampleProduct||res.data.sampleProduct.length==0){
             return this.$message.error('璇ヤ换鍔℃病鏈夋牱鍝佷俊鎭�')
           }
+          // 璧嬪�煎綋鍓嶆牱鍝佸垪琛�
           this.sampleProduct = res.data.sampleProduct
           this.currentSample = this.HaveJson(this.sampleProduct[0])
           let insProduct = this.HaveJson(this.currentSample.insProduct)
-          if(insProduct&&insProduct.length>0){
-            let {temperature,humidity} = insProduct[0];
-            this.otherForm = {
-              temperature:temperature?temperature:null,
-              humidity:humidity?humidity:null,
-            }
-          }
+          // 鑾峰彇褰撳墠鏍峰搧鐨勬楠岄」
           let list = await this.getCurrentProduct(this.currentSample.id,0)
           this.currentSample.insProduct = this.HaveJson(list)
-          // console.log(this.currentSample)
+          // 鍒濆鍖栦紶閫掑埌鍚庣鐨勫弬鏁�
+          this.param = {}
+          this.changeType = 0;
           this.currentSample.insProduct.forEach(a => {
-            this.param[a.id] = {
-              insValue: [],
-              comValue: [],
-              resValue: null,
-              equipValue: [],
-              equipName: [],
-              insResult: null
+            // 鏄惁涓烘垚鍝佺數缂嗕笅鐨勬澗濂楃椤圭洰锛屼笉鏄垯鎵ц鍒濆鍖�
+            if(this.handleCasing(a.inspectionItem)){
+              this.param[a.id] = {
+                insValue: [],
+                comValue: [],
+                resValue: null,
+                equipValue: [],
+                equipName: [],
+                insResult: null
+              }
             }
           })
-          this.getReportModel(this.currentSample.id)
+          this.determineWhetherToCollectData()//鏄惁闇�瑕佹暟閲�
+          this.getReportModel(this.currentSample.id)//鑾峰彇濂楃銆佸厜绾ゅ甫銆佸厜绾や俊鎭�
           if (this.currentSample.index == undefined) this.currentSample['index'] = 1
           let bushing = this.currentSample.bushing
-          this.getTableLists();
+          this.getTableLists();//澶勭悊妯℃澘鍒楄〃淇℃伅
+
           this.componentData.currentId = val;
           this.currentKey = 1;
-
-          // 娓呯┖鍏夌氦閰嶇疆鐩稿叧鏁版嵁
+          // 娓呯┖鍏夌氦閰嶇疆鐩稿叧鏁版嵁---涓嬮潰淇℃伅鏆傛椂鍙拷鐣�
           this.fiberOpticTape = []
           this.currentFiberOpticTape = null;
           this.fiberOptic = []
@@ -900,24 +1220,76 @@
           }
         })
       },
+      // 鐩戝惉褰撳墠妯℃澘鍙樺寲
       currentTable(val1, val0) {
         if (val0 != null && val1 != val0) {
-          this.tableLists.forEach((m, i) => {
+          // if(this.tableLists.find(m=>m.templateId==val1)&&(this.tableLists.find(m=>m.templateId==val1).templateName=='鎴愬搧缂嗘楠屽師濮嬭褰�')){
+          //   if(this.casing.length>0){
+          //     this.handleChange(this.casing[0].id,3)
+          //   }
+          //   return
+          // }
+          if(this.changeType&&this.changeType>0){
+            // 濡傛灉鏄厜绾ゃ�佸厜绾ゅ甫锛屽垯涓嶆墽琛屼笅闈㈡搷浣�
+            return
+          }
+          this.tableLists.forEach(async (m, i) => {
             if (m.templateId == val1) {
-              this.tableList = null;
-              this.tableList = [(this.tableLists[i])];
-              this.handleTableData()
+              let list = await this.getCurrentProduct(this.currentSample.id,0)
+              this.currentSample.insProduct = this.HaveJson(list)//璧嬪�煎綋鍓嶆牱鍝佺殑妫�楠岄」
+              this.param = {}//鍒濆鍖栦紶鍒板悗绔殑鍙傛暟
+              this.currentSample.insProduct.forEach((a, j) => {
+                if(this.handleCasing(a.inspectionItem)){
+                  this.param[a.id] = {
+                    insValue: [],
+                    comValue: [],
+                    resValue: null,
+                    equipValue: [],
+                    equipName: [],
+                    insResult: null
+                  }
+                }
+              })
+              this.getReportModel(this.currentSample.id)//鑾峰彇濂楃銆佸厜绾ゅ甫銆佸厜绾や俊鎭�
+              // 鍘婚噸妯℃澘锛岃繑鍥炴湁鍑犱釜妯℃澘
+              const mySet1 = new Set();
+              this.tableLists = this.currentSample.insProduct.filter(m => {
+                let num0 = mySet1.size;
+                if (m.templateId != null&&m.template != null) {
+                  try {
+                    mySet1.add(JSON.stringify({
+                      template: m.template,
+                      templateId: m.templateId
+                    }))
+                  } catch (error) {
+                    console.log(222,error);
+                  }
+                }
+                let num1 = mySet1.size;
+                if (num1 > num0) {
+                  return m
+                }
+              });
+              if (this.tableLists && this.tableLists.length > 0) {
+                this.tableList = null;
+                this.tableList = this.tableLists.filter(m => m.templateId == val1)
+                // 瀵规ā鏉胯繘琛屽鐞�
+                this.handleTableData()
+              }
             }
           })
         }
       },
+      // 鐗规畩妫�楠岄」--鐩戝惉璁惧淇℃伅鏀瑰彉
       equipForm:{
         deep:true,
         handler(val){
-          if(this.tableLists.find(m=>m.templateId==this.currentTable)&&this.tableLists.find(m=>m.templateId==this.currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'&&this.equipOptions&&this.equipOptions.length>0){
+          if(this.tableLists.find(m=>m.templateId==this.currentTable)&&(this.tableLists.find(m=>m.templateId==this.currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'||this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('鐑惊鐜�')||this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('娓╁崌璇曢獙'))&&this.equipOptions&&this.equipOptions.length>0){
+            // 鍒濆鍖栬澶囦俊鎭�
             this.param[this.currentSample.insProduct[0].id].equipValue = []
             this.param[this.currentSample.insProduct[0].id].equipName = []
             if(this.equipForm.code0){
+              // 璧嬪�肩涓�涓澶囩殑淇℃伅
               this.equipForm.value0 = this.equipOptions.find(m=>m.value==this.equipForm.code0).label
               this.param[this.currentSample.insProduct[0].id].equipValue.push({
                 i:this.currentSample.insProduct[0].id,
@@ -933,6 +1305,7 @@
               })
             }
             if(this.equipForm.code1){
+              // 璧嬪�肩浜屼釜璁惧鐨勪俊鎭�
               this.equipForm.value1 = this.equipOptions.find(m=>m.value==this.equipForm.code1).label
               this.param[this.currentSample.insProduct[0].id].equipValue.push({
                 i:this.currentSample.insProduct[0].id,
@@ -947,35 +1320,303 @@
                 }
               })
             }
+            // 淇濆瓨鏁版嵁
             this.saveInsContext()
           }
         }
-      }
+      },
     },
     beforeDestroy() {
       // 鍦ㄧ粍浠堕攢姣佸墠纭繚鍋滄 Worker锛岄伩鍏嶅唴瀛樻硠婕�
       this.stopWorker();
     },
     methods: {
+      // 鍒犻櫎琛�
+      deleteSag(index) {
+        this.sagData.splice(index, 1)
+      },
+      // 娣诲姞寮у瀭妫�娴�
+      addSag() {
+        this.sagData.push({
+          sampleCode: null,
+          model: null,
+          inspection: null,
+          methodName: null,
+          tensileForce: null,
+          spanLength: null,
+          load: null
+        })
+      },
+      // 鏁版嵁閲囬泦
+      getDataAcquisitionDevice(){
+        if(this.tableLists.find(m=>m.templateId==this.currentTable)&&this.tableLists.find(m=>m.templateId==this.currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'){
+          // 娓╁害寰幆妫�楠屽師濮嬭褰�----鏁伴噰----PK8000
+          let temperature = this.wareForm.inspectionItemSubclass;
+          if(typeof temperature == 'string'&&temperature.includes('(甯告俯)')){
+            temperature = `20鈩�(甯告俯)`
+          }else{
+            temperature = temperature + '鈩�'
+          }
+          this.dataAcquisitionLoading = true
+          this.$axios.post(this.$api.deviceScope.temDataAcquisition,{
+            entrustCode:this.insOrder.entrustCode,
+            sampleCode:this.currentSample.sampleCode,
+            model:this.wareForm0.model,
+            cycles:this.wareForm.inspectionItem,
+            temperature:temperature,
+          }, {
+          headers: {
+            'Content-Type': 'application/json'
+          },
+          noQs:true
+        }).then(res=>{
+            this.dataAcquisitionLoading = false
+            if(res.code!=200){
+              return
+            }
+            // 璧嬪�煎洖鏄綪K8000鐨勬暟鎹�
+            this.wareFormChange()
+          })
+        }else{
+          // 涓�鑸殑鏁版嵁閲囬泦
+          this.dataAcquisitionLoading = true
+          this.$axios.get(this.$api.deviceScope.dataCollection+'?entrustCode='+this.insOrder.entrustCode+'&sampleCode='+this.currentSample.sampleCode + '&id=' + this.currentSample.id).then(res=>{
+            this.dataAcquisitionLoading = false
+            if(res.code!=200){
+              return
+            }
+            this.dataAcquisitionInfoNew = this.HaveJson(res.data)
+            // 瀵规暟閲囧洖鏉ョ殑鍊艰繘琛屽鐞�
+            this.handleDataAcquisition(res.data)
+          })
+        }
+      },
+      handleDataAcquisition(data){
+        // 鏄惁鍙互缂栬緫鏁伴噰鏁版嵁
+        if(this.dataAcquisitionEidtAble){
+          this.getDataType = 1;
+        }else{
+          this.getDataType = 2;
+        }
+        this.dataAcquisitionInfo = {}
+        this.getData = []
+        for (let i in data){
+          let obj = {
+            faName:i,
+            child:[]
+          }
+          // 寰幆鏁伴噰鏁版嵁
+          for(let j in data[i]){
+            // 鎷兼帴瀛楃涓�  妫�楠岄」+妫�楠屽瓙椤�
+            let str0 = ''
+            if(i==j){
+              str0 = i+','
+            }else{
+              str0 = i+','+j
+            }
+            if(j!='frequency'&&data[i][j]&&(!data[i][j].result||typeof data[i][j].result == 'string')){
+              // 澶勭悊鏁伴噰淇℃伅鏍煎紡
+              this.dataAcquisitionInfo[str0] = {
+                value:data[i][j].result,
+                frequency:data[i].frequency
+              }
+              let list = this.tableList[0].arr
+              // 寰幆椤甸潰鍒楄〃淇℃伅锛屽垽鏂暟閲囨暟鎹搴旈〉闈㈠垪琛ㄤ俊鎭殑妫�楠岄」鏄摢涓紝骞剁粰褰撳墠妫�楠岄」缁戝畾璁惧淇℃伅
+              list.forEach((item,index)=>{
+                let num0 = 0;
+                let str = ''
+                item.forEach(m=>{
+                  if(m.v.ps&&(m.v.ps.value=='妫�楠屽瓙椤�'||m.v.ps.value=='妫�楠岄」')){
+                    if(m.v.ps&&m.v.ps.value=='妫�楠岄」'){
+                      if(num0==0){
+                        str = m.v.v+','
+                        num0++
+                      }
+                    }
+                    if(m.v.ps&&m.v.ps.value=='妫�楠屽瓙椤�'){
+                      if(num0==1){
+                        str = str+m.v.v
+                      }
+                    }
+                  }
+                  // 缁戝畾璁惧淇℃伅
+                  if(data[i][j].equipName&&data[i][j].equipValue&&m.v&&m.v.ps&&m.v.ps.value=='璁惧缂栫爜'&&str0==str){
+                    if(!m.v.v){
+                      this.changeEquip(data[i][j].equipValue,m,data[i][j].equipName)
+                    }
+                  }
+                })
+              })
+            }else if(j!='frequency'&&data[i][j]&&Array.isArray(data[i][j].result)){
+              // 濡傛灉杩斿洖鐨勬暟閲囨暟鎹槸鏁扮粍锛屽垯澶勭悊鏁扮粍
+              // 浠ヤ笅閫昏緫涓鸿幏鍙栨瘡涓楠岄」鍙緭鍏ョ殑妫�楠屽�肩殑鏈�澶т釜鏁�
+              let str0 = ''
+              if(i==j){
+                str0 = i+','
+              }else{
+                str0 = i+','+j
+              }
+              let list = this.tableList[0].arr
+              let maxNum = 0
+              list.forEach((item,index)=>{
+                let num0 = 0;
+                let str = ''
+                item.forEach(m=>{
+                  if(m.v.ps&&(m.v.ps.value=='妫�楠屽瓙椤�'||m.v.ps.value=='妫�楠岄」')){
+                    if(m.v.ps&&m.v.ps.value=='妫�楠岄」'){
+                      if(num0==0){
+                        str = m.v.v+','
+                        num0++
+                      }
+                    }
+                    if(m.v.ps&&m.v.ps.value=='妫�楠屽瓙椤�'){
+                      if(num0==1){
+                        str = str+m.v.v
+                      }
+                    }
+                    let num = 0;
+                    list[index].forEach(n=>{
+                      if(n.v.ps&&n.v.ps.value&&typeof n.v.ps.value == 'string'&&n.v.ps.value.includes('妫�楠屽��')){
+                        num++
+                      }
+                    })
+                    if(str0==str){
+                      maxNum = num
+                    }
+                  }
+                  // 缁戝畾璁惧
+                  if(data[i][j].equipName&&data[i][j].equipValue&&m.v&&m.v.ps&&m.v.ps.value=='璁惧缂栫爜'&&str0==str){
+                    if(!m.v.v){
+                      this.changeEquip(data[i][j].equipValue,m,data[i][j].equipName)
+                    }
+                  }
+                })
+              })
+              // let arr3 = []
+              // for (let l=0 ;i<data[i][j].result.length;i++){
+              //   arr3.push({
+              //     id:,
+              //     value:
+              //   })
+              // }
+              // 鑾峰彇鍒版渶澶ф楠屽�艰緭鍏ヤ釜鏁板悗閲嶇粍鏁版嵁
+              let obj0 = {
+                name:j,
+                arr:data[i][j].result,
+                maxNum:maxNum,
+                value:[]
+              }
+              // 濡傛灉鏁伴噰杩斿洖鐨勬暟缁勯暱搴﹀ぇ浜庢渶澶ц緭鍏ヤ釜鏁帮紝鍒欏皢鏁伴噰鏁版嵁鍦ㄥ脊妗嗕腑灞曠ず锛岀敤鎴烽�夋嫨闇�瑕佹墜鍔ㄩ�夋嫨鏁伴噰鐨勪俊鎭�
+              if(data[i][j].result&&Array.isArray(data[i][j].result)&&data[i][j].result.length>maxNum){
+                obj.child.push(obj0)
+              }else{
+                this.dataAcquisitionInfo[str0] = {
+                  value:data[i][j].result
+                }
+              }
+            }
+          }
+          if(obj.child.length>0){
+            this.getData.push(obj)
+          }
+        }
+        // 濡傛灉瀛樺湪鏁伴噰杩斿洖鐨勬暟缁勯暱搴﹀ぇ浜庢渶澶ц緭鍏ヤ釜鏁帮紝鍒欏脊鍑哄脊妗嗛�夋嫨
+        if(this.getData.length>0){
+          this.dataGetDia = true
+          this.getDataIndex = []
+        }else{
+          // 濡傛灉閮戒笉瀛樺湪锛屽垯锛岃繘鍏ュ鐞嗘暟閲囩嚎绋嬮噷鍘诲鐞嗘暟鎹�
+          try {
+            // 鍚� Worker 鍙戦�佹秷鎭紝寮�濮嬪鐞嗛�昏緫
+            this.getDataIndexLoading = false
+            this.dataGetDia = false
+            this.getDataTypeId = ''
+            this.worker0.postMessage(JSON.stringify({
+              dataAcquisitionInfo: this.dataAcquisitionInfo,
+              list:this.tableList[0].arr
+            }));
+          } catch (error) {
+            console.log(1111,error);
+          }
+        }
+        // 鐩戝惉 Worker 杩斿洖鐨勭粨鏋�
+        this.worker0.onmessage = (event) => {
+          let result = JSON.parse(event.data);
+          if(result.method=='changeInput'){
+            // 閲囬泦鍚庣殑鏁版嵁锛岄渶瑕佽繘琛岃绠楃殑绾跨▼杩涜璁$畻
+            let {list,n} = result.value
+            this.$set(this.tableList[0],'arr',list)
+            this.changeInput('',`${this.currentSample.insProduct[0].templateId}-${n.r}-${n.c}-${n.i}`,n)
+          }else if(result.getDataTypeId){
+            // 鑾峰彇鍒版暟閲囨渶鍚庝竴椤癸紝妫�楠岄」鐨処D
+            this.getDataTypeId = result.getDataTypeId
+          }
+        };
+      },
+      // 濡傛灉瀛樺湪鏁伴噰杩斿洖鐨勬暟缁勯暱搴﹀ぇ浜庢渶澶ц緭鍏ヤ釜鏁帮紝鍒欏脊鍑哄脊妗嗛�夋嫨锛岃繖閲屾槸寮规鐨勬彁浜�
+      submitDataGet(){
+        if(this.getDataIndex.length==0){
+          this.$message.error('璇烽�夋嫨闇�瑕侀噰闆嗙殑鏁版嵁')
+          return
+        }
+        this.getDataIndex.sort((a, b) => a - b);
+        for (let i=0;i<this.getData.length;i++){
+          for(let j=0;j<this.getData[i].child.length;j++){
+            // 瀵圭敤鎴烽�夋嫨鐨勬暟閲囦俊鎭繘琛屽鐞嗭紝璧嬪��
+            let arr = []
+            for(let k=0;k<this.getDataIndex.length;k++){
+              arr.push( this.dataAcquisitionInfoNew[this.getData[i].faName][this.getData[i].child[j].name].result[this.getDataIndex[k]])
+            }
+            this.dataAcquisitionInfoNew[this.getData[i].faName][this.getData[i].child[j].name].result = arr
+          }
+        }
+        this.getDataIndexLoading = true
+        // 璧嬪�煎畬鎴愬悗闇�瑕佸啀娆¤繘鍏ュ鐞嗘暟閲囩嚎绋嬮噷鍘诲鐞嗘暟鎹�
+        this.handleDataAcquisition(this.dataAcquisitionInfoNew)
+      },
+      // 澶氱嚎绋�
       startWorker() {
-      if (this.worker) {
-        this.stopWorker(); // 纭繚涔嬪墠鐨� Worker 宸插仠姝�
+        if (this.worker) {
+          this.stopWorker(); // 纭繚涔嬪墠鐨� Worker 宸插仠姝�
         }
         // 鍒涘缓 Worker 瀹炰緥
         this.worker = new Worker('/static/js/worker.js');
+        if (this.worker0) {
+          this.stopWorker(); // 纭繚涔嬪墠鐨� Worker 宸插仠姝�
+        }
+        // 鍒涘缓 Worker 瀹炰緥
+        this.worker0 = new Worker('/static/js/worker0.js');
       },
+      // 鍋滄澶氱嚎绋�
       stopWorker() {
         if (this.worker) {
           this.worker.terminate();
           this.worker = null;
         }
+        if (this.worker0) {
+          this.worker0.terminate();
+          this.worker0 = null;
+        }
       },
+      // 娓╁害寰幆---寮�濮�
       changeItem(row){
-        if(row.value0&&row.value1){
+        // 鍐呯銆佸绔繘琛岃祴鍊奸�昏緫澶勭悊
+
+        // 璧嬪�煎埌椤甸潰
+        if(row.value0&&!row.value1){
+          // 璧嬪�煎唴绔�
+          this.$set(row,'comValue',Number(row.value0).toFixed(3))
+        }else if(!row.value0&&row.value1){
+          // 璧嬪�煎绔�
+          this.$set(row,'comValue',Number(row.value1).toFixed(3))
+        }else if(row.value0&&row.value1){
+          // 璧嬪�艰绠楀��
           this.$set(row,'comValue',((Number(row.value0)+Number(row.value1))/2).toFixed(3))
         }else{
           return
         }
+        // 璧嬪�煎埌浼犲埌鍚庣鐨勫弬鏁�---鐗规畩椤圭洰蹇呴』涓ユ牸鎸夌収杩欑鏍煎紡浼犲弬锛屽惁鍒欏悗绔瘑鍒笉浜�
+        // 璧嬪�煎唴澶栫
         this.param[row.id].insValue = [
           {
             i:row.id,
@@ -990,15 +1631,20 @@
             }
           }
         ]
+        // 璧嬪�艰绠楀��
         this.param[row.id].comValue = [{
             i:row.id,
             v:{
               v:row.comValue
             }
           }]
+        // 鍒ゆ柇缁撴灉锛屽緱鍑虹粨璁�
         if(this.wareForm.inspectionItemSubclass!='20(甯告俯)'){
-          row.resValue = row.comValue?Math.abs(row.comValue-20).toFixed(3):''
+          // 缁欓〉闈㈠垪琛ㄨ祴鍊兼渶缁堝��
+          row.resValue = row.comValue?Math.abs(row.comValue-Number(row.insProduct.complue)).toFixed(3):''
+          // 缁欎紶閫掑埌鍚庣鐨勫弬鏁拌祴鍊兼渶缁堝��
           this.param[row.id].resValue.v.v = row.resValue
+          // 鍒ゆ柇缁撹锛岀粰椤甸潰鍒楄〃璧嬪�肩粨璁�
           if(row.ask&&row.resValue){
             if(row.ask.includes('<')){
               row.insResult = row.resValue<row.ask.split('<')[1]?1:0
@@ -1011,16 +1657,20 @@
             }else if(row.ask.includes('鈮�')){
               row.insResult = row.resValue<=row.ask.split('鈮�')[1]?1:0
             }
+            // 缁欎紶閫掑埌鍚庣鐨勫弬鏁拌祴鍊肩粨璁�
             this.param[row.id].insResult.v.v = row.insResult
           }
         }else{
+          // 20(甯告俯)榛樿鍚堟牸
           this.param[row.id].insResult.v.v = 1
         }
         this.$refs.wareTableData.doLayout()
+        // 杩涜鏁版嵁鐨勪繚瀛�
         this.saveInsContext()
       },
+      // 褰撳惊鐜鏁般�佹俯搴︾偣鍙樺寲銆丳K8000鏁伴噰鏃朵細璋冪敤锛屼富瑕佹槸鑾峰彇淇℃伅杩涜鍥炴樉
       wareFormChange(m,type){
-        if(this.PROJECT!='妫�娴嬩腑蹇�'){
+        if(this.PROJECT!='妫�娴嬩腑蹇�'||!this.tableLists.find(m=>m.templateId==this.currentTable)||this.tableLists.find(m=>m.templateId==this.currentTable).templateName!='娓╁害寰幆妫�楠屽師濮嬭褰�'){
           return
         }
         if(m&&type){
@@ -1041,6 +1691,7 @@
           if (res.code == 201) return
           let {productVos,sampleVo} = res.data
           this.wareForm0 = sampleVo
+          // 鍒濆鍖栦紶鍒板悗绔殑鍙傛暟
           productVos = productVos.map(m=>{
             let obj = {...m,...m.insProduct}
             this.param[obj.id] = {
@@ -1062,12 +1713,15 @@
               }
             }
             let insProductResult = obj.insProductResult
+            // 缁欎紶閫掑埌鍚庣鐨勫弬鏁拌繘琛岃祴鍊硷紝缁欓〉闈㈡暟鎹祴鍊�
             if(insProductResult){
               for(let i in insProductResult){
                 switch (i) {
+                  // 妫�楠屽�艰祴鍊�
                   case 'insValue':
                     let insValue = JSON.parse(insProductResult[i])
                     if(insValue&&insValue.length>1){
+                      // 鍚庣鐨勫弬鏁拌繘琛岃祴鍊�
                       this.param[obj.id].insValue = [
                         {
                           i:obj.id,
@@ -1082,13 +1736,35 @@
                           }
                         }
                       ]
+                      // 椤甸潰鏁版嵁璧嬪��
                       obj.value0 = insValue[0].v
                       obj.value1 = insValue[1].v
+                    }else if(insValue&&insValue.length==1){
+                      // 鍚庣鐨勫弬鏁拌繘琛岃祴鍊�
+                      this.param[obj.id].insValue = [
+                        {
+                          i:obj.id,
+                          v:{
+                            v:insValue[0].v
+                          }
+                        },
+                        {
+                          i:obj.id,
+                          v:{
+                            v:''
+                          }
+                        }
+                      ]
+                       // 椤甸潰鏁版嵁璧嬪��
+                      obj.value0 = insValue[0].v
+                      obj.value1 = ''
                     }
                     break;
+                    // 璁$畻鍊艰祴鍊�
                   case 'comValue':
                   let comValue = JSON.parse(insProductResult[i])
                     if(comValue&&comValue.length>0){
+                      // 鍚庣鐨勫弬鏁拌繘琛岃祴鍊�
                       this.param[obj.id].comValue = [
                         {
                           i:obj.id,
@@ -1097,6 +1773,7 @@
                           }
                         }
                       ]
+                       // 椤甸潰鏁版嵁璧嬪��
                       obj.comValue = comValue[0].v
                     }
                     break;
@@ -1104,13 +1781,18 @@
                     break;
                 }
               }
+              // 鏈�缁堝�艰祴鍊�
+              // 鍚庣鐨勫弬鏁拌繘琛岃祴鍊�
               this.param[obj.id].resValue = {
                 i:obj.id,
                 v:{
                   v:obj.lastValue
                 }
               }
+              // 椤甸潰鏁版嵁璧嬪��
               obj.resValue = obj.lastValue
+              // 缁撹璧嬪��
+              // 鍚庣鐨勫弬鏁拌繘琛岃祴鍊�
               this.param[obj.id].insResult = {
                 i:obj.id,
                 v:{
@@ -1120,32 +1802,343 @@
             }
             return obj
           })
-          this.wareTableData = productVos
+          // 浠ヤ笅鏄娓╁害寰幆椤甸潰鍛堢幇杩涜澶勭悊锛屽幓閲嶃�佹暟鎹噸缃瓑绛�
+          let arr = []
+          let arr0 = []
+          let mySet = new Set()
+          productVos.forEach((m,i)=>{
+            let num0 = mySet.size
+            mySet.add(m.inspectionItemClass)
+            let num1 = mySet.size
+            if(num0!=num1){
+              if(i>0){
+                arr.push(arr0)
+              }
+              arr0 = []
+              arr0.push(m)
+            }else{
+              arr0.push(m)
+            }
+          })
+          arr.push(arr0)
+          let arr1 = []
+          this.wareLength = [];
+          for(let i=0;i<arr.length;i++){
+            this.wareLength.push(arr[i][0].inspectionItemClass)
+          }
+          for(let i=0;i<arr[0].length;i++){
+            arr1.push([])
+          }
+          arr.forEach((item,index)=>{
+            item.forEach((m,i)=>{
+              try {
+                arr1[i].push(m)
+              } catch (e) {
+                console.log(e)
+              }
+            })
+          })
+          let arr2 = []
+          arr1.forEach(item=>{
+            let obj = {
+              bushColor:item[0].bushColor,
+              code:item[0].code,
+              color:item[0].color,
+              arr:item
+            }
+            arr2.push(obj)
+          })
+          // 杩欐槸椤甸潰鏈�缁堝憟鐜扮殑鏍煎紡
+          this.wareTableData = arr2
         })
+        // 鑾峰彇璁惧鍒楄〃
         this.getEquipOptions(true,this.currentSample.insProduct[0].id)
+        // this.$refs.wareTableData&&this.$refs.wareTableData.doLayout()
       },
-      subOtherForm(m,type){
-        let ids = []
-        for (let i in this.param) {
-          ids.push(i)
-        }
-        this.$axios.post(this.$api.insOrderPlan.write,{
-          [type]:Number(m),
-          ids
-        }, {
-          headers: {
-            'Content-Type': 'application/json'
-          },
-          noQs:true
+      // 娓╁害寰幆---缁撴潫
+      // 鐑惊鐜�---寮�濮�
+      // 寰幆娆℃暟鍒囨崲鏃惰皟鐢�
+      thermalCyclingChange(){
+        this.thermalCyclingLoading = true
+        this.$axios.post(this.$api.insOrderPlan.temCycle,{
+          sampleId:this.currentSample.id,
+          inspectionItem:this.thermalCyclingInfo.inspectionItem
         }).then(res => {
+          this.thermalCyclingLoading = false
           if (res.code == 201) return
-          this.$message.success('淇濆瓨鎴愬姛')
+          let {productVos,sampleVo} = res.data
+          this.thermalCyclingInfo = {...this.thermalCyclingInfo,...sampleVo}
+          if(this.thermalCyclingInfo.inspectionItem>1){
+            for(let i in this.param){
+              if(this.param[i].inspectionItemSubclass){
+                delete this.param[i]
+              }
+            }
+          }
+          if(productVos.length>0){
+            this.thermalCyclingInfo.inspectionItemClass = productVos[0].insProduct.inspectionItemClass
+            // 鏍规嵁妫�楠岄」锛屽垵濮嬪寲浼犲埌鍚庣鐨勫弬鏁�
+            productVos.forEach(item=>{
+              this.param[item.insProduct.id] = {
+                insValue: [],
+                comValue: [],
+                resValue: {
+                  i:item.insProduct.id,
+                  r:0,
+                  c:0,
+                  v:{
+                    v:null
+                  }
+                },
+                equipValue: [],
+                equipName: [],
+                insResult: {
+                  i:item.insProduct.id,
+                  v:{
+                    v:null
+                  }
+                },
+                inspectionItemSubclass: item.insProduct.inspectionItemSubclass,
+              }
+              let obj = {...item,...item.insProduct}
+              let insProductResult = obj.insProductResult
+              if(insProductResult){
+                // 缁欓〉闈㈠垪琛ㄨ祴鍊硷紝缁欏悗绔紶鍙傝祴鍊�
+                for(let i in insProductResult){
+                  switch (i) {
+                    case 'insValue':
+                      // 缁欓〉闈㈠垪琛ㄨ祴鍊�
+                      let insValue = JSON.parse(insProductResult[i])
+                      if(insValue&&insValue.length>0){
+                        this.thermalCyclingInfo.length = 0
+                        this.thermalCyclingInfo.arr.forEach(a=>{
+                          if(a.name==obj.inspectionItemSubclass){
+                            a.arr = []
+                            for(let i=0;i<insValue.length;i++){
+                              a.arr.push({
+                                value0:insValue[i].v,
+                                value1:insValue[i].w,
+                              })
+                              this.thermalCyclingInfo.length++
+                            }
+                            a.insResult = obj.insResult
+                          }
+                        })
+                        // 缁欏悗绔紶鍙傝祴鍊�
+                        this.param[obj.id].insValue = []
+                        insValue.forEach(m=>{
+                          this.param[obj.id].insValue.push({
+                            i:obj.id,
+                            r:0,
+                            c:0,
+                            w:m.w,
+                            v:{
+                              v:m.v
+                            }
+                          })
+                        })
+                      }
+                      break;
+                  }
+                }
+                // 缁欏悗绔紶鍙傝祴鍊�
+                this.param[obj.id].insResult = {
+                  i:obj.id,
+                  v:{
+                    v:obj.insResult
+                  }
+                }
+              }else{
+                // 缁欓〉闈㈠垪琛ㄨ祴鍊�
+                this.thermalCyclingInfo.arr.forEach(a=>{
+                  a.insResult = null
+                  a.arr = []
+                  a.arr.push(
+                    {
+                    value0:'',
+                    value1:''
+                  }
+                  )
+                })
+                this.thermalCyclingInfo.length = 1
+              }
+            })
+          }
+          // 鑾峰彇璁惧鍒楄〃
+          this.getEquipOptions(true,this.currentSample.insProduct[0].id)
         })
       },
+      // 娣诲姞妫�楠屽��
+      handleAddThermal(){
+        this.thermalCyclingInfo.length++
+        this.thermalCyclingInfo.arr.forEach(item=>{
+          item.arr.push({
+            value0:'',
+            value1:''
+          })
+        })
+      },
+      // 鍒犻櫎妫�楠屽��
+      handleDeleteThermal(){
+        if(this.thermalCyclingInfo.length==1){
+          this.$message.error('鏈�鍚庝竴鏉℃暟鎹笉鑳藉垹闄�')
+          return
+        }else{
+          this.thermalCyclingInfo.length--
+          this.thermalCyclingInfo.arr.forEach(item=>{
+            item.arr.pop()
+          })
+          // 鍒犻櫎鍚庨渶瑕佷繚瀛樹竴涓嬫暟鎹�
+          this.saveThermalCycling(true,{name:'瀵肩嚎娓╁害'},true)
+        }
+      },
+      saveThermalCycling(m,item,type){
+        // 缁撴灉鍒ゆ柇
+        if(m&&item&&type){
+          if(item.name=='瀵肩嚎娓╁害'||item.name=='鑰愬紶娓╁害'||item.name=='鎺ョ画娓╁害'){
+            this.thermalCyclingInfo.arr.forEach(a=>{
+              if(a.name=='鑰愬紶娓╁害'){
+                a.arr.forEach((b,i)=>{
+                  // 鑾峰彇瀵瑰簲鐨勫绾挎俯搴�
+                  let num0 = 0
+                  this.thermalCyclingInfo.arr.forEach(c=>{
+                    if(c.name=='瀵肩嚎娓╁害'){
+                      num0 = c.arr[i].value0
+                    }
+                  })
+                  // 鍒ゆ柇缁撹
+                  if(!num0||!b.value0){
+                    b.state = null
+                  }else if(Number(num0)>Number(b.value0)){
+                    b.state = 1
+                  }else{
+                    b.state = 0
+                  }
+                })
+                let state = a.arr.filter(b=>b.state==null).length
+                let state0 = a.arr.filter(b=>b.state==0).length
+                let state1 = a.arr.filter(b=>b.state==1).length
+                if(state>0){
+                  // 寰呭畾
+                  a.insResult = null
+                }else if(state0>0){
+                  // 涓嶅悎鏍�
+                  a.insResult = 0
+                }else if(state1==a.arr.length){
+                  // 鍚堟牸
+                  a.insResult = 1
+                }
+              }
+              if(a.name=='鎺ョ画娓╁害'){
+                a.arr.forEach((b,i)=>{
+                  // 鑾峰彇瀵瑰簲鐨勫绾挎俯搴�
+                  let num0 = 0
+                  this.thermalCyclingInfo.arr.forEach(c=>{
+                    if(c.name=='瀵肩嚎娓╁害'){
+                      num0 = c.arr[i].value0
+                    }
+                  })
+                  if(!num0||!b.value0){
+                    b.state = null
+                  }else if(Number(num0)>Number(b.value0)){
+                    b.state = 1
+                  }else{
+                    b.state = 0
+                  }
+                })
+                let state = a.arr.filter(b=>b.state==null).length
+                let state0 = a.arr.filter(b=>b.state==0).length
+                let state1 = a.arr.filter(b=>b.state==1).length
+                if(state>0){
+                  a.insResult = null
+                }else if(state0>0){
+                  a.insResult = 0
+                }else if(state1==a.arr.length){
+                  a.insResult = 1
+                }
+              }
+            })
+          }
+        }
+        // 缁欏悗绔紶鍙傝祴鍊�
+        this.thermalCyclingInfo.arr.forEach(item=>{
+          for (let i in this.param){
+            if(this.param[i].inspectionItemSubclass==item.name){
+              switch (item.name){
+                case '鐜娓╁害':
+                  this.param[i].insResult.v.v = 1
+                  this.param[i].insValue = []
+                  item.arr.forEach(insValue=>{
+                    this.param[i].insValue.push({
+                      i:i,
+                      r:0,
+                      c:0,
+                      v:{
+                        v:insValue.value0
+                      }
+                    })
+                  })
+                  break;
+                case '瀵肩嚎娓╁害':
+                  this.param[i].insResult.v.v = 1
+                  this.param[i].insValue = []
+                  item.arr.forEach(insValue=>{
+                    this.param[i].insValue.push({
+                      i:i,
+                      r:0,
+                      c:0,
+                      w:insValue.value1,
+                      v:{
+                        v:insValue.value0
+                      }
+                    })
+                  })
+                  break;
+                case '鑰愬紶娓╁害':
+                  this.param[i].insValue = []
+                  item.arr.forEach(insValue=>{
+                    this.param[i].insValue.push({
+                      i:i,
+                      r:0,
+                      c:0,
+                      w:insValue.value1,
+                      v:{
+                        v:insValue.value0
+                      }
+                    })
+                  })
+                  this.param[i].insResult.v.v = item.insResult
+                  break;
+                case '鎺ョ画娓╁害':
+                  this.param[i].insValue = []
+                  item.arr.forEach(insValue=>{
+                    this.param[i].insValue.push({
+                      i:i,
+                      r:0,
+                      c:0,
+                      w:insValue.value1,
+                      v:{
+                        v:insValue.value0
+                      }
+                    })
+                  })
+                  this.param[i].insResult.v.v = item.insResult
+                  break;
+              }
+            }
+          }
+        })
+        // 淇濆瓨鏁版嵁
+        this.saveInsContext()
+      },
+      // 鐑惊鐜�---缁撴潫
+      // 鏉冮檺鑾峰彇
       getPower(){
         let power = JSON.parse(sessionStorage.getItem('power'))
         let fileDel = false
         let fileAdd = false
+        let collected = false
+        let temDataAcquisition = false
         for (var i = 0; i < power.length; i++) {
 					if (power[i].menuMethod == 'uploadFile') {
 						fileAdd = true
@@ -1153,76 +2146,38 @@
 					if (power[i].menuMethod == 'delfile') {
 						fileDel = true
 					}
+          if (power[i].menuMethod == 'isItAllowedToModifyTheCollectedValues') {
+						collected = true
+					}
+          if (power[i].menuMethod == 'temDataAcquisition') {
+						temDataAcquisition = true
+					}
 				}
         if (!fileDel) {
 					this.componentData0.do.splice(1, 1)
 				}
         this.fileAdd = fileAdd
+        this.collected = collected
+        this.temDataAcquisition = temDataAcquisition
       },
+      uploadSample(){
+        this.$axios.post(this.$api.insOrderPlan.doInsOrder, {
+          id: this.id,
+          laboratory: this.sonLaboratory
+        }).then(async res => {
+          this.sampleProduct = res.data.sampleProduct
+        })
+      },
+      // 鏍规嵁绫诲瀷銆佷换鍔d銆佸疄楠屽鏉ヨ幏鍙栨牱鍝佺殑妫�楠岄」淇℃伅
       async getCurrentProduct(id,type){
         this.tableLoading = true;
         let res = await this.$axios.post(this.$api.insOrderPlan.getInsProduct+'?id='+id+'&type='+type+'&laboratory='+this.sonLaboratory)
         this.tableLoading = false;
         return res.data
       },
-      handleChangeBushing(row, column, event){
-        this.currentBushing = row;
-        this.fiberOpticTape = []
-        this.currentFiberOpticTape = null;
-        this.fiberOptic = []
-        this.currentFiberOptic = null;
-        if(row.fiber&&row.fiber.length>0){
-          // 鐩存帴閰嶇疆鍏夌氦
-          this.fiberOptic = row.fiber;
-        }else if(row.fibers&&row.fibers.length>0){
-          // 閰嶇疆鍏夌氦甯﹀悗锛屽啀閰嶇疆鍏夌氦
-          this.fiberOpticTape = row.fibers;
-        }
-        this.bushingVisible = false;
-        this.currentKey0 = row.index
-      },
-      async handleChangeOptic(row, column, event){
-        this.currentFiberOptic = row;
-        this.currentFiberOptic.productList.forEach(a => {
-          this.param[a.id] = {
-            insValue: [],
-            comValue: [],
-            resValue: null,
-            equipValue: [],
-            equipName: [],
-            insResult: null
-          }
-        })
-        this.fiberOpticVisible = false;
-        let list = await this.getCurrentProduct(row.id,2)
-        this.getTableLists0(list)
-        this.currentKey2 = row.index
-      },
-      async handleChangeTape(row, column, event){
-        this.currentFiberOpticTape = row;
-        this.param = {}
-        this.fiberOptic = []
-        this.currentFiberOptic = null;
-        this.currentFiberOpticTape.productList.forEach(a => {
-          this.param[a.id] = {
-            insValue: [],
-            comValue: [],
-            resValue: null,
-            equipValue: [],
-            equipName: [],
-            insResult: null
-          }
-        })
-        this.fiberOpticTapeVisible = false;
-        let list = await this.getCurrentProduct(row.id,1)
-        this.getTableLists0(list)
-        if(row.fiber&&row.fiber.length>0){
-          // 閰嶇疆鍏夌氦
-          this.fiberOptic = row.fiber;
-        }
-        this.currentKey1 = row.index
-      },
+      // 鍒囨崲鏍峰搧
       async handleChangeSample(row, column, event) {
+        // 鍒濆鍖栨暟鎹�
         this.param = {}
         // 娓呯┖鍏夌氦閰嶇疆鐩稿叧鏁版嵁
         this.fiberOpticTape = []
@@ -1232,42 +2187,78 @@
         this.bushing = []
         this.currentBushing = null;
         this.sampleVisible = false;
+        // 璧嬪�兼牱鍝�
         this.currentSample = this.HaveJson(row)
         let list = await this.getCurrentProduct(row.id,0)
+        // 璧嬪�兼牱鍝佹楠岄」
         this.currentSample.insProduct = this.HaveJson(list)
-        this.currentSample.insProduct.forEach(a => {
-          this.param[a.id] = {
-            insValue: [],
-            comValue: [],
-            resValue: null,
-            equipValue: [],
-            equipName: [],
-            insResult: null
+        // 鍒濆鍖栧悗绔紶鍙�
+        this.param = {}
+        this.changeType = 0;
+        this.currentSample.insProduct.forEach((a,j) => {
+          if(this.handleCasing(a.inspectionItem)){
+            this.param[a.id] = {
+              insValue: [],
+              comValue: [],
+              resValue: null,
+              equipValue: [],
+              equipName: [],
+              insResult: null
+            }
           }
         })
+        // 鑾峰彇濂楃,鍏夌氦甯�,鍏夌氦鏁版嵁
         this.getReportModel(row.id)
         let bushing = this.currentSample.bushing
         if(bushing&&bushing.length>0){
           this.bushing = bushing
         }
-        // this.handleTableData()
+        // 澶勭悊椤甸潰鍒楄〃鏁版嵁
         this.getTableLists();
         this.currentKey = row.index
         this.currentTab = null;
+        // 鍚戝绾跨▼鍘讳繚瀛橀〉闈㈠垪琛ㄦ暟鎹�,鍚庣浼犲弬,褰撳墠妯℃澘淇℃伅
+        this.worker.postMessage(JSON.stringify({
+          type: 'saveData',
+          tableList:this.tableList,
+          param:this.param,
+          currentTable:this.currentTable
+        }));
       },
+      // 鏉惧绠$殑鍒ゆ柇\濡傛灉changeType涓嶇瓑浜�3閭d箞椤甸潰涓嶅睍绀烘澗濂楃妫�楠岄」
+      handleCasing(inspectionItem){
+        if(this.changeType!=3){
+          if(inspectionItem.includes('鏉惧绠�')){
+            return false
+          }else{
+            return true
+          }
+        }else{
+          return true
+        }
+      },
+      // 鑾峰彇濂楃,鍏夌氦甯�,鍏夌氦鏁版嵁
       getReportModel(id){
         if(this.PROJECT!='妫�娴嬩腑蹇�'){
           return
         }
+        this.getReportModelLoading = true
         this.$axios.post(this.$api.insOrderPlan.getReportModel+'?sampleId='+id, {}).then(res => {
+          this.getReportModelLoading = false
           this.fibers = res.data['鍏夌氦甯�']
           this.fiber = res.data['鍏夌氦']
+          this.casing = res.data['濂楃']
         })
       },
+      // 濂楃,鍏夌氦甯�,鍏夌氦绛夊垏鎹�,瀵瑰簲鍘熷璁板綍妯℃澘涔熻鍒囨崲
       async handleChange(m,type){
+        this.changeType = type
         if(m){
+          // 鑾峰彇妫�楠岄」
           let list = await this.getCurrentProduct(m,type)
           if(list.length>0){
+            // 鍒濆鍖栧悗绔紶鍙�
+            this.param = {}
             list.forEach(a => {
               this.param[a.id] = {
                 insValue: [],
@@ -1278,7 +2269,18 @@
                 insResult: null
               }
             })
+            // 椤甸潰鍒楄〃鏁版嵁澶勭悊
             this.getTableLists0(list)
+            // 鑾峰彇濂楃,鍏夌氦甯�,鍏夌氦鏁版嵁
+            this.getReportModel(this.currentSample.id)
+            // 鍚戝绾跨▼淇濆瓨鏁版嵁
+            this.worker.postMessage(JSON.stringify({
+              type: 'saveData',
+              tableList:this.tableList,
+              param:this.param,
+              currentTable:this.currentTable,
+              bushing:m
+            }));
           }else{
             this.tableLists = []
             this.tableList = []
@@ -1286,10 +2288,12 @@
           }
         }
       },
+      // 鏀瑰彉浠诲姟
       handleChangeTask(row) {
         if (row.length > 0) this.id = row[0].id;
         this.taskVisible = false;
       },
+      // 瀛楀吀鑾峰彇淇℃伅
       getTypeDicts() {
         this.$axios.post(this.$api.enums.selectEnumByCategory, {
           category: "绱ф�ョ▼搴�"
@@ -1308,6 +2312,7 @@
           this.componentData.tagField.type.select = data
         })
       },
+      // 瀛楀吀鑾峰彇淇℃伅
       getInsStateDicts() {
         this.$axios.post(this.$api.enums.selectEnumByCategory, {
           category: "妫�楠屼换鍔$姸鎬�"
@@ -1327,6 +2332,7 @@
           this.componentData.tagField.insState.select = data
         })
       },
+      // 瀛楀吀鑾峰彇淇℃伅
       getComparisonList() {
         this.$axios.post(this.$api.enums.selectEnumByCategory, {
           category: "琛ㄦ牸鍧愭爣杞崲"
@@ -1335,6 +2341,7 @@
           this.comparisonList = data;
         })
       },
+      // 鑾峰彇妫�楠屽�间负涓嬫媺鏃剁殑涓嬫媺鍒楄〃
       selectEnumByCategoryOfSelect(val) {
         this.enumList = []
         if (val === undefined || val === null) {
@@ -1352,15 +2359,20 @@
       }) {
         row.index = rowIndex + 1;
       },
+      // 澶勭悊椤甸潰鍒楄〃鏁版嵁--鍘婚噸,鐢熸垚妫�楠屾ā鏉垮垏鎹㈠垪琛�
       getTableLists() {
         const mySet1 = new Set();
         this.tableLists = this.currentSample.insProduct.filter(m => {
           let num0 = mySet1.size;
           if (m.templateId != null&&m.template != null) {
-            mySet1.add(JSON.stringify({
-              template: m.template,
-              templateId: m.templateId
-            }))
+            try {
+              mySet1.add(JSON.stringify({
+                template: m.template,
+                templateId: m.templateId
+              }))
+            } catch (error) {
+              console.log(222,error);
+            }
           }
           let num1 = mySet1.size;
           if (num1 > num0) {
@@ -1371,6 +2383,10 @@
           this.tableList = null;
           this.tableList = [this.tableLists[0]]
           this.currentTable = this.tableLists[0].templateId;
+          if(this.tableLists.find(m=>m.templateId==this.currentTable)&&this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('鐢佃矾璇曢獙')&&this.currentTableState!=0&&this.currentTableState!=1){
+            this.versionDialogVisible = true
+          }
+          // 澶勭悊椤甸潰鍒楄〃鏁版嵁
           this.handleTableData()
         }
       },
@@ -1380,10 +2396,14 @@
         this.tableLists = list.filter(m => {
           let num0 = mySet1.size;
           if (m.templateId != null&&m.template != null) {
-            mySet1.add(JSON.stringify({
-              template: m.template,
-              templateId: m.templateId
-            }))
+            try {
+              mySet1.add(JSON.stringify({
+                template: m.template,
+                templateId: m.templateId
+              }))
+            } catch (error) {
+              console.log(333,error);
+            }
           }
           let num1 = mySet1.size;
           if (num1 > num0) {
@@ -1395,16 +2415,20 @@
           this.tableList = [this.tableLists[0]]
           this.currentTable = this.tableLists[0].templateId;
           this.currentSample.insProduct = this.HaveJson(list)
+          // 澶勭悊椤甸潰鍒楄〃鏁版嵁
           this.handleTableData()
         }
       },
+      // 澶勭悊椤甸潰鍒楄〃鏁版嵁
       handleTableData() {
-        this.excelMethodList = []
-        this.widthList = this.tableList[0].style.columnlen;
+        this.excelMethodList = []//excel鍑芥暟鍒楄〃
+        this.widthList = this.tableList[0].style.columnlen;//椤甸潰瀹藉害--鏍规嵁妯℃澘鏉ョ殑
         // 娓╁害寰幆妫�楠屽師濮嬭褰�--寮�濮�
-        if(this.tableLists.find(m=>m.templateId==this.currentTable)||this.tableLists.find(m=>m.templateId==this.currentTable).templateName!='娓╁害寰幆妫�楠屽師濮嬭褰�'){
+        if(this.tableLists.find(m=>m.templateId==this.currentTable)&&this.tableLists.find(m=>m.templateId==this.currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'){
+          // 瀵硅姹傚�艰繘琛屾媶鍒嗗鐞�,杩涜�屽緱鍑洪〉闈㈠唴瀹�
           let ask = this.currentSample.insProduct[0].ask
           let askList = ask.split(';')
+          // 鑾峰彇寰幆娆℃暟
           this.numOptions = []
           for (let i = 1; i <= askList[askList.length-1]; i++) {
             this.numOptions.push({
@@ -1418,6 +2442,7 @@
               mySet1.add(m.split(',')[0].replace('鈩�',''))
             }
           })
+          // 鑾峰彇娓╁害鐐瑰垪琛�
           this.temperatureOptions = []
           mySet1.forEach(m => {
             this.temperatureOptions.push({
@@ -1425,9 +2450,54 @@
               label:m
             })
           })
-          this.wareFormChange()
+          // 鍒濆鍖栭〉闈㈡暟鎹�
+          this.wareTableDataLoading = true
+          this.$axios.post(this.$api.deviceScope.temDataAcquisition2,{
+            entrustCode:this.insOrder.entrustCode,
+            sampleCode:this.currentSample.sampleCode,
+            model:this.currentSample.model,
+            }, {
+            headers: {
+              'Content-Type': 'application/json'
+            },
+            noQs:true
+          }).then(res=>{
+            // console.log(res.data)
+            this.wareFormChange()
+          })
+          // this.wareFormChange()
         }
         // 娓╁害寰幆妫�楠屽師濮嬭褰�---缁撴潫
+        // 鐑惊鐜楠屽師濮嬭褰�---寮�濮�
+        if(this.tableLists.find(m=>m.templateId==this.currentTable)&&(this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('鐑惊鐜�')||this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('娓╁崌璇曢獙'))){
+          // 鏍规嵁瑕佹眰鍊兼媶鍒嗘暟鎹�,寰楀埌椤甸潰娓叉煋鐨勪俊鎭�
+          let ask = this.currentSample.insProduct[0].ask
+          let askList = ask.split(';')
+          this.thermalCyclingInfo.max = Number(askList[askList.length-1])
+          let arr = []
+          for (let i = 0; i < askList.length-1; i++) {
+            arr.push(askList[i].split(',')[0])
+          }
+          arr = arr.map(item=>{
+            let obj = {}
+            obj.name = item;
+            if(obj.insResult==null||obj.insResult==undefined){
+              obj.arr = [
+                {
+                  value0:'',
+                  value1:'',
+                }
+              ]
+              obj.insResult = null;
+            }
+            return obj
+          })
+          this.thermalCyclingInfo.arr = arr;
+          // 鍒濆鍖栭〉闈㈡暟鎹�
+          this.thermalCyclingChange()
+        }
+        // 鐑惊鐜楠屽師濮嬭褰�---缁撴潫
+        // 鏈寰幆涓昏鍋氶〉闈㈡覆鏌撳眰闈㈢殑澶勭悊--鍗曞厓鏍煎悎骞堕澶勭悊
         this.tableList.forEach(a => {
           let mcList = []
           a.template.forEach(b => {
@@ -1456,9 +2526,10 @@
             count++
           })
         })
+        // 鏈寰幆涓昏鏄帶鍒跺悎骞�,浠ュ強鎺у埗妫�楠岄」淇℃伅鏄惁灞曠ず鍑烘潵,浠ヤ究鍚庣画妫�楠�
         this.tableList.forEach(a => {
-          let dels = new Set()
-          let ids = []
+          let dels = new Set()//闇�瑕佸垹闄ょ殑琛�
+          let ids = []//鎵�鏈夋楠岄」鐨刬d
           let set3 = new Set()
           a.template.forEach(b => {
             let size1 = set3.size
@@ -1466,42 +2537,63 @@
             if (size1 < size2) {
               let str = ''
               let count4 = 0
+              let isThree = 0
               a.template.forEach(c => {
+                // 鑾峰彇鍒� 妫�楠岄」鍒嗙被+妫�楠岄」+妫�楠屽瓙椤圭殑鎷兼帴,濡傛灉妯℃澘閲岀殑淇℃伅璺熸帴鍙h繑鍥炵殑妫�楠岄」淇℃伅鑳藉鍖归厤鍒欏睍绀哄嚭鏉�
                 if (b.r === c.r) {
-                  if (c.v.ps != undefined && c.v.ps.value === '妫�楠岄」') {
-                    if (count4 === 0) {
-                      str += c.v.v
-                      count4 += 1
+                  if(c.v.ps != undefined && c.v.ps.value === '妫�楠岄」鍒嗙被'&&count4 === 0){
+                    // 涓夌骇鍒嗙被
+                    isThree = 1
+                  }else if(c.v.ps != undefined && c.v.ps.value === '妫�楠岄」'&&count4 === 0){
+                    // 浜岀骇鍒嗙被
+                    isThree = 0
+                  }
+                  if(isThree==0){
+                    if (c.v.ps != undefined && c.v.ps.value === '妫�楠岄」') {
+                      if (count4 === 0) {
+                        str += c.v.v
+                        count4 += 1
+                      }
+                    } else if (c.v.ps != undefined && c.v.ps.value === '妫�楠屽瓙椤�') {
+                      if (count4 === 1) {
+                        str += c.v.v
+                        count4 += 1
+                      }
                     }
-                  } else if (c.v.ps != undefined && c.v.ps.value === '妫�楠屽瓙椤�') {
-                    if (count4 === 1) {
-                      str += c.v.v
-                      count4 += 1
-                    }
-                  }else if (c.v.ps != undefined && c.v.ps.value === '妫�楠屽瓙瀛愰」'&&this.PROJECT=='瑁呭鐢电紗') {
-                    if (count4 === 2) {
-                      str += c.v.v
-                      count4 += 1
+                  }else if(isThree==1){
+                    if (c.v.ps != undefined && c.v.ps.value === '妫�楠岄」鍒嗙被') {
+                      if (count4 === 0) {
+                        str += c.v.v
+                        count4 += 1
+                      }
+                    }else if (c.v.ps != undefined && c.v.ps.value === '妫�楠岄」') {
+                      if (count4 === 1) {
+                        str += c.v.v
+                        count4 += 1
+                      }
+                    } else if (c.v.ps != undefined && c.v.ps.value === '妫�楠屽瓙椤�') {
+                      if (count4 === 2) {
+                        str += c.v.v
+                        count4 += 1
+                      }
                     }
                   }
-                  // else if (c.v.ps != undefined && c.v.ps.value === '鍗曚綅'&&this.PROJECT=='妫�娴嬩腑蹇�'){
-                  //   if(count4==1||count4==2){
-                  //     str += c.v.v?c.v.v:''
-                  //     console.log('str',str,c)
-                  //     count4 += 1
-                  //   }
-                  // }
                 }
               })
               if (str != '') {
-                console.log('str',str)
                 let count2 = 0
                 for (let i in this.currentSample.insProduct) {
-                  // (this.currentSample
-                  // .insProduct[i].unit?this.currentSample
-                  // .insProduct[i].unit:'')
-                  if (this.currentSample.insProduct[i].templateId === a.templateId && this.currentSample
-                  .insProduct[i].inspectionItem +(this.currentSample.insProduct[i].inspectionItemSubclass == null ? '' : this.currentSample.insProduct[i].inspectionItemSubclass)+(this.currentSample.insProduct[i].inspectionItemClass==null||this.PROJECT!='瑁呭鐢电紗'?'':this.currentSample.insProduct[i].inspectionItemClass) ===
+                  let inspectionItemClass = this.currentSample.insProduct[i].inspectionItemClass==null||this.currentSample.insProduct[i].inspectionItemClass==undefined?'':this.currentSample.insProduct[i].inspectionItemClass
+                  let inspectionItem = this.currentSample
+                  .insProduct[i].inspectionItem==null||this.currentSample
+                  .insProduct[i].inspectionItem==undefined?'':this.currentSample
+                  .insProduct[i].inspectionItem
+                  let inspectionItemSubclass = this.currentSample
+                  .insProduct[i].inspectionItemSubclass==null||this.currentSample
+                  .insProduct[i].inspectionItemSubclass==undefined?'':this.currentSample
+                  .insProduct[i].inspectionItemSubclass
+                  // 濡傛灉鐩哥瓑,閭d箞璇存槑鎵惧埌浜�,骞朵笖鎶奿d瀛樿捣鏉�,鍚庣画妫�楠岄」涔熶細鍦ㄩ〉闈腑鏄剧ず鍑烘潵
+                  if (this.currentSample.insProduct[i].templateId === a.templateId && inspectionItemClass +inspectionItem+inspectionItemSubclass ===
                     str) {
                     ids.push({
                       r: b.r,
@@ -1518,6 +2610,7 @@
               }
             }
           })
+          // 鎿嶄綔鍒犻櫎
           dels.forEach(del => {
             for (let b = 0; b < a.template.length; b++) {
               if (a.template[b].r === del) {
@@ -1526,6 +2619,8 @@
               }
             }
           })
+          console.log(4444,a.template)
+          // 鎿嶄綔璧嬪��--涓昏璧嬪�煎崟浣�,璇曢獙鏂规硶绛変俊鎭�
           ids.forEach(id => {
             for (let b = 0; b < a.template.length; b++) {
               if (a.template[b].r === id.r) {
@@ -1537,10 +2632,14 @@
                     .ps.value === '妫�娴嬫柟娉�')) {
                   a.template[b].v.v = id.product.methodS
                 }
+                // if (a.template[b].v.ps != undefined && (a.template[b].v.ps.value === '璇曢獙鏍囧噯')) {
+                //   a.template[b].v.v = id.product.testRequirements
+                // }
               }
             }
           })
           let set2 = new Set()
+          // 鍚堝苟鐨勬暟鎹鐞�,cs  rs  浠h〃鍚堝苟鐨勬暟閲�
           a.template.forEach(b => {
             let size1 = set2.size
             let size2 = set2.add(b.mc).size
@@ -1560,69 +2659,74 @@
             }
           })
         })
+        // 鏈寰幆涓昏鏄鍚庣浼犲弬杩涜鍒濆鍖�,鏍峰紡閫昏緫淇敼
         this.tableList.forEach(a => {
           let arrs = []
           let set = new Set()
           let count1 = 0
           let conclusionList = []; //缁撹鍒楄〃
           let finalList = []; //鏈�缁堝�煎垪琛�
-          conclusionList = a.template.filter(n => n.v.ps != undefined && n.v.ps.value === '缁撹')
-          finalList = a.template.filter(n => n.v.ps != undefined && n.v.ps.value === '鏈�缁堝��')
-          a.template.forEach(b => {
-            if (b.v.ps != undefined && b.v.ps.value === '搴忓彿' && (b.v.mc == undefined || Object.keys(b.v.mc)
-                .length === 4)) {
+          // 缁撹涓庢渶缁堝�煎湪杩欓噷涓�涓�瀵瑰簲,浠ヤ笅涓や釜鍒楄〃闀垮害鑲畾鏄竴鏍风殑,濡傛灉鏈変笉涓�鏍�,閭d箞澶氬崐鏄ā鏉块厤缃緱闂
+          conclusionList = a.template.filter(n => n.v.ps != undefined && n.v.ps.value === '缁撹')//缁撹鍒楄〃
+          finalList = a.template.filter(n => n.v.ps != undefined && n.v.ps.value === '鏈�缁堝��')//鏈�缁堝�煎垪琛�
+          a.template.forEach( b => {
+            if (b.v.ps != undefined && b.v.ps.value === '搴忓彿' && (b.v.mc == undefined || Object.keys(b.v.mc).length === 4)) {
+              // 瀵瑰簭鍙疯繘琛岃祴鍊�
               count1++
               b.v.v = count1
             }
             if (b.v.ps != undefined && b.v.ps.value === '瑕佹眰鍊�') {
+              // 瀵硅姹傚�艰繘琛岃祴鍊�
               b.v.v = this.getAsk(b.i)
             }
-            if (b.v.ps != undefined && b.v.ps.value === '妫�楠屽��') {
-              b.v.v = ''
+            // 瀵归〉闈㈢殑鍜岀粰鍚庣浼犲弬鐨勬楠屽��,璁$畻鍊�,璁惧缂栫爜,璁惧鍚嶇О,鏈�缁堝��,缁撹杩涜鍒濆鍖�
+            if (b.v.ps != undefined && typeof b.v.ps.value ==='string'&&b.v.ps.value.includes('妫�楠屽��')) {
+              this.$set(b.v, 'v','' )
+              // b.v.v = ''
               b.u = ''
-              b.i && this.param[b.i].insValue.push(b)
+              b.i && this.param[b.i]&&this.param[b.i].insValue.push(b)
             }
             if (b.v.ps != undefined && b.v.ps.value === '璁$畻鍊�') {
-              b.v.v = ''
-              b.i && this.param[b.i].comValue.push(b)
+              this.$set(b.v, 'v','' )
+              // b.v.v = ''
+              b.i && this.param[b.i]&&this.param[b.i].comValue.push(b)
             }
             if (b.v.ps != undefined && b.v.ps.value === '璁惧缂栫爜') {
-              b.v.v = ''
-              b.i && this.param[b.i].equipValue.push(b)
+              // b.v.v = ''
+              this.$set(b.v, 'v', '' )
+              b.i && this.param[b.i]&&this.param[b.i].equipValue.push(b)
             }
             if (b.v.ps != undefined && b.v.ps.value === '璁惧鍚嶇О') {
-              b.v.v = ''
-              b.i && this.param[b.i].equipName.push(b)
+              this.$set(b.v, 'v', '' )
+              // b.v.v = ''
+              b.i && this.param[b.i]&&this.param[b.i].equipName.push(b)
             }
             if (b.v.ps != undefined && b.v.ps.value === '鏈�缁堝��') {
-              b.v.v = ''
-              /* if (b.i === undefined) {
-                for (var c in this.param) {
-                  this.param[c].resValue = b
-                }
-              } else {
-                this.param[b.i].resValue = b
-              } */
-              if (b.i !== undefined&&!this.param[b.i].resValue) {
+              // b.v.v = ''
+              this.$set(b.v, 'v', '' )
+              if (b.i !== undefined&&this.param[b.i]&&!this.param[b.i].resValue) {
                 this.param[b.i].resValue = b
               }
             }
             if (b.v.ps != undefined && b.v.ps.value === '缁撹') {
-              if (b.i !== undefined&&!this.param[b.i].insResult) {
+              if (b.i !== undefined&&this.param[b.i]&&!this.param[b.i].insResult) {
                 this.param[b.i].insResult = b
                 conclusionList.forEach((n, i) => {
                   if (n.r == b.r && n.c == b.c) {
                     b.v.f =
                       `(${this.comparisonList.find(j=>j.value==(finalList[i].c)).label}${finalList[i].r+1})`
+
                   }
                 })
               }
             }
             set.add(b.r)
+            // 濡傛灉妯℃澘鍒楄〃鐨勫嚱鏁板瓨鍦�,閭d箞鍔犲叆鍒癳xcel鍑芥暟鍒楄〃閲岄潰
             if (b.v.f) {
               this.excelMethodList.push(b)
             }
           })
+          // 浠ヤ笅鏄牱寮忓鐞嗛�昏緫
           set = Array.sort(set)
           set.forEach(b => {
             let arr = []
@@ -1639,55 +2743,103 @@
             this.tableWidth += (a.style.columnlen[i] === undefined ? 100 : a.style.columnlen[i])
           }
         })
-        this.currentSample.insProduct.forEach(a => {
+        // 鏈寰幆涓昏鏄椤甸潰鍙婂悗绔紶鍙傝繘琛屽垵濮嬪寲璧嬪��
+        this.currentSample.insProduct.forEach(async a => {
           try {
+            // 璁$畻鍊艰祴鍊�
             let comValue = JSON.parse(a.insProductResult.comValue)
             for (var i = 0; i < comValue.length; i++) {
-              this.param[a.id].comValue[i].v.v = comValue[i].v
+              this.param[a.id].comValue[i].v.v = this.toFixed(comValue[i].v,this.param[a.id].comValue[i].v.ct)
             }
           } catch (e) {}
           try {
+            // 妫�楠屽�艰祴鍊�
             let insValue = JSON.parse(a.insProductResult.insValue)
             for (let i = 0; i < insValue.length; i++) {
-              this.param[a.id].insValue[i].v.v = insValue[i].v
-              this.param[a.id].insValue[i].u = insValue[i].u
+              if(this.param[a.id].insValue.find(m=>m.c==insValue[i].c&&m.r==insValue[i].r)){
+                this.param[a.id].insValue.find(m=>m.c==insValue[i].c&&m.r==insValue[i].r).v.v = this.toFixed(insValue[i].v,this.param[a.id].insValue.find(m=>m.c==insValue[i].c&&m.r==insValue[i].r).v.ct)
+                this.param[a.id].insValue.find(m=>m.c==insValue[i].c&&m.r==insValue[i].r).u = insValue[i].u
+                // this.param[a.id].insValue[i].v.v = insValue[i].v
+                // this.param[a.id].insValue[i].u = insValue[i].u
+              }
             }
           } catch (e) {}
           try {
+            // 璁惧缂栧彿璧嬪��
             let equipValue = JSON.parse(a.insProductResult.equipValue)
+            if(this.tableLists.find(m=>m.templateId==this.currentTable)&&(this.tableLists.find(m=>m.templateId==this.currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'||this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('鐑惊鐜�')||this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('娓╁崌璇曢獙'))){
+              // 鐗规畩椤圭洰鍒濆鍖�
+              this.param[a.id].equipValue = []
+              for (let i = 0; i < equipValue.length; i++) {
+                this.param[a.id].equipValue.push({
+                  v:{
+                    v:''
+                  }
+                })
+              }
+            }
             for (let i = 0; i < equipValue.length; i++) {
-              if(this.tableLists.find(m=>m.templateId==this.currentTable)&&this.tableLists.find(m=>m.templateId==this.currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'){
-                // 娓╁害寰幆璧嬪��
+              if(this.tableLists.find(m=>m.templateId==this.currentTable)&&(this.tableLists.find(m=>m.templateId==this.currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'||this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('鐑惊鐜�')||this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('娓╁崌璇曢獙'))){
+                // 娓╁害寰幆璁惧璧嬪��
                 this.$set(this.equipForm,`code`+i,equipValue[i].v)
+                this.param[a.id].equipValue[i].v.v = equipValue[i].v
               }else{
+                // 鏅�氳澶囪祴鍊�
                 this.param[a.id].equipValue[i].v.v = equipValue[i].v
               }
             }
           } catch (e) {}
           try {
+            // 璁惧鍚嶇О璧嬪��
             let equipName = JSON.parse(a.insProductResult.equipName)
+            if(this.tableLists.find(m=>m.templateId==this.currentTable)&&(this.tableLists.find(m=>m.templateId==this.currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'||this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('鐑惊鐜�')||this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('娓╁崌璇曢獙'))){
+              // 璁惧鍚嶇О鍒濆鍖�
+              this.param[a.id].equipName = []
+              for (let i = 0; i < equipName.length; i++) {
+                this.param[a.id].equipName.push({
+                  v:{
+                    v:''
+                  }
+                })
+              }
+            }
             for (let i = 0; i < equipName.length; i++) {
-              if(this.tableLists.find(m=>m.templateId==this.currentTable)&&this.tableLists.find(m=>m.templateId==this.currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'){
+              if(this.tableLists.find(m=>m.templateId==this.currentTable)&&(this.tableLists.find(m=>m.templateId==this.currentTable).templateName=='娓╁害寰幆妫�楠屽師濮嬭褰�'||this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('鐑惊鐜�')||this.tableLists.find(m=>m.templateId==this.currentTable).templateName.includes('娓╁崌璇曢獙'))){
                 // 娓╁害寰幆璧嬪��
                 this.$set(this.equipForm,`value`+i,equipName[i].v)
+                this.param[a.id].equipName[i].v.v = equipName[i].v
               }else{
+                // 鏅�氳澶囧悕绉拌祴鍊�
                 this.param[a.id].equipName[i].v.v = equipName[i].v
               }
             }
           } catch (e) {}
           try {
-            this.param[a.id].resValue.v.v = a.lastValue
+            // 鏈�缁堝�艰祴鍊�
+            this.param[a.id].resValue.v.v = this.toFixed(a.lastValue,this.param[a.id].resValue.v.ct)
+            // 缁撹璧嬪��
             this.param[a.id].insResult.v.v = a.insResult
           } catch (e) {}
         })
+        // 瀵筫xcel鍑芥暟杩涜澶勭悊
         this.handleExcelMethod()
       },
-      changeInput(m, code, n) {
+      // 妫�楠屽�艰緭鍏ュ悗瑙﹀彂鐨勫嚱鏁�
+      changeInput(m, code, n,getDataType) {
+        // 涓烘暟閲囧畾涔変竴涓�昏緫鍙傛暟
+        if(getDataType=='getDataType'){
+          this.getDataType = 2;
+        }
         if (n) {
-          // if (this.PROJECT === '瑁呭鐢电紗') {
-          //   let num2 = new this.$Big(n.v.v)
-          //   n.v.v = num2.toExponential()
-          // }
+          // 闇�瑕佺瀛﹁鏁版硶鐨勫彲浠ヨ蛋杩欓噷
+          if (this.PROJECT === '妫�娴嬩腑蹇�') {
+            if(this.tableList.find(ele=>ele.inspectionItem=='浣撶Н鐢甸樆鐜�')){
+              if(parseFloat(n.v.v)>=100000){
+                let num2 = new this.$Big(n.v.v)
+                n.v.v = num2.toExponential()
+              }
+            }
+          }
           // 瀹氫箟涓�涓嚱鏁版潵楠岃瘉鍒嗘暟鏄惁鏈夋晥
           function isValidFraction(fraction) {
             const [numerator, denominator] = fraction.split('/'); // 鍒嗗瓙鍜屽垎姣�
@@ -1698,27 +2850,34 @@
             n.v.v = n.v.v.replace('/', '')
           }
         }
-        this.startWorker()
-
-        // 鍚� Worker 鍙戦�佹秷鎭紝寮�濮嬪鐞嗛�昏緫
-        this.worker.postMessage(JSON.stringify({
-          code: code,
-          tableList:this.tableList,
-          excelMethodList:this.excelMethodList,
-          comparisonList:this.comparisonList,
-          currentSample:this.currentSample,
-          PROJECT:this.PROJECT,
-          param:this.param
-        }));
+        try {
+          // 鍚� Worker 鍙戦�佹秷鎭紝寮�濮嬪鐞嗛�昏緫
+          this.worker.postMessage(JSON.stringify({
+            code: code,
+            tableList:this.tableList,
+            excelMethodList:this.excelMethodList,
+            comparisonList:this.comparisonList,
+            currentSample:this.currentSample,
+            PROJECT:this.PROJECT,
+            param:this.param,
+            currentTable:this.currentTable,
+            getDataTypeId:this.getDataTypeId
+          }));
+        } catch (error) {
+          console.log(444,error);
+        }
 
         // 鐩戝惉 Worker 杩斿洖鐨勭粨鏋�
         this.worker.onmessage = (event) => {
           this.result = JSON.parse(event.data);
           switch (this.result.method){
             case 'saveInsContext':
+              console.log(`output->`,11111111111111)
               this.$nextTick(()=>{
-                this.tableList = this.result.value.tableList
+                // this.$delete(this.tableList[0],'arr')
+                this.$set(this.tableList[0],'arr',this.result.value.tableList[0].arr)
                 this.param = this.result.value.param
+                // 鐗规畩澶勭悊涓�涓嬬粨璁�,浼氭湁杩欑鐗规畩鎯呭喌
                 for (var i in this.param){
                   if(this.param[i].insResult&&this.param[i].insResult.v&&this.param[i].insResult.v.v){
                     if(this.param[i].insResult.v.v=='鍚堟牸'){
@@ -1728,37 +2887,55 @@
                     }
                   }
                 }
-                this.saveInsContext()
+                // 濡傛灉鏄暟閲囧彲缂栬緫杈撳叆鐨勬儏鍐�,鍙互鐩存帴淇濆瓨鏁版嵁
+                if(this.getDataType==2){
+                  this.saveInsContext()
+                }else{
+                  if(this.isGet&&!this.dataAcquisitionEidtAble){
+                    if(this.result.value.getDataTypeId==''){
+                      // 濡傛灉鏄暟閲囦笉鍙紪杈戣緭鍏ョ殑鎯呭喌,涓旀渶鍚庝竴涓暟閲囨病鏈夊畬鎴�,鍒欎笉淇濆瓨鏁版嵁
+                      return
+                    }
+                    // 淇濆瓨鏁版嵁
+                    setTimeout(()=>{
+                      this.saveInsContext()
+                    },2000)
+                  }else if(this.isGet&&this.dataAcquisitionEidtAble){
+                    if(this.getDataType==1){
+                      if(this.result.value.getDataTypeId==''){
+                        // 濡傛灉鏄暟閲囧彲缂栬緫杈撳叆鐨勬儏鍐�,涓旀渶鍚庝竴涓暟閲囨病鏈夊畬鎴�,鍒欎笉淇濆瓨鏁版嵁
+                        return
+                      }
+                      this.saveInsContext()
+                    }else{
+                      this.saveInsContext()
+                    }
+                  }else{
+                    this.saveInsContext()
+                  }
+                }
               })
               break;
             case 'tableList':
               this.$nextTick(()=>{
-                this.tableList = this.result.value
+                // 鏇存柊鏁版嵁
+                this.$delete(this.tableList[0],'arr')
+                this.$set(this.tableList[0],'arr',this.result.value[0].arr)
               })
               break;
             case 'getCurrentInsProduct':
+              // 鏇存柊椤甸潰鏁版嵁
               this.getCurrentInsProduct(this.result.value)
               break;
           }
-          // if(this.result.method=='saveInsContext'){
-          //   this.stopWorker(); // 澶勭悊瀹屾垚鍚庡仠姝� Worker
-          // }
         };
       },
-      handleFraction(str){
-        if(str&&typeof(str)=='string'&&str.includes('/')){
-          return eval(str.split('/')[0]/str.split('/')[1])
-        } else if (str && typeof(str) == 'string' && str.includes('*') && str.includes('^')) {
-          const num1 = str.split('*')
-          const num2 = num1[1].split('^')
-          let num3 = new this.$Big(num2[0]);
-          let num4 = new this.$Big(num2[1]);
-          let num5 = Math.pow(num3, num4) // 璁$畻娆℃柟
-          return num1[0] * num5 // 鏈�鍚庤绠椾箻娉�
-        } else{
-          return str
-        }
+      // 鏄惁闇�瑕佹暟閲�
+      async determineWhetherToCollectData(){
+        let res = await this.$axios.get(this.$api.deviceScope.determineWhetherToCollectData+"?managementNumber=''")
+        this.isGet =  res.data
       },
+      // 鏍规嵁鍚庣浼犲弬鏇存柊椤甸潰鏁版嵁   param => this.tableList[0].insProductResult
       getCurrentInsProduct(pId) {
         if (!this.tableList[0].insProductResult) {
           this.tableList[0].insProductResult = {}
@@ -1767,6 +2944,7 @@
           let value = this.param[pId][m]
           switch (m) {
             case 'comValue':
+              // 璧嬪�艰绠楀��
               if (value && value.length > 0) {
                 this.tableList[0].insProductResult[m] = [];
                 value.forEach((a, i) => {
@@ -1775,9 +2953,14 @@
                   }
                   this.tableList[0].insProductResult[m].push(obj);
                 })
+                try {
+                  this.tableList[0].insProductResult[m] = JSON.stringify(this.tableList[0].insProductResult[m])
+                } catch (error) {
+                  console.log(555,error);
+                }
               }
-              this.tableList[0].insProductResult[m] = JSON.stringify(this.tableList[0].insProductResult[m])
               break;
+              // 璧嬪�兼楠屽��
             case 'insValue':
               if (value && value.length > 0) {
                 this.tableList[0].insProductResult[m] = [];
@@ -1788,9 +2971,14 @@
                   }
                   this.tableList[0].insProductResult[m].push(obj);
                 })
+                try {
+                  this.tableList[0].insProductResult[m] = JSON.stringify(this.tableList[0].insProductResult[m])
+                } catch (error) {
+                  console.log(666,error);
+                }
               }
-              this.tableList[0].insProductResult[m] = JSON.stringify(this.tableList[0].insProductResult[m])
               break;
+              // 璧嬪�艰澶囩紪鍙�
             case 'equipValue':
               if (value && value.length > 0) {
                 this.tableList[0].insProductResult[m] = [];
@@ -1800,9 +2988,14 @@
                   }
                   this.tableList[0].insProductResult[m].push(obj);
                 })
+                try {
+                  this.tableList[0].insProductResult[m] = JSON.stringify(this.tableList[0].insProductResult[m])
+                } catch (error) {
+                  console.log(777,error);
+                }
               }
-              this.tableList[0].insProductResult[m] = JSON.stringify(this.tableList[0].insProductResult[m])
               break;
+              // 璧嬪�艰澶囧悕绉�
             case 'equipName':
               if (value && value.length > 0) {
                 this.tableList[0].insProductResult[m] = [];
@@ -1812,44 +3005,50 @@
                   }
                   this.tableList[0].insProductResult[m].push(obj);
                 })
+                try {
+                  this.tableList[0].insProductResult[m] = JSON.stringify(this.tableList[0].insProductResult[m])
+                } catch (error) {
+                  console.log(888,error);
+                }
               }
-              this.tableList[0].insProductResult[m] = JSON.stringify(this.tableList[0].insProductResult[m])
               break;
+              // 璧嬪�兼渶缁堝��
             case 'resValue':
               this.tableList[0].lastValue = value?value.v.v:''
               break;
+              // 璧嬪�肩粨璁�
             case 'insResult':
               this.tableList[0].insResult = value?value.v.v:''
               break;
           }
         }
       },
+      // 瀵笶XCEL鍑芥暟杩涜澶勭悊
       handleExcelMethod() {
         if (this.excelMethodList.length > 0) {
           this.excelMethodList.map(item => {
+            // 寰楀埌姣忎釜鍑芥暟鐨勫弬鏁板垪琛�
             item.valueList = excelFunction.changeParameter(item.v.f);
             return item;
           })
         }
       },
-      median(arr) {
-          // 瀵规暟缁勮繘琛屾帓搴�
-          const sortedArr = arr.sort((a, b) => a - b);
-          // 璁$畻鏁扮粍闀垮害鐨勪竴鍗�
-          const half = Math.floor(sortedArr.length / 2);
-          // 濡傛灉鏁扮粍闀垮害涓哄鏁帮紝杩斿洖涓棿鐨勫厓绱狅紱濡傛灉涓哄伓鏁帮紝杩斿洖涓棿涓や釜鍏冪礌鐨勫钩鍧囧��
-          if (sortedArr.length % 2) {
-              // 濂囨暟浣嶇疆鐨勫厓绱�
-              return sortedArr[half];
-          } else {
-              // 鍋舵暟浣嶇疆鐨勫钩鍧囧��
-              return (sortedArr[half - 1] + sortedArr[half]) / 2;
-          }
-      },
       getValue(v){
+        // 瀵归〉闈㈠睍绀烘暟鎹繘琛屽鐞�,@,浠h〃鎹㈣
         let str = v.v?v.v:(v.v===0?v.v:(v.ct&&v.ct.s?v.ct.s.length>0&&v.ct.s[0].v.replace(new RegExp('\n', 'g'), '<br/>').replace(new RegExp('@', 'g'), '<br/>'):''))
+        // 瀵规暟鎹繚鐣欏皬鏁扮偣杩涜澶勭悊
+        if(v.ct&&v.ct.fa&&v.ct.fa.includes('.')&&str){
+          let num = 0
+          let str0 = v.ct.fa.split('.')[1]
+          num = str0.length
+          str = Number(str).toFixed(num)
+        }
+        if(v.v&&typeof v.v == 'string'&&v.v.includes('@')){
+          str = v.v.replace(new RegExp('@', 'g'), '<br/>')
+        }
         return str
       },
+      // 鑾峰彇褰撳墠杈撳叆妗嗙被鍨�
       getInspectionValueType(id) {
         for (var a in this.currentSample.insProduct) {
           if (this.currentSample.insProduct[a].id == id) {
@@ -1857,6 +3056,7 @@
           }
         }
       },
+      // 鑾峰彇瑕佹眰鎻忚堪
       getTell(id) {
         for (var a in this.currentSample.insProduct) {
           if (this.currentSample.insProduct[a].id == id) {
@@ -1864,6 +3064,7 @@
           }
         }
       },
+      // 鍔ㄦ�佽幏鍙栧崟鍏冩牸瀹藉害
       handleWidth(n) {
         let sum = 0;
         if (n.v.mc && n.v.mc.cs && n.v.mc.c != undefined) {
@@ -1876,12 +3077,18 @@
         }
         return sum
       },
+      // 瀵硅緭鍏ュ�艰繘琛屾牸寮忔牎楠�
       handleInput (n) {
-        n.v.v = n.v.v.replace(/[^\d.^e\-/+]/g, '');
-        n.v.v = n.v.v.replace(/\.{2,}/g,"."); //鍙繚鐣欑涓�涓�. 娓呴櫎澶氫綑鐨�
-        n.v.v = n.v.v.replace(".","$#$").replace(/\./g,"").replace("$#$",".");
-        n.v.v = n.v.v.replace(/\/{2,}/g,"/"); //鍙繚鐣欑涓�涓�/娓呴櫎澶氫綑鐨�
-        n.v.v = n.v.v.replace("/","$#$").replace(/\//g,"").replace("$#$","/");
+        try {
+          n.v.v = n.v.v.replace(/[^\d.^e\-/+]/g, '');
+          n.v.v = n.v.v.replace(/\.{2,}/g,"."); //鍙繚鐣欑涓�涓�. 娓呴櫎澶氫綑鐨�
+          n.v.v = n.v.v.replace(".","$#$").replace(/\./g,"").replace("$#$",".");
+          n.v.v = n.v.v.replace(/\/{2,}/g,"/"); //鍙繚鐣欑涓�涓�/娓呴櫎澶氫綑鐨�
+          n.v.v = n.v.v.replace("/","$#$").replace(/\//g,"").replace("$#$","/");
+        } catch (error) {
+          console.log(error);
+        }
+
       },
       getInspectionItemType(id) {
         for (var a in this.currentSample.insProduct) {
@@ -1890,6 +3097,7 @@
           }
         }
       },
+      // 鑾峰彇瑕佹眰鍊�
       getAsk(id) {
         for (var a in this.currentSample.insProduct) {
           if (this.currentSample.insProduct[a].id == id) {
@@ -1927,6 +3135,7 @@
           }
         } */
       },
+      // 鑾峰彇璁惧
       getEquipOptions(e, id) {
         if (e) {
           this.equipOptions = []
@@ -1961,16 +3170,18 @@
       getUserInfo() {
         this.$axios.get(this.$api.user.getUserInfo).then(res => {
           this.userId = res.data.id
+          this.componentData.entity.userId = res.data.id
+          // console.log(1111,this.userId)
         })
       },
       // 澶嶆牳
       upInsReview(e) {
-        if (e == 1) {
-          // 閫氳繃
+        if (e == 1||e==2) {
+          // 缁х画璇曢獙
           this.reviewLoading = true;
           this.$axios.post(this.$api.insOrderPlan.verifyPlan, {
             orderId: this.orderId,
-            type: 1,
+            type: e,
             laboratory: this.sonLaboratory,
             tell: null
           }).then(res => {
@@ -1983,8 +3194,8 @@
             console.error(error)
             this.reviewLoading = false;
           })
-        } else {
-          // 涓嶉�氳繃
+        } else{
+          // 鍐嶆璇曢獙
           this.reviewDia = true;
         }
       },
@@ -2010,6 +3221,14 @@
           this.$message.error('鏈緭鍏ヤ笉閫氳繃鍘熷洜')
         }
       },
+      handleSubmit(){
+        if(this.insOrder.orderType=='C'){
+          this.verifyUser = this.insOrder.prepareUserId
+          this.submit()
+        }else{
+          this.addVerifyDia = true
+        }
+      },
       submit() {
         if (this.verifyUser === null || this.verifyUser === '') {
           this.$message.error("璇锋寚瀹氬鏍镐汉鍛�")
@@ -2026,7 +3245,8 @@
               this.$axios.post(this.$api.insOrderPlan.submitPlan, {
                 orderId: this.orderId,
                 laboratory: this.sonLaboratory,
-                verifyUser: this.verifyUser
+                verifyUser: this.verifyUser,
+                entrustCode: this.insOrder.entrustCode
               }).then(res => {
                 if (res.code === 200) {
                   this.$message.success("鎿嶄綔鎴愬姛")
@@ -2047,7 +3267,7 @@
                 }
                 newData.push(h('p', {style: 'font-size: 14px;color: red;'}, (Number(i)+1)+'銆�'+res.data[i]))
               }
-              newData.push(h('p',  { style: 'font-size: 16px;color:#000;margin-top:12px' },'浠ヤ笂椤圭洰涓嶅悎鏍硷紝纭畾鎻愪氦锛�'))
+              newData.push(h('p',  { style: 'font-size: 16px;color:#000;margin-top:12px;overflow-y: auto;max-height:80vh' },'浠ヤ笂椤圭洰涓嶅悎鏍硷紝纭畾鎻愪氦锛�'))
               this.$confirm('鎻愮ず',{
                 title:'鎻愮ず',
                 message: h('div', null, newData),
@@ -2059,8 +3279,9 @@
                   orderId: this.orderId,
                   laboratory: this.sonLaboratory,
                   verifyUser: this.verifyUser
-                }).then(res => {
+                }).then( res => {
                   if (res.code === 200) {
+                    this.submitLoading = false;
                     this.$message.success("鎿嶄綔鎴愬姛")
                     this.$emit('goback')
                   }
@@ -2071,46 +3292,115 @@
             }
 
           }
-          this.submitLoading = false;
         }).catch(error => {
           console.error(error)
           this.submitLoading = false;
         })
         return
       },
-      saveInsContext() {
-        if(this.param){
-          this.$axios.post(this.$api.insOrderPlan.saveInsContext, {
-            param: JSON.stringify(this.param)
+      async handleCType(){
+        if(this.insOrder.departmentLims=='璐ㄩ噺閮�'){
+          await this.$axios.post(this.$api.insOrderPlan.verifyPlan, {
+            orderId: this.orderId,
+            type: 1,
+            laboratory: this.sonLaboratory,
+            tell: null
           }).then(res => {
-            if (res.code == 201) {
-              this.$message.error('淇濆瓨澶辫触')
-              return
+            if (res.code === 200) {
             }
-            this.$message.success('宸蹭繚瀛�')
+          }).catch(error => {
           })
         }
       },
-      changeEquip(val, n) {
+      // 缁熶竴鍦ㄨ繖閲屼繚瀛樻暟鎹�
+      saveInsContext() {
+        try {
+          console.log(1111,this.param)
+          if(this.param){
+            this.$axios.post(this.$api.insOrderPlan.saveInsContext, {
+              param: JSON.stringify(this.param),
+              currentTable:this.currentTable,
+              num:this.currentSample.num1
+            }).then(res => {
+              if (res.code == 201) {
+                this.$message.error('淇濆瓨澶辫触')
+                return
+              }
+              this.$message.success('宸蹭繚瀛�')
+            })
+            // 鍚� Worker 鍙戦�佹秷鎭紝寮�濮嬪鐞嗛�昏緫
+            this.worker.postMessage(JSON.stringify({
+              type: 'saveData',
+              tableList:this.tableList,
+              param:this.param,
+              currentTable:this.currentTable
+            }));
+          }
+        }catch (error) {
+          console.log(999,error);
+        }
+      },
+      // 璁惧鏀瑰彉
+      changeEquip(val, n,v) {
+        this.$set(n.v,'v',val)
+        this.tableList[0].arr.forEach((item,index)=>{
+          item.forEach((m,i)=>{
+            if(this.param[m.i]){
+              this.param[m.i].state = 1
+            }
+            if(m.i==n.i&&m.v.ps&&m.v.ps.value=='璁惧鍚嶇О'&&v){
+              this.$set(m.v,'v',v)
+            }
+          })
+        })
+        for (let i in this.param) {
+          if(this.param[i].state!=1){
+            delete this.param[i]
+          }
+        }
+        if(val&&v){
+          for (let i1 in this.param[n.i].equipName) {
+            if (this.param[n.i].equipName[i1].i === n.i && this.param[n.i].equipName[i1].r === n.r) {
+              this.$delete(this.param[n.i].equipValue[i1].v,'v')
+              this.$set(this.param[n.i].equipValue[i1].v,'v',val)
+              this.$delete(this.param[n.i].equipName[i1].v,'v')
+              this.$set(this.param[n.i].equipName[i1].v,'v',v)
+            }
+          }
+        }
         for (let i in this.equipOptions) {
-          if (this.equipOptions[i].value === val) {
+          if (this.equipOptions[i].value == val) {
             for (let i1 in this.param[n.i].equipName) {
               if (this.param[n.i].equipName[i1].i === n.i && this.param[n.i].equipName[i1].r === n.r) {
-                this.param[n.i].equipName[i1].v.v = this.equipOptions[i].label
+                this.$delete(this.param[n.i].equipValue[i1].v,'v')
+                this.$set(this.param[n.i].equipValue[i1].v,'v',val)
+                this.$delete(this.param[n.i].equipName[i1].v,'v')
+                this.$set(this.param[n.i].equipName[i1].v,'v',this.equipOptions[i].label)
+                this.tableList[0].arr.forEach((item,index)=>{
+                  item.forEach((m)=>{
+                    if(m.i==n.i&&m.v.ps&&m.v.ps.value=='璁惧鍚嶇О'){
+                      this.$set(m.v,'v',this.equipOptions[i].label)
+                    }
+                  })
+                })
               }
             }
           }
         }
+        // 淇濆瓨鏁版嵁
         this.saveInsContext()
       },
       getAuthorizedPerson() {
         this.$axios.get(this.$api.user.getUserMenu).then(res => {
           let data = []
+          // let userName = JSON.parse(localStorage.getItem("user")).name;
           res.data.forEach(a => {
-            data.push({
+            if(!this.inspectorList.includes(a.name)) {
+              data.push({
               label: a.name,
               value: a.id
             })
+            }
           })
           this.personList = data
         })
@@ -2142,6 +3432,7 @@
           flag = false;
         });
       },
+      // 椤甸潰閲岄潰鍒囨崲鏍峰搧
       async caretSample(num){
         let index = this.currentKey + num
         if(index < 1){
@@ -2153,20 +3444,33 @@
         }
         this.currentKey = index
         this.currentSample = this.HaveJson(this.sampleProduct[index - 1])
+        // 鑾峰彇妫�楠岄」
         let list = await this.getCurrentProduct(this.currentSample.id,0)
         this.currentSample.insProduct = this.HaveJson(list)
+        // 鍒濆鍖栧悗绔紶鍙�
         this.param = {}
-        this.currentSample.insProduct.forEach(a => {
-          this.param[a.id] = {
-            insValue: [],
-            comValue: [],
-            resValue: null,
-            equipValue: [],
-            equipName: [],
-            insResult: null
+        this.changeType = 0;
+        this.currentSample.insProduct.forEach((a, j) => {
+          if(this.handleCasing(a.inspectionItem)){
+            this.param[a.id] = {
+              insValue: [],
+              comValue: [],
+              resValue: null,
+              equipValue: [],
+              equipName: [],
+              insResult: null
+            }
           }
         })
+        // 椤甸潰鏁版嵁澶勭悊
         this.getTableLists()
+        // 鏇存柊鍒板绾跨▼
+        this.worker.postMessage(JSON.stringify({
+          type: 'saveData',
+          tableList:this.tableList,
+          param:this.param,
+          currentTable:this.currentTable
+        }));
       },
       caretBushing(num){
         let index = this.currentKey0 + num
@@ -2215,7 +3519,6 @@
             insResult: null
           }
         })
-        this.fiberOpticTapeVisible = false;
         let list = await this.getCurrentProduct(this.currentFiberOpticTape.id,1)
         this.getTableLists0(list)
         if(this.currentFiberOpticTape.fiber&&this.currentFiberOpticTape.fiber.length>0){
@@ -2298,16 +3601,37 @@
        * @returns 鏍煎紡鍖栧悗鐨勫瓧绗︿覆鎴栧師濮嬫暟鍊硷紙鑻ラ厤缃笉绗﹀悎瑕佹眰锛�
        */
       toFixed(v,ct){
-        if(v&&ct&&ct.fa&&ct.fa.includes('##')){
+        if(v&&ct&&ct.fa){
           if(ct.fa.includes('.')){
             let num = ct.fa.slice(4).length
             return Number(v).toFixed(num)
           }else{
-            return Number(v).toFixed(0)
+            return v
           }
         }else{
           return v
         }
+      },
+      async getCurrentItem(){
+        let list = await this.getCurrentProduct(this.currentSample.id,0)
+        this.currentSample.insProduct = this.HaveJson(list)
+      },
+      saveVersion(){
+        if(this.currentTableState!=0&&this.currentTableState!=1){
+          this.$message.error('璇烽�夋嫨鐗堟湰')
+          return
+        }
+        this.versionLoading = true;
+        this.$axios.post(this.$api.insOrderPlan.chooseVersion, {
+          orderStateId: this.orderStateId,
+          version: this.currentTableState
+        }).then(res => {
+          this.versionLoading = false;
+          if(res.code==201){
+            return
+          }
+          this.versionDialogVisible = false
+        })
       }
     }
   }

--
Gitblit v1.9.3