@within-7/minto 0.4.1 → 0.4.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 (391) hide show
  1. package/dist/Tool.js +7 -0
  2. package/dist/Tool.js.map +2 -2
  3. package/dist/commands/agents/AgentsCommand.js +1 -1
  4. package/dist/commands/agents/AgentsCommand.js.map +2 -2
  5. package/dist/commands/agents/constants.js +2 -2
  6. package/dist/commands/agents/constants.js.map +2 -2
  7. package/dist/commands/clear.js +4 -3
  8. package/dist/commands/clear.js.map +2 -2
  9. package/dist/commands/compact.js +2 -2
  10. package/dist/commands/compact.js.map +1 -1
  11. package/dist/commands/context.js +3 -1
  12. package/dist/commands/context.js.map +2 -2
  13. package/dist/commands/login.js +128 -0
  14. package/dist/commands/login.js.map +7 -0
  15. package/dist/commands/memory.js +33 -82
  16. package/dist/commands/memory.js.map +2 -2
  17. package/dist/commands/quit.js +3 -1
  18. package/dist/commands/quit.js.map +2 -2
  19. package/dist/commands/resume.js +39 -239
  20. package/dist/commands/resume.js.map +2 -2
  21. package/dist/commands/tasks.js +1 -1
  22. package/dist/commands/tasks.js.map +2 -2
  23. package/dist/commands/terminalSetup.js +6 -2
  24. package/dist/commands/terminalSetup.js.map +2 -2
  25. package/dist/commands.js +2 -0
  26. package/dist/commands.js.map +2 -2
  27. package/dist/components/AgentDetailView.js +126 -0
  28. package/dist/components/AgentDetailView.js.map +7 -0
  29. package/dist/components/AgentThinkingBlock.js +1 -1
  30. package/dist/components/AgentThinkingBlock.js.map +2 -2
  31. package/dist/components/AgentViewBanner.js +22 -0
  32. package/dist/components/AgentViewBanner.js.map +7 -0
  33. package/dist/components/HeaderBar.js +1 -1
  34. package/dist/components/HeaderBar.js.map +2 -2
  35. package/dist/components/Help.js +8 -1
  36. package/dist/components/Help.js.map +2 -2
  37. package/dist/components/HotkeyHelpPanel.js +26 -8
  38. package/dist/components/HotkeyHelpPanel.js.map +2 -2
  39. package/dist/components/IdleNotificationBar.js +10 -0
  40. package/dist/components/IdleNotificationBar.js.map +7 -0
  41. package/dist/components/ModelSelector/ModelSelector.js +55 -20
  42. package/dist/components/ModelSelector/ModelSelector.js.map +2 -2
  43. package/dist/components/PromptInput.js +186 -115
  44. package/dist/components/PromptInput.js.map +2 -2
  45. package/dist/components/RewindPanel.js +272 -0
  46. package/dist/components/RewindPanel.js.map +7 -0
  47. package/dist/components/Spinner.js +10 -21
  48. package/dist/components/Spinner.js.map +2 -2
  49. package/dist/components/StreamingTextPreview.js +29 -0
  50. package/dist/components/StreamingTextPreview.js.map +7 -0
  51. package/dist/components/SubagentBlock.js +3 -2
  52. package/dist/components/SubagentBlock.js.map +2 -2
  53. package/dist/components/SubagentProgress.js +4 -4
  54. package/dist/components/SubagentProgress.js.map +2 -2
  55. package/dist/components/TabbedListView/SearchInput.js +1 -1
  56. package/dist/components/TabbedListView/SearchInput.js.map +2 -2
  57. package/dist/components/TabbedListView/TabbedListView.js +87 -41
  58. package/dist/components/TabbedListView/TabbedListView.js.map +2 -2
  59. package/dist/components/TaskCard.js +4 -4
  60. package/dist/components/TaskCard.js.map +2 -2
  61. package/dist/components/TeamMemberPanel.js +107 -0
  62. package/dist/components/TeamMemberPanel.js.map +7 -0
  63. package/dist/components/ThinkingSelector.js +84 -0
  64. package/dist/components/ThinkingSelector.js.map +7 -0
  65. package/dist/components/TitledDivider.js +26 -0
  66. package/dist/components/TitledDivider.js.map +7 -0
  67. package/dist/components/TodoPanel.js +31 -30
  68. package/dist/components/TodoPanel.js.map +2 -2
  69. package/dist/components/TokenWarning.js +28 -7
  70. package/dist/components/TokenWarning.js.map +2 -2
  71. package/dist/components/messages/AssistantTextMessage.js +5 -2
  72. package/dist/components/messages/AssistantTextMessage.js.map +2 -2
  73. package/dist/components/messages/AssistantToolUseMessage.js +9 -1
  74. package/dist/components/messages/AssistantToolUseMessage.js.map +2 -2
  75. package/dist/components/messages/DefaultToolResultFallback.js +11 -0
  76. package/dist/components/messages/DefaultToolResultFallback.js.map +7 -0
  77. package/dist/components/messages/ParallelTasksGroupView.js +14 -6
  78. package/dist/components/messages/ParallelTasksGroupView.js.map +2 -2
  79. package/dist/components/messages/TaskInModuleView.js +27 -27
  80. package/dist/components/messages/TaskInModuleView.js.map +2 -2
  81. package/dist/components/messages/UserGuidanceMessage.js +26 -0
  82. package/dist/components/messages/UserGuidanceMessage.js.map +7 -0
  83. package/dist/components/messages/UserPromptMessage.js +2 -1
  84. package/dist/components/messages/UserPromptMessage.js.map +2 -2
  85. package/dist/components/messages/UserTeamNotificationMessage.js +91 -0
  86. package/dist/components/messages/UserTeamNotificationMessage.js.map +7 -0
  87. package/dist/components/messages/UserTextMessage.js +8 -0
  88. package/dist/components/messages/UserTextMessage.js.map +2 -2
  89. package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js +4 -2
  90. package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js.map +2 -2
  91. package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js +18 -1
  92. package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js.map +2 -2
  93. package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +12 -1
  94. package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js.map +2 -2
  95. package/dist/components/permissions/PermissionRequest.js +4 -0
  96. package/dist/components/permissions/PermissionRequest.js.map +2 -2
  97. package/dist/components/permissions/PlanApprovalRequest.js +164 -0
  98. package/dist/components/permissions/PlanApprovalRequest.js.map +7 -0
  99. package/dist/constants/agentTeams.js +17 -0
  100. package/dist/constants/agentTeams.js.map +7 -0
  101. package/dist/constants/macros.js +2 -1
  102. package/dist/constants/macros.js.map +2 -2
  103. package/dist/constants/prompts/agentPrompt.js +1 -0
  104. package/dist/constants/prompts/agentPrompt.js.map +2 -2
  105. package/dist/constants/prompts/autoMemory.js +39 -0
  106. package/dist/constants/prompts/autoMemory.js.map +7 -0
  107. package/dist/constants/prompts/codeConventions.js +1 -13
  108. package/dist/constants/prompts/codeConventions.js.map +2 -2
  109. package/dist/constants/prompts/doingTasks.js +21 -2
  110. package/dist/constants/prompts/doingTasks.js.map +2 -2
  111. package/dist/constants/prompts/envInfo.js +6 -7
  112. package/dist/constants/prompts/envInfo.js.map +2 -2
  113. package/dist/constants/prompts/index.js +27 -5
  114. package/dist/constants/prompts/index.js.map +2 -2
  115. package/dist/constants/prompts/taskManagement.js +2 -43
  116. package/dist/constants/prompts/taskManagement.js.map +2 -2
  117. package/dist/constants/prompts/teamOverlays.js +50 -0
  118. package/dist/constants/prompts/teamOverlays.js.map +7 -0
  119. package/dist/constants/prompts/toneAndStyle.js +4 -29
  120. package/dist/constants/prompts/toneAndStyle.js.map +2 -2
  121. package/dist/constants/prompts/toolUsagePolicy.js +7 -22
  122. package/dist/constants/prompts/toolUsagePolicy.js.map +2 -2
  123. package/dist/constants/toolInputExamples.js +2 -2
  124. package/dist/constants/toolInputExamples.js.map +2 -2
  125. package/dist/context.js +39 -6
  126. package/dist/context.js.map +2 -2
  127. package/dist/core/backupManager.js +1 -1
  128. package/dist/core/backupManager.js.map +2 -2
  129. package/dist/core/permissions/rules/planModeRule.js +1 -1
  130. package/dist/core/permissions/rules/planModeRule.js.map +1 -1
  131. package/dist/core/permissions/rules/safeModeRule.js +1 -1
  132. package/dist/core/permissions/rules/safeModeRule.js.map +1 -1
  133. package/dist/engine/AgentEngine.js +902 -0
  134. package/dist/engine/AgentEngine.js.map +7 -0
  135. package/dist/engine/EngineRegistry.js +89 -0
  136. package/dist/engine/EngineRegistry.js.map +7 -0
  137. package/dist/engine/foregroundAdapter.js +191 -0
  138. package/dist/engine/foregroundAdapter.js.map +7 -0
  139. package/dist/engine/index.js +15 -0
  140. package/dist/engine/index.js.map +7 -0
  141. package/dist/engine/types.js +1 -0
  142. package/dist/engine/types.js.map +7 -0
  143. package/dist/entrypoints/cli.js +410 -79
  144. package/dist/entrypoints/cli.js.map +3 -3
  145. package/dist/hooks/useAgentEngine.js +129 -0
  146. package/dist/hooks/useAgentEngine.js.map +7 -0
  147. package/dist/hooks/useAgentTokenStats.js +0 -16
  148. package/dist/hooks/useAgentTokenStats.js.map +2 -2
  149. package/dist/hooks/useCanUseTool.js +47 -2
  150. package/dist/hooks/useCanUseTool.js.map +2 -2
  151. package/dist/hooks/useDeferredLoading.js +4 -1
  152. package/dist/hooks/useDeferredLoading.js.map +2 -2
  153. package/dist/hooks/useIdleNotifications.js +66 -0
  154. package/dist/hooks/useIdleNotifications.js.map +7 -0
  155. package/dist/hooks/useSessionTracking.js +9 -7
  156. package/dist/hooks/useSessionTracking.js.map +2 -2
  157. package/dist/hooks/useTeamMembers.js +51 -0
  158. package/dist/hooks/useTeamMembers.js.map +7 -0
  159. package/dist/i18n/locales/en.js +77 -12
  160. package/dist/i18n/locales/en.js.map +2 -2
  161. package/dist/i18n/locales/zh-CN.js +77 -12
  162. package/dist/i18n/locales/zh-CN.js.map +2 -2
  163. package/dist/i18n/types.js.map +1 -1
  164. package/dist/messages.js.map +2 -2
  165. package/dist/permissions.js +113 -7
  166. package/dist/permissions.js.map +2 -2
  167. package/dist/query.js +135 -37
  168. package/dist/query.js.map +2 -2
  169. package/dist/screens/REPL.js +504 -361
  170. package/dist/screens/REPL.js.map +3 -3
  171. package/dist/screens/ResumeConversation.js +199 -14
  172. package/dist/screens/ResumeConversation.js.map +2 -2
  173. package/dist/services/adapters/base.js.map +1 -1
  174. package/dist/services/agentTeams/backends/headless.js +108 -0
  175. package/dist/services/agentTeams/backends/headless.js.map +7 -0
  176. package/dist/services/agentTeams/backends/inProcess.js +102 -0
  177. package/dist/services/agentTeams/backends/inProcess.js.map +7 -0
  178. package/dist/services/agentTeams/backends/resolver.js +18 -0
  179. package/dist/services/agentTeams/backends/resolver.js.map +7 -0
  180. package/dist/services/agentTeams/backends/tmux.js +168 -0
  181. package/dist/services/agentTeams/backends/tmux.js.map +7 -0
  182. package/dist/services/agentTeams/backends/types.js +1 -0
  183. package/dist/services/agentTeams/backends/types.js.map +7 -0
  184. package/dist/services/agentTeams/heartbeat.js +88 -0
  185. package/dist/services/agentTeams/heartbeat.js.map +7 -0
  186. package/dist/services/agentTeams/index.js +42 -2
  187. package/dist/services/agentTeams/index.js.map +2 -2
  188. package/dist/services/agentTeams/injectionChannel.js +105 -0
  189. package/dist/services/agentTeams/injectionChannel.js.map +7 -0
  190. package/dist/services/agentTeams/mailbox.js +410 -30
  191. package/dist/services/agentTeams/mailbox.js.map +2 -2
  192. package/dist/services/agentTeams/messageFormatter.js +80 -0
  193. package/dist/services/agentTeams/messageFormatter.js.map +7 -0
  194. package/dist/services/agentTeams/permissionDelegation.js +71 -0
  195. package/dist/services/agentTeams/permissionDelegation.js.map +7 -0
  196. package/dist/services/agentTeams/teamEvents.js +45 -0
  197. package/dist/services/agentTeams/teamEvents.js.map +7 -0
  198. package/dist/services/agentTeams/teamManager.js +251 -34
  199. package/dist/services/agentTeams/teamManager.js.map +2 -2
  200. package/dist/services/agentTeams/teamTaskStore.js +290 -61
  201. package/dist/services/agentTeams/teamTaskStore.js.map +2 -2
  202. package/dist/services/agentTeams/teammateSpawner.js +99 -18
  203. package/dist/services/agentTeams/teammateSpawner.js.map +2 -2
  204. package/dist/services/hookExecutor.js +51 -8
  205. package/dist/services/hookExecutor.js.map +2 -2
  206. package/dist/services/llm/anthropicProvider.js +56 -59
  207. package/dist/services/llm/anthropicProvider.js.map +2 -2
  208. package/dist/services/llm/dispatch.js +24 -5
  209. package/dist/services/llm/dispatch.js.map +2 -2
  210. package/dist/services/llm/openaiProvider.js +115 -136
  211. package/dist/services/llm/openaiProvider.js.map +3 -3
  212. package/dist/services/llm/types.js +89 -15
  213. package/dist/services/llm/types.js.map +2 -2
  214. package/dist/services/mcpClient.js +80 -4
  215. package/dist/services/mcpClient.js.map +2 -2
  216. package/dist/services/mintoAuth.js +299 -0
  217. package/dist/services/mintoAuth.js.map +7 -0
  218. package/dist/services/oauth.js +3 -3
  219. package/dist/services/oauth.js.map +2 -2
  220. package/dist/services/openai.js +91 -20
  221. package/dist/services/openai.js.map +2 -2
  222. package/dist/services/plugins/pluginRuntime.js +11 -5
  223. package/dist/services/plugins/pluginRuntime.js.map +2 -2
  224. package/dist/services/plugins/pluginValidation.js +4 -2
  225. package/dist/services/plugins/pluginValidation.js.map +2 -2
  226. package/dist/services/sandbox/sandboxController.js +11 -3
  227. package/dist/services/sandbox/sandboxController.js.map +2 -2
  228. package/dist/services/sessionMemoryInjector.js +77 -0
  229. package/dist/services/sessionMemoryInjector.js.map +7 -0
  230. package/dist/services/systemReminder.js +130 -8
  231. package/dist/services/systemReminder.js.map +2 -2
  232. package/dist/services/taskStore.js +199 -8
  233. package/dist/services/taskStore.js.map +3 -3
  234. package/dist/services/topicDetector.js +169 -0
  235. package/dist/services/topicDetector.js.map +7 -0
  236. package/dist/tools/AskExpertModelTool/AskExpertModelTool.js +0 -13
  237. package/dist/tools/AskExpertModelTool/AskExpertModelTool.js.map +2 -2
  238. package/dist/tools/BashTool/BashTool.js +51 -28
  239. package/dist/tools/BashTool/BashTool.js.map +2 -2
  240. package/dist/tools/BashTool/prompt.js +95 -118
  241. package/dist/tools/BashTool/prompt.js.map +2 -2
  242. package/dist/tools/BashTool/utils.js +39 -1
  243. package/dist/tools/BashTool/utils.js.map +2 -2
  244. package/dist/tools/EnterWorktreeTool/EnterWorktreeTool.js +121 -0
  245. package/dist/tools/EnterWorktreeTool/EnterWorktreeTool.js.map +7 -0
  246. package/dist/tools/EnterWorktreeTool/prompt.js +22 -0
  247. package/dist/tools/EnterWorktreeTool/prompt.js.map +7 -0
  248. package/dist/tools/FileEditTool/FileEditTool.js +9 -4
  249. package/dist/tools/FileEditTool/FileEditTool.js.map +2 -2
  250. package/dist/tools/FileEditTool/prompt.js +3 -7
  251. package/dist/tools/FileEditTool/prompt.js.map +2 -2
  252. package/dist/tools/FileReadTool/FileReadTool.js +125 -3
  253. package/dist/tools/FileReadTool/FileReadTool.js.map +2 -2
  254. package/dist/tools/FileReadTool/prompt.js +1 -2
  255. package/dist/tools/FileReadTool/prompt.js.map +2 -2
  256. package/dist/tools/FileWriteTool/prompt.js +3 -5
  257. package/dist/tools/FileWriteTool/prompt.js.map +2 -2
  258. package/dist/tools/GlobTool/GlobTool.js +3 -2
  259. package/dist/tools/GlobTool/GlobTool.js.map +2 -2
  260. package/dist/tools/GrepTool/GrepTool.js +16 -5
  261. package/dist/tools/GrepTool/GrepTool.js.map +2 -2
  262. package/dist/tools/ListMcpResourcesTool/ListMcpResourcesTool.js.map +2 -2
  263. package/dist/tools/MCPSearchTool/MCPSearchTool.js +172 -0
  264. package/dist/tools/MCPSearchTool/MCPSearchTool.js.map +7 -0
  265. package/dist/tools/MCPSearchTool/prompt.js +77 -0
  266. package/dist/tools/MCPSearchTool/prompt.js.map +7 -0
  267. package/dist/tools/MultiEditTool/prompt.js +4 -7
  268. package/dist/tools/MultiEditTool/prompt.js.map +2 -2
  269. package/dist/tools/PlanModeTool/EnterPlanModeTool.js +12 -8
  270. package/dist/tools/PlanModeTool/EnterPlanModeTool.js.map +2 -2
  271. package/dist/tools/PlanModeTool/ExitPlanModeTool.js +54 -1
  272. package/dist/tools/PlanModeTool/ExitPlanModeTool.js.map +2 -2
  273. package/dist/tools/PlanModeTool/prompt.js +23 -74
  274. package/dist/tools/PlanModeTool/prompt.js.map +2 -2
  275. package/dist/tools/SendMessageTool/SendMessageTool.js +341 -0
  276. package/dist/tools/SendMessageTool/SendMessageTool.js.map +7 -0
  277. package/dist/tools/SendMessageTool/prompt.js +44 -0
  278. package/dist/tools/SendMessageTool/prompt.js.map +7 -0
  279. package/dist/tools/TaskCreateTool/prompt.js +15 -4
  280. package/dist/tools/TaskCreateTool/prompt.js.map +2 -2
  281. package/dist/tools/TaskListTool/prompt.js +18 -3
  282. package/dist/tools/TaskListTool/prompt.js.map +2 -2
  283. package/dist/tools/TaskOutputTool/prompt.js +4 -3
  284. package/dist/tools/TaskOutputTool/prompt.js.map +2 -2
  285. package/dist/tools/TaskTool/TaskTool.js +762 -98
  286. package/dist/tools/TaskTool/TaskTool.js.map +3 -3
  287. package/dist/tools/TaskTool/constants.js +8 -2
  288. package/dist/tools/TaskTool/constants.js.map +2 -2
  289. package/dist/tools/TaskTool/prompt.js +74 -70
  290. package/dist/tools/TaskTool/prompt.js.map +2 -2
  291. package/dist/tools/TaskUpdateTool/TaskUpdateTool.js +15 -1
  292. package/dist/tools/TaskUpdateTool/TaskUpdateTool.js.map +2 -2
  293. package/dist/tools/TeamCreateTool/TeamCreateTool.js +129 -0
  294. package/dist/tools/TeamCreateTool/TeamCreateTool.js.map +7 -0
  295. package/dist/tools/TeamCreateTool/prompt.js +58 -0
  296. package/dist/tools/TeamCreateTool/prompt.js.map +7 -0
  297. package/dist/tools/TeamDeleteTool/TeamDeleteTool.js +151 -0
  298. package/dist/tools/TeamDeleteTool/TeamDeleteTool.js.map +7 -0
  299. package/dist/tools/TeamDeleteTool/prompt.js +16 -0
  300. package/dist/tools/TeamDeleteTool/prompt.js.map +7 -0
  301. package/dist/tools/URLFetcherTool/URLFetcherTool.js +106 -15
  302. package/dist/tools/URLFetcherTool/URLFetcherTool.js.map +2 -2
  303. package/dist/tools/URLFetcherTool/prompt.js +3 -2
  304. package/dist/tools/URLFetcherTool/prompt.js.map +2 -2
  305. package/dist/tools/WebSearchTool/WebSearchTool.js +2 -1
  306. package/dist/tools/WebSearchTool/WebSearchTool.js.map +2 -2
  307. package/dist/tools/WebSearchTool/prompt.js +5 -4
  308. package/dist/tools/WebSearchTool/prompt.js.map +2 -2
  309. package/dist/tools.js +100 -20
  310. package/dist/tools.js.map +2 -2
  311. package/dist/types/PermissionMode.js +35 -6
  312. package/dist/types/PermissionMode.js.map +2 -2
  313. package/dist/types/hooks.js +2 -0
  314. package/dist/types/hooks.js.map +2 -2
  315. package/dist/types/plugin.js +2 -0
  316. package/dist/types/plugin.js.map +3 -3
  317. package/dist/utils/CircuitBreaker.js +15 -9
  318. package/dist/utils/CircuitBreaker.js.map +2 -2
  319. package/dist/utils/agentLoader.js +249 -112
  320. package/dist/utils/agentLoader.js.map +2 -2
  321. package/dist/utils/animationManager.js +40 -3
  322. package/dist/utils/animationManager.js.map +2 -2
  323. package/dist/utils/ask.js +7 -6
  324. package/dist/utils/ask.js.map +2 -2
  325. package/dist/utils/atomicWrite.js +23 -0
  326. package/dist/utils/atomicWrite.js.map +7 -0
  327. package/dist/utils/autoCompactCore.js +73 -56
  328. package/dist/utils/autoCompactCore.js.map +2 -2
  329. package/dist/utils/autoMemoryPaths.js +89 -0
  330. package/dist/utils/autoMemoryPaths.js.map +7 -0
  331. package/dist/utils/config.js +63 -38
  332. package/dist/utils/config.js.map +2 -2
  333. package/dist/utils/configSchema.js +13 -8
  334. package/dist/utils/configSchema.js.map +2 -2
  335. package/dist/utils/credentials/index.js +14 -0
  336. package/dist/utils/credentials/index.js.map +2 -2
  337. package/dist/utils/dualPath.js +24 -0
  338. package/dist/utils/dualPath.js.map +7 -0
  339. package/dist/utils/exit.js +66 -7
  340. package/dist/utils/exit.js.map +2 -2
  341. package/dist/utils/externalEditor.js +155 -0
  342. package/dist/utils/externalEditor.js.map +7 -0
  343. package/dist/utils/fileLock.js +67 -0
  344. package/dist/utils/fileLock.js.map +7 -0
  345. package/dist/utils/format.js +24 -14
  346. package/dist/utils/format.js.map +2 -2
  347. package/dist/utils/globalErrorHandler.js +5 -96
  348. package/dist/utils/globalErrorHandler.js.map +3 -3
  349. package/dist/utils/groupHandlers/parallelTasksHandler.js +5 -3
  350. package/dist/utils/groupHandlers/parallelTasksHandler.js.map +2 -2
  351. package/dist/utils/groupHandlers/taskHandler.js +2 -2
  352. package/dist/utils/groupHandlers/taskHandler.js.map +2 -2
  353. package/dist/utils/hookManager.js +64 -6
  354. package/dist/utils/hookManager.js.map +2 -2
  355. package/dist/utils/log.js +6 -2
  356. package/dist/utils/log.js.map +2 -2
  357. package/dist/utils/markdown.js +237 -19
  358. package/dist/utils/markdown.js.map +2 -2
  359. package/dist/utils/messageContextManager.js +18 -5
  360. package/dist/utils/messageContextManager.js.map +2 -2
  361. package/dist/utils/messageGroupManager.js +1 -1
  362. package/dist/utils/messageGroupManager.js.map +2 -2
  363. package/dist/utils/messages.js +104 -46
  364. package/dist/utils/messages.js.map +2 -2
  365. package/dist/utils/model.js +2 -2
  366. package/dist/utils/model.js.map +2 -2
  367. package/dist/utils/pasteCache.js +8 -4
  368. package/dist/utils/pasteCache.js.map +2 -2
  369. package/dist/utils/pluginLoader.js +18 -0
  370. package/dist/utils/pluginLoader.js.map +2 -2
  371. package/dist/utils/secureKeyStorage.js +36 -7
  372. package/dist/utils/secureKeyStorage.js.map +2 -2
  373. package/dist/utils/simpleMode.js +7 -0
  374. package/dist/utils/simpleMode.js.map +7 -0
  375. package/dist/utils/streamingState.js +11 -1
  376. package/dist/utils/streamingState.js.map +2 -2
  377. package/dist/utils/taskDisplayUtils.js +2 -1
  378. package/dist/utils/taskDisplayUtils.js.map +2 -2
  379. package/dist/utils/teamConfig.js +2 -2
  380. package/dist/utils/teamConfig.js.map +2 -2
  381. package/dist/utils/thinking.js +6 -2
  382. package/dist/utils/thinking.js.map +3 -3
  383. package/dist/utils/tokenProgress.js +55 -0
  384. package/dist/utils/tokenProgress.js.map +7 -0
  385. package/dist/utils/toolRiskClassification.js +26 -17
  386. package/dist/utils/toolRiskClassification.js.map +2 -2
  387. package/dist/utils/tooling/toolError.js +12 -0
  388. package/dist/utils/tooling/toolError.js.map +7 -0
  389. package/dist/version.js +2 -2
  390. package/dist/version.js.map +1 -1
  391. package/package.json +10 -8
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/components/PromptInput.tsx"],
4
- "sourcesContent": ["import { Box, Text, useInput } from 'ink'\nimport { sample } from 'lodash-es'\nimport * as React from 'react'\nimport { type Message } from '@query'\nimport { processUserInput } from '@utils/messages'\nimport { useArrowKeyHistory } from '@hooks/useArrowKeyHistory'\nimport { useUnifiedCompletion } from '@hooks/useUnifiedCompletion'\nimport { useHistorySearch } from '@hooks/useHistorySearch'\nimport { addToHistory, getHistory } from '@history'\nimport {\n cachePaste,\n createPlaceholder,\n expandPlaceholder,\n type PasteCacheEntry,\n} from '@utils/pasteCache'\nimport TextInput from './TextInput'\nimport { HistorySearchOverlay } from './HistorySearchOverlay'\nimport {\n HotkeyHelpPanel,\n ContextAwareHints,\n type InputContext,\n} from './HotkeyHelpPanel'\nimport { memo, useCallback, useEffect, useMemo, useRef, useState } from 'react'\nimport { countTokens } from '@utils/tokens'\nimport { SentryErrorBoundary } from './SentryErrorBoundary'\nimport { StartupStatusBar, type StartupItem } from './StartupStatus'\nimport type { Command } from '@commands'\nimport type { SetToolJSXFn, Tool } from '@tool'\nimport { TokenWarning, WARNING_THRESHOLD } from './TokenWarning'\nimport { useTerminalSize } from '@hooks/useTerminalSize'\nimport { getTheme } from '@utils/theme'\nimport { BRAND_GRADIENT, SEMANTIC_COLORS } from '@constants/colors'\nimport { getModelManager, reloadModelManager } from '@utils/model'\nimport {\n getGlobalConfig,\n saveGlobalConfig,\n getVerboseLabel,\n} from '@utils/config'\nimport { setTerminalTitle, clearScreen } from '@utils/terminal'\nimport terminalSetup, {\n isShiftEnterKeyBindingInstalled,\n handleHashCommand,\n} from '@commands/terminalSetup'\nimport { usePermissionContext } from '@context/PermissionContext'\nimport { getHookManager } from '@utils/hookManager'\nimport { debug as debugLogger } from '@utils/debugLogger'\nimport { PROJECT_FILE } from '@constants/product'\nimport { t } from '@i18n'\n\n// Async function to interpret the '#' command input using AI\nasync function interpretHashCommand(input: string): Promise<string> {\n // Use the AI to interpret the input\n try {\n const { queryQuick } = await import('@services/claude')\n\n // Create a prompt for the model to interpret the hash command\n const systemPrompt = [\n \"You're helping the user structure notes that will be added to their KODING.md file.\",\n \"Format the user's input into a well-structured note that will be useful for later reference.\",\n 'Add appropriate markdown formatting, headings, bullet points, or other structural elements as needed.',\n 'The goal is to transform the raw note into something that will be more useful when reviewed later.',\n 'You should keep the original meaning but make the structure clear.',\n ]\n\n // Send the request to the AI\n const result = await queryQuick({\n systemPrompt,\n userPrompt: `Transform this note for KODING.md: ${input}`,\n })\n\n // Extract the content from the response\n if (typeof result.message.content === 'string') {\n return result.message.content\n } else if (Array.isArray(result.message.content)) {\n return result.message.content\n .filter(block => block.type === 'text')\n .map(block => (block.type === 'text' ? block.text : ''))\n .join('\\n')\n }\n\n return `# ${input}\\n\\n_Added on ${new Date().toLocaleString()}_`\n } catch (e) {\n // If interpretation fails, return the input with minimal formatting\n return `# ${input}\\n\\n_Added on ${new Date().toLocaleString()}_`\n }\n}\n\ntype Props = {\n commands: Command[]\n forkNumber: number\n messageLogName: string\n isDisabled: boolean\n isLoading: boolean\n onQuery: (\n newMessages: Message[],\n abortController?: AbortController,\n ) => Promise<void>\n debug: boolean\n verbose: boolean // Computed from displayMode for backward compatibility\n verboseToggleMessage?: string | null // Message to show after verbose toggle (survives remount)\n messages: Message[]\n setToolJSX: SetToolJSXFn\n tools: Tool[]\n input: string\n onInputChange: (value: string) => void\n mode: 'bash' | 'prompt' | 'koding'\n onModeChange: (mode: 'bash' | 'prompt' | 'koding') => void\n submitCount: number\n onSubmitCountChange: (updater: (prev: number) => number) => void\n setIsLoading: (isLoading: boolean) => void\n setAbortController: (abortController: AbortController | null) => void\n onShowMessageSelector: () => void\n setForkConvoWithMessagesOnTheNextRender: (\n forkConvoWithMessages: Message[],\n ) => void\n readFileTimestamps: { [filename: string]: number }\n abortController: AbortController | null\n onModelChange?: () => void\n onRollbackConversation?: () => boolean // Phase 4.1: Esc Esc rollback\n onToggleTodoPanel?: () => void // Ctrl+T: Toggle TodoPanel\n onToggleVerbose?: (verbose: boolean) => void | Promise<void> // Ctrl+O: Toggle verbose mode\n onToggleBackgroundPanel?: () => void // View background tasks\n backgroundShellCount?: number // Number of active background shells\n isBackgroundPanelOpen?: boolean // Whether background panel is currently visible\n fallbackMode?: boolean // Whether to use limited input mode (raw mode not supported)\n // Waiting list feature: queue prompts during task execution\n queuedPrompts?: string[] // List of queued prompts waiting to be processed\n onQueuePrompt?: (prompt: string) => void // Callback to add prompt to queue\n onPopQueuedPrompt?: () => string | undefined // Callback to pop last prompt from queue (for up arrow)\n // Unified interrupt callback - handles all cleanup when ESC cancels a request\n onInterrupt?: () => void\n // Whether an overlay (like TabbedListView) is active below PromptInput\n isOverlayActive?: boolean\n // Unmount current REPL (for commands that need to replace the entire UI, like /resume)\n unmount?: () => void\n // Startup status items (MCP servers, version check) shown in footer while loading\n startupItems?: StartupItem[]\n}\n\nfunction getPastedTextPrompt(text: string): string {\n const newlineCount = (text.match(/\\r\\n|\\r|\\n/g) || []).length\n return `[Pasted text +${newlineCount} lines] `\n}\nfunction PromptInput({\n commands,\n forkNumber,\n messageLogName,\n isDisabled,\n isLoading,\n onQuery,\n debug,\n verbose,\n verboseToggleMessage,\n messages,\n setToolJSX,\n tools,\n input,\n onInputChange,\n mode,\n onModeChange,\n submitCount,\n onSubmitCountChange,\n setIsLoading,\n fallbackMode = false,\n abortController,\n setAbortController,\n onShowMessageSelector,\n setForkConvoWithMessagesOnTheNextRender,\n readFileTimestamps,\n onToggleTodoPanel,\n onToggleVerbose,\n onModelChange,\n onRollbackConversation,\n onToggleBackgroundPanel,\n backgroundShellCount = 0,\n isBackgroundPanelOpen = false,\n queuedPrompts = [],\n onQueuePrompt,\n onPopQueuedPrompt,\n onInterrupt,\n isOverlayActive = false,\n unmount,\n startupItems,\n}: Props): React.ReactNode {\n const [exitMessage, setExitMessage] = useState<{\n show: boolean\n key?: string\n }>({ show: false })\n const [message, setMessage] = useState<{ show: boolean; text?: string }>({\n show: false,\n })\n const [modelSwitchMessage, setModelSwitchMessage] = useState<{\n show: boolean\n text?: string\n }>({\n show: false,\n })\n const [pastedImage, setPastedImage] = useState<string | null>(null)\n const [placeholder, setPlaceholder] = useState('')\n const [cursorOffset, setCursorOffset] = useState<number>(input.length)\n const [pastedText, setPastedText] = useState<string | null>(null)\n\n // Ctrl-D double-tap tracking\n const [ctrlDCount, setCtrlDCount] = useState(0)\n const [ctrlDTimer, setCtrlDTimer] = useState<NodeJS.Timeout | null>(null)\n\n // Unified Esc double-tap tracking for all Esc actions\n // All Esc actions require double-tap to prevent accidental triggers\n const [escCount, setEscCount] = useState(0)\n const [escTimer, setEscTimer] = useState<NodeJS.Timeout | null>(null)\n const ESC_DOUBLE_TAP_WINDOW = 500 // ms - tighter window for intentional double-tap\n\n // Hotkey feedback messages (for Ctrl-C, Ctrl-L, Ctrl-O)\n const [hotkeyMessage, setHotkeyMessage] = useState<{\n show: boolean\n text?: string\n }>({ show: false })\n\n // Show verbose toggle message from parent (survives remount)\n useEffect(() => {\n if (verboseToggleMessage) {\n setHotkeyMessage({ show: true, text: verboseToggleMessage })\n }\n }, [verboseToggleMessage])\n\n // Hotkey help panel visibility\n const [showHotkeyHelp, setShowHotkeyHelp] = useState(false)\n\n // Background task indicator focus state\n const [backgroundIndicatorFocused, setBackgroundIndicatorFocused] =\n useState(false)\n\n // Permission context for mode management\n const { cycleMode, currentMode, getModeConfig } = usePermissionContext()\n\n // Show temporary feedback when permission mode changes (including back to default)\n const prevModeRef = useRef(currentMode)\n useEffect(() => {\n if (currentMode !== prevModeRef.current) {\n const config = getModeConfig()\n const text =\n currentMode === 'default'\n ? 'default mode (shift+tab to cycle)'\n : `${config.inlineIcon} ${config.inlineLabel} (shift+tab to cycle)`\n setHotkeyMessage({ show: true, text })\n setTimeout(() => setHotkeyMessage({ show: false }), 3000)\n prevModeRef.current = currentMode\n }\n }, [currentMode, getModeConfig])\n\n // useEffect(() => {\n // getExampleCommands().then(commands => {\n // setPlaceholder(`Try \"${sample(commands)}\"`)\n // })\n // }, [])\n\n // Get terminal size once and derive all values from it\n const terminalSize = useTerminalSize()\n const { columns } = terminalSize\n // Calculate text input columns: terminal width - 6 (3 for mode indicator, 3 for padding/borders)\n const textInputColumns = columns - 6\n\n const commandWidth = useMemo(\n () => Math.max(...commands.map(cmd => cmd.userFacingName().length)) + 5,\n [commands],\n )\n\n // Unified completion system - one hook to rule them all (now with terminal behavior)\n const {\n suggestions,\n selectedIndex,\n isActive: completionActive,\n emptyDirMessage,\n } = useUnifiedCompletion({\n input,\n cursorOffset,\n onInputChange,\n setCursorOffset,\n commands,\n onSubmit,\n })\n\n // Phase 3: History search with Ctrl-R\n const history = useMemo(() => getHistory(), [submitCount]) // Refresh on submit\n const historySearch = useHistorySearch(history)\n\n // Get theme early for memoized rendering\n const theme = getTheme()\n\n // Compute current input context for context-aware hints\n const inputContext: InputContext = useMemo(() => {\n if (isLoading) return 'loading'\n if (historySearch.isActive) return 'history_search'\n if (completionActive) return 'completion'\n if (input.startsWith('/')) return 'slash_command'\n if (input.trim().length > 0) return 'typing'\n return 'idle'\n }, [isLoading, historySearch.isActive, completionActive, input])\n\n // Visible window size for suggestions - show limited items with scrolling\n const MAX_VISIBLE_SUGGESTIONS = 8\n\n // Calculate visible window for suggestions (pagination logic)\n const visibleSuggestions = useMemo(() => {\n if (suggestions.length === 0) return []\n\n // If all suggestions fit in window, show them all\n if (suggestions.length <= MAX_VISIBLE_SUGGESTIONS) {\n return suggestions.map((s, i) => ({ ...s, globalIndex: i }))\n }\n\n // Calculate scroll window to keep selected item visible\n const halfWindow = Math.floor(MAX_VISIBLE_SUGGESTIONS / 2)\n let startIndex = Math.max(0, selectedIndex - halfWindow)\n let endIndex = startIndex + MAX_VISIBLE_SUGGESTIONS\n\n // Adjust if we're near the end\n if (endIndex > suggestions.length) {\n endIndex = suggestions.length\n startIndex = Math.max(0, endIndex - MAX_VISIBLE_SUGGESTIONS)\n }\n\n return suggestions\n .slice(startIndex, endIndex)\n .map((s, i) => ({ ...s, globalIndex: startIndex + i }))\n }, [suggestions, selectedIndex])\n\n // Memoized completion suggestions rendering - with scroll indicators\n const renderedSuggestions = useMemo(() => {\n if (suggestions.length === 0) return null\n\n const hasMoreAbove =\n visibleSuggestions.length > 0 && visibleSuggestions[0].globalIndex > 0\n const hasMoreBelow =\n visibleSuggestions.length > 0 &&\n visibleSuggestions[visibleSuggestions.length - 1].globalIndex <\n suggestions.length - 1\n\n return (\n <>\n {hasMoreAbove && (\n <Box>\n <Text color={SEMANTIC_COLORS.dim}>\n {' '}\n \u2191 {visibleSuggestions[0].globalIndex} more above...\n </Text>\n </Box>\n )}\n {visibleSuggestions.map(suggestion => {\n const isSelected = suggestion.globalIndex === selectedIndex\n const isAgent = suggestion.type === 'agent'\n\n // Simple color logic - brand gradient for selection\n const displayColor = isSelected\n ? BRAND_GRADIENT.START\n : isAgent && suggestion.metadata?.color\n ? suggestion.metadata.color\n : undefined\n\n return (\n <Box\n key={`${suggestion.type}-${suggestion.value}-${suggestion.globalIndex}`}\n flexDirection=\"row\"\n >\n <Text\n color={\n displayColor ||\n (!isSelected ? SEMANTIC_COLORS.dim : undefined)\n }\n >\n {isSelected ? '\u25C6 ' : ' '}\n {suggestion.displayValue}\n </Text>\n </Box>\n )\n })}\n {hasMoreBelow && (\n <Box>\n <Text color={SEMANTIC_COLORS.dim}>\n {' '}\n \u2193{' '}\n {suggestions.length -\n visibleSuggestions[visibleSuggestions.length - 1].globalIndex -\n 1}{' '}\n more below...\n </Text>\n </Box>\n )}\n </>\n )\n }, [suggestions, selectedIndex, visibleSuggestions, theme.suggestion])\n\n const onChange = useCallback(\n (value: string) => {\n if (value.startsWith('!')) {\n onModeChange('bash')\n return\n }\n if (value.startsWith('#')) {\n onModeChange('koding')\n return\n }\n onInputChange(value)\n },\n [onModeChange, onInputChange],\n )\n\n // Handle Shift+M model switching with enhanced debugging\n const handleQuickModelSwitch = useCallback(async () => {\n const modelManager = getModelManager()\n const currentTokens = countTokens(messages)\n\n // Get debug info for better error reporting\n const debugInfo = modelManager.getModelSwitchingDebugInfo()\n\n const switchResult = modelManager.switchToNextModel(currentTokens)\n\n if (switchResult.success && switchResult.modelName) {\n // Successful switch - use enhanced message from model manager\n onSubmitCountChange(prev => prev + 1)\n setModelSwitchMessage({\n show: true,\n text:\n switchResult.message || `\u2705 Switched to ${switchResult.modelName}`,\n })\n setTimeout(() => setModelSwitchMessage({ show: false }), 3000)\n } else if (switchResult.blocked && switchResult.message) {\n // Context overflow - show detailed message\n setModelSwitchMessage({\n show: true,\n text: switchResult.message,\n })\n setTimeout(() => setModelSwitchMessage({ show: false }), 5000)\n } else {\n // Enhanced error reporting with debug info\n let errorMessage = switchResult.message\n\n if (!errorMessage) {\n if (debugInfo.totalModels === 0) {\n errorMessage = '\u274C No models configured. Use /model to add models.'\n } else if (debugInfo.activeModels === 0) {\n errorMessage = `\u274C No active models (${debugInfo.totalModels} total, all inactive). Use /model to activate models.`\n } else if (debugInfo.activeModels === 1) {\n // Show ALL models including inactive ones for debugging\n const allModelNames = debugInfo.availableModels\n .map(m => `${m.name}${m.isActive ? '' : ' (inactive)'}`)\n .join(', ')\n errorMessage = `\u26A0\uFE0F Only 1 active model out of ${debugInfo.totalModels} total models: ${allModelNames}. ALL configured models will be activated for switching.`\n } else {\n errorMessage = `\u274C Model switching failed (${debugInfo.activeModels} active, ${debugInfo.totalModels} total models available)`\n }\n }\n\n setModelSwitchMessage({\n show: true,\n text: errorMessage,\n })\n setTimeout(() => setModelSwitchMessage({ show: false }), 6000)\n }\n }, [onSubmitCountChange, messages])\n\n const { resetHistory, onHistoryUp, onHistoryDown } = useArrowKeyHistory(\n (value: string, mode: 'bash' | 'prompt' | 'koding') => {\n onChange(value)\n onModeChange(mode)\n },\n input,\n )\n\n // Only use history navigation when there are no suggestions\n // Priority: 1) Pop from queued prompts (if any and input is empty), 2) History navigation\n const handleHistoryUp = () => {\n if (!completionActive) {\n // If input is empty and there are queued prompts, pop the last one\n if (\n input.trim() === '' &&\n queuedPrompts.length > 0 &&\n onPopQueuedPrompt\n ) {\n const poppedPrompt = onPopQueuedPrompt()\n if (poppedPrompt) {\n onInputChange(poppedPrompt)\n setCursorOffset(poppedPrompt.length)\n return\n }\n }\n onHistoryUp()\n }\n }\n\n const handleHistoryDown = () => {\n if (!completionActive) {\n onHistoryDown()\n }\n }\n\n async function onSubmit(input: string, isSubmittingSlashCommand = false) {\n // UserPromptSubmit hook\n const hookManager = getHookManager()\n if (hookManager && input && input.trim()) {\n try {\n const decision = await hookManager.executeUserPromptSubmit(input)\n\n if (!decision.shouldContinue) {\n if (decision.shouldAskUser) {\n // Show confirmation to user (simplified - in real UI might show dialog)\n const confirmed = confirm(\n decision.reason || 'Hook requested approval. Continue?',\n )\n if (!confirmed) {\n return // Don't submit\n }\n } else {\n // Blocked by hook\n setMessage({\n show: true,\n text: decision.reason || 'Blocked by hook',\n })\n setTimeout(() => setMessage({ show: false }), 3000)\n return\n }\n }\n } catch (err) {\n debugLogger.error('UserPromptSubmit hook failed', { error: err })\n // Continue on error (fail-safe)\n }\n }\n\n // Special handling for \"put a verbose summary\" and similar action prompts in koding mode\n if (\n (mode === 'koding' || input.startsWith('#')) &&\n input.match(/^(#\\s*)?(put|create|generate|write|give|provide)/i)\n ) {\n try {\n // Store the original input for history\n const originalInput = input\n\n // Strip the # prefix if present\n const cleanInput = mode === 'koding' ? input : input.substring(1).trim()\n\n // Add to history and clear input field\n addToHistory(mode === 'koding' ? `#${input}` : input)\n onInputChange('')\n\n // Create additional context to inform the assistant this is for KODING.md\n const kodingContext = `The user is using Koding mode. Format your response as a comprehensive, well-structured document suitable for adding to ${PROJECT_FILE}. Use proper markdown formatting with headings, lists, code blocks, etc. The response should be complete and ready to add to ${PROJECT_FILE} documentation.`\n\n // Switch to prompt mode but tag the submission for later capture\n onModeChange('prompt')\n\n // \uD83D\uDD27 Fix Koding mode: clean up previous state\n if (abortController) {\n abortController.abort()\n }\n setIsLoading(false)\n await new Promise(resolve => setTimeout(resolve, 0))\n\n // Set loading state - AbortController now created in onQuery\n setIsLoading(true)\n\n // Process as a normal user input but with special handling\n const messages = await processUserInput(\n cleanInput,\n 'prompt', // Use prompt mode for processing\n setToolJSX,\n {\n options: {\n commands,\n forkNumber,\n messageLogName,\n tools,\n verbose,\n maxThinkingTokens: 0,\n // Add context flag for koding mode\n isKodingRequest: true,\n kodingContext,\n },\n messageId: undefined,\n abortController: abortController || new AbortController(), // Temporary controller, actual one created in onQuery\n readFileTimestamps,\n setForkConvoWithMessagesOnTheNextRender,\n unmount: unmount || (() => {}),\n },\n pastedImage ?? null,\n )\n\n // Send query and capture response\n if (messages.length) {\n await onQuery(messages)\n\n // After query completes, the last message should be the assistant's response\n // We'll set up a one-time listener to capture and save that response\n // This will be handled by the REPL component or message handler\n }\n\n return\n } catch (e) {\n // If something fails, log the error\n console.error('Error processing Koding request:', e)\n }\n }\n\n // If in koding mode or input starts with '#', interpret it using AI before appending to MINTO.md\n else if (mode === 'koding' || input.startsWith('#')) {\n try {\n // Strip the # if we're in koding mode and the user didn't type it (since it's implied)\n const contentToInterpret =\n mode === 'koding' && !input.startsWith('#')\n ? input.trim()\n : input.substring(1).trim()\n\n const interpreted = await interpretHashCommand(contentToInterpret)\n handleHashCommand(interpreted)\n } catch (e) {\n // If interpretation fails, log the error\n }\n onInputChange('')\n addToHistory(mode === 'koding' ? `#${input}` : input)\n onModeChange('prompt')\n return\n }\n if (input === '') {\n return\n }\n if (isDisabled) {\n return\n }\n\n // Waiting list feature: queue prompt when busy instead of rejecting\n if (isLoading) {\n if (onQueuePrompt && input.trim()) {\n onQueuePrompt(input.trim())\n onInputChange('')\n setMessage({\n show: true,\n text: `Queued: \"${input.slice(0, 30)}${input.length > 30 ? '...' : ''}\" (${queuedPrompts.length + 1} in queue)`,\n })\n setTimeout(() => setMessage({ show: false }), 2000)\n }\n return\n }\n\n // Handle Enter key when completions are active\n // If there are suggestions showing, Enter should complete the selection, not send the message\n if (suggestions.length > 0 && completionActive) {\n // The completion is handled by useUnifiedCompletion hook\n // Just return to prevent message sending\n return\n }\n\n // Intercept exit commands and call process.exit(0) directly\n // This matches Kode-cli's working pattern where process.on('exit') handler prints the cost summary\n // The simple pattern: exit command \u2192 process.exit(0) \u2192 'exit' event \u2192 print summary\n // Include both with and without slash prefix\n const exitCommands = [\n 'exit',\n 'quit',\n ':q',\n ':q!',\n ':wq',\n ':wq!',\n '/exit',\n '/quit',\n '/q',\n ]\n if (exitCommands.includes(input.trim())) {\n exit()\n }\n\n let finalInput = input\n if (pastedText) {\n // Create the prompt pattern that would have been used for this pasted text\n const pastedPrompt = getPastedTextPrompt(pastedText)\n if (finalInput.includes(pastedPrompt)) {\n finalInput = finalInput.replace(pastedPrompt, pastedText)\n } // otherwise, ignore the pastedText if the user has modified the prompt\n }\n onInputChange('')\n onModeChange('prompt')\n // Suggestions are now handled by unified completion\n setPastedImage(null)\n setPastedText(null)\n onSubmitCountChange(_ => _ + 1)\n\n setIsLoading(true)\n\n const newAbortController = new AbortController()\n setAbortController(newAbortController)\n\n const messages = await processUserInput(\n finalInput,\n mode,\n setToolJSX,\n {\n options: {\n commands,\n forkNumber,\n messageLogName,\n tools,\n verbose,\n maxThinkingTokens: 0,\n },\n messageId: undefined,\n abortController: newAbortController,\n readFileTimestamps,\n setForkConvoWithMessagesOnTheNextRender,\n unmount: unmount || (() => {}),\n },\n pastedImage ?? null,\n )\n\n if (messages.length) {\n onQuery(messages, newAbortController)\n } else {\n // Local JSX commands\n addToHistory(input)\n resetHistory()\n return\n }\n\n for (const message of messages) {\n if (message.type === 'user') {\n const inputToAdd = mode === 'bash' ? `!${input}` : input\n addToHistory(inputToAdd)\n resetHistory()\n }\n }\n }\n\n function onImagePaste(image: string) {\n onModeChange('prompt')\n setPastedImage(image)\n }\n\n function onTextPaste(rawText: string) {\n // Replace any \\r with \\n first to match useTextInput's conversion behavior\n const text = rawText.replace(/\\r/g, '\\n')\n\n // Try to cache large paste content (> 1000 chars)\n const cacheEntry = cachePaste(text)\n\n // Get prompt with newline count (or cache info if cached)\n let pastedPrompt: string\n if (cacheEntry) {\n // Use cache placeholder for large pastes\n pastedPrompt = createPlaceholder(cacheEntry)\n debugLogger.trace('PASTE_CACHED', {\n length: text.length,\n hash: cacheEntry.hash.slice(0, 8),\n })\n } else {\n // Use standard prompt for smaller pastes\n pastedPrompt = getPastedTextPrompt(text)\n }\n\n // Update the input with a visual indicator that text has been pasted\n const newInput =\n input.slice(0, cursorOffset) + pastedPrompt + input.slice(cursorOffset)\n onInputChange(newInput)\n\n // Update cursor position to be after the inserted indicator\n setCursorOffset(cursorOffset + pastedPrompt.length)\n\n // Still set the pastedText state for actual submission\n setPastedText(text)\n }\n\n // IMPORTANT: useInput must be called unconditionally (React Hook rule)\n // In fallback mode, we provide an empty handler to satisfy the Hook requirement\n useInput(\n fallbackMode\n ? () => {} // Fallback mode: no-op handler\n : (inputChar, key) => {\n // ========== NORMAL MODE: Full interactive input handling ==========\n // ========== NEW HOTKEYS (Phase 1) ==========\n\n // Ctrl-C: Enhanced cancel/interrupt\n if (key.ctrl && inputChar === 'c') {\n if (isLoading) {\n // Cancel ongoing request\n if (abortController && !abortController.signal.aborted) {\n abortController.abort()\n }\n setIsLoading(false)\n setHotkeyMessage({\n show: true,\n text: t('prompts.interruptedCtrlC'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n } else if (input.length > 0) {\n // Clear input\n onInputChange('')\n setHotkeyMessage({ show: true, text: t('prompts.inputCleared') })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n } else {\n // Hint for exit (optional: could implement double Ctrl-C to exit)\n setHotkeyMessage({\n show: true,\n text: t('prompts.pressCtrlDToExit'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n }\n return true\n }\n\n // ESC interrupt is now handled in handleSpecialKey (passed to TextInput)\n // TextInput's internal handler clears input on double-ESC\n // We only need to handle interrupt here as a fallback when input is empty\n\n // Ctrl-D: Graceful EOF exit (double-tap safety)\n if (key.ctrl && inputChar === 'd') {\n if (input.length > 0) {\n // If there's input, just clear it\n onInputChange('')\n setHotkeyMessage({\n show: true,\n text: t('prompts.inputClearedCtrlD'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n return true\n }\n\n // Empty input: increment Ctrl-D count for double-tap safety\n setCtrlDCount(prev => prev + 1)\n\n if (ctrlDTimer) clearTimeout(ctrlDTimer)\n const timer = setTimeout(() => setCtrlDCount(0), 1000)\n setCtrlDTimer(timer)\n\n if (ctrlDCount >= 1) {\n // Second Ctrl-D: graceful exit\n setHotkeyMessage({\n show: true,\n text: t('prompts.exitingGracefully'),\n })\n setTimeout(() => exit(), 500)\n } else {\n // First Ctrl-D: show hint\n setHotkeyMessage({\n show: true,\n text: t('prompts.pressCtrlDAgain'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n }\n\n return true\n }\n\n // Ctrl-L: Clear screen\n if (key.ctrl && inputChar === 'l') {\n clearScreen()\n setHotkeyMessage({ show: true, text: t('prompts.screenCleared') })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n return true\n }\n\n // Ctrl-O: Toggle verbose mode (on/off)\n if (key.ctrl && inputChar === 'o') {\n // Use props.verbose (current UI state) as the source of truth for toggling\n // This ensures the toggle always reflects what user sees on screen\n const newVerbose = !verbose\n\n // Update global config to persist the preference\n const config = getGlobalConfig()\n saveGlobalConfig({\n ...config,\n verbose: newVerbose,\n })\n\n // Show feedback with mode name\n setHotkeyMessage({\n show: true,\n text: `${getVerboseLabel(newVerbose)} (Ctrl+O)`,\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n\n // Notify parent component to update verbose mode\n if (onToggleVerbose) {\n onToggleVerbose(newVerbose)\n }\n\n return true\n }\n\n // Ctrl+T: Toggle TodoPanel visibility\n if (key.ctrl && inputChar === 't') {\n if (onToggleTodoPanel) {\n onToggleTodoPanel()\n setHotkeyMessage({\n show: true,\n text: t('prompts.todoPanelToggled'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n }\n return true\n }\n\n // Phase 4.3: Ctrl-B: Quick bash command execution\n // Note: Moving to background is handled by StreamingBashOutput component\n if (key.ctrl && inputChar === 'b') {\n if (!input || input.trim().length === 0) {\n setHotkeyMessage({\n show: true,\n text: t('prompts.typeCommandFirst'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n return true\n }\n\n // If already in bash mode (starts with !), just submit\n if (mode === 'bash') {\n setHotkeyMessage({\n show: true,\n text: t('prompts.executingBash'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n // Let it submit normally via Enter handling\n onSubmit(input)\n return true\n }\n\n // Otherwise, convert to bash command and submit\n const bashCommand = `!${input}`\n setHotkeyMessage({\n show: true,\n text: 'Executing bash command... (Ctrl-B)',\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n\n // Submit as bash command\n onSubmit(bashCommand)\n return true\n }\n\n // Ctrl+? or Ctrl+/: Toggle hotkey help panel\n if (key.ctrl && (inputChar === '?' || inputChar === '/')) {\n setShowHotkeyHelp(prev => !prev)\n return true\n }\n\n // Phase 3: Ctrl-R: Reverse history search\n if (key.ctrl && inputChar === 'r') {\n if (!historySearch.isActive) {\n // Activate history search\n historySearch.activate()\n return true\n }\n // If already active, cycle to next match (move up in history)\n historySearch.moveUp()\n return true\n }\n\n // History search mode: handle special keys\n if (historySearch.isActive) {\n // Esc: Cancel search\n if (key.escape) {\n historySearch.reset()\n return true\n }\n\n // Enter: Select current item and exit search\n if (key.return) {\n if (historySearch.selectedItem) {\n onInputChange(historySearch.selectedItem)\n }\n historySearch.reset()\n return true\n }\n\n // Up/Down: Navigate through results\n if (key.upArrow) {\n historySearch.moveUp()\n return true\n }\n if (key.downArrow) {\n historySearch.moveDown()\n return true\n }\n\n // Any other character: Update search term\n if (inputChar && !key.ctrl && !key.meta) {\n historySearch.setSearchTerm(historySearch.searchTerm + inputChar)\n return true\n }\n\n // Backspace: Remove character from search\n if (key.backspace || key.delete) {\n if (historySearch.searchTerm.length > 0) {\n historySearch.setSearchTerm(\n historySearch.searchTerm.slice(0, -1),\n )\n } else {\n // No search term, cancel search\n historySearch.reset()\n }\n return true\n }\n }\n\n // Background task indicator navigation\n if (backgroundIndicatorFocused) {\n // Up arrow: return focus to input\n if (key.upArrow) {\n setBackgroundIndicatorFocused(false)\n return true\n }\n\n // Enter: open background tasks panel\n if (key.return) {\n if (onToggleBackgroundPanel) {\n onToggleBackgroundPanel()\n }\n setBackgroundIndicatorFocused(false)\n return true\n }\n\n // Esc: unfocus indicator\n if (key.escape) {\n setBackgroundIndicatorFocused(false)\n return true\n }\n\n return true // Consume all other input when indicator is focused\n }\n\n // Down arrow when input is active: focus background indicator if it exists\n if (key.downArrow && backgroundShellCount > 0 && !completionActive) {\n setBackgroundIndicatorFocused(true)\n return true\n }\n\n // ========== EXISTING HOTKEYS ==========\n\n // For bash mode, only exit when deleting the last character (which would be the '!' character)\n if (mode === 'bash' && (key.backspace || key.delete)) {\n // Check the current input state, not the inputChar parameter\n // If current input is empty, we're about to delete the '!' character, so exit bash mode\n if (input === '') {\n onModeChange('prompt')\n }\n return undefined\n }\n\n // For koding mode, only exit when deleting the last character (which would be the '#' character)\n if (mode === 'koding' && (key.backspace || key.delete)) {\n // Check the current input state, not the inputChar parameter\n // If current input is empty, we're about to delete the '#' character, so exit koding mode\n if (input === '') {\n onModeChange('prompt')\n }\n return undefined\n }\n\n // For other modes, keep the original behavior\n if (inputChar === '' && (key.escape || key.backspace || key.delete)) {\n onModeChange('prompt')\n }\n\n // NOTE: ESC handling is now unified in handleSpecialKey callback\n // All ESC actions require double-tap to prevent accidental triggers\n // - Double-tap with input: clears input\n // - Double-tap without input + loading: interrupts task\n // Message selector is now accessed via Ctrl+H or other hotkey\n\n // Tab (without Shift) for thinking mode toggle (Phase 4.2)\n // Only when completion is NOT active\n if (key.tab && !key.shift && !completionActive) {\n const config = getGlobalConfig()\n const newThinking = !config.thinking\n\n // Update global config\n saveGlobalConfig({\n ...config,\n thinking: newThinking,\n })\n\n // Show feedback\n setMessage({\n show: true,\n text: newThinking\n ? t('prompts.thinkingModeEnabled')\n : t('prompts.thinkingModeDisabled'),\n })\n setTimeout(() => setMessage({ show: false }), 2000)\n\n return true // Explicitly handled\n }\n\n // Shift+Tab for mode cycling (retains legacy keyboard behavior)\n if (key.shift && key.tab) {\n cycleMode()\n return true // Explicitly handled\n }\n\n return false // Not handled, allow other hooks\n },\n { isActive: !isBackgroundPanelOpen && !fallbackMode && !isOverlayActive },\n )\n\n // Handle special key combinations before character input\n // This runs BEFORE TextInput's internal handling, preventing double-processing\n // ESC handling is consolidated here - no separate useCancelRequest hook needed\n const handleSpecialKey = useCallback(\n (inputChar: string, key: any): boolean => {\n // Shift+M for model switching - only when input is empty to avoid conflict with typing uppercase \"M\"\n if (\n key.shift &&\n (inputChar === 'M' || inputChar === 'm') &&\n input.length === 0\n ) {\n handleQuickModelSwitch()\n return true // Prevent character from being input\n }\n\n // ESC: All actions require double-tap to prevent accidental triggers\n // Priority logic:\n // 1. If input has content: double-tap clears input\n // 2. If input is empty + loading: double-tap interrupts task\n // 3. Single tap always shows hint, never performs action\n if (key.escape) {\n // Increment Esc count for double-tap detection\n const newEscCount = escCount + 1\n setEscCount(newEscCount)\n\n // Reset timer and start new one\n if (escTimer) clearTimeout(escTimer)\n const timer = setTimeout(() => setEscCount(0), ESC_DOUBLE_TAP_WINDOW)\n setEscTimer(timer)\n\n if (newEscCount >= 2) {\n // Double-tap detected - perform action based on state\n setEscCount(0) // Reset after action\n\n if (input.length > 0) {\n // Clear input\n onInputChange('')\n setHotkeyMessage({\n show: true,\n text: t('prompts.inputClearedEscEsc'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n return true\n } else if (isLoading && onInterrupt) {\n // Interrupt task\n onInterrupt()\n setHotkeyMessage({\n show: true,\n text: t('prompts.interruptedEscEsc'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n return true\n }\n } else {\n // First tap - show appropriate hint\n if (input.length > 0) {\n setHotkeyMessage({\n show: true,\n text: t('prompts.pressEscAgainClear'),\n })\n } else if (isLoading) {\n setHotkeyMessage({\n show: true,\n text: t('prompts.pressEscAgainInterrupt'),\n })\n }\n setTimeout(() => setHotkeyMessage({ show: false }), 1500)\n return true // Consume the key to prevent other handlers\n }\n }\n\n return false // Not handled, allow normal processing\n },\n [\n handleQuickModelSwitch,\n isLoading,\n input.length,\n onInputChange,\n onInterrupt,\n escCount,\n escTimer,\n ],\n )\n\n // textInputColumns is now calculated at the top of the component from terminalSize\n const tokenUsage = useMemo(() => countTokens(messages), [messages])\n\n // \uD83D\uDD27 Fix: Track model ID changes to detect external config updates\n const modelManager = getModelManager()\n const currentModelId = (modelManager.getModel('main') as any)?.id || null\n\n const modelInfo = useMemo(() => {\n // Force fresh ModelManager instance to detect config changes\n const freshModelManager = getModelManager()\n const currentModel = freshModelManager.getModel('main')\n if (!currentModel) {\n return null\n }\n\n return {\n name: currentModel.modelName, // \uD83D\uDD27 Fix: Use actual model name, not display name\n id: (currentModel as any).id, // \u6DFB\u52A0\u6A21\u578BID\u7528\u4E8E\u8C03\u8BD5\n provider: currentModel.provider, // \u6DFB\u52A0\u63D0\u4F9B\u5546\u4FE1\u606F\n contextLength: currentModel.contextLength,\n currentTokens: tokenUsage,\n }\n }, [tokenUsage, modelSwitchMessage.show, submitCount, currentModelId]) // Track model ID to detect config changes\n\n return (\n <Box flexDirection=\"column\">\n {/* Fallback mode warning */}\n {fallbackMode && (\n <Box marginBottom={1}>\n <Text color={SEMANTIC_COLORS.running}>\n {t('prompts.limitedInputMode')}\n </Text>\n <Text color={SEMANTIC_COLORS.dim}>\n {' '}\n ({t('prompts.limitedInputModeDetail')})\n </Text>\n </Box>\n )}\n\n {/* Hotkey help panel */}\n {showHotkeyHelp && (\n <HotkeyHelpPanel\n isVisible={showHotkeyHelp}\n onClose={() => setShowHotkeyHelp(false)}\n />\n )}\n\n {/* Phase 3: History search overlay */}\n {historySearch.isActive && (\n <HistorySearchOverlay\n searchTerm={historySearch.searchTerm}\n results={historySearch.filteredResults}\n selectedIndex={historySearch.selectedIndex}\n />\n )}\n\n {/* AI \u6A21\u578B\u4FE1\u606F - \u53F3\u4E0A\u89D2\u663E\u793A\uFF0C\u4F7F\u7528\u54C1\u724C\u914D\u8272 */}\n {modelInfo && (\n <Box justifyContent=\"flex-end\" marginBottom={1}>\n <Text color={SEMANTIC_COLORS.dim}>\n <Text color={BRAND_GRADIENT.START}>\u25C6</Text>{' '}\n <Text color={SEMANTIC_COLORS.secondary}>{modelInfo.name}</Text>\n <Text color={SEMANTIC_COLORS.dim}>\n {' '}\n \u00B7 {Math.round(modelInfo.currentTokens / 1000)}k /{' '}\n {Math.round(modelInfo.contextLength / 1000)}k\n </Text>\n </Text>\n </Box>\n )}\n\n {/* \u6392\u961F\u4EFB\u52A1 - \u7B49\u5F85\u5904\u7406\u7684\u63D0\u793A\uFF0C\u4F7F\u7528\u54C1\u724C\u914D\u8272 */}\n {queuedPrompts.length > 0 && (\n <Box flexDirection=\"column\" marginTop={1}>\n <Box paddingLeft={2}>\n <Text color={BRAND_GRADIENT.MIDDLE}>\n \u2500\u2500 {t('ui.hints.queued')} ({queuedPrompts.length})\n </Text>\n <Text color={SEMANTIC_COLORS.dim}>\n {' '}\n \u00B7 {t('ui.hints.willRunAfter')} \u00B7{' '}\n <Text color={SEMANTIC_COLORS.secondary}>\u2191</Text>{' '}\n {t('ui.hints.toEdit')} \u2500\u2500\n </Text>\n </Box>\n {queuedPrompts.map((prompt, index) => (\n <Box key={index} paddingLeft={2}>\n <Text color={BRAND_GRADIENT.START}>\u25C7 </Text>\n <Text color={SEMANTIC_COLORS.secondary}>\n {prompt.length > 60 ? prompt.slice(0, 60) + '...' : prompt}\n </Text>\n </Box>\n ))}\n </Box>\n )}\n\n {/* Input box with top/bottom borders only (no side borders) */}\n <Box\n alignItems=\"flex-start\"\n justifyContent=\"flex-start\"\n borderTop={true}\n borderBottom={true}\n borderLeft={false}\n borderRight={false}\n borderColor={\n isOverlayActive\n ? SEMANTIC_COLORS.muted\n : mode === 'bash'\n ? SEMANTIC_COLORS.running\n : mode === 'koding'\n ? SEMANTIC_COLORS.info\n : BRAND_GRADIENT.START\n }\n borderDimColor={false}\n borderStyle=\"single\"\n marginTop={queuedPrompts.length > 0 ? 0 : 1}\n width=\"100%\"\n >\n <Box\n alignItems=\"flex-start\"\n alignSelf=\"flex-start\"\n flexWrap=\"nowrap\"\n justifyContent=\"flex-start\"\n width={3}\n >\n {mode === 'bash' ? (\n <Text color={SEMANTIC_COLORS.running}>&nbsp;!&nbsp;</Text>\n ) : mode === 'koding' ? (\n <Text color={SEMANTIC_COLORS.info}>&nbsp;#&nbsp;</Text>\n ) : (\n <Text\n color={\n isOverlayActive\n ? SEMANTIC_COLORS.muted\n : isLoading\n ? SEMANTIC_COLORS.dim\n : BRAND_GRADIENT.START\n }\n bold={!isOverlayActive}\n >\n &nbsp;\u276F&nbsp;\n </Text>\n )}\n </Box>\n <Box paddingRight={1}>\n <TextInput\n multiline\n focus={\n !isBackgroundPanelOpen &&\n !isOverlayActive &&\n (!isLoading || !!onQueuePrompt)\n }\n onSubmit={onSubmit}\n onChange={onChange}\n value={input}\n onHistoryUp={handleHistoryUp}\n onHistoryDown={handleHistoryDown}\n onHistoryReset={() => resetHistory()}\n placeholder={submitCount > 0 ? undefined : placeholder}\n onExit={() => process.exit(0)}\n onExitMessage={(show, key) => setExitMessage({ show, key })}\n onMessage={(show, text) => setMessage({ show, text })}\n onImagePaste={onImagePaste}\n columns={textInputColumns}\n isDimmed={isDisabled || (isLoading && !onQueuePrompt)}\n disableCursorMovementForUpDownKeys={completionActive}\n cursorOffset={cursorOffset}\n onChangeCursorOffset={setCursorOffset}\n onPaste={onTextPaste}\n onSpecialKey={handleSpecialKey}\n />\n </Box>\n </Box>\n {!completionActive && suggestions.length === 0 && (\n <Box\n flexDirection=\"row\"\n justifyContent=\"space-between\"\n paddingX={2}\n paddingY={0}\n >\n <Box justifyContent=\"flex-start\" gap={1}>\n {exitMessage.show ? (\n <Text color={SEMANTIC_COLORS.dim}>\n {t('prompts.pressCtrlDAgain')}\n </Text>\n ) : message.show ? (\n <Text color={SEMANTIC_COLORS.dim}>{message.text}</Text>\n ) : hotkeyMessage.show ? (\n <Text color={BRAND_GRADIENT.START}>{hotkeyMessage.text}</Text>\n ) : modelSwitchMessage.show ? (\n <Text color={BRAND_GRADIENT.START}>\n {modelSwitchMessage.text}\n </Text>\n ) : verbose ? (\n // Verbose mode: full static hints (\u5546\u52A1\u7528\u6237\u53CB\u597D) - \u4F7F\u7528\u54C1\u724C\u914D\u8272\n <>\n <Text\n color={\n mode === 'bash'\n ? BRAND_GRADIENT.MIDDLE\n : SEMANTIC_COLORS.dim\n }\n >\n <Text\n color={\n mode === 'bash'\n ? BRAND_GRADIENT.MIDDLE\n : SEMANTIC_COLORS.secondary\n }\n >\n !\n </Text>{' '}\n {t('ui.hints.executeCommand')}\n </Text>\n <Text\n color={\n mode === 'koding'\n ? SEMANTIC_COLORS.info\n : SEMANTIC_COLORS.dim\n }\n >\n \u00B7{' '}\n <Text\n color={\n mode === 'koding'\n ? SEMANTIC_COLORS.info\n : SEMANTIC_COLORS.secondary\n }\n >\n #\n </Text>{' '}\n {t('ui.hints.recordNote')}\n </Text>\n <Text color={SEMANTIC_COLORS.dim}>\n \u00B7 <Text color={SEMANTIC_COLORS.secondary}>/</Text>{' '}\n {t('ui.hints.featureMenu')} \u00B7{' '}\n <Text color={SEMANTIC_COLORS.secondary}>ctrl+?</Text>{' '}\n {t('common.help')}\n </Text>\n {backgroundShellCount > 0 && (\n <Text\n color={\n backgroundIndicatorFocused\n ? BRAND_GRADIENT.START\n : BRAND_GRADIENT.MIDDLE\n }\n backgroundColor={\n backgroundIndicatorFocused\n ? BRAND_GRADIENT.START\n : undefined\n }\n >\n \u00B7 {backgroundIndicatorFocused ? '\u25BA ' : ''}\n {t('ui.hints.backgroundTasks', {\n count: backgroundShellCount,\n })}\n </Text>\n )}\n {queuedPrompts.length > 0 && (\n <Text color={BRAND_GRADIENT.MIDDLE}>\n \u00B7 \uD83D\uDCCB {queuedPrompts.length} {t('ui.hints.queued')}\n </Text>\n )}\n </>\n ) : (\n // Normal mode: context-aware hints with 0.1.7 style\n <>\n <ContextAwareHints context={inputContext} compact />\n {backgroundShellCount > 0 && (\n <Text\n color={\n backgroundIndicatorFocused\n ? BRAND_GRADIENT.START\n : BRAND_GRADIENT.MIDDLE\n }\n backgroundColor={\n backgroundIndicatorFocused\n ? BRAND_GRADIENT.START\n : undefined\n }\n >\n \u2502 {backgroundIndicatorFocused ? '\u25BA ' : ''}\n {t('ui.hints.backgroundTasks', {\n count: backgroundShellCount,\n })}\n </Text>\n )}\n {queuedPrompts.length > 0 && (\n <Text color={BRAND_GRADIENT.MIDDLE}>\n \u2502 \uD83D\uDCCB {queuedPrompts.length} {t('ui.hints.queued')}\n </Text>\n )}\n {isLoading && onQueuePrompt && queuedPrompts.length === 0 && (\n <Text color={SEMANTIC_COLORS.dim}>\n \u2502 {t('ui.hints.typeToQueue')}\n </Text>\n )}\n </>\n )}\n </Box>\n <SentryErrorBoundary\n children={\n <Box justifyContent=\"flex-end\" gap={1}>\n {/* Startup status in footer while loading, then normal newline hint */}\n {startupItems?.some(s => s.status === 'loading') ? (\n <StartupStatusBar items={startupItems} />\n ) : (\n !debug &&\n tokenUsage < WARNING_THRESHOLD && (\n <>\n {/* Compact persistent mode badge for non-default modes */}\n {currentMode !== 'default' && (() => {\n const mc = getModeConfig()\n return (\n <Text color={mc.inlineColor}>\n {mc.inlineIcon} {mc.compactLabel} \u00B7\n </Text>\n )\n })()}\n <Text color={SEMANTIC_COLORS.dim}>\n <Text color={SEMANTIC_COLORS.secondary}>\n {terminalSetup.isEnabled &&\n isShiftEnterKeyBindingInstalled()\n ? 'shift + \u23CE'\n : '\\\\\u23CE'}\n </Text>{' '}\n {t('ui.hints.forNewline')}\n </Text>\n </>\n )\n )}\n <TokenWarning tokenUsage={tokenUsage} />\n </Box>\n }\n />\n </Box>\n )}\n\n {/* Unified completion suggestions - optimized rendering */}\n {suggestions.length > 0 && (\n <Box\n flexDirection=\"row\"\n justifyContent=\"space-between\"\n paddingX={2}\n paddingY={0}\n >\n <Box flexDirection=\"column\">\n {renderedSuggestions}\n\n {/* \u7B80\u6D01\u64CD\u4F5C\u63D0\u793A\u6846 - \u5305\u542B\u5217\u8868\u4F4D\u7F6E\u4FE1\u606F\uFF0C\u4F7F\u7528\u54C1\u724C\u914D\u8272 */}\n <Box\n marginTop={1}\n paddingX={3}\n borderStyle=\"round\"\n borderColor={BRAND_GRADIENT.START}\n >\n <Text\n color={\n emptyDirMessage ? BRAND_GRADIENT.END : SEMANTIC_COLORS.dim\n }\n >\n {emptyDirMessage ||\n (() => {\n const selected = suggestions[selectedIndex]\n const positionInfo =\n suggestions.length > 1\n ? `[${selectedIndex + 1}/${suggestions.length}] `\n : ''\n\n if (!selected) {\n return `${positionInfo}${t('ui.hints.completion.navigate')}`\n }\n if (selected?.value.endsWith('/')) {\n return `${positionInfo}${t('ui.hints.completion.enterDirectory')}`\n } else if (selected?.type === 'agent') {\n return `${positionInfo}${t('ui.hints.completion.selectAgent')}`\n } else {\n return `${positionInfo}${t('ui.hints.completion.insertReference')}`\n }\n })()}\n </Text>\n </Box>\n </Box>\n <SentryErrorBoundary\n children={\n <Box justifyContent=\"flex-end\" gap={1}>\n <TokenWarning tokenUsage={countTokens(messages)} />\n </Box>\n }\n />\n </Box>\n )}\n </Box>\n )\n}\n\nexport default memo(PromptInput)\n\n// Simple exit function matching Kode-cli's working pattern\n// Cost summary is printed by process.on('exit') handler in exit.ts\nfunction exit(): never {\n setTerminalTitle('')\n process.exit(0)\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import { Box, Text, useInput } from 'ink'\nimport { sample } from 'lodash-es'\nimport * as React from 'react'\nimport { type Message } from '@query'\nimport { processUserInput } from '@utils/messages'\nimport { useArrowKeyHistory } from '@hooks/useArrowKeyHistory'\nimport { useUnifiedCompletion } from '@hooks/useUnifiedCompletion'\nimport { useHistorySearch } from '@hooks/useHistorySearch'\nimport { addToHistory, getHistory } from '@history'\nimport {\n cachePaste,\n createPlaceholder,\n expandPlaceholder,\n type PasteCacheEntry,\n} from '@utils/pasteCache'\nimport TextInput from './TextInput'\nimport { HistorySearchOverlay } from './HistorySearchOverlay'\nimport {\n HotkeyHelpPanel,\n ContextAwareHints,\n type InputContext,\n} from './HotkeyHelpPanel'\nimport { memo, useCallback, useEffect, useMemo, useRef, useState } from 'react'\nimport { countTokens } from '@utils/tokens'\nimport { SentryErrorBoundary } from './SentryErrorBoundary'\nimport { StartupStatusBar, type StartupItem } from './StartupStatus'\nimport type { Command } from '@commands'\nimport type { SetToolJSXFn, Tool } from '@tool'\nimport { TokenWarning, WARNING_THRESHOLD } from './TokenWarning'\nimport { useTerminalSize } from '@hooks/useTerminalSize'\nimport { getTheme } from '@utils/theme'\nimport { BRAND_GRADIENT, SEMANTIC_COLORS } from '@constants/colors'\nimport { getModelManager, reloadModelManager } from '@utils/model'\nimport { setTerminalTitle, clearScreen } from '@utils/terminal'\nimport terminalSetup, {\n isShiftEnterKeyBindingInstalled,\n handleHashCommand,\n} from '@commands/terminalSetup'\nimport { usePermissionContext } from '@context/PermissionContext'\nimport { getHookManager } from '@utils/hookManager'\nimport { debug as debugLogger } from '@utils/debugLogger'\nimport { PROJECT_FILE } from '@constants/product'\nimport { openInExternalEditor, resolveEditor } from '@utils/externalEditor'\nimport { t } from '@i18n'\n\n// Async function to interpret the '#' command input using AI\nasync function interpretHashCommand(input: string): Promise<string> {\n // Use the AI to interpret the input\n try {\n const { queryQuick } = await import('@services/claude')\n\n // Create a prompt for the model to interpret the hash command\n const systemPrompt = [\n \"You're helping the user structure notes that will be added to their KODING.md file.\",\n \"Format the user's input into a well-structured note that will be useful for later reference.\",\n 'Add appropriate markdown formatting, headings, bullet points, or other structural elements as needed.',\n 'The goal is to transform the raw note into something that will be more useful when reviewed later.',\n 'You should keep the original meaning but make the structure clear.',\n ]\n\n // Send the request to the AI\n const result = await queryQuick({\n systemPrompt,\n userPrompt: `Transform this note for KODING.md: ${input}`,\n })\n\n // Extract the content from the response\n if (typeof result.message.content === 'string') {\n return result.message.content\n } else if (Array.isArray(result.message.content)) {\n return result.message.content\n .filter(block => block.type === 'text')\n .map(block => (block.type === 'text' ? block.text : ''))\n .join('\\n')\n }\n\n return `# ${input}\\n\\n_Added on ${new Date().toLocaleString()}_`\n } catch (e) {\n // If interpretation fails, return the input with minimal formatting\n return `# ${input}\\n\\n_Added on ${new Date().toLocaleString()}_`\n }\n}\n\ntype Props = {\n commands: Command[]\n forkNumber: number\n messageLogName: string\n isDisabled: boolean\n isLoading: boolean\n onQuery: (\n newMessages: Message[],\n abortController?: AbortController,\n ) => Promise<void>\n debug: boolean\n verbose: boolean // Derived from screen mode (screen === 'transcript')\n messages: Message[]\n setToolJSX: SetToolJSXFn\n tools: Tool[]\n input: string\n onInputChange: (value: string) => void\n mode: 'bash' | 'prompt' | 'koding'\n onModeChange: (mode: 'bash' | 'prompt' | 'koding') => void\n submitCount: number\n onSubmitCountChange: (updater: (prev: number) => number) => void\n setIsLoading: (isLoading: boolean) => void\n setAbortController: (abortController: AbortController | null) => void\n onShowMessageSelector: () => void\n setForkConvoWithMessagesOnTheNextRender: (\n forkConvoWithMessages: Message[],\n ) => void\n readFileTimestamps: { [filename: string]: number }\n abortController: AbortController | null\n onModelChange?: () => void\n onShowRewindPanel?: () => void // Double-Esc: show rewind panel\n onToggleTodoPanel?: () => void // Ctrl+T: Toggle TodoPanel\n onToggleThinkingSelector?: () => void // \u2325T: Toggle thinking mode selector\n onToggleScreen?: () => void | Promise<void> // Ctrl+O: Toggle screen mode (prompt \u2194 transcript)\n onToggleShowAllInTranscript?: () => void | Promise<void> // Ctrl+E: Show/hide previous messages in transcript mode\n screen?: 'prompt' | 'transcript' // Current screen mode\n onToggleBackgroundPanel?: () => void // View background tasks\n onToggleTeamPanel?: () => void // Shift+Down: Toggle team panel\n onCycleTeammate?: (direction: 'next' | 'prev') => void // Shift+Down/Up: Cycle teammate focus\n onToggleAgentView?: () => void // Ctrl+J: Toggle agent view\n onKillAllAgents?: () => void // Ctrl+F: Kill all background agents\n backgroundShellCount?: number // Number of active background shells\n isBackgroundPanelOpen?: boolean // Whether background panel is currently visible\n fallbackMode?: boolean // Whether to use limited input mode (raw mode not supported)\n // Message injection: push user guidance into injection channel during active query\n onInjectMessage?: (input: string) => void // Callback to inject message into running query\n onRemoveQueuedMessage?: () => string | undefined // Remove last user message from injection channel (for queue editing)\n injectionPending?: boolean // Whether injection channel has pending messages\n getQueuedUserMessages?: () => string[] // Peek at user messages in injection channel (for visual sync on agent switch)\n // Unified interrupt callback - handles all cleanup when ESC cancels a request\n onInterrupt?: () => void\n // Whether an overlay (like TabbedListView) is active below PromptInput\n isOverlayActive?: boolean\n // Unmount current REPL (for commands that need to replace the entire UI, like /resume)\n unmount?: () => void\n // Startup status items (MCP servers, version check) shown in footer while loading\n startupItems?: StartupItem[]\n // Team member info for inline agent context display\n teamMembers?: { name: string; status: string }[]\n hasActiveTeam?: boolean\n // Focused agent name for placeholder (e.g., \"Message @team-lead...\")\n focusedAgentName?: string | null\n}\n\nfunction getPastedTextPrompt(text: string): string {\n const newlineCount = (text.match(/\\r\\n|\\r|\\n/g) || []).length\n return `[Pasted text #1 +${newlineCount} lines]`\n}\nfunction PromptInput({\n commands,\n forkNumber,\n messageLogName,\n isDisabled,\n isLoading,\n onQuery,\n debug,\n verbose,\n messages,\n setToolJSX,\n tools,\n input,\n onInputChange,\n mode,\n onModeChange,\n submitCount,\n onSubmitCountChange,\n setIsLoading,\n fallbackMode = false,\n abortController,\n setAbortController,\n onShowMessageSelector,\n setForkConvoWithMessagesOnTheNextRender,\n readFileTimestamps,\n onToggleTodoPanel,\n onToggleThinkingSelector,\n onToggleScreen,\n onToggleShowAllInTranscript,\n screen = 'prompt',\n onModelChange,\n onShowRewindPanel,\n onToggleBackgroundPanel,\n onToggleTeamPanel,\n onCycleTeammate,\n onToggleAgentView,\n onKillAllAgents,\n backgroundShellCount = 0,\n isBackgroundPanelOpen = false,\n onInjectMessage,\n onRemoveQueuedMessage,\n injectionPending = false,\n getQueuedUserMessages,\n onInterrupt,\n isOverlayActive = false,\n unmount,\n startupItems,\n teamMembers = [],\n hasActiveTeam = false,\n focusedAgentName,\n}: Props): React.ReactNode {\n const [exitMessage, setExitMessage] = useState<{\n show: boolean\n key?: string\n }>({ show: false })\n const [message, setMessage] = useState<{ show: boolean; text?: string }>({\n show: false,\n })\n const [modelSwitchMessage, setModelSwitchMessage] = useState<{\n show: boolean\n text?: string\n }>({\n show: false,\n })\n const [pastedImage, setPastedImage] = useState<string | null>(null)\n const [placeholder, setPlaceholder] = useState('')\n const [cursorOffset, setCursorOffset] = useState<number>(input.length)\n const [pastedText, setPastedText] = useState<string | null>(null)\n // Store the exact placeholder shown in input, so submit can match it for replacement\n const pastedPlaceholderRef = useRef<string | null>(null)\n\n // Ctrl-D double-tap tracking\n const [ctrlDCount, setCtrlDCount] = useState(0)\n const [ctrlDTimer, setCtrlDTimer] = useState<NodeJS.Timeout | null>(null)\n\n // Esc double-tap tracking for rollback detection\n // Single Esc = immediate action (clear/interrupt), Double Esc = rollback\n const [escCount, setEscCount] = useState(0)\n const [escTimer, setEscTimer] = useState<NodeJS.Timeout | null>(null)\n const ESC_DOUBLE_TAP_WINDOW = 500 // ms\n\n // Ctrl+F double-tap tracking for kill all agents\n const [ctrlFCount, setCtrlFCount] = useState(0)\n const [ctrlFTimer, setCtrlFTimer] = useState<NodeJS.Timeout | null>(null)\n\n // Cleanup timers on unmount to prevent memory leaks\n useEffect(() => {\n return () => {\n if (ctrlDTimer) clearTimeout(ctrlDTimer)\n if (escTimer) clearTimeout(escTimer)\n if (ctrlFTimer) clearTimeout(ctrlFTimer)\n }\n }, [ctrlDTimer, escTimer, ctrlFTimer])\n\n // Hotkey feedback messages (for Ctrl-C, Ctrl-L, Ctrl-O)\n const [hotkeyMessage, setHotkeyMessage] = useState<{\n show: boolean\n text?: string\n }>({ show: false })\n\n // Hotkey help panel visibility\n const [showHotkeyHelp, setShowHotkeyHelp] = useState(false)\n\n // Background task indicator focus state\n const [backgroundIndicatorFocused, setBackgroundIndicatorFocused] =\n useState(false)\n\n // Visual queue: derived from injection channel (single source of truth)\n const queuedMessages = getQueuedUserMessages?.() ?? []\n\n // Permission context for mode management\n const { cycleMode, currentMode, getModeConfig } = usePermissionContext()\n\n // Show temporary feedback when permission mode changes (including back to default)\n const prevModeRef = useRef(currentMode)\n useEffect(() => {\n if (currentMode !== prevModeRef.current) {\n const config = getModeConfig()\n const text =\n currentMode === 'default'\n ? 'default mode (shift+tab to cycle)'\n : `${config.inlineIcon} ${config.inlineLabel} (shift+tab to cycle)`\n setHotkeyMessage({ show: true, text })\n setTimeout(() => setHotkeyMessage({ show: false }), 3000)\n prevModeRef.current = currentMode\n }\n }, [currentMode, getModeConfig])\n\n // useEffect(() => {\n // getExampleCommands().then(commands => {\n // setPlaceholder(`Try \"${sample(commands)}\"`)\n // })\n // }, [])\n\n // Get terminal size once and derive all values from it\n const terminalSize = useTerminalSize()\n const { columns } = terminalSize\n // Calculate text input columns: terminal width - 6 (3 for mode indicator, 3 for padding/borders)\n const textInputColumns = columns - 6\n\n const commandWidth = useMemo(\n () => Math.max(...commands.map(cmd => cmd.userFacingName().length)) + 5,\n [commands],\n )\n\n // Unified completion system - one hook to rule them all (now with terminal behavior)\n const {\n suggestions,\n selectedIndex,\n isActive: completionActive,\n emptyDirMessage,\n } = useUnifiedCompletion({\n input,\n cursorOffset,\n onInputChange,\n setCursorOffset,\n commands,\n onSubmit,\n })\n\n // Phase 3: History search with Ctrl-R\n const history = useMemo(() => getHistory(), [submitCount]) // Refresh on submit\n const historySearch = useHistorySearch(history)\n\n // Get theme early for memoized rendering\n const theme = getTheme()\n\n // Compute current input context for context-aware hints\n const inputContext: InputContext = useMemo(() => {\n if (isLoading) return 'loading'\n if (historySearch.isActive) return 'history_search'\n if (completionActive) return 'completion'\n if (input.startsWith('/')) return 'slash_command'\n if (input.trim().length > 0) return 'typing'\n return 'idle'\n }, [isLoading, historySearch.isActive, completionActive, input])\n\n // Visible window size for suggestions - show limited items with scrolling\n const MAX_VISIBLE_SUGGESTIONS = 8\n\n // Calculate visible window for suggestions (pagination logic)\n const visibleSuggestions = useMemo(() => {\n if (suggestions.length === 0) return []\n\n // If all suggestions fit in window, show them all\n if (suggestions.length <= MAX_VISIBLE_SUGGESTIONS) {\n return suggestions.map((s, i) => ({ ...s, globalIndex: i }))\n }\n\n // Calculate scroll window to keep selected item visible\n const halfWindow = Math.floor(MAX_VISIBLE_SUGGESTIONS / 2)\n let startIndex = Math.max(0, selectedIndex - halfWindow)\n let endIndex = startIndex + MAX_VISIBLE_SUGGESTIONS\n\n // Adjust if we're near the end\n if (endIndex > suggestions.length) {\n endIndex = suggestions.length\n startIndex = Math.max(0, endIndex - MAX_VISIBLE_SUGGESTIONS)\n }\n\n return suggestions\n .slice(startIndex, endIndex)\n .map((s, i) => ({ ...s, globalIndex: startIndex + i }))\n }, [suggestions, selectedIndex])\n\n // Memoized completion suggestions rendering - with scroll indicators\n const renderedSuggestions = useMemo(() => {\n if (suggestions.length === 0) return null\n\n const hasMoreAbove =\n visibleSuggestions.length > 0 && visibleSuggestions[0].globalIndex > 0\n const hasMoreBelow =\n visibleSuggestions.length > 0 &&\n visibleSuggestions[visibleSuggestions.length - 1].globalIndex <\n suggestions.length - 1\n\n return (\n <>\n {hasMoreAbove && (\n <Box>\n <Text color={SEMANTIC_COLORS.dim}>\n {' '}\n \u2191 {visibleSuggestions[0].globalIndex} more above...\n </Text>\n </Box>\n )}\n {visibleSuggestions.map(suggestion => {\n const isSelected = suggestion.globalIndex === selectedIndex\n const isAgent = suggestion.type === 'agent'\n\n // Simple color logic - brand gradient for selection\n const displayColor = isSelected\n ? BRAND_GRADIENT.START\n : isAgent && suggestion.metadata?.color\n ? suggestion.metadata.color\n : undefined\n\n return (\n <Box\n key={`${suggestion.type}-${suggestion.value}-${suggestion.globalIndex}`}\n flexDirection=\"row\"\n >\n <Text\n color={\n displayColor ||\n (!isSelected ? SEMANTIC_COLORS.dim : undefined)\n }\n >\n {isSelected ? '\u25C6 ' : ' '}\n {suggestion.displayValue}\n </Text>\n </Box>\n )\n })}\n {hasMoreBelow && (\n <Box>\n <Text color={SEMANTIC_COLORS.dim}>\n {' '}\n \u2193{' '}\n {suggestions.length -\n visibleSuggestions[visibleSuggestions.length - 1].globalIndex -\n 1}{' '}\n more below...\n </Text>\n </Box>\n )}\n </>\n )\n }, [suggestions, selectedIndex, visibleSuggestions, theme.suggestion])\n\n const onChange = useCallback(\n (value: string) => {\n if (value.startsWith('!')) {\n onModeChange('bash')\n return\n }\n if (value.startsWith('#')) {\n onModeChange('koding')\n return\n }\n onInputChange(value)\n },\n [onModeChange, onInputChange],\n )\n\n // Handle Shift+M model switching with enhanced debugging\n const handleQuickModelSwitch = useCallback(async () => {\n const modelManager = getModelManager()\n const currentTokens = countTokens(messages)\n\n // Get debug info for better error reporting\n const debugInfo = modelManager.getModelSwitchingDebugInfo()\n\n const switchResult = modelManager.switchToNextModel(currentTokens)\n\n if (switchResult.success && switchResult.modelName) {\n // Successful switch - use enhanced message from model manager\n onSubmitCountChange(prev => prev + 1)\n setModelSwitchMessage({\n show: true,\n text:\n switchResult.message || `\u2705 Switched to ${switchResult.modelName}`,\n })\n setTimeout(() => setModelSwitchMessage({ show: false }), 3000)\n } else if (switchResult.blocked && switchResult.message) {\n // Context overflow - show detailed message\n setModelSwitchMessage({\n show: true,\n text: switchResult.message,\n })\n setTimeout(() => setModelSwitchMessage({ show: false }), 5000)\n } else {\n // Enhanced error reporting with debug info\n let errorMessage = switchResult.message\n\n if (!errorMessage) {\n if (debugInfo.totalModels === 0) {\n errorMessage = '\u274C No models configured. Use /model to add models.'\n } else if (debugInfo.activeModels === 0) {\n errorMessage = `\u274C No active models (${debugInfo.totalModels} total, all inactive). Use /model to activate models.`\n } else if (debugInfo.activeModels === 1) {\n // Show ALL models including inactive ones for debugging\n const allModelNames = debugInfo.availableModels\n .map(m => `${m.name}${m.isActive ? '' : ' (inactive)'}`)\n .join(', ')\n errorMessage = `\u26A0\uFE0F Only 1 active model out of ${debugInfo.totalModels} total models: ${allModelNames}. ALL configured models will be activated for switching.`\n } else {\n errorMessage = `\u274C Model switching failed (${debugInfo.activeModels} active, ${debugInfo.totalModels} total models available)`\n }\n }\n\n setModelSwitchMessage({\n show: true,\n text: errorMessage,\n })\n setTimeout(() => setModelSwitchMessage({ show: false }), 6000)\n }\n }, [onSubmitCountChange, messages])\n\n const { resetHistory, onHistoryUp, onHistoryDown } = useArrowKeyHistory(\n (value: string, mode: 'bash' | 'prompt' | 'koding') => {\n onChange(value)\n onModeChange(mode)\n },\n input,\n )\n\n // Only use history navigation when there are no suggestions\n const handleHistoryUp = () => {\n if (completionActive) return\n // If queue has messages and input is empty, pop last message for editing\n if (isLoading && queuedMessages.length > 0 && !input.trim()) {\n // Remove from injection channel (single source of truth) and load into input\n const removed = onRemoveQueuedMessage?.()\n if (removed) {\n onInputChange(removed)\n }\n return\n }\n onHistoryUp()\n }\n\n const handleHistoryDown = () => {\n if (!completionActive) {\n onHistoryDown()\n }\n }\n\n async function onSubmit(input: string, isSubmittingSlashCommand = false) {\n // UserPromptSubmit hook\n const hookManager = getHookManager()\n if (hookManager && input && input.trim()) {\n try {\n const decision = await hookManager.executeUserPromptSubmit(input)\n\n if (!decision.shouldContinue) {\n if (decision.shouldAskUser) {\n // Hook advisory \u2014 log warning and continue (confirm() not available in Node.js terminal)\n process.stderr.write(\n `\\n\u26A0 Hook: ${decision.reason || 'Hook requested pause.'}\\n`,\n )\n } else {\n // Blocked by hook\n setMessage({\n show: true,\n text: decision.reason || 'Blocked by hook',\n })\n setTimeout(() => setMessage({ show: false }), 3000)\n return\n }\n }\n } catch (err) {\n debugLogger.error('UserPromptSubmit hook failed', { error: err })\n // Continue on error (fail-safe)\n }\n }\n\n // Special handling for \"put a verbose summary\" and similar action prompts in koding mode\n if (\n (mode === 'koding' || input.startsWith('#')) &&\n input.match(/^(#\\s*)?(put|create|generate|write|give|provide)/i)\n ) {\n try {\n // Store the original input for history\n const originalInput = input\n\n // Strip the # prefix if present\n const cleanInput = mode === 'koding' ? input : input.substring(1).trim()\n\n // Add to history and clear input field\n addToHistory(mode === 'koding' ? `#${input}` : input)\n onInputChange('')\n\n // Create additional context to inform the assistant this is for KODING.md\n const kodingContext = `The user is using Koding mode. Format your response as a comprehensive, well-structured document suitable for adding to ${PROJECT_FILE}. Use proper markdown formatting with headings, lists, code blocks, etc. The response should be complete and ready to add to ${PROJECT_FILE} documentation.`\n\n // Switch to prompt mode but tag the submission for later capture\n onModeChange('prompt')\n\n // \uD83D\uDD27 Fix Koding mode: clean up previous state\n if (abortController) {\n abortController.abort()\n }\n setIsLoading(false)\n await new Promise(resolve => setTimeout(resolve, 0))\n\n // Set loading state - AbortController now created in onQuery\n setIsLoading(true)\n\n // Process as a normal user input but with special handling\n const messages = await processUserInput(\n cleanInput,\n 'prompt', // Use prompt mode for processing\n setToolJSX,\n {\n options: {\n commands,\n forkNumber,\n messageLogName,\n tools,\n verbose,\n maxThinkingTokens: 0,\n // Add context flag for koding mode\n isKodingRequest: true,\n kodingContext,\n },\n messageId: undefined,\n abortController: abortController || new AbortController(), // Temporary controller, actual one created in onQuery\n readFileTimestamps,\n setForkConvoWithMessagesOnTheNextRender,\n unmount: unmount || (() => {}),\n },\n pastedImage ?? null,\n )\n\n // Send query and capture response\n if (messages.length) {\n await onQuery(messages)\n\n // After query completes, the last message should be the assistant's response\n // We'll set up a one-time listener to capture and save that response\n // This will be handled by the REPL component or message handler\n }\n\n return\n } catch (e) {\n // If something fails, log the error\n console.error('Error processing Koding request:', e)\n }\n }\n\n // If in koding mode or input starts with '#', interpret it using AI before appending to MINTO.md\n else if (mode === 'koding' || input.startsWith('#')) {\n try {\n // Strip the # if we're in koding mode and the user didn't type it (since it's implied)\n const contentToInterpret =\n mode === 'koding' && !input.startsWith('#')\n ? input.trim()\n : input.substring(1).trim()\n\n const interpreted = await interpretHashCommand(contentToInterpret)\n handleHashCommand(interpreted)\n } catch (e) {\n // If interpretation fails, log the error\n }\n onInputChange('')\n addToHistory(mode === 'koding' ? `#${input}` : input)\n onModeChange('prompt')\n return\n }\n if (input === '') {\n return\n }\n if (isDisabled) {\n return\n }\n\n // Intercept exit commands FIRST \u2014 must run before isLoading/injection check\n // so that \"quit\" always exits, even during an active query.\n // exit() uses dynamic import (async), so we must return immediately to\n // prevent the code from continuing to send the input as a normal message.\n const exitCommands = [\n 'exit',\n 'quit',\n ':q',\n ':q!',\n ':wq',\n ':wq!',\n '/exit',\n '/quit',\n '/q',\n ]\n if (exitCommands.includes(input.trim())) {\n exit()\n return\n }\n\n // Queue user messages during active query \u2014 push to injection channel (single source of truth)\n if (isLoading) {\n if (onInjectMessage && input.trim()) {\n onInjectMessage(input.trim())\n onInputChange('')\n }\n return\n }\n\n // Handle Enter key when completions are active\n // If there are suggestions showing, Enter should complete the selection, not send the message\n if (suggestions.length > 0 && completionActive) {\n // The completion is handled by useUnifiedCompletion hook\n // Just return to prevent message sending\n return\n }\n\n let finalInput = input\n if (pastedText) {\n // Use the exact placeholder that was inserted into the input field\n const storedPlaceholder = pastedPlaceholderRef.current\n if (storedPlaceholder && finalInput.includes(storedPlaceholder)) {\n finalInput = finalInput.replace(storedPlaceholder, pastedText)\n } else {\n // Fallback: try the standard prompt format\n const pastedPrompt = getPastedTextPrompt(pastedText)\n if (finalInput.includes(pastedPrompt)) {\n finalInput = finalInput.replace(pastedPrompt, pastedText)\n }\n }\n }\n\n onInputChange('')\n onModeChange('prompt')\n // Suggestions are now handled by unified completion\n setPastedImage(null)\n setPastedText(null)\n pastedPlaceholderRef.current = null\n onSubmitCountChange(_ => _ + 1)\n\n setIsLoading(true)\n\n const newAbortController = new AbortController()\n setAbortController(newAbortController)\n\n const messages = await processUserInput(\n finalInput,\n mode,\n setToolJSX,\n {\n options: {\n commands,\n forkNumber,\n messageLogName,\n tools,\n verbose,\n maxThinkingTokens: 0,\n },\n messageId: undefined,\n abortController: newAbortController,\n readFileTimestamps,\n setForkConvoWithMessagesOnTheNextRender,\n unmount: unmount || (() => {}),\n },\n pastedImage ?? null,\n )\n\n if (messages.length) {\n onQuery(messages, newAbortController)\n } else {\n // Local JSX commands\n addToHistory(input)\n resetHistory()\n return\n }\n\n for (const message of messages) {\n if (message.type === 'user') {\n const inputToAdd = mode === 'bash' ? `!${input}` : input\n addToHistory(inputToAdd)\n resetHistory()\n }\n }\n }\n\n function onImagePaste(image: string) {\n onModeChange('prompt')\n setPastedImage(image)\n }\n\n function onTextPaste(rawText: string) {\n // Replace any \\r with \\n first to match useTextInput's conversion behavior\n const text = rawText.replace(/\\r/g, '\\n')\n\n // Try to cache large paste content (> 1000 chars)\n const cacheEntry = cachePaste(text)\n\n // Generate a unified placeholder (CC-style for both cached and non-cached)\n let pastedPrompt: string\n if (cacheEntry) {\n // Use CC-style placeholder for large pastes\n pastedPrompt = createPlaceholder(cacheEntry)\n debugLogger.trace('PASTE_CACHED', {\n length: text.length,\n hash: cacheEntry.hash.slice(0, 8),\n })\n } else {\n // Use standard prompt for smaller pastes\n pastedPrompt = getPastedTextPrompt(text)\n }\n\n // Store the exact placeholder for matching on submit\n pastedPlaceholderRef.current = pastedPrompt\n\n // Update the input with a visual indicator that text has been pasted\n const newInput =\n input.slice(0, cursorOffset) + pastedPrompt + input.slice(cursorOffset)\n onInputChange(newInput)\n\n // Update cursor position to be after the inserted indicator\n setCursorOffset(cursorOffset + pastedPrompt.length)\n\n // Still set the pastedText state for actual submission\n setPastedText(text)\n }\n\n // IMPORTANT: useInput must be called unconditionally (React Hook rule)\n // In fallback mode, we provide an empty handler to satisfy the Hook requirement\n useInput(\n fallbackMode\n ? () => {} // Fallback mode: no-op handler\n : (inputChar, key) => {\n // ========== NORMAL MODE: Full interactive input handling ==========\n // ========== NEW HOTKEYS (Phase 1) ==========\n\n // Ctrl-C: Enhanced cancel/interrupt\n if (key.ctrl && inputChar === 'c') {\n if (isLoading) {\n // Cancel ongoing request\n if (abortController && !abortController.signal.aborted) {\n abortController.abort()\n }\n setIsLoading(false)\n setHotkeyMessage({\n show: true,\n text: t('prompts.interruptedCtrlC'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n } else if (input.length > 0) {\n // Clear input\n onInputChange('')\n setHotkeyMessage({ show: true, text: t('prompts.inputCleared') })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n } else {\n // Hint for exit (optional: could implement double Ctrl-C to exit)\n setHotkeyMessage({\n show: true,\n text: t('prompts.pressCtrlDToExit'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n }\n return true\n }\n\n // ESC interrupt is now handled in handleSpecialKey (passed to TextInput)\n // TextInput's internal handler clears input on double-ESC\n // We only need to handle interrupt here as a fallback when input is empty\n\n // Ctrl-D: Graceful EOF exit (double-tap safety)\n if (key.ctrl && inputChar === 'd') {\n if (input.length > 0) {\n // If there's input, just clear it\n onInputChange('')\n setHotkeyMessage({\n show: true,\n text: t('prompts.inputClearedCtrlD'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n return true\n }\n\n // Empty input: increment Ctrl-D count for double-tap safety\n setCtrlDCount(prev => prev + 1)\n\n if (ctrlDTimer) clearTimeout(ctrlDTimer)\n const timer = setTimeout(() => setCtrlDCount(0), 1000)\n setCtrlDTimer(timer)\n\n if (ctrlDCount >= 1) {\n // Second Ctrl-D: graceful exit\n setHotkeyMessage({\n show: true,\n text: t('prompts.exitingGracefully'),\n })\n setTimeout(() => exit(), 500)\n } else {\n // First Ctrl-D: show hint\n setHotkeyMessage({\n show: true,\n text: t('prompts.pressCtrlDAgain'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n }\n\n return true\n }\n\n // Ctrl-L: Clear screen\n if (key.ctrl && inputChar === 'l') {\n clearScreen()\n setHotkeyMessage({ show: true, text: t('prompts.screenCleared') })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n return true\n }\n\n // Ctrl-O: Toggle screen mode (prompt \u2194 transcript)\n if (key.ctrl && inputChar === 'o') {\n onToggleScreen?.()\n return true\n }\n\n // Ctrl-E: Show/hide previous messages (only in transcript mode)\n if (key.ctrl && inputChar === 'e' && screen === 'transcript') {\n onToggleShowAllInTranscript?.()\n return true\n }\n\n // Ctrl+T: Toggle TodoPanel visibility (aligned with Claude Code)\n if (key.ctrl && inputChar === 't') {\n if (onToggleTodoPanel) {\n onToggleTodoPanel()\n setHotkeyMessage({\n show: true,\n text: t('prompts.todoPanelToggled'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n }\n return true\n }\n\n // Phase 4.3: Ctrl-B: Quick bash command execution\n // Note: Moving to background is handled by StreamingBashOutput component\n if (key.ctrl && inputChar === 'b') {\n if (!input || input.trim().length === 0) {\n setHotkeyMessage({\n show: true,\n text: t('prompts.typeCommandFirst'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n return true\n }\n\n // If already in bash mode (starts with !), just submit\n if (mode === 'bash') {\n setHotkeyMessage({\n show: true,\n text: t('prompts.executingBash'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n // Let it submit normally via Enter handling\n onSubmit(input)\n return true\n }\n\n // Otherwise, convert to bash command and submit\n const bashCommand = `!${input}`\n setHotkeyMessage({\n show: true,\n text: 'Executing bash command... (Ctrl-B)',\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n\n // Submit as bash command\n onSubmit(bashCommand)\n return true\n }\n\n // Ctrl+G: Open external editor for prompt composition\n if (key.ctrl && inputChar === 'g') {\n if (isLoading) return true // Don't open editor while loading\n\n const { name: editorName } = resolveEditor()\n setHotkeyMessage({\n show: true,\n text: t('prompts.openingEditor', { editor: editorName }),\n })\n\n // Use setTimeout(0) to let Ink render the message before\n // we release raw mode and hand off to the editor\n setTimeout(() => {\n try {\n const result = openInExternalEditor(input)\n if (result !== null) {\n // Editor returned new content \u2014 replace input\n onInputChange(result)\n setCursorOffset(result.length)\n setHotkeyMessage({\n show: true,\n text: t('prompts.editorDone'),\n })\n } else {\n setHotkeyMessage({\n show: true,\n text: t('prompts.editorNoChange'),\n })\n }\n } catch {\n setHotkeyMessage({\n show: true,\n text: t('prompts.editorFailed', { editor: editorName }),\n })\n }\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n }, 0)\n\n return true\n }\n\n // Ctrl+? or Ctrl+/: Toggle hotkey help panel\n if (key.ctrl && (inputChar === '?' || inputChar === '/')) {\n setShowHotkeyHelp(prev => !prev)\n return true\n }\n\n // Phase 3: Ctrl-R: Reverse history search\n if (key.ctrl && inputChar === 'r') {\n if (!historySearch.isActive) {\n // Activate history search\n historySearch.activate()\n return true\n }\n // If already active, cycle to next match (move up in history)\n historySearch.moveUp()\n return true\n }\n\n // History search mode: handle special keys\n if (historySearch.isActive) {\n // Esc: Cancel search\n if (key.escape) {\n historySearch.reset()\n return true\n }\n\n // Enter: Select current item and exit search\n if (key.return) {\n if (historySearch.selectedItem) {\n onInputChange(historySearch.selectedItem)\n }\n historySearch.reset()\n return true\n }\n\n // Up/Down: Navigate through results\n if (key.upArrow) {\n historySearch.moveUp()\n return true\n }\n if (key.downArrow) {\n historySearch.moveDown()\n return true\n }\n\n // Any other character: Update search term\n if (inputChar && !key.ctrl && !key.meta) {\n historySearch.setSearchTerm(historySearch.searchTerm + inputChar)\n return true\n }\n\n // Backspace: Remove character from search\n if (key.backspace || key.delete) {\n if (historySearch.searchTerm.length > 0) {\n historySearch.setSearchTerm(\n historySearch.searchTerm.slice(0, -1),\n )\n } else {\n // No search term, cancel search\n historySearch.reset()\n }\n return true\n }\n }\n\n // Background task indicator navigation\n if (backgroundIndicatorFocused) {\n // Up arrow: return focus to input\n if (key.upArrow) {\n setBackgroundIndicatorFocused(false)\n return true\n }\n\n // Enter: open background tasks panel\n if (key.return) {\n if (onToggleBackgroundPanel) {\n onToggleBackgroundPanel()\n }\n setBackgroundIndicatorFocused(false)\n return true\n }\n\n // Esc: unfocus indicator\n if (key.escape) {\n setBackgroundIndicatorFocused(false)\n return true\n }\n\n return true // Consume all other input when indicator is focused\n }\n\n // Down arrow when input is active: focus background indicator if it exists\n if (key.downArrow && backgroundShellCount > 0 && !completionActive) {\n setBackgroundIndicatorFocused(true)\n return true\n }\n\n // ========== EXISTING HOTKEYS ==========\n\n // Shift+Down: Now handled in handleSpecialKey (before TextInput processes keys)\n\n // For bash mode, only exit when deleting the last character (which would be the '!' character)\n if (mode === 'bash' && (key.backspace || key.delete)) {\n // Check the current input state, not the inputChar parameter\n // If current input is empty, we're about to delete the '!' character, so exit bash mode\n if (input === '') {\n onModeChange('prompt')\n }\n return undefined\n }\n\n // For koding mode, only exit when deleting the last character (which would be the '#' character)\n if (mode === 'koding' && (key.backspace || key.delete)) {\n // Check the current input state, not the inputChar parameter\n // If current input is empty, we're about to delete the '#' character, so exit koding mode\n if (input === '') {\n onModeChange('prompt')\n }\n return undefined\n }\n\n // For other modes, keep the original behavior\n if (inputChar === '' && (key.escape || key.backspace || key.delete)) {\n onModeChange('prompt')\n }\n\n // NOTE: ESC handling is in handleSpecialKey callback\n // Single Esc = clear input / interrupt task\n // Double Esc = rollback conversation\n\n // \u2325T (Option+T): Open thinking mode selector\n if (key.meta && inputChar === 't') {\n onToggleThinkingSelector?.()\n return true // Explicitly handled\n }\n\n // Shift+Tab for mode cycling (retains legacy keyboard behavior)\n if (key.shift && key.tab) {\n cycleMode()\n return true // Explicitly handled\n }\n\n return false // Not handled, allow other hooks\n },\n { isActive: !isBackgroundPanelOpen && !fallbackMode && !isOverlayActive },\n )\n\n // Handle special key combinations before character input\n // This runs BEFORE TextInput's internal handling, preventing double-processing\n // ESC handling is consolidated here - no separate useCancelRequest hook needed\n const handleSpecialKey = useCallback(\n (inputChar: string, key: any): boolean => {\n // Shift+Down: Toggle team panel (expand/collapse agent list)\n if (key.downArrow && key.shift && !key.ctrl && !key.meta) {\n onToggleTeamPanel?.()\n return true\n }\n\n // Shift+Up: Also toggle team panel (symmetric with Shift+Down)\n if (key.upArrow && key.shift && !key.ctrl && !key.meta) {\n onToggleTeamPanel?.()\n return true\n }\n\n // Ctrl+J: Toggle agent view\n if (key.ctrl && inputChar === 'j') {\n if (hasActiveTeam && onToggleAgentView) {\n onToggleAgentView()\n }\n return true\n }\n\n // Ctrl+F: Kill all background agents (double-tap safety)\n if (key.ctrl && inputChar === 'f') {\n if (hasActiveTeam && onKillAllAgents) {\n setCtrlFCount(prev => prev + 1)\n if (ctrlFTimer) clearTimeout(ctrlFTimer)\n const timer = setTimeout(() => setCtrlFCount(0), 2000)\n setCtrlFTimer(timer)\n\n if (ctrlFCount >= 1) {\n // Second press within 2s: kill all\n setCtrlFCount(0)\n onKillAllAgents()\n setHotkeyMessage({\n show: true,\n text: t('prompts.allAgentsKilled'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n } else {\n // First press: show confirmation\n setHotkeyMessage({\n show: true,\n text: t('prompts.pressCtrlFAgain'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n }\n return true\n }\n return false // Let Ctrl+F pass through when no active team\n }\n\n // Shift+M for model switching - only when input is empty to avoid conflict with typing uppercase \"M\"\n if (\n key.shift &&\n (inputChar === 'M' || inputChar === 'm') &&\n input.length === 0\n ) {\n handleQuickModelSwitch()\n return true // Prevent character from being input\n }\n\n // ESC: Single tap = immediate action, Double tap = rollback\n // Priority: completion/overlay Esc > single Esc (clear/interrupt) > double Esc (rollback)\n if (key.escape) {\n // Don't handle Esc when completion popup is active \u2014 let it close first\n if (completionActive) {\n return false\n }\n\n // Double-tap detection for rollback\n const newEscCount = escCount + 1\n setEscCount(newEscCount)\n\n if (escTimer) clearTimeout(escTimer)\n const timer = setTimeout(() => setEscCount(0), ESC_DOUBLE_TAP_WINDOW)\n setEscTimer(timer)\n\n if (newEscCount >= 2) {\n // Double Esc: Show rewind panel\n setEscCount(0)\n onShowRewindPanel?.()\n return true\n }\n\n // Single Esc: immediate action based on current state\n if (input.length > 0) {\n // Clear input\n onInputChange('')\n setHotkeyMessage({\n show: true,\n text: t('prompts.inputClearedEsc'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 1000)\n } else if (isLoading && onInterrupt) {\n // Interrupt running task\n onInterrupt()\n setHotkeyMessage({\n show: true,\n text: t('prompts.interruptedEsc'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 2000)\n } else {\n // Idle + empty input: show rewind hint\n setHotkeyMessage({\n show: true,\n text: t('prompts.escEscToRollback'),\n })\n setTimeout(() => setHotkeyMessage({ show: false }), 1500)\n }\n\n return true\n }\n\n return false // Not handled, allow normal processing\n },\n [\n handleQuickModelSwitch,\n isLoading,\n input.length,\n onInputChange,\n onInterrupt,\n onShowRewindPanel,\n onToggleTeamPanel,\n onCycleTeammate,\n onToggleAgentView,\n onKillAllAgents,\n hasActiveTeam,\n completionActive,\n escCount,\n escTimer,\n ctrlFCount,\n ctrlFTimer,\n ],\n )\n\n // textInputColumns is now calculated at the top of the component from terminalSize\n const tokenUsage = useMemo(() => countTokens(messages), [messages])\n\n // \uD83D\uDD27 Fix: Track model ID changes to detect external config updates\n const modelManager = getModelManager()\n const currentModelId = (modelManager.getModel('main') as any)?.id || null\n\n const modelInfo = useMemo(() => {\n // Force fresh ModelManager instance to detect config changes\n const freshModelManager = getModelManager()\n const currentModel = freshModelManager.getModel('main')\n if (!currentModel) {\n return null\n }\n\n return {\n name: currentModel.modelName, // \uD83D\uDD27 Fix: Use actual model name, not display name\n id: (currentModel as any).id, // \u6DFB\u52A0\u6A21\u578BID\u7528\u4E8E\u8C03\u8BD5\n provider: currentModel.provider, // \u6DFB\u52A0\u63D0\u4F9B\u5546\u4FE1\u606F\n contextLength: currentModel.contextLength,\n currentTokens: tokenUsage,\n }\n }, [tokenUsage, modelSwitchMessage.show, submitCount, currentModelId]) // Track model ID to detect config changes\n\n return (\n <Box flexDirection=\"column\">\n {/* Fallback mode warning */}\n {fallbackMode && (\n <Box marginBottom={1}>\n <Text color={SEMANTIC_COLORS.running}>\n {t('prompts.limitedInputMode')}\n </Text>\n <Text color={SEMANTIC_COLORS.dim}>\n {' '}\n ({t('prompts.limitedInputModeDetail')})\n </Text>\n </Box>\n )}\n\n {/* Hotkey help panel */}\n {showHotkeyHelp && (\n <HotkeyHelpPanel\n isVisible={showHotkeyHelp}\n onClose={() => setShowHotkeyHelp(false)}\n hasActiveTeam={hasActiveTeam}\n />\n )}\n\n {/* Phase 3: History search overlay */}\n {historySearch.isActive && (\n <HistorySearchOverlay\n searchTerm={historySearch.searchTerm}\n results={historySearch.filteredResults}\n selectedIndex={historySearch.selectedIndex}\n />\n )}\n\n {/* AI \u6A21\u578B\u4FE1\u606F - \u53F3\u4E0A\u89D2\u663E\u793A\uFF0C\u4F7F\u7528\u54C1\u724C\u914D\u8272 */}\n {modelInfo && (\n <Box justifyContent=\"flex-end\" marginBottom={1}>\n <Text color={SEMANTIC_COLORS.dim}>\n <Text color={BRAND_GRADIENT.START}>\u25C6</Text>{' '}\n <Text color={SEMANTIC_COLORS.secondary}>{modelInfo.name}</Text>\n <Text color={SEMANTIC_COLORS.dim}>\n {' '}\n \u00B7 {Math.round(modelInfo.currentTokens / 1000)}k /{' '}\n {Math.round(modelInfo.contextLength / 1000)}k\n </Text>\n </Text>\n </Box>\n )}\n\n {/* Visual queue: show queued messages above the input box (CC-compatible) */}\n {isLoading && queuedMessages.length > 0 && (\n <Box flexDirection=\"column\" paddingLeft={2} marginTop={0}>\n {queuedMessages.map((msg, i) => (\n <Box key={i}>\n <Text color={SEMANTIC_COLORS.dim}>\n <Text color={BRAND_GRADIENT.START}>\u276F</Text> {msg}\n </Text>\n </Box>\n ))}\n </Box>\n )}\n\n {/* Input box with top/bottom borders only (no side borders) */}\n <Box\n alignItems=\"flex-start\"\n justifyContent=\"flex-start\"\n borderTop={true}\n borderBottom={true}\n borderLeft={false}\n borderRight={false}\n borderColor={\n isOverlayActive\n ? SEMANTIC_COLORS.muted\n : mode === 'bash'\n ? SEMANTIC_COLORS.running\n : mode === 'koding'\n ? SEMANTIC_COLORS.info\n : BRAND_GRADIENT.START\n }\n borderDimColor={false}\n borderStyle=\"single\"\n marginTop={1}\n width=\"100%\"\n >\n <Box\n alignItems=\"flex-start\"\n alignSelf=\"flex-start\"\n flexWrap=\"nowrap\"\n justifyContent=\"flex-start\"\n width={3}\n >\n {mode === 'bash' ? (\n <Text color={SEMANTIC_COLORS.running}>&nbsp;!&nbsp;</Text>\n ) : mode === 'koding' ? (\n <Text color={SEMANTIC_COLORS.info}>&nbsp;#&nbsp;</Text>\n ) : (\n <Text\n color={\n isOverlayActive\n ? SEMANTIC_COLORS.muted\n : isLoading\n ? SEMANTIC_COLORS.dim\n : BRAND_GRADIENT.START\n }\n bold={!isOverlayActive}\n >\n &nbsp;\u276F&nbsp;\n </Text>\n )}\n </Box>\n <Box paddingRight={1}>\n <TextInput\n multiline\n focus={\n !isBackgroundPanelOpen &&\n !isOverlayActive &&\n (!isLoading || !!onInjectMessage)\n }\n onSubmit={onSubmit}\n onChange={onChange}\n value={input}\n onHistoryUp={handleHistoryUp}\n onHistoryDown={handleHistoryDown}\n onHistoryReset={() => resetHistory()}\n placeholder={\n isLoading && queuedMessages.length > 0\n ? t('ui.hints.pressUpToEditQueue')\n : focusedAgentName\n ? `Message @${focusedAgentName}...`\n : submitCount > 0\n ? undefined\n : placeholder\n }\n onExit={() => process.exit(0)}\n onExitMessage={(show, key) => setExitMessage({ show, key })}\n onMessage={(show, text) => setMessage({ show, text })}\n onImagePaste={onImagePaste}\n columns={textInputColumns}\n isDimmed={isDisabled || (isLoading && !onInjectMessage)}\n disableCursorMovementForUpDownKeys={completionActive}\n cursorOffset={cursorOffset}\n onChangeCursorOffset={setCursorOffset}\n onPaste={onTextPaste}\n onSpecialKey={handleSpecialKey}\n />\n </Box>\n </Box>\n {!completionActive && suggestions.length === 0 && (\n <Box\n flexDirection=\"row\"\n justifyContent=\"space-between\"\n paddingX={2}\n paddingY={0}\n >\n <Box justifyContent=\"flex-start\" gap={1}>\n {exitMessage.show ? (\n <Text color={SEMANTIC_COLORS.dim}>\n {t('prompts.pressCtrlDAgain')}\n </Text>\n ) : message.show ? (\n <Text color={SEMANTIC_COLORS.dim}>{message.text}</Text>\n ) : hotkeyMessage.show ? (\n <Text color={BRAND_GRADIENT.START}>{hotkeyMessage.text}</Text>\n ) : modelSwitchMessage.show ? (\n <Text color={BRAND_GRADIENT.START}>\n {modelSwitchMessage.text}\n </Text>\n ) : verbose ? (\n // Verbose mode: full static hints (\u5546\u52A1\u7528\u6237\u53CB\u597D) - \u4F7F\u7528\u54C1\u724C\u914D\u8272\n <>\n <Text\n color={\n mode === 'bash'\n ? BRAND_GRADIENT.MIDDLE\n : SEMANTIC_COLORS.dim\n }\n >\n <Text\n color={\n mode === 'bash'\n ? BRAND_GRADIENT.MIDDLE\n : SEMANTIC_COLORS.secondary\n }\n >\n !\n </Text>{' '}\n {t('ui.hints.executeCommand')}\n </Text>\n <Text\n color={\n mode === 'koding'\n ? SEMANTIC_COLORS.info\n : SEMANTIC_COLORS.dim\n }\n >\n \u00B7{' '}\n <Text\n color={\n mode === 'koding'\n ? SEMANTIC_COLORS.info\n : SEMANTIC_COLORS.secondary\n }\n >\n #\n </Text>{' '}\n {t('ui.hints.recordNote')}\n </Text>\n <Text color={SEMANTIC_COLORS.dim}>\n \u00B7 <Text color={SEMANTIC_COLORS.secondary}>/</Text>{' '}\n {t('ui.hints.featureMenu')} \u00B7{' '}\n <Text color={SEMANTIC_COLORS.secondary}>ctrl+?</Text>{' '}\n {t('common.help')}\n </Text>\n {backgroundShellCount > 0 && (\n <Text\n color={\n backgroundIndicatorFocused\n ? BRAND_GRADIENT.START\n : BRAND_GRADIENT.MIDDLE\n }\n backgroundColor={\n backgroundIndicatorFocused\n ? BRAND_GRADIENT.START\n : undefined\n }\n >\n \u00B7 {backgroundIndicatorFocused ? '\u25BA ' : ''}\n {t('ui.hints.backgroundTasks', {\n count: backgroundShellCount,\n })}\n </Text>\n )}\n {injectionPending && (\n <Text color={BRAND_GRADIENT.MIDDLE}>\n \u00B7 {t('ui.hints.injectionPending')}\n </Text>\n )}\n {hasActiveTeam &&\n teamMembers.filter(m => m.status !== 'stopped').length >\n 0 && (\n <Text color={BRAND_GRADIENT.MIDDLE}>\n \u00B7{' '}\n {teamMembers\n .filter(m => m.status !== 'stopped')\n .map(m => `@${m.name}`)\n .join(' ')}\n \u00B7 {teamMembers.filter(m => m.status === 'working').length}{' '}\n active \u00B7 shift+\u2193 to expand\n </Text>\n )}\n </>\n ) : (\n // Normal mode: context-aware hints with 0.1.7 style\n <>\n <ContextAwareHints context={inputContext} compact />\n {backgroundShellCount > 0 && (\n <Text\n color={\n backgroundIndicatorFocused\n ? BRAND_GRADIENT.START\n : BRAND_GRADIENT.MIDDLE\n }\n backgroundColor={\n backgroundIndicatorFocused\n ? BRAND_GRADIENT.START\n : undefined\n }\n >\n \u2502 {backgroundIndicatorFocused ? '\u25BA ' : ''}\n {t('ui.hints.backgroundTasks', {\n count: backgroundShellCount,\n })}\n </Text>\n )}\n {injectionPending && (\n <Text color={BRAND_GRADIENT.MIDDLE}>\n \u2502 {t('ui.hints.injectionPending')}\n </Text>\n )}\n {hasActiveTeam &&\n teamMembers.filter(m => m.status !== 'stopped').length >\n 0 && (\n <Text color={BRAND_GRADIENT.MIDDLE}>\n \u2502{' '}\n {teamMembers\n .filter(m => m.status !== 'stopped')\n .map(m => `@${m.name}`)\n .join(' ')}\n \u00B7 {teamMembers.filter(m => m.status === 'working').length}{' '}\n active \u00B7 shift+\u2193 to expand\n </Text>\n )}\n </>\n )}\n </Box>\n <SentryErrorBoundary\n children={\n <Box justifyContent=\"flex-end\" gap={1}>\n {/* Startup status in footer while loading, then normal newline hint */}\n {startupItems?.some(s => s.status === 'loading') ? (\n <StartupStatusBar items={startupItems} />\n ) : (\n !debug &&\n tokenUsage < WARNING_THRESHOLD && (\n <>\n {/* Compact persistent mode badge for non-default modes */}\n {currentMode !== 'default' &&\n (() => {\n const mc = getModeConfig()\n return (\n <Text color={mc.inlineColor}>\n {mc.inlineIcon} {mc.compactLabel} \u00B7\n </Text>\n )\n })()}\n <Text color={SEMANTIC_COLORS.dim}>\n <Text color={SEMANTIC_COLORS.secondary}>\n {terminalSetup.isEnabled &&\n isShiftEnterKeyBindingInstalled()\n ? 'shift + \u23CE'\n : '\\\\\u23CE'}\n </Text>{' '}\n {t('ui.hints.forNewline')}\n </Text>\n </>\n )\n )}\n <TokenWarning tokenUsage={tokenUsage} />\n </Box>\n }\n />\n </Box>\n )}\n\n {/* Unified completion suggestions - optimized rendering */}\n {suggestions.length > 0 && (\n <Box\n flexDirection=\"row\"\n justifyContent=\"space-between\"\n paddingX={2}\n paddingY={0}\n >\n <Box flexDirection=\"column\">\n {renderedSuggestions}\n\n {/* \u7B80\u6D01\u64CD\u4F5C\u63D0\u793A\u6846 - \u5305\u542B\u5217\u8868\u4F4D\u7F6E\u4FE1\u606F\uFF0C\u4F7F\u7528\u54C1\u724C\u914D\u8272 */}\n <Box\n marginTop={1}\n paddingX={3}\n borderStyle=\"round\"\n borderColor={BRAND_GRADIENT.START}\n >\n <Text\n color={\n emptyDirMessage ? BRAND_GRADIENT.END : SEMANTIC_COLORS.dim\n }\n >\n {emptyDirMessage ||\n (() => {\n const selected = suggestions[selectedIndex]\n const positionInfo =\n suggestions.length > 1\n ? `[${selectedIndex + 1}/${suggestions.length}] `\n : ''\n\n if (!selected) {\n return `${positionInfo}${t('ui.hints.completion.navigate')}`\n }\n if (selected?.value.endsWith('/')) {\n return `${positionInfo}${t('ui.hints.completion.enterDirectory')}`\n } else if (selected?.type === 'agent') {\n return `${positionInfo}${t('ui.hints.completion.selectAgent')}`\n } else {\n return `${positionInfo}${t('ui.hints.completion.insertReference')}`\n }\n })()}\n </Text>\n </Box>\n </Box>\n <SentryErrorBoundary\n children={\n <Box justifyContent=\"flex-end\" gap={1}>\n <TokenWarning tokenUsage={countTokens(messages)} />\n </Box>\n }\n />\n </Box>\n )}\n </Box>\n )\n}\n\nexport default memo(PromptInput)\n\n// Graceful exit: shuts down MCP clients, kills child processes, then exits.\n// Cost summary is printed by useCostSummary's signal-exit handler.\n// NOTE: gracefulExit is async but always calls process.exit() internally,\n// so the process will terminate even though we fire-and-forget here.\nfunction exit(): void {\n setTerminalTitle('')\n // Dynamic import to avoid circular deps at module load time\n import('@utils/exit').then(({ gracefulExit }) => gracefulExit(0))\n}\n"],
5
+ "mappings": "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",
6
6
  "names": ["modelManager", "mode", "input", "messages", "message"]
7
7
  }