Исходный код вызывает событие resize.off-canvas после отмены функции resetSize в течение 100 мс.Вы можете прослушать это событие и задержать, еще лучше, отменить выполнение вашей собственной функции на ту же продолжительность с произвольным допуском.
function debounce(func, wait, immediate) {
var timeout;
return function() {
var context = this, args = arguments;
var later = function() {
timeout = null;
if (!immediate) func.apply(context, args);
};
var callNow = immediate && !timeout;
clearTimeout(timeout);
timeout = setTimeout(later, wait);
if (callNow) func.apply(context, args);
};
};
var myCustomFunction = debounce(function() {
console.log("Call this once after resize function completes and only once every 120ms.");
}, 120);
$(window).on('resize.off-canvas', myCustomFunction );
Это основано на реализации отладки Дэвида Уолша:
// https://davidwalsh.name/javascript-debounce-function
Я не проверял, но думаю, что это сработает.