You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
248 lines
7.0 KiB
248 lines
7.0 KiB
<template>
|
|
<view class="wf-page">
|
|
<!--left-->
|
|
<view>
|
|
<view id="left" v-if="leftList.length">
|
|
<view v-for="(item,index) in leftList" :key="index"
|
|
class="wf-item" @tap="itemTap(item)">
|
|
<WaterfallsFlowItem :item="item" :isAuth="isAuth" :uid="uid" :isShow="isShow" :tab="tab" @likeToggle="(item)=>likeToggle(false, index, item)"/>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<!--right-->
|
|
<view>
|
|
<view id="right" v-if="rightList.length">
|
|
<view v-for="(item,index) in rightList" :key="index"
|
|
class="wf-item" @tap="itemTap(item)">
|
|
<WaterfallsFlowItem :item="item" :isAuth="isAuth" :uid="uid" :isShow="isShow" :tab="tab" @likeToggle="(item)=>likeToggle(true, index, item)"/>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<authorize @onLoadFun="onLoadFun" :isAuto="isAuto" :isShowAuth="isShowAuth" @authColse="authColse"></authorize>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import WaterfallsFlowItem from '../plantWaterfallsFlowItem/WaterfallsFlowItem.vue'
|
|
import { graphicStartApi } from '@/api/community.js';
|
|
import authorize from '@/components/Authorize';
|
|
import { mapGetters } from "vuex";
|
|
export default {
|
|
components: {
|
|
WaterfallsFlowItem,
|
|
authorize,
|
|
},
|
|
props: {
|
|
// 瀑布流列表
|
|
wfList: {
|
|
type: Array,
|
|
require: true
|
|
},
|
|
updateNum: {
|
|
type: Number,
|
|
default: 10
|
|
},
|
|
isAuth: {
|
|
type: Boolean,
|
|
default: false
|
|
},
|
|
tab: {
|
|
type: Number,
|
|
default: 1
|
|
},
|
|
uid: {
|
|
type: Number,
|
|
default: 0
|
|
},
|
|
isShow: {
|
|
type: Boolean,
|
|
default: false
|
|
},
|
|
},
|
|
data() {
|
|
return {
|
|
allList: [], // 全部列表
|
|
leftList: [], // 左边列表
|
|
rightList: [], // 右边列表
|
|
mark: 0, // 列表标记
|
|
boxHeight: [], // 下标0和1分别为左列和右列高度
|
|
isShowAuth: false,
|
|
isAuto: false
|
|
};
|
|
},
|
|
watch: {
|
|
// 监听列表数据变化
|
|
'wfList.length': {
|
|
handler(nVal,oVal){
|
|
// 如果数据为空或新的列表数据少于旧的列表数据(通常为下拉刷新或切换排序或使用筛选器),初始化变量
|
|
if (!this.wfList.length ||
|
|
(this.wfList.length === this.updateNum && this.wfList.length <= this.allList.length)) {
|
|
this.allList = [];
|
|
this.leftList = [];
|
|
this.rightList = [];
|
|
this.boxHeight = [];
|
|
this.mark = 0;
|
|
}
|
|
// 如果列表有值,调用waterfall方法
|
|
if (this.wfList.length) {
|
|
this.allList = this.wfList;
|
|
this.leftList = [];
|
|
this.rightList = [];
|
|
this.boxHeight = [];
|
|
this.allList.forEach((v, i) => {
|
|
if(this.allList.length < 3 || (this.allList.length <= 7 && this.allList.length - i > 1) || (this.allList.length > 7 && this.allList.length - i > 2)) {
|
|
if(i % 2){
|
|
this.rightList.push(v);
|
|
}else{
|
|
this.leftList.push(v);
|
|
}
|
|
}
|
|
});
|
|
if(this.allList.length < 3){
|
|
this.mark = this.allList.length+1;
|
|
}else if(this.allList.length <= 7){
|
|
this.mark = this.allList.length - 1;
|
|
}else{
|
|
this.mark = this.allList.length - 2;
|
|
}
|
|
if(this.mark < this.allList.length){
|
|
this.waterFall()
|
|
}
|
|
}
|
|
},
|
|
immediate: true,
|
|
deep:true
|
|
},
|
|
mounted(){
|
|
},
|
|
// 监听标记,当标记发生变化,则执行下一个item排序
|
|
mark() {
|
|
const len = this.allList.length;
|
|
if (this.mark < len && this.mark !== 0 && this.boxHeight.length) {
|
|
this.waterFall();
|
|
}
|
|
}
|
|
},
|
|
computed: {
|
|
...mapGetters(['isLogin']),
|
|
},
|
|
methods: {
|
|
// 瀑布流排序
|
|
waterFall() {
|
|
const i = this.mark;
|
|
if(!this.allList[i]) return ;
|
|
if (i == 0) {
|
|
// 初始化,从左边开始插入
|
|
this.leftList.push(this.allList[i]);
|
|
// 更新左边列表高度
|
|
this.getViewHeight(0);
|
|
} else if (i == 1) {
|
|
// 第二个item插入,默认为右边插入
|
|
this.rightList.push(this.allList[i]);
|
|
// 更新右边列表高度
|
|
this.getViewHeight(1);
|
|
} else {
|
|
// 根据左右列表高度判断下一个item应该插入哪边
|
|
if(!this.boxHeight.length){
|
|
this.rightList.length < this.leftList.length
|
|
? this.rightList.push(this.allList[i])
|
|
: this.leftList.push(this.allList[i]);
|
|
} else {
|
|
const leftOrRight = this.boxHeight[0] > this.boxHeight[1] ? 1 : 0;
|
|
if (leftOrRight) {
|
|
this.rightList.push(this.allList[i])
|
|
} else {
|
|
this.leftList.push(this.allList[i])
|
|
}
|
|
}
|
|
// 更新插入列表高度
|
|
this.getViewHeight();
|
|
}
|
|
},
|
|
// 获取列表高度
|
|
getViewHeight() {
|
|
// 使用nextTick,确保页面更新结束后,再请求高度
|
|
this.$nextTick(() => {
|
|
setTimeout(()=>{
|
|
uni.createSelectorQuery().in(this).select('#right').boundingClientRect(res => {
|
|
res ? this.boxHeight[1] = res.height : '';
|
|
uni.createSelectorQuery().in(this).select('#left').boundingClientRect(res => {
|
|
res ? this.boxHeight[0] = res.height : '';
|
|
this.mark = this.mark + 1;
|
|
}).exec();
|
|
}).exec();
|
|
},100)
|
|
})
|
|
},
|
|
// item点击
|
|
itemTap(item) {
|
|
this.$emit('itemTap', item)
|
|
},
|
|
giveStart(item){
|
|
let status = item.relevance_id ? 0 : 1
|
|
graphicStartApi(item.community_id,{status: status}).then(res => {
|
|
if(item.relevance_id){
|
|
item.relevance_id = !item.relevance_id;
|
|
item.count_start--;
|
|
item.count_start = item.count_start == 0 ? 0 : item.count_start
|
|
}else{
|
|
item.relevance_id = !item.relevance_id;
|
|
item.count_start++;
|
|
}
|
|
}).catch(err => {
|
|
uni.showToast({
|
|
title: err,
|
|
icon: 'none'
|
|
})
|
|
});
|
|
},
|
|
// 授权回调
|
|
onLoadFun() {
|
|
this.isShowAuth = false
|
|
},
|
|
// 授权关闭
|
|
authColse: function(e) {
|
|
this.isShowAuth = e
|
|
},
|
|
// 打开授权
|
|
authOpen: function() {
|
|
let that = this;
|
|
if (that.isLogin === false) {
|
|
this.isAuto = true;
|
|
this.isShowAuth = true
|
|
}
|
|
},
|
|
likeToggle(type, index){
|
|
if(this.isLogin == true){
|
|
if(type){
|
|
this.giveStart(this.rightList[index])
|
|
}else{
|
|
this.giveStart(this.leftList[index])
|
|
}
|
|
}else{
|
|
this.authOpen();
|
|
}
|
|
},
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
$page-padding: 20rpx;
|
|
$grid-gap: 20rpx;
|
|
|
|
.wf-page {
|
|
display: grid;
|
|
grid-template-columns: 1fr 1fr;
|
|
grid-gap: $grid-gap;
|
|
}
|
|
.wf-item {
|
|
width: calc((100vw - 2 * #{$page-padding} - #{$grid-gap}) / 2);
|
|
margin-bottom: $grid-gap;
|
|
background: #fff;
|
|
border-radius: 16rpx;
|
|
}
|
|
.wf-item-page{
|
|
padding-bottom: 20rpx;
|
|
}
|
|
</style>
|
|
|