index.js
3.56 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
import wx from '../../utils/wx';
import config from '../../common/config';
import Yas from '../../common/yas';
import LimitModel from '../../models/limit/index';
// 获取应用实例
let app = getApp();
let yas;
let router = global.router;
Page({
data: {
tabSelected: 0,
refreshText: '下拉刷新',
userInfo: {},
tabBarArr: [
{
icon: '../../static/images/icon_rmfs_n@3x.png',
iconSelected: '../../static/images/icon_rmfs_p@3x.png',
name: '热门发售',
method: 'app.limitProduct.hotLimitProduct'
},
{
icon: '../../static/images/icon_jjfs_n@3x.png',
iconSelected: '../../static/images/icon_jjfs_p@3x.png',
name: '即将发售',
method: 'app.limitProduct.soonToSaleLimitProduct'
},
{
icon: '../../static/images/icon_yjfs_n@3x.png',
iconSelected: '../../static/images/icon_yjfs_p@3x.png',
name: '已经发售',
method: 'app.limitProduct.alreadySaleLimitProduct'
}
],
listData: [
{}, {}, {}
],
icon: {
clock: '../../static/images/clock_left.png'
}
},
onLoad: function() {
yas = new Yas(app);
console.log(app.getUserInfo());
if (app.getUserInfo().nickName) {
this.setData({
userInfo: app.getUserInfo(),
hasUserInfo: true
});
}
this.getList(0, 1, 20, false);
},
onShow: function() {
yas.pageOpenReport();
},
onPullDownRefresh: function() {
this.setData({
refreshText: '加载中...'
});
this.getList(this.data.tabSelected, 1, 20, false).then(() => {
wx.stopPullDownRefresh();
});
},
onReachBottom: function() {
let page = this.data.listData[this.data.tabSelected].page;
let page_total = this.data.listData[this.data.tabSelected].page_total;
if (page < page_total) {
page += 1;
this.getList(this.data.tabSelected, page, 20, true);
}
},
getUserInfo: function(e) {
console.log(e);
if (e.detail.errMsg === 'getUserInfo:ok') {
// AccountModel.decodeUserInfo();
}
app.setUserInfo(e.detail.userInfo);
this.setData({
userInfo: e.detail.userInfo,
hasUserInfo: true
});
},
tabChange: function(e) {
let index = e.currentTarget.dataset.index;
if (index !== this.data.tabSelected) {
this.setData({
tabSelected: index
});
if (!this.data.listData[index].limitProductVoList || this.data.listData[index].limitProductVoList.length === 0) {
this.getList(index, 1, 20, false);
}
}
},
/**
* index: tab的index,page:分页,limit: 每页数量, isBottom:是否是到达底部后触发
*/
getList: function(index, page, limit, isBottom) { // 获取限定发售列表
let method = this.data.tabBarArr[index].method;
let that = this;
return LimitModel.getLimitSaleList({
method: method,
page: page,
limit: limit
}).then(res => {
console.log(res.data);
if (res.data && res.data.limitProductVoList) {
let list = that.data.listData;
if (isBottom) {
list[index].page = page;
list[index].limitProductVoList = list[index].limitProductVoList.concat(res.data.limitProductVoList);
} else {
list[index] = res.data;
}
that.setData({
listData: list
});
}
});
},
navigateToDetail: function(e) { // 跳转到详情页
console.log(e);
let id = e.currentTarget.dataset.id;
let limitProductCode = e.currentTarget.dataset.code;
router.go('productDetail', {limitProductCode});
}
});