@ranker/raxflow 0.2.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 (425) hide show
  1. package/dashboard/index.html +420 -0
  2. package/dist/benchmark.d.ts.map +1 -0
  3. package/dist/benchmark.js +123 -0
  4. package/dist/benchmark.js.map +1 -0
  5. package/dist/bin.d.ts.map +1 -0
  6. package/dist/bin.js +141 -0
  7. package/dist/bin.js.map +1 -0
  8. package/dist/bootstrap.d.ts.map +1 -0
  9. package/dist/bootstrap.js +22 -0
  10. package/dist/bootstrap.js.map +1 -0
  11. package/dist/bridge-adapter-templates.d.ts.map +1 -0
  12. package/dist/bridge-adapter-templates.js +185 -0
  13. package/dist/bridge-adapter-templates.js.map +1 -0
  14. package/dist/bridge-test.d.ts.map +1 -0
  15. package/dist/bridge-test.js +89 -0
  16. package/dist/bridge-test.js.map +1 -0
  17. package/dist/dashboard.d.ts.map +1 -0
  18. package/dist/dashboard.js +49 -0
  19. package/dist/dashboard.js.map +1 -0
  20. package/dist/doctor.d.ts.map +1 -0
  21. package/dist/doctor.js +70 -0
  22. package/dist/doctor.js.map +1 -0
  23. package/dist/evolve.d.ts.map +1 -0
  24. package/dist/evolve.js +48 -0
  25. package/dist/evolve.js.map +1 -0
  26. package/dist/host-init-templates.d.ts.map +1 -0
  27. package/dist/host-init-templates.js +119 -0
  28. package/dist/host-init-templates.js.map +1 -0
  29. package/dist/hub/__tests__/commands.test.d.ts.map +1 -0
  30. package/dist/hub/__tests__/commands.test.js +72 -0
  31. package/dist/hub/__tests__/commands.test.js.map +1 -0
  32. package/dist/hub/__tests__/history.test.d.ts.map +1 -0
  33. package/dist/hub/__tests__/history.test.js +119 -0
  34. package/dist/hub/__tests__/history.test.js.map +1 -0
  35. package/dist/hub/__tests__/parser.test.d.ts.map +1 -0
  36. package/dist/hub/__tests__/parser.test.js +92 -0
  37. package/dist/hub/__tests__/parser.test.js.map +1 -0
  38. package/dist/hub/chat/ChatApp.d.ts +2 -0
  39. package/dist/hub/chat/ChatApp.d.ts.map +1 -0
  40. package/dist/hub/chat/ChatApp.js +146 -0
  41. package/dist/hub/chat/ChatApp.js.map +1 -0
  42. package/dist/hub/chat/components/ChatInput.d.ts +9 -0
  43. package/dist/hub/chat/components/ChatInput.d.ts.map +1 -0
  44. package/dist/hub/chat/components/ChatInput.js +19 -0
  45. package/dist/hub/chat/components/ChatInput.js.map +1 -0
  46. package/dist/hub/chat/components/MessageList.d.ts +7 -0
  47. package/dist/hub/chat/components/MessageList.d.ts.map +1 -0
  48. package/dist/hub/chat/components/MessageList.js +6 -0
  49. package/dist/hub/chat/components/MessageList.js.map +1 -0
  50. package/dist/hub/chat/context.d.ts.map +1 -0
  51. package/dist/hub/chat/context.js +42 -0
  52. package/dist/hub/chat/context.js.map +1 -0
  53. package/dist/hub/chat/hooks/useChatHistory.d.ts +7 -0
  54. package/dist/hub/chat/hooks/useChatHistory.d.ts.map +1 -0
  55. package/dist/hub/chat/hooks/useChatHistory.js +31 -0
  56. package/dist/hub/chat/hooks/useChatHistory.js.map +1 -0
  57. package/dist/hub/chat/index.d.ts.map +1 -0
  58. package/dist/hub/chat/index.js +7 -0
  59. package/dist/hub/chat/index.js.map +1 -0
  60. package/dist/hub/chat/intent-parser.d.ts.map +1 -0
  61. package/dist/hub/chat/intent-parser.js +48 -0
  62. package/dist/hub/chat/intent-parser.js.map +1 -0
  63. package/dist/hub/chat/types.d.ts.map +1 -0
  64. package/dist/hub/chat/types.js +2 -0
  65. package/dist/hub/chat/types.js.map +1 -0
  66. package/dist/hub/commands/agents.d.ts.map +1 -0
  67. package/dist/hub/commands/agents.js +36 -0
  68. package/dist/hub/commands/agents.js.map +1 -0
  69. package/dist/hub/commands/index.d.ts.map +1 -0
  70. package/dist/hub/commands/index.js +123 -0
  71. package/dist/hub/commands/index.js.map +1 -0
  72. package/dist/hub/commands/logs.d.ts.map +1 -0
  73. package/dist/hub/commands/logs.js +53 -0
  74. package/dist/hub/commands/logs.js.map +1 -0
  75. package/dist/hub/commands/memory.d.ts.map +1 -0
  76. package/dist/hub/commands/memory.js +40 -0
  77. package/dist/hub/commands/memory.js.map +1 -0
  78. package/dist/hub/commands/metrics.d.ts.map +1 -0
  79. package/dist/hub/commands/metrics.js +35 -0
  80. package/dist/hub/commands/metrics.js.map +1 -0
  81. package/dist/hub/commands/providers.d.ts.map +1 -0
  82. package/dist/hub/commands/providers.js +26 -0
  83. package/dist/hub/commands/providers.js.map +1 -0
  84. package/dist/hub/commands/run.d.ts.map +1 -0
  85. package/dist/hub/commands/run.js +31 -0
  86. package/dist/hub/commands/run.js.map +1 -0
  87. package/dist/hub/commands/status.d.ts.map +1 -0
  88. package/dist/hub/commands/status.js +61 -0
  89. package/dist/hub/commands/status.js.map +1 -0
  90. package/dist/hub/commands/workflows.d.ts.map +1 -0
  91. package/dist/hub/commands/workflows.js +45 -0
  92. package/dist/hub/commands/workflows.js.map +1 -0
  93. package/dist/hub/config-loader.d.ts.map +1 -0
  94. package/dist/hub/config-loader.js +27 -0
  95. package/dist/hub/config-loader.js.map +1 -0
  96. package/dist/hub/event-listener.d.ts +6 -0
  97. package/dist/hub/event-listener.d.ts.map +1 -0
  98. package/dist/hub/event-listener.js +12 -0
  99. package/dist/hub/event-listener.js.map +1 -0
  100. package/dist/hub/history.d.ts.map +1 -0
  101. package/dist/hub/history.js +59 -0
  102. package/dist/hub/history.js.map +1 -0
  103. package/dist/hub/index.d.ts.map +1 -0
  104. package/dist/hub/index.js +114 -0
  105. package/dist/hub/index.js.map +1 -0
  106. package/dist/hub/parser.d.ts.map +1 -0
  107. package/dist/hub/parser.js +98 -0
  108. package/dist/hub/parser.js.map +1 -0
  109. package/dist/hub/styles/borders.d.ts.map +1 -0
  110. package/dist/hub/styles/borders.js +64 -0
  111. package/dist/hub/styles/borders.js.map +1 -0
  112. package/dist/hub/styles/colors.d.ts.map +1 -0
  113. package/dist/hub/styles/colors.js +115 -0
  114. package/dist/hub/styles/colors.js.map +1 -0
  115. package/dist/hub/styles/typography.d.ts.map +1 -0
  116. package/dist/hub/styles/typography.js +60 -0
  117. package/dist/hub/styles/typography.js.map +1 -0
  118. package/dist/hub/tui/App.d.ts +2 -0
  119. package/dist/hub/tui/App.d.ts.map +1 -0
  120. package/dist/hub/tui/App.js +53 -0
  121. package/dist/hub/tui/App.js.map +1 -0
  122. package/dist/hub/tui/components/AgentQueue.d.ts +6 -0
  123. package/dist/hub/tui/components/AgentQueue.d.ts.map +1 -0
  124. package/dist/hub/tui/components/AgentQueue.js +20 -0
  125. package/dist/hub/tui/components/AgentQueue.js.map +1 -0
  126. package/dist/hub/tui/components/DAGPanel.d.ts +16 -0
  127. package/dist/hub/tui/components/DAGPanel.d.ts.map +1 -0
  128. package/dist/hub/tui/components/DAGPanel.js +51 -0
  129. package/dist/hub/tui/components/DAGPanel.js.map +1 -0
  130. package/dist/hub/tui/components/Header.d.ts +7 -0
  131. package/dist/hub/tui/components/Header.d.ts.map +1 -0
  132. package/dist/hub/tui/components/Header.js +17 -0
  133. package/dist/hub/tui/components/Header.js.map +1 -0
  134. package/dist/hub/tui/components/LogsPanel.d.ts +6 -0
  135. package/dist/hub/tui/components/LogsPanel.d.ts.map +1 -0
  136. package/dist/hub/tui/components/LogsPanel.js +26 -0
  137. package/dist/hub/tui/components/LogsPanel.js.map +1 -0
  138. package/dist/hub/tui/components/StatusBar.d.ts +8 -0
  139. package/dist/hub/tui/components/StatusBar.d.ts.map +1 -0
  140. package/dist/hub/tui/components/StatusBar.js +7 -0
  141. package/dist/hub/tui/components/StatusBar.js.map +1 -0
  142. package/dist/hub/tui/hooks/useEvents.d.ts +2 -0
  143. package/dist/hub/tui/hooks/useEvents.d.ts.map +1 -0
  144. package/dist/hub/tui/hooks/useEvents.js +13 -0
  145. package/dist/hub/tui/hooks/useEvents.js.map +1 -0
  146. package/dist/hub/tui/index.d.ts.map +1 -0
  147. package/dist/hub/tui/index.js +7 -0
  148. package/dist/hub/tui/index.js.map +1 -0
  149. package/dist/hub/tui/types.d.ts.map +1 -0
  150. package/dist/hub/tui/types.js +2 -0
  151. package/dist/hub/tui/types.js.map +1 -0
  152. package/dist/hub/types.d.ts.map +1 -0
  153. package/dist/hub/types.js +2 -0
  154. package/dist/hub/types.js.map +1 -0
  155. package/dist/index.d.ts.map +1 -0
  156. package/dist/index.js +11 -0
  157. package/dist/index.js.map +1 -0
  158. package/dist/init-host.d.ts.map +1 -0
  159. package/dist/init-host.js +232 -0
  160. package/dist/init-host.js.map +1 -0
  161. package/dist/install.d.ts.map +1 -0
  162. package/dist/install.js +99 -0
  163. package/dist/install.js.map +1 -0
  164. package/dist/run.d.ts.map +1 -0
  165. package/dist/run.js +238 -0
  166. package/dist/run.js.map +1 -0
  167. package/dist/setup/components/ApiKeyInput.d.ts +25 -0
  168. package/dist/setup/components/ApiKeyInput.d.ts.map +1 -0
  169. package/dist/setup/components/ApiKeyInput.js +54 -0
  170. package/dist/setup/components/ApiKeyInput.js.map +1 -0
  171. package/dist/setup/components/AsciiBanner.d.ts +22 -0
  172. package/dist/setup/components/AsciiBanner.d.ts.map +1 -0
  173. package/dist/setup/components/AsciiBanner.js +55 -0
  174. package/dist/setup/components/AsciiBanner.js.map +1 -0
  175. package/dist/setup/components/CliDetector.d.ts +17 -0
  176. package/dist/setup/components/CliDetector.d.ts.map +1 -0
  177. package/dist/setup/components/CliDetector.js +79 -0
  178. package/dist/setup/components/CliDetector.js.map +1 -0
  179. package/dist/setup/components/ModeSelector.d.ts +8 -0
  180. package/dist/setup/components/ModeSelector.d.ts.map +1 -0
  181. package/dist/setup/components/ModeSelector.js +76 -0
  182. package/dist/setup/components/ModeSelector.js.map +1 -0
  183. package/dist/setup/components/ProviderSelector.d.ts +18 -0
  184. package/dist/setup/components/ProviderSelector.d.ts.map +1 -0
  185. package/dist/setup/components/ProviderSelector.js +97 -0
  186. package/dist/setup/components/ProviderSelector.js.map +1 -0
  187. package/dist/setup/components/SetupWizard.d.ts +2 -0
  188. package/dist/setup/components/SetupWizard.d.ts.map +1 -0
  189. package/dist/setup/components/SetupWizard.js +212 -0
  190. package/dist/setup/components/SetupWizard.js.map +1 -0
  191. package/dist/setup/components/StepIndicator.d.ts +13 -0
  192. package/dist/setup/components/StepIndicator.d.ts.map +1 -0
  193. package/dist/setup/components/StepIndicator.js +18 -0
  194. package/dist/setup/components/StepIndicator.js.map +1 -0
  195. package/dist/setup/components/SuccessScreen.d.ts +18 -0
  196. package/dist/setup/components/SuccessScreen.d.ts.map +1 -0
  197. package/dist/setup/components/SuccessScreen.js +38 -0
  198. package/dist/setup/components/SuccessScreen.js.map +1 -0
  199. package/dist/setup/index.d.ts +12 -0
  200. package/dist/setup/index.d.ts.map +1 -0
  201. package/dist/setup/index.js +29 -0
  202. package/dist/setup/index.js.map +1 -0
  203. package/dist/setup/utils/cli-detection.d.ts +12 -0
  204. package/dist/setup/utils/cli-detection.d.ts.map +1 -0
  205. package/dist/setup/utils/cli-detection.js +83 -0
  206. package/dist/setup/utils/cli-detection.js.map +1 -0
  207. package/dist/setup/utils/config-writer.d.ts +43 -0
  208. package/dist/setup/utils/config-writer.d.ts.map +1 -0
  209. package/dist/setup/utils/config-writer.js +180 -0
  210. package/dist/setup/utils/config-writer.js.map +1 -0
  211. package/dist/styles.d.ts.map +1 -0
  212. package/dist/styles.js +12 -0
  213. package/dist/styles.js.map +1 -0
  214. package/dist/tui/App.d.ts +3 -0
  215. package/dist/tui/App.d.ts.map +1 -0
  216. package/dist/tui/App.js +131 -0
  217. package/dist/tui/App.js.map +1 -0
  218. package/dist/tui/components/AgentStateIcon.d.ts +18 -0
  219. package/dist/tui/components/AgentStateIcon.d.ts.map +1 -0
  220. package/dist/tui/components/AgentStateIcon.js +57 -0
  221. package/dist/tui/components/AgentStateIcon.js.map +1 -0
  222. package/dist/tui/components/AnimatedBranch.d.ts +39 -0
  223. package/dist/tui/components/AnimatedBranch.d.ts.map +1 -0
  224. package/dist/tui/components/AnimatedBranch.js +64 -0
  225. package/dist/tui/components/AnimatedBranch.js.map +1 -0
  226. package/dist/tui/components/ChatPanel.d.ts +16 -0
  227. package/dist/tui/components/ChatPanel.d.ts.map +1 -0
  228. package/dist/tui/components/ChatPanel.js +50 -0
  229. package/dist/tui/components/ChatPanel.js.map +1 -0
  230. package/dist/tui/components/DAGPanel.d.ts +36 -0
  231. package/dist/tui/components/DAGPanel.d.ts.map +1 -0
  232. package/dist/tui/components/DAGPanel.js +51 -0
  233. package/dist/tui/components/DAGPanel.js.map +1 -0
  234. package/dist/tui/components/ExecutionTimeline.d.ts +34 -0
  235. package/dist/tui/components/ExecutionTimeline.d.ts.map +1 -0
  236. package/dist/tui/components/ExecutionTimeline.js +67 -0
  237. package/dist/tui/components/ExecutionTimeline.js.map +1 -0
  238. package/dist/tui/components/Header.d.ts +12 -0
  239. package/dist/tui/components/Header.d.ts.map +1 -0
  240. package/dist/tui/components/Header.js +32 -0
  241. package/dist/tui/components/Header.js.map +1 -0
  242. package/dist/tui/components/HelpOverlay.d.ts +7 -0
  243. package/dist/tui/components/HelpOverlay.d.ts.map +1 -0
  244. package/dist/tui/components/HelpOverlay.js +60 -0
  245. package/dist/tui/components/HelpOverlay.js.map +1 -0
  246. package/dist/tui/components/InputBar.d.ts +10 -0
  247. package/dist/tui/components/InputBar.d.ts.map +1 -0
  248. package/dist/tui/components/InputBar.js +21 -0
  249. package/dist/tui/components/InputBar.js.map +1 -0
  250. package/dist/tui/components/LogsPanel.d.ts +9 -0
  251. package/dist/tui/components/LogsPanel.d.ts.map +1 -0
  252. package/dist/tui/components/LogsPanel.js +56 -0
  253. package/dist/tui/components/LogsPanel.js.map +1 -0
  254. package/dist/tui/components/MemoryPanel.d.ts +21 -0
  255. package/dist/tui/components/MemoryPanel.d.ts.map +1 -0
  256. package/dist/tui/components/MemoryPanel.js +51 -0
  257. package/dist/tui/components/MemoryPanel.js.map +1 -0
  258. package/dist/tui/components/MetricsPanel.d.ts +18 -0
  259. package/dist/tui/components/MetricsPanel.d.ts.map +1 -0
  260. package/dist/tui/components/MetricsPanel.js +27 -0
  261. package/dist/tui/components/MetricsPanel.js.map +1 -0
  262. package/dist/tui/components/StatusPanel.d.ts +23 -0
  263. package/dist/tui/components/StatusPanel.d.ts.map +1 -0
  264. package/dist/tui/components/StatusPanel.js +23 -0
  265. package/dist/tui/components/StatusPanel.js.map +1 -0
  266. package/dist/tui/components/TaskTree.d.ts +28 -0
  267. package/dist/tui/components/TaskTree.d.ts.map +1 -0
  268. package/dist/tui/components/TaskTree.js +29 -0
  269. package/dist/tui/components/TaskTree.js.map +1 -0
  270. package/dist/tui/components/animations/ProgressBar.d.ts +39 -0
  271. package/dist/tui/components/animations/ProgressBar.d.ts.map +1 -0
  272. package/dist/tui/components/animations/ProgressBar.js +39 -0
  273. package/dist/tui/components/animations/ProgressBar.js.map +1 -0
  274. package/dist/tui/components/animations/Pulse.d.ts +17 -0
  275. package/dist/tui/components/animations/Pulse.d.ts.map +1 -0
  276. package/dist/tui/components/animations/Pulse.js +47 -0
  277. package/dist/tui/components/animations/Pulse.js.map +1 -0
  278. package/dist/tui/components/animations/Spinner.d.ts +13 -0
  279. package/dist/tui/components/animations/Spinner.d.ts.map +1 -0
  280. package/dist/tui/components/animations/Spinner.js +36 -0
  281. package/dist/tui/components/animations/Spinner.js.map +1 -0
  282. package/dist/tui/components/animations/StatusAnimator.d.ts +27 -0
  283. package/dist/tui/components/animations/StatusAnimator.d.ts.map +1 -0
  284. package/dist/tui/components/animations/StatusAnimator.js +85 -0
  285. package/dist/tui/components/animations/StatusAnimator.js.map +1 -0
  286. package/dist/tui/components/animations/TypingEffect.d.ts +26 -0
  287. package/dist/tui/components/animations/TypingEffect.d.ts.map +1 -0
  288. package/dist/tui/components/animations/TypingEffect.js +59 -0
  289. package/dist/tui/components/animations/TypingEffect.js.map +1 -0
  290. package/dist/tui/components/animations/index.d.ts +8 -0
  291. package/dist/tui/components/animations/index.d.ts.map +1 -0
  292. package/dist/tui/components/animations/index.js +6 -0
  293. package/dist/tui/components/animations/index.js.map +1 -0
  294. package/dist/tui/hooks/useAnimation.d.ts +42 -0
  295. package/dist/tui/hooks/useAnimation.d.ts.map +1 -0
  296. package/dist/tui/hooks/useAnimation.js +212 -0
  297. package/dist/tui/hooks/useAnimation.js.map +1 -0
  298. package/dist/tui/hooks/useAppState.d.ts +65 -0
  299. package/dist/tui/hooks/useAppState.d.ts.map +1 -0
  300. package/dist/tui/hooks/useAppState.js +293 -0
  301. package/dist/tui/hooks/useAppState.js.map +1 -0
  302. package/dist/tui/index.d.ts +3 -0
  303. package/dist/tui/index.d.ts.map +1 -0
  304. package/dist/tui/index.js +8 -0
  305. package/dist/tui/index.js.map +1 -0
  306. package/dist/tui/services/orchestrator.d.ts +16 -0
  307. package/dist/tui/services/orchestrator.d.ts.map +1 -0
  308. package/dist/tui/services/orchestrator.js +152 -0
  309. package/dist/tui/services/orchestrator.js.map +1 -0
  310. package/dist/tui/styles/borders.d.ts +31 -0
  311. package/dist/tui/styles/borders.d.ts.map +1 -0
  312. package/dist/tui/styles/borders.js +47 -0
  313. package/dist/tui/styles/borders.js.map +1 -0
  314. package/dist/tui/styles/colors.d.ts +18 -0
  315. package/dist/tui/styles/colors.d.ts.map +1 -0
  316. package/dist/tui/styles/colors.js +18 -0
  317. package/dist/tui/styles/colors.js.map +1 -0
  318. package/dist/tui/styles/index.d.ts +6 -0
  319. package/dist/tui/styles/index.d.ts.map +1 -0
  320. package/dist/tui/styles/index.js +6 -0
  321. package/dist/tui/styles/index.js.map +1 -0
  322. package/dist/tui/styles/indicators.d.ts +67 -0
  323. package/dist/tui/styles/indicators.d.ts.map +1 -0
  324. package/dist/tui/styles/indicators.js +42 -0
  325. package/dist/tui/styles/indicators.js.map +1 -0
  326. package/dist/tui/styles/layout.d.ts +21 -0
  327. package/dist/tui/styles/layout.d.ts.map +1 -0
  328. package/dist/tui/styles/layout.js +42 -0
  329. package/dist/tui/styles/layout.js.map +1 -0
  330. package/dist/tui/styles/providers.d.ts +77 -0
  331. package/dist/tui/styles/providers.d.ts.map +1 -0
  332. package/dist/tui/styles/providers.js +31 -0
  333. package/dist/tui/styles/providers.js.map +1 -0
  334. package/dist/tui/utils/animation.d.ts +44 -0
  335. package/dist/tui/utils/animation.d.ts.map +1 -0
  336. package/dist/tui/utils/animation.js +107 -0
  337. package/dist/tui/utils/animation.js.map +1 -0
  338. package/dist/vendor-manifests.d.ts.map +1 -0
  339. package/dist/vendor-manifests.js +94 -0
  340. package/dist/vendor-manifests.js.map +1 -0
  341. package/dist/ws-relay.d.ts +12 -0
  342. package/dist/ws-relay.d.ts.map +1 -0
  343. package/dist/ws-relay.js +148 -0
  344. package/dist/ws-relay.js.map +1 -0
  345. package/package.json +34 -0
  346. package/src/benchmark.ts +156 -0
  347. package/src/bin.ts +156 -0
  348. package/src/bootstrap.ts +36 -0
  349. package/src/bridge-adapter-templates.ts +181 -0
  350. package/src/bridge-test.ts +107 -0
  351. package/src/dashboard.ts +51 -0
  352. package/src/doctor.ts +92 -0
  353. package/src/evolve.ts +74 -0
  354. package/src/host-init-templates.ts +134 -0
  355. package/src/hub/__tests__/commands.test.ts +84 -0
  356. package/src/hub/__tests__/history.test.ts +137 -0
  357. package/src/hub/__tests__/parser.test.ts +105 -0
  358. package/src/hub/commands/agents.ts +53 -0
  359. package/src/hub/commands/index.ts +140 -0
  360. package/src/hub/commands/logs.ts +70 -0
  361. package/src/hub/commands/memory.ts +47 -0
  362. package/src/hub/commands/metrics.ts +49 -0
  363. package/src/hub/commands/providers.ts +39 -0
  364. package/src/hub/commands/run.ts +37 -0
  365. package/src/hub/commands/status.ts +69 -0
  366. package/src/hub/commands/workflows.ts +64 -0
  367. package/src/hub/config-loader.ts +37 -0
  368. package/src/hub/event-listener.ts +17 -0
  369. package/src/hub/history.ts +66 -0
  370. package/src/hub/index.ts +132 -0
  371. package/src/hub/parser.ts +107 -0
  372. package/src/hub/styles/borders.ts +74 -0
  373. package/src/hub/styles/colors.ts +129 -0
  374. package/src/hub/styles/typography.ts +68 -0
  375. package/src/hub/types.ts +31 -0
  376. package/src/index.ts +10 -0
  377. package/src/init-host.ts +285 -0
  378. package/src/install.ts +118 -0
  379. package/src/run.ts +317 -0
  380. package/src/setup/components/ApiKeyInput.tsx +158 -0
  381. package/src/setup/components/AsciiBanner.tsx +125 -0
  382. package/src/setup/components/CliDetector.tsx +230 -0
  383. package/src/setup/components/ModeSelector.tsx +137 -0
  384. package/src/setup/components/ProviderSelector.tsx +174 -0
  385. package/src/setup/components/SetupWizard.tsx +368 -0
  386. package/src/setup/components/StepIndicator.tsx +74 -0
  387. package/src/setup/components/SuccessScreen.tsx +229 -0
  388. package/src/setup/index.ts +34 -0
  389. package/src/setup/utils/cli-detection.ts +99 -0
  390. package/src/setup/utils/config-writer.ts +249 -0
  391. package/src/styles.ts +12 -0
  392. package/src/tui/App.tsx +177 -0
  393. package/src/tui/components/AgentStateIcon.tsx +84 -0
  394. package/src/tui/components/AnimatedBranch.tsx +134 -0
  395. package/src/tui/components/ChatPanel.tsx +125 -0
  396. package/src/tui/components/DAGPanel.tsx +208 -0
  397. package/src/tui/components/ExecutionTimeline.tsx +225 -0
  398. package/src/tui/components/Header.tsx +109 -0
  399. package/src/tui/components/HelpOverlay.tsx +140 -0
  400. package/src/tui/components/InputBar.tsx +69 -0
  401. package/src/tui/components/LogsPanel.tsx +129 -0
  402. package/src/tui/components/MemoryPanel.tsx +163 -0
  403. package/src/tui/components/MetricsPanel.tsx +149 -0
  404. package/src/tui/components/StatusPanel.tsx +137 -0
  405. package/src/tui/components/TaskTree.tsx +159 -0
  406. package/src/tui/components/animations/ProgressBar.tsx +160 -0
  407. package/src/tui/components/animations/Pulse.tsx +73 -0
  408. package/src/tui/components/animations/Spinner.tsx +54 -0
  409. package/src/tui/components/animations/StatusAnimator.tsx +153 -0
  410. package/src/tui/components/animations/TypingEffect.tsx +119 -0
  411. package/src/tui/components/animations/index.ts +16 -0
  412. package/src/tui/hooks/useAnimation.ts +290 -0
  413. package/src/tui/hooks/useAppState.ts +403 -0
  414. package/src/tui/index.ts +9 -0
  415. package/src/tui/services/orchestrator.ts +195 -0
  416. package/src/tui/styles/borders.ts +51 -0
  417. package/src/tui/styles/colors.ts +19 -0
  418. package/src/tui/styles/index.ts +20 -0
  419. package/src/tui/styles/indicators.ts +54 -0
  420. package/src/tui/styles/layout.ts +44 -0
  421. package/src/tui/styles/providers.ts +32 -0
  422. package/src/tui/utils/animation.ts +124 -0
  423. package/src/vendor-manifests.ts +113 -0
  424. package/src/ws-relay.ts +156 -0
  425. package/tsconfig.json +28 -0
