From 2024d0f570d9da956e792746992852749c06227c Mon Sep 17 00:00:00 2001
From: xiejun <xj@2023>
Date: 星期二, 11 七月 2023 14:30:11 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 Source/UBCS-WEB/src/components/BatchImport/ShowImportData.vue |  816 +++++++++++++++++++++++++++------------------------------
 1 files changed, 390 insertions(+), 426 deletions(-)

diff --git a/Source/UBCS-WEB/src/components/BatchImport/ShowImportData.vue b/Source/UBCS-WEB/src/components/BatchImport/ShowImportData.vue
index 9a74712..2b2f7de 100644
--- a/Source/UBCS-WEB/src/components/BatchImport/ShowImportData.vue
+++ b/Source/UBCS-WEB/src/components/BatchImport/ShowImportData.vue
@@ -7,7 +7,11 @@
     top="5vh"
   >
     <div class="flex_box">
-      <div class="left" :style="{ width: leftWidth }">
+      <div
+        class="left"
+        :style="{ width: leftWidth + 'px' }"
+        v-show="type !== 'batchImportApply'"
+      >
         <div class="isExpand_box">
           <el-link type="primary" @click="hideTree">
             <i
@@ -27,6 +31,7 @@
           v-show="isExpand"
           class="filter_tree"
           :data="leftTree"
+          node-key="codeClassifyOid"
           default-expand-all
           highlight-current
           :filter-node-method="filterNode"
@@ -38,108 +43,174 @@
         >
         </el-tree>
       </div>
-      <div class="right">
-        <div class="tab_box">
+      <div class="right" :style="{ width: 1280 - leftWidth - 60 + 'px' }">
+        <div class="tab_box" style="width: 100%">
           <el-tabs
+            style="width: 100%"
             v-model="activeTab"
             type="card"
             @tab-click="handleClick"
             size="small"
           >
-            <el-tab-pane label="鏈夌浉浼奸」" name="resemble">
+            <el-tab-pane :label="tab1Name" name="tab1">
               <el-table
                 border
-                :data="resembleData"
+                :data="tab1Table"
                 style="width: 100%"
                 height="400px"
                 highlight-current-row
                 @current-change="resembleRowChange"
+                @selection-change="tab1TableSelectChange"
+                v-if="cloNamesList.length > 1"
               >
                 <el-table-column
-                  v-for="item in cloNamesList"
-                  :key="item.field"
-                  :prop="item.field"
-                  :label="item.title"
-                  :width="item.width"
+                  v-if="type !== 'batchApplyCode'"
+                  type="selection"
+                  width="100px"
+                  align="center"
+                ></el-table-column>
+                <el-table-column
+                  v-else
+                  type="operate"
+                  width="100px"
+                  align="center"
                 >
+                  <template #default="{ row }">
+                    <el-button type="text" @click="reEdit(row)"
+                      >閲嶆柊缂栬緫</el-button
+                    >
+                  </template>
                 </el-table-column>
-              </el-table>
-            </el-tab-pane>
-            <el-tab-pane label="姝g‘鏁版嵁" name="success">
-              <el-table border :data="successData" height="400px">
+                <el-table-column
+                  type="index"
+                  label="搴忓彿"
+                  width="100px"
+                  align="center"
+                ></el-table-column>
                 <el-table-column
                   v-for="item in cloNamesList"
                   :key="item.field"
                   :prop="item.field"
                   :label="item.title"
                   :width="item.width"
+                  align="center"
                 >
                 </el-table-column>
               </el-table>
