npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

powerq

v1.0.0

Published

Effortless, prioritized async scheduling for JavaScript and TypeScript.

Readme

PowerQ - Take control of your async world 🚀

Effortless, prioritized async scheduling for JavaScript and TypeScript.

npm version License: MIT


✨ Features

  • Priority task queue with binary or dynamic task promotion/demotion
  • Configurable concurrency (run many tasks in parallel)
  • Customizable queue selection logic
  • Cancel queued or running tasks
  • Cross-platform: Node.js, React, React Native
  • Zero dependencies, ultra-lightweight

📦 Installation

npm install powerq
# or
yarn add powerq

🚀 Usage

import { PowerQ } from "powerq";

// Create scheduler with concurrency of 3
const scheduler = new PowerQ({ concurrency: 3 });

// Add a normal (default) task
const handle1 = scheduler.add(() => fetch("/api/slow-job"));

// Add a priority task
const handle2 = scheduler.add(() => fetch("/api/vip-job"), { priority: true });

// Await the result (does NOT block the JS thread)
handle1.result.then(console.log).catch(console.error);

// Promote/demote as needed
scheduler.promoteToPriority(handle1.id);
scheduler.demoteToNormal(handle2.id);

// Cancel if needed
handle2.cancel();

// Change concurrency at runtime
scheduler.setConcurrency(5);

// Custom queue selection: favor "aged" normal tasks if they've waited >5s
scheduler.setQueueSelector((priorityQ, normalQ) => {
  if (normalQ.length && Date.now() - normalQ[0].addedAt > 5000) return "normal";
  return "priority";
});

🛠 API

new PowerQ(options?)

Create a new scheduler.

  • concurrency (number): Max concurrent tasks (default: 1)
  • queueSelector (function): Custom selection logic for which queue to draw from

.add(taskFn, options?)

Add a task (default: normal queue).

const handle = scheduler.add(() => someAsyncJob(), { priority: true });

Returns a TaskHandle with:

  • id: string
  • result: Promise<T> — resolves/rejects with task’s outcome
  • cancel(): void — cancels this task

.promoteToPriority(taskId: string)

Move a normal task to the priority queue.


.demoteToNormal(taskId: string)

Move a priority task back to the normal queue.


.cancel(taskId: string)

Cancel a queued or running task.


.setConcurrency(number)

Change the maximum number of concurrent tasks.


.setQueueSelector(fn)

Replace the queue selection strategy at runtime.


🧪 Example with Concurrency

const scheduler = new PowerQ({ concurrency: 2 });

const slowTask = (id: number, ms: number) => () =>
  new Promise((res) => setTimeout(() => res(`Task ${id} done`), ms));

const h1 = scheduler.add(slowTask(1, 1000));
const h2 = scheduler.add(slowTask(2, 500));
const h3 = scheduler.add(slowTask(3, 200), { priority: true });

Promise.all([h1.result, h2.result, h3.result]).then(console.log);

The package is developed and maintained by S25Digital.