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

liteship

v0.3.1

Published

LiteShip umbrella — installs the full @czap/* constraint-based adaptive rendering stack in one dependency

Readme

liteship

One dependency that installs every publishable @czap/* package at the same version — the front door to LiteShip. The mental model is one sentence: a continuous signal crosses boundaries into named states, and named states project into outputs (CSS, ARIA, shaders).

Install this directly when you're starting a project and want the whole stack version-locked. If you only need one slice, install that slice instead — @czap/astro alone pulls the core rendering stack for the Astro path.

Install

npm install liteship   # or yarn add liteship

pnpm users: pnpm's strict node_modules does not hoist transitive dependencies, and liteship re-exports nothing, so import '@czap/core' will not resolve through it. Add the @czap/* packages you import as explicit dependencies (pnpm add @czap/core @czap/astro), or hoist the scope with public-hoist-pattern[]=@czap/* in .npmrc. npm and yarn's hoisted layouts work as-is.

30 seconds

import { Boundary } from '@czap/core'; // installed for you by liteship

const viewport = Boundary.make({
  input: 'viewport.width',
  at: [
    [0, 'mobile'],
    [768, 'tablet'],
    [1280, 'desktop'],
  ],
});

console.log(Boundary.evaluate(viewport, 800)); // 'tablet'

Logs tablet — the named state for a 768–1279px viewport width. That signal-to-state step is the foundation; everything else (compiled CSS, host integrations, motion) projects from it.

Where it sits

The umbrella sits above everything: it depends on all twenty publishable @czap/* packages, pinned at exactly its own version, and deliberately re-exports none of them — the host integrations (@czap/astro, @czap/vite, @czap/cloudflare) carry host-specific peer expectations, and a barrel importing all of them would force every consumer to satisfy all of them at once. You import from the individual scopes exactly as the docs show; this package just makes sure they're installed. Its only export is LITESHIP_PACKAGES, the list of what it installs. See the package surfaces map for the full layout.

Docs


Part of LiteShip — powered by the CZAP engine (Content-Zoned Adaptive Projection), distributed as @czap/* packages.