| | |
| | | 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 + 'px' }" v-show="false">
|
| | | <div
|
| | | class="left"
|
| | | :style="{ width: leftWidth + 'px' }"
|
| | | v-show="type !== 'batchImportApply'"
|
| | | >
|
| | | <div class="isExpand_box">
|
| | | <el-link type="primary" @click="hideTree">
|
| | | <i
|
| | |
| | | v-show="isExpand"
|
| | | class="filter_tree"
|
| | | :data="leftTree"
|
| | | node-key="codeClassifyOid"
|
| | | default-expand-all
|
| | | highlight-current
|
| | | :filter-node-method="filterNode"
|
| | |
| | | >
|
| | | </el-tree>
|
| | | </div>
|
| | | <div class="right" :style="{ width: 1280 - leftWidth - 60 + 'px' }">
|
| | | <div class="right" :style="{ width: 1280 - leftWidth - 60 + 'px' }">
|
| | | <div class="tab_box" style="width: 100%">
|
| | | <el-tabs
|
| | | style="width: 100%"
|
| | |
| | | @selection-change="tab1TableSelectChange"
|
| | | v-if="cloNamesList.length > 1"
|
| | | >
|
| | | <el-table-column
|
| | | <el-table-column
|
| | | 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-column
|
| | | type="index"
|
| | | label="序号"
|
| | |
| | | </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-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="600px">
|
| | | <el-table
|
| | | border
|
| | | :data="tab2Table"
|
| | | :height="
|
| | | type === 'batchApplyCode' && tab2Table.length > 0
|
| | | ? '400px'
|
| | | : '700px'
|
| | | "
|
| | | >
|
| | | <el-table-column
|
| | | v-for="item in cloNamesList"
|
| | | v-for="item in successTableColumns"
|
| | | :key="item.field"
|
| | | :prop="item.field"
|
| | | :label="item.title"
|
| | |
| | | >
|
| | | </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>
|
| | | </div>
|
| | | <template #footer>
|
| | |
| | | </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";
|
| | |
| | | export default {
|
| | | name: "ShowImportData",
|
| | | components: { ResembleQuery, FormTemplate },
|
| | | // mixins: [codeApply],
|
| | | mixins: [codeApply],
|
| | | props: {
|
| | | title: {
|
| | | type: String,
|
| | |
| | | type: String,
|
| | | secDTOList: {
|
| | | type: Array,
|
| | | default: () => ({})
|
| | | }
|
| | | default: () => ({}),
|
| | | },
|
| | | },
|
| | | computed: {
|
| | | dialogVisible: {
|
| | |
| | | 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: "200",
|
| | | leftWidth: 200,
|
| | | templateOid: null,
|
| | | tab1Name: "相似项",
|
| | | tab2Name: "正确数据",
|
| | |
| | | activeTab: "tab1",
|
| | | cloNamesList: [], //列表头部字段
|
| | | localCodeClassifyOid: "",
|
| | | codeRuleOid: "",
|
| | | resembleColumList: [], //相似项查出来的列表字段
|
| | | currentSelectedResemble: [],
|
| | | currentSelectedResembleRow: {
|
| | |
| | | codeClassifyOid: "",
|
| | | rowOid: "",
|
| | | formTemplateVisible: false,
|
| | | type: "detail",
|
| | | title: "查看详细信息",
|
| | | setForm: {},
|
| | | },
|
| | | secVOList: [],
|
| | | batchApplyCodeTableData: {},
|
| | | savedList: [],
|
| | | };
|
| | | },
|
| | |
|
| | |
| | | },
|
| | | hideTree() {
|
| | | if (this.isExpand) {
|
| | | this.leftWidth = "50";
|
| | | this.leftWidth = 50;
|
| | | } else {
|
| | | this.leftWidth = "200";
|
| | | this.leftWidth = 200;
|
| | | }
|
| | | this.isExpand = !this.isExpand;
|
| | | },
|
| | | treeNodeClick(data) {
|
| | | console.log(data);
|
| | | this.localCodeClassifyOid = 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;
|
| | | this.templateOid = data.oid;
|
| | | getHistorySuccessTable({
|
| | | codeClassifyOid: this.templateOid,
|
| | | getResembleTable({
|
| | | codeClassifyOid:
|
| | | this.type === "batchApplyCode" ? data.codeRuleOid : this.templateOid,
|
| | | redisOid: this.redisOid + "-resemble",
|
| | | }).then((res) => {
|
| | | this.tab1Table = res.data.data.filter(
|
| | | (item) => !this.savedList.includes(item.oid)
|
| | | );
|
| | | if (this.type === "batchApplyCode") {
|
| | | this.batchApplyCodeTableData[data.codeRuleOid]["tab1"] =
|
| | | this.tab1Table;
|
| | | }
|
| | | });
|
| | | // 获取正确数据
|
| | | getSuccessTable({
|
| | | codeClassifyOid:
|
| | | this.type === "batchApplyCode" ? data.codeRuleOid : this.templateOid,
|
| | | redisOid: this.redisOid + "-ok",
|
| | | }).then((res) => {
|
| | | this.tab2Table = res.data.data;
|
| | | });
|
| | | getHistoryResembleTable({
|
| | | codeClassifyOid: this.templateOid,
|
| | | redisOid: this.redisOid + "-resemble",
|
| | | }).then((res) => {
|
| | | this.tab1Table = 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,
|
| | |
| | | this.selectedTab1Table = selection;
|
| | | },
|
| | | resembleRowChange(row) {
|
| | | if (!row || !row.oid) {
|
| | | return;
|
| | | }
|
| | | getCurretnSelectedRowResemble({
|
| | | redisOid: this.redisOid + "-resemble-data",
|
| | | dataOid: row.oid,
|
| | |
| | | },
|
| | | openFormTemlpate(row) {
|
| | | this.currentSelectedResembleRow = {
|
| | | visible: true,
|
| | | formTemplateVisible: true,
|
| | | templateOid: row.codetemplateoid,
|
| | | codeClassifyOid: this.localCodeClassifyOid,
|
| | | rowOid: row.rowOid,
|
| | | type: "detail",
|
| | | title: "查看详细信息",
|
| | | setForm: {},
|
| | | };
|
| | | },
|
| | | submit() {
|
| | | const params = {
|
| | | classifyAttr: this.type === 'historyImport' ? this.classifyAttr : undefined,
|
| | | improt: this.type === 'historyImport' ? true : false,
|
| | | codeImprotSaveDatVOList: [
|
| | | 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("导入的数据中没有正确的数据!");
|
| | | 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),
|
| | |
| | | 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: {},
|
| | | };
|
| | | }
|
| | | });
|
| | | },
|
| | |
| | | immediate: true,
|
| | | deep: true,
|
| | | handler(arr) {
|
| | | if (arr.length > 0 && this.type === 'batchImportApply') {
|
| | | this.treeNodeClick(arr[0])
|
| | | this.leftWidth = 0
|
| | | 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 = "正确数据";
|
| | | this.leftWidth = 200;
|
| | | }
|
| | | }
|
| | | }
|
| | | }
|
| | | },
|
| | | },
|
| | | },
|
| | | };
|
| | | </script>
|