debian-mirror-gitlab/app/assets/javascripts/pipelines/components/graph/job_group_dropdown.vue
2022-04-04 11:22:00 +05:30

105 lines
2.6 KiB
Vue

<script>
import { reportToSentry } from '../../utils';
import { JOB_DROPDOWN, SINGLE_JOB } from './constants';
import JobItem from './job_item.vue';
/**
* Renders the dropdown for the pipeline graph.
*
* The object provided as `group` corresponds to app/serializers/job_group_entity.rb.
*
*/
export default {
components: {
JobItem,
},
props: {
group: {
type: Object,
required: true,
},
pipelineId: {
type: Number,
required: false,
default: -1,
},
cssClassJobName: {
type: [String, Array],
required: false,
default: '',
},
stageName: {
type: String,
required: false,
default: '',
},
},
jobItemTypes: {
jobDropdown: JOB_DROPDOWN,
singleJob: SINGLE_JOB,
},
computed: {
computedJobId() {
return this.pipelineId > -1 ? `${this.group.name}-${this.pipelineId}` : '';
},
tooltipText() {
const { name, status } = this.group;
return `${name} - ${status.label}`;
},
},
errorCaptured(err, _vm, info) {
reportToSentry('job_group_dropdown', `error: ${err}, info: ${info}`);
},
methods: {
pipelineActionRequestComplete() {
this.$emit('pipelineActionRequestComplete');
},
},
};
</script>
<template>
<!-- eslint-disable @gitlab/vue-no-data-toggle -->
<div
:id="computedJobId"
class="ci-job-dropdown-container dropdown dropright"
data-qa-selector="job_dropdown_container"
>
<button
type="button"
data-toggle="dropdown"
data-display="static"
:class="cssClassJobName"
class="dropdown-menu-toggle gl-pipeline-job-width! gl-pr-4!"
>
<div class="gl-display-flex gl-align-items-stretch gl-justify-content-space-between">
<job-item
:type="$options.jobItemTypes.jobDropdown"
:group-tooltip="tooltipText"
:job="group"
:stage-name="stageName"
/>
<div class="gl-font-weight-100 gl-font-size-lg gl-ml-n4">{{ group.size }}</div>
</div>
</button>
<ul
class="dropdown-menu big-pipeline-graph-dropdown-menu js-grouped-pipeline-dropdown"
data-qa-selector="jobs_dropdown_menu"
>
<li class="scrollable-menu">
<ul>
<li v-for="job in group.jobs" :key="job.id">
<job-item
:dropdown-length="group.size"
:job="job"
:type="$options.jobItemTypes.singleJob"
css-class-job-name="mini-pipeline-graph-dropdown-item"
@pipelineActionRequestComplete="pipelineActionRequestComplete"
/>
</li>
</ul>
</li>
</ul>
</div>
</template>