@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.
Files changed (725) hide show
  1. package/README.md +25 -388
  2. package/cli-acp.js +82 -0
  3. package/cli.js +89 -79
  4. package/dist/REPL-GIU4ZIXM.js +42 -0
  5. package/dist/acp-H3VJ77YG.js +1357 -0
  6. package/dist/acp-H3VJ77YG.js.map +7 -0
  7. package/dist/agentsValidate-XP3CFN6F.js +373 -0
  8. package/dist/agentsValidate-XP3CFN6F.js.map +7 -0
  9. package/dist/ask-3G5H5KD5.js +125 -0
  10. package/dist/ask-3G5H5KD5.js.map +7 -0
  11. package/dist/autoUpdater-DNRMJWFQ.js +17 -0
  12. package/dist/chunk-2KWKUXLT.js +490 -0
  13. package/dist/chunk-2KWKUXLT.js.map +7 -0
  14. package/dist/chunk-2PMO2FS2.js +1097 -0
  15. package/dist/chunk-2PMO2FS2.js.map +7 -0
  16. package/dist/chunk-3RUXVV4S.js +23 -0
  17. package/dist/chunk-3RUXVV4S.js.map +7 -0
  18. package/dist/chunk-3TXNP6HH.js +240 -0
  19. package/dist/chunk-3TXNP6HH.js.map +7 -0
  20. package/dist/chunk-4GAIJGRH.js +472 -0
  21. package/dist/chunk-4GAIJGRH.js.map +7 -0
  22. package/dist/chunk-4RTX4AG4.js +249 -0
  23. package/dist/chunk-4RTX4AG4.js.map +7 -0
  24. package/dist/chunk-54DNHKOD.js +511 -0
  25. package/dist/chunk-54DNHKOD.js.map +7 -0
  26. package/dist/chunk-67PY5IX6.js +34 -0
  27. package/dist/chunk-67PY5IX6.js.map +7 -0
  28. package/dist/chunk-6DRDLOLP.js +2613 -0
  29. package/dist/chunk-6DRDLOLP.js.map +7 -0
  30. package/dist/chunk-7CQVZNQV.js +1609 -0
  31. package/dist/chunk-7CQVZNQV.js.map +7 -0
  32. package/dist/chunk-ABLVTESJ.js +19 -0
  33. package/dist/chunk-ABLVTESJ.js.map +7 -0
  34. package/dist/{utils/config.js → chunk-AIMIPK4B.js} +351 -171
  35. package/dist/chunk-AIMIPK4B.js.map +7 -0
  36. package/dist/{utils/autoUpdater.js → chunk-BHGTA6JQ.js} +38 -21
  37. package/dist/chunk-BHGTA6JQ.js.map +7 -0
  38. package/dist/chunk-CIG63V4E.js +72 -0
  39. package/dist/chunk-CIG63V4E.js.map +7 -0
  40. package/dist/chunk-E6YNABER.js +24 -0
  41. package/dist/chunk-E6YNABER.js.map +7 -0
  42. package/dist/chunk-EH34V7CY.js +191 -0
  43. package/dist/chunk-EH34V7CY.js.map +7 -0
  44. package/dist/{cost-tracker.js → chunk-EZXMVTDU.js} +51 -32
  45. package/dist/chunk-EZXMVTDU.js.map +7 -0
  46. package/dist/chunk-FH5CHM6L.js +148 -0
  47. package/dist/chunk-FH5CHM6L.js.map +7 -0
  48. package/dist/chunk-G6I7XROM.js +138 -0
  49. package/dist/chunk-G6I7XROM.js.map +7 -0
  50. package/dist/chunk-HN4E4UUQ.js +96 -0
  51. package/dist/chunk-HN4E4UUQ.js.map +7 -0
  52. package/dist/chunk-HSPVVDIW.js +30198 -0
  53. package/dist/chunk-HSPVVDIW.js.map +7 -0
  54. package/dist/{services/systemReminder.js → chunk-IE2CG2TV.js} +221 -59
  55. package/dist/chunk-IE2CG2TV.js.map +7 -0
  56. package/dist/chunk-JC6NCUG5.js +11 -0
  57. package/dist/chunk-K2MI4TPB.js +1256 -0
  58. package/dist/chunk-K2MI4TPB.js.map +7 -0
  59. package/dist/chunk-KAA5BGMQ.js +12 -0
  60. package/dist/chunk-KAA5BGMQ.js.map +7 -0
  61. package/dist/chunk-MN77D2F7.js +2931 -0
  62. package/dist/chunk-MN77D2F7.js.map +7 -0
  63. package/dist/chunk-NPFOMITO.js +21 -0
  64. package/dist/chunk-NPFOMITO.js.map +7 -0
  65. package/dist/chunk-NQLEUHMS.js +196 -0
  66. package/dist/chunk-NQLEUHMS.js.map +7 -0
  67. package/dist/chunk-OIFQB3S4.js +515 -0
  68. package/dist/chunk-OIFQB3S4.js.map +7 -0
  69. package/dist/chunk-OWTG2W3A.js +164 -0
  70. package/dist/chunk-OWTG2W3A.js.map +7 -0
  71. package/dist/chunk-OZNRLY3E.js +735 -0
  72. package/dist/chunk-OZNRLY3E.js.map +7 -0
  73. package/dist/{utils/debugLogger.js → chunk-QYFKRZQC.js} +107 -204
  74. package/dist/chunk-QYFKRZQC.js.map +7 -0
  75. package/dist/chunk-S3J2TLV6.js +16 -0
  76. package/dist/chunk-S3J2TLV6.js.map +7 -0
  77. package/dist/chunk-S6HRABTA.js +95 -0
  78. package/dist/chunk-S6HRABTA.js.map +7 -0
  79. package/dist/{utils/theme.js → chunk-SDGKPKDK.js} +28 -6
  80. package/dist/chunk-SDGKPKDK.js.map +7 -0
  81. package/dist/chunk-SRZZFAS7.js +766 -0
  82. package/dist/chunk-SRZZFAS7.js.map +7 -0
  83. package/dist/chunk-UKHTVRJM.js +47 -0
  84. package/dist/chunk-UKHTVRJM.js.map +7 -0
  85. package/dist/chunk-UYXEDKOZ.js +24 -0
  86. package/dist/chunk-UYXEDKOZ.js.map +7 -0
  87. package/dist/chunk-VBXVYQYY.js +145 -0
  88. package/dist/chunk-VBXVYQYY.js.map +7 -0
  89. package/dist/chunk-WVHORZQ5.js +17 -0
  90. package/dist/chunk-WVHORZQ5.js.map +7 -0
  91. package/dist/chunk-WWUWDNWW.js +49 -0
  92. package/dist/chunk-WWUWDNWW.js.map +7 -0
  93. package/dist/{utils/model.js → chunk-Z33T5YN5.js} +194 -227
  94. package/dist/chunk-Z33T5YN5.js.map +7 -0
  95. package/dist/{services/openai.js → chunk-ZQU3TXLC.js} +168 -234
  96. package/dist/chunk-ZQU3TXLC.js.map +7 -0
  97. package/dist/cli-SRV2INSL.js +3917 -0
  98. package/dist/cli-SRV2INSL.js.map +7 -0
  99. package/dist/commands-TWH6PGVG.js +46 -0
  100. package/dist/config-6ZMBCL23.js +81 -0
  101. package/dist/context-JQIOOI4W.js +30 -0
  102. package/dist/costTracker-6SL26FDB.js +19 -0
  103. package/dist/customCommands-DNEJS3ZU.js +25 -0
  104. package/dist/customCommands-DNEJS3ZU.js.map +7 -0
  105. package/dist/env-OFAXZ3XG.js +22 -0
  106. package/dist/env-OFAXZ3XG.js.map +7 -0
  107. package/dist/index.js +34 -5
  108. package/dist/index.js.map +4 -4
  109. package/dist/kodeAgentSessionId-X6XWQW7B.js +13 -0
  110. package/dist/kodeAgentSessionId-X6XWQW7B.js.map +7 -0
  111. package/dist/kodeAgentSessionLoad-6N27AC5K.js +18 -0
  112. package/dist/kodeAgentSessionLoad-6N27AC5K.js.map +7 -0
  113. package/dist/kodeAgentSessionResume-HUSAEO24.js +16 -0
  114. package/dist/kodeAgentSessionResume-HUSAEO24.js.map +7 -0
  115. package/dist/kodeAgentStreamJson-NXFN7TXH.js +13 -0
  116. package/dist/kodeAgentStreamJson-NXFN7TXH.js.map +7 -0
  117. package/dist/kodeAgentStreamJsonSession-GRWG3SPE.js +131 -0
  118. package/dist/kodeAgentStreamJsonSession-GRWG3SPE.js.map +7 -0
  119. package/dist/kodeAgentStructuredStdio-HGWJT7CU.js +10 -0
  120. package/dist/kodeAgentStructuredStdio-HGWJT7CU.js.map +7 -0
  121. package/dist/kodeHooks-TDMXFWSO.js +36 -0
  122. package/dist/kodeHooks-TDMXFWSO.js.map +7 -0
  123. package/dist/llm-XVXWYOHK.js +3118 -0
  124. package/dist/llm-XVXWYOHK.js.map +7 -0
  125. package/dist/llmLazy-7TD5N7XP.js +15 -0
  126. package/dist/llmLazy-7TD5N7XP.js.map +7 -0
  127. package/dist/loader-AUXIJTY6.js +28 -0
  128. package/dist/loader-AUXIJTY6.js.map +7 -0
  129. package/dist/mcp-BXJ3K7NZ.js +49 -0
  130. package/dist/mcp-BXJ3K7NZ.js.map +7 -0
  131. package/dist/{services/mentionProcessor.js → mentionProcessor-YD7YXYGF.js} +61 -50
  132. package/dist/mentionProcessor-YD7YXYGF.js.map +7 -0
  133. package/dist/messages-OFUJSPRV.js +63 -0
  134. package/dist/messages-OFUJSPRV.js.map +7 -0
  135. package/dist/model-KPYCXWBK.js +30 -0
  136. package/dist/model-KPYCXWBK.js.map +7 -0
  137. package/dist/openai-5G5D5Q4B.js +29 -0
  138. package/dist/openai-5G5D5Q4B.js.map +7 -0
  139. package/dist/outputStyles-HLDXFQK3.js +28 -0
  140. package/dist/outputStyles-HLDXFQK3.js.map +7 -0
  141. package/dist/package.json +1 -1
  142. package/dist/pluginRuntime-FPTKK6NY.js +218 -0
  143. package/dist/pluginRuntime-FPTKK6NY.js.map +7 -0
  144. package/dist/pluginValidation-DSFXZ4GF.js +17 -0
  145. package/dist/pluginValidation-DSFXZ4GF.js.map +7 -0
  146. package/dist/prompts-LWLAJRS2.js +48 -0
  147. package/dist/prompts-LWLAJRS2.js.map +7 -0
  148. package/dist/query-HVPWL27C.js +50 -0
  149. package/dist/query-HVPWL27C.js.map +7 -0
  150. package/dist/responsesStreaming-AW344PQO.js +10 -0
  151. package/dist/responsesStreaming-AW344PQO.js.map +7 -0
  152. package/dist/ripgrep-YOPCY2GO.js +17 -0
  153. package/dist/ripgrep-YOPCY2GO.js.map +7 -0
  154. package/dist/skillMarketplace-PSNKDINM.js +37 -0
  155. package/dist/skillMarketplace-PSNKDINM.js.map +7 -0
  156. package/dist/state-KNRWP3FO.js +16 -0
  157. package/dist/state-KNRWP3FO.js.map +7 -0
  158. package/dist/theme-7S2QN2FO.js +14 -0
  159. package/dist/theme-7S2QN2FO.js.map +7 -0
  160. package/dist/toolPermissionContext-65L65VEZ.js +17 -0
  161. package/dist/toolPermissionContext-65L65VEZ.js.map +7 -0
  162. package/dist/toolPermissionSettings-GPOBH4IV.js +18 -0
  163. package/dist/toolPermissionSettings-GPOBH4IV.js.map +7 -0
  164. package/dist/tools-FZU2FZBD.js +47 -0
  165. package/dist/tools-FZU2FZBD.js.map +7 -0
  166. package/dist/userInput-VHNBN2MW.js +311 -0
  167. package/dist/userInput-VHNBN2MW.js.map +7 -0
  168. package/dist/uuid-QN2CNKKN.js +9 -0
  169. package/dist/uuid-QN2CNKKN.js.map +7 -0
  170. package/package.json +43 -14
  171. package/scripts/binary-utils.cjs +62 -0
  172. package/scripts/cli-acp-wrapper.cjs +82 -0
  173. package/scripts/cli-wrapper.cjs +105 -0
  174. package/scripts/postinstall.js +135 -9
  175. package/LICENSE +0 -201
  176. package/README.zh-CN.md +0 -312
  177. package/dist/ProjectOnboarding.js +0 -99
  178. package/dist/ProjectOnboarding.js.map +0 -7
  179. package/dist/Tool.js +0 -1
  180. package/dist/commands/agents.js +0 -2087
  181. package/dist/commands/agents.js.map +0 -7
  182. package/dist/commands/approvedTools.js +0 -36
  183. package/dist/commands/approvedTools.js.map +0 -7
  184. package/dist/commands/bug.js +0 -21
  185. package/dist/commands/bug.js.map +0 -7
  186. package/dist/commands/clear.js +0 -37
  187. package/dist/commands/clear.js.map +0 -7
  188. package/dist/commands/compact.js +0 -104
  189. package/dist/commands/compact.js.map +0 -7
  190. package/dist/commands/config.js +0 -20
  191. package/dist/commands/config.js.map +0 -7
  192. package/dist/commands/cost.js +0 -19
  193. package/dist/commands/cost.js.map +0 -7
  194. package/dist/commands/ctx_viz.js +0 -152
  195. package/dist/commands/ctx_viz.js.map +0 -7
  196. package/dist/commands/doctor.js +0 -25
  197. package/dist/commands/doctor.js.map +0 -7
  198. package/dist/commands/help.js +0 -20
  199. package/dist/commands/help.js.map +0 -7
  200. package/dist/commands/init.js +0 -38
  201. package/dist/commands/init.js.map +0 -7
  202. package/dist/commands/listen.js +0 -37
  203. package/dist/commands/listen.js.map +0 -7
  204. package/dist/commands/login.js +0 -37
  205. package/dist/commands/login.js.map +0 -7
  206. package/dist/commands/logout.js +0 -33
  207. package/dist/commands/logout.js.map +0 -7
  208. package/dist/commands/mcp.js +0 -34
  209. package/dist/commands/mcp.js.map +0 -7
  210. package/dist/commands/model.js +0 -41
  211. package/dist/commands/model.js.map +0 -7
  212. package/dist/commands/modelstatus.js +0 -21
  213. package/dist/commands/modelstatus.js.map +0 -7
  214. package/dist/commands/onboarding.js +0 -36
  215. package/dist/commands/onboarding.js.map +0 -7
  216. package/dist/commands/pr_comments.js +0 -61
  217. package/dist/commands/pr_comments.js.map +0 -7
  218. package/dist/commands/refreshCommands.js +0 -37
  219. package/dist/commands/refreshCommands.js.map +0 -7
  220. package/dist/commands/release-notes.js +0 -30
  221. package/dist/commands/release-notes.js.map +0 -7
  222. package/dist/commands/resume.js +0 -35
  223. package/dist/commands/resume.js.map +0 -7
  224. package/dist/commands/review.js +0 -51
  225. package/dist/commands/review.js.map +0 -7
  226. package/dist/commands/terminalSetup.js +0 -163
  227. package/dist/commands/terminalSetup.js.map +0 -7
  228. package/dist/commands.js +0 -84
  229. package/dist/commands.js.map +0 -7
  230. package/dist/components/ApproveApiKey.js +0 -74
  231. package/dist/components/ApproveApiKey.js.map +0 -7
  232. package/dist/components/AsciiLogo.js +0 -12
  233. package/dist/components/AsciiLogo.js.map +0 -7
  234. package/dist/components/AutoUpdater.js +0 -74
  235. package/dist/components/AutoUpdater.js.map +0 -7
  236. package/dist/components/Bug.js +0 -147
  237. package/dist/components/Bug.js.map +0 -7
  238. package/dist/components/Config.js +0 -166
  239. package/dist/components/Config.js.map +0 -7
  240. package/dist/components/ConsoleOAuthFlow.js +0 -188
  241. package/dist/components/ConsoleOAuthFlow.js.map +0 -7
  242. package/dist/components/Cost.js +0 -13
  243. package/dist/components/Cost.js.map +0 -7
  244. package/dist/components/CostThresholdDialog.js +0 -38
  245. package/dist/components/CostThresholdDialog.js.map +0 -7
  246. package/dist/components/CustomSelect/option-map.js +0 -32
  247. package/dist/components/CustomSelect/option-map.js.map +0 -7
  248. package/dist/components/CustomSelect/select-option.js +0 -34
  249. package/dist/components/CustomSelect/select-option.js.map +0 -7
  250. package/dist/components/CustomSelect/select.js +0 -64
  251. package/dist/components/CustomSelect/select.js.map +0 -7
  252. package/dist/components/CustomSelect/theme.js +0 -1
  253. package/dist/components/CustomSelect/use-select-state.js +0 -220
  254. package/dist/components/CustomSelect/use-select-state.js.map +0 -7
  255. package/dist/components/CustomSelect/use-select.js +0 -21
  256. package/dist/components/CustomSelect/use-select.js.map +0 -7
  257. package/dist/components/FallbackToolUseRejectedMessage.js +0 -11
  258. package/dist/components/FallbackToolUseRejectedMessage.js.map +0 -7
  259. package/dist/components/FileEditToolUpdatedMessage.js +0 -32
  260. package/dist/components/FileEditToolUpdatedMessage.js.map +0 -7
  261. package/dist/components/Help.js +0 -41
  262. package/dist/components/Help.js.map +0 -7
  263. package/dist/components/HighlightedCode.js +0 -30
  264. package/dist/components/HighlightedCode.js.map +0 -7
  265. package/dist/components/InvalidConfigDialog.js +0 -83
  266. package/dist/components/InvalidConfigDialog.js.map +0 -7
  267. package/dist/components/Link.js +0 -18
  268. package/dist/components/Link.js.map +0 -7
  269. package/dist/components/LogSelector.js +0 -50
  270. package/dist/components/LogSelector.js.map +0 -7
  271. package/dist/components/Logo.js +0 -94
  272. package/dist/components/Logo.js.map +0 -7
  273. package/dist/components/MCPServerApprovalDialog.js +0 -79
  274. package/dist/components/MCPServerApprovalDialog.js.map +0 -7
  275. package/dist/components/MCPServerDialogCopy.js +0 -11
  276. package/dist/components/MCPServerDialogCopy.js.map +0 -7
  277. package/dist/components/MCPServerMultiselectDialog.js +0 -80
  278. package/dist/components/MCPServerMultiselectDialog.js.map +0 -7
  279. package/dist/components/Message.js +0 -146
  280. package/dist/components/Message.js.map +0 -7
  281. package/dist/components/MessageResponse.js +0 -9
  282. package/dist/components/MessageResponse.js.map +0 -7
  283. package/dist/components/MessageSelector.js +0 -133
  284. package/dist/components/MessageSelector.js.map +0 -7
  285. package/dist/components/ModeIndicator.js +0 -38
  286. package/dist/components/ModeIndicator.js.map +0 -7
  287. package/dist/components/ModelConfig.js +0 -208
  288. package/dist/components/ModelConfig.js.map +0 -7
  289. package/dist/components/ModelListManager.js +0 -140
  290. package/dist/components/ModelListManager.js.map +0 -7
  291. package/dist/components/ModelSelector.js +0 -1985
  292. package/dist/components/ModelSelector.js.map +0 -7
  293. package/dist/components/ModelStatusDisplay.js +0 -87
  294. package/dist/components/ModelStatusDisplay.js.map +0 -7
  295. package/dist/components/Onboarding.js +0 -153
  296. package/dist/components/Onboarding.js.map +0 -7
  297. package/dist/components/PressEnterToContinue.js +0 -10
  298. package/dist/components/PressEnterToContinue.js.map +0 -7
  299. package/dist/components/PromptInput.js +0 -488
  300. package/dist/components/PromptInput.js.map +0 -7
  301. package/dist/components/SentryErrorBoundary.js +0 -27
  302. package/dist/components/SentryErrorBoundary.js.map +0 -7
  303. package/dist/components/Spinner.js +0 -101
  304. package/dist/components/Spinner.js.map +0 -7
  305. package/dist/components/StickerRequestForm.js +0 -7
  306. package/dist/components/StickerRequestForm.js.map +0 -7
  307. package/dist/components/StructuredDiff.js +0 -148
  308. package/dist/components/StructuredDiff.js.map +0 -7
  309. package/dist/components/TextInput.js +0 -100
  310. package/dist/components/TextInput.js.map +0 -7
  311. package/dist/components/TodoItem.js +0 -35
  312. package/dist/components/TodoItem.js.map +0 -7
  313. package/dist/components/TokenWarning.js +0 -19
  314. package/dist/components/TokenWarning.js.map +0 -7
  315. package/dist/components/ToolUseLoader.js +0 -24
  316. package/dist/components/ToolUseLoader.js.map +0 -7
  317. package/dist/components/TrustDialog.js +0 -76
  318. package/dist/components/TrustDialog.js.map +0 -7
  319. package/dist/components/binary-feedback/BinaryFeedback.js +0 -50
  320. package/dist/components/binary-feedback/BinaryFeedback.js.map +0 -7
  321. package/dist/components/binary-feedback/BinaryFeedbackOption.js +0 -94
  322. package/dist/components/binary-feedback/BinaryFeedbackOption.js.map +0 -7
  323. package/dist/components/binary-feedback/BinaryFeedbackView.js +0 -139
  324. package/dist/components/binary-feedback/BinaryFeedbackView.js.map +0 -7
  325. package/dist/components/binary-feedback/utils.js +0 -161
  326. package/dist/components/binary-feedback/utils.js.map +0 -7
  327. package/dist/components/messages/AssistantBashOutputMessage.js +0 -23
  328. package/dist/components/messages/AssistantBashOutputMessage.js.map +0 -7
  329. package/dist/components/messages/AssistantLocalCommandOutputMessage.js +0 -36
  330. package/dist/components/messages/AssistantLocalCommandOutputMessage.js.map +0 -7
  331. package/dist/components/messages/AssistantRedactedThinkingMessage.js +0 -12
  332. package/dist/components/messages/AssistantRedactedThinkingMessage.js.map +0 -7
  333. package/dist/components/messages/AssistantTextMessage.js +0 -78
  334. package/dist/components/messages/AssistantTextMessage.js.map +0 -7
  335. package/dist/components/messages/AssistantThinkingMessage.js +0 -27
  336. package/dist/components/messages/AssistantThinkingMessage.js.map +0 -7
  337. package/dist/components/messages/AssistantToolUseMessage.js +0 -91
  338. package/dist/components/messages/AssistantToolUseMessage.js.map +0 -7
  339. package/dist/components/messages/TaskProgressMessage.js +0 -11
  340. package/dist/components/messages/TaskProgressMessage.js.map +0 -7
  341. package/dist/components/messages/TaskToolMessage.js +0 -39
  342. package/dist/components/messages/TaskToolMessage.js.map +0 -7
  343. package/dist/components/messages/UserBashInputMessage.js +0 -18
  344. package/dist/components/messages/UserBashInputMessage.js.map +0 -7
  345. package/dist/components/messages/UserCommandMessage.js +0 -20
  346. package/dist/components/messages/UserCommandMessage.js.map +0 -7
  347. package/dist/components/messages/UserKodingInputMessage.js +0 -18
  348. package/dist/components/messages/UserKodingInputMessage.js.map +0 -7
  349. package/dist/components/messages/UserPromptMessage.js +0 -20
  350. package/dist/components/messages/UserPromptMessage.js.map +0 -7
  351. package/dist/components/messages/UserTextMessage.js +0 -25
  352. package/dist/components/messages/UserTextMessage.js.map +0 -7
  353. package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +0 -10
  354. package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js.map +0 -7
  355. package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js +0 -15
  356. package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js.map +0 -7
  357. package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js +0 -25
  358. package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js.map +0 -7
  359. package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js +0 -47
  360. package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js.map +0 -7
  361. package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +0 -23
  362. package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js.map +0 -7
  363. package/dist/components/messages/UserToolResultMessage/utils.js +0 -42
  364. package/dist/components/messages/UserToolResultMessage/utils.js.map +0 -7
  365. package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js +0 -112
  366. package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js.map +0 -7
  367. package/dist/components/permissions/FallbackPermissionRequest.js +0 -131
  368. package/dist/components/permissions/FallbackPermissionRequest.js.map +0 -7
  369. package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +0 -159
  370. package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js.map +0 -7
  371. package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js +0 -58
  372. package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js.map +0 -7
  373. package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +0 -153
  374. package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js.map +0 -7
  375. package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +0 -70
  376. package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js.map +0 -7
  377. package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +0 -212
  378. package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js.map +0 -7
  379. package/dist/components/permissions/PermissionRequest.js +0 -70
  380. package/dist/components/permissions/PermissionRequest.js.map +0 -7
  381. package/dist/components/permissions/PermissionRequestTitle.js +0 -52
  382. package/dist/components/permissions/PermissionRequestTitle.js.map +0 -7
  383. package/dist/components/permissions/hooks.js +0 -28
  384. package/dist/components/permissions/hooks.js.map +0 -7
  385. package/dist/components/permissions/toolUseOptions.js +0 -46
  386. package/dist/components/permissions/toolUseOptions.js.map +0 -7
  387. package/dist/components/permissions/utils.js +0 -21
  388. package/dist/components/permissions/utils.js.map +0 -7
  389. package/dist/constants/betas.js +0 -11
  390. package/dist/constants/betas.js.map +0 -7
  391. package/dist/constants/claude-asterisk-ascii-art.js +0 -242
  392. package/dist/constants/claude-asterisk-ascii-art.js.map +0 -7
  393. package/dist/constants/figures.js +0 -6
  394. package/dist/constants/figures.js.map +0 -7
  395. package/dist/constants/keys.js +0 -7
  396. package/dist/constants/keys.js.map +0 -7
  397. package/dist/constants/macros.js +0 -13
  398. package/dist/constants/macros.js.map +0 -7
  399. package/dist/constants/modelCapabilities.js +0 -154
  400. package/dist/constants/modelCapabilities.js.map +0 -7
  401. package/dist/constants/models.js +0 -1034
  402. package/dist/constants/models.js.map +0 -7
  403. package/dist/constants/oauth.js +0 -18
  404. package/dist/constants/oauth.js.map +0 -7
  405. package/dist/constants/product.js +0 -26
  406. package/dist/constants/product.js.map +0 -7
  407. package/dist/constants/prompts.js +0 -168
  408. package/dist/constants/prompts.js.map +0 -7
  409. package/dist/constants/releaseNotes.js +0 -9
  410. package/dist/constants/releaseNotes.js.map +0 -7
  411. package/dist/context/PermissionContext.js +0 -111
  412. package/dist/context/PermissionContext.js.map +0 -7
  413. package/dist/context.js +0 -259
  414. package/dist/context.js.map +0 -7
  415. package/dist/cost-tracker.js.map +0 -7
  416. package/dist/entrypoints/cli.js +0 -1107
  417. package/dist/entrypoints/cli.js.map +0 -7
  418. package/dist/entrypoints/mcp.js +0 -150
  419. package/dist/entrypoints/mcp.js.map +0 -7
  420. package/dist/history.js +0 -25
  421. package/dist/history.js.map +0 -7
  422. package/dist/hooks/useApiKeyVerification.js +0 -12
  423. package/dist/hooks/useApiKeyVerification.js.map +0 -7
  424. package/dist/hooks/useArrowKeyHistory.js +0 -50
  425. package/dist/hooks/useArrowKeyHistory.js.map +0 -7
  426. package/dist/hooks/useCanUseTool.js +0 -112
  427. package/dist/hooks/useCanUseTool.js.map +0 -7
  428. package/dist/hooks/useCancelRequest.js +0 -30
  429. package/dist/hooks/useCancelRequest.js.map +0 -7
  430. package/dist/hooks/useDoublePress.js +0 -31
  431. package/dist/hooks/useDoublePress.js.map +0 -7
  432. package/dist/hooks/useExitOnCtrlCD.js +0 -26
  433. package/dist/hooks/useExitOnCtrlCD.js.map +0 -7
  434. package/dist/hooks/useInterval.js +0 -18
  435. package/dist/hooks/useInterval.js.map +0 -7
  436. package/dist/hooks/useLogMessages.js +0 -14
  437. package/dist/hooks/useLogMessages.js.map +0 -7
  438. package/dist/hooks/useLogStartupTime.js +0 -15
  439. package/dist/hooks/useLogStartupTime.js.map +0 -7
  440. package/dist/hooks/useNotifyAfterTimeout.js +0 -42
  441. package/dist/hooks/useNotifyAfterTimeout.js.map +0 -7
  442. package/dist/hooks/usePermissionRequestLogging.js +0 -28
  443. package/dist/hooks/usePermissionRequestLogging.js.map +0 -7
  444. package/dist/hooks/useTerminalSize.js +0 -38
  445. package/dist/hooks/useTerminalSize.js.map +0 -7
  446. package/dist/hooks/useTextInput.js +0 -250
  447. package/dist/hooks/useTextInput.js.map +0 -7
  448. package/dist/hooks/useUnifiedCompletion.js +0 -929
  449. package/dist/hooks/useUnifiedCompletion.js.map +0 -7
  450. package/dist/messages.js +0 -33
  451. package/dist/messages.js.map +0 -7
  452. package/dist/permissions.js +0 -194
  453. package/dist/permissions.js.map +0 -7
  454. package/dist/query.js +0 -492
  455. package/dist/query.js.map +0 -7
  456. package/dist/screens/ConfigureNpmPrefix.js +0 -128
  457. package/dist/screens/ConfigureNpmPrefix.js.map +0 -7
  458. package/dist/screens/Doctor.js +0 -22
  459. package/dist/screens/Doctor.js.map +0 -7
  460. package/dist/screens/LogList.js +0 -55
  461. package/dist/screens/LogList.js.map +0 -7
  462. package/dist/screens/REPL.js +0 -593
  463. package/dist/screens/REPL.js.map +0 -7
  464. package/dist/screens/ResumeConversation.js +0 -56
  465. package/dist/screens/ResumeConversation.js.map +0 -7
  466. package/dist/services/adapters/base.js +0 -29
  467. package/dist/services/adapters/base.js.map +0 -7
  468. package/dist/services/adapters/chatCompletions.js +0 -69
  469. package/dist/services/adapters/chatCompletions.js.map +0 -7
  470. package/dist/services/adapters/responsesAPI.js +0 -126
  471. package/dist/services/adapters/responsesAPI.js.map +0 -7
  472. package/dist/services/browserMocks.js +0 -48
  473. package/dist/services/browserMocks.js.map +0 -7
  474. package/dist/services/claude.js +0 -1605
  475. package/dist/services/claude.js.map +0 -7
  476. package/dist/services/customCommands.js +0 -359
  477. package/dist/services/customCommands.js.map +0 -7
  478. package/dist/services/fileFreshness.js +0 -280
  479. package/dist/services/fileFreshness.js.map +0 -7
  480. package/dist/services/gpt5ConnectionTest.js +0 -248
  481. package/dist/services/gpt5ConnectionTest.js.map +0 -7
  482. package/dist/services/mcpClient.js +0 -435
  483. package/dist/services/mcpClient.js.map +0 -7
  484. package/dist/services/mcpServerApproval.js +0 -55
  485. package/dist/services/mcpServerApproval.js.map +0 -7
  486. package/dist/services/mentionProcessor.js.map +0 -7
  487. package/dist/services/modelAdapterFactory.js +0 -47
  488. package/dist/services/modelAdapterFactory.js.map +0 -7
  489. package/dist/services/notifier.js +0 -35
  490. package/dist/services/notifier.js.map +0 -7
  491. package/dist/services/oauth.js +0 -259
  492. package/dist/services/oauth.js.map +0 -7
  493. package/dist/services/openai.js.map +0 -7
  494. package/dist/services/responseStateManager.js +0 -68
  495. package/dist/services/responseStateManager.js.map +0 -7
  496. package/dist/services/sentry.js +0 -9
  497. package/dist/services/sentry.js.map +0 -7
  498. package/dist/services/statsig.js +0 -112
  499. package/dist/services/statsig.js.map +0 -7
  500. package/dist/services/statsigStorage.js +0 -75
  501. package/dist/services/statsigStorage.js.map +0 -7
  502. package/dist/services/systemReminder.js.map +0 -7
  503. package/dist/services/vcr.js +0 -133
  504. package/dist/services/vcr.js.map +0 -7
  505. package/dist/tools/ArchitectTool/ArchitectTool.js +0 -119
  506. package/dist/tools/ArchitectTool/ArchitectTool.js.map +0 -7
  507. package/dist/tools/ArchitectTool/prompt.js +0 -18
  508. package/dist/tools/ArchitectTool/prompt.js.map +0 -7
  509. package/dist/tools/AskExpertModelTool/AskExpertModelTool.js +0 -423
  510. package/dist/tools/AskExpertModelTool/AskExpertModelTool.js.map +0 -7
  511. package/dist/tools/BashTool/BashTool.js +0 -188
  512. package/dist/tools/BashTool/BashTool.js.map +0 -7
  513. package/dist/tools/BashTool/BashToolResultMessage.js +0 -21
  514. package/dist/tools/BashTool/BashToolResultMessage.js.map +0 -7
  515. package/dist/tools/BashTool/OutputLine.js +0 -30
  516. package/dist/tools/BashTool/OutputLine.js.map +0 -7
  517. package/dist/tools/BashTool/prompt.js +0 -179
  518. package/dist/tools/BashTool/prompt.js.map +0 -7
  519. package/dist/tools/BashTool/utils.js +0 -51
  520. package/dist/tools/BashTool/utils.js.map +0 -7
  521. package/dist/tools/FileEditTool/FileEditTool.js +0 -228
  522. package/dist/tools/FileEditTool/FileEditTool.js.map +0 -7
  523. package/dist/tools/FileEditTool/prompt.js +0 -54
  524. package/dist/tools/FileEditTool/prompt.js.map +0 -7
  525. package/dist/tools/FileEditTool/utils.js +0 -42
  526. package/dist/tools/FileEditTool/utils.js.map +0 -7
  527. package/dist/tools/FileReadTool/FileReadTool.js +0 -272
  528. package/dist/tools/FileReadTool/FileReadTool.js.map +0 -7
  529. package/dist/tools/FileReadTool/prompt.js +0 -10
  530. package/dist/tools/FileReadTool/prompt.js.map +0 -7
  531. package/dist/tools/FileWriteTool/FileWriteTool.js +0 -204
  532. package/dist/tools/FileWriteTool/FileWriteTool.js.map +0 -7
  533. package/dist/tools/FileWriteTool/prompt.js +0 -14
  534. package/dist/tools/FileWriteTool/prompt.js.map +0 -7
  535. package/dist/tools/GlobTool/GlobTool.js +0 -88
  536. package/dist/tools/GlobTool/GlobTool.js.map +0 -7
  537. package/dist/tools/GlobTool/prompt.js +0 -12
  538. package/dist/tools/GlobTool/prompt.js.map +0 -7
  539. package/dist/tools/GrepTool/GrepTool.js +0 -107
  540. package/dist/tools/GrepTool/GrepTool.js.map +0 -7
  541. package/dist/tools/GrepTool/prompt.js +0 -15
  542. package/dist/tools/GrepTool/prompt.js.map +0 -7
  543. package/dist/tools/MCPTool/MCPTool.js +0 -90
  544. package/dist/tools/MCPTool/MCPTool.js.map +0 -7
  545. package/dist/tools/MCPTool/prompt.js +0 -7
  546. package/dist/tools/MCPTool/prompt.js.map +0 -7
  547. package/dist/tools/MemoryReadTool/MemoryReadTool.js +0 -103
  548. package/dist/tools/MemoryReadTool/MemoryReadTool.js.map +0 -7
  549. package/dist/tools/MemoryReadTool/prompt.js +0 -7
  550. package/dist/tools/MemoryReadTool/prompt.js.map +0 -7
  551. package/dist/tools/MemoryWriteTool/MemoryWriteTool.js +0 -77
  552. package/dist/tools/MemoryWriteTool/MemoryWriteTool.js.map +0 -7
  553. package/dist/tools/MemoryWriteTool/prompt.js +0 -7
  554. package/dist/tools/MemoryWriteTool/prompt.js.map +0 -7
  555. package/dist/tools/MultiEditTool/MultiEditTool.js +0 -308
  556. package/dist/tools/MultiEditTool/MultiEditTool.js.map +0 -7
  557. package/dist/tools/MultiEditTool/prompt.js +0 -48
  558. package/dist/tools/MultiEditTool/prompt.js.map +0 -7
  559. package/dist/tools/NotebookEditTool/NotebookEditTool.js +0 -238
  560. package/dist/tools/NotebookEditTool/NotebookEditTool.js.map +0 -7
  561. package/dist/tools/NotebookEditTool/prompt.js +0 -7
  562. package/dist/tools/NotebookEditTool/prompt.js.map +0 -7
  563. package/dist/tools/NotebookReadTool/NotebookReadTool.js +0 -212
  564. package/dist/tools/NotebookReadTool/NotebookReadTool.js.map +0 -7
  565. package/dist/tools/NotebookReadTool/prompt.js +0 -7
  566. package/dist/tools/NotebookReadTool/prompt.js.map +0 -7
  567. package/dist/tools/StickerRequestTool/StickerRequestTool.js +0 -86
  568. package/dist/tools/StickerRequestTool/StickerRequestTool.js.map +0 -7
  569. package/dist/tools/StickerRequestTool/prompt.js +0 -23
  570. package/dist/tools/StickerRequestTool/prompt.js.map +0 -7
  571. package/dist/tools/TaskTool/TaskTool.js +0 -351
  572. package/dist/tools/TaskTool/TaskTool.js.map +0 -7
  573. package/dist/tools/TaskTool/constants.js +0 -5
  574. package/dist/tools/TaskTool/constants.js.map +0 -7
  575. package/dist/tools/TaskTool/prompt.js +0 -82
  576. package/dist/tools/TaskTool/prompt.js.map +0 -7
  577. package/dist/tools/ThinkTool/ThinkTool.js +0 -48
  578. package/dist/tools/ThinkTool/ThinkTool.js.map +0 -7
  579. package/dist/tools/ThinkTool/prompt.js +0 -16
  580. package/dist/tools/ThinkTool/prompt.js.map +0 -7
  581. package/dist/tools/TodoWriteTool/TodoWriteTool.js +0 -216
  582. package/dist/tools/TodoWriteTool/TodoWriteTool.js.map +0 -7
  583. package/dist/tools/TodoWriteTool/prompt.js +0 -66
  584. package/dist/tools/TodoWriteTool/prompt.js.map +0 -7
  585. package/dist/tools/URLFetcherTool/URLFetcherTool.js +0 -137
  586. package/dist/tools/URLFetcherTool/URLFetcherTool.js.map +0 -7
  587. package/dist/tools/URLFetcherTool/cache.js +0 -45
  588. package/dist/tools/URLFetcherTool/cache.js.map +0 -7
  589. package/dist/tools/URLFetcherTool/htmlToMarkdown.js +0 -42
  590. package/dist/tools/URLFetcherTool/htmlToMarkdown.js.map +0 -7
  591. package/dist/tools/URLFetcherTool/prompt.js +0 -22
  592. package/dist/tools/URLFetcherTool/prompt.js.map +0 -7
  593. package/dist/tools/WebSearchTool/WebSearchTool.js +0 -86
  594. package/dist/tools/WebSearchTool/WebSearchTool.js.map +0 -7
  595. package/dist/tools/WebSearchTool/prompt.js +0 -17
  596. package/dist/tools/WebSearchTool/prompt.js.map +0 -7
  597. package/dist/tools/WebSearchTool/searchProviders.js +0 -48
  598. package/dist/tools/WebSearchTool/searchProviders.js.map +0 -7
  599. package/dist/tools/lsTool/lsTool.js +0 -201
  600. package/dist/tools/lsTool/lsTool.js.map +0 -7
  601. package/dist/tools/lsTool/prompt.js +0 -5
  602. package/dist/tools/lsTool/prompt.js.map +0 -7
  603. package/dist/tools.js +0 -64
  604. package/dist/tools.js.map +0 -7
  605. package/dist/types/PermissionMode.js +0 -82
  606. package/dist/types/PermissionMode.js.map +0 -7
  607. package/dist/types/RequestContext.js +0 -47
  608. package/dist/types/RequestContext.js.map +0 -7
  609. package/dist/types/common.d.js +0 -1
  610. package/dist/types/conversation.js +0 -1
  611. package/dist/types/logs.js +0 -1
  612. package/dist/types/modelCapabilities.js +0 -1
  613. package/dist/types/notebook.js +0 -1
  614. package/dist/utils/Cursor.js +0 -313
  615. package/dist/utils/Cursor.js.map +0 -7
  616. package/dist/utils/PersistentShell.js +0 -382
  617. package/dist/utils/PersistentShell.js.map +0 -7
  618. package/dist/utils/advancedFuzzyMatcher.js +0 -206
  619. package/dist/utils/advancedFuzzyMatcher.js.map +0 -7
  620. package/dist/utils/agentLoader.js +0 -199
  621. package/dist/utils/agentLoader.js.map +0 -7
  622. package/dist/utils/agentStorage.js +0 -59
  623. package/dist/utils/agentStorage.js.map +0 -7
  624. package/dist/utils/array.js +0 -7
  625. package/dist/utils/array.js.map +0 -7
  626. package/dist/utils/ask.js +0 -77
  627. package/dist/utils/ask.js.map +0 -7
  628. package/dist/utils/auth.js +0 -11
  629. package/dist/utils/auth.js.map +0 -7
  630. package/dist/utils/autoCompactCore.js +0 -149
  631. package/dist/utils/autoCompactCore.js.map +0 -7
  632. package/dist/utils/autoUpdater.js.map +0 -7
  633. package/dist/utils/betas.js +0 -21
  634. package/dist/utils/betas.js.map +0 -7
  635. package/dist/utils/browser.js +0 -15
  636. package/dist/utils/browser.js.map +0 -7
  637. package/dist/utils/cleanup.js +0 -54
  638. package/dist/utils/cleanup.js.map +0 -7
  639. package/dist/utils/commands.js +0 -207
  640. package/dist/utils/commands.js.map +0 -7
  641. package/dist/utils/commonUnixCommands.js +0 -687
  642. package/dist/utils/commonUnixCommands.js.map +0 -7
  643. package/dist/utils/config.js.map +0 -7
  644. package/dist/utils/conversationRecovery.js +0 -35
  645. package/dist/utils/conversationRecovery.js.map +0 -7
  646. package/dist/utils/debugLogger.js.map +0 -7
  647. package/dist/utils/diff.js +0 -32
  648. package/dist/utils/diff.js.map +0 -7
  649. package/dist/utils/env.js +0 -44
  650. package/dist/utils/env.js.map +0 -7
  651. package/dist/utils/errors.js +0 -23
  652. package/dist/utils/errors.js.map +0 -7
  653. package/dist/utils/exampleCommands.js +0 -80
  654. package/dist/utils/exampleCommands.js.map +0 -7
  655. package/dist/utils/execFileNoThrow.js +0 -44
  656. package/dist/utils/execFileNoThrow.js.map +0 -7
  657. package/dist/utils/expertChatStorage.js +0 -78
  658. package/dist/utils/expertChatStorage.js.map +0 -7
  659. package/dist/utils/file.js +0 -282
  660. package/dist/utils/file.js.map +0 -7
  661. package/dist/utils/fileRecoveryCore.js +0 -41
  662. package/dist/utils/fileRecoveryCore.js.map +0 -7
  663. package/dist/utils/format.js +0 -41
  664. package/dist/utils/format.js.map +0 -7
  665. package/dist/utils/fuzzyMatcher.js +0 -252
  666. package/dist/utils/fuzzyMatcher.js.map +0 -7
  667. package/dist/utils/generators.js +0 -46
  668. package/dist/utils/generators.js.map +0 -7
  669. package/dist/utils/git.js +0 -83
  670. package/dist/utils/git.js.map +0 -7
  671. package/dist/utils/globalLogger.js +0 -54
  672. package/dist/utils/globalLogger.js.map +0 -7
  673. package/dist/utils/http.js +0 -7
  674. package/dist/utils/http.js.map +0 -7
  675. package/dist/utils/imagePaste.js +0 -29
  676. package/dist/utils/imagePaste.js.map +0 -7
  677. package/dist/utils/json.js +0 -16
  678. package/dist/utils/json.js.map +0 -7
  679. package/dist/utils/log.js +0 -298
  680. package/dist/utils/log.js.map +0 -7
  681. package/dist/utils/markdown.js +0 -187
  682. package/dist/utils/markdown.js.map +0 -7
  683. package/dist/utils/messageContextManager.js +0 -195
  684. package/dist/utils/messageContextManager.js.map +0 -7
  685. package/dist/utils/messages.js +0 -633
  686. package/dist/utils/messages.js.map +0 -7
  687. package/dist/utils/model.js.map +0 -7
  688. package/dist/utils/permissions/filesystem.js +0 -80
  689. package/dist/utils/permissions/filesystem.js.map +0 -7
  690. package/dist/utils/responseState.js +0 -20
  691. package/dist/utils/responseState.js.map +0 -7
  692. package/dist/utils/ripgrep.js +0 -131
  693. package/dist/utils/ripgrep.js.map +0 -7
  694. package/dist/utils/secureFile.js +0 -483
  695. package/dist/utils/secureFile.js.map +0 -7
  696. package/dist/utils/sessionState.js +0 -31
  697. package/dist/utils/sessionState.js.map +0 -7
  698. package/dist/utils/state.js +0 -24
  699. package/dist/utils/state.js.map +0 -7
  700. package/dist/utils/style.js +0 -31
  701. package/dist/utils/style.js.map +0 -7
  702. package/dist/utils/terminal.js +0 -43
  703. package/dist/utils/terminal.js.map +0 -7
  704. package/dist/utils/theme.js.map +0 -7
  705. package/dist/utils/thinking.js +0 -103
  706. package/dist/utils/thinking.js.map +0 -7
  707. package/dist/utils/todoStorage.js +0 -291
  708. package/dist/utils/todoStorage.js.map +0 -7
  709. package/dist/utils/tokens.js +0 -30
  710. package/dist/utils/tokens.js.map +0 -7
  711. package/dist/utils/toolExecutionController.js +0 -109
  712. package/dist/utils/toolExecutionController.js.map +0 -7
  713. package/dist/utils/unaryLogging.js +0 -14
  714. package/dist/utils/unaryLogging.js.map +0 -7
  715. package/dist/utils/user.js +0 -40
  716. package/dist/utils/user.js.map +0 -7
  717. package/dist/utils/validate.js +0 -132
  718. package/dist/utils/validate.js.map +0 -7
  719. /package/dist/{Tool.js.map → REPL-GIU4ZIXM.js.map} +0 -0
  720. /package/dist/{components/CustomSelect/theme.js.map → autoUpdater-DNRMJWFQ.js.map} +0 -0
  721. /package/dist/{types/common.d.js.map → chunk-JC6NCUG5.js.map} +0 -0
  722. /package/dist/{types/conversation.js.map → commands-TWH6PGVG.js.map} +0 -0
  723. /package/dist/{types/logs.js.map → config-6ZMBCL23.js.map} +0 -0
  724. /package/dist/{types/modelCapabilities.js.map → context-JQIOOI4W.js.map} +0 -0
  725. /package/dist/{types/notebook.js.map → costTracker-6SL26FDB.js.map} +0 -0
