2192 lines
79 KiB
JavaScript
2192 lines
79 KiB
JavaScript
import {
|
|
errLog,
|
|
getSlotVNs,
|
|
warnLog
|
|
} from "./chunk-GPQQMF6N.js";
|
|
import {
|
|
eqEmptyValue,
|
|
formatText,
|
|
getFuncText,
|
|
isEnableConf
|
|
} from "./chunk-Z4MEN7AG.js";
|
|
import {
|
|
VxeUI,
|
|
require_xe_utils
|
|
} from "./chunk-YJNUXQVJ.js";
|
|
import {
|
|
h,
|
|
reactive,
|
|
watch
|
|
} from "./chunk-AAHVYXXY.js";
|
|
import {
|
|
__toESM
|
|
} from "./chunk-V4OQ3NZ2.js";
|
|
|
|
// ../node_modules/.pnpm/vxe-table@4.17.14_vue@3.5.24_typescript@5.9.3_/node_modules/vxe-table/es/ui/src/dom.js
|
|
var import_xe_utils = __toESM(require_xe_utils());
|
|
var reClsMap = {};
|
|
var tpImgEl;
|
|
function initTpImg() {
|
|
if (!tpImgEl) {
|
|
tpImgEl = new Image();
|
|
tpImgEl.src = "";
|
|
}
|
|
return tpImgEl;
|
|
}
|
|
function getTpImg() {
|
|
if (!tpImgEl) {
|
|
return initTpImg();
|
|
}
|
|
return tpImgEl;
|
|
}
|
|
function getPropClass(property, params) {
|
|
return property ? import_xe_utils.default.isFunction(property) ? property(params) : property : "";
|
|
}
|
|
function getClsRE(cls) {
|
|
if (!reClsMap[cls]) {
|
|
reClsMap[cls] = new RegExp(`(?:^|\\s)${cls}(?!\\S)`, "g");
|
|
}
|
|
return reClsMap[cls];
|
|
}
|
|
function isPx(val) {
|
|
return val && /^\d+(px)?$/.test(val);
|
|
}
|
|
function isScale(val) {
|
|
return val && /^\d+%$/.test(val);
|
|
}
|
|
function hasClass(elem, cls) {
|
|
return !!(elem && elem.className && elem.className.match && elem.className.match(getClsRE(cls)));
|
|
}
|
|
function removeClass(elem, cls) {
|
|
if (elem && hasClass(elem, cls)) {
|
|
elem.className = elem.className.replace(getClsRE(cls), "");
|
|
}
|
|
}
|
|
function addClass(elem, cls) {
|
|
if (elem && !hasClass(elem, cls)) {
|
|
removeClass(elem, cls);
|
|
elem.className = `${elem.className} ${cls}`;
|
|
}
|
|
}
|
|
function hasControlKey(evnt) {
|
|
return evnt.ctrlKey || evnt.metaKey;
|
|
}
|
|
function toCssUnit(val, unit = "px") {
|
|
if (import_xe_utils.default.isNumber(val) || /^\d+$/.test(`${val}`)) {
|
|
return `${val}${unit}`;
|
|
}
|
|
return `${val || ""}`;
|
|
}
|
|
function queryElement(elem, selector) {
|
|
if (elem) {
|
|
return elem.querySelector(selector);
|
|
}
|
|
return null;
|
|
}
|
|
function getDomNode() {
|
|
const documentElement = document.documentElement;
|
|
const bodyElem = document.body;
|
|
return {
|
|
scrollTop: documentElement.scrollTop || bodyElem.scrollTop,
|
|
scrollLeft: documentElement.scrollLeft || bodyElem.scrollLeft,
|
|
visibleHeight: documentElement.clientHeight || bodyElem.clientHeight,
|
|
visibleWidth: documentElement.clientWidth || bodyElem.clientWidth
|
|
};
|
|
}
|
|
function getOffsetHeight(elem) {
|
|
return elem ? elem.offsetHeight : 0;
|
|
}
|
|
function getPaddingTopBottomSize(elem) {
|
|
if (elem) {
|
|
const computedStyle = getComputedStyle(elem);
|
|
const paddingTop = import_xe_utils.default.toNumber(computedStyle.paddingTop);
|
|
const paddingBottom = import_xe_utils.default.toNumber(computedStyle.paddingBottom);
|
|
return paddingTop + paddingBottom;
|
|
}
|
|
return 0;
|
|
}
|
|
function setScrollTop(elem, scrollTop) {
|
|
if (elem) {
|
|
elem.scrollTop = scrollTop;
|
|
}
|
|
}
|
|
function setScrollLeft(elem, scrollLeft) {
|
|
if (elem) {
|
|
elem.scrollLeft = scrollLeft;
|
|
}
|
|
}
|
|
function updateCellTitle(overflowElem, column) {
|
|
const content = column.type === "html" ? overflowElem.innerText : overflowElem.textContent;
|
|
if (overflowElem.getAttribute("title") !== content) {
|
|
overflowElem.setAttribute("title", content);
|
|
}
|
|
}
|
|
function checkTargetElement(target, exEls, endEl) {
|
|
let targetEl = target;
|
|
if (!exEls || !exEls.length) {
|
|
return false;
|
|
}
|
|
const [exEl1, exEl2, exEl3] = exEls;
|
|
while (targetEl) {
|
|
if (exEl1 === targetEl || exEl2 && targetEl === exEl2 || exEl3 && targetEl === exEl3) {
|
|
return true;
|
|
}
|
|
if (endEl && targetEl === endEl) {
|
|
return false;
|
|
}
|
|
targetEl = targetEl.parentElement;
|
|
}
|
|
return false;
|
|
}
|
|
function getEventTargetNode(evnt, container, queryCls, queryMethod) {
|
|
let targetElem;
|
|
let target = evnt.target.shadowRoot && evnt.composed ? evnt.composedPath()[0] || evnt.target : evnt.target;
|
|
while (target && target.nodeType && target !== document) {
|
|
if (queryCls && hasClass(target, queryCls) && (!queryMethod || queryMethod(target))) {
|
|
targetElem = target;
|
|
} else if (target === container) {
|
|
return { flag: queryCls ? !!targetElem : true, container, targetElem };
|
|
}
|
|
target = target.parentNode;
|
|
}
|
|
return { flag: false };
|
|
}
|
|
function getAbsolutePos(elem) {
|
|
const bounding = elem.getBoundingClientRect();
|
|
const boundingTop = bounding.top;
|
|
const boundingLeft = bounding.left;
|
|
const { scrollTop, scrollLeft, visibleHeight, visibleWidth } = getDomNode();
|
|
return { boundingTop, top: scrollTop + boundingTop, boundingLeft, left: scrollLeft + boundingLeft, visibleHeight, visibleWidth };
|
|
}
|
|
var scrollIntoViewIfNeeded = "scrollIntoViewIfNeeded";
|
|
var scrollIntoView = "scrollIntoView";
|
|
function scrollToView(elem) {
|
|
if (elem) {
|
|
if (elem[scrollIntoViewIfNeeded]) {
|
|
elem[scrollIntoViewIfNeeded]();
|
|
} else if (elem[scrollIntoView]) {
|
|
elem[scrollIntoView]();
|
|
}
|
|
}
|
|
}
|
|
function triggerEvent(targetElem, type) {
|
|
if (targetElem) {
|
|
targetElem.dispatchEvent(new Event(type));
|
|
}
|
|
}
|
|
|
|
// ../node_modules/.pnpm/vxe-table@4.17.14_vue@3.5.24_typescript@5.9.3_/node_modules/vxe-table/es/table/src/util.js
|
|
var import_xe_utils3 = __toESM(require_xe_utils());
|
|
|
|
// ../node_modules/.pnpm/vxe-table@4.17.14_vue@3.5.24_typescript@5.9.3_/node_modules/vxe-table/es/table/src/columnInfo.js
|
|
var import_xe_utils2 = __toESM(require_xe_utils());
|
|
var { getI18n, formats, renderer } = VxeUI;
|
|
var ColumnInfo = class {
|
|
/* eslint-disable @typescript-eslint/no-use-before-define */
|
|
constructor($xeTable, _vm, { renderHeader, renderCell, renderFooter, renderData } = {}) {
|
|
const tableProps = $xeTable.props;
|
|
const $xeGrid = $xeTable.xeGrid;
|
|
const $xeGantt = $xeTable.xeGantt;
|
|
const $xeGGWrapper = $xeGrid || $xeGantt;
|
|
const { field, editRender, filterRender, headerFormatter } = _vm;
|
|
const colId = _vm.colId || import_xe_utils2.default.uniqueId("col_");
|
|
const formatter = _vm.formatter;
|
|
const visible = import_xe_utils2.default.isBoolean(_vm.visible) ? _vm.visible : true;
|
|
const flCompConf = isEnableConf(filterRender) ? renderer.get(filterRender.name) : null;
|
|
const ctFilterOptions = flCompConf ? flCompConf.createTableFilterOptions : null;
|
|
const filters = toFilters(_vm.filters, colId);
|
|
if (headerFormatter) {
|
|
errLog("vxe.error.notProp", ["header-formatter"]);
|
|
}
|
|
const types = ["seq", "checkbox", "radio", "expand", "html"];
|
|
if (_vm.type && types.indexOf(_vm.type) === -1) {
|
|
warnLog("vxe.error.errProp", [`type=${_vm.type}`, types.join(", ")]);
|
|
}
|
|
if (import_xe_utils2.default.isBoolean(_vm.cellRender) || _vm.cellRender && !import_xe_utils2.default.isObject(_vm.cellRender)) {
|
|
warnLog("vxe.error.errProp", [`column.cell-render=${_vm.cellRender}`, "column.cell-render={}"]);
|
|
}
|
|
if (import_xe_utils2.default.isBoolean(_vm.editRender) || _vm.editRender && !import_xe_utils2.default.isObject(_vm.editRender)) {
|
|
warnLog("vxe.error.errProp", [`column.edit-render=${_vm.editRender}`, "column.edit-render={}"]);
|
|
}
|
|
if (_vm.type === "expand") {
|
|
const { treeConfig } = tableProps;
|
|
const { computeTreeOpts } = $xeTable.getComputeMaps();
|
|
const treeOpts = computeTreeOpts.value;
|
|
if (treeConfig && (treeOpts.showLine || treeOpts.line)) {
|
|
errLog("vxe.error.errConflicts", ["tree-config.showLine", "column.type=expand"]);
|
|
}
|
|
}
|
|
if (formatter) {
|
|
if (import_xe_utils2.default.isString(formatter)) {
|
|
const gFormatOpts = formats.get(formatter) || import_xe_utils2.default[formatter];
|
|
if (!gFormatOpts || !import_xe_utils2.default.isFunction(gFormatOpts.tableCellFormatMethod || gFormatOpts.cellFormatMethod)) {
|
|
errLog("vxe.error.notFormats", [formatter]);
|
|
}
|
|
} else if (import_xe_utils2.default.isArray(formatter)) {
|
|
const gFormatOpts = formats.get(formatter[0]) || import_xe_utils2.default[formatter[0]];
|
|
if (!gFormatOpts || !import_xe_utils2.default.isFunction(gFormatOpts.tableCellFormatMethod || gFormatOpts.cellFormatMethod)) {
|
|
errLog("vxe.error.notFormats", [formatter[0]]);
|
|
}
|
|
}
|
|
}
|
|
if (_vm.aggFunc) {
|
|
if (!$xeTable.handlePivotTableAggregateData && _vm.aggFunc !== true) {
|
|
errLog("vxe.error.errProp", [`column.agg-func=${_vm.aggFunc}`, "column.agg-func=true"]);
|
|
}
|
|
}
|
|
if (field && editRender) {
|
|
if (editRender.startField && `${editRender.startField}`.indexOf(field) >= 0) {
|
|
errLog("vxe.error.modelConflicts", [`field=${field}`, `edit-render.startField=${editRender.startField}`]);
|
|
}
|
|
if (editRender.endField && `${editRender.endField}`.indexOf(field) >= 0) {
|
|
errLog("vxe.error.modelConflicts", [`field=${field}`, `edit-render.endField=${editRender.endField}`]);
|
|
}
|
|
}
|
|
Object.assign(this, {
|
|
// 基本属性
|
|
type: _vm.type,
|
|
property: _vm.field,
|
|
field,
|
|
title: _vm.title,
|
|
width: _vm.width,
|
|
minWidth: _vm.minWidth,
|
|
maxWidth: _vm.maxWidth,
|
|
resizable: _vm.resizable,
|
|
fixed: _vm.fixed,
|
|
align: _vm.align,
|
|
headerAlign: _vm.headerAlign,
|
|
footerAlign: _vm.footerAlign,
|
|
showOverflow: _vm.showOverflow,
|
|
showHeaderOverflow: _vm.showHeaderOverflow,
|
|
showFooterOverflow: _vm.showFooterOverflow,
|
|
className: _vm.className,
|
|
headerClassName: _vm.headerClassName,
|
|
footerClassName: _vm.footerClassName,
|
|
formatter,
|
|
headerFormatter: _vm.headerFormatter,
|
|
footerFormatter: _vm.footerFormatter,
|
|
padding: _vm.padding,
|
|
verticalAlign: _vm.verticalAlign,
|
|
sortable: _vm.sortable,
|
|
sortBy: _vm.sortBy,
|
|
sortType: _vm.sortType,
|
|
filters,
|
|
filterMultiple: import_xe_utils2.default.isBoolean(_vm.filterMultiple) ? _vm.filterMultiple : true,
|
|
filterMethod: _vm.filterMethod,
|
|
filterResetMethod: _vm.filterResetMethod,
|
|
filterRecoverMethod: _vm.filterRecoverMethod,
|
|
filterRender,
|
|
floatingFilters: _vm.floatingFilters,
|
|
rowGroupNode: _vm.rowGroupNode,
|
|
treeNode: _vm.treeNode,
|
|
dragSort: _vm.dragSort,
|
|
rowResize: _vm.rowResize,
|
|
cellType: _vm.cellType,
|
|
cellRender: _vm.cellRender,
|
|
editRender,
|
|
contentRender: _vm.contentRender,
|
|
headerExportMethod: _vm.headerExportMethod,
|
|
exportMethod: _vm.exportMethod,
|
|
footerExportMethod: _vm.footerExportMethod,
|
|
titleHelp: _vm.titleHelp,
|
|
titlePrefix: _vm.titlePrefix,
|
|
titleSuffix: _vm.titleSuffix,
|
|
aggFunc: _vm.aggFunc,
|
|
copyMethod: _vm.copyMethod,
|
|
cutMethod: _vm.cutMethod,
|
|
pasteMethod: _vm.pasteMethod,
|
|
// 自定义参数
|
|
params: _vm.params,
|
|
// 渲染属性
|
|
id: colId,
|
|
parentId: null,
|
|
visible,
|
|
// 内部属性(一旦被使用,将导致不可升级版本)
|
|
defaultParentId: null,
|
|
halfVisible: false,
|
|
defaultVisible: visible,
|
|
defaultFixed: _vm.fixed,
|
|
defaultAggGroup: _vm.aggGroup,
|
|
defaultAggFunc: _vm.aggFunc,
|
|
checked: false,
|
|
halfChecked: false,
|
|
disabled: false,
|
|
// 分组层级
|
|
level: 1,
|
|
// 跨行
|
|
rowSpan: 1,
|
|
// 跨列
|
|
colSpan: 1,
|
|
// 数据排序
|
|
order: null,
|
|
sortTime: 0,
|
|
// 列排序
|
|
sortNumber: 0,
|
|
renderSortNumber: 0,
|
|
renderAggFn: "",
|
|
renderFixed: "",
|
|
renderVisible: false,
|
|
renderWidth: 0,
|
|
renderHeight: 0,
|
|
renderResizeWidth: 0,
|
|
renderAutoWidth: 0,
|
|
resizeWidth: 0,
|
|
renderLeft: 0,
|
|
renderArgs: [],
|
|
model: {},
|
|
renderHeader: renderHeader || _vm.renderHeader,
|
|
renderCell: renderCell || _vm.renderCell,
|
|
renderFooter: renderFooter || _vm.renderFooter,
|
|
renderData,
|
|
// 单元格插槽,只对 grid 有效
|
|
slots: _vm.slots
|
|
});
|
|
if (ctFilterOptions && (!filters || !filters.length)) {
|
|
this.filters = toFilters(ctFilterOptions({ $table: $xeTable, column: this }), colId);
|
|
}
|
|
if ($xeGGWrapper) {
|
|
const { computeProxyOpts } = $xeGGWrapper.getComputeMaps();
|
|
const proxyOpts = computeProxyOpts.value;
|
|
if (proxyOpts.beforeColumn) {
|
|
proxyOpts.beforeColumn({ $table: $xeTable, $grid: $xeGrid, $gantt: $xeGantt, column: this });
|
|
}
|
|
}
|
|
}
|
|
getTitle() {
|
|
return getFuncText(this.title || (this.type === "seq" ? getI18n("vxe.table.seqTitle") : ""));
|
|
}
|
|
getKey() {
|
|
const { type } = this;
|
|
return this.field || (type ? `type=${type}` : null);
|
|
}
|
|
update(name, value) {
|
|
if (name !== "filters") {
|
|
if (name === "field") {
|
|
this.property = value;
|
|
}
|
|
this[name] = value;
|
|
}
|
|
}
|
|
};
|
|
|
|
// ../node_modules/.pnpm/vxe-table@4.17.14_vue@3.5.24_typescript@5.9.3_/node_modules/vxe-table/es/table/src/util.js
|
|
function createInternalData() {
|
|
return {
|
|
tZindex: 0,
|
|
currKeyField: "",
|
|
isCurrDeepKey: false,
|
|
elemStore: {},
|
|
// 存放横向 X 虚拟滚动相关的信息
|
|
scrollXStore: {
|
|
preloadSize: 0,
|
|
offsetSize: 0,
|
|
visibleSize: 0,
|
|
visibleStartIndex: 0,
|
|
visibleEndIndex: 0,
|
|
startIndex: 0,
|
|
endIndex: 0
|
|
},
|
|
// 存放纵向 Y 虚拟滚动相关信息
|
|
scrollYStore: {
|
|
preloadSize: 0,
|
|
offsetSize: 0,
|
|
visibleSize: 0,
|
|
visibleStartIndex: 0,
|
|
visibleEndIndex: 0,
|
|
startIndex: 0,
|
|
endIndex: 0
|
|
},
|
|
// 表格宽度
|
|
tableWidth: 0,
|
|
// 表格高度
|
|
tableHeight: 0,
|
|
customHeight: 0,
|
|
customMinHeight: 0,
|
|
customMaxHeight: 0,
|
|
// 当前 hover 行
|
|
hoverRow: null,
|
|
// 最后滚动位置
|
|
lastScrollLeft: 0,
|
|
lastScrollTop: 0,
|
|
// 单选框属性,已选中保留的行
|
|
radioReserveRow: null,
|
|
// 复选框属性,已选中保留的行集合
|
|
checkboxReserveRowMap: {},
|
|
// 行数据,已展开保留的行集合
|
|
rowExpandedReserveRowMap: {},
|
|
// 树结构数据,已展开保留的行集合
|
|
treeExpandedReserveRowMap: {},
|
|
// 树结构数据,不确定状态的集合
|
|
treeIndeterminateRowMaps: {},
|
|
// 列表完整数据、条件处理后
|
|
tableFullData: [],
|
|
afterFullData: [],
|
|
afterTreeFullData: [],
|
|
afterGroupFullData: [],
|
|
// 列表条件处理后数据集合
|
|
afterFullRowMaps: {},
|
|
// 树结构完整数据、条件处理后
|
|
tableFullTreeData: [],
|
|
// 行分组全量数据、条件处理后
|
|
tableFullGroupData: [],
|
|
tableSynchData: [],
|
|
tableSourceData: [],
|
|
// 收集的列配置(带分组)
|
|
collectColumn: [],
|
|
// 完整所有列(不带分组)
|
|
tableFullColumn: [],
|
|
// 渲染所有列
|
|
visibleColumn: [],
|
|
// 全量数据集(包括当前和已删除)
|
|
fullAllDataRowIdData: {},
|
|
// 数据集(仅当前)
|
|
fullDataRowIdData: {},
|
|
// 数据集(仅可视)
|
|
visibleDataRowIdData: {},
|
|
footerFullDataRowData: {},
|
|
// 渲染中缓存数据
|
|
sourceDataRowIdData: {},
|
|
fullColumnIdData: {},
|
|
fullColumnFieldData: {},
|
|
// 合并表头单元格的数据
|
|
mergeHeaderList: [],
|
|
mergeHeaderMaps: {},
|
|
// 已合并单元格数据集合
|
|
mergeHeaderCellMaps: {},
|
|
// 合并单元格的数据
|
|
mergeBodyList: [],
|
|
mergeBodyMaps: {},
|
|
// 已合并单元格数据集合
|
|
mergeBodyCellMaps: {},
|
|
// 合并表尾的数据
|
|
mergeFooterList: [],
|
|
mergeFooterMaps: {},
|
|
// 已合并表尾数据集合
|
|
mergeFooterCellMaps: {},
|
|
// 已展开的行集合
|
|
rowExpandedMaps: {},
|
|
// 懒加载中的展开行的集合
|
|
rowExpandLazyLoadedMaps: {},
|
|
// 已展开的分组行
|
|
rowGroupExpandedMaps: {},
|
|
// 已展开树节点集合
|
|
treeExpandedMaps: {},
|
|
// 懒加载中的树节点的集合
|
|
treeExpandLazyLoadedMaps: {},
|
|
// 复选框属性,已选中的行集合
|
|
selectCheckboxMaps: {},
|
|
// 已标记的对象集
|
|
pendingRowMaps: {},
|
|
// 已新增的临时行
|
|
insertRowMaps: {},
|
|
// 已删除行
|
|
removeRowMaps: {},
|
|
cvCacheMaps: {},
|
|
// 表头高度
|
|
tHeaderHeight: 0,
|
|
// 表体高度
|
|
tBodyHeight: 0,
|
|
// 表尾高度
|
|
tFooterHeight: 0,
|
|
teleportToWrapperElem: null,
|
|
popupToWrapperElem: null,
|
|
inited: false,
|
|
tooltipTimeout: null,
|
|
initStatus: false,
|
|
isActivated: false
|
|
};
|
|
}
|
|
var getAllConvertColumns = (columns, parentColumn) => {
|
|
const result = [];
|
|
columns.forEach((column) => {
|
|
column.parentId = parentColumn ? parentColumn.id : null;
|
|
if (column.visible) {
|
|
if (column.children && column.children.length && column.children.some((column2) => column2.visible)) {
|
|
result.push(column);
|
|
result.push(...getAllConvertColumns(column.children, column));
|
|
} else {
|
|
result.push(column);
|
|
}
|
|
}
|
|
});
|
|
return result;
|
|
};
|
|
var convertHeaderColumnToRows = (originColumns) => {
|
|
let maxLevel = 1;
|
|
const traverse = (column, parent) => {
|
|
if (parent) {
|
|
column.level = parent.level + 1;
|
|
if (maxLevel < column.level) {
|
|
maxLevel = column.level;
|
|
}
|
|
}
|
|
if (column.children && column.children.length && column.children.some((column2) => column2.visible)) {
|
|
let colSpan = 0;
|
|
column.children.forEach((subColumn) => {
|
|
if (subColumn.visible) {
|
|
traverse(subColumn, column);
|
|
colSpan += subColumn.colSpan;
|
|
}
|
|
});
|
|
column.colSpan = colSpan;
|
|
} else {
|
|
column.colSpan = 1;
|
|
}
|
|
};
|
|
originColumns.forEach((column) => {
|
|
column.level = 1;
|
|
traverse(column);
|
|
});
|
|
const rows = [];
|
|
for (let i = 0; i < maxLevel; i++) {
|
|
rows.push([]);
|
|
}
|
|
const allColumns = getAllConvertColumns(originColumns);
|
|
allColumns.forEach((column) => {
|
|
if (column.children && column.children.length && column.children.some((column2) => column2.visible)) {
|
|
column.rowSpan = 1;
|
|
} else {
|
|
column.rowSpan = maxLevel - column.level + 1;
|
|
}
|
|
rows[column.level - 1].push(column);
|
|
});
|
|
return rows;
|
|
};
|
|
function convertHeaderToGridRows(spanColumns) {
|
|
const rSize = spanColumns.length;
|
|
const cSize = spanColumns[0].reduce((sum, cell) => sum + cell.colSpan, 0);
|
|
const occupiedRows = [];
|
|
const fullRows = [];
|
|
for (let rIndex = 0; rIndex < rSize; rIndex++) {
|
|
const oCols = [];
|
|
const dCols = [];
|
|
for (let cIndex = 0; cIndex < cSize; cIndex++) {
|
|
oCols.push(false);
|
|
dCols.push("");
|
|
}
|
|
occupiedRows.push(oCols);
|
|
fullRows.push(dCols);
|
|
}
|
|
for (let rIndex = 0; rIndex < rSize; rIndex++) {
|
|
let currColIndex = 0;
|
|
for (const column of spanColumns[rIndex]) {
|
|
const { colSpan, rowSpan } = column;
|
|
let startColIndex = -1;
|
|
for (let ccIndex = currColIndex; ccIndex <= cSize - colSpan; ccIndex++) {
|
|
let oFlag = true;
|
|
for (let csIndex = 0; csIndex < colSpan; csIndex++) {
|
|
if (occupiedRows[rIndex][ccIndex + csIndex]) {
|
|
oFlag = false;
|
|
break;
|
|
}
|
|
}
|
|
if (oFlag) {
|
|
startColIndex = ccIndex;
|
|
break;
|
|
}
|
|
}
|
|
if (startColIndex === -1) {
|
|
for (let j = 0; j <= cSize - colSpan; j++) {
|
|
let oFlag = true;
|
|
for (let k = 0; k < colSpan; k++) {
|
|
if (occupiedRows[rIndex][j + k]) {
|
|
oFlag = false;
|
|
break;
|
|
}
|
|
}
|
|
if (oFlag) {
|
|
startColIndex = j;
|
|
break;
|
|
}
|
|
}
|
|
if (startColIndex === -1) {
|
|
break;
|
|
}
|
|
}
|
|
for (let srIndex = rIndex; srIndex < rIndex + rowSpan; srIndex++) {
|
|
for (let scIndex = startColIndex; scIndex < startColIndex + colSpan; scIndex++) {
|
|
occupiedRows[srIndex][scIndex] = true;
|
|
fullRows[srIndex][scIndex] = column;
|
|
}
|
|
}
|
|
currColIndex = startColIndex + colSpan;
|
|
}
|
|
}
|
|
return fullRows;
|
|
}
|
|
function restoreScrollLocation($xeTable, scrollLeft, scrollTop) {
|
|
const internalData = $xeTable.internalData;
|
|
if (scrollLeft || scrollTop) {
|
|
internalData.intoRunScroll = false;
|
|
internalData.inVirtualScroll = false;
|
|
internalData.inWheelScroll = false;
|
|
internalData.inHeaderScroll = false;
|
|
internalData.inBodyScroll = false;
|
|
internalData.inFooterScroll = false;
|
|
internalData.scrollRenderType = "";
|
|
return $xeTable.scrollTo(scrollLeft, scrollTop);
|
|
}
|
|
return $xeTable.clearScroll();
|
|
}
|
|
function getRowUniqueId() {
|
|
return import_xe_utils3.default.uniqueId("row_");
|
|
}
|
|
function hasDeepKey(rowKey) {
|
|
return rowKey.indexOf(".") > -1;
|
|
}
|
|
function getRowkey($xeTable) {
|
|
const { currKeyField } = $xeTable.internalData;
|
|
return currKeyField;
|
|
}
|
|
function getRowid($xeTable, row) {
|
|
const internalData = $xeTable.internalData;
|
|
const { isCurrDeepKey, currKeyField } = internalData;
|
|
return row ? encodeRowid((isCurrDeepKey ? getDeepRowIdByKey : getFastRowIdByKey)(row, currKeyField)) : "";
|
|
}
|
|
function createHandleUpdateRowId($xeTable) {
|
|
const internalData = $xeTable.internalData;
|
|
const { isCurrDeepKey, currKeyField } = internalData;
|
|
const updateRId = isCurrDeepKey ? updateDeepRowKey : updateFastRowKey;
|
|
return {
|
|
rowKey: currKeyField,
|
|
handleUpdateRowId(row) {
|
|
return row ? updateRId(row, currKeyField) : "";
|
|
}
|
|
};
|
|
}
|
|
function createHandleGetRowId($xeTable) {
|
|
const internalData = $xeTable.internalData;
|
|
const { isCurrDeepKey, currKeyField } = internalData;
|
|
const getRId = isCurrDeepKey ? getDeepRowIdByKey : getFastRowIdByKey;
|
|
return {
|
|
rowKey: currKeyField,
|
|
handleGetRowId(row) {
|
|
return row ? encodeRowid(getRId(row, currKeyField)) : "";
|
|
}
|
|
};
|
|
}
|
|
function encodeRowid(rowVal) {
|
|
return import_xe_utils3.default.eqNull(rowVal) ? "" : encodeURIComponent(rowVal);
|
|
}
|
|
function getDeepRowIdByKey(row, rowKey) {
|
|
return import_xe_utils3.default.get(row, rowKey);
|
|
}
|
|
function updateDeepRowKey(row, rowKey) {
|
|
let rowid = encodeRowid(getDeepRowIdByKey(row, rowKey));
|
|
if (eqEmptyValue(rowid)) {
|
|
rowid = getRowUniqueId();
|
|
import_xe_utils3.default.set(row, rowKey, rowid);
|
|
}
|
|
return rowid;
|
|
}
|
|
function getFastRowIdByKey(row, rowKey) {
|
|
return row[rowKey];
|
|
}
|
|
function updateFastRowKey(row, rowKey) {
|
|
let rowid = encodeRowid(getFastRowIdByKey(row, rowKey));
|
|
if (eqEmptyValue(rowid)) {
|
|
rowid = getRowUniqueId();
|
|
row[rowKey] = rowid;
|
|
}
|
|
return rowid;
|
|
}
|
|
function handleFieldOrColumn($xeTable, fieldOrColumn) {
|
|
if (fieldOrColumn) {
|
|
return import_xe_utils3.default.isString(fieldOrColumn) || import_xe_utils3.default.isNumber(fieldOrColumn) ? $xeTable.getColumnByField(`${fieldOrColumn}`) : fieldOrColumn;
|
|
}
|
|
return null;
|
|
}
|
|
function handleRowidOrRow($xeTable, rowidOrRow) {
|
|
if (rowidOrRow) {
|
|
const rowid = import_xe_utils3.default.isString(rowidOrRow) || import_xe_utils3.default.isNumber(rowidOrRow) ? rowidOrRow : getRowid($xeTable, rowidOrRow);
|
|
return $xeTable.getRowById(rowid);
|
|
}
|
|
return null;
|
|
}
|
|
function getCellRestHeight(rowRest, cellOpts, rowOpts, defaultRowHeight) {
|
|
return rowRest.resizeHeight || cellOpts.height || rowOpts.height || rowRest.height || defaultRowHeight;
|
|
}
|
|
function getPaddingLeftRightSize(elem) {
|
|
if (elem) {
|
|
const computedStyle = getComputedStyle(elem);
|
|
const paddingLeft = import_xe_utils3.default.toNumber(computedStyle.paddingLeft);
|
|
const paddingRight = import_xe_utils3.default.toNumber(computedStyle.paddingRight);
|
|
return paddingLeft + paddingRight;
|
|
}
|
|
return 0;
|
|
}
|
|
function getElementMarginAndWidth(elem) {
|
|
if (elem) {
|
|
const computedStyle = getComputedStyle(elem);
|
|
const marginLeft = import_xe_utils3.default.toNumber(computedStyle.marginLeft);
|
|
const marginRight = import_xe_utils3.default.toNumber(computedStyle.marginRight);
|
|
return elem.offsetWidth + marginLeft + marginRight;
|
|
}
|
|
return 0;
|
|
}
|
|
function toFilters(filters, colid) {
|
|
if (filters) {
|
|
if (import_xe_utils3.default.isArray(filters)) {
|
|
return filters.map(({ label, value, data, resetValue, checked }) => {
|
|
return { label, value, data, resetValue, checked: !!checked, _checked: !!checked, _colId: colid };
|
|
});
|
|
}
|
|
return [];
|
|
}
|
|
return filters;
|
|
}
|
|
function toTreePathSeq(path) {
|
|
return path.map((num, i) => i % 2 === 0 ? Number(num) + 1 : ".").join("");
|
|
}
|
|
function getCellValue(row, column) {
|
|
return import_xe_utils3.default.get(row, column.field);
|
|
}
|
|
function setCellValue(row, column, value) {
|
|
return import_xe_utils3.default.set(row, column.field, value);
|
|
}
|
|
function getRefElem(refEl) {
|
|
if (refEl) {
|
|
const rest = refEl.value;
|
|
if (rest) {
|
|
return rest.$el || rest;
|
|
}
|
|
}
|
|
return null;
|
|
}
|
|
function getCalcHeight(height) {
|
|
if (height === "unset") {
|
|
return 0;
|
|
}
|
|
return height || 0;
|
|
}
|
|
function getColReMinWidth(params) {
|
|
const { $table, column, cell } = params;
|
|
const tableProps = $table.props;
|
|
const internalData = $table.internalData;
|
|
const { computeResizableOpts } = $table.getComputeMaps();
|
|
const resizableOpts = computeResizableOpts.value;
|
|
const { minWidth: reMinWidth } = resizableOpts;
|
|
if (reMinWidth) {
|
|
const customMinWidth = import_xe_utils3.default.isFunction(reMinWidth) ? reMinWidth(params) : reMinWidth;
|
|
if (customMinWidth !== "auto") {
|
|
return Math.max(1, import_xe_utils3.default.toNumber(customMinWidth));
|
|
}
|
|
}
|
|
const { elemStore } = internalData;
|
|
const { showHeaderOverflow: allColumnHeaderOverflow } = tableProps;
|
|
const { showHeaderOverflow, minWidth: colMinWidth } = column;
|
|
const headOverflow = import_xe_utils3.default.isUndefined(showHeaderOverflow) || import_xe_utils3.default.isNull(showHeaderOverflow) ? allColumnHeaderOverflow : showHeaderOverflow;
|
|
const showEllipsis = headOverflow === "ellipsis";
|
|
const showTitle = headOverflow === "title";
|
|
const showTooltip = headOverflow === true || headOverflow === "tooltip";
|
|
const hasEllipsis = showTitle || showTooltip || showEllipsis;
|
|
const minTitleWidth = import_xe_utils3.default.floor((import_xe_utils3.default.toNumber(getComputedStyle(cell).fontSize) || 14) * 1.8);
|
|
const paddingLeftRight = getPaddingLeftRightSize(cell) + getPaddingLeftRightSize(queryElement(cell, ".vxe-cell"));
|
|
let mWidth = minTitleWidth + paddingLeftRight;
|
|
if (hasEllipsis) {
|
|
const dragIconWidth = getElementMarginAndWidth(queryElement(cell, ".vxe-cell--drag-handle"));
|
|
const checkboxIconWidth = getElementMarginAndWidth(queryElement(cell, ".vxe-cell--checkbox"));
|
|
const requiredIconWidth = getElementMarginAndWidth(queryElement(cell, ".vxe-cell--required-icon"));
|
|
const editIconWidth = getElementMarginAndWidth(queryElement(cell, ".vxe-cell--edit-icon"));
|
|
const prefixIconWidth = getElementMarginAndWidth(queryElement(cell, ".vxe-cell-title-prefix-icon"));
|
|
const suffixIconWidth = getElementMarginAndWidth(queryElement(cell, ".vxe-cell-title-suffix-icon"));
|
|
const sortIconWidth = getElementMarginAndWidth(queryElement(cell, ".vxe-cell--sort"));
|
|
const filterIconWidth = getElementMarginAndWidth(queryElement(cell, ".vxe-cell--filter"));
|
|
mWidth += dragIconWidth + checkboxIconWidth + requiredIconWidth + editIconWidth + prefixIconWidth + suffixIconWidth + filterIconWidth + sortIconWidth;
|
|
}
|
|
if (colMinWidth) {
|
|
const bodyScrollElem = getRefElem(elemStore["main-body-scroll"]);
|
|
if (bodyScrollElem) {
|
|
if (isScale(colMinWidth)) {
|
|
const bodyWidth = bodyScrollElem.clientWidth - 1;
|
|
const meanWidth = bodyWidth / 100;
|
|
return Math.max(mWidth, Math.floor(import_xe_utils3.default.toInteger(colMinWidth) * meanWidth));
|
|
} else if (isPx(colMinWidth)) {
|
|
return Math.max(mWidth, import_xe_utils3.default.toInteger(colMinWidth));
|
|
}
|
|
}
|
|
}
|
|
return mWidth;
|
|
}
|
|
function isColumnInfo(column) {
|
|
return column && (column.constructor === ColumnInfo || column instanceof ColumnInfo);
|
|
}
|
|
function getColumnList(columns) {
|
|
const result = [];
|
|
columns.forEach((column) => {
|
|
result.push(...column.children && column.children.length ? getColumnList(column.children) : [column]);
|
|
});
|
|
return result;
|
|
}
|
|
function createColumn($xeTable, options, renderOptions) {
|
|
return isColumnInfo(options) ? options : reactive(new ColumnInfo($xeTable, options, renderOptions));
|
|
}
|
|
function watchColumn($xeTable, props, column) {
|
|
Object.keys(props).forEach((name) => {
|
|
watch(() => props[name], (value) => {
|
|
column.update(name, value);
|
|
if ($xeTable) {
|
|
if (name === "filters") {
|
|
$xeTable.setFilter(column, value);
|
|
$xeTable.handleUpdateDataQueue();
|
|
} else if (["visible", "fixed", "width", "minWidth", "maxWidth"].includes(name)) {
|
|
$xeTable.handleRefreshColumnQueue();
|
|
}
|
|
}
|
|
});
|
|
});
|
|
}
|
|
function assembleColumn($xeTable, elem, column, colgroup) {
|
|
const { reactData } = $xeTable;
|
|
const { staticColumns } = reactData;
|
|
const parentElem = elem.parentNode;
|
|
const parentColumn = colgroup ? colgroup.columnConfig : null;
|
|
const parentCols = parentColumn ? parentColumn.children : staticColumns;
|
|
if (parentElem && parentCols) {
|
|
column.defaultParentId = parentColumn ? parentColumn.id : null;
|
|
parentCols.splice(import_xe_utils3.default.arrayIndexOf(parentElem.children, elem), 0, column);
|
|
reactData.staticColumns = staticColumns.slice(0);
|
|
}
|
|
}
|
|
function destroyColumn($xeTable, column) {
|
|
const { reactData } = $xeTable;
|
|
const { staticColumns } = reactData;
|
|
const matchObj = import_xe_utils3.default.findTree(staticColumns, (item) => item.id === column.id, { children: "children" });
|
|
if (matchObj) {
|
|
matchObj.items.splice(matchObj.index, 1);
|
|
}
|
|
reactData.staticColumns = staticColumns.slice(0);
|
|
}
|
|
function getRootColumn($xeTable, column) {
|
|
const { internalData } = $xeTable;
|
|
const { fullColumnIdData } = internalData;
|
|
if (!column) {
|
|
return null;
|
|
}
|
|
let parentColId = column.parentId;
|
|
while (fullColumnIdData[parentColId]) {
|
|
const column2 = fullColumnIdData[parentColId].column;
|
|
parentColId = column2.parentId;
|
|
if (!parentColId) {
|
|
return column2;
|
|
}
|
|
}
|
|
return column;
|
|
}
|
|
function getFirstChildColumn(column) {
|
|
const { children } = column;
|
|
if (children && children.length) {
|
|
return getFirstChildColumn(import_xe_utils3.default.first(children));
|
|
}
|
|
return column;
|
|
}
|
|
function getLastChildColumn(column) {
|
|
const { children } = column;
|
|
if (children && children.length) {
|
|
return getFirstChildColumn(import_xe_utils3.default.last(children));
|
|
}
|
|
return column;
|
|
}
|
|
function clearTableDefaultStatus($xeTable) {
|
|
const { props, internalData } = $xeTable;
|
|
internalData.initStatus = false;
|
|
const actionList = [
|
|
$xeTable.clearSort(),
|
|
$xeTable.clearCurrentRow(),
|
|
$xeTable.clearCurrentColumn(),
|
|
$xeTable.clearRadioRow(),
|
|
$xeTable.clearRadioReserve(),
|
|
$xeTable.clearCheckboxRow(),
|
|
$xeTable.clearCheckboxReserve(),
|
|
$xeTable.clearRowExpand(),
|
|
$xeTable.clearTreeExpand(),
|
|
$xeTable.clearTreeExpandReserve(),
|
|
$xeTable.clearPendingRow()
|
|
];
|
|
if ($xeTable.clearFilter) {
|
|
actionList.push($xeTable.clearFilter());
|
|
}
|
|
if ($xeTable.clearSelected && (props.keyboardConfig || props.mouseConfig)) {
|
|
actionList.push($xeTable.clearSelected());
|
|
}
|
|
if ($xeTable.clearCellAreas && props.mouseConfig) {
|
|
actionList.push($xeTable.clearCellAreas(), $xeTable.clearCopyCellArea());
|
|
}
|
|
return Promise.all(actionList).then(() => {
|
|
return $xeTable.clearScroll();
|
|
});
|
|
}
|
|
function clearTableAllStatus($xeTable) {
|
|
if ($xeTable.clearFilter) {
|
|
$xeTable.clearFilter();
|
|
}
|
|
return clearTableDefaultStatus($xeTable);
|
|
}
|
|
function rowToVisible($xeTable, row) {
|
|
const tableProps = $xeTable.props;
|
|
const reactData = $xeTable.reactData;
|
|
const internalData = $xeTable.internalData;
|
|
const { computeLeftFixedWidth, computeRightFixedWidth, computeRowOpts, computeCellOpts, computeDefaultRowHeight } = $xeTable.getComputeMaps();
|
|
const { showOverflow } = tableProps;
|
|
const { scrollYLoad, scrollYTop } = reactData;
|
|
const { elemStore, afterFullData, fullAllDataRowIdData, isResizeCellHeight } = internalData;
|
|
const rowOpts = computeRowOpts.value;
|
|
const cellOpts = computeCellOpts.value;
|
|
const defaultRowHeight = computeDefaultRowHeight.value;
|
|
const leftFixedWidth = computeLeftFixedWidth.value;
|
|
const rightFixedWidth = computeRightFixedWidth.value;
|
|
const bodyScrollElem = getRefElem(elemStore["main-body-scroll"]);
|
|
const rowid = getRowid($xeTable, row);
|
|
if (bodyScrollElem) {
|
|
const bodyHeight = bodyScrollElem.clientHeight;
|
|
const bodyScrollTop = bodyScrollElem.scrollTop;
|
|
const trElem = bodyScrollElem.querySelector(`[rowid="${rowid}"]`);
|
|
if (trElem) {
|
|
const trOffsetTop = trElem.offsetTop + (scrollYLoad ? scrollYTop : 0);
|
|
const trHeight = trElem.clientHeight;
|
|
if (trOffsetTop < bodyScrollTop || trOffsetTop > bodyScrollTop + bodyHeight) {
|
|
return $xeTable.scrollTo(null, trOffsetTop);
|
|
} else if (trOffsetTop + trHeight >= bodyHeight + bodyScrollTop) {
|
|
return $xeTable.scrollTo(null, bodyScrollTop + trHeight);
|
|
}
|
|
} else {
|
|
if (scrollYLoad) {
|
|
const isCustomCellHeight = isResizeCellHeight || cellOpts.height || rowOpts.height;
|
|
if (!isCustomCellHeight && showOverflow) {
|
|
return $xeTable.scrollTo(null, ($xeTable.findRowIndexOf(afterFullData, row) - 1) * defaultRowHeight);
|
|
}
|
|
const rowRest = fullAllDataRowIdData[rowid] || {};
|
|
const rHeight = rowRest.resizeHeight || cellOpts.height || rowOpts.height || rowRest.height || defaultRowHeight;
|
|
const scrollTop = rowRest.oTop;
|
|
if (scrollTop < bodyScrollTop) {
|
|
return $xeTable.scrollTo(null, scrollTop - leftFixedWidth - 1);
|
|
}
|
|
return $xeTable.scrollTo(null, scrollTop + rHeight - (bodyHeight - rightFixedWidth - 1));
|
|
}
|
|
}
|
|
}
|
|
return Promise.resolve();
|
|
}
|
|
function colToVisible($xeTable, column, row) {
|
|
const reactData = $xeTable.reactData;
|
|
const internalData = $xeTable.internalData;
|
|
const { computeLeftFixedWidth, computeRightFixedWidth } = $xeTable.getComputeMaps();
|
|
const { scrollXLoad, scrollXLeft } = reactData;
|
|
const { elemStore, visibleColumn } = internalData;
|
|
const leftFixedWidth = computeLeftFixedWidth.value;
|
|
const rightFixedWidth = computeRightFixedWidth.value;
|
|
const bodyScrollElem = getRefElem(elemStore["main-body-scroll"]);
|
|
if (column.fixed) {
|
|
return Promise.resolve();
|
|
}
|
|
if (bodyScrollElem) {
|
|
const bodyWidth = bodyScrollElem.clientWidth;
|
|
const bodyScrollLeft = bodyScrollElem.scrollLeft;
|
|
let tdElem = null;
|
|
if (row) {
|
|
const rowid = getRowid($xeTable, row);
|
|
tdElem = bodyScrollElem.querySelector(`[rowid="${rowid}"] .${column.id}`);
|
|
}
|
|
if (!tdElem) {
|
|
tdElem = bodyScrollElem.querySelector(`.${column.id}`);
|
|
}
|
|
if (tdElem) {
|
|
const tdOffsetLeft = tdElem.offsetLeft + (scrollXLoad ? scrollXLeft : 0);
|
|
const cellWidth = tdElem.clientWidth;
|
|
if (tdOffsetLeft < bodyScrollLeft + leftFixedWidth) {
|
|
return $xeTable.scrollTo(tdOffsetLeft - leftFixedWidth - 1);
|
|
} else if (tdOffsetLeft + cellWidth - bodyScrollLeft > bodyWidth - rightFixedWidth) {
|
|
return $xeTable.scrollTo(tdOffsetLeft + cellWidth - (bodyWidth - rightFixedWidth - 1));
|
|
}
|
|
} else {
|
|
if (scrollXLoad) {
|
|
let scrollLeft = 0;
|
|
const cellWidth = column.renderWidth;
|
|
for (let i = 0; i < visibleColumn.length; i++) {
|
|
const currCol = visibleColumn[i];
|
|
if (currCol === column || currCol.id === column.id) {
|
|
break;
|
|
}
|
|
scrollLeft += currCol.renderWidth;
|
|
}
|
|
if (scrollLeft < bodyScrollLeft) {
|
|
return $xeTable.scrollTo(scrollLeft - leftFixedWidth - 1);
|
|
}
|
|
return $xeTable.scrollTo(scrollLeft + cellWidth - (bodyWidth - rightFixedWidth - 1));
|
|
}
|
|
}
|
|
}
|
|
return Promise.resolve();
|
|
}
|
|
|
|
// ../node_modules/.pnpm/vxe-table@4.17.14_vue@3.5.24_typescript@5.9.3_/node_modules/vxe-table/es/table/src/cell.js
|
|
var import_xe_utils4 = __toESM(require_xe_utils());
|
|
var { getI18n: getI18n2, getIcon, renderer: renderer2, renderEmptyElement } = VxeUI;
|
|
function renderTitlePrefixIcon(params) {
|
|
const { $table, column } = params;
|
|
const titlePrefix = column.titlePrefix || column.titleHelp;
|
|
if (titlePrefix) {
|
|
return h("span", {
|
|
class: ["vxe-cell-title-prefix-icon", titlePrefix.iconStatus ? `theme--${titlePrefix.iconStatus}` : ""],
|
|
onMouseenter(evnt) {
|
|
$table.triggerHeaderTitleEvent(evnt, titlePrefix, params);
|
|
},
|
|
onMouseleave(evnt) {
|
|
$table.handleTargetLeaveEvent(evnt);
|
|
}
|
|
}, [
|
|
h("i", {
|
|
class: titlePrefix.icon || getIcon().TABLE_TITLE_PREFIX
|
|
})
|
|
]);
|
|
}
|
|
return renderEmptyElement($table);
|
|
}
|
|
function renderTitleSuffixIcon(params) {
|
|
const { $table, column } = params;
|
|
const titleSuffix = column.titleSuffix;
|
|
if (titleSuffix) {
|
|
return h("span", {
|
|
class: ["vxe-cell-title-suffix-icon", titleSuffix.iconStatus ? `theme--${titleSuffix.iconStatus}` : ""],
|
|
onMouseenter(evnt) {
|
|
$table.triggerHeaderTitleEvent(evnt, titleSuffix, params);
|
|
},
|
|
onMouseleave(evnt) {
|
|
$table.handleTargetLeaveEvent(evnt);
|
|
}
|
|
}, [
|
|
h("i", {
|
|
class: titleSuffix.icon || getIcon().TABLE_TITLE_SUFFIX
|
|
})
|
|
]);
|
|
}
|
|
return renderEmptyElement($table);
|
|
}
|
|
function renderCellDragIcon(params) {
|
|
const { $table, column } = params;
|
|
const { context } = $table;
|
|
const tableSlots = context.slots;
|
|
const tableProps = $table.props;
|
|
const { slots } = column;
|
|
const { dragConfig } = tableProps;
|
|
const { computeRowDragOpts } = $table.getComputeMaps();
|
|
const rowDragOpts = computeRowDragOpts.value;
|
|
const { icon, trigger, disabledMethod } = rowDragOpts;
|
|
const rDisabledMethod = disabledMethod || (dragConfig ? dragConfig.rowDisabledMethod : null);
|
|
const isDisabled = rDisabledMethod && rDisabledMethod(params);
|
|
const rowDragIconSlot = (slots ? slots.rowDragIcon || slots["row-drag-icon"] : null) || tableSlots.rowDragIcon || tableSlots["row-drag-icon"];
|
|
const ons = {};
|
|
if (trigger !== "cell") {
|
|
ons.onMousedown = (evnt) => {
|
|
if (!isDisabled) {
|
|
$table.handleCellDragMousedownEvent(evnt, params);
|
|
}
|
|
};
|
|
ons.onMouseup = $table.handleCellDragMouseupEvent;
|
|
}
|
|
return h("span", Object.assign({ key: "dg", class: ["vxe-cell--drag-handle", {
|
|
"is--disabled": isDisabled
|
|
}] }, ons), rowDragIconSlot ? $table.callSlot(rowDragIconSlot, params) : [
|
|
h("i", {
|
|
class: icon || (dragConfig ? dragConfig.rowIcon : "") || getIcon().TABLE_DRAG_ROW
|
|
})
|
|
]);
|
|
}
|
|
function renderCellBaseVNs(params, content) {
|
|
const { $table, column, level } = params;
|
|
const { dragSort } = column;
|
|
const tableProps = $table.props;
|
|
const { treeConfig, dragConfig } = tableProps;
|
|
const { computeRowOpts, computeRowDragOpts, computeTreeOpts } = $table.getComputeMaps();
|
|
const rowOpts = computeRowOpts.value;
|
|
const rowDragOpts = computeRowDragOpts.value;
|
|
const treeOpts = computeTreeOpts.value;
|
|
const { showIcon, isPeerDrag, isCrossDrag, visibleMethod } = rowDragOpts;
|
|
const rVisibleMethod = visibleMethod || (dragConfig ? dragConfig.rowVisibleMethod : null);
|
|
const vns = [];
|
|
if (dragSort && rowOpts.drag && ((showIcon || (dragConfig ? dragConfig.showRowIcon : false)) && (!rVisibleMethod || rVisibleMethod(params)))) {
|
|
if (treeConfig) {
|
|
if (treeOpts.transform && (isPeerDrag || isCrossDrag || !level)) {
|
|
vns.push(renderCellDragIcon(params));
|
|
}
|
|
} else {
|
|
vns.push(renderCellDragIcon(params));
|
|
}
|
|
}
|
|
return vns.concat(import_xe_utils4.default.isArray(content) ? content : [content]);
|
|
}
|
|
function renderHeaderCellDragIcon(params) {
|
|
const { $table, column } = params;
|
|
const { context } = $table;
|
|
const tableSlots = context.slots;
|
|
const { slots } = column;
|
|
const { computeColumnOpts, computeColumnDragOpts } = $table.getComputeMaps();
|
|
const columnOpts = computeColumnOpts.value;
|
|
const columnDragOpts = computeColumnDragOpts.value;
|
|
const { showIcon, icon, trigger, isPeerDrag, isCrossDrag, visibleMethod, disabledMethod } = columnDragOpts;
|
|
if (columnOpts.drag && showIcon && (!visibleMethod || visibleMethod(params))) {
|
|
if (!column.fixed && (isPeerDrag || isCrossDrag || !column.parentId)) {
|
|
const isDisabled = disabledMethod && disabledMethod(params);
|
|
const columnDragIconSlot = (slots ? slots.columnDragIcon || slots["column-drag-icon"] : null) || tableSlots.columnDragIcon || tableSlots["column-drag-icon"];
|
|
const ons = {};
|
|
if (trigger !== "cell") {
|
|
ons.onMousedown = (evnt) => {
|
|
if (!isDisabled) {
|
|
$table.handleHeaderCellDragMousedownEvent(evnt, params);
|
|
}
|
|
};
|
|
ons.onMouseup = $table.handleHeaderCellDragMouseupEvent;
|
|
}
|
|
return h("span", Object.assign({ key: "dg", class: ["vxe-cell--drag-handle", {
|
|
"is--disabled": isDisabled
|
|
}] }, ons), columnDragIconSlot ? $table.callSlot(columnDragIconSlot, params) : [
|
|
h("i", {
|
|
class: icon || getIcon().TABLE_DRAG_COLUMN
|
|
})
|
|
]);
|
|
}
|
|
}
|
|
return renderEmptyElement($table);
|
|
}
|
|
function renderHeaderCellBaseVNs(params, content) {
|
|
const vns = [
|
|
renderTitlePrefixIcon(params),
|
|
renderHeaderCellDragIcon(params),
|
|
...import_xe_utils4.default.isArray(content) ? content : [content],
|
|
renderTitleSuffixIcon(params)
|
|
];
|
|
return vns;
|
|
}
|
|
function getRenderDefaultColumnTitle(column, content) {
|
|
if (column.type === "html" && import_xe_utils4.default.isString(content)) {
|
|
return h("span", {
|
|
key: "ch",
|
|
innerHTML: content
|
|
});
|
|
}
|
|
return h("span", {
|
|
key: "ct"
|
|
}, getSlotVNs(content));
|
|
}
|
|
function renderTitleContent(params, content) {
|
|
const { $table, column } = params;
|
|
const tableProps = $table.props;
|
|
const tableReactData = $table.reactData;
|
|
const { computeHeaderTooltipOpts } = $table.getComputeMaps();
|
|
const { showHeaderOverflow: allColumnHeaderOverflow } = tableProps;
|
|
const { isRowGroupStatus } = tableReactData;
|
|
const { showHeaderOverflow, slots } = column;
|
|
const titleSlot = slots ? slots.title : null;
|
|
const headerTooltipOpts = computeHeaderTooltipOpts.value;
|
|
const showAllTip = headerTooltipOpts.showAll;
|
|
const headOverflow = import_xe_utils4.default.eqNull(showHeaderOverflow) ? allColumnHeaderOverflow : showHeaderOverflow;
|
|
const showTitle = headOverflow === "title";
|
|
const showTooltip = headOverflow === true || headOverflow === "tooltip";
|
|
const ons = {};
|
|
if (showTitle || showTooltip || showAllTip) {
|
|
ons.onMouseenter = (evnt) => {
|
|
if (tableReactData.isDragResize) {
|
|
return;
|
|
}
|
|
if (showTitle) {
|
|
updateCellTitle(evnt.currentTarget, column);
|
|
} else if (showTooltip || showAllTip) {
|
|
$table.triggerHeaderTooltipEvent(evnt, params);
|
|
}
|
|
};
|
|
}
|
|
if (showTooltip || showAllTip) {
|
|
ons.onMouseleave = (evnt) => {
|
|
if (tableReactData.isDragResize) {
|
|
return;
|
|
}
|
|
if (showTooltip || showAllTip) {
|
|
$table.handleTargetLeaveEvent(evnt);
|
|
}
|
|
};
|
|
}
|
|
const titleVN = getRenderDefaultColumnTitle(column, content);
|
|
return [
|
|
h("span", Object.assign({ class: "vxe-cell--title" }, ons), isRowGroupStatus && column.aggFunc && $table.getPivotTableAggregateRenderColTitles ? $table.getPivotTableAggregateRenderColTitles(column, titleVN) : titleSlot ? $table.callSlot(titleSlot, params) : [
|
|
titleVN
|
|
])
|
|
];
|
|
}
|
|
function getFooterContent(params) {
|
|
const { $table, column, row } = params;
|
|
const { slots, editRender, cellRender } = column;
|
|
const renderOpts = editRender || cellRender;
|
|
const footerSlot = slots ? slots.footer : null;
|
|
if (footerSlot) {
|
|
return $table.callSlot(footerSlot, params);
|
|
}
|
|
const itemValue = $table.getFooterCellLabel(row, column);
|
|
if (renderOpts) {
|
|
const compConf = renderer2.get(renderOpts.name);
|
|
if (compConf) {
|
|
const rtFooter = compConf.renderTableFooter || compConf.renderFooter;
|
|
if (rtFooter) {
|
|
const footParams = Object.assign(params, {
|
|
cellValue: itemValue,
|
|
itemValue
|
|
});
|
|
return getSlotVNs(rtFooter(renderOpts, footParams));
|
|
}
|
|
}
|
|
}
|
|
return [
|
|
h("span", {
|
|
class: "vxe-cell--label"
|
|
}, formatText(itemValue, 1))
|
|
];
|
|
}
|
|
function getDefaultCellLabel(params) {
|
|
const { $table, row, column } = params;
|
|
return formatText($table.getCellLabel(row, column), 1);
|
|
}
|
|
function renderCellHandle(params) {
|
|
const { column, row, $table } = params;
|
|
const tableProps = $table.props;
|
|
const tableReactData = $table.reactData;
|
|
const { isRowGroupStatus } = tableReactData;
|
|
const { editConfig } = tableProps;
|
|
const { type, treeNode, rowGroupNode, editRender } = column;
|
|
const { computeEditOpts, computeCheckboxOpts, computeAggregateOpts } = $table.getComputeMaps();
|
|
const aggregateOpts = computeAggregateOpts.value;
|
|
const { mode } = aggregateOpts;
|
|
const checkboxOpts = computeCheckboxOpts.value;
|
|
const editOpts = computeEditOpts.value;
|
|
const isDeepCell = treeNode || isRowGroupStatus && (mode === "column" ? column.field === row.groupField : rowGroupNode);
|
|
switch (type) {
|
|
case "seq":
|
|
return isDeepCell ? Cell.renderDeepIndexCell(params) : Cell.renderSeqCell(params);
|
|
case "radio":
|
|
return isDeepCell ? Cell.renderDeepRadioCell(params) : Cell.renderRadioCell(params);
|
|
case "checkbox":
|
|
return checkboxOpts.checkField ? isDeepCell ? Cell.renderDeepSelectionCellByProp(params) : Cell.renderCheckboxCellByProp(params) : isDeepCell ? Cell.renderDeepSelectionCell(params) : Cell.renderCheckboxCell(params);
|
|
case "expand":
|
|
return Cell.renderExpandCell(params);
|
|
case "html":
|
|
return isDeepCell ? Cell.renderDeepHTMLCell(params) : Cell.renderHTMLCell(params);
|
|
}
|
|
if (editConfig && isEnableConf(editOpts) && editRender) {
|
|
return editOpts.mode === "cell" ? isDeepCell ? Cell.renderDeepCellEdit(params) : Cell.renderCellEdit(params) : isDeepCell ? Cell.renderDeepRowEdit(params) : Cell.renderRowEdit(params);
|
|
}
|
|
return isDeepCell ? Cell.renderDeepCell(params) : Cell.renderDefaultCell(params);
|
|
}
|
|
function renderHeaderHandle(params) {
|
|
const { column, $table } = params;
|
|
const tableProps = $table.props;
|
|
const { computeEditOpts } = $table.getComputeMaps();
|
|
const { editConfig } = tableProps;
|
|
const editOpts = computeEditOpts.value;
|
|
const { type, filters, sortable, editRender } = column;
|
|
switch (type) {
|
|
case "seq":
|
|
return Cell.renderSeqHeader(params);
|
|
case "radio":
|
|
return Cell.renderRadioHeader(params);
|
|
case "checkbox":
|
|
return Cell.renderCheckboxHeader(params);
|
|
case "html":
|
|
if (filters && sortable) {
|
|
return Cell.renderSortAndFilterHeader(params);
|
|
} else if (sortable) {
|
|
return Cell.renderSortHeader(params);
|
|
} else if (filters) {
|
|
return Cell.renderFilterHeader(params);
|
|
}
|
|
break;
|
|
}
|
|
if (editConfig && isEnableConf(editOpts) && editRender) {
|
|
return Cell.renderEditHeader(params);
|
|
} else if (filters && sortable) {
|
|
return Cell.renderSortAndFilterHeader(params);
|
|
} else if (sortable) {
|
|
return Cell.renderSortHeader(params);
|
|
} else if (filters) {
|
|
return Cell.renderFilterHeader(params);
|
|
}
|
|
return Cell.renderDefaultHeader(params);
|
|
}
|
|
function renderFooterHandle(params) {
|
|
return Cell.renderDefaultFooter(params);
|
|
}
|
|
var Cell = {
|
|
createColumn($xeTable, columnOpts) {
|
|
const { type } = columnOpts;
|
|
const renConfs = {
|
|
renderHeader: renderHeaderHandle,
|
|
renderCell: renderCellHandle,
|
|
renderFooter: renderFooterHandle
|
|
};
|
|
if (type === "expand") {
|
|
renConfs.renderData = Cell.renderExpandData;
|
|
}
|
|
return createColumn($xeTable, columnOpts, renConfs);
|
|
},
|
|
/**
|
|
* 列头标题
|
|
*/
|
|
renderHeaderTitle(params) {
|
|
const { $table, column } = params;
|
|
const { slots, editRender, cellRender } = column;
|
|
const renderOpts = editRender || cellRender;
|
|
const headerSlot = slots ? slots.header : null;
|
|
if (headerSlot) {
|
|
return renderTitleContent(params, $table.callSlot(headerSlot, params));
|
|
}
|
|
if (renderOpts) {
|
|
const compConf = renderer2.get(renderOpts.name);
|
|
if (compConf) {
|
|
const rtHeader = compConf.renderTableHeader || compConf.renderHeader;
|
|
if (rtHeader) {
|
|
return renderTitleContent(params, getSlotVNs(rtHeader(renderOpts, params)));
|
|
}
|
|
}
|
|
}
|
|
return renderTitleContent(params, formatText(column.getTitle(), 1));
|
|
},
|
|
renderDefaultHeader(params) {
|
|
return renderHeaderCellBaseVNs(params, Cell.renderHeaderTitle(params));
|
|
},
|
|
renderDefaultCell(params) {
|
|
const { $table, row, column } = params;
|
|
const tableProps = $table.props;
|
|
const tableReactData = $table.reactData;
|
|
const tableInternalData = $table.internalData;
|
|
const { isRowGroupStatus } = tableReactData;
|
|
const { editConfig } = tableProps;
|
|
const { field, slots, editRender, cellRender, rowGroupNode, aggFunc, formatter } = column;
|
|
const renderOpts = editConfig && isEnableConf(editRender) ? editRender : isEnableConf(cellRender) ? cellRender : null;
|
|
const defaultSlot = slots ? slots.default : null;
|
|
const gcSlot = slots ? slots.groupContent || slots["group-content"] : null;
|
|
let cellValue = "";
|
|
if (isRowGroupStatus && field && row.isAggregate) {
|
|
const aggRow = row;
|
|
const { fullColumnFieldData } = tableInternalData;
|
|
const { computeAggregateOpts } = $table.getComputeMaps();
|
|
const aggregateOpts = computeAggregateOpts.value;
|
|
const { mode, showTotal, totalMethod, countFields, contentMethod, mapChildrenField } = aggregateOpts;
|
|
const aggCalcMethod = aggregateOpts.calcValuesMethod || aggregateOpts.countMethod || aggregateOpts.aggregateMethod;
|
|
const groupField = aggRow.groupField;
|
|
const groupContent = aggRow.groupContent;
|
|
const childList = mapChildrenField ? aggRow[mapChildrenField] || [] : [];
|
|
const childCount = aggRow.childCount;
|
|
const colRest = fullColumnFieldData[groupField] || {};
|
|
const ctParams = {
|
|
$table,
|
|
groupField,
|
|
groupColumn: colRest ? colRest.column : null,
|
|
column,
|
|
groupValue: groupContent,
|
|
childList,
|
|
childCount,
|
|
aggValue: null,
|
|
/**
|
|
* 已废弃
|
|
* @deprecated
|
|
*/
|
|
children: childList,
|
|
/**
|
|
* 已废弃
|
|
* @deprecated
|
|
*/
|
|
totalValue: childCount
|
|
};
|
|
if (gcSlot) {
|
|
return renderCellBaseVNs(params, $table.callSlot(gcSlot, Object.assign({ groupField, groupContent, childList, childCount }, params)));
|
|
}
|
|
if (mode === "column" ? field === aggRow.groupField : rowGroupNode) {
|
|
cellValue = groupContent;
|
|
if (contentMethod) {
|
|
cellValue = `${contentMethod(ctParams)}`;
|
|
}
|
|
if (showTotal) {
|
|
cellValue = getI18n2("vxe.table.rowGroupContentTotal", [cellValue, totalMethod ? totalMethod(ctParams) : childCount, childCount]);
|
|
}
|
|
} else if ($table.getPivotTableAggregateCellAggValue) {
|
|
cellValue = $table.getPivotTableAggregateCellAggValue(params);
|
|
} else if (aggFunc === true || countFields && countFields.includes(field)) {
|
|
if (aggCalcMethod) {
|
|
ctParams.aggValue = childCount;
|
|
cellValue = `${aggCalcMethod(ctParams)}`;
|
|
}
|
|
}
|
|
} else {
|
|
if (defaultSlot) {
|
|
return renderCellBaseVNs(params, $table.callSlot(defaultSlot, params));
|
|
}
|
|
if (renderOpts && !formatter) {
|
|
const compConf = renderer2.get(renderOpts.name);
|
|
if (compConf) {
|
|
const rtCell = compConf.renderTableCell || compConf.renderCell;
|
|
const rtDefault = compConf.renderTableDefault || compConf.renderDefault;
|
|
const renderFn = editRender ? rtCell : rtDefault;
|
|
if (renderFn) {
|
|
return renderCellBaseVNs(params, getSlotVNs(renderFn(renderOpts, Object.assign({ $type: editRender ? "edit" : "cell" }, params))));
|
|
}
|
|
}
|
|
}
|
|
cellValue = $table.getCellLabel(row, column);
|
|
}
|
|
const cellPlaceholder = editRender ? editRender.placeholder : "";
|
|
return renderCellBaseVNs(params, [
|
|
h("span", {
|
|
class: "vxe-cell--label"
|
|
}, [
|
|
// 如果设置占位符
|
|
editRender && eqEmptyValue(cellValue) ? h("span", {
|
|
class: "vxe-cell--placeholder"
|
|
}, formatText(getFuncText(cellPlaceholder), 1)) : h("span", formatText(cellValue, 1))
|
|
])
|
|
]);
|
|
},
|
|
renderDeepCell(params) {
|
|
return Cell.renderDeepNodeBtn(params, Cell.renderDefaultCell(params));
|
|
},
|
|
renderDefaultFooter(params) {
|
|
return getFooterContent(params);
|
|
},
|
|
/**
|
|
* 行分组
|
|
*/
|
|
renderRowGroupBtn(params, cellVNodes) {
|
|
const { $table } = params;
|
|
const tableReactData = $table.reactData;
|
|
const tableInternalData = $table.internalData;
|
|
const { row, level } = params;
|
|
const { computeAggregateOpts } = $table.getComputeMaps();
|
|
const { rowGroupExpandedFlag } = tableReactData;
|
|
const { rowGroupExpandedMaps } = tableInternalData;
|
|
const aggregateOpts = computeAggregateOpts.value;
|
|
const { mode, padding, indent } = aggregateOpts;
|
|
const rowid = getRowid($table, row);
|
|
const isExpand = !!rowGroupExpandedFlag && !!rowGroupExpandedMaps[rowid];
|
|
return h("div", {
|
|
class: ["vxe-row-group--tree-node", {
|
|
"is--expanded": isExpand
|
|
}],
|
|
style: mode !== "column" && padding && indent ? {
|
|
paddingLeft: `${level * indent}px`
|
|
} : void 0
|
|
}, [
|
|
row.isAggregate ? h("span", {
|
|
class: "vxe-row-group--node-btn",
|
|
onClick(evnt) {
|
|
$table.triggerRowGroupExpandEvent(evnt, params);
|
|
}
|
|
}, [
|
|
h("i", {
|
|
class: isExpand ? getIcon().TABLE_ROW_GROUP_OPEN : getIcon().TABLE_ROW_GROUP_CLOSE
|
|
})
|
|
]) : renderEmptyElement($table),
|
|
h("div", {
|
|
class: "vxe-row-group-cell"
|
|
}, cellVNodes)
|
|
]);
|
|
},
|
|
/**
|
|
* 树
|
|
*/
|
|
renderTreeNodeBtn(params, cellVNodes) {
|
|
const { $table, isHidden } = params;
|
|
const tableReactData = $table.reactData;
|
|
const tableInternalData = $table.internalData;
|
|
const { row, column, level } = params;
|
|
const { slots } = column;
|
|
const iconSlot = slots ? slots.icon : null;
|
|
if (iconSlot) {
|
|
return $table.callSlot(iconSlot, params);
|
|
}
|
|
const { computeTreeOpts } = $table.getComputeMaps();
|
|
const { treeExpandedFlag } = tableReactData;
|
|
const { fullAllDataRowIdData, treeExpandedMaps, treeExpandLazyLoadedMaps } = tableInternalData;
|
|
const treeOpts = computeTreeOpts.value;
|
|
const { padding, indent, lazy, trigger, iconLoaded, showIcon, iconOpen, iconClose } = treeOpts;
|
|
const childrenField = treeOpts.children || treeOpts.childrenField;
|
|
const hasChildField = treeOpts.hasChild || treeOpts.hasChildField;
|
|
const rowChilds = row[childrenField];
|
|
const hasChild = rowChilds && rowChilds.length;
|
|
let hasLazyChilds = false;
|
|
let isActive = false;
|
|
let isLazyLoading = false;
|
|
let isLazyLoaded = false;
|
|
const ons = {};
|
|
if (!isHidden) {
|
|
const rowid = getRowid($table, row);
|
|
isActive = !!treeExpandedFlag && !!treeExpandedMaps[rowid];
|
|
if (lazy) {
|
|
const rest = fullAllDataRowIdData[rowid];
|
|
isLazyLoading = !!treeExpandLazyLoadedMaps[rowid];
|
|
hasLazyChilds = row[hasChildField];
|
|
isLazyLoaded = !!rest.treeLoaded;
|
|
}
|
|
}
|
|
if (!trigger || trigger === "default") {
|
|
ons.onClick = (evnt) => {
|
|
$table.triggerTreeExpandEvent(evnt, params);
|
|
};
|
|
}
|
|
return h("div", {
|
|
class: ["vxe-cell--tree-node", {
|
|
"is--active": isActive
|
|
}],
|
|
style: padding && indent ? {
|
|
paddingLeft: `${level * indent}px`
|
|
} : void 0
|
|
}, [
|
|
showIcon && (lazy ? isLazyLoaded ? hasChild : hasChild || hasLazyChilds : hasChild) ? [
|
|
h("div", Object.assign({ class: "vxe-cell--tree-btn" }, ons), [
|
|
h("i", {
|
|
class: isLazyLoading ? iconLoaded || getIcon().TABLE_TREE_LOADED : isActive ? iconOpen || getIcon().TABLE_TREE_OPEN : iconClose || getIcon().TABLE_TREE_CLOSE
|
|
})
|
|
])
|
|
] : null,
|
|
h("div", {
|
|
class: "vxe-tree-cell"
|
|
}, cellVNodes)
|
|
]);
|
|
},
|
|
/**
|
|
* 层级节点。
|
|
* 行分组、树结构
|
|
*/
|
|
renderDeepNodeBtn(params, cellVNodes) {
|
|
const { $table, row, column } = params;
|
|
const { rowGroupNode } = column;
|
|
const tableReactData = $table.reactData;
|
|
const { rowGroupList } = tableReactData;
|
|
if (rowGroupList.length) {
|
|
const { computeAggregateOpts } = $table.getComputeMaps();
|
|
const aggregateOpts = computeAggregateOpts.value;
|
|
const { mode } = aggregateOpts;
|
|
if (mode === "column" ? column.field === row.groupField : rowGroupNode) {
|
|
return [Cell.renderRowGroupBtn(params, cellVNodes)];
|
|
}
|
|
}
|
|
return [Cell.renderTreeNodeBtn(params, cellVNodes)];
|
|
},
|
|
/**
|
|
* 序号
|
|
*/
|
|
renderSeqHeader(params) {
|
|
const { $table, column } = params;
|
|
const { slots } = column;
|
|
const headerSlot = slots ? slots.header : null;
|
|
return renderHeaderCellBaseVNs(params, renderTitleContent(params, headerSlot ? $table.callSlot(headerSlot, params) : formatText(column.getTitle(), 1)));
|
|
},
|
|
renderSeqCell(params) {
|
|
const { $table, column } = params;
|
|
const tableProps = $table.props;
|
|
const { treeConfig } = tableProps;
|
|
const { computeSeqOpts } = $table.getComputeMaps();
|
|
const seqOpts = computeSeqOpts.value;
|
|
const { slots } = column;
|
|
const defaultSlot = slots ? slots.default : null;
|
|
if (defaultSlot) {
|
|
return renderCellBaseVNs(params, $table.callSlot(defaultSlot, params));
|
|
}
|
|
const { seq } = params;
|
|
const seqMd = seqOpts.seqMethod;
|
|
return renderCellBaseVNs(params, [
|
|
h("span", `${formatText(seqMd ? seqMd(params) : treeConfig ? seq : (seqOpts.startIndex || 0) + seq, 1)}`)
|
|
]);
|
|
},
|
|
renderDeepIndexCell(params) {
|
|
return Cell.renderDeepNodeBtn(params, Cell.renderSeqCell(params));
|
|
},
|
|
/**
|
|
* 单选
|
|
*/
|
|
renderRadioHeader(params) {
|
|
const { $table, column } = params;
|
|
const { slots } = column;
|
|
const headerSlot = slots ? slots.header : null;
|
|
const titleSlot = slots ? slots.title : null;
|
|
return renderHeaderCellBaseVNs(params, renderTitleContent(params, headerSlot ? $table.callSlot(headerSlot, params) : [
|
|
h("span", {
|
|
class: "vxe-radio--label"
|
|
}, titleSlot ? $table.callSlot(titleSlot, params) : formatText(column.getTitle(), 1))
|
|
]));
|
|
},
|
|
renderRadioCell(params) {
|
|
const { $table, column, isHidden } = params;
|
|
const tableReactData = $table.reactData;
|
|
const { computeRadioOpts } = $table.getComputeMaps();
|
|
const { selectRadioRow } = tableReactData;
|
|
const radioOpts = computeRadioOpts.value;
|
|
const { slots } = column;
|
|
const { labelField, checkMethod, visibleMethod } = radioOpts;
|
|
const { row } = params;
|
|
const defaultSlot = slots ? slots.default : null;
|
|
const radioSlot = slots ? slots.radio : null;
|
|
const isChecked = $table.eqRow(row, selectRadioRow);
|
|
const isVisible = !visibleMethod || visibleMethod({ $table, row });
|
|
let isDisabled = !!checkMethod;
|
|
let ons;
|
|
if (!isHidden) {
|
|
ons = {
|
|
onClick(evnt) {
|
|
if (!isDisabled && isVisible) {
|
|
$table.triggerRadioRowEvent(evnt, params);
|
|
}
|
|
}
|
|
};
|
|
if (checkMethod) {
|
|
isDisabled = !checkMethod({ $table, row });
|
|
}
|
|
}
|
|
const radioParams = Object.assign(Object.assign({}, params), { checked: isChecked, disabled: isDisabled, visible: isVisible });
|
|
if (radioSlot) {
|
|
return renderCellBaseVNs(params, $table.callSlot(radioSlot, radioParams));
|
|
}
|
|
const radioVNs = [];
|
|
if (isVisible) {
|
|
radioVNs.push(h("span", {
|
|
class: ["vxe-radio--icon", isChecked ? getIcon().TABLE_RADIO_CHECKED : isDisabled ? getIcon().TABLE_RADIO_DISABLED_UNCHECKED : getIcon().TABLE_RADIO_UNCHECKED]
|
|
}));
|
|
}
|
|
if (defaultSlot || labelField) {
|
|
radioVNs.push(h("span", {
|
|
class: "vxe-radio--label"
|
|
}, defaultSlot ? $table.callSlot(defaultSlot, radioParams) : import_xe_utils4.default.get(row, labelField)));
|
|
}
|
|
return renderCellBaseVNs(params, [
|
|
h("span", Object.assign({ class: ["vxe-cell--radio", {
|
|
"is--checked": isChecked,
|
|
"is--disabled": isDisabled
|
|
}] }, ons), radioVNs)
|
|
]);
|
|
},
|
|
renderDeepRadioCell(params) {
|
|
return Cell.renderDeepNodeBtn(params, Cell.renderRadioCell(params));
|
|
},
|
|
/**
|
|
* 多选
|
|
*/
|
|
renderCheckboxHeader(params) {
|
|
const { $table, column, isHidden } = params;
|
|
const tableReactData = $table.reactData;
|
|
const { computeIsAllCheckboxDisabled, computeCheckboxOpts } = $table.getComputeMaps();
|
|
const { isAllSelected: isAllCheckboxSelected, isIndeterminate: isAllCheckboxIndeterminate } = tableReactData;
|
|
const isAllCheckboxDisabled = computeIsAllCheckboxDisabled.value;
|
|
const { slots } = column;
|
|
const headerSlot = slots ? slots.header : null;
|
|
const titleSlot = slots ? slots.title : null;
|
|
const checkboxOpts = computeCheckboxOpts.value;
|
|
const { checkStrictly, showHeader, headerTitle } = checkboxOpts;
|
|
const colTitle = column.getTitle();
|
|
const ons = {};
|
|
if (!isHidden) {
|
|
ons.onClick = (evnt) => {
|
|
if (!isAllCheckboxDisabled) {
|
|
$table.triggerCheckAllEvent(evnt, !isAllCheckboxSelected);
|
|
}
|
|
};
|
|
}
|
|
const checkboxParams = Object.assign(Object.assign({}, params), { checked: isAllCheckboxSelected, disabled: isAllCheckboxDisabled, indeterminate: isAllCheckboxIndeterminate });
|
|
if (headerSlot) {
|
|
return renderHeaderCellBaseVNs(params, renderTitleContent(checkboxParams, $table.callSlot(headerSlot, checkboxParams)));
|
|
}
|
|
if (checkStrictly ? !showHeader : showHeader === false) {
|
|
return renderHeaderCellBaseVNs(params, renderTitleContent(checkboxParams, [
|
|
h("span", {
|
|
class: "vxe-checkbox--label"
|
|
}, titleSlot ? $table.callSlot(titleSlot, checkboxParams) : colTitle)
|
|
]));
|
|
}
|
|
return renderHeaderCellBaseVNs(params, renderTitleContent(checkboxParams, [
|
|
h("span", Object.assign({ class: ["vxe-cell--checkbox", {
|
|
"is--checked": isAllCheckboxSelected,
|
|
"is--disabled": isAllCheckboxDisabled,
|
|
"is--indeterminate": isAllCheckboxIndeterminate
|
|
}], title: import_xe_utils4.default.eqNull(headerTitle) ? getI18n2("vxe.table.allTitle") : `${headerTitle || ""}` }, ons), [
|
|
h("span", {
|
|
class: ["vxe-checkbox--icon", isAllCheckboxIndeterminate ? getIcon().TABLE_CHECKBOX_INDETERMINATE : isAllCheckboxSelected ? getIcon().TABLE_CHECKBOX_CHECKED : isAllCheckboxDisabled ? getIcon().TABLE_CHECKBOX_DISABLED_UNCHECKED : getIcon().TABLE_CHECKBOX_UNCHECKED]
|
|
})
|
|
].concat(titleSlot || colTitle ? [
|
|
h("span", {
|
|
class: "vxe-checkbox--label"
|
|
}, titleSlot ? $table.callSlot(titleSlot, checkboxParams) : colTitle)
|
|
] : []))
|
|
]));
|
|
},
|
|
renderCheckboxCell(params) {
|
|
const { $table, row, column, isHidden } = params;
|
|
const tableProps = $table.props;
|
|
const tableReactData = $table.reactData;
|
|
const tableInternalData = $table.internalData;
|
|
const { treeConfig } = tableProps;
|
|
const { updateCheckboxFlag, isRowGroupStatus } = tableReactData;
|
|
const { selectCheckboxMaps, treeIndeterminateRowMaps } = tableInternalData;
|
|
const { computeCheckboxOpts, computeAggregateOpts } = $table.getComputeMaps();
|
|
const aggregateOpts = computeAggregateOpts.value;
|
|
const { mapChildrenField } = aggregateOpts;
|
|
const checkboxOpts = computeCheckboxOpts.value;
|
|
const { labelField, checkMethod, visibleMethod } = checkboxOpts;
|
|
const { slots } = column;
|
|
const defaultSlot = slots ? slots.default : null;
|
|
const checkboxSlot = slots ? slots.checkbox : null;
|
|
let indeterminate = false;
|
|
let isChecked = false;
|
|
let isVisible = true;
|
|
let isDisabled = false;
|
|
const ons = {};
|
|
if (!isHidden) {
|
|
const rowid = getRowid($table, row);
|
|
isChecked = !!updateCheckboxFlag && !!selectCheckboxMaps[rowid];
|
|
if (checkMethod && isRowGroupStatus && $table.isAggregateRecord(row)) {
|
|
const childList = row[mapChildrenField || ""];
|
|
if (!childList || !childList.length || childList.every((item) => !checkMethod({ $table, row: item }))) {
|
|
isDisabled = true;
|
|
}
|
|
} else {
|
|
isVisible = !visibleMethod || visibleMethod({ $table, row });
|
|
isDisabled = checkMethod ? !checkMethod({ $table, row }) : !!checkMethod;
|
|
}
|
|
if (treeConfig || isRowGroupStatus) {
|
|
indeterminate = !!treeIndeterminateRowMaps[rowid];
|
|
}
|
|
ons.onClick = (evnt) => {
|
|
if (!isDisabled && isVisible) {
|
|
$table.triggerCheckRowEvent(evnt, params, !isChecked);
|
|
}
|
|
};
|
|
}
|
|
const checkboxParams = Object.assign(Object.assign({}, params), { checked: isChecked, disabled: isDisabled, visible: isVisible, indeterminate });
|
|
if (checkboxSlot) {
|
|
return renderCellBaseVNs(params, $table.callSlot(checkboxSlot, checkboxParams));
|
|
}
|
|
const checkVNs = [];
|
|
if (isVisible) {
|
|
checkVNs.push(h("span", {
|
|
class: ["vxe-checkbox--icon", indeterminate ? getIcon().TABLE_CHECKBOX_INDETERMINATE : isChecked ? getIcon().TABLE_CHECKBOX_CHECKED : isDisabled ? getIcon().TABLE_CHECKBOX_DISABLED_UNCHECKED : getIcon().TABLE_CHECKBOX_UNCHECKED]
|
|
}));
|
|
}
|
|
if (defaultSlot || labelField) {
|
|
checkVNs.push(h("span", {
|
|
class: "vxe-checkbox--label"
|
|
}, defaultSlot ? $table.callSlot(defaultSlot, checkboxParams) : import_xe_utils4.default.get(row, labelField)));
|
|
}
|
|
return renderCellBaseVNs(params, [
|
|
h("span", Object.assign({ class: ["vxe-cell--checkbox", {
|
|
"is--checked": isChecked,
|
|
"is--disabled": isDisabled,
|
|
"is--indeterminate": indeterminate,
|
|
"is--hidden": !isVisible
|
|
}] }, ons), checkVNs)
|
|
]);
|
|
},
|
|
renderDeepSelectionCell(params) {
|
|
return Cell.renderDeepNodeBtn(params, Cell.renderCheckboxCell(params));
|
|
},
|
|
renderCheckboxCellByProp(params) {
|
|
const { $table, row, column, isHidden } = params;
|
|
const tableProps = $table.props;
|
|
const tableReactData = $table.reactData;
|
|
const tableInternalData = $table.internalData;
|
|
const { treeConfig } = tableProps;
|
|
const { updateCheckboxFlag, isRowGroupStatus } = tableReactData;
|
|
const { treeIndeterminateRowMaps } = tableInternalData;
|
|
const { computeCheckboxOpts, computeAggregateOpts } = $table.getComputeMaps();
|
|
const aggregateOpts = computeAggregateOpts.value;
|
|
const { mapChildrenField } = aggregateOpts;
|
|
const checkboxOpts = computeCheckboxOpts.value;
|
|
const { labelField, checkField, checkMethod, visibleMethod } = checkboxOpts;
|
|
const indeterminateField = checkboxOpts.indeterminateField || checkboxOpts.halfField;
|
|
const { slots } = column;
|
|
const defaultSlot = slots ? slots.default : null;
|
|
const checkboxSlot = slots ? slots.checkbox : null;
|
|
let indeterminate = false;
|
|
let isChecked = false;
|
|
let isVisible = true;
|
|
let isDisabled = false;
|
|
const ons = {};
|
|
if (!isHidden) {
|
|
const rowid = getRowid($table, row);
|
|
isChecked = !!updateCheckboxFlag && import_xe_utils4.default.get(row, checkField);
|
|
if (checkMethod && isRowGroupStatus && $table.isAggregateRecord(row)) {
|
|
const childList = row[mapChildrenField || ""];
|
|
if (!childList || !childList.length || childList.every((item) => !checkMethod({ $table, row: item }))) {
|
|
isDisabled = true;
|
|
}
|
|
} else {
|
|
isVisible = !visibleMethod || visibleMethod({ $table, row });
|
|
isDisabled = checkMethod ? !checkMethod({ $table, row }) : !!checkMethod;
|
|
}
|
|
if (treeConfig || isRowGroupStatus) {
|
|
indeterminate = !!treeIndeterminateRowMaps[rowid];
|
|
}
|
|
ons.onClick = (evnt) => {
|
|
if (!isDisabled && isVisible) {
|
|
$table.triggerCheckRowEvent(evnt, params, !isChecked);
|
|
}
|
|
};
|
|
}
|
|
const checkboxParams = Object.assign(Object.assign({}, params), { checked: isChecked, disabled: isDisabled, visible: isVisible, indeterminate });
|
|
if (checkboxSlot) {
|
|
return renderCellBaseVNs(params, $table.callSlot(checkboxSlot, checkboxParams));
|
|
}
|
|
const checkVNs = [];
|
|
if (isVisible) {
|
|
checkVNs.push(h("span", {
|
|
class: ["vxe-checkbox--icon", indeterminate ? getIcon().TABLE_CHECKBOX_INDETERMINATE : isChecked ? getIcon().TABLE_CHECKBOX_CHECKED : isDisabled ? getIcon().TABLE_CHECKBOX_DISABLED_UNCHECKED : getIcon().TABLE_CHECKBOX_UNCHECKED]
|
|
}));
|
|
if (defaultSlot || labelField) {
|
|
checkVNs.push(h("span", {
|
|
class: "vxe-checkbox--label"
|
|
}, defaultSlot ? $table.callSlot(defaultSlot, checkboxParams) : import_xe_utils4.default.get(row, labelField)));
|
|
}
|
|
}
|
|
return renderCellBaseVNs(params, [
|
|
h("span", Object.assign({ class: ["vxe-cell--checkbox", {
|
|
"is--checked": isChecked,
|
|
"is--disabled": isDisabled,
|
|
"is--indeterminate": indeterminateField && !isChecked ? row[indeterminateField] : indeterminate,
|
|
"is--hidden": !isVisible
|
|
}] }, ons), checkVNs)
|
|
]);
|
|
},
|
|
renderDeepSelectionCellByProp(params) {
|
|
return Cell.renderDeepNodeBtn(params, Cell.renderCheckboxCellByProp(params));
|
|
},
|
|
/**
|
|
* 展开行
|
|
*/
|
|
renderExpandCell(params) {
|
|
const { $table, isHidden, row, column } = params;
|
|
const tableReactData = $table.reactData;
|
|
const tableInternalData = $table.internalData;
|
|
const { isRowGroupStatus } = tableReactData;
|
|
const { rowExpandedMaps, rowExpandLazyLoadedMaps } = tableInternalData;
|
|
const { computeExpandOpts } = $table.getComputeMaps();
|
|
const expandOpts = computeExpandOpts.value;
|
|
const { lazy, labelField, iconLoaded, showIcon, iconOpen, iconClose, visibleMethod } = expandOpts;
|
|
const { slots } = column;
|
|
const defaultSlot = slots ? slots.default : null;
|
|
const iconSlot = slots ? slots.icon : null;
|
|
let isActive = false;
|
|
let isLazyLoading = false;
|
|
if (isRowGroupStatus && row.isAggregate) {
|
|
return renderCellBaseVNs(params, []);
|
|
}
|
|
if (iconSlot) {
|
|
return renderCellBaseVNs(params, $table.callSlot(iconSlot, params));
|
|
}
|
|
if (!isHidden) {
|
|
const rowid = getRowid($table, row);
|
|
isActive = !!rowExpandedMaps[rowid];
|
|
if (lazy) {
|
|
isLazyLoading = !!rowExpandLazyLoadedMaps[rowid];
|
|
}
|
|
}
|
|
return renderCellBaseVNs(params, [
|
|
showIcon && (!visibleMethod || visibleMethod(params)) ? h("span", {
|
|
class: ["vxe-table--expanded", {
|
|
"is--active": isActive
|
|
}],
|
|
onMousedown(evnt) {
|
|
evnt.stopPropagation();
|
|
},
|
|
onClick(evnt) {
|
|
$table.triggerRowExpandEvent(evnt, params);
|
|
}
|
|
}, [
|
|
h("i", {
|
|
class: ["vxe-table--expand-btn", isLazyLoading ? iconLoaded || getIcon().TABLE_EXPAND_LOADED : isActive ? iconOpen || getIcon().TABLE_EXPAND_OPEN : iconClose || getIcon().TABLE_EXPAND_CLOSE]
|
|
})
|
|
]) : renderEmptyElement($table),
|
|
defaultSlot || labelField ? h("span", {
|
|
class: "vxe-table--expand-label"
|
|
}, defaultSlot ? $table.callSlot(defaultSlot, params) : import_xe_utils4.default.get(row, labelField)) : renderEmptyElement($table)
|
|
]);
|
|
},
|
|
renderExpandData(params) {
|
|
const { $table, column } = params;
|
|
const { slots, contentRender } = column;
|
|
const contentSlot = slots ? slots.content : null;
|
|
if (contentSlot) {
|
|
return $table.callSlot(contentSlot, params);
|
|
}
|
|
if (contentRender) {
|
|
const compConf = renderer2.get(contentRender.name);
|
|
if (compConf) {
|
|
const rtExpand = compConf.renderTableExpand || compConf.renderExpand;
|
|
if (rtExpand) {
|
|
return getSlotVNs(rtExpand(contentRender, params));
|
|
}
|
|
}
|
|
}
|
|
return [];
|
|
},
|
|
/**
|
|
* HTML 标签
|
|
*/
|
|
renderHTMLCell(params) {
|
|
const { $table, column } = params;
|
|
const { slots } = column;
|
|
const defaultSlot = slots ? slots.default : null;
|
|
if (defaultSlot) {
|
|
return renderCellBaseVNs(params, $table.callSlot(defaultSlot, params));
|
|
}
|
|
return renderCellBaseVNs(params, [
|
|
h("span", {
|
|
class: "vxe-cell--html",
|
|
innerHTML: getDefaultCellLabel(params)
|
|
})
|
|
]);
|
|
},
|
|
renderDeepHTMLCell(params) {
|
|
return Cell.renderDeepNodeBtn(params, Cell.renderHTMLCell(params));
|
|
},
|
|
/**
|
|
* 排序和筛选
|
|
*/
|
|
renderSortAndFilterHeader(params) {
|
|
return renderHeaderCellBaseVNs(params, Cell.renderHeaderTitle(params).concat(Cell.renderSortIcon(params).concat(Cell.renderFilterIcon(params))));
|
|
},
|
|
/**
|
|
* 排序
|
|
*/
|
|
renderSortHeader(params) {
|
|
return renderHeaderCellBaseVNs(params, Cell.renderHeaderTitle(params).concat(Cell.renderSortIcon(params)));
|
|
},
|
|
renderSortIcon(params) {
|
|
const { $table, column } = params;
|
|
const { computeSortOpts } = $table.getComputeMaps();
|
|
const sortOpts = computeSortOpts.value;
|
|
const { showIcon, allowBtn, ascTitle, descTitle, iconLayout, iconAsc, iconDesc, iconVisibleMethod } = sortOpts;
|
|
const { order, slots } = column;
|
|
if (showIcon && (!iconVisibleMethod || iconVisibleMethod(params))) {
|
|
const sortSlot = slots ? slots.sort : null;
|
|
return sortSlot ? getSlotVNs($table.callSlot(sortSlot, params)) : [
|
|
h("span", {
|
|
class: ["vxe-cell--sort", `vxe-cell--sort-${iconLayout}-layout`]
|
|
}, [
|
|
h("i", {
|
|
class: ["vxe-sort--asc-btn", iconAsc || getIcon().TABLE_SORT_ASC, {
|
|
"sort--active": order === "asc"
|
|
}],
|
|
title: import_xe_utils4.default.eqNull(ascTitle) ? getI18n2("vxe.table.sortAsc") : `${ascTitle || ""}`,
|
|
onClick: allowBtn ? (evnt) => {
|
|
evnt.stopPropagation();
|
|
$table.triggerSortEvent(evnt, column, "asc");
|
|
} : void 0
|
|
}),
|
|
h("i", {
|
|
class: ["vxe-sort--desc-btn", iconDesc || getIcon().TABLE_SORT_DESC, {
|
|
"sort--active": order === "desc"
|
|
}],
|
|
title: import_xe_utils4.default.eqNull(descTitle) ? getI18n2("vxe.table.sortDesc") : `${descTitle || ""}`,
|
|
onClick: allowBtn ? (evnt) => {
|
|
evnt.stopPropagation();
|
|
$table.triggerSortEvent(evnt, column, "desc");
|
|
} : void 0
|
|
})
|
|
])
|
|
];
|
|
}
|
|
return [];
|
|
},
|
|
/**
|
|
* 筛选
|
|
*/
|
|
renderFilterHeader(params) {
|
|
return renderHeaderCellBaseVNs(params, Cell.renderHeaderTitle(params).concat(Cell.renderFilterIcon(params)));
|
|
},
|
|
renderFilterIcon(params) {
|
|
const { $table, column, hasFilter } = params;
|
|
const tableReactData = $table.reactData;
|
|
const { filterStore } = tableReactData;
|
|
const { computeFilterOpts } = $table.getComputeMaps();
|
|
const filterOpts = computeFilterOpts.value;
|
|
const { showIcon, iconNone, iconMatch, iconVisibleMethod } = filterOpts;
|
|
if (showIcon && (!iconVisibleMethod || iconVisibleMethod(params))) {
|
|
return [
|
|
h("span", {
|
|
class: ["vxe-cell--filter", {
|
|
"is--active": filterStore.visible && filterStore.column === column
|
|
}],
|
|
onClick(evnt) {
|
|
if ($table.triggerFilterEvent) {
|
|
$table.triggerFilterEvent(evnt, params.column, params);
|
|
}
|
|
}
|
|
}, [
|
|
h("i", {
|
|
class: ["vxe-filter--btn", hasFilter ? iconMatch || getIcon().TABLE_FILTER_MATCH : iconNone || getIcon().TABLE_FILTER_NONE],
|
|
title: getI18n2("vxe.table.filter")
|
|
})
|
|
])
|
|
];
|
|
}
|
|
return [];
|
|
},
|
|
/**
|
|
* 可编辑
|
|
*/
|
|
renderEditHeader(params) {
|
|
const { $table, column } = params;
|
|
const tableProps = $table.props;
|
|
const { computeEditOpts } = $table.getComputeMaps();
|
|
const { editConfig, editRules } = tableProps;
|
|
const editOpts = computeEditOpts.value;
|
|
const { sortable, filters, editRender } = column;
|
|
let isRequired = false;
|
|
if (editRules) {
|
|
const columnRules = import_xe_utils4.default.get(editRules, column.field);
|
|
if (columnRules) {
|
|
isRequired = columnRules.some((rule) => rule.required);
|
|
}
|
|
}
|
|
let editIconVNs = [];
|
|
if (isEnableConf(editConfig)) {
|
|
const { showAsterisk, showIcon, icon } = editOpts;
|
|
editIconVNs = [
|
|
isRequired && showAsterisk ? h("span", {
|
|
class: "vxe-cell--required-icon"
|
|
}, [
|
|
h("i")
|
|
]) : renderEmptyElement($table),
|
|
isEnableConf(editRender) && showIcon ? h("span", {
|
|
class: "vxe-cell--edit-icon"
|
|
}, import_xe_utils4.default.isFunction(icon) ? getSlotVNs(icon({})) : [
|
|
h("i", {
|
|
class: icon || getIcon().TABLE_EDIT
|
|
})
|
|
]) : renderEmptyElement($table)
|
|
];
|
|
}
|
|
return renderHeaderCellBaseVNs(params, editIconVNs.concat(Cell.renderHeaderTitle(params)).concat(sortable ? Cell.renderSortIcon(params) : []).concat(filters ? Cell.renderFilterIcon(params) : []));
|
|
},
|
|
// 行格编辑模式
|
|
renderRowEdit(params) {
|
|
const { $table, column } = params;
|
|
const tableReactData = $table.reactData;
|
|
const { editStore } = tableReactData;
|
|
const { actived } = editStore;
|
|
const { editRender } = column;
|
|
return Cell.runRenderer(params, isEnableConf(editRender) && actived && actived.row === params.row);
|
|
},
|
|
renderDeepRowEdit(params) {
|
|
return Cell.renderDeepNodeBtn(params, Cell.renderRowEdit(params));
|
|
},
|
|
// 单元格编辑模式
|
|
renderCellEdit(params) {
|
|
const { $table, column } = params;
|
|
const tableReactData = $table.reactData;
|
|
const { editStore } = tableReactData;
|
|
const { actived } = editStore;
|
|
const { editRender } = column;
|
|
return Cell.runRenderer(params, isEnableConf(editRender) && actived && actived.row === params.row && actived.column === params.column);
|
|
},
|
|
renderDeepCellEdit(params) {
|
|
return Cell.renderDeepNodeBtn(params, Cell.renderCellEdit(params));
|
|
},
|
|
runRenderer(params, isEdit) {
|
|
const { $table, row, column } = params;
|
|
const tableReactData = $table.reactData;
|
|
const { isRowGroupStatus } = tableReactData;
|
|
const { slots, field, editRender, formatter } = column;
|
|
const defaultSlot = slots ? slots.default : null;
|
|
const gcSlot = slots ? slots.groupContent || slots["group-content"] : null;
|
|
const editSlot = slots ? slots.edit : null;
|
|
const compConf = renderer2.get(editRender.name);
|
|
const rtEdit = compConf ? compConf.renderTableEdit || compConf.renderEdit : null;
|
|
const cellParams = Object.assign({ $type: "", isEdit }, params);
|
|
if (isEdit) {
|
|
cellParams.$type = "edit";
|
|
if (editSlot) {
|
|
return $table.callSlot(editSlot, cellParams);
|
|
}
|
|
if (rtEdit) {
|
|
return getSlotVNs(rtEdit(editRender, cellParams));
|
|
}
|
|
return [];
|
|
}
|
|
if (isRowGroupStatus && field && row.isAggregate) {
|
|
const aggRow = row;
|
|
const { computeAggregateOpts } = $table.getComputeMaps();
|
|
const aggregateOpts = computeAggregateOpts.value;
|
|
const { mapChildrenField } = aggregateOpts;
|
|
const groupField = aggRow.groupField;
|
|
const groupContent = aggRow.groupContent;
|
|
const childList = mapChildrenField ? aggRow[mapChildrenField] || [] : [];
|
|
const childCount = aggRow.childCount;
|
|
if (gcSlot) {
|
|
return renderCellBaseVNs(params, $table.callSlot(gcSlot, Object.assign({ groupField, groupContent, childList, childCount }, params)));
|
|
}
|
|
} else {
|
|
if (defaultSlot) {
|
|
return renderCellBaseVNs(params, $table.callSlot(defaultSlot, cellParams));
|
|
}
|
|
}
|
|
if (formatter) {
|
|
return renderCellBaseVNs(params, [
|
|
h("span", {
|
|
class: "vxe-cell--label"
|
|
}, getDefaultCellLabel(cellParams))
|
|
]);
|
|
}
|
|
return Cell.renderDefaultCell(cellParams);
|
|
}
|
|
};
|
|
var cell_default = Cell;
|
|
|
|
export {
|
|
initTpImg,
|
|
getTpImg,
|
|
getPropClass,
|
|
isPx,
|
|
isScale,
|
|
hasClass,
|
|
removeClass,
|
|
addClass,
|
|
hasControlKey,
|
|
toCssUnit,
|
|
getDomNode,
|
|
getOffsetHeight,
|
|
getPaddingTopBottomSize,
|
|
setScrollTop,
|
|
setScrollLeft,
|
|
updateCellTitle,
|
|
checkTargetElement,
|
|
getEventTargetNode,
|
|
getAbsolutePos,
|
|
scrollToView,
|
|
triggerEvent,
|
|
createInternalData,
|
|
convertHeaderColumnToRows,
|
|
convertHeaderToGridRows,
|
|
restoreScrollLocation,
|
|
getRowUniqueId,
|
|
hasDeepKey,
|
|
getRowkey,
|
|
getRowid,
|
|
createHandleUpdateRowId,
|
|
createHandleGetRowId,
|
|
handleFieldOrColumn,
|
|
handleRowidOrRow,
|
|
getCellRestHeight,
|
|
toFilters,
|
|
toTreePathSeq,
|
|
getCellValue,
|
|
setCellValue,
|
|
getRefElem,
|
|
getCalcHeight,
|
|
getColReMinWidth,
|
|
isColumnInfo,
|
|
getColumnList,
|
|
watchColumn,
|
|
assembleColumn,
|
|
destroyColumn,
|
|
getRootColumn,
|
|
getLastChildColumn,
|
|
clearTableAllStatus,
|
|
rowToVisible,
|
|
colToVisible,
|
|
cell_default
|
|
};
|
|
//# sourceMappingURL=chunk-W4BZ55WN.js.map
|