I am getting response from mongoDB aggregation query which is grouped data and select fields dynamically which is on "projectionObj" object:
Here is my mongodb aggregation query:
let projectionObj = {
"date": 1,
"height": 1,
"bmi": 1,
"level": 1,
}
UpdateForm.aggregate([
{ $match: {
"id": id,
"date": {
"$gte": startdate,
"$lte": enddate,
}}},
{ $group: {
_id: {
year: { $year: "$date" },
month: { $month: "$date" },
day: { $dayOfMonth: "$date" },
},
items: {
$push: '$$ROOT',
}}},
{$project: {
"_id": 0,
"items": projectionObj
}},
])
And below is aggregation result:
[
{
items: [{
date: "2022-03-11",
height: '1',
bmi: '1',
level: '1'
},
{
date: "2022-03-11",
height: '2',
bmi: '2',
level: '2'
}]
},
{
items: [{
date: "2022-03-08",
height: '3',
bmi: '3',
level: '3'
}]
}
]
I want to format aggregation result to desire able format which is given below
{
categories: ["2022-03-11", "2022-03-11", "2022-03-08"],
series: [
{name: "height", data: [1,2,3]},
{name: "bmi", data: [1,2,3]},
{name: "level", data: [1,2,3]},
]
}