diff options
author | Florian Dold <florian.dold@gmail.com> | 2017-05-03 15:35:00 +0200 |
---|---|---|
committer | Florian Dold <florian.dold@gmail.com> | 2017-05-03 15:35:00 +0200 |
commit | de98e0b232509d5f40c135d540a70e415272ff85 (patch) | |
tree | a79222a5b58484ab3b80d18efcaaa7ccc4769b33 /node_modules/fbjs/lib/groupArray.js.flow | |
parent | e0c9d480a73fa629c1e4a47d3e721f1d2d345406 (diff) |
node_modules
Diffstat (limited to 'node_modules/fbjs/lib/groupArray.js.flow')
-rw-r--r-- | node_modules/fbjs/lib/groupArray.js.flow | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/node_modules/fbjs/lib/groupArray.js.flow b/node_modules/fbjs/lib/groupArray.js.flow new file mode 100644 index 000000000..de532f50d --- /dev/null +++ b/node_modules/fbjs/lib/groupArray.js.flow @@ -0,0 +1,37 @@ +/** + * Copyright (c) 2013-present, Facebook, Inc. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + * + * @providesModule groupArray + * @typechecks + */ + +'use strict'; + +/** + * Groups all items in the array using the specified function. An object will + * be returned where the keys are the group names, and the values are arrays of + * all the items in that group. + * + * @param {array} array + * @param {function} fn Should return a string with a group name + * @return {object} items grouped using fn + */ + +function groupArray(array, fn) { + var ret = {}; + for (var ii = 0; ii < array.length; ii++) { + var result = fn.call(array, array[ii], ii); + if (!ret[result]) { + ret[result] = []; + } + ret[result].push(array[ii]); + } + return ret; +} + +module.exports = groupArray;
\ No newline at end of file |