agent-relay 2.0.22 → 2.0.23

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 (391) hide show
  1. package/bin/relay-pty-linux-arm64 +0 -0
  2. package/dist/src/cli/index.d.ts +3 -3
  3. package/dist/src/cli/index.js +31 -100
  4. package/package.json +22 -29
  5. package/packages/api-types/package.json +1 -1
  6. package/packages/bridge/package.json +8 -8
  7. package/packages/cli-tester/package.json +1 -1
  8. package/packages/cloud/dist/server.js +25 -4
  9. package/packages/cloud/package.json +6 -6
  10. package/packages/config/package.json +2 -2
  11. package/packages/continuity/package.json +1 -1
  12. package/packages/daemon/dist/orchestrator.js +19 -1
  13. package/packages/daemon/package.json +12 -12
  14. package/packages/hooks/package.json +4 -4
  15. package/packages/mcp/package.json +2 -2
  16. package/packages/memory/package.json +2 -2
  17. package/packages/policy/package.json +2 -2
  18. package/packages/protocol/package.json +1 -1
  19. package/packages/resiliency/package.json +1 -1
  20. package/packages/sdk/package.json +2 -2
  21. package/packages/spawner/package.json +1 -1
  22. package/packages/state/package.json +1 -1
  23. package/packages/storage/package.json +2 -2
  24. package/packages/telemetry/package.json +1 -1
  25. package/packages/trajectory/package.json +2 -2
  26. package/packages/user-directory/package.json +2 -2
  27. package/packages/utils/dist/update-checker.js +4 -0
  28. package/packages/utils/package.json +1 -1
  29. package/packages/wrapper/package.json +6 -6
  30. package/deploy/workspace/codex.config.toml +0 -20
  31. package/deploy/workspace/entrypoint-browser.sh +0 -118
  32. package/deploy/workspace/entrypoint.sh +0 -612
  33. package/deploy/workspace/gh-credential-relay +0 -90
  34. package/deploy/workspace/gh-relay +0 -156
  35. package/deploy/workspace/git-credential-relay +0 -330
  36. package/deploy/workspace/git-credential-relay.test.sh +0 -230
  37. package/dist/dashboard/out/404.html +0 -1
  38. package/dist/dashboard/out/_next/static/91mkGYq3qbG8WHE6VytQ8/_buildManifest.js +0 -1
  39. package/dist/dashboard/out/_next/static/91mkGYq3qbG8WHE6VytQ8/_ssgManifest.js +0 -1
  40. package/dist/dashboard/out/_next/static/chunks/116-a883fca163f3a5bc.js +0 -1
  41. package/dist/dashboard/out/_next/static/chunks/117-c8afed19e821a35d.js +0 -2
  42. package/dist/dashboard/out/_next/static/chunks/282-980c2eb8fff20123.js +0 -1
  43. package/dist/dashboard/out/_next/static/chunks/320-a6304232cd0ee2ce.js +0 -1
  44. package/dist/dashboard/out/_next/static/chunks/532-bace199897eeab37.js +0 -9
  45. package/dist/dashboard/out/_next/static/chunks/631-16b905e5920f9b59.js +0 -1
  46. package/dist/dashboard/out/_next/static/chunks/648-acb2ff9f77cbfbd3.js +0 -1
  47. package/dist/dashboard/out/_next/static/chunks/766-2aea80818f7eb0d8.js +0 -1
  48. package/dist/dashboard/out/_next/static/chunks/83-26d2bde54616ee90.js +0 -1
  49. package/dist/dashboard/out/_next/static/chunks/847-f1f467060f32afff.js +0 -1
  50. package/dist/dashboard/out/_next/static/chunks/891-5cb1513eeb97a891.js +0 -1
  51. package/dist/dashboard/out/_next/static/chunks/app/_not-found/page-60501fddbafba9dc.js +0 -1
  52. package/dist/dashboard/out/_next/static/chunks/app/app/onboarding/page-9914652442f7e4fb.js +0 -1
  53. package/dist/dashboard/out/_next/static/chunks/app/app/page-366fb7c078d4e9e0.js +0 -1
  54. package/dist/dashboard/out/_next/static/chunks/app/cloud/link/page-fa1d5842aa90e8a6.js +0 -1
  55. package/dist/dashboard/out/_next/static/chunks/app/complete-profile/page-dd64bbdf66b639cd.js +0 -1
  56. package/dist/dashboard/out/_next/static/chunks/app/connect-repos/page-113060009ef35bc2.js +0 -1
  57. package/dist/dashboard/out/_next/static/chunks/app/history/page-9965d2483011b846.js +0 -1
  58. package/dist/dashboard/out/_next/static/chunks/app/layout-6b91e33784c20610.js +0 -1
  59. package/dist/dashboard/out/_next/static/chunks/app/login/page-435eceb0073be027.js +0 -1
  60. package/dist/dashboard/out/_next/static/chunks/app/metrics/page-1e37ef8e73940b40.js +0 -1
  61. package/dist/dashboard/out/_next/static/chunks/app/page-8119d4246743574e.js +0 -1
  62. package/dist/dashboard/out/_next/static/chunks/app/pricing/page-9db3ebdfa567a7c9.js +0 -1
  63. package/dist/dashboard/out/_next/static/chunks/app/providers/page-ecb16ffd3b36262b.js +0 -1
  64. package/dist/dashboard/out/_next/static/chunks/app/providers/setup/[provider]/page-4dbe33f0f7691b7c.js +0 -1
  65. package/dist/dashboard/out/_next/static/chunks/app/signup/page-c7a0a28341365ae0.js +0 -1
  66. package/dist/dashboard/out/_next/static/chunks/e868780c-48e5f147c90a3a41.js +0 -18
  67. package/dist/dashboard/out/_next/static/chunks/fd9d1056-609918ca7b6280bb.js +0 -1
  68. package/dist/dashboard/out/_next/static/chunks/framework-f66176bb897dc684.js +0 -1
  69. package/dist/dashboard/out/_next/static/chunks/main-311c3db74dcfadb7.js +0 -1
  70. package/dist/dashboard/out/_next/static/chunks/main-app-fdbeb09028f57c9f.js +0 -1
  71. package/dist/dashboard/out/_next/static/chunks/pages/_app-72b849fbd24ac258.js +0 -1
  72. package/dist/dashboard/out/_next/static/chunks/pages/_error-7ba65e1336b92748.js +0 -1
  73. package/dist/dashboard/out/_next/static/chunks/polyfills-42372ed130431b0a.js +0 -1
  74. package/dist/dashboard/out/_next/static/chunks/webpack-1cdd8ed57114d5e1.js +0 -1
  75. package/dist/dashboard/out/_next/static/css/4034f236dd1a3178.css +0 -1
  76. package/dist/dashboard/out/_next/static/css/6892f8422896ef7a.css +0 -1
  77. package/dist/dashboard/out/alt-logos/agent-relay-logo-128.png +0 -0
  78. package/dist/dashboard/out/alt-logos/agent-relay-logo-256.png +0 -0
  79. package/dist/dashboard/out/alt-logos/agent-relay-logo-32.png +0 -0
  80. package/dist/dashboard/out/alt-logos/agent-relay-logo-512.png +0 -0
  81. package/dist/dashboard/out/alt-logos/agent-relay-logo-64.png +0 -0
  82. package/dist/dashboard/out/alt-logos/agent-relay-logo.svg +0 -45
  83. package/dist/dashboard/out/alt-logos/logo.svg +0 -38
  84. package/dist/dashboard/out/alt-logos/monogram-logo-128.png +0 -0
  85. package/dist/dashboard/out/alt-logos/monogram-logo-256.png +0 -0
  86. package/dist/dashboard/out/alt-logos/monogram-logo-32.png +0 -0
  87. package/dist/dashboard/out/alt-logos/monogram-logo-512.png +0 -0
  88. package/dist/dashboard/out/alt-logos/monogram-logo-64.png +0 -0
  89. package/dist/dashboard/out/alt-logos/monogram-logo.svg +0 -38
  90. package/dist/dashboard/out/app/onboarding.html +0 -1
  91. package/dist/dashboard/out/app/onboarding.txt +0 -7
  92. package/dist/dashboard/out/app.html +0 -1
  93. package/dist/dashboard/out/app.txt +0 -7
  94. package/dist/dashboard/out/apple-icon.png +0 -0
  95. package/dist/dashboard/out/cloud/link.html +0 -1
  96. package/dist/dashboard/out/cloud/link.txt +0 -7
  97. package/dist/dashboard/out/complete-profile.html +0 -5
  98. package/dist/dashboard/out/complete-profile.txt +0 -7
  99. package/dist/dashboard/out/connect-repos.html +0 -1
  100. package/dist/dashboard/out/connect-repos.txt +0 -7
  101. package/dist/dashboard/out/history.html +0 -1
  102. package/dist/dashboard/out/history.txt +0 -7
  103. package/dist/dashboard/out/index.html +0 -1
  104. package/dist/dashboard/out/index.txt +0 -7
  105. package/dist/dashboard/out/login.html +0 -5
  106. package/dist/dashboard/out/login.txt +0 -7
  107. package/dist/dashboard/out/metrics.html +0 -1
  108. package/dist/dashboard/out/metrics.txt +0 -7
  109. package/dist/dashboard/out/pricing.html +0 -13
  110. package/dist/dashboard/out/pricing.txt +0 -7
  111. package/dist/dashboard/out/providers/setup/claude.html +0 -1
  112. package/dist/dashboard/out/providers/setup/claude.txt +0 -8
  113. package/dist/dashboard/out/providers/setup/codex.html +0 -1
  114. package/dist/dashboard/out/providers/setup/codex.txt +0 -8
  115. package/dist/dashboard/out/providers/setup/cursor.html +0 -1
  116. package/dist/dashboard/out/providers/setup/cursor.txt +0 -8
  117. package/dist/dashboard/out/providers.html +0 -1
  118. package/dist/dashboard/out/providers.txt +0 -7
  119. package/dist/dashboard/out/signup.html +0 -6
  120. package/dist/dashboard/out/signup.txt +0 -7
  121. package/dist/src/dashboard-server/index.d.ts +0 -8
  122. package/dist/src/dashboard-server/index.js +0 -8
  123. package/packages/dashboard/README.md +0 -48
  124. package/packages/dashboard/dist/health-worker-manager.d.ts +0 -62
  125. package/packages/dashboard/dist/health-worker-manager.js +0 -144
  126. package/packages/dashboard/dist/health-worker.d.ts +0 -9
  127. package/packages/dashboard/dist/health-worker.js +0 -79
  128. package/packages/dashboard/dist/index.d.ts +0 -20
  129. package/packages/dashboard/dist/index.js +0 -19
  130. package/packages/dashboard/dist/metrics.d.ts +0 -105
  131. package/packages/dashboard/dist/metrics.js +0 -193
  132. package/packages/dashboard/dist/needs-attention.d.ts +0 -24
  133. package/packages/dashboard/dist/needs-attention.js +0 -78
  134. package/packages/dashboard/dist/server.d.ts +0 -25
  135. package/packages/dashboard/dist/server.js +0 -5270
  136. package/packages/dashboard/dist/start.d.ts +0 -6
  137. package/packages/dashboard/dist/start.js +0 -13
  138. package/packages/dashboard/dist/types/threading.d.ts +0 -8
  139. package/packages/dashboard/dist/types/threading.js +0 -2
  140. package/packages/dashboard/dist/user-bridge.d.ts +0 -154
  141. package/packages/dashboard/dist/user-bridge.js +0 -372
  142. package/packages/dashboard/package.json +0 -65
  143. package/packages/dashboard/ui/app/app/onboarding/page.tsx +0 -394
  144. package/packages/dashboard/ui/app/app/page.tsx +0 -667
  145. package/packages/dashboard/ui/app/apple-icon.png +0 -0
  146. package/packages/dashboard/ui/app/cloud/link/page.tsx +0 -464
  147. package/packages/dashboard/ui/app/complete-profile/page.tsx +0 -204
  148. package/packages/dashboard/ui/app/connect-repos/page.tsx +0 -410
  149. package/packages/dashboard/ui/app/favicon.png +0 -0
  150. package/packages/dashboard/ui/app/globals.css +0 -59
  151. package/packages/dashboard/ui/app/history/page.tsx +0 -658
  152. package/packages/dashboard/ui/app/layout.tsx +0 -25
  153. package/packages/dashboard/ui/app/login/page.tsx +0 -424
  154. package/packages/dashboard/ui/app/metrics/page.tsx +0 -751
  155. package/packages/dashboard/ui/app/page.tsx +0 -59
  156. package/packages/dashboard/ui/app/pricing/page.tsx +0 -7
  157. package/packages/dashboard/ui/app/providers/page.tsx +0 -193
  158. package/packages/dashboard/ui/app/providers/setup/[provider]/ProviderSetupClient.tsx +0 -148
  159. package/packages/dashboard/ui/app/providers/setup/[provider]/constants.ts +0 -35
  160. package/packages/dashboard/ui/app/providers/setup/[provider]/page.tsx +0 -42
  161. package/packages/dashboard/ui/app/signup/page.tsx +0 -533
  162. package/packages/dashboard/ui/index.ts +0 -49
  163. package/packages/dashboard/ui/landing/LandingPage.tsx +0 -713
  164. package/packages/dashboard/ui/landing/PricingPage.tsx +0 -559
  165. package/packages/dashboard/ui/landing/index.ts +0 -6
  166. package/packages/dashboard/ui/landing/styles.css +0 -2850
  167. package/packages/dashboard/ui/lib/agent-merge.ts +0 -35
  168. package/packages/dashboard/ui/lib/api.ts +0 -1155
  169. package/packages/dashboard/ui/lib/cloudApi.ts +0 -877
  170. package/packages/dashboard/ui/lib/colors.ts +0 -218
  171. package/packages/dashboard/ui/lib/hierarchy.ts +0 -242
  172. package/packages/dashboard/ui/lib/stuckDetection.ts +0 -142
  173. package/packages/dashboard/ui/next-env.d.ts +0 -5
  174. package/packages/dashboard/ui/next.config.js +0 -41
  175. package/packages/dashboard/ui/package-lock.json +0 -2882
  176. package/packages/dashboard/ui/package.json +0 -33
  177. package/packages/dashboard/ui/postcss.config.js +0 -5
  178. package/packages/dashboard/ui/react-components/ActivityFeed.tsx +0 -216
  179. package/packages/dashboard/ui/react-components/AddWorkspaceModal.tsx +0 -170
  180. package/packages/dashboard/ui/react-components/AgentCard.tsx +0 -587
  181. package/packages/dashboard/ui/react-components/AgentList.tsx +0 -411
  182. package/packages/dashboard/ui/react-components/AgentProfilePanel.tsx +0 -564
  183. package/packages/dashboard/ui/react-components/App.tsx +0 -3033
  184. package/packages/dashboard/ui/react-components/BillingPanel.tsx +0 -922
  185. package/packages/dashboard/ui/react-components/BillingResult.tsx +0 -447
  186. package/packages/dashboard/ui/react-components/BroadcastComposer.tsx +0 -690
  187. package/packages/dashboard/ui/react-components/ChannelAdminPanel.tsx +0 -773
  188. package/packages/dashboard/ui/react-components/ChannelBrowser.tsx +0 -385
  189. package/packages/dashboard/ui/react-components/ChannelChat.tsx +0 -261
  190. package/packages/dashboard/ui/react-components/ChannelSidebar.tsx +0 -399
  191. package/packages/dashboard/ui/react-components/CloudSessionProvider.tsx +0 -130
  192. package/packages/dashboard/ui/react-components/CommandPalette.tsx +0 -815
  193. package/packages/dashboard/ui/react-components/ConfirmationDialog.tsx +0 -133
  194. package/packages/dashboard/ui/react-components/ConversationHistory.tsx +0 -518
  195. package/packages/dashboard/ui/react-components/CoordinatorPanel.tsx +0 -944
  196. package/packages/dashboard/ui/react-components/DecisionQueue.tsx +0 -717
  197. package/packages/dashboard/ui/react-components/DirectMessageView.tsx +0 -164
  198. package/packages/dashboard/ui/react-components/FileAutocomplete.tsx +0 -368
  199. package/packages/dashboard/ui/react-components/FleetOverview.tsx +0 -278
  200. package/packages/dashboard/ui/react-components/LogViewer.tsx +0 -310
  201. package/packages/dashboard/ui/react-components/LogViewerPanel.tsx +0 -482
  202. package/packages/dashboard/ui/react-components/Logo.tsx +0 -284
  203. package/packages/dashboard/ui/react-components/MentionAutocomplete.tsx +0 -384
  204. package/packages/dashboard/ui/react-components/MessageComposer.tsx +0 -457
  205. package/packages/dashboard/ui/react-components/MessageList.tsx +0 -649
  206. package/packages/dashboard/ui/react-components/MessageSenderName.tsx +0 -91
  207. package/packages/dashboard/ui/react-components/MessageStatusIndicator.tsx +0 -142
  208. package/packages/dashboard/ui/react-components/NewConversationModal.tsx +0 -400
  209. package/packages/dashboard/ui/react-components/NotificationToast.tsx +0 -488
  210. package/packages/dashboard/ui/react-components/OnlineUsersIndicator.tsx +0 -164
  211. package/packages/dashboard/ui/react-components/Pagination.tsx +0 -124
  212. package/packages/dashboard/ui/react-components/PricingPlans.tsx +0 -386
  213. package/packages/dashboard/ui/react-components/ProjectList.tsx +0 -625
  214. package/packages/dashboard/ui/react-components/ProviderAuthFlow.tsx +0 -853
  215. package/packages/dashboard/ui/react-components/ProviderConnectionList.tsx +0 -378
  216. package/packages/dashboard/ui/react-components/ProvisioningProgress.tsx +0 -730
  217. package/packages/dashboard/ui/react-components/RepoAccessPanel.tsx +0 -549
  218. package/packages/dashboard/ui/react-components/ServerCard.tsx +0 -202
  219. package/packages/dashboard/ui/react-components/SessionExpiredModal.tsx +0 -128
  220. package/packages/dashboard/ui/react-components/SpawnModal.tsx +0 -804
  221. package/packages/dashboard/ui/react-components/TaskAssignmentUI.tsx +0 -375
  222. package/packages/dashboard/ui/react-components/TerminalProviderSetup.tsx +0 -608
  223. package/packages/dashboard/ui/react-components/ThemeProvider.tsx +0 -325
  224. package/packages/dashboard/ui/react-components/ThinkingIndicator.tsx +0 -231
  225. package/packages/dashboard/ui/react-components/ThreadList.tsx +0 -198
  226. package/packages/dashboard/ui/react-components/ThreadPanel.tsx +0 -346
  227. package/packages/dashboard/ui/react-components/TrajectoryViewer.tsx +0 -698
  228. package/packages/dashboard/ui/react-components/TypingIndicator.tsx +0 -69
  229. package/packages/dashboard/ui/react-components/UsageBanner.tsx +0 -231
  230. package/packages/dashboard/ui/react-components/UserProfilePanel.tsx +0 -233
  231. package/packages/dashboard/ui/react-components/WorkspaceContext.tsx +0 -107
  232. package/packages/dashboard/ui/react-components/WorkspaceSelector.tsx +0 -234
  233. package/packages/dashboard/ui/react-components/WorkspaceStatusIndicator.tsx +0 -370
  234. package/packages/dashboard/ui/react-components/XTermInteractive.tsx +0 -510
  235. package/packages/dashboard/ui/react-components/XTermLogViewer.tsx +0 -719
  236. package/packages/dashboard/ui/react-components/channels/ChannelDialogs.tsx +0 -1411
  237. package/packages/dashboard/ui/react-components/channels/ChannelHeader.tsx +0 -317
  238. package/packages/dashboard/ui/react-components/channels/ChannelMessageList.tsx +0 -463
  239. package/packages/dashboard/ui/react-components/channels/ChannelViewV1.tsx +0 -146
  240. package/packages/dashboard/ui/react-components/channels/MessageInput.tsx +0 -288
  241. package/packages/dashboard/ui/react-components/channels/SearchInput.tsx +0 -172
  242. package/packages/dashboard/ui/react-components/channels/SearchResults.tsx +0 -336
  243. package/packages/dashboard/ui/react-components/channels/api.ts +0 -697
  244. package/packages/dashboard/ui/react-components/channels/index.ts +0 -76
  245. package/packages/dashboard/ui/react-components/channels/mockApi.ts +0 -344
  246. package/packages/dashboard/ui/react-components/channels/types.ts +0 -566
  247. package/packages/dashboard/ui/react-components/hooks/index.ts +0 -57
  248. package/packages/dashboard/ui/react-components/hooks/useAgentLogs.ts +0 -394
  249. package/packages/dashboard/ui/react-components/hooks/useAgents.ts +0 -127
  250. package/packages/dashboard/ui/react-components/hooks/useBroadcastDedup.ts +0 -86
  251. package/packages/dashboard/ui/react-components/hooks/useChannelAdmin.ts +0 -329
  252. package/packages/dashboard/ui/react-components/hooks/useChannelBrowser.ts +0 -239
  253. package/packages/dashboard/ui/react-components/hooks/useChannelCommands.ts +0 -138
  254. package/packages/dashboard/ui/react-components/hooks/useChannels.ts +0 -328
  255. package/packages/dashboard/ui/react-components/hooks/useDebounce.ts +0 -29
  256. package/packages/dashboard/ui/react-components/hooks/useDirectMessage.ts +0 -141
  257. package/packages/dashboard/ui/react-components/hooks/useMessages.ts +0 -309
  258. package/packages/dashboard/ui/react-components/hooks/useOrchestrator.ts +0 -364
  259. package/packages/dashboard/ui/react-components/hooks/usePinnedAgents.ts +0 -140
  260. package/packages/dashboard/ui/react-components/hooks/usePresence.ts +0 -340
  261. package/packages/dashboard/ui/react-components/hooks/useRecentRepos.ts +0 -130
  262. package/packages/dashboard/ui/react-components/hooks/useSession.ts +0 -209
  263. package/packages/dashboard/ui/react-components/hooks/useTrajectory.ts +0 -265
  264. package/packages/dashboard/ui/react-components/hooks/useWebSocket.ts +0 -169
  265. package/packages/dashboard/ui/react-components/hooks/useWorkspaceMembers.ts +0 -120
  266. package/packages/dashboard/ui/react-components/hooks/useWorkspaceRepos.ts +0 -73
  267. package/packages/dashboard/ui/react-components/hooks/useWorkspaceStatus.ts +0 -237
  268. package/packages/dashboard/ui/react-components/index.ts +0 -81
  269. package/packages/dashboard/ui/react-components/layout/Header.tsx +0 -355
  270. package/packages/dashboard/ui/react-components/layout/RepoContextHeader.tsx +0 -361
  271. package/packages/dashboard/ui/react-components/layout/Sidebar.archive.test.tsx +0 -126
  272. package/packages/dashboard/ui/react-components/layout/Sidebar.test.tsx +0 -691
  273. package/packages/dashboard/ui/react-components/layout/Sidebar.tsx +0 -930
  274. package/packages/dashboard/ui/react-components/layout/index.ts +0 -7
  275. package/packages/dashboard/ui/react-components/settings/BillingSettingsPanel.tsx +0 -564
  276. package/packages/dashboard/ui/react-components/settings/SettingsPage.tsx +0 -544
  277. package/packages/dashboard/ui/react-components/settings/TeamSettingsPanel.tsx +0 -560
  278. package/packages/dashboard/ui/react-components/settings/WorkspaceSettingsPanel.tsx +0 -1386
  279. package/packages/dashboard/ui/react-components/settings/index.ts +0 -11
  280. package/packages/dashboard/ui/react-components/settings/types.ts +0 -53
  281. package/packages/dashboard/ui/react-components/utils/messageFormatting.tsx +0 -370
  282. package/packages/dashboard/ui/tailwind.config.js +0 -148
  283. package/packages/dashboard/ui/types/index.ts +0 -304
  284. package/packages/dashboard/ui/types/threading.ts +0 -7
  285. package/packages/dashboard/ui-dist/404.html +0 -1
  286. package/packages/dashboard/ui-dist/_next/static/91mkGYq3qbG8WHE6VytQ8/_buildManifest.js +0 -1
  287. package/packages/dashboard/ui-dist/_next/static/91mkGYq3qbG8WHE6VytQ8/_ssgManifest.js +0 -1
  288. package/packages/dashboard/ui-dist/_next/static/T2rV14eEU5OweDeV29SvG/_buildManifest.js +0 -1
  289. package/packages/dashboard/ui-dist/_next/static/T2rV14eEU5OweDeV29SvG/_ssgManifest.js +0 -1
  290. package/packages/dashboard/ui-dist/_next/static/chunks/116-a883fca163f3a5bc.js +0 -1
  291. package/packages/dashboard/ui-dist/_next/static/chunks/117-c8afed19e821a35d.js +0 -2
  292. package/packages/dashboard/ui-dist/_next/static/chunks/282-980c2eb8fff20123.js +0 -1
  293. package/packages/dashboard/ui-dist/_next/static/chunks/320-a6304232cd0ee2ce.js +0 -1
  294. package/packages/dashboard/ui-dist/_next/static/chunks/532-bace199897eeab37.js +0 -9
  295. package/packages/dashboard/ui-dist/_next/static/chunks/631-16b905e5920f9b59.js +0 -1
  296. package/packages/dashboard/ui-dist/_next/static/chunks/648-acb2ff9f77cbfbd3.js +0 -1
  297. package/packages/dashboard/ui-dist/_next/static/chunks/766-2aea80818f7eb0d8.js +0 -1
  298. package/packages/dashboard/ui-dist/_next/static/chunks/83-26d2bde54616ee90.js +0 -1
  299. package/packages/dashboard/ui-dist/_next/static/chunks/847-f1f467060f32afff.js +0 -1
  300. package/packages/dashboard/ui-dist/_next/static/chunks/891-5cb1513eeb97a891.js +0 -1
  301. package/packages/dashboard/ui-dist/_next/static/chunks/app/_not-found/page-60501fddbafba9dc.js +0 -1
  302. package/packages/dashboard/ui-dist/_next/static/chunks/app/app/onboarding/page-9914652442f7e4fb.js +0 -1
  303. package/packages/dashboard/ui-dist/_next/static/chunks/app/app/page-366fb7c078d4e9e0.js +0 -1
  304. package/packages/dashboard/ui-dist/_next/static/chunks/app/cloud/link/page-fa1d5842aa90e8a6.js +0 -1
  305. package/packages/dashboard/ui-dist/_next/static/chunks/app/complete-profile/page-dd64bbdf66b639cd.js +0 -1
  306. package/packages/dashboard/ui-dist/_next/static/chunks/app/connect-repos/page-113060009ef35bc2.js +0 -1
  307. package/packages/dashboard/ui-dist/_next/static/chunks/app/history/page-9965d2483011b846.js +0 -1
  308. package/packages/dashboard/ui-dist/_next/static/chunks/app/layout-6b91e33784c20610.js +0 -1
  309. package/packages/dashboard/ui-dist/_next/static/chunks/app/login/page-435eceb0073be027.js +0 -1
  310. package/packages/dashboard/ui-dist/_next/static/chunks/app/metrics/page-1e37ef8e73940b40.js +0 -1
  311. package/packages/dashboard/ui-dist/_next/static/chunks/app/page-8119d4246743574e.js +0 -1
  312. package/packages/dashboard/ui-dist/_next/static/chunks/app/pricing/page-9db3ebdfa567a7c9.js +0 -1
  313. package/packages/dashboard/ui-dist/_next/static/chunks/app/providers/page-ecb16ffd3b36262b.js +0 -1
  314. package/packages/dashboard/ui-dist/_next/static/chunks/app/providers/setup/[provider]/page-4dbe33f0f7691b7c.js +0 -1
  315. package/packages/dashboard/ui-dist/_next/static/chunks/app/signup/page-c7a0a28341365ae0.js +0 -1
  316. package/packages/dashboard/ui-dist/_next/static/chunks/e868780c-48e5f147c90a3a41.js +0 -18
  317. package/packages/dashboard/ui-dist/_next/static/chunks/fd9d1056-609918ca7b6280bb.js +0 -1
  318. package/packages/dashboard/ui-dist/_next/static/chunks/framework-f66176bb897dc684.js +0 -1
  319. package/packages/dashboard/ui-dist/_next/static/chunks/main-311c3db74dcfadb7.js +0 -1
  320. package/packages/dashboard/ui-dist/_next/static/chunks/main-app-fdbeb09028f57c9f.js +0 -1
  321. package/packages/dashboard/ui-dist/_next/static/chunks/pages/_app-72b849fbd24ac258.js +0 -1
  322. package/packages/dashboard/ui-dist/_next/static/chunks/pages/_error-7ba65e1336b92748.js +0 -1
  323. package/packages/dashboard/ui-dist/_next/static/chunks/polyfills-42372ed130431b0a.js +0 -1
  324. package/packages/dashboard/ui-dist/_next/static/chunks/webpack-1cdd8ed57114d5e1.js +0 -1
  325. package/packages/dashboard/ui-dist/_next/static/css/4034f236dd1a3178.css +0 -1
  326. package/packages/dashboard/ui-dist/_next/static/css/6892f8422896ef7a.css +0 -1
  327. package/packages/dashboard/ui-dist/_next/static/l8L2OscDSR2vsMIlWcC48/_buildManifest.js +0 -1
  328. package/packages/dashboard/ui-dist/_next/static/l8L2OscDSR2vsMIlWcC48/_ssgManifest.js +0 -1
  329. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo-128.png +0 -0
  330. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo-256.png +0 -0
  331. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo-32.png +0 -0
  332. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo-512.png +0 -0
  333. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo-64.png +0 -0
  334. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo.svg +0 -45
  335. package/packages/dashboard/ui-dist/alt-logos/logo.svg +0 -38
  336. package/packages/dashboard/ui-dist/alt-logos/monogram-logo-128.png +0 -0
  337. package/packages/dashboard/ui-dist/alt-logos/monogram-logo-256.png +0 -0
  338. package/packages/dashboard/ui-dist/alt-logos/monogram-logo-32.png +0 -0
  339. package/packages/dashboard/ui-dist/alt-logos/monogram-logo-512.png +0 -0
  340. package/packages/dashboard/ui-dist/alt-logos/monogram-logo-64.png +0 -0
  341. package/packages/dashboard/ui-dist/alt-logos/monogram-logo.svg +0 -38
  342. package/packages/dashboard/ui-dist/app/onboarding.html +0 -1
  343. package/packages/dashboard/ui-dist/app/onboarding.txt +0 -7
  344. package/packages/dashboard/ui-dist/app.html +0 -1
  345. package/packages/dashboard/ui-dist/app.txt +0 -7
  346. package/packages/dashboard/ui-dist/apple-icon.png +0 -0
  347. package/packages/dashboard/ui-dist/cloud/link.html +0 -1
  348. package/packages/dashboard/ui-dist/cloud/link.txt +0 -7
  349. package/packages/dashboard/ui-dist/complete-profile.html +0 -5
  350. package/packages/dashboard/ui-dist/complete-profile.txt +0 -7
  351. package/packages/dashboard/ui-dist/connect-repos.html +0 -1
  352. package/packages/dashboard/ui-dist/connect-repos.txt +0 -7
  353. package/packages/dashboard/ui-dist/history.html +0 -1
  354. package/packages/dashboard/ui-dist/history.txt +0 -7
  355. package/packages/dashboard/ui-dist/index.html +0 -1
  356. package/packages/dashboard/ui-dist/index.txt +0 -7
  357. package/packages/dashboard/ui-dist/login.html +0 -5
  358. package/packages/dashboard/ui-dist/login.txt +0 -7
  359. package/packages/dashboard/ui-dist/metrics.html +0 -1
  360. package/packages/dashboard/ui-dist/metrics.txt +0 -7
  361. package/packages/dashboard/ui-dist/pricing.html +0 -13
  362. package/packages/dashboard/ui-dist/pricing.txt +0 -7
  363. package/packages/dashboard/ui-dist/providers/setup/claude.html +0 -1
  364. package/packages/dashboard/ui-dist/providers/setup/claude.txt +0 -8
  365. package/packages/dashboard/ui-dist/providers/setup/codex.html +0 -1
  366. package/packages/dashboard/ui-dist/providers/setup/codex.txt +0 -8
  367. package/packages/dashboard/ui-dist/providers/setup/cursor.html +0 -1
  368. package/packages/dashboard/ui-dist/providers/setup/cursor.txt +0 -8
  369. package/packages/dashboard/ui-dist/providers.html +0 -1
  370. package/packages/dashboard/ui-dist/providers.txt +0 -7
  371. package/packages/dashboard/ui-dist/signup.html +0 -6
  372. package/packages/dashboard/ui-dist/signup.txt +0 -7
  373. package/packages/dashboard-server/dist/health-worker-manager.d.ts +0 -62
  374. package/packages/dashboard-server/dist/health-worker-manager.js +0 -144
  375. package/packages/dashboard-server/dist/health-worker.d.ts +0 -9
  376. package/packages/dashboard-server/dist/health-worker.js +0 -79
  377. package/packages/dashboard-server/dist/index.d.ts +0 -18
  378. package/packages/dashboard-server/dist/index.js +0 -17
  379. package/packages/dashboard-server/dist/metrics.d.ts +0 -105
  380. package/packages/dashboard-server/dist/metrics.js +0 -193
  381. package/packages/dashboard-server/dist/needs-attention.d.ts +0 -24
  382. package/packages/dashboard-server/dist/needs-attention.js +0 -78
  383. package/packages/dashboard-server/dist/server.d.ts +0 -25
  384. package/packages/dashboard-server/dist/server.js +0 -5158
  385. package/packages/dashboard-server/dist/start.d.ts +0 -6
  386. package/packages/dashboard-server/dist/start.js +0 -13
  387. package/packages/dashboard-server/dist/types/threading.d.ts +0 -8
  388. package/packages/dashboard-server/dist/types/threading.js +0 -2
  389. package/packages/dashboard-server/dist/user-bridge.d.ts +0 -158
  390. package/packages/dashboard-server/dist/user-bridge.js +0 -390
  391. package/packages/dashboard-server/package.json +0 -55
