Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/react18-tools/react18-themes
π€ π [Unleash the Power of React Server Components](https://medium.com/javascript-in-plain-english/unleash-the-power-of-react-server-components-eb3fe7201231)
https://github.com/react18-tools/react18-themes
nextjs react react-server-components react18 react18-themes theme themes typescript vercel
Last synced: about 3 hours ago
JSON representation
π€ π [Unleash the Power of React Server Components](https://medium.com/javascript-in-plain-english/unleash-the-power-of-react-server-components-eb3fe7201231)
- Host: GitHub
- URL: https://github.com/react18-tools/react18-themes
- Owner: react18-tools
- License: mit
- Created: 2023-09-01T04:22:14.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-04-11T00:50:13.000Z (7 months ago)
- Last Synced: 2024-04-14T16:14:23.420Z (7 months ago)
- Topics: nextjs, react, react-server-components, react18, react18-themes, theme, themes, typescript, vercel
- Language: TypeScript
- Homepage: https://react18-themes.vercel.app/
- Size: 1.88 MB
- Stars: 4
- Watchers: 1
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# React 18 Themes
[![test](https://github.com/react18-tools/react18-themes/actions/workflows/test.yml/badge.svg)](https://github.com/react18-tools/react18-themes/actions/workflows/test.yml) [![Maintainability](https://api.codeclimate.com/v1/badges/55a85ada9dd24603340f/maintainability)](https://codeclimate.com/github/react18-tools/react18-themes/maintainability) [![codecov](https://codecov.io/gh/react18-tools/react18-themes/branch/main/graph/badge.svg)](https://codecov.io/gh/react18-tools/react18-themes) [![Version](https://img.shields.io/npm/v/react18-themes.svg?colorB=green)](https://www.npmjs.com/package/react18-themes) [![Downloads](https://img.jsdelivr.com/img.shields.io/npm/d18m/react18-themes.svg)](https://www.npmjs.com/package/react18-themes) ![npm bundle size](https://img.shields.io/bundlephobia/minzip/react18-themes) [![Contact me on Codementor](https://www.codementor.io/m-badges/mayank1513/get-help.svg)](https://www.codementor.io/@mayank1513?refer=badge)
Version 3 Short Notes:
Version 3.0 brings minor API changes along with major performance improvements and fixes. We have minimized changes to existing APIs.Note: [react18-themes](https://github.com/react18-tools/react18-themes/) will now be maintained as `react18-themes`, as server-specific APIs are no longer needed.
π€ π [Unleash the Power of React Server Components](https://medium.com/javascript-in-plain-english/unleash-the-power-of-react-server-components-eb3fe7201231)
- β Perfect dark mode in 2 lines of code
- β Fully Treeshakable (`import from react18-themes/client/component`)
- β Full TypeScript Support
- β Secure by design - we support nonce for scripts and styles
- β Unleash the full power of React 18 Server components> Exampand following to see more features.
Motivation and Key Features:
This project was inspired by next-themes. Unlike next-themes, `react18-themes` doesn't require wrapping everything in a provider, allowing you to take full advantage of React 18 Server Components. Additionally, it offers more features and control over your app's theming.
- β Perfect dark mode in 2 lines of code
- β Fully Treeshakable (`import from react18-themes/client/component`)
- β Designed for excellence
- β Full TypeScript Support
- β Unleash the full power of React 18 Server components
- β System setting with prefers-color-scheme
- β Themed browser UI with color-scheme
- β Support for Next.js 13 & Next.js 14 `appDir`
- β No flash on load (for all - SSG, SSR, ISG, Server Components)
- β Sync theme across tabs and windows
- β Disable flashing when changing themes
- β Force pages to specific themes
- β Class and data attribute selector
- β Manipulate theme via `useTheme` hook
- β Documented with [Typedoc](https://react18-tools.github.io/react18-themes) ([Docs](https://react18-tools.github.io/react18-themes))
- β Use combinations of [data-th=""] and [data-color-scheme=""] for dark/light variants of themes
- β Use [data-csp=""] to style based on colorSchemePreference.> Check out the [live example](https://react18-themes.vercel.app/).
Installation
```bash
$ pnpm add react18-themes
```**_or_**
```bash
$ npm install react18-themes
```**_or_**
```bash
$ yarn add react18-themes
```Want Lite Version?
[![npm bundle size](https://img.shields.io/bundlephobia/minzip/react18-themes-lite)](https://www.npmjs.com/package/react18-themes-lite) [![Version](https://img.shields.io/npm/v/react18-themes-lite.svg?colorB=green)](https://www.npmjs.com/package/react18-themes-lite) [![Downloads](https://img.jsdelivr.com/img.shields.io/npm/d18m/react18-themes-lite.svg)](https://www.npmjs.com/package/react18-themes-lite)
```bash
$ pnpm add react18-themes-lite
```**or**
```bash
$ npm install react18-themes-lite
```**or**
```bash
$ yarn add react18-themes-lite
```> Note: `r18gs` is a peer dependency
## Usage
### SPA (e.g., Vite, CRA) and Next.js pages directory (No server components)
To add dark mode support, modify `_app.js` as follows:
```js
import { ThemeSwitcher } from "react18-themes";function MyApp({ Component, pageProps }) {
return (
<>
>
);
}export default MyApp;
```β‘πBoom! Dark mode is ready in just a couple of lines!
### With Next.js `app` router (Server Components)
Update `app/layout.jsx` to add `ThemeSwitcher` from `react18-themes`:
```tsx
// app/layout.jsx
import { ThemeSwitcher } from "react18-themes";export default function Layout({ children }) {
return (
{children}
);
}
```Woohoo! Multiple theme modes with Server Components support!
### HTML & CSS
Next.js app supports dark mode, including System preference with `prefers-color-scheme`. The theme is synced between tabs, modifying the `data-theme` attribute on the `html` element:
```css
:root {
--background: white;
--foreground: black;
}[data-theme="dark"] {
--background: black;
--foreground: white;
}
```## Images
Show different images based on the current theme:
```ts
import Image from "next/image";
import { useTheme } from "react18-themes";function ThemedImage() {
const { resolvedTheme } = useTheme();
const src = resolvedTheme === "light" ? "/light.png" : "/dark.png";
return ;
}export default ThemedImage;
```### useTheme
The `useTheme` hook provides theme information and allows changing the theme:
```js
import { useTheme } from "react18-themes";const ThemeChanger = () => {
const { theme, setTheme } = useTheme();return (
The current theme is: {theme}
setTheme("light")}>Light Mode
setTheme("dark")}>Dark Mode
);
};
```The `useTheme` hook returns the following object:
```tsx
interface UseThemeYield {
theme: string;
darkTheme: string;
lightTheme: string;
colorSchemePref: ColorSchemeType;
systemColorScheme: ResolvedColorSchemeType;
resolvedColorScheme: ResolvedColorSchemeType;
resolvedTheme: string;
setTheme: (theme: string) => void;
setDarkTheme: (darkTheme: string) => void;
setLightTheme: (lightTheme: string) => void;
setThemeSet: (themeSet: { darkTheme: string; lightTheme: string }) => void;
setColorSchemePref: (colorSchemePref: ColorSchemeType) => void;
toggleColorScheme: (skipSystem?: boolean) => void;
setForcedTheme: (forcedTheme: string) => void;
setForcedColorScheme: (forcedColorScheme: ColorSchemeType) => void;
}
```Force per page theme and color-scheme
### Next.js App Router
```tsx
import { ForceTheme } from "react18-themes";function MyPage() {
return (
<>
...
>
);
}export default MyPage;
```### Next.js Pages Router
For the pages router, you have two options. The first option is the same as the app router, and the second option, which is compatible with `next-themes`, involves adding the `theme` property to your page component like this:
```javascript
function MyPage() {
return <>...>;
}MyPage.theme = "my-theme";
export default MyPage;
```Similarly, you can force a color scheme. This will apply your `defaultDark` or `defaultLight` theme, which can be configured via hooks.
### With Styled Components and any CSS-in-JS
Next Themes works with any library. For Styled Components, `createGlobalStyle` in your custom App:
```js
// pages/_app.js
import { createGlobalStyle } from "styled-components";
import { ThemeSwitcher } from "react18-themes";const GlobalStyle = createGlobalStyle`
:root {
--fg: #000;
--bg: #fff;
}[data-theme="dark"] {
--fg: #fff;
--bg: #000;
}
`;function MyApp({ Component, pageProps }) {
return (
<>
>
);
}
```### With Tailwind
In `tailwind.config.js`, set the dark mode property to class:
```js
// tailwind.config.js
module.exports = {
darkMode: "class",
};
```β‘πReady to use dark mode in Tailwind!
> Caution: Your class must be `"dark"`, which is the default value used in this library. Tailwind requires the class name `"dark"` for dark-theme.
Use dark-mode specific classes:
```tsx
```## Migration
> Refer to the [migration guide](./guides/migration.md).
## Docs
[Typedoc](https://react18-tools.github.io/react18-themes)
### π€© Don't forget to star this repo!
Want a hands-on course for getting started with Turborepo? Check out [React and Next.js with TypeScript](https://www.udemy.com/course/react-and-next-js-with-typescript/?referralCode=7202184A1E57C3DCA8B2)
## FAQ
**Do I need to use CSS variables with this library?**
No. You can hard code values for every class:
```css
.my-class {
color: #555;
}[data-theme="dark"] .my-class {
color: white;
}
```**Why is `resolvedTheme` and `resolvedColorScheme` necessary?**
To reflect the System theme preference and forced theme/colorScheme pages in your UI. For instance, buttons or dropdowns indicating the current colorScheme should say "system" when the System colorScheme preference is active.
`resolvedTheme` is useful for modifying behavior or styles at runtime:
```js
const { resolvedTheme, resolvedColorScheme } = useTheme();
const background = getBackground(resolvedTheme);
```Without `resolvedTheme`, you would only know the theme is "system", not what it resolved to.
![Repo stats](https://repobeats.axiom.co/api/embed/3cc219825aee3c38bad8829fb9da0dd6301a1867.svg "Repobeats analytics image")
## License
This library is licensed under the MPL-2.0 open-source license.
> Please consider enrolling in [our courses](https://mayank-chaudhari.vercel.app/courses) or [sponsoring](https://github.com/sponsors/mayank1513) our work.
with π by Mayank Kumar Chaudhari