From e5454b769d44a34af423bf87ac8a740bf8c20341 Mon Sep 17 00:00:00 2001
From: Crunchy <3114200645@qq.com>
Date: 星期二, 29 四月 2025 13:25:29 +0800
Subject: [PATCH] Merge branch 'dev' into dev_tides

---
 src/views/standard/standardLibrary/index.vue | 1603 +++++++++++++----------------------------------------------
 1 files changed, 355 insertions(+), 1,248 deletions(-)

diff --git a/src/views/standard/standardLibrary/index.vue b/src/views/standard/standardLibrary/index.vue
index 2f0e756..d9855a5 100644
--- a/src/views/standard/standardLibrary/index.vue
+++ b/src/views/standard/standardLibrary/index.vue
@@ -1,299 +1,52 @@
-<style scoped>
-.standard {
-  padding: 10px 0;
-  display: flex;
-}
-
-.left {
-  width: 330px;
-  height: calc(100% - 40px - 10px);
-  background-color: white;
-  padding: 15px;
-}
-
-.custom-tree-node {
-  width: 100%;
-  line-height: 32px;
-}
-
-.custom-tree-node .el-icon-delete {
-  color: #3a7bfa;
-  opacity: 0;
-  font-size: 18px;
-}
-
-.custom-tree-node:hover .el-icon-delete {
-  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;
-}
-
-.right {
-  margin-left: 5px;
-  width: calc(100% - 365px);
-  height: calc(100% - 40px);
-}
-
-.right .title {
-  height: 34px;
-  line-height: 34px;
-  padding: 0 10px;
-  background-color: white;
-}
-
-.standard_table {
-  border-top: 1px solid #ebeef5;
-  background-color: white;
-}
-
-.product_table {
-  border-top: 1px solid #ebeef5;
-  height: calc(100% - 235px);
-  margin-top: 5px;
-  background-color: white;
-  user-select: none;
-}
-
-.product_table .el-table {
-  height: calc(100% - 35px) !important;
-}
-
-.sort {
-  width: 80% !important;
-  overflow: hidden;
-}
-
->>> .el-table__body-wrapper {
-  height: calc(100% - 46px) !important;
-}
-
->>> .header-class {
-  height: 40px !important;
-}
-
->>> .header-class th.el-table__cell > .cell {
-  line-height: 20px !important;
-  padding-top: 0 !important;
-  padding-bottom: 0 !important;
-}
-
->>> .el-table__row {
-  height: 35px !important;
-}
-
-.search {
-  border-bottom: 1px solid #ebeef5;
-  margin-bottom: 16px;
-  display: flex;
-  align-items: center;
-  box-sizing: border-box;
-  padding-bottom: 10px;
-}
-
-.search-item {
-  display: flex;
-  align-items: center;
-  flex-wrap: wrap;
-}
-
-.search-item .el-row {
-  display: flex;
-  align-items: center;
-}
-
-.search-item .el-col {
-  margin-left: 0;
-}
-
-.more-edit .dialog-footer {
-  position: absolute;
-  top: 15px;
-  right: 70px;
-}
-
->>> .is-disabled .el-textarea__inner {
-  background: rgba(0, 0, 0, 0.05) !important;
-}
->>> .el-table__body-wrapper::-webkit-scrollbar {
-  height: 14px; /* 璁剧疆婊氬姩鏉″搴� */
-}
-</style>
-<style>
-.standard .el-tree-node__content {
-  height: 32px;
-  font-size: 14px;
-  border-radius: 2px;
-}
-
-.standard
-  .el-tree--highlight-current
-  .el-tree-node.is-current
-  > .el-tree-node__content {
-  color: #3a7bfa;
-}
-
-.standard .has-gutter .el-table__cell .cell {
-  line-height: 34px;
-  background-color: #f8f8f8;
-}
-
-.standard .has-gutter .el-table__cell {
-  background-color: #fafafa !important;
-}
-
-.standard .standard_table .el-table__row .cell {
-  font-size: 14px;
-}
-
-.standard .el-table .warning-row .cell {
-  color: #bababa;
-}
-
-.standard .el-table-filter__list {
-  max-height: 400px;
-  overflow-y: auto;
-}
-
-.standard .el-upload {
-  width: 100%;
-}
-
-.standard .el-upload-dragger {
-  width: 100%;
-}
-
-.standard .handleBtn.is-disabled .el-upload:focus {
-  color: #c0c4cc !important;
-}
-
-.standard .avatar-uploader .el-upload {
-  height: 80px;
-  display: flex;
-  align-items: center;
-  justify-content: center;
-}
-</style>
-
 <template>
   <div class="standard">
     <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 v-model="search" clearable placeholder="杈撳叆鍏抽敭瀛楄繘琛屾悳绱�" size="small" style="margin-bottom: 5px"
