📖 Descrição do Arquivo
O arquivo Avatar.jsx define três componentes principais para a exibição de avatares em uma aplicação. Utilizando o Radix UI, esses componentes são:
- Avatar: O componente raiz que aplica estilos e estrutura ao avatar.
- AvatarImage: Exibe a imagem do avatar.
- AvatarFallback: Mostra um fallback (ícone ou texto) quando a imagem do avatar não está disponível.
Esses componentes são estilizados e têm uma estrutura que suporta tanto a imagem do avatar quanto um substituto caso a imagem falhe.
⚙️ Explicação do Código
1. Importações e Preparação
"use client"
import * as React from "react"
import * as AvatarPrimitive from "@radix-ui/react-avatar"
import { cn } from "@/lib/utils""use client": Esta diretiva garante que o código seja executado no lado do cliente (browser).AvatarPrimitive: Estamos importando os componentes de avatar do Radix UI, que oferecem uma maneira acessível e personalizável de renderizar avatares.cn: A funçãocné utilizada para concatenar classes de forma dinâmica, permitindo personalizar o estilo dos componentes.
2. Componente Avatar
const Avatar = React.forwardRef(({ className, ...props }, ref) => (
<AvatarPrimitive.Root
ref={ref}
className={cn("relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full", className)}
{...props} />
))
Avatar.displayName = AvatarPrimitive.Root.displayNameAvatar: Este é o componente raiz do avatar. Ele utiliza oAvatarPrimitive.Rootdo Radix UI, que encapsula todo o comportamento necessário para o avatar.- Estilos: Aplicamos várias classes CSS para garantir que o avatar tenha um formato redondo (
rounded-full), uma altura e largura fixas deh-10 w-10e um comportamento de overflow para ocultar qualquer conteúdo fora da área do avatar. forwardRef: Usado para passar uma referência ao componente para acesso direto.- Classe Condicional: A classe
classNamepode ser adicionada para personalização.
- Estilos: Aplicamos várias classes CSS para garantir que o avatar tenha um formato redondo (
3. Componente AvatarImage
const AvatarImage = React.forwardRef(({ className, ...props }, ref) => (
<AvatarPrimitive.Image
ref={ref}
className={cn("aspect-square h-full w-full", className)}
{...props} />
))
AvatarImage.displayName = AvatarPrimitive.Image.displayNameAvatarImage: Este componente exibe a imagem do avatar. UsamosAvatarPrimitive.Imagepara definir a imagem do avatar e garantir que ela seja redimensionada adequadamente.- Estilos: A classe
aspect-squaregarante que a imagem tenha uma proporção de 1:1 (quadrada), enquantoh-full w-fullgarante que a imagem ocupe toda a área do avatar.
- Estilos: A classe
4. Componente AvatarFallback
const AvatarFallback = React.forwardRef(({ className, ...props }, ref) => (
<AvatarPrimitive.Fallback
ref={ref}
className={cn(
"flex h-full w-full items-center justify-center rounded-full bg-muted",
className
)}
{...props} />
))
AvatarFallback.displayName = AvatarPrimitive.Fallback.displayNameAvatarFallback: Este componente serve como substituto quando a imagem do avatar não está disponível (por exemplo, caso a imagem falhe ao carregar).- Estilos: Usamos
flexpara centralizar o conteúdo dentro do avatar. Obg-mutedaplica um fundo cinza (pode ser personalizado). Ele também tem bordas arredondadas e ocupa toda a área do avatar.
- Estilos: Usamos
🧑💻 Código Completo
"use client"
import * as React from "react"
import * as AvatarPrimitive from "@radix-ui/react-avatar"
import { cn } from "@/lib/utils"
const Avatar = React.forwardRef(({ className, ...props }, ref) => (
<AvatarPrimitive.Root
ref={ref}
className={cn("relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full", className)}
{...props} />
))
Avatar.displayName = AvatarPrimitive.Root.displayName
const AvatarImage = React.forwardRef(({ className, ...props }, ref) => (
<AvatarPrimitive.Image
ref={ref}
className={cn("aspect-square h-full w-full", className)}
{...props} />
))
AvatarImage.displayName = AvatarPrimitive.Image.displayName
const AvatarFallback = React.forwardRef(({ className, ...props }, ref) => (
<AvatarPrimitive.Fallback
ref={ref}
className={cn(
"flex h-full w-full items-center justify-center rounded-full bg-muted",
className
)}
{...props} />
))
AvatarFallback.displayName = AvatarPrimitive.Fallback.displayName
export { Avatar, AvatarImage, AvatarFallback }