aboutsummaryrefslogtreecommitdiff
path: root/models/polls/poll.schema.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.schema.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.schema.ts')
-rw-r--r--models/polls/poll.schema.ts22
1 files changed, 8 insertions, 14 deletions
diff --git a/models/polls/poll.schema.ts b/models/polls/poll.schema.ts
index bc6d497..4d1d762 100644
--- a/models/polls/poll.schema.ts
+++ b/models/polls/poll.schema.ts
@@ -1,27 +1,21 @@
import { Document, Schema, Types } from 'mongoose';
-import { User } from '../users/user.schema';
-export interface ImageData {
+export interface ImageDataSchema {
url: string;
- votes: number;
}
-export interface Poll {
- author: User;
+export interface PollSchema extends Document {
contents: {
- left: ImageData;
- right: ImageData;
+ left: ImageDataSchema;
+ right: ImageDataSchema;
};
-}
-
-export interface PollSchema extends Document, Omit<Poll, 'author'> {
+ createdAt: Date;
authorId: string;
+ vote: (userId: string, which: 'left' | 'right') => PollSchema;
}
-
-const imageDataSchema = {
+export const imageDataSchema = {
url: String,
- votes: Number
};
export const pollSchema = new Schema({
@@ -33,5 +27,5 @@ export const pollSchema = new Schema({
type: Types.ObjectId,
ref: 'User'
}
-});
+}, { timestamps: true });