New to Javascript. Have been at this for hours looking at examples, but I can't seem to get my head around it.
I have an array of objects with nested properties that I'm trying to loop through and consolidate.
var items = [{
name: "flat bread",
price: "5",
components: [
{ qty: 120, unit: "g", ingredient: { name: "flour", price: 1, perAmount: 1, unit: "kg" } },
{ qty: 250, unit: "mL", ingredient: { name: "milk", price: 4, perAmount: 3, unit: "litre" } },
{ qty: 1.5, unit: "g", ingredient: { name: "salt", price: 1.2, perAmount: 1, unit: "kg" } },
{ qty: 28.35, unit: "g", ingredient: { name: "butter", price: "6", perAmount: 500, unit: "g" } }
]
},
{
name: "pancake",
price: "15",
components: [
{ qty: 120, unit: "g", ingredient: { name: "flour", price: 1, perAmount: 1, unit: "kg" } },
{ qty: 250, unit: "mL", ingredient: { name: "milk", price: 4, perAmount: 3, unit: "litre" } },
{ qty: 2, unit: "each", ingredient: { name: "egg", price: 5, perAmount: 12, unit: "each" } },
{ qty: 12.5, unit: "g", ingredient: { name: "sugar", price: 2.20, perAmount: 2, unit: "kg" } }
]
},
{
name: "crepe",
price: "10",
components: [
{ qty: 120, unit: "g", ingredient: { name: "flour", price: 1, perAmount: 1, unit: "kg" } },
{ qty: 250, unit: "mL", ingredient: { name: "milk", price: 4, perAmount: 3, unit: "litre" } },
{ qty: 2, unit: "each", ingredient: { name: "egg", price: 5, perAmount: 12, unit: "each" } },
{ qty: 28.35, unit: "g", ingredient: { name: "butter", price: "6", perAmount: 500, unit: "g" } }
]
}
];
consolidatedComponents = items.map((item) => {
return { components: item.components }
});
console.log(consolidatedComponents);
I'm trying to get a result like this to return:
- 360g flour
- 750ml milk
- 1.5g salt 4 eggs
- 12.5g sugar
- 56.7g butter
I realise I will need to convert the units down the track, but let's assume they are all the same across the items/ingredients