import React from 'react'; import classNames from 'classnames'; import TimelineItem, { TimeLineItemProps } from './TimelineItem'; export interface TimelineProps { prefixCls?: string; className?: string; /** 指定最后一个幽灵节点是否存在或内容 */ pending?: React.ReactNode; style?: React.CSSProperties; } export default class Timeline extends React.Component { static Item = TimelineItem as React.ClassicComponentClass; static defaultProps = { prefixCls: 'ant-timeline', }; render() { const { prefixCls, children, pending, className, ...restProps } = this.props; const pendingNode = typeof pending === 'boolean' ? null : pending; const classString = classNames(prefixCls, { [`${prefixCls}-pending`]: !!pending, }, className); const items = React.Children.map(children, (ele: React.ReactElement, idx) => React.cloneElement(ele, { last: idx === (React.Children.count(children) - 1), }), ); const pendingItem = (!!pending) ? ( {pendingNode} ) : null; return (
    {items} {pendingItem}
); } }