From 42085aad206257ddeffe71d6defc547b5e13b4b7 Mon Sep 17 00:00:00 2001
From: ludc
Date: 星期一, 26 六月 2023 19:57:50 +0800
Subject: [PATCH] 代码整合

---
 Source/UBCS-WEB/src/components/BatchImport/ShowImportData.vue |  341 +++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 215 insertions(+), 126 deletions(-)

diff --git a/Source/UBCS-WEB/src/components/BatchImport/ShowImportData.vue b/Source/UBCS-WEB/src/components/BatchImport/ShowImportData.vue
index 32fde8d..cd1bd20 100644
--- a/Source/UBCS-WEB/src/components/BatchImport/ShowImportData.vue
+++ b/Source/UBCS-WEB/src/components/BatchImport/ShowImportData.vue
@@ -1,10 +1,22 @@
 <template>
   <el-dialog
     :title="title"
-    :visible="dialogVisible"
-    width="1200px"
+    :visible.sync="dialogVisible"
+    width="1300px"
     append-to-body
+    top="5vh"
   >
+    <div>
+      <FormTemplate
+        v-if="type === 'batchApplyCode'"
+        type="add"
+        :selfColumnType="selfColumnType"
+        :selfColumnConfig="selfColumnConfig"
+        ref="CodeApply"
+        @getFormData="getCodeApplyFormData"
+        @referConfigDataUpdate="referConfigDataUpdate"
+      ></FormTemplate>
+    </div>
     <div class="flex_box">
       <div class="left" :style="{ width: leftWidth }">
         <div class="isExpand_box">
@@ -25,44 +37,151 @@
         <el-tree
           v-show="isExpand"
           class="filter_tree"
-          :data="data"
+          :data="leftTree"
           default-expand-all
+          highlight-current
           :filter-node-method="filterNode"
+          @node-click="treeNodeClick"
           ref="tree"
+          :props="{
+            label: 'name',
+          }"
         >
         </el-tree>
       </div>
       <div class="right">
         <div class="tab_box">
-          <el-tabs v-model="activeName" type="card" @tab-click="handleClick">
-            <el-tab-pane label="姝g‘鏁版嵁" name="success">
-              <el-table border :data="successData"></el-table>
+          <el-tabs
+            v-model="activeTab"
+            type="card"
+            @tab-click="handleClick"
+            size="small"
+          >
+            <el-tab-pane :label="tab1Name" name="tab1">
+              <el-table
+                border
+                :data="tab1Table"
+                style="width: 100%"
+                height="400px"
+                highlight-current-row
+                @current-change="resembleRowChange"
+                @selection-change="tab1TableSelectChange"
+              >
+                <el-table-column type="index"></el-table-column>
+                <el-table-column
+                  v-for="item in cloNamesList"
+                  :key="item.field"
+                  :prop="item.field"
+                  :label="item.title"
+                  :width="item.width"
+                >
+                </el-table-column>
+              </el-table>
             </el-tab-pane>
-            <el-tab-pane label="鏈夌浉浼奸」鎴栬�呴敊璇暟鎹�" name="error">
-              <el-table border :data="errorData"></el-table>
+            <el-tab-pane :label="tab2Name" name="tab2">
+              <el-table border :data="tab2Table" height="400px">
+                <el-table-column
+                  v-for="item in cloNamesList"
+                  :key="item.field"
+                  :prop="item.field"
+                  :label="item.title"
+                  :width="item.width"
+                >
+                </el-table-column>
+              </el-table>
             </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" type="primary" @click="submit"
+          >纭畾瀵煎叆</el-button
+        >
         <el-button size="small">鍙栨秷</el-button>
       </div>
     </template>
+    <FormTemplateDialog
+      ref="FormTemplateDialog"
+      type="detail"
+      v-bind="currentSelectedResembleRow"
+      :visible.sync="currentSelectedResembleRow.visible"
+      title="鏌ョ湅璇︾粏淇℃伅"
+    ></FormTemplateDialog>
   </el-dialog>
 </template>
 
 <script>
