I have 2 data structures as shown below
data1 :
{
purchaceOrder: [{
name: "Purchase Order",
version: 1,
description: "purchase order process",
saved: true,
visibility: true
},
{
name: "Purchase Order",
version: 2,
description: "purchase order process",
saved: false,
visibility: true
}
],
requestOrder: [{
name: "Request Order",
version: 1,
description: "request order process",
saved: true,
visibility: true
},
{
name: "Request Order",
version: 2,
description: "request order process",
saved: false,
visibility: true
}
],
cancelOrder: [{
name: "Cancel Order",
version: 1,
description: "cancel order process",
saved: false,
visibility: false
}]
}
data2:
[
{
id: "dwffrgefg68964",
name: "Purchase Order",
version: 1
},
{
id: "emffrgefg68964",
name: "Purchase Order",
version: 2
},
{
id: "iuffrgefg68964",
name: "request Order",
version: 1
}
]
I want to filter data1 based on name, add id from data2 to each object in data1 and remove the entire object/ empty array in data1 if the process name is not found in data2 as given below
Final result:
{
purchaceOrder: [{
id: "dwffrgefg68964"
name: "Purchase Order",
version: 1,
description: "purchase order process",
saved: true,
visibility: true
},
{
id: "emffrgefg68964"
name: "Purchase Order",
version: 2,
description: "purchase order process",
saved: false,
visibility: true
}
],
requestOrder: [{
id: "iuffrgefg68964"
name: "Request Order",
version: 1,
description: "request order process",
saved: true,
visibility: true
}]
}
I tried various solutions but couldn't get the expected result. This is what I have:
getAllProcess(){
for (let key in data1) {
var temp1 = data1[key];
for (let i = 0; i < temp1.length; i++) {
const reqModel = data2.find(process=> process.name === temp1[i].name&& process.version === temp1[i].version);
if(reqModel){
temp1[i].id=reqModel.id;
data1[key][i]=temp1[i];
}
}}
return data1;
}
savedandvisibilityproperties if it doesn't exist indata2?