UNPKG

19.6 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
5var _typeof3 = require("@babel/runtime/helpers/typeof");
6
7Object.defineProperty(exports, "__esModule", {
8 value: true
9});
10exports["default"] = void 0;
11
12var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
14var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
16var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
18var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
19
20var React = _interopRequireWildcard(require("react"));
21
22var _classnames = _interopRequireDefault(require("classnames"));
23
24var _omit = _interopRequireDefault(require("rc-util/lib/omit"));
25
26var _rcTable = _interopRequireWildcard(require("rc-table"));
27
28var _Table = require("rc-table/lib/Table");
29
30var _useColumns = require("rc-table/lib/hooks/useColumns");
31
32var _spin = _interopRequireDefault(require("../spin"));
33
34var _pagination = _interopRequireDefault(require("../pagination"));
35
36var _context = require("../config-provider/context");
37
38var _usePagination3 = _interopRequireWildcard(require("./hooks/usePagination"));
39
40var _useLazyKVMap3 = _interopRequireDefault(require("./hooks/useLazyKVMap"));
41
42var _useSelection3 = _interopRequireWildcard(require("./hooks/useSelection"));
43
44var _useSorter3 = _interopRequireWildcard(require("./hooks/useSorter"));
45
46var _useFilter3 = _interopRequireWildcard(require("./hooks/useFilter"));
47
48var _useTitleColumns3 = _interopRequireDefault(require("./hooks/useTitleColumns"));
49
50var _ExpandIcon = _interopRequireDefault(require("./ExpandIcon"));
51
52var _scrollTo = _interopRequireDefault(require("../_util/scrollTo"));
53
54var _en_US = _interopRequireDefault(require("../locale/en_US"));
55
56var _SizeContext = _interopRequireDefault(require("../config-provider/SizeContext"));
57
58var _Column = _interopRequireDefault(require("./Column"));
59
60var _ColumnGroup = _interopRequireDefault(require("./ColumnGroup"));
61
62var _devWarning = _interopRequireDefault(require("../_util/devWarning"));
63
64var _useBreakpoint = _interopRequireDefault(require("../grid/hooks/useBreakpoint"));
65
66function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
67
68function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
69
70var EMPTY_LIST = [];
71
72function Table(props) {
73 var _classNames3;
74
75 var customizePrefixCls = props.prefixCls,
76 className = props.className,
77 style = props.style,
78 customizeSize = props.size,
79 bordered = props.bordered,
80 customizeDropdownPrefixCls = props.dropdownPrefixCls,
81 dataSource = props.dataSource,
82 pagination = props.pagination,
83 rowSelection = props.rowSelection,
84 rowKey = props.rowKey,
85 rowClassName = props.rowClassName,
86 columns = props.columns,
87 children = props.children,
88 legacyChildrenColumnName = props.childrenColumnName,
89 onChange = props.onChange,
90 getPopupContainer = props.getPopupContainer,
91 loading = props.loading,
92 expandIcon = props.expandIcon,
93 expandable = props.expandable,
94 expandedRowRender = props.expandedRowRender,
95 expandIconColumnIndex = props.expandIconColumnIndex,
96 indentSize = props.indentSize,
97 scroll = props.scroll,
98 sortDirections = props.sortDirections,
99 locale = props.locale,
100 _props$showSorterTool = props.showSorterTooltip,
101 showSorterTooltip = _props$showSorterTool === void 0 ? true : _props$showSorterTool;
102 (0, _devWarning["default"])(!(typeof rowKey === 'function' && rowKey.length > 1), 'Table', '`index` parameter of `rowKey` function is deprecated. There is no guarantee that it will work as expected.');
103 var screens = (0, _useBreakpoint["default"])();
104 var mergedColumns = React.useMemo(function () {
105 var matched = new Set(Object.keys(screens).filter(function (m) {
106 return screens[m];
107 }));
108 return (columns || (0, _useColumns.convertChildrenToColumns)(children)).filter(function (c) {
109 return !c.responsive || c.responsive.some(function (r) {
110 return matched.has(r);
111 });
112 });
113 }, [children, columns, screens]);
114 var tableProps = (0, _omit["default"])(props, ['className', 'style', 'columns']);
115 var size = React.useContext(_SizeContext["default"]);
116
117 var _React$useContext = React.useContext(_context.ConfigContext),
118 _React$useContext$loc = _React$useContext.locale,
119 contextLocale = _React$useContext$loc === void 0 ? _en_US["default"] : _React$useContext$loc,
120 renderEmpty = _React$useContext.renderEmpty,
121 direction = _React$useContext.direction;
122
123 var mergedSize = customizeSize || size;
124 var tableLocale = (0, _extends2["default"])((0, _extends2["default"])({}, contextLocale.Table), locale);
125 var rawData = dataSource || EMPTY_LIST;
126
127 var _React$useContext2 = React.useContext(_context.ConfigContext),
128 getPrefixCls = _React$useContext2.getPrefixCls;
129
130 var prefixCls = getPrefixCls('table', customizePrefixCls);
131 var dropdownPrefixCls = getPrefixCls('dropdown', customizeDropdownPrefixCls);
132 var mergedExpandable = (0, _extends2["default"])({
133 childrenColumnName: legacyChildrenColumnName,
134 expandIconColumnIndex: expandIconColumnIndex
135 }, expandable);
136 var _mergedExpandable$chi = mergedExpandable.childrenColumnName,
137 childrenColumnName = _mergedExpandable$chi === void 0 ? 'children' : _mergedExpandable$chi;
138 var expandType = React.useMemo(function () {
139 if (rawData.some(function (item) {
140 var _a;
141
142 return (_a = item) === null || _a === void 0 ? void 0 : _a[childrenColumnName];
143 })) {
144 return 'nest';
145 }
146
147 if (expandedRowRender || expandable && expandable.expandedRowRender) {
148 return 'row';
149 }
150
151 return null;
152 }, [rawData]);
153 var internalRefs = {
154 body: React.useRef()
155 }; // ============================ RowKey ============================
156
157 var getRowKey = React.useMemo(function () {
158 if (typeof rowKey === 'function') {
159 return rowKey;
160 }
161
162 return function (record) {
163 var _a;
164
165 return (_a = record) === null || _a === void 0 ? void 0 : _a[rowKey];
166 };
167 }, [rowKey]);
168
169 var _useLazyKVMap = (0, _useLazyKVMap3["default"])(rawData, childrenColumnName, getRowKey),
170 _useLazyKVMap2 = (0, _slicedToArray2["default"])(_useLazyKVMap, 1),
171 getRecordByKey = _useLazyKVMap2[0]; // ============================ Events =============================
172
173
174 var changeEventInfo = {};
175
176 var triggerOnChange = function triggerOnChange(info, action) {
177 var reset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
178 var changeInfo = (0, _extends2["default"])((0, _extends2["default"])({}, changeEventInfo), info);
179
180 if (reset) {
181 changeEventInfo.resetPagination(); // Reset event param
182
183 if (changeInfo.pagination.current) {
184 changeInfo.pagination.current = 1;
185 } // Trigger pagination events
186
187
188 if (pagination && pagination.onChange) {
189 pagination.onChange(1, changeInfo.pagination.pageSize);
190 }
191 }
192
193 if (scroll && scroll.scrollToFirstRowOnChange !== false && internalRefs.body.current) {
194 (0, _scrollTo["default"])(0, {
195 getContainer: function getContainer() {
196 return internalRefs.body.current;
197 }
198 });
199 }
200
201 onChange === null || onChange === void 0 ? void 0 : onChange(changeInfo.pagination, changeInfo.filters, changeInfo.sorter, {
202 currentDataSource: (0, _useFilter3.getFilterData)((0, _useSorter3.getSortData)(rawData, changeInfo.sorterStates, childrenColumnName), changeInfo.filterStates),
203 action: action
204 });
205 };
206 /**
207 * Controlled state in `columns` is not a good idea that makes too many code (1000+ line?) to read
208 * state out and then put it back to title render. Move these code into `hooks` but still too
209 * complex. We should provides Table props like `sorter` & `filter` to handle control in next big version.
210 */
211 // ============================ Sorter =============================
212
213
214 var onSorterChange = function onSorterChange(sorter, sorterStates) {
215 triggerOnChange({
216 sorter: sorter,
217 sorterStates: sorterStates
218 }, 'sort', false);
219 };
220
221 var _useSorter = (0, _useSorter3["default"])({
222 prefixCls: prefixCls,
223 mergedColumns: mergedColumns,
224 onSorterChange: onSorterChange,
225 sortDirections: sortDirections || ['ascend', 'descend'],
226 tableLocale: tableLocale,
227 showSorterTooltip: showSorterTooltip
228 }),
229 _useSorter2 = (0, _slicedToArray2["default"])(_useSorter, 4),
230 transformSorterColumns = _useSorter2[0],
231 sortStates = _useSorter2[1],
232 sorterTitleProps = _useSorter2[2],
233 getSorters = _useSorter2[3];
234
235 var sortedData = React.useMemo(function () {
236 return (0, _useSorter3.getSortData)(rawData, sortStates, childrenColumnName);
237 }, [rawData, sortStates]);
238 changeEventInfo.sorter = getSorters();
239 changeEventInfo.sorterStates = sortStates; // ============================ Filter ============================
240
241 var onFilterChange = function onFilterChange(filters, filterStates) {
242 triggerOnChange({
243 filters: filters,
244 filterStates: filterStates
245 }, 'filter', true);
246 };
247
248 var _useFilter = (0, _useFilter3["default"])({
249 prefixCls: prefixCls,
250 locale: tableLocale,
251 dropdownPrefixCls: dropdownPrefixCls,
252 mergedColumns: mergedColumns,
253 onFilterChange: onFilterChange,
254 getPopupContainer: getPopupContainer
255 }),
256 _useFilter2 = (0, _slicedToArray2["default"])(_useFilter, 3),
257 transformFilterColumns = _useFilter2[0],
258 filterStates = _useFilter2[1],
259 getFilters = _useFilter2[2];
260
261 var mergedData = (0, _useFilter3.getFilterData)(sortedData, filterStates);
262 changeEventInfo.filters = getFilters();
263 changeEventInfo.filterStates = filterStates; // ============================ Column ============================
264
265 var columnTitleProps = React.useMemo(function () {
266 return (0, _extends2["default"])({}, sorterTitleProps);
267 }, [sorterTitleProps]);
268
269 var _useTitleColumns = (0, _useTitleColumns3["default"])(columnTitleProps),
270 _useTitleColumns2 = (0, _slicedToArray2["default"])(_useTitleColumns, 1),
271 transformTitleColumns = _useTitleColumns2[0]; // ========================== Pagination ==========================
272
273
274 var onPaginationChange = function onPaginationChange(current, pageSize) {
275 triggerOnChange({
276 pagination: (0, _extends2["default"])((0, _extends2["default"])({}, changeEventInfo.pagination), {
277 current: current,
278 pageSize: pageSize
279 })
280 }, 'paginate');
281 };
282
283 var _usePagination = (0, _usePagination3["default"])(mergedData.length, pagination, onPaginationChange),
284 _usePagination2 = (0, _slicedToArray2["default"])(_usePagination, 2),
285 mergedPagination = _usePagination2[0],
286 resetPagination = _usePagination2[1];
287
288 changeEventInfo.pagination = pagination === false ? {} : (0, _usePagination3.getPaginationParam)(pagination, mergedPagination);
289 changeEventInfo.resetPagination = resetPagination; // ============================= Data =============================
290
291 var pageData = React.useMemo(function () {
292 if (pagination === false || !mergedPagination.pageSize) {
293 return mergedData;
294 }
295
296 var _mergedPagination$cur = mergedPagination.current,
297 current = _mergedPagination$cur === void 0 ? 1 : _mergedPagination$cur,
298 total = mergedPagination.total,
299 _mergedPagination$pag = mergedPagination.pageSize,
300 pageSize = _mergedPagination$pag === void 0 ? _usePagination3.DEFAULT_PAGE_SIZE : _mergedPagination$pag;
301 (0, _devWarning["default"])(current > 0, 'Table', '`current` should be positive number.'); // Dynamic table data
302
303 if (mergedData.length < total) {
304 if (mergedData.length > pageSize) {
305 (0, _devWarning["default"])(false, 'Table', '`dataSource` length is less than `pagination.total` but large than `pagination.pageSize`. Please make sure your config correct data with async mode.');
306 return mergedData.slice((current - 1) * pageSize, current * pageSize);
307 }
308
309 return mergedData;
310 }
311
312 return mergedData.slice((current - 1) * pageSize, current * pageSize);
313 }, [!!pagination, mergedData, mergedPagination && mergedPagination.current, mergedPagination && mergedPagination.pageSize, mergedPagination && mergedPagination.total]); // ========================== Selections ==========================
314
315 var _useSelection = (0, _useSelection3["default"])(rowSelection, {
316 prefixCls: prefixCls,
317 data: mergedData,
318 pageData: pageData,
319 getRowKey: getRowKey,
320 getRecordByKey: getRecordByKey,
321 expandType: expandType,
322 childrenColumnName: childrenColumnName,
323 locale: tableLocale,
324 expandIconColumnIndex: mergedExpandable.expandIconColumnIndex,
325 getPopupContainer: getPopupContainer
326 }),
327 _useSelection2 = (0, _slicedToArray2["default"])(_useSelection, 2),
328 transformSelectionColumns = _useSelection2[0],
329 selectedKeySet = _useSelection2[1];
330
331 var internalRowClassName = function internalRowClassName(record, index, indent) {
332 var mergedRowClassName;
333
334 if (typeof rowClassName === 'function') {
335 mergedRowClassName = (0, _classnames["default"])(rowClassName(record, index, indent));
336 } else {
337 mergedRowClassName = (0, _classnames["default"])(rowClassName);
338 }
339
340 return (0, _classnames["default"])((0, _defineProperty2["default"])({}, "".concat(prefixCls, "-row-selected"), selectedKeySet.has(getRowKey(record, index))), mergedRowClassName);
341 }; // ========================== Expandable ==========================
342 // Pass origin render status into `rc-table`, this can be removed when refactor with `rc-table`
343
344
345 mergedExpandable.__PARENT_RENDER_ICON__ = mergedExpandable.expandIcon; // Customize expandable icon
346
347 mergedExpandable.expandIcon = mergedExpandable.expandIcon || expandIcon || (0, _ExpandIcon["default"])(tableLocale); // Adjust expand icon index, no overwrite expandIconColumnIndex if set.
348
349 if (expandType === 'nest' && mergedExpandable.expandIconColumnIndex === undefined) {
350 mergedExpandable.expandIconColumnIndex = rowSelection ? 1 : 0;
351 } else if (mergedExpandable.expandIconColumnIndex > 0 && rowSelection) {
352 mergedExpandable.expandIconColumnIndex -= 1;
353 } // Indent size
354
355
356 if (typeof mergedExpandable.indentSize !== 'number') {
357 mergedExpandable.indentSize = typeof indentSize === 'number' ? indentSize : 15;
358 } // ============================ Render ============================
359
360
361 var transformColumns = React.useCallback(function (innerColumns) {
362 return transformTitleColumns(transformSelectionColumns(transformFilterColumns(transformSorterColumns(innerColumns))));
363 }, [transformSorterColumns, transformFilterColumns, transformSelectionColumns]);
364 var topPaginationNode;
365 var bottomPaginationNode;
366
367 if (pagination !== false && (mergedPagination === null || mergedPagination === void 0 ? void 0 : mergedPagination.total)) {
368 var paginationSize;
369
370 if (mergedPagination.size) {
371 paginationSize = mergedPagination.size;
372 } else {
373 paginationSize = mergedSize === 'small' || mergedSize === 'middle' ? 'small' : undefined;
374 }
375
376 var renderPagination = function renderPagination(position) {
377 return /*#__PURE__*/React.createElement(_pagination["default"], (0, _extends2["default"])({
378 className: "".concat(prefixCls, "-pagination ").concat(prefixCls, "-pagination-").concat(position)
379 }, mergedPagination, {
380 size: paginationSize
381 }));
382 };
383
384 var defaultPosition = direction === 'rtl' ? 'left' : 'right';
385 var position = mergedPagination.position;
386
387 if (position !== null && Array.isArray(position)) {
388 var topPos = position.find(function (p) {
389 return p.indexOf('top') !== -1;
390 });
391 var bottomPos = position.find(function (p) {
392 return p.indexOf('bottom') !== -1;
393 });
394 var isDisable = position.every(function (p) {
395 return "".concat(p) === 'none';
396 });
397
398 if (!topPos && !bottomPos && !isDisable) {
399 bottomPaginationNode = renderPagination(defaultPosition);
400 }
401
402 if (topPos) {
403 topPaginationNode = renderPagination(topPos.toLowerCase().replace('top', ''));
404 }
405
406 if (bottomPos) {
407 bottomPaginationNode = renderPagination(bottomPos.toLowerCase().replace('bottom', ''));
408 }
409 } else {
410 bottomPaginationNode = renderPagination(defaultPosition);
411 }
412 } // >>>>>>>>> Spinning
413
414
415 var spinProps;
416
417 if (typeof loading === 'boolean') {
418 spinProps = {
419 spinning: loading
420 };
421 } else if ((0, _typeof2["default"])(loading) === 'object') {
422 spinProps = (0, _extends2["default"])({
423 spinning: true
424 }, loading);
425 }
426
427 var wrapperClassNames = (0, _classnames["default"])("".concat(prefixCls, "-wrapper"), (0, _defineProperty2["default"])({}, "".concat(prefixCls, "-wrapper-rtl"), direction === 'rtl'), className);
428 return /*#__PURE__*/React.createElement("div", {
429 className: wrapperClassNames,
430 style: style
431 }, /*#__PURE__*/React.createElement(_spin["default"], (0, _extends2["default"])({
432 spinning: false
433 }, spinProps), topPaginationNode, /*#__PURE__*/React.createElement(_rcTable["default"], (0, _extends2["default"])({}, tableProps, {
434 columns: mergedColumns,
435 direction: direction,
436 expandable: mergedExpandable,
437 prefixCls: prefixCls,
438 className: (0, _classnames["default"])((_classNames3 = {}, (0, _defineProperty2["default"])(_classNames3, "".concat(prefixCls, "-middle"), mergedSize === 'middle'), (0, _defineProperty2["default"])(_classNames3, "".concat(prefixCls, "-small"), mergedSize === 'small'), (0, _defineProperty2["default"])(_classNames3, "".concat(prefixCls, "-bordered"), bordered), (0, _defineProperty2["default"])(_classNames3, "".concat(prefixCls, "-empty"), rawData.length === 0), _classNames3)),
439 data: pageData,
440 rowKey: getRowKey,
441 rowClassName: internalRowClassName,
442 emptyText: locale && locale.emptyText || renderEmpty('Table') // Internal
443 ,
444 internalHooks: _Table.INTERNAL_HOOKS,
445 internalRefs: internalRefs,
446 transformColumns: transformColumns
447 })), bottomPaginationNode));
448}
449
450Table.defaultProps = {
451 rowKey: 'key'
452};
453Table.SELECTION_ALL = _useSelection3.SELECTION_ALL;
454Table.SELECTION_INVERT = _useSelection3.SELECTION_INVERT;
455Table.SELECTION_NONE = _useSelection3.SELECTION_NONE;
456Table.Column = _Column["default"];
457Table.ColumnGroup = _ColumnGroup["default"];
458Table.Summary = _rcTable.Summary;
459var _default = Table;
460exports["default"] = _default;
\No newline at end of file