97 lines
2.6 KiB
Vue
97 lines
2.6 KiB
Vue
<script>
|
|
import userAvatarImage from '../../vue_shared/components/user_avatar/user_avatar_image.vue';
|
|
import limitWarning from './limit_warning_component.vue';
|
|
import totalTime from './total_time_component.vue';
|
|
import icon from '../../vue_shared/components/icon.vue';
|
|
|
|
export default {
|
|
components: {
|
|
userAvatarImage,
|
|
totalTime,
|
|
limitWarning,
|
|
icon,
|
|
},
|
|
props: {
|
|
items: {
|
|
type: Array,
|
|
default: () => [],
|
|
},
|
|
stage: {
|
|
type: Object,
|
|
default: () => ({}),
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
<template>
|
|
<div>
|
|
<div class="events-description">
|
|
{{ stage.description }}
|
|
<limit-warning :count="items.length" />
|
|
</div>
|
|
<ul class="stage-event-list">
|
|
<li
|
|
v-for="(mergeRequest, i) in items"
|
|
:key="i"
|
|
class="stage-event-item"
|
|
>
|
|
<div class="item-details">
|
|
<!-- FIXME: Pass an alt attribute here for accessibility -->
|
|
<user-avatar-image :img-src="mergeRequest.author.avatarUrl" />
|
|
<h5 class="item-title merge-merquest-title">
|
|
<a :href="mergeRequest.url">
|
|
{{ mergeRequest.title }}
|
|
</a>
|
|
</h5>
|
|
<a
|
|
:href="mergeRequest.url"
|
|
class="issue-link"
|
|
>!{{ mergeRequest.iid }}</a>
|
|
·
|
|
<span>
|
|
{{ s__('OpenedNDaysAgo|Opened') }}
|
|
<a
|
|
:href="mergeRequest.url"
|
|
class="issue-date"
|
|
>{{ mergeRequest.createdAt }}</a>
|
|
</span>
|
|
<span>
|
|
{{ s__('ByAuthor|by') }}
|
|
<a
|
|
:href="mergeRequest.author.webUrl"
|
|
class="issue-author-link"
|
|
>{{ mergeRequest.author.name }}</a>
|
|
</span>
|
|
<template v-if="mergeRequest.state === 'closed'">
|
|
<span class="merge-request-state">
|
|
<i
|
|
class="fa fa-ban"
|
|
aria-hidden="true"
|
|
>
|
|
</i>
|
|
{{ mergeRequest.state.toUpperCase() }}
|
|
</span>
|
|
</template>
|
|
<template v-else>
|
|
<span
|
|
v-if="mergeRequest.branch"
|
|
class="merge-request-branch"
|
|
>
|
|
<icon
|
|
:size="16"
|
|
name="fork"
|
|
/>
|
|
<a :href="mergeRequest.branch.url">
|
|
{{ mergeRequest.branch.name }}
|
|
</a>
|
|
</span>
|
|
</template>
|
|
</div>
|
|
<div class="item-time">
|
|
<total-time :time="mergeRequest.totalTime" />
|
|
</div>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</template>
|