@momentum-ui/react-collaboration
Version:
Cisco Momentum UI Framework for React Collaboration Applications
26 lines (22 loc) • 699 B
JavaScript
import { caf, raf } from '../requestAnimationFrame';
export const cancelAnimationTimeout = (frame) => caf(frame.id);
/**
* Recursively calls requestAnimationFrame until a specified delay has been met or exceeded.
* When the delay time has been reached the function you're timing out will be called.
*
* Credit: Joe Lambert (https://gist.github.com/joelambert/1002116#file-requesttimeout-js)
*/
export const requestAnimationTimeout = (callback, delay) => {
const start = Date.now();
const timeout = () => {
if (Date.now() - start >= delay) {
callback.call();
} else {
frame.id = raf(timeout);
}
};
const frame = {
id: raf(timeout),
};
return frame;
};