swc/crates/swc_bundler/tests/.cache/deno/a777851f3834ac4a4f81b2acdb778752ec3f928a.ts
2021-11-09 20:42:49 +09:00

49 lines
1.6 KiB
TypeScript

// Loaded from https://deno.land/x/ramda@v0.27.2/source/collectBy.js
import _curry2 from './internal/_curry2.js';
import _reduce from './internal/_reduce.js';
/**
* Splits a list into sub-lists, based on the result of calling a key-returning function on each element,
* and grouping the results according to values returned.
*
* @func
* @memberOf R
* @category List
* @typedefn Idx = String | Int | Symbol
* @sig Idx a => (b -> a) -> [b] -> [[b]]
* @param {Function} fn Function :: a -> Idx
* @param {Array} list The array to group
* @return {Array}
* An array of arrays where each sub-array contains items for which
* the String-returning function has returned the same value.
* @see R.groupBy, R.partition
* @example
* R.collectBy(R.prop('type'), [
* {type: 'breakfast', item: '☕️'},
* {type: 'lunch', item: '🌯'},
* {type: 'dinner', item: '🍝'},
* {type: 'breakfast', item: '🥐'},
* {type: 'lunch', item: '🍕'}
* ]);
*
* // [ [ {type: 'breakfast', item: '☕️'},
* // {type: 'breakfast', item: '🥐'} ],
* // [ {type: 'lunch', item: '🌯'},
* // {type: 'lunch', item: '🍕'} ],
* // [ {type: 'dinner', item: '🍝'} ] ]
*/
var collectBy = _curry2(function collectBy(fn, list) {
var group = _reduce(function(o, x) {
var tag = fn(x);
if (o[tag] === undefined) { o[tag] = []; }
o[tag].push(x);
return o;
}, {}, list);
var newList = [];
for (var tag in group) { newList.push(group[tag]); }
return newList;
});
export default collectBy;