From 57e76b55709e8ea88a83ab6c3f665fd9ee7fd64c Mon Sep 17 00:00:00 2001
From: licp <lichunping@guanfang.com.cn>
Date: 星期三, 03 七月 2024 14:23:48 +0800
Subject: [PATCH] Merge branch 'master' of http://114.132.189.42:9002/r/center-lims-before into master

---
 src/components/do/b1-ins-order/fiberoptic-config.vue |  669 +++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 594 insertions(+), 75 deletions(-)

diff --git a/src/components/do/b1-ins-order/fiberoptic-config.vue b/src/components/do/b1-ins-order/fiberoptic-config.vue
index 3be7c9f..8255f67 100644
--- a/src/components/do/b1-ins-order/fiberoptic-config.vue
+++ b/src/components/do/b1-ins-order/fiberoptic-config.vue
@@ -2,11 +2,11 @@
   <div class="ins_order_config">
     <div>
       <el-row class="title">
-        <el-col :span="6" style="padding-left: 20px;">鍏夌氦閰嶇疆</el-col>
+        <el-col :span="6" style="padding-left: 20px;text-align: left;">鍏夌氦閰嶇疆</el-col>
         <el-col :span="18" style="text-align: right;">
-          <el-button size="medium" type="primary" @click="save" :loading="saveLoad">淇� 瀛�</el-button>
+          <el-button size="medium" type="primary" @click="save" :loading="saveLoad" v-if="active==1">淇� 瀛�</el-button>
           <el-button size="medium" @click="outConfig">
-            <span style="color: #3A7BFA;">鍙� 娑�</span>
+            <span style="color: #3A7BFA;">杩� 鍥�</span>
           </el-button>
         </el-col>
       </el-row>
@@ -22,7 +22,7 @@
                 <label style="width: 70px;">鏍峰搧鍨嬪彿</label>
                 <span style="font-size: 14px;">{{models}}</span>
               </div>
-              <el-radio-group v-model="packageInfo.radio" size="small" @change="upNum()">
+              <el-radio-group v-model="packageInfo.radio" size="small" @change="upNum()" :disabled="active!=1">
                 <el-radio :label="0">鍏ㄦ</el-radio>
                 <el-radio :label="1">鎶芥</el-radio>
               </el-radio-group>
@@ -31,33 +31,37 @@
               style="display: flex;align-items: center;justify-content: space-between;margin-bottom: 8px;padding: 0 12px;box-sizing: border-box;">
               <div class="search-item" style="margin-right: 10px;">
                 <label>濂楃鏁扮洰</label>
-                <el-input v-model="packageInfo.num1" placeholder="璇疯緭鍏�" size="small" @change="upNum"></el-input>
+                <el-input v-model="packageInfo.num1" placeholder="璇疯緭鍏�" size="small" @change="upNum" :disabled="active!=1"></el-input>
               </div>
               <div class="search-item" style="margin-right: 10px;">
                 <label style="width: 70px;">鏍囧噯閲�</label>
-                <el-input v-model="packageInfo.num2" placeholder="璇疯緭鍏�" size="small" @change="upNum"></el-input>
+                <el-input v-model="packageInfo.standNum" placeholder="璇疯緭鍏�" size="small" @change="upNum" :disabled="active!=1"></el-input>
               </div>
               <div class="search-item">
                 <label style="width: 70px;">妫�娴嬮噺</label>
-                <el-input v-model="packageInfo.num3" placeholder="璇疯緭鍏�" size="small" @change="upNum"
-                  :disabled="packageInfo.radio===0"></el-input>
+                <el-input v-model="packageInfo.testNum" placeholder="璇疯緭鍏�" size="small" @change="upNum"
+                  :disabled="packageInfo.radio===0||active!=1"></el-input>
               </div>
             </div>
             <el-table ref="table0" :data="bushing" tooltip-effect="dark" style="width: 100%" height="203px" size="small"
-              @selection-change="handleSelectionChange1">
-              <el-table-column type="selection" width="45">
+              @selection-change="handleSelectionChange1"
+              :header-cell-class-name="setClassName0">
+              <el-table-column
+              type="selection"
+              width="45"
+              :selectable="()=>(active==1)">
               </el-table-column>
               <el-table-column label="绠¤壊鏍�" show-overflow-tooltip>
                 <template slot-scope="scope">
-                  <el-select v-model="scope.row.color" size="mini">
+                  <el-select v-model="scope.row.color" size="mini" :disabled="active!=1" allow-create filterable >
                     <el-option v-for="(color,i) in colors" :key="i" :label="color.lable"
                       :value="color.value"></el-option>
                   </el-select>
                 </template>
               </el-table-column>
-              <el-table-column prop="num2" label="鏍囬噺" show-overflow-tooltip>
+              <el-table-column prop="standNum" label="鏍囬噺" show-overflow-tooltip align="center">
               </el-table-column>
