@elizaos/app-core 2.0.0-alpha.73 → 2.0.0-alpha.75

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 (1143) hide show
  1. package/App.d.ts +5 -0
  2. package/App.d.ts.map +1 -0
  3. package/App.js +220 -0
  4. package/actions/character.d.ts +39 -0
  5. package/actions/character.d.ts.map +1 -0
  6. package/actions/character.js +247 -0
  7. package/actions/chat-helpers.d.ts +47 -0
  8. package/actions/chat-helpers.d.ts.map +1 -0
  9. package/actions/chat-helpers.js +79 -0
  10. package/actions/cloud.d.ts +17 -0
  11. package/actions/cloud.d.ts.map +1 -0
  12. package/actions/cloud.js +43 -0
  13. package/actions/index.d.ts +12 -0
  14. package/actions/index.d.ts.map +1 -0
  15. package/actions/index.js +11 -0
  16. package/actions/lifecycle.d.ts +43 -0
  17. package/actions/lifecycle.d.ts.map +1 -0
  18. package/actions/lifecycle.js +118 -0
  19. package/actions/onboarding.d.ts +12 -0
  20. package/actions/onboarding.d.ts.map +1 -0
  21. package/actions/onboarding.js +26 -0
  22. package/actions/triggers.d.ts +23 -0
  23. package/actions/triggers.d.ts.map +1 -0
  24. package/actions/triggers.js +148 -0
  25. package/api/client.d.ts +2736 -0
  26. package/api/client.d.ts.map +1 -0
  27. package/api/client.js +2492 -0
  28. package/api/index.d.ts +2 -0
  29. package/api/index.d.ts.map +1 -0
  30. package/autonomy/index.d.ts +48 -0
  31. package/autonomy/index.d.ts.map +1 -0
  32. package/autonomy/index.js +330 -0
  33. package/bridge/capacitor-bridge.d.ts +153 -0
  34. package/bridge/capacitor-bridge.d.ts.map +1 -0
  35. package/bridge/capacitor-bridge.js +193 -0
  36. package/bridge/electrobun-rpc.d.ts +28 -0
  37. package/bridge/electrobun-rpc.d.ts.map +1 -0
  38. package/bridge/electrobun-rpc.js +35 -0
  39. package/bridge/electrobun-runtime.d.ts +3 -0
  40. package/bridge/electrobun-runtime.d.ts.map +1 -0
  41. package/bridge/electrobun-runtime.js +17 -0
  42. package/bridge/index.d.ts +6 -0
  43. package/bridge/index.d.ts.map +1 -0
  44. package/bridge/native-plugins.d.ts +82 -0
  45. package/bridge/native-plugins.d.ts.map +1 -0
  46. package/bridge/native-plugins.js +39 -0
  47. package/bridge/plugin-bridge.d.ts +116 -0
  48. package/bridge/plugin-bridge.d.ts.map +1 -0
  49. package/bridge/plugin-bridge.js +203 -0
  50. package/bridge/storage-bridge.d.ts +39 -0
  51. package/bridge/storage-bridge.d.ts.map +1 -0
  52. package/bridge/storage-bridge.js +135 -0
  53. package/chat/index.d.ts +57 -0
  54. package/chat/index.d.ts.map +1 -0
  55. package/chat/index.js +160 -0
  56. package/coding/index.d.ts +25 -0
  57. package/coding/index.d.ts.map +1 -0
  58. package/coding/index.js +25 -0
  59. package/components/AdvancedPageView.d.ts +17 -0
  60. package/components/AdvancedPageView.d.ts.map +1 -0
  61. package/components/AdvancedPageView.js +146 -0
  62. package/components/AgentActivityBox.d.ts +7 -0
  63. package/components/AgentActivityBox.d.ts.map +1 -0
  64. package/components/AgentActivityBox.js +25 -0
  65. package/components/ApiKeyConfig.d.ts +26 -0
  66. package/components/ApiKeyConfig.d.ts.map +1 -0
  67. package/components/ApiKeyConfig.js +119 -0
  68. package/components/AppsPageView.d.ts +7 -0
  69. package/components/AppsPageView.d.ts.map +1 -0
  70. package/components/AppsPageView.js +31 -0
  71. package/components/AppsView.d.ts +8 -0
  72. package/components/AppsView.d.ts.map +1 -0
  73. package/components/AppsView.js +149 -0
  74. package/components/AvatarLoader.d.ts +13 -0
  75. package/components/AvatarLoader.d.ts.map +1 -0
  76. package/components/AvatarLoader.js +53 -0
  77. package/components/AvatarSelector.d.ts +23 -0
  78. package/components/AvatarSelector.d.ts.map +1 -0
  79. package/components/AvatarSelector.js +105 -0
  80. package/components/BscTradePanel.d.ts +22 -0
  81. package/components/BscTradePanel.d.ts.map +1 -0
  82. package/components/BscTradePanel.js +221 -0
  83. package/components/BugReportModal.d.ts +2 -0
  84. package/components/BugReportModal.d.ts.map +1 -0
  85. package/components/BugReportModal.js +219 -0
  86. package/components/CharacterRoster.d.ts +31 -0
  87. package/components/CharacterRoster.d.ts.map +1 -0
  88. package/components/CharacterRoster.js +41 -0
  89. package/components/CharacterView.d.ts +8 -0
  90. package/components/CharacterView.d.ts.map +1 -0
  91. package/components/CharacterView.js +685 -0
  92. package/components/ChatAvatar.d.ts +8 -0
  93. package/components/ChatAvatar.d.ts.map +1 -0
  94. package/components/ChatAvatar.js +89 -0
  95. package/components/ChatComposer.d.ts +37 -0
  96. package/components/ChatComposer.d.ts.map +1 -0
  97. package/components/ChatComposer.js +136 -0
  98. package/components/ChatMessage.d.ts +24 -0
  99. package/components/ChatMessage.d.ts.map +1 -0
  100. package/components/ChatMessage.js +167 -0
  101. package/components/ChatModalView.d.ts +10 -0
  102. package/components/ChatModalView.d.ts.map +1 -0
  103. package/components/ChatModalView.js +57 -0
  104. package/components/ChatView.d.ts +14 -0
  105. package/components/ChatView.d.ts.map +1 -0
  106. package/components/ChatView.js +526 -0
  107. package/components/CloudOnboarding.d.ts +7 -0
  108. package/components/CloudOnboarding.d.ts.map +1 -0
  109. package/components/CloudOnboarding.js +22 -0
  110. package/components/CloudSourceControls.d.ts +13 -0
  111. package/components/CloudSourceControls.d.ts.map +1 -0
  112. package/components/CloudSourceControls.js +16 -0
  113. package/components/CodingAgentSettingsSection.d.ts +2 -0
  114. package/components/CodingAgentSettingsSection.d.ts.map +1 -0
  115. package/components/CodingAgentSettingsSection.js +270 -0
  116. package/components/CommandPalette.d.ts +2 -0
  117. package/components/CommandPalette.d.ts.map +1 -0
  118. package/components/CommandPalette.js +181 -0
  119. package/components/CompanionSceneHost.d.ts +14 -0
  120. package/components/CompanionSceneHost.d.ts.map +1 -0
  121. package/components/CompanionSceneHost.js +360 -0
  122. package/components/CompanionShell.d.ts +17 -0
  123. package/components/CompanionShell.d.ts.map +1 -0
  124. package/components/CompanionShell.js +15 -0
  125. package/components/CompanionView.d.ts +2 -0
  126. package/components/CompanionView.d.ts.map +1 -0
  127. package/components/CompanionView.js +22 -0
  128. package/components/ConfigPageView.d.ts +11 -0
  129. package/components/ConfigPageView.d.ts.map +1 -0
  130. package/components/ConfigPageView.js +303 -0
  131. package/components/ConfigSaveFooter.d.ts +8 -0
  132. package/components/ConfigSaveFooter.d.ts.map +1 -0
  133. package/components/ConfigSaveFooter.js +10 -0
  134. package/components/ConfirmModal.d.ts +61 -0
  135. package/components/ConfirmModal.d.ts.map +1 -0
  136. package/components/ConfirmModal.js +164 -0
  137. package/components/ConnectionFailedBanner.d.ts +6 -0
  138. package/components/ConnectionFailedBanner.d.ts.map +1 -0
  139. package/components/ConnectionFailedBanner.js +22 -0
  140. package/components/ConnectorsPageView.d.ts +7 -0
  141. package/components/ConnectorsPageView.d.ts.map +1 -0
  142. package/components/ConnectorsPageView.js +8 -0
  143. package/components/ConversationsSidebar.d.ts +9 -0
  144. package/components/ConversationsSidebar.d.ts.map +1 -0
  145. package/components/ConversationsSidebar.js +116 -0
  146. package/components/CustomActionEditor.d.ts +10 -0
  147. package/components/CustomActionEditor.d.ts.map +1 -0
  148. package/components/CustomActionEditor.js +578 -0
  149. package/components/CustomActionsPanel.d.ts +9 -0
  150. package/components/CustomActionsPanel.d.ts.map +1 -0
  151. package/components/CustomActionsPanel.js +107 -0
  152. package/components/CustomActionsView.d.ts +2 -0
  153. package/components/CustomActionsView.d.ts.map +1 -0
  154. package/components/CustomActionsView.js +134 -0
  155. package/components/DatabasePageView.d.ts +5 -0
  156. package/components/DatabasePageView.d.ts.map +1 -0
  157. package/components/DatabasePageView.js +28 -0
  158. package/components/DatabaseView.d.ts +9 -0
  159. package/components/DatabaseView.d.ts.map +1 -0
  160. package/components/DatabaseView.js +311 -0
  161. package/components/ElizaCloudDashboard.d.ts +2 -0
  162. package/components/ElizaCloudDashboard.d.ts.map +1 -0
  163. package/components/ElizaCloudDashboard.js +657 -0
  164. package/components/EmotePicker.d.ts +2 -0
  165. package/components/EmotePicker.d.ts.map +1 -0
  166. package/components/EmotePicker.js +343 -0
  167. package/components/ErrorBoundary.d.ts +22 -0
  168. package/components/ErrorBoundary.d.ts.map +1 -0
  169. package/components/ErrorBoundary.js +31 -0
  170. package/components/FineTuningView.d.ts +2 -0
  171. package/components/FineTuningView.d.ts.map +1 -0
  172. package/components/FineTuningView.js +433 -0
  173. package/components/FlaminaGuide.d.ts +10 -0
  174. package/components/FlaminaGuide.d.ts.map +1 -0
  175. package/components/FlaminaGuide.js +64 -0
  176. package/components/GameView.d.ts +11 -0
  177. package/components/GameView.d.ts.map +1 -0
  178. package/components/GameView.js +294 -0
  179. package/components/GameViewOverlay.d.ts +8 -0
  180. package/components/GameViewOverlay.d.ts.map +1 -0
  181. package/components/GameViewOverlay.js +70 -0
  182. package/components/GlobalEmoteOverlay.d.ts +2 -0
  183. package/components/GlobalEmoteOverlay.d.ts.map +1 -0
  184. package/components/GlobalEmoteOverlay.js +112 -0
  185. package/components/Header.d.ts +9 -0
  186. package/components/Header.d.ts.map +1 -0
  187. package/components/Header.js +123 -0
  188. package/components/HeartbeatsView.d.ts +2 -0
  189. package/components/HeartbeatsView.d.ts.map +1 -0
  190. package/components/HeartbeatsView.js +378 -0
  191. package/components/InventoryView.d.ts +10 -0
  192. package/components/InventoryView.d.ts.map +1 -0
  193. package/components/InventoryView.js +176 -0
  194. package/components/KnowledgeView.d.ts +20 -0
  195. package/components/KnowledgeView.d.ts.map +1 -0
  196. package/components/KnowledgeView.js +480 -0
  197. package/components/LanguageDropdown.d.ts +30 -0
  198. package/components/LanguageDropdown.d.ts.map +1 -0
  199. package/components/LanguageDropdown.js +99 -0
  200. package/components/LifoMonitorPanel.d.ts +21 -0
  201. package/components/LifoMonitorPanel.d.ts.map +1 -0
  202. package/components/LifoMonitorPanel.js +24 -0
  203. package/components/LifoSandboxView.d.ts +5 -0
  204. package/components/LifoSandboxView.d.ts.map +1 -0
  205. package/components/LifoSandboxView.js +333 -0
  206. package/components/LoadingScreen.d.ts +13 -0
  207. package/components/LoadingScreen.d.ts.map +1 -0
  208. package/components/LoadingScreen.js +70 -0
  209. package/components/LogsPageView.d.ts +2 -0
  210. package/components/LogsPageView.d.ts.map +1 -0
  211. package/components/LogsPageView.js +7 -0
  212. package/components/LogsView.d.ts +5 -0
  213. package/components/LogsView.d.ts.map +1 -0
  214. package/components/LogsView.js +71 -0
  215. package/components/MediaGalleryView.d.ts +9 -0
  216. package/components/MediaGalleryView.d.ts.map +1 -0
  217. package/components/MediaGalleryView.js +236 -0
  218. package/components/MediaSettingsSection.d.ts +11 -0
  219. package/components/MediaSettingsSection.d.ts.map +1 -0
  220. package/components/MediaSettingsSection.js +329 -0
  221. package/components/MessageContent.d.ts +51 -0
  222. package/components/MessageContent.d.ts.map +1 -0
  223. package/components/MessageContent.js +553 -0
  224. package/components/OnboardingWizard.d.ts +2 -0
  225. package/components/OnboardingWizard.d.ts.map +1 -0
  226. package/components/OnboardingWizard.js +96 -0
  227. package/components/PairingView.d.ts +5 -0
  228. package/components/PairingView.d.ts.map +1 -0
  229. package/components/PairingView.js +29 -0
  230. package/components/PermissionsSection.d.ts +20 -0
  231. package/components/PermissionsSection.d.ts.map +1 -0
  232. package/components/PermissionsSection.js +573 -0
  233. package/components/PluginsPageView.d.ts +5 -0
  234. package/components/PluginsPageView.d.ts.map +1 -0
  235. package/components/PluginsPageView.js +8 -0
  236. package/components/PluginsView.d.ts +21 -0
  237. package/components/PluginsView.d.ts.map +1 -0
  238. package/components/PluginsView.js +1534 -0
  239. package/components/ProviderSwitcher.d.ts +42 -0
  240. package/components/ProviderSwitcher.d.ts.map +1 -0
  241. package/components/ProviderSwitcher.js +493 -0
  242. package/components/RestartBanner.d.ts +2 -0
  243. package/components/RestartBanner.d.ts.map +1 -0
  244. package/components/RestartBanner.js +36 -0
  245. package/components/RuntimeView.d.ts +10 -0
  246. package/components/RuntimeView.d.ts.map +1 -0
  247. package/components/RuntimeView.js +165 -0
  248. package/components/SaveCommandModal.d.ts +12 -0
  249. package/components/SaveCommandModal.d.ts.map +1 -0
  250. package/components/SaveCommandModal.js +84 -0
  251. package/components/SecretsView.d.ts +9 -0
  252. package/components/SecretsView.d.ts.map +1 -0
  253. package/components/SecretsView.js +249 -0
  254. package/components/SettingsView.d.ts +9 -0
  255. package/components/SettingsView.d.ts.map +1 -0
  256. package/components/SettingsView.js +230 -0
  257. package/components/ShellOverlays.d.ts +8 -0
  258. package/components/ShellOverlays.d.ts.map +1 -0
  259. package/components/ShellOverlays.js +10 -0
  260. package/components/ShortcutsOverlay.d.ts +2 -0
  261. package/components/ShortcutsOverlay.d.ts.map +1 -0
  262. package/components/ShortcutsOverlay.js +79 -0
  263. package/components/SkillsView.d.ts +11 -0
  264. package/components/SkillsView.d.ts.map +1 -0
  265. package/components/SkillsView.js +358 -0
  266. package/components/StartupFailureView.d.ts +8 -0
  267. package/components/StartupFailureView.d.ts.map +1 -0
  268. package/components/StartupFailureView.js +16 -0
  269. package/components/StreamView.d.ts +16 -0
  270. package/components/StreamView.d.ts.map +1 -0
  271. package/components/StreamView.js +300 -0
  272. package/components/StripeEmbeddedCheckout.d.ts +24 -0
  273. package/components/StripeEmbeddedCheckout.d.ts.map +1 -0
  274. package/components/StripeEmbeddedCheckout.js +101 -0
  275. package/components/SubscriptionStatus.d.ts +23 -0
  276. package/components/SubscriptionStatus.d.ts.map +1 -0
  277. package/components/SubscriptionStatus.js +301 -0
  278. package/components/SystemWarningBanner.d.ts +6 -0
  279. package/components/SystemWarningBanner.d.ts.map +1 -0
  280. package/components/SystemWarningBanner.js +46 -0
  281. package/components/ThemeToggle.d.ts +21 -0
  282. package/components/ThemeToggle.d.ts.map +1 -0
  283. package/components/ThemeToggle.js +24 -0
  284. package/components/TrajectoriesView.d.ts +12 -0
  285. package/components/TrajectoriesView.d.ts.map +1 -0
  286. package/components/TrajectoriesView.js +183 -0
  287. package/components/TrajectoryDetailView.d.ts +13 -0
  288. package/components/TrajectoryDetailView.d.ts.map +1 -0
  289. package/components/TrajectoryDetailView.js +112 -0
  290. package/components/TriggersView.d.ts +2 -0
  291. package/components/TriggersView.d.ts.map +1 -0
  292. package/components/VectorBrowserView.d.ts +10 -0
  293. package/components/VectorBrowserView.d.ts.map +1 -0
  294. package/components/VectorBrowserView.js +997 -0
  295. package/components/VoiceConfigView.d.ts +11 -0
  296. package/components/VoiceConfigView.d.ts.map +1 -0
  297. package/components/VoiceConfigView.js +329 -0
  298. package/components/VrmStage.d.ts +28 -0
  299. package/components/VrmStage.d.ts.map +1 -0
  300. package/components/VrmStage.js +178 -0
  301. package/components/WhatsAppQrOverlay.d.ts +8 -0
  302. package/components/WhatsAppQrOverlay.d.ts.map +1 -0
  303. package/components/WhatsAppQrOverlay.js +63 -0
  304. package/components/apps/AppDetailPane.d.ts +15 -0
  305. package/components/apps/AppDetailPane.d.ts.map +1 -0
  306. package/components/apps/AppDetailPane.js +13 -0
  307. package/components/apps/AppsCatalogGrid.d.ts +20 -0
  308. package/components/apps/AppsCatalogGrid.d.ts.map +1 -0
  309. package/components/apps/AppsCatalogGrid.js +18 -0
  310. package/components/apps/extensions/registry.d.ts +4 -0
  311. package/components/apps/extensions/registry.d.ts.map +1 -0
  312. package/components/apps/extensions/registry.js +7 -0
  313. package/components/apps/extensions/types.d.ts +7 -0
  314. package/components/apps/extensions/types.d.ts.map +1 -0
  315. package/components/apps/extensions/types.js +1 -0
  316. package/components/apps/helpers.d.ts +7 -0
  317. package/components/apps/helpers.d.ts.map +1 -0
  318. package/components/apps/helpers.js +44 -0
  319. package/components/avatar/VrmAnimationLoader.d.ts +30 -0
  320. package/components/avatar/VrmAnimationLoader.d.ts.map +1 -0
  321. package/components/avatar/VrmAnimationLoader.js +99 -0
  322. package/components/avatar/VrmBlinkController.d.ts +37 -0
  323. package/components/avatar/VrmBlinkController.d.ts.map +1 -0
  324. package/components/avatar/VrmBlinkController.js +98 -0
  325. package/components/avatar/VrmCameraManager.d.ts +57 -0
  326. package/components/avatar/VrmCameraManager.d.ts.map +1 -0
  327. package/components/avatar/VrmCameraManager.js +277 -0
  328. package/components/avatar/VrmEngine.d.ts +246 -0
  329. package/components/avatar/VrmEngine.d.ts.map +1 -0
  330. package/components/avatar/VrmEngine.js +2076 -0
  331. package/components/avatar/VrmFootShadow.d.ts +18 -0
  332. package/components/avatar/VrmFootShadow.d.ts.map +1 -0
  333. package/components/avatar/VrmFootShadow.js +83 -0
  334. package/components/avatar/VrmViewer.d.ts +60 -0
  335. package/components/avatar/VrmViewer.d.ts.map +1 -0
  336. package/components/avatar/VrmViewer.js +396 -0
  337. package/components/avatar/mixamoVRMRigMap.d.ts +3 -0
  338. package/components/avatar/mixamoVRMRigMap.d.ts.map +1 -0
  339. package/components/avatar/mixamoVRMRigMap.js +56 -0
  340. package/components/avatar/retargetMixamoFbxToVrm.d.ts +9 -0
  341. package/components/avatar/retargetMixamoFbxToVrm.d.ts.map +1 -0
  342. package/components/avatar/retargetMixamoFbxToVrm.js +88 -0
  343. package/components/avatar/retargetMixamoGltfToVrm.d.ts +11 -0
  344. package/components/avatar/retargetMixamoGltfToVrm.d.ts.map +1 -0
  345. package/components/avatar/retargetMixamoGltfToVrm.js +80 -0
  346. package/components/chainConfig.d.ts +89 -0
  347. package/components/chainConfig.d.ts.map +1 -0
  348. package/components/chainConfig.js +287 -0
  349. package/components/companion/CompanionHeader.d.ts +15 -0
  350. package/components/companion/CompanionHeader.d.ts.map +1 -0
  351. package/components/companion/CompanionHeader.js +7 -0
  352. package/components/companion/CompanionSceneHost.d.ts +2 -0
  353. package/components/companion/CompanionSceneHost.d.ts.map +1 -0
  354. package/components/companion/CompanionSceneHost.js +1 -0
  355. package/components/companion/VrmStage.d.ts +3 -0
  356. package/components/companion/VrmStage.d.ts.map +1 -0
  357. package/components/companion/VrmStage.js +1 -0
  358. package/components/companion/index.d.ts +18 -0
  359. package/components/companion/index.d.ts.map +1 -0
  360. package/components/companion/index.js +17 -0
  361. package/components/companion/walletUtils.d.ts +95 -0
  362. package/components/companion/walletUtils.d.ts.map +1 -0
  363. package/components/companion/walletUtils.js +167 -0
  364. package/components/companion-shell-styles.d.ts +38 -0
  365. package/components/companion-shell-styles.d.ts.map +1 -0
  366. package/components/companion-shell-styles.js +248 -0
  367. package/components/confirm-delete-control.d.ts +16 -0
  368. package/components/confirm-delete-control.d.ts.map +1 -0
  369. package/components/confirm-delete-control.js +12 -0
  370. package/components/conversations/ConversationListItem.d.ts +31 -0
  371. package/components/conversations/ConversationListItem.d.ts.map +1 -0
  372. package/components/conversations/ConversationListItem.js +52 -0
  373. package/components/conversations/conversation-utils.d.ts +9 -0
  374. package/components/conversations/conversation-utils.d.ts.map +1 -0
  375. package/components/conversations/conversation-utils.js +138 -0
  376. package/components/format.d.ts +54 -0
  377. package/components/format.d.ts.map +1 -0
  378. package/components/format.js +82 -0
  379. package/components/index.d.ts +96 -0
  380. package/components/index.d.ts.map +1 -0
  381. package/components/index.js +95 -0
  382. package/components/inventory/CopyableAddress.d.ts +8 -0
  383. package/components/inventory/CopyableAddress.d.ts.map +1 -0
  384. package/components/inventory/CopyableAddress.js +18 -0
  385. package/components/inventory/InventoryToolbar.d.ts +25 -0
  386. package/components/inventory/InventoryToolbar.d.ts.map +1 -0
  387. package/components/inventory/InventoryToolbar.js +28 -0
  388. package/components/inventory/NftGrid.d.ts +13 -0
  389. package/components/inventory/NftGrid.d.ts.map +1 -0
  390. package/components/inventory/NftGrid.js +29 -0
  391. package/components/inventory/TokenLogo.d.ts +12 -0
  392. package/components/inventory/TokenLogo.d.ts.map +1 -0
  393. package/components/inventory/TokenLogo.js +33 -0
  394. package/components/inventory/TokensTable.d.ts +24 -0
  395. package/components/inventory/TokensTable.d.ts.map +1 -0
  396. package/components/inventory/TokensTable.js +26 -0
  397. package/components/inventory/constants.d.ts +52 -0
  398. package/components/inventory/constants.d.ts.map +1 -0
  399. package/components/inventory/constants.js +121 -0
  400. package/components/inventory/index.d.ts +9 -0
  401. package/components/inventory/index.d.ts.map +1 -0
  402. package/components/inventory/index.js +8 -0
  403. package/components/inventory/media-url.d.ts +6 -0
  404. package/components/inventory/media-url.d.ts.map +1 -0
  405. package/components/inventory/media-url.js +28 -0
  406. package/components/inventory/useInventoryData.d.ts +53 -0
  407. package/components/inventory/useInventoryData.d.ts.map +1 -0
  408. package/components/inventory/useInventoryData.js +332 -0
  409. package/components/knowledge-upload-image.d.ts +27 -0
  410. package/components/knowledge-upload-image.d.ts.map +1 -0
  411. package/components/knowledge-upload-image.js +146 -0
  412. package/components/labels.d.ts +6 -0
  413. package/components/labels.d.ts.map +1 -0
  414. package/components/labels.js +40 -0
  415. package/components/onboarding/ActivateStep.d.ts +2 -0
  416. package/components/onboarding/ActivateStep.d.ts.map +1 -0
  417. package/components/onboarding/ActivateStep.js +10 -0
  418. package/components/onboarding/ConnectionStep.d.ts +2 -0
  419. package/components/onboarding/ConnectionStep.d.ts.map +1 -0
  420. package/components/onboarding/ConnectionStep.js +609 -0
  421. package/components/onboarding/IdentityStep.d.ts +2 -0
  422. package/components/onboarding/IdentityStep.d.ts.map +1 -0
  423. package/components/onboarding/IdentityStep.js +102 -0
  424. package/components/onboarding/OnboardingPanel.d.ts +9 -0
  425. package/components/onboarding/OnboardingPanel.d.ts.map +1 -0
  426. package/components/onboarding/OnboardingPanel.js +24 -0
  427. package/components/onboarding/OnboardingStepNav.d.ts +2 -0
  428. package/components/onboarding/OnboardingStepNav.d.ts.map +1 -0
  429. package/components/onboarding/OnboardingStepNav.js +23 -0
  430. package/components/onboarding/PermissionsStep.d.ts +2 -0
  431. package/components/onboarding/PermissionsStep.d.ts.map +1 -0
  432. package/components/onboarding/PermissionsStep.js +7 -0
  433. package/components/onboarding/RpcStep.d.ts +2 -0
  434. package/components/onboarding/RpcStep.d.ts.map +1 -0
  435. package/components/onboarding/RpcStep.js +125 -0
  436. package/components/permissions/PermissionIcon.d.ts +4 -0
  437. package/components/permissions/PermissionIcon.d.ts.map +1 -0
  438. package/components/permissions/PermissionIcon.js +12 -0
  439. package/components/permissions/StreamingPermissions.d.ts +20 -0
  440. package/components/permissions/StreamingPermissions.d.ts.map +1 -0
  441. package/components/permissions/StreamingPermissions.js +177 -0
  442. package/components/plugins/showcase-data.d.ts +7 -0
  443. package/components/plugins/showcase-data.d.ts.map +1 -0
  444. package/components/plugins/showcase-data.js +464 -0
  445. package/components/shared/ShellHeaderControls.d.ts +27 -0
  446. package/components/shared/ShellHeaderControls.d.ts.map +1 -0
  447. package/components/shared/ShellHeaderControls.js +60 -0
  448. package/components/shared-companion-scene-context.d.ts +3 -0
  449. package/components/shared-companion-scene-context.d.ts.map +1 -0
  450. package/components/shared-companion-scene-context.js +13 -0
  451. package/components/skeletons.d.ts +17 -0
  452. package/components/skeletons.d.ts.map +1 -0
  453. package/components/skeletons.js +22 -0
  454. package/components/stream/ActivityFeed.d.ts +5 -0
  455. package/components/stream/ActivityFeed.d.ts.map +1 -0
  456. package/components/stream/ActivityFeed.js +57 -0
  457. package/components/stream/AvatarPip.d.ts +5 -0
  458. package/components/stream/AvatarPip.d.ts.map +1 -0
  459. package/components/stream/AvatarPip.js +6 -0
  460. package/components/stream/ChatContent.d.ts +6 -0
  461. package/components/stream/ChatContent.d.ts.map +1 -0
  462. package/components/stream/ChatContent.js +69 -0
  463. package/components/stream/ChatTicker.d.ts +5 -0
  464. package/components/stream/ChatTicker.d.ts.map +1 -0
  465. package/components/stream/ChatTicker.js +34 -0
  466. package/components/stream/IdleContent.d.ts +5 -0
  467. package/components/stream/IdleContent.d.ts.map +1 -0
  468. package/components/stream/IdleContent.js +17 -0
  469. package/components/stream/StatusBar.d.ts +36 -0
  470. package/components/stream/StatusBar.d.ts.map +1 -0
  471. package/components/stream/StatusBar.js +140 -0
  472. package/components/stream/StreamSettings.d.ts +33 -0
  473. package/components/stream/StreamSettings.d.ts.map +1 -0
  474. package/components/stream/StreamSettings.js +99 -0
  475. package/components/stream/StreamTerminal.d.ts +2 -0
  476. package/components/stream/StreamTerminal.d.ts.map +1 -0
  477. package/components/stream/StreamTerminal.js +52 -0
  478. package/components/stream/StreamVoiceConfig.d.ts +10 -0
  479. package/components/stream/StreamVoiceConfig.d.ts.map +1 -0
  480. package/components/stream/StreamVoiceConfig.js +88 -0
  481. package/components/stream/helpers.d.ts +32 -0
  482. package/components/stream/helpers.d.ts.map +1 -0
  483. package/components/stream/helpers.js +110 -0
  484. package/components/stream/overlays/OverlayLayer.d.ts +20 -0
  485. package/components/stream/overlays/OverlayLayer.d.ts.map +1 -0
  486. package/components/stream/overlays/OverlayLayer.js +24 -0
  487. package/components/stream/overlays/built-in/ActionTickerWidget.d.ts +8 -0
  488. package/components/stream/overlays/built-in/ActionTickerWidget.d.ts.map +1 -0
  489. package/components/stream/overlays/built-in/ActionTickerWidget.js +44 -0
  490. package/components/stream/overlays/built-in/AlertPopupWidget.d.ts +7 -0
  491. package/components/stream/overlays/built-in/AlertPopupWidget.d.ts.map +1 -0
  492. package/components/stream/overlays/built-in/AlertPopupWidget.js +62 -0
  493. package/components/stream/overlays/built-in/BrandingWidget.d.ts +7 -0
  494. package/components/stream/overlays/built-in/BrandingWidget.d.ts.map +1 -0
  495. package/components/stream/overlays/built-in/BrandingWidget.js +36 -0
  496. package/components/stream/overlays/built-in/CustomHtmlWidget.d.ts +26 -0
  497. package/components/stream/overlays/built-in/CustomHtmlWidget.d.ts.map +1 -0
  498. package/components/stream/overlays/built-in/CustomHtmlWidget.js +78 -0
  499. package/components/stream/overlays/built-in/PeonGlassWidget.d.ts +11 -0
  500. package/components/stream/overlays/built-in/PeonGlassWidget.d.ts.map +1 -0
  501. package/components/stream/overlays/built-in/PeonGlassWidget.js +188 -0
  502. package/components/stream/overlays/built-in/PeonHudWidget.d.ts +10 -0
  503. package/components/stream/overlays/built-in/PeonHudWidget.d.ts.map +1 -0
  504. package/components/stream/overlays/built-in/PeonHudWidget.js +168 -0
  505. package/components/stream/overlays/built-in/PeonSakuraWidget.d.ts +11 -0
  506. package/components/stream/overlays/built-in/PeonSakuraWidget.d.ts.map +1 -0
  507. package/components/stream/overlays/built-in/PeonSakuraWidget.js +213 -0
  508. package/components/stream/overlays/built-in/ThoughtBubbleWidget.d.ts +8 -0
  509. package/components/stream/overlays/built-in/ThoughtBubbleWidget.d.ts.map +1 -0
  510. package/components/stream/overlays/built-in/ThoughtBubbleWidget.js +59 -0
  511. package/components/stream/overlays/built-in/ViewerCountWidget.d.ts +7 -0
  512. package/components/stream/overlays/built-in/ViewerCountWidget.d.ts.map +1 -0
  513. package/components/stream/overlays/built-in/ViewerCountWidget.js +34 -0
  514. package/components/stream/overlays/built-in/index.d.ts +13 -0
  515. package/components/stream/overlays/built-in/index.d.ts.map +1 -0
  516. package/components/stream/overlays/built-in/index.js +12 -0
  517. package/components/stream/overlays/registry.d.ts +11 -0
  518. package/components/stream/overlays/registry.d.ts.map +1 -0
  519. package/components/stream/overlays/registry.js +16 -0
  520. package/components/stream/overlays/types.d.ts +67 -0
  521. package/components/stream/overlays/types.d.ts.map +1 -0
  522. package/components/stream/overlays/types.js +7 -0
  523. package/components/stream/overlays/useOverlayLayout.d.ts +27 -0
  524. package/components/stream/overlays/useOverlayLayout.d.ts.map +1 -0
  525. package/components/stream/overlays/useOverlayLayout.js +162 -0
  526. package/components/trajectory-format.d.ts +6 -0
  527. package/components/trajectory-format.d.ts.map +1 -0
  528. package/components/trajectory-format.js +43 -0
  529. package/components/ui-badges.d.ts +23 -0
  530. package/components/ui-badges.d.ts.map +1 -0
  531. package/components/ui-badges.js +38 -0
  532. package/components/ui-switch.d.ts +14 -0
  533. package/components/ui-switch.d.ts.map +1 -0
  534. package/components/ui-switch.js +15 -0
  535. package/components/vector-browser-three.d.ts +4 -0
  536. package/components/vector-browser-three.d.ts.map +1 -0
  537. package/components/vector-browser-three.js +21 -0
  538. package/config/branding.d.ts +49 -0
  539. package/config/branding.d.ts.map +1 -0
  540. package/config/branding.js +16 -0
  541. package/config/config-catalog.d.ts +376 -0
  542. package/config/config-catalog.d.ts.map +1 -0
  543. package/config/config-catalog.js +724 -0
  544. package/config/config-field.d.ts +68 -0
  545. package/config/config-field.d.ts.map +1 -0
  546. package/config/config-field.js +840 -0
  547. package/config/config-renderer.d.ts +176 -0
  548. package/config/config-renderer.d.ts.map +1 -0
  549. package/config/config-renderer.js +405 -0
  550. package/config/index.d.ts +6 -0
  551. package/config/index.d.ts.map +1 -0
  552. package/config/index.js +5 -0
  553. package/config/ui-renderer.d.ts +26 -0
  554. package/config/ui-renderer.d.ts.map +1 -0
  555. package/config/ui-renderer.js +815 -0
  556. package/config/ui-spec.d.ts +164 -0
  557. package/config/ui-spec.d.ts.map +1 -0
  558. package/config/ui-spec.js +13 -0
  559. package/events/index.d.ts +47 -0
  560. package/events/index.d.ts.map +1 -0
  561. package/events/index.js +43 -0
  562. package/hooks/index.d.ts +15 -0
  563. package/hooks/index.d.ts.map +1 -0
  564. package/hooks/useBugReport.d.ts +14 -0
  565. package/hooks/useBugReport.d.ts.map +1 -0
  566. package/hooks/useBugReport.js +18 -0
  567. package/hooks/useCanvasWindow.d.ts +38 -0
  568. package/hooks/useCanvasWindow.d.ts.map +1 -0
  569. package/hooks/useCanvasWindow.js +273 -0
  570. package/hooks/useChatAvatarVoice.d.ts +10 -0
  571. package/hooks/useChatAvatarVoice.d.ts.map +1 -0
  572. package/hooks/useChatAvatarVoice.js +71 -0
  573. package/hooks/useClickOutside.d.ts +6 -0
  574. package/hooks/useClickOutside.d.ts.map +1 -0
  575. package/hooks/useClickOutside.js +25 -0
  576. package/hooks/useContextMenu.d.ts +17 -0
  577. package/hooks/useContextMenu.d.ts.map +1 -0
  578. package/hooks/useContextMenu.js +100 -0
  579. package/hooks/useKeyboardShortcuts.d.ts +17 -0
  580. package/hooks/useKeyboardShortcuts.d.ts.map +1 -0
  581. package/hooks/useKeyboardShortcuts.js +67 -0
  582. package/hooks/useLifoSync.d.ts +18 -0
  583. package/hooks/useLifoSync.d.ts.map +1 -0
  584. package/hooks/useLifoSync.js +113 -0
  585. package/hooks/useMemoryMonitor.d.ts +87 -0
  586. package/hooks/useMemoryMonitor.d.ts.map +1 -0
  587. package/hooks/useMemoryMonitor.js +209 -0
  588. package/hooks/useRenderGuard.d.ts +17 -0
  589. package/hooks/useRenderGuard.d.ts.map +1 -0
  590. package/hooks/useRenderGuard.js +36 -0
  591. package/hooks/useRetakeCapture.d.ts +12 -0
  592. package/hooks/useRetakeCapture.d.ts.map +1 -0
  593. package/hooks/useRetakeCapture.js +60 -0
  594. package/hooks/useStreamPopoutNavigation.d.ts +3 -0
  595. package/hooks/useStreamPopoutNavigation.d.ts.map +1 -0
  596. package/hooks/useStreamPopoutNavigation.js +17 -0
  597. package/hooks/useTimeout.d.ts +11 -0
  598. package/hooks/useTimeout.d.ts.map +1 -0
  599. package/hooks/useTimeout.js +32 -0
  600. package/hooks/useVoiceChat.d.ts +94 -0
  601. package/hooks/useVoiceChat.d.ts.map +1 -0
  602. package/hooks/useVoiceChat.js +1074 -0
  603. package/hooks/useWhatsAppPairing.d.ts +11 -0
  604. package/hooks/useWhatsAppPairing.d.ts.map +1 -0
  605. package/hooks/useWhatsAppPairing.js +95 -0
  606. package/i18n/index.d.ts +7 -0
  607. package/i18n/index.d.ts.map +1 -0
  608. package/i18n/index.js +53 -0
  609. package/i18n/locales/en.json +1239 -0
  610. package/i18n/locales/es.json +1236 -0
  611. package/i18n/locales/ko.json +1236 -0
  612. package/i18n/locales/pt.json +1236 -0
  613. package/i18n/locales/zh-CN.json +1236 -0
  614. package/i18n/messages.d.ts +6 -0
  615. package/i18n/messages.d.ts.map +1 -0
  616. package/i18n/messages.js +14 -0
  617. package/index.d.ts +5 -0
  618. package/index.d.ts.map +1 -0
  619. package/navigation/index.d.ts +27 -0
  620. package/navigation/index.d.ts.map +1 -0
  621. package/navigation/index.js +232 -0
  622. package/onboarding-config.d.ts +25 -0
  623. package/onboarding-config.d.ts.map +1 -0
  624. package/onboarding-config.js +76 -0
  625. package/package.json +143 -53
  626. package/platform/browser-launch.d.ts +2 -0
  627. package/platform/browser-launch.d.ts.map +1 -0
  628. package/platform/browser-launch.js +109 -0
  629. package/platform/index.d.ts +14 -0
  630. package/platform/index.d.ts.map +1 -0
  631. package/platform/index.js +24 -0
  632. package/platform/init.d.ts +40 -0
  633. package/platform/init.d.ts.map +1 -0
  634. package/platform/init.js +160 -0
  635. package/platform/lifo.d.ts +51 -0
  636. package/platform/lifo.d.ts.map +1 -0
  637. package/platform/lifo.js +138 -0
  638. package/providers/index.d.ts +19 -0
  639. package/providers/index.d.ts.map +1 -0
  640. package/providers/index.js +80 -0
  641. package/shell-params.d.ts +12 -0
  642. package/shell-params.d.ts.map +1 -0
  643. package/shell-params.js +19 -0
  644. package/state/AppContext.d.ts +12 -0
  645. package/state/AppContext.d.ts.map +1 -0
  646. package/state/AppContext.js +5060 -0
  647. package/state/index.d.ts +7 -0
  648. package/state/index.d.ts.map +1 -0
  649. package/state/internal.d.ts +7 -0
  650. package/state/internal.d.ts.map +1 -0
  651. package/state/internal.js +6 -0
  652. package/state/onboarding-resume.d.ts +11 -0
  653. package/state/onboarding-resume.d.ts.map +1 -0
  654. package/state/onboarding-resume.js +189 -0
  655. package/state/parsers.d.ts +26 -0
  656. package/state/parsers.d.ts.map +1 -0
  657. package/state/parsers.js +255 -0
  658. package/state/persistence.d.ts +59 -0
  659. package/state/persistence.d.ts.map +1 -0
  660. package/state/persistence.js +326 -0
  661. package/state/shell-routing.d.ts +12 -0
  662. package/state/shell-routing.d.ts.map +1 -0
  663. package/state/shell-routing.js +25 -0
  664. package/state/types.d.ts +421 -0
  665. package/state/types.d.ts.map +1 -0
  666. package/state/types.js +75 -0
  667. package/state/ui-preferences.d.ts +3 -0
  668. package/state/ui-preferences.d.ts.map +1 -0
  669. package/state/ui-preferences.js +1 -0
  670. package/state/useApp.d.ts +4 -0
  671. package/state/useApp.d.ts.map +1 -0
  672. package/state/useApp.js +22 -0
  673. package/state/vrm.d.ts +30 -0
  674. package/state/vrm.d.ts.map +1 -0
  675. package/state/vrm.js +82 -0
  676. package/styles/anime.css +6321 -0
  677. package/styles/onboarding-game.css +1092 -0
  678. package/types/index.d.ts +657 -0
  679. package/types/index.d.ts.map +1 -0
  680. package/types/index.js +1 -0
  681. package/utils/asset-url.d.ts +26 -0
  682. package/utils/asset-url.d.ts.map +1 -0
  683. package/utils/asset-url.js +99 -0
  684. package/utils/assistant-text.d.ts +2 -0
  685. package/utils/assistant-text.d.ts.map +1 -0
  686. package/utils/assistant-text.js +161 -0
  687. package/utils/clipboard.d.ts +2 -0
  688. package/utils/clipboard.d.ts.map +1 -0
  689. package/utils/clipboard.js +38 -0
  690. package/utils/desktop-dialogs.d.ts +19 -0
  691. package/utils/desktop-dialogs.d.ts.map +1 -0
  692. package/utils/desktop-dialogs.js +50 -0
  693. package/utils/eliza-globals.d.ts +11 -0
  694. package/utils/eliza-globals.d.ts.map +1 -0
  695. package/utils/eliza-globals.js +33 -0
  696. package/utils/index.d.ts +8 -0
  697. package/utils/index.d.ts.map +1 -0
  698. package/utils/number-parsing.d.ts +44 -0
  699. package/utils/number-parsing.d.ts.map +1 -0
  700. package/utils/number-parsing.js +56 -0
  701. package/utils/openExternalUrl.d.ts +2 -0
  702. package/utils/openExternalUrl.d.ts.map +1 -0
  703. package/utils/openExternalUrl.js +17 -0
  704. package/utils/spoken-text.d.ts +2 -0
  705. package/utils/spoken-text.d.ts.map +1 -0
  706. package/utils/spoken-text.js +56 -0
  707. package/utils/streaming-text.d.ts +3 -0
  708. package/utils/streaming-text.d.ts.map +1 -0
  709. package/utils/streaming-text.js +87 -0
  710. package/voice/index.d.ts +2 -0
  711. package/voice/index.d.ts.map +1 -0
  712. package/voice/types.d.ts +25 -0
  713. package/voice/types.d.ts.map +1 -0
  714. package/voice/types.js +166 -0
  715. package/wallet-rpc.d.ts +8 -0
  716. package/wallet-rpc.d.ts.map +1 -0
  717. package/wallet-rpc.js +131 -0
  718. package/.turbo/turbo-build.log +0 -5
  719. package/src/App.tsx +0 -504
  720. package/src/actions/character.test.ts +0 -139
  721. package/src/actions/character.ts +0 -334
  722. package/src/actions/chat-helpers.ts +0 -100
  723. package/src/actions/cloud.ts +0 -59
  724. package/src/actions/index.ts +0 -12
  725. package/src/actions/lifecycle.ts +0 -175
  726. package/src/actions/onboarding.ts +0 -38
  727. package/src/actions/triggers.ts +0 -190
  728. package/src/ambient.d.ts +0 -33
  729. package/src/api/client.ts +0 -5659
  730. package/src/autonomy/index.ts +0 -477
  731. package/src/bridge/capacitor-bridge.ts +0 -295
  732. package/src/bridge/electrobun-rpc.ts +0 -78
  733. package/src/bridge/electrobun-runtime.ts +0 -28
  734. package/src/bridge/native-plugins.ts +0 -138
  735. package/src/bridge/plugin-bridge.ts +0 -352
  736. package/src/bridge/storage-bridge.ts +0 -162
  737. package/src/chat/index.ts +0 -250
  738. package/src/coding/index.ts +0 -43
  739. package/src/components/AdvancedPageView.tsx +0 -382
  740. package/src/components/AgentActivityBox.tsx +0 -49
  741. package/src/components/ApiKeyConfig.tsx +0 -222
  742. package/src/components/AppsPageView.tsx +0 -52
  743. package/src/components/AppsView.tsx +0 -293
  744. package/src/components/AvatarLoader.tsx +0 -104
  745. package/src/components/AvatarSelector.tsx +0 -223
  746. package/src/components/BscTradePanel.tsx +0 -549
  747. package/src/components/BugReportModal.tsx +0 -499
  748. package/src/components/CharacterRoster.tsx +0 -143
  749. package/src/components/CharacterView.tsx +0 -1575
  750. package/src/components/ChatAvatar.test.ts +0 -97
  751. package/src/components/ChatAvatar.tsx +0 -147
  752. package/src/components/ChatComposer.tsx +0 -330
  753. package/src/components/ChatMessage.tsx +0 -448
  754. package/src/components/ChatModalView.test.tsx +0 -118
  755. package/src/components/ChatModalView.tsx +0 -125
  756. package/src/components/ChatView.tsx +0 -992
  757. package/src/components/CloudOnboarding.tsx +0 -81
  758. package/src/components/CloudSourceControls.tsx +0 -85
  759. package/src/components/CodingAgentSettingsSection.tsx +0 -537
  760. package/src/components/CommandPalette.tsx +0 -284
  761. package/src/components/CompanionSceneHost.tsx +0 -517
  762. package/src/components/CompanionShell.tsx +0 -31
  763. package/src/components/CompanionView.tsx +0 -110
  764. package/src/components/ConfigPageView.tsx +0 -763
  765. package/src/components/ConfigSaveFooter.tsx +0 -41
  766. package/src/components/ConfirmModal.tsx +0 -379
  767. package/src/components/ConnectionFailedBanner.tsx +0 -91
  768. package/src/components/ConnectorsPageView.tsx +0 -13
  769. package/src/components/ConversationsSidebar.tsx +0 -279
  770. package/src/components/CustomActionEditor.tsx +0 -1127
  771. package/src/components/CustomActionsPanel.tsx +0 -288
  772. package/src/components/CustomActionsView.tsx +0 -325
  773. package/src/components/DatabasePageView.tsx +0 -55
  774. package/src/components/DatabaseView.tsx +0 -814
  775. package/src/components/ElizaCloudDashboard.tsx +0 -1696
  776. package/src/components/EmotePicker.tsx +0 -529
  777. package/src/components/ErrorBoundary.tsx +0 -76
  778. package/src/components/FineTuningView.tsx +0 -1080
  779. package/src/components/FlaminaGuide.test.tsx +0 -61
  780. package/src/components/FlaminaGuide.tsx +0 -212
  781. package/src/components/GameView.tsx +0 -551
  782. package/src/components/GameViewOverlay.tsx +0 -133
  783. package/src/components/GlobalEmoteOverlay.tsx +0 -152
  784. package/src/components/Header.test.tsx +0 -413
  785. package/src/components/Header.tsx +0 -400
  786. package/src/components/HeartbeatsView.tsx +0 -1003
  787. package/src/components/InventoryView.tsx +0 -393
  788. package/src/components/KnowledgeView.tsx +0 -1128
  789. package/src/components/LanguageDropdown.tsx +0 -192
  790. package/src/components/LifoMonitorPanel.tsx +0 -196
  791. package/src/components/LifoSandboxView.tsx +0 -499
  792. package/src/components/LoadingScreen.tsx +0 -112
  793. package/src/components/LogsPageView.tsx +0 -17
  794. package/src/components/LogsView.tsx +0 -239
  795. package/src/components/MediaGalleryView.tsx +0 -431
  796. package/src/components/MediaSettingsSection.tsx +0 -893
  797. package/src/components/MessageContent.tsx +0 -815
  798. package/src/components/MiladyBar.tsx +0 -103
  799. package/src/components/MiladyBarSettings.tsx +0 -872
  800. package/src/components/OnboardingWizard.test.tsx +0 -104
  801. package/src/components/OnboardingWizard.tsx +0 -249
  802. package/src/components/PairingView.tsx +0 -109
  803. package/src/components/PermissionsSection.tsx +0 -1184
  804. package/src/components/PluginsPageView.tsx +0 -9
  805. package/src/components/PluginsView.tsx +0 -3129
  806. package/src/components/ProviderSwitcher.tsx +0 -903
  807. package/src/components/RestartBanner.tsx +0 -76
  808. package/src/components/RuntimeView.tsx +0 -460
  809. package/src/components/SaveCommandModal.tsx +0 -211
  810. package/src/components/SecretsView.tsx +0 -569
  811. package/src/components/SecurityPageView.tsx +0 -242
  812. package/src/components/SettingsView.tsx +0 -825
  813. package/src/components/ShellOverlays.tsx +0 -41
  814. package/src/components/ShortcutsOverlay.tsx +0 -155
  815. package/src/components/SkillsView.tsx +0 -1435
  816. package/src/components/StartupFailureView.tsx +0 -63
  817. package/src/components/StreamView.tsx +0 -481
  818. package/src/components/StripeEmbeddedCheckout.tsx +0 -155
  819. package/src/components/SubscriptionStatus.tsx +0 -640
  820. package/src/components/SystemWarningBanner.tsx +0 -71
  821. package/src/components/ThemeToggle.tsx +0 -103
  822. package/src/components/TrajectoriesView.tsx +0 -526
  823. package/src/components/TrajectoryDetailView.tsx +0 -426
  824. package/src/components/VectorBrowserView.tsx +0 -1633
  825. package/src/components/VoiceConfigView.tsx +0 -674
  826. package/src/components/VrmStage.test.ts +0 -176
  827. package/src/components/VrmStage.tsx +0 -309
  828. package/src/components/WhatsAppQrOverlay.tsx +0 -230
  829. package/src/components/__tests__/chainConfig.test.ts +0 -220
  830. package/src/components/apps/AppDetailPane.tsx +0 -242
  831. package/src/components/apps/AppsCatalogGrid.tsx +0 -137
  832. package/src/components/apps/extensions/registry.ts +0 -13
  833. package/src/components/apps/extensions/types.ts +0 -9
  834. package/src/components/apps/helpers.ts +0 -43
  835. package/src/components/avatar/VrmAnimationLoader.test.ts +0 -164
  836. package/src/components/avatar/VrmAnimationLoader.ts +0 -151
  837. package/src/components/avatar/VrmBlinkController.ts +0 -118
  838. package/src/components/avatar/VrmCameraManager.ts +0 -407
  839. package/src/components/avatar/VrmEngine.ts +0 -2767
  840. package/src/components/avatar/VrmFootShadow.ts +0 -96
  841. package/src/components/avatar/VrmViewer.tsx +0 -421
  842. package/src/components/avatar/__tests__/VrmCameraManager.test.ts +0 -168
  843. package/src/components/avatar/__tests__/VrmEngine.test.ts +0 -1574
  844. package/src/components/avatar/mixamoVRMRigMap.ts +0 -62
  845. package/src/components/avatar/retargetMixamoFbxToVrm.ts +0 -144
  846. package/src/components/avatar/retargetMixamoGltfToVrm.ts +0 -119
  847. package/src/components/chainConfig.ts +0 -400
  848. package/src/components/companion/CompanionHeader.tsx +0 -50
  849. package/src/components/companion/CompanionSceneHost.tsx +0 -5
  850. package/src/components/companion/VrmStage.tsx +0 -2
  851. package/src/components/companion/__tests__/walletUtils.test.ts +0 -742
  852. package/src/components/companion/index.ts +0 -18
  853. package/src/components/companion/walletUtils.ts +0 -290
  854. package/src/components/companion-shell-styles.test.ts +0 -142
  855. package/src/components/companion-shell-styles.ts +0 -270
  856. package/src/components/confirm-delete-control.tsx +0 -69
  857. package/src/components/conversations/ConversationListItem.tsx +0 -185
  858. package/src/components/conversations/conversation-utils.ts +0 -151
  859. package/src/components/format.ts +0 -131
  860. package/src/components/index.ts +0 -96
  861. package/src/components/inventory/CopyableAddress.tsx +0 -41
  862. package/src/components/inventory/InventoryToolbar.tsx +0 -142
  863. package/src/components/inventory/NftGrid.tsx +0 -99
  864. package/src/components/inventory/TokenLogo.tsx +0 -71
  865. package/src/components/inventory/TokensTable.tsx +0 -216
  866. package/src/components/inventory/constants.ts +0 -170
  867. package/src/components/inventory/index.ts +0 -29
  868. package/src/components/inventory/media-url.test.ts +0 -38
  869. package/src/components/inventory/media-url.ts +0 -36
  870. package/src/components/inventory/useInventoryData.ts +0 -460
  871. package/src/components/knowledge-upload-image.ts +0 -215
  872. package/src/components/labels.ts +0 -46
  873. package/src/components/milady-bar/CloudCreditsChip.tsx +0 -61
  874. package/src/components/milady-bar/ProviderDropdown.tsx +0 -166
  875. package/src/components/milady-bar/WalletSummary.tsx +0 -61
  876. package/src/components/milady-bar/index.ts +0 -3
  877. package/src/components/onboarding/ActivateStep.tsx +0 -34
  878. package/src/components/onboarding/ConnectionStep.tsx +0 -1591
  879. package/src/components/onboarding/IdentityStep.tsx +0 -251
  880. package/src/components/onboarding/OnboardingPanel.tsx +0 -39
  881. package/src/components/onboarding/OnboardingStepNav.tsx +0 -41
  882. package/src/components/onboarding/PermissionsStep.tsx +0 -20
  883. package/src/components/onboarding/RpcStep.tsx +0 -402
  884. package/src/components/permissions/PermissionIcon.tsx +0 -25
  885. package/src/components/permissions/StreamingPermissions.tsx +0 -413
  886. package/src/components/plugins/showcase-data.ts +0 -481
  887. package/src/components/shared/ShellHeaderControls.tsx +0 -198
  888. package/src/components/shared-companion-scene-context.ts +0 -15
  889. package/src/components/skeletons.tsx +0 -88
  890. package/src/components/stream/ActivityFeed.tsx +0 -113
  891. package/src/components/stream/AvatarPip.tsx +0 -10
  892. package/src/components/stream/ChatContent.tsx +0 -126
  893. package/src/components/stream/ChatTicker.tsx +0 -55
  894. package/src/components/stream/IdleContent.tsx +0 -73
  895. package/src/components/stream/StatusBar.tsx +0 -463
  896. package/src/components/stream/StreamSettings.tsx +0 -506
  897. package/src/components/stream/StreamTerminal.tsx +0 -94
  898. package/src/components/stream/StreamVoiceConfig.tsx +0 -160
  899. package/src/components/stream/helpers.ts +0 -134
  900. package/src/components/stream/overlays/OverlayLayer.tsx +0 -75
  901. package/src/components/stream/overlays/built-in/ActionTickerWidget.tsx +0 -64
  902. package/src/components/stream/overlays/built-in/AlertPopupWidget.tsx +0 -87
  903. package/src/components/stream/overlays/built-in/BrandingWidget.tsx +0 -51
  904. package/src/components/stream/overlays/built-in/CustomHtmlWidget.tsx +0 -105
  905. package/src/components/stream/overlays/built-in/PeonGlassWidget.tsx +0 -265
  906. package/src/components/stream/overlays/built-in/PeonHudWidget.tsx +0 -247
  907. package/src/components/stream/overlays/built-in/PeonSakuraWidget.tsx +0 -278
  908. package/src/components/stream/overlays/built-in/ThoughtBubbleWidget.tsx +0 -77
  909. package/src/components/stream/overlays/built-in/ViewerCountWidget.tsx +0 -46
  910. package/src/components/stream/overlays/built-in/index.ts +0 -13
  911. package/src/components/stream/overlays/registry.ts +0 -22
  912. package/src/components/stream/overlays/types.ts +0 -90
  913. package/src/components/stream/overlays/useOverlayLayout.ts +0 -218
  914. package/src/components/trajectory-format.ts +0 -50
  915. package/src/components/ui-badges.tsx +0 -109
  916. package/src/components/ui-switch.tsx +0 -57
  917. package/src/components/vector-browser-three.ts +0 -29
  918. package/src/config/branding.ts +0 -67
  919. package/src/config/config-catalog.ts +0 -1092
  920. package/src/config/config-field.tsx +0 -1924
  921. package/src/config/config-renderer.tsx +0 -734
  922. package/src/config/index.ts +0 -12
  923. package/src/config/ui-renderer.tsx +0 -1751
  924. package/src/config/ui-spec.ts +0 -256
  925. package/src/events/index.ts +0 -96
  926. package/src/hooks/useBugReport.tsx +0 -43
  927. package/src/hooks/useCanvasWindow.ts +0 -372
  928. package/src/hooks/useChatAvatarVoice.ts +0 -111
  929. package/src/hooks/useClickOutside.ts +0 -31
  930. package/src/hooks/useContextMenu.ts +0 -127
  931. package/src/hooks/useKeyboardShortcuts.ts +0 -86
  932. package/src/hooks/useLifoSync.ts +0 -143
  933. package/src/hooks/useMemoryMonitor.ts +0 -334
  934. package/src/hooks/useMiladyBar.ts +0 -594
  935. package/src/hooks/useRenderGuard.ts +0 -43
  936. package/src/hooks/useRetakeCapture.ts +0 -68
  937. package/src/hooks/useStreamPopoutNavigation.ts +0 -27
  938. package/src/hooks/useTimeout.ts +0 -37
  939. package/src/hooks/useVoiceChat.ts +0 -1442
  940. package/src/hooks/useWhatsAppPairing.ts +0 -123
  941. package/src/i18n/index.ts +0 -76
  942. package/src/i18n/locales/en.json +0 -1195
  943. package/src/i18n/locales/es.json +0 -1195
  944. package/src/i18n/locales/ko.json +0 -1195
  945. package/src/i18n/locales/pt.json +0 -1195
  946. package/src/i18n/locales/zh-CN.json +0 -1195
  947. package/src/i18n/messages.ts +0 -21
  948. package/src/navigation/index.ts +0 -286
  949. package/src/navigation.test.ts +0 -189
  950. package/src/onboarding-config.test.ts +0 -104
  951. package/src/onboarding-config.ts +0 -122
  952. package/src/platform/browser-launch.test.ts +0 -94
  953. package/src/platform/browser-launch.ts +0 -149
  954. package/src/platform/index.ts +0 -58
  955. package/src/platform/init.ts +0 -238
  956. package/src/platform/lifo.ts +0 -225
  957. package/src/providers/index.ts +0 -108
  958. package/src/shell-params.test.ts +0 -48
  959. package/src/shell-params.ts +0 -36
  960. package/src/state/AppContext.tsx +0 -6415
  961. package/src/state/internal.ts +0 -91
  962. package/src/state/onboarding-resume.test.ts +0 -135
  963. package/src/state/onboarding-resume.ts +0 -263
  964. package/src/state/parsers.test.ts +0 -124
  965. package/src/state/parsers.ts +0 -309
  966. package/src/state/persistence.ts +0 -379
  967. package/src/state/shell-routing.ts +0 -39
  968. package/src/state/types.ts +0 -724
  969. package/src/state/ui-preferences.ts +0 -3
  970. package/src/state/useApp.ts +0 -23
  971. package/src/state/vrm.ts +0 -108
  972. package/src/styles/anime.css +0 -6324
  973. package/src/styles/onboarding-game.css +0 -976
  974. package/src/types/index.ts +0 -715
  975. package/src/types/react-test-renderer.d.ts +0 -45
  976. package/src/utils/asset-url.ts +0 -110
  977. package/src/utils/assistant-text.ts +0 -172
  978. package/src/utils/clipboard.ts +0 -41
  979. package/src/utils/desktop-dialogs.ts +0 -80
  980. package/src/utils/eliza-globals.ts +0 -44
  981. package/src/utils/number-parsing.ts +0 -125
  982. package/src/utils/openExternalUrl.ts +0 -20
  983. package/src/utils/spoken-text.ts +0 -65
  984. package/src/utils/streaming-text.ts +0 -120
  985. package/src/voice/types.ts +0 -197
  986. package/src/wallet-rpc.ts +0 -176
  987. package/test/app/AppContext.pty-sessions.test.tsx +0 -143
  988. package/test/app/MessageContent.test.tsx +0 -366
  989. package/test/app/PermissionsOnboarding.test.tsx +0 -358
  990. package/test/app/PermissionsSection.test.tsx +0 -575
  991. package/test/app/advanced-trajectory-fine-tuning.e2e.test.ts +0 -396
  992. package/test/app/agent-activity-box.test.tsx +0 -132
  993. package/test/app/agent-transfer-lock.test.ts +0 -279
  994. package/test/app/api-client-electrobun-fallback.test.ts +0 -139
  995. package/test/app/api-client-electron-fallback.test.ts +0 -139
  996. package/test/app/api-client-timeout.test.ts +0 -75
  997. package/test/app/api-client-ws.test.ts +0 -98
  998. package/test/app/api-client.ws-max-reconnect.test.ts +0 -139
  999. package/test/app/api-client.ws-reconnect.test.ts +0 -157
  1000. package/test/app/app-context-autonomy-events.test.ts +0 -559
  1001. package/test/app/apps-page-view.test.ts +0 -114
  1002. package/test/app/apps-view.test.ts +0 -768
  1003. package/test/app/autonomous-workflows.e2e.test.ts +0 -765
  1004. package/test/app/autonomy-events.test.ts +0 -150
  1005. package/test/app/avatar-selector.test.tsx +0 -52
  1006. package/test/app/bsc-trade-panel.test.tsx +0 -134
  1007. package/test/app/bug-report-modal.test.tsx +0 -353
  1008. package/test/app/character-action-bar-visibility.test.ts +0 -70
  1009. package/test/app/character-customization.e2e.test.ts +0 -1384
  1010. package/test/app/character-save-journey.test.ts +0 -1245
  1011. package/test/app/chat-advanced-features.e2e.test.ts +0 -706
  1012. package/test/app/chat-composer.test.tsx +0 -181
  1013. package/test/app/chat-journey.test.ts +0 -1075
  1014. package/test/app/chat-language-header.test.ts +0 -64
  1015. package/test/app/chat-message.test.tsx +0 -222
  1016. package/test/app/chat-modal-view.test.tsx +0 -191
  1017. package/test/app/chat-routine-filter.test.ts +0 -96
  1018. package/test/app/chat-send-lock.test.ts +0 -1465
  1019. package/test/app/chat-stream-api-client.test.tsx +0 -390
  1020. package/test/app/chat-view-game-modal.test.tsx +0 -661
  1021. package/test/app/chat-view.test.tsx +0 -877
  1022. package/test/app/cloud-api.e2e.test.ts +0 -258
  1023. package/test/app/cloud-login-flow.e2e.test.ts +0 -494
  1024. package/test/app/cloud-login-lock.test.ts +0 -416
  1025. package/test/app/command-palette.test.tsx +0 -184
  1026. package/test/app/command-registry.test.ts +0 -75
  1027. package/test/app/companion-greeting-wave.test.tsx +0 -431
  1028. package/test/app/companion-scene-host.test.tsx +0 -85
  1029. package/test/app/companion-stale-conversation.test.tsx +0 -447
  1030. package/test/app/companion-view.test.tsx +0 -690
  1031. package/test/app/confirm-delete-control.test.ts +0 -79
  1032. package/test/app/confirm-modal.test.tsx +0 -219
  1033. package/test/app/connection-mode-persistence.test.ts +0 -411
  1034. package/test/app/connectors-ui.e2e.test.ts +0 -508
  1035. package/test/app/conversations-sidebar-game-modal.test.tsx +0 -265
  1036. package/test/app/conversations-sidebar.test.tsx +0 -185
  1037. package/test/app/custom-actions-smoke.test.ts +0 -387
  1038. package/test/app/custom-avatar-api-client.test.ts +0 -207
  1039. package/test/app/desktop-utils.test.ts +0 -145
  1040. package/test/app/electrobun-rpc-bridge.test.ts +0 -83
  1041. package/test/app/events.test.ts +0 -88
  1042. package/test/app/export-import-flows.e2e.test.ts +0 -700
  1043. package/test/app/fine-tuning-view.test.ts +0 -471
  1044. package/test/app/game-view-auth-session.test.tsx +0 -187
  1045. package/test/app/game-view.test.ts +0 -444
  1046. package/test/app/global-emote-overlay.test.tsx +0 -106
  1047. package/test/app/header-status.test.tsx +0 -149
  1048. package/test/app/i18n.test.ts +0 -152
  1049. package/test/app/inventory-bsc-view.test.ts +0 -940
  1050. package/test/app/knowledge-ui.e2e.test.ts +0 -762
  1051. package/test/app/knowledge-upload-helpers.test.ts +0 -124
  1052. package/test/app/lifecycle-lock.test.ts +0 -267
  1053. package/test/app/lifo-popout-utils.test.ts +0 -208
  1054. package/test/app/lifo-safe-endpoint.test.ts +0 -34
  1055. package/test/app/loading-screen.test.tsx +0 -45
  1056. package/test/app/memory-monitor.test.ts +0 -331
  1057. package/test/app/milady-bar-regression.test.tsx +0 -519
  1058. package/test/app/milady-bar-settings.test.tsx +0 -1056
  1059. package/test/app/milady-bar.test.tsx +0 -583
  1060. package/test/app/navigation.test.tsx +0 -22
  1061. package/test/app/onboarding-e2e-journey.test.ts +0 -1409
  1062. package/test/app/onboarding-finish-lock.test.ts +0 -676
  1063. package/test/app/onboarding-language.test.tsx +0 -160
  1064. package/test/app/onboarding-steps.test.tsx +0 -375
  1065. package/test/app/open-external-url.test.ts +0 -65
  1066. package/test/app/pages-navigation-smoke.e2e.test.ts +0 -646
  1067. package/test/app/pairing-lock.test.ts +0 -260
  1068. package/test/app/pairing-view.test.tsx +0 -74
  1069. package/test/app/permissions-section.test.ts +0 -432
  1070. package/test/app/plugin-bridge.test.ts +0 -109
  1071. package/test/app/plugins-ui.e2e.test.ts +0 -605
  1072. package/test/app/plugins-view-game-modal.test.tsx +0 -686
  1073. package/test/app/plugins-view-toggle-restart.test.ts +0 -129
  1074. package/test/app/provider-dropdown-default.test.tsx +0 -300
  1075. package/test/app/restart-banner.test.tsx +0 -205
  1076. package/test/app/retake-capture.test.ts +0 -84
  1077. package/test/app/sandbox-api-client.test.ts +0 -108
  1078. package/test/app/save-command-modal.test.tsx +0 -109
  1079. package/test/app/secrets-view.test.tsx +0 -92
  1080. package/test/app/settings-control-styles.test.tsx +0 -142
  1081. package/test/app/settings-reset.e2e.test.ts +0 -726
  1082. package/test/app/settings-sections.e2e.test.ts +0 -614
  1083. package/test/app/shared-format.test.ts +0 -44
  1084. package/test/app/shared-switch.test.ts +0 -69
  1085. package/test/app/shell-mode-switching.e2e.test.ts +0 -841
  1086. package/test/app/shell-mode-tab-memory.test.tsx +0 -58
  1087. package/test/app/shell-overlays.test.tsx +0 -50
  1088. package/test/app/shortcuts-overlay.test.tsx +0 -111
  1089. package/test/app/sse-interruption.test.ts +0 -122
  1090. package/test/app/startup-asset-missing.e2e.test.ts +0 -126
  1091. package/test/app/startup-backend-missing.e2e.test.ts +0 -126
  1092. package/test/app/startup-chat.e2e.test.ts +0 -323
  1093. package/test/app/startup-conversation-restore.test.tsx +0 -381
  1094. package/test/app/startup-failure-view.test.tsx +0 -103
  1095. package/test/app/startup-onboarding.e2e.test.ts +0 -712
  1096. package/test/app/startup-timeout.test.tsx +0 -80
  1097. package/test/app/startup-token-401.e2e.test.ts +0 -103
  1098. package/test/app/stream-helpers.test.ts +0 -46
  1099. package/test/app/stream-popout-navigation.test.tsx +0 -41
  1100. package/test/app/stream-status-bar.test.tsx +0 -89
  1101. package/test/app/theme-toggle.test.tsx +0 -40
  1102. package/test/app/training-api-client.test.ts +0 -128
  1103. package/test/app/trajectories-view.test.tsx +0 -220
  1104. package/test/app/triggers-api-client.test.ts +0 -77
  1105. package/test/app/triggers-navigation.test.ts +0 -113
  1106. package/test/app/triggers-view.e2e.test.ts +0 -675
  1107. package/test/app/update-channel-lock.test.ts +0 -259
  1108. package/test/app/vector-browser.async-cleanup.test.tsx +0 -367
  1109. package/test/app/vector-browser.e2e.test.ts +0 -653
  1110. package/test/app/vrm-stage.test.tsx +0 -351
  1111. package/test/app/vrm-viewer.test.tsx +0 -298
  1112. package/test/app/wallet-api-save-lock.test.ts +0 -299
  1113. package/test/app/wallet-hooks.test.ts +0 -405
  1114. package/test/app/wallet-ui-flows.e2e.test.ts +0 -556
  1115. package/test/avatar/asset-url.test.ts +0 -90
  1116. package/test/avatar/avatar-selector.test.ts +0 -173
  1117. package/test/avatar/mixamo-vrm-rig-map.test.ts +0 -111
  1118. package/test/avatar/voice-chat-streaming-text.test.ts +0 -96
  1119. package/test/avatar/voice-chat.test.ts +0 -391
  1120. package/test/browser-extension/README.md +0 -138
  1121. package/test/browser-extension/test-harness.ts +0 -499
  1122. package/test/capacitor-plugins.e2e.test.ts +0 -168
  1123. package/test/test-types.ts +0 -5
  1124. package/test/ui/command-palette-commands.test.ts +0 -57
  1125. package/test/ui/ui-renderer.test.ts +0 -39
  1126. package/test/utils/assistant-text.test.ts +0 -68
  1127. package/test/utils/eliza-globals.test.ts +0 -59
  1128. package/test/utils/package-exports.test.ts +0 -70
  1129. package/test/utils/streaming-text.test.ts +0 -89
  1130. package/tsconfig.build.json +0 -19
  1131. package/tsconfig.json +0 -20
  1132. package/tsconfig.typecheck.json +0 -12
  1133. /package/{src/api/index.ts → api/index.js} +0 -0
  1134. /package/{src/bridge/index.ts → bridge/index.js} +0 -0
  1135. /package/{src/components/TriggersView.tsx → components/TriggersView.js} +0 -0
  1136. /package/{src/hooks/index.ts → hooks/index.js} +0 -0
  1137. /package/{src/index.ts → index.js} +0 -0
  1138. /package/{src/state/index.ts → state/index.js} +0 -0
  1139. /package/{src/styles → styles}/base.css +0 -0
  1140. /package/{src/styles → styles}/styles.css +0 -0
  1141. /package/{src/styles → styles}/xterm.css +0 -0
  1142. /package/{src/utils/index.ts → utils/index.js} +0 -0
  1143. /package/{src/voice/index.ts → voice/index.js} +0 -0
