import { Avatar } from "@chakra-ui/react"
const Demo = () => {
return (
<Avatar.Root>
<Avatar.Fallback name="Segun Adebayo" />
<Avatar.Image src="https://bit.ly/sage-adebayo" />
</Avatar.Root>
)
}
Usage
import { Avatar, AvatarGroup } from "@chakra-ui/react"
<AvatarGroup>
<Avatar />
</AvatarGroup>
Examples
Sizes
Use the size
prop to change the size of the avatar
import { Avatar, For, HStack } from "@chakra-ui/react"
const Demo = () => {
return (
<HStack gap="3">
<For each={["xs", "sm", "md", "lg", "xl", "2xl"]}>
{(size) => (
<Avatar.Root size={size} key={size}>
<Avatar.Fallback name="Segun Adebayo" />
<Avatar.Image src="https://bit.ly/sage-adebayo" />
</Avatar.Root>
)}
</For>
</HStack>
)
}
Variants
Use the variant
prop to change the variant of the avatar
import { Avatar, For, HStack } from "@chakra-ui/react"
const Demo = () => {
return (
<HStack gap="3">
<For each={["solid", "outline", "subtle"]}>
{(variant) => (
<Avatar.Root key={variant} variant={variant}>
<Avatar.Fallback name="Segun Adebayo" />
</Avatar.Root>
)}
</For>
</HStack>
)
}
Shape
Use the shape
prop to change the shape of the avatar, from rounded
to
square
import { Avatar, HStack } from "@chakra-ui/react"
const Demo = () => {
return (
<HStack gap="4">
<Avatar.Root shape="square" size="lg">
<Avatar.Fallback name="Dan Abramov" />
<Avatar.Image src="https://bit.ly/dan-abramov" />
</Avatar.Root>
<Avatar.Root shape="rounded" size="lg">
<Avatar.Fallback name="Segun Adebayo" />
<Avatar.Image src="https://bit.ly/sage-adebayo" />
</Avatar.Root>
<Avatar.Root shape="full" size="lg">
<Avatar.Fallback name="Random User" />
<Avatar.Image src="https://images.unsplash.com/photo-1531746020798-e6953c6e8e04" />
</Avatar.Root>
</HStack>
)
}
Colors
Use the colorPalette
prop to change the color of the avatar
gray
red
green
blue
teal
pink
purple
cyan
orange
yellow
import { Avatar, Stack, Text } from "@chakra-ui/react"
import { colorPalettes } from "compositions/lib/color-palettes"
const Demo = () => {
return (
<Stack gap="2" align="flex-start">
{colorPalettes.map((colorPalette) => (
<Stack key={colorPalette} align="center" direction="row" gap="10">
<Text minW="8ch">{colorPalette}</Text>
<Avatar.Root colorPalette={colorPalette}>
<Avatar.Fallback name="Segun Adebayo" />
<Avatar.Image src="https://bit.ly/sage-adebayo" />
</Avatar.Root>
<Avatar.Root colorPalette={colorPalette}>
<Avatar.Fallback name="Segun Adebayo" />
</Avatar.Root>
<Avatar.Root colorPalette={colorPalette}>
<Avatar.Fallback />
</Avatar.Root>
</Stack>
))}
</Stack>
)
}
Fallback
Render Avatar.Icon
as the fallback when the name is not provided or when the
image fails to load.
import { Avatar, HStack } from "@chakra-ui/react"
const Demo = () => {
return (
<HStack>
<Avatar.Root>
<Avatar.Fallback name="Oshigaki Kisame" />
<Avatar.Image src="https://bit.ly/broken-link" />
</Avatar.Root>
<Avatar.Root colorPalette="teal">
<Avatar.Fallback name="Sasuke Uchiha" />
<Avatar.Image src="https://bit.ly/broken-link" />
</Avatar.Root>
<Avatar.Root colorPalette="red">
<Avatar.Fallback />
<Avatar.Image src="https://bit.ly/broken-link" />
</Avatar.Root>
</HStack>
)
}
Random Color
Combine the colorPalette
prop with some custom logic to dynamically change the
color of the avatar
import { Avatar, HStack } from "@chakra-ui/react"
const colorPalette = ["red", "blue", "green", "yellow", "purple", "orange"]
const pickPalette = (name: string) => {
const index = name.charCodeAt(0) % colorPalette.length
return colorPalette[index]
}
const Demo = () => {
return (
<HStack>
<Avatar.Root colorPalette={pickPalette("Shane Nelson")}>
<Avatar.Fallback name="Shane Nelson" />
</Avatar.Root>
<Avatar.Root colorPalette={pickPalette("Brook Lesnar")}>
<Avatar.Fallback name="Brook Lesnar" />
</Avatar.Root>
<Avatar.Root colorPalette={pickPalette("John Lennon")}>
<Avatar.Fallback name="John Lennon" />
</Avatar.Root>
</HStack>
)
}
Ring
Use the outline*
props to add a ring around the avatar
data:image/s3,"s3://crabby-images/b1d42/b1d42c63fe98cb9aaa4667507aea574e730b6448" alt=""
data:image/s3,"s3://crabby-images/847e1/847e180826a0c5be256e87237de783508510bb8c" alt=""
data:image/s3,"s3://crabby-images/9fefe/9fefea764286bd6f47b3f01853256b49fa9c79c1" alt=""
import { Avatar, HStack, defineStyle } from "@chakra-ui/react"
const ringCss = defineStyle({
outlineWidth: "2px",
outlineColor: "colorPalette.500",
outlineOffset: "2px",
outlineStyle: "solid",
})
const Demo = () => {
return (
<HStack gap="4">
<Avatar.Root css={ringCss} colorPalette="pink">
<Avatar.Fallback name="Random" />
<Avatar.Image src="https://randomuser.me/api/portraits/men/70.jpg" />
</Avatar.Root>
<Avatar.Root css={ringCss} colorPalette="green">
<Avatar.Fallback name="Random" />
<Avatar.Image src="https://randomuser.me/api/portraits/men/54.jpg" />
</Avatar.Root>
<Avatar.Root css={ringCss} colorPalette="blue">
<Avatar.Fallback name="Random" />
<Avatar.Image src="https://randomuser.me/api/portraits/men/42.jpg" />
</Avatar.Root>
</HStack>
)
}
Group
Use the Group
component to group multiple avatars together
data:image/s3,"s3://crabby-images/ae115/ae115469591029eea2179066ef21e0cbbf49274c" alt=""
data:image/s3,"s3://crabby-images/c07fb/c07fb980116154236c1fef66749bfc8eb86692cf" alt=""
data:image/s3,"s3://crabby-images/f530f/f530f300d0c05693cd78fb855efc8c281fea67ec" alt=""
import { Avatar, AvatarGroup } from "@chakra-ui/react"
const Demo = () => {
return (
<AvatarGroup gap="0" spaceX="-3" size="lg">
<Avatar.Root>
<Avatar.Fallback name="Uchiha Sasuke" />
<Avatar.Image src="https://cdn.myanimelist.net/r/84x124/images/characters/9/131317.webp?s=d4b03c7291407bde303bc0758047f6bd" />
</Avatar.Root>
<Avatar.Root>
<Avatar.Fallback name="Baki Ani" />
<Avatar.Image src="https://cdn.myanimelist.net/r/84x124/images/characters/7/284129.webp?s=a8998bf668767de58b33740886ca571c" />
</Avatar.Root>
<Avatar.Root>
<Avatar.Fallback name="Uchiha Chan" />
<Avatar.Image src="https://cdn.myanimelist.net/r/84x124/images/characters/9/105421.webp?s=269ff1b2bb9abe3ac1bc443d3a76e863" />
</Avatar.Root>
<Avatar.Root variant="solid">
<Avatar.Fallback>+3</Avatar.Fallback>
</Avatar.Root>
</AvatarGroup>
)
}
Stacking
When using the AvatarGroup
component, you can use the stacking
prop to
change the stacking order of the avatars
data:image/s3,"s3://crabby-images/ae115/ae115469591029eea2179066ef21e0cbbf49274c" alt=""
data:image/s3,"s3://crabby-images/c07fb/c07fb980116154236c1fef66749bfc8eb86692cf" alt=""
data:image/s3,"s3://crabby-images/f530f/f530f300d0c05693cd78fb855efc8c281fea67ec" alt=""
data:image/s3,"s3://crabby-images/ae115/ae115469591029eea2179066ef21e0cbbf49274c" alt=""
data:image/s3,"s3://crabby-images/c07fb/c07fb980116154236c1fef66749bfc8eb86692cf" alt=""
data:image/s3,"s3://crabby-images/f530f/f530f300d0c05693cd78fb855efc8c281fea67ec" alt=""
data:image/s3,"s3://crabby-images/ae115/ae115469591029eea2179066ef21e0cbbf49274c" alt=""
data:image/s3,"s3://crabby-images/c07fb/c07fb980116154236c1fef66749bfc8eb86692cf" alt=""
data:image/s3,"s3://crabby-images/f530f/f530f300d0c05693cd78fb855efc8c281fea67ec" alt=""
import { Avatar, AvatarGroup, Stack } from "@chakra-ui/react"
const Demo = () => {
return (
<Stack>
<AvatarGroup size="lg" stacking="last-on-top">
{items.map((item) => (
<Avatar.Root key={item.name}>
<Avatar.Fallback name={item.name} />
<Avatar.Image src={item.src} />
</Avatar.Root>
))}
<Avatar.Root>
<Avatar.Fallback>+3</Avatar.Fallback>
</Avatar.Root>
</AvatarGroup>
<AvatarGroup size="lg" stacking="first-on-top">
{items.map((item) => (
<Avatar.Root key={item.name}>
<Avatar.Fallback name={item.name} />
<Avatar.Image src={item.src} />
</Avatar.Root>
))}
<Avatar.Root>
<Avatar.Fallback>+3</Avatar.Fallback>
</Avatar.Root>
</AvatarGroup>
<AvatarGroup size="lg" spaceX="1" borderless>
{items.map((item) => (
<Avatar.Root key={item.name}>
<Avatar.Fallback name={item.name} />
<Avatar.Image src={item.src} />
</Avatar.Root>
))}
<Avatar.Root>
<Avatar.Fallback>+3</Avatar.Fallback>
</Avatar.Root>
</AvatarGroup>
</Stack>
)
}
const items = [
{
src: "https://cdn.myanimelist.net/r/84x124/images/characters/9/131317.webp?s=d4b03c7291407bde303bc0758047f6bd",
name: "Uchiha Sasuke",
},
{
src: "https://cdn.myanimelist.net/r/84x124/images/characters/7/284129.webp?s=a8998bf668767de58b33740886ca571c",
name: "Baki Ani",
},
{
src: "https://cdn.myanimelist.net/r/84x124/images/characters/9/105421.webp?s=269ff1b2bb9abe3ac1bc443d3a76e863",
name: "Uchiha Chan",
},
]
Persona
Here's an example of how to use the Avatar
component to display a user
persona.
John Mason
john.mason@example.com
Melissa Jones
melissa.jones@example.com
import { Avatar, HStack, Stack, Text } from "@chakra-ui/react"
const Demo = () => {
return (
<Stack gap="8">
{users.map((user) => (
<HStack key={user.email} gap="4">
<Avatar.Root>
<Avatar.Fallback name={user.name} />
<Avatar.Image src={user.avatar} />
</Avatar.Root>
<Stack gap="0">
<Text fontWeight="medium">{user.name}</Text>
<Text color="fg.muted" textStyle="sm">
{user.email}
</Text>
</Stack>
</HStack>
))}
</Stack>
)
}
const users = [
{
id: "1",
name: "John Mason",
email: "john.mason@example.com",
avatar: "https://i.pravatar.cc/300?u=iu",
},
{
id: "2",
name: "Melissa Jones",
email: "melissa.jones@example.com",
avatar: "https://i.pravatar.cc/300?u=po",
},
]
Badge
Show a badge on the right corner of the avatar by composing the Float
and
Circle
components
import { Avatar, Circle, Float } from "@chakra-ui/react"
const Demo = () => {
return (
<Avatar.Root colorPalette="green" variant="subtle">
<Avatar.Fallback name="Dari Ann" />
<Float placement="bottom-end" offsetX="1" offsetY="1">
<Circle
bg="green.500"
size="8px"
outline="0.2em solid"
outlineColor="bg"
/>
</Float>
</Avatar.Root>
)
}
Overflow
Here's an example of how to handle an overflow of avatars by composing the
Menu
and Avatar
components.
import { Avatar, Group } from "@chakra-ui/react"
import {
MenuContent,
MenuItem,
MenuRoot,
MenuTrigger,
} from "@/components/ui/menu"
const names = [
"Naruto Uzumaki",
"Sakura Haruno",
"Kakashi Hatake",
"Hinata Hyuga",
"Shikamaru Nara",
]
const maxAvatars = 3
const Demo = () => {
const { items, overflow } = partition(names, maxAvatars)
return (
<Group gap="0" spaceX="2">
{items.map((item) => (
<Avatar.Root key={item} colorPalette={pickPalette(item)}>
<Avatar.Fallback name={item} />
</Avatar.Root>
))}
{overflow.length > 0 && (
<MenuRoot positioning={{ placement: "bottom" }}>
<MenuTrigger rounded="full" focusRing="outside">
<Avatar.Root variant="outline">
<Avatar.Fallback>+{overflow.length}</Avatar.Fallback>
</Avatar.Root>
</MenuTrigger>
<MenuContent>
{overflow.map((item) => (
<MenuItem value={item} key={item}>
<Avatar.Root size="xs" colorPalette={pickPalette(item)}>
<Avatar.Fallback name={item} />
</Avatar.Root>
{item}
</MenuItem>
))}
</MenuContent>
</MenuRoot>
)}
</Group>
)
}
const colorPalette = ["red", "blue", "green", "yellow", "purple", "orange"]
const pickPalette = (name: string) => {
const index = name.charCodeAt(0) % colorPalette.length
return colorPalette[index]
}
const partition = (arr: string[], max: number) => {
const items = []
const overflow = []
for (const item of arr) {
if (items.length < max) items.push(item)
else overflow.push(item)
}
return { items, overflow }
}
Next.js
Here's an example of how to compose the avatar with Next.js Image.
import { getImageProps } from "next/image"
function Demo() {
const imageProps = getImageProps({
src: "/image.png",
})
return (
<Avatar.Root>
<Avatar.Fallback name="Segun Adebayo" />
<Avatar.Image {...imageProps} />
</Avatar.Root>
)
}
Store
An alternative way to access the avatar state and methods is to use the
RootProvider
component and the useAvatar
store hook.
not loaded
"use client"
import { Avatar, Code, Stack, useAvatar } from "@chakra-ui/react"
const Demo = () => {
const avatar = useAvatar()
return (
<Stack align="flex-start">
<Avatar.RootProvider value={avatar}>
<Avatar.Image src="https://bit.ly/sage-adebayo" />
<Avatar.Fallback name="Segun Adebayo" />
</Avatar.RootProvider>
<Code>{avatar.loaded ? "loaded" : "not loaded"}</Code>
</Stack>
)
}
Closed Component
Here's how to setup the Avatar for a closed component composition.
import {
Avatar as ChakraAvatar,
AvatarGroup as ChakraAvatarGroup,
} from "@chakra-ui/react"
import * as React from "react"
type ImageProps = React.ImgHTMLAttributes<HTMLImageElement>
export interface AvatarProps extends ChakraAvatar.RootProps {
name?: string
src?: string
srcSet?: string
loading?: ImageProps["loading"]
icon?: React.ReactElement
fallback?: React.ReactNode
}
export const Avatar = React.forwardRef<HTMLDivElement, AvatarProps>(
function Avatar(props, ref) {
const { name, src, srcSet, loading, icon, fallback, children, ...rest } =
props
return (
<ChakraAvatar.Root ref={ref} {...rest}>
<ChakraAvatar.Fallback name={name}>
{fallback || icon}
</ChakraAvatar.Fallback>
<ChakraAvatar.Image src={src} srcSet={srcSet} loading={loading} />
{children}
</ChakraAvatar.Root>
)
},
)
export const AvatarGroup = ChakraAvatarGroup
Props
Root
Prop | Default | Type |
---|---|---|
colorPalette | 'gray' | 'gray' | 'red' | 'orange' | 'yellow' | 'green' | 'teal' | 'blue' | 'cyan' | 'purple' | 'pink' | 'accent' The color palette of the component |
size | 'md' | 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl' The size of the component |
variant | 'subtle' | 'solid' | 'subtle' | 'outline' The variant of the component |
shape | 'full' | 'square' | 'rounded' | 'full' The shape of the component |
asChild | boolean Use the provided child element as the default rendered element, combining their props and behavior. For more details, read our Composition guide. | |
ids | Partial<{ root: string; image: string; fallback: string }> The ids of the elements in the avatar. Useful for composition. | |
onStatusChange | (details: StatusChangeDetails) => void Functional called when the image loading status changes. | |
borderless | 'true' | 'false' The borderless of the component | |
as | React.ElementType The underlying element to render. | |
unstyled | boolean Whether to remove the component's style. |
Fallback
Prop | Default | Type |
---|---|---|
asChild | boolean Use the provided child element as the default rendered element, combining their props and behavior. For more details, read our Composition guide. | |
name | string | |
icon | React.ReactElement |
Image
Prop | Default | Type |
---|---|---|
asChild | boolean Use the provided child element as the default rendered element, combining their props and behavior. For more details, read our Composition guide. |