Update PostComments component

This commit is contained in:
Daniel Supernault 2019-02-10 22:22:46 -07:00
parent f8dea80eeb
commit 022581f71b
No known key found for this signature in database
GPG key ID: 0DEF1C662C9033F7

View file

@ -17,27 +17,14 @@
<div class="postCommentsContainer d-none"> <div class="postCommentsContainer d-none">
<p class="mb-1 text-center load-more-link d-none"><a href="#" class="text-muted" v-on:click="loadMore">Load more comments</a></p> <p class="mb-1 text-center load-more-link d-none"><a href="#" class="text-muted" v-on:click="loadMore">Load more comments</a></p>
<div class="comments" data-min-id="0" data-max-id="0"> <div class="comments" data-min-id="0" data-max-id="0">
<p class="mb-1" v-for="(comment, index) in results" :data-id="comment.id" :key="comment.id"> <p v-for="(reply, index) in results" class="mb-0 d-flex justify-content-between align-items-top read-more" style="overflow-y: hidden;">
<span class="d-flex justify-content-between align-items-center"> <span>
<span class="pr-3" style="overflow: hidden;"> <a class="text-dark font-weight-bold mr-1" :href="reply.account.url">{{reply.account.username}}</a>
<div class="font-weight-bold pr-1"><bdi><a class="text-dark" :href="comment.account.url" :title="comment.account.username">{{l(comment.account.username)}}</a></bdi> <span v-html="reply.content" class=""></span>
</div> </span>
<div class="read-more" style="overflow: hidden;" :id="comment.id + '-reply-readmore'"> <span class="" style="min-width:38px">
<span class="comment-text" v-html="comment.content" style="overflow: hidden;"></span> <span v-on:click="likeStatus(reply, $event)"><i v-bind:class="[reply.favourited ? 'fas fa-heart fa-sm text-danger':'far fa-heart fa-sm text-lighter']"></i></span>
</div> <post-menu :status="reply" :profile="user" :size="'sm'" :modal="'true'" class="d-inline-block pl-2"></post-menu>
</span>
<b-dropdown :id="comment.uri" variant="link" no-caret right class="float-right">
<template slot="button-content">
<i class="fas fa-ellipsis-v text-muted"></i><span class="sr-only">Options</span>
</template>
<b-dropdown-item class="font-weight-bold" v-on:click="reply(comment)">Reply</b-dropdown-item>
<b-dropdown-item class="font-weight-bold" :href="comment.url">Permalink</b-dropdown-item>
<!-- <b-dropdown-item class="font-weight-bold" v-on:click="embed(comment)">Embed</b-dropdown-item> -->
<b-dropdown-item class="font-weight-bold" :href="comment.account.url">Profile</b-dropdown-item>
<b-dropdown-divider></b-dropdown-divider>
<b-dropdown-item class="font-weight-bold" :href="'/i/report?type=post&id='+comment.id">Report</b-dropdown-item>
<b-dropdown-item class="font-weight-bold" v-on:click="deleteComment(comment.id, index)" v-if="comment.account.id == user.id">Delete</b-dropdown-item>
</b-dropdown>
</span> </span>
</p> </p>
</div> </div>
@ -45,6 +32,12 @@
</div> </div>
</template> </template>
<style type="text/css" scoped>
.text-lighter {
color:#B8C2CC !important;
}
</style>
<script> <script>
export default { export default {
props: ['post-id', 'post-username', 'user'], props: ['post-id', 'post-username', 'user'],
@ -142,7 +135,25 @@ export default {
} }
this.pagination = response.data.meta.pagination; this.pagination = response.data.meta.pagination;
}); });
},
likeStatus(status, $event) {
if($('body').hasClass('loggedIn') == false) {
return;
}
axios.post('/i/like', {
item: status.id
}).then(res => {
status.favourites_count = res.data.count;
if(status.favourited == true) {
status.favourited = false;
} else {
status.favourited = true;
}
}).catch(err => {
swal('Error', 'Something went wrong, please try again later.', 'error');
});
} }
} },
} }
</script> </script>