index.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. var _typeof = require("@babel/runtime/helpers/typeof");
  4. Object.defineProperty(exports, "__esModule", {
  5. value: true
  6. });
  7. exports.default = void 0;
  8. exports.genVirtualTable = genVirtualTable;
  9. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  10. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  11. var _classnames = _interopRequireDefault(require("classnames"));
  12. var _rcUtil = require("rc-util");
  13. var React = _interopRequireWildcard(require("react"));
  14. var _constant = require("../constant");
  15. var _TableContext = require("../context/TableContext");
  16. var _Table = _interopRequireWildcard(require("../Table"));
  17. var _BodyGrid = _interopRequireDefault(require("./BodyGrid"));
  18. var _context = require("./context");
  19. var _get = _interopRequireDefault(require("rc-util/lib/utils/get"));
  20. function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
  21. function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
  22. var renderBody = function renderBody(rawData, props) {
  23. var ref = props.ref,
  24. onScroll = props.onScroll;
  25. return /*#__PURE__*/React.createElement(_BodyGrid.default, {
  26. ref: ref,
  27. data: rawData,
  28. onScroll: onScroll
  29. });
  30. };
  31. function VirtualTable(props, ref) {
  32. var data = props.data,
  33. columns = props.columns,
  34. scroll = props.scroll,
  35. sticky = props.sticky,
  36. _props$prefixCls = props.prefixCls,
  37. prefixCls = _props$prefixCls === void 0 ? _Table.DEFAULT_PREFIX : _props$prefixCls,
  38. className = props.className,
  39. listItemHeight = props.listItemHeight,
  40. components = props.components,
  41. onScroll = props.onScroll;
  42. var _ref = scroll || {},
  43. scrollX = _ref.x,
  44. scrollY = _ref.y;
  45. // Fill scrollX
  46. if (typeof scrollX !== 'number') {
  47. if (process.env.NODE_ENV !== 'production') {
  48. (0, _rcUtil.warning)(!scrollX, '`scroll.x` in virtual table must be number.');
  49. }
  50. scrollX = 1;
  51. }
  52. // Fill scrollY
  53. if (typeof scrollY !== 'number') {
  54. scrollY = 500;
  55. if (process.env.NODE_ENV !== 'production') {
  56. (0, _rcUtil.warning)(false, '`scroll.y` in virtual table must be number.');
  57. }
  58. }
  59. var getComponent = (0, _rcUtil.useEvent)(function (path, defaultComponent) {
  60. return (0, _get.default)(components, path) || defaultComponent;
  61. });
  62. // Memo this
  63. var onInternalScroll = (0, _rcUtil.useEvent)(onScroll);
  64. // ========================= Context ==========================
  65. var context = React.useMemo(function () {
  66. return {
  67. sticky: sticky,
  68. scrollY: scrollY,
  69. listItemHeight: listItemHeight,
  70. getComponent: getComponent,
  71. onScroll: onInternalScroll
  72. };
  73. }, [sticky, scrollY, listItemHeight, getComponent, onInternalScroll]);
  74. // ========================== Render ==========================
  75. return /*#__PURE__*/React.createElement(_context.StaticContext.Provider, {
  76. value: context
  77. }, /*#__PURE__*/React.createElement(_Table.default, (0, _extends2.default)({}, props, {
  78. className: (0, _classnames.default)(className, "".concat(prefixCls, "-virtual")),
  79. scroll: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, scroll), {}, {
  80. x: scrollX
  81. }),
  82. components: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, components), {}, {
  83. // fix https://github.com/ant-design/ant-design/issues/48991
  84. body: data !== null && data !== void 0 && data.length ? renderBody : undefined
  85. }),
  86. columns: columns,
  87. internalHooks: _constant.INTERNAL_HOOKS,
  88. tailor: true,
  89. ref: ref
  90. })));
  91. }
  92. var RefVirtualTable = /*#__PURE__*/React.forwardRef(VirtualTable);
  93. if (process.env.NODE_ENV !== 'production') {
  94. RefVirtualTable.displayName = 'VirtualTable';
  95. }
  96. function genVirtualTable(shouldTriggerRender) {
  97. return (0, _TableContext.makeImmutable)(RefVirtualTable, shouldTriggerRender);
  98. }
  99. var _default = exports.default = genVirtualTable();