import React from 'react' import classnames from 'classnames' import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from '../utilities/props' import { globalProps } from '../utilities/globalProps' import Avatar from '../pb_avatar/_avatar' type MultipleUsersProps = { aria?: { [key: string]: string }, className?: string, dark?: boolean, data?: { [key: string]: string }, htmlOptions?: {[key: string]: string | number | boolean | (() => void)}, id?: string, maxDisplayedUsers?: number, reverse?: boolean, size?: "md" | "lg" | "sm" | "xl" | "xs" | "xxs", users: Array<{ [key: string]: string }>, } const MultipleUsers = (props: MultipleUsersProps): React.ReactElement => { const { aria = {}, className, dark = false, data = {}, htmlOptions = {}, id, maxDisplayedUsers = 4, reverse = false, size = 'xs', users, } = props const displayCount = users.length > maxDisplayedUsers ? maxDisplayedUsers - 1 : users.length const usersToDisplay = users.slice(0, displayCount) const reverseClass = reverse === true ? 'reverse' : '' const avatarSizeClass = size === 'xxs' ? 'xxs' : 'xs' const ariaProps = buildAriaProps(aria) const dataProps = buildDataProps(data) const htmlProps = buildHtmlProps(htmlOptions) const classes = classnames( buildCss('pb_multiple_users_kit', reverseClass), globalProps(props), className ) const itemClasses = classnames( 'pb_multiple_users_item', buildCss('multiple_users_badge', avatarSizeClass) ) return (
{usersToDisplay.map((avatarData, index) => ( ))} { users.length > maxDisplayedUsers &&
{`+${users.length - 3}`}
}
) } export default MultipleUsers