Вы можете использовать вложенный подход, уменьшив количество записей объектов.
const
pairs = { A: { D: [1, 2, 3] }, B: { D: [3, 2, 1] }, C: { D: [4, 3, 2, 1], B: [0, 1, 2, 3] } },
result = Object
.entries(pairs)
.reduce((r, [right, object]) => Object
.entries(object)
.reduce((r, [left, value]) => {
r[left] = r[left] || {};
r[left][right] = value;
return r;
}, r), {});
console.log(result);
Другой подход заключается в использовании рекурсивной функции путем создания свойств после сбора всех ключей.
const
reverse = (source, target = {}, keys = []) => {
if (source && typeof source === 'object' && !Array.isArray(source)) {
Object.entries(source).forEach(([k, v]) => reverse(v, target, [k, ...keys]));
} else {
var last = keys.pop();
keys.reduce((o, k) => o[k] = o[k] || {}, target)[last] = source;
}
return target;
},
pairs = { A: { D: [1, 2, 3] }, B: { D: [3, 2, 1] }, C: { D: [4, 3, 2, 1], B: [0, 1, 2, 3] } },
result = reverse(pairs);
console.log(result);