From e1aed0cd01d23e433519621f8d21c0a8ffa3977d Mon Sep 17 00:00:00 2001 From: Adam <2363879+adamdotdevin@users.noreply.github.com> Date: Fri, 31 Oct 2025 13:40:20 -0500 Subject: [PATCH] wip: desktop work --- .../src/components/message-progress.tsx | 86 ++++++++++++------- packages/desktop/src/pages/index.tsx | 20 +++-- 2 files changed, 69 insertions(+), 37 deletions(-) diff --git a/packages/desktop/src/components/message-progress.tsx b/packages/desktop/src/components/message-progress.tsx index f77e196b..fd66c5ca 100644 --- a/packages/desktop/src/components/message-progress.tsx +++ b/packages/desktop/src/components/message-progress.tsx @@ -1,23 +1,47 @@ -import { For, Match, Switch, createEffect, createMemo, createSignal, onCleanup } from "solid-js" +import { For, JSXElement, Match, Switch, createEffect, createMemo, createSignal, onCleanup } from "solid-js" import { Part } from "@opencode-ai/ui" import { useSync } from "@/context/sync" -import type { AssistantMessage as AssistantMessageType } from "@opencode-ai/sdk" +import type { AssistantMessage as AssistantMessageType, Part as PartType, ToolPart } from "@opencode-ai/sdk" -export function MessageProgress(props: { assistantMessages: () => AssistantMessageType[] }) { +export function MessageProgress(props: { assistantMessages: () => AssistantMessageType[]; done?: boolean }) { const sync = useSync() - const items = createMemo(() => props.assistantMessages().flatMap((m) => sync.data.part[m.id])) + const parts = createMemo(() => props.assistantMessages().flatMap((m) => sync.data.part[m.id])) + const done = createMemo(() => props.done ?? false) + const currentTask = createMemo( + () => + parts().findLast( + (p) => + p && + p.type === "tool" && + p.tool === "task" && + p.state && + "metadata" in p.state && + p.state.metadata && + p.state.metadata.sessionId && + p.state.status === "running", + ) as ToolPart, + ) - const finishedItems = createMemo(() => [ - "", - "", - "Loading...", - ...items().filter( + const eligibleItems = createMemo(() => { + let allParts = parts() + const task = currentTask() + if (task && task.state && "metadata" in task.state && task.state.metadata?.sessionId) { + const messages = sync.data.message[task.state.metadata.sessionId as string]?.filter((m) => m.role === "assistant") + allParts = messages?.flatMap((m) => sync.data.part[m.id]) ?? parts() + } + return allParts.filter( (p) => p?.type === "text" || (p?.type === "reasoning" && p.time?.end) || (p?.type === "tool" && p.state.status === "completed"), - ), + ) + }) + const finishedItems = createMemo<(JSXElement | PartType)[]>(() => [ "", + "", +
Loading...
, + ...eligibleItems(), + ...(done() ? ["", "", ""] : []), ]) const MINIMUM_DELAY = 400 @@ -54,26 +78,28 @@ export function MessageProgress(props: { assistantMessages: () => AssistantMessa > {(part) => { - if (typeof part === "string") return
{part}
- const message = createMemo(() => sync.data.message[part.sessionID].find((m) => m.id === part.messageID)) - return ( -
- - - {(p) => ( -
- )} - - - {(p) => } - - {(p) => } - -
- ) + if (part && typeof part === "object" && "type" in part) { + const message = createMemo(() => sync.data.message[part.sessionID].find((m) => m.id === part.messageID)) + return ( +
+ + + {(p) => ( +
+ )} + + + {(p) => } + + {(p) => } + +
+ ) + } + return
{part}
}}
diff --git a/packages/desktop/src/pages/index.tsx b/packages/desktop/src/pages/index.tsx index 2b723c55..929aeda7 100644 --- a/packages/desktop/src/pages/index.tsx +++ b/packages/desktop/src/pages/index.tsx @@ -583,7 +583,8 @@ export default function Page() { {(message) => { const isActive = createMemo(() => local.session.activeMessage()?.id === message.id) - const [initialized, setInitialized] = createSignal(!!message.summary?.title) + const [titled, setTitled] = createSignal(!!message.summary?.title) + const [completed, setCompleted] = createSignal(!!message.summary?.body) const [expanded, setExpanded] = createSignal(false) const parts = createMemo(() => sync.data.part[message.id]) const title = createMemo(() => message.summary?.title) @@ -597,11 +598,16 @@ export default function Page() { const hasToolPart = createMemo(() => assistantMessages() ?.flatMap((m) => sync.data.part[m.id]) - .some((p) => p.type === "tool"), + .some((p) => p?.type === "tool"), ) const working = createMemo(() => !summary()) + + // allowing time for the animations to finish createEffect(() => { - setTimeout(() => setInitialized(!!title()), 10_000) + setTimeout(() => setTitled(!!title()), 10_000) + }) + createEffect(() => { + setTimeout(() => setCompleted(!!summary()), 3_000) }) return ( @@ -613,7 +619,7 @@ export default function Page() { {/* Title */}
- }> + }>

{title()}

@@ -684,10 +690,10 @@ export default function Page() { {/* Response */}
- - + + - +