import { AsyncAction } from './AsyncAction'; import { Subscription } from '../Subscription'; import { QueueScheduler } from './QueueScheduler'; import { SchedulerAction } from '../types'; import { TimerHandle } from './timerHandle'; export class QueueAction extends AsyncAction { constructor(protected scheduler: QueueScheduler, protected work: (this: SchedulerAction, state?: T) => void) { super(scheduler, work); } public schedule(state?: T, delay: number = 0): Subscription { if (delay > 0) { return super.schedule(state, delay); } this.delay = delay; this.state = state; this.scheduler.flush(this); return this; } public execute(state: T, delay: number): any { return delay > 0 || this.closed ? super.execute(state, delay) : this._execute(state, delay); } protected requestAsyncId(scheduler: QueueScheduler, id?: TimerHandle, delay: number = 0): TimerHandle { // If delay exists and is greater than 0, or if the delay is null (the // action wasn't rescheduled) but was originally scheduled as an async // action, then recycle as an async action. if ((delay != null && delay > 0) || (delay == null && this.delay > 0)) { return super.requestAsyncId(scheduler, id, delay); } // Otherwise flush the scheduler starting with this action. scheduler.flush(this); // HACK: In the past, this was returning `void`. However, `void` isn't a valid // `TimerHandle`, and generally the return value here isn't really used. So the // compromise is to return `0` which is both "falsy" and a valid `TimerHandle`, // as opposed to refactoring every other instanceo of `requestAsyncId`. return 0; } }