debian-mirror-gitlab/app/assets/javascripts/notes/components/note_actions.vue

256 lines
5.9 KiB
Vue
Raw Normal View History

2018-03-17 18:26:18 +05:30
<script>
2018-05-09 12:01:36 +05:30
import { mapGetters } from 'vuex';
2018-12-05 23:21:45 +05:30
import Icon from '~/vue_shared/components/icon.vue';
2018-05-09 12:01:36 +05:30
import tooltip from '~/vue_shared/directives/tooltip';
2018-12-13 13:39:08 +05:30
import { GlLoadingIcon } from '@gitlab-org/gitlab-ui';
2018-03-17 18:26:18 +05:30
2018-05-09 12:01:36 +05:30
export default {
name: 'NoteActions',
2018-12-05 23:21:45 +05:30
components: {
Icon,
2018-12-13 13:39:08 +05:30
GlLoadingIcon,
2018-12-05 23:21:45 +05:30
},
2018-05-09 12:01:36 +05:30
directives: {
tooltip,
},
props: {
authorId: {
type: Number,
required: true,
},
noteId: {
2018-12-05 23:21:45 +05:30
type: [String, Number],
2018-05-09 12:01:36 +05:30
required: true,
},
2018-11-08 19:23:39 +05:30
noteUrl: {
type: String,
2018-11-20 20:47:30 +05:30
required: false,
default: '',
2018-11-08 19:23:39 +05:30
},
2018-05-09 12:01:36 +05:30
accessLevel: {
type: String,
required: false,
default: '',
},
reportAbusePath: {
type: String,
2018-12-05 23:21:45 +05:30
required: false,
default: null,
2018-05-09 12:01:36 +05:30
},
canEdit: {
type: Boolean,
required: true,
},
canAwardEmoji: {
type: Boolean,
required: true,
},
canDelete: {
type: Boolean,
required: true,
},
2018-11-08 19:23:39 +05:30
canResolve: {
type: Boolean,
required: false,
default: false,
},
2018-05-09 12:01:36 +05:30
resolvable: {
type: Boolean,
required: false,
default: false,
},
isResolved: {
type: Boolean,
required: false,
default: false,
},
isResolving: {
type: Boolean,
required: false,
default: false,
},
resolvedBy: {
type: Object,
required: false,
default: () => ({}),
},
canReportAsAbuse: {
type: Boolean,
required: true,
},
},
computed: {
...mapGetters(['getUserDataByProp']),
shouldShowActionsDropdown() {
return this.currentUserId && (this.canEdit || this.canReportAsAbuse);
},
2018-12-05 23:21:45 +05:30
showDeleteAction() {
return this.canDelete && !this.canReportAsAbuse && !this.noteUrl;
},
2018-05-09 12:01:36 +05:30
isAuthoredByCurrentUser() {
return this.authorId === this.currentUserId;
},
currentUserId() {
return this.getUserDataByProp('id');
},
resolveButtonTitle() {
let title = 'Mark as resolved';
2018-03-27 19:54:05 +05:30
2018-05-09 12:01:36 +05:30
if (this.resolvedBy) {
title = `Resolved by ${this.resolvedBy.name}`;
}
2018-03-27 19:54:05 +05:30
2018-05-09 12:01:36 +05:30
return title;
},
},
methods: {
onEdit() {
this.$emit('handleEdit');
},
onDelete() {
this.$emit('handleDelete');
},
onResolve() {
this.$emit('handleResolve');
},
},
};
2018-03-17 18:26:18 +05:30
</script>
<template>
<div class="note-actions">
<span
v-if="accessLevel"
class="note-role user-access-role">
{{ accessLevel }}
</span>
2018-03-27 19:54:05 +05:30
<div
2018-11-08 19:23:39 +05:30
v-if="canResolve"
2018-03-27 19:54:05 +05:30
class="note-actions-item">
<button
v-tooltip
:class="{ 'is-disabled': !resolvable, 'is-active': isResolved }"
:title="resolveButtonTitle"
:aria-label="resolveButtonTitle"
type="button"
2018-11-08 19:23:39 +05:30
class="line-resolve-btn note-action-button"
@click="onResolve">
2018-03-27 19:54:05 +05:30
<template v-if="!isResolving">
2018-12-13 13:39:08 +05:30
<icon name="check-circle" />
2018-03-27 19:54:05 +05:30
</template>
2018-12-05 23:21:45 +05:30
<gl-loading-icon
2018-03-27 19:54:05 +05:30
v-else
2018-12-05 23:21:45 +05:30
inline
2018-03-27 19:54:05 +05:30
/>
</button>
</div>
2018-03-17 18:26:18 +05:30
<div
2018-05-09 12:01:36 +05:30
v-if="canAwardEmoji"
2018-03-17 18:26:18 +05:30
class="note-actions-item">
<a
v-tooltip
:class="{ 'js-user-authored': isAuthoredByCurrentUser }"
class="note-action-button note-emoji-button js-add-award js-note-emoji"
data-position="right"
data-placement="bottom"
data-container="body"
href="#"
title="Add reaction"
>
2018-12-05 23:21:45 +05:30
<gl-loading-icon inline/>
2018-12-13 13:39:08 +05:30
<icon
css-classes="link-highlight award-control-icon-neutral"
name="emoji_slightly_smiling_face"
/>
<icon
css-classes="link-highlight award-control-icon-positive"
name="emoji_smiley"
/>
<icon
css-classes="link-highlight award-control-icon-super-positive"
name="emoji_smiley"
/>
2018-03-17 18:26:18 +05:30
</a>
</div>
<div
v-if="canEdit"
class="note-actions-item">
<button
v-tooltip
type="button"
title="Edit comment"
class="note-action-button js-note-edit btn btn-transparent"
data-container="body"
2018-11-08 19:23:39 +05:30
data-placement="bottom"
@click="onEdit">
2018-12-13 13:39:08 +05:30
<icon
name="pencil"
css-classes="link-highlight"
/>
2018-03-17 18:26:18 +05:30
</button>
</div>
<div
2018-12-05 23:21:45 +05:30
v-if="showDeleteAction"
class="note-actions-item"
>
<button
v-tooltip
type="button"
title="Delete comment"
class="note-action-button js-note-delete btn btn-transparent"
data-container="body"
data-placement="bottom"
@click="onDelete"
>
<icon
name="remove"
class="link-highlight"
/>
</button>
</div>
<div
v-else-if="shouldShowActionsDropdown"
2018-03-17 18:26:18 +05:30
class="dropdown more-actions note-actions-item">
<button
v-tooltip
type="button"
title="More actions"
class="note-action-button more-actions-toggle btn btn-transparent"
data-toggle="dropdown"
data-container="body"
data-placement="bottom">
2018-12-13 13:39:08 +05:30
<icon
css-classes="icon"
name="ellipsis_v"
/>
2018-03-17 18:26:18 +05:30
</button>
<ul class="dropdown-menu more-actions-dropdown dropdown-open-left">
<li v-if="canReportAsAbuse">
<a :href="reportAbusePath">
2018-12-13 13:39:08 +05:30
{{ __('Report abuse to GitLab') }}
2018-03-17 18:26:18 +05:30
</a>
</li>
2018-11-20 20:47:30 +05:30
<li v-if="noteUrl">
2018-11-08 19:23:39 +05:30
<button
:data-clipboard-text="noteUrl"
type="button"
2018-11-20 20:47:30 +05:30
class="btn-default btn-transparent js-btn-copy-note-link"
2018-11-08 19:23:39 +05:30
>
2018-12-13 13:39:08 +05:30
{{ __('Copy link') }}
2018-11-08 19:23:39 +05:30
</button>
</li>
2018-03-17 18:26:18 +05:30
<li v-if="canEdit">
<button
class="btn btn-transparent js-note-delete js-note-delete"
2018-11-08 19:23:39 +05:30
type="button"
@click.prevent="onDelete">
2018-03-17 18:26:18 +05:30
<span class="text-danger">
2018-12-13 13:39:08 +05:30
{{ __('Delete comment') }}
2018-03-17 18:26:18 +05:30
</span>
</button>
</li>
</ul>
</div>
</div>
</template>