2016-05-27 11:48:08 +08:00
|
|
|
import React, { Children, cloneElement } from 'react';
|
2016-09-18 14:27:41 +08:00
|
|
|
import { FormattedMessage } from 'react-intl';
|
2016-05-27 11:48:08 +08:00
|
|
|
import DocumentTitle from 'react-document-title';
|
|
|
|
import { getChildren } from 'jsonml.js/lib/utils';
|
|
|
|
import { Timeline } from 'antd';
|
2016-08-17 12:06:38 +08:00
|
|
|
import EditButton from './EditButton';
|
2016-05-27 11:48:08 +08:00
|
|
|
import * as utils from '../utils';
|
|
|
|
|
|
|
|
export default class Article extends React.Component {
|
|
|
|
componentDidMount() {
|
|
|
|
this.componentDidUpdate();
|
|
|
|
}
|
|
|
|
componentDidUpdate() {
|
2016-08-23 21:00:35 +08:00
|
|
|
const links = [...document.querySelectorAll('.outside-link.internal')];
|
2016-05-27 11:48:08 +08:00
|
|
|
if (links.length === 0) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
const checkImgUrl = 'http://alipay-rmsdeploy-dev-image.oss-cn-hangzhou-zmf.aliyuncs.com/rmsportal/JdVaTbZzPxEldUi.png';
|
2016-07-17 15:25:12 +08:00
|
|
|
this.pingTimer = utils.ping(checkImgUrl, status => {
|
2016-05-27 11:48:08 +08:00
|
|
|
if (status === 'responded') {
|
|
|
|
links.forEach(link => (link.style.display = 'block'));
|
2016-08-04 17:59:07 +08:00
|
|
|
} else {
|
|
|
|
links.forEach(link => link.parentNode.removeChild(link));
|
2016-05-27 11:48:08 +08:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2016-07-17 15:25:12 +08:00
|
|
|
componentWillUnmount() {
|
|
|
|
clearTimeout(this.pingTimer);
|
|
|
|
}
|
2016-05-27 11:48:08 +08:00
|
|
|
getArticle(article) {
|
|
|
|
const { content } = this.props;
|
|
|
|
const { meta } = content;
|
|
|
|
if (!meta.timeline) {
|
|
|
|
return article;
|
|
|
|
}
|
|
|
|
const timelineItems = [];
|
|
|
|
let temp = [];
|
2016-08-01 11:43:42 +08:00
|
|
|
let i = 1;
|
|
|
|
Children.forEach(article.props.children, child => {
|
2016-05-27 11:48:08 +08:00
|
|
|
if (child.type === 'h2' && temp.length > 0) {
|
|
|
|
timelineItems.push(<Timeline.Item key={i}>{temp}</Timeline.Item>);
|
|
|
|
temp = [];
|
2016-08-01 11:43:42 +08:00
|
|
|
i += 1;
|
2016-05-27 11:48:08 +08:00
|
|
|
}
|
|
|
|
temp.push(child);
|
|
|
|
});
|
2016-08-01 11:43:42 +08:00
|
|
|
if (temp.length > 0) {
|
|
|
|
timelineItems.push(<Timeline.Item key={i}>{temp}</Timeline.Item>);
|
|
|
|
}
|
2016-05-27 11:48:08 +08:00
|
|
|
return cloneElement(article, {
|
|
|
|
children: <Timeline>{timelineItems}</Timeline>,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
render() {
|
|
|
|
const props = this.props;
|
|
|
|
const content = props.content;
|
|
|
|
|
|
|
|
const { meta, description } = content;
|
2016-08-17 12:06:38 +08:00
|
|
|
const { title, subtitle, chinese, english, filename } = meta;
|
2016-07-17 14:46:21 +08:00
|
|
|
|
2016-05-27 11:48:08 +08:00
|
|
|
return (
|
|
|
|
<DocumentTitle title={`${title || chinese || english} - Ant Design`}>
|
|
|
|
<article className="markdown">
|
|
|
|
<h1>
|
|
|
|
{title || english}
|
|
|
|
{
|
|
|
|
(!subtitle && !chinese) ? null :
|
|
|
|
<span className="subtitle">{subtitle || chinese}</span>
|
|
|
|
}
|
2016-09-18 14:27:41 +08:00
|
|
|
<EditButton title={<FormattedMessage id="app.content.edit-page" />} filename={filename} />
|
2016-05-27 11:48:08 +08:00
|
|
|
</h1>
|
|
|
|
{
|
|
|
|
!description ? null :
|
|
|
|
props.utils.toReactComponent(
|
|
|
|
['section', { className: 'markdown' }].concat(getChildren(description))
|
|
|
|
)
|
|
|
|
}
|
|
|
|
{
|
2016-07-17 15:20:30 +08:00
|
|
|
(!content.toc || content.toc.length <= 1 || meta.toc === false) ? null :
|
2016-05-27 11:48:08 +08:00
|
|
|
<section className="toc">{props.utils.toReactComponent(content.toc)}</section>
|
|
|
|
}
|
|
|
|
{
|
|
|
|
this.getArticle(props.utils.toReactComponent(
|
|
|
|
['section', { className: 'markdown' }].concat(getChildren(content.content))
|
|
|
|
))
|
|
|
|
}
|
|
|
|
</article>
|
|
|
|
</DocumentTitle>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|