+            suffix-icon="el-icon-search" @blur="searchFilter" @clear="searchFilter"></el-input>
         </el-col>
-        <el-col
-          v-if="checkPermi(['system: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 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>
       </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 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="
           height: calc(100% - 30px);
           overflow-y: scroll;
           scrollbar-width: none;
-        "
-        @node-click="handleNodeClick"
-        @node-expand="nodeOpen"
-        @node-collapse="nodeClose"
-        @node-drop="handleDrop"
-      >
+        " @node-click="handleNodeClick"
+               @node-drop="handleDrop">
         <div slot-scope="{ node, data }" class="custom-tree-node">
           <el-row style="width: 100%">
-            <el-col
-              :class="{ sort: node.level > 3 }"
-              :span="19"
-              :title="data.label"
-              style="text-align: left"
-            >
+            <el-col :class="{ sort: node.level > 3 }" :span="19" :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([
-                  'system: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)"
-              >
+            <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="editTreeName(node.data)">
                 <i class="el-icon-edit"></i>
               </el-button>
             </el-col>
-            <el-col
-              v-if="
-                checkPermi([
-                  'system: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 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)">
                 <i class="el-icon-delete"></i>
               </el-button>
             </el-col>
@@ -307,313 +60,134 @@
           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-button v-if="isShowCopy" size="small" style="position: absolute; right: 20px; top: 1px" type="primary"
+            @click="openCopyDia">鎵归噺澶嶅埗</el-button>
         </el-col>
       </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-table ref="standard" :data="standardList" class="el-table" header-row-class-name="header-class" height="220"
+                  :header-cell-style="{ background: '#f8f8f9', color: '#515a6e' }" border
+          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">
             <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 label="鏍囧噯鍚嶇О" prop="name" show-overflow-tooltip></el-table-column>
+          <el-table-column label="澶囨敞" prop="remark" 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-table id="templateParamTable" ref="productTable" v-loading="productTableLoading" :data="productList"
+                  :header-cell-style="{ background: '#f8f8f9', color: '#515a6e' }" border
+          :fit="true" :row-class-name="tableRowClassName" 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-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="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">
             <template slot-scope="scope">
-              <el-input
-                v-if="
-                  checkPermi([
-                    'system: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 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>
               <span v-else>{{ scope.row.ask }}</span>
             </template>
           </el-table-column>
           <el-table-column label="瑕佹眰鎻忚堪" min-width="220px" prop="tell">
             <template slot-scope="scope">
-              <el-input
-                v-if="
-                  checkPermi([
-                    'system: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 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>
               <span v-else>{{ scope.row.ask }}</span>
             </template>
           </el-table-column>
           <el-table-column label="璇曢獙鏂规硶" prop="method" width="200">
             <template slot-scope="scope">
-              <el-select
-                v-if="
-                  checkPermi([
-                    'system: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-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>
               <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 label="鏉′欢" min-width="140" prop="radius" show-overflow-tooltip>
             <template slot-scope="scope">
-              <el-select
-                v-if="
-                  checkPermi([
-                    'system: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 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="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([
-                    'system:standard:standardLibrary:upStandardProduct',
-                  ])
-                "
-                v-model="scope.row.price"
-                placeholder="鍗曚环(鍏�)"
-                size="small"
-                @change="
-                  (value) => upStandardProductListOfPrice(value, scope.row.id)
-                "
-              >
+              <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>
               <span v-else>{{ scope.row.price }}</span>
             </template>
           </el-table-column>
           <el-table-column label="宸ユ椂绯绘暟" prop="manHour" width="120">
             <template slot-scope="scope">
-              <el-input
-                v-if="
-                  checkPermi([
-                    'system:standard:standardLibrary:upStandardProduct',
-                  ])
-                "
-                v-model="scope.row.manHour"
-                placeholder="鍗曚环(鍏�)"
-                size="small"
-                @change="
-                  (value) => upStandardProductListOfManHour(value, scope.row.id)
-                "
-              >
+              <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>
               <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="manHourGroup" show-overflow-tooltip width="100"></el-table-column>
           <el-table-column label="妯℃澘" prop="templateId" width="200">
             <template slot-scope="scope">
-              <el-select
-                v-model="scope.row.templateId"
-                :disabled="
-                  !checkPermi([
-                    'system: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" :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>
             </template>
           </el-table-column>
-          <el-table-column
-            label="鍖洪棿"
-            prop="section"
-            show-overflow-tooltip
-            width="120"
-          ></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">
             <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)" :disabled="!checkPermi(['standard:standardLibrary:upStandardProduct'])
+                ">鍖洪棿璁剧疆</el-button>
+              <el-button type="text" :disabled="!checkPermi(['standard:standardLibrary:upStandardProduct'])
+                " @click="bindSupplierDensitySecond(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>
+        <!-- <el-pagination :current-page="currentPage" :page-size="300" :total="total" layout="total"
+          style="position: absolute; right: 16px; bottom: 1px" @current-change="handleCurrentChange">
+        </el-pagination> -->
+        <p style="text-align: right;margin-right: 20px;color: #333;">鍏眥{ total }}鏉�</p>
       </el-row>
     </div>
+
     <el-dialog :visible.sync="addDia" title="鍒嗙被娣诲姞" width="400px">
       <div class="body">
         <el-row style="line-height: 50px">
@@ -621,21 +195,14 @@
             <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-input v-model="addOb.model" clearable placeholder="璇疯緭鍏ュ瀷鍙�" 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 :loading="addLoad" type="primary" @click="addStandardTree">纭� 瀹�</el-button>
       </span>
     </el-dialog>
     <el-dialog :visible.sync="updateDia" title="鍒嗙被淇敼" width="400px">
@@ -645,395 +212,51 @@
             <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-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
-        >
+        <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"
-      >
-        <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 :span="16">
-                <el-input
-                  v-model="moreInfo.ask"
-                  :disabled="moreSelects.length == 0"
-                  clearable
-                  size="small"
-                ></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-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">
-                <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>
-              </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">
-                <el-input
-                  v-model="moreInfo.price"
-                  :disabled="moreSelects.length == 0"
-                  clearable
-                  size="small"
-                ></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 :span="16">
-                <el-input
-                  v-model="moreInfo.manHour"
-                  :disabled="moreSelects.length == 0"
-                  clearable
-                  size="small"
-                ></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 :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>
-              </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>
-              </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>
-            </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"
-          >
-            <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">
-              <template slot-scope="scope">
-                {{
-                  templateList.find((item) => item.id == scope.row.templateId)
-                    ? templateList.find(
-                        (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>
-          <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>
-        </div>
-      </div>
-    </el-dialog>
-    <el-dialog
-      :close-on-click-modal="false"
-      :visible.sync="sectionUpDia"
-      title="鍖洪棿璁剧疆"
-      width="80%"
-    >
+    <el-dialog :close-on-click-modal="false" :visible.sync="sectionUpDia" title="鍖洪棿璁剧疆" width="80%">
       <div class="body" style="padding: 5px 0">
-        <el-table :data="sectionList" border height="350px" style="width: 100%">
+        <el-table :data="sectionList" border height="350px" style="width: 100%"
+                  :header-cell-style="{ background: '#f8f8f9', color: '#515a6e' }">
           <el-table-column align="center" label="搴忓彿" type="index" width="70">
           </el-table-column>
           <el-table-column align="center" label="鍖洪棿">
             <template slot-scope="scope">
-              <el-input
-                v-model="scope.row.thing"
-                clearable
-                placeholder="鍖洪棿"
-                size="small"
-              ></el-input>
+              <el-input v-model="scope.row.thing" clearable placeholder="鍖洪棿" size="small"></el-input>
             </template>
           </el-table-column>
           <el-table-column align="center" label="鑺暟">
             <template slot-scope="scope">
-              <el-input
-                v-model="scope.row.cores"
-                clearable
-                placeholder="鑺暟"
-                size="small"
-              ></el-input>
+              <el-input v-model="scope.row.cores" clearable placeholder="鑺暟" size="small"></el-input>
             </template>
           </el-table-column>
           <el-table-column align="center" label="瑕佹眰鍊�">
             <template slot-scope="scope">
-              <el-input
-                v-model="scope.row.ask"
-                clearable
-                placeholder="瑕佹眰鍊�"
-                size="small"
-              ></el-input>
+              <el-input v-model="scope.row.ask" clearable placeholder="瑕佹眰鍊�" size="small"></el-input>
             </template>
           </el-table-column>
           <el-table-column align="center" label="瑕佹眰鎻忚堪">
             <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 v-model="scope.row.tell" :autosize="{ minRows: 1, maxRows: 2 }" clearable placeholder="瑕佹眰鎻忚堪"
+                size="small" type="textarea"></el-input>
             </template>
           </el-table-column>
           <el-table-column align="center" label="瀵间綋鏉愯川">
             <template slot-scope="scope">
-              <el-input
-                v-model="scope.row.conductorMaterial"
-                clearable
-                placeholder="瀵间綋鏉愯川"
-                size="small"
-              ></el-input>
+              <el-input v-model="scope.row.conductorMaterial" clearable placeholder="瀵间綋鏉愯川" size="small"></el-input>
             </template>
           </el-table-column>
           <el-table-column align="center" label="瀵间綋绫诲瀷">
             <template slot-scope="scope">
-              <el-input
-                v-model="scope.row.conductorType"
-                clearable
-                placeholder="瀵间綋绫诲瀷"
-                size="small"
-              ></el-input>
+              <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">-->
@@ -1048,64 +271,24 @@
           <!--          </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 circle icon="el-icon-minus" size="mini" type="danger"
+                @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 :loading="sectionLoad" type="primary" @click="sectionLoadAdd">淇� 瀛�</el-button>
+        <el-button icon="el-icon-plus" type="primary" @click="sectionList.push({ thing: '' })"></el-button>
       </span>
     </el-dialog>
-    <el-dialog :visible.sync="uploadDia" title="鏁版嵁瀵煎叆" 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"
-        >
-          <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
-        >
-      </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> -->
+    <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>
 
@@ -1120,30 +303,24 @@
   obtainItemParameterList,
   selectTestObjectByName,
   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";
+import bindSupplierDensityDialogAsk from "./components/bindSupplierDensityDialogAsk.vue";
+import BatchCopy from "./components/BatchCopy.vue";
 export default {
+  name: 'StandardLibrary',
   components: {
-    //   BatchCopy,
-    //   bindSupplierDensityDialogAsk,
+    BatchCopy,
+    bindSupplierDensityDialogAsk,
     draggable,
   },
   dicts: ["sys_factory", "sys_sub_lab", "sys_samp_type"],
@@ -1194,21 +371,9 @@
       total: 0,
       currentPage: 1,
       standardId: 0,
-      moreEdit: false,
-      moreEditLoad: false,
-      moreSelects: [],
       total0: 0,
       currentPage0: 1,
       productList0: [],
-      moreInfo: {
-        ask: "",
-        tell: "",
-        methodS: "",
-        price: "",
-        manHour: "",
-        templateId: "",
-        state: null,
-      },
       methodList: [],
       productTableLoading0: false,
       filters0: [],
@@ -1217,7 +382,6 @@
       inspectionItem: null,
       inspectionItemSubclass: null,
       sonLaboratory: null,
-      uploadDia: false,
       token: null,
       fileList: [],
       uploading: false,
@@ -1229,25 +393,8 @@
       isShowCopy: false,
       batchCopyDia: false,
       VUE_APP_BASE_API: process.env.VUE_APP_BASE_API,
+      moreSelects: [],
     };
-  },
-  watch: {
-    moreEdit(val) {
-      if (!val) {
-        this.$refs.productTable0.clearSelection();
-        this.moreSelects = [];
-        this.currentPage0 = 1;
-        this.productList0 = [];
-        this.moreInfo = {
-          ask: "",
-          tell: "",
-          methodS: "",
-          price: "",
-          manHour: "",
-          templateId: "",
-        };
-      }
-    },
   },
   mounted() {
     this.selectEnumByCategoryForFactory();
@@ -1256,6 +403,7 @@
     this.selectTestObjectByName();
     this.selectStandardMethods();
     this.selectEnumByCategoryForSonLaboratory();
+    this.selectEnumByCategoryForsampleType();
     this.getStandardTemplate();
     this.selectStandardMethodsSec();
     this.token = {
@@ -1263,7 +411,6 @@
     };
   },
   methods: {
-    checkPermi,
     // 淇敼鏈�瀛愮骇鍚嶅瓧
     editTreeName(info) {
       this.updateDia = true;
@@ -1350,10 +497,42 @@
         }
       }
     },
-    filterNode(value, data) {
-      if (!value) return true;
-      return data.label.indexOf(value) !== -1;
+    // 璋冪敤tree杩囨护鏂规硶 涓枃鑻辫繃婊�
+    filterNode (value, data, node) {
+      if (!value) {銆�銆�銆�銆�//濡傛灉鏁版嵁涓虹┖锛屽垯杩斿洖true,鏄剧ず鎵�鏈夌殑鏁版嵁椤�
+        return true
+      }
+      // 鏌ヨ鍒楄〃鏄惁鏈夊尮閰嶆暟鎹紝灏嗗�煎皬鍐欙紝鍖归厤鑻辨枃鏁版嵁
+      let val = value.toLowerCase()
+      return this.chooseNode(val, data, node) // 璋冪敤杩囨护浜屽眰鏂规硶
     },
+    // 杩囨护鐖惰妭鐐� / 瀛愯妭鐐� (濡傛灉杈撳叆鐨勫弬鏁版槸鐖惰妭鐐逛笖鑳藉尮閰嶏紝鍒欒繑鍥炶鑺傜偣浠ュ強鍏朵笅鐨勬墍鏈夊瓙鑺傜偣锛涘鏋滃弬鏁版槸瀛愯妭鐐癸紝鍒欒繑鍥炶鑺傜偣鐨勭埗鑺傜偣銆俷ame鏄腑鏂囧瓧绗︼紝enName鏄嫳鏂囧瓧绗�.
+    chooseNode (value, data, node) {
+      if (data.label.indexOf(value) !== -1) {
+        return true
+      }
+      const level = node.level
+      // 濡傛灉浼犲叆鐨勮妭鐐规湰韬氨鏄竴绾ц妭鐐瑰氨涓嶇敤鏍¢獙浜�
+      if (level === 1) {
+        return false
+      }
+      // 鍏堝彇褰撳墠鑺傜偣鐨勭埗鑺傜偣
+      let parentData = node.parent
+      // 閬嶅巻褰撳墠鑺傜偣鐨勭埗鑺傜偣
+      let index = 0
+      while (index < level - 1) {
+        // 濡傛灉鍖归厤鍒扮洿鎺ヨ繑鍥烇紝姝ゅname鍊兼槸涓枃瀛楃锛宔nName鏄嫳鏂囧瓧绗︺�傚垽鏂尮閰嶄腑鑻辨枃杩囨护
+        if (parentData.data.label.indexOf(value) !== -1) {
+          return true
+        }
+        // 鍚﹀垯鐨勮瘽鍐嶅線涓婁竴灞傚仛鍖归厤
+        parentData = parentData.parent
+        index++
+      }
+      // 娌″尮閰嶅埌杩斿洖false
+      return false
+    },
+
     searchFilter() {
       this.$refs.tree.filter(this.search);
     },
@@ -1413,7 +592,6 @@
           }
           this.selectTree = data2.replace(" - ", "");
           delStandardTree({ tree: this.selectTree }).then((res) => {
-            if (res.code == 201) return;
             this.$message.success("宸插垹闄�");
             let arr = this.selectTree.split(" - ");
             this.deleteStandard(this.list, arr[arr.length - 1]);
@@ -1422,7 +600,7 @@
             this.productList = [];
           });
         })
-        .catch((e) => {});
+        .catch((e) => { });
     },
     deleteStandard(arr, label) {
       arr.forEach((item, index) => {
@@ -1432,15 +610,6 @@
           item.children && this.deleteStandard(item.children, label);
         }
       });
-    },
-    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) => {
@@ -1510,22 +679,6 @@
         this.standardEnum = data;
       });
     },
-    addStandardMethodList() {
-      if (this.standardId == null || this.standardId == "") {
-        this.$message.error("鏍囧噯鏂规硶鏈�夋嫨");
-        return;
-      }
-      this.addLoad2 = true;
-      addStandardMethodList({
-        standardId: this.standardId,
-        tree: this.selectTree,
-      }).then((res) => {
-        this.addLoad2 = false;
-        this.addStandardDia = false;
-        this.$message.success("娣诲姞鎴愬姛");
-        this.selectsStandardMethodByFLSSM();
-      });
-    },
     // 鎻愪氦鍒嗙被娣诲姞
     addStandardTree() {
       if (this.addOb.sampleType == null || this.addOb.sampleType == "") {
@@ -1539,10 +692,6 @@
       this.addLoad = true;
       addStandardTree(this.addOb)
         .then((res) => {
-          if (res.code === 201) {
-            this.addLoad = false;
-            return;
-          }
           this.$message.success("娣诲姞鎴愬姛");
           this.addDia = false;
           this.list
@@ -1576,12 +725,9 @@
       this.updateLoad = true;
       updateStandardTree(this.addOb)
         .then((res) => {
-          if (res.code === 201) {
-            this.updateLoad = false;
-            return;
-          }
           this.$message.success("娣诲姞鎴愬姛");
-          this.selectStandardTreeList();
+          this.$tab.refreshPage();
+          // this.selectStandardTreeList();
           this.updateDia = false;
           this.updateLoad = false;
         })
@@ -1612,10 +758,6 @@
           ask: value,
         }),
       }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
         this.$message.success("宸蹭繚瀛�");
       });
     },
@@ -1626,10 +768,6 @@
           tell: value,
         }),
       }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
         this.$message.success("宸蹭繚瀛�");
       });
     },
