aboutsummaryrefslogtreecommitdiff
path: root/models/polls/poll.model.ts
diff options
context:
space:
mode:
authorEugene Sokolov <eug-vs@keemail.me>2020-06-25 14:39:21 +0300
committerGitHub <noreply@github.com>2020-06-25 14:39:21 +0300
commit0afe8f1530affad1e58a65385b2a4bf888ab86cb (patch)
tree3bd5599bc5c3ce23777c5b369eaadd744f3c5c1f /models/polls/poll.model.ts
parente488591b9548264d0305a5f34786138bd6c6622b (diff)
parent64f5f8c3f9660f649dfdaad07d84aa8c26b9661e (diff)
downloadwhich-api-0afe8f1530affad1e58a65385b2a4bf888ab86cb.tar.gz
Merge pull request #8 from which-ecosystem/votes
Votes
Diffstat (limited to 'models/polls/poll.model.ts')
-rw-r--r--models/polls/poll.model.ts15
1 files changed, 15 insertions, 0 deletions
diff --git a/models/polls/poll.model.ts b/models/polls/poll.model.ts
index 7f6be9a..6749e5c 100644
--- a/models/polls/poll.model.ts
+++ b/models/polls/poll.model.ts
@@ -1,5 +1,20 @@
import { Model, model } from 'mongoose';
import { PollSchema, pollSchema } from './poll.schema';
+import { Types } from 'mongoose';
+import { Which } from 'which-types';
+
+pollSchema.methods.vote = function(userId: string, which: Which): PollSchema {
+ const participants: Types.ObjectId[] = ['left', 'right'].reduce((acc, option) => {
+ const { votes } = this.contents[option];
+ return acc.concat(votes);
+ }, []);
+
+ if (!participants.some(user => user.equals(userId))) {
+ this.contents[which].votes.push(userId);
+ }
+
+ return this.save();
+}
export default model<PollSchema, Model<PollSchema>>('Poll', pollSchema);