Modo Escuro
O pacote Tailwind v4 suporta o modo escuro através de seu sistema de tokens semânticos. Como todas as cores referenciam variáveis CSS, alternar para o modo escuro é simplesmente uma questão de redefinir essas variáveis.
Como Funciona
Os componentes usam classes utilitárias semânticas como bg-primary, text-foreground, e border-border. Elas são resolvidas para variáveis CSS (--color-primary, --color-foreground, etc.) que você define no CSS do seu projeto. O modo escuro funciona fornecendo valores alternativos para essas variáveis sob um seletor escuro.
Configuração
Usando o Atributo data-theme
Defina os valores dos tokens claro e escuro usando seletores data-theme:
@theme { --color-background: oklch(1 0 0); --color-foreground: oklch(0.145 0.004 285.823); --color-popover: oklch(1 0 0); --color-popover-foreground: oklch(0.145 0.004 285.823); --color-primary: oklch(0.205 0.006 285.885); --color-primary-foreground: oklch(0.985 0.001 285.823); --color-muted-foreground: oklch(0.556 0.01 285.823); --color-accent: oklch(0.96 0.003 285.823); --color-accent-foreground: oklch(0.205 0.006 285.885); --color-destructive: oklch(0.577 0.245 27.325); --color-border: oklch(0.922 0.004 285.823); --color-input: oklch(0.922 0.004 285.823); --color-ring: oklch(0.87 0.006 285.823);}
[data-theme="dark"] { --color-background: oklch(0.145 0.004 285.823); --color-foreground: oklch(0.985 0.001 285.823); --color-popover: oklch(0.145 0.004 285.823); --color-popover-foreground: oklch(0.985 0.001 285.823); --color-primary: oklch(0.985 0.001 285.823); --color-primary-foreground: oklch(0.205 0.006 285.885); --color-muted-foreground: oklch(0.556 0.01 285.823); --color-accent: oklch(0.269 0.006 285.885); --color-accent-foreground: oklch(0.985 0.001 285.823); --color-destructive: oklch(0.577 0.245 27.325); --color-border: oklch(0.269 0.006 285.885); --color-input: oklch(0.269 0.006 285.885); --color-ring: oklch(0.369 0.006 285.885);}Alterne para o modo escuro definindo o atributo:
function App() { const [dark, setDark] = useState(false);
return ( <div data-theme={dark ? "dark" : "light"}> <button onClick={() => setDark(!dark)}>Toggle Theme</button> <DatePicker value={value} onChange={setValue} /> </div> );}Usando a Classe .dark
Se o seu framework usa uma classe .dark (por exemplo, Next.js com next-themes), defina os tokens sob essa classe:
@theme { /* Light tokens */ --color-background: oklch(1 0 0); --color-foreground: oklch(0.145 0.004 285.823); /* ... */}
.dark { --color-background: oklch(0.145 0.004 285.823); --color-foreground: oklch(0.985 0.001 285.823); /* ... */}Usando a Preferência do Sistema
Use @media (prefers-color-scheme: dark) para seguir a configuração do sistema operacional:
@theme { /* Light tokens */ --color-background: oklch(1 0 0); --color-foreground: oklch(0.145 0.004 285.823); /* ... */}
@media (prefers-color-scheme: dark) { :root { --color-background: oklch(0.145 0.004 285.823); --color-foreground: oklch(0.985 0.001 285.823); /* ... */ }}Integração com next-themes
Um padrão comum com Next.js e next-themes:
import { ThemeProvider } from "next-themes";
export default function RootLayout({ children }) { return ( <html suppressHydrationWarning> <body> <ThemeProvider attribute="class" defaultTheme="system"> {children} </ThemeProvider> </body> </html> );}@theme { --color-background: oklch(1 0 0); --color-foreground: oklch(0.145 0.004 285.823); --color-primary: oklch(0.205 0.006 285.885); --color-primary-foreground: oklch(0.985 0.001 285.823); /* ... all light tokens */}
.dark { --color-background: oklch(0.145 0.004 285.823); --color-foreground: oklch(0.985 0.001 285.823); --color-primary: oklch(0.985 0.001 285.823); --color-primary-foreground: oklch(0.205 0.006 285.885); /* ... all dark tokens */}O seletor irá capturar automaticamente os valores corretos dos tokens conforme o tema muda.
Ponto de Destaque no Modo Escuro
O ponto de destaque usa after:bg-amber-500 dark:after:bg-amber-400 (uma cor concreta do Tailwind, não um token) para garantir boa visibilidade em ambos os modos. Esta é a única cor não semântica no componente. Se precisar alterá-la, use a API de Componentes Compostos (Compound Component) com uma renderização personalizada do Day:
<DatePicker.Day date={date}> {(props) => ( <button /* ... */> {props.day} {props.isHighlighted && ( <span className="absolute bottom-0.5 w-1 h-1 rounded-full bg-emerald-500 dark:bg-emerald-400" /> )} </button> )}</DatePicker.Day>Forçando um Modo Específico
Para forçar o modo claro ou escuro, independentemente da preferência do sistema, defina o tema explicitamente:
{ /* Always light */}<div data-theme="light"> <DatePicker value={value} onChange={setValue} /></div>;
{ /* Always dark */}<div data-theme="dark"> <DatePicker value={value} onChange={setValue} /></div>;