@elizaos/app-core 2.0.0-alpha.37

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 (1082) hide show
  1. package/.turbo/turbo-build.log +2 -0
  2. package/LICENSE +21 -0
  3. package/dist/App.d.ts +5 -0
  4. package/dist/App.d.ts.map +1 -0
  5. package/dist/App.js +198 -0
  6. package/dist/actions/character.d.ts +27 -0
  7. package/dist/actions/character.d.ts.map +1 -0
  8. package/dist/actions/character.js +97 -0
  9. package/dist/actions/chat-helpers.d.ts +47 -0
  10. package/dist/actions/chat-helpers.d.ts.map +1 -0
  11. package/dist/actions/chat-helpers.js +79 -0
  12. package/dist/actions/cloud.d.ts +17 -0
  13. package/dist/actions/cloud.d.ts.map +1 -0
  14. package/dist/actions/cloud.js +43 -0
  15. package/dist/actions/index.d.ts +12 -0
  16. package/dist/actions/index.d.ts.map +1 -0
  17. package/dist/actions/index.js +11 -0
  18. package/dist/actions/lifecycle.d.ts +43 -0
  19. package/dist/actions/lifecycle.d.ts.map +1 -0
  20. package/dist/actions/lifecycle.js +118 -0
  21. package/dist/actions/onboarding.d.ts +12 -0
  22. package/dist/actions/onboarding.d.ts.map +1 -0
  23. package/dist/actions/onboarding.js +28 -0
  24. package/dist/actions/triggers.d.ts +23 -0
  25. package/dist/actions/triggers.d.ts.map +1 -0
  26. package/dist/actions/triggers.js +148 -0
  27. package/dist/api/client.d.ts +2823 -0
  28. package/dist/api/client.d.ts.map +1 -0
  29. package/dist/api/client.js +2392 -0
  30. package/dist/api/index.d.ts +2 -0
  31. package/dist/api/index.d.ts.map +1 -0
  32. package/dist/api/index.js +1 -0
  33. package/dist/autonomy/index.d.ts +48 -0
  34. package/dist/autonomy/index.d.ts.map +1 -0
  35. package/dist/autonomy/index.js +330 -0
  36. package/dist/bridge/capacitor-bridge.d.ts +153 -0
  37. package/dist/bridge/capacitor-bridge.d.ts.map +1 -0
  38. package/dist/bridge/capacitor-bridge.js +193 -0
  39. package/dist/bridge/electrobun-rpc.d.ts +19 -0
  40. package/dist/bridge/electrobun-rpc.d.ts.map +1 -0
  41. package/dist/bridge/electrobun-rpc.js +27 -0
  42. package/dist/bridge/electrobun-runtime.d.ts +3 -0
  43. package/dist/bridge/electrobun-runtime.d.ts.map +1 -0
  44. package/dist/bridge/electrobun-runtime.js +17 -0
  45. package/dist/bridge/index.d.ts +6 -0
  46. package/dist/bridge/index.d.ts.map +1 -0
  47. package/dist/bridge/index.js +5 -0
  48. package/dist/bridge/native-plugins.d.ts +82 -0
  49. package/dist/bridge/native-plugins.d.ts.map +1 -0
  50. package/dist/bridge/native-plugins.js +39 -0
  51. package/dist/bridge/plugin-bridge.d.ts +116 -0
  52. package/dist/bridge/plugin-bridge.d.ts.map +1 -0
  53. package/dist/bridge/plugin-bridge.js +203 -0
  54. package/dist/bridge/storage-bridge.d.ts +39 -0
  55. package/dist/bridge/storage-bridge.d.ts.map +1 -0
  56. package/dist/bridge/storage-bridge.js +135 -0
  57. package/dist/chat/index.d.ts +57 -0
  58. package/dist/chat/index.d.ts.map +1 -0
  59. package/dist/chat/index.js +161 -0
  60. package/dist/coding/index.d.ts +25 -0
  61. package/dist/coding/index.d.ts.map +1 -0
  62. package/dist/coding/index.js +25 -0
  63. package/dist/components/AdvancedPageView.d.ts +17 -0
  64. package/dist/components/AdvancedPageView.d.ts.map +1 -0
  65. package/dist/components/AdvancedPageView.js +137 -0
  66. package/dist/components/AgentActivityBox.d.ts +7 -0
  67. package/dist/components/AgentActivityBox.d.ts.map +1 -0
  68. package/dist/components/AgentActivityBox.js +25 -0
  69. package/dist/components/ApiKeyConfig.d.ts +26 -0
  70. package/dist/components/ApiKeyConfig.d.ts.map +1 -0
  71. package/dist/components/ApiKeyConfig.js +121 -0
  72. package/dist/components/AppsPageView.d.ts +7 -0
  73. package/dist/components/AppsPageView.d.ts.map +1 -0
  74. package/dist/components/AppsPageView.js +31 -0
  75. package/dist/components/AppsView.d.ts +8 -0
  76. package/dist/components/AppsView.d.ts.map +1 -0
  77. package/dist/components/AppsView.js +149 -0
  78. package/dist/components/AvatarLoader.d.ts +9 -0
  79. package/dist/components/AvatarLoader.d.ts.map +1 -0
  80. package/dist/components/AvatarLoader.js +45 -0
  81. package/dist/components/AvatarSelector.d.ts +23 -0
  82. package/dist/components/AvatarSelector.d.ts.map +1 -0
  83. package/dist/components/AvatarSelector.js +105 -0
  84. package/dist/components/BscTradePanel.d.ts +22 -0
  85. package/dist/components/BscTradePanel.d.ts.map +1 -0
  86. package/dist/components/BscTradePanel.js +221 -0
  87. package/dist/components/BugReportModal.d.ts +2 -0
  88. package/dist/components/BugReportModal.d.ts.map +1 -0
  89. package/dist/components/BugReportModal.js +218 -0
  90. package/dist/components/CharacterView.d.ts +8 -0
  91. package/dist/components/CharacterView.d.ts.map +1 -0
  92. package/dist/components/CharacterView.js +703 -0
  93. package/dist/components/ChatAvatar.d.ts +8 -0
  94. package/dist/components/ChatAvatar.d.ts.map +1 -0
  95. package/dist/components/ChatAvatar.js +89 -0
  96. package/dist/components/ChatComposer.d.ts +37 -0
  97. package/dist/components/ChatComposer.d.ts.map +1 -0
  98. package/dist/components/ChatComposer.js +136 -0
  99. package/dist/components/ChatMessage.d.ts +24 -0
  100. package/dist/components/ChatMessage.d.ts.map +1 -0
  101. package/dist/components/ChatMessage.js +167 -0
  102. package/dist/components/ChatModalView.d.ts +10 -0
  103. package/dist/components/ChatModalView.d.ts.map +1 -0
  104. package/dist/components/ChatModalView.js +57 -0
  105. package/dist/components/ChatView.d.ts +14 -0
  106. package/dist/components/ChatView.d.ts.map +1 -0
  107. package/dist/components/ChatView.js +511 -0
  108. package/dist/components/CloudSourceControls.d.ts +13 -0
  109. package/dist/components/CloudSourceControls.d.ts.map +1 -0
  110. package/dist/components/CloudSourceControls.js +14 -0
  111. package/dist/components/CodingAgentSettingsSection.d.ts +2 -0
  112. package/dist/components/CodingAgentSettingsSection.d.ts.map +1 -0
  113. package/dist/components/CodingAgentSettingsSection.js +268 -0
  114. package/dist/components/CommandPalette.d.ts +2 -0
  115. package/dist/components/CommandPalette.d.ts.map +1 -0
  116. package/dist/components/CommandPalette.js +181 -0
  117. package/dist/components/CompanionSceneHost.d.ts +15 -0
  118. package/dist/components/CompanionSceneHost.d.ts.map +1 -0
  119. package/dist/components/CompanionSceneHost.js +343 -0
  120. package/dist/components/CompanionShell.d.ts +17 -0
  121. package/dist/components/CompanionShell.d.ts.map +1 -0
  122. package/dist/components/CompanionShell.js +15 -0
  123. package/dist/components/CompanionView.d.ts +2 -0
  124. package/dist/components/CompanionView.d.ts.map +1 -0
  125. package/dist/components/CompanionView.js +22 -0
  126. package/dist/components/ConfigPageView.d.ts +11 -0
  127. package/dist/components/ConfigPageView.d.ts.map +1 -0
  128. package/dist/components/ConfigPageView.js +275 -0
  129. package/dist/components/ConfigSaveFooter.d.ts +8 -0
  130. package/dist/components/ConfigSaveFooter.d.ts.map +1 -0
  131. package/dist/components/ConfigSaveFooter.js +10 -0
  132. package/dist/components/ConfirmModal.d.ts +61 -0
  133. package/dist/components/ConfirmModal.d.ts.map +1 -0
  134. package/dist/components/ConfirmModal.js +164 -0
  135. package/dist/components/ConnectionFailedBanner.d.ts +6 -0
  136. package/dist/components/ConnectionFailedBanner.d.ts.map +1 -0
  137. package/dist/components/ConnectionFailedBanner.js +22 -0
  138. package/dist/components/ConnectorsPageView.d.ts +7 -0
  139. package/dist/components/ConnectorsPageView.d.ts.map +1 -0
  140. package/dist/components/ConnectorsPageView.js +8 -0
  141. package/dist/components/ConversationsSidebar.d.ts +9 -0
  142. package/dist/components/ConversationsSidebar.d.ts.map +1 -0
  143. package/dist/components/ConversationsSidebar.js +116 -0
  144. package/dist/components/CustomActionEditor.d.ts +10 -0
  145. package/dist/components/CustomActionEditor.d.ts.map +1 -0
  146. package/dist/components/CustomActionEditor.js +578 -0
  147. package/dist/components/CustomActionsPanel.d.ts +9 -0
  148. package/dist/components/CustomActionsPanel.d.ts.map +1 -0
  149. package/dist/components/CustomActionsPanel.js +107 -0
  150. package/dist/components/CustomActionsView.d.ts +2 -0
  151. package/dist/components/CustomActionsView.d.ts.map +1 -0
  152. package/dist/components/CustomActionsView.js +134 -0
  153. package/dist/components/DatabasePageView.d.ts +5 -0
  154. package/dist/components/DatabasePageView.d.ts.map +1 -0
  155. package/dist/components/DatabasePageView.js +28 -0
  156. package/dist/components/DatabaseView.d.ts +9 -0
  157. package/dist/components/DatabaseView.d.ts.map +1 -0
  158. package/dist/components/DatabaseView.js +311 -0
  159. package/dist/components/ElizaCloudDashboard.d.ts +2 -0
  160. package/dist/components/ElizaCloudDashboard.d.ts.map +1 -0
  161. package/dist/components/ElizaCloudDashboard.js +657 -0
  162. package/dist/components/EmotePicker.d.ts +2 -0
  163. package/dist/components/EmotePicker.d.ts.map +1 -0
  164. package/dist/components/EmotePicker.js +343 -0
  165. package/dist/components/ErrorBoundary.d.ts +22 -0
  166. package/dist/components/ErrorBoundary.d.ts.map +1 -0
  167. package/dist/components/ErrorBoundary.js +31 -0
  168. package/dist/components/FineTuningView.d.ts +2 -0
  169. package/dist/components/FineTuningView.d.ts.map +1 -0
  170. package/dist/components/FineTuningView.js +433 -0
  171. package/dist/components/GameView.d.ts +11 -0
  172. package/dist/components/GameView.d.ts.map +1 -0
  173. package/dist/components/GameView.js +295 -0
  174. package/dist/components/GameViewOverlay.d.ts +8 -0
  175. package/dist/components/GameViewOverlay.d.ts.map +1 -0
  176. package/dist/components/GameViewOverlay.js +70 -0
  177. package/dist/components/GlobalEmoteOverlay.d.ts +2 -0
  178. package/dist/components/GlobalEmoteOverlay.d.ts.map +1 -0
  179. package/dist/components/GlobalEmoteOverlay.js +112 -0
  180. package/dist/components/Header.d.ts +8 -0
  181. package/dist/components/Header.d.ts.map +1 -0
  182. package/dist/components/Header.js +121 -0
  183. package/dist/components/HeartbeatsView.d.ts +2 -0
  184. package/dist/components/HeartbeatsView.d.ts.map +1 -0
  185. package/dist/components/HeartbeatsView.js +378 -0
  186. package/dist/components/InventoryView.d.ts +10 -0
  187. package/dist/components/InventoryView.d.ts.map +1 -0
  188. package/dist/components/InventoryView.js +162 -0
  189. package/dist/components/KnowledgeView.d.ts +20 -0
  190. package/dist/components/KnowledgeView.d.ts.map +1 -0
  191. package/dist/components/KnowledgeView.js +480 -0
  192. package/dist/components/LanguageDropdown.d.ts +30 -0
  193. package/dist/components/LanguageDropdown.d.ts.map +1 -0
  194. package/dist/components/LanguageDropdown.js +98 -0
  195. package/dist/components/LifoMonitorPanel.d.ts +21 -0
  196. package/dist/components/LifoMonitorPanel.d.ts.map +1 -0
  197. package/dist/components/LifoMonitorPanel.js +24 -0
  198. package/dist/components/LifoSandboxView.d.ts +5 -0
  199. package/dist/components/LifoSandboxView.d.ts.map +1 -0
  200. package/dist/components/LifoSandboxView.js +333 -0
  201. package/dist/components/LoadingScreen.d.ts +13 -0
  202. package/dist/components/LoadingScreen.d.ts.map +1 -0
  203. package/dist/components/LoadingScreen.js +39 -0
  204. package/dist/components/LogsPageView.d.ts +2 -0
  205. package/dist/components/LogsPageView.d.ts.map +1 -0
  206. package/dist/components/LogsPageView.js +7 -0
  207. package/dist/components/LogsView.d.ts +5 -0
  208. package/dist/components/LogsView.d.ts.map +1 -0
  209. package/dist/components/LogsView.js +71 -0
  210. package/dist/components/MediaGalleryView.d.ts +9 -0
  211. package/dist/components/MediaGalleryView.d.ts.map +1 -0
  212. package/dist/components/MediaGalleryView.js +236 -0
  213. package/dist/components/MediaSettingsSection.d.ts +11 -0
  214. package/dist/components/MediaSettingsSection.d.ts.map +1 -0
  215. package/dist/components/MediaSettingsSection.js +329 -0
  216. package/dist/components/MessageContent.d.ts +51 -0
  217. package/dist/components/MessageContent.d.ts.map +1 -0
  218. package/dist/components/MessageContent.js +553 -0
  219. package/dist/components/OnboardingWizard.d.ts +2 -0
  220. package/dist/components/OnboardingWizard.d.ts.map +1 -0
  221. package/dist/components/OnboardingWizard.js +59 -0
  222. package/dist/components/PairingView.d.ts +5 -0
  223. package/dist/components/PairingView.d.ts.map +1 -0
  224. package/dist/components/PairingView.js +28 -0
  225. package/dist/components/PermissionsSection.d.ts +20 -0
  226. package/dist/components/PermissionsSection.d.ts.map +1 -0
  227. package/dist/components/PermissionsSection.js +368 -0
  228. package/dist/components/PluginsPageView.d.ts +5 -0
  229. package/dist/components/PluginsPageView.d.ts.map +1 -0
  230. package/dist/components/PluginsPageView.js +8 -0
  231. package/dist/components/PluginsView.d.ts +21 -0
  232. package/dist/components/PluginsView.d.ts.map +1 -0
  233. package/dist/components/PluginsView.js +1531 -0
  234. package/dist/components/ProviderSwitcher.d.ts +42 -0
  235. package/dist/components/ProviderSwitcher.d.ts.map +1 -0
  236. package/dist/components/ProviderSwitcher.js +480 -0
  237. package/dist/components/RestartBanner.d.ts +2 -0
  238. package/dist/components/RestartBanner.d.ts.map +1 -0
  239. package/dist/components/RestartBanner.js +36 -0
  240. package/dist/components/RuntimeView.d.ts +10 -0
  241. package/dist/components/RuntimeView.d.ts.map +1 -0
  242. package/dist/components/RuntimeView.js +165 -0
  243. package/dist/components/SaveCommandModal.d.ts +12 -0
  244. package/dist/components/SaveCommandModal.d.ts.map +1 -0
  245. package/dist/components/SaveCommandModal.js +84 -0
  246. package/dist/components/SecretsView.d.ts +9 -0
  247. package/dist/components/SecretsView.d.ts.map +1 -0
  248. package/dist/components/SecretsView.js +249 -0
  249. package/dist/components/SettingsView.d.ts +9 -0
  250. package/dist/components/SettingsView.d.ts.map +1 -0
  251. package/dist/components/SettingsView.js +230 -0
  252. package/dist/components/ShellOverlays.d.ts +8 -0
  253. package/dist/components/ShellOverlays.d.ts.map +1 -0
  254. package/dist/components/ShellOverlays.js +10 -0
  255. package/dist/components/ShortcutsOverlay.d.ts +2 -0
  256. package/dist/components/ShortcutsOverlay.d.ts.map +1 -0
  257. package/dist/components/ShortcutsOverlay.js +79 -0
  258. package/dist/components/SkillsView.d.ts +11 -0
  259. package/dist/components/SkillsView.d.ts.map +1 -0
  260. package/dist/components/SkillsView.js +358 -0
  261. package/dist/components/StartupFailureView.d.ts +8 -0
  262. package/dist/components/StartupFailureView.d.ts.map +1 -0
  263. package/dist/components/StartupFailureView.js +15 -0
  264. package/dist/components/StreamView.d.ts +16 -0
  265. package/dist/components/StreamView.d.ts.map +1 -0
  266. package/dist/components/StreamView.js +300 -0
  267. package/dist/components/StripeEmbeddedCheckout.d.ts +24 -0
  268. package/dist/components/StripeEmbeddedCheckout.d.ts.map +1 -0
  269. package/dist/components/StripeEmbeddedCheckout.js +101 -0
  270. package/dist/components/SubscriptionStatus.d.ts +22 -0
  271. package/dist/components/SubscriptionStatus.d.ts.map +1 -0
  272. package/dist/components/SubscriptionStatus.js +301 -0
  273. package/dist/components/SystemWarningBanner.d.ts +6 -0
  274. package/dist/components/SystemWarningBanner.d.ts.map +1 -0
  275. package/dist/components/SystemWarningBanner.js +46 -0
  276. package/dist/components/ThemeToggle.d.ts +21 -0
  277. package/dist/components/ThemeToggle.d.ts.map +1 -0
  278. package/dist/components/ThemeToggle.js +24 -0
  279. package/dist/components/TrajectoriesView.d.ts +12 -0
  280. package/dist/components/TrajectoriesView.d.ts.map +1 -0
  281. package/dist/components/TrajectoriesView.js +183 -0
  282. package/dist/components/TrajectoryDetailView.d.ts +13 -0
  283. package/dist/components/TrajectoryDetailView.d.ts.map +1 -0
  284. package/dist/components/TrajectoryDetailView.js +112 -0
  285. package/dist/components/TriggersView.d.ts +2 -0
  286. package/dist/components/TriggersView.d.ts.map +1 -0
  287. package/dist/components/TriggersView.js +1 -0
  288. package/dist/components/VectorBrowserView.d.ts +10 -0
  289. package/dist/components/VectorBrowserView.d.ts.map +1 -0
  290. package/dist/components/VectorBrowserView.js +997 -0
  291. package/dist/components/VoiceConfigView.d.ts +11 -0
  292. package/dist/components/VoiceConfigView.d.ts.map +1 -0
  293. package/dist/components/VoiceConfigView.js +329 -0
  294. package/dist/components/VrmStage.d.ts +21 -0
  295. package/dist/components/VrmStage.d.ts.map +1 -0
  296. package/dist/components/VrmStage.js +252 -0
  297. package/dist/components/WhatsAppQrOverlay.d.ts +8 -0
  298. package/dist/components/WhatsAppQrOverlay.d.ts.map +1 -0
  299. package/dist/components/WhatsAppQrOverlay.js +63 -0
  300. package/dist/components/apps/AppDetailPane.d.ts +15 -0
  301. package/dist/components/apps/AppDetailPane.d.ts.map +1 -0
  302. package/dist/components/apps/AppDetailPane.js +13 -0
  303. package/dist/components/apps/AppsCatalogGrid.d.ts +20 -0
  304. package/dist/components/apps/AppsCatalogGrid.d.ts.map +1 -0
  305. package/dist/components/apps/AppsCatalogGrid.js +18 -0
  306. package/dist/components/apps/extensions/HyperscapeAppDetailPanel.d.ts +3 -0
  307. package/dist/components/apps/extensions/HyperscapeAppDetailPanel.d.ts.map +1 -0
  308. package/dist/components/apps/extensions/HyperscapeAppDetailPanel.js +253 -0
  309. package/dist/components/apps/extensions/registry.d.ts +4 -0
  310. package/dist/components/apps/extensions/registry.d.ts.map +1 -0
  311. package/dist/components/apps/extensions/registry.js +10 -0
  312. package/dist/components/apps/extensions/types.d.ts +7 -0
  313. package/dist/components/apps/extensions/types.d.ts.map +1 -0
  314. package/dist/components/apps/extensions/types.js +1 -0
  315. package/dist/components/apps/helpers.d.ts +7 -0
  316. package/dist/components/apps/helpers.d.ts.map +1 -0
  317. package/dist/components/apps/helpers.js +46 -0
  318. package/dist/components/avatar/VrmAnimationLoader.d.ts +30 -0
  319. package/dist/components/avatar/VrmAnimationLoader.d.ts.map +1 -0
  320. package/dist/components/avatar/VrmAnimationLoader.js +99 -0
  321. package/dist/components/avatar/VrmBlinkController.d.ts +37 -0
  322. package/dist/components/avatar/VrmBlinkController.d.ts.map +1 -0
  323. package/dist/components/avatar/VrmBlinkController.js +98 -0
  324. package/dist/components/avatar/VrmCameraManager.d.ts +57 -0
  325. package/dist/components/avatar/VrmCameraManager.d.ts.map +1 -0
  326. package/dist/components/avatar/VrmCameraManager.js +277 -0
  327. package/dist/components/avatar/VrmEngine.d.ts +229 -0
  328. package/dist/components/avatar/VrmEngine.d.ts.map +1 -0
  329. package/dist/components/avatar/VrmEngine.js +1950 -0
  330. package/dist/components/avatar/VrmFootShadow.d.ts +18 -0
  331. package/dist/components/avatar/VrmFootShadow.d.ts.map +1 -0
  332. package/dist/components/avatar/VrmFootShadow.js +83 -0
  333. package/dist/components/avatar/VrmViewer.d.ts +45 -0
  334. package/dist/components/avatar/VrmViewer.d.ts.map +1 -0
  335. package/dist/components/avatar/VrmViewer.js +341 -0
  336. package/dist/components/avatar/mixamoVRMRigMap.d.ts +3 -0
  337. package/dist/components/avatar/mixamoVRMRigMap.d.ts.map +1 -0
  338. package/dist/components/avatar/mixamoVRMRigMap.js +56 -0
  339. package/dist/components/avatar/retargetMixamoFbxToVrm.d.ts +9 -0
  340. package/dist/components/avatar/retargetMixamoFbxToVrm.d.ts.map +1 -0
  341. package/dist/components/avatar/retargetMixamoFbxToVrm.js +88 -0
  342. package/dist/components/avatar/retargetMixamoGltfToVrm.d.ts +11 -0
  343. package/dist/components/avatar/retargetMixamoGltfToVrm.d.ts.map +1 -0
  344. package/dist/components/avatar/retargetMixamoGltfToVrm.js +80 -0
  345. package/dist/components/chainConfig.d.ts +84 -0
  346. package/dist/components/chainConfig.d.ts.map +1 -0
  347. package/dist/components/chainConfig.js +268 -0
  348. package/dist/components/companion/CompanionHeader.d.ts +15 -0
  349. package/dist/components/companion/CompanionHeader.d.ts.map +1 -0
  350. package/dist/components/companion/CompanionHeader.js +7 -0
  351. package/dist/components/companion/CompanionSceneHost.d.ts +2 -0
  352. package/dist/components/companion/CompanionSceneHost.d.ts.map +1 -0
  353. package/dist/components/companion/CompanionSceneHost.js +1 -0
  354. package/dist/components/companion/VrmStage.d.ts +3 -0
  355. package/dist/components/companion/VrmStage.d.ts.map +1 -0
  356. package/dist/components/companion/VrmStage.js +1 -0
  357. package/dist/components/companion/walletUtils.d.ts +95 -0
  358. package/dist/components/companion/walletUtils.d.ts.map +1 -0
  359. package/dist/components/companion/walletUtils.js +167 -0
  360. package/dist/components/companion-shell-styles.d.ts +38 -0
  361. package/dist/components/companion-shell-styles.d.ts.map +1 -0
  362. package/dist/components/companion-shell-styles.js +248 -0
  363. package/dist/components/confirm-delete-control.d.ts +16 -0
  364. package/dist/components/confirm-delete-control.d.ts.map +1 -0
  365. package/dist/components/confirm-delete-control.js +12 -0
  366. package/dist/components/conversations/ConversationListItem.d.ts +31 -0
  367. package/dist/components/conversations/ConversationListItem.d.ts.map +1 -0
  368. package/dist/components/conversations/ConversationListItem.js +52 -0
  369. package/dist/components/conversations/conversation-utils.d.ts +9 -0
  370. package/dist/components/conversations/conversation-utils.d.ts.map +1 -0
  371. package/dist/components/conversations/conversation-utils.js +138 -0
  372. package/dist/components/format.d.ts +54 -0
  373. package/dist/components/format.d.ts.map +1 -0
  374. package/dist/components/format.js +82 -0
  375. package/dist/components/index.d.ts +93 -0
  376. package/dist/components/index.d.ts.map +1 -0
  377. package/dist/components/index.js +92 -0
  378. package/dist/components/inventory/CopyableAddress.d.ts +8 -0
  379. package/dist/components/inventory/CopyableAddress.d.ts.map +1 -0
  380. package/dist/components/inventory/CopyableAddress.js +18 -0
  381. package/dist/components/inventory/InventoryToolbar.d.ts +25 -0
  382. package/dist/components/inventory/InventoryToolbar.d.ts.map +1 -0
  383. package/dist/components/inventory/InventoryToolbar.js +28 -0
  384. package/dist/components/inventory/NftGrid.d.ts +13 -0
  385. package/dist/components/inventory/NftGrid.d.ts.map +1 -0
  386. package/dist/components/inventory/NftGrid.js +29 -0
  387. package/dist/components/inventory/TokenLogo.d.ts +12 -0
  388. package/dist/components/inventory/TokenLogo.d.ts.map +1 -0
  389. package/dist/components/inventory/TokenLogo.js +33 -0
  390. package/dist/components/inventory/TokensTable.d.ts +24 -0
  391. package/dist/components/inventory/TokensTable.d.ts.map +1 -0
  392. package/dist/components/inventory/TokensTable.js +26 -0
  393. package/dist/components/inventory/constants.d.ts +52 -0
  394. package/dist/components/inventory/constants.d.ts.map +1 -0
  395. package/dist/components/inventory/constants.js +121 -0
  396. package/dist/components/inventory/index.d.ts +9 -0
  397. package/dist/components/inventory/index.d.ts.map +1 -0
  398. package/dist/components/inventory/index.js +8 -0
  399. package/dist/components/inventory/media-url.d.ts +6 -0
  400. package/dist/components/inventory/media-url.d.ts.map +1 -0
  401. package/dist/components/inventory/media-url.js +28 -0
  402. package/dist/components/inventory/useInventoryData.d.ts +53 -0
  403. package/dist/components/inventory/useInventoryData.d.ts.map +1 -0
  404. package/dist/components/inventory/useInventoryData.js +332 -0
  405. package/dist/components/knowledge-upload-image.d.ts +27 -0
  406. package/dist/components/knowledge-upload-image.d.ts.map +1 -0
  407. package/dist/components/knowledge-upload-image.js +146 -0
  408. package/dist/components/labels.d.ts +6 -0
  409. package/dist/components/labels.d.ts.map +1 -0
  410. package/dist/components/labels.js +40 -0
  411. package/dist/components/onboarding/ActivateStep.d.ts +2 -0
  412. package/dist/components/onboarding/ActivateStep.d.ts.map +1 -0
  413. package/dist/components/onboarding/ActivateStep.js +6 -0
  414. package/dist/components/onboarding/ConnectionStep.d.ts +2 -0
  415. package/dist/components/onboarding/ConnectionStep.d.ts.map +1 -0
  416. package/dist/components/onboarding/ConnectionStep.js +552 -0
  417. package/dist/components/onboarding/OnboardingPanel.d.ts +9 -0
  418. package/dist/components/onboarding/OnboardingPanel.d.ts.map +1 -0
  419. package/dist/components/onboarding/OnboardingPanel.js +24 -0
  420. package/dist/components/onboarding/OnboardingStepNav.d.ts +2 -0
  421. package/dist/components/onboarding/OnboardingStepNav.d.ts.map +1 -0
  422. package/dist/components/onboarding/OnboardingStepNav.js +14 -0
  423. package/dist/components/onboarding/PermissionsStep.d.ts +2 -0
  424. package/dist/components/onboarding/PermissionsStep.d.ts.map +1 -0
  425. package/dist/components/onboarding/PermissionsStep.js +7 -0
  426. package/dist/components/onboarding/RpcStep.d.ts +2 -0
  427. package/dist/components/onboarding/RpcStep.d.ts.map +1 -0
  428. package/dist/components/onboarding/RpcStep.js +125 -0
  429. package/dist/components/onboarding/WakeUpStep.d.ts +2 -0
  430. package/dist/components/onboarding/WakeUpStep.d.ts.map +1 -0
  431. package/dist/components/onboarding/WakeUpStep.js +82 -0
  432. package/dist/components/permissions/PermissionIcon.d.ts +4 -0
  433. package/dist/components/permissions/PermissionIcon.d.ts.map +1 -0
  434. package/dist/components/permissions/PermissionIcon.js +12 -0
  435. package/dist/components/permissions/StreamingPermissions.d.ts +20 -0
  436. package/dist/components/permissions/StreamingPermissions.d.ts.map +1 -0
  437. package/dist/components/permissions/StreamingPermissions.js +173 -0
  438. package/dist/components/plugins/showcase-data.d.ts +7 -0
  439. package/dist/components/plugins/showcase-data.d.ts.map +1 -0
  440. package/dist/components/plugins/showcase-data.js +464 -0
  441. package/dist/components/shared/ShellHeaderControls.d.ts +27 -0
  442. package/dist/components/shared/ShellHeaderControls.d.ts.map +1 -0
  443. package/dist/components/shared/ShellHeaderControls.js +60 -0
  444. package/dist/components/skeletons.d.ts +17 -0
  445. package/dist/components/skeletons.d.ts.map +1 -0
  446. package/dist/components/skeletons.js +22 -0
  447. package/dist/components/stream/ActivityFeed.d.ts +5 -0
  448. package/dist/components/stream/ActivityFeed.d.ts.map +1 -0
  449. package/dist/components/stream/ActivityFeed.js +57 -0
  450. package/dist/components/stream/AvatarPip.d.ts +5 -0
  451. package/dist/components/stream/AvatarPip.d.ts.map +1 -0
  452. package/dist/components/stream/AvatarPip.js +6 -0
  453. package/dist/components/stream/ChatContent.d.ts +6 -0
  454. package/dist/components/stream/ChatContent.d.ts.map +1 -0
  455. package/dist/components/stream/ChatContent.js +69 -0
  456. package/dist/components/stream/ChatTicker.d.ts +5 -0
  457. package/dist/components/stream/ChatTicker.d.ts.map +1 -0
  458. package/dist/components/stream/ChatTicker.js +34 -0
  459. package/dist/components/stream/IdleContent.d.ts +5 -0
  460. package/dist/components/stream/IdleContent.d.ts.map +1 -0
  461. package/dist/components/stream/IdleContent.js +17 -0
  462. package/dist/components/stream/StatusBar.d.ts +36 -0
  463. package/dist/components/stream/StatusBar.d.ts.map +1 -0
  464. package/dist/components/stream/StatusBar.js +140 -0
  465. package/dist/components/stream/StreamSettings.d.ts +33 -0
  466. package/dist/components/stream/StreamSettings.d.ts.map +1 -0
  467. package/dist/components/stream/StreamSettings.js +99 -0
  468. package/dist/components/stream/StreamTerminal.d.ts +2 -0
  469. package/dist/components/stream/StreamTerminal.d.ts.map +1 -0
  470. package/dist/components/stream/StreamTerminal.js +52 -0
  471. package/dist/components/stream/StreamVoiceConfig.d.ts +10 -0
  472. package/dist/components/stream/StreamVoiceConfig.d.ts.map +1 -0
  473. package/dist/components/stream/StreamVoiceConfig.js +88 -0
  474. package/dist/components/stream/helpers.d.ts +32 -0
  475. package/dist/components/stream/helpers.d.ts.map +1 -0
  476. package/dist/components/stream/helpers.js +110 -0
  477. package/dist/components/stream/overlays/OverlayLayer.d.ts +20 -0
  478. package/dist/components/stream/overlays/OverlayLayer.d.ts.map +1 -0
  479. package/dist/components/stream/overlays/OverlayLayer.js +24 -0
  480. package/dist/components/stream/overlays/built-in/ActionTickerWidget.d.ts +8 -0
  481. package/dist/components/stream/overlays/built-in/ActionTickerWidget.d.ts.map +1 -0
  482. package/dist/components/stream/overlays/built-in/ActionTickerWidget.js +44 -0
  483. package/dist/components/stream/overlays/built-in/AlertPopupWidget.d.ts +7 -0
  484. package/dist/components/stream/overlays/built-in/AlertPopupWidget.d.ts.map +1 -0
  485. package/dist/components/stream/overlays/built-in/AlertPopupWidget.js +62 -0
  486. package/dist/components/stream/overlays/built-in/BrandingWidget.d.ts +7 -0
  487. package/dist/components/stream/overlays/built-in/BrandingWidget.d.ts.map +1 -0
  488. package/dist/components/stream/overlays/built-in/BrandingWidget.js +36 -0
  489. package/dist/components/stream/overlays/built-in/CustomHtmlWidget.d.ts +26 -0
  490. package/dist/components/stream/overlays/built-in/CustomHtmlWidget.d.ts.map +1 -0
  491. package/dist/components/stream/overlays/built-in/CustomHtmlWidget.js +78 -0
  492. package/dist/components/stream/overlays/built-in/PeonGlassWidget.d.ts +11 -0
  493. package/dist/components/stream/overlays/built-in/PeonGlassWidget.d.ts.map +1 -0
  494. package/dist/components/stream/overlays/built-in/PeonGlassWidget.js +188 -0
  495. package/dist/components/stream/overlays/built-in/PeonHudWidget.d.ts +10 -0
  496. package/dist/components/stream/overlays/built-in/PeonHudWidget.d.ts.map +1 -0
  497. package/dist/components/stream/overlays/built-in/PeonHudWidget.js +168 -0
  498. package/dist/components/stream/overlays/built-in/PeonSakuraWidget.d.ts +11 -0
  499. package/dist/components/stream/overlays/built-in/PeonSakuraWidget.d.ts.map +1 -0
  500. package/dist/components/stream/overlays/built-in/PeonSakuraWidget.js +213 -0
  501. package/dist/components/stream/overlays/built-in/ThoughtBubbleWidget.d.ts +8 -0
  502. package/dist/components/stream/overlays/built-in/ThoughtBubbleWidget.d.ts.map +1 -0
  503. package/dist/components/stream/overlays/built-in/ThoughtBubbleWidget.js +59 -0
  504. package/dist/components/stream/overlays/built-in/ViewerCountWidget.d.ts +7 -0
  505. package/dist/components/stream/overlays/built-in/ViewerCountWidget.d.ts.map +1 -0
  506. package/dist/components/stream/overlays/built-in/ViewerCountWidget.js +34 -0
  507. package/dist/components/stream/overlays/built-in/index.d.ts +13 -0
  508. package/dist/components/stream/overlays/built-in/index.d.ts.map +1 -0
  509. package/dist/components/stream/overlays/built-in/index.js +12 -0
  510. package/dist/components/stream/overlays/registry.d.ts +11 -0
  511. package/dist/components/stream/overlays/registry.d.ts.map +1 -0
  512. package/dist/components/stream/overlays/registry.js +16 -0
  513. package/dist/components/stream/overlays/types.d.ts +67 -0
  514. package/dist/components/stream/overlays/types.d.ts.map +1 -0
  515. package/dist/components/stream/overlays/types.js +7 -0
  516. package/dist/components/stream/overlays/useOverlayLayout.d.ts +27 -0
  517. package/dist/components/stream/overlays/useOverlayLayout.d.ts.map +1 -0
  518. package/dist/components/stream/overlays/useOverlayLayout.js +162 -0
  519. package/dist/components/trajectory-format.d.ts +6 -0
  520. package/dist/components/trajectory-format.d.ts.map +1 -0
  521. package/dist/components/trajectory-format.js +43 -0
  522. package/dist/components/ui-badges.d.ts +23 -0
  523. package/dist/components/ui-badges.d.ts.map +1 -0
  524. package/dist/components/ui-badges.js +38 -0
  525. package/dist/components/ui-switch.d.ts +14 -0
  526. package/dist/components/ui-switch.d.ts.map +1 -0
  527. package/dist/components/ui-switch.js +15 -0
  528. package/dist/components/vector-browser-three.d.ts +4 -0
  529. package/dist/components/vector-browser-three.d.ts.map +1 -0
  530. package/dist/components/vector-browser-three.js +19 -0
  531. package/dist/config/config-catalog.d.ts +376 -0
  532. package/dist/config/config-catalog.d.ts.map +1 -0
  533. package/dist/config/config-catalog.js +724 -0
  534. package/dist/config/config-field.d.ts +68 -0
  535. package/dist/config/config-field.d.ts.map +1 -0
  536. package/dist/config/config-field.js +821 -0
  537. package/dist/config/config-renderer.d.ts +176 -0
  538. package/dist/config/config-renderer.d.ts.map +1 -0
  539. package/dist/config/config-renderer.js +403 -0
  540. package/dist/config/index.d.ts +5 -0
  541. package/dist/config/index.d.ts.map +1 -0
  542. package/dist/config/index.js +4 -0
  543. package/dist/config/ui-renderer.d.ts +26 -0
  544. package/dist/config/ui-renderer.d.ts.map +1 -0
  545. package/dist/config/ui-renderer.js +815 -0
  546. package/dist/config/ui-spec.d.ts +164 -0
  547. package/dist/config/ui-spec.d.ts.map +1 -0
  548. package/dist/config/ui-spec.js +13 -0
  549. package/dist/events/index.d.ts +42 -0
  550. package/dist/events/index.d.ts.map +1 -0
  551. package/dist/events/index.js +41 -0
  552. package/dist/hooks/index.d.ts +14 -0
  553. package/dist/hooks/index.d.ts.map +1 -0
  554. package/dist/hooks/index.js +13 -0
  555. package/dist/hooks/useBugReport.d.ts +14 -0
  556. package/dist/hooks/useBugReport.d.ts.map +1 -0
  557. package/dist/hooks/useBugReport.js +18 -0
  558. package/dist/hooks/useCanvasWindow.d.ts +38 -0
  559. package/dist/hooks/useCanvasWindow.d.ts.map +1 -0
  560. package/dist/hooks/useCanvasWindow.js +273 -0
  561. package/dist/hooks/useChatAvatarVoice.d.ts +10 -0
  562. package/dist/hooks/useChatAvatarVoice.d.ts.map +1 -0
  563. package/dist/hooks/useChatAvatarVoice.js +71 -0
  564. package/dist/hooks/useContextMenu.d.ts +17 -0
  565. package/dist/hooks/useContextMenu.d.ts.map +1 -0
  566. package/dist/hooks/useContextMenu.js +100 -0
  567. package/dist/hooks/useKeyboardShortcuts.d.ts +17 -0
  568. package/dist/hooks/useKeyboardShortcuts.d.ts.map +1 -0
  569. package/dist/hooks/useKeyboardShortcuts.js +67 -0
  570. package/dist/hooks/useLifoSync.d.ts +18 -0
  571. package/dist/hooks/useLifoSync.d.ts.map +1 -0
  572. package/dist/hooks/useLifoSync.js +113 -0
  573. package/dist/hooks/useMemoryMonitor.d.ts +87 -0
  574. package/dist/hooks/useMemoryMonitor.d.ts.map +1 -0
  575. package/dist/hooks/useMemoryMonitor.js +210 -0
  576. package/dist/hooks/useRenderGuard.d.ts +17 -0
  577. package/dist/hooks/useRenderGuard.d.ts.map +1 -0
  578. package/dist/hooks/useRenderGuard.js +36 -0
  579. package/dist/hooks/useRetakeCapture.d.ts +12 -0
  580. package/dist/hooks/useRetakeCapture.d.ts.map +1 -0
  581. package/dist/hooks/useRetakeCapture.js +59 -0
  582. package/dist/hooks/useStreamPopoutNavigation.d.ts +3 -0
  583. package/dist/hooks/useStreamPopoutNavigation.d.ts.map +1 -0
  584. package/dist/hooks/useStreamPopoutNavigation.js +17 -0
  585. package/dist/hooks/useTimeout.d.ts +11 -0
  586. package/dist/hooks/useTimeout.d.ts.map +1 -0
  587. package/dist/hooks/useTimeout.js +32 -0
  588. package/dist/hooks/useVoiceChat.d.ts +129 -0
  589. package/dist/hooks/useVoiceChat.d.ts.map +1 -0
  590. package/dist/hooks/useVoiceChat.js +1071 -0
  591. package/dist/hooks/useWhatsAppPairing.d.ts +11 -0
  592. package/dist/hooks/useWhatsAppPairing.d.ts.map +1 -0
  593. package/dist/hooks/useWhatsAppPairing.js +95 -0
  594. package/dist/i18n/index.d.ts +7 -0
  595. package/dist/i18n/index.d.ts.map +1 -0
  596. package/dist/i18n/index.js +53 -0
  597. package/dist/i18n/locales/en.json +1196 -0
  598. package/dist/i18n/locales/es.json +1196 -0
  599. package/dist/i18n/locales/ko.json +1196 -0
  600. package/dist/i18n/locales/pt.json +1196 -0
  601. package/dist/i18n/locales/zh-CN.json +1196 -0
  602. package/dist/i18n/messages.d.ts +6 -0
  603. package/dist/i18n/messages.d.ts.map +1 -0
  604. package/dist/i18n/messages.js +14 -0
  605. package/dist/index.d.ts +5 -0
  606. package/dist/index.d.ts.map +1 -0
  607. package/dist/index.js +6 -0
  608. package/dist/navigation/index.d.ts +27 -0
  609. package/dist/navigation/index.d.ts.map +1 -0
  610. package/dist/navigation/index.js +230 -0
  611. package/dist/package.json +161 -0
  612. package/dist/platform/browser-launch.d.ts +2 -0
  613. package/dist/platform/browser-launch.d.ts.map +1 -0
  614. package/dist/platform/browser-launch.js +109 -0
  615. package/dist/platform/index.d.ts +64 -0
  616. package/dist/platform/index.d.ts.map +1 -0
  617. package/dist/platform/index.js +155 -0
  618. package/dist/platform/init.d.ts +40 -0
  619. package/dist/platform/init.d.ts.map +1 -0
  620. package/dist/platform/init.js +158 -0
  621. package/dist/providers/index.d.ts +13 -0
  622. package/dist/providers/index.d.ts.map +1 -0
  623. package/dist/providers/index.js +72 -0
  624. package/dist/state/AppContext.d.ts +11 -0
  625. package/dist/state/AppContext.d.ts.map +1 -0
  626. package/dist/state/AppContext.js +4496 -0
  627. package/dist/state/index.d.ts +7 -0
  628. package/dist/state/index.d.ts.map +1 -0
  629. package/dist/state/index.js +6 -0
  630. package/dist/state/internal.d.ts +6 -0
  631. package/dist/state/internal.d.ts.map +1 -0
  632. package/dist/state/internal.js +5 -0
  633. package/dist/state/parsers.d.ts +26 -0
  634. package/dist/state/parsers.d.ts.map +1 -0
  635. package/dist/state/parsers.js +255 -0
  636. package/dist/state/persistence.d.ts +36 -0
  637. package/dist/state/persistence.d.ts.map +1 -0
  638. package/dist/state/persistence.js +254 -0
  639. package/dist/state/types.d.ts +402 -0
  640. package/dist/state/types.d.ts.map +1 -0
  641. package/dist/state/types.js +70 -0
  642. package/dist/state/ui-preferences.d.ts +3 -0
  643. package/dist/state/ui-preferences.d.ts.map +1 -0
  644. package/dist/state/ui-preferences.js +1 -0
  645. package/dist/state/useApp.d.ts +4 -0
  646. package/dist/state/useApp.d.ts.map +1 -0
  647. package/dist/state/useApp.js +22 -0
  648. package/dist/state/vrm.d.ts +19 -0
  649. package/dist/state/vrm.d.ts.map +1 -0
  650. package/dist/state/vrm.js +65 -0
  651. package/dist/stories/AppMockProvider.d.ts +15 -0
  652. package/dist/stories/AppMockProvider.d.ts.map +1 -0
  653. package/dist/stories/AppMockProvider.js +14 -0
  654. package/dist/styles/anime.css +6324 -0
  655. package/dist/styles/base.css +196 -0
  656. package/dist/styles/onboarding-game.css +716 -0
  657. package/dist/styles/styles.css +2085 -0
  658. package/dist/styles/xterm.css +241 -0
  659. package/dist/types/index.d.ts +657 -0
  660. package/dist/types/index.d.ts.map +1 -0
  661. package/dist/types/index.js +1 -0
  662. package/dist/utils/asset-url.d.ts +26 -0
  663. package/dist/utils/asset-url.d.ts.map +1 -0
  664. package/dist/utils/asset-url.js +99 -0
  665. package/dist/utils/assistant-text.d.ts +2 -0
  666. package/dist/utils/assistant-text.d.ts.map +1 -0
  667. package/dist/utils/assistant-text.js +161 -0
  668. package/dist/utils/clipboard.d.ts +2 -0
  669. package/dist/utils/clipboard.d.ts.map +1 -0
  670. package/dist/utils/clipboard.js +38 -0
  671. package/dist/utils/desktop-dialogs.d.ts +19 -0
  672. package/dist/utils/desktop-dialogs.d.ts.map +1 -0
  673. package/dist/utils/desktop-dialogs.js +50 -0
  674. package/dist/utils/index.d.ts +7 -0
  675. package/dist/utils/index.d.ts.map +1 -0
  676. package/dist/utils/index.js +6 -0
  677. package/dist/utils/number-parsing.d.ts +44 -0
  678. package/dist/utils/number-parsing.d.ts.map +1 -0
  679. package/dist/utils/number-parsing.js +56 -0
  680. package/dist/utils/openExternalUrl.d.ts +2 -0
  681. package/dist/utils/openExternalUrl.d.ts.map +1 -0
  682. package/dist/utils/openExternalUrl.js +17 -0
  683. package/dist/utils/spoken-text.d.ts +2 -0
  684. package/dist/utils/spoken-text.d.ts.map +1 -0
  685. package/dist/utils/spoken-text.js +56 -0
  686. package/dist/utils/streaming-text.d.ts +3 -0
  687. package/dist/utils/streaming-text.d.ts.map +1 -0
  688. package/dist/utils/streaming-text.js +87 -0
  689. package/dist/voice/index.d.ts +2 -0
  690. package/dist/voice/index.d.ts.map +1 -0
  691. package/dist/voice/index.js +1 -0
  692. package/dist/voice/types.d.ts +25 -0
  693. package/dist/voice/types.d.ts.map +1 -0
  694. package/dist/voice/types.js +166 -0
  695. package/package.json +86 -0
  696. package/src/App.tsx +469 -0
  697. package/src/actions/character.ts +113 -0
  698. package/src/actions/chat-helpers.ts +100 -0
  699. package/src/actions/cloud.ts +59 -0
  700. package/src/actions/index.ts +12 -0
  701. package/src/actions/lifecycle.ts +175 -0
  702. package/src/actions/onboarding.ts +46 -0
  703. package/src/actions/triggers.ts +190 -0
  704. package/src/ambient.d.ts +16 -0
  705. package/src/api/client.ts +5616 -0
  706. package/src/api/index.ts +1 -0
  707. package/src/autonomy/index.ts +477 -0
  708. package/src/bridge/capacitor-bridge.ts +295 -0
  709. package/src/bridge/electrobun-rpc.ts +58 -0
  710. package/src/bridge/electrobun-runtime.ts +28 -0
  711. package/src/bridge/index.ts +5 -0
  712. package/src/bridge/native-plugins.ts +134 -0
  713. package/src/bridge/plugin-bridge.ts +352 -0
  714. package/src/bridge/storage-bridge.ts +162 -0
  715. package/src/chat/index.ts +251 -0
  716. package/src/coding/index.ts +43 -0
  717. package/src/components/AdvancedPageView.tsx +362 -0
  718. package/src/components/AgentActivityBox.tsx +49 -0
  719. package/src/components/ApiKeyConfig.tsx +224 -0
  720. package/src/components/AppsPageView.tsx +52 -0
  721. package/src/components/AppsView.tsx +293 -0
  722. package/src/components/AvatarLoader.tsx +86 -0
  723. package/src/components/AvatarSelector.tsx +223 -0
  724. package/src/components/BscTradePanel.tsx +549 -0
  725. package/src/components/BugReportModal.tsx +499 -0
  726. package/src/components/CharacterView.tsx +1623 -0
  727. package/src/components/ChatAvatar.test.ts +96 -0
  728. package/src/components/ChatAvatar.tsx +147 -0
  729. package/src/components/ChatComposer.tsx +330 -0
  730. package/src/components/ChatMessage.tsx +448 -0
  731. package/src/components/ChatModalView.test.tsx +118 -0
  732. package/src/components/ChatModalView.tsx +125 -0
  733. package/src/components/ChatView.tsx +999 -0
  734. package/src/components/CloudSourceControls.tsx +80 -0
  735. package/src/components/CodingAgentSettingsSection.tsx +536 -0
  736. package/src/components/CommandPalette.tsx +284 -0
  737. package/src/components/CompanionSceneHost.tsx +498 -0
  738. package/src/components/CompanionShell.tsx +31 -0
  739. package/src/components/CompanionView.tsx +109 -0
  740. package/src/components/ConfigPageView.tsx +722 -0
  741. package/src/components/ConfigSaveFooter.tsx +41 -0
  742. package/src/components/ConfirmModal.tsx +379 -0
  743. package/src/components/ConnectionFailedBanner.tsx +91 -0
  744. package/src/components/ConnectorsPageView.tsx +13 -0
  745. package/src/components/ConversationsSidebar.tsx +279 -0
  746. package/src/components/CustomActionEditor.tsx +1125 -0
  747. package/src/components/CustomActionsPanel.tsx +288 -0
  748. package/src/components/CustomActionsView.tsx +322 -0
  749. package/src/components/DatabasePageView.tsx +55 -0
  750. package/src/components/DatabaseView.tsx +814 -0
  751. package/src/components/ElizaCloudDashboard.tsx +1696 -0
  752. package/src/components/EmotePicker.tsx +529 -0
  753. package/src/components/ErrorBoundary.tsx +76 -0
  754. package/src/components/FineTuningView.tsx +1080 -0
  755. package/src/components/GameView.tsx +551 -0
  756. package/src/components/GameViewOverlay.tsx +133 -0
  757. package/src/components/GlobalEmoteOverlay.tsx +152 -0
  758. package/src/components/Header.test.tsx +413 -0
  759. package/src/components/Header.tsx +400 -0
  760. package/src/components/HeartbeatsView.tsx +1002 -0
  761. package/src/components/InventoryView.tsx +372 -0
  762. package/src/components/KnowledgeView.tsx +1128 -0
  763. package/src/components/LanguageDropdown.tsx +187 -0
  764. package/src/components/LifoMonitorPanel.tsx +196 -0
  765. package/src/components/LifoSandboxView.tsx +499 -0
  766. package/src/components/LoadingScreen.tsx +77 -0
  767. package/src/components/LogsPageView.tsx +17 -0
  768. package/src/components/LogsView.tsx +239 -0
  769. package/src/components/MediaGalleryView.tsx +432 -0
  770. package/src/components/MediaSettingsSection.tsx +893 -0
  771. package/src/components/MessageContent.tsx +815 -0
  772. package/src/components/OnboardingWizard.test.tsx +107 -0
  773. package/src/components/OnboardingWizard.tsx +186 -0
  774. package/src/components/PairingView.tsx +110 -0
  775. package/src/components/PermissionsSection.tsx +818 -0
  776. package/src/components/PluginsPageView.tsx +9 -0
  777. package/src/components/PluginsView.tsx +3152 -0
  778. package/src/components/ProviderSwitcher.tsx +874 -0
  779. package/src/components/RestartBanner.tsx +76 -0
  780. package/src/components/RuntimeView.tsx +460 -0
  781. package/src/components/SaveCommandModal.tsx +211 -0
  782. package/src/components/SecretsView.tsx +569 -0
  783. package/src/components/SettingsView.tsx +825 -0
  784. package/src/components/ShellOverlays.tsx +41 -0
  785. package/src/components/ShortcutsOverlay.tsx +155 -0
  786. package/src/components/SkillsView.tsx +1435 -0
  787. package/src/components/StartupFailureView.tsx +63 -0
  788. package/src/components/StreamView.tsx +483 -0
  789. package/src/components/StripeEmbeddedCheckout.tsx +155 -0
  790. package/src/components/SubscriptionStatus.tsx +634 -0
  791. package/src/components/SystemWarningBanner.tsx +71 -0
  792. package/src/components/ThemeToggle.tsx +100 -0
  793. package/src/components/TrajectoriesView.tsx +526 -0
  794. package/src/components/TrajectoryDetailView.tsx +426 -0
  795. package/src/components/TriggersView.tsx +1 -0
  796. package/src/components/VectorBrowserView.tsx +1633 -0
  797. package/src/components/VoiceConfigView.tsx +674 -0
  798. package/src/components/VrmStage.test.ts +219 -0
  799. package/src/components/VrmStage.tsx +432 -0
  800. package/src/components/WhatsAppQrOverlay.tsx +230 -0
  801. package/src/components/__tests__/chainConfig.test.ts +220 -0
  802. package/src/components/apps/AppDetailPane.tsx +242 -0
  803. package/src/components/apps/AppsCatalogGrid.tsx +137 -0
  804. package/src/components/apps/extensions/HyperscapeAppDetailPanel.tsx +577 -0
  805. package/src/components/apps/extensions/registry.ts +16 -0
  806. package/src/components/apps/extensions/types.ts +9 -0
  807. package/src/components/apps/helpers.ts +44 -0
  808. package/src/components/avatar/VrmAnimationLoader.test.ts +164 -0
  809. package/src/components/avatar/VrmAnimationLoader.ts +151 -0
  810. package/src/components/avatar/VrmBlinkController.ts +118 -0
  811. package/src/components/avatar/VrmCameraManager.ts +407 -0
  812. package/src/components/avatar/VrmEngine.ts +2678 -0
  813. package/src/components/avatar/VrmFootShadow.ts +96 -0
  814. package/src/components/avatar/VrmViewer.tsx +421 -0
  815. package/src/components/avatar/__tests__/VrmCameraManager.test.ts +168 -0
  816. package/src/components/avatar/__tests__/VrmEngine.test.ts +1574 -0
  817. package/src/components/avatar/mixamoVRMRigMap.ts +62 -0
  818. package/src/components/avatar/retargetMixamoFbxToVrm.ts +144 -0
  819. package/src/components/avatar/retargetMixamoGltfToVrm.ts +119 -0
  820. package/src/components/chainConfig.ts +380 -0
  821. package/src/components/companion/CompanionHeader.tsx +47 -0
  822. package/src/components/companion/CompanionSceneHost.tsx +5 -0
  823. package/src/components/companion/VrmStage.tsx +2 -0
  824. package/src/components/companion/__tests__/walletUtils.test.ts +742 -0
  825. package/src/components/companion/walletUtils.ts +290 -0
  826. package/src/components/companion-shell-styles.test.ts +146 -0
  827. package/src/components/companion-shell-styles.ts +270 -0
  828. package/src/components/confirm-delete-control.tsx +69 -0
  829. package/src/components/conversations/ConversationListItem.tsx +185 -0
  830. package/src/components/conversations/conversation-utils.ts +151 -0
  831. package/src/components/format.ts +131 -0
  832. package/src/components/index.ts +92 -0
  833. package/src/components/inventory/CopyableAddress.tsx +41 -0
  834. package/src/components/inventory/InventoryToolbar.tsx +142 -0
  835. package/src/components/inventory/NftGrid.tsx +99 -0
  836. package/src/components/inventory/TokenLogo.tsx +71 -0
  837. package/src/components/inventory/TokensTable.tsx +216 -0
  838. package/src/components/inventory/constants.ts +170 -0
  839. package/src/components/inventory/index.ts +29 -0
  840. package/src/components/inventory/media-url.test.ts +38 -0
  841. package/src/components/inventory/media-url.ts +36 -0
  842. package/src/components/inventory/useInventoryData.ts +460 -0
  843. package/src/components/knowledge-upload-image.ts +215 -0
  844. package/src/components/labels.ts +46 -0
  845. package/src/components/onboarding/ActivateStep.tsx +30 -0
  846. package/src/components/onboarding/ConnectionStep.tsx +1530 -0
  847. package/src/components/onboarding/OnboardingPanel.tsx +39 -0
  848. package/src/components/onboarding/OnboardingStepNav.tsx +31 -0
  849. package/src/components/onboarding/PermissionsStep.tsx +20 -0
  850. package/src/components/onboarding/RpcStep.tsx +402 -0
  851. package/src/components/onboarding/WakeUpStep.tsx +184 -0
  852. package/src/components/permissions/PermissionIcon.tsx +25 -0
  853. package/src/components/permissions/StreamingPermissions.tsx +376 -0
  854. package/src/components/plugins/showcase-data.ts +481 -0
  855. package/src/components/shared/ShellHeaderControls.tsx +193 -0
  856. package/src/components/skeletons.tsx +88 -0
  857. package/src/components/stream/ActivityFeed.tsx +113 -0
  858. package/src/components/stream/AvatarPip.tsx +10 -0
  859. package/src/components/stream/ChatContent.tsx +126 -0
  860. package/src/components/stream/ChatTicker.tsx +55 -0
  861. package/src/components/stream/IdleContent.tsx +73 -0
  862. package/src/components/stream/StatusBar.tsx +469 -0
  863. package/src/components/stream/StreamSettings.tsx +506 -0
  864. package/src/components/stream/StreamTerminal.tsx +94 -0
  865. package/src/components/stream/StreamVoiceConfig.tsx +160 -0
  866. package/src/components/stream/helpers.ts +134 -0
  867. package/src/components/stream/overlays/OverlayLayer.tsx +75 -0
  868. package/src/components/stream/overlays/built-in/ActionTickerWidget.tsx +64 -0
  869. package/src/components/stream/overlays/built-in/AlertPopupWidget.tsx +87 -0
  870. package/src/components/stream/overlays/built-in/BrandingWidget.tsx +51 -0
  871. package/src/components/stream/overlays/built-in/CustomHtmlWidget.tsx +105 -0
  872. package/src/components/stream/overlays/built-in/PeonGlassWidget.tsx +265 -0
  873. package/src/components/stream/overlays/built-in/PeonHudWidget.tsx +247 -0
  874. package/src/components/stream/overlays/built-in/PeonSakuraWidget.tsx +278 -0
  875. package/src/components/stream/overlays/built-in/ThoughtBubbleWidget.tsx +77 -0
  876. package/src/components/stream/overlays/built-in/ViewerCountWidget.tsx +46 -0
  877. package/src/components/stream/overlays/built-in/index.ts +13 -0
  878. package/src/components/stream/overlays/registry.ts +22 -0
  879. package/src/components/stream/overlays/types.ts +90 -0
  880. package/src/components/stream/overlays/useOverlayLayout.ts +218 -0
  881. package/src/components/trajectory-format.ts +50 -0
  882. package/src/components/ui-badges.tsx +109 -0
  883. package/src/components/ui-switch.tsx +57 -0
  884. package/src/components/vector-browser-three.ts +27 -0
  885. package/src/config/config-catalog.ts +1092 -0
  886. package/src/config/config-field.tsx +1900 -0
  887. package/src/config/config-renderer.tsx +730 -0
  888. package/src/config/index.ts +11 -0
  889. package/src/config/ui-renderer.tsx +1751 -0
  890. package/src/config/ui-spec.ts +256 -0
  891. package/src/events/index.ts +89 -0
  892. package/src/hooks/index.ts +13 -0
  893. package/src/hooks/useBugReport.tsx +43 -0
  894. package/src/hooks/useCanvasWindow.ts +372 -0
  895. package/src/hooks/useChatAvatarVoice.ts +111 -0
  896. package/src/hooks/useContextMenu.ts +127 -0
  897. package/src/hooks/useKeyboardShortcuts.ts +86 -0
  898. package/src/hooks/useLifoSync.ts +143 -0
  899. package/src/hooks/useMemoryMonitor.ts +335 -0
  900. package/src/hooks/useRenderGuard.ts +43 -0
  901. package/src/hooks/useRetakeCapture.ts +67 -0
  902. package/src/hooks/useStreamPopoutNavigation.ts +27 -0
  903. package/src/hooks/useTimeout.ts +37 -0
  904. package/src/hooks/useVoiceChat.ts +1443 -0
  905. package/src/hooks/useWhatsAppPairing.ts +123 -0
  906. package/src/i18n/index.ts +76 -0
  907. package/src/i18n/locales/en.json +1196 -0
  908. package/src/i18n/locales/es.json +1196 -0
  909. package/src/i18n/locales/ko.json +1196 -0
  910. package/src/i18n/locales/pt.json +1196 -0
  911. package/src/i18n/locales/zh-CN.json +1196 -0
  912. package/src/i18n/messages.ts +21 -0
  913. package/src/index.ts +6 -0
  914. package/src/navigation/index.ts +282 -0
  915. package/src/navigation.test.ts +189 -0
  916. package/src/platform/browser-launch.test.ts +94 -0
  917. package/src/platform/browser-launch.ts +149 -0
  918. package/src/platform/index.ts +261 -0
  919. package/src/platform/init.ts +236 -0
  920. package/src/providers/index.ts +82 -0
  921. package/src/state/AppContext.tsx +5737 -0
  922. package/src/state/index.ts +6 -0
  923. package/src/state/internal.ts +77 -0
  924. package/src/state/parsers.test.ts +124 -0
  925. package/src/state/parsers.ts +309 -0
  926. package/src/state/persistence.ts +278 -0
  927. package/src/state/types.ts +694 -0
  928. package/src/state/ui-preferences.ts +3 -0
  929. package/src/state/useApp.ts +23 -0
  930. package/src/state/vrm.ts +76 -0
  931. package/src/stories/AppMockProvider.tsx +32 -0
  932. package/src/stories/ChatEmptyState.stories.tsx +27 -0
  933. package/src/stories/ChatMessage.stories.tsx +115 -0
  934. package/src/stories/CompanionHeader.stories.tsx +74 -0
  935. package/src/stories/CompanionView.stories.tsx +33 -0
  936. package/src/stories/ConversationListItem.stories.tsx +102 -0
  937. package/src/stories/TypingIndicator.stories.tsx +28 -0
  938. package/src/styles/anime.css +6324 -0
  939. package/src/styles/base.css +196 -0
  940. package/src/styles/onboarding-game.css +716 -0
  941. package/src/styles/styles.css +2085 -0
  942. package/src/styles/xterm.css +241 -0
  943. package/src/types/index.ts +715 -0
  944. package/src/types/react-test-renderer.d.ts +45 -0
  945. package/src/utils/asset-url.ts +110 -0
  946. package/src/utils/assistant-text.ts +172 -0
  947. package/src/utils/clipboard.ts +41 -0
  948. package/src/utils/desktop-dialogs.ts +80 -0
  949. package/src/utils/index.ts +6 -0
  950. package/src/utils/number-parsing.ts +125 -0
  951. package/src/utils/openExternalUrl.ts +20 -0
  952. package/src/utils/spoken-text.ts +65 -0
  953. package/src/utils/streaming-text.ts +120 -0
  954. package/src/voice/index.ts +1 -0
  955. package/src/voice/types.ts +197 -0
  956. package/test/app/AppContext.pty-sessions.test.tsx +143 -0
  957. package/test/app/MessageContent.test.tsx +326 -0
  958. package/test/app/PermissionsOnboarding.test.tsx +216 -0
  959. package/test/app/PermissionsSection.test.tsx +186 -0
  960. package/test/app/advanced-trajectory-fine-tuning.e2e.test.ts +397 -0
  961. package/test/app/agent-activity-box.test.tsx +132 -0
  962. package/test/app/agent-transfer-lock.test.ts +274 -0
  963. package/test/app/api-client-electron-fallback.test.ts +139 -0
  964. package/test/app/api-client-timeout.test.ts +75 -0
  965. package/test/app/api-client-ws.test.ts +98 -0
  966. package/test/app/api-client.ws-max-reconnect.test.ts +139 -0
  967. package/test/app/api-client.ws-reconnect.test.ts +157 -0
  968. package/test/app/app-context-autonomy-events.test.ts +478 -0
  969. package/test/app/apps-page-view.test.ts +114 -0
  970. package/test/app/apps-view.test.ts +769 -0
  971. package/test/app/autonomous-workflows.e2e.test.ts +765 -0
  972. package/test/app/autonomy-events.test.ts +150 -0
  973. package/test/app/avatar-selector.test.tsx +52 -0
  974. package/test/app/bsc-trade-panel.test.tsx +134 -0
  975. package/test/app/bug-report-modal.test.tsx +353 -0
  976. package/test/app/character-customization.e2e.test.ts +1168 -0
  977. package/test/app/chat-advanced-features.e2e.test.ts +706 -0
  978. package/test/app/chat-composer.test.tsx +181 -0
  979. package/test/app/chat-language-header.test.ts +64 -0
  980. package/test/app/chat-message.test.tsx +222 -0
  981. package/test/app/chat-modal-view.test.tsx +191 -0
  982. package/test/app/chat-routine-filter.test.ts +96 -0
  983. package/test/app/chat-send-lock.test.ts +1302 -0
  984. package/test/app/chat-stream-api-client.test.tsx +390 -0
  985. package/test/app/chat-view-game-modal.test.tsx +661 -0
  986. package/test/app/chat-view.test.tsx +877 -0
  987. package/test/app/cloud-api.e2e.test.ts +258 -0
  988. package/test/app/cloud-login-flow.e2e.test.ts +494 -0
  989. package/test/app/cloud-login-lock.test.ts +411 -0
  990. package/test/app/command-palette.test.tsx +184 -0
  991. package/test/app/command-registry.test.ts +75 -0
  992. package/test/app/companion-greeting-wave.test.tsx +443 -0
  993. package/test/app/companion-stale-conversation.test.tsx +424 -0
  994. package/test/app/companion-view.test.tsx +686 -0
  995. package/test/app/confirm-delete-control.test.ts +79 -0
  996. package/test/app/confirm-modal.test.tsx +219 -0
  997. package/test/app/connectors-ui.e2e.test.ts +508 -0
  998. package/test/app/conversations-sidebar-game-modal.test.tsx +260 -0
  999. package/test/app/conversations-sidebar.test.tsx +160 -0
  1000. package/test/app/custom-actions-smoke.test.ts +387 -0
  1001. package/test/app/custom-avatar-api-client.test.ts +207 -0
  1002. package/test/app/desktop-utils.test.ts +145 -0
  1003. package/test/app/electrobun-rpc-bridge.test.ts +83 -0
  1004. package/test/app/events.test.ts +88 -0
  1005. package/test/app/export-import-flows.e2e.test.ts +700 -0
  1006. package/test/app/fine-tuning-view.test.ts +471 -0
  1007. package/test/app/game-view-auth-session.test.tsx +186 -0
  1008. package/test/app/game-view.test.ts +444 -0
  1009. package/test/app/global-emote-overlay.test.tsx +106 -0
  1010. package/test/app/header-status.test.tsx +149 -0
  1011. package/test/app/i18n.test.ts +152 -0
  1012. package/test/app/inventory-bsc-view.test.ts +908 -0
  1013. package/test/app/knowledge-ui.e2e.test.ts +762 -0
  1014. package/test/app/knowledge-upload-helpers.test.ts +124 -0
  1015. package/test/app/lifecycle-lock.test.ts +267 -0
  1016. package/test/app/lifo-popout-utils.test.ts +208 -0
  1017. package/test/app/lifo-safe-endpoint.test.ts +34 -0
  1018. package/test/app/loading-screen.test.tsx +45 -0
  1019. package/test/app/memory-monitor.test.ts +332 -0
  1020. package/test/app/navigation.test.tsx +29 -0
  1021. package/test/app/onboarding-finish-lock.test.ts +500 -0
  1022. package/test/app/onboarding-language.test.tsx +161 -0
  1023. package/test/app/onboarding-steps.test.tsx +371 -0
  1024. package/test/app/open-external-url.test.ts +65 -0
  1025. package/test/app/pages-navigation-smoke.e2e.test.ts +633 -0
  1026. package/test/app/pairing-lock.test.ts +260 -0
  1027. package/test/app/pairing-view.test.tsx +74 -0
  1028. package/test/app/permissions-section.test.ts +432 -0
  1029. package/test/app/plugin-bridge.test.ts +109 -0
  1030. package/test/app/plugins-ui.e2e.test.ts +605 -0
  1031. package/test/app/plugins-view-game-modal.test.tsx +650 -0
  1032. package/test/app/plugins-view-toggle-restart.test.ts +129 -0
  1033. package/test/app/provider-dropdown-default.test.tsx +164 -0
  1034. package/test/app/restart-banner.test.tsx +197 -0
  1035. package/test/app/retake-capture.test.ts +84 -0
  1036. package/test/app/sandbox-api-client.test.ts +108 -0
  1037. package/test/app/save-command-modal.test.tsx +109 -0
  1038. package/test/app/secrets-view.test.tsx +92 -0
  1039. package/test/app/settings-control-styles.test.tsx +142 -0
  1040. package/test/app/settings-reset.e2e.test.ts +728 -0
  1041. package/test/app/settings-sections.e2e.test.ts +614 -0
  1042. package/test/app/shared-format.test.ts +44 -0
  1043. package/test/app/shared-switch.test.ts +69 -0
  1044. package/test/app/shell-mode-switching.e2e.test.ts +829 -0
  1045. package/test/app/shell-mode-tab-memory.test.tsx +283 -0
  1046. package/test/app/shell-overlays.test.tsx +50 -0
  1047. package/test/app/shortcuts-overlay.test.tsx +111 -0
  1048. package/test/app/sse-interruption.test.ts +122 -0
  1049. package/test/app/startup-asset-missing.e2e.test.ts +126 -0
  1050. package/test/app/startup-backend-missing.e2e.test.ts +118 -0
  1051. package/test/app/startup-chat.e2e.test.ts +305 -0
  1052. package/test/app/startup-conversation-restore.test.tsx +344 -0
  1053. package/test/app/startup-failure-view.test.tsx +103 -0
  1054. package/test/app/startup-onboarding.e2e.test.ts +612 -0
  1055. package/test/app/startup-timeout.test.tsx +80 -0
  1056. package/test/app/startup-token-401.e2e.test.ts +103 -0
  1057. package/test/app/stream-helpers.test.ts +46 -0
  1058. package/test/app/stream-popout-navigation.test.tsx +41 -0
  1059. package/test/app/stream-status-bar.test.tsx +89 -0
  1060. package/test/app/theme-toggle.test.tsx +33 -0
  1061. package/test/app/training-api-client.test.ts +128 -0
  1062. package/test/app/trajectories-view.test.tsx +220 -0
  1063. package/test/app/triggers-api-client.test.ts +77 -0
  1064. package/test/app/triggers-navigation.test.ts +118 -0
  1065. package/test/app/triggers-view.e2e.test.ts +674 -0
  1066. package/test/app/update-channel-lock.test.ts +259 -0
  1067. package/test/app/vector-browser.async-cleanup.test.tsx +367 -0
  1068. package/test/app/vector-browser.e2e.test.ts +653 -0
  1069. package/test/app/vrm-stage.test.tsx +351 -0
  1070. package/test/app/vrm-viewer.test.tsx +298 -0
  1071. package/test/app/wallet-api-save-lock.test.ts +277 -0
  1072. package/test/app/wallet-hooks.test.ts +405 -0
  1073. package/test/app/wallet-ui-flows.e2e.test.ts +556 -0
  1074. package/test/avatar/asset-url.test.ts +90 -0
  1075. package/test/avatar/avatar-selector.test.ts +173 -0
  1076. package/test/avatar/mixamo-vrm-rig-map.test.ts +111 -0
  1077. package/test/avatar/voice-chat-streaming-text.test.ts +96 -0
  1078. package/test/avatar/voice-chat.test.ts +391 -0
  1079. package/test/ui/command-palette-commands.test.ts +57 -0
  1080. package/test/ui/ui-renderer.test.ts +39 -0
  1081. package/tsconfig.build.json +19 -0
  1082. package/tsconfig.json +21 -0
