2015-03-10 19:11:28 -07:00
|
|
|
/**
|
2015-03-23 15:07:33 -07:00
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
*
|
2018-02-16 18:24:55 -08:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2015-03-10 19:11:28 -07:00
|
|
|
*
|
2018-05-10 19:06:46 -07:00
|
|
|
* @format
|
2015-03-24 09:26:16 -07:00
|
|
|
* @flow
|
2015-03-10 19:11:28 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Useful method to split an array into groups of the same number of elements.
|
|
|
|
* You can use it to generate grids, rows, pages...
|
|
|
|
*
|
|
|
|
* If the input length is not a multiple of the count, it'll fill the last
|
|
|
|
* array with null so you can display a placeholder.
|
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
* groupByEveryN([1, 2, 3, 4, 5], 3)
|
|
|
|
* => [[1, 2, 3], [4, 5, null]]
|
|
|
|
*
|
|
|
|
* groupByEveryN([1, 2, 3], 2).map(elems => {
|
|
|
|
* return <Row>{elems.map(elem => <Elem>{elem}</Elem>)}</Row>;
|
|
|
|
* })
|
|
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
|
2015-03-24 09:26:16 -07:00
|
|
|
function groupByEveryN<T>(array: Array<T>, n: number): Array<Array<?T>> {
|
2018-05-10 15:44:52 -07:00
|
|
|
const result = [];
|
|
|
|
let temp = [];
|
2015-03-10 19:11:28 -07:00
|
|
|
|
2018-05-10 15:44:52 -07:00
|
|
|
for (let i = 0; i < array.length; ++i) {
|
2015-03-10 19:11:28 -07:00
|
|
|
if (i > 0 && i % n === 0) {
|
|
|
|
result.push(temp);
|
|
|
|
temp = [];
|
|
|
|
}
|
|
|
|
temp.push(array[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (temp.length > 0) {
|
|
|
|
while (temp.length !== n) {
|
|
|
|
temp.push(null);
|
|
|
|
}
|
|
|
|
result.push(temp);
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = groupByEveryN;
|