sidebar.vue 7.2 KB
Newer Older
1
<script>
2 3
import _ from 'underscore';
import { mapActions, mapState } from 'vuex';
C
Clement Ho 已提交
4
import { GlLink, GlButton } from '@gitlab/ui';
5 6 7 8 9 10 11 12 13
import timeagoMixin from '~/vue_shared/mixins/timeago';
import { timeIntervalInWords } from '~/lib/utils/datetime_utility';
import Icon from '~/vue_shared/components/icon.vue';
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';
14

15 16 17 18 19 20 21 22 23 24
export default {
  name: 'JobSidebar',
  components: {
    ArtifactsBlock,
    CommitBlock,
    DetailRow,
    Icon,
    TriggerBlock,
    StagesDropdown,
    JobsContainer,
25 26
    GlLink,
    GlButton,
27 28 29 30 31 32 33
  },
  mixins: [timeagoMixin],
  props: {
    runnerHelpUrl: {
      type: String,
      required: false,
      default: '',
34
    },
35 36
  },
  computed: {
37
    ...mapState(['job', 'stages', 'jobs', 'selectedStage', 'isLoadingStages']),
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
    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() {
      let className =
        'js-retry-button float-right btn btn-retry d-none d-md-block d-lg-block d-xl-block';
      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 '';
      }
64

65 66 67 68
      let t = this.job.metadata.timeout_human_readable;
      if (this.job.metadata.timeout_source !== '') {
        t += ` (from ${this.job.metadata.timeout_source})`;
      }
69

70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
      return t;
    },
    renderBlock() {
      return (
        this.job.merge_request ||
        this.job.duration ||
        this.job.finished_data ||
        this.job.erased_at ||
        this.job.queued ||
        this.job.runner ||
        this.job.coverage ||
        this.job.tags.length ||
        this.job.cancel_path
      );
    },
    hasArtifact() {
      return !_.isEmpty(this.job.artifact);
    },
    hasTriggers() {
      return !_.isEmpty(this.job.trigger);
    },
    hasStages() {
      return (
        (this.job &&
          this.job.pipeline &&
          this.job.pipeline.stages &&
          this.job.pipeline.stages.length > 0) ||
        false
      );
99
    },
100
    commit() {
101
      return this.job.pipeline && this.job.pipeline.commit ? this.job.pipeline.commit : {};
102
    },
103 104
  },
  methods: {
105
    ...mapActions(['fetchJobsForStage', 'toggleSidebar']),
106 107
  },
};
108 109
</script>
<template>
M
Mike Greiling 已提交
110
  <aside class="right-sidebar build-sidebar" data-offset-top="101" data-spy="affix">
111 112
    <div class="sidebar-container">
      <div class="blocks-container">
113
        <div class="block">
M
Mike Greiling 已提交
114
          <strong class="inline prepend-top-8"> {{ job.name }} </strong>
115
          <gl-link
116 117 118 119 120
            v-if="job.retry_path"
            :class="retryButtonClass"
            :href="job.retry_path"
            data-method="post"
            rel="nofollow"
121
          >
122
            {{ __('Retry') }}
123 124
          </gl-link>
          <gl-link
125 126 127 128 129 130
            v-if="job.terminal_path"
            :href="job.terminal_path"
            class="js-terminal-link pull-right btn btn-primary
      btn-inverted visible-md-block visible-lg-block"
            target="_blank"
          >
M
Mike Greiling 已提交
131
            {{ __('Debug') }} <icon name="external-link" />
132 133
          </gl-link>
          <gl-button
134 135 136 137 138 139
            :aria-label="__('Toggle Sidebar')"
            type="button"
            class="btn btn-blank gutter-toggle
        float-right d-block d-md-none js-sidebar-build-toggle"
            @click="toggleSidebar"
          >
M
Mike Greiling 已提交
140
            <i aria-hidden="true" data-hidden="true" class="fa fa-angle-double-right"></i>
141
          </gl-button>
142
        </div>
M
Mike Greiling 已提交
143
        <div v-if="job.retry_path || job.new_issue_path" class="block retry-link">
144
          <gl-link
145 146 147 148 149
            v-if="job.new_issue_path"
            :href="job.new_issue_path"
            class="js-new-issue btn btn-success btn-inverted"
          >
            {{ __('New issue') }}
150 151
          </gl-link>
          <gl-link
152 153 154 155 156 157 158
            v-if="job.retry_path"
            :href="job.retry_path"
            class="js-retry-job btn btn-inverted-secondary"
            data-method="post"
            rel="nofollow"
          >
            {{ __('Retry') }}
159
          </gl-link>
160
        </div>
M
Mike Greiling 已提交
161 162 163 164
        <div :class="{ block: renderBlock }">
          <p v-if="job.merge_request" class="build-detail-row js-job-mr">
            <span class="build-light-text"> {{ __('Merge Request:') }} </span>
            <gl-link :href="job.merge_request.path"> !{{ job.merge_request.iid }} </gl-link>
165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184
          </p>

          <detail-row
            v-if="job.duration"
            :value="duration"
            class="js-job-duration"
            title="Duration"
          />
          <detail-row
            v-if="job.finished_at"
            :value="timeFormated(job.finished_at)"
            class="js-job-finished"
            title="Finished"
          />
          <detail-row
            v-if="job.erased_at"
            :value="timeFormated(job.erased_at)"
            class="js-job-erased"
            title="Erased"
          />
M
Mike Greiling 已提交
185
          <detail-row v-if="job.queued" :value="queued" class="js-job-queued" title="Queued" />
186 187 188 189 190 191 192
          <detail-row
            v-if="hasTimeout"
            :help-url="runnerHelpUrl"
            :value="timeout"
            class="js-job-timeout"
            title="Timeout"
          />
M
Mike Greiling 已提交
193
          <detail-row v-if="job.runner" :value="runnerId" class="js-job-runner" title="Runner" />
194 195 196 197 198 199
          <detail-row
            v-if="job.coverage"
            :value="coverage"
            class="js-job-coverage"
            title="Coverage"
          />
M
Mike Greiling 已提交
200 201
          <p v-if="job.tags.length" class="build-detail-row js-job-tags">
            <span class="build-light-text"> {{ __('Tags:') }} </span>
202
            <span v-for="(tag, i) in job.tags" :key="i" class="badge badge-primary">
203 204 205 206
              {{ tag }}
            </span>
          </p>

M
Mike Greiling 已提交
207
          <div v-if="job.cancel_path" class="btn-group prepend-top-5" role="group">
208
            <gl-link
209 210
              :href="job.cancel_path"
              class="js-cancel-job btn btn-sm btn-default"
211 212 213
              data-method="post"
              rel="nofollow"
            >
214
              {{ __('Cancel') }}
215
            </gl-link>
216
          </div>
217
        </div>
218

M
Mike Greiling 已提交
219 220
        <artifacts-block v-if="hasArtifact" :artifact="job.artifact" />
        <trigger-block v-if="hasTriggers" :trigger="job.trigger" />
221 222 223 224 225
        <commit-block
          :is-last-block="hasStages"
          :commit="commit"
          :merge-request="job.merge_request"
        />
226

227
        <stages-dropdown
228
          v-if="!isLoadingStages"
229 230 231 232
          :stages="stages"
          :pipeline="job.pipeline"
          :selected-stage="selectedStage"
          @requestSidebarStageDropdown="fetchJobsForStage"
233 234 235
        />
      </div>

M
Mike Greiling 已提交
236
      <jobs-container v-if="jobs.length" :jobs="jobs" :job-id="job.id" />
237 238 239
    </div>
  </aside>
</template>