5.4 KiB
5.4 KiB
| title | state | created_at | updated_at | assignee | readiness | risk_flags | queued_by | queued_at | ||
|---|---|---|---|---|---|---|---|---|---|---|
| Improve workspace panel display and composer key handling | queued | 2026-06-09T08:47:25Z | 2026-06-09T10:03:41Z | null | implementation_ready |
|
workspace-panel | 2026-06-09T10:01:08Z |
Background
yoi panel のトップ行と actionbar に Ctrl+T の操作ヒントが表示されているが、Panel 表示として目立たせる必要が薄く、情報密度も上げている。
また、Panel composer の入力操作が通常のチャット UI / event view TUI composer と一部異なっている。観測された例として、Ctrl+Left / Ctrl+Right による単語単位カーソル移動が Panel composer では効かない。現在は InputBuffer など低レベルの composer 実装は共有されている一方、key handling dispatcher は通常チャット UI と Panel で分かれており、Panel 側が composer editing keymap を十分に共有していない。
Panel は workspace / Ticket 操作の入口である一方、composer は通常の TUI 入力欄として期待されるため、表示と操作の両方を整理する。
Requirements
- Panel のトップ行から
Ctrl+T表示を削除する。 - Panel の actionbar / help text から
Ctrl+T表示を削除する。 - Panel の target switching 操作を
Ctrl+TからTabに変更する。 Tabの優先順位は composer completion がある場合は completion を優先し、completion がない Panel 状態では target switching として扱う。- Panel composer の編集操作は、通常チャット UI composer と可能な限り互換にする。
- Panel 側で composer 操作を再実装して乖離を増やすのではなく、既存 composer 入力処理・keymap・action model を共有または抽象化し、互換性を維持しやすい構造にする。
- bare letter shortcuts を復活させない。通常の文字入力は composer text として扱う既存方針を維持する。
Acceptance criteria
yoi panelのトップ行にCtrl+Tが表示されない。- Panel の actionbar / help text に
Ctrl+Tが表示されない。 - Panel で
Tabにより target switching ができる。 - Panel に completion popup / completion state がある場合、
Tabは target switching より completion 操作を優先する。 - Panel composer で、通常チャット UI composer と同等の主要編集操作が動作する。
- 例: 左右移動、行頭/行末移動、削除、履歴操作、
Ctrl+Left/Ctrl+Right等の単語単位移動。
- 例: 左右移動、行頭/行末移動、削除、履歴操作、
- terminal / backend が特定 key sequence を送らない場合は、その制約を壊れた実装と誤認しない範囲で扱う。
- Panel 専用の ad-hoc composer key handling が増えず、通常 composer との互換性を保ちやすい実装になっている。
nix build .#yoiが通る。
Binding decisions / invariants
Ctrl+Tを Panel の表示要素や target switching 操作として使わない。- Panel の target switching shortcut は
Tabとする。 Tabは completion が active な場合、target switching ではなく completion 操作を優先する。- Composer に入力可能な通常文字キーを Panel 操作用 shortcut として奪わない。
- bare
j/k/o/rのような bare letter shortcuts は復活させない。 - Panel composer は通常チャット UI composer と別物として再実装しない。既存 composer 操作との互換性を保つ方向で実装する。
Implementation latitude
- composer 操作の共有方法は実装者が選んでよい。
- 例: composer input handling の共通関数化。
- 例: key event normalization の共有。
- 例: Panel 側を既存 composer action model に寄せる。
- Panel 固有操作は、共通 composer editing layer の上に別レイヤーとして載せてよい。
- トップ行は
Ctrl+T削除に加えて、workspace / Ticket / role Pod 状態の表示を整理してよい。ただしこの Ticket の主目的は大規模な Panel redesign ではない。
Readiness
- readiness: implementation_ready
- risk_flags: [tui-input, ux-consistency]
Escalation conditions
Tabが terminal focus、既存 TUI 操作、accessibility 上の期待、または将来の Panel completion と衝突する場合は、completion 優先の方針を保ったうえで相談する。- 通常チャット UI composer 側にも同じ操作欠落がある場合は、Panel 固有修正ではなく composer 共通改善として扱う。
- key event が terminal / crossterm 側で区別できない場合は、可能な範囲と制約を implementation report に明記する。
Validation
yoi panelを起動し、トップ行と actionbar にCtrl+Tが出ないことを確認する。Tabで Panel target switching ができることを確認する。- completion が active な状態を実装が持つ場合、
Tabが completion を優先することを確認する。 - Panel composer で通常チャット UI composer と同等の主要 key 操作を手動確認する。
nix build .#yoiを実行する。
Related work
20260606-060548-001Workspace panel layout and display tuning20260607-213808-001Remove bare letter shortcuts from workspace panel20260607-001651-002Workspace panel Companion interface20260601-021104-001TUI: persist composer input recall history per workspace