Tengo dos matrices de usuarios que tienen los mismos iD. Quiero fusionarlos en función de la propiedad updatedAt que tiene cada usuario. El usuario que tiene la propiedad updatedAt más reciente tiene prioridad.
const users1 = [ { id: 1, name: 'user1', childUsers: [2], updatedAt: '2022-02-23T00:00:00.000Z' }, { id: 2, name: 'user2', childUsers: [3, 4], updatedAt: '2022-01-26T00:00:00.000Z' }, { id: 3, name: 'user3', childUsers: [2, 3], updatedAt: '2022-02-24T00:00:00.000Z' }, { id: 4, name: 'user4', childUsers: [2, 4], updatedAt: '2022-02-26T00:00:00.000Z' }, ]
const users2 = [ { id: 1, name: 'user1', childUsers: [2], updatedAt: '2022-02-26T00:00:00.000Z' }, { id: 2, name: 'user2.1', childUsers: [3, 4], updatedAt: '2022-02-27T00:00:00.000Z' }, { id: 3, name: 'user3', childUsers: [2, 3], updatedAt: '2022-02-26T00:00:00.000Z' }, { id: 4, name: 'user4.1', childUsers: [2, 4], updatedAt: '2022-02-27T00:00:00.000Z' }, ]
La salida debe ser
const mergedUsers = [ { id: 1, name: 'user1', childUsers: [2], updatedAt: '2022-02-26T00:00:00.000Z' }, { id: 2, name: 'user2.1', childUsers: [3, 4], updatedAt: '2022-02-27T00:00:00.000Z' }, { id: 3, name: 'user3', childUsers: [2, 3], updatedAt: '2022-02-26T00:00:00.000Z' }, { id: 4, name: 'user4.1', childUsers: [2, 4], updatedAt: '2022-02-27T00:00:00.000Z' },
]
Puede usar Array.reduce()
para agrupar usuarios por id, reemplazando cualquier entrada con una propiedad updatedAt
más nueva.
Una vez que tenemos los usuarios agrupados, podemos usar Object.values()
para obtener el resultado deseado:
const users1 = [ { id: 1, name: 'user1', childUsers: [2], updatedAt: '2022-02-23T00:00:00.000Z' }, { id: 2, name: 'user2', childUsers: [3, 4], updatedAt: '2022-01-26T00:00:00.000Z' }, { id: 3, name: 'user3', childUsers: [2, 3], updatedAt: '2022-02-24T00:00:00.000Z' }, { id: 4, name: 'user4', childUsers: [2, 4], updatedAt: '2022-02-26T00:00:00.000Z' }, ] const users2 = [ { id: 1, name: 'user1', childUsers: [2], updatedAt: '2022-02-26T00:00:00.000Z' }, { id: 2, name: 'user2.1', childUsers: [3, 4], updatedAt: '2022-02-27T00:00:00.000Z' }, { id: 3, name: 'user3', childUsers: [2, 3], updatedAt: '2022-02-26T00:00:00.000Z' }, { id: 4, name: 'user4.1', childUsers: [2, 4], updatedAt: '2022-02-27T00:00:00.000Z' }, ] const result = Object.values([...users1, ...users2].reduce((acc, user) => { // Entry either does not exist or has an older updatedAt property if (!acc[user.id] || (user.updatedAt > acc[user.id].updatedAt)) { acc[user.id] = user; } return acc; }, {})) console.log('Result:', result)
Desea comparar cada usuario en la primera matriz con su similar de la segunda matriz y elegir el que tenga la fecha de actualización más alta.
const users1 = [...]; const users2 = [...]; const merged = users1.map((user1) => { // loop through the users1 array const duplicateUser = users2.find((user2) => user1.id === user2.id); // if a similar user was found if (duplicateUser) { // compare and return the user with the newer updatedAt date return new Date(duplicateUser.updatedAt) > new Date(user1.updatedAt) ? duplicateUser : user1; } return user1; // in the case of no duplicates }); console.log(merged);