22 lines
376 B
TypeScript
22 lines
376 B
TypeScript
|
|
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
|
||
|
|
}
|