2017-06-13 13:01:59 -04:00
|
|
|
<script>
|
2017-08-02 11:22:38 -04:00
|
|
|
import { mapGetters } from 'vuex';
|
2017-07-26 07:02:01 -04:00
|
|
|
import emojiSmiling from 'icons/_emoji_slightly_smiling_face.svg';
|
|
|
|
import emojiSmile from 'icons/_emoji_smile.svg';
|
|
|
|
import emojiSmiley from 'icons/_emoji_smiley.svg';
|
2017-08-17 19:07:29 -04:00
|
|
|
import editSvg from 'icons/_icon_pencil.svg';
|
|
|
|
import ellipsisSvg from 'icons/_ellipsis_v.svg';
|
2017-12-04 11:19:07 -05:00
|
|
|
import loadingIcon from '~/vue_shared/components/loading_icon.vue';
|
|
|
|
import tooltip from '~/vue_shared/directives/tooltip';
|
2017-06-13 13:01:59 -04:00
|
|
|
|
2017-07-26 07:02:01 -04:00
|
|
|
export default {
|
2017-12-04 11:19:07 -05:00
|
|
|
name: 'noteActions',
|
2017-07-26 07:02:01 -04:00
|
|
|
props: {
|
|
|
|
authorId: {
|
|
|
|
type: Number,
|
|
|
|
required: true,
|
|
|
|
},
|
|
|
|
noteId: {
|
|
|
|
type: Number,
|
|
|
|
required: true,
|
|
|
|
},
|
|
|
|
accessLevel: {
|
|
|
|
type: String,
|
|
|
|
required: false,
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
reportAbusePath: {
|
|
|
|
type: String,
|
|
|
|
required: true,
|
|
|
|
},
|
|
|
|
canEdit: {
|
|
|
|
type: Boolean,
|
|
|
|
required: true,
|
|
|
|
},
|
|
|
|
canDelete: {
|
|
|
|
type: Boolean,
|
|
|
|
required: true,
|
|
|
|
},
|
|
|
|
canReportAsAbuse: {
|
|
|
|
type: Boolean,
|
|
|
|
required: true,
|
|
|
|
},
|
2017-07-07 16:55:44 -04:00
|
|
|
},
|
2017-07-26 12:26:07 -04:00
|
|
|
directives: {
|
|
|
|
tooltip,
|
|
|
|
},
|
2017-07-26 07:02:01 -04:00
|
|
|
components: {
|
|
|
|
loadingIcon,
|
2017-06-13 13:01:59 -04:00
|
|
|
},
|
2017-07-26 07:02:01 -04:00
|
|
|
computed: {
|
2017-08-02 11:22:38 -04:00
|
|
|
...mapGetters([
|
|
|
|
'getUserDataByProp',
|
|
|
|
]),
|
2017-07-26 07:02:01 -04:00
|
|
|
shouldShowActionsDropdown() {
|
2017-07-28 07:53:51 -04:00
|
|
|
return this.currentUserId && (this.canEdit || this.canReportAsAbuse);
|
2017-07-26 07:02:01 -04:00
|
|
|
},
|
|
|
|
canAddAwardEmoji() {
|
2017-07-28 07:53:51 -04:00
|
|
|
return this.currentUserId;
|
2017-07-26 07:02:01 -04:00
|
|
|
},
|
2017-07-28 07:53:51 -04:00
|
|
|
isAuthoredByCurrentUser() {
|
2017-08-02 11:22:38 -04:00
|
|
|
return this.authorId === this.currentUserId;
|
2017-07-26 07:02:01 -04:00
|
|
|
},
|
2017-08-02 11:22:38 -04:00
|
|
|
currentUserId() {
|
|
|
|
return this.getUserDataByProp('id');
|
2017-08-03 07:15:54 -04:00
|
|
|
},
|
2017-06-13 13:01:59 -04:00
|
|
|
},
|
2017-08-08 09:54:43 -04:00
|
|
|
methods: {
|
|
|
|
onEdit() {
|
2017-08-21 12:06:20 -04:00
|
|
|
this.$emit('handleEdit');
|
2017-08-08 09:54:43 -04:00
|
|
|
},
|
|
|
|
onDelete() {
|
2017-08-21 12:06:20 -04:00
|
|
|
this.$emit('handleDelete');
|
2017-08-09 15:13:00 -04:00
|
|
|
},
|
|
|
|
},
|
2017-08-11 07:51:41 -04:00
|
|
|
created() {
|
|
|
|
this.emojiSmiling = emojiSmiling;
|
|
|
|
this.emojiSmile = emojiSmile;
|
|
|
|
this.emojiSmiley = emojiSmiley;
|
2017-08-17 19:07:29 -04:00
|
|
|
this.editSvg = editSvg;
|
|
|
|
this.ellipsisSvg = ellipsisSvg;
|
2017-08-11 14:54:26 -04:00
|
|
|
},
|
2017-07-26 07:02:01 -04:00
|
|
|
};
|
2017-06-13 13:01:59 -04:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<div class="note-actions">
|
2017-06-15 12:02:13 -04:00
|
|
|
<span
|
|
|
|
v-if="accessLevel"
|
2017-12-07 04:11:41 -05:00
|
|
|
class="note-role user-access-role">{{accessLevel}}</span>
|
2017-08-18 11:55:51 -04:00
|
|
|
<div
|
|
|
|
v-if="canAddAwardEmoji"
|
|
|
|
class="note-actions-item">
|
2017-08-17 19:07:29 -04:00
|
|
|
<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">
|
|
|
|
<loading-icon :inline="true" />
|
|
|
|
<span
|
|
|
|
v-html="emojiSmiling"
|
|
|
|
class="link-highlight award-control-icon-neutral">
|
|
|
|
</span>
|
|
|
|
<span
|
|
|
|
v-html="emojiSmiley"
|
|
|
|
class="link-highlight award-control-icon-positive">
|
|
|
|
</span>
|
|
|
|
<span
|
|
|
|
v-html="emojiSmile"
|
|
|
|
class="link-highlight award-control-icon-super-positive">
|
|
|
|
</span>
|
|
|
|
</a>
|
|
|
|
</div>
|
2017-08-18 11:55:51 -04:00
|
|
|
<div
|
|
|
|
v-if="canEdit"
|
|
|
|
class="note-actions-item">
|
2017-08-17 19:07:29 -04:00
|
|
|
<button
|
|
|
|
@click="onEdit"
|
|
|
|
v-tooltip
|
|
|
|
type="button"
|
|
|
|
title="Edit comment"
|
|
|
|
class="note-action-button js-note-edit btn btn-transparent"
|
|
|
|
data-container="body"
|
|
|
|
data-placement="bottom">
|
|
|
|
<span
|
|
|
|
v-html="editSvg"
|
|
|
|
class="link-highlight"></span>
|
|
|
|
</button>
|
|
|
|
</div>
|
2017-07-03 19:20:02 -04:00
|
|
|
<div
|
|
|
|
v-if="shouldShowActionsDropdown"
|
2017-08-17 19:07:29 -04:00
|
|
|
class="dropdown more-actions note-actions-item">
|
2017-06-13 13:01:59 -04:00
|
|
|
<button
|
2017-07-26 12:26:07 -04:00
|
|
|
v-tooltip
|
2017-06-13 13:01:59 -04:00
|
|
|
type="button"
|
|
|
|
title="More actions"
|
2017-07-26 12:26:07 -04:00
|
|
|
class="note-action-button more-actions-toggle btn btn-transparent"
|
2017-06-13 13:01:59 -04:00
|
|
|
data-toggle="dropdown"
|
2017-08-17 19:07:29 -04:00
|
|
|
data-container="body"
|
|
|
|
data-placement="bottom">
|
|
|
|
<span
|
|
|
|
class="icon"
|
|
|
|
v-html="ellipsisSvg"></span>
|
2017-06-13 13:01:59 -04:00
|
|
|
</button>
|
|
|
|
<ul class="dropdown-menu more-actions-dropdown dropdown-open-left">
|
2017-07-03 19:04:58 -04:00
|
|
|
<li v-if="canReportAsAbuse">
|
2017-06-13 13:01:59 -04:00
|
|
|
<a :href="reportAbusePath">
|
|
|
|
Report as abuse
|
|
|
|
</a>
|
|
|
|
</li>
|
2017-07-20 15:12:07 -04:00
|
|
|
<li v-if="canEdit">
|
2017-07-25 15:01:53 -04:00
|
|
|
<button
|
2017-08-08 09:54:43 -04:00
|
|
|
@click.prevent="onDelete"
|
2017-07-20 15:12:07 -04:00
|
|
|
class="btn btn-transparent js-note-delete js-note-delete"
|
|
|
|
type="button">
|
2017-06-13 13:01:59 -04:00
|
|
|
<span class="text-danger">
|
|
|
|
Delete comment
|
|
|
|
</span>
|
2017-07-25 15:01:53 -04:00
|
|
|
</button>
|
2017-06-13 13:01:59 -04:00
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|