import React from 'react' import classnames from 'classnames' import { globalProps } from '../utilities/globalProps' import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from '../utilities/props' import Avatar from '../pb_avatar/_avatar' import Badge from '../pb_badge/_badge' type MultipleUsersStackedProps = { aria?: { [key: string]: string }, className?: string, dark?: boolean, data?: { [key: string]: string }, htmlOptions?: {[key: string]: string | number | boolean | (() => void)}, id?: string, users: Array<{ [key: string]: string }>, } const MultipleUsersStacked = (props: MultipleUsersStackedProps) => { const { aria = {}, className, dark = false, data = {}, htmlOptions = {}, id, users, } = props const moreThanTwo = users.length > 2 const onlyOne = users.length == 1 const displayCount = () => { return moreThanTwo ? 1 : users.length } const ariaProps = buildAriaProps(aria) const dataProps = buildDataProps(data) const htmlProps = buildHtmlProps(htmlOptions) const classes = classnames(buildCss( 'pb_multiple_users_stacked_kit', { single: onlyOne }), globalProps(props), className) const firstUser = () => { return users.slice(0, 1).map((userObject, index) => { return ( ) }) } const secondUser = () => { if (moreThanTwo === false) { return users.slice(1, 2).map((userObject, index) => { return ( ) }) } } const plusUsers = () => { if (moreThanTwo === true) { return ( ) } } return (
{firstUser()} {secondUser()} {plusUsers()}
) } export default MultipleUsersStacked