@difizen/libro-virtualized 0.1.2

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.
Files changed (132) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +0 -0
  3. package/es/auto-sizer/auto-sizer.d.ts +56 -0
  4. package/es/auto-sizer/auto-sizer.d.ts.map +1 -0
  5. package/es/auto-sizer/auto-sizer.js +157 -0
  6. package/es/auto-sizer/index.d.ts +3 -0
  7. package/es/auto-sizer/index.d.ts.map +1 -0
  8. package/es/auto-sizer/index.js +2 -0
  9. package/es/cell-measurer/cell-measurer-cache.d.ts +52 -0
  10. package/es/cell-measurer/cell-measurer-cache.d.ts.map +1 -0
  11. package/es/cell-measurer/cell-measurer-cache.js +176 -0
  12. package/es/cell-measurer/cell-measurer.d.ts +39 -0
  13. package/es/cell-measurer/cell-measurer.d.ts.map +1 -0
  14. package/es/cell-measurer/cell-measurer.js +154 -0
  15. package/es/cell-measurer/index.d.ts +5 -0
  16. package/es/cell-measurer/index.d.ts.map +1 -0
  17. package/es/cell-measurer/index.js +4 -0
  18. package/es/cell-measurer/types.d.ts +9 -0
  19. package/es/cell-measurer/types.d.ts.map +1 -0
  20. package/es/cell-measurer/types.js +0 -0
  21. package/es/grid/accessibility-overscanIndices-getter.d.ts +11 -0
  22. package/es/grid/accessibility-overscanIndices-getter.d.ts.map +1 -0
  23. package/es/grid/accessibility-overscanIndices-getter.js +33 -0
  24. package/es/grid/default-cell-range-renderer.d.ts +10 -0
  25. package/es/grid/default-cell-range-renderer.d.ts.map +1 -0
  26. package/es/grid/default-cell-range-renderer.js +135 -0
  27. package/es/grid/default-overscanIndices-getter.d.ts +11 -0
  28. package/es/grid/default-overscanIndices-getter.d.ts.map +1 -0
  29. package/es/grid/default-overscanIndices-getter.js +28 -0
  30. package/es/grid/grid.d.ts +359 -0
  31. package/es/grid/grid.d.ts.map +1 -0
  32. package/es/grid/grid.js +1287 -0
  33. package/es/grid/index.d.ts +6 -0
  34. package/es/grid/index.d.ts.map +1 -0
  35. package/es/grid/index.js +4 -0
  36. package/es/grid/types.d.ts +87 -0
  37. package/es/grid/types.d.ts.map +1 -0
  38. package/es/grid/types.js +1 -0
  39. package/es/grid/utils/calculate-size-and-position-data-and-update-scroll-offset.d.ts +17 -0
  40. package/es/grid/utils/calculate-size-and-position-data-and-update-scroll-offset.d.ts.map +1 -0
  41. package/es/grid/utils/calculate-size-and-position-data-and-update-scroll-offset.js +25 -0
  42. package/es/grid/utils/cell-size-and-position-manager-row.d.ts +97 -0
  43. package/es/grid/utils/cell-size-and-position-manager-row.d.ts.map +1 -0
  44. package/es/grid/utils/cell-size-and-position-manager-row.js +297 -0
  45. package/es/grid/utils/cell-size-and-position-manager.d.ts +85 -0
  46. package/es/grid/utils/cell-size-and-position-manager.d.ts.map +1 -0
  47. package/es/grid/utils/cell-size-and-position-manager.js +268 -0
  48. package/es/grid/utils/max-element-size.d.ts +2 -0
  49. package/es/grid/utils/max-element-size.d.ts.map +1 -0
  50. package/es/grid/utils/max-element-size.js +17 -0
  51. package/es/grid/utils/scaling-cell-size-and-position-manager-row.d.ts +78 -0
  52. package/es/grid/utils/scaling-cell-size-and-position-manager-row.d.ts.map +1 -0
  53. package/es/grid/utils/scaling-cell-size-and-position-manager-row.js +187 -0
  54. package/es/grid/utils/scaling-cell-size-and-position-manager.d.ts +70 -0
  55. package/es/grid/utils/scaling-cell-size-and-position-manager.d.ts.map +1 -0
  56. package/es/grid/utils/scaling-cell-size-and-position-manager.js +187 -0
  57. package/es/grid/utils/update-scroll-index-helper.d.ts +24 -0
  58. package/es/grid/utils/update-scroll-index-helper.d.ts.map +1 -0
  59. package/es/grid/utils/update-scroll-index-helper.js +40 -0
  60. package/es/index.d.ts +5 -0
  61. package/es/index.d.ts.map +1 -0
  62. package/es/index.js +4 -0
  63. package/es/list/index.d.ts +3 -0
  64. package/es/list/index.d.ts.map +1 -0
  65. package/es/list/index.js +1 -0
  66. package/es/list/list.d.ts +109 -0
  67. package/es/list/list.d.ts.map +1 -0
  68. package/es/list/list.js +261 -0
  69. package/es/list/types.d.ts +22 -0
  70. package/es/list/types.d.ts.map +1 -0
  71. package/es/list/types.js +1 -0
  72. package/es/utils/animation-frame.d.ts +7 -0
  73. package/es/utils/animation-frame.d.ts.map +1 -0
  74. package/es/utils/animation-frame.js +20 -0
  75. package/es/utils/create-callback-memoizer.d.ts +5 -0
  76. package/es/utils/create-callback-memoizer.d.ts.map +1 -0
  77. package/es/utils/create-callback-memoizer.js +25 -0
  78. package/es/utils/get-updated-offset-for-index.d.ts +14 -0
  79. package/es/utils/get-updated-offset-for-index.d.ts.map +1 -0
  80. package/es/utils/get-updated-offset-for-index.js +32 -0
  81. package/es/utils/init-cell-metadata.d.ts +13 -0
  82. package/es/utils/init-cell-metadata.d.ts.map +1 -0
  83. package/es/utils/init-cell-metadata.js +32 -0
  84. package/es/utils/request-animation-timeout.d.ts +12 -0
  85. package/es/utils/request-animation-timeout.d.ts.map +1 -0
  86. package/es/utils/request-animation-timeout.js +33 -0
  87. package/es/utils/test-helper.d.ts +5 -0
  88. package/es/utils/test-helper.d.ts.map +1 -0
  89. package/es/utils/test-helper.js +31 -0
  90. package/es/vendor/binary-search-bounds.d.ts +22 -0
  91. package/es/vendor/binary-search-bounds.d.ts.map +1 -0
  92. package/es/vendor/binary-search-bounds.js +198 -0
  93. package/es/vendor/detect-element-resize.d.ts +16 -0
  94. package/es/vendor/detect-element-resize.d.ts.map +1 -0
  95. package/es/vendor/detect-element-resize.js +184 -0
  96. package/es/vendor/interval-tree.d.ts +10 -0
  97. package/es/vendor/interval-tree.d.ts.map +1 -0
  98. package/es/vendor/interval-tree.js +359 -0
  99. package/package.json +59 -0
  100. package/src/auto-sizer/auto-sizer.tsx +187 -0
  101. package/src/auto-sizer/index.ts +4 -0
  102. package/src/cell-measurer/cell-measurer-cache.ts +220 -0
  103. package/src/cell-measurer/cell-measurer.ts +151 -0
  104. package/src/cell-measurer/index.ts +5 -0
  105. package/src/cell-measurer/types.ts +8 -0
  106. package/src/grid/accessibility-overscanIndices-getter.ts +38 -0
  107. package/src/grid/default-cell-range-renderer.ts +166 -0
  108. package/src/grid/default-overscanIndices-getter.ts +32 -0
  109. package/src/grid/grid.tsx +1672 -0
  110. package/src/grid/index.ts +14 -0
  111. package/src/grid/types.ts +112 -0
  112. package/src/grid/utils/calculate-size-and-position-data-and-update-scroll-offset.ts +62 -0
  113. package/src/grid/utils/cell-size-and-position-manager-row.ts +365 -0
  114. package/src/grid/utils/cell-size-and-position-manager.ts +309 -0
  115. package/src/grid/utils/max-element-size.ts +18 -0
  116. package/src/grid/utils/scaling-cell-size-and-position-manager-row.ts +206 -0
  117. package/src/grid/utils/scaling-cell-size-and-position-manager.ts +198 -0
  118. package/src/grid/utils/update-scroll-index-helper.ts +96 -0
  119. package/src/index.spec.ts +10 -0
  120. package/src/index.ts +4 -0
  121. package/src/list/index.ts +2 -0
  122. package/src/list/list.tsx +292 -0
  123. package/src/list/types.ts +25 -0
  124. package/src/utils/animation-frame.ts +38 -0
  125. package/src/utils/create-callback-memoizer.ts +32 -0
  126. package/src/utils/get-updated-offset-for-index.ts +33 -0
  127. package/src/utils/init-cell-metadata.ts +32 -0
  128. package/src/utils/request-animation-timeout.ts +44 -0
  129. package/src/utils/test-helper.ts +20 -0
  130. package/src/vendor/binary-search-bounds.ts +203 -0
  131. package/src/vendor/detect-element-resize.ts +241 -0
  132. package/src/vendor/interval-tree.ts +406 -0
