@uifabric/utilities
Version:
Fluent UI React utilities for building components.
28 lines • 1.12 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
var extendComponent_1 = require("./extendComponent");
/**
* Generates a function to be attached to a React component, which can be called
* as a replacement to RAF. In-flight async calls will be auto canceled if the component
* is unmounting before the async code is executed, preventing bugs where code
* accesses things within the component after being unmounted.
*/
exports.safeRequestAnimationFrame = function (component) {
var activeTimeouts;
return function (cb) {
if (!activeTimeouts) {
activeTimeouts = new Set();
extendComponent_1.extendComponent(component, {
componentWillUnmount: function () {
activeTimeouts.forEach(function (id) { return cancelAnimationFrame(id); });
},
});
}
var timeoutId = requestAnimationFrame(function () {
activeTimeouts.delete(timeoutId);
cb();
});
activeTimeouts.add(timeoutId);
};
};
//# sourceMappingURL=safeRequestAnimationFrame.js.map
;