xtablo-source/packages/ui/src/components/avatar.tsx
Arthur Belleville 7a0a5548f9
Lint and format
2025-10-23 21:36:21 +02:00

55 lines
1.4 KiB
TypeScript

"use client";
import * as AvatarPrimitive from "@radix-ui/react-avatar";
import { cn } from "@xtablo/shared";
import type * as React from "react";
function Avatar({ className, ...props }: React.ComponentProps<typeof AvatarPrimitive.Root>) {
return (
<AvatarPrimitive.Root
data-slot="avatar"
className={cn("relative flex size-8 shrink-0 overflow-hidden rounded-full", className)}
{...props}
/>
);
}
function AvatarImage({ className, ...props }: React.ComponentProps<typeof AvatarPrimitive.Image>) {
return (
<AvatarPrimitive.Image
data-slot="avatar-image"
className={cn("aspect-square size-full", className)}
{...props}
/>
);
}
function AvatarFallback({
className,
...props
}: React.ComponentProps<typeof AvatarPrimitive.Fallback>) {
return (
<AvatarPrimitive.Fallback
data-slot="avatar-fallback"
className={cn("bg-muted flex size-full items-center justify-center rounded-full", className)}
{...props}
/>
);
}
function AvatarBadge({ className, children, ...props }: React.HTMLAttributes<HTMLSpanElement>) {
return (
<span
data-slot="avatar-badge"
className={cn(
"absolute bottom-0 right-0 flex items-center justify-center rounded-full ring-2 ring-background",
className
)}
{...props}
>
{children}
</span>
);
}
export { Avatar, AvatarImage, AvatarFallback, AvatarBadge };