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.
48 lines
1.2 KiB
48 lines
1.2 KiB
6 years ago
|
import raf from 'raf';
|
||
7 years ago
|
|
||
4 years ago
|
export default function throttleByAnimationFrame(fn: (...args: any[]) => void) {
|
||
|
let requestId: number | null;
|
||
7 years ago
|
|
||
4 years ago
|
const later = (args: any[]) => () => {
|
||
6 years ago
|
requestId = null;
|
||
|
fn(...args);
|
||
|
};
|
||
7 years ago
|
|
||
4 years ago
|
const throttled = (...args: any[]) => {
|
||
7 years ago
|
if (requestId == null) {
|
||
6 years ago
|
requestId = raf(later(args));
|
||
7 years ago
|
}
|
||
6 years ago
|
};
|
||
7 years ago
|
|
||
4 years ago
|
(throttled as any).cancel = () => raf.cancel(requestId!);
|
||
7 years ago
|
|
||
6 years ago
|
return throttled;
|
||
7 years ago
|
}
|
||
|
|
||
6 years ago
|
export function throttleByAnimationFrameDecorator() {
|
||
4 years ago
|
// eslint-disable-next-line func-names
|
||
|
return function(target: any, key: string, descriptor: any) {
|
||
6 years ago
|
const fn = descriptor.value;
|
||
|
let definingProperty = false;
|
||
7 years ago
|
return {
|
||
|
configurable: true,
|
||
6 years ago
|
get() {
|
||
4 years ago
|
// eslint-disable-next-line no-prototype-builtins
|
||
7 years ago
|
if (definingProperty || this === target.prototype || this.hasOwnProperty(key)) {
|
||
6 years ago
|
return fn;
|
||
7 years ago
|
}
|
||
|
|
||
6 years ago
|
const boundFn = throttleByAnimationFrame(fn.bind(this));
|
||
|
definingProperty = true;
|
||
7 years ago
|
Object.defineProperty(this, key, {
|
||
|
value: boundFn,
|
||
|
configurable: true,
|
||
|
writable: true,
|
||
6 years ago
|
});
|
||
|
definingProperty = false;
|
||
|
return boundFn;
|
||
7 years ago
|
},
|
||
6 years ago
|
};
|
||
|
};
|
||
7 years ago
|
}
|