Files
headroom/frontend/node_modules/happy-dom/lib/async-task-manager/AsyncTaskManager.d.ts
Santhosh Janardhanan de2d83092e feat: Reinitialize frontend with SvelteKit and TypeScript
- Delete old Vite+Svelte frontend
- Initialize new SvelteKit project with TypeScript
- Configure Tailwind CSS v4 + DaisyUI
- Implement JWT authentication with auto-refresh
- Create login page with form validation (Zod)
- Add protected route guards
- Update Docker configuration for single-stage build
- Add E2E tests with Playwright (6/11 passing)
- Fix Svelte 5 reactivity with $state() runes

Known issues:
- 5 E2E tests failing (timing/async issues)
- Token refresh implementation needs debugging
- Validation error display timing
2026-02-17 16:19:59 -05:00

101 lines
2.2 KiB
TypeScript

import IBrowserFrame from '../browser/types/IBrowserFrame.js';
/**
* 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