import { useState, useCallback } from 'react'; function useLocalStorage(key: string, initialValue: T): [T, (value: T) => void] { const [storedValue, setStoredValue] = useState(() => { try { const item = window.localStorage.getItem(key); return item ? JSON.parse(item) : initialValue; } catch (error) { console.log(error); return initialValue; } }); const setValue = useCallback((value: T) => { setStoredValue((originalValue: T) => { try { const valueToStore = value instanceof Function ? value(originalValue) : value; window.localStorage.setItem(key, JSON.stringify(valueToStore)); return valueToStore; } catch (error) { console.log(error); } }); }, [key]); return [storedValue, setValue]; } export default useLocalStorage;