centaurus-cli 2.0.0

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 (338) hide show
  1. package/AUTH_FLOW.md +138 -0
  2. package/CONFIG_GUIDE.md +255 -0
  3. package/LICENSE +21 -0
  4. package/README.md +346 -0
  5. package/dist/ai/provider-factory.d.ts +6 -0
  6. package/dist/ai/provider-factory.d.ts.map +1 -0
  7. package/dist/ai/provider-factory.js +27 -0
  8. package/dist/ai/provider-factory.js.map +1 -0
  9. package/dist/ai/providers/base.d.ts +25 -0
  10. package/dist/ai/providers/base.d.ts.map +1 -0
  11. package/dist/ai/providers/base.js +9 -0
  12. package/dist/ai/providers/base.js.map +1 -0
  13. package/dist/ai/providers/gemini.d.ts +34 -0
  14. package/dist/ai/providers/gemini.d.ts.map +1 -0
  15. package/dist/ai/providers/gemini.js +146 -0
  16. package/dist/ai/providers/gemini.js.map +1 -0
  17. package/dist/ai/types.d.ts +20 -0
  18. package/dist/ai/types.d.ts.map +1 -0
  19. package/dist/ai/types.js +2 -0
  20. package/dist/ai/types.js.map +1 -0
  21. package/dist/cli-adapter.d.ts +78 -0
  22. package/dist/cli-adapter.d.ts.map +1 -0
  23. package/dist/cli-adapter.js +605 -0
  24. package/dist/cli-adapter.js.map +1 -0
  25. package/dist/commands/CommandParser.d.ts +27 -0
  26. package/dist/commands/CommandParser.d.ts.map +1 -0
  27. package/dist/commands/CommandParser.js +238 -0
  28. package/dist/commands/CommandParser.js.map +1 -0
  29. package/dist/config/ConfigManager.d.ts +59 -0
  30. package/dist/config/ConfigManager.d.ts.map +1 -0
  31. package/dist/config/ConfigManager.js +332 -0
  32. package/dist/config/ConfigManager.js.map +1 -0
  33. package/dist/config/defaultConfig.d.ts +82 -0
  34. package/dist/config/defaultConfig.d.ts.map +1 -0
  35. package/dist/config/defaultConfig.js +88 -0
  36. package/dist/config/defaultConfig.js.map +1 -0
  37. package/dist/config/manager.d.ts +60 -0
  38. package/dist/config/manager.d.ts.map +1 -0
  39. package/dist/config/manager.js +162 -0
  40. package/dist/config/manager.js.map +1 -0
  41. package/dist/config/types.d.ts +9 -0
  42. package/dist/config/types.d.ts.map +1 -0
  43. package/dist/config/types.js +6 -0
  44. package/dist/config/types.js.map +1 -0
  45. package/dist/index-custom.d.ts +3 -0
  46. package/dist/index-custom.d.ts.map +1 -0
  47. package/dist/index-custom.js +65 -0
  48. package/dist/index-custom.js.map +1 -0
  49. package/dist/index.d.ts +3 -0
  50. package/dist/index.d.ts.map +1 -0
  51. package/dist/index.js +102 -0
  52. package/dist/index.js.map +1 -0
  53. package/dist/prompts/system-prompt.d.ts +47 -0
  54. package/dist/prompts/system-prompt.d.ts.map +1 -0
  55. package/dist/prompts/system-prompt.js +378 -0
  56. package/dist/prompts/system-prompt.js.map +1 -0
  57. package/dist/providers/GoogleProvider.d.ts +26 -0
  58. package/dist/providers/GoogleProvider.d.ts.map +1 -0
  59. package/dist/providers/GoogleProvider.js +313 -0
  60. package/dist/providers/GoogleProvider.js.map +1 -0
  61. package/dist/providers/Provider.d.ts +114 -0
  62. package/dist/providers/Provider.d.ts.map +1 -0
  63. package/dist/providers/Provider.js +44 -0
  64. package/dist/providers/Provider.js.map +1 -0
  65. package/dist/services/api-client.d.ts +282 -0
  66. package/dist/services/api-client.d.ts.map +1 -0
  67. package/dist/services/api-client.js +339 -0
  68. package/dist/services/api-client.js.map +1 -0
  69. package/dist/services/auth-handler.d.ts +30 -0
  70. package/dist/services/auth-handler.d.ts.map +1 -0
  71. package/dist/services/auth-handler.js +210 -0
  72. package/dist/services/auth-handler.js.map +1 -0
  73. package/dist/services/conversation-manager.d.ts +73 -0
  74. package/dist/services/conversation-manager.d.ts.map +1 -0
  75. package/dist/services/conversation-manager.js +128 -0
  76. package/dist/services/conversation-manager.js.map +1 -0
  77. package/dist/tests/automated-verification.d.ts +27 -0
  78. package/dist/tests/automated-verification.d.ts.map +1 -0
  79. package/dist/tests/automated-verification.js +359 -0
  80. package/dist/tests/automated-verification.js.map +1 -0
  81. package/dist/tests/integration-tests.d.ts +50 -0
  82. package/dist/tests/integration-tests.d.ts.map +1 -0
  83. package/dist/tests/integration-tests.js +648 -0
  84. package/dist/tests/integration-tests.js.map +1 -0
  85. package/dist/tools/ToolRegistry.d.ts +44 -0
  86. package/dist/tools/ToolRegistry.d.ts.map +1 -0
  87. package/dist/tools/ToolRegistry.js +494 -0
  88. package/dist/tools/ToolRegistry.js.map +1 -0
  89. package/dist/tools/command.d.ts +4 -0
  90. package/dist/tools/command.d.ts.map +1 -0
  91. package/dist/tools/command.js +117 -0
  92. package/dist/tools/command.js.map +1 -0
  93. package/dist/tools/file-ops-test.d.ts +6 -0
  94. package/dist/tools/file-ops-test.d.ts.map +1 -0
  95. package/dist/tools/file-ops-test.js +197 -0
  96. package/dist/tools/file-ops-test.js.map +1 -0
  97. package/dist/tools/file-ops.d.ts +6 -0
  98. package/dist/tools/file-ops.d.ts.map +1 -0
  99. package/dist/tools/file-ops.js +189 -0
  100. package/dist/tools/file-ops.js.map +1 -0
  101. package/dist/tools/plan-mode.d.ts +53 -0
  102. package/dist/tools/plan-mode.d.ts.map +1 -0
  103. package/dist/tools/plan-mode.js +202 -0
  104. package/dist/tools/plan-mode.js.map +1 -0
  105. package/dist/tools/registry.d.ts +30 -0
  106. package/dist/tools/registry.d.ts.map +1 -0
  107. package/dist/tools/registry.js +67 -0
  108. package/dist/tools/registry.js.map +1 -0
  109. package/dist/tools/types.d.ts +34 -0
  110. package/dist/tools/types.d.ts.map +1 -0
  111. package/dist/tools/types.js +2 -0
  112. package/dist/tools/types.js.map +1 -0
  113. package/dist/tools/web-search.d.ts +24 -0
  114. package/dist/tools/web-search.d.ts.map +1 -0
  115. package/dist/tools/web-search.js +194 -0
  116. package/dist/tools/web-search.js.map +1 -0
  117. package/dist/types/index.d.ts +32 -0
  118. package/dist/types/index.d.ts.map +1 -0
  119. package/dist/types/index.js +2 -0
  120. package/dist/types/index.js.map +1 -0
  121. package/dist/ui/DisplayHistory.d.ts +53 -0
  122. package/dist/ui/DisplayHistory.d.ts.map +1 -0
  123. package/dist/ui/DisplayHistory.js +82 -0
  124. package/dist/ui/DisplayHistory.js.map +1 -0
  125. package/dist/ui/clack-ui.d.ts +83 -0
  126. package/dist/ui/clack-ui.d.ts.map +1 -0
  127. package/dist/ui/clack-ui.js +304 -0
  128. package/dist/ui/clack-ui.js.map +1 -0
  129. package/dist/ui/components/App.d.ts +47 -0
  130. package/dist/ui/components/App.d.ts.map +1 -0
  131. package/dist/ui/components/App.js +389 -0
  132. package/dist/ui/components/App.js.map +1 -0
  133. package/dist/ui/components/AuthScreen.d.ts +8 -0
  134. package/dist/ui/components/AuthScreen.d.ts.map +1 -0
  135. package/dist/ui/components/AuthScreen.js +37 -0
  136. package/dist/ui/components/AuthScreen.js.map +1 -0
  137. package/dist/ui/components/AuthWelcomeScreen.d.ts +8 -0
  138. package/dist/ui/components/AuthWelcomeScreen.d.ts.map +1 -0
  139. package/dist/ui/components/AuthWelcomeScreen.js +34 -0
  140. package/dist/ui/components/AuthWelcomeScreen.js.map +1 -0
  141. package/dist/ui/components/CodeBlock.d.ts +9 -0
  142. package/dist/ui/components/CodeBlock.d.ts.map +1 -0
  143. package/dist/ui/components/CodeBlock.js +22 -0
  144. package/dist/ui/components/CodeBlock.js.map +1 -0
  145. package/dist/ui/components/ConfigViewer.d.ts +11 -0
  146. package/dist/ui/components/ConfigViewer.d.ts.map +1 -0
  147. package/dist/ui/components/ConfigViewer.js +27 -0
  148. package/dist/ui/components/ConfigViewer.js.map +1 -0
  149. package/dist/ui/components/ConfirmPrompt.d.ts +11 -0
  150. package/dist/ui/components/ConfirmPrompt.d.ts.map +1 -0
  151. package/dist/ui/components/ConfirmPrompt.js +55 -0
  152. package/dist/ui/components/ConfirmPrompt.js.map +1 -0
  153. package/dist/ui/components/DiffViewer.d.ts +8 -0
  154. package/dist/ui/components/DiffViewer.d.ts.map +1 -0
  155. package/dist/ui/components/DiffViewer.js +63 -0
  156. package/dist/ui/components/DiffViewer.js.map +1 -0
  157. package/dist/ui/components/DisplayItemRenderer.d.ts +18 -0
  158. package/dist/ui/components/DisplayItemRenderer.d.ts.map +1 -0
  159. package/dist/ui/components/DisplayItemRenderer.js +53 -0
  160. package/dist/ui/components/DisplayItemRenderer.js.map +1 -0
  161. package/dist/ui/components/DynamicMessage.d.ts +13 -0
  162. package/dist/ui/components/DynamicMessage.d.ts.map +1 -0
  163. package/dist/ui/components/DynamicMessage.js +27 -0
  164. package/dist/ui/components/DynamicMessage.js.map +1 -0
  165. package/dist/ui/components/ErrorBoundary.d.ts +16 -0
  166. package/dist/ui/components/ErrorBoundary.d.ts.map +1 -0
  167. package/dist/ui/components/ErrorBoundary.js +25 -0
  168. package/dist/ui/components/ErrorBoundary.js.map +1 -0
  169. package/dist/ui/components/FileOperation.d.ts +10 -0
  170. package/dist/ui/components/FileOperation.d.ts.map +1 -0
  171. package/dist/ui/components/FileOperation.js +31 -0
  172. package/dist/ui/components/FileOperation.js.map +1 -0
  173. package/dist/ui/components/InputBox.d.ts +12 -0
  174. package/dist/ui/components/InputBox.d.ts.map +1 -0
  175. package/dist/ui/components/InputBox.js +50 -0
  176. package/dist/ui/components/InputBox.js.map +1 -0
  177. package/dist/ui/components/KeyboardHelp.d.ts +7 -0
  178. package/dist/ui/components/KeyboardHelp.d.ts.map +1 -0
  179. package/dist/ui/components/KeyboardHelp.js +25 -0
  180. package/dist/ui/components/KeyboardHelp.js.map +1 -0
  181. package/dist/ui/components/LoadingIndicator.d.ts +3 -0
  182. package/dist/ui/components/LoadingIndicator.d.ts.map +1 -0
  183. package/dist/ui/components/LoadingIndicator.js +25 -0
  184. package/dist/ui/components/LoadingIndicator.js.map +1 -0
  185. package/dist/ui/components/MarkdownRenderer.d.ts +8 -0
  186. package/dist/ui/components/MarkdownRenderer.d.ts.map +1 -0
  187. package/dist/ui/components/MarkdownRenderer.js +96 -0
  188. package/dist/ui/components/MarkdownRenderer.js.map +1 -0
  189. package/dist/ui/components/MessageBox.d.ts +10 -0
  190. package/dist/ui/components/MessageBox.d.ts.map +1 -0
  191. package/dist/ui/components/MessageBox.js +50 -0
  192. package/dist/ui/components/MessageBox.js.map +1 -0
  193. package/dist/ui/components/MessageDisplay.d.ts +8 -0
  194. package/dist/ui/components/MessageDisplay.d.ts.map +1 -0
  195. package/dist/ui/components/MessageDisplay.js +43 -0
  196. package/dist/ui/components/MessageDisplay.js.map +1 -0
  197. package/dist/ui/components/ScrollableContent.d.ts +7 -0
  198. package/dist/ui/components/ScrollableContent.d.ts.map +1 -0
  199. package/dist/ui/components/ScrollableContent.js +6 -0
  200. package/dist/ui/components/ScrollableContent.js.map +1 -0
  201. package/dist/ui/components/ScrollableMessageList.d.ts +10 -0
  202. package/dist/ui/components/ScrollableMessageList.d.ts.map +1 -0
  203. package/dist/ui/components/ScrollableMessageList.js +133 -0
  204. package/dist/ui/components/ScrollableMessageList.js.map +1 -0
  205. package/dist/ui/components/ScrollableScreen.d.ts +9 -0
  206. package/dist/ui/components/ScrollableScreen.d.ts.map +1 -0
  207. package/dist/ui/components/ScrollableScreen.js +22 -0
  208. package/dist/ui/components/ScrollableScreen.js.map +1 -0
  209. package/dist/ui/components/SelectPrompt.d.ts +12 -0
  210. package/dist/ui/components/SelectPrompt.d.ts.map +1 -0
  211. package/dist/ui/components/SelectPrompt.js +10 -0
  212. package/dist/ui/components/SelectPrompt.js.map +1 -0
  213. package/dist/ui/components/StaticMessageHistory.d.ts +14 -0
  214. package/dist/ui/components/StaticMessageHistory.d.ts.map +1 -0
  215. package/dist/ui/components/StaticMessageHistory.js +19 -0
  216. package/dist/ui/components/StaticMessageHistory.js.map +1 -0
  217. package/dist/ui/components/StatusBar.d.ts +10 -0
  218. package/dist/ui/components/StatusBar.d.ts.map +1 -0
  219. package/dist/ui/components/StatusBar.js +20 -0
  220. package/dist/ui/components/StatusBar.js.map +1 -0
  221. package/dist/ui/components/StreamingMessageDisplay.d.ts +13 -0
  222. package/dist/ui/components/StreamingMessageDisplay.d.ts.map +1 -0
  223. package/dist/ui/components/StreamingMessageDisplay.js +26 -0
  224. package/dist/ui/components/StreamingMessageDisplay.js.map +1 -0
  225. package/dist/ui/components/ToolExecutionMessage.d.ts +8 -0
  226. package/dist/ui/components/ToolExecutionMessage.d.ts.map +1 -0
  227. package/dist/ui/components/ToolExecutionMessage.js +189 -0
  228. package/dist/ui/components/ToolExecutionMessage.js.map +1 -0
  229. package/dist/ui/components/ToolExecutionStatus.d.ts +10 -0
  230. package/dist/ui/components/ToolExecutionStatus.d.ts.map +1 -0
  231. package/dist/ui/components/ToolExecutionStatus.js +65 -0
  232. package/dist/ui/components/ToolExecutionStatus.js.map +1 -0
  233. package/dist/ui/components/ToolResult.d.ts +10 -0
  234. package/dist/ui/components/ToolResult.d.ts.map +1 -0
  235. package/dist/ui/components/ToolResult.js +17 -0
  236. package/dist/ui/components/ToolResult.js.map +1 -0
  237. package/dist/ui/components/WelcomeBanner.d.ts +3 -0
  238. package/dist/ui/components/WelcomeBanner.d.ts.map +1 -0
  239. package/dist/ui/components/WelcomeBanner.js +28 -0
  240. package/dist/ui/components/WelcomeBanner.js.map +1 -0
  241. package/dist/ui/components/code-block.d.ts +10 -0
  242. package/dist/ui/components/code-block.d.ts.map +1 -0
  243. package/dist/ui/components/code-block.js +74 -0
  244. package/dist/ui/components/code-block.js.map +1 -0
  245. package/dist/ui/components/confirm-prompt.d.ts +12 -0
  246. package/dist/ui/components/confirm-prompt.d.ts.map +1 -0
  247. package/dist/ui/components/confirm-prompt.js +104 -0
  248. package/dist/ui/components/confirm-prompt.js.map +1 -0
  249. package/dist/ui/components/diff-viewer.d.ts +9 -0
  250. package/dist/ui/components/diff-viewer.d.ts.map +1 -0
  251. package/dist/ui/components/diff-viewer.js +57 -0
  252. package/dist/ui/components/diff-viewer.js.map +1 -0
  253. package/dist/ui/components/input-box.d.ts +18 -0
  254. package/dist/ui/components/input-box.d.ts.map +1 -0
  255. package/dist/ui/components/input-box.js +157 -0
  256. package/dist/ui/components/input-box.js.map +1 -0
  257. package/dist/ui/components/keyboard-help.d.ts +7 -0
  258. package/dist/ui/components/keyboard-help.d.ts.map +1 -0
  259. package/dist/ui/components/keyboard-help.js +43 -0
  260. package/dist/ui/components/keyboard-help.js.map +1 -0
  261. package/dist/ui/components/loading-indicator.d.ts +3 -0
  262. package/dist/ui/components/loading-indicator.d.ts.map +1 -0
  263. package/dist/ui/components/loading-indicator.js +42 -0
  264. package/dist/ui/components/loading-indicator.js.map +1 -0
  265. package/dist/ui/components/message-display.d.ts +7 -0
  266. package/dist/ui/components/message-display.d.ts.map +1 -0
  267. package/dist/ui/components/message-display.js +104 -0
  268. package/dist/ui/components/message-display.js.map +1 -0
  269. package/dist/ui/components/misc.d.ts +28 -0
  270. package/dist/ui/components/misc.d.ts.map +1 -0
  271. package/dist/ui/components/misc.js +128 -0
  272. package/dist/ui/components/misc.js.map +1 -0
  273. package/dist/ui/components/select-prompt.d.ts +13 -0
  274. package/dist/ui/components/select-prompt.d.ts.map +1 -0
  275. package/dist/ui/components/select-prompt.js +42 -0
  276. package/dist/ui/components/select-prompt.js.map +1 -0
  277. package/dist/ui/components/status-bar.d.ts +11 -0
  278. package/dist/ui/components/status-bar.d.ts.map +1 -0
  279. package/dist/ui/components/status-bar.js +47 -0
  280. package/dist/ui/components/status-bar.js.map +1 -0
  281. package/dist/ui/components/tool-execution.d.ts +3 -0
  282. package/dist/ui/components/tool-execution.d.ts.map +1 -0
  283. package/dist/ui/components/tool-execution.js +374 -0
  284. package/dist/ui/components/tool-execution.js.map +1 -0
  285. package/dist/ui/components/tool-result.d.ts +11 -0
  286. package/dist/ui/components/tool-result.d.ts.map +1 -0
  287. package/dist/ui/components/tool-result.js +58 -0
  288. package/dist/ui/components/tool-result.js.map +1 -0
  289. package/dist/ui/components/welcome-banner.d.ts +3 -0
  290. package/dist/ui/components/welcome-banner.d.ts.map +1 -0
  291. package/dist/ui/components/welcome-banner.js +46 -0
  292. package/dist/ui/components/welcome-banner.js.map +1 -0
  293. package/dist/ui/hooks/useDisplayHistory.d.ts +13 -0
  294. package/dist/ui/hooks/useDisplayHistory.d.ts.map +1 -0
  295. package/dist/ui/hooks/useDisplayHistory.js +45 -0
  296. package/dist/ui/hooks/useDisplayHistory.js.map +1 -0
  297. package/dist/ui/render-engine.d.ts +69 -0
  298. package/dist/ui/render-engine.d.ts.map +1 -0
  299. package/dist/ui/render-engine.js +197 -0
  300. package/dist/ui/render-engine.js.map +1 -0
  301. package/dist/ui/terminal/TerminalRenderer.d.ts +84 -0
  302. package/dist/ui/terminal/TerminalRenderer.d.ts.map +1 -0
  303. package/dist/ui/terminal/TerminalRenderer.js +154 -0
  304. package/dist/ui/terminal/TerminalRenderer.js.map +1 -0
  305. package/dist/ui/terminal/TerminalUI.d.ts +139 -0
  306. package/dist/ui/terminal/TerminalUI.d.ts.map +1 -0
  307. package/dist/ui/terminal/TerminalUI.js +430 -0
  308. package/dist/ui/terminal/TerminalUI.js.map +1 -0
  309. package/dist/ui/terminal/VirtualChatBuffer.d.ts +32 -0
  310. package/dist/ui/terminal/VirtualChatBuffer.d.ts.map +1 -0
  311. package/dist/ui/terminal/VirtualChatBuffer.js +37 -0
  312. package/dist/ui/terminal/VirtualChatBuffer.js.map +1 -0
  313. package/dist/ui/terminal-kit-base.d.ts +117 -0
  314. package/dist/ui/terminal-kit-base.d.ts.map +1 -0
  315. package/dist/ui/terminal-kit-base.js +188 -0
  316. package/dist/ui/terminal-kit-base.js.map +1 -0
  317. package/dist/utils/file.d.ts +21 -0
  318. package/dist/utils/file.d.ts.map +1 -0
  319. package/dist/utils/file.js +68 -0
  320. package/dist/utils/file.js.map +1 -0
  321. package/dist/utils/logger.d.ts +17 -0
  322. package/dist/utils/logger.d.ts.map +1 -0
  323. package/dist/utils/logger.js +57 -0
  324. package/dist/utils/logger.js.map +1 -0
  325. package/dist/utils/markdown-parser.d.ts +56 -0
  326. package/dist/utils/markdown-parser.d.ts.map +1 -0
  327. package/dist/utils/markdown-parser.js +307 -0
  328. package/dist/utils/markdown-parser.js.map +1 -0
  329. package/dist/utils/shell.d.ts +7 -0
  330. package/dist/utils/shell.d.ts.map +1 -0
  331. package/dist/utils/shell.js +62 -0
  332. package/dist/utils/shell.js.map +1 -0
  333. package/dist/utils/state.d.ts +13 -0
  334. package/dist/utils/state.d.ts.map +1 -0
  335. package/dist/utils/state.js +25 -0
  336. package/dist/utils/state.js.map +1 -0
  337. package/package.json +81 -0
  338. package/postinstall.js +46 -0
@@ -0,0 +1,96 @@
1
+ import React, { useMemo } from 'react';
2
+ import { Box, Text } from 'ink';
3
+ import { MarkdownParser, wrapText } from '../../utils/markdown-parser.js';
4
+ export const MarkdownRenderer = ({ content, maxWidth = 100 }) => {
5
+ const parser = useMemo(() => new MarkdownParser(), []);
6
+ const elements = useMemo(() => parser.parse(content), [content, parser]);
7
+ const renderInlineElements = (children) => {
8
+ if (!children || children.length === 0)
9
+ return null;
10
+ return children.map((child, idx) => {
11
+ switch (child.type) {
12
+ case 'bold':
13
+ return (React.createElement(Text, { key: idx, bold: true, color: "#ffffff" }, child.content));
14
+ case 'italic':
15
+ return (React.createElement(Text, { key: idx, italic: true, color: "#cccccc" }, child.content));
16
+ case 'code-inline':
17
+ return (React.createElement(Text, { key: idx, backgroundColor: "#2d2d2d", color: "#ff79c6" }, ` ${child.content} `));
18
+ case 'link':
19
+ return (React.createElement(Text, { key: idx, color: "#00ccff", underline: true }, child.content));
20
+ case 'text':
21
+ default:
22
+ return (React.createElement(Text, { key: idx, color: "#ffffff" }, child.content));
23
+ }
24
+ });
25
+ };
26
+ const renderElement = (element, index) => {
27
+ switch (element.type) {
28
+ case 'heading': {
29
+ const level = element.level || 1;
30
+ const colors = ['#00ffff', '#00dddd', '#00bbbb', '#009999', '#007777', '#005555'];
31
+ const color = colors[level - 1] || '#ffffff';
32
+ const prefix = level === 1 ? '\n' : '';
33
+ const suffix = '\n';
34
+ return (React.createElement(Box, { key: index, flexDirection: "column", marginBottom: 1 },
35
+ React.createElement(Text, { bold: true, color: color },
36
+ prefix,
37
+ '#'.repeat(level),
38
+ " ",
39
+ element.content,
40
+ suffix)));
41
+ }
42
+ case 'code-block': {
43
+ const lines = element.content.split('\n');
44
+ return (React.createElement(Box, { key: index, flexDirection: "column", marginBottom: 1, marginTop: 1 },
45
+ React.createElement(Box, { borderStyle: "round", borderColor: "#666666", paddingX: 1, paddingY: 0 },
46
+ React.createElement(Box, { flexDirection: "column" },
47
+ element.language && element.language !== 'text' && (React.createElement(Text, { color: "#888888", dimColor: true }, element.language)),
48
+ lines.map((line, lineIdx) => (React.createElement(Text, { key: lineIdx, color: "#f8f8f2" }, line || ' ')))))));
49
+ }
50
+ case 'list-item': {
51
+ const indent = (element.level || 0) * 2;
52
+ const bullet = element.ordered ? `${element.index}.` : '•';
53
+ const bulletColor = '#00cc66';
54
+ return (React.createElement(Box, { key: index, flexDirection: "column", marginBottom: 0 },
55
+ React.createElement(Box, null,
56
+ React.createElement(Text, { color: "#666666" }, ' '.repeat(indent)),
57
+ React.createElement(Text, { color: bulletColor, bold: true },
58
+ bullet,
59
+ ' '),
60
+ element.children && element.children.length > 0 ? (React.createElement(Text, null, renderInlineElements(element.children))) : (React.createElement(Text, { color: "#ffffff" }, element.content)))));
61
+ }
62
+ case 'blockquote': {
63
+ return (React.createElement(Box, { key: index, flexDirection: "row", marginBottom: 1 },
64
+ React.createElement(Text, { color: "#666666", bold: true },
65
+ "\u2502",
66
+ ' '),
67
+ React.createElement(Text, { color: "#cccccc", italic: true }, element.children && element.children.length > 0
68
+ ? renderInlineElements(element.children)
69
+ : element.content)));
70
+ }
71
+ case 'horizontal-rule': {
72
+ return (React.createElement(Box, { key: index, marginY: 1 },
73
+ React.createElement(Text, { color: "#444444" }, '─'.repeat(Math.min(maxWidth, 80)))));
74
+ }
75
+ case 'line-break': {
76
+ return React.createElement(Box, { key: index, height: 1 });
77
+ }
78
+ case 'text': {
79
+ // If we have inline children (formatted text), render them directly
80
+ if (element.children && element.children.length > 0) {
81
+ return (React.createElement(Box, { key: index, flexDirection: "column", marginBottom: 1 },
82
+ React.createElement(Box, { paddingLeft: 2 },
83
+ React.createElement(Text, null, renderInlineElements(element.children)))));
84
+ }
85
+ // Otherwise, wrap plain text if needed
86
+ const wrappedLines = wrapText(element.content, maxWidth, 2);
87
+ return (React.createElement(Box, { key: index, flexDirection: "column", marginBottom: 1 }, wrappedLines.map((line, lineIdx) => (React.createElement(Box, { key: lineIdx, paddingLeft: 2 },
88
+ React.createElement(Text, { color: "#ffffff" }, line))))));
89
+ }
90
+ default:
91
+ return null;
92
+ }
93
+ };
94
+ return (React.createElement(Box, { flexDirection: "column" }, elements.map((element, index) => renderElement(element, index))));
95
+ };
96
+ //# sourceMappingURL=MarkdownRenderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarkdownRenderer.js","sourceRoot":"","sources":["../../../src/ui/components/MarkdownRenderer.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ interface MessageBoxProps {
3
+ role: 'user' | 'assistant' | 'system';
4
+ content: string;
5
+ timestamp?: Date;
6
+ isStreaming?: boolean;
7
+ }
8
+ export declare const MessageBox: React.FC<MessageBoxProps>;
9
+ export default MessageBox;
10
+ //# sourceMappingURL=MessageBox.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageBox.d.ts","sourceRoot":"","sources":["../../../src/ui/components/MessageBox.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,eAAe;IACvB,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,QAAQ,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CA+EhD,CAAC;AAEF,eAAe,UAAU,CAAC"}
@@ -0,0 +1,50 @@
1
+ import React from 'react';
2
+ import { Box, Text } from 'ink';
3
+ import chalk from 'chalk';
4
+ export const MessageBox = ({ role, content, timestamp, isStreaming }) => {
5
+ const renderContent = () => {
6
+ // Parse markdown-style formatting
7
+ let formattedContent = content;
8
+ // Bold text
9
+ formattedContent = formattedContent.replace(/\*\*(.*?)\*\*/g, (_, text) => chalk.bold(text));
10
+ // Code blocks
11
+ formattedContent = formattedContent.replace(/`([^`]+)`/g, (_, code) => chalk.gray.bgBlackBright(` ${code} `));
12
+ // Links
13
+ formattedContent = formattedContent.replace(/\[([^\]]+)\]\(([^)]+)\)/g, (_, text, url) => chalk.blue.underline(text));
14
+ return formattedContent;
15
+ };
16
+ const getPrefix = () => {
17
+ switch (role) {
18
+ case 'user':
19
+ return chalk.cyan('Your Message:');
20
+ case 'assistant':
21
+ return chalk.green('Centaurus:');
22
+ case 'system':
23
+ return chalk.yellow('System:');
24
+ default:
25
+ return '';
26
+ }
27
+ };
28
+ const getBorderColor = () => {
29
+ switch (role) {
30
+ case 'user':
31
+ return 'cyan';
32
+ case 'assistant':
33
+ return 'green';
34
+ case 'system':
35
+ return 'yellow';
36
+ default:
37
+ return 'white';
38
+ }
39
+ };
40
+ return (React.createElement(Box, { flexDirection: "column", marginY: 1, paddingX: 1, borderStyle: "round", borderColor: getBorderColor() },
41
+ React.createElement(Box, { justifyContent: "space-between", marginBottom: 1 },
42
+ React.createElement(Text, null, getPrefix()),
43
+ timestamp && (React.createElement(Text, { dimColor: true }, timestamp.toLocaleTimeString()))),
44
+ React.createElement(Box, { paddingLeft: 2 },
45
+ React.createElement(Text, { wrap: "wrap" },
46
+ renderContent(),
47
+ isStreaming && React.createElement(Text, { color: "cyan" }, "\u258C")))));
48
+ };
49
+ export default MessageBox;
50
+ //# sourceMappingURL=MessageBox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageBox.js","sourceRoot":"","sources":["../../../src/ui/components/MessageBox.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,KAAK,MAAM,OAAO,CAAC;AAS1B,MAAM,CAAC,MAAM,UAAU,GAA8B,CAAC,EACpD,IAAI,EACJ,OAAO,EACP,SAAS,EACT,WAAW,EACZ,EAAE,EAAE;IACH,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,kCAAkC;QAClC,IAAI,gBAAgB,GAAG,OAAO,CAAC;QAE/B,YAAY;QACZ,gBAAgB,GAAG,gBAAgB,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,CACxE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CACjB,CAAC;QAEF,cAAc;QACd,gBAAgB,GAAG,gBAAgB,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,CACpE,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,GAAG,CAAC,CACtC,CAAC;QAEF,QAAQ;QACR,gBAAgB,GAAG,gBAAgB,CAAC,OAAO,CAAC,0BAA0B,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE,CACvF,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAC3B,CAAC;QAEF,OAAO,gBAAgB,CAAC;IAC1B,CAAC,CAAC;IAEF,MAAM,SAAS,GAAG,GAAG,EAAE;QACrB,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,MAAM;gBACT,OAAO,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YACrC,KAAK,WAAW;gBACd,OAAO,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YACnC,KAAK,QAAQ;gBACX,OAAO,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YACjC;gBACE,OAAO,EAAE,CAAC;QACd,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,MAAM;gBACT,OAAO,MAAM,CAAC;YAChB,KAAK,WAAW;gBACd,OAAO,OAAO,CAAC;YACjB,KAAK,QAAQ;gBACX,OAAO,QAAQ,CAAC;YAClB;gBACE,OAAO,OAAO,CAAC;QACnB,CAAC;IACH,CAAC,CAAC;IAEF,OAAO,CACL,oBAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,OAAO,EAAE,CAAC,EACV,QAAQ,EAAE,CAAC,EACX,WAAW,EAAC,OAAO,EACnB,WAAW,EAAE,cAAc,EAAE;QAE7B,oBAAC,GAAG,IAAC,cAAc,EAAC,eAAe,EAAC,YAAY,EAAE,CAAC;YACjD,oBAAC,IAAI,QAAE,SAAS,EAAE,CAAQ;YACzB,SAAS,IAAI,CACZ,oBAAC,IAAI,IAAC,QAAQ,UACX,SAAS,CAAC,kBAAkB,EAAE,CAC1B,CACR,CACG;QAEN,oBAAC,GAAG,IAAC,WAAW,EAAE,CAAC;YACjB,oBAAC,IAAI,IAAC,IAAI,EAAC,MAAM;gBACd,aAAa,EAAE;gBACf,WAAW,IAAI,oBAAC,IAAI,IAAC,KAAK,EAAC,MAAM,aAAS,CACtC,CACH,CACF,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,UAAU,CAAC"}
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import { Message } from '../../types/index.js';
3
+ interface MessageDisplayProps {
4
+ message: Message;
5
+ }
6
+ export declare const MessageDisplay: React.FC<MessageDisplayProps>;
7
+ export {};
8
+ //# sourceMappingURL=MessageDisplay.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageDisplay.d.ts","sourceRoot":"","sources":["../../../src/ui/components/MessageDisplay.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAI/C,UAAU,mBAAmB;IAC3B,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,eAAO,MAAM,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC,mBAAmB,CAoDvD,CAAC"}
@@ -0,0 +1,43 @@
1
+ import React from 'react';
2
+ import { Box, Text } from 'ink';
3
+ import { ToolExecutionMessage } from './ToolExecutionMessage.js';
4
+ import { MarkdownRenderer } from './MarkdownRenderer.js';
5
+ export const MessageDisplay = React.memo(({ message }) => {
6
+ const getRoleColor = (role) => {
7
+ switch (role) {
8
+ case 'user': return '#00ccff';
9
+ case 'assistant': return '#00cc66';
10
+ case 'system': return '#ffaa00';
11
+ case 'tool': return '#00ccff';
12
+ default: return '#ffffff';
13
+ }
14
+ };
15
+ const getRoleLabel = (role) => {
16
+ switch (role) {
17
+ case 'user': return 'You';
18
+ case 'assistant': return 'Centaurus';
19
+ case 'system': return 'System';
20
+ case 'tool': return 'Tool';
21
+ default: return role;
22
+ }
23
+ };
24
+ const timestamp = message.timestamp
25
+ ? new Date(message.timestamp).toLocaleTimeString()
26
+ : '';
27
+ // Render tool execution message using specialized component
28
+ if (message.toolExecution) {
29
+ return React.createElement(ToolExecutionMessage, { message: message });
30
+ }
31
+ // Regular message rendering
32
+ return (React.createElement(Box, { flexDirection: "column", marginBottom: 1 },
33
+ React.createElement(Box, { marginBottom: 1 },
34
+ React.createElement(Text, { color: getRoleColor(message.role), bold: true },
35
+ getRoleLabel(message.role),
36
+ ":"),
37
+ timestamp && (React.createElement(Text, { color: "#666666", dimColor: true },
38
+ " ",
39
+ timestamp))),
40
+ message.role === 'assistant' ? (React.createElement(MarkdownRenderer, { content: message.content, maxWidth: 100 })) : (React.createElement(Box, { paddingLeft: 2 },
41
+ React.createElement(Text, { color: "#ffffff" }, message.content)))));
42
+ });
43
+ //# sourceMappingURL=MessageDisplay.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageDisplay.js","sourceRoot":"","sources":["../../../src/ui/components/MessageDisplay.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAEhC,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAMzD,MAAM,CAAC,MAAM,cAAc,GAAkC,KAAK,CAAC,IAAI,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE;IACtF,MAAM,YAAY,GAAG,CAAC,IAAY,EAAE,EAAE;QACpC,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,MAAM,CAAC,CAAC,OAAO,SAAS,CAAC;YAC9B,KAAK,WAAW,CAAC,CAAC,OAAO,SAAS,CAAC;YACnC,KAAK,QAAQ,CAAC,CAAC,OAAO,SAAS,CAAC;YAChC,KAAK,MAAM,CAAC,CAAC,OAAO,SAAS,CAAC;YAC9B,OAAO,CAAC,CAAC,OAAO,SAAS,CAAC;QAC5B,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,YAAY,GAAG,CAAC,IAAY,EAAE,EAAE;QACpC,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,MAAM,CAAC,CAAC,OAAO,KAAK,CAAC;YAC1B,KAAK,WAAW,CAAC,CAAC,OAAO,WAAW,CAAC;YACrC,KAAK,QAAQ,CAAC,CAAC,OAAO,QAAQ,CAAC;YAC/B,KAAK,MAAM,CAAC,CAAC,OAAO,MAAM,CAAC;YAC3B,OAAO,CAAC,CAAC,OAAO,IAAI,CAAC;QACvB,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS;QACjC,CAAC,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,kBAAkB,EAAE;QAClD,CAAC,CAAC,EAAE,CAAC;IAEP,4DAA4D;IAC5D,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;QAC1B,OAAO,oBAAC,oBAAoB,IAAC,OAAO,EAAE,OAAO,GAAI,CAAC;IACpD,CAAC;IAED,4BAA4B;IAC5B,OAAO,CACL,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,YAAY,EAAE,CAAC;QACzC,oBAAC,GAAG,IAAC,YAAY,EAAE,CAAC;YAClB,oBAAC,IAAI,IAAC,KAAK,EAAE,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI;gBAC1C,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC;oBACtB;YACN,SAAS,IAAI,CACZ,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,EAAC,QAAQ;;gBAAG,SAAS,CAAQ,CACnD,CACG;QAGL,OAAO,CAAC,IAAI,KAAK,WAAW,CAAC,CAAC,CAAC,CAC9B,oBAAC,gBAAgB,IAAC,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,QAAQ,EAAE,GAAG,GAAI,CAC9D,CAAC,CAAC,CAAC,CACF,oBAAC,GAAG,IAAC,WAAW,EAAE,CAAC;YACjB,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,IAAE,OAAO,CAAC,OAAO,CAAQ,CAC1C,CACP,CACG,CACP,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ interface ScrollableContentProps {
3
+ children: React.ReactNode;
4
+ }
5
+ export declare const ScrollableContent: React.FC<ScrollableContentProps>;
6
+ export {};
7
+ //# sourceMappingURL=ScrollableContent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollableContent.d.ts","sourceRoot":"","sources":["../../../src/ui/components/ScrollableContent.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,UAAU,sBAAsB;IAC9B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B;AAED,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,sBAAsB,CAM9D,CAAC"}
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import { Box } from 'ink';
3
+ export const ScrollableContent = ({ children }) => {
4
+ return (React.createElement(Box, { flexDirection: "column", flexGrow: 1 }, children));
5
+ };
6
+ //# sourceMappingURL=ScrollableContent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollableContent.js","sourceRoot":"","sources":["../../../src/ui/components/ScrollableContent.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAM1B,MAAM,CAAC,MAAM,iBAAiB,GAAqC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;IAClF,OAAO,CACL,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,QAAQ,EAAE,CAAC,IACpC,QAAQ,CACL,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ import { Message } from '../../types/index.js';
3
+ interface ScrollableMessageListProps {
4
+ messages: Message[];
5
+ maxScrollback?: number;
6
+ viewportHeight?: number;
7
+ }
8
+ export declare const ScrollableMessageList: React.FC<ScrollableMessageListProps>;
9
+ export {};
10
+ //# sourceMappingURL=ScrollableMessageList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollableMessageList.d.ts","sourceRoot":"","sources":["../../../src/ui/components/ScrollableMessageList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA+C,MAAM,OAAO,CAAC;AAGpE,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAE/C,UAAU,0BAA0B;IAClC,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,eAAO,MAAM,qBAAqB,EAAE,KAAK,CAAC,EAAE,CAAC,0BAA0B,CAoKtE,CAAC"}
@@ -0,0 +1,133 @@
1
+ import React, { useState, useEffect, useRef, useMemo } from 'react';
2
+ import { Box, useInput, useStdin, Text } from 'ink';
3
+ import { MessageDisplay } from './MessageDisplay.js';
4
+ export const ScrollableMessageList = ({ messages, maxScrollback = 500, viewportHeight = 20 }) => {
5
+ const [scrollOffset, setScrollOffset] = useState(0);
6
+ const [isScrolledToBottom, setIsScrolledToBottom] = useState(true);
7
+ const { stdin, setRawMode } = useStdin();
8
+ const prevMessagesLengthRef = useRef(messages.length);
9
+ // Limit messages to max scrollback
10
+ const limitedMessages = useMemo(() => {
11
+ return messages.slice(-maxScrollback);
12
+ }, [messages, maxScrollback]);
13
+ const totalMessages = limitedMessages.length;
14
+ const maxScrollOffset = Math.max(0, totalMessages - viewportHeight);
15
+ // Auto-scroll to bottom when new messages arrive (only if already at bottom)
16
+ useEffect(() => {
17
+ if (messages.length > prevMessagesLengthRef.current) {
18
+ if (isScrolledToBottom) {
19
+ setScrollOffset(Math.max(0, messages.slice(-maxScrollback).length - viewportHeight));
20
+ }
21
+ prevMessagesLengthRef.current = messages.length;
22
+ }
23
+ }, [messages, isScrolledToBottom, viewportHeight, maxScrollback]);
24
+ // Check if we're at the bottom
25
+ useEffect(() => {
26
+ const atBottom = scrollOffset >= maxScrollOffset;
27
+ setIsScrolledToBottom(atBottom);
28
+ }, [scrollOffset, maxScrollOffset]);
29
+ // Keyboard input handling
30
+ useInput((input, key) => {
31
+ // Don't handle input if there are too few messages to scroll
32
+ if (totalMessages <= viewportHeight)
33
+ return;
34
+ if (key.upArrow) {
35
+ setScrollOffset(prev => Math.max(0, prev - 1));
36
+ }
37
+ else if (key.downArrow) {
38
+ setScrollOffset(prev => Math.min(maxScrollOffset, prev + 1));
39
+ }
40
+ else if (key.pageUp) {
41
+ setScrollOffset(prev => Math.max(0, prev - viewportHeight));
42
+ }
43
+ else if (key.pageDown) {
44
+ setScrollOffset(prev => Math.min(maxScrollOffset, prev + viewportHeight));
45
+ }
46
+ else if (input === 'g' || input === 'G') {
47
+ // Home - go to top
48
+ if (input === 'g') {
49
+ setScrollOffset(0);
50
+ }
51
+ // End - go to bottom
52
+ if (input === 'G') {
53
+ setScrollOffset(maxScrollOffset);
54
+ }
55
+ }
56
+ });
57
+ // Mouse wheel support
58
+ useEffect(() => {
59
+ if (!stdin || typeof setRawMode !== 'function')
60
+ return;
61
+ // Enable mouse tracking (X11 mouse protocol)
62
+ process.stdout.write('\x1b[?1000h'); // Enable mouse button events
63
+ process.stdout.write('\x1b[?1003h'); // Enable all mouse events
64
+ process.stdout.write('\x1b[?1015h'); // Enable urxvt mouse mode
65
+ process.stdout.write('\x1b[?1006h'); // Enable SGR mouse mode
66
+ const handleData = (data) => {
67
+ const str = data.toString('utf8');
68
+ // Parse SGR mouse format: \x1b[<b;x;y;M or m
69
+ // Wheel up: button 64, Wheel down: button 65
70
+ const sgrMatch = str.match(/\x1b\[<(\d+);(\d+);(\d+)([Mm])/);
71
+ if (sgrMatch) {
72
+ const button = parseInt(sgrMatch[1], 10);
73
+ const action = sgrMatch[4];
74
+ if (action === 'M') { // Mouse button press
75
+ if (button === 64) {
76
+ // Scroll up (wheel up)
77
+ setScrollOffset(prev => Math.max(0, prev - 3));
78
+ }
79
+ else if (button === 65) {
80
+ // Scroll down (wheel down)
81
+ setScrollOffset(prev => Math.min(maxScrollOffset, prev + 3));
82
+ }
83
+ }
84
+ }
85
+ // Fallback: Parse X10 mouse format: \x1b[Mbxy
86
+ if (str.startsWith('\x1b[M') && str.length >= 6) {
87
+ const cb = str.charCodeAt(3) - 32;
88
+ // Wheel up: 64, Wheel down: 65
89
+ if (cb === 64) {
90
+ setScrollOffset(prev => Math.max(0, prev - 3));
91
+ }
92
+ else if (cb === 65) {
93
+ setScrollOffset(prev => Math.min(maxScrollOffset, prev + 3));
94
+ }
95
+ }
96
+ };
97
+ stdin.on('data', handleData);
98
+ return () => {
99
+ // Disable mouse tracking on cleanup
100
+ process.stdout.write('\x1b[?1000l');
101
+ process.stdout.write('\x1b[?1003l');
102
+ process.stdout.write('\x1b[?1015l');
103
+ process.stdout.write('\x1b[?1006l');
104
+ stdin.off('data', handleData);
105
+ };
106
+ }, [stdin, setRawMode, maxScrollOffset]);
107
+ // Calculate visible messages
108
+ const visibleMessages = useMemo(() => {
109
+ const start = scrollOffset;
110
+ const end = Math.min(totalMessages, scrollOffset + viewportHeight);
111
+ return limitedMessages.slice(start, end);
112
+ }, [limitedMessages, scrollOffset, viewportHeight, totalMessages]);
113
+ // Scrollbar indicator
114
+ const showScrollbar = totalMessages > viewportHeight;
115
+ const scrollbarPosition = maxScrollOffset > 0
116
+ ? Math.round((scrollOffset / maxScrollOffset) * (viewportHeight - 1))
117
+ : 0;
118
+ return (React.createElement(Box, { flexDirection: "row", width: "100%" },
119
+ React.createElement(Box, { flexDirection: "column", flexGrow: 1, marginY: 1 },
120
+ visibleMessages.map((msg) => (React.createElement(MessageDisplay, { key: msg.id, message: msg }))),
121
+ totalMessages > viewportHeight && !isScrolledToBottom && (React.createElement(Box, { marginTop: 1 },
122
+ React.createElement(Text, { dimColor: true },
123
+ "\u2193 ",
124
+ totalMessages - (scrollOffset + viewportHeight),
125
+ " more messages below (\u2193/PgDn/G)"))),
126
+ totalMessages > viewportHeight && scrollOffset > 0 && (React.createElement(Box, null,
127
+ React.createElement(Text, { dimColor: true },
128
+ "\u2191 ",
129
+ scrollOffset,
130
+ " messages above (\u2191/PgUp/g)")))),
131
+ showScrollbar && (React.createElement(Box, { flexDirection: "column", marginLeft: 1, width: 1 }, Array.from({ length: viewportHeight }).map((_, i) => (React.createElement(Text, { key: i, dimColor: true }, i === scrollbarPosition ? '█' : '│')))))));
132
+ };
133
+ //# sourceMappingURL=ScrollableMessageList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollableMessageList.js","sourceRoot":"","sources":["../../../src/ui/components/ScrollableMessageList.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ /**
3
+ * ScrollableScreen component that uses alternate screen buffer with scrolling enabled
4
+ * This prevents seeing duplicate renders while allowing scrollback within the current session
5
+ */
6
+ export declare const ScrollableScreen: React.FC<{
7
+ children: React.ReactNode;
8
+ }>;
9
+ //# sourceMappingURL=ScrollableScreen.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollableScreen.d.ts","sourceRoot":"","sources":["../../../src/ui/components/ScrollableScreen.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B;;;GAGG;AACH,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC;IAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAAE,CAkBpE,CAAC"}
@@ -0,0 +1,22 @@
1
+ import React from 'react';
2
+ import { Box } from 'ink';
3
+ /**
4
+ * ScrollableScreen component that uses alternate screen buffer with scrolling enabled
5
+ * This prevents seeing duplicate renders while allowing scrollback within the current session
6
+ */
7
+ export const ScrollableScreen = ({ children }) => {
8
+ React.useEffect(() => {
9
+ // Enter alternate screen buffer
10
+ process.stdout.write('\x1B[?1049h');
11
+ // Enable scrolling in the alternate buffer
12
+ process.stdout.write('\x1B[?7h'); // Enable line wrap
13
+ // Clear screen and home cursor
14
+ process.stdout.write('\x1B[2J\x1B[H');
15
+ return () => {
16
+ // Exit alternate screen buffer on unmount
17
+ process.stdout.write('\x1B[?1049l');
18
+ };
19
+ }, []);
20
+ return React.createElement(Box, { flexDirection: "column" }, children);
21
+ };
22
+ //# sourceMappingURL=ScrollableScreen.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollableScreen.js","sourceRoot":"","sources":["../../../src/ui/components/ScrollableScreen.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B;;;GAGG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAA4C,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;IACxF,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,gCAAgC;QAChC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAEpC,2CAA2C;QAC3C,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,mBAAmB;QAErD,+BAA+B;QAC/B,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;QAEtC,OAAO,GAAG,EAAE;YACV,0CAA0C;YAC1C,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QACtC,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,IAAE,QAAQ,CAAO,CAAC;AACtD,CAAC,CAAC"}
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ interface SelectPromptProps {
3
+ message: string;
4
+ choices: Array<{
5
+ label: string;
6
+ value: string;
7
+ }>;
8
+ onSelect: (value: string) => void;
9
+ }
10
+ export declare const SelectPrompt: React.FC<SelectPromptProps>;
11
+ export {};
12
+ //# sourceMappingURL=SelectPrompt.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectPrompt.d.ts","sourceRoot":"","sources":["../../../src/ui/components/SelectPrompt.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,iBAAiB;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,KAAK,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACjD,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACnC;AAED,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAgBpD,CAAC"}
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ import { Box, Text } from 'ink';
3
+ import SelectInput from 'ink-select-input';
4
+ export const SelectPrompt = ({ message, choices, onSelect }) => {
5
+ return (React.createElement(Box, { flexDirection: "column", borderStyle: "round", borderColor: "#00ccff", paddingX: 1 },
6
+ React.createElement(Text, { color: "#00ccff", bold: true }, message),
7
+ React.createElement(Box, { marginTop: 1 },
8
+ React.createElement(SelectInput, { items: choices, onSelect: (item) => onSelect(item.value) }))));
9
+ };
10
+ //# sourceMappingURL=SelectPrompt.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectPrompt.js","sourceRoot":"","sources":["../../../src/ui/components/SelectPrompt.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,WAAW,MAAM,kBAAkB,CAAC;AAQ3C,MAAM,CAAC,MAAM,YAAY,GAAgC,CAAC,EACxD,OAAO,EACP,OAAO,EACP,QAAQ,EACT,EAAE,EAAE;IACH,OAAO,CACL,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,WAAW,EAAC,OAAO,EAAC,WAAW,EAAC,SAAS,EAAC,QAAQ,EAAE,CAAC;QAC/E,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,EAAC,IAAI,UAAE,OAAO,CAAQ;QAC3C,oBAAC,GAAG,IAAC,SAAS,EAAE,CAAC;YACf,oBAAC,WAAW,IACV,KAAK,EAAE,OAAO,EACd,QAAQ,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,GACxC,CACE,CACF,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,14 @@
1
+ import React from 'react';
2
+ import { Message } from '../../types/index.js';
3
+ interface StaticMessageHistoryProps {
4
+ messages: Message[];
5
+ }
6
+ /**
7
+ * Renders completed messages using Ink's Static component.
8
+ * These messages are "frozen" and never re-render.
9
+ * This is the key to preventing UI duplication - once a message is rendered
10
+ * in Static, it's written to stdout and frozen forever.
11
+ */
12
+ export declare const StaticMessageHistory: React.FC<StaticMessageHistoryProps>;
13
+ export {};
14
+ //# sourceMappingURL=StaticMessageHistory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StaticMessageHistory.d.ts","sourceRoot":"","sources":["../../../src/ui/components/StaticMessageHistory.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAG/C,UAAU,yBAAyB;IACjC,QAAQ,EAAE,OAAO,EAAE,CAAC;CACrB;AAED;;;;;GAKG;AACH,eAAO,MAAM,oBAAoB,EAAE,KAAK,CAAC,EAAE,CAAC,yBAAyB,CAcnE,CAAC"}
@@ -0,0 +1,19 @@
1
+ import React from 'react';
2
+ import { Static } from 'ink';
3
+ import { MessageDisplay } from './MessageDisplay.js';
4
+ /**
5
+ * Renders completed messages using Ink's Static component.
6
+ * These messages are "frozen" and never re-render.
7
+ * This is the key to preventing UI duplication - once a message is rendered
8
+ * in Static, it's written to stdout and frozen forever.
9
+ */
10
+ export const StaticMessageHistory = React.memo(({ messages }) => {
11
+ // Static component ensures these items never re-render
12
+ // They are written to stdout once and frozen
13
+ return (React.createElement(Static, { items: messages }, (message) => (React.createElement(MessageDisplay, { key: message.id, message: message }))));
14
+ }, (prevProps, nextProps) => {
15
+ // Return true to SKIP re-render, false to re-render
16
+ // Only re-render when messages array actually changes (new messages added)
17
+ return prevProps.messages === nextProps.messages;
18
+ });
19
+ //# sourceMappingURL=StaticMessageHistory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StaticMessageHistory.js","sourceRoot":"","sources":["../../../src/ui/components/StaticMessageHistory.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAE7B,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAMrD;;;;;GAKG;AACH,MAAM,CAAC,MAAM,oBAAoB,GAAwC,KAAK,CAAC,IAAI,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;IACnG,uDAAuD;IACvD,6CAA6C;IAC7C,OAAO,CACL,oBAAC,MAAM,IAAC,KAAK,EAAE,QAAQ,IACpB,CAAC,OAAO,EAAE,EAAE,CAAC,CACZ,oBAAC,cAAc,IAAC,GAAG,EAAE,OAAO,CAAC,EAAE,EAAE,OAAO,EAAE,OAAO,GAAI,CACtD,CACM,CACV,CAAC;AACJ,CAAC,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,EAAE;IAC1B,oDAAoD;IACpD,2EAA2E;IAC3E,OAAO,SAAS,CAAC,QAAQ,KAAK,SAAS,CAAC,QAAQ,CAAC;AACnD,CAAC,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ interface StatusBarProps {
3
+ autoAcceptMode: boolean;
4
+ isLoading: boolean;
5
+ loadingMessage?: string;
6
+ model?: string;
7
+ }
8
+ export declare const StatusBar: React.FC<StatusBarProps>;
9
+ export {};
10
+ //# sourceMappingURL=StatusBar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StatusBar.d.ts","sourceRoot":"","sources":["../../../src/ui/components/StatusBar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,cAAc;IACtB,cAAc,EAAE,OAAO,CAAC;IACxB,SAAS,EAAE,OAAO,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAoC9C,CAAC"}
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+ import { Box, Text } from 'ink';
3
+ import Spinner from 'ink-spinner';
4
+ export const StatusBar = ({ autoAcceptMode, isLoading, loadingMessage = 'Processing...', model }) => {
5
+ return (React.createElement(Box, { borderStyle: "single", borderColor: "#003b59", paddingX: 1 },
6
+ React.createElement(Box, { flexGrow: 1 },
7
+ isLoading && (React.createElement(Box, { marginRight: 1 },
8
+ React.createElement(Text, { color: "#00ccff" },
9
+ React.createElement(Spinner, { type: "dots" })),
10
+ React.createElement(Text, { color: "#00ccff" },
11
+ " ",
12
+ loadingMessage))),
13
+ !isLoading && model && (React.createElement(Box, { marginRight: 1 },
14
+ React.createElement(Text, { color: "#666666" }, "Model: "),
15
+ React.createElement(Text, { color: "#00ccff" }, model)))),
16
+ React.createElement(Box, null,
17
+ autoAcceptMode && (React.createElement(Text, { color: "#00cc66", bold: true }, "[AUTO-ACCEPT: ON]")),
18
+ !autoAcceptMode && (React.createElement(Text, { color: "#666666", dimColor: true }, "[AUTO-ACCEPT: OFF]")))));
19
+ };
20
+ //# sourceMappingURL=StatusBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StatusBar.js","sourceRoot":"","sources":["../../../src/ui/components/StatusBar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,OAAO,MAAM,aAAa,CAAC;AASlC,MAAM,CAAC,MAAM,SAAS,GAA6B,CAAC,EAClD,cAAc,EACd,SAAS,EACT,cAAc,GAAG,eAAe,EAChC,KAAK,EACN,EAAE,EAAE;IACH,OAAO,CACL,oBAAC,GAAG,IAAC,WAAW,EAAC,QAAQ,EAAC,WAAW,EAAC,SAAS,EAAC,QAAQ,EAAE,CAAC;QACzD,oBAAC,GAAG,IAAC,QAAQ,EAAE,CAAC;YACb,SAAS,IAAI,CACZ,oBAAC,GAAG,IAAC,WAAW,EAAE,CAAC;gBACjB,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS;oBACnB,oBAAC,OAAO,IAAC,IAAI,EAAC,MAAM,GAAG,CAClB;gBACP,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS;;oBAAG,cAAc,CAAQ,CAC1C,CACP;YAEA,CAAC,SAAS,IAAI,KAAK,IAAI,CACtB,oBAAC,GAAG,IAAC,WAAW,EAAE,CAAC;gBACjB,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,cAAe;gBACpC,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,IAAE,KAAK,CAAQ,CAChC,CACP,CACG;QAEN,oBAAC,GAAG;YACD,cAAc,IAAI,CACjB,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,EAAC,IAAI,8BAAyB,CACpD;YACA,CAAC,cAAc,IAAI,CAClB,oBAAC,IAAI,IAAC,KAAK,EAAC,SAAS,EAAC,QAAQ,+BAA0B,CACzD,CACG,CACF,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ interface StreamingMessage {
3
+ id: string;
4
+ role: 'assistant';
5
+ content: string;
6
+ timestamp: Date;
7
+ }
8
+ interface StreamingMessageDisplayProps {
9
+ message: StreamingMessage;
10
+ }
11
+ export declare const StreamingMessageDisplay: React.FC<StreamingMessageDisplayProps>;
12
+ export {};
13
+ //# sourceMappingURL=StreamingMessageDisplay.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StreamingMessageDisplay.d.ts","sourceRoot":"","sources":["../../../src/ui/components/StreamingMessageDisplay.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,gBAAgB;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,WAAW,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;CACjB;AAED,UAAU,4BAA4B;IACpC,OAAO,EAAE,gBAAgB,CAAC;CAC3B;AAED,eAAO,MAAM,uBAAuB,EAAE,KAAK,CAAC,EAAE,CAAC,4BAA4B,CAkCzE,CAAC"}