1 |
- {"remainingRequest":"E:\\mec-cloud_IntelligentManufacturing_CRM\\mec-cloud_IntelligentManufacturing_CRM\\ruoyi-ui\\node_modules\\babel-loader\\lib\\index.js!E:\\mec-cloud_IntelligentManufacturing_CRM\\mec-cloud_IntelligentManufacturing_CRM\\ruoyi-ui\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!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\\babel.config.js","mtime":1688713370854},{"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:"use strict";

var _interopRequireDefault = require("E:/mec-cloud_IntelligentManufacturing_CRM/mec-cloud_IntelligentManufacturing_CRM/ruoyi-ui/node_modules/@babel/runtime/helpers/interopRequireDefault.js").default;
Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.default = void 0;
var _objectSpread2 = _interopRequireDefault(require("E:/mec-cloud_IntelligentManufacturing_CRM/mec-cloud_IntelligentManufacturing_CRM/ruoyi-ui/node_modules/@babel/runtime/helpers/objectSpread2.js"));
require("core-js/modules/es.json.stringify.js");
require("core-js/modules/es.object.keys.js");
require("core-js/modules/es.array.includes.js");
require("core-js/modules/es.string.includes.js");
require("core-js/modules/es.object.to-string.js");
require("core-js/modules/web.dom-collections.for-each.js");
require("core-js/modules/es.array.splice.js");
require("core-js/modules/es.array.filter.js");
require("core-js/modules/es.array.reduce.js");
require("core-js/modules/es.array.map.js");
require("core-js/modules/es.array.push.js");
var _vuedraggable = _interopRequireDefault(require("vuedraggable"));
var _layoutItem = _interopRequireDefault(require("./layoutItem"));
var _antDesignVue = require("ant-design-vue");
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
var _default2 = {
  name: "KCenter",
  data: function 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: function _default() {}
    },
    hideModel: {
      type: Boolean,
      default: false
    }
  },
  components: {
    draggable: _vuedraggable.default,
    layoutItem: _layoutItem.default
  },
  methods: {
    deepClone: function deepClone(evt) {
      var newIndex = evt.newIndex;
      // json深拷贝一次
      var 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: function handleColAdd(evt, columns) {
      var isCopy = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
      // 重置或者生成key值
      var newIndex = evt.newIndex;
      var key = columns[newIndex].type + "_" + new Date().getTime();
      if (columns[newIndex].key === "" || isCopy) {
        this.$set(columns, newIndex, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, columns[newIndex]), {}, {
          key: key,
          model: key
        }));
        if (this.noModel.includes(columns[newIndex].type)) {
          // 删除不需要的model属性
          delete columns[newIndex].model;
        }
        if (typeof columns[newIndex].options !== "undefined") {
          // 深拷贝options
          var optionsStr = JSON.stringify(columns[newIndex].options);
          columns[newIndex].options = JSON.parse(optionsStr);
        }
        if (typeof columns[newIndex].rules !== "undefined") {
          // 深拷贝rules
          var 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
          var columnsStr = JSON.stringify(columns[newIndex].columns);
          columns[newIndex].columns = JSON.parse(columnsStr);
          // 复制时，清空数据
          columns[newIndex].columns.forEach(function (item) {
            item.list = [];
          });
        }
        if (columns[newIndex].type === "table") {
          // 深拷贝trs
          var trsStr = JSON.stringify(columns[newIndex].trs);
          columns[newIndex].trs = JSON.parse(trsStr);
          // 复制时，清空数据
          columns[newIndex].trs.forEach(function (item) {
            item.tds.forEach(function (val) {
              val.list = [];
            });
          });
        }
      }
      // 深拷贝数据
      var listString = JSON.stringify(columns[newIndex]);
      columns[newIndex] = JSON.parse(listString);
      this.$emit("handleSetSelectItem", columns[newIndex]);
    },
    dragStart: function dragStart(evt, list) {
      // 拖拽结束,自动选择拖拽的控件项
      this.$emit("handleSetSelectItem", list[evt.oldIndex]);
    },
    handleSelectItem: function handleSelectItem(record) {
      // 修改选择Item
      this.$emit("handleSetSelectItem", record);
    },
    handleCopy: function handleCopy() {
      var _this = this;
      var isCopy = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;
      var data = arguments.length > 1 ? arguments[1] : undefined;
      var traverse = function traverse(array) {
        array.forEach(function (element, index) {
          if (element.key === _this.selectItem.key) {
            if (isCopy) {
              // 复制添加到选择节点后面
              array.splice(index + 1, 0, element);
            } else {
              // 双击添加到选择节点后面
              array.splice(index + 1, 0, data);
            }
            // 复制完成，重置key值
            var evt = {
              newIndex: index + 1
            };
            _this.handleColAdd(evt, array, true);
            return;
          }
          if (["grid", "tabs", "selectInputList"].includes(element.type)) {
            // 栅格布局
            element.columns.forEach(function (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(function (item) {
              item.tds.forEach(function (val) {
                traverse(val.list);
              });
            });
          }
        });
      };
      traverse(this.data.list);
    },
    handleDelete: function handleDelete() {
      var _this2 = this;
      // 删除已选择
      var traverse = function traverse(array) {
        array = array.filter(function (element, index) {
          if (["grid", "tabs", "selectInputList"].includes(element.type)) {
            // 栅格布局
            element.columns.forEach(function (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(function (item) {
              item.tds.forEach(function (val) {
                val.list = traverse(val.list);
              });
            });
          }
          if (element.key !== _this2.selectItem.key) {
            return true;
          } else {
            if (array.length === 1) {
              _this2.handleSelectItem({
                key: ""
              });
            } else if (array.length - 1 > index) {
              _this2.handleSelectItem(array[index + 1]);
            } else {
              _this2.handleSelectItem(array[index - 1]);
            }
            return false;
          }
        });
        return array;
      };
      this.data.list = traverse(this.data.list);
    },
    handleDownMerge: function handleDownMerge() {
      // 向下合并

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

      // 获取当前单元格的rowspan
      var 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) {
        _antDesignVue.message.error("当前表格无法向下合并");
        return false;
      }

      // 获取下一列单元格的rowspan
      var 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: function handleRightMerge() {
      // 向右合并
      // 获取当前列的所有colspan总和
      var sumCols = this.rightMenuSelectValue.trs[this.trIndex].tds.map(function (item) {
        return item.colspan;
      }).reduce(function (partial, value) {
        return partial + value;
      });

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

      // 获取当前单元格的colspan
      var 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) {
        _antDesignVue.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: function handleRightSplit() {
      // 获取当前单元格的colspan及rowspan
      var _this$rightMenuSelect = this.rightMenuSelectValue.trs[this.trIndex].tds[this.tdIndex],
        colspan = _this$rightMenuSelect.colspan,
        rowspan = _this$rightMenuSelect.rowspan;
      for (var rowIndex = this.trIndex, rowLen = this.trIndex + rowspan; rowIndex < rowLen; rowIndex++) {
        for (var 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: function handleAddCol() {
      var _this3 = this;
      // 增加列

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

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

      // 在rowspan最大值处插入数据
      this.rightMenuSelectValue.trs.splice(this.trIndex + maxRowSpan, 0, rowJson);
    },
    handleShowRightMenu: function 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: function handleRemoveRightMenu() {
      // 取消右键菜单
      this.showRightMenu = false;
    }
  },
  mounted: function mounted() {
    // 添加监听取消右键菜单
    document.addEventListener("click", this.handleRemoveRightMenu, true);
    document.addEventListener("contextmenu", this.handleRemoveRightMenu, true);
  },
  destroyed: function destroyed() {
    // 移除监听
    document.removeEventListener("click", this.handleRemoveRightMenu, true);
    document.removeEventListener("contextmenu", this.handleRemoveRightMenu, true);
  }
};
exports.default = _default2;"},{"version":3,"names":["_vuedraggable","_interopRequireDefault","require","_layoutItem","_antDesignVue","name","data","form","$form","createForm","insertAllowedType","rightMenuSelectValue","showRightMenu","menuTop","menuLeft","trIndex","tdIndex","props","noModel","type","Array","required","startType","String","Object","selectItem","default","_default","hideModel","Boolean","components","draggable","layoutItem","methods","deepClone","evt","newIndex","listString","JSON","stringify","list","parse","icon","component","$emit","handleColAdd","columns","isCopy","arguments","length","undefined","key","Date","getTime","$set","_objectSpread2","model","includes","options","optionsStr","rules","rulesStr","columnsStr","forEach","item","trsStr","trs","tds","val","dragStart","oldIndex","handleSelectItem","record","handleCopy","_this","traverse","array","element","index","splice","handleDelete","_this2","filter","handleDownMerge","rowspan","message","error","currentRowspan","colspan","nextRowSpan","handleRightMerge","sumCols","map","reduce","partial","value","currentColspan","handleRightSplit","_this$rightMenuSelect","rowIndex","rowLen","colIndex","colLen","handleAddCol","_this3","handleAddRow","rowJson","i","push","maxRowSpan","handleShowRightMenu","e","stopPropagation","clientY","clientX","activeArr","handleRemoveRightMenu","mounted","document","addEventListener","destroyed","removeEventListener","exports","_default2"],"sources":["src/views/system/fromModeling/package/components/KFormDesign/module/formComponentPanel.vue"],"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"],"mappings":"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"}]}
|