gaoluyang
2025-02-14 9ae3620b9e59482b26b6cf4cd8f32a0ebf594b9a
能力范围页面迁移
已重命名1个文件
已删除1个文件
已添加4个文件
877 ■■■■■ 文件已修改
src/api/structural/capability.js 41 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/structural/laboratoryScope.js 9 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/structural/standardMethod.js 9 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/structural/capability/index.vue 13 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/structural/capabilityAndLaboratory/capability/index.vue 805 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/structural/capabilityAndLaboratory/laboratory/index.vue 补丁 | 查看 | 原始文档 | blame | 历史
src/api/structural/capability.js
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,41 @@
import request from '@/utils/request'
// èŽ·å–æ£€éªŒé¡¹ç›®å‚æ•°
export function selectItemParameterList(query) {
  return request({
    url: '/capacityScope/selectItemParameterList',
    method: 'post',
    params: query
  })
}
// æ–°å¢žæ£€éªŒé¡¹ç›®å‚æ•°
export function addItemParameter(query) {
  return request({
    url: '/capacityScope/addItemParameter',
    method: 'post',
    params: query
  })
}
// åˆ é™¤æ£€éªŒé¡¹ç›®å‚æ•°
export function delItemParameter(query) {
  return request({
    url: '/capacityScope/delItemParameter',
    method: 'post',
    params: query
  })
}
// ä¿®æ”¹æ£€éªŒé¡¹ç›®å‚æ•°
export function upItemParameter(query) {
  return request({
    url: '/capacityScope/upItemParameter',
    method: 'post',
    params: query
  })
}
// èŽ·å–æ£€éªŒå¯¹è±¡æ ‘
export function getItemTree() {
  return request({
    url: '/capacityScope/getItemTree',
    method: 'get'
  })
}
src/api/structural/laboratoryScope.js
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,9 @@
import request from '@/utils/request'
// èŽ·å–æ£€éªŒé¡¹ç›®å‚æ•°
export function obtainItemParameterList() {
  return request({
    url: '/laboratoryScope/obtainItemParameterList',
    method: 'get'
  })
}
src/api/structural/standardMethod.js
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,9 @@
import request from '@/utils/request'
// èŽ·å–æ£€éªŒé¡¹ç›®å‚æ•°
export function selectStandardMethods() {
  return request({
    url: '/standardMethod/selectStandardMethods',
    method: 'get'
  })
}
src/views/structural/capability/index.vue
ÎļþÒÑɾ³ý
src/views/structural/capabilityAndLaboratory/capability/index.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,805 @@
<template>
  <div class="capacity-scope">
    <div>
      <el-row class="title">
        <el-col :span="12" style="text-align: left">
          <el-radio-group v-model="radio" @input="selectorSwitch" size="medium" fill="#409EFF">
            <el-radio-button :label="0">检验项目参数</el-radio-button>
            <el-radio-button :label="1">检验对象</el-radio-button>
          </el-radio-group>
        </el-col>
        <el-col :span="12" style="text-align: right;">
<!--          <el-button size="medium" @click="$refs.itemParameterTable.openUpload()" v-if="inPower">-->
<!--            <i class="el-icon-upload2" style="color: #3A7BFA;"></i>-->
<!--            <span style="color: #3A7BFA;">导入</span></el-button>-->
          <el-button size="medium" type="primary" v-if="radio == 1 && importExcel" @click="uploadDia = true">导入</el-button>
          <el-button size="medium" type="primary" @click="openAdd()" v-if="addPower">新增</el-button>
          <!-- <el-button size="medium" icon="el-icon-delete">删除</el-button> -->
        </el-col>
      </el-row>
    </div>
    <div v-if="radio==0" class="bodys">
      <div class="search">
        <div class="search_thing">
          <div class="search_label">检验项:</div>
          <div class="search_input"><el-input size="small" placeholder="请输入" clearable
                                              v-model="itemParameterForm.inspectionItem" @keyup.enter.native="refreshTable()"></el-input></div>
        </div>
        <div class="search_thing">
          <div class="search_label">检验子项:</div>
          <div class="search_input"><el-input size="small" placeholder="请输入" clearable
                                              v-model="itemParameterForm.inspectionItemSubclass" @keyup.enter.native="refreshTable()"></el-input>
          </div>
        </div>
        <div class="search_thing">
          <div class="search_label">检验对象:</div>
          <div class="search_input"><el-input size="small" placeholder="请输入" clearable
                                              v-model="itemParameterForm.sample" @keyup.enter.native="refreshTable()"></el-input>
          </div>
        </div>
        <div class="search_thing" style="padding-left: 30px;">
          <el-button size="small" @click="refresh()">重 ç½®</el-button>
          <el-button size="small" type="primary" @click="refreshTable()">查 è¯¢</el-button>
        </div>
      </div>
      <div class="table">
