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 🙏

© 2025 – Pkg Stats / Ryan Hefner

demo-hats

v0.0.2

Published

> Make multi-persona demos interactive!!

Downloads

3

Readme

Demo-Hats

Make multi-persona demos interactive!!

n.b. consider this beta - but give it a go.. is it useful?

Why would I use this?

  • You have a web application or applications - each of which is being used by a different 'persona' or 'role'.
  • You're trying to demo this at a conference, to your team mates, or your cats.
  • The problem is that unless everybody is paying attention it can be quite easy to forget what UI your looking at is what persona.
    • When did the 'swap' happen?
    • Whose the current persona?

Enter 'Demo-Hats'

The premise is quite simple

  1. Run your application(s) however you want to.
  2. Have you screen setup to demo this however you would normally.
  3. Ideally have a second screen - maybe your laptop's own screen - that is used as a 'control'
  4. MUST have a webcam and MUST have some QR codes printed out and stuck to 'something' (if you can put these on an actual hat so much the better)
  5. Configure and run the 'demo-hats' application - up comes a Chrominum browser with all the applicaations tabs open
  6. Start your demo 'speech' - when you want to swap to a persona, don't manually move the browser window but hold up a QR code instead!

Audience should now be amazed - but that's up to your demo really :-)

In more detail

Installation

It's built on node.js so you'll need that installed, then

npm install -g demo-hats

(or clone the repo!)

Create a configuration file (see below for the basic example),

Run the application

$ demo-hats
  • It will open up your demo tabs.
  • Open the control window (you'll be shown the URL when you run the program)
  • This will ask for permission to use the webcam - say yes.
  • Show it the QR codes and the tabs will change!

** You must keep the Control Windows open, otherwise the webcam won't work ** ** But it doesn't need to have focus - just not be minimised **

Configuration

Key place to start is at the configuration - this will help you understand the whole system. Here it is - by default in a file called hats.json.

{
    "info": {
        "title":"People of Interest",
        "summary":"Scenario showing how how to show different webpages for different personas "
    },
    "personas": {
        "alice": {
            "uri": "http://localhost:3456/users/alice",
            "avatar": "images/alice-person.png",
            "startState": "open",
            "displayName": "Alice",
            "bio": "Entrepreneur. Gamer. Explorer. Pr(remember that you'll need some QR codes printed!)
        },
        "bob": {
            "uri": "http://localhost:3456/users/bob",(remember that you'll need some QR codes printed!)
            "avatar": "images/bob-person.png",
            "startState": "open",
            "displayName": "Matias",
            "bio": "Award-winning web guru. Unapologetic food practitioner. Travel fanatic. Beer ninja. Reader."
        }
    }
}
  • info section gives a title and a brief summary. This is shown on the control screen.
  • personas the list of personas in use
    • the key (alice and bob above) - are the phrases and words that should be encoded into the QR codes. It could be some other word, or just a letter. Up to you - but remember the more complicated the phrase the more complex the QR code.
    • uri this is the uri that will be shown when this persona is 'activated' - i.e. the QR code is recognised... so in this case http://localhost:3456/users/alice, will become active and have focus. (note that the demo-hats app has a number of user pages built in for testing)
    • startState open to say open it on start-up (to be honest this is the only option at the moment, want to add open when you see the QR code for the first time)
    • displayName the name that will be displayed on the control screen
    • avatar the avatar for the persona that will be displayed on the control screen
    • bio some text that will be displayed on the controll screen.

You can have as made entries as you can have QR codes or browser tabs open.

In use

Simply put, you keep the control window open (not mimised) but not necassarily in focus...(makes using one screen possible) And show it the QR code that has the encoded 'key' in it.