@usetheo/ui 0.9.0-next.0 → 0.10.0-next.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 (474) hide show
  1. package/CHANGELOG.md +99 -0
  2. package/dist/chunk-2UJROWAG.js +106 -0
  3. package/dist/chunk-2UJROWAG.js.map +1 -0
  4. package/dist/chunk-2XPWOUEH.js +68 -0
  5. package/dist/chunk-2XPWOUEH.js.map +1 -0
  6. package/dist/chunk-3GHLNCM3.js +42 -0
  7. package/dist/chunk-3GHLNCM3.js.map +1 -0
  8. package/dist/chunk-3HOXC25T.js +48 -0
  9. package/dist/chunk-3HOXC25T.js.map +1 -0
  10. package/dist/chunk-3QGO5SB3.js +46 -0
  11. package/dist/chunk-3QGO5SB3.js.map +1 -0
  12. package/dist/chunk-47QJVWW2.js +85 -0
  13. package/dist/chunk-47QJVWW2.js.map +1 -0
  14. package/dist/chunk-4L63UW3I.js +35 -0
  15. package/dist/chunk-4L63UW3I.js.map +1 -0
  16. package/dist/chunk-4UUSJJFZ.js +25 -0
  17. package/dist/chunk-4UUSJJFZ.js.map +1 -0
  18. package/dist/chunk-4ZBZBRG5.js +127 -0
  19. package/dist/chunk-4ZBZBRG5.js.map +1 -0
  20. package/dist/chunk-57NXT3OX.js +92 -0
  21. package/dist/chunk-57NXT3OX.js.map +1 -0
  22. package/dist/chunk-5FF5EUZP.js +44 -0
  23. package/dist/chunk-5FF5EUZP.js.map +1 -0
  24. package/dist/chunk-5UGQXB2P.js +714 -0
  25. package/dist/chunk-5UGQXB2P.js.map +1 -0
  26. package/dist/chunk-62FT22CI.js +85 -0
  27. package/dist/chunk-62FT22CI.js.map +1 -0
  28. package/dist/chunk-673R3GSK.js +19 -0
  29. package/dist/chunk-673R3GSK.js.map +1 -0
  30. package/dist/chunk-6VINZJBV.js +128 -0
  31. package/dist/chunk-6VINZJBV.js.map +1 -0
  32. package/dist/chunk-74NZ5U3E.js +145 -0
  33. package/dist/chunk-74NZ5U3E.js.map +1 -0
  34. package/dist/chunk-755NWSNW.js +36 -0
  35. package/dist/chunk-755NWSNW.js.map +1 -0
  36. package/dist/chunk-7GLBWWMW.js +70 -0
  37. package/dist/chunk-7GLBWWMW.js.map +1 -0
  38. package/dist/chunk-7RXYW5VM.js +88 -0
  39. package/dist/chunk-7RXYW5VM.js.map +1 -0
  40. package/dist/chunk-AC4MGCXI.js +92 -0
  41. package/dist/chunk-AC4MGCXI.js.map +1 -0
  42. package/dist/chunk-AEVSVDT6.js +67 -0
  43. package/dist/chunk-AEVSVDT6.js.map +1 -0
  44. package/dist/chunk-AODIMN2N.js +68 -0
  45. package/dist/chunk-AODIMN2N.js.map +1 -0
  46. package/dist/chunk-ATHOPBCA.js +61 -0
  47. package/dist/chunk-ATHOPBCA.js.map +1 -0
  48. package/dist/chunk-AXKBNRZW.js +173 -0
  49. package/dist/chunk-AXKBNRZW.js.map +1 -0
  50. package/dist/chunk-B75MEYNR.js +106 -0
  51. package/dist/chunk-B75MEYNR.js.map +1 -0
  52. package/dist/chunk-BGKA6DI6.js +34 -0
  53. package/dist/chunk-BGKA6DI6.js.map +1 -0
  54. package/dist/chunk-BNQAJGEN.js +88 -0
  55. package/dist/chunk-BNQAJGEN.js.map +1 -0
  56. package/dist/chunk-BP2SETUC.js +101 -0
  57. package/dist/chunk-BP2SETUC.js.map +1 -0
  58. package/dist/chunk-BPUQWMBD.js +79 -0
  59. package/dist/chunk-BPUQWMBD.js.map +1 -0
  60. package/dist/chunk-BVDASR3Y.js +74 -0
  61. package/dist/chunk-BVDASR3Y.js.map +1 -0
  62. package/dist/chunk-CDA6RYOX.js +115 -0
  63. package/dist/chunk-CDA6RYOX.js.map +1 -0
  64. package/dist/chunk-CG7O3A42.js +80 -0
  65. package/dist/chunk-CG7O3A42.js.map +1 -0
  66. package/dist/chunk-CIYGNPKT.js +76 -0
  67. package/dist/chunk-CIYGNPKT.js.map +1 -0
  68. package/dist/chunk-CKXY4FTV.js +59 -0
  69. package/dist/chunk-CKXY4FTV.js.map +1 -0
  70. package/dist/chunk-CVOKZITR.js +82 -0
  71. package/dist/chunk-CVOKZITR.js.map +1 -0
  72. package/dist/chunk-CWFMFKDI.js +82 -0
  73. package/dist/chunk-CWFMFKDI.js.map +1 -0
  74. package/dist/chunk-CWVKSV7S.js +124 -0
  75. package/dist/chunk-CWVKSV7S.js.map +1 -0
  76. package/dist/chunk-CYOLRWOX.js +63 -0
  77. package/dist/chunk-CYOLRWOX.js.map +1 -0
  78. package/dist/chunk-D23LRJT6.js +116 -0
  79. package/dist/chunk-D23LRJT6.js.map +1 -0
  80. package/dist/chunk-DAKIL5PC.js +186 -0
  81. package/dist/chunk-DAKIL5PC.js.map +1 -0
  82. package/dist/chunk-DFADMEJK.js +127 -0
  83. package/dist/chunk-DFADMEJK.js.map +1 -0
  84. package/dist/chunk-E5A7HN6H.js +32 -0
  85. package/dist/chunk-E5A7HN6H.js.map +1 -0
  86. package/dist/chunk-EI63GTN7.js +57 -0
  87. package/dist/chunk-EI63GTN7.js.map +1 -0
  88. package/dist/chunk-EP25QJ4N.js +146 -0
  89. package/dist/chunk-EP25QJ4N.js.map +1 -0
  90. package/dist/chunk-ET44426Q.js +80 -0
  91. package/dist/chunk-ET44426Q.js.map +1 -0
  92. package/dist/chunk-ETEIDY34.js +67 -0
  93. package/dist/chunk-ETEIDY34.js.map +1 -0
  94. package/dist/chunk-EU55O4P7.js +76 -0
  95. package/dist/chunk-EU55O4P7.js.map +1 -0
  96. package/dist/chunk-F436537E.js +104 -0
  97. package/dist/chunk-F436537E.js.map +1 -0
  98. package/dist/chunk-FLBTGNQI.js +86 -0
  99. package/dist/chunk-FLBTGNQI.js.map +1 -0
  100. package/dist/chunk-FUT45NFW.js +46 -0
  101. package/dist/chunk-FUT45NFW.js.map +1 -0
  102. package/dist/chunk-G3LWNTVZ.js +51 -0
  103. package/dist/chunk-G3LWNTVZ.js.map +1 -0
  104. package/dist/chunk-GBJB5WLT.js +58 -0
  105. package/dist/chunk-GBJB5WLT.js.map +1 -0
  106. package/dist/chunk-GIEPEFRX.js +110 -0
  107. package/dist/chunk-GIEPEFRX.js.map +1 -0
  108. package/dist/chunk-GSO7MISR.js +58 -0
  109. package/dist/chunk-GSO7MISR.js.map +1 -0
  110. package/dist/chunk-GUQFYUIC.js +61 -0
  111. package/dist/chunk-GUQFYUIC.js.map +1 -0
  112. package/dist/chunk-H3ANHVEL.js +83 -0
  113. package/dist/chunk-H3ANHVEL.js.map +1 -0
  114. package/dist/chunk-H3VJMFJQ.js +35 -0
  115. package/dist/chunk-H3VJMFJQ.js.map +1 -0
  116. package/dist/chunk-HG4WEERE.js +26 -0
  117. package/dist/chunk-HG4WEERE.js.map +1 -0
  118. package/dist/chunk-HGPBGLNP.js +51 -0
  119. package/dist/chunk-HGPBGLNP.js.map +1 -0
  120. package/dist/chunk-HQFTW7SF.js +141 -0
  121. package/dist/chunk-HQFTW7SF.js.map +1 -0
  122. package/dist/chunk-I7WYM63C.js +170 -0
  123. package/dist/chunk-I7WYM63C.js.map +1 -0
  124. package/dist/chunk-JQXLPVWP.js +74 -0
  125. package/dist/chunk-JQXLPVWP.js.map +1 -0
  126. package/dist/chunk-K5ARID4S.js +26 -0
  127. package/dist/chunk-K5ARID4S.js.map +1 -0
  128. package/dist/chunk-K6RTLPIJ.js +41 -0
  129. package/dist/chunk-K6RTLPIJ.js.map +1 -0
  130. package/dist/chunk-KQNKKV2C.js +56 -0
  131. package/dist/chunk-KQNKKV2C.js.map +1 -0
  132. package/dist/chunk-KRN4NE4U.js +155 -0
  133. package/dist/chunk-KRN4NE4U.js.map +1 -0
  134. package/dist/chunk-L2BI762I.js +82 -0
  135. package/dist/chunk-L2BI762I.js.map +1 -0
  136. package/dist/chunk-LEEH63B2.js +56 -0
  137. package/dist/chunk-LEEH63B2.js.map +1 -0
  138. package/dist/chunk-LHRWVM3G.js +42 -0
  139. package/dist/chunk-LHRWVM3G.js.map +1 -0
  140. package/dist/chunk-LIGWMGXM.js +117 -0
  141. package/dist/chunk-LIGWMGXM.js.map +1 -0
  142. package/dist/chunk-LKYSX3QF.js +104 -0
  143. package/dist/chunk-LKYSX3QF.js.map +1 -0
  144. package/dist/chunk-MCIFB6VS.js +54 -0
  145. package/dist/chunk-MCIFB6VS.js.map +1 -0
  146. package/dist/chunk-NQZYY4LR.js +84 -0
  147. package/dist/chunk-NQZYY4LR.js.map +1 -0
  148. package/dist/chunk-O23LKHUR.js +66 -0
  149. package/dist/chunk-O23LKHUR.js.map +1 -0
  150. package/dist/chunk-PASI2U2R.js +23 -0
  151. package/dist/chunk-PASI2U2R.js.map +1 -0
  152. package/dist/chunk-PPH5NTHV.js +34 -0
  153. package/dist/chunk-PPH5NTHV.js.map +1 -0
  154. package/dist/chunk-PR6OZF6D.js +28 -0
  155. package/dist/chunk-PR6OZF6D.js.map +1 -0
  156. package/dist/chunk-PWXOXPFT.js +142 -0
  157. package/dist/chunk-PWXOXPFT.js.map +1 -0
  158. package/dist/chunk-QB6BNHO3.js +112 -0
  159. package/dist/chunk-QB6BNHO3.js.map +1 -0
  160. package/dist/chunk-QSOIJ6J3.js +91 -0
  161. package/dist/chunk-QSOIJ6J3.js.map +1 -0
  162. package/dist/chunk-QU6RLHYH.js +156 -0
  163. package/dist/chunk-QU6RLHYH.js.map +1 -0
  164. package/dist/chunk-R63ZKLQM.js +45 -0
  165. package/dist/chunk-R63ZKLQM.js.map +1 -0
  166. package/dist/chunk-RTYYJPPE.js +77 -0
  167. package/dist/chunk-RTYYJPPE.js.map +1 -0
  168. package/dist/chunk-RVOBP7PO.js +116 -0
  169. package/dist/chunk-RVOBP7PO.js.map +1 -0
  170. package/dist/chunk-SF6R5VMQ.js +97 -0
  171. package/dist/chunk-SF6R5VMQ.js.map +1 -0
  172. package/dist/chunk-SP4CP5HY.js +57 -0
  173. package/dist/chunk-SP4CP5HY.js.map +1 -0
  174. package/dist/chunk-SWJ4EUOI.js +30 -0
  175. package/dist/chunk-SWJ4EUOI.js.map +1 -0
  176. package/dist/chunk-TK24HQJJ.js +128 -0
  177. package/dist/chunk-TK24HQJJ.js.map +1 -0
  178. package/dist/chunk-TO3UAT6O.js +221 -0
  179. package/dist/chunk-TO3UAT6O.js.map +1 -0
  180. package/dist/chunk-UAYOOTRR.js +77 -0
  181. package/dist/chunk-UAYOOTRR.js.map +1 -0
  182. package/dist/chunk-UDTAMHXW.js +55 -0
  183. package/dist/chunk-UDTAMHXW.js.map +1 -0
  184. package/dist/chunk-UGKI466V.js +12 -0
  185. package/dist/chunk-UGKI466V.js.map +1 -0
  186. package/dist/chunk-UOXU7NDY.js +120 -0
  187. package/dist/chunk-UOXU7NDY.js.map +1 -0
  188. package/dist/chunk-V7OOTVK3.js +106 -0
  189. package/dist/chunk-V7OOTVK3.js.map +1 -0
  190. package/dist/chunk-VI5M7KJ2.js +1022 -0
  191. package/dist/chunk-VI5M7KJ2.js.map +1 -0
  192. package/dist/chunk-VM4RMQQN.js +11 -0
  193. package/dist/chunk-VM4RMQQN.js.map +1 -0
  194. package/dist/chunk-VMMATOPE.js +64 -0
  195. package/dist/chunk-VMMATOPE.js.map +1 -0
  196. package/dist/chunk-W2PVSIW3.js +89 -0
  197. package/dist/chunk-W2PVSIW3.js.map +1 -0
  198. package/dist/chunk-W3DUDZDU.js +88 -0
  199. package/dist/chunk-W3DUDZDU.js.map +1 -0
  200. package/dist/chunk-WKEUU2FU.js +114 -0
  201. package/dist/chunk-WKEUU2FU.js.map +1 -0
  202. package/dist/chunk-WKLW7RC6.js +28 -0
  203. package/dist/chunk-WKLW7RC6.js.map +1 -0
  204. package/dist/chunk-WSJGZNUH.js +111 -0
  205. package/dist/chunk-WSJGZNUH.js.map +1 -0
  206. package/dist/chunk-WVPDQMC2.js +144 -0
  207. package/dist/chunk-WVPDQMC2.js.map +1 -0
  208. package/dist/chunk-WWNH5ENT.js +43 -0
  209. package/dist/chunk-WWNH5ENT.js.map +1 -0
  210. package/dist/chunk-X5L62PXY.js +112 -0
  211. package/dist/chunk-X5L62PXY.js.map +1 -0
  212. package/dist/chunk-XGCV5E6W.js +133 -0
  213. package/dist/chunk-XGCV5E6W.js.map +1 -0
  214. package/dist/chunk-XRKIEL5M.js +72 -0
  215. package/dist/chunk-XRKIEL5M.js.map +1 -0
  216. package/dist/chunk-XUJYEADU.js +80 -0
  217. package/dist/chunk-XUJYEADU.js.map +1 -0
  218. package/dist/chunk-XVYNSIQC.js +116 -0
  219. package/dist/chunk-XVYNSIQC.js.map +1 -0
  220. package/dist/chunk-XWTISHXO.js +54 -0
  221. package/dist/chunk-XWTISHXO.js.map +1 -0
  222. package/dist/chunk-YOGHS4UU.js +202 -0
  223. package/dist/chunk-YOGHS4UU.js.map +1 -0
  224. package/dist/chunk-YRSKXEOD.js +135 -0
  225. package/dist/chunk-YRSKXEOD.js.map +1 -0
  226. package/dist/chunk-ZALLCR7X.js +108 -0
  227. package/dist/chunk-ZALLCR7X.js.map +1 -0
  228. package/dist/chunk-ZDAOHMCW.js +46 -0
  229. package/dist/chunk-ZDAOHMCW.js.map +1 -0
  230. package/dist/chunk-ZESICCKK.js +37 -0
  231. package/dist/chunk-ZESICCKK.js.map +1 -0
  232. package/dist/chunk-ZIKFOD6N.js +87 -0
  233. package/dist/chunk-ZIKFOD6N.js.map +1 -0
  234. package/dist/chunk-ZJRWCQEN.js +76 -0
  235. package/dist/chunk-ZJRWCQEN.js.map +1 -0
  236. package/dist/chunk-ZSRJCIWF.js +24 -0
  237. package/dist/chunk-ZSRJCIWF.js.map +1 -0
  238. package/dist/chunk-ZXPDS6DH.js +3 -0
  239. package/dist/chunk-ZXPDS6DH.js.map +1 -0
  240. package/dist/components.css +1 -1
  241. package/dist/composites/account-menu/index.js +6 -0
  242. package/dist/composites/account-menu/index.js.map +1 -0
  243. package/dist/composites/agent-composer/index.js +7 -0
  244. package/dist/composites/agent-composer/index.js.map +1 -0
  245. package/dist/composites/agent-editor/index.js +10 -0
  246. package/dist/composites/agent-editor/index.js.map +1 -0
  247. package/dist/composites/agent-stream/index.js +12 -0
  248. package/dist/composites/agent-stream/index.js.map +1 -0
  249. package/dist/composites/agent-timeline/index.js +5 -0
  250. package/dist/composites/agent-timeline/index.js.map +1 -0
  251. package/dist/composites/approval-card/index.js +5 -0
  252. package/dist/composites/approval-card/index.js.map +1 -0
  253. package/dist/composites/chat-composer/index.js +6 -0
  254. package/dist/composites/chat-composer/index.js.map +1 -0
  255. package/dist/composites/chat-message/index.js +6 -0
  256. package/dist/composites/chat-message/index.js.map +1 -0
  257. package/dist/composites/code-block/index.js +5 -0
  258. package/dist/composites/code-block/index.js.map +1 -0
  259. package/dist/composites/command-palette/index.js +5 -0
  260. package/dist/composites/command-palette/index.js.map +1 -0
  261. package/dist/composites/confirm-dialog/index.js +7 -0
  262. package/dist/composites/confirm-dialog/index.js.map +1 -0
  263. package/dist/composites/cron-jobs-list/index.js +5 -0
  264. package/dist/composites/cron-jobs-list/index.js.map +1 -0
  265. package/dist/composites/deployment-row/index.js +5 -0
  266. package/dist/composites/deployment-row/index.js.map +1 -0
  267. package/dist/composites/domain-config/index.js +7 -0
  268. package/dist/composites/domain-config/index.js.map +1 -0
  269. package/dist/composites/env-var-editor/index.js +7 -0
  270. package/dist/composites/env-var-editor/index.js.map +1 -0
  271. package/dist/composites/mcp-server-list/index.js +5 -0
  272. package/dist/composites/mcp-server-list/index.js.map +1 -0
  273. package/dist/composites/permission-modal/index.js +6 -0
  274. package/dist/composites/permission-modal/index.js.map +1 -0
  275. package/dist/composites/preview-env-card/index.js +6 -0
  276. package/dist/composites/preview-env-card/index.js.map +1 -0
  277. package/dist/composites/preview-panel/index.js +5 -0
  278. package/dist/composites/preview-panel/index.js.map +1 -0
  279. package/dist/composites/project-card/index.js +6 -0
  280. package/dist/composites/project-card/index.js.map +1 -0
  281. package/dist/composites/rollback-ui/index.js +6 -0
  282. package/dist/composites/rollback-ui/index.js.map +1 -0
  283. package/dist/composites/rule-editor/index.js +11 -0
  284. package/dist/composites/rule-editor/index.js.map +1 -0
  285. package/dist/composites/skill-editor/index.js +11 -0
  286. package/dist/composites/skill-editor/index.js.map +1 -0
  287. package/dist/composites/skills-list/index.js +5 -0
  288. package/dist/composites/skills-list/index.js.map +1 -0
  289. package/dist/composites/task-header/index.js +5 -0
  290. package/dist/composites/task-header/index.js.map +1 -0
  291. package/dist/composites/usage-meter/index.js +5 -0
  292. package/dist/composites/usage-meter/index.js.map +1 -0
  293. package/dist/index.js +130 -9493
  294. package/dist/index.js.map +1 -1
  295. package/dist/primitives/agent-error-card/index.js +5 -0
  296. package/dist/primitives/agent-error-card/index.js.map +1 -0
  297. package/dist/primitives/agent-event/index.js +4 -0
  298. package/dist/primitives/agent-event/index.js.map +1 -0
  299. package/dist/primitives/agent-handoff/index.js +4 -0
  300. package/dist/primitives/agent-handoff/index.js.map +1 -0
  301. package/dist/primitives/agent-profile/index.js +4 -0
  302. package/dist/primitives/agent-profile/index.js.map +1 -0
  303. package/dist/primitives/agent-starting-state/index.js +5 -0
  304. package/dist/primitives/agent-starting-state/index.js.map +1 -0
  305. package/dist/primitives/agent-streaming/index.js +5 -0
  306. package/dist/primitives/agent-streaming/index.js.map +1 -0
  307. package/dist/primitives/alert/index.js +4 -0
  308. package/dist/primitives/alert/index.js.map +1 -0
  309. package/dist/primitives/artifact-preview/index.js +4 -0
  310. package/dist/primitives/artifact-preview/index.js.map +1 -0
  311. package/dist/primitives/attachment-chip/index.js +4 -0
  312. package/dist/primitives/attachment-chip/index.js.map +1 -0
  313. package/dist/primitives/audit-log-entry/index.js +4 -0
  314. package/dist/primitives/audit-log-entry/index.js.map +1 -0
  315. package/dist/primitives/auto-compact-notice/index.js +5 -0
  316. package/dist/primitives/auto-compact-notice/index.js.map +1 -0
  317. package/dist/primitives/avatar/index.js +4 -0
  318. package/dist/primitives/avatar/index.js.map +1 -0
  319. package/dist/primitives/badge/index.js +4 -0
  320. package/dist/primitives/badge/index.js.map +1 -0
  321. package/dist/primitives/browser-controls/index.js +4 -0
  322. package/dist/primitives/browser-controls/index.js.map +1 -0
  323. package/dist/primitives/build-log-stream/index.js +5 -0
  324. package/dist/primitives/build-log-stream/index.js.map +1 -0
  325. package/dist/primitives/button/index.js +4 -0
  326. package/dist/primitives/button/index.js.map +1 -0
  327. package/dist/primitives/capability-indicator/index.js +4 -0
  328. package/dist/primitives/capability-indicator/index.js.map +1 -0
  329. package/dist/primitives/card/index.js +4 -0
  330. package/dist/primitives/card/index.js.map +1 -0
  331. package/dist/primitives/chat-thread/index.js +5 -0
  332. package/dist/primitives/chat-thread/index.js.map +1 -0
  333. package/dist/primitives/checkbox/index.js +4 -0
  334. package/dist/primitives/checkbox/index.js.map +1 -0
  335. package/dist/primitives/context-card/index.js +4 -0
  336. package/dist/primitives/context-card/index.js.map +1 -0
  337. package/dist/primitives/context-window-bar/index.js +4 -0
  338. package/dist/primitives/context-window-bar/index.js.map +1 -0
  339. package/dist/primitives/copy-button/index.js +4 -0
  340. package/dist/primitives/copy-button/index.js.map +1 -0
  341. package/dist/primitives/cost-meter/index.js +4 -0
  342. package/dist/primitives/cost-meter/index.js.map +1 -0
  343. package/dist/primitives/created-files-card/index.js +4 -0
  344. package/dist/primitives/created-files-card/index.js.map +1 -0
  345. package/dist/primitives/cron-job-card/index.js +4 -0
  346. package/dist/primitives/cron-job-card/index.js.map +1 -0
  347. package/dist/primitives/danger-zone/index.js +4 -0
  348. package/dist/primitives/danger-zone/index.js.map +1 -0
  349. package/dist/primitives/dialog/index.js +4 -0
  350. package/dist/primitives/dialog/index.js.map +1 -0
  351. package/dist/primitives/diff-viewer/index.js +4 -0
  352. package/dist/primitives/diff-viewer/index.js.map +1 -0
  353. package/dist/primitives/empty-state/index.js +4 -0
  354. package/dist/primitives/empty-state/index.js.map +1 -0
  355. package/dist/primitives/folder-context-card/index.js +4 -0
  356. package/dist/primitives/folder-context-card/index.js.map +1 -0
  357. package/dist/primitives/folder-selector/index.js +4 -0
  358. package/dist/primitives/folder-selector/index.js.map +1 -0
  359. package/dist/primitives/form-field/index.js +4 -0
  360. package/dist/primitives/form-field/index.js.map +1 -0
  361. package/dist/primitives/hook-config/index.js +4 -0
  362. package/dist/primitives/hook-config/index.js.map +1 -0
  363. package/dist/primitives/hook-event-log/index.js +4 -0
  364. package/dist/primitives/hook-event-log/index.js.map +1 -0
  365. package/dist/primitives/input/index.js +4 -0
  366. package/dist/primitives/input/index.js.map +1 -0
  367. package/dist/primitives/intent-selector/index.js +4 -0
  368. package/dist/primitives/intent-selector/index.js.map +1 -0
  369. package/dist/primitives/label/index.js +4 -0
  370. package/dist/primitives/label/index.js.map +1 -0
  371. package/dist/primitives/lane-board/index.js +4 -0
  372. package/dist/primitives/lane-board/index.js.map +1 -0
  373. package/dist/primitives/login-split/index.js +4 -0
  374. package/dist/primitives/login-split/index.js.map +1 -0
  375. package/dist/primitives/mcp-server-card/index.js +4 -0
  376. package/dist/primitives/mcp-server-card/index.js.map +1 -0
  377. package/dist/primitives/memory-editor/index.js +4 -0
  378. package/dist/primitives/memory-editor/index.js.map +1 -0
  379. package/dist/primitives/mention-menu/index.js +4 -0
  380. package/dist/primitives/mention-menu/index.js.map +1 -0
  381. package/dist/primitives/metrics-panel/index.js +4 -0
  382. package/dist/primitives/metrics-panel/index.js.map +1 -0
  383. package/dist/primitives/model-card/index.js +4 -0
  384. package/dist/primitives/model-card/index.js.map +1 -0
  385. package/dist/primitives/model-selector/index.js +4 -0
  386. package/dist/primitives/model-selector/index.js.map +1 -0
  387. package/dist/primitives/pagination/index.js +4 -0
  388. package/dist/primitives/pagination/index.js.map +1 -0
  389. package/dist/primitives/permission-matrix/index.js +4 -0
  390. package/dist/primitives/permission-matrix/index.js.map +1 -0
  391. package/dist/primitives/plan-badge/index.js +4 -0
  392. package/dist/primitives/plan-badge/index.js.map +1 -0
  393. package/dist/primitives/progress/index.js +4 -0
  394. package/dist/primitives/progress/index.js.map +1 -0
  395. package/dist/primitives/progress-checklist/index.js +4 -0
  396. package/dist/primitives/progress-checklist/index.js.map +1 -0
  397. package/dist/primitives/project-switcher/index.js +4 -0
  398. package/dist/primitives/project-switcher/index.js.map +1 -0
  399. package/dist/primitives/quick-action-chips/index.js +4 -0
  400. package/dist/primitives/quick-action-chips/index.js.map +1 -0
  401. package/dist/primitives/radio-group/index.js +4 -0
  402. package/dist/primitives/radio-group/index.js.map +1 -0
  403. package/dist/primitives/recent-folders-list/index.js +4 -0
  404. package/dist/primitives/recent-folders-list/index.js.map +1 -0
  405. package/dist/primitives/rule-card/index.js +4 -0
  406. package/dist/primitives/rule-card/index.js.map +1 -0
  407. package/dist/primitives/run-stats/index.js +4 -0
  408. package/dist/primitives/run-stats/index.js.map +1 -0
  409. package/dist/primitives/running-tasks-panel/index.js +4 -0
  410. package/dist/primitives/running-tasks-panel/index.js.map +1 -0
  411. package/dist/primitives/scroll-area/index.js +4 -0
  412. package/dist/primitives/scroll-area/index.js.map +1 -0
  413. package/dist/primitives/select/index.js +4 -0
  414. package/dist/primitives/select/index.js.map +1 -0
  415. package/dist/primitives/session-list-item/index.js +4 -0
  416. package/dist/primitives/session-list-item/index.js.map +1 -0
  417. package/dist/primitives/session-timeline/index.js +4 -0
  418. package/dist/primitives/session-timeline/index.js.map +1 -0
  419. package/dist/primitives/sheet/index.js +4 -0
  420. package/dist/primitives/sheet/index.js.map +1 -0
  421. package/dist/primitives/sidebar/index.js +4 -0
  422. package/dist/primitives/sidebar/index.js.map +1 -0
  423. package/dist/primitives/skeleton/index.js +5 -0
  424. package/dist/primitives/skeleton/index.js.map +1 -0
  425. package/dist/primitives/skill-card/index.js +4 -0
  426. package/dist/primitives/skill-card/index.js.map +1 -0
  427. package/dist/primitives/social-auth-row/index.js +4 -0
  428. package/dist/primitives/social-auth-row/index.js.map +1 -0
  429. package/dist/primitives/stat-tile/index.js +4 -0
  430. package/dist/primitives/stat-tile/index.js.map +1 -0
  431. package/dist/primitives/status-dot/index.js +4 -0
  432. package/dist/primitives/status-dot/index.js.map +1 -0
  433. package/dist/primitives/steps-rail/index.js +4 -0
  434. package/dist/primitives/steps-rail/index.js.map +1 -0
  435. package/dist/primitives/sub-agent-dispatch/index.js +4 -0
  436. package/dist/primitives/sub-agent-dispatch/index.js.map +1 -0
  437. package/dist/primitives/switch/index.js +4 -0
  438. package/dist/primitives/switch/index.js.map +1 -0
  439. package/dist/primitives/system-prompt-editor/index.js +4 -0
  440. package/dist/primitives/system-prompt-editor/index.js.map +1 -0
  441. package/dist/primitives/table/index.js +4 -0
  442. package/dist/primitives/table/index.js.map +1 -0
  443. package/dist/primitives/tabs/index.js +4 -0
  444. package/dist/primitives/tabs/index.js.map +1 -0
  445. package/dist/primitives/task-plan/index.js +4 -0
  446. package/dist/primitives/task-plan/index.js.map +1 -0
  447. package/dist/primitives/terminal-panel/index.js +5 -0
  448. package/dist/primitives/terminal-panel/index.js.map +1 -0
  449. package/dist/primitives/textarea/index.js +4 -0
  450. package/dist/primitives/textarea/index.js.map +1 -0
  451. package/dist/primitives/timestamp/index.js +4 -0
  452. package/dist/primitives/timestamp/index.js.map +1 -0
  453. package/dist/primitives/toast/index.js +4 -0
  454. package/dist/primitives/toast/index.js.map +1 -0
  455. package/dist/primitives/token-usage-chart/index.js +4 -0
  456. package/dist/primitives/token-usage-chart/index.js.map +1 -0
  457. package/dist/primitives/tool-call/index.js +4 -0
  458. package/dist/primitives/tool-call/index.js.map +1 -0
  459. package/dist/primitives/tool-call-card/index.js +4 -0
  460. package/dist/primitives/tool-call-card/index.js.map +1 -0
  461. package/dist/primitives/tool-result/index.js +4 -0
  462. package/dist/primitives/tool-result/index.js.map +1 -0
  463. package/dist/primitives/tools-list/index.js +4 -0
  464. package/dist/primitives/tools-list/index.js.map +1 -0
  465. package/dist/primitives/tooltip/index.js +4 -0
  466. package/dist/primitives/tooltip/index.js.map +1 -0
  467. package/dist/primitives/topnav/index.js +4 -0
  468. package/dist/primitives/topnav/index.js.map +1 -0
  469. package/dist/slide/index.js +1 -712
  470. package/dist/slide/index.js.map +1 -1
  471. package/dist/slide-deck/index.js +2 -688
  472. package/dist/slide-deck/index.js.map +1 -1
  473. package/llms.txt +6 -5
  474. package/package.json +115 -115
