## 作成 LocalTicketBackend によって作成されました。 --- ## Intake summary `yoi panel` の View item / row をマウスクリックでアプリ内選択できるようにする Ticket として materialize した。参考 UX は `./ghq.local/github.com/anomalyco/opencode` の OpenCode TUI selection/dialog/autocomplete 系。ratatui では DOM-like handler ではなく、描画時の item rect registry と `MouseEvent { column, row }` hit-test が有力。MVP は click/down による selection のみで、Queue/Open/Close 等の workflow action 即時実行、汎用 drag/text selection、single-Pod history block focus は範囲外。既存 composer 入力優先、selected-Pod direct-send 非復活、least-intrusive mouse capture 方針を invariant とする。 --- ## State changed 要件、受け入れ条件、binding invariants、OpenCode 参考、実装裁量、escalation conditions、validation が整理され、Orchestrator が routing 可能な状態になったため ready にする。 --- ## State changed Ticket を `workspace-panel` が queued にしました。 --- ## Decision Routing decision: implementation_ready Reason: - Ticket は `queued` で、要件・受け入れ条件・binding invariants・implementation latitude・escalation conditions が揃っている。 - `TicketRelationQuery` と `TicketOrchestrationPlanQuery` で blocker / ordering / conflict 記録は見つからなかった。 - risk flags は `tui-input` / `mouse-capture` / `panel-ux` だが、Ticket は mouse capture 方針、click-only MVP、destructive action 非実行、composer 入力優先を binding invariant として明記しており、実装前に不足する設計判断はない。 - 現 Orchestrator worktree は clean。root/original workspace では git/read/write/validate せず、実装は専用 child worktree に隔離する。 - 併走候補のうち `00001KV0723PC` は同じ `crates/tui/src/multi_pod.rs` 周辺に触れる可能性が高いため、こちらの panel mouse selection を先に受理し、Quit 遅延 Ticket は queued のまま conflict/capacity 待ちにする。`00001KV04NJ8D` は single-Pod rewind / Pod protocol 周辺で主な変更面が異なるため並列開始候補にできる。 Evidence checked: - Ticket body / thread / artifacts(artifacts なし)。 - relation records: なし。 - orchestration plan records: なし。 - code map: `crates/tui/src/multi_pod.rs` の panel selection state / keyboard handling / draw paths、`crates/tui/src/workspace_panel.rs` の ViewModel / row data、既存 `EnableWheelMouseCapture` 方針は `crates/tui/src/single_pod.rs` にあることを確認。 - related context: composer 入力優先、Panel selected-row actionbar 方針、least-intrusive mouse capture 方針は Ticket に binding invariant として反映済み。 - workspace/Pod state: Orchestrator worktree clean、visible live implementation Pods なし。 IntentPacket: Intent: - `yoi panel` の View item / row をマウスクリックでアプリ内選択できるようにし、クリック後の selected row に既存の blank Enter / actionbar / detail 表示が働くようにする。 Binding decisions / invariants: - 対象は workspace Panel/View item selection に限定する。single-Pod conversation history 全体の block focus / navigation mode は実装しない。 - マウス操作で selected-Pod direct-send semantics を復活させない。 - composer text entry と既存 keyboard 操作を優先し、`↑` / `↓` / Enter / Esc / Tab の意味を壊さない。 - クリックは selection のみで、Queue / Open / Close などの workflow state mutation / destructive action を即時実行しない。 - 汎用 drag/text selection は作らない。 - `?1000h` + `?1006h` の least-intrusive mouse capture 方針を優先し、drag tracking を有効化して端末選択への副作用を増やさない。 Requirements / acceptance criteria: - Panel 表示中に View item / row をクリックすると対応 item が selected になる。 - item 外クリックでは不正な selection change や composer draft loss が起きない。 - selected item に対する既存 action / blank Enter / detail 表示がクリック後の selection に対して働く。 - existing keyboard/composer behavior を維持する。 - focused tests で row hit testing / click selection / non-row click no-op / keyboard preservation を確認する。 Implementation latitude: - render 時の row rect registry、row coordinate mapping、hit-test helper の具体設計は coder が選んでよい。 - MVP は click/down による Panel rows selection でよい。詳細 pane 内の個別要素クリックや hover selection は必須ではない。 - 外部 crate は不要なら入れない。既存 Panel 構造を大きく歪める外部 crate 導入は escalation する。 Escalate if: - mouse capture が端末通常選択・貼り付け・wheel・IME・composer 入力へ副作用を出す場合。 - click selection と Enter / blank composer / Queue/Open/Close の境界が曖昧になる場合。 - Panel 以外の view、single-Pod block focus、drag selection へ範囲が広がる場合。 - hit testing のために大きな描画アーキテクチャ変更が必要になる場合。 Validation: - focused `cargo test -p tui workspace_panel --lib` または該当 `multi_pod` / workspace panel tests。 - `cargo fmt --check`。 - `git diff --check`。 - 変更範囲に応じて `cargo check --workspace --all-targets`。 Current code map: - `crates/tui/src/multi_pod.rs`: panel event handling、`selected_row`、visible rows、draw/hotkey/action path、tests。 - `crates/tui/src/workspace_panel.rs`: `WorkspacePanelViewModel` / `PanelRowKey` / row data。 - `crates/tui/src/single_pod.rs`: existing narrow mouse capture implementation as reference only。 Critical risks / reviewer focus: - click must select only, not execute workflow actions。 - item 外 click must be no-op for selection and must not drop composer draft。 - keyboard/composer target semantics must remain unchanged。 - mouse capture must remain least-intrusive and not enable drag tracking unnecessarily。 --- ## State changed Ticket evidence、relations、orchestration plan、bounded code map、Orchestrator worktree clean state を確認した。blocking relation はなく、Panel mouse selection の binding invariants と acceptance criteria は実装可能な粒度で記録済み。実装 side effect の前に routing decision / IntentPacket / accepted plan を記録したため、専用 child worktree と Coder delegation に進む。 --- ## Implementation report Implementation handoff started. - Worktree: `/home/hare/Projects/yoi/.worktree/panel-mouse-selection` - Branch: `ticket-00001KV072V89-panel-mouse-selection` - Coder Pod: `coder-00001KV072V89-panel-mouse` - Scope: child worktree read, `crates/tui` write, this Ticket record write。`.yoi/memory` や local/runtime/log/lock/secret-like `.yoi` paths は write scope に含めていない。 - Note: 初回 SpawnPod は runtime launch validation が workspace root `/home/hare/Projects/yoi` の readable grant を要求して失敗したため、非再帰 read grant のみ追加して再実行した。Coder には root/original workspace を inspect/write/git/validate/merge/cleanup しないよう明示済み。 Next: - Coder の commit / implementation_report / validation evidence を確認後、Reviewer を read-only 基本で起動する。 --- ## Implementation report Implementation report for Ticket 00001KV072V89 Summary: - Added panel row mouse hit testing in `crates/tui/src/multi_pod.rs` by recording selectable row rectangles during list rendering. - Handled left mouse button down events as selection-only operations for ticket/pod rows; non-row clicks are no-ops and diagnostic popups ignore clicks behind them. - Kept action execution on existing keyboard/action paths: clicked rows feed existing selected row behavior, including blank Enter, actionbar target status, and row detail selection. - Added focused tests for row hit testing, click selection, non-row click no-op/draft preservation, and composer/keyboard behavior preservation after click selection. Validation: - `cargo fmt -p tui` — passed. - `cargo fmt --check` — passed. - `cargo test -p tui mouse_ --lib` — passed (4 tests; includes the focused mouse tests plus existing wheel capture test matching the filter). - `cargo test -p tui row_hit_testing_maps_only_visible_selectable_rows --lib` — passed. - `cargo check -p tui --all-targets` — passed. - `git diff --check` — passed. - Additional broader check: `cargo test -p tui multi_pod --lib` ran; 85 tests passed and 1 existing/unrelated test failed (`multi_pod::tests::orchestrator_launch_context_uses_orchestration_root_for_runtime_workspace`, expected orchestration root vs `/repo/yoi`). The failure is outside the panel mouse selection change area. Commit: - `452c9df1` (`tui: select panel rows by mouse`) Residual risks: - Hit boxes are tied to the last rendered list area. This matches the current draw/event loop model; resize events trigger redraw, but stale hit boxes before the first draw would be ignored/empty. - MVP intentionally handles left-button down only; hover, release-to-action, detailed pane clicks, and drag/text selection remain out of scope. --- ## Review: approve Approve. Evidence: - Reviewed Ticket 00001KV072V89 and diff `20daae0c..HEAD` in `/home/hare/Projects/yoi/.worktree/panel-mouse-selection`. - Implementation adds a bounded `PanelRowHitBox` hit-test cache from the rendered list area and only handles primary-button `MouseEventKind::Down`; non-row/list-empty clicks return no selection change. - Click handling calls `select_panel_key` only. I found no mouse path invoking Queue/Open/Close, ticket lifecycle mutation, Pod attach/open, or destructive workflow actions. - Existing keyboard/composer paths remain the execution/action paths: blank Enter/actionbar/detail display consume the selected row after selection; text input, arrows, Enter, Esc, and Tab behavior is still handled by the existing key handlers. - Modal/diagnostic state is guarded by `panel_diagnostic_open`, so background row clicks do not change selection while diagnostics are shown. - Mouse terminal mode remains the existing least-intrusive normal mouse + SGR setup (`?1000h` + `?1006h` via the local narrow capture command), with no drag-capture mode added. - Tests added/updated cover row hit testing for visible selectable rows, left-click selection feeding existing blank-Enter behavior, non-row no-op/preserved draft, and keyboard/composer preservation; the no-Queue/Open/Close guarantee is enforced by the mouse handler only selecting rows and leaving action dispatch on existing key/action paths. Validation performed: - `cargo test -p tui mouse_ --lib` — passed. - `cargo test -p tui row_hit_testing_maps_only_visible_selectable_rows --lib` — passed. - `cargo fmt --check` — passed. - `git diff --check 20daae0c..HEAD` — passed. Risks / notes: - I did not run the broader `cargo test -p tui multi_pod --lib` suite because the requested focused coverage passed and that broader suite was noted as having a likely unrelated existing failure. --- ## Implementation report Integration outcome: merged and validated. - Implementation branch: `ticket-00001KV072V89-panel-mouse-selection` - Implementation commits: `452c9df1 tui: select panel rows by mouse`, `c96a6c46 ticket: report panel mouse implementation` - Review commit: `6c7385e5 ticket: approve panel mouse selection` - Orchestrator merge commit: `02311883 merge: panel mouse selection` Reviewer result: - `approve`。Panel row hit-test cache、left-click selection-only path、non-row no-op / composer draft preservation、diagnostic guard、least-intrusive mouse capture、keyboard/composer preservation を確認済み。 Orchestrator validation after merge: - `cargo test -p tui mouse_ --lib`: PASS(4 tests) - `cargo test -p tui row_hit_testing_maps_only_visible_selectable_rows --lib`: PASS(1 test) - `cargo fmt --check`: PASS - `git diff --check`: PASS - `cargo check -p tui --all-targets`: PASS Residual notes: - Broad `cargo test -p tui multi_pod --lib` は child validation で既知 unrelated failure があるため、Orchestrator validation では focused tests と `cargo check -p tui --all-targets` を採用した。 - Click は selection のみで、Queue/Open/Close など workflow action は既存 key/action path に残っている。 Next: - Ticket を `done` に遷移し、panel mouse child Pods / worktree / branch を cleanup する。close は別途明示権限がある場合に行う。 --- ## State changed Implementation branch `ticket-00001KV072V89-panel-mouse-selection` was reviewed, approved, merged into the Orchestrator branch as `02311883`, and validated in the Orchestrator worktree. Focused mouse-selection tests, formatting, diff check, and `cargo check -p tui --all-targets` passed. Ticket implementation work is done; closure remains separate. ---