licp
2024-07-01 b5397c4f12baf35a3200ce4d053d549ffa7ec2e4
src/components/do/b1-ins-order/add.vue
@@ -117,7 +117,7 @@
  <div class="ins_order_add">
    <div v-show="!configShow&&!equipConfigShow&&!cableConfigShow">
      <el-row class="title">
        <el-col :span="6" style="padding-left: 20px;">委托单信息&nbsp;&nbsp;&nbsp;总价:<span
        <el-col :span="6" style="padding-left: 20px;text-align: left;">委托单信息&nbsp;&nbsp;&nbsp;总价:<span
            style="color: #3A7BFA">¥{{total}}</span></el-col>
        <el-col :span="18" style="text-align: right;">
          <el-select v-model="template" size="medium" placeholder="下单模板" style="margin-right: 10px;" v-show="active==1"
@@ -132,7 +132,7 @@
            <span style="color: #3A7BFA;">保存模板</span>
          </el-button>
          <el-button size="medium" type="primary" @click="openCableConfig"
            v-if="active==1&&PROJECT=='装备电缆'">电缆配置</el-button>
            v-if="active==1&&PROJECT=='装备电缆'&&addObj.sampleType!=undefined&&addObj.sampleType.indexOf('电缆')>-1">电缆配置</el-button>
          <el-button size="medium" type="primary" @click="openEquipConfig" v-if="active==1">子样品配置</el-button>
          <el-button size="medium" type="primary" @click="openConfig" v-if="addObj.sampleType==='光缆'">光纤配置</el-button>
          <el-button size="medium" type="primary" @click="save" :loading="saveLoad" v-show="active==1">提交</el-button>
@@ -163,8 +163,8 @@
            </el-select>
          </div>
        </el-col>
        <el-col class="search_thing" :span="6">
          <div class="search_label"><span class="required-span">* </span>委托人:</div>
        <el-col class="search_thing" :span="6" >
          <div class="search_label"><span class="required-span">* </span>制单人:</div>
          <div class="search_input">
            <el-input size="small" clearable disabled v-model="addObj.custom"></el-input>
            <!-- <el-input readonly size="small" v-model="addObj.custom">
@@ -186,7 +186,7 @@
        <el-col class="search_thing" :span="6">
          <div class="search_label"><span class="required-span">* </span>联系方式:</div>
          <div class="search_input">
            <el-input size="small" placeholder="选择委托客户" clearable disabled v-model="addObj.phone"></el-input>
            <el-input size="small" placeholder="选择委托客户" clearable :readonly="active>1" v-model="addObj.phone"></el-input>
          </div>
        </el-col>
        <el-col class="search_thing" :span="6">
@@ -256,14 +256,14 @@
        <el-col class="search_thing" :span="6">
          <div class="search_label">工程名称:</div>
          <div class="search_input">
            <el-input size="small" placeholder="请输入" clearable v-model="addObj.engineering"
            <el-input size="small" :placeholder="active>1 ? '' : '请输入'" clearable v-model="addObj.engineering"
              :readonly="active>1"></el-input>
          </div>
        </el-col>
        <el-col class="search_thing" :span="6">
          <div class="search_label">工程名称EN:</div>
          <div class="search_input">
            <el-input size="small" placeholder="请输入" clearable v-model="addObj.engineeringEn"
            <el-input size="small" :placeholder="active>1 ? '' : '请输入'" clearable v-model="addObj.engineeringEn"
              :readonly="active>1"></el-input>
          </div>
        </el-col>
@@ -302,13 +302,19 @@
        <el-col class="search_thing" :span="6">
          <div class="search_label">OTC订单号:</div>
          <div class="search_input">
            <el-input size="small" placeholder="请输入" clearable v-model="addObj.otcCode" :readonly="active>1"></el-input>
            <el-input size="small" :placeholder="active>1 ? '' : '请输入'" clearable v-model="addObj.otcCode" :readonly="active>1"></el-input>
          </div>
        </el-col>
        <el-col class="search_thing" :span="6">
          <div class="search_label">委托人:</div>
          <div class="search_input">
            <el-input size="small" :placeholder="active>1 ? '' : '请输入'" clearable v-model="addObj.prepareUser" :readonly="active>1"></el-input>
          </div>
        </el-col>
        <el-col class="search_thing" :span="6" style="align-items: flex-start;margin: 8px 0;">
          <div class="search_label">备注:</div>
          <div class="search_input">
            <el-input type="textarea" :autosize="{ minRows: 2, maxRows: 2}" size="small" clearable
            <el-input type="textarea" :autosize="{ minRows: 2, maxRows: 2}" size="small" clearable :placeholder="active>1 ? '' : '请输入'"
              v-model="addObj.remark" :readonly="active>1"></el-input>
          </div>
        </el-col>
