611 lines
29 KiB
Vue
611 lines
29 KiB
Vue
<template>
|
||
<view class="view-comment">
|
||
<view style="display: flex;">
|
||
<text class="title">
|
||
{{ title }}
|
||
</text>
|
||
<cover-image @tap="close" style="width: 40rpx;height:40rpx;position: absolute;top:12rpx;z-index:1007;right:12rpx;" src="@/static/images/false.png" ></cover-image>
|
||
</view>
|
||
|
||
<view class="view-conmment-note" v-if="(commentList.length == 0)">
|
||
<image
|
||
src=""
|
||
class="icon-none"
|
||
mode="aspectFit"
|
||
></image>
|
||
<text class="text-conmment-note">暂无评论</text>
|
||
</view>
|
||
<scroll-view scroll-y @scrolltolower="scrollbottom" style="z-index:999;max-height: 800rpx;" v-if="(commentList.length > 0)">
|
||
<view class="view-comment-list" v-for="(item, index) in commentList" :key="index" v-if="(commentList.length > 0)">
|
||
<image :src="item.user_avatar" class="view-comment-list-item-photo" mode="aspectFill"></image>
|
||
<view class="view-comment-list-item">
|
||
<view class="comment-title">
|
||
<text class="comment-name">{{ item.user_nickname }}</text>
|
||
<view style="flex: 1;"></view>
|
||
<image
|
||
v-if="item.IsFabulous == 1"
|
||
class="praise-icon"
|
||
:data-index='index'
|
||
:data-comment_id='item.comment_id'
|
||
@click="onUnCommentLike"
|
||
src=""
|
||
mode="aspectFill"
|
||
></image>
|
||
<image
|
||
v-else
|
||
class="praise-icon"
|
||
:data-index='index'
|
||
:data-comment_id='item.comment_id'
|
||
@click="onCommentLike"
|
||
src=""
|
||
mode="aspectFill"
|
||
></image>
|
||
<text class="praise-num" style="margin-left: 10rpx;">{{ item.comment_like_count }}</text>
|
||
</view>
|
||
<view class="comment-content"><text style="font-size: 30rpx;">{{ item.comment_content }}</text></view>
|
||
<view class="comment-sub">
|
||
<text class="comment-sub-time">{{ item.comment_time }}</text>
|
||
<!-- <view class="comment-sub-recomment" style="color: #999999;" v-if="item.CANDELETE == 1" @click="clickDelete(item)">删除</view>
|
||
<view class="comment-sub-recomment" @click="clickRecomment(item)">回复</view> -->
|
||
</view>
|
||
<view class="comment-child" v-show="item.commentList.length > 0">
|
||
<view class="comment-child-item" v-for="(itemChild, indexChild) in item.commentList" :key="indexChild">
|
||
<text class="comment-child-item-name" @click="clickRecommentChild(itemChild)">{{ itemChild.FIRSTNICKNAME + ':' }}</text>
|
||
<!-- <text class="comment-child-item-content">{{ (itemChild.SECONDNICKNAME ? '回复 ' + itemChild.SECONDNICKNAME + ':' : '') + itemChild.COMMENT }}</text> -->
|
||
<text class="comment-child-item-content" v-if="itemChild.SECONDNICKNAME">回复</text>
|
||
<text class="comment-child-item-content">{{ itemChild.SECONDNICKNAME ? itemChild.SECONDNICKNAME : '' }}</text>
|
||
<text class="comment-child-item-content" v-if="itemChild.SECONDNICKNAME">:</text>
|
||
<text class="comment-child-item-content">{{ itemChild.COMMENT }}</text>
|
||
<text v-if="itemChild.CANDELETE == 1" class="comment-child-item-delete" @click="clickDeleteChild(itemChild)">删除</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</scroll-view>
|
||
<view class="view-conmment-send-bottom" @click.stop="clickComment" style="left:0;width:100%;">
|
||
<view class=" view-comment-textarea" ><cover-view class="textarea-comment">写评论…</cover-view></view>
|
||
</view>
|
||
<five-comment ref="detailComment" @sendComment="sendComment" :placeholder="placeholder"></five-comment>
|
||
</view>
|
||
</template>
|
||
|
||
<script>
|
||
import FiveComment from '../five-comment/five-comment.vue'
|
||
import {
|
||
mapState,
|
||
mapMutations
|
||
} from 'vuex'
|
||
export default {
|
||
name: 'MulCommentList',
|
||
components:{
|
||
FiveComment
|
||
},
|
||
//属性
|
||
props: {
|
||
commentLists: {
|
||
type: Array
|
||
},
|
||
title: {
|
||
type: String,
|
||
default: '网友评论'
|
||
},
|
||
story_id: {
|
||
type: Number,
|
||
default: 0
|
||
},
|
||
user_id: {
|
||
type: Number,
|
||
default: 0
|
||
}
|
||
},
|
||
computed: mapState(['Config', 'StateCode', 'notice', 'plantformInfo', 'shopInfo', 'userInfo', 'hasLogin', '__', '$',
|
||
'sprintf'
|
||
]),
|
||
|
||
data() {
|
||
return {
|
||
//评论组件相关
|
||
placeholder: '请输入评论内容…',
|
||
commentParam: {},
|
||
commentList: [],
|
||
|
||
flag : true,
|
||
ispage : true,
|
||
page:1,
|
||
|
||
winHeight: 0,
|
||
winWidth: 0,
|
||
};
|
||
},
|
||
created: function(e) {
|
||
this.winHeight = uni.getSystemInfoSync().windowHeight;
|
||
this.winWidth = uni.getSystemInfoSync().windowWidth;
|
||
this.updateHeights()
|
||
},
|
||
watch:{
|
||
commentLists(newVal, oldVal){
|
||
this.commentList = this.commentLists
|
||
|
||
|
||
}
|
||
},
|
||
methods: {
|
||
...mapMutations(['logout', 'getPlantformInfo', 'forceUserInfo', 'getStoreInfo']),
|
||
|
||
updateHeights() {
|
||
this.$nextTick(() => {
|
||
uni.createSelectorQuery()
|
||
.in(this)
|
||
.selectAll('.view-comment')
|
||
.boundingClientRect(res => {
|
||
var heights = 0;
|
||
|
||
if (res.length > 0) {
|
||
heights = res.map(item => item.height);
|
||
|
||
}
|
||
|
||
this.updateHeight(this.winHeight - (heights[0] + 43))
|
||
})
|
||
.exec();
|
||
});
|
||
},
|
||
updateHeight(h) {
|
||
// #ifdef MP-WEIXIN
|
||
this.$emit('updata',h);
|
||
// #endif
|
||
},
|
||
clickComment(event) {
|
||
this.commentParam = {
|
||
COMMENT_TIME: '2020-07-07 14:30:01',
|
||
FIRSTNICKNAME: '网友45454545',
|
||
CHILD_ANWSER_LIST: [],
|
||
IS_PRAISE: null,
|
||
PRAISE_NUM: 0,
|
||
CANDELETE: 1,
|
||
HEADIMGURL: 'http://img4.imgtn.bdimg.com/it/u=2858424520,3197172862&fm=11&gp=0.jpg',
|
||
SECONDNICKNAME: null
|
||
};
|
||
event.stopPropagation();
|
||
|
||
this.$refs.detailComment.open();
|
||
},
|
||
sendComment(result) {
|
||
var that = this;
|
||
|
||
if (false)
|
||
{
|
||
that.$.alert(that.__("该帖禁止评论!"))
|
||
}
|
||
else
|
||
{
|
||
|
||
var commentParam = {
|
||
user_id: that.userInfo.user_id,
|
||
story_id: that.story_id,
|
||
comment_content: result,
|
||
comment_reply_id: 0,
|
||
comment_id: 0,
|
||
to_user_id: that.user_id
|
||
};
|
||
|
||
|
||
var params = commentParam
|
||
|
||
that.$.request({
|
||
url: that.Config.URL.sns.story_comment_add,
|
||
data: params,
|
||
success: function (data, status, msg, code) {
|
||
if (200 == status) {
|
||
var date = new Date();
|
||
commentParam.user_nickname = that.userInfo.user_nickname
|
||
commentParam.user_avatar = that.userInfo.user_avatar
|
||
commentParam.comment_like_count = 0
|
||
commentParam.comment_id = data.comment_id
|
||
commentParam.IsFabulous = 0
|
||
commentParam.comment_time = date .toLocaleString()
|
||
commentParam.commentList = []
|
||
that.commentList.unshift(commentParam);
|
||
that.$emit('confirm', 1);
|
||
// that.GetPostsCommentByPostsId()
|
||
} else {
|
||
that.$.alert(msg)
|
||
}
|
||
}
|
||
});
|
||
}
|
||
|
||
console.log(this.commentList)
|
||
},
|
||
|
||
scrollbottom: function(e) {
|
||
if (this.flag) {
|
||
var that = this;
|
||
that.flag = false;
|
||
clearTimeout(n);
|
||
|
||
|
||
/*
|
||
post.sidx = 'product_unit_price';
|
||
post.sord = this.sort == 1 ? 'DESC' : 'ASC';
|
||
*/
|
||
that.page = parseInt(that.page) + 1;
|
||
|
||
var n = setTimeout(function() {
|
||
|
||
that.GetPostsCommentByPostsId();
|
||
}, 500);
|
||
}
|
||
},
|
||
|
||
close(e) {
|
||
this.$emit('closesp');
|
||
},
|
||
|
||
|
||
|
||
|
||
GetPostsCommentByPostsId: function (e) {
|
||
var that = this
|
||
var params = {
|
||
story_id: that.story_id,
|
||
page:that.page,
|
||
sidx: 'comment_time',
|
||
sord: 'DESC',
|
||
};
|
||
that.$.request({
|
||
url: this.Config.URL.sns.story_comment_lists,
|
||
data: params,
|
||
loading: false,
|
||
success: function (data, status, msg, code) {
|
||
if (data.items.length > 0) {
|
||
|
||
for (var r = 0; r < data.items.length; r++) {
|
||
//that.dataComment[r]['comment_time_str'] = dateUtil.dateUtils.format(that.$.datetimeFormatter(that.dataComment[r]['comment_time']));
|
||
|
||
data.items[r]['comment_time_str'] = data.items[r]['comment_time'];
|
||
|
||
data.items[r]['reply_name_str'] = '';
|
||
|
||
for (var j = 0; j < data.items[r]['commentList'].length; j++) {
|
||
data.items[r]['commentList'][j]['comment_reply_time_str'] = dateUtil.dateUtils.format(that.$.datetimeFormatter(data.items[r]['commentList'][j]['comment_reply_time']));
|
||
|
||
//data.items[r]['commentList'][j]['comment_reply_time_str'] = data.items[r]['commentList'][j]['comment_reply_time'];
|
||
|
||
data.items[r]['reply_name_str'] = data.items[r]['commentList'][j]['user_nickname'];
|
||
}
|
||
}
|
||
|
||
if (data.page >= data.total) {
|
||
that.commentList = that.commentList.concat(data.items)
|
||
that.flag = false
|
||
that.ispage = false
|
||
} else {
|
||
that.commentList = that.commentList.concat(data.items)
|
||
that.flag = true
|
||
that.ispage = true
|
||
}
|
||
console.log(that.commentList)
|
||
|
||
} else {
|
||
that.flag = false
|
||
that.ispage = false
|
||
}
|
||
}
|
||
});
|
||
},
|
||
/**
|
||
* 点赞
|
||
* @param {Object} item
|
||
*/
|
||
clickPraise(item) {
|
||
this.$emit('clickPraise', item);
|
||
},
|
||
onUnCommentLike: function (n) {
|
||
let that = this;
|
||
n.stopPropagation();
|
||
that.forceUserInfo(function(user) {
|
||
|
||
var params = {
|
||
comment_id: n.currentTarget.dataset.comment_id
|
||
};
|
||
|
||
that.$.request({
|
||
url: that.Config.URL.sns.story_comment_like_remove,
|
||
data: params,
|
||
success: function (data, status, msg, code) {
|
||
if (200 == status) {
|
||
for (var t = [], e = 0; e < that.commentList.length; e++)
|
||
{
|
||
if (that.commentList[e].comment_id == n.currentTarget.dataset.comment_id)
|
||
{
|
||
var o = that.commentList[e];
|
||
0 == that.commentList[e].IsFabulous ? (o.IsFabulous = 1, o.comment_like_count = o.comment_like_count + 1) : (o.IsFabulous = 0, o.comment_like_count = o.comment_like_count - 1), t.push(o)
|
||
}
|
||
else
|
||
{
|
||
t.push(that.commentList[e]);
|
||
}
|
||
}
|
||
that.commentList= t
|
||
|
||
} else {
|
||
}
|
||
}
|
||
});
|
||
});
|
||
},
|
||
onCommentLike: function (a) {
|
||
let that = this;
|
||
a.stopPropagation();
|
||
that.forceUserInfo(function(user) {
|
||
that.zan(a.currentTarget.dataset.comment_id)
|
||
});
|
||
},
|
||
zan: function (comment_id) {
|
||
var that = this, params = {
|
||
user_id: that.userInfo.user_id,
|
||
/*operateId: that.shopInfo.store_id,*/
|
||
comment_id: comment_id
|
||
};
|
||
|
||
that.$.request({
|
||
url: this.Config.URL.sns.story_comment_like_add,
|
||
data: params,
|
||
success: function (data, status, msg, code) {
|
||
if (200 == status) {
|
||
for (var t = [], e = 0; e < that.commentList.length; e++)
|
||
{
|
||
if (that.commentList[e].comment_id == comment_id)
|
||
{
|
||
var o = that.commentList[e];
|
||
0 == that.commentList[e].IsFabulous ? (o.IsFabulous = 1, o.comment_like_count = o.comment_like_count + 1) : (o.IsFabulous = 0, o.comment_like_count = o.comment_like_count - 1), t.push(o)
|
||
}
|
||
else
|
||
{
|
||
t.push(that.commentList[e]);
|
||
}
|
||
}
|
||
|
||
that.commentList= t
|
||
} else {
|
||
}
|
||
}
|
||
});
|
||
},
|
||
/**
|
||
* 回复 评论
|
||
* @param {Object} item
|
||
*/
|
||
clickRecomment(item) {
|
||
this.$emit('clickRecomment', item);
|
||
},
|
||
/**
|
||
* 删除评论
|
||
* @param {Object} item
|
||
clickDelete(item) {
|
||
this.$emit('clickDelete', item);
|
||
},
|
||
/**
|
||
* 删除评论
|
||
* @param {Object} item
|
||
*/
|
||
clickDeleteChild(item) {
|
||
this.$emit('clickDeleteChild', item);
|
||
},
|
||
/**
|
||
* 回复评论的评论
|
||
* @param {Object} item
|
||
*/
|
||
clickRecommentChild(item) {
|
||
this.$emit('clickRecommentChild', item);
|
||
}
|
||
}
|
||
};
|
||
</script>
|
||
|
||
<style scoped>
|
||
@import '@/styles/iconfont.css';
|
||
.view-comment {
|
||
width: 750rpx;
|
||
background-color: white;
|
||
margin-top: 20rpx;
|
||
display: flex;
|
||
flex-direction: column;
|
||
position: fixed;
|
||
padding: 30rpx;
|
||
bottom: 100rpx;
|
||
max-height: 1000rpx;
|
||
/* #ifdef APP-PLUS-NVUE */
|
||
bottom: 100rpx;
|
||
/* #endif */
|
||
|
||
z-index:9999;
|
||
|
||
|
||
}
|
||
|
||
.title {
|
||
width: 100%;
|
||
color: #333;
|
||
font-weight: bold;
|
||
font-size: 34rpx;
|
||
}
|
||
.praise-icon {
|
||
height: 40rpx;
|
||
width: 40rpx;
|
||
font-size: 36rpx;
|
||
color: #999;
|
||
}
|
||
.praise-num {
|
||
font-size: 26rpx;
|
||
color: #999;
|
||
}
|
||
|
||
.view-conmment-note {
|
||
display: flex;
|
||
flex-direction: column;
|
||
justify-content: center;
|
||
align-items: center;
|
||
flex: 1;
|
||
padding-bottom: 20rpx;
|
||
}
|
||
.icon-none {
|
||
width: 200rpx;
|
||
height: 200rpx;
|
||
color: #bbbbbb;
|
||
}
|
||
.text-conmment-note {
|
||
color: #808080;
|
||
font-size: 32rpx;
|
||
margin-top: 30rpx;
|
||
}
|
||
|
||
.border-line {
|
||
border-bottom-style: solid ;
|
||
border-bottom-width: 1px;
|
||
border-bottom-color: #f6f6f6;
|
||
}
|
||
.view-comment-list {
|
||
width: 100%;
|
||
display: flex;
|
||
flex-direction: row;
|
||
background-color: white;
|
||
padding: 20rpx 0;
|
||
border-bottom-style: solid ;
|
||
border-bottom-width: 1px;
|
||
border-bottom-color: #f6f6f6;
|
||
}
|
||
.view-comment-list-item-photo {
|
||
height: 80rpx;
|
||
width: 80rpx;
|
||
border-radius: 40rpx;
|
||
border: 1px solid #f6f6f6;
|
||
}
|
||
.view-comment-list-item {
|
||
margin-left: 16rpx;
|
||
display: flex;
|
||
flex: 1;
|
||
flex-direction: column;
|
||
}
|
||
.comment-name {
|
||
color: #666;
|
||
font-size: 32rpx;
|
||
display: flex;
|
||
align-items: center;
|
||
}
|
||
.comment-title {
|
||
align-items: center;
|
||
display: flex;
|
||
width:594rpx;
|
||
height: 60rpx;
|
||
flex-direction: row;
|
||
justify-content : space-between;
|
||
}
|
||
|
||
.comment-content {
|
||
color: #000000;
|
||
width:596rpx;
|
||
font-size: 26rpx;
|
||
font-weight: 500;
|
||
padding:10rpx 0;
|
||
}
|
||
|
||
|
||
.comment-sub {
|
||
display: flex;
|
||
align-items: center;
|
||
flex-direction: row;
|
||
|
||
}
|
||
|
||
.comment-sub-time {
|
||
color: #999;
|
||
font-size: 26rpx;
|
||
}
|
||
.comment-sub-recomment {
|
||
color: #666;
|
||
font-size: 28rpx;
|
||
padding: 0 0 0 20rpx;
|
||
}
|
||
.comment-child {
|
||
background-color: #f8f8f8;
|
||
border-radius: 10rpx;
|
||
padding: 0 20rpx;
|
||
}
|
||
.comment-child-item {
|
||
flex-wrap: wrap;
|
||
margin: 15rpx 0;
|
||
display: flex;
|
||
align-items: center;
|
||
flex-direction: row;
|
||
|
||
}
|
||
.comment-child-item-name {
|
||
white-space: nowrap;
|
||
font-size: 30rpx;
|
||
color: #5074cf;
|
||
}
|
||
.comment-child-item-content {
|
||
font-size: 30rpx;
|
||
text-align: center;
|
||
}
|
||
.comment-child-item-delete {
|
||
font-size: 28rpx;
|
||
color: #999999;
|
||
margin-left: 30rpx;
|
||
text-align: center;
|
||
}
|
||
|
||
.view-conmment-send-bottom {
|
||
width: 750rpx;
|
||
position: fixed;
|
||
bottom: 0;
|
||
display: flex;
|
||
flex-direction: row;
|
||
background-color: white;
|
||
border-top: 1px solid #fbfbfb;
|
||
z-index:999;
|
||
}
|
||
|
||
.view-comment-textarea {
|
||
background-color: #f8f8f8;
|
||
border-radius: 40rpx;
|
||
padding: 15rpx 20rpx;
|
||
margin: 25rpx 20rpx;
|
||
width: 700rpx;
|
||
/* flex: 1;
|
||
align-items: center; */
|
||
}
|
||
.textarea-comment {
|
||
padding: 0;
|
||
width: 100%;
|
||
/* height: 100%; */
|
||
font-size: $uni-font-size-base;
|
||
/* color: $uni-text-color; */
|
||
color: $uni-text-sub-color;
|
||
}
|
||
|
||
.icon-comment {
|
||
font-size: 46rpx;
|
||
color: $uni-text-color;
|
||
margin: 0 30rpx 0 5rpx;
|
||
}
|
||
.view-btn-comment {
|
||
display: flex;
|
||
justify-content: center;
|
||
align-items: center;
|
||
font-size: $uni-font-size-base;
|
||
color: white;
|
||
height: 70rpx;
|
||
width: 120rpx;
|
||
border-radius: 10rpx;
|
||
background-color: $theme-color;
|
||
font-weight: 500;
|
||
}
|
||
.textarea-bottom {
|
||
background-color: white;
|
||
padding: 20rpx;
|
||
}
|
||
</style>
|