@@ -1641,10 +779,6 @@
           methodS: value,
         }),
       }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
         this.$message.success("宸蹭繚瀛�");
       });
     },
@@ -1656,10 +790,6 @@
           radius: value,
         }),
       }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
         this.$message.success("宸蹭繚瀛�");
       });
     },
@@ -1670,10 +800,6 @@
           price: value,
         }),
       }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
         this.$message.success("宸蹭繚瀛�");
       });
     },
@@ -1684,10 +810,6 @@
           manHour: value,
         }),
       }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
         this.$message.success("宸蹭繚瀛�");
       });
     },
@@ -1698,30 +820,8 @@
           templateId: value,
         }),
       }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
         this.$message.success("宸蹭繚瀛�");
       });
-    },
-    delStandardMethodByFLSSM(id) {
-      this.$confirm("鏄惁鍒犻櫎褰撳墠鏁版嵁?", "璀﹀憡", {
-        confirmButtonText: "纭畾",
-        cancelButtonText: "鍙栨秷",
-        type: "warning",
-      })
-        .then(() => {
-          this.tableLoad = true;
-          delStandardMethodByFLSSM({ id: id }).then((res) => {
-            if (res.code == 201) {
-              return;
-            }
-            this.$message.success("宸插垹闄�");
-            this.selectsStandardMethodByFLSSM();
-          });
-        })
-        .catch(() => {});
     },
     handleSelectionChange(val) {
       this.selects = [];
@@ -1729,57 +829,7 @@
         this.selects.push(a.id);
       });
     },
