Home > Software design >  Extract object with same key from multiple array and make them into one array
Extract object with same key from multiple array and make them into one array

Time:07-12

I have an array of widgets containing multiple objects. Each object contains an array called cards which contains just a single object. I need help with extracting all the cards object and making a new cards array containing all the cards as elements

{
    "widgets" : [
        {
            "type": "Grid",
            "cards": [
                {
                    "data": {},
                    "layout": 1
                }
            ]
        },
        {
            "type": "Grid",
            "cards": [
                {
                    "data": {},
                    "layout": 1
                }
            ]
        }
    ]
}

How I want is

{
    "widgets": [
        {
            "type": "Grid",
            "cards": [
                {
                    "data": {},
                    "layout": 1
                },
                {
                    "data": {},
                    "layout": 1
                }
            ]
        }
    ]
}

CodePudding user response:

You can loop over the original object orig and extract it's cards into a new array allCards:

const allCards = [];
for (let widget of orig.widgets) {
    allCards.push(widget.cards[0]); 
}

Then you can construct a new object with these extracted cards.

CodePudding user response:

Given your requirement, the below might work.

let x = {
    "widgets" : [
        {
            "type": "Grid",
            "cards": [
                {
                    "data": {},
                    "layout": 1
                }
            ]
        },
        {
            "type": "Grid",
            "cards": [
                {
                    "data": {},
                    "layout": 1
                }
            ]
        }
    ]
}
let y = {"widgets": [{...x.widgets[0], "cards":[]}]};
x.widgets.forEach(el => y.widgets[0].cards.push(...[].concat(el.cards)));

CodePudding user response:

You can try this code that taek into account the type of each widget :

object = {
    "widgets" : [
        {
            "type": "Grid",
            "cards": [
                {
                    "data": {},
                    "layout": 1
                }
            ]
        },
        {
            "type": "Grid",
            "cards": [
                {
                    "data": {},
                    "layout": 1
                }
            ]
        },
        {
            "type": "Table",
            "cards": [
                {
                    "data": {},
                    "layout": 1
                }
            ]
        },
        {
            "type": "Grid",
            "cards": [
                {
                    "data": {},
                    "layout": 1
                }
            ]
        }
    ]
}

new_object = {"widgets" : []}

for (let i=0;  i < object["widgets"].length; i  ) {
    exist = false
    for (let j=0;  j < new_object["widgets"].length; j  ) {
        if (new_object["widgets"][j]["type"] === object["widgets"][i]["type"]){
            exist = true
            new_object["widgets"][j]["cards"].push(object["widgets"][i]["cards"][0])
        }
    }
    if (exist === false){
        new_object["widgets"].push(object["widgets"][i])
    }
  
}
console.log(new_object)

  • Related