diff --git a/src/core/task/Task.ts b/src/core/task/Task.ts index a6a9d89986..3d63b1698b 100644 --- a/src/core/task/Task.ts +++ b/src/core/task/Task.ts @@ -1417,10 +1417,15 @@ export class Task extends EventEmitter { // cancel task. this.abortTask() - await abortStream( - "streaming_failed", - error.message ?? JSON.stringify(serializeError(error), null, 2), - ) + // Check if this was a user-initiated cancellation + // If this.abort is true, it means the user clicked cancel, so we should + // treat this as "user_cancelled" rather than "streaming_failed" + const cancelReason = this.abort ? "user_cancelled" : "streaming_failed" + const streamingFailedMessage = this.abort + ? undefined + : (error.message ?? JSON.stringify(serializeError(error), null, 2)) + + await abortStream(cancelReason, streamingFailedMessage) const history = await provider?.getTaskWithId(this.taskId)