@@ -0,0 +1,104 @@
1
+ import { cn } from './chunk-ZSRJCIWF.js';
2
+ import { Coins, TrendingUp, TrendingDown } from 'lucide-react';
3
+ import { forwardRef } from 'react';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ var formatUsd = (n) => n >= 100 ? `$${n.toFixed(0)}` : n >= 10 ? `$${n.toFixed(1)}` : `$${n.toFixed(2)}`;
7
+ var CostMeter = forwardRef(
8
+ ({ className, cost, budget, title = "Spend", delta, compact, ...props }, ref) => {
9
+ if (compact) {
10
+ return /* @__PURE__ */ jsxs(
11
+ "div",
12
+ {
13
+ ref,
14
+ className: cn(
15
+ "inline-flex items-center gap-1.5 rounded-full border border-border/60 bg-card px-2.5 py-1",
16
+ "font-mono text-label",
17
+ className
18
+ ),
19
+ ...props,
20
+ children: [
21
+ /* @__PURE__ */ jsx(Coins, { className: "size-3 text-primary", "aria-hidden": "true" }),
22
+ /* @__PURE__ */ jsx("span", { className: "text-foreground tabular-nums", children: formatUsd(cost) }),
23
+ budget ? /* @__PURE__ */ jsxs("span", { className: "text-muted-foreground", children: [
24
+ "/ ",
25
+ formatUsd(budget)
26
+ ] }) : null
27
+ ]
28
+ }
29
+ );
30
+ }
31
+ const ratio = budget ? Math.max(0, Math.min(1, cost / budget)) : 0;
32
+ const percent = Math.round(ratio * 100);
33
+ const overBudget = budget !== void 0 && cost > budget;
34
+ return /* @__PURE__ */ jsxs(
35
+ "div",
36
+ {
37
+ ref,
38
+ className: cn("grid gap-2 rounded-xl border bg-card p-4", className),
39
+ ...props,
40
+ children: [
41
+ /* @__PURE__ */ jsxs("header", { className: "flex items-baseline justify-between", children: [
42
+ /* @__PURE__ */ jsx("span", { className: "font-mono text-label-caps text-muted-foreground uppercase tracking-wider", children: title }),
43
+ delta ? /* @__PURE__ */ jsxs(
44
+ "span",
45
+ {
46
+ className: cn(
47
+ "inline-flex items-center gap-1 font-mono text-body-sm tabular-nums",
48
+ delta.value >= 0 ? "text-warning" : "text-success"
49
+ ),
50
+ children: [
51
+ delta.value >= 0 ? /* @__PURE__ */ jsx(TrendingUp, { className: "size-3", "aria-hidden": "true" }) : /* @__PURE__ */ jsx(TrendingDown, { className: "size-3", "aria-hidden": "true" }),
52
+ delta.value >= 0 ? "+" : "",
53
+ formatUsd(Math.abs(delta.value)),
54
+ " ",
55
+ /* @__PURE__ */ jsx("span", { className: "text-muted-foreground", children: delta.period })
56
+ ]
57
+ }
58
+ ) : null
59
+ ] }),
60
+ /* @__PURE__ */ jsxs("div", { className: "flex items-baseline gap-1.5", children: [
61
+ /* @__PURE__ */ jsx("span", { className: "font-bold font-display text-display-md text-foreground tabular-nums leading-none", children: formatUsd(cost) }),
62
+ budget !== void 0 ? /* @__PURE__ */ jsxs("span", { className: "font-mono text-body-sm text-muted-foreground", children: [
63
+ "of ",
64
+ formatUsd(budget)
65
+ ] }) : null
66
+ ] }),
67
+ budget !== void 0 ? /* @__PURE__ */ jsxs("div", { className: "grid gap-1", children: [
68
+ /* @__PURE__ */ jsx(
69
+ "div",
70
+ {
71
+ className: "h-1.5 w-full overflow-hidden rounded-full bg-muted",
72
+ role: "progressbar",
73
+ tabIndex: -1,
74
+ "aria-valuenow": percent,
75
+ "aria-valuemin": 0,
76
+ "aria-valuemax": 100,
77
+ children: /* @__PURE__ */ jsx(
78
+ "div",
79
+ {
80
+ className: cn(
81
+ "h-full rounded-full transition-[width,background-color]",
82
+ overBudget ? "bg-destructive" : ratio > 0.75 ? "bg-warning" : "bg-primary"
83
+ ),
84
+ style: { width: `${Math.min(100, percent)}%` }
85
+ }
86
+ )
87
+ }
88
+ ),
89
+ /* @__PURE__ */ jsxs("span", { className: "font-mono text-label text-muted-foreground tabular-nums", children: [
90
+ percent,
91
+ "% of budget ",
92
+ overBudget ? "\xB7 over!" : "used"
93
+ ] })
94
+ ] }) : null
95
+ ]
96
+ }
97
+ );
98
+ }
99
+ );
100
+ CostMeter.displayName = "CostMeter";
101
+
102
+ export { CostMeter };
103
+ //# sourceMappingURL=chunk-LKYSX3QF.js.map
104
+ //# sourceMappingURL=chunk-LKYSX3QF.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/primitives/cost-meter/cost-meter.tsx"],"names":[],"mappings":"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","file":"chunk-LKYSX3QF.js","sourcesContent":["import { Coins, TrendingDown, TrendingUp } from \"lucide-react\";\nimport { forwardRef } from \"react\";\nimport type { HTMLAttributes, ReactNode } from \"react\";\nimport { cn } from \"../../../lib/cn.js\";\n\ninterface CostMeterProps extends Omit<HTMLAttributes<HTMLDivElement>, \"title\"> {\n /** Current cost in USD. */\n cost: number;\n /** Optional monthly budget; renders progress bar when present. */\n budget?: number;\n /** Optional title (e.g. \"This session\", \"Monthly\"). */\n title?: ReactNode;\n /** Optional delta vs previous period. */\n delta?: { value: number; period: string };\n /** Compact mode — single-line summary. */\n compact?: boolean;\n}\n\nconst formatUsd = (n: number) =>\n n >= 100 ? `$${n.toFixed(0)}` : n >= 10 ? `$${n.toFixed(1)}` : `$${n.toFixed(2)}`;\n\n/**\n * CostMeter — gauge for token spend. Two visuals:\n * - card: title + big number + optional progress bar + optional delta.\n * - compact: chip \"Coins $4.20\" for nav bars.\n */\nconst CostMeter = forwardRef<HTMLDivElement, CostMeterProps>(\n ({ className, cost, budget, title = \"Spend\", delta, compact, ...props }, ref) => {\n if (compact) {\n return (\n <div\n ref={ref}\n className={cn(\n \"inline-flex items-center gap-1.5 rounded-full border border-border/60 bg-card px-2.5 py-1\",\n \"font-mono text-label\",\n className,\n )}\n {...props}\n >\n <Coins className=\"size-3 text-primary\" aria-hidden=\"true\" />\n <span className=\"text-foreground tabular-nums\">{formatUsd(cost)}</span>\n {budget ? <span className=\"text-muted-foreground\">/ {formatUsd(budget)}</span> : null}\n </div>\n );\n }\n\n const ratio = budget ? Math.max(0, Math.min(1, cost / budget)) : 0;\n const percent = Math.round(ratio * 100);\n const overBudget = budget !== undefined && cost > budget;\n\n return (\n <div\n ref={ref}\n className={cn(\"grid gap-2 rounded-xl border bg-card p-4\", className)}\n {...props}\n >\n <header className=\"flex items-baseline justify-between\">\n <span className=\"font-mono text-label-caps text-muted-foreground uppercase tracking-wider\">\n {title}\n </span>\n {delta ? (\n <span\n className={cn(\n \"inline-flex items-center gap-1 font-mono text-body-sm tabular-nums\",\n delta.value >= 0 ? \"text-warning\" : \"text-success\",\n )}\n >\n {delta.value >= 0 ? (\n <TrendingUp className=\"size-3\" aria-hidden=\"true\" />\n ) : (\n <TrendingDown className=\"size-3\" aria-hidden=\"true\" />\n )}\n {delta.value >= 0 ? \"+\" : \"\"}\n {formatUsd(Math.abs(delta.value))}{\" \"}\n <span className=\"text-muted-foreground\">{delta.period}</span>\n </span>\n ) : null}\n </header>\n <div className=\"flex items-baseline gap-1.5\">\n <span className=\"font-bold font-display text-display-md text-foreground tabular-nums leading-none\">\n {formatUsd(cost)}\n </span>\n {budget !== undefined ? (\n <span className=\"font-mono text-body-sm text-muted-foreground\">\n of {formatUsd(budget)}\n </span>\n ) : null}\n </div>\n {budget !== undefined ? (\n <div className=\"grid gap-1\">\n <div\n className=\"h-1.5 w-full overflow-hidden rounded-full bg-muted\"\n role=\"progressbar\"\n tabIndex={-1}\n aria-valuenow={percent}\n aria-valuemin={0}\n aria-valuemax={100}\n >\n <div\n className={cn(\n \"h-full rounded-full transition-[width,background-color]\",\n overBudget ? \"bg-destructive\" : ratio > 0.75 ? \"bg-warning\" : \"bg-primary\",\n )}\n style={{ width: `${Math.min(100, percent)}%` }}\n />\n </div>\n <span className=\"font-mono text-label text-muted-foreground tabular-nums\">\n {percent}% of budget {overBudget ? \"· over!\" : \"used\"}\n </span>\n </div>\n ) : null}\n </div>\n );\n },\n);\nCostMeter.displayName = \"CostMeter\";\n\nexport { CostMeter };\n"]}
@@ -0,0 +1,54 @@
1
+ import { cn } from './chunk-ZSRJCIWF.js';
2
+ import { FileText, FileCode, FileSpreadsheet, FileImage, File, X } from 'lucide-react';
3
+ import { forwardRef } from 'react';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ var typeIcon = {
7
+ image: FileImage,
8
+ spreadsheet: FileSpreadsheet,
9
+ code: FileCode,
10
+ text: FileText
11
+ };
12
+ var AttachmentChip = forwardRef(
13
+ ({ className, attachment, onRemove, ...props }, ref) => {
14
+ const Icon = (attachment.type ? typeIcon[attachment.type] : void 0) ?? File;
15
+ return /* @__PURE__ */ jsxs(
16
+ "div",
17
+ {
18
+ ref,
19
+ className: cn(
20
+ "inline-flex max-w-[18rem] items-center gap-2 rounded-md border border-border/40 bg-muted/60 px-2 py-1",
21
+ "font-mono text-code-sm text-muted-foreground",
22
+ className
23
+ ),
24
+ ...props,
25
+ children: [
26
+ /* @__PURE__ */ jsx(Icon, { className: "size-3.5 shrink-0 text-primary", "aria-hidden": "true" }),
27
+ /* @__PURE__ */ jsx("span", { className: "truncate text-foreground", title: attachment.name, children: attachment.name }),
28
+ attachment.size ? /* @__PURE__ */ jsxs("span", { children: [
29
+ "\xB7 ",
30
+ attachment.size
31
+ ] }) : null,
32
+ onRemove ? /* @__PURE__ */ jsx(
33
+ "button",
34
+ {
35
+ type: "button",
36
+ onClick: () => onRemove(attachment.id),
37
+ "aria-label": `Remove ${attachment.name}`,
38
+ className: cn(
39
+ "ml-1 rounded-sm p-0.5 text-muted-foreground transition-colors hover:bg-muted hover:text-destructive",
40
+ "focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring"
41
+ ),
42
+ children: /* @__PURE__ */ jsx(X, { className: "size-3" })
43
+ }
44
+ ) : null
45
+ ]
46
+ }
47
+ );
48
+ }
49
+ );
50
+ AttachmentChip.displayName = "AttachmentChip";
51
+
52
+ export { AttachmentChip };
53
+ //# sourceMappingURL=chunk-MCIFB6VS.js.map
54
+ //# sourceMappingURL=chunk-MCIFB6VS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/primitives/attachment-chip/attachment-chip.tsx"],"names":[],"mappings":";;;;;AAOA,IAAM,QAAA,GAA0C;AAAA,EAC9C,KAAA,EAAO,SAAA;AAAA,EACP,WAAA,EAAa,eAAA;AAAA,EACb,IAAA,EAAM,QAAA;AAAA,EACN,IAAA,EAAM;AACR,CAAA;AAaA,IAAM,cAAA,GAAiB,UAAA;AAAA,EACrB,CAAC,EAAE,SAAA,EAAW,UAAA,EAAY,UAAU,GAAG,KAAA,IAAS,GAAA,KAAQ;AACtD,IAAA,MAAM,QAAuB,UAAA,CAAW,IAAA,GAAO,SAAS,UAAA,CAAW,IAAI,IAAI,MAAA,KAAc,IAAA;AACzF,IAAA,uBACE,IAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,GAAA;AAAA,QACA,SAAA,EAAW,EAAA;AAAA,UACT,uGAAA;AAAA,UACA,8CAAA;AAAA,UACA;AAAA,SACF;AAAA,QACC,GAAG,KAAA;AAAA,QAEJ,QAAA,EAAA;AAAA,0BAAA,GAAA,CAAC,IAAA,EAAA,EAAK,SAAA,EAAU,gCAAA,EAAiC,aAAA,EAAY,MAAA,EAAO,CAAA;AAAA,0BACpE,GAAA,CAAC,UAAK,SAAA,EAAU,0BAAA,EAA2B,OAAO,UAAA,CAAW,IAAA,EAC1D,qBAAW,IAAA,EACd,CAAA;AAAA,UACC,UAAA,CAAW,IAAA,mBAAO,IAAA,CAAC,MAAA,EAAA,EAAK,QAAA,EAAA;AAAA,YAAA,OAAA;AAAA,YAAG,UAAA,CAAW;AAAA,WAAA,EAAK,CAAA,GAAU,IAAA;AAAA,UACrD,QAAA,mBACC,GAAA;AAAA,YAAC,QAAA;AAAA,YAAA;AAAA,cACC,IAAA,EAAK,QAAA;AAAA,cACL,OAAA,EAAS,MAAM,QAAA,CAAS,UAAA,CAAW,EAAE,CAAA;AAAA,cACrC,YAAA,EAAY,CAAA,OAAA,EAAU,UAAA,CAAW,IAAI,CAAA,CAAA;AAAA,cACrC,SAAA,EAAW,EAAA;AAAA,gBACT,qGAAA;AAAA,gBACA;AAAA,eACF;AAAA,cAEA,QAAA,kBAAA,GAAA,CAAC,CAAA,EAAA,EAAE,SAAA,EAAU,QAAA,EAAS;AAAA;AAAA,WACxB,GACE;AAAA;AAAA;AAAA,KACN;AAAA,EAEJ;AACF;AACA,cAAA,CAAe,WAAA,GAAc,gBAAA","file":"chunk-MCIFB6VS.js","sourcesContent":["import { File, FileCode, FileImage, FileSpreadsheet, FileText, X } from \"lucide-react\";\nimport { forwardRef } from \"react\";\nimport type { HTMLAttributes } from \"react\";\nimport { cn } from \"../../../lib/cn.js\";\nimport type { IconComponent } from \"../../../lib/types.js\";\nimport type { Attachment } from \"../../../types/chat.js\";\n\nconst typeIcon: Record<string, IconComponent> = {\n image: FileImage,\n spreadsheet: FileSpreadsheet,\n code: FileCode,\n text: FileText,\n};\n\ninterface AttachmentChipProps extends HTMLAttributes<HTMLDivElement> {\n attachment: Attachment;\n onRemove?: (id: string) => void;\n}\n\n/**\n * AttachmentChip — file pill shown in chat composer or message attachments row.\n *\n * Visual: rounded chip with type-icon + name + size + optional remove button.\n * Truncates the name with `text-ellipsis`; full name available via title.\n */\nconst AttachmentChip = forwardRef<HTMLDivElement, AttachmentChipProps>(\n ({ className, attachment, onRemove, ...props }, ref) => {\n const Icon: IconComponent = (attachment.type ? typeIcon[attachment.type] : undefined) ?? File;\n return (\n <div\n ref={ref}\n className={cn(\n \"inline-flex max-w-[18rem] items-center gap-2 rounded-md border border-border/40 bg-muted/60 px-2 py-1\",\n \"font-mono text-code-sm text-muted-foreground\",\n className,\n )}\n {...props}\n >\n <Icon className=\"size-3.5 shrink-0 text-primary\" aria-hidden=\"true\" />\n <span className=\"truncate text-foreground\" title={attachment.name}>\n {attachment.name}\n </span>\n {attachment.size ? <span>· {attachment.size}</span> : null}\n {onRemove ? (\n <button\n type=\"button\"\n onClick={() => onRemove(attachment.id)}\n aria-label={`Remove ${attachment.name}`}\n className={cn(\n \"ml-1 rounded-sm p-0.5 text-muted-foreground transition-colors hover:bg-muted hover:text-destructive\",\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring\",\n )}\n >\n <X className=\"size-3\" />\n </button>\n ) : null}\n </div>\n );\n },\n);\nAttachmentChip.displayName = \"AttachmentChip\";\n\nexport { AttachmentChip };\n"]}
@@ -0,0 +1,84 @@
1
+ import { cn } from './chunk-ZSRJCIWF.js';
2
+ import { forwardRef, useEffect } from 'react';
3
+ import { jsx, jsxs } from 'react/jsx-runtime';
4
+
5
+ var DOT_COLOR = {
6
+ live: "bg-success",
7
+ building: "bg-warning",
8
+ failed: "bg-destructive",
9
+ idle: "bg-muted-foreground/40",
10
+ warning: "bg-warning"
11
+ };
12
+ var LABEL_COLOR = {
13
+ live: "text-success",
14
+ building: "text-warning",
15
+ failed: "text-destructive",
16
+ idle: "text-muted-foreground",
17
+ warning: "text-warning"
18
+ };
19
+ var SIZE = {
20
+ xs: "size-1.5",
21
+ sm: "size-2",
22
+ md: "size-2.5"
23
+ };
24
+ var StatusDot = forwardRef(
25
+ ({ className, status, label, size = "sm", pulse, "aria-label": ariaLabel, ...props }, ref) => {
26
+ const shouldPulse = pulse ?? status === "building";
27
+ const hasVisibleLabel = label !== void 0 && label !== null;
28
+ const effectiveAriaLabel = ariaLabel ?? (hasVisibleLabel ? void 0 : status);
29
+ useEffect(() => {
30
+ if (process.env.NODE_ENV !== "production" && !hasVisibleLabel && ariaLabel === void 0) {
31
+ console.warn(
32
+ `<StatusDot status="${status}" />: no \`label\` or \`aria-label\` provided. Color-only status is invisible to screen readers. Falling back to aria-label="${status}".`
33
+ );
34
+ }
35
+ }, [hasVisibleLabel, ariaLabel, status]);
36
+ const dot = /* @__PURE__ */ jsx(
37
+ "span",
38
+ {
39
+ "aria-hidden": hasVisibleLabel ? "true" : void 0,
40
+ className: cn(
41
+ "inline-block shrink-0 rounded-full",
42
+ SIZE[size],
43
+ DOT_COLOR[status],
44
+ shouldPulse && "animate-pulse"
45
+ )
46
+ }
47
+ );
48
+ if (!hasVisibleLabel) {
49
+ return /* @__PURE__ */ jsx(
50
+ "span",
51
+ {
52
+ ref,
53
+ role: "status",
54
+ "aria-label": effectiveAriaLabel,
55
+ className: cn("inline-flex items-center", className),
56
+ ...props,
57
+ children: dot
58
+ }
59
+ );
60
+ }
61
+ return /* @__PURE__ */ jsxs(
62
+ "span",
63
+ {
64
+ ref,
65
+ "aria-label": effectiveAriaLabel,
66
+ className: cn(
67
+ "inline-flex items-center gap-1.5 font-mono text-label",
68
+ LABEL_COLOR[status],
69
+ className
70
+ ),
71
+ ...props,
72
+ children: [
73
+ dot,
74
+ /* @__PURE__ */ jsx("span", { children: label })
75
+ ]
76
+ }
77
+ );
78
+ }
79
+ );
80
+ StatusDot.displayName = "StatusDot";
81
+
82
+ export { StatusDot };
83
+ //# sourceMappingURL=chunk-NQZYY4LR.js.map
84
+ //# sourceMappingURL=chunk-NQZYY4LR.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/primitives/status-dot/status-dot.tsx"],"names":[],"mappings":";;;;AAkCA,IAAM,SAAA,GAAwC;AAAA,EAC5C,IAAA,EAAM,YAAA;AAAA,EACN,QAAA,EAAU,YAAA;AAAA,EACV,MAAA,EAAQ,gBAAA;AAAA,EACR,IAAA,EAAM,wBAAA;AAAA,EACN,OAAA,EAAS;AACX,CAAA;AAEA,IAAM,WAAA,GAA0C;AAAA,EAC9C,IAAA,EAAM,cAAA;AAAA,EACN,QAAA,EAAU,cAAA;AAAA,EACV,MAAA,EAAQ,kBAAA;AAAA,EACR,IAAA,EAAM,uBAAA;AAAA,EACN,OAAA,EAAS;AACX,CAAA;AAEA,IAAM,IAAA,GAA4D;AAAA,EAChE,EAAA,EAAI,UAAA;AAAA,EACJ,EAAA,EAAI,QAAA;AAAA,EACJ,EAAA,EAAI;AACN,CAAA;AAEA,IAAM,SAAA,GAAY,UAAA;AAAA,EAChB,CAAC,EAAE,SAAA,EAAW,MAAA,EAAQ,KAAA,EAAO,IAAA,GAAO,IAAA,EAAM,KAAA,EAAO,YAAA,EAAc,SAAA,EAAW,GAAG,KAAA,IAAS,GAAA,KAAQ;AAC5F,IAAA,MAAM,WAAA,GAAc,SAAS,MAAA,KAAW,UAAA;AAExC,IAAA,MAAM,eAAA,GAAkB,KAAA,KAAU,MAAA,IAAa,KAAA,KAAU,IAAA;AACzD,IAAA,MAAM,kBAAA,GAAqB,SAAA,KAAc,eAAA,GAAkB,MAAA,GAAY,MAAA,CAAA;AAGvE,IAAA,SAAA,CAAU,MAAM;AACd,MAAA,IAAI,QAAQ,GAAA,CAAI,QAAA,KAAa,gBAAgB,CAAC,eAAA,IAAmB,cAAc,MAAA,EAAW;AAExF,QAAA,OAAA,CAAQ,IAAA;AAAA,UACN,CAAA,mBAAA,EAAsB,MAAM,CAAA,6HAAA,EAAgI,MAAM,CAAA,EAAA;AAAA,SACpK;AAAA,MACF;AAAA,IACF,CAAA,EAAG,CAAC,eAAA,EAAiB,SAAA,EAAW,MAAM,CAAC,CAAA;AAEvC,IAAA,MAAM,GAAA,mBACJ,GAAA;AAAA,MAAC,MAAA;AAAA,MAAA;AAAA,QACC,aAAA,EAAa,kBAAkB,MAAA,GAAS,MAAA;AAAA,QACxC,SAAA,EAAW,EAAA;AAAA,UACT,oCAAA;AAAA,UACA,KAAK,IAAI,CAAA;AAAA,UACT,UAAU,MAAM,CAAA;AAAA,UAChB,WAAA,IAAe;AAAA;AACjB;AAAA,KACF;AAGF,IAAA,IAAI,CAAC,eAAA,EAAiB;AACpB,MAAA,uBACE,GAAA;AAAA,QAAC,MAAA;AAAA,QAAA;AAAA,UACC,GAAA;AAAA,UAEA,IAAA,EAAK,QAAA;AAAA,UACL,YAAA,EAAY,kBAAA;AAAA,UACZ,SAAA,EAAW,EAAA,CAAG,0BAAA,EAA4B,SAAS,CAAA;AAAA,UAClD,GAAG,KAAA;AAAA,UAEH,QAAA,EAAA;AAAA;AAAA,OACH;AAAA,IAEJ;AAEA,IAAA,uBACE,IAAA;AAAA,MAAC,MAAA;AAAA,MAAA;AAAA,QACC,GAAA;AAAA,QACA,YAAA,EAAY,kBAAA;AAAA,QACZ,SAAA,EAAW,EAAA;AAAA,UACT,uDAAA;AAAA,UACA,YAAY,MAAM,CAAA;AAAA,UAClB;AAAA,SACF;AAAA,QACC,GAAG,KAAA;AAAA,QAEH,QAAA,EAAA;AAAA,UAAA,GAAA;AAAA,0BACD,GAAA,CAAC,UAAM,QAAA,EAAA,KAAA,EAAM;AAAA;AAAA;AAAA,KACf;AAAA,EAEJ;AACF;AACA,SAAA,CAAU,WAAA,GAAc,WAAA","file":"chunk-NQZYY4LR.js","sourcesContent":["import { forwardRef, useEffect } from \"react\";\nimport type { HTMLAttributes, ReactNode } from \"react\";\nimport { cn } from \"../../../lib/cn.js\";\n\n/**\n * StatusDot — semantic status indicator (colored circle + optional label).\n *\n * Five status kinds:\n * - `live` — deployed / verified / healthy (success)\n * - `building` — in-progress / queued (warning, auto-pulses)\n * - `failed` — error / down / rejected (destructive)\n * - `idle` — pending / offline (muted)\n * - `warning` — degraded but functional (warning, static)\n *\n * Three sizes (xs 6px, sm 8px default, md 10px). `pulse` defaults to\n * `true` for `building` and `false` otherwise; passing `pulse` explicitly\n * overrides the auto behavior. When no visible `label` AND no `aria-label`\n * are provided, the component auto-applies `aria-label={status}` and\n * emits a dev-mode warning (a status communicated only by color is\n * invisible to screen readers).\n *\n * @example\n * <StatusDot status=\"live\" label=\"Production\" />\n * <StatusDot status=\"building\" /> // auto-pulses + auto-aria-label\n */\nexport type StatusKind = \"live\" | \"building\" | \"failed\" | \"idle\" | \"warning\";\n\nexport interface StatusDotProps extends Omit<HTMLAttributes<HTMLSpanElement>, \"children\"> {\n status: StatusKind;\n label?: ReactNode;\n size?: \"xs\" | \"sm\" | \"md\";\n pulse?: boolean;\n}\n\nconst DOT_COLOR: Record<StatusKind, string> = {\n live: \"bg-success\",\n building: \"bg-warning\",\n failed: \"bg-destructive\",\n idle: \"bg-muted-foreground/40\",\n warning: \"bg-warning\",\n};\n\nconst LABEL_COLOR: Record<StatusKind, string> = {\n live: \"text-success\",\n building: \"text-warning\",\n failed: \"text-destructive\",\n idle: \"text-muted-foreground\",\n warning: \"text-warning\",\n};\n\nconst SIZE: Record<NonNullable<StatusDotProps[\"size\"]>, string> = {\n xs: \"size-1.5\",\n sm: \"size-2\",\n md: \"size-2.5\",\n};\n\nconst StatusDot = forwardRef<HTMLSpanElement, StatusDotProps>(\n ({ className, status, label, size = \"sm\", pulse, \"aria-label\": ariaLabel, ...props }, ref) => {\n const shouldPulse = pulse ?? status === \"building\";\n\n const hasVisibleLabel = label !== undefined && label !== null;\n const effectiveAriaLabel = ariaLabel ?? (hasVisibleLabel ? undefined : status);\n\n // EC-6: dev warning when neither label nor aria-label is provided.\n useEffect(() => {\n if (process.env.NODE_ENV !== \"production\" && !hasVisibleLabel && ariaLabel === undefined) {\n // biome-ignore lint/suspicious/noConsole: dev-only diagnostic for a11y misconfiguration.\n console.warn(\n `<StatusDot status=\"${status}\" />: no \\`label\\` or \\`aria-label\\` provided. Color-only status is invisible to screen readers. Falling back to aria-label=\"${status}\".`,\n );\n }\n }, [hasVisibleLabel, ariaLabel, status]);\n\n const dot = (\n <span\n aria-hidden={hasVisibleLabel ? \"true\" : undefined}\n className={cn(\n \"inline-block shrink-0 rounded-full\",\n SIZE[size],\n DOT_COLOR[status],\n shouldPulse && \"animate-pulse\",\n )}\n />\n );\n\n if (!hasVisibleLabel) {\n return (\n <span\n ref={ref}\n // biome-ignore lint/a11y/useSemanticElements: StatusDot is a generic inline indicator; there is no HTML element with implicit role=\"status\" that is an inline span. The native <output> is block-level and form-bound, which doesn't fit this use case.\n role=\"status\"\n aria-label={effectiveAriaLabel}\n className={cn(\"inline-flex items-center\", className)}\n {...props}\n >\n {dot}\n </span>\n );\n }\n\n return (\n <span\n ref={ref}\n aria-label={effectiveAriaLabel}\n className={cn(\n \"inline-flex items-center gap-1.5 font-mono text-label\",\n LABEL_COLOR[status],\n className,\n )}\n {...props}\n >\n {dot}\n <span>{label}</span>\n </span>\n );\n },\n);\nStatusDot.displayName = \"StatusDot\";\n\nexport { StatusDot };\n"]}
@@ -0,0 +1,66 @@
1
+ import { cn } from './chunk-ZSRJCIWF.js';
2
+ import { cva } from 'class-variance-authority';
3
+ import { forwardRef } from 'react';
4
+ import { jsx } from 'react/jsx-runtime';
5
+
6
+ var badgeVariants = cva(
7
+ [
8
+ "inline-flex items-center gap-1.5 rounded-full border",
9
+ "font-sans uppercase tracking-wider",
10
+ "transition-colors"
11
+ ],
12
+ {
13
+ variants: {
14
+ variant: {
15
+ default: "border-border/40 bg-muted text-muted-foreground",
16
+ primary: "border-primary/30 bg-primary/10 text-primary",
17
+ accent: "border-accent/40 bg-accent/15 text-accent",
18
+ success: "border-success/40 bg-success/15 text-success",
19
+ warning: "border-warning/40 bg-warning/15 text-warning",
20
+ destructive: "border-destructive/40 bg-destructive/15 text-destructive",
21
+ outline: "border-border bg-transparent text-foreground"
22
+ },
23
+ size: {
24
+ sm: "px-2 py-0.5 text-label-caps",
25
+ md: "px-2.5 py-0.5 text-label",
26
+ lg: "px-3 py-1 text-body-md"
27
+ }
28
+ },
29
+ defaultVariants: { variant: "default", size: "md" }
30
+ }
31
+ );
32
+ var Badge = forwardRef(
33
+ ({ className, variant, size, ...props }, ref) => /* @__PURE__ */ jsx("span", { ref, className: cn(badgeVariants({ variant, size }), className), ...props })
34
+ );
35
+ Badge.displayName = "Badge";
36
+ var toneClass = {
37
+ primary: "bg-primary",
38
+ accent: "bg-accent",
39
+ success: "bg-success",
40
+ warning: "bg-warning",
41
+ destructive: "bg-destructive",
42
+ muted: "bg-muted-foreground"
43
+ };
44
+ var Dot = forwardRef(
45
+ ({ className, pulse = false, tone = "success", ...props }, ref) => /* @__PURE__ */ jsx(
46
+ "span",
47
+ {
48
+ ref,
49
+ "aria-hidden": "true",
50
+ className: cn(
51
+ "inline-block size-1.5 rounded-full",
52
+ toneClass[tone],
53
+ pulse && "animate-pulse-glow",
54
+ className
55
+ ),
56
+ ...props
57
+ }
58
+ )
59
+ );
60
+ Dot.displayName = "Badge.Dot";
61
+ var BadgeWithDot = Badge;
62
+ BadgeWithDot.Dot = Dot;
63
+
64
+ export { BadgeWithDot, badgeVariants };
65
+ //# sourceMappingURL=chunk-O23LKHUR.js.map
66
+ //# sourceMappingURL=chunk-O23LKHUR.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/primitives/badge/badge.tsx"],"names":[],"mappings":";;;;;AAoBA,IAAM,aAAA,GAAgB,GAAA;AAAA,EACpB;AAAA,IACE,sDAAA;AAAA,IACA,oCAAA;AAAA,IACA;AAAA,GACF;AAAA,EACA;AAAA,IACE,QAAA,EAAU;AAAA,MACR,OAAA,EAAS;AAAA,QACP,OAAA,EAAS,iDAAA;AAAA,QACT,OAAA,EAAS,8CAAA;AAAA,QACT,MAAA,EAAQ,2CAAA;AAAA,QACR,OAAA,EAAS,8CAAA;AAAA,QACT,OAAA,EAAS,8CAAA;AAAA,QACT,WAAA,EAAa,0DAAA;AAAA,QACb,OAAA,EAAS;AAAA,OACX;AAAA,MACA,IAAA,EAAM;AAAA,QACJ,EAAA,EAAI,6BAAA;AAAA,QACJ,EAAA,EAAI,0BAAA;AAAA,QACJ,EAAA,EAAI;AAAA;AACN,KACF;AAAA,IACA,eAAA,EAAiB,EAAE,OAAA,EAAS,SAAA,EAAW,MAAM,IAAA;AAAK;AAEtD;AAMA,IAAM,KAAA,GAAQ,UAAA;AAAA,EACZ,CAAC,EAAE,SAAA,EAAW,OAAA,EAAS,MAAM,GAAG,KAAA,EAAM,EAAG,GAAA,qBACvC,GAAA,CAAC,MAAA,EAAA,EAAK,KAAU,SAAA,EAAW,EAAA,CAAG,aAAA,CAAc,EAAE,OAAA,EAAS,IAAA,EAAM,CAAA,EAAG,SAAS,CAAA,EAAI,GAAG,KAAA,EAAO;AAE3F,CAAA;AACA,KAAA,CAAM,WAAA,GAAc,OAAA;AAOpB,IAAM,SAAA,GAAgE;AAAA,EACpE,OAAA,EAAS,YAAA;AAAA,EACT,MAAA,EAAQ,WAAA;AAAA,EACR,OAAA,EAAS,YAAA;AAAA,EACT,OAAA,EAAS,YAAA;AAAA,EACT,WAAA,EAAa,gBAAA;AAAA,EACb,KAAA,EAAO;AACT,CAAA;AAEA,IAAM,GAAA,GAAM,UAAA;AAAA,EACV,CAAC,EAAE,SAAA,EAAW,KAAA,GAAQ,KAAA,EAAO,OAAO,SAAA,EAAW,GAAG,KAAA,EAAM,EAAG,GAAA,qBACzD,GAAA;AAAA,IAAC,MAAA;AAAA,IAAA;AAAA,MACC,GAAA;AAAA,MACA,aAAA,EAAY,MAAA;AAAA,MACZ,SAAA,EAAW,EAAA;AAAA,QACT,oCAAA;AAAA,QACA,UAAU,IAAI,CAAA;AAAA,QACd,KAAA,IAAS,oBAAA;AAAA,QACT;AAAA,OACF;AAAA,MACC,GAAG;AAAA;AAAA;AAGV,CAAA;AACA,GAAA,CAAI,WAAA,GAAc,WAAA;AAElB,IAAM,YAAA,GAAe;AACrB,YAAA,CAAa,GAAA,GAAM,GAAA","file":"chunk-O23LKHUR.js","sourcesContent":["import { type VariantProps, cva } from \"class-variance-authority\";\nimport { forwardRef } from \"react\";\nimport type { HTMLAttributes } from \"react\";\nimport { cn } from \"../../../lib/cn.js\";\n\n/**\n * Badge — small status / tag indicator.\n *\n * Variants:\n * - default muted surface, hairline border\n * - primary violet outline + soft violet bg\n * - accent burnt sienna (celebration / pro / beta)\n * - success deploy succeeded\n * - warning attention needed\n * - destructive failed\n * - outline transparent, just border\n *\n * Status dots are inlined via `<Badge.Dot />` for things like \"Building…\",\n * \"Running\", \"Failed\" rows in deployment lists.\n */\nconst badgeVariants = cva(\n [\n \"inline-flex items-center gap-1.5 rounded-full border\",\n \"font-sans uppercase tracking-wider\",\n \"transition-colors\",\n ],\n {\n variants: {\n variant: {\n default: \"border-border/40 bg-muted text-muted-foreground\",\n primary: \"border-primary/30 bg-primary/10 text-primary\",\n accent: \"border-accent/40 bg-accent/15 text-accent\",\n success: \"border-success/40 bg-success/15 text-success\",\n warning: \"border-warning/40 bg-warning/15 text-warning\",\n destructive: \"border-destructive/40 bg-destructive/15 text-destructive\",\n outline: \"border-border bg-transparent text-foreground\",\n },\n size: {\n sm: \"px-2 py-0.5 text-label-caps\",\n md: \"px-2.5 py-0.5 text-label\",\n lg: \"px-3 py-1 text-body-md\",\n },\n },\n defaultVariants: { variant: \"default\", size: \"md\" },\n },\n);\n\nexport interface BadgeProps\n extends HTMLAttributes<HTMLSpanElement>,\n VariantProps<typeof badgeVariants> {}\n\nconst Badge = forwardRef<HTMLSpanElement, BadgeProps>(\n ({ className, variant, size, ...props }, ref) => (\n <span ref={ref} className={cn(badgeVariants({ variant, size }), className)} {...props} />\n ),\n);\nBadge.displayName = \"Badge\";\n\ninterface BadgeDotProps extends HTMLAttributes<HTMLSpanElement> {\n pulse?: boolean;\n tone?: \"primary\" | \"accent\" | \"success\" | \"warning\" | \"destructive\" | \"muted\";\n}\n\nconst toneClass: Record<NonNullable<BadgeDotProps[\"tone\"]>, string> = {\n primary: \"bg-primary\",\n accent: \"bg-accent\",\n success: \"bg-success\",\n warning: \"bg-warning\",\n destructive: \"bg-destructive\",\n muted: \"bg-muted-foreground\",\n};\n\nconst Dot = forwardRef<HTMLSpanElement, BadgeDotProps>(\n ({ className, pulse = false, tone = \"success\", ...props }, ref) => (\n <span\n ref={ref}\n aria-hidden=\"true\"\n className={cn(\n \"inline-block size-1.5 rounded-full\",\n toneClass[tone],\n pulse && \"animate-pulse-glow\",\n className,\n )}\n {...props}\n />\n ),\n);\nDot.displayName = \"Badge.Dot\";\n\nconst BadgeWithDot = Badge as typeof Badge & { Dot: typeof Dot };\nBadgeWithDot.Dot = Dot;\n\nexport { BadgeWithDot as Badge, badgeVariants };\n"]}
@@ -0,0 +1,23 @@
1
+ import { LiveRegionProvider } from './chunk-UGKI466V.js';
2
+ import { cn } from './chunk-ZSRJCIWF.js';
3
+ import { forwardRef } from 'react';
4
+ import { jsx } from 'react/jsx-runtime';
5
+
6
+ var ChatThread = forwardRef(
7
+ ({ className, ...props }, ref) => /* @__PURE__ */ jsx(LiveRegionProvider, { value: true, children: /* @__PURE__ */ jsx(
8
+ "div",
9
+ {
10
+ ref,
11
+ role: "log",
12
+ "aria-live": "polite",
13
+ "aria-relevant": "additions",
14
+ className: cn("flex flex-col gap-6", className),
15
+ ...props
16
+ }
17
+ ) })
18
+ );
19
+ ChatThread.displayName = "ChatThread";
20
+
21
+ export { ChatThread };
22
+ //# sourceMappingURL=chunk-PASI2U2R.js.map
23
+ //# sourceMappingURL=chunk-PASI2U2R.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/primitives/chat-thread/chat-thread.tsx"],"names":[],"mappings":";;;;;AAcA,IAAM,UAAA,GAAa,UAAA;AAAA,EACjB,CAAC,EAAE,SAAA,EAAW,GAAG,KAAA,IAAS,GAAA,qBACxB,GAAA,CAAC,kBAAA,EAAA,EAAmB,KAAA,EAAO,IAAA,EACzB,QAAA,kBAAA,GAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,GAAA;AAAA,MACA,IAAA,EAAK,KAAA;AAAA,MACL,WAAA,EAAU,QAAA;AAAA,MACV,eAAA,EAAc,WAAA;AAAA,MACd,SAAA,EAAW,EAAA,CAAG,qBAAA,EAAuB,SAAS,CAAA;AAAA,MAC7C,GAAG;AAAA;AAAA,GACN,EACF;AAEJ;AACA,UAAA,CAAW,WAAA,GAAc,YAAA","file":"chunk-PASI2U2R.js","sourcesContent":["import { forwardRef } from \"react\";\nimport type { HTMLAttributes } from \"react\";\nimport { cn } from \"../../../lib/cn.js\";\nimport { LiveRegionProvider } from \"../../../lib/live-region-context.js\";\n\n/**\n * ChatThread — simple vertical container that applies spacing + scroll.\n *\n * No virtualization or stickiness. Wrap with your own scroller for long threads.\n *\n * T4.1 (MF-4): declares the outer live region and wraps children in\n * LiveRegionProvider so nested AgentStreaming / AgentErrorCard / Skeleton\n * don't add their own aria-live (double-announcement avoided).\n */\nconst ChatThread = forwardRef<HTMLDivElement, HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <LiveRegionProvider value={true}>\n <div\n ref={ref}\n role=\"log\"\n aria-live=\"polite\"\n aria-relevant=\"additions\"\n className={cn(\"flex flex-col gap-6\", className)}\n {...props}\n />\n </LiveRegionProvider>\n ),\n);\nChatThread.displayName = \"ChatThread\";\n\nexport { ChatThread };\n"]}
@@ -0,0 +1,34 @@
1
+ import { cn } from './chunk-ZSRJCIWF.js';
2
+ import { Folder, ChevronDown } from 'lucide-react';
3
+ import { forwardRef } from 'react';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ var FolderSelector = forwardRef(
7
+ ({ className, path, compact, ...props }, ref) => /* @__PURE__ */ jsxs(
8
+ "button",
9
+ {
10
+ ref,
11
+ type: "button",
12
+ className: cn(
13
+ "inline-flex items-center gap-2 rounded-lg border border-border/60 bg-card",
14
+ "font-mono text-code-sm text-foreground",
15
+ "transition-colors duration-base ease-out-soft",
16
+ "hover:border-primary/40 hover:bg-muted",
17
+ "focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-offset-background",
18
+ compact ? "h-8 px-2.5" : "h-10 px-3",
19
+ className
20
+ ),
21
+ ...props,
22
+ children: [
23
+ /* @__PURE__ */ jsx(Folder, { className: "size-4 shrink-0 text-muted-foreground", "aria-hidden": "true" }),
24
+ /* @__PURE__ */ jsx("span", { className: "min-w-0 flex-1 truncate text-left", children: path }),
25
+ /* @__PURE__ */ jsx(ChevronDown, { className: "size-3 shrink-0 text-muted-foreground", "aria-hidden": "true" })
26
+ ]
27
+ }
28
+ )
29
+ );
30
+ FolderSelector.displayName = "FolderSelector";
31
+
32
+ export { FolderSelector };
33
+ //# sourceMappingURL=chunk-PPH5NTHV.js.map
34
+ //# sourceMappingURL=chunk-PPH5NTHV.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/primitives/folder-selector/folder-selector.tsx"],"names":[],"mappings":";;;;;AAqBA,IAAM,cAAA,GAAiB,UAAA;AAAA,EACrB,CAAC,EAAE,SAAA,EAAW,IAAA,EAAM,SAAS,GAAG,KAAA,IAAS,GAAA,qBACvC,IAAA;AAAA,IAAC,QAAA;AAAA,IAAA;AAAA,MACC,GAAA;AAAA,MACA,IAAA,EAAK,QAAA;AAAA,MACL,SAAA,EAAW,EAAA;AAAA,QACT,2EAAA;AAAA,QACA,wCAAA;AAAA,QACA,+CAAA;AAAA,QACA,wCAAA;AAAA,QACA,0IAAA;AAAA,QACA,UAAU,YAAA,GAAe,WAAA;AAAA,QACzB;AAAA,OACF;AAAA,MACC,GAAG,KAAA;AAAA,MAEJ,QAAA,EAAA;AAAA,wBAAA,GAAA,CAAC,MAAA,EAAA,EAAO,SAAA,EAAU,uCAAA,EAAwC,aAAA,EAAY,MAAA,EAAO,CAAA;AAAA,wBAC7E,GAAA,CAAC,MAAA,EAAA,EAAK,SAAA,EAAU,mCAAA,EAAqC,QAAA,EAAA,IAAA,EAAK,CAAA;AAAA,wBAC1D,GAAA,CAAC,WAAA,EAAA,EAAY,SAAA,EAAU,uCAAA,EAAwC,eAAY,MAAA,EAAO;AAAA;AAAA;AAAA;AAGxF;AACA,cAAA,CAAe,WAAA,GAAc,gBAAA","file":"chunk-PPH5NTHV.js","sourcesContent":["import { ChevronDown, Folder } from \"lucide-react\";\nimport { forwardRef } from \"react\";\nimport type { ButtonHTMLAttributes } from \"react\";\nimport { cn } from \"../../../lib/cn.js\";\n\ninterface FolderSelectorProps extends ButtonHTMLAttributes<HTMLButtonElement> {\n /** Currently selected absolute path. */\n path: string;\n /**\n * Render in compact mode (smaller height, no chevron padding).\n * Default is the full-width composer variant used in the Files panel.\n */\n compact?: boolean;\n}\n\n/**\n * FolderSelector — chip showing the active working directory.\n *\n * Visual: folder icon + monospaced path (truncated middle) + chevron.\n * Stateless: caller handles the actual folder-picker dialog.\n */\nconst FolderSelector = forwardRef<HTMLButtonElement, FolderSelectorProps>(\n ({ className, path, compact, ...props }, ref) => (\n <button\n ref={ref}\n type=\"button\"\n className={cn(\n \"inline-flex items-center gap-2 rounded-lg border border-border/60 bg-card\",\n \"font-mono text-code-sm text-foreground\",\n \"transition-colors duration-base ease-out-soft\",\n \"hover:border-primary/40 hover:bg-muted\",\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-offset-background\",\n compact ? \"h-8 px-2.5\" : \"h-10 px-3\",\n className,\n )}\n {...props}\n >\n <Folder className=\"size-4 shrink-0 text-muted-foreground\" aria-hidden=\"true\" />\n <span className=\"min-w-0 flex-1 truncate text-left\">{path}</span>\n <ChevronDown className=\"size-3 shrink-0 text-muted-foreground\" aria-hidden=\"true\" />\n </button>\n ),\n);\nFolderSelector.displayName = \"FolderSelector\";\n\nexport { FolderSelector };\n"]}
@@ -0,0 +1,28 @@
1
+ import { cn } from './chunk-ZSRJCIWF.js';
2
+ import * as LabelPrimitive from '@radix-ui/react-label';
3
+ import { forwardRef } from 'react';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ var Label = forwardRef(
7
+ ({ className, required, children, ...props }, ref) => /* @__PURE__ */ jsxs(
8
+ LabelPrimitive.Root,
9
+ {
10
+ ref,
11
+ className: cn(
12
+ "inline-flex items-center gap-1 font-medium font-sans text-body-sm text-foreground",
13
+ "peer-disabled:cursor-not-allowed peer-disabled:opacity-60",
14
+ className
15
+ ),
16
+ ...props,
17
+ children: [
18
+ children,
19
+ required ? /* @__PURE__ */ jsx("span", { className: "text-destructive", "aria-hidden": "true", children: "*" }) : null
20
+ ]
21
+ }
22
+ )
23
+ );
24
+ Label.displayName = "Label";
25
+
26
+ export { Label };
27
+ //# sourceMappingURL=chunk-PR6OZF6D.js.map
28
+ //# sourceMappingURL=chunk-PR6OZF6D.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/primitives/label/label.tsx"],"names":[],"mappings":";;;;;AAiBA,IAAM,KAAA,GAAQ,UAAA;AAAA,EACZ,CAAC,EAAE,SAAA,EAAW,QAAA,EAAU,UAAU,GAAG,KAAA,IAAS,GAAA,qBAC5C,IAAA;AAAA,IAAgB,cAAA,CAAA,IAAA;AAAA,IAAf;AAAA,MACC,GAAA;AAAA,MACA,SAAA,EAAW,EAAA;AAAA,QACT,mFAAA;AAAA,QACA,2DAAA;AAAA,QACA;AAAA,OACF;AAAA,MACC,GAAG,KAAA;AAAA,MAEH,QAAA,EAAA;AAAA,QAAA,QAAA;AAAA,QACA,QAAA,uBACE,MAAA,EAAA,EAAK,SAAA,EAAU,oBAAmB,aAAA,EAAY,MAAA,EAAO,eAEtD,CAAA,GACE;AAAA;AAAA;AAAA;AAGV;AACA,KAAA,CAAM,WAAA,GAAc,OAAA","file":"chunk-PR6OZF6D.js","sourcesContent":["import * as LabelPrimitive from \"@radix-ui/react-label\";\nimport { forwardRef } from \"react\";\nimport type { ComponentPropsWithoutRef, ElementRef } from \"react\";\nimport { cn } from \"../../../lib/cn.js\";\n\n/**\n * Label — form field label built on Radix Label.\n *\n * Behaviors:\n * - Clicking the label focuses the associated `htmlFor` input.\n * - Adds a small red asterisk when `required` is set.\n * - Inherits disabled visuals from the wrapper (`peer-disabled`).\n */\ninterface LabelProps extends ComponentPropsWithoutRef<typeof LabelPrimitive.Root> {\n required?: boolean;\n}\n\nconst Label = forwardRef<ElementRef<typeof LabelPrimitive.Root>, LabelProps>(\n ({ className, required, children, ...props }, ref) => (\n <LabelPrimitive.Root\n ref={ref}\n className={cn(\n \"inline-flex items-center gap-1 font-medium font-sans text-body-sm text-foreground\",\n \"peer-disabled:cursor-not-allowed peer-disabled:opacity-60\",\n className,\n )}\n {...props}\n >\n {children}\n {required ? (\n <span className=\"text-destructive\" aria-hidden=\"true\">\n *\n </span>\n ) : null}\n </LabelPrimitive.Root>\n ),\n);\nLabel.displayName = \"Label\";\n\nexport { Label };\n"]}
@@ -0,0 +1,142 @@
1
+ import { cn } from './chunk-ZSRJCIWF.js';
2
+ import { Zap, Plus, Trash2 } from 'lucide-react';
3
+ import { forwardRef, useState } from 'react';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ var HOOK_EVENTS = [
7
+ "PreToolUse",
8
+ "PostToolUse",
9
+ "UserPromptSubmit",
10
+ "Stop",
11
+ "SessionStart",
12
+ "SessionEnd"
13
+ ];
14
+ var HookConfig = forwardRef(
15
+ ({ className, hooks, onAdd, onRemove, onToggle, title = "Hooks", ...props }, ref) => {
16
+ const [event, setEvent] = useState("PreToolUse");
17
+ const [matcher, setMatcher] = useState("*");
18
+ const [command, setCommand] = useState("");
19
+ const submit = () => {
20
+ if (!command.trim()) return;
21
+ onAdd?.({ event, matcher: matcher.trim() || "*", command: command.trim() });
22
+ setCommand("");
23
+ };
24
+ return /* @__PURE__ */ jsxs("section", { ref, className: cn("rounded-xl border bg-card", className), ...props, children: [
25
+ /* @__PURE__ */ jsxs("header", { className: "flex items-baseline justify-between border-border/40 border-b px-4 py-3", children: [
26
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
27
+ /* @__PURE__ */ jsx(Zap, { className: "size-4 text-primary", "aria-hidden": "true" }),
28
+ /* @__PURE__ */ jsx("h3", { className: "font-display text-title-md tracking-tight", children: title })
29
+ ] }),
30
+ /* @__PURE__ */ jsxs("span", { className: "font-mono text-label text-muted-foreground", children: [
31
+ hooks.length,
32
+ " ",
33
+ hooks.length === 1 ? "hook" : "hooks"
34
+ ] })
35
+ ] }),
36
+ onAdd ? /* @__PURE__ */ jsxs(
37
+ "form",
38
+ {
39
+ className: "grid grid-cols-[140px_140px_1fr_auto] items-center gap-2 border-border/40 border-b p-3",
40
+ onSubmit: (e) => {
41
+ e.preventDefault();
42
+ submit();
43
+ },
44
+ children: [
45
+ /* @__PURE__ */ jsx(
46
+ "select",
47
+ {
48
+ value: event,
49
+ onChange: (e) => setEvent(e.target.value),
50
+ "aria-label": "Event",
51
+ className: "h-9 rounded-md border border-input bg-card px-2 font-mono text-code-sm",
52
+ children: HOOK_EVENTS.map((evt) => /* @__PURE__ */ jsx("option", { value: evt, children: evt }, evt))
53
+ }
54
+ ),
55
+ /* @__PURE__ */ jsx(
56
+ "input",
57
+ {
58
+ type: "text",
59
+ value: matcher,
60
+ onChange: (e) => setMatcher(e.target.value),
61
+ placeholder: "matcher (Bash, Write, *)",
62
+ "aria-label": "Matcher",
63
+ className: "h-9 rounded-md border border-input bg-card px-2 font-mono text-code-sm focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring"
64
+ }
65
+ ),
66
+ /* @__PURE__ */ jsx(
67
+ "input",
68
+ {
69
+ type: "text",
70
+ value: command,
71
+ onChange: (e) => setCommand(e.target.value),
72
+ placeholder: 'command (e.g. "./scripts/audit.sh")',
73
+ "aria-label": "Command",
74
+ className: "h-9 rounded-md border border-input bg-card px-2 font-mono text-code-sm focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring"
75
+ }
76
+ ),
77
+ /* @__PURE__ */ jsxs(
78
+ "button",
79
+ {
80
+ type: "submit",
81
+ className: "inline-flex h-9 items-center gap-1 rounded-md bg-primary px-3 font-sans text-label text-primary-foreground hover:shadow-glow focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring",
82
+ children: [
83
+ /* @__PURE__ */ jsx(Plus, { className: "size-3.5" }),
84
+ " Add"
85
+ ]
86
+ }
87
+ )
88
+ ]
89
+ }
90
+ ) : null,
91
+ /* @__PURE__ */ jsxs("ul", { className: "divide-y divide-border/30", children: [
92
+ hooks.map((hook) => {
93
+ const enabled = hook.enabled ?? true;
94
+ return /* @__PURE__ */ jsxs(
95
+ "li",
96
+ {
97
+ className: cn(
98
+ "grid grid-cols-[140px_140px_1fr_auto_auto] items-center gap-3 px-4 py-2.5",
99
+ !enabled && "opacity-50"
100
+ ),
101
+ children: [
102
+ /* @__PURE__ */ jsx("span", { className: "font-mono text-code-sm text-primary", children: hook.event }),
103
+ /* @__PURE__ */ jsx("span", { className: "font-mono text-code-sm text-muted-foreground", children: hook.matcher }),
104
+ /* @__PURE__ */ jsx("span", { className: "truncate font-mono text-code-sm text-foreground", children: hook.command }),
105
+ onToggle ? /* @__PURE__ */ jsx(
106
+ "button",
107
+ {
108
+ type: "button",
109
+ onClick: () => onToggle(hook.id, !enabled),
110
+ "aria-pressed": enabled,
111
+ className: cn(
112
+ "rounded-full border px-2.5 py-0.5 font-mono text-label uppercase",
113
+ enabled ? "border-success/40 bg-success/15 text-success" : "border-border/40 bg-muted text-muted-foreground"
114
+ ),
115
+ children: enabled ? "On" : "Off"
116
+ }
117
+ ) : /* @__PURE__ */ jsx("span", {}),
118
+ onRemove ? /* @__PURE__ */ jsx(
119
+ "button",
120
+ {
121
+ type: "button",
122
+ onClick: () => onRemove(hook.id),
123
+ "aria-label": `Remove hook ${hook.event} ${hook.matcher}`,
124
+ className: "rounded-md p-1.5 text-muted-foreground hover:bg-muted hover:text-destructive focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring",
125
+ children: /* @__PURE__ */ jsx(Trash2, { className: "size-3.5" })
126
+ }
127
+ ) : /* @__PURE__ */ jsx("span", {})
128
+ ]
129
+ },
130
+ hook.id
131
+ );
132
+ }),
133
+ hooks.length === 0 ? /* @__PURE__ */ jsx("li", { className: "px-4 py-8 text-center font-sans text-body-sm text-muted-foreground", children: "No hooks configured." }) : null
134
+ ] })
135
+ ] });
136
+ }
137
+ );
138
+ HookConfig.displayName = "HookConfig";
139
+
140
+ export { HOOK_EVENTS, HookConfig };
141
+ //# sourceMappingURL=chunk-PWXOXPFT.js.map
142
+ //# sourceMappingURL=chunk-PWXOXPFT.js.map