@@ -325,7 +331,7 @@
        <div class="search_thing">
          <div class="search_label">样品型号:</div>
          <div class="search_input">
            <el-select v-model="model" placeholder="请选择" filterable allow-create default-first-option size="small"
            <el-select v-model="model" :placeholder="active>1 ? '' : '请输入'" filterable allow-create default-first-option size="small"
              @change="changeModel">
              <el-option v-for="item in models" :key="item.value" :label="item.label" :value="item.value">
              </el-option>
@@ -335,7 +341,7 @@
        <div class="search_thing">
          <div class="search_label">检验标准:</div>
          <div class="search_input">
            <el-select v-model="standardMethodListId" placeholder="请选择" size="small" @focus="methodFocus"
            <el-select v-model="standardMethodListId" :placeholder="active>1 ? '' : '请输入'" size="small" @focus="methodFocus"
              :loading="methodLoad" @change="changeStandardMethodListId">
              <el-option v-for="item in methods" :key="item.id" :label="item.code" :value="item.id">
              </el-option>
@@ -408,7 +414,17 @@
        @selection-change="selectProduct" style="margin-bottom: 10px;" @select="upProductSelect"
        :row-class-name="tableRowClassName" v-loading="getProductLoad" @select-all="handleAll">
        <el-table-column type="selection" width="65" :selectable="selectable" v-if="active==1"></el-table-column>
        <el-table-column prop="inspectionItem" label="检验项" min-width="140" show-overflow-tooltip></el-table-column>
        <el-table-column prop="inspectionItem" label="检验项" min-width="140" show-overflow-tooltip>
          <template slot="header" slot-scope="scope">
            <div style="display: flex;align-items: center;flex-direction: column;font-size: 14px">
              <span>检验项</span>
              <el-input
              v-model="inspectionItem"
              size="mini"
              placeholder="请输入"/>
            </div>
          </template>
        </el-table-column>
        <el-table-column prop="inspectionItemSubclass" label="检验项子项" min-width="140"
          show-overflow-tooltip></el-table-column>
        <el-table-column prop="sonLaboratory" label="子实验室" min-width="130" show-overflow-tooltip :filters="filters"
@@ -427,7 +443,7 @@
              :autosize="{ minRows: 1, maxRows: 3}" @change="e=>requestChange(e,scope.row)"
              v-if="active==1&&isAskOnlyRead"></el-input>
            <span v-else>
              <template v-if="(scope.row.ask.indexOf('D')>-1
              <!-- <template v-if="(scope.row.ask.indexOf('D')>-1
              ||scope.row.ask.indexOf('W')>-1
              ||scope.row.ask.indexOf('X')>-1
              ||scope.row.ask.indexOf('RTS')>-1
@@ -435,7 +451,8 @@
              ||scope.row.ask.indexOf('L')>-1)&&active==1">
                <input class="askRts" v-model="scope.row.rts" /><br />{{ scope.row.ask }}
              </template>
              <template v-else>{{ scope.row.ask }}</template>
              <template v-else>{{ scope.row.ask }}</template> -->
              <template >{{ scope.row.ask }}</template>
            </span>
          </template>
        </el-table-column>
@@ -540,19 +557,20 @@
    <fiberOpticConfig :currentId="currentId" @saveFiberopticConfig="getTotal()" v-if="configShow" :active="active" />
    <equipConfig :currentId="currentId" v-if="equipConfigShow" :active="active" />
    <cableConfig v-if="cableConfigShow" :active="active" />
<!--    单选特殊值处理框-->
    <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">
          <el-col class="search_thing" :span="22" style="height: initial;margin: 5px 0;">
            <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 v-for="(a, ai) in JSON.parse(bsmRow.section)" :key="ai" :label="a" style="margin-bottom: 2px;margin-top: 2px;"></el-radio>
              </el-radio-group>
            </div>
          </el-col>
          <el-col class="search_thing" :span="22">
          <el-col class="search_thing" :span="22" style="height: initial;margin: 5px 0;">
            <div class="search_label">要求值:</div>
            <div class="search_input" v-show="bsm1Val!==null&&bsm1Val!==''">
              <el-radio-group v-model="bsm1Val" @input="upBsm1">
