Skip to content
This repository has been archived by the owner on Dec 28, 2022. It is now read-only.

maverick-js/scheduler

Repository files navigation

Scheduler

package-badge license-badge size-badge

This is a tiny (~250B minzipped) scheduler which batches and runs tasks off the microtask queue.

Installation

$: npm i @maverick-js/scheduler

$: pnpm i @maverick-js/scheduler

$: yarn add @maverick-js/scheduler

Usage

import { createScheduler } from '@maverick-js/scheduler';

const scheduler = createScheduler();

const taskA = () => {};
const taskB = () => {};

// Queue tasks.
scheduler.enqueue(taskA);
scheduler.enqueue(taskB);

// Be notified of a flush.
const stop = scheduler.onFlush(() => {
  console.log('Flushed!');
});

stop(); // unsubscribe

// Schedule a flush - can be invoked more than once.
scheduler.flush();

// Wait for flush to complete.
await scheduler.tick;

// Synchronously flush the queue whenever desired.
scheduler.flushSync();

Extra reading:

  • The source file is only ~80 LOC so feel free to dig through.
  • You can read more about microtasks on MDN.

Inspiration

@maverick-js/scheduler was made possible based on my learnings from:

About

A tiny (~250B) microtask scheduler.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published