seti-ramesesv1
Version:
Reusable components and context for Next.js apps
38 lines (34 loc) • 824 B
JavaScript
import useLazyRef from '../useLazyRef/useLazyRef.js';
import useOnMount from '../useOnMount/useOnMount.js';
class Timeout {
static create() {
return new Timeout();
}
currentId = null;
/**
* Executes `fn` after `delay`, clearing any previously scheduled call.
*/
start(delay, fn) {
this.clear();
this.currentId = setTimeout(() => {
this.currentId = null;
fn();
}, delay);
}
clear = () => {
if (this.currentId !== null) {
clearTimeout(this.currentId);
this.currentId = null;
}
};
disposeEffect = () => {
return this.clear;
};
}
function useTimeout() {
const timeout = useLazyRef(Timeout.create).current;
useOnMount(timeout.disposeEffect);
return timeout;
}
export { Timeout, useTimeout as default };
//# sourceMappingURL=useTimeout.js.map