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

@forge-kit-dev/module-ddd

v0.2.0

Published

Domain-Driven Design module for forge. Enforces entity identity, bounded context isolation, and ubiquitous language.

Readme

@forge-kit-dev/module-ddd

Domain-Driven Design as a forge module. Precedence 40 — weaker than Clean Code (10) and FSD (20). DDD is about language and shape, not about runtime checks, so most of this module's enforcement is advisory rather than mechanical.

What is mechanical (pre-commit block)

| Rule | What it does | |---|---| | @forge-kit-dev/forge/ddd-entity-id | Every type declared under src/entities/** (or explicitly marked with a @entity JSDoc tag) must include an id field. |

Only one mechanical rule lives here because every other DDD concept depends on reading intent. Forcing them at the lint level produces more noise than signal.

What is advisory (Evaluator rubrics)

  • r-ddd-ubiquitous-language — does the code reuse business vocabulary (basket vs cart) and is the glossary updated alongside?
  • r-ddd-aggregate-integrity — do writes go through aggregate roots, and are invariants enforced inside the aggregate rather than scattered in UI?

Skills

  • ddd-bounded-context (plan stage) — pick a context for a new file, respect its language
  • ddd-aggregate-root (generate stage) — find the root, put mutations on it
  • ddd-value-object (generate stage) — entity vs value object decision, immutable modeling

Why DDD is so sparse here

If your frontend is a thin UI for a fat backend, DDD on the frontend is mostly unnecessary. Turn this module on when:

  • The frontend holds non-trivial business rules (e.g. a financial calculator, a rules engine UI, an offline-first app)
  • Multiple teams contribute and need a shared vocabulary
  • You have a clear domain expert driving the language

Otherwise, leave it off. It will just add rubric noise.