- Add new libraries: ui-accessibility, ui-animations, ui-backgrounds, ui-code-display, ui-data-utils, ui-font-manager, hcl-studio - Add extensive layout components: gallery-grid, infinite-scroll-container, kanban-board, masonry, split-view, sticky-layout - Add comprehensive demo components for all new features - Update project configuration and dependencies - Expand component exports and routing structure - Add UI landing pages planning document 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
53 lines
1.3 KiB
TypeScript
53 lines
1.3 KiB
TypeScript
import { Scheduler } from '../Scheduler';
|
|
import { Action } from './Action';
|
|
import { AsyncAction } from './AsyncAction';
|
|
import { TimerHandle } from './timerHandle';
|
|
|
|
export class AsyncScheduler extends Scheduler {
|
|
public actions: Array<AsyncAction<any>> = [];
|
|
/**
|
|
* A flag to indicate whether the Scheduler is currently executing a batch of
|
|
* queued actions.
|
|
* @internal
|
|
*/
|
|
public _active: boolean = false;
|
|
/**
|
|
* An internal ID used to track the latest asynchronous task such as those
|
|
* coming from `setTimeout`, `setInterval`, `requestAnimationFrame`, and
|
|
* others.
|
|
* @internal
|
|
*/
|
|
public _scheduled: TimerHandle | undefined;
|
|
|
|
constructor(SchedulerAction: typeof Action, now: () => number = Scheduler.now) {
|
|
super(SchedulerAction, now);
|
|
}
|
|
|
|
public flush(action: AsyncAction<any>): void {
|
|
const { actions } = this;
|
|
|
|
if (this._active) {
|
|
actions.push(action);
|
|
return;
|
|
}
|
|
|
|
let error: any;
|
|
this._active = true;
|
|
|
|
do {
|
|
if ((error = action.execute(action.state, action.delay))) {
|
|
break;
|
|
}
|
|
} while ((action = actions.shift()!)); // exhaust the scheduler queue
|
|
|
|
this._active = false;
|
|
|
|
if (error) {
|
|
while ((action = actions.shift()!)) {
|
|
action.unsubscribe();
|
|
}
|
|
throw error;
|
|
}
|
|
}
|
|
}
|