UNPKG

@wfp/react

Version:
55 lines (47 loc) 1.11 kB
// mdn resize function import window from 'window-or-global'; const OptimizedResize = (function optimizedResize() { const callbacks = []; let running = false; // run the actual callbacks function runCallbacks() { callbacks.forEach(callback => { callback(); }); running = false; } // fired on resize event function resize() { if (!running) { running = true; window.requestAnimationFrame(runCallbacks); } } // adds callback to loop function addCallback(callback) { if (callback) { const index = callbacks.indexOf(callback); if (index < 0) { callbacks.push(callback); } } } return { // public method to add additional callback add: callback => { if (!callbacks.length) { window.addEventListener('resize', resize); } addCallback(callback); return { release() { const index = callbacks.indexOf(callback); if (index >= 0) { callbacks.splice(index, 1); } }, }; }, }; })(); export default OptimizedResize;