170 lines
4.8 KiB
Vue
170 lines
4.8 KiB
Vue
<template>
|
|
<view>
|
|
<!-- 状态栏 -->
|
|
<status-nav :titleVal="'用户足迹'" :statusTitle="true"></status-nav>
|
|
<!-- 自定义二级分类 -->
|
|
<!-- 列表 -->
|
|
<view :style="{paddingTop: statusHNH+'px'}" class="pad-zy30">
|
|
<view class="radius20 fon28 col3 mar-sx20">
|
|
<view class="disac">
|
|
<view class="disjbac width100 radius10 pad-zy20 xialak bacf">
|
|
<input class="fon28 width100" type="text" @confirm="searchEv" v-model="keyword" placeholder="请输入姓名/电话查找" placeholder-style="color: #B3B3B3;" />
|
|
</view>
|
|
<view @tap="searchEv" class="flexs tc mar-z30 colf radius10 customer-btn" :style="{background:publicColor}">搜索</view>
|
|
</view>
|
|
</view>
|
|
<!-- 列表 -->
|
|
<view @tap="chooseId(item.id)" class="bacf radius10 pad20 mar-x20 fon28" v-for="(item,index) in dataList" :key="index">
|
|
<view style="color: #B3B3B3;">{{item.time}}</view>
|
|
<view class="mar-s20">
|
|
<text class="bold col3">{{item.name}}</text>
|
|
<text style="color: #B3B3B3;">{{item.action}}</text>
|
|
<text class="bold col3" v-if="item.title!=null && item.title!=''">【{{item.title}}】</text>
|
|
<text style="color: #B3B3B3;" v-if="item.zwhat!=null && item.zwhat!=''">{{item.zwhat}}</text>
|
|
</view>
|
|
</view>
|
|
<view v-if="dataList.length==0" class="disjcac fc" style="margin-top: 50%;">
|
|
<image class="zanw-img" src="/static/public/nothing.png" mode="aspectFill"></image>
|
|
<view class="fon24 col3">您搜索的内容暂无结果,换个关键词试试吧</view>
|
|
</view>
|
|
<!-- 返回顶部 -->
|
|
<back-top :showTop="showTop" @backTop="backTop"></back-top>
|
|
</view>
|
|
<!-- 底部客服 -->
|
|
<public-customer :nbottom="100"></public-customer>
|
|
<!-- 弹框授权 -->
|
|
<empower @buttonH="buttonH" :vision="vision" :isWhere="2"></empower>
|
|
<!-- 弹框 -->
|
|
<auth-phone v-if="isShowP"></auth-phone>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
export default {
|
|
data() {
|
|
return {
|
|
statusHNH:uni.getStorageSync('statusHNH'),
|
|
publicColor:uni.getStorageSync('publicColor'),//主题颜色
|
|
dataList:[],//数据列表
|
|
showTop:false,//是否显示返回顶部的箭头
|
|
customer_id:'',//客户ID
|
|
keyword:'',//关键词
|
|
page:1,
|
|
size:10,
|
|
total:'',//总数
|
|
isZanw:true,
|
|
vision:false,
|
|
isShowP:false,
|
|
}
|
|
},
|
|
onPageScroll(e) {
|
|
e.scrollTop > 360 ? this.showTop = true : this.showTop = false
|
|
},
|
|
onReachBottom() {//触底事件
|
|
if(this.total!=this.dataList.length){
|
|
this.page++
|
|
this.checkList()
|
|
} else {
|
|
if(this.isZanw) this.$toolAll.tools.showToast('暂无更多足迹内容')
|
|
this.isZanw = false
|
|
}
|
|
},
|
|
onShow() {
|
|
this.$toolAll.tools.isLogin()
|
|
},
|
|
onLoad(options) {
|
|
if(uni.getStorageSync('is_active')!=1){this.vision = true;}
|
|
if(options.invite_code!='' && options.invite_code!=undefined){
|
|
this.loginEv(options.invite_code);
|
|
} else if(options.source_code!='' && options.source_code!=undefined){
|
|
this.loginEv('',options.source_code,options.channel);
|
|
}
|
|
this.checkList()
|
|
},
|
|
methods: {
|
|
loginEv(invite_code='',source='',channel=''){
|
|
uni.login({
|
|
provider: 'weixin',
|
|
success: (res)=> {
|
|
if (res.code) {
|
|
var params = {
|
|
code:res.code,
|
|
invite_code:invite_code,//用户邀请码
|
|
source_code:source,
|
|
channel:channel
|
|
}
|
|
this.$requst.post('user/login',params).then(res => {
|
|
if(res.data.token!=''){
|
|
if(res.data.is_active==0) {
|
|
this.vision = true;
|
|
}
|
|
}
|
|
},error => {})
|
|
}
|
|
},
|
|
});
|
|
},
|
|
buttonH(e){//授权成功
|
|
if(e) {
|
|
this.vision = false
|
|
this.isShowP = true
|
|
}
|
|
},
|
|
chooseId(id){
|
|
this.backTop()
|
|
this.page = 1
|
|
this.isZanw = true
|
|
this.customer_id = id
|
|
this.keyword = ''
|
|
this.checkList()
|
|
},
|
|
searchEv(){//搜索事件
|
|
if(this.keyword!='') this.customer_id = ''
|
|
this.page = 1
|
|
this.isZanw = true
|
|
this.checkList()
|
|
},
|
|
checkList(){//查询列表事件
|
|
let params = {
|
|
page:this.page,
|
|
size:this.size,
|
|
customer_id:this.customer_id,//客户ID
|
|
keyword:this.keyword
|
|
}
|
|
this.$requst.post('user/footmarks',params).then(res=>{
|
|
// console.log('足迹列表查询:',res);
|
|
if(res.code==0){
|
|
if(this.page==1) this.dataList = []
|
|
this.total = res.data.total
|
|
if(res.data.list.length!=0){
|
|
res.data.list.forEach(item=>{
|
|
let newCate = ''
|
|
if(item.content_id > 0) newCate = item.category
|
|
else newCate = ''
|
|
let obj = {
|
|
id:item.account_id,
|
|
name:item.nickname,
|
|
action:item.action,
|
|
title:item.title,
|
|
time:item.created_at,
|
|
zwhat:newCate,
|
|
}
|
|
this.dataList.push(obj)
|
|
})
|
|
}
|
|
}
|
|
},error=>{})
|
|
},
|
|
backTop(){//回到顶部事件
|
|
uni.pageScrollTo({
|
|
scrollTop: 0,
|
|
duration: 300
|
|
});
|
|
},
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style>
|
|
</style>
|