summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/vue_merge_request_widget/components/states/merge_checks_failed.vue
blob: 503ddf8a396206f34d48a14e8caa04d79aff55a5 (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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
<script>
import { GlButton } from '@gitlab/ui';
import { s__ } from '~/locale';
import notesEventHub from '~/notes/event_hub';
import StatusIcon from '../mr_widget_status_icon.vue';

export default {
  i18n: {
    pipelineFailed: s__(
      'mrWidget|The pipeline for this merge request did not complete. Push a new commit to fix the failure.',
    ),
    approvalNeeded: s__('mrWidget|You can only merge once this merge request is approved.'),
    unresolvedDiscussions: s__('mrWidget|Merge blocked: all threads must be resolved.'),
  },
  components: {
    StatusIcon,
    GlButton,
  },
  props: {
    mr: {
      type: Object,
      required: true,
    },
  },
  computed: {
    failedText() {
      if (this.mr.isPipelineFailed) {
        return this.$options.i18n.pipelineFailed;
      } else if (this.mr.approvals && !this.mr.isApproved) {
        return this.$options.i18n.approvalNeeded;
      } else if (this.mr.hasMergeableDiscussionsState) {
        return this.$options.i18n.unresolvedDiscussions;
      }

      return null;
    },
  },
  methods: {
    jumpToFirstUnresolvedDiscussion() {
      notesEventHub.$emit('jumpToFirstUnresolvedDiscussion');
    },
  },
};
</script>

<template>
  <div class="mr-widget-body media gl-flex-wrap">
    <status-icon status="warning" />
    <p class="media-body gl-m-0! gl-font-weight-bold gl-text-black-normal!">
      {{ failedText }}
      <template v-if="failedText == $options.i18n.unresolvedDiscussions">
        <gl-button
          class="gl-ml-3"
          size="small"
          variant="confirm"
          data-testid="jumpToUnresolved"
          @click="jumpToFirstUnresolvedDiscussion"
        >
          {{ s__('mrWidget|Jump to first unresolved thread') }}
        </gl-button>
        <gl-button
          v-if="mr.createIssueToResolveDiscussionsPath"
          :href="mr.createIssueToResolveDiscussionsPath"
          class="gl-ml-3"
          size="small"
          variant="confirm"
          category="secondary"
          data-testid="resolveIssue"
        >
          {{ s__('mrWidget|Create issue to resolve all threads') }}
        </gl-button>
      </template>
    </p>
  </div>
</template>