@qduc/term2 0.1.0

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 (621) hide show
  1. package/LICENSE +21 -0
  2. package/dist/agent.d.ts +19 -0
  3. package/dist/agent.d.ts.map +1 -0
  4. package/dist/agent.js +143 -0
  5. package/dist/agent.js.map +1 -0
  6. package/dist/app.d.ts +22 -0
  7. package/dist/app.d.ts.map +1 -0
  8. package/dist/app.js +403 -0
  9. package/dist/app.js.map +1 -0
  10. package/dist/app.model-command-feedback.test.d.ts +2 -0
  11. package/dist/app.model-command-feedback.test.d.ts.map +1 -0
  12. package/dist/app.model-command-feedback.test.js +19 -0
  13. package/dist/app.model-command-feedback.test.js.map +1 -0
  14. package/dist/app.parseInput.test.d.ts +2 -0
  15. package/dist/app.parseInput.test.d.ts.map +1 -0
  16. package/dist/app.parseInput.test.js +97 -0
  17. package/dist/app.parseInput.test.js.map +1 -0
  18. package/dist/cli.d.ts +3 -0
  19. package/dist/cli.d.ts.map +1 -0
  20. package/dist/cli.js +241 -0
  21. package/dist/cli.js.map +1 -0
  22. package/dist/components/ApprovalPrompt.d.ts +10 -0
  23. package/dist/components/ApprovalPrompt.d.ts.map +1 -0
  24. package/dist/components/ApprovalPrompt.js +163 -0
  25. package/dist/components/ApprovalPrompt.js.map +1 -0
  26. package/dist/components/Banner.d.ts +9 -0
  27. package/dist/components/Banner.d.ts.map +1 -0
  28. package/dist/components/Banner.js +86 -0
  29. package/dist/components/Banner.js.map +1 -0
  30. package/dist/components/BottomArea.d.ts +33 -0
  31. package/dist/components/BottomArea.d.ts.map +1 -0
  32. package/dist/components/BottomArea.js +31 -0
  33. package/dist/components/BottomArea.js.map +1 -0
  34. package/dist/components/BottomArea.test.d.ts +2 -0
  35. package/dist/components/BottomArea.test.d.ts.map +1 -0
  36. package/dist/components/BottomArea.test.js +73 -0
  37. package/dist/components/BottomArea.test.js.map +1 -0
  38. package/dist/components/ChatMessage.d.ts +7 -0
  39. package/dist/components/ChatMessage.d.ts.map +1 -0
  40. package/dist/components/ChatMessage.js +10 -0
  41. package/dist/components/ChatMessage.js.map +1 -0
  42. package/dist/components/CommandMessage.d.ts +15 -0
  43. package/dist/components/CommandMessage.d.ts.map +1 -0
  44. package/dist/components/CommandMessage.js +188 -0
  45. package/dist/components/CommandMessage.js.map +1 -0
  46. package/dist/components/CommandMessage.test.d.ts +2 -0
  47. package/dist/components/CommandMessage.test.d.ts.map +1 -0
  48. package/dist/components/CommandMessage.test.js +35 -0
  49. package/dist/components/CommandMessage.test.js.map +1 -0
  50. package/dist/components/ErrorBoundary.d.ts +27 -0
  51. package/dist/components/ErrorBoundary.d.ts.map +1 -0
  52. package/dist/components/ErrorBoundary.js +77 -0
  53. package/dist/components/ErrorBoundary.js.map +1 -0
  54. package/dist/components/ErrorBoundary.test.d.ts +2 -0
  55. package/dist/components/ErrorBoundary.test.d.ts.map +1 -0
  56. package/dist/components/ErrorBoundary.test.js +32 -0
  57. package/dist/components/ErrorBoundary.test.js.map +1 -0
  58. package/dist/components/Input/PopupManager.d.ts +42 -0
  59. package/dist/components/Input/PopupManager.d.ts.map +1 -0
  60. package/dist/components/Input/PopupManager.js +13 -0
  61. package/dist/components/Input/PopupManager.js.map +1 -0
  62. package/dist/components/InputBox.d.ts +18 -0
  63. package/dist/components/InputBox.d.ts.map +1 -0
  64. package/dist/components/InputBox.js +384 -0
  65. package/dist/components/InputBox.js.map +1 -0
  66. package/dist/components/InputBox.menu-logic.test.d.ts +2 -0
  67. package/dist/components/InputBox.menu-logic.test.d.ts.map +1 -0
  68. package/dist/components/InputBox.menu-logic.test.js +151 -0
  69. package/dist/components/InputBox.menu-logic.test.js.map +1 -0
  70. package/dist/components/InputBox.test.d.ts +2 -0
  71. package/dist/components/InputBox.test.d.ts.map +1 -0
  72. package/dist/components/InputBox.test.js +91 -0
  73. package/dist/components/InputBox.test.js.map +1 -0
  74. package/dist/components/LiveResponse.d.ts +13 -0
  75. package/dist/components/LiveResponse.d.ts.map +1 -0
  76. package/dist/components/LiveResponse.js +16 -0
  77. package/dist/components/LiveResponse.js.map +1 -0
  78. package/dist/components/MarkdownRenderer.d.ts +8 -0
  79. package/dist/components/MarkdownRenderer.d.ts.map +1 -0
  80. package/dist/components/MarkdownRenderer.js +225 -0
  81. package/dist/components/MarkdownRenderer.js.map +1 -0
  82. package/dist/components/MentorMode.test.d.ts +2 -0
  83. package/dist/components/MentorMode.test.d.ts.map +1 -0
  84. package/dist/components/MentorMode.test.js.map +1 -0
  85. package/dist/components/MessageList.d.ts +7 -0
  86. package/dist/components/MessageList.d.ts.map +1 -0
  87. package/dist/components/MessageList.js +29 -0
  88. package/dist/components/MessageList.js.map +1 -0
  89. package/dist/components/MessageList.test.d.ts +2 -0
  90. package/dist/components/MessageList.test.d.ts.map +1 -0
  91. package/dist/components/MessageList.test.js +15 -0
  92. package/dist/components/MessageList.test.js.map +1 -0
  93. package/dist/components/ModelSelectionMenu.d.ts +18 -0
  94. package/dist/components/ModelSelectionMenu.d.ts.map +1 -0
  95. package/dist/components/ModelSelectionMenu.js +91 -0
  96. package/dist/components/ModelSelectionMenu.js.map +1 -0
  97. package/dist/components/ModelSelectionMenu.test.d.ts +2 -0
  98. package/dist/components/ModelSelectionMenu.test.d.ts.map +1 -0
  99. package/dist/components/ModelSelectionMenu.test.js +83 -0
  100. package/dist/components/ModelSelectionMenu.test.js.map +1 -0
  101. package/dist/components/PathSelectionMenu.d.ts +12 -0
  102. package/dist/components/PathSelectionMenu.d.ts.map +1 -0
  103. package/dist/components/PathSelectionMenu.js +42 -0
  104. package/dist/components/PathSelectionMenu.js.map +1 -0
  105. package/dist/components/SettingsSelectionMenu.d.ts +9 -0
  106. package/dist/components/SettingsSelectionMenu.d.ts.map +1 -0
  107. package/dist/components/SettingsSelectionMenu.js +21 -0
  108. package/dist/components/SettingsSelectionMenu.js.map +1 -0
  109. package/dist/components/SlashCommandMenu.d.ts +15 -0
  110. package/dist/components/SlashCommandMenu.d.ts.map +1 -0
  111. package/dist/components/SlashCommandMenu.js +20 -0
  112. package/dist/components/SlashCommandMenu.js.map +1 -0
  113. package/dist/components/StatusBar.d.ts +11 -0
  114. package/dist/components/StatusBar.d.ts.map +1 -0
  115. package/dist/components/StatusBar.js +59 -0
  116. package/dist/components/StatusBar.js.map +1 -0
  117. package/dist/components/TextInput.d.ts +42 -0
  118. package/dist/components/TextInput.d.ts.map +1 -0
  119. package/dist/components/TextInput.js +397 -0
  120. package/dist/components/TextInput.js.map +1 -0
  121. package/dist/components/TextInput.test.d.ts +2 -0
  122. package/dist/components/TextInput.test.d.ts.map +1 -0
  123. package/dist/components/TextInput.test.js +75 -0
  124. package/dist/components/TextInput.test.js.map +1 -0
  125. package/dist/context/InputContext.d.ts +31 -0
  126. package/dist/context/InputContext.d.ts.map +1 -0
  127. package/dist/context/InputContext.js +36 -0
  128. package/dist/context/InputContext.js.map +1 -0
  129. package/dist/context/InputContext.stability.test.d.ts +2 -0
  130. package/dist/context/InputContext.stability.test.d.ts.map +1 -0
  131. package/dist/context/InputContext.stability.test.js +28 -0
  132. package/dist/context/InputContext.stability.test.js.map +1 -0
  133. package/dist/context/InputContext.test.d.ts +2 -0
  134. package/dist/context/InputContext.test.d.ts.map +1 -0
  135. package/dist/context/InputContext.test.js +168 -0
  136. package/dist/context/InputContext.test.js.map +1 -0
  137. package/dist/debug-schema.d.ts +2 -0
  138. package/dist/debug-schema.d.ts.map +1 -0
  139. package/dist/debug-schema.js +22 -0
  140. package/dist/debug-schema.js.map +1 -0
  141. package/dist/hooks/use-conversation.d.ts +78 -0
  142. package/dist/hooks/use-conversation.d.ts.map +1 -0
  143. package/dist/hooks/use-conversation.js +1017 -0
  144. package/dist/hooks/use-conversation.js.map +1 -0
  145. package/dist/hooks/use-input-history.d.ts +16 -0
  146. package/dist/hooks/use-input-history.d.ts.map +1 -0
  147. package/dist/hooks/use-input-history.js +71 -0
  148. package/dist/hooks/use-input-history.js.map +1 -0
  149. package/dist/hooks/use-model-selection.d.ts +27 -0
  150. package/dist/hooks/use-model-selection.d.ts.map +1 -0
  151. package/dist/hooks/use-model-selection.js +187 -0
  152. package/dist/hooks/use-model-selection.js.map +1 -0
  153. package/dist/hooks/use-model-selection.test.d.ts +2 -0
  154. package/dist/hooks/use-model-selection.test.d.ts.map +1 -0
  155. package/dist/hooks/use-model-selection.test.js +28 -0
  156. package/dist/hooks/use-model-selection.test.js.map +1 -0
  157. package/dist/hooks/use-path-completion.d.ts +22 -0
  158. package/dist/hooks/use-path-completion.d.ts.map +1 -0
  159. package/dist/hooks/use-path-completion.js +153 -0
  160. package/dist/hooks/use-path-completion.js.map +1 -0
  161. package/dist/hooks/use-path-completion.test.d.ts +2 -0
  162. package/dist/hooks/use-path-completion.test.d.ts.map +1 -0
  163. package/dist/hooks/use-path-completion.test.js +29 -0
  164. package/dist/hooks/use-path-completion.test.js.map +1 -0
  165. package/dist/hooks/use-setting.d.ts +7 -0
  166. package/dist/hooks/use-setting.d.ts.map +1 -0
  167. package/dist/hooks/use-setting.js +35 -0
  168. package/dist/hooks/use-setting.js.map +1 -0
  169. package/dist/hooks/use-settings-completion.d.ts +23 -0
  170. package/dist/hooks/use-settings-completion.d.ts.map +1 -0
  171. package/dist/hooks/use-settings-completion.js +164 -0
  172. package/dist/hooks/use-settings-completion.js.map +1 -0
  173. package/dist/hooks/use-settings-completion.test.d.ts +2 -0
  174. package/dist/hooks/use-settings-completion.test.d.ts.map +1 -0
  175. package/dist/hooks/use-settings-completion.test.js +334 -0
  176. package/dist/hooks/use-settings-completion.test.js.map +1 -0
  177. package/dist/hooks/use-slash-commands.d.ts +21 -0
  178. package/dist/hooks/use-slash-commands.d.ts.map +1 -0
  179. package/dist/hooks/use-slash-commands.js +87 -0
  180. package/dist/hooks/use-slash-commands.js.map +1 -0
  181. package/dist/hooks/use-slash-commands.test.d.ts +2 -0
  182. package/dist/hooks/use-slash-commands.test.d.ts.map +1 -0
  183. package/dist/hooks/use-slash-commands.test.js +246 -0
  184. package/dist/hooks/use-slash-commands.test.js.map +1 -0
  185. package/dist/lib/editor-impl.d.ts +23 -0
  186. package/dist/lib/editor-impl.d.ts.map +1 -0
  187. package/dist/lib/editor-impl.js +235 -0
  188. package/dist/lib/editor-impl.js.map +1 -0
  189. package/dist/lib/openai-agent-client.chat.test.d.ts +2 -0
  190. package/dist/lib/openai-agent-client.chat.test.d.ts.map +1 -0
  191. package/dist/lib/openai-agent-client.chat.test.js +68 -0
  192. package/dist/lib/openai-agent-client.chat.test.js.map +1 -0
  193. package/dist/lib/openai-agent-client.d.ts +48 -0
  194. package/dist/lib/openai-agent-client.d.ts.map +1 -0
  195. package/dist/lib/openai-agent-client.js +653 -0
  196. package/dist/lib/openai-agent-client.js.map +1 -0
  197. package/dist/lib/openai-agent-client.test.d.ts +2 -0
  198. package/dist/lib/openai-agent-client.test.d.ts.map +1 -0
  199. package/dist/lib/openai-agent-client.test.js +181 -0
  200. package/dist/lib/openai-agent-client.test.js.map +1 -0
  201. package/dist/lib/shell.d.ts +7 -0
  202. package/dist/lib/shell.d.ts.map +1 -0
  203. package/dist/lib/shell.js +56 -0
  204. package/dist/lib/shell.js.map +1 -0
  205. package/dist/lib/tool-invoke.d.ts +4 -0
  206. package/dist/lib/tool-invoke.d.ts.map +1 -0
  207. package/dist/lib/tool-invoke.js +26 -0
  208. package/dist/lib/tool-invoke.js.map +1 -0
  209. package/dist/lib/tool-invoke.test.d.ts +2 -0
  210. package/dist/lib/tool-invoke.test.d.ts.map +1 -0
  211. package/dist/lib/tool-invoke.test.js +19 -0
  212. package/dist/lib/tool-invoke.test.js.map +1 -0
  213. package/dist/no-singleton-imports.test.d.ts +2 -0
  214. package/dist/no-singleton-imports.test.d.ts.map +1 -0
  215. package/dist/no-singleton-imports.test.js +30 -0
  216. package/dist/no-singleton-imports.test.js.map +1 -0
  217. package/dist/prompts/anthropic.md +79 -0
  218. package/dist/prompts/codex.md +97 -0
  219. package/dist/prompts/default.md +77 -0
  220. package/dist/prompts/default.md.bak +77 -0
  221. package/dist/prompts/gpt-5.md +318 -0
  222. package/dist/prompts/lite.md +29 -0
  223. package/dist/prompts/simple-mentor.md +207 -0
  224. package/dist/prompts/simple.md +189 -0
  225. package/dist/providers/index.d.ts +5 -0
  226. package/dist/providers/index.d.ts.map +1 -0
  227. package/dist/providers/index.js +8 -0
  228. package/dist/providers/index.js.map +1 -0
  229. package/dist/providers/openai-compatible/api.d.ts +17 -0
  230. package/dist/providers/openai-compatible/api.d.ts.map +1 -0
  231. package/dist/providers/openai-compatible/api.js +58 -0
  232. package/dist/providers/openai-compatible/api.js.map +1 -0
  233. package/dist/providers/openai-compatible/model.d.ts +17 -0
  234. package/dist/providers/openai-compatible/model.d.ts.map +1 -0
  235. package/dist/providers/openai-compatible/model.js +435 -0
  236. package/dist/providers/openai-compatible/model.js.map +1 -0
  237. package/dist/providers/openai-compatible/provider.d.ts +22 -0
  238. package/dist/providers/openai-compatible/provider.d.ts.map +1 -0
  239. package/dist/providers/openai-compatible/provider.js +43 -0
  240. package/dist/providers/openai-compatible/provider.js.map +1 -0
  241. package/dist/providers/openai-compatible/utils.d.ts +3 -0
  242. package/dist/providers/openai-compatible/utils.d.ts.map +1 -0
  243. package/dist/providers/openai-compatible/utils.js +11 -0
  244. package/dist/providers/openai-compatible/utils.js.map +1 -0
  245. package/dist/providers/openai-compatible.provider.d.ts +8 -0
  246. package/dist/providers/openai-compatible.provider.d.ts.map +1 -0
  247. package/dist/providers/openai-compatible.provider.js +71 -0
  248. package/dist/providers/openai-compatible.provider.js.map +1 -0
  249. package/dist/providers/openai.provider.d.ts +2 -0
  250. package/dist/providers/openai.provider.d.ts.map +1 -0
  251. package/dist/providers/openai.provider.js +36 -0
  252. package/dist/providers/openai.provider.js.map +1 -0
  253. package/dist/providers/openrouter/api.d.ts +39 -0
  254. package/dist/providers/openrouter/api.d.ts.map +1 -0
  255. package/dist/providers/openrouter/api.js +172 -0
  256. package/dist/providers/openrouter/api.js.map +1 -0
  257. package/dist/providers/openrouter/converters.d.ts +8 -0
  258. package/dist/providers/openrouter/converters.d.ts.map +1 -0
  259. package/dist/providers/openrouter/converters.js +382 -0
  260. package/dist/providers/openrouter/converters.js.map +1 -0
  261. package/dist/providers/openrouter/converters.test.d.ts +2 -0
  262. package/dist/providers/openrouter/converters.test.d.ts.map +1 -0
  263. package/dist/providers/openrouter/converters.test.js +158 -0
  264. package/dist/providers/openrouter/converters.test.js.map +1 -0
  265. package/dist/providers/openrouter/index.d.ts +4 -0
  266. package/dist/providers/openrouter/index.d.ts.map +1 -0
  267. package/dist/providers/openrouter/index.js +4 -0
  268. package/dist/providers/openrouter/index.js.map +1 -0
  269. package/dist/providers/openrouter/model.d.ts +14 -0
  270. package/dist/providers/openrouter/model.d.ts.map +1 -0
  271. package/dist/providers/openrouter/model.js +485 -0
  272. package/dist/providers/openrouter/model.js.map +1 -0
  273. package/dist/providers/openrouter/provider.d.ts +15 -0
  274. package/dist/providers/openrouter/provider.d.ts.map +1 -0
  275. package/dist/providers/openrouter/provider.js +21 -0
  276. package/dist/providers/openrouter/provider.js.map +1 -0
  277. package/dist/providers/openrouter/utils.d.ts +10 -0
  278. package/dist/providers/openrouter/utils.d.ts.map +1 -0
  279. package/dist/providers/openrouter/utils.js +27 -0
  280. package/dist/providers/openrouter/utils.js.map +1 -0
  281. package/dist/providers/openrouter.api.retry.test.d.ts +2 -0
  282. package/dist/providers/openrouter.api.retry.test.d.ts.map +1 -0
  283. package/dist/providers/openrouter.api.retry.test.js +148 -0
  284. package/dist/providers/openrouter.api.retry.test.js.map +1 -0
  285. package/dist/providers/openrouter.d.ts +2 -0
  286. package/dist/providers/openrouter.d.ts.map +1 -0
  287. package/dist/providers/openrouter.history.test.d.ts +2 -0
  288. package/dist/providers/openrouter.history.test.d.ts.map +1 -0
  289. package/dist/providers/openrouter.history.test.js +533 -0
  290. package/dist/providers/openrouter.history.test.js.map +1 -0
  291. package/dist/providers/openrouter.js +4 -0
  292. package/dist/providers/openrouter.js.map +1 -0
  293. package/dist/providers/openrouter.provider.createRunner.test.d.ts +2 -0
  294. package/dist/providers/openrouter.provider.createRunner.test.d.ts.map +1 -0
  295. package/dist/providers/openrouter.provider.createRunner.test.js +23 -0
  296. package/dist/providers/openrouter.provider.createRunner.test.js.map +1 -0
  297. package/dist/providers/openrouter.provider.d.ts +2 -0
  298. package/dist/providers/openrouter.provider.d.ts.map +1 -0
  299. package/dist/providers/openrouter.provider.js +56 -0
  300. package/dist/providers/openrouter.provider.js.map +1 -0
  301. package/dist/providers/openrouter.test.d.ts +2 -0
  302. package/dist/providers/openrouter.test.d.ts.map +1 -0
  303. package/dist/providers/openrouter.test.js +1382 -0
  304. package/dist/providers/openrouter.test.js.map +1 -0
  305. package/dist/providers/registry.d.ts +65 -0
  306. package/dist/providers/registry.d.ts.map +1 -0
  307. package/dist/providers/registry.js +44 -0
  308. package/dist/providers/registry.js.map +1 -0
  309. package/dist/providers/registry.test.d.ts +2 -0
  310. package/dist/providers/registry.test.d.ts.map +1 -0
  311. package/dist/providers/registry.test.js +76 -0
  312. package/dist/providers/registry.test.js.map +1 -0
  313. package/dist/providers/web-search/index.d.ts +8 -0
  314. package/dist/providers/web-search/index.d.ts.map +1 -0
  315. package/dist/providers/web-search/index.js +9 -0
  316. package/dist/providers/web-search/index.js.map +1 -0
  317. package/dist/providers/web-search/registry.d.ts +35 -0
  318. package/dist/providers/web-search/registry.d.ts.map +1 -0
  319. package/dist/providers/web-search/registry.js +56 -0
  320. package/dist/providers/web-search/registry.js.map +1 -0
  321. package/dist/providers/web-search/registry.test.d.ts +2 -0
  322. package/dist/providers/web-search/registry.test.d.ts.map +1 -0
  323. package/dist/providers/web-search/registry.test.js +105 -0
  324. package/dist/providers/web-search/registry.test.js.map +1 -0
  325. package/dist/providers/web-search/tavily.provider.d.ts +15 -0
  326. package/dist/providers/web-search/tavily.provider.d.ts.map +1 -0
  327. package/dist/providers/web-search/tavily.provider.js +69 -0
  328. package/dist/providers/web-search/tavily.provider.js.map +1 -0
  329. package/dist/providers/web-search/tavily.provider.test.d.ts +2 -0
  330. package/dist/providers/web-search/tavily.provider.test.d.ts.map +1 -0
  331. package/dist/providers/web-search/tavily.provider.test.js +67 -0
  332. package/dist/providers/web-search/tavily.provider.test.js.map +1 -0
  333. package/dist/providers/web-search/types.d.ts +55 -0
  334. package/dist/providers/web-search/types.d.ts.map +1 -0
  335. package/dist/providers/web-search/types.js +6 -0
  336. package/dist/providers/web-search/types.js.map +1 -0
  337. package/dist/safety-checker.js +57 -0
  338. package/dist/services/conversation-events.d.ts +76 -0
  339. package/dist/services/conversation-events.d.ts.map +1 -0
  340. package/dist/services/conversation-events.js +2 -0
  341. package/dist/services/conversation-events.js.map +1 -0
  342. package/dist/services/conversation-service.d.ts +31 -0
  343. package/dist/services/conversation-service.d.ts.map +1 -0
  344. package/dist/services/conversation-service.js +46 -0
  345. package/dist/services/conversation-service.js.map +1 -0
  346. package/dist/services/conversation-service.test.js +190 -0
  347. package/dist/services/conversation-session.d.ts +99 -0
  348. package/dist/services/conversation-session.d.ts.map +1 -0
  349. package/dist/services/conversation-session.js +978 -0
  350. package/dist/services/conversation-session.js.map +1 -0
  351. package/dist/services/conversation-store.d.ts +24 -0
  352. package/dist/services/conversation-store.d.ts.map +1 -0
  353. package/dist/services/conversation-store.js +216 -0
  354. package/dist/services/conversation-store.js.map +1 -0
  355. package/dist/services/conversation-store.test.d.ts +2 -0
  356. package/dist/services/conversation-store.test.d.ts.map +1 -0
  357. package/dist/services/conversation-store.test.js +167 -0
  358. package/dist/services/conversation-store.test.js.map +1 -0
  359. package/dist/services/execution-context.d.ts +10 -0
  360. package/dist/services/execution-context.d.ts.map +1 -0
  361. package/dist/services/execution-context.js +22 -0
  362. package/dist/services/execution-context.js.map +1 -0
  363. package/dist/services/execution-context.test.d.ts +2 -0
  364. package/dist/services/execution-context.test.d.ts.map +1 -0
  365. package/dist/services/execution-context.test.js +49 -0
  366. package/dist/services/execution-context.test.js.map +1 -0
  367. package/dist/services/file-service.d.ts +12 -0
  368. package/dist/services/file-service.d.ts.map +1 -0
  369. package/dist/services/file-service.js +90 -0
  370. package/dist/services/file-service.js.map +1 -0
  371. package/dist/services/history-service.d.ts +39 -0
  372. package/dist/services/history-service.d.ts.map +1 -0
  373. package/dist/services/history-service.js +152 -0
  374. package/dist/services/history-service.js.map +1 -0
  375. package/dist/services/logging-service.d.ts +75 -0
  376. package/dist/services/logging-service.d.ts.map +1 -0
  377. package/dist/services/logging-service.js +343 -0
  378. package/dist/services/logging-service.js.map +1 -0
  379. package/dist/services/model-service.d.ts +15 -0
  380. package/dist/services/model-service.d.ts.map +1 -0
  381. package/dist/services/model-service.js +46 -0
  382. package/dist/services/model-service.js.map +1 -0
  383. package/dist/services/model-service.test.d.ts +2 -0
  384. package/dist/services/model-service.test.d.ts.map +1 -0
  385. package/dist/services/model-service.test.js +128 -0
  386. package/dist/services/model-service.test.js.map +1 -0
  387. package/dist/services/service-interfaces.d.ts +33 -0
  388. package/dist/services/service-interfaces.d.ts.map +1 -0
  389. package/dist/services/service-interfaces.js +2 -0
  390. package/dist/services/service-interfaces.js.map +1 -0
  391. package/dist/services/settings-service.d.ts +316 -0
  392. package/dist/services/settings-service.d.ts.map +1 -0
  393. package/dist/services/settings-service.js +1128 -0
  394. package/dist/services/settings-service.js.map +1 -0
  395. package/dist/services/settings-service.mock.d.ts +20 -0
  396. package/dist/services/settings-service.mock.d.ts.map +1 -0
  397. package/dist/services/settings-service.mock.js +55 -0
  398. package/dist/services/settings-service.mock.js.map +1 -0
  399. package/dist/services/singleton-deprecation.test.d.ts +2 -0
  400. package/dist/services/singleton-deprecation.test.d.ts.map +1 -0
  401. package/dist/services/singleton-deprecation.test.js +59 -0
  402. package/dist/services/singleton-deprecation.test.js.map +1 -0
  403. package/dist/services/ssh-service.d.ts +32 -0
  404. package/dist/services/ssh-service.d.ts.map +1 -0
  405. package/dist/services/ssh-service.js +119 -0
  406. package/dist/services/ssh-service.js.map +1 -0
  407. package/dist/services/ssh-service.test.d.ts +2 -0
  408. package/dist/services/ssh-service.test.d.ts.map +1 -0
  409. package/dist/services/ssh-service.test.js +269 -0
  410. package/dist/services/ssh-service.test.js.map +1 -0
  411. package/dist/test-search-tool.d.ts +2 -0
  412. package/dist/test-search-tool.d.ts.map +1 -0
  413. package/dist/test-search-tool.js +36 -0
  414. package/dist/test-search-tool.js.map +1 -0
  415. package/dist/tools/apply-patch.d.ts +28 -0
  416. package/dist/tools/apply-patch.d.ts.map +1 -0
  417. package/dist/tools/apply-patch.js +399 -0
  418. package/dist/tools/apply-patch.js.map +1 -0
  419. package/dist/tools/apply-patch.test.d.ts +2 -0
  420. package/dist/tools/apply-patch.test.d.ts.map +1 -0
  421. package/dist/tools/apply-patch.test.js +155 -0
  422. package/dist/tools/apply-patch.test.js.map +1 -0
  423. package/dist/tools/ask-mentor.d.ts +11 -0
  424. package/dist/tools/ask-mentor.d.ts.map +1 -0
  425. package/dist/tools/ask-mentor.js +52 -0
  426. package/dist/tools/ask-mentor.js.map +1 -0
  427. package/dist/tools/ask-mentor.test.d.ts +2 -0
  428. package/dist/tools/ask-mentor.test.d.ts.map +1 -0
  429. package/dist/tools/ask-mentor.test.js +47 -0
  430. package/dist/tools/ask-mentor.test.js.map +1 -0
  431. package/dist/tools/bash.d.ts +10 -0
  432. package/dist/tools/bash.d.ts.map +1 -0
  433. package/dist/tools/bash.js +55 -0
  434. package/dist/tools/bash.js.map +1 -0
  435. package/dist/tools/find-files.d.ts +15 -0
  436. package/dist/tools/find-files.d.ts.map +1 -0
  437. package/dist/tools/find-files.js +179 -0
  438. package/dist/tools/find-files.js.map +1 -0
  439. package/dist/tools/find-files.test.d.ts +2 -0
  440. package/dist/tools/find-files.test.d.ts.map +1 -0
  441. package/dist/tools/find-files.test.js +131 -0
  442. package/dist/tools/find-files.test.js.map +1 -0
  443. package/dist/tools/format-helpers.d.ts +34 -0
  444. package/dist/tools/format-helpers.d.ts.map +1 -0
  445. package/dist/tools/format-helpers.js +131 -0
  446. package/dist/tools/format-helpers.js.map +1 -0
  447. package/dist/tools/grep.d.ts +16 -0
  448. package/dist/tools/grep.d.ts.map +1 -0
  449. package/dist/tools/grep.js +211 -0
  450. package/dist/tools/grep.js.map +1 -0
  451. package/dist/tools/read-file.d.ts +15 -0
  452. package/dist/tools/read-file.d.ts.map +1 -0
  453. package/dist/tools/read-file.js +114 -0
  454. package/dist/tools/read-file.js.map +1 -0
  455. package/dist/tools/read-file.test.d.ts +2 -0
  456. package/dist/tools/read-file.test.d.ts.map +1 -0
  457. package/dist/tools/read-file.test.js +122 -0
  458. package/dist/tools/read-file.test.js.map +1 -0
  459. package/dist/tools/search-replace.d.ts +19 -0
  460. package/dist/tools/search-replace.d.ts.map +1 -0
  461. package/dist/tools/search-replace.js +411 -0
  462. package/dist/tools/search-replace.js.map +1 -0
  463. package/dist/tools/search-replace.test.d.ts +2 -0
  464. package/dist/tools/search-replace.test.d.ts.map +1 -0
  465. package/dist/tools/search-replace.test.js +302 -0
  466. package/dist/tools/search-replace.test.js.map +1 -0
  467. package/dist/tools/search.d.ts +15 -0
  468. package/dist/tools/search.d.ts.map +1 -0
  469. package/dist/tools/search.js +143 -0
  470. package/dist/tools/search.js.map +1 -0
  471. package/dist/tools/shell.d.ts +19 -0
  472. package/dist/tools/shell.d.ts.map +1 -0
  473. package/dist/tools/shell.js +278 -0
  474. package/dist/tools/shell.js.map +1 -0
  475. package/dist/tools/tool-execution-context.d.ts +7 -0
  476. package/dist/tools/tool-execution-context.d.ts.map +1 -0
  477. package/dist/tools/tool-execution-context.js +7 -0
  478. package/dist/tools/tool-execution-context.js.map +1 -0
  479. package/dist/tools/types.d.ts +30 -0
  480. package/dist/tools/types.d.ts.map +1 -0
  481. package/dist/tools/types.js +2 -0
  482. package/dist/tools/types.js.map +1 -0
  483. package/dist/tools/utils.d.ts +12 -0
  484. package/dist/tools/utils.d.ts.map +1 -0
  485. package/dist/tools/utils.js +19 -0
  486. package/dist/tools/utils.js.map +1 -0
  487. package/dist/tools/web-search.d.ts +29 -0
  488. package/dist/tools/web-search.d.ts.map +1 -0
  489. package/dist/tools/web-search.js +106 -0
  490. package/dist/tools/web-search.js.map +1 -0
  491. package/dist/tools/web-search.test.d.ts +2 -0
  492. package/dist/tools/web-search.test.d.ts.map +1 -0
  493. package/dist/tools/web-search.test.js +176 -0
  494. package/dist/tools/web-search.test.js.map +1 -0
  495. package/dist/utils/command-logger.d.ts +11 -0
  496. package/dist/utils/command-logger.d.ts.map +1 -0
  497. package/dist/utils/command-logger.js +34 -0
  498. package/dist/utils/command-logger.js.map +1 -0
  499. package/dist/utils/command-safety/constants.d.ts +21 -0
  500. package/dist/utils/command-safety/constants.d.ts.map +1 -0
  501. package/dist/utils/command-safety/constants.js +245 -0
  502. package/dist/utils/command-safety/constants.js.map +1 -0
  503. package/dist/utils/command-safety/find-helpers.d.ts +15 -0
  504. package/dist/utils/command-safety/find-helpers.d.ts.map +1 -0
  505. package/dist/utils/command-safety/find-helpers.js +218 -0
  506. package/dist/utils/command-safety/find-helpers.js.map +1 -0
  507. package/dist/utils/command-safety/handlers/find-handler.d.ts +6 -0
  508. package/dist/utils/command-safety/handlers/find-handler.d.ts.map +1 -0
  509. package/dist/utils/command-safety/handlers/find-handler.js +113 -0
  510. package/dist/utils/command-safety/handlers/find-handler.js.map +1 -0
  511. package/dist/utils/command-safety/handlers/git-handler.d.ts +6 -0
  512. package/dist/utils/command-safety/handlers/git-handler.d.ts.map +1 -0
  513. package/dist/utils/command-safety/handlers/git-handler.js +68 -0
  514. package/dist/utils/command-safety/handlers/git-handler.js.map +1 -0
  515. package/dist/utils/command-safety/handlers/index.d.ts +13 -0
  516. package/dist/utils/command-safety/handlers/index.d.ts.map +1 -0
  517. package/dist/utils/command-safety/handlers/index.js +20 -0
  518. package/dist/utils/command-safety/handlers/index.js.map +1 -0
  519. package/dist/utils/command-safety/handlers/sed-handler.d.ts +6 -0
  520. package/dist/utils/command-safety/handlers/sed-handler.d.ts.map +1 -0
  521. package/dist/utils/command-safety/handlers/sed-handler.js +94 -0
  522. package/dist/utils/command-safety/handlers/sed-handler.js.map +1 -0
  523. package/dist/utils/command-safety/handlers/types.d.ts +36 -0
  524. package/dist/utils/command-safety/handlers/types.d.ts.map +1 -0
  525. package/dist/utils/command-safety/handlers/types.js +2 -0
  526. package/dist/utils/command-safety/handlers/types.js.map +1 -0
  527. package/dist/utils/command-safety/index.d.ts +14 -0
  528. package/dist/utils/command-safety/index.d.ts.map +1 -0
  529. package/dist/utils/command-safety/index.js +183 -0
  530. package/dist/utils/command-safety/index.js.map +1 -0
  531. package/dist/utils/command-safety/path-analysis.d.ts +4 -0
  532. package/dist/utils/command-safety/path-analysis.d.ts.map +1 -0
  533. package/dist/utils/command-safety/path-analysis.js +153 -0
  534. package/dist/utils/command-safety/path-analysis.js.map +1 -0
  535. package/dist/utils/command-safety/utils.d.ts +2 -0
  536. package/dist/utils/command-safety/utils.d.ts.map +1 -0
  537. package/dist/utils/command-safety/utils.js +22 -0
  538. package/dist/utils/command-safety/utils.js.map +1 -0
  539. package/dist/utils/command-safety.d.ts +21 -0
  540. package/dist/utils/command-safety.d.ts.map +1 -0
  541. package/dist/utils/command-safety.find.test.d.ts +2 -0
  542. package/dist/utils/command-safety.find.test.d.ts.map +1 -0
  543. package/dist/utils/command-safety.find.test.js +342 -0
  544. package/dist/utils/command-safety.find.test.js.map +1 -0
  545. package/dist/utils/command-safety.js +702 -0
  546. package/dist/utils/command-safety.js.map +1 -0
  547. package/dist/utils/command-safety.path.test.d.ts +2 -0
  548. package/dist/utils/command-safety.path.test.d.ts.map +1 -0
  549. package/dist/utils/command-safety.path.test.js +360 -0
  550. package/dist/utils/command-safety.path.test.js.map +1 -0
  551. package/dist/utils/diff.d.ts +2 -0
  552. package/dist/utils/diff.d.ts.map +1 -0
  553. package/dist/utils/diff.js +44 -0
  554. package/dist/utils/diff.js.map +1 -0
  555. package/dist/utils/diff.test.d.ts +2 -0
  556. package/dist/utils/diff.test.d.ts.map +1 -0
  557. package/dist/utils/diff.test.js +85 -0
  558. package/dist/utils/diff.test.js.map +1 -0
  559. package/dist/utils/error-helpers.d.ts +6 -0
  560. package/dist/utils/error-helpers.d.ts.map +1 -0
  561. package/dist/utils/error-helpers.js +46 -0
  562. package/dist/utils/error-helpers.js.map +1 -0
  563. package/dist/utils/error-helpers.test.d.ts +2 -0
  564. package/dist/utils/error-helpers.test.d.ts.map +1 -0
  565. package/dist/utils/error-helpers.test.js +152 -0
  566. package/dist/utils/error-helpers.test.js.map +1 -0
  567. package/dist/utils/execute-shell.d.ts +15 -0
  568. package/dist/utils/execute-shell.d.ts.map +1 -0
  569. package/dist/utils/execute-shell.js +34 -0
  570. package/dist/utils/execute-shell.js.map +1 -0
  571. package/dist/utils/execute-shell.test.d.ts +2 -0
  572. package/dist/utils/execute-shell.test.d.ts.map +1 -0
  573. package/dist/utils/execute-shell.test.js +20 -0
  574. package/dist/utils/execute-shell.test.js.map +1 -0
  575. package/dist/utils/extract-command-messages.d.ts +5 -0
  576. package/dist/utils/extract-command-messages.d.ts.map +1 -0
  577. package/dist/utils/extract-command-messages.js +140 -0
  578. package/dist/utils/extract-command-messages.js.map +1 -0
  579. package/dist/utils/extract-command-messages.repro.test.d.ts +2 -0
  580. package/dist/utils/extract-command-messages.repro.test.d.ts.map +1 -0
  581. package/dist/utils/extract-command-messages.repro.test.js +31 -0
  582. package/dist/utils/extract-command-messages.repro.test.js.map +1 -0
  583. package/dist/utils/extract-command-messages.test.js +57 -0
  584. package/dist/utils/message-buffer.d.ts +2 -0
  585. package/dist/utils/message-buffer.d.ts.map +1 -0
  586. package/dist/utils/message-buffer.js +15 -0
  587. package/dist/utils/message-buffer.js.map +1 -0
  588. package/dist/utils/message-buffer.test.d.ts +2 -0
  589. package/dist/utils/message-buffer.test.d.ts.map +1 -0
  590. package/dist/utils/message-buffer.test.js +17 -0
  591. package/dist/utils/message-buffer.test.js.map +1 -0
  592. package/dist/utils/output-trim.d.ts +31 -0
  593. package/dist/utils/output-trim.d.ts.map +1 -0
  594. package/dist/utils/output-trim.js +71 -0
  595. package/dist/utils/output-trim.js.map +1 -0
  596. package/dist/utils/provider-credentials.d.ts +10 -0
  597. package/dist/utils/provider-credentials.d.ts.map +1 -0
  598. package/dist/utils/provider-credentials.js +22 -0
  599. package/dist/utils/provider-credentials.js.map +1 -0
  600. package/dist/utils/settings-command.d.ts +13 -0
  601. package/dist/utils/settings-command.d.ts.map +1 -0
  602. package/dist/utils/settings-command.js +173 -0
  603. package/dist/utils/settings-command.js.map +1 -0
  604. package/dist/utils/ssh-config-parser.d.ts +21 -0
  605. package/dist/utils/ssh-config-parser.d.ts.map +1 -0
  606. package/dist/utils/ssh-config-parser.js +89 -0
  607. package/dist/utils/ssh-config-parser.js.map +1 -0
  608. package/dist/utils/ssh-config-parser.test.d.ts +2 -0
  609. package/dist/utils/ssh-config-parser.test.d.ts.map +1 -0
  610. package/dist/utils/ssh-config-parser.test.js +153 -0
  611. package/dist/utils/ssh-config-parser.test.js.map +1 -0
  612. package/dist/utils/streaming-updater.d.ts +7 -0
  613. package/dist/utils/streaming-updater.d.ts.map +1 -0
  614. package/dist/utils/streaming-updater.js +41 -0
  615. package/dist/utils/streaming-updater.js.map +1 -0
  616. package/dist/utils/throttle.d.ts +7 -0
  617. package/dist/utils/throttle.d.ts.map +1 -0
  618. package/dist/utils/throttle.js +49 -0
  619. package/dist/utils/throttle.js.map +1 -0
  620. package/package.json +108 -0
  621. package/readme.md +428 -0
