react-virtualized
Version:
React components for efficiently rendering large, scrollable lists and tabular data
37 lines (30 loc) • 985 B
JavaScript
/**
* Initializes metadata for an axis and its cells.
* This data is used to determine which cells are visible given a container size and scroll position.
*
* @param cellCount Total number of cells.
* @param size Either a fixed size or a function that returns the size for a given given an index.
* @return Object mapping cell index to cell metadata (size, offset)
*/
export default function initCellMetadata(_ref) {
var cellCount = _ref.cellCount;
var size = _ref.size;
var sizeGetter = size instanceof Function ? size : function (_ref2) {
var index = _ref2.index;
return size;
};
var cellMetadata = [];
var offset = 0;
for (var i = 0; i < cellCount; i++) {
var _size = sizeGetter({ index: i });
if (_size == null || isNaN(_size)) {
throw Error("Invalid size returned for cell " + i + " of value " + _size);
}
cellMetadata[i] = {
size: _size,
offset: offset
};
offset += _size;
}
return cellMetadata;
}