- INTENT.md: declare umbrella as the home for shared contracts; document umbrella-first MVP decision (code lives here until subsystems stabilize) - wiki/SharedContracts.md: vocabulary, state enums, relation types, selector taxonomy, event vocabulary, viewer adapter contract, canonical text normalization, rect-registry contract - wiki/DependencyMap.md: allowed dependency edges; folder layout + lint-rule strategy during umbrella-first phase - history/2026-05-24-initial-assessment.md: alignment review, technical risks, and the umbrella-first pivot rationale - workplans/CE-WP-0001..0004: four ralph-compatible workplans covering foundations, PDF review slice, form binding + visual guide, and citation card export — implementing PRD §20 end-to-end Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
7.1 KiB
id, type, title, domain, repo, repo_id, status, owner, created, updated, depends_on_workplan, spec_refs
| id | type | title | domain | repo | repo_id | status | owner | created | updated | depends_on_workplan | spec_refs | |||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| CE-WP-0003 | workplan | Form binding + visual guide — EvidenceLink, rect registry, SVG overlay | citation_evidence | citation-evidence | a677c189-b4e2-4f2a-9e48-faa482c277e6 | todo | Bernd | 2026-05-24 | 2026-05-24 | CE-WP-0002 |
|
CE-WP-0003 — Form Binding + Visual Guide
Build the evidence-backed form mode and the SVG visual guide overlay. After this workplan, a user can:
- Open a form next to the document viewer.
- Drag (or click-to-link) an evidence item from the sidebar onto a form field.
- Click a form field → its linked evidence items appear → the active evidence's source passage is scrolled into view and highlighted → an SVG guide visually connects the field, the evidence card, and the highlight.
- Cycle through multiple evidence items on the same field.
This is the workplan that stress-tests the rect-registry contract from
wiki/SharedContracts.md §7. The form, the evidence card, and the viewer's
highlight all need to publish rects to a single overlay that re-renders on
scroll/resize/focus.
Dependency Order
T01 (EvidenceLink + EvidenceSet types + relation/status enums)
└─ T02 (binding service + in-memory link repo + active-state machine)
└─ T03 (rect registry — the contract from SharedContracts.md §7)
└─ T04 (form schema + simple field renderer)
└─ T05 (side-by-side layout + drag-or-click to link)
└─ T06 (active-evidence cycling on a field)
└─ T07 (SVG visual guide overlay)
└─ T08 (E2E test of PRD scenario steps 5-9)
T01 — EvidenceLink + EvidenceSet types
id: CE-WP-0003-T01
priority: critical
status: todo
Add under src/shared/:
src/shared/evidence-link.ts—EvidenceLink,EvidenceLink.statusenum per SharedContracts §2.4,EvidenceLink.relationenum per §2.5,EvidenceTargetgeneric shapesrc/shared/evidence-set.ts—EvidenceSetwithactiveEvidenceItemId
No services. Pure shapes.
Add a unit test asserting that the union of all enum values matches the
SharedContracts.md lists exactly — if someone adds a value without
updating the doc, the test fails.
T02 — Binding service + in-memory link repo + active-state machine
id: CE-WP-0003-T02
priority: high
status: todo
depends_on: [T01]
Under src/binder/:
repos/in-memory-links.ts— Map-backedEvidenceLinkRepositoryservices/bindings.ts—linkEvidenceToTarget,unlinkEvidence,listEvidenceForTarget,setActiveEvidencestate/active.ts— a small machine tracking(activeTarget, activeEvidenceItem, activeAnnotation). Exposed as a React context.
Emit the events from SharedContracts §4 (EvidenceLinkCreated,
EvidenceItemActivated, FormFieldActivated).
T03 — Rect registry (the SharedContracts §7 contract)
id: CE-WP-0003-T03
priority: critical
status: todo
depends_on: [T02]
Implement under src/binder/visual-guide/:
rect-registry.ts—RectRegistrywithregister,getRect,subscribeper SharedContracts §7react-hooks.ts—useRegisterRect(kind, id, ref)for components to register a ref-derived rectevents.ts— registry emitsrect-changedevents on scroll/resize/focus/active-evidence-change (use ResizeObserver + IntersectionObserver + window resize + window scroll listeners)
Unit tests: register a fake field, evidence card, and highlight; mutate their bounding rects; assert subscribers fire with the new rects.
This contract must not change after T03. Three subsystems will depend on it in T05/T06/T07.
T04 — Form schema + simple field renderer
id: CE-WP-0003-T04
priority: medium
status: todo
depends_on: [T01]
A deliberately minimal form schema lives in src/app/forms/demo-schema.ts:
type FormFieldSchema =
| { type: "text"; id: string; label: string }
| { type: "textarea"; id: string; label: string }
| { type: "date"; id: string; label: string };
JSON Schema is not used yet — defer that to a later ADR. The MVP form just needs to render 3-4 fields and accept evidence links.
src/work/FormRenderer.tsxrenders the schema as a basic form- Each field registers itself with the rect registry as kind
"field"with the field'sid
T05 — Side-by-side layout + link evidence to field
id: CE-WP-0003-T05
priority: high
status: todo
depends_on: [T02, T04]
A new app route /forms/demo shows the side-by-side layout from Architecture
§12.2:
- Left:
FormRendererwith a demo schema (3 fields) - Right: viewer (reusing
ViewerShellfrom CE-WP-0002) - Bottom strip or popover: evidence list
Linking interaction: click an evidence item, then click a field → link created. (Drag-and-drop is a polish item, not MVP.) Visual indication on linked fields (e.g. a chip showing the count of linked evidence items).
T06 — Active-evidence cycling on a field
id: CE-WP-0003-T06
priority: high
status: todo
depends_on: [T05]
When a field is focused:
- Binder loads the field's evidence set.
- The first evidence item becomes active.
- The viewer scrolls to and highlights its annotation.
- Keyboard
Tab/Shift-Tabwithin the field's evidence chips cycles active evidence; viewer scrolls accordingly. - The evidence sidebar highlights the active evidence card.
Each evidence card registers itself with the rect registry as
"evidence-card".
T07 — SVG visual guide overlay
id: CE-WP-0003-T07
priority: high
status: todo
depends_on: [T03, T06]
Implement src/binder/visual-guide/Overlay.tsx:
- Single absolutely-positioned SVG covering the viewport
- Subscribes to the rect registry
- On every change, redraws two curves:
field → evidence-cardandevidence-card → highlight - Active-only — only the currently active triple gets drawn
- Throttled to animation frames
Acceptance: scroll the viewer, resize the window, change active evidence — the guide tracks every change without visible lag.
The viewer adapter from CE-WP-0002 must expose
getHighlightClientRects(annotationId) so the highlight's rect can be
registered.
T08 — E2E test of PRD scenario steps 5-9
id: CE-WP-0003-T08
priority: high
status: todo
depends_on: [T05, T07]
Extend the Playwright E2E from CE-WP-0002-T09:
- Navigate to
/forms/demo. - Link the previously-created evidence item to the "summary" field.
- Click the "summary" field.
- Assert the field, the evidence card, and the highlight all have an
aria-current="true"(or equivalent active marker). - Assert the SVG overlay contains exactly two
<path>elements (one field→card, one card→highlight). - Scroll the viewer; assert the SVG paths' endpoints update within the next animation frame.
If this passes, the form-binding slice is complete and CE-WP-0004 may run in parallel with any deferred polish work.