@sheinx/base 3.6.4-beta.8 → 3.7.0-beta.10
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/cjs/popover/popover.d.ts +1 -1
- package/cjs/popover/popover.d.ts.map +1 -1
- package/cjs/popover/popover.js +10 -8
- package/cjs/popover/popover.type.d.ts +6 -0
- package/cjs/popover/popover.type.d.ts.map +1 -1
- package/cjs/sticky/sticky.d.ts.map +1 -1
- package/cjs/sticky/sticky.js +6 -3
- package/cjs/sticky/sticky.type.d.ts +2 -2
- package/cjs/sticky/sticky.type.d.ts.map +1 -1
- package/cjs/table/table.d.ts.map +1 -1
- package/cjs/table/table.js +156 -98
- package/cjs/table/table.type.d.ts +15 -2
- package/cjs/table/table.type.d.ts.map +1 -1
- package/cjs/table/tbody.d.ts +1 -1
- package/cjs/table/tbody.d.ts.map +1 -1
- package/cjs/table/tbody.js +28 -10
- package/cjs/table/tbody.type.d.ts +2 -3
- package/cjs/table/tbody.type.d.ts.map +1 -1
- package/cjs/table/td.d.ts +21 -0
- package/cjs/table/td.d.ts.map +1 -0
- package/cjs/table/td.js +74 -0
- package/cjs/table/tfoot.d.ts.map +1 -1
- package/cjs/table/tfoot.js +0 -10
- package/cjs/table/tfoot.type.d.ts +0 -2
- package/cjs/table/tfoot.type.d.ts.map +1 -1
- package/cjs/table/thead.d.ts.map +1 -1
- package/cjs/table/thead.js +7 -19
- package/cjs/table/thead.type.d.ts +0 -2
- package/cjs/table/thead.type.d.ts.map +1 -1
- package/cjs/table/tr.d.ts +1 -2
- package/cjs/table/tr.d.ts.map +1 -1
- package/cjs/table/tr.js +33 -29
- package/cjs/tabs/tabs.d.ts.map +1 -1
- package/cjs/tabs/tabs.js +10 -1
- package/cjs/tabs/tabs.type.d.ts +6 -0
- package/cjs/tabs/tabs.type.d.ts.map +1 -1
- package/cjs/tag/tag.d.ts.map +1 -1
- package/cjs/tag/tag.js +1 -1
- package/cjs/tooltip/tooltip.d.ts.map +1 -1
- package/cjs/tooltip/tooltip.js +10 -2
- package/cjs/virtual-scroll/scroll-table.d.ts +28 -0
- package/cjs/virtual-scroll/scroll-table.d.ts.map +1 -0
- package/cjs/virtual-scroll/scroll-table.js +155 -0
- package/cjs/virtual-scroll/scroll.d.ts.map +1 -1
- package/cjs/virtual-scroll/scroll.js +4 -4
- package/esm/popover/popover.d.ts +1 -1
- package/esm/popover/popover.d.ts.map +1 -1
- package/esm/popover/popover.js +10 -8
- package/esm/popover/popover.type.d.ts +6 -0
- package/esm/popover/popover.type.d.ts.map +1 -1
- package/esm/sticky/sticky.d.ts.map +1 -1
- package/esm/sticky/sticky.js +6 -3
- package/esm/sticky/sticky.type.d.ts +2 -2
- package/esm/sticky/sticky.type.d.ts.map +1 -1
- package/esm/table/table.d.ts.map +1 -1
- package/esm/table/table.js +157 -99
- package/esm/table/table.type.d.ts +15 -2
- package/esm/table/table.type.d.ts.map +1 -1
- package/esm/table/tbody.d.ts +1 -1
- package/esm/table/tbody.d.ts.map +1 -1
- package/esm/table/tbody.js +29 -11
- package/esm/table/tbody.type.d.ts +2 -3
- package/esm/table/tbody.type.d.ts.map +1 -1
- package/esm/table/td.d.ts +21 -0
- package/esm/table/td.d.ts.map +1 -0
- package/esm/table/td.js +66 -0
- package/esm/table/tfoot.d.ts.map +1 -1
- package/esm/table/tfoot.js +0 -10
- package/esm/table/tfoot.type.d.ts +0 -2
- package/esm/table/tfoot.type.d.ts.map +1 -1
- package/esm/table/thead.d.ts.map +1 -1
- package/esm/table/thead.js +7 -19
- package/esm/table/thead.type.d.ts +0 -2
- package/esm/table/thead.type.d.ts.map +1 -1
- package/esm/table/tr.d.ts +1 -2
- package/esm/table/tr.d.ts.map +1 -1
- package/esm/table/tr.js +33 -29
- package/esm/tabs/tabs.d.ts.map +1 -1
- package/esm/tabs/tabs.js +10 -1
- package/esm/tabs/tabs.type.d.ts +6 -0
- package/esm/tabs/tabs.type.d.ts.map +1 -1
- package/esm/tag/tag.d.ts.map +1 -1
- package/esm/tag/tag.js +1 -1
- package/esm/tooltip/tooltip.d.ts.map +1 -1
- package/esm/tooltip/tooltip.js +11 -3
- package/esm/virtual-scroll/scroll-table.d.ts +28 -0
- package/esm/virtual-scroll/scroll-table.d.ts.map +1 -0
- package/esm/virtual-scroll/scroll-table.js +148 -0
- package/esm/virtual-scroll/scroll.d.ts.map +1 -1
- package/esm/virtual-scroll/scroll.js +4 -4
- package/package.json +2 -2
package/esm/table/table.js
CHANGED
|
@@ -1,14 +1,20 @@
|
|
|
1
1
|
var _excluded = ["data"];
|
|
2
2
|
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
|
3
3
|
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
|
4
|
-
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
5
4
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
6
5
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
7
6
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
8
7
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
|
|
9
8
|
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
10
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
11
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
12
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
13
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
14
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
15
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
16
|
+
import React, { useEffect, useMemo, useRef, useState } from 'react';
|
|
17
|
+
import Scroll from "../virtual-scroll/scroll-table";
|
|
12
18
|
import classNames from 'classnames';
|
|
13
19
|
import Spin from "../spin";
|
|
14
20
|
import Pagination from "../pagination";
|
|
@@ -28,19 +34,6 @@ import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
28
34
|
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
29
35
|
var devUseWarning = util.devUseWarning;
|
|
30
36
|
var emptyArr = [];
|
|
31
|
-
var virtualScrollerStyle = {
|
|
32
|
-
flex: 1,
|
|
33
|
-
minWidth: 0,
|
|
34
|
-
minHeight: 0,
|
|
35
|
-
overflow: 'auto',
|
|
36
|
-
width: '100%'
|
|
37
|
-
};
|
|
38
|
-
var scrollWrapperStyle = {
|
|
39
|
-
flex: 1,
|
|
40
|
-
minHeight: 0,
|
|
41
|
-
minWidth: 0,
|
|
42
|
-
display: 'flex'
|
|
43
|
-
};
|
|
44
37
|
var emptyRef = {
|
|
45
38
|
current: null
|
|
46
39
|
};
|
|
@@ -59,18 +52,14 @@ export default (function (props) {
|
|
|
59
52
|
var theadRef = useRef(null);
|
|
60
53
|
var tfootRef = useRef(null);
|
|
61
54
|
var scrollRef = useRef(null);
|
|
62
|
-
var
|
|
55
|
+
var headMirrorScrollRef = useRef(null);
|
|
56
|
+
var bottomMirrorScrollRef = useRef(null);
|
|
63
57
|
var tableRef = useRef(null);
|
|
58
|
+
var _useState = useState(false),
|
|
59
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
60
|
+
scrolling = _useState2[0],
|
|
61
|
+
setScrolling = _useState2[1];
|
|
64
62
|
var browserScrollbarWidth = useScrollbarWidth();
|
|
65
|
-
var emptyStyle = _objectSpread(_objectSpread({}, virtualScrollerStyle), {}, {
|
|
66
|
-
overflow: 'auto hidden',
|
|
67
|
-
position: 'absolute',
|
|
68
|
-
zIndex: 1,
|
|
69
|
-
bottom: 0,
|
|
70
|
-
left: 0,
|
|
71
|
-
right: 0,
|
|
72
|
-
height: browserScrollbarWidth
|
|
73
|
-
});
|
|
74
63
|
if (props.fixed) {
|
|
75
64
|
devUseWarning.deprecated('fixed', 'virtual', 'Table');
|
|
76
65
|
}
|
|
@@ -91,7 +80,9 @@ export default (function (props) {
|
|
|
91
80
|
};
|
|
92
81
|
};
|
|
93
82
|
var _useRef = useRef({
|
|
94
|
-
emptyHeight: 0
|
|
83
|
+
emptyHeight: 0,
|
|
84
|
+
theadAndTfootHeight: 0,
|
|
85
|
+
scrollingTimer: null
|
|
95
86
|
}),
|
|
96
87
|
context = _useRef.current;
|
|
97
88
|
var virtual = ((_props$data = props.data) === null || _props$data === void 0 ? void 0 : _props$data.length) && props.rowsInView !== 0 && (!!props.virtual || props.fixed === 'both' || props.fixed === 'y' || props.fixed === 'auto');
|
|
@@ -140,7 +131,6 @@ export default (function (props) {
|
|
|
140
131
|
floatRight = _useTableLayout.floatRight,
|
|
141
132
|
width = _useTableLayout.width,
|
|
142
133
|
shouldLastColAuto = _useTableLayout.shouldLastColAuto,
|
|
143
|
-
maxScrollLeft = _useTableLayout.maxScrollLeft,
|
|
144
134
|
scrollBarWidth = _useTableLayout.scrollBarWidth,
|
|
145
135
|
scrollWidth = _useTableLayout.scrollWidth,
|
|
146
136
|
resizeFlag = _useTableLayout.resizeFlag;
|
|
@@ -224,6 +214,10 @@ export default (function (props) {
|
|
|
224
214
|
onChange: inputableData.onChange,
|
|
225
215
|
disabled: props.disabled
|
|
226
216
|
});
|
|
217
|
+
useEffect(function () {
|
|
218
|
+
var _theadRef$current, _tfootRef$current;
|
|
219
|
+
context.theadAndTfootHeight = ((theadRef === null || theadRef === void 0 || (_theadRef$current = theadRef.current) === null || _theadRef$current === void 0 ? void 0 : _theadRef$current.clientHeight) || 0) + (((_tfootRef$current = tfootRef.current) === null || _tfootRef$current === void 0 ? void 0 : _tfootRef$current.clientHeight) || 0);
|
|
220
|
+
}, [theadRef.current, tfootRef.current]);
|
|
227
221
|
var virtualInfo = useTableVirtual({
|
|
228
222
|
disabled: !virtual,
|
|
229
223
|
data: treeData,
|
|
@@ -234,27 +228,26 @@ export default (function (props) {
|
|
|
234
228
|
scrollRef: scrollRef,
|
|
235
229
|
innerRef: tbodyRef,
|
|
236
230
|
scrollLeft: props.scrollLeft,
|
|
237
|
-
isRtl: isRtl
|
|
231
|
+
isRtl: isRtl,
|
|
232
|
+
theadAndTfootHeight: context.theadAndTfootHeight
|
|
238
233
|
});
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
var max = scrollEl.scrollWidth - scrollEl.clientWidth;
|
|
245
|
-
var scrollLeft = scrollEl.scrollLeft + e.deltaX;
|
|
246
|
-
if (scrollLeft === scrollEl.scrollLeft) {
|
|
247
|
-
return;
|
|
248
|
-
}
|
|
249
|
-
e.preventDefault();
|
|
250
|
-
scrollEl.scrollLeft = Math.min(Math.max(scrollLeft, 0), max);
|
|
234
|
+
var syncHeaderScroll = usePersistFn(function (left) {
|
|
235
|
+
var _theadRef$current2;
|
|
236
|
+
if (props.hideHeader || !props.sticky) return;
|
|
237
|
+
if (!(theadRef !== null && theadRef !== void 0 && (_theadRef$current2 = theadRef.current) !== null && _theadRef$current2 !== void 0 && _theadRef$current2.parentElement)) return;
|
|
238
|
+
theadRef.current.parentElement.scrollLeft = left;
|
|
251
239
|
});
|
|
240
|
+
|
|
241
|
+
// 简单表格的滚动事件
|
|
252
242
|
var handleBodyScroll = usePersistFn(function (e) {
|
|
253
243
|
var target = e.currentTarget;
|
|
254
244
|
if (!target) return;
|
|
255
245
|
layoutFunc.checkFloat();
|
|
256
|
-
if (
|
|
257
|
-
|
|
246
|
+
if (headMirrorScrollRef.current) {
|
|
247
|
+
headMirrorScrollRef.current.scrollLeft = target.scrollLeft;
|
|
248
|
+
}
|
|
249
|
+
if (bottomMirrorScrollRef.current) {
|
|
250
|
+
bottomMirrorScrollRef.current.scrollLeft = target.scrollLeft;
|
|
258
251
|
}
|
|
259
252
|
if (props.onScroll && typeof props.onScroll === 'function') {
|
|
260
253
|
var maxWidth = target.scrollWidth - target.clientWidth;
|
|
@@ -263,22 +256,36 @@ export default (function (props) {
|
|
|
263
256
|
var y = Math.min(target.scrollTop / maxHeight, 1);
|
|
264
257
|
props.onScroll(x, y, target.scrollLeft, target.scrollTop);
|
|
265
258
|
}
|
|
259
|
+
syncHeaderScroll(target.scrollLeft);
|
|
266
260
|
});
|
|
261
|
+
|
|
262
|
+
// 虚拟表格的滚动事件
|
|
267
263
|
var handleVirtualScroll = usePersistFn(function (info) {
|
|
268
264
|
virtualInfo.handleScroll(info);
|
|
269
265
|
layoutFunc.checkFloat();
|
|
270
|
-
if (
|
|
271
|
-
|
|
266
|
+
if (headMirrorScrollRef.current) {
|
|
267
|
+
headMirrorScrollRef.current.scrollLeft = info.scrollLeft;
|
|
268
|
+
}
|
|
269
|
+
if (bottomMirrorScrollRef.current) {
|
|
270
|
+
bottomMirrorScrollRef.current.scrollLeft = info.scrollLeft;
|
|
272
271
|
}
|
|
273
272
|
if (props.onScroll && typeof props.onScroll === 'function') {
|
|
274
273
|
props.onScroll(info.x, info.y, info.scrollLeft, info.scrollTop);
|
|
275
274
|
}
|
|
275
|
+
syncHeaderScroll(info.scrollLeft);
|
|
276
|
+
if (context.scrollingTimer) {
|
|
277
|
+
clearTimeout(context.scrollingTimer);
|
|
278
|
+
}
|
|
279
|
+
setScrolling(true);
|
|
280
|
+
context.scrollingTimer = setTimeout(function () {
|
|
281
|
+
setScrolling(false);
|
|
282
|
+
}, 100);
|
|
276
283
|
});
|
|
277
284
|
var renderEmpty = function renderEmpty() {
|
|
278
285
|
var _props$data2;
|
|
279
286
|
if (!((_props$data2 = props.data) !== null && _props$data2 !== void 0 && _props$data2.length) || filteredData !== undefined && filteredData.length === 0) {
|
|
280
287
|
return /*#__PURE__*/_jsx("div", {
|
|
281
|
-
className: tableClasses === null || tableClasses === void 0 ? void 0 : tableClasses.emptyWrapper,
|
|
288
|
+
className: classNames(tableClasses === null || tableClasses === void 0 ? void 0 : tableClasses.emptyWrapper, isScrollX && (tableClasses === null || tableClasses === void 0 ? void 0 : tableClasses.emptyNoBorder)),
|
|
282
289
|
ref: function ref(el) {
|
|
283
290
|
context.emptyHeight = (el === null || el === void 0 ? void 0 : el.clientHeight) || 0;
|
|
284
291
|
},
|
|
@@ -325,7 +332,8 @@ export default (function (props) {
|
|
|
325
332
|
bodyScrollWidth: scrollWidth,
|
|
326
333
|
resizeFlag: resizeFlag,
|
|
327
334
|
treeCheckAll: props.treeCheckAll,
|
|
328
|
-
onCellClick: props.onCellClick
|
|
335
|
+
onCellClick: props.onCellClick,
|
|
336
|
+
shouldCellUpdate: props.shouldCellUpdate
|
|
329
337
|
};
|
|
330
338
|
var headCommonProps = {
|
|
331
339
|
disabled: props.disabled,
|
|
@@ -356,7 +364,6 @@ export default (function (props) {
|
|
|
356
364
|
jssStyle: props.jssStyle,
|
|
357
365
|
colgroup: colgroup
|
|
358
366
|
};
|
|
359
|
-
var fixRightNum = (isRtl ? -1 * maxScrollLeft : maxScrollLeft) - virtualInfo.innerLeft;
|
|
360
367
|
var StickyWrapper = props.sticky ? Sticky : React.Fragment;
|
|
361
368
|
var sticky = _typeof(props.sticky) === 'object' ? props.sticky : {
|
|
362
369
|
top: 0
|
|
@@ -369,8 +376,8 @@ export default (function (props) {
|
|
|
369
376
|
parent: tableRef === null || tableRef === void 0 ? void 0 : tableRef.current
|
|
370
377
|
};
|
|
371
378
|
var isRenderVirtualTable = virtual || props.sticky || !((_props$data3 = props.data) !== null && _props$data3 !== void 0 && _props$data3.length);
|
|
372
|
-
var headWrapperClass = classNames(tableClasses === null || tableClasses === void 0 ? void 0 : tableClasses.headWrapper
|
|
373
|
-
var footWrapperClass = classNames(tableClasses === null || tableClasses === void 0 ? void 0 : tableClasses.footWrapper
|
|
379
|
+
var headWrapperClass = classNames(tableClasses === null || tableClasses === void 0 ? void 0 : tableClasses.headWrapper);
|
|
380
|
+
var footWrapperClass = classNames(tableClasses === null || tableClasses === void 0 ? void 0 : tableClasses.footWrapper);
|
|
374
381
|
var renderHeadMirrorScroller = function renderHeadMirrorScroller() {
|
|
375
382
|
var _scrollRef$current, _scrollRef$current2, _scrollRef$current3;
|
|
376
383
|
if (!props.showTopScrollbar) return null;
|
|
@@ -386,7 +393,7 @@ export default (function (props) {
|
|
|
386
393
|
});
|
|
387
394
|
return /*#__PURE__*/_jsx(StickyWrapper, _objectSpread(_objectSpread({}, props.sticky ? scrollerStickyProps : {}), {}, {
|
|
388
395
|
children: /*#__PURE__*/_jsx("div", {
|
|
389
|
-
className: tableClasses === null || tableClasses === void 0 ? void 0 : tableClasses.
|
|
396
|
+
className: tableClasses === null || tableClasses === void 0 ? void 0 : tableClasses.mirrorScroller,
|
|
390
397
|
style: {
|
|
391
398
|
height: browserScrollbarWidth,
|
|
392
399
|
width: mirrorScrollRefWidth
|
|
@@ -397,7 +404,7 @@ export default (function (props) {
|
|
|
397
404
|
scrollRef.current.scrollLeft = target.scrollLeft;
|
|
398
405
|
}
|
|
399
406
|
},
|
|
400
|
-
ref:
|
|
407
|
+
ref: headMirrorScrollRef,
|
|
401
408
|
children: /*#__PURE__*/_jsx("div", {
|
|
402
409
|
style: {
|
|
403
410
|
width: scrollRef === null || scrollRef === void 0 || (_scrollRef$current3 = scrollRef.current) === null || _scrollRef$current3 === void 0 ? void 0 : _scrollRef$current3.scrollWidth,
|
|
@@ -407,61 +414,103 @@ export default (function (props) {
|
|
|
407
414
|
})
|
|
408
415
|
}));
|
|
409
416
|
};
|
|
417
|
+
var renderBottomMirrorScroller = function renderBottomMirrorScroller() {
|
|
418
|
+
var _scrollRef$current4, _scrollRef$current5, _scrollRef$current6;
|
|
419
|
+
if (!props.showBottomScrollbar) return null;
|
|
420
|
+
var scrollRefWidth = (scrollRef === null || scrollRef === void 0 || (_scrollRef$current4 = scrollRef.current) === null || _scrollRef$current4 === void 0 ? void 0 : _scrollRef$current4.clientWidth) || 0;
|
|
421
|
+
var scrollRefScrollWidth = (scrollRef === null || scrollRef === void 0 || (_scrollRef$current5 = scrollRef.current) === null || _scrollRef$current5 === void 0 ? void 0 : _scrollRef$current5.scrollWidth) || 0;
|
|
422
|
+
var mirrorScrollRefWidth = scrollRefWidth + scrollBarWidth;
|
|
423
|
+
var showScroll = scrollRefScrollWidth > scrollRefWidth;
|
|
424
|
+
// 开启了双滚,但是没有滚动条,不显示
|
|
425
|
+
if (!scrollRefWidth || !mirrorScrollRefWidth || !showScroll) return null;
|
|
426
|
+
var options = props.showBottomScrollbar === true ? {} : props.showBottomScrollbar;
|
|
427
|
+
var scrollerStickyProps = {
|
|
428
|
+
scrollContainer: options.scrollContainer || document.body,
|
|
429
|
+
bottom: options.bottom || 0,
|
|
430
|
+
zIndex: options.zIndex || defaultZIndex + 1,
|
|
431
|
+
parent: tableRef === null || tableRef === void 0 ? void 0 : tableRef.current
|
|
432
|
+
};
|
|
433
|
+
return /*#__PURE__*/_jsx(Sticky, _objectSpread(_objectSpread({}, scrollerStickyProps), {}, {
|
|
434
|
+
children: /*#__PURE__*/_jsx("div", {
|
|
435
|
+
className: tableClasses === null || tableClasses === void 0 ? void 0 : tableClasses.mirrorScroller,
|
|
436
|
+
style: {
|
|
437
|
+
height: browserScrollbarWidth,
|
|
438
|
+
width: mirrorScrollRefWidth,
|
|
439
|
+
marginTop: -browserScrollbarWidth
|
|
440
|
+
},
|
|
441
|
+
onScroll: function onScroll(e) {
|
|
442
|
+
var target = e.currentTarget;
|
|
443
|
+
if (scrollRef !== null && scrollRef !== void 0 && scrollRef.current && scrollRef.current.scrollLeft !== target.scrollLeft) {
|
|
444
|
+
scrollRef.current.scrollLeft = target.scrollLeft;
|
|
445
|
+
}
|
|
446
|
+
},
|
|
447
|
+
ref: bottomMirrorScrollRef,
|
|
448
|
+
children: /*#__PURE__*/_jsx("div", {
|
|
449
|
+
style: {
|
|
450
|
+
width: scrollRef === null || scrollRef === void 0 || (_scrollRef$current6 = scrollRef.current) === null || _scrollRef$current6 === void 0 ? void 0 : _scrollRef$current6.scrollWidth,
|
|
451
|
+
height: 1
|
|
452
|
+
}
|
|
453
|
+
})
|
|
454
|
+
})
|
|
455
|
+
}));
|
|
456
|
+
};
|
|
457
|
+
var $headTable = /*#__PURE__*/_jsxs("table", {
|
|
458
|
+
style: {
|
|
459
|
+
width: width
|
|
460
|
+
},
|
|
461
|
+
ref: theadRef,
|
|
462
|
+
children: [Group, /*#__PURE__*/_jsx(Thead, _objectSpread({}, headCommonProps))]
|
|
463
|
+
});
|
|
410
464
|
if (isRenderVirtualTable) {
|
|
411
465
|
var _props$data4;
|
|
412
466
|
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
413
|
-
children: [renderHeadMirrorScroller(), !props.hideHeader && /*#__PURE__*/_jsx(StickyWrapper, _objectSpread(_objectSpread({},
|
|
467
|
+
children: [renderHeadMirrorScroller(), !props.hideHeader && props.sticky && /*#__PURE__*/_jsx(StickyWrapper, _objectSpread(_objectSpread({}, stickyProps), {}, {
|
|
414
468
|
children: /*#__PURE__*/_jsx("div", {
|
|
415
469
|
className: headWrapperClass,
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
},
|
|
421
|
-
ref: theadRef,
|
|
422
|
-
children: [Group, /*#__PURE__*/_jsx(Thead, _objectSpread(_objectSpread({}, headCommonProps), {}, {
|
|
423
|
-
fixLeftNum: virtualInfo.innerLeft,
|
|
424
|
-
fixRightNum: fixRightNum
|
|
425
|
-
}))]
|
|
426
|
-
})
|
|
470
|
+
style: {
|
|
471
|
+
overflow: 'hidden'
|
|
472
|
+
},
|
|
473
|
+
children: $headTable
|
|
427
474
|
})
|
|
428
|
-
})), /*#__PURE__*/
|
|
429
|
-
style:
|
|
430
|
-
|
|
475
|
+
})), /*#__PURE__*/_jsxs(Scroll, {
|
|
476
|
+
style: {
|
|
477
|
+
display: 'flex',
|
|
478
|
+
minWidth: 0,
|
|
479
|
+
minHeight: 0,
|
|
480
|
+
flex: 1
|
|
481
|
+
},
|
|
431
482
|
wrapperRef: scrollRef,
|
|
432
483
|
scrollWidth: width || 1,
|
|
433
484
|
scrollHeight: virtual ? virtualInfo.scrollHeight : tbodyHeight,
|
|
434
485
|
onScroll: handleVirtualScroll,
|
|
435
486
|
defaultHeight: context.emptyHeight,
|
|
436
487
|
isScrollY: isScrollY,
|
|
437
|
-
children: /*#__PURE__*/
|
|
488
|
+
children: [!props.hideHeader && !props.sticky && /*#__PURE__*/_jsx("div", {
|
|
489
|
+
className: headWrapperClass,
|
|
490
|
+
children: $headTable
|
|
491
|
+
}), !!((_props$data4 = props.data) !== null && _props$data4 !== void 0 && _props$data4.length) && /*#__PURE__*/_jsxs("table", {
|
|
438
492
|
style: {
|
|
439
493
|
width: width,
|
|
440
|
-
transform: virtualInfo.
|
|
494
|
+
transform: virtualInfo.translateStyle
|
|
441
495
|
},
|
|
442
496
|
ref: tbodyRef,
|
|
443
497
|
children: [Group, /*#__PURE__*/_jsx(Tbody, _objectSpread(_objectSpread({}, bodyCommonProps), {}, {
|
|
444
498
|
currentIndex: virtualInfo.startIndex,
|
|
445
499
|
data: virtualInfo.data,
|
|
446
500
|
setRowHeight: virtualInfo.setRowHeight,
|
|
447
|
-
|
|
448
|
-
fixRightNum: fixRightNum
|
|
449
|
-
}))]
|
|
450
|
-
})
|
|
451
|
-
}), renderEmpty(), showFoot ? /*#__PURE__*/_jsx("div", {
|
|
452
|
-
className: footWrapperClass,
|
|
453
|
-
children: /*#__PURE__*/_jsxs("table", {
|
|
454
|
-
style: {
|
|
455
|
-
width: width,
|
|
456
|
-
transform: "translate3d(-".concat(virtualInfo.innerLeft, "px, 0, 0)")
|
|
457
|
-
},
|
|
458
|
-
ref: tfootRef,
|
|
459
|
-
children: [Group, /*#__PURE__*/_jsx(Tfoot, _objectSpread(_objectSpread({}, footCommonProps), {}, {
|
|
460
|
-
fixLeftNum: virtualInfo.innerLeft,
|
|
461
|
-
fixRightNum: fixRightNum
|
|
501
|
+
scrolling: scrolling
|
|
462
502
|
}))]
|
|
463
|
-
})
|
|
464
|
-
|
|
503
|
+
}), showFoot ? /*#__PURE__*/_jsx("div", {
|
|
504
|
+
className: footWrapperClass,
|
|
505
|
+
children: /*#__PURE__*/_jsxs("table", {
|
|
506
|
+
style: {
|
|
507
|
+
width: width
|
|
508
|
+
},
|
|
509
|
+
ref: tfootRef,
|
|
510
|
+
children: [Group, /*#__PURE__*/_jsx(Tfoot, _objectSpread({}, footCommonProps))]
|
|
511
|
+
})
|
|
512
|
+
}) : null, renderEmpty()]
|
|
513
|
+
}), renderBottomMirrorScroller()]
|
|
465
514
|
});
|
|
466
515
|
}
|
|
467
516
|
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
@@ -478,7 +527,7 @@ export default (function (props) {
|
|
|
478
527
|
children: renderEmpty()
|
|
479
528
|
}) : /*#__PURE__*/_jsx(Tbody, _objectSpread({}, bodyCommonProps)), /*#__PURE__*/_jsx(Tfoot, _objectSpread({}, footCommonProps))]
|
|
480
529
|
})
|
|
481
|
-
})]
|
|
530
|
+
}), renderBottomMirrorScroller()]
|
|
482
531
|
});
|
|
483
532
|
};
|
|
484
533
|
var renderLoading = function renderLoading() {
|
|
@@ -498,27 +547,36 @@ export default (function (props) {
|
|
|
498
547
|
align: "right"
|
|
499
548
|
}, pagination), paginationInfo));
|
|
500
549
|
};
|
|
550
|
+
|
|
551
|
+
// handle head and foot scroll
|
|
552
|
+
var handleHeaderWheel = usePersistFn(function (e) {
|
|
553
|
+
var _theadRef$current3;
|
|
554
|
+
var scrollEl = scrollRef.current;
|
|
555
|
+
if (!scrollEl) return;
|
|
556
|
+
if (!(theadRef !== null && theadRef !== void 0 && (_theadRef$current3 = theadRef.current) !== null && _theadRef$current3 !== void 0 && _theadRef$current3.parentElement)) return;
|
|
557
|
+
var max = scrollEl.scrollWidth - scrollEl.clientWidth;
|
|
558
|
+
var scrollLeft = scrollEl.scrollLeft + e.deltaX;
|
|
559
|
+
if (scrollLeft === scrollEl.scrollLeft) {
|
|
560
|
+
return;
|
|
561
|
+
}
|
|
562
|
+
e.preventDefault();
|
|
563
|
+
var left = Math.min(Math.max(scrollLeft, 0), max);
|
|
564
|
+
scrollEl.scrollLeft = left;
|
|
565
|
+
theadRef.current.parentElement.scrollLeft = left;
|
|
566
|
+
});
|
|
501
567
|
useEffect(function () {
|
|
502
568
|
// 绑定 wheel 事件
|
|
503
|
-
if (theadRef.current && theadRef.current.parentElement) {
|
|
569
|
+
if (props.sticky && theadRef.current && theadRef.current.parentElement) {
|
|
504
570
|
theadRef.current.parentElement.addEventListener('wheel', handleHeaderWheel, {
|
|
505
571
|
passive: false
|
|
506
572
|
});
|
|
507
573
|
}
|
|
508
|
-
if (tfootRef.current && tfootRef.current.parentElement) {
|
|
509
|
-
tfootRef.current.parentElement.addEventListener('wheel', handleHeaderWheel, {
|
|
510
|
-
passive: false
|
|
511
|
-
});
|
|
512
|
-
}
|
|
513
574
|
return function () {
|
|
514
|
-
if (theadRef.current && theadRef.current.parentElement) {
|
|
575
|
+
if (props.sticky && theadRef.current && theadRef.current.parentElement) {
|
|
515
576
|
theadRef.current.parentElement.removeEventListener('wheel', handleHeaderWheel);
|
|
516
577
|
}
|
|
517
|
-
if (tfootRef.current && tfootRef.current.parentElement) {
|
|
518
|
-
tfootRef.current.parentElement.removeEventListener('wheel', handleHeaderWheel);
|
|
519
|
-
}
|
|
520
578
|
};
|
|
521
|
-
}, [theadRef.current, isScrollY]);
|
|
579
|
+
}, [theadRef.current, props.sticky, isScrollY]);
|
|
522
580
|
var getRenderIndexByData = function getRenderIndexByData(data) {
|
|
523
581
|
var originKey = typeof data === 'string' ? data : util.getKey(props.keygen, data);
|
|
524
582
|
var index = treeData.findIndex(function (item) {
|
|
@@ -554,7 +612,7 @@ export default (function (props) {
|
|
|
554
612
|
});
|
|
555
613
|
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
556
614
|
children: [/*#__PURE__*/_jsx("div", _objectSpread(_objectSpread({
|
|
557
|
-
className: classNames(tableWrapperClass,
|
|
615
|
+
className: classNames(tableWrapperClass, _defineProperty(_defineProperty(_defineProperty({}, tableClasses.sticky, props.sticky), tableClasses.floatLeft, floatLeft), tableClasses.floatRight, floatRight)),
|
|
558
616
|
style: _objectSpread({
|
|
559
617
|
height: defaultHeight
|
|
560
618
|
}, props.style)
|
|
@@ -18,6 +18,7 @@ import { RadioClasses } from '../radio/radio.type';
|
|
|
18
18
|
import { PopoverClasses } from '../popover/popover.type';
|
|
19
19
|
import { TreeClasses } from '../tree/tree.type';
|
|
20
20
|
import { KeygenResult } from '@sheinx/hooks';
|
|
21
|
+
import { StickyProps } from '../sticky';
|
|
21
22
|
export type ListDatum = ReturnType<typeof useListSelect<any, any>>;
|
|
22
23
|
export type UseTreeResult = ReturnType<typeof useTableTree>;
|
|
23
24
|
export interface TableClasses {
|
|
@@ -26,7 +27,6 @@ export interface TableClasses {
|
|
|
26
27
|
small: string;
|
|
27
28
|
large: string;
|
|
28
29
|
default: string;
|
|
29
|
-
scrollY: string;
|
|
30
30
|
floatLeft: string;
|
|
31
31
|
floatRight: string;
|
|
32
32
|
bordered: string;
|
|
@@ -36,11 +36,12 @@ export interface TableClasses {
|
|
|
36
36
|
simple: string;
|
|
37
37
|
striped: string;
|
|
38
38
|
loading: string;
|
|
39
|
-
|
|
39
|
+
mirrorScroller: string;
|
|
40
40
|
headWrapper: string;
|
|
41
41
|
bodyWrapper: string;
|
|
42
42
|
footWrapper: string;
|
|
43
43
|
emptyWrapper: string;
|
|
44
|
+
emptyNoBorder: string;
|
|
44
45
|
cellAlignLeft: string;
|
|
45
46
|
cellAlignRight: string;
|
|
46
47
|
cellAlignCenter: string;
|
|
@@ -333,6 +334,7 @@ export interface TableProps<DataItem, Value> extends Pick<CommonType, 'className
|
|
|
333
334
|
sticky?: boolean | {
|
|
334
335
|
top?: number;
|
|
335
336
|
css?: boolean;
|
|
337
|
+
target?: Element | null;
|
|
336
338
|
};
|
|
337
339
|
/**
|
|
338
340
|
* @en Whether to show the top scroller
|
|
@@ -341,6 +343,13 @@ export interface TableProps<DataItem, Value> extends Pick<CommonType, 'className
|
|
|
341
343
|
* @version 3.4.0
|
|
342
344
|
*/
|
|
343
345
|
showTopScrollbar?: boolean;
|
|
346
|
+
/**
|
|
347
|
+
* @en Whether to show the bottom scroller
|
|
348
|
+
* @cn 是否开启底部自定吸附的滚动条
|
|
349
|
+
* @default false
|
|
350
|
+
* @version 3.7.0
|
|
351
|
+
*/
|
|
352
|
+
showBottomScrollbar?: boolean | BottomScrollbarOption;
|
|
344
353
|
/**
|
|
345
354
|
* @en Table instance (please use with caution: only fixed Table)
|
|
346
355
|
* @cn Table 实例(请谨慎使用:仅虚拟列表支持)
|
|
@@ -352,6 +361,9 @@ export interface TableProps<DataItem, Value> extends Pick<CommonType, 'className
|
|
|
352
361
|
*/
|
|
353
362
|
onRowSelect?: (rows: Value) => void;
|
|
354
363
|
}
|
|
364
|
+
interface BottomScrollbarOption extends Pick<StickyProps, 'scrollContainer' | 'bottom'> {
|
|
365
|
+
zIndex?: number;
|
|
366
|
+
}
|
|
355
367
|
export interface SorterInfo {
|
|
356
368
|
order?: ColumnOrder;
|
|
357
369
|
/**
|
|
@@ -389,4 +401,5 @@ export interface SummaryItem {
|
|
|
389
401
|
* @title TableColumn
|
|
390
402
|
*/
|
|
391
403
|
export type ColumnItem<DataItem> = TableColumnItem<DataItem>;
|
|
404
|
+
export {};
|
|
392
405
|
//# sourceMappingURL=table.type.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"table.type.d.ts","sourceRoot":"","sources":["table.type.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,KAAK,EAAE,UAAU,EAAE,eAAe,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC5F,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"table.type.d.ts","sourceRoot":"","sources":["table.type.ts"],"names":[],"mappings":"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"}
|
package/esm/table/tbody.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { TbodyProps } from './tbody.type';
|
|
2
|
-
declare const _default: (props: TbodyProps) => import("react/jsx-runtime").JSX.Element;
|
|
2
|
+
declare const _default: (props: TbodyProps) => import("react/jsx-runtime").JSX.Element | undefined;
|
|
3
3
|
export default _default;
|
|
4
4
|
//# sourceMappingURL=tbody.d.ts.map
|
package/esm/table/tbody.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tbody.d.ts","sourceRoot":"","sources":["tbody.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;gCAEnB,UAAU;AAAjC,
|
|
1
|
+
{"version":3,"file":"tbody.d.ts","sourceRoot":"","sources":["tbody.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;gCAEnB,UAAU;AAAjC,wBAoGE"}
|
package/esm/table/tbody.js
CHANGED
|
@@ -1,5 +1,12 @@
|
|
|
1
|
+
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
|
2
|
+
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
3
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
4
|
+
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
|
5
|
+
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
|
6
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
7
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
1
8
|
import React from 'react';
|
|
2
|
-
import { useTableRow, useTableExpand, util } from '@sheinx/hooks';
|
|
9
|
+
import { useTableRow, useTableExpand, util, useComponentMemo } from '@sheinx/hooks';
|
|
3
10
|
import Tr from "./tr";
|
|
4
11
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
5
12
|
export default (function (props) {
|
|
@@ -23,7 +30,6 @@ export default (function (props) {
|
|
|
23
30
|
hover: hover
|
|
24
31
|
}),
|
|
25
32
|
rowData = _useTableRow.rowData,
|
|
26
|
-
isCellHover = _useTableRow.isCellHover,
|
|
27
33
|
handleCellHover = _useTableRow.handleCellHover,
|
|
28
34
|
hoverIndex = _useTableRow.hoverIndex,
|
|
29
35
|
rowSelectMergeStartData = _useTableRow.rowSelectMergeStartData;
|
|
@@ -59,11 +65,8 @@ export default (function (props) {
|
|
|
59
65
|
isEmptyTree: props.isEmptyTree,
|
|
60
66
|
treeColumnsName: props.treeColumnsName,
|
|
61
67
|
setRowHeight: props.setRowHeight,
|
|
62
|
-
fixLeftNum: props.fixLeftNum,
|
|
63
|
-
fixRightNum: props.fixRightNum,
|
|
64
68
|
striped: props.striped,
|
|
65
69
|
radio: props.radio,
|
|
66
|
-
isCellHover: isCellHover,
|
|
67
70
|
hover: hover,
|
|
68
71
|
isSelect: props.datum.check(rowSelectMergeStartData[index]),
|
|
69
72
|
handleCellHover: handleCellHover
|
|
@@ -77,12 +80,27 @@ export default (function (props) {
|
|
|
77
80
|
bodyScrollWidth: props.bodyScrollWidth,
|
|
78
81
|
resizeFlag: props.resizeFlag,
|
|
79
82
|
treeCheckAll: props.treeCheckAll,
|
|
80
|
-
onCellClick: props.onCellClick
|
|
83
|
+
onCellClick: props.onCellClick,
|
|
84
|
+
shouldCellUpdate: props.shouldCellUpdate
|
|
81
85
|
}, trRenderKey);
|
|
82
86
|
};
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
87
|
+
var externalDependencies = _typeof(props.shouldCellUpdate) === 'object' && props.shouldCellUpdate.dependencies ? props.shouldCellUpdate.dependencies : [];
|
|
88
|
+
var updateFn = _typeof(props.shouldCellUpdate) === 'object' && 'update' in props.shouldCellUpdate ? props.shouldCellUpdate.update : props.shouldCellUpdate;
|
|
89
|
+
var $tbody = useComponentMemo(function () {
|
|
90
|
+
return /*#__PURE__*/_jsx("tbody", {
|
|
91
|
+
children: (props.data || []).map(function (item, index) {
|
|
92
|
+
return renderRow(item, index);
|
|
93
|
+
})
|
|
94
|
+
});
|
|
95
|
+
}, [props.data, currentIndex].concat(_toConsumableArray(externalDependencies)), updateFn ? function (prev, next) {
|
|
96
|
+
return prev.some(function (_, index) {
|
|
97
|
+
if (index === 0) {
|
|
98
|
+
return prev[index].some(function (item, idx) {
|
|
99
|
+
return updateFn(item, next[index][idx]);
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
return !util.shallowEqual(prev[index], next[index]);
|
|
103
|
+
}) || !props.scrolling;
|
|
104
|
+
} : undefined);
|
|
105
|
+
return $tbody;
|
|
88
106
|
});
|
|
@@ -3,7 +3,7 @@ import { TableProps, ListDatum, UseTreeResult } from './table.type';
|
|
|
3
3
|
import type { TableFormatColumn, OptionalToRequired } from '@sheinx/hooks';
|
|
4
4
|
export type UseColumnsResult = ReturnType<typeof useTableColumns>;
|
|
5
5
|
export type UseTableRowResult = ReturnType<typeof useTableRow>;
|
|
6
|
-
export interface TbodyProps extends Pick<OptionalToRequired<TableProps<any, any>>, 'data' | 'jssStyle' | 'rowClassName' | 'expandKeys' | 'keygen' | 'treeEmptyExpand' | 'expandIcon' | 'treeExpandIcon' | 'loader' | 'striped' | 'radio' | 'onRowClick' | 'rowClickAttr' | 'rowEvents' | 'disabled' | 'hover' | 'treeCheckAll' | 'onCellClick'> {
|
|
6
|
+
export interface TbodyProps extends Pick<OptionalToRequired<TableProps<any, any>>, 'data' | 'jssStyle' | 'rowClassName' | 'expandKeys' | 'keygen' | 'treeEmptyExpand' | 'expandIcon' | 'treeExpandIcon' | 'loader' | 'striped' | 'radio' | 'onRowClick' | 'rowClickAttr' | 'rowEvents' | 'disabled' | 'hover' | 'treeCheckAll' | 'onCellClick' | 'shouldCellUpdate'> {
|
|
7
7
|
columns: TableFormatColumn<any>[];
|
|
8
8
|
data: any[];
|
|
9
9
|
colgroup: (number | string | undefined)[];
|
|
@@ -16,9 +16,8 @@ export interface TbodyProps extends Pick<OptionalToRequired<TableProps<any, any>
|
|
|
16
16
|
isEmptyTree: boolean | undefined;
|
|
17
17
|
treeColumnsName: string | undefined;
|
|
18
18
|
setRowHeight?: (index: number, height: number) => void;
|
|
19
|
-
fixLeftNum?: number;
|
|
20
|
-
fixRightNum?: number;
|
|
21
19
|
bodyScrollWidth?: number;
|
|
22
20
|
resizeFlag?: number;
|
|
21
|
+
scrolling?: boolean;
|
|
23
22
|
}
|
|
24
23
|
//# sourceMappingURL=tbody.type.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tbody.type.d.ts","sourceRoot":"","sources":["tbody.type.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC7D,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AACpE,OAAO,KAAK,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAE3E,MAAM,MAAM,gBAAgB,GAAG,UAAU,CAAC,OAAO,eAAe,CAAC,CAAC;AAClE,MAAM,MAAM,iBAAiB,GAAG,UAAU,CAAC,OAAO,WAAW,CAAC,CAAC;AAE/D,MAAM,WAAW,UACf,SAAQ,IAAI,CACV,kBAAkB,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EACtC,MAAM,GACN,UAAU,GACV,cAAc,GACd,YAAY,GACZ,QAAQ,GACR,iBAAiB,GACjB,YAAY,GACZ,gBAAgB,GAChB,QAAQ,GACR,SAAS,GACT,OAAO,GACP,YAAY,GACZ,cAAc,GACd,WAAW,GACX,UAAU,GACV,OAAO,GACP,cAAc,GACd,aAAa,
|
|
1
|
+
{"version":3,"file":"tbody.type.d.ts","sourceRoot":"","sources":["tbody.type.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC7D,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AACpE,OAAO,KAAK,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAE3E,MAAM,MAAM,gBAAgB,GAAG,UAAU,CAAC,OAAO,eAAe,CAAC,CAAC;AAClE,MAAM,MAAM,iBAAiB,GAAG,UAAU,CAAC,OAAO,WAAW,CAAC,CAAC;AAE/D,MAAM,WAAW,UACf,SAAQ,IAAI,CACV,kBAAkB,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,EACtC,MAAM,GACN,UAAU,GACV,cAAc,GACd,YAAY,GACZ,QAAQ,GACR,iBAAiB,GACjB,YAAY,GACZ,gBAAgB,GAChB,QAAQ,GACR,SAAS,GACT,OAAO,GACP,YAAY,GACZ,cAAc,GACd,WAAW,GACX,UAAU,GACV,OAAO,GACP,cAAc,GACd,aAAa,GACb,kBAAkB,CACrB;IACD,OAAO,EAAE,iBAAiB,CAAC,GAAG,CAAC,EAAE,CAAC;IAClC,IAAI,EAAE,GAAG,EAAE,CAAC;IACZ,QAAQ,EAAE,CAAC,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC,EAAE,CAAC;IAC1C,SAAS,EAAE,OAAO,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,gBAAgB,CAAC,eAAe,CAAC,CAAC;IACjD,KAAK,EAAE,SAAS,CAAC;IACjB,QAAQ,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;IAChC,eAAe,EAAE,aAAa,CAAC,iBAAiB,CAAC,CAAC;IAClD,WAAW,EAAE,OAAO,GAAG,SAAS,CAAC;IACjC,eAAe,EAAE,MAAM,GAAG,SAAS,CAAC;IACpC,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IACvD,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB"}
|