AvatarGroup
Stack multiple avatars in a group.
Usage
Wrap multiple Avatar within an AvatarGroup to stack them.
data:image/s3,"s3://crabby-images/01dd6/01dd65b1f191699cf7c5dda52aa90f04fb0fdebe" alt="Neil Richter"
data:image/s3,"s3://crabby-images/b8d16/b8d16266d9bd829c1b7857c7056ad9b3934fcbb4" alt="Romain Hamel"
data:image/s3,"s3://crabby-images/33f3e/33f3e05422bac2863b7a2a0d44ca3fe634c7ea1e" alt="Benjamin Canac"
<template>
<UAvatarGroup>
<UAvatar src="https://github.com/benjamincanac.png" alt="Benjamin Canac" />
<UAvatar src="https://github.com/romhml.png" alt="Romain Hamel" />
<UAvatar src="https://github.com/noook.png" alt="Neil Richter" />
</UAvatarGroup>
</template>
Size
Use the size
prop to change the size of all the avatars.
data:image/s3,"s3://crabby-images/01dd6/01dd65b1f191699cf7c5dda52aa90f04fb0fdebe" alt="Neil Richter"
data:image/s3,"s3://crabby-images/b8d16/b8d16266d9bd829c1b7857c7056ad9b3934fcbb4" alt="Romain Hamel"
data:image/s3,"s3://crabby-images/33f3e/33f3e05422bac2863b7a2a0d44ca3fe634c7ea1e" alt="Benjamin Canac"
<template>
<UAvatarGroup size="xl">
<UAvatar src="https://github.com/benjamincanac.png" alt="Benjamin Canac" />
<UAvatar src="https://github.com/romhml.png" alt="Romain Hamel" />
<UAvatar src="https://github.com/noook.png" alt="Neil Richter" />
</UAvatarGroup>
</template>
Max
Use the max
prop to limit the number of avatars displayed. The rest is displayed as an +X
avatar.
+1data:image/s3,"s3://crabby-images/b8d16/b8d16266d9bd829c1b7857c7056ad9b3934fcbb4" alt="Romain Hamel"
data:image/s3,"s3://crabby-images/33f3e/33f3e05422bac2863b7a2a0d44ca3fe634c7ea1e" alt="Benjamin Canac"
data:image/s3,"s3://crabby-images/b8d16/b8d16266d9bd829c1b7857c7056ad9b3934fcbb4" alt="Romain Hamel"
data:image/s3,"s3://crabby-images/33f3e/33f3e05422bac2863b7a2a0d44ca3fe634c7ea1e" alt="Benjamin Canac"
<template>
<UAvatarGroup :max="2">
<UAvatar src="https://github.com/benjamincanac.png" alt="Benjamin Canac" />
<UAvatar src="https://github.com/romhml.png" alt="Romain Hamel" />
<UAvatar src="https://github.com/noook.png" alt="Neil Richter" />
</UAvatarGroup>
</template>
Examples
With tooltip
Wrap each avatar with a Tooltip to display a tooltip on hover.
data:image/s3,"s3://crabby-images/01dd6/01dd65b1f191699cf7c5dda52aa90f04fb0fdebe" alt="Neil Richter"
data:image/s3,"s3://crabby-images/b8d16/b8d16266d9bd829c1b7857c7056ad9b3934fcbb4" alt="Romain Hamel"
data:image/s3,"s3://crabby-images/33f3e/33f3e05422bac2863b7a2a0d44ca3fe634c7ea1e" alt="Benjamin Canac"
<template>
<UAvatarGroup>
<UTooltip text="benjamincanac">
<UAvatar
src="https://github.com/benjamincanac.png"
alt="Benjamin Canac"
/>
</UTooltip>
<UTooltip text="romhml">
<UAvatar
src="https://github.com/romhml.png"
alt="Romain Hamel"
/>
</UTooltip>
<UTooltip text="noook">
<UAvatar
src="https://github.com/noook.png"
alt="Neil Richter"
/>
</UTooltip>
</UAvatarGroup>
</template>
With chip
Wrap each avatar with a Chip to display a chip around the avatar.
data:image/s3,"s3://crabby-images/01dd6/01dd65b1f191699cf7c5dda52aa90f04fb0fdebe" alt="Neil Richter"
data:image/s3,"s3://crabby-images/b8d16/b8d16266d9bd829c1b7857c7056ad9b3934fcbb4" alt="Romain Hamel"
data:image/s3,"s3://crabby-images/33f3e/33f3e05422bac2863b7a2a0d44ca3fe634c7ea1e" alt="Benjamin Canac"
<template>
<UAvatarGroup>
<UChip inset color="success">
<UAvatar
src="https://github.com/benjamincanac.png"
alt="Benjamin Canac"
/>
</UChip>
<UChip inset color="warning">
<UAvatar
src="https://github.com/romhml.png"
alt="Romain Hamel"
/>
</UChip>
<UChip inset color="error">
<UAvatar
src="https://github.com/noook.png"
alt="Neil Richter"
/>
</UChip>
</UAvatarGroup>
</template>
With link
Wrap each avatar with a Link to make them clickable.
<template>
<UAvatarGroup>
<ULink
to="https://github.com/benjamincanac"
target="_blank"
class="hover:ring-(--ui-primary) transition"
raw
>
<UAvatar
src="https://github.com/benjamincanac.png"
alt="Benjamin Canac"
/>
</ULink>
<ULink
to="https://github.com/romhml"
target="_blank"
class="hover:ring-(--ui-primary) transition"
raw
>
<UAvatar
src="https://github.com/romhml.png"
alt="Romain Hamel"
/>
</ULink>
<ULink
to="https://github.com/noook"
target="_blank"
class="hover:ring-(--ui-primary) transition"
raw
>
<UAvatar
src="https://github.com/noook.png"
alt="Neil Richter"
/>
</ULink>
</UAvatarGroup>
</template>
API
Props
Prop | Default | Type |
---|---|---|
as |
|
The element or component this component should render as. |
size |
|
|
max |
The maximum number of avatars to display. | |
ui |
|
Slots
Slot | Type |
---|---|
default |
|
Theme
app.config.ts
export default defineAppConfig({
ui: {
avatarGroup: {
slots: {
root: 'inline-flex flex-row-reverse justify-end',
base: 'relative rounded-full ring-(--ui-bg) first:me-0'
},
variants: {
size: {
'3xs': {
base: 'ring -me-0.5'
},
'2xs': {
base: 'ring -me-0.5'
},
xs: {
base: 'ring -me-0.5'
},
sm: {
base: 'ring-2 -me-1.5'
},
md: {
base: 'ring-2 -me-1.5'
},
lg: {
base: 'ring-2 -me-1.5'
},
xl: {
base: 'ring-3 -me-2'
},
'2xl': {
base: 'ring-3 -me-2'
},
'3xl': {
base: 'ring-3 -me-2'
}
}
},
defaultVariants: {
size: 'md'
}
}
}
})
vite.config.ts
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import ui from '@nuxt/ui/vite'
export default defineConfig({
plugins: [
vue(),
ui({
ui: {
avatarGroup: {
slots: {
root: 'inline-flex flex-row-reverse justify-end',
base: 'relative rounded-full ring-(--ui-bg) first:me-0'
},
variants: {
size: {
'3xs': {
base: 'ring -me-0.5'
},
'2xs': {
base: 'ring -me-0.5'
},
xs: {
base: 'ring -me-0.5'
},
sm: {
base: 'ring-2 -me-1.5'
},
md: {
base: 'ring-2 -me-1.5'
},
lg: {
base: 'ring-2 -me-1.5'
},
xl: {
base: 'ring-3 -me-2'
},
'2xl': {
base: 'ring-3 -me-2'
},
'3xl': {
base: 'ring-3 -me-2'
}
}
},
defaultVariants: {
size: 'md'
}
}
}
})
]
})