-              <el-table-column prop="num3" label="娴嬭瘯閲�" show-overflow-tooltip>
+              <el-table-column prop="testNum" label="娴嬭瘯閲�" show-overflow-tooltip align="center">
               </el-table-column>
             </el-table>
           </div>
@@ -65,45 +69,54 @@
         <el-col :span="15">
           <div class="grid-content">
             <h5>妫�娴嬮」淇℃伅</h5>
-            <el-table ref="table1" :data="tableData" tooltip-effect="dark" style="width: 100%" height="282px"
-              size="small" @selection-change="handleSelectionChange">
-              <el-table-column type="selection" width="55">
+            <el-table ref="productTable" :data="detectionItems" tooltip-effect="dark" style="width: 100%"
+            :row-class-name="tableRowClassName"
+            :header-cell-class-name="setClassName"
+            height="283px"
+              size="small" @selection-change="handleSelectionChange2"
+              @select-all="handleAll"
+              @select="upProductSelect"
+              >
+              <el-table-column type="selection" width="55"
+              :selectable="()=>((currentDetectionItems||this.multiFiberList.length > 0)&&active==1)">
               </el-table-column>
-              <el-table-column label="瀹為獙瀹�" show-overflow-tooltip>
-                <template slot-scope="scope">{{ scope.row.date }}</template>
+              <el-table-column label="瀹為獙瀹�" show-overflow-tooltip prop="sonLaboratory" ></el-table-column>
+              <el-table-column prop="inspectionItem" label="妫�楠岄」" show-overflow-tooltip>
               </el-table-column>
-              <el-table-column prop="name" label="妫�娴嬮」鐩�" show-overflow-tooltip>
+              <el-table-column prop="inspectionItemSubclass" label="妫�楠岄」瀛愰」" show-overflow-tooltip width="100px">
               </el-table-column>
-              <el-table-column prop="address" label="璇曢獙鏂规硶" show-overflow-tooltip>
+              <el-table-column prop="methodS" label="璇曢獙鏂规硶" min-width="90" show-overflow-tooltip>
               </el-table-column>
-              <el-table-column prop="address" label="鍗曚环" width="70" show-overflow-tooltip>
+              <el-table-column prop="price" label="鍗曚环" width="70" show-overflow-tooltip>
               </el-table-column>
-              <el-table-column prop="address" label="鍗曚綅" width="70" show-overflow-tooltip>
+              <el-table-column prop="unit" label="鍗曚綅" width="70" show-overflow-tooltip>
               </el-table-column>
-              <el-table-column prop="address" label="棰勮鏃堕棿" show-overflow-tooltip>
-              </el-table-column>
-              <el-table-column prop="address" label="妫�娴嬫爣鍑�" show-overflow-tooltip>
-              </el-table-column>
-              <el-table-column prop="address" label="妫�娴嬭姹�" show-overflow-tooltip>
+              <!-- <el-table-column prop="manDay" label="棰勮鏃堕棿" width="90" show-overflow-tooltip>
+              </el-table-column> -->
+              <el-table-column prop="ask" label="妫�娴嬭姹�" show-overflow-tooltip width="200px">
+                <template slot-scope="scope">
+                  <el-input v-model="scope.row.ask" placeholder="璇疯緭鍏�" size="small" :disabled="active!=1" v-if="!isAskOnlyRead"></el-input>
+                  <span v-else>{{ scope.row.ask }}</span>
+                </template>
               </el-table-column>
             </el-table>
           </div>
         </el-col>
       </el-row>
       <el-row :gutter="10">
-        <el-col :span="12">
+        <el-col :span="12" v-if="packageInfo.ismiers">
           <div class="grid-content">
             <h5>鍏夌氦甯�
               <el-button size="mini" type="primary" class="btns" @click="addFibers"
-                :disabled="miresModel===null||miresStandard===null">鐢熸垚鍏夌氦甯�</el-button>
-              <el-button size="mini" class="btns" @click="clearFibers" :disabled="selectBushing.length === 0">娓呴櫎</el-button>
+                :disabled="miresModel===null||miresStandard===null" v-if="active==1">鐢熸垚鍏夌氦甯�</el-button>
+              <el-button size="mini" class="btns" @click="clearFibers" :disabled="selectBushing.length === 0" v-if="active==1">娓呴櫎</el-button>
             </h5>
             <div
               style="display: flex;align-items: center;justify-content: space-between;margin:4px 0 6px 0;padding: 0 12px;box-sizing: border-box;">
               <div class="search-item" style="width: 50%;margin-right: 16px;">
                 <label style="width: 80px;">绾ゅ甫绫诲瀷</label>
                 <el-select v-model="miresModel" placeholder="璇烽�夋嫨" size="small" style="width: 100%;"
-                  :disabled="bushing.length===0">
+                  :disabled="selectBushing.length===0||active!=1">
                   <el-option v-for="(item,a) in miresModels" :key="a" :label="item.label" :value="item.value">
                   </el-option>
                 </el-select>
