sidebar.vue 7.0 KB
Newer Older
1
<script>
2
import { isEmpty } from 'lodash';
3
import { mapActions, mapState } from 'vuex';
4
import { GlLink, GlDeprecatedButton, GlIcon } from '@gitlab/ui';
5
import { __, sprintf } from '~/locale';
6
import timeagoMixin from '~/vue_shared/mixins/timeago';
7
import TooltipOnTruncate from '~/vue_shared/components/tooltip_on_truncate.vue';
8 9 10 11 12 13 14
import { timeIntervalInWords } from '~/lib/utils/datetime_utility';
import DetailRow from './sidebar_detail_row.vue';
import ArtifactsBlock from './artifacts_block.vue';
import TriggerBlock from './trigger_block.vue';
import CommitBlock from './commit_block.vue';
import StagesDropdown from './stages_dropdown.vue';
import JobsContainer from './jobs_container.vue';
15

16 17 18 19 20 21
export default {
  name: 'JobSidebar',
  components: {
    ArtifactsBlock,
    CommitBlock,
    DetailRow,
22
    GlIcon,
23 24 25
    TriggerBlock,
    StagesDropdown,
    JobsContainer,
26
    GlLink,
27
    GlDeprecatedButton,
28
    TooltipOnTruncate,
29 30 31 32 33 34 35
  },
  mixins: [timeagoMixin],
  props: {
    runnerHelpUrl: {
      type: String,
      required: false,
      default: '',
36
    },
37 38
  },
  computed: {
39
    ...mapState(['job', 'stages', 'jobs', 'selectedStage']),
40 41 42 43 44 45 46 47 48 49 50 51 52
    coverage() {
      return `${this.job.coverage}%`;
    },
    duration() {
      return timeIntervalInWords(this.job.duration);
    },
    queued() {
      return timeIntervalInWords(this.job.queued);
    },
    runnerId() {
      return `${this.job.runner.description} (#${this.job.runner.id})`;
    },
    retryButtonClass() {
F
Fernando Arias 已提交
53
      let className = 'js-retry-button btn btn-retry';
54 55 56 57 58 59 60 61 62 63 64
      className +=
        this.job.status && this.job.recoverable ? ' btn-primary' : ' btn-inverted-secondary';
      return className;
    },
    hasTimeout() {
      return this.job.metadata != null && this.job.metadata.timeout_human_readable !== null;
    },
    timeout() {
      if (this.job.metadata == null) {
        return '';
      }
65

66 67
      let t = this.job.metadata.timeout_human_readable;
      if (this.job.metadata.timeout_source !== '') {
68 69 70
        t += sprintf(__(` (from %{timeoutSource})`), {
          timeoutSource: this.job.metadata.timeout_source,
        });
71
      }
72

73 74 75 76 77
      return t;
    },
    renderBlock() {
      return (
        this.job.duration ||
78
        this.job.finished_at ||
79 80
        this.job.erased_at ||
        this.job.queued ||
81
        this.hasTimeout ||
82 83
        this.job.runner ||
        this.job.coverage ||
84
        this.job.tags.length
85 86 87
      );
    },
    hasArtifact() {
88
      return !isEmpty(this.job.artifact);
89 90
    },
    hasTriggers() {
91
      return !isEmpty(this.job.trigger);
92 93 94 95 96 97 98 99 100
    },
    hasStages() {
      return (
        (this.job &&
          this.job.pipeline &&
          this.job.pipeline.stages &&
          this.job.pipeline.stages.length > 0) ||
        false
      );
101
    },
102
    commit() {
103
      return this.job.pipeline && this.job.pipeline.commit ? this.job.pipeline.commit : {};
104
    },
105 106
  },
  methods: {
107
    ...mapActions(['fetchJobsForStage', 'toggleSidebar']),
108 109
  },
};
110 111
</script>
<template>
M
Mike Greiling 已提交
112
  <aside class="right-sidebar build-sidebar" data-offset-top="101" data-spy="affix">
113 114
    <div class="sidebar-container">
      <div class="blocks-container">
F
Fernando Arias 已提交
115
        <div class="block d-flex flex-nowrap align-items-center">
116 117 118 119 120
          <tooltip-on-truncate :title="job.name" truncate-target="child"
            ><h4 class="my-0 mr-2 gl-text-truncate">
              {{ job.name }}
            </h4>
          </tooltip-on-truncate>
F
Fernando Arias 已提交
121 122 123 124 125 126
          <div class="flex-grow-1 flex-shrink-0 text-right">
            <gl-link
              v-if="job.retry_path"
              :class="retryButtonClass"
              :href="job.retry_path"
              data-method="post"
127
              data-qa-selector="retry_button"
F
Fernando Arias 已提交
128 129 130 131 132 133 134 135 136 137 138 139 140
              rel="nofollow"
              >{{ __('Retry') }}</gl-link
            >
            <gl-link
              v-if="job.cancel_path"
              :href="job.cancel_path"
              class="js-cancel-job btn btn-default"
              data-method="post"
              rel="nofollow"
              >{{ __('Cancel') }}</gl-link
            >
          </div>

141
          <gl-deprecated-button
142 143
            :aria-label="__('Toggle Sidebar')"
            type="button"
144
            class="btn btn-blank gutter-toggle float-right d-block d-md-none js-sidebar-build-toggle"
145 146
            @click="toggleSidebar"
          >
M
Mike Greiling 已提交
147
            <i aria-hidden="true" data-hidden="true" class="fa fa-angle-double-right"></i>
148
          </gl-deprecated-button>
149
        </div>
F
Fernando Arias 已提交
150 151

        <div v-if="job.terminal_path || job.new_issue_path" class="block retry-link">
152
          <gl-link
153 154
            v-if="job.new_issue_path"
            :href="job.new_issue_path"
155 156
            class="btn btn-success btn-inverted float-left mr-2"
            data-testid="job-new-issue"
157
            >{{ __('New issue') }}</gl-link
158
          >
159
          <gl-link
F
Fernando Arias 已提交
160 161 162 163
            v-if="job.terminal_path"
            :href="job.terminal_path"
            class="js-terminal-link btn btn-primary btn-inverted visible-md-block visible-lg-block float-left"
            target="_blank"
164
          >
165
            {{ __('Debug') }} <gl-icon name="external-link" :size="14" />
F
Fernando Arias 已提交
166
          </gl-link>
167
        </div>
F
Fernando Arias 已提交
168

169
        <div v-if="renderBlock" class="block">
170 171 172 173 174 175 176 177
          <detail-row
            v-if="job.duration"
            :value="duration"
            class="js-job-duration"
            title="Duration"
          />
          <detail-row
            v-if="job.finished_at"
178
            :value="timeFormatted(job.finished_at)"
179 180 181 182 183
            class="js-job-finished"
            title="Finished"
          />
          <detail-row
            v-if="job.erased_at"
184
            :value="timeFormatted(job.erased_at)"
185 186 187
            class="js-job-erased"
            title="Erased"
          />
M
Mike Greiling 已提交
188
          <detail-row v-if="job.queued" :value="queued" class="js-job-queued" title="Queued" />
189 190 191 192 193 194 195
          <detail-row
            v-if="hasTimeout"
            :help-url="runnerHelpUrl"
            :value="timeout"
            class="js-job-timeout"
            title="Timeout"
          />
M
Mike Greiling 已提交
196
          <detail-row v-if="job.runner" :value="runnerId" class="js-job-runner" title="Runner" />
197 198 199 200 201 202
          <detail-row
            v-if="job.coverage"
            :value="coverage"
            class="js-job-coverage"
            title="Coverage"
          />
M
Mike Greiling 已提交
203
          <p v-if="job.tags.length" class="build-detail-row js-job-tags">
204 205 206 207
            <span class="font-weight-bold">{{ __('Tags:') }}</span>
            <span v-for="(tag, i) in job.tags" :key="i" class="badge badge-primary mr-1">{{
              tag
            }}</span>
208 209
          </p>
        </div>
210

M
Mike Greiling 已提交
211 212
        <artifacts-block v-if="hasArtifact" :artifact="job.artifact" />
        <trigger-block v-if="hasTriggers" :trigger="job.trigger" />
213 214 215 216 217
        <commit-block
          :is-last-block="hasStages"
          :commit="commit"
          :merge-request="job.merge_request"
        />
218

219 220 221 222 223
        <stages-dropdown
          :stages="stages"
          :pipeline="job.pipeline"
          :selected-stage="selectedStage"
          @requestSidebarStageDropdown="fetchJobsForStage"
224 225 226
        />
      </div>

M
Mike Greiling 已提交
227
      <jobs-container v-if="jobs.length" :jobs="jobs" :job-id="job.id" />
228 229 230
    </div>
  </aside>
</template>