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,463 +0,0 @@
1
- /**
2
- * ChannelMessageList Component
3
- *
4
- * Displays messages in a channel with:
5
- * - Unread separator
6
- * - Date dividers
7
- * - Auto-scroll to new messages
8
- * - Infinite scroll for history
9
- */
10
-
11
- import React, { useRef, useEffect, useCallback, useState, useMemo } from 'react';
12
- import type { ChannelMessage, ChannelMessageListProps, UnreadState } from './types';
13
- import { formatMessageBody } from '../utils/messageFormatting';
14
-
15
- export function ChannelMessageList({
16
- messages,
17
- unreadState,
18
- currentUser,
19
- isLoadingMore = false,
20
- hasMore = false,
21
- onLoadMore,
22
- onThreadClick,
23
- onMemberClick,
24
- }: ChannelMessageListProps) {
25
- const containerRef = useRef<HTMLDivElement>(null);
26
- const bottomRef = useRef<HTMLDivElement>(null);
27
- const [isNearBottom, setIsNearBottom] = useState(true);
28
- const [showScrollToBottom, setShowScrollToBottom] = useState(false);
29
-
30
- // Group messages by date
31
- const groupedMessages = useMemo(() => {
32
- const groups: { date: string; messages: ChannelMessage[] }[] = [];
33
- let currentDate = '';
34
-
35
- messages.forEach(message => {
36
- const messageDate = formatDateKey(message.timestamp);
37
- if (messageDate !== currentDate) {
38
- currentDate = messageDate;
39
- groups.push({ date: messageDate, messages: [message] });
40
- } else {
41
- groups[groups.length - 1].messages.push(message);
42
- }
43
- });
44
-
45
- return groups;
46
- }, [messages]);
47
-
48
- // Handle scroll events
49
- const handleScroll = useCallback(() => {
50
- const container = containerRef.current;
51
- if (!container) return;
52
-
53
- const { scrollTop, scrollHeight, clientHeight } = container;
54
- const distanceFromBottom = scrollHeight - scrollTop - clientHeight;
55
- const nearBottom = distanceFromBottom < 100;
56
-
57
- setIsNearBottom(nearBottom);
58
- setShowScrollToBottom(!nearBottom && distanceFromBottom > 500);
59
-
60
- // Load more when scrolling near top
61
- if (scrollTop < 100 && hasMore && !isLoadingMore && onLoadMore) {
62
- onLoadMore();
63
- }
64
- }, [hasMore, isLoadingMore, onLoadMore]);
65
-
66
- // Scroll to bottom when new messages arrive (if near bottom)
67
- useEffect(() => {
68
- if (isNearBottom && bottomRef.current) {
69
- bottomRef.current.scrollIntoView({ behavior: 'smooth' });
70
- }
71
- }, [messages.length, isNearBottom]);
72
-
73
- // Initial scroll to bottom
74
- useEffect(() => {
75
- if (bottomRef.current) {
76
- bottomRef.current.scrollIntoView();
77
- }
78
- }, []);
79
-
80
- const scrollToBottom = useCallback(() => {
81
- bottomRef.current?.scrollIntoView({ behavior: 'smooth' });
82
- }, []);
83
-
84
- return (
85
- <div className="relative flex-1 overflow-hidden">
86
- <div
87
- ref={containerRef}
88
- onScroll={handleScroll}
89
- className="h-full overflow-y-auto px-4 py-2"
90
- >
91
- {/* Loading more indicator */}
92
- {isLoadingMore && (
93
- <div className="flex justify-center py-4">
94
- <LoadingSpinner />
95
- </div>
96
- )}
97
-
98
- {/* Load more button */}
99
- {hasMore && !isLoadingMore && (
100
- <div className="flex justify-center py-4">
101
- <button
102
- onClick={onLoadMore}
103
- className="text-sm text-accent-cyan hover:underline"
104
- >
105
- Load earlier messages
106
- </button>
107
- </div>
108
- )}
109
-
110
- {/* Empty state */}
111
- {messages.length === 0 && !isLoadingMore && (
112
- <div className="flex flex-col items-center justify-center h-full text-center py-12">
113
- <div className="text-4xl mb-3">
114
- <MessageIcon className="w-12 h-12 text-text-muted" />
115
- </div>
116
- <h3 className="text-lg font-medium text-text-primary mb-1">
117
- No messages yet
118
- </h3>
119
- <p className="text-sm text-text-muted">
120
- Be the first to send a message in this channel
121
- </p>
122
- </div>
123
- )}
124
-
125
- {/* Message groups */}
126
- {groupedMessages.map(({ date, messages: dateMessages }) => (
127
- <div key={date}>
128
- {/* Date divider */}
129
- <DateDivider date={date} />
130
-
131
- {/* Messages for this date */}
132
- {dateMessages.map((message, index) => {
133
- const isFirstUnread = unreadState?.firstUnreadMessageId === message.id;
134
- const showUnreadSeparator = isFirstUnread && unreadState && unreadState.count > 0;
135
-
136
- return (
137
- <React.Fragment key={message.id}>
138
- {/* Unread separator */}
139
- {showUnreadSeparator && (
140
- <UnreadSeparator count={unreadState.count} />
141
- )}
142
-
143
- {/* Message */}
144
- <MessageItem
145
- message={message}
146
- isOwn={message.from === currentUser}
147
- onThreadClick={onThreadClick}
148
- onMemberClick={onMemberClick}
149
- showAvatar={shouldShowAvatar(dateMessages, index)}
150
- />
151
- </React.Fragment>
152
- );
153
- })}
154
- </div>
155
- ))}
156
-
157
- {/* Scroll anchor */}
158
- <div ref={bottomRef} />
159
- </div>
160
-
161
- {/* Scroll to bottom button */}
162
- {showScrollToBottom && (
163
- <button
164
- onClick={scrollToBottom}
165
- className="absolute bottom-4 right-4 p-3 bg-bg-elevated border border-border-subtle rounded-full shadow-lg hover:bg-bg-hover transition-colors"
166
- title="Scroll to bottom"
167
- >
168
- <ChevronDownIcon className="w-5 h-5 text-text-primary" />
169
- </button>
170
- )}
171
- </div>
172
- );
173
- }
174
-
175
- // =============================================================================
176
- // Sub-components
177
- // =============================================================================
178
-
179
- interface MessageItemProps {
180
- message: ChannelMessage;
181
- isOwn: boolean;
182
- onThreadClick?: (messageId: string) => void;
183
- onMemberClick?: (memberId: string, entityType: 'user' | 'agent') => void;
184
- showAvatar: boolean;
185
- }
186
-
187
- function MessageItem({
188
- message,
189
- isOwn,
190
- onThreadClick,
191
- onMemberClick,
192
- showAvatar,
193
- }: MessageItemProps) {
194
- const hasThread = message.threadSummary && message.threadSummary.replyCount > 0;
195
-
196
- return (
197
- <div className={`group relative py-1 ${showAvatar ? 'mt-3' : ''}`}>
198
- <div className="flex gap-3">
199
- {/* Avatar column */}
200
- <div className="w-9 flex-shrink-0">
201
- {showAvatar && (
202
- <Avatar
203
- name={message.from}
204
- avatarUrl={message.fromAvatarUrl}
205
- entityType={message.fromEntityType}
206
- />
207
- )}
208
- </div>
209
-
210
- {/* Content column */}
211
- <div className="flex-1 min-w-0">
212
- {/* Header (only show with avatar) */}
213
- {showAvatar && (
214
- <div className="flex items-center gap-2 mb-0.5">
215
- <button
216
- type="button"
217
- onClick={() => {
218
- if (!isOwn && onMemberClick) {
219
- onMemberClick(message.from, message.fromEntityType || 'agent');
220
- }
221
- }}
222
- disabled={isOwn || !onMemberClick}
223
- className={`text-sm font-semibold ${
224
- isOwn ? 'text-accent-cyan cursor-default' : 'text-text-primary hover:underline cursor-pointer'
225
- } disabled:cursor-default disabled:hover:no-underline`}
226
- >
227
- {message.from}
228
- </button>
229
- <span className="text-xs text-text-muted">
230
- {formatTime(message.timestamp)}
231
- </span>
232
- {message.editedAt && (
233
- <span className="text-xs text-text-muted">(edited)</span>
234
- )}
235
-
236
- {/* Thread button */}
237
- <button
238
- className={`
239
- inline-flex items-center gap-1.5 p-1.5 rounded-lg transition-all duration-150 cursor-pointer border-none
240
- ${hasThread || message.threadId
241
- ? 'text-accent-cyan bg-accent-cyan/10 hover:bg-accent-cyan/20'
242
- : 'text-text-muted bg-transparent opacity-0 group-hover:opacity-100 hover:text-accent-cyan hover:bg-accent-cyan/10'}
243
- `}
244
- onClick={() => onThreadClick?.(message.threadId || message.id)}
245
- title={message.threadId ? `View thread` : (hasThread ? `${message.threadSummary!.replyCount} ${message.threadSummary!.replyCount === 1 ? 'reply' : 'replies'}` : 'Reply in thread')}
246
- >
247
- <ThreadIcon className="w-3.5 h-3.5" />
248
- {hasThread && (
249
- <span className="text-xs font-medium">{message.threadSummary!.replyCount}</span>
250
- )}
251
- </button>
252
- </div>
253
- )}
254
-
255
- {/* Message content */}
256
- <div className="text-sm text-text-primary whitespace-pre-wrap break-words">
257
- {formatMessageBody(message.content, { mentions: message.mentions })}
258
- </div>
259
-
260
- {/* Attachments */}
261
- {message.attachments && message.attachments.length > 0 && (
262
- <div className="mt-2 flex flex-wrap gap-2">
263
- {message.attachments.map(attachment => (
264
- <AttachmentPreview key={attachment.id} attachment={attachment} />
265
- ))}
266
- </div>
267
- )}
268
- </div>
269
- </div>
270
- </div>
271
- );
272
- }
273
-
274
- function Avatar({
275
- name,
276
- avatarUrl,
277
- entityType,
278
- }: {
279
- name: string;
280
- avatarUrl?: string;
281
- entityType: 'agent' | 'user';
282
- }) {
283
- if (avatarUrl) {
284
- return (
285
- <img
286
- src={avatarUrl}
287
- alt={name}
288
- className="w-9 h-9 rounded-full object-cover"
289
- />
290
- );
291
- }
292
-
293
- return (
294
- <div className={`
295
- w-9 h-9 rounded-full flex items-center justify-center text-sm font-medium
296
- ${entityType === 'user'
297
- ? 'bg-purple-500/30 text-purple-300'
298
- : 'bg-accent-cyan/30 text-accent-cyan'}
299
- `}>
300
- {name.charAt(0).toUpperCase()}
301
- </div>
302
- );
303
- }
304
-
305
- function AttachmentPreview({ attachment }: { attachment: NonNullable<ChannelMessage['attachments']>[0] }) {
306
- const isImage = attachment.mimeType.startsWith('image/');
307
-
308
- if (isImage) {
309
- return (
310
- <a
311
- href={attachment.url}
312
- target="_blank"
313
- rel="noopener noreferrer"
314
- className="block max-w-xs rounded-lg overflow-hidden border border-border-subtle hover:border-accent-cyan/30 transition-colors"
315
- >
316
- <img
317
- src={attachment.thumbnailUrl || attachment.url}
318
- alt={attachment.filename}
319
- className="max-w-full max-h-48 object-cover"
320
- />
321
- </a>
322
- );
323
- }
324
-
325
- return (
326
- <a
327
- href={attachment.url}
328
- target="_blank"
329
- rel="noopener noreferrer"
330
- className="flex items-center gap-2 px-3 py-2 bg-bg-tertiary rounded-lg border border-border-subtle hover:border-accent-cyan/30 transition-colors"
331
- >
332
- <FileIcon className="w-5 h-5 text-text-muted" />
333
- <div className="min-w-0">
334
- <p className="text-sm text-text-primary truncate">{attachment.filename}</p>
335
- <p className="text-xs text-text-muted">{formatFileSize(attachment.size)}</p>
336
- </div>
337
- </a>
338
- );
339
- }
340
-
341
- function DateDivider({ date }: { date: string }) {
342
- return (
343
- <div className="flex items-center gap-3 py-3">
344
- <div className="flex-1 h-px bg-border-subtle" />
345
- <span className="text-xs font-medium text-text-muted px-2">
346
- {formatDateDisplay(date)}
347
- </span>
348
- <div className="flex-1 h-px bg-border-subtle" />
349
- </div>
350
- );
351
- }
352
-
353
- function UnreadSeparator({ count }: { count: number }) {
354
- return (
355
- <div className="flex items-center gap-3 py-2 my-2">
356
- <div className="flex-1 h-px bg-red-500/50" />
357
- <span className="text-xs font-semibold text-red-400 px-2 flex items-center gap-1">
358
- <span className="w-2 h-2 bg-red-500 rounded-full" />
359
- {count} new {count === 1 ? 'message' : 'messages'}
360
- </span>
361
- <div className="flex-1 h-px bg-red-500/50" />
362
- </div>
363
- );
364
- }
365
-
366
- function LoadingSpinner() {
367
- return (
368
- <div className="w-5 h-5 border-2 border-accent-cyan/30 border-t-accent-cyan rounded-full animate-spin" />
369
- );
370
- }
371
-
372
- // =============================================================================
373
- // Helper functions
374
- // =============================================================================
375
-
376
- function shouldShowAvatar(messages: ChannelMessage[], index: number): boolean {
377
- if (index === 0) return true;
378
- const current = messages[index];
379
- const previous = messages[index - 1];
380
-
381
- // Show avatar if different sender
382
- if (current.from !== previous.from) return true;
383
-
384
- // Show avatar if more than 5 minutes since last message
385
- const currentTime = new Date(current.timestamp).getTime();
386
- const previousTime = new Date(previous.timestamp).getTime();
387
- return currentTime - previousTime > 5 * 60 * 1000;
388
- }
389
-
390
- function formatDateKey(isoString: string): string {
391
- return new Date(isoString).toDateString();
392
- }
393
-
394
- function formatDateDisplay(dateKey: string): string {
395
- const date = new Date(dateKey);
396
- const today = new Date();
397
- const yesterday = new Date(today);
398
- yesterday.setDate(yesterday.getDate() - 1);
399
-
400
- if (date.toDateString() === today.toDateString()) {
401
- return 'Today';
402
- }
403
- if (date.toDateString() === yesterday.toDateString()) {
404
- return 'Yesterday';
405
- }
406
- return date.toLocaleDateString(undefined, {
407
- weekday: 'long',
408
- month: 'long',
409
- day: 'numeric',
410
- });
411
- }
412
-
413
- function formatTime(isoString: string): string {
414
- return new Date(isoString).toLocaleTimeString(undefined, {
415
- hour: '2-digit',
416
- minute: '2-digit',
417
- });
418
- }
419
-
420
- function formatFileSize(bytes: number): string {
421
- if (bytes < 1024) return `${bytes} B`;
422
- if (bytes < 1024 * 1024) return `${(bytes / 1024).toFixed(1)} KB`;
423
- return `${(bytes / (1024 * 1024)).toFixed(1)} MB`;
424
- }
425
-
426
- // =============================================================================
427
- // Icons
428
- // =============================================================================
429
-
430
- function MessageIcon({ className }: { className?: string }) {
431
- return (
432
- <svg className={className} viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="1.5" strokeLinecap="round" strokeLinejoin="round">
433
- <path d="M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z" />
434
- </svg>
435
- );
436
- }
437
-
438
- function ThreadIcon({ className }: { className?: string }) {
439
- return (
440
- <svg className={className} viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="2" strokeLinecap="round" strokeLinejoin="round">
441
- <path d="M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z" />
442
- </svg>
443
- );
444
- }
445
-
446
- function ChevronDownIcon({ className }: { className?: string }) {
447
- return (
448
- <svg className={className} viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="2" strokeLinecap="round" strokeLinejoin="round">
449
- <polyline points="6 9 12 15 18 9" />
450
- </svg>
451
- );
452
- }
453
-
454
- function FileIcon({ className }: { className?: string }) {
455
- return (
456
- <svg className={className} viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="2" strokeLinecap="round" strokeLinejoin="round">
457
- <path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z" />
458
- <polyline points="14 2 14 8 20 8" />
459
- </svg>
460
- );
461
- }
462
-
463
- export default ChannelMessageList;
@@ -1,146 +0,0 @@
1
- /**
2
- * ChannelViewV1 Component
3
- *
4
- * Composed channel view that combines:
5
- * - ChannelHeader
6
- * - ChannelMessageList
7
- * - MessageInput
8
- *
9
- * This is the main view component for displaying a channel's content.
10
- */
11
-
12
- import React, { useCallback, useMemo } from 'react';
13
- import { ChannelHeader } from './ChannelHeader';
14
- import { ChannelMessageList } from './ChannelMessageList';
15
- import { MessageInput } from './MessageInput';
16
- import type {
17
- Channel,
18
- ChannelMember,
19
- ChannelMessage,
20
- UnreadState,
21
- } from './types';
22
-
23
- export interface ChannelViewV1Props {
24
- /** Current channel to display */
25
- channel: Channel;
26
- /** Channel members */
27
- members?: ChannelMember[];
28
- /** Messages in the channel */
29
- messages: ChannelMessage[];
30
- /** Unread state for the channel */
31
- unreadState?: UnreadState;
32
- /** Current user's name */
33
- currentUser: string;
34
- /** Whether user can edit the channel */
35
- canEditChannel?: boolean;
36
- /** Whether loading more messages */
37
- isLoadingMore?: boolean;
38
- /** Whether there are more messages to load */
39
- hasMoreMessages?: boolean;
40
- /** Available users/agents for @-mentions */
41
- mentionSuggestions?: string[];
42
- /** Callback to load more messages */
43
- onLoadMore?: () => void;
44
- /** Callback to send a message */
45
- onSendMessage: (content: string) => void;
46
- /** Callback when editing channel settings */
47
- onEditChannel?: () => void;
48
- /** Callback to show member list */
49
- onShowMembers?: () => void;
50
- /** Callback to show pinned messages */
51
- onShowPinned?: () => void;
52
- /** Callback to search in channel */
53
- onSearch?: () => void;
54
- /** Callback when clicking thread button */
55
- onThreadClick?: (messageId: string) => void;
56
- /** Callback when typing status changes */
57
- onTyping?: (isTyping: boolean) => void;
58
- /** Callback to mark messages as read */
59
- onMarkRead?: (upToTimestamp: string) => void;
60
- /** Callback when clicking on a member name (for DM navigation) */
61
- onMemberClick?: (memberId: string, entityType: 'user' | 'agent') => void;
62
- }
63
-
64
- export function ChannelViewV1({
65
- channel,
66
- members = [],
67
- messages,
68
- unreadState,
69
- currentUser,
70
- canEditChannel = false,
71
- isLoadingMore = false,
72
- hasMoreMessages = false,
73
- mentionSuggestions = [],
74
- onLoadMore,
75
- onSendMessage,
76
- onEditChannel,
77
- onShowMembers,
78
- onShowPinned,
79
- onSearch,
80
- onThreadClick,
81
- onTyping,
82
- onMarkRead,
83
- onMemberClick,
84
- }: ChannelViewV1Props) {
85
- // Handle send
86
- const handleSend = useCallback((content: string) => {
87
- onSendMessage(content);
88
- }, [onSendMessage]);
89
-
90
- // Get placeholder text based on channel type
91
- const inputPlaceholder = useMemo(() => {
92
- if (channel.isDm) {
93
- return `Message ${channel.name}`;
94
- }
95
- return `Message #${channel.name}`;
96
- }, [channel]);
97
-
98
- // Check if channel is archived (disable input)
99
- const isArchived = channel.status === 'archived';
100
-
101
- return (
102
- <div className="flex flex-col h-full bg-bg-primary">
103
- {/* Header */}
104
- <ChannelHeader
105
- channel={channel}
106
- members={members}
107
- canEdit={canEditChannel}
108
- onEditChannel={onEditChannel}
109
- onShowMembers={onShowMembers}
110
- onShowPinned={onShowPinned}
111
- onSearch={onSearch}
112
- />
113
-
114
- {/* Message List */}
115
- <ChannelMessageList
116
- messages={messages}
117
- unreadState={unreadState}
118
- currentUser={currentUser}
119
- isLoadingMore={isLoadingMore}
120
- hasMore={hasMoreMessages}
121
- onLoadMore={onLoadMore}
122
- onThreadClick={onThreadClick}
123
- onMemberClick={onMemberClick}
124
- />
125
-
126
- {/* Message Input */}
127
- {isArchived ? (
128
- <div className="px-4 py-3 bg-bg-secondary border-t border-border-subtle text-center">
129
- <p className="text-sm text-text-muted">
130
- This channel is archived. Unarchive it to send messages.
131
- </p>
132
- </div>
133
- ) : (
134
- <MessageInput
135
- channelId={channel.id}
136
- placeholder={inputPlaceholder}
137
- onSend={handleSend}
138
- onTyping={onTyping}
139
- mentionSuggestions={mentionSuggestions}
140
- />
141
- )}
142
- </div>
143
- );
144
- }
145
-
146
- export default ChannelViewV1;