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:
useThemedonext-themes, que é uma biblioteca útil para permitir a troca de temas (como claro e escuro) no Next.js.ToastercomoSonner, 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 }