2024-07-02 03:38:41 +00:00
|
|
|
import { SSR } from '@/lib/constants'
|
|
|
|
import { useCallback, useState } from 'react'
|
2024-06-03 22:41:15 +00:00
|
|
|
|
|
|
|
export default function useLocalState (storageKey, initialValue = '') {
|
2024-07-02 03:38:41 +00:00
|
|
|
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]
|
|
|
|
}
|