@@ -1,713 +0,0 @@
1
- /**
2
- * Agent Relay Cloud - Landing Page
3
- *
4
- * A mission-control themed landing page showcasing AI agent orchestration.
5
- * Features animated agent networks, live demo, and immersive visuals.
6
- */
7
-
8
- import React, { useState, useEffect, useRef } from 'react';
9
- import './styles.css';
10
- import { Logo, LogoIcon, LogoHero } from '../react-components/Logo';
11
-
12
- // Agent providers with their signature colors
13
- const PROVIDERS = {
14
- claude: { name: 'Claude', color: '#D97757', icon: '◈' },
15
- codex: { name: 'Codex', color: '#10A37F', icon: '⬡' },
16
- gemini: { name: 'Gemini', color: '#4285F4', icon: '◇' },
17
- opencode: { name: 'OpenCode', color: '#00D4AA', icon: '◆' },
18
- droid: { name: 'Droid', color: '#6366F1', icon: '⬢' },
19
- cursor: { name: 'Cursor', color: '#7C3AED', icon: '✎' },
20
- };
21
-
22
- // Simulated agent messages for the live demo
23
- const DEMO_MESSAGES = [
24
- { from: 'Architect', to: 'all', content: 'Starting auth module implementation. @Backend handle API, @Frontend build login UI.', provider: 'claude' },
25
- { from: 'Backend', to: 'Architect', content: 'Acknowledged. Setting up JWT middleware and user routes.', provider: 'codex' },
26
- { from: 'Frontend', to: 'Architect', content: 'On it. Creating login form with OAuth integration.', provider: 'claude' },
27
- { from: 'Backend', to: 'Frontend', content: 'API ready at /api/auth. Endpoints: POST /login, POST /register, GET /me', provider: 'codex' },
28
- { from: 'Frontend', to: 'Backend', content: 'Perfect. Integrating now. Need CORS headers for localhost:3000', provider: 'claude' },
29
- { from: 'Backend', to: 'Frontend', content: 'Done. CORS configured for development.', provider: 'codex' },
30
- { from: 'Reviewer', to: 'all', content: 'Running security audit on auth implementation...', provider: 'gemini' },
31
- { from: 'Reviewer', to: 'Backend', content: 'Found issue: password not being hashed. Use bcrypt.', provider: 'gemini' },
32
- { from: 'Backend', to: 'Reviewer', content: 'Good catch. Fixed and pushed. Using bcrypt with 12 rounds.', provider: 'codex' },
33
- { from: 'Architect', to: 'all', content: 'Auth module complete. Moving to dashboard implementation.', provider: 'claude' },
34
- ];
35
-
36
- export function LandingPage() {
37
- return (
38
- <div className="landing-page">
39
- <div className="landing-bg">
40
- <GridBackground />
41
- <GlowOrbs />
42
- </div>
43
-
44
- <Navigation />
45
-
46
- <main>
47
- <HeroSection />
48
- <LiveDemoSection />
49
- <FeaturesSection />
50
- <ProvidersSection />
51
- <PricingSection />
52
- <CTASection />
53
- </main>
54
-
55
- <Footer />
56
- </div>
57
- );
58
- }
59
-
60
- function Navigation() {
61
- const [scrolled, setScrolled] = useState(false);
62
- const [mobileMenuOpen, setMobileMenuOpen] = useState(false);
63
- const [isLoggedIn, setIsLoggedIn] = useState(false);
64
-
65
- useEffect(() => {
66
- const handleScroll = () => setScrolled(window.scrollY > 50);
67
- window.addEventListener('scroll', handleScroll);
68
- return () => window.removeEventListener('scroll', handleScroll);
69
- }, []);
70
-
71
- // Check if user is logged in
72
- useEffect(() => {
73
- async function checkAuth() {
74
- try {
75
- const response = await fetch('/api/auth/me', { credentials: 'include' });
76
- setIsLoggedIn(response.ok);
77
- } catch {
78
- setIsLoggedIn(false);
79
- }
80
- }
81
- checkAuth();
82
- }, []);
83
-
84
- // Close mobile menu on resize to desktop
85
- useEffect(() => {
86
- const handleResize = () => {
87
- if (window.innerWidth > 768) {
88
- setMobileMenuOpen(false);
89
- }
90
- };
91
- window.addEventListener('resize', handleResize);
92
- return () => window.removeEventListener('resize', handleResize);
93
- }, []);
94
-
95
- // Prevent body scroll when mobile menu is open
96
- useEffect(() => {
97
- if (mobileMenuOpen) {
98
- document.body.style.overflow = 'hidden';
99
- } else {
100
- document.body.style.overflow = '';
101
- }
102
- return () => {
103
- document.body.style.overflow = '';
104
- };
105
- }, [mobileMenuOpen]);
106
-
107
- const handleNavClick = () => {
108
- setMobileMenuOpen(false);
109
- };
110
-
111
- return (
112
- <nav className={`nav ${scrolled ? 'scrolled' : ''} ${mobileMenuOpen ? 'menu-open' : ''}`}>
113
- <div className="nav-inner">
114
- <a href="/" className="nav-logo">
115
- <LogoIcon size={28} withGlow={true} />
116
- <span className="logo-text">Agent Relay</span>
117
- </a>
118
-
119
- <div className="nav-links">
120
- <a href="#demo">Demo</a>
121
- <a href="#features">Features</a>
122
- <a href="#pricing">Pricing</a>
123
- <a href="/docs" className="nav-docs">Docs</a>
124
- </div>
125
-
126
- <div className="nav-actions">
127
- {isLoggedIn ? (
128
- <a href="/app" className="btn-primary">Go to App</a>
129
- ) : (
130
- <>
131
- <a href="/login" className="btn-ghost">Sign In</a>
132
- <a href="/signup" className="btn-primary">Get Started</a>
133
- </>
134
- )}
135
- </div>
136
-
137
- <button
138
- className="mobile-menu-toggle"
139
- onClick={() => setMobileMenuOpen(!mobileMenuOpen)}
140
- aria-label={mobileMenuOpen ? 'Close menu' : 'Open menu'}
141
- >
142
- <span className={`hamburger ${mobileMenuOpen ? 'open' : ''}`}>
143
- <span className="hamburger-line" />
144
- <span className="hamburger-line" />
145
- <span className="hamburger-line" />
146
- </span>
147
- </button>
148
- </div>
149
-
150
- {/* Mobile Menu Overlay */}
151
- <div className={`mobile-menu-overlay ${mobileMenuOpen ? 'open' : ''}`} onClick={handleNavClick} />
152
-
153
- {/* Mobile Menu */}
154
- <div className={`mobile-menu ${mobileMenuOpen ? 'open' : ''}`}>
155
- <div className="mobile-menu-content">
156
- <div className="mobile-nav-links">
157
- <a href="#demo" onClick={handleNavClick}>Demo</a>
158
- <a href="#features" onClick={handleNavClick}>Features</a>
159
- <a href="#pricing" onClick={handleNavClick}>Pricing</a>
160
- <a href="/docs" onClick={handleNavClick}>Documentation</a>
161
- </div>
162
- <div className="mobile-nav-actions">
163
- {isLoggedIn ? (
164
- <a href="/app" className="btn-primary btn-full" onClick={handleNavClick}>Go to App</a>
165
- ) : (
166
- <>
167
- <a href="/login" className="btn-ghost btn-full" onClick={handleNavClick}>Sign In</a>
168
- <a href="/signup" className="btn-primary btn-full" onClick={handleNavClick}>Get Started</a>
169
- </>
170
- )}
171
- </div>
172
- </div>
173
- </div>
174
- </nav>
175
- );
176
- }
177
-
178
- function HeroSection() {
179
- return (
180
- <section className="hero">
181
- <div className="hero-content">
182
- <div className="hero-badge">
183
- <span className="badge-dot" />
184
- <span>Now in Public Beta</span>
185
- </div>
186
-
187
- <h1 className="hero-title">
188
- <span className="title-line">Orchestrate AI Agents</span>
189
- <span className="title-line gradient">Like a Symphony</span>
190
- </h1>
191
-
192
- <p className="hero-subtitle">
193
- Deploy Claude, Codex, and Gemini agents that communicate in real-time.
194
- One dashboard to rule them all. Zero infrastructure headaches.
195
- </p>
196
-
197
- <div className="hero-cta">
198
- <a href="/signup" className="btn-primary btn-large">
199
- <span>Start Building</span>
200
- <span className="btn-arrow">→</span>
201
- </a>
202
- <a href="#demo" className="btn-ghost btn-large">
203
- <span className="play-icon">▶</span>
204
- <span>Watch Demo</span>
205
- </a>
206
- </div>
207
-
208
- <div className="hero-stats">
209
- <div className="stat">
210
- <span className="stat-value">10K+</span>
211
- <span className="stat-label">Agents Spawned</span>
212
- </div>
213
- <div className="stat-divider" />
214
- <div className="stat">
215
- <span className="stat-value">500+</span>
216
- <span className="stat-label">Teams</span>
217
- </div>
218
- <div className="stat-divider" />
219
- <div className="stat">
220
- <span className="stat-value">99.9%</span>
221
- <span className="stat-label">Uptime</span>
222
- </div>
223
- </div>
224
- </div>
225
-
226
- <div className="hero-visual">
227
- <AgentNetwork />
228
- </div>
229
- </section>
230
- );
231
- }
232
-
233
- function AgentNetwork() {
234
- const agents = [
235
- { id: 'lead', name: 'Lead', x: 50, y: 30, provider: 'claude', pulse: true },
236
- { id: 'backend', name: 'Backend', x: 25, y: 55, provider: 'codex', pulse: false },
237
- { id: 'frontend', name: 'Frontend', x: 75, y: 55, provider: 'claude', pulse: false },
238
- { id: 'reviewer', name: 'Reviewer', x: 50, y: 80, provider: 'gemini', pulse: false },
239
- ];
240
-
241
- const connections = [
242
- { from: 'lead', to: 'backend' },
243
- { from: 'lead', to: 'frontend' },
244
- { from: 'backend', to: 'frontend' },
245
- { from: 'backend', to: 'reviewer' },
246
- { from: 'frontend', to: 'reviewer' },
247
- ];
248
-
249
- return (
250
- <div className="agent-network">
251
- <svg className="network-lines" viewBox="0 0 100 100" preserveAspectRatio="none">
252
- {connections.map((conn, i) => {
253
- const fromAgent = agents.find((a) => a.id === conn.from)!;
254
- const toAgent = agents.find((a) => a.id === conn.to)!;
255
- return (
256
- <g key={i}>
257
- <line
258
- x1={fromAgent.x}
259
- y1={fromAgent.y}
260
- x2={toAgent.x}
261
- y2={toAgent.y}
262
- className="network-line"
263
- />
264
- <line
265
- x1={fromAgent.x}
266
- y1={fromAgent.y}
267
- x2={toAgent.x}
268
- y2={toAgent.y}
269
- className="network-line-glow"
270
- style={{ animationDelay: `${i * 0.3}s` }}
271
- />
272
- </g>
273
- );
274
- })}
275
- </svg>
276
-
277
- {agents.map((agent) => {
278
- const provider = PROVIDERS[agent.provider as keyof typeof PROVIDERS];
279
- return (
280
- <div
281
- key={agent.id}
282
- className={`network-agent ${agent.pulse ? 'pulse' : ''}`}
283
- style={{
284
- left: `${agent.x}%`,
285
- top: `${agent.y}%`,
286
- '--agent-color': provider.color,
287
- } as React.CSSProperties}
288
- >
289
- <div className="agent-glow" />
290
- <div className="agent-icon">{provider.icon}</div>
291
- <div className="agent-label">{agent.name}</div>
292
- </div>
293
- );
294
- })}
295
-
296
- <DataPacket fromX={50} fromY={30} toX={25} toY={55} delay={0} />
297
- <DataPacket fromX={25} fromY={55} toX={75} toY={55} delay={1} />
298
- <DataPacket fromX={75} fromY={55} toX={50} toY={80} delay={2} />
299
- </div>
300
- );
301
- }
302
-
303
- function DataPacket({ fromX, fromY, toX, toY, delay }: { fromX: number; fromY: number; toX: number; toY: number; delay: number }) {
304
- return (
305
- <div
306
- className="data-packet"
307
- style={{
308
- '--from-x': `${fromX}%`,
309
- '--from-y': `${fromY}%`,
310
- '--to-x': `${toX}%`,
311
- '--to-y': `${toY}%`,
312
- animationDelay: `${delay}s`,
313
- } as React.CSSProperties}
314
- />
315
- );
316
- }
317
-
318
- function LiveDemoSection() {
319
- const [messages, setMessages] = useState<typeof DEMO_MESSAGES>([]);
320
- const [currentIndex, setCurrentIndex] = useState(0);
321
- const messagesContainerRef = useRef<HTMLDivElement>(null);
322
-
323
- useEffect(() => {
324
- if (currentIndex >= DEMO_MESSAGES.length) {
325
- // Reset after a pause
326
- const timeout = setTimeout(() => {
327
- setMessages([]);
328
- setCurrentIndex(0);
329
- }, 3000);
330
- return () => clearTimeout(timeout);
331
- }
332
-
333
- const timeout = setTimeout(() => {
334
- setMessages((prev) => [...prev, DEMO_MESSAGES[currentIndex]]);
335
- setCurrentIndex((prev) => prev + 1);
336
- }, 1500);
337
-
338
- return () => clearTimeout(timeout);
339
- }, [currentIndex]);
340
-
341
- useEffect(() => {
342
- // Scroll within the container only, not the page
343
- const container = messagesContainerRef.current;
344
- if (container) {
345
- container.scrollTop = container.scrollHeight;
346
- }
347
- }, [messages]);
348
-
349
- return (
350
- <section id="demo" className="demo-section">
351
- <div className="section-header">
352
- <span className="section-tag">Live Demo</span>
353
- <h2>Watch Agents Collaborate</h2>
354
- <p>See how multiple AI agents work together on a real task in real-time.</p>
355
- </div>
356
-
357
- <div className="demo-container">
358
- <div className="demo-window">
359
- <div className="window-header">
360
- <div className="window-dots">
361
- <span className="dot red" />
362
- <span className="dot yellow" />
363
- <span className="dot green" />
364
- </div>
365
- <div className="window-title">Agent Relay — auth-module</div>
366
- <div className="window-status">
367
- <span className="status-dot" />
368
- <span>4 agents online</span>
369
- </div>
370
- </div>
371
-
372
- <div className="demo-content">
373
- <div className="demo-sidebar">
374
- <div className="sidebar-section">
375
- <div className="sidebar-label">AGENTS</div>
376
- {['Architect', 'Backend', 'Frontend', 'Reviewer'].map((name, i) => {
377
- const providers = ['claude', 'codex', 'claude', 'gemini'];
378
- const provider = PROVIDERS[providers[i] as keyof typeof PROVIDERS];
379
- return (
380
- <div key={name} className="sidebar-agent">
381
- <span className="agent-dot" style={{ background: provider.color }} />
382
- <span className="agent-name">{name}</span>
383
- <span className="agent-status">●</span>
384
- </div>
385
- );
386
- })}
387
- </div>
388
- </div>
389
-
390
- <div className="demo-messages" ref={messagesContainerRef}>
391
- {messages.map((msg, i) => {
392
- const provider = PROVIDERS[msg.provider as keyof typeof PROVIDERS];
393
- return (
394
- <div key={i} className="message" style={{ '--msg-color': provider.color } as React.CSSProperties}>
395
- <div className="message-header">
396
- <span className="message-icon" style={{ background: provider.color }}>{provider.icon}</span>
397
- <span className="message-from">{msg.from}</span>
398
- <span className="message-arrow">→</span>
399
- <span className="message-to">{msg.to === 'all' ? 'everyone' : msg.to}</span>
400
- <span className="message-time">just now</span>
401
- </div>
402
- <div className="message-content">{msg.content}</div>
403
- </div>
404
- );
405
- })}
406
-
407
- {messages.length < DEMO_MESSAGES.length && (
408
- <div className="typing-indicator">
409
- <span className="typing-dot" />
410
- <span className="typing-dot" />
411
- <span className="typing-dot" />
412
- </div>
413
- )}
414
- </div>
415
- </div>
416
- </div>
417
-
418
- <div className="demo-caption">
419
- <p>This is a simulation of agents completing a task. In production, agents run your actual code.</p>
420
- </div>
421
- </div>
422
- </section>
423
- );
424
- }
425
-
426
- function FeaturesSection() {
427
- const features = [
428
- {
429
- icon: '⚡',
430
- title: 'One-Click Workspaces',
431
- description: 'Spin up isolated environments for each project. Connect your repo and agents are ready in seconds.',
432
- },
433
- {
434
- icon: '🔄',
435
- title: 'Real-Time Messaging',
436
- description: 'Agents communicate through a blazing-fast relay. @mentions, broadcasts, and direct messages.',
437
- },
438
- {
439
- icon: '🔐',
440
- title: 'Secure Credential Vault',
441
- description: 'Store API keys and secrets encrypted at rest. Agents access only what they need.',
442
- },
443
- {
444
- icon: '🎯',
445
- title: 'Smart Orchestration',
446
- description: 'Lead agents delegate tasks. Workers report progress. The system handles the complexity.',
447
- },
448
- {
449
- icon: '📊',
450
- title: 'Full Observability',
451
- description: 'Trace every message, tool call, and decision. Replay and debug any session.',
452
- },
453
- {
454
- icon: '🚀',
455
- title: 'Auto-Scaling',
456
- description: 'From 1 agent to 100. Pay only for what you use. Scale down to zero when idle.',
457
- },
458
- ];
459
-
460
- return (
461
- <section id="features" className="features-section">
462
- <div className="section-header">
463
- <span className="section-tag">Features</span>
464
- <h2>Everything You Need</h2>
465
- <p>Built for developers who want AI agents that actually work together.</p>
466
- </div>
467
-
468
- <div className="features-grid">
469
- {features.map((feature, i) => (
470
- <div key={i} className="feature-card" style={{ animationDelay: `${i * 0.1}s` }}>
471
- <div className="feature-icon">{feature.icon}</div>
472
- <h3>{feature.title}</h3>
473
- <p>{feature.description}</p>
474
- </div>
475
- ))}
476
- </div>
477
- </section>
478
- );
479
- }
480
-
481
- function ProvidersSection() {
482
- return (
483
- <section className="providers-section">
484
- <div className="section-header">
485
- <span className="section-tag">Providers</span>
486
- <h2>Bring Your Own Agents</h2>
487
- <p>Use any AI provider. Mix and match for the perfect team.</p>
488
- </div>
489
-
490
- <div className="providers-grid">
491
- {Object.entries(PROVIDERS).map(([key, provider]) => (
492
- <div key={key} className="provider-card" style={{ '--provider-color': provider.color } as React.CSSProperties}>
493
- <div className="provider-icon">{provider.icon}</div>
494
- <div className="provider-name">{provider.name}</div>
495
- <div className="provider-status">Supported</div>
496
- </div>
497
- ))}
498
- </div>
499
- </section>
500
- );
501
- }
502
-
503
- function PricingSection() {
504
- const plans = [
505
- {
506
- name: 'Free',
507
- price: '$0',
508
- period: 'forever',
509
- description: 'Try AI agent workflows',
510
- features: ['1 workspace', '2 repositories', '2 concurrent agents', '5 compute hours/month', 'Shared CPU', 'Community support'],
511
- cta: 'Get Started',
512
- highlighted: false,
513
- },
514
- {
515
- name: 'Pro',
516
- price: '$69',
517
- period: '/month',
518
- description: 'For professional developers',
519
- features: ['5 workspaces', '10 repositories', '5 concurrent agents', '50 compute hours/month', 'Auto-scaling', 'Session persistence', 'Email support'],
520
- cta: 'Start Free Trial',
521
- highlighted: true,
522
- },
523
- {
524
- name: 'Team',
525
- price: '$129',
526
- period: '/month',
527
- description: 'For growing teams',
528
- features: ['20 workspaces', '100 repositories', '50 concurrent agents', '500 compute hours/month', 'Dedicated CPU', 'Priority support', 'Audit logs'],
529
- cta: 'Start Free Trial',
530
- highlighted: false,
531
- },
532
- {
533
- name: 'Enterprise',
534
- price: '$499',
535
- period: '/month',
536
- description: 'For organizations at scale',
537
- features: ['Unlimited workspaces', 'Unlimited repositories', 'Unlimited agents', 'Unlimited compute', 'SSO/SAML', 'SLA guarantee', 'Dedicated support'],
538
- cta: 'Contact Sales',
539
- highlighted: false,
540
- },
541
- ];
542
-
543
- return (
544
- <section id="pricing" className="pricing-section">
545
- <div className="section-header">
546
- <span className="section-tag">Pricing</span>
547
- <h2>Simple, Transparent Pricing</h2>
548
- <p>Start free. Scale as you grow. No hidden fees.</p>
549
- </div>
550
-
551
- <div className="pricing-grid">
552
- {plans.map((plan, i) => (
553
- <div key={i} className={`pricing-card ${plan.highlighted ? 'highlighted' : ''}`}>
554
- {plan.highlighted && <div className="popular-badge">Most Popular</div>}
555
- <div className="pricing-header">
556
- <h3>{plan.name}</h3>
557
- <div className="pricing-price">
558
- <span className="price">{plan.price}</span>
559
- <span className="period">{plan.period}</span>
560
- </div>
561
- <p className="pricing-description">{plan.description}</p>
562
- </div>
563
- <ul className="pricing-features">
564
- {plan.features.map((feature, j) => (
565
- <li key={j}>
566
- <span className="check">✓</span>
567
- <span>{feature}</span>
568
- </li>
569
- ))}
570
- </ul>
571
- <a href="/signup" className={`btn-${plan.highlighted ? 'primary' : 'ghost'} btn-full`}>
572
- {plan.cta}
573
- </a>
574
- </div>
575
- ))}
576
- </div>
577
- </section>
578
- );
579
- }
580
-
581
- function CTASection() {
582
- return (
583
- <section className="cta-section">
584
- <div className="cta-content">
585
- <h2>Ready to Orchestrate?</h2>
586
- <p>Join thousands of developers building with AI agent teams.</p>
587
- <div className="cta-buttons">
588
- <a href="/signup" className="btn-primary btn-large">
589
- <span>Start Building Free</span>
590
- <span className="btn-arrow">→</span>
591
- </a>
592
- <a href="/docs" className="btn-ghost btn-large">Read the Docs</a>
593
- </div>
594
- </div>
595
-
596
- <div className="cta-terminal">
597
- <div className="terminal-header">
598
- <span className="terminal-prompt">$</span>
599
- <span className="terminal-text">agent-relay cloud link</span>
600
- </div>
601
- <div className="terminal-output">
602
- <span className="output-line">✓ Machine linked to Agent Relay Cloud</span>
603
- <span className="output-line">✓ Syncing with workspace: my-project</span>
604
- <span className="output-line">✓ 3 agents online: Lead, Backend, Frontend</span>
605
- <span className="output-line"></span>
606
- <span className="output-line dim">$ agent-relay cloud send Lead &quot;Start the auth module&quot;</span>
607
- <span className="output-line cursor">✓ Message sent to Lead on cloud-workspace</span>
608
- </div>
609
- </div>
610
- </section>
611
- );
612
- }
613
-
614
- function Footer() {
615
- return (
616
- <footer className="footer">
617
- <div className="footer-inner">
618
- <div className="footer-brand">
619
- <a href="/" className="footer-logo">
620
- <LogoIcon size={24} withGlow={true} />
621
- <span className="logo-text">Agent Relay</span>
622
- </a>
623
- <p>Orchestrate AI agents like a symphony.</p>
624
- </div>
625
-
626
- <div className="footer-links">
627
- <div className="footer-column">
628
- <h4>Product</h4>
629
- <a href="#features">Features</a>
630
- <a href="#pricing">Pricing</a>
631
- <a href="/docs">Documentation</a>
632
- <a href="/changelog">Changelog</a>
633
- </div>
634
- <div className="footer-column">
635
- <h4>Company</h4>
636
- <a href="/about">About</a>
637
- <a href="/blog">Blog</a>
638
- <a href="/careers">Careers</a>
639
- <a href="/contact">Contact</a>
640
- </div>
641
- <div className="footer-column">
642
- <h4>Legal</h4>
643
- <a href="/privacy">Privacy</a>
644
- <a href="/terms">Terms</a>
645
- <a href="/security">Security</a>
646
- </div>
647
- </div>
648
- </div>
649
-
650
- <div className="footer-bottom">
651
- <p>© 2026 Agent Relay. All rights reserved.</p>
652
- <div className="social-links">
653
- <a href="https://github.com/AgentWorkforce/relay" aria-label="GitHub">
654
- <GitHubIcon />
655
- </a>
656
- <a href="https://twitter.com/agent_relay" aria-label="Twitter">
657
- <TwitterIcon />
658
- </a>
659
- <a href="https://discord.gg/agentrelay" aria-label="Discord">
660
- <DiscordIcon />
661
- </a>
662
- </div>
663
- </div>
664
- </footer>
665
- );
666
- }
667
-
668
- // Background components
669
- function GridBackground() {
670
- return (
671
- <div className="grid-bg">
672
- <div className="grid-lines" />
673
- <div className="grid-glow" />
674
- </div>
675
- );
676
- }
677
-
678
- function GlowOrbs() {
679
- return (
680
- <div className="glow-orbs">
681
- <div className="orb orb-1" />
682
- <div className="orb orb-2" />
683
- <div className="orb orb-3" />
684
- </div>
685
- );
686
- }
687
-
688
- // Icons
689
- function GitHubIcon() {
690
- return (
691
- <svg width="20" height="20" viewBox="0 0 24 24" fill="currentColor">
692
- <path d="M12 0C5.37 0 0 5.37 0 12c0 5.31 3.435 9.795 8.205 11.385.6.105.825-.255.825-.57 0-.285-.015-1.23-.015-2.235-3.015.555-3.795-.735-4.035-1.41-.135-.345-.72-1.41-1.23-1.695-.42-.225-1.02-.78-.015-.795.945-.015 1.62.87 1.845 1.23 1.08 1.815 2.805 1.305 3.495.99.105-.78.42-1.305.765-1.605-2.67-.3-5.46-1.335-5.46-5.925 0-1.305.465-2.385 1.23-3.225-.12-.3-.54-1.53.12-3.18 0 0 1.005-.315 3.3 1.23.96-.27 1.98-.405 3-.405s2.04.135 3 .405c2.295-1.56 3.3-1.23 3.3-1.23.66 1.65.24 2.88.12 3.18.765.84 1.23 1.905 1.23 3.225 0 4.605-2.805 5.625-5.475 5.925.435.375.81 1.095.81 2.22 0 1.605-.015 2.895-.015 3.3 0 .315.225.69.825.57A12.02 12.02 0 0024 12c0-6.63-5.37-12-12-12z" />
693
- </svg>
694
- );
695
- }
696
-
697
- function TwitterIcon() {
698
- return (
699
- <svg width="20" height="20" viewBox="0 0 24 24" fill="currentColor">
700
- <path d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z" />
701
- </svg>
702
- );
703
- }
704
-
705
- function DiscordIcon() {
706
- return (
707
- <svg width="20" height="20" viewBox="0 0 24 24" fill="currentColor">
708
- <path d="M20.317 4.37a19.791 19.791 0 00-4.885-1.515.074.074 0 00-.079.037c-.21.375-.444.864-.608 1.25a18.27 18.27 0 00-5.487 0 12.64 12.64 0 00-.617-1.25.077.077 0 00-.079-.037A19.736 19.736 0 003.677 4.37a.07.07 0 00-.032.027C.533 9.046-.32 13.58.099 18.057a.082.082 0 00.031.057 19.9 19.9 0 005.993 3.03.078.078 0 00.084-.028c.462-.63.874-1.295 1.226-1.994a.076.076 0 00-.041-.106 13.107 13.107 0 01-1.872-.892.077.077 0 01-.008-.128 10.2 10.2 0 00.372-.292.074.074 0 01.077-.01c3.928 1.793 8.18 1.793 12.062 0a.074.074 0 01.078.01c.12.098.246.198.373.292a.077.077 0 01-.006.127 12.299 12.299 0 01-1.873.892.077.077 0 00-.041.107c.36.698.772 1.362 1.225 1.993a.076.076 0 00.084.028 19.839 19.839 0 006.002-3.03.077.077 0 00.032-.054c.5-5.177-.838-9.674-3.549-13.66a.061.061 0 00-.031-.03zM8.02 15.33c-1.183 0-2.157-1.085-2.157-2.419 0-1.333.956-2.419 2.157-2.419 1.21 0 2.176 1.096 2.157 2.42 0 1.333-.956 2.418-2.157 2.418zm7.975 0c-1.183 0-2.157-1.085-2.157-2.419 0-1.333.955-2.419 2.157-2.419 1.21 0 2.176 1.096 2.157 2.42 0 1.333-.946 2.418-2.157 2.418z" />
709
- </svg>
710
- );
711
- }
712
-
713
- export default LandingPage;