Preview
Switch between light and dark to inspect the embedded Storybook preview.
Installation
pnpm dlx shadcn@latest add https://ui.vllnt.ai/r/avatar.jsonStorybook
Explore all variants, controls, and accessibility checks in the interactive Storybook playground.
View in StorybookCode
"use client";
import * as AvatarPrimitive from "@radix-ui/react-avatar";
import { cn } from "../../lib/utils";
const Avatar = ({
className,
ref,
...props
}: React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Root> & {
ref?: React.Ref<React.ComponentRef<typeof AvatarPrimitive.Root>>;
}) => (
<AvatarPrimitive.Root
className={cn(
"relative flex size-10 shrink-0 overflow-hidden rounded-full",
className,
)}
ref={ref}
{...props}
/>
);
Avatar.displayName = AvatarPrimitive.Root.displayName;
const AvatarImage = ({
className,
ref,
...props
}: React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Image> & {
ref?: React.Ref<React.ComponentRef<typeof AvatarPrimitive.Image>>;
}) => (
<AvatarPrimitive.Image
className={cn("aspect-square h-full w-full", className)}
ref={ref}
{...props}
/>
);
AvatarImage.displayName = AvatarPrimitive.Image.displayName;
const AvatarFallback = ({
className,
ref,
...props
}: React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Fallback> & {
ref?: React.Ref<React.ComponentRef<typeof AvatarPrimitive.Fallback>>;
}) => (
<AvatarPrimitive.Fallback
className={cn(
"flex h-full w-full items-center justify-center rounded-full bg-muted",
className,
)}
ref={ref}
{...props}
/>
);
AvatarFallback.displayName = AvatarPrimitive.Fallback.displayName;
export { Avatar, AvatarFallback, AvatarImage };