@ottocode/web-sdk 0.1.226 → 0.1.227
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/dist/components/chat/FileMentionPopup.d.ts.map +1 -1
- package/dist/components/index.js +25148 -80
- package/dist/components/index.js.map +180 -1
- package/dist/components/messages/AssistantMessageGroup.d.ts.map +1 -1
- package/dist/components/messages/CompactActivityGroup.d.ts +10 -0
- package/dist/components/messages/CompactActivityGroup.d.ts.map +1 -0
- package/dist/components/messages/MessagePartItem.d.ts.map +1 -1
- package/dist/components/messages/MessageThread.d.ts +1 -0
- package/dist/components/messages/MessageThread.d.ts.map +1 -1
- package/dist/components/messages/MessageThreadContainer.d.ts.map +1 -1
- package/dist/components/messages/compactActivity.d.ts +34 -0
- package/dist/components/messages/compactActivity.d.ts.map +1 -0
- package/dist/components/messages/renderers/EditRenderer.d.ts +1 -1
- package/dist/components/messages/renderers/EditRenderer.d.ts.map +1 -1
- package/dist/components/messages/renderers/index.d.ts.map +1 -1
- package/dist/components/messages/renderers/types.d.ts +3 -1
- package/dist/components/messages/renderers/types.d.ts.map +1 -1
- package/dist/components/settings/SettingsSidebar.d.ts.map +1 -1
- package/dist/components/settings/SetuTopupModal.d.ts.map +1 -1
- package/dist/hooks/index.js +4812 -29
- package/dist/hooks/index.js.map +67 -1
- package/dist/hooks/useAuthStatus.d.ts.map +1 -1
- package/dist/hooks/useMCP.d.ts +9 -0
- package/dist/hooks/useMCP.d.ts.map +1 -1
- package/dist/hooks/usePreferences.d.ts +1 -0
- package/dist/hooks/usePreferences.d.ts.map +1 -1
- package/dist/hooks/useSessionStream.d.ts.map +1 -1
- package/dist/index.js +25918 -7
- package/dist/index.js.map +185 -1
- package/dist/lib/api-client/approval.d.ts.map +1 -1
- package/dist/lib/index.js +1007 -5
- package/dist/lib/index.js.map +22 -1
- package/dist/stores/index.js +693 -22
- package/dist/stores/index.js.map +30 -1
- package/dist/stores/toastStore.d.ts +1 -0
- package/dist/stores/toastStore.d.ts.map +1 -1
- package/dist/types/api.js +2 -2
- package/dist/types/api.js.map +9 -1
- package/package.json +4 -4
- package/dist/assets/provider-logos.js +0 -43
- package/dist/assets/provider-logos.js.map +0 -1
- package/dist/components/branch/BranchModal.js +0 -45
- package/dist/components/branch/BranchModal.js.map +0 -1
- package/dist/components/chat/ChatInput.js +0 -267
- package/dist/components/chat/ChatInput.js.map +0 -1
- package/dist/components/chat/ChatInputContainer.js +0 -295
- package/dist/components/chat/ChatInputContainer.js.map +0 -1
- package/dist/components/chat/ChatInputKeyHandler.js +0 -75
- package/dist/components/chat/ChatInputKeyHandler.js.map +0 -1
- package/dist/components/chat/CommandSuggestionsPopup.js +0 -45
- package/dist/components/chat/CommandSuggestionsPopup.js.map +0 -1
- package/dist/components/chat/ConfigModal.js +0 -46
- package/dist/components/chat/ConfigModal.js.map +0 -1
- package/dist/components/chat/ConfigSelector.js +0 -47
- package/dist/components/chat/ConfigSelector.js.map +0 -1
- package/dist/components/chat/FileMentionPopup.js +0 -138
- package/dist/components/chat/FileMentionPopup.js.map +0 -1
- package/dist/components/chat/ShortcutsModal.js +0 -275
- package/dist/components/chat/ShortcutsModal.js.map +0 -1
- package/dist/components/chat/StopButton.js +0 -25
- package/dist/components/chat/StopButton.js.map +0 -1
- package/dist/components/chat/UnifiedAgentSelector.js +0 -107
- package/dist/components/chat/UnifiedAgentSelector.js.map +0 -1
- package/dist/components/chat/UnifiedModelSelector.js +0 -209
- package/dist/components/chat/UnifiedModelSelector.js.map +0 -1
- package/dist/components/common/ProviderLogo.js +0 -30
- package/dist/components/common/ProviderLogo.js.map +0 -1
- package/dist/components/common/StatusIndicator.js +0 -54
- package/dist/components/common/StatusIndicator.js.map +0 -1
- package/dist/components/common/UsageModal.js +0 -55
- package/dist/components/common/UsageModal.js.map +0 -1
- package/dist/components/common/UsageRing.js +0 -22
- package/dist/components/common/UsageRing.js.map +0 -1
- package/dist/components/file-browser/FileBrowserSidebar.js +0 -50
- package/dist/components/file-browser/FileBrowserSidebar.js.map +0 -1
- package/dist/components/file-browser/FileBrowserSidebarToggle.js +0 -12
- package/dist/components/file-browser/FileBrowserSidebarToggle.js.map +0 -1
- package/dist/components/file-browser/FileViewerPanel.js +0 -85
- package/dist/components/file-browser/FileViewerPanel.js.map +0 -1
- package/dist/components/file-browser/QuickFilePicker.js +0 -118
- package/dist/components/file-browser/QuickFilePicker.js.map +0 -1
- package/dist/components/git/GitCommitModal.js +0 -70
- package/dist/components/git/GitCommitModal.js.map +0 -1
- package/dist/components/git/GitDiffPanel.js +0 -60
- package/dist/components/git/GitDiffPanel.js.map +0 -1
- package/dist/components/git/GitDiffViewer.js +0 -224
- package/dist/components/git/GitDiffViewer.js.map +0 -1
- package/dist/components/git/GitFileItem.js +0 -145
- package/dist/components/git/GitFileItem.js.map +0 -1
- package/dist/components/git/GitFileList.js +0 -108
- package/dist/components/git/GitFileList.js.map +0 -1
- package/dist/components/git/GitSidebar.js +0 -156
- package/dist/components/git/GitSidebar.js.map +0 -1
- package/dist/components/git/GitSidebarToggle.js +0 -18
- package/dist/components/git/GitSidebarToggle.js.map +0 -1
- package/dist/components/mcp/AddMCPServerModal.js +0 -166
- package/dist/components/mcp/AddMCPServerModal.js.map +0 -1
- package/dist/components/mcp/MCPSidebar.js +0 -192
- package/dist/components/mcp/MCPSidebar.js.map +0 -1
- package/dist/components/mcp/MCPSidebarToggle.js +0 -14
- package/dist/components/mcp/MCPSidebarToggle.js.map +0 -1
- package/dist/components/mcp/index.js +0 -4
- package/dist/components/mcp/index.js.map +0 -1
- package/dist/components/messages/AssistantMessageGroup.js +0 -176
- package/dist/components/messages/AssistantMessageGroup.js.map +0 -1
- package/dist/components/messages/MessagePartItem.js +0 -362
- package/dist/components/messages/MessagePartItem.js.map +0 -1
- package/dist/components/messages/MessageThread.js +0 -239
- package/dist/components/messages/MessageThread.js.map +0 -1
- package/dist/components/messages/MessageThreadContainer.js +0 -22
- package/dist/components/messages/MessageThreadContainer.js.map +0 -1
- package/dist/components/messages/ToolApprovalCard.js +0 -143
- package/dist/components/messages/ToolApprovalCard.js.map +0 -1
- package/dist/components/messages/TopupApprovalCard.js +0 -52
- package/dist/components/messages/TopupApprovalCard.js.map +0 -1
- package/dist/components/messages/UserMessageGroup.js +0 -132
- package/dist/components/messages/UserMessageGroup.js.map +0 -1
- package/dist/components/messages/renderers/ApplyPatchRenderer.js +0 -55
- package/dist/components/messages/renderers/ApplyPatchRenderer.js.map +0 -1
- package/dist/components/messages/renderers/BashRenderer.js +0 -55
- package/dist/components/messages/renderers/BashRenderer.js.map +0 -1
- package/dist/components/messages/renderers/DatabaseToolRenderer.js +0 -151
- package/dist/components/messages/renderers/DatabaseToolRenderer.js.map +0 -1
- package/dist/components/messages/renderers/DebugRenderer.js +0 -5
- package/dist/components/messages/renderers/DebugRenderer.js.map +0 -1
- package/dist/components/messages/renderers/DiffView.js +0 -206
- package/dist/components/messages/renderers/DiffView.js.map +0 -1
- package/dist/components/messages/renderers/EditRenderer.js +0 -25
- package/dist/components/messages/renderers/EditRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ErrorRenderer.js +0 -162
- package/dist/components/messages/renderers/ErrorRenderer.js.map +0 -1
- package/dist/components/messages/renderers/FinishRenderer.js +0 -7
- package/dist/components/messages/renderers/FinishRenderer.js.map +0 -1
- package/dist/components/messages/renderers/GenericRenderer.js +0 -50
- package/dist/components/messages/renderers/GenericRenderer.js.map +0 -1
- package/dist/components/messages/renderers/GitCommitRenderer.js +0 -21
- package/dist/components/messages/renderers/GitCommitRenderer.js.map +0 -1
- package/dist/components/messages/renderers/GitDiffRenderer.js +0 -34
- package/dist/components/messages/renderers/GitDiffRenderer.js.map +0 -1
- package/dist/components/messages/renderers/GitStatusRenderer.js +0 -60
- package/dist/components/messages/renderers/GitStatusRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ListRenderer.js +0 -28
- package/dist/components/messages/renderers/ListRenderer.js.map +0 -1
- package/dist/components/messages/renderers/LoadMcpToolsRenderer.js +0 -20
- package/dist/components/messages/renderers/LoadMcpToolsRenderer.js.map +0 -1
- package/dist/components/messages/renderers/McpToolRenderer.js +0 -68
- package/dist/components/messages/renderers/McpToolRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ProgressUpdateRenderer.js +0 -9
- package/dist/components/messages/renderers/ProgressUpdateRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ReadRenderer.js +0 -87
- package/dist/components/messages/renderers/ReadRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ReasoningRenderer.js +0 -34
- package/dist/components/messages/renderers/ReasoningRenderer.js.map +0 -1
- package/dist/components/messages/renderers/SearchRenderer.js +0 -52
- package/dist/components/messages/renderers/SearchRenderer.js.map +0 -1
- package/dist/components/messages/renderers/SkillRenderer.js +0 -36
- package/dist/components/messages/renderers/SkillRenderer.js.map +0 -1
- package/dist/components/messages/renderers/TerminalRenderer.js +0 -84
- package/dist/components/messages/renderers/TerminalRenderer.js.map +0 -1
- package/dist/components/messages/renderers/TodosRenderer.js +0 -15
- package/dist/components/messages/renderers/TodosRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ToolErrorDisplay.js +0 -10
- package/dist/components/messages/renderers/ToolErrorDisplay.js.map +0 -1
- package/dist/components/messages/renderers/TreeRenderer.js +0 -33
- package/dist/components/messages/renderers/TreeRenderer.js.map +0 -1
- package/dist/components/messages/renderers/WebSearchRenderer.js +0 -29
- package/dist/components/messages/renderers/WebSearchRenderer.js.map +0 -1
- package/dist/components/messages/renderers/WriteRenderer.js +0 -28
- package/dist/components/messages/renderers/WriteRenderer.js.map +0 -1
- package/dist/components/messages/renderers/index.js +0 -129
- package/dist/components/messages/renderers/index.js.map +0 -1
- package/dist/components/messages/renderers/shared/CopyButton.js +0 -27
- package/dist/components/messages/renderers/shared/CopyButton.js.map +0 -1
- package/dist/components/messages/renderers/shared/ImagePreview.js +0 -14
- package/dist/components/messages/renderers/shared/ImagePreview.js.map +0 -1
- package/dist/components/messages/renderers/shared/ToolContentBox.js +0 -9
- package/dist/components/messages/renderers/shared/ToolContentBox.js.map +0 -1
- package/dist/components/messages/renderers/shared/ToolHeader.js +0 -69
- package/dist/components/messages/renderers/shared/ToolHeader.js.map +0 -1
- package/dist/components/messages/renderers/shared/index.js +0 -5
- package/dist/components/messages/renderers/shared/index.js.map +0 -1
- package/dist/components/messages/renderers/types.js +0 -2
- package/dist/components/messages/renderers/types.js.map +0 -1
- package/dist/components/messages/renderers/utils.js +0 -60
- package/dist/components/messages/renderers/utils.js.map +0 -1
- package/dist/components/onboarding/OnboardingModal.js +0 -22
- package/dist/components/onboarding/OnboardingModal.js.map +0 -1
- package/dist/components/onboarding/index.js +0 -4
- package/dist/components/onboarding/index.js.map +0 -1
- package/dist/components/onboarding/steps/DefaultsStep.js +0 -104
- package/dist/components/onboarding/steps/DefaultsStep.js.map +0 -1
- package/dist/components/onboarding/steps/ProviderSetupStep.js +0 -398
- package/dist/components/onboarding/steps/ProviderSetupStep.js.map +0 -1
- package/dist/components/research/ResearchSidebar.js +0 -288
- package/dist/components/research/ResearchSidebar.js.map +0 -1
- package/dist/components/research/ResearchSidebarToggle.js +0 -15
- package/dist/components/research/ResearchSidebarToggle.js.map +0 -1
- package/dist/components/research/index.js +0 -3
- package/dist/components/research/index.js.map +0 -1
- package/dist/components/session-files/SessionFilesDiffPanel.js +0 -345
- package/dist/components/session-files/SessionFilesDiffPanel.js.map +0 -1
- package/dist/components/session-files/SessionFilesSidebar.js +0 -87
- package/dist/components/session-files/SessionFilesSidebar.js.map +0 -1
- package/dist/components/session-files/SessionFilesSidebarToggle.js +0 -15
- package/dist/components/session-files/SessionFilesSidebarToggle.js.map +0 -1
- package/dist/components/session-files/index.js +0 -4
- package/dist/components/session-files/index.js.map +0 -1
- package/dist/components/sessions/EditableTitle.js +0 -40
- package/dist/components/sessions/EditableTitle.js.map +0 -1
- package/dist/components/sessions/LeanHeader.js +0 -70
- package/dist/components/sessions/LeanHeader.js.map +0 -1
- package/dist/components/sessions/SessionHeader.js +0 -75
- package/dist/components/sessions/SessionHeader.js.map +0 -1
- package/dist/components/sessions/SessionItem.js +0 -28
- package/dist/components/sessions/SessionItem.js.map +0 -1
- package/dist/components/sessions/SessionListContainer.js +0 -86
- package/dist/components/sessions/SessionListContainer.js.map +0 -1
- package/dist/components/settings/SettingsSidebar.js +0 -212
- package/dist/components/settings/SettingsSidebar.js.map +0 -1
- package/dist/components/settings/SettingsSidebarToggle.js +0 -12
- package/dist/components/settings/SettingsSidebarToggle.js.map +0 -1
- package/dist/components/settings/SetuTopupModal.js +0 -306
- package/dist/components/settings/SetuTopupModal.js.map +0 -1
- package/dist/components/skills/SkillViewerPanel.js +0 -89
- package/dist/components/skills/SkillViewerPanel.js.map +0 -1
- package/dist/components/skills/SkillsSidebar.js +0 -59
- package/dist/components/skills/SkillsSidebar.js.map +0 -1
- package/dist/components/skills/SkillsSidebarToggle.js +0 -12
- package/dist/components/skills/SkillsSidebarToggle.js.map +0 -1
- package/dist/components/skills/index.js +0 -4
- package/dist/components/skills/index.js.map +0 -1
- package/dist/components/terminals/TerminalPanelToggle.js +0 -13
- package/dist/components/terminals/TerminalPanelToggle.js.map +0 -1
- package/dist/components/terminals/TerminalTabBar.js +0 -22
- package/dist/components/terminals/TerminalTabBar.js.map +0 -1
- package/dist/components/terminals/TerminalViewer.js +0 -371
- package/dist/components/terminals/TerminalViewer.js.map +0 -1
- package/dist/components/terminals/TerminalsPanel.js +0 -134
- package/dist/components/terminals/TerminalsPanel.js.map +0 -1
- package/dist/components/terminals/index.js +0 -11
- package/dist/components/terminals/index.js.map +0 -1
- package/dist/components/tunnel/TunnelSidebar.js +0 -55
- package/dist/components/tunnel/TunnelSidebar.js.map +0 -1
- package/dist/components/tunnel/TunnelSidebarToggle.js +0 -14
- package/dist/components/tunnel/TunnelSidebarToggle.js.map +0 -1
- package/dist/components/tunnel/index.js +0 -3
- package/dist/components/tunnel/index.js.map +0 -1
- package/dist/components/ui/Button.js +0 -19
- package/dist/components/ui/Button.js.map +0 -1
- package/dist/components/ui/Card.js +0 -7
- package/dist/components/ui/Card.js.map +0 -1
- package/dist/components/ui/ConfirmationDialog.js +0 -72
- package/dist/components/ui/ConfirmationDialog.js.map +0 -1
- package/dist/components/ui/Input.js +0 -7
- package/dist/components/ui/Input.js.map +0 -1
- package/dist/components/ui/Modal.js +0 -51
- package/dist/components/ui/Modal.js.map +0 -1
- package/dist/components/ui/ResizeHandle.js +0 -39
- package/dist/components/ui/ResizeHandle.js.map +0 -1
- package/dist/components/ui/Textarea.js +0 -7
- package/dist/components/ui/Textarea.js.map +0 -1
- package/dist/components/ui/Toaster.js +0 -41
- package/dist/components/ui/Toaster.js.map +0 -1
- package/dist/components/ui/ToolApprovalDialog.js +0 -57
- package/dist/components/ui/ToolApprovalDialog.js.map +0 -1
- package/dist/hooks/useAuthStatus.js +0 -287
- package/dist/hooks/useAuthStatus.js.map +0 -1
- package/dist/hooks/useBranch.js +0 -44
- package/dist/hooks/useBranch.js.map +0 -1
- package/dist/hooks/useCommandSuggestions.js +0 -86
- package/dist/hooks/useCommandSuggestions.js.map +0 -1
- package/dist/hooks/useConfig.js +0 -32
- package/dist/hooks/useConfig.js.map +0 -1
- package/dist/hooks/useFileBrowser.js +0 -30
- package/dist/hooks/useFileBrowser.js.map +0 -1
- package/dist/hooks/useFileMention.js +0 -56
- package/dist/hooks/useFileMention.js.map +0 -1
- package/dist/hooks/useFileUpload.js +0 -317
- package/dist/hooks/useFileUpload.js.map +0 -1
- package/dist/hooks/useFiles.js +0 -15
- package/dist/hooks/useFiles.js.map +0 -1
- package/dist/hooks/useGit.js +0 -149
- package/dist/hooks/useGit.js.map +0 -1
- package/dist/hooks/useImageUpload.js +0 -197
- package/dist/hooks/useImageUpload.js.map +0 -1
- package/dist/hooks/useKeyboardShortcuts.js +0 -249
- package/dist/hooks/useKeyboardShortcuts.js.map +0 -1
- package/dist/hooks/useMCP.js +0 -202
- package/dist/hooks/useMCP.js.map +0 -1
- package/dist/hooks/useMessages.js +0 -26
- package/dist/hooks/useMessages.js.map +0 -1
- package/dist/hooks/usePreferences.js +0 -61
- package/dist/hooks/usePreferences.js.map +0 -1
- package/dist/hooks/useProviderUsage.js +0 -44
- package/dist/hooks/useProviderUsage.js.map +0 -1
- package/dist/hooks/useQueueState.js +0 -31
- package/dist/hooks/useQueueState.js.map +0 -1
- package/dist/hooks/useResearch.js +0 -139
- package/dist/hooks/useResearch.js.map +0 -1
- package/dist/hooks/useSessionFiles.js +0 -15
- package/dist/hooks/useSessionFiles.js.map +0 -1
- package/dist/hooks/useSessionStream.js +0 -572
- package/dist/hooks/useSessionStream.js.map +0 -1
- package/dist/hooks/useSessions.js +0 -83
- package/dist/hooks/useSessions.js.map +0 -1
- package/dist/hooks/useSetuBalance.js +0 -71
- package/dist/hooks/useSetuBalance.js.map +0 -1
- package/dist/hooks/useSetuPayments.js +0 -171
- package/dist/hooks/useSetuPayments.js.map +0 -1
- package/dist/hooks/useShareStatus.js +0 -12
- package/dist/hooks/useShareStatus.js.map +0 -1
- package/dist/hooks/useSkills.js +0 -54
- package/dist/hooks/useSkills.js.map +0 -1
- package/dist/hooks/useTerminals.js +0 -67
- package/dist/hooks/useTerminals.js.map +0 -1
- package/dist/hooks/useTheme.js +0 -57
- package/dist/hooks/useTheme.js.map +0 -1
- package/dist/hooks/useToolApprovalShortcuts.js +0 -88
- package/dist/hooks/useToolApprovalShortcuts.js.map +0 -1
- package/dist/hooks/useTopupCallback.js +0 -74
- package/dist/hooks/useTopupCallback.js.map +0 -1
- package/dist/hooks/useTunnel.js +0 -158
- package/dist/hooks/useTunnel.js.map +0 -1
- package/dist/hooks/useVimMode.js +0 -298
- package/dist/hooks/useVimMode.js.map +0 -1
- package/dist/hooks/useWorkingDirectory.js +0 -34
- package/dist/hooks/useWorkingDirectory.js.map +0 -1
- package/dist/lib/api-client/approval.js +0 -25
- package/dist/lib/api-client/approval.js.map +0 -1
- package/dist/lib/api-client/auth.js +0 -139
- package/dist/lib/api-client/auth.js.map +0 -1
- package/dist/lib/api-client/branches.js +0 -45
- package/dist/lib/api-client/branches.js.map +0 -1
- package/dist/lib/api-client/config.js +0 -38
- package/dist/lib/api-client/config.js.map +0 -1
- package/dist/lib/api-client/files.js +0 -35
- package/dist/lib/api-client/files.js.map +0 -1
- package/dist/lib/api-client/git.js +0 -154
- package/dist/lib/api-client/git.js.map +0 -1
- package/dist/lib/api-client/index.js +0 -92
- package/dist/lib/api-client/index.js.map +0 -1
- package/dist/lib/api-client/sessions.js +0 -106
- package/dist/lib/api-client/sessions.js.map +0 -1
- package/dist/lib/api-client/setu.js +0 -144
- package/dist/lib/api-client/setu.js.map +0 -1
- package/dist/lib/api-client/skills.js +0 -31
- package/dist/lib/api-client/skills.js.map +0 -1
- package/dist/lib/api-client/utils.js +0 -65
- package/dist/lib/api-client/utils.js.map +0 -1
- package/dist/lib/commands.js +0 -124
- package/dist/lib/commands.js.map +0 -1
- package/dist/lib/config.js +0 -28
- package/dist/lib/config.js.map +0 -1
- package/dist/lib/nerd-font.js +0 -55
- package/dist/lib/nerd-font.js.map +0 -1
- package/dist/lib/open-url.js +0 -9
- package/dist/lib/open-url.js.map +0 -1
- package/dist/lib/parseResearchContext.js +0 -30
- package/dist/lib/parseResearchContext.js.map +0 -1
- package/dist/lib/sse-client.js +0 -113
- package/dist/lib/sse-client.js.map +0 -1
- package/dist/stores/confirmationStore.js +0 -27
- package/dist/stores/confirmationStore.js.map +0 -1
- package/dist/stores/fileBrowserStore.js +0 -63
- package/dist/stores/fileBrowserStore.js.map +0 -1
- package/dist/stores/filePickerStore.js +0 -8
- package/dist/stores/filePickerStore.js.map +0 -1
- package/dist/stores/focusStore.js +0 -12
- package/dist/stores/focusStore.js.map +0 -1
- package/dist/stores/gitStore.js +0 -63
- package/dist/stores/gitStore.js.map +0 -1
- package/dist/stores/mcpStore.js +0 -63
- package/dist/stores/mcpStore.js.map +0 -1
- package/dist/stores/onboardingStore.js +0 -38
- package/dist/stores/onboardingStore.js.map +0 -1
- package/dist/stores/panelWidthStore.js +0 -12
- package/dist/stores/panelWidthStore.js.map +0 -1
- package/dist/stores/pendingResearchStore.js +0 -38
- package/dist/stores/pendingResearchStore.js.map +0 -1
- package/dist/stores/queueStore.js +0 -11
- package/dist/stores/queueStore.js.map +0 -1
- package/dist/stores/researchStore.js +0 -54
- package/dist/stores/researchStore.js.map +0 -1
- package/dist/stores/sessionFilesStore.js +0 -62
- package/dist/stores/sessionFilesStore.js.map +0 -1
- package/dist/stores/settingsStore.js +0 -29
- package/dist/stores/settingsStore.js.map +0 -1
- package/dist/stores/setuStore.js +0 -29
- package/dist/stores/setuStore.js.map +0 -1
- package/dist/stores/sidebarStore.js +0 -10
- package/dist/stores/sidebarStore.js.map +0 -1
- package/dist/stores/skillsStore.js +0 -46
- package/dist/stores/skillsStore.js.map +0 -1
- package/dist/stores/terminalStore.js +0 -32
- package/dist/stores/terminalStore.js.map +0 -1
- package/dist/stores/toastStore.js +0 -46
- package/dist/stores/toastStore.js.map +0 -1
- package/dist/stores/toolApprovalStore.js +0 -16
- package/dist/stores/toolApprovalStore.js.map +0 -1
- package/dist/stores/topupApprovalStore.js +0 -11
- package/dist/stores/topupApprovalStore.js.map +0 -1
- package/dist/stores/tunnelStore.js +0 -55
- package/dist/stores/tunnelStore.js.map +0 -1
- package/dist/stores/usageStore.js +0 -14
- package/dist/stores/usageStore.js.map +0 -1
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
import { useInfiniteQuery, useMutation, useQueryClient, } from '@tanstack/react-query';
|
|
2
|
-
import { useMemo } from 'react';
|
|
3
|
-
import { apiClient } from '../lib/api-client';
|
|
4
|
-
const SESSIONS_PAGE_SIZE = 50;
|
|
5
|
-
export const sessionsQueryKey = ['sessions', 'list'];
|
|
6
|
-
export function useSessionsInfinite() {
|
|
7
|
-
return useInfiniteQuery({
|
|
8
|
-
queryKey: sessionsQueryKey,
|
|
9
|
-
queryFn: ({ pageParam = 0 }) => apiClient.getSessionsPage({
|
|
10
|
-
limit: SESSIONS_PAGE_SIZE,
|
|
11
|
-
offset: pageParam,
|
|
12
|
-
}),
|
|
13
|
-
getNextPageParam: (lastPage) => lastPage.nextOffset ?? undefined,
|
|
14
|
-
initialPageParam: 0,
|
|
15
|
-
staleTime: 30_000,
|
|
16
|
-
refetchInterval: 30_000,
|
|
17
|
-
refetchOnWindowFocus: false,
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
export function useSessions() {
|
|
21
|
-
const query = useSessionsInfinite();
|
|
22
|
-
const data = useMemo(() => {
|
|
23
|
-
if (!query.data?.pages)
|
|
24
|
-
return [];
|
|
25
|
-
return query.data.pages.flatMap((p) => p.items ?? []);
|
|
26
|
-
}, [query.data]);
|
|
27
|
-
return {
|
|
28
|
-
data,
|
|
29
|
-
isLoading: query.isLoading,
|
|
30
|
-
isError: query.isError,
|
|
31
|
-
error: query.error,
|
|
32
|
-
hasNextPage: query.hasNextPage,
|
|
33
|
-
fetchNextPage: query.fetchNextPage,
|
|
34
|
-
isFetchingNextPage: query.isFetchingNextPage,
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
export function useSession(sessionId) {
|
|
38
|
-
const { data: sessions } = useSessions();
|
|
39
|
-
return sessions?.find((s) => s.id === sessionId);
|
|
40
|
-
}
|
|
41
|
-
export function useCreateSession() {
|
|
42
|
-
const queryClient = useQueryClient();
|
|
43
|
-
return useMutation({
|
|
44
|
-
mutationFn: (data) => apiClient.createSession(data),
|
|
45
|
-
onSuccess: (newSession) => {
|
|
46
|
-
queryClient.setQueryData(sessionsQueryKey, (old) => {
|
|
47
|
-
if (!old)
|
|
48
|
-
return old;
|
|
49
|
-
const firstPage = old.pages[0];
|
|
50
|
-
if (!firstPage)
|
|
51
|
-
return old;
|
|
52
|
-
return {
|
|
53
|
-
...old,
|
|
54
|
-
pages: [
|
|
55
|
-
{ ...firstPage, items: [newSession, ...firstPage.items] },
|
|
56
|
-
...old.pages.slice(1),
|
|
57
|
-
],
|
|
58
|
-
};
|
|
59
|
-
});
|
|
60
|
-
queryClient.invalidateQueries({ queryKey: sessionsQueryKey });
|
|
61
|
-
},
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
export function useUpdateSession(sessionId) {
|
|
65
|
-
const queryClient = useQueryClient();
|
|
66
|
-
return useMutation({
|
|
67
|
-
mutationFn: (data) => apiClient.updateSession(sessionId, data),
|
|
68
|
-
onSuccess: async () => {
|
|
69
|
-
await queryClient.invalidateQueries({ queryKey: sessionsQueryKey });
|
|
70
|
-
await queryClient.invalidateQueries({ queryKey: ['session', sessionId] });
|
|
71
|
-
},
|
|
72
|
-
});
|
|
73
|
-
}
|
|
74
|
-
export function useDeleteSession() {
|
|
75
|
-
const queryClient = useQueryClient();
|
|
76
|
-
return useMutation({
|
|
77
|
-
mutationFn: (sessionId) => apiClient.deleteSession(sessionId),
|
|
78
|
-
onSuccess: () => {
|
|
79
|
-
queryClient.invalidateQueries({ queryKey: sessionsQueryKey });
|
|
80
|
-
},
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
//# sourceMappingURL=useSessions.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useSessions.js","sourceRoot":"","sources":["../../src/hooks/useSessions.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import { useEffect, useCallback } from 'react';
|
|
2
|
-
import { apiClient } from '../lib/api-client';
|
|
3
|
-
import { useSetuStore } from '../stores/setuStore';
|
|
4
|
-
export function useSetuBalance(providerName) {
|
|
5
|
-
const setBalance = useSetuStore((s) => s.setBalance);
|
|
6
|
-
const setUsdcBalance = useSetuStore((s) => s.setUsdcBalance);
|
|
7
|
-
const setWalletAddress = useSetuStore((s) => s.setWalletAddress);
|
|
8
|
-
const setLoading = useSetuStore((s) => s.setLoading);
|
|
9
|
-
const setScope = useSetuStore((s) => s.setScope);
|
|
10
|
-
const setPayg = useSetuStore((s) => s.setPayg);
|
|
11
|
-
const setSubscription = useSetuStore((s) => s.setSubscription);
|
|
12
|
-
const setLimits = useSetuStore((s) => s.setLimits);
|
|
13
|
-
const balance = useSetuStore((s) => s.balance);
|
|
14
|
-
const usdcBalance = useSetuStore((s) => s.usdcBalance);
|
|
15
|
-
const network = useSetuStore((s) => s.network);
|
|
16
|
-
const fetchBalance = useCallback(async () => {
|
|
17
|
-
if (providerName !== 'setu') {
|
|
18
|
-
return;
|
|
19
|
-
}
|
|
20
|
-
setLoading(true);
|
|
21
|
-
try {
|
|
22
|
-
const [setuData, usdcData, walletData] = await Promise.all([
|
|
23
|
-
apiClient.getSetuBalance(),
|
|
24
|
-
apiClient.getSetuUsdcBalance(network),
|
|
25
|
-
apiClient.getSetuWallet(),
|
|
26
|
-
]);
|
|
27
|
-
if (setuData) {
|
|
28
|
-
setBalance(setuData.balance);
|
|
29
|
-
setWalletAddress(setuData.walletAddress);
|
|
30
|
-
setScope(setuData.scope ?? null);
|
|
31
|
-
setPayg(setuData.payg ?? null);
|
|
32
|
-
setSubscription(setuData.subscription ?? null);
|
|
33
|
-
setLimits(setuData.limits ?? null);
|
|
34
|
-
}
|
|
35
|
-
else if (walletData?.configured && walletData.publicKey) {
|
|
36
|
-
setWalletAddress(walletData.publicKey);
|
|
37
|
-
}
|
|
38
|
-
if (usdcData) {
|
|
39
|
-
setUsdcBalance(usdcData.usdcBalance);
|
|
40
|
-
if (!setuData && usdcData.walletAddress) {
|
|
41
|
-
setWalletAddress(usdcData.walletAddress);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
catch {
|
|
46
|
-
}
|
|
47
|
-
finally {
|
|
48
|
-
setLoading(false);
|
|
49
|
-
}
|
|
50
|
-
}, [
|
|
51
|
-
providerName,
|
|
52
|
-
network,
|
|
53
|
-
setBalance,
|
|
54
|
-
setUsdcBalance,
|
|
55
|
-
setWalletAddress,
|
|
56
|
-
setLoading,
|
|
57
|
-
setScope,
|
|
58
|
-
setPayg,
|
|
59
|
-
setSubscription,
|
|
60
|
-
setLimits,
|
|
61
|
-
]);
|
|
62
|
-
useEffect(() => {
|
|
63
|
-
if (providerName === 'setu' && (balance === null || usdcBalance === null)) {
|
|
64
|
-
fetchBalance();
|
|
65
|
-
}
|
|
66
|
-
}, [providerName, balance, usdcBalance, fetchBalance]);
|
|
67
|
-
return {
|
|
68
|
-
fetchBalance,
|
|
69
|
-
};
|
|
70
|
-
}
|
|
71
|
-
//# sourceMappingURL=useSetuBalance.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useSetuBalance.js","sourceRoot":"","sources":["../../src/hooks/useSetuBalance.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,MAAM,UAAU,cAAc,CAAC,YAAgC;IAC9D,MAAM,UAAU,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;IACrD,MAAM,cAAc,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC;IAC7D,MAAM,gBAAgB,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC;IACjE,MAAM,UAAU,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;IACrD,MAAM,QAAQ,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IACjD,MAAM,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;IAC/C,MAAM,eAAe,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;IAC/D,MAAM,SAAS,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IACnD,MAAM,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;IAC/C,MAAM,WAAW,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;IACvD,MAAM,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;IAE/C,MAAM,YAAY,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QAC3C,IAAI,YAAY,KAAK,MAAM,EAAE,CAAC;YAC7B,OAAO;QACR,CAAC;QAED,UAAU,CAAC,IAAI,CAAC,CAAC;QACjB,IAAI,CAAC;YACJ,MAAM,CAAC,QAAQ,EAAE,QAAQ,EAAE,UAAU,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;gBAC1D,SAAS,CAAC,cAAc,EAAE;gBAC1B,SAAS,CAAC,kBAAkB,CAAC,OAAO,CAAC;gBACrC,SAAS,CAAC,aAAa,EAAE;aACzB,CAAC,CAAC;YAEH,IAAI,QAAQ,EAAE,CAAC;gBACd,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;gBAC7B,gBAAgB,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;gBACzC,QAAQ,CAAC,QAAQ,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC;gBACjC,OAAO,CAAC,QAAQ,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC;gBAC/B,eAAe,CAAC,QAAQ,CAAC,YAAY,IAAI,IAAI,CAAC,CAAC;gBAC/C,SAAS,CAAC,QAAQ,CAAC,MAAM,IAAI,IAAI,CAAC,CAAC;YACpC,CAAC;iBAAM,IAAI,UAAU,EAAE,UAAU,IAAI,UAAU,CAAC,SAAS,EAAE,CAAC;gBAC3D,gBAAgB,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;YACxC,CAAC;YAED,IAAI,QAAQ,EAAE,CAAC;gBACd,cAAc,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;gBACrC,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,aAAa,EAAE,CAAC;oBACzC,gBAAgB,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;gBAC1C,CAAC;YACF,CAAC;QACF,CAAC;QAAC,MAAM,CAAC;QACT,CAAC;gBAAS,CAAC;YACV,UAAU,CAAC,KAAK,CAAC,CAAC;QACnB,CAAC;IACF,CAAC,EAAE;QACF,YAAY;QACZ,OAAO;QACP,UAAU;QACV,cAAc;QACd,gBAAgB;QAChB,UAAU;QACV,QAAQ;QACR,OAAO;QACP,eAAe;QACf,SAAS;KACT,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACd,IAAI,YAAY,KAAK,MAAM,IAAI,CAAC,OAAO,KAAK,IAAI,IAAI,WAAW,KAAK,IAAI,CAAC,EAAE,CAAC;YAC3E,YAAY,EAAE,CAAC;QAChB,CAAC;IACF,CAAC,EAAE,CAAC,YAAY,EAAE,OAAO,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC,CAAC;IAEvD,OAAO;QACN,YAAY;KACZ,CAAC;AACH,CAAC"}
|
|
@@ -1,171 +0,0 @@
|
|
|
1
|
-
import { useEffect, useRef } from 'react';
|
|
2
|
-
import { SSEClient } from '../lib/sse-client';
|
|
3
|
-
import { apiClient } from '../lib/api-client';
|
|
4
|
-
import { toast, useToastStore } from '../stores/toastStore';
|
|
5
|
-
import { useSetuStore } from '../stores/setuStore';
|
|
6
|
-
import { useTopupApprovalStore } from '../stores/topupApprovalStore';
|
|
7
|
-
export function useSetuPayments(sessionId) {
|
|
8
|
-
const clientRef = useRef(null);
|
|
9
|
-
const loadingToastIdRef = useRef(null);
|
|
10
|
-
const setBalance = useSetuStore((s) => s.setBalance);
|
|
11
|
-
const setPaymentPending = useSetuStore((s) => s.setPaymentPending);
|
|
12
|
-
const removeToast = useToastStore((s) => s.removeToast);
|
|
13
|
-
const updateToast = useToastStore((s) => s.updateToast);
|
|
14
|
-
const setPendingTopup = useTopupApprovalStore((s) => s.setPendingTopup);
|
|
15
|
-
const clearPendingTopup = useTopupApprovalStore((s) => s.clearPendingTopup);
|
|
16
|
-
useEffect(() => {
|
|
17
|
-
if (!sessionId)
|
|
18
|
-
return;
|
|
19
|
-
const client = new SSEClient();
|
|
20
|
-
clientRef.current = client;
|
|
21
|
-
const url = apiClient.getStreamUrl(sessionId);
|
|
22
|
-
client.connect(url);
|
|
23
|
-
const unsubscribe = client.on('*', (event) => {
|
|
24
|
-
const payload = event.payload;
|
|
25
|
-
switch (event.type) {
|
|
26
|
-
case 'setu.topup.required': {
|
|
27
|
-
const amountUsd = typeof payload?.amountUsd === 'number' ? payload.amountUsd : 0;
|
|
28
|
-
const currentBalance = typeof payload?.currentBalance === 'number'
|
|
29
|
-
? payload.currentBalance
|
|
30
|
-
: 0;
|
|
31
|
-
const minTopupUsd = typeof payload?.minTopupUsd === 'number' ? payload.minTopupUsd : 5;
|
|
32
|
-
const suggestedTopupUsd = typeof payload?.suggestedTopupUsd === 'number'
|
|
33
|
-
? payload.suggestedTopupUsd
|
|
34
|
-
: 10;
|
|
35
|
-
const messageId = typeof payload?.messageId === 'string' ? payload.messageId : '';
|
|
36
|
-
setPendingTopup({
|
|
37
|
-
sessionId,
|
|
38
|
-
messageId,
|
|
39
|
-
amountUsd,
|
|
40
|
-
currentBalance,
|
|
41
|
-
minTopupUsd,
|
|
42
|
-
suggestedTopupUsd,
|
|
43
|
-
});
|
|
44
|
-
break;
|
|
45
|
-
}
|
|
46
|
-
case 'setu.topup.method_selected': {
|
|
47
|
-
const method = payload?.method;
|
|
48
|
-
if (method === 'crypto') {
|
|
49
|
-
setPaymentPending(true);
|
|
50
|
-
loadingToastIdRef.current = toast.loading('💳 Processing crypto payment...');
|
|
51
|
-
}
|
|
52
|
-
break;
|
|
53
|
-
}
|
|
54
|
-
case 'setu.topup.cancelled': {
|
|
55
|
-
clearPendingTopup();
|
|
56
|
-
const reason = typeof payload?.reason === 'string'
|
|
57
|
-
? payload.reason
|
|
58
|
-
: 'Request cancelled';
|
|
59
|
-
toast(`⚠️ ${reason}`);
|
|
60
|
-
break;
|
|
61
|
-
}
|
|
62
|
-
case 'setu.payment.required': {
|
|
63
|
-
const amountUsd = typeof payload?.amountUsd === 'number' ? payload.amountUsd : 0;
|
|
64
|
-
setPaymentPending(true);
|
|
65
|
-
if (!loadingToastIdRef.current) {
|
|
66
|
-
loadingToastIdRef.current = toast.loading(`💳 Payment required: $${amountUsd.toFixed(2)}`);
|
|
67
|
-
}
|
|
68
|
-
break;
|
|
69
|
-
}
|
|
70
|
-
case 'setu.payment.signing': {
|
|
71
|
-
if (loadingToastIdRef.current) {
|
|
72
|
-
updateToast(loadingToastIdRef.current, {
|
|
73
|
-
message: '✍️ Signing transaction...',
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
loadingToastIdRef.current = toast.loading('✍️ Signing transaction...');
|
|
78
|
-
}
|
|
79
|
-
break;
|
|
80
|
-
}
|
|
81
|
-
case 'setu.payment.complete': {
|
|
82
|
-
clearPendingTopup();
|
|
83
|
-
const rawAmount = payload?.amountUsd;
|
|
84
|
-
const rawBalance = payload?.newBalance;
|
|
85
|
-
const transactionId = typeof payload?.transactionId === 'string'
|
|
86
|
-
? payload.transactionId
|
|
87
|
-
: undefined;
|
|
88
|
-
const amountUsd = typeof rawAmount === 'number'
|
|
89
|
-
? rawAmount
|
|
90
|
-
: typeof rawAmount === 'string'
|
|
91
|
-
? parseFloat(rawAmount)
|
|
92
|
-
: 0;
|
|
93
|
-
const newBalance = typeof rawBalance === 'number'
|
|
94
|
-
? rawBalance
|
|
95
|
-
: typeof rawBalance === 'string'
|
|
96
|
-
? parseFloat(rawBalance)
|
|
97
|
-
: 0;
|
|
98
|
-
setBalance(newBalance);
|
|
99
|
-
setPaymentPending(false);
|
|
100
|
-
if (loadingToastIdRef.current) {
|
|
101
|
-
removeToast(loadingToastIdRef.current);
|
|
102
|
-
loadingToastIdRef.current = null;
|
|
103
|
-
}
|
|
104
|
-
const message = `✅ Paid $${amountUsd.toFixed(2)}`;
|
|
105
|
-
if (transactionId) {
|
|
106
|
-
toast.successWithAction(message, {
|
|
107
|
-
label: 'View Tx',
|
|
108
|
-
href: `https://orbmarkets.io/tx/${transactionId}`,
|
|
109
|
-
});
|
|
110
|
-
}
|
|
111
|
-
else {
|
|
112
|
-
toast.success(message);
|
|
113
|
-
}
|
|
114
|
-
break;
|
|
115
|
-
}
|
|
116
|
-
case 'setu.fiat.checkout_created': {
|
|
117
|
-
clearPendingTopup();
|
|
118
|
-
setPaymentPending(false);
|
|
119
|
-
if (loadingToastIdRef.current) {
|
|
120
|
-
removeToast(loadingToastIdRef.current);
|
|
121
|
-
loadingToastIdRef.current = null;
|
|
122
|
-
}
|
|
123
|
-
// Modal is already opened by TopupApprovalCard
|
|
124
|
-
// Just show a helpful toast
|
|
125
|
-
toast.success('💳 Complete payment, then retry your message');
|
|
126
|
-
break;
|
|
127
|
-
}
|
|
128
|
-
case 'setu.balance.updated': {
|
|
129
|
-
const rawBalance = payload?.balanceRemaining;
|
|
130
|
-
const newBalance = typeof rawBalance === 'number'
|
|
131
|
-
? rawBalance
|
|
132
|
-
: typeof rawBalance === 'string'
|
|
133
|
-
? parseFloat(rawBalance)
|
|
134
|
-
: null;
|
|
135
|
-
if (newBalance !== null && !Number.isNaN(newBalance)) {
|
|
136
|
-
setBalance(newBalance);
|
|
137
|
-
}
|
|
138
|
-
break;
|
|
139
|
-
}
|
|
140
|
-
case 'setu.payment.error': {
|
|
141
|
-
clearPendingTopup();
|
|
142
|
-
const error = typeof payload?.error === 'string'
|
|
143
|
-
? payload.error
|
|
144
|
-
: 'Payment failed';
|
|
145
|
-
setPaymentPending(false);
|
|
146
|
-
if (loadingToastIdRef.current) {
|
|
147
|
-
removeToast(loadingToastIdRef.current);
|
|
148
|
-
loadingToastIdRef.current = null;
|
|
149
|
-
}
|
|
150
|
-
toast.error(`❌ ${error}`);
|
|
151
|
-
break;
|
|
152
|
-
}
|
|
153
|
-
default:
|
|
154
|
-
break;
|
|
155
|
-
}
|
|
156
|
-
});
|
|
157
|
-
return () => {
|
|
158
|
-
unsubscribe();
|
|
159
|
-
client.disconnect();
|
|
160
|
-
};
|
|
161
|
-
}, [
|
|
162
|
-
sessionId,
|
|
163
|
-
setBalance,
|
|
164
|
-
setPaymentPending,
|
|
165
|
-
removeToast,
|
|
166
|
-
updateToast,
|
|
167
|
-
setPendingTopup,
|
|
168
|
-
clearPendingTopup,
|
|
169
|
-
]);
|
|
170
|
-
}
|
|
171
|
-
//# sourceMappingURL=useSetuPayments.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useSetuPayments.js","sourceRoot":"","sources":["../../src/hooks/useSetuPayments.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { useQuery } from '@tanstack/react-query';
|
|
2
|
-
import { apiClient } from '../lib/api-client';
|
|
3
|
-
export function useShareStatus(sessionId) {
|
|
4
|
-
const { data, isLoading, error } = useQuery({
|
|
5
|
-
queryKey: ['share-status', sessionId],
|
|
6
|
-
queryFn: () => apiClient.getShareStatus(sessionId),
|
|
7
|
-
enabled: !!sessionId,
|
|
8
|
-
staleTime: 30000,
|
|
9
|
-
});
|
|
10
|
-
return { data, isLoading, error: error };
|
|
11
|
-
}
|
|
12
|
-
//# sourceMappingURL=useShareStatus.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useShareStatus.js","sourceRoot":"","sources":["../../src/hooks/useShareStatus.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAG9C,MAAM,UAAU,cAAc,CAAC,SAA6B;IAK3D,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,QAAQ,CAAC;QAC3C,QAAQ,EAAE,CAAC,cAAc,EAAE,SAAS,CAAC;QACrC,OAAO,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,cAAc,CAAC,SAAmB,CAAC;QAC5D,OAAO,EAAE,CAAC,CAAC,SAAS;QACpB,SAAS,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,KAAqB,EAAE,CAAC;AAC1D,CAAC"}
|
package/dist/hooks/useSkills.js
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import { useQuery } from '@tanstack/react-query';
|
|
2
|
-
import { useSkillsStore } from '../stores/skillsStore';
|
|
3
|
-
import { useEffect } from 'react';
|
|
4
|
-
import { apiClient } from '../lib/api-client';
|
|
5
|
-
export function useSkills() {
|
|
6
|
-
const setSkills = useSkillsStore((s) => s.setSkills);
|
|
7
|
-
const query = useQuery({
|
|
8
|
-
queryKey: ['skills'],
|
|
9
|
-
queryFn: async () => {
|
|
10
|
-
return apiClient.listSkills();
|
|
11
|
-
},
|
|
12
|
-
refetchInterval: 30000,
|
|
13
|
-
});
|
|
14
|
-
useEffect(() => {
|
|
15
|
-
if (query.data?.skills) {
|
|
16
|
-
setSkills(query.data.skills);
|
|
17
|
-
}
|
|
18
|
-
}, [query.data, setSkills]);
|
|
19
|
-
return query;
|
|
20
|
-
}
|
|
21
|
-
export function useSkillDetail(name) {
|
|
22
|
-
return useQuery({
|
|
23
|
-
queryKey: ['skills', name],
|
|
24
|
-
queryFn: async () => {
|
|
25
|
-
if (!name)
|
|
26
|
-
return null;
|
|
27
|
-
return apiClient.getSkill(name);
|
|
28
|
-
},
|
|
29
|
-
enabled: !!name,
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
export function useSkillFiles(name) {
|
|
33
|
-
return useQuery({
|
|
34
|
-
queryKey: ['skills', name, 'files'],
|
|
35
|
-
queryFn: async () => {
|
|
36
|
-
if (!name)
|
|
37
|
-
return null;
|
|
38
|
-
return apiClient.getSkillFiles(name);
|
|
39
|
-
},
|
|
40
|
-
enabled: !!name,
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
export function useSkillFileContent(name, filePath) {
|
|
44
|
-
return useQuery({
|
|
45
|
-
queryKey: ['skills', name, 'files', filePath],
|
|
46
|
-
queryFn: async () => {
|
|
47
|
-
if (!name || !filePath)
|
|
48
|
-
return null;
|
|
49
|
-
return apiClient.getSkillFileContent(name, filePath);
|
|
50
|
-
},
|
|
51
|
-
enabled: !!name && !!filePath,
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
//# sourceMappingURL=useSkills.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useSkills.js","sourceRoot":"","sources":["../../src/hooks/useSkills.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAClC,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE9C,MAAM,UAAU,SAAS;IACxB,MAAM,SAAS,GAAG,cAAc,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAErD,MAAM,KAAK,GAAG,QAAQ,CAAC;QACtB,QAAQ,EAAE,CAAC,QAAQ,CAAC;QACpB,OAAO,EAAE,KAAK,IAAI,EAAE;YACnB,OAAO,SAAS,CAAC,UAAU,EAAE,CAAC;QAC/B,CAAC;QACD,eAAe,EAAE,KAAK;KACtB,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACd,IAAI,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC;YACxB,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9B,CAAC;IACF,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC;IAE5B,OAAO,KAAK,CAAC;AACd,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,IAAmB;IACjD,OAAO,QAAQ,CAAC;QACf,QAAQ,EAAE,CAAC,QAAQ,EAAE,IAAI,CAAC;QAC1B,OAAO,EAAE,KAAK,IAAI,EAAE;YACnB,IAAI,CAAC,IAAI;gBAAE,OAAO,IAAI,CAAC;YACvB,OAAO,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACjC,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,IAAI;KACf,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,IAAmB;IAChD,OAAO,QAAQ,CAAC;QACf,QAAQ,EAAE,CAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,CAAC;QACnC,OAAO,EAAE,KAAK,IAAI,EAAE;YACnB,IAAI,CAAC,IAAI;gBAAE,OAAO,IAAI,CAAC;YACvB,OAAO,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QACtC,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,IAAI;KACf,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,mBAAmB,CAClC,IAAmB,EACnB,QAAuB;IAEvB,OAAO,QAAQ,CAAC;QACf,QAAQ,EAAE,CAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,CAAC;QAC7C,OAAO,EAAE,KAAK,IAAI,EAAE;YACnB,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ;gBAAE,OAAO,IAAI,CAAC;YACpC,OAAO,SAAS,CAAC,mBAAmB,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QACtD,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,QAAQ;KAC7B,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
import { useQuery, useMutation, useQueryClient } from '@tanstack/react-query';
|
|
2
|
-
import { getTerminals, postTerminals, deleteTerminalsById, getTerminalsById, } from '@ottocode/api';
|
|
3
|
-
export function useTerminals() {
|
|
4
|
-
return useQuery({
|
|
5
|
-
queryKey: ['terminals'],
|
|
6
|
-
queryFn: async () => {
|
|
7
|
-
const response = await getTerminals();
|
|
8
|
-
if (response.error) {
|
|
9
|
-
throw new Error('Failed to fetch terminals');
|
|
10
|
-
}
|
|
11
|
-
return response.data;
|
|
12
|
-
},
|
|
13
|
-
refetchInterval: 2000,
|
|
14
|
-
});
|
|
15
|
-
}
|
|
16
|
-
export function useCreateTerminal() {
|
|
17
|
-
const queryClient = useQueryClient();
|
|
18
|
-
return useMutation({
|
|
19
|
-
mutationFn: async (params) => {
|
|
20
|
-
const response = await postTerminals({
|
|
21
|
-
body: params,
|
|
22
|
-
});
|
|
23
|
-
if (response.error) {
|
|
24
|
-
throw new Error('Failed to create terminal');
|
|
25
|
-
}
|
|
26
|
-
return response.data;
|
|
27
|
-
},
|
|
28
|
-
onSuccess: async () => {
|
|
29
|
-
await queryClient.invalidateQueries({ queryKey: ['terminals'] });
|
|
30
|
-
},
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
export function useKillTerminal() {
|
|
34
|
-
const queryClient = useQueryClient();
|
|
35
|
-
return useMutation({
|
|
36
|
-
mutationFn: async (terminalId) => {
|
|
37
|
-
const response = await deleteTerminalsById({
|
|
38
|
-
path: { id: terminalId },
|
|
39
|
-
});
|
|
40
|
-
if (response.error) {
|
|
41
|
-
throw new Error('Failed to kill terminal');
|
|
42
|
-
}
|
|
43
|
-
},
|
|
44
|
-
onSuccess: () => {
|
|
45
|
-
queryClient.invalidateQueries({ queryKey: ['terminals'] });
|
|
46
|
-
},
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
export function useTerminalOutput(terminalId) {
|
|
50
|
-
return useQuery({
|
|
51
|
-
queryKey: ['terminal', terminalId],
|
|
52
|
-
queryFn: async () => {
|
|
53
|
-
if (!terminalId)
|
|
54
|
-
throw new Error('No terminal ID');
|
|
55
|
-
const response = await getTerminalsById({
|
|
56
|
-
path: { id: terminalId },
|
|
57
|
-
});
|
|
58
|
-
if (response.error) {
|
|
59
|
-
throw new Error('Failed to fetch terminal');
|
|
60
|
-
}
|
|
61
|
-
return response.data?.terminal;
|
|
62
|
-
},
|
|
63
|
-
enabled: !!terminalId,
|
|
64
|
-
refetchInterval: 1000,
|
|
65
|
-
});
|
|
66
|
-
}
|
|
67
|
-
//# sourceMappingURL=useTerminals.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useTerminals.js","sourceRoot":"","sources":["../../src/hooks/useTerminals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC9E,OAAO,EACN,YAAY,EACZ,aAAa,EACb,mBAAmB,EACnB,gBAAgB,GAChB,MAAM,eAAe,CAAC;AAqCvB,MAAM,UAAU,YAAY;IAC3B,OAAO,QAAQ,CAAoB;QAClC,QAAQ,EAAE,CAAC,WAAW,CAAC;QACvB,OAAO,EAAE,KAAK,IAAI,EAAE;YACnB,MAAM,QAAQ,GAAG,MAAM,YAAY,EAAE,CAAC;YACtC,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;gBACpB,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;YAC9C,CAAC;YACD,OAAO,QAAQ,CAAC,IAAyB,CAAC;QAC3C,CAAC;QACD,eAAe,EAAE,IAAI;KACrB,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,iBAAiB;IAChC,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IAErC,OAAO,WAAW,CAAsD;QACvE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;YAC5B,MAAM,QAAQ,GAAG,MAAM,aAAa,CAAC;gBACpC,IAAI,EAAE,MAAM;aACZ,CAAC,CAAC;YAEH,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;gBACpB,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;YAC9C,CAAC;YAED,OAAO,QAAQ,CAAC,IAA8B,CAAC;QAChD,CAAC;QACD,SAAS,EAAE,KAAK,IAAI,EAAE;YACrB,MAAM,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QAClE,CAAC;KACD,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,eAAe;IAC9B,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IAErC,OAAO,WAAW,CAAsB;QACvC,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE;YAChC,MAAM,QAAQ,GAAG,MAAM,mBAAmB,CAAC;gBAC1C,IAAI,EAAE,EAAE,EAAE,EAAE,UAAU,EAAE;aACxB,CAAC,CAAC;YAEH,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;gBACpB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;YAC5C,CAAC;QACF,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACf,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QAC5D,CAAC;KACD,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,UAAyB;IAC1D,OAAO,QAAQ,CAAW;QACzB,QAAQ,EAAE,CAAC,UAAU,EAAE,UAAU,CAAC;QAClC,OAAO,EAAE,KAAK,IAAI,EAAE;YACnB,IAAI,CAAC,UAAU;gBAAE,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAC;YAEnD,MAAM,QAAQ,GAAG,MAAM,gBAAgB,CAAC;gBACvC,IAAI,EAAE,EAAE,EAAE,EAAE,UAAU,EAAE;aACxB,CAAC,CAAC;YACH,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;gBACpB,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;YAC7C,CAAC;YACD,OAAO,QAAQ,CAAC,IAAI,EAAE,QAAoB,CAAC;QAC5C,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,UAAU;QACrB,eAAe,EAAE,IAAI;KACrB,CAAC,CAAC;AACJ,CAAC"}
|
package/dist/hooks/useTheme.js
DELETED
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { useEffect, useState, useCallback, useMemo } from 'react';
|
|
2
|
-
const STORAGE_KEY = 'otto-theme';
|
|
3
|
-
function resolveInitialTheme() {
|
|
4
|
-
if (typeof window === 'undefined') {
|
|
5
|
-
return 'dark';
|
|
6
|
-
}
|
|
7
|
-
const stored = window.localStorage.getItem(STORAGE_KEY);
|
|
8
|
-
if (stored === 'light' || stored === 'dark') {
|
|
9
|
-
return stored;
|
|
10
|
-
}
|
|
11
|
-
if (window.matchMedia?.('(prefers-color-scheme: light)').matches) {
|
|
12
|
-
return 'light';
|
|
13
|
-
}
|
|
14
|
-
return 'dark';
|
|
15
|
-
}
|
|
16
|
-
export function useTheme() {
|
|
17
|
-
const [theme, setTheme] = useState(() => resolveInitialTheme());
|
|
18
|
-
useEffect(() => {
|
|
19
|
-
if (typeof document === 'undefined')
|
|
20
|
-
return;
|
|
21
|
-
const root = document.documentElement;
|
|
22
|
-
if (theme === 'dark') {
|
|
23
|
-
root.classList.add('dark');
|
|
24
|
-
}
|
|
25
|
-
else {
|
|
26
|
-
root.classList.remove('dark');
|
|
27
|
-
}
|
|
28
|
-
try {
|
|
29
|
-
window.localStorage.setItem(STORAGE_KEY, theme);
|
|
30
|
-
}
|
|
31
|
-
catch (error) {
|
|
32
|
-
console.warn('Failed to persist theme preference', error);
|
|
33
|
-
}
|
|
34
|
-
if (window.parent && window.parent !== window) {
|
|
35
|
-
window.parent.postMessage({ type: 'otto-set-theme', theme }, '*');
|
|
36
|
-
}
|
|
37
|
-
}, [theme]);
|
|
38
|
-
useEffect(() => {
|
|
39
|
-
if (typeof window === 'undefined')
|
|
40
|
-
return;
|
|
41
|
-
const handler = (e) => {
|
|
42
|
-
if (e.data?.type === 'otto-set-theme' &&
|
|
43
|
-
(e.data.theme === 'light' || e.data.theme === 'dark')) {
|
|
44
|
-
setTheme(e.data.theme);
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
window.addEventListener('message', handler);
|
|
48
|
-
return () => window.removeEventListener('message', handler);
|
|
49
|
-
}, []);
|
|
50
|
-
// Memoize toggleTheme to prevent creating new function reference on every render
|
|
51
|
-
const toggleTheme = useCallback(() => {
|
|
52
|
-
setTheme((prev) => (prev === 'dark' ? 'light' : 'dark'));
|
|
53
|
-
}, []);
|
|
54
|
-
// Return a stable object reference
|
|
55
|
-
return useMemo(() => ({ theme, setTheme, toggleTheme }), [theme, toggleTheme]);
|
|
56
|
-
}
|
|
57
|
-
//# sourceMappingURL=useTheme.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useTheme.js","sourceRoot":"","sources":["../../src/hooks/useTheme.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
import { useEffect, useCallback } from 'react';
|
|
2
|
-
import { useToolApprovalStore } from '../stores/toolApprovalStore';
|
|
3
|
-
import { apiClient } from '../lib/api-client';
|
|
4
|
-
/**
|
|
5
|
-
* Hook for handling keyboard shortcuts for tool approval.
|
|
6
|
-
* Only responds to shortcuts when there are pending approvals for the given session.
|
|
7
|
-
*
|
|
8
|
-
* Shortcuts:
|
|
9
|
-
* - Y: Approve first pending
|
|
10
|
-
* - N or Escape: Reject first pending
|
|
11
|
-
* - A: Approve all pending
|
|
12
|
-
*/
|
|
13
|
-
export function useToolApprovalShortcuts(sessionId) {
|
|
14
|
-
const { pendingApprovals, removePendingApproval } = useToolApprovalStore();
|
|
15
|
-
// Filter approvals for this session
|
|
16
|
-
// Since approvals are tied to messages, and messages to sessions,
|
|
17
|
-
// we need to check that the pending approval belongs to this session's messages
|
|
18
|
-
const sessionPendingApprovals = pendingApprovals;
|
|
19
|
-
const handleApprove = useCallback(async (callId) => {
|
|
20
|
-
if (!sessionId)
|
|
21
|
-
return;
|
|
22
|
-
try {
|
|
23
|
-
await apiClient.approveToolCall(sessionId, callId, true);
|
|
24
|
-
removePendingApproval(callId);
|
|
25
|
-
}
|
|
26
|
-
catch (error) {
|
|
27
|
-
console.error('Failed to approve tool call:', error);
|
|
28
|
-
}
|
|
29
|
-
}, [sessionId, removePendingApproval]);
|
|
30
|
-
const handleReject = useCallback(async (callId) => {
|
|
31
|
-
if (!sessionId)
|
|
32
|
-
return;
|
|
33
|
-
try {
|
|
34
|
-
await apiClient.approveToolCall(sessionId, callId, false);
|
|
35
|
-
removePendingApproval(callId);
|
|
36
|
-
}
|
|
37
|
-
catch (error) {
|
|
38
|
-
console.error('Failed to reject tool call:', error);
|
|
39
|
-
}
|
|
40
|
-
}, [sessionId, removePendingApproval]);
|
|
41
|
-
const handleApproveAll = useCallback(async () => {
|
|
42
|
-
if (!sessionId)
|
|
43
|
-
return;
|
|
44
|
-
try {
|
|
45
|
-
await Promise.all(sessionPendingApprovals.map((a) => apiClient.approveToolCall(sessionId, a.callId, true)));
|
|
46
|
-
for (const a of sessionPendingApprovals) {
|
|
47
|
-
removePendingApproval(a.callId);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
catch (error) {
|
|
51
|
-
console.error('Failed to approve all tool calls:', error);
|
|
52
|
-
}
|
|
53
|
-
}, [sessionId, sessionPendingApprovals, removePendingApproval]);
|
|
54
|
-
useEffect(() => {
|
|
55
|
-
if (!sessionId || sessionPendingApprovals.length === 0)
|
|
56
|
-
return;
|
|
57
|
-
const handleKeyDown = (e) => {
|
|
58
|
-
// Don't trigger if user is typing in an input/textarea
|
|
59
|
-
if (e.target instanceof HTMLInputElement ||
|
|
60
|
-
e.target instanceof HTMLTextAreaElement ||
|
|
61
|
-
e.target?.isContentEditable) {
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
const firstPending = sessionPendingApprovals[0];
|
|
65
|
-
if (e.key === 'y' || e.key === 'Y') {
|
|
66
|
-
e.preventDefault();
|
|
67
|
-
handleApprove(firstPending.callId);
|
|
68
|
-
}
|
|
69
|
-
else if (e.key === 'n' || e.key === 'N' || e.key === 'Escape') {
|
|
70
|
-
e.preventDefault();
|
|
71
|
-
handleReject(firstPending.callId);
|
|
72
|
-
}
|
|
73
|
-
else if (e.key === 'a' || e.key === 'A') {
|
|
74
|
-
e.preventDefault();
|
|
75
|
-
handleApproveAll();
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
window.addEventListener('keydown', handleKeyDown);
|
|
79
|
-
return () => window.removeEventListener('keydown', handleKeyDown);
|
|
80
|
-
}, [
|
|
81
|
-
sessionId,
|
|
82
|
-
sessionPendingApprovals,
|
|
83
|
-
handleApprove,
|
|
84
|
-
handleReject,
|
|
85
|
-
handleApproveAll,
|
|
86
|
-
]);
|
|
87
|
-
}
|
|
88
|
-
//# sourceMappingURL=useToolApprovalShortcuts.js.map
|