yoi/.yoi/tickets/00001KTJ4QFP0/item.md

85 lines
5.1 KiB
Markdown

---
title: "Replace Ticket intake state with planning state"
state: "closed"
created_at: "2026-06-07T22:54:48Z"
updated_at: "2026-06-08T10:19:05Z"
queued_by: "workspace-panel"
queued_at: "2026-06-08T08:35:07Z"
---
## Background
The Ticket workflow state `intake` is currently used for more than initial intake. It also represents clarification, requirements synchronization, and preflight/planning work before a Ticket is implementation-ready.
This naming is misleading in panel/orchestration flows:
- A Ticket can be returned from Orchestrator routing because implementation requires preflight or requirements clarification.
- Such a Ticket should go back to the planning/clarification lane, not appear as a brand-new intake item.
- Current Orchestrator `preflight_needed` behavior can look like nothing happened because it may only comment and avoid starting coder Pods.
- Users need a visible state/action that says the Ticket is under planning / needs planning work.
Desired direction:
- Remove `intake` as the user-facing workflow state name.
- Replace it with a planning-oriented state such as `planning` or `under_planning`.
- Orchestrator `preflight_needed` / requirements-sync-needed routing should return the Ticket to this planning state and notify any active Intake/Planning Pod if one exists.
## Goal
Rename/reframe Ticket `workflow_state = intake` into a planning-oriented state and make Orchestrator preflight-needed routing visibly return Tickets to that lane instead of silently stalling.
## Requirements
### State model / migration
- Replace `intake` in the Ticket workflow-state model with a planning-oriented state name.
- Candidate names: `planning`, `under_planning`, or another concise name chosen during implementation.
- Prefer a name that communicates requirements clarification / preflight preparation, not only initial intake.
- Define migration behavior for existing Tickets with `workflow_state: intake`.
- Either migrate records to the new value or support legacy `intake` as an input alias with normalized output.
- Update typed transition graph accordingly.
- Existing start path becomes `planning -> ready -> queued -> inprogress -> done`.
- Allow Orchestrator to route `queued` or `ready` back to `planning` when preflight/requirements sync is needed, with a reason.
- Update CLI, Ticket tools, TUI panel, prompts, workflow docs, and tests that refer to `intake` as a workflow state.
- Keep the Intake role name separate if still useful for the Pod/persona; this ticket is about workflow state naming and lane semantics.
### Orchestrator preflight-needed behavior
- When Orchestrator determines `preflight_needed` or requirements-sync-needed:
- Do not start coder Pods.
- Record a typed routing/state-change event with a clear reason.
- Return the Ticket to the planning state, or otherwise ensure the planning lane visibly owns it.
- Surface the reason in Panel/Ticket UI so the user can see why implementation did not start.
- If a live/restorable Intake/Planning Pod claim exists for that Ticket, notify/send it the routing-back reason and requested planning/preflight action.
- If no such Pod exists, Panel should show that planning/clarification/preflight attention is needed and provide the existing launch path.
- Preserve auditability: the state transition and reason must be recorded in Ticket files/thread.
### UI / terminology
- Replace user-facing `intake` workflow-state labels in Panel and docs with the chosen planning-oriented label.
- Clarify that this lane covers:
- initial Ticket clarification;
- requirements synchronization;
- preflight preparation;
- Orchestrator return-to-planning decisions.
- Avoid confusing `Intake` role/profile naming with the workflow state if the role remains named Intake.
## Non-goals
- Do not redesign the entire Ticket workflow state machine beyond replacing/reframing `intake` and adding return-to-planning behavior.
- Do not remove the Intake Pod role/profile unless a separate decision is made.
- Do not implement arbitrary role registries.
- Do not change implementation worktree/coder/reviewer mechanics except where Orchestrator routing needs to return to planning.
## Acceptance criteria
- New/updated Tickets use the planning-oriented workflow-state name instead of `intake`.
- Existing `workflow_state: intake` Tickets are migrated or parsed compatibly and emitted in the new form according to the chosen policy.
- Panel no longer presents the state as simply `intake`; it shows planning/clarification/preflight terminology.
- Orchestrator `preflight_needed` routing produces a visible state/typed event and returns the Ticket to the planning lane.
- A claimed live/restorable Intake/Planning Pod is notified when Orchestrator returns a Ticket for planning/preflight.
- Without a claimed Pod, Panel clearly shows planning/preflight attention is needed and provides a launch path.
- Tests cover state parsing/migration, transition graph, Panel action derivation, and Orchestrator return-to-planning behavior.
- Relevant docs/workflows are updated.
- `target/debug/yoi ticket doctor`, focused `cargo test` suites, `cargo fmt --check`, and `git diff --check` pass.