138 lines
3.9 KiB
Vue
138 lines
3.9 KiB
Vue
<script>
|
|
/* eslint-disable @gitlab/vue-i18n/no-bare-strings */
|
|
import _ from 'underscore';
|
|
import { GlLink, GlTooltip, GlTooltipDirective } from '@gitlab/ui';
|
|
import { __ } from '~/locale';
|
|
import Icon from '~/vue_shared/components/icon.vue';
|
|
import UserAvatarImage from '~/vue_shared/components/user_avatar/user_avatar_image.vue';
|
|
import TimeagoTooltip from '~/vue_shared/components/time_ago_tooltip.vue';
|
|
import timeago from '~/vue_shared/mixins/timeago';
|
|
|
|
export default {
|
|
components: {
|
|
GlTooltip,
|
|
GlLink,
|
|
Icon,
|
|
UserAvatarImage,
|
|
TimeagoTooltip,
|
|
},
|
|
directives: {
|
|
GlTooltip: GlTooltipDirective,
|
|
},
|
|
mixins: [timeago],
|
|
props: {
|
|
suggestion: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
},
|
|
computed: {
|
|
isOpen() {
|
|
return this.suggestion.state === 'opened';
|
|
},
|
|
isClosed() {
|
|
return this.suggestion.state === 'closed';
|
|
},
|
|
counts() {
|
|
return [
|
|
{
|
|
id: _.uniqueId(),
|
|
icon: 'thumb-up',
|
|
tooltipTitle: __('Upvotes'),
|
|
count: this.suggestion.upvotes,
|
|
},
|
|
{
|
|
id: _.uniqueId(),
|
|
icon: 'comment',
|
|
tooltipTitle: __('Comments'),
|
|
count: this.suggestion.userNotesCount,
|
|
},
|
|
].filter(({ count }) => count);
|
|
},
|
|
stateIcon() {
|
|
return this.isClosed ? 'issue-close' : 'issue-open-m';
|
|
},
|
|
stateTitle() {
|
|
return this.isClosed ? __('Closed') : __('Opened');
|
|
},
|
|
closedOrCreatedDate() {
|
|
return this.suggestion.closedAt || this.suggestion.createdAt;
|
|
},
|
|
hasUpdated() {
|
|
return this.suggestion.updatedAt !== this.suggestion.createdAt;
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<div class="suggestion-item">
|
|
<div class="d-flex align-items-center">
|
|
<icon
|
|
v-if="suggestion.confidential"
|
|
v-gl-tooltip.bottom
|
|
:title="__('Confidential')"
|
|
name="eye-slash"
|
|
class="suggestion-help-hover mr-1 suggestion-confidential"
|
|
/>
|
|
<gl-link :href="suggestion.webUrl" target="_blank" class="suggestion bold str-truncated-100">
|
|
{{ suggestion.title }}
|
|
</gl-link>
|
|
</div>
|
|
<div class="text-secondary suggestion-footer">
|
|
<icon
|
|
ref="state"
|
|
:name="stateIcon"
|
|
:class="{
|
|
'suggestion-state-open': isOpen,
|
|
'suggestion-state-closed': isClosed,
|
|
}"
|
|
class="suggestion-help-hover"
|
|
/>
|
|
<gl-tooltip :target="() => $refs.state" placement="bottom">
|
|
<span class="d-block">
|
|
<span class="bold"> {{ stateTitle }} </span> {{ timeFormated(closedOrCreatedDate) }}
|
|
</span>
|
|
<span class="text-tertiary">{{ tooltipTitle(closedOrCreatedDate) }}</span>
|
|
</gl-tooltip>
|
|
#{{ suggestion.iid }} •
|
|
<timeago-tooltip
|
|
:time="suggestion.createdAt"
|
|
tooltip-placement="bottom"
|
|
class="suggestion-help-hover"
|
|
/>
|
|
by
|
|
<gl-link :href="suggestion.author.webUrl">
|
|
<user-avatar-image
|
|
:img-src="suggestion.author.avatarUrl"
|
|
:size="16"
|
|
css-classes="mr-0 float-none"
|
|
tooltip-placement="bottom"
|
|
class="d-inline-block"
|
|
>
|
|
<span class="bold d-block">{{ __('Author') }}</span> {{ suggestion.author.name }}
|
|
<span class="text-tertiary">@{{ suggestion.author.username }}</span>
|
|
</user-avatar-image>
|
|
</gl-link>
|
|
<template v-if="hasUpdated">
|
|
• {{ __('updated') }}
|
|
<timeago-tooltip
|
|
:time="suggestion.updatedAt"
|
|
tooltip-placement="bottom"
|
|
class="suggestion-help-hover"
|
|
/>
|
|
</template>
|
|
<span class="suggestion-counts">
|
|
<span
|
|
v-for="{ count, icon, tooltipTitle, id } in counts"
|
|
:key="id"
|
|
v-gl-tooltip.bottom
|
|
:title="tooltipTitle"
|
|
class="suggestion-help-hover prepend-left-8 text-tertiary"
|
|
>
|
|
<icon :name="icon" /> {{ count }}
|
|
</span>
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</template>
|