Filler.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. "use strict";
  2. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  3. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  4. Object.defineProperty(exports, "__esModule", {
  5. value: true
  6. });
  7. exports.default = void 0;
  8. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  9. var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
  10. var _objectSpread3 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  11. var React = _interopRequireWildcard(require("react"));
  12. var _rcResizeObserver = _interopRequireDefault(require("rc-resize-observer"));
  13. var _classnames = _interopRequireDefault(require("classnames"));
  14. /**
  15. * Fill component to provided the scroll content real height.
  16. */
  17. var Filler = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
  18. var height = _ref.height,
  19. offsetY = _ref.offsetY,
  20. offsetX = _ref.offsetX,
  21. children = _ref.children,
  22. prefixCls = _ref.prefixCls,
  23. onInnerResize = _ref.onInnerResize,
  24. innerProps = _ref.innerProps,
  25. rtl = _ref.rtl,
  26. extra = _ref.extra;
  27. var outerStyle = {};
  28. var innerStyle = {
  29. display: 'flex',
  30. flexDirection: 'column'
  31. };
  32. if (offsetY !== undefined) {
  33. // Not set `width` since this will break `sticky: right`
  34. outerStyle = {
  35. height: height,
  36. position: 'relative',
  37. overflow: 'hidden'
  38. };
  39. innerStyle = (0, _objectSpread3.default)((0, _objectSpread3.default)({}, innerStyle), {}, (0, _defineProperty2.default)((0, _defineProperty2.default)((0, _defineProperty2.default)((0, _defineProperty2.default)((0, _defineProperty2.default)({
  40. transform: "translateY(".concat(offsetY, "px)")
  41. }, rtl ? 'marginRight' : 'marginLeft', -offsetX), "position", 'absolute'), "left", 0), "right", 0), "top", 0));
  42. }
  43. return /*#__PURE__*/React.createElement("div", {
  44. style: outerStyle
  45. }, /*#__PURE__*/React.createElement(_rcResizeObserver.default, {
  46. onResize: function onResize(_ref2) {
  47. var offsetHeight = _ref2.offsetHeight;
  48. if (offsetHeight && onInnerResize) {
  49. onInnerResize();
  50. }
  51. }
  52. }, /*#__PURE__*/React.createElement("div", (0, _extends2.default)({
  53. style: innerStyle,
  54. className: (0, _classnames.default)((0, _defineProperty2.default)({}, "".concat(prefixCls, "-holder-inner"), prefixCls)),
  55. ref: ref
  56. }, innerProps), children, extra)));
  57. });
  58. Filler.displayName = 'Filler';
  59. var _default = exports.default = Filler;