opencode-zellij-status
v0.2.1
Published
OpenCode tab status and desktop notifications for Zellij
Maintainers
Readme
opencode-zellij-status
Small OpenCode plugin that shows OpenCode status on the current Zellij tab and optionally sends macOS desktop notifications for attention-worthy events.
The plugin listens for OpenCode session, permission, and question events. It renames the current Zellij tab with a small status suffix, using an idle marker so the tab label width stays stable as status changes.
Install
Add the plugin to your OpenCode config:
{
"plugin": ["opencode-zellij-status"]
}The plugin only acts when running inside Zellij, detected through ZELLIJ or ZELLIJ_SESSION_NAME. It also uses ZELLIJ_PANE_ID to find the tab containing the current OpenCode pane.
If Zellij tab lookup or tab rename fails, the plugin no-ops silently so it does not break OpenCode outside the expected environment.
Behavior
The first version intentionally keeps the mapping small and quiet. These are the default portable markers:
| OpenCode event | Tab suffix | Notification |
| --- | --- | --- |
| idle/default | ✓ | No |
| session.status busy | ● | No |
| session.status retry | … | macOS only, if enabled |
| session.status idle | ✓ | No |
| session.idle | ✓ | macOS only, if enabled |
| session.error | ! | macOS only, if enabled |
| permission.asked | ? | macOS only, if enabled |
| permission.replied | ✓ | No |
| question.asked | ? | macOS only, if enabled |
On each handled event, the plugin reads the current tab name from Zellij, strips any known status suffix (✓, ●, …, ?, !), and stores that base tab name in memory using the current Zellij session and tab ID. If the stripped tab name changes, for example after sesh here or a manual tab rename, the plugin treats the new name as authoritative. Idle status renames the tab back to that stored base name plus ✓.
Status Markers
Use a Nerd Font marker preset with:
OPENCODE_ZELLIJ_STATUS_STYLE=nerdThe Nerd Font preset is:
| State | Marker |
| --- | --- |
| idle/default | |
| busy | |
| retry | |
| waiting/question | |
| error | |
Override individual markers with:
OPENCODE_ZELLIJ_STATUS_IDLE=""
OPENCODE_ZELLIJ_STATUS_BUSY=""
OPENCODE_ZELLIJ_STATUS_RETRY=""
OPENCODE_ZELLIJ_STATUS_WAITING=""
OPENCODE_ZELLIJ_STATUS_ERROR=""Per-marker overrides win over the preset. The plugin strips both default and Nerd Font markers from the current tab name before storing the base name, so switching styles does not permanently bake the old marker into the tab name.
Zellij tab names are plain text, so this plugin cannot make one marker glyph larger than the rest of the tab label. Marker size comes from your terminal font, font fallback, and any zjstatus tab styling. Use zjstatus colors, bold text, backgrounds, or a wider custom marker if you want the status to stand out more.
Desktop Notifications
macOS desktop notifications are disabled by default. Enable them with:
OPENCODE_ZELLIJ_NOTIFY_DESKTOP=1When enabled, attention-worthy events run:
osascript -e 'display notification ... with title "OpenCode"'Notifications are only sent for session.idle, retry, error, permission, and question events. When the current Zellij tab can be resolved, the notification body is prefixed with the base tab name, for example:
OpenCode Zellij Status: task completeZellij Details
The plugin finds the current tab by reading pane metadata:
zellij action list-panes --json --tab --command --stateIt matches the current OpenCode process using ZELLIJ_PANE_ID, then renames the owning tab:
zellij action rename-tab-by-id <tab_id> "<base tab name> ●"No custom Zellij WASM plugin is required.
zjstatus
zjstatus is recommended as the visual tab bar layer if you want a polished tab display, but it is not the status transport for v1. The plugin does not send zjstatus::pipe::pipe_opencode messages.
If you already use zjstatus, no special OpenCode pipe widget is needed. Make sure your tab format displays the tab name so the suffix is visible. A minimal tab-bar-oriented example:
layout {
default_tab_template {
children
pane size=1 borderless=true {
plugin location="https://github.com/dj95/zjstatus/releases/latest/download/zjstatus.wasm" {
format_left "{tabs}"
format_right "{mode}"
tab_normal "#[fg=#6C7086] {name} "
tab_active "#[fg=#89B4FA,bold] {name} "
}
}
}
}Add this to a Zellij layout, such as ~/.config/zellij/layouts/default.kdl. If you already have a default_tab_template or zjstatus config, merge the format_left and tab_* pieces rather than replacing your whole layout.
Design Notes
- This is a focused OpenCode plugin, not a custom Zellij WASM plugin.
- It does not adopt
opencode-zellijwholesale. - It does not track todo counts in the first version.
- It fails silently when
zellijorosascriptis unavailable.
Future Ideas
- Port/status display.
- Branch or worktree display.
- Richer agent status.
- Integration with
sesh. - Optional
zjstatuspipe integration if tab suffixes are not enough.
