/* * Copyright (C) 2022 StApps * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation, version 3. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along with * this program. If not, see . */ export type Tree = { [key: string]: Tree; } & { _?: T[] | undefined; }; /** * */ export function treeGroupBy(items: T[], transform: (item: T) => string[]): Tree { const tree: Tree = {}; for (const item of items) { let currentTree = tree; const keys = transform(item); if (keys.length === 0) { currentTree._ = currentTree._ || []; currentTree._.push(item); } // eslint-disable-next-line unicorn/no-array-for-each keys.forEach((key, i) => { currentTree = currentTree[key] = (currentTree[key] ?? {}) as Tree; if (i === keys.length - 1) { currentTree._ = currentTree._ ?? []; // eslint-disable-next-line @typescript-eslint/no-non-null-assertion currentTree._.push(item); } }); } return tree; }