package/dist/commands.js DELETED
@@ -1,84 +0,0 @@
1
- import bug from "./commands/bug.js";
2
- import clear from "./commands/clear.js";
3
- import compact from "./commands/compact.js";
4
- import config from "./commands/config.js";
5
- import cost from "./commands/cost.js";
6
- import ctx_viz from "./commands/ctx_viz.js";
7
- import doctor from "./commands/doctor.js";
8
- import help from "./commands/help.js";
9
- import init from "./commands/init.js";
10
- import listen from "./commands/listen.js";
11
- import login from "./commands/login.js";
12
- import logout from "./commands/logout.js";
13
- import mcp from "./commands/mcp.js";
14
- import * as model from "./commands/model.js";
15
- import modelstatus from "./commands/modelstatus.js";
16
- import onboarding from "./commands/onboarding.js";
17
- import pr_comments from "./commands/pr_comments.js";
18
- import refreshCommands from "./commands/refreshCommands.js";
19
- import releaseNotes from "./commands/release-notes.js";
20
- import review from "./commands/review.js";
21
- import terminalSetup from "./commands/terminalSetup.js";
22
- import resume from "./commands/resume.js";
23
- import agents from "./commands/agents.js";
24
- import { getMCPCommands } from "./services/mcpClient.js";
25
- import { loadCustomCommands } from "./services/customCommands.js";
26
- import { memoize } from "lodash-es";
27
- import { isAnthropicAuthEnabled } from "./utils/auth.js";
28
- const INTERNAL_ONLY_COMMANDS = [ctx_viz, resume, listen];
29
- const COMMANDS = memoize(() => [
30
- agents,
31
- clear,
32
- compact,
33
- config,
34
- cost,
35
- doctor,
36
- help,
37
- init,
38
- mcp,
39
- model,
40
- modelstatus,
41
- onboarding,
42
- pr_comments,
43
- refreshCommands,
44
- releaseNotes,
45
- bug,
46
- review,
47
- terminalSetup,
48
- ...isAnthropicAuthEnabled() ? [logout, login()] : [],
49
- ...INTERNAL_ONLY_COMMANDS
50
- ]);
51
- const getCommands = memoize(async () => {
52
- const [mcpCommands, customCommands] = await Promise.all([
53
- getMCPCommands(),
54
- loadCustomCommands()
55
- ]);
56
- return [...mcpCommands, ...customCommands, ...COMMANDS()].filter(
57
- (_) => _.isEnabled
58
- );
59
- });
60
- function hasCommand(commandName, commands) {
61
- return commands.some(
62
- (_) => _.userFacingName() === commandName || _.aliases?.includes(commandName)
63
- );
64
- }
65
- function getCommand(commandName, commands) {
66
- const command = commands.find(
67
- (_) => _.userFacingName() === commandName || _.aliases?.includes(commandName)
68
- );
69
- if (!command) {
70
- throw ReferenceError(
71
- `Command ${commandName} not found. Available commands: ${commands.map((_) => {
72
- const name = _.userFacingName();
73
- return _.aliases ? `${name} (aliases: ${_.aliases.join(", ")})` : name;
74
- }).join(", ")}`
75
- );
76
- }
77
- return command;
78
- }
79
- export {
80
- getCommand,
81
- getCommands,
82
- hasCommand
83
- };
84
- //# sourceMappingURL=commands.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../src/commands.ts"],
4
- "sourcesContent": ["import React from 'react'\nimport bug from './commands/bug'\nimport clear from './commands/clear'\nimport compact from './commands/compact'\nimport config from './commands/config'\nimport cost from './commands/cost'\nimport ctx_viz from './commands/ctx_viz'\nimport doctor from './commands/doctor'\nimport help from './commands/help'\nimport init from './commands/init'\nimport listen from './commands/listen'\nimport login from './commands/login'\nimport logout from './commands/logout'\nimport mcp from './commands/mcp'\nimport * as model from './commands/model'\nimport modelstatus from './commands/modelstatus'\nimport onboarding from './commands/onboarding'\nimport pr_comments from './commands/pr_comments'\nimport refreshCommands from './commands/refreshCommands'\nimport releaseNotes from './commands/release-notes'\nimport review from './commands/review'\nimport terminalSetup from './commands/terminalSetup'\nimport { Tool, ToolUseContext } from './Tool'\nimport resume from './commands/resume'\nimport agents from './commands/agents'\nimport { getMCPCommands } from './services/mcpClient'\nimport { loadCustomCommands } from './services/customCommands'\nimport type { MessageParam } from '@anthropic-ai/sdk/resources/index.mjs'\nimport { memoize } from 'lodash-es'\nimport type { Message } from './query'\nimport { isAnthropicAuthEnabled } from './utils/auth'\n\ntype PromptCommand = {\n type: 'prompt'\n progressMessage: string\n argNames?: string[]\n getPromptForCommand(args: string): Promise<MessageParam[]>\n}\n\ntype LocalCommand = {\n type: 'local'\n call(\n args: string,\n context: {\n options: {\n commands: Command[]\n tools: Tool[]\n slowAndCapableModel: string\n }\n abortController: AbortController\n setForkConvoWithMessagesOnTheNextRender: (\n forkConvoWithMessages: Message[],\n ) => void\n },\n ): Promise<string>\n}\n\ntype LocalJSXCommand = {\n type: 'local-jsx'\n call(\n onDone: (result?: string) => void,\n context: ToolUseContext & {\n setForkConvoWithMessagesOnTheNextRender: (\n forkConvoWithMessages: Message[],\n ) => void\n },\n ): Promise<React.ReactNode>\n}\n\nexport type Command = {\n description: string\n isEnabled: boolean\n isHidden: boolean\n name: string\n aliases?: string[]\n userFacingName(): string\n} & (PromptCommand | LocalCommand | LocalJSXCommand)\n\nconst INTERNAL_ONLY_COMMANDS = [ctx_viz, resume, listen]\n\n// Declared as a function so that we don't run this until getCommands is called,\n// since underlying functions read from config, which can't be read at module initialization time\nconst COMMANDS = memoize((): Command[] => [\n agents,\n clear,\n compact,\n config,\n cost,\n doctor,\n help,\n init,\n mcp,\n model,\n modelstatus,\n onboarding,\n pr_comments,\n refreshCommands,\n releaseNotes,\n bug,\n review,\n terminalSetup,\n ...(isAnthropicAuthEnabled() ? [logout, login()] : []),\n ...INTERNAL_ONLY_COMMANDS,\n])\n\nexport const getCommands = memoize(async (): Promise<Command[]> => {\n const [mcpCommands, customCommands] = await Promise.all([\n getMCPCommands(),\n loadCustomCommands(),\n ])\n\n return [...mcpCommands, ...customCommands, ...COMMANDS()].filter(\n _ => _.isEnabled,\n )\n})\n\nexport function hasCommand(commandName: string, commands: Command[]): boolean {\n return commands.some(\n _ => _.userFacingName() === commandName || _.aliases?.includes(commandName),\n )\n}\n\nexport function getCommand(commandName: string, commands: Command[]): Command {\n const command = commands.find(\n _ => _.userFacingName() === commandName || _.aliases?.includes(commandName),\n ) as Command | undefined\n if (!command) {\n throw ReferenceError(\n `Command ${commandName} not found. Available commands: ${commands\n .map(_ => {\n const name = _.userFacingName()\n return _.aliases ? `${name} (aliases: ${_.aliases.join(', ')})` : name\n })\n .join(', ')}`,\n )\n }\n\n return command\n}\n"],
5
- "mappings": "AACA,OAAO,SAAS;AAChB,OAAO,WAAW;AAClB,OAAO,aAAa;AACpB,OAAO,YAAY;AACnB,OAAO,UAAU;AACjB,OAAO,aAAa;AACpB,OAAO,YAAY;AACnB,OAAO,UAAU;AACjB,OAAO,UAAU;AACjB,OAAO,YAAY;AACnB,OAAO,WAAW;AAClB,OAAO,YAAY;AACnB,OAAO,SAAS;AAChB,YAAY,WAAW;AACvB,OAAO,iBAAiB;AACxB,OAAO,gBAAgB;AACvB,OAAO,iBAAiB;AACxB,OAAO,qBAAqB;AAC5B,OAAO,kBAAkB;AACzB,OAAO,YAAY;AACnB,OAAO,mBAAmB;AAE1B,OAAO,YAAY;AACnB,OAAO,YAAY;AACnB,SAAS,sBAAsB;AAC/B,SAAS,0BAA0B;AAEnC,SAAS,eAAe;AAExB,SAAS,8BAA8B;AAgDvC,MAAM,yBAAyB,CAAC,SAAS,QAAQ,MAAM;AAIvD,MAAM,WAAW,QAAQ,MAAiB;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAI,uBAAuB,IAAI,CAAC,QAAQ,MAAM,CAAC,IAAI,CAAC;AAAA,EACpD,GAAG;AACL,CAAC;AAEM,MAAM,cAAc,QAAQ,YAAgC;AACjE,QAAM,CAAC,aAAa,cAAc,IAAI,MAAM,QAAQ,IAAI;AAAA,IACtD,eAAe;AAAA,IACf,mBAAmB;AAAA,EACrB,CAAC;AAED,SAAO,CAAC,GAAG,aAAa,GAAG,gBAAgB,GAAG,SAAS,CAAC,EAAE;AAAA,IACxD,OAAK,EAAE;AAAA,EACT;AACF,CAAC;AAEM,SAAS,WAAW,aAAqB,UAA8B;AAC5E,SAAO,SAAS;AAAA,IACd,OAAK,EAAE,eAAe,MAAM,eAAe,EAAE,SAAS,SAAS,WAAW;AAAA,EAC5E;AACF;AAEO,SAAS,WAAW,aAAqB,UAA8B;AAC5E,QAAM,UAAU,SAAS;AAAA,IACvB,OAAK,EAAE,eAAe,MAAM,eAAe,EAAE,SAAS,SAAS,WAAW;AAAA,EAC5E;AACA,MAAI,CAAC,SAAS;AACZ,UAAM;AAAA,MACJ,WAAW,WAAW,mCAAmC,SACtD,IAAI,OAAK;AACR,cAAM,OAAO,EAAE,eAAe;AAC9B,eAAO,EAAE,UAAU,GAAG,IAAI,cAAc,EAAE,QAAQ,KAAK,IAAI,CAAC,MAAM;AAAA,MACpE,CAAC,EACA,KAAK,IAAI,CAAC;AAAA,IACf;AAAA,EACF;AAEA,SAAO;AACT;",
6
- "names": []
7
- }
@@ -1,74 +0,0 @@
1
- import React from "react";
2
- import { Box, Text } from "ink";
3
- import { getGlobalConfig, saveGlobalConfig } from "../utils/config.js";
4
- import { getTheme } from "../utils/theme.js";
5
- import { Select } from "./CustomSelect/select.js";
6
- import { useExitOnCtrlCD } from "../hooks/useExitOnCtrlCD.js";
7
- import chalk from "chalk";
8
- function ApproveApiKey({
9
- customApiKeyTruncated,
10
- onDone
11
- }) {
12
- const theme = getTheme();
13
- function onChange(value) {
14
- const config = getGlobalConfig();
15
- switch (value) {
16
- case "yes": {
17
- saveGlobalConfig({
18
- ...config,
19
- customApiKeyResponses: {
20
- ...config.customApiKeyResponses,
21
- approved: [
22
- ...config.customApiKeyResponses?.approved ?? [],
23
- customApiKeyTruncated
24
- ]
25
- }
26
- });
27
- onDone();
28
- break;
29
- }
30
- case "no": {
31
- saveGlobalConfig({
32
- ...config,
33
- customApiKeyResponses: {
34
- ...config.customApiKeyResponses,
35
- rejected: [
36
- ...config.customApiKeyResponses?.rejected ?? [],
37
- customApiKeyTruncated
38
- ]
39
- }
40
- });
41
- onDone();
42
- break;
43
- }
44
- }
45
- }
46
- const exitState = useExitOnCtrlCD(() => process.exit(0));
47
- return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
48
- Box,
49
- {
50
- flexDirection: "column",
51
- gap: 1,
52
- padding: 1,
53
- borderStyle: "round",
54
- borderColor: theme.warning
55
- },
56
- /* @__PURE__ */ React.createElement(Text, { bold: true, color: theme.warning }, "Detected a custom API key in your environment"),
57
- /* @__PURE__ */ React.createElement(Text, null, "Your environment sets", " ", /* @__PURE__ */ React.createElement(Text, { color: theme.warning }, "ANTHROPIC_API_KEY"), ":", " ", /* @__PURE__ */ React.createElement(Text, { bold: true }, "sk-ant-...", customApiKeyTruncated)),
58
- /* @__PURE__ */ React.createElement(Text, null, "Do you want to use this API key?"),
59
- /* @__PURE__ */ React.createElement(
60
- Select,
61
- {
62
- options: [
63
- { label: `No (${chalk.bold("recommended")})`, value: "no" },
64
- { label: "Yes", value: "yes" }
65
- ],
66
- onChange: (value) => onChange(value)
67
- }
68
- )
69
- ), /* @__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, "Enter to confirm"))));
70
- }
71
- export {
72
- ApproveApiKey
73
- };
74
- //# sourceMappingURL=ApproveApiKey.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/components/ApproveApiKey.tsx"],
4
- "sourcesContent": ["import React from 'react'\nimport { Box, Text } from 'ink'\nimport { getGlobalConfig, saveGlobalConfig } from '../utils/config'\nimport { getTheme } from '../utils/theme'\nimport { Select } from './CustomSelect/select'\nimport { useExitOnCtrlCD } from '../hooks/useExitOnCtrlCD'\nimport chalk from 'chalk'\n\ntype Props = {\n customApiKeyTruncated: string\n onDone(): void\n}\n\nexport function ApproveApiKey({\n customApiKeyTruncated,\n onDone,\n}: Props): React.ReactNode {\n const theme = getTheme()\n\n function onChange(value: 'yes' | 'no') {\n const config = getGlobalConfig()\n switch (value) {\n case 'yes': {\n saveGlobalConfig({\n ...config,\n customApiKeyResponses: {\n ...config.customApiKeyResponses,\n approved: [\n ...(config.customApiKeyResponses?.approved ?? []),\n customApiKeyTruncated,\n ],\n },\n })\n onDone()\n break\n }\n case 'no': {\n saveGlobalConfig({\n ...config,\n customApiKeyResponses: {\n ...config.customApiKeyResponses,\n rejected: [\n ...(config.customApiKeyResponses?.rejected ?? []),\n customApiKeyTruncated,\n ],\n },\n })\n onDone()\n break\n }\n }\n }\n\n const exitState = useExitOnCtrlCD(() => process.exit(0))\n\n return (\n <>\n <Box\n flexDirection=\"column\"\n gap={1}\n padding={1}\n borderStyle=\"round\"\n borderColor={theme.warning}\n >\n <Text bold color={theme.warning}>\n Detected a custom API key in your environment\n </Text>\n <Text>\n Your environment sets{' '}\n <Text color={theme.warning}>ANTHROPIC_API_KEY</Text>:{' '}\n <Text bold>sk-ant-...{customApiKeyTruncated}</Text>\n </Text>\n <Text>Do you want to use this API key?</Text>\n <Select\n options={[\n { label: `No (${chalk.bold('recommended')})`, value: 'no' },\n { label: 'Yes', value: 'yes' },\n ]}\n onChange={value => onChange(value as 'yes' | 'no')}\n />\n </Box>\n <Box marginLeft={3}>\n <Text dimColor>\n {exitState.pending ? (\n <>Press {exitState.keyName} again to exit</>\n ) : (\n <>Enter to confirm</>\n )}\n </Text>\n </Box>\n </>\n )\n}\n"],
5
- "mappings": "AAAA,OAAO,WAAW;AAClB,SAAS,KAAK,YAAY;AAC1B,SAAS,iBAAiB,wBAAwB;AAClD,SAAS,gBAAgB;AACzB,SAAS,cAAc;AACvB,SAAS,uBAAuB;AAChC,OAAO,WAAW;AAOX,SAAS,cAAc;AAAA,EAC5B;AAAA,EACA;AACF,GAA2B;AACzB,QAAM,QAAQ,SAAS;AAEvB,WAAS,SAAS,OAAqB;AACrC,UAAM,SAAS,gBAAgB;AAC/B,YAAQ,OAAO;AAAA,MACb,KAAK,OAAO;AACV,yBAAiB;AAAA,UACf,GAAG;AAAA,UACH,uBAAuB;AAAA,YACrB,GAAG,OAAO;AAAA,YACV,UAAU;AAAA,cACR,GAAI,OAAO,uBAAuB,YAAY,CAAC;AAAA,cAC/C;AAAA,YACF;AAAA,UACF;AAAA,QACF,CAAC;AACD,eAAO;AACP;AAAA,MACF;AAAA,MACA,KAAK,MAAM;AACT,yBAAiB;AAAA,UACf,GAAG;AAAA,UACH,uBAAuB;AAAA,YACrB,GAAG,OAAO;AAAA,YACV,UAAU;AAAA,cACR,GAAI,OAAO,uBAAuB,YAAY,CAAC;AAAA,cAC/C;AAAA,YACF;AAAA,UACF;AAAA,QACF,CAAC;AACD,eAAO;AACP;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAEA,QAAM,YAAY,gBAAgB,MAAM,QAAQ,KAAK,CAAC,CAAC;AAEvD,SACE,0DACE;AAAA,IAAC;AAAA;AAAA,MACC,eAAc;AAAA,MACd,KAAK;AAAA,MACL,SAAS;AAAA,MACT,aAAY;AAAA,MACZ,aAAa,MAAM;AAAA;AAAA,IAEnB,oCAAC,QAAK,MAAI,MAAC,OAAO,MAAM,WAAS,+CAEjC;AAAA,IACA,oCAAC,YAAK,yBACkB,KACtB,oCAAC,QAAK,OAAO,MAAM,WAAS,mBAAiB,GAAO,KAAE,KACtD,oCAAC,QAAK,MAAI,QAAC,cAAW,qBAAsB,CAC9C;AAAA,IACA,oCAAC,YAAK,kCAAgC;AAAA,IACtC;AAAA,MAAC;AAAA;AAAA,QACC,SAAS;AAAA,UACP,EAAE,OAAO,OAAO,MAAM,KAAK,aAAa,CAAC,KAAK,OAAO,KAAK;AAAA,UAC1D,EAAE,OAAO,OAAO,OAAO,MAAM;AAAA,QAC/B;AAAA,QACA,UAAU,WAAS,SAAS,KAAqB;AAAA;AAAA,IACnD;AAAA,EACF,GACA,oCAAC,OAAI,YAAY,KACf,oCAAC,QAAK,UAAQ,QACX,UAAU,UACT,0DAAE,UAAO,UAAU,SAAQ,gBAAc,IAEzC,0DAAE,kBAAgB,CAEtB,CACF,CACF;AAEJ;",
6
- "names": []
7
- }
@@ -1,12 +0,0 @@
1
- import { Box, Text } from "ink";
2
- import React from "react";
3
- import { getTheme } from "../utils/theme.js";
4
- import { ASCII_LOGO } from "../constants/product.js";
5
- function AsciiLogo() {
6
- const theme = getTheme();
7
- return /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", alignItems: "flex-start" }, /* @__PURE__ */ React.createElement(Text, { color: theme.kode }, ASCII_LOGO));
8
- }
9
- export {
10
- AsciiLogo
11
- };
12
- //# sourceMappingURL=AsciiLogo.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/components/AsciiLogo.tsx"],
4
- "sourcesContent": ["import { Box, Text } from 'ink'\nimport React from 'react'\nimport { getTheme } from '../utils/theme'\nimport { ASCII_LOGO } from '../constants/product'\n\nexport function AsciiLogo(): React.ReactNode {\n const theme = getTheme()\n return (\n <Box flexDirection=\"column\" alignItems=\"flex-start\">\n <Text color={theme.kode}>{ASCII_LOGO}</Text>\n </Box>\n )\n}\n"],
5
- "mappings": "AAAA,SAAS,KAAK,YAAY;AAC1B,OAAO,WAAW;AAClB,SAAS,gBAAgB;AACzB,SAAS,kBAAkB;AAEpB,SAAS,YAA6B;AAC3C,QAAM,QAAQ,SAAS;AACvB,SACE,oCAAC,OAAI,eAAc,UAAS,YAAW,gBACrC,oCAAC,QAAK,OAAO,MAAM,QAAO,UAAW,CACvC;AAEJ;",
6
- "names": []
7
- }
@@ -1,74 +0,0 @@
1
- import { Box, Text } from "ink";
2
- import * as React from "react";
3
- import { getTheme } from "../utils/theme.js";
4
- import { gte } from "semver";
5
- import { useEffect, useState } from "react";
6
- import {
7
- getLatestVersion,
8
- installGlobalPackage
9
- } from "../utils/autoUpdater.js";
10
- import { logEvent } from "../services/statsig.js";
11
- import { MACRO } from "../constants/macros.js";
12
- import { PRODUCT_COMMAND } from "../constants/product.js";
13
- function AutoUpdater({
14
- debug,
15
- isUpdating,
16
- onChangeIsUpdating,
17
- onAutoUpdaterResult,
18
- autoUpdaterResult
19
- }) {
20
- const theme = getTheme();
21
- const [versions, setVersions] = useState({});
22
- const checkForUpdates = React.useCallback(async () => {
23
- if (process.env.NODE_ENV === "test" || process.env.NODE_ENV === "dev") {
24
- return;
25
- }
26
- if (isUpdating) {
27
- return;
28
- }
29
- const globalVersion = MACRO.VERSION;
30
- const latestVersion = await getLatestVersion();
31
- const isDisabled = true;
32
- setVersions({ global: globalVersion, latest: latestVersion });
33
- if (!isDisabled && globalVersion && latestVersion && !gte(globalVersion, latestVersion)) {
34
- const startTime = Date.now();
35
- onChangeIsUpdating(true);
36
- const installStatus = await installGlobalPackage();
37
- onChangeIsUpdating(false);
38
- if (installStatus === "success") {
39
- logEvent("tengu_auto_updater_success", {
40
- fromVersion: globalVersion,
41
- toVersion: latestVersion,
42
- durationMs: String(Date.now() - startTime)
43
- });
44
- } else {
45
- logEvent("tengu_auto_updater_fail", {
46
- fromVersion: globalVersion,
47
- attemptedVersion: latestVersion,
48
- status: installStatus,
49
- durationMs: String(Date.now() - startTime)
50
- });
51
- }
52
- onAutoUpdaterResult({
53
- version: latestVersion,
54
- status: installStatus
55
- });
56
- }
57
- }, [onAutoUpdaterResult]);
58
- useEffect(() => {
59
- }, [checkForUpdates]);
60
- if (debug) {
61
- return /* @__PURE__ */ React.createElement(Box, { flexDirection: "row" }, /* @__PURE__ */ React.createElement(Text, { dimColor: true }, "globalVersion: ", versions.global, " \xB7 latestVersion:", " ", versions.latest));
62
- }
63
- if (!autoUpdaterResult?.version && (!versions.global || !versions.latest)) {
64
- return null;
65
- }
66
- if (!autoUpdaterResult?.version && !isUpdating) {
67
- return null;
68
- }
69
- return /* @__PURE__ */ React.createElement(Box, { flexDirection: "row" }, debug && /* @__PURE__ */ React.createElement(Text, { dimColor: true }, "globalVersion: ", versions.global, " \xB7 latestVersion:", " ", versions.latest), isUpdating && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(Box, null, /* @__PURE__ */ React.createElement(Text, { color: theme.secondaryText, dimColor: true, wrap: "end" }, "Auto-updating to v", versions.latest, "\u2026"))), autoUpdaterResult?.status === "success" && autoUpdaterResult?.version ? /* @__PURE__ */ React.createElement(Text, { color: theme.success }, "\u2713 Update installed \xB7 Restart to apply") : null, (autoUpdaterResult?.status === "install_failed" || autoUpdaterResult?.status === "no_permissions") && /* @__PURE__ */ React.createElement(Text, { color: theme.error }, "\u2717 Auto-update failed \xB7 Try", " ", /* @__PURE__ */ React.createElement(Text, { bold: true }, PRODUCT_COMMAND, " doctor"), " or", " ", /* @__PURE__ */ React.createElement(Text, { bold: true }, "npm i -g ", MACRO.PACKAGE_URL)));
70
- }
71
- export {
72
- AutoUpdater
73
- };
74
- //# sourceMappingURL=AutoUpdater.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/components/AutoUpdater.tsx"],
4
- "sourcesContent": ["import { Box, Text } from 'ink'\nimport * as React from 'react'\nimport { getTheme } from '../utils/theme'\nimport { gte } from 'semver'\nimport { useEffect, useState } from 'react'\nimport { isAutoUpdaterDisabled } from '../utils/config'\nimport {\n AutoUpdaterResult,\n getLatestVersion,\n installGlobalPackage,\n} from '../utils/autoUpdater.js'\nimport { useInterval } from '../hooks/useInterval'\nimport { logEvent } from '../services/statsig'\nimport { MACRO } from '../constants/macros'\nimport { PRODUCT_COMMAND } from '../constants/product'\ntype Props = {\n debug: boolean\n isUpdating: boolean\n onChangeIsUpdating: (isUpdating: boolean) => void\n onAutoUpdaterResult: (autoUpdaterResult: AutoUpdaterResult) => void\n autoUpdaterResult: AutoUpdaterResult | null\n}\n\nexport function AutoUpdater({\n debug,\n isUpdating,\n onChangeIsUpdating,\n onAutoUpdaterResult,\n autoUpdaterResult,\n}: Props): React.ReactNode {\n const theme = getTheme()\n const [versions, setVersions] = useState<{\n global?: string | null\n latest?: string | null\n }>({})\n const checkForUpdates = React.useCallback(async () => {\n if (process.env.NODE_ENV === 'test' || process.env.NODE_ENV === 'dev') {\n return\n }\n\n if (isUpdating) {\n return\n }\n\n // Get versions\n const globalVersion = MACRO.VERSION\n const latestVersion = await getLatestVersion()\n const isDisabled = true //await isAutoUpdaterDisabled()\n\n setVersions({ global: globalVersion, latest: latestVersion })\n\n // Check if update needed and perform update\n if (\n !isDisabled &&\n globalVersion &&\n latestVersion &&\n !gte(globalVersion, latestVersion)\n ) {\n const startTime = Date.now()\n onChangeIsUpdating(true)\n const installStatus = await installGlobalPackage()\n onChangeIsUpdating(false)\n\n if (installStatus === 'success') {\n logEvent('tengu_auto_updater_success', {\n fromVersion: globalVersion,\n toVersion: latestVersion,\n durationMs: String(Date.now() - startTime),\n })\n } else {\n logEvent('tengu_auto_updater_fail', {\n fromVersion: globalVersion,\n attemptedVersion: latestVersion,\n status: installStatus,\n durationMs: String(Date.now() - startTime),\n })\n }\n\n onAutoUpdaterResult({\n version: latestVersion!,\n status: installStatus,\n })\n }\n // Don't re-render when isUpdating changes\n // TODO: Find a cleaner way to do this\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [onAutoUpdaterResult])\n\n // Initial check\n useEffect(() => {\n // checkForUpdates()\n }, [checkForUpdates])\n\n // Check every 30 minutes\n // useInterval(checkForUpdates, 30 * 60 * 1000)\n\n if (debug) {\n return (\n <Box flexDirection=\"row\">\n <Text dimColor>\n globalVersion: {versions.global} &middot; latestVersion:{' '}\n {versions.latest}\n </Text>\n </Box>\n )\n }\n\n if (!autoUpdaterResult?.version && (!versions.global || !versions.latest)) {\n return null\n }\n\n if (!autoUpdaterResult?.version && !isUpdating) {\n return null\n }\n\n return (\n <Box flexDirection=\"row\">\n {debug && (\n <Text dimColor>\n globalVersion: {versions.global} &middot; latestVersion:{' '}\n {versions.latest}\n </Text>\n )}\n {isUpdating && (\n <>\n <Box>\n <Text color={theme.secondaryText} dimColor wrap=\"end\">\n Auto-updating to v{versions.latest}\u2026\n </Text>\n </Box>\n </>\n )}\n {autoUpdaterResult?.status === 'success' && autoUpdaterResult?.version ? (\n <Text color={theme.success}>\n \u2713 Update installed &middot; Restart to apply\n </Text>\n ) : null}\n {(autoUpdaterResult?.status === 'install_failed' ||\n autoUpdaterResult?.status === 'no_permissions') && (\n <Text color={theme.error}>\n \u2717 Auto-update failed &middot; Try{' '}\n <Text bold>{PRODUCT_COMMAND} doctor</Text> or{' '}\n <Text bold>npm i -g {MACRO.PACKAGE_URL}</Text>\n </Text>\n )}\n </Box>\n )\n}\n"],
5
- "mappings": "AAAA,SAAS,KAAK,YAAY;AAC1B,YAAY,WAAW;AACvB,SAAS,gBAAgB;AACzB,SAAS,WAAW;AACpB,SAAS,WAAW,gBAAgB;AAEpC;AAAA,EAEE;AAAA,EACA;AAAA,OACK;AAEP,SAAS,gBAAgB;AACzB,SAAS,aAAa;AACtB,SAAS,uBAAuB;AASzB,SAAS,YAAY;AAAA,EAC1B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AACzB,QAAM,QAAQ,SAAS;AACvB,QAAM,CAAC,UAAU,WAAW,IAAI,SAG7B,CAAC,CAAC;AACL,QAAM,kBAAkB,MAAM,YAAY,YAAY;AACpD,QAAI,QAAQ,IAAI,aAAa,UAAU,QAAQ,IAAI,aAAa,OAAO;AACrE;AAAA,IACF;AAEA,QAAI,YAAY;AACd;AAAA,IACF;AAGA,UAAM,gBAAgB,MAAM;AAC5B,UAAM,gBAAgB,MAAM,iBAAiB;AAC7C,UAAM,aAAa;AAEnB,gBAAY,EAAE,QAAQ,eAAe,QAAQ,cAAc,CAAC;AAG5D,QACE,CAAC,cACD,iBACA,iBACA,CAAC,IAAI,eAAe,aAAa,GACjC;AACA,YAAM,YAAY,KAAK,IAAI;AAC3B,yBAAmB,IAAI;AACvB,YAAM,gBAAgB,MAAM,qBAAqB;AACjD,yBAAmB,KAAK;AAExB,UAAI,kBAAkB,WAAW;AAC/B,iBAAS,8BAA8B;AAAA,UACrC,aAAa;AAAA,UACb,WAAW;AAAA,UACX,YAAY,OAAO,KAAK,IAAI,IAAI,SAAS;AAAA,QAC3C,CAAC;AAAA,MACH,OAAO;AACL,iBAAS,2BAA2B;AAAA,UAClC,aAAa;AAAA,UACb,kBAAkB;AAAA,UAClB,QAAQ;AAAA,UACR,YAAY,OAAO,KAAK,IAAI,IAAI,SAAS;AAAA,QAC3C,CAAC;AAAA,MACH;AAEA,0BAAoB;AAAA,QAClB,SAAS;AAAA,QACT,QAAQ;AAAA,MACV,CAAC;AAAA,IACH;AAAA,EAIF,GAAG,CAAC,mBAAmB,CAAC;AAGxB,YAAU,MAAM;AAAA,EAEhB,GAAG,CAAC,eAAe,CAAC;AAKpB,MAAI,OAAO;AACT,WACE,oCAAC,OAAI,eAAc,SACjB,oCAAC,QAAK,UAAQ,QAAC,mBACG,SAAS,QAAO,wBAAyB,KACxD,SAAS,MACZ,CACF;AAAA,EAEJ;AAEA,MAAI,CAAC,mBAAmB,YAAY,CAAC,SAAS,UAAU,CAAC,SAAS,SAAS;AACzE,WAAO;AAAA,EACT;AAEA,MAAI,CAAC,mBAAmB,WAAW,CAAC,YAAY;AAC9C,WAAO;AAAA,EACT;AAEA,SACE,oCAAC,OAAI,eAAc,SAChB,SACC,oCAAC,QAAK,UAAQ,QAAC,mBACG,SAAS,QAAO,wBAAyB,KACxD,SAAS,MACZ,GAED,cACC,0DACE,oCAAC,WACC,oCAAC,QAAK,OAAO,MAAM,eAAe,UAAQ,MAAC,MAAK,SAAM,sBACjC,SAAS,QAAO,QACrC,CACF,CACF,GAED,mBAAmB,WAAW,aAAa,mBAAmB,UAC7D,oCAAC,QAAK,OAAO,MAAM,WAAS,+CAE5B,IACE,OACF,mBAAmB,WAAW,oBAC9B,mBAAmB,WAAW,qBAC9B,oCAAC,QAAK,OAAO,MAAM,SAAO,sCACU,KAClC,oCAAC,QAAK,MAAI,QAAE,iBAAgB,SAAO,GAAO,OAAI,KAC9C,oCAAC,QAAK,MAAI,QAAC,aAAU,MAAM,WAAY,CACzC,CAEJ;AAEJ;",
6
- "names": []
7
- }
@@ -1,147 +0,0 @@
1
- import { Box, Text, useInput } from "ink";
2
- import * as React from "react";
3
- import { useState, useCallback, useEffect } from "react";
4
- import { getTheme } from "../utils/theme.js";
5
- import { getMessagesGetter } from "../messages.js";
6
- import TextInput from "./TextInput.js";
7
- import { env } from "../utils/env.js";
8
- import { getGitState, getIsGit } from "../utils/git.js";
9
- import { useTerminalSize } from "../hooks/useTerminalSize.js";
10
- import { getGlobalConfig } from "../utils/config.js";
11
- import { API_ERROR_MESSAGE_PREFIX, queryQuick } from "../services/claude.js";
12
- import { openBrowser } from "../utils/browser.js";
13
- import { useExitOnCtrlCD } from "../hooks/useExitOnCtrlCD.js";
14
- import { MACRO } from "../constants/macros.js";
15
- import { GITHUB_ISSUES_REPO_URL } from "../constants/product.js";
16
- function Bug({ onDone }) {
17
- const [step, setStep] = useState("userInput");
18
- const [cursorOffset, setCursorOffset] = useState(0);
19
- const [description, setDescription] = useState("");
20
- const [feedbackId, setFeedbackId] = useState(null);
21
- const [error, setError] = useState(null);
22
- const [envInfo, setEnvInfo] = useState({ isGit: false, gitState: null });
23
- const [title, setTitle] = useState(null);
24
- const textInputColumns = useTerminalSize().columns - 4;
25
- const messages = getMessagesGetter()();
26
- useEffect(() => {
27
- async function loadEnvInfo() {
28
- const isGit = await getIsGit();
29
- let gitState = null;
30
- if (isGit) {
31
- gitState = await getGitState();
32
- }
33
- setEnvInfo({ isGit, gitState });
34
- }
35
- void loadEnvInfo();
36
- }, []);
37
- const exitState = useExitOnCtrlCD(() => process.exit(0));
38
- const submitReport = useCallback(async () => {
39
- setStep("done");
40
- }, [description, envInfo.isGit, messages]);
41
- useInput((input, key) => {
42
- if (error) {
43
- onDone("<bash-stderr>Error submitting bug report</bash-stderr>");
44
- return;
45
- }
46
- if (key.escape) {
47
- onDone("<bash-stderr>Bug report cancelled</bash-stderr>");
48
- return;
49
- }
50
- if (step === "consent" && (key.return || input === " ")) {
51
- const issueUrl = createGitHubIssueUrl(
52
- feedbackId,
53
- description.slice(0, 80),
54
- description
55
- );
56
- void openBrowser(issueUrl);
57
- onDone("<bash-stdout>Bug report submitted</bash-stdout>");
58
- }
59
- });
60
- const theme = getTheme();
61
- return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
62
- Box,
63
- {
64
- flexDirection: "column",
65
- borderStyle: "round",
66
- borderColor: theme.permission,
67
- paddingX: 1,
68
- paddingBottom: 1,
69
- gap: 1
70
- },
71
- /* @__PURE__ */ React.createElement(Text, { bold: true, color: theme.permission }, "Submit Bug Report"),
72
- step === "userInput" && /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", gap: 1 }, /* @__PURE__ */ React.createElement(Text, null, "Describe the issue below and copy/paste any errors you see:"), /* @__PURE__ */ React.createElement(
73
- TextInput,
74
- {
75
- value: description,
76
- onChange: setDescription,
77
- columns: textInputColumns,
78
- onSubmit: () => setStep("consent"),
79
- onExitMessage: () => onDone("<bash-stderr>Bug report cancelled</bash-stderr>"),
80
- cursorOffset,
81
- onChangeCursorOffset: setCursorOffset
82
- }
83
- ), error && /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", gap: 1 }, /* @__PURE__ */ React.createElement(Text, { color: "red" }, error), /* @__PURE__ */ React.createElement(Text, { dimColor: true }, "Press any key to close"))),
84
- step === "consent" && /* @__PURE__ */ React.createElement(Box, { flexDirection: "column" }, /* @__PURE__ */ React.createElement(Text, null, "This report will include:"), /* @__PURE__ */ React.createElement(Box, { marginLeft: 2, flexDirection: "column" }, /* @__PURE__ */ React.createElement(Text, null, "- Your bug description: ", /* @__PURE__ */ React.createElement(Text, { dimColor: true }, description)), /* @__PURE__ */ React.createElement(Text, null, "- Environment info:", " ", /* @__PURE__ */ React.createElement(Text, { dimColor: true }, env.platform, ", ", env.terminal, ", v", MACRO.VERSION)), /* @__PURE__ */ React.createElement(Text, null, "- Model settings (no api keys)"))),
85
- step === "submitting" && /* @__PURE__ */ React.createElement(Box, { flexDirection: "row", gap: 1 }, /* @__PURE__ */ React.createElement(Text, null, "Submitting report\u2026")),
86
- step === "done" && /* @__PURE__ */ React.createElement(Box, { flexDirection: "column" }, /* @__PURE__ */ React.createElement(Text, { color: getTheme().success }, "Thank you for your report!"), feedbackId && /* @__PURE__ */ React.createElement(Text, { dimColor: true }, "Feedback ID: ", feedbackId), /* @__PURE__ */ React.createElement(Box, { marginTop: 1 }, /* @__PURE__ */ React.createElement(Text, null, "Press "), /* @__PURE__ */ React.createElement(Text, { bold: true }, "Enter "), /* @__PURE__ */ React.createElement(Text, null, "to also create a GitHub issue, or any other key to close.")))
87
- ), /* @__PURE__ */ React.createElement(Box, { marginLeft: 3 }, /* @__PURE__ */ React.createElement(Text, { dimColor: true }, exitState.pending ? /* @__PURE__ */ React.createElement(React.Fragment, null, "Press ", exitState.keyName, " again to exit") : step === "userInput" ? /* @__PURE__ */ React.createElement(React.Fragment, null, "Enter to continue \xB7 Esc to cancel") : step === "consent" ? /* @__PURE__ */ React.createElement(React.Fragment, null, "Enter to open browser to create GitHub issue \xB7 Esc to cancel") : null)));
88
- }
89
- function createGitHubIssueUrl(feedbackId, title, description) {
90
- const globalConfig = getGlobalConfig();
91
- const modelProfiles = globalConfig.modelProfiles || [];
92
- const activeProfiles = modelProfiles.filter((p) => p.isActive);
93
- let modelInfo = "## Models\n";
94
- if (activeProfiles.length === 0) {
95
- modelInfo += "- No model profiles configured\n";
96
- } else {
97
- activeProfiles.forEach((profile) => {
98
- modelInfo += `- ${profile.name}
99
- `;
100
- modelInfo += ` - provider: ${profile.provider}
101
- `;
102
- modelInfo += ` - model: ${profile.modelName}
103
- `;
104
- modelInfo += ` - baseURL: ${profile.baseURL}
105
- `;
106
- modelInfo += ` - maxTokens: ${profile.maxTokens}
107
- `;
108
- modelInfo += ` - contextLength: ${profile.contextLength}
109
- `;
110
- if (profile.reasoningEffort) {
111
- modelInfo += ` - reasoning effort: ${profile.reasoningEffort}
112
- `;
113
- }
114
- });
115
- }
116
- const body = encodeURIComponent(`
117
- ## Bug Description
118
- ${description}
119
-
120
- ## Environment Info
121
- - Platform: ${env.platform}
122
- - Terminal: ${env.terminal}
123
- - Version: ${MACRO.VERSION || "unknown"}
124
-
125
- ${modelInfo}`);
126
- return `${GITHUB_ISSUES_REPO_URL}/new?title=${encodeURIComponent(title)}&body=${body}&labels=user-reported,bug`;
127
- }
128
- async function generateTitle(description) {
129
- const response = await queryQuick({
130
- systemPrompt: [
131
- 'Generate a concise issue title (max 80 chars) that captures the key point of this feedback. Do not include quotes or prefixes like "Feedback:" or "Issue:". If you cannot generate a title, just use "User Feedback".'
132
- ],
133
- userPrompt: description
134
- });
135
- const title = response.message.content[0]?.type === "text" ? response.message.content[0].text : "Bug Report";
136
- if (title.startsWith(API_ERROR_MESSAGE_PREFIX)) {
137
- return `Bug Report: ${description.slice(0, 60)}${description.length > 60 ? "..." : ""}`;
138
- }
139
- return title;
140
- }
141
- async function submitFeedback(data) {
142
- return { success: true, feedbackId: "123" };
143
- }
144
- export {
145
- Bug
146
- };
147
- //# sourceMappingURL=Bug.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/components/Bug.tsx"],
4
- "sourcesContent": ["import { Box, Text, useInput } from 'ink'\nimport * as React from 'react'\nimport { useState, useCallback, useEffect } from 'react'\nimport { getTheme } from '../utils/theme'\nimport { getMessagesGetter } from '../messages'\nimport type { Message } from '../query'\nimport TextInput from './TextInput'\nimport { logError, getInMemoryErrors } from '../utils/log'\nimport { env } from '../utils/env'\nimport { getGitState, getIsGit, GitRepoState } from '../utils/git'\nimport { useTerminalSize } from '../hooks/useTerminalSize'\nimport { getAnthropicApiKey, getGlobalConfig } from '../utils/config'\nimport { USER_AGENT } from '../utils/http'\nimport { logEvent } from '../services/statsig'\nimport { PRODUCT_NAME } from '../constants/product'\nimport { API_ERROR_MESSAGE_PREFIX, queryQuick } from '../services/claude'\nimport { openBrowser } from '../utils/browser'\nimport { useExitOnCtrlCD } from '../hooks/useExitOnCtrlCD'\nimport { MACRO } from '../constants/macros'\nimport { GITHUB_ISSUES_REPO_URL } from '../constants/product'\n\ntype Props = {\n onDone(result: string): void\n}\n\ntype Step = 'userInput' | 'consent' | 'submitting' | 'done'\n\ntype FeedbackData = {\n // Removing because of privacy concerns. Add this back in when we have a more\n // robust tool for viewing feedback data that can de-identify users\n // user_id: string\n // session_id: string\n message_count: number\n datetime: string\n description: string\n platform: string\n gitRepo: boolean\n version: string | null\n transcript: Message[]\n}\n\nexport function Bug({ onDone }: Props): React.ReactNode {\n const [step, setStep] = useState<Step>('userInput')\n const [cursorOffset, setCursorOffset] = useState(0)\n const [description, setDescription] = useState('')\n const [feedbackId, setFeedbackId] = useState<string | null>(null)\n const [error, setError] = useState<string | null>(null)\n const [envInfo, setEnvInfo] = useState<{\n isGit: boolean\n gitState: GitRepoState | null\n }>({ isGit: false, gitState: null })\n const [title, setTitle] = useState<string | null>(null)\n const textInputColumns = useTerminalSize().columns - 4\n const messages = getMessagesGetter()()\n\n useEffect(() => {\n async function loadEnvInfo() {\n const isGit = await getIsGit()\n let gitState: GitRepoState | null = null\n if (isGit) {\n gitState = await getGitState()\n }\n setEnvInfo({ isGit, gitState })\n }\n void loadEnvInfo()\n }, [])\n\n const exitState = useExitOnCtrlCD(() => process.exit(0))\n\n const submitReport = useCallback(async () => {\n setStep('done')\n // setStep('submitting')\n // setError(null)\n // setFeedbackId(null)\n\n // const reportData = {\n // message_count: messages.length,\n // datetime: new Date().toISOString(),\n // description,\n // platform: env.platform,\n // gitRepo: envInfo.isGit,\n // terminal: env.terminal,\n // version: MACRO.VERSION,\n // transcript: messages,\n // errors: getInMemoryErrors(),\n // }\n\n // const [result, t] = await Promise.all([\n // submitFeedback(reportData),\n // generateTitle(description),\n // ])\n\n // setTitle(t)\n\n // if (result.success) {\n // if (result.feedbackId) {\n // setFeedbackId(result.feedbackId)\n // logEvent('tengu_bug_report_submitted', {\n // feedback_id: result.feedbackId,\n // })\n // }\n // setStep('done')\n // } else {\n // console.log(result)\n // setError('Could not submit feedback. Please try again later.')\n // setStep('userInput')\n // }\n }, [description, envInfo.isGit, messages])\n\n useInput((input, key) => {\n // Allow any key press to close the dialog when done or when there's an error\n // if (step === 'done') {\n // if (key.return && feedbackId && title) {\n // // Open GitHub issue URL when Enter is pressed\n // const issueUrl = createGitHubIssueUrl(feedbackId, title, description)\n // void openBrowser(issueUrl)\n // }\n // onDone('<bash-stdout>Bug report submitted</bash-stdout>')\n // return\n // }\n\n if (error) {\n onDone('<bash-stderr>Error submitting bug report</bash-stderr>')\n return\n }\n\n if (key.escape) {\n onDone('<bash-stderr>Bug report cancelled</bash-stderr>')\n return\n }\n\n if (step === 'consent' && (key.return || input === ' ')) {\n const issueUrl = createGitHubIssueUrl(\n feedbackId,\n description.slice(0, 80),\n description,\n )\n void openBrowser(issueUrl)\n onDone('<bash-stdout>Bug report submitted</bash-stdout>')\n }\n })\n\n const theme = getTheme()\n\n return (\n <>\n <Box\n flexDirection=\"column\"\n borderStyle=\"round\"\n borderColor={theme.permission}\n paddingX={1}\n paddingBottom={1}\n gap={1}\n >\n <Text bold color={theme.permission}>\n Submit Bug Report\n </Text>\n {step === 'userInput' && (\n <Box flexDirection=\"column\" gap={1}>\n <Text>\n Describe the issue below and copy/paste any errors you see:\n </Text>\n <TextInput\n value={description}\n onChange={setDescription}\n columns={textInputColumns}\n onSubmit={() => setStep('consent')}\n onExitMessage={() =>\n onDone('<bash-stderr>Bug report cancelled</bash-stderr>')\n }\n cursorOffset={cursorOffset}\n onChangeCursorOffset={setCursorOffset}\n />\n {error && (\n <Box flexDirection=\"column\" gap={1}>\n <Text color=\"red\">{error}</Text>\n <Text dimColor>Press any key to close</Text>\n </Box>\n )}\n </Box>\n )}\n\n {step === 'consent' && (\n <Box flexDirection=\"column\">\n <Text>This report will include:</Text>\n <Box marginLeft={2} flexDirection=\"column\">\n <Text>\n - Your bug description: <Text dimColor>{description}</Text>\n </Text>\n <Text>\n - Environment info:{' '}\n <Text dimColor>\n {env.platform}, {env.terminal}, v{MACRO.VERSION}\n </Text>\n </Text>\n {/* {envInfo.gitState && (\n <Text>\n - Git repo metadata:{' '}\n <Text dimColor>\n {envInfo.gitState.branchName}\n {envInfo.gitState.commitHash\n ? `, ${envInfo.gitState.commitHash.slice(0, 7)}`\n : ''}\n {envInfo.gitState.remoteUrl\n ? ` @ ${envInfo.gitState.remoteUrl}`\n : ''}\n {!envInfo.gitState.isHeadOnRemote && ', not synced'}\n {!envInfo.gitState.isClean && ', has local changes'}\n </Text>\n </Text>\n )} */}\n <Text>- Model settings (no api keys)</Text>\n </Box>\n {/* <Box marginTop={1}>\n <Text wrap=\"wrap\" dimColor>\n We will use your feedback to debug related issues or to improve{' '}\n {PRODUCT_NAME}&apos;s functionality (eg. to reduce the risk of\n bugs occurring in the future). Anthropic will not train\n generative models using feedback from {PRODUCT_NAME}.\n </Text>\n </Box>\n <Box marginTop={1}>\n <Text>\n Press <Text bold>Enter</Text> to confirm and submit.\n </Text>\n </Box> */}\n </Box>\n )}\n\n {step === 'submitting' && (\n <Box flexDirection=\"row\" gap={1}>\n <Text>Submitting report\u2026</Text>\n </Box>\n )}\n\n {step === 'done' && (\n <Box flexDirection=\"column\">\n <Text color={getTheme().success}>Thank you for your report!</Text>\n {feedbackId && <Text dimColor>Feedback ID: {feedbackId}</Text>}\n <Box marginTop={1}>\n <Text>Press </Text>\n <Text bold>Enter </Text>\n <Text>\n to also create a GitHub issue, or any other key to close.\n </Text>\n </Box>\n </Box>\n )}\n </Box>\n\n <Box marginLeft={3}>\n <Text dimColor>\n {exitState.pending ? (\n <>Press {exitState.keyName} again to exit</>\n ) : step === 'userInput' ? (\n <>Enter to continue \u00B7 Esc to cancel</>\n ) : step === 'consent' ? (\n <>Enter to open browser to create GitHub issue \u00B7 Esc to cancel</>\n ) : null}\n </Text>\n </Box>\n </>\n )\n}\n\nfunction createGitHubIssueUrl(\n feedbackId: string,\n title: string,\n description: string,\n): string {\n const globalConfig = getGlobalConfig()\n\n // Get ModelProfile information instead of legacy model info\n const modelProfiles = globalConfig.modelProfiles || []\n const activeProfiles = modelProfiles.filter(p => p.isActive)\n\n let modelInfo = '## Models\\n'\n if (activeProfiles.length === 0) {\n modelInfo += '- No model profiles configured\\n'\n } else {\n activeProfiles.forEach(profile => {\n modelInfo += `- ${profile.name}\\n`\n modelInfo += ` - provider: ${profile.provider}\\n`\n modelInfo += ` - model: ${profile.modelName}\\n`\n modelInfo += ` - baseURL: ${profile.baseURL}\\n`\n modelInfo += ` - maxTokens: ${profile.maxTokens}\\n`\n modelInfo += ` - contextLength: ${profile.contextLength}\\n`\n if (profile.reasoningEffort) {\n modelInfo += ` - reasoning effort: ${profile.reasoningEffort}\\n`\n }\n })\n }\n\n const body = encodeURIComponent(`\n## Bug Description\n${description}\n\n## Environment Info\n- Platform: ${env.platform}\n- Terminal: ${env.terminal}\n- Version: ${MACRO.VERSION || 'unknown'}\n\n${modelInfo}`)\n return `${GITHUB_ISSUES_REPO_URL}/new?title=${encodeURIComponent(title)}&body=${body}&labels=user-reported,bug`\n}\n\nasync function generateTitle(description: string): Promise<string> {\n const response = await queryQuick({\n systemPrompt: [\n 'Generate a concise issue title (max 80 chars) that captures the key point of this feedback. Do not include quotes or prefixes like \"Feedback:\" or \"Issue:\". If you cannot generate a title, just use \"User Feedback\".',\n ],\n userPrompt: description,\n })\n const title =\n response.message.content[0]?.type === 'text'\n ? response.message.content[0].text\n : 'Bug Report'\n if (title.startsWith(API_ERROR_MESSAGE_PREFIX)) {\n return `Bug Report: ${description.slice(0, 60)}${description.length > 60 ? '...' : ''}`\n }\n return title\n}\n\nasync function submitFeedback(\n data: FeedbackData,\n): Promise<{ success: boolean; feedbackId?: string }> {\n return { success: true, feedbackId: '123' }\n // try {\n // const apiKey = getAnthropicApiKey()\n // if (!apiKey) {\n // return { success: false }\n // }\n\n // const response = await fetch(\n // 'https://api.anthropic.com/api/claude_cli_feedback',\n // {\n // method: 'POST',\n // headers: {\n // 'Content-Type': 'application/json',\n // 'User-Agent': USER_AGENT,\n // 'x-api-key': apiKey,\n // },\n // body: JSON.stringify({\n // content: JSON.stringify(data),\n // }),\n // },\n // )\n\n // if (response.ok) {\n // const result = await response.json()\n // if (result?.feedback_id) {\n // return { success: true, feedbackId: result.feedback_id }\n // }\n // logError('Failed to submit feedback: request did not return feedback_id')\n // return { success: false }\n // }\n\n // logError('Failed to submit feedback:' + response.status)\n // return { success: false }\n // } catch (err) {\n // logError(\n // 'Error submitting feedback: ' +\n // (err instanceof Error ? err.message : 'Unknown error'),\n // )\n // return { success: false }\n // }\n}\n"],
5
- "mappings": "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",
6
- "names": []
7
- }