Skip to content

Instantly share code, notes, and snippets.

@Mon4ik
Last active May 26, 2024 06:23
Show Gist options
  • Save Mon4ik/2636100f5b74ee14e35cf283700616fe to your computer and use it in GitHub Desktop.
Save Mon4ik/2636100f5b74ee14e35cf283700616fe to your computer and use it in GitHub Desktop.
Typescript useLocalStorage hook
/* `useLocalStorage`
*
* Features:
* - JSON Serializing
* - Also value will be updated everywhere, when value updated (via `storage` event)
*/
import { useEffect, useState } from "react";
export default function useLocalStorage<T>(key: string, defaultValue: T): [T, (value: T) => void] {
const [value, setValue] = useState(defaultValue);
useEffect(() => {
const item = localStorage.getItem(key);
if (!item) {
localStorage.setItem(key, JSON.stringify(defaultValue))
}
setValue(item ? JSON.parse(item) : defaultValue)
function handler(e: StorageEvent) {
if (e.key !== key) return;
const lsi = localStorage.getItem(key)
setValue(JSON.parse(lsi ?? ""))
}
window.addEventListener("storage", handler)
return () => {
window.removeEventListener("storage", handler)
};
}, [])
const setValueWrap = (value: T) => {
try {
setValue(value);
localStorage.setItem(key, JSON.stringify(value));
if (typeof window !== "undefined") {
window.dispatchEvent(new StorageEvent("storage", { key }))
}
} catch (e) { console.error(e) }
};
return [value, setValueWrap];
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment