vxe-table
Version:
一个基于 vue 的 PC 端表格组件,支持增删改查、虚拟滚动、懒加载、快捷菜单、数据校验、树形结构、打印导出、表单渲染、数据分页、虚拟列表、模态窗口、自定义模板、渲染器、贼灵活的配置项、扩展接口等...
102 lines (81 loc) • 3.26 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.isItem = isItem;
exports.getItemConfig = getItemConfig;
exports.createItem = createItem;
exports.destroyItem = destroyItem;
exports.assemItem = assemItem;
var _ctor = _interopRequireDefault(require("xe-utils/ctor"));
var _vXETable = _interopRequireDefault(require("../../v-x-e-table"));
var _tools = require("../../tools");
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
var ItemConfig = /*#__PURE__*/function () {
function ItemConfig($xeform, _vm) {
_classCallCheck(this, ItemConfig);
Object.assign(this, {
id: _ctor.default.uniqueId('item_'),
title: _vm.title,
field: _vm.field,
span: _vm.span,
align: _vm.align,
titleAlign: _vm.titleAlign,
titleWidth: _vm.titleWidth,
titlePrefix: _vm.titlePrefix,
titleSuffix: _vm.titleSuffix,
resetValue: _vm.resetValue,
visible: _vm.visible,
visibleMethod: _vm.visibleMethod,
folding: _vm.folding,
collapseNode: _vm.collapseNode,
itemRender: _vm.itemRender,
// 渲染属性
showError: false,
errRule: null,
slots: _vm.slots
});
if (process.env.VUE_APP_VXE_TABLE_ENV === 'development') {
var compConf = _vm.itemRender ? _vXETable.default.renderer.get(_vm.itemRender.name) : null;
if (compConf && !compConf.renderItemContent && compConf.renderItem) {
_tools.UtilTools.warn('vxe.error.delProp', ['item-render.renderItem', 'item-render.renderItemContent']);
}
}
}
_createClass(ItemConfig, [{
key: "update",
value: function update(name, value) {
this[name] = value;
}
}]);
return ItemConfig;
}();
function isItem(option) {
return option instanceof ItemConfig;
}
function getItemConfig($xeform, _vm, options) {
return isItem(_vm) ? _vm : new ItemConfig($xeform, _vm, options);
}
function createItem($xeform, _vm) {
return getItemConfig($xeform, _vm);
}
function destroyItem(_vm) {
var $xeform = _vm.$xeform,
itemConfig = _vm.itemConfig;
var matchObj = _ctor.default.findTree($xeform.staticItems, function (option) {
return option === itemConfig;
});
if (matchObj) {
matchObj.items.splice(matchObj.index, 1);
}
}
function assemItem(_vm) {
var $el = _vm.$el,
$xeform = _vm.$xeform,
itemConfig = _vm.itemConfig;
itemConfig.slots = _vm.$scopedSlots;
$xeform.staticItems.splice([].indexOf.call($xeform.$refs.hideItem.children, $el), 0, itemConfig);
}