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

@pindakaasman/gamepad-sdk

v1.0.3

Published

A simple SDK to integrate with Gamepads

Downloads

5

Readme

Gamepad SDK

A simple SDK for handling gamepad input in the browser using the navigator.Gamepad API. This SDK provides an easy way to detect button presses, releases, axis movements, and gamepad connection/disconnection events.

Features

  • Detect gamepad button presses and releases.
  • Track axis changes (analog stick movements).
  • Listen for gamepad connection and disconnection events.
  • Works with multiple gamepads.

Installation

You can install the SDK via NPM:

npm install @pindakaasman/gamepad-sdk

Usage

Here’s a basic example of how to use the Gamepad SDK in your project:

const GamepadSDK = require('@pindakaasman/gamepad-sdk');

// Initialize the SDK
const myGamepad = new GamepadSDK();

// Listen for button presses
myGamepad.addEventListener('buttonpress', (event) => {
  console.log(`Button ${event.buttonIndex} was pressed on gamepad: ${event.gamepad.id}`);
});

// Listen for axis changes
myGamepad.addEventListener('axischange', (event) => {
  console.log(`Axis ${event.axisIndex} changed to ${event.axisValue} on gamepad: ${event.gamepad.id}`);
});

// Listen for gamepad connection
myGamepad.addEventListener('connect', (event) => {
  console.log(`Gamepad connected: ${event.gamepad.id}`);
});

// Listen for gamepad disconnection
myGamepad.addEventListener('disconnect', (event) => {
  console.log(`Gamepad disconnected: ${event.gamepad.id}`);
});

Event Types

buttonpress

Triggered when a button is pressed.

Event Object:

  • gamepad: The gamepad object.
  • button: The button object.
  • buttonIndex: The index of the pressed button.

buttonrelease

Triggered when a button is released.

Event Object:

  • gamepad: The gamepad object.
  • button: The button object.
  • buttonIndex: The index of the released button.

axischange

Triggered when a gamepad axis (such as an analog stick) changes position.

Event Object:

  • gamepad: The gamepad object.
  • axisValue: The value of the axis (ranging from -1.0 to 1.0).
  • axisIndex: The index of the axis that changed.

connect

Triggered when a gamepad is connected.

Event Object:

  • gamepad: The connected gamepad object.

disconnect

Triggered when a gamepad is disconnected.

Event Object:

  • gamepad: The disconnected gamepad object.

Browser Compatibility

The Gamepad API is still an experimental feature in some browsers. Ensure that you check browser compatibility before using this SDK in production.

Supported Browsers:

  • Chrome
  • Firefox
  • Edge
  • Opera

License

This SDK is licensed under the ISC License.

Development

If you'd like to contribute to the project or work on it locally, follow these instructions to set up your development environment:

Prerequisites

Ensure that you have the following installed:

Setting Up the Project

  1. Clone the repository:

    git clone [email protected]:RamonGebben/Gamepad-SDK.git
    cd Gamepad-SDK
  2. Install dependencies: After cloning the repo, run the following command to install all project dependencies:

    npm install

Running the Code Locally

You can start developing the SDK locally by editing the source code directly in the repository. If you're adding new features or fixing bugs, ensure everything works as expected.

Running Tests

If you add tests to the project, you can run them using:

npm test

Versioning and Publishing

We use npm's versioning to manage the package versions. To bump the version of the package and publish to NPM:

  1. Bump the version:

    • For a patch version:
      npm version patch
    • For a minor version:
      npm version minor
    • For a major version:
      npm version major
  2. Publish to NPM (requires NPM authentication):

    npm publish

Automatic Publishing with GitHub Actions

This repository is configured to automatically publish to NPM whenever changes are pushed to the main branch. The GitHub Actions workflow handles the build, test, and publish process.

For more details, see the .github/workflows/npm-publish.yml file.


Feel free to fork this repository, make your changes, and submit a pull request. Contributions are always welcome!