summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/vue_merge_request_widget/components/mr_widget_related_links.js
blob: 205804670fa473de6d573ea41d9bbbcb579a946b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
export default {
  name: 'MRWidgetRelatedLinks',
  props: {
    relatedLinks: { type: Object, required: true },
  },
  computed: {
    hasLinks() {
      const { closing, mentioned, assignToMe } = this.relatedLinks;
      return closing || mentioned || assignToMe;
    },
  },
  methods: {
    hasMultipleIssues(text) {
      return !text ? false : text.match(/<\/a> and <a/);
    },
    issueLabel(field) {
      return this.hasMultipleIssues(this.relatedLinks[field]) ? 'issues' : 'issue';
    },
    verbLabel(field) {
      return this.hasMultipleIssues(this.relatedLinks[field]) ? 'are' : 'is';
    },
  },
  template: `
    <section
      v-if="hasLinks"
      class="mr-info-list mr-links">
      <div class="legend"></div>
      <p v-if="relatedLinks.closing">
        Closes {{issueLabel('closing')}}
        <span v-html="relatedLinks.closing"></span>.
      </p>
      <p v-if="relatedLinks.mentioned">
        <span class="capitalize">{{issueLabel('mentioned')}}</span>
        <span v-html="relatedLinks.mentioned"></span>
        {{verbLabel('mentioned')}} mentioned but will not be closed.
      </p>
      <p v-if="relatedLinks.assignToMe">
        <span v-html="relatedLinks.assignToMe"></span>
      </p>
    </section>
  `,
};