2022-01-21 08:28:41 +00:00
|
|
|
import { AsyncAction } from './AsyncAction';
|
2022-04-07 07:06:43 +00:00
|
|
|
import { animationFrameProvider } from './animationFrameProvider';
|
2022-01-21 08:28:41 +00:00
|
|
|
export class AnimationFrameAction extends AsyncAction {
|
|
|
|
constructor(scheduler, work) {
|
|
|
|
super(scheduler, work);
|
|
|
|
this.scheduler = scheduler;
|
|
|
|
this.work = work;
|
|
|
|
}
|
|
|
|
requestAsyncId(scheduler, id, delay = 0) {
|
|
|
|
if (delay !== null && delay > 0) {
|
|
|
|
return super.requestAsyncId(scheduler, id, delay);
|
|
|
|
}
|
|
|
|
scheduler.actions.push(this);
|
2022-04-07 07:06:43 +00:00
|
|
|
return scheduler._scheduled || (scheduler._scheduled = animationFrameProvider.requestAnimationFrame(() => scheduler.flush(undefined)));
|
2022-01-21 08:28:41 +00:00
|
|
|
}
|
|
|
|
recycleAsyncId(scheduler, id, delay = 0) {
|
2022-04-07 07:06:43 +00:00
|
|
|
if ((delay != null && delay > 0) || (delay == null && this.delay > 0)) {
|
2022-01-21 08:28:41 +00:00
|
|
|
return super.recycleAsyncId(scheduler, id, delay);
|
|
|
|
}
|
2022-04-07 07:06:43 +00:00
|
|
|
if (!scheduler.actions.some((action) => action.id === id)) {
|
|
|
|
animationFrameProvider.cancelAnimationFrame(id);
|
|
|
|
scheduler._scheduled = undefined;
|
2022-01-21 08:28:41 +00:00
|
|
|
}
|
|
|
|
return undefined;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//# sourceMappingURL=AnimationFrameAction.js.map
|