-    delStandardProductByIds() {
-      if (this.selects.length == 0) {
-        this.$message.error("鏈�変腑鏁版嵁");
-        return;
-      }
-      this.$confirm(
-        "鏄惁鍒犻櫎褰撳墠閫変腑 " + this.selects.length + " 鏉℃暟鎹�?",
-        "璀﹀憡",
-        {
-          confirmButtonText: "纭畾",
-          cancelButtonText: "鍙栨秷",
-          type: "warning",
-        }
-      )
-        .then(() => {
-          this.tableLoad = true;
-          delStandardProductByIds({
-            ids: JSON.stringify(this.selects),
-          }).then((res) => {
-            if (res.code == 201) {
-              return;
-            }
-            this.$message.success("宸插垹闄�");
-            this.selectsStandardMethodByFLSSM();
-          });
-        })
-        .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(
@@ -1850,11 +900,7 @@
           state: row.state,
         }),
       }).then((res) => {
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
-        // this.$message.success('宸蹭繚瀛�')
+        this.$message.success('宸蹭繚瀛�')
       });
     },
     filterHandler(value) {
@@ -2004,10 +1050,6 @@
           }),
         }).then((res) => {
           this.sectionLoad = false;
-          if (res.code == 201) {
-            this.$message.error("鏈繚瀛�");
-            return;
-          }
           this.$message.success("宸蹭繚瀛�");
           this.sectionUpDia = false;
         });
