Skip to content

Latest commit

 

History

History
68 lines (51 loc) · 1.33 KB

File metadata and controls

68 lines (51 loc) · 1.33 KB
title description
Next.js
Adding dark mode to your next app.

Dark mode

Install next-themes

Start by installing next-themes:

npm install next-themes

Create a theme provider

'use client';

import * as React from 'react';
import { ThemeProvider as NextThemesProvider } from 'next-themes';

export function ThemeProvider({
  children,
  ...props
}: React.ComponentProps<typeof NextThemesProvider>) {
  return <NextThemesProvider {...props}>{children}</NextThemesProvider>;
}

Wrap your root layout

Add the ThemeProvider to your root layout.

import { ThemeProvider } from '@/components/theme-provider';

export default function RootLayout({ children }: RootLayoutProps) {
  return (
    <>
      <html lang="en" suppressHydrationWarning>
        <head />
        <body>
          <ThemeProvider 
            attribute="class"
            defaultTheme="system"
            enableSystem
            disableTransitionOnChange
          >
            {children}
          </ThemeProvider>
        </body>
      </html>
    </>
  );
}

Add a mode toggle

Place a mode toggle on your site to toggle between light and dark mode.