@shareai-lab/kode 1.1.12 → 1.1.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cli.js +44 -23
- package/dist/ProjectOnboarding.js +99 -0
- package/dist/ProjectOnboarding.js.map +7 -0
- package/dist/Tool.js +1 -0
- package/dist/Tool.js.map +7 -0
- package/dist/commands/agents.js +2087 -0
- package/dist/commands/agents.js.map +7 -0
- package/dist/commands/approvedTools.js +36 -0
- package/dist/commands/approvedTools.js.map +7 -0
- package/dist/commands/bug.js +21 -0
- package/dist/commands/bug.js.map +7 -0
- package/dist/commands/clear.js +37 -0
- package/dist/commands/clear.js.map +7 -0
- package/dist/commands/compact.js +104 -0
- package/dist/commands/compact.js.map +7 -0
- package/dist/commands/config.js +20 -0
- package/dist/commands/config.js.map +7 -0
- package/dist/commands/cost.js +19 -0
- package/dist/commands/cost.js.map +7 -0
- package/dist/commands/ctx_viz.js +152 -0
- package/dist/commands/ctx_viz.js.map +7 -0
- package/dist/commands/doctor.js +25 -0
- package/dist/commands/doctor.js.map +7 -0
- package/dist/commands/help.js +20 -0
- package/dist/commands/help.js.map +7 -0
- package/dist/commands/init.js +38 -0
- package/dist/commands/init.js.map +7 -0
- package/dist/commands/listen.js +37 -0
- package/dist/commands/listen.js.map +7 -0
- package/dist/commands/login.js +37 -0
- package/dist/commands/login.js.map +7 -0
- package/dist/commands/logout.js +33 -0
- package/dist/commands/logout.js.map +7 -0
- package/dist/commands/mcp.js +34 -0
- package/dist/commands/mcp.js.map +7 -0
- package/dist/commands/model.js +41 -0
- package/dist/commands/model.js.map +7 -0
- package/dist/commands/modelstatus.js +21 -0
- package/dist/commands/modelstatus.js.map +7 -0
- package/dist/commands/onboarding.js +36 -0
- package/dist/commands/onboarding.js.map +7 -0
- package/dist/commands/pr_comments.js +61 -0
- package/dist/commands/pr_comments.js.map +7 -0
- package/dist/commands/refreshCommands.js +37 -0
- package/dist/commands/refreshCommands.js.map +7 -0
- package/dist/commands/release-notes.js +30 -0
- package/dist/commands/release-notes.js.map +7 -0
- package/dist/commands/resume.js +35 -0
- package/dist/commands/resume.js.map +7 -0
- package/dist/commands/review.js +51 -0
- package/dist/commands/review.js.map +7 -0
- package/dist/commands/terminalSetup.js +163 -0
- package/dist/commands/terminalSetup.js.map +7 -0
- package/dist/commands.js +84 -0
- package/dist/commands.js.map +7 -0
- package/dist/components/ApproveApiKey.js +74 -0
- package/dist/components/ApproveApiKey.js.map +7 -0
- package/dist/components/AsciiLogo.js +12 -0
- package/dist/components/AsciiLogo.js.map +7 -0
- package/dist/components/AutoUpdater.js +74 -0
- package/dist/components/AutoUpdater.js.map +7 -0
- package/dist/components/Bug.js +147 -0
- package/dist/components/Bug.js.map +7 -0
- package/dist/components/Config.js +166 -0
- package/dist/components/Config.js.map +7 -0
- package/dist/components/ConsoleOAuthFlow.js +188 -0
- package/dist/components/ConsoleOAuthFlow.js.map +7 -0
- package/dist/components/Cost.js +13 -0
- package/dist/components/Cost.js.map +7 -0
- package/dist/components/CostThresholdDialog.js +38 -0
- package/dist/components/CostThresholdDialog.js.map +7 -0
- package/dist/components/CustomSelect/option-map.js +32 -0
- package/dist/components/CustomSelect/option-map.js.map +7 -0
- package/dist/components/CustomSelect/select-option.js +34 -0
- package/dist/components/CustomSelect/select-option.js.map +7 -0
- package/dist/components/CustomSelect/select.js +64 -0
- package/dist/components/CustomSelect/select.js.map +7 -0
- package/dist/components/CustomSelect/theme.js +1 -0
- package/dist/components/CustomSelect/theme.js.map +7 -0
- package/dist/components/CustomSelect/use-select-state.js +220 -0
- package/dist/components/CustomSelect/use-select-state.js.map +7 -0
- package/dist/components/CustomSelect/use-select.js +21 -0
- package/dist/components/CustomSelect/use-select.js.map +7 -0
- package/dist/components/FallbackToolUseRejectedMessage.js +11 -0
- package/dist/components/FallbackToolUseRejectedMessage.js.map +7 -0
- package/dist/components/FileEditToolUpdatedMessage.js +31 -0
- package/dist/components/FileEditToolUpdatedMessage.js.map +7 -0
- package/dist/components/Help.js +41 -0
- package/dist/components/Help.js.map +7 -0
- package/dist/components/HighlightedCode.js +30 -0
- package/dist/components/HighlightedCode.js.map +7 -0
- package/dist/components/InvalidConfigDialog.js +83 -0
- package/dist/components/InvalidConfigDialog.js.map +7 -0
- package/dist/components/Link.js +18 -0
- package/dist/components/Link.js.map +7 -0
- package/dist/components/LogSelector.js +50 -0
- package/dist/components/LogSelector.js.map +7 -0
- package/dist/components/Logo.js +89 -0
- package/dist/components/Logo.js.map +7 -0
- package/dist/components/MCPServerApprovalDialog.js +79 -0
- package/dist/components/MCPServerApprovalDialog.js.map +7 -0
- package/dist/components/MCPServerDialogCopy.js +11 -0
- package/dist/components/MCPServerDialogCopy.js.map +7 -0
- package/dist/components/MCPServerMultiselectDialog.js +80 -0
- package/dist/components/MCPServerMultiselectDialog.js.map +7 -0
- package/dist/components/Message.js +146 -0
- package/dist/components/Message.js.map +7 -0
- package/dist/components/MessageResponse.js +9 -0
- package/dist/components/MessageResponse.js.map +7 -0
- package/dist/components/MessageSelector.js +133 -0
- package/dist/components/MessageSelector.js.map +7 -0
- package/dist/components/ModeIndicator.js +38 -0
- package/dist/components/ModeIndicator.js.map +7 -0
- package/dist/components/ModelConfig.js +208 -0
- package/dist/components/ModelConfig.js.map +7 -0
- package/dist/components/ModelListManager.js +140 -0
- package/dist/components/ModelListManager.js.map +7 -0
- package/dist/components/ModelSelector.js +1985 -0
- package/dist/components/ModelSelector.js.map +7 -0
- package/dist/components/ModelStatusDisplay.js +87 -0
- package/dist/components/ModelStatusDisplay.js.map +7 -0
- package/dist/components/Onboarding.js +153 -0
- package/dist/components/Onboarding.js.map +7 -0
- package/dist/components/PressEnterToContinue.js +10 -0
- package/dist/components/PressEnterToContinue.js.map +7 -0
- package/dist/components/PromptInput.js +501 -0
- package/dist/components/PromptInput.js.map +7 -0
- package/dist/components/SentryErrorBoundary.js +27 -0
- package/dist/components/SentryErrorBoundary.js.map +7 -0
- package/dist/components/Spinner.js +101 -0
- package/dist/components/Spinner.js.map +7 -0
- package/dist/components/StickerRequestForm.js +7 -0
- package/dist/components/StickerRequestForm.js.map +7 -0
- package/dist/components/StructuredDiff.js +148 -0
- package/dist/components/StructuredDiff.js.map +7 -0
- package/dist/components/TextInput.js +100 -0
- package/dist/components/TextInput.js.map +7 -0
- package/dist/components/TodoItem.js +35 -0
- package/dist/components/TodoItem.js.map +7 -0
- package/dist/components/TokenWarning.js +19 -0
- package/dist/components/TokenWarning.js.map +7 -0
- package/dist/components/ToolUseLoader.js +24 -0
- package/dist/components/ToolUseLoader.js.map +7 -0
- package/dist/components/TrustDialog.js +76 -0
- package/dist/components/TrustDialog.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedback.js +50 -0
- package/dist/components/binary-feedback/BinaryFeedback.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedbackOption.js +94 -0
- package/dist/components/binary-feedback/BinaryFeedbackOption.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedbackView.js +139 -0
- package/dist/components/binary-feedback/BinaryFeedbackView.js.map +7 -0
- package/dist/components/binary-feedback/utils.js +161 -0
- package/dist/components/binary-feedback/utils.js.map +7 -0
- package/dist/components/messages/AssistantBashOutputMessage.js +23 -0
- package/dist/components/messages/AssistantBashOutputMessage.js.map +7 -0
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js +36 -0
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js.map +7 -0
- package/dist/components/messages/AssistantRedactedThinkingMessage.js +12 -0
- package/dist/components/messages/AssistantRedactedThinkingMessage.js.map +7 -0
- package/dist/components/messages/AssistantTextMessage.js +78 -0
- package/dist/components/messages/AssistantTextMessage.js.map +7 -0
- package/dist/components/messages/AssistantThinkingMessage.js +27 -0
- package/dist/components/messages/AssistantThinkingMessage.js.map +7 -0
- package/dist/components/messages/AssistantToolUseMessage.js +91 -0
- package/dist/components/messages/AssistantToolUseMessage.js.map +7 -0
- package/dist/components/messages/TaskProgressMessage.js +11 -0
- package/dist/components/messages/TaskProgressMessage.js.map +7 -0
- package/dist/components/messages/TaskToolMessage.js +39 -0
- package/dist/components/messages/TaskToolMessage.js.map +7 -0
- package/dist/components/messages/UserBashInputMessage.js +18 -0
- package/dist/components/messages/UserBashInputMessage.js.map +7 -0
- package/dist/components/messages/UserCommandMessage.js +20 -0
- package/dist/components/messages/UserCommandMessage.js.map +7 -0
- package/dist/components/messages/UserKodingInputMessage.js +18 -0
- package/dist/components/messages/UserKodingInputMessage.js.map +7 -0
- package/dist/components/messages/UserPromptMessage.js +20 -0
- package/dist/components/messages/UserPromptMessage.js.map +7 -0
- package/dist/components/messages/UserTextMessage.js +25 -0
- package/dist/components/messages/UserTextMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +10 -0
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js +15 -0
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js +25 -0
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js +47 -0
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +23 -0
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/utils.js +42 -0
- package/dist/components/messages/UserToolResultMessage/utils.js.map +7 -0
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js +112 -0
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FallbackPermissionRequest.js +131 -0
- package/dist/components/permissions/FallbackPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +159 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js +58 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js.map +7 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +153 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +70 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js.map +7 -0
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +212 -0
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js.map +7 -0
- package/dist/components/permissions/PermissionRequest.js +70 -0
- package/dist/components/permissions/PermissionRequest.js.map +7 -0
- package/dist/components/permissions/PermissionRequestTitle.js +52 -0
- package/dist/components/permissions/PermissionRequestTitle.js.map +7 -0
- package/dist/components/permissions/hooks.js +28 -0
- package/dist/components/permissions/hooks.js.map +7 -0
- package/dist/components/permissions/toolUseOptions.js +46 -0
- package/dist/components/permissions/toolUseOptions.js.map +7 -0
- package/dist/components/permissions/utils.js +21 -0
- package/dist/components/permissions/utils.js.map +7 -0
- package/dist/constants/betas.js +11 -0
- package/dist/constants/betas.js.map +7 -0
- package/dist/constants/claude-asterisk-ascii-art.js +242 -0
- package/dist/constants/claude-asterisk-ascii-art.js.map +7 -0
- package/dist/constants/figures.js +6 -0
- package/dist/constants/figures.js.map +7 -0
- package/dist/constants/keys.js +7 -0
- package/dist/constants/keys.js.map +7 -0
- package/dist/constants/macros.js +13 -0
- package/dist/constants/macros.js.map +7 -0
- package/dist/constants/modelCapabilities.js +154 -0
- package/dist/constants/modelCapabilities.js.map +7 -0
- package/dist/constants/models.js +1029 -0
- package/dist/constants/models.js.map +7 -0
- package/dist/constants/oauth.js +18 -0
- package/dist/constants/oauth.js.map +7 -0
- package/dist/constants/product.js +26 -0
- package/dist/constants/product.js.map +7 -0
- package/dist/constants/prompts.js +168 -0
- package/dist/constants/prompts.js.map +7 -0
- package/dist/constants/releaseNotes.js +9 -0
- package/dist/constants/releaseNotes.js.map +7 -0
- package/dist/context/PermissionContext.js +111 -0
- package/dist/context/PermissionContext.js.map +7 -0
- package/dist/context.js +259 -0
- package/dist/context.js.map +7 -0
- package/dist/cost-tracker.js +76 -0
- package/dist/cost-tracker.js.map +7 -0
- package/dist/entrypoints/cli.js +1101 -0
- package/dist/entrypoints/cli.js.map +7 -0
- package/dist/entrypoints/mcp.js +150 -0
- package/dist/entrypoints/mcp.js.map +7 -0
- package/dist/history.js +25 -0
- package/dist/history.js.map +7 -0
- package/dist/hooks/useApiKeyVerification.js +12 -0
- package/dist/hooks/useApiKeyVerification.js.map +7 -0
- package/dist/hooks/useArrowKeyHistory.js +50 -0
- package/dist/hooks/useArrowKeyHistory.js.map +7 -0
- package/dist/hooks/useCanUseTool.js +112 -0
- package/dist/hooks/useCanUseTool.js.map +7 -0
- package/dist/hooks/useCancelRequest.js +30 -0
- package/dist/hooks/useCancelRequest.js.map +7 -0
- package/dist/hooks/useDoublePress.js +31 -0
- package/dist/hooks/useDoublePress.js.map +7 -0
- package/dist/hooks/useExitOnCtrlCD.js +26 -0
- package/dist/hooks/useExitOnCtrlCD.js.map +7 -0
- package/dist/hooks/useInterval.js +18 -0
- package/dist/hooks/useInterval.js.map +7 -0
- package/dist/hooks/useLogMessages.js +14 -0
- package/dist/hooks/useLogMessages.js.map +7 -0
- package/dist/hooks/useLogStartupTime.js +15 -0
- package/dist/hooks/useLogStartupTime.js.map +7 -0
- package/dist/hooks/useNotifyAfterTimeout.js +42 -0
- package/dist/hooks/useNotifyAfterTimeout.js.map +7 -0
- package/dist/hooks/usePermissionRequestLogging.js +28 -0
- package/dist/hooks/usePermissionRequestLogging.js.map +7 -0
- package/dist/hooks/useTerminalSize.js +38 -0
- package/dist/hooks/useTerminalSize.js.map +7 -0
- package/dist/hooks/useTextInput.js +250 -0
- package/dist/hooks/useTextInput.js.map +7 -0
- package/dist/hooks/useUnifiedCompletion.js +929 -0
- package/dist/hooks/useUnifiedCompletion.js.map +7 -0
- package/dist/index.js +26 -0
- package/dist/index.js.map +7 -0
- package/dist/messages.js +33 -0
- package/dist/messages.js.map +7 -0
- package/dist/package.json +1 -0
- package/dist/permissions.js +194 -0
- package/dist/permissions.js.map +7 -0
- package/dist/query.js +492 -0
- package/dist/query.js.map +7 -0
- package/dist/screens/ConfigureNpmPrefix.js +128 -0
- package/dist/screens/ConfigureNpmPrefix.js.map +7 -0
- package/dist/screens/Doctor.js +143 -0
- package/dist/screens/Doctor.js.map +7 -0
- package/dist/screens/LogList.js +55 -0
- package/dist/screens/LogList.js.map +7 -0
- package/dist/screens/REPL.js +596 -0
- package/dist/screens/REPL.js.map +7 -0
- package/dist/screens/ResumeConversation.js +56 -0
- package/dist/screens/ResumeConversation.js.map +7 -0
- package/dist/services/adapters/base.js +29 -0
- package/dist/services/adapters/base.js.map +7 -0
- package/dist/services/adapters/chatCompletions.js +69 -0
- package/dist/services/adapters/chatCompletions.js.map +7 -0
- package/dist/services/adapters/responsesAPI.js +126 -0
- package/dist/services/adapters/responsesAPI.js.map +7 -0
- package/dist/services/browserMocks.js +48 -0
- package/dist/services/browserMocks.js.map +7 -0
- package/dist/services/claude.js +1605 -0
- package/dist/services/claude.js.map +7 -0
- package/dist/services/customCommands.js +359 -0
- package/dist/services/customCommands.js.map +7 -0
- package/dist/services/fileFreshness.js +280 -0
- package/dist/services/fileFreshness.js.map +7 -0
- package/dist/services/gpt5ConnectionTest.js +248 -0
- package/dist/services/gpt5ConnectionTest.js.map +7 -0
- package/dist/services/mcpClient.js +435 -0
- package/dist/services/mcpClient.js.map +7 -0
- package/dist/services/mcpServerApproval.js +55 -0
- package/dist/services/mcpServerApproval.js.map +7 -0
- package/dist/services/mentionProcessor.js +200 -0
- package/dist/services/mentionProcessor.js.map +7 -0
- package/dist/services/modelAdapterFactory.js +47 -0
- package/dist/services/modelAdapterFactory.js.map +7 -0
- package/dist/services/notifier.js +35 -0
- package/dist/services/notifier.js.map +7 -0
- package/dist/services/oauth.js +259 -0
- package/dist/services/oauth.js.map +7 -0
- package/dist/services/openai.js +998 -0
- package/dist/services/openai.js.map +7 -0
- package/dist/services/responseStateManager.js +68 -0
- package/dist/services/responseStateManager.js.map +7 -0
- package/dist/services/sentry.js +9 -0
- package/dist/services/sentry.js.map +7 -0
- package/dist/services/statsig.js +112 -0
- package/dist/services/statsig.js.map +7 -0
- package/dist/services/statsigStorage.js +75 -0
- package/dist/services/statsigStorage.js.map +7 -0
- package/dist/services/systemReminder.js +353 -0
- package/dist/services/systemReminder.js.map +7 -0
- package/dist/services/vcr.js +133 -0
- package/dist/services/vcr.js.map +7 -0
- package/dist/test/testAdapters.js +88 -0
- package/dist/test/testAdapters.js.map +1 -0
- package/dist/tools/ArchitectTool/ArchitectTool.js +119 -0
- package/dist/tools/ArchitectTool/ArchitectTool.js.map +7 -0
- package/dist/tools/ArchitectTool/prompt.js +18 -0
- package/dist/tools/ArchitectTool/prompt.js.map +7 -0
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js +423 -0
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js.map +7 -0
- package/dist/tools/BashTool/BashTool.js +188 -0
- package/dist/tools/BashTool/BashTool.js.map +7 -0
- package/dist/tools/BashTool/BashToolResultMessage.js +21 -0
- package/dist/tools/BashTool/BashToolResultMessage.js.map +7 -0
- package/dist/tools/BashTool/OutputLine.js +30 -0
- package/dist/tools/BashTool/OutputLine.js.map +7 -0
- package/dist/tools/BashTool/prompt.js +179 -0
- package/dist/tools/BashTool/prompt.js.map +7 -0
- package/dist/tools/BashTool/utils.js +51 -0
- package/dist/tools/BashTool/utils.js.map +7 -0
- package/dist/tools/FileEditTool/FileEditTool.js +228 -0
- package/dist/tools/FileEditTool/FileEditTool.js.map +7 -0
- package/dist/tools/FileEditTool/prompt.js +54 -0
- package/dist/tools/FileEditTool/prompt.js.map +7 -0
- package/dist/tools/FileEditTool/utils.js +42 -0
- package/dist/tools/FileEditTool/utils.js.map +7 -0
- package/dist/tools/FileReadTool/FileReadTool.js +272 -0
- package/dist/tools/FileReadTool/FileReadTool.js.map +7 -0
- package/dist/tools/FileReadTool/prompt.js +10 -0
- package/dist/tools/FileReadTool/prompt.js.map +7 -0
- package/dist/tools/FileWriteTool/FileWriteTool.js +204 -0
- package/dist/tools/FileWriteTool/FileWriteTool.js.map +7 -0
- package/dist/tools/FileWriteTool/prompt.js +14 -0
- package/dist/tools/FileWriteTool/prompt.js.map +7 -0
- package/dist/tools/GlobTool/GlobTool.js +88 -0
- package/dist/tools/GlobTool/GlobTool.js.map +7 -0
- package/dist/tools/GlobTool/prompt.js +12 -0
- package/dist/tools/GlobTool/prompt.js.map +7 -0
- package/dist/tools/GrepTool/GrepTool.js +107 -0
- package/dist/tools/GrepTool/GrepTool.js.map +7 -0
- package/dist/tools/GrepTool/prompt.js +15 -0
- package/dist/tools/GrepTool/prompt.js.map +7 -0
- package/dist/tools/MCPTool/MCPTool.js +90 -0
- package/dist/tools/MCPTool/MCPTool.js.map +7 -0
- package/dist/tools/MCPTool/prompt.js +7 -0
- package/dist/tools/MCPTool/prompt.js.map +7 -0
- package/dist/tools/MemoryReadTool/MemoryReadTool.js +103 -0
- package/dist/tools/MemoryReadTool/MemoryReadTool.js.map +7 -0
- package/dist/tools/MemoryReadTool/prompt.js +7 -0
- package/dist/tools/MemoryReadTool/prompt.js.map +7 -0
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js +77 -0
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js.map +7 -0
- package/dist/tools/MemoryWriteTool/prompt.js +7 -0
- package/dist/tools/MemoryWriteTool/prompt.js.map +7 -0
- package/dist/tools/MultiEditTool/MultiEditTool.js +293 -0
- package/dist/tools/MultiEditTool/MultiEditTool.js.map +7 -0
- package/dist/tools/MultiEditTool/prompt.js +48 -0
- package/dist/tools/MultiEditTool/prompt.js.map +7 -0
- package/dist/tools/NotebookEditTool/NotebookEditTool.js +238 -0
- package/dist/tools/NotebookEditTool/NotebookEditTool.js.map +7 -0
- package/dist/tools/NotebookEditTool/prompt.js +7 -0
- package/dist/tools/NotebookEditTool/prompt.js.map +7 -0
- package/dist/tools/NotebookReadTool/NotebookReadTool.js +212 -0
- package/dist/tools/NotebookReadTool/NotebookReadTool.js.map +7 -0
- package/dist/tools/NotebookReadTool/prompt.js +7 -0
- package/dist/tools/NotebookReadTool/prompt.js.map +7 -0
- package/dist/tools/StickerRequestTool/StickerRequestTool.js +86 -0
- package/dist/tools/StickerRequestTool/StickerRequestTool.js.map +7 -0
- package/dist/tools/StickerRequestTool/prompt.js +23 -0
- package/dist/tools/StickerRequestTool/prompt.js.map +7 -0
- package/dist/tools/TaskTool/TaskTool.js +308 -0
- package/dist/tools/TaskTool/TaskTool.js.map +7 -0
- package/dist/tools/TaskTool/constants.js +5 -0
- package/dist/tools/TaskTool/constants.js.map +7 -0
- package/dist/tools/TaskTool/prompt.js +82 -0
- package/dist/tools/TaskTool/prompt.js.map +7 -0
- package/dist/tools/ThinkTool/ThinkTool.js +48 -0
- package/dist/tools/ThinkTool/ThinkTool.js.map +7 -0
- package/dist/tools/ThinkTool/prompt.js +16 -0
- package/dist/tools/ThinkTool/prompt.js.map +7 -0
- package/dist/tools/TodoWriteTool/TodoWriteTool.js +216 -0
- package/dist/tools/TodoWriteTool/TodoWriteTool.js.map +7 -0
- package/dist/tools/TodoWriteTool/prompt.js +66 -0
- package/dist/tools/TodoWriteTool/prompt.js.map +7 -0
- package/dist/tools/URLFetcherTool/URLFetcherTool.js +137 -0
- package/dist/tools/URLFetcherTool/URLFetcherTool.js.map +7 -0
- package/dist/tools/URLFetcherTool/cache.js +45 -0
- package/dist/tools/URLFetcherTool/cache.js.map +7 -0
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js +42 -0
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js.map +7 -0
- package/dist/tools/URLFetcherTool/prompt.js +22 -0
- package/dist/tools/URLFetcherTool/prompt.js.map +7 -0
- package/dist/tools/WebSearchTool/WebSearchTool.js +86 -0
- package/dist/tools/WebSearchTool/WebSearchTool.js.map +7 -0
- package/dist/tools/WebSearchTool/prompt.js +17 -0
- package/dist/tools/WebSearchTool/prompt.js.map +7 -0
- package/dist/tools/WebSearchTool/searchProviders.js +48 -0
- package/dist/tools/WebSearchTool/searchProviders.js.map +7 -0
- package/dist/tools/lsTool/lsTool.js +201 -0
- package/dist/tools/lsTool/lsTool.js.map +7 -0
- package/dist/tools/lsTool/prompt.js +5 -0
- package/dist/tools/lsTool/prompt.js.map +7 -0
- package/dist/tools.js +64 -0
- package/dist/tools.js.map +7 -0
- package/dist/types/PermissionMode.js +82 -0
- package/dist/types/PermissionMode.js.map +7 -0
- package/dist/types/RequestContext.js +47 -0
- package/dist/types/RequestContext.js.map +7 -0
- package/dist/types/common.d.js +1 -0
- package/dist/types/common.d.js.map +7 -0
- package/dist/types/conversation.js +1 -0
- package/dist/types/conversation.js.map +7 -0
- package/dist/types/logs.js +1 -0
- package/dist/types/logs.js.map +7 -0
- package/dist/types/modelCapabilities.js +1 -0
- package/dist/types/modelCapabilities.js.map +7 -0
- package/dist/types/notebook.js +1 -0
- package/dist/types/notebook.js.map +7 -0
- package/dist/utils/Cursor.js +313 -0
- package/dist/utils/Cursor.js.map +7 -0
- package/dist/utils/PersistentShell.js +382 -0
- package/dist/utils/PersistentShell.js.map +7 -0
- package/dist/utils/advancedFuzzyMatcher.js +206 -0
- package/dist/utils/advancedFuzzyMatcher.js.map +7 -0
- package/dist/utils/agentLoader.js +199 -0
- package/dist/utils/agentLoader.js.map +7 -0
- package/dist/utils/agentStorage.js +59 -0
- package/dist/utils/agentStorage.js.map +7 -0
- package/dist/utils/array.js +7 -0
- package/dist/utils/array.js.map +7 -0
- package/dist/utils/ask.js +77 -0
- package/dist/utils/ask.js.map +7 -0
- package/dist/utils/auth.js +11 -0
- package/dist/utils/auth.js.map +7 -0
- package/dist/utils/autoCompactCore.js +149 -0
- package/dist/utils/autoCompactCore.js.map +7 -0
- package/dist/utils/autoUpdater.js +362 -0
- package/dist/utils/autoUpdater.js.map +7 -0
- package/dist/utils/betas.js +21 -0
- package/dist/utils/betas.js.map +7 -0
- package/dist/utils/browser.js +15 -0
- package/dist/utils/browser.js.map +7 -0
- package/dist/utils/cleanup.js +54 -0
- package/dist/utils/cleanup.js.map +7 -0
- package/dist/utils/commands.js +207 -0
- package/dist/utils/commands.js.map +7 -0
- package/dist/utils/commonUnixCommands.js +687 -0
- package/dist/utils/commonUnixCommands.js.map +7 -0
- package/dist/utils/config.js +655 -0
- package/dist/utils/config.js.map +7 -0
- package/dist/utils/conversationRecovery.js +35 -0
- package/dist/utils/conversationRecovery.js.map +7 -0
- package/dist/utils/debugLogger.js +891 -0
- package/dist/utils/debugLogger.js.map +7 -0
- package/dist/utils/diff.js +32 -0
- package/dist/utils/diff.js.map +7 -0
- package/dist/utils/env.js +44 -0
- package/dist/utils/env.js.map +7 -0
- package/dist/utils/errors.js +23 -0
- package/dist/utils/errors.js.map +7 -0
- package/dist/utils/exampleCommands.js +80 -0
- package/dist/utils/exampleCommands.js.map +7 -0
- package/dist/utils/execFileNoThrow.js +44 -0
- package/dist/utils/execFileNoThrow.js.map +7 -0
- package/dist/utils/expertChatStorage.js +78 -0
- package/dist/utils/expertChatStorage.js.map +7 -0
- package/dist/utils/file.js +282 -0
- package/dist/utils/file.js.map +7 -0
- package/dist/utils/fileRecoveryCore.js +41 -0
- package/dist/utils/fileRecoveryCore.js.map +7 -0
- package/dist/utils/format.js +41 -0
- package/dist/utils/format.js.map +7 -0
- package/dist/utils/fuzzyMatcher.js +252 -0
- package/dist/utils/fuzzyMatcher.js.map +7 -0
- package/dist/utils/generators.js +46 -0
- package/dist/utils/generators.js.map +7 -0
- package/dist/utils/git.js +83 -0
- package/dist/utils/git.js.map +7 -0
- package/dist/utils/globalLogger.js +54 -0
- package/dist/utils/globalLogger.js.map +7 -0
- package/dist/utils/http.js +7 -0
- package/dist/utils/http.js.map +7 -0
- package/dist/utils/imagePaste.js +29 -0
- package/dist/utils/imagePaste.js.map +7 -0
- package/dist/utils/json.js +16 -0
- package/dist/utils/json.js.map +7 -0
- package/dist/utils/log.js +298 -0
- package/dist/utils/log.js.map +7 -0
- package/dist/utils/markdown.js +187 -0
- package/dist/utils/markdown.js.map +7 -0
- package/dist/utils/messageContextManager.js +195 -0
- package/dist/utils/messageContextManager.js.map +7 -0
- package/dist/utils/messages.js +633 -0
- package/dist/utils/messages.js.map +7 -0
- package/dist/utils/model.js +687 -0
- package/dist/utils/model.js.map +7 -0
- package/dist/utils/permissions/filesystem.js +80 -0
- package/dist/utils/permissions/filesystem.js.map +7 -0
- package/dist/utils/responseState.js +20 -0
- package/dist/utils/responseState.js.map +7 -0
- package/dist/utils/ripgrep.js +131 -0
- package/dist/utils/ripgrep.js.map +7 -0
- package/dist/utils/secureFile.js +483 -0
- package/dist/utils/secureFile.js.map +7 -0
- package/dist/utils/sessionState.js +31 -0
- package/dist/utils/sessionState.js.map +7 -0
- package/dist/utils/state.js +24 -0
- package/dist/utils/state.js.map +7 -0
- package/dist/utils/style.js +31 -0
- package/dist/utils/style.js.map +7 -0
- package/dist/utils/terminal.js +43 -0
- package/dist/utils/terminal.js.map +7 -0
- package/dist/utils/theme.js +102 -0
- package/dist/utils/theme.js.map +7 -0
- package/dist/utils/thinking.js +103 -0
- package/dist/utils/thinking.js.map +7 -0
- package/dist/utils/todoStorage.js +291 -0
- package/dist/utils/todoStorage.js.map +7 -0
- package/dist/utils/tokens.js +30 -0
- package/dist/utils/tokens.js.map +7 -0
- package/dist/utils/toolExecutionController.js +109 -0
- package/dist/utils/toolExecutionController.js.map +7 -0
- package/dist/utils/unaryLogging.js +14 -0
- package/dist/utils/unaryLogging.js.map +7 -0
- package/dist/utils/user.js +40 -0
- package/dist/utils/user.js.map +7 -0
- package/dist/utils/validate.js +132 -0
- package/dist/utils/validate.js.map +7 -0
- package/dist/yoga.wasm +0 -0
- package/package.json +28 -7
- package/src/Tool.ts +4 -3
- package/src/commands/agents.tsx +10 -4
- package/src/components/messages/AssistantToolUseMessage.tsx +5 -6
- package/src/constants/macros.ts +5 -2
- package/src/entrypoints/cli.tsx +38 -19
- package/src/entrypoints/mcp.ts +1 -2
- package/src/hooks/useDoublePress.ts +0 -1
- package/src/hooks/useTextInput.ts +4 -5
- package/src/hooks/useUnifiedCompletion.ts +2 -2
- package/src/index.ts +34 -0
- package/src/query.ts +13 -8
- package/src/screens/Doctor.tsx +1 -1
- package/src/screens/REPL.tsx +13 -9
- package/src/services/openai.ts +25 -4
- package/src/tools/ArchitectTool/ArchitectTool.tsx +18 -5
- package/src/tools/AskExpertModelTool/AskExpertModelTool.tsx +21 -14
- package/src/tools/FileEditTool/FileEditTool.tsx +6 -2
- package/src/tools/FileWriteTool/FileWriteTool.tsx +7 -3
- package/src/tools/MultiEditTool/MultiEditTool.tsx +26 -4
- package/src/tools/NotebookReadTool/NotebookReadTool.tsx +1 -1
- package/src/tools/StickerRequestTool/StickerRequestTool.tsx +28 -14
- package/src/tools/TaskTool/TaskTool.tsx +8 -36
- package/src/types/common.d.ts +2 -0
- package/src/utils/generators.ts +1 -1
- package/src/utils/messageContextManager.ts +5 -0
- package/src/utils/messages.tsx +8 -2
- package/src/utils/thinking.ts +1 -1
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
import { Box } from "ink";
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
import { logError } from "../utils/log.js";
|
|
4
|
+
import { UserToolResultMessage } from "./messages/UserToolResultMessage/UserToolResultMessage.js";
|
|
5
|
+
import { AssistantToolUseMessage } from "./messages/AssistantToolUseMessage.js";
|
|
6
|
+
import { AssistantTextMessage } from "./messages/AssistantTextMessage.js";
|
|
7
|
+
import { UserTextMessage } from "./messages/UserTextMessage.js";
|
|
8
|
+
import { AssistantThinkingMessage } from "./messages/AssistantThinkingMessage.js";
|
|
9
|
+
import { AssistantRedactedThinkingMessage } from "./messages/AssistantRedactedThinkingMessage.js";
|
|
10
|
+
import { useTerminalSize } from "../hooks/useTerminalSize.js";
|
|
11
|
+
function Message({
|
|
12
|
+
message,
|
|
13
|
+
messages,
|
|
14
|
+
addMargin,
|
|
15
|
+
tools,
|
|
16
|
+
verbose,
|
|
17
|
+
debug,
|
|
18
|
+
erroredToolUseIDs,
|
|
19
|
+
inProgressToolUseIDs,
|
|
20
|
+
unresolvedToolUseIDs,
|
|
21
|
+
shouldAnimate,
|
|
22
|
+
shouldShowDot,
|
|
23
|
+
width
|
|
24
|
+
}) {
|
|
25
|
+
if (message.type === "assistant") {
|
|
26
|
+
return /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", width: "100%" }, message.message.content.map((_, index) => /* @__PURE__ */ React.createElement(
|
|
27
|
+
AssistantMessage,
|
|
28
|
+
{
|
|
29
|
+
key: index,
|
|
30
|
+
param: _,
|
|
31
|
+
costUSD: message.costUSD,
|
|
32
|
+
durationMs: message.durationMs,
|
|
33
|
+
addMargin,
|
|
34
|
+
tools,
|
|
35
|
+
debug,
|
|
36
|
+
options: { verbose },
|
|
37
|
+
erroredToolUseIDs,
|
|
38
|
+
inProgressToolUseIDs,
|
|
39
|
+
unresolvedToolUseIDs,
|
|
40
|
+
shouldAnimate,
|
|
41
|
+
shouldShowDot,
|
|
42
|
+
width
|
|
43
|
+
}
|
|
44
|
+
)));
|
|
45
|
+
}
|
|
46
|
+
const content = typeof message.message.content === "string" ? [{ type: "text", text: message.message.content }] : message.message.content;
|
|
47
|
+
return /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", width: "100%" }, content.map((_, index) => /* @__PURE__ */ React.createElement(
|
|
48
|
+
UserMessage,
|
|
49
|
+
{
|
|
50
|
+
key: index,
|
|
51
|
+
message,
|
|
52
|
+
messages,
|
|
53
|
+
addMargin,
|
|
54
|
+
tools,
|
|
55
|
+
param: _,
|
|
56
|
+
options: { verbose }
|
|
57
|
+
}
|
|
58
|
+
)));
|
|
59
|
+
}
|
|
60
|
+
function UserMessage({
|
|
61
|
+
message,
|
|
62
|
+
messages,
|
|
63
|
+
addMargin,
|
|
64
|
+
tools,
|
|
65
|
+
param,
|
|
66
|
+
options: { verbose }
|
|
67
|
+
}) {
|
|
68
|
+
const { columns } = useTerminalSize();
|
|
69
|
+
switch (param.type) {
|
|
70
|
+
case "text":
|
|
71
|
+
return /* @__PURE__ */ React.createElement(UserTextMessage, { addMargin, param });
|
|
72
|
+
case "tool_result":
|
|
73
|
+
return /* @__PURE__ */ React.createElement(
|
|
74
|
+
UserToolResultMessage,
|
|
75
|
+
{
|
|
76
|
+
param,
|
|
77
|
+
message,
|
|
78
|
+
messages,
|
|
79
|
+
tools,
|
|
80
|
+
verbose,
|
|
81
|
+
width: columns - 5
|
|
82
|
+
}
|
|
83
|
+
);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
function AssistantMessage({
|
|
87
|
+
param,
|
|
88
|
+
costUSD,
|
|
89
|
+
durationMs,
|
|
90
|
+
addMargin,
|
|
91
|
+
tools,
|
|
92
|
+
debug,
|
|
93
|
+
options: { verbose },
|
|
94
|
+
erroredToolUseIDs,
|
|
95
|
+
inProgressToolUseIDs,
|
|
96
|
+
unresolvedToolUseIDs,
|
|
97
|
+
shouldAnimate,
|
|
98
|
+
shouldShowDot,
|
|
99
|
+
width
|
|
100
|
+
}) {
|
|
101
|
+
switch (param.type) {
|
|
102
|
+
case "tool_use":
|
|
103
|
+
return /* @__PURE__ */ React.createElement(
|
|
104
|
+
AssistantToolUseMessage,
|
|
105
|
+
{
|
|
106
|
+
param,
|
|
107
|
+
costUSD,
|
|
108
|
+
durationMs,
|
|
109
|
+
addMargin,
|
|
110
|
+
tools,
|
|
111
|
+
debug,
|
|
112
|
+
verbose,
|
|
113
|
+
erroredToolUseIDs,
|
|
114
|
+
inProgressToolUseIDs,
|
|
115
|
+
unresolvedToolUseIDs,
|
|
116
|
+
shouldAnimate,
|
|
117
|
+
shouldShowDot
|
|
118
|
+
}
|
|
119
|
+
);
|
|
120
|
+
case "text":
|
|
121
|
+
return /* @__PURE__ */ React.createElement(
|
|
122
|
+
AssistantTextMessage,
|
|
123
|
+
{
|
|
124
|
+
param,
|
|
125
|
+
costUSD,
|
|
126
|
+
durationMs,
|
|
127
|
+
debug,
|
|
128
|
+
addMargin,
|
|
129
|
+
shouldShowDot,
|
|
130
|
+
verbose,
|
|
131
|
+
width
|
|
132
|
+
}
|
|
133
|
+
);
|
|
134
|
+
case "redacted_thinking":
|
|
135
|
+
return /* @__PURE__ */ React.createElement(AssistantRedactedThinkingMessage, { addMargin });
|
|
136
|
+
case "thinking":
|
|
137
|
+
return /* @__PURE__ */ React.createElement(AssistantThinkingMessage, { addMargin, param });
|
|
138
|
+
default:
|
|
139
|
+
logError(`Unable to render message type: ${param.type}`);
|
|
140
|
+
return null;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
export {
|
|
144
|
+
Message
|
|
145
|
+
};
|
|
146
|
+
//# sourceMappingURL=Message.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/components/Message.tsx"],
|
|
4
|
+
"sourcesContent": ["import { Box } from 'ink'\nimport * as React from 'react'\nimport type { AssistantMessage, Message, UserMessage } from '../query'\nimport type {\n ContentBlock,\n DocumentBlockParam,\n ImageBlockParam,\n TextBlockParam,\n ThinkingBlockParam,\n ToolResultBlockParam,\n ToolUseBlockParam,\n} from '@anthropic-ai/sdk/resources/index.mjs'\nimport { Tool } from '../Tool'\nimport { logError } from '../utils/log'\nimport { UserToolResultMessage } from './messages/UserToolResultMessage/UserToolResultMessage'\nimport { AssistantToolUseMessage } from './messages/AssistantToolUseMessage'\nimport { AssistantTextMessage } from './messages/AssistantTextMessage'\nimport { UserTextMessage } from './messages/UserTextMessage'\nimport { NormalizedMessage } from '../utils/messages'\nimport { AssistantThinkingMessage } from './messages/AssistantThinkingMessage'\nimport { AssistantRedactedThinkingMessage } from './messages/AssistantRedactedThinkingMessage'\nimport { useTerminalSize } from '../hooks/useTerminalSize'\n\ntype Props = {\n message: UserMessage | AssistantMessage\n messages: NormalizedMessage[]\n // TODO: Find a way to remove this, and leave spacing to the consumer\n addMargin: boolean\n tools: Tool[]\n verbose: boolean\n debug: boolean\n erroredToolUseIDs: Set<string>\n inProgressToolUseIDs: Set<string>\n unresolvedToolUseIDs: Set<string>\n shouldAnimate: boolean\n shouldShowDot: boolean\n width?: number | string\n}\n\nexport function Message({\n message,\n messages,\n addMargin,\n tools,\n verbose,\n debug,\n erroredToolUseIDs,\n inProgressToolUseIDs,\n unresolvedToolUseIDs,\n shouldAnimate,\n shouldShowDot,\n width,\n}: Props): React.ReactNode {\n // Assistant message\n if (message.type === 'assistant') {\n return (\n <Box flexDirection=\"column\" width=\"100%\">\n {message.message.content.map((_, index) => (\n <AssistantMessage\n key={index}\n param={_}\n costUSD={message.costUSD}\n durationMs={message.durationMs}\n addMargin={addMargin}\n tools={tools}\n debug={debug}\n options={{ verbose }}\n erroredToolUseIDs={erroredToolUseIDs}\n inProgressToolUseIDs={inProgressToolUseIDs}\n unresolvedToolUseIDs={unresolvedToolUseIDs}\n shouldAnimate={shouldAnimate}\n shouldShowDot={shouldShowDot}\n width={width}\n />\n ))}\n </Box>\n )\n }\n\n // User message\n // TODO: normalize upstream\n const content =\n typeof message.message.content === 'string'\n ? [{ type: 'text', text: message.message.content } as TextBlockParam]\n : message.message.content\n return (\n <Box flexDirection=\"column\" width=\"100%\">\n {content.map((_, index) => (\n <UserMessage\n key={index}\n message={message}\n messages={messages}\n addMargin={addMargin}\n tools={tools}\n param={_ as TextBlockParam}\n options={{ verbose }}\n />\n ))}\n </Box>\n )\n}\n\nfunction UserMessage({\n message,\n messages,\n addMargin,\n tools,\n param,\n options: { verbose },\n}: {\n message: UserMessage\n messages: Message[]\n addMargin: boolean\n tools: Tool[]\n param:\n | TextBlockParam\n | DocumentBlockParam\n | ImageBlockParam\n | ToolUseBlockParam\n | ToolResultBlockParam\n options: {\n verbose: boolean\n }\n key?: React.Key\n}): React.ReactNode {\n const { columns } = useTerminalSize()\n switch (param.type) {\n case 'text':\n return <UserTextMessage addMargin={addMargin} param={param} />\n case 'tool_result':\n return (\n <UserToolResultMessage\n param={param}\n message={message}\n messages={messages}\n tools={tools}\n verbose={verbose}\n width={columns - 5}\n />\n )\n }\n}\n\nfunction AssistantMessage({\n param,\n costUSD,\n durationMs,\n addMargin,\n tools,\n debug,\n options: { verbose },\n erroredToolUseIDs,\n inProgressToolUseIDs,\n unresolvedToolUseIDs,\n shouldAnimate,\n shouldShowDot,\n width,\n}: {\n param:\n | ContentBlock\n | TextBlockParam\n | ImageBlockParam\n | ThinkingBlockParam\n | ToolUseBlockParam\n | ToolResultBlockParam\n costUSD: number\n durationMs: number\n addMargin: boolean\n tools: Tool[]\n debug: boolean\n options: {\n verbose: boolean\n }\n erroredToolUseIDs: Set<string>\n inProgressToolUseIDs: Set<string>\n unresolvedToolUseIDs: Set<string>\n shouldAnimate: boolean\n shouldShowDot: boolean\n width?: number | string\n key?: React.Key\n}): React.ReactNode {\n switch (param.type) {\n case 'tool_use':\n return (\n <AssistantToolUseMessage\n param={param}\n costUSD={costUSD}\n durationMs={durationMs}\n addMargin={addMargin}\n tools={tools}\n debug={debug}\n verbose={verbose}\n erroredToolUseIDs={erroredToolUseIDs}\n inProgressToolUseIDs={inProgressToolUseIDs}\n unresolvedToolUseIDs={unresolvedToolUseIDs}\n shouldAnimate={shouldAnimate}\n shouldShowDot={shouldShowDot}\n />\n )\n case 'text':\n return (\n <AssistantTextMessage\n param={param}\n costUSD={costUSD}\n durationMs={durationMs}\n debug={debug}\n addMargin={addMargin}\n shouldShowDot={shouldShowDot}\n verbose={verbose}\n width={width}\n />\n )\n case 'redacted_thinking':\n return <AssistantRedactedThinkingMessage addMargin={addMargin} />\n case 'thinking':\n return <AssistantThinkingMessage addMargin={addMargin} param={param} />\n default:\n logError(`Unable to render message type: ${param.type}`)\n return null\n }\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,WAAW;AACpB,YAAY,WAAW;AAYvB,SAAS,gBAAgB;AACzB,SAAS,6BAA6B;AACtC,SAAS,+BAA+B;AACxC,SAAS,4BAA4B;AACrC,SAAS,uBAAuB;AAEhC,SAAS,gCAAgC;AACzC,SAAS,wCAAwC;AACjD,SAAS,uBAAuB;AAkBzB,SAAS,QAAQ;AAAA,EACtB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AAEzB,MAAI,QAAQ,SAAS,aAAa;AAChC,WACE,oCAAC,OAAI,eAAc,UAAS,OAAM,UAC/B,QAAQ,QAAQ,QAAQ,IAAI,CAAC,GAAG,UAC/B;AAAA,MAAC;AAAA;AAAA,QACC,KAAK;AAAA,QACL,OAAO;AAAA,QACP,SAAS,QAAQ;AAAA,QACjB,YAAY,QAAQ;AAAA,QACpB;AAAA,QACA;AAAA,QACA;AAAA,QACA,SAAS,EAAE,QAAQ;AAAA,QACnB;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA;AAAA,IACF,CACD,CACH;AAAA,EAEJ;AAIA,QAAM,UACJ,OAAO,QAAQ,QAAQ,YAAY,WAC/B,CAAC,EAAE,MAAM,QAAQ,MAAM,QAAQ,QAAQ,QAAQ,CAAmB,IAClE,QAAQ,QAAQ;AACtB,SACE,oCAAC,OAAI,eAAc,UAAS,OAAM,UAC/B,QAAQ,IAAI,CAAC,GAAG,UACf;AAAA,IAAC;AAAA;AAAA,MACC,KAAK;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,OAAO;AAAA,MACP,SAAS,EAAE,QAAQ;AAAA;AAAA,EACrB,CACD,CACH;AAEJ;AAEA,SAAS,YAAY;AAAA,EACnB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,SAAS,EAAE,QAAQ;AACrB,GAeoB;AAClB,QAAM,EAAE,QAAQ,IAAI,gBAAgB;AACpC,UAAQ,MAAM,MAAM;AAAA,IAClB,KAAK;AACH,aAAO,oCAAC,mBAAgB,WAAsB,OAAc;AAAA,IAC9D,KAAK;AACH,aACE;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA,OAAO,UAAU;AAAA;AAAA,MACnB;AAAA,EAEN;AACF;AAEA,SAAS,iBAAiB;AAAA,EACxB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,SAAS,EAAE,QAAQ;AAAA,EACnB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAuBoB;AAClB,UAAQ,MAAM,MAAM;AAAA,IAClB,KAAK;AACH,aACE;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA;AAAA,MACF;AAAA,IAEJ,KAAK;AACH,aACE;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA;AAAA,MACF;AAAA,IAEJ,KAAK;AACH,aAAO,oCAAC,oCAAiC,WAAsB;AAAA,IACjE,KAAK;AACH,aAAO,oCAAC,4BAAyB,WAAsB,OAAc;AAAA,IACvE;AACE,eAAS,kCAAkC,MAAM,IAAI,EAAE;AACvD,aAAO;AAAA,EACX;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Box, Text } from "ink";
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
function MessageResponse({ children }) {
|
|
4
|
+
return /* @__PURE__ */ React.createElement(Box, { flexDirection: "row", height: 1, overflow: "hidden" }, /* @__PURE__ */ React.createElement(Text, null, " ", "\u23BF \xA0"), children);
|
|
5
|
+
}
|
|
6
|
+
export {
|
|
7
|
+
MessageResponse
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=MessageResponse.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/components/MessageResponse.tsx"],
|
|
4
|
+
"sourcesContent": ["import { Box, Text } from 'ink'\nimport * as React from 'react'\n\ntype Props = {\n children: React.ReactNode\n}\n\nexport function MessageResponse({ children }: Props): React.ReactNode {\n return (\n <Box flexDirection=\"row\" height={1} overflow=\"hidden\">\n <Text>{' '}\u23BF </Text>\n {children}\n </Box>\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,KAAK,YAAY;AAC1B,YAAY,WAAW;AAMhB,SAAS,gBAAgB,EAAE,SAAS,GAA2B;AACpE,SACE,oCAAC,OAAI,eAAc,OAAM,QAAQ,GAAG,UAAS,YAC3C,oCAAC,YAAM,MAAK,aAAQ,GACnB,QACH;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { Box, Text, useInput } from "ink";
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
import { useMemo, useState, useEffect } from "react";
|
|
4
|
+
import figures from "figures";
|
|
5
|
+
import { getTheme } from "../utils/theme.js";
|
|
6
|
+
import { Message as MessageComponent } from "./Message.js";
|
|
7
|
+
import { randomUUID } from "crypto";
|
|
8
|
+
import {
|
|
9
|
+
createUserMessage,
|
|
10
|
+
isEmptyMessageText,
|
|
11
|
+
isNotEmptyMessage,
|
|
12
|
+
normalizeMessages
|
|
13
|
+
} from "../utils/messages.js";
|
|
14
|
+
import { logEvent } from "../services/statsig.js";
|
|
15
|
+
import { useExitOnCtrlCD } from "../hooks/useExitOnCtrlCD.js";
|
|
16
|
+
const MAX_VISIBLE_MESSAGES = 7;
|
|
17
|
+
function MessageSelector({
|
|
18
|
+
erroredToolUseIDs,
|
|
19
|
+
messages,
|
|
20
|
+
onSelect,
|
|
21
|
+
onEscape,
|
|
22
|
+
tools,
|
|
23
|
+
unresolvedToolUseIDs
|
|
24
|
+
}) {
|
|
25
|
+
const currentUUID = useMemo(randomUUID, []);
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
logEvent("tengu_message_selector_opened", {});
|
|
28
|
+
}, []);
|
|
29
|
+
function handleSelect(message) {
|
|
30
|
+
const indexFromEnd = messages.length - 1 - messages.indexOf(message);
|
|
31
|
+
logEvent("tengu_message_selector_selected", {
|
|
32
|
+
index_from_end: indexFromEnd.toString(),
|
|
33
|
+
message_type: message.type,
|
|
34
|
+
is_current_prompt: (message.uuid === currentUUID).toString()
|
|
35
|
+
});
|
|
36
|
+
onSelect(message);
|
|
37
|
+
}
|
|
38
|
+
function handleEscape() {
|
|
39
|
+
logEvent("tengu_message_selector_cancelled", {});
|
|
40
|
+
onEscape();
|
|
41
|
+
}
|
|
42
|
+
const allItems = useMemo(
|
|
43
|
+
() => [
|
|
44
|
+
// Filter out tool results
|
|
45
|
+
...messages.filter(
|
|
46
|
+
(_) => !(_.type === "user" && Array.isArray(_.message.content) && _.message.content[0]?.type === "tool_result")
|
|
47
|
+
).filter((_) => _.type !== "assistant"),
|
|
48
|
+
{ ...createUserMessage(""), uuid: currentUUID }
|
|
49
|
+
],
|
|
50
|
+
[messages, currentUUID]
|
|
51
|
+
);
|
|
52
|
+
const [selectedIndex, setSelectedIndex] = useState(allItems.length - 1);
|
|
53
|
+
const exitState = useExitOnCtrlCD(() => process.exit(0));
|
|
54
|
+
useInput((input, key) => {
|
|
55
|
+
if (key.tab || key.escape) {
|
|
56
|
+
handleEscape();
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
if (key.return) {
|
|
60
|
+
handleSelect(allItems[selectedIndex]);
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
if (key.upArrow) {
|
|
64
|
+
if (key.ctrl || key.shift || key.meta) {
|
|
65
|
+
setSelectedIndex(0);
|
|
66
|
+
} else {
|
|
67
|
+
setSelectedIndex((prev) => Math.max(0, prev - 1));
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
if (key.downArrow) {
|
|
71
|
+
if (key.ctrl || key.shift || key.meta) {
|
|
72
|
+
setSelectedIndex(allItems.length - 1);
|
|
73
|
+
} else {
|
|
74
|
+
setSelectedIndex((prev) => Math.min(allItems.length - 1, prev + 1));
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
const num = Number(input);
|
|
78
|
+
if (!isNaN(num) && num >= 1 && num <= Math.min(9, allItems.length)) {
|
|
79
|
+
if (!allItems[num - 1]) {
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
handleSelect(allItems[num - 1]);
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
const firstVisibleIndex = Math.max(
|
|
86
|
+
0,
|
|
87
|
+
Math.min(
|
|
88
|
+
selectedIndex - Math.floor(MAX_VISIBLE_MESSAGES / 2),
|
|
89
|
+
allItems.length - MAX_VISIBLE_MESSAGES
|
|
90
|
+
)
|
|
91
|
+
);
|
|
92
|
+
const normalizedMessages = useMemo(
|
|
93
|
+
() => normalizeMessages(messages).filter(isNotEmptyMessage),
|
|
94
|
+
[messages]
|
|
95
|
+
);
|
|
96
|
+
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
|
|
97
|
+
Box,
|
|
98
|
+
{
|
|
99
|
+
flexDirection: "column",
|
|
100
|
+
borderStyle: "round",
|
|
101
|
+
borderColor: getTheme().secondaryBorder,
|
|
102
|
+
height: 4 + Math.min(MAX_VISIBLE_MESSAGES, allItems.length) * 2,
|
|
103
|
+
paddingX: 1,
|
|
104
|
+
marginTop: 1
|
|
105
|
+
},
|
|
106
|
+
/* @__PURE__ */ React.createElement(Box, { flexDirection: "column", minHeight: 2, marginBottom: 1 }, /* @__PURE__ */ React.createElement(Text, { bold: true }, "Jump to a previous message"), /* @__PURE__ */ React.createElement(Text, { dimColor: true }, "This will fork the conversation")),
|
|
107
|
+
allItems.slice(firstVisibleIndex, firstVisibleIndex + MAX_VISIBLE_MESSAGES).map((msg, index) => {
|
|
108
|
+
const actualIndex = firstVisibleIndex + index;
|
|
109
|
+
const isSelected = actualIndex === selectedIndex;
|
|
110
|
+
const isCurrent = msg.uuid === currentUUID;
|
|
111
|
+
return /* @__PURE__ */ React.createElement(Box, { key: msg.uuid, flexDirection: "row", height: 2, minHeight: 2 }, /* @__PURE__ */ React.createElement(Box, { width: 7 }, isSelected ? /* @__PURE__ */ React.createElement(Text, { color: "blue", bold: true }, figures.pointer, " ", firstVisibleIndex + index + 1, " ") : /* @__PURE__ */ React.createElement(Text, null, " ", firstVisibleIndex + index + 1, " ")), /* @__PURE__ */ React.createElement(Box, { height: 1, overflow: "hidden", width: 100 }, isCurrent ? /* @__PURE__ */ React.createElement(Box, { width: "100%" }, /* @__PURE__ */ React.createElement(Text, { dimColor: true, italic: true }, "(current)")) : Array.isArray(msg.message.content) && msg.message.content[0]?.type === "text" && isEmptyMessageText(msg.message.content[0].text) ? /* @__PURE__ */ React.createElement(Text, { dimColor: true, italic: true }, "(empty message)") : /* @__PURE__ */ React.createElement(
|
|
112
|
+
MessageComponent,
|
|
113
|
+
{
|
|
114
|
+
message: msg,
|
|
115
|
+
messages: normalizedMessages,
|
|
116
|
+
addMargin: false,
|
|
117
|
+
tools,
|
|
118
|
+
verbose: false,
|
|
119
|
+
debug: false,
|
|
120
|
+
erroredToolUseIDs,
|
|
121
|
+
inProgressToolUseIDs: /* @__PURE__ */ new Set(),
|
|
122
|
+
unresolvedToolUseIDs,
|
|
123
|
+
shouldAnimate: false,
|
|
124
|
+
shouldShowDot: false
|
|
125
|
+
}
|
|
126
|
+
)));
|
|
127
|
+
})
|
|
128
|
+
), /* @__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") : /* @__PURE__ */ React.createElement(React.Fragment, null, "\u2191/\u2193 to select \xB7 Enter to confirm \xB7 Tab/Esc to cancel"))));
|
|
129
|
+
}
|
|
130
|
+
export {
|
|
131
|
+
MessageSelector
|
|
132
|
+
};
|
|
133
|
+
//# sourceMappingURL=MessageSelector.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/components/MessageSelector.tsx"],
|
|
4
|
+
"sourcesContent": ["import { Box, Text, useInput } from 'ink'\nimport * as React from 'react'\nimport { useMemo, useState, useEffect } from 'react'\nimport figures from 'figures'\nimport { getTheme } from '../utils/theme'\nimport { Message as MessageComponent } from './Message'\nimport { randomUUID } from 'crypto'\nimport { type Tool } from '../Tool'\nimport {\n createUserMessage,\n isEmptyMessageText,\n isNotEmptyMessage,\n normalizeMessages,\n} from '../utils/messages.js'\nimport { logEvent } from '../services/statsig'\nimport type { AssistantMessage, UserMessage } from '../query'\nimport { useExitOnCtrlCD } from '../hooks/useExitOnCtrlCD'\n\ntype Props = {\n erroredToolUseIDs: Set<string>\n messages: (UserMessage | AssistantMessage)[]\n onSelect: (message: UserMessage) => void\n onEscape: () => void\n tools: Tool[]\n unresolvedToolUseIDs: Set<string>\n}\n\nconst MAX_VISIBLE_MESSAGES = 7\n\nexport function MessageSelector({\n erroredToolUseIDs,\n messages,\n onSelect,\n onEscape,\n tools,\n unresolvedToolUseIDs,\n}: Props): React.ReactNode {\n const currentUUID = useMemo(randomUUID, [])\n\n // Log when selector is opened\n useEffect(() => {\n logEvent('tengu_message_selector_opened', {})\n }, [])\n\n function handleSelect(message: UserMessage) {\n const indexFromEnd = messages.length - 1 - messages.indexOf(message)\n logEvent('tengu_message_selector_selected', {\n index_from_end: indexFromEnd.toString(),\n message_type: message.type,\n is_current_prompt: (message.uuid === currentUUID).toString(),\n })\n onSelect(message)\n }\n\n function handleEscape() {\n logEvent('tengu_message_selector_cancelled', {})\n onEscape()\n }\n\n // Add current prompt as a virtual message\n const allItems = useMemo(\n () => [\n // Filter out tool results\n ...messages\n .filter(\n _ =>\n !(\n _.type === 'user' &&\n Array.isArray(_.message.content) &&\n _.message.content[0]?.type === 'tool_result'\n ),\n )\n // Filter out assistant messages, until we have a way to kick off the tool use loop from REPL\n .filter(_ => _.type !== 'assistant'),\n { ...createUserMessage(''), uuid: currentUUID } as UserMessage,\n ],\n [messages, currentUUID],\n )\n const [selectedIndex, setSelectedIndex] = useState(allItems.length - 1)\n\n const exitState = useExitOnCtrlCD(() => process.exit(0))\n\n useInput((input, key) => {\n if (key.tab || key.escape) {\n handleEscape()\n return\n }\n if (key.return) {\n handleSelect(allItems[selectedIndex]!)\n return\n }\n if (key.upArrow) {\n if (key.ctrl || key.shift || key.meta) {\n // Jump to top with any modifier key\n setSelectedIndex(0)\n } else {\n setSelectedIndex(prev => Math.max(0, prev - 1))\n }\n }\n if (key.downArrow) {\n if (key.ctrl || key.shift || key.meta) {\n // Jump to bottom with any modifier key\n setSelectedIndex(allItems.length - 1)\n } else {\n setSelectedIndex(prev => Math.min(allItems.length - 1, prev + 1))\n }\n }\n\n // Handle number keys (1-9)\n const num = Number(input)\n if (!isNaN(num) && num >= 1 && num <= Math.min(9, allItems.length)) {\n if (!allItems[num - 1]) {\n return\n }\n handleSelect(allItems[num - 1]!)\n }\n })\n\n const firstVisibleIndex = Math.max(\n 0,\n Math.min(\n selectedIndex - Math.floor(MAX_VISIBLE_MESSAGES / 2),\n allItems.length - MAX_VISIBLE_MESSAGES,\n ),\n )\n\n const normalizedMessages = useMemo(\n () => normalizeMessages(messages).filter(isNotEmptyMessage),\n [messages],\n )\n\n return (\n <>\n <Box\n flexDirection=\"column\"\n borderStyle=\"round\"\n borderColor={getTheme().secondaryBorder}\n height={4 + Math.min(MAX_VISIBLE_MESSAGES, allItems.length) * 2}\n paddingX={1}\n marginTop={1}\n >\n <Box flexDirection=\"column\" minHeight={2} marginBottom={1}>\n <Text bold>Jump to a previous message</Text>\n <Text dimColor>This will fork the conversation</Text>\n </Box>\n {allItems\n .slice(firstVisibleIndex, firstVisibleIndex + MAX_VISIBLE_MESSAGES)\n .map((msg, index) => {\n const actualIndex = firstVisibleIndex + index\n const isSelected = actualIndex === selectedIndex\n const isCurrent = msg.uuid === currentUUID\n\n return (\n <Box key={msg.uuid} flexDirection=\"row\" height={2} minHeight={2}>\n <Box width={7}>\n {isSelected ? (\n <Text color=\"blue\" bold>\n {figures.pointer} {firstVisibleIndex + index + 1}{' '}\n </Text>\n ) : (\n <Text>\n {' '}\n {firstVisibleIndex + index + 1}{' '}\n </Text>\n )}\n </Box>\n <Box height={1} overflow=\"hidden\" width={100}>\n {isCurrent ? (\n <Box width=\"100%\">\n <Text dimColor italic>\n {'(current)'}\n </Text>\n </Box>\n ) : Array.isArray(msg.message.content) &&\n msg.message.content[0]?.type === 'text' &&\n isEmptyMessageText(msg.message.content[0].text) ? (\n <Text dimColor italic>\n (empty message)\n </Text>\n ) : (\n <MessageComponent\n message={msg}\n messages={normalizedMessages}\n addMargin={false}\n tools={tools}\n verbose={false}\n debug={false}\n erroredToolUseIDs={erroredToolUseIDs}\n inProgressToolUseIDs={new Set()}\n unresolvedToolUseIDs={unresolvedToolUseIDs}\n shouldAnimate={false}\n shouldShowDot={false}\n />\n )}\n </Box>\n </Box>\n )\n })}\n </Box>\n <Box marginLeft={3}>\n <Text dimColor>\n {exitState.pending ? (\n <>Press {exitState.keyName} again to exit</>\n ) : (\n <>\u2191/\u2193 to select \u00B7 Enter to confirm \u00B7 Tab/Esc to cancel</>\n )}\n </Text>\n </Box>\n </>\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,KAAK,MAAM,gBAAgB;AACpC,YAAY,WAAW;AACvB,SAAS,SAAS,UAAU,iBAAiB;AAC7C,OAAO,aAAa;AACpB,SAAS,gBAAgB;AACzB,SAAS,WAAW,wBAAwB;AAC5C,SAAS,kBAAkB;AAE3B;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,gBAAgB;AAEzB,SAAS,uBAAuB;AAWhC,MAAM,uBAAuB;AAEtB,SAAS,gBAAgB;AAAA,EAC9B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AACzB,QAAM,cAAc,QAAQ,YAAY,CAAC,CAAC;AAG1C,YAAU,MAAM;AACd,aAAS,iCAAiC,CAAC,CAAC;AAAA,EAC9C,GAAG,CAAC,CAAC;AAEL,WAAS,aAAa,SAAsB;AAC1C,UAAM,eAAe,SAAS,SAAS,IAAI,SAAS,QAAQ,OAAO;AACnE,aAAS,mCAAmC;AAAA,MAC1C,gBAAgB,aAAa,SAAS;AAAA,MACtC,cAAc,QAAQ;AAAA,MACtB,oBAAoB,QAAQ,SAAS,aAAa,SAAS;AAAA,IAC7D,CAAC;AACD,aAAS,OAAO;AAAA,EAClB;AAEA,WAAS,eAAe;AACtB,aAAS,oCAAoC,CAAC,CAAC;AAC/C,aAAS;AAAA,EACX;AAGA,QAAM,WAAW;AAAA,IACf,MAAM;AAAA;AAAA,MAEJ,GAAG,SACA;AAAA,QACC,OACE,EACE,EAAE,SAAS,UACX,MAAM,QAAQ,EAAE,QAAQ,OAAO,KAC/B,EAAE,QAAQ,QAAQ,CAAC,GAAG,SAAS;AAAA,MAErC,EAEC,OAAO,OAAK,EAAE,SAAS,WAAW;AAAA,MACrC,EAAE,GAAG,kBAAkB,EAAE,GAAG,MAAM,YAAY;AAAA,IAChD;AAAA,IACA,CAAC,UAAU,WAAW;AAAA,EACxB;AACA,QAAM,CAAC,eAAe,gBAAgB,IAAI,SAAS,SAAS,SAAS,CAAC;AAEtE,QAAM,YAAY,gBAAgB,MAAM,QAAQ,KAAK,CAAC,CAAC;AAEvD,WAAS,CAAC,OAAO,QAAQ;AACvB,QAAI,IAAI,OAAO,IAAI,QAAQ;AACzB,mBAAa;AACb;AAAA,IACF;AACA,QAAI,IAAI,QAAQ;AACd,mBAAa,SAAS,aAAa,CAAE;AACrC;AAAA,IACF;AACA,QAAI,IAAI,SAAS;AACf,UAAI,IAAI,QAAQ,IAAI,SAAS,IAAI,MAAM;AAErC,yBAAiB,CAAC;AAAA,MACpB,OAAO;AACL,yBAAiB,UAAQ,KAAK,IAAI,GAAG,OAAO,CAAC,CAAC;AAAA,MAChD;AAAA,IACF;AACA,QAAI,IAAI,WAAW;AACjB,UAAI,IAAI,QAAQ,IAAI,SAAS,IAAI,MAAM;AAErC,yBAAiB,SAAS,SAAS,CAAC;AAAA,MACtC,OAAO;AACL,yBAAiB,UAAQ,KAAK,IAAI,SAAS,SAAS,GAAG,OAAO,CAAC,CAAC;AAAA,MAClE;AAAA,IACF;AAGA,UAAM,MAAM,OAAO,KAAK;AACxB,QAAI,CAAC,MAAM,GAAG,KAAK,OAAO,KAAK,OAAO,KAAK,IAAI,GAAG,SAAS,MAAM,GAAG;AAClE,UAAI,CAAC,SAAS,MAAM,CAAC,GAAG;AACtB;AAAA,MACF;AACA,mBAAa,SAAS,MAAM,CAAC,CAAE;AAAA,IACjC;AAAA,EACF,CAAC;AAED,QAAM,oBAAoB,KAAK;AAAA,IAC7B;AAAA,IACA,KAAK;AAAA,MACH,gBAAgB,KAAK,MAAM,uBAAuB,CAAC;AAAA,MACnD,SAAS,SAAS;AAAA,IACpB;AAAA,EACF;AAEA,QAAM,qBAAqB;AAAA,IACzB,MAAM,kBAAkB,QAAQ,EAAE,OAAO,iBAAiB;AAAA,IAC1D,CAAC,QAAQ;AAAA,EACX;AAEA,SACE,0DACE;AAAA,IAAC;AAAA;AAAA,MACC,eAAc;AAAA,MACd,aAAY;AAAA,MACZ,aAAa,SAAS,EAAE;AAAA,MACxB,QAAQ,IAAI,KAAK,IAAI,sBAAsB,SAAS,MAAM,IAAI;AAAA,MAC9D,UAAU;AAAA,MACV,WAAW;AAAA;AAAA,IAEX,oCAAC,OAAI,eAAc,UAAS,WAAW,GAAG,cAAc,KACtD,oCAAC,QAAK,MAAI,QAAC,4BAA0B,GACrC,oCAAC,QAAK,UAAQ,QAAC,iCAA+B,CAChD;AAAA,IACC,SACE,MAAM,mBAAmB,oBAAoB,oBAAoB,EACjE,IAAI,CAAC,KAAK,UAAU;AACnB,YAAM,cAAc,oBAAoB;AACxC,YAAM,aAAa,gBAAgB;AACnC,YAAM,YAAY,IAAI,SAAS;AAE/B,aACE,oCAAC,OAAI,KAAK,IAAI,MAAM,eAAc,OAAM,QAAQ,GAAG,WAAW,KAC5D,oCAAC,OAAI,OAAO,KACT,aACC,oCAAC,QAAK,OAAM,QAAO,MAAI,QACpB,QAAQ,SAAQ,KAAE,oBAAoB,QAAQ,GAAG,GACpD,IAEA,oCAAC,YACE,MACA,oBAAoB,QAAQ,GAAG,GAClC,CAEJ,GACA,oCAAC,OAAI,QAAQ,GAAG,UAAS,UAAS,OAAO,OACtC,YACC,oCAAC,OAAI,OAAM,UACT,oCAAC,QAAK,UAAQ,MAAC,QAAM,QAClB,WACH,CACF,IACE,MAAM,QAAQ,IAAI,QAAQ,OAAO,KACnC,IAAI,QAAQ,QAAQ,CAAC,GAAG,SAAS,UACjC,mBAAmB,IAAI,QAAQ,QAAQ,CAAC,EAAE,IAAI,IAC9C,oCAAC,QAAK,UAAQ,MAAC,QAAM,QAAC,iBAEtB,IAEA;AAAA,QAAC;AAAA;AAAA,UACC,SAAS;AAAA,UACT,UAAU;AAAA,UACV,WAAW;AAAA,UACX;AAAA,UACA,SAAS;AAAA,UACT,OAAO;AAAA,UACP;AAAA,UACA,sBAAsB,oBAAI,IAAI;AAAA,UAC9B;AAAA,UACA,eAAe;AAAA,UACf,eAAe;AAAA;AAAA,MACjB,CAEJ,CACF;AAAA,IAEJ,CAAC;AAAA,EACL,GACA,oCAAC,OAAI,YAAY,KACf,oCAAC,QAAK,UAAQ,QACX,UAAU,UACT,0DAAE,UAAO,UAAU,SAAQ,gBAAc,IAEzC,0DAAE,sEAAoD,CAE1D,CACF,CACF;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Box, Text } from "ink";
|
|
3
|
+
import { usePermissionContext } from "../context/PermissionContext.js";
|
|
4
|
+
import { getTheme } from "../utils/theme.js";
|
|
5
|
+
function ModeIndicator({
|
|
6
|
+
showTransitionCount = false
|
|
7
|
+
}) {
|
|
8
|
+
const { currentMode, permissionContext, getModeConfig } = usePermissionContext();
|
|
9
|
+
const theme = getTheme();
|
|
10
|
+
const modeConfig = getModeConfig();
|
|
11
|
+
if (currentMode === "default" && !showTransitionCount) {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
return /* @__PURE__ */ React.createElement(Box, { borderStyle: "single", padding: 1, marginY: 1 }, /* @__PURE__ */ React.createElement(Box, { flexDirection: "column" }, /* @__PURE__ */ React.createElement(Box, { flexDirection: "row", alignItems: "center" }, /* @__PURE__ */ React.createElement(Text, { color: getThemeColor(modeConfig.color, theme), bold: true }, modeConfig.icon, " ", modeConfig.label)), /* @__PURE__ */ React.createElement(Text, { color: "gray", dimColor: true }, modeConfig.description), /* @__PURE__ */ React.createElement(Box, { flexDirection: "row", justifyContent: "space-between", marginTop: 1 }, /* @__PURE__ */ React.createElement(Text, { color: "gray", dimColor: true }, "Press Shift+Tab to cycle modes"), showTransitionCount && /* @__PURE__ */ React.createElement(Text, { color: "gray", dimColor: true }, "Switches: ", permissionContext.metadata.transitionCount)), currentMode === "plan" && /* @__PURE__ */ React.createElement(Box, { marginTop: 1 }, /* @__PURE__ */ React.createElement(Text, { color: "cyan", dimColor: true }, "Available tools: ", permissionContext.allowedTools.join(", ")), /* @__PURE__ */ React.createElement(Text, { color: "yellow", dimColor: true }, "Use exit_plan_mode tool when ready to execute"))));
|
|
15
|
+
}
|
|
16
|
+
function getThemeColor(colorName, theme) {
|
|
17
|
+
const colorMap = {
|
|
18
|
+
blue: theme.primary || "blue",
|
|
19
|
+
green: theme.success || "green",
|
|
20
|
+
yellow: theme.warning || "yellow",
|
|
21
|
+
red: theme.error || "red"
|
|
22
|
+
};
|
|
23
|
+
return colorMap[colorName] || colorName;
|
|
24
|
+
}
|
|
25
|
+
function CompactModeIndicator() {
|
|
26
|
+
const { currentMode, getModeConfig } = usePermissionContext();
|
|
27
|
+
const modeConfig = getModeConfig();
|
|
28
|
+
const theme = getTheme();
|
|
29
|
+
if (currentMode === "default") {
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
return /* @__PURE__ */ React.createElement(Text, { color: getThemeColor(modeConfig.color, theme) }, modeConfig.icon, " ", modeConfig.name);
|
|
33
|
+
}
|
|
34
|
+
export {
|
|
35
|
+
CompactModeIndicator,
|
|
36
|
+
ModeIndicator
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=ModeIndicator.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/components/ModeIndicator.tsx"],
|
|
4
|
+
"sourcesContent": ["import React from 'react'\nimport { Box, Text } from 'ink'\nimport { usePermissionContext } from '../context/PermissionContext'\nimport { getTheme } from '../utils/theme'\n\ninterface ModeIndicatorProps {\n showTransitionCount?: boolean\n}\n\nexport function ModeIndicator({\n showTransitionCount = false,\n}: ModeIndicatorProps) {\n const { currentMode, permissionContext, getModeConfig } =\n usePermissionContext()\n const theme = getTheme()\n const modeConfig = getModeConfig()\n\n // Don't show indicator for default mode unless explicitly requested\n if (currentMode === 'default' && !showTransitionCount) {\n return null\n }\n\n return (\n <Box borderStyle=\"single\" padding={1} marginY={1}>\n <Box flexDirection=\"column\">\n <Box flexDirection=\"row\" alignItems=\"center\">\n <Text color={getThemeColor(modeConfig.color, theme)} bold>\n {modeConfig.icon} {modeConfig.label}\n </Text>\n </Box>\n\n <Text color=\"gray\" dimColor>\n {modeConfig.description}\n </Text>\n\n <Box flexDirection=\"row\" justifyContent=\"space-between\" marginTop={1}>\n <Text color=\"gray\" dimColor>\n Press Shift+Tab to cycle modes\n </Text>\n {showTransitionCount && (\n <Text color=\"gray\" dimColor>\n Switches: {permissionContext.metadata.transitionCount}\n </Text>\n )}\n </Box>\n\n {currentMode === 'plan' && (\n <Box marginTop={1}>\n <Text color=\"cyan\" dimColor>\n Available tools: {permissionContext.allowedTools.join(', ')}\n </Text>\n <Text color=\"yellow\" dimColor>\n Use exit_plan_mode tool when ready to execute\n </Text>\n </Box>\n )}\n </Box>\n </Box>\n )\n}\n\nfunction getThemeColor(colorName: string, theme: any): string {\n const colorMap: Record<string, string> = {\n blue: theme.primary || 'blue',\n green: theme.success || 'green',\n yellow: theme.warning || 'yellow',\n red: theme.error || 'red',\n }\n\n return colorMap[colorName] || colorName\n}\n\n// Compact mode indicator for status bar\nexport function CompactModeIndicator() {\n const { currentMode, getModeConfig } = usePermissionContext()\n const modeConfig = getModeConfig()\n const theme = getTheme()\n\n if (currentMode === 'default') {\n return null\n }\n\n return (\n <Text color={getThemeColor(modeConfig.color, theme)}>\n {modeConfig.icon} {modeConfig.name}\n </Text>\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,OAAO,WAAW;AAClB,SAAS,KAAK,YAAY;AAC1B,SAAS,4BAA4B;AACrC,SAAS,gBAAgB;AAMlB,SAAS,cAAc;AAAA,EAC5B,sBAAsB;AACxB,GAAuB;AACrB,QAAM,EAAE,aAAa,mBAAmB,cAAc,IACpD,qBAAqB;AACvB,QAAM,QAAQ,SAAS;AACvB,QAAM,aAAa,cAAc;AAGjC,MAAI,gBAAgB,aAAa,CAAC,qBAAqB;AACrD,WAAO;AAAA,EACT;AAEA,SACE,oCAAC,OAAI,aAAY,UAAS,SAAS,GAAG,SAAS,KAC7C,oCAAC,OAAI,eAAc,YACjB,oCAAC,OAAI,eAAc,OAAM,YAAW,YAClC,oCAAC,QAAK,OAAO,cAAc,WAAW,OAAO,KAAK,GAAG,MAAI,QACtD,WAAW,MAAK,KAAE,WAAW,KAChC,CACF,GAEA,oCAAC,QAAK,OAAM,QAAO,UAAQ,QACxB,WAAW,WACd,GAEA,oCAAC,OAAI,eAAc,OAAM,gBAAe,iBAAgB,WAAW,KACjE,oCAAC,QAAK,OAAM,QAAO,UAAQ,QAAC,gCAE5B,GACC,uBACC,oCAAC,QAAK,OAAM,QAAO,UAAQ,QAAC,cACf,kBAAkB,SAAS,eACxC,CAEJ,GAEC,gBAAgB,UACf,oCAAC,OAAI,WAAW,KACd,oCAAC,QAAK,OAAM,QAAO,UAAQ,QAAC,qBACR,kBAAkB,aAAa,KAAK,IAAI,CAC5D,GACA,oCAAC,QAAK,OAAM,UAAS,UAAQ,QAAC,+CAE9B,CACF,CAEJ,CACF;AAEJ;AAEA,SAAS,cAAc,WAAmB,OAAoB;AAC5D,QAAM,WAAmC;AAAA,IACvC,MAAM,MAAM,WAAW;AAAA,IACvB,OAAO,MAAM,WAAW;AAAA,IACxB,QAAQ,MAAM,WAAW;AAAA,IACzB,KAAK,MAAM,SAAS;AAAA,EACtB;AAEA,SAAO,SAAS,SAAS,KAAK;AAChC;AAGO,SAAS,uBAAuB;AACrC,QAAM,EAAE,aAAa,cAAc,IAAI,qBAAqB;AAC5D,QAAM,aAAa,cAAc;AACjC,QAAM,QAAQ,SAAS;AAEvB,MAAI,gBAAgB,WAAW;AAC7B,WAAO;AAAA,EACT;AAEA,SACE,oCAAC,QAAK,OAAO,cAAc,WAAW,OAAO,KAAK,KAC/C,WAAW,MAAK,KAAE,WAAW,IAChC;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
import { Box, Text, useInput } from "ink";
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
import { useState, useCallback, useEffect, useRef } from "react";
|
|
4
|
+
import figures from "figures";
|
|
5
|
+
import { getTheme } from "../utils/theme.js";
|
|
6
|
+
import {
|
|
7
|
+
getGlobalConfig,
|
|
8
|
+
setModelPointer
|
|
9
|
+
} from "../utils/config.js";
|
|
10
|
+
import { getModelManager } from "../utils/model.js";
|
|
11
|
+
import { useExitOnCtrlCD } from "../hooks/useExitOnCtrlCD.js";
|
|
12
|
+
import { ModelSelector } from "./ModelSelector.js";
|
|
13
|
+
import { ModelListManager } from "./ModelListManager.js";
|
|
14
|
+
function ModelConfig({ onClose }) {
|
|
15
|
+
const config = getGlobalConfig();
|
|
16
|
+
const theme = getTheme();
|
|
17
|
+
const [selectedIndex, setSelectedIndex] = useState(0);
|
|
18
|
+
const [showModelSelector, setShowModelSelector] = useState(false);
|
|
19
|
+
const [showModelListManager, setShowModelListManager] = useState(false);
|
|
20
|
+
const [currentPointer, setCurrentPointer] = useState(
|
|
21
|
+
null
|
|
22
|
+
);
|
|
23
|
+
const [refreshKey, setRefreshKey] = useState(0);
|
|
24
|
+
const [isDeleteMode, setIsDeleteMode] = useState(false);
|
|
25
|
+
const selectedIndexRef = useRef(selectedIndex);
|
|
26
|
+
const exitState = useExitOnCtrlCD(() => process.exit(0));
|
|
27
|
+
const modelManager = getModelManager();
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
selectedIndexRef.current = selectedIndex;
|
|
30
|
+
}, [selectedIndex]);
|
|
31
|
+
const availableModels = React.useMemo(() => {
|
|
32
|
+
const profiles = modelManager.getAvailableModels();
|
|
33
|
+
return profiles.map((p) => ({ id: p.modelName, name: p.name }));
|
|
34
|
+
}, [modelManager, refreshKey]);
|
|
35
|
+
const menuItems = React.useMemo(() => {
|
|
36
|
+
const modelSettings = [
|
|
37
|
+
{
|
|
38
|
+
id: "main",
|
|
39
|
+
label: "Main Model",
|
|
40
|
+
description: "Primary model for general tasks and conversations",
|
|
41
|
+
value: config.modelPointers?.main || "",
|
|
42
|
+
options: availableModels,
|
|
43
|
+
type: "modelPointer",
|
|
44
|
+
onChange: (value) => handleModelPointerChange("main", value)
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
id: "task",
|
|
48
|
+
label: "Task Model",
|
|
49
|
+
description: "Model for TaskTool sub-agents and automation",
|
|
50
|
+
value: config.modelPointers?.task || "",
|
|
51
|
+
options: availableModels,
|
|
52
|
+
type: "modelPointer",
|
|
53
|
+
onChange: (value) => handleModelPointerChange("task", value)
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
id: "reasoning",
|
|
57
|
+
label: "Reasoning Model",
|
|
58
|
+
description: "Model optimized for complex reasoning tasks",
|
|
59
|
+
value: config.modelPointers?.reasoning || "",
|
|
60
|
+
options: availableModels,
|
|
61
|
+
type: "modelPointer",
|
|
62
|
+
onChange: (value) => handleModelPointerChange("reasoning", value)
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
id: "quick",
|
|
66
|
+
label: "Quick Model",
|
|
67
|
+
description: "Fast model for simple operations and utilities",
|
|
68
|
+
value: config.modelPointers?.quick || "",
|
|
69
|
+
options: availableModels,
|
|
70
|
+
type: "modelPointer",
|
|
71
|
+
onChange: (value) => handleModelPointerChange("quick", value)
|
|
72
|
+
}
|
|
73
|
+
];
|
|
74
|
+
return [
|
|
75
|
+
...modelSettings,
|
|
76
|
+
{
|
|
77
|
+
id: "manage-models",
|
|
78
|
+
label: "Manage Model List",
|
|
79
|
+
description: "View, add, and delete model configurations",
|
|
80
|
+
value: "",
|
|
81
|
+
options: [],
|
|
82
|
+
type: "action",
|
|
83
|
+
onChange: () => handleManageModels()
|
|
84
|
+
}
|
|
85
|
+
];
|
|
86
|
+
}, [config.modelPointers, availableModels, refreshKey]);
|
|
87
|
+
const handleModelPointerChange = (pointer, modelId) => {
|
|
88
|
+
setModelPointer(pointer, modelId);
|
|
89
|
+
setRefreshKey((prev) => prev + 1);
|
|
90
|
+
};
|
|
91
|
+
const handleManageModels = () => {
|
|
92
|
+
setShowModelListManager(true);
|
|
93
|
+
};
|
|
94
|
+
const handleModelConfigurationComplete = () => {
|
|
95
|
+
setShowModelSelector(false);
|
|
96
|
+
setShowModelListManager(false);
|
|
97
|
+
setCurrentPointer(null);
|
|
98
|
+
setRefreshKey((prev) => prev + 1);
|
|
99
|
+
const manageIndex = menuItems.findIndex((item) => item.id === "manage-models");
|
|
100
|
+
if (manageIndex !== -1) {
|
|
101
|
+
setSelectedIndex(manageIndex);
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
const handleInput = useCallback(
|
|
105
|
+
(input, key) => {
|
|
106
|
+
if (key.escape) {
|
|
107
|
+
if (isDeleteMode) {
|
|
108
|
+
setIsDeleteMode(false);
|
|
109
|
+
} else {
|
|
110
|
+
onClose();
|
|
111
|
+
}
|
|
112
|
+
} else if (input === "d" && !isDeleteMode) {
|
|
113
|
+
setIsDeleteMode(true);
|
|
114
|
+
} else if (key.upArrow) {
|
|
115
|
+
setSelectedIndex((prev) => Math.max(0, prev - 1));
|
|
116
|
+
} else if (key.downArrow) {
|
|
117
|
+
setSelectedIndex((prev) => Math.min(menuItems.length - 1, prev + 1));
|
|
118
|
+
} else if (key.return || input === " ") {
|
|
119
|
+
const setting = menuItems[selectedIndex];
|
|
120
|
+
if (isDeleteMode && setting.type === "modelPointer" && setting.value) {
|
|
121
|
+
setModelPointer(setting.id, "");
|
|
122
|
+
setRefreshKey((prev) => prev + 1);
|
|
123
|
+
setIsDeleteMode(false);
|
|
124
|
+
} else if (setting.type === "modelPointer") {
|
|
125
|
+
if (setting.options.length === 0) {
|
|
126
|
+
handleManageModels();
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
const currentIndex = setting.options.findIndex(
|
|
130
|
+
(opt) => opt.id === setting.value
|
|
131
|
+
);
|
|
132
|
+
const nextIndex = (currentIndex + 1) % setting.options.length;
|
|
133
|
+
const nextOption = setting.options[nextIndex];
|
|
134
|
+
if (nextOption) {
|
|
135
|
+
setting.onChange(nextOption.id);
|
|
136
|
+
}
|
|
137
|
+
} else if (setting.type === "action") {
|
|
138
|
+
setting.onChange();
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
},
|
|
142
|
+
[selectedIndex, menuItems, onClose, isDeleteMode, modelManager]
|
|
143
|
+
);
|
|
144
|
+
useInput(handleInput);
|
|
145
|
+
if (showModelListManager) {
|
|
146
|
+
return /* @__PURE__ */ React.createElement(ModelListManager, { onClose: handleModelConfigurationComplete });
|
|
147
|
+
}
|
|
148
|
+
if (showModelSelector) {
|
|
149
|
+
return /* @__PURE__ */ React.createElement(
|
|
150
|
+
ModelSelector,
|
|
151
|
+
{
|
|
152
|
+
onDone: handleModelConfigurationComplete,
|
|
153
|
+
onCancel: handleModelConfigurationComplete,
|
|
154
|
+
skipModelType: true,
|
|
155
|
+
targetPointer: currentPointer || void 0,
|
|
156
|
+
isOnboarding: false,
|
|
157
|
+
abortController: new AbortController()
|
|
158
|
+
}
|
|
159
|
+
);
|
|
160
|
+
}
|
|
161
|
+
return /* @__PURE__ */ React.createElement(
|
|
162
|
+
Box,
|
|
163
|
+
{
|
|
164
|
+
flexDirection: "column",
|
|
165
|
+
borderStyle: "round",
|
|
166
|
+
borderColor: theme.secondaryBorder,
|
|
167
|
+
paddingX: 1,
|
|
168
|
+
marginTop: 1
|
|
169
|
+
},
|
|
170
|
+
/* @__PURE__ */ React.createElement(Box, { flexDirection: "column", minHeight: 2, marginBottom: 1 }, /* @__PURE__ */ React.createElement(Text, { bold: true }, "Model Configuration", isDeleteMode ? " - CLEAR MODE" : ""), /* @__PURE__ */ React.createElement(Text, { dimColor: true }, isDeleteMode ? "Press Enter/Space to clear selected pointer assignment, Esc to cancel" : availableModels.length === 0 ? 'No models configured. Use "Configure New Model" to add your first model.' : "Configure which models to use for different tasks. Space to cycle, Enter to configure.")),
|
|
171
|
+
menuItems.map((setting, i) => {
|
|
172
|
+
const isSelected = i === selectedIndex;
|
|
173
|
+
let displayValue = "";
|
|
174
|
+
let actionText = "";
|
|
175
|
+
if (setting.type === "modelPointer") {
|
|
176
|
+
const currentModel = setting.options.find(
|
|
177
|
+
(opt) => opt.id === setting.value
|
|
178
|
+
);
|
|
179
|
+
displayValue = currentModel?.name || "(not configured)";
|
|
180
|
+
actionText = isSelected ? " [Space to cycle]" : "";
|
|
181
|
+
} else if (setting.type === "action") {
|
|
182
|
+
displayValue = "";
|
|
183
|
+
actionText = isSelected ? " [Enter to configure]" : "";
|
|
184
|
+
}
|
|
185
|
+
return /* @__PURE__ */ React.createElement(Box, { key: setting.id, flexDirection: "column" }, /* @__PURE__ */ React.createElement(Box, null, /* @__PURE__ */ React.createElement(Box, { width: 44 }, /* @__PURE__ */ React.createElement(Text, { color: isSelected ? "blue" : void 0 }, isSelected ? figures.pointer : " ", " ", setting.label)), /* @__PURE__ */ React.createElement(Box, null, setting.type === "modelPointer" && /* @__PURE__ */ React.createElement(
|
|
186
|
+
Text,
|
|
187
|
+
{
|
|
188
|
+
color: displayValue !== "(not configured)" ? theme.success : theme.warning
|
|
189
|
+
},
|
|
190
|
+
displayValue
|
|
191
|
+
), actionText && /* @__PURE__ */ React.createElement(Text, { color: "blue" }, actionText))), isSelected && /* @__PURE__ */ React.createElement(Box, { paddingLeft: 2, marginBottom: 1 }, /* @__PURE__ */ React.createElement(Text, { dimColor: true }, setting.description)));
|
|
192
|
+
}),
|
|
193
|
+
/* @__PURE__ */ React.createElement(
|
|
194
|
+
Box,
|
|
195
|
+
{
|
|
196
|
+
marginTop: 1,
|
|
197
|
+
paddingTop: 1,
|
|
198
|
+
borderTopColor: theme.secondaryBorder,
|
|
199
|
+
borderTopStyle: "single"
|
|
200
|
+
},
|
|
201
|
+
/* @__PURE__ */ React.createElement(Text, { dimColor: true }, isDeleteMode ? "CLEAR MODE: Press Enter/Space to clear assignment, Esc to cancel" : availableModels.length === 0 ? "Use \u2191/\u2193 to navigate, Enter to configure new model, Esc to exit" : "Use \u2191/\u2193 to navigate, Space to cycle models, Enter to configure, d to clear, Esc to exit")
|
|
202
|
+
)
|
|
203
|
+
);
|
|
204
|
+
}
|
|
205
|
+
export {
|
|
206
|
+
ModelConfig
|
|
207
|
+
};
|
|
208
|
+
//# sourceMappingURL=ModelConfig.js.map
|