Avatar
A circular identification element that prominently showcases the user's customized profile picture or their first and last name initials.
import * as React from 'react';
import { Avatar, getUserColor } from '@itwin/itwinui-react';
const imgSrc =
'';
export default () => {
return (
<Avatar
abbreviation='RR'
backgroundColor={getUserColor('Robbie Robot')}
image={<img src={imgSrc} alt='' />}
title='Robbie Robot'
size='x-large'
/>
);
};
The avatar is an essential UI component, making it easier to identify a person or organization by their photo, icon, or initials.
Usage
Different props can be passed to the <Avatar>
component to customize it according to the user’s needs.
image
prop can be passed to set a custom image source or icon that will be displayed within the avatar.abbreviation
prop can be passed to set a short abbreviation or initials that will be displayed whenimage
is not available.
import * as React from 'react';
import { Avatar, getUserColor } from '@itwin/itwinui-react';
import { SvgUser } from '@itwin/itwinui-icons-react';
const imgSrc =
'';
export default () => {
return (
<div className='demo-container'>
<Avatar
abbreviation='TR'
backgroundColor={getUserColor('Terry Rivers')}
title='Terry Rivers'
size='x-large'
status='online'
/>
<Avatar
abbreviation='AU'
backgroundColor={getUserColor('Anonymous user')}
image={<SvgUser aria-hidden='true' />}
title='Anonymous user'
size='x-large'
status='away'
/>
<Avatar
abbreviation='RR'
backgroundColor={getUserColor('Robbie Robot')}
image={<img src={imgSrc} alt='' />}
title='Robbie Robot'
size='x-large'
status='busy'
/>
</div>
);
};
Sizes
Avatars can be displayed in various sizes including small
, medium
, large
, and x-large
.
import * as React from 'react';
import { Avatar, getUserColor } from '@itwin/itwinui-react';
export default () => {
return (
<div className='demo-container'>
<Avatar
abbreviation='TR'
backgroundColor={getUserColor('Terry Rivers')}
size='small'
title='Terry Rivers'
/>
<Avatar
abbreviation='RM'
backgroundColor={getUserColor('Robin Mercer')}
size='medium'
title='Robin Mercer'
/>
<Avatar
abbreviation='MV'
backgroundColor={getUserColor('Morgan Vera')}
size='large'
title='Morgan Vera'
/>
<Avatar
abbreviation='JM'
backgroundColor={getUserColor('Jean Mullins')}
size='x-large'
title='Jean Mullins'
/>
</div>
);
};
Status indicators
Status indicators are indicators that display in the bottom right of the avatar. Statuses can be set using the status
prop. The available statuses are:
online
away
busy
offline
We suggest not using statuses on the small size avatar.
import * as React from 'react';
import { Avatar, getUserColor } from '@itwin/itwinui-react';
export default () => {
return (
<div className='demo-container'>
<Avatar
abbreviation='TR'
backgroundColor={getUserColor('Terry Rivers')}
title='Terry Rivers'
size='x-large'
status='online'
/>
<Avatar
abbreviation='RM'
backgroundColor={getUserColor('Robin Mercer')}
title='Robin Mercer'
size='x-large'
status='away'
/>
<Avatar
abbreviation='JM'
backgroundColor={getUserColor('Jean Mullins')}
title='Jean Mullins'
size='x-large'
status='busy'
/>
<Avatar
abbreviation='AM'
backgroundColor={getUserColor('Ashley Miles')}
title='Ashley Miles'
size='x-large'
status='offline'
/>
</div>
);
};
AvatarGroup
Avatars can be displayed in a list to represent a group of people using the <AvatarGroup>
component. This visual treatment reinforces the fact that these people work together and/or share similar permissions to access/view/edit a file or a project.
By default, the avatars will overlay each other to save space. This can be turned off by setting stacked={false}
if needed.
Note that when using the stacked group, you can not display status indicators.
import * as React from 'react';
import { AvatarGroup, Avatar, getUserColor } from '@itwin/itwinui-react';
export default () => {
return (
<AvatarGroup iconSize='x-large'>
<Avatar
abbreviation='TR'
backgroundColor={getUserColor('Terry Rivers')}
title='Terry Rivers'
/>
<Avatar
abbreviation='RM'
backgroundColor={getUserColor('Robin Mercer')}
title='Robin Mercer'
/>
<Avatar
abbreviation='MV'
backgroundColor={getUserColor('Morgan Vera')}
title='Morgan Vera'
/>
<Avatar
abbreviation='JM'
backgroundColor={getUserColor('Jean Mullins')}
title='Jean Mullins'
/>
<Avatar
abbreviation='AM'
backgroundColor={getUserColor('Ashley Miles')}
title='Ashley Miles'
/>
</AvatarGroup>
);
};
Animated Stack
You can also have the stacked group animate to unstacked on hover by passing the animated
prop. When doing this, be sure to pay close attention to unintentionally shifting other content on the page.
import * as React from 'react';
import { AvatarGroup, Avatar, getUserColor } from '@itwin/itwinui-react';
export default () => {
return (
<AvatarGroup animated iconSize='x-large'>
<Avatar
abbreviation='TR'
backgroundColor={getUserColor('Terry Rivers')}
title='Terry Rivers'
/>
<Avatar
abbreviation='RM'
backgroundColor={getUserColor('Robin Mercer')}
title='Robin Mercer'
/>
<Avatar
abbreviation='MV'
backgroundColor={getUserColor('Morgan Vera')}
title='Morgan Vera'
/>
<Avatar
abbreviation='JM'
backgroundColor={getUserColor('Jean Mullins')}
title='Jean Mullins'
/>
<Avatar
abbreviation='AM'
backgroundColor={getUserColor('Ashley Miles')}
title='Ashley Miles'
/>
</AvatarGroup>
);
};
Overflow
By default a maximum of five avatars will be shown within a group. Additional avatars are hidden; however, the number of hidden items will be displayed in the last avatar circle as shown below.
import * as React from 'react';
import { AvatarGroup, Avatar, getUserColor } from '@itwin/itwinui-react';
export default () => {
return (
<AvatarGroup iconSize='x-large'>
<Avatar
abbreviation='TR'
backgroundColor={getUserColor('Terry Rivers')}
title='Terry Rivers'
/>
<Avatar
abbreviation='RM'
backgroundColor={getUserColor('Robin Mercer')}
title='Robin Mercer'
/>
<Avatar
abbreviation='MV'
backgroundColor={getUserColor('Morgan Vera')}
title='Morgan Vera'
/>
<Avatar
abbreviation='JM'
backgroundColor={getUserColor('Jean Mullins')}
title='Jean Mullins'
/>
<Avatar
abbreviation='AM'
backgroundColor={getUserColor('Ashley Miles')}
title='Ashley Miles'
/>
<Avatar
abbreviation='TR'
backgroundColor={getUserColor('Terry Rivers')}
title='Terry Rivers'
/>
<Avatar
abbreviation='RM'
backgroundColor={getUserColor('Robin Mercer')}
title='Robin Mercer'
/>
<Avatar
abbreviation='MV'
backgroundColor={getUserColor('Morgan Vera')}
title='Morgan Vera'
/>
<Avatar
abbreviation='JM'
backgroundColor={getUserColor('Jean Mullins')}
title='Jean Mullins'
/>
<Avatar
abbreviation='AM'
backgroundColor={getUserColor('Ashley Miles')}
title='Ashley Miles'
/>
<Avatar
abbreviation='TR'
backgroundColor={getUserColor('Terry Rivers')}
title='Terry Rivers'
/>
<Avatar
abbreviation='RM'
backgroundColor={getUserColor('Robin Mercer')}
title='Robin Mercer'
/>
<Avatar
abbreviation='MV'
backgroundColor={getUserColor('Morgan Vera')}
title='Morgan Vera'
/>
<Avatar
abbreviation='JM'
backgroundColor={getUserColor('Jean Mullins')}
title='Jean Mullins'
/>
<Avatar
abbreviation='AM'
backgroundColor={getUserColor('Ashley Miles')}
title='Ashley Miles'
/>
</AvatarGroup>
);
};
Additionally, you could display a tooltip on hover, a dialog on click, or perhaps a dropdown menu of the hidden users. Implementation of these options depends on the purpose of the page and the use case.
The example below displays a tooltip of all hidden avatars. It also uses the property maxIcons
to limit the number of visible avatars to three.
import * as React from 'react';
import {
AvatarGroup,
Avatar,
getUserColor,
Tooltip,
} from '@itwin/itwinui-react';
export default () => {
const userNames = [
'Terry Rivers',
'Robin Mercer',
'Morgan Vera',
'Ashley Miles',
'Jean Mullins',
'Charlie Mayfield',
'Peyton Pennington',
'Justice Harrington',
'Alex Gonzales',
'Jordan Baker',
];
/**
* Ref is set on the last avatar for tooltip positioning.
*/
const [avatarRef, setAvatarRef] = React.useState(null);
const maxIcons = 3;
const arrayLength = maxIcons;
const usersSubArray = userNames.slice(arrayLength);
const tooltipContent = usersSubArray.join(`\n`);
return (
<>
<AvatarGroup
iconSize='x-large'
maxIcons={maxIcons}
countIconProps={{ ref: setAvatarRef }}
>
{userNames.map((name, index) => (
<Avatar
key={`${name}-${index}`}
abbreviation={name
.split(' ')
.map((token) => token[0])
.join('')}
backgroundColor={getUserColor(name)}
title={name}
/>
))}
</AvatarGroup>
<Tooltip
reference={avatarRef}
content={tooltipContent}
placement='right'
style={{ whiteSpace: 'pre' }}
/>
</>
);
};
Props
Avatar
Prop | Description | Default |
---|---|---|
size | Size of an avatar. "small" | "medium" | "large" | "x-large" | 'small' |
status | Status/Availability of a user. AvatarStatus | |
title | Text which will appear when hovering over the icon. string | |
abbreviation | Abbreviation to be displayed. string | |
image | User image to be displayed. Can be <img> or <svg> or anything else.Element | |
backgroundColor | Color of the icon. You can use getUserColor function to generate color from user name or email. If not provided, default background color from CSS styling will be used (hsl(72, 51%, 56%) / olive green)."skyblue" | "celery" | "froly" | "steelblue" | "sunglow" | "seabuckthorn" | "montecarlo" | "poloblue" | "bouquet" | "ash" | "oak" | AnyString | |
translatedStatusTitles | Translated status messages shown on hover. StatusTitles | |
as | "symbol" | "object" | "span" | "a" | "abbr" | "address" | "area" | "article" | "aside" | "audio" | "b" | "base" | "bdi" | "bdo" | "big" | "blockquote" | "body" | "br" | "button" | ... 159 more ... | FunctionComponent<...> |
AvatarGroup
Prop | Description | Default |
---|---|---|
maxIcons | Max number of avatars unstacked. number | 5 |
stacked | If true, group will be stacked to take less space. boolean | true |
animated | If true, group will be animated on hover. boolean | false |
iconSize | Size of avatars and count avatars. "small" | "medium" | "large" | "x-large" | 'small' |
children | Avatars in the group. ReactNode | |
countIconProps | Count Avatar props. Omit<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & { ref?: Ref<HTMLDivElement>; } | |
as | "symbol" | "object" | "div" | "a" | "abbr" | "address" | "area" | "article" | "aside" | "audio" | "b" | "base" | "bdi" | "bdo" | "big" | "blockquote" | "body" | "br" | "button" | "canvas" | ... 158 more ... | FunctionComponent<...> |