@@ -0,0 +1,1530 @@
1
+ import type {
2
+ OpenRouterModelOption,
3
+ PiAiModelOption,
4
+ ProviderOption,
5
+ } from "@elizaos/app-core/api";
6
+ import { client } from "@elizaos/app-core/api";
7
+ import { isNative } from "@elizaos/app-core/platform";
8
+ import { getProviderLogo } from "@elizaos/app-core/providers";
9
+ import { useApp } from "@elizaos/app-core/state";
10
+ import { openExternalUrl } from "@elizaos/app-core/utils";
11
+ import { useState } from "react";
12
+
13
+ function formatRequestError(err: unknown): string {
14
+ if (err instanceof Error) {
15
+ return err.message;
16
+ }
17
+ return String(err);
18
+ }
19
+
20
+ export function ConnectionStep() {
21
+ const {
22
+ onboardingOptions,
23
+ onboardingRunMode,
24
+ onboardingCloudProvider,
25
+ onboardingProvider,
26
+ onboardingSubscriptionTab,
27
+ onboardingApiKey,
28
+ onboardingRemoteApiBase,
29
+ onboardingRemoteToken,
30
+ onboardingRemoteConnecting,
31
+ onboardingRemoteError,
32
+ onboardingRemoteConnected,
33
+ onboardingPrimaryModel,
34
+ onboardingElizaCloudTab,
35
+ onboardingOpenRouterModel,
36
+ elizaCloudConnected,
37
+ elizaCloudLoginBusy,
38
+ elizaCloudLoginError,
39
+ handleCloudLogin,
40
+ handleOnboardingRemoteConnect,
41
+ handleOnboardingUseLocalBackend,
42
+ handleOnboardingNext,
43
+ handleOnboardingBack,
44
+ setState,
45
+ t,
46
+ } = useApp();
47
+
48
+ const [openaiOAuthStarted, setOpenaiOAuthStarted] = useState(false);
49
+ const [openaiCallbackUrl, setOpenaiCallbackUrl] = useState("");
50
+ const [openaiConnected, setOpenaiConnected] = useState(false);
51
+ const [openaiError, setOpenaiError] = useState("");
52
+
53
+ const [anthropicOAuthStarted, setAnthropicOAuthStarted] = useState(false);
54
+ const [anthropicCode, setAnthropicCode] = useState("");
55
+ const [anthropicConnected, setAnthropicConnected] = useState(false);
56
+ const [anthropicError, setAnthropicError] = useState("");
57
+
58
+ const [apiKeyFormatWarning, setApiKeyFormatWarning] = useState("");
59
+
60
+ const handleAnthropicStart = async () => {
61
+ setAnthropicError("");
62
+ try {
63
+ const { authUrl } = await client.startAnthropicLogin();
64
+ if (authUrl) {
65
+ await openExternalUrl(authUrl);
66
+ setAnthropicOAuthStarted(true);
67
+ return;
68
+ }
69
+ setAnthropicError("Failed to get auth URL");
70
+ } catch (err) {
71
+ setAnthropicError(`Failed to start login: ${formatRequestError(err)}`);
72
+ }
73
+ };
74
+
75
+ const handleAnthropicExchange = async () => {
76
+ setAnthropicError("");
77
+ try {
78
+ const result = await client.exchangeAnthropicCode(anthropicCode);
79
+ if (result.success) {
80
+ setAnthropicConnected(true);
81
+ return;
82
+ }
83
+ setAnthropicError(result.error ?? "Exchange failed");
84
+ } catch (err) {
85
+ setAnthropicError(`Exchange failed: ${formatRequestError(err)}`);
86
+ }
87
+ };
88
+
89
+ const handleOpenAIStart = async () => {
90
+ try {
91
+ const { authUrl } = await client.startOpenAILogin();
92
+ if (authUrl) {
93
+ await openExternalUrl(authUrl);
94
+ setOpenaiOAuthStarted(true);
95
+ return;
96
+ }
97
+ setOpenaiError("No auth URL returned from login");
98
+ } catch (err) {
99
+ setOpenaiError(`Failed to start login: ${formatRequestError(err)}`);
100
+ }
101
+ };
102
+
103
+ const handleOpenAIExchange = async () => {
104
+ setOpenaiError("");
105
+ try {
106
+ const data = await client.exchangeOpenAICode(openaiCallbackUrl);
107
+ if (data.success) {
108
+ setOpenaiOAuthStarted(false);
109
+ setOpenaiCallbackUrl("");
110
+ setOpenaiConnected(true);
111
+ setState("onboardingProvider", "openai-subscription");
112
+ return;
113
+ }
114
+ const msg = data.error ?? "Exchange failed";
115
+ setOpenaiError(
116
+ msg.includes("No active flow")
117
+ ? t("onboarding.loginSessionExpired")
118
+ : msg,
119
+ );
120
+ } catch (_err) {
121
+ setOpenaiError(t("onboarding.networkError"));
122
+ }
123
+ };
124
+
125
+ const validateApiKeyFormat = (key: string, providerId: string): string => {
126
+ if (!key || key.trim().length === 0) return "";
127
+ const trimmed = key.trim();
128
+ if (providerId === "openai" && !trimmed.startsWith("sk-")) {
129
+ return t("onboarding.keyFormatWarning");
130
+ }
131
+ if (providerId === "anthropic" && !trimmed.startsWith("sk-ant-")) {
132
+ return t("onboarding.keyFormatWarning");
133
+ }
134
+ if (trimmed.length < 20) {
135
+ return t("onboarding.keyFormatWarning");
136
+ }
137
+ return "";
138
+ };
139
+
140
+ const handleApiKeyChange = (e: React.ChangeEvent<HTMLInputElement>) => {
141
+ const newKey = e.target.value;
142
+ setState("onboardingApiKey", newKey);
143
+ setApiKeyFormatWarning(validateApiKeyFormat(newKey, onboardingProvider));
144
+ };
145
+
146
+ const handleOpenRouterModelSelect = (modelId: string) => {
147
+ setState("onboardingOpenRouterModel", modelId);
148
+ };
149
+
150
+ const providers = (onboardingOptions?.providers ?? []).filter(
151
+ (provider: ProviderOption) => provider.id !== "elizacloud",
152
+ );
153
+ const elizaCloudReady =
154
+ elizaCloudConnected ||
155
+ (onboardingRunMode === "cloud" &&
156
+ onboardingCloudProvider === "elizacloud" &&
157
+ onboardingApiKey.trim().length > 0);
158
+ const showProviderSelection =
159
+ onboardingRemoteConnected || onboardingRunMode === "local";
160
+
161
+ const recommendedIds = new Set([
162
+ "anthropic-subscription",
163
+ "openai-subscription",
164
+ ]);
165
+
166
+ const providerOverrides: Record<
167
+ string,
168
+ { name: string; description?: string }
169
+ > = {
170
+ elizacloud: { name: "Eliza Cloud", description: "Managed hosting" },
171
+ "anthropic-subscription": {
172
+ name: "Claude Sub",
173
+ description: "Pro/Max subscription",
174
+ },
175
+ "openai-subscription": {
176
+ name: "ChatGPT Sub",
177
+ description: "Plus/Pro subscription",
178
+ },
179
+ anthropic: { name: "Anthropic", description: "Claude API key" },
180
+ openai: { name: "OpenAI", description: "GPT API key" },
181
+ openrouter: { name: "OpenRouter", description: "Multi-model API" },
182
+ gemini: { name: "Gemini", description: "Google AI" },
183
+ grok: { name: "xAI (Grok)" },
184
+ groq: { name: "Groq", description: "Fast inference" },
185
+ deepseek: { name: "DeepSeek" },
186
+ "pi-ai": { name: "Pi Credentials", description: "Local auth" },
187
+ };
188
+
189
+ const getProviderDisplay = (provider: ProviderOption) => {
190
+ const override = providerOverrides[provider.id];
191
+ return {
192
+ name: override?.name ?? provider.name,
193
+ description: override?.description ?? provider.description,
194
+ };
195
+ };
196
+
197
+ const handleSelectLocalHosting = () => {
198
+ setState("onboardingRunMode", "local");
199
+ setState("onboardingCloudProvider", "");
200
+ setState("onboardingRemoteError", null);
201
+ setState("onboardingRemoteConnecting", false);
202
+ };
203
+
204
+ const handleSelectCloudHosting = () => {
205
+ setState("onboardingRunMode", "cloud");
206
+ setState("onboardingProvider", "");
207
+ setState("onboardingApiKey", "");
208
+ setState("onboardingPrimaryModel", "");
209
+ };
210
+
211
+ const resetCloudSelection = () => {
212
+ setState("onboardingCloudProvider", "");
213
+ setState("onboardingApiKey", "");
214
+ setState("onboardingRemoteError", null);
215
+ setState("onboardingRemoteConnecting", false);
216
+ };
217
+
218
+ const resetHostingSelection = () => {
219
+ resetCloudSelection();
220
+ setState("onboardingRunMode", "");
221
+ };
222
+
223
+ const handleRemoteBack = () => {
224
+ if (onboardingRemoteConnected) {
225
+ handleOnboardingUseLocalBackend();
226
+ return;
227
+ }
228
+ resetCloudSelection();
229
+ };
230
+
231
+ const availableProviders = providers;
232
+ const recommendedProviders = availableProviders.filter((p: ProviderOption) =>
233
+ recommendedIds.has(p.id),
234
+ );
235
+ const otherProviders = availableProviders.filter(
236
+ (p: ProviderOption) => !recommendedIds.has(p.id),
237
+ );
238
+ const sortedProviders = [...recommendedProviders, ...otherProviders];
239
+
240
+ const piAiModels = onboardingOptions?.piAiModels ?? [];
241
+ const piAiDefaultModel = onboardingOptions?.piAiDefaultModel ?? "";
242
+ const normalizedPrimaryModel = onboardingPrimaryModel.trim();
243
+ const hasKnownPiAiModel = piAiModels.some(
244
+ (model: PiAiModelOption) => model.id === normalizedPrimaryModel,
245
+ );
246
+ const piAiSelectValue =
247
+ normalizedPrimaryModel.length === 0
248
+ ? ""
249
+ : hasKnownPiAiModel
250
+ ? normalizedPrimaryModel
251
+ : "__custom__";
252
+
253
+ const handleProviderSelect = (providerId: string) => {
254
+ setState("onboardingProvider", providerId);
255
+ setState("onboardingApiKey", "");
256
+ setState("onboardingPrimaryModel", "");
257
+ if (providerId === "anthropic-subscription") {
258
+ setState("onboardingSubscriptionTab", "token");
259
+ }
260
+ };
261
+
262
+ if (!showProviderSelection) {
263
+ if (!onboardingRunMode) {
264
+ return (
265
+ <>
266
+ <div className="onboarding-section-title">
267
+ {t("onboarding.hostingTitle")}
268
+ </div>
269
+ <div className="onboarding-divider">
270
+ <div className="onboarding-divider-diamond" />
271
+ </div>
272
+ <div className="onboarding-question">
273
+ {t("onboarding.hostingQuestion")}
274
+ </div>
275
+ <div className="onboarding-provider-grid">
276
+ {!isNative && (
277
+ <button
278
+ type="button"
279
+ className="onboarding-provider-card onboarding-provider-card--recommended"
280
+ onClick={handleSelectLocalHosting}
281
+ >
282
+ <div>
283
+ <div className="onboarding-provider-name">
284
+ {t("onboarding.hostingLocal")}
285
+ </div>
286
+ <div className="onboarding-provider-desc">
287
+ {t("onboarding.hostingLocalDesc")}
288
+ </div>
289
+ </div>
290
+ <span className="onboarding-provider-badge">
291
+ {t("onboarding.recommended") ?? "Recommended"}
292
+ </span>
293
+ </button>
294
+ )}
295
+ <button
296
+ type="button"
297
+ className="onboarding-provider-card"
298
+ onClick={handleSelectCloudHosting}
299
+ >
300
+ <div>
301
+ <div className="onboarding-provider-name">
302
+ {t("onboarding.hostingCloud")}
303
+ </div>
304
+ <div className="onboarding-provider-desc">
305
+ {t("onboarding.hostingCloudDesc")}
306
+ </div>
307
+ </div>
308
+ </button>
309
+ </div>
310
+ <div className="onboarding-panel-footer">
311
+ <button
312
+ className="onboarding-back-link"
313
+ onClick={handleOnboardingBack}
314
+ type="button"
315
+ >
316
+ {t("onboarding.back")}
317
+ </button>
318
+ <span />
319
+ </div>
320
+ </>
321
+ );
322
+ }
323
+
324
+ if (!onboardingCloudProvider) {
325
+ return (
326
+ <>
327
+ <div className="onboarding-section-title">
328
+ {t("onboarding.hostingCloud")}
329
+ </div>
330
+ <div className="onboarding-divider">
331
+ <div className="onboarding-divider-diamond" />
332
+ </div>
333
+ <div className="onboarding-question">
334
+ {t("onboarding.cloudQuestion")}
335
+ </div>
336
+ <div className="onboarding-provider-grid">
337
+ <button
338
+ type="button"
339
+ className="onboarding-provider-card onboarding-provider-card--recommended"
340
+ onClick={() => setState("onboardingCloudProvider", "elizacloud")}
341
+ >
342
+ <div>
343
+ <div className="onboarding-provider-name">
344
+ {t("onboarding.cloudManaged")}
345
+ </div>
346
+ <div className="onboarding-provider-desc">
347
+ {t("onboarding.cloudManagedDesc")}
348
+ </div>
349
+ </div>
350
+ <span className="onboarding-provider-badge">
351
+ {t("onboarding.recommended") ?? "Recommended"}
352
+ </span>
353
+ </button>
354
+ <button
355
+ type="button"
356
+ className="onboarding-provider-card"
357
+ onClick={() => setState("onboardingCloudProvider", "remote")}
358
+ >
359
+ <div>
360
+ <div className="onboarding-provider-name">
361
+ {t("onboarding.cloudRemote")}
362
+ </div>
363
+ <div className="onboarding-provider-desc">
364
+ {t("onboarding.cloudRemoteDesc")}
365
+ </div>
366
+ </div>
367
+ </button>
368
+ </div>
369
+ <div className="onboarding-panel-footer">
370
+ <button
371
+ className="onboarding-back-link"
372
+ onClick={resetHostingSelection}
373
+ type="button"
374
+ >
375
+ {t("onboarding.back")}
376
+ </button>
377
+ <span />
378
+ </div>
379
+ </>
380
+ );
381
+ }
382
+
383
+ if (onboardingCloudProvider === "remote") {
384
+ return (
385
+ <>
386
+ <div className="onboarding-section-title">
387
+ {t("onboarding.remoteTitle")}
388
+ </div>
389
+ <div className="onboarding-divider">
390
+ <div className="onboarding-divider-diamond" />
391
+ </div>
392
+ <div
393
+ style={{
394
+ width: "100%",
395
+ textAlign: "left",
396
+ display: "flex",
397
+ flexDirection: "column",
398
+ gap: "0.875rem",
399
+ }}
400
+ >
401
+ <div>
402
+ <label
403
+ htmlFor="remote-api-base"
404
+ style={{
405
+ display: "block",
406
+ fontSize: "0.875rem",
407
+ marginBottom: "0.375rem",
408
+ color: "var(--muted)",
409
+ }}
410
+ >
411
+ {t("onboarding.remoteAddress")}
412
+ </label>
413
+ <input
414
+ id="remote-api-base"
415
+ type="text"
416
+ className="onboarding-input"
417
+ placeholder={t("onboarding.remoteAddressPlaceholder")}
418
+ value={onboardingRemoteApiBase}
419
+ onChange={(e) =>
420
+ setState("onboardingRemoteApiBase", e.target.value)
421
+ }
422
+ />
423
+ </div>
424
+
425
+ <div>
426
+ <label
427
+ htmlFor="remote-api-token"
428
+ style={{
429
+ display: "block",
430
+ fontSize: "0.875rem",
431
+ marginBottom: "0.375rem",
432
+ color: "var(--muted)",
433
+ }}
434
+ >
435
+ {t("onboarding.remoteAccessKey")}
436
+ </label>
437
+ <input
438
+ id="remote-api-token"
439
+ type="password"
440
+ className="onboarding-input"
441
+ placeholder={t("onboarding.remoteAccessKeyPlaceholder")}
442
+ value={onboardingRemoteToken}
443
+ onChange={(e) =>
444
+ setState("onboardingRemoteToken", e.target.value)
445
+ }
446
+ />
447
+ </div>
448
+
449
+ {onboardingRemoteError && (
450
+ <p
451
+ style={{
452
+ color: "var(--danger)",
453
+ fontSize: "0.8125rem",
454
+ }}
455
+ >
456
+ {onboardingRemoteError}
457
+ </p>
458
+ )}
459
+ </div>
460
+ <div className="onboarding-panel-footer">
461
+ <button
462
+ className="onboarding-back-link"
463
+ onClick={handleRemoteBack}
464
+ type="button"
465
+ >
466
+ {t("onboarding.back")}
467
+ </button>
468
+ <button
469
+ className="onboarding-confirm-btn"
470
+ onClick={() => void handleOnboardingRemoteConnect()}
471
+ disabled={onboardingRemoteConnecting}
472
+ type="button"
473
+ >
474
+ {onboardingRemoteConnecting
475
+ ? t("onboarding.connecting")
476
+ : t("onboarding.remoteConnect")}
477
+ </button>
478
+ </div>
479
+ </>
480
+ );
481
+ }
482
+
483
+ return (
484
+ <>
485
+ <div className="onboarding-section-title">Eliza Cloud</div>
486
+ <div className="onboarding-divider">
487
+ <div className="onboarding-divider-diamond" />
488
+ </div>
489
+
490
+ <div style={{ width: "100%", textAlign: "left" }}>
491
+ <div
492
+ style={{
493
+ display: "flex",
494
+ gap: "1rem",
495
+ borderBottom: "1px solid var(--border)",
496
+ marginBottom: "1rem",
497
+ }}
498
+ >
499
+ <button
500
+ type="button"
501
+ style={{
502
+ fontSize: "0.875rem",
503
+ paddingBottom: "0.5rem",
504
+ color:
505
+ onboardingElizaCloudTab === "login"
506
+ ? "#f0b90b"
507
+ : "var(--muted)",
508
+ background: "none",
509
+ border: "none",
510
+ borderBottom:
511
+ onboardingElizaCloudTab === "login"
512
+ ? "2px solid #f0b90b"
513
+ : "2px solid transparent",
514
+ cursor: "pointer",
515
+ }}
516
+ onClick={() => setState("onboardingElizaCloudTab", "login")}
517
+ >
518
+ {t("onboarding.login")}
519
+ </button>
520
+ <button
521
+ type="button"
522
+ style={{
523
+ fontSize: "0.875rem",
524
+ paddingBottom: "0.5rem",
525
+ borderBottom:
526
+ onboardingElizaCloudTab === "apikey"
527
+ ? "2px solid #f0b90b"
528
+ : "2px solid transparent",
529
+ color:
530
+ onboardingElizaCloudTab === "apikey"
531
+ ? "#f0b90b"
532
+ : "var(--muted)",
533
+ background: "none",
534
+ border: "none",
535
+ cursor: "pointer",
536
+ }}
537
+ onClick={() => setState("onboardingElizaCloudTab", "apikey")}
538
+ >
539
+ {t("onboarding.apiKey")}
540
+ </button>
541
+ </div>
542
+
543
+ {onboardingElizaCloudTab === "login" ? (
544
+ <div style={{ textAlign: "center" }}>
545
+ {elizaCloudConnected ? (
546
+ <div
547
+ style={{
548
+ display: "flex",
549
+ alignItems: "center",
550
+ gap: "0.5rem",
551
+ padding: "0.625rem 1rem",
552
+ border: "1px solid var(--ok-muted)",
553
+ background: "var(--ok-subtle)",
554
+ color: "var(--ok)",
555
+ fontSize: "0.875rem",
556
+ borderRadius: "0.5rem",
557
+ justifyContent: "center",
558
+ }}
559
+ >
560
+ <svg
561
+ width="16"
562
+ height="16"
563
+ viewBox="0 0 24 24"
564
+ fill="none"
565
+ stroke="currentColor"
566
+ strokeWidth="2.5"
567
+ strokeLinecap="round"
568
+ strokeLinejoin="round"
569
+ >
570
+ <title>{t("onboarding.connected")}</title>
571
+ <polyline points="20 6 9 17 4 12" />
572
+ </svg>
573
+ {t("onboarding.connected")}
574
+ </div>
575
+ ) : (
576
+ <button
577
+ type="button"
578
+ className="onboarding-confirm-btn"
579
+ onClick={handleCloudLogin}
580
+ disabled={elizaCloudLoginBusy}
581
+ >
582
+ {elizaCloudLoginBusy
583
+ ? t("onboarding.connecting")
584
+ : t("onboarding.connectAccount")}
585
+ </button>
586
+ )}
587
+ {elizaCloudLoginError &&
588
+ (() => {
589
+ const urlMatch = elizaCloudLoginError.match(
590
+ /^Open this link to log in: (.+)$/,
591
+ );
592
+ if (urlMatch) {
593
+ return (
594
+ <p
595
+ style={{
596
+ fontSize: "0.8125rem",
597
+ marginTop: "0.5rem",
598
+ color: "var(--text)",
599
+ }}
600
+ >
601
+ Open this link to log in:{" "}
602
+ <a
603
+ href={urlMatch[1]}
604
+ target="_blank"
605
+ rel="noopener noreferrer"
606
+ style={{
607
+ color: "var(--text)",
608
+ textDecoration: "underline",
609
+ }}
610
+ >
611
+ Click here
612
+ </a>
613
+ </p>
614
+ );
615
+ }
616
+ return (
617
+ <p
618
+ style={{
619
+ color: "var(--danger)",
620
+ fontSize: "0.8125rem",
621
+ marginTop: "0.5rem",
622
+ }}
623
+ >
624
+ {elizaCloudLoginError}
625
+ </p>
626
+ );
627
+ })()}
628
+ <p className="onboarding-desc">{t("onboarding.freeCredits")}</p>
629
+ </div>
630
+ ) : (
631
+ <div>
632
+ <label
633
+ htmlFor="elizacloud-apikey"
634
+ style={{
635
+ display: "block",
636
+ fontSize: "0.875rem",
637
+ marginBottom: "0.375rem",
638
+ color: "var(--muted)",
639
+ }}
640
+ >
641
+ {t("onboarding.apiKey")}
642
+ </label>
643
+ <input
644
+ id="elizacloud-apikey"
645
+ type="password"
646
+ className="onboarding-input"
647
+ placeholder="ck-..."
648
+ value={onboardingApiKey}
649
+ onChange={handleApiKeyChange}
650
+ />
651
+ <p className="onboarding-desc">
652
+ {t("onboarding.useExistingKey")}{" "}
653
+ <a
654
+ href="https://elizacloud.ai/dashboard/settings"
655
+ target="_blank"
656
+ rel="noopener noreferrer"
657
+ style={{ color: "var(--text)" }}
658
+ >
659
+ {t("onboarding.getOneHere")}
660
+ </a>
661
+ </p>
662
+ </div>
663
+ )}
664
+ </div>
665
+
666
+ <div className="onboarding-panel-footer">
667
+ <button
668
+ className="onboarding-back-link"
669
+ onClick={resetCloudSelection}
670
+ type="button"
671
+ >
672
+ {t("onboarding.back")}
673
+ </button>
674
+ <button
675
+ className="onboarding-confirm-btn"
676
+ onClick={() => void handleOnboardingNext()}
677
+ disabled={!elizaCloudReady}
678
+ type="button"
679
+ >
680
+ {t("onboarding.confirm")}
681
+ </button>
682
+ </div>
683
+ </>
684
+ );
685
+ }
686
+
687
+ if (!onboardingProvider) {
688
+ return (
689
+ <>
690
+ <div className="onboarding-section-title">
691
+ {t("onboarding.neuralLinkTitle")}
692
+ </div>
693
+ <div className="onboarding-divider">
694
+ <div className="onboarding-divider-diamond" />
695
+ </div>
696
+ {onboardingRemoteConnected && (
697
+ <p className="onboarding-desc" style={{ marginBottom: "1rem" }}>
698
+ {t("onboarding.remoteConnectedDesc")}
699
+ </p>
700
+ )}
701
+ <div className="onboarding-question">
702
+ {t("onboarding.chooseProvider")}
703
+ </div>
704
+ <div className="onboarding-provider-grid">
705
+ {sortedProviders.map((p: ProviderOption) => {
706
+ const display = getProviderDisplay(p);
707
+ const isRecommended = recommendedIds.has(p.id);
708
+ return (
709
+ <button
710
+ type="button"
711
+ key={p.id}
712
+ className={`onboarding-provider-card${isRecommended ? " onboarding-provider-card--recommended" : ""}`}
713
+ onClick={() => handleProviderSelect(p.id)}
714
+ >
715
+ <img
716
+ src={getProviderLogo(p.id, false)}
717
+ alt={display.name}
718
+ className="onboarding-provider-icon"
719
+ />
720
+ <div>
721
+ <div className="onboarding-provider-name">{display.name}</div>
722
+ {display.description && (
723
+ <div className="onboarding-provider-desc">
724
+ {display.description}
725
+ </div>
726
+ )}
727
+ </div>
728
+ {isRecommended && (
729
+ <span className="onboarding-provider-badge">
730
+ {t("onboarding.recommended") ?? "Recommended"}
731
+ </span>
732
+ )}
733
+ </button>
734
+ );
735
+ })}
736
+ </div>
737
+ <div className="onboarding-panel-footer">
738
+ <button
739
+ className="onboarding-back-link"
740
+ onClick={
741
+ onboardingRemoteConnected
742
+ ? handleOnboardingUseLocalBackend
743
+ : resetHostingSelection
744
+ }
745
+ type="button"
746
+ >
747
+ {t("onboarding.back")}
748
+ </button>
749
+ <span />
750
+ </div>
751
+ </>
752
+ );
753
+ }
754
+
755
+ // Screen B: provider selected — show config UI
756
+ const selectedProvider = providers.find(
757
+ (p: ProviderOption) => p.id === onboardingProvider,
758
+ );
759
+ const selectedDisplay = selectedProvider
760
+ ? getProviderDisplay(selectedProvider)
761
+ : { name: onboardingProvider, description: "" };
762
+
763
+ return (
764
+ <>
765
+ <div className="onboarding-section-title">
766
+ <span
767
+ style={{
768
+ display: "flex",
769
+ alignItems: "center",
770
+ gap: "0.5rem",
771
+ justifyContent: "center",
772
+ }}
773
+ >
774
+ {selectedProvider && (
775
+ <img
776
+ src={getProviderLogo(selectedProvider.id, false)}
777
+ alt={selectedDisplay.name}
778
+ className="onboarding-provider-icon"
779
+ style={{ width: "1.5rem", height: "1.5rem" }}
780
+ />
781
+ )}
782
+ {selectedDisplay.name}
783
+ <button
784
+ type="button"
785
+ className="onboarding-back-link"
786
+ style={{ marginLeft: "0.5rem", fontSize: "0.75rem" }}
787
+ onClick={() => {
788
+ setState("onboardingProvider", "");
789
+ setState("onboardingApiKey", "");
790
+ setState("onboardingPrimaryModel", "");
791
+ }}
792
+ >
793
+ {t("onboarding.change")}
794
+ </button>
795
+ </span>
796
+ </div>
797
+ <div className="onboarding-divider">
798
+ <div className="onboarding-divider-diamond" />
799
+ </div>
800
+
801
+ {/* elizacloud */}
802
+ {onboardingProvider === "elizacloud" && (
803
+ <div style={{ width: "100%", textAlign: "left" }}>
804
+ <div
805
+ style={{
806
+ display: "flex",
807
+ gap: "1rem",
808
+ borderBottom: "1px solid var(--border)",
809
+ marginBottom: "1rem",
810
+ }}
811
+ >
812
+ <button
813
+ type="button"
814
+ style={{
815
+ fontSize: "0.875rem",
816
+ paddingBottom: "0.5rem",
817
+ color:
818
+ onboardingElizaCloudTab === "login"
819
+ ? "#f0b90b"
820
+ : "var(--muted)",
821
+ background: "none",
822
+ border: "none",
823
+ borderBottom:
824
+ onboardingElizaCloudTab === "login"
825
+ ? "2px solid #f0b90b"
826
+ : "2px solid transparent",
827
+ cursor: "pointer",
828
+ }}
829
+ onClick={() => setState("onboardingElizaCloudTab", "login")}
830
+ >
831
+ {t("onboarding.login")}
832
+ </button>
833
+ <button
834
+ type="button"
835
+ style={{
836
+ fontSize: "0.875rem",
837
+ paddingBottom: "0.5rem",
838
+ borderBottom:
839
+ onboardingElizaCloudTab === "apikey"
840
+ ? "2px solid #f0b90b"
841
+ : "2px solid transparent",
842
+ color:
843
+ onboardingElizaCloudTab === "apikey"
844
+ ? "#f0b90b"
845
+ : "var(--muted)",
846
+ background: "none",
847
+ border: "none",
848
+ cursor: "pointer",
849
+ }}
850
+ onClick={() => setState("onboardingElizaCloudTab", "apikey")}
851
+ >
852
+ {t("onboarding.apiKey")}
853
+ </button>
854
+ </div>
855
+
856
+ {onboardingElizaCloudTab === "login" ? (
857
+ <div style={{ textAlign: "center" }}>
858
+ {elizaCloudConnected ? (
859
+ <div
860
+ style={{
861
+ display: "flex",
862
+ alignItems: "center",
863
+ gap: "0.5rem",
864
+ padding: "0.625rem 1rem",
865
+ border: "1px solid var(--ok-muted)",
866
+ background: "var(--ok-subtle)",
867
+ color: "var(--ok)",
868
+ fontSize: "0.875rem",
869
+ borderRadius: "0.5rem",
870
+ justifyContent: "center",
871
+ }}
872
+ >
873
+ <svg
874
+ width="16"
875
+ height="16"
876
+ viewBox="0 0 24 24"
877
+ fill="none"
878
+ stroke="currentColor"
879
+ strokeWidth="2.5"
880
+ strokeLinecap="round"
881
+ strokeLinejoin="round"
882
+ >
883
+ <title>{t("onboarding.connected")}</title>
884
+ <polyline points="20 6 9 17 4 12" />
885
+ </svg>
886
+ {t("onboarding.connected")}
887
+ </div>
888
+ ) : (
889
+ <button
890
+ type="button"
891
+ className="onboarding-confirm-btn"
892
+ onClick={handleCloudLogin}
893
+ disabled={elizaCloudLoginBusy}
894
+ >
895
+ {elizaCloudLoginBusy
896
+ ? t("onboarding.connecting")
897
+ : t("onboarding.connectAccount")}
898
+ </button>
899
+ )}
900
+ {elizaCloudLoginError &&
901
+ (() => {
902
+ const urlMatch = elizaCloudLoginError.match(
903
+ /^Open this link to log in: (.+)$/,
904
+ );
905
+ if (urlMatch) {
906
+ return (
907
+ <p
908
+ style={{
909
+ fontSize: "0.8125rem",
910
+ marginTop: "0.5rem",
911
+ color: "var(--text)",
912
+ }}
913
+ >
914
+ Open this link to log in:{" "}
915
+ <a
916
+ href={urlMatch[1]}
917
+ target="_blank"
918
+ rel="noopener noreferrer"
919
+ style={{
920
+ color: "var(--text)",
921
+ textDecoration: "underline",
922
+ }}
923
+ >
924
+ Click here
925
+ </a>
926
+ </p>
927
+ );
928
+ }
929
+ return (
930
+ <p
931
+ style={{
932
+ color: "var(--danger)",
933
+ fontSize: "0.8125rem",
934
+ marginTop: "0.5rem",
935
+ }}
936
+ >
937
+ {elizaCloudLoginError}
938
+ </p>
939
+ );
940
+ })()}
941
+ <p className="onboarding-desc">{t("onboarding.freeCredits")}</p>
942
+ </div>
943
+ ) : (
944
+ <div>
945
+ <label
946
+ htmlFor="elizacloud-apikey"
947
+ style={{
948
+ display: "block",
949
+ fontSize: "0.875rem",
950
+ marginBottom: "0.375rem",
951
+ color: "var(--muted)",
952
+ }}
953
+ >
954
+ {t("onboarding.apiKey")}
955
+ </label>
956
+ <input
957
+ id="elizacloud-apikey"
958
+ type="password"
959
+ className="onboarding-input"
960
+ placeholder="ec-..."
961
+ value={onboardingApiKey}
962
+ onChange={handleApiKeyChange}
963
+ />
964
+ <p className="onboarding-desc">
965
+ {t("onboarding.useExistingKey")}{" "}
966
+ <a
967
+ href="https://elizacloud.ai/dashboard/settings"
968
+ target="_blank"
969
+ rel="noopener noreferrer"
970
+ style={{ color: "var(--text)" }}
971
+ >
972
+ {t("onboarding.getOneHere")}
973
+ </a>
974
+ </p>
975
+ </div>
976
+ )}
977
+ </div>
978
+ )}
979
+
980
+ {/* anthropic-subscription */}
981
+ {onboardingProvider === "anthropic-subscription" && (
982
+ <div style={{ textAlign: "left", width: "100%" }}>
983
+ <div
984
+ style={{
985
+ display: "flex",
986
+ gap: "1rem",
987
+ borderBottom: "1px solid var(--border)",
988
+ marginBottom: "0.75rem",
989
+ }}
990
+ >
991
+ <button
992
+ type="button"
993
+ style={{
994
+ fontSize: "0.875rem",
995
+ paddingBottom: "0.5rem",
996
+ background: "none",
997
+ border: "none",
998
+ borderBottom:
999
+ onboardingSubscriptionTab === "token"
1000
+ ? "2px solid #f0b90b"
1001
+ : "2px solid transparent",
1002
+ color:
1003
+ onboardingSubscriptionTab === "token"
1004
+ ? "#f0b90b"
1005
+ : "var(--muted)",
1006
+ cursor: "pointer",
1007
+ }}
1008
+ onClick={() => setState("onboardingSubscriptionTab", "token")}
1009
+ >
1010
+ {t("onboarding.setupToken")}
1011
+ </button>
1012
+ <button
1013
+ type="button"
1014
+ style={{
1015
+ fontSize: "0.875rem",
1016
+ paddingBottom: "0.5rem",
1017
+ background: "none",
1018
+ border: "none",
1019
+ borderBottom:
1020
+ onboardingSubscriptionTab === "oauth"
1021
+ ? "2px solid #f0b90b"
1022
+ : "2px solid transparent",
1023
+ color:
1024
+ onboardingSubscriptionTab === "oauth"
1025
+ ? "#f0b90b"
1026
+ : "var(--muted)",
1027
+ cursor: "pointer",
1028
+ }}
1029
+ onClick={() => setState("onboardingSubscriptionTab", "oauth")}
1030
+ >
1031
+ {t("onboarding.oauthLogin")}
1032
+ </button>
1033
+ </div>
1034
+
1035
+ {onboardingSubscriptionTab === "token" ? (
1036
+ <>
1037
+ <span
1038
+ style={{
1039
+ fontSize: "0.8125rem",
1040
+ fontWeight: "bold",
1041
+ display: "block",
1042
+ marginBottom: "0.5rem",
1043
+ color: "var(--text)",
1044
+ }}
1045
+ >
1046
+ {t("onboarding.enterSetupToken")}
1047
+ </span>
1048
+ <input
1049
+ type="password"
1050
+ className="onboarding-input"
1051
+ value={onboardingApiKey}
1052
+ onChange={handleApiKeyChange}
1053
+ placeholder="sk-ant-oat01-..."
1054
+ />
1055
+ <p
1056
+ className="onboarding-desc"
1057
+ style={{ whiteSpace: "pre-line", textAlign: "left" }}
1058
+ >
1059
+ {t("onboarding.setupTokenInstructions")}
1060
+ </p>
1061
+ </>
1062
+ ) : anthropicConnected ? (
1063
+ <div
1064
+ style={{
1065
+ display: "flex",
1066
+ flexDirection: "column",
1067
+ alignItems: "center",
1068
+ gap: "0.75rem",
1069
+ }}
1070
+ >
1071
+ <div
1072
+ style={{
1073
+ display: "flex",
1074
+ alignItems: "center",
1075
+ gap: "0.5rem",
1076
+ padding: "0.75rem 1.5rem",
1077
+ border: "1px solid var(--ok-muted)",
1078
+ background: "var(--ok-subtle)",
1079
+ color: "var(--ok)",
1080
+ fontSize: "0.875rem",
1081
+ fontWeight: "500",
1082
+ width: "100%",
1083
+ maxWidth: "20rem",
1084
+ justifyContent: "center",
1085
+ }}
1086
+ >
1087
+ <svg
1088
+ width="18"
1089
+ height="18"
1090
+ viewBox="0 0 24 24"
1091
+ fill="none"
1092
+ stroke="currentColor"
1093
+ strokeWidth="2.5"
1094
+ strokeLinecap="round"
1095
+ strokeLinejoin="round"
1096
+ >
1097
+ <title>{t("onboarding.connected")}</title>
1098
+ <polyline points="20 6 9 17 4 12" />
1099
+ </svg>
1100
+ {t("onboarding.connectedToClaude")}
1101
+ </div>
1102
+ <p className="onboarding-desc" style={{ textAlign: "center" }}>
1103
+ {t("onboarding.claudeSubscriptionReady")}
1104
+ </p>
1105
+ </div>
1106
+ ) : !anthropicOAuthStarted ? (
1107
+ <div
1108
+ style={{
1109
+ display: "flex",
1110
+ flexDirection: "column",
1111
+ alignItems: "center",
1112
+ gap: "0.75rem",
1113
+ }}
1114
+ >
1115
+ <button
1116
+ type="button"
1117
+ className="onboarding-confirm-btn"
1118
+ onClick={() => void handleAnthropicStart()}
1119
+ >
1120
+ {t("onboarding.loginWithAnthropic")}
1121
+ </button>
1122
+ <p className="onboarding-desc" style={{ textAlign: "center" }}>
1123
+ {t("onboarding.requiresClaudeSub")}
1124
+ </p>
1125
+ {anthropicError && (
1126
+ <p style={{ fontSize: "0.75rem", color: "var(--danger)" }}>
1127
+ {anthropicError}
1128
+ </p>
1129
+ )}
1130
+ </div>
1131
+ ) : (
1132
+ <div
1133
+ style={{
1134
+ display: "flex",
1135
+ flexDirection: "column",
1136
+ alignItems: "center",
1137
+ gap: "0.75rem",
1138
+ }}
1139
+ >
1140
+ <p
1141
+ style={{
1142
+ fontSize: "0.875rem",
1143
+ textAlign: "center",
1144
+ color: "var(--text)",
1145
+ }}
1146
+ >
1147
+ {t("onboarding.authCodeInstructions")
1148
+ .split("\n")
1149
+ .map((line, i) => (
1150
+ <span key={line + String(i)}>
1151
+ {line}
1152
+ {i === 0 && <br />}
1153
+ </span>
1154
+ ))}
1155
+ </p>
1156
+ <input
1157
+ type="text"
1158
+ className="onboarding-input"
1159
+ placeholder={t("onboarding.pasteAuthCode")}
1160
+ value={anthropicCode}
1161
+ onChange={(e) => setAnthropicCode(e.target.value)}
1162
+ style={{ textAlign: "center" }}
1163
+ />
1164
+ {anthropicError && (
1165
+ <p style={{ fontSize: "0.75rem", color: "var(--danger)" }}>
1166
+ {anthropicError}
1167
+ </p>
1168
+ )}
1169
+ <button
1170
+ type="button"
1171
+ className="onboarding-confirm-btn"
1172
+ disabled={!anthropicCode}
1173
+ onClick={() => void handleAnthropicExchange()}
1174
+ >
1175
+ {t("onboarding.connect")}
1176
+ </button>
1177
+ </div>
1178
+ )}
1179
+ </div>
1180
+ )}
1181
+
1182
+ {/* openai-subscription */}
1183
+ {onboardingProvider === "openai-subscription" && (
1184
+ <div style={{ width: "100%" }}>
1185
+ {openaiConnected ? (
1186
+ <div
1187
+ style={{
1188
+ display: "flex",
1189
+ flexDirection: "column",
1190
+ alignItems: "center",
1191
+ gap: "0.75rem",
1192
+ }}
1193
+ >
1194
+ <div
1195
+ style={{
1196
+ display: "flex",
1197
+ alignItems: "center",
1198
+ gap: "0.5rem",
1199
+ padding: "0.75rem 1.5rem",
1200
+ border: "1px solid var(--ok-muted)",
1201
+ background: "var(--ok-subtle)",
1202
+ color: "var(--ok)",
1203
+ fontSize: "0.875rem",
1204
+ fontWeight: "500",
1205
+ width: "100%",
1206
+ maxWidth: "20rem",
1207
+ justifyContent: "center",
1208
+ }}
1209
+ >
1210
+ <svg
1211
+ width="18"
1212
+ height="18"
1213
+ viewBox="0 0 24 24"
1214
+ fill="none"
1215
+ stroke="currentColor"
1216
+ strokeWidth="2.5"
1217
+ strokeLinecap="round"
1218
+ strokeLinejoin="round"
1219
+ >
1220
+ <title>{t("onboarding.connected")}</title>
1221
+ <polyline points="20 6 9 17 4 12" />
1222
+ </svg>
1223
+ {t("onboarding.connectedToChatGPT")}
1224
+ </div>
1225
+ <p className="onboarding-desc" style={{ textAlign: "center" }}>
1226
+ {t("onboarding.chatgptSubscriptionReady")}
1227
+ </p>
1228
+ </div>
1229
+ ) : !openaiOAuthStarted ? (
1230
+ <div
1231
+ style={{
1232
+ display: "flex",
1233
+ flexDirection: "column",
1234
+ alignItems: "center",
1235
+ gap: "0.75rem",
1236
+ }}
1237
+ >
1238
+ <button
1239
+ type="button"
1240
+ className="onboarding-confirm-btn"
1241
+ onClick={() => void handleOpenAIStart()}
1242
+ >
1243
+ {t("onboarding.loginWithOpenAI")}
1244
+ </button>
1245
+ <p className="onboarding-desc" style={{ textAlign: "center" }}>
1246
+ {t("onboarding.requiresChatGPTSub")}
1247
+ </p>
1248
+ </div>
1249
+ ) : (
1250
+ <div
1251
+ style={{
1252
+ display: "flex",
1253
+ flexDirection: "column",
1254
+ gap: "0.75rem",
1255
+ }}
1256
+ >
1257
+ <div
1258
+ style={{
1259
+ padding: "0.75rem",
1260
+ border: "1px solid var(--border)",
1261
+ background: "var(--bg-hover)",
1262
+ fontSize: "0.875rem",
1263
+ borderRadius: "0.25rem",
1264
+ }}
1265
+ >
1266
+ <p
1267
+ style={{
1268
+ fontWeight: "500",
1269
+ marginBottom: "0.25rem",
1270
+ color: "var(--text)",
1271
+ }}
1272
+ >
1273
+ {t("onboarding.almostThere")}
1274
+ </p>
1275
+ <p
1276
+ className="onboarding-desc"
1277
+ style={{ lineHeight: "1.5", textAlign: "left" }}
1278
+ >
1279
+ {t("onboarding.redirectInstructions")}{" "}
1280
+ <code
1281
+ style={{
1282
+ background: "var(--bg-hover)",
1283
+ padding: "0 0.25rem",
1284
+ fontSize: "0.75rem",
1285
+ }}
1286
+ >
1287
+ localhost:1455
1288
+ </code>
1289
+ {t("onboarding.copyEntireUrl")}
1290
+ </p>
1291
+ </div>
1292
+ <input
1293
+ type="text"
1294
+ className="onboarding-input"
1295
+ placeholder="http://localhost:1455/..."
1296
+ value={openaiCallbackUrl}
1297
+ onChange={(e) => {
1298
+ setOpenaiCallbackUrl(e.target.value);
1299
+ setOpenaiError("");
1300
+ }}
1301
+ />
1302
+ {openaiError && (
1303
+ <p style={{ fontSize: "0.75rem", color: "var(--danger)" }}>
1304
+ {openaiError}
1305
+ </p>
1306
+ )}
1307
+ <div
1308
+ style={{
1309
+ display: "flex",
1310
+ gap: "0.5rem",
1311
+ justifyContent: "center",
1312
+ }}
1313
+ >
1314
+ <button
1315
+ type="button"
1316
+ className="onboarding-confirm-btn"
1317
+ disabled={!openaiCallbackUrl}
1318
+ onClick={() => void handleOpenAIExchange()}
1319
+ >
1320
+ {t("onboarding.completeLogin")}
1321
+ </button>
1322
+ <button
1323
+ type="button"
1324
+ className="onboarding-back-link"
1325
+ onClick={() => {
1326
+ setOpenaiOAuthStarted(false);
1327
+ setOpenaiCallbackUrl("");
1328
+ }}
1329
+ >
1330
+ {t("onboarding.startOver")}
1331
+ </button>
1332
+ </div>
1333
+ </div>
1334
+ )}
1335
+ </div>
1336
+ )}
1337
+
1338
+ {/* Generic API key providers */}
1339
+ {onboardingProvider &&
1340
+ onboardingProvider !== "anthropic-subscription" &&
1341
+ onboardingProvider !== "openai-subscription" &&
1342
+ onboardingProvider !== "elizacloud" &&
1343
+ onboardingProvider !== "ollama" &&
1344
+ onboardingProvider !== "pi-ai" && (
1345
+ <div style={{ textAlign: "left", width: "100%" }}>
1346
+ <span
1347
+ style={{
1348
+ fontSize: "0.8125rem",
1349
+ fontWeight: "bold",
1350
+ display: "block",
1351
+ marginBottom: "0.5rem",
1352
+ color: "var(--text)",
1353
+ }}
1354
+ >
1355
+ {t("onboarding.apiKey")}
1356
+ </span>
1357
+ <input
1358
+ type="password"
1359
+ className="onboarding-input"
1360
+ value={onboardingApiKey}
1361
+ onChange={handleApiKeyChange}
1362
+ placeholder={t("onboarding.enterApiKey")}
1363
+ />
1364
+ {apiKeyFormatWarning && (
1365
+ <p
1366
+ style={{
1367
+ fontSize: "0.75rem",
1368
+ color: "var(--danger)",
1369
+ marginTop: "0.5rem",
1370
+ }}
1371
+ >
1372
+ {apiKeyFormatWarning}
1373
+ </p>
1374
+ )}
1375
+ </div>
1376
+ )}
1377
+
1378
+ {/* ollama */}
1379
+ {onboardingProvider === "ollama" && (
1380
+ <p className="onboarding-desc">{t("onboarding.ollamaNoConfig")}</p>
1381
+ )}
1382
+
1383
+ {/* pi-ai */}
1384
+ {onboardingProvider === "pi-ai" && (
1385
+ <div style={{ textAlign: "left", width: "100%" }}>
1386
+ <span
1387
+ style={{
1388
+ fontSize: "0.8125rem",
1389
+ fontWeight: "bold",
1390
+ display: "block",
1391
+ marginBottom: "0.5rem",
1392
+ color: "var(--text)",
1393
+ }}
1394
+ >
1395
+ {t("onboarding.primaryModelOptional")}
1396
+ </span>
1397
+ {piAiModels.length > 0 ? (
1398
+ <>
1399
+ <select
1400
+ value={piAiSelectValue}
1401
+ onChange={(e) => {
1402
+ const next = e.target.value;
1403
+ if (next === "__custom__") {
1404
+ if (piAiSelectValue !== "__custom__") {
1405
+ setState("onboardingPrimaryModel", "");
1406
+ }
1407
+ return;
1408
+ }
1409
+ setState("onboardingPrimaryModel", next);
1410
+ }}
1411
+ className="onboarding-input"
1412
+ >
1413
+ <option value="">
1414
+ {t("onboarding.useDefaultModel")}
1415
+ {piAiDefaultModel ? ` (${piAiDefaultModel})` : ""}
1416
+ </option>
1417
+ {piAiModels.map((model: PiAiModelOption) => (
1418
+ <option key={model.id} value={model.id}>
1419
+ {model.name} ({model.provider})
1420
+ </option>
1421
+ ))}
1422
+ <option value="__custom__">
1423
+ {t("onboarding.customModel")}
1424
+ </option>
1425
+ </select>
1426
+ {piAiSelectValue === "__custom__" && (
1427
+ <input
1428
+ type="text"
1429
+ className="onboarding-input"
1430
+ value={onboardingPrimaryModel}
1431
+ onChange={(e) =>
1432
+ setState("onboardingPrimaryModel", e.target.value)
1433
+ }
1434
+ placeholder="provider/model (e.g. anthropic/claude-3.5-sonnet)"
1435
+ style={{ marginTop: "0.5rem" }}
1436
+ />
1437
+ )}
1438
+ </>
1439
+ ) : (
1440
+ <input
1441
+ type="text"
1442
+ className="onboarding-input"
1443
+ value={onboardingPrimaryModel}
1444
+ onChange={(e) =>
1445
+ setState("onboardingPrimaryModel", e.target.value)
1446
+ }
1447
+ placeholder="provider/model (e.g. anthropic/claude-3.5-sonnet)"
1448
+ />
1449
+ )}
1450
+ <p className="onboarding-desc" style={{ textAlign: "left" }}>
1451
+ {t("onboarding.piCredentialsHint")}
1452
+ {piAiModels.length > 0
1453
+ ? t("onboarding.piDropdownHint")
1454
+ : t("onboarding.piManualHint")}
1455
+ </p>
1456
+ </div>
1457
+ )}
1458
+
1459
+ {/* openrouter model selection */}
1460
+ {onboardingProvider === "openrouter" &&
1461
+ onboardingApiKey.trim() &&
1462
+ onboardingOptions?.openrouterModels && (
1463
+ <div style={{ marginTop: "1rem", textAlign: "left", width: "100%" }}>
1464
+ <span
1465
+ style={{
1466
+ fontSize: "0.8125rem",
1467
+ fontWeight: "bold",
1468
+ display: "block",
1469
+ marginBottom: "0.5rem",
1470
+ color: "var(--text)",
1471
+ }}
1472
+ >
1473
+ {t("onboarding.selectModel")}
1474
+ </span>
1475
+ <div
1476
+ style={{
1477
+ display: "flex",
1478
+ flexDirection: "column",
1479
+ gap: "0.5rem",
1480
+ }}
1481
+ >
1482
+ {onboardingOptions?.openrouterModels?.map(
1483
+ (model: OpenRouterModelOption) => (
1484
+ <button
1485
+ type="button"
1486
+ key={model.id}
1487
+ className={`onboarding-provider-card${onboardingOpenRouterModel === model.id ? " onboarding-provider-card--selected" : ""}`}
1488
+ onClick={() => handleOpenRouterModelSelect(model.id)}
1489
+ style={{ width: "100%" }}
1490
+ >
1491
+ <div>
1492
+ <div className="onboarding-provider-name">
1493
+ {model.name}
1494
+ </div>
1495
+ {model.description && (
1496
+ <div className="onboarding-provider-desc">
1497
+ {model.description}
1498
+ </div>
1499
+ )}
1500
+ </div>
1501
+ </button>
1502
+ ),
1503
+ )}
1504
+ </div>
1505
+ </div>
1506
+ )}
1507
+
1508
+ <div className="onboarding-panel-footer">
1509
+ <button
1510
+ className="onboarding-back-link"
1511
+ onClick={() => {
1512
+ setState("onboardingProvider", "");
1513
+ setState("onboardingApiKey", "");
1514
+ setState("onboardingPrimaryModel", "");
1515
+ }}
1516
+ type="button"
1517
+ >
1518
+ {t("onboarding.back")}
1519
+ </button>
1520
+ <button
1521
+ className="onboarding-confirm-btn"
1522
+ onClick={() => handleOnboardingNext()}
1523
+ type="button"
1524
+ >
1525
+ {t("onboarding.confirm")}
1526
+ </button>
1527
+ </div>
1528
+ </>
1529
+ );
1530
+ }