@signalflare-ai/ui 0.5.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 (765) hide show
  1. package/CHANGELOG.md +96 -0
  2. package/README.md +527 -0
  3. package/ai/USAGE.md +200 -0
  4. package/ai/component-registry.json +7103 -0
  5. package/ai/component-registry.md +3046 -0
  6. package/ai/schemas.ts +1230 -0
  7. package/bin/intent.js +23 -0
  8. package/bin/sf.js +34 -0
  9. package/dist/.build-complete +1 -0
  10. package/dist/ai/schemas.d.ts +7056 -0
  11. package/dist/ai/schemas.d.ts.map +1 -0
  12. package/dist/ai-actions-DG1dhDMP.js +57 -0
  13. package/dist/ai-actions-DG1dhDMP.js.map +1 -0
  14. package/dist/ai-agent-card-BbtL4NII.js +171 -0
  15. package/dist/ai-agent-card-BbtL4NII.js.map +1 -0
  16. package/dist/ai-approval-Mb7-BY6i.js +184 -0
  17. package/dist/ai-approval-Mb7-BY6i.js.map +1 -0
  18. package/dist/ai-code-block-BI_z0UVR.js +110 -0
  19. package/dist/ai-code-block-BI_z0UVR.js.map +1 -0
  20. package/dist/ai-conversation-DYtExcrw.js +184 -0
  21. package/dist/ai-conversation-DYtExcrw.js.map +1 -0
  22. package/dist/ai-info-banner-BpzauUAY.js +76 -0
  23. package/dist/ai-info-banner-BpzauUAY.js.map +1 -0
  24. package/dist/ai-loader-Cr3eQkNS.js +134 -0
  25. package/dist/ai-loader-Cr3eQkNS.js.map +1 -0
  26. package/dist/ai-message-CV8SBoHM.js +286 -0
  27. package/dist/ai-message-CV8SBoHM.js.map +1 -0
  28. package/dist/ai-mission-header-ByYkJ6YP.js +171 -0
  29. package/dist/ai-mission-header-ByYkJ6YP.js.map +1 -0
  30. package/dist/ai-prompt-input-Bo1YuJly.js +769 -0
  31. package/dist/ai-prompt-input-Bo1YuJly.js.map +1 -0
  32. package/dist/ai-question-Dp1g9k2o.js +149 -0
  33. package/dist/ai-question-Dp1g9k2o.js.map +1 -0
  34. package/dist/ai-reasoning-UAmNx_LD.js +270 -0
  35. package/dist/ai-reasoning-UAmNx_LD.js.map +1 -0
  36. package/dist/ai-response-BWoVsNQG.js +42 -0
  37. package/dist/ai-response-BWoVsNQG.js.map +1 -0
  38. package/dist/ai-shimmer-BpOmfonu.js +43 -0
  39. package/dist/ai-shimmer-BpOmfonu.js.map +1 -0
  40. package/dist/ai-status-badge-WhbKVeqn.js +63 -0
  41. package/dist/ai-status-badge-WhbKVeqn.js.map +1 -0
  42. package/dist/ai-streaming-text-ClL7FwvD.js +81 -0
  43. package/dist/ai-streaming-text-ClL7FwvD.js.map +1 -0
  44. package/dist/ai-subagent-BruGN1UE.js +133 -0
  45. package/dist/ai-subagent-BruGN1UE.js.map +1 -0
  46. package/dist/ai-suggestion-CNsCZj5P.js +55 -0
  47. package/dist/ai-suggestion-CNsCZj5P.js.map +1 -0
  48. package/dist/ai-task-list-B9CpMDYN.js +120 -0
  49. package/dist/ai-task-list-B9CpMDYN.js.map +1 -0
  50. package/dist/ai-timeline-Bb5ntsr3.js +373 -0
  51. package/dist/ai-timeline-Bb5ntsr3.js.map +1 -0
  52. package/dist/ai-tool-BGH8nQ_D.js +437 -0
  53. package/dist/ai-tool-BGH8nQ_D.js.map +1 -0
  54. package/dist/ai-usage-bar-BI-p-JBk.js +70 -0
  55. package/dist/ai-usage-bar-BI-p-JBk.js.map +1 -0
  56. package/dist/badge-D_eaA6wv.js +128 -0
  57. package/dist/badge-D_eaA6wv.js.map +1 -0
  58. package/dist/banner-B_6oBrsu.js +54 -0
  59. package/dist/banner-B_6oBrsu.js.map +1 -0
  60. package/dist/breadcrumbs-BlmeYfgq.js +128 -0
  61. package/dist/breadcrumbs-BlmeYfgq.js.map +1 -0
  62. package/dist/button-De0267YU.js +170 -0
  63. package/dist/button-De0267YU.js.map +1 -0
  64. package/dist/catalog.js +506 -0
  65. package/dist/catalog.js.map +1 -0
  66. package/dist/chart-Bes4MN3C.js +618 -0
  67. package/dist/chart-Bes4MN3C.js.map +1 -0
  68. package/dist/checkbox-CPX7lBaU.js +153 -0
  69. package/dist/checkbox-CPX7lBaU.js.map +1 -0
  70. package/dist/clipboard-text-92YeCybc.js +176 -0
  71. package/dist/clipboard-text-92YeCybc.js.map +1 -0
  72. package/dist/cn-YROP2_ox.js +25 -0
  73. package/dist/cn-YROP2_ox.js.map +1 -0
  74. package/dist/code-DE1Yy1Cu.js +97 -0
  75. package/dist/code-DE1Yy1Cu.js.map +1 -0
  76. package/dist/collapsible-DWsXeXmS.js +72 -0
  77. package/dist/collapsible-DWsXeXmS.js.map +1 -0
  78. package/dist/combobox-B0bLdsX8.js +197 -0
  79. package/dist/combobox-B0bLdsX8.js.map +1 -0
  80. package/dist/command-line/cli.js +823 -0
  81. package/dist/command-palette-CBTY8EiF.js +484 -0
  82. package/dist/command-palette-CBTY8EiF.js.map +1 -0
  83. package/dist/components/ai-actions.js +3 -0
  84. package/dist/components/ai-agent-card.js +3 -0
  85. package/dist/components/ai-approval.js +3 -0
  86. package/dist/components/ai-code-block.js +3 -0
  87. package/dist/components/ai-conversation.js +3 -0
  88. package/dist/components/ai-info-banner.js +3 -0
  89. package/dist/components/ai-loader.js +3 -0
  90. package/dist/components/ai-message.js +3 -0
  91. package/dist/components/ai-mission-header.js +3 -0
  92. package/dist/components/ai-prompt-input.js +3 -0
  93. package/dist/components/ai-question.js +3 -0
  94. package/dist/components/ai-reasoning.js +3 -0
  95. package/dist/components/ai-response.js +3 -0
  96. package/dist/components/ai-shimmer.js +3 -0
  97. package/dist/components/ai-status-badge.js +3 -0
  98. package/dist/components/ai-streaming-text.js +3 -0
  99. package/dist/components/ai-subagent.js +3 -0
  100. package/dist/components/ai-suggestion.js +3 -0
  101. package/dist/components/ai-task-list.js +3 -0
  102. package/dist/components/ai-timeline.js +3 -0
  103. package/dist/components/ai-tool.js +3 -0
  104. package/dist/components/ai-usage-bar.js +3 -0
  105. package/dist/components/badge.js +3 -0
  106. package/dist/components/banner.js +3 -0
  107. package/dist/components/breadcrumbs.js +3 -0
  108. package/dist/components/button.js +3 -0
  109. package/dist/components/chart.js +3 -0
  110. package/dist/components/checkbox.js +3 -0
  111. package/dist/components/clipboard-text.js +3 -0
  112. package/dist/components/code.js +3 -0
  113. package/dist/components/collapsible.js +3 -0
  114. package/dist/components/combobox.js +3 -0
  115. package/dist/components/command-palette.js +3 -0
  116. package/dist/components/data-grid.js +3 -0
  117. package/dist/components/date-picker.js +3 -0
  118. package/dist/components/date-range-picker.js +3 -0
  119. package/dist/components/dialog.js +3 -0
  120. package/dist/components/dropdown.js +3 -0
  121. package/dist/components/empty.js +3 -0
  122. package/dist/components/field.js +3 -0
  123. package/dist/components/filters.js +3 -0
  124. package/dist/components/flow.js +3 -0
  125. package/dist/components/grid.js +3 -0
  126. package/dist/components/input.js +4 -0
  127. package/dist/components/label.js +3 -0
  128. package/dist/components/layer-card.js +3 -0
  129. package/dist/components/link.js +92 -0
  130. package/dist/components/link.js.map +1 -0
  131. package/dist/components/loader.js +4 -0
  132. package/dist/components/menubar.js +3 -0
  133. package/dist/components/meter.js +3 -0
  134. package/dist/components/pagination.js +3 -0
  135. package/dist/components/popover.js +3 -0
  136. package/dist/components/radio.js +3 -0
  137. package/dist/components/select.js +3 -0
  138. package/dist/components/sensitive-input.js +3 -0
  139. package/dist/components/sidebar.js +3 -0
  140. package/dist/components/signalflare-ai-logo.js +3 -0
  141. package/dist/components/surface.js +3 -0
  142. package/dist/components/switch.js +3 -0
  143. package/dist/components/table.js +3 -0
  144. package/dist/components/tabs.js +3 -0
  145. package/dist/components/text.js +3 -0
  146. package/dist/components/theme-toggle.js +3 -0
  147. package/dist/components/toast.js +3 -0
  148. package/dist/components/tooltip.js +3 -0
  149. package/dist/components/use-agent-harness.js +3 -0
  150. package/dist/data-grid-UJ9ja5cu.js +305 -0
  151. package/dist/data-grid-UJ9ja5cu.js.map +1 -0
  152. package/dist/date-picker-ebekkC3R.js +57 -0
  153. package/dist/date-picker-ebekkC3R.js.map +1 -0
  154. package/dist/date-range-picker-D75LLINc.js +347 -0
  155. package/dist/date-range-picker-D75LLINc.js.map +1 -0
  156. package/dist/dialog-CyHEQXEY.js +104 -0
  157. package/dist/dialog-CyHEQXEY.js.map +1 -0
  158. package/dist/dist-BNlyONdD.js +3546 -0
  159. package/dist/dist-BNlyONdD.js.map +1 -0
  160. package/dist/dropdown-J5T4pHaR.js +202 -0
  161. package/dist/dropdown-J5T4pHaR.js.map +1 -0
  162. package/dist/empty-D2TypIId.js +90 -0
  163. package/dist/empty-D2TypIId.js.map +1 -0
  164. package/dist/favicon.svg +4 -0
  165. package/dist/field-Y_UK1_Cg.js +57 -0
  166. package/dist/field-Y_UK1_Cg.js.map +1 -0
  167. package/dist/filters-BdBogf7D.js +682 -0
  168. package/dist/filters-BdBogf7D.js.map +1 -0
  169. package/dist/flow-BRsYUCJa.js +741 -0
  170. package/dist/flow-BRsYUCJa.js.map +1 -0
  171. package/dist/genui.js +40 -0
  172. package/dist/genui.js.map +1 -0
  173. package/dist/grid-qUAN9hFx.js +119 -0
  174. package/dist/grid-qUAN9hFx.js.map +1 -0
  175. package/dist/highlight-to-react-ClEfL81q.js +57 -0
  176. package/dist/highlight-to-react-ClEfL81q.js.map +1 -0
  177. package/dist/index.js +215 -0
  178. package/dist/index.js.map +1 -0
  179. package/dist/input-BxQAnXki.js +81 -0
  180. package/dist/input-BxQAnXki.js.map +1 -0
  181. package/dist/input-Cn25I4o5.js +121 -0
  182. package/dist/input-Cn25I4o5.js.map +1 -0
  183. package/dist/label-QtJxtJ4u.js +70 -0
  184. package/dist/label-QtJxtJ4u.js.map +1 -0
  185. package/dist/layer-card-BME0eljh.js +44 -0
  186. package/dist/layer-card-BME0eljh.js.map +1 -0
  187. package/dist/link-provider-BUZKXaNE.js +25 -0
  188. package/dist/link-provider-BUZKXaNE.js.map +1 -0
  189. package/dist/loader-DAcc-Uag.js +84 -0
  190. package/dist/loader-DAcc-Uag.js.map +1 -0
  191. package/dist/logo.svg +1 -0
  192. package/dist/menubar-C8NzAjfd.js +102 -0
  193. package/dist/menubar-C8NzAjfd.js.map +1 -0
  194. package/dist/meter-CpmTenEr.js +37 -0
  195. package/dist/meter-CpmTenEr.js.map +1 -0
  196. package/dist/pagination-C_YqCy8l.js +117 -0
  197. package/dist/pagination-C_YqCy8l.js.map +1 -0
  198. package/dist/popover-BRQZ2b6z.js +147 -0
  199. package/dist/popover-BRQZ2b6z.js.map +1 -0
  200. package/dist/primitives/accordion.js +2 -0
  201. package/dist/primitives/alert-dialog.js +2 -0
  202. package/dist/primitives/autocomplete.js +2 -0
  203. package/dist/primitives/avatar.js +2 -0
  204. package/dist/primitives/button.js +2 -0
  205. package/dist/primitives/checkbox-group.js +2 -0
  206. package/dist/primitives/checkbox.js +2 -0
  207. package/dist/primitives/collapsible.js +2 -0
  208. package/dist/primitives/combobox.js +2 -0
  209. package/dist/primitives/context-menu.js +2 -0
  210. package/dist/primitives/csp-provider.js +2 -0
  211. package/dist/primitives/dialog.js +2 -0
  212. package/dist/primitives/direction-provider.js +2 -0
  213. package/dist/primitives/drawer.js +2 -0
  214. package/dist/primitives/field.js +2 -0
  215. package/dist/primitives/fieldset.js +2 -0
  216. package/dist/primitives/form.js +2 -0
  217. package/dist/primitives/input.js +2 -0
  218. package/dist/primitives/menu.js +2 -0
  219. package/dist/primitives/menubar.js +2 -0
  220. package/dist/primitives/meter.js +2 -0
  221. package/dist/primitives/navigation-menu.js +2 -0
  222. package/dist/primitives/number-field.js +2 -0
  223. package/dist/primitives/popover.js +2 -0
  224. package/dist/primitives/preview-card.js +2 -0
  225. package/dist/primitives/progress.js +2 -0
  226. package/dist/primitives/radio-group.js +2 -0
  227. package/dist/primitives/radio.js +2 -0
  228. package/dist/primitives/scroll-area.js +2 -0
  229. package/dist/primitives/select.js +2 -0
  230. package/dist/primitives/separator.js +2 -0
  231. package/dist/primitives/slider.js +2 -0
  232. package/dist/primitives/switch.js +2 -0
  233. package/dist/primitives/tabs.js +2 -0
  234. package/dist/primitives/toast.js +2 -0
  235. package/dist/primitives/toggle-group.js +2 -0
  236. package/dist/primitives/toggle.js +2 -0
  237. package/dist/primitives/toolbar.js +2 -0
  238. package/dist/primitives/tooltip.js +2 -0
  239. package/dist/primitives.js +40 -0
  240. package/dist/radio-B7zg1wUI.js +101 -0
  241. package/dist/radio-B7zg1wUI.js.map +1 -0
  242. package/dist/registry.js +1 -0
  243. package/dist/select-9p721G00.js +95 -0
  244. package/dist/select-9p721G00.js.map +1 -0
  245. package/dist/sensitive-input-D5je2NLl.js +248 -0
  246. package/dist/sensitive-input-D5je2NLl.js.map +1 -0
  247. package/dist/sidebar-DOwBrq57.js +964 -0
  248. package/dist/sidebar-DOwBrq57.js.map +1 -0
  249. package/dist/signalflare-ai-logo-DDhxMJD6.js +260 -0
  250. package/dist/signalflare-ai-logo-DDhxMJD6.js.map +1 -0
  251. package/dist/skeleton-line-Do3UmGk9.js +36 -0
  252. package/dist/skeleton-line-Do3UmGk9.js.map +1 -0
  253. package/dist/src/blocks/agent-harness/agent-harness.d.ts +177 -0
  254. package/dist/src/blocks/agent-harness/agent-harness.d.ts.map +1 -0
  255. package/dist/src/blocks/agent-harness/agent-harness.tsx +1122 -0
  256. package/dist/src/blocks/agent-harness/index.d.ts +2 -0
  257. package/dist/src/blocks/agent-harness/index.d.ts.map +1 -0
  258. package/dist/src/blocks/commander/commander.d.ts +101 -0
  259. package/dist/src/blocks/commander/commander.d.ts.map +1 -0
  260. package/dist/src/blocks/commander/commander.tsx +477 -0
  261. package/dist/src/blocks/commander/index.d.ts +2 -0
  262. package/dist/src/blocks/commander/index.d.ts.map +1 -0
  263. package/dist/src/blocks/delete-resource/delete-resource.d.ts +46 -0
  264. package/dist/src/blocks/delete-resource/delete-resource.d.ts.map +1 -0
  265. package/dist/src/blocks/delete-resource/delete-resource.tsx +214 -0
  266. package/dist/src/blocks/delete-resource/index.d.ts +2 -0
  267. package/dist/src/blocks/delete-resource/index.d.ts.map +1 -0
  268. package/dist/src/blocks/map-block/index.d.ts +2 -0
  269. package/dist/src/blocks/map-block/index.d.ts.map +1 -0
  270. package/dist/src/blocks/map-block/map-block.d.ts +79 -0
  271. package/dist/src/blocks/map-block/map-block.d.ts.map +1 -0
  272. package/dist/src/blocks/map-block/map-block.tsx +522 -0
  273. package/dist/src/blocks/page-header/index.d.ts +2 -0
  274. package/dist/src/blocks/page-header/index.d.ts.map +1 -0
  275. package/dist/src/blocks/page-header/page-header.d.ts +38 -0
  276. package/dist/src/blocks/page-header/page-header.d.ts.map +1 -0
  277. package/dist/src/blocks/page-header/page-header.tsx +96 -0
  278. package/dist/src/blocks/resource-list/index.d.ts +2 -0
  279. package/dist/src/blocks/resource-list/index.d.ts.map +1 -0
  280. package/dist/src/blocks/resource-list/resource-list.d.ts +18 -0
  281. package/dist/src/blocks/resource-list/resource-list.d.ts.map +1 -0
  282. package/dist/src/blocks/resource-list/resource-list.test.tsx +27 -0
  283. package/dist/src/blocks/resource-list/resource-list.tsx +65 -0
  284. package/dist/src/catalog/catalog.d.ts +75 -0
  285. package/dist/src/catalog/catalog.d.ts.map +1 -0
  286. package/dist/src/catalog/data.d.ts +44 -0
  287. package/dist/src/catalog/data.d.ts.map +1 -0
  288. package/dist/src/catalog/index.d.ts +35 -0
  289. package/dist/src/catalog/index.d.ts.map +1 -0
  290. package/dist/src/catalog/sf-components.d.ts +8 -0
  291. package/dist/src/catalog/sf-components.d.ts.map +1 -0
  292. package/dist/src/catalog/sf-registry.d.ts +4 -0
  293. package/dist/src/catalog/sf-registry.d.ts.map +1 -0
  294. package/dist/src/catalog/types.d.ts +226 -0
  295. package/dist/src/catalog/types.d.ts.map +1 -0
  296. package/dist/src/catalog/visibility.d.ts +37 -0
  297. package/dist/src/catalog/visibility.d.ts.map +1 -0
  298. package/dist/src/command-line/build-cli.d.ts +7 -0
  299. package/dist/src/command-line/build-cli.d.ts.map +1 -0
  300. package/dist/src/command-line/cli.d.ts +13 -0
  301. package/dist/src/command-line/cli.d.ts.map +1 -0
  302. package/dist/src/command-line/commands/add.d.ts +10 -0
  303. package/dist/src/command-line/commands/add.d.ts.map +1 -0
  304. package/dist/src/command-line/commands/ai.d.ts +10 -0
  305. package/dist/src/command-line/commands/ai.d.ts.map +1 -0
  306. package/dist/src/command-line/commands/blocks.d.ts +10 -0
  307. package/dist/src/command-line/commands/blocks.d.ts.map +1 -0
  308. package/dist/src/command-line/commands/doc.d.ts +14 -0
  309. package/dist/src/command-line/commands/doc.d.ts.map +1 -0
  310. package/dist/src/command-line/commands/init.d.ts +18 -0
  311. package/dist/src/command-line/commands/init.d.ts.map +1 -0
  312. package/dist/src/command-line/commands/ls.d.ts +10 -0
  313. package/dist/src/command-line/commands/ls.d.ts.map +1 -0
  314. package/dist/src/command-line/commands/migrate.d.ts +10 -0
  315. package/dist/src/command-line/commands/migrate.d.ts.map +1 -0
  316. package/dist/src/command-line/utils/config.d.ts +42 -0
  317. package/dist/src/command-line/utils/config.d.ts.map +1 -0
  318. package/dist/src/command-line/utils/transformer.d.ts +21 -0
  319. package/dist/src/command-line/utils/transformer.d.ts.map +1 -0
  320. package/dist/src/components/ai-actions/ai-actions.d.ts +35 -0
  321. package/dist/src/components/ai-actions/ai-actions.d.ts.map +1 -0
  322. package/dist/src/components/ai-actions/index.d.ts +2 -0
  323. package/dist/src/components/ai-actions/index.d.ts.map +1 -0
  324. package/dist/src/components/ai-agent-card/ai-agent-card.d.ts +82 -0
  325. package/dist/src/components/ai-agent-card/ai-agent-card.d.ts.map +1 -0
  326. package/dist/src/components/ai-agent-card/index.d.ts +2 -0
  327. package/dist/src/components/ai-agent-card/index.d.ts.map +1 -0
  328. package/dist/src/components/ai-approval/ai-approval.d.ts +102 -0
  329. package/dist/src/components/ai-approval/ai-approval.d.ts.map +1 -0
  330. package/dist/src/components/ai-approval/index.d.ts +2 -0
  331. package/dist/src/components/ai-approval/index.d.ts.map +1 -0
  332. package/dist/src/components/ai-code-block/ai-code-block.d.ts +48 -0
  333. package/dist/src/components/ai-code-block/ai-code-block.d.ts.map +1 -0
  334. package/dist/src/components/ai-code-block/index.d.ts +2 -0
  335. package/dist/src/components/ai-code-block/index.d.ts.map +1 -0
  336. package/dist/src/components/ai-conversation/ai-conversation.d.ts +125 -0
  337. package/dist/src/components/ai-conversation/ai-conversation.d.ts.map +1 -0
  338. package/dist/src/components/ai-conversation/index.d.ts +2 -0
  339. package/dist/src/components/ai-conversation/index.d.ts.map +1 -0
  340. package/dist/src/components/ai-info-banner/ai-info-banner.d.ts +55 -0
  341. package/dist/src/components/ai-info-banner/ai-info-banner.d.ts.map +1 -0
  342. package/dist/src/components/ai-info-banner/index.d.ts +2 -0
  343. package/dist/src/components/ai-info-banner/index.d.ts.map +1 -0
  344. package/dist/src/components/ai-loader/ai-loader.d.ts +44 -0
  345. package/dist/src/components/ai-loader/ai-loader.d.ts.map +1 -0
  346. package/dist/src/components/ai-loader/index.d.ts +2 -0
  347. package/dist/src/components/ai-loader/index.d.ts.map +1 -0
  348. package/dist/src/components/ai-message/ai-message.d.ts +97 -0
  349. package/dist/src/components/ai-message/ai-message.d.ts.map +1 -0
  350. package/dist/src/components/ai-message/index.d.ts +2 -0
  351. package/dist/src/components/ai-message/index.d.ts.map +1 -0
  352. package/dist/src/components/ai-mission-header/ai-mission-header.d.ts +62 -0
  353. package/dist/src/components/ai-mission-header/ai-mission-header.d.ts.map +1 -0
  354. package/dist/src/components/ai-mission-header/index.d.ts +2 -0
  355. package/dist/src/components/ai-mission-header/index.d.ts.map +1 -0
  356. package/dist/src/components/ai-prompt-input/ai-prompt-input.d.ts +260 -0
  357. package/dist/src/components/ai-prompt-input/ai-prompt-input.d.ts.map +1 -0
  358. package/dist/src/components/ai-prompt-input/index.d.ts +2 -0
  359. package/dist/src/components/ai-prompt-input/index.d.ts.map +1 -0
  360. package/dist/src/components/ai-question/ai-question.d.ts +73 -0
  361. package/dist/src/components/ai-question/ai-question.d.ts.map +1 -0
  362. package/dist/src/components/ai-question/index.d.ts +2 -0
  363. package/dist/src/components/ai-question/index.d.ts.map +1 -0
  364. package/dist/src/components/ai-reasoning/ai-reasoning.d.ts +107 -0
  365. package/dist/src/components/ai-reasoning/ai-reasoning.d.ts.map +1 -0
  366. package/dist/src/components/ai-reasoning/index.d.ts +2 -0
  367. package/dist/src/components/ai-reasoning/index.d.ts.map +1 -0
  368. package/dist/src/components/ai-response/ai-response.d.ts +26 -0
  369. package/dist/src/components/ai-response/ai-response.d.ts.map +1 -0
  370. package/dist/src/components/ai-response/index.d.ts +2 -0
  371. package/dist/src/components/ai-response/index.d.ts.map +1 -0
  372. package/dist/src/components/ai-shimmer/ai-shimmer.d.ts +29 -0
  373. package/dist/src/components/ai-shimmer/ai-shimmer.d.ts.map +1 -0
  374. package/dist/src/components/ai-shimmer/index.d.ts +2 -0
  375. package/dist/src/components/ai-shimmer/index.d.ts.map +1 -0
  376. package/dist/src/components/ai-status-badge/ai-status-badge.d.ts +46 -0
  377. package/dist/src/components/ai-status-badge/ai-status-badge.d.ts.map +1 -0
  378. package/dist/src/components/ai-status-badge/index.d.ts +2 -0
  379. package/dist/src/components/ai-status-badge/index.d.ts.map +1 -0
  380. package/dist/src/components/ai-streaming-text/ai-streaming-text.d.ts +27 -0
  381. package/dist/src/components/ai-streaming-text/ai-streaming-text.d.ts.map +1 -0
  382. package/dist/src/components/ai-streaming-text/index.d.ts +2 -0
  383. package/dist/src/components/ai-streaming-text/index.d.ts.map +1 -0
  384. package/dist/src/components/ai-subagent/ai-subagent.d.ts +74 -0
  385. package/dist/src/components/ai-subagent/ai-subagent.d.ts.map +1 -0
  386. package/dist/src/components/ai-subagent/index.d.ts +2 -0
  387. package/dist/src/components/ai-subagent/index.d.ts.map +1 -0
  388. package/dist/src/components/ai-suggestion/ai-suggestion.d.ts +40 -0
  389. package/dist/src/components/ai-suggestion/ai-suggestion.d.ts.map +1 -0
  390. package/dist/src/components/ai-suggestion/index.d.ts +2 -0
  391. package/dist/src/components/ai-suggestion/index.d.ts.map +1 -0
  392. package/dist/src/components/ai-task-list/ai-task-list.d.ts +61 -0
  393. package/dist/src/components/ai-task-list/ai-task-list.d.ts.map +1 -0
  394. package/dist/src/components/ai-task-list/index.d.ts +2 -0
  395. package/dist/src/components/ai-task-list/index.d.ts.map +1 -0
  396. package/dist/src/components/ai-timeline/ai-timeline.d.ts +130 -0
  397. package/dist/src/components/ai-timeline/ai-timeline.d.ts.map +1 -0
  398. package/dist/src/components/ai-timeline/index.d.ts +2 -0
  399. package/dist/src/components/ai-timeline/index.d.ts.map +1 -0
  400. package/dist/src/components/ai-tool/ai-tool.d.ts +138 -0
  401. package/dist/src/components/ai-tool/ai-tool.d.ts.map +1 -0
  402. package/dist/src/components/ai-tool/index.d.ts +2 -0
  403. package/dist/src/components/ai-tool/index.d.ts.map +1 -0
  404. package/dist/src/components/ai-usage-bar/ai-usage-bar.d.ts +38 -0
  405. package/dist/src/components/ai-usage-bar/ai-usage-bar.d.ts.map +1 -0
  406. package/dist/src/components/ai-usage-bar/index.d.ts +2 -0
  407. package/dist/src/components/ai-usage-bar/index.d.ts.map +1 -0
  408. package/dist/src/components/badge/badge.d.ts +129 -0
  409. package/dist/src/components/badge/badge.d.ts.map +1 -0
  410. package/dist/src/components/badge/index.d.ts +2 -0
  411. package/dist/src/components/badge/index.d.ts.map +1 -0
  412. package/dist/src/components/banner/banner.d.ts +80 -0
  413. package/dist/src/components/banner/banner.d.ts.map +1 -0
  414. package/dist/src/components/banner/index.d.ts +2 -0
  415. package/dist/src/components/banner/index.d.ts.map +1 -0
  416. package/dist/src/components/breadcrumbs/breadcrumbs.d.ts +78 -0
  417. package/dist/src/components/breadcrumbs/breadcrumbs.d.ts.map +1 -0
  418. package/dist/src/components/breadcrumbs/index.d.ts +2 -0
  419. package/dist/src/components/breadcrumbs/index.d.ts.map +1 -0
  420. package/dist/src/components/button/button.d.ts +212 -0
  421. package/dist/src/components/button/button.d.ts.map +1 -0
  422. package/dist/src/components/button/index.d.ts +2 -0
  423. package/dist/src/components/button/index.d.ts.map +1 -0
  424. package/dist/src/components/chart/color.d.ts +98 -0
  425. package/dist/src/components/chart/color.d.ts.map +1 -0
  426. package/dist/src/components/chart/echart.d.ts +135 -0
  427. package/dist/src/components/chart/echart.d.ts.map +1 -0
  428. package/dist/src/components/chart/index.d.ts +5 -0
  429. package/dist/src/components/chart/index.d.ts.map +1 -0
  430. package/dist/src/components/chart/legend.d.ts +42 -0
  431. package/dist/src/components/chart/legend.d.ts.map +1 -0
  432. package/dist/src/components/chart/timeseries-chart.d.ts +119 -0
  433. package/dist/src/components/chart/timeseries-chart.d.ts.map +1 -0
  434. package/dist/src/components/checkbox/checkbox.d.ts +174 -0
  435. package/dist/src/components/checkbox/checkbox.d.ts.map +1 -0
  436. package/dist/src/components/checkbox/index.d.ts +2 -0
  437. package/dist/src/components/checkbox/index.d.ts.map +1 -0
  438. package/dist/src/components/clipboard-text/clipboard-text.d.ts +86 -0
  439. package/dist/src/components/clipboard-text/clipboard-text.d.ts.map +1 -0
  440. package/dist/src/components/clipboard-text/index.d.ts +2 -0
  441. package/dist/src/components/clipboard-text/index.d.ts.map +1 -0
  442. package/dist/src/components/code/code.d.ts +165 -0
  443. package/dist/src/components/code/code.d.ts.map +1 -0
  444. package/dist/src/components/code/index.d.ts +4 -0
  445. package/dist/src/components/code/index.d.ts.map +1 -0
  446. package/dist/src/components/collapsible/collapsible.d.ts +72 -0
  447. package/dist/src/components/collapsible/collapsible.d.ts.map +1 -0
  448. package/dist/src/components/collapsible/index.d.ts +2 -0
  449. package/dist/src/components/collapsible/index.d.ts.map +1 -0
  450. package/dist/src/components/combobox/combobox.d.ts +188 -0
  451. package/dist/src/components/combobox/combobox.d.ts.map +1 -0
  452. package/dist/src/components/combobox/index.d.ts +2 -0
  453. package/dist/src/components/combobox/index.d.ts.map +1 -0
  454. package/dist/src/components/command-palette/command-palette.d.ts +260 -0
  455. package/dist/src/components/command-palette/command-palette.d.ts.map +1 -0
  456. package/dist/src/components/command-palette/index.d.ts +3 -0
  457. package/dist/src/components/command-palette/index.d.ts.map +1 -0
  458. package/dist/src/components/command-palette/types.d.ts +149 -0
  459. package/dist/src/components/command-palette/types.d.ts.map +1 -0
  460. package/dist/src/components/data-grid/data-grid.d.ts +78 -0
  461. package/dist/src/components/data-grid/data-grid.d.ts.map +1 -0
  462. package/dist/src/components/data-grid/index.d.ts +3 -0
  463. package/dist/src/components/data-grid/index.d.ts.map +1 -0
  464. package/dist/src/components/data-grid/types.d.ts +236 -0
  465. package/dist/src/components/data-grid/types.d.ts.map +1 -0
  466. package/dist/src/components/date-picker/date-picker.d.ts +65 -0
  467. package/dist/src/components/date-picker/date-picker.d.ts.map +1 -0
  468. package/dist/src/components/date-picker/index.d.ts +4 -0
  469. package/dist/src/components/date-picker/index.d.ts.map +1 -0
  470. package/dist/src/components/date-range-picker/date-range-picker.d.ts +125 -0
  471. package/dist/src/components/date-range-picker/date-range-picker.d.ts.map +1 -0
  472. package/dist/src/components/date-range-picker/index.d.ts +5 -0
  473. package/dist/src/components/date-range-picker/index.d.ts.map +1 -0
  474. package/dist/src/components/dialog/dialog.d.ts +189 -0
  475. package/dist/src/components/dialog/dialog.d.ts.map +1 -0
  476. package/dist/src/components/dialog/index.d.ts +2 -0
  477. package/dist/src/components/dialog/index.d.ts.map +1 -0
  478. package/dist/src/components/dropdown/dropdown.d.ts +91 -0
  479. package/dist/src/components/dropdown/dropdown.d.ts.map +1 -0
  480. package/dist/src/components/dropdown/index.d.ts +2 -0
  481. package/dist/src/components/dropdown/index.d.ts.map +1 -0
  482. package/dist/src/components/empty/empty.d.ts +69 -0
  483. package/dist/src/components/empty/empty.d.ts.map +1 -0
  484. package/dist/src/components/empty/index.d.ts +2 -0
  485. package/dist/src/components/empty/index.d.ts.map +1 -0
  486. package/dist/src/components/field/field.d.ts +68 -0
  487. package/dist/src/components/field/field.d.ts.map +1 -0
  488. package/dist/src/components/field/index.d.ts +2 -0
  489. package/dist/src/components/field/index.d.ts.map +1 -0
  490. package/dist/src/components/filters/filters.d.ts +54 -0
  491. package/dist/src/components/filters/filters.d.ts.map +1 -0
  492. package/dist/src/components/filters/helpers.d.ts +56 -0
  493. package/dist/src/components/filters/helpers.d.ts.map +1 -0
  494. package/dist/src/components/filters/index.d.ts +3 -0
  495. package/dist/src/components/filters/index.d.ts.map +1 -0
  496. package/dist/src/components/filters/types.d.ts +148 -0
  497. package/dist/src/components/filters/types.d.ts.map +1 -0
  498. package/dist/src/components/flow/connectors.d.ts +35 -0
  499. package/dist/src/components/flow/connectors.d.ts.map +1 -0
  500. package/dist/src/components/flow/diagram.d.ts +62 -0
  501. package/dist/src/components/flow/diagram.d.ts.map +1 -0
  502. package/dist/src/components/flow/index.d.ts +26 -0
  503. package/dist/src/components/flow/index.d.ts.map +1 -0
  504. package/dist/src/components/flow/node.d.ts +52 -0
  505. package/dist/src/components/flow/node.d.ts.map +1 -0
  506. package/dist/src/components/flow/parallel.d.ts +5 -0
  507. package/dist/src/components/flow/parallel.d.ts.map +1 -0
  508. package/dist/src/components/flow/use-children.d.ts +69 -0
  509. package/dist/src/components/flow/use-children.d.ts.map +1 -0
  510. package/dist/src/components/grid/grid.d.ts +135 -0
  511. package/dist/src/components/grid/grid.d.ts.map +1 -0
  512. package/dist/src/components/grid/index.d.ts +2 -0
  513. package/dist/src/components/grid/index.d.ts.map +1 -0
  514. package/dist/src/components/input/index.d.ts +4 -0
  515. package/dist/src/components/input/index.d.ts.map +1 -0
  516. package/dist/src/components/input/input-area.d.ts +65 -0
  517. package/dist/src/components/input/input-area.d.ts.map +1 -0
  518. package/dist/src/components/input/input-group.d.ts +39 -0
  519. package/dist/src/components/input/input-group.d.ts.map +1 -0
  520. package/dist/src/components/input/input.d.ts +172 -0
  521. package/dist/src/components/input/input.d.ts.map +1 -0
  522. package/dist/src/components/label/index.d.ts +2 -0
  523. package/dist/src/components/label/index.d.ts.map +1 -0
  524. package/dist/src/components/label/label.d.ts +67 -0
  525. package/dist/src/components/label/label.d.ts.map +1 -0
  526. package/dist/src/components/layer-card/index.d.ts +2 -0
  527. package/dist/src/components/layer-card/index.d.ts.map +1 -0
  528. package/dist/src/components/layer-card/layer-card.d.ts +29 -0
  529. package/dist/src/components/layer-card/layer-card.d.ts.map +1 -0
  530. package/dist/src/components/link/index.d.ts +2 -0
  531. package/dist/src/components/link/index.d.ts.map +1 -0
  532. package/dist/src/components/link/link.d.ts +55 -0
  533. package/dist/src/components/link/link.d.ts.map +1 -0
  534. package/dist/src/components/loader/index.d.ts +3 -0
  535. package/dist/src/components/loader/index.d.ts.map +1 -0
  536. package/dist/src/components/loader/loader.d.ts +65 -0
  537. package/dist/src/components/loader/loader.d.ts.map +1 -0
  538. package/dist/src/components/loader/skeleton-line.d.ts +10 -0
  539. package/dist/src/components/loader/skeleton-line.d.ts.map +1 -0
  540. package/dist/src/components/menubar/index.d.ts +3 -0
  541. package/dist/src/components/menubar/index.d.ts.map +1 -0
  542. package/dist/src/components/menubar/menubar.d.ts +66 -0
  543. package/dist/src/components/menubar/menubar.d.ts.map +1 -0
  544. package/dist/src/components/menubar/use-menu-navigation.d.ts +8 -0
  545. package/dist/src/components/menubar/use-menu-navigation.d.ts.map +1 -0
  546. package/dist/src/components/meter/index.d.ts +2 -0
  547. package/dist/src/components/meter/index.d.ts.map +1 -0
  548. package/dist/src/components/meter/meter.d.ts +44 -0
  549. package/dist/src/components/meter/meter.d.ts.map +1 -0
  550. package/dist/src/components/pagination/index.d.ts +2 -0
  551. package/dist/src/components/pagination/index.d.ts.map +1 -0
  552. package/dist/src/components/pagination/pagination.d.ts +60 -0
  553. package/dist/src/components/pagination/pagination.d.ts.map +1 -0
  554. package/dist/src/components/popover/index.d.ts +3 -0
  555. package/dist/src/components/popover/index.d.ts.map +1 -0
  556. package/dist/src/components/popover/popover.d.ts +138 -0
  557. package/dist/src/components/popover/popover.d.ts.map +1 -0
  558. package/dist/src/components/radio/index.d.ts +2 -0
  559. package/dist/src/components/radio/index.d.ts.map +1 -0
  560. package/dist/src/components/radio/radio.d.ts +163 -0
  561. package/dist/src/components/radio/radio.d.ts.map +1 -0
  562. package/dist/src/components/select/index.d.ts +2 -0
  563. package/dist/src/components/select/index.d.ts.map +1 -0
  564. package/dist/src/components/select/select.d.ts +150 -0
  565. package/dist/src/components/select/select.d.ts.map +1 -0
  566. package/dist/src/components/sensitive-input/index.d.ts +2 -0
  567. package/dist/src/components/sensitive-input/index.d.ts.map +1 -0
  568. package/dist/src/components/sensitive-input/sensitive-input.d.ts +94 -0
  569. package/dist/src/components/sensitive-input/sensitive-input.d.ts.map +1 -0
  570. package/dist/src/components/sidebar/index.d.ts +2 -0
  571. package/dist/src/components/sidebar/index.d.ts.map +1 -0
  572. package/dist/src/components/sidebar/sidebar.d.ts +556 -0
  573. package/dist/src/components/sidebar/sidebar.d.ts.map +1 -0
  574. package/dist/src/components/signalflare-ai-logo/index.d.ts +2 -0
  575. package/dist/src/components/signalflare-ai-logo/index.d.ts.map +1 -0
  576. package/dist/src/components/signalflare-ai-logo/signalflare-ai-logo.d.ts +171 -0
  577. package/dist/src/components/signalflare-ai-logo/signalflare-ai-logo.d.ts.map +1 -0
  578. package/dist/src/components/surface/index.d.ts +2 -0
  579. package/dist/src/components/surface/index.d.ts.map +1 -0
  580. package/dist/src/components/surface/surface.d.ts +60 -0
  581. package/dist/src/components/surface/surface.d.ts.map +1 -0
  582. package/dist/src/components/switch/index.d.ts +2 -0
  583. package/dist/src/components/switch/index.d.ts.map +1 -0
  584. package/dist/src/components/switch/switch.d.ts +169 -0
  585. package/dist/src/components/switch/switch.d.ts.map +1 -0
  586. package/dist/src/components/table/index.d.ts +2 -0
  587. package/dist/src/components/table/index.d.ts.map +1 -0
  588. package/dist/src/components/table/table.d.ts +89 -0
  589. package/dist/src/components/table/table.d.ts.map +1 -0
  590. package/dist/src/components/tabs/index.d.ts +3 -0
  591. package/dist/src/components/tabs/index.d.ts.map +1 -0
  592. package/dist/src/components/tabs/tabs.d.ts +105 -0
  593. package/dist/src/components/tabs/tabs.d.ts.map +1 -0
  594. package/dist/src/components/text/index.d.ts +2 -0
  595. package/dist/src/components/text/index.d.ts.map +1 -0
  596. package/dist/src/components/text/text.d.ts +181 -0
  597. package/dist/src/components/text/text.d.ts.map +1 -0
  598. package/dist/src/components/theme-toggle/index.d.ts +2 -0
  599. package/dist/src/components/theme-toggle/index.d.ts.map +1 -0
  600. package/dist/src/components/theme-toggle/theme-toggle.d.ts +68 -0
  601. package/dist/src/components/theme-toggle/theme-toggle.d.ts.map +1 -0
  602. package/dist/src/components/toast/index.d.ts +5 -0
  603. package/dist/src/components/toast/index.d.ts.map +1 -0
  604. package/dist/src/components/toast/toast.d.ts +152 -0
  605. package/dist/src/components/toast/toast.d.ts.map +1 -0
  606. package/dist/src/components/tooltip/index.d.ts +2 -0
  607. package/dist/src/components/tooltip/index.d.ts.map +1 -0
  608. package/dist/src/components/tooltip/tooltip.d.ts +82 -0
  609. package/dist/src/components/tooltip/tooltip.d.ts.map +1 -0
  610. package/dist/src/components/use-agent-harness/index.d.ts +2 -0
  611. package/dist/src/components/use-agent-harness/index.d.ts.map +1 -0
  612. package/dist/src/components/use-agent-harness/use-agent-harness.d.ts +642 -0
  613. package/dist/src/components/use-agent-harness/use-agent-harness.d.ts.map +1 -0
  614. package/dist/src/genui/genui.d.ts +17 -0
  615. package/dist/src/genui/genui.d.ts.map +1 -0
  616. package/dist/src/genui/index.d.ts +19 -0
  617. package/dist/src/genui/index.d.ts.map +1 -0
  618. package/dist/src/index.d.ts +102 -0
  619. package/dist/src/index.d.ts.map +1 -0
  620. package/dist/src/lib/utils.d.ts +2 -0
  621. package/dist/src/lib/utils.d.ts.map +1 -0
  622. package/dist/src/primitives/accordion.d.ts +13 -0
  623. package/dist/src/primitives/accordion.d.ts.map +1 -0
  624. package/dist/src/primitives/alert-dialog.d.ts +13 -0
  625. package/dist/src/primitives/alert-dialog.d.ts.map +1 -0
  626. package/dist/src/primitives/autocomplete.d.ts +13 -0
  627. package/dist/src/primitives/autocomplete.d.ts.map +1 -0
  628. package/dist/src/primitives/avatar.d.ts +13 -0
  629. package/dist/src/primitives/avatar.d.ts.map +1 -0
  630. package/dist/src/primitives/button.d.ts +13 -0
  631. package/dist/src/primitives/button.d.ts.map +1 -0
  632. package/dist/src/primitives/checkbox-group.d.ts +13 -0
  633. package/dist/src/primitives/checkbox-group.d.ts.map +1 -0
  634. package/dist/src/primitives/checkbox.d.ts +13 -0
  635. package/dist/src/primitives/checkbox.d.ts.map +1 -0
  636. package/dist/src/primitives/collapsible.d.ts +13 -0
  637. package/dist/src/primitives/collapsible.d.ts.map +1 -0
  638. package/dist/src/primitives/combobox.d.ts +13 -0
  639. package/dist/src/primitives/combobox.d.ts.map +1 -0
  640. package/dist/src/primitives/context-menu.d.ts +13 -0
  641. package/dist/src/primitives/context-menu.d.ts.map +1 -0
  642. package/dist/src/primitives/csp-provider.d.ts +13 -0
  643. package/dist/src/primitives/csp-provider.d.ts.map +1 -0
  644. package/dist/src/primitives/dialog.d.ts +13 -0
  645. package/dist/src/primitives/dialog.d.ts.map +1 -0
  646. package/dist/src/primitives/direction-provider.d.ts +13 -0
  647. package/dist/src/primitives/direction-provider.d.ts.map +1 -0
  648. package/dist/src/primitives/drawer.d.ts +13 -0
  649. package/dist/src/primitives/drawer.d.ts.map +1 -0
  650. package/dist/src/primitives/field.d.ts +13 -0
  651. package/dist/src/primitives/field.d.ts.map +1 -0
  652. package/dist/src/primitives/fieldset.d.ts +13 -0
  653. package/dist/src/primitives/fieldset.d.ts.map +1 -0
  654. package/dist/src/primitives/form.d.ts +13 -0
  655. package/dist/src/primitives/form.d.ts.map +1 -0
  656. package/dist/src/primitives/index.d.ts +54 -0
  657. package/dist/src/primitives/index.d.ts.map +1 -0
  658. package/dist/src/primitives/input.d.ts +13 -0
  659. package/dist/src/primitives/input.d.ts.map +1 -0
  660. package/dist/src/primitives/menu.d.ts +13 -0
  661. package/dist/src/primitives/menu.d.ts.map +1 -0
  662. package/dist/src/primitives/menubar.d.ts +13 -0
  663. package/dist/src/primitives/menubar.d.ts.map +1 -0
  664. package/dist/src/primitives/meter.d.ts +13 -0
  665. package/dist/src/primitives/meter.d.ts.map +1 -0
  666. package/dist/src/primitives/navigation-menu.d.ts +13 -0
  667. package/dist/src/primitives/navigation-menu.d.ts.map +1 -0
  668. package/dist/src/primitives/number-field.d.ts +13 -0
  669. package/dist/src/primitives/number-field.d.ts.map +1 -0
  670. package/dist/src/primitives/popover.d.ts +13 -0
  671. package/dist/src/primitives/popover.d.ts.map +1 -0
  672. package/dist/src/primitives/preview-card.d.ts +13 -0
  673. package/dist/src/primitives/preview-card.d.ts.map +1 -0
  674. package/dist/src/primitives/progress.d.ts +13 -0
  675. package/dist/src/primitives/progress.d.ts.map +1 -0
  676. package/dist/src/primitives/radio-group.d.ts +13 -0
  677. package/dist/src/primitives/radio-group.d.ts.map +1 -0
  678. package/dist/src/primitives/radio.d.ts +13 -0
  679. package/dist/src/primitives/radio.d.ts.map +1 -0
  680. package/dist/src/primitives/scroll-area.d.ts +13 -0
  681. package/dist/src/primitives/scroll-area.d.ts.map +1 -0
  682. package/dist/src/primitives/select.d.ts +13 -0
  683. package/dist/src/primitives/select.d.ts.map +1 -0
  684. package/dist/src/primitives/separator.d.ts +13 -0
  685. package/dist/src/primitives/separator.d.ts.map +1 -0
  686. package/dist/src/primitives/slider.d.ts +13 -0
  687. package/dist/src/primitives/slider.d.ts.map +1 -0
  688. package/dist/src/primitives/switch.d.ts +13 -0
  689. package/dist/src/primitives/switch.d.ts.map +1 -0
  690. package/dist/src/primitives/tabs.d.ts +13 -0
  691. package/dist/src/primitives/tabs.d.ts.map +1 -0
  692. package/dist/src/primitives/toast.d.ts +13 -0
  693. package/dist/src/primitives/toast.d.ts.map +1 -0
  694. package/dist/src/primitives/toggle-group.d.ts +13 -0
  695. package/dist/src/primitives/toggle-group.d.ts.map +1 -0
  696. package/dist/src/primitives/toggle.d.ts +13 -0
  697. package/dist/src/primitives/toggle.d.ts.map +1 -0
  698. package/dist/src/primitives/toolbar.d.ts +13 -0
  699. package/dist/src/primitives/toolbar.d.ts.map +1 -0
  700. package/dist/src/primitives/tooltip.d.ts +13 -0
  701. package/dist/src/primitives/tooltip.d.ts.map +1 -0
  702. package/dist/src/registry/index.d.ts +8 -0
  703. package/dist/src/registry/index.d.ts.map +1 -0
  704. package/dist/src/registry/types.d.ts +191 -0
  705. package/dist/src/registry/types.d.ts.map +1 -0
  706. package/dist/src/utils/cn.d.ts +4 -0
  707. package/dist/src/utils/cn.d.ts.map +1 -0
  708. package/dist/src/utils/highlight-to-react.d.ts +12 -0
  709. package/dist/src/utils/highlight-to-react.d.ts.map +1 -0
  710. package/dist/src/utils/index.d.ts +3 -0
  711. package/dist/src/utils/index.d.ts.map +1 -0
  712. package/dist/src/utils/link-provider.d.ts +12 -0
  713. package/dist/src/utils/link-provider.d.ts.map +1 -0
  714. package/dist/src/utils/prop-examples.d.ts +36 -0
  715. package/dist/src/utils/prop-examples.d.ts.map +1 -0
  716. package/dist/styles/sf-binding.css +255 -0
  717. package/dist/styles/sf-standalone.css +2 -0
  718. package/dist/styles/sf.css +596 -0
  719. package/dist/styles/theme-fedramp.css +22 -0
  720. package/dist/styles/theme-minimal.css +127 -0
  721. package/dist/styles/theme-navigator.css +137 -0
  722. package/dist/styles/theme-sf.css +191 -0
  723. package/dist/surface-BduI7Ehl.js +18 -0
  724. package/dist/surface-BduI7Ehl.js.map +1 -0
  725. package/dist/switch-CzZBRBL7.js +169 -0
  726. package/dist/switch-CzZBRBL7.js.map +1 -0
  727. package/dist/table-CIMx0Oq0.js +200 -0
  728. package/dist/table-CIMx0Oq0.js.map +1 -0
  729. package/dist/tabs-1cHrYoel.js +54 -0
  730. package/dist/tabs-1cHrYoel.js.map +1 -0
  731. package/dist/text-KJmGkwnf.js +103 -0
  732. package/dist/text-KJmGkwnf.js.map +1 -0
  733. package/dist/theme-toggle-Dpgnoj_Q.js +129 -0
  734. package/dist/theme-toggle-Dpgnoj_Q.js.map +1 -0
  735. package/dist/toast-Nw28a5Cx.js +161 -0
  736. package/dist/toast-Nw28a5Cx.js.map +1 -0
  737. package/dist/tooltip-Cb7QW-7H.js +79 -0
  738. package/dist/tooltip-Cb7QW-7H.js.map +1 -0
  739. package/dist/use-agent-harness-DZzcn96L.js +929 -0
  740. package/dist/use-agent-harness-DZzcn96L.js.map +1 -0
  741. package/dist/utils.js +4 -0
  742. package/package.json +620 -0
  743. package/scripts/component-registry/cache.ts +124 -0
  744. package/scripts/component-registry/discovery.ts +464 -0
  745. package/scripts/component-registry/example-cleanup.ts +168 -0
  746. package/scripts/component-registry/index.test.ts +678 -0
  747. package/scripts/component-registry/index.ts +931 -0
  748. package/scripts/component-registry/markdown-generator.ts +222 -0
  749. package/scripts/component-registry/metadata.ts +653 -0
  750. package/scripts/component-registry/props-filter.ts +313 -0
  751. package/scripts/component-registry/schema-generator.ts +332 -0
  752. package/scripts/component-registry/sub-components.ts +350 -0
  753. package/scripts/component-registry/types.ts +156 -0
  754. package/scripts/component-registry/utils.ts +280 -0
  755. package/scripts/component-registry/variant-parser.ts +262 -0
  756. package/scripts/css-build.ts +117 -0
  757. package/scripts/generate-primitives.ts +178 -0
  758. package/scripts/theme-generator/config.ts +538 -0
  759. package/scripts/theme-generator/generate-css.ts +256 -0
  760. package/scripts/theme-generator/index.ts +161 -0
  761. package/scripts/theme-generator/migrate.ts +584 -0
  762. package/scripts/theme-generator/types.ts +86 -0
  763. package/skills/component-selection/SKILL.md +64 -0
  764. package/skills/installing-blocks/SKILL.md +47 -0
  765. package/skills/theming-and-tokens/SKILL.md +62 -0
