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\\index.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\\index.vue","mtime":1688978853931},{"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 _typeof2 = _interopRequireDefault(require("E:/mec-cloud_IntelligentManufacturing_CRM/mec-cloud_IntelligentManufacturing_CRM/ruoyi-ui/node_modules/@babel/runtime/helpers/typeof.js"));
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.array.push.js");
require("core-js/modules/es.array.includes.js");
require("core-js/modules/es.string.includes.js");
require("core-js/modules/es.json.stringify.js");
require("core-js/modules/es.object.keys.js");
require("core-js/modules/es.object.to-string.js");
require("core-js/modules/web.dom-collections.for-each.js");
var _operatingArea = _interopRequireDefault(require("./module/operatingArea"));
var _footer = _interopRequireDefault(require("./module/footer"));
var _formComponentPanel = _interopRequireDefault(require("./module/formComponentPanel"));
var _jsonModal = _interopRequireDefault(require("./module/jsonModal"));
var _codeModal = _interopRequireDefault(require("./module/codeModal"));
var _collapseItem = _interopRequireDefault(require("./module/collapseItem"));
var _importJsonModal = _interopRequireDefault(require("./module/importJsonModal"));
var _index = _interopRequireDefault(require("../KFormPreview/index.vue"));
var _zh_CN = _interopRequireDefault(require("ant-design-vue/lib/locale-provider/zh_CN"));
var _antDesignVue = require("ant-design-vue");
var _index2 = require("../../utils/index");
var _formItemProperties = _interopRequireDefault(require("./module/formItemProperties"));
var _formProperties = _interopRequireDefault(require("./module/formProperties"));
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
/*
 * author kcz
 * date 2019-11-20
 * description 表单设计器
 */
