Просто сохраните комментарии так, как вы хотите, чтобы они были представлены в вашем блоге. Вы хотите многопоточные / вложенные комментарии? Затем сохраните их во вложенном виде:
postId: {
comments: [
{
id: "47cc67093475061e3d95369d" // ObjectId
title: "Title of comment",
body: "Comment body",
timestamp: 123456789,
author: "authorIdentifier",
upVotes: 11,
downVotes: 2,
comments: [
{
id: "58ab67093475061e3d95a684"
title: "Nested comment",
body: "Hello, this is a nested/threaded comment",
timestamp: 123456789,
author: "authorIdentifier",
upVotes: 11,
downVotes: 2,
comments: [
// More nested comments
]
}
]
},
{
// Another top-level comment
}
]
}
postId
относится к сообщению в блоге, к которому принадлежат комментарии, и использовалось в качестве ключа (или _id
в MongoDB) документа. Каждый комментарий имеет уникальный id
, чтобы голосовать или комментировать отдельные комментарии.
Чтобы получить агрегированные голоса, вам нужно написать функции уменьшения карты где-то по следующим направлениям:
function map() {
mapRecursive(this.comments)
}
function mapRecursive(comments) {
comments.forEach(
function (c) {
emit(comment.author, { upVotes: c.upVotes, downVotes: c.downVotes });
mapRecursive(c.comments);
}
);
}
function reduce(key, values) {
var upVotes = 0;
var downVotes = 0;
values.forEach(
function(votes) {
upVotes += votes.upVotes;
downVotes += votes.downVotes;
}
);
return { upVotes: upVotes, downVotes: downVotes };
}
Я не проверял эти функции, и они также не проверяют значения null
. Это зависит от вас:)