@shareai-lab/kode 1.2.0 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +25 -388
- package/cli-acp.js +82 -0
- package/cli.js +89 -79
- package/dist/REPL-CW7AYLVL.js +42 -0
- package/dist/acp-VEPJ74LT.js +1357 -0
- package/dist/acp-VEPJ74LT.js.map +7 -0
- package/dist/agentsValidate-7LH4HTNR.js +373 -0
- package/dist/agentsValidate-7LH4HTNR.js.map +7 -0
- package/dist/ask-3NHFFUQG.js +125 -0
- package/dist/ask-3NHFFUQG.js.map +7 -0
- package/dist/autoUpdater-ITPIHCOI.js +17 -0
- package/dist/{utils/autoUpdater.js → chunk-3IN27HA5.js} +38 -21
- package/dist/chunk-3IN27HA5.js.map +7 -0
- package/dist/chunk-3RUXVV4S.js +23 -0
- package/dist/chunk-3RUXVV4S.js.map +7 -0
- package/dist/chunk-4FX3IVPT.js +164 -0
- package/dist/chunk-4FX3IVPT.js.map +7 -0
- package/dist/chunk-4RTX4AG4.js +249 -0
- package/dist/chunk-4RTX4AG4.js.map +7 -0
- package/dist/chunk-5PDP7R6N.js +515 -0
- package/dist/chunk-5PDP7R6N.js.map +7 -0
- package/dist/chunk-73WGVYLQ.js +735 -0
- package/dist/chunk-73WGVYLQ.js.map +7 -0
- package/dist/{services/systemReminder.js → chunk-7M2YN6TU.js} +221 -59
- package/dist/chunk-7M2YN6TU.js.map +7 -0
- package/dist/{utils/theme.js → chunk-7U7L4NMD.js} +28 -6
- package/dist/chunk-7U7L4NMD.js.map +7 -0
- package/dist/chunk-ABLVTESJ.js +19 -0
- package/dist/chunk-ABLVTESJ.js.map +7 -0
- package/dist/chunk-AFFSCMYS.js +191 -0
- package/dist/chunk-AFFSCMYS.js.map +7 -0
- package/dist/chunk-ARZSBOAO.js +1256 -0
- package/dist/chunk-ARZSBOAO.js.map +7 -0
- package/dist/chunk-CIG63V4E.js +72 -0
- package/dist/chunk-CIG63V4E.js.map +7 -0
- package/dist/chunk-CM3EGTG6.js +1609 -0
- package/dist/chunk-CM3EGTG6.js.map +7 -0
- package/dist/{services/openai.js → chunk-DZE5YA7L.js} +168 -234
- package/dist/chunk-DZE5YA7L.js.map +7 -0
- package/dist/chunk-E6YNABER.js +24 -0
- package/dist/chunk-E6YNABER.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-F2SJXUDI.js +148 -0
- package/dist/chunk-F2SJXUDI.js.map +7 -0
- package/dist/chunk-FC5ZCKBI.js +30167 -0
- package/dist/chunk-FC5ZCKBI.js.map +7 -0
- package/dist/chunk-HCBELH4J.js +145 -0
- package/dist/chunk-HCBELH4J.js.map +7 -0
- package/dist/chunk-HN4E4UUQ.js +96 -0
- package/dist/chunk-HN4E4UUQ.js.map +7 -0
- package/dist/{utils/model.js → chunk-IZVMU4S2.js} +194 -227
- package/dist/chunk-IZVMU4S2.js.map +7 -0
- package/dist/chunk-JC6NCUG5.js +11 -0
- package/dist/chunk-K2CWOTI2.js +196 -0
- package/dist/chunk-K2CWOTI2.js.map +7 -0
- package/dist/chunk-KAA5BGMQ.js +12 -0
- package/dist/chunk-KAA5BGMQ.js.map +7 -0
- package/dist/{utils/config.js → chunk-LC4TVOCZ.js} +351 -171
- package/dist/chunk-LC4TVOCZ.js.map +7 -0
- package/dist/chunk-MIW7N2MY.js +2613 -0
- package/dist/chunk-MIW7N2MY.js.map +7 -0
- package/dist/chunk-MWRSY4X6.js +240 -0
- package/dist/chunk-MWRSY4X6.js.map +7 -0
- package/dist/chunk-ND3XWFO6.js +34 -0
- package/dist/chunk-ND3XWFO6.js.map +7 -0
- package/dist/chunk-NPFOMITO.js +21 -0
- package/dist/chunk-NPFOMITO.js.map +7 -0
- package/dist/chunk-QVLYOPO5.js +1097 -0
- package/dist/chunk-QVLYOPO5.js.map +7 -0
- package/dist/chunk-RZWOUA25.js +490 -0
- package/dist/chunk-RZWOUA25.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/debugLogger.js → chunk-STSX7GIX.js} +107 -204
- package/dist/chunk-STSX7GIX.js.map +7 -0
- package/dist/chunk-UHYRLID6.js +472 -0
- package/dist/chunk-UHYRLID6.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-W7GRKO7Q.js +766 -0
- package/dist/chunk-W7GRKO7Q.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/chunk-YC6LJCDE.js +511 -0
- package/dist/chunk-YC6LJCDE.js.map +7 -0
- package/dist/chunk-YXYYDIMI.js +2931 -0
- package/dist/chunk-YXYYDIMI.js.map +7 -0
- package/dist/chunk-ZVDRDPII.js +138 -0
- package/dist/chunk-ZVDRDPII.js.map +7 -0
- package/dist/cli-DOPVY2CW.js +3917 -0
- package/dist/cli-DOPVY2CW.js.map +7 -0
- package/dist/commands-2BF2CJ3A.js +46 -0
- package/dist/config-RUSD6G5Y.js +81 -0
- package/dist/context-6FXPETYH.js +30 -0
- package/dist/costTracker-6SL26FDB.js +19 -0
- package/dist/customCommands-TOIJFZAL.js +25 -0
- package/dist/customCommands-TOIJFZAL.js.map +7 -0
- package/dist/env-XGKBLU3D.js +22 -0
- package/dist/env-XGKBLU3D.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-MITZADPB.js +18 -0
- package/dist/kodeAgentSessionLoad-MITZADPB.js.map +7 -0
- package/dist/kodeAgentSessionResume-GVRWB4WO.js +16 -0
- package/dist/kodeAgentSessionResume-GVRWB4WO.js.map +7 -0
- package/dist/kodeAgentStreamJson-NXFN7TXH.js +13 -0
- package/dist/kodeAgentStreamJson-NXFN7TXH.js.map +7 -0
- package/dist/kodeAgentStreamJsonSession-UGEZJJEB.js +131 -0
- package/dist/kodeAgentStreamJsonSession-UGEZJJEB.js.map +7 -0
- package/dist/kodeAgentStructuredStdio-HGWJT7CU.js +10 -0
- package/dist/kodeAgentStructuredStdio-HGWJT7CU.js.map +7 -0
- package/dist/kodeHooks-QWM36A3D.js +36 -0
- package/dist/kodeHooks-QWM36A3D.js.map +7 -0
- package/dist/llm-ZUQC4WYM.js +3118 -0
- package/dist/llm-ZUQC4WYM.js.map +7 -0
- package/dist/llmLazy-54QQHA54.js +15 -0
- package/dist/llmLazy-54QQHA54.js.map +7 -0
- package/dist/loader-FYHJQES5.js +28 -0
- package/dist/loader-FYHJQES5.js.map +7 -0
- package/dist/mcp-J332IKT3.js +49 -0
- package/dist/mcp-J332IKT3.js.map +7 -0
- package/dist/{services/mentionProcessor.js → mentionProcessor-EE3XFHCJ.js} +61 -50
- package/dist/mentionProcessor-EE3XFHCJ.js.map +7 -0
- package/dist/messages-EOYQKPGM.js +63 -0
- package/dist/messages-EOYQKPGM.js.map +7 -0
- package/dist/model-FV3JDJKH.js +30 -0
- package/dist/model-FV3JDJKH.js.map +7 -0
- package/dist/openai-RRCWW33N.js +29 -0
- package/dist/openai-RRCWW33N.js.map +7 -0
- package/dist/outputStyles-62Q3VH2J.js +28 -0
- package/dist/outputStyles-62Q3VH2J.js.map +7 -0
- package/dist/package.json +1 -1
- package/dist/pluginRuntime-6ETCZ2LL.js +218 -0
- package/dist/pluginRuntime-6ETCZ2LL.js.map +7 -0
- package/dist/pluginValidation-I4YKUWGS.js +17 -0
- package/dist/pluginValidation-I4YKUWGS.js.map +7 -0
- package/dist/prompts-ZLEKDD77.js +48 -0
- package/dist/prompts-ZLEKDD77.js.map +7 -0
- package/dist/query-VFRJPBGD.js +50 -0
- package/dist/query-VFRJPBGD.js.map +7 -0
- package/dist/responsesStreaming-AW344PQO.js +10 -0
- package/dist/responsesStreaming-AW344PQO.js.map +7 -0
- package/dist/ripgrep-3NTIKQYW.js +17 -0
- package/dist/ripgrep-3NTIKQYW.js.map +7 -0
- package/dist/skillMarketplace-3RXQBVOL.js +37 -0
- package/dist/skillMarketplace-3RXQBVOL.js.map +7 -0
- package/dist/state-P5G6CO5V.js +16 -0
- package/dist/state-P5G6CO5V.js.map +7 -0
- package/dist/theme-3LWP3BG7.js +14 -0
- package/dist/theme-3LWP3BG7.js.map +7 -0
- package/dist/toolPermissionContext-65L65VEZ.js +17 -0
- package/dist/toolPermissionContext-65L65VEZ.js.map +7 -0
- package/dist/toolPermissionSettings-3ROBVTUK.js +18 -0
- package/dist/toolPermissionSettings-3ROBVTUK.js.map +7 -0
- package/dist/tools-RO7HSSE5.js +47 -0
- package/dist/tools-RO7HSSE5.js.map +7 -0
- package/dist/userInput-JSBJRFSK.js +311 -0
- package/dist/userInput-JSBJRFSK.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-CW7AYLVL.js.map} +0 -0
- /package/dist/{components/CustomSelect/theme.js.map → autoUpdater-ITPIHCOI.js.map} +0 -0
- /package/dist/{types/common.d.js.map → chunk-JC6NCUG5.js.map} +0 -0
- /package/dist/{types/conversation.js.map → commands-2BF2CJ3A.js.map} +0 -0
- /package/dist/{types/logs.js.map → config-RUSD6G5Y.js.map} +0 -0
- /package/dist/{types/modelCapabilities.js.map → context-6FXPETYH.js.map} +0 -0
- /package/dist/{types/notebook.js.map → costTracker-6SL26FDB.js.map} +0 -0
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { default as React, useCallback } from "react";
|
|
2
|
-
import { useNotifyAfterTimeout } from "../../hooks/useNotifyAfterTimeout.js";
|
|
3
|
-
import { BinaryFeedbackView } from "./BinaryFeedbackView.js";
|
|
4
|
-
import {
|
|
5
|
-
getBinaryFeedbackResultForChoice,
|
|
6
|
-
logBinaryFeedbackEvent
|
|
7
|
-
} from "./utils.js";
|
|
8
|
-
import { PRODUCT_NAME } from "../../constants/product.js";
|
|
9
|
-
function BinaryFeedback({
|
|
10
|
-
m1,
|
|
11
|
-
m2,
|
|
12
|
-
resolve,
|
|
13
|
-
debug,
|
|
14
|
-
erroredToolUseIDs,
|
|
15
|
-
inProgressToolUseIDs,
|
|
16
|
-
normalizedMessages,
|
|
17
|
-
tools,
|
|
18
|
-
unresolvedToolUseIDs,
|
|
19
|
-
verbose
|
|
20
|
-
}) {
|
|
21
|
-
const onChoose = useCallback(
|
|
22
|
-
(choice) => {
|
|
23
|
-
logBinaryFeedbackEvent(m1, m2, choice);
|
|
24
|
-
resolve(getBinaryFeedbackResultForChoice(m1, m2, choice));
|
|
25
|
-
},
|
|
26
|
-
[m1, m2, resolve]
|
|
27
|
-
);
|
|
28
|
-
useNotifyAfterTimeout(
|
|
29
|
-
`${PRODUCT_NAME} needs your input on a response comparison`
|
|
30
|
-
);
|
|
31
|
-
return /* @__PURE__ */ React.createElement(
|
|
32
|
-
BinaryFeedbackView,
|
|
33
|
-
{
|
|
34
|
-
debug,
|
|
35
|
-
erroredToolUseIDs,
|
|
36
|
-
inProgressToolUseIDs,
|
|
37
|
-
m1,
|
|
38
|
-
m2,
|
|
39
|
-
normalizedMessages,
|
|
40
|
-
tools,
|
|
41
|
-
unresolvedToolUseIDs,
|
|
42
|
-
verbose,
|
|
43
|
-
onChoose
|
|
44
|
-
}
|
|
45
|
-
);
|
|
46
|
-
}
|
|
47
|
-
export {
|
|
48
|
-
BinaryFeedback
|
|
49
|
-
};
|
|
50
|
-
//# sourceMappingURL=BinaryFeedback.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/binary-feedback/BinaryFeedback.tsx"],
|
|
4
|
-
"sourcesContent": ["import { default as React, useCallback } from 'react'\nimport { useNotifyAfterTimeout } from '../../hooks/useNotifyAfterTimeout'\nimport { AssistantMessage, BinaryFeedbackResult } from '../../query'\nimport type { Tool } from '../../Tool'\nimport type { NormalizedMessage } from '../../utils/messages'\nimport { BinaryFeedbackView } from './BinaryFeedbackView'\nimport {\n type BinaryFeedbackChoose,\n getBinaryFeedbackResultForChoice,\n logBinaryFeedbackEvent,\n} from './utils.js'\nimport { PRODUCT_NAME } from '../../constants/product'\n\ntype Props = {\n m1: AssistantMessage\n m2: AssistantMessage\n resolve: (result: BinaryFeedbackResult) => void\n debug: boolean\n erroredToolUseIDs: Set<string>\n inProgressToolUseIDs: Set<string>\n normalizedMessages: NormalizedMessage[]\n tools: Tool[]\n unresolvedToolUseIDs: Set<string>\n verbose: boolean\n}\n\nexport function BinaryFeedback({\n m1,\n m2,\n resolve,\n debug,\n erroredToolUseIDs,\n inProgressToolUseIDs,\n normalizedMessages,\n tools,\n unresolvedToolUseIDs,\n verbose,\n}: Props): React.ReactNode {\n const onChoose = useCallback<BinaryFeedbackChoose>(\n choice => {\n logBinaryFeedbackEvent(m1, m2, choice)\n resolve(getBinaryFeedbackResultForChoice(m1, m2, choice))\n },\n [m1, m2, resolve],\n )\n useNotifyAfterTimeout(\n `${PRODUCT_NAME} needs your input on a response comparison`,\n )\n return (\n <BinaryFeedbackView\n debug={debug}\n erroredToolUseIDs={erroredToolUseIDs}\n inProgressToolUseIDs={inProgressToolUseIDs}\n m1={m1}\n m2={m2}\n normalizedMessages={normalizedMessages}\n tools={tools}\n unresolvedToolUseIDs={unresolvedToolUseIDs}\n verbose={verbose}\n onChoose={onChoose}\n />\n )\n}\n"],
|
|
5
|
-
"mappings": "AAAA,SAAS,WAAW,OAAO,mBAAmB;AAC9C,SAAS,6BAA6B;AAItC,SAAS,0BAA0B;AACnC;AAAA,EAEE;AAAA,EACA;AAAA,OACK;AACP,SAAS,oBAAoB;AAetB,SAAS,eAAe;AAAA,EAC7B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AACzB,QAAM,WAAW;AAAA,IACf,YAAU;AACR,6BAAuB,IAAI,IAAI,MAAM;AACrC,cAAQ,iCAAiC,IAAI,IAAI,MAAM,CAAC;AAAA,IAC1D;AAAA,IACA,CAAC,IAAI,IAAI,OAAO;AAAA,EAClB;AACA;AAAA,IACE,GAAG,YAAY;AAAA,EACjB;AACA,SACE;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA;AAAA,EACF;AAEJ;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
import { FileEditTool } from "../../tools/FileEditTool/FileEditTool.js";
|
|
2
|
-
import { FileEditToolDiff } from "../permissions/FileEditPermissionRequest/FileEditToolDiff.js";
|
|
3
|
-
import { Message } from "../Message.js";
|
|
4
|
-
import {
|
|
5
|
-
normalizeMessages
|
|
6
|
-
} from "../../utils/messages.js";
|
|
7
|
-
import { useTerminalSize } from "../../hooks/useTerminalSize.js";
|
|
8
|
-
import { FileWriteTool } from "../../tools/FileWriteTool/FileWriteTool.js";
|
|
9
|
-
import { FileWriteToolDiff } from "../permissions/FileWritePermissionRequest/FileWriteToolDiff.js";
|
|
10
|
-
import * as React from "react";
|
|
11
|
-
import { Box } from "ink";
|
|
12
|
-
function BinaryFeedbackOption({
|
|
13
|
-
debug,
|
|
14
|
-
erroredToolUseIDs,
|
|
15
|
-
inProgressToolUseIDs,
|
|
16
|
-
message,
|
|
17
|
-
normalizedMessages,
|
|
18
|
-
tools,
|
|
19
|
-
unresolvedToolUseIDs,
|
|
20
|
-
verbose
|
|
21
|
-
}) {
|
|
22
|
-
const { columns } = useTerminalSize();
|
|
23
|
-
return normalizeMessages([message]).filter((_) => _.type !== "progress").map((_, index) => /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", key: index }, /* @__PURE__ */ React.createElement(
|
|
24
|
-
Message,
|
|
25
|
-
{
|
|
26
|
-
addMargin: false,
|
|
27
|
-
erroredToolUseIDs,
|
|
28
|
-
debug,
|
|
29
|
-
inProgressToolUseIDs,
|
|
30
|
-
message: _,
|
|
31
|
-
messages: normalizedMessages,
|
|
32
|
-
shouldAnimate: false,
|
|
33
|
-
shouldShowDot: true,
|
|
34
|
-
tools,
|
|
35
|
-
unresolvedToolUseIDs,
|
|
36
|
-
verbose,
|
|
37
|
-
width: columns / 2 - 6
|
|
38
|
-
}
|
|
39
|
-
), /* @__PURE__ */ React.createElement(AdditionalContext, { message: _, verbose })));
|
|
40
|
-
}
|
|
41
|
-
function AdditionalContext({
|
|
42
|
-
message,
|
|
43
|
-
verbose
|
|
44
|
-
}) {
|
|
45
|
-
const { columns } = useTerminalSize();
|
|
46
|
-
if (message.type !== "assistant") {
|
|
47
|
-
return null;
|
|
48
|
-
}
|
|
49
|
-
const content = message.message.content[0];
|
|
50
|
-
switch (content.type) {
|
|
51
|
-
case "tool_use":
|
|
52
|
-
switch (content.name) {
|
|
53
|
-
case FileEditTool.name: {
|
|
54
|
-
const input = FileEditTool.inputSchema.safeParse(content.input);
|
|
55
|
-
if (!input.success) {
|
|
56
|
-
return null;
|
|
57
|
-
}
|
|
58
|
-
return /* @__PURE__ */ React.createElement(
|
|
59
|
-
FileEditToolDiff,
|
|
60
|
-
{
|
|
61
|
-
file_path: input.data.file_path,
|
|
62
|
-
new_string: input.data.new_string,
|
|
63
|
-
old_string: input.data.old_string,
|
|
64
|
-
verbose,
|
|
65
|
-
width: columns / 2 - 12
|
|
66
|
-
}
|
|
67
|
-
);
|
|
68
|
-
}
|
|
69
|
-
case FileWriteTool.name: {
|
|
70
|
-
const input = FileWriteTool.inputSchema.safeParse(content.input);
|
|
71
|
-
if (!input.success) {
|
|
72
|
-
return null;
|
|
73
|
-
}
|
|
74
|
-
return /* @__PURE__ */ React.createElement(
|
|
75
|
-
FileWriteToolDiff,
|
|
76
|
-
{
|
|
77
|
-
file_path: input.data.file_path,
|
|
78
|
-
content: input.data.content,
|
|
79
|
-
verbose,
|
|
80
|
-
width: columns / 2 - 12
|
|
81
|
-
}
|
|
82
|
-
);
|
|
83
|
-
}
|
|
84
|
-
default:
|
|
85
|
-
return null;
|
|
86
|
-
}
|
|
87
|
-
default:
|
|
88
|
-
return null;
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
export {
|
|
92
|
-
BinaryFeedbackOption
|
|
93
|
-
};
|
|
94
|
-
//# sourceMappingURL=BinaryFeedbackOption.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/binary-feedback/BinaryFeedbackOption.tsx"],
|
|
4
|
-
"sourcesContent": ["import { FileEditTool } from '../../tools/FileEditTool/FileEditTool'\nimport { FileEditToolDiff } from '../permissions/FileEditPermissionRequest/FileEditToolDiff'\nimport { Message } from '../Message'\nimport {\n normalizeMessages,\n type NormalizedMessage,\n} from '../../utils/messages.js'\nimport type { Tool } from '../../Tool'\nimport { useTerminalSize } from '../../hooks/useTerminalSize'\nimport { FileWriteTool } from '../../tools/FileWriteTool/FileWriteTool'\nimport { FileWriteToolDiff } from '../permissions/FileWritePermissionRequest/FileWriteToolDiff'\nimport type { AssistantMessage } from '../../query'\nimport * as React from 'react'\nimport { Box } from 'ink'\n\ntype Props = {\n debug: boolean\n erroredToolUseIDs: Set<string>\n inProgressToolUseIDs: Set<string>\n message: AssistantMessage\n normalizedMessages: NormalizedMessage[]\n tools: Tool[]\n unresolvedToolUseIDs: Set<string>\n verbose: boolean\n}\n\nexport function BinaryFeedbackOption({\n debug,\n erroredToolUseIDs,\n inProgressToolUseIDs,\n message,\n normalizedMessages,\n tools,\n unresolvedToolUseIDs,\n verbose,\n}: Props): React.ReactNode {\n const { columns } = useTerminalSize()\n return normalizeMessages([message])\n .filter(_ => _.type !== 'progress')\n .map((_, index) => (\n <Box flexDirection=\"column\" key={index}>\n <Message\n addMargin={false}\n erroredToolUseIDs={erroredToolUseIDs}\n debug={debug}\n inProgressToolUseIDs={inProgressToolUseIDs}\n message={_}\n messages={normalizedMessages}\n shouldAnimate={false}\n shouldShowDot={true}\n tools={tools}\n unresolvedToolUseIDs={unresolvedToolUseIDs}\n verbose={verbose}\n width={columns / 2 - 6}\n />\n <AdditionalContext message={_} verbose={verbose} />\n </Box>\n ))\n}\n\nfunction AdditionalContext({\n message,\n verbose,\n}: {\n message: NormalizedMessage\n verbose: boolean\n}) {\n const { columns } = useTerminalSize()\n if (message.type !== 'assistant') {\n return null\n }\n const content = message.message.content[0]!\n switch (content.type) {\n case 'tool_use':\n switch (content.name) {\n case FileEditTool.name: {\n const input = FileEditTool.inputSchema.safeParse(content.input)\n if (!input.success) {\n return null\n }\n return (\n <FileEditToolDiff\n file_path={input.data.file_path}\n new_string={input.data.new_string}\n old_string={input.data.old_string}\n verbose={verbose}\n width={columns / 2 - 12}\n />\n )\n }\n case FileWriteTool.name: {\n const input = FileWriteTool.inputSchema.safeParse(content.input)\n if (!input.success) {\n return null\n }\n return (\n <FileWriteToolDiff\n file_path={input.data.file_path}\n content={input.data.content}\n verbose={verbose}\n width={columns / 2 - 12}\n />\n )\n }\n default:\n return null\n }\n default:\n return null\n }\n}\n"],
|
|
5
|
-
"mappings": "AAAA,SAAS,oBAAoB;AAC7B,SAAS,wBAAwB;AACjC,SAAS,eAAe;AACxB;AAAA,EACE;AAAA,OAEK;AAEP,SAAS,uBAAuB;AAChC,SAAS,qBAAqB;AAC9B,SAAS,yBAAyB;AAElC,YAAY,WAAW;AACvB,SAAS,WAAW;AAab,SAAS,qBAAqB;AAAA,EACnC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AACzB,QAAM,EAAE,QAAQ,IAAI,gBAAgB;AACpC,SAAO,kBAAkB,CAAC,OAAO,CAAC,EAC/B,OAAO,OAAK,EAAE,SAAS,UAAU,EACjC,IAAI,CAAC,GAAG,UACP,oCAAC,OAAI,eAAc,UAAS,KAAK,SAC/B;AAAA,IAAC;AAAA;AAAA,MACC,WAAW;AAAA,MACX;AAAA,MACA;AAAA,MACA;AAAA,MACA,SAAS;AAAA,MACT,UAAU;AAAA,MACV,eAAe;AAAA,MACf,eAAe;AAAA,MACf;AAAA,MACA;AAAA,MACA;AAAA,MACA,OAAO,UAAU,IAAI;AAAA;AAAA,EACvB,GACA,oCAAC,qBAAkB,SAAS,GAAG,SAAkB,CACnD,CACD;AACL;AAEA,SAAS,kBAAkB;AAAA,EACzB;AAAA,EACA;AACF,GAGG;AACD,QAAM,EAAE,QAAQ,IAAI,gBAAgB;AACpC,MAAI,QAAQ,SAAS,aAAa;AAChC,WAAO;AAAA,EACT;AACA,QAAM,UAAU,QAAQ,QAAQ,QAAQ,CAAC;AACzC,UAAQ,QAAQ,MAAM;AAAA,IACpB,KAAK;AACH,cAAQ,QAAQ,MAAM;AAAA,QACpB,KAAK,aAAa,MAAM;AACtB,gBAAM,QAAQ,aAAa,YAAY,UAAU,QAAQ,KAAK;AAC9D,cAAI,CAAC,MAAM,SAAS;AAClB,mBAAO;AAAA,UACT;AACA,iBACE;AAAA,YAAC;AAAA;AAAA,cACC,WAAW,MAAM,KAAK;AAAA,cACtB,YAAY,MAAM,KAAK;AAAA,cACvB,YAAY,MAAM,KAAK;AAAA,cACvB;AAAA,cACA,OAAO,UAAU,IAAI;AAAA;AAAA,UACvB;AAAA,QAEJ;AAAA,QACA,KAAK,cAAc,MAAM;AACvB,gBAAM,QAAQ,cAAc,YAAY,UAAU,QAAQ,KAAK;AAC/D,cAAI,CAAC,MAAM,SAAS;AAClB,mBAAO;AAAA,UACT;AACA,iBACE;AAAA,YAAC;AAAA;AAAA,cACC,WAAW,MAAM,KAAK;AAAA,cACtB,SAAS,MAAM,KAAK;AAAA,cACpB;AAAA,cACA,OAAO,UAAU,IAAI;AAAA;AAAA,UACvB;AAAA,QAEJ;AAAA,QACA;AACE,iBAAO;AAAA,MACX;AAAA,IACF;AACE,aAAO;AAAA,EACX;AACF;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
import chalk from "chalk";
|
|
2
|
-
import { Box, Text, useInput } from "ink";
|
|
3
|
-
import Link from "ink-link";
|
|
4
|
-
import React, { useState } from "react";
|
|
5
|
-
import { getTheme } from "../../utils/theme.js";
|
|
6
|
-
import { Select } from "../CustomSelect/select.js";
|
|
7
|
-
import { BinaryFeedbackOption } from "./BinaryFeedbackOption.js";
|
|
8
|
-
import { useExitOnCtrlCD } from "../../hooks/useExitOnCtrlCD.js";
|
|
9
|
-
import { PRODUCT_NAME } from "../../constants/product.js";
|
|
10
|
-
const HELP_URL = "https://go/cli-feedback";
|
|
11
|
-
function getOptions() {
|
|
12
|
-
return [
|
|
13
|
-
{
|
|
14
|
-
// This option combines the follow user intents:
|
|
15
|
-
// - The two options look about equally good to me
|
|
16
|
-
// - I don't feel confident enough to choose
|
|
17
|
-
// - I don't want to choose right now
|
|
18
|
-
label: "Choose for me",
|
|
19
|
-
value: "no-preference"
|
|
20
|
-
},
|
|
21
|
-
{
|
|
22
|
-
label: "Left option looks better",
|
|
23
|
-
value: "prefer-left"
|
|
24
|
-
},
|
|
25
|
-
{
|
|
26
|
-
label: "Right option looks better",
|
|
27
|
-
value: "prefer-right"
|
|
28
|
-
},
|
|
29
|
-
{
|
|
30
|
-
label: `Neither, and tell ${PRODUCT_NAME} what to do differently (${chalk.bold.hex(getTheme().warning)("esc")})`,
|
|
31
|
-
value: "neither"
|
|
32
|
-
}
|
|
33
|
-
];
|
|
34
|
-
}
|
|
35
|
-
function BinaryFeedbackView({
|
|
36
|
-
m1,
|
|
37
|
-
m2,
|
|
38
|
-
onChoose,
|
|
39
|
-
debug,
|
|
40
|
-
erroredToolUseIDs,
|
|
41
|
-
inProgressToolUseIDs,
|
|
42
|
-
normalizedMessages,
|
|
43
|
-
tools,
|
|
44
|
-
unresolvedToolUseIDs,
|
|
45
|
-
verbose
|
|
46
|
-
}) {
|
|
47
|
-
const theme = getTheme();
|
|
48
|
-
const [focused, setFocus] = useState("no-preference");
|
|
49
|
-
const [focusValue, setFocusValue] = useState(void 0);
|
|
50
|
-
const exitState = useExitOnCtrlCD(() => process.exit(1));
|
|
51
|
-
useInput((_input, key) => {
|
|
52
|
-
if (key.leftArrow) {
|
|
53
|
-
setFocusValue("prefer-left");
|
|
54
|
-
} else if (key.rightArrow) {
|
|
55
|
-
setFocusValue("prefer-right");
|
|
56
|
-
} else if (key.escape) {
|
|
57
|
-
onChoose?.("neither");
|
|
58
|
-
}
|
|
59
|
-
});
|
|
60
|
-
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
|
|
61
|
-
Box,
|
|
62
|
-
{
|
|
63
|
-
flexDirection: "column",
|
|
64
|
-
height: "100%",
|
|
65
|
-
width: "100%",
|
|
66
|
-
borderStyle: "round",
|
|
67
|
-
borderColor: theme.permission
|
|
68
|
-
},
|
|
69
|
-
/* @__PURE__ */ React.createElement(Box, { width: "100%", justifyContent: "space-between", paddingX: 1 }, /* @__PURE__ */ React.createElement(Text, { bold: true, color: theme.permission }, "[ANT-ONLY] Help train ", PRODUCT_NAME), /* @__PURE__ */ React.createElement(Text, null, /* @__PURE__ */ React.createElement(Link, { url: HELP_URL }, "[?]"))),
|
|
70
|
-
/* @__PURE__ */ React.createElement(Box, { flexDirection: "row", width: "100%", flexGrow: 1, paddingTop: 1 }, /* @__PURE__ */ React.createElement(
|
|
71
|
-
Box,
|
|
72
|
-
{
|
|
73
|
-
flexDirection: "column",
|
|
74
|
-
flexGrow: 1,
|
|
75
|
-
flexBasis: 1,
|
|
76
|
-
gap: 1,
|
|
77
|
-
borderStyle: focused === "prefer-left" ? "bold" : "single",
|
|
78
|
-
borderColor: focused === "prefer-left" ? theme.success : theme.secondaryBorder,
|
|
79
|
-
marginRight: 1,
|
|
80
|
-
padding: 1
|
|
81
|
-
},
|
|
82
|
-
/* @__PURE__ */ React.createElement(
|
|
83
|
-
BinaryFeedbackOption,
|
|
84
|
-
{
|
|
85
|
-
erroredToolUseIDs,
|
|
86
|
-
debug,
|
|
87
|
-
inProgressToolUseIDs,
|
|
88
|
-
message: m1,
|
|
89
|
-
normalizedMessages,
|
|
90
|
-
tools,
|
|
91
|
-
unresolvedToolUseIDs,
|
|
92
|
-
verbose
|
|
93
|
-
}
|
|
94
|
-
)
|
|
95
|
-
), /* @__PURE__ */ React.createElement(
|
|
96
|
-
Box,
|
|
97
|
-
{
|
|
98
|
-
flexDirection: "column",
|
|
99
|
-
flexGrow: 1,
|
|
100
|
-
flexBasis: 1,
|
|
101
|
-
gap: 1,
|
|
102
|
-
borderStyle: focused === "prefer-right" ? "bold" : "single",
|
|
103
|
-
borderColor: focused === "prefer-right" ? theme.success : theme.secondaryBorder,
|
|
104
|
-
marginLeft: 1,
|
|
105
|
-
padding: 1
|
|
106
|
-
},
|
|
107
|
-
/* @__PURE__ */ React.createElement(
|
|
108
|
-
BinaryFeedbackOption,
|
|
109
|
-
{
|
|
110
|
-
erroredToolUseIDs,
|
|
111
|
-
debug,
|
|
112
|
-
inProgressToolUseIDs,
|
|
113
|
-
message: m2,
|
|
114
|
-
normalizedMessages,
|
|
115
|
-
tools,
|
|
116
|
-
unresolvedToolUseIDs,
|
|
117
|
-
verbose
|
|
118
|
-
}
|
|
119
|
-
)
|
|
120
|
-
)),
|
|
121
|
-
/* @__PURE__ */ React.createElement(Box, { flexDirection: "column", paddingTop: 1, paddingX: 1 }, /* @__PURE__ */ React.createElement(Text, null, "How do you want to proceed?"), /* @__PURE__ */ React.createElement(
|
|
122
|
-
Select,
|
|
123
|
-
{
|
|
124
|
-
options: getOptions(),
|
|
125
|
-
onFocus: setFocus,
|
|
126
|
-
focusValue,
|
|
127
|
-
onChange: onChoose
|
|
128
|
-
}
|
|
129
|
-
))
|
|
130
|
-
), exitState.pending ? /* @__PURE__ */ React.createElement(Box, { marginLeft: 3 }, /* @__PURE__ */ React.createElement(Text, { dimColor: true }, "Press ", exitState.keyName, " again to exit")) : (
|
|
131
|
-
// Render a blank line so that the UI doesn't reflow when the exit message is shown
|
|
132
|
-
/* @__PURE__ */ React.createElement(Text, null, " ")
|
|
133
|
-
));
|
|
134
|
-
}
|
|
135
|
-
export {
|
|
136
|
-
BinaryFeedbackView,
|
|
137
|
-
getOptions
|
|
138
|
-
};
|
|
139
|
-
//# sourceMappingURL=BinaryFeedbackView.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/binary-feedback/BinaryFeedbackView.tsx"],
|
|
4
|
-
"sourcesContent": ["import { Option, SelectProps } from '@inkjs/ui'\nimport chalk from 'chalk'\nimport { Box, Text, useInput } from 'ink'\nimport Link from 'ink-link'\nimport React, { useState } from 'react'\nimport { getTheme } from '../../utils/theme'\nimport { Select } from '../CustomSelect/select'\nimport type { Tool } from '../../Tool'\nimport type { NormalizedMessage } from '../../utils/messages'\nimport { BinaryFeedbackOption } from './BinaryFeedbackOption'\nimport type { AssistantMessage } from '../../query'\nimport type { BinaryFeedbackChoose } from './utils'\nimport { useExitOnCtrlCD } from '../../hooks/useExitOnCtrlCD'\nimport { BinaryFeedbackChoice } from './utils'\nimport { PRODUCT_NAME } from '../../constants/product'\n\nconst HELP_URL = 'https://go/cli-feedback'\n\ntype BinaryFeedbackOption = Option & { value: BinaryFeedbackChoice }\n\n// Make options a function to avoid early theme access during module initialization\nexport function getOptions(): BinaryFeedbackOption[] {\n return [\n {\n // This option combines the follow user intents:\n // - The two options look about equally good to me\n // - I don't feel confident enough to choose\n // - I don't want to choose right now\n label: 'Choose for me',\n value: 'no-preference',\n },\n {\n label: 'Left option looks better',\n value: 'prefer-left',\n },\n {\n label: 'Right option looks better',\n value: 'prefer-right',\n },\n {\n label: `Neither, and tell ${PRODUCT_NAME} what to do differently (${chalk.bold.hex(getTheme().warning)('esc')})`,\n value: 'neither',\n },\n ]\n}\n\ntype Props = {\n m1: AssistantMessage\n m2: AssistantMessage\n onChoose?: BinaryFeedbackChoose\n debug: boolean\n erroredToolUseIDs: Set<string>\n inProgressToolUseIDs: Set<string>\n normalizedMessages: NormalizedMessage[]\n tools: Tool[]\n unresolvedToolUseIDs: Set<string>\n verbose: boolean\n}\n\nexport function BinaryFeedbackView({\n m1,\n m2,\n onChoose,\n debug,\n erroredToolUseIDs,\n inProgressToolUseIDs,\n normalizedMessages,\n tools,\n unresolvedToolUseIDs,\n verbose,\n}: Props) {\n const theme = getTheme()\n const [focused, setFocus] = useState('no-preference')\n const [focusValue, setFocusValue] = useState<string | undefined>(undefined)\n const exitState = useExitOnCtrlCD(() => process.exit(1))\n\n useInput((_input, key) => {\n if (key.leftArrow) {\n setFocusValue('prefer-left')\n } else if (key.rightArrow) {\n setFocusValue('prefer-right')\n } else if (key.escape) {\n onChoose?.('neither')\n }\n })\n\n return (\n <>\n <Box\n flexDirection=\"column\"\n height=\"100%\"\n width=\"100%\"\n borderStyle=\"round\"\n borderColor={theme.permission}\n >\n <Box width=\"100%\" justifyContent=\"space-between\" paddingX={1}>\n <Text bold color={theme.permission}>\n [ANT-ONLY] Help train {PRODUCT_NAME}\n </Text>\n <Text>\n <Link url={HELP_URL}>[?]</Link>\n </Text>\n </Box>\n <Box flexDirection=\"row\" width=\"100%\" flexGrow={1} paddingTop={1}>\n <Box\n flexDirection=\"column\"\n flexGrow={1}\n flexBasis={1}\n gap={1}\n borderStyle={focused === 'prefer-left' ? 'bold' : 'single'}\n borderColor={\n focused === 'prefer-left' ? theme.success : theme.secondaryBorder\n }\n marginRight={1}\n padding={1}\n >\n <BinaryFeedbackOption\n erroredToolUseIDs={erroredToolUseIDs}\n debug={debug}\n inProgressToolUseIDs={inProgressToolUseIDs}\n message={m1}\n normalizedMessages={normalizedMessages}\n tools={tools}\n unresolvedToolUseIDs={unresolvedToolUseIDs}\n verbose={verbose}\n />\n </Box>\n <Box\n flexDirection=\"column\"\n flexGrow={1}\n flexBasis={1}\n gap={1}\n borderStyle={focused === 'prefer-right' ? 'bold' : 'single'}\n borderColor={\n focused === 'prefer-right' ? theme.success : theme.secondaryBorder\n }\n marginLeft={1}\n padding={1}\n >\n <BinaryFeedbackOption\n erroredToolUseIDs={erroredToolUseIDs}\n debug={debug}\n inProgressToolUseIDs={inProgressToolUseIDs}\n message={m2}\n normalizedMessages={normalizedMessages}\n tools={tools}\n unresolvedToolUseIDs={unresolvedToolUseIDs}\n verbose={verbose}\n />\n </Box>\n </Box>\n <Box flexDirection=\"column\" paddingTop={1} paddingX={1}>\n <Text>How do you want to proceed?</Text>\n <Select\n options={getOptions()}\n onFocus={setFocus}\n focusValue={focusValue}\n onChange={onChoose as SelectProps['onChange']}\n />\n </Box>\n </Box>\n {exitState.pending ? (\n <Box marginLeft={3}>\n <Text dimColor>Press {exitState.keyName} again to exit</Text>\n </Box>\n ) : (\n // Render a blank line so that the UI doesn't reflow when the exit message is shown\n <Text> </Text>\n )}\n </>\n )\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
import { MAIN_QUERY_TEMPERATURE } from "../../services/claude.js";
|
|
2
|
-
import { getDynamicConfig, logEvent } from "../../services/statsig.js";
|
|
3
|
-
import { isEqual, zip } from "lodash-es";
|
|
4
|
-
import { getGitState } from "../../utils/git.js";
|
|
5
|
-
async function getBinaryFeedbackStatsigConfig() {
|
|
6
|
-
return await getDynamicConfig("tengu-binary-feedback-config", {
|
|
7
|
-
sampleFrequency: 0
|
|
8
|
-
});
|
|
9
|
-
}
|
|
10
|
-
function getMessageBlockSequence(m) {
|
|
11
|
-
return m.message.content.map((cb) => {
|
|
12
|
-
if (cb.type === "text") return "text";
|
|
13
|
-
if (cb.type === "tool_use") return cb.name;
|
|
14
|
-
return cb.type;
|
|
15
|
-
});
|
|
16
|
-
}
|
|
17
|
-
async function logBinaryFeedbackEvent(m1, m2, choice) {
|
|
18
|
-
const modelA = m1.message.model;
|
|
19
|
-
const modelB = m2.message.model;
|
|
20
|
-
const gitState = await getGitState();
|
|
21
|
-
logEvent("tengu_binary_feedback", {
|
|
22
|
-
msg_id_A: m1.message.id,
|
|
23
|
-
msg_id_B: m2.message.id,
|
|
24
|
-
choice: {
|
|
25
|
-
"prefer-left": m1.message.id,
|
|
26
|
-
"prefer-right": m2.message.id,
|
|
27
|
-
neither: void 0,
|
|
28
|
-
"no-preference": void 0
|
|
29
|
-
}[choice],
|
|
30
|
-
choiceStr: choice,
|
|
31
|
-
gitHead: gitState?.commitHash,
|
|
32
|
-
gitBranch: gitState?.branchName,
|
|
33
|
-
gitRepoRemoteUrl: gitState?.remoteUrl || void 0,
|
|
34
|
-
gitRepoIsHeadOnRemote: gitState?.isHeadOnRemote?.toString(),
|
|
35
|
-
gitRepoIsClean: gitState?.isClean?.toString(),
|
|
36
|
-
modelA,
|
|
37
|
-
modelB,
|
|
38
|
-
temperatureA: String(MAIN_QUERY_TEMPERATURE),
|
|
39
|
-
temperatureB: String(MAIN_QUERY_TEMPERATURE),
|
|
40
|
-
seqA: String(getMessageBlockSequence(m1)),
|
|
41
|
-
seqB: String(getMessageBlockSequence(m2))
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
async function logBinaryFeedbackSamplingDecision(decision, reason) {
|
|
45
|
-
logEvent("tengu_binary_feedback_sampling_decision", {
|
|
46
|
-
decision: decision.toString(),
|
|
47
|
-
reason
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
async function logBinaryFeedbackDisplayDecision(decision, m1, m2, reason) {
|
|
51
|
-
logEvent("tengu_binary_feedback_display_decision", {
|
|
52
|
-
decision: decision.toString(),
|
|
53
|
-
reason,
|
|
54
|
-
msg_id_A: m1.message.id,
|
|
55
|
-
msg_id_B: m2.message.id,
|
|
56
|
-
seqA: String(getMessageBlockSequence(m1)),
|
|
57
|
-
seqB: String(getMessageBlockSequence(m2))
|
|
58
|
-
});
|
|
59
|
-
}
|
|
60
|
-
function textContentBlocksEqual(cb1, cb2) {
|
|
61
|
-
return cb1.text === cb2.text;
|
|
62
|
-
}
|
|
63
|
-
function contentBlocksEqual(cb1, cb2) {
|
|
64
|
-
if (cb1.type !== cb2.type) {
|
|
65
|
-
return false;
|
|
66
|
-
}
|
|
67
|
-
if (cb1.type === "text") {
|
|
68
|
-
return textContentBlocksEqual(cb1, cb2);
|
|
69
|
-
}
|
|
70
|
-
cb2 = cb2;
|
|
71
|
-
return cb1.name === cb2.name && isEqual(cb1.input, cb2.input);
|
|
72
|
-
}
|
|
73
|
-
function allContentBlocksEqual(content1, content2) {
|
|
74
|
-
if (content1.length !== content2.length) {
|
|
75
|
-
return false;
|
|
76
|
-
}
|
|
77
|
-
return zip(content1, content2).every(
|
|
78
|
-
([cb1, cb2]) => contentBlocksEqual(cb1, cb2)
|
|
79
|
-
);
|
|
80
|
-
}
|
|
81
|
-
async function shouldUseBinaryFeedback() {
|
|
82
|
-
if (process.env.DISABLE_BINARY_FEEDBACK) {
|
|
83
|
-
logBinaryFeedbackSamplingDecision(false, "disabled_by_env_var");
|
|
84
|
-
return false;
|
|
85
|
-
}
|
|
86
|
-
if (process.env.FORCE_BINARY_FEEDBACK) {
|
|
87
|
-
logBinaryFeedbackSamplingDecision(true, "forced_by_env_var");
|
|
88
|
-
return true;
|
|
89
|
-
}
|
|
90
|
-
if (process.env.USER_TYPE !== "ant") {
|
|
91
|
-
logBinaryFeedbackSamplingDecision(false, "not_ant");
|
|
92
|
-
return false;
|
|
93
|
-
}
|
|
94
|
-
if (process.env.NODE_ENV === "test") {
|
|
95
|
-
logBinaryFeedbackSamplingDecision(false, "test");
|
|
96
|
-
return false;
|
|
97
|
-
}
|
|
98
|
-
const config = await getBinaryFeedbackStatsigConfig();
|
|
99
|
-
if (config.sampleFrequency === 0) {
|
|
100
|
-
logBinaryFeedbackSamplingDecision(false, "top_level_frequency_zero");
|
|
101
|
-
return false;
|
|
102
|
-
}
|
|
103
|
-
if (Math.random() > config.sampleFrequency) {
|
|
104
|
-
logBinaryFeedbackSamplingDecision(false, "top_level_frequency_rng");
|
|
105
|
-
return false;
|
|
106
|
-
}
|
|
107
|
-
logBinaryFeedbackSamplingDecision(true);
|
|
108
|
-
return true;
|
|
109
|
-
}
|
|
110
|
-
function messagePairValidForBinaryFeedback(m1, m2) {
|
|
111
|
-
const logPass = () => logBinaryFeedbackDisplayDecision(true, m1, m2);
|
|
112
|
-
const logFail = (reason) => logBinaryFeedbackDisplayDecision(false, m1, m2, reason);
|
|
113
|
-
const nonThinkingBlocks1 = m1.message.content.filter(
|
|
114
|
-
(b) => b.type !== "thinking" && b.type !== "redacted_thinking"
|
|
115
|
-
);
|
|
116
|
-
const nonThinkingBlocks2 = m2.message.content.filter(
|
|
117
|
-
(b) => b.type !== "thinking" && b.type !== "redacted_thinking"
|
|
118
|
-
);
|
|
119
|
-
const hasToolUse = nonThinkingBlocks1.some((b) => b.type === "tool_use") || nonThinkingBlocks2.some((b) => b.type === "tool_use");
|
|
120
|
-
if (!hasToolUse) {
|
|
121
|
-
if (allContentBlocksEqual(nonThinkingBlocks1, nonThinkingBlocks2)) {
|
|
122
|
-
logFail("contents_identical");
|
|
123
|
-
return false;
|
|
124
|
-
}
|
|
125
|
-
logPass();
|
|
126
|
-
return true;
|
|
127
|
-
}
|
|
128
|
-
if (allContentBlocksEqual(
|
|
129
|
-
nonThinkingBlocks1.filter((b) => b.type === "tool_use"),
|
|
130
|
-
nonThinkingBlocks2.filter((b) => b.type === "tool_use")
|
|
131
|
-
)) {
|
|
132
|
-
logFail("contents_identical");
|
|
133
|
-
return false;
|
|
134
|
-
}
|
|
135
|
-
logPass();
|
|
136
|
-
return true;
|
|
137
|
-
}
|
|
138
|
-
function getBinaryFeedbackResultForChoice(m1, m2, choice) {
|
|
139
|
-
switch (choice) {
|
|
140
|
-
case "prefer-left":
|
|
141
|
-
return { message: m1, shouldSkipPermissionCheck: true };
|
|
142
|
-
case "prefer-right":
|
|
143
|
-
return { message: m2, shouldSkipPermissionCheck: true };
|
|
144
|
-
case "no-preference":
|
|
145
|
-
return {
|
|
146
|
-
message: Math.random() < 0.5 ? m1 : m2,
|
|
147
|
-
shouldSkipPermissionCheck: false
|
|
148
|
-
};
|
|
149
|
-
case "neither":
|
|
150
|
-
return { message: null, shouldSkipPermissionCheck: false };
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
export {
|
|
154
|
-
getBinaryFeedbackResultForChoice,
|
|
155
|
-
logBinaryFeedbackDisplayDecision,
|
|
156
|
-
logBinaryFeedbackEvent,
|
|
157
|
-
logBinaryFeedbackSamplingDecision,
|
|
158
|
-
messagePairValidForBinaryFeedback,
|
|
159
|
-
shouldUseBinaryFeedback
|
|
160
|
-
};
|
|
161
|
-
//# sourceMappingURL=utils.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/binary-feedback/utils.ts"],
|
|
4
|
-
"sourcesContent": ["import { TextBlock, ToolUseBlock } from '@anthropic-ai/sdk/resources/index.mjs'\nimport { AssistantMessage, BinaryFeedbackResult } from '../../query'\nimport { MAIN_QUERY_TEMPERATURE } from '../../services/claude'\nimport { getDynamicConfig, logEvent } from '../../services/statsig'\n\nimport { isEqual, zip } from 'lodash-es'\nimport { getGitState } from '../../utils/git'\n\nexport type BinaryFeedbackChoice =\n | 'prefer-left'\n | 'prefer-right'\n | 'neither'\n | 'no-preference'\n\nexport type BinaryFeedbackChoose = (choice: BinaryFeedbackChoice) => void\n\ntype BinaryFeedbackConfig = {\n sampleFrequency: number\n}\n\nasync function getBinaryFeedbackStatsigConfig(): Promise<BinaryFeedbackConfig> {\n return await getDynamicConfig('tengu-binary-feedback-config', {\n sampleFrequency: 0,\n })\n}\n\nfunction getMessageBlockSequence(m: AssistantMessage) {\n return m.message.content.map(cb => {\n if (cb.type === 'text') return 'text'\n if (cb.type === 'tool_use') return cb.name\n return cb.type // Handle other block types like 'thinking' or 'redacted_thinking'\n })\n}\n\nexport async function logBinaryFeedbackEvent(\n m1: AssistantMessage,\n m2: AssistantMessage,\n choice: BinaryFeedbackChoice,\n): Promise<void> {\n const modelA = m1.message.model\n const modelB = m2.message.model\n const gitState = await getGitState()\n logEvent('tengu_binary_feedback', {\n msg_id_A: m1.message.id,\n msg_id_B: m2.message.id,\n choice: {\n 'prefer-left': m1.message.id,\n 'prefer-right': m2.message.id,\n neither: undefined,\n 'no-preference': undefined,\n }[choice],\n choiceStr: choice,\n gitHead: gitState?.commitHash,\n gitBranch: gitState?.branchName,\n gitRepoRemoteUrl: gitState?.remoteUrl || undefined,\n gitRepoIsHeadOnRemote: gitState?.isHeadOnRemote?.toString(),\n gitRepoIsClean: gitState?.isClean?.toString(),\n modelA,\n modelB,\n temperatureA: String(MAIN_QUERY_TEMPERATURE),\n temperatureB: String(MAIN_QUERY_TEMPERATURE),\n seqA: String(getMessageBlockSequence(m1)),\n seqB: String(getMessageBlockSequence(m2)),\n })\n}\n\nexport async function logBinaryFeedbackSamplingDecision(\n decision: boolean,\n reason?: string,\n): Promise<void> {\n logEvent('tengu_binary_feedback_sampling_decision', {\n decision: decision.toString(),\n reason,\n })\n}\n\nexport async function logBinaryFeedbackDisplayDecision(\n decision: boolean,\n m1: AssistantMessage,\n m2: AssistantMessage,\n reason?: string,\n): Promise<void> {\n logEvent('tengu_binary_feedback_display_decision', {\n decision: decision.toString(),\n reason,\n msg_id_A: m1.message.id,\n msg_id_B: m2.message.id,\n seqA: String(getMessageBlockSequence(m1)),\n seqB: String(getMessageBlockSequence(m2)),\n })\n}\n\nfunction textContentBlocksEqual(cb1: TextBlock, cb2: TextBlock): boolean {\n return cb1.text === cb2.text\n}\n\nfunction contentBlocksEqual(\n cb1: TextBlock | ToolUseBlock,\n cb2: TextBlock | ToolUseBlock,\n): boolean {\n if (cb1.type !== cb2.type) {\n return false\n }\n if (cb1.type === 'text') {\n return textContentBlocksEqual(cb1, cb2 as TextBlock)\n }\n cb2 = cb2 as ToolUseBlock\n return cb1.name === cb2.name && isEqual(cb1.input, cb2.input)\n}\n\nfunction allContentBlocksEqual(\n content1: (TextBlock | ToolUseBlock)[],\n content2: (TextBlock | ToolUseBlock)[],\n): boolean {\n if (content1.length !== content2.length) {\n return false\n }\n return zip(content1, content2).every(([cb1, cb2]) =>\n contentBlocksEqual(cb1!, cb2!),\n )\n}\n\nexport async function shouldUseBinaryFeedback(): Promise<boolean> {\n if (process.env.DISABLE_BINARY_FEEDBACK) {\n logBinaryFeedbackSamplingDecision(false, 'disabled_by_env_var')\n return false\n }\n if (process.env.FORCE_BINARY_FEEDBACK) {\n logBinaryFeedbackSamplingDecision(true, 'forced_by_env_var')\n return true\n }\n if (process.env.USER_TYPE !== 'ant') {\n logBinaryFeedbackSamplingDecision(false, 'not_ant')\n return false\n }\n if (process.env.NODE_ENV === 'test') {\n // Binary feedback breaks a couple tests related to checking for permission,\n // so we have to disable it in tests at the risk of hiding bugs\n logBinaryFeedbackSamplingDecision(false, 'test')\n return false\n }\n\n const config = await getBinaryFeedbackStatsigConfig()\n if (config.sampleFrequency === 0) {\n logBinaryFeedbackSamplingDecision(false, 'top_level_frequency_zero')\n return false\n }\n if (Math.random() > config.sampleFrequency) {\n logBinaryFeedbackSamplingDecision(false, 'top_level_frequency_rng')\n return false\n }\n logBinaryFeedbackSamplingDecision(true)\n return true\n}\n\nexport function messagePairValidForBinaryFeedback(\n m1: AssistantMessage,\n m2: AssistantMessage,\n): boolean {\n const logPass = () => logBinaryFeedbackDisplayDecision(true, m1, m2)\n const logFail = (reason: string) =>\n logBinaryFeedbackDisplayDecision(false, m1, m2, reason)\n\n // Ignore thinking blocks, on the assumption that users don't find them very relevant\n // compared to other content types\n const nonThinkingBlocks1 = m1.message.content.filter(\n b => b.type !== 'thinking' && b.type !== 'redacted_thinking',\n )\n const nonThinkingBlocks2 = m2.message.content.filter(\n b => b.type !== 'thinking' && b.type !== 'redacted_thinking',\n )\n const hasToolUse =\n nonThinkingBlocks1.some(b => b.type === 'tool_use') ||\n nonThinkingBlocks2.some(b => b.type === 'tool_use')\n\n // If they're all text blocks, compare those\n if (!hasToolUse) {\n if (allContentBlocksEqual(nonThinkingBlocks1, nonThinkingBlocks2)) {\n logFail('contents_identical')\n return false\n }\n logPass()\n return true\n }\n\n // If there are tools, they're the most material difference between the messages.\n // Only show binary feedback if there's a tool use difference, ignoring text.\n if (\n allContentBlocksEqual(\n nonThinkingBlocks1.filter(b => b.type === 'tool_use'),\n nonThinkingBlocks2.filter(b => b.type === 'tool_use'),\n )\n ) {\n logFail('contents_identical')\n return false\n }\n\n logPass()\n return true\n}\n\nexport function getBinaryFeedbackResultForChoice(\n m1: AssistantMessage,\n m2: AssistantMessage,\n choice: BinaryFeedbackChoice,\n): BinaryFeedbackResult {\n switch (choice) {\n case 'prefer-left':\n return { message: m1, shouldSkipPermissionCheck: true }\n case 'prefer-right':\n return { message: m2, shouldSkipPermissionCheck: true }\n case 'no-preference':\n return {\n message: Math.random() < 0.5 ? m1 : m2,\n shouldSkipPermissionCheck: false,\n }\n case 'neither':\n return { message: null, shouldSkipPermissionCheck: false }\n }\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import * as React from "react";
|
|
2
|
-
import BashToolResultMessage from "../../tools/BashTool/BashToolResultMessage.js";
|
|
3
|
-
import { extractTag } from "../../utils/messages.js";
|
|
4
|
-
function AssistantBashOutputMessage({
|
|
5
|
-
content,
|
|
6
|
-
verbose
|
|
7
|
-
}) {
|
|
8
|
-
const stdout = extractTag(content, "bash-stdout") ?? "";
|
|
9
|
-
const stderr = extractTag(content, "bash-stderr") ?? "";
|
|
10
|
-
const stdoutLines = stdout.split("\n").length;
|
|
11
|
-
const stderrLines = stderr.split("\n").length;
|
|
12
|
-
return /* @__PURE__ */ React.createElement(
|
|
13
|
-
BashToolResultMessage,
|
|
14
|
-
{
|
|
15
|
-
content: { stdout, stdoutLines, stderr, stderrLines },
|
|
16
|
-
verbose: !!verbose
|
|
17
|
-
}
|
|
18
|
-
);
|
|
19
|
-
}
|
|
20
|
-
export {
|
|
21
|
-
AssistantBashOutputMessage
|
|
22
|
-
};
|
|
23
|
-
//# sourceMappingURL=AssistantBashOutputMessage.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/messages/AssistantBashOutputMessage.tsx"],
|
|
4
|
-
"sourcesContent": ["import * as React from 'react'\nimport BashToolResultMessage from '../../tools/BashTool/BashToolResultMessage'\nimport { extractTag } from '../../utils/messages'\n\nexport function AssistantBashOutputMessage({\n content,\n verbose,\n}: {\n content: string\n verbose?: boolean\n}): React.ReactNode {\n const stdout = extractTag(content, 'bash-stdout') ?? ''\n const stderr = extractTag(content, 'bash-stderr') ?? ''\n const stdoutLines = stdout.split('\\n').length\n const stderrLines = stderr.split('\\n').length\n return (\n <BashToolResultMessage\n content={{ stdout, stdoutLines, stderr, stderrLines }}\n verbose={!!verbose}\n />\n )\n}\n"],
|
|
5
|
-
"mappings": "AAAA,YAAY,WAAW;AACvB,OAAO,2BAA2B;AAClC,SAAS,kBAAkB;AAEpB,SAAS,2BAA2B;AAAA,EACzC;AAAA,EACA;AACF,GAGoB;AAClB,QAAM,SAAS,WAAW,SAAS,aAAa,KAAK;AACrD,QAAM,SAAS,WAAW,SAAS,aAAa,KAAK;AACrD,QAAM,cAAc,OAAO,MAAM,IAAI,EAAE;AACvC,QAAM,cAAc,OAAO,MAAM,IAAI,EAAE;AACvC,SACE;AAAA,IAAC;AAAA;AAAA,MACC,SAAS,EAAE,QAAQ,aAAa,QAAQ,YAAY;AAAA,MACpD,SAAS,CAAC,CAAC;AAAA;AAAA,EACb;AAEJ;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import * as React from "react";
|
|
2
|
-
import { extractTag } from "../../utils/messages.js";
|
|
3
|
-
import { getTheme } from "../../utils/theme.js";
|
|
4
|
-
import { Box, Text } from "ink";
|
|
5
|
-
function AssistantLocalCommandOutputMessage({
|
|
6
|
-
content
|
|
7
|
-
}) {
|
|
8
|
-
const stdout = extractTag(content, "local-command-stdout");
|
|
9
|
-
const stderr = extractTag(content, "local-command-stderr");
|
|
10
|
-
if (!stdout && !stderr) {
|
|
11
|
-
return [];
|
|
12
|
-
}
|
|
13
|
-
const theme = getTheme();
|
|
14
|
-
let insides = [
|
|
15
|
-
format(stdout?.trim(), theme.text),
|
|
16
|
-
format(stderr?.trim(), theme.error)
|
|
17
|
-
].filter(Boolean);
|
|
18
|
-
if (insides.length === 0) {
|
|
19
|
-
insides = [
|
|
20
|
-
/* @__PURE__ */ React.createElement(React.Fragment, { key: "0" }, /* @__PURE__ */ React.createElement(Text, null, "(No output)"))
|
|
21
|
-
];
|
|
22
|
-
}
|
|
23
|
-
return [
|
|
24
|
-
/* @__PURE__ */ React.createElement(Box, { key: "0", gap: 1 }, /* @__PURE__ */ React.createElement(Box, null, /* @__PURE__ */ React.createElement(Text, { color: theme.secondaryText }, " ", "\u23BF ")), insides.map((_, index) => /* @__PURE__ */ React.createElement(Box, { key: index, flexDirection: "column" }, _)))
|
|
25
|
-
];
|
|
26
|
-
}
|
|
27
|
-
function format(content, color) {
|
|
28
|
-
if (!content) {
|
|
29
|
-
return null;
|
|
30
|
-
}
|
|
31
|
-
return /* @__PURE__ */ React.createElement(Text, { color }, content);
|
|
32
|
-
}
|
|
33
|
-
export {
|
|
34
|
-
AssistantLocalCommandOutputMessage
|
|
35
|
-
};
|
|
36
|
-
//# sourceMappingURL=AssistantLocalCommandOutputMessage.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/messages/AssistantLocalCommandOutputMessage.tsx"],
|
|
4
|
-
"sourcesContent": ["import * as React from 'react'\nimport { extractTag } from '../../utils/messages'\nimport { getTheme } from '../../utils/theme'\nimport { Box, Text } from 'ink'\n\nexport function AssistantLocalCommandOutputMessage({\n content,\n}: {\n content: string\n}): React.ReactNode[] {\n const stdout = extractTag(content, 'local-command-stdout')\n const stderr = extractTag(content, 'local-command-stderr')\n if (!stdout && !stderr) {\n return []\n }\n const theme = getTheme()\n let insides = [\n format(stdout?.trim(), theme.text),\n format(stderr?.trim(), theme.error),\n ].filter(Boolean)\n\n if (insides.length === 0) {\n insides = [\n <React.Fragment key=\"0\">\n <Text>(No output)</Text>\n </React.Fragment>\n ]\n }\n\n return [\n <Box key=\"0\" gap={1}>\n <Box>\n <Text color={theme.secondaryText}>{' '}\u23BF </Text>\n </Box>\n {insides.map((_, index) => (\n <Box key={index} flexDirection=\"column\">\n {_}\n </Box>\n ))}\n </Box>,\n ]\n}\n\nfunction format(content: string | undefined, color: string): React.ReactNode {\n if (!content) {\n return null\n }\n return <Text color={color}>{content}</Text>\n}\n"],
|
|
5
|
-
"mappings": "AAAA,YAAY,WAAW;AACvB,SAAS,kBAAkB;AAC3B,SAAS,gBAAgB;AACzB,SAAS,KAAK,YAAY;AAEnB,SAAS,mCAAmC;AAAA,EACjD;AACF,GAEsB;AACpB,QAAM,SAAS,WAAW,SAAS,sBAAsB;AACzD,QAAM,SAAS,WAAW,SAAS,sBAAsB;AACzD,MAAI,CAAC,UAAU,CAAC,QAAQ;AACtB,WAAO,CAAC;AAAA,EACV;AACA,QAAM,QAAQ,SAAS;AACvB,MAAI,UAAU;AAAA,IACZ,OAAO,QAAQ,KAAK,GAAG,MAAM,IAAI;AAAA,IACjC,OAAO,QAAQ,KAAK,GAAG,MAAM,KAAK;AAAA,EACpC,EAAE,OAAO,OAAO;AAEhB,MAAI,QAAQ,WAAW,GAAG;AACxB,cAAU;AAAA,MACR,oCAAC,MAAM,UAAN,EAAe,KAAI,OAClB,oCAAC,YAAK,aAAW,CACnB;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AAAA,IACL,oCAAC,OAAI,KAAI,KAAI,KAAK,KAChB,oCAAC,WACC,oCAAC,QAAK,OAAO,MAAM,iBAAgB,MAAK,SAAE,CAC5C,GACC,QAAQ,IAAI,CAAC,GAAG,UACf,oCAAC,OAAI,KAAK,OAAO,eAAc,YAC5B,CACH,CACD,CACH;AAAA,EACF;AACF;AAEA,SAAS,OAAO,SAA6B,OAAgC;AAC3E,MAAI,CAAC,SAAS;AACZ,WAAO;AAAA,EACT;AACA,SAAO,oCAAC,QAAK,SAAe,OAAQ;AACtC;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import React from "react";
|
|
2
|
-
import { Box, Text } from "ink";
|
|
3
|
-
import { getTheme } from "../../utils/theme.js";
|
|
4
|
-
function AssistantRedactedThinkingMessage({
|
|
5
|
-
addMargin = false
|
|
6
|
-
}) {
|
|
7
|
-
return /* @__PURE__ */ React.createElement(Box, { marginTop: addMargin ? 1 : 0 }, /* @__PURE__ */ React.createElement(Text, { color: getTheme().secondaryText, italic: true }, "\u273B Thinking\u2026"));
|
|
8
|
-
}
|
|
9
|
-
export {
|
|
10
|
-
AssistantRedactedThinkingMessage
|
|
11
|
-
};
|
|
12
|
-
//# sourceMappingURL=AssistantRedactedThinkingMessage.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/messages/AssistantRedactedThinkingMessage.tsx"],
|
|
4
|
-
"sourcesContent": ["import React from 'react'\nimport { Box, Text } from 'ink'\nimport { getTheme } from '../../utils/theme'\n\ntype Props = {\n addMargin: boolean\n}\n\nexport function AssistantRedactedThinkingMessage({\n addMargin = false,\n}: Props): React.ReactNode {\n return (\n <Box marginTop={addMargin ? 1 : 0}>\n <Text color={getTheme().secondaryText} italic>\n \u273B Thinking\u2026\n </Text>\n </Box>\n )\n}\n"],
|
|
5
|
-
"mappings": "AAAA,OAAO,WAAW;AAClB,SAAS,KAAK,YAAY;AAC1B,SAAS,gBAAgB;AAMlB,SAAS,iCAAiC;AAAA,EAC/C,YAAY;AACd,GAA2B;AACzB,SACE,oCAAC,OAAI,WAAW,YAAY,IAAI,KAC9B,oCAAC,QAAK,OAAO,SAAS,EAAE,eAAe,QAAM,QAAC,uBAE9C,CACF;AAEJ;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|