--- title: Task --- ```js import {API} from "../components/config.js"; import {fieldRow} from "../components/field-help.js"; ``` ```js const taskId = observable.params.id; const raw = await fetch(`${API}/tasks/${taskId}`) .then(r => r.ok ? r.json() : r.json().then(e => ({error: e.detail ?? `HTTP ${r.status}`}))) .catch(e => ({error: String(e)})); ``` ```js if (raw.error) { display(html`
⚠️ ${raw.error}
`); } else { const name = raw.title || taskId; const shortName = name.length > 60 ? name.slice(0, 60) + "…" : name; display(html`

Task · ${shortName}

`); display(html`

← Tasks  |  ← Token Cost

`); const FIELD_ORDER = [ "id","title","status","priority","assignee", "workstream_id","due_date","needs_human","intervention_note", "created_at","updated_at", ]; const rows = FIELD_ORDER.map(k => fieldRow(k, raw[k] ?? null)); for (const k of Object.keys(raw)) { if (!FIELD_ORDER.includes(k)) rows.push(fieldRow(k, raw[k])); } display(html`${rows}
`); } ```