import * as React from 'react'; import classNames from 'classnames'; import toArray from 'rc-util/lib/Children/toArray'; import { cloneElement } from '../_util/reactNode'; import { ConfigContext } from '../config-provider'; import Avatar from './avatar'; import Popover from '../popover'; export interface GroupProps { className?: string; children?: React.ReactNode; style?: React.CSSProperties; prefixCls?: string; maxCount?: number; maxStyle?: React.CSSProperties; maxPopoverPlacement?: 'top' | 'bottom'; } const Group: React.FC = props => { const { getPrefixCls, direction } = React.useContext(ConfigContext); const { prefixCls: customizePrefixCls, className = '', maxCount, maxStyle } = props; const prefixCls = getPrefixCls('avatar-group', customizePrefixCls); const cls = classNames( prefixCls, { [`${prefixCls}-rtl`]: direction === 'rtl', }, className, ); const { children, maxPopoverPlacement = 'top' } = props; const childrenWithProps = toArray(children).map((child, index) => { return cloneElement(child, { key: `avatar-key-${index}`, }); }); const numOfChildren = childrenWithProps.length; if (maxCount && maxCount < numOfChildren) { const childrenShow = childrenWithProps.slice(0, maxCount); const childrenHidden = childrenWithProps.slice(maxCount, numOfChildren); childrenShow.push( {`+${numOfChildren - maxCount}`} , ); return (
{childrenShow}
); } return (
{children}
); }; export default Group;