+              <div v-else style="height: 400px"></div>
+              <div>
+                <el-table
+                  border
+                  :data="currentSelectedResemble"
+                  style="width: 100%"
+                  height="200px"
+                >
+                  <el-table-column
+                    v-for="item in resembleColumList"
+                    :key="item.field"
+                    :prop="item.field"
+                    :label="item.title"
+                    :minWidth="item.minWidth"
+                    align="center"
+                  >
+                    <template #default="{ row }">
+                      <span v-if="item.field === 'id'">
+                        <el-link
+                          type="primary"
+                          @click="openFormTemlpate(row)"
+                          >{{ row[item.field] }}</el-link
+                        >
+                      </span>
+                      <span v-else>
+                        {{ row[item.field] }}
+                      </span>
+                    </template>
+                  </el-table-column>
+                  <el-table-column
+                    v-show="resembleColumList.length > 0"
+                    prop="rowIndex"
+                    label="excel琛屾暟"
+                    align="center"
+                  ></el-table-column>
+                </el-table>
+              </div>
+            </el-tab-pane>
+            <el-tab-pane :label="tab2Name" name="tab2">
+              <el-table
+                border
+                :data="tab2Table"
+                :height="
+                  type === 'batchApplyCode' && tab2Table.length > 0
+                    ? '400px'
+                    : '700px'
+                "
+              >
+                <el-table-column
+                  v-for="item in successTableColumns"
+                  :key="item.field"
+                  :prop="item.field"
+                  :label="item.title"
+                  :width="item.width"
+                  align="center"
+                >
+                </el-table-column>
+              </el-table>
+              <el-card
+                style="min-height: 200px; margintop: 10px"
+                v-if="type === 'batchApplyCode' && tab2Table.length > 0"
+              >
+                <div slot="header" class="clearfix">
+                  <h4>缂栫爜鐢宠</h4>
+                </div>
+                <FormTemplate
+                  v-if="type === 'batchApplyCode'"
+                  type="add"
+                  :selfColumnType="selfColumnType"
+                  :selfColumnConfig="selfColumnConfig"
+                  ref="CodeApply"
+                  @getFormData="getCodeApplyFormData"
+                  @referConfigDataUpdate="referConfigDataUpdate"
+                ></FormTemplate>
+              </el-card>
             </el-tab-pane>
           </el-tabs>
-        </div>
-        <div>
-          <el-table
-            border
-            :data="currentSelectedResemble"
-            style="width: 100%"
-            height="200px"
-          >
-            <el-table-column
-              v-for="item in resembleColumList"
-              :key="item.field"
-              :prop="item.field"
-              :label="item.title"
-              :minWidth="item.minWidth"
-            >
-              <template #default="{ row }">
-                <span v-if="item.field === 'id'">
-                  <el-link type="primary" @click="openFormTemlpate(row)">{{
-                    row[item.field]
-                  }}</el-link>
-                </span>
-                <span v-else>
-                  {{ row[item.field] }}
-                </span>
-              </template>
-            </el-table-column>
-            <el-table-column
-              v-show="resembleColumList.length > 0"
-              prop="rowIndex"
-              label="excel琛屾暟"
-            ></el-table-column>
-          </el-table>
         </div>
       </div>
     </div>
     <template #footer>
       <div>
-        <el-button size="small" type="primary">纭畾瀵煎叆</el-button>
-        <el-button size="small">鍙栨秷</el-button>
+        <el-button size="small" type="primary" @click="submit"
+          >纭畾瀵煎叆</el-button
+        >
+        <el-button size="small" @click="dialogVisible = false">鍙栨秷</el-button>
       </div>
     </template>
     <FormTemplateDialog
       ref="FormTemplateDialog"
-      type="detail"
       v-bind="currentSelectedResembleRow"
-      :visible.sync="currentSelectedResembleRow.visible"
-      title="鏌ョ湅璇︾粏淇℃伅"
+      :visible.sync="currentSelectedResembleRow.formTemplateVisible"
+      @submit="FormTemplateSubmit"
     ></FormTemplateDialog>
   </el-dialog>
 </template>
 
 <script>
 import {
-  getHistorySuccessTable,
-  getHistoryResembleTable,
+  getSuccessTable,
+  getResembleTable,
   getFormTemplate,
   getCurretnSelectedRowResemble,
+  submitHistoryimport,
+  addSaveCode,
 } from "../../api/batchImport/index";
 import ResembleQuery from "../FormTemplate/ResembleQuery.vue";
