ant-design/site/theme/template/Content/index.jsx
2016-10-18 11:18:25 +08:00

37 lines
1014 B
JavaScript

import React from 'react';
import Promise from 'bluebird';
import MainContent from './MainContent';
import * as utils from '../utils';
const locale = utils.isZhCN() ? 'zh-CN' : 'en-US';
export function collect(nextProps, callback) {
const pageData = nextProps.location.pathname === 'changelog' ?
nextProps.data.CHANGELOG : nextProps.pageData;
if (!pageData) {
callback(404, nextProps);
return;
}
const pageDataPromise = typeof pageData === 'function' ?
pageData() : (pageData[locale] || pageData.index[locale] || pageData.index)();
const promises = [pageDataPromise];
const pathname = nextProps.location.pathname;
const demos = nextProps.utils.get(
nextProps.data, [...pathname.split('/'), 'demo']
);
if (demos) {
promises.push(demos());
}
Promise.all(promises)
.then(list => callback(null, {
...nextProps,
localizedPageData: list[0],
demos: list[1],
}));
}
export default (props) => {
return <MainContent {...props} />;
};