import React, { Children, cloneElement } from 'react'; import PropTypes from 'prop-types'; import { FormattedMessage } from 'react-intl'; import DocumentTitle from 'react-document-title'; import { getChildren } from 'jsonml.js/lib/utils'; import { Timeline, Alert } from 'antd'; import delegate from 'delegate'; import EditButton from './EditButton'; import * as utils from '../utils'; export default class Article extends React.Component { static contextTypes = { intl: PropTypes.object.isRequired, } componentDidMount() { // Add ga event click this.delegation = delegate(this.node, '.resource-card', 'click', (e) => { if (window.ga) { window.ga('send', 'event', 'Download', 'resource', e.delegateTarget.href); } }, false); this.componentDidUpdate(); } componentDidUpdate() { const links = [...document.querySelectorAll('.outside-link.internal')]; if (links.length === 0) { return; } // eslint-disable-next-line const checkImgUrl = 'https://private.alipay' + 'objects.com/alip' + 'ay-rmsdeploy-image/rmsportal/RKuAiriJqrUhyqW.png'; this.pingTimer = utils.ping(checkImgUrl, (status) => { if (status !== 'timeout' && status !== 'error') { links.forEach(link => (link.style.display = 'block')); } else { links.forEach(link => link.parentNode.removeChild(link)); } }); } componentWillUnmount() { clearTimeout(this.pingTimer); if (this.delegation) { this.delegation.destroy(); } } getArticle(article) { const { content } = this.props; const { meta } = content; if (!meta.timeline) { return article; } const timelineItems = []; let temp = []; let i = 1; Children.forEach(article.props.children, (child) => { if (child.type === 'h2' && temp.length > 0) { timelineItems.push({temp}); temp = []; i += 1; } temp.push(child); }); if (temp.length > 0) { timelineItems.push({temp}); } return cloneElement(article, { children: {timelineItems}, }); } render() { const props = this.props; const content = props.content; const { meta, description } = content; const { title, subtitle, filename } = meta; const locale = this.context.intl.locale; const isNotTranslated = locale === 'en-US' && typeof title === 'object'; return (
{ this.node = node; }}> {isNotTranslated && ( This article has not been translated, hope that your can PR to translated it. Help us! )} /> )}

{title[locale] || title} { !subtitle || locale === 'en-US' ? null : {subtitle} } } filename={filename} />

{ !description ? null : props.utils.toReactComponent( ['section', { className: 'markdown' }].concat(getChildren(description)) ) } { (!content.toc || content.toc.length <= 1 || meta.toc === false) ? null :
{props.utils.toReactComponent(content.toc)}
} { this.getArticle(props.utils.toReactComponent( ['section', { className: 'markdown' }].concat(getChildren(content.content)) )) }
); } }