import classNames from 'classnames'; import * as React from 'react'; import { ConfigContext } from '../config-provider'; export interface CommentProps { /** List of action items rendered below the comment content */ actions?: Array; /** The element to display as the comment author. */ author?: React.ReactNode; /** The element to display as the comment avatar - generally an antd Avatar */ avatar?: React.ReactNode; /** ClassName of comment */ className?: string; /** The main content of the comment */ content: React.ReactNode; /** Nested comments should be provided as children of the Comment */ children?: React.ReactNode; /** Comment prefix defaults to '.ant-comment' */ prefixCls?: string; /** Additional style for the comment */ style?: React.CSSProperties; /** A datetime element containing the time to be displayed */ datetime?: React.ReactNode; } const Comment: React.FC = ({ actions, author, avatar, children, className, content, prefixCls: customizePrefixCls, datetime, ...otherProps }) => { const { getPrefixCls, direction } = React.useContext(ConfigContext); const renderNested = (prefixCls: string, nestedChildren: any) => (
{nestedChildren}
); const prefixCls = getPrefixCls('comment', customizePrefixCls); const avatarDom = avatar ? (
{typeof avatar === 'string' ? comment-avatar : avatar}
) : null; const actionDom = actions && actions.length ? ( ) : null; const authorContent = (author || datetime) && (
{author && {author}} {datetime && {datetime}}
); const contentDom = (
{authorContent}
{content}
{actionDom}
); const cls = classNames( prefixCls, { [`${prefixCls}-rtl`]: direction === 'rtl', }, className, ); return (
{avatarDom} {contentDom}
{children ? renderNested(prefixCls, children) : null}
); }; export default Comment;