Database
[{_id:"ObjectId('997v2ha1cv9b0036fa648zx3')",title:"Adidas Predator",size:"8",colors:[{hex:"005FFF",name:"Blue"},{hex:"FF003A",name:"Red"},{hex:"FFFE00",name:"Yellow"},{hex:"07FF00",name:"Green"},],extras:[{description:"laces",type:"exterior"},{description:"sole",type:"interior"},{description:"logo"},{description:"stud",type:"exterior"}],media:{images:[{url:"http://link.com",type:"exterior"},{url:"http://link3.com",type:"interior"},{url:"http://link2.com",type:"interior"},{url:"http://link4.com",type:"exterior"}]}},]
Query
db.collection.aggregate([{"$addFields":{colors:{$map:{input:"$colors",as:"color",in:"$$color.name"}}}},{$unwind:"$extras"},{"$addFields":{imageUrls:{$map:{input:{$filter:{input:"$media.images",as:"image",cond:{$eq:["$$image.type","$extras.type"]}}},as:"image",in:"$$image.url"}}}},{$group:{_id:{_id:"$_id",extraType:"$extras.type"},extraDescriptions:{"$addToSet":"$extras.description"},imageUrls:{"$first":"$imageUrls"},colors:{$first:"$colors"},size:{$first:"$size"},title:{$first:"$title"}}},{$group:{_id:"$_id._id",colors:{$first:"$colors"},size:{$first:"$size"},title:{$first:"$title"},images:{$push:{type:{"$ifNull":["$_id.extraType",null]},url:"$imageUrls"}},extras:{$push:{type:{"$ifNull":["$_id.extraType",null]},description:"$extraDescriptions"}}}}])