672 lines
15 KiB
Vue
672 lines
15 KiB
Vue
<template>
|
|
<view class="page" :style="{background:(BgConfig.BackgroundObj.type==1?BgConfig.BackgroundObj.bgColor:('url('+BgConfig.BackgroundObj.path+') no-repeat '+ BgConfig.BackgroundObj.pathColor))}">
|
|
<status-bar :backgroundColor="PageNav.window.navigationBarBackgroundColor"></status-bar>
|
|
<view class='banner-nav' :style="{background:(PageNav.window.navigationBarBackgroundColor)}">
|
|
<view class='xx-box' style="position: relative;">
|
|
<navigator hover-class="none" class="xx" url='/member/member/message'>
|
|
<view style="position: absolute;right: 44rpx;top:10rpx">
|
|
<uni-badge :text="newMsgNum" type="red" class="badge"></uni-badge>
|
|
</view>
|
|
<image class='xx1' src='https://static.lancerdt.com/xcxfile/appicon/img/tzxq_05.png'></image>
|
|
</navigator>
|
|
</view>
|
|
<view class='input_box2' v-if="NIndex">
|
|
<uni-icons class='iconfont icon-sousuo-sousuo' style='font-size:70rpx;color:#ffffff' @tap='searchinput'/>
|
|
<input v-model="story_index" class="input_box2_input" :placeholder="__('搜索您想看的内容')"
|
|
placeholder-style="font-size:30rpx;color:#ffffff;line-height:54rpx"
|
|
confirm-type="done" @confirm="searchinput"/></view>
|
|
<view class='sq_0-box'>
|
|
<navigator hover-class="none" :url="'/community/community/userspace?uid=' + userInfo.user_id"
|
|
:class="'sq_0 ' + (istop==true?'border22':'')">
|
|
<image lazy-load class='sq_1' :src="(userInfo.user_avatar)" mode="scaleToFill" />
|
|
</navigator>
|
|
</view>
|
|
<view class="zhanwei">
|
|
|
|
</view>
|
|
</view>
|
|
|
|
<view style="height: 88rpx;" v-if="false"></view>
|
|
|
|
<diy :BgConfig="BgConfig" :PageContent="PageContent" :pageId="pageId" :PageNav="PageNav" :loadPageFlag="loadPageFlag"></diy>
|
|
|
|
<WaterfallsFlow :wfList='MemberPostsList' @itemTap="choose" />
|
|
|
|
<view class="m-loading-box" style="margin-top:120rpx;">
|
|
<block v-if="ispage">
|
|
<view class="u-loadmore">
|
|
<label class="u-loading"></label>
|
|
<text class="u-loadmore-tips">{{__('正在加载')}}</text>
|
|
</view>
|
|
<view>
|
|
<text></text>
|
|
</view>
|
|
</block>
|
|
<block v-else>
|
|
<view class="u-loadmore u-loadmore-line">
|
|
<text class="u-loadmore-tips">{{__('没有更多数据啦!')}}</text>
|
|
</view>
|
|
</block>
|
|
</view>
|
|
|
|
<view class="u-top" v-if="plantformInfo.config.sns_enable">
|
|
<movable-area class="movableArea">
|
|
<movable-view class="movableView" @touchmove.stop.prevent="doNothing" direction="all" :x="initX" :y="initY">
|
|
<image @click="onPostStory" src='https://static.lancerdt.com/xcxfile/appicon/nav/black/nav_post.png' class='quicknav'></image>
|
|
<image src='https://static.lancerdt.com/xcxfile/appicon/nav/black/nav_gotop.png' :class='(isquicknav?"quicknav":"hide")' @tap="returnTop"></image>
|
|
</movable-view>
|
|
</movable-area>
|
|
</view>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import diy from '../../components/themes/diy.vue'
|
|
import dateUtil from "../../helpers/util_date";
|
|
import statusBar from '../../components/status-bar.vue'
|
|
import uniBadge from '@/components/uni-badge.vue';
|
|
|
|
// 瀑布流组件
|
|
|
|
import WaterfallsFlow from '../../components/WaterfallsFlow/WaterfallsFlow.vue'
|
|
|
|
import {
|
|
mapState,
|
|
mapMutations
|
|
} from 'vuex'
|
|
|
|
export default {
|
|
data: function() {
|
|
return {
|
|
options:{},
|
|
pageId: '',
|
|
loadPageFlag: false,
|
|
PageContent: [],
|
|
BgConfig: {BackgroundObj:{type:1, bgColor:'#ffffff' ,"pathColor":"#f8f8f8","path":""}},
|
|
PageNav:{window:{"navigationBarBackgroundColor":"#ffffff","navigationBarTextStyle":"black","navigationBarTitleText":"","backgroundColor":"#f8f8f8","backgroundTextStyle":"dark"}},
|
|
ShareImg: "",
|
|
ShareTitle: "",
|
|
refresh: true,
|
|
ispage: true,
|
|
flag:true,
|
|
w:0,
|
|
chatUrl:"",
|
|
MemberPostsList:[],
|
|
NIndex:true,
|
|
story_index:"",
|
|
scposition: -1,
|
|
old: {
|
|
scposition: 0
|
|
},
|
|
|
|
isClose:true,
|
|
is_loaded:false,
|
|
|
|
isquicknav: false,
|
|
opacity: 1,
|
|
background: "f1f1f1",
|
|
istop: true,
|
|
initX: '690',
|
|
initY: '1336',
|
|
page: 1,
|
|
loading: true,
|
|
screenHeight: 0
|
|
}
|
|
},
|
|
computed: mapState(['Config', 'StateCode', 'notice', 'plantformInfo', 'shopInfo', 'userInfo', 'hasLogin', 'newMsgNum']),
|
|
components: {
|
|
diy,
|
|
statusBar,
|
|
WaterfallsFlow,
|
|
uniBadge
|
|
},
|
|
mounted() {
|
|
let view = uni.createSelectorQuery().in(this).select(".movableArea");
|
|
let that = this;
|
|
|
|
view.fields({
|
|
size: true,
|
|
scrollOffset: true
|
|
}, data => {
|
|
if (data) {
|
|
that.setData({
|
|
initX: data.width,
|
|
initY: data.height - 100,
|
|
});
|
|
}
|
|
}).exec();
|
|
},
|
|
|
|
|
|
onLoad: function(options) {
|
|
uni.setNavigationBarTitle({
|
|
title:this.__('')
|
|
});
|
|
|
|
var that = this;
|
|
|
|
//that.$.showLoading();
|
|
|
|
this.setData({
|
|
options: options
|
|
});
|
|
|
|
var w = that.$.getSystemInfoSync().windowWidth;
|
|
|
|
that.$.getSystemInfo({
|
|
success: function (t) {
|
|
that.setData({screenHeight: t.screenHeight})
|
|
}
|
|
});
|
|
|
|
that.setData({
|
|
w: w
|
|
})
|
|
},
|
|
|
|
/**
|
|
* 生命周期函数--监听页面显示
|
|
*/
|
|
onShow: function() {
|
|
let that = this;
|
|
|
|
this.refresh || this.setData({
|
|
refresh: true
|
|
})
|
|
|
|
},
|
|
|
|
onReady() {
|
|
let that = this;
|
|
setTimeout(() => {
|
|
if (!that.is_loaded)
|
|
{
|
|
that.initData(false);
|
|
}
|
|
}, 100)
|
|
},
|
|
/**
|
|
* 生命周期函数--监听页面卸载
|
|
*/
|
|
onUnload: function() {
|
|
// 离开页面,注销事件
|
|
var that = this
|
|
this.notice.removeNotification("RefreshProduct", that);
|
|
},
|
|
|
|
/**
|
|
* 页面相关事件处理函数--监听用户下拉动作
|
|
*/
|
|
onPullDownRefresh: function() {
|
|
//this.getDivModel(true)
|
|
this.setData({
|
|
MemberPostsList:[],
|
|
page:1,
|
|
})
|
|
this.initData(true)
|
|
},
|
|
|
|
/**
|
|
* 页面上拉触底事件的处理函数
|
|
*/
|
|
onReachBottom() {
|
|
if (this.flag) {
|
|
var that = this;
|
|
that.setData({flag: false});
|
|
clearTimeout(t);
|
|
|
|
var t = setTimeout(function () {
|
|
that.setData({page: parseInt(that.page) + 1});
|
|
that.getPostsList()
|
|
}, 500)
|
|
}
|
|
},
|
|
/**
|
|
* 用户点击右上角分享
|
|
*/
|
|
onShareAppMessage: function() {
|
|
// #ifdef MP-WEIXIN
|
|
wx.showShareMenu({
|
|
withShareTicket: true,
|
|
menus: ['shareAppMessage', 'shareTimeline']
|
|
});
|
|
// #endif
|
|
|
|
return {
|
|
title: this.ShareTitle,
|
|
imageUrl: this.ShareImg,
|
|
path: "/pages/index/image?uid=" + this.userInfo.user_id
|
|
}
|
|
},
|
|
|
|
/**
|
|
* 用户点击右上角分享朋友圈
|
|
*/
|
|
onShareTimeline: function () {
|
|
return {
|
|
title: this.ShareTitle,
|
|
query: {
|
|
uid: this.userInfo.user_id
|
|
},
|
|
imageUrl: this.ShareImg,
|
|
}
|
|
},
|
|
/**
|
|
* 页面滚动触发事件的处理函数
|
|
*/
|
|
onPageScroll: function(e) {
|
|
this.scroll(e)
|
|
},
|
|
|
|
methods: {
|
|
...mapMutations(['logout', 'getPlantformInfo', 'forceUserInfo', 'getStoreInfo']),
|
|
|
|
|
|
// 选中
|
|
choose(item) {
|
|
// item 返回选中 JSON 对象
|
|
//console.log(item)
|
|
|
|
let url = '/community/community/detail?id=' + item.story_id;
|
|
|
|
if (item.story_type == 4) {
|
|
//url = "/community/community/video?id=" + item.story_id;
|
|
|
|
// #ifdef APP-PLUS
|
|
url = '/community/index/index?id=' + item.story_id;
|
|
// #endif
|
|
|
|
// #ifdef H5 || MP-WEIXIN
|
|
url = '/community/nvueSwiper/nvueSwiper?id=' + item.story_id;
|
|
// #endif
|
|
}
|
|
|
|
console.info(url)
|
|
|
|
this.$.gopage(url);
|
|
},
|
|
|
|
getPostsList: function (force_refresh) {
|
|
let that = this;
|
|
var params = {page: this.page, 'rand':1};
|
|
|
|
that.$.request({
|
|
url: this.Config.URL.sns.story_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++) {
|
|
data.items[r]['story_time_str'] = dateUtil.dateUtils.format(that.$.datetimeFormatter(data.items[r]['story_time']));
|
|
}
|
|
|
|
let tmp = []
|
|
|
|
if (force_refresh)
|
|
{
|
|
tmp = data.items.concat(that.MemberPostsList);
|
|
}
|
|
else
|
|
{
|
|
tmp = that.MemberPostsList.concat(data.items);
|
|
}
|
|
|
|
if (data.page >= data.total) {
|
|
that.setData({
|
|
MemberPostsList: tmp,
|
|
flag: false,
|
|
ispage: false
|
|
});
|
|
} else {
|
|
that.setData({
|
|
MemberPostsList: tmp,
|
|
flag: true,
|
|
ispage: true
|
|
})
|
|
}
|
|
|
|
//that.$forceUpdate() //二维数组,开启强制渲染
|
|
|
|
} else {
|
|
that.setData({flag: false, ispage: false})
|
|
}
|
|
|
|
that.setData({is_loaded: true})
|
|
|
|
that.$.stopPullDownRefresh()
|
|
//that.$.hideLoading();
|
|
}
|
|
});
|
|
},
|
|
doNothing: function() {
|
|
|
|
},
|
|
|
|
//初始化数据,获取店铺分类
|
|
initData: function(force_refresh) {
|
|
var that = this;
|
|
|
|
that.getDivModel(force_refresh)
|
|
|
|
|
|
let param = {}
|
|
|
|
that.getPostsList(force_refresh)
|
|
|
|
|
|
},
|
|
moNitor: function () {
|
|
this.setData({isClose: false})
|
|
},
|
|
onLike: function (a) {
|
|
let that = this;
|
|
that.forceUserInfo(function(user) {
|
|
that.dianzan(a.currentTarget.dataset.story_id)
|
|
});
|
|
},
|
|
dianzan: function (story_id) {
|
|
var that = this, params = {
|
|
story_id: story_id
|
|
};
|
|
|
|
that.$.request({
|
|
url: this.Config.URL.sns.story_like_add,
|
|
data: params,
|
|
success: function (data, status, msg, code) {
|
|
if (200 == status) {
|
|
//that.getPostsList()
|
|
|
|
//修正当前记录数据
|
|
for (var r = 0; r < that.MemberPostsList.length; r++) {
|
|
if (story_id == that.MemberPostsList[r]['story_id'])
|
|
{
|
|
that.MemberPostsList[r]['IsFabulous'] = 1;
|
|
}
|
|
}
|
|
} else {
|
|
}
|
|
}
|
|
});
|
|
},
|
|
onUnLike: function (a) {
|
|
let that = this;
|
|
that.forceUserInfo(function(user) {
|
|
that.canceldianzan(a.currentTarget.dataset.story_id)
|
|
});
|
|
},
|
|
canceldianzan: function (story_id) {
|
|
var that = this, params = {
|
|
story_id: story_id
|
|
};
|
|
|
|
that.$.request({
|
|
url: this.Config.URL.sns.story_like_remove,
|
|
data: params,
|
|
success: function (data, status, msg, code) {
|
|
if (200 == status) {
|
|
//修正当前记录数据
|
|
for (var r = 0; r < that.MemberPostsList.length; r++) {
|
|
if (story_id == that.MemberPostsList[r]['story_id'])
|
|
{
|
|
that.MemberPostsList[r]['IsFabulous'] = 0;
|
|
}
|
|
}
|
|
} else {
|
|
}
|
|
}
|
|
});
|
|
},
|
|
|
|
onPostStory: function (a) {
|
|
let that = this;
|
|
that.forceUserInfo(function(user) {
|
|
that.$.navigateTo({url: "/community/community/post"})
|
|
})
|
|
},
|
|
|
|
//读取diy内容
|
|
getDivModel: function(force_refresh) {
|
|
var that = this,
|
|
params = {page_type:'page_sns'};
|
|
|
|
that.$.request({
|
|
url: that.Config.URL.index_app,
|
|
data: params,
|
|
loading: false,
|
|
ajaxCache: {
|
|
timeout: that.Config.CACHE_EXPIRE,
|
|
forceRefresh: force_refresh
|
|
},
|
|
success: function(data, status, msg, code) {
|
|
uni.stopPullDownRefresh()
|
|
|
|
if (typeof data.page_loaded != 'undefined' && data.page_loaded)
|
|
{
|
|
that.setData({
|
|
loadPageFlag: true
|
|
});
|
|
|
|
let page_code = that.$.parseJSON(data.page_code);
|
|
|
|
that.setData({
|
|
pageId: data.page_id,
|
|
PageContent: page_code,
|
|
BgConfig: that.$.parseJSON(data.page_config),
|
|
PageNav: that.$.parseJSON(data.page_nav),
|
|
ShareImg: data.page_share_image,
|
|
ShareTitle: data.page_share_title
|
|
});
|
|
|
|
if (that.PageNav.window.navigationBarTextStyle == 'black')
|
|
{
|
|
that.PageNav.window.navigationBarTextStyle = '#000000'
|
|
}
|
|
|
|
if (that.PageNav.window.navigationBarTextStyle == 'white')
|
|
{
|
|
that.PageNav.window.navigationBarTextStyle = '#ffffff'
|
|
}
|
|
|
|
uni.setNavigationBarColor({
|
|
frontColor: that.PageNav.window.navigationBarTextStyle,
|
|
backgroundColor: that.PageNav.window.navigationBarBackgroundColor,
|
|
animation: {
|
|
duration: 400,
|
|
timingFunc: 'easeIn'
|
|
}
|
|
})
|
|
}
|
|
else
|
|
{
|
|
that.setData({
|
|
loadPageFlag: false
|
|
});
|
|
}
|
|
}
|
|
});
|
|
},
|
|
searchinput: function (a) {
|
|
wx.navigateTo({
|
|
url: "/community/community/lists?story_index=" + this.story_index,
|
|
success: function (a) {
|
|
},
|
|
fail: function (a) {
|
|
},
|
|
complete: function (a) {
|
|
}
|
|
}), this.setData({story_index: ""})
|
|
},
|
|
|
|
scroll: function (t) {
|
|
let that = this;
|
|
that.old.scposition = t.scrollTop;
|
|
|
|
if (100 < t.scrollTop) {
|
|
that.setData({opacity: 1, background: "f8f8f8"});
|
|
} else {
|
|
that.setData({
|
|
opacity: 0,
|
|
background: "fff"
|
|
})
|
|
}
|
|
|
|
if (t.scrollTop >= this.screenHeight) {
|
|
this.setData({isquicknav: true})
|
|
} else {
|
|
this.setData({isquicknav: false})
|
|
}
|
|
|
|
},
|
|
|
|
scrollbottom: function () {
|
|
if (this.flag) {
|
|
var that = this;
|
|
that.setData({flag: false});
|
|
clearTimeout(t);
|
|
|
|
var t = setTimeout(function () {
|
|
that.setData({page: parseInt(that.page) + 1});
|
|
that.getPostsList()
|
|
}, 500)
|
|
}
|
|
},
|
|
scrollView: function(e) {
|
|
},
|
|
scrollTop: function() {
|
|
},
|
|
scrolltoupper: function(t) {
|
|
this.old.scposition = t.detail.scrollTop;
|
|
},
|
|
returnTop: function() {
|
|
uni.pageScrollTo({
|
|
scrollTop: 0,
|
|
duration: 300
|
|
});
|
|
}
|
|
}
|
|
};
|
|
</script>
|
|
|
|
|
|
<style lang="scss">
|
|
@import "../../styles/_variables";
|
|
|
|
@import '../../styles/layout.scss';
|
|
|
|
|
|
send-message button {
|
|
display: inline-block;
|
|
width: 100%;
|
|
height: 100%;
|
|
float: left;
|
|
}
|
|
|
|
page {
|
|
background-color: #fff;
|
|
}
|
|
|
|
|
|
.banner-nav {
|
|
/* position: absolute; */
|
|
width: 100%;
|
|
|
|
height: 88rpx;
|
|
z-index: 999;
|
|
display: flex;
|
|
align-items: center;
|
|
/* justify-content: center; */
|
|
background-color: rgba(0, 0, 0, 0);
|
|
}
|
|
|
|
.xx-box {
|
|
/* margin-top: 20rpx; margin-left: 22rpx; */
|
|
width: 80rpx;
|
|
height: 58rpx;
|
|
display: flex;
|
|
}
|
|
|
|
.xx {
|
|
/* position: fixed;*/
|
|
/* top: 20rpx; left: 22rpx; */
|
|
width: 80rpx;
|
|
height: 50rpx;
|
|
z-index: 999;
|
|
border-radius: 100%;
|
|
opacity: 0.8;
|
|
// background-color: #fafafa;
|
|
// border: 1rpx solid #fafafa;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
}
|
|
|
|
.xx1 {
|
|
width: 50rpx;
|
|
height: 50rpx;
|
|
margin: 9rpx;
|
|
}
|
|
|
|
.input_box2 {
|
|
/* position: fixed;*/
|
|
/* top: 20rpx; left: 95rpx; */
|
|
|
|
height: 54rpx;
|
|
z-index: 99;
|
|
border-radius: 35rpx;
|
|
opacity: 0.8;
|
|
display: flex;
|
|
flex: 1;
|
|
align-items: center;
|
|
}
|
|
|
|
.input_box2_input {
|
|
font-size: 24rpx;
|
|
}
|
|
|
|
.sq_0 {
|
|
width: 54rpx;
|
|
height: 54rpx;
|
|
/* top: 20rpx; right: 22rpx; */
|
|
z-index: 99;
|
|
border-radius: 100%;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.sq_1 {
|
|
width: 50rpx;
|
|
height: 50rpx;
|
|
|
|
border-radius: 120rpx;
|
|
border: 1px solid #fff;
|
|
vertical-align: middle;
|
|
box-shadow: 0px 2rpx 15rpx rgba(0, 0, 0, 0.35);
|
|
}
|
|
|
|
.sq_0-box{
|
|
display: flex;
|
|
width: 80rpx;
|
|
}
|
|
|
|
.zhanwei {
|
|
/* #ifdef MP */
|
|
width: 200rpx;
|
|
/* #endif */
|
|
/* #ifndef MP */
|
|
width: 0;
|
|
/* #endif */
|
|
}
|
|
.border {
|
|
border: 1rpx solid #d9d9d9;
|
|
}
|
|
|
|
.border1 {
|
|
border-bottom: 1rpx solid #fafafa;
|
|
}
|
|
|
|
.border22 {
|
|
/* border: 1rpx solid #d9d9d9; */
|
|
}
|
|
|
|
|
|
</style>
|