react-query
Version:
Hooks for managing, caching and syncing asynchronous and remote data in React
54 lines (40 loc) • 1.22 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
exports.__esModule = true;
exports.default = useLocalStorage;
var _react = _interopRequireDefault(require("react"));
const getItem = key => {
try {
const itemValue = localStorage.getItem(key);
if (typeof itemValue === 'string') {
return JSON.parse(itemValue);
}
return undefined;
} catch {
return undefined;
}
};
function useLocalStorage(key, defaultValue) {
const [value, setValue] = _react.default.useState();
_react.default.useEffect(() => {
const initialValue = getItem(key);
if (typeof initialValue === 'undefined' || initialValue === null) {
setValue(typeof defaultValue === 'function' ? defaultValue() : defaultValue);
} else {
setValue(initialValue);
}
}, [defaultValue, key]);
const setter = _react.default.useCallback(updater => {
setValue(old => {
let newVal = updater;
if (typeof updater == 'function') {
newVal = updater(old);
}
try {
localStorage.setItem(key, JSON.stringify(newVal));
} catch {}
return newVal;
});
}, [key]);
return [value, setter];
}
;