diff --git a/src/hooks/useLocalStorage.js b/src/hooks/useLocalStorage.js new file mode 100644 index 0000000..1027160 --- /dev/null +++ b/src/hooks/useLocalStorage.js @@ -0,0 +1,36 @@ +import { useState } from "react"; + +function useLocalStorage(key, initialValue) { + const [storedValue, setStoredValue] = useState(() => { + try { + const item = localStorage.getItem(key); + return item ? JSON.parse(item) : initialValue; + } catch (error) { + console.error("Error reading localStorage key:", key, error); + return initialValue; + } + }); + + const setValue = (value) => { + try { + const valueToStore = value instanceof Function ? value(storedValue) : value; + setStoredValue(valueToStore); + localStorage.setItem(key, JSON.stringify(valueToStore)); + } catch (error) { + console.error("Error setting localStorage key:", key, error); + } + }; + + const removeValue = () => { + try { + localStorage.removeItem(key); + setStoredValue(initialValue); + } catch (error) { + console.error("Error removing localStorage key:", key, error); + } + }; + + return [storedValue, setValue, removeValue]; +} + +export default useLocalStorage;