@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,108 @@
|
|
|
1
|
+
import { isEqual, zip } from "lodash-es";
|
|
2
|
+
async function getBinaryFeedbackConfig() {
|
|
3
|
+
return { sampleFrequency: 0 };
|
|
4
|
+
}
|
|
5
|
+
function getMessageBlockSequence(m) {
|
|
6
|
+
return m.message.content.map((cb) => {
|
|
7
|
+
if (cb.type === "text") return "text";
|
|
8
|
+
if (cb.type === "tool_use") return cb.name;
|
|
9
|
+
return cb.type;
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
function textContentBlocksEqual(cb1, cb2) {
|
|
13
|
+
return cb1.text === cb2.text;
|
|
14
|
+
}
|
|
15
|
+
function contentBlocksEqual(cb1, cb2) {
|
|
16
|
+
if (cb1.type !== cb2.type) {
|
|
17
|
+
return false;
|
|
18
|
+
}
|
|
19
|
+
if (cb1.type === "text") {
|
|
20
|
+
return textContentBlocksEqual(cb1, cb2);
|
|
21
|
+
}
|
|
22
|
+
cb2 = cb2;
|
|
23
|
+
return cb1.name === cb2.name && isEqual(cb1.input, cb2.input);
|
|
24
|
+
}
|
|
25
|
+
function allContentBlocksEqual(content1, content2) {
|
|
26
|
+
if (content1.length !== content2.length) {
|
|
27
|
+
return false;
|
|
28
|
+
}
|
|
29
|
+
return zip(content1, content2).every(
|
|
30
|
+
([cb1, cb2]) => contentBlocksEqual(cb1, cb2)
|
|
31
|
+
);
|
|
32
|
+
}
|
|
33
|
+
async function shouldUseBinaryFeedback() {
|
|
34
|
+
if (process.env.DISABLE_BINARY_FEEDBACK) {
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
if (process.env.FORCE_BINARY_FEEDBACK) {
|
|
38
|
+
return true;
|
|
39
|
+
}
|
|
40
|
+
if (process.env.USER_TYPE !== "ant") {
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
43
|
+
if (process.env.NODE_ENV === "test") {
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
const config = await getBinaryFeedbackConfig();
|
|
47
|
+
if (config.sampleFrequency === 0) {
|
|
48
|
+
return false;
|
|
49
|
+
}
|
|
50
|
+
if (Math.random() > config.sampleFrequency) {
|
|
51
|
+
return false;
|
|
52
|
+
}
|
|
53
|
+
return true;
|
|
54
|
+
}
|
|
55
|
+
function messagePairValidForBinaryFeedback(m1, m2) {
|
|
56
|
+
const logPass = () => {
|
|
57
|
+
};
|
|
58
|
+
const logFail = (_reason) => {
|
|
59
|
+
};
|
|
60
|
+
const nonThinkingBlocks1 = m1.message.content.filter(
|
|
61
|
+
(b) => b.type !== "thinking" && b.type !== "redacted_thinking"
|
|
62
|
+
);
|
|
63
|
+
const nonThinkingBlocks2 = m2.message.content.filter(
|
|
64
|
+
(b) => b.type !== "thinking" && b.type !== "redacted_thinking"
|
|
65
|
+
);
|
|
66
|
+
const hasToolUse = nonThinkingBlocks1.some((b) => b.type === "tool_use") || nonThinkingBlocks2.some((b) => b.type === "tool_use");
|
|
67
|
+
if (!hasToolUse) {
|
|
68
|
+
if (allContentBlocksEqual(nonThinkingBlocks1, nonThinkingBlocks2)) {
|
|
69
|
+
logFail("contents_identical");
|
|
70
|
+
return false;
|
|
71
|
+
}
|
|
72
|
+
logPass();
|
|
73
|
+
return true;
|
|
74
|
+
}
|
|
75
|
+
if (allContentBlocksEqual(
|
|
76
|
+
nonThinkingBlocks1.filter((b) => b.type === "tool_use"),
|
|
77
|
+
nonThinkingBlocks2.filter((b) => b.type === "tool_use")
|
|
78
|
+
)) {
|
|
79
|
+
logFail("contents_identical");
|
|
80
|
+
return false;
|
|
81
|
+
}
|
|
82
|
+
logPass();
|
|
83
|
+
return true;
|
|
84
|
+
}
|
|
85
|
+
function getBinaryFeedbackResultForChoice(m1, m2, choice) {
|
|
86
|
+
switch (choice) {
|
|
87
|
+
case "prefer-left":
|
|
88
|
+
return { message: m1, shouldSkipPermissionCheck: true };
|
|
89
|
+
case "prefer-right":
|
|
90
|
+
return { message: m2, shouldSkipPermissionCheck: true };
|
|
91
|
+
case "no-preference":
|
|
92
|
+
return {
|
|
93
|
+
message: Math.random() < 0.5 ? m1 : m2,
|
|
94
|
+
shouldSkipPermissionCheck: false
|
|
95
|
+
};
|
|
96
|
+
case "neither":
|
|
97
|
+
return { message: null, shouldSkipPermissionCheck: false };
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
async function logBinaryFeedbackEvent(_m1, _m2, _choice) {
|
|
101
|
+
}
|
|
102
|
+
export {
|
|
103
|
+
getBinaryFeedbackResultForChoice,
|
|
104
|
+
logBinaryFeedbackEvent,
|
|
105
|
+
messagePairValidForBinaryFeedback,
|
|
106
|
+
shouldUseBinaryFeedback
|
|
107
|
+
};
|
|
108
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/binary-feedback/utils.ts"],
|
|
4
|
+
"sourcesContent": ["import { TextBlock, ToolUseBlock } from '@anthropic-ai/sdk/resources/index.mjs'\nimport { AssistantMessage, BinaryFeedbackResult } from '@query'\nimport { MAIN_QUERY_TEMPERATURE } from '@services/claude'\n\nimport { isEqual, zip } from 'lodash-es'\nimport { getGitState } from '@utils/git'\n\nexport type BinaryFeedbackChoice =\n | 'prefer-left'\n | 'prefer-right'\n | 'neither'\n | 'no-preference'\n\nexport type BinaryFeedbackChoose = (choice: BinaryFeedbackChoice) => void\n\ntype BinaryFeedbackConfig = {\n sampleFrequency: number\n}\n\nasync function getBinaryFeedbackConfig(): Promise<BinaryFeedbackConfig> {\n return { sampleFrequency: 0 }\n}\n\nfunction getMessageBlockSequence(m: AssistantMessage) {\n return m.message.content.map(cb => {\n if (cb.type === 'text') return 'text'\n if (cb.type === 'tool_use') return cb.name\n return cb.type // Handle other block types like 'thinking' or 'redacted_thinking'\n })\n}\n\n// Logging removed to minimize runtime surface area; behavior unaffected\n\nfunction textContentBlocksEqual(cb1: TextBlock, cb2: TextBlock): boolean {\n return cb1.text === cb2.text\n}\n\nfunction contentBlocksEqual(\n cb1: TextBlock | ToolUseBlock,\n cb2: TextBlock | ToolUseBlock,\n): boolean {\n if (cb1.type !== cb2.type) {\n return false\n }\n if (cb1.type === 'text') {\n return textContentBlocksEqual(cb1, cb2 as TextBlock)\n }\n cb2 = cb2 as ToolUseBlock\n return cb1.name === cb2.name && isEqual(cb1.input, cb2.input)\n}\n\nfunction allContentBlocksEqual(\n content1: (TextBlock | ToolUseBlock)[],\n content2: (TextBlock | ToolUseBlock)[],\n): boolean {\n if (content1.length !== content2.length) {\n return false\n }\n return zip(content1, content2).every(([cb1, cb2]) =>\n contentBlocksEqual(cb1!, cb2!),\n )\n}\n\nexport async function shouldUseBinaryFeedback(): Promise<boolean> {\n if (process.env.DISABLE_BINARY_FEEDBACK) {\n return false\n }\n if (process.env.FORCE_BINARY_FEEDBACK) {\n return true\n }\n if (process.env.USER_TYPE !== 'ant') {\n return false\n }\n if (process.env.NODE_ENV === 'test') {\n // Binary feedback breaks a couple tests related to checking for permission,\n // so we have to disable it in tests at the risk of hiding bugs\n return false\n }\n\n const config = await getBinaryFeedbackConfig()\n if (config.sampleFrequency === 0) {\n return false\n }\n if (Math.random() > config.sampleFrequency) {\n return false\n }\n return true\n}\n\nexport function messagePairValidForBinaryFeedback(\n m1: AssistantMessage,\n m2: AssistantMessage,\n): boolean {\n const logPass = () => {}\n const logFail = (_reason: string) => {}\n\n // Ignore thinking blocks, on the assumption that users don't find them very relevant\n // compared to other content types\n const nonThinkingBlocks1 = m1.message.content.filter(\n b => b.type !== 'thinking' && b.type !== 'redacted_thinking',\n )\n const nonThinkingBlocks2 = m2.message.content.filter(\n b => b.type !== 'thinking' && b.type !== 'redacted_thinking',\n )\n const hasToolUse =\n nonThinkingBlocks1.some(b => b.type === 'tool_use') ||\n nonThinkingBlocks2.some(b => b.type === 'tool_use')\n\n // If they're all text blocks, compare those\n if (!hasToolUse) {\n if (allContentBlocksEqual(nonThinkingBlocks1, nonThinkingBlocks2)) {\n logFail('contents_identical')\n return false\n }\n logPass()\n return true\n }\n\n // If there are tools, they're the most material difference between the messages.\n // Only show binary feedback if there's a tool use difference, ignoring text.\n if (\n allContentBlocksEqual(\n nonThinkingBlocks1.filter(b => b.type === 'tool_use'),\n nonThinkingBlocks2.filter(b => b.type === 'tool_use'),\n )\n ) {\n logFail('contents_identical')\n return false\n }\n\n logPass()\n return true\n}\n\nexport function getBinaryFeedbackResultForChoice(\n m1: AssistantMessage,\n m2: AssistantMessage,\n choice: BinaryFeedbackChoice,\n): BinaryFeedbackResult {\n switch (choice) {\n case 'prefer-left':\n return { message: m1, shouldSkipPermissionCheck: true }\n case 'prefer-right':\n return { message: m2, shouldSkipPermissionCheck: true }\n case 'no-preference':\n return {\n message: Math.random() < 0.5 ? m1 : m2,\n shouldSkipPermissionCheck: false,\n }\n case 'neither':\n return { message: null, shouldSkipPermissionCheck: false }\n }\n}\n// Keep a minimal exported stub to satisfy imports without side effects\nexport async function logBinaryFeedbackEvent(\n _m1: AssistantMessage,\n _m2: AssistantMessage,\n _choice: BinaryFeedbackChoice,\n): Promise<void> {}\n"],
|
|
5
|
+
"mappings": "AAIA,SAAS,SAAS,WAAW;AAe7B,eAAe,0BAAyD;AACtE,SAAO,EAAE,iBAAiB,EAAE;AAC9B;AAEA,SAAS,wBAAwB,GAAqB;AACpD,SAAO,EAAE,QAAQ,QAAQ,IAAI,QAAM;AACjC,QAAI,GAAG,SAAS,OAAQ,QAAO;AAC/B,QAAI,GAAG,SAAS,WAAY,QAAO,GAAG;AACtC,WAAO,GAAG;AAAA,EACZ,CAAC;AACH;AAIA,SAAS,uBAAuB,KAAgB,KAAyB;AACvE,SAAO,IAAI,SAAS,IAAI;AAC1B;AAEA,SAAS,mBACP,KACA,KACS;AACT,MAAI,IAAI,SAAS,IAAI,MAAM;AACzB,WAAO;AAAA,EACT;AACA,MAAI,IAAI,SAAS,QAAQ;AACvB,WAAO,uBAAuB,KAAK,GAAgB;AAAA,EACrD;AACA,QAAM;AACN,SAAO,IAAI,SAAS,IAAI,QAAQ,QAAQ,IAAI,OAAO,IAAI,KAAK;AAC9D;AAEA,SAAS,sBACP,UACA,UACS;AACT,MAAI,SAAS,WAAW,SAAS,QAAQ;AACvC,WAAO;AAAA,EACT;AACA,SAAO,IAAI,UAAU,QAAQ,EAAE;AAAA,IAAM,CAAC,CAAC,KAAK,GAAG,MAC7C,mBAAmB,KAAM,GAAI;AAAA,EAC/B;AACF;AAEA,eAAsB,0BAA4C;AAChE,MAAI,QAAQ,IAAI,yBAAyB;AACvC,WAAO;AAAA,EACT;AACA,MAAI,QAAQ,IAAI,uBAAuB;AACrC,WAAO;AAAA,EACT;AACA,MAAI,QAAQ,IAAI,cAAc,OAAO;AACnC,WAAO;AAAA,EACT;AACA,MAAI,QAAQ,IAAI,aAAa,QAAQ;AAGnC,WAAO;AAAA,EACT;AAEA,QAAM,SAAS,MAAM,wBAAwB;AAC7C,MAAI,OAAO,oBAAoB,GAAG;AAChC,WAAO;AAAA,EACT;AACA,MAAI,KAAK,OAAO,IAAI,OAAO,iBAAiB;AAC1C,WAAO;AAAA,EACT;AACA,SAAO;AACT;AAEO,SAAS,kCACd,IACA,IACS;AACT,QAAM,UAAU,MAAM;AAAA,EAAC;AACvB,QAAM,UAAU,CAAC,YAAoB;AAAA,EAAC;AAItC,QAAM,qBAAqB,GAAG,QAAQ,QAAQ;AAAA,IAC5C,OAAK,EAAE,SAAS,cAAc,EAAE,SAAS;AAAA,EAC3C;AACA,QAAM,qBAAqB,GAAG,QAAQ,QAAQ;AAAA,IAC5C,OAAK,EAAE,SAAS,cAAc,EAAE,SAAS;AAAA,EAC3C;AACA,QAAM,aACJ,mBAAmB,KAAK,OAAK,EAAE,SAAS,UAAU,KAClD,mBAAmB,KAAK,OAAK,EAAE,SAAS,UAAU;AAGpD,MAAI,CAAC,YAAY;AACf,QAAI,sBAAsB,oBAAoB,kBAAkB,GAAG;AACjE,cAAQ,oBAAoB;AAC5B,aAAO;AAAA,IACT;AACA,YAAQ;AACR,WAAO;AAAA,EACT;AAIA,MACE;AAAA,IACE,mBAAmB,OAAO,OAAK,EAAE,SAAS,UAAU;AAAA,IACpD,mBAAmB,OAAO,OAAK,EAAE,SAAS,UAAU;AAAA,EACtD,GACA;AACA,YAAQ,oBAAoB;AAC5B,WAAO;AAAA,EACT;AAEA,UAAQ;AACR,SAAO;AACT;AAEO,SAAS,iCACd,IACA,IACA,QACsB;AACtB,UAAQ,QAAQ;AAAA,IACd,KAAK;AACH,aAAO,EAAE,SAAS,IAAI,2BAA2B,KAAK;AAAA,IACxD,KAAK;AACH,aAAO,EAAE,SAAS,IAAI,2BAA2B,KAAK;AAAA,IACxD,KAAK;AACH,aAAO;AAAA,QACL,SAAS,KAAK,OAAO,IAAI,MAAM,KAAK;AAAA,QACpC,2BAA2B;AAAA,MAC7B;AAAA,IACF,KAAK;AACH,aAAO,EAAE,SAAS,MAAM,2BAA2B,MAAM;AAAA,EAC7D;AACF;AAEA,eAAsB,uBACpB,KACA,KACA,SACe;AAAC;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import BashToolResultMessage from "../../tools/BashTool/BashToolResultMessage.js";
|
|
3
|
+
import { extractTag } from "../../utils/messages.js";
|
|
4
|
+
function AssistantBashOutputMessage({
|
|
5
|
+
content,
|
|
6
|
+
verbose
|
|
7
|
+
}) {
|
|
8
|
+
const stdout = extractTag(content, "bash-stdout") ?? "";
|
|
9
|
+
const stderr = extractTag(content, "bash-stderr") ?? "";
|
|
10
|
+
const stdoutLines = stdout.split("\n").length;
|
|
11
|
+
const stderrLines = stderr.split("\n").length;
|
|
12
|
+
return /* @__PURE__ */ React.createElement(
|
|
13
|
+
BashToolResultMessage,
|
|
14
|
+
{
|
|
15
|
+
content: { stdout, stdoutLines, stderr, stderrLines },
|
|
16
|
+
verbose: !!verbose
|
|
17
|
+
}
|
|
18
|
+
);
|
|
19
|
+
}
|
|
20
|
+
export {
|
|
21
|
+
AssistantBashOutputMessage
|
|
22
|
+
};
|
|
23
|
+
//# sourceMappingURL=AssistantBashOutputMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/AssistantBashOutputMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import * as React from 'react'\nimport BashToolResultMessage from '@tools/BashTool/BashToolResultMessage'\nimport { extractTag } from '@utils/messages'\n\nexport function AssistantBashOutputMessage({\n content,\n verbose,\n}: {\n content: string\n verbose?: boolean\n}): React.ReactNode {\n const stdout = extractTag(content, 'bash-stdout') ?? ''\n const stderr = extractTag(content, 'bash-stderr') ?? ''\n const stdoutLines = stdout.split('\\n').length\n const stderrLines = stderr.split('\\n').length\n return (\n <BashToolResultMessage\n content={{ stdout, stdoutLines, stderr, stderrLines }}\n verbose={!!verbose}\n />\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,YAAY,WAAW;AACvB,OAAO,2BAA2B;AAClC,SAAS,kBAAkB;AAEpB,SAAS,2BAA2B;AAAA,EACzC;AAAA,EACA;AACF,GAGoB;AAClB,QAAM,SAAS,WAAW,SAAS,aAAa,KAAK;AACrD,QAAM,SAAS,WAAW,SAAS,aAAa,KAAK;AACrD,QAAM,cAAc,OAAO,MAAM,IAAI,EAAE;AACvC,QAAM,cAAc,OAAO,MAAM,IAAI,EAAE;AACvC,SACE;AAAA,IAAC;AAAA;AAAA,MACC,SAAS,EAAE,QAAQ,aAAa,QAAQ,YAAY;AAAA,MACpD,SAAS,CAAC,CAAC;AAAA;AAAA,EACb;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import { extractTag } from "../../utils/messages.js";
|
|
3
|
+
import { getTheme } from "../../utils/theme.js";
|
|
4
|
+
import { Box, Text } from "ink";
|
|
5
|
+
function AssistantLocalCommandOutputMessage({
|
|
6
|
+
content
|
|
7
|
+
}) {
|
|
8
|
+
const stdout = extractTag(content, "local-command-stdout");
|
|
9
|
+
const stderr = extractTag(content, "local-command-stderr");
|
|
10
|
+
if (!stdout && !stderr) {
|
|
11
|
+
return [];
|
|
12
|
+
}
|
|
13
|
+
const theme = getTheme();
|
|
14
|
+
let insides = [
|
|
15
|
+
format(stdout?.trim(), theme.text),
|
|
16
|
+
format(stderr?.trim(), theme.error)
|
|
17
|
+
].filter(Boolean);
|
|
18
|
+
if (insides.length === 0) {
|
|
19
|
+
insides = [
|
|
20
|
+
/* @__PURE__ */ React.createElement(React.Fragment, { key: "0" }, /* @__PURE__ */ React.createElement(Text, null, "(No output)"))
|
|
21
|
+
];
|
|
22
|
+
}
|
|
23
|
+
return [
|
|
24
|
+
/* @__PURE__ */ React.createElement(Box, { key: "0", gap: 1 }, /* @__PURE__ */ React.createElement(Box, null, /* @__PURE__ */ React.createElement(Text, { color: theme.secondaryText }, " ", "\u23BF ")), insides.map((_, index) => /* @__PURE__ */ React.createElement(Box, { key: index, flexDirection: "column" }, _)))
|
|
25
|
+
];
|
|
26
|
+
}
|
|
27
|
+
function format(content, color) {
|
|
28
|
+
if (!content) {
|
|
29
|
+
return null;
|
|
30
|
+
}
|
|
31
|
+
return /* @__PURE__ */ React.createElement(Text, { color }, content);
|
|
32
|
+
}
|
|
33
|
+
export {
|
|
34
|
+
AssistantLocalCommandOutputMessage
|
|
35
|
+
};
|
|
36
|
+
//# sourceMappingURL=AssistantLocalCommandOutputMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/AssistantLocalCommandOutputMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import * as React from 'react'\nimport { extractTag } from '@utils/messages'\nimport { getTheme } from '@utils/theme'\nimport { Box, Text } from 'ink'\n\nexport function AssistantLocalCommandOutputMessage({\n content,\n}: {\n content: string\n}): React.ReactNode[] {\n const stdout = extractTag(content, 'local-command-stdout')\n const stderr = extractTag(content, 'local-command-stderr')\n if (!stdout && !stderr) {\n return []\n }\n const theme = getTheme()\n let insides = [\n format(stdout?.trim(), theme.text),\n format(stderr?.trim(), theme.error),\n ].filter(Boolean)\n\n if (insides.length === 0) {\n insides = [\n <React.Fragment key=\"0\">\n <Text>(No output)</Text>\n </React.Fragment>\n ]\n }\n\n return [\n <Box key=\"0\" gap={1}>\n <Box>\n <Text color={theme.secondaryText}>{' '}\u23BF </Text>\n </Box>\n {insides.map((_, index) => (\n <Box key={index} flexDirection=\"column\">\n {_}\n </Box>\n ))}\n </Box>,\n ]\n}\n\nfunction format(content: string | undefined, color: string): React.ReactNode {\n if (!content) {\n return null\n }\n return <Text color={color}>{content}</Text>\n}\n"],
|
|
5
|
+
"mappings": "AAAA,YAAY,WAAW;AACvB,SAAS,kBAAkB;AAC3B,SAAS,gBAAgB;AACzB,SAAS,KAAK,YAAY;AAEnB,SAAS,mCAAmC;AAAA,EACjD;AACF,GAEsB;AACpB,QAAM,SAAS,WAAW,SAAS,sBAAsB;AACzD,QAAM,SAAS,WAAW,SAAS,sBAAsB;AACzD,MAAI,CAAC,UAAU,CAAC,QAAQ;AACtB,WAAO,CAAC;AAAA,EACV;AACA,QAAM,QAAQ,SAAS;AACvB,MAAI,UAAU;AAAA,IACZ,OAAO,QAAQ,KAAK,GAAG,MAAM,IAAI;AAAA,IACjC,OAAO,QAAQ,KAAK,GAAG,MAAM,KAAK;AAAA,EACpC,EAAE,OAAO,OAAO;AAEhB,MAAI,QAAQ,WAAW,GAAG;AACxB,cAAU;AAAA,MACR,oCAAC,MAAM,UAAN,EAAe,KAAI,OAClB,oCAAC,YAAK,aAAW,CACnB;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AAAA,IACL,oCAAC,OAAI,KAAI,KAAI,KAAK,KAChB,oCAAC,WACC,oCAAC,QAAK,OAAO,MAAM,iBAAgB,MAAK,SAAE,CAC5C,GACC,QAAQ,IAAI,CAAC,GAAG,UACf,oCAAC,OAAI,KAAK,OAAO,eAAc,YAC5B,CACH,CACD,CACH;AAAA,EACF;AACF;AAEA,SAAS,OAAO,SAA6B,OAAgC;AAC3E,MAAI,CAAC,SAAS;AACZ,WAAO;AAAA,EACT;AACA,SAAO,oCAAC,QAAK,SAAe,OAAQ;AACtC;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Box, Text } from "ink";
|
|
3
|
+
import { getTheme } from "../../utils/theme.js";
|
|
4
|
+
function AssistantRedactedThinkingMessage({
|
|
5
|
+
addMargin = false
|
|
6
|
+
}) {
|
|
7
|
+
return /* @__PURE__ */ React.createElement(Box, { marginTop: addMargin ? 1 : 0 }, /* @__PURE__ */ React.createElement(Text, { color: getTheme().secondaryText, italic: true }, "\u273B Thinking\u2026"));
|
|
8
|
+
}
|
|
9
|
+
export {
|
|
10
|
+
AssistantRedactedThinkingMessage
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=AssistantRedactedThinkingMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/AssistantRedactedThinkingMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import React from 'react'\nimport { Box, Text } from 'ink'\nimport { getTheme } from '@utils/theme'\n\ntype Props = {\n addMargin: boolean\n}\n\nexport function AssistantRedactedThinkingMessage({\n addMargin = false,\n}: Props): React.ReactNode {\n return (\n <Box marginTop={addMargin ? 1 : 0}>\n <Text color={getTheme().secondaryText} italic>\n \u273B Thinking\u2026\n </Text>\n </Box>\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,OAAO,WAAW;AAClB,SAAS,KAAK,YAAY;AAC1B,SAAS,gBAAgB;AAMlB,SAAS,iCAAiC;AAAA,EAC/C,YAAY;AACd,GAA2B;AACzB,SACE,oCAAC,OAAI,WAAW,YAAY,IAAI,KAC9B,oCAAC,QAAK,OAAO,SAAS,EAAE,eAAe,QAAM,QAAC,uBAE9C,CACF;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { AssistantBashOutputMessage } from "./AssistantBashOutputMessage.js";
|
|
3
|
+
import { AssistantLocalCommandOutputMessage } from "./AssistantLocalCommandOutputMessage.js";
|
|
4
|
+
import { getTheme } from "../../utils/theme.js";
|
|
5
|
+
import { Box, Text } from "ink";
|
|
6
|
+
import { Cost } from "../Cost.js";
|
|
7
|
+
import {
|
|
8
|
+
API_ERROR_MESSAGE_PREFIX,
|
|
9
|
+
CREDIT_BALANCE_TOO_LOW_ERROR_MESSAGE,
|
|
10
|
+
INVALID_API_KEY_ERROR_MESSAGE,
|
|
11
|
+
PROMPT_TOO_LONG_ERROR_MESSAGE
|
|
12
|
+
} from "../../services/claude.js";
|
|
13
|
+
import {
|
|
14
|
+
CANCEL_MESSAGE,
|
|
15
|
+
INTERRUPT_MESSAGE,
|
|
16
|
+
INTERRUPT_MESSAGE_FOR_TOOL_USE,
|
|
17
|
+
isEmptyMessageText,
|
|
18
|
+
NO_RESPONSE_REQUESTED
|
|
19
|
+
} from "../../utils/messages.js";
|
|
20
|
+
import { BLACK_CIRCLE } from "../../constants/figures.js";
|
|
21
|
+
import { applyMarkdown } from "../../utils/markdown.js";
|
|
22
|
+
import { useTerminalSize } from "../../hooks/useTerminalSize.js";
|
|
23
|
+
function AssistantTextMessage({
|
|
24
|
+
param: { text },
|
|
25
|
+
costUSD,
|
|
26
|
+
durationMs,
|
|
27
|
+
debug,
|
|
28
|
+
addMargin,
|
|
29
|
+
shouldShowDot,
|
|
30
|
+
verbose
|
|
31
|
+
}) {
|
|
32
|
+
const { columns } = useTerminalSize();
|
|
33
|
+
if (isEmptyMessageText(text)) {
|
|
34
|
+
return null;
|
|
35
|
+
}
|
|
36
|
+
if (text.startsWith("<bash-stdout") || text.startsWith("<bash-stderr")) {
|
|
37
|
+
return /* @__PURE__ */ React.createElement(AssistantBashOutputMessage, { content: text, verbose });
|
|
38
|
+
}
|
|
39
|
+
if (text.startsWith("<local-command-stdout") || text.startsWith("<local-command-stderr")) {
|
|
40
|
+
return /* @__PURE__ */ React.createElement(AssistantLocalCommandOutputMessage, { content: text });
|
|
41
|
+
}
|
|
42
|
+
if (text.startsWith(API_ERROR_MESSAGE_PREFIX)) {
|
|
43
|
+
return /* @__PURE__ */ React.createElement(Text, null, "\xA0\xA0\u23BF \xA0", /* @__PURE__ */ React.createElement(Text, { color: getTheme().error }, text === API_ERROR_MESSAGE_PREFIX ? `${API_ERROR_MESSAGE_PREFIX}: Please wait a moment and try again.` : text));
|
|
44
|
+
}
|
|
45
|
+
switch (text) {
|
|
46
|
+
// Local JSX commands don't need a response, but we still want the assistant to see them
|
|
47
|
+
// Tool results render their own interrupt messages
|
|
48
|
+
case NO_RESPONSE_REQUESTED:
|
|
49
|
+
case INTERRUPT_MESSAGE_FOR_TOOL_USE:
|
|
50
|
+
return null;
|
|
51
|
+
case INTERRUPT_MESSAGE:
|
|
52
|
+
case CANCEL_MESSAGE:
|
|
53
|
+
return /* @__PURE__ */ React.createElement(Text, null, "\xA0\xA0\u23BF \xA0", /* @__PURE__ */ React.createElement(Text, { color: getTheme().error }, "Interrupted by user"));
|
|
54
|
+
case PROMPT_TOO_LONG_ERROR_MESSAGE:
|
|
55
|
+
return /* @__PURE__ */ React.createElement(Text, null, "\xA0\xA0\u23BF \xA0", /* @__PURE__ */ React.createElement(Text, { color: getTheme().error }, "Context low \xB7 Run /compact to compact & continue"));
|
|
56
|
+
case CREDIT_BALANCE_TOO_LOW_ERROR_MESSAGE:
|
|
57
|
+
return /* @__PURE__ */ React.createElement(Text, null, "\xA0\xA0\u23BF \xA0", /* @__PURE__ */ React.createElement(Text, { color: getTheme().error }, "Credit balance too low \xB7 Add funds: https://console.anthropic.com/settings/billing"));
|
|
58
|
+
case INVALID_API_KEY_ERROR_MESSAGE:
|
|
59
|
+
return /* @__PURE__ */ React.createElement(Text, null, "\xA0\xA0\u23BF \xA0", /* @__PURE__ */ React.createElement(Text, { color: getTheme().error }, INVALID_API_KEY_ERROR_MESSAGE));
|
|
60
|
+
default:
|
|
61
|
+
return /* @__PURE__ */ React.createElement(
|
|
62
|
+
Box,
|
|
63
|
+
{
|
|
64
|
+
alignItems: "flex-start",
|
|
65
|
+
flexDirection: "row",
|
|
66
|
+
justifyContent: "space-between",
|
|
67
|
+
marginTop: addMargin ? 1 : 0,
|
|
68
|
+
width: "100%"
|
|
69
|
+
},
|
|
70
|
+
/* @__PURE__ */ React.createElement(Box, { flexDirection: "row" }, shouldShowDot && /* @__PURE__ */ React.createElement(Box, { minWidth: 2 }, /* @__PURE__ */ React.createElement(Text, { color: getTheme().text }, BLACK_CIRCLE)), /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", width: columns - 6 }, /* @__PURE__ */ React.createElement(Text, null, applyMarkdown(text)))),
|
|
71
|
+
/* @__PURE__ */ React.createElement(Cost, { costUSD, durationMs, debug })
|
|
72
|
+
);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
export {
|
|
76
|
+
AssistantTextMessage
|
|
77
|
+
};
|
|
78
|
+
//# sourceMappingURL=AssistantTextMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/AssistantTextMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'\nimport React from 'react'\nimport { AssistantBashOutputMessage } from './AssistantBashOutputMessage'\nimport { AssistantLocalCommandOutputMessage } from './AssistantLocalCommandOutputMessage'\nimport { getTheme } from '@utils/theme'\nimport { Box, Text } from 'ink'\nimport { Cost } from '@components/Cost'\nimport {\n API_ERROR_MESSAGE_PREFIX,\n CREDIT_BALANCE_TOO_LOW_ERROR_MESSAGE,\n INVALID_API_KEY_ERROR_MESSAGE,\n PROMPT_TOO_LONG_ERROR_MESSAGE,\n} from '@services/claude'\nimport {\n CANCEL_MESSAGE,\n INTERRUPT_MESSAGE,\n INTERRUPT_MESSAGE_FOR_TOOL_USE,\n isEmptyMessageText,\n NO_RESPONSE_REQUESTED,\n} from '@utils/messages'\nimport { BLACK_CIRCLE } from '@constants/figures'\nimport { applyMarkdown } from '@utils/markdown'\nimport { useTerminalSize } from '@hooks/useTerminalSize'\n\ntype Props = {\n param: TextBlockParam\n costUSD: number\n durationMs: number\n debug: boolean\n addMargin: boolean\n shouldShowDot: boolean\n verbose?: boolean\n width?: number | string\n}\n\nexport function AssistantTextMessage({\n param: { text },\n costUSD,\n durationMs,\n debug,\n addMargin,\n shouldShowDot,\n verbose,\n}: Props): React.ReactNode {\n const { columns } = useTerminalSize()\n if (isEmptyMessageText(text)) {\n return null\n }\n\n // Show bash output\n if (text.startsWith('<bash-stdout') || text.startsWith('<bash-stderr')) {\n return <AssistantBashOutputMessage content={text} verbose={verbose} />\n }\n\n // Show command output\n if (\n text.startsWith('<local-command-stdout') ||\n text.startsWith('<local-command-stderr')\n ) {\n return <AssistantLocalCommandOutputMessage content={text} />\n }\n\n if (text.startsWith(API_ERROR_MESSAGE_PREFIX)) {\n return (\n <Text>\n \u23BF \n <Text color={getTheme().error}>\n {text === API_ERROR_MESSAGE_PREFIX\n ? `${API_ERROR_MESSAGE_PREFIX}: Please wait a moment and try again.`\n : text}\n </Text>\n </Text>\n )\n }\n\n switch (text) {\n // Local JSX commands don't need a response, but we still want the assistant to see them\n // Tool results render their own interrupt messages\n case NO_RESPONSE_REQUESTED:\n case INTERRUPT_MESSAGE_FOR_TOOL_USE:\n return null\n\n case INTERRUPT_MESSAGE:\n case CANCEL_MESSAGE:\n return (\n <Text>\n \u23BF \n <Text color={getTheme().error}>Interrupted by user</Text>\n </Text>\n )\n\n case PROMPT_TOO_LONG_ERROR_MESSAGE:\n return (\n <Text>\n \u23BF \n <Text color={getTheme().error}>\n Context low · Run /compact to compact & continue\n </Text>\n </Text>\n )\n\n case CREDIT_BALANCE_TOO_LOW_ERROR_MESSAGE:\n return (\n <Text>\n \u23BF \n <Text color={getTheme().error}>\n Credit balance too low · Add funds:\n https://console.anthropic.com/settings/billing\n </Text>\n </Text>\n )\n\n case INVALID_API_KEY_ERROR_MESSAGE:\n return (\n <Text>\n \u23BF \n <Text color={getTheme().error}>{INVALID_API_KEY_ERROR_MESSAGE}</Text>\n </Text>\n )\n\n default:\n return (\n <Box\n alignItems=\"flex-start\"\n flexDirection=\"row\"\n justifyContent=\"space-between\"\n marginTop={addMargin ? 1 : 0}\n width=\"100%\"\n >\n <Box flexDirection=\"row\">\n {shouldShowDot && (\n <Box minWidth={2}>\n <Text color={getTheme().text}>{BLACK_CIRCLE}</Text>\n </Box>\n )}\n <Box flexDirection=\"column\" width={columns - 6}>\n <Text>{applyMarkdown(text)}</Text>\n </Box>\n </Box>\n <Cost costUSD={costUSD} durationMs={durationMs} debug={debug} />\n </Box>\n )\n }\n}\n"],
|
|
5
|
+
"mappings": "AACA,OAAO,WAAW;AAClB,SAAS,kCAAkC;AAC3C,SAAS,0CAA0C;AACnD,SAAS,gBAAgB;AACzB,SAAS,KAAK,YAAY;AAC1B,SAAS,YAAY;AACrB;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,oBAAoB;AAC7B,SAAS,qBAAqB;AAC9B,SAAS,uBAAuB;AAazB,SAAS,qBAAqB;AAAA,EACnC,OAAO,EAAE,KAAK;AAAA,EACd;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AACzB,QAAM,EAAE,QAAQ,IAAI,gBAAgB;AACpC,MAAI,mBAAmB,IAAI,GAAG;AAC5B,WAAO;AAAA,EACT;AAGA,MAAI,KAAK,WAAW,cAAc,KAAK,KAAK,WAAW,cAAc,GAAG;AACtE,WAAO,oCAAC,8BAA2B,SAAS,MAAM,SAAkB;AAAA,EACtE;AAGA,MACE,KAAK,WAAW,uBAAuB,KACvC,KAAK,WAAW,uBAAuB,GACvC;AACA,WAAO,oCAAC,sCAAmC,SAAS,MAAM;AAAA,EAC5D;AAEA,MAAI,KAAK,WAAW,wBAAwB,GAAG;AAC7C,WACE,oCAAC,YAAK,uBAEJ,oCAAC,QAAK,OAAO,SAAS,EAAE,SACrB,SAAS,2BACN,GAAG,wBAAwB,0CAC3B,IACN,CACF;AAAA,EAEJ;AAEA,UAAQ,MAAM;AAAA;AAAA;AAAA,IAGZ,KAAK;AAAA,IACL,KAAK;AACH,aAAO;AAAA,IAET,KAAK;AAAA,IACL,KAAK;AACH,aACE,oCAAC,YAAK,uBAEJ,oCAAC,QAAK,OAAO,SAAS,EAAE,SAAO,qBAAmB,CACpD;AAAA,IAGJ,KAAK;AACH,aACE,oCAAC,YAAK,uBAEJ,oCAAC,QAAK,OAAO,SAAS,EAAE,SAAO,qDAE/B,CACF;AAAA,IAGJ,KAAK;AACH,aACE,oCAAC,YAAK,uBAEJ,oCAAC,QAAK,OAAO,SAAS,EAAE,SAAO,uFAG/B,CACF;AAAA,IAGJ,KAAK;AACH,aACE,oCAAC,YAAK,uBAEJ,oCAAC,QAAK,OAAO,SAAS,EAAE,SAAQ,6BAA8B,CAChE;AAAA,IAGJ;AACE,aACE;AAAA,QAAC;AAAA;AAAA,UACC,YAAW;AAAA,UACX,eAAc;AAAA,UACd,gBAAe;AAAA,UACf,WAAW,YAAY,IAAI;AAAA,UAC3B,OAAM;AAAA;AAAA,QAEN,oCAAC,OAAI,eAAc,SAChB,iBACC,oCAAC,OAAI,UAAU,KACb,oCAAC,QAAK,OAAO,SAAS,EAAE,QAAO,YAAa,CAC9C,GAEF,oCAAC,OAAI,eAAc,UAAS,OAAO,UAAU,KAC3C,oCAAC,YAAM,cAAc,IAAI,CAAE,CAC7B,CACF;AAAA,QACA,oCAAC,QAAK,SAAkB,YAAwB,OAAc;AAAA,MAChE;AAAA,EAEN;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Box, Text } from "ink";
|
|
3
|
+
import { getTheme } from "../../utils/theme.js";
|
|
4
|
+
import { applyMarkdown } from "../../utils/markdown.js";
|
|
5
|
+
function AssistantThinkingMessage({
|
|
6
|
+
param: { thinking },
|
|
7
|
+
addMargin = false
|
|
8
|
+
}) {
|
|
9
|
+
if (!thinking) {
|
|
10
|
+
return null;
|
|
11
|
+
}
|
|
12
|
+
return /* @__PURE__ */ React.createElement(
|
|
13
|
+
Box,
|
|
14
|
+
{
|
|
15
|
+
flexDirection: "column",
|
|
16
|
+
gap: 1,
|
|
17
|
+
marginTop: addMargin ? 1 : 0,
|
|
18
|
+
width: "100%"
|
|
19
|
+
},
|
|
20
|
+
/* @__PURE__ */ React.createElement(Text, { color: getTheme().secondaryText, italic: true }, "\u273B Thinking\u2026"),
|
|
21
|
+
/* @__PURE__ */ React.createElement(Box, { paddingLeft: 2 }, /* @__PURE__ */ React.createElement(Text, { color: getTheme().secondaryText, italic: true }, applyMarkdown(thinking)))
|
|
22
|
+
);
|
|
23
|
+
}
|
|
24
|
+
export {
|
|
25
|
+
AssistantThinkingMessage
|
|
26
|
+
};
|
|
27
|
+
//# sourceMappingURL=AssistantThinkingMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/AssistantThinkingMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import React from 'react'\nimport { Box, Text } from 'ink'\nimport { getTheme } from '@utils/theme'\nimport { applyMarkdown } from '@utils/markdown'\nimport {\n ThinkingBlock,\n ThinkingBlockParam,\n} from '@anthropic-ai/sdk/resources/index.mjs'\n\ntype Props = {\n param: ThinkingBlock | ThinkingBlockParam\n addMargin: boolean\n}\n\nexport function AssistantThinkingMessage({\n param: { thinking },\n addMargin = false,\n}: Props): React.ReactNode {\n if (!thinking) {\n return null\n }\n\n return (\n <Box\n flexDirection=\"column\"\n gap={1}\n marginTop={addMargin ? 1 : 0}\n width=\"100%\"\n >\n <Text color={getTheme().secondaryText} italic>\n \u273B Thinking\u2026\n </Text>\n <Box paddingLeft={2}>\n <Text color={getTheme().secondaryText} italic>\n {applyMarkdown(thinking)}\n </Text>\n </Box>\n </Box>\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,OAAO,WAAW;AAClB,SAAS,KAAK,YAAY;AAC1B,SAAS,gBAAgB;AACzB,SAAS,qBAAqB;AAWvB,SAAS,yBAAyB;AAAA,EACvC,OAAO,EAAE,SAAS;AAAA,EAClB,YAAY;AACd,GAA2B;AACzB,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SACE;AAAA,IAAC;AAAA;AAAA,MACC,eAAc;AAAA,MACd,KAAK;AAAA,MACL,WAAW,YAAY,IAAI;AAAA,MAC3B,OAAM;AAAA;AAAA,IAEN,oCAAC,QAAK,OAAO,SAAS,EAAE,eAAe,QAAM,QAAC,uBAE9C;AAAA,IACA,oCAAC,OAAI,aAAa,KAChB,oCAAC,QAAK,OAAO,SAAS,EAAE,eAAe,QAAM,QAC1C,cAAc,QAAQ,CACzB,CACF;AAAA,EACF;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { Box, Text } from "ink";
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { logError } from "../../utils/log.js";
|
|
4
|
+
import { Cost } from "../Cost.js";
|
|
5
|
+
import { ToolUseLoader } from "../ToolUseLoader.js";
|
|
6
|
+
import { getTheme } from "../../utils/theme.js";
|
|
7
|
+
import { BLACK_CIRCLE } from "../../constants/figures.js";
|
|
8
|
+
import { ThinkTool } from "../../tools/ThinkTool/ThinkTool.js";
|
|
9
|
+
import { AssistantThinkingMessage } from "./AssistantThinkingMessage.js";
|
|
10
|
+
import { TaskToolMessage } from "./TaskToolMessage.js";
|
|
11
|
+
function AssistantToolUseMessage({
|
|
12
|
+
param,
|
|
13
|
+
costUSD,
|
|
14
|
+
durationMs,
|
|
15
|
+
addMargin,
|
|
16
|
+
tools,
|
|
17
|
+
debug,
|
|
18
|
+
verbose,
|
|
19
|
+
erroredToolUseIDs,
|
|
20
|
+
inProgressToolUseIDs,
|
|
21
|
+
unresolvedToolUseIDs,
|
|
22
|
+
shouldAnimate,
|
|
23
|
+
shouldShowDot
|
|
24
|
+
}) {
|
|
25
|
+
const tool = tools.find((_) => _.name === param.name);
|
|
26
|
+
if (!tool) {
|
|
27
|
+
logError(`Tool ${param.name} not found`);
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
30
|
+
const isQueued = !inProgressToolUseIDs.has(param.id) && unresolvedToolUseIDs.has(param.id);
|
|
31
|
+
const color = isQueued ? getTheme().secondaryText : void 0;
|
|
32
|
+
if (tool === ThinkTool) {
|
|
33
|
+
const { thought } = ThinkTool.inputSchema.parse(param.input);
|
|
34
|
+
return /* @__PURE__ */ React.createElement(
|
|
35
|
+
AssistantThinkingMessage,
|
|
36
|
+
{
|
|
37
|
+
param: { thinking: thought, signature: "", type: "thinking" },
|
|
38
|
+
addMargin
|
|
39
|
+
}
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
const userFacingToolName = tool.userFacingName ? tool.userFacingName() : tool.name;
|
|
43
|
+
return /* @__PURE__ */ React.createElement(
|
|
44
|
+
Box,
|
|
45
|
+
{
|
|
46
|
+
flexDirection: "row",
|
|
47
|
+
justifyContent: "space-between",
|
|
48
|
+
marginTop: addMargin ? 1 : 0,
|
|
49
|
+
width: "100%"
|
|
50
|
+
},
|
|
51
|
+
/* @__PURE__ */ React.createElement(Box, null, /* @__PURE__ */ React.createElement(
|
|
52
|
+
Box,
|
|
53
|
+
{
|
|
54
|
+
flexWrap: "nowrap",
|
|
55
|
+
minWidth: userFacingToolName.length + (shouldShowDot ? 2 : 0)
|
|
56
|
+
},
|
|
57
|
+
shouldShowDot && (isQueued ? /* @__PURE__ */ React.createElement(Box, { minWidth: 2 }, /* @__PURE__ */ React.createElement(Text, { color }, BLACK_CIRCLE)) : /* @__PURE__ */ React.createElement(
|
|
58
|
+
ToolUseLoader,
|
|
59
|
+
{
|
|
60
|
+
shouldAnimate,
|
|
61
|
+
isUnresolved: unresolvedToolUseIDs.has(param.id),
|
|
62
|
+
isError: erroredToolUseIDs.has(param.id)
|
|
63
|
+
}
|
|
64
|
+
)),
|
|
65
|
+
tool.name === "Task" && param.input ? /* @__PURE__ */ React.createElement(
|
|
66
|
+
TaskToolMessage,
|
|
67
|
+
{
|
|
68
|
+
agentType: String(param.input.subagent_type || "general-purpose"),
|
|
69
|
+
bold: Boolean(!isQueued),
|
|
70
|
+
children: String(userFacingToolName || "")
|
|
71
|
+
}
|
|
72
|
+
) : /* @__PURE__ */ React.createElement(Text, { color, bold: !isQueued }, userFacingToolName)
|
|
73
|
+
), /* @__PURE__ */ React.createElement(Box, { flexWrap: "nowrap" }, Object.keys(param.input).length > 0 && (() => {
|
|
74
|
+
const toolMessage = tool.renderToolUseMessage(
|
|
75
|
+
param.input,
|
|
76
|
+
{
|
|
77
|
+
verbose
|
|
78
|
+
}
|
|
79
|
+
);
|
|
80
|
+
if (React.isValidElement(toolMessage)) {
|
|
81
|
+
return /* @__PURE__ */ React.createElement(Box, { flexDirection: "row" }, /* @__PURE__ */ React.createElement(Text, { color }, "("), toolMessage, /* @__PURE__ */ React.createElement(Text, { color }, ")"));
|
|
82
|
+
}
|
|
83
|
+
return /* @__PURE__ */ React.createElement(Text, { color }, "(", toolMessage, ")");
|
|
84
|
+
})(), /* @__PURE__ */ React.createElement(Text, { color }, "\u2026"))),
|
|
85
|
+
/* @__PURE__ */ React.createElement(Cost, { costUSD, durationMs, debug })
|
|
86
|
+
);
|
|
87
|
+
}
|
|
88
|
+
export {
|
|
89
|
+
AssistantToolUseMessage
|
|
90
|
+
};
|
|
91
|
+
//# sourceMappingURL=AssistantToolUseMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/AssistantToolUseMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import { Box, Text } from 'ink'\nimport React from 'react'\nimport { logError } from '@utils/log'\nimport { ToolUseBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'\nimport { Tool } from '@tool'\nimport { Cost } from '@components/Cost'\nimport { ToolUseLoader } from '@components/ToolUseLoader'\nimport { getTheme } from '@utils/theme'\nimport { BLACK_CIRCLE } from '@constants/figures'\nimport { ThinkTool } from '@tools/ThinkTool/ThinkTool'\nimport { AssistantThinkingMessage } from './AssistantThinkingMessage'\nimport { TaskToolMessage } from './TaskToolMessage'\n\ntype Props = {\n param: ToolUseBlockParam\n costUSD: number\n durationMs: number\n addMargin: boolean\n tools: Tool[]\n debug: boolean\n verbose: boolean\n erroredToolUseIDs: Set<string>\n inProgressToolUseIDs: Set<string>\n unresolvedToolUseIDs: Set<string>\n shouldAnimate: boolean\n shouldShowDot: boolean\n}\n\nexport function AssistantToolUseMessage({\n param,\n costUSD,\n durationMs,\n addMargin,\n tools,\n debug,\n verbose,\n erroredToolUseIDs,\n inProgressToolUseIDs,\n unresolvedToolUseIDs,\n shouldAnimate,\n shouldShowDot,\n}: Props): React.ReactNode {\n const tool = tools.find(_ => _.name === param.name)\n if (!tool) {\n logError(`Tool ${param.name} not found`)\n return null\n }\n const isQueued =\n !inProgressToolUseIDs.has(param.id) && unresolvedToolUseIDs.has(param.id)\n // Keeping color undefined makes the OS use the default color regardless of appearance\n const color = isQueued ? getTheme().secondaryText : undefined\n\n // Handle thinking tool with specialized rendering\n if (tool === ThinkTool) {\n const { thought } = ThinkTool.inputSchema.parse(param.input)\n return (\n <AssistantThinkingMessage\n param={{ thinking: thought, signature: '', type: 'thinking' }}\n addMargin={addMargin}\n />\n )\n }\n\n const userFacingToolName = tool.userFacingName ? tool.userFacingName() : tool.name\n return (\n <Box\n flexDirection=\"row\"\n justifyContent=\"space-between\"\n marginTop={addMargin ? 1 : 0}\n width=\"100%\"\n >\n <Box>\n <Box\n flexWrap=\"nowrap\"\n minWidth={userFacingToolName.length + (shouldShowDot ? 2 : 0)}\n >\n {shouldShowDot &&\n (isQueued ? (\n <Box minWidth={2}>\n <Text color={color}>{BLACK_CIRCLE}</Text>\n </Box>\n ) : (\n <ToolUseLoader\n shouldAnimate={shouldAnimate}\n isUnresolved={unresolvedToolUseIDs.has(param.id)}\n isError={erroredToolUseIDs.has(param.id)}\n />\n ))}\n {tool.name === 'Task' && param.input ? (\n <TaskToolMessage\n agentType={String((param.input as any).subagent_type || 'general-purpose')}\n bold={Boolean(!isQueued)}\n children={String(userFacingToolName || '')}\n />\n ) : (\n <Text color={color} bold={!isQueued}>\n {userFacingToolName}\n </Text>\n )}\n </Box>\n <Box flexWrap=\"nowrap\">\n {Object.keys(param.input as { [key: string]: unknown }).length > 0 &&\n (() => {\n const toolMessage = tool.renderToolUseMessage(\n param.input as never,\n {\n verbose,\n },\n )\n\n // If the tool returns a React component, render it directly\n if (React.isValidElement(toolMessage)) {\n return (\n <Box flexDirection=\"row\">\n <Text color={color}>(</Text>\n {toolMessage}\n <Text color={color}>)</Text>\n </Box>\n )\n }\n\n // If it's a string, wrap it in Text\n return <Text color={color}>({toolMessage})</Text>\n })()}\n <Text color={color}>\u2026</Text>\n </Box>\n </Box>\n <Cost costUSD={costUSD} durationMs={durationMs} debug={debug} />\n </Box>\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,KAAK,YAAY;AAC1B,OAAO,WAAW;AAClB,SAAS,gBAAgB;AAGzB,SAAS,YAAY;AACrB,SAAS,qBAAqB;AAC9B,SAAS,gBAAgB;AACzB,SAAS,oBAAoB;AAC7B,SAAS,iBAAiB;AAC1B,SAAS,gCAAgC;AACzC,SAAS,uBAAuB;AAiBzB,SAAS,wBAAwB;AAAA,EACtC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AACzB,QAAM,OAAO,MAAM,KAAK,OAAK,EAAE,SAAS,MAAM,IAAI;AAClD,MAAI,CAAC,MAAM;AACT,aAAS,QAAQ,MAAM,IAAI,YAAY;AACvC,WAAO;AAAA,EACT;AACA,QAAM,WACJ,CAAC,qBAAqB,IAAI,MAAM,EAAE,KAAK,qBAAqB,IAAI,MAAM,EAAE;AAE1E,QAAM,QAAQ,WAAW,SAAS,EAAE,gBAAgB;AAGpD,MAAI,SAAS,WAAW;AACtB,UAAM,EAAE,QAAQ,IAAI,UAAU,YAAY,MAAM,MAAM,KAAK;AAC3D,WACE;AAAA,MAAC;AAAA;AAAA,QACC,OAAO,EAAE,UAAU,SAAS,WAAW,IAAI,MAAM,WAAW;AAAA,QAC5D;AAAA;AAAA,IACF;AAAA,EAEJ;AAEA,QAAM,qBAAqB,KAAK,iBAAiB,KAAK,eAAe,IAAI,KAAK;AAC9E,SACE;AAAA,IAAC;AAAA;AAAA,MACC,eAAc;AAAA,MACd,gBAAe;AAAA,MACf,WAAW,YAAY,IAAI;AAAA,MAC3B,OAAM;AAAA;AAAA,IAEN,oCAAC,WACC;AAAA,MAAC;AAAA;AAAA,QACC,UAAS;AAAA,QACT,UAAU,mBAAmB,UAAU,gBAAgB,IAAI;AAAA;AAAA,MAE1D,kBACE,WACC,oCAAC,OAAI,UAAU,KACb,oCAAC,QAAK,SAAe,YAAa,CACpC,IAEA;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA,cAAc,qBAAqB,IAAI,MAAM,EAAE;AAAA,UAC/C,SAAS,kBAAkB,IAAI,MAAM,EAAE;AAAA;AAAA,MACzC;AAAA,MAEH,KAAK,SAAS,UAAU,MAAM,QAC7B;AAAA,QAAC;AAAA;AAAA,UACC,WAAW,OAAQ,MAAM,MAAc,iBAAiB,iBAAiB;AAAA,UACzE,MAAM,QAAQ,CAAC,QAAQ;AAAA,UACvB,UAAU,OAAO,sBAAsB,EAAE;AAAA;AAAA,MAC3C,IAEA,oCAAC,QAAK,OAAc,MAAM,CAAC,YACxB,kBACH;AAAA,IAEJ,GACA,oCAAC,OAAI,UAAS,YACX,OAAO,KAAK,MAAM,KAAmC,EAAE,SAAS,MAC9D,MAAM;AACL,YAAM,cAAc,KAAK;AAAA,QACvB,MAAM;AAAA,QACN;AAAA,UACE;AAAA,QACF;AAAA,MACF;AAGA,UAAI,MAAM,eAAe,WAAW,GAAG;AACrC,eACE,oCAAC,OAAI,eAAc,SACjB,oCAAC,QAAK,SAAc,GAAC,GACpB,aACD,oCAAC,QAAK,SAAc,GAAC,CACvB;AAAA,MAEJ;AAGA,aAAO,oCAAC,QAAK,SAAc,KAAE,aAAY,GAAC;AAAA,IAC5C,GAAG,GACL,oCAAC,QAAK,SAAc,QAAC,CACvB,CACF;AAAA,IACA,oCAAC,QAAK,SAAkB,YAAwB,OAAc;AAAA,EAChE;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Box, Text } from "ink";
|
|
3
|
+
import { getTheme } from "../../utils/theme.js";
|
|
4
|
+
function TaskProgressMessage({ agentType, status, toolCount }) {
|
|
5
|
+
const theme = getTheme();
|
|
6
|
+
return /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", marginTop: 1 }, /* @__PURE__ */ React.createElement(Box, { flexDirection: "row" }, /* @__PURE__ */ React.createElement(Text, { color: theme.minto }, "\u23AF "), /* @__PURE__ */ React.createElement(Text, { color: theme.text, bold: true }, "[", agentType, "]"), /* @__PURE__ */ React.createElement(Text, { color: theme.secondaryText }, " ", status)), toolCount && toolCount > 0 && /* @__PURE__ */ React.createElement(Box, { marginLeft: 3 }, /* @__PURE__ */ React.createElement(Text, { color: theme.secondaryText }, "Tools used: ", toolCount)));
|
|
7
|
+
}
|
|
8
|
+
export {
|
|
9
|
+
TaskProgressMessage
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=TaskProgressMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/TaskProgressMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import React from 'react'\nimport { Box, Text } from 'ink'\nimport { getTheme } from '@utils/theme'\n\ninterface Props {\n agentType: string\n status: string\n toolCount?: number\n}\n\nexport function TaskProgressMessage({ agentType, status, toolCount }: Props) {\n const theme = getTheme()\n \n return (\n <Box flexDirection=\"column\" marginTop={1}>\n <Box flexDirection=\"row\">\n <Text color={theme.minto}>\u23AF </Text>\n <Text color={theme.text} bold>\n [{agentType}]\n </Text>\n <Text color={theme.secondaryText}> {status}</Text>\n </Box>\n {toolCount && toolCount > 0 && (\n <Box marginLeft={3}>\n <Text color={theme.secondaryText}>\n Tools used: {toolCount}\n </Text>\n </Box>\n )}\n </Box>\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,OAAO,WAAW;AAClB,SAAS,KAAK,YAAY;AAC1B,SAAS,gBAAgB;AAQlB,SAAS,oBAAoB,EAAE,WAAW,QAAQ,UAAU,GAAU;AAC3E,QAAM,QAAQ,SAAS;AAEvB,SACE,oCAAC,OAAI,eAAc,UAAS,WAAW,KACrC,oCAAC,OAAI,eAAc,SACjB,oCAAC,QAAK,OAAO,MAAM,SAAO,SAAE,GAC5B,oCAAC,QAAK,OAAO,MAAM,MAAM,MAAI,QAAC,KAC1B,WAAU,GACd,GACA,oCAAC,QAAK,OAAO,MAAM,iBAAe,KAAE,MAAO,CAC7C,GACC,aAAa,YAAY,KACxB,oCAAC,OAAI,YAAY,KACf,oCAAC,QAAK,OAAO,MAAM,iBAAe,gBACnB,SACf,CACF,CAEJ;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import React, { useEffect, useState, useMemo } from "react";
|
|
2
|
+
import { Text } from "ink";
|
|
3
|
+
import { getAgentByType } from "../../utils/agentLoader.js";
|
|
4
|
+
import { getTheme } from "../../utils/theme.js";
|
|
5
|
+
const agentConfigCache = /* @__PURE__ */ new Map();
|
|
6
|
+
function TaskToolMessage({ agentType, children, bold = true }) {
|
|
7
|
+
const theme = getTheme();
|
|
8
|
+
const [agentConfig, setAgentConfig] = useState(() => {
|
|
9
|
+
return agentConfigCache.get(agentType) || null;
|
|
10
|
+
});
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
if (agentConfigCache.has(agentType)) {
|
|
13
|
+
setAgentConfig(agentConfigCache.get(agentType));
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
let mounted = true;
|
|
17
|
+
getAgentByType(agentType).then((config) => {
|
|
18
|
+
if (mounted) {
|
|
19
|
+
agentConfigCache.set(agentType, config);
|
|
20
|
+
setAgentConfig(config);
|
|
21
|
+
}
|
|
22
|
+
}).catch(() => {
|
|
23
|
+
if (mounted) {
|
|
24
|
+
agentConfigCache.set(agentType, null);
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
return () => {
|
|
28
|
+
mounted = false;
|
|
29
|
+
};
|
|
30
|
+
}, [agentType]);
|
|
31
|
+
const color = useMemo(() => {
|
|
32
|
+
return agentConfig?.color || theme.text;
|
|
33
|
+
}, [agentConfig?.color, theme.text]);
|
|
34
|
+
return /* @__PURE__ */ React.createElement(Text, { color, bold }, children);
|
|
35
|
+
}
|
|
36
|
+
export {
|
|
37
|
+
TaskToolMessage
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=TaskToolMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/TaskToolMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import React, { useEffect, useState, useMemo } from 'react'\nimport { Text } from 'ink'\nimport { getAgentByType } from '@utils/agentLoader'\nimport { getTheme } from '@utils/theme'\n\ninterface Props {\n agentType: string\n children: React.ReactNode\n bold?: boolean\n}\n\n// Simple cache to prevent re-fetching agent configs\nconst agentConfigCache = new Map<string, any>()\n\nexport function TaskToolMessage({ agentType, children, bold = true }: Props) {\n const theme = getTheme()\n const [agentConfig, setAgentConfig] = useState<any>(() => {\n // Return cached config immediately if available\n return agentConfigCache.get(agentType) || null\n })\n\n useEffect(() => {\n // Skip if already cached\n if (agentConfigCache.has(agentType)) {\n setAgentConfig(agentConfigCache.get(agentType))\n return\n }\n\n // Load and cache agent configuration\n let mounted = true\n getAgentByType(agentType).then(config => {\n if (mounted) {\n agentConfigCache.set(agentType, config)\n setAgentConfig(config)\n }\n }).catch(() => {\n // Silently handle errors to prevent console noise\n if (mounted) {\n agentConfigCache.set(agentType, null)\n }\n })\n\n return () => {\n mounted = false\n }\n }, [agentType])\n\n // Memoize color calculation to prevent unnecessary re-renders\n const color = useMemo(() => {\n return agentConfig?.color || theme.text\n }, [agentConfig?.color, theme.text])\n\n return (\n <Text color={color} bold={bold}>\n {children}\n </Text>\n )\n}"],
|
|
5
|
+
"mappings": "AAAA,OAAO,SAAS,WAAW,UAAU,eAAe;AACpD,SAAS,YAAY;AACrB,SAAS,sBAAsB;AAC/B,SAAS,gBAAgB;AASzB,MAAM,mBAAmB,oBAAI,IAAiB;AAEvC,SAAS,gBAAgB,EAAE,WAAW,UAAU,OAAO,KAAK,GAAU;AAC3E,QAAM,QAAQ,SAAS;AACvB,QAAM,CAAC,aAAa,cAAc,IAAI,SAAc,MAAM;AAExD,WAAO,iBAAiB,IAAI,SAAS,KAAK;AAAA,EAC5C,CAAC;AAED,YAAU,MAAM;AAEd,QAAI,iBAAiB,IAAI,SAAS,GAAG;AACnC,qBAAe,iBAAiB,IAAI,SAAS,CAAC;AAC9C;AAAA,IACF;AAGA,QAAI,UAAU;AACd,mBAAe,SAAS,EAAE,KAAK,YAAU;AACvC,UAAI,SAAS;AACX,yBAAiB,IAAI,WAAW,MAAM;AACtC,uBAAe,MAAM;AAAA,MACvB;AAAA,IACF,CAAC,EAAE,MAAM,MAAM;AAEb,UAAI,SAAS;AACX,yBAAiB,IAAI,WAAW,IAAI;AAAA,MACtC;AAAA,IACF,CAAC;AAED,WAAO,MAAM;AACX,gBAAU;AAAA,IACZ;AAAA,EACF,GAAG,CAAC,SAAS,CAAC;AAGd,QAAM,QAAQ,QAAQ,MAAM;AAC1B,WAAO,aAAa,SAAS,MAAM;AAAA,EACrC,GAAG,CAAC,aAAa,OAAO,MAAM,IAAI,CAAC;AAEnC,SACE,oCAAC,QAAK,OAAc,QACjB,QACH;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Box, Text } from "ink";
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
import { extractTag } from "../../utils/messages.js";
|
|
4
|
+
import { getTheme } from "../../utils/theme.js";
|
|
5
|
+
function UserBashInputMessage({
|
|
6
|
+
param: { text },
|
|
7
|
+
addMargin
|
|
8
|
+
}) {
|
|
9
|
+
const input = extractTag(text, "bash-input");
|
|
10
|
+
if (!input) {
|
|
11
|
+
return null;
|
|
12
|
+
}
|
|
13
|
+
return /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", marginTop: addMargin ? 1 : 0, width: "100%" }, /* @__PURE__ */ React.createElement(Box, null, /* @__PURE__ */ React.createElement(Text, { color: getTheme().bashBorder }, "!"), /* @__PURE__ */ React.createElement(Text, { color: getTheme().secondaryText }, " ", input)));
|
|
14
|
+
}
|
|
15
|
+
export {
|
|
16
|
+
UserBashInputMessage
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=UserBashInputMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/UserBashInputMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import { Box, Text } from 'ink'\nimport * as React from 'react'\nimport { extractTag } from '@utils/messages'\nimport { getTheme } from '@utils/theme'\nimport { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'\n\ntype Props = {\n addMargin: boolean\n param: TextBlockParam\n}\n\nexport function UserBashInputMessage({\n param: { text },\n addMargin,\n}: Props): React.ReactNode {\n const input = extractTag(text, 'bash-input')\n if (!input) {\n return null\n }\n return (\n <Box flexDirection=\"column\" marginTop={addMargin ? 1 : 0} width=\"100%\">\n <Box>\n <Text color={getTheme().bashBorder}>!</Text>\n <Text color={getTheme().secondaryText}> {input}</Text>\n </Box>\n </Box>\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,KAAK,YAAY;AAC1B,YAAY,WAAW;AACvB,SAAS,kBAAkB;AAC3B,SAAS,gBAAgB;AAQlB,SAAS,qBAAqB;AAAA,EACnC,OAAO,EAAE,KAAK;AAAA,EACd;AACF,GAA2B;AACzB,QAAM,QAAQ,WAAW,MAAM,YAAY;AAC3C,MAAI,CAAC,OAAO;AACV,WAAO;AAAA,EACT;AACA,SACE,oCAAC,OAAI,eAAc,UAAS,WAAW,YAAY,IAAI,GAAG,OAAM,UAC9D,oCAAC,WACC,oCAAC,QAAK,OAAO,SAAS,EAAE,cAAY,GAAC,GACrC,oCAAC,QAAK,OAAO,SAAS,EAAE,iBAAe,KAAE,KAAM,CACjD,CACF;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Box, Text } from "ink";
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
import { getTheme } from "../../utils/theme.js";
|
|
4
|
+
import { extractTag } from "../../utils/messages.js";
|
|
5
|
+
function UserCommandMessage({
|
|
6
|
+
addMargin,
|
|
7
|
+
param: { text }
|
|
8
|
+
}) {
|
|
9
|
+
const commandMessage = extractTag(text, "command-message");
|
|
10
|
+
const args = extractTag(text, "command-args");
|
|
11
|
+
if (!commandMessage) {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
const theme = getTheme();
|
|
15
|
+
return /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", marginTop: addMargin ? 1 : 0, width: "100%" }, /* @__PURE__ */ React.createElement(Text, { color: theme.secondaryText }, "> /", commandMessage, " ", args));
|
|
16
|
+
}
|
|
17
|
+
export {
|
|
18
|
+
UserCommandMessage
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=UserCommandMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/UserCommandMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import { Box, Text } from 'ink'\nimport * as React from 'react'\nimport { getTheme } from '@utils/theme'\nimport { extractTag } from '@utils/messages'\nimport { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'\n\ntype Props = {\n addMargin: boolean\n param: TextBlockParam\n}\n\nexport function UserCommandMessage({\n addMargin,\n param: { text },\n}: Props): React.ReactNode {\n const commandMessage = extractTag(text, 'command-message')\n const args = extractTag(text, 'command-args')\n if (!commandMessage) {\n return null\n }\n\n const theme = getTheme()\n return (\n <Box flexDirection=\"column\" marginTop={addMargin ? 1 : 0} width=\"100%\">\n <Text color={theme.secondaryText}>\n > /{commandMessage} {args}\n </Text>\n </Box>\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,KAAK,YAAY;AAC1B,YAAY,WAAW;AACvB,SAAS,gBAAgB;AACzB,SAAS,kBAAkB;AAQpB,SAAS,mBAAmB;AAAA,EACjC;AAAA,EACA,OAAO,EAAE,KAAK;AAChB,GAA2B;AACzB,QAAM,iBAAiB,WAAW,MAAM,iBAAiB;AACzD,QAAM,OAAO,WAAW,MAAM,cAAc;AAC5C,MAAI,CAAC,gBAAgB;AACnB,WAAO;AAAA,EACT;AAEA,QAAM,QAAQ,SAAS;AACvB,SACE,oCAAC,OAAI,eAAc,UAAS,WAAW,YAAY,IAAI,GAAG,OAAM,UAC9D,oCAAC,QAAK,OAAO,MAAM,iBAAe,OACzB,gBAAe,KAAE,IAC1B,CACF;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|