πŸ“„ File detail

components/tasks/BackgroundTasksDialog.tsx

🧩 .tsxπŸ“ 652 linesπŸ’Ύ 116,395 bytesπŸ“ text
← Back to All Files

🎯 Use case

This file lives under β€œcomponents/”, which covers shared React UI pieces. On the API surface it exposes BackgroundTasksDialog β€” mainly types, interfaces, or factory objects. Dependencies touch React UI, bun:bundle, figures, and src. It composes internal code from commands, context, hooks, ink, and keybindings (relative imports).

Generated from folder role, exports, dependency roots, and inline comments β€” not hand-reviewed for every path.

🧠 Inline summary

import { c as _c } from "react/compiler-runtime"; import { feature } from 'bun:bundle'; import figures from 'figures'; import React, { type ReactNode, useEffect, useEffectEvent, useMemo, useRef, useState } from 'react'; import { isCoordinatorMode } from 'src/coordinator/coordinatorMode.js';

πŸ“€ Exports (heuristic)

  • BackgroundTasksDialog

πŸ“š External import roots

Package roots from from "…" (relative paths omitted).

  • react
  • bun:bundle
  • figures
  • src

πŸ–₯️ Source preview

import { c as _c } from "react/compiler-runtime";
import { feature } from 'bun:bundle';
import figures from 'figures';
import React, { type ReactNode, useEffect, useEffectEvent, useMemo, useRef, useState } from 'react';
import { isCoordinatorMode } from 'src/coordinator/coordinatorMode.js';
import { useTerminalSize } from 'src/hooks/useTerminalSize.js';
import { useAppState, useSetAppState } from 'src/state/AppState.js';
import { enterTeammateView, exitTeammateView } from 'src/state/teammateViewHelpers.js';
import type { ToolUseContext } from 'src/Tool.js';
import { DreamTask, type DreamTaskState } from 'src/tasks/DreamTask/DreamTask.js';
import { InProcessTeammateTask } from 'src/tasks/InProcessTeammateTask/InProcessTeammateTask.js';
import type { InProcessTeammateTaskState } from 'src/tasks/InProcessTeammateTask/types.js';
import type { LocalAgentTaskState } from 'src/tasks/LocalAgentTask/LocalAgentTask.js';
import { LocalAgentTask } from 'src/tasks/LocalAgentTask/LocalAgentTask.js';
import type { LocalShellTaskState } from 'src/tasks/LocalShellTask/guards.js';
import { LocalShellTask } from 'src/tasks/LocalShellTask/LocalShellTask.js';
// Type import is erased at build time β€” safe even though module is ant-gated.
import type { LocalWorkflowTaskState } from 'src/tasks/LocalWorkflowTask/LocalWorkflowTask.js';
import type { MonitorMcpTaskState } from 'src/tasks/MonitorMcpTask/MonitorMcpTask.js';
import { RemoteAgentTask, type RemoteAgentTaskState } from 'src/tasks/RemoteAgentTask/RemoteAgentTask.js';
import { type BackgroundTaskState, isBackgroundTask, type TaskState } from 'src/tasks/types.js';
import type { DeepImmutable } from 'src/types/utils.js';
import { intersperse } from 'src/utils/array.js';
import { TEAM_LEAD_NAME } from 'src/utils/swarm/constants.js';
import { stopUltraplan } from '../../commands/ultraplan.js';
import type { CommandResultDisplay } from '../../commands.js';
import { useRegisterOverlay } from '../../context/overlayContext.js';
import type { ExitState } from '../../hooks/useExitOnCtrlCDWithKeybindings.js';
import type { KeyboardEvent } from '../../ink/events/keyboard-event.js';
import { Box, Text } from '../../ink.js';
import { useKeybindings } from '../../keybindings/useKeybinding.js';
import { useShortcutDisplay } from '../../keybindings/useShortcutDisplay.js';
import { count } from '../../utils/array.js';
import { Byline } from '../design-system/Byline.js';
import { Dialog } from '../design-system/Dialog.js';
import { KeyboardShortcutHint } from '../design-system/KeyboardShortcutHint.js';
import { AsyncAgentDetailDialog } from './AsyncAgentDetailDialog.js';
import { BackgroundTask as BackgroundTaskComponent } from './BackgroundTask.js';
import { DreamDetailDialog } from './DreamDetailDialog.js';
import { InProcessTeammateDetailDialog } from './InProcessTeammateDetailDialog.js';
import { RemoteSessionDetailDialog } from './RemoteSessionDetailDialog.js';
import { ShellDetailDialog } from './ShellDetailDialog.js';
type ViewState = {
  mode: 'list';
} | {
  mode: 'detail';
  itemId: string;
};
type Props = {
  onDone: (result?: string, options?: {
    display?: CommandResultDisplay;
  }) => void;
  toolUseContext: ToolUseContext;
  initialDetailTaskId?: string;
};
type ListItem = {
  id: string;
  type: 'local_bash';
  label: string;
  status: string;
  task: DeepImmutable<LocalShellTaskState>;
} | {
  id: string;
  type: 'remote_agent';
  label: string;
  status: string;
  task: DeepImmutable<RemoteAgentTaskState>;
} | {
  id: string;
  type: 'local_agent';
  label: string;
  status: string;
  task: DeepImmutable<LocalAgentTaskState>;
} | {
  id: string;
  type: 'in_process_teammate';
  label: string;
  status: string;
  task: DeepImmutable<InProcessTeammateTaskState>;
} | {
  id: string;
  type: 'local_workflow';
  label: string;
  status: string;
  task: DeepImmutable<LocalWorkflowTaskState>;
} | {
  id: string;
  type: 'monitor_mcp';
  label: string;
  status: string;
  task: DeepImmutable<MonitorMcpTaskState>;
} | {
  id: string;
  type: 'dream';
  label: string;
  status: string;
  task: DeepImmutable<DreamTaskState>;
} | {
  id: string;
  type: 'leader';
  label: string;
  status: 'running';
};

// WORKFLOW_SCRIPTS is ant-only (build_flags.yaml). Static imports would leak
// ~1.3K lines into external builds. Gate with feature() + require so the
// bundler can dead-code-eliminate the branch.
/* eslint-disable @typescript-eslint/no-require-imports */
const WorkflowDetailDialog = feature('WORKFLOW_SCRIPTS') ? (require('./WorkflowDetailDialog.js') as typeof import('./WorkflowDetailDialog.js')).WorkflowDetailDialog : null;
const workflowTaskModule = feature('WORKFLOW_SCRIPTS') ? require('src/tasks/LocalWorkflowTask/LocalWorkflowTask.js') as typeof import('src/tasks/LocalWorkflowTask/LocalWorkflowTask.js') : null;
const killWorkflowTask = workflowTaskModule?.killWorkflowTask ?? null;
const skipWorkflowAgent = workflowTaskModule?.skipWorkflowAgent ?? null;
const retryWorkflowAgent = workflowTaskModule?.retryWorkflowAgent ?? null;
// Relative path, not `src/...` path-mapping β€” Bun's DCE can statically
// resolve + eliminate `./` requires, but path-mapped strings stay opaque
// and survive as dead literals in the bundle. Matches tasks.ts pattern.
const monitorMcpModule = feature('MONITOR_TOOL') ? require('../../tasks/MonitorMcpTask/MonitorMcpTask.js') as typeof import('../../tasks/MonitorMcpTask/MonitorMcpTask.js') : null;
const killMonitorMcp = monitorMcpModule?.killMonitorMcp ?? null;
const MonitorMcpDetailDialog = feature('MONITOR_TOOL') ? (require('./MonitorMcpDetailDialog.js') as typeof import('./MonitorMcpDetailDialog.js')).MonitorMcpDetailDialog : null;
/* eslint-enable @typescript-eslint/no-require-imports */

