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

whoisdave

v0.1.4

Published

a command-line chatbot about Dave Seidman

Readme

whoisdave

A command-line chatbot about Dave Seidman.

The idea is simple: instead of sending a normal portfolio link or resume, Dave can send people an npm package they can run in their terminal.

npx whoisdave

It opens a local terminal conversation where people can ask about Dave's work, projects, background, preferences, and other biographical details.

How It Works

This is intentionally not a hosted AI service. It runs locally in Node, uses node-nlp to classify what the user is asking, and answers from authored local data. The goal is for the bot to feel conversational without making things up.

The basic flow is:

user question
  -> local NLP intent classification
  -> matching answer or action
  -> typewriter-style terminal response

Some answers have multiple variants. The app shuffles and cycles through them so repeated questions do not always get the exact same response.

Where The Data Lives

If you want to jump straight into the content, start here:

  • data/profile.json - biographical information, personal details, education, personality, music, hobbies.
  • data/experience.json - work history, technical stack, learning habits, motivation.
  • data/projects.json - structured project records.
  • data/stories.json - longer project stories and interview-style examples.
  • data/interview.json - prompts and draft answers for common interview questions.
  • data/voice.json - writing and interaction guidelines for how the bot should sound.

The current runtime still gets most direct answers from:

  • modules/nlp/intents/*.json

Each intent file contains example questions and, when applicable, answer variants. After editing intent files, retrain the NLP model:

npm run train

That updates:

modules/nlp/model.nlp

Development

Install dependencies:

npm install

Run the CLI locally:

npm run dev

Run it in watch mode while editing data, intents, or source files:

npm run dev:watch

Publishing

Patch versions are enough while this is evolving:

npm version patch --no-git-tag-version
npm publish

Then test the published package:

npx whoisdave@latest