import { Scheduler } from '../Scheduler'; 
 | 
import { Subscription } from '../Subscription'; 
 | 
import { SchedulerAction } from '../types'; 
 | 
  
 | 
/** 
 | 
 * A unit of work to be executed in a `scheduler`. An action is typically 
 | 
 * created from within a {@link SchedulerLike} and an RxJS user does not need to concern 
 | 
 * themselves about creating and manipulating an Action. 
 | 
 * 
 | 
 * ```ts 
 | 
 * class Action<T> extends Subscription { 
 | 
 *   new (scheduler: Scheduler, work: (state?: T) => void); 
 | 
 *   schedule(state?: T, delay: number = 0): Subscription; 
 | 
 * } 
 | 
 * ``` 
 | 
 * 
 | 
 * @class Action<T> 
 | 
 */ 
 | 
export class Action<T> extends Subscription { 
 | 
  constructor(scheduler: Scheduler, work: (this: SchedulerAction<T>, state?: T) => void) { 
 | 
    super(); 
 | 
  } 
 | 
  /** 
 | 
   * Schedules this action on its parent {@link SchedulerLike} for execution. May be passed 
 | 
   * some context object, `state`. May happen at some point in the future, 
 | 
   * according to the `delay` parameter, if specified. 
 | 
   * @param {T} [state] Some contextual data that the `work` function uses when 
 | 
   * called by the Scheduler. 
 | 
   * @param {number} [delay] Time to wait before executing the work, where the 
 | 
   * time unit is implicit and defined by the Scheduler. 
 | 
   * @return {void} 
 | 
   */ 
 | 
  public schedule(state?: T, delay: number = 0): Subscription { 
 | 
    return this; 
 | 
  } 
 | 
} 
 |