const array1 = [
{page: '1.ru', title: 'title 1'},
{page: '3.ru', title: 'title 3'},
{page: '6.ru', title: 'title 6'},
];
const array2 = [
{page: '666.ru', title: 'title 666', referer: '66.ru'},
{page: '33.ru', title: 'title 33', referer: '3.ru'},
{page: '66.ru', title: 'title 66', referer: '6.ru'},
];
function createTree(roots, notRoots) {
if (!roots || !roots.length) { return []; }
const childsMap = new Map();
// строим карту (page => список_чилдов), создавая узлы дерева для чилдов
notRoots.forEach((child) => {
let childs = childsMap.get(child.referer);
if (!childs) {
childs = [];
childsMap.set(child.referer, childs);
}
childs.push({
page: child.page,
title: child.title,
});
});
// всем чилдам (вновь созданным узлам), которые попали в карту, проставляем чилдов
childsMap.forEach((childs) => {
childs.forEach((child) => {
child.childs = childsMap.get(child.page) || [];
})
});
// обходим корневые элементы, создаем для них узлы дерева, подставляем чилды по карте
return roots.map((root) => {
return {
page: root.page,
title: root.title,
childs: childsMap.get(root.page) || []
};
})
}
console.log(createTree(array1, array2));