From 7e4a48404dcca87fa8060fde21dcb5cdf6b651dc Mon Sep 17 00:00:00 2001
From: spring <2396852758@qq.com>
Date: 星期三, 12 三月 2025 15:42:23 +0800
Subject: [PATCH] table封装showHidebug

---
 src/views/standard/standardLibrary/index.vue | 1816 +++++++++++++++++++---------------------------------------
 1 files changed, 605 insertions(+), 1,211 deletions(-)

diff --git a/src/views/standard/standardLibrary/index.vue b/src/views/standard/standardLibrary/index.vue
index d57f377..a467c0b 100644
--- a/src/views/standard/standardLibrary/index.vue
+++ b/src/views/standard/standardLibrary/index.vue
@@ -1,7 +1,8 @@
 <style scoped>
 .standard {
-  padding: 10px 0;
+  padding-top: 10px;
   display: flex;
+  height: calc(100vh - 90px);
 }
 
 .left {
@@ -26,16 +27,6 @@
   opacity: 1;
 }
 
-.custom-tree-node .el-icon-edit {
-  color: #3a7bfa;
-  opacity: 0;
-  font-size: 18px;
-}
-
-.custom-tree-node:hover .el-icon-edit {
-  opacity: 1;
-}
-
 .node_i {
   color: orange;
   font-size: 18px;
@@ -43,7 +34,7 @@
 
 .right {
   margin-left: 5px;
-  width: calc(100% - 365px);
+  width: calc(100% - 350px);
   height: calc(100% - 40px);
 }
 
@@ -76,21 +67,21 @@
   overflow: hidden;
 }
 
