|
|
<template><view id="recharge-balance"> <view class="content"> <!-- 我在类名里面写了样式,但是并不起作用,先用行内样式--> <view class="balance-top" style="background:#FB5054 "> <view class="title"> 账户余额(元) </view> <view class="recharge-box"> <view class="money"> {{num/100}} </view> <view class="recharge" @tap="jump" style="display: flex; justify-content: center; align-items: center; width:50px; height:24px; border-radius:2px; border:1px solid rgba(255,255,255,1);"> 充值 > </view> </view> </view> <view class="tab-panel"> <block v-for="(item, index) in tabList" :key="index"> <view :id="index" :hidden="activeIndex != index" :style="'color: ' + config.mainColor + '; border-color: ' + config.mainColor + ' '" class="tab-title active" @tap="tabClick">{{item.name}}</view> <view :id="index" :hidden="activeIndex == index" class="tab-title" @tap="tabClick">{{item.name}}</view> </block> </view> <view class="tab-content"> <view class="tab-item" :hidden="activeIndex!=0"> <block v-for="(items, idx) in dataList[0]" :key="idx"> <view class="tab-item-content" v-for="(item, index) in dataList[0][idx]" :key="index"> <view class="text"> <view style="font-size: 14px; text-overflow:ellipsis;overflow:hidden;">{{item.note}}</view> <view style="font-size: 10px;color: #A3A3A3">{{item.updated_at}}</view> </view> <view class="num"> +{{item.value/100}} </view> </view> </block> <view class="loadingbox" :hidden="!tabList[0].show"> {{showText}} </view> </view> <view class="tab-item" :hidden="activeIndex!=1"> <block v-for="(item, idx) in dataList[1]" :key="idx" > <view class="tab-item-content" v-for="(item, index) in dataList[1][idx]" :key="index"> <view class="text"> <view style="font-size: 14px; text-overflow:ellipsis;overflow:hidden;">{{item.note}}</view> <view style="font-size: 10px;color: #A3A3A3">{{item.updated_at}}</view> </view> <view class="num"> {{item.value/100}} </view> </view> </block> <view class="loadingbox" :hidden="!tabList[1].show"> {{showText}} </view> </view> </view> </view></view>
</template><script>import {pageLogin, getUrl,config,is} from '@/common/js/utils.js';
export default { data() { return { activeIndex: 0, tabList: [{ id: 0, name: "收入", init: false, page: 0, more: true, show: false }, { id: 1, name: "支出", init: false, page: 0, more: true, show: false }], token: "", dataList: { 0: [], 1: [] }, num: "", showText: '正在加载下一页数据', config: '' }; },
onReachBottom(e) { var status = this.activeIndex; var page = this.tabList[status].page + 1; var tabList = `tabList[${status}]`;
if (this.tabList[status].more) { this.setData({ [`${tabList}.show`]: true }); var token = this.token; this.queryBalanceList(token, status, page); } else { wx.showToast({ icon: 'error', title: '再拉也没有啦' }); } },
onShow() {// let app =getApp();
// app.isBirthday().then(()=>{
// if(this.$cookieStorage.get("birthday_gift")){
// var giftData=this.$cookieStorage.get("birthday_gift").data;
// new app.ToastPannel().__page.showText(giftData);
// }
// });
},
onLoad(e) { // 第三方平台配置颜色
var bgConfig = this.$cookieStorage.get('globalConfig') || ''; this.setData({ config: bgConfig }); // var status=0,page=1;
// this.queryBalanceList(token);
var status = e.type ? e.type : 0; var page = this.tabList[status].page; pageLogin(getUrl(), token => { this.setData({ 'token': token }); this.queryBalanceList(token, status, page); this.queryUserSum(token); }); },
components: {}, props: {}, methods: { jump() { wx.navigateTo({ url: '/pages/recharge/index/index' }); },
tabClick(e) { // console.log(e.currentTarget.id);
var status = e.currentTarget.id; this.setData({ activeIndex: status });
if (!this.tabList[status].init) { var page = this.tabList[status].page; wx.showLoading({ title: "加载中", mask: true }); this.queryBalanceList(this.token, status, page); } },
result(res, status) { if (res.status) { var list; var page = res.meta.pagination; var current_page = page.current_page; var total_pages = page.total_pages; var tabList = `tabList[${status}]`; list = res.data; // this.setData({
// [`dataList.${status}[${current_page - 1}]`]: list,
// [`${tabList}.init`]: true,
// [`${tabList}.page`]: current_page,
// [`${tabList}.more`]: current_page < total_pages,
// [`${tabList}.show`]: false
// });
this.dataList[status][current_page - 1]=res.data; this.tabList[status].init=true; this.tabList[status].page=current_page; this.tabList[status].more=current_page < total_pages; this.tabList[status].show=false; } },
queryBalanceList(token, status, page) { var type = status ? 'consume' : 'recharge'; var params = type ? { type } : {}; params.page = page; this.$http.get({ api: 'api/users/balance/list', header: { Authorization: token }, data: params }).then(res => { if (res.statusCode == 200) { res = res.data; this.result(res, status); } else { wx.showModal({ title: '提示', content: '数据请求失败', success: res => {} }); }
wx.hideLoading(); }).catch(rej => { wx.showToast({ title: "请求失败", image: '../../../static/error.png' }); wx.hideLoading(); }); },
queryUserSum(token) { this.$http.get({ api: "api/users/balance/sum", header: { Authorization: token } }).then(res => { if (res.statusCode == 200) { res = res.data; this.setData({ "num": res.data.sum }); } else { wx.showModal({ title: '提示', content: '数据请求失败', success: res => {} }); } }); },
setData: function (obj) { let that = this; let keys = []; let val, data; Object.keys(obj).forEach(function (key) { keys = key.split('.'); val = obj[key]; data = that.$data; keys.forEach(function (key2, index) { if (index + 1 == keys.length) { that.$set(data, key2, val); } else { if (!data[key2]) { that.$set(data, key2, {}); } }
data = data[key2]; }); }); } }, computed: {}, watch: {}};</script><style>#recharge-balance .content{height:100%;overflow:auto;box-sizing:border-box}#recharge-balance .content .balance-top{color:#FFF;padding:20px 15px;background:#CDA76E}#recharge-balance .content .balance-top .title{font-size:12px}#recharge-balance .content .balance-top .recharge-box{display:flex;align-items:center;margin-top:20px;font-size:14px}#recharge-balance .content .tab-content,#recharge-balance .content .tab-panel{margin-top:10px;background-color:#FFF}#recharge-balance .content .balance-top .recharge-box .money{flex:1;font-size:30px}#recharge-balance .content .tab-panel{display:flex;box-sizing:border-box}#recharge-balance .content .tab-panel .tab-title{height:44px;width:50%;line-height:44px;text-align:center;box-sizing:border-box}#recharge-balance .content .tab-panel .tab-title.active{color:#CDA76E;border-bottom:2px solid #CDA76E}#recharge-balance .content .tab-content .tab-item-content{box-sizing:border-box;padding-left:12px;padding-right:12px;display:flex;line-height:60px;height:60px;border-bottom:1px solid #d9d9d9;justify-content:space-between}#recharge-balance .content .tab-content .tab-item-content .num{color:#ff2741}#recharge-balance .content .tab-content .tab-item-content .text{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;line-height:30px;flex:1}#recharge-balance .loadingbox{text-align:center;padding:5px 0}</style>
|