2018-03-26 14:32:43 -07:00
|
|
|
// Returns a function, that, as long as it continues to be invoked, will not
|
|
|
|
// be triggered. The function will be called after it stops being called for
|
|
|
|
// N milliseconds. If `immediate` is passed, trigger the function on the
|
|
|
|
// leading edge, instead of the trailing.
|
2022-04-15 00:05:59 -03:00
|
|
|
export default function debouce(func, waitInMs, immediate) {
|
2018-03-26 14:32:43 -07:00
|
|
|
let timeout;
|
|
|
|
|
2022-04-15 00:05:59 -03:00
|
|
|
return function () {
|
2018-03-26 14:32:43 -07:00
|
|
|
const context = this;
|
|
|
|
const args = arguments;
|
|
|
|
const later = () => {
|
|
|
|
timeout = null;
|
|
|
|
if (!immediate) func.apply(context, args);
|
|
|
|
};
|
|
|
|
|
|
|
|
const callNow = immediate && !timeout;
|
|
|
|
clearTimeout(timeout);
|
2022-04-15 00:05:59 -03:00
|
|
|
timeout = setTimeout(later, waitInMs);
|
2018-03-26 14:32:43 -07:00
|
|
|
if (callNow) func.apply(context, args);
|
|
|
|
};
|
|
|
|
}
|