@@ -2026,10 +1068,6 @@
           },
         }).then((res) => {
           this.sectionLoad = false;
-          if (res.code == 201) {
-            this.$message.error("鏈繚瀛�");
-            return;
-          }
           this.$message.success("宸蹭繚瀛�");
           this.sectionUpDia = false;
           this.currentPage0 = 1;
@@ -2079,16 +1117,6 @@
         this.$refs.BatchCopy.getList();
       });
     },
-    async handleMore() {
-      if (
-        (!this.standardId && this.standardId != 0) ||
-        this.standardList.length == 0
-      ) {
-        return this.$message.error("璇烽�夋嫨瀹為獙瀹ゃ�佹牱鍝�");
-      }
-      await this.getList();
-      this.moreEdit = true;
-    },
     selectStandardMethodsSec() {
       selectStandardMethods().then((res) => {
         let data = [];
@@ -2099,33 +1127,6 @@
           });
         });
         this.methodList = data;
-      });
-    },
-    subMoreEdit() {
-      if (this.moreSelects.length === 0) {
-        return this.$message.error("璇烽�夋嫨妫�楠岄」");
-      }
-      this.moreEditLoad = true;
-      for (let a in this.moreInfo) {
-        if (this.moreInfo[a] == "") {
-          delete this.moreInfo[a];
-        }
-      }
-      upStandardProducts({
-        ids: JSON.stringify(this.moreSelects.map((a) => a.id)),
-        standardProductList: this.moreInfo,
-      }).then((res) => {
-        this.moreEditLoad = false;
-        if (res.code == 201) {
-          this.$message.error("鏈繚瀛�");
-          return;
-        }
-        this.$message.success("宸蹭繚瀛�");
-        this.currentPage0 = 1;
-        this.getList();
-        this.rowClick({
-          id: this.standardId,
-        });
       });
     },
     handleSelectAll0(rows) {
@@ -2203,83 +1204,189 @@
         });
       });
     },