var _default2 = {
  name: "KFormDesign",
  props: {
    showHead: {
      type: Boolean,
      default: "表单设计器 "
    },
    hideResetHint: {
      type: Boolean,
      default: false
    },
    toolbarsTop: {
      type: Boolean,
      default: false
    },
    toolbars: {
      type: Array,
      default: function _default() {
        return ["save", "preview", "importJson", "exportJson", "exportCode", "reset", "close", "undo", "redo"];
      }
    },
    showToolbarsText: {
      type: Boolean,
      default: false
    },
    hideModel: {
      // 隐藏数据字段
      type: Boolean,
      default: false
    }
  },
  data: function data() {
    return {
      locale: _zh_CN.default,
      loadState: false,
      activeKey: 1,
      updateTime: 0,
      updateRecordTime: 0,
      startType: "",
      noModel: ["button", "divider", "card", "grid", "tabs", "table", "alert", "text", "html"],
      schemaGroup: [],
      data: {
        list: [],
        config: {
          layout: "horizontal",
          labelCol: {
            xs: 4,
            sm: 4,
            md: 4,
            lg: 4,
            xl: 4,
            xxl: 4
          },
          labelWidth: 100,
          labelLayout: "flex",
          wrapperCol: {
            xs: 18,
            sm: 18,
            md: 18,
            lg: 18,
            xl: 18,
            xxl: 18
          },
          hideRequiredMark: false,
          customStyle: ""
        }
      },
      previewOptions: {
        width: 850
      },
      selectItem: {
        key: ""
      }
    };
  },
  components: {
    // kHeader,
    // kFooter,
    operatingArea: _operatingArea.default,
    collapseItem: _collapseItem.default,
    kJsonModal: _jsonModal.default,
    kCodeModal: _codeModal.default,
    importJsonModal: _importJsonModal.default,
    previewModal: _index.default,
    kFormComponentPanel: _formComponentPanel.default,
    formItemProperties: _formItemProperties.default,
    formProperties: _formProperties.default
  },
  watch: {
    data: {
      handler: function handler(e) {
        this.$nextTick(function () {
          _index2.revoke.push(e);
        });
      },
      deep: true,
      immediate: true
    }
  },
  computed: {
    collapseDefaultActiveKey: function collapseDefaultActiveKey() {
      // 计算当前展开的控件列表
      var defaultActiveKey = window.localStorage.getItem("collapseDefaultActiveKey");
      if (defaultActiveKey) {
        return defaultActiveKey.split(",");
      } else {
        return ["1"];
      }
    }
  },
  methods: {
    generateKey: function generateKey(list, index) {
      // 生成key值
      var key = list[index].type + "_" + new Date().getTime();
      this.$set(list, index, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, list[index]), {}, {
        key: key,
        model: key
      }));
      if (this.noModel.includes(list[index].type)) {
        // 删除不需要的model属性
        delete list[index].model;
      }
    },
    handleListPush: function handleListPush(item) {
      // 双击控件按钮push到list
      // 生成key值
      if (!this.selectItem.key) {
        // 在没有选择表单时，将数据push到this.data.list
        var key = item.type + "_" + new Date().getTime();
        item = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, item), {}, {
          key: key,
          model: key
        });
        if (this.noModel.includes(item.type)) {
          // 删除不需要的model属性
          delete item.model;
        }
        var itemString = JSON.stringify(item);
        var record = JSON.parse(itemString);
        // 删除icon及compoent属性
        delete record.icon;
        delete record.component;
        this.data.list.push(record);
        this.handleSetSelectItem(record);
        return false;
      }
      this.$refs.KFCP.handleCopy(false, item);
    },
    handleOpenJsonModal: function handleOpenJsonModal() {
      // 打开json预览模态框
      this.$refs.jsonModal.jsonData = this.data;
      this.$refs.jsonModal.visible = true;
    },
    handleOpenCodeModal: function handleOpenCodeModal() {
      // 打开代码预览模态框
      this.$refs.codeModal.jsonData = this.data;
      this.$refs.codeModal.visible = true;
    },
    handleOpenImportJsonModal: function handleOpenImportJsonModal() {
      // 打开json预览模态框
      this.$refs.importJsonModal.jsonData = this.data;
      this.$refs.importJsonModal.handleSetSelectItem = this.handleSetSelectItem;
      this.$refs.importJsonModal.visible = true;
    },
    handlePreview: function handlePreview() {
      // 打开预览模态框
      this.$refs.previewModal.jsonData = this.data;
      this.$refs.previewModal.previewWidth = this.previewOptions.width;
      this.$refs.previewModal.visible = true;
    },
    handleReset: function handleReset() {
      var _this = this;
      // 清空
      if (this.hideResetHint) {
        // 不显示提示直接清空
        this.resetData();
        return;
      }
      _antDesignVue.Modal.confirm({
        title: "警告",
        content: "是否确认清空内容?",
        okText: "是",
        okType: "danger",
        cancelText: "否",
        onOk: function onOk() {
          _this.resetData();
        }
      });
    },
    resetData: function resetData() {
      this.data = {
        list: [],
        config: {
          layout: "horizontal",
          labelCol: {
            xs: 4,
            sm: 4,
            md: 4,
            lg: 4,
            xl: 4,
            xxl: 4
          },
          labelWidth: 100,
          labelLayout: "flex",
          wrapperCol: {
            xs: 18,
            sm: 18,
            md: 18,
            lg: 18,
            xl: 18,
            xxl: 18
          },
          hideRequiredMark: false,
          customStyle: ""
        }
      };
      this.handleSetSelectItem({
        key: ""
      });
      _antDesignVue.message.success("已清空");
    },
    handleSetSelectItem: function handleSetSelectItem(record) {
      // 操作间隔不能低于100毫秒
      var newTime = new Date().getTime();
      if (newTime - this.updateTime < 100) {
        return false;
      }
      this.updateTime = newTime;

      // 设置selectItem的值
      this.selectItem = record;

      // 判断是否选中控件，如果选中则弹出属性面板，否则关闭属性面板
      if (record.key) {
        this.startType = record.type;
        this.changeTab(2);
      } else {
        this.changeTab(1);
      }
    },
    /**
     * @description: 切换属性设置面板
     * @param {*}
     * @return {*}
     */
    changeTab: function changeTab(e) {
      this.activeKey = e;
    },
    /**
     * @Author: kcz
     * @description: 遍历json结构，获取所有字段
     * @param {*}
     * @return {*} Array
     */
    getFieldSchema: function getFieldSchema() {
      var fields = [];
      var traverse = function traverse(array) {
        array.forEach(function (element) {
          if (element.type === "grid" || element.type === "tabs") {
            // 栅格布局
            element.columns.forEach(function (item) {
              traverse(item.list);
            });
          } else if (element.type === "card") {
            // 卡片布局
            traverse(element.list);
          } else if (element.type === "batch") {
            // 动态表格内复制
            traverse(element.list);
          } else if (element.type === "table") {
            // 表格布局
            element.trs.forEach(function (item) {
              item.tds.forEach(function (val) {
                traverse(val.list);
              });
            });
          } else {
            if (element.model) {
              fields.push(element);
            }
          }
        });
      };
      traverse(this.data.list);
      return fields;
    },
    handleSetData: function handleSetData(data) {
      // 用于父组件赋值
      try {
        if ((0, _typeof2.default)(data) !== "object") {
          return false;
        } else {
          this.data = data;
          // 导入json数据后，需要清除已选择key
          this.handleSetSelectItem({
            key: ""
          });
        }
        return true;
      } catch (error) {
        console.error(error);
        return false;
      }
    },
    collapseChange: function collapseChange(val) {
      // 点击collapse时，保存当前collapse状态
      window.localStorage.setItem("collapseDefaultActiveKey", val);
    },
    handleStart: function handleStart(type) {
      this.startType = type;
    },
    /**
     * @description: 撤销
     * @param {*}
     * @return {*}
     */
    handleUndo: function handleUndo() {
      var record = _index2.revoke.undo();
      if (!record) {
        return false;
      }
      this.data = record;
      this.handleSetSelectItem({
        key: ""
      });
    },
    /**
     * @description: 重做
     * @param {*}
     * @return {*}
     */
    handleRedo: function handleRedo() {
      var record = _index2.revoke.redo();
      if (!record) {
        return false;
      }
      this.data = record;
    },
    handleSave: function handleSave() {
      // 保存函数
      this.$emit("save", JSON.stringify(this.data));
    },
    getValue: function getValue() {
      // 获取数据
      return this.data;
    },
    handleClose: function handleClose() {
      this.$emit("close");
    }
  },
  created: function created() {
    this.loadState = true;
    _index2.nodeSchema.addComputed(this.schemaGroup);
  }
};
exports.default = _default2;"},{"version":3,"names":["_operatingArea","_interopRequireDefault","require","_footer","_formComponentPanel","_jsonModal","_codeModal","_collapseItem","_importJsonModal","_index","_zh_CN","_antDesignVue","_index2","_formItemProperties","_formProperties","_default2","name","props","showHead","type","Boolean","default","hideResetHint","toolbarsTop","toolbars","Array","_default","showToolbarsText","hideModel","data","locale","zhCN","loadState","activeKey","updateTime","updateRecordTime","startType","noModel","schemaGroup","list","config","layout","labelCol","xs","sm","md","lg","xl","xxl","labelWidth","labelLayout","wrapperCol","hideRequiredMark","customStyle","previewOptions","width","selectItem","key","components","operatingArea","collapseItem","kJsonModal","kCodeModal","importJsonModal","previewModal","kFormComponentPanel","formItemProperties","formProperties","watch","handler","e","$nextTick","revoke","push","deep","immediate","computed","collapseDefaultActiveKey","defaultActiveKey","window","localStorage","getItem","split","methods","generateKey","index","Date","getTime","$set","_objectSpread2","model","includes","handleListPush","item","itemString","JSON","stringify","record","parse","icon","component","handleSetSelectItem","$refs","KFCP","handleCopy","handleOpenJsonModal","jsonModal","jsonData","visible","handleOpenCodeModal","codeModal","handleOpenImportJsonModal","handlePreview","previewWidth","handleReset","_this","resetData","Modal","confirm","title","content","okText","okType","cancelText","onOk","message","success","newTime","changeTab","getFieldSchema","fields","traverse","array","forEach","element","columns","trs","tds","val","handleSetData","_typeof2","error","console","collapseChange","setItem","handleStart","handleUndo","undo","handleRedo","redo","handleSave","$emit","getValue","handleClose","created","nodeSchema","addComputed","exports"],"sources":["src/views/system/fromModeling/package/components/KFormDesign/index.vue"],"sourcesContent":["<template>\n <a-config-provider :locale=\"locale\">\n <div class=\"form-designer-container-9136076486841527\" v-if=\"loadState\">\n <!-- <k-header v-if=\"showHead\" :title=\"title\" /> -->\n <!-- 操作区域 start -->\n <operatingArea\n v-if=\"toolbarsTop\"\n :showToolbarsText=\"showToolbarsText\"\n :toolbars=\"toolbars\"\n @handleSave=\"handleSave\"\n @handlePreview=\"handlePreview\"\n @handleOpenImportJsonModal=\"handleOpenImportJsonModal\"\n @handleOpenCodeModal=\"handleOpenCodeModal\"\n @handleOpenJsonModal=\"handleOpenJsonModal\"\n @handleReset=\"handleReset\"\n @handleClose=\"handleClose\"\n @handleUndo=\"handleUndo\"\n @handleRedo=\"handleRedo\"\n >\n <template slot=\"left-action\">\n <slot name=\"left-action\"></slot>\n </template>\n\n <template slot=\"right-action\">\n <slot name=\"right-action\"></slot>\n </template>\n </operatingArea>\n <!-- 操作区域 end -->\n <div\n class=\"content\"\n :class=\"{\n 'show-head': showHead,\n 'toolbars-top': toolbarsTop,\n 'show-head-and-toolbars-top': toolbarsTop && showHead\n }\"\n >\n <!-- 左侧控件区域 start -->\n <aside class=\"left\">\n <a-collapse\n @change=\"collapseChange\"\n :defaultActiveKey=\"collapseDefaultActiveKey\"\n >\n <!-- 基础控件 start -->\n <a-collapse-panel\n v-for=\"(item, index) in schemaGroup\"\n \n :key=\"index\"\n >\n <collapseItem\n :list=\"item.list\"\n @generateKey=\"generateKey\"\n @handleListPush=\"handleListPush\"\n @start=\"handleStart\"\n />\n </a-collapse-panel>\n <!-- 基础控件 end -->\n </a-collapse>\n </aside>\n <!-- 左侧控件区域 end -->\n\n <!-- 中间面板区域 start -->\n <section>\n <!-- 操作区域 start -->\n <operatingArea\n v-if=\"!toolbarsTop\"\n :showToolbarsText=\"showToolbarsText\"\n :toolbars=\"toolbars\"\n @handleSave=\"handleSave\"\n @handlePreview=\"handlePreview\"\n @handleOpenImportJsonModal=\"handleOpenImportJsonModal\"\n @handleOpenCodeModal=\"handleOpenCodeModal\"\n @handleOpenJsonModal=\"handleOpenJsonModal\"\n @handleReset=\"handleReset\"\n @handleClose=\"handleClose\"\n @handleUndo=\"handleUndo\"\n @handleRedo=\"handleRedo\"\n >\n <template slot=\"left-action\">\n <slot name=\"left-action\"></slot>\n </template>\n\n <template slot=\"right-action\">\n <slot name=\"right-action\"></slot>\n </template>\n </operatingArea>\n <!-- 操作区域 end -->\n <k-form-component-panel\n :class=\"{ 'no-toolbars-top': !toolbarsTop }\"\n :data=\"data\"\n :selectItem=\"selectItem\"\n :noModel=\"noModel\"\n :hideModel=\"hideModel\"\n :startType=\"startType\"\n ref=\"KFCP\"\n @handleSetSelectItem=\"handleSetSelectItem\"\n />\n <!-- 操作区域 start -->\n <k-json-modal ref=\"jsonModal\" />\n <k-code-modal ref=\"codeModal\" />\n <importJsonModal ref=\"importJsonModal\" />\n <previewModal ref=\"previewModal\" />\n </section>\n <!-- 中间面板区域 end -->\n\n <!-- 右侧控件属性区域 start -->\n <aside class=\"right\">\n <a-tabs\n :activeKey=\"activeKey\"\n @change=\"changeTab\"\n :tabBarStyle=\"{ margin: 0 }\"\n >\n <a-tab-pane :key=\"1\" tab=\"表单属性设置\">\n <formProperties\n :config=\"data.config\"\n :previewOptions=\"previewOptions\"\n />\n </a-tab-pane>\n <a-tab-pane :key=\"2\" tab=\"控件属性设置\">\n <formItemProperties\n class=\"form-item-properties\"\n :selectItem=\"selectItem\"\n :hideModel=\"hideModel\"\n />\n </a-tab-pane>\n </a-tabs>\n </aside>\n <!-- 右侧控件属性区域 end -->\n </div>\n <!-- <k-footer /> -->\n </div>\n </a-config-provider>\n</template>\n<script>\n/*\n * author kcz\n * date 2019-11-20\n * description 表单设计器\n */\nimport operatingArea from \"./module/operatingArea\";\n\nimport kFooter from \"./module/footer\";\nimport kFormComponentPanel from \"./module/formComponentPanel\";\nimport kJsonModal from \"./module/jsonModal\";\nimport kCodeModal from \"./module/codeModal\";\nimport collapseItem from \"./module/collapseItem\";\nimport importJsonModal from \"./module/importJsonModal\";\nimport previewModal from \"../KFormPreview/index.vue\";\nimport zhCN from \"ant-design-vue/lib/locale-provider/zh_CN\";\nimport { Modal, message } from \"ant-design-vue\";\nimport { revoke, nodeSchema } from \"../../utils/index\";\nimport formItemProperties from \"./module/formItemProperties\";\nimport formProperties from \"./module/formProperties\";\n\nexport default {\n name: \"KFormDesign\",\n props: {\n showHead: {\n type: Boolean,\n default: \"表单设计器 \"\n },\n hideResetHint: {\n type: Boolean,\n default: false\n },\n toolbarsTop: {\n type: Boolean,\n default: false\n },\n toolbars: {\n type: Array,\n default: () => [\n \"save\",\n \"preview\",\n \"importJson\",\n \"exportJson\",\n \"exportCode\",\n \"reset\",\n \"close\",\n \"undo\",\n \"redo\"\n ]\n },\n showToolbarsText: {\n type: Boolean,\n default: false\n },\n hideModel: {\n // 隐藏数据字段\n type: Boolean,\n default: false\n }\n },\n data() {\n return {\n locale: zhCN,\n loadState: false,\n activeKey: 1,\n updateTime: 0,\n updateRecordTime: 0,\n startType: \"\",\n noModel: [\n \"button\",\n \"divider\",\n \"card\",\n \"grid\",\n \"tabs\",\n \"table\",\n \"alert\",\n \"text\",\n \"html\"\n ],\n schemaGroup: [],\n data: {\n list: [],\n config: {\n layout: \"horizontal\",\n labelCol: { xs: 4, sm: 4, md: 4, lg: 4, xl: 4, xxl: 4 },\n labelWidth: 100,\n labelLayout: \"flex\",\n wrapperCol: { xs: 18, sm: 18, md: 18, lg: 18, xl: 18, xxl: 18 },\n hideRequiredMark: false,\n customStyle: \"\"\n }\n },\n previewOptions: {\n width: 850\n },\n selectItem: {\n key: \"\"\n }\n };\n },\n components: {\n // kHeader,\n // kFooter,\n operatingArea,\n collapseItem,\n kJsonModal,\n kCodeModal,\n importJsonModal,\n previewModal,\n kFormComponentPanel,\n formItemProperties,\n formProperties\n },\n watch: {\n data: {\n handler(e) {\n this.$nextTick(() => {\n revoke.push(e);\n });\n },\n deep: true,\n immediate: true\n }\n },\n computed: {\n collapseDefaultActiveKey() {\n // 计算当前展开的控件列表\n const defaultActiveKey = window.localStorage.getItem(\n \"collapseDefaultActiveKey\"\n );\n if (defaultActiveKey) {\n return defaultActiveKey.split(\",\");\n } else {\n return [\"1\"];\n }\n }\n },\n methods: {\n generateKey(list, index) {\n // 生成key值\n const key = list[index].type + \"_\" + new Date().getTime();\n this.$set(list, index, {\n ...list[index],\n key,\n model: key\n });\n if (this.noModel.includes(list[index].type)) {\n // 删除不需要的model属性\n delete list[index].model;\n }\n },\n handleListPush(item) {\n // 双击控件按钮push到list\n // 生成key值\n if (!this.selectItem.key) {\n // 在没有选择表单时,将数据push到this.data.list\n const key = item.type + \"_\" + new Date().getTime();\n item = {\n ...item,\n key,\n model: key\n };\n if (this.noModel.includes(item.type)) {\n // 删除不需要的model属性\n delete item.model;\n }\n const itemString = JSON.stringify(item);\n const record = JSON.parse(itemString);\n // 删除icon及compoent属性\n delete record.icon;\n delete record.component;\n this.data.list.push(record);\n this.handleSetSelectItem(record);\n return false;\n }\n this.$refs.KFCP.handleCopy(false, item);\n },\n handleOpenJsonModal() {\n // 打开json预览模态框\n this.$refs.jsonModal.jsonData = this.data;\n this.$refs.jsonModal.visible = true;\n },\n handleOpenCodeModal() {\n // 打开代码预览模态框\n this.$refs.codeModal.jsonData = this.data;\n this.$refs.codeModal.visible = true;\n },\n handleOpenImportJsonModal() {\n // 打开json预览模态框\n this.$refs.importJsonModal.jsonData = this.data;\n this.$refs.importJsonModal.handleSetSelectItem = this.handleSetSelectItem;\n this.$refs.importJsonModal.visible = true;\n },\n handlePreview() {\n // 打开预览模态框\n this.$refs.previewModal.jsonData = this.data;\n this.$refs.previewModal.previewWidth = this.previewOptions.width;\n this.$refs.previewModal.visible = true;\n },\n handleReset() {\n // 清空\n if (this.hideResetHint) {\n // 不显示提示直接清空\n this.resetData();\n return;\n }\n\n Modal.confirm({\n title: \"警告\",\n content: \"是否确认清空内容?\",\n okText: \"是\",\n okType: \"danger\",\n cancelText: \"否\",\n onOk: () => {\n this.resetData();\n }\n });\n },\n resetData() {\n this.data = {\n list: [],\n config: {\n layout: \"horizontal\",\n labelCol: { xs: 4, sm: 4, md: 4, lg: 4, xl: 4, xxl: 4 },\n labelWidth: 100,\n labelLayout: \"flex\",\n wrapperCol: { xs: 18, sm: 18, md: 18, lg: 18, xl: 18, xxl: 18 },\n hideRequiredMark: false,\n customStyle: \"\"\n }\n };\n this.handleSetSelectItem({ key: \"\" });\n message.success(\"已清空\");\n },\n handleSetSelectItem(record) {\n // 操作间隔不能低于100毫秒\n const newTime = new Date().getTime();\n if (newTime - this.updateTime < 100) {\n return false;\n }\n\n this.updateTime = newTime;\n\n // 设置selectItem的值\n this.selectItem = record;\n\n // 判断是否选中控件,如果选中则弹出属性面板,否则关闭属性面板\n if (record.key) {\n this.startType = record.type;\n this.changeTab(2);\n } else {\n this.changeTab(1);\n }\n },\n /**\n * @description: 切换属性设置面板\n * @param {*}\n * @return {*}\n */\n\n changeTab(e) {\n this.activeKey = e;\n },\n /**\n * @Author: kcz\n * @description: 遍历json结构,获取所有字段\n * @param {*}\n * @return {*} Array\n */\n getFieldSchema() {\n const fields = [];\n const traverse = array => {\n array.forEach(element => {\n if (element.type === \"grid\" || element.type === \"tabs\") {\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 traverse(element.list);\n } else if (element.type === \"table\") {\n // 表格布局\n element.trs.forEach(item => {\n item.tds.forEach(val => {\n traverse(val.list);\n });\n });\n } else {\n if (element.model) {\n fields.push(element);\n }\n }\n });\n };\n traverse(this.data.list);\n return fields;\n },\n handleSetData(data) {\n // 用于父组件赋值\n try {\n if (typeof data !== \"object\") {\n return false;\n } else {\n this.data = data;\n // 导入json数据后,需要清除已选择key\n this.handleSetSelectItem({ key: \"\" });\n }\n return true;\n } catch (error) {\n console.error(error);\n return false;\n }\n },\n collapseChange(val) {\n // 点击collapse时,保存当前collapse状态\n window.localStorage.setItem(\"collapseDefaultActiveKey\", val);\n },\n handleStart(type) {\n this.startType = type;\n },\n\n /**\n * @description: 撤销\n * @param {*}\n * @return {*}\n */\n handleUndo() {\n const record = revoke.undo();\n if (!record) {\n return false;\n }\n this.data = record;\n\n this.handleSetSelectItem({ key: \"\" });\n },\n\n /**\n * @description: 重做\n * @param {*}\n * @return {*}\n */\n handleRedo() {\n const record = revoke.redo();\n if (!record) {\n return false;\n }\n this.data = record;\n },\n\n handleSave() {\n // 保存函数\n this.$emit(\"save\", JSON.stringify(this.data));\n },\n getValue() {\n // 获取数据\n return this.data;\n },\n handleClose() {\n this.$emit(\"close\");\n }\n },\n created() {\n this.loadState = true;\n nodeSchema.addComputed(this.schemaGroup);\n }\n};\n</script>\n<style scoped>\n.form-designer-container-9136076486841527 .content aside, .k-form-build-9136076486841527 .content aside {\n -webkit-box-shadow: 0 0 1px 1px #ccc;\n box-shadow: 0 0 1px 1px #ccc;\n width: 305px;\n height: 100%;\n}\n</style>"],"mappings":"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"}]}
|