@shareai-lab/kode 1.2.0 → 2.0.2
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/README.md +25 -388
- package/cli-acp.js +82 -0
- package/cli.js +89 -79
- package/dist/REPL-GIU4ZIXM.js +42 -0
- package/dist/acp-H3VJ77YG.js +1357 -0
- package/dist/acp-H3VJ77YG.js.map +7 -0
- package/dist/agentsValidate-XP3CFN6F.js +373 -0
- package/dist/agentsValidate-XP3CFN6F.js.map +7 -0
- package/dist/ask-3G5H5KD5.js +125 -0
- package/dist/ask-3G5H5KD5.js.map +7 -0
- package/dist/autoUpdater-DNRMJWFQ.js +17 -0
- package/dist/chunk-2KWKUXLT.js +490 -0
- package/dist/chunk-2KWKUXLT.js.map +7 -0
- package/dist/chunk-2PMO2FS2.js +1097 -0
- package/dist/chunk-2PMO2FS2.js.map +7 -0
- package/dist/chunk-3RUXVV4S.js +23 -0
- package/dist/chunk-3RUXVV4S.js.map +7 -0
- package/dist/chunk-3TXNP6HH.js +240 -0
- package/dist/chunk-3TXNP6HH.js.map +7 -0
- package/dist/chunk-4GAIJGRH.js +472 -0
- package/dist/chunk-4GAIJGRH.js.map +7 -0
- package/dist/chunk-4RTX4AG4.js +249 -0
- package/dist/chunk-4RTX4AG4.js.map +7 -0
- package/dist/chunk-54DNHKOD.js +511 -0
- package/dist/chunk-54DNHKOD.js.map +7 -0
- package/dist/chunk-67PY5IX6.js +34 -0
- package/dist/chunk-67PY5IX6.js.map +7 -0
- package/dist/chunk-6DRDLOLP.js +2613 -0
- package/dist/chunk-6DRDLOLP.js.map +7 -0
- package/dist/chunk-7CQVZNQV.js +1609 -0
- package/dist/chunk-7CQVZNQV.js.map +7 -0
- package/dist/chunk-ABLVTESJ.js +19 -0
- package/dist/chunk-ABLVTESJ.js.map +7 -0
- package/dist/{utils/config.js → chunk-AIMIPK4B.js} +351 -171
- package/dist/chunk-AIMIPK4B.js.map +7 -0
- package/dist/{utils/autoUpdater.js → chunk-BHGTA6JQ.js} +38 -21
- package/dist/chunk-BHGTA6JQ.js.map +7 -0
- package/dist/chunk-CIG63V4E.js +72 -0
- package/dist/chunk-CIG63V4E.js.map +7 -0
- package/dist/chunk-E6YNABER.js +24 -0
- package/dist/chunk-E6YNABER.js.map +7 -0
- package/dist/chunk-EH34V7CY.js +191 -0
- package/dist/chunk-EH34V7CY.js.map +7 -0
- package/dist/{cost-tracker.js → chunk-EZXMVTDU.js} +51 -32
- package/dist/chunk-EZXMVTDU.js.map +7 -0
- package/dist/chunk-FH5CHM6L.js +148 -0
- package/dist/chunk-FH5CHM6L.js.map +7 -0
- package/dist/chunk-G6I7XROM.js +138 -0
- package/dist/chunk-G6I7XROM.js.map +7 -0
- package/dist/chunk-HN4E4UUQ.js +96 -0
- package/dist/chunk-HN4E4UUQ.js.map +7 -0
- package/dist/chunk-HSPVVDIW.js +30198 -0
- package/dist/chunk-HSPVVDIW.js.map +7 -0
- package/dist/{services/systemReminder.js → chunk-IE2CG2TV.js} +221 -59
- package/dist/chunk-IE2CG2TV.js.map +7 -0
- package/dist/chunk-JC6NCUG5.js +11 -0
- package/dist/chunk-K2MI4TPB.js +1256 -0
- package/dist/chunk-K2MI4TPB.js.map +7 -0
- package/dist/chunk-KAA5BGMQ.js +12 -0
- package/dist/chunk-KAA5BGMQ.js.map +7 -0
- package/dist/chunk-MN77D2F7.js +2931 -0
- package/dist/chunk-MN77D2F7.js.map +7 -0
- package/dist/chunk-NPFOMITO.js +21 -0
- package/dist/chunk-NPFOMITO.js.map +7 -0
- package/dist/chunk-NQLEUHMS.js +196 -0
- package/dist/chunk-NQLEUHMS.js.map +7 -0
- package/dist/chunk-OIFQB3S4.js +515 -0
- package/dist/chunk-OIFQB3S4.js.map +7 -0
- package/dist/chunk-OWTG2W3A.js +164 -0
- package/dist/chunk-OWTG2W3A.js.map +7 -0
- package/dist/chunk-OZNRLY3E.js +735 -0
- package/dist/chunk-OZNRLY3E.js.map +7 -0
- package/dist/{utils/debugLogger.js → chunk-QYFKRZQC.js} +107 -204
- package/dist/chunk-QYFKRZQC.js.map +7 -0
- package/dist/chunk-S3J2TLV6.js +16 -0
- package/dist/chunk-S3J2TLV6.js.map +7 -0
- package/dist/chunk-S6HRABTA.js +95 -0
- package/dist/chunk-S6HRABTA.js.map +7 -0
- package/dist/{utils/theme.js → chunk-SDGKPKDK.js} +28 -6
- package/dist/chunk-SDGKPKDK.js.map +7 -0
- package/dist/chunk-SRZZFAS7.js +766 -0
- package/dist/chunk-SRZZFAS7.js.map +7 -0
- package/dist/chunk-UKHTVRJM.js +47 -0
- package/dist/chunk-UKHTVRJM.js.map +7 -0
- package/dist/chunk-UYXEDKOZ.js +24 -0
- package/dist/chunk-UYXEDKOZ.js.map +7 -0
- package/dist/chunk-VBXVYQYY.js +145 -0
- package/dist/chunk-VBXVYQYY.js.map +7 -0
- package/dist/chunk-WVHORZQ5.js +17 -0
- package/dist/chunk-WVHORZQ5.js.map +7 -0
- package/dist/chunk-WWUWDNWW.js +49 -0
- package/dist/chunk-WWUWDNWW.js.map +7 -0
- package/dist/{utils/model.js → chunk-Z33T5YN5.js} +194 -227
- package/dist/chunk-Z33T5YN5.js.map +7 -0
- package/dist/{services/openai.js → chunk-ZQU3TXLC.js} +168 -234
- package/dist/chunk-ZQU3TXLC.js.map +7 -0
- package/dist/cli-SRV2INSL.js +3917 -0
- package/dist/cli-SRV2INSL.js.map +7 -0
- package/dist/commands-TWH6PGVG.js +46 -0
- package/dist/config-6ZMBCL23.js +81 -0
- package/dist/context-JQIOOI4W.js +30 -0
- package/dist/costTracker-6SL26FDB.js +19 -0
- package/dist/customCommands-DNEJS3ZU.js +25 -0
- package/dist/customCommands-DNEJS3ZU.js.map +7 -0
- package/dist/env-OFAXZ3XG.js +22 -0
- package/dist/env-OFAXZ3XG.js.map +7 -0
- package/dist/index.js +34 -5
- package/dist/index.js.map +4 -4
- package/dist/kodeAgentSessionId-X6XWQW7B.js +13 -0
- package/dist/kodeAgentSessionId-X6XWQW7B.js.map +7 -0
- package/dist/kodeAgentSessionLoad-6N27AC5K.js +18 -0
- package/dist/kodeAgentSessionLoad-6N27AC5K.js.map +7 -0
- package/dist/kodeAgentSessionResume-HUSAEO24.js +16 -0
- package/dist/kodeAgentSessionResume-HUSAEO24.js.map +7 -0
- package/dist/kodeAgentStreamJson-NXFN7TXH.js +13 -0
- package/dist/kodeAgentStreamJson-NXFN7TXH.js.map +7 -0
- package/dist/kodeAgentStreamJsonSession-GRWG3SPE.js +131 -0
- package/dist/kodeAgentStreamJsonSession-GRWG3SPE.js.map +7 -0
- package/dist/kodeAgentStructuredStdio-HGWJT7CU.js +10 -0
- package/dist/kodeAgentStructuredStdio-HGWJT7CU.js.map +7 -0
- package/dist/kodeHooks-TDMXFWSO.js +36 -0
- package/dist/kodeHooks-TDMXFWSO.js.map +7 -0
- package/dist/llm-XVXWYOHK.js +3118 -0
- package/dist/llm-XVXWYOHK.js.map +7 -0
- package/dist/llmLazy-7TD5N7XP.js +15 -0
- package/dist/llmLazy-7TD5N7XP.js.map +7 -0
- package/dist/loader-AUXIJTY6.js +28 -0
- package/dist/loader-AUXIJTY6.js.map +7 -0
- package/dist/mcp-BXJ3K7NZ.js +49 -0
- package/dist/mcp-BXJ3K7NZ.js.map +7 -0
- package/dist/{services/mentionProcessor.js → mentionProcessor-YD7YXYGF.js} +61 -50
- package/dist/mentionProcessor-YD7YXYGF.js.map +7 -0
- package/dist/messages-OFUJSPRV.js +63 -0
- package/dist/messages-OFUJSPRV.js.map +7 -0
- package/dist/model-KPYCXWBK.js +30 -0
- package/dist/model-KPYCXWBK.js.map +7 -0
- package/dist/openai-5G5D5Q4B.js +29 -0
- package/dist/openai-5G5D5Q4B.js.map +7 -0
- package/dist/outputStyles-HLDXFQK3.js +28 -0
- package/dist/outputStyles-HLDXFQK3.js.map +7 -0
- package/dist/package.json +1 -1
- package/dist/pluginRuntime-FPTKK6NY.js +218 -0
- package/dist/pluginRuntime-FPTKK6NY.js.map +7 -0
- package/dist/pluginValidation-DSFXZ4GF.js +17 -0
- package/dist/pluginValidation-DSFXZ4GF.js.map +7 -0
- package/dist/prompts-LWLAJRS2.js +48 -0
- package/dist/prompts-LWLAJRS2.js.map +7 -0
- package/dist/query-HVPWL27C.js +50 -0
- package/dist/query-HVPWL27C.js.map +7 -0
- package/dist/responsesStreaming-AW344PQO.js +10 -0
- package/dist/responsesStreaming-AW344PQO.js.map +7 -0
- package/dist/ripgrep-YOPCY2GO.js +17 -0
- package/dist/ripgrep-YOPCY2GO.js.map +7 -0
- package/dist/skillMarketplace-PSNKDINM.js +37 -0
- package/dist/skillMarketplace-PSNKDINM.js.map +7 -0
- package/dist/state-KNRWP3FO.js +16 -0
- package/dist/state-KNRWP3FO.js.map +7 -0
- package/dist/theme-7S2QN2FO.js +14 -0
- package/dist/theme-7S2QN2FO.js.map +7 -0
- package/dist/toolPermissionContext-65L65VEZ.js +17 -0
- package/dist/toolPermissionContext-65L65VEZ.js.map +7 -0
- package/dist/toolPermissionSettings-GPOBH4IV.js +18 -0
- package/dist/toolPermissionSettings-GPOBH4IV.js.map +7 -0
- package/dist/tools-FZU2FZBD.js +47 -0
- package/dist/tools-FZU2FZBD.js.map +7 -0
- package/dist/userInput-VHNBN2MW.js +311 -0
- package/dist/userInput-VHNBN2MW.js.map +7 -0
- package/dist/uuid-QN2CNKKN.js +9 -0
- package/dist/uuid-QN2CNKKN.js.map +7 -0
- package/package.json +43 -14
- package/scripts/binary-utils.cjs +62 -0
- package/scripts/cli-acp-wrapper.cjs +82 -0
- package/scripts/cli-wrapper.cjs +105 -0
- package/scripts/postinstall.js +135 -9
- package/LICENSE +0 -201
- package/README.zh-CN.md +0 -312
- package/dist/ProjectOnboarding.js +0 -99
- package/dist/ProjectOnboarding.js.map +0 -7
- package/dist/Tool.js +0 -1
- package/dist/commands/agents.js +0 -2087
- package/dist/commands/agents.js.map +0 -7
- package/dist/commands/approvedTools.js +0 -36
- package/dist/commands/approvedTools.js.map +0 -7
- package/dist/commands/bug.js +0 -21
- package/dist/commands/bug.js.map +0 -7
- package/dist/commands/clear.js +0 -37
- package/dist/commands/clear.js.map +0 -7
- package/dist/commands/compact.js +0 -104
- package/dist/commands/compact.js.map +0 -7
- package/dist/commands/config.js +0 -20
- package/dist/commands/config.js.map +0 -7
- package/dist/commands/cost.js +0 -19
- package/dist/commands/cost.js.map +0 -7
- package/dist/commands/ctx_viz.js +0 -152
- package/dist/commands/ctx_viz.js.map +0 -7
- package/dist/commands/doctor.js +0 -25
- package/dist/commands/doctor.js.map +0 -7
- package/dist/commands/help.js +0 -20
- package/dist/commands/help.js.map +0 -7
- package/dist/commands/init.js +0 -38
- package/dist/commands/init.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 -34
- package/dist/commands/mcp.js.map +0 -7
- package/dist/commands/model.js +0 -41
- package/dist/commands/model.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/pr_comments.js +0 -61
- package/dist/commands/pr_comments.js.map +0 -7
- package/dist/commands/refreshCommands.js +0 -37
- package/dist/commands/refreshCommands.js.map +0 -7
- package/dist/commands/release-notes.js +0 -30
- package/dist/commands/release-notes.js.map +0 -7
- package/dist/commands/resume.js +0 -35
- package/dist/commands/resume.js.map +0 -7
- package/dist/commands/review.js +0 -51
- package/dist/commands/review.js.map +0 -7
- package/dist/commands/terminalSetup.js +0 -163
- package/dist/commands/terminalSetup.js.map +0 -7
- package/dist/commands.js +0 -84
- package/dist/commands.js.map +0 -7
- package/dist/components/ApproveApiKey.js +0 -74
- package/dist/components/ApproveApiKey.js.map +0 -7
- package/dist/components/AsciiLogo.js +0 -12
- package/dist/components/AsciiLogo.js.map +0 -7
- package/dist/components/AutoUpdater.js +0 -74
- package/dist/components/AutoUpdater.js.map +0 -7
- package/dist/components/Bug.js +0 -147
- package/dist/components/Bug.js.map +0 -7
- package/dist/components/Config.js +0 -166
- package/dist/components/Config.js.map +0 -7
- package/dist/components/ConsoleOAuthFlow.js +0 -188
- package/dist/components/ConsoleOAuthFlow.js.map +0 -7
- package/dist/components/Cost.js +0 -13
- package/dist/components/Cost.js.map +0 -7
- package/dist/components/CostThresholdDialog.js +0 -38
- package/dist/components/CostThresholdDialog.js.map +0 -7
- package/dist/components/CustomSelect/option-map.js +0 -32
- package/dist/components/CustomSelect/option-map.js.map +0 -7
- package/dist/components/CustomSelect/select-option.js +0 -34
- package/dist/components/CustomSelect/select-option.js.map +0 -7
- package/dist/components/CustomSelect/select.js +0 -64
- package/dist/components/CustomSelect/select.js.map +0 -7
- package/dist/components/CustomSelect/theme.js +0 -1
- package/dist/components/CustomSelect/use-select-state.js +0 -220
- package/dist/components/CustomSelect/use-select-state.js.map +0 -7
- package/dist/components/CustomSelect/use-select.js +0 -21
- package/dist/components/CustomSelect/use-select.js.map +0 -7
- package/dist/components/FallbackToolUseRejectedMessage.js +0 -11
- package/dist/components/FallbackToolUseRejectedMessage.js.map +0 -7
- package/dist/components/FileEditToolUpdatedMessage.js +0 -32
- package/dist/components/FileEditToolUpdatedMessage.js.map +0 -7
- package/dist/components/Help.js +0 -41
- package/dist/components/Help.js.map +0 -7
- package/dist/components/HighlightedCode.js +0 -30
- package/dist/components/HighlightedCode.js.map +0 -7
- package/dist/components/InvalidConfigDialog.js +0 -83
- package/dist/components/InvalidConfigDialog.js.map +0 -7
- package/dist/components/Link.js +0 -18
- package/dist/components/Link.js.map +0 -7
- package/dist/components/LogSelector.js +0 -50
- package/dist/components/LogSelector.js.map +0 -7
- package/dist/components/Logo.js +0 -94
- package/dist/components/Logo.js.map +0 -7
- package/dist/components/MCPServerApprovalDialog.js +0 -79
- package/dist/components/MCPServerApprovalDialog.js.map +0 -7
- package/dist/components/MCPServerDialogCopy.js +0 -11
- package/dist/components/MCPServerDialogCopy.js.map +0 -7
- package/dist/components/MCPServerMultiselectDialog.js +0 -80
- package/dist/components/MCPServerMultiselectDialog.js.map +0 -7
- package/dist/components/Message.js +0 -146
- package/dist/components/Message.js.map +0 -7
- package/dist/components/MessageResponse.js +0 -9
- package/dist/components/MessageResponse.js.map +0 -7
- package/dist/components/MessageSelector.js +0 -133
- package/dist/components/MessageSelector.js.map +0 -7
- package/dist/components/ModeIndicator.js +0 -38
- package/dist/components/ModeIndicator.js.map +0 -7
- package/dist/components/ModelConfig.js +0 -208
- package/dist/components/ModelConfig.js.map +0 -7
- package/dist/components/ModelListManager.js +0 -140
- package/dist/components/ModelListManager.js.map +0 -7
- package/dist/components/ModelSelector.js +0 -1985
- 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/components/Onboarding.js +0 -153
- package/dist/components/Onboarding.js.map +0 -7
- package/dist/components/PressEnterToContinue.js +0 -10
- package/dist/components/PressEnterToContinue.js.map +0 -7
- package/dist/components/PromptInput.js +0 -488
- package/dist/components/PromptInput.js.map +0 -7
- package/dist/components/SentryErrorBoundary.js +0 -27
- package/dist/components/SentryErrorBoundary.js.map +0 -7
- package/dist/components/Spinner.js +0 -101
- package/dist/components/Spinner.js.map +0 -7
- package/dist/components/StickerRequestForm.js +0 -7
- package/dist/components/StickerRequestForm.js.map +0 -7
- package/dist/components/StructuredDiff.js +0 -148
- package/dist/components/StructuredDiff.js.map +0 -7
- package/dist/components/TextInput.js +0 -100
- package/dist/components/TextInput.js.map +0 -7
- package/dist/components/TodoItem.js +0 -35
- package/dist/components/TodoItem.js.map +0 -7
- package/dist/components/TokenWarning.js +0 -19
- package/dist/components/TokenWarning.js.map +0 -7
- package/dist/components/ToolUseLoader.js +0 -24
- package/dist/components/ToolUseLoader.js.map +0 -7
- package/dist/components/TrustDialog.js +0 -76
- package/dist/components/TrustDialog.js.map +0 -7
- package/dist/components/binary-feedback/BinaryFeedback.js +0 -50
- package/dist/components/binary-feedback/BinaryFeedback.js.map +0 -7
- package/dist/components/binary-feedback/BinaryFeedbackOption.js +0 -94
- package/dist/components/binary-feedback/BinaryFeedbackOption.js.map +0 -7
- package/dist/components/binary-feedback/BinaryFeedbackView.js +0 -139
- package/dist/components/binary-feedback/BinaryFeedbackView.js.map +0 -7
- package/dist/components/binary-feedback/utils.js +0 -161
- package/dist/components/binary-feedback/utils.js.map +0 -7
- package/dist/components/messages/AssistantBashOutputMessage.js +0 -23
- package/dist/components/messages/AssistantBashOutputMessage.js.map +0 -7
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js +0 -36
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js.map +0 -7
- package/dist/components/messages/AssistantRedactedThinkingMessage.js +0 -12
- package/dist/components/messages/AssistantRedactedThinkingMessage.js.map +0 -7
- package/dist/components/messages/AssistantTextMessage.js +0 -78
- package/dist/components/messages/AssistantTextMessage.js.map +0 -7
- package/dist/components/messages/AssistantThinkingMessage.js +0 -27
- package/dist/components/messages/AssistantThinkingMessage.js.map +0 -7
- package/dist/components/messages/AssistantToolUseMessage.js +0 -91
- package/dist/components/messages/AssistantToolUseMessage.js.map +0 -7
- package/dist/components/messages/TaskProgressMessage.js +0 -11
- package/dist/components/messages/TaskProgressMessage.js.map +0 -7
- package/dist/components/messages/TaskToolMessage.js +0 -39
- package/dist/components/messages/TaskToolMessage.js.map +0 -7
- package/dist/components/messages/UserBashInputMessage.js +0 -18
- package/dist/components/messages/UserBashInputMessage.js.map +0 -7
- package/dist/components/messages/UserCommandMessage.js +0 -20
- package/dist/components/messages/UserCommandMessage.js.map +0 -7
- package/dist/components/messages/UserKodingInputMessage.js +0 -18
- package/dist/components/messages/UserKodingInputMessage.js.map +0 -7
- package/dist/components/messages/UserPromptMessage.js +0 -20
- package/dist/components/messages/UserPromptMessage.js.map +0 -7
- package/dist/components/messages/UserTextMessage.js +0 -25
- package/dist/components/messages/UserTextMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +0 -10
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js +0 -15
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js +0 -25
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js +0 -47
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +0 -23
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/utils.js +0 -42
- package/dist/components/messages/UserToolResultMessage/utils.js.map +0 -7
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js +0 -112
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js.map +0 -7
- package/dist/components/permissions/FallbackPermissionRequest.js +0 -131
- package/dist/components/permissions/FallbackPermissionRequest.js.map +0 -7
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +0 -159
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js.map +0 -7
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js +0 -58
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js.map +0 -7
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +0 -153
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js.map +0 -7
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +0 -70
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js.map +0 -7
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +0 -212
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js.map +0 -7
- package/dist/components/permissions/PermissionRequest.js +0 -70
- package/dist/components/permissions/PermissionRequest.js.map +0 -7
- package/dist/components/permissions/PermissionRequestTitle.js +0 -52
- package/dist/components/permissions/PermissionRequestTitle.js.map +0 -7
- package/dist/components/permissions/hooks.js +0 -28
- package/dist/components/permissions/hooks.js.map +0 -7
- package/dist/components/permissions/toolUseOptions.js +0 -46
- package/dist/components/permissions/toolUseOptions.js.map +0 -7
- package/dist/components/permissions/utils.js +0 -21
- package/dist/components/permissions/utils.js.map +0 -7
- package/dist/constants/betas.js +0 -11
- package/dist/constants/betas.js.map +0 -7
- package/dist/constants/claude-asterisk-ascii-art.js +0 -242
- package/dist/constants/claude-asterisk-ascii-art.js.map +0 -7
- package/dist/constants/figures.js +0 -6
- package/dist/constants/figures.js.map +0 -7
- package/dist/constants/keys.js +0 -7
- package/dist/constants/keys.js.map +0 -7
- package/dist/constants/macros.js +0 -13
- package/dist/constants/macros.js.map +0 -7
- package/dist/constants/modelCapabilities.js +0 -154
- package/dist/constants/modelCapabilities.js.map +0 -7
- package/dist/constants/models.js +0 -1034
- package/dist/constants/models.js.map +0 -7
- package/dist/constants/oauth.js +0 -18
- package/dist/constants/oauth.js.map +0 -7
- package/dist/constants/product.js +0 -26
- package/dist/constants/product.js.map +0 -7
- package/dist/constants/prompts.js +0 -168
- package/dist/constants/prompts.js.map +0 -7
- package/dist/constants/releaseNotes.js +0 -9
- package/dist/constants/releaseNotes.js.map +0 -7
- package/dist/context/PermissionContext.js +0 -111
- package/dist/context/PermissionContext.js.map +0 -7
- package/dist/context.js +0 -259
- package/dist/context.js.map +0 -7
- package/dist/cost-tracker.js.map +0 -7
- package/dist/entrypoints/cli.js +0 -1107
- package/dist/entrypoints/cli.js.map +0 -7
- package/dist/entrypoints/mcp.js +0 -150
- package/dist/entrypoints/mcp.js.map +0 -7
- package/dist/history.js +0 -25
- package/dist/history.js.map +0 -7
- package/dist/hooks/useApiKeyVerification.js +0 -12
- package/dist/hooks/useApiKeyVerification.js.map +0 -7
- package/dist/hooks/useArrowKeyHistory.js +0 -50
- package/dist/hooks/useArrowKeyHistory.js.map +0 -7
- package/dist/hooks/useCanUseTool.js +0 -112
- package/dist/hooks/useCanUseTool.js.map +0 -7
- package/dist/hooks/useCancelRequest.js +0 -30
- package/dist/hooks/useCancelRequest.js.map +0 -7
- package/dist/hooks/useDoublePress.js +0 -31
- package/dist/hooks/useDoublePress.js.map +0 -7
- package/dist/hooks/useExitOnCtrlCD.js +0 -26
- package/dist/hooks/useExitOnCtrlCD.js.map +0 -7
- package/dist/hooks/useInterval.js +0 -18
- package/dist/hooks/useInterval.js.map +0 -7
- package/dist/hooks/useLogMessages.js +0 -14
- package/dist/hooks/useLogMessages.js.map +0 -7
- package/dist/hooks/useLogStartupTime.js +0 -15
- package/dist/hooks/useLogStartupTime.js.map +0 -7
- package/dist/hooks/useNotifyAfterTimeout.js +0 -42
- package/dist/hooks/useNotifyAfterTimeout.js.map +0 -7
- package/dist/hooks/usePermissionRequestLogging.js +0 -28
- package/dist/hooks/usePermissionRequestLogging.js.map +0 -7
- package/dist/hooks/useTerminalSize.js +0 -38
- package/dist/hooks/useTerminalSize.js.map +0 -7
- package/dist/hooks/useTextInput.js +0 -250
- package/dist/hooks/useTextInput.js.map +0 -7
- package/dist/hooks/useUnifiedCompletion.js +0 -929
- package/dist/hooks/useUnifiedCompletion.js.map +0 -7
- package/dist/messages.js +0 -33
- package/dist/messages.js.map +0 -7
- package/dist/permissions.js +0 -194
- package/dist/permissions.js.map +0 -7
- package/dist/query.js +0 -492
- package/dist/query.js.map +0 -7
- package/dist/screens/ConfigureNpmPrefix.js +0 -128
- package/dist/screens/ConfigureNpmPrefix.js.map +0 -7
- package/dist/screens/Doctor.js +0 -22
- package/dist/screens/Doctor.js.map +0 -7
- package/dist/screens/LogList.js +0 -55
- package/dist/screens/LogList.js.map +0 -7
- package/dist/screens/REPL.js +0 -593
- package/dist/screens/REPL.js.map +0 -7
- package/dist/screens/ResumeConversation.js +0 -56
- package/dist/screens/ResumeConversation.js.map +0 -7
- package/dist/services/adapters/base.js +0 -29
- package/dist/services/adapters/base.js.map +0 -7
- package/dist/services/adapters/chatCompletions.js +0 -69
- package/dist/services/adapters/chatCompletions.js.map +0 -7
- package/dist/services/adapters/responsesAPI.js +0 -126
- package/dist/services/adapters/responsesAPI.js.map +0 -7
- package/dist/services/browserMocks.js +0 -48
- package/dist/services/browserMocks.js.map +0 -7
- package/dist/services/claude.js +0 -1605
- package/dist/services/claude.js.map +0 -7
- package/dist/services/customCommands.js +0 -359
- package/dist/services/customCommands.js.map +0 -7
- package/dist/services/fileFreshness.js +0 -280
- package/dist/services/fileFreshness.js.map +0 -7
- package/dist/services/gpt5ConnectionTest.js +0 -248
- package/dist/services/gpt5ConnectionTest.js.map +0 -7
- package/dist/services/mcpClient.js +0 -435
- package/dist/services/mcpClient.js.map +0 -7
- package/dist/services/mcpServerApproval.js +0 -55
- package/dist/services/mcpServerApproval.js.map +0 -7
- package/dist/services/mentionProcessor.js.map +0 -7
- package/dist/services/modelAdapterFactory.js +0 -47
- package/dist/services/modelAdapterFactory.js.map +0 -7
- package/dist/services/notifier.js +0 -35
- package/dist/services/notifier.js.map +0 -7
- package/dist/services/oauth.js +0 -259
- package/dist/services/oauth.js.map +0 -7
- package/dist/services/openai.js.map +0 -7
- package/dist/services/responseStateManager.js +0 -68
- package/dist/services/responseStateManager.js.map +0 -7
- package/dist/services/sentry.js +0 -9
- package/dist/services/sentry.js.map +0 -7
- package/dist/services/statsig.js +0 -112
- package/dist/services/statsig.js.map +0 -7
- package/dist/services/statsigStorage.js +0 -75
- package/dist/services/statsigStorage.js.map +0 -7
- package/dist/services/systemReminder.js.map +0 -7
- package/dist/services/vcr.js +0 -133
- package/dist/services/vcr.js.map +0 -7
- package/dist/tools/ArchitectTool/ArchitectTool.js +0 -119
- package/dist/tools/ArchitectTool/ArchitectTool.js.map +0 -7
- package/dist/tools/ArchitectTool/prompt.js +0 -18
- package/dist/tools/ArchitectTool/prompt.js.map +0 -7
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js +0 -423
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js.map +0 -7
- package/dist/tools/BashTool/BashTool.js +0 -188
- package/dist/tools/BashTool/BashTool.js.map +0 -7
- package/dist/tools/BashTool/BashToolResultMessage.js +0 -21
- package/dist/tools/BashTool/BashToolResultMessage.js.map +0 -7
- package/dist/tools/BashTool/OutputLine.js +0 -30
- package/dist/tools/BashTool/OutputLine.js.map +0 -7
- package/dist/tools/BashTool/prompt.js +0 -179
- package/dist/tools/BashTool/prompt.js.map +0 -7
- package/dist/tools/BashTool/utils.js +0 -51
- package/dist/tools/BashTool/utils.js.map +0 -7
- package/dist/tools/FileEditTool/FileEditTool.js +0 -228
- package/dist/tools/FileEditTool/FileEditTool.js.map +0 -7
- package/dist/tools/FileEditTool/prompt.js +0 -54
- package/dist/tools/FileEditTool/prompt.js.map +0 -7
- package/dist/tools/FileEditTool/utils.js +0 -42
- package/dist/tools/FileEditTool/utils.js.map +0 -7
- package/dist/tools/FileReadTool/FileReadTool.js +0 -272
- package/dist/tools/FileReadTool/FileReadTool.js.map +0 -7
- package/dist/tools/FileReadTool/prompt.js +0 -10
- package/dist/tools/FileReadTool/prompt.js.map +0 -7
- package/dist/tools/FileWriteTool/FileWriteTool.js +0 -204
- package/dist/tools/FileWriteTool/FileWriteTool.js.map +0 -7
- package/dist/tools/FileWriteTool/prompt.js +0 -14
- package/dist/tools/FileWriteTool/prompt.js.map +0 -7
- package/dist/tools/GlobTool/GlobTool.js +0 -88
- package/dist/tools/GlobTool/GlobTool.js.map +0 -7
- package/dist/tools/GlobTool/prompt.js +0 -12
- package/dist/tools/GlobTool/prompt.js.map +0 -7
- package/dist/tools/GrepTool/GrepTool.js +0 -107
- package/dist/tools/GrepTool/GrepTool.js.map +0 -7
- package/dist/tools/GrepTool/prompt.js +0 -15
- package/dist/tools/GrepTool/prompt.js.map +0 -7
- package/dist/tools/MCPTool/MCPTool.js +0 -90
- package/dist/tools/MCPTool/MCPTool.js.map +0 -7
- package/dist/tools/MCPTool/prompt.js +0 -7
- package/dist/tools/MCPTool/prompt.js.map +0 -7
- package/dist/tools/MemoryReadTool/MemoryReadTool.js +0 -103
- package/dist/tools/MemoryReadTool/MemoryReadTool.js.map +0 -7
- package/dist/tools/MemoryReadTool/prompt.js +0 -7
- package/dist/tools/MemoryReadTool/prompt.js.map +0 -7
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js +0 -77
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js.map +0 -7
- package/dist/tools/MemoryWriteTool/prompt.js +0 -7
- package/dist/tools/MemoryWriteTool/prompt.js.map +0 -7
- package/dist/tools/MultiEditTool/MultiEditTool.js +0 -308
- package/dist/tools/MultiEditTool/MultiEditTool.js.map +0 -7
- package/dist/tools/MultiEditTool/prompt.js +0 -48
- package/dist/tools/MultiEditTool/prompt.js.map +0 -7
- package/dist/tools/NotebookEditTool/NotebookEditTool.js +0 -238
- package/dist/tools/NotebookEditTool/NotebookEditTool.js.map +0 -7
- package/dist/tools/NotebookEditTool/prompt.js +0 -7
- package/dist/tools/NotebookEditTool/prompt.js.map +0 -7
- package/dist/tools/NotebookReadTool/NotebookReadTool.js +0 -212
- package/dist/tools/NotebookReadTool/NotebookReadTool.js.map +0 -7
- package/dist/tools/NotebookReadTool/prompt.js +0 -7
- package/dist/tools/NotebookReadTool/prompt.js.map +0 -7
- package/dist/tools/StickerRequestTool/StickerRequestTool.js +0 -86
- package/dist/tools/StickerRequestTool/StickerRequestTool.js.map +0 -7
- package/dist/tools/StickerRequestTool/prompt.js +0 -23
- package/dist/tools/StickerRequestTool/prompt.js.map +0 -7
- package/dist/tools/TaskTool/TaskTool.js +0 -351
- package/dist/tools/TaskTool/TaskTool.js.map +0 -7
- package/dist/tools/TaskTool/constants.js +0 -5
- package/dist/tools/TaskTool/constants.js.map +0 -7
- package/dist/tools/TaskTool/prompt.js +0 -82
- package/dist/tools/TaskTool/prompt.js.map +0 -7
- package/dist/tools/ThinkTool/ThinkTool.js +0 -48
- package/dist/tools/ThinkTool/ThinkTool.js.map +0 -7
- package/dist/tools/ThinkTool/prompt.js +0 -16
- package/dist/tools/ThinkTool/prompt.js.map +0 -7
- package/dist/tools/TodoWriteTool/TodoWriteTool.js +0 -216
- package/dist/tools/TodoWriteTool/TodoWriteTool.js.map +0 -7
- package/dist/tools/TodoWriteTool/prompt.js +0 -66
- package/dist/tools/TodoWriteTool/prompt.js.map +0 -7
- package/dist/tools/URLFetcherTool/URLFetcherTool.js +0 -137
- package/dist/tools/URLFetcherTool/URLFetcherTool.js.map +0 -7
- package/dist/tools/URLFetcherTool/cache.js +0 -45
- package/dist/tools/URLFetcherTool/cache.js.map +0 -7
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js +0 -42
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js.map +0 -7
- package/dist/tools/URLFetcherTool/prompt.js +0 -22
- package/dist/tools/URLFetcherTool/prompt.js.map +0 -7
- package/dist/tools/WebSearchTool/WebSearchTool.js +0 -86
- package/dist/tools/WebSearchTool/WebSearchTool.js.map +0 -7
- package/dist/tools/WebSearchTool/prompt.js +0 -17
- package/dist/tools/WebSearchTool/prompt.js.map +0 -7
- package/dist/tools/WebSearchTool/searchProviders.js +0 -48
- package/dist/tools/WebSearchTool/searchProviders.js.map +0 -7
- package/dist/tools/lsTool/lsTool.js +0 -201
- package/dist/tools/lsTool/lsTool.js.map +0 -7
- package/dist/tools/lsTool/prompt.js +0 -5
- package/dist/tools/lsTool/prompt.js.map +0 -7
- package/dist/tools.js +0 -64
- package/dist/tools.js.map +0 -7
- package/dist/types/PermissionMode.js +0 -82
- package/dist/types/PermissionMode.js.map +0 -7
- package/dist/types/RequestContext.js +0 -47
- package/dist/types/RequestContext.js.map +0 -7
- package/dist/types/common.d.js +0 -1
- package/dist/types/conversation.js +0 -1
- package/dist/types/logs.js +0 -1
- package/dist/types/modelCapabilities.js +0 -1
- package/dist/types/notebook.js +0 -1
- package/dist/utils/Cursor.js +0 -313
- package/dist/utils/Cursor.js.map +0 -7
- package/dist/utils/PersistentShell.js +0 -382
- package/dist/utils/PersistentShell.js.map +0 -7
- package/dist/utils/advancedFuzzyMatcher.js +0 -206
- package/dist/utils/advancedFuzzyMatcher.js.map +0 -7
- package/dist/utils/agentLoader.js +0 -199
- package/dist/utils/agentLoader.js.map +0 -7
- package/dist/utils/agentStorage.js +0 -59
- package/dist/utils/agentStorage.js.map +0 -7
- package/dist/utils/array.js +0 -7
- package/dist/utils/array.js.map +0 -7
- package/dist/utils/ask.js +0 -77
- package/dist/utils/ask.js.map +0 -7
- package/dist/utils/auth.js +0 -11
- package/dist/utils/auth.js.map +0 -7
- package/dist/utils/autoCompactCore.js +0 -149
- package/dist/utils/autoCompactCore.js.map +0 -7
- package/dist/utils/autoUpdater.js.map +0 -7
- package/dist/utils/betas.js +0 -21
- package/dist/utils/betas.js.map +0 -7
- package/dist/utils/browser.js +0 -15
- package/dist/utils/browser.js.map +0 -7
- package/dist/utils/cleanup.js +0 -54
- package/dist/utils/cleanup.js.map +0 -7
- package/dist/utils/commands.js +0 -207
- package/dist/utils/commands.js.map +0 -7
- package/dist/utils/commonUnixCommands.js +0 -687
- package/dist/utils/commonUnixCommands.js.map +0 -7
- package/dist/utils/config.js.map +0 -7
- package/dist/utils/conversationRecovery.js +0 -35
- package/dist/utils/conversationRecovery.js.map +0 -7
- package/dist/utils/debugLogger.js.map +0 -7
- package/dist/utils/diff.js +0 -32
- package/dist/utils/diff.js.map +0 -7
- package/dist/utils/env.js +0 -44
- package/dist/utils/env.js.map +0 -7
- package/dist/utils/errors.js +0 -23
- package/dist/utils/errors.js.map +0 -7
- package/dist/utils/exampleCommands.js +0 -80
- package/dist/utils/exampleCommands.js.map +0 -7
- package/dist/utils/execFileNoThrow.js +0 -44
- package/dist/utils/execFileNoThrow.js.map +0 -7
- package/dist/utils/expertChatStorage.js +0 -78
- package/dist/utils/expertChatStorage.js.map +0 -7
- package/dist/utils/file.js +0 -282
- package/dist/utils/file.js.map +0 -7
- package/dist/utils/fileRecoveryCore.js +0 -41
- package/dist/utils/fileRecoveryCore.js.map +0 -7
- package/dist/utils/format.js +0 -41
- package/dist/utils/format.js.map +0 -7
- package/dist/utils/fuzzyMatcher.js +0 -252
- package/dist/utils/fuzzyMatcher.js.map +0 -7
- package/dist/utils/generators.js +0 -46
- package/dist/utils/generators.js.map +0 -7
- package/dist/utils/git.js +0 -83
- package/dist/utils/git.js.map +0 -7
- package/dist/utils/globalLogger.js +0 -54
- package/dist/utils/globalLogger.js.map +0 -7
- package/dist/utils/http.js +0 -7
- package/dist/utils/http.js.map +0 -7
- package/dist/utils/imagePaste.js +0 -29
- package/dist/utils/imagePaste.js.map +0 -7
- package/dist/utils/json.js +0 -16
- package/dist/utils/json.js.map +0 -7
- package/dist/utils/log.js +0 -298
- package/dist/utils/log.js.map +0 -7
- package/dist/utils/markdown.js +0 -187
- package/dist/utils/markdown.js.map +0 -7
- package/dist/utils/messageContextManager.js +0 -195
- package/dist/utils/messageContextManager.js.map +0 -7
- package/dist/utils/messages.js +0 -633
- package/dist/utils/messages.js.map +0 -7
- package/dist/utils/model.js.map +0 -7
- package/dist/utils/permissions/filesystem.js +0 -80
- package/dist/utils/permissions/filesystem.js.map +0 -7
- package/dist/utils/responseState.js +0 -20
- package/dist/utils/responseState.js.map +0 -7
- package/dist/utils/ripgrep.js +0 -131
- package/dist/utils/ripgrep.js.map +0 -7
- package/dist/utils/secureFile.js +0 -483
- package/dist/utils/secureFile.js.map +0 -7
- package/dist/utils/sessionState.js +0 -31
- package/dist/utils/sessionState.js.map +0 -7
- package/dist/utils/state.js +0 -24
- package/dist/utils/state.js.map +0 -7
- package/dist/utils/style.js +0 -31
- package/dist/utils/style.js.map +0 -7
- package/dist/utils/terminal.js +0 -43
- package/dist/utils/terminal.js.map +0 -7
- package/dist/utils/theme.js.map +0 -7
- package/dist/utils/thinking.js +0 -103
- package/dist/utils/thinking.js.map +0 -7
- package/dist/utils/todoStorage.js +0 -291
- package/dist/utils/todoStorage.js.map +0 -7
- package/dist/utils/tokens.js +0 -30
- package/dist/utils/tokens.js.map +0 -7
- package/dist/utils/toolExecutionController.js +0 -109
- package/dist/utils/toolExecutionController.js.map +0 -7
- package/dist/utils/unaryLogging.js +0 -14
- package/dist/utils/unaryLogging.js.map +0 -7
- package/dist/utils/user.js +0 -40
- package/dist/utils/user.js.map +0 -7
- package/dist/utils/validate.js +0 -132
- package/dist/utils/validate.js.map +0 -7
- /package/dist/{Tool.js.map → REPL-GIU4ZIXM.js.map} +0 -0
- /package/dist/{components/CustomSelect/theme.js.map → autoUpdater-DNRMJWFQ.js.map} +0 -0
- /package/dist/{types/common.d.js.map → chunk-JC6NCUG5.js.map} +0 -0
- /package/dist/{types/conversation.js.map → commands-TWH6PGVG.js.map} +0 -0
- /package/dist/{types/logs.js.map → config-6ZMBCL23.js.map} +0 -0
- /package/dist/{types/modelCapabilities.js.map → context-JQIOOI4W.js.map} +0 -0
- /package/dist/{types/notebook.js.map → costTracker-6SL26FDB.js.map} +0 -0
|
@@ -1,146 +0,0 @@
|
|
|
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
|
|
@@ -1,7 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
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
|
|
@@ -1,7 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,133 +0,0 @@
|
|
|
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
|
|
@@ -1,7 +0,0 @@
|
|
|
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": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,38 +0,0 @@
|
|
|
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
|
|
@@ -1,7 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,208 +0,0 @@
|
|
|
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
|