UNPKG

react-virtualized

Version:

React components for efficiently rendering large, scrollable lists and tabular data

38 lines (36 loc) 1.35 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.requestAnimationTimeout = exports.cancelAnimationTimeout = void 0; var _animationFrame = require("./animationFrame"); /*:: export type AnimationTimeoutId = { id: number, };*/ var cancelAnimationTimeout = exports.cancelAnimationTimeout = function cancelAnimationTimeout(frame /*: AnimationTimeoutId*/) { return (0, _animationFrame.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) */ var requestAnimationTimeout = exports.requestAnimationTimeout = function requestAnimationTimeout(callback /*: Function*/, delay /*: number*/) /*: AnimationTimeoutId*/{ var start; // wait for end of processing current event handler, because event handler may be long Promise.resolve().then(function () { start = Date.now(); }); var _timeout = function timeout() { if (Date.now() - start >= delay) { callback.call(); } else { frame.id = (0, _animationFrame.raf)(_timeout); } }; var frame /*: AnimationTimeoutId*/ = { id: (0, _animationFrame.raf)(_timeout) }; return frame; };