Files
headroom/frontend/node_modules/happy-dom/lib/nodes/document/DocumentReadyStateManager.js
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

73 lines
1.8 KiB
JavaScript

/**
* Document ready state manager.
*/
export default class DocumentReadyStateManager {
totalTasks = 0;
readyStateCallbacks = [];
window = null;
immediate = null;
isComplete = false;
/**
* Constructor.
*
* @param window
*/
constructor(window) {
this.window = window;
}
/**
* Returns a promise that is fulfilled when ready state is complete.
*
* @returns Promise.
*/
waitUntilComplete() {
return new Promise((resolve) => {
if (this.isComplete) {
resolve();
}
else {
this.readyStateCallbacks.push(resolve);
this.startTask();
this.endTask();
}
});
}
/**
* Starts a task.
*/
startTask() {
if (this.isComplete) {
return;
}
if (this.immediate) {
this.window.cancelAnimationFrame(this.immediate);
this.immediate = null;
}
this.totalTasks++;
}
/**
* Ends a task.
*/
endTask() {
if (this.isComplete) {
return;
}
if (this.immediate) {
this.window.cancelAnimationFrame(this.immediate);
this.immediate = null;
}
this.totalTasks--;
this.immediate = this.window.requestAnimationFrame(() => {
this.immediate = null;
if (this.totalTasks <= 0) {
const callbacks = this.readyStateCallbacks;
this.readyStateCallbacks = [];
this.isComplete = true;
for (const callback of callbacks) {
callback();
}
}
});
}
}
//# sourceMappingURL=DocumentReadyStateManager.js.map