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

gamevis

v0.2.0

Published

[![Gitter](https://badges.gitter.im/saul/gamevis.svg)](https://gitter.im/saul/gamevis?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)

Readme

Gamevis

Gitter

Gamevis is an open-source Electron application for visualising gameplay data developed by Saul Rennison as part of his degree dissertation.

Gamevis is unopinionated and easily fits many genres of games, and includes importers for Counter-Strike: Global Offensive and Dota 2.

Screenshot

Screenshot demonstrating two layered heatmap visualisations:

Installation

1. Prerequisites

Node & npm are already expected to be installed:

brew install libpqxx
npm install -g gulp # required for building
npm install # install app dependencies
gulp # compile JavaScript and stylesheets

2. Database

A Postgres server is by default expected to be running on localhost. The config.json file can be updated at the root of the project to specify a non-default database IP/port.

By default the server is expected to have a database named gamevis with a username and password of gamevis.

Note that no tables need to be generated - the application will automatically generate.

3. Run the app

The application can be started with npm start. However, no sessions are available by default. The importers (see below) can be used to import game sessions into the database.

Visualisations

Multiple visualisations can be show on a single visualisation (as shown in the screenshot):

  • Heatmaps
  • Timeline events (e.g., round start)
  • Discontinuous points (e.g., death location)
  • Continuous points (e.g., player movement)

Importers

Game | Path | Comments -----|------|---------- Counter-Strike: Global Offensive | importers/csgo | Run import.js with the path to the demo file as the argument. Dota 2: Reborn | importers/dota_reborn | Run import.go with the path to the .dem replay file as the argument.

Release log

Gamevis is still a work-in-progress and is not expected to be in a production-ready state until Summer 2016. However, changes are committed frequently and any issues should be raised as bugs. Of course pull requests are welcome!

Database

Gamevis expects to connect to a Postgres database of version 9.3 or later due to JSONB querying features. This section details the structure of the database tables, that are automatically generated by the game client.

session

Column | Type | Value -------|------|------- title | string, not null | User-friendly session title level | string, not null | Name of the level/map/world this session was recorded from, e.g., de_dust2 game | string, not null | Short name of the game this session is associated with, e.g., csgo. This name will be used as the subdirectory to find the level overview data. data | JSONB | (Optional) Custom data associated with this session.

event

This table represents events that occur throughout a game's session. Events are optionally associated with one or more locations within the game world, and optionally associated with one or more entities.

Column | Type | Value -------|------|------- session_id | foreign key | → session tick | int, not null | Game tick that this event occurred name | string, not null | Name of the event data | JSONB, not null | Event-specific data. The data keys for a particular event name are expected to be constant across all instances of it being fired in a particular session locations | JSONB | (Optional) All locations associated with this instance of the event. Keys should be a user-friendly string, and the value a Vector2 object, e.g., {'player': {'x': 500, 'y': 250}} entities | JSONB | (Optional) All entities associated with this instance of the event. Keys should be a user-friendly string, and the values pointers into the entity_props table, e.g., {'grenade': 175, 'thrower': 11}

entity_props

This table represents the entity properties throughout the recorded session.

Column | Type | Value -------|------|------- session_id | foreign key | → session index | int, not null | Entity index. Does not have unique across an entire session, just for this entity at this tick tick | int, not null | Game tick that this update occurred prop | string, not null | Name of the property that was updated (e.g., health) value | JSONB, not null | JSON object of the format {'value': newValue} representing the new value of the property.

License

This project is licensed under the MIT license, see LICENSE.md for the full legalese.

Acknowledgements