aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoreug-vs <eug-vs@keemail.me>2020-06-28 18:33:58 +0300
committereug-vs <eug-vs@keemail.me>2020-06-28 18:49:24 +0300
commitc3438eb4a7187773e2736dea765bb8281f7edf0e (patch)
tree4397f49f436d8d1a79e3e09eaa291d6ae6a7cc27
parent02b0da08155c6615a48b8d7f49648c19c1600020 (diff)
downloadwhich-api-c3438eb4a7187773e2736dea765bb8281f7edf0e.tar.gz
refactor: move convertPoll to polls hooks
-rw-r--r--hooks/convertPoll.ts43
-rw-r--r--services/feed/feed.hooks.ts4
-rw-r--r--services/polls/polls.hooks.ts43
3 files changed, 44 insertions, 46 deletions
diff --git a/hooks/convertPoll.ts b/hooks/convertPoll.ts
deleted file mode 100644
index 5e6f9f4..0000000
--- a/hooks/convertPoll.ts
+++ /dev/null
@@ -1,43 +0,0 @@
-import { HookContext } from '@feathersjs/feathers';
-import { Types } from 'mongoose';
-import bluebird from 'bluebird';
-import _ from 'lodash';
-import { Poll } from 'which-types';
-
-import { PollSchema } from '../models/polls/poll.schema';
-import VoteModel from '../models/votes/vote.model';
-
-
-export default async (context: HookContext): Promise<HookContext> => {
- const { app, result, params: { user } } = context;
-
- const convert = async (poll: PollSchema): Promise<Poll | null> => {
- const author = await app.service('users').get(poll.authorId);
-
- const contents = await VoteModel.aggregate([
- { $match: { pollId: Types.ObjectId(poll._id) } },
- { $group: { _id: '$which', total: { $sum: 1 } } }
- ]).then(groups => groups.reduce(
- (acc, group) => _.set(acc, `${group._id}.votes`, group.total),
- { left: { votes: 0 }, right: { votes: 0 } }
- ));
-
- const userChoice = await VoteModel.findOne(
- { pollId: poll._id, userId: user?._id }
- ).then(vote => vote?.which);
-
- return _.merge(
- _.omit(poll, ['authorId']),
- { author, contents, userChoice }
- );
- };
-
- if (Array.isArray(result)) {
- const polls = await bluebird.map(result, (poll: PollSchema) => convert(poll));
- context.result = _.compact(polls);
- } else {
- context.result = await convert(result);
- }
- return context;
-};
-
diff --git a/services/feed/feed.hooks.ts b/services/feed/feed.hooks.ts
index 54f6d61..6bff8dc 100644
--- a/services/feed/feed.hooks.ts
+++ b/services/feed/feed.hooks.ts
@@ -7,7 +7,7 @@ const raiseNewVerifedPolls = async (context: HookContext): Promise<HookContext>
// Raise unseen verified polls to the very top
context.result = _.sortBy(
context.result,
- poll => !(poll.author.verified && !poll.userChoice)
+ poll => !(poll.author.verified && !poll.vote)
);
return context;
};
@@ -16,7 +16,7 @@ const lowerOldPolls = async (context: HookContext): Promise<HookContext> => {
// Move all seen polls down
context.result = _.sortBy(
context.result,
- poll => !!poll.userChoice
+ poll => !!poll.vote
);
return context;
};
diff --git a/services/polls/polls.hooks.ts b/services/polls/polls.hooks.ts
index 77fcc7a..9f2183f 100644
--- a/services/polls/polls.hooks.ts
+++ b/services/polls/polls.hooks.ts
@@ -1,6 +1,47 @@
-import convertPoll from '../../hooks/convertPoll';
+import { HookContext } from '@feathersjs/feathers';
+import { Types } from 'mongoose';
+import bluebird from 'bluebird'; import _ from 'lodash';
+import { Poll } from 'which-types';
+
+import { PollSchema } from '../../models/polls/poll.schema';
+import VoteModel from '../../models/votes/vote.model';
import sortByDate from '../../hooks/sortByDate';
+
+const convertPoll = async (context: HookContext): Promise<HookContext> => {
+ const { app, result, params: { user } } = context;
+
+ const convert = async (poll: PollSchema): Promise<Poll | null> => {
+ const author = await app.service('users').get(poll.authorId);
+
+ const contents = await VoteModel.aggregate([
+ { $match: { pollId: Types.ObjectId(poll._id) } },
+ { $group: { _id: '$which', total: { $sum: 1 } } }
+ ]).then(groups => groups.reduce(
+ (acc, group) => _.set(acc, `${group._id}.votes`, group.total),
+ { left: { votes: 0 }, right: { votes: 0 } }
+ ));
+
+ const vote = await VoteModel.findOne(
+ { pollId: poll._id, authorId: user?._id }
+ );
+
+ return _.merge(
+ _.omit(poll, ['authorId']),
+ { author, contents, vote }
+ );
+ };
+
+ if (Array.isArray(result)) {
+ const polls = await bluebird.map(result, (poll: PollSchema) => convert(poll));
+ context.result = _.compact(polls);
+ } else {
+ context.result = await convert(result);
+ }
+ return context;
+};
+
+
export default {
before: {
find: sortByDate