-    beforeUpload(file, fileList) {
-      if (
-        file.raw.type !=
-        "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
-      ) {
-        this.$message.error("涓婁紶鏂囦欢鏍煎紡涓嶆纭�");
-        this.$refs.upload.clearFiles();
-        return false;
-      }
-    },
-    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.selectStandardTreeList();
-    },
-    onError(err, file, fileList) {
-      this.$message.error("涓婁紶澶辫触");
-      this.$refs.upload.clearFiles();
-      this.uploading = false;
-    },
-    clearProduct(type) {
-      this.$confirm("鏄惁娓呯┖?", "璀﹀憡", {
-        confirmButtonText: "纭畾",
-        cancelButtonText: "鍙栨秷",
-        type: "warning",
-      })
-        .then(() => {
-          if (type === 1) {
-            resetTreeOfPrice({
-              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,
-              });
-            });
-          } else if (type === 2) {
-            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,
-              });
-            });
-          }
-        })
-        .catch(() => {});
-    },
   },
 };
 </script>
+<style scoped>
+.standard {
+  padding-top: 10px;
+  display: flex;
+  height: calc(100vh - 90px);
+}
+
+.left {
+  width: 330px;
+  height: calc(100% - 40px - 10px);
+  background-color: white;
+  padding: 15px;
+}
+
+.custom-tree-node {
+  width: 100%;
+  line-height: 32px;
+}
+
+.custom-tree-node .el-icon-delete {
+  color: #3a7bfa;
+  opacity: 0;
+  font-size: 18px;
+}
+
+.custom-tree-node:hover .el-icon-delete {
+  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;
+}
+
+.right {
+  margin-left: 5px;
+  width: calc(100% - 350px);
+  height: calc(100% - 40px);
+}
+
+.right .title {
+  height: 34px;
+  line-height: 34px;
+  padding: 0 10px;
+  background-color: white;
+}
+
+.standard_table {
+  border-top: 1px solid #ebeef5;
+  background-color: white;
+}
+
+.product_table {
+  border-top: 1px solid #ebeef5;
+  height: calc(100% - 235px);
+  margin-top: 5px;
+  background-color: white;
+  user-select: none;
+}
+
+.product_table .el-table {
+  height: calc(100% - 35px) !important;
+}
+
+.sort {
+  width: 80% !important;
+  overflow: hidden;
+}
+
+>>>.el-table__body-wrapper {
+  height: calc(100% - 46px) !important;
+}
+
+>>>.header-class {
+  height: 40px !important;
+}
+
+>>>.header-class th.el-table__cell>.cell {
+  line-height: 20px !important;
+  padding-top: 0 !important;
+  padding-bottom: 0 !important;
+}
+
+>>>.el-table__row {
+  height: 35px !important;
+}
+
+.search {
+  border-bottom: 1px solid #ebeef5;
+  margin-bottom: 16px;
+  display: flex;
+  align-items: center;
+  box-sizing: border-box;
+  padding-bottom: 10px;
+}
+
+.search-item {
+  display: flex;
+  align-items: center;
+  flex-wrap: wrap;
+}
+
+.search-item .el-row {
+  display: flex;
+  align-items: center;
+}
+
+.search-item .el-col {
+  margin-left: 0;
+}
+
+.more-edit .dialog-footer {
+  position: absolute;
+  top: 15px;
+  right: 70px;
+}
+
+>>>.is-disabled .el-textarea__inner {
+  background: rgba(0, 0, 0, 0.05) !important;
+}
+</style>
+<style scoped>
+.standard .el-tree-node__content {
+  height: 32px;
+  font-size: 14px;
+  border-radius: 2px;
+}
+
+.standard .el-tree--highlight-current .el-tree-node.is-current>.el-tree-node__content {
+  color: #3a7bfa;
+}
+
+.standard .has-gutter .el-table__cell .cell {
+  line-height: 34px;
+  background-color: #f8f8f8;
+}
+
+.standard .has-gutter .el-table__cell {
+  background-color: #fafafa !important;
+}
+
+.standard .standard_table .el-table__row .cell {
+  font-size: 14px;
+}
+
+.standard .el-table .warning-row .cell {
+  color: #bababa;
+}
+
+.standard .el-table-filter__list {
+  max-height: 400px;
+  overflow-y: auto;
+}
+
+.standard .el-upload {
+  width: 100%;
+}
+
+.standard .el-upload-dragger {
+  width: 100%;
+}
+
+.standard .handleBtn.is-disabled .el-upload:focus {
+  color: #c0c4cc !important;
+}
+
+.standard .avatar-uploader .el-upload {
+  height: 80px;
+  display: flex;
+  align-items: center;
+  justify-content: center;
+}
+</style>

--
Gitblit v1.9.3