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

@dloizides/og-image-generator

v1.0.0

Published

Provider-agnostic build-time image generation (rasterize SVG -> PNG for OG/social cards and icons). The image seam of the generation abstraction.

Readme

@dloizides/og-image-generator

Provider-agnostic build-time image generation — rasterise brand SVGs into PNG social cards (OG) and icons. This is the image seam of the cross-product generation abstraction (Capability Wave C3): consumers depend on the ImageRasterizer interface, never on a specific backend, so the rendering engine (today sharp, tomorrow a self-host/AI provider) is swappable without code change.

Why

Every site that ships an Open Graph card and an apple-touch-icon needs the same build step: take an SVG design source and emit a sized PNG. Instead of copy-pasting a sharp script into each repo, depend on this package and pass the jobs in.

Install

npm i -D @dloizides/og-image-generator sharp

sharp is injected, not a dependency of this package — you control its version and the package itself has zero runtime deps.

Use (build script)

import sharp from 'sharp';
import { resolve, dirname } from 'node:path';
import { fileURLToPath } from 'node:url';
import {
  SharpRasterizer,
  generateOgImages,
  nodeFileSystem,
} from '@dloizides/og-image-generator';

const root = resolve(dirname(fileURLToPath(import.meta.url)), '..');
const p = (rel) => resolve(root, rel);

await generateOgImages(
  [
    { src: p('public/og-card.svg'), dst: p('public/og-card.png'), width: 1200, height: 630, fit: 'cover' },
    { src: p('public/favicon.svg'), dst: p('public/apple-touch-icon.png'), width: 180, height: 180, fit: 'contain' },
  ],
  { rasterizer: new SharpRasterizer(sharp), fs: nodeFileSystem, logger: console },
);

Missing sources are skipped with a warning (written: false), so a site without a favicon SVG still builds.

API

  • ImageRasterizer — the seam: rasterize(source: Buffer, opts): Promise<Buffer>.
  • SharpRasterizer — build-time provider; new SharpRasterizer(sharp).
  • generateOgImages(jobs, { rasterizer, fs, logger? }) — orchestrates read → rasterize → write per job (sequential; missing sources skipped).
  • nodeFileSystem — default node:fs filesystem port.
  • Defaultsfit: 'cover', density: 144, quality: 90.

Adding a provider

Implement ImageRasterizer (e.g. a self-host ComfyUI or an AI image API) and pass it to generateOgImages — no consumer change. The build-time sharp path stays the default for deterministic, dependency-light asset rendering.