diff options
Diffstat (limited to 'src/hooks/local.js')
-rw-r--r-- | src/hooks/local.js | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/src/hooks/local.js b/src/hooks/local.js new file mode 100644 index 0000000..4b6b2ca --- /dev/null +++ b/src/hooks/local.js @@ -0,0 +1,31 @@ +import { useState } from "react"; + +const useLocalStorage = (key, initialValue) => { + const [storedValue, setStoredValue] = useState(() => { + if (typeof window === "undefined") { + return initialValue; + } + try { + const item = window.localStorage.getItem(key); + return item ? JSON.parse(item) : initialValue; + } catch (error) { + console.warn(error); + return initialValue; + } + }); + const setValue = (value) => { + try { + const valueToStore = + value instanceof Function ? value(storedValue) : value; + setStoredValue(valueToStore); + if (typeof window !== "undefined") { + window.localStorage.setItem(key, JSON.stringify(valueToStore)); + } + } catch (error) { + console.log(error); + } + }; + return [storedValue, setValue]; +} + +export default useLocalStorage; |