2021-07-21 15:49:51 +05:30
|
|
|
<template>
|
2021-12-27 20:16:26 +05:30
|
|
|
<div class="comment flex">
|
2021-10-09 00:22:51 +05:30
|
|
|
<img
|
|
|
|
:src="comment.thumbnail"
|
2021-12-27 20:16:26 +05:30
|
|
|
class="comment-avatar rounded-full uk-margin-right"
|
2021-11-02 01:53:04 +05:30
|
|
|
height="48"
|
|
|
|
width="48"
|
2021-10-28 23:25:20 +05:30
|
|
|
style="width: 48px; height: 48px"
|
2021-10-09 00:22:51 +05:30
|
|
|
loading="lazy"
|
|
|
|
alt="Avatar"
|
|
|
|
/>
|
2021-07-21 15:49:51 +05:30
|
|
|
|
2021-10-09 00:22:51 +05:30
|
|
|
<div class="comment-content">
|
|
|
|
<div class="comment-header">
|
|
|
|
<div v-if="comment.pinned" class="comment-pinned uk-text-meta">
|
|
|
|
<font-awesome-icon icon="thumbtack"></font-awesome-icon> {{ $t("comment.pinned_by") }}
|
|
|
|
{{ uploader }}
|
|
|
|
</div>
|
2021-07-21 15:49:51 +05:30
|
|
|
|
2021-10-09 00:22:51 +05:30
|
|
|
<div class="comment-author">
|
2021-12-27 20:16:26 +05:30
|
|
|
<router-link class="font-bold uk-text-small" :to="comment.commentorUrl">
|
2021-10-09 00:22:51 +05:30
|
|
|
{{ comment.author }} </router-link
|
|
|
|
> <font-awesome-icon v-if="comment.verified" icon="check"></font-awesome-icon>
|
|
|
|
</div>
|
|
|
|
<div class="comment-meta uk-text-meta uk-margin-small-bottom">
|
|
|
|
{{ comment.commentedTime }}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="comment-body" style="white-space: pre-wrap">
|
|
|
|
{{ comment.commentText }}
|
|
|
|
</div>
|
|
|
|
<div class="comment-footer uk-margin-small-top uk-text-meta">
|
2021-10-28 23:25:20 +05:30
|
|
|
<font-awesome-icon icon="thumbs-up" style="margin-right: 4px"></font-awesome-icon>
|
2021-10-09 00:22:51 +05:30
|
|
|
<span>{{ numberFormat(comment.likeCount) }}</span>
|
|
|
|
|
|
|
|
<font-awesome-icon v-if="comment.hearted" icon="heart"></font-awesome-icon>
|
|
|
|
</div>
|
2021-11-04 16:22:28 +05:30
|
|
|
<template v-if="comment.repliesPage && (!loadingReplies || !showingReplies)">
|
2021-11-02 01:53:04 +05:30
|
|
|
<div @click="loadReplies">
|
2021-11-04 16:22:28 +05:30
|
|
|
<a class="uk-link-text" v-t="'actions.show_replies'" />
|
2021-11-02 01:53:04 +05:30
|
|
|
|
2021-11-04 16:22:28 +05:30
|
|
|
<font-awesome-icon icon="level-down-alt" />
|
2021-11-02 01:53:04 +05:30
|
|
|
</div>
|
2021-11-04 16:22:28 +05:30
|
|
|
</template>
|
|
|
|
<template v-if="showingReplies">
|
|
|
|
<div @click="hideReplies">
|
|
|
|
<a class="uk-link-text" v-t="'actions.hide_replies'" />
|
|
|
|
|
|
|
|
<font-awesome-icon icon="level-up-alt" />
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
<div v-show="showingReplies" v-if="replies" class="replies uk-width-4-5@xl uk-width-3-4@s uk-width-1">
|
2021-11-02 01:53:04 +05:30
|
|
|
<div
|
|
|
|
v-for="reply in replies"
|
|
|
|
:key="reply.commentId"
|
|
|
|
class="uk-tile-default uk-align-left uk-width-expand"
|
|
|
|
>
|
|
|
|
<Comment :comment="reply" :uploader="uploader" :video-id="videoId" />
|
|
|
|
</div>
|
|
|
|
<div v-if="nextpage" @click="loadReplies">
|
2021-11-04 16:22:28 +05:30
|
|
|
<a class="uk-link-text" v-t="'actions.load_more_replies'" />
|
2021-11-02 01:53:04 +05:30
|
|
|
|
2021-11-04 16:22:28 +05:30
|
|
|
<font-awesome-icon icon="level-down-alt" />
|
2021-11-02 01:53:04 +05:30
|
|
|
</div>
|
|
|
|
</div>
|
2021-07-21 15:49:51 +05:30
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2021-10-09 00:22:51 +05:30
|
|
|
export default {
|
2021-07-21 15:49:51 +05:30
|
|
|
props: {
|
2021-10-09 00:22:51 +05:30
|
|
|
comment: {
|
|
|
|
type: Object,
|
|
|
|
default: () => {
|
|
|
|
return {};
|
|
|
|
},
|
|
|
|
},
|
|
|
|
uploader: { type: String, default: null },
|
2021-11-02 01:53:04 +05:30
|
|
|
videoId: { type: String, default: null },
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
2021-11-04 16:22:28 +05:30
|
|
|
loadingReplies: false,
|
|
|
|
showingReplies: false,
|
2021-11-02 01:53:04 +05:30
|
|
|
replies: [],
|
|
|
|
nextpage: null,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
methods: {
|
2021-11-04 16:22:28 +05:30
|
|
|
async loadReplies() {
|
|
|
|
if (!this.showingReplies && this.loadingReplies) {
|
|
|
|
this.showingReplies = true;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.loadingReplies = true;
|
|
|
|
this.showingReplies = true;
|
2021-11-02 01:53:04 +05:30
|
|
|
this.fetchJson(this.apiUrl() + "/nextpage/comments/" + this.videoId, {
|
|
|
|
nextpage: this.nextpage || this.comment.repliesPage,
|
|
|
|
}).then(json => {
|
|
|
|
this.replies = this.replies.concat(json.comments);
|
|
|
|
this.nextpage = json.nextpage;
|
|
|
|
});
|
|
|
|
},
|
2021-11-04 16:22:28 +05:30
|
|
|
async hideReplies() {
|
|
|
|
this.showingReplies = false;
|
|
|
|
},
|
2021-10-09 00:22:51 +05:30
|
|
|
},
|
|
|
|
};
|
|
|
|
</script>
|