362 lines
8.9 KiB
Vue
362 lines
8.9 KiB
Vue
|
<template>
|
|||
|
<view>
|
|||
|
<view class="main">
|
|||
|
<view class="tab-cont">
|
|||
|
<view v-if="featuredList.length" class="follow_count">
|
|||
|
<block v-for="(item, index) in featuredList" :key="index">
|
|||
|
<view class="list_count">
|
|||
|
<view v-if="item.author" class="title">
|
|||
|
<view class="author">
|
|||
|
<image class="picture" :src="item.author.avatar || '/static/images/f.png'"></image>
|
|||
|
<text class="name">{{item.author.nickname}}</text>
|
|||
|
</view>
|
|||
|
<view @click="followAuthor(item)">
|
|||
|
<view v-if="!item.relevance_id" class="follow focus">
|
|||
|
<text class="iconfont icon-jiahao2"></text>关注
|
|||
|
</view>
|
|||
|
<view v-else class="follow focused">已关注</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<view class="product">
|
|||
|
<productConSwiper :imgUrls="item.image"></productConSwiper>
|
|||
|
</view>
|
|||
|
<view class="pro_describle">
|
|||
|
<view class="mentioned" v-if="item.relevance.length>0" @click="openMore(item)">
|
|||
|
<text class="title">查看TA提到的宝贝({{item.relevance.length}})</text>
|
|||
|
<view class="product_more">
|
|||
|
<view class="item">
|
|||
|
<image v-for="(itemn, indexn) in item.relevance" :key="indexn" :src="(itemn.spu&&itemn.spu.image)||itemn.image" class="more_image"></image>
|
|||
|
</view>
|
|||
|
<text class="iconfont icon-gengduo3"></text>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<view class="product_info">
|
|||
|
<text class="text">
|
|||
|
{{item.content}}
|
|||
|
</text>
|
|||
|
<text class="unfold_btn">展开</text>
|
|||
|
</view>
|
|||
|
<navigator v-if="item.topic" hover-class="none" class="product_cate" :url="'/pages/plantGrass/plant_search_list/index?id='+item.topic.topic_id">
|
|||
|
<view>
|
|||
|
<text class="icon">#</text><text class="text">{{item.topic.topic_name}}</text>
|
|||
|
</view>
|
|||
|
</navigator>
|
|||
|
<view class="foot_bar">
|
|||
|
<view class="item iconfont icon-fenxiang2"></view>
|
|||
|
<view class="item">
|
|||
|
<view class="item_count" @click.stop="likeToggle(item)">
|
|||
|
<text class="iconfont" :class="item.relevance_id ? 'icon-shoucang1' : 'icon-dianzan'"></text>
|
|||
|
<text>{{item.count_start > 0 ? item.count_start : '点赞'}}</text>
|
|||
|
</view>
|
|||
|
|
|||
|
<view class="item_count" @click="openCommon(item,index)">
|
|||
|
<text class="iconfont icon-pinglun"></text>
|
|||
|
<text>{{item.count_reply ? item.count_reply : '评论'}}</text>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</block>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
</view>
|
|||
|
<!-- 他提到的宝贝弹窗 -->
|
|||
|
<uni-popup ref="mentioned" type="bottom">
|
|||
|
<mentioned @close="close" :list="moreList"></mentioned>
|
|||
|
</uni-popup>
|
|||
|
<!-- 评论弹窗 -->
|
|||
|
<comment ref="comment" :isShow="showComment" @close="close" @successFul="commentSucces"></comment>
|
|||
|
|
|||
|
</view>
|
|||
|
|
|||
|
</template>
|
|||
|
|
|||
|
<script>
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
// | Copyright (c) 2016~2024 https://www.crmeb.com All rights reserved.
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
// | Author: CRMEB Team <admin@crmeb.com>
|
|||
|
// +----------------------------------------------------------------------
|
|||
|
import WaterfallsFlow from '@/components/plantWaterfallsFlow/WaterfallsFlow.vue'
|
|||
|
import mentioned from '@/components/mentioned.vue';
|
|||
|
import comment from '@/components/comment.vue';
|
|||
|
import {graphicLstApi, graphicStartApi, followAuthorApi} from '@/api/community.js';
|
|||
|
import { getUserInfo } from '@/api/user.js';
|
|||
|
import { mapGetters } from "vuex";
|
|||
|
import productConSwiper from '@/components/productConSwiper';
|
|||
|
const app = getApp();
|
|||
|
export default {
|
|||
|
components: {
|
|||
|
WaterfallsFlow,
|
|||
|
productConSwiper,
|
|||
|
mentioned,
|
|||
|
comment
|
|||
|
},
|
|||
|
data() {
|
|||
|
return {
|
|||
|
featuredList: [], // 商铺商品
|
|||
|
moreList: [],
|
|||
|
commList: [], //评论列表
|
|||
|
loading: false,
|
|||
|
loaded: false,
|
|||
|
loadTitle: '加载更多',
|
|||
|
where: {
|
|||
|
topic_id: '',
|
|||
|
page: 1,
|
|||
|
limit: 30
|
|||
|
},
|
|||
|
showComment: false,
|
|||
|
}
|
|||
|
},
|
|||
|
created() {
|
|||
|
|
|||
|
},
|
|||
|
computed: {
|
|||
|
...mapGetters(['isLogin']),
|
|||
|
},
|
|||
|
watch: {
|
|||
|
|
|||
|
},
|
|||
|
onLoad: function(options) {
|
|||
|
this.where.topic_id = options.id
|
|||
|
this.getList();
|
|||
|
},
|
|||
|
onShow() {
|
|||
|
|
|||
|
},
|
|||
|
mounted: function() {
|
|||
|
},
|
|||
|
methods: {
|
|||
|
// 获取关注商品
|
|||
|
getList: function() {
|
|||
|
let that = this;
|
|||
|
if (that.loaded || that.loading) return;
|
|||
|
that.loading = true;
|
|||
|
that.loadTitle = '';
|
|||
|
graphicLstApi(that.where).then(res => {
|
|||
|
that.loading = false;
|
|||
|
let list = res.data.list;
|
|||
|
let featuredList = that.$util.SplitArray(list, that.featuredList);
|
|||
|
that.loaded = list.length < that.where.limit;
|
|||
|
that.loadTitle = loaded ? '已全部加载' : '加载更多';
|
|||
|
that.$set(that, 'featuredList', featuredList);
|
|||
|
that.$set(that.where, 'page', that.where.page + 1);
|
|||
|
}).catch(err => {
|
|||
|
that.loading = false;
|
|||
|
uni.showToast({
|
|||
|
title: err,
|
|||
|
icon: 'none'
|
|||
|
})
|
|||
|
});
|
|||
|
},
|
|||
|
likeToggle(item){
|
|||
|
let status = item.relevance_id ? 0 : 1
|
|||
|
graphicStartApi(item.community_id,{status: status}).then(res => {
|
|||
|
if(item.relevance_id){
|
|||
|
item.count_start--;
|
|||
|
item.count_start = item.count_start == 0 ? 0 : item.count_start
|
|||
|
item.relevance_id = false
|
|||
|
}else{
|
|||
|
item.count_start++;
|
|||
|
item.relevance_id = true
|
|||
|
}
|
|||
|
});
|
|||
|
},
|
|||
|
// 关注作者
|
|||
|
followAuthor: function(item) {
|
|||
|
let status = item.relevance_id ? 0 : 1
|
|||
|
followAuthorApi(item.uid,{status: status}).then(res => {
|
|||
|
if (res.status === 200) {
|
|||
|
item.relevance_id = item.relevance_id ? false : true
|
|||
|
}
|
|||
|
this.$util.Tips({
|
|||
|
title: res.message
|
|||
|
});
|
|||
|
});
|
|||
|
},
|
|||
|
/*查看提到的宝贝*/
|
|||
|
openMore(item){
|
|||
|
this.$refs.mentioned.open();
|
|||
|
this.moreList = item.relevance;
|
|||
|
},
|
|||
|
openCommon(item,index){
|
|||
|
this.showComment = true
|
|||
|
this.$refs.comment.getData(item,index);
|
|||
|
},
|
|||
|
commentSucces(index){
|
|||
|
this.featuredList[index]['count_reply']++
|
|||
|
},
|
|||
|
close(){
|
|||
|
this.$refs.mentioned.close();
|
|||
|
this.showComment = false;
|
|||
|
}
|
|||
|
},
|
|||
|
onReachBottom() {
|
|||
|
this.getList();
|
|||
|
},
|
|||
|
onPullDownRefresh(){
|
|||
|
|
|||
|
}
|
|||
|
}
|
|||
|
</script>
|
|||
|
|
|||
|
<style lang="scss" scoped>
|
|||
|
.main{
|
|||
|
background: #ffffff;
|
|||
|
min-height: 100vh;
|
|||
|
}
|
|||
|
.tab-cont{
|
|||
|
background: #fff;
|
|||
|
border-radius: 16rpx 16rpx 0 0;
|
|||
|
}
|
|||
|
.follow_count{
|
|||
|
padding: 20rpx;
|
|||
|
.list_count{
|
|||
|
margin-bottom: 70rpx;
|
|||
|
}
|
|||
|
.title{
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
justify-content: space-between;
|
|||
|
}
|
|||
|
.author{
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
.picture, uni-image{
|
|||
|
width: 78rpx;
|
|||
|
height: 78rpx;
|
|||
|
border-radius: 100%;
|
|||
|
}
|
|||
|
.name{
|
|||
|
margin-left: 20rpx;
|
|||
|
color: #333333;
|
|||
|
font-size: 32rpx;
|
|||
|
font-weight: bold;
|
|||
|
}
|
|||
|
}
|
|||
|
.follow{
|
|||
|
margin-right: 10rpx;
|
|||
|
width: 112rpx;
|
|||
|
text-align: center;
|
|||
|
line-height: 42rpx;
|
|||
|
font-size: 22rpx;
|
|||
|
border-radius: 33rpx;
|
|||
|
&.focus{
|
|||
|
color: #E93323;
|
|||
|
border: 1px solid #E93323;
|
|||
|
.iconfont{
|
|||
|
font-size: 15rpx;
|
|||
|
margin-right: 5rpx;
|
|||
|
}
|
|||
|
}
|
|||
|
&.focused{
|
|||
|
background: #EEEEEE;
|
|||
|
border: 1px solid #EEEEEE;
|
|||
|
color: #999999;
|
|||
|
}
|
|||
|
}
|
|||
|
.product{
|
|||
|
margin-top: 20rpx;
|
|||
|
border-radius: 16rpx;
|
|||
|
}
|
|||
|
}
|
|||
|
.pro_describle{
|
|||
|
.mentioned{
|
|||
|
padding: 20rpx 0;
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
justify-content: space-between;
|
|||
|
border-bottom: 1px solid #F5F5F5;
|
|||
|
.title{
|
|||
|
color: #666666;
|
|||
|
font-size: 26rpx;
|
|||
|
}
|
|||
|
}
|
|||
|
.product_more{
|
|||
|
max-width: 360rpx;
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
.more_image{
|
|||
|
width: 58rpx;
|
|||
|
height: 58rpx;
|
|||
|
border-radius: 5rpx;
|
|||
|
border: 1px solid #BBBBBB;
|
|||
|
margin-right: 12rpx;
|
|||
|
}
|
|||
|
.iconfont{
|
|||
|
color: #CCCCCC;
|
|||
|
margin-left: 10rpx;
|
|||
|
}
|
|||
|
}
|
|||
|
.product_info{
|
|||
|
line-height: 45rpx;
|
|||
|
margin: 20rpx 0;
|
|||
|
.text{
|
|||
|
font-size: 28rpx;
|
|||
|
color: #282828;
|
|||
|
}
|
|||
|
.unfold_btn{
|
|||
|
margin-left: 30rpx;
|
|||
|
font-size: 30rpx;
|
|||
|
color: #282828;
|
|||
|
font-weight: bold;
|
|||
|
}
|
|||
|
}
|
|||
|
.product_cate{
|
|||
|
margin: 20rpx 0;
|
|||
|
display: inline-block;
|
|||
|
>view{
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
background: #FFF3F2;
|
|||
|
border-radius: 30rpx;
|
|||
|
padding: 0 25rpx;
|
|||
|
line-height: 56rpx;
|
|||
|
height: 56rpx;
|
|||
|
color: #E93323;
|
|||
|
.text{
|
|||
|
font-size: 28rpx;
|
|||
|
}
|
|||
|
.icon{
|
|||
|
font-size: 35rpx;
|
|||
|
font-weight: bold;
|
|||
|
margin-right: 10rpx;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
.foot_bar{
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
justify-content: space-between;
|
|||
|
.item{
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
color: #282828;
|
|||
|
&.icon-fenxiang2{
|
|||
|
font-size: 46rpx;
|
|||
|
}
|
|||
|
}
|
|||
|
.item_count{
|
|||
|
font-size: 26rpx;
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
&:first-child{
|
|||
|
margin-right: 30rpx;
|
|||
|
}
|
|||
|
.iconfont{
|
|||
|
font-size: 40rpx;
|
|||
|
margin-right: 5rpx;
|
|||
|
}
|
|||
|
.icon-shoucang1{
|
|||
|
color: #E93323;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
</style>
|