94 lines
2.1 KiB
Vue
94 lines
2.1 KiB
Vue
|
<script>
|
||
|
import {
|
||
|
GlDropdownSectionHeader,
|
||
|
GlDropdownDivider,
|
||
|
GlDropdownItem,
|
||
|
GlBadge,
|
||
|
GlIcon,
|
||
|
} from '@gitlab/ui';
|
||
|
import { s__ } from '~/locale';
|
||
|
|
||
|
export default {
|
||
|
name: 'MilestoneResultsSection',
|
||
|
components: {
|
||
|
GlDropdownSectionHeader,
|
||
|
GlDropdownDivider,
|
||
|
GlDropdownItem,
|
||
|
GlBadge,
|
||
|
GlIcon,
|
||
|
},
|
||
|
props: {
|
||
|
sectionTitle: {
|
||
|
type: String,
|
||
|
required: true,
|
||
|
},
|
||
|
totalCount: {
|
||
|
type: Number,
|
||
|
required: true,
|
||
|
},
|
||
|
items: {
|
||
|
type: Array,
|
||
|
required: true,
|
||
|
},
|
||
|
selectedMilestones: {
|
||
|
type: Array,
|
||
|
required: true,
|
||
|
default: () => [],
|
||
|
},
|
||
|
error: {
|
||
|
type: Error,
|
||
|
required: false,
|
||
|
default: null,
|
||
|
},
|
||
|
errorMessage: {
|
||
|
type: String,
|
||
|
required: false,
|
||
|
default: '',
|
||
|
},
|
||
|
},
|
||
|
computed: {
|
||
|
totalCountText() {
|
||
|
return this.totalCount > 999 ? s__('TotalMilestonesIndicator|1000+') : `${this.totalCount}`;
|
||
|
},
|
||
|
},
|
||
|
methods: {
|
||
|
isSelectedMilestone(item) {
|
||
|
return this.selectedMilestones.includes(item);
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
</script>
|
||
|
|
||
|
<template>
|
||
|
<div>
|
||
|
<gl-dropdown-section-header>
|
||
|
<div
|
||
|
class="gl-display-flex gl-align-items-center gl-pl-6"
|
||
|
data-testid="milestone-results-section-header"
|
||
|
>
|
||
|
<span class="gl-mr-2 gl-mb-1">{{ sectionTitle }}</span>
|
||
|
<gl-badge variant="neutral">{{ totalCountText }}</gl-badge>
|
||
|
</div>
|
||
|
</gl-dropdown-section-header>
|
||
|
<template v-if="error">
|
||
|
<div class="gl-display-flex align-items-start gl-text-red-500 gl-ml-4 gl-mr-4 gl-mb-3">
|
||
|
<gl-icon name="error" class="gl-mr-2 gl-mt-2 gl-flex-shrink-0" />
|
||
|
<span>{{ errorMessage }}</span>
|
||
|
</div>
|
||
|
</template>
|
||
|
<template v-else>
|
||
|
<gl-dropdown-item
|
||
|
v-for="{ title } in items"
|
||
|
:key="title"
|
||
|
role="milestone option"
|
||
|
@click="$emit('selected', title)"
|
||
|
>
|
||
|
<span class="gl-pl-6" :class="{ 'selected-item': isSelectedMilestone(title) }">
|
||
|
{{ title }}
|
||
|
</span>
|
||
|
</gl-dropdown-item>
|
||
|
<gl-dropdown-divider />
|
||
|
</template>
|
||
|
</div>
|
||
|
</template>
|