"use strict"; var AnimationFrameAction_1 = require('./AnimationFrameAction'); var AnimationFrameScheduler_1 = require('./AnimationFrameScheduler'); /** * * Animation Frame Scheduler * * Perform task when `window.requestAnimationFrame` would fire * * When `animationFrame` scheduler is used with delay, it will fall back to {@link async} scheduler * behaviour. * * Without delay, `animationFrame` scheduler can be used to create smooth browser animations. * It makes sure scheduled task will happen just before next browser content repaint, * thus performing animations as efficiently as possible. * * @example Schedule div height animation * const div = document.querySelector('.some-div'); * * Rx.Scheduler.schedule(function(height) { * div.style.height = height + "px"; * * this.schedule(height + 1); // `this` references currently executing Action, * // which we reschedule with new state * }, 0, 0); * * // You will see .some-div element growing in height * * * @static true * @name animationFrame * @owner Scheduler */ exports.animationFrame = new AnimationFrameScheduler_1.AnimationFrameScheduler(AnimationFrameAction_1.AnimationFrameAction); //# sourceMappingURL=animationFrame.js.map