@@ -0,0 +1,1287 @@
1
+ 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); }
2
+ 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; }
3
+ 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; }
4
+ 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; }
5
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
6
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
7
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
8
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
9
+ function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
10
+ function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
11
+ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
12
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
13
+ function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
14
+ function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
15
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
16
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
17
+ /* eslint-disable @typescript-eslint/no-shadow */
18
+
19
+ import classNames from 'classnames';
20
+ import { scrollbarSize } from 'dom-helpers';
21
+ import * as React from 'react';
22
+ import createCallbackMemoizer from "../utils/create-callback-memoizer.js";
23
+ import { cancelAnimationTimeout, requestAnimationTimeout } from "../utils/request-animation-timeout.js";
24
+ import defaultCellRangeRenderer from "./default-cell-range-renderer.js";
25
+ import defaultOverscanIndicesGetter, { SCROLL_DIRECTION_BACKWARD, SCROLL_DIRECTION_FORWARD } from "./default-overscanIndices-getter.js";
26
+ import calculateSizeAndPositionDataAndUpdateScrollOffset from "./utils/calculate-size-and-position-data-and-update-scroll-offset.js";
27
+ import RowScalingCellSizeAndPositionManager from "./utils/scaling-cell-size-and-position-manager-row.js";
28
+ import ScalingCellSizeAndPositionManager from "./utils/scaling-cell-size-and-position-manager.js";
29
+ import updateScrollIndexHelper from "./utils/update-scroll-index-helper.js";
30
+
31
+ /**
32
+ * Specifies the number of milliseconds during which to disable pointer events while a scroll is in progress.
33
+ * This improves performance and makes scrolling smoother.
34
+ */
35
+ import { jsxs as _jsxs } from "react/jsx-runtime";
36
+ export var DEFAULT_SCROLLING_RESET_TIME_INTERVAL = 150;
37
+
38
+ /**
39
+ * Controls whether the Grid updates the DOM element's scrollLeft/scrollTop based on the current state or just observes it.
40
+ * This prevents Grid from interrupting mouse-wheel animations (see issue #2).
41
+ */
42
+ var SCROLL_POSITION_CHANGE_REASONS = {
43
+ OBSERVED: 'observed',
44
+ REQUESTED: 'requested'
45
+ };
46
+ var renderNull = function renderNull() {
47
+ return null;
48
+ };
49
+ // let scrollCache: { direction: number; timestamp: number } | null = null;
50
+ /**
51
+ * Renders tabular data with virtualization along the vertical and horizontal axes.
52
+ * Row heights and column widths must be known ahead of time and specified as properties.
53
+ */
54
+ var Grid = /*#__PURE__*/function (_React$PureComponent) {
55
+ _inherits(Grid, _React$PureComponent);
56
+ var _super = _createSuper(Grid);
57
+ function Grid(props) {
58
+ var _this;
59
+ _classCallCheck(this, Grid);
60
+ _this = _super.call(this, props);
61
+ // Invokes onSectionRendered callback only when start/stop row or column indices change
62
+ _this._onGridRenderedMemoizer = createCallbackMemoizer();
63
+ _this._onScrollMemoizer = createCallbackMemoizer(false);
64
+ _this._deferredInvalidateColumnIndex = null;
65
+ _this._deferredInvalidateRowIndex = null;
66
+ _this._recomputeScrollLeftFlag = false;
67
+ _this._recomputeScrollTopFlag = false;
68
+ _this._horizontalScrollBarSize = 0;
69
+ _this._verticalScrollBarSize = 0;
70
+ _this._scrollbarPresenceChanged = false;
71
+ _this._childrenToDisplay = [];
72
+ _this._renderedColumnStartIndex = 0;
73
+ _this._renderedColumnStopIndex = 0;
74
+ _this._renderedRowStartIndex = 0;
75
+ _this._renderedRowStopIndex = 0;
76
+ _this._styleCache = {};
77
+ _this._cellCache = {};
78
+ _this._debounceScrollEndedCallback = function () {
79
+ _this._disablePointerEventsTimeoutId = null;
80
+ // isScrolling is used to determine if we reset styleCache
81
+ _this.setState({
82
+ isScrolling: false,
83
+ needToResetStyleCache: false
84
+ });
85
+ };
86
+ _this._invokeOnGridRenderedHelper = function () {
87
+ var onSectionRendered = _this.props.onSectionRendered;
88
+ _this._onGridRenderedMemoizer({
89
+ callback: onSectionRendered,
90
+ indices: {
91
+ columnOverscanStartIndex: _this._columnStartIndex,
92
+ columnOverscanStopIndex: _this._columnStopIndex,
93
+ columnStartIndex: _this._renderedColumnStartIndex,
94
+ columnStopIndex: _this._renderedColumnStopIndex,
95
+ rowOverscanStartIndex: _this._rowStartIndex,
96
+ rowOverscanStopIndex: _this._rowStopIndex,
97
+ rowStartIndex: _this._renderedRowStartIndex,
98
+ rowStopIndex: _this._renderedRowStopIndex
99
+ }
100
+ });
101
+ };
102
+ _this._setScrollingContainerRef = function (ref) {
103
+ _this._scrollingContainer = ref;
104
+ };
105
+ _this._onScroll = function (event) {
106
+ // In certain edge-cases React dispatches an onScroll event with an invalid target.scrollLeft / target.scrollTop.
107
+ // This invalid event can be detected by comparing event.target to this component's scrollable DOM element.
108
+ // See issue #404 for more information.
109
+ if (event.target === _this._scrollingContainer) {
110
+ _this.handleScrollEvent(event.target);
111
+ }
112
+ };
113
+ var columnSizeAndPositionManager = new ScalingCellSizeAndPositionManager({
114
+ cellCount: props.columnCount,
115
+ cellSizeGetter: function cellSizeGetter(params) {
116
+ return Grid._wrapSizeGetter(props.columnWidth)(params);
117
+ },
118
+ estimatedCellSize: Grid._getEstimatedColumnSize(props)
119
+ });
120
+ var rowSizeAndPositionManager = new RowScalingCellSizeAndPositionManager({
121
+ cellCount: props.rowCount,
122
+ cellSizeGetter: function cellSizeGetter(params) {
123
+ return Grid._wrapSizeGetter(props.rowHeight)(params);
124
+ },
125
+ estimatedCellSize: Grid._getEstimatedRowSize(props),
126
+ cellsHeight: props.cellsHeight,
127
+ editorAreaHeight: props.editorAreaHeight,
128
+ totalSize: props.totalSize,
129
+ editorsOffset: props.editorsOffset
130
+ });
131
+ _this.state = {
132
+ instanceProps: {
133
+ columnSizeAndPositionManager: columnSizeAndPositionManager,
134
+ rowSizeAndPositionManager: rowSizeAndPositionManager,
135
+ prevColumnWidth: props.columnWidth,
136
+ prevRowHeight: props.rowHeight,
137
+ prevColumnCount: props.columnCount,
138
+ prevRowCount: props.rowCount,
139
+ prevIsScrolling: props.isScrolling === true,
140
+ prevScrollToColumn: props.scrollToColumn,
141
+ prevScrollToRow: props.scrollToRow,
142
+ prevScrollLeft: props.scrollLeft,
143
+ prevScrollTop: props.scrollTop,
144
+ scrollbarSize: 0,
145
+ scrollbarSizeMeasured: false,
146
+ cellsHeight: props.cellsHeight,
147
+ noEditorArea: props.noEditorArea,
148
+ editorAreaHeight: props.editorAreaHeight,
149
+ totalSize: props.totalSize,
150
+ editorsOffset: props.editorsOffset
151
+ },
152
+ isScrolling: false,
153
+ scrollDirectionHorizontal: SCROLL_DIRECTION_FORWARD,
154
+ scrollDirectionVertical: SCROLL_DIRECTION_FORWARD,
155
+ scrollLeft: props.scrollLeft || 0,
156
+ scrollTop: props.scrollTop || 0,
157
+ scrollPositionChangeReason: null,
158
+ needToResetStyleCache: false
159
+ };
160
+ if (props.scrollToRow > 0) {
161
+ _this._initialScrollTop = _this._getCalculatedScrollTop(props, _this.state);
162
+ }
163
+ if (props.scrollToColumn > 0) {
164
+ _this._initialScrollLeft = _this._getCalculatedScrollLeft(props, _this.state);
165
+ }
166
+ return _this;
167
+ }
168
+
169
+ /**
170
+ * Gets offsets for a given cell and alignment.
171
+ */
172
+ _createClass(Grid, [{
173
+ key: "getOffsetForCell",
174
+ value: function getOffsetForCell() {
175
+ var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
176
+ _ref$alignment = _ref.alignment,
177
+ alignment = _ref$alignment === void 0 ? this.props.scrollToAlignment : _ref$alignment,
178
+ _ref$columnIndex = _ref.columnIndex,
179
+ columnIndex = _ref$columnIndex === void 0 ? this.props.scrollToColumn : _ref$columnIndex,
180
+ _ref$rowIndex = _ref.rowIndex,
181
+ rowIndex = _ref$rowIndex === void 0 ? this.props.scrollToRow : _ref$rowIndex;
182
+ var offsetProps = _objectSpread(_objectSpread({}, this.props), {}, {
183
+ scrollToAlignment: alignment,
184
+ scrollToColumn: columnIndex,
185
+ scrollToRow: rowIndex
186
+ });
187
+ return {
188
+ scrollLeft: this._getCalculatedScrollLeft(offsetProps),
189
+ scrollTop: this._getCalculatedScrollTop(offsetProps)
190
+ };
191
+ }
192
+
193
+ /**
194
+ * Gets estimated total rows' height.
195
+ */
196
+ }, {
197
+ key: "getTotalRowsHeight",
198
+ value: function getTotalRowsHeight() {
199
+ return this.state.instanceProps.rowSizeAndPositionManager.getTotalSize();
200
+ }
201
+
202
+ /**
203
+ * Gets estimated total columns' width.
204
+ */
205
+ }, {
206
+ key: "getTotalColumnsWidth",
207
+ value: function getTotalColumnsWidth() {
208
+ return this.state.instanceProps.columnSizeAndPositionManager.getTotalSize();
209
+ }
210
+
211
+ /**
212
+ * This method handles a scroll event originating from an external scroll control.
213
+ * It's an advanced method and should probably not be used unless you're implementing a custom scroll-bar solution.
214
+ */
215
+ }, {
216
+ key: "handleScrollEvent",
217
+ value: function handleScrollEvent(_ref2) {
218
+ var _ref2$scrollLeft = _ref2.scrollLeft,
219
+ scrollLeftParam = _ref2$scrollLeft === void 0 ? 0 : _ref2$scrollLeft,
220
+ _ref2$scrollTop = _ref2.scrollTop,
221
+ scrollTopParam = _ref2$scrollTop === void 0 ? 0 : _ref2$scrollTop;
222
+ // On iOS, we can arrive at negative offsets by swiping past the start.
223
+ // To prevent flicker here, we make playing in the negative offset zone cause nothing to happen.
224
+ if (scrollTopParam < 0) {
225
+ return;
226
+ }
227
+
228
+ // Prevent pointer events from interrupting a smooth scroll
229
+ this._debounceScrollEnded();
230
+ var _this$props = this.props,
231
+ autoHeight = _this$props.autoHeight,
232
+ autoWidth = _this$props.autoWidth,
233
+ height = _this$props.height,
234
+ width = _this$props.width;
235
+ var instanceProps = this.state.instanceProps;
236
+
237
+ // When this component is shrunk drastically, React dispatches a series of back-to-back scroll events,
238
+ // Gradually converging on a scrollTop that is within the bounds of the new, smaller height.
239
+ // This causes a series of rapid renders that is slow for long lists.
240
+ // We can avoid that by doing some simple bounds checking to ensure that scroll offsets never exceed their bounds.
241
+ var scrollbarSize = instanceProps.scrollbarSize;
242
+ var totalRowsHeight = instanceProps.rowSizeAndPositionManager.getTotalSize();
243
+ var totalColumnsWidth = instanceProps.columnSizeAndPositionManager.getTotalSize();
244
+ var scrollLeft = Math.min(Math.max(0, totalColumnsWidth - width + scrollbarSize), scrollLeftParam);
245
+ var scrollTop = Math.min(Math.max(0, totalRowsHeight - height + scrollbarSize), scrollTopParam);
246
+
247
+ // Certain devices (like Apple touchpad) rapid-fire duplicate events.
248
+ // Don't force a re-render if this is the case.
249
+ // The mouse may move faster then the animation frame does.
250
+ // Use requestAnimationFrame to avoid over-updating.
251
+ if (this.state.scrollLeft !== scrollLeft || this.state.scrollTop !== scrollTop) {
252
+ // Track scrolling direction so we can more efficiently overscan rows to reduce empty space around the edges while scrolling.
253
+ // Don't change direction for an axis unless scroll offset has changed.
254
+ var scrollDirectionHorizontal = scrollLeft !== this.state.scrollLeft ? scrollLeft > this.state.scrollLeft ? SCROLL_DIRECTION_FORWARD : SCROLL_DIRECTION_BACKWARD : this.state.scrollDirectionHorizontal;
255
+ var scrollDirectionVertical = scrollTop !== this.state.scrollTop ? scrollTop > this.state.scrollTop ? SCROLL_DIRECTION_FORWARD : SCROLL_DIRECTION_BACKWARD : this.state.scrollDirectionVertical;
256
+
257
+ // if (
258
+ // scrollCache &&
259
+ // // scrollCache.direction !== scrollDirectionVertical &&
260
+ // Date.now() - scrollCache.timestamp < 150
261
+ // ) {
262
+ // return;
263
+ // }
264
+
265
+ // // 更新缓存
266
+ // scrollCache = {
267
+ // timestamp: Date.now(),
268
+ // direction: scrollDirectionVertical,
269
+ // };
270
+
271
+ var newState = {
272
+ isScrolling: true,
273
+ scrollDirectionHorizontal: scrollDirectionHorizontal,
274
+ scrollDirectionVertical: scrollDirectionVertical,
275
+ scrollPositionChangeReason: SCROLL_POSITION_CHANGE_REASONS.OBSERVED
276
+ };
277
+ if (!autoHeight) {
278
+ newState.scrollTop = scrollTop;
279
+ }
280
+ if (!autoWidth) {
281
+ newState.scrollLeft = scrollLeft;
282
+ }
283
+ newState.needToResetStyleCache = false;
284
+ this.setState(newState);
285
+ }
286
+ this._invokeOnScrollMemoizer({
287
+ scrollLeft: scrollLeft,
288
+ scrollTop: scrollTop,
289
+ totalColumnsWidth: totalColumnsWidth,
290
+ totalRowsHeight: totalRowsHeight
291
+ });
292
+ }
293
+
294
+ /**
295
+ * Invalidate Grid size and recompute visible cells.
296
+ * This is a deferred wrapper for recomputeGridSize().
297
+ * It sets a flag to be evaluated on cDM/cDU to avoid unnecessary renders.
298
+ * This method is intended for advanced use-cases like CellMeasurer.
299
+ */
300
+ // @TODO (bvaughn) Add automated test coverage for this.
301
+ }, {
302
+ key: "invalidateCellSizeAfterRender",
303
+ value: function invalidateCellSizeAfterRender(_ref3) {
304
+ var columnIndex = _ref3.columnIndex,
305
+ rowIndex = _ref3.rowIndex;
306
+ this._deferredInvalidateColumnIndex = typeof this._deferredInvalidateColumnIndex === 'number' ? Math.min(this._deferredInvalidateColumnIndex, columnIndex) : columnIndex;
307
+ this._deferredInvalidateRowIndex = typeof this._deferredInvalidateRowIndex === 'number' ? Math.min(this._deferredInvalidateRowIndex, rowIndex) : rowIndex;
308
+ }
309
+
310
+ /**
311
+ * Pre-measure all columns and rows in a Grid.
312
+ * Typically cells are only measured as needed and estimated sizes are used for cells that have not yet been measured.
313
+ * This method ensures that the next call to getTotalSize() returns an exact size (as opposed to just an estimated one).
314
+ */
315
+ }, {
316
+ key: "measureAllCells",
317
+ value: function measureAllCells() {
318
+ var _this$props2 = this.props,
319
+ columnCount = _this$props2.columnCount,
320
+ rowCount = _this$props2.rowCount;
321
+ var instanceProps = this.state.instanceProps;
322
+ instanceProps.columnSizeAndPositionManager.getSizeAndPositionOfCell(columnCount - 1);
323
+ instanceProps.rowSizeAndPositionManager.getSizeAndPositionOfCell(rowCount - 1);
324
+ }
325
+
326
+ /**
327
+ * Forced recompute of row heights and column widths.
328
+ * This function should be called if dynamic column or row sizes have changed but nothing else has.
329
+ * Since Grid only receives :columnCount and :rowCount it has no way of detecting when the underlying data changes.
330
+ */
331
+ }, {
332
+ key: "recomputeGridSize",
333
+ value: function recomputeGridSize() {
334
+ var _ref4 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
335
+ columnIndex: 0,
336
+ rowIndex: 0
337
+ },
338
+ _ref4$columnIndex = _ref4.columnIndex,
339
+ columnIndex = _ref4$columnIndex === void 0 ? 0 : _ref4$columnIndex,
340
+ _ref4$rowIndex = _ref4.rowIndex,
341
+ rowIndex = _ref4$rowIndex === void 0 ? 0 : _ref4$rowIndex;
342
+ var _this$props3 = this.props,
343
+ scrollToColumn = _this$props3.scrollToColumn,
344
+ scrollToRow = _this$props3.scrollToRow;
345
+ var instanceProps = this.state.instanceProps;
346
+ instanceProps.columnSizeAndPositionManager.resetCell(columnIndex);
347
+ instanceProps.rowSizeAndPositionManager.resetCell(rowIndex);
348
+
349
+ // Cell sizes may be determined by a function property.
350
+ // In this case the cDU handler can't know if they changed.
351
+ // Store this flag to let the next cDU pass know it needs to recompute the scroll offset.
352
+ this._recomputeScrollLeftFlag = scrollToColumn >= 0 && (this.state.scrollDirectionHorizontal === SCROLL_DIRECTION_FORWARD ? columnIndex <= scrollToColumn : columnIndex >= scrollToColumn);
353
+ this._recomputeScrollTopFlag = scrollToRow >= 0 && (this.state.scrollDirectionVertical === SCROLL_DIRECTION_FORWARD ? rowIndex <= scrollToRow : rowIndex >= scrollToRow);
354
+
355
+ // Clear cell cache in case we are scrolling;
356
+ // Invalid row heights likely mean invalid cached content as well.
357
+ this._styleCache = {};
358
+ this._cellCache = {};
359
+ this.forceUpdate();
360
+ }
361
+ }, {
362
+ key: "scrollToLine",
363
+ value: function scrollToLine(_ref5) {
364
+ var cellIndex = _ref5.cellIndex,
365
+ lineIndex = _ref5.lineIndex;
366
+ var _this$state$instanceP = this.state.instanceProps.rowSizeAndPositionManager.getSizeAndPositionOfCell(cellIndex),
367
+ offset = _this$state$instanceP.offset;
368
+ var scrollTop = offset + (lineIndex - 1) * 20 + 12; // 上padding 为12
369
+
370
+ this.scrollToPosition({
371
+ scrollTop: scrollTop
372
+ });
373
+ }
374
+
375
+ /**
376
+ * Ensure column and row are visible.
377
+ */
378
+ }, {
379
+ key: "scrollToCell",
380
+ value: function scrollToCell(_ref6) {
381
+ var columnIndex = _ref6.columnIndex,
382
+ rowIndex = _ref6.rowIndex;
383
+ var columnCount = this.props.columnCount;
384
+ var props = this.props;
385
+
386
+ // Don't adjust scroll offset for single-column grids (eg List, Table).
387
+ // This can cause a funky scroll offset because of the vertical scrollbar width.
388
+ if (columnCount > 1 && columnIndex !== undefined) {
389
+ this._updateScrollLeftForScrollToColumn(_objectSpread(_objectSpread({}, props), {}, {
390
+ scrollToColumn: columnIndex
391
+ }));
392
+ }
393
+ if (rowIndex !== undefined) {
394
+ this._updateScrollTopForScrollToRow(_objectSpread(_objectSpread({}, props), {}, {
395
+ scrollToRow: rowIndex
396
+ }));
397
+ }
398
+ }
399
+ }, {
400
+ key: "componentDidMount",
401
+ value: function componentDidMount() {
402
+ var _this$props4 = this.props,
403
+ getScrollbarSize = _this$props4.getScrollbarSize,
404
+ height = _this$props4.height,
405
+ scrollLeft = _this$props4.scrollLeft,
406
+ scrollToColumn = _this$props4.scrollToColumn,
407
+ scrollTop = _this$props4.scrollTop,
408
+ scrollToRow = _this$props4.scrollToRow,
409
+ width = _this$props4.width;
410
+
411
+ // // 创建ResizeObserver实例,当观察的元素尺寸变化时调用回调函数
412
+ // this.resizeObserver = new ResizeObserver(entries => {
413
+ // entries.forEach(entry => {
414
+ // const isVisible = entry.contentRect.width !== 0 && entry.contentRect.height !== 0;
415
+
416
+ // if (isVisible) {
417
+ // console.log(
418
+ // 'output Container width, height',
419
+ // entry.target.clientWidth,
420
+ // entry.target.clientHeight,
421
+ // );
422
+ // }
423
+ // });
424
+ // });
425
+
426
+ var instanceProps = this.state.instanceProps;
427
+
428
+ // Reset initial offsets to be ignored in browser
429
+ this._initialScrollTop = 0;
430
+ this._initialScrollLeft = 0;
431
+
432
+ // If cell sizes have been invalidated (eg we are using CellMeasurer) then reset cached positions.
433
+ // We must do this at the start of the method as we may calculate and update scroll position below.
434
+ this._handleInvalidatedGridSize();
435
+
436
+ // If this component was first rendered server-side, scrollbar size will be undefined.
437
+ // In that event we need to remeasure.
438
+ if (!instanceProps.scrollbarSizeMeasured) {
439
+ this.setState(function (prevState) {
440
+ var stateUpdate = _objectSpread(_objectSpread({}, prevState), {}, {
441
+ needToResetStyleCache: false
442
+ });
443
+ stateUpdate.instanceProps.scrollbarSize = getScrollbarSize();
444
+ stateUpdate.instanceProps.scrollbarSizeMeasured = true;
445
+ return stateUpdate;
446
+ });
447
+ }
448
+ if (typeof scrollLeft === 'number' && scrollLeft >= 0 || typeof scrollTop === 'number' && scrollTop >= 0) {
449
+ var stateUpdate = Grid._getScrollToPositionStateUpdate({
450
+ prevState: this.state,
451
+ scrollLeft: scrollLeft,
452
+ scrollTop: scrollTop
453
+ });
454
+ if (stateUpdate) {
455
+ stateUpdate.needToResetStyleCache = false;
456
+ this.setState(stateUpdate);
457
+ }
458
+ }
459
+
460
+ // refs don't work in `react-test-renderer`
461
+ if (this._scrollingContainer) {
462
+ // setting the ref's scrollLeft and scrollTop.
463
+ // Somehow in MultiGrid the main grid doesn't trigger a update on mount.
464
+ if (this._scrollingContainer.scrollLeft !== this.state.scrollLeft) {
465
+ this._scrollingContainer.scrollLeft = this.state.scrollLeft;
466
+ }
467
+ if (this._scrollingContainer.scrollTop !== this.state.scrollTop) {
468
+ this._scrollingContainer.scrollTop = this.state.scrollTop;
469
+ }
470
+ }
471
+
472
+ // Don't update scroll offset if the size is 0; we don't render any cells in this case.
473
+ // Setting a state may cause us to later thing we've updated the offce when we haven't.
474
+ var sizeIsBiggerThanZero = height > 0 && width > 0;
475
+ if (scrollToColumn >= 0 && sizeIsBiggerThanZero) {
476
+ this._updateScrollLeftForScrollToColumn();
477
+ }
478
+ if (scrollToRow >= 0 && sizeIsBiggerThanZero) {
479
+ this._updateScrollTopForScrollToRow();
480
+ }
481
+
482
+ // Update onRowsRendered callback
483
+ this._invokeOnGridRenderedHelper();
484
+
485
+ // Initialize onScroll callback
486
+ this._invokeOnScrollMemoizer({
487
+ scrollLeft: scrollLeft || 0,
488
+ scrollTop: scrollTop || 0,
489
+ totalColumnsWidth: instanceProps.columnSizeAndPositionManager.getTotalSize(),
490
+ totalRowsHeight: instanceProps.rowSizeAndPositionManager.getTotalSize()
491
+ });
492
+ this._maybeCallOnScrollbarPresenceChange();
493
+ }
494
+
495
+ /**
496
+ * @private
497
+ * This method updates scrollLeft/scrollTop in state for the following conditions:
498
+ * 1) New scroll-to-cell props have been set
499
+ */
500
+ }, {
501
+ key: "componentDidUpdate",
502
+ value: function componentDidUpdate(prevProps, prevState) {
503
+ var _this2 = this;
504
+ var _this$props5 = this.props,
505
+ autoHeight = _this$props5.autoHeight,
506
+ autoWidth = _this$props5.autoWidth,
507
+ columnCount = _this$props5.columnCount,
508
+ height = _this$props5.height,
509
+ rowCount = _this$props5.rowCount,
510
+ scrollToAlignment = _this$props5.scrollToAlignment,
511
+ scrollToColumn = _this$props5.scrollToColumn,
512
+ scrollToRow = _this$props5.scrollToRow,
513
+ width = _this$props5.width;
514
+ var _this$state = this.state,
515
+ scrollLeft = _this$state.scrollLeft,
516
+ scrollPositionChangeReason = _this$state.scrollPositionChangeReason,
517
+ scrollTop = _this$state.scrollTop,
518
+ instanceProps = _this$state.instanceProps;
519
+
520
+ // If cell sizes have been invalidated (eg we are using CellMeasurer) then reset cached positions.
521
+ // We must do this at the start of the method as we may calculate and update scroll position below.
522
+ this._handleInvalidatedGridSize();
523
+
524
+ // Handle edge case where column or row count has only just increased over 0.
525
+ // In this case we may have to restore a previously-specified scroll offset.
526
+ // For more info see bvaughn/react-virtualized/issues/218
527
+ var columnOrRowCountJustIncreasedFromZero = columnCount > 0 && prevProps.columnCount === 0 || rowCount > 0 && prevProps.rowCount === 0;
528
+
529
+ // Make sure requested changes to :scrollLeft or :scrollTop get applied.
530
+ // Assigning to scrollLeft/scrollTop tells the browser to interrupt any running scroll animations,
531
+ // And to discard any pending async changes to the scroll position that may have happened in the meantime (e.g. on a separate scrolling thread).
532
+ // So we only set these when we require an adjustment of the scroll position.
533
+ // See issue #2 for more information.
534
+ if (scrollPositionChangeReason === SCROLL_POSITION_CHANGE_REASONS.REQUESTED) {
535
+ // @TRICKY :autoHeight and :autoWidth properties instructs Grid to leave :scrollTop and :scrollLeft management to an external HOC (eg WindowScroller).
536
+ // In this case we should avoid checking scrollingContainer.scrollTop and scrollingContainer.scrollLeft since it forces layout/flow.
537
+ if (!autoWidth && scrollLeft >= 0 && (scrollLeft !== this._scrollingContainer.scrollLeft || columnOrRowCountJustIncreasedFromZero)) {
538
+ this._scrollingContainer.scrollLeft = scrollLeft;
539
+ }
540
+ if (!autoHeight && scrollTop >= 0 && (scrollTop !== this._scrollingContainer.scrollTop || columnOrRowCountJustIncreasedFromZero)) {
541
+ this._scrollingContainer.scrollTop = scrollTop;
542
+ }
543
+ }
544
+
545
+ // Special case where the previous size was 0:
546
+ // In this case we don't show any windowed cells at all.
547
+ // So we should always recalculate offset afterwards.
548
+ var sizeJustIncreasedFromZero = (prevProps.width === 0 || prevProps.height === 0) && height > 0 && width > 0;
549
+
550
+ // Update scroll offsets if the current :scrollToColumn or :scrollToRow values requires it
551
+ // @TODO Do we also need this check or can the one in componentWillUpdate() suffice?
552
+ if (this._recomputeScrollLeftFlag) {
553
+ this._recomputeScrollLeftFlag = false;
554
+ this._updateScrollLeftForScrollToColumn(this.props);
555
+ } else {
556
+ updateScrollIndexHelper({
557
+ cellSizeAndPositionManager: instanceProps.columnSizeAndPositionManager,
558
+ previousCellsCount: prevProps.columnCount,
559
+ previousCellSize: prevProps.columnWidth,
560
+ previousScrollToAlignment: prevProps.scrollToAlignment,
561
+ previousScrollToIndex: prevProps.scrollToColumn,
562
+ previousSize: prevProps.width,
563
+ scrollOffset: scrollLeft,
564
+ scrollToAlignment: scrollToAlignment,
565
+ scrollToIndex: scrollToColumn,
566
+ size: width,
567
+ sizeJustIncreasedFromZero: sizeJustIncreasedFromZero,
568
+ updateScrollIndexCallback: function updateScrollIndexCallback() {
569
+ return _this2._updateScrollLeftForScrollToColumn(_this2.props);
570
+ }
571
+ });
572
+ }
573
+ if (this._recomputeScrollTopFlag) {
574
+ this._recomputeScrollTopFlag = false;
575
+ this._updateScrollTopForScrollToRow(this.props);
576
+ } else {
577
+ updateScrollIndexHelper({
578
+ cellSizeAndPositionManager: instanceProps.rowSizeAndPositionManager,
579
+ previousCellsCount: prevProps.rowCount,
580
+ previousCellSize: prevProps.rowHeight,
581
+ previousScrollToAlignment: prevProps.scrollToAlignment,
582
+ previousScrollToIndex: prevProps.scrollToRow,
583
+ previousSize: prevProps.height,
584
+ scrollOffset: scrollTop,
585
+ scrollToAlignment: scrollToAlignment,
586
+ scrollToIndex: scrollToRow,
587
+ size: height,
588
+ sizeJustIncreasedFromZero: sizeJustIncreasedFromZero,
589
+ updateScrollIndexCallback: function updateScrollIndexCallback() {
590
+ return _this2._updateScrollTopForScrollToRow(_this2.props);
591
+ }
592
+ });
593
+ }
594
+
595
+ // Update onRowsRendered callback if start/stop indices have changed
596
+ this._invokeOnGridRenderedHelper();
597
+
598
+ // Changes to :scrollLeft or :scrollTop should also notify :onScroll listeners
599
+ if (scrollLeft !== prevState.scrollLeft || scrollTop !== prevState.scrollTop) {
600
+ var totalRowsHeight = instanceProps.rowSizeAndPositionManager.getTotalSize();
601
+ var totalColumnsWidth = instanceProps.columnSizeAndPositionManager.getTotalSize();
602
+ this._invokeOnScrollMemoizer({
603
+ scrollLeft: scrollLeft,
604
+ scrollTop: scrollTop,
605
+ totalColumnsWidth: totalColumnsWidth,
606
+ totalRowsHeight: totalRowsHeight
607
+ });
608
+ }
609
+ this._maybeCallOnScrollbarPresenceChange();
610
+ }
611
+ }, {
612
+ key: "componentWillUnmount",
613
+ value: function componentWillUnmount() {
614
+ if (this._disablePointerEventsTimeoutId) {
615
+ cancelAnimationTimeout(this._disablePointerEventsTimeoutId);
616
+ }
617
+ // 组件卸载时,停止监听
618
+ if (this.resizeObserver) {
619
+ this.resizeObserver.disconnect();
620
+ }
621
+ }
622
+
623
+ /**
624
+ * This method updates scrollLeft/scrollTop in state for the following conditions:
625
+ * 1) Empty content (0 rows or columns)
626
+ * 2) New scroll props overriding the current state
627
+ * 3) Cells-count or cells-size has changed, making previous scroll offsets invalid
628
+ */
629
+ }, {
630
+ key: "render",
631
+ value: function render() {
632
+ var _this$props6 = this.props,
633
+ autoContainerWidth = _this$props6.autoContainerWidth,
634
+ autoHeight = _this$props6.autoHeight,
635
+ autoWidth = _this$props6.autoWidth,
636
+ className = _this$props6.className,
637
+ containerProps = _this$props6.containerProps,
638
+ containerRole = _this$props6.containerRole,
639
+ containerStyle = _this$props6.containerStyle,
640
+ height = _this$props6.height,
641
+ id = _this$props6.id,
642
+ noContentRenderer = _this$props6.noContentRenderer,
643
+ role = _this$props6.role,
644
+ style = _this$props6.style,
645
+ tabIndex = _this$props6.tabIndex,
646
+ width = _this$props6.width,
647
+ noEditorArea = _this$props6.noEditorArea;
648
+ var _this$state2 = this.state,
649
+ instanceProps = _this$state2.instanceProps,
650
+ needToResetStyleCache = _this$state2.needToResetStyleCache;
651
+ var isScrolling = this._isScrolling();
652
+ var gridStyle = {
653
+ boxSizing: 'border-box',
654
+ direction: 'ltr',
655
+ height: autoHeight ? 'auto' : height,
656
+ position: 'relative',
657
+ width: autoWidth ? 'auto' : width,
658
+ WebkitOverflowScrolling: 'touch',
659
+ willChange: 'transform'
660
+ };
661
+ if (needToResetStyleCache) {
662
+ this._styleCache = {};
663
+ }
664
+
665
+ // calculate _styleCache here
666
+ // if state.isScrolling (not from _isScrolling) then reset
667
+ if (!this.state.isScrolling) {
668
+ this._resetStyleCache();
669
+ }
670
+
671
+ // calculate children to render here
672
+ this._calculateChildrenToRender(this.props, this.state);
673
+ var totalColumnsWidth = instanceProps.columnSizeAndPositionManager.getTotalSize();
674
+ var totalRowsHeight = instanceProps.rowSizeAndPositionManager.getTotalSize();
675
+
676
+ // Force browser to hide scrollbars when we know they aren't necessary.
677
+ // Otherwise once scrollbars appear they may not disappear again.
678
+ // For more info see issue #116
679
+ var verticalScrollBarSize = totalRowsHeight > height ? instanceProps.scrollbarSize : 0;
680
+ var horizontalScrollBarSize = totalColumnsWidth > width ? instanceProps.scrollbarSize : 0;
681
+ if (horizontalScrollBarSize !== this._horizontalScrollBarSize || verticalScrollBarSize !== this._verticalScrollBarSize) {
682
+ this._horizontalScrollBarSize = horizontalScrollBarSize;
683
+ this._verticalScrollBarSize = verticalScrollBarSize;
684
+ this._scrollbarPresenceChanged = true;
685
+ }
686
+
687
+ // Also explicitly init styles to 'auto' if scrollbars are required.
688
+ // This works around an obscure edge case where external CSS styles have not yet been loaded,
689
+ // But an initial scroll index of offset is set as an external prop.
690
+ // Without this style, Grid would render the correct range of cells but would NOT update its internal offset.
691
+ // This was originally reported via clauderic/react-infinite-calendar/issues/23
692
+ gridStyle.overflowX = totalColumnsWidth + verticalScrollBarSize <= width ? 'hidden' : 'auto';
693
+ gridStyle.overflowY = totalRowsHeight + horizontalScrollBarSize <= height ? 'hidden' : 'auto';
694
+ var childrenToDisplay = this._childrenToDisplay;
695
+ var showNoContentRenderer = childrenToDisplay.length === 0 && height > 0 && width > 0;
696
+ return /*#__PURE__*/_jsxs("div", _objectSpread(_objectSpread({
697
+ ref: this._setScrollingContainerRef
698
+ }, containerProps), {}, {
699
+ "aria-label": this.props['aria-label'],
700
+ "aria-readonly": this.props['aria-readonly'],
701
+ className: classNames('ReactVirtualized__Grid', className),
702
+ id: id,
703
+ onScroll: this._onScroll,
704
+ role: role,
705
+ style: _objectSpread(_objectSpread({}, gridStyle), style),
706
+ tabIndex: tabIndex,
707
+ children: [/*#__PURE__*/_jsxs("div", {
708
+ className: "ReactVirtualized__Grid__innerScrollContainer",
709
+ role: containerRole,
710
+ style: _objectSpread({
711
+ width: autoContainerWidth ? 'auto' : totalColumnsWidth,
712
+ height: totalRowsHeight,
713
+ maxWidth: totalColumnsWidth,
714
+ maxHeight: totalRowsHeight,
715
+ overflow: 'hidden',
716
+ pointerEvents: isScrolling ? 'none' : undefined,
717
+ position: 'relative'
718
+ }, containerStyle),
719
+ children: [noEditorArea, childrenToDisplay.length > 0 && childrenToDisplay]
720
+ }), showNoContentRenderer && noContentRenderer()]
721
+ }));
722
+ }
723
+
724
+ /* ---------------------------- Helper methods ---------------------------- */
725
+ }, {
726
+ key: "_calculateChildrenToRender",
727
+ value: function _calculateChildrenToRender() {
728
+ var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props;
729
+ var state = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.state;
730
+ var cellRenderer = props.cellRenderer,
731
+ cellRangeRenderer = props.cellRangeRenderer,
732
+ columnCount = props.columnCount,
733
+ deferredMeasurementCache = props.deferredMeasurementCache,
734
+ height = props.height,
735
+ overscanColumnCount = props.overscanColumnCount,
736
+ overscanIndicesGetter = props.overscanIndicesGetter,
737
+ overscanRowCount = props.overscanRowCount,
738
+ rowCount = props.rowCount,
739
+ width = props.width,
740
+ isScrollingOptOut = props.isScrollingOptOut;
741
+ var scrollDirectionHorizontal = state.scrollDirectionHorizontal,
742
+ scrollDirectionVertical = state.scrollDirectionVertical,
743
+ instanceProps = state.instanceProps;
744
+ var scrollTop = this._initialScrollTop > 0 ? this._initialScrollTop : state.scrollTop;
745
+ var scrollLeft = this._initialScrollLeft > 0 ? this._initialScrollLeft : state.scrollLeft;
746
+ var isScrolling = this._isScrolling(props, state);
747
+ this._childrenToDisplay = [];
748
+
749
+ // Render only enough columns and rows to cover the visible area of the grid.
750
+ if (height > 0 && width > 0) {
751
+ var visibleColumnIndices = instanceProps.columnSizeAndPositionManager.getVisibleCellRange({
752
+ containerSize: width,
753
+ offset: scrollLeft
754
+ });
755
+ var visibleRowIndices = instanceProps.rowSizeAndPositionManager.getVisibleCellRange({
756
+ containerSize: height,
757
+ offset: scrollTop
758
+ });
759
+ var horizontalOffsetAdjustment = instanceProps.columnSizeAndPositionManager.getOffsetAdjustment({
760
+ containerSize: width,
761
+ offset: scrollLeft
762
+ });
763
+ var verticalOffsetAdjustment = instanceProps.rowSizeAndPositionManager.getOffsetAdjustment({
764
+ containerSize: height,
765
+ offset: scrollTop
766
+ });
767
+
768
+ // Store for _invokeOnGridRenderedHelper()
769
+ this._renderedColumnStartIndex = visibleColumnIndices.start;
770
+ this._renderedColumnStopIndex = visibleColumnIndices.stop;
771
+ this._renderedRowStartIndex = visibleRowIndices.start;
772
+ this._renderedRowStopIndex = visibleRowIndices.stop;
773
+ var overscanColumnIndices = overscanIndicesGetter({
774
+ direction: 'horizontal',
775
+ cellCount: columnCount,
776
+ overscanCellsCount: overscanColumnCount,
777
+ scrollDirection: scrollDirectionHorizontal,
778
+ startIndex: typeof visibleColumnIndices.start === 'number' ? visibleColumnIndices.start : 0,
779
+ stopIndex: typeof visibleColumnIndices.stop === 'number' ? visibleColumnIndices.stop : -1
780
+ });
781
+ var overscanRowIndices = overscanIndicesGetter({
782
+ direction: 'vertical',
783
+ cellCount: rowCount,
784
+ overscanCellsCount: overscanRowCount,
785
+ scrollDirection: scrollDirectionVertical,
786
+ startIndex: typeof visibleRowIndices.start === 'number' ? visibleRowIndices.start : 0,
787
+ stopIndex: typeof visibleRowIndices.stop === 'number' ? visibleRowIndices.stop : -1
788
+ });
789
+
790
+ // Store for _invokeOnGridRenderedHelper()
791
+ var columnStartIndex = overscanColumnIndices.overscanStartIndex;
792
+ var columnStopIndex = overscanColumnIndices.overscanStopIndex;
793
+ var rowStartIndex = overscanRowIndices.overscanStartIndex;
794
+ var rowStopIndex = overscanRowIndices.overscanStopIndex;
795
+
796
+ // Advanced use-cases (eg CellMeasurer) require batched measurements to determine accurate sizes.
797
+ if (deferredMeasurementCache) {
798
+ // If rows have a dynamic height, scan the rows we are about to render.
799
+ // If any have not yet been measured, then we need to render all columns initially,
800
+ // Because the height of the row is equal to the tallest cell within that row,
801
+ // (And so we can't know the height without measuring all column-cells first).
802
+ if (!deferredMeasurementCache.hasFixedHeight()) {
803
+ for (var rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {
804
+ if (!deferredMeasurementCache.has(rowIndex, 0)) {
805
+ columnStartIndex = 0;
806
+ columnStopIndex = columnCount - 1;
807
+ break;
808
+ }
809
+ }
810
+ }
811
+
812
+ // If columns have a dynamic width, scan the columns we are about to render.
813
+ // If any have not yet been measured, then we need to render all rows initially,
814
+ // Because the width of the column is equal to the widest cell within that column,
815
+ // (And so we can't know the width without measuring all row-cells first).
816
+ if (!deferredMeasurementCache.hasFixedWidth()) {
817
+ for (var columnIndex = columnStartIndex; columnIndex <= columnStopIndex; columnIndex++) {
818
+ if (!deferredMeasurementCache.has(0, columnIndex)) {
819
+ rowStartIndex = 0;
820
+ rowStopIndex = rowCount - 1;
821
+ break;
822
+ }
823
+ }
824
+ }
825
+ }
826
+
827
+ // 计算偏差
828
+ this._childrenToDisplay = cellRangeRenderer({
829
+ cellCache: this._cellCache,
830
+ cellRenderer: cellRenderer,
831
+ columnSizeAndPositionManager: instanceProps.columnSizeAndPositionManager,
832
+ columnStartIndex: columnStartIndex,
833
+ columnStopIndex: columnStopIndex,
834
+ deferredMeasurementCache: deferredMeasurementCache,
835
+ horizontalOffsetAdjustment: horizontalOffsetAdjustment,
836
+ isScrolling: isScrolling,
837
+ isScrollingOptOut: isScrollingOptOut,
838
+ parent: this,
839
+ rowSizeAndPositionManager: instanceProps.rowSizeAndPositionManager,
840
+ rowStartIndex: rowStartIndex,
841
+ rowStopIndex: rowStopIndex,
842
+ scrollLeft: scrollLeft,
843
+ scrollTop: scrollTop,
844
+ styleCache: this._styleCache,
845
+ verticalOffsetAdjustment: verticalOffsetAdjustment,
846
+ visibleColumnIndices: visibleColumnIndices,
847
+ visibleRowIndices: visibleRowIndices
848
+ });
849
+
850
+ // update the indices
851
+ this._columnStartIndex = columnStartIndex;
852
+ this._columnStopIndex = columnStopIndex;
853
+ this._rowStartIndex = rowStartIndex;
854
+ this._rowStopIndex = rowStopIndex;
855
+ }
856
+ }
857
+
858
+ /**
859
+ * Sets an :isScrolling flag for a small window of time.
860
+ * This flag is used to disable pointer events on the scrollable portion of the Grid.
861
+ * This prevents jerky/stuttery mouse-wheel scrolling.
862
+ */
863
+ }, {
864
+ key: "_debounceScrollEnded",
865
+ value: function _debounceScrollEnded() {
866
+ var scrollingResetTimeInterval = this.props.scrollingResetTimeInterval;
867
+ if (this._disablePointerEventsTimeoutId) {
868
+ cancelAnimationTimeout(this._disablePointerEventsTimeoutId);
869
+ }
870
+ this._disablePointerEventsTimeoutId = requestAnimationTimeout(this._debounceScrollEndedCallback, scrollingResetTimeInterval);
871
+ }
872
+ }, {
873
+ key: "_handleInvalidatedGridSize",
874
+ value:
875
+ /**
876
+ * Check for batched CellMeasurer size invalidations.
877
+ * This will occur the first time one or more previously unmeasured cells are rendered.
878
+ */
879
+ function _handleInvalidatedGridSize() {
880
+ if (typeof this._deferredInvalidateColumnIndex === 'number' && typeof this._deferredInvalidateRowIndex === 'number') {
881
+ var columnIndex = this._deferredInvalidateColumnIndex;
882
+ var rowIndex = this._deferredInvalidateRowIndex;
883
+ this._deferredInvalidateColumnIndex = null;
884
+ this._deferredInvalidateRowIndex = null;
885
+ this.recomputeGridSize({
886
+ columnIndex: columnIndex,
887
+ rowIndex: rowIndex
888
+ });
889
+ }
890
+ }
891
+ }, {
892
+ key: "_invokeOnScrollMemoizer",
893
+ value: function _invokeOnScrollMemoizer(_ref7) {
894
+ var _this3 = this;
895
+ var scrollLeft = _ref7.scrollLeft,
896
+ scrollTop = _ref7.scrollTop,
897
+ totalColumnsWidth = _ref7.totalColumnsWidth,
898
+ totalRowsHeight = _ref7.totalRowsHeight;
899
+ this._onScrollMemoizer({
900
+ callback: function callback(_ref8) {
901
+ var scrollLeft = _ref8.scrollLeft,
902
+ scrollTop = _ref8.scrollTop;
903
+ var _this3$props = _this3.props,
904
+ height = _this3$props.height,
905
+ onScroll = _this3$props.onScroll,
906
+ width = _this3$props.width;
907
+ onScroll({
908
+ clientHeight: height,
909
+ clientWidth: width,
910
+ scrollHeight: totalRowsHeight,
911
+ scrollLeft: scrollLeft,
912
+ scrollTop: scrollTop,
913
+ scrollWidth: totalColumnsWidth
914
+ });
915
+ },
916
+ indices: {
917
+ scrollLeft: scrollLeft,
918
+ scrollTop: scrollTop
919
+ }
920
+ });
921
+ }
922
+ }, {
923
+ key: "_isScrolling",
924
+ value: function _isScrolling() {
925
+ var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props;
926
+ var state = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.state;
927
+ // If isScrolling is defined in props, use it to override the value in state
928
+ // This is a performance optimization for WindowScroller + Grid
929
+ return Object.hasOwnProperty.call(props, 'isScrolling') ? Boolean(props.isScrolling) : Boolean(state.isScrolling);
930
+ }
931
+ }, {
932
+ key: "_maybeCallOnScrollbarPresenceChange",
933
+ value: function _maybeCallOnScrollbarPresenceChange() {
934
+ if (this._scrollbarPresenceChanged) {
935
+ var onScrollbarPresenceChange = this.props.onScrollbarPresenceChange;
936
+ this._scrollbarPresenceChanged = false;
937
+ onScrollbarPresenceChange({
938
+ horizontal: this._horizontalScrollBarSize > 0,
939
+ size: this.state.instanceProps.scrollbarSize,
940
+ vertical: this._verticalScrollBarSize > 0
941
+ });
942
+ }
943
+ }
944
+ }, {
945
+ key: "scrollToPosition",
946
+ value:
947
+ /**
948
+ * Scroll to the specified offset(s).
949
+ * Useful for animating position changes.
950
+ */
951
+ function scrollToPosition(_ref9) {
952
+ var scrollLeft = _ref9.scrollLeft,
953
+ scrollTop = _ref9.scrollTop;
954
+ var stateUpdate = Grid._getScrollToPositionStateUpdate({
955
+ prevState: this.state,
956
+ scrollLeft: scrollLeft,
957
+ scrollTop: scrollTop
958
+ });
959
+ if (stateUpdate) {
960
+ stateUpdate.needToResetStyleCache = false;
961
+ this.setState(stateUpdate);
962
+ }
963
+ }
964
+ }, {
965
+ key: "_getCalculatedScrollLeft",
966
+ value: function _getCalculatedScrollLeft() {
967
+ var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props;
968
+ var state = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.state;
969
+ return Grid._getCalculatedScrollLeft(props, state);
970
+ }
971
+ }, {
972
+ key: "_updateScrollLeftForScrollToColumn",
973
+ value: function _updateScrollLeftForScrollToColumn() {
974
+ var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props;
975
+ var state = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.state;
976
+ var stateUpdate = Grid._getScrollLeftForScrollToColumnStateUpdate(props, state);
977
+ if (stateUpdate) {
978
+ stateUpdate.needToResetStyleCache = false;
979
+ this.setState(stateUpdate);
980
+ }
981
+ }
982
+ }, {
983
+ key: "_getCalculatedScrollTop",
984
+ value: function _getCalculatedScrollTop() {
985
+ var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props;
986
+ var state = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.state;
987
+ return Grid._getCalculatedScrollTop(props, state);
988
+ }
989
+ }, {
990
+ key: "_resetStyleCache",
991
+ value: function _resetStyleCache() {
992
+ var styleCache = this._styleCache;
993
+ var cellCache = this._cellCache;
994
+ var isScrollingOptOut = this.props.isScrollingOptOut;
995
+
996
+ // Reset cell and style caches once scrolling stops.
997
+ // This makes Grid simpler to use (since cells commonly change).
998
+ // And it keeps the caches from growing too large.
999
+ // Performance is most sensitive when a user is scrolling.
1000
+ // Don't clear visible cells from cellCache if isScrollingOptOut is specified.
1001
+ // This keeps the cellCache to a resonable size.
1002
+ this._cellCache = {};
1003
+ this._styleCache = {};
1004
+
1005
+ // Copy over the visible cell styles so avoid unnecessary re-render.
1006
+ for (var rowIndex = this._rowStartIndex; rowIndex <= this._rowStopIndex; rowIndex++) {
1007
+ for (var columnIndex = this._columnStartIndex; columnIndex <= this._columnStopIndex; columnIndex++) {
1008
+ var key = "".concat(rowIndex, "-").concat(columnIndex);
1009
+ this._styleCache[key] = styleCache[key];
1010
+ if (isScrollingOptOut) {
1011
+ this._cellCache[key] = cellCache[key];
1012
+ }
1013
+ }
1014
+ }
1015
+ }
1016
+ }, {
1017
+ key: "_updateScrollTopForScrollToRow",
1018
+ value: function _updateScrollTopForScrollToRow() {
1019
+ var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props;
1020
+ var state = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.state;
1021
+ var stateUpdate = Grid._getScrollTopForScrollToRowStateUpdate(props, state);
1022
+ if (stateUpdate) {
1023
+ stateUpdate.needToResetStyleCache = false;
1024
+ this.setState(stateUpdate);
1025
+ }
1026
+ }
1027
+ }], [{
1028
+ key: "getDerivedStateFromProps",
1029
+ value: function getDerivedStateFromProps(nextProps, prevState) {
1030
+ var newState = {};
1031
+ var instanceProps = prevState.instanceProps;
1032
+ if (nextProps.columnCount === 0 && prevState.scrollLeft !== 0 || nextProps.rowCount === 0 && prevState.scrollTop !== 0) {
1033
+ newState.scrollLeft = 0;
1034
+ newState.scrollTop = 0;
1035
+
1036
+ // only use scroll{Left,Top} from props if scrollTo{Column,Row} isn't specified
1037
+ // scrollTo{Column,Row} should override scroll{Left,Top}
1038
+ } else if (nextProps.scrollLeft !== instanceProps.prevScrollLeft && nextProps.scrollToColumn < 0 || nextProps.scrollTop !== instanceProps.prevScrollTop && nextProps.scrollToRow < 0) {
1039
+ Object.assign(newState, Grid._getScrollToPositionStateUpdate({
1040
+ prevState: prevState,
1041
+ scrollLeft: nextProps.scrollLeft,
1042
+ scrollTop: nextProps.scrollTop
1043
+ }));
1044
+ }
1045
+
1046
+ // Initially we should not clearStyleCache
1047
+ newState.needToResetStyleCache = false;
1048
+ if (nextProps.columnWidth !== instanceProps.prevColumnWidth || nextProps.rowHeight !== instanceProps.prevRowHeight) {
1049
+ // Reset cache. set it to {} in render
1050
+ newState.needToResetStyleCache = true;
1051
+ }
1052
+ instanceProps.columnSizeAndPositionManager.configure({
1053
+ cellCount: nextProps.columnCount,
1054
+ estimatedCellSize: Grid._getEstimatedColumnSize(nextProps),
1055
+ cellSizeGetter: Grid._wrapSizeGetter(nextProps.columnWidth)
1056
+ });
1057
+ instanceProps.rowSizeAndPositionManager.configure({
1058
+ cellCount: nextProps.rowCount,
1059
+ estimatedCellSize: Grid._getEstimatedRowSize(nextProps),
1060
+ cellSizeGetter: Grid._wrapSizeGetter(nextProps.rowHeight),
1061
+ cellsHeight: nextProps.cellsHeight,
1062
+ editorAreaHeight: nextProps.editorAreaHeight,
1063
+ totalSize: nextProps.totalSize,
1064
+ editorsOffset: nextProps.editorsOffset
1065
+ });
1066
+ if (instanceProps.prevColumnCount === 0 || instanceProps.prevRowCount === 0) {
1067
+ instanceProps.prevColumnCount = 0;
1068
+ instanceProps.prevRowCount = 0;
1069
+ }
1070
+
1071
+ // If scrolling is controlled outside this component, clear cache when scrolling stops
1072
+ if (nextProps.autoHeight && nextProps.isScrolling === false && instanceProps.prevIsScrolling === true) {
1073
+ Object.assign(newState, {
1074
+ isScrolling: false
1075
+ });
1076
+ }
1077
+ var maybeStateA;
1078
+ var maybeStateB;
1079
+ calculateSizeAndPositionDataAndUpdateScrollOffset({
1080
+ cellCount: instanceProps.prevColumnCount,
1081
+ cellSize: typeof instanceProps.prevColumnWidth === 'number' ? instanceProps.prevColumnWidth : null,
1082
+ computeMetadataCallback: function computeMetadataCallback() {
1083
+ return instanceProps.columnSizeAndPositionManager.resetCell(0);
1084
+ },
1085
+ computeMetadataCallbackProps: nextProps,
1086
+ nextCellsCount: nextProps.columnCount,
1087
+ nextCellSize: typeof nextProps.columnWidth === 'number' ? nextProps.columnWidth : null,
1088
+ nextScrollToIndex: nextProps.scrollToColumn,
1089
+ scrollToIndex: instanceProps.prevScrollToColumn,
1090
+ updateScrollOffsetForScrollToIndex: function updateScrollOffsetForScrollToIndex() {
1091
+ maybeStateA = Grid._getScrollLeftForScrollToColumnStateUpdate(nextProps, prevState);
1092
+ }
1093
+ });
1094
+ calculateSizeAndPositionDataAndUpdateScrollOffset({
1095
+ cellCount: instanceProps.prevRowCount,
1096
+ cellSize: typeof instanceProps.prevRowHeight === 'number' ? instanceProps.prevRowHeight : null,
1097
+ computeMetadataCallback: function computeMetadataCallback() {
1098
+ return instanceProps.rowSizeAndPositionManager.resetCell(0);
1099
+ },
1100
+ computeMetadataCallbackProps: nextProps,
1101
+ nextCellsCount: nextProps.rowCount,
1102
+ nextCellSize: typeof nextProps.rowHeight === 'number' ? nextProps.rowHeight : null,
1103
+ nextScrollToIndex: nextProps.scrollToRow,
1104
+ scrollToIndex: instanceProps.prevScrollToRow,
1105
+ updateScrollOffsetForScrollToIndex: function updateScrollOffsetForScrollToIndex() {
1106
+ maybeStateB = Grid._getScrollTopForScrollToRowStateUpdate(nextProps, prevState);
1107
+ }
1108
+ });
1109
+ instanceProps.prevColumnCount = nextProps.columnCount;
1110
+ instanceProps.prevColumnWidth = nextProps.columnWidth;
1111
+ instanceProps.prevIsScrolling = nextProps.isScrolling === true;
1112
+ instanceProps.prevRowCount = nextProps.rowCount;
1113
+ instanceProps.prevRowHeight = nextProps.rowHeight;
1114
+ instanceProps.prevScrollToColumn = nextProps.scrollToColumn;
1115
+ instanceProps.prevScrollToRow = nextProps.scrollToRow;
1116
+ instanceProps.prevScrollLeft = nextProps.scrollLeft;
1117
+ instanceProps.prevScrollTop = nextProps.scrollTop;
1118
+
1119
+ // getting scrollBarSize (moved from componentWillMount)
1120
+ instanceProps.scrollbarSize = nextProps.getScrollbarSize();
1121
+ if (instanceProps.scrollbarSize === undefined) {
1122
+ instanceProps.scrollbarSizeMeasured = false;
1123
+ instanceProps.scrollbarSize = 0;
1124
+ } else {
1125
+ instanceProps.scrollbarSizeMeasured = true;
1126
+ }
1127
+ newState.instanceProps = instanceProps;
1128
+ return _objectSpread(_objectSpread(_objectSpread({}, newState), maybeStateA), maybeStateB);
1129
+ }
1130
+ }, {
1131
+ key: "_getEstimatedColumnSize",
1132
+ value: function _getEstimatedColumnSize(props) {
1133
+ return typeof props.columnWidth === 'number' ? props.columnWidth : props.estimatedColumnSize;
1134
+ }
1135
+ }, {
1136
+ key: "_getEstimatedRowSize",
1137
+ value: function _getEstimatedRowSize(props) {
1138
+ return typeof props.rowHeight === 'number' ? props.rowHeight : props.estimatedRowSize;
1139
+ }
1140
+ }, {
1141
+ key: "_getScrollToPositionStateUpdate",
1142
+ value:
1143
+ /**
1144
+ * Get the updated state after scrolling to
1145
+ * scrollLeft and scrollTop
1146
+ */
1147
+ function _getScrollToPositionStateUpdate(_ref10) {
1148
+ var prevState = _ref10.prevState,
1149
+ scrollLeft = _ref10.scrollLeft,
1150
+ scrollTop = _ref10.scrollTop;
1151
+ var newState = {
1152
+ scrollPositionChangeReason: SCROLL_POSITION_CHANGE_REASONS.REQUESTED
1153
+ };
1154
+ if (typeof scrollLeft === 'number' && scrollLeft >= 0) {
1155
+ newState.scrollDirectionHorizontal = scrollLeft > prevState.scrollLeft ? SCROLL_DIRECTION_FORWARD : SCROLL_DIRECTION_BACKWARD;
1156
+ newState.scrollLeft = scrollLeft;
1157
+ }
1158
+ if (typeof scrollTop === 'number' && scrollTop >= 0) {
1159
+ newState.scrollDirectionVertical = scrollTop > prevState.scrollTop ? SCROLL_DIRECTION_FORWARD : SCROLL_DIRECTION_BACKWARD;
1160
+ newState.scrollTop = scrollTop;
1161
+ }
1162
+ if (typeof scrollLeft === 'number' && scrollLeft >= 0 && scrollLeft !== prevState.scrollLeft || typeof scrollTop === 'number' && scrollTop >= 0 && scrollTop !== prevState.scrollTop) {
1163
+ return newState;
1164
+ }
1165
+ return null;
1166
+ }
1167
+ }, {
1168
+ key: "_wrapSizeGetter",
1169
+ value: function _wrapSizeGetter(value) {
1170
+ return typeof value === 'function' ? value : function () {
1171
+ return value;
1172
+ };
1173
+ }
1174
+ }, {
1175
+ key: "_getCalculatedScrollLeft",
1176
+ value: function _getCalculatedScrollLeft(nextProps, prevState) {
1177
+ var columnCount = nextProps.columnCount,
1178
+ height = nextProps.height,
1179
+ scrollToAlignment = nextProps.scrollToAlignment,
1180
+ scrollToColumn = nextProps.scrollToColumn,
1181
+ width = nextProps.width;
1182
+ var scrollLeft = prevState.scrollLeft,
1183
+ instanceProps = prevState.instanceProps;
1184
+ if (columnCount > 0) {
1185
+ var finalColumn = columnCount - 1;
1186
+ var targetIndex = scrollToColumn < 0 ? finalColumn : Math.min(finalColumn, scrollToColumn);
1187
+ var totalRowsHeight = instanceProps.rowSizeAndPositionManager.getTotalSize();
1188
+ var scrollBarSize = instanceProps.scrollbarSizeMeasured && totalRowsHeight > height ? instanceProps.scrollbarSize : 0;
1189
+ return instanceProps.columnSizeAndPositionManager.getUpdatedOffsetForIndex({
1190
+ align: scrollToAlignment,
1191
+ containerSize: width - scrollBarSize,
1192
+ currentOffset: scrollLeft,
1193
+ targetIndex: targetIndex
1194
+ });
1195
+ }
1196
+ return 0;
1197
+ }
1198
+ }, {
1199
+ key: "_getScrollLeftForScrollToColumnStateUpdate",
1200
+ value: function _getScrollLeftForScrollToColumnStateUpdate(nextProps, prevState) {
1201
+ var scrollLeft = prevState.scrollLeft;
1202
+ var calculatedScrollLeft = Grid._getCalculatedScrollLeft(nextProps, prevState);
1203
+ if (typeof calculatedScrollLeft === 'number' && calculatedScrollLeft >= 0 && scrollLeft !== calculatedScrollLeft) {
1204
+ return Grid._getScrollToPositionStateUpdate({
1205
+ prevState: prevState,
1206
+ scrollLeft: calculatedScrollLeft,
1207
+ scrollTop: -1
1208
+ });
1209
+ }
1210
+ return null;
1211
+ }
1212
+ }, {
1213
+ key: "_getCalculatedScrollTop",
1214
+ value: function _getCalculatedScrollTop(nextProps, prevState) {
1215
+ var height = nextProps.height,
1216
+ rowCount = nextProps.rowCount,
1217
+ scrollToAlignment = nextProps.scrollToAlignment,
1218
+ scrollToRow = nextProps.scrollToRow,
1219
+ width = nextProps.width;
1220
+ var scrollTop = prevState.scrollTop,
1221
+ instanceProps = prevState.instanceProps;
1222
+ if (rowCount > 0) {
1223
+ var finalRow = rowCount - 1;
1224
+ var targetIndex = scrollToRow < 0 ? finalRow : Math.min(finalRow, scrollToRow);
1225
+ var totalColumnsWidth = instanceProps.columnSizeAndPositionManager.getTotalSize();
1226
+ var scrollBarSize = instanceProps.scrollbarSizeMeasured && totalColumnsWidth > width ? instanceProps.scrollbarSize : 0;
1227
+ return instanceProps.rowSizeAndPositionManager.getUpdatedOffsetForIndex({
1228
+ align: scrollToAlignment,
1229
+ containerSize: height - scrollBarSize,
1230
+ currentOffset: scrollTop,
1231
+ targetIndex: targetIndex
1232
+ });
1233
+ }
1234
+ return 0;
1235
+ }
1236
+ }, {
1237
+ key: "_getScrollTopForScrollToRowStateUpdate",
1238
+ value: function _getScrollTopForScrollToRowStateUpdate(nextProps, prevState) {
1239
+ var scrollTop = prevState.scrollTop;
1240
+ var calculatedScrollTop = Grid._getCalculatedScrollTop(nextProps, prevState);
1241
+ if (typeof calculatedScrollTop === 'number' && calculatedScrollTop >= 0 && scrollTop !== calculatedScrollTop) {
1242
+ return Grid._getScrollToPositionStateUpdate({
1243
+ prevState: prevState,
1244
+ scrollLeft: -1,
1245
+ scrollTop: calculatedScrollTop
1246
+ });
1247
+ }
1248
+ return null;
1249
+ }
1250
+ }]);
1251
+ return Grid;
1252
+ }(React.PureComponent);
1253
+ Grid.defaultProps = {
1254
+ 'aria-label': 'grid',
1255
+ 'aria-readonly': true,
1256
+ autoContainerWidth: false,
1257
+ autoHeight: false,
1258
+ autoWidth: false,
1259
+ cellRangeRenderer: defaultCellRangeRenderer,
1260
+ containerRole: 'rowgroup',
1261
+ containerStyle: {},
1262
+ estimatedColumnSize: 100,
1263
+ estimatedRowSize: 30,
1264
+ getScrollbarSize: scrollbarSize,
1265
+ noContentRenderer: renderNull,
1266
+ onScroll: function onScroll() {
1267
+ //
1268
+ },
1269
+ onScrollbarPresenceChange: function onScrollbarPresenceChange() {
1270
+ //
1271
+ },
1272
+ onSectionRendered: function onSectionRendered() {
1273
+ //
1274
+ },
1275
+ overscanColumnCount: 0,
1276
+ overscanIndicesGetter: defaultOverscanIndicesGetter,
1277
+ overscanRowCount: 10,
1278
+ role: 'grid',
1279
+ scrollingResetTimeInterval: DEFAULT_SCROLLING_RESET_TIME_INTERVAL,
1280
+ scrollToAlignment: 'auto',
1281
+ scrollToColumn: -1,
1282
+ scrollToRow: -1,
1283
+ style: {},
1284
+ tabIndex: 0,
1285
+ isScrollingOptOut: false
1286
+ };
1287
+ export default Grid;