1 | "use client";
|
2 |
|
3 | import { createContext, useContext } from "react";
|
4 | import type { UseIsDark } from "./client";
|
5 | import { useConstCallback } from "../tools/powerhooks/useConstCallback";
|
6 | import { assert } from "tsafe/assert";
|
7 |
|
8 | const ssrIsDarkContext = createContext<boolean | undefined>(undefined);
|
9 |
|
10 | export const { Provider: SsrIsDarkProvider } = ssrIsDarkContext;
|
11 |
|
12 | export const useIsDarkServerSide: UseIsDark = () => {
|
13 | const setIsDark = useConstCallback(() => {
|
14 |
|
15 | });
|
16 |
|
17 | const isDark = useContext(ssrIsDarkContext);
|
18 |
|
19 | assert(isDark !== undefined, "Not within provider");
|
20 |
|
21 | return {
|
22 | isDark,
|
23 | setIsDark
|
24 | };
|
25 | };
|