You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ant-design-vue/components/_util/raf.ts

37 lines
759 B

interface RafMap {
[id: number]: number;
}
let id = 0;
const ids: RafMap = {};
// Support call raf with delay specified frame
export default function wrapperRaf(callback: () => void, delayFrames = 1): number {
const myId: number = id++;
let restFrames: number = delayFrames;
function internalCallback() {
restFrames -= 1;
if (restFrames <= 0) {
callback();
delete ids[myId];
} else {
ids[myId] = requestAnimationFrame(internalCallback);
}
}
ids[myId] = requestAnimationFrame(internalCallback);
return myId;
}
wrapperRaf.cancel = function cancel(pid?: number) {
if (pid === undefined) return;
cancelAnimationFrame(ids[pid]);
delete ids[pid];
};
wrapperRaf.ids = ids; // export this for test usage