import * as React from 'react'; import * as PropTypes from 'prop-types'; import classNames from 'classnames'; import { ListGridType, ColumnType } from './index'; import { Col } from '../grid'; import { ConfigConsumer, ConfigConsumerProps } from '../config-provider'; export interface ListItemProps { className?: string; children?: React.ReactNode; prefixCls?: string; style?: React.CSSProperties; extra?: React.ReactNode; actions?: React.ReactNode[]; grid?: ListGridType; } export interface ListItemMetaProps { avatar?: React.ReactNode; className?: string; children?: React.ReactNode; description?: React.ReactNode; prefixCls?: string; style?: React.CSSProperties; title?: React.ReactNode; } export const Meta = (props: ListItemMetaProps) => ( {({ getPrefixCls }: ConfigConsumerProps) => { const { prefixCls: customizePrefixCls, className, avatar, title, description, ...others } = props; const prefixCls = getPrefixCls('list', customizePrefixCls); const classString = classNames(`${prefixCls}-item-meta`, className); const content = (
{title &&

{title}

} {description &&
{description}
}
); return (
{avatar &&
{avatar}
} {(title || description) && content}
); }}
); function getGrid(grid: ListGridType, t: ColumnType) { return grid[t] && Math.floor(24 / grid[t]!); } export default class Item extends React.Component { static Meta: typeof Meta = Meta; static contextTypes = { grid: PropTypes.any, }; context: any; renderItem = ({ getPrefixCls }: ConfigConsumerProps) => { const { grid } = this.context; const { prefixCls: customizePrefixCls, children, actions, extra, className, ...others } = this.props; const prefixCls = getPrefixCls('list', customizePrefixCls); const classString = classNames(`${prefixCls}-item`, className); const metaContent: React.ReactElement[] = []; const otherContent: React.ReactElement[] = []; React.Children.forEach(children, (element: React.ReactElement) => { if (element && element.type && element.type === Meta) { metaContent.push(element); } else { otherContent.push(element); } }); const contentClassString = classNames(`${prefixCls}-item-content`, { [`${prefixCls}-item-content-single`]: metaContent.length < 1, }); const content = otherContent.length > 0 ?
{otherContent}
: null; let actionsContent; if (actions && actions.length > 0) { const actionsContentItem = (action: React.ReactNode, i: number) => (
  • {action} {i !== actions.length - 1 && }
  • ); actionsContent = (
      {actions.map((action, i) => actionsContentItem(action, i))}
    ); } const extraContent = (
    {metaContent} {content} {actionsContent}
    {extra}
    ); const mainContent = grid ? (
    {extra && extraContent} {!extra && metaContent} {!extra && content} {!extra && actionsContent}
    ) : (
    {extra && extraContent} {!extra && metaContent} {!extra && content} {!extra && actionsContent}
    ); return mainContent; }; render() { return {this.renderItem}; } }