->>> .el-table__body-wrapper {
+>>>.el-table__body-wrapper {
   height: calc(100% - 46px) !important;
 }
 
->>> .header-class {
+>>>.header-class {
   height: 40px !important;
 }
 
->>> .header-class th.el-table__cell > .cell {
+>>>.header-class th.el-table__cell>.cell {
   line-height: 20px !important;
   padding-top: 0 !important;
   padding-bottom: 0 !important;
 }
 
->>> .el-table__row {
+>>>.el-table__row {
   height: 35px !important;
 }
 
@@ -124,11 +115,17 @@
   right: 70px;
 }
 
->>> .is-disabled .el-textarea__inner {
+>>>.is-disabled .el-textarea__inner {
   background: rgba(0, 0, 0, 0.05) !important;
 }
->>> .el-table__body-wrapper::-webkit-scrollbar {
-  height: 14px; /* 璁剧疆婊氬姩鏉″搴� */
+
+>>>.is-disabled .el-textarea__inner {
+  background: rgba(0, 0, 0, 0.05) !important;
+}
+
+>>>.el-table__body-wrapper::-webkit-scrollbar {
+  height: 14px;
+  /* 璁剧疆婊氬姩鏉″搴� */
 }
 </style>
 <style>
@@ -138,10 +135,7 @@
   border-radius: 2px;
 }
 
-.standard
-  .el-tree--highlight-current
-  .el-tree-node.is-current
-  > .el-tree-node__content {
+.standard .el-tree--highlight-current .el-tree-node.is-current>.el-tree-node__content {
   color: #3a7bfa;
 }
 
@@ -192,104 +186,38 @@
     <div class="left">
       <el-row>
         <el-col :span="20">
-          <el-input
-            v-model="search"
-            clearable
-            placeholder="杈撳叆鍏抽敭瀛楄繘琛屾悳绱�"
-            size="small"
-            style="margin-bottom: 5px"
-            suffix-icon="el-icon-search"
-            @blur="searchFilter"
-            @clear="searchFilter"
-          ></el-input>
+          <el-input placeholder="杈撳叆鍏抽敭瀛楄繘琛屾悳绱�" suffix-icon="el-icon-search" v-model="search" size="small"
+            style="margin-bottom: 5px" clearable @blur="searchFilter" @clear="searchFilter"></el-input>
         </el-col>
-        <el-col
-          v-if="checkPermi(['standard:standardLibrary:add'])"
-          :span="4"
-          style="text-align: center; line-height: 30px"
-        >
-          <el-button
-            circle
-            icon="el-icon-plus"
-            size="mini"
-            type="primary"
-            @click="addDia = true"
-          ></el-button>
+        <el-col :span="4" style="text-align: center; line-height: 30px" v-if="addPower">
+          <el-button type="primary" icon="el-icon-plus" size="mini" circle @click="addDia = true"></el-button>
         </el-col>
       </el-row>
-      <el-tree
-        ref="tree"
-        v-loading="treeLoad"
-        :allow-drop="allowDrop"
-        :data="list"
-        :default-expanded-keys="expandedKeys"
-        :draggable="true"
-        :filter-node-method="filterNode"
-        :props="{ children: 'children', label: 'label' }"
-        highlight-current
-        node-key="label"
-        style="
+      <el-tree :data="list" ref="tree" :props="{ children: 'children', label: 'label' }" node-key="label"
+        :filter-node-method="filterNode" @node-click="handleNodeClick" highlight-current v-loading="treeLoad"
+        :expand-on-click-node="false" :default-expanded-keys="expandedKeys" style="
           height: calc(100% - 30px);
           overflow-y: scroll;
           scrollbar-width: none;
-        "
-        @node-click="handleNodeClick"
-        @node-expand="nodeOpen"
-        @node-collapse="nodeClose"
-        @node-drop="handleDrop"
-      >
-        <div slot-scope="{ node, data }" class="custom-tree-node">
+        ">
+        <div class="custom-tree-node" slot-scope="{ node, data }">
           <el-row style="width: 100%">
-            <el-col
-              :class="{ sort: node.level > 3 }"
-              :span="19"
-              :title="data.label"
-              style="text-align: left"
-            >
+            <el-col :span="21" :class="{ sort: node.level > 3 }" :title="data.label" style="text-align: left">
               <span>
-                <i
-                  :class="`node_i ${
-                    data.children != undefined
-                      ? data.code === '[1]'
-                        ? 'el-icon-folder-opened'
-                        : 'el-icon-folder'
-                      : 'el-icon-tickets'
-                  }`"
-                ></i>
+                <i :class="`node_i ${data.children != undefined
+                  ? data.code === '[1]'
+                    ? 'el-icon-folder-opened'
+                    : 'el-icon-folder'
+                  : 'el-icon-tickets'
+                  }`"></i>
                 {{ data.label }}
               </span>
             </el-col>
-            <el-col
-              v-if="
-                checkPermi(['standard:standardLibrary:delStandardTree']) &&
-                (node.data.children === null ||
-                  node.data.children === undefined)
-              "
-              :span="2"
-              style="text-align: right"
-            >
-              <el-button
-                size="mini"
-                type="text"
-                @click="editTreeName(node.data)"
-              >
-                <i class="el-icon-edit"></i>
-              </el-button>
-            </el-col>
-            <el-col
-              v-if="
-                checkPermi(['standard:standardLibrary:delStandardTree']) &&
-                (node.data.children === null ||
-                  node.data.children === undefined)
-              "
-              :span="2"
-              style="text-align: right"
-            >
-              <el-button
-                size="mini"
-                type="text"
-                @click.stop="remove(node, data)"
-              >
+            <el-col :span="2" style="text-align: right" v-if="
+              (node.data.children === null ||
+                node.data.children === undefined)
+            ">
+              <el-button type="text" size="mini" @click.stop="remove(node, data)">
                 <i class="el-icon-delete"></i>
               </el-button>
             </el-col>
@@ -302,801 +230,349 @@
         <el-col :span="20" style="font-size: 14px; color: #999">{{
           selectTree
         }}</el-col>
-        <el-col :span="4">
-          <el-button
-            v-if="isShowCopy"
-            size="small"
-            style="position: absolute; right: 50px; top: 1px"
-            type="primary"
-            @click="openCopyDia"
-            >鎵归噺澶嶅埗</el-button
-          >
-        </el-col>
+        <el-button size="small" type="primary" style="position: absolute; right: 100px; top: 1px"
+          @click="uploadDia = true" v-if="inExcelOfTreePower">瀵煎叆</el-button>
+        <el-button size="small" type="primary" @click="handleMore" style="position: absolute; right: 5px; top: 1px"
+          v-if="upStandardProduct">鎵归噺缂栬緫</el-button>
       </el-row>
-      <el-row v-loading="tableLoad" class="standard_table">
-        <el-table
-          ref="standard"
-          :data="standardList"
-          class="el-table"
-          header-row-class-name="header-class"
-          height="220"
-          highlight-current-row
-          style="width: 100%; height: 220px !important"
-          tooltip-effect="dark"
-          @row-click="rowClick"
-        >
-          <el-table-column
-            label="鏍囧噯缂栧彿"
-            prop="code"
-            show-overflow-tooltip
-            width="200"
-          >
+      <el-row class="standard_table" v-loading="tableLoad">
+        <el-table class="el-table" :data="standardList" style="width: 100%; height: 220px !important" height="220"
+          tooltip-effect="dark" highlight-current-row @row-click="rowClick" ref="standard"
+          header-row-class-name="header-class">
+          <el-table-column prop="code" label="鏍囧噯缂栧彿" show-overflow-tooltip width="200">
             <template slot-scope="scope">
               <span style="color: red; font-size: 14px">{{
                 scope.row["code"]
               }}</span>
             </template>
           </el-table-column>
-          <el-table-column
-            label="鏍囧噯鍚嶇О"
-            prop="name"
-            show-overflow-tooltip
-          ></el-table-column>
-          <el-table-column
-            label="澶囨敞"
-            prop="remark"
-            show-overflow-tooltip
-          ></el-table-column>
+          <el-table-column prop="name" label="鏍囧噯鍚嶇О" show-overflow-tooltip></el-table-column>
+          <el-table-column prop="remark" label="澶囨敞" show-overflow-tooltip></el-table-column>
         </el-table>
       </el-row>
-      <el-row v-loading="tableLoad2" class="product_table">
-        <el-table
-          id="templateParamTable"
-          ref="productTable"
-          v-loading="productTableLoading"
-          :data="productList"
-          :fit="true"
-          :row-class-name="tableRowClassName"
-          border
-          class="productTable"
-          header-row-class-name="header-class"
-          height="100%"
-          row-key="id"
-          stripe
-          style="width: 100%"
-          tooltip-effect="dark"
-          @select="upProductSelect"
-          @selection-change="handleSelectionChange"
-          @select-all="handleAll"
-        >
+      <el-row class="product_table" v-loading="tableLoad2">
+        <el-table :data="productList" ref="productTable" style="width: 100%" height="100%" tooltip-effect="dark" stripe
+          :fit="true" border @selection-change="handleSelectionChange" :row-class-name="tableRowClassName"
+          @select="upProductSelect" @select-all="handleAll" class="productTable" header-row-class-name="header-class">
           <el-table-column type="selection" width="50"> </el-table-column>
-          <el-table-column
-            label="浜у搧"
-            min-width="100"
-            prop="sample"
-            show-overflow-tooltip
-          ></el-table-column>
-          <el-table-column
-            label="鍨嬪彿"
-            min-width="100"
-            prop="model"
-            show-overflow-tooltip
-          ></el-table-column>
-          <el-table-column
-            label="妫�楠岄」鍒嗙被"
-            min-width="140"
-            prop="inspectionItemClass"
-            show-overflow-tooltip
-          ></el-table-column>
-          <el-table-column
-            label="妫�楠岄」"
-            min-width="140"
-            prop="inspectionItem"
-            show-overflow-tooltip
-          ></el-table-column>
-          <el-table-column
-            label="妫�楠岄」瀛愰」"
-            min-width="140"
-            prop="inspectionItemSubclass"
-            show-overflow-tooltip
-          ></el-table-column>
-          <el-table-column
-            label="瀛愬疄楠屽"
-            prop="sonLaboratory"
-            show-overflow-tooltip
-            width="130"
-          ></el-table-column>
-          <el-table-column label="瑕佹眰鍊�" min-width="200px" prop="ask">
+          <el-table-column prop="sample" label="浜у搧" min-width="100" show-overflow-tooltip></el-table-column>
+          <el-table-column prop="model" label="鍨嬪彿" min-width="100" show-overflow-tooltip></el-table-column>
+          <el-table-column prop="inspectionItem" label="妫�楠岄」" min-width="140" show-overflow-tooltip></el-table-column>
+          <!-- <el-table-column prop="inspectionItemClassify" label="妫�楠岄」绫诲瀷" width="120" show-overflow-tooltip></el-table-column> -->
+          <el-table-column prop="inspectionItemSubclass" label="妫�楠岄」瀛愰」" min-width="140"
+            show-overflow-tooltip></el-table-column>
+          <el-table-column prop="sonLaboratory" label="瀛愬疄楠屽" width="130" show-overflow-tooltip></el-table-column>
+          <el-table-column prop="ask" label="瑕佹眰鍊�" min-width="200px">
             <template slot-scope="scope">
-              <el-input
-                v-if="
-                  checkPermi(['standard:standardLibrary:upStandardProduct'])
-                "
-                v-model="scope.row.ask"
-                :autosize="{ minRows: 1, maxRows: 3 }"
-                clearable
-                placeholder="瑕佹眰鍊�"
-                size="small"
-                type="textarea"
-                @change="(value) => upStandardProductList(value, scope.row.id)"
-              ></el-input>
+              <el-input size="small" placeholder="瑕佹眰鍊�" v-model="scope.row.ask" clearable
+                @change="(value) => upStandardProductList(value, scope.row.id)" v-if="upStandardProduct" type="textarea"
+                :autosize="{ minRows: 1, maxRows: 3 }"></el-input>
               <span v-else>{{ scope.row.ask }}</span>
             </template>
           </el-table-column>
-          <el-table-column label="瑕佹眰鎻忚堪" min-width="220px" prop="tell">
+          <el-table-column prop="tell" label="瑕佹眰鎻忚堪" min-width="220px">
             <template slot-scope="scope">
-              <el-input
-                v-if="
-                  checkPermi(['standard:standardLibrary:upStandardProduct'])
-                "
-                v-model="scope.row.tell"
-                :autosize="{ minRows: 1, maxRows: 3 }"
-                clearable
-                placeholder="瑕佹眰鎻忚堪"
-                size="small"
-                type="textarea"
-                @change="
-                  (value) => upStandardProductListOfTell(value, scope.row.id)
-                "
-              ></el-input>
+              <el-input size="small" placeholder="瑕佹眰鎻忚堪" v-model="scope.row.tell" clearable @change="(value) => upStandardProductListOfTell(value, scope.row.id)
+                " v-if="upStandardProduct" type="textarea" :autosize="{ minRows: 1, maxRows: 3 }"></el-input>
               <span v-else>{{ scope.row.ask }}</span>
             </template>
           </el-table-column>
-          <el-table-column label="璇曢獙鏂规硶" prop="method" width="200">
+          <el-table-column prop="method" label="璇曢獙鏂规硶" width="200">
             <template slot-scope="scope">
-              <el-select
-                v-if="
-                  checkPermi(['standard:standardLibrary:upStandardProduct'])
-                "
-                v-model="scope.row.methodS"
-                clearable
-                placeholder="璇曢獙鏂规硶"
-                size="small"
-                @change="
-                  (value) => upStandardProductListOfMethodS(value, scope.row.id)
-                "
-              >
-                <el-option
-                  v-for="(a, i) in scope.row.method &&
-                  JSON.parse(scope.row.method)"
-                  :key="i"
-                  :label="a"
-                  :value="a"
-                ></el-option>
+              <el-select v-model="scope.row.methodS" size="small" placeholder="璇曢獙鏂规硶" @change="(value) => upStandardProductListOfMethodS(value, scope.row.id)
+                " v-if="upStandardProduct">
+                <el-option v-for="(a, i) in JSON.parse(scope.row.method)" :key="i" :label="a" :value="a"></el-option>
               </el-select>
               <span v-else>{{ scope.row.methodS }}</span>
             </template>
           </el-table-column>
-          <el-table-column
-            label="鏉′欢"
-            min-width="140"
-            prop="radius"
-            show-overflow-tooltip
-          >
+          <el-table-column prop="unit" label="璁¢噺鍗曚綅" width="100" show-overflow-tooltip></el-table-column>
+          <el-table-column prop="price" label="鍗曚环(鍏�)" width="120">
             <template slot-scope="scope">
-              <el-select
-                v-if="
-                  checkPermi(['standard:standardLibrary:upStandardProduct'])
-                "
-                v-model="scope.row.radius"
-                clearable
-                placeholder="鏉′欢"
-                size="small"
-                @change="
-                  (value) => upStandardProductListOfRadius(value, scope.row.id)
-                "
-              >
-                <el-option
-                  v-for="(a, i) in scope.row.radiusList &&
-                  JSON.parse(scope.row.radiusList)"
-                  :key="i"
-                  :label="a"
-                  :value="a"
-                ></el-option>
-              </el-select>
-              <span v-else>{{ scope.row.radius }}</span>
-            </template>
-          </el-table-column>
-          <el-table-column
-            label="璁¢噺鍗曚綅"
-            prop="unit"
-            show-overflow-tooltip
-            width="100"
-          ></el-table-column>
-          <el-table-column label="鍗曚环(鍏�)" prop="price" width="120">
-            <template slot-scope="scope">
-              <el-input
-                v-if="
-                  checkPermi(['standard:standardLibrary:upStandardProduct'])
-                "
-                v-model="scope.row.price"
-                placeholder="鍗曚环(鍏�)"
-                size="small"
-                @change="
-                  (value) => upStandardProductListOfPrice(value, scope.row.id)
-                "
-              >
+              <el-input v-model="scope.row.price" size="small" placeholder="鍗曚环(鍏�)" @change="(value) => upStandardProductListOfPrice(value, scope.row.id)
+                " v-if="upStandardProduct">
               </el-input>
               <span v-else>{{ scope.row.price }}</span>
             </template>
           </el-table-column>
-          <el-table-column label="宸ユ椂绯绘暟" prop="manHour" width="120">
+          <el-table-column prop="manHour" label="宸ユ椂绯绘暟" width="120">
             <template slot-scope="scope">
-              <el-input
-                v-if="
-                  checkPermi(['standard:standardLibrary:upStandardProduct'])
-                "
-                v-model="scope.row.manHour"
-                placeholder="鍗曚环(鍏�)"
-                size="small"
-                @change="
-                  (value) => upStandardProductListOfManHour(value, scope.row.id)
-                "
-              >
+              <el-input v-model="scope.row.manHour" size="small" placeholder="宸ユ椂绯绘暟" @change="(value) => upStandardProductListOfManHour(value, scope.row.id)
+                " v-if="upStandardProduct">
               </el-input>
               <span v-else>{{ scope.row.manHour }}</span>
             </template>
           </el-table-column>
-          <el-table-column
-            label="宸ユ椂鍒嗙粍"
-            prop="manHourGroup"
-            show-overflow-tooltip
-            width="100"
-          ></el-table-column>
-          <el-table-column label="妯℃澘" prop="templateId" width="200">
+          <el-table-column prop="manHourGroup" label="宸ユ椂鍒嗙粍" width="100" show-overflow-tooltip></el-table-column>
+          <el-table-column prop="templateId" label="妯℃澘" width="200">
             <template slot-scope="scope">
-              <el-select
-                v-model="scope.row.templateId"
-                :disabled="
-                  !checkPermi(['standard:standardLibrary:upStandardProduct'])
-                "
-                filterable
-                size="small"
-                @change="
-                  (value) =>
-                    upStandardProductListOfTemplate(value, scope.row.id)
-                "
-              >
-                <el-option
-                  v-for="(a, ai) in templateList"
-                  :key="ai"
-                  :label="a.name"
-                  :value="a.id"
-                ></el-option>
+              <el-select v-model="scope.row.templateId" size="small" filterable :disabled="!upStandardProduct" @change="(value) =>
+                upStandardProductListOfTemplate(value, scope.row.id)
+                ">
+                <el-option v-for="(a, ai) in templateList" :key="ai" :label="a.name" :value="a.id"></el-option>
               </el-select>
             </template>
           </el-table-column>
-          <el-table-column
-            label="鍖洪棿"
-            prop="section"
-            show-overflow-tooltip
-            width="120"
-          ></el-table-column>
-          <el-table-column label="鎿嶄綔" prop="section" width="160">
+          <el-table-column prop="section" label="鍖洪棿" width="120" show-overflow-tooltip></el-table-column>
+          <el-table-column prop="section" label="鎿嶄綔" width="120">
             <template slot-scope="scope">
-              <el-button type="text" @click="sectionUp(scope.row)"
-                >鍖洪棿璁剧疆</el-button
-              >
-              <el-button
-                type="text"
-                @click="bindSupplierDensitySecond(scope.row)"
-                >缁戝畾鍘傚</el-button
-              >
+              <el-button type="text" @click="sectionUp(scope.row)">鍖洪棿璁剧疆</el-button>
             </template>
           </el-table-column>
         </el-table>
-        <el-pagination
-          :current-page="currentPage"
-          :page-size="300"
-          :total="total"
-          layout="total, prev, pager, next, jumper"
-          style="position: absolute; right: 16px; bottom: 1px"
-          @current-change="handleCurrentChange"
-        >
+        <el-pagination style="position: absolute; right: 16px; bottom: 1px" @current-change="handleCurrentChange"
+          :current-page="currentPage" layout="total, prev, pager, next, jumper" :page-size="50" :total="total">
         </el-pagination>
       </el-row>
     </div>
-    <el-dialog :visible.sync="addDia" title="鍒嗙被娣诲姞" width="400px">
+    <el-dialog title="鍒嗙被娣诲姞" :visible.sync="addDia" width="400px">
       <div class="body">
+        <!-- <el-row style="line-height: 50px;">
+          <el-col :span="6" style="text-align: right;">宸ュ巶锛�</el-col>
+          <el-col :span="16" :offset="1">
+            <el-input size="small" readonly v-model="addOb.factory"></el-input>
+          </el-col>
+        </el-row>
+        <el-row style="line-height: 50px;">
+          <el-col :span="6" style="text-align: right;">瀹為獙瀹わ細</el-col>
+          <el-col :span="16" :offset="1">
+            <el-input size="small" readonly v-model="addOb.laboratory"></el-input>
+          </el-col>
+        </el-row>
+        <el-row style="line-height: 50px;">
+          <el-col :span="6" style="text-align: right;">鏍峰搧澶х被锛�</el-col>
+          <el-col :span="16" :offset="1">
+            <el-input size="small" readonly v-model="addOb.sampleType"></el-input>
+          </el-col>
+        </el-row>
+        <el-row style="line-height: 50px;">
+          <el-col :span="6" style="text-align: right;">鏍峰搧鍚嶇О锛�</el-col>
+          <el-col :span="16" :offset="1">
+            <el-input v-model="addOb.sample" readonly size="small"></el-input>
+          </el-col>
+        </el-row> -->
         <el-row style="line-height: 50px">
           <el-col :span="6" style="text-align: right">
             <span class="required-span">* </span>鍨嬪彿锛�
           </el-col>
-          <el-col :offset="1" :span="16">
-            <el-input
-              v-model="addOb.model"
-              clearable
-              placeholder="璇疯緭鍏ュ瀷鍙�"
-              size="small"
-              @keyup.enter.native="addStandardTree"
-            ></el-input>
+          <el-col :span="16" :offset="1">
+            <el-input v-model="addOb.model" placeholder="璇疯緭鍏ュ瀷鍙�" clearable size="small"
+              @keyup.enter.native="addStandardTree"></el-input>
           </el-col>
         </el-row>
       </div>
       <span slot="footer" class="dialog-footer">
         <el-button @click="addDia = false">鍙� 娑�</el-button>
-        <el-button :loading="addLoad" type="primary" @click="addStandardTree"
-          >纭� 瀹�</el-button
-        >
+        <el-button type="primary" @click="addStandardTree" :loading="addLoad">纭� 瀹�</el-button>
       </span>
     </el-dialog>
-    <el-dialog :visible.sync="updateDia" title="鍒嗙被淇敼" width="400px">
-      <div class="body">
-        <el-row style="line-height: 50px">
-          <el-col :span="6" style="text-align: right">
-            <span class="required-span">* </span>鍨嬪彿锛�
-          </el-col>
-          <el-col :offset="1" :span="16">
-            <el-input
-              v-model="addOb.model"
-              clearable
-              placeholder="璇疯緭鍏ュ瀷鍙�"
-              size="small"
-              @keyup.enter.native="updateStandardTree"
-            ></el-input>
-          </el-col>
-        </el-row>
-      </div>
-      <span slot="footer" class="dialog-footer">
-        <el-button @click="updateDia = false">鍙� 娑�</el-button>
-        <el-button
-          :loading="updateLoad"
-          type="primary"
-          @click="updateStandardTree"
-          >纭� 瀹�</el-button
-        >
-      </span>
-    </el-dialog>
-    <el-dialog
-      :visible.sync="moreEdit"
-      class="more-edit"
-      title="鎵归噺缂栬緫"
-      width="90%"
-    >
-      <div
-        class="body"
-        style="display: flex; flex-direction: column; height: 85vh"
-      >
+    <el-dialog title="鎵归噺缂栬緫" top="5vh" :visible.sync="moreEdit" width="90%" class="more-edit">
+      <div class="body" style="display: flex; flex-direction: column; height: 85vh">
         <div class="search">
           <div class="search-item">
             <el-row style="width: 25%; margin-bottom: 16px">
               <el-col :span="6" style="text-align: right">
                 <!-- <span class="required-span">* </span> -->
-                瑕佹眰鍊硷細</el-col
-              >
+                瑕佹眰鍊硷細</el-col>
               <el-col :span="16">
-                <el-input
-                  v-model="moreInfo.ask"
-                  :disabled="moreSelects.length == 0"
-                  clearable
-                  size="small"
-                ></el-input>
+                <el-input size="small" v-model="moreInfo.ask" clearable :disabled="moreSelects.length == 0"></el-input>
               </el-col>
             </el-row>
             <el-row style="width: 25%; margin-bottom: 16px">
               <el-col :span="6" style="text-align: right">
                 <!-- <span class="required-span">* </span> -->
-                瑕佹眰鎻忚堪锛�</el-col
-              >
-              <el-col
-                :span="16"
-                style="display: flex; align-items: flex-start; height: 100%"
-              >
-                <el-input
-                  v-model="moreInfo.tell"
-                  :autosize="{ minRows: 1, maxRows: 3 }"
-                  :disabled="moreSelects.length == 0"
-                  clearable
-                  size="small"
-                  type="textarea"
-                ></el-input>
+                瑕佹眰鎻忚堪锛�</el-col>
+              <el-col :span="16" style="display: flex; align-items: flex-start; height: 100%">
+                <el-input size="small" clearable type="textarea" :autosize="{ minRows: 1, maxRows: 3 }"
+                  v-model="moreInfo.tell" :disabled="moreSelects.length == 0"></el-input>
               </el-col>
             </el-row>
             <el-row style="width: 25%; margin-bottom: 16px">
               <el-col :span="6" style="text-align: right">
                 <!-- <span class="required-span">* </span> -->
-                璇曢獙鏂规硶锛�</el-col
-              >
+                璇曢獙鏂规硶锛�</el-col>
               <el-col :span="16">
-                <el-select
-                  v-model="moreInfo.methodS"
-                  :disabled="moreSelects.length == 0"
-                  clearable
-                  filterable
-                  size="small"
-                  style="width: 100%"
-                >
-                  <el-option
-                    v-for="(a, ai) in methodList"
-                    :key="ai"
-                    :label="a.label"
-                    :value="a.value"
-                  ></el-option>
+                <el-select v-model="moreInfo.methodS" size="small" filterable style="width: 100%"
+                  :disabled="moreSelects.length == 0" clearable>
+                  <el-option v-for="(a, ai) in methodList" :key="ai" :label="a.label" :value="a.value"></el-option>
                 </el-select>
               </el-col>
             </el-row>
             <el-row style="width: 25%; margin-bottom: 16px">
               <el-col :span="6" style="text-align: right">
                 <!-- <span class="required-span">* </span> -->
-                鍗曚环(鍏�)锛�</el-col
-              >
+                鍗曚环(鍏�)锛�</el-col>
               <el-col :span="16">
-                <el-input
-                  v-model="moreInfo.price"
-                  :disabled="moreSelects.length == 0"
-                  clearable
-                  size="small"
-                ></el-input>
+                <el-input size="small" v-model="moreInfo.price" clearable
+                  :disabled="moreSelects.length == 0"></el-input>
               </el-col>
             </el-row>
             <el-row style="width: 25%">
               <el-col :span="6" style="text-align: right">
                 <!-- <span class="required-span">* </span> -->
-                宸ユ椂绯绘暟锛�</el-col
-              >
+                宸ユ椂绯绘暟锛�</el-col>
               <el-col :span="16">
-                <el-input
-                  v-model="moreInfo.manHour"
-                  :disabled="moreSelects.length == 0"
-                  clearable
-                  size="small"
-                ></el-input>
+                <el-input size="small" v-model="moreInfo.manHour" clearable
+                  :disabled="moreSelects.length == 0"></el-input>
               </el-col>
             </el-row>
             <el-row style="width: 25%">
               <el-col :span="6" style="text-align: right">
                 <!-- <span class="required-span">* </span> -->
-                妯℃澘锛�</el-col
-              >
+                妯℃澘锛�</el-col>
               <el-col :span="16">
-                <el-select
-                  v-model="moreInfo.templateId"
-                  :disabled="moreSelects.length == 0"
-                  filterable
-                  placeholder="妯℃澘"
-                  size="small"
-                  style="width: 100%"
-                >
-                  <el-option
-                    v-for="(a, ai) in templateList"
-                    :key="ai"
-                    :label="a.name"
-                    :value="a.id"
-                  ></el-option>
+                <el-select v-model="moreInfo.templateId" size="small" filterable placeholder="妯℃澘" style="width: 100%"
+                  :disabled="moreSelects.length == 0">
+                  <el-option v-for="(a, ai) in templateList" :key="ai" :label="a.name" :value="a.id"></el-option>
                 </el-select>
               </el-col>
             </el-row>
             <el-row style="width: 25%">
               <el-col :span="6" style="text-align: right"> 鏄惁鍚敤锛�</el-col>
               <el-col :span="16">
-                <el-select
-                  v-model="moreInfo.state"
-                  :disabled="moreSelects.length == 0"
-                  clearable
-                  filterable
-                  placeholder="妯℃澘"
-                  size="small"
-                  style="width: 100%"
-                >
-                  <el-option :value="1" label="鍚敤"></el-option>
-                  <el-option :value="0" label="涓嶅惎鐢�"></el-option>
+                <el-select v-model="moreInfo.state" size="small" filterable placeholder="鏄惁鍚敤" style="width: 100%"
+                  :disabled="moreSelects.length == 0" clearable>
+                  <el-option label="鍚敤" :value="1"></el-option>
+                  <el-option label="涓嶅惎鐢�" :value="0"></el-option>
                 </el-select>
               </el-col>
             </el-row>
             <el-row style="width: 100%; margin-top: 8px">
-              <el-col
-                :span="24"
-                style="display: flex; align-items: center; justify-content: end"
-              >
-                <el-button size="small" type="danger" @click="clearProduct(1)"
-                  >閲嶇疆鍗曚环</el-button
-                >
-                <el-button size="small" type="danger" @click="clearProduct(2)"
-                  >閲嶇疆宸ユ椂绯绘暟</el-button
-                >
-                <el-button
-                  size="small"
-                  type="primary"
-                  @click="sectionUp(moreSelects)"
-                  >璁剧疆鍖洪棿</el-button
-                >
-                <el-button size="small" @click="moreEdit = false"
-                  >鍙� 娑�</el-button
-                >
-                <el-button
-                  :loading="moreEditLoad"
-                  size="small"
-                  type="primary"
-                  @click="subMoreEdit"
-                  >淇� 瀛�</el-button
-                >
+              <el-col :span="24" style="display: flex; align-items: center; justify-content: flex-end">
+                <el-button @click="clearProduct(1)" size="small" type="danger">閲嶇疆鍗曚环</el-button>
+                <el-button @click="clearProduct(2)" size="small" type="danger">閲嶇疆宸ユ椂绯绘暟</el-button>
+                <el-button type="primary" size="small" @click="sectionUp(moreSelects)">璁剧疆鍖洪棿</el-button>
+                <el-button @click="moreEdit = false" size="small">鍙� 娑�</el-button>
+                <el-button type="primary" @click="subMoreEdit" :loading="moreEditLoad" size="small">淇� 瀛�</el-button>
               </el-col>
             </el-row>
           </div>
         </div>
-        <div v-loading="productTableLoading0" style="flex: 1; overflow-y: auto">
-          <el-table
-            ref="productTable0"
-            :data="productList0"
-            :fit="true"
-            :row-key="(row) => row.id"
-            border
-            header-row-class-name="header-class"
-            height="96%"
-            highlight-current-row
-            stripe
-            style="width: 100%"
-            tooltip-effect="dark"
-            @select="handleSelectionChange0"
-            @select-all="handleSelectAll0"
-            @filter-change="filterHandler"
-          >
+        <div style="flex: 1; overflow-y: auto" v-loading="productTableLoading0">
+          <el-table :data="productList0" ref="productTable0" style="width: 100%" height="96%" tooltip-effect="dark"
+            stripe :fit="true" border @select-all="handleSelectAll0" @select="handleSelectionChange0"
+            header-row-class-name="header-class" :row-key="(row) => row.id" @filter-change="filterHandler"
+            highlight-current-row>
             <el-table-column type="selection" width="50"> </el-table-column>
-            <el-table-column
-              label="浜у搧"
-              min-width="100"
-              prop="sample"
-              show-overflow-tooltip
-            ></el-table-column>
-            <el-table-column
-              label="鍨嬪彿"
-              min-width="100"
-              prop="model"
-              show-overflow-tooltip
-            ></el-table-column>
-            <el-table-column
-              :filter-multiple="false"
-              :filters="filters0"
-              column-key="inspectionItem"
-              filter-placement="bottom-start"
-              label="妫�楠岄」"
-              min-width="140"
-              prop="inspectionItem"
-              show-overflow-tooltip
-            ></el-table-column>
-            <el-table-column
-              :filter-multiple="false"
-              :filters="filters1"
-              column-key="inspectionItemSubclass"
-              filter-placement="bottom-start"
-              label="妫�楠岄」瀛愰」"
-              min-width="140"
-              prop="inspectionItemSubclass"
-              show-overflow-tooltip
-            ></el-table-column>
-            <el-table-column
-              :filter-multiple="false"
-              :filters="filters"
-              column-key="sonLaboratory"
-              filter-placement="bottom-start"
-              label="瀛愬疄楠屽"
-              prop="sonLaboratory"
-              show-overflow-tooltip
-              width="130"
-            ></el-table-column>
-            <el-table-column
-              label="瑕佹眰鍊�"
-              min-width="200px"
-              prop="ask"
-            ></el-table-column>
-            <el-table-column
-              label="瑕佹眰鎻忚堪"
-              min-width="220px"
-              prop="tell"
-            ></el-table-column>
-            <el-table-column
-              label="璇曢獙鏂规硶"
-              prop="methodS"
-              width="200"
-            ></el-table-column>
-            <el-table-column
-              label="鏉′欢"
-              prop="radius"
-              width="200"
-            ></el-table-column>
-            <el-table-column
-              label="璁¢噺鍗曚綅"
-              prop="unit"
-              show-overflow-tooltip
-              width="100"
-            ></el-table-column>
-            <el-table-column
-              label="鍗曚环(鍏�)"
-              prop="price"
-              width="120"
-            ></el-table-column>
-            <el-table-column
-              label="宸ユ椂绯绘暟"
-              prop="manHour"
-              width="120"
-            ></el-table-column>
-            <el-table-column
-              label="宸ユ椂鍒嗙粍"
-              prop="manHourGroup"
-              show-overflow-tooltip
-              width="100"
-            ></el-table-column>
-            <el-table-column label="妯℃澘" prop="templateId" width="200">
+            <el-table-column prop="sample" label="浜у搧" min-width="100" show-overflow-tooltip></el-table-column>
+            <el-table-column prop="model" label="鍨嬪彿" min-width="100" show-overflow-tooltip></el-table-column>
+            <el-table-column prop="inspectionItem" label="妫�楠岄」" min-width="140" show-overflow-tooltip :filters="filters0"
+              :filter-multiple="false" column-key="inspectionItem" filter-placement="bottom-start"></el-table-column>
+            <el-table-column prop="inspectionItemSubclass" label="妫�楠岄」瀛愰」" min-width="140" show-overflow-tooltip
+              :filters="filters1" :filter-multiple="false" column-key="inspectionItemSubclass"
+              filter-placement="bottom-start"></el-table-column>
+            <el-table-column prop="sonLaboratory" label="瀛愬疄楠屽" width="130" show-overflow-tooltip
+              :filters="dict.type.sys_sub_lab" :filter-multiple="false" column-key="sonLaboratory"
+              filter-placement="bottom-start"></el-table-column>
+            <el-table-column prop="ask" label="瑕佹眰鍊�" min-width="200px"></el-table-column>
+            <el-table-column prop="tell" label="瑕佹眰鎻忚堪" min-width="220px"></el-table-column>
+            <el-table-column prop="methodS" label="璇曢獙鏂规硶" width="200"></el-table-column>
+            <el-table-column prop="unit" label="璁¢噺鍗曚綅" width="100" show-overflow-tooltip></el-table-column>
+            <el-table-column prop="price" label="鍗曚环(鍏�)" width="120"></el-table-column>
+            <el-table-column prop="manHour" label="宸ユ椂绯绘暟" width="120"></el-table-column>
+            <el-table-column prop="manHourGroup" label="宸ユ椂鍒嗙粍" width="100" show-overflow-tooltip></el-table-column>
+            <el-table-column prop="templateId" label="妯℃澘" width="200">
               <template slot-scope="scope">
                 {{
                   templateList.find((item) => item.id == scope.row.templateId)
                     ? templateList.find(
-                        (item) => item.id == scope.row.templateId
-                      ).name
+                      (item) => item.id == scope.row.templateId
+                    ).name
                     : ""
                 }}
               </template>
             </el-table-column>
-            <el-table-column
-              label="鍖洪棿"
-              prop="section"
-              show-overflow-tooltip
-              width="120"
-            ></el-table-column>
+            <el-table-column prop="section" label="鍖洪棿" width="120" show-overflow-tooltip></el-table-column>
           </el-table>
-          <el-pagination
-            :current-page="currentPage0"
-            :page-size="100"
-            :total="total0"
-            layout="total, prev, pager, next, jumper"
-            style="position: absolute; right: 16px; bottom: 4px"
-            @current-change="handleCurrentChange0"
-          >
+          <el-pagination style="position: absolute; right: 16px; bottom: 4px" @current-change="handleCurrentChange0"
+            :current-page="currentPage0" layout="total, prev, pager, next, jumper" :page-size="100" :total="total0">
           </el-pagination>
         </div>
       </div>
     </el-dialog>
-    <el-dialog
-      :close-on-click-modal="false"
-      :visible.sync="sectionUpDia"
-      title="鍖洪棿璁剧疆"
-      width="80%"
-    >
+    <el-dialog title="鍖洪棿璁剧疆" :visible.sync="sectionUpDia" width="70%" :close-on-click-modal="false">
+      <div style="width: 100%; text-align: left">
+        <el-button id="copyBtn" v-if="sectionList.length > 0" :data-clipboard-text="JSON.stringify(sectionList)"
+          type="primary" size="mini" @click="copySectionConfig">澶嶅埗鍖洪棿璁剧疆</el-button>
+        <el-button type="primary" size="mini" @click="openImportSectionsConfig">瀵煎叆鍖洪棿璁剧疆</el-button>
+        <el-dialog :visible.sync="importSectionsConfigDia" width="30%" title="瀵煎叆鍖洪棿閰嶇疆">
+          <el-input type="textarea" :rows="3" v-model="sectionsConfigText"></el-input>
+          <span slot="footer" class="dialog-footer">
+            <el-button @click="importSectionsConfigDia = false">鍙� 娑�</el-button>
+            <el-button type="primary" @click="confirmImportConfig">纭</el-button>
+          </span>
+        </el-dialog>
+      </div>
       <div class="body" style="padding: 5px 0">
-        <el-table :data="sectionList" border height="350px" style="width: 100%">
-          <el-table-column align="center" label="搴忓彿" type="index" width="70">
+        <el-table :data="sectionList" border style="width: 100%" height="350px">
+          <el-table-column type="index" label="搴忓彿" width="70" align="center">
           </el-table-column>
-          <el-table-column align="center" label="鍖洪棿">
+          <el-table-column label="鍖洪棿" align="center">
             <template slot-scope="scope">
-              <el-input
-                v-model="scope.row.thing"
-                clearable
-                placeholder="鍖洪棿"
-                size="small"
-              ></el-input>
+              <el-input size="small" v-model="scope.row.thing" clearable placeholder="鍖洪棿"></el-input>
             </template>
           </el-table-column>
-          <el-table-column align="center" label="鑺暟">
+          <el-table-column label="瑕佹眰鍊�" align="center">
             <template slot-scope="scope">
-              <el-input
-                v-model="scope.row.cores"
-                clearable
-                placeholder="鑺暟"
-                size="small"
-              ></el-input>
+              <el-input size="small" v-model="scope.row.ask" clearable placeholder="瑕佹眰鍊�"></el-input>
             </template>
           </el-table-column>
-          <el-table-column align="center" label="瑕佹眰鍊�">
+          <el-table-column label="瑕佹眰鎻忚堪" align="center">
             <template slot-scope="scope">
-              <el-input
-                v-model="scope.row.ask"
-                clearable
-                placeholder="瑕佹眰鍊�"
-                size="small"
-              ></el-input>
+              <el-input size="small" placeholder="瑕佹眰鎻忚堪" v-model="scope.row.tell" clearable type="textarea"
+                :autosize="{ minRows: 1, maxRows: 2 }"></el-input>
             </template>
           </el-table-column>
-          <el-table-column align="center" label="瑕佹眰鎻忚堪">
+          <el-table-column label="鍗曚环" align="center" width="120">
             <template slot-scope="scope">
-              <el-input
-                v-model="scope.row.tell"
-                :autosize="{ minRows: 1, maxRows: 2 }"
-                clearable
-                placeholder="瑕佹眰鎻忚堪"
-                size="small"
-                type="textarea"
-              ></el-input>
+              <el-input size="small" v-model="scope.row.price" clearable placeholder="鍗曚环"></el-input>
             </template>
           </el-table-column>
-          <el-table-column align="center" label="瀵间綋鏉愯川">
+          <el-table-column label="宸ユ椂绯绘暟" align="center" width="120">
             <template slot-scope="scope">
-              <el-input
-                v-model="scope.row.conductorMaterial"
-                clearable
-                placeholder="瀵间綋鏉愯川"
-                size="small"
-              ></el-input>
+              <el-input size="small" v-model="scope.row.manHour" clearable placeholder="宸ユ椂绯绘暟"></el-input>
             </template>
           </el-table-column>
-          <el-table-column align="center" label="瀵间綋绫诲瀷">
+          <el-table-column label="鎿嶄綔" width="70" align="center">
             <template slot-scope="scope">
-              <el-input
-                v-model="scope.row.conductorType"
-                clearable
-                placeholder="瀵间綋绫诲瀷"
-                size="small"
-              ></el-input>
-            </template>
-          </el-table-column>
-          <!--          <el-table-column align="center" label="鍗曚环" width="120">-->
-          <!--            <template slot-scope="scope">-->
-          <!--              <el-input v-model="scope.row.price" clearable placeholder="鍗曚环" size="small"></el-input>-->
-          <!--            </template>-->
-          <!--          </el-table-column>-->
-          <!--          <el-table-column align="center" label="宸ユ椂绯绘暟" width="120">-->
-          <!--            <template slot-scope="scope">-->
-          <!--              <el-input v-model="scope.row.manHour" clearable placeholder="宸ユ椂绯绘暟" size="small"></el-input>-->
-          <!--            </template>-->
-          <!--          </el-table-column>-->
-          <el-table-column align="center" label="鎿嶄綔" width="70">
-            <template slot-scope="scope">
-              <el-button
-                circle
-                icon="el-icon-minus"
-                size="mini"
-                type="danger"
-                @click="sectionList.splice(scope.$index, 1)"
-              ></el-button>
+              <el-button size="mini" type="danger" icon="el-icon-minus" circle
+                @click="sectionList.splice(scope.$index, 1)"></el-button>
             </template>
           </el-table-column>
         </el-table>
       </div>
       <span slot="footer" class="dialog-footer">
         <el-button @click="sectionUpDia = false">鍙� 娑�</el-button>
-        <el-button :loading="sectionLoad" type="primary" @click="sectionLoadAdd"
-          >淇� 瀛�</el-button
-        >
-        <el-button
-          icon="el-icon-plus"
-          type="primary"
-          @click="sectionList.push({ thing: '' })"
-        ></el-button>
+        <el-button type="primary" @click="sectionLoadAdd" :loading="sectionLoad">淇� 瀛�</el-button>
+        <el-button type="primary" @click="
+          sectionList.push({
+            thing: '',
+            price: sectionRow.price,
+            manHour: sectionRow.manHour,
+          })
+          " icon="el-icon-plus"></el-button>
       </span>
     </el-dialog>
-    <el-dialog :visible.sync="uploadDia" title="鏁版嵁瀵煎叆" width="500px">
+    <el-dialog title="鏁版嵁瀵煎叆" :visible.sync="uploadDia" width="500px">
       <div style="margin: 0 auto">
-        <el-upload
-          ref="upload"
-          :action="
-            VUE_APP_BASE_API + '/standardTree/inExcelOfTree/' + isEquipment
-          "
-          :auto-upload="false"
-          :file-list="fileList"
-          :headers="token"
-          :limit="1"
-          :on-change="beforeUpload"
-          :on-error="onError"
-          :on-success="onSuccess"
-          accept=".xlsx"
-          drag
-          name="file"
-        >
+        <el-upload ref="upload" drag :action="javaApi + '/standardTree/inExcelOfTree' + '/' + 'false'
+          " :headers="uploadHeader" :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 :loading="uploading" type="primary" @click="submitUpload()"
-          >涓� 浼�</el-button
-        >
+        <el-button type="primary" @click="submitUpload()" :loading="uploading">涓� 浼�</el-button>
       </span>
     </el-dialog>
-    <!-- <bindSupplierDensityDialogAsk v-if="bindSupplierDensityDialog"
-                               :bindSupplierDensityDialog="bindSupplierDensityDialog"
-                               :currentRow="currentSupplierDensityRow"
-                               @closeBindPartDialog="closeBindSupplierDensityDialog"></bindSupplierDensityDialogAsk> -->
-    <!-- <BatchCopy v-if="batchCopyDia" ref="BatchCopy" :selectTree1="selectTree"
-               :standardId="standardId" @refreshList="refreshList"></BatchCopy> -->
   </div>
 </template>
 
 <script>
-import Sortable from "sortablejs";
-import draggable from "vuedraggable";
+import Clipboard from "../../../../public/js/clipboard.min.js";
 import {
-  updateTreeSort,
-  resetTreeDragBatch,
   delStandardTree,
   selectStandardTreeList,
   obtainItemParameterList,
@@ -1104,41 +580,27 @@
   selectStandardMethods,
   addStandardMethodList,
   addStandardTree,
-  updateStandardTree,
-  selectsStandardMethodByFLSSM,
   upStandardProductList,
   delStandardMethodByFLSSM,
   delStandardProductByIds,
-  addStandardProduct,
   selectStandardProductListByMethodId,
-  updateSection,
-  upStandardProducts,
   getStandardTemplate,
-  selectStandardProductByMethodId,
-  selectStandardProductEnumByMethodId,
   resetTreeOfPrice,
   resetTreeOfHour,
-} from "@/api/standard/standardLibrary";
-import { checkPermi } from "@/utils/permission"; // 鏉冮檺鍒ゆ柇鍑芥暟
-//   import bindSupplierDensityDialogAsk from "../do/a5-capacity-scope/bindSupplierDensityDialogAsk.vue";
-//   import BatchCopy from "../do/a5-capacity-scope/BatchCopy.vue";
+  selectsStandardMethodByFLSSM,
+} from '@/api/standard/standardLibrary.js'
+
 export default {
-  components: {
-    //   BatchCopy,
-    //   bindSupplierDensityDialogAsk,
-    draggable,
-  },
-  dicts: ["sys_factory", "sys_sub_lab", "sys_samp_type"],
+  dicts: ['sys_sub_lab'],
   data() {
     return {
-      tableKey: "productList",
+      importSectionsConfigDia: false,
+      sectionsConfigText: "", //瀵煎叆鐨勫尯闂撮厤缃枃鏈�
       search: null,
       list: [],
       selectTree: "",
-      factory: [],
+      // factory: [],
       addDia: false,
-      updateDia: false, // 淇敼鏍戝悕瀛楀脊妗�
-      oldModel: "",
       addOb: {
         factory: null,
         laboratory: null,
@@ -1148,26 +610,30 @@
       },
       laboratory: [],
       addLoad: false,
-      updateLoad: false,
-      sampleType: [],
+      // sampleType: [],
       sample: [],
       treeLoad: false,
-      addPower: false,
+      addPower: true,
       standardList: [],
       standardEnum: [],
       addStandardDia: false,
+      standardId: null,
+      addStandardMethod: true,
       addLoad2: false,
       productList: [],
-      productTableLoading: false,
       tableLoad: false,
       tableLoad2: false,
+      upStandardProduct: false,
+      delStandardMethod: false,
       selects: [],
+      delStandardProduct: false,
       addProductDia: false,
       productId: null,
+      addStandardProduct: false,
       addLoad3: false,
       productEnum: [],
       expandedKeys: [],
-      filters: [],
+      // filters: [],
       sectionUpDia: false,
       sectionLoad: false,
       sectionRow: null,
@@ -1200,17 +666,10 @@
       inspectionItemSubclass: null,
       sonLaboratory: null,
       uploadDia: false,
-      token: null,
       fileList: [],
+      inExcelOfTreePower: true,
       uploading: false,
-      isEquipment: true,
-      isHaveChildren: {},
-      sortTable: null,
-      currentSupplierDensityRow: {}, // 閫夋嫨闆朵欢缁戝畾鏈潯鏁版嵁鐨勪俊鎭�
-      bindSupplierDensityDialog: false,
-      isShowCopy: false,
-      batchCopyDia: false,
-      VUE_APP_BASE_API: process.env.VUE_APP_BASE_API,
+      isEquipment: false,
     };
   },
   watch: {
@@ -1232,105 +691,73 @@
     },
   },
   mounted() {
-    this.selectEnumByCategoryForFactory();
+    // this.getPower();
+    // this.selectEnumByCategoryForFactory();
     this.selectStandardTreeList();
     this.obtainItemParameterList();
+    // this.selectEnumByCategoryForsampleType()
     this.selectTestObjectByName();
     this.selectStandardMethods();
-    this.selectEnumByCategoryForSonLaboratory();
+    // this.selectEnumByCategoryForDevice();
+    // this.selectEnumByCategory();
+    // this.selectEnumByCategoryForValue();
+    // this.selectEnumByCategoryForSpecial();
+    // this.selectEnumByCategoryForInspectionValueType();
+    // this.selectEnumByCategoryForSonLaboratory();
     this.getStandardTemplate();
-    this.selectStandardMethodsSec();
-    this.token = {
-      token: sessionStorage.getItem("token"),
-    };
+    this.selectStandardMethods();
   },
   methods: {
-    checkPermi,
-    // 淇敼鏈�瀛愮骇鍚嶅瓧
-    editTreeName(info) {
-      this.updateDia = true;
-      this.oldModel = info.label;
-    },
-    // 鎷栨嫿鏃跺垽瀹氱洰鏍囪妭鐐硅兘鍚﹁鏀剧疆
-    // 'prev'銆�'inner' 鍜� 'next'锛屽墠銆佹彃鍏ャ�佸悗
-    allowDrop(draggingNode, dropNode, type) {
-      if (draggingNode.level !== 3) return;
-      if (draggingNode.data.level === dropNode.data.level) {
-        if (draggingNode.data.parentId === dropNode.data.parentId) {
-          return type === "prev" || type === "next";
-        } else {
-          return false;
-        }
-      } else {
-        // 涓嶅悓绾ц繘琛屽鐞�
-        return false;
-      }
-    },
-    // tree鎷栨嫿鎴愬姛瀹屾垚鏃惰Е鍙戠殑浜嬩欢
-    handleDrop(draggingNode, dropNode, dropType, ev) {
-      try {
-        this.treeLoad = true;
-        updateTreeSort(this.list).then((res) => {
-          if (res.code === 200) {
-            this.$message.success("鎿嶄綔鎴愬姛");
+    confirmImportConfig() { },
+    openImportSectionsConfig() {
+      // this.importSectionsConfigDia = true
+      this.$confirm("纭瀵煎叆澶嶅埗鐨勫尯闂撮厤缃�?", "鎻愮ず", {
+        confirmButtonText: "纭畾",
+        cancelButtonText: "鍙栨秷",
+        type: "warning",
+      })
+        .then(() => {
+          if (
+            this.sectionsConfigText == null ||
+            this.sectionsConfigText == "" ||
+            this.sectionsConfigText == undefined
+          ) {
+            this.$message.error("鏈瘑鍒埌鍓垏鏉跨殑鏈夋晥鏂囨湰");
+            return;
+          } else {
+            let parseConfig = JSON.parse(this.sectionsConfigText);
+            if (!Array.isArray(parseConfig)) {
+              this.$message.error("閿欒鐨勬暟鎹牸寮�");
+              return;
+            }
+            parseConfig.forEach((ele) => {
+              this.sectionList.push(ele);
+            });
+            this.$message.success("瀵煎叆鎴愬姛");
           }
-          this.treeLoad = false;
-        });
-      } catch (e) {
-        this.treeLoad = false;
-        console.log("e----", e);
-      }
+        })
+        .catch(() => { });
     },
-    rowDrop(methodId) {
-      const that = this;
-      const tbody = document.querySelector(
-        "#templateParamTable .el-table__body-wrapper tbody"
-      );
-      if (!this.sortTable) {
-        this.sortTable = Sortable.create(tbody, {
-          animation: 200, //鍔ㄧ敾鏃堕暱
-          handle: ".el-table__row", //鍙嫋鎷藉尯鍩焎lass
-          //鎷栨嫿涓簨浠�
-          onMove: ({ dragged, related }) => {
-            const oldRow = that.productList[dragged.rowIndex]; //鏃т綅缃暟鎹�
-            const newRow = that.productList[related.rowIndex]; //琚嫋鎷界殑鏂版暟鎹�
-          },
-          //鎷栨嫿缁撴潫浜嬩欢
-          onEnd: (evt) => {
-            const curRow = that.productList.splice(evt.oldIndex, 1)[0]; // 褰撳墠琚嫋鎷界殑淇℃伅
-            that.productList.splice(evt.newIndex, 0, curRow);
-            let arr = [];
-            this.productList.forEach((item, index) => {
-              const obj = Object.assign({
-                sort: index,
-                id: item.id,
-              });
-              arr.push(obj);
-            });
-            this.productTableLoading = true;
-            // 鎷栨嫿瀹屾垚鍚庝紶缁欏悗绔繚瀛樻暟鎹�
-            resetTreeDragBatch({ params: arr }).then((res) => {
-              if (res.code === 200) {
-                this.$message.success("淇濆瓨鎴愬姛");
-              }
-              this.productTableLoading = false;
-            });
-          },
-        });
-      }
-    },
-    hasChildWithId(nodes, name) {
-      for (let node of nodes) {
-        const comName = node.label + node.code;
-        if (comName == name) {
-          //鍒ゆ柇閫掑綊缁撴潫鏉′欢
-          this.isHaveChildren = node;
-          return node;
-        } else if (node.children && node.children.length > 0) {
-          //鍒ゆ柇children鏄惁鏈夋暟鎹�
-          this.hasChildWithId(node.children, name); //閫掑綊璋冪敤
-        }
-      }
+    //澶嶅埗鍖洪棿閰嶇疆
+    copySectionConfig() {
+      // 鍒涘缓 clipboard 瀹炰緥,鑾峰彇鎸夐挳鍏冪礌
+      let clipboard = new Clipboard("#copyBtn");
+      /* 娉ㄦ剰姝や簨浠剁洃鍚槸寮傛鐨� */
+      clipboard.on("success", (e) => {
+        this.sectionsConfigText = e.text;
+        e.clearSelection();
+        // 閲婃斁鍐呭瓨
+        clipboard.destroy();
+        // 澶嶅埗鎴愬姛鎻愮ず
+        this.$message.success("宸插鍒跺埌鍓创鏉�");
+      });
+      // 澶嶅埗澶辫触
+      clipboard.on("error", (e) => {
+        // 閲婃斁鍐呭瓨
+        clipboard.destroy();
+        // 澶嶅埗澶辫触鎻愮ず
+        this.$message.error("澶嶅埗澶辫触");
+      });
     },
     filterNode(value, data) {
       if (!value) return true;
@@ -1344,11 +771,6 @@
     },
     handleNodeClick(val, node, el) {
       //鏍戠殑鍊�
-      if (node.childNodes.length === 0) {
-        this.isShowCopy = true;
-      } else {
-        this.isShowCopy = false;
-      }
       this.total = 0;
       this.currentPage = 1;
       this.selectTree = "";
@@ -1360,9 +782,7 @@
         data2 += " - " + data[index];
       }
       this.selectTree = data2.replace(" - ", "");
-      if (node.childNodes.length === 0) {
-        this.selectsStandardMethodByFLSSM();
-      }
+      this.selectsStandardMethodByFLSSM();
       let trees = this.selectTree.split(" - ");
       this.addOb.factory = trees[0];
       this.addOb.laboratory = trees[1];
@@ -1394,17 +814,18 @@
             data2 += " - " + data[index];
           }
           this.selectTree = data2.replace(" - ", "");
-          delStandardTree({ tree: this.selectTree }).then((res) => {
+          delStandardTree({ tree: this.selectTre }).then((res) => {
             if (res.code == 201) return;
             this.$message.success("宸插垹闄�");
             let arr = this.selectTree.split(" - ");
             this.deleteStandard(this.list, arr[arr.length - 1]);
+            // this.selectStandardTreeList()
             this.selectTree = "";
             this.standardList = [];
             this.productList = [];
           });
         })
-        .catch((e) => {});
+        .catch((e) => { });
     },
     deleteStandard(arr, label) {
       arr.forEach((item, index) => {
@@ -1415,37 +836,85 @@
         }
       });
     },
-    nodeOpen(data, node, el) {
-      $($(el.$el).find(".node_i")[0]).attr(
-        "class",
-        "node_i el-icon-folder-opened"
-      );
-    },
-    nodeClose(data, node, el) {
-      $($(el.$el).find(".node_i")[0]).attr("class", "node_i el-icon-folder");
-    },
-    selectEnumByCategoryForFactory() {
-      this.getConfigKey("sys_factory").then((response) => {
-        this.factory = response.msg;
-      });
-    },
-    selectEnumByCategoryForSonLaboratory() {
-      let arr = [];
-      this.getConfigKey("sys_sub_lab").then((response) => {
-        arr = response.msg;
-      });
-      arr.forEach((a) => {
-        this.filters.push({
-          text: a.label,
-          value: a.value,
-        });
-      });
-    },
-    selectEnumByCategoryForsampleType() {
-      this.getConfigKey("sys_samp_type").then((response) => {
-        this.sampleType = response.msg;
-      });
-    },
+    // selectEnumByCategoryForFactory() {
+    //   this.$axios
+    //     .post(this.$api.enums.selectEnumByCategory, {
+    //       category: "宸ュ巶",
+    //     })
+    //     .then((res) => {
+    //       this.factory = res.data;
+    //     });
+    // },
+    // selectEnumByCategoryForSonLaboratory() {
+    //   this.$axios
+    //     .post(this.$api.enums.selectEnumByCategory, {
+    //       category: "瀛愬疄楠屽",
+    //     })
+    //     .then((res) => {
+    //       this.factory = [];
+    //       res.data.forEach((a) => {
+    //         this.filters.push({
+    //           text: a.label,
+    //           value: a.value,
+    //         });
+    //       });
+    //     });
+    // },
+    // selectEnumByCategoryForsampleType() {
+    //   this.$axios
+    //     .post(this.$api.enums.selectEnumByCategory, {
+    //       category: "鏍峰搧澶х被",
+    //     })
+    //     .then((res) => {
+    //       this.sampleType = res.data;
+    //     });
+    // },
+    // selectEnumByCategoryForDevice() {
+    //   this.$axios
+    //     .post(this.$api.enums.selectEnumByCategory, {
+    //       category: "璁惧鍒嗙被",
+    //     })
+    //     .then((res) => {
+    //       this.componentData.tagField.deviceGroup.select = res.data;
+    //     });
+    // },
+    // selectEnumByCategory() {
+    //   this.$axios
+    //     .post(this.$api.enums.selectEnumByCategory, {
+    //       category: "妫�楠岄」绫诲瀷",
+    //     })
+    //     .then((res) => {
+    //       res.data[1].type = "info";
+    //       this.componentData.tagField.inspectionItemType.select = res.data;
+    //     });
+    // },
+    // selectEnumByCategoryForValue() {
+    //   this.$axios
+    //     .post(this.$api.enums.selectEnumByCategory, {
+    //       category: "鍙栧�肩被鍨�",
+    //     })
+    //     .then((res) => {
+    //       this.componentData.tagField.valueType.select = res.data;
+    //     });
+    // },
+    // selectEnumByCategoryForSpecial() {
+    //   this.$axios
+    //     .post(this.$api.enums.selectEnumByCategory, {
+    //       category: "鏄惁",
+    //     })
+    //     .then((res) => {
+    //       this.componentData.tagField.bsm.select = res.data;
+    //     });
+    // },
+    // selectEnumByCategoryForInspectionValueType() {
+    //   this.$axios
+    //     .post(this.$api.enums.selectEnumByCategory, {
+    //       category: "妫�楠屽�肩被鍨�",
+    //     })
+    //     .then((res) => {
+    //       this.componentData.tagField.inspectionValueType.select = res.data;
+    //     });
+    // },
     selectStandardTreeList() {
       this.treeLoad = true;
       selectStandardTreeList().then((res) => {
@@ -1508,7 +977,6 @@
         this.selectsStandardMethodByFLSSM();
       });
     },
-    // 鎻愪氦鍒嗙被娣诲姞
     addStandardTree() {
       if (this.addOb.sampleType == null || this.addOb.sampleType == "") {
         this.$message.error("瀵硅薄涓嶅瓨鍦�");
@@ -1519,73 +987,92 @@
         return;
       }
       this.addLoad = true;
-      addStandardTree(this.addOb)
-        .then((res) => {
-          if (res.code === 201) {
-            this.addLoad = false;
-            return;
-          }
-          this.$message.success("娣诲姞鎴愬姛");
-          this.addDia = false;
-          this.list
-            .find((a) => a.label == this.addOb.factory)
-            .children.find((a) => a.label == this.addOb.laboratory)
-            .children.find((a) => a.label == this.addOb.sampleType)
-            .children.find((a) => a.label == this.addOb.sample)
-            .children.push({
-              code: "[5]",
-              label: this.addOb.model,
-              value: this.addOb.model,
-            });
+      addStandardTree(this.addOb).then((res) => {
+        if (res.code === 201) {
           this.addLoad = false;
-        })
+          return;
+        }
+        this.$message.success("娣诲姞鎴愬姛");
+        this.addDia = false;
+        this.list
+          .find((a) => a.label == this.addOb.factory)
+          .children.find((a) => a.label == this.addOb.laboratory)
+          .children.find((a) => a.label == this.addOb.sampleType)
+          .children.find((a) => a.label == this.addOb.sample)
+          .children.push({
+            code: "[5]",
+            label: this.addOb.model,
+            value: this.addOb.model,
+          });
+        this.addLoad = false;
+        this.$tab.refreshPage();
+
+      })
         .catch((e) => {
           this.addDia = false;
           this.addLoad = false;
-        });
-    },
-    // 淇敼鍨嬪彿
-    updateStandardTree() {
-      if (this.addOb.sampleType == null || this.addOb.sampleType == "") {
-        this.$message.error("瀵硅薄涓嶅瓨鍦�");
-        return;
-      }
-      if (this.addOb.model == null || this.addOb.model == "") {
-        this.$message.error("璇峰~鍐欏瀷鍙�");
-        return;
-      }
-      this.addOb.oldModel = this.oldModel;
-      this.updateLoad = true;
-      updateStandardTree(this.addOb)
-        .then((res) => {
-          if (res.code === 201) {
-            this.updateLoad = false;
-            return;
-          }
-          this.$message.success("娣诲姞鎴愬姛");
-          this.selectStandardTreeList();
-          this.updateDia = false;
-          this.updateLoad = false;
-        })
-        .catch((e) => {
-          this.updateDia = false;
-          this.updateLoad = false;
         });
     },
     selectsStandardMethodByFLSSM() {
       this.tableLoad = true;
       selectsStandardMethodByFLSSM({
         tree: this.selectTree,
-      }).then((res) => {
-        this.tableLoad = false;
-        this.standardList = res.data.standardMethodList;
-        if (this.standardList && this.standardList.length > 0) {
-          this.$refs.standard.setCurrentRow(this.standardList[0]);
-          this.rowClick(this.standardList[0]);
-        } else {
-          this.productList = [];
+      })
+        .then((res) => {
+          this.tableLoad = false;
+          this.standardList = res.data.standardMethodList;
+          if (this.standardList && this.standardList.length > 0) {
+            this.$refs.standard.setCurrentRow(this.standardList[0]);
+            this.rowClick(this.standardList[0]);
+          } else {
+            this.productList = [];
+          }
+        });
+    },
+    getPower() {
+      let power = JSON.parse(sessionStorage.getItem("power"));
+      let add = false;
+      let addStandardMethod = false;
+      let upStandardProduct = false;
+      let delStandardMethod = false;
+      let delStandardProduct = false;
+      let addStandardProduct = false;
+      let delStandardTree = false;
+      let inExcelOfTreePower = false;
+      for (var i = 0; i < power.length; i++) {
+        if (power[i].menuMethod == "addStandardTree") {
+          add = true;
         }
-      });
+        if (power[i].menuMethod == "addStandardMethodList") {
+          addStandardMethod = true;
+        }
+        if (power[i].menuMethod == "upStandardProductList") {
+          upStandardProduct = true;
+        }
+        if (power[i].menuMethod == "delStandardMethodByFLSSM") {
+          delStandardMethod = true;
+        }
+        if (power[i].menuMethod == "delStandardProductByIds") {
+          delStandardProduct = true;
+        }
+        if (power[i].menuMethod == "addStandardProduct") {
+          addStandardProduct = true;
+        }
+        if (power[i].menuMethod == "delStandardTree") {
+          delStandardTree = true;
+        }
+        if (power[i].menuMethod == "inExcelOfTree") {
+          inExcelOfTreePower = true;
+        }
+      }
+      this.addPower = add;
+      this.addStandardMethod = addStandardMethod;
+      this.upStandardProduct = upStandardProduct;
+      this.delStandardMethod = delStandardMethod;
+      this.delStandardProduct = delStandardProduct;
+      this.addStandardProduct = addStandardProduct;
+      this.delStandardTree = delStandardTree;
+      this.inExcelOfTreePower = inExcelOfTreePower;
     },
     upStandardProductList(value, index) {
       upStandardProductList({
@@ -1607,43 +1094,29 @@
           id: index,
           tell: value,
         }),
-      }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
-        this.$message.success("宸蹭繚瀛�");
-      });
+      })
+        .then((res) => {
+          if (res.code == 201) {
+            this.$message.error("鏈繚瀛�");
+            return;
+          }
+          this.$message.success("宸蹭繚瀛�");
+        });
     },
-    // 鏍囧噯搴撻�夋嫨瀹為獙鏂规硶鐨勫洖璋�
     upStandardProductListOfMethodS(value, index) {
       upStandardProductList({
         str: JSON.stringify({
           id: index,
           methodS: value,
         }),
-      }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
-        this.$message.success("宸蹭繚瀛�");
-      });
-    },
-    // 鏍囧噯搴撻�夋嫨鏉′欢鐨勫洖璋�
-    upStandardProductListOfRadius(value, index) {
-      upStandardProductList({
-        str: JSON.stringify({
-          id: index,
-          radius: value,
-        }),
-      }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
-        this.$message.success("宸蹭繚瀛�");
-      });
+      })
+        .then((res) => {
+          if (res.code == 201) {
+            this.$message.error("鏈繚瀛�");
+            return;
+          }
+          // this.$message.success('宸蹭繚瀛�')
+        });
     },
     upStandardProductListOfPrice(value, index) {
       upStandardProductList({
@@ -1651,13 +1124,14 @@
           id: index,
           price: value,
         }),
-      }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
-        this.$message.success("宸蹭繚瀛�");
-      });
+      })
+        .then((res) => {
+          if (res.code == 201) {
+            this.$message.error("鏈繚瀛�");
+            return;
+          }
+          // this.$message.success('宸蹭繚瀛�')
+        });
     },
     upStandardProductListOfManHour(value, index) {
       upStandardProductList({
@@ -1665,13 +1139,14 @@
           id: index,
           manHour: value,
         }),
-      }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
-        this.$message.success("宸蹭繚瀛�");
-      });
+      })
+        .then((res) => {
+          if (res.code == 201) {
+            this.$message.error("鏈繚瀛�");
+            return;
+          }
+          // this.$message.success('宸蹭繚瀛�')
+        });
     },
     upStandardProductListOfTemplate(value, index) {
       upStandardProductList({
@@ -1679,13 +1154,14 @@
           id: index,
           templateId: value,
         }),
-      }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
-        this.$message.success("宸蹭繚瀛�");
-      });
+      })
+        .then((res) => {
+          if (res.code == 201) {
+            this.$message.error("鏈繚瀛�");
+            return;
+          }
+          // this.$message.success('宸蹭繚瀛�')
+        });
     },
     delStandardMethodByFLSSM(id) {
       this.$confirm("鏄惁鍒犻櫎褰撳墠鏁版嵁?", "璀﹀憡", {
@@ -1695,7 +1171,7 @@
       })
         .then(() => {
           this.tableLoad = true;
-          delStandardMethodByFLSSM({ id: id }).then((res) => {
+          delStandardMethodByFLSSM({ id: id, }).then((res) => {
             if (res.code == 201) {
               return;
             }
@@ -1703,7 +1179,7 @@
             this.selectsStandardMethodByFLSSM();
           });
         })
-        .catch(() => {});
+        .catch(() => { });
     },
     handleSelectionChange(val) {
       this.selects = [];
@@ -1737,40 +1213,33 @@
             this.selectsStandardMethodByFLSSM();
           });
         })
-        .catch(() => {});
+        .catch(() => { });
     },
-    addStandardProductDo() {
-      let selects = this.$refs.ValueTable.multipleSelection;
-      if (selects.length == 0) {
-        this.$message.error("鏈�夋嫨鏁版嵁");
-        return;
-      }
-      let select = [];
-      selects.forEach((a) => {
-        select.push(a.id);
-      });
-      this.tableLoad = true;
-      addStandardProduct({
-        ids: JSON.stringify(select),
-        tree: this.selectTree,
-      }).then((res) => {
-        if (res.code == 201) {
-          return;
-        }
-        this.$message.success("娣诲姞鎴愬姛");
-        this.selectsStandardMethodByFLSSM();
-      });
-      this.addProductDia = false;
-    },
-    refreshList() {
-      this.batchCopyDia = false;
-      const index = this.standardList.findIndex(
-        (item) => item.id == this.standardId
-      );
-      if (index > -1) {
-        this.rowClick(this.standardList[index]);
-      }
-    },
+    // addStandardProductDo() {
+    //   let selects = this.$refs.ValueTable.multipleSelection;
+    //   if (selects.length == 0) {
+    //     this.$message.error("鏈�夋嫨鏁版嵁");
+    //     return;
+    //   }
+    //   let select = [];
+    //   selects.forEach((a) => {
+    //     select.push(a.id);
+    //   });
+    //   this.tableLoad = true;
+    //   this.$axios
+    //     .post(this.$api.standardTree.addStandardProduct, {
+    //       ids: JSON.stringify(select),
+    //       tree: this.selectTree,
+    //     })
+    //     .then((res) => {
+    //       if (res.code == 201) {
+    //         return;
+    //       }
+    //       this.$message.success("娣诲姞鎴愬姛");
+    //       this.selectsStandardMethodByFLSSM();
+    //     });
+    //   this.addProductDia = false;
+    // },
     rowClick(row, column, event) {
       this.currentPage = 1;
       this.tableLoad2 = true;
@@ -1788,31 +1257,6 @@
           });
         }, 300);
         this.tableLoad2 = false;
-        const tree = this.selectTree.split(" - ");
-        // 閫夋嫨鏈�鍚庝竴灞傛爲鎵嶅彲浠ユ嫋鎷芥帓搴�
-        if (tree.length === 4) {
-          const name = tree[3] + "[4]";
-          this.hasChildWithId(this.list, name);
-          if (
-            this.isHaveChildren.children &&
-            this.isHaveChildren.children.length > 0
-          ) {
-            if (this.sortTable) {
-              this.sortTable.destroy();
-              this.sortTable = null;
-            }
-            return;
-          }
-        } else if (tree.length < 4) {
-          if (this.sortTable) {
-            this.sortTable.destroy();
-            this.sortTable = null;
-          }
-          return;
-        }
-        this.$nextTick(() => {
-          this.rowDrop(row.id);
-        });
       });
     },
     toggleSelection(row) {
@@ -1876,7 +1320,6 @@
         });
       }
     },
-    // 璁剧疆鍖洪棿
     sectionUp(row) {
       if (Array.isArray(row)) {
         // 鍊兼槸涓�涓暟缁�
@@ -1893,106 +1336,66 @@
         this.sectionList = [];
         if (this.sectionRow.section != null && this.sectionRow.section != "") {
           JSON.parse(this.sectionRow.section).forEach((a, ai) => {
-            if (this.sectionRow.cores !== null) {
-              this.sectionList.push({
-                thing: a,
-                ask: JSON.parse(this.sectionRow.ask)[ai],
-                tell: JSON.parse(this.sectionRow.tell)[ai],
-                // price: JSON.parse(this.sectionRow.price)[ai],
-                // manHour: JSON.parse(this.sectionRow.manHour)[ai],
-                cores: JSON.parse(this.sectionRow.cores)[ai],
-                conductorMaterial:
-                  this.sectionRow.conductorMaterial &&
-                  JSON.parse(this.sectionRow.conductorMaterial)[ai],
-                conductorType:
-                  this.sectionRow.conductorType &&
-                  JSON.parse(this.sectionRow.conductorType)[ai],
-              });
-            } else {
-              this.sectionList.push({
-                thing: a,
-                ask: JSON.parse(this.sectionRow.ask)[ai],
-                tell: JSON.parse(this.sectionRow.tell)[ai],
-                // price: JSON.parse(this.sectionRow.price)[ai],
-                // manHour: JSON.parse(this.sectionRow.manHour)[ai],
-                conductorMaterial:
-                  this.sectionRow.conductorMaterial &&
-                  JSON.parse(this.sectionRow.conductorMaterial)[ai],
-                conductorType:
-                  this.sectionRow.conductorType &&
-                  JSON.parse(this.sectionRow.conductorType)[ai],
-              });
-            }
+            this.sectionList.push({
+              thing: a,
+              ask: JSON.parse(this.sectionRow.ask)[ai],
+              tell: JSON.parse(this.sectionRow.tell)[ai],
+              price: JSON.parse(this.sectionRow.price)[ai],
+              manHour: JSON.parse(this.sectionRow.manHour)[ai],
+            });
           });
         }
       }
     },
-    // 鎻愪氦鍖洪棿鎵�濉殑鏁版嵁
     sectionLoadAdd() {
       let sectionList = [];
       let askList = [];
       let tellList = [];
       let priceList = [];
       let manHourList = [];
-      let coresList = [];
-      let conductorMaterialList = [];
-      let conductorTypeList = [];
       this.sectionList.forEach((a) => {
         if (a.thing !== "") {
           sectionList.push(a.thing);
           askList.push(a.ask);
           tellList.push(a.tell);
-          // priceList.push(a.price)
-          // manHourList.push(a.manHour)
-          coresList.push(a.cores);
-          conductorMaterialList.push(a.conductorMaterial);
-          conductorTypeList.push(a.conductorType);
+          priceList.push(a.price);
+          manHourList.push(a.manHour);
         }
       });
       if (sectionList.length === 0) {
         this.sectionRow.section = null;
         this.sectionRow.ask = null;
         this.sectionRow.tell = null;
-        // this.sectionRow.price = null
-        // this.sectionRow.manHour = null
-        this.sectionRow.cores = null;
-        this.sectionRow.conductorMaterial = null;
-        this.sectionRow.conductorType = null;
+        this.sectionRow.price = null;
+        this.sectionRow.manHour = null;
       } else {
         this.sectionRow.section = JSON.stringify(sectionList);
         this.sectionRow.ask = JSON.stringify(askList);
         this.sectionRow.tell = JSON.stringify(tellList);
-        // this.sectionRow.price = JSON.stringify(priceList)
-        // this.sectionRow.manHour = JSON.stringify(manHourList)
-        this.sectionRow.cores = JSON.stringify(coresList);
-        this.sectionRow.conductorMaterial = JSON.stringify(
-          conductorMaterialList
-        );
-        this.sectionRow.conductorType = JSON.stringify(conductorTypeList);
+        this.sectionRow.price = JSON.stringify(priceList);
+        this.sectionRow.manHour = JSON.stringify(manHourList);
       }
       this.sectionLoad = true;
       if (this.moreSelects.length === 0) {
-        updateSection({
+        upStandardProductList({
           str: JSON.stringify({
             id: this.sectionRow.id,
             section: this.sectionRow.section,
             ask: this.sectionRow.ask,
             tell: this.sectionRow.tell,
-            // price: this.sectionRow.price,
-            // manHour: this.sectionRow.manHour,
-            cores: this.sectionRow.cores,
-            conductorMaterial: this.sectionRow.conductorMaterial,
-            conductorType: this.sectionRow.conductorType,
+            price: this.sectionRow.price,
+            manHour: this.sectionRow.manHour,
           }),
-        }).then((res) => {
-          this.sectionLoad = false;
-          if (res.code == 201) {
-            this.$message.error("鏈繚瀛�");
-            return;
-          }
-          this.$message.success("宸蹭繚瀛�");
-          this.sectionUpDia = false;
-        });
+        })
+          .then((res) => {
+            this.sectionLoad = false;
+            if (res.code == 201) {
+              this.$message.error("鏈繚瀛�");
+              return;
+            }
+            this.$message.success("宸蹭繚瀛�");
+            this.sectionUpDia = false;
+          });
       } else {
         upStandardProducts({
           ids: JSON.stringify(this.moreSelects.map((a) => a.id)),
@@ -2000,11 +1403,8 @@
             section: this.sectionRow.section,
             ask: this.sectionRow.ask,
             tell: this.sectionRow.tell,
-            // price: this.sectionRow.price,
-            // manHour: this.sectionRow.manHour,
-            cores: this.sectionRow.cores,
-            conductorMaterial: this.sectionRow.conductorMaterial,
-            conductorType: this.sectionRow.conductorType,
+            price: this.sectionRow.price,
+            manHour: this.sectionRow.manHour,
           },
         }).then((res) => {
           this.sectionLoad = false;
@@ -2021,17 +1421,6 @@
           });
         });
       }
-    },
-    bindSupplierDensitySecond(row) {
-      this.bindSupplierDensity(row);
-    },
-    // 鎵撳紑鍘傚缁戝畾寮规
-    bindSupplierDensity(row) {
-      this.currentSupplierDensityRow = row;
-      this.bindSupplierDensityDialog = true;
-    },
-    closeBindSupplierDensityDialog() {
-      this.bindSupplierDensityDialog = false;
     },
     getStandardTemplate() {
       getStandardTemplate().then((res) => {
@@ -2055,12 +1444,6 @@
         this.tableLoad2 = false;
       });
     },
-    openCopyDia() {
-      this.batchCopyDia = true;
-      this.$nextTick(() => {
-        this.$refs.BatchCopy.getList();
-      });
-    },
     async handleMore() {
       if (
         (!this.standardId && this.standardId != 0) ||
@@ -2071,7 +1454,7 @@
       await this.getList();
       this.moreEdit = true;
     },
-    selectStandardMethodsSec() {
+    selectStandardMethods() {
       selectStandardMethods().then((res) => {
         let data = [];
         res.data.forEach((a) => {
@@ -2096,7 +1479,7 @@
       upStandardProducts({
         ids: JSON.stringify(this.moreSelects.map((a) => a.id)),
         standardProductList: this.moreInfo,
-      }).then((res) => {
+      },).then((res) => {
         this.moreEditLoad = false;
         if (res.code == 201) {
           this.$message.error("鏈繚瀛�");
@@ -2108,6 +1491,14 @@
         this.rowClick({
           id: this.standardId,
         });
+        // this.moreInfo = {
+        //   ask:'',
+        //   tell:'',
+        //   methodS:'',
+        //   price:'',
+        //   manHour:'',
+        //   templateId:''
+        // }
       });
     },
     handleSelectAll0(rows) {
@@ -2140,22 +1531,23 @@
         laboratory: this.sonLaboratory,
         items: this.inspectionItemSubclass,
         item: this.inspectionItem,
-      }).then((res) => {
-        this.productList0 = res.data.records;
-        this.total0 = res.data.total;
-        this.productTableLoading0 = false;
-        this.page = res.data.pages;
-        this.$nextTick(() => {
-          this.productList0.forEach((a, i) => {
-            if (this.moreSelects.find((b) => a.id == b.id)) {
-              this.$refs.productTable0.toggleRowSelection(
-                this.productList0[i],
-                true
-              );
-            }
+      })
+        .then((res) => {
+          this.productList0 = res.data.records;
+          this.total0 = res.data.total;
+          this.productTableLoading0 = false;
+          this.page = res.data.pages;
+          this.$nextTick(() => {
+            this.productList0.forEach((a, i) => {
+              if (this.moreSelects.find((b) => a.id == b.id)) {
+                this.$refs.productTable0.toggleRowSelection(
+                  this.productList0[i],
+                  true
+                );
+              }
+            });
           });
         });
-      });
     },
     handleCurrentChange0(e) {
       this.currentPage0 = e;
@@ -2166,24 +1558,25 @@
         id: this.standardId,
         tree: this.selectTree,
         item: this.inspectionItem,
-      }).then((res) => {
-        this.filters0 = [];
-        this.filters1 = [];
-        res.data.item.forEach((a) => {
-          this.filters0.push({
-            text: a.inspectionItem,
-            value: a.inspectionItem,
+      })
+        .then((res) => {
+          this.filters0 = [];
+          this.filters1 = [];
+          res.data.item.forEach((a) => {
+            this.filters0.push({
+              text: a.inspectionItem,
+              value: a.inspectionItem,
+            });
+          });
+          res.data.items.forEach((a) => {
+            if (a != null) {
+              this.filters1.push({
+                text: a.inspectionItemSubclass,
+                value: a.inspectionItemSubclass,
+              });
+            }
           });
         });
-        res.data.items.forEach((a) => {
-          if (a != null) {
-            this.filters1.push({
-              text: a.inspectionItemSubclass,
-              value: a.inspectionItemSubclass,
-            });
-          }
-        });
-      });
     },
     beforeUpload(file, fileList) {
       if (
@@ -2247,20 +1640,21 @@
             resetTreeOfHour({
               tree: this.selectTree,
               standardId: this.standardId,
-            }).then((res) => {
-              if (res.code == 201) {
-                return;
-              }
-              this.$message.success("宸叉竻绌�");
-              this.currentPage0 = 1;
-              this.getList();
-              this.rowClick({
-                id: this.standardId,
+            })
+              .then((res) => {
+                if (res.code == 201) {
+                  return;
+                }
+                this.$message.success("宸叉竻绌�");
+                this.currentPage0 = 1;
+                this.getList();
+                this.rowClick({
+                  id: this.standardId,
+                });
               });
-            });
           }
         })
-        .catch(() => {});
+        .catch(() => { });
     },
   },
 };

--
Gitblit v1.9.3