<!--        <ValueTable ref="itemParameterTable"-->
<!--                    :url="$api.capacityScope.selectItemParameterList" v-if="PROJECT === '检测中心'"-->
<!--                    :upUrl="$api.capacityScope.upItemParameter" :delUrl="$api.capacityScope.delItemParameter"-->
<!--                    :inputUrl="$api.capacityScope.importData" :componentData="itemParameterData" :key="upIndex" />-->
<!--        <ValueTable ref="itemParameterTable" :url="$api.capacityScope.selectItemParameterList" v-if="PROJECT === '装备电缆'"-->
<!--                    :upUrl="$api.capacityScope.upItemParameter" :delUrl="$api.capacityScope.delItemParameter"-->
<!--                    :inputUrl="$api.capacityScope.importEquipData" :componentData="itemParameterData" :key="upIndex" />-->
      </div>
    </div>
    <div class="bodys">
      <div class="search" v-if="radio==1">
        <div class="search_thing">
          <div class="search_label">检验对象:</div>
          <div class="search_input"><el-input size="small" placeholder="请输入" clearable
                                              v-model="testObjectData.entity.specimenName" @keyup.enter.native="refreshTable()"></el-input></div>
        </div>
        <div class="search_thing" style="padding-left: 30px;">
          <el-button size="small" @click="refresh()">重 ç½®</el-button>
          <el-button size="small" type="primary" @click="refreshTable()">查 è¯¢</el-button>
        </div>
      </div>
      <div class="table" v-if="radio==1">
<!--        <ValueTable ref="testObjectTable" :url="$api.capacityScope.selectTestObjectList"-->
<!--                    :upUrl="$api.capacityScope.upTestObject" :delUrl="$api.capacityScope.delTestObject"-->
<!--                    :componentData="testObjectData" :key="upIndex" />-->
      </div>
    </div>
    <el-dialog title="产品维护" :visible.sync="diaProduct" width="600px">
      <div class="body" v-if="diaProduct" style="height: 350px;overflow-y: auto;padding: 5px 0;">
<!--        <ValueTable ref="productData" :url="$api.capacityScope.selectProductListByObjectId"-->
<!--                    :upUrl="$api.capacityScope.upProduct" :delUrl="$api.capacityScope.delProduct"-->
<!--                    :componentData="productData" :key="upIndex"/>-->
      </div>
      <span slot="footer" class="dialog-footer">
        <el-button @click="diaProduct = false">取 æ¶ˆ</el-button>
        <el-button type="primary" @click="openAdd2" :loading="productLoad">新 å¢ž</el-button>
      </span>
    </el-dialog>
    <el-dialog title="数据导入" :visible.sync="uploadDia" width="500px">
