Spaces:
Build error
Build error
import {InternMap} from "internmap"; | |
import identity from "./identity.js"; | |
export default function group(values, ...keys) { | |
return nest(values, identity, identity, keys); | |
} | |
export function groups(values, ...keys) { | |
return nest(values, Array.from, identity, keys); | |
} | |
function flatten(groups, keys) { | |
for (let i = 1, n = keys.length; i < n; ++i) { | |
groups = groups.flatMap(g => g.pop().map(([key, value]) => [...g, key, value])); | |
} | |
return groups; | |
} | |
export function flatGroup(values, ...keys) { | |
return flatten(groups(values, ...keys), keys); | |
} | |
export function flatRollup(values, reduce, ...keys) { | |
return flatten(rollups(values, reduce, ...keys), keys); | |
} | |
export function rollup(values, reduce, ...keys) { | |
return nest(values, identity, reduce, keys); | |
} | |
export function rollups(values, reduce, ...keys) { | |
return nest(values, Array.from, reduce, keys); | |
} | |
export function index(values, ...keys) { | |
return nest(values, identity, unique, keys); | |
} | |
export function indexes(values, ...keys) { | |
return nest(values, Array.from, unique, keys); | |
} | |
function unique(values) { | |
if (values.length !== 1) throw new Error("duplicate key"); | |
return values[0]; | |
} | |
function nest(values, map, reduce, keys) { | |
return (function regroup(values, i) { | |
if (i >= keys.length) return reduce(values); | |
const groups = new InternMap(); | |
const keyof = keys[i++]; | |
let index = -1; | |
for (const value of values) { | |
const key = keyof(value, ++index, values); | |
const group = groups.get(key); | |
if (group) group.push(value); | |
else groups.set(key, [value]); | |
} | |
for (const [key, values] of groups) { | |
groups.set(key, regroup(values, i)); | |
} | |
return map(groups); | |
})(values, 0); | |
} | |