@stackmemoryai/stackmemory 0.3.16 → 0.3.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +48 -2
- package/dist/cli/commands/skills.js +15 -2
- package/dist/cli/commands/skills.js.map +2 -2
- package/dist/cli/index.js +113 -834
- package/dist/cli/index.js.map +3 -3
- package/dist/core/context/dual-stack-manager.js +1 -1
- package/dist/core/context/dual-stack-manager.js.map +1 -1
- package/dist/core/context/frame-manager.js +3 -0
- package/dist/core/context/frame-manager.js.map +2 -2
- package/dist/integrations/claude-code/subagent-client.js +106 -3
- package/dist/integrations/claude-code/subagent-client.js.map +2 -2
- package/dist/servers/railway/config.js +51 -0
- package/dist/servers/railway/config.js.map +7 -0
- package/dist/servers/railway/index-enhanced.js +156 -0
- package/dist/servers/railway/index-enhanced.js.map +7 -0
- package/dist/servers/railway/minimal.js +48 -3
- package/dist/servers/railway/minimal.js.map +2 -2
- package/dist/servers/railway/storage-test.js +455 -0
- package/dist/servers/railway/storage-test.js.map +7 -0
- package/dist/skills/claude-skills.js +13 -12
- package/dist/skills/claude-skills.js.map +2 -2
- package/dist/skills/recursive-agent-orchestrator.js +27 -18
- package/dist/skills/recursive-agent-orchestrator.js.map +2 -2
- package/dist/skills/unified-rlm-orchestrator.js.map +2 -2
- package/package.json +6 -18
- package/scripts/README-TESTING.md +186 -0
- package/scripts/analyze-cli-security.js +288 -0
- package/scripts/archive/add-phase-tasks-to-linear.js +163 -0
- package/scripts/archive/analyze-linear-duplicates.js +214 -0
- package/scripts/archive/analyze-remaining-duplicates.js +230 -0
- package/scripts/archive/analyze-sta-duplicates.js +292 -0
- package/scripts/archive/analyze-sta-graphql.js +399 -0
- package/scripts/archive/cancel-duplicate-tasks.ts +246 -0
- package/scripts/archive/check-all-duplicates.ts +419 -0
- package/scripts/archive/clean-duplicate-tasks.js +114 -0
- package/scripts/archive/cleanup-duplicate-tasks.ts +286 -0
- package/scripts/archive/create-phase-tasks.js +387 -0
- package/scripts/archive/delete-linear-duplicates.js +182 -0
- package/scripts/archive/delete-remaining-duplicates.js +158 -0
- package/scripts/archive/delete-sta-duplicates.js +201 -0
- package/scripts/archive/delete-sta-oauth.js +201 -0
- package/scripts/archive/export-sta-tasks.js +62 -0
- package/scripts/archive/install-auto-sync.js +266 -0
- package/scripts/archive/install-chromadb-hooks.sh +133 -0
- package/scripts/archive/install-enhanced-clear-hooks.sh +431 -0
- package/scripts/archive/install-post-task-hooks.sh +289 -0
- package/scripts/archive/install-stackmemory-hooks.sh +420 -0
- package/scripts/archive/merge-linear-duplicates-safe.ts +362 -0
- package/scripts/archive/merge-linear-duplicates.ts +180 -0
- package/scripts/archive/remove-sta-tasks.js +70 -0
- package/scripts/archive/setup-background-sync.sh +168 -0
- package/scripts/archive/setup-claude-auto-triggers.sh +181 -0
- package/scripts/archive/setup-claude-autostart.sh +305 -0
- package/scripts/archive/setup-git-hooks.sh +25 -0
- package/scripts/archive/setup-linear-oauth.sh +46 -0
- package/scripts/archive/setup-mcp.sh +113 -0
- package/scripts/archive/setup-railway-deployment.sh +81 -0
- package/scripts/auto-handoff.sh +262 -0
- package/scripts/background-sync-manager.js +416 -0
- package/scripts/benchmark-performance.ts +57 -0
- package/scripts/check-redis.ts +48 -0
- package/scripts/chromadb-auto-loader.sh +128 -0
- package/scripts/chromadb-context-loader.js +479 -0
- package/scripts/claude-chromadb-hook.js +460 -0
- package/scripts/claude-code-wrapper.sh +66 -0
- package/scripts/claude-linear-skill.js +455 -0
- package/scripts/claude-pre-commit.sh +302 -0
- package/scripts/claude-sm-autostart.js +532 -0
- package/scripts/claude-sm-setup.sh +367 -0
- package/scripts/claude-with-chromadb.sh +69 -0
- package/scripts/claude-worktree-manager.sh +323 -0
- package/scripts/claude-worktree-monitor.sh +371 -0
- package/scripts/claude-worktree-setup.sh +327 -0
- package/scripts/clean-linear-backlog.js +273 -0
- package/scripts/cleanup-old-sessions.sh +57 -0
- package/scripts/codex-wrapper.sh +88 -0
- package/scripts/create-sandbox.sh +269 -0
- package/scripts/debug-linear-update.js +174 -0
- package/scripts/delete-linear-tasks.js +167 -0
- package/scripts/deploy.sh +89 -0
- package/scripts/deployment/railway.sh +352 -0
- package/scripts/deployment/test-deployment.js +194 -0
- package/scripts/detect-and-rehydrate.js +162 -0
- package/scripts/detect-and-rehydrate.mjs +165 -0
- package/scripts/development/create-demo-tasks.js +143 -0
- package/scripts/development/debug-frame-test.js +16 -0
- package/scripts/development/demo-auto-sync.js +128 -0
- package/scripts/development/fix-all-imports.js +213 -0
- package/scripts/development/fix-imports.js +229 -0
- package/scripts/development/fix-lint-loop.cjs +103 -0
- package/scripts/development/fix-project-id.ts +161 -0
- package/scripts/development/fix-strict-mode-issues.ts +291 -0
- package/scripts/development/reorganize-structure.sh +228 -0
- package/scripts/development/test-persistence-direct.js +148 -0
- package/scripts/development/test-persistence.js +114 -0
- package/scripts/development/test-tasks.js +93 -0
- package/scripts/development/update-imports.js +212 -0
- package/scripts/fetch-linear-status.js +125 -0
- package/scripts/git-hooks/README.md +310 -0
- package/scripts/git-hooks/branch-context-manager.sh +342 -0
- package/scripts/git-hooks/post-checkout-stackmemory.sh +63 -0
- package/scripts/git-hooks/post-commit-stackmemory.sh +305 -0
- package/scripts/git-hooks/pre-commit-stackmemory.sh +275 -0
- package/scripts/hooks/cleanup-shell.sh +130 -0
- package/scripts/hooks/task-complete.sh +114 -0
- package/scripts/initialize.ts +129 -0
- package/scripts/install-claude-hooks-auto.js +104 -0
- package/scripts/install-claude-hooks.sh +133 -0
- package/scripts/install-global.sh +296 -0
- package/scripts/install.sh +235 -0
- package/scripts/linear-auto-sync.js +262 -0
- package/scripts/linear-auto-sync.sh +161 -0
- package/scripts/linear-sync-daemon.js +150 -0
- package/scripts/linear-task-review.js +237 -0
- package/scripts/list-linear-tasks.ts +178 -0
- package/scripts/mcp-proxy.js +66 -0
- package/scripts/opencode-wrapper.sh +85 -0
- package/scripts/publish-local.js +74 -0
- package/scripts/query-chromadb.ts +201 -0
- package/scripts/railway-env-setup.sh +39 -0
- package/scripts/reconcile-local-tasks.js +170 -0
- package/scripts/recreate-frames-db.js +89 -0
- package/scripts/setup/claude-integration.js +138 -0
- package/scripts/setup/configure-alias.js +125 -0
- package/scripts/setup/configure-codex-alias.js +161 -0
- package/scripts/setup/configure-opencode-alias.js +175 -0
- package/scripts/setup-claude-integration.js +204 -0
- package/scripts/setup-claude-integration.sh +183 -0
- package/scripts/setup.sh +31 -0
- package/scripts/show-linear-summary.ts +172 -0
- package/scripts/stackmemory-auto-handoff.sh +231 -0
- package/scripts/stackmemory-daemon.sh +40 -0
- package/scripts/start-linear-sync-daemon.sh +141 -0
- package/scripts/start-temporal-paradox.sh +214 -0
- package/scripts/status.ts +159 -0
- package/scripts/sync-and-clean-tasks.js +258 -0
- package/scripts/sync-frames-from-railway.js +228 -0
- package/scripts/sync-linear-graphql.js +303 -0
- package/scripts/sync-linear-tasks.js +186 -0
- package/scripts/test-auto-triggers.sh +57 -0
- package/scripts/test-browser-mcp.js +74 -0
- package/scripts/test-chromadb-full.js +115 -0
- package/scripts/test-chromadb-hooks.sh +28 -0
- package/scripts/test-chromadb-sync.ts +245 -0
- package/scripts/test-cli-security.js +293 -0
- package/scripts/test-hooks-persistence.sh +220 -0
- package/scripts/test-installation-scenarios.sh +359 -0
- package/scripts/test-installation.sh +224 -0
- package/scripts/test-mcp.js +163 -0
- package/scripts/test-pre-publish-quick.sh +75 -0
- package/scripts/test-quality-gates.sh +263 -0
- package/scripts/test-railway-db.js +222 -0
- package/scripts/test-redis-storage.ts +490 -0
- package/scripts/test-rlm-basic.sh +122 -0
- package/scripts/test-rlm-comprehensive.sh +260 -0
- package/scripts/test-rlm-e2e.sh +268 -0
- package/scripts/test-rlm-simple.js +90 -0
- package/scripts/test-rlm.js +110 -0
- package/scripts/test-session-handoff.sh +165 -0
- package/scripts/test-shell-integration.sh +275 -0
- package/scripts/testing/ab-test-runner.ts +508 -0
- package/scripts/testing/collect-metrics.ts +457 -0
- package/scripts/testing/quick-effectiveness-demo.js +187 -0
- package/scripts/testing/real-performance-test.js +422 -0
- package/scripts/testing/run-effectiveness-tests.sh +176 -0
- package/scripts/testing/scripts/testing/ab-test-runner.js +363 -0
- package/scripts/testing/scripts/testing/collect-metrics.js +292 -0
- package/scripts/testing/simple-effectiveness-test.js +310 -0
- package/scripts/testing/src/core/context/context-bridge.js +253 -0
- package/scripts/testing/src/core/context/frame-manager.js +746 -0
- package/scripts/testing/src/core/context/shared-context-layer.js +437 -0
- package/scripts/testing/src/core/database/database-adapter.js +54 -0
- package/scripts/testing/src/core/errors/index.js +291 -0
- package/scripts/testing/src/core/errors/recovery.js +268 -0
- package/scripts/testing/src/core/monitoring/logger.js +145 -0
- package/scripts/testing/src/core/retrieval/context-retriever.js +516 -0
- package/scripts/testing/src/core/session/index.js +1 -0
- package/scripts/testing/src/core/session/session-manager.js +323 -0
- package/scripts/testing/src/core/trace/cli-trace-wrapper.js +140 -0
- package/scripts/testing/src/core/trace/db-trace-wrapper.js +251 -0
- package/scripts/testing/src/core/trace/debug-trace.js +398 -0
- package/scripts/testing/src/core/trace/index.js +120 -0
- package/scripts/testing/src/core/trace/linear-api-wrapper.js +204 -0
- package/scripts/update-linear-status.js +268 -0
- package/scripts/update-linear-tasks-fixed.js +284 -0
- package/templates/claude-hooks/hooks.json +5 -0
- package/templates/claude-hooks/on-clear.js +56 -0
- package/templates/claude-hooks/on-startup.js +56 -0
- package/templates/claude-hooks/tool-use-trace.js +67 -0
- package/dist/features/tui/components/analytics-panel.js +0 -157
- package/dist/features/tui/components/analytics-panel.js.map +0 -7
- package/dist/features/tui/components/frame-visualizer.js +0 -377
- package/dist/features/tui/components/frame-visualizer.js.map +0 -7
- package/dist/features/tui/components/pr-tracker.js +0 -135
- package/dist/features/tui/components/pr-tracker.js.map +0 -7
- package/dist/features/tui/components/session-monitor.js +0 -299
- package/dist/features/tui/components/session-monitor.js.map +0 -7
- package/dist/features/tui/components/subagent-fleet.js +0 -395
- package/dist/features/tui/components/subagent-fleet.js.map +0 -7
- package/dist/features/tui/components/task-board.js +0 -1139
- package/dist/features/tui/components/task-board.js.map +0 -7
- package/dist/features/tui/index.js +0 -408
- package/dist/features/tui/index.js.map +0 -7
- package/dist/features/tui/services/data-service.js +0 -641
- package/dist/features/tui/services/data-service.js.map +0 -7
- package/dist/features/tui/services/linear-task-reader.js +0 -102
- package/dist/features/tui/services/linear-task-reader.js.map +0 -7
- package/dist/features/tui/services/websocket-client.js +0 -162
- package/dist/features/tui/services/websocket-client.js.map +0 -7
- package/dist/features/tui/terminal-compat.js +0 -220
- package/dist/features/tui/terminal-compat.js.map +0 -7
- package/dist/features/tui/types.js +0 -1
- package/dist/features/tui/types.js.map +0 -7
|
@@ -1,395 +0,0 @@
|
|
|
1
|
-
import blessed from "blessed";
|
|
2
|
-
import { EventEmitter } from "events";
|
|
3
|
-
class SubagentFleet extends EventEmitter {
|
|
4
|
-
container;
|
|
5
|
-
agentList;
|
|
6
|
-
statsBox;
|
|
7
|
-
agents;
|
|
8
|
-
selectedAgent = null;
|
|
9
|
-
constructor(container) {
|
|
10
|
-
super();
|
|
11
|
-
this.container = container;
|
|
12
|
-
this.agents = /* @__PURE__ */ new Map();
|
|
13
|
-
this.initializeUI();
|
|
14
|
-
}
|
|
15
|
-
initializeUI() {
|
|
16
|
-
this.agentList = blessed.list({
|
|
17
|
-
parent: this.container,
|
|
18
|
-
top: 0,
|
|
19
|
-
left: 0,
|
|
20
|
-
width: "60%",
|
|
21
|
-
height: "100%-3",
|
|
22
|
-
style: {
|
|
23
|
-
selected: {
|
|
24
|
-
bg: "magenta",
|
|
25
|
-
fg: "white",
|
|
26
|
-
bold: true
|
|
27
|
-
},
|
|
28
|
-
item: {
|
|
29
|
-
fg: "white"
|
|
30
|
-
}
|
|
31
|
-
},
|
|
32
|
-
mouse: true,
|
|
33
|
-
keys: true,
|
|
34
|
-
vi: true,
|
|
35
|
-
scrollable: true,
|
|
36
|
-
tags: true
|
|
37
|
-
});
|
|
38
|
-
this.statsBox = blessed.box({
|
|
39
|
-
parent: this.container,
|
|
40
|
-
top: 0,
|
|
41
|
-
right: 0,
|
|
42
|
-
width: "40%",
|
|
43
|
-
height: "100%-3",
|
|
44
|
-
content: this.getFleetStats(),
|
|
45
|
-
tags: true,
|
|
46
|
-
scrollable: true,
|
|
47
|
-
style: {
|
|
48
|
-
fg: "white"
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
const footer = blessed.box({
|
|
52
|
-
parent: this.container,
|
|
53
|
-
bottom: 0,
|
|
54
|
-
left: 0,
|
|
55
|
-
width: "100%",
|
|
56
|
-
height: 3,
|
|
57
|
-
content: "Fleet: 0 agents | Active: 0 | Idle: 0",
|
|
58
|
-
tags: true,
|
|
59
|
-
style: {
|
|
60
|
-
fg: "white",
|
|
61
|
-
bg: "black"
|
|
62
|
-
}
|
|
63
|
-
});
|
|
64
|
-
this.agentList.on("select", (item, index) => {
|
|
65
|
-
const agentId = Array.from(this.agents.keys())[index];
|
|
66
|
-
this.selectAgent(agentId);
|
|
67
|
-
});
|
|
68
|
-
this.setupKeyboardShortcuts();
|
|
69
|
-
}
|
|
70
|
-
setupKeyboardShortcuts() {
|
|
71
|
-
this.container.key(["t"], () => {
|
|
72
|
-
if (this.selectedAgent) {
|
|
73
|
-
this.terminateAgent(this.selectedAgent);
|
|
74
|
-
}
|
|
75
|
-
});
|
|
76
|
-
this.container.key(["r"], () => {
|
|
77
|
-
if (this.selectedAgent) {
|
|
78
|
-
this.restartAgent(this.selectedAgent);
|
|
79
|
-
}
|
|
80
|
-
});
|
|
81
|
-
this.container.key(["l"], () => {
|
|
82
|
-
if (this.selectedAgent) {
|
|
83
|
-
this.showAgentLogs(this.selectedAgent);
|
|
84
|
-
}
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
/**
|
|
88
|
-
* Format agent item for display
|
|
89
|
-
*/
|
|
90
|
-
formatAgentItem(agent) {
|
|
91
|
-
const status = this.getStatusIcon(agent.status);
|
|
92
|
-
const type = this.getAgentTypeIcon(agent.type);
|
|
93
|
-
const successRate = Math.round(agent.successRate * 100);
|
|
94
|
-
const rateColor = successRate >= 90 ? "green" : successRate >= 70 ? "yellow" : "red";
|
|
95
|
-
let item = `${status} ${type} ${agent.type} (${agent.id.substring(0, 8)})
|
|
96
|
-
`;
|
|
97
|
-
if (agent.currentTask) {
|
|
98
|
-
const progress = Math.round(agent.currentTask.progress * 100);
|
|
99
|
-
const elapsed = this.formatDuration(
|
|
100
|
-
Date.now() - agent.currentTask.startTime
|
|
101
|
-
);
|
|
102
|
-
item += ` {cyan-fg}\u25B6 ${agent.currentTask.description.substring(0, 30)}...{/}
|
|
103
|
-
`;
|
|
104
|
-
item += ` Progress: ${this.createProgressBar(agent.currentTask.progress)} ${progress}% (${elapsed})`;
|
|
105
|
-
} else {
|
|
106
|
-
item += ` Completed: ${agent.tasksCompleted} | Failed: ${agent.tasksFailed}
|
|
107
|
-
`;
|
|
108
|
-
item += ` Success Rate: {${rateColor}-fg}${successRate}%{/} | Avg Time: ${this.formatDuration(agent.averageTime)}`;
|
|
109
|
-
}
|
|
110
|
-
if (agent.cpuUsage !== void 0 || agent.memoryUsage !== void 0) {
|
|
111
|
-
item += "\n ";
|
|
112
|
-
if (agent.cpuUsage !== void 0) {
|
|
113
|
-
const cpuColor = agent.cpuUsage > 80 ? "red" : agent.cpuUsage > 50 ? "yellow" : "green";
|
|
114
|
-
item += `CPU: {${cpuColor}-fg}${Math.round(agent.cpuUsage)}%{/} `;
|
|
115
|
-
}
|
|
116
|
-
if (agent.memoryUsage !== void 0) {
|
|
117
|
-
const memColor = agent.memoryUsage > 80 ? "red" : agent.memoryUsage > 50 ? "yellow" : "green";
|
|
118
|
-
item += `MEM: {${memColor}-fg}${Math.round(agent.memoryUsage)}%{/} `;
|
|
119
|
-
}
|
|
120
|
-
if (agent.tokenUsage !== void 0) {
|
|
121
|
-
item += `Tokens: ${this.formatTokens(agent.tokenUsage)}`;
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
if (agent.lastError) {
|
|
125
|
-
const errorAge = this.formatDuration(
|
|
126
|
-
Date.now() - agent.lastError.timestamp
|
|
127
|
-
);
|
|
128
|
-
item += `
|
|
129
|
-
{red-fg}\u26A0 Error ${errorAge} ago: ${agent.lastError.message.substring(0, 40)}{/}`;
|
|
130
|
-
}
|
|
131
|
-
return item;
|
|
132
|
-
}
|
|
133
|
-
getStatusIcon(status) {
|
|
134
|
-
switch (status) {
|
|
135
|
-
case "active":
|
|
136
|
-
return "{green-fg}\u25CF{/}";
|
|
137
|
-
case "idle":
|
|
138
|
-
return "{cyan-fg}\u25CF{/}";
|
|
139
|
-
case "error":
|
|
140
|
-
return "{red-fg}\u25CF{/}";
|
|
141
|
-
case "completed":
|
|
142
|
-
return "{gray-fg}\u25CF{/}";
|
|
143
|
-
default:
|
|
144
|
-
return "{white-fg}\u25CB{/}";
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
getAgentTypeIcon(type) {
|
|
148
|
-
const icons = {
|
|
149
|
-
analyzer: "\u{1F50D}",
|
|
150
|
-
builder: "\u{1F528}",
|
|
151
|
-
debugger: "\u{1F41B}",
|
|
152
|
-
tester: "\u{1F9EA}",
|
|
153
|
-
reviewer: "\u{1F441}\uFE0F",
|
|
154
|
-
refactorer: "\u267B\uFE0F",
|
|
155
|
-
documenter: "\u{1F4DD}",
|
|
156
|
-
security: "\u{1F512}",
|
|
157
|
-
performance: "\u26A1",
|
|
158
|
-
general: "\u{1F916}"
|
|
159
|
-
};
|
|
160
|
-
return icons[type.toLowerCase()] || "\u{1F916}";
|
|
161
|
-
}
|
|
162
|
-
createProgressBar(progress) {
|
|
163
|
-
const width = 10;
|
|
164
|
-
const filled = Math.round(progress * width);
|
|
165
|
-
const empty = width - filled;
|
|
166
|
-
const color = progress >= 0.8 ? "green" : progress >= 0.5 ? "yellow" : "cyan";
|
|
167
|
-
return `{${color}-fg}${"\u2588".repeat(filled)}{/}{gray-fg}${"\u2591".repeat(empty)}{/}`;
|
|
168
|
-
}
|
|
169
|
-
formatDuration(ms) {
|
|
170
|
-
if (ms < 1e3) return `${ms}ms`;
|
|
171
|
-
if (ms < 6e4) return `${Math.round(ms / 1e3)}s`;
|
|
172
|
-
if (ms < 36e5) return `${Math.round(ms / 6e4)}m`;
|
|
173
|
-
return `${Math.round(ms / 36e5)}h`;
|
|
174
|
-
}
|
|
175
|
-
formatTokens(tokens) {
|
|
176
|
-
if (tokens < 1e3) return `${tokens}`;
|
|
177
|
-
if (tokens < 1e6) return `${(tokens / 1e3).toFixed(1)}K`;
|
|
178
|
-
return `${(tokens / 1e6).toFixed(1)}M`;
|
|
179
|
-
}
|
|
180
|
-
/**
|
|
181
|
-
* Generate fleet statistics
|
|
182
|
-
*/
|
|
183
|
-
getFleetStats() {
|
|
184
|
-
const agents = Array.from(this.agents.values());
|
|
185
|
-
if (agents.length === 0) {
|
|
186
|
-
return "{gray-fg}No agents active{/}";
|
|
187
|
-
}
|
|
188
|
-
const stats = {
|
|
189
|
-
total: agents.length,
|
|
190
|
-
active: agents.filter((a) => a.status === "active").length,
|
|
191
|
-
idle: agents.filter((a) => a.status === "idle").length,
|
|
192
|
-
error: agents.filter((a) => a.status === "error").length,
|
|
193
|
-
totalTasks: agents.reduce(
|
|
194
|
-
(sum, a) => sum + a.tasksCompleted + a.tasksFailed,
|
|
195
|
-
0
|
|
196
|
-
),
|
|
197
|
-
successfulTasks: agents.reduce((sum, a) => sum + a.tasksCompleted, 0),
|
|
198
|
-
failedTasks: agents.reduce((sum, a) => sum + a.tasksFailed, 0),
|
|
199
|
-
avgSuccessRate: agents.reduce((sum, a) => sum + a.successRate, 0) / agents.length,
|
|
200
|
-
totalTokens: agents.reduce((sum, a) => sum + (a.tokenUsage || 0), 0),
|
|
201
|
-
avgCpu: agents.reduce((sum, a) => sum + (a.cpuUsage || 0), 0) / agents.length,
|
|
202
|
-
avgMemory: agents.reduce((sum, a) => sum + (a.memoryUsage || 0), 0) / agents.length
|
|
203
|
-
};
|
|
204
|
-
const typeGroups = /* @__PURE__ */ new Map();
|
|
205
|
-
agents.forEach((agent) => {
|
|
206
|
-
typeGroups.set(agent.type, (typeGroups.get(agent.type) || 0) + 1);
|
|
207
|
-
});
|
|
208
|
-
let output = "{bold}Fleet Statistics{/}\n\n";
|
|
209
|
-
output += "{bold}Status:{/}\n";
|
|
210
|
-
output += ` Total: ${stats.total}
|
|
211
|
-
`;
|
|
212
|
-
output += ` Active: {green-fg}${stats.active}{/}
|
|
213
|
-
`;
|
|
214
|
-
output += ` Idle: {cyan-fg}${stats.idle}{/}
|
|
215
|
-
`;
|
|
216
|
-
output += ` Error: {red-fg}${stats.error}{/}
|
|
217
|
-
`;
|
|
218
|
-
output += "\n{bold}Performance:{/}\n";
|
|
219
|
-
output += ` Tasks: ${stats.successfulTasks}/${stats.totalTasks}
|
|
220
|
-
`;
|
|
221
|
-
const rateColor = stats.avgSuccessRate >= 0.9 ? "green" : stats.avgSuccessRate >= 0.7 ? "yellow" : "red";
|
|
222
|
-
output += ` Success: {${rateColor}-fg}${Math.round(stats.avgSuccessRate * 100)}%{/}
|
|
223
|
-
`;
|
|
224
|
-
output += ` Tokens: ${this.formatTokens(stats.totalTokens)}
|
|
225
|
-
`;
|
|
226
|
-
output += "\n{bold}Resources:{/}\n";
|
|
227
|
-
const cpuColor = stats.avgCpu > 80 ? "red" : stats.avgCpu > 50 ? "yellow" : "green";
|
|
228
|
-
const memColor = stats.avgMemory > 80 ? "red" : stats.avgMemory > 50 ? "yellow" : "green";
|
|
229
|
-
output += ` CPU: {${cpuColor}-fg}${Math.round(stats.avgCpu)}%{/}
|
|
230
|
-
`;
|
|
231
|
-
output += ` Memory: {${memColor}-fg}${Math.round(stats.avgMemory)}%{/}
|
|
232
|
-
`;
|
|
233
|
-
output += "\n{bold}Types:{/}\n";
|
|
234
|
-
Array.from(typeGroups.entries()).sort((a, b) => b[1] - a[1]).forEach(([type, count]) => {
|
|
235
|
-
const icon = this.getAgentTypeIcon(type);
|
|
236
|
-
output += ` ${icon} ${type}: ${count}
|
|
237
|
-
`;
|
|
238
|
-
});
|
|
239
|
-
return output;
|
|
240
|
-
}
|
|
241
|
-
update(agents) {
|
|
242
|
-
this.agents.clear();
|
|
243
|
-
agents.forEach((agent) => {
|
|
244
|
-
this.agents.set(agent.id, agent);
|
|
245
|
-
});
|
|
246
|
-
const items = agents.map((agent) => this.formatAgentItem(agent));
|
|
247
|
-
this.agentList.setItems(items);
|
|
248
|
-
this.statsBox.setContent(this.getFleetStats());
|
|
249
|
-
const active = agents.filter((a) => a.status === "active").length;
|
|
250
|
-
const idle = agents.filter((a) => a.status === "idle").length;
|
|
251
|
-
const total = agents.length;
|
|
252
|
-
const footer = this.container.children[2];
|
|
253
|
-
if (footer) {
|
|
254
|
-
footer.setContent(
|
|
255
|
-
`{bold}Fleet:{/} ${total} agents | {bold}Active:{/} {green-fg}${active}{/} | {bold}Idle:{/} {cyan-fg}${idle}{/}`
|
|
256
|
-
);
|
|
257
|
-
}
|
|
258
|
-
this.container.screen.render();
|
|
259
|
-
}
|
|
260
|
-
selectAgent(agentId) {
|
|
261
|
-
this.selectedAgent = agentId;
|
|
262
|
-
const agent = this.agents.get(agentId);
|
|
263
|
-
if (agent) {
|
|
264
|
-
this.emit("agent:selected", agent);
|
|
265
|
-
this.showAgentDetails(agent);
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
showAgentDetails(agent) {
|
|
269
|
-
const details = blessed.box({
|
|
270
|
-
parent: this.container.screen,
|
|
271
|
-
top: "center",
|
|
272
|
-
left: "center",
|
|
273
|
-
width: "70%",
|
|
274
|
-
height: "70%",
|
|
275
|
-
content: this.formatAgentDetails(agent),
|
|
276
|
-
tags: true,
|
|
277
|
-
border: {
|
|
278
|
-
type: "line"
|
|
279
|
-
},
|
|
280
|
-
style: {
|
|
281
|
-
border: {
|
|
282
|
-
fg: "magenta"
|
|
283
|
-
}
|
|
284
|
-
},
|
|
285
|
-
scrollable: true,
|
|
286
|
-
keys: true,
|
|
287
|
-
vi: true,
|
|
288
|
-
mouse: true,
|
|
289
|
-
hidden: false,
|
|
290
|
-
label: ` Agent: ${agent.type} (${agent.id}) `
|
|
291
|
-
});
|
|
292
|
-
details.key(["escape", "q"], () => {
|
|
293
|
-
details.destroy();
|
|
294
|
-
this.container.screen.render();
|
|
295
|
-
});
|
|
296
|
-
details.focus();
|
|
297
|
-
this.container.screen.render();
|
|
298
|
-
}
|
|
299
|
-
formatAgentDetails(agent) {
|
|
300
|
-
let details = `{bold}Agent ID:{/} ${agent.id}
|
|
301
|
-
`;
|
|
302
|
-
details += `{bold}Type:{/} ${this.getAgentTypeIcon(agent.type)} ${agent.type}
|
|
303
|
-
`;
|
|
304
|
-
details += `{bold}Status:{/} ${this.getStatusIcon(agent.status)} ${agent.status}
|
|
305
|
-
`;
|
|
306
|
-
if (agent.currentTask) {
|
|
307
|
-
details += `
|
|
308
|
-
{bold}Current Task:{/}
|
|
309
|
-
`;
|
|
310
|
-
details += ` ID: ${agent.currentTask.id}
|
|
311
|
-
`;
|
|
312
|
-
details += ` Description: ${agent.currentTask.description}
|
|
313
|
-
`;
|
|
314
|
-
details += ` Progress: ${Math.round(agent.currentTask.progress * 100)}%
|
|
315
|
-
`;
|
|
316
|
-
details += ` Started: ${new Date(agent.currentTask.startTime).toLocaleString()}
|
|
317
|
-
`;
|
|
318
|
-
details += ` Elapsed: ${this.formatDuration(Date.now() - agent.currentTask.startTime)}
|
|
319
|
-
`;
|
|
320
|
-
}
|
|
321
|
-
details += `
|
|
322
|
-
{bold}Performance Metrics:{/}
|
|
323
|
-
`;
|
|
324
|
-
details += ` Tasks Completed: ${agent.tasksCompleted}
|
|
325
|
-
`;
|
|
326
|
-
details += ` Tasks Failed: ${agent.tasksFailed}
|
|
327
|
-
`;
|
|
328
|
-
details += ` Success Rate: ${Math.round(agent.successRate * 100)}%
|
|
329
|
-
`;
|
|
330
|
-
details += ` Average Time: ${this.formatDuration(agent.averageTime)}
|
|
331
|
-
`;
|
|
332
|
-
if (agent.cpuUsage !== void 0 || agent.memoryUsage !== void 0 || agent.tokenUsage !== void 0) {
|
|
333
|
-
details += `
|
|
334
|
-
{bold}Resource Usage:{/}
|
|
335
|
-
`;
|
|
336
|
-
if (agent.cpuUsage !== void 0) {
|
|
337
|
-
details += ` CPU: ${Math.round(agent.cpuUsage)}%
|
|
338
|
-
`;
|
|
339
|
-
}
|
|
340
|
-
if (agent.memoryUsage !== void 0) {
|
|
341
|
-
details += ` Memory: ${Math.round(agent.memoryUsage)}%
|
|
342
|
-
`;
|
|
343
|
-
}
|
|
344
|
-
if (agent.tokenUsage !== void 0) {
|
|
345
|
-
details += ` Tokens: ${this.formatTokens(agent.tokenUsage)}
|
|
346
|
-
`;
|
|
347
|
-
}
|
|
348
|
-
}
|
|
349
|
-
if (agent.lastError) {
|
|
350
|
-
details += `
|
|
351
|
-
{bold}Last Error:{/}
|
|
352
|
-
`;
|
|
353
|
-
details += ` Message: ${agent.lastError.message}
|
|
354
|
-
`;
|
|
355
|
-
details += ` Time: ${new Date(agent.lastError.timestamp).toLocaleString()}
|
|
356
|
-
`;
|
|
357
|
-
details += ` Recoverable: ${agent.lastError.recoverable ? "Yes" : "No"}
|
|
358
|
-
`;
|
|
359
|
-
}
|
|
360
|
-
details += `
|
|
361
|
-
{gray-fg}[t] Terminate | [r] Restart | [l] View Logs{/}
|
|
362
|
-
`;
|
|
363
|
-
return details;
|
|
364
|
-
}
|
|
365
|
-
terminateAgent(agentId) {
|
|
366
|
-
this.emit("agent:terminate", { agentId });
|
|
367
|
-
const agent = this.agents.get(agentId);
|
|
368
|
-
if (agent) {
|
|
369
|
-
agent.status = "completed";
|
|
370
|
-
this.update(Array.from(this.agents.values()));
|
|
371
|
-
}
|
|
372
|
-
}
|
|
373
|
-
restartAgent(agentId) {
|
|
374
|
-
this.emit("agent:restart", { agentId });
|
|
375
|
-
const agent = this.agents.get(agentId);
|
|
376
|
-
if (agent) {
|
|
377
|
-
agent.status = "idle";
|
|
378
|
-
agent.lastError = void 0;
|
|
379
|
-
this.update(Array.from(this.agents.values()));
|
|
380
|
-
}
|
|
381
|
-
}
|
|
382
|
-
showAgentLogs(agentId) {
|
|
383
|
-
this.emit("agent:logs", { agentId });
|
|
384
|
-
}
|
|
385
|
-
focus() {
|
|
386
|
-
this.agentList.focus();
|
|
387
|
-
}
|
|
388
|
-
hasFocus() {
|
|
389
|
-
return this.agentList === this.container.screen.focused;
|
|
390
|
-
}
|
|
391
|
-
}
|
|
392
|
-
export {
|
|
393
|
-
SubagentFleet
|
|
394
|
-
};
|
|
395
|
-
//# sourceMappingURL=subagent-fleet.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../../src/features/tui/components/subagent-fleet.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Subagent Fleet Component\n * Monitors and displays status of all active subagents\n */\n\nimport blessed from 'blessed';\nimport { EventEmitter } from 'events';\nimport type { SubagentData } from '../types.js';\n\nexport class SubagentFleet extends EventEmitter {\n private container: blessed.Widgets.BoxElement;\n private agentList: blessed.Widgets.ListElement;\n private statsBox: blessed.Widgets.BoxElement;\n private agents: Map<string, SubagentData>;\n private selectedAgent: string | null = null;\n\n constructor(container: blessed.Widgets.BoxElement) {\n super();\n this.container = container;\n this.agents = new Map();\n this.initializeUI();\n }\n\n private initializeUI(): void {\n // Agent list (left side)\n this.agentList = blessed.list({\n parent: this.container,\n top: 0,\n left: 0,\n width: '60%',\n height: '100%-3',\n style: {\n selected: {\n bg: 'magenta',\n fg: 'white',\n bold: true,\n },\n item: {\n fg: 'white',\n },\n },\n mouse: true,\n keys: true,\n vi: true,\n scrollable: true,\n tags: true,\n });\n\n // Stats panel (right side)\n this.statsBox = blessed.box({\n parent: this.container,\n top: 0,\n right: 0,\n width: '40%',\n height: '100%-3',\n content: this.getFleetStats(),\n tags: true,\n scrollable: true,\n style: {\n fg: 'white',\n },\n });\n\n // Fleet summary footer\n const footer = blessed.box({\n parent: this.container,\n bottom: 0,\n left: 0,\n width: '100%',\n height: 3,\n content: 'Fleet: 0 agents | Active: 0 | Idle: 0',\n tags: true,\n style: {\n fg: 'white',\n bg: 'black',\n },\n });\n\n this.agentList.on('select', (item, index) => {\n const agentId = Array.from(this.agents.keys())[index];\n this.selectAgent(agentId);\n });\n\n // Keyboard shortcuts\n this.setupKeyboardShortcuts();\n }\n\n private setupKeyboardShortcuts(): void {\n this.container.key(['t'], () => {\n if (this.selectedAgent) {\n this.terminateAgent(this.selectedAgent);\n }\n });\n\n this.container.key(['r'], () => {\n if (this.selectedAgent) {\n this.restartAgent(this.selectedAgent);\n }\n });\n\n this.container.key(['l'], () => {\n if (this.selectedAgent) {\n this.showAgentLogs(this.selectedAgent);\n }\n });\n }\n\n /**\n * Format agent item for display\n */\n private formatAgentItem(agent: SubagentData): string {\n const status = this.getStatusIcon(agent.status);\n const type = this.getAgentTypeIcon(agent.type);\n const successRate = Math.round(agent.successRate * 100);\n const rateColor =\n successRate >= 90 ? 'green' : successRate >= 70 ? 'yellow' : 'red';\n\n let item = `${status} ${type} ${agent.type} (${agent.id.substring(0, 8)})\\n`;\n\n if (agent.currentTask) {\n const progress = Math.round(agent.currentTask.progress * 100);\n const elapsed = this.formatDuration(\n Date.now() - agent.currentTask.startTime\n );\n item += ` {cyan-fg}\u25B6 ${agent.currentTask.description.substring(0, 30)}...{/}\\n`;\n item += ` Progress: ${this.createProgressBar(agent.currentTask.progress)} ${progress}% (${elapsed})`;\n } else {\n item += ` Completed: ${agent.tasksCompleted} | Failed: ${agent.tasksFailed}\\n`;\n item += ` Success Rate: {${rateColor}-fg}${successRate}%{/} | Avg Time: ${this.formatDuration(agent.averageTime)}`;\n }\n\n // Resource usage indicators\n if (agent.cpuUsage !== undefined || agent.memoryUsage !== undefined) {\n item += '\\n ';\n if (agent.cpuUsage !== undefined) {\n const cpuColor =\n agent.cpuUsage > 80\n ? 'red'\n : agent.cpuUsage > 50\n ? 'yellow'\n : 'green';\n item += `CPU: {${cpuColor}-fg}${Math.round(agent.cpuUsage)}%{/} `;\n }\n if (agent.memoryUsage !== undefined) {\n const memColor =\n agent.memoryUsage > 80\n ? 'red'\n : agent.memoryUsage > 50\n ? 'yellow'\n : 'green';\n item += `MEM: {${memColor}-fg}${Math.round(agent.memoryUsage)}%{/} `;\n }\n if (agent.tokenUsage !== undefined) {\n item += `Tokens: ${this.formatTokens(agent.tokenUsage)}`;\n }\n }\n\n // Error indicator\n if (agent.lastError) {\n const errorAge = this.formatDuration(\n Date.now() - agent.lastError.timestamp\n );\n item += `\\n {red-fg}\u26A0 Error ${errorAge} ago: ${agent.lastError.message.substring(0, 40)}{/}`;\n }\n\n return item;\n }\n\n private getStatusIcon(status: string): string {\n switch (status) {\n case 'active':\n return '{green-fg}\u25CF{/}';\n case 'idle':\n return '{cyan-fg}\u25CF{/}';\n case 'error':\n return '{red-fg}\u25CF{/}';\n case 'completed':\n return '{gray-fg}\u25CF{/}';\n default:\n return '{white-fg}\u25CB{/}';\n }\n }\n\n private getAgentTypeIcon(type: string): string {\n const icons: Record<string, string> = {\n analyzer: '\uD83D\uDD0D',\n builder: '\uD83D\uDD28',\n debugger: '\uD83D\uDC1B',\n tester: '\uD83E\uDDEA',\n reviewer: '\uD83D\uDC41\uFE0F',\n refactorer: '\u267B\uFE0F',\n documenter: '\uD83D\uDCDD',\n security: '\uD83D\uDD12',\n performance: '\u26A1',\n general: '\uD83E\uDD16',\n };\n return icons[type.toLowerCase()] || '\uD83E\uDD16';\n }\n\n private createProgressBar(progress: number): string {\n const width = 10;\n const filled = Math.round(progress * width);\n const empty = width - filled;\n\n const color =\n progress >= 0.8 ? 'green' : progress >= 0.5 ? 'yellow' : 'cyan';\n return `{${color}-fg}${'\u2588'.repeat(filled)}{/}{gray-fg}${'\u2591'.repeat(empty)}{/}`;\n }\n\n private formatDuration(ms: number): string {\n if (ms < 1000) return `${ms}ms`;\n if (ms < 60000) return `${Math.round(ms / 1000)}s`;\n if (ms < 3600000) return `${Math.round(ms / 60000)}m`;\n return `${Math.round(ms / 3600000)}h`;\n }\n\n private formatTokens(tokens: number): string {\n if (tokens < 1000) return `${tokens}`;\n if (tokens < 1000000) return `${(tokens / 1000).toFixed(1)}K`;\n return `${(tokens / 1000000).toFixed(1)}M`;\n }\n\n /**\n * Generate fleet statistics\n */\n private getFleetStats(): string {\n const agents = Array.from(this.agents.values());\n\n if (agents.length === 0) {\n return '{gray-fg}No agents active{/}';\n }\n\n // Calculate statistics\n const stats = {\n total: agents.length,\n active: agents.filter((a: any) => a.status === 'active').length,\n idle: agents.filter((a: any) => a.status === 'idle').length,\n error: agents.filter((a: any) => a.status === 'error').length,\n totalTasks: agents.reduce(\n (sum, a) => sum + a.tasksCompleted + a.tasksFailed,\n 0\n ),\n successfulTasks: agents.reduce((sum, a) => sum + a.tasksCompleted, 0),\n failedTasks: agents.reduce((sum, a) => sum + a.tasksFailed, 0),\n avgSuccessRate:\n agents.reduce((sum, a) => sum + a.successRate, 0) / agents.length,\n totalTokens: agents.reduce((sum, a) => sum + (a.tokenUsage || 0), 0),\n avgCpu:\n agents.reduce((sum, a) => sum + (a.cpuUsage || 0), 0) / agents.length,\n avgMemory:\n agents.reduce((sum, a) => sum + (a.memoryUsage || 0), 0) /\n agents.length,\n };\n\n // Group by type\n const typeGroups = new Map<string, number>();\n agents.forEach((agent) => {\n typeGroups.set(agent.type, (typeGroups.get(agent.type) || 0) + 1);\n });\n\n let output = '{bold}Fleet Statistics{/}\\n\\n';\n\n output += '{bold}Status:{/}\\n';\n output += ` Total: ${stats.total}\\n`;\n output += ` Active: {green-fg}${stats.active}{/}\\n`;\n output += ` Idle: {cyan-fg}${stats.idle}{/}\\n`;\n output += ` Error: {red-fg}${stats.error}{/}\\n`;\n\n output += '\\n{bold}Performance:{/}\\n';\n output += ` Tasks: ${stats.successfulTasks}/${stats.totalTasks}\\n`;\n const rateColor =\n stats.avgSuccessRate >= 0.9\n ? 'green'\n : stats.avgSuccessRate >= 0.7\n ? 'yellow'\n : 'red';\n output += ` Success: {${rateColor}-fg}${Math.round(stats.avgSuccessRate * 100)}%{/}\\n`;\n output += ` Tokens: ${this.formatTokens(stats.totalTokens)}\\n`;\n\n output += '\\n{bold}Resources:{/}\\n';\n const cpuColor =\n stats.avgCpu > 80 ? 'red' : stats.avgCpu > 50 ? 'yellow' : 'green';\n const memColor =\n stats.avgMemory > 80 ? 'red' : stats.avgMemory > 50 ? 'yellow' : 'green';\n output += ` CPU: {${cpuColor}-fg}${Math.round(stats.avgCpu)}%{/}\\n`;\n output += ` Memory: {${memColor}-fg}${Math.round(stats.avgMemory)}%{/}\\n`;\n\n output += '\\n{bold}Types:{/}\\n';\n Array.from(typeGroups.entries())\n .sort((a, b) => b[1] - a[1])\n .forEach(([type, count]) => {\n const icon = this.getAgentTypeIcon(type);\n output += ` ${icon} ${type}: ${count}\\n`;\n });\n\n return output;\n }\n\n public update(agents: SubagentData[]): void {\n // Update agent map\n this.agents.clear();\n agents.forEach((agent) => {\n this.agents.set(agent.id, agent);\n });\n\n // Update list display\n const items = agents.map((agent: any) => this.formatAgentItem(agent));\n this.agentList.setItems(items);\n\n // Update stats panel\n this.statsBox.setContent(this.getFleetStats());\n\n // Update footer\n const active = agents.filter((a: any) => a.status === 'active').length;\n const idle = agents.filter((a: any) => a.status === 'idle').length;\n const total = agents.length;\n\n const footer = this.container.children[2] as blessed.Widgets.BoxElement;\n if (footer) {\n footer.setContent(\n `{bold}Fleet:{/} ${total} agents | ` +\n `{bold}Active:{/} {green-fg}${active}{/} | ` +\n `{bold}Idle:{/} {cyan-fg}${idle}{/}`\n );\n }\n\n this.container.screen.render();\n }\n\n private selectAgent(agentId: string): void {\n this.selectedAgent = agentId;\n const agent = this.agents.get(agentId);\n if (agent) {\n this.emit('agent:selected', agent);\n this.showAgentDetails(agent);\n }\n }\n\n private showAgentDetails(agent: SubagentData): void {\n const details = blessed.box({\n parent: this.container.screen,\n top: 'center',\n left: 'center',\n width: '70%',\n height: '70%',\n content: this.formatAgentDetails(agent),\n tags: true,\n border: {\n type: 'line',\n },\n style: {\n border: {\n fg: 'magenta',\n },\n },\n scrollable: true,\n keys: true,\n vi: true,\n mouse: true,\n hidden: false,\n label: ` Agent: ${agent.type} (${agent.id}) `,\n });\n\n details.key(['escape', 'q'], () => {\n details.destroy();\n this.container.screen.render();\n });\n\n details.focus();\n this.container.screen.render();\n }\n\n private formatAgentDetails(agent: SubagentData): string {\n let details = `{bold}Agent ID:{/} ${agent.id}\\n`;\n details += `{bold}Type:{/} ${this.getAgentTypeIcon(agent.type)} ${agent.type}\\n`;\n details += `{bold}Status:{/} ${this.getStatusIcon(agent.status)} ${agent.status}\\n`;\n\n if (agent.currentTask) {\n details += `\\n{bold}Current Task:{/}\\n`;\n details += ` ID: ${agent.currentTask.id}\\n`;\n details += ` Description: ${agent.currentTask.description}\\n`;\n details += ` Progress: ${Math.round(agent.currentTask.progress * 100)}%\\n`;\n details += ` Started: ${new Date(agent.currentTask.startTime).toLocaleString()}\\n`;\n details += ` Elapsed: ${this.formatDuration(Date.now() - agent.currentTask.startTime)}\\n`;\n }\n\n details += `\\n{bold}Performance Metrics:{/}\\n`;\n details += ` Tasks Completed: ${agent.tasksCompleted}\\n`;\n details += ` Tasks Failed: ${agent.tasksFailed}\\n`;\n details += ` Success Rate: ${Math.round(agent.successRate * 100)}%\\n`;\n details += ` Average Time: ${this.formatDuration(agent.averageTime)}\\n`;\n\n if (\n agent.cpuUsage !== undefined ||\n agent.memoryUsage !== undefined ||\n agent.tokenUsage !== undefined\n ) {\n details += `\\n{bold}Resource Usage:{/}\\n`;\n if (agent.cpuUsage !== undefined) {\n details += ` CPU: ${Math.round(agent.cpuUsage)}%\\n`;\n }\n if (agent.memoryUsage !== undefined) {\n details += ` Memory: ${Math.round(agent.memoryUsage)}%\\n`;\n }\n if (agent.tokenUsage !== undefined) {\n details += ` Tokens: ${this.formatTokens(agent.tokenUsage)}\\n`;\n }\n }\n\n if (agent.lastError) {\n details += `\\n{bold}Last Error:{/}\\n`;\n details += ` Message: ${agent.lastError.message}\\n`;\n details += ` Time: ${new Date(agent.lastError.timestamp).toLocaleString()}\\n`;\n details += ` Recoverable: ${agent.lastError.recoverable ? 'Yes' : 'No'}\\n`;\n }\n\n details += `\\n{gray-fg}[t] Terminate | [r] Restart | [l] View Logs{/}\\n`;\n\n return details;\n }\n\n private terminateAgent(agentId: string): void {\n this.emit('agent:terminate', { agentId });\n // Optimistically update UI\n const agent = this.agents.get(agentId);\n if (agent) {\n agent.status = 'completed';\n this.update(Array.from(this.agents.values()));\n }\n }\n\n private restartAgent(agentId: string): void {\n this.emit('agent:restart', { agentId });\n // Optimistically update UI\n const agent = this.agents.get(agentId);\n if (agent) {\n agent.status = 'idle';\n agent.lastError = undefined;\n this.update(Array.from(this.agents.values()));\n }\n }\n\n private showAgentLogs(agentId: string): void {\n this.emit('agent:logs', { agentId });\n }\n\n public focus(): void {\n this.agentList.focus();\n }\n\n public hasFocus(): boolean {\n return this.agentList === this.container.screen.focused;\n }\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|