<!--      <div style="margin: 0 auto;">-->
<!--        <el-upload ref="upload" drag :action="javaApi + $api.capacityScope.importExcel" :headers="token" :file-list="fileList" name="file"-->
<!--                   :auto-upload="false" accept=".xlsx" :limit="1" :on-change="beforeUpload" :on-success="onSuccess"-->
<!--                   :on-error="onError">-->
<!--          <i class="el-icon-upload"></i>-->
<!--          <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>-->
<!--        </el-upload>-->
<!--      </div>-->
      <span slot="footer" class="dialog-footer">
        <el-button @click="uploadDia = false">取 æ¶ˆ</el-button>
        <el-button type="primary" @click="submitUpload()" :loading="uploading">上 ä¼ </el-button>
      </span>
    </el-dialog>
    <!-- ç¼–辑 æ–°å¢ž -->
    <el-dialog
      :title="title"
      :visible.sync="dialogVisible"
      width="50%"
      :before-close="handleClose">
      <el-form :model="addOrupdateForm" label-width="120px" :rules="rules" inline ref="addOrupdateForm"  size="mini">
        <el-form-item label="检验项" prop="inspectionItem">
          <el-input v-model="addOrupdateForm.inspectionItem" placeholder="请输入检验项" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="检验项EN" >
          <el-input v-model="addOrupdateForm.inspectionItemEn" placeholder="请输入检验项EN" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="检验项子项" >
          <el-input v-model="addOrupdateForm.inspectionItemSubclass" placeholder="请输入检验项子项" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="检验子项EN" >
          <el-input v-model="addOrupdateForm.inspectionItemSubclassEn" placeholder="请输入检验子项EN" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="检验对象" >
          <el-cascader
            size="mini" style="width: 220px;"
            filterable
            v-model="addOrupdateForm.sample"
            :options="tree"
            :props="{value:'name',label: 'name', multiple: true, checkStrictly: true }"
            clearable></el-cascader>
          <!-- <el-input v-model="addOrupdateForm.sample" placeholder="请输入检验对象" size="mini" style="width: 220px;"></el-input> -->
        </el-form-item>
        <el-form-item label="单价(元)" >
          <el-input v-model="addOrupdateForm.price" placeholder="请输入单价" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="场所" >
          <el-select v-model="addOrupdateForm.laboratory" filterable size="small" style="width: 220px;">
            <el-option
              v-for="item in laboratory"
              :key="item.value"
              :label="item.label"
              :value="item.label">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="试验室" prop="sonLaboratory">
          <el-select v-model="addOrupdateForm.sonLaboratory" filterable size="small" style="width: 220px;">
            <el-option
              v-for="item in dicList.sonLaboratory"
              :key="item.value"
              :label="item.label"
              :value="item.value">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="要求描述" >
          <el-input v-model="addOrupdateForm.askTell" placeholder="请输入要求描述" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="要求值" >
          <el-input v-model="addOrupdateForm.ask" placeholder="请输入要求值" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="计量单位" prop="unit">
          <el-select v-model="addOrupdateForm.unit" filterable size="small" style="width: 220px;">
            <el-option
              v-for="item in dicList.unit"
              :key="item.value"
              :label="item.label"
              :value="item.value">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="工时(H)" >
          <el-input v-model="addOrupdateForm.manHour" placeholder="请输入工时" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="预计时间(H)" prop="manDay">
          <el-input v-model="addOrupdateForm.manDay" placeholder="请输入预计时间" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="工时分组" >
          <el-input v-model="addOrupdateForm.manHourGroup" placeholder="请输入工时分组" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="检验项类型" prop="inspectionItemType">
          <el-select v-model="addOrupdateForm.inspectionItemType" filterable size="small" style="width: 220px;">
            <el-option
              v-for="item in dicList.inspectionItemType"
              :key="item.value"
              :label="item.label"
              :value="item.value">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="检验值类型" prop="inspectionValueType">
          <el-select v-model="addOrupdateForm.inspectionValueType" filterable size="small" style="width: 220px;">
            <el-option
              v-for="item in dicList.inspectionValueType"
              :key="item.value"
              :label="item.label"
              :value="item.value">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="字典类型" >
          <el-select v-model="addOrupdateForm.dic" clearable filterable size="small" style="width: 220px;">
            <el-option
              v-for="item in dicList.dic"
              :key="item.value"
              :label="item.label"
              :value="item.value">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="特殊标识符">
          <el-select v-model="addOrupdateForm.bsm" filterable size="small" style="width: 220px;">
            <el-option
              v-for="item in dicList.bsm"
              :key="item.value"
              :label="item.label"
              :value="item.value">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="原始记录模板" prop="templateId">
          <el-select v-model="addOrupdateForm.templateId" filterable size="small" style="width: 220px;">
            <el-option
              v-for="item in dicList.templateId"
              :key="item.value"
              :label="item.label"
              :value="item.value">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="检验项分类" >
          <el-input v-model="addOrupdateForm.inspectionItemClass" placeholder="请输入检验项分类" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="检验项分类EN" >
          <el-input v-model="addOrupdateForm.inspectionItemClassEn" placeholder="请输入检验项分类EN" size="mini" style="width: 220px;"></el-input>
        </el-form-item>
        <el-form-item label="试验方法" prop="method">
          <el-select v-model="addOrupdateForm.method" filterable multiple  size="small" style="width: 220px;">
            <el-option
              v-for="(item,index) in dicList.method"
              :key="index"
              :label="item.label"
              :value="item.value">
            </el-option>
          </el-select>
        </el-form-item>
      </el-form>
      <span slot="footer" class="dialog-footer">
      <el-button @click="handleClose">取 æ¶ˆ</el-button>
      <el-button type="primary" @click="saveOrEnit">ç¡® å®š</el-button>
    </span>
    </el-dialog>
  </div>