+import FormTemplate from "../FormTemplate/FormTemplate.vue";
+import codeApply from "@/mixins/codeApply.js";
+
 export default {
   name: "ShowImportData",
-  components: { ResembleQuery },
+  components: { ResembleQuery, FormTemplate },
+  mixins: [codeApply],
   props: {
     title: {
       type: String,
@@ -154,6 +225,19 @@
       type: String,
       default: "",
     },
+    classifyAttr: {
+      type: String,
+      default: "id",
+    },
+    codeClassifyOid: {
+      type: String,
+      default: "",
+    },
+    type: String,
+    secDTOList: {
+      type: Array,
+      default: () => ({}),
+    },
   },
   computed: {
     dialogVisible: {
@@ -164,139 +248,42 @@
         this.$emit("update:visible", val);
       },
     },
+    successTableColumns() {
+      if (this.type === "batchApplyCode") {
+        return this.cloNamesList.slice(1);
+      } else {
+        return this.cloNamesList;
+      }
+    },
   },
   data() {
     return {
       isExpand: true,
       filterText: "",
-      leftWidth: "200px",
-      data: [
-        {
-          id: 1,
-          label: "涓�绾� 1",
-          children: [
-            {
-              id: 4,
-              label: "浜岀骇 1-1",
-              children: [
-                {
-                  id: 9,
-                  label: "涓夌骇 1-1-1",
-                },
-                {
-                  id: 10,
-                  label: "涓夌骇 1-1-2",
-                },
-              ],
-            },
-          ],
-        },
-        {
-          id: 2,
-          label: "涓�绾� 2",
-          children: [
-            {
-              id: 5,
-              label: "浜岀骇 2-1",
-            },
-            {
-              id: 6,
-              label: "浜岀骇 2-2",
-            },
-          ],
-        },
-        {
-          id: 3,
-          label: "涓�绾� 3",
-          children: [
-            {
-              id: 7,
-              label: "浜岀骇 3-1",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-            {
-              id: 8,
-              label: "浜岀骇 3-2",
-            },
-          ],
-        },
-      ],
-      resembleData: [],
-      successData: [],
-      activeTab: "resemble",
-      cloNamesList: [],
-      codeClassifyOid: "",
-      resembleColumList: [],
+      leftWidth: 200,
+      templateOid: null,
+      tab1Name: "鐩镐技椤�",
+      tab2Name: "姝g‘鏁版嵁",
+      tab1Table: [],
+      selectedTab1Table: [],
+      tab2Table: [],
+      activeTab: "tab1",
+      cloNamesList: [], //鍒楄〃澶撮儴瀛楁
+      localCodeClassifyOid: "",
+      codeRuleOid: "",
+      resembleColumList: [], //鐩镐技椤规煡鍑烘潵鐨勫垪琛ㄥ瓧娈�
       currentSelectedResemble: [],
       currentSelectedResembleRow: {
         templateOid: "",
         codeClassifyOid: "",
         rowOid: "",
         formTemplateVisible: false,
+        type: "detail",
+        title: "鏌ョ湅璇︾粏淇℃伅",
+        setForm: {},
       },
+      batchApplyCodeTableData: {},
+      savedList: [],
     };
   },
 
@@ -307,286 +294,262 @@
     },
     hideTree() {
       if (this.isExpand) {
-        this.leftWidth = "50px";
+        this.leftWidth = 50;
       } else {
-        this.leftWidth = "200px";
+        this.leftWidth = 200;
       }
       this.isExpand = !this.isExpand;
     },