// Helper to get filtered background tasks (excludes foregrounded local_agent)
function getSelectableBackgroundTasks(tasks: Record<string, TaskState> | undefined, foregroundedTaskId: string | undefined): TaskState[] {
  const backgroundTasks = Object.values(tasks ?? {}).filter(isBackgroundTask);
  return backgroundTasks.filter(task => !(task.type === 'local_agent' && task.id === foregroundedTaskId));
}
export function BackgroundTasksDialog({
  onDone,
  toolUseContext,
  initialDetailTaskId
}: Props): React.ReactNode {
  const tasks = useAppState(s => s.tasks);
  const foregroundedTaskId = useAppState(s_0 => s_0.foregroundedTaskId);
  const showSpinnerTree = useAppState(s_1 => s_1.expandedView) === 'teammates';
  const setAppState = useSetAppState();
  const killAgentsShortcut = useShortcutDisplay('chat:killAgents', 'Chat', 'ctrl+x ctrl+k');
  const typedTasks = tasks as Record<string, TaskState> | undefined;

  // Track if we skipped list view on mount (for back button behavior)
  const skippedListOnMount = useRef(false);

  // Compute initial view state - skip list if caller provided a specific task,
  // or if there's exactly one task
  const [viewState, setViewState] = useState<ViewState>(() => {
    if (initialDetailTaskId) {
      skippedListOnMount.current = true;
      return {
        mode: 'detail',
        itemId: initialDetailTaskId
      };
    }
    const allItems = getSelectableBackgroundTasks(typedTasks, foregroundedTaskId);
    if (allItems.length === 1) {
      skippedListOnMount.current = true;
      return {
        mode: 'detail',
        itemId: allItems[0]!.id
      };
    }
    return {
      mode: 'list'
    };
  });
  const [selectedIndex, setSelectedIndex] = useState<number>(0);

  // Register as modal overlay so parent Chat keybindings (up/down for history)
  // are deactivated while this dialog is open
  useRegisterOverlay('background-tasks-dialog');

  // Memoize the sorted and categorized items together to ensure stable references
  const {
    bashTasks,
    remoteSessions,
    agentTasks,
    teammateTasks,
    workflowTasks,
    mcpMonitors,
    dreamTasks: dreamTasks_0,
    allSelectableItems
  } = useMemo(() => {
    // Filter to only show running/pending background tasks, matching the status bar count
    const backgroundTasks = Object.values(typedTasks ?? {}).filter(isBackgroundTask);
    const allItems_0 = backgroundTasks.map(toListItem);
    const sorted = allItems_0.sort((a, b) => {
      const aStatus = a.status;
      const bStatus = b.status;
      if (aStatus === 'running' && bStatus !== 'running') return -1;
      if (aStatus !== 'running' && bStatus === 'running') return 1;
      const aTime = 'task' in a ? a.task.startTime : 0;
      const bTime = 'task' in b ? b.task.startTime : 0;
      return bTime - aTime;
    });
    const bash = sorted.filter(item => item.type === 'local_bash');
    const remote = sorted.filter(item_0 => item_0.type === 'remote_agent');
    // Exclude foregrounded task - it's being viewed in the main UI, not a background task
    const agent = sorted.filter(item_1 => item_1.type === 'local_agent' && item_1.id !== foregroundedTaskId);
    const workflows = sorted.filter(item_2 => item_2.type === 'local_workflow');
    const monitorMcp = sorted.filter(item_3 => item_3.type === 'monitor_mcp');
    const dreamTasks = sorted.filter(item_4 => item_4.type === 'dream');
    // In spinner-tree mode, exclude teammates from the dialog (they appear in the tree)
    const teammates = showSpinnerTree ? [] : sorted.filter(item_5 => item_5.type === 'in_process_teammate');
    // Add leader entry when there are teammates, so users can foreground back to leader
    const leaderItem: ListItem[] = teammates.length > 0 ? [{
      id: '__leader__',
      type: 'leader',
      label: `@${TEAM_LEAD_NAME}`,
      status: 'running'
    }] : [];
    return {
      bashTasks: bash,
      remoteSessions: remote,
      agentTasks: agent,
      workflowTasks: workflows,
      mcpMonitors: monitorMcp,
      dreamTasks,
      teammateTasks: [...leaderItem, ...teammates],
      // Order MUST match JSX render order (teammates \u2192 bash \u2192 monitorMcp \u2192
      // remote \u2192 agent \u2192 workflows \u2192 dream) so \u2193/\u2191 navigation moves the cursor
      // visually downward.
      allSelectableItems: [...leaderItem, ...teammates, ...bash, ...monitorMcp, ...remote, ...agent, ...workflows, ...dreamTasks]
    };
  }, [typedTasks, foregroundedTaskId, showSpinnerTree]);
  const currentSelection = allSelectableItems[selectedIndex] ?? null;

  // Use configurable keybindings for standard navigation and confirm/cancel.
  // confirm:no is handled by Dialog's onCancel prop.
  useKeybindings({
    'confirm:previous': () => setSelectedIndex(prev => Math.max(0, prev - 1)),
    'confirm:next': () => setSelectedIndex(prev_0 => Math.min(allSelectableItems.length - 1, prev_0 + 1)),
    'confirm:yes': () => {
      const current = allSelectableItems[selectedIndex];
      if (current) {
        if (current.type === 'leader') {
          exitTeammateView(setAppState);
          onDone('Viewing leader', {
            display: 'system'
          });
        } else {
          setViewState({
            mode: 'detail',
            itemId: current.id
          });
        }
      }
    }
  }, {
    context: 'Confirmation',
    isActive: viewState.mode === 'list'
  });

  // Component-specific shortcuts (x=stop, f=foreground, right=zoom) shown in UI.
  // These are task-type and status dependent, not standard dialog keybindings.
  const handleKeyDown = (e: KeyboardEvent) => {
    // Only handle input when in list mode
    if (viewState.mode !== 'list') return;
    if (e.key === 'left') {
      e.preventDefault();
      onDone('Background tasks dialog dismissed', {
        display: 'system'
      });
      return;
    }

    // Compute current selection at the time of the key press
    const currentSelection_0 = allSelectableItems[selectedIndex];
    if (!currentSelection_0) return; // everything below requires a selection

    if (e.key === 'x') {
      e.preventDefault();
      if (currentSelection_0.type === 'local_bash' && currentSelection_0.status === 'running') {
        void killShellTask(currentSelection_0.id);
      } else if (currentSelection_0.type === 'local_agent' && currentSelection_0.status === 'running') {
        void killAgentTask(currentSelection_0.id);
      } else if (currentSelection_0.type === 'in_process_teammate' && currentSelection_0.status === 'running') {
        void killTeammateTask(currentSelection_0.id);
      } else if (currentSelection_0.type === 'local_workflow' && currentSelection_0.status === 'running' && killWorkflowTask) {
        killWorkflowTask(currentSelection_0.id, setAppState);
      } else if (currentSelection_0.type === 'monitor_mcp' && currentSelection_0.status === 'running' && killMonitorMcp) {
        killMonitorMcp(currentSelection_0.id, setAppState);
      } else if (currentSelection_0.type === 'dream' && currentSelection_0.status === 'running') {
        void killDreamTask(currentSelection_0.id);
      } else if (currentSelection_0.type === 'remote_agent' && currentSelection_0.status === 'running') {
        if (currentSelection_0.task.isUltraplan) {
          void stopUltraplan(currentSelection_0.id, currentSelection_0.task.sessionId, setAppState);
        } else {
          void killRemoteAgentTask(currentSelection_0.id);
        }
      }
    }
    if (e.key === 'f') {
      if (currentSelection_0.type === 'in_process_teammate' && currentSelection_0.status === 'running') {
        e.preventDefault();
        enterTeammateView(currentSelection_0.id, setAppState);
        onDone('Viewing teammate', {
          display: 'system'
        });
      } else if (currentSelection_0.type === 'leader') {
        e.preventDefault();
        exitTeammateView(setAppState);
        onDone('Viewing leader', {
          display: 'system'
        });
      }
    }
  };
  async function killShellTask(taskId: string): Promise<void> {
    await LocalShellTask.kill(taskId, setAppState);
  }
  async function killAgentTask(taskId_0: string): Promise<void> {
    await LocalAgentTask.kill(taskId_0, setAppState);
  }
  async function killTeammateTask(taskId_1: string): Promise<void> {
    await InProcessTeammateTask.kill(taskId_1, setAppState);
  }
  async function killDreamTask(taskId_2: string): Promise<void> {
    await DreamTask.kill(taskId_2, setAppState);
  }
  async function killRemoteAgentTask(taskId_3: string): Promise<void> {
    await RemoteAgentTask.kill(taskId_3, setAppState);
  }

  // Wrap onDone in useEffectEvent to get a stable reference that always calls
  // the current onDone callback without causing the effect to re-fire.
  const onDoneEvent = useEffectEvent(onDone);
  useEffect(() => {
    if (viewState.mode !== 'list') {
      const task = (typedTasks ?? {})[viewState.itemId];
      // Workflow tasks get a grace: their detail view stays open through
      // completion so the user sees the final state before eviction.
      if (!task || task.type !== 'local_workflow' && !isBackgroundTask(task)) {
        // Task was removed or is no longer a background task (e.g. killed).
        // If we skipped the list on mount, close the dialog entirely.
        if (skippedListOnMount.current) {
          onDoneEvent('Background tasks dialog dismissed', {
            display: 'system'
          });
        } else {
          setViewState({
            mode: 'list'
          });
        }
      }
    }
    const totalItems = allSelectableItems.length;
    if (selectedIndex >= totalItems && totalItems > 0) {
      setSelectedIndex(totalItems - 1);
    }
  }, [viewState, typedTasks, selectedIndex, allSelectableItems, onDoneEvent]);

  // Helper to go back to list view (or close dialog if we skipped list on
  // mount AND there's still only ≀1 item). Checking current count prevents
  // the stale-state trap: if you opened with 1 task (auto-skipped to detail),
  // then a second task started, 'back' should show the list β€” not close.
  const goBackToList = () => {
    if (skippedListOnMount.current && allSelectableItems.length <= 1) {
      onDone('Background tasks dialog dismissed', {
        display: 'system'
      });
    } else {
      skippedListOnMount.current = false;
      setViewState({
        mode: 'list'
      });
    }
  };

  // If an item is selected, show the appropriate view
  if (viewState.mode !== 'list' && typedTasks) {
    const task_0 = typedTasks[viewState.itemId];
    if (!task_0) {
      return null;
    }

    // Detail mode - show appropriate detail dialog
    switch (task_0.type) {
      case 'local_bash':
        return <ShellDetailDialog shell={task_0} onDone={onDone} onKillShell={() => void killShellTask(task_0.id)} onBack={goBackToList} key={`shell-${task_0.id}`} />;
      case 'local_agent':
        return <AsyncAgentDetailDialog agent={task_0} onDone={onDone} onKillAgent={() => void killAgentTask(task_0.id)} onBack={goBackToList} key={`agent-${task_0.id}`} />;
      case 'remote_agent':
        return <RemoteSessionDetailDialog session={task_0} onDone={onDone} toolUseContext={toolUseContext} onBack={goBackToList} onKill={task_0.status !== 'running' ? undefined : task_0.isUltraplan ? () => void stopUltraplan(task_0.id, task_0.sessionId, setAppState) : () => void killRemoteAgentTask(task_0.id)} key={`session-${task_0.id}`} />;
      case 'in_process_teammate':
        return <InProcessTeammateDetailDialog teammate={task_0} onDone={onDone} onKill={task_0.status === 'running' ? () => void killTeammateTask(task_0.id) : undefined} onBack={goBackToList} onForeground={task_0.status === 'running' ? () => {
          enterTeammateView(task_0.id, setAppState);
          onDone('Viewing teammate', {
            display: 'system'
          });
        } : undefined} key={`teammate-${task_0.id}`} />;
      case 'local_workflow':
        if (!WorkflowDetailDialog) return null;
        return <WorkflowDetailDialog workflow={task_0} onDone={onDone} onKill={task_0.status === 'running' && killWorkflowTask ? () => killWorkflowTask(task_0.id, setAppState) : undefined} onSkipAgent={task_0.status === 'running' && skipWorkflowAgent ? agentId => skipWorkflowAgent(task_0.id, agentId, setAppState) : undefined} onRetryAgent={task_0.status === 'running' && retryWorkflowAgent ? agentId_0 => retryWorkflowAgent(task_0.id, agentId_0, setAppState) : undefined} onBack={goBackToList} key={`workflow-${task_0.id}`} />;
      case 'monitor_mcp':
        if (!MonitorMcpDetailDialog) return null;
        return <MonitorMcpDetailDialog task={task_0} onKill={task_0.status === 'running' && killMonitorMcp ? () => killMonitorMcp(task_0.id, setAppState) : undefined} onBack={goBackToList} key={`monitor-mcp-${task_0.id}`} />;
      case 'dream':
        return <DreamDetailDialog task={task_0} onDone={() => onDone('Background tasks dialog dismissed', {
          display: 'system'
        })} onBack={goBackToList} onKill={task_0.status === 'running' ? () => void killDreamTask(task_0.id) : undefined} key={`dream-${task_0.id}`} />;
    }
  }
  const runningBashCount = count(bashTasks, _ => _.status === 'running');
  const runningAgentCount = count(remoteSessions, __0 => __0.status === 'running' || __0.status === 'pending') + count(agentTasks, __1 => __1.status === 'running');
  const runningTeammateCount = count(teammateTasks, __2 => __2.status === 'running');
  const subtitle = intersperse([...(runningTeammateCount > 0 ? [<Text key="teammates">
              {runningTeammateCount}{' '}
              {runningTeammateCount !== 1 ? 'agents' : 'agent'}
            </Text>] : []), ...(runningBashCount > 0 ? [<Text key="shells">
              {runningBashCount}{' '}
              {runningBashCount !== 1 ? 'active shells' : 'active shell'}
            </Text>] : []), ...(runningAgentCount > 0 ? [<Text key="agents">
              {runningAgentCount}{' '}
              {runningAgentCount !== 1 ? 'active agents' : 'active agent'}
            </Text>] : [])], index => <Text key={`separator-${index}`}> Β· </Text>);
  const actions = [<KeyboardShortcutHint key="upDown" shortcut="↑/↓" action="select" />, <KeyboardShortcutHint key="enter" shortcut="Enter" action="view" />, ...(currentSelection?.type === 'in_process_teammate' && currentSelection.status === 'running' ? [<KeyboardShortcutHint key="foreground" shortcut="f" action="foreground" />] : []), ...((currentSelection?.type === 'local_bash' || currentSelection?.type === 'local_agent' || currentSelection?.type === 'in_process_teammate' || currentSelection?.type === 'local_workflow' || currentSelection?.type === 'monitor_mcp' || currentSelection?.type === 'dream' || currentSelection?.type === 'remote_agent') && currentSelection.status === 'running' ? [<KeyboardShortcutHint key="kill" shortcut="x" action="stop" />] : []), ...(agentTasks.some(t => t.status === 'running') ? [<KeyboardShortcutHint key="kill-all" shortcut={killAgentsShortcut} action="stop all agents" />] : []), <KeyboardShortcutHint key="esc" shortcut="←/Esc" action="close" />];
  const handleCancel = () => onDone('Background tasks dialog dismissed', {
    display: 'system'
  });
  function renderInputGuide(exitState: ExitState): React.ReactNode {
    if (exitState.pending) {
      return <Text>Press {exitState.keyName} again to exit</Text>;
    }
    return <Byline>{actions}</Byline>;
  }
  return <Box flexDirection="column" tabIndex={0} autoFocus onKeyDown={handleKeyDown}>
      <Dialog title="Background tasks" subtitle={<>{subtitle}</>} onCancel={handleCancel} color="background" inputGuide={renderInputGuide}>
        {allSelectableItems.length === 0 ? <Text dimColor>No tasks currently running</Text> : <Box flexDirection="column">
            {teammateTasks.length > 0 && <Box flexDirection="column">
                {(bashTasks.length > 0 || remoteSessions.length > 0 || agentTasks.length > 0) && <Text dimColor>
                    <Text bold>{'  '}Agents</Text> (
                    {count(teammateTasks, i => i.type !== 'leader')})
                  </Text>}
                <Box flexDirection="column">
                  <TeammateTaskGroups teammateTasks={teammateTasks} currentSelectionId={currentSelection?.id} />
                </Box>
              </Box>}

            {bashTasks.length > 0 && <Box flexDirection="column" marginTop={teammateTasks.length > 0 ? 1 : 0}>
                {(teammateTasks.length > 0 || remoteSessions.length > 0 || agentTasks.length > 0) && <Text dimColor>
                    <Text bold>{'  '}Shells</Text> ({bashTasks.length})
                  </Text>}
                <Box flexDirection="column">
                  {bashTasks.map(item_6 => <Item key={item_6.id} item={item_6} isSelected={item_6.id === currentSelection?.id} />)}
                </Box>
              </Box>}

            {mcpMonitors.length > 0 && <Box flexDirection="column" marginTop={teammateTasks.length > 0 || bashTasks.length > 0 ? 1 : 0}>
                <Text dimColor>
                  <Text bold>{'  '}Monitors</Text> ({mcpMonitors.length})
                </Text>
                <Box flexDirection="column">
                  {mcpMonitors.map(item_7 => <Item key={item_7.id} item={item_7} isSelected={item_7.id === currentSelection?.id} />)}
                </Box>
              </Box>}

            {remoteSessions.length > 0 && <Box flexDirection="column" marginTop={teammateTasks.length > 0 || bashTasks.length > 0 || mcpMonitors.length > 0 ? 1 : 0}>
                <Text dimColor>
                  <Text bold>{'  '}Remote agents</Text> ({remoteSessions.length}
                  )
                </Text>
                <Box flexDirection="column">
                  {remoteSessions.map(item_8 => <Item key={item_8.id} item={item_8} isSelected={item_8.id === currentSelection?.id} />)}
                </Box>
              </Box>}

            {agentTasks.length > 0 && <Box flexDirection="column" marginTop={teammateTasks.length > 0 || bashTasks.length > 0 || mcpMonitors.length > 0 || remoteSessions.length > 0 ? 1 : 0}>
                <Text dimColor>
                  <Text bold>{'  '}Local agents</Text> ({agentTasks.length})
                </Text>
                <Box flexDirection="column">
                  {agentTasks.map(item_9 => <Item key={item_9.id} item={item_9} isSelected={item_9.id === currentSelection?.id} />)}
                </Box>
              </Box>}

            {workflowTasks.length > 0 && <Box flexDirection="column" marginTop={teammateTasks.length > 0 || bashTasks.length > 0 || mcpMonitors.length > 0 || remoteSessions.length > 0 || agentTasks.length > 0 ? 1 : 0}>
                <Text dimColor>
                  <Text bold>{'  '}Workflows</Text> ({workflowTasks.length})
                </Text>
                <Box flexDirection="column">
                  {workflowTasks.map(item_10 => <Item key={item_10.id} item={item_10} isSelected={item_10.id === currentSelection?.id} />)}
                </Box>
              </Box>}

            {dreamTasks_0.length > 0 && <Box flexDirection="column" marginTop={teammateTasks.length > 0 || bashTasks.length > 0 || mcpMonitors.length > 0 || remoteSessions.length > 0 || agentTasks.length > 0 || workflowTasks.length > 0 ? 1 : 0}>
                <Box flexDirection="column">
                  {dreamTasks_0.map(item_11 => <Item key={item_11.id} item={item_11} isSelected={item_11.id === currentSelection?.id} />)}
                </Box>
              </Box>}
          </Box>}
      </Dialog>
    </Box>;
}
function toListItem(task: BackgroundTaskState): ListItem {
  switch (task.type) {
    case 'local_bash':
      return {
        id: task.id,
        type: 'local_bash',
        label: task.kind === 'monitor' ? task.description : task.command,
        status: task.status,
        task
      };
    case 'remote_agent':
      return {
        id: task.id,
        type: 'remote_agent',
        label: task.title,
        status: task.status,
        task
      };
    case 'local_agent':
      return {
        id: task.id,
        type: 'local_agent',
        label: task.description,
        status: task.status,
        task
      };
    case 'in_process_teammate':
      return {
        id: task.id,
        type: 'in_process_teammate',
        label: `@${task.identity.agentName}`,
        status: task.status,
        task
      };
    case 'local_workflow':
      return {
        id: task.id,
        type: 'local_workflow',
        label: task.summary ?? task.description,
        status: task.status,
        task
      };
    case 'monitor_mcp':
      return {
        id: task.id,
        type: 'monitor_mcp',
        label: task.description,
        status: task.status,
        task
      };
    case 'dream':
      return {
        id: task.id,
        type: 'dream',
        label: task.description,
        status: task.status,
        task
      };
  }
}
function Item(t0) {
  const $ = _c(14);
  const {
    item,
    isSelected
  } = t0;
  const {
    columns
  } = useTerminalSize();
  const maxActivityWidth = Math.max(30, columns - 26);
  let t1;
  if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
    t1 = isCoordinatorMode();
    $[0] = t1;
  } else {
    t1 = $[0];
  }
  const useGreyPointer = t1;
  const t2 = useGreyPointer && isSelected;
  const t3 = isSelected ? figures.pointer + " " : "  ";
  let t4;
  if ($[1] !== t2 || $[2] !== t3) {
    t4 = <Text dimColor={t2}>{t3}</Text>;
    $[1] = t2;
    $[2] = t3;
    $[3] = t4;
  } else {
    t4 = $[3];
  }
  const t5 = isSelected && !useGreyPointer ? "suggestion" : undefined;
  let t6;
  if ($[4] !== item.task || $[5] !== item.type || $[6] !== maxActivityWidth) {
    t6 = item.type === "leader" ? <Text>@{TEAM_LEAD_NAME}</Text> : <BackgroundTaskComponent task={item.task} maxActivityWidth={maxActivityWidth} />;
    $[4] = item.task;
    $[5] = item.type;
    $[6] = maxActivityWidth;
    $[7] = t6;
  } else {
    t6 = $[7];
  }
  let t7;
  if ($[8] !== t5 || $[9] !== t6) {
    t7 = <Text color={t5}>{t6}</Text>;
    $[8] = t5;
    $[9] = t6;
    $[10] = t7;
  } else {
    t7 = $[10];
  }
  let t8;
  if ($[11] !== t4 || $[12] !== t7) {
    t8 = <Box flexDirection="row">{t4}{t7}</Box>;
    $[11] = t4;
    $[12] = t7;
    $[13] = t8;
  } else {
    t8 = $[13];
  }
  return t8;
}
function TeammateTaskGroups(t0) {
  const $ = _c(3);
  const {
    teammateTasks,
    currentSelectionId
  } = t0;
  let t1;
  if ($[0] !== currentSelectionId || $[1] !== teammateTasks) {
    const leaderItems = teammateTasks.filter(_temp);
    const teammateItems = teammateTasks.filter(_temp2);
    const teams = new Map();
    for (const item of teammateItems) {
      const teamName = item.task.identity.teamName;
      const group = teams.get(teamName);
      if (group) {
        group.push(item);
      } else {
        teams.set(teamName, [item]);
      }
    }
    const teamEntries = [...teams.entries()];
    t1 = <>{teamEntries.map(t2 => {
        const [teamName_0, items] = t2;
        const memberCount = items.length + leaderItems.length;
        return <Box key={teamName_0} flexDirection="column"><Text dimColor={true}>{"  "}Team: {teamName_0} ({memberCount})</Text>{leaderItems.map(item_0 => <Item key={`${item_0.id}-${teamName_0}`} item={item_0} isSelected={item_0.id === currentSelectionId} />)}{items.map(item_1 => <Item key={item_1.id} item={item_1} isSelected={item_1.id === currentSelectionId} />)}</Box>;
      })}</>;
    $[0] = currentSelectionId;
    $[1] = teammateTasks;
    $[2] = t1;
  } else {
    t1 = $[2];
  }
  return t1;
}
function _temp2(i_0) {
  return i_0.type === "in_process_teammate";
}
function _temp(i) {
  return i.type === "leader";
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["feature","figures","React","ReactNode","useEffect","useEffectEvent","useMemo","useRef","useState","isCoordinatorMode","useTerminalSize","useAppState","useSetAppState","enterTeammateView","exitTeammateView","ToolUseContext","DreamTask","DreamTaskState","InProcessTeammateTask","InProcessTeammateTaskState","LocalAgentTaskState","LocalAgentTask","LocalShellTaskState","LocalShellTask","LocalWorkflowTaskState","MonitorMcpTaskState","RemoteAgentTask","RemoteAgentTaskState","BackgroundTaskState","isBackgroundTask","TaskState","DeepImmutable","intersperse","TEAM_LEAD_NAME","stopUltraplan","CommandResultDisplay","useRegisterOverlay","ExitState","KeyboardEvent","Box","Text","useKeybindings","useShortcutDisplay","count","Byline","Dialog","KeyboardShortcutHint","AsyncAgentDetailDialog","BackgroundTask","BackgroundTaskComponent","DreamDetailDialog","InProcessTeammateDetailDialog","RemoteSessionDetailDialog","ShellDetailDialog","ViewState","mode","itemId","Props","onDone","result","options","display","toolUseContext","initialDetailTaskId","ListItem","id","type","label","status","task","WorkflowDetailDialog","require","workflowTaskModule","killWorkflowTask","skipWorkflowAgent","retryWorkflowAgent","monitorMcpModule","killMonitorMcp","MonitorMcpDetailDialog","getSelectableBackgroundTasks","tasks","Record","foregroundedTaskId","backgroundTasks","Object","values","filter","BackgroundTasksDialog","s","showSpinnerTree","expandedView","setAppState","killAgentsShortcut","typedTasks","skippedListOnMount","viewState","setViewState","current","allItems","length","selectedIndex","setSelectedIndex","bashTasks","remoteSessions","agentTasks","teammateTasks","workflowTasks","mcpMonitors","dreamTasks","allSelectableItems","map","toListItem","sorted","sort","a","b","aStatus","bStatus","aTime","startTime","bTime","bash","item","remote","agent","workflows","monitorMcp","teammates","leaderItem","currentSelection","confirm:previous","prev","Math","max","confirm:next","min","confirm:yes","context","isActive","handleKeyDown","e","key","preventDefault","killShellTask","killAgentTask","killTeammateTask","killDreamTask","isUltraplan","sessionId","killRemoteAgentTask","taskId","Promise","kill","onDoneEvent","totalItems","goBackToList","undefined","agentId","runningBashCount","_","runningAgentCount","runningTeammateCount","subtitle","index","actions","some","t","handleCancel","renderInputGuide","exitState","pending","keyName","i","kind","description","command","title","identity","agentName","summary","Item","t0","$","_c","isSelected","columns","maxActivityWidth","t1","Symbol","for","useGreyPointer","t2","t3","pointer","t4","t5","t6","t7","t8","TeammateTaskGroups","currentSelectionId","leaderItems","_temp","teammateItems","_temp2","teams","Map","teamName","group","get","push","set","teamEntries","entries","teamName_0","items","memberCount","item_0","item_1","i_0"],"sources":["BackgroundTasksDialog.tsx"],"sourcesContent":["import { feature } from 'bun:bundle'\nimport figures from 'figures'\nimport React, {\n  type ReactNode,\n  useEffect,\n  useEffectEvent,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { isCoordinatorMode } from 'src/coordinator/coordinatorMode.js'\nimport { useTerminalSize } from 'src/hooks/useTerminalSize.js'\nimport { useAppState, useSetAppState } from 'src/state/AppState.js'\nimport {\n  enterTeammateView,\n  exitTeammateView,\n} from 'src/state/teammateViewHelpers.js'\nimport type { ToolUseContext } from 'src/Tool.js'\nimport {\n  DreamTask,\n  type DreamTaskState,\n} from 'src/tasks/DreamTask/DreamTask.js'\nimport { InProcessTeammateTask } from 'src/tasks/InProcessTeammateTask/InProcessTeammateTask.js'\nimport type { InProcessTeammateTaskState } from 'src/tasks/InProcessTeammateTask/types.js'\nimport type { LocalAgentTaskState } from 'src/tasks/LocalAgentTask/LocalAgentTask.js'\nimport { LocalAgentTask } from 'src/tasks/LocalAgentTask/LocalAgentTask.js'\nimport type { LocalShellTaskState } from 'src/tasks/LocalShellTask/guards.js'\nimport { LocalShellTask } from 'src/tasks/LocalShellTask/LocalShellTask.js'\n// Type import is erased at build time — safe even though module is ant-gated.\nimport type { LocalWorkflowTaskState } from 'src/tasks/LocalWorkflowTask/LocalWorkflowTask.js'\nimport type { MonitorMcpTaskState } from 'src/tasks/MonitorMcpTask/MonitorMcpTask.js'\nimport {\n  RemoteAgentTask,\n  type RemoteAgentTaskState,\n} from 'src/tasks/RemoteAgentTask/RemoteAgentTask.js'\nimport {\n  type BackgroundTaskState,\n  isBackgroundTask,\n  type TaskState,\n} from 'src/tasks/types.js'\nimport type { DeepImmutable } from 'src/types/utils.js'\nimport { intersperse } from 'src/utils/array.js'\nimport { TEAM_LEAD_NAME } from 'src/utils/swarm/constants.js'\nimport { stopUltraplan } from '../../commands/ultraplan.js'\nimport type { CommandResultDisplay } from '../../commands.js'\nimport { useRegisterOverlay } from '../../context/overlayContext.js'\nimport type { ExitState } from '../../hooks/useExitOnCtrlCDWithKeybindings.js'\nimport type { KeyboardEvent } from '../../ink/events/keyboard-event.js'\nimport { Box, Text } from '../../ink.js'\nimport { useKeybindings } from '../../keybindings/useKeybinding.js'\nimport { useShortcutDisplay } from '../../keybindings/useShortcutDisplay.js'\nimport { count } from '../../utils/array.js'\nimport { Byline } from '../design-system/Byline.js'\nimport { Dialog } from '../design-system/Dialog.js'\nimport { KeyboardShortcutHint } from '../design-system/KeyboardShortcutHint.js'\nimport { AsyncAgentDetailDialog } from './AsyncAgentDetailDialog.js'\nimport { BackgroundTask as BackgroundTaskComponent } from './BackgroundTask.js'\nimport { DreamDetailDialog } from './DreamDetailDialog.js'\nimport { InProcessTeammateDetailDialog } from './InProcessTeammateDetailDialog.js'\nimport { RemoteSessionDetailDialog } from './RemoteSessionDetailDialog.js'\nimport { ShellDetailDialog } from './ShellDetailDialog.js'\n\ntype ViewState = { mode: 'list' } | { mode: 'detail'; itemId: string }\n\ntype Props = {\n  onDone: (\n    result?: string,\n    options?: { display?: CommandResultDisplay },\n  ) => void\n  toolUseContext: ToolUseContext\n  initialDetailTaskId?: string\n}\n\ntype ListItem =\n  | {\n      id: string\n      type: 'local_bash'\n      label: string\n      status: string\n      task: DeepImmutable<LocalShellTaskState>\n    }\n  | {\n      id: string\n      type: 'remote_agent'\n      label: string\n      status: string\n      task: DeepImmutable<RemoteAgentTaskState>\n    }\n  | {\n      id: string\n      type: 'local_agent'\n      label: string\n      status: string\n      task: DeepImmutable<LocalAgentTaskState>\n    }\n  | {\n      id: string\n      type: 'in_process_teammate'\n      label: string\n      status: string\n      task: DeepImmutable<InProcessTeammateTaskState>\n    }\n  | {\n      id: string\n      type: 'local_workflow'\n      label: string\n      status: string\n      task: DeepImmutable<LocalWorkflowTaskState>\n    }\n  | {\n      id: string\n      type: 'monitor_mcp'\n      label: string\n      status: string\n      task: DeepImmutable<MonitorMcpTaskState>\n    }\n  | {\n      id: string\n      type: 'dream'\n      label: string\n      status: string\n      task: DeepImmutable<DreamTaskState>\n    }\n  | {\n      id: string\n      type: 'leader'\n      label: string\n      status: 'running'\n    }\n\n// WORKFLOW_SCRIPTS is ant-only (build_flags.yaml). Static imports would leak\n// ~1.3K lines into external builds. Gate with feature() + require so the\n// bundler can dead-code-eliminate the branch.\n/* eslint-disable @typescript-eslint/no-require-imports */\nconst WorkflowDetailDialog = feature('WORKFLOW_SCRIPTS')\n  ? (\n      require('./WorkflowDetailDialog.js') as typeof import('./WorkflowDetailDialog.js')\n    ).WorkflowDetailDialog\n  : null\nconst workflowTaskModule = feature('WORKFLOW_SCRIPTS')\n  ? (require('src/tasks/LocalWorkflowTask/LocalWorkflowTask.js') as typeof import('src/tasks/LocalWorkflowTask/LocalWorkflowTask.js'))\n  : null\nconst killWorkflowTask = workflowTaskModule?.killWorkflowTask ?? null\nconst skipWorkflowAgent = workflowTaskModule?.skipWorkflowAgent ?? null\nconst retryWorkflowAgent = workflowTaskModule?.retryWorkflowAgent ?? null\n// Relative path, not `src/...` path-mapping — Bun's DCE can statically\n// resolve + eliminate `./` requires, but path-mapped strings stay opaque\n// and survive as dead literals in the bundle. Matches tasks.ts pattern.\nconst monitorMcpModule = feature('MONITOR_TOOL')\n  ? (require('../../tasks/MonitorMcpTask/MonitorMcpTask.js') as typeof import('../../tasks/MonitorMcpTask/MonitorMcpTask.js'))\n  : null\nconst killMonitorMcp = monitorMcpModule?.killMonitorMcp ?? null\nconst MonitorMcpDetailDialog = feature('MONITOR_TOOL')\n  ? (\n      require('./MonitorMcpDetailDialog.js') as typeof import('./MonitorMcpDetailDialog.js')\n    ).MonitorMcpDetailDialog\n  : null\n/* eslint-enable @typescript-eslint/no-require-imports */\n\n// Helper to get filtered background tasks (excludes foregrounded local_agent)\nfunction getSelectableBackgroundTasks(\n  tasks: Record<string, TaskState> | undefined,\n  foregroundedTaskId: string | undefined,\n): TaskState[] {\n  const backgroundTasks = Object.values(tasks ?? {}).filter(isBackgroundTask)\n  return backgroundTasks.filter(\n    task => !(task.type === 'local_agent' && task.id === foregroundedTaskId),\n  )\n}\n\nexport function BackgroundTasksDialog({\n  onDone,\n  toolUseContext,\n  initialDetailTaskId,\n}: Props): React.ReactNode {\n  const tasks = useAppState(s => s.tasks)\n  const foregroundedTaskId = useAppState(s => s.foregroundedTaskId)\n  const showSpinnerTree = useAppState(s => s.expandedView) === 'teammates'\n  const setAppState = useSetAppState()\n  const killAgentsShortcut = useShortcutDisplay(\n    'chat:killAgents',\n    'Chat',\n    'ctrl+x ctrl+k',\n  )\n  const typedTasks = tasks as Record<string, TaskState> | undefined\n\n  // Track if we skipped list view on mount (for back button behavior)\n  const skippedListOnMount = useRef(false)\n\n  // Compute initial view state - skip list if caller provided a specific task,\n  // or if there's exactly one task\n  const [viewState, setViewState] = useState<ViewState>(() => {\n    if (initialDetailTaskId) {\n      skippedListOnMount.current = true\n      return { mode: 'detail', itemId: initialDetailTaskId }\n    }\n    const allItems = getSelectableBackgroundTasks(\n      typedTasks,\n      foregroundedTaskId,\n    )\n    if (allItems.length === 1) {\n      skippedListOnMount.current = true\n      return { mode: 'detail', itemId: allItems[0]!.id }\n    }\n    return { mode: 'list' }\n  })\n  const [selectedIndex, setSelectedIndex] = useState<number>(0)\n\n  // Register as modal overlay so parent Chat keybindings (up/down for history)\n  // are deactivated while this dialog is open\n  useRegisterOverlay('background-tasks-dialog')\n\n  // Memoize the sorted and categorized items together to ensure stable references\n  const {\n    bashTasks,\n    remoteSessions,\n    agentTasks,\n    teammateTasks,\n    workflowTasks,\n    mcpMonitors,\n    dreamTasks,\n    allSelectableItems,\n  } = useMemo(() => {\n    // Filter to only show running/pending background tasks, matching the status bar count\n    const backgroundTasks = Object.values(typedTasks ?? {}).filter(\n      isBackgroundTask,\n    )\n    const allItems = backgroundTasks.map(toListItem)\n    const sorted = allItems.sort((a, b) => {\n      const aStatus = a.status\n      const bStatus = b.status\n      if (aStatus === 'running' && bStatus !== 'running') return -1\n      if (aStatus !== 'running' && bStatus === 'running') return 1\n      const aTime = 'task' in a ? a.task.startTime : 0\n      const bTime = 'task' in b ? b.task.startTime : 0\n      return bTime - aTime\n    })\n    const bash = sorted.filter(item => item.type === 'local_bash')\n    const remote = sorted.filter(item => item.type === 'remote_agent')\n    // Exclude foregrounded task - it's being viewed in the main UI, not a background task\n    const agent = sorted.filter(\n      item => item.type === 'local_agent' && item.id !== foregroundedTaskId,\n    )\n    const workflows = sorted.filter(item => item.type === 'local_workflow')\n    const monitorMcp = sorted.filter(item => item.type === 'monitor_mcp')\n    const dreamTasks = sorted.filter(item => item.type === 'dream')\n    // In spinner-tree mode, exclude teammates from the dialog (they appear in the tree)\n    const teammates = showSpinnerTree\n      ? []\n      : sorted.filter(item => item.type === 'in_process_teammate')\n    // Add leader entry when there are teammates, so users can foreground back to leader\n    const leaderItem: ListItem[] =\n      teammates.length > 0\n        ? [\n            {\n              id: '__leader__',\n              type: 'leader',\n              label: `@${TEAM_LEAD_NAME}`,\n              status: 'running',\n            },\n          ]\n        : []\n    return {\n      bashTasks: bash,\n      remoteSessions: remote,\n      agentTasks: agent,\n      workflowTasks: workflows,\n      mcpMonitors: monitorMcp,\n      dreamTasks,\n      teammateTasks: [...leaderItem, ...teammates],\n      // Order MUST match JSX render order (teammates \\u2192 bash \\u2192 monitorMcp \\u2192\n      // remote \\u2192 agent \\u2192 workflows \\u2192 dream) so \\u2193/\\u2191 navigation moves the cursor\n      // visually downward.\n      allSelectableItems: [\n        ...leaderItem,\n        ...teammates,\n        ...bash,\n        ...monitorMcp,\n        ...remote,\n        ...agent,\n        ...workflows,\n        ...dreamTasks,\n      ],\n    }\n  }, [typedTasks, foregroundedTaskId, showSpinnerTree])\n\n  const currentSelection = allSelectableItems[selectedIndex] ?? null\n\n  // Use configurable keybindings for standard navigation and confirm/cancel.\n  // confirm:no is handled by Dialog's onCancel prop.\n  useKeybindings(\n    {\n      'confirm:previous': () => setSelectedIndex(prev => Math.max(0, prev - 1)),\n      'confirm:next': () =>\n        setSelectedIndex(prev =>\n          Math.min(allSelectableItems.length - 1, prev + 1),\n        ),\n      'confirm:yes': () => {\n        const current = allSelectableItems[selectedIndex]\n        if (current) {\n          if (current.type === 'leader') {\n            exitTeammateView(setAppState)\n            onDone('Viewing leader', { display: 'system' })\n          } else {\n            setViewState({ mode: 'detail', itemId: current.id })\n          }\n        }\n      },\n    },\n    { context: 'Confirmation', isActive: viewState.mode === 'list' },\n  )\n\n  // Component-specific shortcuts (x=stop, f=foreground, right=zoom) shown in UI.\n  // These are task-type and status dependent, not standard dialog keybindings.\n  const handleKeyDown = (e: KeyboardEvent) => {\n    // Only handle input when in list mode\n    if (viewState.mode !== 'list') return\n\n    if (e.key === 'left') {\n      e.preventDefault()\n      onDone('Background tasks dialog dismissed', { display: 'system' })\n      return\n    }\n\n    // Compute current selection at the time of the key press\n    const currentSelection = allSelectableItems[selectedIndex]\n    if (!currentSelection) return // everything below requires a selection\n\n    if (e.key === 'x') {\n      e.preventDefault()\n      if (\n        currentSelection.type === 'local_bash' &&\n        currentSelection.status === 'running'\n      ) {\n        void killShellTask(currentSelection.id)\n      } else if (\n        currentSelection.type === 'local_agent' &&\n        currentSelection.status === 'running'\n      ) {\n        void killAgentTask(currentSelection.id)\n      } else if (\n        currentSelection.type === 'in_process_teammate' &&\n        currentSelection.status === 'running'\n      ) {\n        void killTeammateTask(currentSelection.id)\n      } else if (\n        currentSelection.type === 'local_workflow' &&\n        currentSelection.status === 'running' &&\n        killWorkflowTask\n      ) {\n        killWorkflowTask(currentSelection.id, setAppState)\n      } else if (\n        currentSelection.type === 'monitor_mcp' &&\n        currentSelection.status === 'running' &&\n        killMonitorMcp\n      ) {\n        killMonitorMcp(currentSelection.id, setAppState)\n      } else if (\n        currentSelection.type === 'dream' &&\n        currentSelection.status === 'running'\n      ) {\n        void killDreamTask(currentSelection.id)\n      } else if (\n        currentSelection.type === 'remote_agent' &&\n        currentSelection.status === 'running'\n      ) {\n        if (currentSelection.task.isUltraplan) {\n          void stopUltraplan(\n            currentSelection.id,\n            currentSelection.task.sessionId,\n            setAppState,\n          )\n        } else {\n          void killRemoteAgentTask(currentSelection.id)\n        }\n      }\n    }\n\n    if (e.key === 'f') {\n      if (\n        currentSelection.type === 'in_process_teammate' &&\n        currentSelection.status === 'running'\n      ) {\n        e.preventDefault()\n        enterTeammateView(currentSelection.id, setAppState)\n        onDone('Viewing teammate', { display: 'system' })\n      } else if (currentSelection.type === 'leader') {\n        e.preventDefault()\n        exitTeammateView(setAppState)\n        onDone('Viewing leader', { display: 'system' })\n      }\n    }\n  }\n\n  async function killShellTask(taskId: string): Promise<void> {\n    await LocalShellTask.kill(taskId, setAppState)\n  }\n\n  async function killAgentTask(taskId: string): Promise<void> {\n    await LocalAgentTask.kill(taskId, setAppState)\n  }\n\n  async function killTeammateTask(taskId: string): Promise<void> {\n    await InProcessTeammateTask.kill(taskId, setAppState)\n  }\n\n  async function killDreamTask(taskId: string): Promise<void> {\n    await DreamTask.kill(taskId, setAppState)\n  }\n\n  async function killRemoteAgentTask(taskId: string): Promise<void> {\n    await RemoteAgentTask.kill(taskId, setAppState)\n  }\n\n  // Wrap onDone in useEffectEvent to get a stable reference that always calls\n  // the current onDone callback without causing the effect to re-fire.\n  const onDoneEvent = useEffectEvent(onDone)\n\n  useEffect(() => {\n    if (viewState.mode !== 'list') {\n      const task = (typedTasks ?? {})[viewState.itemId]\n      // Workflow tasks get a grace: their detail view stays open through\n      // completion so the user sees the final state before eviction.\n      if (\n        !task ||\n        (task.type !== 'local_workflow' && !isBackgroundTask(task))\n      ) {\n        // Task was removed or is no longer a background task (e.g. killed).\n        // If we skipped the list on mount, close the dialog entirely.\n        if (skippedListOnMount.current) {\n          onDoneEvent('Background tasks dialog dismissed', {\n            display: 'system',\n          })\n        } else {\n          setViewState({ mode: 'list' })\n        }\n      }\n    }\n\n    const totalItems = allSelectableItems.length\n    if (selectedIndex >= totalItems && totalItems > 0) {\n      setSelectedIndex(totalItems - 1)\n    }\n  }, [viewState, typedTasks, selectedIndex, allSelectableItems, onDoneEvent])\n\n  // Helper to go back to list view (or close dialog if we skipped list on\n  // mount AND there's still only ≤1 item). Checking current count prevents\n  // the stale-state trap: if you opened with 1 task (auto-skipped to detail),\n  // then a second task started, 'back' should show the list — not close.\n  const goBackToList = () => {\n    if (skippedListOnMount.current && allSelectableItems.length <= 1) {\n      onDone('Background tasks dialog dismissed', { display: 'system' })\n    } else {\n      skippedListOnMount.current = false\n      setViewState({ mode: 'list' })\n    }\n  }\n\n  // If an item is selected, show the appropriate view\n  if (viewState.mode !== 'list' && typedTasks) {\n    const task = typedTasks[viewState.itemId]\n    if (!task) {\n      return null\n    }\n\n    // Detail mode - show appropriate detail dialog\n    switch (task.type) {\n      case 'local_bash':\n        return (\n          <ShellDetailDialog\n            shell={task}\n            onDone={onDone}\n            onKillShell={() => void killShellTask(task.id)}\n            onBack={goBackToList}\n            key={`shell-${task.id}`}\n          />\n        )\n      case 'local_agent':\n        return (\n          <AsyncAgentDetailDialog\n            agent={task}\n            onDone={onDone}\n            onKillAgent={() => void killAgentTask(task.id)}\n            onBack={goBackToList}\n            key={`agent-${task.id}`}\n          />\n        )\n      case 'remote_agent':\n        return (\n          <RemoteSessionDetailDialog\n            session={task}\n            onDone={onDone}\n            toolUseContext={toolUseContext}\n            onBack={goBackToList}\n            onKill={\n              task.status !== 'running'\n                ? undefined\n                : task.isUltraplan\n                  ? () =>\n                      void stopUltraplan(task.id, task.sessionId, setAppState)\n                  : () => void killRemoteAgentTask(task.id)\n            }\n            key={`session-${task.id}`}\n          />\n        )\n      case 'in_process_teammate':\n        return (\n          <InProcessTeammateDetailDialog\n            teammate={task}\n            onDone={onDone}\n            onKill={\n              task.status === 'running'\n                ? () => void killTeammateTask(task.id)\n                : undefined\n            }\n            onBack={goBackToList}\n            onForeground={\n              task.status === 'running'\n                ? () => {\n                    enterTeammateView(task.id, setAppState)\n                    onDone('Viewing teammate', { display: 'system' })\n                  }\n                : undefined\n            }\n            key={`teammate-${task.id}`}\n          />\n        )\n      case 'local_workflow':\n        if (!WorkflowDetailDialog) return null\n        return (\n          <WorkflowDetailDialog\n            workflow={task}\n            onDone={onDone}\n            onKill={\n              task.status === 'running' && killWorkflowTask\n                ? () => killWorkflowTask(task.id, setAppState)\n                : undefined\n            }\n            onSkipAgent={\n              task.status === 'running' && skipWorkflowAgent\n                ? agentId => skipWorkflowAgent(task.id, agentId, setAppState)\n                : undefined\n            }\n            onRetryAgent={\n              task.status === 'running' && retryWorkflowAgent\n                ? agentId => retryWorkflowAgent(task.id, agentId, setAppState)\n                : undefined\n            }\n            onBack={goBackToList}\n            key={`workflow-${task.id}`}\n          />\n        )\n      case 'monitor_mcp':\n        if (!MonitorMcpDetailDialog) return null\n        return (\n          <MonitorMcpDetailDialog\n            task={task}\n            onKill={\n              task.status === 'running' && killMonitorMcp\n                ? () => killMonitorMcp(task.id, setAppState)\n                : undefined\n            }\n            onBack={goBackToList}\n            key={`monitor-mcp-${task.id}`}\n          />\n        )\n      case 'dream':\n        return (\n          <DreamDetailDialog\n            task={task}\n            onDone={() =>\n              onDone('Background tasks dialog dismissed', {\n                display: 'system',\n              })\n            }\n            onBack={goBackToList}\n            onKill={\n              task.status === 'running'\n                ? () => void killDreamTask(task.id)\n                : undefined\n            }\n            key={`dream-${task.id}`}\n          />\n        )\n    }\n  }\n\n  const runningBashCount = count(bashTasks, _ => _.status === 'running')\n  const runningAgentCount =\n    count(\n      remoteSessions,\n      _ => _.status === 'running' || _.status === 'pending',\n    ) + count(agentTasks, _ => _.status === 'running')\n  const runningTeammateCount = count(teammateTasks, _ => _.status === 'running')\n  const subtitle = intersperse(\n    [\n      ...(runningTeammateCount > 0\n        ? [\n            <Text key=\"teammates\">\n              {runningTeammateCount}{' '}\n              {runningTeammateCount !== 1 ? 'agents' : 'agent'}\n            </Text>,\n          ]\n        : []),\n      ...(runningBashCount > 0\n        ? [\n            <Text key=\"shells\">\n              {runningBashCount}{' '}\n              {runningBashCount !== 1 ? 'active shells' : 'active shell'}\n            </Text>,\n          ]\n        : []),\n      ...(runningAgentCount > 0\n        ? [\n            <Text key=\"agents\">\n              {runningAgentCount}{' '}\n              {runningAgentCount !== 1 ? 'active agents' : 'active agent'}\n            </Text>,\n          ]\n        : []),\n    ],\n    index => <Text key={`separator-${index}`}> · </Text>,\n  )\n\n  const actions = [\n    <KeyboardShortcutHint key=\"upDown\" shortcut=\"↑/↓\" action=\"select\" />,\n    <KeyboardShortcutHint key=\"enter\" shortcut=\"Enter\" action=\"view\" />,\n    ...(currentSelection?.type === 'in_process_teammate' &&\n    currentSelection.status === 'running'\n      ? [\n          <KeyboardShortcutHint\n            key=\"foreground\"\n            shortcut=\"f\"\n            action=\"foreground\"\n          />,\n        ]\n      : []),\n    ...((currentSelection?.type === 'local_bash' ||\n      currentSelection?.type === 'local_agent' ||\n      currentSelection?.type === 'in_process_teammate' ||\n      currentSelection?.type === 'local_workflow' ||\n      currentSelection?.type === 'monitor_mcp' ||\n      currentSelection?.type === 'dream' ||\n      currentSelection?.type === 'remote_agent') &&\n    currentSelection.status === 'running'\n      ? [<KeyboardShortcutHint key=\"kill\" shortcut=\"x\" action=\"stop\" />]\n      : []),\n    ...(agentTasks.some(t => t.status === 'running')\n      ? [\n          <KeyboardShortcutHint\n            key=\"kill-all\"\n            shortcut={killAgentsShortcut}\n            action=\"stop all agents\"\n          />,\n        ]\n      : []),\n    <KeyboardShortcutHint key=\"esc\" shortcut=\"←/Esc\" action=\"close\" />,\n  ]\n\n  const handleCancel = () =>\n    onDone('Background tasks dialog dismissed', { display: 'system' })\n\n  function renderInputGuide(exitState: ExitState): React.ReactNode {\n    if (exitState.pending) {\n      return <Text>Press {exitState.keyName} again to exit</Text>\n    }\n    return <Byline>{actions}</Byline>\n  }\n\n  return (\n    <Box\n      flexDirection=\"column\"\n      tabIndex={0}\n      autoFocus\n      onKeyDown={handleKeyDown}\n    >\n      <Dialog\n        title=\"Background tasks\"\n        subtitle={<>{subtitle}</>}\n        onCancel={handleCancel}\n        color=\"background\"\n        inputGuide={renderInputGuide}\n      >\n        {allSelectableItems.length === 0 ? (\n          <Text dimColor>No tasks currently running</Text>\n        ) : (\n          <Box flexDirection=\"column\">\n            {teammateTasks.length > 0 && (\n              <Box flexDirection=\"column\">\n                {(bashTasks.length > 0 ||\n                  remoteSessions.length > 0 ||\n                  agentTasks.length > 0) && (\n                  <Text dimColor>\n                    <Text bold>{'  '}Agents</Text> (\n                    {count(teammateTasks, i => i.type !== 'leader')})\n                  </Text>\n                )}\n                <Box flexDirection=\"column\">\n                  <TeammateTaskGroups\n                    teammateTasks={teammateTasks}\n                    currentSelectionId={currentSelection?.id}\n                  />\n                </Box>\n              </Box>\n            )}\n\n            {bashTasks.length > 0 && (\n              <Box\n                flexDirection=\"column\"\n                marginTop={teammateTasks.length > 0 ? 1 : 0}\n              >\n                {(teammateTasks.length > 0 ||\n                  remoteSessions.length > 0 ||\n                  agentTasks.length > 0) && (\n                  <Text dimColor>\n                    <Text bold>{'  '}Shells</Text> ({bashTasks.length})\n                  </Text>\n                )}\n                <Box flexDirection=\"column\">\n                  {bashTasks.map(item => (\n                    <Item\n                      key={item.id}\n                      item={item}\n                      isSelected={item.id === currentSelection?.id}\n                    />\n                  ))}\n                </Box>\n              </Box>\n            )}\n\n            {mcpMonitors.length > 0 && (\n              <Box\n                flexDirection=\"column\"\n                marginTop={\n                  teammateTasks.length > 0 || bashTasks.length > 0 ? 1 : 0\n                }\n              >\n                <Text dimColor>\n                  <Text bold>{'  '}Monitors</Text> ({mcpMonitors.length})\n                </Text>\n                <Box flexDirection=\"column\">\n                  {mcpMonitors.map(item => (\n                    <Item\n                      key={item.id}\n                      item={item}\n                      isSelected={item.id === currentSelection?.id}\n                    />\n                  ))}\n                </Box>\n              </Box>\n            )}\n\n            {remoteSessions.length > 0 && (\n              <Box\n                flexDirection=\"column\"\n                marginTop={\n                  teammateTasks.length > 0 ||\n                  bashTasks.length > 0 ||\n                  mcpMonitors.length > 0\n                    ? 1\n                    : 0\n                }\n              >\n                <Text dimColor>\n                  <Text bold>{'  '}Remote agents</Text> ({remoteSessions.length}\n                  )\n                </Text>\n                <Box flexDirection=\"column\">\n                  {remoteSessions.map(item => (\n                    <Item\n                      key={item.id}\n                      item={item}\n                      isSelected={item.id === currentSelection?.id}\n                    />\n                  ))}\n                </Box>\n              </Box>\n            )}\n\n            {agentTasks.length > 0 && (\n              <Box\n                flexDirection=\"column\"\n                marginTop={\n                  teammateTasks.length > 0 ||\n                  bashTasks.length > 0 ||\n                  mcpMonitors.length > 0 ||\n                  remoteSessions.length > 0\n                    ? 1\n                    : 0\n                }\n              >\n                <Text dimColor>\n                  <Text bold>{'  '}Local agents</Text> ({agentTasks.length})\n                </Text>\n                <Box flexDirection=\"column\">\n                  {agentTasks.map(item => (\n                    <Item\n                      key={item.id}\n                      item={item}\n                      isSelected={item.id === currentSelection?.id}\n                    />\n                  ))}\n                </Box>\n              </Box>\n            )}\n\n            {workflowTasks.length > 0 && (\n              <Box\n                flexDirection=\"column\"\n                marginTop={\n                  teammateTasks.length > 0 ||\n                  bashTasks.length > 0 ||\n                  mcpMonitors.length > 0 ||\n                  remoteSessions.length > 0 ||\n                  agentTasks.length > 0\n                    ? 1\n                    : 0\n                }\n              >\n                <Text dimColor>\n                  <Text bold>{'  '}Workflows</Text> ({workflowTasks.length})\n                </Text>\n                <Box flexDirection=\"column\">\n                  {workflowTasks.map(item => (\n                    <Item\n                      key={item.id}\n                      item={item}\n                      isSelected={item.id === currentSelection?.id}\n                    />\n                  ))}\n                </Box>\n              </Box>\n            )}\n\n            {dreamTasks.length > 0 && (\n              <Box\n                flexDirection=\"column\"\n                marginTop={\n                  teammateTasks.length > 0 ||\n                  bashTasks.length > 0 ||\n                  mcpMonitors.length > 0 ||\n                  remoteSessions.length > 0 ||\n                  agentTasks.length > 0 ||\n                  workflowTasks.length > 0\n                    ? 1\n                    : 0\n                }\n              >\n                <Box flexDirection=\"column\">\n                  {dreamTasks.map(item => (\n                    <Item\n                      key={item.id}\n                      item={item}\n                      isSelected={item.id === currentSelection?.id}\n                    />\n                  ))}\n                </Box>\n              </Box>\n            )}\n          </Box>\n        )}\n      </Dialog>\n    </Box>\n  )\n}\n\nfunction toListItem(task: BackgroundTaskState): ListItem {\n  switch (task.type) {\n    case 'local_bash':\n      return {\n        id: task.id,\n        type: 'local_bash',\n        label: task.kind === 'monitor' ? task.description : task.command,\n        status: task.status,\n        task,\n      }\n    case 'remote_agent':\n      return {\n        id: task.id,\n        type: 'remote_agent',\n        label: task.title,\n        status: task.status,\n        task,\n      }\n    case 'local_agent':\n      return {\n        id: task.id,\n        type: 'local_agent',\n        label: task.description,\n        status: task.status,\n        task,\n      }\n    case 'in_process_teammate':\n      return {\n        id: task.id,\n        type: 'in_process_teammate',\n        label: `@${task.identity.agentName}`,\n        status: task.status,\n        task,\n      }\n    case 'local_workflow':\n      return {\n        id: task.id,\n        type: 'local_workflow',\n        label: task.summary ?? task.description,\n        status: task.status,\n        task,\n      }\n    case 'monitor_mcp':\n      return {\n        id: task.id,\n        type: 'monitor_mcp',\n        label: task.description,\n        status: task.status,\n        task,\n      }\n    case 'dream':\n      return {\n        id: task.id,\n        type: 'dream',\n        label: task.description,\n        status: task.status,\n        task,\n      }\n  }\n}\n\nfunction Item({\n  item,\n  isSelected,\n}: {\n  item: ListItem\n  isSelected: boolean\n}): ReactNode {\n  const { columns } = useTerminalSize()\n  // Dialog border (2) + padding (2) + pointer prefix (2) + name/status overhead (~20)\n  const maxActivityWidth = Math.max(30, columns - 26)\n  // In coordinator mode, use grey pointer instead of blue\n  const useGreyPointer = isCoordinatorMode()\n\n  return (\n    <Box flexDirection=\"row\">\n      <Text dimColor={useGreyPointer && isSelected}>\n        {isSelected ? figures.pointer + ' ' : '  '}\n      </Text>\n      <Text color={isSelected && !useGreyPointer ? 'suggestion' : undefined}>\n        {item.type === 'leader' ? (\n          <Text>@{TEAM_LEAD_NAME}</Text>\n        ) : (\n          <BackgroundTaskComponent\n            task={item.task}\n            maxActivityWidth={maxActivityWidth}\n          />\n        )}\n      </Text>\n    </Box>\n  )\n}\n\nfunction TeammateTaskGroups({\n  teammateTasks,\n  currentSelectionId,\n}: {\n  teammateTasks: ListItem[]\n  currentSelectionId: string | undefined\n}): ReactNode {\n  // Separate leader from teammates, group teammates by team\n  const leaderItems = teammateTasks.filter(i => i.type === 'leader')\n  const teammateItems = teammateTasks.filter(\n    i => i.type === 'in_process_teammate',\n  )\n  const teams = new Map<string, typeof teammateItems>()\n  for (const item of teammateItems) {\n    const teamName = item.task.identity.teamName\n    const group = teams.get(teamName)\n    if (group) {\n      group.push(item)\n    } else {\n      teams.set(teamName, [item])\n    }\n  }\n  const teamEntries = [...teams.entries()]\n  return (\n    <>\n      {teamEntries.map(([teamName, items]) => {\n        const memberCount = items.length + leaderItems.length\n        return (\n          <Box key={teamName} flexDirection=\"column\">\n            <Text dimColor>\n              {'  '}Team: {teamName} ({memberCount})\n            </Text>\n            {/* Render leader first within each team */}\n            {leaderItems.map(item => (\n              <Item\n                key={`${item.id}-${teamName}`}\n                item={item}\n                isSelected={item.id === currentSelectionId}\n              />\n            ))}\n            {items.map(item => (\n              <Item\n                key={item.id}\n                item={item}\n                isSelected={item.id === currentSelectionId}\n              />\n            ))}\n          </Box>\n        )\n      })}\n    </>\n  )\n}\n"],"mappings":"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","ignoreList":[]}