21 lines
524 B
JavaScript
21 lines
524 B
JavaScript
// Sometimes we want to queue multiple requestAnimationFrames but only run the last one.
|
|
// It's tedious to do this using cancelAnimationFrame, so this is a utility to throttle
|
|
// a timer such that it only runs the last callback when it fires.
|
|
|
|
export const throttleTimer = timer => {
|
|
let queuedCallback
|
|
|
|
const flush = () => {
|
|
const callback = queuedCallback
|
|
queuedCallback = null
|
|
callback()
|
|
}
|
|
|
|
return callback => {
|
|
if (!queuedCallback) {
|
|
timer(flush)
|
|
}
|
|
queuedCallback = callback
|
|
}
|
|
}
|