-    treeNodeClick(data) {
-      this.codeClassifyOid = data.codeclassifyoid;
+    async treeNodeClick(data, first) {
+      if (this.type === "batchApplyCode") {
+        if (first === true) {
+          this.codeRuleOid = data.codeRuleOid;
+          // 绗竴娆℃墦寮�鐩存帴璧嬪�间笉鏍¢獙
+          this.batchApplyCodeTableData[data.codeRuleOid] = {
+            name: data.name,
+            templateOid: data.oid,
+            cloNamesList: data.cloNamesList,
+            codeClassifyOid: data.codeClassifyOid,
+            codeRuleOid: data.codeRuleOid,
+          };
+          // 涓嶆槸绗竴娆℃墦寮�闇�瑕佷紭鍏堟牎楠�
+        } else if (this.localCodeClassifyOid === data.codeClassifyOid) {
+          console.log("閲嶅鐐瑰嚮");
+        } else {
+          if (this.$refs.CodeApply) {
+            if (!(await this.$refs.CodeApply.validate())) {
+              this.$message.warning("璇峰~鍐欎究缂栫爜鐢宠锛�");
+              this.activeTab = "tab2";
+              this.$refs.tree.setCurrentKey(this.localCodeClassifyOid);
+              return false;
+            }
+          }
+        }
+        if (!this.batchApplyCodeTableData[data.codeRuleOid]) {
+          this.batchApplyCodeTableData[data.codeRuleOid] = {
+            name: data.name,
+            templateOid: data.oid,
+            cloNamesList: data.cloNamesList,
+            codeClassifyOid: data.codeClassifyOid,
+            codeRuleOid: data.codeRuleOid,
+          };
+        }
+      }
+      this.localCodeClassifyOid = data.codeClassifyOid;
       this.cloNamesList = data.cloNamesList;
-      getHistorySuccessTable(this.redisOid).then((res) => {
-        this.successData = res.data
-        // this.successData = [
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH007",
-        //     caigouwl: "鏄�",
-        //     oid: "433DFA8E-4445-18F4-AC95-85E7EE1C92CF",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH006",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘瘝",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯4",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0004",
-        //     id: "0201020013",
-        //   },
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH006",
-        //     caigouwl: "鏄�",
-        //     oid: "E94E3320-841F-AE87-1D56-D6B3398D0FFC",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH005",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘瘝",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯3",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0003",
-        //     id: "0201020012",
-        //   },
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH003",
-        //     caigouwl: "鏄�",
-        //     oid: "D2E0A166-A774-BE6F-A9C7-3277467CE8EC",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH003",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘瘝",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯2",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0002",
-        //     id: "0201020011",
-        //   },
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH002",
-        //     caigouwl: "鏄�",
-        //     oid: "291CD01A-F18D-2D95-5291-D2C80ED57CC8",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH002",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘瘝",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯1",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0001",
-        //     id: "0201020010",
-        //   },
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH001",
-        //     caigouwl: "鏄�",
-        //     oid: "FED83315-F2B4-C603-2AC2-11B0DF3029A6",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH001",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘爴",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯6",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0006",
-        //     id: "0201010019",
-        //   },
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH005",
-        //     caigouwl: "鏄�",
-        //     oid: "3E120284-8EC2-9BF4-D1AB-579380DFA085",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH005",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘爴",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯5",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0005",
-        //     id: "0201010018",
-        //   },
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH004",
-        //     caigouwl: "鏄�",
-        //     oid: "2EB3B122-2FE4-A236-53F2-9B67E40332AC",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH004",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘爴",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯4",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0004",
-        //     id: "0201010017",
-        //   },
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH009",
-        //     caigouwl: "鏄�",
-        //     oid: "8940A341-8041-E031-6FE1-A18526C62DE9",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH008",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘瘝",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯6",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0006",
-        //     id: "0201020015",
-        //   },
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH008",
-        //     caigouwl: "鏄�",
-        //     oid: "936CBC1E-2FD0-5CD7-C331-64B86204FD78",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH007",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘瘝",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯5",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0005",
-        //     id: "0201020014",
-        //   },
-        // ];
-      });
-      getHistoryResembleTable({
-        codeClassifyOid: data.codeClassifyOid,
+      this.templateOid = data.oid;
+      getResembleTable({
+        codeClassifyOid:
+          this.type === "batchApplyCode" ? data.codeRuleOid : this.templateOid,
         redisOid: this.redisOid + "-resemble",
       }).then((res) => {
-        console.log(res);
-        this.resembleData = res.data
-        // this.resembleData = [
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH007",
-        //     caigouwl: "鏄�",
-        //     oid: "FC2F0D9F-8B2E-5A19-3BDE-22107F373EB3",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH006",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘瘝",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯4",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0004",
-        //     id: "0201020013",
-        //   },
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH007",
-        //     caigouwl: "鏄�",
-        //     oid: "B92CFF46-1D46-E680-66C4-33A3ABE77A6C",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH005",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘瘝",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯3",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0003",
-        //     id: "0201020012",
-        //   },
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH15",
-        //     caigouwl: "鏄�",
-        //     oid: "B383C30E-D201-01F2-89EE-6F751EFA0AA1",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH008",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘瘝",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯6",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0006",
-        //     id: "0201020015",
-        //   },
-        //   {
-        //     xiaoshouwl: "鏄�",
-        //     xinghaoguige: "XH17",
-        //     caigouwl: "鏄�",
-        //     oid: "1C379116-F27B-3F20-DFC3-74A39B87E505",
-        //     kucunwl: "鏄�",
-        //     tuhao: "TH007",
-        //     codeSecLengthField: "6#4",
-        //     codeclsfid: "绱у浐浠�#铻烘瘝",
-        //     materialtype: "鏉愭枡",
-        //     chukufangshi: "鍏堣繘鍏堝嚭",
-        //     hesuanfenlei: "鍘熸潗鏂�",
-        //     name: "娴嬭瘯5",
-        //     jiliangdw: "涓�",
-        //     oldcode: "z0005",
-        //     id: "0201020014",
-        //   },
-        // ];
+        this.tab1Table = res.data.data.filter(
+          (item) => !this.savedList.includes(item.oid)
+        );
+        if (this.type === "batchApplyCode") {
+          this.batchApplyCodeTableData[data.codeRuleOid]["tab1"] =
+            this.tab1Table;
+        }
+      });
+      // 鑾峰彇姝g‘鏁版嵁
+      getSuccessTable({
+        codeClassifyOid:
+          this.type === "batchApplyCode" ? data.codeRuleOid : this.templateOid,
+        redisOid: this.redisOid + "-ok",
+      }).then((res) => {
+        this.tab2Table = res.data.data;
+        if (this.tab2Table.length > 0 && this.type === "batchApplyCode") {
+          this.batchApplyCodeTableData[data.codeRuleOid]["codeApply"] = {};
+          this.batchApplyCodeTableData[data.codeRuleOid]["tab2"] =
+            res.data.data;
+          if (this.$refs.CodeApply) {
+            this.$refs.CodeApply.loading = true;
+          }
+          this.getCodeRule();
+        }
       });
       getFormTemplate({
         templateOid: data.oid,
-        codeClassifyOid: data.codeClassifyOid,
+        codeClassifyOid: this.localCodeClassifyOid,
       }).then((res) => {
         this.resembleColumList = res.data.resembleTableVO.cols[0];
       });
     },
+    tab1TableSelectChange(selection) {
+      this.selectedTab1Table = selection;
+    },
     resembleRowChange(row) {
+      if (!row || !row.oid) {
+        return;
+      }
       getCurretnSelectedRowResemble({
         redisOid: this.redisOid + "-resemble-data",
         dataOid: row.oid,
       }).then((res) => {
-        this.currentSelectedResemble = res.data
-        // this.currentSelectedResemble = [
-        //   {
-        //     xinghaoguige: "XH007",
-        //     codetemplateoid: "f441b131-5ea0-4672-ab74-735b11161928",
-        //     rowIndex: "9",
-        //     id: "0201020012",
-        //     oid: "B92CFF46-1D46-E680-66C4-33A3ABE77A6C",
-        //   },
-        // ];
+        this.currentSelectedResemble = res.data.data;
       });
     },
     openFormTemlpate(row) {
       this.currentSelectedResembleRow = {
-        visible: true,
+        formTemplateVisible: true,
         templateOid: row.codetemplateoid,
-        codeClassifyOid: this.codeClassifyOid,
+        codeClassifyOid: this.localCodeClassifyOid,
         rowOid: row.rowOid,
+        type: "detail",
+        title: "鏌ョ湅璇︾粏淇℃伅",
+        setForm: {},
+      };
+    },
+    async submit() {
+      let params = {
+        classifyAttr:
+          this.type === "historyImport" || this.type === "batchApplyCode"
+            ? this.classifyAttr
+            : undefined,
+        improt: this.type === "historyImport" ? true : false,
+      };
+      if (this.type === "batchApplyCode") {
+        if (this.$refs.CodeApply) {
+          if (!(await this.$refs.CodeApply.validate())) {
+            this.$message.warning("璇峰~鍐欎究缂栫爜鐢宠锛�");
+            this.activeTab = "tab2";
+            return false;
+          }
+        }
+        let lookedCodeRuleOidList = Object.keys(this.batchApplyCodeTableData);
+        let noLookCodeRuleOidList = this.leftTree.filter(
+          (item) => !lookedCodeRuleOidList.includes(item.codeRuleOid)
+        );
+        let noLookName = noLookCodeRuleOidList.map((item) => item.name);
+        if (noLookName.length > 0) {
+          this.$message.warning(`鏁版嵁${noLookName}杩樻湭鏇炬煡鐪嬶紝璇峰厛鏌ョ湅锛乣);
+          return false;
+        }
+        let errorData = [];
+        let successData = [];
+        for (const key in this.batchApplyCodeTableData) {
+          if (Object.hasOwnProperty.call(this.batchApplyCodeTableData, key)) {
+            const element = this.batchApplyCodeTableData[key];
+            if (element.tab1.length > 0) {
+              errorData.push(element);
+            }
+            if (element.tab2.length > 0) {
+              successData.push(element);
+            }
+          }
+        }
+        if (successData.length === 0) {
+          this.$message.warning("瀵煎叆鐨勬暟鎹腑娌℃湁姝g‘鐨勬暟鎹紒");
+          return;
+        }
+        if (errorData.length > 0) {
+          await this.$confirm(
+            errorData.map((item) => item.name).join("銆�") +
+              "锛岃繖鍑犱釜缂栫爜瑙勫垯涓嬬殑鏈夐敊璇暟鎹拰鐩镐技椤规暟鎹病鏈夊鐞嗭紝鎮ㄥ鏋滅户缁繚瀛樼殑璇濓紝杩欎簺鏁版嵁灏嗕細琚嚜鍔ㄨ垗寮冿紝鏄惁缁х画锛�",
+            "鎻愮ず",
+            {
+              confirmButtonText: "纭畾",
+              cancelButtonText: "鍙栨秷",
+              type: "warning",
+            }
+          );
+        }
+        params.codeImprotSaveDatVOList = successData.map((item) => {
+          return {
+            Clos: item.cloNamesList,
+            dataList: item.tab2,
+            orderDTO: {
+              codeClassifyOid: item.codeClassifyOid,
+              templateOid: item.templateOid,
+              secDTOList: item.localSecVOList.map((itm) => {
+                return {
+                  secOid: itm.oid,
+                  secValue: item.codeApply[itm.oid],
+                };
+              }),
+            },
+          };
+        });
+      } else {
+        params.codeImprotSaveDatVOList = [
+          {
+            Clos: this.cloNamesList.map((item) => item.title),
+            dataList: this.tab2Table.concat(this.selectedTab1Table),
+            orderDTO: {
+              codeClassifyOid: this.codeClassifyOid,
+              templateOid: this.templateOid,
+              secDTOList: this.secDTOList,
+            },
+          },
+        ];
       }
+      submitHistoryimport(params).then((res) => {
+        console.log(res);
+        if (res.data.code === 200) {
+          this.$message.success(res.data.msg);
+        } else {
+          this.$message.error(res.data.msg);
+        }
+      });
+    },
+    // 閲嶆柊缂栬緫
+    reEdit(row) {
+      console.log(row, "row");
+      this.currentSelectedResembleRow = {
+        templateOid: row.codetemplateoid,
+        codeClassifyOid: row.codeclassifyid,
+        rowOid: row.oid,
+        formTemplateVisible: true,
+        type: "add",
+        title: "缂栬緫鏁版嵁鍚庨噸鏂板叆搴�",
+        setForm: row,
+      };
+    },
+    // 鐩存帴缂栬緫鍚庝繚瀛�
+    FormTemplateSubmit(form) {
+      addSaveCode(form).then((res) => {
+        console.log(res);
+        if (res.data.code === 200) {
+          this.savedList.push(form.oid);
+          this.$message.success("鏂板鎴愬姛锛�");
+          this.treeNodeClick(
+            this.leftTree.find((item) => item.codeRuleOid === this.codeRuleOid)
+          );
+          this.currentSelectedResembleRow = {
+            templateOid: "",
+            codeClassifyOid: "",
+            rowOid: "",
+            formTemplateVisible: false,
+            type: "detail",
+            title: "鏌ョ湅璇︾粏淇℃伅",
+            setForm: {},
+          };
+        }
+      });
     },
   },
   watch: {
     filterText(val) {
       this.$refs.tree.filter(val);
+    },
+    leftTree: {
+      immediate: true,
+      deep: true,
+      handler(arr) {
+        if (arr.length > 0) {
+          this.treeNodeClick(arr[0], true);
+          this.$nextTick(() => {
+            this.$refs.tree.setCurrentKey(arr[0]["codeClassifyOid"]);
+          });
+          if (this.type === "batchImportApply") {
+            this.leftWidth = 0;
+          } else if (this.type === "batchApplyCode") {
+            this.tab1Name = "鏈夌浉浼奸」鎴栭敊璇暟鎹�";
+            this.tab2Name = "姝g‘鏁版嵁";
+            this.leftWidth = 200;
+          }
+        }
+      },
     },
   },
 };
@@ -595,13 +558,15 @@
 <style lang="scss" scoped>
 .flex_box {
   display: flex;
+  width: 1280px;
   .left {
-    transition: all 0.3s;
+    transition: all 0.5s;
     .isExpand_box {
       margin-bottom: 10px;
       text-align: right;
     }
     .filter_tree {
+      margin-top: 15px;
       max-height: 400px;
       overflow-y: scroll;
     }
@@ -609,7 +574,6 @@
   .right {
     margin-left: 20px;
     margin-top: 30px;
-    width: 1000px;
   }
 }
 </style>

--
Gitblit v1.9.3