@@ -0,0 +1,29 @@
1
+ import test from 'ava';
2
+ import React from 'react';
3
+ import { render } from 'ink-testing-library';
4
+ import { InputProvider } from '../context/InputContext.js';
5
+ import { usePathCompletion } from './use-path-completion.js';
6
+ test('open() is blocked immediately after close() for path completion', async (t) => {
7
+ let control = null;
8
+ const Test = () => {
9
+ const hook = usePathCompletion();
10
+ control = hook;
11
+ return React.createElement(React.Fragment, null, hook.isOpen ? 'OPEN' : 'CLOSED');
12
+ };
13
+ const { lastFrame } = render(React.createElement(InputProvider, null, React.createElement(Test, null)));
14
+ t.true(lastFrame().includes('CLOSED'));
15
+ control.open(0);
16
+ await new Promise(resolve => setTimeout(resolve, 50));
17
+ t.true(lastFrame().includes('OPEN'));
18
+ control.close();
19
+ await new Promise(resolve => setTimeout(resolve, 50));
20
+ t.true(lastFrame().includes('CLOSED'));
21
+ control.open(0);
22
+ await new Promise(resolve => setTimeout(resolve, 50));
23
+ t.true(lastFrame().includes('CLOSED'));
24
+ await new Promise(resolve => setTimeout(resolve, 350));
25
+ control.open(0);
26
+ await new Promise(resolve => setTimeout(resolve, 50));
27
+ t.true(lastFrame().includes('OPEN'));
28
+ });
29
+ //# sourceMappingURL=use-path-completion.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-path-completion.test.js","sourceRoot":"","sources":["../../source/hooks/use-path-completion.test.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,KAAK,CAAC;AACvB,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAC,MAAM,EAAC,MAAM,qBAAqB,CAAC;AAC3C,OAAO,EAAC,aAAa,EAAC,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAC,iBAAiB,EAAC,MAAM,0BAA0B,CAAC;AAE3D,IAAI,CAAC,iEAAiE,EAAE,KAAK,EAAC,CAAC,EAAC,EAAE;IAC9E,IAAI,OAAO,GAAQ,IAAI,CAAC;IAExB,MAAM,IAAI,GAAG,GAAG,EAAE;QACd,MAAM,IAAI,GAAG,iBAAiB,EAAE,CAAC;QACjC,OAAO,GAAG,IAAI,CAAC;QACf,OAAO,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IACtF,CAAC,CAAC;IAEF,MAAM,EAAC,SAAS,EAAC,GAAG,MAAM,CACtB,KAAK,CAAC,aAAa,CAAC,aAAa,EAAE,IAAI,EAAE,KAAK,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAC5E,CAAC;IAEF,CAAC,CAAC,IAAI,CAAC,SAAS,EAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;IACxC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAChB,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;IACtD,CAAC,CAAC,IAAI,CAAC,SAAS,EAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;IACtC,OAAO,CAAC,KAAK,EAAE,CAAC;IAChB,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;IACtD,CAAC,CAAC,IAAI,CAAC,SAAS,EAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;IACxC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAChB,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;IACtD,CAAC,CAAC,IAAI,CAAC,SAAS,EAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;IACxC,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC;IACvD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAChB,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;IACtD,CAAC,CAAC,IAAI,CAAC,SAAS,EAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;AAC1C,CAAC,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { SettingsService } from '../services/settings-service.js';
2
+ /**
3
+ * Hook to subscribe to a specific setting value.
4
+ * Updates the component whenever the setting changes.
5
+ */
6
+ export declare function useSetting<T>(settingsService: SettingsService, key: string): T;
7
+ //# sourceMappingURL=use-setting.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-setting.d.ts","sourceRoot":"","sources":["../../source/hooks/use-setting.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAC,eAAe,EAAC,MAAM,iCAAiC,CAAC;AAErE;;;GAGG;AACH,wBAAgB,UAAU,CAAC,CAAC,EACxB,eAAe,EAAE,eAAe,EAChC,GAAG,EAAE,MAAM,GACZ,CAAC,CAkCH"}
@@ -0,0 +1,35 @@
1
+ import { useState, useEffect } from 'react';
2
+ /**
3
+ * Hook to subscribe to a specific setting value.
4
+ * Updates the component whenever the setting changes.
5
+ */
6
+ export function useSetting(settingsService, key) {
7
+ const [value, setValue] = useState(() => settingsService.get(key));
8
+ useEffect(() => {
9
+ // Ensure we have the latest value on mount/update
10
+ const currentValue = settingsService.get(key);
11
+ if (currentValue !== value) {
12
+ setValue(currentValue);
13
+ }
14
+ const unsubscribe = settingsService.onChange(changedKey => {
15
+ // optimized: only update if the relevant key changed
16
+ // simpler version: just check if the value actually changed
17
+ if (!changedKey ||
18
+ changedKey === key ||
19
+ changedKey.startsWith(key + '.') ||
20
+ key.startsWith(changedKey + '.')) {
21
+ const newValue = settingsService.get(key);
22
+ setValue(prev => {
23
+ // Simple equality check to avoid rerenders if value hasn't effectively changed
24
+ if (JSON.stringify(prev) !== JSON.stringify(newValue)) {
25
+ return newValue;
26
+ }
27
+ return prev;
28
+ });
29
+ }
30
+ });
31
+ return unsubscribe;
32
+ }, [key]);
33
+ return value;
34
+ }
35
+ //# sourceMappingURL=use-setting.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-setting.js","sourceRoot":"","sources":["../../source/hooks/use-setting.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAE,SAAS,EAAC,MAAM,OAAO,CAAC;AAG1C;;;GAGG;AACH,MAAM,UAAU,UAAU,CACtB,eAAgC,EAChC,GAAW;IAEX,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAI,GAAG,EAAE,CAAC,eAAe,CAAC,GAAG,CAAI,GAAG,CAAC,CAAC,CAAC;IAEzE,SAAS,CAAC,GAAG,EAAE;QACX,kDAAkD;QAClD,MAAM,YAAY,GAAG,eAAe,CAAC,GAAG,CAAI,GAAG,CAAC,CAAC;QACjD,IAAI,YAAY,KAAK,KAAK,EAAE,CAAC;YACzB,QAAQ,CAAC,YAAY,CAAC,CAAC;QAC3B,CAAC;QAED,MAAM,WAAW,GAAG,eAAe,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE;YACtD,qDAAqD;YACrD,4DAA4D;YAC5D,IACI,CAAC,UAAU;gBACX,UAAU,KAAK,GAAG;gBAClB,UAAU,CAAC,UAAU,CAAC,GAAG,GAAG,GAAG,CAAC;gBAChC,GAAG,CAAC,UAAU,CAAC,UAAU,GAAG,GAAG,CAAC,EAClC,CAAC;gBACC,MAAM,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAI,GAAG,CAAC,CAAC;gBAC7C,QAAQ,CAAC,IAAI,CAAC,EAAE;oBACZ,+EAA+E;oBAC/E,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC;wBACpD,OAAO,QAAQ,CAAC;oBACpB,CAAC;oBACD,OAAO,IAAI,CAAC;gBAChB,CAAC,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,OAAO,WAAW,CAAC;IACvB,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAEV,OAAO,KAAK,CAAC;AACjB,CAAC"}
@@ -0,0 +1,23 @@
1
+ import Fuse from 'fuse.js';
2
+ import { type SettingsService } from '../services/settings-service.js';
3
+ export type SettingCompletionItem = {
4
+ key: string;
5
+ description?: string;
6
+ currentValue?: string | number | boolean;
7
+ };
8
+ export declare function buildSettingsList(settingKeys: Record<string, string>, descriptions: Record<string, string>, excludeSensitive?: boolean, getCurrentValue?: (key: string) => string | number | boolean | undefined): SettingCompletionItem[];
9
+ export declare function filterSettingsByQuery(settings: SettingCompletionItem[], query: string, fuseInstance: Fuse<SettingCompletionItem>, maxResults?: number): SettingCompletionItem[];
10
+ export declare function clampIndex(currentIndex: number, arrayLength: number): number;
11
+ export declare const useSettingsCompletion: (settingsService: SettingsService) => {
12
+ isOpen: boolean;
13
+ triggerIndex: number | null;
14
+ query: string;
15
+ filteredEntries: SettingCompletionItem[];
16
+ selectedIndex: number;
17
+ open: (startIndex: number, _initialQuery?: string) => void;
18
+ close: () => void;
19
+ moveUp: () => void;
20
+ moveDown: () => void;
21
+ getSelectedItem: () => SettingCompletionItem | undefined;
22
+ };
23
+ //# sourceMappingURL=use-settings-completion.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-settings-completion.d.ts","sourceRoot":"","sources":["../../source/hooks/use-settings-completion.ts"],"names":[],"mappings":"AACA,OAAO,IAAI,MAAM,SAAS,CAAC;AAC3B,OAAO,EAGH,KAAK,eAAe,EACvB,MAAM,iCAAiC,CAAC;AAGzC,MAAM,MAAM,qBAAqB,GAAG;IAChC,GAAG,EAAE,MAAM,CAAC;IACZ,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;CAC5C,CAAC;AA4DF,wBAAgB,iBAAiB,CAC7B,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACnC,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACpC,gBAAgB,GAAE,OAAc,EAChC,eAAe,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,SAAS,GACzE,qBAAqB,EAAE,CAYzB;AAED,wBAAgB,qBAAqB,CACjC,QAAQ,EAAE,qBAAqB,EAAE,EACjC,KAAK,EAAE,MAAM,EACb,YAAY,EAAE,IAAI,CAAC,qBAAqB,CAAC,EACzC,UAAU,GAAE,MAAW,GACxB,qBAAqB,EAAE,CASzB;AAED,wBAAgB,UAAU,CAAC,YAAY,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,MAAM,CAK5E;AAED,eAAO,MAAM,qBAAqB,GAAI,iBAAiB,eAAe;;;;;;uBAkDjD,MAAM;;;;;CA2D1B,CAAC"}
@@ -0,0 +1,164 @@
1
+ import { useCallback, useEffect, useMemo, useState } from 'react';
2
+ import Fuse from 'fuse.js';
3
+ import { SETTING_KEYS, SENSITIVE_SETTINGS, } from '../services/settings-service.js';
4
+ import { useInputContext } from '../context/InputContext.js';
5
+ const SETTING_DESCRIPTIONS = {
6
+ [SETTING_KEYS.AGENT_MODEL]: 'The AI model to use (e.g. gpt-4, claude-3-opus)',
7
+ [SETTING_KEYS.AGENT_REASONING_EFFORT]: 'Reasoning effort level (default, low, medium, high)',
8
+ [SETTING_KEYS.AGENT_TEMPERATURE]: 'Model temperature (0-2, controls randomness)',
9
+ // agent.provider is hidden from UI - it can only be changed via model menu
10
+ [SETTING_KEYS.AGENT_MAX_TURNS]: 'Maximum conversation turns',
11
+ [SETTING_KEYS.AGENT_RETRY_ATTEMPTS]: 'Number of retry attempts for failed requests',
12
+ [SETTING_KEYS.SHELL_TIMEOUT]: 'Shell command timeout in milliseconds',
13
+ [SETTING_KEYS.SHELL_MAX_OUTPUT_LINES]: 'Maximum lines of shell output to capture',
14
+ [SETTING_KEYS.SHELL_MAX_OUTPUT_CHARS]: 'Maximum characters of shell output to capture',
15
+ [SETTING_KEYS.UI_HISTORY_SIZE]: 'Number of history items to keep',
16
+ [SETTING_KEYS.LOGGING_LOG_LEVEL]: 'Logging level (debug, info, warn, error)',
17
+ [SETTING_KEYS.LOGGING_SUPPRESS_CONSOLE]: 'Suppress console output to avoid interfering with Ink UI',
18
+ };
19
+ /**
20
+ * Settings that should be hidden from the UI (not for security, but for UX/workflow)
21
+ * - agent.provider: Can only be changed at the start of a new conversation via model menu
22
+ */
23
+ const HIDDEN_SETTINGS = new Set([SETTING_KEYS.AGENT_PROVIDER]);
24
+ const MAX_RESULTS = 10;
25
+ /**
26
+ * Get the set of sensitive setting keys that should not appear in the UI
27
+ */
28
+ function getSensitiveSettingKeysSet() {
29
+ return new Set(Object.values(SENSITIVE_SETTINGS));
30
+ }
31
+ /**
32
+ * Get the current value of a setting for display in the menu
33
+ */
34
+ function getCurrentSettingValue(settingsService, key) {
35
+ try {
36
+ const value = settingsService.get(key);
37
+ // Format the value for display
38
+ if (typeof value === 'object') {
39
+ return JSON.stringify(value);
40
+ }
41
+ return value;
42
+ }
43
+ catch {
44
+ return undefined;
45
+ }
46
+ }
47
+ // Pure functions exported for testing
48
+ export function buildSettingsList(settingKeys, descriptions, excludeSensitive = true, getCurrentValue) {
49
+ const sensitiveKeys = excludeSensitive
50
+ ? getSensitiveSettingKeysSet()
51
+ : new Set();
52
+ return Object.values(settingKeys)
53
+ .filter(key => !sensitiveKeys.has(key) && !HIDDEN_SETTINGS.has(key))
54
+ .map(key => ({
55
+ key,
56
+ description: descriptions[key] || '',
57
+ currentValue: getCurrentValue?.(key),
58
+ }));
59
+ }
60
+ export function filterSettingsByQuery(settings, query, fuseInstance, maxResults = 10) {
61
+ if (!query.trim()) {
62
+ return settings.slice(0, maxResults);
63
+ }
64
+ return fuseInstance
65
+ .search(query.trim())
66
+ .map(result => result.item)
67
+ .slice(0, maxResults);
68
+ }
69
+ export function clampIndex(currentIndex, arrayLength) {
70
+ if (arrayLength === 0) {
71
+ return 0;
72
+ }
73
+ return Math.min(currentIndex, arrayLength - 1);
74
+ }
75
+ export const useSettingsCompletion = (settingsService) => {
76
+ const { mode, setMode, input, triggerIndex, setTriggerIndex } = useInputContext();
77
+ const isOpen = mode === 'settings_completion';
78
+ // Derive query from input + triggerIndex
79
+ const query = useMemo(() => {
80
+ if (!isOpen || triggerIndex === null)
81
+ return '';
82
+ // triggerIndex is the end of "/settings " prefix
83
+ if (triggerIndex > input.length)
84
+ return '';
85
+ return input.slice(triggerIndex);
86
+ }, [isOpen, triggerIndex, input]);
87
+ const [selectedIndex, setSelectedIndex] = useState(0);
88
+ const [settingsVersion, setSettingsVersion] = useState(0);
89
+ // Refresh the list whenever a setting changes so currentValue stays accurate
90
+ useEffect(() => {
91
+ const unsubscribe = settingsService.onChange(() => {
92
+ setSettingsVersion(prev => prev + 1);
93
+ });
94
+ return unsubscribe;
95
+ }, [settingsService]);
96
+ const allSettings = useMemo(() => {
97
+ return buildSettingsList(SETTING_KEYS, SETTING_DESCRIPTIONS, true, (key) => getCurrentSettingValue(settingsService, key));
98
+ }, [settingsVersion, settingsService]);
99
+ const fuse = useMemo(() => {
100
+ return new Fuse(allSettings, {
101
+ keys: ['key', 'description'],
102
+ threshold: 0.4,
103
+ });
104
+ }, [allSettings]);
105
+ const filteredEntries = useMemo(() => {
106
+ return filterSettingsByQuery(allSettings, query, fuse, MAX_RESULTS);
107
+ }, [allSettings, fuse, query]);
108
+ useEffect(() => {
109
+ setSelectedIndex(prev => clampIndex(prev, filteredEntries.length));
110
+ }, [filteredEntries.length]);
111
+ const open = useCallback((startIndex, _initialQuery = '') => {
112
+ // If already in settings mode, do not reset selection.
113
+ if (mode === 'settings_completion')
114
+ return;
115
+ setMode('settings_completion');
116
+ setTriggerIndex(startIndex);
117
+ setSelectedIndex(0);
118
+ }, [mode, setMode, setTriggerIndex]);
119
+ const close = useCallback(() => {
120
+ if (mode === 'settings_completion') {
121
+ setMode('text');
122
+ setTriggerIndex(null);
123
+ setSelectedIndex(0);
124
+ }
125
+ }, [mode, setMode, setTriggerIndex]);
126
+ // updateQuery removed as it is derived
127
+ const moveUp = useCallback(() => {
128
+ setSelectedIndex(prev => {
129
+ if (filteredEntries.length === 0) {
130
+ return 0;
131
+ }
132
+ return prev > 0 ? prev - 1 : filteredEntries.length - 1;
133
+ });
134
+ }, [filteredEntries.length]);
135
+ const moveDown = useCallback(() => {
136
+ setSelectedIndex(prev => {
137
+ if (filteredEntries.length === 0) {
138
+ return 0;
139
+ }
140
+ return prev < filteredEntries.length - 1 ? prev + 1 : 0;
141
+ });
142
+ }, [filteredEntries.length]);
143
+ const getSelectedItem = useCallback(() => {
144
+ if (filteredEntries.length === 0) {
145
+ return undefined;
146
+ }
147
+ const safeIndex = clampIndex(selectedIndex, filteredEntries.length);
148
+ return filteredEntries[safeIndex];
149
+ }, [filteredEntries, selectedIndex]);
150
+ return {
151
+ isOpen,
152
+ triggerIndex,
153
+ query,
154
+ filteredEntries,
155
+ selectedIndex,
156
+ open,
157
+ close,
158
+ // updateQuery,
159
+ moveUp,
160
+ moveDown,
161
+ getSelectedItem,
162
+ };
163
+ };
164
+ //# sourceMappingURL=use-settings-completion.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-settings-completion.js","sourceRoot":"","sources":["../../source/hooks/use-settings-completion.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=use-settings-completion.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-settings-completion.test.d.ts","sourceRoot":"","sources":["../../source/hooks/use-settings-completion.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,334 @@
1
+ import test from 'ava';
2
+ import Fuse from 'fuse.js';
3
+ import { buildSettingsList, filterSettingsByQuery, clampIndex, } from './use-settings-completion.js';
4
+ // Mock setting keys for testing (matching actual SETTING_KEYS structure)
5
+ const MOCK_SETTING_KEYS = {
6
+ AGENT_MODEL: 'agent.model',
7
+ AGENT_REASONING_EFFORT: 'agent.reasoningEffort',
8
+ AGENT_PROVIDER: 'agent.provider',
9
+ AGENT_MAX_TURNS: 'agent.maxTurns',
10
+ AGENT_RETRY_ATTEMPTS: 'agent.retryAttempts',
11
+ AGENT_OPENROUTER_API_KEY: 'agent.openrouter.apiKey',
12
+ AGENT_OPENROUTER_BASE_URL: 'agent.openrouter.baseUrl',
13
+ AGENT_OPENROUTER_REFERRER: 'agent.openrouter.referrer',
14
+ AGENT_OPENROUTER_TITLE: 'agent.openrouter.title',
15
+ SHELL_TIMEOUT: 'shell.timeout',
16
+ SHELL_MAX_OUTPUT_LINES: 'shell.maxOutputLines',
17
+ SHELL_MAX_OUTPUT_CHARS: 'shell.maxOutputChars',
18
+ UI_HISTORY_SIZE: 'ui.historySize',
19
+ LOGGING_LOG_LEVEL: 'logging.logLevel',
20
+ LOGGING_DISABLE: 'logging.disableLogging',
21
+ LOGGING_DEBUG: 'logging.debugLogging',
22
+ LOGGING_SUPPRESS_CONSOLE: 'logging.suppressConsoleOutput',
23
+ ENV_NODE_ENV: 'environment.nodeEnv',
24
+ APP_SHELL_PATH: 'app.shellPath',
25
+ TOOLS_LOG_FILE_OPS: 'tools.logFileOperations',
26
+ DEBUG_BASH_TOOL: 'debug.debugBashTool',
27
+ };
28
+ const MOCK_DESCRIPTIONS = {
29
+ 'agent.model': 'The AI model to use (e.g. gpt-4, claude-3-opus)',
30
+ 'agent.reasoningEffort': 'Reasoning effort level (default, low, medium, high)',
31
+ 'agent.provider': 'AI provider (openai, openrouter)',
32
+ 'agent.maxTurns': 'Maximum conversation turns',
33
+ 'agent.retryAttempts': 'Number of retry attempts for failed requests',
34
+ 'agent.openrouter.apiKey': 'OpenRouter API key',
35
+ 'agent.openrouter.baseUrl': 'OpenRouter base URL',
36
+ 'agent.openrouter.referrer': 'OpenRouter referrer',
37
+ 'agent.openrouter.title': 'OpenRouter title',
38
+ 'shell.timeout': 'Shell command timeout in milliseconds',
39
+ 'shell.maxOutputLines': 'Maximum lines of shell output to capture',
40
+ 'shell.maxOutputChars': 'Maximum characters of shell output to capture',
41
+ 'ui.historySize': 'Number of history items to keep',
42
+ 'logging.logLevel': 'Logging level (debug, info, warn, error)',
43
+ 'logging.disableLogging': 'Disable all logging',
44
+ 'logging.debugLogging': 'Enable debug logging',
45
+ 'logging.suppressConsoleOutput': 'Suppress console output to avoid interfering with Ink UI',
46
+ 'environment.nodeEnv': 'Node environment (development, production)',
47
+ 'app.shellPath': 'Path to shell executable',
48
+ 'tools.logFileOperations': 'Log file operations to disk',
49
+ 'debug.debugBashTool': 'Enable bash tool debugging',
50
+ };
51
+ // buildSettingsList tests
52
+ test('buildSettingsList - creates list from keys and descriptions', t => {
53
+ const result = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
54
+ // Should exclude 5 sensitive settings + 1 hidden setting by default
55
+ const expectedCount = Object.keys(MOCK_SETTING_KEYS).length - 6;
56
+ t.is(result.length, expectedCount);
57
+ t.true(result.every(() => true));
58
+ t.true(result.every(item => item.description !== undefined));
59
+ });
60
+ test('buildSettingsList - excludes sensitive settings by default', t => {
61
+ const result = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
62
+ const keys = new Set(result.map(item => item.key));
63
+ // Should not include sensitive settings
64
+ t.false(keys.has('agent.openrouter.apiKey'));
65
+ t.false(keys.has('agent.openrouter.baseUrl'));
66
+ t.false(keys.has('agent.openrouter.referrer'));
67
+ t.false(keys.has('agent.openrouter.title'));
68
+ t.false(keys.has('app.shellPath'));
69
+ // Should include non-sensitive settings
70
+ t.true(keys.has('agent.model'));
71
+ t.true(keys.has('shell.timeout'));
72
+ });
73
+ test('buildSettingsList - can include sensitive settings when requested', t => {
74
+ const result = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS, false);
75
+ const keys = new Set(result.map(item => item.key));
76
+ // Should include all settings except hidden ones when excludeSensitive is false
77
+ t.is(result.length, Object.keys(MOCK_SETTING_KEYS).length - 1);
78
+ t.true(keys.has('agent.openrouter.apiKey'));
79
+ t.true(keys.has('app.shellPath'));
80
+ // Hidden settings should still be excluded
81
+ t.false(keys.has('agent.provider'));
82
+ });
83
+ test('buildSettingsList - includes all non-sensitive setting keys', t => {
84
+ const result = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
85
+ const keys = result.map(item => item.key);
86
+ // Check specific non-sensitive keys that should be included
87
+ const nonSensitiveKeys = [
88
+ 'agent.model',
89
+ 'agent.reasoningEffort',
90
+ 'agent.maxTurns',
91
+ 'shell.timeout',
92
+ 'logging.logLevel',
93
+ ];
94
+ for (const settingKey of nonSensitiveKeys) {
95
+ t.true(keys.includes(settingKey), `Missing key: ${settingKey}`);
96
+ }
97
+ });
98
+ test('buildSettingsList - maps descriptions correctly', t => {
99
+ const result = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
100
+ for (const item of result) {
101
+ t.is(item.description, MOCK_DESCRIPTIONS[item.key]);
102
+ }
103
+ });
104
+ test('buildSettingsList - includes current values when provided', t => {
105
+ const mockGetCurrentValue = (key) => {
106
+ const values = {
107
+ 'agent.model': 'gpt-4o',
108
+ 'shell.timeout': 120000,
109
+ 'logging.logLevel': 'info',
110
+ };
111
+ return values[key] ?? 'default';
112
+ };
113
+ const result = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS, true, mockGetCurrentValue);
114
+ const agentModel = result.find(item => item.key === 'agent.model');
115
+ const shellTimeout = result.find(item => item.key === 'shell.timeout');
116
+ const logLevel = result.find(item => item.key === 'logging.logLevel');
117
+ t.is(agentModel?.currentValue, 'gpt-4o');
118
+ t.is(shellTimeout?.currentValue, 120000);
119
+ t.is(logLevel?.currentValue, 'info');
120
+ });
121
+ test('buildSettingsList - handles missing current values', t => {
122
+ const mockGetCurrentValue = (key) => {
123
+ if (key === 'agent.model') {
124
+ return 'gpt-4o';
125
+ }
126
+ return undefined;
127
+ };
128
+ const result = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS, true, mockGetCurrentValue);
129
+ const agentModel = result.find(item => item.key === 'agent.model');
130
+ const shellTimeout = result.find(item => item.key === 'shell.timeout');
131
+ t.is(agentModel?.currentValue, 'gpt-4o');
132
+ t.is(shellTimeout?.currentValue, undefined);
133
+ });
134
+ test('buildSettingsList - handles missing descriptions with empty string', t => {
135
+ const incompleteDescriptions = {
136
+ 'agent.model': 'Model description',
137
+ };
138
+ const result = buildSettingsList(MOCK_SETTING_KEYS, incompleteDescriptions);
139
+ const agentModel = result.find(item => item.key === 'agent.model');
140
+ const shellTimeout = result.find(item => item.key === 'shell.timeout');
141
+ t.is(agentModel?.description, 'Model description');
142
+ t.is(shellTimeout?.description, '');
143
+ });
144
+ test('buildSettingsList - handles empty descriptions object', t => {
145
+ const result = buildSettingsList(MOCK_SETTING_KEYS, {});
146
+ // Should exclude sensitive settings + hidden settings
147
+ const expectedCount = Object.keys(MOCK_SETTING_KEYS).length - 6;
148
+ t.is(result.length, expectedCount);
149
+ t.true(result.every(item => item.description === ''));
150
+ });
151
+ test('buildSettingsList - no duplicate keys', t => {
152
+ const result = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
153
+ const keys = result.map(item => item.key);
154
+ const uniqueKeys = new Set(keys);
155
+ t.is(keys.length, uniqueKeys.size, 'Duplicate keys found');
156
+ });
157
+ // filterSettingsByQuery tests
158
+ test('filterSettingsByQuery - empty query returns first N results', t => {
159
+ const settings = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
160
+ const fuse = new Fuse(settings, {
161
+ keys: ['key', 'description'],
162
+ threshold: 0.4,
163
+ });
164
+ const result = filterSettingsByQuery(settings, '', fuse, 3);
165
+ t.is(result.length, 3);
166
+ });
167
+ test('filterSettingsByQuery - whitespace-only query returns first N results', t => {
168
+ const settings = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
169
+ const fuse = new Fuse(settings, {
170
+ keys: ['key', 'description'],
171
+ threshold: 0.4,
172
+ });
173
+ const result = filterSettingsByQuery(settings, ' ', fuse, 3);
174
+ t.is(result.length, 3);
175
+ });
176
+ test('filterSettingsByQuery - exact key match returns result', t => {
177
+ const settings = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
178
+ const fuse = new Fuse(settings, {
179
+ keys: ['key', 'description'],
180
+ threshold: 0.4,
181
+ });
182
+ const result = filterSettingsByQuery(settings, 'agent.model', fuse, 10);
183
+ t.true(result.length > 0);
184
+ t.true(result.some(item => item.key === 'agent.model'));
185
+ });
186
+ test('filterSettingsByQuery - partial key match returns results', t => {
187
+ const settings = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
188
+ const fuse = new Fuse(settings, {
189
+ keys: ['key', 'description'],
190
+ threshold: 0.4,
191
+ });
192
+ const cases = [
193
+ { query: 'agent', expectedKeySubstring: 'agent' },
194
+ { query: 'shell', expectedKeySubstring: 'shell' },
195
+ { query: 'model', expectedKeySubstring: 'model' },
196
+ ];
197
+ for (const { query, expectedKeySubstring } of cases) {
198
+ const result = filterSettingsByQuery(settings, query, fuse, 10);
199
+ t.true(result.length > 0, `Query "${query}" should return results`);
200
+ t.true(result.some(item => item.key.includes(expectedKeySubstring)), `Query "${query}" should match key containing "${expectedKeySubstring}"`);
201
+ }
202
+ });
203
+ test('filterSettingsByQuery - search by description returns results', t => {
204
+ const settings = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
205
+ const fuse = new Fuse(settings, {
206
+ keys: ['key', 'description'],
207
+ threshold: 0.4,
208
+ });
209
+ const cases = [
210
+ { query: 'timeout', expectedKey: 'shell.timeout' },
211
+ { query: 'model', expectedKey: 'agent.model' },
212
+ { query: 'logging', expectedKey: 'logging.logLevel' },
213
+ ];
214
+ for (const { query, expectedKey } of cases) {
215
+ const result = filterSettingsByQuery(settings, query, fuse, 10);
216
+ t.true(result.length > 0, `Query "${query}" should return results`);
217
+ t.true(result.some(item => item.key === expectedKey), `Query "${query}" should find key "${expectedKey}"`);
218
+ }
219
+ });
220
+ test('filterSettingsByQuery - respects maxResults parameter', t => {
221
+ const settings = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
222
+ const fuse = new Fuse(settings, {
223
+ keys: ['key', 'description'],
224
+ threshold: 0.4,
225
+ });
226
+ const result1 = filterSettingsByQuery(settings, '', fuse, 2);
227
+ t.is(result1.length, 2);
228
+ const result2 = filterSettingsByQuery(settings, '', fuse, 4);
229
+ t.is(result2.length, 4);
230
+ const result3 = filterSettingsByQuery(settings, '', fuse, 100);
231
+ t.true(result3.length <= settings.length);
232
+ });
233
+ test('filterSettingsByQuery - case insensitive search', t => {
234
+ const settings = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
235
+ const fuse = new Fuse(settings, {
236
+ keys: ['key', 'description'],
237
+ threshold: 0.4,
238
+ });
239
+ const lowerCase = filterSettingsByQuery(settings, 'agent', fuse, 10);
240
+ const upperCase = filterSettingsByQuery(settings, 'AGENT', fuse, 10);
241
+ const mixedCase = filterSettingsByQuery(settings, 'AgEnT', fuse, 10);
242
+ t.true(lowerCase.length > 0);
243
+ t.true(upperCase.length > 0);
244
+ t.true(mixedCase.length > 0);
245
+ // Note: Fuzzy search might return slightly different results, but all should find matches
246
+ });
247
+ test('filterSettingsByQuery - handles query with no matches', t => {
248
+ const settings = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
249
+ const fuse = new Fuse(settings, {
250
+ keys: ['key', 'description'],
251
+ threshold: 0.4,
252
+ });
253
+ const result = filterSettingsByQuery(settings, 'xyzzzznonexistent', fuse, 10);
254
+ // Fuzzy search might still return some results due to threshold, but likely empty
255
+ t.true(Array.isArray(result));
256
+ });
257
+ test('filterSettingsByQuery - trims query before searching', t => {
258
+ const settings = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
259
+ const fuse = new Fuse(settings, {
260
+ keys: ['key', 'description'],
261
+ threshold: 0.4,
262
+ });
263
+ const trimmed = filterSettingsByQuery(settings, 'agent', fuse, 10);
264
+ const withSpaces = filterSettingsByQuery(settings, ' agent ', fuse, 10);
265
+ t.true(trimmed.length > 0);
266
+ t.true(withSpaces.length > 0);
267
+ });
268
+ test('filterSettingsByQuery - handles empty settings array', t => {
269
+ const fuse = new Fuse([], { keys: ['key', 'description'], threshold: 0.4 });
270
+ const result = filterSettingsByQuery([], 'agent', fuse, 10);
271
+ t.is(result.length, 0);
272
+ });
273
+ // clampIndex tests
274
+ test('clampIndex - returns 0 when array is empty', t => {
275
+ t.is(clampIndex(0, 0), 0);
276
+ t.is(clampIndex(5, 0), 0);
277
+ t.is(clampIndex(100, 0), 0);
278
+ });
279
+ test('clampIndex - returns same index when within bounds', t => {
280
+ const cases = [
281
+ { index: 0, length: 5, expected: 0 },
282
+ { index: 2, length: 5, expected: 2 },
283
+ { index: 4, length: 5, expected: 4 },
284
+ ];
285
+ for (const { index, length, expected } of cases) {
286
+ t.is(clampIndex(index, length), expected, `Index ${index} in length ${length}`);
287
+ }
288
+ });
289
+ test('clampIndex - clamps to max index when out of bounds', t => {
290
+ const cases = [
291
+ { index: 5, length: 5, expected: 4 },
292
+ { index: 10, length: 5, expected: 4 },
293
+ { index: 100, length: 3, expected: 2 },
294
+ ];
295
+ for (const { index, length, expected } of cases) {
296
+ t.is(clampIndex(index, length), expected, `Index ${index} clamped in length ${length}`);
297
+ }
298
+ });
299
+ test('clampIndex - handles length of 1', t => {
300
+ t.is(clampIndex(0, 1), 0);
301
+ t.is(clampIndex(1, 1), 0);
302
+ t.is(clampIndex(10, 1), 0);
303
+ });
304
+ test('clampIndex - handles negative index (Math.min behavior)', t => {
305
+ // Math.min will return the negative value if it's smaller than arrayLength - 1
306
+ // This is the actual behavior of the implementation
307
+ const result = clampIndex(-1, 5);
308
+ t.is(result, -1, 'Math.min(-1, 4) = -1');
309
+ });
310
+ // Integration tests
311
+ test('Integration - buildSettingsList and filterSettingsByQuery work together', t => {
312
+ const settings = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
313
+ const fuse = new Fuse(settings, {
314
+ keys: ['key', 'description'],
315
+ threshold: 0.4,
316
+ });
317
+ // Search for "model" should find agent.model
318
+ const result = filterSettingsByQuery(settings, 'model', fuse, 10);
319
+ t.true(result.some(item => item.key === 'agent.model'));
320
+ t.true(result.some(item => item.description?.includes('model')));
321
+ });
322
+ test('Integration - clampIndex with filtered results', t => {
323
+ const settings = buildSettingsList(MOCK_SETTING_KEYS, MOCK_DESCRIPTIONS);
324
+ const fuse = new Fuse(settings, {
325
+ keys: ['key', 'description'],
326
+ threshold: 0.4,
327
+ });
328
+ // Get filtered results
329
+ const filtered = filterSettingsByQuery(settings, 'agent', fuse, 3);
330
+ // Clamp selection index to filtered results
331
+ t.is(clampIndex(0, filtered.length), 0);
332
+ t.is(clampIndex(10, filtered.length), filtered.length - 1);
333
+ });
334
+ //# sourceMappingURL=use-settings-completion.test.js.map