@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.
- package/App.d.ts +5 -0
- package/App.d.ts.map +1 -0
- package/App.js +220 -0
- package/actions/character.d.ts +39 -0
- package/actions/character.d.ts.map +1 -0
- package/actions/character.js +247 -0
- package/actions/chat-helpers.d.ts +47 -0
- package/actions/chat-helpers.d.ts.map +1 -0
- package/actions/chat-helpers.js +79 -0
- package/actions/cloud.d.ts +17 -0
- package/actions/cloud.d.ts.map +1 -0
- package/actions/cloud.js +43 -0
- package/actions/index.d.ts +12 -0
- package/actions/index.d.ts.map +1 -0
- package/actions/index.js +11 -0
- package/actions/lifecycle.d.ts +43 -0
- package/actions/lifecycle.d.ts.map +1 -0
- package/actions/lifecycle.js +118 -0
- package/actions/onboarding.d.ts +12 -0
- package/actions/onboarding.d.ts.map +1 -0
- package/actions/onboarding.js +26 -0
- package/actions/triggers.d.ts +23 -0
- package/actions/triggers.d.ts.map +1 -0
- package/actions/triggers.js +148 -0
- package/api/client.d.ts +2736 -0
- package/api/client.d.ts.map +1 -0
- package/api/client.js +2492 -0
- package/api/index.d.ts +2 -0
- package/api/index.d.ts.map +1 -0
- package/autonomy/index.d.ts +48 -0
- package/autonomy/index.d.ts.map +1 -0
- package/autonomy/index.js +330 -0
- package/bridge/capacitor-bridge.d.ts +153 -0
- package/bridge/capacitor-bridge.d.ts.map +1 -0
- package/bridge/capacitor-bridge.js +193 -0
- package/bridge/electrobun-rpc.d.ts +28 -0
- package/bridge/electrobun-rpc.d.ts.map +1 -0
- package/bridge/electrobun-rpc.js +35 -0
- package/bridge/electrobun-runtime.d.ts +3 -0
- package/bridge/electrobun-runtime.d.ts.map +1 -0
- package/bridge/electrobun-runtime.js +17 -0
- package/bridge/index.d.ts +6 -0
- package/bridge/index.d.ts.map +1 -0
- package/bridge/native-plugins.d.ts +82 -0
- package/bridge/native-plugins.d.ts.map +1 -0
- package/bridge/native-plugins.js +39 -0
- package/bridge/plugin-bridge.d.ts +116 -0
- package/bridge/plugin-bridge.d.ts.map +1 -0
- package/bridge/plugin-bridge.js +203 -0
- package/bridge/storage-bridge.d.ts +39 -0
- package/bridge/storage-bridge.d.ts.map +1 -0
- package/bridge/storage-bridge.js +135 -0
- package/chat/index.d.ts +57 -0
- package/chat/index.d.ts.map +1 -0
- package/chat/index.js +160 -0
- package/coding/index.d.ts +25 -0
- package/coding/index.d.ts.map +1 -0
- package/coding/index.js +25 -0
- package/components/AdvancedPageView.d.ts +17 -0
- package/components/AdvancedPageView.d.ts.map +1 -0
- package/components/AdvancedPageView.js +146 -0
- package/components/AgentActivityBox.d.ts +7 -0
- package/components/AgentActivityBox.d.ts.map +1 -0
- package/components/AgentActivityBox.js +25 -0
- package/components/ApiKeyConfig.d.ts +26 -0
- package/components/ApiKeyConfig.d.ts.map +1 -0
- package/components/ApiKeyConfig.js +119 -0
- package/components/AppsPageView.d.ts +7 -0
- package/components/AppsPageView.d.ts.map +1 -0
- package/components/AppsPageView.js +31 -0
- package/components/AppsView.d.ts +8 -0
- package/components/AppsView.d.ts.map +1 -0
- package/components/AppsView.js +149 -0
- package/components/AvatarLoader.d.ts +13 -0
- package/components/AvatarLoader.d.ts.map +1 -0
- package/components/AvatarLoader.js +53 -0
- package/components/AvatarSelector.d.ts +23 -0
- package/components/AvatarSelector.d.ts.map +1 -0
- package/components/AvatarSelector.js +105 -0
- package/components/BscTradePanel.d.ts +22 -0
- package/components/BscTradePanel.d.ts.map +1 -0
- package/components/BscTradePanel.js +221 -0
- package/components/BugReportModal.d.ts +2 -0
- package/components/BugReportModal.d.ts.map +1 -0
- package/components/BugReportModal.js +219 -0
- package/components/CharacterRoster.d.ts +31 -0
- package/components/CharacterRoster.d.ts.map +1 -0
- package/components/CharacterRoster.js +41 -0
- package/components/CharacterView.d.ts +8 -0
- package/components/CharacterView.d.ts.map +1 -0
- package/components/CharacterView.js +685 -0
- package/components/ChatAvatar.d.ts +8 -0
- package/components/ChatAvatar.d.ts.map +1 -0
- package/components/ChatAvatar.js +89 -0
- package/components/ChatComposer.d.ts +37 -0
- package/components/ChatComposer.d.ts.map +1 -0
- package/components/ChatComposer.js +136 -0
- package/components/ChatMessage.d.ts +24 -0
- package/components/ChatMessage.d.ts.map +1 -0
- package/components/ChatMessage.js +167 -0
- package/components/ChatModalView.d.ts +10 -0
- package/components/ChatModalView.d.ts.map +1 -0
- package/components/ChatModalView.js +57 -0
- package/components/ChatView.d.ts +14 -0
- package/components/ChatView.d.ts.map +1 -0
- package/components/ChatView.js +526 -0
- package/components/CloudOnboarding.d.ts +7 -0
- package/components/CloudOnboarding.d.ts.map +1 -0
- package/components/CloudOnboarding.js +22 -0
- package/components/CloudSourceControls.d.ts +13 -0
- package/components/CloudSourceControls.d.ts.map +1 -0
- package/components/CloudSourceControls.js +16 -0
- package/components/CodingAgentSettingsSection.d.ts +2 -0
- package/components/CodingAgentSettingsSection.d.ts.map +1 -0
- package/components/CodingAgentSettingsSection.js +270 -0
- package/components/CommandPalette.d.ts +2 -0
- package/components/CommandPalette.d.ts.map +1 -0
- package/components/CommandPalette.js +181 -0
- package/components/CompanionSceneHost.d.ts +14 -0
- package/components/CompanionSceneHost.d.ts.map +1 -0
- package/components/CompanionSceneHost.js +360 -0
- package/components/CompanionShell.d.ts +17 -0
- package/components/CompanionShell.d.ts.map +1 -0
- package/components/CompanionShell.js +15 -0
- package/components/CompanionView.d.ts +2 -0
- package/components/CompanionView.d.ts.map +1 -0
- package/components/CompanionView.js +22 -0
- package/components/ConfigPageView.d.ts +11 -0
- package/components/ConfigPageView.d.ts.map +1 -0
- package/components/ConfigPageView.js +303 -0
- package/components/ConfigSaveFooter.d.ts +8 -0
- package/components/ConfigSaveFooter.d.ts.map +1 -0
- package/components/ConfigSaveFooter.js +10 -0
- package/components/ConfirmModal.d.ts +61 -0
- package/components/ConfirmModal.d.ts.map +1 -0
- package/components/ConfirmModal.js +164 -0
- package/components/ConnectionFailedBanner.d.ts +6 -0
- package/components/ConnectionFailedBanner.d.ts.map +1 -0
- package/components/ConnectionFailedBanner.js +22 -0
- package/components/ConnectorsPageView.d.ts +7 -0
- package/components/ConnectorsPageView.d.ts.map +1 -0
- package/components/ConnectorsPageView.js +8 -0
- package/components/ConversationsSidebar.d.ts +9 -0
- package/components/ConversationsSidebar.d.ts.map +1 -0
- package/components/ConversationsSidebar.js +116 -0
- package/components/CustomActionEditor.d.ts +10 -0
- package/components/CustomActionEditor.d.ts.map +1 -0
- package/components/CustomActionEditor.js +578 -0
- package/components/CustomActionsPanel.d.ts +9 -0
- package/components/CustomActionsPanel.d.ts.map +1 -0
- package/components/CustomActionsPanel.js +107 -0
- package/components/CustomActionsView.d.ts +2 -0
- package/components/CustomActionsView.d.ts.map +1 -0
- package/components/CustomActionsView.js +134 -0
- package/components/DatabasePageView.d.ts +5 -0
- package/components/DatabasePageView.d.ts.map +1 -0
- package/components/DatabasePageView.js +28 -0
- package/components/DatabaseView.d.ts +9 -0
- package/components/DatabaseView.d.ts.map +1 -0
- package/components/DatabaseView.js +311 -0
- package/components/ElizaCloudDashboard.d.ts +2 -0
- package/components/ElizaCloudDashboard.d.ts.map +1 -0
- package/components/ElizaCloudDashboard.js +657 -0
- package/components/EmotePicker.d.ts +2 -0
- package/components/EmotePicker.d.ts.map +1 -0
- package/components/EmotePicker.js +343 -0
- package/components/ErrorBoundary.d.ts +22 -0
- package/components/ErrorBoundary.d.ts.map +1 -0
- package/components/ErrorBoundary.js +31 -0
- package/components/FineTuningView.d.ts +2 -0
- package/components/FineTuningView.d.ts.map +1 -0
- package/components/FineTuningView.js +433 -0
- package/components/FlaminaGuide.d.ts +10 -0
- package/components/FlaminaGuide.d.ts.map +1 -0
- package/components/FlaminaGuide.js +64 -0
- package/components/GameView.d.ts +11 -0
- package/components/GameView.d.ts.map +1 -0
- package/components/GameView.js +294 -0
- package/components/GameViewOverlay.d.ts +8 -0
- package/components/GameViewOverlay.d.ts.map +1 -0
- package/components/GameViewOverlay.js +70 -0
- package/components/GlobalEmoteOverlay.d.ts +2 -0
- package/components/GlobalEmoteOverlay.d.ts.map +1 -0
- package/components/GlobalEmoteOverlay.js +112 -0
- package/components/Header.d.ts +9 -0
- package/components/Header.d.ts.map +1 -0
- package/components/Header.js +123 -0
- package/components/HeartbeatsView.d.ts +2 -0
- package/components/HeartbeatsView.d.ts.map +1 -0
- package/components/HeartbeatsView.js +378 -0
- package/components/InventoryView.d.ts +10 -0
- package/components/InventoryView.d.ts.map +1 -0
- package/components/InventoryView.js +176 -0
- package/components/KnowledgeView.d.ts +20 -0
- package/components/KnowledgeView.d.ts.map +1 -0
- package/components/KnowledgeView.js +480 -0
- package/components/LanguageDropdown.d.ts +30 -0
- package/components/LanguageDropdown.d.ts.map +1 -0
- package/components/LanguageDropdown.js +99 -0
- package/components/LifoMonitorPanel.d.ts +21 -0
- package/components/LifoMonitorPanel.d.ts.map +1 -0
- package/components/LifoMonitorPanel.js +24 -0
- package/components/LifoSandboxView.d.ts +5 -0
- package/components/LifoSandboxView.d.ts.map +1 -0
- package/components/LifoSandboxView.js +333 -0
- package/components/LoadingScreen.d.ts +13 -0
- package/components/LoadingScreen.d.ts.map +1 -0
- package/components/LoadingScreen.js +70 -0
- package/components/LogsPageView.d.ts +2 -0
- package/components/LogsPageView.d.ts.map +1 -0
- package/components/LogsPageView.js +7 -0
- package/components/LogsView.d.ts +5 -0
- package/components/LogsView.d.ts.map +1 -0
- package/components/LogsView.js +71 -0
- package/components/MediaGalleryView.d.ts +9 -0
- package/components/MediaGalleryView.d.ts.map +1 -0
- package/components/MediaGalleryView.js +236 -0
- package/components/MediaSettingsSection.d.ts +11 -0
- package/components/MediaSettingsSection.d.ts.map +1 -0
- package/components/MediaSettingsSection.js +329 -0
- package/components/MessageContent.d.ts +51 -0
- package/components/MessageContent.d.ts.map +1 -0
- package/components/MessageContent.js +553 -0
- package/components/OnboardingWizard.d.ts +2 -0
- package/components/OnboardingWizard.d.ts.map +1 -0
- package/components/OnboardingWizard.js +96 -0
- package/components/PairingView.d.ts +5 -0
- package/components/PairingView.d.ts.map +1 -0
- package/components/PairingView.js +29 -0
- package/components/PermissionsSection.d.ts +20 -0
- package/components/PermissionsSection.d.ts.map +1 -0
- package/components/PermissionsSection.js +573 -0
- package/components/PluginsPageView.d.ts +5 -0
- package/components/PluginsPageView.d.ts.map +1 -0
- package/components/PluginsPageView.js +8 -0
- package/components/PluginsView.d.ts +21 -0
- package/components/PluginsView.d.ts.map +1 -0
- package/components/PluginsView.js +1534 -0
- package/components/ProviderSwitcher.d.ts +42 -0
- package/components/ProviderSwitcher.d.ts.map +1 -0
- package/components/ProviderSwitcher.js +493 -0
- package/components/RestartBanner.d.ts +2 -0
- package/components/RestartBanner.d.ts.map +1 -0
- package/components/RestartBanner.js +36 -0
- package/components/RuntimeView.d.ts +10 -0
- package/components/RuntimeView.d.ts.map +1 -0
- package/components/RuntimeView.js +165 -0
- package/components/SaveCommandModal.d.ts +12 -0
- package/components/SaveCommandModal.d.ts.map +1 -0
- package/components/SaveCommandModal.js +84 -0
- package/components/SecretsView.d.ts +9 -0
- package/components/SecretsView.d.ts.map +1 -0
- package/components/SecretsView.js +249 -0
- package/components/SettingsView.d.ts +9 -0
- package/components/SettingsView.d.ts.map +1 -0
- package/components/SettingsView.js +230 -0
- package/components/ShellOverlays.d.ts +8 -0
- package/components/ShellOverlays.d.ts.map +1 -0
- package/components/ShellOverlays.js +10 -0
- package/components/ShortcutsOverlay.d.ts +2 -0
- package/components/ShortcutsOverlay.d.ts.map +1 -0
- package/components/ShortcutsOverlay.js +79 -0
- package/components/SkillsView.d.ts +11 -0
- package/components/SkillsView.d.ts.map +1 -0
- package/components/SkillsView.js +358 -0
- package/components/StartupFailureView.d.ts +8 -0
- package/components/StartupFailureView.d.ts.map +1 -0
- package/components/StartupFailureView.js +16 -0
- package/components/StreamView.d.ts +16 -0
- package/components/StreamView.d.ts.map +1 -0
- package/components/StreamView.js +300 -0
- package/components/StripeEmbeddedCheckout.d.ts +24 -0
- package/components/StripeEmbeddedCheckout.d.ts.map +1 -0
- package/components/StripeEmbeddedCheckout.js +101 -0
- package/components/SubscriptionStatus.d.ts +23 -0
- package/components/SubscriptionStatus.d.ts.map +1 -0
- package/components/SubscriptionStatus.js +301 -0
- package/components/SystemWarningBanner.d.ts +6 -0
- package/components/SystemWarningBanner.d.ts.map +1 -0
- package/components/SystemWarningBanner.js +46 -0
- package/components/ThemeToggle.d.ts +21 -0
- package/components/ThemeToggle.d.ts.map +1 -0
- package/components/ThemeToggle.js +24 -0
- package/components/TrajectoriesView.d.ts +12 -0
- package/components/TrajectoriesView.d.ts.map +1 -0
- package/components/TrajectoriesView.js +183 -0
- package/components/TrajectoryDetailView.d.ts +13 -0
- package/components/TrajectoryDetailView.d.ts.map +1 -0
- package/components/TrajectoryDetailView.js +112 -0
- package/components/TriggersView.d.ts +2 -0
- package/components/TriggersView.d.ts.map +1 -0
- package/components/VectorBrowserView.d.ts +10 -0
- package/components/VectorBrowserView.d.ts.map +1 -0
- package/components/VectorBrowserView.js +997 -0
- package/components/VoiceConfigView.d.ts +11 -0
- package/components/VoiceConfigView.d.ts.map +1 -0
- package/components/VoiceConfigView.js +329 -0
- package/components/VrmStage.d.ts +28 -0
- package/components/VrmStage.d.ts.map +1 -0
- package/components/VrmStage.js +178 -0
- package/components/WhatsAppQrOverlay.d.ts +8 -0
- package/components/WhatsAppQrOverlay.d.ts.map +1 -0
- package/components/WhatsAppQrOverlay.js +63 -0
- package/components/apps/AppDetailPane.d.ts +15 -0
- package/components/apps/AppDetailPane.d.ts.map +1 -0
- package/components/apps/AppDetailPane.js +13 -0
- package/components/apps/AppsCatalogGrid.d.ts +20 -0
- package/components/apps/AppsCatalogGrid.d.ts.map +1 -0
- package/components/apps/AppsCatalogGrid.js +18 -0
- package/components/apps/extensions/registry.d.ts +4 -0
- package/components/apps/extensions/registry.d.ts.map +1 -0
- package/components/apps/extensions/registry.js +7 -0
- package/components/apps/extensions/types.d.ts +7 -0
- package/components/apps/extensions/types.d.ts.map +1 -0
- package/components/apps/extensions/types.js +1 -0
- package/components/apps/helpers.d.ts +7 -0
- package/components/apps/helpers.d.ts.map +1 -0
- package/components/apps/helpers.js +44 -0
- package/components/avatar/VrmAnimationLoader.d.ts +30 -0
- package/components/avatar/VrmAnimationLoader.d.ts.map +1 -0
- package/components/avatar/VrmAnimationLoader.js +99 -0
- package/components/avatar/VrmBlinkController.d.ts +37 -0
- package/components/avatar/VrmBlinkController.d.ts.map +1 -0
- package/components/avatar/VrmBlinkController.js +98 -0
- package/components/avatar/VrmCameraManager.d.ts +57 -0
- package/components/avatar/VrmCameraManager.d.ts.map +1 -0
- package/components/avatar/VrmCameraManager.js +277 -0
- package/components/avatar/VrmEngine.d.ts +246 -0
- package/components/avatar/VrmEngine.d.ts.map +1 -0
- package/components/avatar/VrmEngine.js +2076 -0
- package/components/avatar/VrmFootShadow.d.ts +18 -0
- package/components/avatar/VrmFootShadow.d.ts.map +1 -0
- package/components/avatar/VrmFootShadow.js +83 -0
- package/components/avatar/VrmViewer.d.ts +60 -0
- package/components/avatar/VrmViewer.d.ts.map +1 -0
- package/components/avatar/VrmViewer.js +396 -0
- package/components/avatar/mixamoVRMRigMap.d.ts +3 -0
- package/components/avatar/mixamoVRMRigMap.d.ts.map +1 -0
- package/components/avatar/mixamoVRMRigMap.js +56 -0
- package/components/avatar/retargetMixamoFbxToVrm.d.ts +9 -0
- package/components/avatar/retargetMixamoFbxToVrm.d.ts.map +1 -0
- package/components/avatar/retargetMixamoFbxToVrm.js +88 -0
- package/components/avatar/retargetMixamoGltfToVrm.d.ts +11 -0
- package/components/avatar/retargetMixamoGltfToVrm.d.ts.map +1 -0
- package/components/avatar/retargetMixamoGltfToVrm.js +80 -0
- package/components/chainConfig.d.ts +89 -0
- package/components/chainConfig.d.ts.map +1 -0
- package/components/chainConfig.js +287 -0
- package/components/companion/CompanionHeader.d.ts +15 -0
- package/components/companion/CompanionHeader.d.ts.map +1 -0
- package/components/companion/CompanionHeader.js +7 -0
- package/components/companion/CompanionSceneHost.d.ts +2 -0
- package/components/companion/CompanionSceneHost.d.ts.map +1 -0
- package/components/companion/CompanionSceneHost.js +1 -0
- package/components/companion/VrmStage.d.ts +3 -0
- package/components/companion/VrmStage.d.ts.map +1 -0
- package/components/companion/VrmStage.js +1 -0
- package/components/companion/index.d.ts +18 -0
- package/components/companion/index.d.ts.map +1 -0
- package/components/companion/index.js +17 -0
- package/components/companion/walletUtils.d.ts +95 -0
- package/components/companion/walletUtils.d.ts.map +1 -0
- package/components/companion/walletUtils.js +167 -0
- package/components/companion-shell-styles.d.ts +38 -0
- package/components/companion-shell-styles.d.ts.map +1 -0
- package/components/companion-shell-styles.js +248 -0
- package/components/confirm-delete-control.d.ts +16 -0
- package/components/confirm-delete-control.d.ts.map +1 -0
- package/components/confirm-delete-control.js +12 -0
- package/components/conversations/ConversationListItem.d.ts +31 -0
- package/components/conversations/ConversationListItem.d.ts.map +1 -0
- package/components/conversations/ConversationListItem.js +52 -0
- package/components/conversations/conversation-utils.d.ts +9 -0
- package/components/conversations/conversation-utils.d.ts.map +1 -0
- package/components/conversations/conversation-utils.js +138 -0
- package/components/format.d.ts +54 -0
- package/components/format.d.ts.map +1 -0
- package/components/format.js +82 -0
- package/components/index.d.ts +96 -0
- package/components/index.d.ts.map +1 -0
- package/components/index.js +95 -0
- package/components/inventory/CopyableAddress.d.ts +8 -0
- package/components/inventory/CopyableAddress.d.ts.map +1 -0
- package/components/inventory/CopyableAddress.js +18 -0
- package/components/inventory/InventoryToolbar.d.ts +25 -0
- package/components/inventory/InventoryToolbar.d.ts.map +1 -0
- package/components/inventory/InventoryToolbar.js +28 -0
- package/components/inventory/NftGrid.d.ts +13 -0
- package/components/inventory/NftGrid.d.ts.map +1 -0
- package/components/inventory/NftGrid.js +29 -0
- package/components/inventory/TokenLogo.d.ts +12 -0
- package/components/inventory/TokenLogo.d.ts.map +1 -0
- package/components/inventory/TokenLogo.js +33 -0
- package/components/inventory/TokensTable.d.ts +24 -0
- package/components/inventory/TokensTable.d.ts.map +1 -0
- package/components/inventory/TokensTable.js +26 -0
- package/components/inventory/constants.d.ts +52 -0
- package/components/inventory/constants.d.ts.map +1 -0
- package/components/inventory/constants.js +121 -0
- package/components/inventory/index.d.ts +9 -0
- package/components/inventory/index.d.ts.map +1 -0
- package/components/inventory/index.js +8 -0
- package/components/inventory/media-url.d.ts +6 -0
- package/components/inventory/media-url.d.ts.map +1 -0
- package/components/inventory/media-url.js +28 -0
- package/components/inventory/useInventoryData.d.ts +53 -0
- package/components/inventory/useInventoryData.d.ts.map +1 -0
- package/components/inventory/useInventoryData.js +332 -0
- package/components/knowledge-upload-image.d.ts +27 -0
- package/components/knowledge-upload-image.d.ts.map +1 -0
- package/components/knowledge-upload-image.js +146 -0
- package/components/labels.d.ts +6 -0
- package/components/labels.d.ts.map +1 -0
- package/components/labels.js +40 -0
- package/components/onboarding/ActivateStep.d.ts +2 -0
- package/components/onboarding/ActivateStep.d.ts.map +1 -0
- package/components/onboarding/ActivateStep.js +10 -0
- package/components/onboarding/ConnectionStep.d.ts +2 -0
- package/components/onboarding/ConnectionStep.d.ts.map +1 -0
- package/components/onboarding/ConnectionStep.js +609 -0
- package/components/onboarding/IdentityStep.d.ts +2 -0
- package/components/onboarding/IdentityStep.d.ts.map +1 -0
- package/components/onboarding/IdentityStep.js +102 -0
- package/components/onboarding/OnboardingPanel.d.ts +9 -0
- package/components/onboarding/OnboardingPanel.d.ts.map +1 -0
- package/components/onboarding/OnboardingPanel.js +24 -0
- package/components/onboarding/OnboardingStepNav.d.ts +2 -0
- package/components/onboarding/OnboardingStepNav.d.ts.map +1 -0
- package/components/onboarding/OnboardingStepNav.js +23 -0
- package/components/onboarding/PermissionsStep.d.ts +2 -0
- package/components/onboarding/PermissionsStep.d.ts.map +1 -0
- package/components/onboarding/PermissionsStep.js +7 -0
- package/components/onboarding/RpcStep.d.ts +2 -0
- package/components/onboarding/RpcStep.d.ts.map +1 -0
- package/components/onboarding/RpcStep.js +125 -0
- package/components/permissions/PermissionIcon.d.ts +4 -0
- package/components/permissions/PermissionIcon.d.ts.map +1 -0
- package/components/permissions/PermissionIcon.js +12 -0
- package/components/permissions/StreamingPermissions.d.ts +20 -0
- package/components/permissions/StreamingPermissions.d.ts.map +1 -0
- package/components/permissions/StreamingPermissions.js +177 -0
- package/components/plugins/showcase-data.d.ts +7 -0
- package/components/plugins/showcase-data.d.ts.map +1 -0
- package/components/plugins/showcase-data.js +464 -0
- package/components/shared/ShellHeaderControls.d.ts +27 -0
- package/components/shared/ShellHeaderControls.d.ts.map +1 -0
- package/components/shared/ShellHeaderControls.js +60 -0
- package/components/shared-companion-scene-context.d.ts +3 -0
- package/components/shared-companion-scene-context.d.ts.map +1 -0
- package/components/shared-companion-scene-context.js +13 -0
- package/components/skeletons.d.ts +17 -0
- package/components/skeletons.d.ts.map +1 -0
- package/components/skeletons.js +22 -0
- package/components/stream/ActivityFeed.d.ts +5 -0
- package/components/stream/ActivityFeed.d.ts.map +1 -0
- package/components/stream/ActivityFeed.js +57 -0
- package/components/stream/AvatarPip.d.ts +5 -0
- package/components/stream/AvatarPip.d.ts.map +1 -0
- package/components/stream/AvatarPip.js +6 -0
- package/components/stream/ChatContent.d.ts +6 -0
- package/components/stream/ChatContent.d.ts.map +1 -0
- package/components/stream/ChatContent.js +69 -0
- package/components/stream/ChatTicker.d.ts +5 -0
- package/components/stream/ChatTicker.d.ts.map +1 -0
- package/components/stream/ChatTicker.js +34 -0
- package/components/stream/IdleContent.d.ts +5 -0
- package/components/stream/IdleContent.d.ts.map +1 -0
- package/components/stream/IdleContent.js +17 -0
- package/components/stream/StatusBar.d.ts +36 -0
- package/components/stream/StatusBar.d.ts.map +1 -0
- package/components/stream/StatusBar.js +140 -0
- package/components/stream/StreamSettings.d.ts +33 -0
- package/components/stream/StreamSettings.d.ts.map +1 -0
- package/components/stream/StreamSettings.js +99 -0
- package/components/stream/StreamTerminal.d.ts +2 -0
- package/components/stream/StreamTerminal.d.ts.map +1 -0
- package/components/stream/StreamTerminal.js +52 -0
- package/components/stream/StreamVoiceConfig.d.ts +10 -0
- package/components/stream/StreamVoiceConfig.d.ts.map +1 -0
- package/components/stream/StreamVoiceConfig.js +88 -0
- package/components/stream/helpers.d.ts +32 -0
- package/components/stream/helpers.d.ts.map +1 -0
- package/components/stream/helpers.js +110 -0
- package/components/stream/overlays/OverlayLayer.d.ts +20 -0
- package/components/stream/overlays/OverlayLayer.d.ts.map +1 -0
- package/components/stream/overlays/OverlayLayer.js +24 -0
- package/components/stream/overlays/built-in/ActionTickerWidget.d.ts +8 -0
- package/components/stream/overlays/built-in/ActionTickerWidget.d.ts.map +1 -0
- package/components/stream/overlays/built-in/ActionTickerWidget.js +44 -0
- package/components/stream/overlays/built-in/AlertPopupWidget.d.ts +7 -0
- package/components/stream/overlays/built-in/AlertPopupWidget.d.ts.map +1 -0
- package/components/stream/overlays/built-in/AlertPopupWidget.js +62 -0
- package/components/stream/overlays/built-in/BrandingWidget.d.ts +7 -0
- package/components/stream/overlays/built-in/BrandingWidget.d.ts.map +1 -0
- package/components/stream/overlays/built-in/BrandingWidget.js +36 -0
- package/components/stream/overlays/built-in/CustomHtmlWidget.d.ts +26 -0
- package/components/stream/overlays/built-in/CustomHtmlWidget.d.ts.map +1 -0
- package/components/stream/overlays/built-in/CustomHtmlWidget.js +78 -0
- package/components/stream/overlays/built-in/PeonGlassWidget.d.ts +11 -0
- package/components/stream/overlays/built-in/PeonGlassWidget.d.ts.map +1 -0
- package/components/stream/overlays/built-in/PeonGlassWidget.js +188 -0
- package/components/stream/overlays/built-in/PeonHudWidget.d.ts +10 -0
- package/components/stream/overlays/built-in/PeonHudWidget.d.ts.map +1 -0
- package/components/stream/overlays/built-in/PeonHudWidget.js +168 -0
- package/components/stream/overlays/built-in/PeonSakuraWidget.d.ts +11 -0
- package/components/stream/overlays/built-in/PeonSakuraWidget.d.ts.map +1 -0
- package/components/stream/overlays/built-in/PeonSakuraWidget.js +213 -0
- package/components/stream/overlays/built-in/ThoughtBubbleWidget.d.ts +8 -0
- package/components/stream/overlays/built-in/ThoughtBubbleWidget.d.ts.map +1 -0
- package/components/stream/overlays/built-in/ThoughtBubbleWidget.js +59 -0
- package/components/stream/overlays/built-in/ViewerCountWidget.d.ts +7 -0
- package/components/stream/overlays/built-in/ViewerCountWidget.d.ts.map +1 -0
- package/components/stream/overlays/built-in/ViewerCountWidget.js +34 -0
- package/components/stream/overlays/built-in/index.d.ts +13 -0
- package/components/stream/overlays/built-in/index.d.ts.map +1 -0
- package/components/stream/overlays/built-in/index.js +12 -0
- package/components/stream/overlays/registry.d.ts +11 -0
- package/components/stream/overlays/registry.d.ts.map +1 -0
- package/components/stream/overlays/registry.js +16 -0
- package/components/stream/overlays/types.d.ts +67 -0
- package/components/stream/overlays/types.d.ts.map +1 -0
- package/components/stream/overlays/types.js +7 -0
- package/components/stream/overlays/useOverlayLayout.d.ts +27 -0
- package/components/stream/overlays/useOverlayLayout.d.ts.map +1 -0
- package/components/stream/overlays/useOverlayLayout.js +162 -0
- package/components/trajectory-format.d.ts +6 -0
- package/components/trajectory-format.d.ts.map +1 -0
- package/components/trajectory-format.js +43 -0
- package/components/ui-badges.d.ts +23 -0
- package/components/ui-badges.d.ts.map +1 -0
- package/components/ui-badges.js +38 -0
- package/components/ui-switch.d.ts +14 -0
- package/components/ui-switch.d.ts.map +1 -0
- package/components/ui-switch.js +15 -0
- package/components/vector-browser-three.d.ts +4 -0
- package/components/vector-browser-three.d.ts.map +1 -0
- package/components/vector-browser-three.js +21 -0
- package/config/branding.d.ts +49 -0
- package/config/branding.d.ts.map +1 -0
- package/config/branding.js +16 -0
- package/config/config-catalog.d.ts +376 -0
- package/config/config-catalog.d.ts.map +1 -0
- package/config/config-catalog.js +724 -0
- package/config/config-field.d.ts +68 -0
- package/config/config-field.d.ts.map +1 -0
- package/config/config-field.js +840 -0
- package/config/config-renderer.d.ts +176 -0
- package/config/config-renderer.d.ts.map +1 -0
- package/config/config-renderer.js +405 -0
- package/config/index.d.ts +6 -0
- package/config/index.d.ts.map +1 -0
- package/config/index.js +5 -0
- package/config/ui-renderer.d.ts +26 -0
- package/config/ui-renderer.d.ts.map +1 -0
- package/config/ui-renderer.js +815 -0
- package/config/ui-spec.d.ts +164 -0
- package/config/ui-spec.d.ts.map +1 -0
- package/config/ui-spec.js +13 -0
- package/events/index.d.ts +47 -0
- package/events/index.d.ts.map +1 -0
- package/events/index.js +43 -0
- package/hooks/index.d.ts +15 -0
- package/hooks/index.d.ts.map +1 -0
- package/hooks/useBugReport.d.ts +14 -0
- package/hooks/useBugReport.d.ts.map +1 -0
- package/hooks/useBugReport.js +18 -0
- package/hooks/useCanvasWindow.d.ts +38 -0
- package/hooks/useCanvasWindow.d.ts.map +1 -0
- package/hooks/useCanvasWindow.js +273 -0
- package/hooks/useChatAvatarVoice.d.ts +10 -0
- package/hooks/useChatAvatarVoice.d.ts.map +1 -0
- package/hooks/useChatAvatarVoice.js +71 -0
- package/hooks/useClickOutside.d.ts +6 -0
- package/hooks/useClickOutside.d.ts.map +1 -0
- package/hooks/useClickOutside.js +25 -0
- package/hooks/useContextMenu.d.ts +17 -0
- package/hooks/useContextMenu.d.ts.map +1 -0
- package/hooks/useContextMenu.js +100 -0
- package/hooks/useKeyboardShortcuts.d.ts +17 -0
- package/hooks/useKeyboardShortcuts.d.ts.map +1 -0
- package/hooks/useKeyboardShortcuts.js +67 -0
- package/hooks/useLifoSync.d.ts +18 -0
- package/hooks/useLifoSync.d.ts.map +1 -0
- package/hooks/useLifoSync.js +113 -0
- package/hooks/useMemoryMonitor.d.ts +87 -0
- package/hooks/useMemoryMonitor.d.ts.map +1 -0
- package/hooks/useMemoryMonitor.js +209 -0
- package/hooks/useRenderGuard.d.ts +17 -0
- package/hooks/useRenderGuard.d.ts.map +1 -0
- package/hooks/useRenderGuard.js +36 -0
- package/hooks/useRetakeCapture.d.ts +12 -0
- package/hooks/useRetakeCapture.d.ts.map +1 -0
- package/hooks/useRetakeCapture.js +60 -0
- package/hooks/useStreamPopoutNavigation.d.ts +3 -0
- package/hooks/useStreamPopoutNavigation.d.ts.map +1 -0
- package/hooks/useStreamPopoutNavigation.js +17 -0
- package/hooks/useTimeout.d.ts +11 -0
- package/hooks/useTimeout.d.ts.map +1 -0
- package/hooks/useTimeout.js +32 -0
- package/hooks/useVoiceChat.d.ts +94 -0
- package/hooks/useVoiceChat.d.ts.map +1 -0
- package/hooks/useVoiceChat.js +1074 -0
- package/hooks/useWhatsAppPairing.d.ts +11 -0
- package/hooks/useWhatsAppPairing.d.ts.map +1 -0
- package/hooks/useWhatsAppPairing.js +95 -0
- package/i18n/index.d.ts +7 -0
- package/i18n/index.d.ts.map +1 -0
- package/i18n/index.js +53 -0
- package/i18n/locales/en.json +1239 -0
- package/i18n/locales/es.json +1236 -0
- package/i18n/locales/ko.json +1236 -0
- package/i18n/locales/pt.json +1236 -0
- package/i18n/locales/zh-CN.json +1236 -0
- package/i18n/messages.d.ts +6 -0
- package/i18n/messages.d.ts.map +1 -0
- package/i18n/messages.js +14 -0
- package/index.d.ts +5 -0
- package/index.d.ts.map +1 -0
- package/navigation/index.d.ts +27 -0
- package/navigation/index.d.ts.map +1 -0
- package/navigation/index.js +232 -0
- package/onboarding-config.d.ts +25 -0
- package/onboarding-config.d.ts.map +1 -0
- package/onboarding-config.js +76 -0
- package/package.json +143 -53
- package/platform/browser-launch.d.ts +2 -0
- package/platform/browser-launch.d.ts.map +1 -0
- package/platform/browser-launch.js +109 -0
- package/platform/index.d.ts +14 -0
- package/platform/index.d.ts.map +1 -0
- package/platform/index.js +24 -0
- package/platform/init.d.ts +40 -0
- package/platform/init.d.ts.map +1 -0
- package/platform/init.js +160 -0
- package/platform/lifo.d.ts +51 -0
- package/platform/lifo.d.ts.map +1 -0
- package/platform/lifo.js +138 -0
- package/providers/index.d.ts +19 -0
- package/providers/index.d.ts.map +1 -0
- package/providers/index.js +80 -0
- package/shell-params.d.ts +12 -0
- package/shell-params.d.ts.map +1 -0
- package/shell-params.js +19 -0
- package/state/AppContext.d.ts +12 -0
- package/state/AppContext.d.ts.map +1 -0
- package/state/AppContext.js +5060 -0
- package/state/index.d.ts +7 -0
- package/state/index.d.ts.map +1 -0
- package/state/internal.d.ts +7 -0
- package/state/internal.d.ts.map +1 -0
- package/state/internal.js +6 -0
- package/state/onboarding-resume.d.ts +11 -0
- package/state/onboarding-resume.d.ts.map +1 -0
- package/state/onboarding-resume.js +189 -0
- package/state/parsers.d.ts +26 -0
- package/state/parsers.d.ts.map +1 -0
- package/state/parsers.js +255 -0
- package/state/persistence.d.ts +59 -0
- package/state/persistence.d.ts.map +1 -0
- package/state/persistence.js +326 -0
- package/state/shell-routing.d.ts +12 -0
- package/state/shell-routing.d.ts.map +1 -0
- package/state/shell-routing.js +25 -0
- package/state/types.d.ts +421 -0
- package/state/types.d.ts.map +1 -0
- package/state/types.js +75 -0
- package/state/ui-preferences.d.ts +3 -0
- package/state/ui-preferences.d.ts.map +1 -0
- package/state/ui-preferences.js +1 -0
- package/state/useApp.d.ts +4 -0
- package/state/useApp.d.ts.map +1 -0
- package/state/useApp.js +22 -0
- package/state/vrm.d.ts +30 -0
- package/state/vrm.d.ts.map +1 -0
- package/state/vrm.js +82 -0
- package/styles/anime.css +6321 -0
- package/styles/onboarding-game.css +1092 -0
- package/types/index.d.ts +657 -0
- package/types/index.d.ts.map +1 -0
- package/types/index.js +1 -0
- package/utils/asset-url.d.ts +26 -0
- package/utils/asset-url.d.ts.map +1 -0
- package/utils/asset-url.js +99 -0
- package/utils/assistant-text.d.ts +2 -0
- package/utils/assistant-text.d.ts.map +1 -0
- package/utils/assistant-text.js +161 -0
- package/utils/clipboard.d.ts +2 -0
- package/utils/clipboard.d.ts.map +1 -0
- package/utils/clipboard.js +38 -0
- package/utils/desktop-dialogs.d.ts +19 -0
- package/utils/desktop-dialogs.d.ts.map +1 -0
- package/utils/desktop-dialogs.js +50 -0
- package/utils/eliza-globals.d.ts +11 -0
- package/utils/eliza-globals.d.ts.map +1 -0
- package/utils/eliza-globals.js +33 -0
- package/utils/index.d.ts +8 -0
- package/utils/index.d.ts.map +1 -0
- package/utils/number-parsing.d.ts +44 -0
- package/utils/number-parsing.d.ts.map +1 -0
- package/utils/number-parsing.js +56 -0
- package/utils/openExternalUrl.d.ts +2 -0
- package/utils/openExternalUrl.d.ts.map +1 -0
- package/utils/openExternalUrl.js +17 -0
- package/utils/spoken-text.d.ts +2 -0
- package/utils/spoken-text.d.ts.map +1 -0
- package/utils/spoken-text.js +56 -0
- package/utils/streaming-text.d.ts +3 -0
- package/utils/streaming-text.d.ts.map +1 -0
- package/utils/streaming-text.js +87 -0
- package/voice/index.d.ts +2 -0
- package/voice/index.d.ts.map +1 -0
- package/voice/types.d.ts +25 -0
- package/voice/types.d.ts.map +1 -0
- package/voice/types.js +166 -0
- package/wallet-rpc.d.ts +8 -0
- package/wallet-rpc.d.ts.map +1 -0
- package/wallet-rpc.js +131 -0
- package/.turbo/turbo-build.log +0 -5
- package/src/App.tsx +0 -504
- package/src/actions/character.test.ts +0 -139
- package/src/actions/character.ts +0 -334
- package/src/actions/chat-helpers.ts +0 -100
- package/src/actions/cloud.ts +0 -59
- package/src/actions/index.ts +0 -12
- package/src/actions/lifecycle.ts +0 -175
- package/src/actions/onboarding.ts +0 -38
- package/src/actions/triggers.ts +0 -190
- package/src/ambient.d.ts +0 -33
- package/src/api/client.ts +0 -5659
- package/src/autonomy/index.ts +0 -477
- package/src/bridge/capacitor-bridge.ts +0 -295
- package/src/bridge/electrobun-rpc.ts +0 -78
- package/src/bridge/electrobun-runtime.ts +0 -28
- package/src/bridge/native-plugins.ts +0 -138
- package/src/bridge/plugin-bridge.ts +0 -352
- package/src/bridge/storage-bridge.ts +0 -162
- package/src/chat/index.ts +0 -250
- package/src/coding/index.ts +0 -43
- package/src/components/AdvancedPageView.tsx +0 -382
- package/src/components/AgentActivityBox.tsx +0 -49
- package/src/components/ApiKeyConfig.tsx +0 -222
- package/src/components/AppsPageView.tsx +0 -52
- package/src/components/AppsView.tsx +0 -293
- package/src/components/AvatarLoader.tsx +0 -104
- package/src/components/AvatarSelector.tsx +0 -223
- package/src/components/BscTradePanel.tsx +0 -549
- package/src/components/BugReportModal.tsx +0 -499
- package/src/components/CharacterRoster.tsx +0 -143
- package/src/components/CharacterView.tsx +0 -1575
- package/src/components/ChatAvatar.test.ts +0 -97
- package/src/components/ChatAvatar.tsx +0 -147
- package/src/components/ChatComposer.tsx +0 -330
- package/src/components/ChatMessage.tsx +0 -448
- package/src/components/ChatModalView.test.tsx +0 -118
- package/src/components/ChatModalView.tsx +0 -125
- package/src/components/ChatView.tsx +0 -992
- package/src/components/CloudOnboarding.tsx +0 -81
- package/src/components/CloudSourceControls.tsx +0 -85
- package/src/components/CodingAgentSettingsSection.tsx +0 -537
- package/src/components/CommandPalette.tsx +0 -284
- package/src/components/CompanionSceneHost.tsx +0 -517
- package/src/components/CompanionShell.tsx +0 -31
- package/src/components/CompanionView.tsx +0 -110
- package/src/components/ConfigPageView.tsx +0 -763
- package/src/components/ConfigSaveFooter.tsx +0 -41
- package/src/components/ConfirmModal.tsx +0 -379
- package/src/components/ConnectionFailedBanner.tsx +0 -91
- package/src/components/ConnectorsPageView.tsx +0 -13
- package/src/components/ConversationsSidebar.tsx +0 -279
- package/src/components/CustomActionEditor.tsx +0 -1127
- package/src/components/CustomActionsPanel.tsx +0 -288
- package/src/components/CustomActionsView.tsx +0 -325
- package/src/components/DatabasePageView.tsx +0 -55
- package/src/components/DatabaseView.tsx +0 -814
- package/src/components/ElizaCloudDashboard.tsx +0 -1696
- package/src/components/EmotePicker.tsx +0 -529
- package/src/components/ErrorBoundary.tsx +0 -76
- package/src/components/FineTuningView.tsx +0 -1080
- package/src/components/FlaminaGuide.test.tsx +0 -61
- package/src/components/FlaminaGuide.tsx +0 -212
- package/src/components/GameView.tsx +0 -551
- package/src/components/GameViewOverlay.tsx +0 -133
- package/src/components/GlobalEmoteOverlay.tsx +0 -152
- package/src/components/Header.test.tsx +0 -413
- package/src/components/Header.tsx +0 -400
- package/src/components/HeartbeatsView.tsx +0 -1003
- package/src/components/InventoryView.tsx +0 -393
- package/src/components/KnowledgeView.tsx +0 -1128
- package/src/components/LanguageDropdown.tsx +0 -192
- package/src/components/LifoMonitorPanel.tsx +0 -196
- package/src/components/LifoSandboxView.tsx +0 -499
- package/src/components/LoadingScreen.tsx +0 -112
- package/src/components/LogsPageView.tsx +0 -17
- package/src/components/LogsView.tsx +0 -239
- package/src/components/MediaGalleryView.tsx +0 -431
- package/src/components/MediaSettingsSection.tsx +0 -893
- package/src/components/MessageContent.tsx +0 -815
- package/src/components/MiladyBar.tsx +0 -103
- package/src/components/MiladyBarSettings.tsx +0 -872
- package/src/components/OnboardingWizard.test.tsx +0 -104
- package/src/components/OnboardingWizard.tsx +0 -249
- package/src/components/PairingView.tsx +0 -109
- package/src/components/PermissionsSection.tsx +0 -1184
- package/src/components/PluginsPageView.tsx +0 -9
- package/src/components/PluginsView.tsx +0 -3129
- package/src/components/ProviderSwitcher.tsx +0 -903
- package/src/components/RestartBanner.tsx +0 -76
- package/src/components/RuntimeView.tsx +0 -460
- package/src/components/SaveCommandModal.tsx +0 -211
- package/src/components/SecretsView.tsx +0 -569
- package/src/components/SecurityPageView.tsx +0 -242
- package/src/components/SettingsView.tsx +0 -825
- package/src/components/ShellOverlays.tsx +0 -41
- package/src/components/ShortcutsOverlay.tsx +0 -155
- package/src/components/SkillsView.tsx +0 -1435
- package/src/components/StartupFailureView.tsx +0 -63
- package/src/components/StreamView.tsx +0 -481
- package/src/components/StripeEmbeddedCheckout.tsx +0 -155
- package/src/components/SubscriptionStatus.tsx +0 -640
- package/src/components/SystemWarningBanner.tsx +0 -71
- package/src/components/ThemeToggle.tsx +0 -103
- package/src/components/TrajectoriesView.tsx +0 -526
- package/src/components/TrajectoryDetailView.tsx +0 -426
- package/src/components/VectorBrowserView.tsx +0 -1633
- package/src/components/VoiceConfigView.tsx +0 -674
- package/src/components/VrmStage.test.ts +0 -176
- package/src/components/VrmStage.tsx +0 -309
- package/src/components/WhatsAppQrOverlay.tsx +0 -230
- package/src/components/__tests__/chainConfig.test.ts +0 -220
- package/src/components/apps/AppDetailPane.tsx +0 -242
- package/src/components/apps/AppsCatalogGrid.tsx +0 -137
- package/src/components/apps/extensions/registry.ts +0 -13
- package/src/components/apps/extensions/types.ts +0 -9
- package/src/components/apps/helpers.ts +0 -43
- package/src/components/avatar/VrmAnimationLoader.test.ts +0 -164
- package/src/components/avatar/VrmAnimationLoader.ts +0 -151
- package/src/components/avatar/VrmBlinkController.ts +0 -118
- package/src/components/avatar/VrmCameraManager.ts +0 -407
- package/src/components/avatar/VrmEngine.ts +0 -2767
- package/src/components/avatar/VrmFootShadow.ts +0 -96
- package/src/components/avatar/VrmViewer.tsx +0 -421
- package/src/components/avatar/__tests__/VrmCameraManager.test.ts +0 -168
- package/src/components/avatar/__tests__/VrmEngine.test.ts +0 -1574
- package/src/components/avatar/mixamoVRMRigMap.ts +0 -62
- package/src/components/avatar/retargetMixamoFbxToVrm.ts +0 -144
- package/src/components/avatar/retargetMixamoGltfToVrm.ts +0 -119
- package/src/components/chainConfig.ts +0 -400
- package/src/components/companion/CompanionHeader.tsx +0 -50
- package/src/components/companion/CompanionSceneHost.tsx +0 -5
- package/src/components/companion/VrmStage.tsx +0 -2
- package/src/components/companion/__tests__/walletUtils.test.ts +0 -742
- package/src/components/companion/index.ts +0 -18
- package/src/components/companion/walletUtils.ts +0 -290
- package/src/components/companion-shell-styles.test.ts +0 -142
- package/src/components/companion-shell-styles.ts +0 -270
- package/src/components/confirm-delete-control.tsx +0 -69
- package/src/components/conversations/ConversationListItem.tsx +0 -185
- package/src/components/conversations/conversation-utils.ts +0 -151
- package/src/components/format.ts +0 -131
- package/src/components/index.ts +0 -96
- package/src/components/inventory/CopyableAddress.tsx +0 -41
- package/src/components/inventory/InventoryToolbar.tsx +0 -142
- package/src/components/inventory/NftGrid.tsx +0 -99
- package/src/components/inventory/TokenLogo.tsx +0 -71
- package/src/components/inventory/TokensTable.tsx +0 -216
- package/src/components/inventory/constants.ts +0 -170
- package/src/components/inventory/index.ts +0 -29
- package/src/components/inventory/media-url.test.ts +0 -38
- package/src/components/inventory/media-url.ts +0 -36
- package/src/components/inventory/useInventoryData.ts +0 -460
- package/src/components/knowledge-upload-image.ts +0 -215
- package/src/components/labels.ts +0 -46
- package/src/components/milady-bar/CloudCreditsChip.tsx +0 -61
- package/src/components/milady-bar/ProviderDropdown.tsx +0 -166
- package/src/components/milady-bar/WalletSummary.tsx +0 -61
- package/src/components/milady-bar/index.ts +0 -3
- package/src/components/onboarding/ActivateStep.tsx +0 -34
- package/src/components/onboarding/ConnectionStep.tsx +0 -1591
- package/src/components/onboarding/IdentityStep.tsx +0 -251
- package/src/components/onboarding/OnboardingPanel.tsx +0 -39
- package/src/components/onboarding/OnboardingStepNav.tsx +0 -41
- package/src/components/onboarding/PermissionsStep.tsx +0 -20
- package/src/components/onboarding/RpcStep.tsx +0 -402
- package/src/components/permissions/PermissionIcon.tsx +0 -25
- package/src/components/permissions/StreamingPermissions.tsx +0 -413
- package/src/components/plugins/showcase-data.ts +0 -481
- package/src/components/shared/ShellHeaderControls.tsx +0 -198
- package/src/components/shared-companion-scene-context.ts +0 -15
- package/src/components/skeletons.tsx +0 -88
- package/src/components/stream/ActivityFeed.tsx +0 -113
- package/src/components/stream/AvatarPip.tsx +0 -10
- package/src/components/stream/ChatContent.tsx +0 -126
- package/src/components/stream/ChatTicker.tsx +0 -55
- package/src/components/stream/IdleContent.tsx +0 -73
- package/src/components/stream/StatusBar.tsx +0 -463
- package/src/components/stream/StreamSettings.tsx +0 -506
- package/src/components/stream/StreamTerminal.tsx +0 -94
- package/src/components/stream/StreamVoiceConfig.tsx +0 -160
- package/src/components/stream/helpers.ts +0 -134
- package/src/components/stream/overlays/OverlayLayer.tsx +0 -75
- package/src/components/stream/overlays/built-in/ActionTickerWidget.tsx +0 -64
- package/src/components/stream/overlays/built-in/AlertPopupWidget.tsx +0 -87
- package/src/components/stream/overlays/built-in/BrandingWidget.tsx +0 -51
- package/src/components/stream/overlays/built-in/CustomHtmlWidget.tsx +0 -105
- package/src/components/stream/overlays/built-in/PeonGlassWidget.tsx +0 -265
- package/src/components/stream/overlays/built-in/PeonHudWidget.tsx +0 -247
- package/src/components/stream/overlays/built-in/PeonSakuraWidget.tsx +0 -278
- package/src/components/stream/overlays/built-in/ThoughtBubbleWidget.tsx +0 -77
- package/src/components/stream/overlays/built-in/ViewerCountWidget.tsx +0 -46
- package/src/components/stream/overlays/built-in/index.ts +0 -13
- package/src/components/stream/overlays/registry.ts +0 -22
- package/src/components/stream/overlays/types.ts +0 -90
- package/src/components/stream/overlays/useOverlayLayout.ts +0 -218
- package/src/components/trajectory-format.ts +0 -50
- package/src/components/ui-badges.tsx +0 -109
- package/src/components/ui-switch.tsx +0 -57
- package/src/components/vector-browser-three.ts +0 -29
- package/src/config/branding.ts +0 -67
- package/src/config/config-catalog.ts +0 -1092
- package/src/config/config-field.tsx +0 -1924
- package/src/config/config-renderer.tsx +0 -734
- package/src/config/index.ts +0 -12
- package/src/config/ui-renderer.tsx +0 -1751
- package/src/config/ui-spec.ts +0 -256
- package/src/events/index.ts +0 -96
- package/src/hooks/useBugReport.tsx +0 -43
- package/src/hooks/useCanvasWindow.ts +0 -372
- package/src/hooks/useChatAvatarVoice.ts +0 -111
- package/src/hooks/useClickOutside.ts +0 -31
- package/src/hooks/useContextMenu.ts +0 -127
- package/src/hooks/useKeyboardShortcuts.ts +0 -86
- package/src/hooks/useLifoSync.ts +0 -143
- package/src/hooks/useMemoryMonitor.ts +0 -334
- package/src/hooks/useMiladyBar.ts +0 -594
- package/src/hooks/useRenderGuard.ts +0 -43
- package/src/hooks/useRetakeCapture.ts +0 -68
- package/src/hooks/useStreamPopoutNavigation.ts +0 -27
- package/src/hooks/useTimeout.ts +0 -37
- package/src/hooks/useVoiceChat.ts +0 -1442
- package/src/hooks/useWhatsAppPairing.ts +0 -123
- package/src/i18n/index.ts +0 -76
- package/src/i18n/locales/en.json +0 -1195
- package/src/i18n/locales/es.json +0 -1195
- package/src/i18n/locales/ko.json +0 -1195
- package/src/i18n/locales/pt.json +0 -1195
- package/src/i18n/locales/zh-CN.json +0 -1195
- package/src/i18n/messages.ts +0 -21
- package/src/navigation/index.ts +0 -286
- package/src/navigation.test.ts +0 -189
- package/src/onboarding-config.test.ts +0 -104
- package/src/onboarding-config.ts +0 -122
- package/src/platform/browser-launch.test.ts +0 -94
- package/src/platform/browser-launch.ts +0 -149
- package/src/platform/index.ts +0 -58
- package/src/platform/init.ts +0 -238
- package/src/platform/lifo.ts +0 -225
- package/src/providers/index.ts +0 -108
- package/src/shell-params.test.ts +0 -48
- package/src/shell-params.ts +0 -36
- package/src/state/AppContext.tsx +0 -6415
- package/src/state/internal.ts +0 -91
- package/src/state/onboarding-resume.test.ts +0 -135
- package/src/state/onboarding-resume.ts +0 -263
- package/src/state/parsers.test.ts +0 -124
- package/src/state/parsers.ts +0 -309
- package/src/state/persistence.ts +0 -379
- package/src/state/shell-routing.ts +0 -39
- package/src/state/types.ts +0 -724
- package/src/state/ui-preferences.ts +0 -3
- package/src/state/useApp.ts +0 -23
- package/src/state/vrm.ts +0 -108
- package/src/styles/anime.css +0 -6324
- package/src/styles/onboarding-game.css +0 -976
- package/src/types/index.ts +0 -715
- package/src/types/react-test-renderer.d.ts +0 -45
- package/src/utils/asset-url.ts +0 -110
- package/src/utils/assistant-text.ts +0 -172
- package/src/utils/clipboard.ts +0 -41
- package/src/utils/desktop-dialogs.ts +0 -80
- package/src/utils/eliza-globals.ts +0 -44
- package/src/utils/number-parsing.ts +0 -125
- package/src/utils/openExternalUrl.ts +0 -20
- package/src/utils/spoken-text.ts +0 -65
- package/src/utils/streaming-text.ts +0 -120
- package/src/voice/types.ts +0 -197
- package/src/wallet-rpc.ts +0 -176
- package/test/app/AppContext.pty-sessions.test.tsx +0 -143
- package/test/app/MessageContent.test.tsx +0 -366
- package/test/app/PermissionsOnboarding.test.tsx +0 -358
- package/test/app/PermissionsSection.test.tsx +0 -575
- package/test/app/advanced-trajectory-fine-tuning.e2e.test.ts +0 -396
- package/test/app/agent-activity-box.test.tsx +0 -132
- package/test/app/agent-transfer-lock.test.ts +0 -279
- package/test/app/api-client-electrobun-fallback.test.ts +0 -139
- package/test/app/api-client-electron-fallback.test.ts +0 -139
- package/test/app/api-client-timeout.test.ts +0 -75
- package/test/app/api-client-ws.test.ts +0 -98
- package/test/app/api-client.ws-max-reconnect.test.ts +0 -139
- package/test/app/api-client.ws-reconnect.test.ts +0 -157
- package/test/app/app-context-autonomy-events.test.ts +0 -559
- package/test/app/apps-page-view.test.ts +0 -114
- package/test/app/apps-view.test.ts +0 -768
- package/test/app/autonomous-workflows.e2e.test.ts +0 -765
- package/test/app/autonomy-events.test.ts +0 -150
- package/test/app/avatar-selector.test.tsx +0 -52
- package/test/app/bsc-trade-panel.test.tsx +0 -134
- package/test/app/bug-report-modal.test.tsx +0 -353
- package/test/app/character-action-bar-visibility.test.ts +0 -70
- package/test/app/character-customization.e2e.test.ts +0 -1384
- package/test/app/character-save-journey.test.ts +0 -1245
- package/test/app/chat-advanced-features.e2e.test.ts +0 -706
- package/test/app/chat-composer.test.tsx +0 -181
- package/test/app/chat-journey.test.ts +0 -1075
- package/test/app/chat-language-header.test.ts +0 -64
- package/test/app/chat-message.test.tsx +0 -222
- package/test/app/chat-modal-view.test.tsx +0 -191
- package/test/app/chat-routine-filter.test.ts +0 -96
- package/test/app/chat-send-lock.test.ts +0 -1465
- package/test/app/chat-stream-api-client.test.tsx +0 -390
- package/test/app/chat-view-game-modal.test.tsx +0 -661
- package/test/app/chat-view.test.tsx +0 -877
- package/test/app/cloud-api.e2e.test.ts +0 -258
- package/test/app/cloud-login-flow.e2e.test.ts +0 -494
- package/test/app/cloud-login-lock.test.ts +0 -416
- package/test/app/command-palette.test.tsx +0 -184
- package/test/app/command-registry.test.ts +0 -75
- package/test/app/companion-greeting-wave.test.tsx +0 -431
- package/test/app/companion-scene-host.test.tsx +0 -85
- package/test/app/companion-stale-conversation.test.tsx +0 -447
- package/test/app/companion-view.test.tsx +0 -690
- package/test/app/confirm-delete-control.test.ts +0 -79
- package/test/app/confirm-modal.test.tsx +0 -219
- package/test/app/connection-mode-persistence.test.ts +0 -411
- package/test/app/connectors-ui.e2e.test.ts +0 -508
- package/test/app/conversations-sidebar-game-modal.test.tsx +0 -265
- package/test/app/conversations-sidebar.test.tsx +0 -185
- package/test/app/custom-actions-smoke.test.ts +0 -387
- package/test/app/custom-avatar-api-client.test.ts +0 -207
- package/test/app/desktop-utils.test.ts +0 -145
- package/test/app/electrobun-rpc-bridge.test.ts +0 -83
- package/test/app/events.test.ts +0 -88
- package/test/app/export-import-flows.e2e.test.ts +0 -700
- package/test/app/fine-tuning-view.test.ts +0 -471
- package/test/app/game-view-auth-session.test.tsx +0 -187
- package/test/app/game-view.test.ts +0 -444
- package/test/app/global-emote-overlay.test.tsx +0 -106
- package/test/app/header-status.test.tsx +0 -149
- package/test/app/i18n.test.ts +0 -152
- package/test/app/inventory-bsc-view.test.ts +0 -940
- package/test/app/knowledge-ui.e2e.test.ts +0 -762
- package/test/app/knowledge-upload-helpers.test.ts +0 -124
- package/test/app/lifecycle-lock.test.ts +0 -267
- package/test/app/lifo-popout-utils.test.ts +0 -208
- package/test/app/lifo-safe-endpoint.test.ts +0 -34
- package/test/app/loading-screen.test.tsx +0 -45
- package/test/app/memory-monitor.test.ts +0 -331
- package/test/app/milady-bar-regression.test.tsx +0 -519
- package/test/app/milady-bar-settings.test.tsx +0 -1056
- package/test/app/milady-bar.test.tsx +0 -583
- package/test/app/navigation.test.tsx +0 -22
- package/test/app/onboarding-e2e-journey.test.ts +0 -1409
- package/test/app/onboarding-finish-lock.test.ts +0 -676
- package/test/app/onboarding-language.test.tsx +0 -160
- package/test/app/onboarding-steps.test.tsx +0 -375
- package/test/app/open-external-url.test.ts +0 -65
- package/test/app/pages-navigation-smoke.e2e.test.ts +0 -646
- package/test/app/pairing-lock.test.ts +0 -260
- package/test/app/pairing-view.test.tsx +0 -74
- package/test/app/permissions-section.test.ts +0 -432
- package/test/app/plugin-bridge.test.ts +0 -109
- package/test/app/plugins-ui.e2e.test.ts +0 -605
- package/test/app/plugins-view-game-modal.test.tsx +0 -686
- package/test/app/plugins-view-toggle-restart.test.ts +0 -129
- package/test/app/provider-dropdown-default.test.tsx +0 -300
- package/test/app/restart-banner.test.tsx +0 -205
- package/test/app/retake-capture.test.ts +0 -84
- package/test/app/sandbox-api-client.test.ts +0 -108
- package/test/app/save-command-modal.test.tsx +0 -109
- package/test/app/secrets-view.test.tsx +0 -92
- package/test/app/settings-control-styles.test.tsx +0 -142
- package/test/app/settings-reset.e2e.test.ts +0 -726
- package/test/app/settings-sections.e2e.test.ts +0 -614
- package/test/app/shared-format.test.ts +0 -44
- package/test/app/shared-switch.test.ts +0 -69
- package/test/app/shell-mode-switching.e2e.test.ts +0 -841
- package/test/app/shell-mode-tab-memory.test.tsx +0 -58
- package/test/app/shell-overlays.test.tsx +0 -50
- package/test/app/shortcuts-overlay.test.tsx +0 -111
- package/test/app/sse-interruption.test.ts +0 -122
- package/test/app/startup-asset-missing.e2e.test.ts +0 -126
- package/test/app/startup-backend-missing.e2e.test.ts +0 -126
- package/test/app/startup-chat.e2e.test.ts +0 -323
- package/test/app/startup-conversation-restore.test.tsx +0 -381
- package/test/app/startup-failure-view.test.tsx +0 -103
- package/test/app/startup-onboarding.e2e.test.ts +0 -712
- package/test/app/startup-timeout.test.tsx +0 -80
- package/test/app/startup-token-401.e2e.test.ts +0 -103
- package/test/app/stream-helpers.test.ts +0 -46
- package/test/app/stream-popout-navigation.test.tsx +0 -41
- package/test/app/stream-status-bar.test.tsx +0 -89
- package/test/app/theme-toggle.test.tsx +0 -40
- package/test/app/training-api-client.test.ts +0 -128
- package/test/app/trajectories-view.test.tsx +0 -220
- package/test/app/triggers-api-client.test.ts +0 -77
- package/test/app/triggers-navigation.test.ts +0 -113
- package/test/app/triggers-view.e2e.test.ts +0 -675
- package/test/app/update-channel-lock.test.ts +0 -259
- package/test/app/vector-browser.async-cleanup.test.tsx +0 -367
- package/test/app/vector-browser.e2e.test.ts +0 -653
- package/test/app/vrm-stage.test.tsx +0 -351
- package/test/app/vrm-viewer.test.tsx +0 -298
- package/test/app/wallet-api-save-lock.test.ts +0 -299
- package/test/app/wallet-hooks.test.ts +0 -405
- package/test/app/wallet-ui-flows.e2e.test.ts +0 -556
- package/test/avatar/asset-url.test.ts +0 -90
- package/test/avatar/avatar-selector.test.ts +0 -173
- package/test/avatar/mixamo-vrm-rig-map.test.ts +0 -111
- package/test/avatar/voice-chat-streaming-text.test.ts +0 -96
- package/test/avatar/voice-chat.test.ts +0 -391
- package/test/browser-extension/README.md +0 -138
- package/test/browser-extension/test-harness.ts +0 -499
- package/test/capacitor-plugins.e2e.test.ts +0 -168
- package/test/test-types.ts +0 -5
- package/test/ui/command-palette-commands.test.ts +0 -57
- package/test/ui/ui-renderer.test.ts +0 -39
- package/test/utils/assistant-text.test.ts +0 -68
- package/test/utils/eliza-globals.test.ts +0 -59
- package/test/utils/package-exports.test.ts +0 -70
- package/test/utils/streaming-text.test.ts +0 -89
- package/tsconfig.build.json +0 -19
- package/tsconfig.json +0 -20
- package/tsconfig.typecheck.json +0 -12
- /package/{src/api/index.ts → api/index.js} +0 -0
- /package/{src/bridge/index.ts → bridge/index.js} +0 -0
- /package/{src/components/TriggersView.tsx → components/TriggersView.js} +0 -0
- /package/{src/hooks/index.ts → hooks/index.js} +0 -0
- /package/{src/index.ts → index.js} +0 -0
- /package/{src/state/index.ts → state/index.js} +0 -0
- /package/{src/styles → styles}/base.css +0 -0
- /package/{src/styles → styles}/styles.css +0 -0
- /package/{src/styles → styles}/xterm.css +0 -0
- /package/{src/utils/index.ts → utils/index.js} +0 -0
- /package/{src/voice/index.ts → voice/index.js} +0 -0
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* RuntimeView — deep runtime state inspector for advanced debugging.
|
|
4
|
+
*
|
|
5
|
+
* Shows:
|
|
6
|
+
* - Full runtime snapshot
|
|
7
|
+
* - Split sections: actions/providers/plugins/services/evaluators
|
|
8
|
+
* - Explicit load order metadata
|
|
9
|
+
*/
|
|
10
|
+
import { useCallback, useEffect, useState } from "react";
|
|
11
|
+
import { client, } from "../api";
|
|
12
|
+
import { useApp } from "../state";
|
|
13
|
+
import { formatDateTime } from "./format";
|
|
14
|
+
const SECTION_TABS = [
|
|
15
|
+
{ key: "runtime", label: "Runtime" },
|
|
16
|
+
{ key: "actions", label: "Actions" },
|
|
17
|
+
{ key: "providers", label: "Providers" },
|
|
18
|
+
{ key: "plugins", label: "Plugins" },
|
|
19
|
+
{ key: "services", label: "Services" },
|
|
20
|
+
{ key: "evaluators", label: "Evaluators" },
|
|
21
|
+
];
|
|
22
|
+
function nodeSummary(value) {
|
|
23
|
+
if (value === null)
|
|
24
|
+
return "null";
|
|
25
|
+
if (typeof value === "string") {
|
|
26
|
+
const compact = value.length > 100 ? `${value.slice(0, 100)}...` : value;
|
|
27
|
+
return JSON.stringify(compact);
|
|
28
|
+
}
|
|
29
|
+
if (typeof value === "number" || typeof value === "boolean")
|
|
30
|
+
return String(value);
|
|
31
|
+
if (Array.isArray(value))
|
|
32
|
+
return `Array(${value.length})`;
|
|
33
|
+
if (typeof value === "object") {
|
|
34
|
+
const record = value;
|
|
35
|
+
const typeTag = typeof record.__type === "string" ? record.__type : null;
|
|
36
|
+
if (typeTag === "array" && typeof record.length === "number") {
|
|
37
|
+
return `Array(${String(record.length)})`;
|
|
38
|
+
}
|
|
39
|
+
if (typeTag === "map" && typeof record.size === "number") {
|
|
40
|
+
return `Map(${String(record.size)})`;
|
|
41
|
+
}
|
|
42
|
+
if (typeTag === "set" && typeof record.size === "number") {
|
|
43
|
+
return `Set(${String(record.size)})`;
|
|
44
|
+
}
|
|
45
|
+
if (typeTag === "object") {
|
|
46
|
+
const className = typeof record.className === "string" ? record.className : "Object";
|
|
47
|
+
const props = record.properties &&
|
|
48
|
+
typeof record.properties === "object" &&
|
|
49
|
+
!Array.isArray(record.properties)
|
|
50
|
+
? Object.keys(record.properties).length
|
|
51
|
+
: 0;
|
|
52
|
+
return `${className} {${props}}`;
|
|
53
|
+
}
|
|
54
|
+
return `${typeTag ?? "Object"} {${Object.keys(record).length}}`;
|
|
55
|
+
}
|
|
56
|
+
return String(value);
|
|
57
|
+
}
|
|
58
|
+
function isExpandable(value) {
|
|
59
|
+
if (Array.isArray(value))
|
|
60
|
+
return value.length > 0;
|
|
61
|
+
if (!value || typeof value !== "object")
|
|
62
|
+
return false;
|
|
63
|
+
return Object.keys(value).length > 0;
|
|
64
|
+
}
|
|
65
|
+
function nodeEntries(value, path) {
|
|
66
|
+
if (Array.isArray(value)) {
|
|
67
|
+
return value.map((entry, i) => ({
|
|
68
|
+
key: `[${i}]`,
|
|
69
|
+
value: entry,
|
|
70
|
+
path: `${path}[${i}]`,
|
|
71
|
+
}));
|
|
72
|
+
}
|
|
73
|
+
if (!value || typeof value !== "object")
|
|
74
|
+
return [];
|
|
75
|
+
return Object.entries(value).map(([key, entry]) => ({
|
|
76
|
+
key,
|
|
77
|
+
value: entry,
|
|
78
|
+
path: `${path}.${key}`,
|
|
79
|
+
}));
|
|
80
|
+
}
|
|
81
|
+
function buildInitialExpanded(rootPath, value) {
|
|
82
|
+
const expanded = new Set([rootPath]);
|
|
83
|
+
const firstLayer = nodeEntries(value, rootPath).slice(0, 24);
|
|
84
|
+
for (const entry of firstLayer)
|
|
85
|
+
expanded.add(entry.path);
|
|
86
|
+
return expanded;
|
|
87
|
+
}
|
|
88
|
+
function orderItemLabel(entry) {
|
|
89
|
+
const idPart = entry.id ? ` (${entry.id})` : "";
|
|
90
|
+
return `[${entry.index}] ${entry.name} :: ${entry.className}${idPart}`;
|
|
91
|
+
}
|
|
92
|
+
function TreeNode(props) {
|
|
93
|
+
const { label, value, path, depth, expanded, onToggle } = props;
|
|
94
|
+
const canExpand = isExpandable(value);
|
|
95
|
+
const open = expanded.has(path);
|
|
96
|
+
const entries = canExpand ? nodeEntries(value, path) : [];
|
|
97
|
+
return (_jsxs("div", { children: [_jsxs("div", { className: "flex items-baseline gap-1 text-[11px] font-mono leading-5", style: { paddingLeft: `${depth * 14}px` }, children: [canExpand ? (_jsx("button", { type: "button", onClick: () => onToggle(path), className: "w-4 text-left text-[var(--muted)] hover:text-[var(--txt)]", title: open ? "Collapse" : "Expand", children: open ? "▾" : "▸" })) : (_jsx("span", { className: "inline-block w-4 text-[var(--muted)]", children: "\u00B7" })), _jsx("span", { className: "text-[var(--muted)]", children: label }), _jsx("span", { className: "text-[var(--txt)]", children: nodeSummary(value) })] }), canExpand && open && (_jsx("div", { children: entries.map((entry) => (_jsx(TreeNode, { label: entry.key, value: entry.value, path: entry.path, depth: depth + 1, expanded: expanded, onToggle: onToggle }, entry.path))) }))] }));
|
|
98
|
+
}
|
|
99
|
+
function OrderCard(props) {
|
|
100
|
+
const { t } = useApp();
|
|
101
|
+
const { title, entries } = props;
|
|
102
|
+
return (_jsxs("div", { className: "border border-[var(--border)] bg-[var(--card)] rounded-md p-3 min-h-[150px]", children: [_jsxs("div", { className: "text-xs font-semibold mb-2", children: [title, " (", entries.length, ")"] }), _jsx("div", { className: "max-h-[180px] overflow-auto text-[11px] font-mono leading-5", children: entries.length === 0 ? (_jsx("div", { className: "text-[var(--muted)]", children: t("runtimeview.none") })) : (entries.map((entry) => (_jsx("div", { className: "text-[var(--txt)]", children: orderItemLabel(entry) }, `${title}-${entry.index}`)))) })] }));
|
|
103
|
+
}
|
|
104
|
+
function ServicesOrderCard(props) {
|
|
105
|
+
const { t } = useApp();
|
|
106
|
+
const { entries } = props;
|
|
107
|
+
return (_jsxs("div", { className: "border border-[var(--border)] bg-[var(--card)] rounded-md p-3 min-h-[150px]", children: [_jsxs("div", { className: "text-xs font-semibold mb-2", children: [t("runtimeview.Services"), entries.length, " ", t("runtimeview.types")] }), _jsx("div", { className: "max-h-[180px] overflow-auto text-[11px] font-mono leading-5", children: entries.length === 0 ? (_jsx("div", { className: "text-[var(--muted)]", children: t("runtimeview.none") })) : (entries.map((serviceGroup) => (_jsxs("div", { className: "mb-2", children: [_jsxs("div", { className: "text-[var(--txt)]", children: ["[", serviceGroup.index, "] ", serviceGroup.serviceType, " (", serviceGroup.count, ")"] }), serviceGroup.instances.map((instance) => (_jsx("div", { className: "text-[var(--muted)] pl-4", children: orderItemLabel(instance) }, `${serviceGroup.serviceType}-${instance.index}`)))] }, `${serviceGroup.serviceType}-${serviceGroup.index}`)))) })] }));
|
|
108
|
+
}
|
|
109
|
+
export function RuntimeView() {
|
|
110
|
+
const { t } = useApp();
|
|
111
|
+
const [snapshot, setSnapshot] = useState(null);
|
|
112
|
+
const [loading, setLoading] = useState(false);
|
|
113
|
+
const [error, setError] = useState(null);
|
|
114
|
+
const [activeSection, setActiveSection] = useState("runtime");
|
|
115
|
+
const [expandedPaths, setExpandedPaths] = useState(new Set());
|
|
116
|
+
const [depth, setDepth] = useState(10);
|
|
117
|
+
const [maxArrayLength, setMaxArrayLength] = useState(1000);
|
|
118
|
+
const [maxObjectEntries, setMaxObjectEntries] = useState(1000);
|
|
119
|
+
const sectionData = snapshot?.sections[activeSection] ?? null;
|
|
120
|
+
const rootPath = `$${activeSection}`;
|
|
121
|
+
const loadSnapshot = useCallback(async () => {
|
|
122
|
+
setLoading(true);
|
|
123
|
+
setError(null);
|
|
124
|
+
try {
|
|
125
|
+
const next = await client.getRuntimeSnapshot({
|
|
126
|
+
depth,
|
|
127
|
+
maxArrayLength,
|
|
128
|
+
maxObjectEntries,
|
|
129
|
+
});
|
|
130
|
+
setSnapshot(next);
|
|
131
|
+
}
|
|
132
|
+
catch (err) {
|
|
133
|
+
setError(err instanceof Error ? err.message : "Failed to load runtime snapshot");
|
|
134
|
+
}
|
|
135
|
+
finally {
|
|
136
|
+
setLoading(false);
|
|
137
|
+
}
|
|
138
|
+
}, [depth, maxArrayLength, maxObjectEntries]);
|
|
139
|
+
useEffect(() => {
|
|
140
|
+
void loadSnapshot();
|
|
141
|
+
}, [loadSnapshot]);
|
|
142
|
+
useEffect(() => {
|
|
143
|
+
setExpandedPaths(buildInitialExpanded(rootPath, sectionData));
|
|
144
|
+
}, [rootPath, sectionData]);
|
|
145
|
+
const handleTogglePath = useCallback((path) => {
|
|
146
|
+
setExpandedPaths((prev) => {
|
|
147
|
+
const next = new Set(prev);
|
|
148
|
+
if (next.has(path))
|
|
149
|
+
next.delete(path);
|
|
150
|
+
else
|
|
151
|
+
next.add(path);
|
|
152
|
+
return next;
|
|
153
|
+
});
|
|
154
|
+
}, []);
|
|
155
|
+
return (_jsxs("div", { "data-testid": "runtime-view", className: "flex flex-col gap-4 h-full", children: [_jsxs("div", { className: "flex flex-wrap items-end gap-3 border border-[var(--border)] bg-[var(--card)] rounded-md p-3", children: [_jsxs("label", { className: "text-[11px] text-[var(--muted)] flex items-center gap-1", children: [t("runtimeview.depth"), _jsx("input", { type: "number", min: 1, max: 24, value: depth, onChange: (e) => setDepth(Math.max(1, Math.min(24, Number(e.target.value) || 1))), className: "w-16 px-1.5 py-0.5 border border-[var(--border)] bg-[var(--bg)] text-[var(--txt)] rounded-sm" })] }), _jsxs("label", { className: "text-[11px] text-[var(--muted)] flex items-center gap-1", children: [t("runtimeview.arrayCap"), _jsx("input", { type: "number", min: 1, max: 5000, value: maxArrayLength, onChange: (e) => setMaxArrayLength(Math.max(1, Math.min(5000, Number(e.target.value) || 1))), className: "w-20 px-1.5 py-0.5 border border-[var(--border)] bg-[var(--bg)] text-[var(--txt)] rounded-sm" })] }), _jsxs("label", { className: "text-[11px] text-[var(--muted)] flex items-center gap-1", children: [t("runtimeview.objectCap"), _jsx("input", { type: "number", min: 1, max: 5000, value: maxObjectEntries, onChange: (e) => setMaxObjectEntries(Math.max(1, Math.min(5000, Number(e.target.value) || 1))), className: "w-20 px-1.5 py-0.5 border border-[var(--border)] bg-[var(--bg)] text-[var(--txt)] rounded-sm" })] }), _jsx("button", { type: "button", onClick: () => void loadSnapshot(), disabled: loading, className: "px-3 py-1.5 text-xs rounded border border-[var(--border)] bg-[var(--bg)] hover:bg-[var(--bg-hover)] disabled:opacity-60", children: loading ? "Refreshing..." : "Refresh" }), _jsx("button", { type: "button", onClick: () => setExpandedPaths(new Set([rootPath])), className: "px-3 py-1.5 text-xs rounded border border-[var(--border)] bg-[var(--bg)] hover:bg-[var(--bg-hover)]", children: t("runtimeview.Collapse") }), _jsx("button", { type: "button", onClick: () => setExpandedPaths(buildInitialExpanded(rootPath, sectionData)), className: "px-3 py-1.5 text-xs rounded border border-[var(--border)] bg-[var(--bg)] hover:bg-[var(--bg-hover)]", children: t("runtimeview.ExpandTop") }), _jsx("div", { className: "text-[11px] text-[var(--muted)] ml-auto", children: snapshot
|
|
156
|
+
? `Last updated: ${formatDateTime(snapshot.generatedAt, { fallback: "n/a" })}`
|
|
157
|
+
: "No snapshot loaded" })] }), snapshot && (_jsxs("div", { className: "grid gap-3 md:grid-cols-2 xl:grid-cols-3", children: [_jsx(OrderCard, { title: t("runtimeview.Plugins"), entries: snapshot.order.plugins }), _jsx(OrderCard, { title: t("runtimeview.Actions"), entries: snapshot.order.actions }), _jsx(OrderCard, { title: t("runtimeview.Providers"), entries: snapshot.order.providers }), _jsx(OrderCard, { title: t("runtimeview.Evaluators"), entries: snapshot.order.evaluators }), _jsx(ServicesOrderCard, { entries: snapshot.order.services }), _jsxs("div", { className: "border border-[var(--border)] bg-[var(--card)] rounded-md p-3", children: [_jsx("div", { className: "text-xs font-semibold mb-2", children: t("runtimeview.Summary") }), _jsxs("div", { className: "text-[11px] font-mono leading-5", children: [_jsxs("div", { children: [t("runtimeview.runtime"), " ", snapshot.runtimeAvailable ? "available" : "offline"] }), _jsxs("div", { children: [t("runtimeview.agent"), " ", snapshot.meta.agentName] }), _jsxs("div", { children: [t("runtimeview.state"), " ", snapshot.meta.agentState] }), _jsxs("div", { children: [t("runtimeview.model"), " ", snapshot.meta.model ?? "n/a"] }), _jsxs("div", { children: [t("runtimeview.plugins"), " ", snapshot.meta.pluginCount] }), _jsxs("div", { children: [t("runtimeview.actions"), " ", snapshot.meta.actionCount] }), _jsxs("div", { children: [t("runtimeview.providers"), " ", snapshot.meta.providerCount] }), _jsxs("div", { children: [t("runtimeview.evaluators"), " ", snapshot.meta.evaluatorCount] }), _jsxs("div", { children: [t("runtimeview.services"), " ", snapshot.meta.serviceCount] })] })] })] })), _jsx("div", { className: "flex gap-1 border-b border-[var(--border)]", children: SECTION_TABS.map((tab) => {
|
|
158
|
+
const active = tab.key === activeSection;
|
|
159
|
+
return (_jsx("button", { type: "button", onClick: () => setActiveSection(tab.key), className: `px-3 py-2 text-xs font-medium border-b-2 -mb-px ${active
|
|
160
|
+
? "border-accent text-txt"
|
|
161
|
+
: "border-transparent text-muted hover:text-txt hover:border-border"}`, children: tab.label }, tab.key));
|
|
162
|
+
}) }), _jsx("div", { className: "flex-1 min-h-0 border border-[var(--border)] bg-[var(--card)] rounded-md overflow-auto p-2", children: error ? (_jsx("div", { className: "text-xs text-danger p-3", children: error })) : !snapshot ? (_jsx("div", { className: "text-xs text-[var(--muted)] p-3", children: loading
|
|
163
|
+
? "Loading runtime snapshot..."
|
|
164
|
+
: "No runtime snapshot available." })) : !snapshot.runtimeAvailable ? (_jsx("div", { className: "text-xs text-[var(--muted)] p-3", children: t("runtimeview.AgentRuntimeIsNot") })) : (_jsx(TreeNode, { label: activeSection, value: sectionData, path: rootPath, depth: 0, expanded: expandedPaths, onToggle: handleTogglePath })) })] }));
|
|
165
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Modal for naming and saving a custom /command from selected text.
|
|
3
|
+
*/
|
|
4
|
+
interface SaveCommandModalProps {
|
|
5
|
+
open: boolean;
|
|
6
|
+
text: string;
|
|
7
|
+
onSave: (name: string) => void;
|
|
8
|
+
onClose: () => void;
|
|
9
|
+
}
|
|
10
|
+
export declare function SaveCommandModal({ open, text, onSave, onClose, }: SaveCommandModalProps): import("react/jsx-runtime").JSX.Element | null;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=SaveCommandModal.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SaveCommandModal.d.ts","sourceRoot":"","sources":["../../src/components/SaveCommandModal.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAMH,UAAU,qBAAqB;IAC7B,IAAI,EAAE,OAAO,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAC/B,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAID,wBAAgB,gBAAgB,CAAC,EAC/B,IAAI,EACJ,IAAI,EACJ,MAAM,EACN,OAAO,GACR,EAAE,qBAAqB,kDA4LvB"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* Modal for naming and saving a custom /command from selected text.
|
|
4
|
+
*/
|
|
5
|
+
import { Input } from "@elizaos/ui";
|
|
6
|
+
import { useCallback, useEffect, useId, useRef, useState } from "react";
|
|
7
|
+
import { useApp } from "../state";
|
|
8
|
+
const NAME_PATTERN = /^[a-zA-Z][a-zA-Z0-9-]*$/;
|
|
9
|
+
export function SaveCommandModal({ open, text, onSave, onClose, }) {
|
|
10
|
+
const { t } = useApp();
|
|
11
|
+
const [name, setName] = useState("");
|
|
12
|
+
const [error, setError] = useState("");
|
|
13
|
+
const inputRef = useRef(null);
|
|
14
|
+
const dialogTitleId = useId();
|
|
15
|
+
const inputId = useId();
|
|
16
|
+
const inputLabelId = useId();
|
|
17
|
+
const inputErrorId = useId();
|
|
18
|
+
useEffect(() => {
|
|
19
|
+
if (open) {
|
|
20
|
+
setName("");
|
|
21
|
+
setError("");
|
|
22
|
+
const focusTimeout = setTimeout(() => inputRef.current?.focus(), 50);
|
|
23
|
+
return () => clearTimeout(focusTimeout);
|
|
24
|
+
}
|
|
25
|
+
}, [open]);
|
|
26
|
+
const validate = useCallback((value) => {
|
|
27
|
+
if (!value)
|
|
28
|
+
return "Name is required";
|
|
29
|
+
if (!NAME_PATTERN.test(value))
|
|
30
|
+
return "Must start with a letter, no spaces (a-z, 0-9, -)";
|
|
31
|
+
return "";
|
|
32
|
+
}, []);
|
|
33
|
+
const handleSubmit = useCallback(() => {
|
|
34
|
+
const err = validate(name);
|
|
35
|
+
if (err) {
|
|
36
|
+
setError(err);
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
onSave(name);
|
|
40
|
+
}, [name, validate, onSave]);
|
|
41
|
+
const handleKeyDown = useCallback((e) => {
|
|
42
|
+
if (e.nativeEvent.isComposing)
|
|
43
|
+
return;
|
|
44
|
+
if (e.key === "Enter")
|
|
45
|
+
handleSubmit();
|
|
46
|
+
if (e.key === "Escape")
|
|
47
|
+
onClose();
|
|
48
|
+
}, [handleSubmit, onClose]);
|
|
49
|
+
if (!open)
|
|
50
|
+
return null;
|
|
51
|
+
const preview = text.length > 120 ? `${text.slice(0, 120)}...` : text;
|
|
52
|
+
return (_jsx("div", { className: "fixed inset-0 z-50 flex items-center justify-center", style: {
|
|
53
|
+
background: "color-mix(in srgb, var(--bg) 50%, transparent)",
|
|
54
|
+
backdropFilter: "blur(4px)",
|
|
55
|
+
}, onClick: (e) => {
|
|
56
|
+
if (e.target === e.currentTarget)
|
|
57
|
+
onClose();
|
|
58
|
+
}, onKeyDown: (e) => {
|
|
59
|
+
if (e.key === "Escape") {
|
|
60
|
+
e.preventDefault();
|
|
61
|
+
onClose();
|
|
62
|
+
}
|
|
63
|
+
}, role: "dialog", "aria-modal": "true", "aria-labelledby": dialogTitleId, children: _jsxs("div", { className: "w-full max-w-md shadow-lg flex flex-col overflow-hidden rounded-xl", style: {
|
|
64
|
+
background: "color-mix(in srgb, var(--bg) 96%, transparent)",
|
|
65
|
+
border: "1px solid color-mix(in srgb, var(--accent) 18%, transparent)",
|
|
66
|
+
backdropFilter: "blur(24px)",
|
|
67
|
+
boxShadow: "var(--shadow-lg)",
|
|
68
|
+
}, children: [_jsxs("div", { className: "flex items-center px-5 py-3 shrink-0", style: { borderBottom: "1px solid var(--border)" }, children: [_jsx("span", { id: dialogTitleId, className: "font-bold text-sm flex-1", style: { color: "var(--text)" }, children: t("savecommandmodal.SaveAsCommand") }), _jsx("button", { type: "button", className: "bg-transparent border-0 cursor-pointer text-lg h-6 w-6", style: { color: "var(--muted)" }, onClick: onClose, "aria-label": "Close dialog", children: t("bugreportmodal.Times") })] }), _jsxs("div", { className: "px-5 py-4 flex flex-col gap-3", children: [_jsx("label", { id: inputLabelId, htmlFor: inputId, className: "text-xs", style: { color: "var(--muted)" }, children: t("savecommandmodal.CommandName") }), _jsxs("div", { className: "flex items-center gap-1", children: [_jsx("span", { className: "text-sm", style: { color: "var(--muted)" }, children: "/" }), _jsx(Input, { id: inputId, ref: inputRef, type: "text", value: name, onChange: (e) => {
|
|
69
|
+
setName(e.target.value);
|
|
70
|
+
setError("");
|
|
71
|
+
}, onKeyDown: handleKeyDown, placeholder: t("savecommandmodal.myCommand"), "aria-labelledby": inputLabelId, "aria-describedby": error ? inputErrorId : undefined, "aria-invalid": error ? "true" : undefined, className: "flex-1 h-8 text-sm shadow-sm", style: {
|
|
72
|
+
background: "var(--bg-hover)",
|
|
73
|
+
border: "1px solid var(--border)",
|
|
74
|
+
color: "var(--text)",
|
|
75
|
+
} })] }), error && (_jsx("p", { id: inputErrorId, className: "text-xs", style: { color: "#ef4444" }, children: error })), _jsx("span", { className: "text-xs mt-1", style: { color: "var(--muted)" }, children: t("savecommandmodal.Preview") }), _jsx("pre", { className: "text-xs px-3 py-2 whitespace-pre-wrap break-words max-h-24 overflow-y-auto", style: {
|
|
76
|
+
color: "var(--muted)",
|
|
77
|
+
background: "var(--bg-hover)",
|
|
78
|
+
border: "1px solid var(--border)",
|
|
79
|
+
}, children: preview })] }), _jsxs("div", { className: "flex justify-end gap-2 px-5 py-3", style: { borderTop: "1px solid var(--border)" }, children: [_jsx("button", { type: "button", className: "px-3 py-1.5 h-8 text-xs font-medium rounded cursor-pointer transition-colors", style: {
|
|
80
|
+
background: "transparent",
|
|
81
|
+
border: "1px solid var(--border)",
|
|
82
|
+
color: "var(--muted)",
|
|
83
|
+
}, onClick: onClose, children: t("onboarding.cancel") }), _jsx("button", { type: "button", className: "px-3 py-1.5 h-8 text-xs font-medium rounded cursor-pointer transition-colors", style: { background: "#f0b232", border: "none", color: "#000" }, onClick: handleSubmit, children: t("savecommandmodal.Save") })] })] }) }));
|
|
84
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Secrets Vault — user-curated view of API keys and credentials.
|
|
3
|
+
*
|
|
4
|
+
* Only shows secrets the user has explicitly added to their vault (persisted in
|
|
5
|
+
* localStorage) plus any that are already set in the environment. Users browse
|
|
6
|
+
* available secrets from plugins and pick which ones to manage here.
|
|
7
|
+
*/
|
|
8
|
+
export declare function SecretsView(): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
//# sourceMappingURL=SecretsView.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SecretsView.d.ts","sourceRoot":"","sources":["../../src/components/SecretsView.tsx"],"names":[],"mappings":"AAAA;;;;;;GAMG;AA6EH,wBAAgB,WAAW,4CAmQ1B"}
|
|
@@ -0,0 +1,249 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* Secrets Vault — user-curated view of API keys and credentials.
|
|
4
|
+
*
|
|
5
|
+
* Only shows secrets the user has explicitly added to their vault (persisted in
|
|
6
|
+
* localStorage) plus any that are already set in the environment. Users browse
|
|
7
|
+
* available secrets from plugins and pick which ones to manage here.
|
|
8
|
+
*/
|
|
9
|
+
import { Button, Input } from "@elizaos/ui";
|
|
10
|
+
import { ChevronDown } from "lucide-react";
|
|
11
|
+
import { useCallback, useEffect, useMemo, useState } from "react";
|
|
12
|
+
import { client } from "../api";
|
|
13
|
+
import { useApp } from "../state";
|
|
14
|
+
/* ── Constants ──────────────────────────────────────────────────────── */
|
|
15
|
+
const STORAGE_KEY = "eliza:secrets-vault-keys";
|
|
16
|
+
const CATEGORY_ORDER = [
|
|
17
|
+
"ai-provider",
|
|
18
|
+
"blockchain",
|
|
19
|
+
"connector",
|
|
20
|
+
"auth",
|
|
21
|
+
"other",
|
|
22
|
+
];
|
|
23
|
+
const CATEGORY_LABELS = {
|
|
24
|
+
"ai-provider": "AI Providers",
|
|
25
|
+
blockchain: "Blockchain",
|
|
26
|
+
connector: "Connectors",
|
|
27
|
+
auth: "Authentication",
|
|
28
|
+
other: "Other",
|
|
29
|
+
};
|
|
30
|
+
function groupSecretsByCategory(secrets) {
|
|
31
|
+
const grouped = new Map();
|
|
32
|
+
for (const secret of secrets) {
|
|
33
|
+
const existing = grouped.get(secret.category);
|
|
34
|
+
if (existing) {
|
|
35
|
+
existing.push(secret);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
grouped.set(secret.category, [secret]);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
return CATEGORY_ORDER.filter((category) => grouped.has(category)).map((category) => ({
|
|
42
|
+
category,
|
|
43
|
+
label: CATEGORY_LABELS[category],
|
|
44
|
+
secrets: grouped.get(category) ?? [],
|
|
45
|
+
}));
|
|
46
|
+
}
|
|
47
|
+
/* ── Persistence ────────────────────────────────────────────────────── */
|
|
48
|
+
function loadPinnedKeys() {
|
|
49
|
+
try {
|
|
50
|
+
const raw = localStorage.getItem(STORAGE_KEY);
|
|
51
|
+
if (raw)
|
|
52
|
+
return new Set(JSON.parse(raw));
|
|
53
|
+
}
|
|
54
|
+
catch {
|
|
55
|
+
/* ignore */
|
|
56
|
+
}
|
|
57
|
+
return new Set();
|
|
58
|
+
}
|
|
59
|
+
function savePinnedKeys(keys) {
|
|
60
|
+
try {
|
|
61
|
+
localStorage.setItem(STORAGE_KEY, JSON.stringify([...keys]));
|
|
62
|
+
}
|
|
63
|
+
catch {
|
|
64
|
+
/* ignore */
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
/* ── Component ──────────────────────────────────────────────────────── */
|
|
68
|
+
export function SecretsView() {
|
|
69
|
+
const { t } = useApp();
|
|
70
|
+
const [allSecrets, setAllSecrets] = useState([]);
|
|
71
|
+
const [loading, setLoading] = useState(true);
|
|
72
|
+
const [error, setError] = useState(null);
|
|
73
|
+
const [pinnedKeys, setPinnedKeys] = useState(loadPinnedKeys);
|
|
74
|
+
const [draft, setDraft] = useState({});
|
|
75
|
+
const [visible, setVisible] = useState(new Set());
|
|
76
|
+
const [saving, setSaving] = useState(false);
|
|
77
|
+
const [saveResult, setSaveResult] = useState(null);
|
|
78
|
+
const [collapsed, setCollapsed] = useState(new Set());
|
|
79
|
+
const [pickerOpen, setPickerOpen] = useState(false);
|
|
80
|
+
const [pickerSearch, setPickerSearch] = useState("");
|
|
81
|
+
const load = useCallback(async () => {
|
|
82
|
+
setLoading(true);
|
|
83
|
+
setError(null);
|
|
84
|
+
try {
|
|
85
|
+
const res = await client.getSecrets();
|
|
86
|
+
setAllSecrets(res.secrets);
|
|
87
|
+
}
|
|
88
|
+
catch (err) {
|
|
89
|
+
setError(err instanceof Error ? err.message : "Failed to load secrets");
|
|
90
|
+
}
|
|
91
|
+
finally {
|
|
92
|
+
setLoading(false);
|
|
93
|
+
}
|
|
94
|
+
}, []);
|
|
95
|
+
useEffect(() => {
|
|
96
|
+
load();
|
|
97
|
+
}, [load]);
|
|
98
|
+
// Vault secrets = pinned by user OR already set in env
|
|
99
|
+
const vaultSecrets = useMemo(() => {
|
|
100
|
+
return allSecrets.filter((s) => pinnedKeys.has(s.key) || s.isSet);
|
|
101
|
+
}, [allSecrets, pinnedKeys]);
|
|
102
|
+
// Available secrets not in the vault (for the picker)
|
|
103
|
+
const availableSecrets = useMemo(() => {
|
|
104
|
+
const vaultKeys = new Set(vaultSecrets.map((s) => s.key));
|
|
105
|
+
const available = allSecrets.filter((s) => !vaultKeys.has(s.key));
|
|
106
|
+
if (!pickerSearch.trim())
|
|
107
|
+
return available;
|
|
108
|
+
const q = pickerSearch.toLowerCase();
|
|
109
|
+
return available.filter((s) => s.key.toLowerCase().includes(q) ||
|
|
110
|
+
s.description.toLowerCase().includes(q) ||
|
|
111
|
+
s.usedBy.some((u) => u.pluginName.toLowerCase().includes(q)));
|
|
112
|
+
}, [allSecrets, vaultSecrets, pickerSearch]);
|
|
113
|
+
// Group vault secrets by category
|
|
114
|
+
const grouped = useMemo(() => {
|
|
115
|
+
return groupSecretsByCategory(vaultSecrets);
|
|
116
|
+
}, [vaultSecrets]);
|
|
117
|
+
const dirtyKeys = useMemo(() => {
|
|
118
|
+
return Object.keys(draft).filter((k) => draft[k].trim() !== "");
|
|
119
|
+
}, [draft]);
|
|
120
|
+
const pinKey = (key) => {
|
|
121
|
+
setPinnedKeys((prev) => {
|
|
122
|
+
const next = new Set(prev);
|
|
123
|
+
next.add(key);
|
|
124
|
+
savePinnedKeys(next);
|
|
125
|
+
return next;
|
|
126
|
+
});
|
|
127
|
+
};
|
|
128
|
+
const unpinKey = (key) => {
|
|
129
|
+
setPinnedKeys((prev) => {
|
|
130
|
+
const next = new Set(prev);
|
|
131
|
+
next.delete(key);
|
|
132
|
+
savePinnedKeys(next);
|
|
133
|
+
return next;
|
|
134
|
+
});
|
|
135
|
+
setDraft((prev) => {
|
|
136
|
+
const next = { ...prev };
|
|
137
|
+
delete next[key];
|
|
138
|
+
return next;
|
|
139
|
+
});
|
|
140
|
+
};
|
|
141
|
+
const handleSave = async () => {
|
|
142
|
+
if (dirtyKeys.length === 0)
|
|
143
|
+
return;
|
|
144
|
+
setSaving(true);
|
|
145
|
+
setSaveResult(null);
|
|
146
|
+
try {
|
|
147
|
+
const payload = {};
|
|
148
|
+
for (const key of dirtyKeys)
|
|
149
|
+
payload[key] = draft[key];
|
|
150
|
+
const res = await client.updateSecrets(payload);
|
|
151
|
+
setSaveResult({
|
|
152
|
+
ok: true,
|
|
153
|
+
message: `Updated ${res.updated.length} secret${res.updated.length !== 1 ? "s" : ""}`,
|
|
154
|
+
});
|
|
155
|
+
setDraft({});
|
|
156
|
+
await load();
|
|
157
|
+
}
|
|
158
|
+
catch (err) {
|
|
159
|
+
setSaveResult({
|
|
160
|
+
ok: false,
|
|
161
|
+
message: err instanceof Error ? err.message : "Save failed",
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
finally {
|
|
165
|
+
setSaving(false);
|
|
166
|
+
}
|
|
167
|
+
};
|
|
168
|
+
const toggleCollapse = (cat) => {
|
|
169
|
+
setCollapsed((prev) => {
|
|
170
|
+
const next = new Set(prev);
|
|
171
|
+
if (next.has(cat))
|
|
172
|
+
next.delete(cat);
|
|
173
|
+
else
|
|
174
|
+
next.add(cat);
|
|
175
|
+
return next;
|
|
176
|
+
});
|
|
177
|
+
};
|
|
178
|
+
const toggleVisible = (key) => {
|
|
179
|
+
setVisible((prev) => {
|
|
180
|
+
const next = new Set(prev);
|
|
181
|
+
if (next.has(key))
|
|
182
|
+
next.delete(key);
|
|
183
|
+
else
|
|
184
|
+
next.add(key);
|
|
185
|
+
return next;
|
|
186
|
+
});
|
|
187
|
+
};
|
|
188
|
+
if (loading) {
|
|
189
|
+
return (_jsx("div", { className: "text-[var(--muted)] text-[13px] italic py-8 text-center", children: t("secretsview.LoadingSecrets") }));
|
|
190
|
+
}
|
|
191
|
+
if (error) {
|
|
192
|
+
return (_jsxs("div", { className: "text-center py-8", children: [_jsx("p", { className: "text-[var(--danger)] text-[13px] mb-2", children: error }), _jsx("button", { type: "button", className: "bg-transparent border-0 text-[13px] text-[var(--text)] underline decoration-[var(--accent)] underline-offset-2 cursor-pointer hover:opacity-80", onClick: load, children: t("common.retry") })] }));
|
|
193
|
+
}
|
|
194
|
+
return (_jsxs("div", { children: [_jsxs("div", { className: "flex items-center justify-between mb-5", children: [_jsx("p", { className: "text-[13px] text-[var(--muted)] m-0", children: t("secretsview.ManageAPIKeysAnd") }), _jsx(Button, { variant: "default", size: "sm", className: "px-3 py-1.5 h-8 text-[13px] shadow-sm flex-shrink-0", onClick: () => {
|
|
195
|
+
setPickerOpen(true);
|
|
196
|
+
setPickerSearch("");
|
|
197
|
+
}, children: t("secretsview.AddSecret") })] }), pickerOpen && (_jsx(SecretPicker, { available: availableSecrets, search: pickerSearch, onSearchChange: setPickerSearch, onAdd: (key) => {
|
|
198
|
+
pinKey(key);
|
|
199
|
+
}, onClose: () => setPickerOpen(false) })), vaultSecrets.length === 0 && (_jsx("div", { className: "text-[var(--muted)] text-[13px] italic py-8 text-center border border-dashed border-[var(--border)]", children: t("secretsview.YourVaultIsEmpty") })), grouped.map(({ category, label, secrets: catSecrets }) => (_jsxs("div", { className: "mb-6", children: [_jsxs("button", { type: "button", className: "flex items-center gap-2 w-full bg-transparent border-0 cursor-pointer text-left mb-3", onClick: () => toggleCollapse(category), children: [_jsx(ChevronDown, { className: "w-3 h-3 text-[var(--muted)] select-none transition-transform", style: {
|
|
200
|
+
transform: collapsed.has(category)
|
|
201
|
+
? "rotate(-90deg)"
|
|
202
|
+
: "rotate(0deg)",
|
|
203
|
+
} }), _jsx("span", { className: "text-[14px] font-semibold text-[var(--txt)]", children: label }), _jsxs("span", { className: "text-[12px] text-[var(--muted)]", children: ["(", catSecrets.length, ")"] })] }), !collapsed.has(category) && (_jsx("div", { className: "grid grid-cols-1 md:grid-cols-2 gap-3", children: catSecrets.map((secret) => (_jsx(SecretCard, { secret: secret, draftValue: draft[secret.key] ?? "", isVisible: visible.has(secret.key), isPinned: pinnedKeys.has(secret.key), onToggleVisible: () => toggleVisible(secret.key), onDraftChange: (val) => setDraft((prev) => ({ ...prev, [secret.key]: val })), onRemove: () => unpinKey(secret.key) }, secret.key))) }))] }, category))), vaultSecrets.length > 0 && (_jsxs("div", { className: "flex items-center gap-3 mt-4 pt-4 border-t border-[var(--border)]", children: [_jsx(Button, { variant: "default", size: "sm", className: "px-4 py-2 h-9 text-[13px] font-medium shadow-sm transition-colors", disabled: dirtyKeys.length === 0 || saving, onClick: handleSave, children: saving
|
|
204
|
+
? "Saving..."
|
|
205
|
+
: `Save${dirtyKeys.length > 0 ? ` (${dirtyKeys.length})` : ""}` }), saveResult && (_jsx("span", { className: `text-[13px] ${saveResult.ok ? "text-[var(--ok)]" : "text-[var(--danger)]"}`, children: saveResult.message }))] }))] }));
|
|
206
|
+
}
|
|
207
|
+
/* ── Secret Picker ──────────────────────────────────────────────────── */
|
|
208
|
+
function SecretPicker({ available, search, onSearchChange, onAdd, onClose, }) {
|
|
209
|
+
const { t } = useApp();
|
|
210
|
+
// Group available by category
|
|
211
|
+
const grouped = useMemo(() => {
|
|
212
|
+
return groupSecretsByCategory(available);
|
|
213
|
+
}, [available]);
|
|
214
|
+
return (_jsx("div", { className: "fixed inset-0 bg-black/40 z-[9999] flex items-start justify-center pt-20", onClick: (e) => {
|
|
215
|
+
if (e.target === e.currentTarget)
|
|
216
|
+
onClose();
|
|
217
|
+
}, onKeyDown: (e) => {
|
|
218
|
+
if (e.key === "Escape") {
|
|
219
|
+
e.preventDefault();
|
|
220
|
+
onClose();
|
|
221
|
+
}
|
|
222
|
+
}, role: "dialog", "aria-modal": "true", children: _jsxs("div", { className: "bg-[var(--bg)] border border-[var(--border)] w-[560px] max-h-[480px] flex flex-col shadow-2xl", children: [_jsxs("div", { className: "px-4 py-3 border-b border-[var(--border)] flex items-center justify-between", children: [_jsx("span", { className: "text-[14px] font-semibold text-[var(--txt)]", children: t("secretsview.AddSecretsToVault") }), _jsx("button", { type: "button", className: "text-[var(--muted)] bg-transparent border-0 cursor-pointer text-[16px] hover:text-[var(--txt)]", onClick: onClose, children: "x" })] }), _jsx(Input, { type: "text", className: "w-full px-4 py-2.5 h-12 border-0 border-b border-[var(--border)] bg-transparent text-[13px] text-[var(--txt)] shadow-none rounded-none focus-visible:ring-0 font-body", placeholder: t("secretsview.SearchByKeyDescr"), value: search, onChange: (e) => onSearchChange(e.target.value) }), _jsx("div", { className: "flex-1 overflow-y-auto p-3", children: available.length === 0 ? (_jsx("div", { className: "py-6 text-center text-[var(--muted)] text-[13px]", children: search
|
|
223
|
+
? "No matching secrets found."
|
|
224
|
+
: "All available secrets are already in your vault." })) : (grouped.map(({ category, label, secrets }) => (_jsxs("div", { className: "mb-4", children: [_jsx("div", { className: "text-[11px] font-semibold text-[var(--muted)] uppercase tracking-wide mb-2", children: label }), secrets.map((s) => {
|
|
225
|
+
const enabledPlugins = s.usedBy.filter((u) => u.enabled);
|
|
226
|
+
const pluginList = s.usedBy
|
|
227
|
+
.map((u) => u.pluginName || u.pluginId)
|
|
228
|
+
.join(", ");
|
|
229
|
+
return (_jsxs("div", { className: "flex items-center justify-between py-2 px-2 hover:bg-[var(--bg-hover)] gap-3", children: [_jsxs("div", { className: "flex-1 min-w-0", children: [_jsx("div", { className: "text-[13px] font-mono text-[var(--txt)]", children: s.key }), _jsxs("div", { className: "text-[11px] text-[var(--muted)] truncate", title: pluginList, children: [s.description, s.usedBy.length > 0 && (_jsxs("span", { className: "ml-1", children: ["\u2014", " ", enabledPlugins.length > 0
|
|
230
|
+
? `${enabledPlugins.length} active plugin${enabledPlugins.length !== 1 ? "s" : ""}`
|
|
231
|
+
: `${s.usedBy.length} plugin${s.usedBy.length !== 1 ? "s" : ""} (none active)`] }))] })] }), _jsx(Button, { variant: "default", size: "sm", className: "px-2.5 py-1 h-7 text-[12px] shadow-sm flex-shrink-0", onClick: () => onAdd(s.key), children: t("secretsview.Add") })] }, s.key));
|
|
232
|
+
})] }, category)))) })] }) }));
|
|
233
|
+
}
|
|
234
|
+
/* ── Secret Card ────────────────────────────────────────────────────── */
|
|
235
|
+
function SecretCard({ secret, draftValue, isVisible, isPinned, onToggleVisible, onDraftChange, onRemove, }) {
|
|
236
|
+
const { t } = useApp();
|
|
237
|
+
const enabledPlugins = secret.usedBy.filter((u) => u.enabled);
|
|
238
|
+
const pluginList = secret.usedBy
|
|
239
|
+
.map((u) => u.pluginName || u.pluginId)
|
|
240
|
+
.join(", ");
|
|
241
|
+
const hasDraft = draftValue.trim() !== "";
|
|
242
|
+
// Only show "Required" if an enabled plugin actually requires it
|
|
243
|
+
const showRequired = secret.required && enabledPlugins.length > 0;
|
|
244
|
+
return (_jsxs("div", { className: "border border-[var(--border)] bg-[var(--bg-card)] p-4 flex flex-col gap-2", children: [_jsxs("div", { className: "flex items-start justify-between gap-2", children: [_jsxs("div", { className: "flex-1 min-w-0", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "w-2 h-2 rounded-full flex-shrink-0", style: {
|
|
245
|
+
backgroundColor: secret.isSet ? "var(--ok)" : "var(--muted)",
|
|
246
|
+
} }), _jsx("span", { className: "text-[13px] font-mono font-medium text-[var(--txt)] truncate", children: secret.key })] }), _jsx("p", { className: "text-[12px] text-[var(--muted)] mt-1 leading-snug", children: secret.description })] }), _jsxs("div", { className: "flex items-center gap-1.5 flex-shrink-0", children: [showRequired && (_jsx("span", { className: "text-[10px] text-[var(--danger)] font-medium px-1.5 py-0.5 border border-[var(--danger)] rounded", children: t("secretsview.Required") })), isPinned && !secret.isSet && (_jsx("button", { type: "button", className: "text-[11px] text-[var(--muted)] bg-transparent border-0 cursor-pointer hover:text-[var(--danger)]", onClick: onRemove, title: t("secretsview.RemoveFromVault"), children: "x" }))] })] }), _jsx("div", { className: "text-[11px] text-[var(--muted)]", title: pluginList, children: enabledPlugins.length > 0
|
|
247
|
+
? `Used by ${enabledPlugins.length} active plugin${enabledPlugins.length !== 1 ? "s" : ""}: ${enabledPlugins.map((u) => u.pluginName || u.pluginId).join(", ")}`
|
|
248
|
+
: `Available for: ${pluginList}` }), secret.isSet && !hasDraft && (_jsx("div", { className: "text-[12px] font-mono text-[var(--muted)] bg-[var(--bg)] px-2 py-1 rounded", children: secret.maskedValue })), _jsxs("div", { className: "flex gap-1.5 items-center", children: [_jsx(Input, { type: isVisible ? "text" : "password", className: "flex-1 px-2.5 py-1.5 h-8 text-[13px] font-mono bg-[var(--bg)] border border-[var(--border)] text-[var(--txt)] focus-visible:ring-1 focus-visible:ring-[var(--accent)] focus-visible:border-[var(--accent)]", placeholder: secret.isSet ? "Enter new value to update" : "Enter value", value: draftValue, onChange: (e) => onDraftChange(e.target.value) }), _jsx(Button, { variant: "outline", size: "sm", className: "px-2 py-1.5 h-8 text-[12px] bg-[var(--bg)] text-[var(--muted)] hover:text-[var(--txt)] shadow-sm", onClick: onToggleVisible, title: isVisible ? "Hide" : "Show", children: isVisible ? "Hide" : "Show" })] })] }));
|
|
249
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Settings view — two-panel layout with section navigator and active section.
|
|
3
|
+
*/
|
|
4
|
+
export declare function SettingsView({ inModal, onClose, initialSection, }?: {
|
|
5
|
+
inModal?: boolean;
|
|
6
|
+
onClose?: () => void;
|
|
7
|
+
initialSection?: string;
|
|
8
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
//# sourceMappingURL=SettingsView.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SettingsView.d.ts","sourceRoot":"","sources":["../../src/components/SettingsView.tsx"],"names":[],"mappings":"AAAA;;GAEG;AA8hBH,wBAAgB,YAAY,CAAC,EAC3B,OAAO,EACP,OAAO,EACP,cAAc,GACf,GAAE;IACD,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,cAAc,CAAC,EAAE,MAAM,CAAC;CACpB,2CAgRL"}
|