@@ -111,7 +124,7 @@
               <div class="search-item" style="width: 50%;">
                 <label style="width: 80px;">鍙傝�冩爣鍑�</label>
                 <el-select v-model="miresStandard" placeholder="璇烽�夋嫨" size="small" style="width: 100%;"
-                  :disabled="miresModel===null" @focus="selectsStandardMethodByFLSSM2()"
+                  :disabled="miresModel===null||active!=1" @focus="selectsStandardMethodByFLSSM2()"
                   @change="(value)=>methodChange2(value)">
                   <el-option v-for="item in miresStandards" :key="item.id" :label="item.code" :value="item.id">
                   </el-option>
@@ -119,8 +132,12 @@
               </div>
             </div>
             <el-table ref="table2" :data="fibersList" tooltip-effect="dark" style="width: 100%" height="270px"
-              size="small" @selection-change="handleSelectionChange" highlight-current-row>
-              <el-table-column type="selection" width="55">
+              size="small" @selection-change="handleSelectionChange" highlight-current-row @row-click="(row, column, event)=>rowClickFiber(row, column, event,0)"
+              :header-cell-class-name="setClassName0">
+              <el-table-column
+              type="selection"
+              width="55"
+              :selectable="()=>(active==1)">
               </el-table-column>
               <el-table-column prop="code" label="鍏夌氦甯︾紪鍙�" show-overflow-tooltip align="center">
               </el-table-column>
@@ -133,16 +150,16 @@
             </el-table>
           </div>
         </el-col>
-        <el-col :span="12">
+        <el-col :span="!packageInfo.ismiers?24:12">
           <div class="grid-content">
             <h5>鍏夌氦<el-button size="mini" type="primary" class="btns" @click="addFiber"
-                :disabled="mireModel===null||mireStandard===null">鍏夌氦閰嶈壊</el-button></h5>
+                :disabled="mireModel===null||mireStandard===null" v-if="active==1">鍏夌氦閰嶈壊</el-button></h5>
             <div
               style="display: flex;align-items: center;justify-content: space-between;margin: 4px 0 6px 0;padding: 0 12px;box-sizing: border-box;">
               <div class="search-item" style="width: 50%;margin-right: 16px;">
                 <label style="width: 80px;">鍏夌氦绫诲瀷</label>
                 <el-select v-model="mireModel" placeholder="璇烽�夋嫨" size="small" style="width: 100%;"
-                  :disabled="bushing.length===0">
+                  :disabled="selectBushing.length===0||active!=1">
                   <el-option v-for="(item,a) in mireModels" :key="a" :label="item.label" :value="item.value">
                   </el-option>
                 </el-select>
@@ -150,22 +167,27 @@
               <div class="search-item" style="width: 50%;">
                 <label style="width: 80px;">鍙傝�冩爣鍑�</label>
                 <el-select v-model="mireStandard" placeholder="璇烽�夋嫨" size="small" style="width: 100%;"
-                  :disabled="mireModel===null" @focus="selectsStandardMethodByFLSSM()"
-                  @change="(value)=>methodChange(value)">
+                  :disabled="mireModel===null||active!=1" @focus="selectsStandardMethodByFLSSM()"
+                  @change="(value)=>methodChange(value)" :loading="mireStandardLoading">
                   <el-option v-for="item in mireStandards" :key="item.id" :label="item.code" :value="item.id">
                   </el-option>
                 </el-select>
               </div>
             </div>
             <el-table ref="table3" :data="fiberList" tooltip-effect="dark" style="width: 100%" height="270px"
-              size="small" @selection-change="handleSelectionChange">
-              <el-table-column type="selection" width="55">
+              size="small" highlight-current-row @selection-change="handleSelectionChange4"
+              @row-click="(row, column, event)=>rowClickFiber(row, column, event,1)"
+              :header-cell-class-name="setClassName0">
+              <el-table-column
+              type="selection"
+              width="55"
+              :selectable="()=>(active==1)">
               </el-table-column>
               <el-table-column prop="bushColor" label="绠″鑹叉爣" width="90" align="center">
               </el-table-column>
               <el-table-column prop="color" label="鍏夌氦鑹叉爣" width="120">
                 <template slot-scope="scope">
-                  <el-select v-model="scope.row.color" size="mini">
+                  <el-select v-model="scope.row.color" size="mini" :disabled="active!=1" allow-create filterable >
                     <el-option v-for="(color,i) in colors" :key="i" :label="color.lable"
                       :value="color.value"></el-option>
                   </el-select>
@@ -180,19 +202,113 @@
         </el-col>
       </el-row>
     </div>