</template>
<script>
// import ValueTable from '../tool/value-table.vue'
import {addItemParameter, getItemTree, upItemParameter} from "@/api/structural/capability";
import {obtainItemParameterList} from "@/api/structural/laboratoryScope";
import {selectStandardMethods} from "@/api/structural/standardMethod";
export default {
  data() {
    return {
      dicList: {
        inspectionItemType: [],
        inspectionValueType: [],
        bsm: [],
        sonLaboratory: [],
        unit: [],
        dic: [],
        method: [],
      },
      addOrUpdate: '',
      addOrupdateForm:{
        inspectionItem: '',
        inspectionItemEn: '',
        inspectionItemSubclass: '',
        inspectionItemSubclassEn: '',
        sample: null,
        price: '',
        laboratory: '',
        sonLaboratory: '',
        askTell: '',
        ask: '',
        unit: '',
        manHour: '',
        manDay: '',
        manHourGroup: '',
        inspectionItemType: '',
        inspectionValueType: '',
        dic: '',
        bsm: '',
        templateId: '',
        inspectionItemClass: '',
        inspectionItemClassEn: '',
        method: []
      },
      tree: null,
      rules:{
        inspectionItem: [
          { required: true, message: '请输入检验项', trigger: 'blur' }
        ],
        sonLaboratory: [
          { required: true, message: '请输入试验室', trigger: 'change' }
        ],
        unit: [
          { required: true, message: '请输入计量单位', trigger: 'change' }
        ],
        manDay: [
          { required: true, message: '请输入预计时间', trigger: 'blur' }
        ],
        inspectionItemType: [
          { required: true, message: '请输入检验项类型', trigger: 'change' }
        ],
        inspectionValueType: [
          { required: true, message: '请输入检验值类型', trigger: 'change' }
        ],
        method: [
          { required: true, message: '请选择试验方法', trigger: 'change' }
        ],
        templateId: [
          { required: true, message: '请输入原始记录模板', trigger: 'change' }
        ],
      },
      dialogVisible: false,
      loading: true,
      itemParameterForm: {
        inspectionItem: null,
        inspectionItemSubclass: null,
        sample: null
      },
      logining:false,
      radio: 0,
      showItemParameter: true,
      showTestObject: false,
      itemParameterData: {
        entity: {
          inspectionItem: null,
          inspectionItemSubclass: null,
          sample: null,
          orderBy: {
            field: 'id',
            order: 'asc'
          }
        },
        isIndex: true,
        showSelect: false,
        select: true,
        row: 2,
        do: [{
          id: 'update',
          font: '编辑',
          type: 'text',
          method: 'openAdd',
          field: []
        }, {
          id: 'delete',
          font: '删除',
          type: 'text',
          method: 'doDiy'
        }],
        tagField: {
        },
        selectField: {
          inspectionItemType: {
            select: []
          },
          bsm: {
            select: []
          },
          inspectionValueType: {
            select: []
          },
          laboratory: {
            select: []
          },
          templateId: {
            select: []
          },
          method: {
            select: [],
            choose: true
          },
          sonLaboratory: {
            select: []
          },
          unit: {
            select: []
          },
          dic: {
            select: []
          },
        },
        cascaderField:{
          sample:{
            tree:[]
          },
          // å­—段配置
          props:{
            value:'name',
            label:'name',
            checkStrictly: true,
            multiple: true
          }
        },
        requiredAdd: ['sonLaboratory', 'inspectionItem', 'inspectionItemType', 'inspectionValueType',
          'unit', 'method', 'manDay', 'templateId'
        ],
        requiredUp: ['sonLaboratory', 'inspectionItem', 'inspectionItemType', 'inspectionValueType',
          'unit', 'method', 'manDay', 'templateId'
        ],
        accept: '.xlsx',
        inputType: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
        needSort: ['createTime', 'updateTime', 'inspectionItem', 'inspectionItemSubclass', 'sample'],
      },
      testObjectData: {
        entity: {
          specimenName: null,
          orderBy: {
            field: 'id',
            order: 'asc'
          }
        },
        isIndex: true,
        showSelect: false,
        select: true,
        do: [{
          id: 'update',
          font: '编辑',
          type: 'text',
          method: 'doDiy',
          field: ['createUserName', 'updateUserName', 'product']
        }, {
          id: 'delete',
          font: '删除',
          type: 'text',
          method: 'doDiy'
        }, {
          font: '产品维护',
          type: 'text',
          method: 'upProduct'
        }],
        tagField: {
          laboratoryId: {
            select: []
          }
        },
        selectField: {
          laboratoryId: {
            select: []
          }
        },
        requiredAdd: ['specimenName', 'code', 'laboratoryId'],
        requiredUp: ['specimenName', 'code', 'laboratoryId'],
        needSort: ['createTime', 'updateTime', 'specimenName'],
      },
      itemParameterEntityCopy: {},
      testObjectDataEntityCopy: {},
      upIndex: 0,
      addDia: false,
      addPower: true,
      select: 0,
      laboratory: [],
      productLoad: false,
      diaProduct: false,
      productData: {
        entity: {
          objectId: 0,
          orderBy: {
            field: 'id',
            order: 'asc'
          }
        },
        isPage: false,
        isIndex: true,
        showSelect: false,
        select: true,
        do: [{
          id: 'update',
          font: '编辑',
          type: 'text',
          method: 'doDiy',
          field: []
        }, {
          id: 'delete',
          font: '删除',
          type: 'text',
          method: 'doDiy'
        }],
        tagField: {},
        selectField: {},
        requiredAdd: ['name','nameEn'],
        requiredUp: ['name','nameEn'],
      },
      inPower: true,
      importExcel: false,
      uploadDia: false,
      fileList: [],
      token: null,
      uploading: false,
    }
  },
  created() {
    if (this.PROJECT === '装备电缆') {
      this.itemParameterData.requiredUp = ['sonLaboratory', 'inspectionItem', 'inspectionItemType', 'inspectionValueType',
        'unit', 'manDay', 'templateId'
      ]
    }
  },
  mounted() {
    this.token = {
      'token': sessionStorage.getItem('token')
    }
    this.itemParameterEntityCopy = this.HaveJson(this.itemParameterData.entity)
    this.testObjectDataEntityCopy = this.HaveJson(this.testObjectData.entity)
    this.obtainItemParameterList() //场所
    this.selectStandardMethods()    // è¯•验方法
    this.selectTestObjectByName()
    this.getStandardTemplate() // åŽŸå§‹è®°å½•æ¨¡æ¿
    this.selectDocUnit()
    this.selectAllNeedEnum()
  },
  computed: {
    title() {
      return this.addOrUpdate == 1 ? '新增' : '编辑'
    }
  },
  methods: {
    //查询需要的全部枚举
    selectAllNeedEnum(){
      // this.$axios.post(this.$api.enums.selectEnumListByCategory,
      //   {categoryList:['检验项类型','取值类型','是否','检验值类型','子实验室','单位']},{
      //     headers: {
      //       'Content-Type': 'application/json'
      //     }
      //   }).then(res => {
      //   res.data['检验项类型'].forEach(ele => {
      //     if(ele.label.indexOf('非采集')==0)ele.type='info'
      //   });
      //   this.dicList.sonLaboratory = res.data['子实验室']
      //   this.dicList.unit = res.data['单位']
      //   this.dicList.inspectionItemType = res.data['检验项类型']
      //   this.dicList.inspectionValueType = res.data['检验值类型']
      //   this.dicList.bsm = res.data['是否']
      // })
    },
    saveOrEnit() {
      console.log('this.addOrupdateForm', this.addOrupdateForm.sample);
      let flag = true
      this.$refs['addOrupdateForm'].validate((valid) => {
        if (valid) {
          flag = false
          return false
        }
      });
      if(flag) return
      if(this.addOrupdateForm.sample != null && this.addOrupdateForm.sample != '' && this.addOrupdateForm.sample != undefined ) {
        if(this.addOrupdateForm.sample.length > 0) {
          this.addOrupdateForm.sample = JSON.stringify(this.addOrupdateForm.sample)
        }else{
          this.addOrupdateForm.sample = '[]'
        }
      }else{
        this.addOrupdateForm.sample = '[]'
      }
      // 1是新增
      if(this.addOrUpdate == 1) {
        this.addOrupdateForm.method = JSON.stringify(this.addOrupdateForm.method)
        addItemParameter(this.addOrupdateForm).then(res => {
          if(res.code == 200) {
            this.$message.success('新增成功')
            this.refreshTable()
            this.handleClose()
            this.dialogVisible = false
          } else {
            // æŠ¥é”™ å°†è½¬æ¢çš„method ä»¥åŠ sample è½¬æ¢å›žæ¥
            this.addOrupdateForm.method = JSON.parse(this.addOrupdateForm.method)
            this.addOrupdateForm.sample = JSON.parse(this.addOrupdateForm.sample)
            this.$message.error(res.message)
          }
        })
      }else{
        this.addOrupdateForm.method = JSON.stringify(this.addOrupdateForm.method)
        upItemParameter(this.addOrupdateForm).then(res => {
          if(res.code == 200) {
            this.$message.success('编辑成功')
            this.refreshTable()
            this.handleClose()
            this.dialogVisible = false
          } else {
            // æŠ¥é”™ å°†è½¬æ¢çš„method ä»¥åŠ sample è½¬æ¢å›žæ¥
            this.addOrupdateForm.method = JSON.parse(this.addOrupdateForm.method)
            this.addOrupdateForm.sample = JSON.parse(this.addOrupdateForm.sample)
            this.$message.error(res.message)
          }
        })
      }
    },
    handleClose() {
      this.dialogVisible = false
      this.addOrupdateForm = {
        inspectionItem: '',
        inspectionItemEn: '',
        inspectionItemSubclass: '',
        inspectionItemSubclassEn: '',
        sample: null,
        price: '',
        laboratory: '',
        sonLaboratory: '',
        askTell: '',
        ask: '',
        unit: '',
        manHour: '',
        manDay: '',
        manHourGroup: '',
        inspectionItemType: '',
        inspectionValueType: '',
        dic: '',
        bsm: '',
        templateId: '',
        inspectionItemClass: '',
        inspectionItemClassEn: '',
        method: null
      }
      this.$refs['addOrupdateForm'].resetFields();
      this.addOrUpdate = ''
    },
    submitUpload() {
      if (this.$refs.upload.uploadFiles.length == 0) {
        this.$message.error('未选择文件')
        return
      }
      this.uploading = true
      this.$refs.upload.submit();
    },
    onSuccess(response, file, fileList) {
      this.$refs.upload.clearFiles()
      this.uploadDia = false
      this.uploading = false
      if (response.code == 201) {
        this.$message.error(response.message)
        return
      }
      this.$message.success('上传成功')
      this.standardList = []
      this.productList = []
      this.refreshTable()
    },
    onError(err, file, fileList) {
      this.$message.error('上传失败')
      this.$refs.upload.clearFiles()
      this.uploading = false
    },
    beforeUpload(file, fileList) {
      if (file.raw.type != 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet') {
        this.$message.error('上传文件格式不正确');
        this.$refs.upload.clearFiles()
        return false;
      }
    },
    selectorSwitch(radio) {
      if (this.radio === '0') {
        this.showItemParameter = true;
        this.showTestObject = false;
        this.selectTestObjectByName()
        /* this.$nextTick(() => {
          this.$refs.itemParameterTable.selectList()
        }) */
      } else {
        this.showTestObject = true;
        this.showItemParameter = false;
      }
    },
    refreshTable() {
      this.itemParameterData.entity.inspectionItem = this.itemParameterForm.inspectionItem
      this.itemParameterData.entity.inspectionItemSubclass = this.itemParameterForm.inspectionItemSubclass
      this.itemParameterData.entity.sample = this.itemParameterForm.sample
      if (this.radio === '0') {
        // this.$refs['itemParameterTable'].selectList()
      } else {
        // this.$refs['testObjectTable'].selectList()
      }
    },
    refresh() {
      this.itemParameterData.entity = this.HaveJson(this.itemParameterEntityCopy)
      this.testObjectData.entity = this.HaveJson(this.testObjectDataEntityCopy)
      this.upIndex++
    },
    openAdd(row) {
      //0代表检验参数tab
      if (this.radio === '0') {
        // this.$refs.itemParameterTable.openAddDia(this.$api.capacityScope.addItemParameter);
        if(!row) {
          this.addOrUpdate = 1
        }else{
          if(typeof row.sample == 'string') {
            row.sample = JSON.parse(row.sample)
          }
          this.addOrUpdate = ''
          this.addOrupdateForm = JSON.parse(JSON.stringify(row))
        }
        this.dialogVisible = true
      } else {
        // this.$refs.testObjectTable.openAddDia(this.$api.capacityScope.addTestObject);
      }
    },
    selectDocUnit() {
      // this.$axios.post(this.$api.enums.getDic).then(res => {
      //   this.dicList.dic = res.data.map(m => {
      //     return {
      //       label: m,
      //       value: m
      //     }
      //   })
      // })
    },
    obtainItemParameterList() {
      obtainItemParameterList().then(res => {
        let data = []
        let data0 = []
        res.data.forEach(a => {
          data.push({
            label: a.laboratoryName,
            value: a.id
          })
          data0.push({
            label: a.laboratoryName,
            value: a.laboratoryName
          })
        })
        // this.itemParameterData.selectField.laboratory.select = data0
        // this.itemParameterData.tagField.laboratory.select = data0
        this.testObjectData.selectField.laboratoryId.select = data
        this.testObjectData.tagField.laboratoryId.select = data
        this.laboratory = data
      })
    },
    selectStandardMethods() {
      selectStandardMethods().then(res => {
        let data = []
        res.data.forEach(a => {
          data.push({
            label: a.code,
            value: a.code
          })
        })
        this.dicList.method = data
      })
    },
    selectTestObjectByName() {
      getItemTree().then(res => {
        res.data.forEach(a=>{
          this.cascaderFieldData(a)
        })
        this.itemParameterData.cascaderField.sample.tree = res.data
        this.tree = res.data
      })
    },
    cascaderFieldData(val){
      if(val.children === undefined) {
        return
      }else if(val.children.length==0){[
        delete val.children
      ]}else{
        val.children.forEach(a=>{
          this.cascaderFieldData(a)
        })
      }
    },
    getStandardTemplate() {
      // this.$axios.get(this.$api.StandardTemplate.getStandardTemplate).then(res => {
      //   let data = []
      //   res.data.forEach(a => {
      //     data.push({
      //       label: a.name,
      //       value: a.id,
      //       type: 'success'
      //     })
      //   })
      //   // this.itemParameterData.selectField.templateId.select = data
      //   // this.itemParameterData.tagField.templateId.select = data
      //   this.dicList.templateId = data
      // })
    },
    upProduct(row) {
      this.productData.entity.objectId = row.id
      this.diaProduct = true
    },
    openAdd2(){
      // this.$refs.productData.openAddDia(this.$api.capacityScope.addProduct, {objectId: this.productData.entity.objectId});
    },
  }
}
</script>
<style scoped>
.title {
  height: 40px;
  line-height: 40px;
  margin-bottom: 10px;
}
</style>
src/views/structural/capabilityAndLaboratory/laboratory/index.vue