@usetheo/ui 0.9.0-next.0 → 0.11.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 (502) hide show
  1. package/CHANGELOG.md +215 -0
  2. package/README.md +22 -21
  3. package/dist/chunk-2UJROWAG.js +106 -0
  4. package/dist/chunk-2UJROWAG.js.map +1 -0
  5. package/dist/chunk-2XPWOUEH.js +68 -0
  6. package/dist/chunk-2XPWOUEH.js.map +1 -0
  7. package/dist/chunk-3GHLNCM3.js +42 -0
  8. package/dist/chunk-3GHLNCM3.js.map +1 -0
  9. package/dist/chunk-3HOXC25T.js +48 -0
  10. package/dist/chunk-3HOXC25T.js.map +1 -0
  11. package/dist/chunk-3QGO5SB3.js +46 -0
  12. package/dist/chunk-3QGO5SB3.js.map +1 -0
  13. package/dist/chunk-47QJVWW2.js +85 -0
  14. package/dist/chunk-47QJVWW2.js.map +1 -0
  15. package/dist/chunk-4L63UW3I.js +35 -0
  16. package/dist/chunk-4L63UW3I.js.map +1 -0
  17. package/dist/chunk-4UUSJJFZ.js +25 -0
  18. package/dist/chunk-4UUSJJFZ.js.map +1 -0
  19. package/dist/chunk-4ZBZBRG5.js +127 -0
  20. package/dist/chunk-4ZBZBRG5.js.map +1 -0
  21. package/dist/chunk-57NXT3OX.js +92 -0
  22. package/dist/chunk-57NXT3OX.js.map +1 -0
  23. package/dist/chunk-5FF5EUZP.js +44 -0
  24. package/dist/chunk-5FF5EUZP.js.map +1 -0
  25. package/dist/chunk-5UGQXB2P.js +714 -0
  26. package/dist/chunk-5UGQXB2P.js.map +1 -0
  27. package/dist/chunk-62FT22CI.js +85 -0
  28. package/dist/chunk-62FT22CI.js.map +1 -0
  29. package/dist/chunk-673R3GSK.js +19 -0
  30. package/dist/chunk-673R3GSK.js.map +1 -0
  31. package/dist/chunk-6VINZJBV.js +128 -0
  32. package/dist/chunk-6VINZJBV.js.map +1 -0
  33. package/dist/chunk-74NZ5U3E.js +145 -0
  34. package/dist/chunk-74NZ5U3E.js.map +1 -0
  35. package/dist/chunk-755NWSNW.js +36 -0
  36. package/dist/chunk-755NWSNW.js.map +1 -0
  37. package/dist/chunk-7GLBWWMW.js +70 -0
  38. package/dist/chunk-7GLBWWMW.js.map +1 -0
  39. package/dist/chunk-7RXYW5VM.js +88 -0
  40. package/dist/chunk-7RXYW5VM.js.map +1 -0
  41. package/dist/chunk-AC4MGCXI.js +92 -0
  42. package/dist/chunk-AC4MGCXI.js.map +1 -0
  43. package/dist/chunk-AEVSVDT6.js +67 -0
  44. package/dist/chunk-AEVSVDT6.js.map +1 -0
  45. package/dist/chunk-AODIMN2N.js +68 -0
  46. package/dist/chunk-AODIMN2N.js.map +1 -0
  47. package/dist/chunk-ATHOPBCA.js +61 -0
  48. package/dist/chunk-ATHOPBCA.js.map +1 -0
  49. package/dist/chunk-AXKBNRZW.js +173 -0
  50. package/dist/chunk-AXKBNRZW.js.map +1 -0
  51. package/dist/chunk-B75MEYNR.js +106 -0
  52. package/dist/chunk-B75MEYNR.js.map +1 -0
  53. package/dist/chunk-BGKA6DI6.js +34 -0
  54. package/dist/chunk-BGKA6DI6.js.map +1 -0
  55. package/dist/chunk-BNQAJGEN.js +88 -0
  56. package/dist/chunk-BNQAJGEN.js.map +1 -0
  57. package/dist/chunk-BP2SETUC.js +101 -0
  58. package/dist/chunk-BP2SETUC.js.map +1 -0
  59. package/dist/chunk-BPUQWMBD.js +79 -0
  60. package/dist/chunk-BPUQWMBD.js.map +1 -0
  61. package/dist/chunk-BVDASR3Y.js +74 -0
  62. package/dist/chunk-BVDASR3Y.js.map +1 -0
  63. package/dist/chunk-BX7A5GUV.js +78 -0
  64. package/dist/chunk-BX7A5GUV.js.map +1 -0
  65. package/dist/chunk-CDA6RYOX.js +115 -0
  66. package/dist/chunk-CDA6RYOX.js.map +1 -0
  67. package/dist/chunk-CG7O3A42.js +80 -0
  68. package/dist/chunk-CG7O3A42.js.map +1 -0
  69. package/dist/chunk-CIYGNPKT.js +76 -0
  70. package/dist/chunk-CIYGNPKT.js.map +1 -0
  71. package/dist/chunk-CKXY4FTV.js +59 -0
  72. package/dist/chunk-CKXY4FTV.js.map +1 -0
  73. package/dist/chunk-CVOKZITR.js +82 -0
  74. package/dist/chunk-CVOKZITR.js.map +1 -0
  75. package/dist/chunk-CWFMFKDI.js +82 -0
  76. package/dist/chunk-CWFMFKDI.js.map +1 -0
  77. package/dist/chunk-CWVKSV7S.js +124 -0
  78. package/dist/chunk-CWVKSV7S.js.map +1 -0
  79. package/dist/chunk-CYOLRWOX.js +63 -0
  80. package/dist/chunk-CYOLRWOX.js.map +1 -0
  81. package/dist/chunk-D23LRJT6.js +116 -0
  82. package/dist/chunk-D23LRJT6.js.map +1 -0
  83. package/dist/chunk-DFADMEJK.js +127 -0
  84. package/dist/chunk-DFADMEJK.js.map +1 -0
  85. package/dist/chunk-DKQAHZG2.js +83 -0
  86. package/dist/chunk-DKQAHZG2.js.map +1 -0
  87. package/dist/chunk-E5A7HN6H.js +32 -0
  88. package/dist/chunk-E5A7HN6H.js.map +1 -0
  89. package/dist/chunk-EI63GTN7.js +57 -0
  90. package/dist/chunk-EI63GTN7.js.map +1 -0
  91. package/dist/chunk-EP25QJ4N.js +146 -0
  92. package/dist/chunk-EP25QJ4N.js.map +1 -0
  93. package/dist/chunk-ET44426Q.js +80 -0
  94. package/dist/chunk-ET44426Q.js.map +1 -0
  95. package/dist/chunk-ETEIDY34.js +67 -0
  96. package/dist/chunk-ETEIDY34.js.map +1 -0
  97. package/dist/chunk-EU55O4P7.js +76 -0
  98. package/dist/chunk-EU55O4P7.js.map +1 -0
  99. package/dist/chunk-F436537E.js +104 -0
  100. package/dist/chunk-F436537E.js.map +1 -0
  101. package/dist/chunk-FLBTGNQI.js +86 -0
  102. package/dist/chunk-FLBTGNQI.js.map +1 -0
  103. package/dist/chunk-FUT45NFW.js +46 -0
  104. package/dist/chunk-FUT45NFW.js.map +1 -0
  105. package/dist/chunk-G3LWNTVZ.js +51 -0
  106. package/dist/chunk-G3LWNTVZ.js.map +1 -0
  107. package/dist/chunk-GBJB5WLT.js +58 -0
  108. package/dist/chunk-GBJB5WLT.js.map +1 -0
  109. package/dist/chunk-GIEPEFRX.js +110 -0
  110. package/dist/chunk-GIEPEFRX.js.map +1 -0
  111. package/dist/chunk-GSO7MISR.js +58 -0
  112. package/dist/chunk-GSO7MISR.js.map +1 -0
  113. package/dist/chunk-GUQFYUIC.js +61 -0
  114. package/dist/chunk-GUQFYUIC.js.map +1 -0
  115. package/dist/chunk-H3VJMFJQ.js +35 -0
  116. package/dist/chunk-H3VJMFJQ.js.map +1 -0
  117. package/dist/chunk-HG4WEERE.js +26 -0
  118. package/dist/chunk-HG4WEERE.js.map +1 -0
  119. package/dist/chunk-HGPBGLNP.js +51 -0
  120. package/dist/chunk-HGPBGLNP.js.map +1 -0
  121. package/dist/chunk-HQFTW7SF.js +141 -0
  122. package/dist/chunk-HQFTW7SF.js.map +1 -0
  123. package/dist/chunk-I7WYM63C.js +170 -0
  124. package/dist/chunk-I7WYM63C.js.map +1 -0
  125. package/dist/chunk-IPEYGWA7.js +186 -0
  126. package/dist/chunk-IPEYGWA7.js.map +1 -0
  127. package/dist/chunk-IWSLOBYG.js +199 -0
  128. package/dist/chunk-IWSLOBYG.js.map +1 -0
  129. package/dist/chunk-JQXLPVWP.js +74 -0
  130. package/dist/chunk-JQXLPVWP.js.map +1 -0
  131. package/dist/chunk-K5ARID4S.js +26 -0
  132. package/dist/chunk-K5ARID4S.js.map +1 -0
  133. package/dist/chunk-K6RTLPIJ.js +41 -0
  134. package/dist/chunk-K6RTLPIJ.js.map +1 -0
  135. package/dist/chunk-KQNKKV2C.js +56 -0
  136. package/dist/chunk-KQNKKV2C.js.map +1 -0
  137. package/dist/chunk-KRN4NE4U.js +155 -0
  138. package/dist/chunk-KRN4NE4U.js.map +1 -0
  139. package/dist/chunk-L2BI762I.js +82 -0
  140. package/dist/chunk-L2BI762I.js.map +1 -0
  141. package/dist/chunk-LEEH63B2.js +56 -0
  142. package/dist/chunk-LEEH63B2.js.map +1 -0
  143. package/dist/chunk-LHRWVM3G.js +42 -0
  144. package/dist/chunk-LHRWVM3G.js.map +1 -0
  145. package/dist/chunk-LIGWMGXM.js +117 -0
  146. package/dist/chunk-LIGWMGXM.js.map +1 -0
  147. package/dist/chunk-LKYSX3QF.js +104 -0
  148. package/dist/chunk-LKYSX3QF.js.map +1 -0
  149. package/dist/chunk-MCIFB6VS.js +54 -0
  150. package/dist/chunk-MCIFB6VS.js.map +1 -0
  151. package/dist/chunk-MI5CXMZU.js +171 -0
  152. package/dist/chunk-MI5CXMZU.js.map +1 -0
  153. package/dist/chunk-NQZYY4LR.js +84 -0
  154. package/dist/chunk-NQZYY4LR.js.map +1 -0
  155. package/dist/chunk-O23LKHUR.js +66 -0
  156. package/dist/chunk-O23LKHUR.js.map +1 -0
  157. package/dist/chunk-PASI2U2R.js +23 -0
  158. package/dist/chunk-PASI2U2R.js.map +1 -0
  159. package/dist/chunk-PPH5NTHV.js +34 -0
  160. package/dist/chunk-PPH5NTHV.js.map +1 -0
  161. package/dist/chunk-PR6OZF6D.js +28 -0
  162. package/dist/chunk-PR6OZF6D.js.map +1 -0
  163. package/dist/chunk-PWXOXPFT.js +142 -0
  164. package/dist/chunk-PWXOXPFT.js.map +1 -0
  165. package/dist/chunk-QB6BNHO3.js +112 -0
  166. package/dist/chunk-QB6BNHO3.js.map +1 -0
  167. package/dist/chunk-QJGGTIUN.js +110 -0
  168. package/dist/chunk-QJGGTIUN.js.map +1 -0
  169. package/dist/chunk-QSOIJ6J3.js +91 -0
  170. package/dist/chunk-QSOIJ6J3.js.map +1 -0
  171. package/dist/chunk-R2PAGRDP.js +152 -0
  172. package/dist/chunk-R2PAGRDP.js.map +1 -0
  173. package/dist/chunk-R63ZKLQM.js +45 -0
  174. package/dist/chunk-R63ZKLQM.js.map +1 -0
  175. package/dist/chunk-RTYYJPPE.js +77 -0
  176. package/dist/chunk-RTYYJPPE.js.map +1 -0
  177. package/dist/chunk-RVOBP7PO.js +116 -0
  178. package/dist/chunk-RVOBP7PO.js.map +1 -0
  179. package/dist/chunk-SF6R5VMQ.js +97 -0
  180. package/dist/chunk-SF6R5VMQ.js.map +1 -0
  181. package/dist/chunk-SP4CP5HY.js +57 -0
  182. package/dist/chunk-SP4CP5HY.js.map +1 -0
  183. package/dist/chunk-SWJ4EUOI.js +30 -0
  184. package/dist/chunk-SWJ4EUOI.js.map +1 -0
  185. package/dist/chunk-TK24HQJJ.js +128 -0
  186. package/dist/chunk-TK24HQJJ.js.map +1 -0
  187. package/dist/chunk-TNBJ36XJ.js +156 -0
  188. package/dist/chunk-TNBJ36XJ.js.map +1 -0
  189. package/dist/chunk-TO3UAT6O.js +221 -0
  190. package/dist/chunk-TO3UAT6O.js.map +1 -0
  191. package/dist/chunk-UAYOOTRR.js +77 -0
  192. package/dist/chunk-UAYOOTRR.js.map +1 -0
  193. package/dist/chunk-UDTAMHXW.js +55 -0
  194. package/dist/chunk-UDTAMHXW.js.map +1 -0
  195. package/dist/chunk-UGKI466V.js +12 -0
  196. package/dist/chunk-UGKI466V.js.map +1 -0
  197. package/dist/chunk-UOXU7NDY.js +120 -0
  198. package/dist/chunk-UOXU7NDY.js.map +1 -0
  199. package/dist/chunk-V7OOTVK3.js +106 -0
  200. package/dist/chunk-V7OOTVK3.js.map +1 -0
  201. package/dist/chunk-VI5M7KJ2.js +1022 -0
  202. package/dist/chunk-VI5M7KJ2.js.map +1 -0
  203. package/dist/chunk-VM4RMQQN.js +11 -0
  204. package/dist/chunk-VM4RMQQN.js.map +1 -0
  205. package/dist/chunk-VMMATOPE.js +64 -0
  206. package/dist/chunk-VMMATOPE.js.map +1 -0
  207. package/dist/chunk-W2PVSIW3.js +89 -0
  208. package/dist/chunk-W2PVSIW3.js.map +1 -0
  209. package/dist/chunk-W3DUDZDU.js +88 -0
  210. package/dist/chunk-W3DUDZDU.js.map +1 -0
  211. package/dist/chunk-WKEUU2FU.js +114 -0
  212. package/dist/chunk-WKEUU2FU.js.map +1 -0
  213. package/dist/chunk-WKLW7RC6.js +28 -0
  214. package/dist/chunk-WKLW7RC6.js.map +1 -0
  215. package/dist/chunk-WSJGZNUH.js +111 -0
  216. package/dist/chunk-WSJGZNUH.js.map +1 -0
  217. package/dist/chunk-WVPDQMC2.js +144 -0
  218. package/dist/chunk-WVPDQMC2.js.map +1 -0
  219. package/dist/chunk-WWNH5ENT.js +43 -0
  220. package/dist/chunk-WWNH5ENT.js.map +1 -0
  221. package/dist/chunk-X5L62PXY.js +112 -0
  222. package/dist/chunk-X5L62PXY.js.map +1 -0
  223. package/dist/chunk-XGCV5E6W.js +133 -0
  224. package/dist/chunk-XGCV5E6W.js.map +1 -0
  225. package/dist/chunk-XRKIEL5M.js +72 -0
  226. package/dist/chunk-XRKIEL5M.js.map +1 -0
  227. package/dist/chunk-XUJYEADU.js +80 -0
  228. package/dist/chunk-XUJYEADU.js.map +1 -0
  229. package/dist/chunk-XVYNSIQC.js +116 -0
  230. package/dist/chunk-XVYNSIQC.js.map +1 -0
  231. package/dist/chunk-XWTISHXO.js +54 -0
  232. package/dist/chunk-XWTISHXO.js.map +1 -0
  233. package/dist/chunk-YOGHS4UU.js +202 -0
  234. package/dist/chunk-YOGHS4UU.js.map +1 -0
  235. package/dist/chunk-YRSKXEOD.js +135 -0
  236. package/dist/chunk-YRSKXEOD.js.map +1 -0
  237. package/dist/chunk-ZALLCR7X.js +108 -0
  238. package/dist/chunk-ZALLCR7X.js.map +1 -0
  239. package/dist/chunk-ZDAOHMCW.js +46 -0
  240. package/dist/chunk-ZDAOHMCW.js.map +1 -0
  241. package/dist/chunk-ZESICCKK.js +37 -0
  242. package/dist/chunk-ZESICCKK.js.map +1 -0
  243. package/dist/chunk-ZIKFOD6N.js +87 -0
  244. package/dist/chunk-ZIKFOD6N.js.map +1 -0
  245. package/dist/chunk-ZJRWCQEN.js +76 -0
  246. package/dist/chunk-ZJRWCQEN.js.map +1 -0
  247. package/dist/chunk-ZSRJCIWF.js +24 -0
  248. package/dist/chunk-ZSRJCIWF.js.map +1 -0
  249. package/dist/chunk-ZXPDS6DH.js +3 -0
  250. package/dist/chunk-ZXPDS6DH.js.map +1 -0
  251. package/dist/components.css +1 -1
  252. package/dist/composites/account-menu/index.js +6 -0
  253. package/dist/composites/account-menu/index.js.map +1 -0
  254. package/dist/composites/agent-composer/index.js +7 -0
  255. package/dist/composites/agent-composer/index.js.map +1 -0
  256. package/dist/composites/agent-editor/index.js +10 -0
  257. package/dist/composites/agent-editor/index.js.map +1 -0
  258. package/dist/composites/agent-stream/index.js +12 -0
  259. package/dist/composites/agent-stream/index.js.map +1 -0
  260. package/dist/composites/agent-timeline/index.js +5 -0
  261. package/dist/composites/agent-timeline/index.js.map +1 -0
  262. package/dist/composites/approval-card/index.js +5 -0
  263. package/dist/composites/approval-card/index.js.map +1 -0
  264. package/dist/composites/chat-composer/index.js +6 -0
  265. package/dist/composites/chat-composer/index.js.map +1 -0
  266. package/dist/composites/chat-message/index.js +6 -0
  267. package/dist/composites/chat-message/index.js.map +1 -0
  268. package/dist/composites/code-block/index.js +5 -0
  269. package/dist/composites/code-block/index.js.map +1 -0
  270. package/dist/composites/command-palette/index.js +5 -0
  271. package/dist/composites/command-palette/index.js.map +1 -0
  272. package/dist/composites/confirm-dialog/index.js +7 -0
  273. package/dist/composites/confirm-dialog/index.js.map +1 -0
  274. package/dist/composites/cron-jobs-list/index.js +5 -0
  275. package/dist/composites/cron-jobs-list/index.js.map +1 -0
  276. package/dist/composites/data-table/index.js +10 -0
  277. package/dist/composites/data-table/index.js.map +1 -0
  278. package/dist/composites/deployment-row/index.js +5 -0
  279. package/dist/composites/deployment-row/index.js.map +1 -0
  280. package/dist/composites/domain-config/index.js +7 -0
  281. package/dist/composites/domain-config/index.js.map +1 -0
  282. package/dist/composites/env-var-editor/index.js +7 -0
  283. package/dist/composites/env-var-editor/index.js.map +1 -0
  284. package/dist/composites/mcp-server-list/index.js +5 -0
  285. package/dist/composites/mcp-server-list/index.js.map +1 -0
  286. package/dist/composites/page-shell/index.js +7 -0
  287. package/dist/composites/page-shell/index.js.map +1 -0
  288. package/dist/composites/permission-modal/index.js +6 -0
  289. package/dist/composites/permission-modal/index.js.map +1 -0
  290. package/dist/composites/preview-env-card/index.js +6 -0
  291. package/dist/composites/preview-env-card/index.js.map +1 -0
  292. package/dist/composites/preview-panel/index.js +5 -0
  293. package/dist/composites/preview-panel/index.js.map +1 -0
  294. package/dist/composites/project-card/index.js +6 -0
  295. package/dist/composites/project-card/index.js.map +1 -0
  296. package/dist/composites/rollback-ui/index.js +6 -0
  297. package/dist/composites/rollback-ui/index.js.map +1 -0
  298. package/dist/composites/rule-editor/index.js +11 -0
  299. package/dist/composites/rule-editor/index.js.map +1 -0
  300. package/dist/composites/skill-editor/index.js +11 -0
  301. package/dist/composites/skill-editor/index.js.map +1 -0
  302. package/dist/composites/skills-list/index.js +5 -0
  303. package/dist/composites/skills-list/index.js.map +1 -0
  304. package/dist/composites/task-header/index.js +5 -0
  305. package/dist/composites/task-header/index.js.map +1 -0
  306. package/dist/composites/usage-meter/index.js +5 -0
  307. package/dist/composites/usage-meter/index.js.map +1 -0
  308. package/dist/index.d.ts +281 -12
  309. package/dist/index.js +129 -9487
  310. package/dist/index.js.map +1 -1
  311. package/dist/primitives/action-bar/index.js +4 -0
  312. package/dist/primitives/action-bar/index.js.map +1 -0
  313. package/dist/primitives/agent-error-card/index.js +5 -0
  314. package/dist/primitives/agent-error-card/index.js.map +1 -0
  315. package/dist/primitives/agent-event/index.js +4 -0
  316. package/dist/primitives/agent-event/index.js.map +1 -0
  317. package/dist/primitives/agent-handoff/index.js +4 -0
  318. package/dist/primitives/agent-handoff/index.js.map +1 -0
  319. package/dist/primitives/agent-profile/index.js +4 -0
  320. package/dist/primitives/agent-profile/index.js.map +1 -0
  321. package/dist/primitives/agent-starting-state/index.js +5 -0
  322. package/dist/primitives/agent-starting-state/index.js.map +1 -0
  323. package/dist/primitives/agent-streaming/index.js +5 -0
  324. package/dist/primitives/agent-streaming/index.js.map +1 -0
  325. package/dist/primitives/alert/index.js +4 -0
  326. package/dist/primitives/alert/index.js.map +1 -0
  327. package/dist/primitives/artifact-preview/index.js +4 -0
  328. package/dist/primitives/artifact-preview/index.js.map +1 -0
  329. package/dist/primitives/attachment-chip/index.js +4 -0
  330. package/dist/primitives/attachment-chip/index.js.map +1 -0
  331. package/dist/primitives/audit-log-entry/index.js +4 -0
  332. package/dist/primitives/audit-log-entry/index.js.map +1 -0
  333. package/dist/primitives/auto-compact-notice/index.js +5 -0
  334. package/dist/primitives/auto-compact-notice/index.js.map +1 -0
  335. package/dist/primitives/avatar/index.js +4 -0
  336. package/dist/primitives/avatar/index.js.map +1 -0
  337. package/dist/primitives/badge/index.js +4 -0
  338. package/dist/primitives/badge/index.js.map +1 -0
  339. package/dist/primitives/browser-controls/index.js +4 -0
  340. package/dist/primitives/browser-controls/index.js.map +1 -0
  341. package/dist/primitives/build-log-stream/index.js +5 -0
  342. package/dist/primitives/build-log-stream/index.js.map +1 -0
  343. package/dist/primitives/button/index.js +4 -0
  344. package/dist/primitives/button/index.js.map +1 -0
  345. package/dist/primitives/capability-indicator/index.js +4 -0
  346. package/dist/primitives/capability-indicator/index.js.map +1 -0
  347. package/dist/primitives/card/index.js +4 -0
  348. package/dist/primitives/card/index.js.map +1 -0
  349. package/dist/primitives/chat-thread/index.js +5 -0
  350. package/dist/primitives/chat-thread/index.js.map +1 -0
  351. package/dist/primitives/checkbox/index.js +4 -0
  352. package/dist/primitives/checkbox/index.js.map +1 -0
  353. package/dist/primitives/context-card/index.js +4 -0
  354. package/dist/primitives/context-card/index.js.map +1 -0
  355. package/dist/primitives/context-window-bar/index.js +4 -0
  356. package/dist/primitives/context-window-bar/index.js.map +1 -0
  357. package/dist/primitives/copy-button/index.js +4 -0
  358. package/dist/primitives/copy-button/index.js.map +1 -0
  359. package/dist/primitives/cost-meter/index.js +4 -0
  360. package/dist/primitives/cost-meter/index.js.map +1 -0
  361. package/dist/primitives/created-files-card/index.js +4 -0
  362. package/dist/primitives/created-files-card/index.js.map +1 -0
  363. package/dist/primitives/cron-job-card/index.js +4 -0
  364. package/dist/primitives/cron-job-card/index.js.map +1 -0
  365. package/dist/primitives/danger-zone/index.js +4 -0
  366. package/dist/primitives/danger-zone/index.js.map +1 -0
  367. package/dist/primitives/dialog/index.js +4 -0
  368. package/dist/primitives/dialog/index.js.map +1 -0
  369. package/dist/primitives/diff-viewer/index.js +4 -0
  370. package/dist/primitives/diff-viewer/index.js.map +1 -0
  371. package/dist/primitives/dropdown-menu/index.js +4 -0
  372. package/dist/primitives/dropdown-menu/index.js.map +1 -0
  373. package/dist/primitives/empty-state/index.js +4 -0
  374. package/dist/primitives/empty-state/index.js.map +1 -0
  375. package/dist/primitives/folder-context-card/index.js +4 -0
  376. package/dist/primitives/folder-context-card/index.js.map +1 -0
  377. package/dist/primitives/folder-selector/index.js +4 -0
  378. package/dist/primitives/folder-selector/index.js.map +1 -0
  379. package/dist/primitives/form-field/index.js +4 -0
  380. package/dist/primitives/form-field/index.js.map +1 -0
  381. package/dist/primitives/hook-config/index.js +4 -0
  382. package/dist/primitives/hook-config/index.js.map +1 -0
  383. package/dist/primitives/hook-event-log/index.js +4 -0
  384. package/dist/primitives/hook-event-log/index.js.map +1 -0
  385. package/dist/primitives/input/index.js +4 -0
  386. package/dist/primitives/input/index.js.map +1 -0
  387. package/dist/primitives/intent-selector/index.js +4 -0
  388. package/dist/primitives/intent-selector/index.js.map +1 -0
  389. package/dist/primitives/label/index.js +4 -0
  390. package/dist/primitives/label/index.js.map +1 -0
  391. package/dist/primitives/lane-board/index.js +4 -0
  392. package/dist/primitives/lane-board/index.js.map +1 -0
  393. package/dist/primitives/login-split/index.js +4 -0
  394. package/dist/primitives/login-split/index.js.map +1 -0
  395. package/dist/primitives/mcp-server-card/index.js +4 -0
  396. package/dist/primitives/mcp-server-card/index.js.map +1 -0
  397. package/dist/primitives/memory-editor/index.js +4 -0
  398. package/dist/primitives/memory-editor/index.js.map +1 -0
  399. package/dist/primitives/mention-menu/index.js +4 -0
  400. package/dist/primitives/mention-menu/index.js.map +1 -0
  401. package/dist/primitives/metrics-panel/index.js +4 -0
  402. package/dist/primitives/metrics-panel/index.js.map +1 -0
  403. package/dist/primitives/model-card/index.js +4 -0
  404. package/dist/primitives/model-card/index.js.map +1 -0
  405. package/dist/primitives/model-selector/index.js +4 -0
  406. package/dist/primitives/model-selector/index.js.map +1 -0
  407. package/dist/primitives/pagination/index.js +4 -0
  408. package/dist/primitives/pagination/index.js.map +1 -0
  409. package/dist/primitives/permission-matrix/index.js +4 -0
  410. package/dist/primitives/permission-matrix/index.js.map +1 -0
  411. package/dist/primitives/pin-input/index.js +4 -0
  412. package/dist/primitives/pin-input/index.js.map +1 -0
  413. package/dist/primitives/plan-badge/index.js +4 -0
  414. package/dist/primitives/plan-badge/index.js.map +1 -0
  415. package/dist/primitives/progress/index.js +4 -0
  416. package/dist/primitives/progress/index.js.map +1 -0
  417. package/dist/primitives/progress-checklist/index.js +4 -0
  418. package/dist/primitives/progress-checklist/index.js.map +1 -0
  419. package/dist/primitives/project-switcher/index.js +4 -0
  420. package/dist/primitives/project-switcher/index.js.map +1 -0
  421. package/dist/primitives/quick-action-chips/index.js +4 -0
  422. package/dist/primitives/quick-action-chips/index.js.map +1 -0
  423. package/dist/primitives/radio-group/index.js +4 -0
  424. package/dist/primitives/radio-group/index.js.map +1 -0
  425. package/dist/primitives/recent-folders-list/index.js +4 -0
  426. package/dist/primitives/recent-folders-list/index.js.map +1 -0
  427. package/dist/primitives/rule-card/index.js +4 -0
  428. package/dist/primitives/rule-card/index.js.map +1 -0
  429. package/dist/primitives/run-stats/index.js +4 -0
  430. package/dist/primitives/run-stats/index.js.map +1 -0
  431. package/dist/primitives/running-tasks-panel/index.js +4 -0
  432. package/dist/primitives/running-tasks-panel/index.js.map +1 -0
  433. package/dist/primitives/scroll-area/index.js +4 -0
  434. package/dist/primitives/scroll-area/index.js.map +1 -0
  435. package/dist/primitives/select/index.js +4 -0
  436. package/dist/primitives/select/index.js.map +1 -0
  437. package/dist/primitives/session-list-item/index.js +4 -0
  438. package/dist/primitives/session-list-item/index.js.map +1 -0
  439. package/dist/primitives/session-timeline/index.js +4 -0
  440. package/dist/primitives/session-timeline/index.js.map +1 -0
  441. package/dist/primitives/sheet/index.js +4 -0
  442. package/dist/primitives/sheet/index.js.map +1 -0
  443. package/dist/primitives/sidebar/index.js +4 -0
  444. package/dist/primitives/sidebar/index.js.map +1 -0
  445. package/dist/primitives/skeleton/index.js +5 -0
  446. package/dist/primitives/skeleton/index.js.map +1 -0
  447. package/dist/primitives/skill-card/index.js +4 -0
  448. package/dist/primitives/skill-card/index.js.map +1 -0
  449. package/dist/primitives/social-auth-row/index.js +4 -0
  450. package/dist/primitives/social-auth-row/index.js.map +1 -0
  451. package/dist/primitives/stat-tile/index.js +4 -0
  452. package/dist/primitives/stat-tile/index.js.map +1 -0
  453. package/dist/primitives/status-dot/index.js +4 -0
  454. package/dist/primitives/status-dot/index.js.map +1 -0
  455. package/dist/primitives/steps-rail/index.js +4 -0
  456. package/dist/primitives/steps-rail/index.js.map +1 -0
  457. package/dist/primitives/sub-agent-dispatch/index.js +4 -0
  458. package/dist/primitives/sub-agent-dispatch/index.js.map +1 -0
  459. package/dist/primitives/switch/index.js +4 -0
  460. package/dist/primitives/switch/index.js.map +1 -0
  461. package/dist/primitives/system-prompt-editor/index.js +4 -0
  462. package/dist/primitives/system-prompt-editor/index.js.map +1 -0
  463. package/dist/primitives/table/index.js +4 -0
  464. package/dist/primitives/table/index.js.map +1 -0
  465. package/dist/primitives/tabs/index.js +4 -0
  466. package/dist/primitives/tabs/index.js.map +1 -0
  467. package/dist/primitives/task-plan/index.js +4 -0
  468. package/dist/primitives/task-plan/index.js.map +1 -0
  469. package/dist/primitives/terminal-panel/index.js +5 -0
  470. package/dist/primitives/terminal-panel/index.js.map +1 -0
  471. package/dist/primitives/textarea/index.js +4 -0
  472. package/dist/primitives/textarea/index.js.map +1 -0
  473. package/dist/primitives/timestamp/index.js +4 -0
  474. package/dist/primitives/timestamp/index.js.map +1 -0
  475. package/dist/primitives/toast/index.js +4 -0
  476. package/dist/primitives/toast/index.js.map +1 -0
  477. package/dist/primitives/token-usage-chart/index.js +4 -0
  478. package/dist/primitives/token-usage-chart/index.js.map +1 -0
  479. package/dist/primitives/tool-call/index.js +4 -0
  480. package/dist/primitives/tool-call/index.js.map +1 -0
  481. package/dist/primitives/tool-call-card/index.js +4 -0
  482. package/dist/primitives/tool-call-card/index.js.map +1 -0
  483. package/dist/primitives/tool-result/index.js +4 -0
  484. package/dist/primitives/tool-result/index.js.map +1 -0
  485. package/dist/primitives/tools-list/index.js +4 -0
  486. package/dist/primitives/tools-list/index.js.map +1 -0
  487. package/dist/primitives/tooltip/index.js +4 -0
  488. package/dist/primitives/tooltip/index.js.map +1 -0
  489. package/dist/primitives/topnav/index.js +4 -0
  490. package/dist/primitives/topnav/index.js.map +1 -0
  491. package/dist/slide/index.js +1 -712
  492. package/dist/slide/index.js.map +1 -1
  493. package/dist/slide-deck/index.js +2 -688
  494. package/dist/slide-deck/index.js.map +1 -1
  495. package/llms.txt +8 -6
  496. package/package.json +177 -157
  497. package/registry/index.json +30 -0
  498. package/registry/r/action-bar.json +22 -0
  499. package/registry/r/data-table.json +27 -0
  500. package/registry/r/dropdown-menu.json +23 -0
  501. package/registry/r/page-shell.json +25 -0
  502. package/registry/r/pin-input.json +20 -0
