Skip to content
Snippets Groups Projects
Fragment.js 3.34 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
    const 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 })
      const activeAuthors = userHelper.getActiveAuthors(authors)

      const authorsList = activeAuthors.map(
        author => `${author.firstName} ${author.lastName}`,
      )
Sebastian Mihalache's avatar
Sebastian Mihalache committed

      return {
        authorsList,
        submittingAuthor,
      }
    } catch (e) {
      throw e
    const { fragment: { invitations = [] } } = this
    return agree
      ? invitations.filter(
          inv =>
            inv.role === 'reviewer' &&
            inv.hasAnswer === true &&
            inv.isAccepted === true,
        )
      : invitations.filter(
          inv => inv.role === 'reviewer' && inv.hasAnswer === false,
        )
  }
    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 getInvitationsForSubmittingReviewers() {
    const { fragment: { recommendations = [] } } = this
    const agreedInvitations = this.getReviewerInvitations({
      agree: true,
    })

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