@@ -0,0 +1,230 @@
1
+ import React, { useState, useEffect } from "react";
2
+ import { Box, Text, useInput } from "ink";
3
+ import Spinner from "ink-spinner";
4
+ import { detectInstalledClis, DetectedCli } from "../utils/cli-detection.js";
5
+
6
+ export type { DetectedCli };
7
+
8
+ interface CliDetectorProps {
9
+ onDetected: (clis: DetectedCli[]) => void;
10
+ onContinue: () => void;
11
+ onBack: () => void;
12
+ }
13
+
14
+ export function CliDetector({ onDetected, onContinue, onBack }: CliDetectorProps) {
15
+ const [detecting, setDetecting] = useState(true);
16
+ const [detectedClis, setDetectedClis] = useState<DetectedCli[]>([]);
17
+ const [error, setError] = useState<string | null>(null);
18
+ const PRIMARY = "#f97316";
19
+
20
+ useEffect(() => {
21
+ detectInstalledClis()
22
+ .then((clis) => {
23
+ setDetectedClis(clis);
24
+ onDetected(clis);
25
+ setDetecting(false);
26
+ })
27
+ .catch((err) => {
28
+ setError(err.message);
29
+ setDetecting(false);
30
+ });
31
+ }, [onDetected]);
32
+
33
+ useInput((input, key) => {
34
+ if (!detecting) {
35
+ if (key.return || input === "c") {
36
+ onContinue();
37
+ } else if (input === "b") {
38
+ onBack();
39
+ }
40
+ }
41
+ });
42
+
43
+ if (detecting) {
44
+ return (
45
+ <Box flexDirection="column">
46
+ <Box marginBottom={1}>
47
+ <Text color={PRIMARY} bold>
48
+ DETECTING INSTALLED TOOLS
49
+ </Text>
50
+ </Box>
51
+ <Box>
52
+ <Text color="#f59e0b">
53
+ <Spinner type="dots" />
54
+ </Text>
55
+ <Text color="#a1a1aa"> Scanning for compatible CLI tools...</Text>
56
+ </Box>
57
+ </Box>
58
+ );
59
+ }
60
+
61
+ if (error) {
62
+ return (
63
+ <Box flexDirection="column">
64
+ <Text color="#ef4444">Error detecting CLIs: {error}</Text>
65
+ <Box marginTop={1}>
66
+ <Text color="#71717a">[B] Back</Text>
67
+ </Box>
68
+ </Box>
69
+ );
70
+ }
71
+
72
+ const availableClis = detectedClis.filter((c) => c.detected);
73
+
74
+ return (
75
+ <Box flexDirection="column">
76
+ <Box marginBottom={1}>
77
+ <Text color={PRIMARY} bold>
78
+ DETECTED TOOLS
79
+ </Text>
80
+ </Box>
81
+
82
+ <Box flexDirection="column" marginBottom={1}>
83
+ {detectedClis.map((cli) => (
84
+ <Box key={cli.id}>
85
+ <Text color={cli.detected ? "#22c55e" : "#71717a"}>
86
+ {cli.detected ? "●" : "○"}
87
+ </Text>
88
+ <Text> </Text>
89
+ <Text color={cli.detected ? "#ffffff" : "#71717a"}>
90
+ {cli.name}
91
+ </Text>
92
+ {cli.version && (
93
+ <Text color="#a1a1aa"> v{cli.version.split(" ")[0]}</Text>
94
+ )}
95
+ {cli.configPath && (
96
+ <Text color="#71717a" dimColor>
97
+ {" "}
98
+ ({cli.configPath})
99
+ </Text>
100
+ )}
101
+ </Box>
102
+ ))}
103
+ </Box>
104
+
105
+ {availableClis.length === 0 && (
106
+ <Box marginBottom={1}>
107
+ <Text color="#f59e0b">
108
+ ⚠ No compatible CLI tools detected. You can still use cloud providers.
109
+ </Text>
110
+ </Box>
111
+ )}
112
+
113
+ <Box>
114
+ <Text color="#27272a">{"─".repeat(50)}</Text>
115
+ </Box>
116
+
117
+ <Box marginTop={1}>
118
+ <Text color="#22c55e">[C] Continue</Text>
119
+ <Text color="#71717a"> [B] Back</Text>
120
+ </Box>
121
+ </Box>
122
+ );
123
+ }
124
+
125
+ interface CliSelectorProps {
126
+ detectedClis: DetectedCli[];
127
+ selectedClis: string[];
128
+ onToggle: (cliId: string) => void;
129
+ onContinue: () => void;
130
+ onBack: () => void;
131
+ }
132
+
133
+ export function CliSelector({
134
+ detectedClis,
135
+ selectedClis,
136
+ onToggle,
137
+ onContinue,
138
+ onBack,
139
+ }: CliSelectorProps) {
140
+ const [focusedIndex, setFocusedIndex] = useState(0);
141
+ const availableClis = detectedClis.filter((c) => c.detected);
142
+ const PRIMARY = "#f97316";
143
+
144
+ useInput((input, key) => {
145
+ if (key.upArrow) {
146
+ setFocusedIndex((prev) =>
147
+ prev === 0 ? availableClis.length : prev - 1
148
+ );
149
+ } else if (key.downArrow) {
150
+ setFocusedIndex((prev) =>
151
+ prev === availableClis.length ? 0 : prev + 1
152
+ );
153
+ } else if (key.return) {
154
+ if (focusedIndex === availableClis.length) {
155
+ onContinue();
156
+ } else {
157
+ onToggle(availableClis[focusedIndex].id);
158
+ }
159
+ } else if (input === " ") {
160
+ if (focusedIndex < availableClis.length) {
161
+ onToggle(availableClis[focusedIndex].id);
162
+ }
163
+ } else if (input === "b") {
164
+ onBack();
165
+ }
166
+ });
167
+
168
+ if (availableClis.length === 0) {
169
+ return (
170
+ <Box flexDirection="column">
171
+ <Text color="#f59e0b">No CLI tools detected. Skipping hub setup...</Text>
172
+ <Box marginTop={1}>
173
+ <Text color="#22c55e">[C] Continue</Text>
174
+ </Box>
175
+ </Box>
176
+ );
177
+ }
178
+
179
+ return (
180
+ <Box flexDirection="column">
181
+ <Box marginBottom={1}>
182
+ <Text color={PRIMARY} bold>
183
+ SELECT TOOLS TO INTEGRATE
184
+ </Text>
185
+ </Box>
186
+
187
+ <Box marginBottom={1}>
188
+ <Text color="#a1a1aa" dimColor>
189
+ Use ↑/↓ to navigate, SPACE to toggle, ENTER to continue
190
+ </Text>
191
+ </Box>
192
+
193
+ <Box flexDirection="column">
194
+ {availableClis.map((cli, index) => {
195
+ const isSelected = selectedClis.includes(cli.id);
196
+ const isFocused = index === focusedIndex;
197
+
198
+ return (
199
+ <Box key={cli.id}>
200
+ <Text color={isFocused ? PRIMARY : "#27272a"}>
201
+ {isFocused ? "▶ " : " "}
202
+ </Text>
203
+ <Text color={isSelected ? "#22c55e" : "#a1a1aa"}>
204
+ [{isSelected ? "■" : " "}]
205
+ </Text>
206
+ <Text> </Text>
207
+ <Text color={isFocused ? "#ffffff" : "#a1a1aa"} bold={isFocused}>
208
+ {cli.name}
209
+ </Text>
210
+ {cli.version && (
211
+ <Text color="#71717a"> {cli.version.split(" ")[0]}</Text>
212
+ )}
213
+ </Box>
214
+ );
215
+ })}
216
+ </Box>
217
+
218
+ <Box marginTop={1}>
219
+ <Text color={focusedIndex === availableClis.length ? PRIMARY : "#a1a1aa"}>
220
+ {focusedIndex === availableClis.length ? "▶ " : " "}
221
+ </Text>
222
+ <Text color="#22c55e">[CONTINUE]</Text>
223
+ </Box>
224
+
225
+ <Box marginTop={1}>
226
+ <Text color="#71717a">[B] Back</Text>
227
+ </Box>
228
+ </Box>
229
+ );
230
+ }
@@ -0,0 +1,137 @@
1
+ import React, { useState, useEffect } from "react";
2
+ import { Box, Text, useInput } from "ink";
3
+
4
+ interface ModeSelectorProps {
5
+ selectedMode: "hub" | "standalone" | "both" | null;
6
+ onSelect: (mode: "hub" | "standalone" | "both") => void;
7
+ onContinue: () => void;
8
+ }
9
+
10
+ const MODES = [
11
+ {
12
+ id: "hub" as const,
13
+ key: "1",
14
+ name: "HUB MODE",
15
+ description: "Use raxflow within your existing CLI",
16
+ features: [
17
+ "Integrates with claude-code, codex, opencode, kilo",
18
+ "Orchestrates agents inside your preferred tool",
19
+ "Minimal setup, maximum compatibility",
20
+ ],
21
+ },
22
+ {
23
+ id: "standalone" as const,
24
+ key: "2",
25
+ name: "STANDALONE MODE",
26
+ description: "Use raxflow as your main CLI",
27
+ features: [
28
+ "Full interactive TUI with panels and visualization",
29
+ "Complete orchestration from terminal",
30
+ "Advanced workflow management",
31
+ ],
32
+ },
33
+ {
34
+ id: "both" as const,
35
+ key: "3",
36
+ name: "BOTH",
37
+ description: "Setup both modes for maximum flexibility",
38
+ features: [
39
+ "Full hub integration with your CLIs",
40
+ "Standalone TUI when you need it",
41
+ "Best of both worlds",
42
+ ],
43
+ },
44
+ ];
45
+
46
+ export function ModeSelector({ selectedMode, onSelect, onContinue }: ModeSelectorProps) {
47
+ const [focusedIndex, setFocusedIndex] = useState(0);
48
+ const PRIMARY = "#f97316";
49
+
50
+ useInput((input, key) => {
51
+ if (key.upArrow) {
52
+ setFocusedIndex((prev) => (prev === 0 ? MODES.length : prev - 1));
53
+ } else if (key.downArrow) {
54
+ setFocusedIndex((prev) => (prev === MODES.length ? 0 : prev + 1));
55
+ } else if (key.return) {
56
+ if (focusedIndex === MODES.length && selectedMode) {
57
+ onContinue();
58
+ } else if (focusedIndex < MODES.length) {
59
+ onSelect(MODES[focusedIndex].id);
60
+ }
61
+ } else if (input === "1" || input === "2" || input === "3") {
62
+ const index = parseInt(input) - 1;
63
+ if (index < MODES.length) {
64
+ onSelect(MODES[index].id);
65
+ setFocusedIndex(index);
66
+ }
67
+ } else if (input === " ") {
68
+ if (focusedIndex < MODES.length) {
69
+ onSelect(MODES[focusedIndex].id);
70
+ }
71
+ }
72
+ });
73
+
74
+ return (
75
+ <Box flexDirection="column">
76
+ <Box marginBottom={1}>
77
+ <Text color={PRIMARY} bold>
78
+ SELECT USAGE MODE
79
+ </Text>
80
+ </Box>
81
+
82
+ <Box marginBottom={1}>
83
+ <Text color="#a1a1aa" dimColor>
84
+ Press 1, 2, or 3 to select, ENTER to continue
85
+ </Text>
86
+ </Box>
87
+
88
+ <Box flexDirection="column">
89
+ {MODES.map((mode, index) => {
90
+ const isSelected = selectedMode === mode.id;
91
+ const isFocused = index === focusedIndex;
92
+
93
+ return (
94
+ <Box
95
+ key={mode.id}
96
+ flexDirection="column"
97
+ marginBottom={1}
98
+ borderStyle={isSelected ? "bold" : "single"}
99
+ borderColor={isSelected ? PRIMARY : "#27272a"}
100
+ paddingX={1}
101
+ >
102
+ <Box>
103
+ <Text color={isFocused ? PRIMARY : "#27272a"}>
104
+ {isFocused ? "▶ " : " "}
105
+ </Text>
106
+ <Text color="#f59e0b">[{mode.key}]</Text>
107
+ <Text> </Text>
108
+ <Text color={isSelected ? PRIMARY : "#ffffff"} bold>
109
+ {mode.name}
110
+ </Text>
111
+ <Text color="#a1a1aa"> - {mode.description}</Text>
112
+ </Box>
113
+
114
+ {isSelected && (
115
+ <Box flexDirection="column" marginLeft={4} marginTop={0}>
116
+ {mode.features.map((feature, i) => (
117
+ <Box key={i}>
118
+ <Text color="#71717a">◆</Text>
119
+ <Text color="#a1a1aa"> {feature}</Text>
120
+ </Box>
121
+ ))}
122
+ </Box>
123
+ )}
124
+ </Box>
125
+ );
126
+ })}
127
+ </Box>
128
+
129
+ <Box marginTop={1}>
130
+ <Text color={focusedIndex === MODES.length ? PRIMARY : "#a1a1aa"}>
131
+ {focusedIndex === MODES.length ? "▶ " : " "}
132
+ </Text>
133
+ <Text color={selectedMode ? "#22c55e" : "#71717a"}>[CONTINUE]</Text>
134
+ </Box>
135
+ </Box>
136
+ );
137
+ }
@@ -0,0 +1,174 @@
1
+ import React, { useState, useEffect } from "react";
2
+ import { Box, Text, useInput } from "ink";
3
+
4
+ interface Provider {
5
+ id: string;
6
+ name: string;
7
+ description: string;
8
+ key: string;
9
+ requiresApiKey: boolean;
10
+ }
11
+
12
+ const PROVIDERS: Provider[] = [
13
+ {
14
+ id: "host",
15
+ name: "Host-Native",
16
+ description: "Use your local AI CLI tool (Claude Code, Codex, etc.)",
17
+ key: "H",
18
+ requiresApiKey: false,
19
+ },
20
+ {
21
+ id: "anthropic",
22
+ name: "Anthropic API",
23
+ description: "Direct Claude API access",
24
+ key: "A",
25
+ requiresApiKey: true,
26
+ },
27
+ {
28
+ id: "openai",
29
+ name: "OpenAI",
30
+ description: "GPT-4 and other OpenAI models",
31
+ key: "O",
32
+ requiresApiKey: true,
33
+ },
34
+ {
35
+ id: "gemini",
36
+ name: "Gemini",
37
+ description: "Google's Gemini models",
38
+ key: "G",
39
+ requiresApiKey: true,
40
+ },
41
+ {
42
+ id: "mistral",
43
+ name: "Mistral",
44
+ description: "Mistral AI models",
45
+ key: "M",
46
+ requiresApiKey: true,
47
+ },
48
+ {
49
+ id: "groq",
50
+ name: "Groq",
51
+ description: "Fast inference with Groq",
52
+ key: "Q",
53
+ requiresApiKey: true,
54
+ },
55
+ ];
56
+
57
+ interface ProviderSelectorProps {
58
+ selectedProviders: string[];
59
+ onToggle: (providerId: string) => void;
60
+ onContinue: () => void;
61
+ onBack: () => void;
62
+ }
63
+
64
+ export function ProviderSelector({
65
+ selectedProviders,
66
+ onToggle,
67
+ onContinue,
68
+ onBack,
69
+ }: ProviderSelectorProps) {
70
+ const [focusedIndex, setFocusedIndex] = useState(0);
71
+ const PRIMARY = "#f97316";
72
+
73
+ useInput((input, key) => {
74
+ if (key.upArrow) {
75
+ setFocusedIndex((prev) => (prev === 0 ? PROVIDERS.length - 1 : prev - 1));
76
+ } else if (key.downArrow) {
77
+ setFocusedIndex((prev) => (prev === PROVIDERS.length - 1 ? 0 : prev + 1));
78
+ } else if (key.return) {
79
+ if (focusedIndex === PROVIDERS.length) {
80
+ if (selectedProviders.length > 0) {
81
+ onContinue();
82
+ }
83
+ } else if (focusedIndex === PROVIDERS.length + 1) {
84
+ onBack();
85
+ } else {
86
+ onToggle(PROVIDERS[focusedIndex].id);
87
+ }
88
+ } else if (input === " ") {
89
+ if (focusedIndex < PROVIDERS.length) {
90
+ onToggle(PROVIDERS[focusedIndex].id);
91
+ }
92
+ } else if (key.leftArrow || input === "b") {
93
+ onBack();
94
+ } else {
95
+ // Check for key shortcuts
96
+ const provider = PROVIDERS.find((p) => p.key.toLowerCase() === input.toLowerCase());
97
+ if (provider) {
98
+ onToggle(provider.id);
99
+ }
100
+ }
101
+ });
102
+
103
+ useEffect(() => {
104
+ // Add extra navigation items
105
+ }, []);
106
+
107
+ return (
108
+ <Box flexDirection="column">
109
+ <Box marginBottom={1}>
110
+ <Text color="#f97316" bold>
111
+ SELECT PROVIDERS
112
+ </Text>
113
+ </Box>
114
+
115
+ <Box marginBottom={1}>
116
+ <Text color="#a1a1aa" dimColor>
117
+ Use ↑/↓ to navigate, SPACE to toggle, ENTER to continue
118
+ </Text>
119
+ </Box>
120
+
121
+ <Box flexDirection="column">
122
+ {PROVIDERS.map((provider, index) => {
123
+ const isSelected = selectedProviders.includes(provider.id);
124
+ const isFocused = index === focusedIndex;
125
+
126
+ return (
127
+ <Box key={provider.id} marginBottom={0}>
128
+ <Text color={isFocused ? PRIMARY : "#27272a"}>
129
+ {isFocused ? "▶ " : " "}
130
+ </Text>
131
+ <Text color={isSelected ? "#22c55e" : "#a1a1aa"}>
132
+ [{isSelected ? "■" : " "}]
133
+ </Text>
134
+ <Text> </Text>
135
+ <Text color="#f59e0b">[{provider.key}]</Text>
136
+ <Text> </Text>
137
+ <Text color={isFocused ? "#ffffff" : "#a1a1aa"} bold={isFocused}>
138
+ {provider.name}
139
+ </Text>
140
+ <Text color="#71717a"> - {provider.description}</Text>
141
+ </Box>
142
+ );
143
+ })}
144
+ </Box>
145
+
146
+ <Box marginTop={1}>
147
+ <Text color="#27272a">{"─".repeat(50)}</Text>
148
+ </Box>
149
+
150
+ <Box marginTop={1}>
151
+ <Text color={focusedIndex === PROVIDERS.length ? PRIMARY : "#a1a1aa"}>
152
+ {focusedIndex === PROVIDERS.length ? "▶ " : " "}
153
+ </Text>
154
+ <Text color={selectedProviders.length > 0 ? "#22c55e" : "#71717a"}>
155
+ [CONTINUE]
156
+ </Text>
157
+ <Text> </Text>
158
+ <Text color={focusedIndex === PROVIDERS.length + 1 ? PRIMARY : "#a1a1aa"}>
159
+ {focusedIndex === PROVIDERS.length + 1 ? "▶ " : " "}
160
+ </Text>
161
+ <Text color="#a1a1aa">[BACK]</Text>
162
+ </Box>
163
+
164
+ {selectedProviders.length === 0 && (
165
+ <Box marginTop={1}>
166
+ <Text color="#f59e0b">⚠ Select at least one provider to continue</Text>
167
+ </Box>
168
+ )}
169
+ </Box>
170
+ );
171
+ }
172
+
173
+ export { PROVIDERS };
174
+ export type { Provider };