1
Fork 0
mirror of https://github.com/pds-nest/nest.git synced 2024-11-24 14:04:19 +00:00
pds-2021-g2-nest/nest_frontend/hooks/useLocalStorageState.js

62 lines
1.7 KiB
JavaScript
Raw Normal View History

import { useCallback, useState } from "react"
/**
2021-05-22 02:44:08 +00:00
* Hook with the same API as {@link React.useState} which additionally stores its value in the browser's
* {@link localStorage}.
*/
export default function useLocalStorageState(key, def) {
/**
* Load the `key` from the {@link localStorage} into `value`, defaulting to `def` if it is not found.
*/
const load = () => {
if(localStorage) {
console.debug(`Loading ${key} from localStorage...`)
let _value = JSON.parse(localStorage.getItem(key))
if(_value) {
console.info(`Loaded ${key} from localStorage!`)
return _value
}
else {
console.info(`There is no value ${key} stored, defaulting...`)
return def
}
}
else {
console.warn(`Can't load value as localStorage doesn't seem to be available, defaulting...`)
return def
}
}
2021-05-11 14:37:15 +00:00
const [value, setValue] = useState(load())
/**
* Save a value to the {@link localStorage}.
*/
const save = useCallback(
val => {
if(localStorage) {
console.debug(`Saving ${key} to localStorage...`)
localStorage.setItem(key, JSON.stringify(val))
}
else {
console.warn(`Can't save ${key}; localStorage doesn't seem to be available...`)
}
},
2021-05-11 14:37:15 +00:00
[key],
)
/**
* Set `value` and save it to the {@link localStorage}.
*/
const setAndSave = useCallback(
val => {
setValue(val)
save(val)
},
2021-05-11 14:37:15 +00:00
[save],
)
return [value, setAndSave]
}