@@ -601,15 +619,120 @@
        </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>
<!--    全选特殊值处理框-->
    <el-dialog title="检测到特殊项,请作出以下选择" :visible.sync="bsm1DiaAll" width="500px" :show-close="false"
               :before-close="beforeClose">
      <div class="body" style="max-height: 60vh;" v-for="(item, index) in bsm1DiaList" :key="index">
        <el-row v-if="item.bsm1">
          <el-col class="search_thing" :span="22" style="height: initial;margin: 5px 0;">
            <div class="search_label"><span class="required-span">* </span>选项:</div>
            <div class="search_input">
              <el-radio-group v-model="item.bsm1Val" @input="upBsmAll(item)">
                <el-radio v-for="(a, ai) in JSON.parse(item.bsmRow.section)" :key="ai" :label="a" style="margin-bottom: 2px;margin-top: 2px;"></el-radio>
              </el-radio-group>
            </div>
          </el-col>
          <el-col class="search_thing" :span="22" style="height: initial;margin: 5px 0;">
            <div class="search_label">要求值:</div>
            <div class="search_input" v-show="item.bsm1Val!==null&&item.bsm1Val!==''">
              <el-radio-group v-model="item.bsm1Val" @input="upBsmAll(item)">
                <el-radio v-for="(a, ai) in JSON.parse(item.bsmRow.section)" :key="ai"
                          :label="a">{{JSON.parse(item.bsmRow.ask)[ai]}}</el-radio>
              </el-radio-group>
            </div>
          </el-col>
        </el-row>
        <el-row v-if="item.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="item.bsm2Val" :min="1" :max="item.bsm2Val3.length" :precision="0"
                               style="width: 70%;" :controls="false" @change="bsm2Up"></el-input-number>
              <span>MAX:{{item.bsm2Val3.length}}</span>
            </div>
          </el-col>
          <el-col style="margin-top: 6px;">
            <el-col v-for="(a,ai) in item.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 item.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 item.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>
      </div>
    </el-dialog>
    <el-dialog title="特殊值填写" :visible.sync="bsm3Dia" width="800px" :show-close="false">
      <el-table
      :data="editTable"
      style="width: 100%">
      <!-- inspectionItemList -->
      <el-table-column
          prop="inspectionItemList"
          label="检验项"
          width="180">
        </el-table-column>
        <el-table-column
          prop="sampleCode"
          label="样品编号"
          width="180">
        </el-table-column>
        <el-table-column
          prop="model"
          label="样品型号"
          width="180">
        </el-table-column>
        <el-table-column
          prop="symbolItem"
          label="识别符号">
        </el-table-column>
        <el-table-column
          prop="value"
          label="识别符值">
          <template slot-scope="scope">
            <el-input v-model="scope.row.value" placeholder="请输入" size="small"></el-input>
          </template>
        </el-table-column>
      </el-table>
      <span slot="footer" class="dialog-footer">
        <el-row>
          <el-button @click="bsm3Dia=false">取 消</el-button>
          <el-button type="primary" @click="save0" :loading="saveLoad">确 定</el-button>
        </el-row>
      </span>
    </el-dialog>
    <el-dialog title="温度循环要求填写" :visible.sync="circulateShow" width="800px" :show-close="false">
      <div class="search" style="display: flex;background: transparent;">
        <div class="search_thing">
          <div class="search_label">保温时间:</div>
          <div class="search_input">
            <el-input size="small" placeholder="请输入" clearable v-model="bsm3Val"></el-input>
            <el-input v-model="circulateForm.entrustCode" size="small" placeholder=""></el-input>
          </div>
        </el-col>
      </el-row>
        </div>
        <div class="search_thing">
          <div class="search_label">循环次数:</div>
          <div class="search_input">
            <el-input v-model="circulateForm.entrustCode" size="small" placeholder=""></el-input>
          </div>
        </div>
        <div class="search_thing">
          <div class="search_label">温度点:</div>
          <div class="search_input">
            <el-input v-model="circulateForm.entrustCode" size="small" placeholder=""></el-input>
          </div>
        </div>
      </div>
    </el-dialog>
  </div>
