Skip to main content

Next Generation Linux UI for the Elgato Stream Deck - Modernized fork with Python 3.11+ support

Project description

streamdeck-gui-ng - Next Generation Linux UI for the Elgato Stream Deck


PyPI version Build Status Docs Status License Imports: isort semantic-release: angular


streamdeck-gui-ng - Next Generation Linux compatible UI for the Elgato Stream Deck.

Why This Fork?

I use Stream Deck every day and depend on it for my workflow. When I noticed that streamdeck-linux-gui had entered maintenance mode and was no longer accepting new features, I decided to fork it to ensure continued development and modernization.

This fork aims to:

  • Modernize the codebase with support for current Python versions (3.11+)
  • Fix security vulnerabilities and keep dependencies up to date
  • Continue active development and feature improvements
  • Maintain compatibility with the latest Stream Deck devices

Project History

streamdeck-gui-ng is the third generation of this project:

  1. streamdeck_ui (Original) - Created by Timothy Crosley, this was the first Linux UI for Stream Deck. The project was abandoned when the original author disappeared.

  2. streamdeck-linux-gui (First Fork) - The community forked the original project to keep it alive. However, this fork eventually entered maintenance mode in 2024, accepting only critical bug fixes while directing users to StreamController for new features.

  3. streamdeck-gui-ng (This Fork) - A modernized continuation for users who prefer the original architecture and want continued development of this proven codebase.

All credit to the original authors and the many contributors to both previous projects. This fork builds on their excellent work.

Streamdeck UI Usage Example

Key Features

  • Linux Compatible: Enables usage of Stream Deck devices (Original, MK2, Mini and XL) on Linux.
  • Multi-device: Enables connecting and configuring multiple Stream Decks on one computer.
  • Brightness Control: Supports controlling the brightness from both the configuration UI and buttons on the device itself.
  • Configurable Button Display: Icons + Text, Icon Only, and Text Only configurable per button on the Stream Deck.
  • Multi-Action Support: Run commands, write text and press hotkey combinations at the press of a single button on your Stream Deck.
  • Button Pages: streamdeck_ui supports multiple pages of buttons and dynamically setting up buttons to switch between those pages.
  • Auto Reconnect: Automatically and gracefully reconnects, in the case the device is unplugged and replugged in.
  • Import/Export: Supports saving and restoring Stream Deck configuration.
  • Drag/Drop: Move buttons by simply drag and drop.
  • Drag/Drop Image: Configure a button image by dragging it from your file manager onto the button.
  • Auto Dim: Configure the Stream Deck to automatically dim the display after a period of time. A button press wakes it up again.
  • Animated icons: Use an animated gif to liven things up a bit.
  • Runs under systemd: Run automatically in the background as a systemd --user service.
  • Stream Deck Pedal: Supports actions when pressing pedals.
  • Plugin System: Extend functionality with Python plugins that can monitor external services, update buttons dynamically, and respond to events. See Plugin Development Guide.

Documentation

Communication with the Stream Deck is powered by the Python Elgato Stream Deck Library.

Documentation is available at https://millaguie.github.io/streamdeck-gui-ng/

Installation Guides

Once you're up and running, consider installing a systemd service.

Use the troubleshooting guide or search the issues for guidance. If you cannot find on the issue on this repository please try searching on the original at streamdeck_ui.

Precooked Scripts

There are scripts for setting up streamdeck_ui on Debian/Ubuntu and Fedora.

Plugin System

StreamDeck UI now supports a powerful plugin system that allows you to extend functionality with custom Python scripts. Plugins can:

  • Monitor external services (APIs, databases, servers, etc.)
  • Update button appearance dynamically based on real-time data
  • Respond to button presses with custom logic
  • Request page switches when important events occur
  • Run continuously or only when visible

Example Plugins

The repository includes two production-ready example plugins:

Prometheus AlertManager Monitor (plugins/alertmanager/):

  • Monitors AlertManager for active alerts
  • Updates button display with alert count
  • Changes color based on severity
  • Flashes and switches pages on new alerts
  • Opens AlertManager in browser when pressed
  • Supports multiple authentication methods

