{"remainingRequest":"D:\\workspace\\idea\\ruoyi-api\\ruoyi-ui\\node_modules\\babel-loader\\lib\\index.js!D:\\workspace\\idea\\ruoyi-api\\ruoyi-ui\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!D:\\workspace\\idea\\ruoyi-api\\ruoyi-ui\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\workspace\\idea\\ruoyi-api\\ruoyi-ui\\src\\views\\tool\\build\\index.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\workspace\\idea\\ruoyi-api\\ruoyi-ui\\src\\views\\tool\\build\\index.vue","mtime":1683257485959},{"path":"D:\\workspace\\idea\\ruoyi-api\\ruoyi-ui\\babel.config.js","mtime":1683257214499},{"path":"D:\\workspace\\idea\\ruoyi-api\\ruoyi-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1683257226511},{"path":"D:\\workspace\\idea\\ruoyi-api\\ruoyi-ui\\node_modules\\babel-loader\\lib\\index.js","mtime":1683257224897},{"path":"D:\\workspace\\idea\\ruoyi-api\\ruoyi-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1683257226511},{"path":"D:\\workspace\\idea\\ruoyi-api\\ruoyi-ui\\node_modules\\vue-loader\\lib\\index.js","mtime":1683257451742}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:"use strict";

var _interopRequireDefault = require("D:/workspace/idea/ruoyi-api/ruoyi-ui/node_modules/@babel/runtime/helpers/interopRequireDefault.js").default;
Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.default = void 0;
var _typeof2 = _interopRequireDefault(require("D:/workspace/idea/ruoyi-api/ruoyi-ui/node_modules/@babel/runtime/helpers/typeof.js"));
var _objectSpread2 = _interopRequireDefault(require("D:/workspace/idea/ruoyi-api/ruoyi-ui/node_modules/@babel/runtime/helpers/objectSpread2.js"));
require("core-js/modules/es.regexp.exec.js");
require("core-js/modules/es.string.replace.js");
require("core-js/modules/es.array.push.js");
require("core-js/modules/es.json.stringify.js");
require("core-js/modules/es.array.map.js");
require("core-js/modules/es.array.splice.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.object.keys.js");
require("core-js/modules/es.array.find-index.js");
var _vuedraggable = _interopRequireDefault(require("vuedraggable"));
var _jsBeautify = _interopRequireDefault(require("js-beautify"));
var _clipboard = _interopRequireDefault(require("clipboard"));
var _render = _interopRequireDefault(require("@/utils/generator/render"));
var _RightPanel = _interopRequireDefault(require("./RightPanel"));
var _config = require("@/utils/generator/config");
var _index = require("@/utils/index");
var _html = require("@/utils/generator/html");
var _js = require("@/utils/generator/js");
var _css = require("@/utils/generator/css");
var _drawingDefault = _interopRequireDefault(require("@/utils/generator/drawingDefault"));
var _logo = _interopRequireDefault(require("@/assets/logo/logo.png"));
var _CodeTypeDialog = _interopRequireDefault(require("./CodeTypeDialog"));
var _DraggableItem = _interopRequireDefault(require("./DraggableItem"));
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

var oldActiveId;
var tempActiveData;
var _default = {
  components: {
    draggable: _vuedraggable.default,
    render: _render.default,
    RightPanel: _RightPanel.default,
    CodeTypeDialog: _CodeTypeDialog.default,
    DraggableItem: _DraggableItem.default
  },
  data: function data() {
    return {
      logo: _logo.default,
      idGlobal: 100,
      formConf: _config.formConf,
      inputComponents: _config.inputComponents,
      selectComponents: _config.selectComponents,
      layoutComponents: _config.layoutComponents,
      labelWidth: 100,
      drawingList: _drawingDefault.default,
      drawingData: {},
      activeId: _drawingDefault.default[0].formId,
      drawerVisible: false,
      formData: {},
      dialogVisible: false,
      generateConf: null,
      showFileName: false,
      activeData: _drawingDefault.default[0]
    };
  },
  created: function created() {
    // 防止 firefox 下 拖拽 会新打卡一个选项卡
    document.body.ondrop = function (event) {
      event.preventDefault();
      event.stopPropagation();
    };
  },
  watch: {
    // eslint-disable-next-line func-names
    'activeData.label': function activeDataLabel(val, oldVal) {
      if (this.activeData.placeholder === undefined || !this.activeData.tag || oldActiveId !== this.activeId) {
        return;
      }
      this.activeData.placeholder = this.activeData.placeholder.replace(oldVal, '') + val;
    },
    activeId: {
      handler: function handler(val) {
        oldActiveId = val;
      },
      immediate: true
    }
  },
  mounted: function mounted() {
    var _this = this;
    var clipboard = new _clipboard.default('#copyNode', {
      text: function text(trigger) {
        var codeStr = _this.generateCode();
        _this.$notify({
          title: '成功',
          message: '代码已复制到剪切板，可粘贴。',
          type: 'success'
        });
        return codeStr;
      }
    });
    clipboard.on('error', function (e) {
      _this.$message.error('代码复制失败');
    });
  },
  methods: {
    activeFormItem: function activeFormItem(element) {
      this.activeData = element;
      this.activeId = element.formId;
    },
    onEnd: function onEnd(obj, a) {
      if (obj.from !== obj.to) {
        this.activeData = tempActiveData;
        this.activeId = this.idGlobal;
      }
    },
    addComponent: function addComponent(item) {
      var clone = this.cloneComponent(item);
      this.drawingList.push(clone);
      this.activeFormItem(clone);
    },
    cloneComponent: function cloneComponent(origin) {
      var clone = JSON.parse(JSON.stringify(origin));
      clone.formId = ++this.idGlobal;
      clone.span = _config.formConf.span;
      clone.renderKey = +new Date(); // 改变renderKey后可以实现强制更新组件
      if (!clone.layout) clone.layout = 'colFormItem';
      if (clone.layout === 'colFormItem') {
        clone.vModel = "field".concat(this.idGlobal);
        clone.placeholder !== undefined && (clone.placeholder += clone.label);
        tempActiveData = clone;
      } else if (clone.layout === 'rowFormItem') {
        delete clone.label;
        clone.componentName = "row".concat(this.idGlobal);
        clone.gutter = this.formConf.gutter;
        tempActiveData = clone;
      }
      return tempActiveData;
    },
    AssembleFormData: function AssembleFormData() {
      this.formData = (0, _objectSpread2.default)({
        fields: JSON.parse(JSON.stringify(this.drawingList))
      }, this.formConf);
    },
    generate: function generate(data) {
      var func = this["exec".concat((0, _index.titleCase)(this.operationType))];
      this.generateConf = data;
      func && func(data);
    },
    execRun: function execRun(data) {
      this.AssembleFormData();
      this.drawerVisible = true;
    },
    execDownload: function execDownload(data) {
      var codeStr = this.generateCode();
      var blob = new Blob([codeStr], {
        type: 'text/plain;charset=utf-8'
      });
      this.$download.saveAs(blob, data.fileName);
    },
    execCopy: function execCopy(data) {
      document.getElementById('copyNode').click();
    },
    empty: function empty() {
      var _this2 = this;
      this.$confirm('确定要清空所有组件吗？', '提示', {
        type: 'warning'
      }).then(function () {
        _this2.drawingList = [];
      });
    },
    drawingItemCopy: function drawingItemCopy(item, parent) {
      var clone = JSON.parse(JSON.stringify(item));
      clone = this.createIdAndKey(clone);
      parent.push(clone);
      this.activeFormItem(clone);
    },
    createIdAndKey: function createIdAndKey(item) {
      var _this3 = this;
      item.formId = ++this.idGlobal;
      item.renderKey = +new Date();
      if (item.layout === 'colFormItem') {
        item.vModel = "field".concat(this.idGlobal);
      } else if (item.layout === 'rowFormItem') {
        item.componentName = "row".concat(this.idGlobal);
      }
      if (Array.isArray(item.children)) {
        item.children = item.children.map(function (childItem) {
          return _this3.createIdAndKey(childItem);
        });
      }
      return item;
    },
    drawingItemDelete: function drawingItemDelete(index, parent) {
      var _this4 = this;
      parent.splice(index, 1);
      this.$nextTick(function () {
        var len = _this4.drawingList.length;
        if (len) {
          _this4.activeFormItem(_this4.drawingList[len - 1]);
        }
      });
    },
    generateCode: function generateCode() {
      var type = this.generateConf.type;
      this.AssembleFormData();
      var script = (0, _html.vueScript)((0, _js.makeUpJs)(this.formData, type));
      var html = (0, _html.vueTemplate)((0, _html.makeUpHtml)(this.formData, type));
      var css = (0, _html.cssStyle)((0, _css.makeUpCss)(this.formData));
      return _jsBeautify.default.html(html + script + css, _index.beautifierConf.html);
    },
    download: function download() {
      this.dialogVisible = true;
      this.showFileName = true;
      this.operationType = 'download';
    },
    run: function run() {
      this.dialogVisible = true;
      this.showFileName = false;
      this.operationType = 'run';
    },
    copy: function copy() {
      this.dialogVisible = true;
      this.showFileName = false;
      this.operationType = 'copy';
    },
    tagChange: function tagChange(newTag) {
      var _this5 = this;
      newTag = this.cloneComponent(newTag);
      newTag.vModel = this.activeData.vModel;
      newTag.formId = this.activeId;
      newTag.span = this.activeData.span;
      delete this.activeData.tag;
      delete this.activeData.tagIcon;
      delete this.activeData.document;
      Object.keys(newTag).forEach(function (key) {
        if (_this5.activeData[key] !== undefined && (0, _typeof2.default)(_this5.activeData[key]) === (0, _typeof2.default)(newTag[key])) {
          newTag[key] = _this5.activeData[key];
        }
      });
      this.activeData = newTag;
      this.updateDrawingList(newTag, this.drawingList);
    },
    updateDrawingList: function updateDrawingList(newTag, list) {
      var _this6 = this;
      var index = list.findIndex(function (item) {
        return item.formId === _this6.activeId;
      });
      if (index > -1) {
        list.splice(index, 1, newTag);
      } else {
        list.forEach(function (item) {
          if (Array.isArray(item.children)) _this6.updateDrawingList(newTag, item.children);
        });
      }
    }
  }
};
exports.default = _default;"},{"version":3,"mappings":";;;;;;;;;;;;;;;;;;;AA0IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA;AACA;AAAA,eAEA;EACAA;IACAC;IACAC;IACAC;IACAC;IACAC;EACA;EACAC;IACA;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;IACA;EACA;EACAC;IACA;IACAC;MACAC;MACAA;IACA;EACA;EACAC;IACA;IACA;MACA,IACA,6CACA,wBACAC,+BACA;QACA;MACA;MACA;IACA;IACAX;MACAY;QACAD;MACA;MACAE;IACA;EACA;EACAC;IAAA;IACA;MACAC;QACA;QACA;UACAC;UACAC;UACAC;QACA;QACA;MACA;IACA;IACAC;MACA;IACA;EACA;EACAC;IACAC;MACA;MACA;IACA;IACAC;MACA;QACA;QACA;MACA;IACA;IACAC;MACA;MACA;MACA;IACA;IACAC;MACA;MACAC;MACAA;MACAA;MACA;MACA;QACAA;QACAA;QACAC;MACA;QACA;QACAD;QACAA;QACAC;MACA;MACA;IACA;IACAC;MACA;QACAC;MAAA,GACA,cACA;IACA;IACAC;MACA;MACA;MACAC;IACA;IACAC;MACA;MACA;IACA;IACAC;MACA;MACA;QAAAd;MAAA;MACA;IACA;IACAe;MACAzB;IACA;IACA0B;MAAA;MACA;QAAAhB;MAAA,QACA;QACA;MACA,EACA;IACA;IACAiB;MACA;MACAV;MACAW;MACA;IACA;IACAC;MAAA;MACAC;MACAA;MACA;QACAA;MACA;QACAA;MACA;MACA;QACAA;UAAA;QAAA;MACA;MACA;IACA;IACAC;MAAA;MACAH;MACA;QACA;QACA;UACA;QACA;MACA;IACA;IACAI;MACA;MACA;MACA;MACA;MACA;MACA;IACA;IACAC;MACA;MACA;MACA;IACA;IACAC;MACA;MACA;MACA;IACA;IACAC;MACA;MACA;MACA;IACA;IACAC;MAAA;MACAC;MACAA;MACAA;MACAA;MACA;MACA;MACA;MACAC;QACA,4CACA;UACAD;QACA;MACA;MACA;MACA;IACA;IACAE;MAAA;MACA;QAAA;MAAA;MACA;QACAC;MACA;QACAA;UACA;QACA;MACA;IACA;EACA;AACA;AAAA","names":["components","draggable","render","RightPanel","CodeTypeDialog","DraggableItem","data","logo","idGlobal","formConf","inputComponents","selectComponents","layoutComponents","labelWidth","drawingList","drawingData","activeId","drawerVisible","formData","dialogVisible","generateConf","showFileName","activeData","created","document","event","watch","oldActiveId","handler","immediate","mounted","text","title","message","type","clipboard","methods","activeFormItem","onEnd","addComponent","cloneComponent","clone","tempActiveData","AssembleFormData","fields","generate","func","execRun","execDownload","execCopy","empty","drawingItemCopy","parent","createIdAndKey","item","drawingItemDelete","generateCode","download","run","copy","tagChange","newTag","Object","updateDrawingList","list"],"sourceRoot":"src/views/tool/build","sources":["index.vue"],"sourcesContent":["\r\n\r\n\r\n\r\n\r\n"]}]}