@ebowwa/coder 0.7.63 → 0.7.64

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 (341) hide show
  1. package/dist/core/__tests__/permissions.test.d.ts +12 -0
  2. package/dist/core/__tests__/permissions.test.d.ts.map +1 -0
  3. package/dist/core/__tests__/permissions.test.js +851 -0
  4. package/dist/core/agent-loop/__tests__/compaction.test.d.ts +5 -0
  5. package/dist/core/agent-loop/__tests__/compaction.test.d.ts.map +1 -0
  6. package/dist/core/agent-loop/__tests__/compaction.test.js +209 -0
  7. package/dist/core/agent-loop/__tests__/formatters.test.d.ts +5 -0
  8. package/dist/core/agent-loop/__tests__/formatters.test.d.ts.map +1 -0
  9. package/dist/core/agent-loop/__tests__/formatters.test.js +195 -0
  10. package/dist/core/agent-loop/__tests__/index.test.d.ts +5 -0
  11. package/dist/core/agent-loop/__tests__/index.test.d.ts.map +1 -0
  12. package/dist/core/agent-loop/__tests__/index.test.js +121 -0
  13. package/dist/core/agent-loop/__tests__/loop-state.test.d.ts +5 -0
  14. package/dist/core/agent-loop/__tests__/loop-state.test.d.ts.map +1 -0
  15. package/dist/core/agent-loop/__tests__/loop-state.test.js +340 -0
  16. package/dist/core/agent-loop/__tests__/message-builder.test.d.ts +5 -0
  17. package/dist/core/agent-loop/__tests__/message-builder.test.d.ts.map +1 -0
  18. package/dist/core/agent-loop/__tests__/message-builder.test.js +178 -0
  19. package/dist/core/agent-loop/__tests__/tool-executor.test.d.ts +5 -0
  20. package/dist/core/agent-loop/__tests__/tool-executor.test.d.ts.map +1 -0
  21. package/dist/core/agent-loop/__tests__/tool-executor.test.js +331 -0
  22. package/dist/core/agent-loop/compaction.d.ts +39 -0
  23. package/dist/core/agent-loop/compaction.d.ts.map +1 -0
  24. package/dist/core/agent-loop/compaction.js +51 -0
  25. package/dist/core/agent-loop/formatters.d.ts +21 -0
  26. package/dist/core/agent-loop/formatters.d.ts.map +1 -0
  27. package/dist/core/agent-loop/formatters.js +42 -0
  28. package/dist/core/agent-loop/index.d.ts +25 -0
  29. package/dist/core/agent-loop/index.d.ts.map +1 -0
  30. package/dist/core/agent-loop/index.js +83 -0
  31. package/dist/core/agent-loop/loop-state.d.ts +74 -0
  32. package/dist/core/agent-loop/loop-state.d.ts.map +1 -0
  33. package/dist/core/agent-loop/loop-state.js +147 -0
  34. package/dist/core/agent-loop/message-builder.d.ts +13 -0
  35. package/dist/core/agent-loop/message-builder.d.ts.map +1 -0
  36. package/dist/core/agent-loop/message-builder.js +49 -0
  37. package/dist/core/agent-loop/tool-executor.d.ts +23 -0
  38. package/dist/core/agent-loop/tool-executor.d.ts.map +1 -0
  39. package/dist/core/agent-loop/tool-executor.js +152 -0
  40. package/dist/core/agent-loop/turn-executor.d.ts +57 -0
  41. package/dist/core/agent-loop/turn-executor.d.ts.map +1 -0
  42. package/dist/core/agent-loop/turn-executor.js +124 -0
  43. package/dist/core/agent-loop/types.d.ts +141 -0
  44. package/dist/core/agent-loop/types.d.ts.map +1 -0
  45. package/dist/core/agent-loop/types.js +4 -0
  46. package/dist/core/agent-loop.d.ts +17 -0
  47. package/dist/core/agent-loop.d.ts.map +1 -0
  48. package/dist/core/agent-loop.js +16 -0
  49. package/dist/core/api-client-impl.d.ts +62 -0
  50. package/dist/core/api-client-impl.d.ts.map +1 -0
  51. package/dist/core/api-client-impl.js +479 -0
  52. package/dist/core/api-client.d.ts +6 -0
  53. package/dist/core/api-client.d.ts.map +1 -0
  54. package/dist/core/api-client.js +5 -0
  55. package/dist/core/checkpoints.d.ts +128 -0
  56. package/dist/core/checkpoints.d.ts.map +1 -0
  57. package/dist/core/checkpoints.js +438 -0
  58. package/dist/core/claude-md.d.ts +71 -0
  59. package/dist/core/claude-md.d.ts.map +1 -0
  60. package/dist/core/claude-md.js +198 -0
  61. package/dist/core/cognitive-security/hooks.d.ts +138 -0
  62. package/dist/core/cognitive-security/hooks.d.ts.map +1 -0
  63. package/dist/core/cognitive-security/hooks.js +389 -0
  64. package/dist/core/cognitive-security/index.d.ts +751 -0
  65. package/dist/core/cognitive-security/index.d.ts.map +1 -0
  66. package/dist/core/cognitive-security/index.js +1123 -0
  67. package/dist/core/cognitive-security/middleware.d.ts +136 -0
  68. package/dist/core/cognitive-security/middleware.d.ts.map +1 -0
  69. package/dist/core/cognitive-security/middleware.js +376 -0
  70. package/dist/core/config-loader.d.ts +127 -0
  71. package/dist/core/config-loader.d.ts.map +1 -0
  72. package/dist/core/config-loader.js +219 -0
  73. package/dist/core/context-compaction.d.ts +87 -0
  74. package/dist/core/context-compaction.d.ts.map +1 -0
  75. package/dist/core/context-compaction.js +428 -0
  76. package/dist/core/git-status.d.ts +25 -0
  77. package/dist/core/git-status.d.ts.map +1 -0
  78. package/dist/core/git-status.js +204 -0
  79. package/dist/core/image.d.ts +69 -0
  80. package/dist/core/image.d.ts.map +1 -0
  81. package/dist/core/image.js +290 -0
  82. package/dist/core/image.test.d.ts +2 -0
  83. package/dist/core/image.test.d.ts.map +1 -0
  84. package/dist/core/image.test.js +149 -0
  85. package/dist/core/models.d.ts +123 -0
  86. package/dist/core/models.d.ts.map +1 -0
  87. package/dist/core/models.js +325 -0
  88. package/dist/core/permissions.d.ts +81 -0
  89. package/dist/core/permissions.d.ts.map +1 -0
  90. package/dist/core/permissions.js +327 -0
  91. package/dist/core/retry.d.ts +25 -0
  92. package/dist/core/retry.d.ts.map +1 -0
  93. package/dist/core/retry.js +121 -0
  94. package/dist/core/session-store.d.ts +9 -0
  95. package/dist/core/session-store.d.ts.map +1 -0
  96. package/dist/core/session-store.js +10 -0
  97. package/dist/core/sessions/export.d.ts +47 -0
  98. package/dist/core/sessions/export.d.ts.map +1 -0
  99. package/dist/core/sessions/export.js +256 -0
  100. package/dist/core/sessions/index.d.ts +132 -0
  101. package/dist/core/sessions/index.d.ts.map +1 -0
  102. package/dist/core/sessions/index.js +442 -0
  103. package/dist/core/sessions/metadata.d.ts +77 -0
  104. package/dist/core/sessions/metadata.d.ts.map +1 -0
  105. package/dist/core/sessions/metadata.js +233 -0
  106. package/dist/core/sessions/persistence.d.ts +72 -0
  107. package/dist/core/sessions/persistence.d.ts.map +1 -0
  108. package/dist/core/sessions/persistence.js +201 -0
  109. package/dist/core/sessions/types.d.ts +110 -0
  110. package/dist/core/sessions/types.d.ts.map +1 -0
  111. package/dist/core/sessions/types.js +4 -0
  112. package/dist/core/stream-highlighter.d.ts +18 -0
  113. package/dist/core/stream-highlighter.d.ts.map +1 -0
  114. package/dist/core/stream-highlighter.js +916 -0
  115. package/dist/core/system-reminders.d.ts +89 -0
  116. package/dist/core/system-reminders.d.ts.map +1 -0
  117. package/dist/core/system-reminders.js +285 -0
  118. package/dist/ecosystem/hooks/__tests__/index.test.d.ts +5 -0
  119. package/dist/ecosystem/hooks/__tests__/index.test.d.ts.map +1 -0
  120. package/dist/ecosystem/hooks/__tests__/index.test.js +458 -0
  121. package/dist/ecosystem/hooks/index.d.ts +59 -0
  122. package/dist/ecosystem/hooks/index.d.ts.map +1 -0
  123. package/dist/ecosystem/hooks/index.js +294 -0
  124. package/dist/ecosystem/hooks/prompt-evaluator.d.ts +32 -0
  125. package/dist/ecosystem/hooks/prompt-evaluator.d.ts.map +1 -0
  126. package/dist/ecosystem/hooks/prompt-evaluator.js +229 -0
  127. package/dist/ecosystem/skills/index.d.ts +55 -0
  128. package/dist/ecosystem/skills/index.d.ts.map +1 -0
  129. package/dist/ecosystem/skills/index.js +258 -0
  130. package/dist/ecosystem/tools/__tests__/index.test.d.ts +7 -0
  131. package/dist/ecosystem/tools/__tests__/index.test.d.ts.map +1 -0
  132. package/dist/ecosystem/tools/__tests__/index.test.js +856 -0
  133. package/dist/ecosystem/tools/index.d.ts +24 -0
  134. package/dist/ecosystem/tools/index.d.ts.map +1 -0
  135. package/dist/ecosystem/tools/index.js +1709 -0
  136. package/dist/index.d.ts +24 -0
  137. package/dist/index.d.ts.map +1 -0
  138. package/dist/index.js +32 -52192
  139. package/dist/interfaces/mcp/client.d.ts +40 -0
  140. package/dist/interfaces/mcp/client.d.ts.map +1 -0
  141. package/dist/interfaces/mcp/client.js +309 -0
  142. package/dist/interfaces/ui/index.d.ts +36 -0
  143. package/dist/interfaces/ui/index.d.ts.map +1 -0
  144. package/dist/interfaces/ui/index.js +61 -0
  145. package/dist/interfaces/ui/spinner.d.ts +140 -0
  146. package/dist/interfaces/ui/spinner.d.ts.map +1 -0
  147. package/dist/interfaces/ui/spinner.js +342 -0
  148. package/dist/interfaces/ui/terminal/cli/index.d.ts +12 -0
  149. package/dist/interfaces/ui/terminal/cli/index.d.ts.map +1 -0
  150. package/dist/interfaces/ui/terminal/cli/index.js +159 -52768
  151. package/dist/interfaces/ui/terminal/shared/args.d.ts +39 -0
  152. package/dist/interfaces/ui/terminal/shared/args.d.ts.map +1 -0
  153. package/dist/interfaces/ui/terminal/shared/args.js +176 -0
  154. package/dist/interfaces/ui/terminal/shared/index.d.ts +11 -0
  155. package/dist/interfaces/ui/terminal/shared/index.d.ts.map +1 -0
  156. package/dist/interfaces/ui/terminal/shared/index.js +16 -0
  157. package/dist/interfaces/ui/terminal/shared/loading-state.d.ts +124 -0
  158. package/dist/interfaces/ui/terminal/shared/loading-state.d.ts.map +1 -0
  159. package/dist/interfaces/ui/terminal/shared/loading-state.js +246 -0
  160. package/dist/interfaces/ui/terminal/shared/query.d.ts +22 -0
  161. package/dist/interfaces/ui/terminal/shared/query.d.ts.map +1 -0
  162. package/dist/interfaces/ui/terminal/shared/query.js +100 -0
  163. package/dist/interfaces/ui/terminal/shared/setup.d.ts +33 -0
  164. package/dist/interfaces/ui/terminal/shared/setup.d.ts.map +1 -0
  165. package/dist/interfaces/ui/terminal/shared/setup.js +226 -0
  166. package/dist/interfaces/ui/terminal/shared/status-line.d.ts +117 -0
  167. package/dist/interfaces/ui/terminal/shared/status-line.d.ts.map +1 -0
  168. package/dist/interfaces/ui/terminal/shared/status-line.js +267 -0
  169. package/dist/interfaces/ui/terminal/shared/system-prompt.d.ts +38 -0
  170. package/dist/interfaces/ui/terminal/shared/system-prompt.d.ts.map +1 -0
  171. package/dist/interfaces/ui/terminal/shared/system-prompt.js +102 -0
  172. package/dist/interfaces/ui/terminal/tui/HelpPanel.d.ts +39 -0
  173. package/dist/interfaces/ui/terminal/tui/HelpPanel.d.ts.map +1 -0
  174. package/dist/interfaces/ui/terminal/tui/HelpPanel.js +215 -0
  175. package/dist/interfaces/ui/terminal/tui/InputContext.d.ts +91 -0
  176. package/dist/interfaces/ui/terminal/tui/InputContext.d.ts.map +1 -0
  177. package/dist/interfaces/ui/terminal/tui/InputContext.js +154 -0
  178. package/dist/interfaces/ui/terminal/tui/InputField.d.ts +18 -0
  179. package/dist/interfaces/ui/terminal/tui/InputField.d.ts.map +1 -0
  180. package/dist/interfaces/ui/terminal/tui/InputField.js +41 -0
  181. package/dist/interfaces/ui/terminal/tui/InteractiveTUI.d.ts +16 -0
  182. package/dist/interfaces/ui/terminal/tui/InteractiveTUI.d.ts.map +1 -0
  183. package/dist/interfaces/ui/terminal/tui/InteractiveTUI.js +451 -0
  184. package/dist/interfaces/ui/terminal/tui/MessageArea.d.ts +10 -0
  185. package/dist/interfaces/ui/terminal/tui/MessageArea.d.ts.map +1 -0
  186. package/dist/interfaces/ui/terminal/tui/MessageArea.js +91 -0
  187. package/dist/interfaces/ui/terminal/tui/MessageStore.d.ts +48 -0
  188. package/dist/interfaces/ui/terminal/tui/MessageStore.d.ts.map +1 -0
  189. package/dist/interfaces/ui/terminal/tui/MessageStore.js +151 -0
  190. package/dist/interfaces/ui/terminal/tui/StatusBar.d.ts +9 -0
  191. package/dist/interfaces/ui/terminal/tui/StatusBar.d.ts.map +1 -0
  192. package/dist/interfaces/ui/terminal/tui/StatusBar.js +36 -0
  193. package/dist/interfaces/ui/terminal/tui/commands.d.ts +21 -0
  194. package/dist/interfaces/ui/terminal/tui/commands.d.ts.map +1 -0
  195. package/dist/interfaces/ui/terminal/tui/commands.js +359 -0
  196. package/dist/interfaces/ui/terminal/tui/components/InteractiveElements.d.ts +115 -0
  197. package/dist/interfaces/ui/terminal/tui/components/InteractiveElements.d.ts.map +1 -0
  198. package/dist/interfaces/ui/terminal/tui/components/InteractiveElements.js +306 -0
  199. package/dist/interfaces/ui/terminal/tui/components/MultilineInput.d.ts +92 -0
  200. package/dist/interfaces/ui/terminal/tui/components/MultilineInput.d.ts.map +1 -0
  201. package/dist/interfaces/ui/terminal/tui/components/MultilineInput.js +399 -0
  202. package/dist/interfaces/ui/terminal/tui/components/PaneManager.d.ts +59 -0
  203. package/dist/interfaces/ui/terminal/tui/components/PaneManager.d.ts.map +1 -0
  204. package/dist/interfaces/ui/terminal/tui/components/PaneManager.js +139 -0
  205. package/dist/interfaces/ui/terminal/tui/components/Sidebar.d.ts +68 -0
  206. package/dist/interfaces/ui/terminal/tui/components/Sidebar.d.ts.map +1 -0
  207. package/dist/interfaces/ui/terminal/tui/components/Sidebar.js +340 -0
  208. package/dist/interfaces/ui/terminal/tui/components/index.d.ts +23 -0
  209. package/dist/interfaces/ui/terminal/tui/components/index.d.ts.map +1 -0
  210. package/dist/interfaces/ui/terminal/tui/components/index.js +51 -0
  211. package/dist/interfaces/ui/terminal/tui/console.d.ts +20 -0
  212. package/dist/interfaces/ui/terminal/tui/console.d.ts.map +1 -0
  213. package/dist/interfaces/ui/terminal/tui/console.js +46 -0
  214. package/dist/interfaces/ui/terminal/tui/index.d.ts +20 -0
  215. package/dist/interfaces/ui/terminal/tui/index.d.ts.map +1 -0
  216. package/dist/interfaces/ui/terminal/tui/index.js +28 -0
  217. package/dist/interfaces/ui/terminal/tui/run.d.ts +13 -0
  218. package/dist/interfaces/ui/terminal/tui/run.d.ts.map +1 -0
  219. package/dist/interfaces/ui/terminal/tui/run.js +31 -0
  220. package/dist/interfaces/ui/terminal/tui/spinner.d.ts +44 -0
  221. package/dist/interfaces/ui/terminal/tui/spinner.d.ts.map +1 -0
  222. package/dist/interfaces/ui/terminal/tui/spinner.js +59 -0
  223. package/dist/interfaces/ui/terminal/tui/tui-app.d.ts +39 -0
  224. package/dist/interfaces/ui/terminal/tui/tui-app.d.ts.map +1 -0
  225. package/dist/interfaces/ui/terminal/tui/tui-app.js +198 -0
  226. package/dist/interfaces/ui/terminal/tui/tui-footer.d.ts +167 -0
  227. package/dist/interfaces/ui/terminal/tui/tui-footer.d.ts.map +1 -0
  228. package/dist/interfaces/ui/terminal/tui/tui-footer.js +330 -0
  229. package/dist/interfaces/ui/terminal/tui/types.d.ts +165 -0
  230. package/dist/interfaces/ui/terminal/tui/types.d.ts.map +1 -0
  231. package/dist/interfaces/ui/terminal/tui/types.js +5 -0
  232. package/dist/interfaces/ui/terminal/tui/useInputHandler.d.ts +23 -0
  233. package/dist/interfaces/ui/terminal/tui/useInputHandler.d.ts.map +1 -0
  234. package/dist/interfaces/ui/terminal/tui/useInputHandler.js +72 -0
  235. package/dist/interfaces/ui/terminal/tui/useNativeInput.d.ts +90 -0
  236. package/dist/interfaces/ui/terminal/tui/useNativeInput.d.ts.map +1 -0
  237. package/dist/interfaces/ui/terminal/tui/useNativeInput.js +188 -0
  238. package/dist/native/index.d.ts +480 -0
  239. package/dist/native/index.d.ts.map +1 -0
  240. package/dist/native/index.js +1625 -0
  241. package/dist/teammates/index.d.ts +161 -0
  242. package/dist/teammates/index.d.ts.map +1 -0
  243. package/dist/teammates/index.js +827 -0
  244. package/dist/types/index.d.ts +482 -0
  245. package/dist/types/index.d.ts.map +1 -0
  246. package/dist/types/index.js +52 -0
  247. package/package.json +4 -2
  248. package/packages/src/core/__tests__/permissions.test.ts +1091 -0
  249. package/packages/src/core/agent-loop/__tests__/compaction.test.ts +280 -0
  250. package/packages/src/core/agent-loop/__tests__/formatters.test.ts +234 -0
  251. package/packages/src/core/agent-loop/__tests__/index.test.ts +162 -0
  252. package/packages/src/core/agent-loop/__tests__/loop-state.test.ts +413 -0
  253. package/packages/src/core/agent-loop/__tests__/message-builder.test.ts +229 -0
  254. package/packages/src/core/agent-loop/__tests__/tool-executor.test.ts +457 -0
  255. package/packages/src/core/agent-loop/compaction.ts +88 -0
  256. package/packages/src/core/agent-loop/formatters.ts +50 -0
  257. package/packages/src/core/agent-loop/index.ts +135 -0
  258. package/packages/src/core/agent-loop/loop-state.ts +187 -0
  259. package/packages/src/core/agent-loop/message-builder.ts +62 -0
  260. package/packages/src/core/agent-loop/tool-executor.ts +211 -0
  261. package/packages/src/core/agent-loop/turn-executor.ts +222 -0
  262. package/packages/src/core/agent-loop/types.ts +148 -0
  263. package/packages/src/core/agent-loop.ts +18 -0
  264. package/packages/src/core/api-client-impl.ts +619 -0
  265. package/packages/src/core/api-client.ts +6 -0
  266. package/packages/src/core/checkpoints.ts +606 -0
  267. package/packages/src/core/claude-md.ts +272 -0
  268. package/packages/src/core/cognitive-security/hooks.ts +590 -0
  269. package/packages/src/core/cognitive-security/index.ts +2041 -0
  270. package/packages/src/core/cognitive-security/middleware.ts +536 -0
  271. package/packages/src/core/config-loader.ts +324 -0
  272. package/packages/src/core/context-compaction.ts +578 -0
  273. package/packages/src/core/git-status.ts +262 -0
  274. package/packages/src/core/image.test.ts +180 -0
  275. package/packages/src/core/image.ts +350 -0
  276. package/packages/src/core/lmdb.db +0 -0
  277. package/packages/src/core/lmdb.db-lock +0 -0
  278. package/packages/src/core/models.ts +430 -0
  279. package/packages/src/core/normalizers/todo +4 -0
  280. package/packages/src/core/permissions.ts +431 -0
  281. package/packages/src/core/retry.ts +170 -0
  282. package/packages/src/core/session-store.ts +36 -0
  283. package/packages/src/core/sessions/export.ts +329 -0
  284. package/packages/src/core/sessions/index.ts +587 -0
  285. package/packages/src/core/sessions/metadata.ts +309 -0
  286. package/packages/src/core/sessions/persistence.ts +244 -0
  287. package/packages/src/core/sessions/types.ts +169 -0
  288. package/packages/src/core/stream-highlighter.ts +1123 -0
  289. package/packages/src/core/system-reminders.ts +402 -0
  290. package/packages/src/core/todo +8 -0
  291. package/packages/src/ecosystem/hooks/__tests__/index.test.ts +561 -0
  292. package/packages/src/ecosystem/hooks/index.ts +341 -0
  293. package/packages/src/ecosystem/hooks/prompt-evaluator.ts +300 -0
  294. package/packages/src/ecosystem/skills/index.ts +295 -0
  295. package/packages/src/ecosystem/tools/__tests__/index.test.ts +1335 -0
  296. package/packages/src/ecosystem/tools/index.ts +1877 -0
  297. package/packages/src/index.ts +120 -0
  298. package/packages/src/interfaces/mcp/client.ts +389 -0
  299. package/packages/src/interfaces/ui/Screenshot 2026-03-02 at 9.23.10/342/200/257PM.png +0 -0
  300. package/packages/src/interfaces/ui/Screenshot 2026-03-03 at 10.55.11/342/200/257AM.png +0 -0
  301. package/packages/src/interfaces/ui/index.ts +161 -0
  302. package/packages/src/interfaces/ui/lmdb.db +0 -0
  303. package/packages/src/interfaces/ui/lmdb.db-lock +0 -0
  304. package/packages/src/interfaces/ui/spinner.ts +451 -0
  305. package/packages/src/interfaces/ui/terminal/cli/index.ts +228 -0
  306. package/packages/src/interfaces/ui/terminal/lmdb.db +0 -0
  307. package/packages/src/interfaces/ui/terminal/lmdb.db-lock +0 -0
  308. package/packages/src/interfaces/ui/terminal/shared/args.ts +222 -0
  309. package/packages/src/interfaces/ui/terminal/shared/index.ts +71 -0
  310. package/packages/src/interfaces/ui/terminal/shared/loading-state.ts +322 -0
  311. package/packages/src/interfaces/ui/terminal/shared/query.ts +146 -0
  312. package/packages/src/interfaces/ui/terminal/shared/setup.ts +295 -0
  313. package/packages/src/interfaces/ui/terminal/shared/status-line.ts +358 -0
  314. package/packages/src/interfaces/ui/terminal/shared/system-prompt.ts +146 -0
  315. package/packages/src/interfaces/ui/terminal/tui/HelpPanel.tsx +262 -0
  316. package/packages/src/interfaces/ui/terminal/tui/InputContext.tsx +232 -0
  317. package/packages/src/interfaces/ui/terminal/tui/InputField.tsx +62 -0
  318. package/packages/src/interfaces/ui/terminal/tui/InteractiveTUI.tsx +537 -0
  319. package/packages/src/interfaces/ui/terminal/tui/MessageArea.tsx +107 -0
  320. package/packages/src/interfaces/ui/terminal/tui/MessageStore.tsx +240 -0
  321. package/packages/src/interfaces/ui/terminal/tui/StatusBar.tsx +54 -0
  322. package/packages/src/interfaces/ui/terminal/tui/commands.ts +438 -0
  323. package/packages/src/interfaces/ui/terminal/tui/components/InteractiveElements.tsx +584 -0
  324. package/packages/src/interfaces/ui/terminal/tui/components/MultilineInput.tsx +614 -0
  325. package/packages/src/interfaces/ui/terminal/tui/components/PaneManager.tsx +333 -0
  326. package/packages/src/interfaces/ui/terminal/tui/components/Sidebar.tsx +604 -0
  327. package/packages/src/interfaces/ui/terminal/tui/components/index.ts +118 -0
  328. package/packages/src/interfaces/ui/terminal/tui/console.ts +49 -0
  329. package/packages/src/interfaces/ui/terminal/tui/index.ts +90 -0
  330. package/packages/src/interfaces/ui/terminal/tui/run.tsx +42 -0
  331. package/packages/src/interfaces/ui/terminal/tui/spinner.ts +69 -0
  332. package/packages/src/interfaces/ui/terminal/tui/tui-app.tsx +390 -0
  333. package/packages/src/interfaces/ui/terminal/tui/tui-footer.ts +422 -0
  334. package/packages/src/interfaces/ui/terminal/tui/types.ts +186 -0
  335. package/packages/src/interfaces/ui/terminal/tui/useInputHandler.ts +104 -0
  336. package/packages/src/interfaces/ui/terminal/tui/useNativeInput.ts +239 -0
  337. package/packages/src/lmdb.db +0 -0
  338. package/packages/src/lmdb.db-lock +0 -0
  339. package/packages/src/native/index.ts +2345 -0
  340. package/packages/src/teammates/index.ts +982 -0
  341. package/packages/src/types/index.ts +722 -0