</template>
@@ -639,6 +762,7 @@
    },
    data() {
      return {
        editTable:[],
        template: null,
        templates: [],
        addObj: {
@@ -670,7 +794,8 @@
          engineeringEn: null,
          production: null,
          productionEn: null,
          companyId: null
          companyId: null,
          prepareUser:null
        },
        sample: {
          sampleCode: null,
@@ -723,6 +848,7 @@
        addSampleDia: false,
        count: 1,
        productList: [],
        bsm1DiaList: [],
        productIds: [],
        getProductLoad: false,
        saveLoad: false,
@@ -754,6 +880,7 @@
        bsm1: false,
        bsm1Val: null,
        bsm1Dia: false,
        bsm1DiaAll: false,
        equipConfigShow: false,
        cableConfigShow: false,
        bsm2: false,
@@ -769,6 +896,12 @@
        totalArr: [],
        model: null,
        standardMethodListId: null,
        symbolList:[
        'RTS','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'],
        inspectionItem:null,
        circulateShow:false,
        circulateForm:{},
        isBsm2Val2:false
      }
    },
    watch: {
@@ -873,43 +1006,57 @@
        this.addObj.companyId = selects.id
        this.selectUserDia = false
      },
      handleAsk(ask, rts) {
      containsValue(str) {
        if(str){
          let symbolItem = ''
          this.symbolList.some(value =>{
            if(str.includes(value)){
              symbolItem  = value
              return true
            }
          })
          return symbolItem
        }
      },
      handleAsk(ask,symbolItem, value) {
        try{
          let code = [">", "<", "=", ">", "<", "≥", "≤", "±"];
          if (ask.includes('RTS') || ask.includes('D') || ask.includes('W') ||
            ask.includes('X') || ask.includes('H') || ask.includes('L')) {
            if (ask.includes('&')) {
              // 多个条件
              let arr0 = ask.split('&')
              let arr1 = []
              arr0.forEach(m => {
                let index = code.findIndex(b => m.includes(b))
                if (index > -1) {
                  let arr = m.split(code[index]).filter(b => !!b)
                  let num = eval(this.replaceAll(arr[0], 'RTS', rts))
                  m = code[index] + '' + num
                  arr1.push(m)
                }
              })
              return arr1.join('&')
            } else {
              // 单个条件
              let index = code.findIndex(b => ask.includes(b))
          if (ask.includes('&')) {
            // 多个条件
            let arr0 = ask.split('&')
            let arr1 = []
            arr0.forEach(m => {
              let index = code.findIndex(b => m.includes(b))
              if (index > -1) {
                let arr = ask.split(code[index]).filter(b => !!b)
                let num = eval(this.replaceAll(arr[0], 'RTS', rts))
                return code[index] + '' + num
                let arr = m.split(code[index]).filter(b => !!b)
                let num = eval(this.replaceAll(arr[0], symbolItem, value))
                m = code[index] + '' + num
                arr1.push(m)
              }
            })
            return arr1.join('&')
          } else {
            // 单个条件
            let index = code.findIndex(b => ask.includes(b))
            if (index > -1) {
              let arr = ask.split(code[index]).filter(b => !!b)
              let num = eval(this.replaceAll(arr[0], symbolItem, value))
              return code[index] + '' + num
            }
          }
        }catch(e){}
      },
      replaceAll(str, find, rts) {
        if (rts === undefined) {
      handleTell(tell,symbolItem, value){
        try{
          let num = this.replaceAll(tell, symbolItem, value)
          return num
        }catch(e){}
      },
      replaceAll(str,find,value) {
        if (str === undefined) {
          return str
        }
        return str.replace('RTS', rts).replace('D', rts).replace('W', rts).replace('X', rts).replace('H', rts).replace(
          'L', rts);
        return str.replace(find, value);
      },
      save() {
        if (!this.addObj.companyId) {
@@ -936,61 +1083,171 @@
          this.$message.error('请选择检验标准')
        } else {
          let sampleList = this.HaveJson(this.sampleList)
          let isRTS = this.totalArr.find(a => a.ask != null && (a.ask.includes('RTS') || a.ask.includes('D') || a.ask
            .includes('W') ||
            a.ask.includes('X') || a.ask.includes('H') || a.ask.includes('L')) && a.state == 1)
          if (isRTS) {
            sampleList.forEach(item => {
              if (item.insProduct && item.insProduct.length > 0) {
                item.insProduct.forEach(a => {
                  if (a.state == 1) {
                    let ask = this.handleAsk(a.ask, a.rts)
                    if (ask && a.state == 1) {
                      a.ask = ask
          let projectNum = this.totalArr.filter(a => a.state == 1).length
          if(projectNum==0){
            this.$confirm('检验项目为空,是否确认提交?', "提示", {
              confirmButtonText: "确定",
              cancelButtonText: "取消",
              type: "warning"
            }).then(() => {
              this.saveMethod(sampleList)
            }).catch(() => {})
          }else{
            let isRTS = this.totalArr.find(a => a.ask != null && this.symbolList.find(b=>a.ask.includes(b)) && a.state == 1)
            if (isRTS) {
              this.editTable = this.handleData(sampleList,this.containsValue, 0)
              this.editTable.forEach(item => {
                item.value = item.modelNum
              })
              this.bsm3Dia = true;
              return
            }
            this.saveMethod(sampleList)
          }
        }
      },
      save0(){
        if(this.editTable.every(m=>m.value)){
          let sampleList = this.handleData(this.HaveJson(this.sampleList),this.handleAsk,1)
          this.saveMethod(sampleList)
        }else{
          this.$message.error('请填写识别符值')
        }
      },
      handleData(sampleList,calBack,type){
        let editTable = []
        sampleList.forEach(item => {
          let obj = {
            sampleCode:item.sampleCode,
            model:item.model,
            symbolList:[],
            sampleId:item.id,
            modelNum:item.modelNum,
          }
          if (item.insProduct && item.insProduct.length > 0) {
            item.insProduct.forEach(a => {
              if (a.state == 1) {
                if(type==0){
                  let str = calBack(a.ask)
                  str&&obj.symbolList.push({
                    symbolItem:str,
                    inspectionItem:a.inspectionItem,
                  })
                }else if(type==1){
                  let arr = this.editTable.filter(b => b.sampleId == item.id)
                  arr.forEach(f => {
                    if(a.ask.includes(f.symbolItem)){
                      let ask = calBack(a.ask, f.symbolItem,f.value)
                      if (ask) {
                        a.ask = ask
                      }
                      let tell = this.handleTell(a.tell, f.symbolItem,f.value)
                      if (tell) {
                        a.tell = tell
                      }
                    }
                  }
                })
                  })
                }
              }
              // 光纤带项目
              if (item.bushing && item.bushing.length > 0) {
                item.bushing.forEach(a => {
                  if (a.fiber && a.fiber.length > 0) {
                    a.fiber.forEach(b => {
                      if (b.productList && b.productList.length > 0) {
                        b.productList.forEach(c => {
                          if (c.state == 1) {
                            let ask = this.handleAsk(c.ask, c.rts)
                            if (ask && c.state == 1) {
                              c.ask = ask
            })
          }
          // 光纤带项目
          if (item.bushing && item.bushing.length > 0) {
            item.bushing.forEach(a => {
              if (a.fiber && a.fiber.length > 0) {
                a.fiber.forEach(b => {
                  if (b.productList && b.productList.length > 0) {
                    b.productList.forEach(c => {
                      if (c.state == 1) {
                        if(type==0){
                          let str = calBack(c.ask)
                          str&&obj.symbolList.push({
                    symbolItem:str,
                    inspectionItem:c.inspectionItem,
                  })
                        }else if(type==1){
                          let arr = this.editTable.filter(b => b.sampleId == item.id)
                          arr.forEach(f => {
                            if(c.ask.includes(f.symbolItem)){
                              let ask = calBack(c.ask, f.symbolItem,f.value)
                              if (ask) {
                                c.ask = ask
                              }
                              let tell = this.handleTell(c.tell, f.symbolItem,f.value)
                              if (tell) {
                                c.tell = tell
                              }
                            }
                          }
                        })
                          })
                        }
                      }
                    })
                  }
                  if (a.fibers && a.fibers.length > 0) {
                    a.fibers.forEach(b => {
                      if (b.productList && b.productList.length > 0) {
                        b.productList.forEach(c => {
                          if (c.state == 1) {
                            let ask = this.handleAsk(c.ask, c.rts)
                            if (ask && c.state == 1) {
                              c.ask = ask
                            }
                          }
                        })
                      }
                      if (b.fiber && b.fiber.length > 0) {
                        b.fiber.forEach(c => {
                          if (c.productList && c.productList.length > 0) {
                            c.productList.forEach(d => {
                              if (d.state == 1) {
                                let ask = this.handleAsk(d.ask, d.rts)
                                if (ask) {
                                  d.ask = ask
                                }
                })
              }
              if (a.fibers && a.fibers.length > 0) {
                a.fibers.forEach(b => {
                  if (b.productList && b.productList.length > 0) {
                    b.productList.forEach(c => {
                      if (c.state == 1) {
                        if(type==0){
                          let str = calBack(c.ask)
                          str&&obj.symbolList.push({
                    symbolItem:str,
                    inspectionItem:c.inspectionItem,
                  })
                        }else if(type==1){
                          // let ask = calBack(c.ask, c.rts)
                          // if (ask && c.state == 1) {
                          //   c.ask = csk
                          // }
                          let arr = this.editTable.filter(b => b.sampleId == item.id)
                          arr.forEach(f => {
                            if(c.ask.includes(f.symbolItem)){
                              let ask = calBack(c.ask, f.symbolItem,f.value)
                              if (ask) {
                                c.ask = ask
                              }
                            })
                              let tell = this.handleTell(c.tell, f.symbolItem,f.value)
                              if (tell) {
                                c.tell = tell
                              }
                            }
                          })
                        }
                      }
                    })
                  }
                  if (b.fiber && b.fiber.length > 0) {
                    b.fiber.forEach(c => {
                      if (c.productList && c.productList.length > 0) {
                        c.productList.forEach(d => {
                          if (d.state == 1) {
                            if(type==0){
                              let str = calBack(d.ask)
                              str&&obj.symbolList.push({
                    symbolItem:str,
                    inspectionItem:d.inspectionItem,
                  })
                            }else if(type==1){
                              // let ask = calBack(d.ask, d.rts)
                              // if (ask && d.state == 1) {
                              //   d.ask = ask
                              // }
                              let arr = this.editTable.filter(b => b.sampleId == item.id)
                              arr.forEach(f => {
                                if(d.ask.includes(f.symbolItem)){
                                  let ask = calBack(d.ask, f.symbolItem,f.value)
                                  if (ask) {
                                    d.ask = ask
                                  }
                                  let tell = this.handleTell(d.tell, f.symbolItem,f.value)
                                  if (tell) {
                                    d.tell = tell
                                  }
                                }
                              })
                            }
                          }
                        })
                      }
@@ -1000,34 +1257,82 @@
              }
            })
          }
          this.saveLoad = true
          this.$axios.post(this.$api.insOrder.addInsOrder, {
            str: JSON.stringify({
              insOrder: this.addObj,
              list: JSON.stringify(sampleList.map(a => {
                a.model = a.model + ((a.modelNum == null || a.modelNum == '' || a.modelNum == 'null') ?
                  '' : (
                    '-' + a.modelNum))
                return a
              })),
              pairing: JSON.stringify(this.bsm2Val2)
          if(type==0){
            editTable.push(obj)
          }
        })
        if(type==0){
          editTable.forEach(a => {
            a.symbolList.forEach(b => {
              let arr = a.symbolList.filter(c => c.symbolItem == b.symbolItem);
              b.inspectionItemList = arr.map(c => c.inspectionItem).join(',')
            })
          }).then(res => {
            this.saveLoad = false
            if (res.code == 201) return
            this.$message.success('已提交')
            this.$parent.playOrder(0)
          }).catch(e=>{
            this.saveLoad = false
          })
          editTable.forEach(a => {
            let mySet = new Set();
            a.symbolList = a.symbolList.filter(b =>{
              let num0 = mySet.size;
              mySet.add(b.symbolItem);
              let num1 = mySet.size;
              if(num0!=num1){
                return true;
              }else{
                return false
              }
            })
          })
          let editTableNew = []
          editTable.forEach(a => {
            a.symbolList.forEach(b => {
              let obj = {
                sampleCode:a.sampleCode,
                model:a.model,
                symbolItem:b.symbolItem,
                sampleId:a.sampleId,
                value:null,
                inspectionItemList:b.inspectionItemList,
                modelNum:a.modelNum,
              }
              editTableNew.push(obj)
            })
          })
          return editTableNew
        }else{
          return sampleList
        }
      },
      saveMethod(sampleList){
        this.saveLoad = true
        this.$axios.post(this.$api.insOrder.addInsOrder, {
          str: JSON.stringify({
            insOrder: this.addObj,
            list: JSON.stringify(sampleList.map(a => {
              a.model = a.model + ((a.modelNum == null || a.modelNum == '' || a.modelNum == 'null') ?
                '' : (
                  '-' + a.modelNum))
              a.insProduct = a.insProduct.filter(b=>b.state === 1)
              return a
            })),
            pairing: JSON.stringify(this.bsm2Val2)
          })
        }).then(res => {
          this.saveLoad = false
          if (res.code == 201) return
          this.$message.success('已提交')
          this.bsm3Dia = false;
          this.$parent.playOrder(0)
        }).catch(e=>{
          this.saveLoad = false
        })
      },
      upInsOrderOfState(state) {
        if (state == 1) {
          this.saveLoad = true
          this.$axios.post(this.$api.insOrder.upInsOrderOfState, {
            state,
            id: this.currentId
            id: this.currentId,
            companyId:this.addObj.companyId,
            laboratory:this.addObj.laboratory
          }, {
            headers: {
              'Content-Type': 'application/json'
@@ -1036,6 +1341,8 @@
            this.saveLoad = false
            if (res.code == 201) return
            this.$message.success('提交成功')
            // this.$parent.multipleSelection = [{id: this.currentId}]
            // this.$parent.print()
            // 如果紧急程度为紧急,需要直接下发人员
            // if (this.addObj.type == 2) {
            //    this.issuedDialogVisible = true;
@@ -1144,7 +1451,7 @@
        }
      },
      selectStandardTreeList() {
        this.$axios.get(this.$api.standardTree.selectStandardTreeList).then(res => {
        this.$axios.get(this.$api.standardTree.selectStandardTreeList2).then(res => {
          this.list = res.data
          this.list.forEach(a => {
            this.expandedKeys.push(a.label)
@@ -1284,17 +1591,19 @@
        this.$refs.productTable.toggleRowSelection(row, true);
      },
      upProductSelect(selection, row) {
        this.bsm1DiaList = []
        row.state = row.state == 1 ? 0 : 1
        if (row.bsm === '1' && row.section !== '' && row.section !== null && row.state === 1) {
          if (row.section.indexOf('[') > -1) {
            this.bsmRow = this.HaveJson(row)
            row.bsmRow = this.HaveJson(row)
          }
          this.bsm1 = true
          this.bsm1Dia = true
          row.bsm1 = true
          this.bsm1DiaList.push(row)
          this.bsm1DiaAll = true
        } else if (row.bsm === '1' && row.section !== '' && row.section !== null && row.state === 0) {
          this.bsm1 = false
          row.bsm1 = false
        }
        if (row.bsm === '1' && row.inspectionItem === '熔接损耗' && this.sampleList.length > 1 && row.state === 1) {
        if (row.bsm === '1' && row.inspectionItem === '光纤接头损耗' && this.sampleList.length > 1 && row.state === 1&&!this.isBsm2Val2) {
          this.bsm2 = true
          this.bsm1Dia = true
          if (this.bsm2Val2.length === 0) {
@@ -1302,9 +1611,9 @@
            this.computationalPairing(this.sampleList.length)
            this.bsm2Val2 = this.HaveJson(this.bsm2Val3)
          }
        } else if (row.bsm === '1' && row.inspectionItem === '熔接损耗' && row.state === 1 && this.sampleList.length > 1) {
        } else if (row.bsm === '1' && row.inspectionItem === '光纤接头损耗' && row.state === 1 && this.sampleList.length > 1) {
          this.bsm2 = false
        } else if (row.bsm === '1' && row.inspectionItem === '熔接损耗' && this.sampleList.length < 2) {
        } else if (row.bsm === '1' && row.inspectionItem === '光纤接头损耗' && this.sampleList.length < 2) {
          this.$message.error('样品数量不足够进行配对操作')
          row.state = row.state == 1 ? 0 : 1
          this.$refs.productTable.toggleRowSelection(row, false)
@@ -1330,6 +1639,10 @@
          }
          return item
        })
        if (row.inspectionItem === '温度循环') {
          this.circulateShow = true;
          return
        }
        this.getProNum()
      },
      permute(nums) {
@@ -1506,6 +1819,7 @@
          let obj = this.sampleIds.find(b => b == a.id)
          if (obj) {
            a.standardMethodListId = this.standardMethodListId
            this.methodChange(this.standardMethodListId, a)
          }
        })
      },
@@ -1550,6 +1864,7 @@
        }
      },
      handleAll(e) {
        console.log('全选')
        if (e.length > 0) {
          this.productList.map(m => {
            m.state = 1
@@ -1562,17 +1877,19 @@
          })
        }
        this.bsmRow3 = [];
        this.bsm1DiaList = []
        this.productList.forEach(p => {
          if (p.bsm === '1' && p.section !== '' && p.section !== null && p.state === 1) {
            if (p.section.indexOf('[') > -1) {
              this.bsmRow = this.HaveJson(p)
              p.bsmRow = this.HaveJson(p)
            }
            this.bsm1 = true
            this.bsm1Dia = true
            p.bsm1 = true
            this.bsm1DiaList.push(p)
            this.bsm1DiaAll = true
          } else if (p.bsm === '1' && p.section !== '' && p.section !== null && p.state === 0) {
            this.bsm1 = false
            p.bsm1 = false
          }
          if (p.bsm === '1' && p.inspectionItem === '熔接损耗' && this.sampleList.length > 1 && p.state === 1) {
          if (p.bsm === '1' && p.inspectionItem === '光纤接头损耗' && this.sampleList.length > 1 && p.state === 1&&!this.isBsm2Val2) {
            this.bsm2 = true
            this.bsm1Dia = true
            if (this.bsm2Val2.length === 0) {
@@ -1580,9 +1897,9 @@
              this.computationalPairing(this.sampleList.length)
              this.bsm2Val2 = this.HaveJson(this.bsm2Val3)
            }
          } else if (p.bsm === '1' && p.inspectionItem === '熔接损耗' && p.state === 1 && this.sampleList.length > 1) {
          } else if (p.bsm === '1' && p.inspectionItem === '光纤接头损耗' && p.state === 1 && this.sampleList.length > 1) {
            this.bsm2 = false
          } else if (p.bsm === '1' && p.inspectionItem === '熔接损耗' && this.sampleList.length < 2) {
          } else if (p.bsm === '1' && p.inspectionItem === '光纤接头损耗' && this.sampleList.length < 2) {
            this.$message.error('样品数量不足够进行配对操作')
            this.$refs.productTable.clearSelection()
            return
@@ -1769,12 +2086,40 @@
          }
        }
      },
      beforeClose(done) {
        if (this.bsm1) {
          if (this.bsm1Val === null || this.bsm1Val === '') {
            this.$message.error('特殊项目必须处理')
            return
      upBsmAll (item) {
        let sections = JSON.parse(item.bsmRow.section);
        let asks = JSON.parse(item.bsmRow.ask);
        let tells = JSON.parse(item.bsmRow.tell);
        let manHours = JSON.parse(item.bsmRow.manHour);
        let prices = JSON.parse(item.bsmRow.price);
        for (var a in sections) {
          if (item.bsm1Val === sections[a]) {
            this.productList.forEach(p => {
              if (p.id === item.bsmRow.id) {
                p.section = sections[a]
                p.ask = asks[a]
                p.tell = tells[a]
                p.manHour = manHours[a]
                p.price = prices[a]
              }
            })
            break
          }
        }
      },
      beforeClose(done) {
        // if (this.bsm1) {
        //   if (this.bsm1Val === null || this.bsm1Val === '') {
        //     this.$message.error('特殊项目必须处理')
        //     return
        //   }
        // }
        if (this.bsm1DiaList.length > 0) {
          this.bsm1DiaList.forEach(item => {
            if (!item.bsm1Val) {
              throw this.$message.error('特殊项目必须处理')
            }
          })
        }
        if (this.bsm2) {
          if (this.bsm2Val2.length === 0) {
@@ -1797,6 +2142,7 @@
              return
            }
          }
          this.isBsm2Val2 = true;
        }
        // if(this.bsm3){
        //   if(!this.bsm3Val){