React hook for subscribing to user's color scheme preference.
npm install @anatoliygatt/use-prefers-color-scheme
import { usePrefersColorScheme } from '@anatoliygatt/use-prefers-color-scheme';
function Example() {
const preferredColorScheme = usePrefersColorScheme();
const isDarkColorSchemePreferred = preferredColorScheme === 'dark';
return (
<div>
Preferred Color Scheme:{' '}
{isDarkColorSchemePreferred ? '🌚 Dark' : '🌞 Light'}
</div>
);
}
Frameworks like Next.js and Gatsby take advantage of server-side rendering, which means that the HTML is pre-rendered at some point before it's sent to the browser. When we first render our React component tree, we don't know whether the user prefers light or dark color scheme.
It may lead to the markup mismatches during hydration. In order to prevent this, we need to set the ssr
option provided by the usePrefersColorScheme()
hook to true
, like so:
usePrefersColorScheme({ ssr: true });
This will guarantee no markup mismatches between the original server render and the first client render, however, we will have to make a compromise: force a dark color scheme for all users in the very first render.