diff options
author | Eugene Sokolov <eug-vs@keemail.me> | 2020-06-25 14:39:21 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-06-25 14:39:21 +0300 |
commit | 0afe8f1530affad1e58a65385b2a4bf888ab86cb (patch) | |
tree | 3bd5599bc5c3ce23777c5b369eaadd744f3c5c1f /models/polls/poll.model.ts | |
parent | e488591b9548264d0305a5f34786138bd6c6622b (diff) | |
parent | 64f5f8c3f9660f649dfdaad07d84aa8c26b9661e (diff) | |
download | which-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.ts | 15 |
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); |