channel.js
2.52 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
/**
* 频道页面 model
* @author: Bi Kai<kai.bi@yoho.cn>
* @date: 2016/05/09
*/
'use strict';
const _ = require('lodash');
const API = require('../../../library/api');
const sign = require('../../../library/sign');
const api = new API();
const processFloor = (list) => {
const formatData = {};
list = list || [];
_.forEach(list, (floor) => {
// FIXME 楼层数据处理有问题
formatData[_.camelCase(floor.template_name)] = floor.data; // 接口数据格式化,键使用驼峰写法
});
return formatData;
};
/**
* 获取频道页面资源位
*/
const getChannelResource = (gender) => {
gender = gender || '1,3';
return api.get('operations/api/v5/resource/home', sign.apiSign({
new_device: true, // eslint-disable-line
gender: gender,
content_code: '8512bf0755cc549ac323f852c9fd945d', // eslint-disable-line
page: 1,
limit: 30
})).then(result => {
result = JSON.parse(result);
if (result.code === 200) {
return processFloor(result.data.list);
} else {
return result;
}
});
};
const getLeftNav = (guangChoosed) => {
guangChoosed = guangChoosed || 'all';
return api.get('operations/api/v6/category/getCategory', sign.apiSign({})).then(result => {
result = JSON.parse(result);
if (result.code === 200) {
_.forEach(result.data, (item) => {
_.forEach(Object.keys(item), (k) => {
item[_.camelCase(k)] = item[k]; // 下划线变量名转换为驼峰
});
if (item.sub) {
let sub = [];
// 子菜单键名驼峰化
_.forEach(item.sub, (s) => {
_.forEach(Object.keys(s), (key) => {
s[_.camelCase(key)] = s[key]; // 下划线变量名转换为驼峰
});
sub.push(s);
});
item.sub = sub;
}
});
return result.data;
} else {
return result;
}
});
};
/**
* 获取频道页面数据
* @param {[object]} params
* @return {[object]}
*/
exports.getChannelDate = (params) => {
var channelData = {};
return Promise.all([getChannelResource(params.gender), getLeftNav()]).then((data) => {
channelData.content = data[0]; // 资源位数据
channelData.sideNav = data[1]; // 侧边栏数据
return channelData;
});
};