Skip to content
Snippets Groups Projects
Fragment.js 3.58 KiB
Newer Older
Sebastian Mihalache's avatar
Sebastian Mihalache committed
const get = require('lodash/get')
Sebastian Mihalache's avatar
Sebastian Mihalache committed

class Fragment {
  constructor({ fragment }) {
    this.fragment = fragment
  }
Sebastian Mihalache's avatar
Sebastian Mihalache committed

  set _fragment(newFragment) {
    this.fragment = newFragment
  }

  static setFragmentOwners(fragment = {}, author = {}) {
    const { owners = [] } = fragment
    if (author.isSubmitting) {
      const authorAlreadyOwner = owners.includes(author.id)
      if (!authorAlreadyOwner) {
        return [author.id, ...owners]
      }
    }
    return owners
  }

  async getFragmentData({ handlingEditor } = {}) {
Sebastian Mihalache's avatar
Sebastian Mihalache committed
    const { fragment: { metadata = {}, recommendations = [], id } } = this
    let heRecommendation

    if (handlingEditor) {
      heRecommendation = recommendations.find(
        rec => rec.userId === handlingEditor.id,
      )
    }

Sebastian Mihalache's avatar
Sebastian Mihalache committed
    let { title = '', abstract = '' } = metadata
    const { type } = metadata
    title = title.replace(/<(.|\n)*?>/g, '')
    abstract = abstract ? abstract.replace(/<(.|\n)*?>/g, '') : ''

    return {
      id,
      type,
      title,
      abstract,
      recommendations,
      heRecommendation,
    }
  }

  async addAuthor({ user, isSubmitting, isCorresponding }) {
    const { fragment } = this
    fragment.authors = fragment.authors || []
    const author = {
      firstName: user.firstName || '',
      lastName: user.lastName || '',
      email: user.email,
      title: user.title || '',
      affiliation: user.affiliation || '',
      isSubmitting,
      isCorresponding,
    }
    fragment.authors.push(author)
    fragment.owners = this.constructor.setFragmentOwners(fragment, author)
Sebastian Mihalache's avatar
Sebastian Mihalache committed
    const { fragment: { authors = [] } } = this
    const submittingAuthorData = authors.find(author => author.isSubmitting)
Sebastian Mihalache's avatar
Sebastian Mihalache committed
    try {
      const submittingAuthor = await UserModel.find(
        get(submittingAuthorData, 'id'),
      )

      const userHelper = new User({ UserModel })
Sebastian Mihalache's avatar
Sebastian Mihalache committed
      const activeAuthors = await userHelper.getActiveAuthors(authors)
Sebastian Mihalache's avatar
Sebastian Mihalache committed
      return {
Sebastian Mihalache's avatar
Sebastian Mihalache committed
        submittingAuthor,
      }
    } catch (e) {
      throw e
  getInvitations({ isAccepted = true, role = 'reviewer', type }) {
    const { fragment: { invitations = [], recommendations = [] } } = this
    let filteredInvitations = isAccepted
            inv.role === role &&
            inv.hasAnswer === true &&
            inv.isAccepted === true,
        )
      : invitations.filter(inv => inv.role === role && inv.hasAnswer === false)

      filteredInvitations = filteredInvitations.filter(inv =>
        recommendations.find(
          rec =>
            rec.recommendationType === 'review' &&
            rec.submittedOn &&
            inv.userId === rec.userId,
        ),
      )
    }

    return filteredInvitations
    const { fragment: { recommendations = [] } } = this
    return recommendations
      .filter(
        rec =>
          rec.recommendationType === 'editorRecommendation' &&
          (rec.recommendation === 'minor' || rec.recommendation === 'major'),
      )
      .sort((a, b) => b.createdOn - a.createdOn)[0]
  async getReviewers({ UserModel, type }) {
    const isAccepted = type !== 'pending'
    const invitations = await this.getInvitations({ isAccepted, type })
    return (await Promise.all(
      invitations.map(inv => UserModel.find(inv.userId)),
    ))
      .filter(rev => rev.isActive)
      .filter(rev => get(rev, 'notifications.email.user'))