Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

elgato-stream-deck-clean-mini

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

elgato-stream-deck-clean-mini

An npm module for interfacing with the Elgato Stream Deck Mini. Without image library dependencies. (clean)

  • 1.0.1
  • latest
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

elgato-stream-deck-clean-mini

alt text

elgato-stream-deck-clean-mini is a Node.js library for interfacing with the Elgato Stream Deck Mini.

❗ Please note that elgato-stream-deck-clean-mini is NOT a standalone application. It is not something you download and run on its own. It is not an alternative to the official Stream Deck Mini program provided by Elgato. Instead, elgato-stream-deck-clean-mini is a code library, which developers can use to make their own applications which interface with the Stream Deck Mini.

Custom version

This is a modified version of elgato-stream-deck that does not have dependencies to image libraries. And that only supports the "mini" device. That way the end-application can use its own libraries, so the dependencies stay at a minimum.

Install

$ npm install --save elgato-stream-deck-clean-mini

Table of Contents

Example

JavaScript
const path = require('path');
const StreamDeck = require('elgato-stream-deck-clean-mini');

// Automatically discovers connected Stream Deck Minis, and attaches to the first one.
// Throws if there are no connected stream decks.
// You also have the option of providing the devicePath yourself as the first argument to the constructor.
// For example: const myStreamDeck = new StreamDeck('\\\\?\\hid#vid_05f3&pid_0405&mi_00#7&56cf813&0&0000#{4d1e55b2-f16f-11cf-88cb-001111000030}')
// Device paths can be obtained via node-hid: https://github.com/node-hid/node-hid
const myStreamDeck = new StreamDeck();

myStreamDeck.on('down', keyIndex => {
	console.log('key %d down', keyIndex);
});

myStreamDeck.on('up', keyIndex => {
	console.log('key %d up', keyIndex);
});

// Fired whenever an error is detected by the `node-hid` library.
// Always add a listener for this event! If you don't, errors will be silently dropped.
myStreamDeck.on('error', error => {
	console.error(error);
});

// Fill the first button form the left in the first row with a solid red color. This is synchronous.
myStreamDeck.fillColor(4, 255, 0, 0);
console.log('Successfully wrote a red square to key 4.');
TypeScript
import StreamDeck = require('elgato-stream-deck-clean-mini');
const myStreamDeck = new StreamDeck(); // Will throw an error if no Stream Deck Minis are connected.

myStreamDeck.on('down', keyIndex => {
	console.log('key %d down', keyIndex);
});

myStreamDeck.on('up', keyIndex => {
	console.log('key %d up', keyIndex);
});

// Fired whenever an error is detected by the `node-hid` library.
// Always add a listener for this event! If you don't, errors will be silently dropped.
myStreamDeck.on('error', error => {
	console.error(error);
});

Features

  • Multiplatform support: Windows 7-10, MacOS, Linux, and even Raspberry Pi!
  • Key down and key up events
  • Fill keys with images or solid RGB colors
  • Fill the entire panel with a single image, spread across all keys
  • Set the Stream Deck Mini brightness
  • TypeScript support

API

> streamDeck.write(buffer) -> undefined

Synchronously writes an arbitrary Buffer instance to the Stream Deck Mini. Throws if an error is encountered during the write operation.

Example
// Writes 16 bytes of zero to the Stream Deck Mini.
streamDeck.write(Buffer.alloc(16));
> streamDeck.fillColor(keyIndex, r, g, b) -> undefined

Synchronously sets the given keyIndex's screen to a solid RGB color.

Example
// Turn key 4 (the top left key) solid red.
streamDeck.fillColor(4, 255, 0, 0);
> streamDeck.fillImage(keyIndex, buffer) -> undefined

Synchronously writes a buffer of 72x72 RGB image data to the given keyIndex's screen. The buffer must be exactly 15552 bytes in length. Any other length will result in an error being thrown.

Example
// Fill the third button from the left in the first row with an image of the GitHub logo.
const sharp = require('sharp'); // See http://sharp.dimens.io/en/stable/ for full docs on this great library!
sharp(path.resolve(__dirname, 'github_logo.png'))
	.flatten() // Eliminate alpha channel, if any.
	.resize(streamDeck.ICON_SIZE, streamDeck.ICON_SIZE) // Scale up/down to the right size, cropping if necessary.
	.raw() // Give us uncompressed RGB.
	.toBuffer()
	.then(buffer => {
		return streamDeck.fillImage(2, buffer);
	})
	.catch(err => {
		console.error(err);
	});
> streamDeck.clearKey(keyIndex) -> undefined

Synchronously clears the given keyIndex's screen.

Example
// Clear the third button from the left in the first row.
streamDeck.clearKey(2);
> streamDeck.clearAllKeys() -> undefined

Synchronously clears all keys on the device.

Example
// Clear all keys.
streamDeck.clearAllKeys();
> streamDeck.setBrightness(percentage) -> undefined

Synchronously set the brightness of the Stream Deck Mini. This affects all keys at once. The brightness of individual keys cannot be controlled.

Example
// Set the Stream Deck Mini to maximum brightness
streamDeck.setBrightness(100);

Events

> down

Fired whenever a key is pressed. keyIndex is the 0-14 numerical index of that key.

Example
streamDeck.on('down', keyIndex => {
	console.log('key %d down', keyIndex);
});
> up

Fired whenever a key is released. keyIndex is the 0-14 numerical index of that key.

Example
streamDeck.on('up', keyIndex => {
	console.log('key %d up', keyIndex);
});
> error

Fired whenever an error is detected by the node-hid library. Always add a listener for this event! If you don't, errors will be silently dropped.

Example
streamDeck.on('error', error => {
	console.error(error);
});

Keywords

FAQs

Package last updated on 08 Jun 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc