@aria-cli/cli 1.0.57 → 1.0.59

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.
Files changed (319) hide show
  1. package/bin/aria.mjs +799 -668
  2. package/package.json +17 -76
  3. package/dist/.tsbuildinfo +0 -1
  4. package/dist/attached-local-control-client.js +0 -826
  5. package/dist/bootstrap-local-control-client.js +0 -2
  6. package/dist/capability-aware-method-proxy.js +0 -42
  7. package/dist/cli-context.js +0 -160
  8. package/dist/commands/arions.js +0 -174
  9. package/dist/commands/auth.js +0 -123
  10. package/dist/commands/daemon.js +0 -367
  11. package/dist/commands/definitions.js +0 -176
  12. package/dist/commands/index.js +0 -80
  13. package/dist/commands/login-handler.js +0 -1108
  14. package/dist/commands/logout-handler.js +0 -92
  15. package/dist/commands/memory-handlers.js +0 -89
  16. package/dist/commands/pairing.js +0 -60
  17. package/dist/commands/runtime-cutover-reset-command.js +0 -12
  18. package/dist/commands/runtime-cutover-reset.js +0 -265
  19. package/dist/commands/terminal-setup.js +0 -84
  20. package/dist/config/aria-config.js +0 -238
  21. package/dist/config/index.js +0 -3
  22. package/dist/config/loader.js +0 -97
  23. package/dist/config.js +0 -142
  24. package/dist/daemon-info.js +0 -10
  25. package/dist/ensure-daemon.js +0 -128
  26. package/dist/entrypoints/command-mode.js +0 -5
  27. package/dist/entrypoints/daemon.js +0 -50
  28. package/dist/entrypoints/headless-stdio.js +0 -25
  29. package/dist/entrypoints/interactive.js +0 -80
  30. package/dist/event-loop-watchdog.js +0 -73
  31. package/dist/headless/auth-orchestrator.js +0 -508
  32. package/dist/headless/auth-service.js +0 -43
  33. package/dist/headless/bootstrap-fast-path.js +0 -112
  34. package/dist/headless/call-command.js +0 -143
  35. package/dist/headless/daemon-service.js +0 -318
  36. package/dist/headless/hook-actions.js +0 -235
  37. package/dist/headless/hook-service.js +0 -42
  38. package/dist/headless/kernel-services.js +0 -216
  39. package/dist/headless/kernel.js +0 -785
  40. package/dist/headless/operations/arion.js +0 -119
  41. package/dist/headless/operations/auth.js +0 -45
  42. package/dist/headless/operations/client.js +0 -31
  43. package/dist/headless/operations/config.js +0 -69
  44. package/dist/headless/operations/daemon.js +0 -47
  45. package/dist/headless/operations/hook.js +0 -56
  46. package/dist/headless/operations/index.js +0 -11
  47. package/dist/headless/operations/memory.js +0 -102
  48. package/dist/headless/operations/message.js +0 -279
  49. package/dist/headless/operations/model.js +0 -100
  50. package/dist/headless/operations/peer.js +0 -56
  51. package/dist/headless/operations/run.js +0 -24
  52. package/dist/headless/operations/session.js +0 -90
  53. package/dist/headless/operations/system.js +0 -19
  54. package/dist/headless/operations/utils.js +0 -35
  55. package/dist/headless/run-orchestrator.js +0 -703
  56. package/dist/headless/stdio-server.js +0 -439
  57. package/dist/history/SessionHistory.js +0 -8
  58. package/dist/history/SessionHistoryClient.js +0 -186
  59. package/dist/history/conversation-message.js +0 -112
  60. package/dist/history/index.js +0 -8
  61. package/dist/history/jsonl-replay.js +0 -154
  62. package/dist/history/repair-tool-pairing.js +0 -84
  63. package/dist/history/stall-phase-bridge.js +0 -11
  64. package/dist/history/turn-accumulator.js +0 -427
  65. package/dist/index.js +0 -7
  66. package/dist/ink-repl.js +0 -4183
  67. package/dist/local-control-bootstrap.js +0 -26
  68. package/dist/local-control-client.js +0 -2
  69. package/dist/local-control-error-reporting.js +0 -34
  70. package/dist/local-control-http-client.js +0 -362
  71. package/dist/local-control-lazy-wrapper.js +0 -363
  72. package/dist/local-control-manager.js +0 -146
  73. package/dist/main.js +0 -62
  74. package/dist/network-security.js +0 -62
  75. package/dist/networking-server.js +0 -38
  76. package/dist/peer-identity.js +0 -23
  77. package/dist/polling-subscription.js +0 -34
  78. package/dist/relaunch.js +0 -617
  79. package/dist/release-notes.js +0 -35
  80. package/dist/repl-cleanup.js +0 -47
  81. package/dist/runtime/configure-bun-sqlite.js +0 -3
  82. package/dist/runtime/crash-handlers.js +0 -111
  83. package/dist/runtime/interactive-invocation.js +0 -39
  84. package/dist/runtime/internal-mode.js +0 -14
  85. package/dist/runtime/launch-spec.js +0 -64
  86. package/dist/runtime/owner-lease.js +0 -44
  87. package/dist/runtime/public-mode.js +0 -20
  88. package/dist/runtime/run-internal-mode.js +0 -18
  89. package/dist/runtime/runtime-kind.js +0 -32
  90. package/dist/runtime/spawn-aria.js +0 -38
  91. package/dist/selectable-client.js +0 -2
  92. package/dist/selectable-peer.js +0 -2
  93. package/dist/session.js +0 -203
  94. package/dist/slash-commands.js +0 -80
  95. package/dist/sounds.js +0 -210
  96. package/dist/ui/App.js +0 -526
  97. package/dist/ui/components/AnthropicMethodPicker.js +0 -6
  98. package/dist/ui/components/ArionPrompt.js +0 -15
  99. package/dist/ui/components/AutocompleteDropdown.js +0 -23
  100. package/dist/ui/components/AutonomySelector.js +0 -55
  101. package/dist/ui/components/Banner.js +0 -98
  102. package/dist/ui/components/ConversationHistory.js +0 -175
  103. package/dist/ui/components/CopilotDeviceLoginFlow.js +0 -88
  104. package/dist/ui/components/CopilotSourcePicker.js +0 -50
  105. package/dist/ui/components/Cost.js +0 -10
  106. package/dist/ui/components/CustomSelect/option-map.js +0 -30
  107. package/dist/ui/components/CustomSelect/select-option.js +0 -13
  108. package/dist/ui/components/CustomSelect/select.js +0 -42
  109. package/dist/ui/components/CustomSelect/use-select-state.js +0 -179
  110. package/dist/ui/components/CustomSelect/use-select.js +0 -15
  111. package/dist/ui/components/ErrorDisplay.js +0 -35
  112. package/dist/ui/components/FallbackToolUseRejectedMessage.js +0 -7
  113. package/dist/ui/components/FileEditToolUpdatedMessage.js +0 -57
  114. package/dist/ui/components/HandoffMarker.js +0 -18
  115. package/dist/ui/components/HighlightedCode.js +0 -21
  116. package/dist/ui/components/InputArea.js +0 -187
  117. package/dist/ui/components/Message.js +0 -25
  118. package/dist/ui/components/OAuthLoginFlow.js +0 -113
  119. package/dist/ui/components/OutputTruncation.js +0 -35
  120. package/dist/ui/components/PermissionPrompt.js +0 -79
  121. package/dist/ui/components/PipelineTimingPanel.js +0 -15
  122. package/dist/ui/components/ProviderMethodPicker.js +0 -61
  123. package/dist/ui/components/ProviderPicker.js +0 -63
  124. package/dist/ui/components/RenderItemView.js +0 -71
  125. package/dist/ui/components/Spinner.js +0 -46
  126. package/dist/ui/components/StatusBar.js +0 -95
  127. package/dist/ui/components/StreamingIndicator.js +0 -55
  128. package/dist/ui/components/StructuredDiff.js +0 -168
  129. package/dist/ui/components/TextInputOverlay.js +0 -43
  130. package/dist/ui/components/ThinkingBlock.js +0 -82
  131. package/dist/ui/components/ToolCost.js +0 -17
  132. package/dist/ui/components/ToolExecution.js +0 -61
  133. package/dist/ui/components/ToolHeader.js +0 -51
  134. package/dist/ui/components/ToolRenderLayoutContext.js +0 -14
  135. package/dist/ui/components/ToolResultWrapper.js +0 -6
  136. package/dist/ui/components/ToolUseLoader.js +0 -35
  137. package/dist/ui/components/TraceWaterfall.js +0 -91
  138. package/dist/ui/components/index.js +0 -33
  139. package/dist/ui/components/messages/AssistantTextMessage.js +0 -25
  140. package/dist/ui/components/messages/UserImageMessage.js +0 -12
  141. package/dist/ui/components/messages/UserTextMessage.js +0 -12
  142. package/dist/ui/components/overlays/ArionSelector.js +0 -68
  143. package/dist/ui/components/overlays/ClientSelector.js +0 -62
  144. package/dist/ui/components/overlays/CommandPalette.js +0 -67
  145. package/dist/ui/components/overlays/DaemonControl.js +0 -87
  146. package/dist/ui/components/overlays/InviteShareOverlay.js +0 -15
  147. package/dist/ui/components/overlays/JoinInviteOverlay.js +0 -32
  148. package/dist/ui/components/overlays/MemoryBrowser.js +0 -100
  149. package/dist/ui/components/overlays/MessageSelector.js +0 -123
  150. package/dist/ui/components/overlays/ModelSelector.js +0 -211
  151. package/dist/ui/components/overlays/PairRequestOverlay.js +0 -42
  152. package/dist/ui/components/overlays/PeerSelector.js +0 -84
  153. package/dist/ui/components/overlays/SessionSelector.js +0 -102
  154. package/dist/ui/components/overlays/SoundSelector.js +0 -86
  155. package/dist/ui/components/overlays/ThemeSelector.js +0 -139
  156. package/dist/ui/components/overlays/index.js +0 -15
  157. package/dist/ui/components/permissions/BashPermissionRequest/BashPermissionRequest.js +0 -53
  158. package/dist/ui/components/permissions/FallbackPermissionRequest.js +0 -56
  159. package/dist/ui/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +0 -76
  160. package/dist/ui/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js +0 -18
  161. package/dist/ui/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +0 -64
  162. package/dist/ui/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +0 -26
  163. package/dist/ui/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +0 -141
  164. package/dist/ui/components/permissions/PermissionRequest.js +0 -70
  165. package/dist/ui/components/permissions/PermissionRequestTitle.js +0 -41
  166. package/dist/ui/components/permissions/hooks.js +0 -10
  167. package/dist/ui/components/permissions/toolUseOptions.js +0 -68
  168. package/dist/ui/components/permissions/utils.js +0 -10
  169. package/dist/ui/components/text-input/Cursor.js +0 -326
  170. package/dist/ui/components/text-input/TextInput.js +0 -231
  171. package/dist/ui/components/text-input/imagePaste.js +0 -28
  172. package/dist/ui/components/text-input/index.js +0 -6
  173. package/dist/ui/components/text-input/useDoublePress.js +0 -30
  174. package/dist/ui/components/text-input/useTextInput.js +0 -245
  175. package/dist/ui/components/tool-types.js +0 -9
  176. package/dist/ui/constants/figures.js +0 -4
  177. package/dist/ui/constants/index.js +0 -3
  178. package/dist/ui/display-mode.js +0 -93
  179. package/dist/ui/display-policy.js +0 -19
  180. package/dist/ui/hooks/index.js +0 -6
  181. package/dist/ui/hooks/useCommandAutocomplete.js +0 -93
  182. package/dist/ui/hooks/useDoublePress.js +0 -37
  183. package/dist/ui/hooks/useIndicatorState.js +0 -55
  184. package/dist/ui/hooks/useInterval.js +0 -23
  185. package/dist/ui/hooks/useKeyboardShortcuts.js +0 -127
  186. package/dist/ui/hooks/useTerminalSize.js +0 -55
  187. package/dist/ui/hooks/useUnifiedMessages.js +0 -117
  188. package/dist/ui/indicator-state.js +0 -44
  189. package/dist/ui/markdown/highlight.js +0 -44
  190. package/dist/ui/markdown/index.js +0 -1460
  191. package/dist/ui/markdown/tokenizer.js +0 -24
  192. package/dist/ui/render-item.js +0 -5
  193. package/dist/ui/screens/REPL.js +0 -119
  194. package/dist/ui/screens/approval-lifecycle.js +0 -38
  195. package/dist/ui/status-line.js +0 -72
  196. package/dist/ui/theme/index.js +0 -51
  197. package/dist/ui/theme/themes/claude-dark-daltonized.js +0 -51
  198. package/dist/ui/theme/themes/claude-dark.js +0 -50
  199. package/dist/ui/theme/themes/claude-light-daltonized.js +0 -51
  200. package/dist/ui/theme/themes/claude-light.js +0 -50
  201. package/dist/ui/theme/themes/dark-accessible.js +0 -18
  202. package/dist/ui/theme/themes/dark.js +0 -49
  203. package/dist/ui/theme/themes/light-accessible.js +0 -18
  204. package/dist/ui/theme/themes/light.js +0 -49
  205. package/dist/ui/theme/types.js +0 -3
  206. package/dist/ui/theme.js +0 -142
  207. package/dist/ui/to-render-items.js +0 -145
  208. package/dist/ui/tools/AgentTool/index.js +0 -30
  209. package/dist/ui/tools/ArchitectTool/index.js +0 -31
  210. package/dist/ui/tools/AskUserTool/index.js +0 -46
  211. package/dist/ui/tools/BashTool/BashToolResultMessage.js +0 -11
  212. package/dist/ui/tools/BashTool/OutputLine.js +0 -21
  213. package/dist/ui/tools/BashTool/index.js +0 -91
  214. package/dist/ui/tools/BrowseTool/index.js +0 -43
  215. package/dist/ui/tools/BrowserTool/index.js +0 -47
  216. package/dist/ui/tools/CbmTool/index.js +0 -188
  217. package/dist/ui/tools/CheckDelegationTool/index.js +0 -46
  218. package/dist/ui/tools/CheckMessagesTool/index.js +0 -85
  219. package/dist/ui/tools/CreateQuipTool/index.js +0 -30
  220. package/dist/ui/tools/CreateSkillTool/index.js +0 -22
  221. package/dist/ui/tools/CreateToolTool/index.js +0 -31
  222. package/dist/ui/tools/DelegateRemoteTool/index.js +0 -42
  223. package/dist/ui/tools/DeployTool/index.js +0 -47
  224. package/dist/ui/tools/FffTool/index.js +0 -103
  225. package/dist/ui/tools/FileEditTool/index.js +0 -67
  226. package/dist/ui/tools/FileReadTool/index.js +0 -68
  227. package/dist/ui/tools/FileWriteTool/index.js +0 -61
  228. package/dist/ui/tools/ForkTool/index.js +0 -47
  229. package/dist/ui/tools/FrgTool/index.js +0 -96
  230. package/dist/ui/tools/GetThreadTool/index.js +0 -39
  231. package/dist/ui/tools/GlobTool/index.js +0 -50
  232. package/dist/ui/tools/GrepTool/index.js +0 -84
  233. package/dist/ui/tools/HatchArionTool/index.js +0 -36
  234. package/dist/ui/tools/LearnSkillTool/index.js +0 -22
  235. package/dist/ui/tools/LearnTool/index.js +0 -43
  236. package/dist/ui/tools/LearnToolTool/index.js +0 -22
  237. package/dist/ui/tools/ListClientsTool/index.js +0 -39
  238. package/dist/ui/tools/LspTool/index.js +0 -261
  239. package/dist/ui/tools/MCPTool/index.js +0 -33
  240. package/dist/ui/tools/ManageNetworkTool/index.js +0 -53
  241. package/dist/ui/tools/MemoryReadTool/index.js +0 -64
  242. package/dist/ui/tools/MemoryWriteTool/index.js +0 -20
  243. package/dist/ui/tools/NotebookEditTool/index.js +0 -33
  244. package/dist/ui/tools/NotebookReadTool/index.js +0 -25
  245. package/dist/ui/tools/OutlookReadTool/index.js +0 -66
  246. package/dist/ui/tools/OutlookReplyTool/index.js +0 -49
  247. package/dist/ui/tools/OutlookSendTool/index.js +0 -49
  248. package/dist/ui/tools/PauseDelegationTool/index.js +0 -35
  249. package/dist/ui/tools/ProbeTool/index.js +0 -121
  250. package/dist/ui/tools/ProcessTool/index.js +0 -66
  251. package/dist/ui/tools/QuestListTool/index.js +0 -46
  252. package/dist/ui/tools/QuestReportTool/index.js +0 -49
  253. package/dist/ui/tools/QuestUpdateTool/index.js +0 -87
  254. package/dist/ui/tools/QuipCommentTool/index.js +0 -69
  255. package/dist/ui/tools/QuipReadTool/index.js +0 -71
  256. package/dist/ui/tools/RestArionTool/index.js +0 -32
  257. package/dist/ui/tools/RestartTool/index.js +0 -35
  258. package/dist/ui/tools/ResumeDelegationTool/index.js +0 -35
  259. package/dist/ui/tools/RetireArionTool/index.js +0 -32
  260. package/dist/ui/tools/RgTool/index.js +0 -73
  261. package/dist/ui/tools/SearchKnowledgeTool/index.js +0 -43
  262. package/dist/ui/tools/SearchMessagesTool/index.js +0 -43
  263. package/dist/ui/tools/SelfDiagnoseTool/index.js +0 -61
  264. package/dist/ui/tools/SendMessageTool/index.js +0 -45
  265. package/dist/ui/tools/SerenaTool/index.js +0 -124
  266. package/dist/ui/tools/SessionHistoryTool/index.js +0 -52
  267. package/dist/ui/tools/SgTool/index.js +0 -80
  268. package/dist/ui/tools/SlackReactTool/index.js +0 -41
  269. package/dist/ui/tools/SlackReadTool/index.js +0 -48
  270. package/dist/ui/tools/SlackSendTool/index.js +0 -45
  271. package/dist/ui/tools/SpawnWorkerTool/index.js +0 -33
  272. package/dist/ui/tools/StickerRequestTool/index.js +0 -19
  273. package/dist/ui/tools/ThinkTool/index.js +0 -17
  274. package/dist/ui/tools/UgTool/index.js +0 -108
  275. package/dist/ui/tools/UseSkillTool/index.js +0 -22
  276. package/dist/ui/tools/WakeArionTool/index.js +0 -32
  277. package/dist/ui/tools/WebFetchTool/index.js +0 -56
  278. package/dist/ui/tools/WebSearchTool/index.js +0 -44
  279. package/dist/ui/tools/lsTool/index.js +0 -58
  280. package/dist/ui/tools/registry.js +0 -197
  281. package/dist/ui/tools/tool-renderer.js +0 -11
  282. package/dist/ui/tools/truncation.js +0 -35
  283. package/dist/ui/types/anthropic.js +0 -4
  284. package/dist/ui/types/index.js +0 -2
  285. package/dist/ui/types/message.js +0 -3
  286. package/dist/ui/types/tool.js +0 -4
  287. package/dist/ui/utils/array.js +0 -4
  288. package/dist/ui/utils/cursor.js +0 -131
  289. package/dist/ui/utils/diff.js +0 -120
  290. package/dist/ui/utils/format.js +0 -42
  291. package/dist/ui/utils/fuzzy.js +0 -59
  292. package/dist/ui/utils/index.js +0 -11
  293. package/dist/ui/utils/keys.js +0 -8
  294. package/dist/ui/utils/patch.js +0 -17
  295. package/dist/ui/utils/risk.js +0 -114
  296. package/dist/ui/utils/terminal-image.js +0 -70
  297. package/dist/ui/utils/validation.js +0 -48
  298. package/dist/ui/verb-pairs.js +0 -248
  299. package/dist/ui.js +0 -131
  300. package/src/entrypoints/command-mode.ts +0 -5
  301. package/src/entrypoints/daemon.ts +0 -54
  302. package/src/entrypoints/headless-stdio.ts +0 -27
  303. package/src/entrypoints/interactive.ts +0 -112
  304. package/src/main.ts +0 -72
  305. package/src/runtime/configure-bun-sqlite.ts +0 -3
  306. package/src/runtime/crash-handlers.ts +0 -128
  307. package/src/runtime/interactive-invocation.test.ts +0 -42
  308. package/src/runtime/interactive-invocation.ts +0 -51
  309. package/src/runtime/internal-mode.test.ts +0 -19
  310. package/src/runtime/internal-mode.ts +0 -24
  311. package/src/runtime/launch-spec.test.ts +0 -26
  312. package/src/runtime/launch-spec.ts +0 -84
  313. package/src/runtime/owner-lease.ts +0 -52
  314. package/src/runtime/public-mode.test.ts +0 -18
  315. package/src/runtime/public-mode.ts +0 -19
  316. package/src/runtime/run-internal-mode.ts +0 -19
  317. package/src/runtime/runtime-kind.test.ts +0 -23
  318. package/src/runtime/runtime-kind.ts +0 -41
  319. package/src/runtime/spawn-aria.ts +0 -62
@@ -1,49 +0,0 @@
1
- import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
2
- import { Box, Text } from "ink";
3
- import { FallbackToolUseRejectedMessage } from "../../components/FallbackToolUseRejectedMessage.js";
4
- import { getTheme } from "../../theme/index.js";
5
- import { safeFallbackText } from "../truncation.js";
6
- export const OutlookSendToolRenderers = {
7
- displayName() {
8
- return "Outlook Send";
9
- },
10
- renderInput(input, { verbose } = {}) {
11
- const theme = getTheme();
12
- const to = String(input?.to ?? "");
13
- let subject = String(input?.subject ?? "");
14
- // Truncate subject to 40 chars
15
- if (subject.length > 40) {
16
- subject = subject.substring(0, 40) + "...";
17
- }
18
- return (_jsx(Box, { flexDirection: "row", children: _jsxs(Text, { children: ["to: ", to, subject && ` — "${subject}"`] }) }));
19
- },
20
- renderRejection() {
21
- return _jsx(FallbackToolUseRejectedMessage, {});
22
- },
23
- renderOutput(output, { verbose } = {}) {
24
- const theme = getTheme();
25
- if (output == null) {
26
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.error, children: "Failed to send email" }) }));
27
- }
28
- const obj = output;
29
- // Handle error case: { success: false, message: "..." }
30
- if (obj.success === false) {
31
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.error, children: String(obj.message ?? "Failed to send email") }) }));
32
- }
33
- // Handle success case: { success: true, message: "Sent to ..." }
34
- if (obj.success === true) {
35
- const message = String(obj.message ?? "Email sent");
36
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.success, children: message }) }));
37
- }
38
- // String output (likely success message or error)
39
- if (typeof output === "string") {
40
- if (output.toLowerCase().includes("sent") || output.toLowerCase().includes("success")) {
41
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.success, children: output }) }));
42
- }
43
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.error, children: output }) }));
44
- }
45
- // Fallback for unexpected shapes
46
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { children: safeFallbackText(output) }) }));
47
- },
48
- };
49
- //# sourceMappingURL=index.js.map
@@ -1,35 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { Box, Text } from "ink";
3
- import { FallbackToolUseRejectedMessage } from "../../components/FallbackToolUseRejectedMessage.js";
4
- import { getTheme } from "../../theme/index.js";
5
- import { safeFallbackText } from "../truncation.js";
6
- export const PauseDelegationToolRenderers = {
7
- displayName() {
8
- return "Pause";
9
- },
10
- renderInput(input, _opts = {}) {
11
- if (input.id) {
12
- return input.id;
13
- }
14
- return Object.entries(input)
15
- .map(([key, value]) => `${key}: ${JSON.stringify(value)}`)
16
- .join(", ");
17
- },
18
- renderRejection() {
19
- return _jsx(FallbackToolUseRejectedMessage, {});
20
- },
21
- renderOutput(output, _opts = {}) {
22
- const theme = getTheme();
23
- if (!output) {
24
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, children: "(No content)" }) }) }));
25
- }
26
- if (typeof output === "string") {
27
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { children: safeFallbackText(output) }) }) }));
28
- }
29
- if (output.error) {
30
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.error, children: output.error }) }) }));
31
- }
32
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.success, children: "Paused" }) }) }));
33
- },
34
- };
35
- //# sourceMappingURL=index.js.map
@@ -1,121 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Box, Text } from "ink";
3
- import { relative } from "path";
4
- import { FallbackToolUseRejectedMessage } from "../../components/FallbackToolUseRejectedMessage.js";
5
- import { getTheme } from "../../theme/index.js";
6
- /** Map symbol kind to unicode icon */
7
- function getSymbolIcon(kind) {
8
- if (!kind)
9
- return "•";
10
- const k = kind.toLowerCase();
11
- if (k.includes("function") || k === "fn")
12
- return "𝑓";
13
- if (k.includes("class"))
14
- return "𝐶";
15
- if (k.includes("method"))
16
- return "𝑚";
17
- if (k.includes("type") || k === "interface" || k === "enum")
18
- return "𝑇";
19
- if (k.includes("const") || k === "variable" || k === "var")
20
- return "𝑐";
21
- return "•";
22
- }
23
- /** Format input for display */
24
- function formatInput(input) {
25
- const { command, query, files, language, max_results, exact, reranker, path, ...rest } = input;
26
- const parts = [];
27
- if (command) {
28
- parts.push(`${command}`);
29
- }
30
- if (query) {
31
- parts.push(`"${query}"`);
32
- }
33
- if (files) {
34
- const filesList = Array.isArray(files) ? files.join(", ") : files;
35
- parts.push(filesList);
36
- }
37
- if (language) {
38
- parts.push(`lang: ${language}`);
39
- }
40
- if (max_results) {
41
- parts.push(`max: ${max_results}`);
42
- }
43
- if (exact) {
44
- parts.push(`exact`);
45
- }
46
- return parts.join(" ");
47
- }
48
- export const ProbeToolRenderers = {
49
- displayName() {
50
- return "Probe";
51
- },
52
- renderInput(input, { verbose }) {
53
- return formatInput(input);
54
- },
55
- renderRejection() {
56
- return _jsx(FallbackToolUseRejectedMessage, {});
57
- },
58
- renderOutput(output, { verbose } = {}, input) {
59
- const theme = getTheme();
60
- if (!output) {
61
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, children: "No results" }) }) }));
62
- }
63
- // Handle raw string output
64
- if (typeof output === "string") {
65
- const lines = output.split("\n").slice(0, 3);
66
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsxs(Box, { flexDirection: "column", children: [lines.map((line, i) => (_jsx(Text, { color: theme.colors.textMuted, children: line.length > 80 ? line.slice(0, 77) + "…" : line }, i))), output.split("\n").length > 3 && (_jsxs(Text, { color: theme.colors.textMuted, children: ["... (+", output.split("\n").length - 3, " lines)"] }))] }) }));
67
- }
68
- // Handle object output
69
- if (typeof output !== "object" || output === null) {
70
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, children: "No results" }) }) }));
71
- }
72
- const obj = output;
73
- // Handle raw field (string within object)
74
- if (typeof obj.raw === "string") {
75
- const lines = obj.raw.split("\n").slice(0, 3);
76
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsxs(Box, { flexDirection: "column", children: [lines.map((line, i) => (_jsx(Text, { color: theme.colors.textMuted, children: line.length > 80 ? line.slice(0, 77) + "…" : line }, i))), obj.raw.split("\n").length > 3 && (_jsxs(Text, { color: theme.colors.textMuted, children: ["... (+", obj.raw.split("\n").length - 3, " lines)"] }))] }) }));
77
- }
78
- // Handle symbols output
79
- if (Array.isArray(obj.symbols) && obj.symbols.length > 0) {
80
- const symbols = obj.symbols.filter((s) => s != null && typeof s === "object");
81
- const maxSymbols = 5;
82
- const displaySymbols = symbols.slice(0, maxSymbols);
83
- return (_jsxs(Box, { flexDirection: "column", children: [_jsxs(Box, { flexDirection: "row", children: [_jsx(Text, { children: "Found " }), _jsxs(Text, { bold: true, children: [symbols.length, " "] }), _jsx(Text, { children: symbols.length === 1 ? "symbol" : "symbols" })] }), displaySymbols.map((sym, i) => (_jsxs(Box, { flexDirection: "row", paddingLeft: 2, children: [_jsxs(Text, { children: [getSymbolIcon(sym.kind), " "] }), _jsx(Text, { bold: true, children: sym.name || "(unnamed)" }), sym.line !== undefined && _jsxs(Text, { color: theme.colors.textMuted, children: [" :", sym.line] })] }, i))), symbols.length > maxSymbols && (_jsx(Box, { flexDirection: "row", paddingLeft: 2, children: _jsxs(Text, { color: theme.colors.textMuted, children: ["+", symbols.length - maxSymbols, " more"] }) }))] }));
84
- }
85
- // Handle results array (search/extract output)
86
- if (Array.isArray(obj.results) && obj.results.length > 0) {
87
- const results = obj.results.filter((r) => r != null && typeof r === "object");
88
- const maxResults = 3;
89
- const displayResults = results.slice(0, maxResults);
90
- return (_jsxs(Box, { flexDirection: "column", children: [_jsxs(Box, { flexDirection: "row", children: [_jsx(Text, { children: "Found " }), _jsxs(Text, { bold: true, children: [results.length, " "] }), _jsx(Text, { children: results.length === 1 ? "result" : "results" })] }), displayResults.map((result, i) => (_jsxs(Box, { flexDirection: "column", paddingLeft: 2, children: [_jsx(Box, { flexDirection: "row", children: _jsxs(Text, { bold: true, children: [relative(process.cwd(), result.file || ""), result.line !== undefined ? `:${result.line}` : ""] }) }), result.code && (_jsx(Text, { color: theme.colors.textMuted, children: result.code.length > 60 ? result.code.slice(0, 60) + "…" : result.code }))] }, i))), results.length > maxResults && (_jsx(Box, { flexDirection: "row", paddingLeft: 2, children: _jsxs(Text, { color: theme.colors.textMuted, children: ["+", results.length - maxResults, " more"] }) }))] }));
91
- }
92
- // Handle array of objects (could be results or symbols)
93
- if (Array.isArray(output)) {
94
- const items = output.filter((item) => item != null && typeof item === "object");
95
- if (items.length === 0) {
96
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, children: "No results" }) }) }));
97
- }
98
- // Check if it looks like symbols (has 'kind' or 'name' fields typical of symbols)
99
- const firstItem = items[0];
100
- if (firstItem.kind !== undefined || (firstItem.name && !firstItem.file)) {
101
- // Treat as symbols
102
- const maxSymbols = 5;
103
- const displaySymbols = items.slice(0, maxSymbols);
104
- return (_jsxs(Box, { flexDirection: "column", children: [_jsxs(Box, { flexDirection: "row", children: [_jsx(Text, { children: "Found " }), _jsxs(Text, { bold: true, children: [items.length, " "] }), _jsx(Text, { children: items.length === 1 ? "symbol" : "symbols" })] }), displaySymbols.map((sym, i) => (_jsxs(Box, { flexDirection: "row", paddingLeft: 2, children: [_jsxs(Text, { children: [getSymbolIcon(sym.kind), " "] }), _jsx(Text, { bold: true, children: sym.name || "(unnamed)" }), sym.line !== undefined && (_jsxs(Text, { color: theme.colors.textMuted, children: [":", sym.line] }))] }, i))), items.length > maxSymbols && (_jsx(Box, { flexDirection: "row", paddingLeft: 2, children: _jsxs(Text, { color: theme.colors.textMuted, children: ["+", items.length - maxSymbols, " more"] }) }))] }));
105
- }
106
- // Treat as results
107
- const maxResults = 3;
108
- const displayResults = items.slice(0, maxResults);
109
- return (_jsxs(Box, { flexDirection: "column", children: [_jsxs(Box, { flexDirection: "row", children: [_jsx(Text, { children: "Found " }), _jsxs(Text, { bold: true, children: [items.length, " "] }), _jsx(Text, { children: items.length === 1 ? "result" : "results" })] }), displayResults.map((result, i) => (_jsxs(Box, { flexDirection: "column", paddingLeft: 2, children: [_jsx(Box, { flexDirection: "row", children: _jsxs(Text, { bold: true, children: [relative(process.cwd(), (result.file ||
110
- result.path ||
111
- "")), result.line !== undefined
112
- ? `:${result.line}`
113
- : ""] }) }), typeof result.code === "string" && (_jsx(Text, { color: theme.colors.textMuted, children: result.code.length > 60
114
- ? result.code.slice(0, 60) + "…"
115
- : result.code }))] }, i))), items.length > maxResults && (_jsx(Box, { flexDirection: "row", paddingLeft: 2, children: _jsxs(Text, { color: theme.colors.textMuted, children: ["+", items.length - maxResults, " more"] }) }))] }));
116
- }
117
- // Fallback for unhandled object shapes
118
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, children: "No results" }) }) }));
119
- },
120
- };
121
- //# sourceMappingURL=index.js.map
@@ -1,66 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Box, Text } from "ink";
3
- import { FallbackToolUseRejectedMessage } from "../../components/FallbackToolUseRejectedMessage.js";
4
- import { getTheme } from "../../theme/index.js";
5
- import { capLine, safeFallbackText } from "../truncation.js";
6
- function formatProcessAction(input) {
7
- const action = input.action || "unknown";
8
- switch (action) {
9
- case "spawn":
10
- return input.command ? `spawn: ${input.command}` : "spawn";
11
- case "read":
12
- return input.pid != null ? `read pid ${input.pid}` : "read";
13
- case "write":
14
- return input.pid != null ? `write to pid ${input.pid}` : "write";
15
- case "kill":
16
- return input.pid != null ? `kill pid ${input.pid}` : "kill";
17
- case "list":
18
- return "list processes";
19
- default:
20
- return action;
21
- }
22
- }
23
- export const ProcessToolRenderers = {
24
- displayName() {
25
- return "Process";
26
- },
27
- renderInput(input, _opts) {
28
- return formatProcessAction(input);
29
- },
30
- renderRejection() {
31
- return _jsx(FallbackToolUseRejectedMessage, {});
32
- },
33
- renderOutput(output, _opts) {
34
- const theme = getTheme();
35
- if (!output) {
36
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, children: "(No content)" }) }) }));
37
- }
38
- if (typeof output === "string") {
39
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { children: safeFallbackText(output) }) }) }));
40
- }
41
- // Spawn result: show pid
42
- if (output.action === "spawn" || (output.pid != null && !output.output && !output.sessions)) {
43
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsxs(Box, { flexDirection: "row", children: [_jsx(Text, { children: "Spawned process " }), _jsx(Text, { bold: true, children: output.pid })] }) }));
44
- }
45
- // Read result: show output
46
- if (output.action === "read" || output.output != null) {
47
- const lines = (output.output || "").split("\n");
48
- const preview = lines.length > 3
49
- ? lines.slice(0, 3).map(capLine).join("\n") + `\n... +${lines.length - 3} more lines`
50
- : (output.output || "").split("\n").map(capLine).join("\n");
51
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { children: preview }) }) }));
52
- }
53
- // List result: show sessions table
54
- if (output.action === "list" || output.sessions) {
55
- const sessions = output.sessions || [];
56
- if (sessions.length === 0) {
57
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, children: "No active processes" }) }) }));
58
- }
59
- const MAX_SESSIONS = 2; // 1 header + 2 items = 3 lines
60
- return (_jsxs(Box, { flexDirection: "column", children: [_jsxs(Box, { flexDirection: "row", children: [_jsxs(Text, { bold: true, children: [sessions.length, " "] }), _jsx(Text, { children: sessions.length === 1 ? "process" : "processes" })] }), sessions.slice(0, MAX_SESSIONS).map((s, i) => (_jsxs(Box, { flexDirection: "row", paddingLeft: 4, children: [_jsxs(Text, { bold: true, children: [s.pid, " "] }), _jsxs(Text, { children: [s.command || "", " "] }), _jsx(Text, { color: s.status === "running" ? theme.colors.success : theme.colors.textMuted, children: s.status || "" })] }, i))), sessions.length > MAX_SESSIONS && (_jsxs(Text, { color: theme.colors.textMuted, children: ["... (+", sessions.length - MAX_SESSIONS, " more)"] }))] }));
61
- }
62
- // Fallback
63
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { children: safeFallbackText(output) }) }) }));
64
- },
65
- };
66
- //# sourceMappingURL=index.js.map
@@ -1,46 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Box, Text } from "ink";
3
- import { FallbackToolUseRejectedMessage } from "../../components/FallbackToolUseRejectedMessage.js";
4
- import { getTheme } from "../../theme/index.js";
5
- function statusColor(status) {
6
- const theme = getTheme();
7
- switch (status) {
8
- case "active":
9
- case "in_progress":
10
- return theme.colors.success;
11
- case "blocked":
12
- return theme.colors.warning;
13
- case "done":
14
- case "closed":
15
- return theme.colors.textMuted;
16
- default:
17
- return theme.colors.text;
18
- }
19
- }
20
- export const QuestListToolRenderers = {
21
- displayName() {
22
- return "Quest List";
23
- },
24
- renderInput(input) {
25
- if (input.status) {
26
- return `status: ${input.status}`;
27
- }
28
- return "all quests";
29
- },
30
- renderRejection() {
31
- return _jsx(FallbackToolUseRejectedMessage, {});
32
- },
33
- renderOutput(output, { verbose }) {
34
- const quests = output?.quests ?? [];
35
- const n = output?.count ?? quests.length;
36
- if (!verbose) {
37
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsxs(Text, { children: [n, " quest", n !== 1 ? "s" : ""] }) }) }));
38
- }
39
- // Verbose: show table of quests
40
- if (quests.length === 0) {
41
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { children: "0 quests" }) }) }));
42
- }
43
- return (_jsxs(Box, { flexDirection: "column", children: [_jsx(Box, { children: _jsxs(Text, { children: [n, " quest", n !== 1 ? "s" : ""] }) }), quests.map((q) => (_jsx(Box, { flexDirection: "row", paddingLeft: 4, children: _jsxs(Text, { color: statusColor(q.status), children: ["P", q.priority, " [", q.status, "] ", q.id, " ", q.title] }) }, q.id)))] }));
44
- },
45
- };
46
- //# sourceMappingURL=index.js.map
@@ -1,49 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Box, Text } from "ink";
3
- import { FallbackToolUseRejectedMessage } from "../../components/FallbackToolUseRejectedMessage.js";
4
- import { getTheme } from "../../theme/index.js";
5
- import { safeFallbackText } from "../truncation.js";
6
- export const QuestReportToolRenderers = {
7
- displayName() {
8
- return "Quest Report";
9
- },
10
- renderInput(input, _opts = {}) {
11
- if (input.quest_id) {
12
- return input.quest_id;
13
- }
14
- return Object.entries(input)
15
- .map(([key, value]) => `${key}: ${JSON.stringify(value)}`)
16
- .join(", ");
17
- },
18
- renderRejection() {
19
- return _jsx(FallbackToolUseRejectedMessage, {});
20
- },
21
- renderOutput(output, _opts = {}) {
22
- const theme = getTheme();
23
- if (!output) {
24
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, children: "(No content)" }) }) }));
25
- }
26
- if (typeof output === "string") {
27
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { children: safeFallbackText(output) }) }) }));
28
- }
29
- if (output.error) {
30
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.error, children: output.error }) }) }));
31
- }
32
- if (output.data) {
33
- const { commits, filesChanged, cost } = output.data;
34
- const parts = [];
35
- if (commits !== undefined) {
36
- parts.push(`${commits} commit${commits !== 1 ? "s" : ""}`);
37
- }
38
- if (filesChanged !== undefined) {
39
- parts.push(`${filesChanged} file${filesChanged !== 1 ? "s" : ""} changed`);
40
- }
41
- return (_jsxs(Box, { flexDirection: "column", children: [parts.length > 0 && (_jsx(Box, { flexDirection: "row", children: _jsx(Text, { children: parts.join(", ") }) })), cost !== undefined && (_jsx(Box, { flexDirection: "row", children: _jsxs(Text, { color: theme.colors.textMuted, children: ["Cost: ", cost] }) }))] }));
42
- }
43
- if (output.message) {
44
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { children: output.message }) }) }));
45
- }
46
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, children: "(No data)" }) }) }));
47
- },
48
- };
49
- //# sourceMappingURL=index.js.map
@@ -1,87 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Box, Text } from "ink";
3
- import { FallbackToolUseRejectedMessage } from "../../components/FallbackToolUseRejectedMessage.js";
4
- import { getTheme } from "../../theme/index.js";
5
- function actionColor(action) {
6
- const theme = getTheme();
7
- switch (action) {
8
- case "created":
9
- return theme.colors.success;
10
- case "updated":
11
- return theme.colors.info;
12
- case "failed":
13
- return theme.colors.error;
14
- default:
15
- return theme.colors.text;
16
- }
17
- }
18
- export const QuestUpdateToolRenderers = {
19
- displayName() {
20
- return "Quest Update";
21
- },
22
- renderInput(input) {
23
- // Handle both flat fields and quests array input
24
- if (input.quests && Array.isArray(input.quests)) {
25
- const n = input.quests.length;
26
- return `${n} quest${n !== 1 ? "s" : ""}`;
27
- }
28
- const parts = [];
29
- if (input.action)
30
- parts.push(input.action);
31
- if (input.title)
32
- parts.push(input.title);
33
- if (input.id)
34
- parts.push(input.id);
35
- return parts.join(" ") || "quest update";
36
- },
37
- renderRejection() {
38
- return _jsx(FallbackToolUseRejectedMessage, {});
39
- },
40
- renderOutput(output, { verbose }) {
41
- // Handle both { quests: [...] } and direct output shapes
42
- let quests = [];
43
- if (output != null && typeof output === "object") {
44
- const obj = output;
45
- if (Array.isArray(obj.quests)) {
46
- quests = obj.quests;
47
- }
48
- }
49
- const created = quests.filter((q) => q.action === "created").length;
50
- const updated = quests.filter((q) => q.action === "updated").length;
51
- const failed = quests.filter((q) => q.action === "failed").length;
52
- const theme = getTheme();
53
- const summaryParts = [];
54
- if (created > 0)
55
- summaryParts.push(`${created} created`);
56
- if (updated > 0)
57
- summaryParts.push(`${updated} updated`);
58
- if (failed > 0)
59
- summaryParts.push(`${failed} failed`);
60
- if (summaryParts.length === 0)
61
- summaryParts.push("0 changes");
62
- if (!verbose) {
63
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: summaryParts.map((part, i) => {
64
- const color = part.includes("created")
65
- ? theme.colors.success
66
- : part.includes("updated")
67
- ? theme.colors.info
68
- : part.includes("failed")
69
- ? theme.colors.error
70
- : theme.colors.text;
71
- return (_jsxs(Text, { children: [i > 0 ? ", " : "", _jsx(Text, { color: color, children: part })] }, i));
72
- }) }) }));
73
- }
74
- // Verbose: show per-quest details
75
- return (_jsxs(Box, { flexDirection: "column", children: [_jsx(Box, { children: summaryParts.map((part, i) => {
76
- const color = part.includes("created")
77
- ? theme.colors.success
78
- : part.includes("updated")
79
- ? theme.colors.info
80
- : part.includes("failed")
81
- ? theme.colors.error
82
- : theme.colors.text;
83
- return (_jsxs(Text, { children: [i > 0 ? ", " : "", _jsx(Text, { color: color, children: part })] }, i));
84
- }) }), quests.map((q) => (_jsx(Box, { flexDirection: "row", paddingLeft: 4, children: _jsxs(Text, { color: actionColor(q.action), children: ["[", q.action, "] ", q.id, " ", q.title, q.error ? ` -- ${q.error}` : ""] }) }, q.id)))] }));
85
- },
86
- };
87
- //# sourceMappingURL=index.js.map
@@ -1,69 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { Box, Text } from "ink";
3
- import { FallbackToolUseRejectedMessage } from "../../components/FallbackToolUseRejectedMessage.js";
4
- import { getTheme } from "../../theme/index.js";
5
- import { safeFallbackText } from "../truncation.js";
6
- function truncateText(text, maxLen = 40) {
7
- return text.length > maxLen ? text.slice(0, maxLen - 1) + "…" : text;
8
- }
9
- export const QuipCommentToolRenderers = {
10
- displayName() {
11
- return "Quip Comment";
12
- },
13
- renderInput(input, { verbose } = {}) {
14
- const threadId = input.threadId ? truncateText(String(input.threadId), 30) : "";
15
- const content = input.content ? truncateText(String(input.content), 40) : "";
16
- const parts = [];
17
- if (threadId) {
18
- parts.push(`thread: ${threadId}`);
19
- }
20
- if (content) {
21
- parts.push(`"${content}"`);
22
- }
23
- return (_jsx(Box, { flexDirection: "row", children: _jsx(Text, { children: parts.length > 0 ? parts.join(" ") : "Posting comment..." }) }));
24
- },
25
- renderRejection() {
26
- return _jsx(FallbackToolUseRejectedMessage, {});
27
- },
28
- renderOutput(output, { verbose } = {}) {
29
- const theme = getTheme();
30
- // Handle null/undefined
31
- if (output == null) {
32
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.textMuted, children: "(No response)" }) }));
33
- }
34
- // Handle plain string
35
- if (typeof output === "string") {
36
- // If it looks like a success message, color it green
37
- if (output.toLowerCase().includes("posted") || output.toLowerCase().includes("success")) {
38
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.success, children: safeFallbackText(output) }) }));
39
- }
40
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { children: safeFallbackText(output) }) }));
41
- }
42
- const obj = output;
43
- // Handle error case: { success: false, message: "..." }
44
- if (obj.success === false) {
45
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.error, children: String(obj.message ?? "Error posting comment") }) }));
46
- }
47
- // Handle success case
48
- if (obj.success === true) {
49
- const message = obj.message ?? "Comment posted";
50
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.success, children: message }) }));
51
- }
52
- // Generic message display
53
- if (obj.message) {
54
- // If message suggests success, color it green
55
- if (String(obj.message).toLowerCase().includes("posted")) {
56
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.success, children: String(obj.message) }) }));
57
- }
58
- // If message suggests error, color it red
59
- if (String(obj.message).toLowerCase().includes("error") ||
60
- String(obj.message).toLowerCase().includes("failed")) {
61
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.error, children: String(obj.message) }) }));
62
- }
63
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { children: String(obj.message) }) }));
64
- }
65
- // Last resort
66
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.textMuted, children: "(Comment posted)" }) }));
67
- },
68
- };
69
- //# sourceMappingURL=index.js.map
@@ -1,71 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Box, Text } from "ink";
3
- import { FallbackToolUseRejectedMessage } from "../../components/FallbackToolUseRejectedMessage.js";
4
- import { getTheme } from "../../theme/index.js";
5
- import { safeFallbackText } from "../truncation.js";
6
- function truncateText(text, maxLen = 60) {
7
- return text.length > maxLen ? text.slice(0, maxLen - 1) + "…" : text;
8
- }
9
- export const QuipReadToolRenderers = {
10
- displayName() {
11
- return "Quip";
12
- },
13
- renderInput(input, { verbose } = {}) {
14
- const action = String(input.action ?? "read");
15
- const query = input.query ? truncateText(String(input.query)) : "";
16
- const threadId = input.threadId ? truncateText(String(input.threadId)) : "";
17
- const parts = [action];
18
- if (query) {
19
- parts.push(`query: ${query}`);
20
- }
21
- else if (threadId) {
22
- parts.push(`threadId: ${threadId}`);
23
- }
24
- return (_jsx(Box, { flexDirection: "row", children: _jsx(Text, { children: parts.join(", ") }) }));
25
- },
26
- renderRejection() {
27
- return _jsx(FallbackToolUseRejectedMessage, {});
28
- },
29
- renderOutput(output, { verbose } = {}) {
30
- const theme = getTheme();
31
- // Handle null/undefined
32
- if (output == null) {
33
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.textMuted, children: "(No content)" }) }));
34
- }
35
- // Handle plain string
36
- if (typeof output === "string") {
37
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { children: safeFallbackText(output) }) }));
38
- }
39
- const obj = output;
40
- // Handle error case: { success: false, message: "..." }
41
- if (obj.success === false) {
42
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.error, children: String(obj.message ?? "Error reading Quip document") }) }));
43
- }
44
- // Handle success case with document data
45
- if (obj.success === true) {
46
- const data = obj.data;
47
- // If we have output text content
48
- if (data?.output && typeof data.output === "string") {
49
- const outputLines = data.output.split("\n");
50
- const previewLines = outputLines.slice(0, 2);
51
- const preview = previewLines.join("\n");
52
- return (_jsxs(Box, { flexDirection: "column", children: [_jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, dimColor: true, children: truncateText(preview, 80) }) }), outputLines.length > 2 && (_jsx(Box, { flexDirection: "row", paddingLeft: 0, children: _jsxs(Text, { color: theme.colors.textMuted, children: ["... (", outputLines.length - 2, " more lines)"] }) }))] }));
53
- }
54
- // Fallback to message if no output
55
- if (obj.message) {
56
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { children: String(obj.message) }) }));
57
- }
58
- }
59
- // Handle create_quip_document response: "Document created" message
60
- if (typeof obj.message === "string" && obj.message.toLowerCase().includes("created")) {
61
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.success, children: obj.message }) }));
62
- }
63
- // Fallback: generic message display
64
- if (obj.message) {
65
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { children: String(obj.message) }) }));
66
- }
67
- // Last resort
68
- return (_jsx(Box, { flexDirection: "column", children: _jsx(Text, { color: theme.colors.textMuted, children: "(No response)" }) }));
69
- },
70
- };
71
- //# sourceMappingURL=index.js.map
@@ -1,32 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { Box, Text } from "ink";
3
- import { FallbackToolUseRejectedMessage } from "../../components/FallbackToolUseRejectedMessage.js";
4
- import { getTheme } from "../../theme/index.js";
5
- export const RestArionToolRenderers = {
6
- displayName() {
7
- return "Rest Arion";
8
- },
9
- renderInput(input, _opts) {
10
- if (input.name) {
11
- return `${input.name}`;
12
- }
13
- return Object.entries(input)
14
- .map(([key, value]) => `${key}: ${JSON.stringify(value)}`)
15
- .join(", ");
16
- },
17
- renderRejection() {
18
- return _jsx(FallbackToolUseRejectedMessage, {});
19
- },
20
- renderOutput(output, _opts) {
21
- const theme = getTheme();
22
- // Handle undefined/null output (ARIA may return undefined)
23
- if (output == null) {
24
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, children: "Arion is now resting" }) }) }));
25
- }
26
- const message = typeof output === "string"
27
- ? output
28
- : output.message || `${output.name || "Arion"} is now resting`;
29
- return (_jsx(Box, { justifyContent: "space-between", overflowX: "hidden", width: "100%", children: _jsx(Box, { flexDirection: "row", children: _jsx(Text, { color: theme.colors.textMuted, children: message }) }) }));
30
- },
31
- };
32
- //# sourceMappingURL=index.js.map