Desenvolvedores
src_
components_
ui_
sonner.jsx

Explicação do código

1. Importação de Dependências 📦

import { useTheme } from "next-themes"
import { Toaster as Sonner } from "sonner"

Aqui, importamos duas dependências importantes:

  • useTheme do next-themes, que é uma biblioteca útil para permitir a troca de temas (como claro e escuro) no Next.js.
  • Toaster como Sonner, que é a biblioteca que implementa a funcionalidade de mostrar notificações (toasts).

2. Componente Toaster 🔔

const Toaster = ({ ...props }) => {
  const { theme = "system" } = useTheme()

Este é o componente Toaster. Ele recebe props como parâmetros para ser reutilizável em qualquer parte da aplicação. A primeira coisa que fazemos dentro dele é chamar o hook useTheme, que nos permite acessar o tema atual da aplicação (por padrão, o tema é system — que é baseado nas configurações do sistema operacional).

3. Uso do Componente Sonner 📱

  return (
    (<Sonner
      theme={theme}
      className="toaster group"
      toastOptions={{
        classNames: {
          toast:
            "group toast group-[.toaster]:bg-background group-[.toaster]:text-foreground group-[.toaster]:border-border group-[.toaster]:shadow-lg",
          description: "group-[.toast]:text-muted-foreground",
          actionButton:
            "group-[.toast]:bg-primary group-[.toast]:text-primary-foreground",
          cancelButton:
            "group-[.toast]:bg-muted group-[.toast]:text-muted-foreground",
        },
      }}
      {...props} />)
  );
}

Dentro do componente Toaster, utilizamos o componente Sonner para criar a notificação (toast). Passamos várias propriedades, incluindo:

  • theme: O tema atual, que pode ser claro, escuro ou o padrão do sistema.
  • className="toaster group": Aplicação de classes para estilização do componente.
  • toastOptions: Definimos configurações específicas de estilização para o toast. Cada parte do toast (como a descrição, o botão de ação e o botão de cancelamento) recebe classes personalizadas baseadas no tema.

A estrutura do toast é altamente configurável, permitindo que você personalize o comportamento visual de cada parte da notificação.

4. Exportação do Componente 📤

export { Toaster }

Por fim, o componente Toaster é exportado para ser utilizado em outras partes da aplicação.

Código Completo 📜

'use client'
import { useTheme } from "next-themes"
import { Toaster as Sonner } from "sonner"
 
const Toaster = ({
  ...props
}) => {
  const { theme = "system" } = useTheme()
 
  return (
    (<Sonner
      theme={theme}
      className="toaster group"
      toastOptions={{
        classNames: {
          toast:
            "group toast group-[.toaster]:bg-background group-[.toaster]:text-foreground group-[.toaster]:border-border group-[.toaster]:shadow-lg",
          description: "group-[.toast]:text-muted-foreground",
          actionButton:
            "group-[.toast]:bg-primary group-[.toast]:text-primary-foreground",
          cancelButton:
            "group-[.toast]:bg-muted group-[.toast]:text-muted-foreground",
        },
      }}
      {...props} />)
  );
}
 
export { Toaster }