@@ -0,0 +1,156 @@
1
+ import { ALL_MODES, MODE_LABEL } from './chunk-VM4RMQQN.js';
2
+ import { Textarea } from './chunk-WWNH5ENT.js';
3
+ import { Switch } from './chunk-3HOXC25T.js';
4
+ import { Select } from './chunk-EP25QJ4N.js';
5
+ import { FormField } from './chunk-TK24HQJJ.js';
6
+ import { Input } from './chunk-H3VJMFJQ.js';
7
+ import { Button } from './chunk-57NXT3OX.js';
8
+ import { cn } from './chunk-ZSRJCIWF.js';
9
+ import { useState } from 'react';
10
+ import { jsxs, jsx } from 'react/jsx-runtime';
11
+
12
+ var SCOPES = [
13
+ { id: "global", label: "Global \u2014 applies to every session" },
14
+ { id: "project", label: "Project \u2014 only this workspace" }
15
+ ];
16
+ function RuleEditor({
17
+ className,
18
+ initial,
19
+ onSave,
20
+ onCancel,
21
+ onDelete,
22
+ ...formProps
23
+ }) {
24
+ const [title, setTitle] = useState(initial?.title ?? "");
25
+ const [body, setBody] = useState(initial?.body ?? "");
26
+ const [scope, setScope] = useState(initial?.scope ?? "global");
27
+ const [tagsRaw, setTagsRaw] = useState(initial?.tags?.join(", ") ?? "");
28
+ const [enabled, setEnabled] = useState(initial?.state ?? "enabled");
29
+ const [modes, setModes] = useState(initial?.modes ?? []);
30
+ const toggleMode = (m) => setModes((prev) => prev.includes(m) ? prev.filter((x) => x !== m) : [...prev, m]);
31
+ const canSave = title.trim().length > 0 && body.trim().length > 0;
32
+ const handleSubmit = (e) => {
33
+ e.preventDefault();
34
+ if (!canSave) return;
35
+ onSave({
36
+ id: initial?.id,
37
+ title: title.trim(),
38
+ body: body.trim(),
39
+ scope,
40
+ state: enabled,
41
+ tags: tagsRaw.split(",").map((t) => t.trim()).filter(Boolean),
42
+ modes: modes.length > 0 ? modes : void 0
43
+ });
44
+ };
45
+ return /* @__PURE__ */ jsxs(
46
+ "form",
47
+ {
48
+ onSubmit: handleSubmit,
49
+ className: cn("flex h-full flex-col gap-4", className),
50
+ ...formProps,
51
+ children: [
52
+ /* @__PURE__ */ jsxs(FormField, { children: [
53
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Title" }),
54
+ /* @__PURE__ */ jsx(FormField.Control, { children: /* @__PURE__ */ jsx(
55
+ Input,
56
+ {
57
+ value: title,
58
+ onChange: (e) => setTitle(e.target.value),
59
+ placeholder: "Always write tests before fixes",
60
+ required: true
61
+ }
62
+ ) }),
63
+ /* @__PURE__ */ jsx(FormField.Hint, { children: "Short, imperative summary the agent will keep in memory." })
64
+ ] }),
65
+ /* @__PURE__ */ jsxs(FormField, { className: "flex-1", children: [
66
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Body (markdown)" }),
67
+ /* @__PURE__ */ jsx(FormField.Control, { children: /* @__PURE__ */ jsx(
68
+ Textarea,
69
+ {
70
+ value: body,
71
+ onChange: (e) => setBody(e.target.value),
72
+ rows: 8,
73
+ placeholder: "When fixing a bug, first write a failing regression test, then the fix.",
74
+ required: true,
75
+ className: "min-h-[12rem] flex-1 font-mono text-code-sm"
76
+ }
77
+ ) }),
78
+ /* @__PURE__ */ jsx(FormField.Hint, { children: "Injected into the system prompt verbatim." })
79
+ ] }),
80
+ /* @__PURE__ */ jsxs("div", { className: "grid grid-cols-2 gap-3", children: [
81
+ /* @__PURE__ */ jsxs(FormField, { children: [
82
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Scope" }),
83
+ /* @__PURE__ */ jsx(FormField.Control, { children: /* @__PURE__ */ jsxs(
84
+ Select,
85
+ {
86
+ value: scope,
87
+ onValueChange: (v) => {
88
+ const next = SCOPES.find((s) => s.id === v);
89
+ if (next) setScope(next.id);
90
+ },
91
+ children: [
92
+ /* @__PURE__ */ jsx(Select.Trigger, { "aria-label": "Select rule scope", children: /* @__PURE__ */ jsx(Select.Value, {}) }),
93
+ /* @__PURE__ */ jsx(Select.Content, { children: SCOPES.map((s) => /* @__PURE__ */ jsx(Select.Item, { value: s.id, children: s.label }, s.id)) })
94
+ ]
95
+ }
96
+ ) })
97
+ ] }),
98
+ /* @__PURE__ */ jsxs(FormField, { children: [
99
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Tags (comma-separated)" }),
100
+ /* @__PURE__ */ jsx(FormField.Control, { children: /* @__PURE__ */ jsx(
101
+ Input,
102
+ {
103
+ value: tagsRaw,
104
+ onChange: (e) => setTagsRaw(e.target.value),
105
+ placeholder: "testing, process"
106
+ }
107
+ ) })
108
+ ] })
109
+ ] }),
110
+ /* @__PURE__ */ jsxs(FormField, { children: [
111
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Active modes" }),
112
+ /* @__PURE__ */ jsx("div", { className: "flex flex-wrap gap-1.5", children: ALL_MODES.map((m) => {
113
+ const on = modes.includes(m);
114
+ return /* @__PURE__ */ jsx(
115
+ "button",
116
+ {
117
+ type: "button",
118
+ onClick: () => toggleMode(m),
119
+ "aria-pressed": on,
120
+ className: cn(
121
+ "inline-flex h-7 items-center rounded-full border px-3 font-mono text-body-sm transition-colors",
122
+ on ? "border-primary bg-primary/15 text-primary" : "border-border/60 bg-card text-muted-foreground hover:text-foreground"
123
+ ),
124
+ children: MODE_LABEL[m]
125
+ },
126
+ m
127
+ );
128
+ }) }),
129
+ /* @__PURE__ */ jsx(FormField.Hint, { children: modes.length === 0 ? "Empty = global (applies to every mode)." : `Only visible in: ${modes.map((m) => MODE_LABEL[m]).join(", ")}.` })
130
+ ] }),
131
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-3", children: [
132
+ /* @__PURE__ */ jsx(
133
+ Switch,
134
+ {
135
+ checked: enabled === "enabled",
136
+ onCheckedChange: (v) => setEnabled(v ? "enabled" : "disabled"),
137
+ "aria-label": "Enabled"
138
+ }
139
+ ),
140
+ /* @__PURE__ */ jsx("span", { className: "text-body-sm text-muted-foreground", children: enabled === "enabled" ? "Enabled \u2014 agent will follow this rule." : "Disabled \u2014 kept but ignored." })
141
+ ] }),
142
+ /* @__PURE__ */ jsxs("footer", { className: "flex items-center justify-between gap-2 border-border/40 border-t pt-4", children: [
143
+ /* @__PURE__ */ jsx("div", { children: onDelete ? /* @__PURE__ */ jsx(Button, { type: "button", variant: "ghost", onClick: onDelete, children: "Delete" }) : null }),
144
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
145
+ onCancel ? /* @__PURE__ */ jsx(Button, { type: "button", variant: "secondary", onClick: onCancel, children: "Cancel" }) : null,
146
+ /* @__PURE__ */ jsx(Button, { type: "submit", disabled: !canSave, children: initial?.id ? "Save changes" : "Create rule" })
147
+ ] })
148
+ ] })
149
+ ]
150
+ }
151
+ );
152
+ }
153
+
154
+ export { RuleEditor };
155
+ //# sourceMappingURL=chunk-TNBJ36XJ.js.map
156
+ //# sourceMappingURL=chunk-TNBJ36XJ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/composites/rule-editor/rule-editor.tsx"],"names":[],"mappings":";;;;;;;;;;;AA6BA,IAAM,MAAA,GAAkD;AAAA,EACtD,EAAE,EAAA,EAAI,QAAA,EAAU,KAAA,EAAO,wCAAA,EAAoC;AAAA,EAC3D,EAAE,EAAA,EAAI,SAAA,EAAW,KAAA,EAAO,oCAAA;AAC1B,CAAA;AAEO,SAAS,UAAA,CAAW;AAAA,EACzB,SAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACA,QAAA;AAAA,EACA,QAAA;AAAA,EACA,GAAG;AACL,CAAA,EAAoB;AAClB,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,IAAI,QAAA,CAAS,OAAA,EAAS,SAAS,EAAE,CAAA;AACvD,EAAA,MAAM,CAAC,IAAA,EAAM,OAAO,IAAI,QAAA,CAAS,OAAA,EAAS,QAAQ,EAAE,CAAA;AACpD,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,IAAI,QAAA,CAAoB,OAAA,EAAS,SAAS,QAAQ,CAAA;AACxE,EAAA,MAAM,CAAC,OAAA,EAAS,UAAU,CAAA,GAAI,QAAA,CAAS,SAAS,IAAA,EAAM,IAAA,CAAK,IAAI,CAAA,IAAK,EAAE,CAAA;AACtE,EAAA,MAAM,CAAC,OAAA,EAAS,UAAU,IAAI,QAAA,CAAoB,OAAA,EAAS,SAAS,SAAS,CAAA;AAC7E,EAAA,MAAM,CAAC,OAAO,QAAQ,CAAA,GAAI,SAAiB,OAAA,EAAS,KAAA,IAAS,EAAE,CAAA;AAK/D,EAAA,MAAM,UAAA,GAAa,CAAC,CAAA,KAClB,QAAA,CAAS,CAAC,IAAA,KAAU,IAAA,CAAK,SAAS,CAAC,CAAA,GAAI,KAAK,MAAA,CAAO,CAAC,MAAM,CAAA,KAAM,CAAC,IAAI,CAAC,GAAG,IAAA,EAAM,CAAC,CAAE,CAAA;AAEpF,EAAA,MAAM,OAAA,GAAU,MAAM,IAAA,EAAK,CAAE,SAAS,CAAA,IAAK,IAAA,CAAK,IAAA,EAAK,CAAE,MAAA,GAAS,CAAA;AAChE,EAAA,MAAM,YAAA,GAAe,CAAC,CAAA,KAAiB;AACrC,IAAA,CAAA,CAAE,cAAA,EAAe;AACjB,IAAA,IAAI,CAAC,OAAA,EAAS;AACd,IAAA,MAAA,CAAO;AAAA,MACL,IAAI,OAAA,EAAS,EAAA;AAAA,MACb,KAAA,EAAO,MAAM,IAAA,EAAK;AAAA,MAClB,IAAA,EAAM,KAAK,IAAA,EAAK;AAAA,MAChB,KAAA;AAAA,MACA,KAAA,EAAO,OAAA;AAAA,MACP,IAAA,EAAM,OAAA,CACH,KAAA,CAAM,GAAG,CAAA,CACT,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,IAAA,EAAM,CAAA,CACnB,OAAO,OAAO,CAAA;AAAA,MACjB,KAAA,EAAO,KAAA,CAAM,MAAA,GAAS,CAAA,GAAI,KAAA,GAAQ;AAAA,KACnC,CAAA;AAAA,EACH,CAAA;AAEA,EAAA,uBACE,IAAA;AAAA,IAAC,MAAA;AAAA,IAAA;AAAA,MACC,QAAA,EAAU,YAAA;AAAA,MACV,SAAA,EAAW,EAAA,CAAG,4BAAA,EAA8B,SAAS,CAAA;AAAA,MACpD,GAAG,SAAA;AAAA,MAEJ,QAAA,EAAA;AAAA,wBAAA,IAAA,CAAC,SAAA,EAAA,EACC,QAAA,EAAA;AAAA,0BAAA,GAAA,CAAC,SAAA,CAAU,KAAA,EAAV,EAAgB,QAAA,EAAA,OAAA,EAAK,CAAA;AAAA,0BACtB,GAAA,CAAC,SAAA,CAAU,OAAA,EAAV,EACC,QAAA,kBAAA,GAAA;AAAA,YAAC,KAAA;AAAA,YAAA;AAAA,cACC,KAAA,EAAO,KAAA;AAAA,cACP,UAAU,CAAC,CAAA,KAAM,QAAA,CAAS,CAAA,CAAE,OAAO,KAAK,CAAA;AAAA,cACxC,WAAA,EAAY,iCAAA;AAAA,cACZ,QAAA,EAAQ;AAAA;AAAA,WACV,EACF,CAAA;AAAA,0BACA,GAAA,CAAC,SAAA,CAAU,IAAA,EAAV,EAAe,QAAA,EAAA,0DAAA,EAAwD;AAAA,SAAA,EAC1E,CAAA;AAAA,wBAEA,IAAA,CAAC,SAAA,EAAA,EAAU,SAAA,EAAU,QAAA,EACnB,QAAA,EAAA;AAAA,0BAAA,GAAA,CAAC,SAAA,CAAU,KAAA,EAAV,EAAgB,QAAA,EAAA,iBAAA,EAAe,CAAA;AAAA,0BAChC,GAAA,CAAC,SAAA,CAAU,OAAA,EAAV,EACC,QAAA,kBAAA,GAAA;AAAA,YAAC,QAAA;AAAA,YAAA;AAAA,cACC,KAAA,EAAO,IAAA;AAAA,cACP,UAAU,CAAC,CAAA,KAAM,OAAA,CAAQ,CAAA,CAAE,OAAO,KAAK,CAAA;AAAA,cACvC,IAAA,EAAM,CAAA;AAAA,cACN,WAAA,EAAY,yEAAA;AAAA,cACZ,QAAA,EAAQ,IAAA;AAAA,cACR,SAAA,EAAU;AAAA;AAAA,WACZ,EACF,CAAA;AAAA,0BACA,GAAA,CAAC,SAAA,CAAU,IAAA,EAAV,EAAe,QAAA,EAAA,2CAAA,EAAyC;AAAA,SAAA,EAC3D,CAAA;AAAA,wBAEA,IAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAU,wBAAA,EACb,QAAA,EAAA;AAAA,0BAAA,IAAA,CAAC,SAAA,EAAA,EACC,QAAA,EAAA;AAAA,4BAAA,GAAA,CAAC,SAAA,CAAU,KAAA,EAAV,EAAgB,QAAA,EAAA,OAAA,EAAK,CAAA;AAAA,4BACtB,GAAA,CAAC,SAAA,CAAU,OAAA,EAAV,EACC,QAAA,kBAAA,IAAA;AAAA,cAAC,MAAA;AAAA,cAAA;AAAA,gBACC,KAAA,EAAO,KAAA;AAAA,gBACP,aAAA,EAAe,CAAC,CAAA,KAAM;AAGpB,kBAAA,MAAM,OAAO,MAAA,CAAO,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,OAAO,CAAC,CAAA;AAC1C,kBAAA,IAAI,IAAA,EAAM,QAAA,CAAS,IAAA,CAAK,EAAE,CAAA;AAAA,gBAC5B,CAAA;AAAA,gBAEA,QAAA,EAAA;AAAA,kCAAA,GAAA,CAAC,MAAA,CAAO,SAAP,EAAe,YAAA,EAAW,qBACzB,QAAA,kBAAA,GAAA,CAAC,MAAA,CAAO,KAAA,EAAP,EAAa,CAAA,EAChB,CAAA;AAAA,kCACA,GAAA,CAAC,OAAO,OAAA,EAAP,EACE,iBAAO,GAAA,CAAI,CAAC,sBACX,GAAA,CAAC,MAAA,CAAO,MAAP,EAAuB,KAAA,EAAO,EAAE,EAAA,EAC9B,QAAA,EAAA,CAAA,CAAE,SADa,CAAA,CAAE,EAEpB,CACD,CAAA,EACH;AAAA;AAAA;AAAA,aACF,EACF;AAAA,WAAA,EACF,CAAA;AAAA,+BACC,SAAA,EAAA,EACC,QAAA,EAAA;AAAA,4BAAA,GAAA,CAAC,SAAA,CAAU,KAAA,EAAV,EAAgB,QAAA,EAAA,wBAAA,EAAsB,CAAA;AAAA,4BACvC,GAAA,CAAC,SAAA,CAAU,OAAA,EAAV,EACC,QAAA,kBAAA,GAAA;AAAA,cAAC,KAAA;AAAA,cAAA;AAAA,gBACC,KAAA,EAAO,OAAA;AAAA,gBACP,UAAU,CAAC,CAAA,KAAM,UAAA,CAAW,CAAA,CAAE,OAAO,KAAK,CAAA;AAAA,gBAC1C,WAAA,EAAY;AAAA;AAAA,aACd,EACF;AAAA,WAAA,EACF;AAAA,SAAA,EACF,CAAA;AAAA,6BAEC,SAAA,EAAA,EACC,QAAA,EAAA;AAAA,0BAAA,GAAA,CAAC,SAAA,CAAU,KAAA,EAAV,EAAgB,QAAA,EAAA,cAAA,EAAY,CAAA;AAAA,8BAC5B,KAAA,EAAA,EAAI,SAAA,EAAU,0BACZ,QAAA,EAAA,SAAA,CAAU,GAAA,CAAI,CAAC,CAAA,KAAM;AACpB,YAAA,MAAM,EAAA,GAAK,KAAA,CAAM,QAAA,CAAS,CAAC,CAAA;AAC3B,YAAA,uBACE,GAAA;AAAA,cAAC,QAAA;AAAA,cAAA;AAAA,gBAEC,IAAA,EAAK,QAAA;AAAA,gBACL,OAAA,EAAS,MAAM,UAAA,CAAW,CAAC,CAAA;AAAA,gBAC3B,cAAA,EAAc,EAAA;AAAA,gBACd,SAAA,EAAW,EAAA;AAAA,kBACT,gGAAA;AAAA,kBACA,KACI,2CAAA,GACA;AAAA,iBACN;AAAA,gBAEC,qBAAW,CAAC;AAAA,eAAA;AAAA,cAXR;AAAA,aAYP;AAAA,UAEJ,CAAC,CAAA,EACH,CAAA;AAAA,0BACA,GAAA,CAAC,UAAU,IAAA,EAAV,EACE,gBAAM,MAAA,KAAW,CAAA,GACd,4CACA,CAAA,iBAAA,EAAoB,KAAA,CAAM,IAAI,CAAC,CAAA,KAAM,WAAW,CAAC,CAAC,EAAE,IAAA,CAAK,IAAI,CAAC,CAAA,CAAA,CAAA,EACpE;AAAA,SAAA,EACF,CAAA;AAAA,wBAEA,IAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAU,yBAAA,EACb,QAAA,EAAA;AAAA,0BAAA,GAAA;AAAA,YAAC,MAAA;AAAA,YAAA;AAAA,cACC,SAAS,OAAA,KAAY,SAAA;AAAA,cACrB,iBAAiB,CAAC,CAAA,KAAM,UAAA,CAAW,CAAA,GAAI,YAAY,UAAU,CAAA;AAAA,cAC7D,YAAA,EAAW;AAAA;AAAA,WACb;AAAA,8BACC,MAAA,EAAA,EAAK,SAAA,EAAU,sCACb,QAAA,EAAA,OAAA,KAAY,SAAA,GACT,gDACA,mCAAA,EACN;AAAA,SAAA,EACF,CAAA;AAAA,wBAEA,IAAA,CAAC,QAAA,EAAA,EAAO,SAAA,EAAU,wEAAA,EAChB,QAAA,EAAA;AAAA,0BAAA,GAAA,CAAC,KAAA,EAAA,EACE,QAAA,EAAA,QAAA,mBACC,GAAA,CAAC,MAAA,EAAA,EAAO,IAAA,EAAK,QAAA,EAAS,OAAA,EAAQ,OAAA,EAAQ,OAAA,EAAS,QAAA,EAAU,QAAA,EAAA,QAAA,EAEzD,CAAA,GACE,IAAA,EACN,CAAA;AAAA,0BACA,IAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAU,yBAAA,EACZ,QAAA,EAAA;AAAA,YAAA,QAAA,mBACC,GAAA,CAAC,UAAO,IAAA,EAAK,QAAA,EAAS,SAAQ,WAAA,EAAY,OAAA,EAAS,QAAA,EAAU,QAAA,EAAA,QAAA,EAE7D,CAAA,GACE,IAAA;AAAA,4BACJ,GAAA,CAAC,MAAA,EAAA,EAAO,IAAA,EAAK,QAAA,EAAS,QAAA,EAAU,CAAC,OAAA,EAC9B,QAAA,EAAA,OAAA,EAAS,EAAA,GAAK,cAAA,GAAiB,aAAA,EAClC;AAAA,WAAA,EACF;AAAA,SAAA,EACF;AAAA;AAAA;AAAA,GACF;AAEJ","file":"chunk-TNBJ36XJ.js","sourcesContent":["import { useState } from \"react\";\nimport type { FormEvent, HTMLAttributes } from \"react\";\nimport { cn } from \"../../../lib/cn.js\";\nimport { ALL_MODES, MODE_LABEL, type Mode } from \"../../../types/mode.js\";\nimport type { Rule, RuleScope, RuleState } from \"../../../types/rule.js\";\nimport { Button } from \"../../primitives/button/index.js\";\nimport { FormField } from \"../../primitives/form-field/index.js\";\nimport { Input } from \"../../primitives/input/index.js\";\nimport { Select } from \"../../primitives/select/index.js\";\nimport { Switch } from \"../../primitives/switch/index.js\";\nimport { Textarea } from \"../../primitives/textarea/index.js\";\n\n/**\n * RuleEditor — form for creating or editing a Rule (behavior instruction\n * injected into the system prompt).\n */\n\ntype RuleDraft = Omit<Rule, \"id\" | \"updatedAt\"> & {\n id?: string;\n tags?: string[];\n};\n\ninterface RuleEditorProps extends Omit<HTMLAttributes<HTMLFormElement>, \"onSubmit\" | \"onChange\"> {\n initial?: Partial<Rule>;\n onSave: (draft: RuleDraft) => void;\n onCancel?: () => void;\n onDelete?: () => void;\n}\n\nconst SCOPES: Array<{ id: RuleScope; label: string }> = [\n { id: \"global\", label: \"Global — applies to every session\" },\n { id: \"project\", label: \"Project — only this workspace\" },\n];\n\nexport function RuleEditor({\n className,\n initial,\n onSave,\n onCancel,\n onDelete,\n ...formProps\n}: RuleEditorProps) {\n const [title, setTitle] = useState(initial?.title ?? \"\");\n const [body, setBody] = useState(initial?.body ?? \"\");\n const [scope, setScope] = useState<RuleScope>(initial?.scope ?? \"global\");\n const [tagsRaw, setTagsRaw] = useState(initial?.tags?.join(\", \") ?? \"\");\n const [enabled, setEnabled] = useState<RuleState>(initial?.state ?? \"enabled\");\n const [modes, setModes] = useState<Mode[]>(initial?.modes ?? []);\n\n // Note: state is only seeded once on mount. To reset the form when editing\n // a different rule, use the React `key` pattern at the call site:\n // <RuleEditor key={rule.id} initial={rule} ... />\n const toggleMode = (m: Mode) =>\n setModes((prev) => (prev.includes(m) ? prev.filter((x) => x !== m) : [...prev, m]));\n\n const canSave = title.trim().length > 0 && body.trim().length > 0;\n const handleSubmit = (e: FormEvent) => {\n e.preventDefault();\n if (!canSave) return;\n onSave({\n id: initial?.id,\n title: title.trim(),\n body: body.trim(),\n scope,\n state: enabled,\n tags: tagsRaw\n .split(\",\")\n .map((t) => t.trim())\n .filter(Boolean),\n modes: modes.length > 0 ? modes : undefined,\n });\n };\n\n return (\n <form\n onSubmit={handleSubmit}\n className={cn(\"flex h-full flex-col gap-4\", className)}\n {...formProps}\n >\n <FormField>\n <FormField.Label>Title</FormField.Label>\n <FormField.Control>\n <Input\n value={title}\n onChange={(e) => setTitle(e.target.value)}\n placeholder=\"Always write tests before fixes\"\n required\n />\n </FormField.Control>\n <FormField.Hint>Short, imperative summary the agent will keep in memory.</FormField.Hint>\n </FormField>\n\n <FormField className=\"flex-1\">\n <FormField.Label>Body (markdown)</FormField.Label>\n <FormField.Control>\n <Textarea\n value={body}\n onChange={(e) => setBody(e.target.value)}\n rows={8}\n placeholder=\"When fixing a bug, first write a failing regression test, then the fix.\"\n required\n className=\"min-h-[12rem] flex-1 font-mono text-code-sm\"\n />\n </FormField.Control>\n <FormField.Hint>Injected into the system prompt verbatim.</FormField.Hint>\n </FormField>\n\n <div className=\"grid grid-cols-2 gap-3\">\n <FormField>\n <FormField.Label>Scope</FormField.Label>\n <FormField.Control>\n <Select\n value={scope}\n onValueChange={(v) => {\n // Re-audit Issue 7: narrow Select string value against\n // SCOPES.id before casting. Silent no-op for unknown.\n const next = SCOPES.find((s) => s.id === v);\n if (next) setScope(next.id);\n }}\n >\n <Select.Trigger aria-label=\"Select rule scope\">\n <Select.Value />\n </Select.Trigger>\n <Select.Content>\n {SCOPES.map((s) => (\n <Select.Item key={s.id} value={s.id}>\n {s.label}\n </Select.Item>\n ))}\n </Select.Content>\n </Select>\n </FormField.Control>\n </FormField>\n <FormField>\n <FormField.Label>Tags (comma-separated)</FormField.Label>\n <FormField.Control>\n <Input\n value={tagsRaw}\n onChange={(e) => setTagsRaw(e.target.value)}\n placeholder=\"testing, process\"\n />\n </FormField.Control>\n </FormField>\n </div>\n\n <FormField>\n <FormField.Label>Active modes</FormField.Label>\n <div className=\"flex flex-wrap gap-1.5\">\n {ALL_MODES.map((m) => {\n const on = modes.includes(m);\n return (\n <button\n key={m}\n type=\"button\"\n onClick={() => toggleMode(m)}\n aria-pressed={on}\n className={cn(\n \"inline-flex h-7 items-center rounded-full border px-3 font-mono text-body-sm transition-colors\",\n on\n ? \"border-primary bg-primary/15 text-primary\"\n : \"border-border/60 bg-card text-muted-foreground hover:text-foreground\",\n )}\n >\n {MODE_LABEL[m]}\n </button>\n );\n })}\n </div>\n <FormField.Hint>\n {modes.length === 0\n ? \"Empty = global (applies to every mode).\"\n : `Only visible in: ${modes.map((m) => MODE_LABEL[m]).join(\", \")}.`}\n </FormField.Hint>\n </FormField>\n\n <div className=\"flex items-center gap-3\">\n <Switch\n checked={enabled === \"enabled\"}\n onCheckedChange={(v) => setEnabled(v ? \"enabled\" : \"disabled\")}\n aria-label=\"Enabled\"\n />\n <span className=\"text-body-sm text-muted-foreground\">\n {enabled === \"enabled\"\n ? \"Enabled — agent will follow this rule.\"\n : \"Disabled — kept but ignored.\"}\n </span>\n </div>\n\n <footer className=\"flex items-center justify-between gap-2 border-border/40 border-t pt-4\">\n <div>\n {onDelete ? (\n <Button type=\"button\" variant=\"ghost\" onClick={onDelete}>\n Delete\n </Button>\n ) : null}\n </div>\n <div className=\"flex items-center gap-2\">\n {onCancel ? (\n <Button type=\"button\" variant=\"secondary\" onClick={onCancel}>\n Cancel\n </Button>\n ) : null}\n <Button type=\"submit\" disabled={!canSave}>\n {initial?.id ? \"Save changes\" : \"Create rule\"}\n </Button>\n </div>\n </footer>\n </form>\n );\n}\n"]}
@@ -0,0 +1,221 @@
1
+ import { ALL_MODES, MODE_LABEL } from './chunk-VM4RMQQN.js';
2
+ import { Textarea } from './chunk-WWNH5ENT.js';
3
+ import { Select } from './chunk-EP25QJ4N.js';
4
+ import { FormField } from './chunk-TK24HQJJ.js';
5
+ import { Input } from './chunk-H3VJMFJQ.js';
6
+ import { Button } from './chunk-57NXT3OX.js';
7
+ import { cn } from './chunk-ZSRJCIWF.js';
8
+ import { useState } from 'react';
9
+ import { jsxs, jsx } from 'react/jsx-runtime';
10
+
11
+ var TONES = [
12
+ { id: "primary", label: "Primary (violet)" },
13
+ { id: "accent", label: "Accent (sienna)" },
14
+ { id: "success", label: "Success (green)" },
15
+ { id: "warning", label: "Warning (amber)" },
16
+ { id: "info", label: "Info (blue)" },
17
+ { id: "muted", label: "Muted (neutral)" }
18
+ ];
19
+ function AgentEditor({
20
+ className,
21
+ initial,
22
+ models,
23
+ skills,
24
+ onSave,
25
+ onCancel,
26
+ onDelete,
27
+ ...formProps
28
+ }) {
29
+ const [name, setName] = useState(initial?.name ?? "");
30
+ const [initials, setInitials] = useState(initial?.initials ?? "");
31
+ const [description, setDescription] = useState(
32
+ typeof initial?.description === "string" ? initial.description : ""
33
+ );
34
+ const [tone, setTone] = useState(
35
+ initial?.tone ?? "primary"
36
+ );
37
+ const [model, setModel] = useState(initial?.model ?? models?.[0]?.id ?? "");
38
+ const [systemPrompt, setSystemPrompt] = useState(initial?.systemPrompt ?? "");
39
+ const [allowedToolsRaw, setAllowedToolsRaw] = useState(initial?.allowedTools?.join(", ") ?? "");
40
+ const [skillsSelected, setSkillsSelected] = useState(
41
+ new Set(initial?.skillIds ?? [])
42
+ );
43
+ const [modes, setModes] = useState(initial?.modes ?? []);
44
+ const toggleMode = (m) => setModes((prev) => prev.includes(m) ? prev.filter((x) => x !== m) : [...prev, m]);
45
+ const canSave = name.trim().length > 0;
46
+ const handleSubmit = (e) => {
47
+ e.preventDefault();
48
+ if (!canSave) return;
49
+ onSave({
50
+ id: initial?.id,
51
+ name: name.trim(),
52
+ initials: initials.trim() || void 0,
53
+ description: description.trim() || void 0,
54
+ tone,
55
+ model: model || void 0,
56
+ systemPrompt: systemPrompt.trim() || void 0,
57
+ allowedTools: allowedToolsRaw.split(",").map((t) => t.trim()).filter(Boolean),
58
+ skillIds: Array.from(skillsSelected),
59
+ modes: modes.length > 0 ? modes : void 0
60
+ });
61
+ };
62
+ const toggleSkill = (id) => {
63
+ setSkillsSelected((prev) => {
64
+ const next = new Set(prev);
65
+ if (next.has(id)) next.delete(id);
66
+ else next.add(id);
67
+ return next;
68
+ });
69
+ };
70
+ return /* @__PURE__ */ jsxs(
71
+ "form",
72
+ {
73
+ onSubmit: handleSubmit,
74
+ className: cn("flex h-full flex-col gap-4", className),
75
+ ...formProps,
76
+ children: [
77
+ /* @__PURE__ */ jsxs("div", { className: "grid grid-cols-[1fr_auto] gap-3", children: [
78
+ /* @__PURE__ */ jsxs(FormField, { children: [
79
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Name" }),
80
+ /* @__PURE__ */ jsx(FormField.Control, { children: /* @__PURE__ */ jsx(
81
+ Input,
82
+ {
83
+ value: name,
84
+ onChange: (e) => setName(e.target.value),
85
+ placeholder: "Coder",
86
+ required: true
87
+ }
88
+ ) })
89
+ ] }),
90
+ /* @__PURE__ */ jsxs(FormField, { className: "w-24", children: [
91
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Initials" }),
92
+ /* @__PURE__ */ jsx(FormField.Control, { children: /* @__PURE__ */ jsx(
93
+ Input,
94
+ {
95
+ value: initials,
96
+ onChange: (e) => setInitials(e.target.value.slice(0, 2).toUpperCase()),
97
+ placeholder: "CO",
98
+ maxLength: 2,
99
+ className: "text-center font-mono uppercase"
100
+ }
101
+ ) })
102
+ ] })
103
+ ] }),
104
+ /* @__PURE__ */ jsxs(FormField, { children: [
105
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Description" }),
106
+ /* @__PURE__ */ jsx(FormField.Control, { children: /* @__PURE__ */ jsx(
107
+ Input,
108
+ {
109
+ value: description,
110
+ onChange: (e) => setDescription(e.target.value),
111
+ placeholder: "Writes code, edits files, runs verification."
112
+ }
113
+ ) })
114
+ ] }),
115
+ /* @__PURE__ */ jsxs("div", { className: "grid grid-cols-2 gap-3", children: [
116
+ /* @__PURE__ */ jsxs(FormField, { children: [
117
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Tone" }),
118
+ /* @__PURE__ */ jsx(FormField.Control, { children: /* @__PURE__ */ jsxs(
119
+ Select,
120
+ {
121
+ value: tone,
122
+ onValueChange: (v) => {
123
+ const next = TONES.find((t) => t.id === v);
124
+ if (next) setTone(next.id);
125
+ },
126
+ children: [
127
+ /* @__PURE__ */ jsx(Select.Trigger, { "aria-label": "Select tone", children: /* @__PURE__ */ jsx(Select.Value, {}) }),
128
+ /* @__PURE__ */ jsx(Select.Content, { children: TONES.map((t) => /* @__PURE__ */ jsx(Select.Item, { value: t.id, children: t.label }, t.id)) })
129
+ ]
130
+ }
131
+ ) })
132
+ ] }),
133
+ models && models.length > 0 ? /* @__PURE__ */ jsxs(FormField, { children: [
134
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Model" }),
135
+ /* @__PURE__ */ jsx(FormField.Control, { children: /* @__PURE__ */ jsxs(Select, { value: model, onValueChange: setModel, children: [
136
+ /* @__PURE__ */ jsx(Select.Trigger, { "aria-label": "Select model", children: /* @__PURE__ */ jsx(Select.Value, {}) }),
137
+ /* @__PURE__ */ jsx(Select.Content, { children: models.map((m) => /* @__PURE__ */ jsx(Select.Item, { value: m.id, children: m.label }, m.id)) })
138
+ ] }) })
139
+ ] }) : null
140
+ ] }),
141
+ /* @__PURE__ */ jsxs(FormField, { className: "flex-1", children: [
142
+ /* @__PURE__ */ jsx(FormField.Label, { children: "System prompt override" }),
143
+ /* @__PURE__ */ jsx(FormField.Control, { children: /* @__PURE__ */ jsx(
144
+ Textarea,
145
+ {
146
+ value: systemPrompt,
147
+ onChange: (e) => setSystemPrompt(e.target.value),
148
+ rows: 6,
149
+ placeholder: "You are the Coder. You write code, edit files, and run verification\u2026",
150
+ className: "min-h-[10rem] flex-1 font-mono text-code-sm"
151
+ }
152
+ ) }),
153
+ /* @__PURE__ */ jsx(FormField.Hint, { children: "Leave empty to inherit the workspace default." })
154
+ ] }),
155
+ /* @__PURE__ */ jsxs(FormField, { children: [
156
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Allowed tools" }),
157
+ /* @__PURE__ */ jsx(FormField.Control, { children: /* @__PURE__ */ jsx(
158
+ Input,
159
+ {
160
+ value: allowedToolsRaw,
161
+ onChange: (e) => setAllowedToolsRaw(e.target.value),
162
+ placeholder: "Read, Edit, Bash"
163
+ }
164
+ ) })
165
+ ] }),
166
+ skills && skills.length > 0 ? /* @__PURE__ */ jsxs(FormField, { children: [
167
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Linked skills" }),
168
+ /* @__PURE__ */ jsx("div", { className: "flex flex-wrap gap-1.5", children: skills.map((s) => {
169
+ const on = skillsSelected.has(s.id);
170
+ return /* @__PURE__ */ jsx(
171
+ "button",
172
+ {
173
+ type: "button",
174
+ onClick: () => toggleSkill(s.id),
175
+ "aria-pressed": on,
176
+ className: cn(
177
+ "inline-flex h-7 items-center rounded-full border px-3 font-mono text-body-sm transition-colors",
178
+ on ? "border-primary bg-primary/15 text-primary" : "border-border/60 bg-card text-muted-foreground hover:text-foreground"
179
+ ),
180
+ children: s.label
181
+ },
182
+ s.id
183
+ );
184
+ }) })
185
+ ] }) : null,
186
+ /* @__PURE__ */ jsxs(FormField, { children: [
187
+ /* @__PURE__ */ jsx(FormField.Label, { children: "Active modes" }),
188
+ /* @__PURE__ */ jsx("div", { className: "flex flex-wrap gap-1.5", children: ALL_MODES.map((m) => {
189
+ const on = modes.includes(m);
190
+ return /* @__PURE__ */ jsx(
191
+ "button",
192
+ {
193
+ type: "button",
194
+ onClick: () => toggleMode(m),
195
+ "aria-pressed": on,
196
+ className: cn(
197
+ "inline-flex h-7 items-center rounded-full border px-3 font-mono text-body-sm transition-colors",
198
+ on ? "border-primary bg-primary/15 text-primary" : "border-border/60 bg-card text-muted-foreground hover:text-foreground"
199
+ ),
200
+ children: MODE_LABEL[m]
201
+ },
202
+ m
203
+ );
204
+ }) }),
205
+ /* @__PURE__ */ jsx(FormField.Hint, { children: modes.length === 0 ? "Empty = global (available in every mode)." : `Only visible in: ${modes.map((m) => MODE_LABEL[m]).join(", ")}.` })
206
+ ] }),
207
+ /* @__PURE__ */ jsxs("footer", { className: "flex items-center justify-between gap-2 border-border/40 border-t pt-4", children: [
208
+ /* @__PURE__ */ jsx("div", { children: onDelete ? /* @__PURE__ */ jsx(Button, { type: "button", variant: "ghost", onClick: onDelete, children: "Delete" }) : null }),
209
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
210
+ onCancel ? /* @__PURE__ */ jsx(Button, { type: "button", variant: "secondary", onClick: onCancel, children: "Cancel" }) : null,
211
+ /* @__PURE__ */ jsx(Button, { type: "submit", disabled: !canSave, children: initial?.id ? "Save changes" : "Create agent" })
212
+ ] })
213
+ ] })
214
+ ]
215
+ }
216
+ );
217
+ }
218
+
219
+ export { AgentEditor };
220
+ //# sourceMappingURL=chunk-TO3UAT6O.js.map
221
+ //# sourceMappingURL=chunk-TO3UAT6O.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/composites/agent-editor/agent-editor.tsx"],"names":[],"mappings":"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","file":"chunk-TO3UAT6O.js","sourcesContent":["import { useState } from \"react\";\nimport type { FormEvent, HTMLAttributes } from \"react\";\nimport { cn } from \"../../../lib/cn.js\";\nimport { ALL_MODES, MODE_LABEL, type Mode } from \"../../../types/mode.js\";\nimport type { AgentProfileDescriptor } from \"../../primitives/agent-profile/index.js\";\nimport { Button } from \"../../primitives/button/index.js\";\nimport { FormField } from \"../../primitives/form-field/index.js\";\nimport { Input } from \"../../primitives/input/index.js\";\nimport { Select } from \"../../primitives/select/index.js\";\nimport { Textarea } from \"../../primitives/textarea/index.js\";\n\n/**\n * AgentEditor — form for creating or editing an Agent persona.\n */\n\nexport interface AgentDraft extends Omit<AgentProfileDescriptor, \"id\"> {\n id?: string;\n systemPrompt?: string;\n model?: string;\n allowedTools?: string[];\n skillIds?: string[];\n /** Modes this agent is visible in. Omit / empty = global (all modes). */\n modes?: Mode[];\n}\n\ninterface AgentEditorProps extends Omit<HTMLAttributes<HTMLFormElement>, \"onSubmit\" | \"onChange\"> {\n initial?: Partial<AgentDraft>;\n models?: Array<{ id: string; label: string }>;\n skills?: Array<{ id: string; label: string }>;\n onSave: (draft: AgentDraft) => void;\n onCancel?: () => void;\n onDelete?: () => void;\n}\n\nconst TONES: Array<{ id: NonNullable<AgentProfileDescriptor[\"tone\"]>; label: string }> = [\n { id: \"primary\", label: \"Primary (violet)\" },\n { id: \"accent\", label: \"Accent (sienna)\" },\n { id: \"success\", label: \"Success (green)\" },\n { id: \"warning\", label: \"Warning (amber)\" },\n { id: \"info\", label: \"Info (blue)\" },\n { id: \"muted\", label: \"Muted (neutral)\" },\n];\n\nexport function AgentEditor({\n className,\n initial,\n models,\n skills,\n onSave,\n onCancel,\n onDelete,\n ...formProps\n}: AgentEditorProps) {\n const [name, setName] = useState(initial?.name ?? \"\");\n const [initials, setInitials] = useState(initial?.initials ?? \"\");\n const [description, setDescription] = useState(\n typeof initial?.description === \"string\" ? initial.description : \"\",\n );\n const [tone, setTone] = useState<NonNullable<AgentProfileDescriptor[\"tone\"]>>(\n initial?.tone ?? \"primary\",\n );\n const [model, setModel] = useState<string>(initial?.model ?? models?.[0]?.id ?? \"\");\n const [systemPrompt, setSystemPrompt] = useState(initial?.systemPrompt ?? \"\");\n const [allowedToolsRaw, setAllowedToolsRaw] = useState(initial?.allowedTools?.join(\", \") ?? \"\");\n const [skillsSelected, setSkillsSelected] = useState<Set<string>>(\n new Set(initial?.skillIds ?? []),\n );\n const [modes, setModes] = useState<Mode[]>(initial?.modes ?? []);\n\n // Note: state is only seeded once on mount. To reset the form when editing a\n // different agent, use the React `key` pattern at the call site:\n // <AgentEditor key={agent.id} initial={agent} ... />\n // This is the idiomatic React way (over a useEffect that watches prop deltas\n // and writes setters) — it guarantees a clean component instance per entity.\n const toggleMode = (m: Mode) =>\n setModes((prev) => (prev.includes(m) ? prev.filter((x) => x !== m) : [...prev, m]));\n\n const canSave = name.trim().length > 0;\n const handleSubmit = (e: FormEvent) => {\n e.preventDefault();\n if (!canSave) return;\n onSave({\n id: initial?.id,\n name: name.trim(),\n initials: initials.trim() || undefined,\n description: description.trim() || undefined,\n tone,\n model: model || undefined,\n systemPrompt: systemPrompt.trim() || undefined,\n allowedTools: allowedToolsRaw\n .split(\",\")\n .map((t) => t.trim())\n .filter(Boolean),\n skillIds: Array.from(skillsSelected),\n modes: modes.length > 0 ? modes : undefined,\n });\n };\n\n const toggleSkill = (id: string) => {\n setSkillsSelected((prev) => {\n const next = new Set(prev);\n if (next.has(id)) next.delete(id);\n else next.add(id);\n return next;\n });\n };\n\n return (\n <form\n onSubmit={handleSubmit}\n className={cn(\"flex h-full flex-col gap-4\", className)}\n {...formProps}\n >\n <div className=\"grid grid-cols-[1fr_auto] gap-3\">\n <FormField>\n <FormField.Label>Name</FormField.Label>\n <FormField.Control>\n <Input\n value={name}\n onChange={(e) => setName(e.target.value)}\n placeholder=\"Coder\"\n required\n />\n </FormField.Control>\n </FormField>\n <FormField className=\"w-24\">\n <FormField.Label>Initials</FormField.Label>\n <FormField.Control>\n <Input\n value={initials}\n onChange={(e) => setInitials(e.target.value.slice(0, 2).toUpperCase())}\n placeholder=\"CO\"\n maxLength={2}\n className=\"text-center font-mono uppercase\"\n />\n </FormField.Control>\n </FormField>\n </div>\n\n <FormField>\n <FormField.Label>Description</FormField.Label>\n <FormField.Control>\n <Input\n value={description}\n onChange={(e) => setDescription(e.target.value)}\n placeholder=\"Writes code, edits files, runs verification.\"\n />\n </FormField.Control>\n </FormField>\n\n <div className=\"grid grid-cols-2 gap-3\">\n <FormField>\n <FormField.Label>Tone</FormField.Label>\n <FormField.Control>\n <Select\n value={tone}\n onValueChange={(v) => {\n // Re-audit Issue 7: narrow the string `v` against TONES.id\n // values before casting. Radix Select guarantees `v` is one\n // of the Select.Item values declared below, but adding the\n // runtime guard keeps the type narrowing explicit and\n // surfaces invalid future configurations as no-ops instead\n // of silently writing a bad state.\n const next = TONES.find((t) => t.id === v);\n if (next) setTone(next.id);\n }}\n >\n <Select.Trigger aria-label=\"Select tone\">\n <Select.Value />\n </Select.Trigger>\n <Select.Content>\n {TONES.map((t) => (\n <Select.Item key={t.id} value={t.id}>\n {t.label}\n </Select.Item>\n ))}\n </Select.Content>\n </Select>\n </FormField.Control>\n </FormField>\n {models && models.length > 0 ? (\n <FormField>\n <FormField.Label>Model</FormField.Label>\n <FormField.Control>\n <Select value={model} onValueChange={setModel}>\n <Select.Trigger aria-label=\"Select model\">\n <Select.Value />\n </Select.Trigger>\n <Select.Content>\n {models.map((m) => (\n <Select.Item key={m.id} value={m.id}>\n {m.label}\n </Select.Item>\n ))}\n </Select.Content>\n </Select>\n </FormField.Control>\n </FormField>\n ) : null}\n </div>\n\n <FormField className=\"flex-1\">\n <FormField.Label>System prompt override</FormField.Label>\n <FormField.Control>\n <Textarea\n value={systemPrompt}\n onChange={(e) => setSystemPrompt(e.target.value)}\n rows={6}\n placeholder=\"You are the Coder. You write code, edit files, and run verification…\"\n className=\"min-h-[10rem] flex-1 font-mono text-code-sm\"\n />\n </FormField.Control>\n <FormField.Hint>Leave empty to inherit the workspace default.</FormField.Hint>\n </FormField>\n\n <FormField>\n <FormField.Label>Allowed tools</FormField.Label>\n <FormField.Control>\n <Input\n value={allowedToolsRaw}\n onChange={(e) => setAllowedToolsRaw(e.target.value)}\n placeholder=\"Read, Edit, Bash\"\n />\n </FormField.Control>\n </FormField>\n\n {skills && skills.length > 0 ? (\n <FormField>\n <FormField.Label>Linked skills</FormField.Label>\n <div className=\"flex flex-wrap gap-1.5\">\n {skills.map((s) => {\n const on = skillsSelected.has(s.id);\n return (\n <button\n key={s.id}\n type=\"button\"\n onClick={() => toggleSkill(s.id)}\n aria-pressed={on}\n className={cn(\n \"inline-flex h-7 items-center rounded-full border px-3 font-mono text-body-sm transition-colors\",\n on\n ? \"border-primary bg-primary/15 text-primary\"\n : \"border-border/60 bg-card text-muted-foreground hover:text-foreground\",\n )}\n >\n {s.label}\n </button>\n );\n })}\n </div>\n </FormField>\n ) : null}\n\n <FormField>\n <FormField.Label>Active modes</FormField.Label>\n <div className=\"flex flex-wrap gap-1.5\">\n {ALL_MODES.map((m) => {\n const on = modes.includes(m);\n return (\n <button\n key={m}\n type=\"button\"\n onClick={() => toggleMode(m)}\n aria-pressed={on}\n className={cn(\n \"inline-flex h-7 items-center rounded-full border px-3 font-mono text-body-sm transition-colors\",\n on\n ? \"border-primary bg-primary/15 text-primary\"\n : \"border-border/60 bg-card text-muted-foreground hover:text-foreground\",\n )}\n >\n {MODE_LABEL[m]}\n </button>\n );\n })}\n </div>\n <FormField.Hint>\n {modes.length === 0\n ? \"Empty = global (available in every mode).\"\n : `Only visible in: ${modes.map((m) => MODE_LABEL[m]).join(\", \")}.`}\n </FormField.Hint>\n </FormField>\n\n <footer className=\"flex items-center justify-between gap-2 border-border/40 border-t pt-4\">\n <div>\n {onDelete ? (\n <Button type=\"button\" variant=\"ghost\" onClick={onDelete}>\n Delete\n </Button>\n ) : null}\n </div>\n <div className=\"flex items-center gap-2\">\n {onCancel ? (\n <Button type=\"button\" variant=\"secondary\" onClick={onCancel}>\n Cancel\n </Button>\n ) : null}\n <Button type=\"submit\" disabled={!canSave}>\n {initial?.id ? \"Save changes\" : \"Create agent\"}\n </Button>\n </div>\n </footer>\n </form>\n );\n}\n"]}
@@ -0,0 +1,77 @@
1
+ import { cn } from './chunk-ZSRJCIWF.js';
2
+ import { TrendingDown, TrendingUp } from 'lucide-react';
3
+ import { forwardRef } from 'react';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ var MetricsPanel = forwardRef(
7
+ ({ className, title, description, metrics, columns, ...props }, ref) => /* @__PURE__ */ jsxs("div", { ref, className: cn("rounded-xl border bg-card p-5 shadow-sm", className), ...props, children: [
8
+ title || description ? /* @__PURE__ */ jsxs("header", { className: "mb-4 grid gap-0.5", children: [
9
+ title ? /* @__PURE__ */ jsx("h3", { className: "font-display text-title-md tracking-tight", children: title }) : null,
10
+ description ? /* @__PURE__ */ jsx("p", { className: "text-body-sm text-muted-foreground", children: description }) : null
11
+ ] }) : null,
12
+ /* @__PURE__ */ jsx(
13
+ "div",
14
+ {
15
+ className: "grid gap-4",
16
+ style: {
17
+ gridTemplateColumns: columns ? `repeat(${columns}, minmax(0, 1fr))` : "repeat(auto-fit, minmax(180px, 1fr))"
18
+ },
19
+ children: metrics.map((m) => /* @__PURE__ */ jsx(Tile, { metric: m }, m.label))
20
+ }
21
+ )
22
+ ] })
23
+ );
24
+ MetricsPanel.displayName = "MetricsPanel";
25
+ function Tile({ metric }) {
26
+ const interactive = metric.onClick !== void 0;
27
+ const Tag = interactive ? "button" : "div";
28
+ const ariaLabel = interactive ? metric.actionLabel ?? `View ${metric.label} details` : void 0;
29
+ return /* @__PURE__ */ jsxs(
30
+ Tag,
31
+ {
32
+ type: interactive ? "button" : void 0,
33
+ onClick: metric.onClick,
34
+ "aria-label": ariaLabel,
35
+ className: cn(
36
+ "flex flex-col gap-2 rounded-lg border border-border/30 bg-muted/30 p-4 text-left",
37
+ "transition-colors duration-base ease-out-soft",
38
+ interactive && "hover:border-primary/40 hover:bg-muted/60 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-offset-card"
39
+ ),
40
+ children: [
41
+ /* @__PURE__ */ jsx("span", { className: "font-sans text-label-caps text-muted-foreground uppercase", children: metric.label }),
42
+ /* @__PURE__ */ jsxs("div", { className: "flex items-baseline gap-1.5", children: [
43
+ /* @__PURE__ */ jsx("span", { className: "font-bold font-display text-display-md tabular-nums leading-none", children: metric.value }),
44
+ metric.unit ? /* @__PURE__ */ jsx("span", { className: "font-mono text-body-sm text-muted-foreground", children: metric.unit }) : null
45
+ ] }),
46
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
47
+ metric.delta ? /* @__PURE__ */ jsx(Delta, { metric }) : null,
48
+ metric.sparkline && metric.sparkline.length > 0 ? /* @__PURE__ */ jsx(Sparkline, { values: metric.sparkline }) : null
49
+ ] })
50
+ ]
51
+ }
52
+ );
53
+ }
54
+ function Delta({ metric }) {
55
+ const tone = metric.deltaGood === void 0 ? "text-muted-foreground" : metric.deltaGood ? "text-success" : "text-destructive";
56
+ const Icon = metric.deltaGood === false ? TrendingDown : TrendingUp;
57
+ return /* @__PURE__ */ jsxs("span", { className: cn("inline-flex items-center gap-1 font-mono text-body-sm", tone), children: [
58
+ /* @__PURE__ */ jsx(Icon, { className: "size-3" }),
59
+ " ",
60
+ metric.delta
61
+ ] });
62
+ }
63
+ function Sparkline({ values }) {
64
+ const clamped = values.map((v) => Math.max(0, Math.min(1, v)));
65
+ return /* @__PURE__ */ jsx("span", { className: "ml-auto flex h-6 items-end gap-[2px]", "aria-hidden": "true", children: clamped.map((v, idx) => /* @__PURE__ */ jsx(
66
+ "span",
67
+ {
68
+ className: "w-[3px] rounded-sm bg-primary/60",
69
+ style: { height: `${Math.max(8, v * 100)}%` }
70
+ },
71
+ idx
72
+ )) });
73
+ }
74
+
75
+ export { MetricsPanel };
76
+ //# sourceMappingURL=chunk-UAYOOTRR.js.map
77
+ //# sourceMappingURL=chunk-UAYOOTRR.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/primitives/metrics-panel/metrics-panel.tsx"],"names":[],"mappings":";;;;;AAkEA,IAAM,YAAA,GAAe,UAAA;AAAA,EACnB,CAAC,EAAE,SAAA,EAAW,KAAA,EAAO,aAAa,OAAA,EAAS,OAAA,EAAS,GAAG,KAAA,EAAM,EAAG,wBAC9D,IAAA,CAAC,KAAA,EAAA,EAAI,KAAU,SAAA,EAAW,EAAA,CAAG,2CAA2C,SAAS,CAAA,EAAI,GAAG,KAAA,EACrF,QAAA,EAAA;AAAA,IAAA,KAAA,IAAS,WAAA,mBACR,IAAA,CAAC,QAAA,EAAA,EAAO,SAAA,EAAU,mBAAA,EACf,QAAA,EAAA;AAAA,MAAA,KAAA,mBAAQ,GAAA,CAAC,IAAA,EAAA,EAAG,SAAA,EAAU,2CAAA,EAA6C,iBAAM,CAAA,GAAQ,IAAA;AAAA,MACjF,8BAAc,GAAA,CAAC,GAAA,EAAA,EAAE,SAAA,EAAU,oCAAA,EAAsC,uBAAY,CAAA,GAAO;AAAA,KAAA,EACvF,CAAA,GACE,IAAA;AAAA,oBACJ,GAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,SAAA,EAAU,YAAA;AAAA,QACV,KAAA,EAAO;AAAA,UACL,mBAAA,EAAqB,OAAA,GACjB,CAAA,OAAA,EAAU,OAAO,CAAA,iBAAA,CAAA,GACjB;AAAA,SACN;AAAA,QAEC,QAAA,EAAA,OAAA,CAAQ,GAAA,CAAI,CAAC,CAAA,qBACZ,GAAA,CAAC,QAAmB,MAAA,EAAQ,CAAA,EAAA,EAAjB,CAAA,CAAE,KAAkB,CAChC;AAAA;AAAA;AACH,GAAA,EACF;AAEJ;AACA,YAAA,CAAa,WAAA,GAAc,cAAA;AAE3B,SAAS,IAAA,CAAK,EAAE,MAAA,EAAO,EAAuB;AAC5C,EAAA,MAAM,WAAA,GAAc,OAAO,OAAA,KAAY,MAAA;AACvC,EAAA,MAAM,GAAA,GAAM,cAAc,QAAA,GAAW,KAAA;AAKrC,EAAA,MAAM,YAAY,WAAA,GACb,MAAA,CAAO,eAAe,CAAA,KAAA,EAAQ,MAAA,CAAO,KAAK,CAAA,QAAA,CAAA,GAC3C,MAAA;AACJ,EAAA,uBACE,IAAA;AAAA,IAAC,GAAA;AAAA,IAAA;AAAA,MACC,IAAA,EAAM,cAAc,QAAA,GAAW,MAAA;AAAA,MAC/B,SAAS,MAAA,CAAO,OAAA;AAAA,MAChB,YAAA,EAAY,SAAA;AAAA,MACZ,SAAA,EAAW,EAAA;AAAA,QACT,kFAAA;AAAA,QACA,+CAAA;AAAA,QACA,WAAA,IACE;AAAA,OACJ;AAAA,MAEA,QAAA,EAAA;AAAA,wBAAA,GAAA,CAAC,MAAA,EAAA,EAAK,SAAA,EAAU,2DAAA,EACb,QAAA,EAAA,MAAA,CAAO,KAAA,EACV,CAAA;AAAA,wBACA,IAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAU,6BAAA,EACb,QAAA,EAAA;AAAA,0BAAA,GAAA,CAAC,MAAA,EAAA,EAAK,SAAA,EAAU,kEAAA,EACb,QAAA,EAAA,MAAA,CAAO,KAAA,EACV,CAAA;AAAA,UACC,MAAA,CAAO,uBACN,GAAA,CAAC,MAAA,EAAA,EAAK,WAAU,8CAAA,EAAgD,QAAA,EAAA,MAAA,CAAO,MAAK,CAAA,GAC1E;AAAA,SAAA,EACN,CAAA;AAAA,wBACA,IAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAU,yBAAA,EACZ,QAAA,EAAA;AAAA,UAAA,MAAA,CAAO,KAAA,mBAAQ,GAAA,CAAC,KAAA,EAAA,EAAM,MAAA,EAAgB,CAAA,GAAK,IAAA;AAAA,UAC3C,MAAA,CAAO,SAAA,IAAa,MAAA,CAAO,SAAA,CAAU,MAAA,GAAS,CAAA,mBAC7C,GAAA,CAAC,SAAA,EAAA,EAAU,MAAA,EAAQ,MAAA,CAAO,SAAA,EAAW,CAAA,GACnC;AAAA,SAAA,EACN;AAAA;AAAA;AAAA,GACF;AAEJ;AAEA,SAAS,KAAA,CAAM,EAAE,MAAA,EAAO,EAAuB;AAC7C,EAAA,MAAM,OACJ,MAAA,CAAO,SAAA,KAAc,SACjB,uBAAA,GACA,MAAA,CAAO,YACL,cAAA,GACA,kBAAA;AACR,EAAA,MAAM,IAAA,GAAO,MAAA,CAAO,SAAA,KAAc,KAAA,GAAQ,YAAA,GAAe,UAAA;AACzD,EAAA,4BACG,MAAA,EAAA,EAAK,SAAA,EAAW,EAAA,CAAG,uDAAA,EAAyD,IAAI,CAAA,EAC/E,QAAA,EAAA;AAAA,oBAAA,GAAA,CAAC,IAAA,EAAA,EAAK,WAAU,QAAA,EAAS,CAAA;AAAA,IAAE,GAAA;AAAA,IAAE,MAAA,CAAO;AAAA,GAAA,EACtC,CAAA;AAEJ;AAEA,SAAS,SAAA,CAAU,EAAE,MAAA,EAAO,EAAyB;AACnD,EAAA,MAAM,OAAA,GAAU,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA,KAAM,IAAA,CAAK,GAAA,CAAI,CAAA,EAAG,IAAA,CAAK,GAAA,CAAI,CAAA,EAAG,CAAC,CAAC,CAAC,CAAA;AAC7D,EAAA,uBACE,GAAA,CAAC,MAAA,EAAA,EAAK,SAAA,EAAU,sCAAA,EAAuC,aAAA,EAAY,QAChE,QAAA,EAAA,OAAA,CAAQ,GAAA,CAAI,CAAC,CAAA,EAAG,GAAA,qBACf,GAAA;AAAA,IAAC,MAAA;AAAA,IAAA;AAAA,MAGC,SAAA,EAAU,kCAAA;AAAA,MACV,KAAA,EAAO,EAAE,MAAA,EAAQ,CAAA,EAAG,IAAA,CAAK,IAAI,CAAA,EAAG,CAAA,GAAI,GAAG,CAAC,CAAA,CAAA,CAAA;AAAI,KAAA;AAAA,IAFvC;AAAA,GAIR,CAAA,EACH,CAAA;AAEJ","file":"chunk-UAYOOTRR.js","sourcesContent":["import { TrendingDown, TrendingUp } from \"lucide-react\";\nimport { forwardRef } from \"react\";\nimport type { HTMLAttributes, ReactNode } from \"react\";\nimport { cn } from \"../../../lib/cn.js\";\n\nexport interface Metric {\n /**\n * Short label, e.g. \"Requests/s\", \"p95 latency\", \"Error rate\".\n */\n label: string;\n /**\n * Pre-formatted value string, e.g. \"1.2k\", \"182ms\", \"0.03%\".\n * Consumer formats; the component does not parse.\n */\n value: string;\n /**\n * Optional unit suffix appended after value with .9 opacity.\n */\n unit?: string;\n /**\n * Optional change vs comparison period, e.g. \"+12%\", \"-4ms\", \"+0.01pp\".\n */\n delta?: string;\n /**\n * If true, delta is \"good\" (success color); if false, \"bad\" (destructive).\n * If omitted, delta is rendered in muted (neutral).\n *\n * Caller decides semantics — \"more requests\" is good but \"more errors\" is bad.\n */\n deltaGood?: boolean;\n /**\n * Optional sparkline data, 0..1 normalized. Consumer is responsible for normalization.\n */\n sparkline?: number[];\n /**\n * Optional onClick to drill into the metric.\n */\n onClick?: () => void;\n /**\n * Optional override for the clickable tile's accessible name. When the\n * tile is interactive (`onClick` set), defaults to `View <label> details`.\n * Has no effect when `onClick` is absent (tile is rendered as a non-link\n * `<div>` with no button semantics). T4.3.\n */\n actionLabel?: string;\n}\n\ninterface MetricsPanelProps extends Omit<HTMLAttributes<HTMLDivElement>, \"title\"> {\n title?: ReactNode;\n description?: ReactNode;\n metrics: Metric[];\n /**\n * Grid columns. Defaults to auto-fit ~180px min.\n */\n columns?: number;\n}\n\n/**\n * MetricsPanel — grid of metric tiles for observability dashboards.\n *\n * Visual: each tile is a soft surface with a big value (font-display),\n * label uppercase muted, optional delta with arrow icon + tone color,\n * optional CSS-only sparkline drawn as flexed bars.\n *\n * No external chart lib — keeps the registry copy-pasteable.\n */\nconst MetricsPanel = forwardRef<HTMLDivElement, MetricsPanelProps>(\n ({ className, title, description, metrics, columns, ...props }, ref) => (\n <div ref={ref} className={cn(\"rounded-xl border bg-card p-5 shadow-sm\", className)} {...props}>\n {title || description ? (\n <header className=\"mb-4 grid gap-0.5\">\n {title ? <h3 className=\"font-display text-title-md tracking-tight\">{title}</h3> : null}\n {description ? <p className=\"text-body-sm text-muted-foreground\">{description}</p> : null}\n </header>\n ) : null}\n <div\n className=\"grid gap-4\"\n style={{\n gridTemplateColumns: columns\n ? `repeat(${columns}, minmax(0, 1fr))`\n : \"repeat(auto-fit, minmax(180px, 1fr))\",\n }}\n >\n {metrics.map((m) => (\n <Tile key={m.label} metric={m} />\n ))}\n </div>\n </div>\n ),\n);\nMetricsPanel.displayName = \"MetricsPanel\";\n\nfunction Tile({ metric }: { metric: Metric }) {\n const interactive = metric.onClick !== undefined;\n const Tag = interactive ? \"button\" : \"div\";\n // T4.3 (Code Issue 3): clickable tiles need an explicit accessible name\n // so AT users hear \"View Requests/s details, button\" instead of just\n // the spoken value cluster. Falls back to metric.actionLabel when the\n // caller wants custom text (e.g., \"Drill into requests\").\n const ariaLabel = interactive\n ? (metric.actionLabel ?? `View ${metric.label} details`)\n : undefined;\n return (\n <Tag\n type={interactive ? \"button\" : undefined}\n onClick={metric.onClick}\n aria-label={ariaLabel}\n className={cn(\n \"flex flex-col gap-2 rounded-lg border border-border/30 bg-muted/30 p-4 text-left\",\n \"transition-colors duration-base ease-out-soft\",\n interactive &&\n \"hover:border-primary/40 hover:bg-muted/60 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-offset-card\",\n )}\n >\n <span className=\"font-sans text-label-caps text-muted-foreground uppercase\">\n {metric.label}\n </span>\n <div className=\"flex items-baseline gap-1.5\">\n <span className=\"font-bold font-display text-display-md tabular-nums leading-none\">\n {metric.value}\n </span>\n {metric.unit ? (\n <span className=\"font-mono text-body-sm text-muted-foreground\">{metric.unit}</span>\n ) : null}\n </div>\n <div className=\"flex items-center gap-2\">\n {metric.delta ? <Delta metric={metric} /> : null}\n {metric.sparkline && metric.sparkline.length > 0 ? (\n <Sparkline values={metric.sparkline} />\n ) : null}\n </div>\n </Tag>\n );\n}\n\nfunction Delta({ metric }: { metric: Metric }) {\n const tone =\n metric.deltaGood === undefined\n ? \"text-muted-foreground\"\n : metric.deltaGood\n ? \"text-success\"\n : \"text-destructive\";\n const Icon = metric.deltaGood === false ? TrendingDown : TrendingUp;\n return (\n <span className={cn(\"inline-flex items-center gap-1 font-mono text-body-sm\", tone)}>\n <Icon className=\"size-3\" /> {metric.delta}\n </span>\n );\n}\n\nfunction Sparkline({ values }: { values: number[] }) {\n const clamped = values.map((v) => Math.max(0, Math.min(1, v)));\n return (\n <span className=\"ml-auto flex h-6 items-end gap-[2px]\" aria-hidden=\"true\">\n {clamped.map((v, idx) => (\n <span\n // biome-ignore lint/suspicious/noArrayIndexKey: positional, values are not stable identifiers\n key={idx}\n className=\"w-[3px] rounded-sm bg-primary/60\"\n style={{ height: `${Math.max(8, v * 100)}%` }}\n />\n ))}\n </span>\n );\n}\n\nexport { MetricsPanel };\n"]}
@@ -0,0 +1,55 @@
1
+ import { cn } from './chunk-ZSRJCIWF.js';
2
+ import { Cloud, FileSpreadsheet, Folder } from 'lucide-react';
3
+ import { forwardRef } from 'react';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ var CreatedFilesCard = forwardRef(
7
+ ({ className, title = "Files created", files, cta, ...props }, ref) => /* @__PURE__ */ jsxs(
8
+ "section",
9
+ {
10
+ ref,
11
+ className: cn("rounded-xl border border-primary/40 bg-primary/5 p-4", className),
12
+ ...props,
13
+ children: [
14
+ /* @__PURE__ */ jsxs("header", { className: "mb-3 flex items-center gap-2", children: [
15
+ /* @__PURE__ */ jsx(Cloud, { className: "size-4 text-primary", "aria-hidden": "true" }),
16
+ /* @__PURE__ */ jsx("h3", { className: "font-display text-title-md tracking-tight", children: title })
17
+ ] }),
18
+ /* @__PURE__ */ jsx("ul", { className: "grid gap-2", children: files.map((file) => {
19
+ const Icon = file.icon ?? FileSpreadsheet;
20
+ const RowTag = file.href ? "a" : "div";
21
+ return /* @__PURE__ */ jsx("li", { children: /* @__PURE__ */ jsxs(
22
+ RowTag,
23
+ {
24
+ href: file.href,
25
+ target: file.href ? "_blank" : void 0,
26
+ rel: file.href ? "noreferrer" : void 0,
27
+ className: cn(
28
+ "flex items-center gap-3 rounded-md border border-border/40 bg-card px-3 py-2",
29
+ file.href && "transition-colors hover:border-primary/40 hover:bg-muted focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring"
30
+ ),
31
+ children: [
32
+ /* @__PURE__ */ jsx(Icon, { className: "size-5 shrink-0 text-primary", "aria-hidden": "true" }),
33
+ /* @__PURE__ */ jsxs("div", { className: "min-w-0 flex-1", children: [
34
+ /* @__PURE__ */ jsx("p", { className: "truncate font-mono text-code-md text-foreground", children: file.name }),
35
+ file.destination ? /* @__PURE__ */ jsxs("p", { className: "flex items-center gap-1 truncate text-body-sm text-muted-foreground", children: [
36
+ /* @__PURE__ */ jsx(Folder, { className: "size-3 shrink-0", "aria-hidden": "true" }),
37
+ " ",
38
+ file.destination
39
+ ] }) : null
40
+ ] }),
41
+ file.size ? /* @__PURE__ */ jsx("span", { className: "font-mono text-code-sm text-muted-foreground", children: file.size }) : null
42
+ ]
43
+ }
44
+ ) }, file.id);
45
+ }) }),
46
+ cta ? /* @__PURE__ */ jsx("div", { className: "mt-3 flex justify-end", children: cta }) : null
47
+ ]
48
+ }
49
+ )
50
+ );
51
+ CreatedFilesCard.displayName = "CreatedFilesCard";
52
+
53
+ export { CreatedFilesCard };
54
+ //# sourceMappingURL=chunk-UDTAMHXW.js.map
55
+ //# sourceMappingURL=chunk-UDTAMHXW.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/primitives/created-files-card/created-files-card.tsx"],"names":[],"mappings":";;;;;AAkCA,IAAM,gBAAA,GAAmB,UAAA;AAAA,EACvB,CAAC,EAAE,SAAA,EAAW,KAAA,GAAQ,eAAA,EAAiB,OAAO,GAAA,EAAK,GAAG,KAAA,EAAM,EAAG,GAAA,qBAC7D,IAAA;AAAA,IAAC,SAAA;AAAA,IAAA;AAAA,MACC,GAAA;AAAA,MACA,SAAA,EAAW,EAAA,CAAG,sDAAA,EAAwD,SAAS,CAAA;AAAA,MAC9E,GAAG,KAAA;AAAA,MAEJ,QAAA,EAAA;AAAA,wBAAA,IAAA,CAAC,QAAA,EAAA,EAAO,WAAU,8BAAA,EAChB,QAAA,EAAA;AAAA,0BAAA,GAAA,CAAC,KAAA,EAAA,EAAM,SAAA,EAAU,qBAAA,EAAsB,aAAA,EAAY,MAAA,EAAO,CAAA;AAAA,0BAC1D,GAAA,CAAC,IAAA,EAAA,EAAG,SAAA,EAAU,2CAAA,EAA6C,QAAA,EAAA,KAAA,EAAM;AAAA,SAAA,EACnE,CAAA;AAAA,4BACC,IAAA,EAAA,EAAG,SAAA,EAAU,cACX,QAAA,EAAA,KAAA,CAAM,GAAA,CAAI,CAAC,IAAA,KAAS;AACnB,UAAA,MAAM,IAAA,GAAO,KAAK,IAAA,IAAQ,eAAA;AAC1B,UAAA,MAAM,MAAA,GAAS,IAAA,CAAK,IAAA,GAAO,GAAA,GAAM,KAAA;AACjC,UAAA,2BACG,IAAA,EAAA,EACC,QAAA,kBAAA,IAAA;AAAA,YAAC,MAAA;AAAA,YAAA;AAAA,cACC,MAAM,IAAA,CAAK,IAAA;AAAA,cACX,MAAA,EAAQ,IAAA,CAAK,IAAA,GAAO,QAAA,GAAW,MAAA;AAAA,cAC/B,GAAA,EAAK,IAAA,CAAK,IAAA,GAAO,YAAA,GAAe,MAAA;AAAA,cAChC,SAAA,EAAW,EAAA;AAAA,gBACT,8EAAA;AAAA,gBACA,KAAK,IAAA,IACH;AAAA,eACJ;AAAA,cAEA,QAAA,EAAA;AAAA,gCAAA,GAAA,CAAC,IAAA,EAAA,EAAK,SAAA,EAAU,8BAAA,EAA+B,aAAA,EAAY,MAAA,EAAO,CAAA;AAAA,gCAClE,IAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAU,gBAAA,EACb,QAAA,EAAA;AAAA,kCAAA,GAAA,CAAC,GAAA,EAAA,EAAE,SAAA,EAAU,iDAAA,EAAmD,QAAA,EAAA,IAAA,CAAK,IAAA,EAAK,CAAA;AAAA,kBACzE,IAAA,CAAK,WAAA,mBACJ,IAAA,CAAC,GAAA,EAAA,EAAE,WAAU,qEAAA,EACX,QAAA,EAAA;AAAA,oCAAA,GAAA,CAAC,MAAA,EAAA,EAAO,SAAA,EAAU,iBAAA,EAAkB,aAAA,EAAY,MAAA,EAAO,CAAA;AAAA,oBAAE,GAAA;AAAA,oBAAE,IAAA,CAAK;AAAA,mBAAA,EAClE,CAAA,GACE;AAAA,iBAAA,EACN,CAAA;AAAA,gBACC,IAAA,CAAK,uBACJ,GAAA,CAAC,MAAA,EAAA,EAAK,WAAU,8CAAA,EAAgD,QAAA,EAAA,IAAA,CAAK,MAAK,CAAA,GACxE;AAAA;AAAA;AAAA,WACN,EAAA,EAvBO,KAAK,EAwBd,CAAA;AAAA,QAEJ,CAAC,CAAA,EACH,CAAA;AAAA,QACC,sBAAM,GAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAU,uBAAA,EAAyB,eAAI,CAAA,GAAS;AAAA;AAAA;AAAA;AAGlE;AACA,gBAAA,CAAiB,WAAA,GAAc,kBAAA","file":"chunk-UDTAMHXW.js","sourcesContent":["import { Cloud, FileSpreadsheet, Folder } from \"lucide-react\";\nimport { forwardRef } from \"react\";\nimport type { HTMLAttributes, ReactNode } from \"react\";\nimport { cn } from \"../../../lib/cn.js\";\nimport type { IconComponent } from \"../../../lib/types.js\";\n\nexport interface CreatedFile {\n id: string;\n name: string;\n /** Optional size for display, e.g. \"42 KB\". */\n size?: string;\n /** Icon override. */\n icon?: IconComponent;\n /** Optional destination metadata (e.g. \"Google Drive · /Reports\"). */\n destination?: ReactNode;\n /** Optional URL to open the file. */\n href?: string;\n}\n\ninterface CreatedFilesCardProps extends Omit<HTMLAttributes<HTMLElement>, \"title\"> {\n title?: ReactNode;\n files: CreatedFile[];\n /**\n * Optional CTA shown at the bottom (e.g. \"Move to Google Drive\").\n */\n cta?: ReactNode;\n}\n\n/**\n * CreatedFilesCard — surfaces files produced by a completed task.\n *\n * From WIREMOCKS §2: each file is a card-like row with icon + name + destination.\n * Used as social proof of delivery in Task Completed views.\n */\nconst CreatedFilesCard = forwardRef<HTMLElement, CreatedFilesCardProps>(\n ({ className, title = \"Files created\", files, cta, ...props }, ref) => (\n <section\n ref={ref}\n className={cn(\"rounded-xl border border-primary/40 bg-primary/5 p-4\", className)}\n {...props}\n >\n <header className=\"mb-3 flex items-center gap-2\">\n <Cloud className=\"size-4 text-primary\" aria-hidden=\"true\" />\n <h3 className=\"font-display text-title-md tracking-tight\">{title}</h3>\n </header>\n <ul className=\"grid gap-2\">\n {files.map((file) => {\n const Icon = file.icon ?? FileSpreadsheet;\n const RowTag = file.href ? \"a\" : \"div\";\n return (\n <li key={file.id}>\n <RowTag\n href={file.href}\n target={file.href ? \"_blank\" : undefined}\n rel={file.href ? \"noreferrer\" : undefined}\n className={cn(\n \"flex items-center gap-3 rounded-md border border-border/40 bg-card px-3 py-2\",\n file.href &&\n \"transition-colors hover:border-primary/40 hover:bg-muted focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring\",\n )}\n >\n <Icon className=\"size-5 shrink-0 text-primary\" aria-hidden=\"true\" />\n <div className=\"min-w-0 flex-1\">\n <p className=\"truncate font-mono text-code-md text-foreground\">{file.name}</p>\n {file.destination ? (\n <p className=\"flex items-center gap-1 truncate text-body-sm text-muted-foreground\">\n <Folder className=\"size-3 shrink-0\" aria-hidden=\"true\" /> {file.destination}\n </p>\n ) : null}\n </div>\n {file.size ? (\n <span className=\"font-mono text-code-sm text-muted-foreground\">{file.size}</span>\n ) : null}\n </RowTag>\n </li>\n );\n })}\n </ul>\n {cta ? <div className=\"mt-3 flex justify-end\">{cta}</div> : null}\n </section>\n ),\n);\nCreatedFilesCard.displayName = \"CreatedFilesCard\";\n\nexport { CreatedFilesCard };\n"]}