Database

[{"_id":{"$oid":"60c1e8e318afd80016ce58b1"},"searchPriority":1,"sortPriority":300,"isLive":true,"vehicleCondition":"USED","vehicleDetails":{"city":"Delhi"}},{"_id":{"$oid":"60c1f2f418afd80016ce58b5"},"searchPriority":2,"sortPriority":301,"isLive":true,"vehicleCondition":"USED","vehicleDetails":{"city":"Delhi"}},{"_id":{"$oid":"60cb429eadd33c00139d2be7"},"searchPriority":1,/**Lowest*/"sortPriority":101,"isLive":true,"vehicleCondition":"USED","vehicleDetails":{"city":"Gurugram"}},{"_id":{"$oid":"60c21be618afd80016ce5905"},"searchPriority":2,"sortPriority":201,"isLive":true,"vehicleCondition":"USED","vehicleDetails":{"city":"New Delhi"}},{"_id":{"$oid":"60e306d29e452d00134b978f"},"searchPriority":3,"sortPriority":202,"isLive":true,"vehicleCondition":"USED","vehicleDetails":{"city":"New Delhi"}}]

Query

db.collection.aggregate([{$match:{"isLive":true,"vehicleDetails.city":{$in:["Gurugram","Delhi","New Delhi"]},"vehicleCondition":"USED"}},{"$addFields":{"cityIndex":{"$indexOfArray":[["Gurugram","Delhi","New Delhi"],"$vehicleDetails.city"]}}},{$sort:{cityIndex:1,sortPriority:1}},{$project:{cityIndex:0}}])

Result