+    <el-dialog title="妫�娴嬪埌鐗规畩椤癸紝璇蜂綔鍑轰互涓嬮�夋嫨" :visible.sync="bsm1Dia" width="500px" :show-close="false" :before-close="beforeClose">
+      <div class="body" style="max-height: 60vh;">
+        <el-row v-if="bsm1">
+          <el-col class="search_thing" :span="22">
+            <div class="search_label"><span class="required-span">* </span>鎶ゅ瀵嗗害锛�</div>
+            <div class="search_input">
+              <el-radio-group v-model="bsm1Val" @input="upBsm1">
+                <el-radio v-for="(a, ai) in JSON.parse(bsmRow.section)" :key="ai" :label="a"></el-radio>
+              </el-radio-group>
+            </div>
+          </el-col>
+          <el-col class="search_thing" :span="22">
+            <div class="search_label">瑕佹眰鍊硷細</div>
+            <div class="search_input" v-show="bsm1Val!==null&&bsm1Val!==''">
+              <el-radio-group v-model="bsm1Val" @input="upBsm1">
+                <el-radio v-for="(a, ai) in JSON.parse(bsmRow.section)" :key="ai"
+                  :label="a">{{JSON.parse(bsmRow.ask)[ai]}}</el-radio>
+              </el-radio-group>
+            </div>
+          </el-col>
+          <el-col class="search_thing" :span="22">
+            <div class="search_label">鍗曚环锛�</div>
+            <div class="search_input" v-show="bsm1Val!==null&&bsm1Val!==''">
+              <el-radio-group v-model="bsm1Val" @input="upBsm1">
+                <el-radio v-for="(a, ai) in JSON.parse(bsmRow.section)" :key="ai"
+                  :label="a">{{JSON.parse(bsmRow.price)[ai]}}</el-radio>
+              </el-radio-group>
+            </div>
+          </el-col>
+        </el-row>
+        <el-row v-if="bsm2">
+          <el-col class="search_thing" :span="22">
+            <div class="search_label" style="width: 220px;"><span class="required-span">* </span>鏍峰搧鐔旀帴閰嶅鏁伴噺锛�</div>
+            <div class="search_input">
+              <el-input-number size="medium" v-model="bsm2Val" :min="1" :max="bsm2Val3.length" :precision="0" style="width: 70%;"
+                :controls="false" @change="bsm2Up"></el-input-number>
+              <span>MAX锛歿{bsm2Val3.length}}</span>
+            </div>
+          </el-col>
+          <el-col style="margin-top: 6px;">
+            <el-col v-for="(a,ai) in bsm2Val2" :key="ai">
+              <el-col :span="10">
+                <el-select v-model="a[0]" placeholder="璇烽�夋嫨" size="small" style="width: 100%;">
+                  <el-option
+                    v-for="(item,index) in sampleList"
+                    :key="index"
+                    :label="index+1"
+                    :value="index+1">
+                  </el-option>
+                </el-select>
+              </el-col>
+              <!-- <el-col :span="10" class="pairing">{{a[0]}}</el-col> -->
+              <el-col :span="4" class="pairing" style="border: 0;color: rgba(0, 0, 0, 0.2);">鈥斺��</el-col>
+              <el-col :span="10">
+                <el-select v-model="a[1]" placeholder="璇烽�夋嫨" size="small" style="width: 100%;">
+                  <el-option
+                    v-for="(item,index) in sampleList"
+                    :key="index"
+                    :label="index+1"
+                    :value="index+1">
+                  </el-option>
+                </el-select>
+              </el-col>
+              <!-- <el-col :span="10" class="pairing">{{a[1]}}</el-col> -->
+            </el-col>
+          </el-col>
+        </el-row>
+        <!-- <el-row v-if="bsm3">
+          <el-col class="search_thing" :span="22" style="display: flex;align-items: center;">
+            <div class="search_label"><span class="required-span">* </span>RTS锛�</div>
+            <div class="search_input">
+              <el-input size="small" placeholder="璇疯緭鍏�" clearable v-model="bsm3Val"></el-input>
+            </div>
+          </el-col>
+        </el-row> -->
+      </div>
+    </el-dialog>
+    <el-dialog title="RTS濉啓" :visible.sync="bsm3Dia" width="500px" :show-close="false" :before-close="beforeClose0">
+      <el-row>
+        <el-col class="search_thing" :span="22" style="display: flex;align-items: center;">
+          <div class="search_label"><span class="required-span">* </span>RTS锛�</div>
+          <div class="search_input">
+            <el-input size="small" placeholder="璇疯緭鍏�" clearable v-model="bsm3Val"></el-input>
+          </div>
+        </el-col>
+      </el-row>
+    </el-dialog>
   </div>
 </template>
 
 <script>
   export default {
+    props: {
+      active: {
+        type: Number,
+        default: () => 0
+      },
+    },
     data() {
       return {
+        type:1,
         saveLoad: false,
         packageInfo: {
           radio: 1,
           num1: null,
-          num2: null,
-          num3: null,
+          standNum: null,
+          testNum: null,
           ismiers: false
         },
         tableData: [],
@@ -218,7 +334,49 @@
         productList2: [],
         fiberList: [],
         fibersList: [],
-        selectFibers: []
+        selectFibers: [],
+        detectionItems:[],
+        currentDetectionItems:null,
+        mireStandardLoading:false,
+        multiFiberList:[],
+        isAskOnlyRead:true,
+        bsm1Dia: false,
+        bsmRow: null,
+        bsm1: false,
+        bsm1Val: null,
+        bsm2: false,
+        bsm2Val: null,
+        bsm2Dia: false,
+        bsm2Val2: [],
+        bsm2Val3: [],
+        sampleIds:[],
+        bsm3Val: null,
+        bsmRow3: null,
+        bsm3Dia: false,
+      }
+    },
+    computed: {
+      isAllDisabled() {
+        return this.multiFiberList.length > 0||this.currentDetectionItems||this.active!=1
+      },
+    },
+    watch: {
+      mireModel(val1,val0) {
+        if(val1!=val0){
+          this.mireStandards = []
+          this.fiberList = []
+          this.multiFiberList = []
+          this.detectionItems = []
+          this.currentDetectionItems = null;
+        }
+      },
+      mireStandard(val1,val0) {
+        if(val1!=val0){
+          this.fiberList = []
+          this.multiFiberList = []
+          this.detectionItems = []
+          this.currentDetectionItems = null;
+        }
       }
     },
     mounted() {
@@ -232,6 +390,31 @@
         }
       })
       this.models = this.models.replace(',', '')
