happy-dom
Version:
Happy DOM is a JavaScript implementation of a web browser without its graphical user interface. It includes many web standards from WHATWG DOM and HTML.
101 lines • 2.23 kB
TypeScript
import IBrowserFrame from '../browser/types/IBrowserFrame.cjs';
/**
* Handles async tasks.
*/
export default class AsyncTaskManager {
#private;
private static taskID;
private runningTasks;
private runningTaskCount;
private runningTimers;
private runningImmediates;
private debugTrace;
private waitUntilCompleteTimer;
private waitUntilCompleteResolvers;
private aborted;
private destroyed;
/**
* Constructor.
*
* @param browserFrame Browser frame.
*/
constructor(browserFrame: IBrowserFrame);
/**
* Returns a promise that is resolved when async tasks are complete.
*
* @returns Promise.
*/
waitUntilComplete(): Promise<void>;
/**
* Aborts all tasks.
*/
abort(): Promise<void>;
/**
* Destroys the manager.
*/
destroy(): Promise<void>;
/**
* Starts a timer.
*
* @param timerID Timer ID.
*/
startTimer(timerID: NodeJS.Timeout): void;
/**
* Ends a timer.
*
* @param timerID Timer ID.
*/
endTimer(timerID: NodeJS.Timeout): void;
/**
* Starts an immediate.
*
* @param immediateID Immediate ID.
*/
startImmediate(immediateID: NodeJS.Immediate): void;
/**
* Ends an immediate.
*
* @param immediateID Immediate ID.
*/
endImmediate(immediateID: NodeJS.Immediate): void;
/**
* Starts an async task.
*
* @param abortHandler Abort handler.
* @returns Task ID.
*/
startTask(abortHandler?: (destroy?: boolean) => void): number;
/**
* Ends an async task.
*
* @param taskID Task ID.
*/
endTask(taskID: number): void;
/**
* Returns the amount of running tasks.
*
* @returns Count.
*/
getTaskCount(): number;
/**
* Returns a new task ID.
*
* @returns Task ID.
*/
private newTaskID;
/**
* Resolves when complete.
*/
private resolveWhenComplete;
/**
* Applies debugging.
*/
private applyDebugging;
/**
* Aborts all tasks.
*
* @param destroy Destroy.
*/
private abortAll;
}
//# sourceMappingURL=AsyncTaskManager.d.ts.map