@within-7/minto 0.1.7 → 0.3.0
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 +155 -37
- package/dist/Tool.js +38 -0
- package/dist/Tool.js.map +3 -3
- package/dist/commands/agents/AgentsCommand.js +73 -49
- package/dist/commands/agents/AgentsCommand.js.map +2 -2
- package/dist/commands/agents/constants.js +1 -1
- package/dist/commands/agents/constants.js.map +1 -1
- package/dist/commands/agents/index.js +1 -1
- package/dist/commands/bug.js +74 -7
- package/dist/commands/bug.js.map +3 -3
- package/dist/commands/clear.js +3 -0
- package/dist/commands/clear.js.map +2 -2
- package/dist/commands/compact.js +37 -0
- package/dist/commands/compact.js.map +2 -2
- package/dist/commands/context.js +85 -0
- package/dist/commands/context.js.map +7 -0
- package/dist/commands/ctx_viz.js +18 -10
- package/dist/commands/ctx_viz.js.map +2 -2
- package/dist/commands/doctor.js +158 -12
- package/dist/commands/doctor.js.map +2 -2
- package/dist/commands/export.js +157 -0
- package/dist/commands/export.js.map +7 -0
- package/dist/commands/mcp-interactive.js +28 -18
- package/dist/commands/mcp-interactive.js.map +2 -2
- package/dist/commands/model.js +9 -7
- package/dist/commands/model.js.map +2 -2
- package/dist/commands/permissions.js +87 -0
- package/dist/commands/permissions.js.map +7 -0
- package/dist/commands/plugin/AddMarketplaceForm.js +3 -2
- package/dist/commands/plugin/AddMarketplaceForm.js.map +2 -2
- package/dist/commands/plugin/ConfirmDialog.js +2 -1
- package/dist/commands/plugin/ConfirmDialog.js.map +2 -2
- package/dist/commands/plugin/ErrorView.js +2 -1
- package/dist/commands/plugin/ErrorView.js.map +2 -2
- package/dist/commands/plugin/InstalledPluginsByMarketplace.js +5 -4
- package/dist/commands/plugin/InstalledPluginsByMarketplace.js.map +2 -2
- package/dist/commands/plugin/InstalledPluginsManager.js +5 -4
- package/dist/commands/plugin/InstalledPluginsManager.js.map +2 -2
- package/dist/commands/plugin/MainMenu.js +2 -1
- package/dist/commands/plugin/MainMenu.js.map +2 -2
- package/dist/commands/plugin/MarketplaceManager.js +5 -4
- package/dist/commands/plugin/MarketplaceManager.js.map +2 -2
- package/dist/commands/plugin/MarketplaceSelector.js +4 -3
- package/dist/commands/plugin/MarketplaceSelector.js.map +2 -2
- package/dist/commands/plugin/PlaceholderScreen.js +3 -2
- package/dist/commands/plugin/PlaceholderScreen.js.map +2 -2
- package/dist/commands/plugin/PluginBrowser.js +6 -5
- package/dist/commands/plugin/PluginBrowser.js.map +2 -2
- package/dist/commands/plugin/PluginDetailsInstall.js +5 -4
- package/dist/commands/plugin/PluginDetailsInstall.js.map +2 -2
- package/dist/commands/plugin/PluginDetailsManage.js +4 -3
- package/dist/commands/plugin/PluginDetailsManage.js.map +2 -2
- package/dist/commands/plugin.js +16 -15
- package/dist/commands/plugin.js.map +2 -2
- package/dist/commands/quit.js +3 -1
- package/dist/commands/quit.js.map +2 -2
- package/dist/commands/sandbox.js +105 -0
- package/dist/commands/sandbox.js.map +7 -0
- package/dist/commands/setup.js +2 -1
- package/dist/commands/setup.js.map +2 -2
- package/dist/commands/status.js +59 -0
- package/dist/commands/status.js.map +7 -0
- package/dist/commands/tasks.js +108 -0
- package/dist/commands/tasks.js.map +7 -0
- package/dist/commands/todos.js +123 -0
- package/dist/commands/todos.js.map +7 -0
- package/dist/commands/undo.js +245 -0
- package/dist/commands/undo.js.map +7 -0
- package/dist/commands.js +22 -2
- package/dist/commands.js.map +2 -2
- package/dist/components/AgentThinkingBlock.js +10 -18
- package/dist/components/AgentThinkingBlock.js.map +2 -2
- package/dist/components/AsciiLogo.js +7 -8
- package/dist/components/AsciiLogo.js.map +2 -2
- package/dist/components/AskUserQuestionDialog/AskUserQuestionDialog.js +3 -2
- package/dist/components/AskUserQuestionDialog/AskUserQuestionDialog.js.map +2 -2
- package/dist/components/AskUserQuestionDialog/QuestionView.js +2 -1
- package/dist/components/AskUserQuestionDialog/QuestionView.js.map +2 -2
- package/dist/components/BackgroundTasksPanel.js +78 -29
- package/dist/components/BackgroundTasksPanel.js.map +2 -2
- package/dist/components/BashStreamingProgress.js +24 -0
- package/dist/components/BashStreamingProgress.js.map +7 -0
- package/dist/components/CollapsibleHint.js +15 -0
- package/dist/components/CollapsibleHint.js.map +7 -0
- package/dist/components/Config.js +3 -2
- package/dist/components/Config.js.map +2 -2
- package/dist/components/ConsoleOAuthFlow.js +2 -1
- package/dist/components/ConsoleOAuthFlow.js.map +2 -2
- package/dist/components/Cost.js +2 -1
- package/dist/components/Cost.js.map +2 -2
- package/dist/components/FileEditToolUpdatedMessage.js +1 -1
- package/dist/components/FileEditToolUpdatedMessage.js.map +2 -2
- package/dist/components/HeaderBar.js +13 -8
- package/dist/components/HeaderBar.js.map +2 -2
- package/dist/components/HistorySearchOverlay.js +4 -3
- package/dist/components/HistorySearchOverlay.js.map +2 -2
- package/dist/components/HotkeyHelpPanel.js +134 -0
- package/dist/components/HotkeyHelpPanel.js.map +7 -0
- package/dist/components/InvalidConfigDialog.js +2 -1
- package/dist/components/InvalidConfigDialog.js.map +2 -2
- package/dist/components/Logo.js +24 -68
- package/dist/components/Logo.js.map +2 -2
- package/dist/components/MCPServerApprovalDialog.js +2 -1
- package/dist/components/MCPServerApprovalDialog.js.map +2 -2
- package/dist/components/MCPServerDialogCopy.js +2 -1
- package/dist/components/MCPServerDialogCopy.js.map +2 -2
- package/dist/components/MCPServerMultiselectDialog.js +2 -1
- package/dist/components/MCPServerMultiselectDialog.js.map +2 -2
- package/dist/components/Message.js +23 -7
- package/dist/components/Message.js.map +3 -3
- package/dist/components/MessageSelector.js +4 -3
- package/dist/components/MessageSelector.js.map +2 -2
- package/dist/components/ModeIndicator.js +2 -1
- package/dist/components/ModeIndicator.js.map +2 -2
- package/dist/components/ModelConfig.js +20 -6
- package/dist/components/ModelConfig.js.map +2 -2
- package/dist/components/ModelListManager.js +7 -6
- package/dist/components/ModelListManager.js.map +2 -2
- package/dist/components/ModelSelector/ModelSelector.js +27 -14
- package/dist/components/ModelSelector/ModelSelector.js.map +2 -2
- package/dist/components/Onboarding.js +22 -16
- package/dist/components/Onboarding.js.map +2 -2
- package/dist/components/OperationSummary.js +130 -0
- package/dist/components/OperationSummary.js.map +7 -0
- package/dist/components/ProgressBar.js +74 -0
- package/dist/components/ProgressBar.js.map +7 -0
- package/dist/components/PromptInput.js +210 -87
- package/dist/components/PromptInput.js.map +2 -2
- package/dist/components/RequestStatusIndicator.js +194 -0
- package/dist/components/RequestStatusIndicator.js.map +7 -0
- package/dist/components/SensitiveFileWarning.js +31 -0
- package/dist/components/SensitiveFileWarning.js.map +7 -0
- package/dist/components/Spinner.js +141 -27
- package/dist/components/Spinner.js.map +2 -2
- package/dist/components/SpinnerSymbol.js +21 -27
- package/dist/components/SpinnerSymbol.js.map +2 -2
- package/dist/components/StreamingBashOutput.js +9 -8
- package/dist/components/StreamingBashOutput.js.map +2 -2
- package/dist/components/StructuredDiff.js +6 -8
- package/dist/components/StructuredDiff.js.map +2 -2
- package/dist/components/SubagentBlock.js +5 -3
- package/dist/components/SubagentBlock.js.map +2 -2
- package/dist/components/SubagentProgress.js +17 -15
- package/dist/components/SubagentProgress.js.map +2 -2
- package/dist/components/TaskCard.js +30 -24
- package/dist/components/TaskCard.js.map +2 -2
- package/dist/components/TextInput.js +9 -1
- package/dist/components/TextInput.js.map +2 -2
- package/dist/components/TodoChangeBlock.js +1 -1
- package/dist/components/TodoChangeBlock.js.map +2 -2
- package/dist/components/TodoPanel.js +140 -31
- package/dist/components/TodoPanel.js.map +3 -3
- package/dist/components/TokenCounter.js +74 -0
- package/dist/components/TokenCounter.js.map +7 -0
- package/dist/components/TokenWarning.js +2 -1
- package/dist/components/TokenWarning.js.map +2 -2
- package/dist/components/ToolUseLoader.js +2 -2
- package/dist/components/ToolUseLoader.js.map +2 -2
- package/dist/components/TreeConnector.js +26 -0
- package/dist/components/TreeConnector.js.map +7 -0
- package/dist/components/TrustDialog.js +2 -1
- package/dist/components/TrustDialog.js.map +2 -2
- package/dist/components/TurnCompletionIndicator.js +18 -0
- package/dist/components/TurnCompletionIndicator.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedbackView.js +2 -1
- package/dist/components/binary-feedback/BinaryFeedbackView.js.map +2 -2
- package/dist/components/messages/AssistantTextMessage.js +20 -9
- package/dist/components/messages/AssistantTextMessage.js.map +2 -2
- package/dist/components/messages/AssistantThinkingMessage.js +18 -3
- package/dist/components/messages/AssistantThinkingMessage.js.map +2 -2
- package/dist/components/messages/AssistantToolUseMessage.js +17 -10
- package/dist/components/messages/AssistantToolUseMessage.js.map +2 -2
- package/dist/components/messages/GroupRenderer.js +54 -0
- package/dist/components/messages/GroupRenderer.js.map +7 -0
- package/dist/components/messages/NestedTasksPreview.js +24 -0
- package/dist/components/messages/NestedTasksPreview.js.map +7 -0
- package/dist/components/messages/ParallelTasksGroupView.js +93 -0
- package/dist/components/messages/ParallelTasksGroupView.js.map +7 -0
- package/dist/components/messages/TaskInModuleView.js +218 -0
- package/dist/components/messages/TaskInModuleView.js.map +7 -0
- package/dist/components/messages/TaskOutputContent.js +56 -0
- package/dist/components/messages/TaskOutputContent.js.map +7 -0
- package/dist/components/messages/UserPromptMessage.js +2 -2
- package/dist/components/messages/UserPromptMessage.js.map +2 -2
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +2 -3
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js.map +2 -2
- package/dist/components/permissions/FallbackPermissionRequest.js +4 -4
- package/dist/components/permissions/FallbackPermissionRequest.js.map +2 -2
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +4 -4
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js.map +2 -2
- package/dist/constants/colors.js +120 -54
- package/dist/constants/colors.js.map +2 -2
- package/dist/constants/formatRules.js +102 -0
- package/dist/constants/formatRules.js.map +7 -0
- package/dist/constants/prompts.js +12 -34
- package/dist/constants/prompts.js.map +2 -2
- package/dist/constants/symbols.js +64 -6
- package/dist/constants/symbols.js.map +2 -2
- package/dist/constants/timing.js +5 -0
- package/dist/constants/timing.js.map +2 -2
- package/dist/constants/toolInputExamples.js +84 -0
- package/dist/constants/toolInputExamples.js.map +7 -0
- package/dist/core/backupManager.js +321 -0
- package/dist/core/backupManager.js.map +7 -0
- package/dist/core/config/defaults.js +84 -0
- package/dist/core/config/defaults.js.map +7 -0
- package/dist/core/config/index.js +111 -0
- package/dist/core/config/index.js.map +7 -0
- package/dist/core/config/loader.js +221 -0
- package/dist/core/config/loader.js.map +7 -0
- package/dist/core/config/migrations.js +128 -0
- package/dist/core/config/migrations.js.map +7 -0
- package/dist/core/config/schema.js +178 -0
- package/dist/core/config/schema.js.map +7 -0
- package/dist/core/costTracker.js +129 -0
- package/dist/core/costTracker.js.map +7 -0
- package/dist/core/gitAutoCommit.js +287 -0
- package/dist/core/gitAutoCommit.js.map +7 -0
- package/dist/core/index.js +8 -0
- package/dist/core/index.js.map +7 -0
- package/dist/core/operationTracker.js +212 -0
- package/dist/core/operationTracker.js.map +7 -0
- package/dist/core/permissions/auditLog.js +204 -0
- package/dist/core/permissions/auditLog.js.map +7 -0
- package/dist/core/permissions/engine/index.js +3 -0
- package/dist/core/permissions/engine/index.js.map +7 -0
- package/dist/core/permissions/engine/permissionEngine.js +106 -0
- package/dist/core/permissions/engine/permissionEngine.js.map +7 -0
- package/dist/core/permissions/engine/types.js +1 -0
- package/dist/core/permissions/engine/types.js.map +7 -0
- package/dist/core/permissions/index.js +84 -0
- package/dist/core/permissions/index.js.map +7 -0
- package/dist/core/permissions/ruleEngine.js +259 -0
- package/dist/core/permissions/ruleEngine.js.map +7 -0
- package/dist/core/permissions/rules/allowedToolsRule.js +62 -0
- package/dist/core/permissions/rules/allowedToolsRule.js.map +7 -0
- package/dist/core/permissions/rules/autoEscalationRule.js +296 -0
- package/dist/core/permissions/rules/autoEscalationRule.js.map +7 -0
- package/dist/core/permissions/rules/index.js +46 -0
- package/dist/core/permissions/rules/index.js.map +7 -0
- package/dist/core/permissions/rules/planModeRule.js +55 -0
- package/dist/core/permissions/rules/planModeRule.js.map +7 -0
- package/dist/core/permissions/rules/projectBoundaryRule.js +173 -0
- package/dist/core/permissions/rules/projectBoundaryRule.js.map +7 -0
- package/dist/core/permissions/rules/safeModeRule.js +65 -0
- package/dist/core/permissions/rules/safeModeRule.js.map +7 -0
- package/dist/core/permissions/rules/sensitivePathsRule.js +345 -0
- package/dist/core/permissions/rules/sensitivePathsRule.js.map +7 -0
- package/dist/core/permissions/types.js +127 -0
- package/dist/core/permissions/types.js.map +7 -0
- package/dist/core/tokenStats.js +9 -0
- package/dist/core/tokenStats.js.map +7 -0
- package/dist/core/tokenStatsManager.js +331 -0
- package/dist/core/tokenStatsManager.js.map +7 -0
- package/dist/core/tools/executor.js +143 -0
- package/dist/core/tools/executor.js.map +7 -0
- package/dist/core/tools/index.js +15 -0
- package/dist/core/tools/index.js.map +7 -0
- package/dist/core/tools/registry.js +183 -0
- package/dist/core/tools/registry.js.map +7 -0
- package/dist/core/tools/types.js +1 -0
- package/dist/core/tools/types.js.map +7 -0
- package/dist/cost-tracker.js +23 -15
- package/dist/cost-tracker.js.map +2 -2
- package/dist/entrypoints/cli.js +158 -130
- package/dist/entrypoints/cli.js.map +2 -2
- package/dist/entrypoints/mcp.js +12 -4
- package/dist/entrypoints/mcp.js.map +2 -2
- package/dist/history.js +14 -3
- package/dist/history.js.map +2 -2
- package/dist/hooks/useAgentTokenStats.js +72 -0
- package/dist/hooks/useAgentTokenStats.js.map +7 -0
- package/dist/hooks/useAgentTranscripts.js +140 -0
- package/dist/hooks/useAgentTranscripts.js.map +7 -0
- package/dist/hooks/useAnimationSync.js +53 -0
- package/dist/hooks/useAnimationSync.js.map +7 -0
- package/dist/hooks/useArrowKeyHistory.js +4 -2
- package/dist/hooks/useArrowKeyHistory.js.map +2 -2
- package/dist/hooks/useCanUseTool.js +3 -1
- package/dist/hooks/useCanUseTool.js.map +2 -2
- package/dist/hooks/useExitOnCtrlCD.js +9 -5
- package/dist/hooks/useExitOnCtrlCD.js.map +2 -2
- package/dist/hooks/useHookStatus.js +40 -0
- package/dist/hooks/useHookStatus.js.map +7 -0
- package/dist/hooks/useLogMessages.js +29 -2
- package/dist/hooks/useLogMessages.js.map +2 -2
- package/dist/hooks/useMessageGroups.js +43 -0
- package/dist/hooks/useMessageGroups.js.map +7 -0
- package/dist/hooks/useTerminalSize.js +62 -6
- package/dist/hooks/useTerminalSize.js.map +2 -2
- package/dist/hooks/useUnifiedCompletion.js +69 -0
- package/dist/hooks/useUnifiedCompletion.js.map +2 -2
- package/dist/i18n/index.js +109 -0
- package/dist/i18n/index.js.map +7 -0
- package/dist/i18n/locales/en.js +348 -0
- package/dist/i18n/locales/en.js.map +7 -0
- package/dist/i18n/locales/index.js +7 -0
- package/dist/i18n/locales/index.js.map +7 -0
- package/dist/i18n/locales/zh-CN.js +348 -0
- package/dist/i18n/locales/zh-CN.js.map +7 -0
- package/dist/i18n/types.js +8 -0
- package/dist/i18n/types.js.map +7 -0
- package/dist/permissions.js +28 -1
- package/dist/permissions.js.map +2 -2
- package/dist/query.js +253 -21
- package/dist/query.js.map +3 -3
- package/dist/screens/REPL.js +523 -194
- package/dist/screens/REPL.js.map +3 -3
- package/dist/services/adapters/chatCompletions.js +3 -1
- package/dist/services/adapters/chatCompletions.js.map +2 -2
- package/dist/services/adapters/messageNormalizer.js +354 -0
- package/dist/services/adapters/messageNormalizer.js.map +7 -0
- package/dist/services/adapters/responsesAPI.js +6 -3
- package/dist/services/adapters/responsesAPI.js.map +2 -2
- package/dist/services/checkpointManager.js +386 -0
- package/dist/services/checkpointManager.js.map +7 -0
- package/dist/services/claude.js +192 -14
- package/dist/services/claude.js.map +3 -3
- package/dist/services/compressionService.js +50 -1
- package/dist/services/compressionService.js.map +2 -2
- package/dist/services/contextMonitor.js +162 -0
- package/dist/services/contextMonitor.js.map +7 -0
- package/dist/services/customCommands.js +60 -41
- package/dist/services/customCommands.js.map +2 -2
- package/dist/services/hookExecutor.js +173 -1
- package/dist/services/hookExecutor.js.map +2 -2
- package/dist/services/intelligentCompactor.js +281 -0
- package/dist/services/intelligentCompactor.js.map +7 -0
- package/dist/services/lspConfig.js +109 -0
- package/dist/services/lspConfig.js.map +7 -0
- package/dist/services/mcpClient.js +338 -43
- package/dist/services/mcpClient.js.map +2 -2
- package/dist/services/modelOrchestrator.js +310 -0
- package/dist/services/modelOrchestrator.js.map +7 -0
- package/dist/services/openai.js +8 -1
- package/dist/services/openai.js.map +2 -2
- package/dist/services/outputStyles.js +138 -0
- package/dist/services/outputStyles.js.map +7 -0
- package/dist/services/plugins/index.js +5 -0
- package/dist/services/plugins/index.js.map +7 -0
- package/dist/services/plugins/lspServers.js +188 -0
- package/dist/services/plugins/lspServers.js.map +7 -0
- package/dist/services/plugins/pluginRuntime.js +229 -0
- package/dist/services/plugins/pluginRuntime.js.map +7 -0
- package/dist/services/plugins/pluginValidation.js +219 -0
- package/dist/services/plugins/pluginValidation.js.map +7 -0
- package/dist/services/plugins/skillMarketplace.js +556 -0
- package/dist/services/plugins/skillMarketplace.js.map +7 -0
- package/dist/services/responseStateManager.js +37 -3
- package/dist/services/responseStateManager.js.map +2 -2
- package/dist/services/sandbox/filesystemBoundary.js +341 -0
- package/dist/services/sandbox/filesystemBoundary.js.map +7 -0
- package/dist/services/sandbox/index.js +14 -0
- package/dist/services/sandbox/index.js.map +7 -0
- package/dist/services/sandbox/networkProxy.js +293 -0
- package/dist/services/sandbox/networkProxy.js.map +7 -0
- package/dist/services/sandbox/sandboxController.js +574 -0
- package/dist/services/sandbox/sandboxController.js.map +7 -0
- package/dist/services/sandbox/types.js +50 -0
- package/dist/services/sandbox/types.js.map +7 -0
- package/dist/services/sessionMemory.js +266 -0
- package/dist/services/sessionMemory.js.map +7 -0
- package/dist/services/taskRouter.js +324 -0
- package/dist/services/taskRouter.js.map +7 -0
- package/dist/tools/ArchitectTool/ArchitectTool.js +7 -1
- package/dist/tools/ArchitectTool/ArchitectTool.js.map +2 -2
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js +6 -2
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js.map +2 -2
- package/dist/tools/AskUserQuestionTool/AskUserQuestionTool.js +2 -1
- package/dist/tools/AskUserQuestionTool/AskUserQuestionTool.js.map +2 -2
- package/dist/tools/BaseTool.js +72 -0
- package/dist/tools/BaseTool.js.map +7 -0
- package/dist/tools/BashOutputTool/BashOutputToolResultMessage.js +3 -0
- package/dist/tools/BashOutputTool/BashOutputToolResultMessage.js.map +2 -2
- package/dist/tools/BashTool/BashTool.js +79 -3
- package/dist/tools/BashTool/BashTool.js.map +2 -2
- package/dist/tools/BashTool/BashToolResultMessage.js +3 -0
- package/dist/tools/BashTool/BashToolResultMessage.js.map +2 -2
- package/dist/tools/BashTool/OutputLine.js +54 -0
- package/dist/tools/BashTool/OutputLine.js.map +2 -2
- package/dist/tools/BashTool/prompt.js +336 -3
- package/dist/tools/BashTool/prompt.js.map +2 -2
- package/dist/tools/FileEditTool/FileEditTool.js +29 -4
- package/dist/tools/FileEditTool/FileEditTool.js.map +2 -2
- package/dist/tools/FileEditTool/prompt.js +6 -3
- package/dist/tools/FileEditTool/prompt.js.map +2 -2
- package/dist/tools/FileWriteTool/FileWriteTool.js +5 -5
- package/dist/tools/FileWriteTool/FileWriteTool.js.map +2 -2
- package/dist/tools/FileWriteTool/prompt.js +4 -2
- package/dist/tools/FileWriteTool/prompt.js.map +2 -2
- package/dist/tools/GlobTool/GlobTool.js +4 -2
- package/dist/tools/GlobTool/GlobTool.js.map +2 -2
- package/dist/tools/GrepTool/GrepTool.js +36 -7
- package/dist/tools/GrepTool/GrepTool.js.map +2 -2
- package/dist/tools/KillShellTool/KillShellToolResultMessage.js +3 -0
- package/dist/tools/KillShellTool/KillShellToolResultMessage.js.map +2 -2
- package/dist/tools/ListMcpResourcesTool/ListMcpResourcesTool.js +109 -0
- package/dist/tools/ListMcpResourcesTool/ListMcpResourcesTool.js.map +7 -0
- package/dist/tools/ListMcpResourcesTool/prompt.js +19 -0
- package/dist/tools/ListMcpResourcesTool/prompt.js.map +7 -0
- package/dist/tools/LspTool/LspTool.js +664 -0
- package/dist/tools/LspTool/LspTool.js.map +7 -0
- package/dist/tools/LspTool/prompt.js +27 -0
- package/dist/tools/LspTool/prompt.js.map +7 -0
- package/dist/tools/MCPTool/MCPTool.js +9 -1
- package/dist/tools/MCPTool/MCPTool.js.map +2 -2
- package/dist/tools/MemoryReadTool/MemoryReadTool.js +19 -6
- package/dist/tools/MemoryReadTool/MemoryReadTool.js.map +2 -2
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js +6 -6
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js.map +2 -2
- package/dist/tools/MultiEditTool/MultiEditTool.js +19 -2
- package/dist/tools/MultiEditTool/MultiEditTool.js.map +2 -2
- package/dist/tools/MultiEditTool/prompt.js +5 -3
- package/dist/tools/MultiEditTool/prompt.js.map +2 -2
- package/dist/tools/NotebookEditTool/NotebookEditTool.js +7 -2
- package/dist/tools/NotebookEditTool/NotebookEditTool.js.map +2 -2
- package/dist/tools/NotebookReadTool/NotebookReadTool.js.map +2 -2
- package/dist/tools/PlanModeTool/EnterPlanModeTool.js +75 -0
- package/dist/tools/PlanModeTool/EnterPlanModeTool.js.map +7 -0
- package/dist/tools/PlanModeTool/ExitPlanModeTool.js +109 -0
- package/dist/tools/PlanModeTool/ExitPlanModeTool.js.map +7 -0
- package/dist/tools/PlanModeTool/prompt.js +94 -0
- package/dist/tools/PlanModeTool/prompt.js.map +7 -0
- package/dist/tools/ReadMcpResourceTool/ReadMcpResourceTool.js +130 -0
- package/dist/tools/ReadMcpResourceTool/ReadMcpResourceTool.js.map +7 -0
- package/dist/tools/ReadMcpResourceTool/prompt.js +17 -0
- package/dist/tools/ReadMcpResourceTool/prompt.js.map +7 -0
- package/dist/tools/SkillTool/SkillTool.js +10 -4
- package/dist/tools/SkillTool/SkillTool.js.map +2 -2
- package/dist/tools/SkillTool/prompt.js +1 -1
- package/dist/tools/SkillTool/prompt.js.map +1 -1
- package/dist/tools/SlashCommandTool/SlashCommandTool.js +260 -0
- package/dist/tools/SlashCommandTool/SlashCommandTool.js.map +7 -0
- package/dist/tools/SlashCommandTool/prompt.js +35 -0
- package/dist/tools/SlashCommandTool/prompt.js.map +7 -0
- package/dist/tools/TaskOutputTool/TaskOutputTool.js +190 -0
- package/dist/tools/TaskOutputTool/TaskOutputTool.js.map +7 -0
- package/dist/tools/TaskOutputTool/prompt.js +15 -0
- package/dist/tools/TaskOutputTool/prompt.js.map +7 -0
- package/dist/tools/TaskTool/TaskTool.js +310 -104
- package/dist/tools/TaskTool/TaskTool.js.map +2 -2
- package/dist/tools/TaskTool/prompt.js.map +2 -2
- package/dist/tools/TodoWriteTool/TodoWriteTool.js +42 -77
- package/dist/tools/TodoWriteTool/TodoWriteTool.js.map +2 -2
- package/dist/tools/URLFetcherTool/URLFetcherTool.js +4 -1
- package/dist/tools/URLFetcherTool/URLFetcherTool.js.map +2 -2
- package/dist/tools/URLFetcherTool/cache.js +55 -8
- package/dist/tools/URLFetcherTool/cache.js.map +2 -2
- package/dist/tools.js +31 -2
- package/dist/tools.js.map +2 -2
- package/dist/types/hooks.js +4 -0
- package/dist/types/hooks.js.map +2 -2
- package/dist/types/marketplace.js.map +2 -2
- package/dist/types/messageGroup.js +36 -0
- package/dist/types/messageGroup.js.map +7 -0
- package/dist/types/plugin.js.map +2 -2
- package/dist/types/thinking.js +1 -0
- package/dist/types/thinking.js.map +7 -0
- package/dist/utils/BackgroundShellManager.js +136 -39
- package/dist/utils/BackgroundShellManager.js.map +2 -2
- package/dist/utils/CircuitBreaker.js +242 -0
- package/dist/utils/CircuitBreaker.js.map +7 -0
- package/dist/utils/MessageBatchBuffer.js +102 -0
- package/dist/utils/MessageBatchBuffer.js.map +7 -0
- package/dist/utils/PersistentShell.js +151 -1
- package/dist/utils/PersistentShell.js.map +2 -2
- package/dist/utils/agentLoader.js +1 -23
- package/dist/utils/agentLoader.js.map +2 -2
- package/dist/utils/agentTranscripts.js +641 -0
- package/dist/utils/agentTranscripts.js.map +7 -0
- package/dist/utils/animationManager.js +213 -0
- package/dist/utils/animationManager.js.map +7 -0
- package/dist/utils/animationSync.js +110 -0
- package/dist/utils/animationSync.js.map +7 -0
- package/dist/utils/ask.js +2 -0
- package/dist/utils/ask.js.map +2 -2
- package/dist/utils/asyncFile.js +215 -0
- package/dist/utils/asyncFile.js.map +7 -0
- package/dist/utils/backgroundAgentManager.js +231 -0
- package/dist/utils/backgroundAgentManager.js.map +7 -0
- package/dist/utils/config.js +108 -10
- package/dist/utils/config.js.map +2 -2
- package/dist/utils/conversationRecovery.js +19 -0
- package/dist/utils/conversationRecovery.js.map +2 -2
- package/dist/utils/credentials/CredentialStore.js +1 -0
- package/dist/utils/credentials/CredentialStore.js.map +7 -0
- package/dist/utils/credentials/EncryptedFileStore.js +157 -0
- package/dist/utils/credentials/EncryptedFileStore.js.map +7 -0
- package/dist/utils/credentials/index.js +37 -0
- package/dist/utils/credentials/index.js.map +7 -0
- package/dist/utils/credentials/migration.js +82 -0
- package/dist/utils/credentials/migration.js.map +7 -0
- package/dist/utils/exit.js +73 -0
- package/dist/utils/exit.js.map +7 -0
- package/dist/utils/format.js +73 -5
- package/dist/utils/format.js.map +2 -2
- package/dist/utils/generators.js +76 -6
- package/dist/utils/generators.js.map +2 -2
- package/dist/utils/globalErrorHandler.js +149 -0
- package/dist/utils/globalErrorHandler.js.map +7 -0
- package/dist/utils/groupHandlers/index.js +8 -0
- package/dist/utils/groupHandlers/index.js.map +7 -0
- package/dist/utils/groupHandlers/parallelTasksHandler.js +140 -0
- package/dist/utils/groupHandlers/parallelTasksHandler.js.map +7 -0
- package/dist/utils/groupHandlers/taskHandler.js +104 -0
- package/dist/utils/groupHandlers/taskHandler.js.map +7 -0
- package/dist/utils/groupHandlers/types.js +1 -0
- package/dist/utils/groupHandlers/types.js.map +7 -0
- package/dist/utils/logRotation.js +224 -0
- package/dist/utils/logRotation.js.map +7 -0
- package/dist/utils/markdown.js +13 -1
- package/dist/utils/markdown.js.map +2 -2
- package/dist/utils/marketplaceManager.js +3 -5
- package/dist/utils/marketplaceManager.js.map +2 -2
- package/dist/utils/memSafety.js +264 -0
- package/dist/utils/memSafety.js.map +7 -0
- package/dist/utils/messageGroupManager.js +274 -0
- package/dist/utils/messageGroupManager.js.map +7 -0
- package/dist/utils/messages.js +13 -4
- package/dist/utils/messages.js.map +2 -2
- package/dist/utils/model.js +119 -15
- package/dist/utils/model.js.map +3 -3
- package/dist/utils/permissions/filesystem.js +162 -6
- package/dist/utils/permissions/filesystem.js.map +2 -2
- package/dist/utils/plan/planMode.js +143 -0
- package/dist/utils/plan/planMode.js.map +7 -0
- package/dist/utils/pluginLoader.js +17 -21
- package/dist/utils/pluginLoader.js.map +2 -2
- package/dist/utils/ripgrep.js +55 -2
- package/dist/utils/ripgrep.js.map +2 -2
- package/dist/utils/safePath.js +132 -0
- package/dist/utils/safePath.js.map +7 -0
- package/dist/utils/sanitizeInput.js +32 -0
- package/dist/utils/sanitizeInput.js.map +7 -0
- package/dist/utils/secureKeyStorage.js +312 -0
- package/dist/utils/secureKeyStorage.js.map +7 -0
- package/dist/utils/sensitiveFiles.js +125 -0
- package/dist/utils/sensitiveFiles.js.map +7 -0
- package/dist/utils/session/sessionPlugins.js +67 -0
- package/dist/utils/session/sessionPlugins.js.map +7 -0
- package/dist/utils/taskDisplayUtils.js +257 -0
- package/dist/utils/taskDisplayUtils.js.map +7 -0
- package/dist/utils/teamConfig.js +2 -1
- package/dist/utils/teamConfig.js.map +2 -2
- package/dist/utils/theme.js +6 -6
- package/dist/utils/theme.js.map +1 -1
- package/dist/utils/todoStorage.js +92 -2
- package/dist/utils/todoStorage.js.map +2 -2
- package/dist/utils/toolRiskClassification.js +207 -0
- package/dist/utils/toolRiskClassification.js.map +7 -0
- package/dist/utils/toolTimeout.js +136 -0
- package/dist/utils/toolTimeout.js.map +7 -0
- package/dist/utils/tooling/safeRender.js +116 -0
- package/dist/utils/tooling/safeRender.js.map +7 -0
- package/dist/utils/userFriendlyError.js +346 -0
- package/dist/utils/userFriendlyError.js.map +7 -0
- package/dist/utils/vendor/ripgrep/arm64-darwin/rg +0 -0
- package/dist/version.js +2 -2
- package/dist/version.js.map +1 -1
- package/package.json +17 -5
- package/scripts/postinstall.js +128 -38
- package/dist/commands/agents.js +0 -2086
- package/dist/commands/agents.js.map +0 -7
- package/dist/commands/build.js +0 -74
- package/dist/commands/build.js.map +0 -7
- package/dist/commands/compression.js +0 -57
- package/dist/commands/compression.js.map +0 -7
- package/dist/commands/listen.js +0 -37
- package/dist/commands/listen.js.map +0 -7
- package/dist/commands/login.js +0 -37
- package/dist/commands/login.js.map +0 -7
- package/dist/commands/logout.js +0 -33
- package/dist/commands/logout.js.map +0 -7
- package/dist/commands/mcp.js +0 -40
- package/dist/commands/mcp.js.map +0 -7
- package/dist/commands/mcp_refresh.js +0 -40
- package/dist/commands/mcp_refresh.js.map +0 -7
- package/dist/commands/modelstatus.js +0 -21
- package/dist/commands/modelstatus.js.map +0 -7
- package/dist/commands/onboarding.js +0 -36
- package/dist/commands/onboarding.js.map +0 -7
- package/dist/commands/plugin-interactive.js +0 -446
- package/dist/commands/plugin-interactive.js.map +0 -7
- package/dist/commands/pr_comments.js +0 -61
- package/dist/commands/pr_comments.js.map +0 -7
- package/dist/commands/release-notes.js +0 -30
- package/dist/commands/release-notes.js.map +0 -7
- package/dist/commands/review.js +0 -51
- package/dist/commands/review.js.map +0 -7
- package/dist/components/Bug.js +0 -147
- package/dist/components/Bug.js.map +0 -7
- package/dist/components/ModelSelector.js +0 -2062
- package/dist/components/ModelSelector.js.map +0 -7
- package/dist/components/ModelStatusDisplay.js +0 -87
- package/dist/components/ModelStatusDisplay.js.map +0 -7
- package/dist/entrypoints/cli-wrapper.js +0 -61
- package/dist/entrypoints/cli-wrapper.js.map +0 -7
- package/dist/hooks/useCancelRequest.js +0 -28
- package/dist/hooks/useCancelRequest.js.map +0 -7
- package/dist/screens/Doctor.js +0 -22
- package/dist/screens/Doctor.js.map +0 -7
package/dist/commands/review.js
DELETED
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import { BashTool } from "../tools/BashTool/BashTool.js";
|
|
2
|
-
var review_default = {
|
|
3
|
-
type: "prompt",
|
|
4
|
-
name: "review",
|
|
5
|
-
description: "Review a pull request",
|
|
6
|
-
isEnabled: true,
|
|
7
|
-
isHidden: false,
|
|
8
|
-
progressMessage: "reviewing pull request",
|
|
9
|
-
userFacingName() {
|
|
10
|
-
return "review";
|
|
11
|
-
},
|
|
12
|
-
async getPromptForCommand(args) {
|
|
13
|
-
return [
|
|
14
|
-
{
|
|
15
|
-
role: "user",
|
|
16
|
-
content: [
|
|
17
|
-
{
|
|
18
|
-
type: "text",
|
|
19
|
-
text: `
|
|
20
|
-
You are an expert code reviewer. Follow these steps:
|
|
21
|
-
|
|
22
|
-
1. If no PR number is provided in the args, use ${BashTool.name}("gh pr list") to show open PRs
|
|
23
|
-
2. If a PR number is provided, use ${BashTool.name}("gh pr view <number>") to get PR details
|
|
24
|
-
3. Use ${BashTool.name}("gh pr diff <number>") to get the diff
|
|
25
|
-
4. Analyze the changes and provide a thorough code review that includes:
|
|
26
|
-
- Overview of what the PR does
|
|
27
|
-
- Analysis of code quality and style
|
|
28
|
-
- Specific suggestions for improvements
|
|
29
|
-
- Any potential issues or risks
|
|
30
|
-
|
|
31
|
-
Keep your review concise but thorough. Focus on:
|
|
32
|
-
- Code correctness
|
|
33
|
-
- Following project conventions
|
|
34
|
-
- Performance implications
|
|
35
|
-
- Test coverage
|
|
36
|
-
- Security considerations
|
|
37
|
-
|
|
38
|
-
Format your review with clear sections and bullet points.
|
|
39
|
-
|
|
40
|
-
PR number: ${args}
|
|
41
|
-
`
|
|
42
|
-
}
|
|
43
|
-
]
|
|
44
|
-
}
|
|
45
|
-
];
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
export {
|
|
49
|
-
review_default as default
|
|
50
|
-
};
|
|
51
|
-
//# sourceMappingURL=review.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/commands/review.ts"],
|
|
4
|
-
"sourcesContent": ["import { Command } from '@commands'\nimport { BashTool } from '@tools/BashTool/BashTool'\n\nexport default {\n type: 'prompt',\n name: 'review',\n description: 'Review a pull request',\n isEnabled: true,\n isHidden: false,\n progressMessage: 'reviewing pull request',\n userFacingName() {\n return 'review'\n },\n async getPromptForCommand(args) {\n return [\n {\n role: 'user',\n content: [\n {\n type: 'text',\n text: `\n You are an expert code reviewer. Follow these steps:\n\n 1. If no PR number is provided in the args, use ${BashTool.name}(\"gh pr list\") to show open PRs\n 2. If a PR number is provided, use ${BashTool.name}(\"gh pr view <number>\") to get PR details\n 3. Use ${BashTool.name}(\"gh pr diff <number>\") to get the diff\n 4. Analyze the changes and provide a thorough code review that includes:\n - Overview of what the PR does\n - Analysis of code quality and style\n - Specific suggestions for improvements\n - Any potential issues or risks\n \n Keep your review concise but thorough. Focus on:\n - Code correctness\n - Following project conventions\n - Performance implications\n - Test coverage\n - Security considerations\n\n Format your review with clear sections and bullet points.\n\n PR number: ${args}\n `,\n },\n ],\n },\n ]\n },\n} satisfies Command\n"],
|
|
5
|
-
"mappings": "AACA,SAAS,gBAAgB;AAEzB,IAAO,iBAAQ;AAAA,EACb,MAAM;AAAA,EACN,MAAM;AAAA,EACN,aAAa;AAAA,EACb,WAAW;AAAA,EACX,UAAU;AAAA,EACV,iBAAiB;AAAA,EACjB,iBAAiB;AACf,WAAO;AAAA,EACT;AAAA,EACA,MAAM,oBAAoB,MAAM;AAC9B,WAAO;AAAA,MACL;AAAA,QACE,MAAM;AAAA,QACN,SAAS;AAAA,UACP;AAAA,YACE,MAAM;AAAA,YACN,MAAM;AAAA;AAAA;AAAA,wDAGsC,SAAS,IAAI;AAAA,2CAC1B,SAAS,IAAI;AAAA,eACzC,SAAS,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAgBT,IAAI;AAAA;AAAA,UAEb;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AACF;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
package/dist/components/Bug.js
DELETED
|
@@ -1,147 +0,0 @@
|
|
|
1
|
-
import { Box, Text, useInput } from "ink";
|
|
2
|
-
import * as React from "react";
|
|
3
|
-
import { useState, useCallback, useEffect } from "react";
|
|
4
|
-
import { getTheme } from "../utils/theme.js";
|
|
5
|
-
import { getMessagesGetter } from "../messages.js";
|
|
6
|
-
import TextInput from "./TextInput.js";
|
|
7
|
-
import { env } from "../utils/env.js";
|
|
8
|
-
import { getGitState, getIsGit } from "../utils/git.js";
|
|
9
|
-
import { useTerminalSize } from "../hooks/useTerminalSize.js";
|
|
10
|
-
import { getGlobalConfig } from "../utils/config.js";
|
|
11
|
-
import { API_ERROR_MESSAGE_PREFIX, queryQuick } from "../services/claude.js";
|
|
12
|
-
import { openBrowser } from "../utils/browser.js";
|
|
13
|
-
import { useExitOnCtrlCD } from "../hooks/useExitOnCtrlCD.js";
|
|
14
|
-
import { MACRO } from "../constants/macros.js";
|
|
15
|
-
import { GITHUB_ISSUES_REPO_URL } from "../constants/product.js";
|
|
16
|
-
function Bug({ onDone }) {
|
|
17
|
-
const [step, setStep] = useState("userInput");
|
|
18
|
-
const [cursorOffset, setCursorOffset] = useState(0);
|
|
19
|
-
const [description, setDescription] = useState("");
|
|
20
|
-
const [feedbackId, setFeedbackId] = useState(null);
|
|
21
|
-
const [error, setError] = useState(null);
|
|
22
|
-
const [envInfo, setEnvInfo] = useState({ isGit: false, gitState: null });
|
|
23
|
-
const [title, setTitle] = useState(null);
|
|
24
|
-
const textInputColumns = useTerminalSize().columns - 4;
|
|
25
|
-
const messages = getMessagesGetter()();
|
|
26
|
-
useEffect(() => {
|
|
27
|
-
async function loadEnvInfo() {
|
|
28
|
-
const isGit = await getIsGit();
|
|
29
|
-
let gitState = null;
|
|
30
|
-
if (isGit) {
|
|
31
|
-
gitState = await getGitState();
|
|
32
|
-
}
|
|
33
|
-
setEnvInfo({ isGit, gitState });
|
|
34
|
-
}
|
|
35
|
-
void loadEnvInfo();
|
|
36
|
-
}, []);
|
|
37
|
-
const exitState = useExitOnCtrlCD(() => process.exit(0));
|
|
38
|
-
const submitReport = useCallback(async () => {
|
|
39
|
-
setStep("done");
|
|
40
|
-
}, [description, envInfo.isGit, messages]);
|
|
41
|
-
useInput((input, key) => {
|
|
42
|
-
if (error) {
|
|
43
|
-
onDone("<bash-stderr>Error submitting bug report</bash-stderr>");
|
|
44
|
-
return;
|
|
45
|
-
}
|
|
46
|
-
if (key.escape) {
|
|
47
|
-
onDone("<bash-stderr>Bug report cancelled</bash-stderr>");
|
|
48
|
-
return;
|
|
49
|
-
}
|
|
50
|
-
if (step === "consent" && (key.return || input === " ")) {
|
|
51
|
-
const issueUrl = createGitHubIssueUrl(
|
|
52
|
-
feedbackId,
|
|
53
|
-
description.slice(0, 80),
|
|
54
|
-
description
|
|
55
|
-
);
|
|
56
|
-
void openBrowser(issueUrl);
|
|
57
|
-
onDone("<bash-stdout>Bug report submitted</bash-stdout>");
|
|
58
|
-
}
|
|
59
|
-
});
|
|
60
|
-
const theme = getTheme();
|
|
61
|
-
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
|
|
62
|
-
Box,
|
|
63
|
-
{
|
|
64
|
-
flexDirection: "column",
|
|
65
|
-
borderStyle: "round",
|
|
66
|
-
borderColor: theme.permission,
|
|
67
|
-
paddingX: 1,
|
|
68
|
-
paddingBottom: 1,
|
|
69
|
-
gap: 1
|
|
70
|
-
},
|
|
71
|
-
/* @__PURE__ */ React.createElement(Text, { bold: true, color: theme.permission }, "Submit Bug Report"),
|
|
72
|
-
step === "userInput" && /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", gap: 1 }, /* @__PURE__ */ React.createElement(Text, null, "Describe the issue below and copy/paste any errors you see:"), /* @__PURE__ */ React.createElement(
|
|
73
|
-
TextInput,
|
|
74
|
-
{
|
|
75
|
-
value: description,
|
|
76
|
-
onChange: setDescription,
|
|
77
|
-
columns: textInputColumns,
|
|
78
|
-
onSubmit: () => setStep("consent"),
|
|
79
|
-
onExitMessage: () => onDone("<bash-stderr>Bug report cancelled</bash-stderr>"),
|
|
80
|
-
cursorOffset,
|
|
81
|
-
onChangeCursorOffset: setCursorOffset
|
|
82
|
-
}
|
|
83
|
-
), error && /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", gap: 1 }, /* @__PURE__ */ React.createElement(Text, { color: "red" }, error), /* @__PURE__ */ React.createElement(Text, { dimColor: true }, "Press any key to close"))),
|
|
84
|
-
step === "consent" && /* @__PURE__ */ React.createElement(Box, { flexDirection: "column" }, /* @__PURE__ */ React.createElement(Text, null, "This report will include:"), /* @__PURE__ */ React.createElement(Box, { marginLeft: 2, flexDirection: "column" }, /* @__PURE__ */ React.createElement(Text, null, "- Your bug description: ", /* @__PURE__ */ React.createElement(Text, { dimColor: true }, description)), /* @__PURE__ */ React.createElement(Text, null, "- Environment info:", " ", /* @__PURE__ */ React.createElement(Text, { dimColor: true }, env.platform, ", ", env.terminal, ", v", MACRO.VERSION)), /* @__PURE__ */ React.createElement(Text, null, "- Model settings (no api keys)"))),
|
|
85
|
-
step === "submitting" && /* @__PURE__ */ React.createElement(Box, { flexDirection: "row", gap: 1 }, /* @__PURE__ */ React.createElement(Text, null, "Submitting report\u2026")),
|
|
86
|
-
step === "done" && /* @__PURE__ */ React.createElement(Box, { flexDirection: "column" }, /* @__PURE__ */ React.createElement(Text, { color: getTheme().success }, "Thank you for your report!"), feedbackId && /* @__PURE__ */ React.createElement(Text, { dimColor: true }, "Feedback ID: ", feedbackId), /* @__PURE__ */ React.createElement(Box, { marginTop: 1 }, /* @__PURE__ */ React.createElement(Text, null, "Press "), /* @__PURE__ */ React.createElement(Text, { bold: true }, "Enter "), /* @__PURE__ */ React.createElement(Text, null, "to also create a GitHub issue, or any other key to close.")))
|
|
87
|
-
), /* @__PURE__ */ React.createElement(Box, { marginLeft: 3 }, /* @__PURE__ */ React.createElement(Text, { dimColor: true }, exitState.pending ? /* @__PURE__ */ React.createElement(React.Fragment, null, "Press ", exitState.keyName, " again to exit") : step === "userInput" ? /* @__PURE__ */ React.createElement(React.Fragment, null, "Enter to continue \xB7 Esc to cancel") : step === "consent" ? /* @__PURE__ */ React.createElement(React.Fragment, null, "Enter to open browser to create GitHub issue \xB7 Esc to cancel") : null)));
|
|
88
|
-
}
|
|
89
|
-
function createGitHubIssueUrl(feedbackId, title, description) {
|
|
90
|
-
const globalConfig = getGlobalConfig();
|
|
91
|
-
const modelProfiles = globalConfig.modelProfiles || [];
|
|
92
|
-
const activeProfiles = modelProfiles.filter((p) => p.isActive);
|
|
93
|
-
let modelInfo = "## Models\n";
|
|
94
|
-
if (activeProfiles.length === 0) {
|
|
95
|
-
modelInfo += "- No model profiles configured\n";
|
|
96
|
-
} else {
|
|
97
|
-
activeProfiles.forEach((profile) => {
|
|
98
|
-
modelInfo += `- ${profile.name}
|
|
99
|
-
`;
|
|
100
|
-
modelInfo += ` - provider: ${profile.provider}
|
|
101
|
-
`;
|
|
102
|
-
modelInfo += ` - model: ${profile.modelName}
|
|
103
|
-
`;
|
|
104
|
-
modelInfo += ` - baseURL: ${profile.baseURL}
|
|
105
|
-
`;
|
|
106
|
-
modelInfo += ` - maxTokens: ${profile.maxTokens}
|
|
107
|
-
`;
|
|
108
|
-
modelInfo += ` - contextLength: ${profile.contextLength}
|
|
109
|
-
`;
|
|
110
|
-
if (profile.reasoningEffort) {
|
|
111
|
-
modelInfo += ` - reasoning effort: ${profile.reasoningEffort}
|
|
112
|
-
`;
|
|
113
|
-
}
|
|
114
|
-
});
|
|
115
|
-
}
|
|
116
|
-
const body = encodeURIComponent(`
|
|
117
|
-
## Bug Description
|
|
118
|
-
${description}
|
|
119
|
-
|
|
120
|
-
## Environment Info
|
|
121
|
-
- Platform: ${env.platform}
|
|
122
|
-
- Terminal: ${env.terminal}
|
|
123
|
-
- Version: ${MACRO.VERSION || "unknown"}
|
|
124
|
-
|
|
125
|
-
${modelInfo}`);
|
|
126
|
-
return `${GITHUB_ISSUES_REPO_URL}/new?title=${encodeURIComponent(title)}&body=${body}&labels=user-reported,bug`;
|
|
127
|
-
}
|
|
128
|
-
async function generateTitle(description) {
|
|
129
|
-
const response = await queryQuick({
|
|
130
|
-
systemPrompt: [
|
|
131
|
-
'Generate a concise issue title (max 80 chars) that captures the key point of this feedback. Do not include quotes or prefixes like "Feedback:" or "Issue:". If you cannot generate a title, just use "User Feedback".'
|
|
132
|
-
],
|
|
133
|
-
userPrompt: description
|
|
134
|
-
});
|
|
135
|
-
const title = response.message.content[0]?.type === "text" ? response.message.content[0].text : "Bug Report";
|
|
136
|
-
if (title.startsWith(API_ERROR_MESSAGE_PREFIX)) {
|
|
137
|
-
return `Bug Report: ${description.slice(0, 60)}${description.length > 60 ? "..." : ""}`;
|
|
138
|
-
}
|
|
139
|
-
return title;
|
|
140
|
-
}
|
|
141
|
-
async function submitFeedback(data) {
|
|
142
|
-
return { success: true, feedbackId: "123" };
|
|
143
|
-
}
|
|
144
|
-
export {
|
|
145
|
-
Bug
|
|
146
|
-
};
|
|
147
|
-
//# sourceMappingURL=Bug.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/components/Bug.tsx"],
|
|
4
|
-
"sourcesContent": ["import { Box, Text, useInput } from 'ink'\nimport * as React from 'react'\nimport { useState, useCallback, useEffect } from 'react'\nimport { getTheme } from '@utils/theme'\nimport { getMessagesGetter } from '@messages'\nimport type { Message } from '@query'\nimport TextInput from './TextInput'\nimport { logError, getInMemoryErrors } from '@utils/log'\nimport { env } from '@utils/env'\nimport { getGitState, getIsGit, GitRepoState } from '@utils/git'\nimport { useTerminalSize } from '@hooks/useTerminalSize'\nimport { getAnthropicApiKey, getGlobalConfig } from '@utils/config'\nimport { USER_AGENT } from '@utils/http'\nimport { PRODUCT_NAME } from '@constants/product'\nimport { API_ERROR_MESSAGE_PREFIX, queryQuick } from '@services/claude'\nimport { openBrowser } from '@utils/browser'\nimport { useExitOnCtrlCD } from '@hooks/useExitOnCtrlCD'\nimport { MACRO } from '@constants/macros'\nimport { GITHUB_ISSUES_REPO_URL } from '@constants/product'\n\ntype Props = {\n onDone(result: string): void\n}\n\ntype Step = 'userInput' | 'consent' | 'submitting' | 'done'\n\ntype FeedbackData = {\n // Removing because of privacy concerns. Add this back in when we have a more\n // robust tool for viewing feedback data that can de-identify users\n // user_id: string\n // session_id: string\n message_count: number\n datetime: string\n description: string\n platform: string\n gitRepo: boolean\n version: string | null\n transcript: Message[]\n}\n\nexport function Bug({ onDone }: Props): React.ReactNode {\n const [step, setStep] = useState<Step>('userInput')\n const [cursorOffset, setCursorOffset] = useState(0)\n const [description, setDescription] = useState('')\n const [feedbackId, setFeedbackId] = useState<string | null>(null)\n const [error, setError] = useState<string | null>(null)\n const [envInfo, setEnvInfo] = useState<{\n isGit: boolean\n gitState: GitRepoState | null\n }>({ isGit: false, gitState: null })\n const [title, setTitle] = useState<string | null>(null)\n const textInputColumns = useTerminalSize().columns - 4\n const messages = getMessagesGetter()()\n\n useEffect(() => {\n async function loadEnvInfo() {\n const isGit = await getIsGit()\n let gitState: GitRepoState | null = null\n if (isGit) {\n gitState = await getGitState()\n }\n setEnvInfo({ isGit, gitState })\n }\n void loadEnvInfo()\n }, [])\n\n const exitState = useExitOnCtrlCD(() => process.exit(0))\n\n const submitReport = useCallback(async () => {\n setStep('done')\n // setStep('submitting')\n // setError(null)\n // setFeedbackId(null)\n\n // const reportData = {\n // message_count: messages.length,\n // datetime: new Date().toISOString(),\n // description,\n // platform: env.platform,\n // gitRepo: envInfo.isGit,\n // terminal: env.terminal,\n // version: MACRO.VERSION,\n // transcript: messages,\n // errors: getInMemoryErrors(),\n // }\n\n // const [result, t] = await Promise.all([\n // submitFeedback(reportData),\n // generateTitle(description),\n // ])\n\n // setTitle(t)\n\n // if (result.success) {\n // if (result.feedbackId) {\n // setFeedbackId(result.feedbackId)\n // logEvent('tengu_bug_report_submitted', {\n // feedback_id: result.feedbackId,\n // })\n // }\n // setStep('done')\n // } else {\n // console.log(result)\n // setError('Could not submit feedback. Please try again later.')\n // setStep('userInput')\n // }\n }, [description, envInfo.isGit, messages])\n\n useInput((input, key) => {\n // Allow any key press to close the dialog when done or when there's an error\n // if (step === 'done') {\n // if (key.return && feedbackId && title) {\n // // Open GitHub issue URL when Enter is pressed\n // const issueUrl = createGitHubIssueUrl(feedbackId, title, description)\n // void openBrowser(issueUrl)\n // }\n // onDone('<bash-stdout>Bug report submitted</bash-stdout>')\n // return\n // }\n\n if (error) {\n onDone('<bash-stderr>Error submitting bug report</bash-stderr>')\n return\n }\n\n if (key.escape) {\n onDone('<bash-stderr>Bug report cancelled</bash-stderr>')\n return\n }\n\n if (step === 'consent' && (key.return || input === ' ')) {\n const issueUrl = createGitHubIssueUrl(\n feedbackId,\n description.slice(0, 80),\n description,\n )\n void openBrowser(issueUrl)\n onDone('<bash-stdout>Bug report submitted</bash-stdout>')\n }\n })\n\n const theme = getTheme()\n\n return (\n <>\n <Box\n flexDirection=\"column\"\n borderStyle=\"round\"\n borderColor={theme.permission}\n paddingX={1}\n paddingBottom={1}\n gap={1}\n >\n <Text bold color={theme.permission}>\n Submit Bug Report\n </Text>\n {step === 'userInput' && (\n <Box flexDirection=\"column\" gap={1}>\n <Text>\n Describe the issue below and copy/paste any errors you see:\n </Text>\n <TextInput\n value={description}\n onChange={setDescription}\n columns={textInputColumns}\n onSubmit={() => setStep('consent')}\n onExitMessage={() =>\n onDone('<bash-stderr>Bug report cancelled</bash-stderr>')\n }\n cursorOffset={cursorOffset}\n onChangeCursorOffset={setCursorOffset}\n />\n {error && (\n <Box flexDirection=\"column\" gap={1}>\n <Text color=\"red\">{error}</Text>\n <Text dimColor>Press any key to close</Text>\n </Box>\n )}\n </Box>\n )}\n\n {step === 'consent' && (\n <Box flexDirection=\"column\">\n <Text>This report will include:</Text>\n <Box marginLeft={2} flexDirection=\"column\">\n <Text>\n - Your bug description: <Text dimColor>{description}</Text>\n </Text>\n <Text>\n - Environment info:{' '}\n <Text dimColor>\n {env.platform}, {env.terminal}, v{MACRO.VERSION}\n </Text>\n </Text>\n {/* {envInfo.gitState && (\n <Text>\n - Git repo metadata:{' '}\n <Text dimColor>\n {envInfo.gitState.branchName}\n {envInfo.gitState.commitHash\n ? `, ${envInfo.gitState.commitHash.slice(0, 7)}`\n : ''}\n {envInfo.gitState.remoteUrl\n ? ` @ ${envInfo.gitState.remoteUrl}`\n : ''}\n {!envInfo.gitState.isHeadOnRemote && ', not synced'}\n {!envInfo.gitState.isClean && ', has local changes'}\n </Text>\n </Text>\n )} */}\n <Text>- Model settings (no api keys)</Text>\n </Box>\n {/* <Box marginTop={1}>\n <Text wrap=\"wrap\" dimColor>\n We will use your feedback to debug related issues or to improve{' '}\n {PRODUCT_NAME}'s functionality (eg. to reduce the risk of\n bugs occurring in the future). Anthropic will not train\n generative models using feedback from {PRODUCT_NAME}.\n </Text>\n </Box>\n <Box marginTop={1}>\n <Text>\n Press <Text bold>Enter</Text> to confirm and submit.\n </Text>\n </Box> */}\n </Box>\n )}\n\n {step === 'submitting' && (\n <Box flexDirection=\"row\" gap={1}>\n <Text>Submitting report\u2026</Text>\n </Box>\n )}\n\n {step === 'done' && (\n <Box flexDirection=\"column\">\n <Text color={getTheme().success}>Thank you for your report!</Text>\n {feedbackId && <Text dimColor>Feedback ID: {feedbackId}</Text>}\n <Box marginTop={1}>\n <Text>Press </Text>\n <Text bold>Enter </Text>\n <Text>\n to also create a GitHub issue, or any other key to close.\n </Text>\n </Box>\n </Box>\n )}\n </Box>\n\n <Box marginLeft={3}>\n <Text dimColor>\n {exitState.pending ? (\n <>Press {exitState.keyName} again to exit</>\n ) : step === 'userInput' ? (\n <>Enter to continue \u00B7 Esc to cancel</>\n ) : step === 'consent' ? (\n <>Enter to open browser to create GitHub issue \u00B7 Esc to cancel</>\n ) : null}\n </Text>\n </Box>\n </>\n )\n}\n\nfunction createGitHubIssueUrl(\n feedbackId: string,\n title: string,\n description: string,\n): string {\n const globalConfig = getGlobalConfig()\n\n // Get ModelProfile information instead of legacy model info\n const modelProfiles = globalConfig.modelProfiles || []\n const activeProfiles = modelProfiles.filter(p => p.isActive)\n\n let modelInfo = '## Models\\n'\n if (activeProfiles.length === 0) {\n modelInfo += '- No model profiles configured\\n'\n } else {\n activeProfiles.forEach(profile => {\n modelInfo += `- ${profile.name}\\n`\n modelInfo += ` - provider: ${profile.provider}\\n`\n modelInfo += ` - model: ${profile.modelName}\\n`\n modelInfo += ` - baseURL: ${profile.baseURL}\\n`\n modelInfo += ` - maxTokens: ${profile.maxTokens}\\n`\n modelInfo += ` - contextLength: ${profile.contextLength}\\n`\n if (profile.reasoningEffort) {\n modelInfo += ` - reasoning effort: ${profile.reasoningEffort}\\n`\n }\n })\n }\n\n const body = encodeURIComponent(`\n## Bug Description\n${description}\n\n## Environment Info\n- Platform: ${env.platform}\n- Terminal: ${env.terminal}\n- Version: ${MACRO.VERSION || 'unknown'}\n\n${modelInfo}`)\n return `${GITHUB_ISSUES_REPO_URL}/new?title=${encodeURIComponent(title)}&body=${body}&labels=user-reported,bug`\n}\n\nasync function generateTitle(description: string): Promise<string> {\n const response = await queryQuick({\n systemPrompt: [\n 'Generate a concise issue title (max 80 chars) that captures the key point of this feedback. Do not include quotes or prefixes like \"Feedback:\" or \"Issue:\". If you cannot generate a title, just use \"User Feedback\".',\n ],\n userPrompt: description,\n })\n const title =\n response.message.content[0]?.type === 'text'\n ? response.message.content[0].text\n : 'Bug Report'\n if (title.startsWith(API_ERROR_MESSAGE_PREFIX)) {\n return `Bug Report: ${description.slice(0, 60)}${description.length > 60 ? '...' : ''}`\n }\n return title\n}\n\nasync function submitFeedback(\n data: FeedbackData,\n): Promise<{ success: boolean; feedbackId?: string }> {\n return { success: true, feedbackId: '123' }\n // try {\n // const apiKey = getAnthropicApiKey()\n // if (!apiKey) {\n // return { success: false }\n // }\n\n // const response = await fetch(\n // 'https://api.anthropic.com/api/claude_cli_feedback',\n // {\n // method: 'POST',\n // headers: {\n // 'Content-Type': 'application/json',\n // 'User-Agent': USER_AGENT,\n // 'x-api-key': apiKey,\n // },\n // body: JSON.stringify({\n // content: JSON.stringify(data),\n // }),\n // },\n // )\n\n // if (response.ok) {\n // const result = await response.json()\n // if (result?.feedback_id) {\n // return { success: true, feedbackId: result.feedback_id }\n // }\n // logError('Failed to submit feedback: request did not return feedback_id')\n // return { success: false }\n // }\n\n // logError('Failed to submit feedback:' + response.status)\n // return { success: false }\n // } catch (err) {\n // logError(\n // 'Error submitting feedback: ' +\n // (err instanceof Error ? err.message : 'Unknown error'),\n // )\n // return { success: false }\n // }\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|