I have data which is structured like this:
let siteLists = [
{
"data": {
"client_id": 29
},
"all_branch": 1,
"value": 29,
"label": "A Site"
},
{
"data": {
"client_id": 23,
},
"all_branch": 0,
"value": 91,
"label": "B-1 Site"
},
{
"data": {
"client_id": 23,
},
"all_branch": 0,
"value": 86,
"label": "B-2 Site"
},
{
"data": {
"client_id": 10
},
"all_branch": 1,
"value": 10,
"label": "C Site"
}
];
I need to concatenate the above object which has same data.client_id value into one object which contains all branch values.
Expected result:
[
{
id: 29,
branches: [],
all_branch:1
},
{
id: 23,
branches: [91,86],
all_branch:0
},
{
id: 10,
branches: [],
all_branch:1
}
]
I tried the following code but the result did not fit the expected result...
let populate = [...siteLists.map(item => {
return item.all_branch === 1 ? {
all_placement: 1,
placement_id: item.data.client_id,
branch_id: []
} : {
all_placement: 0,
placement_id: item.data.client_id,
branch_id: [item.value]
}
})];