File size: 1,494 Bytes
c2ea5ed
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
import React, {
  createContext,
  useContext,
  useState,
  useEffect,
  ReactNode,
} from "react";

export type KGDisplayMode = "single" | "multiple";

interface KGDisplayModeContextType {
  mode: KGDisplayMode;
  setMode: (mode: KGDisplayMode) => void;
  toggleMode: () => void;
}

const KGDisplayModeContext = createContext<
  KGDisplayModeContextType | undefined
>(undefined);

export function KGDisplayModeProvider({ children }: { children: ReactNode }) {
  const [mode, setModeState] = useState<KGDisplayMode>("multiple");

  // Load saved mode from localStorage on mount
  useEffect(() => {
    const savedMode = localStorage.getItem("kg-display-mode") as KGDisplayMode;
    if (savedMode && (savedMode === "single" || savedMode === "multiple")) {
      setModeState(savedMode);
    }
  }, []);

  // Save mode to localStorage when it changes
  const setMode = (newMode: KGDisplayMode) => {
    setModeState(newMode);
    localStorage.setItem("kg-display-mode", newMode);
  };

  const toggleMode = () => {
    const newMode = mode === "single" ? "multiple" : "single";
    setMode(newMode);
  };

  return (
    <KGDisplayModeContext.Provider value={{ mode, setMode, toggleMode }}>
      {children}
    </KGDisplayModeContext.Provider>
  );
}

export function useKGDisplayMode() {
  const context = useContext(KGDisplayModeContext);
  if (context === undefined) {
    throw new Error(
      "useKGDisplayMode must be used within a KGDisplayModeProvider"
    );
  }
  return context;
}