Turn any tablet into a fully configurable stream deck. A lightweight, standalone stream-deck app — launch programs, switch DisplayFusion monitor profiles, control media, fire hotkeys/macros, hit any HTTP endpoint, and more — all from a web panel on your tablet(s) or the Elgato Stream Deck plugin. No heavy backend, no cloud.
RigzDeck is a slim host around the shared deckcore engine (included here as a git submodule) — a battle-tested deck editor, deck model, and renderer wrapped in a minimal FastAPI app.
- Decks — independent view templates (own grid / categories / style), share a button pool.
- WYSIWYG editor — drag buttons into a live grid; free placement, per-button image + title overlay, widget tiles (clock / text / graph), resizable tiles, folders & radial menus.
- One-click presets — pick an action type and the matching status monitor, on/off logic and a fitting symbol fill in automatically (fully editable). The smallest button in seconds, not minutes.
- Generic capabilities —
launch(any .exe/.py/.lnk, native file picker + icon extraction),obs(scene / source toggle / stream / record),displayfusion(load monitor profiles),media(play/pause · ⏭⏮ · volume · mute),hotkey(send any key combo),http,flag. - Audio (Wave Link + Windows) — one click syncs the running Wave Link app into a fader deck (per-mix/channel level + mute, live VU); switch the Windows default output device from a button, with optional “Wave Link follows Windows default” coupling — all built right in the editor.
- Sensors — HWiNFO sensors + PresentMon FPS / frametime as value or live-graph tiles.
- Status monitors — poll / file / flag / OBS scene / DisplayFusion profile / default-device …
- Modern deck design — sleek flat tiles with accent glow + corner brackets, redesigned faders with gradient fill, peak-hold VU meters and image-or-emoji symbols; the editor preview is true WYSIWYG.
- Touch panel over LAN for tablets (deck fullscreen, offline screen, version badge) + the Elgato Stream Deck plugin.
git clone --recurse-submodules https://github.com/RitschyRigz/rigzdeck.git
cd rigzdeck
pip install -r requirements.txt
( cd web && npm install && npm run build )
python -m rigzdeck # → http://localhost:7990 (panel: /panel)Already cloned without submodules?
git submodule update --init --recursive
pip install -r requirements-build.txt
.\packaging\build.ps1 # builds the frontend, then bundles dist\RigzDeck\RigzDeck.exeThe .exe runs the server in the background and lives in the system tray — open the editor
or panel, copy the LAN URL for tablets, or quit. Optionally compile packaging\RigzDeck.iss
with Inno Setup for an installer (Start-menu shortcut,
optional autostart, uninstaller).
rigzdeck/ (this host: FastAPI + event bus + static serving) → embeds deckcore
(DeckCoreService + build_streamdeck_router) → serves web/ (Preact editor + touch panel,
which import the deck UI modules from deckcore/web).
MIT — see LICENSE.