@@ -0,0 +1,458 @@
1
+ /**
2
+ * Hook System Tests
3
+ */
4
+ import { describe, it, expect, beforeEach, afterEach } from "bun:test";
5
+ import { HookManager, builtInHooks, hookExitCodes } from "../index.js";
6
+ describe("HookManager", () => {
7
+ let manager;
8
+ beforeEach(() => {
9
+ manager = new HookManager(5000);
10
+ });
11
+ afterEach(() => {
12
+ manager.clear();
13
+ });
14
+ describe("registration", () => {
15
+ it("should register a hook", () => {
16
+ manager.register("PreToolUse", {
17
+ event: "PreToolUse",
18
+ command: "echo 'test'",
19
+ enabled: true,
20
+ });
21
+ const hooks = manager.getHooks("PreToolUse");
22
+ expect(hooks).toHaveLength(1);
23
+ expect(hooks[0]?.command).toBe("echo 'test'");
24
+ });
25
+ it("should register multiple hooks for the same event", () => {
26
+ manager.register("PreToolUse", {
27
+ event: "PreToolUse",
28
+ command: "echo '1'",
29
+ enabled: true,
30
+ });
31
+ manager.register("PreToolUse", {
32
+ event: "PreToolUse",
33
+ command: "echo '2'",
34
+ enabled: true,
35
+ });
36
+ const hooks = manager.getHooks("PreToolUse");
37
+ expect(hooks).toHaveLength(2);
38
+ });
39
+ it("should register all hooks from a record", () => {
40
+ // Using type assertion since registerAll expects a complete Record
41
+ manager.registerAll({
42
+ PreToolUse: [
43
+ {
44
+ event: "PreToolUse",
45
+ command: "echo '1'",
46
+ enabled: true,
47
+ },
48
+ ],
49
+ PostToolUse: [
50
+ {
51
+ event: "PostToolUse",
52
+ command: "echo '2'",
53
+ enabled: true,
54
+ },
55
+ ],
56
+ });
57
+ expect(manager.getHooks("PreToolUse")).toHaveLength(1);
58
+ expect(manager.getHooks("PostToolUse")).toHaveLength(1);
59
+ });
60
+ });
61
+ describe("in-process handlers", () => {
62
+ it("should execute an in-process handler", async () => {
63
+ let called = false;
64
+ manager.registerHandler("PreToolUse", async (input) => {
65
+ called = true;
66
+ return { decision: "allow" };
67
+ });
68
+ const result = await manager.execute("PreToolUse", {
69
+ tool_name: "Write",
70
+ tool_input: {},
71
+ });
72
+ expect(called).toBe(true);
73
+ expect(result.decision).toBe("allow");
74
+ });
75
+ it("should allow handler to deny execution", async () => {
76
+ manager.registerHandler("PreToolUse", async (input) => {
77
+ return {
78
+ decision: "deny",
79
+ reason: "Not allowed",
80
+ };
81
+ });
82
+ const result = await manager.execute("PreToolUse", {
83
+ tool_name: "Write",
84
+ tool_input: {},
85
+ });
86
+ expect(result.decision).toBe("deny");
87
+ expect(result.reason).toBe("Not allowed");
88
+ });
89
+ it("should allow handler to modify input", async () => {
90
+ manager.registerHandler("PreToolUse", async (input) => {
91
+ return {
92
+ decision: "allow",
93
+ modified_input: {
94
+ tool_input: { modified: true },
95
+ },
96
+ };
97
+ });
98
+ const input = {
99
+ tool_name: "Write",
100
+ tool_input: { original: true },
101
+ };
102
+ const result = await manager.execute("PreToolUse", input);
103
+ expect(result.decision).toBe("allow");
104
+ expect(input.tool_input).toEqual({ modified: true });
105
+ });
106
+ it("should handle handler errors gracefully", async () => {
107
+ manager.registerHandler("PreToolUse", async () => {
108
+ throw new Error("Handler failed");
109
+ });
110
+ const result = await manager.execute("PreToolUse", {
111
+ tool_name: "Write",
112
+ tool_input: {},
113
+ });
114
+ expect(result.decision).toBe("deny");
115
+ expect(result.reason).toBe("Hook handler error: Handler failed");
116
+ expect(result.errors?.[0]).toContain("Handler failed");
117
+ });
118
+ });
119
+ describe("shell command hooks", () => {
120
+ it("should execute a simple shell hook", async () => {
121
+ manager.register("PostToolUse", {
122
+ event: "PostToolUse",
123
+ command: `node -e '
124
+ const input = JSON.parse(require("fs").readFileSync(0, "utf8"));
125
+ console.log(JSON.stringify({ decision: "allow" }));
126
+ '`,
127
+ enabled: true,
128
+ });
129
+ const result = await manager.execute("PostToolUse", {
130
+ tool_name: "Write",
131
+ tool_input: {},
132
+ tool_result: { content: "test" },
133
+ });
134
+ expect(result.decision).toBe("allow");
135
+ });
136
+ it("should parse JSON output from hook", async () => {
137
+ manager.register("PreToolUse", {
138
+ event: "PreToolUse",
139
+ command: `node -e '
140
+ const input = JSON.parse(require("fs").readFileSync(0, "utf8"));
141
+ console.log(JSON.stringify({
142
+ decision: "deny",
143
+ reason: "Test denial"
144
+ }));
145
+ '`,
146
+ enabled: true,
147
+ });
148
+ const result = await manager.execute("PreToolUse", {
149
+ tool_name: "Write",
150
+ tool_input: {},
151
+ });
152
+ expect(result.decision).toBe("deny");
153
+ expect(result.reason).toBe("Test denial");
154
+ });
155
+ it("should default to allow on invalid JSON", async () => {
156
+ manager.register("PreToolUse", {
157
+ event: "PreToolUse",
158
+ command: `echo "not json"`,
159
+ enabled: true,
160
+ });
161
+ const result = await manager.execute("PreToolUse", {
162
+ tool_name: "Write",
163
+ tool_input: {},
164
+ });
165
+ expect(result.decision).toBe("allow");
166
+ });
167
+ it("should handle exit code 1 as deny", async () => {
168
+ manager.register("PreToolUse", {
169
+ event: "PreToolUse",
170
+ command: `node -e '
171
+ console.error("Access denied");
172
+ process.exit(1);
173
+ '`,
174
+ enabled: true,
175
+ });
176
+ const result = await manager.execute("PreToolUse", {
177
+ tool_name: "Write",
178
+ tool_input: {},
179
+ });
180
+ expect(result.decision).toBe("deny");
181
+ expect(result.reason).toContain("Access denied");
182
+ });
183
+ it("should handle exit code 2 as block", async () => {
184
+ manager.register("PreToolUse", {
185
+ event: "PreToolUse",
186
+ command: `node -e '
187
+ console.error("Blocked");
188
+ process.exit(2);
189
+ '`,
190
+ enabled: true,
191
+ });
192
+ const result = await manager.execute("PreToolUse", {
193
+ tool_name: "Write",
194
+ tool_input: {},
195
+ });
196
+ expect(result.decision).toBe("block");
197
+ });
198
+ it("should timeout long-running hooks", async () => {
199
+ manager.register("PreToolUse", {
200
+ event: "PreToolUse",
201
+ command: `node -e '
202
+ setTimeout(() => {}, 10000);
203
+ '`,
204
+ enabled: true,
205
+ timeout: 100,
206
+ });
207
+ const result = await manager.execute("PreToolUse", {
208
+ tool_name: "Write",
209
+ tool_input: {},
210
+ });
211
+ // After timeout, execution is denied
212
+ expect(result.decision).toBe("deny");
213
+ expect(result.reason).toContain("Hook timeout");
214
+ });
215
+ });
216
+ describe("hook chaining", () => {
217
+ it("should execute multiple hooks in sequence", async () => {
218
+ const order = [];
219
+ manager.registerHandler("PreToolUse", async () => {
220
+ order.push("hook1");
221
+ return { decision: "allow" };
222
+ });
223
+ manager.registerHandler("PreToolUse", async () => {
224
+ order.push("hook2");
225
+ return { decision: "allow" };
226
+ });
227
+ manager.registerHandler("PreToolUse", async () => {
228
+ order.push("hook3");
229
+ return { decision: "allow" };
230
+ });
231
+ await manager.execute("PreToolUse", {
232
+ tool_name: "Write",
233
+ tool_input: {},
234
+ });
235
+ expect(order).toEqual(["hook1", "hook2", "hook3"]);
236
+ });
237
+ it("should stop on first deny", async () => {
238
+ const order = [];
239
+ manager.registerHandler("PreToolUse", async () => {
240
+ order.push("hook1");
241
+ return { decision: "allow" };
242
+ });
243
+ manager.registerHandler("PreToolUse", async () => {
244
+ order.push("hook2");
245
+ return { decision: "deny", reason: "Stop here" };
246
+ });
247
+ manager.registerHandler("PreToolUse", async () => {
248
+ order.push("hook3");
249
+ return { decision: "allow" };
250
+ });
251
+ const result = await manager.execute("PreToolUse", {
252
+ tool_name: "Write",
253
+ tool_input: {},
254
+ });
255
+ expect(order).toEqual(["hook1", "hook2"]);
256
+ expect(result.decision).toBe("deny");
257
+ expect(result.reason).toBe("Stop here");
258
+ });
259
+ it("should stop on first block", async () => {
260
+ const order = [];
261
+ manager.registerHandler("PreToolUse", async () => {
262
+ order.push("hook1");
263
+ return { decision: "allow" };
264
+ });
265
+ manager.registerHandler("PreToolUse", async () => {
266
+ order.push("hook2");
267
+ return { decision: "block", reason: "Blocked" };
268
+ });
269
+ manager.registerHandler("PreToolUse", async () => {
270
+ order.push("hook3");
271
+ return { decision: "allow" };
272
+ });
273
+ const result = await manager.execute("PreToolUse", {
274
+ tool_name: "Write",
275
+ tool_input: {},
276
+ });
277
+ expect(order).toEqual(["hook1", "hook2"]);
278
+ expect(result.decision).toBe("block");
279
+ });
280
+ });
281
+ describe("disabled hooks", () => {
282
+ it("should skip disabled hooks", async () => {
283
+ let called = false;
284
+ manager.registerHandler("PreToolUse", async () => {
285
+ called = true;
286
+ return { decision: "deny" };
287
+ });
288
+ const hooks = manager.getHooks("PreToolUse");
289
+ if (hooks[0])
290
+ hooks[0].enabled = false;
291
+ const result = await manager.execute("PreToolUse", {
292
+ tool_name: "Write",
293
+ tool_input: {},
294
+ });
295
+ expect(called).toBe(false);
296
+ expect(result.decision).toBe("allow");
297
+ });
298
+ });
299
+ describe("input modification", () => {
300
+ it("should apply modifications from hooks", async () => {
301
+ manager.registerHandler("PreToolUse", async () => {
302
+ return {
303
+ decision: "allow",
304
+ modified_input: {
305
+ tool_input: { step1: true },
306
+ },
307
+ };
308
+ });
309
+ manager.registerHandler("PreToolUse", async () => {
310
+ return {
311
+ decision: "allow",
312
+ modified_input: {
313
+ tool_input: { step2: true },
314
+ },
315
+ };
316
+ });
317
+ const input = {
318
+ tool_name: "Write",
319
+ tool_input: { original: true },
320
+ };
321
+ await manager.execute("PreToolUse", input);
322
+ expect(input.tool_input).toEqual({
323
+ step2: true,
324
+ });
325
+ });
326
+ });
327
+ describe("clear hooks", () => {
328
+ it("should clear all hooks", () => {
329
+ manager.register("PreToolUse", {
330
+ event: "PreToolUse",
331
+ command: "echo '1'",
332
+ enabled: true,
333
+ });
334
+ manager.register("PostToolUse", {
335
+ event: "PostToolUse",
336
+ command: "echo '2'",
337
+ enabled: true,
338
+ });
339
+ expect(manager.getHooks("PreToolUse")).toHaveLength(1);
340
+ expect(manager.getHooks("PostToolUse")).toHaveLength(1);
341
+ manager.clear();
342
+ expect(manager.getHooks("PreToolUse")).toHaveLength(0);
343
+ expect(manager.getHooks("PostToolUse")).toHaveLength(0);
344
+ });
345
+ it("should clear specific event hooks", () => {
346
+ manager.register("PreToolUse", {
347
+ event: "PreToolUse",
348
+ command: "echo '1'",
349
+ enabled: true,
350
+ });
351
+ manager.register("PostToolUse", {
352
+ event: "PostToolUse",
353
+ command: "echo '2'",
354
+ enabled: true,
355
+ });
356
+ manager.clear("PreToolUse");
357
+ expect(manager.getHooks("PreToolUse")).toHaveLength(0);
358
+ expect(manager.getHooks("PostToolUse")).toHaveLength(1);
359
+ });
360
+ });
361
+ describe("built-in hooks", () => {
362
+ it("should have built-in hooks defined", () => {
363
+ expect(builtInHooks.validateWrite).toBeDefined();
364
+ expect(builtInHooks.logToolUse).toBeDefined();
365
+ });
366
+ it("should have validateWrite hook disabled by default", () => {
367
+ expect(builtInHooks.validateWrite?.enabled).toBe(false);
368
+ });
369
+ it("should have logToolUse hook disabled by default", () => {
370
+ expect(builtInHooks.logToolUse?.enabled).toBe(false);
371
+ });
372
+ });
373
+ describe("hook input structure", () => {
374
+ it("should include timestamp in hook input", async () => {
375
+ let receivedTimestamp = 0;
376
+ manager.registerHandler("PreToolUse", async (input) => {
377
+ receivedTimestamp = input.timestamp;
378
+ return { decision: "allow" };
379
+ });
380
+ await manager.execute("PreToolUse", {
381
+ tool_name: "Write",
382
+ tool_input: {},
383
+ });
384
+ expect(receivedTimestamp).toBeGreaterThan(0);
385
+ });
386
+ it("should include event in hook input", async () => {
387
+ let receivedEvent = null;
388
+ manager.registerHandler("PreToolUse", async (input) => {
389
+ receivedEvent = input.event;
390
+ return { decision: "allow" };
391
+ });
392
+ await manager.execute("PreToolUse", {
393
+ tool_name: "Write",
394
+ tool_input: {},
395
+ });
396
+ expect(receivedEvent === "PreToolUse").toBe(true);
397
+ });
398
+ });
399
+ describe("real-world scenarios", () => {
400
+ it("should prevent writes to sensitive paths", async () => {
401
+ manager.register("PreToolUse", {
402
+ event: "PreToolUse",
403
+ command: `node -e '
404
+ const input = JSON.parse(require("fs").readFileSync(0, "utf8"));
405
+ if (input.tool_name === "Write") {
406
+ const path = input.tool_input.file_path;
407
+ if (path.includes("/etc/") || path.includes("~/.ssh/")) {
408
+ console.log(JSON.stringify({
409
+ decision: "deny",
410
+ reason: "Cannot write to sensitive path: " + path
411
+ }));
412
+ process.exit(1);
413
+ }
414
+ }
415
+ console.log(JSON.stringify({ decision: "allow" }));
416
+ '`,
417
+ enabled: true,
418
+ });
419
+ const safeResult = await manager.execute("PreToolUse", {
420
+ tool_name: "Write",
421
+ tool_input: { file_path: "/tmp/test.txt" },
422
+ });
423
+ expect(safeResult.decision).toBe("allow");
424
+ const dangerousResult = await manager.execute("PreToolUse", {
425
+ tool_name: "Write",
426
+ tool_input: { file_path: "/etc/passwd" },
427
+ });
428
+ expect(dangerousResult.decision).toBe("deny");
429
+ expect(dangerousResult.reason).toContain("Cannot write to sensitive path");
430
+ expect(dangerousResult.reason).toContain("/etc/passwd");
431
+ });
432
+ it("should log all tool uses", async () => {
433
+ const logs = [];
434
+ manager.registerHandler("PostToolUse", async (input) => {
435
+ logs.push(`Used: ${input.tool_name}`);
436
+ return { decision: "allow" };
437
+ });
438
+ await manager.execute("PostToolUse", {
439
+ tool_name: "Read",
440
+ tool_input: { file_path: "test.txt" },
441
+ tool_result: { content: "content" },
442
+ });
443
+ await manager.execute("PostToolUse", {
444
+ tool_name: "Write",
445
+ tool_input: { file_path: "test.txt" },
446
+ tool_result: { content: "" },
447
+ });
448
+ expect(logs).toEqual(["Used: Read", "Used: Write"]);
449
+ });
450
+ });
451
+ });
452
+ describe("hookExitCodes", () => {
453
+ it("should have correct exit codes", () => {
454
+ expect(hookExitCodes.ALLOW).toBe(0);
455
+ expect(hookExitCodes.DENY).toBe(1);
456
+ expect(hookExitCodes.BLOCK).toBe(2);
457
+ });
458
+ });
@@ -0,0 +1,59 @@
1
+ /**
2
+ * Hook System - Lifecycle event handlers
3
+ */
4
+ import type { HookEvent, HookDefinition, HookInput, HookOutput } from "../../types/index.js";
5
+ export type HookHandler = (input: HookInput) => Promise<HookOutput>;
6
+ /**
7
+ * Prompt evaluator function type - calls LLM to evaluate hook prompt
8
+ */
9
+ export type PromptEvaluator = (prompt: string, context: HookInput) => Promise<HookOutput>;
10
+ /**
11
+ * Extended hook definition that supports shell commands, in-process handlers, and LLM prompts
12
+ */
13
+ export interface ExtendedHookDefinition extends HookDefinition {
14
+ /** In-process handler function (alternative to command) */
15
+ handler?: HookHandler;
16
+ /** Prompt template for LLM-based evaluation (alternative to command) */
17
+ prompt?: string;
18
+ /** Matcher pattern for filtering which tools this hook applies to */
19
+ _matcher?: string;
20
+ }
21
+ export declare class HookManager {
22
+ private hooks;
23
+ private timeout;
24
+ private promptEvaluator?;
25
+ constructor(timeout?: number, promptEvaluator?: PromptEvaluator);
26
+ /**
27
+ * Set the prompt evaluator for LLM-based hooks
28
+ */
29
+ setPromptEvaluator(evaluator: PromptEvaluator): void;
30
+ register(event: HookEvent, definition: HookDefinition | ExtendedHookDefinition): void;
31
+ /**
32
+ * Register an in-process handler for an event
33
+ */
34
+ registerHandler(event: HookEvent, handler: HookHandler, options?: {
35
+ timeout?: number;
36
+ enabled?: boolean;
37
+ }): void;
38
+ registerAll(hooks: Record<HookEvent, HookDefinition[]>): void;
39
+ execute(event: HookEvent, input: Omit<HookInput, "event" | "timestamp">): Promise<HookOutput>;
40
+ private executeHook;
41
+ getHooks(event: HookEvent): ExtendedHookDefinition[];
42
+ clear(event?: HookEvent): void;
43
+ }
44
+ export declare const builtInHooks: Record<string, HookDefinition>;
45
+ export declare const hookEventDocs: Record<HookEvent, string>;
46
+ /**
47
+ * Exit codes for hook commands:
48
+ * 0 = Success, allow execution
49
+ * 1 = Show stderr, deny execution
50
+ * 2 = Block execution silently
51
+ */
52
+ export declare const hookExitCodes: {
53
+ ALLOW: number;
54
+ DENY: number;
55
+ BLOCK: number;
56
+ };
57
+ export { createPromptEvaluator, createMockPromptEvaluator } from "./prompt-evaluator.js";
58
+ export type { PromptEvaluatorOptions } from "./prompt-evaluator.js";
59
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../packages/src/ecosystem/hooks/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,cAAc,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAG7F,MAAM,MAAM,WAAW,GAAG,CAAC,KAAK,EAAE,SAAS,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;AAEpE;;GAEG;AACH,MAAM,MAAM,eAAe,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;AAE1F;;GAEG;AACH,MAAM,WAAW,sBAAuB,SAAQ,cAAc;IAC5D,2DAA2D;IAC3D,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,wEAAwE;IACxE,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,qEAAqE;IACrE,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,qBAAa,WAAW;IACtB,OAAO,CAAC,KAAK,CAAkD;IAC/D,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,eAAe,CAAC,CAAkB;gBAE9B,OAAO,SAAQ,EAAE,eAAe,CAAC,EAAE,eAAe;IAK9D;;OAEG;IACH,kBAAkB,CAAC,SAAS,EAAE,eAAe,GAAG,IAAI;IAIpD,QAAQ,CAAC,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,cAAc,GAAG,sBAAsB,GAAG,IAAI;IAOrF;;OAEG;IACH,eAAe,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE;QAAE,OAAO,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,OAAO,CAAA;KAAE,GAAG,IAAI;IAUhH,WAAW,CAAC,KAAK,EAAE,MAAM,CAAC,SAAS,EAAE,cAAc,EAAE,CAAC,GAAG,IAAI;IAQvD,OAAO,CAAC,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE,OAAO,GAAG,WAAW,CAAC,GAAG,OAAO,CAAC,UAAU,CAAC;YA4CrF,WAAW;IA6IzB,QAAQ,CAAC,KAAK,EAAE,SAAS,GAAG,sBAAsB,EAAE;IAIpD,KAAK,CAAC,KAAK,CAAC,EAAE,SAAS,GAAG,IAAI;CAO/B;AAMD,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAkCvD,CAAC;AAMF,eAAO,MAAM,aAAa,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,CAWnD,CAAC;AAEF;;;;;GAKG;AACH,eAAO,MAAM,aAAa;;;;CAIzB,CAAC;AAGF,OAAO,EAAE,qBAAqB,EAAE,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AACzF,YAAY,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC"}