@@ -0,0 +1,484 @@
1
+ "use client";
2
+ import { t as cn } from "./cn-YROP2_ox.js";
3
+ import { t as Loader } from "./loader-DAcc-Uag.js";
4
+ import { t as Surface } from "./surface-BduI7Ehl.js";
5
+ import { createContext, forwardRef, useCallback, useContext, useRef } from "react";
6
+ import { Fragment as Fragment$1, jsx, jsxs } from "react/jsx-runtime";
7
+ import { ArrowRightIcon, ArrowSquareOutIcon, CaretRightIcon, MagnifyingGlassIcon } from "@phosphor-icons/react";
8
+ import { Dialog } from "@base-ui/react/dialog";
9
+ import { Autocomplete } from "@base-ui/react/autocomplete";
10
+ //#region src/components/command-palette/command-palette.tsx
11
+ var DialogContext = createContext({});
12
+ /**
13
+ * Dialog component - Modal wrapper for command palette content.
14
+ *
15
+ * Use this when you need a dialog that can swap between different Panel contents
16
+ * without re-mounting (e.g., drill-down navigation).
17
+ *
18
+ * @example
19
+ * ```tsx
20
+ * <CommandPalette.Dialog open={open} onOpenChange={setOpen}>
21
+ * {showDrillDown ? (
22
+ * <ZonePicker />
23
+ * ) : (
24
+ * <CommandPalette.Panel items={results} ...>
25
+ * ...
26
+ * </CommandPalette.Panel>
27
+ * )}
28
+ * </CommandPalette.Dialog>
29
+ * ```
30
+ */
31
+ function Dialog$1({ open, onOpenChange, onBackdropClick, children }) {
32
+ const handleBackdropClick = (e) => {
33
+ if (onBackdropClick) onBackdropClick(e);
34
+ else onOpenChange(false);
35
+ };
36
+ const handleClose = useCallback(() => {
37
+ onOpenChange(false);
38
+ }, [onOpenChange]);
39
+ return /* @__PURE__ */ jsx(Dialog.Root, {
40
+ open,
41
+ onOpenChange,
42
+ modal: true,
43
+ children: /* @__PURE__ */ jsxs(Dialog.Portal, { children: [/* @__PURE__ */ jsx(Dialog.Backdrop, {
44
+ className: "fixed inset-0 bg-sf-overlay opacity-80 transition-all duration-150 data-[ending-style]:opacity-0 data-[starting-style]:opacity-0",
45
+ onClick: handleBackdropClick
46
+ }), /* @__PURE__ */ jsx(Surface, {
47
+ as: Dialog.Popup,
48
+ className: cn("fixed top-[10vh] left-1/2 w-full max-w-2xl -translate-x-1/2", "overflow-hidden rounded-lg", "duration-150 data-[ending-style]:scale-90 data-[ending-style]:opacity-0 data-[starting-style]:scale-90 data-[starting-style]:opacity-0"),
49
+ style: {
50
+ transitionProperty: "scale, opacity",
51
+ transitionTimingFunction: "var(--default-transition-timing-function)"
52
+ },
53
+ children: /* @__PURE__ */ jsx(DialogContext.Provider, {
54
+ value: { onClose: handleClose },
55
+ children
56
+ })
57
+ })] })
58
+ });
59
+ }
60
+ /**
61
+ * Root component - Dialog + Panel combined for simple use cases.
62
+ *
63
+ * For cases where you need to swap content inside the dialog without
64
+ * re-mounting (e.g., drill-down navigation), use Dialog + Panel separately.
65
+ *
66
+ * Keyboard navigation is always enabled:
67
+ * - Arrow keys (up/down) move highlight
68
+ * - Enter selects highlighted item
69
+ * - Cmd/Ctrl+Enter selects with newTab: true
70
+ * - First item is auto-highlighted when results change
71
+ */
72
+ function Root({ open, onOpenChange, onBackdropClick, children, items, value, onValueChange, onItemHighlighted, itemToStringValue, filter, onSelect, getSelectableItems }) {
73
+ return /* @__PURE__ */ jsx(Dialog$1, {
74
+ open,
75
+ onOpenChange,
76
+ onBackdropClick,
77
+ children: /* @__PURE__ */ jsx(Panel, {
78
+ items,
79
+ value,
80
+ onValueChange,
81
+ onItemHighlighted,
82
+ itemToStringValue,
83
+ filter,
84
+ open,
85
+ onSelect,
86
+ getSelectableItems,
87
+ children
88
+ })
89
+ });
90
+ }
91
+ /**
92
+ * InputHeader component - Internal styled container for search input.
93
+ */
94
+ function InputHeader({ children, leading, trailing }) {
95
+ return /* @__PURE__ */ jsxs("div", {
96
+ className: "flex items-center gap-3 bg-sf-elevated px-4 py-3",
97
+ children: [
98
+ leading ?? /* @__PURE__ */ jsx(MagnifyingGlassIcon, {
99
+ className: "h-4 w-4 text-sf-subtle",
100
+ weight: "bold"
101
+ }),
102
+ children,
103
+ trailing
104
+ ]
105
+ });
106
+ }
107
+ /**
108
+ * List component - Scrollable results container
109
+ *
110
+ * Wrapper div with proper styling, contains Autocomplete.List internally.
111
+ * Supports ref forwarding for scroll control.
112
+ */
113
+ var List = forwardRef(function List({ children, className }, ref) {
114
+ return /* @__PURE__ */ jsx("div", {
115
+ ref,
116
+ className: cn("z-10 min-h-0 flex-1 overflow-y-auto rounded-b-lg bg-sf-elevated px-2 py-2 ring-1 ring-sf-line", className),
117
+ children
118
+ });
119
+ });
120
+ List.displayName = "CommandPalette.List";
121
+ /**
122
+ * Group component - Category grouping
123
+ *
124
+ * Re-export of Autocomplete.Group with default styling.
125
+ */
126
+ function Group({ children, className, ...props }) {
127
+ return /* @__PURE__ */ jsx(Autocomplete.Group, {
128
+ className: cn("space-y-0.5", className),
129
+ ...props,
130
+ children
131
+ });
132
+ }
133
+ /**
134
+ * GroupLabel component - Section header text
135
+ *
136
+ * Re-export of Autocomplete.GroupLabel with styling matching SectionHeader.
137
+ */
138
+ function GroupLabel({ children, className }) {
139
+ return /* @__PURE__ */ jsx(Autocomplete.GroupLabel, {
140
+ className: cn("mb-2 px-2 pt-1 text-xs font-semibold text-sf-strong", className),
141
+ children
142
+ });
143
+ }
144
+ /**
145
+ * Item component - Individual result item
146
+ *
147
+ * Re-export of Autocomplete.Item with styling matching SearchResultItem.
148
+ * Note: Use onClick for selection handling, matching the existing CommandPalette pattern.
149
+ */
150
+ function Item({ value, disabled, children, className, onClick }) {
151
+ return /* @__PURE__ */ jsx(Autocomplete.Item, {
152
+ value,
153
+ disabled,
154
+ onClick,
155
+ className: cn("group flex w-full items-center gap-3 px-2 py-1.5 text-left transition-colors", "cursor-pointer data-[highlighted]:bg-sf-overlay", "rounded-lg", disabled && "cursor-default opacity-50", className),
156
+ children
157
+ });
158
+ }
159
+ /**
160
+ * Empty component - Empty state when no results
161
+ *
162
+ * Re-export of Autocomplete.Empty with default styling.
163
+ */
164
+ function Empty({ children }) {
165
+ return /* @__PURE__ */ jsx(Autocomplete.Empty, { children: /* @__PURE__ */ jsx("div", {
166
+ className: "p-8 text-center",
167
+ children: /* @__PURE__ */ jsx("p", {
168
+ className: "text-sf-strong",
169
+ children: children ?? "No results found"
170
+ })
171
+ }) });
172
+ }
173
+ /**
174
+ * Loading component - Loading spinner state
175
+ *
176
+ * Centered loading spinner using SF Loader.
177
+ */
178
+ function Loading({ children }) {
179
+ return /* @__PURE__ */ jsx("div", {
180
+ className: "flex items-center justify-center p-8",
181
+ children: children ?? /* @__PURE__ */ jsx(Loader, { size: 24 })
182
+ });
183
+ }
184
+ /**
185
+ * Footer component - Styled container for keyboard hints or other footer content.
186
+ *
187
+ * Children are required - this is just a styled container.
188
+ * Consumers should provide their own keyboard hints with proper i18n.
189
+ */
190
+ function Footer({ children }) {
191
+ return /* @__PURE__ */ jsx("div", {
192
+ className: "flex items-center justify-between rounded-b-lg bg-sf-elevated px-4 py-3 text-xs text-sf-strong",
193
+ children
194
+ });
195
+ }
196
+ /**
197
+ * HighlightedText - Renders text with highlighted portions based on match indices.
198
+ * Highlighted text is shown with a background color to indicate matches.
199
+ */
200
+ function HighlightedText({ text, highlights, className }) {
201
+ if (!highlights || highlights.length === 0) return /* @__PURE__ */ jsx("span", {
202
+ className,
203
+ children: text
204
+ });
205
+ const sortedHighlights = [...highlights].sort((a, b) => a[0] - b[0]);
206
+ const mergedHighlights = [];
207
+ for (const range of sortedHighlights) {
208
+ const last = mergedHighlights[mergedHighlights.length - 1];
209
+ if (last && range[0] <= last[1] + 1) last[1] = Math.max(last[1], range[1]);
210
+ else mergedHighlights.push([...range]);
211
+ }
212
+ const parts = [];
213
+ let lastIndex = 0;
214
+ mergedHighlights.forEach((range, i) => {
215
+ const [start, end] = range;
216
+ if (start > lastIndex) parts.push(/* @__PURE__ */ jsx("span", { children: text.slice(lastIndex, start) }, `text-${i}`));
217
+ parts.push(/* @__PURE__ */ jsx("mark", {
218
+ className: "rounded-sm bg-sf-warning/50 text-sf-default",
219
+ children: text.slice(start, end + 1)
220
+ }, `highlight-${i}`));
221
+ lastIndex = end + 1;
222
+ });
223
+ if (lastIndex < text.length) parts.push(/* @__PURE__ */ jsx("span", { children: text.slice(lastIndex) }, "text-end"));
224
+ return /* @__PURE__ */ jsx("span", {
225
+ className,
226
+ children: parts
227
+ });
228
+ }
229
+ /**
230
+ * ResultItem - Rich item component with breadcrumbs, highlights, icons, and external indicators.
231
+ *
232
+ * Use this for search result items that need breadcrumb navigation, text highlighting,
233
+ * or external link indicators. For simple items, use Item instead.
234
+ */
235
+ function ResultItem({ title, breadcrumbs, titleHighlights, breadcrumbHighlights, description, icon, value, onClick, showArrow = true, external = false, nonInteractive = false }) {
236
+ return /* @__PURE__ */ jsxs(Autocomplete.Item, {
237
+ value,
238
+ onClick: nonInteractive ? void 0 : (e) => onClick(e),
239
+ className: cn("group flex w-full items-center gap-3 rounded-lg px-2 py-1.5 text-left transition-colors", nonInteractive ? "cursor-default" : "cursor-pointer data-[highlighted]:bg-sf-overlay"),
240
+ children: [
241
+ icon && /* @__PURE__ */ jsx("div", {
242
+ className: "flex flex-shrink-0 items-center text-sf-subtle",
243
+ children: icon
244
+ }),
245
+ /* @__PURE__ */ jsx("div", {
246
+ className: "min-w-0 flex-1",
247
+ children: /* @__PURE__ */ jsxs("div", {
248
+ className: "flex items-center gap-2 truncate",
249
+ children: [
250
+ breadcrumbs?.map((crumb, index) => /* @__PURE__ */ jsxs("span", {
251
+ className: "flex items-center gap-2",
252
+ children: [/* @__PURE__ */ jsx(HighlightedText, {
253
+ text: crumb,
254
+ highlights: breadcrumbHighlights?.[index],
255
+ className: "text-base text-sf-default"
256
+ }), /* @__PURE__ */ jsx(CaretRightIcon, {
257
+ className: "h-3 w-3 flex-shrink-0 text-sf-subtle",
258
+ weight: "bold"
259
+ })]
260
+ }, index)),
261
+ /* @__PURE__ */ jsx(HighlightedText, {
262
+ text: title,
263
+ highlights: titleHighlights,
264
+ className: "text-base text-sf-default"
265
+ }),
266
+ external && /* @__PURE__ */ jsx(ArrowSquareOutIcon, { className: "h-3.5 w-3.5 flex-shrink-0 text-sf-subtle" }),
267
+ description && /* @__PURE__ */ jsxs(Fragment$1, { children: [/* @__PURE__ */ jsx("span", {
268
+ className: "text-sf-strong",
269
+ children: "—"
270
+ }), /* @__PURE__ */ jsx("span", {
271
+ className: "truncate text-sm text-sf-strong",
272
+ children: description
273
+ })] })
274
+ ]
275
+ })
276
+ }),
277
+ showArrow && !external && !nonInteractive && /* @__PURE__ */ jsx(ArrowRightIcon, { className: "h-4 w-4 flex-shrink-0 text-sf-subtle opacity-0 transition-opacity group-data-[highlighted]:opacity-100" })
278
+ ]
279
+ });
280
+ }
281
+ /**
282
+ * Container component - Internal styled wrapper.
283
+ */
284
+ function Container({ children, className }) {
285
+ return /* @__PURE__ */ jsx("div", {
286
+ className: cn("flex max-h-[60vh] flex-col overflow-hidden rounded-lg bg-sf-elevated", className),
287
+ children
288
+ });
289
+ }
290
+ var PanelContext = createContext({});
291
+ /**
292
+ * Panel component - Command palette without dialog wrapper.
293
+ *
294
+ * Use this when you need to render command palette content inside an existing dialog
295
+ * (e.g., for drill-down navigation where the dialog stays open but content changes).
296
+ *
297
+ * Combines Container + Autocomplete functionality with a clean API.
298
+ *
299
+ * @example
300
+ * ```tsx
301
+ * <DialogRoot open={open} onOpenChange={setOpen}>
302
+ * <Dialog>
303
+ * <CommandPalette.Panel
304
+ * items={results}
305
+ * value={searchTerm}
306
+ * onValueChange={setSearchTerm}
307
+ * itemToStringValue={(group) => group.label}
308
+ * >
309
+ * <CommandPalette.Input placeholder="Search..." />
310
+ * <CommandPalette.List>
311
+ * <CommandPalette.Results>
312
+ * {(group) => (
313
+ * <CommandPalette.Group items={group.items}>
314
+ * <CommandPalette.GroupLabel>{group.label}</CommandPalette.GroupLabel>
315
+ * <CommandPalette.Items>
316
+ * {(item) => <CommandPalette.ResultItem ... />}
317
+ * </CommandPalette.Items>
318
+ * </CommandPalette.Group>
319
+ * )}
320
+ * </CommandPalette.Results>
321
+ * <CommandPalette.Empty>No results</CommandPalette.Empty>
322
+ * </CommandPalette.List>
323
+ * <CommandPalette.Footer>...</CommandPalette.Footer>
324
+ * </CommandPalette.Panel>
325
+ * </Dialog>
326
+ * </DialogRoot>
327
+ * ```
328
+ */
329
+ var defaultFilter = () => true;
330
+ function Panel({ children, items, value, onValueChange, onItemHighlighted, itemToStringValue, filter = defaultFilter, open = true, className, onSelect, getSelectableItems }) {
331
+ const highlightedIndexRef = useRef(-1);
332
+ const handleItemHighlighted = useCallback((item, details) => {
333
+ highlightedIndexRef.current = details.index;
334
+ onItemHighlighted?.(item, details);
335
+ }, [onItemHighlighted]);
336
+ const handleInputKeyDown = useCallback((e) => {
337
+ const isEnter = e.key === "Enter";
338
+ const withModifier = e.metaKey || e.ctrlKey;
339
+ if (isEnter && withModifier && onSelect && getSelectableItems) {
340
+ const highlightedItem = getSelectableItems(items)[highlightedIndexRef.current];
341
+ if (highlightedItem !== void 0) {
342
+ e.preventDefault();
343
+ onSelect(highlightedItem, { newTab: true });
344
+ }
345
+ }
346
+ }, [
347
+ items,
348
+ onSelect,
349
+ getSelectableItems
350
+ ]);
351
+ return /* @__PURE__ */ jsx(Container, {
352
+ className,
353
+ children: /* @__PURE__ */ jsx(Autocomplete.Root, {
354
+ items,
355
+ value,
356
+ onValueChange,
357
+ onItemHighlighted: handleItemHighlighted,
358
+ itemToStringValue,
359
+ filter,
360
+ autoHighlight: "always",
361
+ keepHighlight: true,
362
+ open,
363
+ children: /* @__PURE__ */ jsx(PanelContext.Provider, {
364
+ value: { onInputKeyDown: handleInputKeyDown },
365
+ children
366
+ })
367
+ })
368
+ });
369
+ }
370
+ /**
371
+ * PanelInput component - Input that works inside Panel.
372
+ *
373
+ * Similar to Input but designed for use with Panel instead of Root.
374
+ * Automatically wires up Cmd/Ctrl+Enter handling from Panel.
375
+ */
376
+ function PanelInput({ autoFocus = true, placeholder, className, onKeyDown: onKeyDownProp, leading, trailing, ...props }) {
377
+ const { onInputKeyDown } = useContext(PanelContext);
378
+ const { onClose } = useContext(DialogContext);
379
+ const handleKeyDown = useCallback((e) => {
380
+ onKeyDownProp?.(e);
381
+ if (e.defaultPrevented) return;
382
+ if (e.key === "Escape" && onClose) {
383
+ e.preventDefault();
384
+ onClose();
385
+ return;
386
+ }
387
+ onInputKeyDown?.(e);
388
+ }, [
389
+ onInputKeyDown,
390
+ onKeyDownProp,
391
+ onClose
392
+ ]);
393
+ return /* @__PURE__ */ jsx(InputHeader, {
394
+ leading,
395
+ trailing,
396
+ children: /* @__PURE__ */ jsx(Autocomplete.Input, {
397
+ placeholder,
398
+ className: cn("flex-1 border-none bg-transparent text-base placeholder:text-sf-subtle", "outline-none focus-visible:outline-none", className),
399
+ onKeyDown: handleKeyDown,
400
+ autoFocus,
401
+ ...props
402
+ })
403
+ });
404
+ }
405
+ /**
406
+ * Render prop iterators - wrap base-ui primitives with cleaner names.
407
+ */
408
+ /**
409
+ * Results component - Render prop iterator for groups.
410
+ *
411
+ * Wraps Autocomplete.List with default spacing between groups.
412
+ */
413
+ function Results({ children, className }) {
414
+ return /* @__PURE__ */ jsx(Autocomplete.List, {
415
+ className: cn("space-y-3", className),
416
+ children
417
+ });
418
+ }
419
+ var Items = Autocomplete.Collection;
420
+ /** CommandPalette variant definitions (no user-facing variants; structure reserved for future use). */
421
+ var SF_COMMAND_PALETTE_VARIANTS = {};
422
+ var SF_COMMAND_PALETTE_DEFAULT_VARIANTS = {};
423
+ /**
424
+ * CommandPalette — accessible command palette / spotlight search overlay.
425
+ *
426
+ * Compound component: `CommandPalette.Root` (or `.Dialog` + `.Panel`),
427
+ * `.Input`, `.List`, `.Results`, `.Items`, `.Group`, `.GroupLabel`,
428
+ * `.Item`, `.ResultItem`, `.HighlightedText`, `.Empty`, `.Loading`, `.Footer`.
429
+ *
430
+ * Built on `@base-ui/react/autocomplete` + `@base-ui/react/dialog`.
431
+ *
432
+ * @example
433
+ * ```tsx
434
+ * <CommandPalette.Root
435
+ * open={open}
436
+ * onOpenChange={setOpen}
437
+ * items={results}
438
+ * value={query}
439
+ * onValueChange={setQuery}
440
+ * itemToStringValue={(g) => g.label}
441
+ * onSelect={(item, { newTab }) => navigate(item, newTab)}
442
+ * getSelectableItems={(groups) => groups.flatMap((g) => g.items)}
443
+ * >
444
+ * <CommandPalette.Input placeholder="Search…" />
445
+ * <CommandPalette.List>
446
+ * <CommandPalette.Results>
447
+ * {(group) => (
448
+ * <CommandPalette.Group items={group.items}>
449
+ * <CommandPalette.GroupLabel>{group.label}</CommandPalette.GroupLabel>
450
+ * <CommandPalette.Items>
451
+ * {(item) => (
452
+ * <CommandPalette.ResultItem title={item.title} value={item} onClick={…} />
453
+ * )}
454
+ * </CommandPalette.Items>
455
+ * </CommandPalette.Group>
456
+ * )}
457
+ * </CommandPalette.Results>
458
+ * <CommandPalette.Empty>No results found</CommandPalette.Empty>
459
+ * </CommandPalette.List>
460
+ * <CommandPalette.Footer>…keyboard hints…</CommandPalette.Footer>
461
+ * </CommandPalette.Root>
462
+ * ```
463
+ */
464
+ var CommandPalette = {
465
+ Dialog: Dialog$1,
466
+ Root,
467
+ Panel,
468
+ Input: PanelInput,
469
+ List,
470
+ Group,
471
+ GroupLabel,
472
+ Item,
473
+ ResultItem,
474
+ HighlightedText,
475
+ Empty,
476
+ Loading,
477
+ Footer,
478
+ Results,
479
+ Items
480
+ };
481
+ //#endregion
482
+ export { SF_COMMAND_PALETTE_DEFAULT_VARIANTS as n, SF_COMMAND_PALETTE_VARIANTS as r, CommandPalette as t };
483
+
484
+ //# sourceMappingURL=command-palette-CBTY8EiF.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"command-palette-CBTY8EiF.js","names":[],"sources":["../src/components/command-palette/command-palette.tsx"],"sourcesContent":["import { Autocomplete } from \"@base-ui/react/autocomplete\";\nimport { Dialog as DialogBase } from \"@base-ui/react/dialog\";\nimport {\n MagnifyingGlassIcon,\n ArrowRightIcon,\n ArrowSquareOutIcon,\n CaretRightIcon,\n} from \"@phosphor-icons/react\";\nimport {\n useRef,\n useCallback,\n createContext,\n useContext,\n forwardRef,\n type CSSProperties,\n} from \"react\";\n\nimport { cn } from \"../../utils\";\nimport { Loader } from \"../loader\";\nimport { Surface } from \"../surface\";\nimport type {\n HighlightRange,\n CommandPaletteRootProps,\n CommandPaletteListProps,\n CommandPaletteGroupProps,\n CommandPaletteGroupLabelProps,\n CommandPaletteItemProps,\n CommandPaletteEmptyProps,\n CommandPaletteLoadingProps,\n CommandPaletteFooterProps,\n CommandPaletteResultItemProps,\n} from \"./types\";\n\n/**\n * CommandPalette - A composable command palette component for SF\n *\n * Uses @base-ui/react/autocomplete primitives for accessible command palette functionality.\n *\n * Keyboard navigation is built-in:\n * - Arrow keys (up/down) move highlight between items\n * - Enter selects the highlighted item (calls onSelect with newTab: false)\n * - Cmd+Enter (Mac) / Ctrl+Enter (Windows/Linux) selects with newTab: true\n * - First item is auto-highlighted when results change\n * - Escape closes the dialog\n *\n * Usage:\n * ```tsx\n * <CommandPalette.Root\n * open={open}\n * onOpenChange={setOpen}\n * items={results}\n * value={searchTerm}\n * onValueChange={setSearchTerm}\n * itemToStringValue={(group) => group.label}\n * onSelect={(item, { newTab }) => handleSelect(item, newTab)}\n * getSelectableItems={(groups) => groups.flatMap(g => g.items)}\n * >\n * <CommandPalette.Input placeholder=\"Search...\" />\n * <CommandPalette.List>\n * <Autocomplete.List>\n * {(group) => (\n * <CommandPalette.Group items={group.items}>\n * <CommandPalette.GroupLabel>{group.label}</CommandPalette.GroupLabel>\n * <Autocomplete.Collection>\n * {(item) => (\n * <CommandPalette.Item value={item} onClick={(e) => handleSelect(item, e.metaKey || e.ctrlKey)}>\n * {item.title}\n * </CommandPalette.Item>\n * )}\n * </Autocomplete.Collection>\n * </CommandPalette.Group>\n * )}\n * </Autocomplete.List>\n * <CommandPalette.Empty>No results found</CommandPalette.Empty>\n * </CommandPalette.List>\n * <CommandPalette.Footer />\n * </CommandPalette.Root>\n * ```\n */\n\n/**\n * Dialog context for passing close handler to children\n */\ninterface DialogContextValue {\n onClose?: () => void;\n}\n\nconst DialogContext = createContext<DialogContextValue>({});\n\n/**\n * Props for the Dialog component\n */\ninterface DialogProps {\n /** Whether the dialog is open */\n open: boolean;\n /** Callback when the open state changes */\n onOpenChange: (open: boolean) => void;\n /**\n * Optional callback when backdrop is clicked.\n * Receives the mouse event for position tracking (e.g., for ripple effects).\n * If not provided, backdrop click calls onOpenChange(false).\n */\n onBackdropClick?: (e: React.MouseEvent) => void;\n /** Child content - typically one or more Panel components */\n children: React.ReactNode;\n}\n\n/**\n * Dialog component - Modal wrapper for command palette content.\n *\n * Use this when you need a dialog that can swap between different Panel contents\n * without re-mounting (e.g., drill-down navigation).\n *\n * @example\n * ```tsx\n * <CommandPalette.Dialog open={open} onOpenChange={setOpen}>\n * {showDrillDown ? (\n * <ZonePicker />\n * ) : (\n * <CommandPalette.Panel items={results} ...>\n * ...\n * </CommandPalette.Panel>\n * )}\n * </CommandPalette.Dialog>\n * ```\n */\nfunction Dialog({\n open,\n onOpenChange,\n onBackdropClick,\n children,\n}: DialogProps) {\n const handleBackdropClick = (e: React.MouseEvent) => {\n if (onBackdropClick) {\n onBackdropClick(e);\n } else {\n onOpenChange(false);\n }\n };\n\n const handleClose = useCallback(() => {\n onOpenChange(false);\n }, [onOpenChange]);\n\n return (\n <DialogBase.Root open={open} onOpenChange={onOpenChange} modal>\n <DialogBase.Portal>\n <DialogBase.Backdrop\n className=\"fixed inset-0 bg-sf-overlay opacity-80 transition-all duration-150 data-[ending-style]:opacity-0 data-[starting-style]:opacity-0\"\n onClick={handleBackdropClick}\n />\n <Surface\n as={DialogBase.Popup}\n className={cn(\n \"fixed top-[10vh] left-1/2 w-full max-w-2xl -translate-x-1/2\",\n \"overflow-hidden rounded-lg\",\n \"duration-150 data-[ending-style]:scale-90 data-[ending-style]:opacity-0 data-[starting-style]:scale-90 data-[starting-style]:opacity-0\"\n )}\n style={\n {\n transitionProperty: \"scale, opacity\",\n transitionTimingFunction:\n \"var(--default-transition-timing-function)\",\n } as CSSProperties\n }\n >\n <DialogContext.Provider value={{ onClose: handleClose }}>\n {children}\n </DialogContext.Provider>\n </Surface>\n </DialogBase.Portal>\n </DialogBase.Root>\n );\n}\n\n/**\n * Root component - Dialog + Panel combined for simple use cases.\n *\n * For cases where you need to swap content inside the dialog without\n * re-mounting (e.g., drill-down navigation), use Dialog + Panel separately.\n *\n * Keyboard navigation is always enabled:\n * - Arrow keys (up/down) move highlight\n * - Enter selects highlighted item\n * - Cmd/Ctrl+Enter selects with newTab: true\n * - First item is auto-highlighted when results change\n */\nfunction Root<TGroup, TItem = TGroup>({\n open,\n onOpenChange,\n onBackdropClick,\n children,\n items,\n value,\n onValueChange,\n onItemHighlighted,\n itemToStringValue,\n filter,\n onSelect,\n getSelectableItems,\n}: CommandPaletteRootProps<TGroup, TItem>) {\n return (\n <Dialog\n open={open}\n onOpenChange={onOpenChange}\n onBackdropClick={onBackdropClick}\n >\n <Panel\n items={items}\n value={value}\n onValueChange={onValueChange}\n onItemHighlighted={onItemHighlighted}\n itemToStringValue={itemToStringValue}\n filter={filter}\n open={open}\n onSelect={onSelect}\n getSelectableItems={getSelectableItems}\n >\n {children}\n </Panel>\n </Dialog>\n );\n}\n\n/**\n * InputHeader component - Internal styled container for search input.\n */\nfunction InputHeader({\n children,\n leading,\n trailing,\n}: {\n children: React.ReactNode;\n leading?: React.ReactNode;\n trailing?: React.ReactNode;\n}) {\n return (\n <div className=\"flex items-center gap-3 bg-sf-elevated px-4 py-3\">\n {leading ?? (\n <MagnifyingGlassIcon className=\"h-4 w-4 text-sf-subtle\" weight=\"bold\" />\n )}\n {children}\n {trailing}\n </div>\n );\n}\n\n/**\n * List component - Scrollable results container\n *\n * Wrapper div with proper styling, contains Autocomplete.List internally.\n * Supports ref forwarding for scroll control.\n */\nconst List = forwardRef<\n HTMLDivElement,\n CommandPaletteListProps & { className?: string }\n>(function List({ children, className }, ref) {\n return (\n <div\n ref={ref}\n className={cn(\n \"z-10 min-h-0 flex-1 overflow-y-auto rounded-b-lg bg-sf-elevated px-2 py-2 ring-1 ring-sf-line\",\n className\n )}\n >\n {children}\n </div>\n );\n});\n\nList.displayName = \"CommandPalette.List\";\n\n/**\n * Group component - Category grouping\n *\n * Re-export of Autocomplete.Group with default styling.\n */\nfunction Group({\n children,\n className,\n ...props\n}: CommandPaletteGroupProps & {\n className?: string;\n items?: unknown[];\n}) {\n return (\n <Autocomplete.Group className={cn(\"space-y-0.5\", className)} {...props}>\n {children}\n </Autocomplete.Group>\n );\n}\n\n/**\n * GroupLabel component - Section header text\n *\n * Re-export of Autocomplete.GroupLabel with styling matching SectionHeader.\n */\nfunction GroupLabel({\n children,\n className,\n}: CommandPaletteGroupLabelProps & { className?: string }) {\n return (\n <Autocomplete.GroupLabel\n className={cn(\n \"mb-2 px-2 pt-1 text-xs font-semibold text-sf-strong\",\n className\n )}\n >\n {children}\n </Autocomplete.GroupLabel>\n );\n}\n\n/**\n * Item component - Individual result item\n *\n * Re-export of Autocomplete.Item with styling matching SearchResultItem.\n * Note: Use onClick for selection handling, matching the existing CommandPalette pattern.\n */\nfunction Item<T>({\n value,\n disabled,\n children,\n className,\n onClick,\n}: CommandPaletteItemProps<T> & {\n className?: string;\n}) {\n return (\n <Autocomplete.Item\n value={value}\n disabled={disabled}\n onClick={onClick}\n className={cn(\n \"group flex w-full items-center gap-3 px-2 py-1.5 text-left transition-colors\",\n \"cursor-pointer data-[highlighted]:bg-sf-overlay\",\n \"rounded-lg\",\n disabled && \"cursor-default opacity-50\",\n className\n )}\n >\n {children}\n </Autocomplete.Item>\n );\n}\n\n/**\n * Empty component - Empty state when no results\n *\n * Re-export of Autocomplete.Empty with default styling.\n */\nfunction Empty({ children }: CommandPaletteEmptyProps) {\n return (\n <Autocomplete.Empty>\n <div className=\"p-8 text-center\">\n <p className=\"text-sf-strong\">{children ?? \"No results found\"}</p>\n </div>\n </Autocomplete.Empty>\n );\n}\n\n/**\n * Loading component - Loading spinner state\n *\n * Centered loading spinner using SF Loader.\n */\nfunction Loading({ children }: CommandPaletteLoadingProps) {\n return (\n <div className=\"flex items-center justify-center p-8\">\n {children ?? <Loader size={24} />}\n </div>\n );\n}\n\n/**\n * Footer component - Styled container for keyboard hints or other footer content.\n *\n * Children are required - this is just a styled container.\n * Consumers should provide their own keyboard hints with proper i18n.\n */\nfunction Footer({ children }: CommandPaletteFooterProps) {\n return (\n <div className=\"flex items-center justify-between rounded-b-lg bg-sf-elevated px-4 py-3 text-xs text-sf-strong\">\n {children}\n </div>\n );\n}\n\n/**\n * HighlightedText - Renders text with highlighted portions based on match indices.\n * Highlighted text is shown with a background color to indicate matches.\n */\nfunction HighlightedText({\n text,\n highlights,\n className,\n}: {\n text: string;\n highlights?: HighlightRange[];\n className?: string;\n}) {\n if (!highlights || highlights.length === 0) {\n return <span className={className}>{text}</span>;\n }\n\n // Sort highlights by start index and merge overlapping ranges\n const sortedHighlights = [...highlights].sort((a, b) => a[0] - b[0]);\n const mergedHighlights: HighlightRange[] = [];\n\n for (const range of sortedHighlights) {\n const last = mergedHighlights[mergedHighlights.length - 1];\n if (last && range[0] <= last[1] + 1) {\n // Merge overlapping or adjacent ranges\n last[1] = Math.max(last[1], range[1]);\n } else {\n mergedHighlights.push([...range]);\n }\n }\n\n const parts: React.ReactNode[] = [];\n let lastIndex = 0;\n\n mergedHighlights.forEach((range, i) => {\n const [start, end] = range;\n\n // Add non-highlighted text before this match\n if (start > lastIndex) {\n parts.push(<span key={`text-${i}`}>{text.slice(lastIndex, start)}</span>);\n }\n\n // Add highlighted text (end index is inclusive)\n parts.push(\n <mark\n key={`highlight-${i}`}\n className=\"rounded-sm bg-sf-warning/50 text-sf-default\"\n >\n {text.slice(start, end + 1)}\n </mark>\n );\n\n lastIndex = end + 1;\n });\n\n // Add remaining non-highlighted text\n if (lastIndex < text.length) {\n parts.push(<span key=\"text-end\">{text.slice(lastIndex)}</span>);\n }\n\n return <span className={className}>{parts}</span>;\n}\n\n/**\n * ResultItem - Rich item component with breadcrumbs, highlights, icons, and external indicators.\n *\n * Use this for search result items that need breadcrumb navigation, text highlighting,\n * or external link indicators. For simple items, use Item instead.\n */\nfunction ResultItem<T>({\n title,\n breadcrumbs,\n titleHighlights,\n breadcrumbHighlights,\n description,\n icon,\n value,\n onClick,\n showArrow = true,\n external = false,\n nonInteractive = false,\n}: CommandPaletteResultItemProps<T>) {\n return (\n <Autocomplete.Item\n value={value}\n onClick={nonInteractive ? undefined : (e: React.MouseEvent) => onClick(e)}\n className={cn(\n \"group flex w-full items-center gap-3 rounded-lg px-2 py-1.5 text-left transition-colors\",\n nonInteractive\n ? \"cursor-default\"\n : \"cursor-pointer data-[highlighted]:bg-sf-overlay\"\n )}\n >\n {icon && (\n <div className=\"flex flex-shrink-0 items-center text-sf-subtle\">\n {icon}\n </div>\n )}\n <div className=\"min-w-0 flex-1\">\n <div className=\"flex items-center gap-2 truncate\">\n {breadcrumbs?.map((crumb, index) => (\n <span key={index} className=\"flex items-center gap-2\">\n <HighlightedText\n text={crumb}\n highlights={breadcrumbHighlights?.[index]}\n className=\"text-base text-sf-default\"\n />\n <CaretRightIcon\n className=\"h-3 w-3 flex-shrink-0 text-sf-subtle\"\n weight=\"bold\"\n />\n </span>\n ))}\n <HighlightedText\n text={title}\n highlights={titleHighlights}\n className=\"text-base text-sf-default\"\n />\n {external && (\n <ArrowSquareOutIcon className=\"h-3.5 w-3.5 flex-shrink-0 text-sf-subtle\" />\n )}\n {description && (\n <>\n <span className=\"text-sf-strong\">—</span>\n <span className=\"truncate text-sm text-sf-strong\">\n {description}\n </span>\n </>\n )}\n </div>\n </div>\n {showArrow && !external && !nonInteractive && (\n <ArrowRightIcon className=\"h-4 w-4 flex-shrink-0 text-sf-subtle opacity-0 transition-opacity group-data-[highlighted]:opacity-100\" />\n )}\n </Autocomplete.Item>\n );\n}\n\n/**\n * Container component - Internal styled wrapper.\n */\nfunction Container({\n children,\n className,\n}: {\n children: React.ReactNode;\n className?: string;\n}) {\n return (\n <div\n className={cn(\n \"flex max-h-[60vh] flex-col overflow-hidden rounded-lg bg-sf-elevated\",\n className\n )}\n >\n {children}\n </div>\n );\n}\n\n/**\n * Panel context for passing handlers from Panel to children\n */\ninterface PanelContextValue {\n onInputKeyDown?: (e: React.KeyboardEvent) => void;\n}\n\nconst PanelContext = createContext<PanelContextValue>({});\n\n/**\n * Props for the Panel component\n */\ninterface PanelProps<TGroup, TItem = TGroup> {\n /** Child components (Input, List, Footer, etc.) */\n children: React.ReactNode;\n /** Items for the autocomplete */\n items: TGroup[];\n /** Controlled input value */\n value?: string;\n /** Callback when input value changes */\n onValueChange?: (value: string) => void;\n /** Callback when an item is highlighted */\n onItemHighlighted?: (\n item: TGroup | undefined,\n details: { reason: string; event: Event; index: number }\n ) => void;\n /** Convert item to string for accessibility */\n itemToStringValue?: (item: TGroup) => string;\n /** Custom filter function */\n filter?: (item: TGroup, query: string) => boolean;\n /** Whether the panel is active/open (for autocomplete state) */\n open?: boolean;\n /** Optional className for the container */\n className?: string;\n /**\n * Callback when an item is selected via Cmd/Ctrl+Enter.\n * Requires getSelectableItems to be provided.\n */\n onSelect?: (item: TItem, options: { newTab: boolean }) => void;\n /**\n * Function to get flat list of selectable items from groups.\n * Required when items are grouped and onSelect is used.\n */\n getSelectableItems?: (items: TGroup[]) => TItem[];\n}\n\n/**\n * Panel component - Command palette without dialog wrapper.\n *\n * Use this when you need to render command palette content inside an existing dialog\n * (e.g., for drill-down navigation where the dialog stays open but content changes).\n *\n * Combines Container + Autocomplete functionality with a clean API.\n *\n * @example\n * ```tsx\n * <DialogRoot open={open} onOpenChange={setOpen}>\n * <Dialog>\n * <CommandPalette.Panel\n * items={results}\n * value={searchTerm}\n * onValueChange={setSearchTerm}\n * itemToStringValue={(group) => group.label}\n * >\n * <CommandPalette.Input placeholder=\"Search...\" />\n * <CommandPalette.List>\n * <CommandPalette.Results>\n * {(group) => (\n * <CommandPalette.Group items={group.items}>\n * <CommandPalette.GroupLabel>{group.label}</CommandPalette.GroupLabel>\n * <CommandPalette.Items>\n * {(item) => <CommandPalette.ResultItem ... />}\n * </CommandPalette.Items>\n * </CommandPalette.Group>\n * )}\n * </CommandPalette.Results>\n * <CommandPalette.Empty>No results</CommandPalette.Empty>\n * </CommandPalette.List>\n * <CommandPalette.Footer>...</CommandPalette.Footer>\n * </CommandPalette.Panel>\n * </Dialog>\n * </DialogRoot>\n * ```\n */\nconst defaultFilter = () => true;\n\nfunction Panel<TGroup, TItem = TGroup>({\n children,\n items,\n value,\n onValueChange,\n onItemHighlighted,\n itemToStringValue,\n filter = defaultFilter,\n open = true,\n className,\n onSelect,\n getSelectableItems,\n}: PanelProps<TGroup, TItem>) {\n const highlightedIndexRef = useRef<number>(-1);\n\n const handleItemHighlighted = useCallback(\n (\n item: TGroup | undefined,\n details: { reason: string; event: Event; index: number }\n ) => {\n highlightedIndexRef.current = details.index;\n onItemHighlighted?.(item, details);\n },\n [onItemHighlighted]\n );\n\n // Handle Cmd/Ctrl+Enter for new tab selection\n const handleInputKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n const isEnter = e.key === \"Enter\";\n const withModifier = e.metaKey || e.ctrlKey;\n\n if (isEnter && withModifier && onSelect && getSelectableItems) {\n const selectableItems = getSelectableItems(items);\n const highlightedItem = selectableItems[highlightedIndexRef.current];\n\n if (highlightedItem !== undefined) {\n e.preventDefault();\n onSelect(highlightedItem, { newTab: true });\n }\n }\n },\n [items, onSelect, getSelectableItems]\n );\n\n return (\n <Container className={className}>\n <Autocomplete.Root\n items={items}\n value={value}\n onValueChange={onValueChange}\n onItemHighlighted={handleItemHighlighted}\n itemToStringValue={itemToStringValue}\n filter={filter}\n autoHighlight=\"always\"\n keepHighlight\n open={open}\n >\n <PanelContext.Provider value={{ onInputKeyDown: handleInputKeyDown }}>\n {children}\n </PanelContext.Provider>\n </Autocomplete.Root>\n </Container>\n );\n}\n\n/**\n * PanelInput component - Input that works inside Panel.\n *\n * Similar to Input but designed for use with Panel instead of Root.\n * Automatically wires up Cmd/Ctrl+Enter handling from Panel.\n */\nfunction PanelInput({\n autoFocus = true,\n placeholder,\n className,\n onKeyDown: onKeyDownProp,\n leading,\n trailing,\n ...props\n}: {\n autoFocus?: boolean;\n placeholder?: string;\n className?: string;\n onKeyDown?: (e: React.KeyboardEvent) => void;\n /** Optional leading content (e.g., back button) */\n leading?: React.ReactNode;\n /** Optional trailing content (e.g., Esc button) */\n trailing?: React.ReactNode;\n}) {\n const { onInputKeyDown } = useContext(PanelContext);\n const { onClose } = useContext(DialogContext);\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n // Let consumer handle first (e.g., for custom Escape/Backspace behavior)\n onKeyDownProp?.(e);\n if (e.defaultPrevented) return;\n\n // Handle Escape to close the dialog\n if (e.key === \"Escape\" && onClose) {\n e.preventDefault();\n onClose();\n return;\n }\n onInputKeyDown?.(e);\n },\n [onInputKeyDown, onKeyDownProp, onClose]\n );\n\n return (\n <InputHeader leading={leading} trailing={trailing}>\n <Autocomplete.Input\n placeholder={placeholder}\n className={cn(\n \"flex-1 border-none bg-transparent text-base placeholder:text-sf-subtle\",\n \"outline-none focus-visible:outline-none\",\n className\n )}\n onKeyDown={handleKeyDown}\n // oxlint-disable-next-line no-autofocus -- Command palette input should autofocus for keyboard-driven UX\n autoFocus={autoFocus}\n {...props}\n />\n </InputHeader>\n );\n}\n\n/**\n * Render prop iterators - wrap base-ui primitives with cleaner names.\n */\n\n/**\n * Results component - Render prop iterator for groups.\n *\n * Wraps Autocomplete.List with default spacing between groups.\n */\nfunction Results({\n children,\n className,\n}: React.ComponentProps<typeof Autocomplete.List> & { className?: string }) {\n return (\n <Autocomplete.List className={cn(\"space-y-3\", className)}>\n {children}\n </Autocomplete.List>\n );\n}\n\nconst Items = Autocomplete.Collection;\n\n/** CommandPalette variant definitions (no user-facing variants; structure reserved for future use). */\nexport const SF_COMMAND_PALETTE_VARIANTS = {} as const;\n\nexport const SF_COMMAND_PALETTE_DEFAULT_VARIANTS = {} as const;\n\n/**\n * CommandPalette — accessible command palette / spotlight search overlay.\n *\n * Compound component: `CommandPalette.Root` (or `.Dialog` + `.Panel`),\n * `.Input`, `.List`, `.Results`, `.Items`, `.Group`, `.GroupLabel`,\n * `.Item`, `.ResultItem`, `.HighlightedText`, `.Empty`, `.Loading`, `.Footer`.\n *\n * Built on `@base-ui/react/autocomplete` + `@base-ui/react/dialog`.\n *\n * @example\n * ```tsx\n * <CommandPalette.Root\n * open={open}\n * onOpenChange={setOpen}\n * items={results}\n * value={query}\n * onValueChange={setQuery}\n * itemToStringValue={(g) => g.label}\n * onSelect={(item, { newTab }) => navigate(item, newTab)}\n * getSelectableItems={(groups) => groups.flatMap((g) => g.items)}\n * >\n * <CommandPalette.Input placeholder=\"Search…\" />\n * <CommandPalette.List>\n * <CommandPalette.Results>\n * {(group) => (\n * <CommandPalette.Group items={group.items}>\n * <CommandPalette.GroupLabel>{group.label}</CommandPalette.GroupLabel>\n * <CommandPalette.Items>\n * {(item) => (\n * <CommandPalette.ResultItem title={item.title} value={item} onClick={…} />\n * )}\n * </CommandPalette.Items>\n * </CommandPalette.Group>\n * )}\n * </CommandPalette.Results>\n * <CommandPalette.Empty>No results found</CommandPalette.Empty>\n * </CommandPalette.List>\n * <CommandPalette.Footer>…keyboard hints…</CommandPalette.Footer>\n * </CommandPalette.Root>\n * ```\n */\nexport const CommandPalette = {\n /** Modal dialog wrapper - use with Panel for content that can swap */\n Dialog,\n /** Dialog + Panel combined - for simple single-view command palettes */\n Root,\n /** Autocomplete panel without dialog - use inside Dialog for swappable content */\n Panel,\n /** Input for use inside Panel */\n Input: PanelInput,\n /** Scrollable results container */\n List,\n /** Category grouping */\n Group,\n /** Section header text */\n GroupLabel,\n /** Basic item */\n Item,\n /** Rich item with breadcrumbs, highlights, icons */\n ResultItem,\n /** Text with highlighted portions */\n HighlightedText,\n /** Empty state */\n Empty,\n /** Loading state */\n Loading,\n /** Footer for keyboard hints */\n Footer,\n /** Render prop iterator for groups */\n Results,\n /** Render prop iterator for items within a group */\n Items,\n};\n"],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { i as SF_AI_ACTIONS_VARIANTS, n as AiActions, r as SF_AI_ACTIONS_DEFAULT_VARIANTS, t as AiAction } from "../ai-actions-DG1dhDMP.js";
3
+ export { AiAction, AiActions, SF_AI_ACTIONS_DEFAULT_VARIANTS, SF_AI_ACTIONS_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { n as SF_AI_AGENT_CARD_DEFAULT_VARIANTS, r as SF_AI_AGENT_CARD_VARIANTS, t as AiAgentCard } from "../ai-agent-card-BbtL4NII.js";
3
+ export { AiAgentCard, SF_AI_AGENT_CARD_DEFAULT_VARIANTS, SF_AI_AGENT_CARD_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { n as SF_AI_APPROVAL_DEFAULT_VARIANTS, r as SF_AI_APPROVAL_VARIANTS, t as AiApproval } from "../ai-approval-Mb7-BY6i.js";
3
+ export { AiApproval, SF_AI_APPROVAL_DEFAULT_VARIANTS, SF_AI_APPROVAL_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { i as SF_AI_CODE_BLOCK_VARIANTS, n as AiCodeBlockCopyButton, r as SF_AI_CODE_BLOCK_DEFAULT_VARIANTS, t as AiCodeBlock } from "../ai-code-block-BI_z0UVR.js";
3
+ export { AiCodeBlock, AiCodeBlockCopyButton, SF_AI_CODE_BLOCK_DEFAULT_VARIANTS, SF_AI_CODE_BLOCK_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { a as SF_AI_CONVERSATION_VARIANTS, i as SF_AI_CONVERSATION_DEFAULT_VARIANTS, n as AiConversationContent, o as useConversationVirtualizer, r as AiConversationScrollButton, t as AiConversation } from "../ai-conversation-DYtExcrw.js";
3
+ export { AiConversation, AiConversationContent, AiConversationScrollButton, SF_AI_CONVERSATION_DEFAULT_VARIANTS, SF_AI_CONVERSATION_VARIANTS, useConversationVirtualizer };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { n as SF_AI_INFO_BANNER_DEFAULT_VARIANTS, r as SF_AI_INFO_BANNER_VARIANTS, t as AiInfoBanner } from "../ai-info-banner-BpzauUAY.js";
3
+ export { AiInfoBanner, SF_AI_INFO_BANNER_DEFAULT_VARIANTS, SF_AI_INFO_BANNER_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { n as SF_AI_LOADER_DEFAULT_VARIANTS, r as SF_AI_LOADER_VARIANTS, t as AiLoader } from "../ai-loader-Cr3eQkNS.js";
3
+ export { AiLoader, SF_AI_LOADER_DEFAULT_VARIANTS, SF_AI_LOADER_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { a as AiMessageAttachments, c as AiMessageBranchSelector, d as SF_AI_MESSAGE_DEFAULT_VARIANTS, f as SF_AI_MESSAGE_VARIANTS, i as AiMessageAttachment, l as AiMessageContent, n as AiMessageAction, o as AiMessageBranch, r as AiMessageActions, s as AiMessageBranchContent, t as AiMessage, u as AiMessageToolbar } from "../ai-message-CV8SBoHM.js";
3
+ export { AiMessage, AiMessageAction, AiMessageActions, AiMessageAttachment, AiMessageAttachments, AiMessageBranch, AiMessageBranchContent, AiMessageBranchSelector, AiMessageContent, AiMessageToolbar, SF_AI_MESSAGE_DEFAULT_VARIANTS, SF_AI_MESSAGE_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { n as SF_AI_MISSION_HEADER_DEFAULT_VARIANTS, r as SF_AI_MISSION_HEADER_VARIANTS, t as AiMissionHeader } from "../ai-mission-header-ByYkJ6YP.js";
3
+ export { AiMissionHeader, SF_AI_MISSION_HEADER_DEFAULT_VARIANTS, SF_AI_MISSION_HEADER_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { C as usePromptInputController, S as usePromptInputAttachments, _ as PromptInputTextarea, a as PromptInputActionMenuItem, b as SF_AI_PROMPT_INPUT_DEFAULT_VARIANTS, c as PromptInputAttachment, d as PromptInputBody, f as PromptInputButton, g as PromptInputSubmit, h as PromptInputSpeechButton, i as PromptInputActionMenuContent, l as PromptInputAttachments, m as PromptInputProvider, n as PromptInputActionAddAttachments, o as PromptInputActionMenuTrigger, p as PromptInputModeSelector, r as PromptInputActionMenu, s as PromptInputAttachButton, t as PromptInput, u as PromptInputBackLayer, v as PromptInputToolbar, w as useProviderAttachments, x as SF_AI_PROMPT_INPUT_VARIANTS, y as PromptInputTools } from "../ai-prompt-input-Bo1YuJly.js";
3
+ export { PromptInput, PromptInputActionAddAttachments, PromptInputActionMenu, PromptInputActionMenuContent, PromptInputActionMenuItem, PromptInputActionMenuTrigger, PromptInputAttachButton, PromptInputAttachment, PromptInputAttachments, PromptInputBackLayer, PromptInputBody, PromptInputButton, PromptInputModeSelector, PromptInputProvider, PromptInputSpeechButton, PromptInputSubmit, PromptInputTextarea, PromptInputToolbar, PromptInputTools, SF_AI_PROMPT_INPUT_DEFAULT_VARIANTS, SF_AI_PROMPT_INPUT_VARIANTS, usePromptInputAttachments, usePromptInputController, useProviderAttachments };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { n as SF_AI_QUESTION_DEFAULT_VARIANTS, r as SF_AI_QUESTION_VARIANTS, t as AiQuestion } from "../ai-question-Dp1g9k2o.js";
3
+ export { AiQuestion, SF_AI_QUESTION_DEFAULT_VARIANTS, SF_AI_QUESTION_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { a as extractFirstBoldText, i as SF_AI_REASONING_VARIANTS, n as AiReasoningGroup, o as formatDuration, r as SF_AI_REASONING_DEFAULT_VARIANTS, s as truncateReasoning, t as AiReasoning } from "../ai-reasoning-UAmNx_LD.js";
3
+ export { AiReasoning, AiReasoningGroup, SF_AI_REASONING_DEFAULT_VARIANTS, SF_AI_REASONING_VARIANTS, extractFirstBoldText, formatDuration, truncateReasoning };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { n as SF_AI_RESPONSE_DEFAULT_VARIANTS, r as SF_AI_RESPONSE_VARIANTS, t as AiResponse } from "../ai-response-BWoVsNQG.js";
3
+ export { AiResponse, SF_AI_RESPONSE_DEFAULT_VARIANTS, SF_AI_RESPONSE_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { n as SF_AI_SHIMMER_DEFAULT_VARIANTS, r as SF_AI_SHIMMER_VARIANTS, t as AiShimmer } from "../ai-shimmer-BpOmfonu.js";
3
+ export { AiShimmer, SF_AI_SHIMMER_DEFAULT_VARIANTS, SF_AI_SHIMMER_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { n as SF_AI_STATUS_BADGE_DEFAULT_VARIANTS, r as SF_AI_STATUS_BADGE_VARIANTS, t as AiStatusBadge } from "../ai-status-badge-WhbKVeqn.js";
3
+ export { AiStatusBadge, SF_AI_STATUS_BADGE_DEFAULT_VARIANTS, SF_AI_STATUS_BADGE_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { n as SF_AI_STREAMING_TEXT_VARIANTS, r as useAiStreamingText, t as SF_AI_STREAMING_TEXT_DEFAULT_VARIANTS } from "../ai-streaming-text-ClL7FwvD.js";
3
+ export { SF_AI_STREAMING_TEXT_DEFAULT_VARIANTS, SF_AI_STREAMING_TEXT_VARIANTS, useAiStreamingText };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { n as SF_AI_SUBAGENT_DEFAULT_VARIANTS, r as SF_AI_SUBAGENT_VARIANTS, t as AiSubagent } from "../ai-subagent-BruGN1UE.js";
3
+ export { AiSubagent, SF_AI_SUBAGENT_DEFAULT_VARIANTS, SF_AI_SUBAGENT_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { i as SF_AI_SUGGESTION_VARIANTS, n as AiSuggestions, r as SF_AI_SUGGESTION_DEFAULT_VARIANTS, t as AiSuggestion } from "../ai-suggestion-CNsCZj5P.js";
3
+ export { AiSuggestion, AiSuggestions, SF_AI_SUGGESTION_DEFAULT_VARIANTS, SF_AI_SUGGESTION_VARIANTS };
@@ -0,0 +1,3 @@
1
+ "use client";
2
+ import { i as SF_AI_TASK_LIST_VARIANTS, n as AiTaskListItem, r as SF_AI_TASK_LIST_DEFAULT_VARIANTS, t as AiTaskList } from "../ai-task-list-B9CpMDYN.js";
3
+ export { AiTaskList, AiTaskListItem, SF_AI_TASK_LIST_DEFAULT_VARIANTS, SF_AI_TASK_LIST_VARIANTS };