Arch Linux Update Monitor (plugins/arch_update/):

  • Monitors system updates (pacman, AUR, Flatpak)
  • Shows update count with color coding
  • Displays breakdown by source (P:pacman, A:AUR, F:Flatpak)
  • Launches update command in terminal on button press
  • Supports any AUR helper and terminal emulator
  • Automatic page switching on new updates

See the Plugin Development Guide for complete documentation on creating your own plugins.

Quick Start

  1. Create plugin directory: ~/.streamdeck_ui/plugins/my_plugin/
  2. Add manifest.yaml with plugin metadata
  3. Write your plugin extending BasePlugin
  4. Restart StreamDeck UI
  5. Assign plugin to a button in the UI

Updating Documentation

Documentation is powered by mkdocs-material, and its on the docs folder. Install it with pip install mkdocs-material and run mkdocs serve to see the changes locally, before submitting a PR.

Development & Contributions

Contributuions encouraged and very welcome, however some rules and guidelines must be followed!

General Guidelines

  • The project is versioned according to Semantic Versioning.
  • When writing your commit messages, please follow the Angular commit message.
  • Pull requests should be made against the develop branch, so please make sure you check out the develop branch.
  • Pull requests should include tests and documentation as appropriate.
  • When opening a pull request, if possible, attach a screenshot or GIF of the changes.
  • Please read the contributing guide for more information and instructions on how to get started.

Feature Requests

Open a new discussion with the feature request tag and describe the feature you would like to see implemented. If you have a screenshot or GIF of the feature, please attach it to the discussion.

Bug Reports

Open a bug report and follow the template. Please include as much information as possible.

Have a Question?

If you need any help, have a question, or just want to discuss something related to the project, please feel free to open a discussion.

Known issues

  • pip package is not yet available for the current state of the project. Please install from source, currently trying to find a better way to provide the package.
  • Streamdeck uses pynput for simulating Key Presses but it lacks proper support for Wayland. Generally your results will be good when using X (Ubuntu/Linux Mint). This thread may be useful.
  • Key Press or Write Text does not work on Fedora (outside of the streamdeck itself), which is not particularly useful. However, still do a lot with the Command feature.
  • Some users have reported that the Stream Deck device does not work on all on specific USB ports, as it draws quite a bit of power and/or has strict bandwidth requirements. Try a different port.
  • If you are executing a shell script from the Command feature - remember to add the shebang at the top of your file, for the language in question. #!/bin/bash or #!/usr/bin/python3 etc. The streamdeck may appear to lock up if you don't under some distros.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

streamdeck_gui_ng-4.4.2.tar.gz (1.3 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

streamdeck_gui_ng-4.4.2-py3-none-any.whl (1.3 MB view details)

Uploaded Python 3

File details

Details for the file streamdeck_gui_ng-4.4.2.tar.gz.

File metadata

  • Download URL: streamdeck_gui_ng-4.4.2.tar.gz
  • Upload date:
  • Size: 1.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for streamdeck_gui_ng-4.4.2.tar.gz
Algorithm Hash digest
SHA256 dcd016f0a4f2bee135177916f68e471ceee737666a9dc4a2cda4cfc9a8bd202f
MD5 d1962e22076fd8ca6e1d201786e9df53
BLAKE2b-256 913443666b8849f91594f9f69a0a018a199b463da44fcccfaf19c6def8bba72f

See more details on using hashes here.

Provenance

The following attestation bundles were made for streamdeck_gui_ng-4.4.2.tar.gz:

Publisher: publish.yaml on millaguie/streamdeck-gui-ng

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file streamdeck_gui_ng-4.4.2-py3-none-any.whl.

File metadata

File hashes

Hashes for streamdeck_gui_ng-4.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 f7396d3799ed0c60f0e98a8f7092848935b932af7d4351b86a08f594aa722092
MD5 9c61323d90b08d1596119d1f029b207a
BLAKE2b-256 133d6b0bf67f35a94490d9838cf045cbb57268835024dd73f12986203327c5cc

See more details on using hashes here.

Provenance

The following attestation bundles were made for streamdeck_gui_ng-4.4.2-py3-none-any.whl:

Publisher: publish.yaml on millaguie/streamdeck-gui-ng

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page