sidebar.vue 6.7 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
    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 已提交
51
      let className = 'js-retry-button btn btn-retry';
52 53 54 55 56 57 58 59 60 61 62
      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 '';
      }
63

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

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
      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
      );
98
    },
99
    commit() {
100
      return this.job.pipeline && this.job.pipeline.commit ? this.job.pipeline.commit : {};
101
    },
102 103
  },
  methods: {
104
    ...mapActions(['fetchJobsForStage', 'toggleSidebar']),
105 106
  },
};
107 108
</script>
<template>
M
Mike Greiling 已提交
109
  <aside class="right-sidebar build-sidebar" data-offset-top="101" data-spy="affix">
110 111
    <div class="sidebar-container">
      <div class="blocks-container">
F
Fernando Arias 已提交
112
        <div class="block d-flex flex-nowrap align-items-center">
113
          <h4 class="my-0 mr-2 text-break-word">{{ job.name }}</h4>
F
Fernando Arias 已提交
114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132
          <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"
              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>

133
          <gl-button
134 135
            :aria-label="__('Toggle Sidebar')"
            type="button"
136
            class="btn btn-blank gutter-toggle float-right d-block d-md-none js-sidebar-build-toggle"
137 138
            @click="toggleSidebar"
          >
M
Mike Greiling 已提交
139
            <i aria-hidden="true" data-hidden="true" class="fa fa-angle-double-right"></i>
140
          </gl-button>
141
        </div>
F
Fernando Arias 已提交
142 143

        <div v-if="job.terminal_path || job.new_issue_path" class="block retry-link">
144
          <gl-link
145 146
            v-if="job.new_issue_path"
            :href="job.new_issue_path"
F
Fernando Arias 已提交
147
            class="js-new-issue btn btn-success btn-inverted float-left mr-2"
148
            >{{ __('New issue') }}</gl-link
149
          >
150
          <gl-link
F
Fernando Arias 已提交
151 152 153 154
            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"
155
          >
F
Fernando Arias 已提交
156 157
            {{ __('Debug') }} <icon name="external-link" :size="14" />
          </gl-link>
158
        </div>
F
Fernando Arias 已提交
159

M
Mike Greiling 已提交
160
        <div :class="{ block: renderBlock }">
161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178
          <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 已提交
179
          <detail-row v-if="job.queued" :value="queued" class="js-job-queued" title="Queued" />
180 181 182 183 184 185 186
          <detail-row
            v-if="hasTimeout"
            :help-url="runnerHelpUrl"
            :value="timeout"
            class="js-job-timeout"
            title="Timeout"
          />
M
Mike Greiling 已提交
187
          <detail-row v-if="job.runner" :value="runnerId" class="js-job-runner" title="Runner" />
188 189 190 191 192 193
          <detail-row
            v-if="job.coverage"
            :value="coverage"
            class="js-job-coverage"
            title="Coverage"
          />
M
Mike Greiling 已提交
194
          <p v-if="job.tags.length" class="build-detail-row js-job-tags">
195 196 197 198
            <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>
199 200
          </p>
        </div>
201

M
Mike Greiling 已提交
202 203
        <artifacts-block v-if="hasArtifact" :artifact="job.artifact" />
        <trigger-block v-if="hasTriggers" :trigger="job.trigger" />
204 205 206 207 208
        <commit-block
          :is-last-block="hasStages"
          :commit="commit"
          :merge-request="job.merge_request"
        />
209

210
        <stages-dropdown
211
          v-if="!isLoadingStages"
212 213 214 215
          :stages="stages"
          :pipeline="job.pipeline"
          :selected-stage="selectedStage"
          @requestSidebarStageDropdown="fetchJobsForStage"
216 217 218
        />
      </div>

M
Mike Greiling 已提交
219
      <jobs-container v-if="jobs.length" :jobs="jobs" :job-id="job.id" />
220 221 222
    </div>
  </aside>
</template>