@shareai-lab/kode 1.1.12 → 1.1.13
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/cli.js +44 -23
- package/dist/ProjectOnboarding.js +99 -0
- package/dist/ProjectOnboarding.js.map +7 -0
- package/dist/Tool.js +1 -0
- package/dist/Tool.js.map +7 -0
- package/dist/commands/agents.js +2087 -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/clear.js +37 -0
- package/dist/commands/clear.js.map +7 -0
- package/dist/commands/compact.js +104 -0
- package/dist/commands/compact.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.js +34 -0
- package/dist/commands/mcp.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/pr_comments.js +61 -0
- package/dist/commands/pr_comments.js.map +7 -0
- package/dist/commands/refreshCommands.js +37 -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 +163 -0
- package/dist/commands/terminalSetup.js.map +7 -0
- package/dist/commands.js +84 -0
- package/dist/commands.js.map +7 -0
- package/dist/components/ApproveApiKey.js +74 -0
- package/dist/components/ApproveApiKey.js.map +7 -0
- package/dist/components/AsciiLogo.js +12 -0
- package/dist/components/AsciiLogo.js.map +7 -0
- package/dist/components/AutoUpdater.js +74 -0
- package/dist/components/AutoUpdater.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 +188 -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 +31 -0
- package/dist/components/FileEditToolUpdatedMessage.js.map +7 -0
- package/dist/components/Help.js +41 -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/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 +89 -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 +133 -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 +1985 -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/PromptInput.js +501 -0
- package/dist/components/PromptInput.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/StickerRequestForm.js +7 -0
- package/dist/components/StickerRequestForm.js.map +7 -0
- package/dist/components/StructuredDiff.js +148 -0
- package/dist/components/StructuredDiff.js.map +7 -0
- package/dist/components/TextInput.js +100 -0
- package/dist/components/TextInput.js.map +7 -0
- package/dist/components/TodoItem.js +35 -0
- package/dist/components/TodoItem.js.map +7 -0
- package/dist/components/TokenWarning.js +19 -0
- package/dist/components/TokenWarning.js.map +7 -0
- package/dist/components/ToolUseLoader.js +24 -0
- package/dist/components/ToolUseLoader.js.map +7 -0
- package/dist/components/TrustDialog.js +76 -0
- package/dist/components/TrustDialog.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 +161 -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 +42 -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 +28 -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/betas.js +11 -0
- package/dist/constants/betas.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/figures.js +6 -0
- package/dist/constants/figures.js.map +7 -0
- package/dist/constants/keys.js +7 -0
- package/dist/constants/keys.js.map +7 -0
- package/dist/constants/macros.js +13 -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 +1029 -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/context/PermissionContext.js +111 -0
- package/dist/context/PermissionContext.js.map +7 -0
- package/dist/context.js +259 -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.js +1101 -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 +112 -0
- package/dist/hooks/useCanUseTool.js.map +7 -0
- package/dist/hooks/useCancelRequest.js +30 -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/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 +15 -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 +28 -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 +250 -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 +26 -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 +1 -0
- package/dist/permissions.js +194 -0
- package/dist/permissions.js.map +7 -0
- package/dist/query.js +492 -0
- package/dist/query.js.map +7 -0
- package/dist/screens/ConfigureNpmPrefix.js +128 -0
- package/dist/screens/ConfigureNpmPrefix.js.map +7 -0
- package/dist/screens/Doctor.js +143 -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 +596 -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/browserMocks.js +48 -0
- package/dist/services/browserMocks.js.map +7 -0
- package/dist/services/claude.js +1605 -0
- package/dist/services/claude.js.map +7 -0
- package/dist/services/customCommands.js +359 -0
- package/dist/services/customCommands.js.map +7 -0
- package/dist/services/fileFreshness.js +280 -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/mcpClient.js +435 -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 +200 -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 +259 -0
- package/dist/services/oauth.js.map +7 -0
- package/dist/services/openai.js +998 -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/statsig.js +112 -0
- package/dist/services/statsig.js.map +7 -0
- package/dist/services/statsigStorage.js +75 -0
- package/dist/services/statsigStorage.js.map +7 -0
- package/dist/services/systemReminder.js +353 -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/test/testAdapters.js +88 -0
- package/dist/test/testAdapters.js.map +1 -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/BashTool/BashTool.js +188 -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 +179 -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 +228 -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 +204 -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/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 +293 -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/StickerRequestTool/StickerRequestTool.js +86 -0
- package/dist/tools/StickerRequestTool/StickerRequestTool.js.map +7 -0
- package/dist/tools/StickerRequestTool/prompt.js +23 -0
- package/dist/tools/StickerRequestTool/prompt.js.map +7 -0
- package/dist/tools/TaskTool/TaskTool.js +308 -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 +82 -0
- package/dist/tools/TaskTool/prompt.js.map +7 -0
- package/dist/tools/ThinkTool/ThinkTool.js +48 -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 +216 -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 +64 -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/logs.js +1 -0
- package/dist/types/logs.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/utils/Cursor.js +313 -0
- package/dist/utils/Cursor.js.map +7 -0
- package/dist/utils/PersistentShell.js +382 -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 +199 -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 +149 -0
- package/dist/utils/autoCompactCore.js.map +7 -0
- package/dist/utils/autoUpdater.js +362 -0
- package/dist/utils/autoUpdater.js.map +7 -0
- package/dist/utils/betas.js +21 -0
- package/dist/utils/betas.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/config.js +655 -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 +891 -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/exampleCommands.js +80 -0
- package/dist/utils/exampleCommands.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/globalLogger.js +54 -0
- package/dist/utils/globalLogger.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 +298 -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/messageContextManager.js +195 -0
- package/dist/utils/messageContextManager.js.map +7 -0
- package/dist/utils/messages.js +633 -0
- package/dist/utils/messages.js.map +7 -0
- package/dist/utils/model.js +687 -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/responseState.js +20 -0
- package/dist/utils/responseState.js.map +7 -0
- package/dist/utils/ripgrep.js +131 -0
- package/dist/utils/ripgrep.js.map +7 -0
- package/dist/utils/secureFile.js +483 -0
- package/dist/utils/secureFile.js.map +7 -0
- package/dist/utils/sessionState.js +31 -0
- package/dist/utils/sessionState.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 +43 -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 +103 -0
- package/dist/utils/thinking.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 +14 -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/yoga.wasm +0 -0
- package/package.json +28 -7
- package/src/Tool.ts +4 -3
- package/src/commands/agents.tsx +10 -4
- package/src/components/messages/AssistantToolUseMessage.tsx +5 -6
- package/src/constants/macros.ts +5 -2
- package/src/entrypoints/cli.tsx +38 -19
- package/src/entrypoints/mcp.ts +1 -2
- package/src/hooks/useDoublePress.ts +0 -1
- package/src/hooks/useTextInput.ts +4 -5
- package/src/hooks/useUnifiedCompletion.ts +2 -2
- package/src/index.ts +34 -0
- package/src/query.ts +13 -8
- package/src/screens/Doctor.tsx +1 -1
- package/src/screens/REPL.tsx +13 -9
- package/src/services/openai.ts +25 -4
- package/src/tools/ArchitectTool/ArchitectTool.tsx +18 -5
- package/src/tools/AskExpertModelTool/AskExpertModelTool.tsx +21 -14
- package/src/tools/FileEditTool/FileEditTool.tsx +6 -2
- package/src/tools/FileWriteTool/FileWriteTool.tsx +7 -3
- package/src/tools/MultiEditTool/MultiEditTool.tsx +26 -4
- package/src/tools/NotebookReadTool/NotebookReadTool.tsx +1 -1
- package/src/tools/StickerRequestTool/StickerRequestTool.tsx +28 -14
- package/src/tools/TaskTool/TaskTool.tsx +8 -36
- package/src/types/common.d.ts +2 -0
- package/src/utils/generators.ts +1 -1
- package/src/utils/messageContextManager.ts +5 -0
- package/src/utils/messages.tsx +8 -2
- package/src/utils/thinking.ts +1 -1
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { useInput } from "ink";
|
|
2
|
+
import { logEvent } from "../services/statsig.js";
|
|
3
|
+
function useCancelRequest(setToolJSX, setToolUseConfirm, setBinaryFeedbackContext, onCancel, isLoading, isMessageSelectorVisible, abortSignal) {
|
|
4
|
+
useInput((_, key) => {
|
|
5
|
+
if (!key.escape) {
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
if (abortSignal?.aborted) {
|
|
9
|
+
return;
|
|
10
|
+
}
|
|
11
|
+
if (!abortSignal) {
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
if (!isLoading) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
if (isMessageSelectorVisible) {
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
logEvent("tengu_cancel", {});
|
|
21
|
+
setToolJSX(null);
|
|
22
|
+
setToolUseConfirm(null);
|
|
23
|
+
setBinaryFeedbackContext(null);
|
|
24
|
+
onCancel();
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
export {
|
|
28
|
+
useCancelRequest
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=useCancelRequest.js.map
|
|
@@ -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 { logEvent } from '../services/statsig'\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 logEvent('tengu_cancel', {})\n setToolJSX(null)\n setToolUseConfirm(null)\n setBinaryFeedbackContext(null)\n onCancel()\n })\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,gBAAgB;AAEzB,SAAS,gBAAgB;AAIlB,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;AACA,aAAS,gBAAgB,CAAC,CAAC;AAC3B,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,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,15 @@
|
|
|
1
|
+
import { useEffect } from "react";
|
|
2
|
+
import { logEvent } from "../services/statsig.js";
|
|
3
|
+
function useLogStartupTime() {
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
const startupTimeMs = Math.round(process.uptime() * 1e3);
|
|
6
|
+
logEvent("tengu_timer", {
|
|
7
|
+
event: "startup",
|
|
8
|
+
durationMs: String(startupTimeMs)
|
|
9
|
+
});
|
|
10
|
+
}, []);
|
|
11
|
+
}
|
|
12
|
+
export {
|
|
13
|
+
useLogStartupTime
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=useLogStartupTime.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/useLogStartupTime.ts"],
|
|
4
|
+
"sourcesContent": ["import { useEffect } from 'react'\nimport { logEvent } from '../services/statsig'\n\nexport function useLogStartupTime(): void {\n useEffect(() => {\n const startupTimeMs = Math.round(process.uptime() * 1000)\n logEvent('tengu_timer', {\n event: 'startup',\n durationMs: String(startupTimeMs),\n })\n }, [])\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,iBAAiB;AAC1B,SAAS,gBAAgB;AAElB,SAAS,oBAA0B;AACxC,YAAU,MAAM;AACd,UAAM,gBAAgB,KAAK,MAAM,QAAQ,OAAO,IAAI,GAAI;AACxD,aAAS,eAAe;AAAA,MACtB,OAAO;AAAA,MACP,YAAY,OAAO,aAAa;AAAA,IAClC,CAAC;AAAA,EACH,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,28 @@
|
|
|
1
|
+
import { useEffect } from "react";
|
|
2
|
+
import { logEvent } from "../services/statsig.js";
|
|
3
|
+
import { logUnaryEvent } from "../utils/unaryLogging.js";
|
|
4
|
+
import { env } from "../utils/env.js";
|
|
5
|
+
function usePermissionRequestLogging(toolUseConfirm, unaryEvent) {
|
|
6
|
+
useEffect(() => {
|
|
7
|
+
logEvent("tengu_tool_use_show_permission_request", {
|
|
8
|
+
messageID: toolUseConfirm.assistantMessage.message.id,
|
|
9
|
+
toolName: toolUseConfirm.tool.name
|
|
10
|
+
});
|
|
11
|
+
const languagePromise = Promise.resolve(unaryEvent.language_name);
|
|
12
|
+
languagePromise.then((language) => {
|
|
13
|
+
logUnaryEvent({
|
|
14
|
+
completion_type: unaryEvent.completion_type,
|
|
15
|
+
event: "response",
|
|
16
|
+
metadata: {
|
|
17
|
+
language_name: language,
|
|
18
|
+
message_id: toolUseConfirm.assistantMessage.message.id,
|
|
19
|
+
platform: env.platform
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
}, [toolUseConfirm, unaryEvent]);
|
|
24
|
+
}
|
|
25
|
+
export {
|
|
26
|
+
usePermissionRequestLogging
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=usePermissionRequestLogging.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/usePermissionRequestLogging.ts"],
|
|
4
|
+
"sourcesContent": ["import { useEffect } from 'react'\nimport { logEvent } from '../services/statsig'\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 using Statsig and unary logging.\n * Handles both the Statsig event and the unary event 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 // Log Statsig event\n logEvent('tengu_tool_use_show_permission_request', {\n messageID: toolUseConfirm.assistantMessage.message.id,\n toolName: toolUseConfirm.tool.name,\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;AAC1B,SAAS,gBAAgB;AACzB,SAAS,qBAAqC;AAE9C,SAAS,WAAW;AAYb,SAAS,4BACd,gBACA,YACM;AACN,YAAU,MAAM;AAEd,aAAS,0CAA0C;AAAA,MACjD,WAAW,eAAe,iBAAiB,QAAQ;AAAA,MACnD,UAAU,eAAe,KAAK;AAAA,IAChC,CAAC;AAGD,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,250 @@
|
|
|
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
|
+
["k", () => cursor.deleteToLineEnd()],
|
|
120
|
+
["l", () => clear()],
|
|
121
|
+
["n", () => downOrHistoryDown()],
|
|
122
|
+
["p", () => upOrHistoryUp()],
|
|
123
|
+
["u", () => cursor.deleteToLineStart()],
|
|
124
|
+
["v", tryImagePaste],
|
|
125
|
+
["w", () => cursor.deleteWordBefore()]
|
|
126
|
+
]);
|
|
127
|
+
const handleMeta = mapInput([
|
|
128
|
+
["b", () => cursor.prevWord()],
|
|
129
|
+
["f", () => cursor.nextWord()],
|
|
130
|
+
["d", () => cursor.deleteWordAfter()]
|
|
131
|
+
]);
|
|
132
|
+
function handleEnter(key) {
|
|
133
|
+
if (multiline && cursor.offset > 0 && cursor.text[cursor.offset - 1] === "\\") {
|
|
134
|
+
return cursor.backspace().insert("\n");
|
|
135
|
+
}
|
|
136
|
+
if (key.meta) {
|
|
137
|
+
return cursor.insert("\n");
|
|
138
|
+
}
|
|
139
|
+
onSubmit?.(originalValue);
|
|
140
|
+
}
|
|
141
|
+
function upOrHistoryUp() {
|
|
142
|
+
if (disableCursorMovementForUpDownKeys) {
|
|
143
|
+
onHistoryUp?.();
|
|
144
|
+
return cursor;
|
|
145
|
+
}
|
|
146
|
+
const cursorUp = cursor.up();
|
|
147
|
+
if (cursorUp.equals(cursor)) {
|
|
148
|
+
onHistoryUp?.();
|
|
149
|
+
}
|
|
150
|
+
return cursorUp;
|
|
151
|
+
}
|
|
152
|
+
function downOrHistoryDown() {
|
|
153
|
+
if (disableCursorMovementForUpDownKeys) {
|
|
154
|
+
onHistoryDown?.();
|
|
155
|
+
return cursor;
|
|
156
|
+
}
|
|
157
|
+
const cursorDown = cursor.down();
|
|
158
|
+
if (cursorDown.equals(cursor)) {
|
|
159
|
+
onHistoryDown?.();
|
|
160
|
+
}
|
|
161
|
+
return cursorDown;
|
|
162
|
+
}
|
|
163
|
+
function onInput(input, key) {
|
|
164
|
+
if (key.tab) {
|
|
165
|
+
return;
|
|
166
|
+
}
|
|
167
|
+
if (key.backspace || key.delete || input === "\b" || input === "\x7F" || input === "\b") {
|
|
168
|
+
const nextCursor2 = cursor.backspace();
|
|
169
|
+
if (!cursor.equals(nextCursor2)) {
|
|
170
|
+
setOffset(nextCursor2.offset);
|
|
171
|
+
if (cursor.text !== nextCursor2.text) {
|
|
172
|
+
onChange(nextCursor2.text);
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
return;
|
|
176
|
+
}
|
|
177
|
+
const nextCursor = mapKey(key)(input);
|
|
178
|
+
if (nextCursor) {
|
|
179
|
+
if (!cursor.equals(nextCursor)) {
|
|
180
|
+
setOffset(nextCursor.offset);
|
|
181
|
+
if (cursor.text !== nextCursor.text) {
|
|
182
|
+
onChange(nextCursor.text);
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
function mapKey(key) {
|
|
188
|
+
if (key.backspace || key.delete) {
|
|
189
|
+
maybeClearImagePasteErrorTimeout();
|
|
190
|
+
return () => cursor.backspace();
|
|
191
|
+
}
|
|
192
|
+
switch (true) {
|
|
193
|
+
case key.escape:
|
|
194
|
+
return handleEscape;
|
|
195
|
+
case (key.leftArrow && (key.ctrl || key.meta || "fn" in key && key.fn)):
|
|
196
|
+
return () => cursor.prevWord();
|
|
197
|
+
case (key.rightArrow && (key.ctrl || key.meta || "fn" in key && key.fn)):
|
|
198
|
+
return () => cursor.nextWord();
|
|
199
|
+
case key.ctrl:
|
|
200
|
+
return handleCtrl;
|
|
201
|
+
case ("home" in key && key.home):
|
|
202
|
+
return () => cursor.startOfLine();
|
|
203
|
+
case ("end" in key && key.end):
|
|
204
|
+
return () => cursor.endOfLine();
|
|
205
|
+
case key.pageDown:
|
|
206
|
+
return () => cursor.endOfLine();
|
|
207
|
+
case key.pageUp:
|
|
208
|
+
return () => cursor.startOfLine();
|
|
209
|
+
case key.meta:
|
|
210
|
+
return handleMeta;
|
|
211
|
+
case key.return:
|
|
212
|
+
return () => handleEnter(key);
|
|
213
|
+
// Remove Tab handling - let completion system handle it
|
|
214
|
+
case key.upArrow:
|
|
215
|
+
return upOrHistoryUp;
|
|
216
|
+
case key.downArrow:
|
|
217
|
+
return downOrHistoryDown;
|
|
218
|
+
case key.leftArrow:
|
|
219
|
+
return () => cursor.left();
|
|
220
|
+
case key.rightArrow:
|
|
221
|
+
return () => cursor.right();
|
|
222
|
+
}
|
|
223
|
+
return function(input) {
|
|
224
|
+
switch (true) {
|
|
225
|
+
// Home key
|
|
226
|
+
case (input == "\x1B[H" || input == "\x1B[1~"):
|
|
227
|
+
return cursor.startOfLine();
|
|
228
|
+
// End key
|
|
229
|
+
case (input == "\x1B[F" || input == "\x1B[4~"):
|
|
230
|
+
return cursor.endOfLine();
|
|
231
|
+
// Handle backspace character explicitly - this is the key fix
|
|
232
|
+
case (input === "\b" || input === "\x7F" || input === "\b"):
|
|
233
|
+
maybeClearImagePasteErrorTimeout();
|
|
234
|
+
return cursor.backspace();
|
|
235
|
+
default:
|
|
236
|
+
return cursor.insert(input.replace(/\r/g, "\n"));
|
|
237
|
+
}
|
|
238
|
+
};
|
|
239
|
+
}
|
|
240
|
+
return {
|
|
241
|
+
onInput,
|
|
242
|
+
renderedValue: cursor.render(cursorChar, mask, invert),
|
|
243
|
+
offset,
|
|
244
|
+
setOffset
|
|
245
|
+
};
|
|
246
|
+
}
|
|
247
|
+
export {
|
|
248
|
+
useTextInput
|
|
249
|
+
};
|
|
250
|
+
//# sourceMappingURL=useTextInput.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/hooks/useTextInput.ts"],
|
|
4
|
+
"sourcesContent": ["import { useState } from 'react'\nimport { type Key } from 'ink'\nimport { useDoublePress } from './useDoublePress'\nimport { Cursor } from '../utils/Cursor'\nimport {\n getImageFromClipboard,\n CLIPBOARD_ERROR_MESSAGE,\n} from '../utils/imagePaste.js'\n\nconst IMAGE_PLACEHOLDER = '[Image pasted]'\n\ntype MaybeCursor = void | Cursor\ntype InputHandler = (input: string) => MaybeCursor\ntype InputMapper = (input: string) => MaybeCursor\nfunction mapInput(input_map: Array<[string, InputHandler]>): InputMapper {\n return function (input: string): MaybeCursor {\n const handler = new Map(input_map).get(input) ?? (() => {})\n return handler(input)\n }\n}\n\ntype UseTextInputProps = {\n value: string\n onChange: (value: string) => void\n onSubmit?: (value: string) => void\n onExit?: () => void\n onExitMessage?: (show: boolean, key?: string) => void\n onMessage?: (show: boolean, message?: string) => void\n onHistoryUp?: () => void\n onHistoryDown?: () => void\n onHistoryReset?: () => void\n focus?: boolean\n mask?: string\n multiline?: boolean\n cursorChar: string\n highlightPastedText?: boolean\n invert: (text: string) => string\n themeText: (text: string) => string\n columns: number\n onImagePaste?: (base64Image: string) => void\n disableCursorMovementForUpDownKeys?: boolean\n externalOffset: number\n onOffsetChange: (offset: number) => void\n}\n\ntype UseTextInputResult = {\n renderedValue: string\n onInput: (input: string, key: Key) => void\n offset: number\n setOffset: (offset: number) => void\n}\n\nexport function useTextInput({\n value: originalValue,\n onChange,\n onSubmit,\n onExit,\n onExitMessage,\n onMessage,\n onHistoryUp,\n onHistoryDown,\n onHistoryReset,\n mask = '',\n multiline = false,\n cursorChar,\n invert,\n columns,\n onImagePaste,\n disableCursorMovementForUpDownKeys = false,\n externalOffset,\n onOffsetChange,\n}: UseTextInputProps): UseTextInputResult {\n const offset = externalOffset\n const setOffset = onOffsetChange\n const cursor = Cursor.fromText(originalValue, columns, offset)\n const [imagePasteErrorTimeout, setImagePasteErrorTimeout] =\n useState<NodeJS.Timeout | null>(null)\n\n function maybeClearImagePasteErrorTimeout() {\n if (!imagePasteErrorTimeout) {\n return\n }\n clearTimeout(imagePasteErrorTimeout)\n setImagePasteErrorTimeout(null)\n onMessage?.(false)\n }\n\n const handleCtrlC = useDoublePress(\n show => {\n maybeClearImagePasteErrorTimeout()\n onExitMessage?.(show, 'Ctrl-C')\n },\n () => onExit?.(),\n () => {\n if (originalValue) {\n onChange('')\n onHistoryReset?.()\n }\n },\n )\n\n // Keep Escape for clearing input\n const handleEscape = useDoublePress(\n show => {\n maybeClearImagePasteErrorTimeout()\n onMessage?.(!!originalValue && show, `Press Escape again to clear`)\n },\n () => {\n if (originalValue) {\n onChange('')\n }\n },\n )\n function clear() {\n return Cursor.fromText('', columns, 0)\n }\n\n const handleEmptyCtrlD = useDoublePress(\n show => onExitMessage?.(show, 'Ctrl-D'),\n () => onExit?.(),\n )\n\n function handleCtrlD(): MaybeCursor {\n maybeClearImagePasteErrorTimeout()\n if (cursor.text === '') {\n // When input is empty, handle double-press\n handleEmptyCtrlD()\n return cursor\n }\n // When input is not empty, delete forward like iPython\n return cursor.del()\n }\n\n function tryImagePaste() {\n const base64Image = getImageFromClipboard()\n if (base64Image === null) {\n if (process.platform !== 'darwin') {\n return cursor\n }\n onMessage?.(true, CLIPBOARD_ERROR_MESSAGE)\n maybeClearImagePasteErrorTimeout()\n setImagePasteErrorTimeout(\n setTimeout(() => {\n onMessage?.(false)\n }, 4000),\n )\n return cursor\n }\n\n onImagePaste?.(base64Image)\n return cursor.insert(IMAGE_PLACEHOLDER)\n }\n\n const handleCtrl = mapInput([\n ['a', () => cursor.startOfLine()],\n ['b', () => cursor.left()],\n ['c', handleCtrlC],\n ['d', handleCtrlD],\n ['e', () => cursor.endOfLine()],\n ['f', () => cursor.right()],\n [\n 'h',\n () => {\n maybeClearImagePasteErrorTimeout()\n return cursor.backspace()\n },\n ],\n ['k', () => cursor.deleteToLineEnd()],\n ['l', () => clear()],\n ['n', () => downOrHistoryDown()],\n ['p', () => upOrHistoryUp()],\n ['u', () => cursor.deleteToLineStart()],\n ['v', tryImagePaste],\n ['w', () => cursor.deleteWordBefore()],\n ])\n\n const handleMeta = mapInput([\n ['b', () => cursor.prevWord()],\n ['f', () => cursor.nextWord()],\n ['d', () => cursor.deleteWordAfter()],\n ])\n\n function handleEnter(key: Key) {\n if (\n multiline &&\n cursor.offset > 0 &&\n cursor.text[cursor.offset - 1] === '\\\\'\n ) {\n return cursor.backspace().insert('\\n')\n }\n if (key.meta) {\n return cursor.insert('\\n')\n }\n onSubmit?.(originalValue)\n }\n\n function upOrHistoryUp() {\n if (disableCursorMovementForUpDownKeys) {\n onHistoryUp?.()\n return cursor\n }\n const cursorUp = cursor.up()\n if (cursorUp.equals(cursor)) {\n // already at beginning\n onHistoryUp?.()\n }\n return cursorUp\n }\n function downOrHistoryDown() {\n if (disableCursorMovementForUpDownKeys) {\n onHistoryDown?.()\n return cursor\n }\n const cursorDown = cursor.down()\n if (cursorDown.equals(cursor)) {\n onHistoryDown?.()\n }\n return cursorDown\n }\n\n function onInput(input: string, key: Key): void {\n if (key.tab) {\n return // Skip Tab key processing - let completion system handle it\n }\n \n // Direct handling for backspace or delete (which is being detected as delete)\n if (\n key.backspace ||\n key.delete ||\n input === '\\b' ||\n input === '\\x7f' ||\n input === '\\x08'\n ) {\n const nextCursor = cursor.backspace()\n if (!cursor.equals(nextCursor)) {\n setOffset(nextCursor.offset)\n if (cursor.text !== nextCursor.text) {\n onChange(nextCursor.text)\n }\n }\n return\n }\n\n const nextCursor = mapKey(key)(input)\n if (nextCursor) {\n if (!cursor.equals(nextCursor)) {\n setOffset(nextCursor.offset)\n if (cursor.text !== nextCursor.text) {\n onChange(nextCursor.text)\n }\n }\n }\n }\n\n function mapKey(key: Key): InputMapper {\n // Direct handling for backspace or delete\n if (key.backspace || key.delete) {\n maybeClearImagePasteErrorTimeout()\n return () => cursor.backspace()\n }\n\n switch (true) {\n case key.escape:\n return handleEscape\n case key.leftArrow && (key.ctrl || key.meta || ('fn' in key && key.fn)):\n return () => cursor.prevWord()\n case key.rightArrow && (key.ctrl || key.meta || ('fn' in key && key.fn)):\n return () => cursor.nextWord()\n case key.ctrl:\n return handleCtrl\n case 'home' in key && key.home:\n return () => cursor.startOfLine()\n case 'end' in key && key.end:\n return () => cursor.endOfLine()\n case key.pageDown:\n return () => cursor.endOfLine()\n case key.pageUp:\n return () => cursor.startOfLine()\n case key.meta:\n return handleMeta\n case key.return:\n return () => handleEnter(key)\n // Remove Tab handling - let completion system handle it\n case key.upArrow:\n return upOrHistoryUp\n case key.downArrow:\n return downOrHistoryDown\n case key.leftArrow:\n return () => cursor.left()\n case key.rightArrow:\n return () => cursor.right()\n }\n return function (input: string) {\n switch (true) {\n // Home key\n case input == '\\x1b[H' || input == '\\x1b[1~':\n return cursor.startOfLine()\n // End key\n case input == '\\x1b[F' || input == '\\x1b[4~':\n return cursor.endOfLine()\n // Handle backspace character explicitly - this is the key fix\n case input === '\\b' || input === '\\x7f' || input === '\\x08':\n maybeClearImagePasteErrorTimeout()\n return cursor.backspace()\n default:\n return cursor.insert(input.replace(/\\r/g, '\\n'))\n }\n }\n }\n\n return {\n onInput,\n renderedValue: cursor.render(cursorChar, mask, invert),\n offset,\n setOffset,\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["nextCursor"]
|
|
7
|
+
}
|