Lipstick for your OpenCode TUI.
@skwid138/opencode-tui is a configurable OpenCode TUI plugin that replaces the home screen logo and prompt placeholders with friendlier defaults. Use it as-is, customize ASCII logo rows with per-segment inline colors, swap prompt suggestions for normal and shell modes, or disable either section independently while invalid config safely falls back to defaults.
Install the package:
npm install @skwid138/opencode-tuiAdd the TUI entry to your OpenCode plugin configuration using the package's TUI export:
- Custom ASCII logos made from rows of inline text segments.
- Per-segment logo colors using 3- or 6-digit hex values.
- Prompt placeholder customization for normal and shell modes.
- Disable logo or prompt customization independently.
- Graceful fallback to defaults when config is invalid.
- Companion Logo Builder web app for generating
logo.rowsconfig.
Use the default JustVibes logo and default prompt placeholders:
{
"plugin": ["@skwid138/opencode-tui/tui"]
}Plugin options are registered as a tuple: ["@skwid138/opencode-tui/tui", { config }].
Disable only the logo:
{
"plugin": [
["@skwid138/opencode-tui/tui", { "logo": false }]
]
}Disable only the prompt override:
{
"plugin": [
["@skwid138/opencode-tui/tui", { "prompt": false }]
]
}Disable both sections:
{
"plugin": [
["@skwid138/opencode-tui/tui", { "logo": false, "prompt": false }]
]
}{
"plugin": [
[
"@skwid138/opencode-tui/tui",
{
"prompt": {
"placeholders": {
"normal": [
"Build a dashboard for my team",
"Refactor this component",
"Help me debug this error"
],
"shell": [
"List files by size",
"Show current git status"
]
}
}
}
]
]
}Each row contains literal pre-rendered ASCII text segments. Segment color is an inline 3- or 6-digit hex string including #.
{
"plugin": [
[
"@skwid138/opencode-tui/tui",
{
"logo": {
"rows": [
{
"segments": [
{ "text": "Open", "color": "#5DBDB3" },
{ "text": "Code", "color": "#F8B4C4" }
]
}
]
}
}
]
]
}| Option | Type | Default | Description |
|---|---|---|---|
logo |
false | LogoConfig |
default logo | Set to false to leave home_logo untouched. |
logo.rows |
Array<{ segments: Array<{ text: string; color: string }> }> |
JustVibes ASCII art | Logo rows rendered as horizontal text segments. Segment colors must match #RGB or #RRGGBB. Empty arrays fall back to defaults. |
prompt |
false | PromptConfig |
default prompt | Set to false to leave home_prompt untouched. |
prompt.placeholders.normal |
string[] |
11 default ideas | Suggestions for normal prompt mode. Empty arrays fall back to defaults. |
prompt.placeholders.shell |
string[] |
3 default shell ideas | Suggestions for shell prompt mode. Empty arrays fall back to defaults. |
Invalid sections are isolated: a bad logo config falls back to the default logo without breaking prompt customization, and a bad prompt config falls back without breaking the logo. Validation never throws; warnings are logged and surfaced through the OpenCode toast API when available.
Use the companion Logo Builder app to generate custom logo.rows config: https://skwid138.github.io/opencode-logo-builder/. The companion repo lives at https://github.com/skwid138/opencode-logo-builder.
Install dependencies:
npm installRun tests:
npm testRun tests with coverage:
npm run test:coverageType-check:
npm run typecheckBuild the package:
npm run buildThe build emits ESM artifacts and declaration files into dist/.
This repo uses Conventional Commits. A local
husky hook runs
commitlint on every commit, and PR titles are validated
by GitHub Actions (.github/workflows/pr-title.yml) since this repo squash-merges
with the PR title as the commit subject.
Allowed types: feat, fix, perf, refactor (patch), docs, chore, ci,
style, test, build, revert.
Notes:
- Use
git commit --no-verifyto bypass the hook in unusual cases (e.g. WIP commits you'll squash later). - A
BREAKING CHANGE:footer in the commit body triggers a major release regardless of the type prefix — use deliberately. - The conventional prefix governs the release type, but the human is responsible for
matching prefix to actual change (a
feat:whose diff is a README typo will still publish a minor release).
MIT © Spencer Miller
{ "plugin": ["@skwid138/opencode-tui/tui"] }