diff options
Diffstat (limited to 'services')
| -rw-r--r-- | services/feed/feed.hooks.ts | 4 | ||||
| -rw-r--r-- | services/polls/polls.hooks.ts | 43 | 
2 files changed, 44 insertions, 3 deletions
| 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 | 
