@within-7/minto 0.0.5-dev.1
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/LICENSE +201 -0
- package/README.md +1097 -0
- package/README.zh-CN.md +1097 -0
- package/cli.js +59 -0
- package/dist/Tool.js +1 -0
- package/dist/Tool.js.map +7 -0
- package/dist/commands/agents.js +2086 -0
- package/dist/commands/agents.js.map +7 -0
- package/dist/commands/approvedTools.js +36 -0
- package/dist/commands/approvedTools.js.map +7 -0
- package/dist/commands/bug.js +21 -0
- package/dist/commands/bug.js.map +7 -0
- package/dist/commands/build.js +74 -0
- package/dist/commands/build.js.map +7 -0
- package/dist/commands/clear.js +37 -0
- package/dist/commands/clear.js.map +7 -0
- package/dist/commands/compact.js +82 -0
- package/dist/commands/compact.js.map +7 -0
- package/dist/commands/compression.js +57 -0
- package/dist/commands/compression.js.map +7 -0
- package/dist/commands/config.js +20 -0
- package/dist/commands/config.js.map +7 -0
- package/dist/commands/cost.js +19 -0
- package/dist/commands/cost.js.map +7 -0
- package/dist/commands/ctx_viz.js +152 -0
- package/dist/commands/ctx_viz.js.map +7 -0
- package/dist/commands/doctor.js +25 -0
- package/dist/commands/doctor.js.map +7 -0
- package/dist/commands/help.js +20 -0
- package/dist/commands/help.js.map +7 -0
- package/dist/commands/init.js +38 -0
- package/dist/commands/init.js.map +7 -0
- package/dist/commands/listen.js +37 -0
- package/dist/commands/listen.js.map +7 -0
- package/dist/commands/login.js +37 -0
- package/dist/commands/login.js.map +7 -0
- package/dist/commands/logout.js +33 -0
- package/dist/commands/logout.js.map +7 -0
- package/dist/commands/mcp-interactive.js +267 -0
- package/dist/commands/mcp-interactive.js.map +7 -0
- package/dist/commands/mcp.js +40 -0
- package/dist/commands/mcp.js.map +7 -0
- package/dist/commands/mcp_refresh.js +40 -0
- package/dist/commands/mcp_refresh.js.map +7 -0
- package/dist/commands/model.js +41 -0
- package/dist/commands/model.js.map +7 -0
- package/dist/commands/modelstatus.js +21 -0
- package/dist/commands/modelstatus.js.map +7 -0
- package/dist/commands/onboarding.js +36 -0
- package/dist/commands/onboarding.js.map +7 -0
- package/dist/commands/plugin/AddMarketplaceForm.js +62 -0
- package/dist/commands/plugin/AddMarketplaceForm.js.map +7 -0
- package/dist/commands/plugin/ConfirmDialog.js +71 -0
- package/dist/commands/plugin/ConfirmDialog.js.map +7 -0
- package/dist/commands/plugin/ErrorView.js +33 -0
- package/dist/commands/plugin/ErrorView.js.map +7 -0
- package/dist/commands/plugin/InstalledPluginsByMarketplace.js +135 -0
- package/dist/commands/plugin/InstalledPluginsByMarketplace.js.map +7 -0
- package/dist/commands/plugin/InstalledPluginsManager.js +99 -0
- package/dist/commands/plugin/InstalledPluginsManager.js.map +7 -0
- package/dist/commands/plugin/LoadingView.js +14 -0
- package/dist/commands/plugin/LoadingView.js.map +7 -0
- package/dist/commands/plugin/MainMenu.js +57 -0
- package/dist/commands/plugin/MainMenu.js.map +7 -0
- package/dist/commands/plugin/MarketplaceManager.js +155 -0
- package/dist/commands/plugin/MarketplaceManager.js.map +7 -0
- package/dist/commands/plugin/MarketplaceSelector.js +119 -0
- package/dist/commands/plugin/MarketplaceSelector.js.map +7 -0
- package/dist/commands/plugin/PlaceholderScreen.js +16 -0
- package/dist/commands/plugin/PlaceholderScreen.js.map +7 -0
- package/dist/commands/plugin/PluginBrowser.js +180 -0
- package/dist/commands/plugin/PluginBrowser.js.map +7 -0
- package/dist/commands/plugin/PluginDetailsInstall.js +152 -0
- package/dist/commands/plugin/PluginDetailsInstall.js.map +7 -0
- package/dist/commands/plugin/PluginDetailsManage.js +200 -0
- package/dist/commands/plugin/PluginDetailsManage.js.map +7 -0
- package/dist/commands/plugin/components.js +16 -0
- package/dist/commands/plugin/components.js.map +7 -0
- package/dist/commands/plugin/example-usage.js +63 -0
- package/dist/commands/plugin/example-usage.js.map +7 -0
- package/dist/commands/plugin/types.js +1 -0
- package/dist/commands/plugin/types.js.map +7 -0
- package/dist/commands/plugin/utils.js +77 -0
- package/dist/commands/plugin/utils.js.map +7 -0
- package/dist/commands/plugin-interactive.js +446 -0
- package/dist/commands/plugin-interactive.js.map +7 -0
- package/dist/commands/plugin.js +523 -0
- package/dist/commands/plugin.js.map +7 -0
- package/dist/commands/pr_comments.js +61 -0
- package/dist/commands/pr_comments.js.map +7 -0
- package/dist/commands/quit.js +16 -0
- package/dist/commands/quit.js.map +7 -0
- package/dist/commands/refreshCommands.js +43 -0
- package/dist/commands/refreshCommands.js.map +7 -0
- package/dist/commands/release-notes.js +30 -0
- package/dist/commands/release-notes.js.map +7 -0
- package/dist/commands/resume.js +35 -0
- package/dist/commands/resume.js.map +7 -0
- package/dist/commands/review.js +51 -0
- package/dist/commands/review.js.map +7 -0
- package/dist/commands/terminalSetup.js +164 -0
- package/dist/commands/terminalSetup.js.map +7 -0
- package/dist/commands.js +104 -0
- package/dist/commands.js.map +7 -0
- package/dist/components/AgentResponseBlock.js +41 -0
- package/dist/components/AgentResponseBlock.js.map +7 -0
- package/dist/components/AgentThinkingBlock.js +40 -0
- package/dist/components/AgentThinkingBlock.js.map +7 -0
- package/dist/components/AsciiLogo.js +19 -0
- package/dist/components/AsciiLogo.js.map +7 -0
- package/dist/components/BackgroundTasksPanel.js +124 -0
- package/dist/components/BackgroundTasksPanel.js.map +7 -0
- package/dist/components/Bug.js +147 -0
- package/dist/components/Bug.js.map +7 -0
- package/dist/components/Config.js +166 -0
- package/dist/components/Config.js.map +7 -0
- package/dist/components/ConsoleOAuthFlow.js +178 -0
- package/dist/components/ConsoleOAuthFlow.js.map +7 -0
- package/dist/components/Cost.js +13 -0
- package/dist/components/Cost.js.map +7 -0
- package/dist/components/CostThresholdDialog.js +38 -0
- package/dist/components/CostThresholdDialog.js.map +7 -0
- package/dist/components/CustomSelect/option-map.js +32 -0
- package/dist/components/CustomSelect/option-map.js.map +7 -0
- package/dist/components/CustomSelect/select-option.js +34 -0
- package/dist/components/CustomSelect/select-option.js.map +7 -0
- package/dist/components/CustomSelect/select.js +64 -0
- package/dist/components/CustomSelect/select.js.map +7 -0
- package/dist/components/CustomSelect/theme.js +1 -0
- package/dist/components/CustomSelect/theme.js.map +7 -0
- package/dist/components/CustomSelect/use-select-state.js +220 -0
- package/dist/components/CustomSelect/use-select-state.js.map +7 -0
- package/dist/components/CustomSelect/use-select.js +21 -0
- package/dist/components/CustomSelect/use-select.js.map +7 -0
- package/dist/components/FallbackToolUseRejectedMessage.js +11 -0
- package/dist/components/FallbackToolUseRejectedMessage.js.map +7 -0
- package/dist/components/FileEditToolUpdatedMessage.js +32 -0
- package/dist/components/FileEditToolUpdatedMessage.js.map +7 -0
- package/dist/components/HeaderBar.js +57 -0
- package/dist/components/HeaderBar.js.map +7 -0
- package/dist/components/Help.js +46 -0
- package/dist/components/Help.js.map +7 -0
- package/dist/components/HighlightedCode.js +30 -0
- package/dist/components/HighlightedCode.js.map +7 -0
- package/dist/components/HistorySearchOverlay.js +48 -0
- package/dist/components/HistorySearchOverlay.js.map +7 -0
- package/dist/components/InteractionRoundBlock.js +56 -0
- package/dist/components/InteractionRoundBlock.js.map +7 -0
- package/dist/components/InvalidConfigDialog.js +83 -0
- package/dist/components/InvalidConfigDialog.js.map +7 -0
- package/dist/components/Link.js +18 -0
- package/dist/components/Link.js.map +7 -0
- package/dist/components/LogSelector.js +50 -0
- package/dist/components/LogSelector.js.map +7 -0
- package/dist/components/Logo.js +96 -0
- package/dist/components/Logo.js.map +7 -0
- package/dist/components/MCPServerApprovalDialog.js +79 -0
- package/dist/components/MCPServerApprovalDialog.js.map +7 -0
- package/dist/components/MCPServerDialogCopy.js +11 -0
- package/dist/components/MCPServerDialogCopy.js.map +7 -0
- package/dist/components/MCPServerMultiselectDialog.js +80 -0
- package/dist/components/MCPServerMultiselectDialog.js.map +7 -0
- package/dist/components/Message.js +146 -0
- package/dist/components/Message.js.map +7 -0
- package/dist/components/MessageResponse.js +9 -0
- package/dist/components/MessageResponse.js.map +7 -0
- package/dist/components/MessageSelector.js +125 -0
- package/dist/components/MessageSelector.js.map +7 -0
- package/dist/components/ModeIndicator.js +38 -0
- package/dist/components/ModeIndicator.js.map +7 -0
- package/dist/components/ModelConfig.js +208 -0
- package/dist/components/ModelConfig.js.map +7 -0
- package/dist/components/ModelListManager.js +140 -0
- package/dist/components/ModelListManager.js.map +7 -0
- package/dist/components/ModelSelector.js +2062 -0
- package/dist/components/ModelSelector.js.map +7 -0
- package/dist/components/ModelStatusDisplay.js +87 -0
- package/dist/components/ModelStatusDisplay.js.map +7 -0
- package/dist/components/Onboarding.js +153 -0
- package/dist/components/Onboarding.js.map +7 -0
- package/dist/components/PressEnterToContinue.js +10 -0
- package/dist/components/PressEnterToContinue.js.map +7 -0
- package/dist/components/ProjectOnboarding.js +99 -0
- package/dist/components/ProjectOnboarding.js.map +7 -0
- package/dist/components/PromptInput.js +755 -0
- package/dist/components/PromptInput.js.map +7 -0
- package/dist/components/QuitSummary.js +81 -0
- package/dist/components/QuitSummary.js.map +7 -0
- package/dist/components/SentryErrorBoundary.js +27 -0
- package/dist/components/SentryErrorBoundary.js.map +7 -0
- package/dist/components/Spinner.js +101 -0
- package/dist/components/Spinner.js.map +7 -0
- package/dist/components/SpinnerSymbol.js +78 -0
- package/dist/components/SpinnerSymbol.js.map +7 -0
- package/dist/components/StreamingBashOutput.js +70 -0
- package/dist/components/StreamingBashOutput.js.map +7 -0
- package/dist/components/StructuredDiff.js +148 -0
- package/dist/components/StructuredDiff.js.map +7 -0
- package/dist/components/SubagentBlock.js +157 -0
- package/dist/components/SubagentBlock.js.map +7 -0
- package/dist/components/SubagentManager.js +65 -0
- package/dist/components/SubagentManager.js.map +7 -0
- package/dist/components/SubagentProgress.js +109 -0
- package/dist/components/SubagentProgress.js.map +7 -0
- package/dist/components/SubagentStatusMarker.js +37 -0
- package/dist/components/SubagentStatusMarker.js.map +7 -0
- package/dist/components/TaskCard.js +170 -0
- package/dist/components/TaskCard.js.map +7 -0
- package/dist/components/TextInput.js +100 -0
- package/dist/components/TextInput.js.map +7 -0
- package/dist/components/TimelineRenderer.js +31 -0
- package/dist/components/TimelineRenderer.js.map +7 -0
- package/dist/components/TodoChangeBlock.js +29 -0
- package/dist/components/TodoChangeBlock.js.map +7 -0
- package/dist/components/TodoChangeLine.js +22 -0
- package/dist/components/TodoChangeLine.js.map +7 -0
- package/dist/components/TodoItem.js +35 -0
- package/dist/components/TodoItem.js.map +7 -0
- package/dist/components/TodoPanel.js +55 -0
- package/dist/components/TodoPanel.js.map +7 -0
- package/dist/components/TokenWarning.js +19 -0
- package/dist/components/TokenWarning.js.map +7 -0
- package/dist/components/ToolExecutionBlock.js +18 -0
- package/dist/components/ToolExecutionBlock.js.map +7 -0
- package/dist/components/ToolUseLoader.js +24 -0
- package/dist/components/ToolUseLoader.js.map +7 -0
- package/dist/components/TrustDialog.js +71 -0
- package/dist/components/TrustDialog.js.map +7 -0
- package/dist/components/UserQueryBlock.js +12 -0
- package/dist/components/UserQueryBlock.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedback.js +50 -0
- package/dist/components/binary-feedback/BinaryFeedback.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedbackOption.js +94 -0
- package/dist/components/binary-feedback/BinaryFeedbackOption.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedbackView.js +139 -0
- package/dist/components/binary-feedback/BinaryFeedbackView.js.map +7 -0
- package/dist/components/binary-feedback/utils.js +108 -0
- package/dist/components/binary-feedback/utils.js.map +7 -0
- package/dist/components/messages/AssistantBashOutputMessage.js +23 -0
- package/dist/components/messages/AssistantBashOutputMessage.js.map +7 -0
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js +36 -0
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js.map +7 -0
- package/dist/components/messages/AssistantRedactedThinkingMessage.js +12 -0
- package/dist/components/messages/AssistantRedactedThinkingMessage.js.map +7 -0
- package/dist/components/messages/AssistantTextMessage.js +78 -0
- package/dist/components/messages/AssistantTextMessage.js.map +7 -0
- package/dist/components/messages/AssistantThinkingMessage.js +27 -0
- package/dist/components/messages/AssistantThinkingMessage.js.map +7 -0
- package/dist/components/messages/AssistantToolUseMessage.js +91 -0
- package/dist/components/messages/AssistantToolUseMessage.js.map +7 -0
- package/dist/components/messages/TaskProgressMessage.js +11 -0
- package/dist/components/messages/TaskProgressMessage.js.map +7 -0
- package/dist/components/messages/TaskToolMessage.js +39 -0
- package/dist/components/messages/TaskToolMessage.js.map +7 -0
- package/dist/components/messages/UserBashInputMessage.js +18 -0
- package/dist/components/messages/UserBashInputMessage.js.map +7 -0
- package/dist/components/messages/UserCommandMessage.js +20 -0
- package/dist/components/messages/UserCommandMessage.js.map +7 -0
- package/dist/components/messages/UserKodingInputMessage.js +18 -0
- package/dist/components/messages/UserKodingInputMessage.js.map +7 -0
- package/dist/components/messages/UserPromptMessage.js +20 -0
- package/dist/components/messages/UserPromptMessage.js.map +7 -0
- package/dist/components/messages/UserTextMessage.js +25 -0
- package/dist/components/messages/UserTextMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +10 -0
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js +15 -0
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js +25 -0
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js +47 -0
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +23 -0
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/utils.js +50 -0
- package/dist/components/messages/UserToolResultMessage/utils.js.map +7 -0
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js +112 -0
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FallbackPermissionRequest.js +131 -0
- package/dist/components/permissions/FallbackPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +159 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js +58 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js.map +7 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +153 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +70 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js.map +7 -0
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +212 -0
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js.map +7 -0
- package/dist/components/permissions/PermissionRequest.js +70 -0
- package/dist/components/permissions/PermissionRequest.js.map +7 -0
- package/dist/components/permissions/PermissionRequestTitle.js +52 -0
- package/dist/components/permissions/PermissionRequestTitle.js.map +7 -0
- package/dist/components/permissions/hooks.js +23 -0
- package/dist/components/permissions/hooks.js.map +7 -0
- package/dist/components/permissions/toolUseOptions.js +46 -0
- package/dist/components/permissions/toolUseOptions.js.map +7 -0
- package/dist/components/permissions/utils.js +21 -0
- package/dist/components/permissions/utils.js.map +7 -0
- package/dist/constants/claude-asterisk-ascii-art.js +242 -0
- package/dist/constants/claude-asterisk-ascii-art.js.map +7 -0
- package/dist/constants/colors.js +126 -0
- package/dist/constants/colors.js.map +7 -0
- package/dist/constants/compressionPrompts.js +73 -0
- package/dist/constants/compressionPrompts.js.map +7 -0
- package/dist/constants/figures.js +6 -0
- package/dist/constants/figures.js.map +7 -0
- package/dist/constants/macros.js +11 -0
- package/dist/constants/macros.js.map +7 -0
- package/dist/constants/modelCapabilities.js +154 -0
- package/dist/constants/modelCapabilities.js.map +7 -0
- package/dist/constants/models.js +1034 -0
- package/dist/constants/models.js.map +7 -0
- package/dist/constants/oauth.js +18 -0
- package/dist/constants/oauth.js.map +7 -0
- package/dist/constants/product.js +26 -0
- package/dist/constants/product.js.map +7 -0
- package/dist/constants/prompts.js +168 -0
- package/dist/constants/prompts.js.map +7 -0
- package/dist/constants/releaseNotes.js +9 -0
- package/dist/constants/releaseNotes.js.map +7 -0
- package/dist/constants/symbols.js +50 -0
- package/dist/constants/symbols.js.map +7 -0
- package/dist/context/PermissionContext.js +111 -0
- package/dist/context/PermissionContext.js.map +7 -0
- package/dist/context.js +278 -0
- package/dist/context.js.map +7 -0
- package/dist/cost-tracker.js +76 -0
- package/dist/cost-tracker.js.map +7 -0
- package/dist/entrypoints/cli-wrapper.js +61 -0
- package/dist/entrypoints/cli-wrapper.js.map +7 -0
- package/dist/entrypoints/cli.js +1115 -0
- package/dist/entrypoints/cli.js.map +7 -0
- package/dist/entrypoints/mcp.js +150 -0
- package/dist/entrypoints/mcp.js.map +7 -0
- package/dist/history.js +25 -0
- package/dist/history.js.map +7 -0
- package/dist/hooks/useApiKeyVerification.js +12 -0
- package/dist/hooks/useApiKeyVerification.js.map +7 -0
- package/dist/hooks/useArrowKeyHistory.js +50 -0
- package/dist/hooks/useArrowKeyHistory.js.map +7 -0
- package/dist/hooks/useCanUseTool.js +87 -0
- package/dist/hooks/useCanUseTool.js.map +7 -0
- package/dist/hooks/useCancelRequest.js +28 -0
- package/dist/hooks/useCancelRequest.js.map +7 -0
- package/dist/hooks/useDoublePress.js +31 -0
- package/dist/hooks/useDoublePress.js.map +7 -0
- package/dist/hooks/useExitOnCtrlCD.js +26 -0
- package/dist/hooks/useExitOnCtrlCD.js.map +7 -0
- package/dist/hooks/useHistorySearch.js +62 -0
- package/dist/hooks/useHistorySearch.js.map +7 -0
- package/dist/hooks/useInterval.js +18 -0
- package/dist/hooks/useInterval.js.map +7 -0
- package/dist/hooks/useLogMessages.js +14 -0
- package/dist/hooks/useLogMessages.js.map +7 -0
- package/dist/hooks/useLogStartupTime.js +10 -0
- package/dist/hooks/useLogStartupTime.js.map +7 -0
- package/dist/hooks/useNotifyAfterTimeout.js +42 -0
- package/dist/hooks/useNotifyAfterTimeout.js.map +7 -0
- package/dist/hooks/usePermissionRequestLogging.js +23 -0
- package/dist/hooks/usePermissionRequestLogging.js.map +7 -0
- package/dist/hooks/useTerminalSize.js +38 -0
- package/dist/hooks/useTerminalSize.js.map +7 -0
- package/dist/hooks/useTextInput.js +252 -0
- package/dist/hooks/useTextInput.js.map +7 -0
- package/dist/hooks/useUnifiedCompletion.js +929 -0
- package/dist/hooks/useUnifiedCompletion.js.map +7 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +7 -0
- package/dist/messages.js +33 -0
- package/dist/messages.js.map +7 -0
- package/dist/package.json +4 -0
- package/dist/permissions.js +194 -0
- package/dist/permissions.js.map +7 -0
- package/dist/query.js +499 -0
- package/dist/query.js.map +7 -0
- package/dist/screens/Doctor.js +22 -0
- package/dist/screens/Doctor.js.map +7 -0
- package/dist/screens/LogList.js +55 -0
- package/dist/screens/LogList.js.map +7 -0
- package/dist/screens/REPL.js +671 -0
- package/dist/screens/REPL.js.map +7 -0
- package/dist/screens/ResumeConversation.js +56 -0
- package/dist/screens/ResumeConversation.js.map +7 -0
- package/dist/services/adapters/base.js +29 -0
- package/dist/services/adapters/base.js.map +7 -0
- package/dist/services/adapters/chatCompletions.js +69 -0
- package/dist/services/adapters/chatCompletions.js.map +7 -0
- package/dist/services/adapters/responsesAPI.js +126 -0
- package/dist/services/adapters/responsesAPI.js.map +7 -0
- package/dist/services/claude.js +1573 -0
- package/dist/services/claude.js.map +7 -0
- package/dist/services/compressionService.js +210 -0
- package/dist/services/compressionService.js.map +7 -0
- package/dist/services/customCommands.js +437 -0
- package/dist/services/customCommands.js.map +7 -0
- package/dist/services/fileFreshness.js +275 -0
- package/dist/services/fileFreshness.js.map +7 -0
- package/dist/services/gpt5ConnectionTest.js +248 -0
- package/dist/services/gpt5ConnectionTest.js.map +7 -0
- package/dist/services/hookExecutor.js +276 -0
- package/dist/services/hookExecutor.js.map +7 -0
- package/dist/services/mainAgentCompressor.js +84 -0
- package/dist/services/mainAgentCompressor.js.map +7 -0
- package/dist/services/mcpClient.js +449 -0
- package/dist/services/mcpClient.js.map +7 -0
- package/dist/services/mcpServerApproval.js +55 -0
- package/dist/services/mcpServerApproval.js.map +7 -0
- package/dist/services/mentionProcessor.js +201 -0
- package/dist/services/mentionProcessor.js.map +7 -0
- package/dist/services/modelAdapterFactory.js +47 -0
- package/dist/services/modelAdapterFactory.js.map +7 -0
- package/dist/services/notifier.js +35 -0
- package/dist/services/notifier.js.map +7 -0
- package/dist/services/oauth.js +247 -0
- package/dist/services/oauth.js.map +7 -0
- package/dist/services/openai.js +995 -0
- package/dist/services/openai.js.map +7 -0
- package/dist/services/responseStateManager.js +68 -0
- package/dist/services/responseStateManager.js.map +7 -0
- package/dist/services/sentry.js +9 -0
- package/dist/services/sentry.js.map +7 -0
- package/dist/services/subagentAbortManager.js +95 -0
- package/dist/services/subagentAbortManager.js.map +7 -0
- package/dist/services/subagentCompressor.js +146 -0
- package/dist/services/subagentCompressor.js.map +7 -0
- package/dist/services/systemReminder.js +335 -0
- package/dist/services/systemReminder.js.map +7 -0
- package/dist/services/vcr.js +133 -0
- package/dist/services/vcr.js.map +7 -0
- package/dist/tools/ArchitectTool/ArchitectTool.js +119 -0
- package/dist/tools/ArchitectTool/ArchitectTool.js.map +7 -0
- package/dist/tools/ArchitectTool/prompt.js +18 -0
- package/dist/tools/ArchitectTool/prompt.js.map +7 -0
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js +423 -0
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js.map +7 -0
- package/dist/tools/BashOutputTool/BashOutputTool.js +120 -0
- package/dist/tools/BashOutputTool/BashOutputTool.js.map +7 -0
- package/dist/tools/BashOutputTool/BashOutputToolResultMessage.js +11 -0
- package/dist/tools/BashOutputTool/BashOutputToolResultMessage.js.map +7 -0
- package/dist/tools/BashOutputTool/prompt.js +13 -0
- package/dist/tools/BashOutputTool/prompt.js.map +7 -0
- package/dist/tools/BashTool/BashTool.js +209 -0
- package/dist/tools/BashTool/BashTool.js.map +7 -0
- package/dist/tools/BashTool/BashToolResultMessage.js +21 -0
- package/dist/tools/BashTool/BashToolResultMessage.js.map +7 -0
- package/dist/tools/BashTool/OutputLine.js +30 -0
- package/dist/tools/BashTool/OutputLine.js.map +7 -0
- package/dist/tools/BashTool/prompt.js +180 -0
- package/dist/tools/BashTool/prompt.js.map +7 -0
- package/dist/tools/BashTool/utils.js +51 -0
- package/dist/tools/BashTool/utils.js.map +7 -0
- package/dist/tools/FileEditTool/FileEditTool.js +226 -0
- package/dist/tools/FileEditTool/FileEditTool.js.map +7 -0
- package/dist/tools/FileEditTool/prompt.js +54 -0
- package/dist/tools/FileEditTool/prompt.js.map +7 -0
- package/dist/tools/FileEditTool/utils.js +42 -0
- package/dist/tools/FileEditTool/utils.js.map +7 -0
- package/dist/tools/FileReadTool/FileReadTool.js +272 -0
- package/dist/tools/FileReadTool/FileReadTool.js.map +7 -0
- package/dist/tools/FileReadTool/prompt.js +10 -0
- package/dist/tools/FileReadTool/prompt.js.map +7 -0
- package/dist/tools/FileWriteTool/FileWriteTool.js +202 -0
- package/dist/tools/FileWriteTool/FileWriteTool.js.map +7 -0
- package/dist/tools/FileWriteTool/prompt.js +14 -0
- package/dist/tools/FileWriteTool/prompt.js.map +7 -0
- package/dist/tools/GlobTool/GlobTool.js +88 -0
- package/dist/tools/GlobTool/GlobTool.js.map +7 -0
- package/dist/tools/GlobTool/prompt.js +12 -0
- package/dist/tools/GlobTool/prompt.js.map +7 -0
- package/dist/tools/GrepTool/GrepTool.js +107 -0
- package/dist/tools/GrepTool/GrepTool.js.map +7 -0
- package/dist/tools/GrepTool/prompt.js +15 -0
- package/dist/tools/GrepTool/prompt.js.map +7 -0
- package/dist/tools/KillShellTool/KillShellTool.js +92 -0
- package/dist/tools/KillShellTool/KillShellTool.js.map +7 -0
- package/dist/tools/KillShellTool/KillShellToolResultMessage.js +11 -0
- package/dist/tools/KillShellTool/KillShellToolResultMessage.js.map +7 -0
- package/dist/tools/KillShellTool/prompt.js +12 -0
- package/dist/tools/KillShellTool/prompt.js.map +7 -0
- package/dist/tools/MCPTool/MCPTool.js +90 -0
- package/dist/tools/MCPTool/MCPTool.js.map +7 -0
- package/dist/tools/MCPTool/prompt.js +7 -0
- package/dist/tools/MCPTool/prompt.js.map +7 -0
- package/dist/tools/MemoryReadTool/MemoryReadTool.js +103 -0
- package/dist/tools/MemoryReadTool/MemoryReadTool.js.map +7 -0
- package/dist/tools/MemoryReadTool/prompt.js +7 -0
- package/dist/tools/MemoryReadTool/prompt.js.map +7 -0
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js +77 -0
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js.map +7 -0
- package/dist/tools/MemoryWriteTool/prompt.js +7 -0
- package/dist/tools/MemoryWriteTool/prompt.js.map +7 -0
- package/dist/tools/MultiEditTool/MultiEditTool.js +301 -0
- package/dist/tools/MultiEditTool/MultiEditTool.js.map +7 -0
- package/dist/tools/MultiEditTool/prompt.js +48 -0
- package/dist/tools/MultiEditTool/prompt.js.map +7 -0
- package/dist/tools/NotebookEditTool/NotebookEditTool.js +238 -0
- package/dist/tools/NotebookEditTool/NotebookEditTool.js.map +7 -0
- package/dist/tools/NotebookEditTool/prompt.js +7 -0
- package/dist/tools/NotebookEditTool/prompt.js.map +7 -0
- package/dist/tools/NotebookReadTool/NotebookReadTool.js +212 -0
- package/dist/tools/NotebookReadTool/NotebookReadTool.js.map +7 -0
- package/dist/tools/NotebookReadTool/prompt.js +7 -0
- package/dist/tools/NotebookReadTool/prompt.js.map +7 -0
- package/dist/tools/SkillTool/SkillTool.js +209 -0
- package/dist/tools/SkillTool/SkillTool.js.map +7 -0
- package/dist/tools/SkillTool/prompt.js +81 -0
- package/dist/tools/SkillTool/prompt.js.map +7 -0
- package/dist/tools/TaskTool/TaskTool.js +381 -0
- package/dist/tools/TaskTool/TaskTool.js.map +7 -0
- package/dist/tools/TaskTool/constants.js +5 -0
- package/dist/tools/TaskTool/constants.js.map +7 -0
- package/dist/tools/TaskTool/prompt.js +111 -0
- package/dist/tools/TaskTool/prompt.js.map +7 -0
- package/dist/tools/ThinkTool/ThinkTool.js +40 -0
- package/dist/tools/ThinkTool/ThinkTool.js.map +7 -0
- package/dist/tools/ThinkTool/prompt.js +16 -0
- package/dist/tools/ThinkTool/prompt.js.map +7 -0
- package/dist/tools/TodoWriteTool/TodoWriteTool.js +243 -0
- package/dist/tools/TodoWriteTool/TodoWriteTool.js.map +7 -0
- package/dist/tools/TodoWriteTool/prompt.js +66 -0
- package/dist/tools/TodoWriteTool/prompt.js.map +7 -0
- package/dist/tools/URLFetcherTool/URLFetcherTool.js +137 -0
- package/dist/tools/URLFetcherTool/URLFetcherTool.js.map +7 -0
- package/dist/tools/URLFetcherTool/cache.js +45 -0
- package/dist/tools/URLFetcherTool/cache.js.map +7 -0
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js +42 -0
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js.map +7 -0
- package/dist/tools/URLFetcherTool/prompt.js +22 -0
- package/dist/tools/URLFetcherTool/prompt.js.map +7 -0
- package/dist/tools/WebSearchTool/WebSearchTool.js +86 -0
- package/dist/tools/WebSearchTool/WebSearchTool.js.map +7 -0
- package/dist/tools/WebSearchTool/prompt.js +17 -0
- package/dist/tools/WebSearchTool/prompt.js.map +7 -0
- package/dist/tools/WebSearchTool/searchProviders.js +48 -0
- package/dist/tools/WebSearchTool/searchProviders.js.map +7 -0
- package/dist/tools/lsTool/lsTool.js +201 -0
- package/dist/tools/lsTool/lsTool.js.map +7 -0
- package/dist/tools/lsTool/prompt.js +5 -0
- package/dist/tools/lsTool/prompt.js.map +7 -0
- package/dist/tools.js +70 -0
- package/dist/tools.js.map +7 -0
- package/dist/types/PermissionMode.js +82 -0
- package/dist/types/PermissionMode.js.map +7 -0
- package/dist/types/RequestContext.js +47 -0
- package/dist/types/RequestContext.js.map +7 -0
- package/dist/types/common.d.js +1 -0
- package/dist/types/common.d.js.map +7 -0
- package/dist/types/conversation.js +1 -0
- package/dist/types/conversation.js.map +7 -0
- package/dist/types/hooks.js +38 -0
- package/dist/types/hooks.js.map +7 -0
- package/dist/types/interactionRound.js +1 -0
- package/dist/types/interactionRound.js.map +7 -0
- package/dist/types/logs.js +1 -0
- package/dist/types/logs.js.map +7 -0
- package/dist/types/marketplace.js +101 -0
- package/dist/types/marketplace.js.map +7 -0
- package/dist/types/modelCapabilities.js +1 -0
- package/dist/types/modelCapabilities.js.map +7 -0
- package/dist/types/notebook.js +1 -0
- package/dist/types/notebook.js.map +7 -0
- package/dist/types/plugin.js +83 -0
- package/dist/types/plugin.js.map +7 -0
- package/dist/types/subagent.js +1 -0
- package/dist/types/subagent.js.map +7 -0
- package/dist/utils/BackgroundShellManager.js +215 -0
- package/dist/utils/BackgroundShellManager.js.map +7 -0
- package/dist/utils/Cursor.js +315 -0
- package/dist/utils/Cursor.js.map +7 -0
- package/dist/utils/PersistentShell.js +371 -0
- package/dist/utils/PersistentShell.js.map +7 -0
- package/dist/utils/advancedFuzzyMatcher.js +206 -0
- package/dist/utils/advancedFuzzyMatcher.js.map +7 -0
- package/dist/utils/agentLoader.js +244 -0
- package/dist/utils/agentLoader.js.map +7 -0
- package/dist/utils/agentStorage.js +59 -0
- package/dist/utils/agentStorage.js.map +7 -0
- package/dist/utils/array.js +7 -0
- package/dist/utils/array.js.map +7 -0
- package/dist/utils/ask.js +77 -0
- package/dist/utils/ask.js.map +7 -0
- package/dist/utils/auth.js +11 -0
- package/dist/utils/auth.js.map +7 -0
- package/dist/utils/autoCompactCore.js +126 -0
- package/dist/utils/autoCompactCore.js.map +7 -0
- package/dist/utils/autoUpdater.js +107 -0
- package/dist/utils/autoUpdater.js.map +7 -0
- package/dist/utils/browser.js +15 -0
- package/dist/utils/browser.js.map +7 -0
- package/dist/utils/cleanup.js +54 -0
- package/dist/utils/cleanup.js.map +7 -0
- package/dist/utils/commands.js +207 -0
- package/dist/utils/commands.js.map +7 -0
- package/dist/utils/commonUnixCommands.js +687 -0
- package/dist/utils/commonUnixCommands.js.map +7 -0
- package/dist/utils/compressionMode.js +47 -0
- package/dist/utils/compressionMode.js.map +7 -0
- package/dist/utils/config.js +651 -0
- package/dist/utils/config.js.map +7 -0
- package/dist/utils/conversationRecovery.js +35 -0
- package/dist/utils/conversationRecovery.js.map +7 -0
- package/dist/utils/debugLogger.js +889 -0
- package/dist/utils/debugLogger.js.map +7 -0
- package/dist/utils/diff.js +32 -0
- package/dist/utils/diff.js.map +7 -0
- package/dist/utils/env.js +44 -0
- package/dist/utils/env.js.map +7 -0
- package/dist/utils/errors.js +23 -0
- package/dist/utils/errors.js.map +7 -0
- package/dist/utils/execFileNoThrow.js +44 -0
- package/dist/utils/execFileNoThrow.js.map +7 -0
- package/dist/utils/expertChatStorage.js +78 -0
- package/dist/utils/expertChatStorage.js.map +7 -0
- package/dist/utils/file.js +282 -0
- package/dist/utils/file.js.map +7 -0
- package/dist/utils/fileRecoveryCore.js +41 -0
- package/dist/utils/fileRecoveryCore.js.map +7 -0
- package/dist/utils/format.js +41 -0
- package/dist/utils/format.js.map +7 -0
- package/dist/utils/fuzzyMatcher.js +252 -0
- package/dist/utils/fuzzyMatcher.js.map +7 -0
- package/dist/utils/generators.js +46 -0
- package/dist/utils/generators.js.map +7 -0
- package/dist/utils/git.js +83 -0
- package/dist/utils/git.js.map +7 -0
- package/dist/utils/hookManager.js +238 -0
- package/dist/utils/hookManager.js.map +7 -0
- package/dist/utils/http.js +7 -0
- package/dist/utils/http.js.map +7 -0
- package/dist/utils/imagePaste.js +29 -0
- package/dist/utils/imagePaste.js.map +7 -0
- package/dist/utils/json.js +16 -0
- package/dist/utils/json.js.map +7 -0
- package/dist/utils/log.js +329 -0
- package/dist/utils/log.js.map +7 -0
- package/dist/utils/markdown.js +187 -0
- package/dist/utils/markdown.js.map +7 -0
- package/dist/utils/marketplaceManager.js +474 -0
- package/dist/utils/marketplaceManager.js.map +7 -0
- package/dist/utils/messageContextManager.js +195 -0
- package/dist/utils/messageContextManager.js.map +7 -0
- package/dist/utils/messages.js +650 -0
- package/dist/utils/messages.js.map +7 -0
- package/dist/utils/model.js +677 -0
- package/dist/utils/model.js.map +7 -0
- package/dist/utils/permissions/filesystem.js +80 -0
- package/dist/utils/permissions/filesystem.js.map +7 -0
- package/dist/utils/pluginInstaller.js +491 -0
- package/dist/utils/pluginInstaller.js.map +7 -0
- package/dist/utils/pluginLoader.js +582 -0
- package/dist/utils/pluginLoader.js.map +7 -0
- package/dist/utils/pluginRegistry.js +111 -0
- package/dist/utils/pluginRegistry.js.map +7 -0
- package/dist/utils/pluginValidator.js +774 -0
- package/dist/utils/pluginValidator.js.map +7 -0
- package/dist/utils/ptyCompat.js +125 -0
- package/dist/utils/ptyCompat.js.map +7 -0
- package/dist/utils/replStateMachine.js +145 -0
- package/dist/utils/replStateMachine.js.map +7 -0
- package/dist/utils/ripgrep.js +131 -0
- package/dist/utils/ripgrep.js.map +7 -0
- package/dist/utils/roundConverter.js +262 -0
- package/dist/utils/roundConverter.js.map +7 -0
- package/dist/utils/secureFile.js +483 -0
- package/dist/utils/secureFile.js.map +7 -0
- package/dist/utils/sessionState.js +22 -0
- package/dist/utils/sessionState.js.map +7 -0
- package/dist/utils/skillLoader.js +79 -0
- package/dist/utils/skillLoader.js.map +7 -0
- package/dist/utils/state.js +24 -0
- package/dist/utils/state.js.map +7 -0
- package/dist/utils/style.js +31 -0
- package/dist/utils/style.js.map +7 -0
- package/dist/utils/terminal.js +47 -0
- package/dist/utils/terminal.js.map +7 -0
- package/dist/utils/theme.js +102 -0
- package/dist/utils/theme.js.map +7 -0
- package/dist/utils/thinking.js +59 -0
- package/dist/utils/thinking.js.map +7 -0
- package/dist/utils/todoChangeCalculator.js +64 -0
- package/dist/utils/todoChangeCalculator.js.map +7 -0
- package/dist/utils/todoStorage.js +291 -0
- package/dist/utils/todoStorage.js.map +7 -0
- package/dist/utils/tokens.js +30 -0
- package/dist/utils/tokens.js.map +7 -0
- package/dist/utils/toolExecutionController.js +109 -0
- package/dist/utils/toolExecutionController.js.map +7 -0
- package/dist/utils/unaryLogging.js +6 -0
- package/dist/utils/unaryLogging.js.map +7 -0
- package/dist/utils/user.js +40 -0
- package/dist/utils/user.js.map +7 -0
- package/dist/utils/validate.js +132 -0
- package/dist/utils/validate.js.map +7 -0
- package/dist/version.js +7 -0
- package/dist/version.js.map +7 -0
- package/dist/yoga.wasm +0 -0
- package/package.json +113 -0
- package/scripts/postinstall.js +18 -0
- package/yoga.wasm +0 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/useCancelRequest.ts"],
|
|
4
|
+
"sourcesContent": ["import { useInput } from 'ink'\nimport { ToolUseConfirm } from '@components/permissions/PermissionRequest'\nimport { BinaryFeedbackContext } from '@screens/REPL'\nimport type { SetToolJSXFn } from '@tool'\n\nexport function useCancelRequest(\n setToolJSX: SetToolJSXFn,\n setToolUseConfirm: (toolUseConfirm: ToolUseConfirm | null) => void,\n setBinaryFeedbackContext: (bfContext: BinaryFeedbackContext | null) => void,\n onCancel: () => void,\n isLoading: boolean,\n isMessageSelectorVisible: boolean,\n abortSignal?: AbortSignal,\n) {\n useInput((_, key) => {\n if (!key.escape) {\n return\n }\n if (abortSignal?.aborted) {\n return\n }\n if (!abortSignal) {\n return\n }\n if (!isLoading) {\n return\n }\n if (isMessageSelectorVisible) {\n // Esc closes the message selector\n return\n }\n \n setToolJSX(null)\n setToolUseConfirm(null)\n setBinaryFeedbackContext(null)\n onCancel()\n })\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,gBAAgB;AAKlB,SAAS,iBACd,YACA,mBACA,0BACA,UACA,WACA,0BACA,aACA;AACA,WAAS,CAAC,GAAG,QAAQ;AACnB,QAAI,CAAC,IAAI,QAAQ;AACf;AAAA,IACF;AACA,QAAI,aAAa,SAAS;AACxB;AAAA,IACF;AACA,QAAI,CAAC,aAAa;AAChB;AAAA,IACF;AACA,QAAI,CAAC,WAAW;AACd;AAAA,IACF;AACA,QAAI,0BAA0B;AAE5B;AAAA,IACF;AAEA,eAAW,IAAI;AACf,sBAAkB,IAAI;AACtB,6BAAyB,IAAI;AAC7B,aAAS;AAAA,EACX,CAAC;AACH;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { useRef } from "react";
|
|
2
|
+
const DOUBLE_PRESS_TIMEOUT_MS = 2e3;
|
|
3
|
+
function useDoublePress(setPending, onDoublePress, onFirstPress) {
|
|
4
|
+
const lastPressRef = useRef(0);
|
|
5
|
+
const timeoutRef = useRef();
|
|
6
|
+
return () => {
|
|
7
|
+
const now = Date.now();
|
|
8
|
+
const timeSinceLastPress = now - lastPressRef.current;
|
|
9
|
+
if (timeSinceLastPress <= DOUBLE_PRESS_TIMEOUT_MS && timeoutRef.current) {
|
|
10
|
+
if (timeoutRef.current) {
|
|
11
|
+
clearTimeout(timeoutRef.current);
|
|
12
|
+
timeoutRef.current = void 0;
|
|
13
|
+
}
|
|
14
|
+
onDoublePress();
|
|
15
|
+
setPending(false);
|
|
16
|
+
} else {
|
|
17
|
+
onFirstPress?.();
|
|
18
|
+
setPending(true);
|
|
19
|
+
timeoutRef.current = setTimeout(
|
|
20
|
+
() => setPending(false),
|
|
21
|
+
DOUBLE_PRESS_TIMEOUT_MS
|
|
22
|
+
);
|
|
23
|
+
}
|
|
24
|
+
lastPressRef.current = now;
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
export {
|
|
28
|
+
DOUBLE_PRESS_TIMEOUT_MS,
|
|
29
|
+
useDoublePress
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=useDoublePress.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/useDoublePress.ts"],
|
|
4
|
+
"sourcesContent": ["// Creates a function that calls one function on the first call and another\n// function on the second call within a certain timeout\n\nimport { useRef } from 'react'\n\nexport const DOUBLE_PRESS_TIMEOUT_MS = 2000\n\nexport function useDoublePress(\n setPending: (pending: boolean) => void,\n onDoublePress: () => void,\n onFirstPress?: () => void,\n): () => void {\n const lastPressRef = useRef<number>(0)\n const timeoutRef = useRef<NodeJS.Timeout>()\n\n return () => {\n const now = Date.now()\n const timeSinceLastPress = now - lastPressRef.current\n\n // For this to count as a double-call, be sure to check that\n // timeoutRef.current exists so we don't trigger on triple call\n // (e.g. of Esc to clear the text input)\n if (timeSinceLastPress <= DOUBLE_PRESS_TIMEOUT_MS && timeoutRef.current) {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n timeoutRef.current = undefined\n }\n onDoublePress()\n setPending(false)\n } else {\n onFirstPress?.()\n setPending(true)\n timeoutRef.current = setTimeout(\n () => setPending(false),\n DOUBLE_PRESS_TIMEOUT_MS,\n )\n }\n\n lastPressRef.current = now\n }\n}\n"],
|
|
5
|
+
"mappings": "AAGA,SAAS,cAAc;AAEhB,MAAM,0BAA0B;AAEhC,SAAS,eACd,YACA,eACA,cACY;AACZ,QAAM,eAAe,OAAe,CAAC;AACrC,QAAM,aAAa,OAAuB;AAE1C,SAAO,MAAM;AACX,UAAM,MAAM,KAAK,IAAI;AACrB,UAAM,qBAAqB,MAAM,aAAa;AAK9C,QAAI,sBAAsB,2BAA2B,WAAW,SAAS;AACvE,UAAI,WAAW,SAAS;AACtB,qBAAa,WAAW,OAAO;AAC/B,mBAAW,UAAU;AAAA,MACvB;AACA,oBAAc;AACd,iBAAW,KAAK;AAAA,IAClB,OAAO;AACL,qBAAe;AACf,iBAAW,IAAI;AACf,iBAAW,UAAU;AAAA,QACnB,MAAM,WAAW,KAAK;AAAA,QACtB;AAAA,MACF;AAAA,IACF;AAEA,iBAAa,UAAU;AAAA,EACzB;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { useInput } from "ink";
|
|
2
|
+
import { useDoublePress } from "./useDoublePress.js";
|
|
3
|
+
import { useState } from "react";
|
|
4
|
+
function useExitOnCtrlCD(onExit) {
|
|
5
|
+
const [exitState, setExitState] = useState({
|
|
6
|
+
pending: false,
|
|
7
|
+
keyName: null
|
|
8
|
+
});
|
|
9
|
+
const handleCtrlC = useDoublePress(
|
|
10
|
+
(pending) => setExitState({ pending, keyName: "Ctrl-C" }),
|
|
11
|
+
onExit
|
|
12
|
+
);
|
|
13
|
+
const handleCtrlD = useDoublePress(
|
|
14
|
+
(pending) => setExitState({ pending, keyName: "Ctrl-D" }),
|
|
15
|
+
onExit
|
|
16
|
+
);
|
|
17
|
+
useInput((input, key) => {
|
|
18
|
+
if (key.ctrl && input === "c") handleCtrlC();
|
|
19
|
+
if (key.ctrl && input === "d") handleCtrlD();
|
|
20
|
+
});
|
|
21
|
+
return exitState;
|
|
22
|
+
}
|
|
23
|
+
export {
|
|
24
|
+
useExitOnCtrlCD
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=useExitOnCtrlCD.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/useExitOnCtrlCD.ts"],
|
|
4
|
+
"sourcesContent": ["import { useInput } from 'ink'\nimport { useDoublePress } from './useDoublePress'\nimport { useState } from 'react'\n\ntype ExitState = {\n pending: boolean\n keyName: 'Ctrl-C' | 'Ctrl-D' | null\n}\n\nexport function useExitOnCtrlCD(onExit: () => void): ExitState {\n const [exitState, setExitState] = useState<ExitState>({\n pending: false,\n keyName: null,\n })\n\n const handleCtrlC = useDoublePress(\n pending => setExitState({ pending, keyName: 'Ctrl-C' }),\n onExit,\n )\n const handleCtrlD = useDoublePress(\n pending => setExitState({ pending, keyName: 'Ctrl-D' }),\n onExit,\n )\n\n useInput((input, key) => {\n if (key.ctrl && input === 'c') handleCtrlC()\n if (key.ctrl && input === 'd') handleCtrlD()\n })\n\n return exitState\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,gBAAgB;AACzB,SAAS,sBAAsB;AAC/B,SAAS,gBAAgB;AAOlB,SAAS,gBAAgB,QAA+B;AAC7D,QAAM,CAAC,WAAW,YAAY,IAAI,SAAoB;AAAA,IACpD,SAAS;AAAA,IACT,SAAS;AAAA,EACX,CAAC;AAED,QAAM,cAAc;AAAA,IAClB,aAAW,aAAa,EAAE,SAAS,SAAS,SAAS,CAAC;AAAA,IACtD;AAAA,EACF;AACA,QAAM,cAAc;AAAA,IAClB,aAAW,aAAa,EAAE,SAAS,SAAS,SAAS,CAAC;AAAA,IACtD;AAAA,EACF;AAEA,WAAS,CAAC,OAAO,QAAQ;AACvB,QAAI,IAAI,QAAQ,UAAU,IAAK,aAAY;AAC3C,QAAI,IAAI,QAAQ,UAAU,IAAK,aAAY;AAAA,EAC7C,CAAC;AAED,SAAO;AACT;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { useState, useMemo, useCallback, useEffect } from "react";
|
|
2
|
+
function useHistorySearch(history) {
|
|
3
|
+
const [searchTerm, setSearchTerm] = useState("");
|
|
4
|
+
const [selectedIndex, setSelectedIndex] = useState(0);
|
|
5
|
+
const [isActive, setIsActive] = useState(false);
|
|
6
|
+
const filteredResults = useMemo(() => {
|
|
7
|
+
if (!searchTerm.trim()) {
|
|
8
|
+
return history.map((item, index) => ({ item, index })).reverse();
|
|
9
|
+
}
|
|
10
|
+
const lowerSearch = searchTerm.toLowerCase();
|
|
11
|
+
return history.map((item, index) => ({ item, index })).filter(({ item }) => item.toLowerCase().includes(lowerSearch)).reverse();
|
|
12
|
+
}, [history, searchTerm]);
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
if (filteredResults.length === 0) {
|
|
15
|
+
setSelectedIndex(0);
|
|
16
|
+
} else if (selectedIndex >= filteredResults.length) {
|
|
17
|
+
setSelectedIndex(Math.max(0, filteredResults.length - 1));
|
|
18
|
+
}
|
|
19
|
+
}, [filteredResults, selectedIndex]);
|
|
20
|
+
const moveUp = useCallback(() => {
|
|
21
|
+
setSelectedIndex(
|
|
22
|
+
(prev) => Math.max(0, Math.min(prev + 1, filteredResults.length - 1))
|
|
23
|
+
);
|
|
24
|
+
}, [filteredResults.length]);
|
|
25
|
+
const moveDown = useCallback(() => {
|
|
26
|
+
setSelectedIndex((prev) => Math.max(0, prev - 1));
|
|
27
|
+
}, []);
|
|
28
|
+
const selectedItem = useMemo(() => {
|
|
29
|
+
if (filteredResults.length === 0 || selectedIndex < 0 || selectedIndex >= filteredResults.length) {
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
return filteredResults[selectedIndex]?.item || null;
|
|
33
|
+
}, [filteredResults, selectedIndex]);
|
|
34
|
+
const reset = useCallback(() => {
|
|
35
|
+
setSearchTerm("");
|
|
36
|
+
setSelectedIndex(0);
|
|
37
|
+
setIsActive(false);
|
|
38
|
+
}, []);
|
|
39
|
+
const activate = useCallback(() => {
|
|
40
|
+
setIsActive(true);
|
|
41
|
+
setSearchTerm("");
|
|
42
|
+
setSelectedIndex(0);
|
|
43
|
+
}, []);
|
|
44
|
+
return {
|
|
45
|
+
// State
|
|
46
|
+
searchTerm,
|
|
47
|
+
setSearchTerm,
|
|
48
|
+
selectedIndex,
|
|
49
|
+
isActive,
|
|
50
|
+
filteredResults,
|
|
51
|
+
selectedItem,
|
|
52
|
+
// Actions
|
|
53
|
+
moveUp,
|
|
54
|
+
moveDown,
|
|
55
|
+
reset,
|
|
56
|
+
activate
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
export {
|
|
60
|
+
useHistorySearch
|
|
61
|
+
};
|
|
62
|
+
//# sourceMappingURL=useHistorySearch.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/useHistorySearch.ts"],
|
|
4
|
+
"sourcesContent": ["import { useState, useMemo, useCallback, useEffect } from 'react'\n\nexport type HistorySearchResult = {\n item: string\n index: number\n}\n\nexport function useHistorySearch(history: string[]) {\n const [searchTerm, setSearchTerm] = useState('')\n const [selectedIndex, setSelectedIndex] = useState(0)\n const [isActive, setIsActive] = useState(false)\n\n // Filter history items based on search term (case-insensitive)\n const filteredResults = useMemo<HistorySearchResult[]>(() => {\n if (!searchTerm.trim()) {\n // No search term: show all history (reversed - most recent first)\n return history\n .map((item, index) => ({ item, index }))\n .reverse()\n }\n\n // Search term: filter and reverse\n const lowerSearch = searchTerm.toLowerCase()\n return history\n .map((item, index) => ({ item, index }))\n .filter(({ item }) => item.toLowerCase().includes(lowerSearch))\n .reverse()\n }, [history, searchTerm])\n\n // Reset selected index when search results change\n useEffect(() => {\n if (filteredResults.length === 0) {\n setSelectedIndex(0)\n } else if (selectedIndex >= filteredResults.length) {\n setSelectedIndex(Math.max(0, filteredResults.length - 1))\n }\n }, [filteredResults, selectedIndex])\n\n // Navigate up in the list (towards older items)\n const moveUp = useCallback(() => {\n setSelectedIndex(prev =>\n Math.max(0, Math.min(prev + 1, filteredResults.length - 1)),\n )\n }, [filteredResults.length])\n\n // Navigate down in the list (towards newer items)\n const moveDown = useCallback(() => {\n setSelectedIndex(prev => Math.max(0, prev - 1))\n }, [])\n\n // Get the currently selected item\n const selectedItem = useMemo(() => {\n if (\n filteredResults.length === 0 ||\n selectedIndex < 0 ||\n selectedIndex >= filteredResults.length\n ) {\n return null\n }\n return filteredResults[selectedIndex]?.item || null\n }, [filteredResults, selectedIndex])\n\n // Reset search state\n const reset = useCallback(() => {\n setSearchTerm('')\n setSelectedIndex(0)\n setIsActive(false)\n }, [])\n\n // Activate search mode\n const activate = useCallback(() => {\n setIsActive(true)\n setSearchTerm('')\n setSelectedIndex(0)\n }, [])\n\n return {\n // State\n searchTerm,\n setSearchTerm,\n selectedIndex,\n isActive,\n filteredResults,\n selectedItem,\n\n // Actions\n moveUp,\n moveDown,\n reset,\n activate,\n }\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,UAAU,SAAS,aAAa,iBAAiB;AAOnD,SAAS,iBAAiB,SAAmB;AAClD,QAAM,CAAC,YAAY,aAAa,IAAI,SAAS,EAAE;AAC/C,QAAM,CAAC,eAAe,gBAAgB,IAAI,SAAS,CAAC;AACpD,QAAM,CAAC,UAAU,WAAW,IAAI,SAAS,KAAK;AAG9C,QAAM,kBAAkB,QAA+B,MAAM;AAC3D,QAAI,CAAC,WAAW,KAAK,GAAG;AAEtB,aAAO,QACJ,IAAI,CAAC,MAAM,WAAW,EAAE,MAAM,MAAM,EAAE,EACtC,QAAQ;AAAA,IACb;AAGA,UAAM,cAAc,WAAW,YAAY;AAC3C,WAAO,QACJ,IAAI,CAAC,MAAM,WAAW,EAAE,MAAM,MAAM,EAAE,EACtC,OAAO,CAAC,EAAE,KAAK,MAAM,KAAK,YAAY,EAAE,SAAS,WAAW,CAAC,EAC7D,QAAQ;AAAA,EACb,GAAG,CAAC,SAAS,UAAU,CAAC;AAGxB,YAAU,MAAM;AACd,QAAI,gBAAgB,WAAW,GAAG;AAChC,uBAAiB,CAAC;AAAA,IACpB,WAAW,iBAAiB,gBAAgB,QAAQ;AAClD,uBAAiB,KAAK,IAAI,GAAG,gBAAgB,SAAS,CAAC,CAAC;AAAA,IAC1D;AAAA,EACF,GAAG,CAAC,iBAAiB,aAAa,CAAC;AAGnC,QAAM,SAAS,YAAY,MAAM;AAC/B;AAAA,MAAiB,UACf,KAAK,IAAI,GAAG,KAAK,IAAI,OAAO,GAAG,gBAAgB,SAAS,CAAC,CAAC;AAAA,IAC5D;AAAA,EACF,GAAG,CAAC,gBAAgB,MAAM,CAAC;AAG3B,QAAM,WAAW,YAAY,MAAM;AACjC,qBAAiB,UAAQ,KAAK,IAAI,GAAG,OAAO,CAAC,CAAC;AAAA,EAChD,GAAG,CAAC,CAAC;AAGL,QAAM,eAAe,QAAQ,MAAM;AACjC,QACE,gBAAgB,WAAW,KAC3B,gBAAgB,KAChB,iBAAiB,gBAAgB,QACjC;AACA,aAAO;AAAA,IACT;AACA,WAAO,gBAAgB,aAAa,GAAG,QAAQ;AAAA,EACjD,GAAG,CAAC,iBAAiB,aAAa,CAAC;AAGnC,QAAM,QAAQ,YAAY,MAAM;AAC9B,kBAAc,EAAE;AAChB,qBAAiB,CAAC;AAClB,gBAAY,KAAK;AAAA,EACnB,GAAG,CAAC,CAAC;AAGL,QAAM,WAAW,YAAY,MAAM;AACjC,gBAAY,IAAI;AAChB,kBAAc,EAAE;AAChB,qBAAiB,CAAC;AAAA,EACpB,GAAG,CAAC,CAAC;AAEL,SAAO;AAAA;AAAA,IAEL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA;AAAA,IAGA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { useEffect, useRef } from "react";
|
|
2
|
+
function useInterval(callback, delay) {
|
|
3
|
+
const savedCallback = useRef(callback);
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
savedCallback.current = callback;
|
|
6
|
+
}, [callback]);
|
|
7
|
+
useEffect(() => {
|
|
8
|
+
function tick() {
|
|
9
|
+
savedCallback.current();
|
|
10
|
+
}
|
|
11
|
+
const id = setInterval(tick, delay);
|
|
12
|
+
return () => clearInterval(id);
|
|
13
|
+
}, [delay]);
|
|
14
|
+
}
|
|
15
|
+
export {
|
|
16
|
+
useInterval
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=useInterval.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/useInterval.ts"],
|
|
4
|
+
"sourcesContent": ["import { useEffect, useRef } from 'react'\n\n/**\n * A custom hook that runs a callback at a specified interval.\n * The interval is cleared when the component unmounts.\n * The interval is also cleared and restarted if the delay changes.\n */\nexport function useInterval(callback: () => void, delay: number): void {\n const savedCallback = useRef(callback)\n\n // Remember the latest callback\n useEffect(() => {\n savedCallback.current = callback\n }, [callback])\n\n // Set up the interval\n useEffect(() => {\n function tick() {\n savedCallback.current()\n }\n\n const id = setInterval(tick, delay)\n return () => clearInterval(id)\n }, [delay])\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,WAAW,cAAc;AAO3B,SAAS,YAAY,UAAsB,OAAqB;AACrE,QAAM,gBAAgB,OAAO,QAAQ;AAGrC,YAAU,MAAM;AACd,kBAAc,UAAU;AAAA,EAC1B,GAAG,CAAC,QAAQ,CAAC;AAGb,YAAU,MAAM;AACd,aAAS,OAAO;AACd,oBAAc,QAAQ;AAAA,IACxB;AAEA,UAAM,KAAK,YAAY,MAAM,KAAK;AAClC,WAAO,MAAM,cAAc,EAAE;AAAA,EAC/B,GAAG,CAAC,KAAK,CAAC;AACZ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { useEffect } from "react";
|
|
2
|
+
import { overwriteLog, getMessagesPath } from "../utils/log.js";
|
|
3
|
+
function useLogMessages(messages, messageLogName, forkNumber) {
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
overwriteLog(
|
|
6
|
+
getMessagesPath(messageLogName, forkNumber, 0),
|
|
7
|
+
messages.filter((_) => _.type !== "progress")
|
|
8
|
+
);
|
|
9
|
+
}, [messages, messageLogName, forkNumber]);
|
|
10
|
+
}
|
|
11
|
+
export {
|
|
12
|
+
useLogMessages
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=useLogMessages.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/useLogMessages.ts"],
|
|
4
|
+
"sourcesContent": ["import { useEffect } from 'react'\nimport { type Message } from '@query'\nimport { overwriteLog, getMessagesPath } from '@utils/log'\n\nexport function useLogMessages(\n messages: Message[],\n messageLogName: string,\n forkNumber: number,\n): void {\n useEffect(() => {\n overwriteLog(\n getMessagesPath(messageLogName, forkNumber, 0),\n messages.filter(_ => _.type !== 'progress'),\n )\n }, [messages, messageLogName, forkNumber])\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,iBAAiB;AAE1B,SAAS,cAAc,uBAAuB;AAEvC,SAAS,eACd,UACA,gBACA,YACM;AACN,YAAU,MAAM;AACd;AAAA,MACE,gBAAgB,gBAAgB,YAAY,CAAC;AAAA,MAC7C,SAAS,OAAO,OAAK,EAAE,SAAS,UAAU;AAAA,IAC5C;AAAA,EACF,GAAG,CAAC,UAAU,gBAAgB,UAAU,CAAC;AAC3C;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/useLogStartupTime.ts"],
|
|
4
|
+
"sourcesContent": ["import { useEffect } from 'react'\n \n\nexport function useLogStartupTime(): void {\n useEffect(() => {\n const startupTimeMs = Math.round(process.uptime() * 1000)\n }, [])\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,iBAAiB;AAGnB,SAAS,oBAA0B;AACxC,YAAU,MAAM;AACd,UAAM,gBAAgB,KAAK,MAAM,QAAQ,OAAO,IAAI,GAAI;AAAA,EAC1D,GAAG,CAAC,CAAC;AACP;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { useEffect } from "react";
|
|
2
|
+
import { sendNotification } from "../services/notifier.js";
|
|
3
|
+
import { memoize } from "lodash-es";
|
|
4
|
+
const DEFAULT_INTERACTION_THRESHOLD_MS = 6e3;
|
|
5
|
+
const STATE = {
|
|
6
|
+
lastInteractionTime: Date.now()
|
|
7
|
+
};
|
|
8
|
+
function updateLastInteractionTime() {
|
|
9
|
+
STATE.lastInteractionTime = Date.now();
|
|
10
|
+
}
|
|
11
|
+
function getTimeSinceLastInteraction() {
|
|
12
|
+
return Date.now() - STATE.lastInteractionTime;
|
|
13
|
+
}
|
|
14
|
+
function hasRecentInteraction(threshold) {
|
|
15
|
+
return getTimeSinceLastInteraction() < threshold;
|
|
16
|
+
}
|
|
17
|
+
function shouldNotify(threshold) {
|
|
18
|
+
return process.env.NODE_ENV !== "test" && !hasRecentInteraction(threshold);
|
|
19
|
+
}
|
|
20
|
+
const init = memoize(() => process.stdin.on("data", updateLastInteractionTime));
|
|
21
|
+
function useNotifyAfterTimeout(message, timeout = DEFAULT_INTERACTION_THRESHOLD_MS) {
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
init();
|
|
24
|
+
updateLastInteractionTime();
|
|
25
|
+
}, []);
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
let hasNotified = false;
|
|
28
|
+
const timer = setInterval(() => {
|
|
29
|
+
if (shouldNotify(timeout) && !hasNotified) {
|
|
30
|
+
hasNotified = true;
|
|
31
|
+
sendNotification({
|
|
32
|
+
message
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
}, timeout);
|
|
36
|
+
return () => clearTimeout(timer);
|
|
37
|
+
}, [message, timeout]);
|
|
38
|
+
}
|
|
39
|
+
export {
|
|
40
|
+
useNotifyAfterTimeout
|
|
41
|
+
};
|
|
42
|
+
//# sourceMappingURL=useNotifyAfterTimeout.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/useNotifyAfterTimeout.ts"],
|
|
4
|
+
"sourcesContent": ["import { useEffect } from 'react'\nimport { sendNotification } from '@services/notifier'\nimport { memoize } from 'lodash-es'\n\n// The time threshold in milliseconds for considering an interaction \"recent\" (6 seconds)\nconst DEFAULT_INTERACTION_THRESHOLD_MS = 6000\n\nconst STATE = {\n lastInteractionTime: Date.now(),\n}\n\nfunction updateLastInteractionTime(): void {\n STATE.lastInteractionTime = Date.now()\n}\n\nfunction getTimeSinceLastInteraction(): number {\n return Date.now() - STATE.lastInteractionTime\n}\n\nfunction hasRecentInteraction(threshold: number): boolean {\n return getTimeSinceLastInteraction() < threshold\n}\n\nfunction shouldNotify(threshold: number): boolean {\n return process.env.NODE_ENV !== 'test' && !hasRecentInteraction(threshold)\n}\n\n// Start tracking the time of the user's last interaction with the app\nconst init = memoize(() => process.stdin.on('data', updateLastInteractionTime))\n\n/**\n * Hook that manages desktop notifications after a timeout period.\n *\n * Shows a notification in two cases:\n * 1. Immediately if the app has been idle for longer than the threshold\n * 2. After the specified timeout if the user doesn't interact within that time\n *\n * @param message - The notification message to display\n * @param timeout - The timeout in milliseconds (defaults to 6000ms)\n */\nexport function useNotifyAfterTimeout(\n message: string,\n timeout: number = DEFAULT_INTERACTION_THRESHOLD_MS,\n): void {\n // Reset interaction time when hook is called to make sure that requests\n // that took a long time to complete don't pop up a notification right away\n useEffect(() => {\n init()\n updateLastInteractionTime()\n }, [])\n\n useEffect(() => {\n let hasNotified = false\n const timer = setInterval(() => {\n if (shouldNotify(timeout) && !hasNotified) {\n hasNotified = true\n sendNotification({\n message,\n })\n }\n }, timeout)\n\n return () => clearTimeout(timer)\n }, [message, timeout])\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,iBAAiB;AAC1B,SAAS,wBAAwB;AACjC,SAAS,eAAe;AAGxB,MAAM,mCAAmC;AAEzC,MAAM,QAAQ;AAAA,EACZ,qBAAqB,KAAK,IAAI;AAChC;AAEA,SAAS,4BAAkC;AACzC,QAAM,sBAAsB,KAAK,IAAI;AACvC;AAEA,SAAS,8BAAsC;AAC7C,SAAO,KAAK,IAAI,IAAI,MAAM;AAC5B;AAEA,SAAS,qBAAqB,WAA4B;AACxD,SAAO,4BAA4B,IAAI;AACzC;AAEA,SAAS,aAAa,WAA4B;AAChD,SAAO,QAAQ,IAAI,aAAa,UAAU,CAAC,qBAAqB,SAAS;AAC3E;AAGA,MAAM,OAAO,QAAQ,MAAM,QAAQ,MAAM,GAAG,QAAQ,yBAAyB,CAAC;AAYvE,SAAS,sBACd,SACA,UAAkB,kCACZ;AAGN,YAAU,MAAM;AACd,SAAK;AACL,8BAA0B;AAAA,EAC5B,GAAG,CAAC,CAAC;AAEL,YAAU,MAAM;AACd,QAAI,cAAc;AAClB,UAAM,QAAQ,YAAY,MAAM;AAC9B,UAAI,aAAa,OAAO,KAAK,CAAC,aAAa;AACzC,sBAAc;AACd,yBAAiB;AAAA,UACf;AAAA,QACF,CAAC;AAAA,MACH;AAAA,IACF,GAAG,OAAO;AAEV,WAAO,MAAM,aAAa,KAAK;AAAA,EACjC,GAAG,CAAC,SAAS,OAAO,CAAC;AACvB;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { useEffect } from "react";
|
|
2
|
+
import { logUnaryEvent } from "../utils/unaryLogging.js";
|
|
3
|
+
import { env } from "../utils/env.js";
|
|
4
|
+
function usePermissionRequestLogging(toolUseConfirm, unaryEvent) {
|
|
5
|
+
useEffect(() => {
|
|
6
|
+
const languagePromise = Promise.resolve(unaryEvent.language_name);
|
|
7
|
+
languagePromise.then((language) => {
|
|
8
|
+
logUnaryEvent({
|
|
9
|
+
completion_type: unaryEvent.completion_type,
|
|
10
|
+
event: "response",
|
|
11
|
+
metadata: {
|
|
12
|
+
language_name: language,
|
|
13
|
+
message_id: toolUseConfirm.assistantMessage.message.id,
|
|
14
|
+
platform: env.platform
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
}, [toolUseConfirm, unaryEvent]);
|
|
19
|
+
}
|
|
20
|
+
export {
|
|
21
|
+
usePermissionRequestLogging
|
|
22
|
+
};
|
|
23
|
+
//# sourceMappingURL=usePermissionRequestLogging.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/usePermissionRequestLogging.ts"],
|
|
4
|
+
"sourcesContent": ["import { useEffect } from 'react'\n \nimport { logUnaryEvent, CompletionType } from '@utils/unaryLogging'\nimport { ToolUseConfirm } from '@components/permissions/PermissionRequest'\nimport { env } from '@utils/env'\n\nexport type UnaryEvent = {\n completion_type: CompletionType\n language_name: string | Promise<string>\n}\n\n/**\n * Logs permission request events via unary logging.\n * Can handle either a string or Promise<string> for language_name.\n */\nexport function usePermissionRequestLogging(\n toolUseConfirm: ToolUseConfirm,\n unaryEvent: UnaryEvent,\n): void {\n useEffect(() => {\n \n\n // Handle string or Promise language name\n const languagePromise = Promise.resolve(unaryEvent.language_name)\n\n // Log unary event once language is resolved\n languagePromise.then(language => {\n logUnaryEvent({\n completion_type: unaryEvent.completion_type,\n event: 'response',\n metadata: {\n language_name: language,\n message_id: toolUseConfirm.assistantMessage.message.id,\n platform: env.platform,\n },\n })\n })\n }, [toolUseConfirm, unaryEvent])\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,iBAAiB;AAE1B,SAAS,qBAAqC;AAE9C,SAAS,WAAW;AAWb,SAAS,4BACd,gBACA,YACM;AACN,YAAU,MAAM;AAId,UAAM,kBAAkB,QAAQ,QAAQ,WAAW,aAAa;AAGhE,oBAAgB,KAAK,cAAY;AAC/B,oBAAc;AAAA,QACZ,iBAAiB,WAAW;AAAA,QAC5B,OAAO;AAAA,QACP,UAAU;AAAA,UACR,eAAe;AAAA,UACf,YAAY,eAAe,iBAAiB,QAAQ;AAAA,UACpD,UAAU,IAAI;AAAA,QAChB;AAAA,MACF,CAAC;AAAA,IACH,CAAC;AAAA,EACH,GAAG,CAAC,gBAAgB,UAAU,CAAC;AACjC;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { useEffect, useState } from "react";
|
|
2
|
+
let globalSize = {
|
|
3
|
+
columns: process.stdout.columns || 80,
|
|
4
|
+
rows: process.stdout.rows || 24
|
|
5
|
+
};
|
|
6
|
+
const listeners = /* @__PURE__ */ new Set();
|
|
7
|
+
let isListenerAttached = false;
|
|
8
|
+
function updateAllListeners() {
|
|
9
|
+
globalSize = {
|
|
10
|
+
columns: process.stdout.columns || 80,
|
|
11
|
+
rows: process.stdout.rows || 24
|
|
12
|
+
};
|
|
13
|
+
listeners.forEach((listener) => listener());
|
|
14
|
+
}
|
|
15
|
+
function useTerminalSize() {
|
|
16
|
+
const [size, setSize] = useState(globalSize);
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
const updateSize = () => setSize({ ...globalSize });
|
|
19
|
+
listeners.add(updateSize);
|
|
20
|
+
if (!isListenerAttached) {
|
|
21
|
+
process.stdout.setMaxListeners(20);
|
|
22
|
+
process.stdout.on("resize", updateAllListeners);
|
|
23
|
+
isListenerAttached = true;
|
|
24
|
+
}
|
|
25
|
+
return () => {
|
|
26
|
+
listeners.delete(updateSize);
|
|
27
|
+
if (listeners.size === 0 && isListenerAttached) {
|
|
28
|
+
process.stdout.off("resize", updateAllListeners);
|
|
29
|
+
isListenerAttached = false;
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
}, []);
|
|
33
|
+
return size;
|
|
34
|
+
}
|
|
35
|
+
export {
|
|
36
|
+
useTerminalSize
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=useTerminalSize.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/useTerminalSize.ts"],
|
|
4
|
+
"sourcesContent": ["import { useEffect, useState } from 'react'\n\n// Global state to share across all hook instances\nlet globalSize = {\n columns: process.stdout.columns || 80,\n rows: process.stdout.rows || 24,\n}\n\nconst listeners = new Set<() => void>()\nlet isListenerAttached = false\n\nfunction updateAllListeners() {\n globalSize = {\n columns: process.stdout.columns || 80,\n rows: process.stdout.rows || 24,\n }\n listeners.forEach(listener => listener())\n}\n\nexport function useTerminalSize() {\n const [size, setSize] = useState(globalSize)\n\n useEffect(() => {\n // Add this component's listener to the set\n const updateSize = () => setSize({ ...globalSize })\n listeners.add(updateSize)\n\n // Only attach the global resize listener once\n if (!isListenerAttached) {\n // Increase max listeners to prevent warnings\n process.stdout.setMaxListeners(20)\n process.stdout.on('resize', updateAllListeners)\n isListenerAttached = true\n }\n\n return () => {\n // Remove this component's listener\n listeners.delete(updateSize)\n\n // If no more listeners, remove the global listener\n if (listeners.size === 0 && isListenerAttached) {\n process.stdout.off('resize', updateAllListeners)\n isListenerAttached = false\n }\n }\n }, [])\n\n return size\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,WAAW,gBAAgB;AAGpC,IAAI,aAAa;AAAA,EACf,SAAS,QAAQ,OAAO,WAAW;AAAA,EACnC,MAAM,QAAQ,OAAO,QAAQ;AAC/B;AAEA,MAAM,YAAY,oBAAI,IAAgB;AACtC,IAAI,qBAAqB;AAEzB,SAAS,qBAAqB;AAC5B,eAAa;AAAA,IACX,SAAS,QAAQ,OAAO,WAAW;AAAA,IACnC,MAAM,QAAQ,OAAO,QAAQ;AAAA,EAC/B;AACA,YAAU,QAAQ,cAAY,SAAS,CAAC;AAC1C;AAEO,SAAS,kBAAkB;AAChC,QAAM,CAAC,MAAM,OAAO,IAAI,SAAS,UAAU;AAE3C,YAAU,MAAM;AAEd,UAAM,aAAa,MAAM,QAAQ,EAAE,GAAG,WAAW,CAAC;AAClD,cAAU,IAAI,UAAU;AAGxB,QAAI,CAAC,oBAAoB;AAEvB,cAAQ,OAAO,gBAAgB,EAAE;AACjC,cAAQ,OAAO,GAAG,UAAU,kBAAkB;AAC9C,2BAAqB;AAAA,IACvB;AAEA,WAAO,MAAM;AAEX,gBAAU,OAAO,UAAU;AAG3B,UAAI,UAAU,SAAS,KAAK,oBAAoB;AAC9C,gBAAQ,OAAO,IAAI,UAAU,kBAAkB;AAC/C,6BAAqB;AAAA,MACvB;AAAA,IACF;AAAA,EACF,GAAG,CAAC,CAAC;AAEL,SAAO;AACT;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,252 @@
|
|
|
1
|
+
import { useState } from "react";
|
|
2
|
+
import { useDoublePress } from "./useDoublePress.js";
|
|
3
|
+
import { Cursor } from "../utils/Cursor.js";
|
|
4
|
+
import {
|
|
5
|
+
getImageFromClipboard,
|
|
6
|
+
CLIPBOARD_ERROR_MESSAGE
|
|
7
|
+
} from "../utils/imagePaste.js";
|
|
8
|
+
const IMAGE_PLACEHOLDER = "[Image pasted]";
|
|
9
|
+
function mapInput(input_map) {
|
|
10
|
+
return function(input) {
|
|
11
|
+
const handler = new Map(input_map).get(input) ?? (() => {
|
|
12
|
+
});
|
|
13
|
+
return handler(input);
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
function useTextInput({
|
|
17
|
+
value: originalValue,
|
|
18
|
+
onChange,
|
|
19
|
+
onSubmit,
|
|
20
|
+
onExit,
|
|
21
|
+
onExitMessage,
|
|
22
|
+
onMessage,
|
|
23
|
+
onHistoryUp,
|
|
24
|
+
onHistoryDown,
|
|
25
|
+
onHistoryReset,
|
|
26
|
+
mask = "",
|
|
27
|
+
multiline = false,
|
|
28
|
+
cursorChar,
|
|
29
|
+
invert,
|
|
30
|
+
columns,
|
|
31
|
+
onImagePaste,
|
|
32
|
+
disableCursorMovementForUpDownKeys = false,
|
|
33
|
+
externalOffset,
|
|
34
|
+
onOffsetChange
|
|
35
|
+
}) {
|
|
36
|
+
const offset = externalOffset;
|
|
37
|
+
const setOffset = onOffsetChange;
|
|
38
|
+
const cursor = Cursor.fromText(originalValue, columns, offset);
|
|
39
|
+
const [imagePasteErrorTimeout, setImagePasteErrorTimeout] = useState(null);
|
|
40
|
+
function maybeClearImagePasteErrorTimeout() {
|
|
41
|
+
if (!imagePasteErrorTimeout) {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
clearTimeout(imagePasteErrorTimeout);
|
|
45
|
+
setImagePasteErrorTimeout(null);
|
|
46
|
+
onMessage?.(false);
|
|
47
|
+
}
|
|
48
|
+
const handleCtrlC = useDoublePress(
|
|
49
|
+
(show) => {
|
|
50
|
+
maybeClearImagePasteErrorTimeout();
|
|
51
|
+
onExitMessage?.(show, "Ctrl-C");
|
|
52
|
+
},
|
|
53
|
+
() => onExit?.(),
|
|
54
|
+
() => {
|
|
55
|
+
if (originalValue) {
|
|
56
|
+
onChange("");
|
|
57
|
+
onHistoryReset?.();
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
);
|
|
61
|
+
const handleEscape = useDoublePress(
|
|
62
|
+
(show) => {
|
|
63
|
+
maybeClearImagePasteErrorTimeout();
|
|
64
|
+
onMessage?.(!!originalValue && show, `Press Escape again to clear`);
|
|
65
|
+
},
|
|
66
|
+
() => {
|
|
67
|
+
if (originalValue) {
|
|
68
|
+
onChange("");
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
);
|
|
72
|
+
function clear() {
|
|
73
|
+
return Cursor.fromText("", columns, 0);
|
|
74
|
+
}
|
|
75
|
+
const handleEmptyCtrlD = useDoublePress(
|
|
76
|
+
(show) => onExitMessage?.(show, "Ctrl-D"),
|
|
77
|
+
() => onExit?.()
|
|
78
|
+
);
|
|
79
|
+
function handleCtrlD() {
|
|
80
|
+
maybeClearImagePasteErrorTimeout();
|
|
81
|
+
if (cursor.text === "") {
|
|
82
|
+
handleEmptyCtrlD();
|
|
83
|
+
return cursor;
|
|
84
|
+
}
|
|
85
|
+
return cursor.del();
|
|
86
|
+
}
|
|
87
|
+
function tryImagePaste() {
|
|
88
|
+
const base64Image = getImageFromClipboard();
|
|
89
|
+
if (base64Image === null) {
|
|
90
|
+
if (process.platform !== "darwin") {
|
|
91
|
+
return cursor;
|
|
92
|
+
}
|
|
93
|
+
onMessage?.(true, CLIPBOARD_ERROR_MESSAGE);
|
|
94
|
+
maybeClearImagePasteErrorTimeout();
|
|
95
|
+
setImagePasteErrorTimeout(
|
|
96
|
+
setTimeout(() => {
|
|
97
|
+
onMessage?.(false);
|
|
98
|
+
}, 4e3)
|
|
99
|
+
);
|
|
100
|
+
return cursor;
|
|
101
|
+
}
|
|
102
|
+
onImagePaste?.(base64Image);
|
|
103
|
+
return cursor.insert(IMAGE_PLACEHOLDER);
|
|
104
|
+
}
|
|
105
|
+
const handleCtrl = mapInput([
|
|
106
|
+
["a", () => cursor.startOfLine()],
|
|
107
|
+
["b", () => cursor.left()],
|
|
108
|
+
["c", handleCtrlC],
|
|
109
|
+
["d", handleCtrlD],
|
|
110
|
+
["e", () => cursor.endOfLine()],
|
|
111
|
+
["f", () => cursor.right()],
|
|
112
|
+
[
|
|
113
|
+
"h",
|
|
114
|
+
() => {
|
|
115
|
+
maybeClearImagePasteErrorTimeout();
|
|
116
|
+
return cursor.backspace();
|
|
117
|
+
}
|
|
118
|
+
],
|
|
119
|
+
["j", () => cursor.insert("\n")],
|
|
120
|
+
// Ctrl+J: Raw newline (Phase 2)
|
|
121
|
+
["k", () => cursor.deleteToLineEnd()],
|
|
122
|
+
["l", () => clear()],
|
|
123
|
+
["n", () => downOrHistoryDown()],
|
|
124
|
+
["p", () => upOrHistoryUp()],
|
|
125
|
+
["u", () => cursor.deleteToLineStart()],
|
|
126
|
+
["v", tryImagePaste],
|
|
127
|
+
["w", () => cursor.deleteWordBefore()]
|
|
128
|
+
]);
|
|
129
|
+
const handleMeta = mapInput([
|
|
130
|
+
["b", () => cursor.prevWord()],
|
|
131
|
+
["f", () => cursor.nextWord()],
|
|
132
|
+
["d", () => cursor.deleteWordAfter()]
|
|
133
|
+
]);
|
|
134
|
+
function handleEnter(key) {
|
|
135
|
+
if (multiline && cursor.offset > 0 && cursor.text[cursor.offset - 1] === "\\") {
|
|
136
|
+
return cursor.backspace().insert("\n");
|
|
137
|
+
}
|
|
138
|
+
if (key.meta) {
|
|
139
|
+
return cursor.insert("\n");
|
|
140
|
+
}
|
|
141
|
+
onSubmit?.(originalValue);
|
|
142
|
+
}
|
|
143
|
+
function upOrHistoryUp() {
|
|
144
|
+
if (disableCursorMovementForUpDownKeys) {
|
|
145
|
+
onHistoryUp?.();
|
|
146
|
+
return cursor;
|
|
147
|
+
}
|
|
148
|
+
const cursorUp = cursor.up();
|
|
149
|
+
if (cursorUp.equals(cursor)) {
|
|
150
|
+
onHistoryUp?.();
|
|
151
|
+
}
|
|
152
|
+
return cursorUp;
|
|
153
|
+
}
|
|
154
|
+
function downOrHistoryDown() {
|
|
155
|
+
if (disableCursorMovementForUpDownKeys) {
|
|
156
|
+
onHistoryDown?.();
|
|
157
|
+
return cursor;
|
|
158
|
+
}
|
|
159
|
+
const cursorDown = cursor.down();
|
|
160
|
+
if (cursorDown.equals(cursor)) {
|
|
161
|
+
onHistoryDown?.();
|
|
162
|
+
}
|
|
163
|
+
return cursorDown;
|
|
164
|
+
}
|
|
165
|
+
function onInput(input, key) {
|
|
166
|
+
if (key.tab) {
|
|
167
|
+
return;
|
|
168
|
+
}
|
|
169
|
+
if (key.backspace || key.delete || input === "\b" || input === "\x7F" || input === "\b") {
|
|
170
|
+
const nextCursor2 = cursor.backspace();
|
|
171
|
+
if (!cursor.equals(nextCursor2)) {
|
|
172
|
+
setOffset(nextCursor2.offset);
|
|
173
|
+
if (cursor.text !== nextCursor2.text) {
|
|
174
|
+
onChange(nextCursor2.text);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
return;
|
|
178
|
+
}
|
|
179
|
+
const nextCursor = mapKey(key)(input);
|
|
180
|
+
if (nextCursor) {
|
|
181
|
+
if (!cursor.equals(nextCursor)) {
|
|
182
|
+
setOffset(nextCursor.offset);
|
|
183
|
+
if (cursor.text !== nextCursor.text) {
|
|
184
|
+
onChange(nextCursor.text);
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
function mapKey(key) {
|
|
190
|
+
if (key.backspace || key.delete) {
|
|
191
|
+
maybeClearImagePasteErrorTimeout();
|
|
192
|
+
return () => cursor.backspace();
|
|
193
|
+
}
|
|
194
|
+
switch (true) {
|
|
195
|
+
case key.escape:
|
|
196
|
+
return handleEscape;
|
|
197
|
+
case (key.leftArrow && (key.ctrl || key.meta || "fn" in key && key.fn)):
|
|
198
|
+
return () => cursor.prevWord();
|
|
199
|
+
case (key.rightArrow && (key.ctrl || key.meta || "fn" in key && key.fn)):
|
|
200
|
+
return () => cursor.nextWord();
|
|
201
|
+
case key.ctrl:
|
|
202
|
+
return handleCtrl;
|
|
203
|
+
case ("home" in key && key.home):
|
|
204
|
+
return () => cursor.startOfLine();
|
|
205
|
+
case ("end" in key && key.end):
|
|
206
|
+
return () => cursor.endOfLine();
|
|
207
|
+
case key.pageDown:
|
|
208
|
+
return () => cursor.endOfLine();
|
|
209
|
+
case key.pageUp:
|
|
210
|
+
return () => cursor.startOfLine();
|
|
211
|
+
case key.meta:
|
|
212
|
+
return handleMeta;
|
|
213
|
+
case key.return:
|
|
214
|
+
return () => handleEnter(key);
|
|
215
|
+
// Remove Tab handling - let completion system handle it
|
|
216
|
+
case key.upArrow:
|
|
217
|
+
return upOrHistoryUp;
|
|
218
|
+
case key.downArrow:
|
|
219
|
+
return downOrHistoryDown;
|
|
220
|
+
case key.leftArrow:
|
|
221
|
+
return () => cursor.left();
|
|
222
|
+
case key.rightArrow:
|
|
223
|
+
return () => cursor.right();
|
|
224
|
+
}
|
|
225
|
+
return function(input) {
|
|
226
|
+
switch (true) {
|
|
227
|
+
// Home key
|
|
228
|
+
case (input == "\x1B[H" || input == "\x1B[1~"):
|
|
229
|
+
return cursor.startOfLine();
|
|
230
|
+
// End key
|
|
231
|
+
case (input == "\x1B[F" || input == "\x1B[4~"):
|
|
232
|
+
return cursor.endOfLine();
|
|
233
|
+
// Handle backspace character explicitly - this is the key fix
|
|
234
|
+
case (input === "\b" || input === "\x7F" || input === "\b"):
|
|
235
|
+
maybeClearImagePasteErrorTimeout();
|
|
236
|
+
return cursor.backspace();
|
|
237
|
+
default:
|
|
238
|
+
return cursor.insert(input.replace(/\r/g, "\n"));
|
|
239
|
+
}
|
|
240
|
+
};
|
|
241
|
+
}
|
|
242
|
+
return {
|
|
243
|
+
onInput,
|
|
244
|
+
renderedValue: cursor.render(cursorChar, mask, invert),
|
|
245
|
+
offset,
|
|
246
|
+
setOffset
|
|
247
|
+
};
|
|
248
|
+
}
|
|
249
|
+
export {
|
|
250
|
+
useTextInput
|
|
251
|
+
};
|
|
252
|
+
//# sourceMappingURL=useTextInput.js.map
|