1d5efb3c5777cebbcc0778c26f538f3f.json 37 KB

1
  1. {"remainingRequest":"E:\\mec-cloud_IntelligentManufacturing_CRM\\mec-cloud_IntelligentManufacturing_CRM\\ruoyi-ui\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!E:\\mec-cloud_IntelligentManufacturing_CRM\\mec-cloud_IntelligentManufacturing_CRM\\ruoyi-ui\\src\\views\\system\\fromModeling\\package\\components\\KFormDesign\\module\\formComponentPanel.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\mec-cloud_IntelligentManufacturing_CRM\\mec-cloud_IntelligentManufacturing_CRM\\ruoyi-ui\\src\\views\\system\\fromModeling\\package\\components\\KFormDesign\\module\\formComponentPanel.vue","mtime":1688724235534},{"path":"E:\\mec-cloud_IntelligentManufacturing_CRM\\mec-cloud_IntelligentManufacturing_CRM\\ruoyi-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1688725391035},{"path":"E:\\mec-cloud_IntelligentManufacturing_CRM\\mec-cloud_IntelligentManufacturing_CRM\\ruoyi-ui\\node_modules\\babel-loader\\lib\\index.js","mtime":1688725407620},{"path":"E:\\mec-cloud_IntelligentManufacturing_CRM\\mec-cloud_IntelligentManufacturing_CRM\\ruoyi-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1688725391035},{"path":"E:\\mec-cloud_IntelligentManufacturing_CRM\\mec-cloud_IntelligentManufacturing_CRM\\ruoyi-ui\\node_modules\\vue-loader\\lib\\index.js","mtime":1688725415411}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

import draggable from "vuedraggable";
import layoutItem from "./layoutItem";
import { message } from "ant-design-vue";