+      this.packageInfo.ismiers = this.models.split(',').every(e=>(e.indexOf('d')>-1||e.indexOf('D')>-1))
+      if(this.sample[0].bushing === undefined || this.sample[0].bushing === null){
+        this.bushing = []
+      }else{
+        this.bushing = this.HaveJson(this.sample[0].bushing)
+        this.packageInfo.num1 = this.sample[0].bushing.length
+        this.packageInfo.standNum = this.sample[0].bushing[0].standNum
+        this.packageInfo.testNum = this.sample[0].bushing[0].testNum
+        this.bushing.forEach(a=>{
+          if(a.fibers===null)a.fibers=[]
+          if(a.fiber===null)a.fiber=[]
+          if(this.packageInfo.ismiers){
+            a.fibers.forEach(b=>{
+              this.fibersList.push(b)
+              b.fiber.forEach(c=>{
+                this.fiberList.push(c)
+              })
+            })
+          }else{
+            a.fiber.forEach(b=>{
+              this.fiberList.push(b)
+            })
+          }
+        })
+      }
       this.getTypeDicts1()
       this.getStandTreeBySampleType()
       this.getStandTreeBySampleType2()
@@ -239,9 +422,14 @@
     methods: {
       handleSelectionChange(val) {
         this.selectFibers = val
+        this.multiFiberList = val
       },
       handleSelectionChange1(val) {
         this.selectBushing = val
+      },
+      handleSelectionChange2(val){},
+      handleSelectionChange4(val){
+        this.multiFiberList = val
       },
       outConfig() {
         this.$parent.configShow = false
@@ -254,15 +442,18 @@
         })
       },
       upNum() {
+        this.fiberList = []
+        this.fibersList = []
+        this.detectionItems = []
         if (this.packageInfo.radio === 0) {
-          this.packageInfo.num3 = this.packageInfo.num2
+          this.packageInfo.testNum = this.packageInfo.standNum
         }
-        if (parseInt(this.packageInfo.num2) < parseInt(this.packageInfo.num3)) {
-          this.packageInfo.num3 = this.packageInfo.num2
+        if (parseInt(this.packageInfo.standNum) < parseInt(this.packageInfo.testNum)) {
+          this.packageInfo.testNum = this.packageInfo.standNum
         }
         if (this.packageInfo.num1 !== null && this.packageInfo.num1 !== '' &&
-          this.packageInfo.num2 !== null && this.packageInfo.num2 !== '' &&
-          this.packageInfo.num3 != null && this.packageInfo.num3 !== '') {
+          this.packageInfo.standNum !== null && this.packageInfo.standNum !== '' &&
+          this.packageInfo.testNum != null && this.packageInfo.testNum !== '') {
           let colors2 = []
           if (this.packageInfo.num1 / this.colors.length > 1) {
             let num = this.packageInfo.num1 / this.colors.length
@@ -277,9 +468,8 @@
           for (var i = 0; i < this.packageInfo.num1; i++) {
             let bushing = {
               color: colors2[i].label,
-              num2: this.packageInfo.num2,
-              num3: this.packageInfo.num3,
-              ismiers: this.packageInfo.ismiers,
+              standNum: this.packageInfo.standNum,
+              testNum: this.packageInfo.testNum,
               fibers: [],
               fiber: []
             }
@@ -312,16 +502,18 @@
           res.data.forEach(a => {
             this.miresModels.push({
               label: a.model,
-              value: a.sample + ' - ' + a.model
+              value: a.model
             })
           })
         })
       },
       selectsStandardMethodByFLSSM() {
         this.mireStandards = []
+        this.mireStandardLoading = true
         this.$axios.post(this.$api.standardTree.selectsStandardMethodByFLSSM, {
           tree: '涓ぉ绉戞妧妫�娴嬩腑蹇� - 閫氫俊浜у搧瀹為獙瀹� - 鍏夌氦 - ' + this.mireModel
         }).then(res => {
+          this.mireStandardLoading = false
           this.mireStandards = res.data.standardMethodList
         })
       },
@@ -358,9 +550,9 @@
       methodChange2(val) {
         if (val === null || val === '') return
         this.$axios.post(this.$api.standardTree.selectStandardProductList, {
-          model: this.miresModel.split(' - ')[1],
+          model: '',
           standardMethodListId: val,
-          factory: ''
+          factory: '涓ぉ绉戞妧妫�娴嬩腑蹇� - 閫氫俊浜у搧瀹為獙瀹� - 鍏夌氦甯� - ' + this.miresModel + ' - ',
         }, {
           headers: {
             'Content-Type': 'application/json'
@@ -392,34 +584,34 @@
         let model = this.mireModel.split(' - ')[1]
         let standard = this.mireStandards.find(a => a.id == this.mireStandard).code
         if (this.packageInfo.ismiers) {
-          /* if(this.selectFibers.length === 0){
+          if(this.selectFibers.length === 0){
             this.$message.error('鏈�夋嫨鍏夌氦甯�')
             return
-          } */
-          // this.selectFibers.forEach(a => {
-          this.fibersList.forEach(a => {
+          }
+          this.selectFibers.forEach((a,index) => {
+            a.fiber = []
             for (var i = 0; i < parseInt(a.num); i++) {
               let fiber = {
                 bushColor: a.color,
-                color: colors2[i].label,
+                color: colors2[(i+(parseInt(a.num)*index))>colors2.length?0:i+(parseInt(a.num)*index)*index].label,
                 model: model,
                 standard: standard,
-                product: this.productList
+                productList: this.HaveJson(this.productList)
               }
               a.fiber.push(fiber)
               this.fiberList.push(fiber)
             }
           })
         } else {
-          // this.selectBushing.forEach(a => {
-          this.bushing.forEach(a => {
-            for (var i = 0; i < parseInt(a.num3); i++) {
+          this.selectBushing.forEach((a,index) => {
+            a.fiber = []
+            for (var i = 0; i < parseInt(a.testNum); i++) {
               let fiber = {
                 bushColor: a.color,
-                color: colors2[i].label,
+                color: colors2[(i+(parseInt(a.testNum))*index)>colors2.length?0:i+(parseInt(a.testNum))*index].label,
                 model: model,
                 standard: standard,
-                product: this.productList
+                productList: this.HaveJson(this.productList)
               }
               a.fiber.push(fiber)
               this.fiberList.push(fiber)
@@ -428,28 +620,254 @@
         }
       },
       addFibers() {
+        if(this.selectBushing.length===0){
+          this.$message.error('鏈�夋嫨濂楃')
+          return
+        }
         this.fibersList = []
-        let model = this.miresModel.split(' - ')[1]
         let standard = this.miresStandards.find(a => a.id == this.miresStandard).code
         this.packageInfo.ismiers = true
         this.fiberList = []
-        this.bushing.forEach(a => {
-        // this.selectBushing.forEach(a => {
+        this.selectBushing.forEach(a => {
           a.fiber = []
-          for (var i = 0; i < parseInt(a.num3); i++) {
+          a.fibers = []
+          for (var i = 0; i < parseInt(a.testNum); i++) {
             let fibers = {
               code: null,
               color: a.color,
-              model: model,
+              model: this.miresModel,
               standard: standard,
-              num: a.num3,
-              product: this.HaveJson(this.productList2),
+              num: a.testNum,
+              productList: this.HaveJson(this.productList2),
               fiber: []
             }
             a.fibers.push(fibers)
             this.fibersList.push(fibers)
           }
         })
+      },
+      rowClickFiber(row, column, event,type){
+        this.type = type
+        if(this.active===1){
+          if(type==0){
+            let standard = null;
+            try{
+              standard = this.miresStandards.find(a => a.id == this.miresStandards)
+            }catch(e){}
+            if(standard&&standard.code=='濮旀墭瑕佹眰'){
+              this.isAskOnlyRead = false;
+            }else{
+              this.isAskOnlyRead = true;
+            }
+          }else{
+            let standard = null;
+            try{
+              standard = this.mireStandards.find(a => a.id == this.mireStandard)
+            }catch(e){}
+            if(standard&&standard.code=='濮旀墭瑕佹眰'){
+              this.isAskOnlyRead = false;
+            }else{
+              this.isAskOnlyRead = true;
+            }
+          }
+        }
+        if(this.type==1){
+          if (this.active !== 1) {
+            this.sampleIds = []
+            this.sampleIds.push(row.id)
+          }
+        }
+        this.currentDetectionItems = row
+        this.detectionItems = row.productList
+        if(this.detectionItems === null) return
+        setTimeout(() => {
+          this.detectionItems.forEach(a => {
+            if (a.state == 1) this.toggleSelection(a)
+          })
+        }, 200)
+      },
+      toggleSelection(row) {
+        this.$refs.productTable.toggleRowSelection(row, true);
+      },
+      tableRowClassName({
+        row,
+        rowIndex
+      }) {
+        if (row.state === 0) {
+          return 'warning-row';
+        }
+        return '';
+      },
+      handleAll(e) {
+        if (e.length > 0) {
+          this.detectionItems.map(m => {
+            m.state = 1
+            return m
+          })
+        } else {
+          this.detectionItems.map(m => {
+            m.state = 0
+            return m
+          })
+        }
+        if (e.length > 0) {
+          if(this.multiFiberList.length > 0){
+            this.multiFiberList.map(item => {
+              item.productList.map(m=>{
+                m.state = 1;
+                return m;
+              })
+              return item
+            })
+          }else{
+          this.currentDetectionItems.productList.map(m=>{
+              m.state = 1;
+              return m;
+            })
+          }
+        } else {
+          if(this.multiFiberList.length > 0){
+            this.multiFiberList.map(item => {
+              item.productList.map(m=>{
+                m.state = 0;
+                return m;
+              })
+              return item
+            })
+          }else{
+            this.currentDetectionItems.productList.map(m=>{
+              m.state = 0;
+              return m;
+            });
+          }
+        }
+        this.bsmRow3 = []
+        this.detectionItems.forEach(p => {
+          if(this.type==1){
+            if (p.bsm === '1' && p.section !== '' && p.section !== null && p.state === 1) {
+              if (p.section.indexOf('[') > -1) {
+                this.bsmRow = this.HaveJson(p)
+              }
+              this.bsm1 = true
+              this.bsm1Dia = true
+            } else if (p.bsm === '1' && p.section !== '' && p.section !== null && p.state === 0) {
+              this.bsm1 = false
+            }
+            if (p.bsm === '1' && p.inspectionItem === '鍏夌氦鎺ュご鎹熻��' && this.sampleList.length > 1 && p.state === 1) {
+              this.bsm2 = true
+              this.bsm1Dia = true
+              if(this.bsm2Val2.length === 0){
+                this.bsm2Val = (this.sampleList.length - 1) * this.sampleList.length / 2
+                this.computationalPairing(this.sampleList.length)
+                this.bsm2Val2 = this.HaveJson(this.bsm2Val3)
+              }
+            } else if (p.bsm === '1' && p.inspectionItem === '鍏夌氦鎺ュご鎹熻��' && p.state === 1) {
+              this.bsm2 = false
+            }
+          }
+          // if (p.ask.includes('RTS')&&p.state === 1) {
+          //   p.rts = ''
+          //   this.bsm3Val = ''
+          //   this.bsm3Dia = true
+          //   this.bsmRow3.push(p)
+          // }
+        })
+
+        if (e.length > 0) {
+          this.sampleList.map(item => {
+            if (this.sampleIds.indexOf(item.id) > -1) {
+              item.insProduct.map(m => {
+                m.state = 1
+                return m;
+              })
+            }
+            return item
+          })
+        } else {
+          this.sampleList.map(item => {
+            if (this.sampleIds.indexOf(item.id) > -1) {
+              item.insProduct.map(m => {
+                m.state = 0
+                return m;
+              })
+            }
+            return item
+          })
+        }
+        this.$nextTick(() => {
+          this.$refs.productTable.doLayout()
+        })
+      },
+      upProductSelect(selection, row) {
+        row.state = row.state == 1 ? 0 : 1
+        if(this.multiFiberList.length > 0){
+          this.multiFiberList.map(item => {
+            item.productList.map(m=>{
+              if(m.id == row.id){
+                m.state = row.state;
+              }
+              return m
+            })
+            return item
+          })
+        }else{
+          this.currentDetectionItems.productList.map(m=>{
+            if(m.id == row.id){
+                m.state = row.state;
+              }
+              return m;
+            });
+        }
+        if(this.type==1){
+          if (row.bsm === '1' && row.section !== '' && row.section !== null && row.state === 1) {
+            if (row.section.indexOf('[') > -1) {
+              this.bsmRow = this.HaveJson(row)
+            }
+            this.bsm1 = true
+            this.bsm1Dia = true
+          } else if (row.bsm === '1' && row.section !== '' && row.section !== null && row.state === 0) {
+            this.bsm1 = false
+          }
+          if (row.bsm === '1' && row.inspectionItem === '鍏夌氦鎺ュご鎹熻��' && this.sampleList.length > 1 && row.state === 1) {
+          this.bsm2 = true
+          this.bsm1Dia = true
+            if(this.bsm2Val2.length === 0){
+              this.bsm2Val = (this.sampleList.length - 1) * this.sampleList.length / 2
+              this.computationalPairing(this.sampleList.length)
+              this.bsm2Val2 = this.HaveJson(this.bsm2Val3)
+            }
+          } else if (row.bsm === '1' && row.inspectionItem === '鍏夌氦鎺ュご鎹熻��' && row.state === 1) {
+            this.bsm2 = false
+          }
+        }else{
+          this.bsm1Dia = false
+        }
+        // if (row.ask.includes('RTS')&&row.state === 1) {
+        //   this.bsmRow3 = null;
+        //   row.rts = ''
+        //   this.bsm3Val = ''
+        //   this.bsm3Dia = true
+        //   this.bsmRow3 = row
+        // }else{
+        //   this.bsm3Dia = false
+        // }
+      },
+      computationalPairing(n){
+        const nums = [];
+        for (let i = 1; i <= n; i++) {
+          nums.push(i);
+        }
+        this.bsm2Val3 = this.HaveJson(this.permute(nums))
+      },
+      setClassName({ column }) {
+        if (column.type == 'selection' && !this.isAllDisabled) {
+          return 'all-disabled'
+        }
+      },
+      setClassName0({ column }){
+        if (column.type == 'selection' && this.active!=1) {
+          return 'all-disabled'
+        }
       },
       clearFibers(){
         this.packageInfo.ismiers = false
@@ -459,7 +877,103 @@
         })
       },
       save(){
-        console.log(this.bushing);
+        if(this.bushing.length === 0){
+          this.$message.error('缂哄皯閰嶇疆鏃犳硶淇濆瓨')
+          return
+        }
+        for(let a in this.bushing){
+          if(this.bushing[a].fibers.length===0&&this.bushing[a].fiber.length===0){
+            this.$message.error(this.bushing[a].color+'绠¤壊鏍囧绠$己灏戦厤缃棤娉曚繚瀛�')
+            return
+          }
+        }
+        this.sample.forEach(a=>{
+          a.bushing = this.bushing
+        })
+        this.$message.success('宸蹭繚瀛�')
+        this.$emit('saveFiberopticConfig')
+      },
+      beforeClose(done){
+        if (this.bsm1) {
+          if (this.bsm1Val === null || this.bsm1Val === '') {
+            this.$message.error('鐗规畩椤圭洰蹇呴』澶勭悊')
+            return
+          }
+        }
+        if (this.bsm2) {
+          if (this.bsm2Val2.length === 0) {
+            this.$message.error('鐗规畩椤圭洰蹇呴』澶勭悊')
+            return
+          }
+          let set = new Set()
+          for (let i=0;i<this.bsm2Val2.length;i++){
+            let num0 = set.size
+            set.add(JSON.stringify(this.bsm2Val2[i]))
+            let num1 = set.size
+            if(num1==num0){
+              this.$message.error('鍏宠仈椤圭洰涓嶈兘閲嶅')
+              return
+            }
+            set.add(JSON.stringify(this.bsm2Val2[i].reverse()))
+            let num2 = set.size
+            if(num1==num2){
+              this.$message.error('鍏宠仈椤圭洰涓嶈兘閲嶅')
+              return
+            }
+          }
+        }
+        done()
+      },
+      beforeClose0(done){
+        if(!this.bsm3Val){
+          this.$message.error('RST蹇呴』濉啓')
+          return
+        }else{
+          if(Array.isArray(this.bsmRow3)){
+            this.bsmRow3.forEach(item=>{
+              item.rts = this.bsm3Val
+            })
+          }else{
+            this.bsmRow3.rts = this.bsm3Val
+          }
+        }
+        done()
+      },
+      upBsm1(val) {
+        let sections = JSON.parse(this.bsmRow.section);
+        let asks = JSON.parse(this.bsmRow.ask);
+        let tells = JSON.parse(this.bsmRow.tell);
+        let manHours = JSON.parse(this.bsmRow.manHour);
+        let prices = JSON.parse(this.bsmRow.price);
+        for (var a in sections) {
+          if (val === sections[a]) {
+            this.productList.forEach(p => {
+              if (p.id === this.bsmRow.id) {
+                p.section = sections[a]
+                p.ask = asks[a]
+                p.tell = tells[a]
+                p.manHour = manHours[a]
+                p.price = prices[a]
+              }
+            })
+            break
+          }
+        }
+      },
+      bsm2Up(val){
+        let list = []
+        for(let a=1;a < this.bsm2Val3.length + 1;a++){
+          list.push(a)
+        }
+        let set = new Set()
+        let size1 = set.length
+        while(set.size < val){
+          set.add(Math.ceil(Math.random() * this.bsm2Val3.length))
+        }
+        this.bsm2Val2 = []
+        for(let a of set){
+          this.bsm2Val2.push(this.HaveJson(this.bsm2Val3[a-1]))
+        }
       }
     }
   }
@@ -523,4 +1037,9 @@
     padding-top: 2px !important;
     padding-bottom: 2px !important;
   }
+  >>>.all-disabled .el-checkbox__input .el-checkbox__inner {
+    background-color: #edf2fc;
+    border-color: #dcdfe6;
+    cursor: not-allowed;
+  }
 </style>

--
Gitblit v1.9.3