@@ -1,1435 +0,0 @@
1
- /**
2
- * Skills management view — create, enable/disable, and install skills.
3
- *
4
- * Professional card-grid layout with search, stats, polished toggle switches,
5
- * and a structured install modal. Follows the CSS variable design system used
6
- * throughout the app (--bg, --card, --border, --accent, --muted, --txt, etc.).
7
- */
8
-
9
- import { Button, Input } from "@elizaos/ui";
10
- import { useCallback, useEffect, useMemo, useState } from "react";
11
- import { createPortal } from "react-dom";
12
- import type {
13
- SkillInfo,
14
- SkillMarketplaceResult,
15
- SkillScanReportSummary,
16
- } from "../api";
17
- import { client } from "../api";
18
- import { useTimeout } from "../hooks";
19
- import { useApp } from "../state";
20
- import { ConfirmDeleteControl } from "./confirm-delete-control";
21
- import { StatusBadge } from "./ui-badges";
22
- import { Switch } from "./ui-switch";
23
-
24
- /* ── Skill Card ─────────────────────────────────────────────────────── */
25
-
26
- function SkillCard({
27
- skill,
28
- skillToggleAction,
29
- skillReviewId,
30
- skillReviewReport,
31
- skillReviewLoading,
32
- onToggle,
33
- onEdit,
34
- onDelete,
35
- onReview,
36
- onAcknowledge,
37
- onDismissReview,
38
- }: {
39
- skill: SkillInfo;
40
- skillToggleAction: string;
41
- skillReviewId: string;
42
- skillReviewReport: ReturnType<typeof useApp>["skillReviewReport"];
43
- skillReviewLoading: boolean;
44
- onToggle: (id: string, enabled: boolean) => void;
45
- onEdit: (skill: SkillInfo) => void;
46
- onDelete: (id: string, name: string) => void;
47
- onReview: (id: string) => void;
48
- onAcknowledge: (id: string) => void;
49
- onDismissReview: () => void;
50
- }) {
51
- const { t } = useApp();
52
- const isQuarantined =
53
- skill.scanStatus === "warning" || skill.scanStatus === "critical";
54
- const isBlocked = skill.scanStatus === "blocked";
55
- const isReviewing = skillReviewId === skill.id;
56
-
57
- return (
58
- <div
59
- className={`flex flex-col border bg-[var(--card)] transition-colors ${
60
- isQuarantined || isBlocked
61
- ? "border-[#e74c3c]/40"
62
- : "border-[var(--border)] hover:border-[var(--accent)]/50"
63
- }`}
64
- data-skill-id={skill.id}
65
- >
66
- {/* Main content area */}
67
- <div className="p-4">
68
- {/* Top row: badge + toggle */}
69
- <div className="flex items-center justify-between mb-2.5">
70
- <StatusBadge
71
- label={
72
- skill.scanStatus === "blocked" || skill.scanStatus === "critical"
73
- ? "Blocked"
74
- : skill.scanStatus === "warning"
75
- ? "Warning"
76
- : skill.enabled
77
- ? "Active"
78
- : "Inactive"
79
- }
80
- tone={
81
- skill.scanStatus === "blocked" ||
82
- skill.scanStatus === "critical" ||
83
- skill.scanStatus === "warning"
84
- ? skill.scanStatus === "warning"
85
- ? "warning"
86
- : "danger"
87
- : skill.enabled
88
- ? "success"
89
- : "muted"
90
- }
91
- withDot
92
- />
93
- {!isBlocked && !isQuarantined && (
94
- <Switch
95
- checked={skill.enabled}
96
- disabled={skillToggleAction === skill.id}
97
- onChange={(val) => onToggle(skill.id, val)}
98
- size="compact"
99
- trackOnClass="bg-[var(--accent)]"
100
- trackOffClass="bg-[var(--border)]"
101
- knobClass="bg-white shadow-sm"
102
- />
103
- )}
104
- {isQuarantined && !isReviewing && (
105
- <Button
106
- variant="outline"
107
- size="sm"
108
- className="h-6 px-2 text-[10px] font-bold bg-[#f39c12]/15 text-[#f39c12] border-[#f39c12]/30 hover:bg-[#f39c12]/25 hover:text-[#f39c12] transition-colors"
109
- onClick={() => onReview(skill.id)}
110
- >
111
- {t("skillsview.ReviewFindings")}
112
- </Button>
113
- )}
114
- </div>
115
-
116
- {/* Name + description */}
117
- <div
118
- className="font-semibold text-sm text-[var(--txt)] mb-1 truncate"
119
- title={skill.name}
120
- >
121
- {skill.name}
122
- </div>
123
- <div className="text-[11px] text-[var(--muted)] line-clamp-2 min-h-[2em]">
124
- {skill.description || "No description provided"}
125
- </div>
126
- </div>
127
-
128
- {/* Footer actions */}
129
- <div className="flex items-center gap-2 px-4 py-3 border-t border-border/40 bg-black/5 mt-auto">
130
- <Button
131
- variant="ghost"
132
- size="sm"
133
- className="h-7 px-3 text-[11px] font-bold text-muted hover:text-txt transition-colors"
134
- onClick={() => onEdit(skill)}
135
- >
136
- {t("triggersview.Edit")}
137
- </Button>
138
- <ConfirmDeleteControl
139
- triggerClassName="h-7 px-3 text-[11px] font-bold text-danger hover:bg-danger/10 hover:text-danger-foreground transition-colors rounded-md"
140
- confirmClassName="px-3 py-1 text-[11px] font-bold bg-danger text-danger-foreground hover:bg-danger/90 transition-colors rounded-md shadow-sm"
141
- cancelClassName="px-3 py-1 text-[11px] font-bold text-muted border border-border/40 hover:text-txt transition-colors rounded-md"
142
- confirmLabel="Yes"
143
- cancelLabel="No"
144
- onConfirm={() => onDelete(skill.id, skill.name)}
145
- />
146
- <span className="flex-1" />
147
- <span
148
- className="text-[10px] text-[var(--muted)] font-mono truncate max-w-[120px]"
149
- title={skill.id}
150
- >
151
- {skill.id.length > 16 ? `${skill.id.slice(0, 16)}...` : skill.id}
152
- </span>
153
- </div>
154
-
155
- {/* Inline review panel */}
156
- {isReviewing && skillReviewReport ? (
157
- <div className="border-t border-[var(--border)] p-4 bg-[var(--bg)]">
158
- <div className="flex items-center gap-3 mb-3">
159
- <span className="text-xs font-semibold text-[var(--txt)]">
160
- {t("skillsview.ScanReport")}
161
- </span>
162
- <span className="text-[11px] text-[#e74c3c] font-mono">
163
- {skillReviewReport.summary.critical} {t("skillsview.critical")}
164
- </span>
165
- <span className="text-[11px] text-[#f39c12] font-mono">
166
- {skillReviewReport.summary.warn} {t("skillsview.warnings")}
167
- </span>
168
- </div>
169
- {skillReviewReport.findings.length > 0 && (
170
- <div className="max-h-40 overflow-y-auto mb-3 border border-[var(--border)] bg-[var(--card)]">
171
- {skillReviewReport.findings.map(
172
- (
173
- f: SkillScanReportSummary["findings"][number],
174
- idx: number,
175
- ) => (
176
- <div
177
- key={`${f.file}:${f.line}:${f.message}`}
178
- className={`flex items-start gap-2 px-3 py-1.5 text-[11px] font-mono ${
179
- idx > 0 ? "border-t border-[var(--border)]" : ""
180
- }`}
181
- >
182
- <span
183
- className={`shrink-0 px-1.5 py-px font-bold text-[10px] uppercase ${
184
- f.severity === "critical"
185
- ? "bg-[#e74c3c]/15 text-[#e74c3c]"
186
- : "bg-[#f39c12]/15 text-[#f39c12]"
187
- }`}
188
- >
189
- {f.severity}
190
- </span>
191
- <span className="text-[var(--txt)] flex-1 min-w-0">
192
- {f.message}
193
- </span>
194
- <span className="text-[var(--muted)] shrink-0">
195
- {f.file}:{f.line}
196
- </span>
197
- </div>
198
- ),
199
- )}
200
- </div>
201
- )}
202
- <div className="flex gap-2.5 mt-2">
203
- <Button
204
- variant="default"
205
- size="sm"
206
- className="h-7 px-3 text-[11px] font-bold tracking-wide shadow-sm"
207
- onClick={() => onAcknowledge(skill.id)}
208
- >
209
- {t("skillsview.AcknowledgeAmpEn")}
210
- </Button>
211
- <Button
212
- variant="ghost"
213
- size="sm"
214
- className="h-7 px-3 text-[11px] font-bold text-muted hover:text-txt transition-colors"
215
- onClick={onDismissReview}
216
- >
217
- {t("skillsview.Dismiss")}
218
- </Button>
219
- </div>
220
- </div>
221
- ) : isReviewing && skillReviewLoading ? (
222
- <div className="border-t border-[var(--border)] p-4 text-xs text-[var(--muted)] italic">
223
- {t("skillsview.LoadingScanReport")}
224
- </div>
225
- ) : null}
226
- </div>
227
- );
228
- }
229
-
230
- /* ── Marketplace Result Card ────────────────────────────────────────── */
231
-
232
- function MarketplaceCard({
233
- item,
234
- isInstalled,
235
- skillsMarketplaceAction,
236
- onInstall,
237
- onUninstall,
238
- }: {
239
- item: SkillMarketplaceResult;
240
- isInstalled: boolean;
241
- skillsMarketplaceAction: string;
242
- onInstall: (item: SkillMarketplaceResult) => void;
243
- onUninstall: (skillId: string, name: string) => void;
244
- }) {
245
- const { t } = useApp();
246
- const isInstalling = skillsMarketplaceAction === `install:${item.id}`;
247
- const isUninstalling = skillsMarketplaceAction === `uninstall:${item.id}`;
248
- const sourceLabel = item.repository || item.slug || item.id;
249
-
250
- return (
251
- <div className="flex items-start gap-4 p-4 border border-[var(--border)] bg-[var(--card)] hover:border-[var(--accent)]/50 transition-colors">
252
- {/* Icon placeholder */}
253
- <div className="w-10 h-10 shrink-0 flex items-center justify-center bg-[var(--accent)]/10 text-[var(--accent)] text-sm font-bold rounded">
254
- {item.name.charAt(0).toUpperCase()}
255
- </div>
256
- <div className="flex-1 min-w-0">
257
- <div className="font-semibold text-sm text-[var(--txt)]">
258
- {item.name}
259
- </div>
260
- <div className="text-[11px] text-[var(--muted)] mt-0.5 line-clamp-2">
261
- {item.description || "No description."}
262
- </div>
263
- <div className="flex items-center gap-2 mt-1.5 text-[10px] text-[var(--muted)]">
264
- <span className="font-mono">{sourceLabel}</span>
265
- {item.score != null && (
266
- <>
267
- <span className="text-[var(--border)]">/</span>
268
- <span>
269
- {t("skillsview.score")} {item.score.toFixed(2)}
270
- </span>
271
- </>
272
- )}
273
- {item.tags && item.tags.length > 0 && (
274
- <>
275
- <span className="text-[var(--border)]">/</span>
276
- {item.tags.slice(0, 3).map((tag) => (
277
- <span
278
- key={tag}
279
- className="px-1.5 py-px bg-[var(--accent)]/10 text-[var(--accent)]"
280
- >
281
- {tag}
282
- </span>
283
- ))}
284
- </>
285
- )}
286
- </div>
287
- </div>
288
- {isInstalled ? (
289
- <Button
290
- variant="destructive"
291
- size="sm"
292
- className="h-8 px-4 text-[11px] font-bold tracking-wide shadow-sm shrink-0"
293
- onClick={() => onUninstall(item.id, item.name)}
294
- disabled={isUninstalling}
295
- >
296
- {isUninstalling ? "Removing..." : "Uninstall"}
297
- </Button>
298
- ) : (
299
- <Button
300
- variant="default"
301
- size="sm"
302
- className="h-8 px-4 text-[11px] font-bold tracking-wide shadow-sm shrink-0"
303
- onClick={() => onInstall(item)}
304
- disabled={isInstalling}
305
- >
306
- {isInstalling ? "Installing..." : "Install"}
307
- </Button>
308
- )}
309
- </div>
310
- );
311
- }
312
-
313
- /* ── Install Modal ──────────────────────────────────────────────────── */
314
-
315
- type InstallTab = "search" | "url";
316
-
317
- function InstallModal({
318
- skills,
319
- skillsMarketplaceQuery,
320
- skillsMarketplaceResults,
321
- skillsMarketplaceError,
322
- skillsMarketplaceLoading,
323
- skillsMarketplaceAction,
324
- skillsMarketplaceManualGithubUrl,
325
- searchSkillsMarketplace,
326
- installSkillFromMarketplace,
327
- uninstallMarketplaceSkill,
328
- installSkillFromGithubUrl,
329
- setState,
330
- onClose,
331
- }: {
332
- skills: SkillInfo[];
333
- skillsMarketplaceQuery: string;
334
- skillsMarketplaceResults: SkillMarketplaceResult[];
335
- skillsMarketplaceError: string;
336
- skillsMarketplaceLoading: boolean;
337
- skillsMarketplaceAction: string;
338
- skillsMarketplaceManualGithubUrl: string;
339
- searchSkillsMarketplace: () => Promise<void>;
340
- installSkillFromMarketplace: (item: SkillMarketplaceResult) => Promise<void>;
341
- uninstallMarketplaceSkill: (skillId: string, name: string) => Promise<void>;
342
- installSkillFromGithubUrl: () => Promise<void>;
343
- setState: ReturnType<typeof useApp>["setState"];
344
- onClose: () => void;
345
- }) {
346
- const { t } = useApp();
347
- const [tab, setTab] = useState<InstallTab>("search");
348
-
349
- return (
350
- <div
351
- className="fixed inset-0 z-[70] flex items-center justify-center bg-black/70"
352
- onClick={(e) => {
353
- if (e.target === e.currentTarget) onClose();
354
- }}
355
- onKeyDown={(e) => {
356
- if (e.key === "Escape" || e.key === "Enter" || e.key === " ") {
357
- e.preventDefault();
358
- onClose();
359
- }
360
- }}
361
- role="dialog"
362
- aria-modal="true"
363
- >
364
- <div
365
- className="w-full max-w-2xl max-h-[80vh] flex flex-col overflow-hidden mx-4"
366
- style={{
367
- background: "var(--card)",
368
- border: "1px solid var(--border)",
369
- borderRadius: 16,
370
- backdropFilter: "blur(20px) saturate(115%)",
371
- boxShadow: "var(--shadow-lg)",
372
- color: "var(--text)",
373
- }}
374
- >
375
- {/* Header */}
376
- <div
377
- className="flex items-center justify-between px-5 py-4"
378
- style={{ borderBottom: "1px solid var(--border)" }}
379
- >
380
- <div>
381
- <div
382
- style={{
383
- fontSize: 13,
384
- fontWeight: 800,
385
- letterSpacing: "0.14em",
386
- textTransform: "uppercase",
387
- color: "var(--text)",
388
- }}
389
- >
390
- Install Skill
391
- </div>
392
- <div
393
- style={{
394
- fontSize: 11,
395
- color: "var(--muted)",
396
- marginTop: 2,
397
- }}
398
- >
399
- Add skills from the marketplace or a GitHub repository.
400
- </div>
401
- </div>
402
- <button
403
- type="button"
404
- style={{
405
- width: 28,
406
- height: 28,
407
- borderRadius: "50%",
408
- border: "1px solid var(--border)",
409
- background: "transparent",
410
- color: "var(--muted)",
411
- cursor: "pointer",
412
- fontSize: 14,
413
- display: "flex",
414
- alignItems: "center",
415
- justifyContent: "center",
416
- }}
417
- onClick={onClose}
418
- >
419
- ×
420
- </button>
421
- </div>
422
-
423
- {/* Tabs */}
424
- <div
425
- className="flex"
426
- style={{ borderBottom: "1px solid var(--border)" }}
427
- >
428
- {(
429
- [
430
- { id: "search" as const, label: "MARKETPLACE" },
431
- { id: "url" as const, label: "GITHUB URL" },
432
- ] as const
433
- ).map((t) => (
434
- <button
435
- type="button"
436
- key={t.id}
437
- style={{
438
- flex: 1,
439
- padding: "10px 16px",
440
- fontSize: 11,
441
- fontWeight: 700,
442
- letterSpacing: "0.1em",
443
- background: "transparent",
444
- border: "none",
445
- cursor: "pointer",
446
- borderBottom:
447
- tab === t.id ? "2px solid #f0b232" : "2px solid transparent",
448
- color: tab === t.id ? "#f0b232" : "var(--muted)",
449
- transition: "color 0.2s, border-color 0.2s",
450
- }}
451
- onClick={() => setTab(t.id)}
452
- >
453
- {t.label}
454
- </button>
455
- ))}
456
- </div>
457
-
458
- {/* Body */}
459
- <div className="flex-1 overflow-y-auto px-5 py-4">
460
- {tab === "search" && (
461
- <>
462
- <div className="flex gap-2 items-center mb-4">
463
- <input
464
- type="text"
465
- className="plugins-game-search-input"
466
- style={{ flex: 1, minWidth: 200 }}
467
- placeholder="Search skills by keyword..."
468
- value={skillsMarketplaceQuery}
469
- onChange={(e) =>
470
- setState("skillsMarketplaceQuery", e.target.value)
471
- }
472
- onKeyDown={(e) => {
473
- if (e.key === "Enter") void searchSkillsMarketplace();
474
- }}
475
- />
476
- <button
477
- type="button"
478
- className="plugins-game-chip"
479
- style={{ minHeight: 36, padding: "0 16px", fontWeight: 700 }}
480
- onClick={() => searchSkillsMarketplace()}
481
- disabled={skillsMarketplaceLoading}
482
- >
483
- {skillsMarketplaceLoading ? "Searching..." : "Search"}
484
- </button>
485
- </div>
486
-
487
- {skillsMarketplaceError && (
488
- <div
489
- className="p-2.5 text-xs mb-3"
490
- style={{ border: "1px solid #e74c3c", color: "#e74c3c" }}
491
- >
492
- {skillsMarketplaceError}
493
- </div>
494
- )}
495
-
496
- {skillsMarketplaceResults.length === 0 ? (
497
- <div className="text-center py-12">
498
- <div
499
- style={{
500
- color: "var(--muted)",
501
- fontSize: 12,
502
- letterSpacing: "0.1em",
503
- textTransform: "uppercase",
504
- }}
505
- >
506
- Search above to discover skills.
507
- </div>
508
- </div>
509
- ) : (
510
- <div className="flex flex-col gap-2">
511
- <div className="text-[11px] text-[var(--muted)] mb-1">
512
- {skillsMarketplaceResults.length} {t("skillsview.result")}
513
- {skillsMarketplaceResults.length !== 1 ? "s" : ""}
514
- </div>
515
- {skillsMarketplaceResults.map((item) => (
516
- <MarketplaceCard
517
- key={item.id}
518
- item={item}
519
- isInstalled={skills.some((s) => s.id === item.id)}
520
- skillsMarketplaceAction={skillsMarketplaceAction}
521
- onInstall={installSkillFromMarketplace}
522
- onUninstall={uninstallMarketplaceSkill}
523
- />
524
- ))}
525
- </div>
526
- )}
527
- </>
528
- )}
529
-
530
- {tab === "url" && (
531
- <div>
532
- <div
533
- style={{
534
- fontSize: 12,
535
- fontWeight: 600,
536
- color: "var(--text)",
537
- marginBottom: 4,
538
- }}
539
- >
540
- GitHub Repository URL
541
- </div>
542
- <div
543
- style={{
544
- fontSize: 11,
545
- color: "var(--muted)",
546
- marginBottom: 12,
547
- }}
548
- >
549
- Paste a full GitHub repository URL to install a skill directly.
550
- </div>
551
- <div className="flex gap-2 items-center">
552
- <input
553
- type="text"
554
- className="plugins-game-search-input"
555
- style={{ flex: 1 }}
556
- placeholder="https://github.com/org/repo"
557
- value={skillsMarketplaceManualGithubUrl}
558
- onChange={(e) =>
559
- setState("skillsMarketplaceManualGithubUrl", e.target.value)
560
- }
561
- onKeyDown={(e) => {
562
- if (e.key === "Enter") void installSkillFromGithubUrl();
563
- }}
564
- />
565
- <button
566
- type="button"
567
- className="plugins-game-chip"
568
- style={{ minHeight: 36, padding: "0 16px", fontWeight: 700 }}
569
- onClick={() => installSkillFromGithubUrl()}
570
- disabled={
571
- skillsMarketplaceAction === "install:manual" ||
572
- !skillsMarketplaceManualGithubUrl.trim()
573
- }
574
- >
575
- {skillsMarketplaceAction === "install:manual"
576
- ? "Installing..."
577
- : "Install"}
578
- </button>
579
- </div>
580
-
581
- {skillsMarketplaceError && (
582
- <div
583
- className="p-2.5 text-xs mt-3"
584
- style={{ border: "1px solid #e74c3c", color: "#e74c3c" }}
585
- >
586
- {skillsMarketplaceError}
587
- </div>
588
- )}
589
- </div>
590
- )}
591
- </div>
592
- </div>
593
- </div>
594
- );
595
- }
596
-
597
- /* ── Create Skill Inline Form ───────────────────────────────────────── */
598
-
599
- function CreateSkillForm({
600
- skillCreateName,
601
- skillCreateDescription,
602
- skillCreating,
603
- setState,
604
- onCancel,
605
- onCreate,
606
- }: {
607
- skillCreateName: string;
608
- skillCreateDescription: string;
609
- skillCreating: boolean;
610
- setState: ReturnType<typeof useApp>["setState"];
611
- onCancel: () => void;
612
- onCreate: () => void;
613
- }) {
614
- const { t } = useApp();
615
- return (
616
- <div className="border border-[var(--accent)]/40 bg-[var(--card)] mb-4">
617
- <div className="px-4 py-3 border-b border-[var(--border)]">
618
- <div className="text-xs font-semibold text-[var(--txt)]">
619
- {t("skillsview.CreateNewSkill")}
620
- </div>
621
- </div>
622
- <div className="p-4 flex flex-col gap-3">
623
- <div>
624
- <span className="block text-[11px] text-[var(--muted)] mb-1 font-medium">
625
- {t("skillsview.SkillName")}{" "}
626
- <span className="text-[#e74c3c]">*</span>
627
- </span>
628
- <Input
629
- className="w-full bg-bg/50 border-border/50 focus-visible:ring-accent"
630
- placeholder={t("skillsview.eGMyAwesomeSkil")}
631
- value={skillCreateName}
632
- onChange={(e) => setState("skillCreateName", e.target.value)}
633
- onKeyDown={(e) => {
634
- if (e.key === "Enter" && skillCreateName.trim()) onCreate();
635
- }}
636
- />
637
- </div>
638
- <div>
639
- <span className="block text-[11px] text-[var(--muted)] mb-1 font-medium">
640
- {t("skillsview.Description")}
641
- </span>
642
- <Input
643
- className="w-full bg-bg/50 border-border/50 focus-visible:ring-accent"
644
- placeholder={t("skillsview.BriefDescriptionOf")}
645
- value={skillCreateDescription}
646
- onChange={(e) => setState("skillCreateDescription", e.target.value)}
647
- onKeyDown={(e) => {
648
- if (e.key === "Enter" && skillCreateName.trim()) onCreate();
649
- }}
650
- />
651
- </div>
652
- <div className="flex gap-2 justify-end pt-2">
653
- <Button variant="ghost" size="sm" onClick={onCancel}>
654
- {t("onboarding.cancel")}
655
- </Button>
656
- <Button
657
- variant="default"
658
- size="sm"
659
- onClick={onCreate}
660
- disabled={skillCreating || !skillCreateName.trim()}
661
- >
662
- {skillCreating ? "Creating..." : "Create Skill"}
663
- </Button>
664
- </div>
665
- </div>
666
- </div>
667
- );
668
- }
669
-
670
- /* ── Edit Skill Modal ──────────────────────────────────────────────── */
671
-
672
- function EditSkillModal({
673
- skillId,
674
- skillName,
675
- onClose,
676
- onSaved,
677
- }: {
678
- skillId: string;
679
- skillName: string;
680
- onClose: () => void;
681
- onSaved: () => void;
682
- }) {
683
- const { t } = useApp();
684
- const [content, setContent] = useState("");
685
- const [originalContent, setOriginalContent] = useState("");
686
- const [loading, setLoading] = useState(true);
687
- const [saving, setSaving] = useState(false);
688
- const [error, setError] = useState("");
689
- const [saveSuccess, setSaveSuccess] = useState(false);
690
-
691
- const loadSource = useCallback(async () => {
692
- setLoading(true);
693
- setError("");
694
- try {
695
- const res = await client.getSkillSource(skillId);
696
- setContent(res.content);
697
- setOriginalContent(res.content);
698
- } catch (err) {
699
- setError(
700
- err instanceof Error ? err.message : "Failed to load skill source",
701
- );
702
- }
703
- setLoading(false);
704
- }, [skillId]);
705
-
706
- useEffect(() => {
707
- void loadSource();
708
- }, [loadSource]);
709
-
710
- const hasChanges = content !== originalContent;
711
-
712
- const handleSave = async () => {
713
- setSaving(true);
714
- setError("");
715
- setSaveSuccess(false);
716
- try {
717
- await client.saveSkillSource(skillId, content);
718
- setOriginalContent(content);
719
- setSaveSuccess(true);
720
- onSaved();
721
- setTimeout(() => setSaveSuccess(false), 2000);
722
- } catch (err) {
723
- setError(err instanceof Error ? err.message : "Failed to save");
724
- }
725
- setSaving(false);
726
- };
727
-
728
- const handleKeyDown = (e: React.KeyboardEvent) => {
729
- if ((e.metaKey || e.ctrlKey) && e.key === "s") {
730
- e.preventDefault();
731
- if (hasChanges && !saving) void handleSave();
732
- }
733
- // Allow tab to insert spaces
734
- if (e.key === "Tab") {
735
- e.preventDefault();
736
- const target = e.target as HTMLTextAreaElement;
737
- const start = target.selectionStart;
738
- const end = target.selectionEnd;
739
- const val = target.value;
740
- setContent(`${val.substring(0, start)} ${val.substring(end)}`);
741
- requestAnimationFrame(() => {
742
- target.selectionStart = target.selectionEnd = start + 2;
743
- });
744
- }
745
- };
746
-
747
- return (
748
- <div
749
- className="fixed inset-0 z-[70] flex items-center justify-center bg-black/70"
750
- onClick={(e) => {
751
- if (e.target === e.currentTarget) onClose();
752
- }}
753
- onKeyDown={(e) => {
754
- if (e.key === "Escape" || e.key === "Enter" || e.key === " ") {
755
- e.preventDefault();
756
- onClose();
757
- }
758
- }}
759
- role="dialog"
760
- aria-modal="true"
761
- >
762
- <div
763
- className="w-full max-w-4xl h-[85vh] flex flex-col overflow-hidden mx-4 rounded-xl"
764
- style={{
765
- background: "color-mix(in srgb, var(--bg) 96%, transparent)",
766
- border:
767
- "1px solid color-mix(in srgb, var(--accent) 18%, transparent)",
768
- backdropFilter: "blur(24px)",
769
- boxShadow: "var(--shadow-lg)",
770
- }}
771
- >
772
- {/* Header */}
773
- <div
774
- className="flex items-center justify-between px-5 py-3 shrink-0"
775
- style={{ borderBottom: "1px solid var(--border)" }}
776
- >
777
- <div className="flex items-center gap-3 min-w-0">
778
- <div
779
- className="font-semibold text-sm truncate"
780
- style={{ color: "var(--text)" }}
781
- >
782
- {skillName}
783
- </div>
784
- <span
785
- className="text-[10px] font-mono px-1.5 py-0.5"
786
- style={{
787
- color: "var(--muted)",
788
- background: "var(--bg-hover)",
789
- border: "1px solid var(--border)",
790
- borderRadius: 4,
791
- }}
792
- >
793
- {t("skillsview.SKILLMd")}
794
- </span>
795
- {hasChanges && (
796
- <span
797
- className="text-[10px] font-medium"
798
- style={{ color: "#f0b232" }}
799
- >
800
- {t("skillsview.unsaved")}
801
- </span>
802
- )}
803
- </div>
804
- <div className="flex items-center gap-2">
805
- <span className="text-[10px]" style={{ color: "var(--muted)" }}>
806
- {navigator.platform.includes("Mac") ? "⌘S" : "Ctrl+S"}{" "}
807
- {t("skillsview.toSave")}
808
- </span>
809
- <button
810
- type="button"
811
- className="bg-transparent border-0 cursor-pointer text-lg px-2 transition-colors"
812
- style={{ color: "var(--muted)" }}
813
- onMouseEnter={(e) => {
814
- e.currentTarget.style.color = "var(--text)";
815
- }}
816
- onMouseLeave={(e) => {
817
- e.currentTarget.style.color = "var(--muted)";
818
- }}
819
- onClick={onClose}
820
- >
821
- ×
822
- </button>
823
- </div>
824
- </div>
825
-
826
- {/* Editor body */}
827
- <div className="flex-1 overflow-hidden">
828
- {loading ? (
829
- <div
830
- className="flex items-center justify-center h-full text-sm"
831
- style={{ color: "var(--muted)" }}
832
- >
833
- {t("skillsview.LoadingSkillSource")}
834
- </div>
835
- ) : error && !content ? (
836
- <div className="flex flex-col items-center justify-center h-full gap-3">
837
- <div className="text-sm font-medium" style={{ color: "#ef4444" }}>
838
- {error}
839
- </div>
840
- <button
841
- type="button"
842
- className="px-3 py-1.5 text-xs font-medium rounded cursor-pointer transition-colors"
843
- style={{
844
- background: "var(--bg-hover)",
845
- border: "1px solid var(--border)",
846
- color: "var(--text)",
847
- }}
848
- onClick={() => loadSource()}
849
- >
850
- {t("common.retry")}
851
- </button>
852
- </div>
853
- ) : (
854
- <textarea
855
- className="w-full h-full resize-none border-0 text-[13px] leading-relaxed font-mono p-5 focus:outline-none"
856
- style={{
857
- background: "var(--bg-hover)",
858
- color: "var(--text)",
859
- }}
860
- value={content}
861
- onChange={(e) => setContent(e.target.value)}
862
- onKeyDown={handleKeyDown}
863
- spellCheck={false}
864
- />
865
- )}
866
- </div>
867
-
868
- {/* Footer */}
869
- <div
870
- className="flex items-center justify-between px-5 py-3 shrink-0"
871
- style={{ borderTop: "1px solid var(--border)" }}
872
- >
873
- <div className="text-[11px]" style={{ color: "var(--muted)" }}>
874
- {content ? `${content.split("\n").length} lines` : ""}
875
- {error && content ? (
876
- <span className="ml-3" style={{ color: "#ef4444" }}>
877
- {error}
878
- </span>
879
- ) : null}
880
- </div>
881
- <div className="flex items-center gap-2">
882
- <button
883
- type="button"
884
- className="px-3 py-1.5 text-xs font-medium rounded cursor-pointer transition-colors"
885
- style={{
886
- background: "transparent",
887
- border: "1px solid var(--border)",
888
- color: "var(--muted)",
889
- }}
890
- onClick={onClose}
891
- >
892
- {hasChanges ? "Discard" : "Close"}
893
- </button>
894
- <button
895
- type="button"
896
- className="px-3 py-1.5 text-xs font-medium rounded cursor-pointer transition-colors"
897
- style={{
898
- background: saveSuccess ? "#22c55e" : "#f0b232",
899
- border: "none",
900
- color: saveSuccess ? "#fff" : "#000",
901
- opacity: saving || !hasChanges ? 0.5 : 1,
902
- }}
903
- onClick={() => handleSave()}
904
- disabled={saving || !hasChanges}
905
- >
906
- {saving ? "Saving..." : saveSuccess ? "Saved" : "Save"}
907
- </button>
908
- </div>
909
- </div>
910
- </div>
911
- </div>
912
- );
913
- }
914
-
915
- /* ── Main Skills View ───────────────────────────────────────────────── */
916
-
917
- export function SkillsView({ inModal }: { inModal?: boolean } = {}) {
918
- if (inModal) return <SkillsModalView />;
919
- return <SkillsFullView />;
920
- }
921
-
922
- /* ── Companion Modal View (sidebar + detail, reuses plugins-game-* CSS) ── */
923
-
924
- function SkillsModalView() {
925
- const {
926
- skills,
927
- skillToggleAction,
928
- loadSkills,
929
- handleSkillToggle,
930
- handleDeleteSkill,
931
- refreshSkills,
932
- setState,
933
- skillsMarketplaceQuery,
934
- skillsMarketplaceResults,
935
- skillsMarketplaceError,
936
- skillsMarketplaceLoading,
937
- skillsMarketplaceAction,
938
- skillsMarketplaceManualGithubUrl,
939
- searchSkillsMarketplace,
940
- installSkillFromMarketplace,
941
- uninstallMarketplaceSkill,
942
- installSkillFromGithubUrl,
943
- } = useApp();
944
-
945
- const [selectedId, setSelectedId] = useState<string | null>(null);
946
- const [filterText, setFilterText] = useState("");
947
- const [filterTab, setFilterTab] = useState<"all" | "on" | "off">("all");
948
- const [editingSkill, setEditingSkill] = useState<SkillInfo | null>(null);
949
- const [installModalOpen, setInstallModalOpen] = useState(false);
950
-
951
- useEffect(() => {
952
- void loadSkills();
953
- }, [loadSkills]);
954
-
955
- const filtered = useMemo(() => {
956
- const searchLower = filterText.toLowerCase();
957
- return skills.filter((s) => {
958
- if (filterTab === "on" && !s.enabled) return false;
959
- if (filterTab === "off" && s.enabled) return false;
960
- if (
961
- searchLower &&
962
- !s.name.toLowerCase().includes(searchLower) &&
963
- !(s.description ?? "").toLowerCase().includes(searchLower)
964
- )
965
- return false;
966
- return true;
967
- });
968
- }, [skills, filterText, filterTab]);
969
-
970
- const effectiveSelectedId =
971
- selectedId && filtered.find((s) => s.id === selectedId)
972
- ? selectedId
973
- : (filtered[0]?.id ?? null);
974
- const selected = effectiveSelectedId
975
- ? (skills.find((s) => s.id === effectiveSelectedId) ?? null)
976
- : null;
977
-
978
- const tabs: { key: typeof filterTab; label: string }[] = [
979
- { key: "all", label: `ALL (${skills.length})` },
980
- { key: "on", label: `ON (${skills.filter((s) => s.enabled).length})` },
981
- { key: "off", label: `OFF (${skills.filter((s) => !s.enabled).length})` },
982
- ];
983
-
984
- return (
985
- <div className="plugins-game-modal">
986
- {/* ── Left sidebar ── */}
987
- <div className="plugins-game-list-panel">
988
- <div className="plugins-game-list-head">
989
- <div className="plugins-game-section-title">Talents</div>
990
- <div className="plugins-game-section-meta">
991
- {skills.length} installed
992
- </div>
993
- </div>
994
-
995
- {/* Search + Install */}
996
- <div className="plugins-game-list-search">
997
- <div className="plugins-game-list-search-row">
998
- <input
999
- type="text"
1000
- placeholder="Search skills..."
1001
- value={filterText}
1002
- onChange={(e) => setFilterText(e.target.value)}
1003
- className="plugins-game-search-input"
1004
- />
1005
- <button
1006
- type="button"
1007
- className="plugins-game-chip plugins-game-add-btn"
1008
- onClick={() => setInstallModalOpen(true)}
1009
- >
1010
- <span className="plugins-game-add-symbol">+</span> Install
1011
- </button>
1012
- </div>
1013
- </div>
1014
-
1015
- {/* Filter tabs */}
1016
- <div className="plugins-game-chip-row">
1017
- {tabs.map((tab) => (
1018
- <button
1019
- key={tab.key}
1020
- type="button"
1021
- className={`plugins-game-chip plugins-game-chip-small${filterTab === tab.key ? " is-active" : ""}`}
1022
- onClick={() => setFilterTab(tab.key)}
1023
- >
1024
- {tab.label}
1025
- </button>
1026
- ))}
1027
- </div>
1028
-
1029
- {/* Skill list */}
1030
- <div className="plugins-game-list-scroll">
1031
- {filtered.length === 0 ? (
1032
- <div className="plugins-game-list-empty">No skills found</div>
1033
- ) : (
1034
- filtered.map((skill) => (
1035
- <button
1036
- key={skill.id}
1037
- type="button"
1038
- className={`plugins-game-card${effectiveSelectedId === skill.id ? " is-selected" : ""}${!skill.enabled ? " is-disabled" : ""}`}
1039
- onClick={() => setSelectedId(skill.id)}
1040
- >
1041
- <div className="plugins-game-card-icon-shell">
1042
- <span className="plugins-game-card-icon">
1043
- {skill.name.charAt(0).toUpperCase()}
1044
- </span>
1045
- </div>
1046
- <div className="plugins-game-card-body">
1047
- <div className="plugins-game-card-name">{skill.name}</div>
1048
- <div className="plugins-game-card-meta">
1049
- <span
1050
- className={`plugins-game-badge ${skill.enabled ? "is-on" : "is-off"}`}
1051
- >
1052
- {skill.enabled ? "ON" : "OFF"}
1053
- </span>
1054
- </div>
1055
- </div>
1056
- </button>
1057
- ))
1058
- )}
1059
- </div>
1060
- </div>
1061
-
1062
- {/* ── Right detail panel ── */}
1063
- <div className="plugins-game-detail-panel">
1064
- {selected ? (
1065
- <>
1066
- <div className="plugins-game-detail-head">
1067
- <div className="plugins-game-detail-title-row">
1068
- <div className="plugins-game-detail-icon-shell">
1069
- <span className="plugins-game-detail-icon">
1070
- {selected.name.charAt(0).toUpperCase()}
1071
- </span>
1072
- </div>
1073
- <div className="plugins-game-detail-main">
1074
- <div className="plugins-game-detail-name">
1075
- {selected.name}
1076
- </div>
1077
- </div>
1078
- <button
1079
- type="button"
1080
- className={`plugins-game-toggle ${selected.enabled ? "is-on" : "is-off"}`}
1081
- onClick={() =>
1082
- handleSkillToggle(selected.id, !selected.enabled)
1083
- }
1084
- disabled={skillToggleAction === selected.id}
1085
- >
1086
- {skillToggleAction === selected.id
1087
- ? "..."
1088
- : selected.enabled
1089
- ? "ON"
1090
- : "OFF"}
1091
- </button>
1092
- </div>
1093
- </div>
1094
- <div className="plugins-game-detail-description">
1095
- {selected.description || "No description provided."}
1096
- </div>
1097
- <div className="plugins-game-detail-actions">
1098
- <button
1099
- type="button"
1100
- className="plugins-game-action-btn"
1101
- onClick={() => setEditingSkill(selected)}
1102
- >
1103
- Edit Source
1104
- </button>
1105
- <button
1106
- type="button"
1107
- className="plugins-game-action-btn"
1108
- onClick={() => handleDeleteSkill(selected.id, selected.name)}
1109
- >
1110
- Delete
1111
- </button>
1112
- </div>
1113
- </>
1114
- ) : (
1115
- <div className="plugins-game-detail-empty">
1116
- <span className="plugins-game-detail-empty-icon">🧠</span>
1117
- <span className="plugins-game-detail-empty-text">
1118
- Select a talent to configure
1119
- </span>
1120
- </div>
1121
- )}
1122
- </div>
1123
-
1124
- {/* Portal modals to body so they escape the 3D transform stacking context */}
1125
- {editingSkill &&
1126
- createPortal(
1127
- <EditSkillModal
1128
- skillId={editingSkill.id}
1129
- skillName={editingSkill.name}
1130
- onClose={() => setEditingSkill(null)}
1131
- onSaved={() => void refreshSkills()}
1132
- />,
1133
- document.body,
1134
- )}
1135
-
1136
- {installModalOpen &&
1137
- createPortal(
1138
- <InstallModal
1139
- skills={skills}
1140
- skillsMarketplaceQuery={skillsMarketplaceQuery}
1141
- skillsMarketplaceResults={skillsMarketplaceResults}
1142
- skillsMarketplaceError={skillsMarketplaceError}
1143
- skillsMarketplaceLoading={skillsMarketplaceLoading}
1144
- skillsMarketplaceAction={skillsMarketplaceAction}
1145
- skillsMarketplaceManualGithubUrl={skillsMarketplaceManualGithubUrl}
1146
- searchSkillsMarketplace={searchSkillsMarketplace}
1147
- installSkillFromMarketplace={installSkillFromMarketplace}
1148
- uninstallMarketplaceSkill={uninstallMarketplaceSkill}
1149
- installSkillFromGithubUrl={installSkillFromGithubUrl}
1150
- setState={setState}
1151
- onClose={() => setInstallModalOpen(false)}
1152
- />,
1153
- document.body,
1154
- )}
1155
- </div>
1156
- );
1157
- }
1158
-
1159
- /* ── Full-Page Skills View ─────────────────────────────────────────── */
1160
-
1161
- function SkillsFullView() {
1162
- const { setTimeout: _setTimeout } = useTimeout();
1163
-
1164
- const {
1165
- skills,
1166
- skillCreateFormOpen,
1167
- skillCreateName,
1168
- skillCreateDescription,
1169
- skillCreating,
1170
- skillReviewReport,
1171
- skillReviewId,
1172
- skillReviewLoading,
1173
- skillToggleAction,
1174
- skillsMarketplaceQuery,
1175
- skillsMarketplaceResults,
1176
- skillsMarketplaceError,
1177
- skillsMarketplaceLoading,
1178
- skillsMarketplaceAction,
1179
- skillsMarketplaceManualGithubUrl,
1180
- loadSkills,
1181
- refreshSkills,
1182
- handleSkillToggle,
1183
- handleCreateSkill,
1184
- handleDeleteSkill,
1185
- handleReviewSkill,
1186
- handleAcknowledgeSkill,
1187
- searchSkillsMarketplace,
1188
- installSkillFromMarketplace,
1189
- uninstallMarketplaceSkill,
1190
- installSkillFromGithubUrl,
1191
- setState,
1192
- } = useApp();
1193
-
1194
- const [installModalOpen, setInstallModalOpen] = useState(false);
1195
- const [filterText, setFilterText] = useState("");
1196
- const [editingSkill, setEditingSkill] = useState<SkillInfo | null>(null);
1197
-
1198
- useEffect(() => {
1199
- void loadSkills();
1200
- }, [loadSkills]);
1201
-
1202
- // Group into: needs attention, active, inactive — with text filter
1203
- const { attention, active, inactive, activeCount, totalCount } =
1204
- useMemo(() => {
1205
- const attention: SkillInfo[] = [];
1206
- const active: SkillInfo[] = [];
1207
- const inactive: SkillInfo[] = [];
1208
- let activeCount = 0;
1209
-
1210
- const query = filterText.toLowerCase();
1211
-
1212
- for (const skill of skills) {
1213
- if (
1214
- query &&
1215
- !skill.name.toLowerCase().includes(query) &&
1216
- !skill.description?.toLowerCase().includes(query)
1217
- ) {
1218
- continue;
1219
- }
1220
-
1221
- if (skill.enabled) activeCount++;
1222
-
1223
- if (
1224
- skill.scanStatus === "warning" ||
1225
- skill.scanStatus === "critical" ||
1226
- skill.scanStatus === "blocked"
1227
- ) {
1228
- attention.push(skill);
1229
- } else if (skill.enabled) {
1230
- active.push(skill);
1231
- } else {
1232
- inactive.push(skill);
1233
- }
1234
- }
1235
-
1236
- return {
1237
- attention,
1238
- active,
1239
- inactive,
1240
- activeCount,
1241
- totalCount: skills.length,
1242
- };
1243
- }, [skills, filterText]);
1244
-
1245
- const handleDismissReview = () => {
1246
- setState("skillReviewId", "");
1247
- setState("skillReviewReport", null);
1248
- };
1249
-
1250
- const handleCancelCreate = () => {
1251
- setState("skillCreateFormOpen", false);
1252
- setState("skillCreateName", "");
1253
- setState("skillCreateDescription", "");
1254
- };
1255
-
1256
- const allVisible = [...attention, ...active, ...inactive];
1257
-
1258
- /** Render a group of skill cards in a grid with a section header. */
1259
- const renderGroup = (label: string, items: SkillInfo[], accent?: string) => {
1260
- if (items.length === 0) return null;
1261
- return (
1262
- <div className="mb-6">
1263
- <div
1264
- className="text-xs uppercase tracking-wider font-semibold mb-2 flex items-center gap-2"
1265
- style={accent ? { color: accent } : { color: "var(--muted)" }}
1266
- >
1267
- {label}
1268
- <span className="text-[10px] font-mono opacity-60">
1269
- ({items.length})
1270
- </span>
1271
- </div>
1272
- <div className="grid grid-cols-1 md:grid-cols-2 gap-3">
1273
- {items.map((skill) => (
1274
- <SkillCard
1275
- key={skill.id}
1276
- skill={skill}
1277
- skillToggleAction={skillToggleAction}
1278
- skillReviewId={skillReviewId}
1279
- skillReviewReport={skillReviewReport}
1280
- skillReviewLoading={skillReviewLoading}
1281
- onToggle={handleSkillToggle}
1282
- onEdit={setEditingSkill}
1283
- onDelete={handleDeleteSkill}
1284
- onReview={handleReviewSkill}
1285
- onAcknowledge={handleAcknowledgeSkill}
1286
- onDismissReview={handleDismissReview}
1287
- />
1288
- ))}
1289
- </div>
1290
- </div>
1291
- );
1292
- };
1293
-
1294
- return (
1295
- <div>
1296
- {/* Stats bar */}
1297
- <div className="flex items-center gap-4 mb-4 text-[11px] text-[var(--muted)]">
1298
- <span>
1299
- {totalCount} skill{totalCount !== 1 ? "s" : ""}
1300
- </span>
1301
- <span>{activeCount} active</span>
1302
- <span>{inactive.length} inactive</span>
1303
- {attention.length > 0 && (
1304
- <span className="text-[#f39c12]">
1305
- {attention.length} need{attention.length === 1 ? "s" : ""} attention
1306
- </span>
1307
- )}
1308
- </div>
1309
-
1310
- {/* Toolbar */}
1311
- <div className="flex flex-wrap items-center gap-3 mb-6 p-3 border border-border/40 bg-card/60 backdrop-blur-md rounded-2xl shadow-sm">
1312
- <Input
1313
- type="text"
1314
- placeholder="Filter skills..."
1315
- value={filterText}
1316
- onChange={(e) => setFilterText(e.target.value)}
1317
- className="w-[240px] h-9 bg-bg/50 border-border/50 focus-visible:ring-accent rounded-xl text-xs"
1318
- />
1319
-
1320
- <span className="flex-1" />
1321
-
1322
- <Button
1323
- variant={skillCreateFormOpen ? "ghost" : "default"}
1324
- size="sm"
1325
- className={
1326
- skillCreateFormOpen
1327
- ? "h-9 px-4 font-bold text-muted hover:text-txt"
1328
- : "h-9 px-4 font-bold tracking-wide shadow-sm"
1329
- }
1330
- onClick={() => setState("skillCreateFormOpen", !skillCreateFormOpen)}
1331
- >
1332
- {skillCreateFormOpen ? "Cancel" : "+ New Skill"}
1333
- </Button>
1334
- <Button
1335
- variant="default"
1336
- size="sm"
1337
- className="h-9 px-4 font-bold tracking-wide shadow-sm"
1338
- onClick={() => setInstallModalOpen(true)}
1339
- >
1340
- Browse Marketplace
1341
- </Button>
1342
- <Button
1343
- variant="ghost"
1344
- size="sm"
1345
- className="h-9 px-4 font-bold text-muted hover:text-txt"
1346
- onClick={() => refreshSkills()}
1347
- title="Refresh Skills List"
1348
- >
1349
- Refresh
1350
- </Button>
1351
- </div>
1352
-
1353
- {/* Create form */}
1354
- {skillCreateFormOpen && (
1355
- <CreateSkillForm
1356
- skillCreateName={skillCreateName}
1357
- skillCreateDescription={skillCreateDescription}
1358
- skillCreating={skillCreating}
1359
- setState={setState}
1360
- onCancel={handleCancelCreate}
1361
- onCreate={handleCreateSkill}
1362
- />
1363
- )}
1364
-
1365
- {/* Skill grid — grouped by status */}
1366
- {skills.length === 0 ? (
1367
- <div className="text-center py-16">
1368
- <div className="text-[var(--muted)] text-sm mb-2">
1369
- No Skills Installed
1370
- </div>
1371
- <div className="text-[var(--muted)] text-[11px] mb-4">
1372
- Install skills from the marketplace or create your own.
1373
- </div>
1374
- <div className="flex justify-center gap-3">
1375
- <Button
1376
- variant="default"
1377
- size="sm"
1378
- className="h-10 px-6 font-bold tracking-wide shadow-sm"
1379
- onClick={() => setInstallModalOpen(true)}
1380
- >
1381
- Browse Marketplace
1382
- </Button>
1383
- <Button
1384
- variant="ghost"
1385
- size="sm"
1386
- className="h-10 px-6 font-bold text-muted hover:text-txt"
1387
- onClick={() => setState("skillCreateFormOpen", true)}
1388
- >
1389
- Create Skill
1390
- </Button>
1391
- </div>
1392
- </div>
1393
- ) : allVisible.length === 0 ? (
1394
- <div className="text-center py-12 text-[var(--muted)] text-xs">
1395
- No skills match filtering "{filterText}"
1396
- </div>
1397
- ) : (
1398
- <div>
1399
- {renderGroup("Needs Attention", attention, "#f39c12")}
1400
- {renderGroup("Active", active, "var(--ok, #16a34a)")}
1401
- {renderGroup("Inactive", inactive)}
1402
- </div>
1403
- )}
1404
-
1405
- {/* Edit modal */}
1406
- {editingSkill && (
1407
- <EditSkillModal
1408
- skillId={editingSkill.id}
1409
- skillName={editingSkill.name}
1410
- onClose={() => setEditingSkill(null)}
1411
- onSaved={() => void refreshSkills()}
1412
- />
1413
- )}
1414
-
1415
- {/* Install modal */}
1416
- {installModalOpen && (
1417
- <InstallModal
1418
- skills={skills}
1419
- skillsMarketplaceQuery={skillsMarketplaceQuery}
1420
- skillsMarketplaceResults={skillsMarketplaceResults}
1421
- skillsMarketplaceError={skillsMarketplaceError}
1422
- skillsMarketplaceLoading={skillsMarketplaceLoading}
1423
- skillsMarketplaceAction={skillsMarketplaceAction}
1424
- skillsMarketplaceManualGithubUrl={skillsMarketplaceManualGithubUrl}
1425
- searchSkillsMarketplace={searchSkillsMarketplace}
1426
- installSkillFromMarketplace={installSkillFromMarketplace}
1427
- uninstallMarketplaceSkill={uninstallMarketplaceSkill}
1428
- installSkillFromGithubUrl={installSkillFromGithubUrl}
1429
- setState={setState}
1430
- onClose={() => setInstallModalOpen(false)}
1431
- />
1432
- )}
1433
- </div>
1434
- );
1435
- }