gitlab-org--gitlab-foss/app/assets/javascripts/notes/components/toggle_replies_widget.vue

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

91 lines
2.4 KiB
Vue
Raw Normal View History

2018-11-08 02:58:45 -05:00
<script>
import { GlButton, GlIcon } from '@gitlab/ui';
import { uniqBy } from 'lodash';
2018-11-08 02:58:45 -05:00
import TimeAgoTooltip from '~/vue_shared/components/time_ago_tooltip.vue';
import UserAvatarLink from '~/vue_shared/components/user_avatar/user_avatar_link.vue';
2018-11-08 02:58:45 -05:00
export default {
components: {
GlButton,
GlIcon,
2018-11-08 02:58:45 -05:00
UserAvatarLink,
TimeAgoTooltip,
},
props: {
collapsed: {
type: Boolean,
required: true,
},
replies: {
type: Array,
required: true,
},
},
computed: {
lastReply() {
return this.replies[this.replies.length - 1];
},
uniqueAuthors() {
const authors = this.replies.map((reply) => reply.author || {});
2018-11-08 02:58:45 -05:00
return uniqBy(authors, (author) => author.username);
2018-11-08 02:58:45 -05:00
},
className() {
return this.collapsed ? 'collapsed' : 'expanded';
},
},
methods: {
toggle() {
this.$emit('toggle');
},
},
ICON_CLASS: 'gl-mr-3 gl-cursor-pointer',
2018-11-08 02:58:45 -05:00
};
</script>
<template>
<li
:class="className"
class="replies-toggle js-toggle-replies gl-display-flex! gl-align-items-center gl-flex-wrap"
>
2018-11-08 02:58:45 -05:00
<template v-if="collapsed">
<gl-icon :class="$options.ICON_CLASS" name="chevron-right" @click.native="toggle" />
2018-11-08 02:58:45 -05:00
<div>
<user-avatar-link
v-for="author in uniqueAuthors"
:key="author.username"
:link-href="author.path"
:img-alt="author.name"
:img-src="author.avatar_url"
:img-size="24"
2018-11-08 02:58:45 -05:00
:tooltip-text="author.name"
tooltip-placement="bottom"
/>
</div>
<gl-button
class="js-replies-text gl-mr-2"
category="tertiary"
variant="link"
data-qa-selector="expand_replies_button"
@click="toggle"
>
2018-11-08 02:58:45 -05:00
{{ replies.length }} {{ n__('reply', 'replies', replies.length) }}
</gl-button>
2018-11-08 02:58:45 -05:00
{{ __('Last reply by') }}
<a :href="lastReply.author.path" class="btn btn-link author-link gl-mx-2 gl-button">
2018-11-08 02:58:45 -05:00
{{ lastReply.author.name }}
</a>
2018-11-16 15:07:38 -05:00
<time-ago-tooltip :time="lastReply.created_at" tooltip-placement="bottom" />
2018-11-08 02:58:45 -05:00
</template>
<div
2019-01-03 09:57:51 -05:00
v-else
class="collapse-replies-btn js-collapse-replies gl-display-flex align-items-center"
data-qa-selector="collapse_replies_button"
2019-01-03 09:57:51 -05:00
@click="toggle"
>
<gl-icon :class="$options.ICON_CLASS" name="chevron-down" />
<span class="gl-cursor-pointer">{{ s__('Notes|Collapse replies') }}</span>
</div>
2018-11-08 02:58:45 -05:00
</li>
</template>