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