+import {
+  getHistorySuccessTable,
+  getHistoryResembleTable,
+  getFormTemplate,
+  getCurretnSelectedRowResemble,
+  submitHistoryimport,
+} 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, FormTemplate },
+  mixins: [ codeApply ],
   props: {
     title: {
       type: String,
       default: "鍘嗗彶鏁版嵁瀵煎叆",
     },
     visible: false,
+    leftTree: {
+      type: Array,
+      default: () => [],
+    },
+    redisOid: {
+      type: String,
+      default: "",
+    },
+    classifyAttr: {
+      type: String,
+      default: "id",
+    },
+    codeClassifyOid: {
+      type: String,
+      default: "",
+    },
   },
   computed: {
     dialogVisible: {
@@ -79,129 +198,31 @@
       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",
-            },
-          ],
-        },
-      ],
-      successData: [],
-      errorData: [],
+      templateOid: null,
+      tab1Name: "鐩镐技椤�",
+      tab2Name: "姝g‘鏁版嵁",
+      tab1Table: [],
+      selectedTab1Table: [],
+      tab2Table: [],
+      activeTab: "tab1",
+      cloNamesList: [], //鍒楄〃澶撮儴瀛楁
+      localCodeClassifyOid: "",
+      resembleColumList: [], //鐩镐技椤规煡鍑烘潵鐨勫垪琛ㄥ瓧娈�
+      currentSelectedResemble: [],
+      currentSelectedResembleRow: {
+        templateOid: "",
+        codeClassifyOid: "",
+        rowOid: "",
+        formTemplateVisible: false,
+      },
+      secVOList: [],
     };
   },
 
   methods: {
     filterNode(value, data) {
       if (!value) return true;
-      return data.label.indexOf(value) !== -1;
+      return data.name.indexOf(value) !== -1;
     },
     hideTree() {
       if (this.isExpand) {
@@ -210,6 +231,69 @@
         this.leftWidth = "200px";
       }
       this.isExpand = !this.isExpand;
+    },
+    treeNodeClick(data) {
+      this.localCodeClassifyOid = data.codeclassifyoid;
+      this.cloNamesList = data.cloNamesList;
+      this.templateOid = data.codeClassifyTemplateVO.oid;
+      getHistorySuccessTable(this.redisOid).then((res) => {
+        this.tab2Table = res.data;
+      });
+      getHistoryResembleTable({
+        codeClassifyOid: data.codeClassifyOid,
+        redisOid: this.redisOid + "-resemble",
+      }).then((res) => {
+        this.tab1Table = res.data;
+      });
+      getFormTemplate({
+        templateOid: data.oid,
+        codeClassifyOid: data.codeClassifyOid,
+      }).then((res) => {
+        this.resembleColumList = res.data.resembleTableVO.cols[0];
+      });
+    },
+    tab1TableSelectChange(selection) {
+      this.selectedTab1Table = selection;
+    },
+    resembleRowChange(row) {
+      getCurretnSelectedRowResemble({
+        redisOid: this.redisOid + "-resemble-data",
+        dataOid: row.oid,
+      }).then((res) => {
+        this.currentSelectedResemble = res.data;
+      });
+    },
+    openFormTemlpate(row) {
+      this.currentSelectedResembleRow = {
+        visible: true,
+        templateOid: row.codetemplateoid,
+        codeClassifyOid: this.localCodeClassifyOid,
+        rowOid: row.rowOid,
+      };
+    },
+    submit() {
+      const params = {
+        classifyAttr: this.classifyAttr,
+        isImprot: true,
+        codeImprotSaveDatVOList: [
+          {
+            Clos: this.cloNamesList.map((item) => item.title),
+            dataList: this.tab2Table.concat(this.selectedTab1Table),
+            orderDTO: {
+              codeClassifyOid: this.codeClassifyOid,
+              templateOid: this.templateOid,
+              secDTOList: [],
+            },
+          },
+        ],
+      };
+      submitHistoryimport(params).then((res) => {
+        if (res.code === 200) {
+          this.$message.success(res.obj);
+        } else {
+          this.$message.error(res.obj);
+        }
+      });
     },
   },
   watch: {
@@ -234,5 +318,10 @@
       overflow-y: scroll;
     }
   }
+  .right {
+    margin-left: 20px;
+    margin-top: 30px;
+    width: 1000px;
+  }
 }
 </style>

--
Gitblit v1.9.3