171 lines
4.6 KiB
Vue
171 lines
4.6 KiB
Vue
<template>
|
||
<view :style="viewColor">
|
||
<view class='bill-details'>
|
||
<view class='nav acea-row'>
|
||
<view class='item' :class='type==0 ? "on":""' @click='changeType(0)'>全部</view>
|
||
<view class='item' :class='type==1 ? "on":""' @click='changeType(1)'>消费</view>
|
||
<view class='item' :class='type==2 ? "on":""' @click='changeType(2)'>充值</view>
|
||
</view>
|
||
<view class='sign-record'>
|
||
<view class='list' v-for="(item,index) in userBillList" :key="index">
|
||
<view class='item'>
|
||
<!-- <view class='data'>{{item.time}}</view> -->
|
||
<view class='listn'>
|
||
<view class='itemn acea-row row-between-wrapper'>
|
||
<view>
|
||
<view class='name line1'>{{item.title}}</view>
|
||
<view>{{item.create_time}}</view>
|
||
</view>
|
||
<view class='num' v-if="item.pm ==1">+{{item.number}}</view>
|
||
<view class='num p-color' v-else>-{{item.number}}</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class='loadingicon acea-row row-center-wrapper' v-if="userBillList.length>0">
|
||
<text class='loading iconfont icon-jiazai' :hidden='loading==false'></text>{{loadTitle}}
|
||
</view>
|
||
<view v-if="userBillList.length == 0">
|
||
<emptyPage title="暂无账单的记录哦~"></emptyPage>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<authorize @onLoadFun="onLoadFun" :isAuto="isAuto" :isShowAuth="isShowAuth" @authColse="authColse"></authorize>
|
||
</view>
|
||
</template>
|
||
|
||
<script>
|
||
// +----------------------------------------------------------------------
|
||
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
||
// +----------------------------------------------------------------------
|
||
// | Copyright (c) 2016~2021 https://www.crmeb.com All rights reserved.
|
||
// +----------------------------------------------------------------------
|
||
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
||
// +----------------------------------------------------------------------
|
||
// | Author: CRMEB Team <admin@crmeb.com>
|
||
// +----------------------------------------------------------------------
|
||
import {
|
||
getCommissionInfo
|
||
} from '@/api/user.js';
|
||
import {
|
||
mapGetters
|
||
} from "vuex";
|
||
import authorize from '@/components/Authorize';
|
||
import emptyPage from '@/components/emptyPage.vue'
|
||
export default {
|
||
components: {
|
||
authorize,
|
||
emptyPage
|
||
},
|
||
data() {
|
||
return {
|
||
loadTitle: '加载更多',
|
||
loading: false,
|
||
loadend: false,
|
||
page: 1,
|
||
limit: 15,
|
||
type: 0,
|
||
userBillList: [],
|
||
isAuto: false, //没有授权的不会自动授权
|
||
isShowAuth: false //是否隐藏授权
|
||
};
|
||
},
|
||
computed: mapGetters(['isLogin','viewColor']),
|
||
onShow() {
|
||
if (this.isLogin) {
|
||
this.getUserBillList();
|
||
} else {
|
||
this.isAuto = true;
|
||
this.isShowAuth = true
|
||
}
|
||
},
|
||
/**
|
||
* 生命周期函数--监听页面加载
|
||
*/
|
||
onLoad: function(options) {
|
||
this.type = options.type || 0;
|
||
},
|
||
/**
|
||
* 页面上拉触底事件的处理函数
|
||
*/
|
||
onReachBottom: function() {
|
||
this.getUserBillList();
|
||
},
|
||
methods: {
|
||
/**
|
||
* 授权回调
|
||
*/
|
||
onLoadFun: function() {
|
||
this.isShowAuth = false;
|
||
this.getUserBillList();
|
||
},
|
||
// 授权关闭
|
||
authColse: function(e) {
|
||
this.isShowAuth = e
|
||
},
|
||
/**
|
||
* 获取账户明细
|
||
*/
|
||
getUserBillList: function() {
|
||
let that = this;
|
||
if (that.loadend) return;
|
||
if (that.loading) return;
|
||
that.loading = true;
|
||
that.loadTitle = "";
|
||
let data = {
|
||
page: that.page,
|
||
limit: that.limit,
|
||
type:that.type
|
||
}
|
||
getCommissionInfo(data).then(function(res) {
|
||
let list = res.data.list,
|
||
loadend = list.length < that.limit;
|
||
that.userBillList = that.$util.SplitArray(list, that.userBillList);
|
||
that.$set(that, 'userBillList', that.userBillList);
|
||
that.loadend = loadend;
|
||
that.loading = false;
|
||
that.loadTitle = loadend ? "哼😕~我也是有底线的~" : "加载更多";
|
||
that.page = that.page + 1;
|
||
}, function(res) {
|
||
that.loading = false;
|
||
that.loadTitle = '加载更多';
|
||
});
|
||
},
|
||
/**
|
||
* 切换导航
|
||
*/
|
||
changeType: function(type) {
|
||
this.type = type;
|
||
this.loadend = false;
|
||
this.page = 1;
|
||
this.$set(this, 'userBillList', []);
|
||
this.getUserBillList();
|
||
},
|
||
}
|
||
}
|
||
</script>
|
||
|
||
<style scoped lang='scss'>
|
||
.bill-details .nav {
|
||
background-color: #fff;
|
||
height: 90rpx;
|
||
width: 100%;
|
||
line-height: 90rpx;
|
||
}
|
||
|
||
.bill-details .nav .item {
|
||
flex: 1;
|
||
text-align: center;
|
||
font-size: 30rpx;
|
||
color: #282828;
|
||
}
|
||
|
||
.bill-details .nav .item.on {
|
||
color: var(--view-theme);
|
||
border-bottom: 3rpx solid var(--view-theme);
|
||
}
|
||
.p-color {
|
||
color: var(--view-priceColor)!important;
|
||
}
|
||
</style>
|