stacker.news/components/use-local-state.js

22 lines
634 B
JavaScript
Raw Normal View History

import { SSR } from '@/lib/constants'
import { useCallback, useState } from 'react'
2024-06-03 22:41:15 +00:00
export default function useLocalState (storageKey, initialValue = '') {
const [value, innerSetValue] = useState(
initialValue ||
(SSR ? null : JSON.parse(window.localStorage.getItem(storageKey)))
)
2024-06-03 22:41:15 +00:00
const setValue = useCallback((newValue) => {
window.localStorage.setItem(storageKey, JSON.stringify(newValue))
innerSetValue(newValue)
}, [storageKey])
const clearValue = useCallback(() => {
window.localStorage.removeItem(storageKey)
innerSetValue(null)
}, [storageKey])
return [value, setValue, clearValue]
}