DetailViewModel.ets
2.06 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
import { ContentDetailDTO } from 'wdBean';
import { Logger, StringUtils } from 'wdKit';
import { ResponseDTO, } from 'wdNetwork';
import { PageRepository } from '../repository/PageRepository';
import { BaseViewModel } from './BaseViewModel';
const TAG = 'DetailViewModel';
/**
* 处理返回后的数据
*/
export class DetailViewModel extends BaseViewModel {
getLogTag() {
return TAG;
}
/**
* 获取详情数据.
* 例:https://pd-apis-uat.pdnews.cn/api/rmrb-bff-display-zh/content/zh/c/content/detail?relId=500000008738&contentId=30001373964&relType=1
* @return {string} resDTO.data
*/
getDetailPageData(relId: string, contentId: string, relType: string): Promise<ContentDetailDTO[]> {
Logger.debug(TAG, 'getDetailPageData contentId: ' + contentId);
return new Promise<ContentDetailDTO[]>((success, error) => {
PageRepository.fetchDetailData(relId, contentId, relType).then((resDTO: ResponseDTO<ContentDetailDTO[]>) => {
if (!resDTO || !resDTO.data) {
Logger.error(TAG, 'getDetailPageData then resDTO is empty');
error('resDTO is empty');
return
}
if (resDTO.code != 0) {
Logger.error(TAG, `getDetailPageData then code:${resDTO.code}, message:${resDTO.message}`);
error('resDTO Response Code is failure');
return
}
Logger.info(TAG, "getDetailPageData then,resDTO.timeStamp:" + resDTO.timestamp);
success(resDTO.data);
}).catch((err: Error) => {
Logger.error(TAG, `getDetailPageData catch, error.name : ${err.name}, error.message:${err.message}`);
error(err);
})
})
}
private dataTranslate(json: string): ContentDetailDTO | null {
if (StringUtils.isEmpty(json)) {
return null;
}
try {
let data: ContentDetailDTO = JSON.parse(json)
return data;
} catch (err) {
// json解析异常
Logger.error(TAG, `dataTranslate catch parse failed.: ${err}`);
}
return null;
}
}
let detailViewModel = new DetailViewModel();
export default detailViewModel as DetailViewModel;