@wrksz/themesv0.7.2

Getting Started

Install and configure @wrksz/themes in your Next.js app.

Edit on GitHub

Last updated on

Installation

bun add @wrksz/themes
npm install @wrksz/themes
pnpm add @wrksz/themes
yarn add @wrksz/themes

Setup

Add ThemeProvider to your root layout. Import from @wrksz/themes/next for Next.js - this avoids the React 19 inline script warning by using useServerInsertedHTML. Add suppressHydrationWarning to <html> to prevent hydration mismatches.

app/layout.tsx
import { ThemeProvider } from "@wrksz/themes/next";

export default function RootLayout({ children }: { children: React.ReactNode }) {
  return (
    <html lang="en" suppressHydrationWarning>
      <body>
        <ThemeProvider>{children}</ThemeProvider>
      </body>
    </html>
  );
}

Usage

Use the useTheme hook in any Client Component to read and update the current theme.

components/theme-toggle.tsx
"use client";

import { useTheme } from "@wrksz/themes/client";

export function ThemeToggle() {
  const { resolvedTheme, setTheme } = useTheme();

  return (
    <button
      type="button"
      onClick={() => setTheme(resolvedTheme === "dark" ? "light" : "dark")}
    >
      Toggle theme
    </button>
  );
}

Import paths

Since v0.6.0
ImportUse for
@wrksz/themes/nextThemeProvider in Next.js (recommended)
@wrksz/themes/clientuseTheme, useThemeValue, ThemedImage, ClientThemeProvider
@wrksz/themesThemeProvider for non-Next.js frameworks

The API is identical to next-themes. Migrating requires changing one import line: @wrksz/themes/next instead of next-themes. See Why not next-themes? for a full comparison.

Requirements

  • Next.js 16+
  • React 19+

Next steps

On this page