graphicek/client/src/utils/hooks/useDelayedState.ts

22 lines
376 B
TypeScript
Raw Normal View History

2024-04-01 10:03:17 +02:00
import { useEffect, useState } from 'preact/hooks'
import { useTimeout } from './useTimeout'
export const useDelayedState = (enabled: boolean, delay: number) => {
const [state, setState] = useState(false)
useTimeout(
() => {
setState(true)
},
enabled ? delay : false
)
useEffect(() => {
if (!enabled) {
setState(false)
}
}, [enabled])
return state
}