86 lines
3.6 KiB
Markdown
86 lines
3.6 KiB
Markdown
# Changelog
|
|
|
|
All notable changes to TeamsISO are documented here. The format follows
|
|
[Keep a Changelog](https://keepachangelog.com/en/1.1.0/) and this project
|
|
adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
|
|
|
## [1.0.0] — 2026-05-17
|
|
|
|
First general release. Windows-only, .NET 8 WPF, NDI 6.
|
|
|
|
### Engine
|
|
|
|
- **Participant discovery** over NDI with name cleanup — strips the
|
|
"MS Teams - " / "(Teams) " prefixes and surfaces the operator-friendly
|
|
display name.
|
|
- **Per-participant ISO outputs** with normalized framerate, resolution,
|
|
aspect mode, and audio routing. Each ISO is an individually-addressable
|
|
NDI source.
|
|
- **NDI Groups** support — discovery and sender. One-click "Apply
|
|
transcoder topology" pins Teams' raw broadcasts to a private
|
|
`teamsiso-input` group while TeamsISO re-emits on `Public`.
|
|
- **Self-healing finder** — if the NDI runtime stalls (zero discovered
|
|
sources past a startup grace period, or sources go from present to
|
|
empty and stay that way), the engine rebuilds the finder automatically.
|
|
- **Real-time recording** — per-output raw BGRA stream + `manifest.json`
|
|
+ an FFmpeg `convert.cmd` script for post-production conversion to
|
|
H.264 MKV. Recording is opt-in globally and per-participant.
|
|
|
|
### UI — "Studio Terminal"
|
|
|
|
- **Dark and light themes** with a runtime swap and a system-follow mode.
|
|
The Wild Dragon mark, the participants-grid watermark, and every accent
|
|
brush respond to the active theme.
|
|
- **Header**: brand mark, theme toggle, settings gear.
|
|
- **Transport strip**: session timer, participant count, live ISO count,
|
|
control-surface URL — at-a-glance status.
|
|
- **Participants table**: 24px state LED, 106px live thumbnail preview,
|
|
name + caption, 5-bar audio meter, **inline-editable output name**,
|
|
CFG button (per-row override editor), ISO enable pill.
|
|
- **Settings drawer** — slide-over from the right with OUTPUT / NETWORK /
|
|
APP tabs.
|
|
- **Ctrl+K command palette** — fuzzy search across Quick / Teams /
|
|
Presets / Output / Network / App categories.
|
|
- **Live preview thumbnails** in the participants table; right-click →
|
|
Open preview… spawns a non-modal floating window suitable for a
|
|
secondary monitor.
|
|
|
|
### Output name template
|
|
|
|
- New default: **the speaker's display name** (`{name}`). Per-participant
|
|
overrides are inline-editable in the table. Empty-name fallback to
|
|
`TEAMSISO_{guid}` keeps the NDI sender uniquely identifiable while a
|
|
participant's display name resolves upstream.
|
|
- Available tokens: `{name}`, `{guid}`, `{machine}`, `{timestamp}`.
|
|
|
|
### Operator presets
|
|
|
|
- Save current per-participant ISO assignments + custom output names to
|
|
`%LOCALAPPDATA%\TeamsISO\presets.json`. Optional auto-apply on next
|
|
launch.
|
|
|
|
### Teams orchestration
|
|
|
|
- Launch / stop Teams from the app.
|
|
- Hide Teams' UI windows during a show.
|
|
- Drive in-call controls (mute, camera, share, leave, raise hand) via
|
|
UIAutomation.
|
|
|
|
### External control surface
|
|
|
|
- REST + WebSocket on `127.0.0.1:9755` for Bitfocus Companion / Stream
|
|
Deck / custom controllers.
|
|
- OSC on UDP `127.0.0.1:9000` for TouchOSC.
|
|
- Self-contained HTML control panel at `/ui` — open from any phone on
|
|
the LAN.
|
|
|
|
### Diagnostics & installer
|
|
|
|
- Rolling daily Serilog logs under `%LOCALAPPDATA%\TeamsISO\logs\`.
|
|
- Diagnostic bundle export — zips logs + config + presets for bug reports.
|
|
- Forgejo-backed update check (manual or silent-on-launch, throttled to
|
|
24h).
|
|
- WiX MSI installer with proper Add/Remove Programs metadata, Start Menu
|
|
+ Desktop shortcuts, and in-place upgrade.
|
|
|
|
[1.0.0]: https://forge.wilddragon.net/zgaetano/teamsiso/releases/tag/v1.0.0
|