( key: string, defaultValue: T, storage = localStorage )
| 7 | } |
| 8 | |
| 9 | export function useLocalStorage<T>( |
| 10 | key: string, |
| 11 | defaultValue: T, |
| 12 | storage = localStorage |
| 13 | ): [T, (value: T) => void] { |
| 14 | const [value, setValue] = useState(get<T>(key, defaultValue, storage)); |
| 15 | |
| 16 | const handleChange = useCallback( |
| 17 | (value) => { |
| 18 | setValue(value); |
| 19 | set<T>(key, value, storage); |
| 20 | }, |
| 21 | [key, storage] |
| 22 | ); |
| 23 | |
| 24 | return useMemo(() => [value, handleChange], [value, handleChange]); |
| 25 | } |
| 26 | |
| 27 | export function get<T>( |
| 28 | key: string, |
no test coverage detected