lbry-desktop/ui/effects/use-persisted-state.js

37 lines
820 B
JavaScript
Raw Normal View History

2019-06-11 14:10:58 -04:00
import { useState, useEffect } from 'react';
export default function usePersistedState(key, firstTimeDefault) {
// If no key is passed in, act as a normal `useState`
let defaultValue;
if (key) {
2019-08-13 01:35:13 -04:00
let item = localStorage.getItem(key);
if (item) {
let parsedItem;
try {
parsedItem = JSON.parse(item);
} catch (e) {}
if (parsedItem !== undefined) {
2019-08-13 01:35:13 -04:00
defaultValue = parsedItem;
} else {
defaultValue = item;
}
2019-06-26 19:59:27 -04:00
}
2019-06-11 14:10:58 -04:00
}
if (!defaultValue && defaultValue !== false) {
2019-06-11 14:10:58 -04:00
defaultValue = firstTimeDefault;
}
const [value, setValue] = useState(defaultValue);
useEffect(() => {
if (key) {
2019-08-13 01:35:13 -04:00
localStorage.setItem(key, typeof value === 'object' ? JSON.stringify(value) : value);
2019-06-11 14:10:58 -04:00
}
}, [key, value]);
return [value, setValue];
}