@kdcloudjs/table 1.2.1-canary.6 → 1.2.2-canary.3
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/LICENSE +568 -568
- package/README.md +111 -111
- package/dist/@kdcloudjs/table.css +1 -1
- package/dist/@kdcloudjs/table.js +5480 -6087
- package/dist/@kdcloudjs/table.js.map +1 -1
- package/dist/@kdcloudjs/table.min.css +1 -1
- package/dist/@kdcloudjs/table.min.js +18 -16
- package/dist/@kdcloudjs/table.min.js.map +1 -1
- package/dist/kd-ui-complete.less +777 -777
- package/es/_utils/arrayUtil.js +0 -3
- package/es/_utils/devwarning.js +0 -1
- package/es/_utils/formatUtil.js +36 -101
- package/es/_utils/hooks.js +21 -45
- package/es/_utils/index.js +0 -2
- package/es/_utils/numberUtil.js +32 -55
- package/es/_utils/omit.js +0 -2
- package/es/_utils/type.js +0 -2
- package/es/_utils/usePopper.js +81 -144
- package/es/config-provider/compDefaultProps.js +0 -1
- package/es/config-provider/configProvider.js +2 -7
- package/es/config-provider/defaultConfig.js +0 -1
- package/es/index.js +0 -2
- package/es/locale/locale.js +11 -50
- package/es/style/color/colors.less +1 -1
- package/es/style/core/index.less +1 -1
- package/es/style/core/motion/other.less +27 -27
- package/es/style/core/motion/slide.less +53 -53
- package/es/style/core/motion.less +1 -1
- package/es/style/core/reset.less +185 -185
- package/es/style/index.less +1 -1
- package/es/style/mixins/index.less +18 -18
- package/es/style/mixins/overlay.less +21 -21
- package/es/style/mixins/reset.less +12 -12
- package/es/style/themes/default.less +445 -445
- package/es/table/base/calculations.js +25 -75
- package/es/table/base/colgroup.js +0 -1
- package/es/table/base/empty.js +6 -6
- package/es/table/base/globalStyleComponent.d.ts +4 -0
- package/es/table/base/globalStyleComponent.js +24 -0
- package/es/table/base/header.js +21 -76
- package/es/table/base/helpers/SpanManager.js +4 -11
- package/es/table/base/helpers/TableDOMUtils.js +9 -34
- package/es/table/base/helpers/__test__/SpanManager.test.js +2 -2
- package/es/table/base/helpers/__test__/TableDOMUtils.test.js +0 -1
- package/es/table/base/helpers/getRichVisibleRectsStream.js +13 -45
- package/es/table/base/helpers/rowHeightManager.js +0 -28
- package/es/table/base/html-table.js +17 -39
- package/es/table/base/loading.js +8 -10
- package/es/table/base/renderTemplates.js +42 -60
- package/es/table/base/styles.d.ts +10 -0
- package/es/table/base/styles.js +17 -16
- package/es/table/base/table.js +113 -201
- package/es/table/base/utils.js +17 -57
- package/es/table/common-views.js +0 -7
- package/es/table/interfaces.d.ts +38 -0
- package/es/table/internals.js +0 -13
- package/es/table/pipeline/const.d.ts +3 -0
- package/es/table/pipeline/const.js +3 -0
- package/es/table/pipeline/features/autoFill.js +11 -40
- package/es/table/pipeline/features/autoRowSpan.js +1 -14
- package/es/table/pipeline/features/colGroupExtendable.js +4 -19
- package/es/table/pipeline/features/columnDrag.js +41 -97
- package/es/table/pipeline/features/columnFilter.js +12 -51
- package/es/table/pipeline/features/columnHover.js +1 -7
- package/es/table/pipeline/features/columnRangeHover.js +1 -8
- package/es/table/pipeline/features/columnResizeWidth.js +13 -39
- package/es/table/pipeline/features/contextMenu.js +22 -95
- package/es/table/pipeline/features/featureApi/RowDragApi.d.ts +15 -0
- package/es/table/pipeline/features/featureApi/RowDragApi.js +66 -0
- package/es/table/pipeline/features/featureApi/utils.d.ts +2 -0
- package/es/table/pipeline/features/featureApi/utils.js +10 -0
- package/es/table/pipeline/features/filter/DefaultFilterContent.js +14 -30
- package/es/table/pipeline/features/filter/DefaultFilterIcon.js +1 -1
- package/es/table/pipeline/features/filter/Filter.js +27 -51
- package/es/table/pipeline/features/filter/FilterPanel.js +11 -25
- package/es/table/pipeline/features/filter/util.js +0 -4
- package/es/table/pipeline/features/footerDataSource.js +0 -3
- package/es/table/pipeline/features/mergeCellHover.js +0 -1
- package/es/table/pipeline/features/multiSelect.js +15 -57
- package/es/table/pipeline/features/rangeSelection.js +73 -152
- package/es/table/pipeline/features/rowDetail.js +4 -43
- package/es/table/pipeline/features/rowDrag.d.ts +10 -12
- package/es/table/pipeline/features/rowDrag.js +491 -236
- package/es/table/pipeline/features/rowGrouping.js +4 -37
- package/es/table/pipeline/features/singleSelect.js +0 -24
- package/es/table/pipeline/features/sort.js +38 -96
- package/es/table/pipeline/features/tips.js +4 -10
- package/es/table/pipeline/features/treeMode.d.ts +1 -0
- package/es/table/pipeline/features/treeMode.js +38 -57
- package/es/table/pipeline/features/treeSelect.js +2 -28
- package/es/table/pipeline/pipeline.d.ts +3 -0
- package/es/table/pipeline/pipeline.js +35 -54
- package/es/table/pivot/cross-table/buildCrossTable.js +21 -72
- package/es/table/pivot/cross-table/cross-table.js +23 -31
- package/es/table/pivot/cross-tree-table/buildCrossTreeTable.js +22 -57
- package/es/table/pivot/cross-tree-table/cross-tree-table.js +36 -61
- package/es/table/pivot/pivot-utils/buildDrillTree.js +10 -23
- package/es/table/pivot/pivot-utils/builders.js +34 -74
- package/es/table/pivot/pivot-utils/convert-utils.js +16 -42
- package/es/table/pivot/pivot-utils/simpleEncode.js +0 -1
- package/es/table/style/index.less +1 -1
- package/es/table/transforms/autoRowSpan.js +1 -15
- package/es/table/transforms/autoWidth.js +13 -35
- package/es/table/transforms/buildTree.js +1 -2
- package/es/table/transforms/columnHover.js +9 -15
- package/es/table/transforms/columnRangeHover.js +12 -19
- package/es/table/transforms/columnResize.js +18 -42
- package/es/table/transforms/flatten.js +0 -3
- package/es/table/transforms/orderField.js +0 -3
- package/es/table/transforms/sort.js +42 -101
- package/es/table/transforms/tips.js +5 -10
- package/es/table/transforms/treeMode.js +36 -77
- package/es/table/transforms/visible.js +0 -2
- package/es/table/use/useResizeObserver.js +1 -4
- package/es/table/utils/applyTransforms.js +0 -1
- package/es/table/utils/browserType.js +12 -19
- package/es/table/utils/buildTree.js +7 -22
- package/es/table/utils/collectNodes.js +4 -13
- package/es/table/utils/console.js +0 -14
- package/es/table/utils/copyToClipboard.js +0 -4
- package/es/table/utils/element.js +14 -41
- package/es/table/utils/exportTableAsExcel.js +7 -43
- package/es/table/utils/getTreeDepth.js +4 -12
- package/es/table/utils/groupBy.js +4 -13
- package/es/table/utils/layeredFilter.js +0 -4
- package/es/table/utils/layeredSort.js +0 -5
- package/es/table/utils/makeRecursiveMapper.js +4 -15
- package/es/table/utils/mergeCellProps.js +6 -14
- package/es/table/utils/others.js +6 -19
- package/es/table/utils/proto.js +2 -30
- package/es/table/utils/smartCompare.js +4 -12
- package/es/table/utils/traverseColumn.js +5 -18
- package/es/table/utils/tree-data-helpers/StrictTreeDataHelper.js +8 -30
- package/es/table/utils/tree-data-helpers/TreeDataHelper.js +19 -74
- package/es/table/utils/uiDegrade.js +0 -5
- package/lib/_utils/arrayUtil.js +2 -8
- package/lib/_utils/devwarning.js +0 -5
- package/lib/_utils/formatUtil.js +36 -105
- package/lib/_utils/hooks.js +21 -56
- package/lib/_utils/index.js +2 -9
- package/lib/_utils/numberUtil.js +32 -63
- package/lib/_utils/omit.js +0 -5
- package/lib/_utils/react-children.js +0 -5
- package/lib/_utils/type.js +3 -11
- package/lib/_utils/usePopper.js +86 -173
- package/lib/config-provider/ConfigContext.js +2 -6
- package/lib/config-provider/compDefaultProps.js +1 -3
- package/lib/config-provider/configProvider.js +6 -22
- package/lib/config-provider/defaultConfig.js +1 -7
- package/lib/config-provider/index.js +1 -8
- package/lib/index.js +2 -8
- package/lib/locale/index.js +3 -11
- package/lib/locale/locale.js +15 -71
- package/lib/locale/zh-CN.js +1 -2
- package/lib/style/color/colors.less +1 -1
- package/lib/style/components.less +1 -1
- package/lib/style/core/index.less +1 -1
- package/lib/style/core/motion/other.less +27 -27
- package/lib/style/core/motion/slide.less +53 -53
- package/lib/style/core/motion.less +1 -1
- package/lib/style/core/reset.less +185 -185
- package/lib/style/index.less +1 -1
- package/lib/style/mixins/index.less +18 -18
- package/lib/style/mixins/overlay.less +21 -21
- package/lib/style/mixins/reset.less +12 -12
- package/lib/style/themes/default.less +445 -445
- package/lib/table/base/calculations.js +25 -86
- package/lib/table/base/colgroup.js +0 -5
- package/lib/table/base/empty.js +8 -20
- package/lib/table/base/globalStyleComponent.d.ts +4 -0
- package/lib/table/base/globalStyleComponent.js +35 -0
- package/lib/table/base/header.js +21 -86
- package/lib/table/base/helpers/SpanManager.js +6 -16
- package/lib/table/base/helpers/TableDOMUtils.js +9 -37
- package/lib/table/base/helpers/__test__/SpanManager.test.js +2 -4
- package/lib/table/base/helpers/__test__/TableDOMUtils.test.js +0 -5
- package/lib/table/base/helpers/__test__/rowHeightManager.test.js +0 -1
- package/lib/table/base/helpers/getRichVisibleRectsStream.js +15 -65
- package/lib/table/base/helpers/rowHeightManager.js +0 -33
- package/lib/table/base/html-table.js +17 -49
- package/lib/table/base/index.js +0 -2
- package/lib/table/base/loading.js +8 -14
- package/lib/table/base/renderTemplates.js +45 -76
- package/lib/table/base/styles.d.ts +10 -0
- package/lib/table/base/styles.js +24 -42
- package/lib/table/base/table.js +125 -245
- package/lib/table/base/utils.js +27 -109
- package/lib/table/common-views.js +4 -24
- package/lib/table/index.js +0 -13
- package/lib/table/interfaces.d.ts +38 -0
- package/lib/table/internals.js +2 -17
- package/lib/table/pipeline/const.d.ts +3 -0
- package/lib/table/pipeline/const.js +9 -0
- package/lib/table/pipeline/features/autoFill.js +14 -53
- package/lib/table/pipeline/features/autoRowSpan.js +1 -19
- package/lib/table/pipeline/features/buildTree.js +0 -2
- package/lib/table/pipeline/features/colGroupExtendable.js +6 -35
- package/lib/table/pipeline/features/columnDrag.js +41 -103
- package/lib/table/pipeline/features/columnFilter.js +12 -65
- package/lib/table/pipeline/features/columnHover.js +1 -11
- package/lib/table/pipeline/features/columnRangeHover.js +1 -13
- package/lib/table/pipeline/features/columnResizeWidth.js +18 -63
- package/lib/table/pipeline/features/contextMenu.js +24 -121
- package/lib/table/pipeline/features/featureApi/RowDragApi.d.ts +15 -0
- package/lib/table/pipeline/features/featureApi/RowDragApi.js +72 -0
- package/lib/table/pipeline/features/featureApi/utils.d.ts +2 -0
- package/lib/table/pipeline/features/featureApi/utils.js +17 -0
- package/lib/table/pipeline/features/filter/DefaultFilterContent.js +17 -52
- package/lib/table/pipeline/features/filter/DefaultFilterIcon.js +1 -4
- package/lib/table/pipeline/features/filter/Filter.js +30 -77
- package/lib/table/pipeline/features/filter/FilterPanel.js +14 -44
- package/lib/table/pipeline/features/filter/index.js +0 -5
- package/lib/table/pipeline/features/filter/util.js +2 -10
- package/lib/table/pipeline/features/footerDataSource.js +1 -12
- package/lib/table/pipeline/features/index.js +0 -23
- package/lib/table/pipeline/features/mergeCellHover.js +0 -5
- package/lib/table/pipeline/features/multiSelect.js +15 -71
- package/lib/table/pipeline/features/rangeSelection.js +75 -173
- package/lib/table/pipeline/features/rowDetail.js +4 -67
- package/lib/table/pipeline/features/rowDrag.d.ts +10 -12
- package/lib/table/pipeline/features/rowDrag.js +494 -252
- package/lib/table/pipeline/features/rowGrouping.js +4 -57
- package/lib/table/pipeline/features/singleSelect.js +0 -34
- package/lib/table/pipeline/features/sort.js +37 -115
- package/lib/table/pipeline/features/tips.js +4 -19
- package/lib/table/pipeline/features/treeMode.d.ts +1 -0
- package/lib/table/pipeline/features/treeMode.js +40 -80
- package/lib/table/pipeline/features/treeSelect.js +2 -36
- package/lib/table/pipeline/index.js +2 -10
- package/lib/table/pipeline/pipeline.d.ts +3 -0
- package/lib/table/pipeline/pipeline.js +36 -65
- package/lib/table/pivot/cross-table/buildCrossTable.js +21 -83
- package/lib/table/pivot/cross-table/constants.js +1 -2
- package/lib/table/pivot/cross-table/cross-table.js +25 -42
- package/lib/table/pivot/cross-table/index.js +0 -4
- package/lib/table/pivot/cross-tree-table/buildCrossTreeTable.js +22 -70
- package/lib/table/pivot/cross-tree-table/cross-tree-table.js +37 -73
- package/lib/table/pivot/cross-tree-table/index.js +0 -3
- package/lib/table/pivot/pivot-utils/buildDrillTree.js +10 -29
- package/lib/table/pivot/pivot-utils/builders.js +34 -85
- package/lib/table/pivot/pivot-utils/convert-utils.js +16 -60
- package/lib/table/pivot/pivot-utils/index.js +0 -7
- package/lib/table/pivot/pivot-utils/simpleEncode.js +0 -2
- package/lib/table/style/css.js +0 -1
- package/lib/table/style/index.js +0 -1
- package/lib/table/style/index.less +1 -1
- package/lib/table/transforms/autoRowSpan.js +1 -21
- package/lib/table/transforms/autoWidth.js +15 -58
- package/lib/table/transforms/buildTree.js +1 -4
- package/lib/table/transforms/columnHover.js +9 -22
- package/lib/table/transforms/columnRangeHover.js +12 -27
- package/lib/table/transforms/columnResize.js +20 -63
- package/lib/table/transforms/flatten.js +0 -5
- package/lib/table/transforms/index.js +0 -12
- package/lib/table/transforms/orderField.js +0 -7
- package/lib/table/transforms/sort.js +44 -127
- package/lib/table/transforms/tips.js +5 -20
- package/lib/table/transforms/treeMode.js +38 -106
- package/lib/table/transforms/visible.js +0 -7
- package/lib/table/transforms/warnTransformsDeprecated.js +0 -4
- package/lib/table/use/useResizeObserver.js +2 -10
- package/lib/table/utils/applyTransforms.js +0 -2
- package/lib/table/utils/browserType.js +14 -23
- package/lib/table/utils/buildTree.js +7 -33
- package/lib/table/utils/collectNodes.js +4 -18
- package/lib/table/utils/console.js +2 -19
- package/lib/table/utils/copyToClipboard.js +1 -8
- package/lib/table/utils/element.js +14 -46
- package/lib/table/utils/exportTableAsExcel.js +7 -52
- package/lib/table/utils/getTreeDepth.js +4 -17
- package/lib/table/utils/groupBy.js +4 -17
- package/lib/table/utils/index.js +0 -22
- package/lib/table/utils/isGroupColumn.js +0 -3
- package/lib/table/utils/isLeafNode.js +0 -1
- package/lib/table/utils/keyCode.js +1 -2
- package/lib/table/utils/layeredFilter.js +0 -10
- package/lib/table/utils/layeredSort.js +0 -10
- package/lib/table/utils/makeRecursiveMapper.js +4 -24
- package/lib/table/utils/mergeCellProps.js +6 -18
- package/lib/table/utils/others.js +7 -36
- package/lib/table/utils/proto.js +3 -35
- package/lib/table/utils/selectColumn.js +2 -5
- package/lib/table/utils/smartCompare.js +4 -13
- package/lib/table/utils/traverseColumn.js +5 -25
- package/lib/table/utils/tree-data-helpers/StrictTreeDataHelper.js +10 -41
- package/lib/table/utils/tree-data-helpers/TreeDataHelper.js +21 -90
- package/lib/table/utils/uiDegrade.js +1 -8
- package/package.json +218 -218
|
@@ -1,25 +1,22 @@
|
|
|
1
1
|
import _classCallCheck from "@babel/runtime-corejs3/helpers/classCallCheck";
|
|
2
2
|
import _createClass from "@babel/runtime-corejs3/helpers/createClass";
|
|
3
3
|
import _filterInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/filter";
|
|
4
|
-
|
|
5
4
|
/** 在表格的单元格的渲染过程中,先渲染的单元格的 colSpan/rowSpan 会影响到后续单元格是否被渲染
|
|
6
5
|
* `SpanManager` 会在内部维护一份状态来记录最近渲染单元格的 colSpan/rowSpan,
|
|
7
6
|
* 方便后续的单元格快速判断 "是否需要跳过渲染" */
|
|
8
7
|
var SpanManager = /*#__PURE__*/function () {
|
|
9
8
|
function SpanManager() {
|
|
10
9
|
_classCallCheck(this, SpanManager);
|
|
11
|
-
|
|
12
10
|
this.rects = [];
|
|
13
11
|
}
|
|
14
|
-
|
|
15
|
-
_createClass(SpanManager, [{
|
|
12
|
+
return _createClass(SpanManager, [{
|
|
16
13
|
key: "testSkip",
|
|
17
14
|
value: function testSkip(rowIndex, colIndex) {
|
|
18
15
|
return this.rects.some(function (_ref) {
|
|
19
16
|
var left = _ref.left,
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
17
|
+
right = _ref.right,
|
|
18
|
+
top = _ref.top,
|
|
19
|
+
bottom = _ref.bottom;
|
|
23
20
|
return left <= colIndex && colIndex < right && top <= rowIndex && rowIndex < bottom;
|
|
24
21
|
});
|
|
25
22
|
}
|
|
@@ -27,7 +24,6 @@ var SpanManager = /*#__PURE__*/function () {
|
|
|
27
24
|
key: "stripUpwards",
|
|
28
25
|
value: function stripUpwards(rowIndex) {
|
|
29
26
|
var _context;
|
|
30
|
-
|
|
31
27
|
this.rects = _filterInstanceProperty(_context = this.rects).call(_context, function (rect) {
|
|
32
28
|
return rect.bottom > rowIndex;
|
|
33
29
|
});
|
|
@@ -43,8 +39,5 @@ var SpanManager = /*#__PURE__*/function () {
|
|
|
43
39
|
});
|
|
44
40
|
}
|
|
45
41
|
}]);
|
|
46
|
-
|
|
47
|
-
return SpanManager;
|
|
48
42
|
}();
|
|
49
|
-
|
|
50
43
|
export { SpanManager as default };
|
|
@@ -3,7 +3,8 @@ import _createClass from "@babel/runtime-corejs3/helpers/createClass";
|
|
|
3
3
|
import _sliceInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/slice";
|
|
4
4
|
import _Array$from from "@babel/runtime-corejs3/core-js-stable/array/from";
|
|
5
5
|
import _concatInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/concat";
|
|
6
|
-
import { Classes } from '../styles';
|
|
6
|
+
import { Classes } from '../styles';
|
|
7
|
+
// 表格 DOM 结构
|
|
7
8
|
// div.art-table-wrapper
|
|
8
9
|
// └── div.art-loading-wrapper
|
|
9
10
|
// ├── div.art-loading-indicator-wrapper
|
|
@@ -40,48 +41,37 @@ import { Classes } from '../styles'; // 表格 DOM 结构
|
|
|
40
41
|
// 在「可能存在嵌套表格」的情况下,我们可以采用以下的方式来避免「querySelector 不小心获取到了的嵌套表格上的元素」:
|
|
41
42
|
// artTable.querySelector('.art-lock-shadow-mask .art-left-lock-shadow')
|
|
42
43
|
// 表格 DOM 结构辅助工具
|
|
43
|
-
|
|
44
44
|
export var TableDOMHelper = /*#__PURE__*/function () {
|
|
45
45
|
function TableDOMHelper(artTableWrapper) {
|
|
46
46
|
var _this = this,
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
47
|
+
_context2,
|
|
48
|
+
_context3;
|
|
50
49
|
_classCallCheck(this, TableDOMHelper);
|
|
51
|
-
|
|
52
50
|
this.getRowNodeListByEvent = function (e) {
|
|
53
51
|
var nodeList = null;
|
|
54
52
|
var rowIndex = e.currentTarget.dataset.rowindex;
|
|
55
|
-
|
|
56
53
|
if (rowIndex !== undefined) {
|
|
57
54
|
var targetParent = _this.tableBody.contains(e.currentTarget) ? _this.tableBody : _this.tableFooter;
|
|
58
55
|
nodeList = targetParent.querySelectorAll("tr[data-rowindex=\"".concat(rowIndex, "\"]"));
|
|
59
56
|
}
|
|
60
|
-
|
|
61
57
|
return nodeList;
|
|
62
58
|
};
|
|
63
|
-
|
|
64
59
|
this.getInRangeRowByCellEvent = function (e) {
|
|
65
60
|
var _context;
|
|
66
|
-
|
|
67
61
|
var _a;
|
|
68
|
-
|
|
69
|
-
var getParentNode = function getParentNode(ele, target) {
|
|
62
|
+
var _getParentNode = function getParentNode(ele, target) {
|
|
70
63
|
if (ele.parentNode.nodeName === target) {
|
|
71
64
|
return ele.parentNode;
|
|
72
65
|
}
|
|
73
|
-
|
|
74
|
-
return getParentNode(ele.parentNode, target);
|
|
66
|
+
return _getParentNode(ele.parentNode, target);
|
|
75
67
|
};
|
|
76
|
-
|
|
77
68
|
e = e instanceof Array ? e[0] : e;
|
|
78
69
|
var curCell = e === null || e === void 0 ? void 0 : e.currentTarget;
|
|
79
|
-
var curRow =
|
|
70
|
+
var curRow = _getParentNode(curCell, 'TR');
|
|
80
71
|
var curRowSpan = parseInt(e.currentTarget.getAttribute('rowspan')) || 1;
|
|
81
|
-
var rows = (_a =
|
|
72
|
+
var rows = (_a = _getParentNode(curCell, 'TABLE')) === null || _a === void 0 ? void 0 : _a.rows;
|
|
82
73
|
return _sliceInstanceProperty(_context = _Array$from(rows)).call(_context, curRow.rowIndex, curRow.rowIndex + curRowSpan);
|
|
83
74
|
};
|
|
84
|
-
|
|
85
75
|
this.artTableWrapper = artTableWrapper;
|
|
86
76
|
this.artTable = artTableWrapper.querySelector(".".concat(Classes.artTable));
|
|
87
77
|
this.tableHeader = this.artTable.querySelector(".".concat(Classes.tableHeader));
|
|
@@ -91,16 +81,12 @@ export var TableDOMHelper = /*#__PURE__*/function () {
|
|
|
91
81
|
this.tableElement = this.artTable.querySelector(".".concat(Classes.tableBody, " table"));
|
|
92
82
|
this.tableFooter = this.artTable.querySelector(".".concat(Classes.tableFooter));
|
|
93
83
|
this.tableFooterMain = this.artTable.querySelector(".".concat(Classes.tableFooterMain));
|
|
94
|
-
|
|
95
84
|
var stickyScrollSelector = _concatInstanceProperty(_context2 = _concatInstanceProperty(_context3 = ".".concat(Classes.artTable, " + .")).call(_context3, Classes.horizontalStickyScrollContainer, " .")).call(_context2, Classes.stickyScroll);
|
|
96
|
-
|
|
97
85
|
var stickyScrolls = artTableWrapper.querySelectorAll(stickyScrollSelector);
|
|
98
86
|
this.stickyScroll = stickyScrolls[stickyScrolls.length - 1]; // 当嵌套多层表格时,需要查找最后一个,否则会查找到父表格内嵌套的子表格的
|
|
99
|
-
|
|
100
87
|
this.stickyScrollItem = this.stickyScroll.querySelector(".".concat(Classes.stickyScrollItem));
|
|
101
88
|
}
|
|
102
|
-
|
|
103
|
-
_createClass(TableDOMHelper, [{
|
|
89
|
+
return _createClass(TableDOMHelper, [{
|
|
104
90
|
key: "getVirtualTop",
|
|
105
91
|
value: function getVirtualTop() {
|
|
106
92
|
return this.tableBody.querySelector(".".concat(Classes.virtualBlank, ".top"));
|
|
@@ -109,7 +95,6 @@ export var TableDOMHelper = /*#__PURE__*/function () {
|
|
|
109
95
|
key: "getTableRows",
|
|
110
96
|
value: function getTableRows() {
|
|
111
97
|
var _context4;
|
|
112
|
-
|
|
113
98
|
var tbody = this.artTable.querySelector(_concatInstanceProperty(_context4 = ".".concat(Classes.tableBody, " .")).call(_context4, Classes.virtual, " table tbody"));
|
|
114
99
|
return tbody.childNodes;
|
|
115
100
|
}
|
|
@@ -117,16 +102,13 @@ export var TableDOMHelper = /*#__PURE__*/function () {
|
|
|
117
102
|
key: "getTableBodyHtmlTable",
|
|
118
103
|
value: function getTableBodyHtmlTable() {
|
|
119
104
|
var _context5;
|
|
120
|
-
|
|
121
105
|
return this.artTable.querySelector(_concatInstanceProperty(_context5 = ".".concat(Classes.tableBody, " .")).call(_context5, Classes.virtual, " table"));
|
|
122
106
|
}
|
|
123
107
|
}, {
|
|
124
108
|
key: "getLeftLockShadow",
|
|
125
109
|
value: function getLeftLockShadow() {
|
|
126
110
|
var _context6;
|
|
127
|
-
|
|
128
111
|
var selector = _concatInstanceProperty(_context6 = ".".concat(Classes.lockShadowMask, " .")).call(_context6, Classes.leftLockShadow);
|
|
129
|
-
|
|
130
112
|
var allLeftLockShadow = this.artTable.querySelectorAll(selector);
|
|
131
113
|
return allLeftLockShadow[allLeftLockShadow.length - 1]; // 当table-body、table-footer嵌套多层表格时,需要查找最后一个,否则会查找到嵌套表格的
|
|
132
114
|
}
|
|
@@ -134,9 +116,7 @@ export var TableDOMHelper = /*#__PURE__*/function () {
|
|
|
134
116
|
key: "getRightLockShadow",
|
|
135
117
|
value: function getRightLockShadow() {
|
|
136
118
|
var _context7;
|
|
137
|
-
|
|
138
119
|
var selector = _concatInstanceProperty(_context7 = ".".concat(Classes.lockShadowMask, " .")).call(_context7, Classes.rightLockShadow);
|
|
139
|
-
|
|
140
120
|
var allRightLockShadow = this.artTable.querySelectorAll(selector);
|
|
141
121
|
return allRightLockShadow[allRightLockShadow.length - 1]; // 当table-body、table-footer嵌套多层表格时,需要查找最后一个,否则会查找到嵌套表格的
|
|
142
122
|
}
|
|
@@ -149,17 +129,12 @@ export var TableDOMHelper = /*#__PURE__*/function () {
|
|
|
149
129
|
key: "getRowTop",
|
|
150
130
|
value: function getRowTop(rowIndex) {
|
|
151
131
|
var _context8, _context9;
|
|
152
|
-
|
|
153
132
|
if (rowIndex === 0) return 0;
|
|
154
|
-
|
|
155
133
|
var selector = _concatInstanceProperty(_context8 = _concatInstanceProperty(_context9 = ".".concat(Classes.tableBody, " .")).call(_context9, Classes.tableRow, "[data-rowindex=\"")).call(_context8, rowIndex, "\"]");
|
|
156
|
-
|
|
157
134
|
var row = this.artTable.querySelector(selector);
|
|
158
135
|
var rowOffsetTop = row && row.offsetTop || 0;
|
|
159
136
|
var tableOffsetTop = this.tableElement.offsetTop || 0;
|
|
160
137
|
return rowOffsetTop + tableOffsetTop;
|
|
161
138
|
}
|
|
162
139
|
}]);
|
|
163
|
-
|
|
164
|
-
return TableDOMHelper;
|
|
165
140
|
}();
|
|
@@ -8,8 +8,8 @@ describe("".concat(NAME), function () {
|
|
|
8
8
|
});
|
|
9
9
|
it('test skip', function () {
|
|
10
10
|
// 第二行,第一列跳过渲染
|
|
11
|
-
expect(spanManager.testSkip(1, 0)).toBe(true);
|
|
12
|
-
|
|
11
|
+
expect(spanManager.testSkip(1, 0)).toBe(true);
|
|
12
|
+
// 第四行,第一列不跳过渲染
|
|
13
13
|
expect(spanManager.testSkip(3, 0)).toBe(false);
|
|
14
14
|
});
|
|
15
15
|
it('strip upwards span info', function () {
|
|
@@ -7,7 +7,6 @@ describe("".concat(NAME), function () {
|
|
|
7
7
|
var container;
|
|
8
8
|
beforeAll(function () {
|
|
9
9
|
var _context, _context2, _context3, _context4, _context5, _context6, _context7, _context8, _context9, _context10, _context11, _context12, _context13, _context14, _context15, _context16, _context17;
|
|
10
|
-
|
|
11
10
|
container = document.createElement('div');
|
|
12
11
|
container.innerHTML = _concatInstanceProperty(_context = _concatInstanceProperty(_context2 = _concatInstanceProperty(_context3 = _concatInstanceProperty(_context4 = _concatInstanceProperty(_context5 = _concatInstanceProperty(_context6 = _concatInstanceProperty(_context7 = _concatInstanceProperty(_context8 = _concatInstanceProperty(_context9 = _concatInstanceProperty(_context10 = _concatInstanceProperty(_context11 = _concatInstanceProperty(_context12 = _concatInstanceProperty(_context13 = _concatInstanceProperty(_context14 = _concatInstanceProperty(_context15 = _concatInstanceProperty(_context16 = _concatInstanceProperty(_context17 = "<div class='".concat(Classes.artTableWrapper, "'>\n <div class='")).call(_context17, Classes.loadingWrapper, "'>\n <div class='")).call(_context16, Classes.loadingIndicatorWrapper, "'>\n <div class='")).call(_context15, Classes.loadingIndicator, "'></div>\n </div> \n <div class='")).call(_context14, Classes.loadingContentWrapper, "'>\n <div class='")).call(_context13, Classes.artTable, "'>\n <div class='")).call(_context12, Classes.tableHeader, "'>\n \n </div>\n <div class='")).call(_context11, Classes.tableBody, "'>\n <div class='")).call(_context10, Classes.virtual, "'>\n <div class='")).call(_context9, Classes.virtualBlank, " top'></div>\n <table></table>\n <div class='")).call(_context8, Classes.virtualBlank, " bottom'></div>\n </div> \n </div>\n <div class='")).call(_context7, Classes.tableFooter, "'>\n </div>\n <div class='")).call(_context6, Classes.lockShadowMask, "'>\n <div class='")).call(_context5, Classes.leftLockShadow, "'></div>\n </div>\n <div class='")).call(_context4, Classes.lockShadowMask, "'>\n <div class='")).call(_context3, Classes.rightLockShadow, "'></div>\n </div>\n </div>\n <div class='")).call(_context2, Classes.stickyScroll, "'>\n <div class='")).call(_context, Classes.stickyScrollItem, "'></div>\n </div>\n </div> \n </div> \n </div>");
|
|
13
12
|
tableDOMHelper = new TableDOMHelper(container.querySelector(".".concat(Classes.artTableWrapper)));
|
|
@@ -10,51 +10,39 @@ import ResizeObserver from 'resize-observer-polyfill';
|
|
|
10
10
|
import { fromEvent, merge, Observable } from 'rxjs';
|
|
11
11
|
import * as op from 'rxjs/operators';
|
|
12
12
|
import { shallowEqual } from '../utils';
|
|
13
|
-
|
|
14
13
|
function isWindow(arg) {
|
|
15
14
|
return arg.toString() === '[object Window]' || arg.toString() === '[object global]';
|
|
16
15
|
}
|
|
17
|
-
|
|
18
16
|
function isBody(arg) {
|
|
19
17
|
return getNodeName(arg) === 'body';
|
|
20
18
|
}
|
|
21
|
-
|
|
22
19
|
function isHtml(arg) {
|
|
23
20
|
return getNodeName(arg) === 'html';
|
|
24
21
|
}
|
|
25
|
-
|
|
26
22
|
function isHtmlOrBody(arg) {
|
|
27
23
|
return isHtml(arg) || isBody(arg);
|
|
28
|
-
}
|
|
24
|
+
}
|
|
25
|
+
// 计算从 start(子元素)到 stop(祖先元素)之间所有元素的 scrollTop 或 scrollLeft 的和
|
|
29
26
|
// 注意 start 和 stop 都是 INCLUSIVE 的,即两者的 scrollTop 或 scrollLeft 都会统计在内
|
|
30
|
-
|
|
31
|
-
|
|
32
27
|
function accumulateScrollOffset(start, stop, scrollOffsetKey) {
|
|
33
28
|
var result = 0;
|
|
34
29
|
var elem = start;
|
|
35
|
-
|
|
36
30
|
while (elem != null) {
|
|
37
31
|
result += elem[scrollOffsetKey];
|
|
38
|
-
|
|
39
32
|
if (elem === stop || isWindow(stop) && isHtmlOrBody(elem)) {
|
|
40
33
|
break;
|
|
41
34
|
}
|
|
42
|
-
|
|
43
35
|
elem = elem.parentElement;
|
|
44
36
|
}
|
|
45
|
-
|
|
46
37
|
if (isWindow(stop)) {
|
|
47
38
|
result += getWindowScroll(elem)[scrollOffsetKey];
|
|
48
39
|
}
|
|
49
|
-
|
|
50
40
|
return result;
|
|
51
41
|
}
|
|
52
42
|
/**
|
|
53
43
|
* 获取 target 相对于 base 的布局大小和相对位置。
|
|
54
44
|
* 注意该方法会考虑滚动所带来的影响
|
|
55
45
|
*/
|
|
56
|
-
|
|
57
|
-
|
|
58
46
|
function getRelativeLayoutRect(base, target) {
|
|
59
47
|
if (isWindow(target) || isHtmlOrBody(target)) {
|
|
60
48
|
return {
|
|
@@ -64,27 +52,22 @@ function getRelativeLayoutRect(base, target) {
|
|
|
64
52
|
bottom: window.innerHeight
|
|
65
53
|
};
|
|
66
54
|
}
|
|
67
|
-
|
|
68
55
|
var deltaX = 0;
|
|
69
56
|
var deltaY = 0;
|
|
70
57
|
var elem = target;
|
|
71
|
-
|
|
72
58
|
while (elem != null && elem != base) {
|
|
73
59
|
deltaY += elem.offsetTop;
|
|
74
60
|
deltaX += elem.offsetLeft;
|
|
75
61
|
var offsetParent = getOffsetParent(elem);
|
|
76
62
|
deltaY -= accumulateScrollOffset(elem.parentElement, offsetParent, 'scrollTop');
|
|
77
63
|
deltaX -= accumulateScrollOffset(elem.parentElement, offsetParent, 'scrollLeft');
|
|
78
|
-
|
|
79
64
|
if (isWindow(offsetParent)) {
|
|
80
65
|
break;
|
|
81
66
|
}
|
|
82
|
-
|
|
83
67
|
deltaY += offsetParent.clientTop;
|
|
84
68
|
deltaX += offsetParent.clientLeft;
|
|
85
69
|
elem = offsetParent;
|
|
86
70
|
}
|
|
87
|
-
|
|
88
71
|
return {
|
|
89
72
|
top: deltaY,
|
|
90
73
|
bottom: deltaY + target.offsetHeight,
|
|
@@ -92,51 +75,40 @@ function getRelativeLayoutRect(base, target) {
|
|
|
92
75
|
right: deltaX + target.offsetWidth
|
|
93
76
|
};
|
|
94
77
|
}
|
|
95
|
-
|
|
96
78
|
function findCommonOffsetAncestor(target, scrollParent) {
|
|
97
79
|
if (isWindow(scrollParent)) {
|
|
98
80
|
return scrollParent;
|
|
99
81
|
}
|
|
100
|
-
|
|
101
82
|
var offsetParents = listOffsetParents(target);
|
|
102
|
-
|
|
103
83
|
if (_includesInstanceProperty(offsetParents).call(offsetParents, scrollParent)) {
|
|
104
84
|
return scrollParent;
|
|
105
85
|
}
|
|
106
|
-
|
|
107
86
|
return getOffsetParent(scrollParent);
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
|
|
87
|
+
}
|
|
88
|
+
// 列出 target 元素上层的所有 offset parents
|
|
111
89
|
function listOffsetParents(target) {
|
|
112
90
|
var result = [];
|
|
113
91
|
var elem = target;
|
|
114
|
-
|
|
115
92
|
while (true) {
|
|
116
93
|
if (isWindow(elem)) {
|
|
117
94
|
break;
|
|
118
95
|
}
|
|
119
|
-
|
|
120
96
|
elem = getOffsetParent(elem);
|
|
121
97
|
result.push(elem);
|
|
122
98
|
}
|
|
123
|
-
|
|
124
99
|
return result;
|
|
125
100
|
}
|
|
126
|
-
|
|
127
101
|
function fromScrollEvent(element) {
|
|
128
102
|
return fromEvent(element, 'scroll', {
|
|
129
103
|
passive: true
|
|
130
104
|
});
|
|
131
105
|
}
|
|
132
|
-
|
|
133
106
|
function fromResizeEvent(element) {
|
|
134
107
|
if (isWindow(element)) {
|
|
135
108
|
return fromEvent(element, 'resize', {
|
|
136
109
|
passive: true
|
|
137
110
|
});
|
|
138
111
|
}
|
|
139
|
-
|
|
140
112
|
return new Observable(function (subscriber) {
|
|
141
113
|
var resizeObserver = new ResizeObserver(function (entries) {
|
|
142
114
|
subscriber.next(entries);
|
|
@@ -147,30 +119,26 @@ function fromResizeEvent(element) {
|
|
|
147
119
|
};
|
|
148
120
|
});
|
|
149
121
|
}
|
|
150
|
-
|
|
151
122
|
function getScrollParent(elem) {
|
|
152
123
|
var _context;
|
|
153
|
-
|
|
154
124
|
if (_includesInstanceProperty(_context = ['html', 'body', '#document']).call(_context, getNodeName(elem))) {
|
|
155
125
|
return getWindow(elem);
|
|
156
126
|
}
|
|
157
|
-
|
|
158
127
|
if (isHTMLElement(elem) && isScrollParent(elem)) {
|
|
159
128
|
return elem;
|
|
160
129
|
}
|
|
161
|
-
|
|
162
130
|
return getScrollParent(getParentNode(elem));
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
|
|
131
|
+
}
|
|
132
|
+
// 获取 target 相对于「它的滚动父元素」的可见部分的大小与位置
|
|
166
133
|
export function getRichVisibleRectsStream(target, structureMayChange$, virtualDebugLabel) {
|
|
167
|
-
return structureMayChange$.pipe(op.mapTo(target), op.distinctUntilChanged(shallowEqual),
|
|
134
|
+
return structureMayChange$.pipe(op.mapTo(target), op.distinctUntilChanged(shallowEqual),
|
|
135
|
+
// 当target没有发生变化时,无需重新查找
|
|
168
136
|
op.startWith('init'), op.map(function () {
|
|
169
137
|
// target 的第一个滚动父元素,我们认为这就是虚拟滚动发生的地方
|
|
170
138
|
// 即虚拟滚动不考虑「更上层元素发生滚动」的情况
|
|
171
139
|
// 直接从父元素开始查找,防止自身设置overflow属性导致是同一个元素
|
|
172
|
-
var scrollParent = getScrollParent(getParentNode(target));
|
|
173
|
-
|
|
140
|
+
var scrollParent = getScrollParent(getParentNode(target));
|
|
141
|
+
// target 和 scrollParent 的共同 offset 祖先,作为布局尺寸计算时的参照元素
|
|
174
142
|
var commonOffsetAncestor = findCommonOffsetAncestor(target, scrollParent);
|
|
175
143
|
return {
|
|
176
144
|
scrollParent: scrollParent,
|
|
@@ -182,7 +150,7 @@ export function getRichVisibleRectsStream(target, structureMayChange$, virtualDe
|
|
|
182
150
|
}
|
|
183
151
|
}), op.switchMap(function (_ref) {
|
|
184
152
|
var scrollParent = _ref.scrollParent,
|
|
185
|
-
|
|
153
|
+
commonOffsetAncestor = _ref.commonOffsetAncestor;
|
|
186
154
|
var events$ = merge(fromScrollEvent(scrollParent), fromResizeEvent(scrollParent), fromResizeEvent(target));
|
|
187
155
|
return events$.pipe(op.map(function (event) {
|
|
188
156
|
return {
|
|
@@ -192,8 +160,8 @@ export function getRichVisibleRectsStream(target, structureMayChange$, virtualDe
|
|
|
192
160
|
};
|
|
193
161
|
}), op.map(function (_ref2) {
|
|
194
162
|
var event = _ref2.event,
|
|
195
|
-
|
|
196
|
-
|
|
163
|
+
scrollParentRect = _ref2.scrollParentRect,
|
|
164
|
+
targetRect = _ref2.targetRect;
|
|
197
165
|
return {
|
|
198
166
|
event: event,
|
|
199
167
|
targetRect: targetRect,
|
|
@@ -11,14 +11,11 @@ export function getFullRenderRange(rowCount) {
|
|
|
11
11
|
}
|
|
12
12
|
export function makeRowHeightManager(initRowCount, estimatedRowHeight) {
|
|
13
13
|
var _context;
|
|
14
|
-
|
|
15
14
|
var cache = _fillInstanceProperty(_context = new Array(initRowCount)).call(_context, estimatedRowHeight);
|
|
16
|
-
|
|
17
15
|
function getRenderRange(offset, maxRenderHeight, rowCount) {
|
|
18
16
|
if (cache.length !== rowCount) {
|
|
19
17
|
setRowCount(rowCount);
|
|
20
18
|
}
|
|
21
|
-
|
|
22
19
|
if (maxRenderHeight <= 0) {
|
|
23
20
|
// maxRenderHeight <= 0 说明表格目前在 viewport 之外
|
|
24
21
|
if (offset <= 0) {
|
|
@@ -32,7 +29,6 @@ export function makeRowHeightManager(initRowCount, estimatedRowHeight) {
|
|
|
32
29
|
// 表格与 viewport 相交
|
|
33
30
|
return getRenderRangeWhenInView();
|
|
34
31
|
}
|
|
35
|
-
|
|
36
32
|
function getRenderRangeWhenBelowView() {
|
|
37
33
|
var start = {
|
|
38
34
|
topIndex: 0,
|
|
@@ -41,22 +37,18 @@ export function makeRowHeightManager(initRowCount, estimatedRowHeight) {
|
|
|
41
37
|
var end = getEnd(0, start);
|
|
42
38
|
return _extends(_extends({}, start), end);
|
|
43
39
|
}
|
|
44
|
-
|
|
45
40
|
function getRenderRangeWhenAboveView() {
|
|
46
41
|
var totalSize = getEstimatedTotalSize(rowCount);
|
|
47
42
|
var start = getStart(totalSize);
|
|
48
43
|
var end = getEnd(totalSize, start);
|
|
49
44
|
return _extends(_extends({}, start), end);
|
|
50
45
|
}
|
|
51
|
-
|
|
52
46
|
function getRenderRangeWhenInView() {
|
|
53
47
|
var start = getStart(offset);
|
|
54
48
|
var end = getEnd(offset + maxRenderHeight, start);
|
|
55
49
|
return _extends(_extends({}, start), end);
|
|
56
50
|
}
|
|
57
51
|
/** 获取虚拟滚动在 开始位置上的信息 */
|
|
58
|
-
|
|
59
|
-
|
|
60
52
|
function getStart(offset) {
|
|
61
53
|
if (cache.length === 0) {
|
|
62
54
|
return {
|
|
@@ -64,73 +56,56 @@ export function makeRowHeightManager(initRowCount, estimatedRowHeight) {
|
|
|
64
56
|
topBlank: 0
|
|
65
57
|
};
|
|
66
58
|
}
|
|
67
|
-
|
|
68
59
|
var topIndex = 0;
|
|
69
60
|
var topBlank = 0;
|
|
70
|
-
|
|
71
61
|
while (topIndex < cache.length) {
|
|
72
62
|
var h = cache[topIndex];
|
|
73
|
-
|
|
74
63
|
if (topBlank + h >= offset) {
|
|
75
64
|
break;
|
|
76
65
|
}
|
|
77
|
-
|
|
78
66
|
topBlank += h;
|
|
79
67
|
topIndex += 1;
|
|
80
68
|
}
|
|
81
|
-
|
|
82
69
|
return overscanUpwards(topIndex, topBlank);
|
|
83
70
|
}
|
|
84
|
-
|
|
85
71
|
function overscanUpwards(topIndex, topBlank) {
|
|
86
72
|
var overscanSize = 0;
|
|
87
73
|
var overscanCount = 0;
|
|
88
|
-
|
|
89
74
|
while (overscanCount < topIndex && overscanSize < OVERSCAN_SIZE) {
|
|
90
75
|
overscanCount += 1;
|
|
91
76
|
overscanSize += cache[topIndex - overscanCount];
|
|
92
77
|
}
|
|
93
|
-
|
|
94
78
|
return {
|
|
95
79
|
topIndex: topIndex - overscanCount,
|
|
96
80
|
topBlank: topBlank - overscanSize
|
|
97
81
|
};
|
|
98
82
|
}
|
|
99
83
|
/** 获取虚拟滚动 在结束位置上的信息 */
|
|
100
|
-
|
|
101
|
-
|
|
102
84
|
function getEnd(endOffset, startInfo) {
|
|
103
85
|
var bottomIndex = startInfo.topIndex;
|
|
104
86
|
var offset = startInfo.topBlank;
|
|
105
|
-
|
|
106
87
|
while (bottomIndex < rowCount && offset < endOffset) {
|
|
107
88
|
offset += cache[bottomIndex];
|
|
108
89
|
bottomIndex += 1;
|
|
109
90
|
}
|
|
110
|
-
|
|
111
91
|
var bottomBlank = getEstimatedTotalSize(rowCount) - offset;
|
|
112
92
|
return overscanDownwards(bottomIndex, bottomBlank);
|
|
113
93
|
}
|
|
114
|
-
|
|
115
94
|
function overscanDownwards(bottomIndex, bottomBlank) {
|
|
116
95
|
var overscanSize = 0;
|
|
117
96
|
var overscanCount = 0;
|
|
118
|
-
|
|
119
97
|
while (overscanCount < rowCount - bottomIndex && overscanSize < OVERSCAN_SIZE) {
|
|
120
98
|
overscanSize += cache[bottomIndex + overscanCount];
|
|
121
99
|
overscanCount += 1;
|
|
122
100
|
}
|
|
123
|
-
|
|
124
101
|
return {
|
|
125
102
|
bottomIndex: bottomIndex + overscanCount,
|
|
126
103
|
bottomBlank: bottomBlank - overscanSize
|
|
127
104
|
};
|
|
128
105
|
}
|
|
129
|
-
|
|
130
106
|
function getEstimatedTotalSize(rowCount) {
|
|
131
107
|
return sum(cache) + (rowCount - cache.length) * estimatedRowHeight;
|
|
132
108
|
}
|
|
133
|
-
|
|
134
109
|
function setRowCount(count) {
|
|
135
110
|
// 将 cache 的长度设置为 count
|
|
136
111
|
if (count < cache.length) {
|
|
@@ -138,16 +113,13 @@ export function makeRowHeightManager(initRowCount, estimatedRowHeight) {
|
|
|
138
113
|
} else {
|
|
139
114
|
var prevSize = cache.length;
|
|
140
115
|
cache.length = count;
|
|
141
|
-
|
|
142
116
|
_fillInstanceProperty(cache).call(cache, estimatedRowHeight, prevSize);
|
|
143
117
|
}
|
|
144
118
|
}
|
|
145
119
|
}
|
|
146
|
-
|
|
147
120
|
function updateRow(index, offset, size) {
|
|
148
121
|
cache[index] = size;
|
|
149
122
|
}
|
|
150
|
-
|
|
151
123
|
return {
|
|
152
124
|
getRenderRange: getRenderRange,
|
|
153
125
|
updateRow: updateRow,
|
|
@@ -11,17 +11,15 @@ import SpanManager from './helpers/SpanManager';
|
|
|
11
11
|
import { Classes } from './styles';
|
|
12
12
|
export function HtmlTable(_ref) {
|
|
13
13
|
var tbodyHtmlTag = _ref.tbodyHtmlTag,
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
14
|
+
getRowProps = _ref.getRowProps,
|
|
15
|
+
primaryKey = _ref.primaryKey,
|
|
16
|
+
stickyRightOffset = _ref.stickyRightOffset,
|
|
17
|
+
data = _ref.data,
|
|
18
|
+
verInfo = _ref.verticalRenderInfo,
|
|
19
|
+
hozInfo = _ref.horizontalRenderInfo,
|
|
20
|
+
tbodyPosition = _ref.tbodyPosition;
|
|
22
21
|
var flat = _flatInstanceProperty(hozInfo),
|
|
23
|
-
|
|
24
|
-
|
|
22
|
+
hoz = hozInfo.horizontalRenderRange;
|
|
25
23
|
var spanManager = new SpanManager();
|
|
26
24
|
var fullFlatCount = flat.full.length;
|
|
27
25
|
var leftFlatCount = flat.left.length;
|
|
@@ -29,20 +27,16 @@ export function HtmlTable(_ref) {
|
|
|
29
27
|
return /*#__PURE__*/React.createElement("table", null, /*#__PURE__*/React.createElement(Colgroup, {
|
|
30
28
|
descriptors: hozInfo.visible
|
|
31
29
|
}), /*#__PURE__*/React.createElement(tbodyHtmlTag, null, _mapInstanceProperty(data).call(data, renderRow)));
|
|
32
|
-
|
|
33
30
|
function renderRow(record, i) {
|
|
34
|
-
var
|
|
35
|
-
|
|
31
|
+
var _context;
|
|
36
32
|
var rowIndex = verInfo.offset + i;
|
|
37
33
|
spanManager.stripUpwards(rowIndex);
|
|
38
34
|
var rowProps = getRowProps(record, rowIndex);
|
|
39
|
-
var rowClass = cx(Classes.tableRow, (
|
|
40
|
-
|
|
41
|
-
|
|
35
|
+
var rowClass = cx(Classes.tableRow, _defineProperty(_defineProperty(_defineProperty(_defineProperty({}, Classes.first, rowIndex === verInfo.first), Classes.last, rowIndex === verInfo.last), Classes.even, rowIndex % 2 === 0), Classes.odd, rowIndex % 2 === 1), rowProps === null || rowProps === void 0 ? void 0 : rowProps.className);
|
|
36
|
+
var visibleColumnDescriptor = _concatInstanceProperty(_context = hozInfo.visible).call(_context);
|
|
37
|
+
// 左中右区域渲染,存在融合单元格时需要适配rowspan属性
|
|
42
38
|
// 如果固定的列均存在融合单元格,需空白一列做占位,否则融合的单元格不会渲染,导致显示异常
|
|
43
39
|
// 这里无法区分是否存在融合列,默认左右固定区域均添加占位空白列
|
|
44
|
-
|
|
45
|
-
|
|
46
40
|
if (['left', 'right'].indexOf(tbodyPosition) > -1) {
|
|
47
41
|
visibleColumnDescriptor.push({
|
|
48
42
|
type: 'blank',
|
|
@@ -51,7 +45,6 @@ export function HtmlTable(_ref) {
|
|
|
51
45
|
isPlacehoder: true
|
|
52
46
|
});
|
|
53
47
|
}
|
|
54
|
-
|
|
55
48
|
return /*#__PURE__*/React.createElement("tr", _extends({}, rowProps, {
|
|
56
49
|
className: rowClass,
|
|
57
50
|
key: (rowProps === null || rowProps === void 0 ? void 0 : rowProps['data-row-detail-key']) ? rowProps['data-row-detail-key'] : internals.safeGetRowKey(primaryKey, record, rowIndex),
|
|
@@ -66,31 +59,22 @@ export function HtmlTable(_ref) {
|
|
|
66
59
|
}
|
|
67
60
|
});
|
|
68
61
|
}
|
|
69
|
-
|
|
70
62
|
return renderBodyCell(record, rowIndex, descriptor.col, descriptor.colIndex);
|
|
71
63
|
}));
|
|
72
64
|
}
|
|
73
|
-
|
|
74
65
|
function renderBodyCell(record, rowIndex, column, colIndex) {
|
|
75
|
-
var _cx2;
|
|
76
|
-
|
|
77
66
|
var _a, _b, _c;
|
|
78
|
-
|
|
79
67
|
if (spanManager.testSkip(rowIndex, colIndex)) {
|
|
80
68
|
return null;
|
|
81
69
|
}
|
|
82
|
-
|
|
83
70
|
var value = internals.safeGetValue(column, record, rowIndex);
|
|
84
71
|
var cellProps = (_b = (_a = column.getCellProps) === null || _a === void 0 ? void 0 : _a.call(column, value, record, rowIndex)) !== null && _b !== void 0 ? _b : {};
|
|
85
72
|
var cellContent = value;
|
|
86
|
-
|
|
87
73
|
if (column.render) {
|
|
88
74
|
cellContent = column.render(value, record, rowIndex);
|
|
89
75
|
}
|
|
90
|
-
|
|
91
76
|
var colSpan = 1;
|
|
92
77
|
var rowSpan = 1;
|
|
93
|
-
|
|
94
78
|
if (column.getSpanRect) {
|
|
95
79
|
var spanRect = column.getSpanRect(value, record, rowIndex);
|
|
96
80
|
colSpan = spanRect == null ? 1 : spanRect.right - colIndex;
|
|
@@ -99,26 +83,21 @@ export function HtmlTable(_ref) {
|
|
|
99
83
|
if (cellProps.colSpan != null) {
|
|
100
84
|
colSpan = cellProps.colSpan;
|
|
101
85
|
}
|
|
102
|
-
|
|
103
86
|
if (cellProps.rowSpan != null) {
|
|
104
87
|
rowSpan = cellProps.rowSpan;
|
|
105
88
|
}
|
|
106
89
|
}
|
|
107
|
-
|
|
108
90
|
var hasSpan = colSpan > 1 || rowSpan > 1;
|
|
109
|
-
|
|
110
91
|
if (hasSpan) {
|
|
111
92
|
spanManager.add(rowIndex, colIndex, colSpan, rowSpan);
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
|
|
93
|
+
}
|
|
94
|
+
// rowSpan/colSpan 不能过大,避免 rowSpan/colSpan 影响因虚拟滚动而未渲染的单元格
|
|
115
95
|
rowSpan = Math.min(rowSpan, verInfo.limit - rowIndex);
|
|
116
|
-
colSpan = Math.min(colSpan, hozInfo.visible.length - colIndex);
|
|
117
|
-
|
|
96
|
+
colSpan = Math.min(colSpan, hozInfo.visible.length - colIndex);
|
|
97
|
+
// todo: 右侧有列固定的情况下colSpan计算不对,这里先限制一下
|
|
118
98
|
rowSpan = Math.max(rowSpan, 1);
|
|
119
99
|
colSpan = Math.max(colSpan, 1);
|
|
120
100
|
var positionStyle = {};
|
|
121
|
-
|
|
122
101
|
if (colIndex < leftFlatCount) {
|
|
123
102
|
positionStyle.position = 'sticky';
|
|
124
103
|
positionStyle.left = hozInfo.stickyLeftMap.get(colIndex);
|
|
@@ -126,11 +105,10 @@ export function HtmlTable(_ref) {
|
|
|
126
105
|
positionStyle.position = 'sticky';
|
|
127
106
|
positionStyle.right = hozInfo.stickyRightMap.get(colIndex) + (typeof stickyRightOffset === 'number' ? stickyRightOffset : 0);
|
|
128
107
|
}
|
|
129
|
-
|
|
130
108
|
return /*#__PURE__*/React.createElement('td', _extends(_extends(_extends(_extends({
|
|
131
109
|
key: colIndex
|
|
132
110
|
}, cellProps), {
|
|
133
|
-
className: cx(Classes.tableCell, cellProps.className, (
|
|
111
|
+
className: cx(Classes.tableCell, cellProps.className, _defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({}, Classes.first, colIndex === 0), Classes.last, colIndex + colSpan === fullFlatCount), Classes.lockLeft, colIndex < leftFlatCount || tbodyPosition === 'left'), Classes.lockRight, colIndex >= fullFlatCount - rightFlatCount), Classes.rowSpan, rowSpan > 1))
|
|
134
112
|
}), hasSpan ? {
|
|
135
113
|
colSpan: colSpan,
|
|
136
114
|
rowSpan: rowSpan
|