import { AsyncAction } from './AsyncAction'; 
 | 
import { Subscription } from '../Subscription'; 
 | 
import { QueueScheduler } from './QueueScheduler'; 
 | 
import { SchedulerAction } from '../types'; 
 | 
import { TimerHandle } from './timerHandle'; 
 | 
  
 | 
export class QueueAction<T> extends AsyncAction<T> { 
 | 
  constructor(protected scheduler: QueueScheduler, protected work: (this: SchedulerAction<T>, 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; 
 | 
  } 
 | 
} 
 |