vxe-table 4.10.6-beta.25 → 4.10.6-beta.27
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/index.css +1 -1
- package/es/index.min.css +1 -1
- package/es/locale/lang/en-US.js +2 -2
- package/es/style.css +1 -1
- package/es/style.min.css +1 -1
- package/es/table/src/body.js +21 -19
- package/es/table/src/cell.js +25 -39
- package/es/table/src/column.js +10 -0
- package/es/table/src/columnInfo.js +2 -0
- package/es/table/src/footer.js +2 -1
- package/es/table/src/header.js +2 -2
- package/es/table/src/table.js +111 -81
- package/es/table/src/util.js +9 -3
- package/es/table/style.css +51 -26
- package/es/table/style.min.css +1 -1
- package/es/ui/index.js +1 -1
- package/es/ui/src/log.js +1 -1
- package/es/vxe-table/style.css +51 -26
- package/es/vxe-table/style.min.css +1 -1
- package/lib/index.css +1 -1
- package/lib/index.min.css +1 -1
- package/lib/index.umd.js +189 -150
- package/lib/index.umd.min.js +1 -1
- package/lib/locale/lang/en-US.js +2 -2
- package/lib/locale/lang/en-US.min.js +1 -1
- package/lib/locale/lang/en-US.umd.js +2 -2
- package/lib/style.css +1 -1
- package/lib/style.min.css +1 -1
- package/lib/table/src/body.js +17 -18
- package/lib/table/src/body.min.js +1 -1
- package/lib/table/src/cell.js +24 -33
- package/lib/table/src/cell.min.js +1 -1
- package/lib/table/src/column.js +10 -0
- package/lib/table/src/column.min.js +1 -1
- package/lib/table/src/columnInfo.js +2 -0
- package/lib/table/src/columnInfo.min.js +1 -1
- package/lib/table/src/footer.js +2 -1
- package/lib/table/src/footer.min.js +1 -1
- package/lib/table/src/header.js +1 -1
- package/lib/table/src/header.min.js +1 -1
- package/lib/table/src/table.js +122 -92
- package/lib/table/src/table.min.js +1 -1
- package/lib/table/src/util.js +10 -3
- package/lib/table/src/util.min.js +1 -1
- package/lib/table/style/style.css +51 -26
- package/lib/table/style/style.min.css +1 -1
- package/lib/ui/index.js +1 -1
- package/lib/ui/index.min.js +1 -1
- package/lib/ui/src/log.js +1 -1
- package/lib/ui/src/log.min.js +1 -1
- package/lib/vxe-table/style/style.css +51 -26
- package/lib/vxe-table/style/style.min.css +1 -1
- package/package.json +2 -2
- package/packages/locale/lang/en-US.ts +2 -2
- package/packages/table/src/body.ts +21 -19
- package/packages/table/src/cell.ts +25 -47
- package/packages/table/src/column.ts +10 -0
- package/packages/table/src/columnInfo.ts +2 -0
- package/packages/table/src/footer.ts +2 -1
- package/packages/table/src/header.ts +2 -2
- package/packages/table/src/table.ts +116 -83
- package/packages/table/src/util.ts +10 -3
- package/styles/components/table.scss +63 -31
- /package/es/{iconfont.1737356819937.ttf → iconfont.1737446773545.ttf} +0 -0
- /package/es/{iconfont.1737356819937.woff → iconfont.1737446773545.woff} +0 -0
- /package/es/{iconfont.1737356819937.woff2 → iconfont.1737446773545.woff2} +0 -0
- /package/lib/{iconfont.1737356819937.ttf → iconfont.1737446773545.ttf} +0 -0
- /package/lib/{iconfont.1737356819937.woff → iconfont.1737446773545.woff} +0 -0
- /package/lib/{iconfont.1737356819937.woff2 → iconfont.1737446773545.woff2} +0 -0
package/lib/table/src/table.js
CHANGED
|
@@ -940,14 +940,14 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
940
940
|
};
|
|
941
941
|
const computeRowHeight = () => {
|
|
942
942
|
const {
|
|
943
|
-
|
|
944
|
-
} =
|
|
943
|
+
isAllOverflow
|
|
944
|
+
} = reactData;
|
|
945
945
|
const tableHeader = refTableHeader.value;
|
|
946
946
|
const tableBody = refTableBody.value;
|
|
947
947
|
const tableBodyElem = tableBody ? tableBody.$el : null;
|
|
948
948
|
const defaultRowHeight = computeDefaultRowHeight.value;
|
|
949
949
|
let rowHeight = 0;
|
|
950
|
-
if (
|
|
950
|
+
if (isAllOverflow) {
|
|
951
951
|
if (tableBodyElem) {
|
|
952
952
|
const tableHeaderElem = tableHeader ? tableHeader.$el : null;
|
|
953
953
|
let firstTrElem;
|
|
@@ -970,8 +970,8 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
970
970
|
};
|
|
971
971
|
const handleVirtualYVisible = currScrollTop => {
|
|
972
972
|
const {
|
|
973
|
-
|
|
974
|
-
} =
|
|
973
|
+
isAllOverflow
|
|
974
|
+
} = reactData;
|
|
975
975
|
const {
|
|
976
976
|
elemStore,
|
|
977
977
|
isResizeCellHeight,
|
|
@@ -990,15 +990,15 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
990
990
|
let offsetTop = 0;
|
|
991
991
|
let visibleSize = 0;
|
|
992
992
|
const isCustomCellHeight = isResizeCellHeight || cellOpts.height || rowOpts.height;
|
|
993
|
-
if (!isCustomCellHeight &&
|
|
993
|
+
if (!isCustomCellHeight && isAllOverflow) {
|
|
994
994
|
toVisibleIndex = Math.floor(scrollTop / defaultRowHeight);
|
|
995
995
|
visibleSize = Math.ceil(clientHeight / defaultRowHeight) + 1;
|
|
996
996
|
} else {
|
|
997
997
|
for (let rIndex = 0, rLen = afterFullData.length; rIndex < rLen; rIndex++) {
|
|
998
998
|
const row = afterFullData[rIndex];
|
|
999
999
|
const rowid = (0, _util.getRowid)($xeTable, row);
|
|
1000
|
-
const rowRest = fullAllDataRowIdData[rowid];
|
|
1001
|
-
offsetTop += rowRest
|
|
1000
|
+
const rowRest = fullAllDataRowIdData[rowid] || {};
|
|
1001
|
+
offsetTop += rowRest.resizeHeight || rowRest.height || cellOpts.height || rowOpts.height || defaultRowHeight;
|
|
1002
1002
|
if (toVisibleIndex === -1 && scrollTop < offsetTop) {
|
|
1003
1003
|
toVisibleIndex = rIndex;
|
|
1004
1004
|
}
|
|
@@ -1571,26 +1571,20 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
1571
1571
|
};
|
|
1572
1572
|
const calcCellAutoHeight = (rowRest, wrapperEl) => {
|
|
1573
1573
|
const cellElemList = wrapperEl.querySelectorAll(`.vxe-cell--wrapper[rowid="${rowRest.rowid}"]`);
|
|
1574
|
-
let
|
|
1575
|
-
const firstCellEl = cellElemList[0];
|
|
1576
|
-
if (firstCellEl && firstCellEl.parentElement) {
|
|
1577
|
-
const cellStyle = getComputedStyle(firstCellEl.parentElement);
|
|
1578
|
-
topBottomPadding = Math.ceil(_xeUtils.default.toNumber(cellStyle.paddingTop) + _xeUtils.default.toNumber(cellStyle.paddingBottom));
|
|
1579
|
-
}
|
|
1580
|
-
let colHeight = rowRest.height - topBottomPadding;
|
|
1574
|
+
let colHeight = rowRest.height;
|
|
1581
1575
|
for (let i = 0; i < cellElemList.length; i++) {
|
|
1582
1576
|
const cellElem = cellElemList[i];
|
|
1577
|
+
const tdEl = cellElem.parentElement;
|
|
1578
|
+
const topBottomPadding = Math.ceil(_xeUtils.default.toNumber(tdEl.style.paddingTop) + _xeUtils.default.toNumber(tdEl.style.paddingBottom));
|
|
1583
1579
|
const cellHeight = cellElem ? cellElem.clientHeight : 0;
|
|
1584
|
-
colHeight = Math.max(colHeight, Math.ceil(cellHeight));
|
|
1580
|
+
colHeight = Math.max(colHeight - topBottomPadding, Math.ceil(cellHeight));
|
|
1585
1581
|
}
|
|
1586
|
-
return colHeight
|
|
1582
|
+
return colHeight;
|
|
1587
1583
|
};
|
|
1588
1584
|
const calcCellHeight = () => {
|
|
1589
|
-
const {
|
|
1590
|
-
showOverflow
|
|
1591
|
-
} = props;
|
|
1592
1585
|
const {
|
|
1593
1586
|
tableData,
|
|
1587
|
+
isAllOverflow,
|
|
1594
1588
|
scrollYLoad,
|
|
1595
1589
|
scrollXLoad
|
|
1596
1590
|
} = reactData;
|
|
@@ -1599,14 +1593,16 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
1599
1593
|
} = internalData;
|
|
1600
1594
|
const defaultRowHeight = computeDefaultRowHeight.value;
|
|
1601
1595
|
const el = refElem.value;
|
|
1602
|
-
if (!
|
|
1596
|
+
if (!isAllOverflow && scrollYLoad && el) {
|
|
1597
|
+
el.setAttribute('data-calc-row', 'Y');
|
|
1603
1598
|
tableData.forEach(row => {
|
|
1604
1599
|
const rowid = (0, _util.getRowid)($xeTable, row);
|
|
1605
1600
|
const rowRest = fullAllDataRowIdData[rowid];
|
|
1606
1601
|
if (rowRest) {
|
|
1607
|
-
const
|
|
1608
|
-
rowRest.height = Math.max(defaultRowHeight, scrollXLoad ? Math.max(rowRest.height,
|
|
1602
|
+
const reHeight = calcCellAutoHeight(rowRest, el);
|
|
1603
|
+
rowRest.height = Math.max(defaultRowHeight, scrollXLoad ? Math.max(rowRest.height, reHeight) : reHeight);
|
|
1609
1604
|
}
|
|
1605
|
+
el.removeAttribute('data-calc-row');
|
|
1610
1606
|
});
|
|
1611
1607
|
reactData.calcCellHeightFlag++;
|
|
1612
1608
|
}
|
|
@@ -1983,7 +1979,6 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
1983
1979
|
const updateStyle = () => {
|
|
1984
1980
|
const {
|
|
1985
1981
|
border,
|
|
1986
|
-
showOverflow: allColumnOverflow,
|
|
1987
1982
|
showHeaderOverflow: allColumnHeaderOverflow,
|
|
1988
1983
|
showFooterOverflow: allColumnFooterOverflow,
|
|
1989
1984
|
mouseConfig,
|
|
@@ -2204,7 +2199,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
2204
2199
|
let renderColumnList = tableColumn;
|
|
2205
2200
|
let isOptimizeMode = false;
|
|
2206
2201
|
// 如果是使用优化模式
|
|
2207
|
-
if (scrollXLoad || scrollYLoad ||
|
|
2202
|
+
if (scrollXLoad || scrollYLoad || isAllOverflow) {
|
|
2208
2203
|
if (expandColumn || spanMethod || footerSpanMethod) {
|
|
2209
2204
|
// 如果不支持优化模式
|
|
2210
2205
|
} else {
|
|
@@ -2288,7 +2283,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
2288
2283
|
} else if (layout === 'footer') {
|
|
2289
2284
|
cellOverflow = _xeUtils.default.isUndefined(showFooterOverflow) || _xeUtils.default.isNull(showFooterOverflow) ? allColumnFooterOverflow : showFooterOverflow;
|
|
2290
2285
|
} else {
|
|
2291
|
-
cellOverflow = _xeUtils.default.isUndefined(showOverflow) || _xeUtils.default.isNull(showOverflow) ?
|
|
2286
|
+
cellOverflow = _xeUtils.default.isUndefined(showOverflow) || _xeUtils.default.isNull(showOverflow) ? isAllOverflow : showOverflow;
|
|
2292
2287
|
}
|
|
2293
2288
|
const showEllipsis = cellOverflow === 'ellipsis';
|
|
2294
2289
|
const showTitle = cellOverflow === 'title';
|
|
@@ -2985,8 +2980,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
2985
2980
|
const loadTableData = (datas, isReset) => {
|
|
2986
2981
|
const {
|
|
2987
2982
|
keepSource,
|
|
2988
|
-
treeConfig
|
|
2989
|
-
showOverflow
|
|
2983
|
+
treeConfig
|
|
2990
2984
|
} = props;
|
|
2991
2985
|
const {
|
|
2992
2986
|
editStore,
|
|
@@ -2999,7 +2993,6 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
2999
2993
|
lastScrollTop
|
|
3000
2994
|
} = internalData;
|
|
3001
2995
|
const treeOpts = computeTreeOpts.value;
|
|
3002
|
-
const rowOpts = computeRowOpts.value;
|
|
3003
2996
|
const {
|
|
3004
2997
|
transform
|
|
3005
2998
|
} = treeOpts;
|
|
@@ -3060,32 +3053,15 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
3060
3053
|
internalData.tableSynchData = datas;
|
|
3061
3054
|
if (isReset) {
|
|
3062
3055
|
internalData.isResizeCellHeight = false;
|
|
3056
|
+
reactData.rowExpandedMaps = {};
|
|
3057
|
+
reactData.rowExpandLazyLoadedMaps = {};
|
|
3058
|
+
reactData.treeExpandedMaps = {};
|
|
3059
|
+
reactData.treeExpandLazyLoadedMaps = {};
|
|
3063
3060
|
}
|
|
3064
3061
|
// 克隆原数据,用于显示编辑状态,与编辑值做对比
|
|
3065
3062
|
if (keepSource) {
|
|
3066
3063
|
tablePrivateMethods.cacheSourceMap(fullData);
|
|
3067
3064
|
}
|
|
3068
|
-
if (sYLoad) {
|
|
3069
|
-
if (showOverflow) {
|
|
3070
|
-
if (!rowOpts.height) {
|
|
3071
|
-
const errColumn = internalData.tableFullColumn.find(column => column.showOverflow === false);
|
|
3072
|
-
if (errColumn) {
|
|
3073
|
-
(0, _log.errLog)('vxe.error.errProp', [`column[field="${errColumn.field}"].show-overflow=false`, 'show-overflow=true']);
|
|
3074
|
-
}
|
|
3075
|
-
}
|
|
3076
|
-
}
|
|
3077
|
-
if (process.env.NODE_ENV === 'development') {
|
|
3078
|
-
if (!(props.height || props.maxHeight)) {
|
|
3079
|
-
(0, _log.errLog)('vxe.error.reqProp', ['table.height | table.max-height | table.scroll-y={enabled: false}']);
|
|
3080
|
-
}
|
|
3081
|
-
// if (!props.showOverflow) {
|
|
3082
|
-
// warnLog('vxe.error.reqProp', ['table.show-overflow'])
|
|
3083
|
-
// }
|
|
3084
|
-
if (props.spanMethod) {
|
|
3085
|
-
(0, _log.warnLog)('vxe.error.scrollErrProp', ['table.span-method']);
|
|
3086
|
-
}
|
|
3087
|
-
}
|
|
3088
|
-
}
|
|
3089
3065
|
if ($xeTable.clearCellAreas && props.mouseConfig) {
|
|
3090
3066
|
$xeTable.clearCellAreas();
|
|
3091
3067
|
$xeTable.clearCopyCellArea();
|
|
@@ -3104,6 +3080,27 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
3104
3080
|
if (sYLoad) {
|
|
3105
3081
|
scrollYStore.endIndex = scrollYStore.visibleSize;
|
|
3106
3082
|
}
|
|
3083
|
+
if (sYLoad) {
|
|
3084
|
+
// if (showOverflow) {
|
|
3085
|
+
// if (!rowOpts.height) {
|
|
3086
|
+
// const errColumn = internalData.tableFullColumn.find(column => column.showOverflow === false)
|
|
3087
|
+
// if (errColumn) {
|
|
3088
|
+
// errLog('vxe.error.errProp', [`column[field="${errColumn.field}"].show-overflow=false`, 'show-overflow=true'])
|
|
3089
|
+
// }
|
|
3090
|
+
// }
|
|
3091
|
+
// }
|
|
3092
|
+
if (process.env.NODE_ENV === 'development') {
|
|
3093
|
+
if (!(props.height || props.maxHeight)) {
|
|
3094
|
+
(0, _log.errLog)('vxe.error.reqProp', ['table.height | table.max-height | table.scroll-y={enabled: false}']);
|
|
3095
|
+
}
|
|
3096
|
+
// if (!props.showOverflow) {
|
|
3097
|
+
// warnLog('vxe.error.reqProp', ['table.show-overflow'])
|
|
3098
|
+
// }
|
|
3099
|
+
if (props.spanMethod) {
|
|
3100
|
+
(0, _log.warnLog)('vxe.error.scrollErrProp', ['table.span-method']);
|
|
3101
|
+
}
|
|
3102
|
+
}
|
|
3103
|
+
}
|
|
3107
3104
|
handleReserveStatus();
|
|
3108
3105
|
tablePrivateMethods.checkSelectionStatus();
|
|
3109
3106
|
return new Promise(resolve => {
|
|
@@ -3552,10 +3549,8 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
3552
3549
|
*/
|
|
3553
3550
|
const loadScrollYData = scrollTop => {
|
|
3554
3551
|
const {
|
|
3555
|
-
|
|
3556
|
-
|
|
3557
|
-
const {
|
|
3558
|
-
mergeList
|
|
3552
|
+
mergeList,
|
|
3553
|
+
isAllOverflow
|
|
3559
3554
|
} = reactData;
|
|
3560
3555
|
const {
|
|
3561
3556
|
scrollYStore
|
|
@@ -3566,7 +3561,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
3566
3561
|
endIndex,
|
|
3567
3562
|
offsetSize
|
|
3568
3563
|
} = scrollYStore;
|
|
3569
|
-
const autoOffsetYSize =
|
|
3564
|
+
const autoOffsetYSize = isAllOverflow ? offsetSize : offsetSize + 1;
|
|
3570
3565
|
const {
|
|
3571
3566
|
toVisibleIndex,
|
|
3572
3567
|
visibleSize
|
|
@@ -4819,7 +4814,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
4819
4814
|
if (rowRest) {
|
|
4820
4815
|
const resizeHeight = rowRest.resizeHeight;
|
|
4821
4816
|
if (resizeHeight || isFull) {
|
|
4822
|
-
const currCellHeight = resizeHeight || cellOpts.height || rowOpts.height || defaultRowHeight;
|
|
4817
|
+
const currCellHeight = resizeHeight || rowRest.height || cellOpts.height || rowOpts.height || defaultRowHeight;
|
|
4823
4818
|
rest[rowid] = currCellHeight;
|
|
4824
4819
|
}
|
|
4825
4820
|
}
|
|
@@ -4870,8 +4865,10 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
4870
4865
|
const defaultRowHeight = computeDefaultRowHeight.value;
|
|
4871
4866
|
const rowid = _xeUtils.default.isString(rowOrId) || _xeUtils.default.isNumber(rowOrId) ? rowOrId : (0, _util.getRowid)($xeTable, rowOrId);
|
|
4872
4867
|
const rowRest = fullAllDataRowIdData[rowid];
|
|
4873
|
-
|
|
4874
|
-
|
|
4868
|
+
if (rowRest) {
|
|
4869
|
+
return rowRest.resizeHeight || rowRest.height || cellOpts.height || rowOpts.height || defaultRowHeight;
|
|
4870
|
+
}
|
|
4871
|
+
return 0;
|
|
4875
4872
|
},
|
|
4876
4873
|
/**
|
|
4877
4874
|
* 刷新滚动操作,手动同步滚动相关位置(对于某些特殊的操作,比如滚动条错位、固定列不同步)
|
|
@@ -6136,9 +6133,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
6136
6133
|
*/
|
|
6137
6134
|
scrollToRow(row, fieldOrColumn) {
|
|
6138
6135
|
const {
|
|
6139
|
-
|
|
6140
|
-
} = props;
|
|
6141
|
-
const {
|
|
6136
|
+
isAllOverflow,
|
|
6142
6137
|
scrollYLoad,
|
|
6143
6138
|
scrollXLoad
|
|
6144
6139
|
} = reactData;
|
|
@@ -6155,7 +6150,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
6155
6150
|
}
|
|
6156
6151
|
return Promise.all(rest).then(() => {
|
|
6157
6152
|
if (row) {
|
|
6158
|
-
if (!
|
|
6153
|
+
if (!isAllOverflow && (scrollYLoad || scrollXLoad)) {
|
|
6159
6154
|
calcCellHeight();
|
|
6160
6155
|
calcCellWidth();
|
|
6161
6156
|
}
|
|
@@ -7765,6 +7760,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
7765
7760
|
resizeTipElem.style.left = `${resizeTipLeft}px`;
|
|
7766
7761
|
resizeTipElem.style.top = `${Math.min(tableHeight - resizeTipHeight, Math.max(0, evnt.clientY - wrapperRect.y - resizeTipHeight / 2))}px`;
|
|
7767
7762
|
}
|
|
7763
|
+
reactData.isDragResize = true;
|
|
7768
7764
|
};
|
|
7769
7765
|
reactData.isDragResize = true;
|
|
7770
7766
|
(0, _dom.addClass)(tableEl, 'col-drag--resize');
|
|
@@ -7774,8 +7770,10 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
7774
7770
|
document.onmousemove = null;
|
|
7775
7771
|
document.onmouseup = null;
|
|
7776
7772
|
resizeBarElem.style.display = 'none';
|
|
7777
|
-
reactData.isDragResize = false;
|
|
7778
7773
|
internalData._lastResizeTime = Date.now();
|
|
7774
|
+
setTimeout(() => {
|
|
7775
|
+
reactData.isDragResize = false;
|
|
7776
|
+
}, 50);
|
|
7779
7777
|
const resizeWidth = resizeColumn.renderWidth + (isRightFixed ? dragPosLeft - dragLeft : dragLeft - dragPosLeft);
|
|
7780
7778
|
const resizeParams = Object.assign(Object.assign({}, params), {
|
|
7781
7779
|
resizeWidth,
|
|
@@ -7810,6 +7808,8 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
7810
7808
|
} = resizableOpts;
|
|
7811
7809
|
const el = refElem.value;
|
|
7812
7810
|
if (isDblclickAutoWidth && el) {
|
|
7811
|
+
evnt.stopPropagation();
|
|
7812
|
+
evnt.preventDefault();
|
|
7813
7813
|
const {
|
|
7814
7814
|
fullColumnIdData
|
|
7815
7815
|
} = internalData;
|
|
@@ -7895,7 +7895,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
7895
7895
|
return;
|
|
7896
7896
|
}
|
|
7897
7897
|
const defaultRowHeight = computeDefaultRowHeight.value;
|
|
7898
|
-
const currCellHeight = rowRest.resizeHeight || cellOpts.height || rowOpts.height || defaultRowHeight;
|
|
7898
|
+
const currCellHeight = rowRest.resizeHeight || rowRest.height || cellOpts.height || rowOpts.height || defaultRowHeight;
|
|
7899
7899
|
const tableRect = tableEl.getBoundingClientRect();
|
|
7900
7900
|
const trRect = trEl.getBoundingClientRect();
|
|
7901
7901
|
const targetOffsetY = dragClientY - trRect.y - trEl.clientHeight;
|
|
@@ -7937,6 +7937,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
7937
7937
|
resizeTipElem.style.left = `${resizeBarLeft}px`;
|
|
7938
7938
|
resizeTipElem.style.top = `${resizeBarTop}px`;
|
|
7939
7939
|
}
|
|
7940
|
+
reactData.isDragResize = true;
|
|
7940
7941
|
};
|
|
7941
7942
|
reactData.isDragResize = true;
|
|
7942
7943
|
(0, _dom.addClass)(tableEl, 'row-drag--resize');
|
|
@@ -7946,8 +7947,10 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
7946
7947
|
document.onmousemove = null;
|
|
7947
7948
|
document.onmouseup = null;
|
|
7948
7949
|
resizeBarElem.style.display = 'none';
|
|
7949
|
-
reactData.isDragResize = false;
|
|
7950
7950
|
internalData._lastResizeTime = Date.now();
|
|
7951
|
+
setTimeout(() => {
|
|
7952
|
+
reactData.isDragResize = false;
|
|
7953
|
+
}, 50);
|
|
7951
7954
|
if (resizeHeight !== currCellHeight) {
|
|
7952
7955
|
const resizeParams = Object.assign(Object.assign({}, params), {
|
|
7953
7956
|
resizeHeight,
|
|
@@ -7972,9 +7975,17 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
7972
7975
|
} = resizableOpts;
|
|
7973
7976
|
const el = refElem.value;
|
|
7974
7977
|
if (isDblclickAutoHeight && el) {
|
|
7978
|
+
evnt.stopPropagation();
|
|
7979
|
+
evnt.preventDefault();
|
|
7980
|
+
const {
|
|
7981
|
+
editStore
|
|
7982
|
+
} = reactData;
|
|
7975
7983
|
const {
|
|
7976
7984
|
fullAllDataRowIdData
|
|
7977
7985
|
} = internalData;
|
|
7986
|
+
const {
|
|
7987
|
+
actived
|
|
7988
|
+
} = editStore;
|
|
7978
7989
|
const {
|
|
7979
7990
|
row
|
|
7980
7991
|
} = params;
|
|
@@ -7983,18 +7994,27 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
7983
7994
|
if (!rowRest) {
|
|
7984
7995
|
return;
|
|
7985
7996
|
}
|
|
7986
|
-
const
|
|
7987
|
-
|
|
7988
|
-
resizeHeight,
|
|
7989
|
-
|
|
7990
|
-
|
|
7991
|
-
|
|
7992
|
-
|
|
7993
|
-
|
|
7994
|
-
|
|
7997
|
+
const handleRsHeight = () => {
|
|
7998
|
+
el.setAttribute('data-calc-row', 'Y');
|
|
7999
|
+
const resizeHeight = calcCellAutoHeight(rowRest, el);
|
|
8000
|
+
el.removeAttribute('data-calc-row');
|
|
8001
|
+
const resizeParams = Object.assign(Object.assign({}, params), {
|
|
8002
|
+
resizeHeight,
|
|
8003
|
+
resizeRow: row
|
|
8004
|
+
});
|
|
8005
|
+
reactData.isDragResize = false;
|
|
8006
|
+
internalData._lastResizeTime = Date.now();
|
|
8007
|
+
if ($xeTable.handleRowResizeDblclickCellAreaEvent) {
|
|
8008
|
+
$xeTable.handleRowResizeDblclickCellAreaEvent(evnt, resizeParams);
|
|
8009
|
+
} else {
|
|
8010
|
+
rowRest.resizeHeight = resizeHeight;
|
|
8011
|
+
handleUpdateRowResize(evnt, resizeParams);
|
|
8012
|
+
}
|
|
8013
|
+
};
|
|
8014
|
+
if (actived.row || actived.column) {
|
|
8015
|
+
$xeTable.clearEdit().then(handleRsHeight);
|
|
7995
8016
|
} else {
|
|
7996
|
-
|
|
7997
|
-
handleUpdateRowResize(evnt, resizeParams);
|
|
8017
|
+
handleRsHeight();
|
|
7998
8018
|
}
|
|
7999
8019
|
}
|
|
8000
8020
|
},
|
|
@@ -8482,11 +8502,11 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
8482
8502
|
internalData.tooltipTimeout = setTimeout(() => {
|
|
8483
8503
|
$tooltip = refTooltip.value;
|
|
8484
8504
|
if ($tooltip && $tooltip.isActived && !$tooltip.isActived()) {
|
|
8485
|
-
|
|
8505
|
+
$xeTable.closeTooltip();
|
|
8486
8506
|
}
|
|
8487
8507
|
}, tooltipOpts.leaveDelay);
|
|
8488
8508
|
} else {
|
|
8489
|
-
|
|
8509
|
+
$xeTable.closeTooltip();
|
|
8490
8510
|
}
|
|
8491
8511
|
},
|
|
8492
8512
|
triggerHeaderCellClickEvent(evnt, params) {
|
|
@@ -8531,8 +8551,12 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
8531
8551
|
editConfig
|
|
8532
8552
|
} = props;
|
|
8533
8553
|
const {
|
|
8534
|
-
editStore
|
|
8554
|
+
editStore,
|
|
8555
|
+
isDragResize
|
|
8535
8556
|
} = reactData;
|
|
8557
|
+
if (isDragResize) {
|
|
8558
|
+
return;
|
|
8559
|
+
}
|
|
8536
8560
|
const expandOpts = computeExpandOpts.value;
|
|
8537
8561
|
const editOpts = computeEditOpts.value;
|
|
8538
8562
|
const treeOpts = computeTreeOpts.value;
|
|
@@ -8642,8 +8666,12 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
8642
8666
|
editConfig
|
|
8643
8667
|
} = props;
|
|
8644
8668
|
const {
|
|
8645
|
-
editStore
|
|
8669
|
+
editStore,
|
|
8670
|
+
isDragResize
|
|
8646
8671
|
} = reactData;
|
|
8672
|
+
if (isDragResize) {
|
|
8673
|
+
return;
|
|
8674
|
+
}
|
|
8647
8675
|
const editOpts = computeEditOpts.value;
|
|
8648
8676
|
const {
|
|
8649
8677
|
actived
|
|
@@ -9979,9 +10007,13 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
9979
10007
|
},
|
|
9980
10008
|
triggerBodyWheelEvent(evnt) {
|
|
9981
10009
|
const {
|
|
10010
|
+
target,
|
|
9982
10011
|
deltaY,
|
|
9983
10012
|
deltaX
|
|
9984
10013
|
} = evnt;
|
|
10014
|
+
if (target && /^textarea$/i.test(target.tagName)) {
|
|
10015
|
+
return;
|
|
10016
|
+
}
|
|
9985
10017
|
const {
|
|
9986
10018
|
highlightHoverRow
|
|
9987
10019
|
} = _props.default;
|
|
@@ -10216,9 +10248,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
10216
10248
|
// 更新纵向 Y 可视渲染上下剩余空间大小
|
|
10217
10249
|
updateScrollYSpace() {
|
|
10218
10250
|
const {
|
|
10219
|
-
|
|
10220
|
-
} = props;
|
|
10221
|
-
const {
|
|
10251
|
+
isAllOverflow,
|
|
10222
10252
|
scrollYLoad
|
|
10223
10253
|
} = reactData;
|
|
10224
10254
|
const {
|
|
@@ -10240,21 +10270,21 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
10240
10270
|
let ySpaceHeight = 0;
|
|
10241
10271
|
if (scrollYLoad) {
|
|
10242
10272
|
const isCustomCellHeight = isResizeCellHeight || cellOpts.height || rowOpts.height;
|
|
10243
|
-
if (!isCustomCellHeight &&
|
|
10273
|
+
if (!isCustomCellHeight && isAllOverflow) {
|
|
10244
10274
|
ySpaceHeight = afterFullData.length * defaultRowHeight;
|
|
10245
10275
|
topSpaceHeight = Math.max(0, startIndex * defaultRowHeight);
|
|
10246
10276
|
} else {
|
|
10247
10277
|
for (let i = 0; i < afterFullData.length; i++) {
|
|
10248
10278
|
const row = afterFullData[i];
|
|
10249
10279
|
const rowid = (0, _util.getRowid)($xeTable, row);
|
|
10250
|
-
const rowRest = fullAllDataRowIdData[rowid];
|
|
10251
|
-
ySpaceHeight += rowRest
|
|
10280
|
+
const rowRest = fullAllDataRowIdData[rowid] || {};
|
|
10281
|
+
ySpaceHeight += rowRest.resizeHeight || rowRest.height || cellOpts.height || rowOpts.height || defaultRowHeight;
|
|
10252
10282
|
}
|
|
10253
10283
|
for (let i = 0; i < startIndex; i++) {
|
|
10254
10284
|
const row = afterFullData[i];
|
|
10255
10285
|
const rowid = (0, _util.getRowid)($xeTable, row);
|
|
10256
|
-
const rowRest = fullAllDataRowIdData[rowid];
|
|
10257
|
-
topSpaceHeight += rowRest
|
|
10286
|
+
const rowRest = fullAllDataRowIdData[rowid] || {};
|
|
10287
|
+
topSpaceHeight += rowRest.resizeHeight || rowRest.height || cellOpts.height || rowOpts.height || defaultRowHeight;
|
|
10258
10288
|
}
|
|
10259
10289
|
}
|
|
10260
10290
|
} else {
|
|
@@ -10285,13 +10315,13 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
10285
10315
|
},
|
|
10286
10316
|
updateScrollXData() {
|
|
10287
10317
|
const {
|
|
10288
|
-
|
|
10289
|
-
} =
|
|
10318
|
+
isAllOverflow
|
|
10319
|
+
} = reactData;
|
|
10290
10320
|
handleTableColumn();
|
|
10291
10321
|
return (0, _vue.nextTick)().then(() => {
|
|
10292
10322
|
handleTableColumn();
|
|
10293
10323
|
$xeTable.updateScrollXSpace();
|
|
10294
|
-
if (!
|
|
10324
|
+
if (!isAllOverflow) {
|
|
10295
10325
|
$xeTable.updateScrollYSpace();
|
|
10296
10326
|
}
|
|
10297
10327
|
});
|
|
@@ -10880,7 +10910,7 @@ var _default = exports.default = (0, _vue.defineComponent)({
|
|
|
10880
10910
|
if (value && value.length >= 50000) {
|
|
10881
10911
|
(0, _log.warnLog)('vxe.error.errLargeData', ['loadData(data), reloadData(data)']);
|
|
10882
10912
|
}
|
|
10883
|
-
loadTableData(value,
|
|
10913
|
+
loadTableData(value, true).then(() => {
|
|
10884
10914
|
const {
|
|
10885
10915
|
scrollXLoad,
|
|
10886
10916
|
scrollYLoad,
|