export default {
  name: "KCenter",
  data() {
    return {
      form: this.$form.createForm(this),
      insertAllowedType: [
        "input",
        "textarea",
        "number",
        "select",
        "checkbox",
        "radio",
        "date",
        "time",
        "rate",
        "slider",
        "uploadFile",
        "uploadImg",
        "cascader",
        "treeSelect",
        "switch",
        "text",
        "html"
      ],
      rightMenuSelectValue: {},
      showRightMenu: false,
      menuTop: 0,
      menuLeft: 0,
      trIndex: 0,
      tdIndex: 0
    };
  },
  props: {
    noModel: {
      type: Array,
      required: true
    },
    startType: {
      type: String,
      required: true
    },
    data: {
      type: Object,
      required: true
    },
    selectItem: {
      type: Object,
      default: () => {}
    },
    hideModel: {
      type: Boolean,
      default: false
    }
  },
  components: {
    draggable,
    layoutItem
  },
  methods: {
    deepClone(evt) {
      const newIndex = evt.newIndex;
      // json深拷贝一次
      const listString = JSON.stringify(this.data.list);
      this.data.list = JSON.parse(listString);
      // 删除icon及compoent属性
      delete this.data.list[newIndex].icon;
      delete this.data.list[newIndex].component;
      this.$emit("handleSetSelectItem", this.data.list[newIndex]);
    },
    handleColAdd(evt, columns, isCopy = false) {
      // 重置或者生成key值
      const newIndex = evt.newIndex;
      const key = columns[newIndex].type + "_" + new Date().getTime();
      if (columns[newIndex].key === "" || isCopy) {
        this.$set(columns, newIndex, {
          ...columns[newIndex],
          key,
          model: key
        });
        if (this.noModel.includes(columns[newIndex].type)) {
          // 删除不需要的model属性
          delete columns[newIndex].model;
        }
        if (typeof columns[newIndex].options !== "undefined") {
          // 深拷贝options
          const optionsStr = JSON.stringify(columns[newIndex].options);
          columns[newIndex].options = JSON.parse(optionsStr);
        }
        if (typeof columns[newIndex].rules !== "undefined") {
          // 深拷贝rules
          const rulesStr = JSON.stringify(columns[newIndex].rules);
          columns[newIndex].rules = JSON.parse(rulesStr);
        }
        if (typeof columns[newIndex].list !== "undefined") {
          // 深拷贝list
          columns[newIndex].list = [];
        }
        if (typeof columns[newIndex].columns !== "undefined") {
          // 深拷贝columns
          const columnsStr = JSON.stringify(columns[newIndex].columns);
          columns[newIndex].columns = JSON.parse(columnsStr);
          // 复制时，清空数据
          columns[newIndex].columns.forEach(item => {
            item.list = [];
          });
        }
        if (columns[newIndex].type === "table") {
          // 深拷贝trs
          const trsStr = JSON.stringify(columns[newIndex].trs);
          columns[newIndex].trs = JSON.parse(trsStr);
          // 复制时，清空数据
          columns[newIndex].trs.forEach(item => {
            item.tds.forEach(val => {
              val.list = [];
            });
          });
        }
      }
      // 深拷贝数据
      const listString = JSON.stringify(columns[newIndex]);
      columns[newIndex] = JSON.parse(listString);
      this.$emit("handleSetSelectItem", columns[newIndex]);
    },
    dragStart(evt, list) {
      // 拖拽结束,自动选择拖拽的控件项
      this.$emit("handleSetSelectItem", list[evt.oldIndex]);
    },
    handleSelectItem(record) {
      // 修改选择Item
      this.$emit("handleSetSelectItem", record);
    },
    handleCopy(isCopy = true, data) {
      const traverse = array => {
        array.forEach((element, index) => {
          if (element.key === this.selectItem.key) {
            if (isCopy) {
              // 复制添加到选择节点后面
              array.splice(index + 1, 0, element);
            } else {
              // 双击添加到选择节点后面
              array.splice(index + 1, 0, data);
            }
            // 复制完成，重置key值
            const evt = {
              newIndex: index + 1
            };
            this.handleColAdd(evt, array, true);
            return;
          }
          if (["grid", "tabs", "selectInputList"].includes(element.type)) {
            // 栅格布局
            element.columns.forEach(item => {
              traverse(item.list);
            });
          } else if (element.type === "card") {
            // 卡片布局
            traverse(element.list);
          } else if (element.type === "batch") {
            // 动态表格内复制
            if (!isCopy && !this.insertAllowedType.includes(data.type)) {
              // 插入不允许的字段时，直接return false
              return false;
            }
            traverse(element.list);
          }
          if (element.type === "table") {
            // 表格布局
            element.trs.forEach(item => {
              item.tds.forEach(val => {
                traverse(val.list);
              });
            });
          }
        });
      };
      traverse(this.data.list);
    },
    handleDelete() {
      // 删除已选择
      const traverse = array => {
        array = array.filter((element, index) => {
          if (["grid", "tabs", "selectInputList"].includes(element.type)) {
            // 栅格布局
            element.columns.forEach(item => {
              item.list = traverse(item.list);
            });
          }
          if (element.type === "card" || element.type === "batch") {
            // 卡片布局
            element.list = traverse(element.list);
          }
          if (element.type === "table") {
            // 表格布局
            element.trs.forEach(item => {
              item.tds.forEach(val => {
                val.list = traverse(val.list);
              });
            });
          }
          if (element.key !== this.selectItem.key) {
            return true;
          } else {
            if (array.length === 1) {
              this.handleSelectItem({ key: "" });
            } else if (array.length - 1 > index) {
              this.handleSelectItem(array[index + 1]);
            } else {
              this.handleSelectItem(array[index - 1]);
            }
            return false;
          }
        });
        return array;
      };

      this.data.list = traverse(this.data.list);
    },
    handleDownMerge() {
      // 向下合并

      // 判断当前行是否是最后一行，最后一行无法向下合并
      if (
        this.rightMenuSelectValue.trs.length -
          this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex]
            .rowspan <=
        this.trIndex
      ) {
        message.error("当前是最后一行，无法向下合并");
        return false;
      }

      // 获取当前单元格的rowspan
      const currentRowspan = this.rightMenuSelectValue.trs[this.trIndex].tds[
        this.tdIndex
      ].rowspan;

      // 判断下一列单元格与当前单元格的colspan是否一致，如果不一致则无法合并
      if (
        this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex]
          .colspan !==
        this.rightMenuSelectValue.trs[this.trIndex + currentRowspan].tds[
          this.tdIndex
        ].colspan
      ) {
        message.error("当前表格无法向下合并");
        return false;
      }

      // 获取下一列单元格的rowspan
      const nextRowSpan = this.rightMenuSelectValue.trs[
        this.trIndex + currentRowspan
      ].tds[this.tdIndex].rowspan;

      // 当前单元格rowspan等于当前单元格rowspan加上下一列单元格rowspan
      this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex].rowspan =
        currentRowspan + nextRowSpan;

      // 将被合并的单元rowspan修改为0
      this.rightMenuSelectValue.trs[this.trIndex + currentRowspan].tds[
        this.tdIndex
      ].rowspan = 0;

      // 清空被合并单元格list
      this.rightMenuSelectValue.trs[this.trIndex + currentRowspan].tds[
        this.tdIndex
      ].list = [];
    },
    handleRightMerge() {
      // 向右合并
      // 获取当前列的所有colspan总和
      const sumCols = this.rightMenuSelectValue.trs[this.trIndex].tds
        .map(item => item.colspan)
        .reduce(function(partial, value) {
          return partial + value;
        });

      // 判断是否是最后一列，最后一列无法继续向右合并
      if (
        sumCols -
          this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex]
            .colspan <=
        this.tdIndex
      ) {
        message.error("当前是最后一列，无法向右合并");
        return false;
      }

      // 获取当前单元格的colspan
      const currentColspan = this.rightMenuSelectValue.trs[this.trIndex].tds[
        this.tdIndex
      ].colspan;

      // 判断需要合并的单元格rowspan是否与当前单元格一致
      if (
        this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex]
          .rowspan !==
        this.rightMenuSelectValue.trs[this.trIndex].tds[
          this.tdIndex + currentColspan
        ].rowspan
      ) {
        message.error("当前表格无法向右合并");
        return false;
      }

      // 合并单元格colspan
      this.rightMenuSelectValue.trs[this.trIndex].tds[
        this.tdIndex
      ].colspan += this.rightMenuSelectValue.trs[this.trIndex].tds[
        this.tdIndex + currentColspan
      ].colspan;

      // 将被合并的单元格colspan设置为0
      this.rightMenuSelectValue.trs[this.trIndex].tds[
        this.tdIndex + currentColspan
      ].colspan = 0;

      // 情况被合并单元格的list
      this.rightMenuSelectValue.trs[this.trIndex].tds[
        this.tdIndex + currentColspan
      ].list = [];
    },
    // 拆分单元格
    handleRightSplit() {
      // 获取当前单元格的colspan及rowspan
      const { colspan, rowspan } = this.rightMenuSelectValue.trs[
        this.trIndex
      ].tds[this.tdIndex];

      for (
        let rowIndex = this.trIndex, rowLen = this.trIndex + rowspan;
        rowIndex < rowLen;
        rowIndex++
      ) {
        for (
          let colIndex = this.tdIndex, colLen = this.tdIndex + colspan;
          colIndex < colLen;
          colIndex++
        ) {
          if (rowIndex === this.trIndex && colIndex === this.tdIndex) continue;
          this.rightMenuSelectValue.trs[rowIndex].tds.splice(colIndex, 1, {
            colspan: 1,
            rowspan: 1,
            list: []
          });
        }
      }
      // 修改当前单元格colspan、rowspan为1
      this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex].colspan = 1;
      this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex].rowspan = 1;
    },
    handleAddCol() {
      // 增加列

      this.rightMenuSelectValue.trs.forEach(item => {
        item.tds.splice(this.tdIndex + 1, 0, {
          colspan: 1,
          rowspan: 1,
          list: []
        });
      });
    },
    handleAddRow() {
      // 增加行
      // 获取总col值
      const sumCols = this.rightMenuSelectValue.trs[0].tds
        .map(item => item.colspan)
        .reduce(function(partial, value) {
          return partial + value;
        });
      const rowJson = { tds: [] };
      for (let i = 0; i < sumCols; i++) {
        rowJson.tds.push({
          colspan: 1,
          rowspan: 1,
          list: []
        });
      }

      // 取当前rowspan最大值
      let maxRowSpan = 1;
      this.rightMenuSelectValue.trs[this.trIndex].tds.forEach(item => {
        if (maxRowSpan < item.rowspan) {
          maxRowSpan = item.rowspan;
        }
      });

      // 在rowspan最大值处插入数据
      this.rightMenuSelectValue.trs.splice(
        this.trIndex + maxRowSpan,
        0,
        rowJson
      );
    },
    handleShowRightMenu(e, val, trIndex, tdIndex) {
      // 显示右键菜单
      e.stopPropagation();
      // this.fileItem = item
      // 显示
      this.showRightMenu = true;

      // 定位
      this.menuTop = e.clientY;
      this.menuLeft = e.clientX;
      // this.rightMenuType = type
      // this.rightId = id
      this.activeArr = [val];
      this.rightMenuSelectValue = val;
      this.trIndex = trIndex;
      this.tdIndex = tdIndex;
      return false;
    },
    handleRemoveRightMenu() {
      // 取消右键菜单
      this.showRightMenu = false;
    }
  },
  mounted() {
    // 添加监听取消右键菜单
    document.addEventListener("click", this.handleRemoveRightMenu, true);
    document.addEventListener("contextmenu", this.handleRemoveRightMenu, true);
  },
  destroyed() {
    // 移除监听
    document.removeEventListener("click", this.handleRemoveRightMenu, true);
    document.removeEventListener(
      "contextmenu",
      this.handleRemoveRightMenu,
      true
    );
  }
};
"},{"version":3,"sources":["formComponentPanel.vue"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4EA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"formComponentPanel.vue","sourceRoot":"src/views/system/fromModeling/package/components/KFormDesign/module","sourcesContent":["<!--\n * @Description: 表单设计器内容展示操作组件\n * @Author: kcz\n * @Date: 2019-12-31 19:39:48\n * @LastEditors: kcz\n * @LastEditTime: 2022-11-12 00:11:55\n -->\n<template>\n <div class=\"form-panel\">\n <p class=\"hint-text\" v-show=\"data.list.length === 0\">\n <a-empty description=\"从左侧选择控件添加组件进行编辑\" />\n </p>\n\n <a-form\n class=\"a-form-box k-form-build\"\n :form=\"form\"\n selfUpdate\n :layout=\"data.config.layout\"\n :hideRequiredMark=\"data.config.hideRequiredMark\"\n :style=\"data.config.customStyle\"\n >\n <draggable\n tag=\"div\"\n class=\"draggable-box\"\n v-bind=\"{\n group: 'form-draggable',\n ghostClass: 'moving',\n animation: 180,\n handle: '.drag-move'\n }\"\n v-model=\"data.list\"\n @add=\"deepClone\"\n @start=\"dragStart($event, data.list)\"\n >\n <transition-group tag=\"div\" name=\"list\" class=\"list-main\">\n <layoutItem\n class=\"drag-move\"\n v-for=\"record in data.list\"\n :key=\"record.key\"\n :record=\"record\"\n :config=\"data.config\"\n :selectItem.sync=\"selectItem\"\n :startType=\"startType\"\n :insertAllowedType=\"insertAllowedType\"\n :hideModel=\"hideModel\"\n @dragStart=\"dragStart\"\n @handleSelectItem=\"handleSelectItem\"\n @handleCopy=\"handleCopy\"\n @handleDelete=\"handleDelete\"\n @handleColAdd=\"handleColAdd\"\n @handleShowRightMenu=\"handleShowRightMenu\"\n />\n </transition-group>\n </draggable>\n </a-form>\n <!-- 右键菜单 start -->\n <div\n v-show=\"showRightMenu\"\n :style=\"{ top: menuTop + 'px', left: menuLeft + 'px' }\"\n class=\"right-menu\"\n >\n <ul>\n <li @click=\"handleDownMerge\"><a-icon type=\"caret-down\" />向下合并</li>\n <li @click=\"handleRightMerge\"><a-icon type=\"caret-right\" />向右合并</li>\n <li @click=\"handleRightSplit\">\n <a-icon type=\"border-inner\" />拆分单元格\n </li>\n <li @click=\"handleAddCol\">\n <a-icon type=\"border-horizontal\" />增加一列\n </li>\n <li @click=\"handleAddRow\"><a-icon type=\"border-verticle\" />增加一行</li>\n </ul>\n </div>\n </div>\n</template>\n<script>\nimport draggable from \"vuedraggable\";\nimport layoutItem from \"./layoutItem\";\nimport { message } from \"ant-design-vue\";\n\nexport default {\n name: \"KCenter\",\n data() {\n return {\n form: this.$form.createForm(this),\n insertAllowedType: [\n \"input\",\n \"textarea\",\n \"number\",\n \"select\",\n \"checkbox\",\n \"radio\",\n \"date\",\n \"time\",\n \"rate\",\n \"slider\",\n \"uploadFile\",\n \"uploadImg\",\n \"cascader\",\n \"treeSelect\",\n \"switch\",\n \"text\",\n \"html\"\n ],\n rightMenuSelectValue: {},\n showRightMenu: false,\n menuTop: 0,\n menuLeft: 0,\n trIndex: 0,\n tdIndex: 0\n };\n },\n props: {\n noModel: {\n type: Array,\n required: true\n },\n startType: {\n type: String,\n required: true\n },\n data: {\n type: Object,\n required: true\n },\n selectItem: {\n type: Object,\n default: () => {}\n },\n hideModel: {\n type: Boolean,\n default: false\n }\n },\n components: {\n draggable,\n layoutItem\n },\n methods: {\n deepClone(evt) {\n const newIndex = evt.newIndex;\n // json深拷贝一次\n const listString = JSON.stringify(this.data.list);\n this.data.list = JSON.parse(listString);\n // 删除icon及compoent属性\n delete this.data.list[newIndex].icon;\n delete this.data.list[newIndex].component;\n this.$emit(\"handleSetSelectItem\", this.data.list[newIndex]);\n },\n handleColAdd(evt, columns, isCopy = false) {\n // 重置或者生成key值\n const newIndex = evt.newIndex;\n const key = columns[newIndex].type + \"_\" + new Date().getTime();\n if (columns[newIndex].key === \"\" || isCopy) {\n this.$set(columns, newIndex, {\n ...columns[newIndex],\n key,\n model: key\n });\n if (this.noModel.includes(columns[newIndex].type)) {\n // 删除不需要的model属性\n delete columns[newIndex].model;\n }\n if (typeof columns[newIndex].options !== \"undefined\") {\n // 深拷贝options\n const optionsStr = JSON.stringify(columns[newIndex].options);\n columns[newIndex].options = JSON.parse(optionsStr);\n }\n if (typeof columns[newIndex].rules !== \"undefined\") {\n // 深拷贝rules\n const rulesStr = JSON.stringify(columns[newIndex].rules);\n columns[newIndex].rules = JSON.parse(rulesStr);\n }\n if (typeof columns[newIndex].list !== \"undefined\") {\n // 深拷贝list\n columns[newIndex].list = [];\n }\n if (typeof columns[newIndex].columns !== \"undefined\") {\n // 深拷贝columns\n const columnsStr = JSON.stringify(columns[newIndex].columns);\n columns[newIndex].columns = JSON.parse(columnsStr);\n // 复制时,清空数据\n columns[newIndex].columns.forEach(item => {\n item.list = [];\n });\n }\n if (columns[newIndex].type === \"table\") {\n // 深拷贝trs\n const trsStr = JSON.stringify(columns[newIndex].trs);\n columns[newIndex].trs = JSON.parse(trsStr);\n // 复制时,清空数据\n columns[newIndex].trs.forEach(item => {\n item.tds.forEach(val => {\n val.list = [];\n });\n });\n }\n }\n // 深拷贝数据\n const listString = JSON.stringify(columns[newIndex]);\n columns[newIndex] = JSON.parse(listString);\n this.$emit(\"handleSetSelectItem\", columns[newIndex]);\n },\n dragStart(evt, list) {\n // 拖拽结束,自动选择拖拽的控件项\n this.$emit(\"handleSetSelectItem\", list[evt.oldIndex]);\n },\n handleSelectItem(record) {\n // 修改选择Item\n this.$emit(\"handleSetSelectItem\", record);\n },\n handleCopy(isCopy = true, data) {\n const traverse = array => {\n array.forEach((element, index) => {\n if (element.key === this.selectItem.key) {\n if (isCopy) {\n // 复制添加到选择节点后面\n array.splice(index + 1, 0, element);\n } else {\n // 双击添加到选择节点后面\n array.splice(index + 1, 0, data);\n }\n // 复制完成,重置key值\n const evt = {\n newIndex: index + 1\n };\n this.handleColAdd(evt, array, true);\n return;\n }\n if ([\"grid\", \"tabs\", \"selectInputList\"].includes(element.type)) {\n // 栅格布局\n element.columns.forEach(item => {\n traverse(item.list);\n });\n } else if (element.type === \"card\") {\n // 卡片布局\n traverse(element.list);\n } else if (element.type === \"batch\") {\n // 动态表格内复制\n if (!isCopy && !this.insertAllowedType.includes(data.type)) {\n // 插入不允许的字段时,直接return false\n return false;\n }\n traverse(element.list);\n }\n if (element.type === \"table\") {\n // 表格布局\n element.trs.forEach(item => {\n item.tds.forEach(val => {\n traverse(val.list);\n });\n });\n }\n });\n };\n traverse(this.data.list);\n },\n handleDelete() {\n // 删除已选择\n const traverse = array => {\n array = array.filter((element, index) => {\n if ([\"grid\", \"tabs\", \"selectInputList\"].includes(element.type)) {\n // 栅格布局\n element.columns.forEach(item => {\n item.list = traverse(item.list);\n });\n }\n if (element.type === \"card\" || element.type === \"batch\") {\n // 卡片布局\n element.list = traverse(element.list);\n }\n if (element.type === \"table\") {\n // 表格布局\n element.trs.forEach(item => {\n item.tds.forEach(val => {\n val.list = traverse(val.list);\n });\n });\n }\n if (element.key !== this.selectItem.key) {\n return true;\n } else {\n if (array.length === 1) {\n this.handleSelectItem({ key: \"\" });\n } else if (array.length - 1 > index) {\n this.handleSelectItem(array[index + 1]);\n } else {\n this.handleSelectItem(array[index - 1]);\n }\n return false;\n }\n });\n return array;\n };\n\n this.data.list = traverse(this.data.list);\n },\n handleDownMerge() {\n // 向下合并\n\n // 判断当前行是否是最后一行,最后一行无法向下合并\n if (\n this.rightMenuSelectValue.trs.length -\n this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex]\n .rowspan <=\n this.trIndex\n ) {\n message.error(\"当前是最后一行,无法向下合并\");\n return false;\n }\n\n // 获取当前单元格的rowspan\n const currentRowspan = this.rightMenuSelectValue.trs[this.trIndex].tds[\n this.tdIndex\n ].rowspan;\n\n // 判断下一列单元格与当前单元格的colspan是否一致,如果不一致则无法合并\n if (\n this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex]\n .colspan !==\n this.rightMenuSelectValue.trs[this.trIndex + currentRowspan].tds[\n this.tdIndex\n ].colspan\n ) {\n message.error(\"当前表格无法向下合并\");\n return false;\n }\n\n // 获取下一列单元格的rowspan\n const nextRowSpan = this.rightMenuSelectValue.trs[\n this.trIndex + currentRowspan\n ].tds[this.tdIndex].rowspan;\n\n // 当前单元格rowspan等于当前单元格rowspan加上下一列单元格rowspan\n this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex].rowspan =\n currentRowspan + nextRowSpan;\n\n // 将被合并的单元rowspan修改为0\n this.rightMenuSelectValue.trs[this.trIndex + currentRowspan].tds[\n this.tdIndex\n ].rowspan = 0;\n\n // 清空被合并单元格list\n this.rightMenuSelectValue.trs[this.trIndex + currentRowspan].tds[\n this.tdIndex\n ].list = [];\n },\n handleRightMerge() {\n // 向右合并\n // 获取当前列的所有colspan总和\n const sumCols = this.rightMenuSelectValue.trs[this.trIndex].tds\n .map(item => item.colspan)\n .reduce(function(partial, value) {\n return partial + value;\n });\n\n // 判断是否是最后一列,最后一列无法继续向右合并\n if (\n sumCols -\n this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex]\n .colspan <=\n this.tdIndex\n ) {\n message.error(\"当前是最后一列,无法向右合并\");\n return false;\n }\n\n // 获取当前单元格的colspan\n const currentColspan = this.rightMenuSelectValue.trs[this.trIndex].tds[\n this.tdIndex\n ].colspan;\n\n // 判断需要合并的单元格rowspan是否与当前单元格一致\n if (\n this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex]\n .rowspan !==\n this.rightMenuSelectValue.trs[this.trIndex].tds[\n this.tdIndex + currentColspan\n ].rowspan\n ) {\n message.error(\"当前表格无法向右合并\");\n return false;\n }\n\n // 合并单元格colspan\n this.rightMenuSelectValue.trs[this.trIndex].tds[\n this.tdIndex\n ].colspan += this.rightMenuSelectValue.trs[this.trIndex].tds[\n this.tdIndex + currentColspan\n ].colspan;\n\n // 将被合并的单元格colspan设置为0\n this.rightMenuSelectValue.trs[this.trIndex].tds[\n this.tdIndex + currentColspan\n ].colspan = 0;\n\n // 情况被合并单元格的list\n this.rightMenuSelectValue.trs[this.trIndex].tds[\n this.tdIndex + currentColspan\n ].list = [];\n },\n // 拆分单元格\n handleRightSplit() {\n // 获取当前单元格的colspan及rowspan\n const { colspan, rowspan } = this.rightMenuSelectValue.trs[\n this.trIndex\n ].tds[this.tdIndex];\n\n for (\n let rowIndex = this.trIndex, rowLen = this.trIndex + rowspan;\n rowIndex < rowLen;\n rowIndex++\n ) {\n for (\n let colIndex = this.tdIndex, colLen = this.tdIndex + colspan;\n colIndex < colLen;\n colIndex++\n ) {\n if (rowIndex === this.trIndex && colIndex === this.tdIndex) continue;\n this.rightMenuSelectValue.trs[rowIndex].tds.splice(colIndex, 1, {\n colspan: 1,\n rowspan: 1,\n list: []\n });\n }\n }\n // 修改当前单元格colspan、rowspan为1\n this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex].colspan = 1;\n this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex].rowspan = 1;\n },\n handleAddCol() {\n // 增加列\n\n this.rightMenuSelectValue.trs.forEach(item => {\n item.tds.splice(this.tdIndex + 1, 0, {\n colspan: 1,\n rowspan: 1,\n list: []\n });\n });\n },\n handleAddRow() {\n // 增加行\n // 获取总col值\n const sumCols = this.rightMenuSelectValue.trs[0].tds\n .map(item => item.colspan)\n .reduce(function(partial, value) {\n return partial + value;\n });\n const rowJson = { tds: [] };\n for (let i = 0; i < sumCols; i++) {\n rowJson.tds.push({\n colspan: 1,\n rowspan: 1,\n list: []\n });\n }\n\n // 取当前rowspan最大值\n let maxRowSpan = 1;\n this.rightMenuSelectValue.trs[this.trIndex].tds.forEach(item => {\n if (maxRowSpan < item.rowspan) {\n maxRowSpan = item.rowspan;\n }\n });\n\n // 在rowspan最大值处插入数据\n this.rightMenuSelectValue.trs.splice(\n this.trIndex + maxRowSpan,\n 0,\n rowJson\n );\n },\n handleShowRightMenu(e, val, trIndex, tdIndex) {\n // 显示右键菜单\n e.stopPropagation();\n // this.fileItem = item\n // 显示\n this.showRightMenu = true;\n\n // 定位\n this.menuTop = e.clientY;\n this.menuLeft = e.clientX;\n // this.rightMenuType = type\n // this.rightId = id\n this.activeArr = [val];\n this.rightMenuSelectValue = val;\n this.trIndex = trIndex;\n this.tdIndex = tdIndex;\n return false;\n },\n handleRemoveRightMenu() {\n // 取消右键菜单\n this.showRightMenu = false;\n }\n },\n mounted() {\n // 添加监听取消右键菜单\n document.addEventListener(\"click\", this.handleRemoveRightMenu, true);\n document.addEventListener(\"contextmenu\", this.handleRemoveRightMenu, true);\n },\n destroyed() {\n // 移除监听\n document.removeEventListener(\"click\", this.handleRemoveRightMenu, true);\n document.removeEventListener(\n \"contextmenu\",\n this.handleRemoveRightMenu,\n true\n );\n }\n};\n</script>\n"]}]}