@signalflare-ai/ui 1.2.0 → 1.4.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 (318) hide show
  1. package/CHANGELOG.md +154 -1
  2. package/ai/component-registry.json +208 -550
  3. package/ai/component-registry.md +3042 -3115
  4. package/ai/schemas.ts +504 -96
  5. package/dist/.build-complete +1 -1
  6. package/dist/ai/schemas.d.ts.map +1 -1
  7. package/dist/{ai-actions-BdUZI3Gk.js → ai-actions-CBfz5XEf.js} +4 -4
  8. package/dist/{ai-actions-BdUZI3Gk.js.map → ai-actions-CBfz5XEf.js.map} +1 -1
  9. package/dist/{ai-agent-card-BR2NIYhi.js → ai-agent-card-CByAUe0q.js} +3 -3
  10. package/dist/ai-agent-card-CByAUe0q.js.map +1 -0
  11. package/dist/{ai-approval-Ba7mrKba.js → ai-approval-Ci8N70a7.js} +4 -3
  12. package/dist/{ai-approval-Ba7mrKba.js.map → ai-approval-Ci8N70a7.js.map} +1 -1
  13. package/dist/{ai-code-block-CZtoL73R.js → ai-code-block-P9TJHvaC.js} +37 -39
  14. package/dist/ai-code-block-P9TJHvaC.js.map +1 -0
  15. package/dist/{ai-conversation-Cc7WlaBg.js → ai-conversation-Qslfdi1t.js} +28 -42
  16. package/dist/ai-conversation-Qslfdi1t.js.map +1 -0
  17. package/dist/{ai-info-banner-C7EWPBj7.js → ai-info-banner-B_9vtGK3.js} +3 -3
  18. package/dist/{ai-info-banner-C7EWPBj7.js.map → ai-info-banner-B_9vtGK3.js.map} +1 -1
  19. package/dist/{ai-message-Bp7L68U_.js → ai-message-Ci3gwM7G.js} +6 -6
  20. package/dist/{ai-message-Bp7L68U_.js.map → ai-message-Ci3gwM7G.js.map} +1 -1
  21. package/dist/{ai-mission-header-TiCJfTNt.js → ai-mission-header-CaBc19-t.js} +2 -2
  22. package/dist/{ai-mission-header-TiCJfTNt.js.map → ai-mission-header-CaBc19-t.js.map} +1 -1
  23. package/dist/{ai-part-group-DNb9I446.js → ai-part-group-Dx1Mr92B.js} +5 -4
  24. package/dist/ai-part-group-Dx1Mr92B.js.map +1 -0
  25. package/dist/{ai-prompt-input-BVvov_KF.js → ai-prompt-input-Bm4XoSj2.js} +19 -17
  26. package/dist/ai-prompt-input-Bm4XoSj2.js.map +1 -0
  27. package/dist/{ai-question-GPPMk7YM.js → ai-question-OyJovxGe.js} +4 -3
  28. package/dist/{ai-question-GPPMk7YM.js.map → ai-question-OyJovxGe.js.map} +1 -1
  29. package/dist/{ai-reasoning-_feFjk56.js → ai-reasoning-BLfBXx3F.js} +9 -5
  30. package/dist/ai-reasoning-BLfBXx3F.js.map +1 -0
  31. package/dist/{ai-response-CvjV3WhV.js → ai-response-hbVCZJmo.js} +2 -2
  32. package/dist/{ai-response-CvjV3WhV.js.map → ai-response-hbVCZJmo.js.map} +1 -1
  33. package/dist/{ai-shimmer-j6lKIrjj.js → ai-shimmer-BamNMNK3.js} +2 -2
  34. package/dist/{ai-shimmer-j6lKIrjj.js.map → ai-shimmer-BamNMNK3.js.map} +1 -1
  35. package/dist/{ai-status-badge-CSU_QOdz.js → ai-status-badge-BZLczdkI.js} +2 -2
  36. package/dist/{ai-status-badge-CSU_QOdz.js.map → ai-status-badge-BZLczdkI.js.map} +1 -1
  37. package/dist/{ai-streaming-text-IWW1BhvZ.js → ai-streaming-text-DgYu64UH.js} +1 -1
  38. package/dist/{ai-streaming-text-IWW1BhvZ.js.map → ai-streaming-text-DgYu64UH.js.map} +1 -1
  39. package/dist/{ai-subagent-JA4iIMW3.js → ai-subagent-p97AI1h9.js} +3 -3
  40. package/dist/{ai-subagent-JA4iIMW3.js.map → ai-subagent-p97AI1h9.js.map} +1 -1
  41. package/dist/{ai-suggestion-BdO6MBuH.js → ai-suggestion-Bj6vF7CT.js} +3 -3
  42. package/dist/{ai-suggestion-BdO6MBuH.js.map → ai-suggestion-Bj6vF7CT.js.map} +1 -1
  43. package/dist/{ai-task-list-DYw4R1FA.js → ai-task-list-C_UQYpk9.js} +6 -4
  44. package/dist/{ai-task-list-DYw4R1FA.js.map → ai-task-list-C_UQYpk9.js.map} +1 -1
  45. package/dist/{ai-timeline-C42tOUT8.js → ai-timeline-CePL1LOU.js} +3 -3
  46. package/dist/ai-timeline-CePL1LOU.js.map +1 -0
  47. package/dist/{ai-tool-03jOTwUI.js → ai-tool-CfRcwmHT.js} +17 -11
  48. package/dist/ai-tool-CfRcwmHT.js.map +1 -0
  49. package/dist/{ai-usage-bar-BRf5LC_b.js → ai-usage-bar-45pVRCGA.js} +2 -2
  50. package/dist/{ai-usage-bar-BRf5LC_b.js.map → ai-usage-bar-45pVRCGA.js.map} +1 -1
  51. package/dist/{badge-BheXjMc8.js → badge-Beb-6uut.js} +5 -5
  52. package/dist/{badge-BheXjMc8.js.map → badge-Beb-6uut.js.map} +1 -1
  53. package/dist/{banner-CcsjunJg.js → banner-CCEksxPg.js} +3 -3
  54. package/dist/{banner-CcsjunJg.js.map → banner-CCEksxPg.js.map} +1 -1
  55. package/dist/{breadcrumbs-CouSyy3H.js → breadcrumbs-HiTmgaZ4.js} +5 -5
  56. package/dist/{breadcrumbs-CouSyy3H.js.map → breadcrumbs-HiTmgaZ4.js.map} +1 -1
  57. package/dist/{button-CO6-qPax.js → button-BHOgXJRU.js} +4 -4
  58. package/dist/{button-CO6-qPax.js.map → button-BHOgXJRU.js.map} +1 -1
  59. package/dist/catalog.js +1 -1
  60. package/dist/catalog.js.map +1 -1
  61. package/dist/{chart-Dg0qUeSc.js → chart-B9FfZdKs.js} +7 -7
  62. package/dist/chart-B9FfZdKs.js.map +1 -0
  63. package/dist/{checkbox-D7p4QKsC.js → checkbox-Cy_OCyay.js} +3 -3
  64. package/dist/{checkbox-D7p4QKsC.js.map → checkbox-Cy_OCyay.js.map} +1 -1
  65. package/dist/{clipboard-text-kLaMogs3.js → clipboard-text-CKSvNp9L.js} +6 -5
  66. package/dist/clipboard-text-CKSvNp9L.js.map +1 -0
  67. package/dist/{cn-YROP2_ox.js → cn-CmAOpn49.js} +2 -2
  68. package/dist/{cn-YROP2_ox.js.map → cn-CmAOpn49.js.map} +1 -1
  69. package/dist/{code-BN8InC0G.js → code-JsQz-0G_.js} +4 -4
  70. package/dist/{code-BN8InC0G.js.map → code-JsQz-0G_.js.map} +1 -1
  71. package/dist/{collapsible-D_ueZ0jz.js → collapsible-1kOZ-89L.js} +2 -2
  72. package/dist/{collapsible-D_ueZ0jz.js.map → collapsible-1kOZ-89L.js.map} +1 -1
  73. package/dist/{combobox-B7TOK0U2.js → combobox-CQwDmqgA.js} +4 -4
  74. package/dist/{combobox-B7TOK0U2.js.map → combobox-CQwDmqgA.js.map} +1 -1
  75. package/dist/command-line/cli.js +3 -3
  76. package/dist/{command-palette-CuNUyJca.js → command-palette-Bkuv3e6o.js} +20 -5
  77. package/dist/command-palette-Bkuv3e6o.js.map +1 -0
  78. package/dist/components/ai-actions.js +1 -1
  79. package/dist/components/ai-agent-card.js +1 -1
  80. package/dist/components/ai-approval.js +1 -1
  81. package/dist/components/ai-code-block.js +1 -1
  82. package/dist/components/ai-conversation.js +1 -1
  83. package/dist/components/ai-info-banner.js +1 -1
  84. package/dist/components/ai-message.js +1 -1
  85. package/dist/components/ai-mission-header.js +1 -1
  86. package/dist/components/ai-part-group.js +1 -1
  87. package/dist/components/ai-prompt-input.js +1 -1
  88. package/dist/components/ai-question.js +1 -1
  89. package/dist/components/ai-reasoning.js +1 -1
  90. package/dist/components/ai-response.js +1 -1
  91. package/dist/components/ai-shimmer.js +1 -1
  92. package/dist/components/ai-status-badge.js +1 -1
  93. package/dist/components/ai-streaming-text.js +1 -1
  94. package/dist/components/ai-subagent.js +1 -1
  95. package/dist/components/ai-suggestion.js +1 -1
  96. package/dist/components/ai-task-list.js +1 -1
  97. package/dist/components/ai-timeline.js +1 -1
  98. package/dist/components/ai-tool.js +1 -1
  99. package/dist/components/ai-usage-bar.js +1 -1
  100. package/dist/components/badge.js +1 -1
  101. package/dist/components/banner.js +1 -1
  102. package/dist/components/breadcrumbs.js +1 -1
  103. package/dist/components/button.js +1 -1
  104. package/dist/components/chart.js +2 -2
  105. package/dist/components/checkbox.js +1 -1
  106. package/dist/components/clipboard-text.js +1 -1
  107. package/dist/components/code.js +1 -1
  108. package/dist/components/collapsible.js +1 -1
  109. package/dist/components/combobox.js +1 -1
  110. package/dist/components/command-palette.js +1 -1
  111. package/dist/components/data-grid.js +1 -1
  112. package/dist/components/date-picker.js +1 -1
  113. package/dist/components/date-range-picker.js +1 -1
  114. package/dist/components/dialog.js +1 -1
  115. package/dist/components/dropdown.js +1 -1
  116. package/dist/components/empty.js +1 -1
  117. package/dist/components/field.js +1 -1
  118. package/dist/components/filters.js +1 -1
  119. package/dist/components/flow.js +1 -1
  120. package/dist/components/grid.js +1 -1
  121. package/dist/components/input.js +2 -2
  122. package/dist/components/label.js +1 -1
  123. package/dist/components/layer-card.js +1 -1
  124. package/dist/components/link.js +3 -3
  125. package/dist/components/link.js.map +1 -1
  126. package/dist/components/loader.js +2 -2
  127. package/dist/components/menubar.js +1 -1
  128. package/dist/components/meter.js +1 -1
  129. package/dist/components/pagination.js +1 -1
  130. package/dist/components/popover.js +1 -1
  131. package/dist/components/radio.js +1 -1
  132. package/dist/components/select.js +1 -1
  133. package/dist/components/sensitive-input.js +1 -1
  134. package/dist/components/sidebar.js +1 -1
  135. package/dist/components/signalflare-ai-logo.js +1 -1
  136. package/dist/components/sparkline.js +1 -1
  137. package/dist/components/stat-card.js +1 -1
  138. package/dist/components/surface.js +1 -1
  139. package/dist/components/switch.js +1 -1
  140. package/dist/components/table.js +1 -1
  141. package/dist/components/tabs.js +1 -1
  142. package/dist/components/text-roll.js +1 -1
  143. package/dist/components/text.js +1 -1
  144. package/dist/components/theme-toggle.js +1 -1
  145. package/dist/components/toast.js +1 -1
  146. package/dist/components/tooltip.js +1 -1
  147. package/dist/components/use-agent-harness.js +1 -1
  148. package/dist/data-grid-DrguJq_H.js +395 -0
  149. package/dist/data-grid-DrguJq_H.js.map +1 -0
  150. package/dist/{date-picker--ox89RBy.js → date-picker-O34AqG3f.js} +2 -2
  151. package/dist/{date-picker--ox89RBy.js.map → date-picker-O34AqG3f.js.map} +1 -1
  152. package/dist/{date-range-picker-DVa7QBqE.js → date-range-picker-YKYvum_r.js} +29 -39
  153. package/dist/{date-range-picker-DVa7QBqE.js.map → date-range-picker-YKYvum_r.js.map} +1 -1
  154. package/dist/{dialog-Bv1oSFOd.js → dialog-DYqu4aDO.js} +3 -3
  155. package/dist/{dialog-Bv1oSFOd.js.map → dialog-DYqu4aDO.js.map} +1 -1
  156. package/dist/{dist-B6iWiWwp.js → dist-6AtBsaJE.js} +153 -47
  157. package/dist/dist-6AtBsaJE.js.map +1 -0
  158. package/dist/{dropdown-B_nrGXjV.js → dropdown-XzbnRLYR.js} +15 -5
  159. package/dist/dropdown-XzbnRLYR.js.map +1 -0
  160. package/dist/{echart-CdOUaT-r.js → echart-DGBIVAv1.js} +23 -57
  161. package/dist/{echart-CdOUaT-r.js.map → echart-DGBIVAv1.js.map} +1 -1
  162. package/dist/{empty-DZnN0zKX.js → empty-C1tAkawe.js} +6 -6
  163. package/dist/{empty-DZnN0zKX.js.map → empty-C1tAkawe.js.map} +1 -1
  164. package/dist/{field-B_yVof52.js → field-DBpFzzBS.js} +3 -3
  165. package/dist/{field-B_yVof52.js.map → field-DBpFzzBS.js.map} +1 -1
  166. package/dist/{filters-cpJCY21R.js → filters-SmEl93za.js} +10 -10
  167. package/dist/filters-SmEl93za.js.map +1 -0
  168. package/dist/{flow-B4v198ot.js → flow-BLzgbq1T.js} +6 -6
  169. package/dist/flow-BLzgbq1T.js.map +1 -0
  170. package/dist/genui.js +2 -2
  171. package/dist/genui.js.map +1 -1
  172. package/dist/{grid-CEd64Lnh.js → grid-CifjQL-5.js} +2 -2
  173. package/dist/{grid-CEd64Lnh.js.map → grid-CifjQL-5.js.map} +1 -1
  174. package/dist/{highlight-to-react-D0Yav4jk.js → highlight-to-react-DN9dUCS2.js} +9 -15
  175. package/dist/highlight-to-react-DN9dUCS2.js.map +1 -0
  176. package/dist/index.js +71 -71
  177. package/dist/index.js.map +1 -1
  178. package/dist/{input-ClB_E4Lb.js → input-COmx2M_R.js} +5 -5
  179. package/dist/{input-ClB_E4Lb.js.map → input-COmx2M_R.js.map} +1 -1
  180. package/dist/{input-B2bbijRh.js → input-GkfMQZC_.js} +3 -3
  181. package/dist/{input-B2bbijRh.js.map → input-GkfMQZC_.js.map} +1 -1
  182. package/dist/{label-DUv_urO1.js → label-CiGZ464N.js} +3 -3
  183. package/dist/{label-DUv_urO1.js.map → label-CiGZ464N.js.map} +1 -1
  184. package/dist/{layer-card-BK7eYfwn.js → layer-card-8l8GuLQr.js} +2 -2
  185. package/dist/{layer-card-BK7eYfwn.js.map → layer-card-8l8GuLQr.js.map} +1 -1
  186. package/dist/{layout-DJHMMap2.js → layout-CWBE0qwx.js} +258 -154
  187. package/dist/layout-CWBE0qwx.js.map +1 -0
  188. package/dist/{link-provider-BUZKXaNE.js → link-provider-BSn8YJon.js} +2 -2
  189. package/dist/link-provider-BSn8YJon.js.map +1 -0
  190. package/dist/{loader-DAcc-Uag.js → loader-BEMz8pJO.js} +1 -1
  191. package/dist/{loader-DAcc-Uag.js.map → loader-BEMz8pJO.js.map} +1 -1
  192. package/dist/{measured-text-BI3dTJmH.js → measured-text-CXkdw9Yr.js} +45 -30
  193. package/dist/measured-text-CXkdw9Yr.js.map +1 -0
  194. package/dist/{menubar-Cxf3xeAt.js → menubar-CoOr4ocj.js} +3 -3
  195. package/dist/{menubar-Cxf3xeAt.js.map → menubar-CoOr4ocj.js.map} +1 -1
  196. package/dist/{meter-BFFe9l5b.js → meter-Pf_VOl59.js} +2 -2
  197. package/dist/{meter-BFFe9l5b.js.map → meter-Pf_VOl59.js.map} +1 -1
  198. package/dist/{pagination-yS372Tr4.js → pagination-DSY279Ta.js} +2 -2
  199. package/dist/{pagination-yS372Tr4.js.map → pagination-DSY279Ta.js.map} +1 -1
  200. package/dist/{popover-SRoJaCZr.js → popover-BY-e9co1.js} +2 -2
  201. package/dist/{popover-SRoJaCZr.js.map → popover-BY-e9co1.js.map} +1 -1
  202. package/dist/{radio-BcwhwYNB.js → radio-DZwL13j0.js} +2 -2
  203. package/dist/{radio-BcwhwYNB.js.map → radio-DZwL13j0.js.map} +1 -1
  204. package/dist/{select-DMhdoHMa.js → select-BFifYqHA.js} +6 -6
  205. package/dist/{select-DMhdoHMa.js.map → select-BFifYqHA.js.map} +1 -1
  206. package/dist/{sensitive-input-CJUpIRal.js → sensitive-input-DHLZcM73.js} +4 -4
  207. package/dist/{sensitive-input-CJUpIRal.js.map → sensitive-input-DHLZcM73.js.map} +1 -1
  208. package/dist/{sidebar-D4zrlYpn.js → sidebar-odGsdvG4.js} +6 -7
  209. package/dist/sidebar-odGsdvG4.js.map +1 -0
  210. package/dist/{signalflare-ai-logo-Bipogceq.js → signalflare-ai-logo-CNaDT_w8.js} +2 -2
  211. package/dist/{signalflare-ai-logo-Bipogceq.js.map → signalflare-ai-logo-CNaDT_w8.js.map} +1 -1
  212. package/dist/{skeleton-line-CH1-h6e2.js → skeleton-line-CxxYVTO2.js} +2 -2
  213. package/dist/{skeleton-line-CH1-h6e2.js.map → skeleton-line-CxxYVTO2.js.map} +1 -1
  214. package/dist/{sparkline-DHmgj1d0.js → sparkline-BQ-4j2W2.js} +2 -2
  215. package/dist/{sparkline-DHmgj1d0.js.map → sparkline-BQ-4j2W2.js.map} +1 -1
  216. package/dist/src/blocks/agent-harness/agent-harness.tsx +11 -11
  217. package/dist/src/blocks/commander/commander.tsx +15 -15
  218. package/dist/src/blocks/map-block/map-block.d.ts.map +1 -1
  219. package/dist/src/blocks/map-block/map-block.tsx +11 -7
  220. package/dist/src/components/ai-approval/ai-approval.d.ts.map +1 -1
  221. package/dist/src/components/ai-code-block/ai-code-block.d.ts +14 -13
  222. package/dist/src/components/ai-code-block/ai-code-block.d.ts.map +1 -1
  223. package/dist/src/components/ai-conversation/ai-conversation.d.ts.map +1 -1
  224. package/dist/src/components/ai-part-group/ai-part-group.d.ts.map +1 -1
  225. package/dist/src/components/ai-prompt-input/ai-prompt-input.d.ts.map +1 -1
  226. package/dist/src/components/ai-prompt-input/controller.d.ts.map +1 -1
  227. package/dist/src/components/ai-prompt-input/types.d.ts.map +1 -1
  228. package/dist/src/components/ai-question/ai-question.d.ts.map +1 -1
  229. package/dist/src/components/ai-reasoning/ai-reasoning.d.ts.map +1 -1
  230. package/dist/src/components/ai-response/ai-response.d.ts.map +1 -1
  231. package/dist/src/components/ai-subagent/ai-subagent.d.ts.map +1 -1
  232. package/dist/src/components/ai-tool/ai-tool.d.ts.map +1 -1
  233. package/dist/src/components/chart/echart.d.ts.map +1 -1
  234. package/dist/src/components/clipboard-text/clipboard-text.d.ts.map +1 -1
  235. package/dist/src/components/data-grid/data-grid.d.ts +2 -1
  236. package/dist/src/components/data-grid/data-grid.d.ts.map +1 -1
  237. package/dist/src/components/data-grid/features.d.ts +20 -0
  238. package/dist/src/components/data-grid/features.d.ts.map +1 -0
  239. package/dist/src/components/data-grid/types.d.ts +38 -7
  240. package/dist/src/components/data-grid/types.d.ts.map +1 -1
  241. package/dist/src/components/filters/filters.d.ts.map +1 -1
  242. package/dist/src/components/flow/use-children.d.ts +1 -1
  243. package/dist/src/components/link/link.d.ts.map +1 -1
  244. package/dist/src/components/sidebar/sidebar.d.ts +1 -1
  245. package/dist/src/components/signalflare-ai-logo/signalflare-ai-logo.d.ts.map +1 -1
  246. package/dist/src/components/text/text.d.ts +2 -1
  247. package/dist/src/components/text/text.d.ts.map +1 -1
  248. package/dist/src/components/text-roll/text-roll.d.ts.map +1 -1
  249. package/dist/src/components/theme-toggle/theme-toggle.d.ts.map +1 -1
  250. package/dist/src/components/toast/toast.d.ts.map +1 -1
  251. package/dist/src/utils/highlight-to-react.d.ts.map +1 -1
  252. package/dist/src/utils/measured-text.d.ts.map +1 -1
  253. package/dist/src/utils/use-measured-text.d.ts.map +1 -1
  254. package/dist/{stat-card-Ew-ofzEm.js → stat-card-Bspk4XFr.js} +4 -4
  255. package/dist/stat-card-Bspk4XFr.js.map +1 -0
  256. package/dist/styles/sf-standalone.css +1 -1
  257. package/dist/styles/theme-fedramp.css +3 -12
  258. package/dist/styles/theme-minimal.css +26 -104
  259. package/dist/styles/theme-sf.css +37 -142
  260. package/dist/{surface-DGwRlC0o.js → surface-CWdSFVUx.js} +3 -3
  261. package/dist/{surface-DGwRlC0o.js.map → surface-CWdSFVUx.js.map} +1 -1
  262. package/dist/{switch-BxAMfHdt.js → switch-TA4cByCJ.js} +5 -5
  263. package/dist/switch-TA4cByCJ.js.map +1 -0
  264. package/dist/{table-BBeAtYVZ.js → table-BM8JBGBs.js} +3 -3
  265. package/dist/{table-BBeAtYVZ.js.map → table-BM8JBGBs.js.map} +1 -1
  266. package/dist/{tabs-CeHu7Scn.js → tabs-bnH2vGLv.js} +2 -2
  267. package/dist/{tabs-CeHu7Scn.js.map → tabs-bnH2vGLv.js.map} +1 -1
  268. package/dist/{text-Cqryz7rk.js → text-iQ0YUFNg.js} +4 -5
  269. package/dist/{text-Cqryz7rk.js.map → text-iQ0YUFNg.js.map} +1 -1
  270. package/dist/{text-roll-Ch52hcQj.js → text-roll-C3U2jd2u.js} +5 -2
  271. package/dist/text-roll-C3U2jd2u.js.map +1 -0
  272. package/dist/{theme-toggle-LDfIKEqx.js → theme-toggle-BTVxD-fD.js} +10 -9
  273. package/dist/theme-toggle-BTVxD-fD.js.map +1 -0
  274. package/dist/{toast-CaFQNYng.js → toast-CgZVaAkw.js} +3 -3
  275. package/dist/{toast-CaFQNYng.js.map → toast-CgZVaAkw.js.map} +1 -1
  276. package/dist/{tooltip-g9lFsvcT.js → tooltip-uobk6Oh-.js} +3 -3
  277. package/dist/{tooltip-g9lFsvcT.js.map → tooltip-uobk6Oh-.js.map} +1 -1
  278. package/dist/{use-agent-harness-BTcNJdw4.js → use-agent-harness-Dl8w6X5O.js} +3 -3
  279. package/dist/{use-agent-harness-BTcNJdw4.js.map → use-agent-harness-Dl8w6X5O.js.map} +1 -1
  280. package/dist/utils.js +3 -3
  281. package/package.json +27 -25
  282. package/scripts/component-registry/discovery.ts +11 -10
  283. package/scripts/component-registry/example-cleanup.ts +8 -8
  284. package/scripts/component-registry/index.ts +6 -6
  285. package/scripts/component-registry/schema-generator.ts +1 -1
  286. package/scripts/component-registry/sub-components.ts +35 -23
  287. package/scripts/component-registry/utils.ts +11 -11
  288. package/scripts/component-registry/variant-parser.ts +17 -15
  289. package/scripts/convert-demos-to-stories.ts +5 -5
  290. package/scripts/theme-generator/config.ts +1 -5
  291. package/scripts/theme-generator/generate-css.ts +1 -1
  292. package/scripts/theme-generator/migrate.ts +3 -3
  293. package/dist/ai-agent-card-BR2NIYhi.js.map +0 -1
  294. package/dist/ai-code-block-CZtoL73R.js.map +0 -1
  295. package/dist/ai-conversation-Cc7WlaBg.js.map +0 -1
  296. package/dist/ai-part-group-DNb9I446.js.map +0 -1
  297. package/dist/ai-prompt-input-BVvov_KF.js.map +0 -1
  298. package/dist/ai-reasoning-_feFjk56.js.map +0 -1
  299. package/dist/ai-timeline-C42tOUT8.js.map +0 -1
  300. package/dist/ai-tool-03jOTwUI.js.map +0 -1
  301. package/dist/chart-Dg0qUeSc.js.map +0 -1
  302. package/dist/clipboard-text-kLaMogs3.js.map +0 -1
  303. package/dist/command-palette-CuNUyJca.js.map +0 -1
  304. package/dist/data-grid-DGHmU0w3.js +0 -305
  305. package/dist/data-grid-DGHmU0w3.js.map +0 -1
  306. package/dist/dist-B6iWiWwp.js.map +0 -1
  307. package/dist/dropdown-B_nrGXjV.js.map +0 -1
  308. package/dist/filters-cpJCY21R.js.map +0 -1
  309. package/dist/flow-B4v198ot.js.map +0 -1
  310. package/dist/highlight-to-react-D0Yav4jk.js.map +0 -1
  311. package/dist/layout-DJHMMap2.js.map +0 -1
  312. package/dist/link-provider-BUZKXaNE.js.map +0 -1
  313. package/dist/measured-text-BI3dTJmH.js.map +0 -1
  314. package/dist/sidebar-D4zrlYpn.js.map +0 -1
  315. package/dist/stat-card-Ew-ofzEm.js.map +0 -1
  316. package/dist/switch-BxAMfHdt.js.map +0 -1
  317. package/dist/text-roll-Ch52hcQj.js.map +0 -1
  318. package/dist/theme-toggle-LDfIKEqx.js.map +0 -1
@@ -1,305 +0,0 @@
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 Button } from "./button-CO6-qPax.js";
5
- import { t as Checkbox } from "./checkbox-D7p4QKsC.js";
6
- import { t as DropdownMenu } from "./dropdown-B_nrGXjV.js";
7
- import { t as Pagination } from "./pagination-yS372Tr4.js";
8
- import { r as Table } from "./table-BBeAtYVZ.js";
9
- import { t as Filters } from "./filters-cpJCY21R.js";
10
- import { t as Empty } from "./empty-DZnN0zKX.js";
11
- import { createContext, useContext, useMemo, useState } from "react";
12
- import { Fragment as Fragment$1, jsx, jsxs } from "react/jsx-runtime";
13
- import { CaretDownIcon, CaretUpDownIcon, CaretUpIcon, ColumnsIcon, FadersHorizontalIcon } from "@phosphor-icons/react";
14
- import { flexRender, getCoreRowModel, getFilteredRowModel, getPaginationRowModel, getSortedRowModel, useReactTable } from "@tanstack/react-table";
15
- //#region src/components/data-grid/data-grid.tsx
16
- /** DataGrid layout variant definitions */
17
- var SF_DATA_GRID_VARIANTS = { layout: {
18
- auto: {
19
- classes: "",
20
- description: "Auto column sizing - columns resize based on content"
21
- },
22
- fixed: {
23
- classes: "table-fixed",
24
- description: "Fixed column sizing - columns have equal width"
25
- }
26
- } };
27
- /** Default variants for DataGrid */
28
- var SF_DATA_GRID_DEFAULT_VARIANTS = { layout: "auto" };
29
- var DataGridContext = createContext(null);
30
- function useDataGridContext() {
31
- const context = useContext(DataGridContext);
32
- if (!context) throw new Error("DataGrid compound components must be used within a DataGrid");
33
- return context;
34
- }
35
- function SortIcon({ sorted }) {
36
- if (sorted === "asc") return /* @__PURE__ */ jsx(CaretUpIcon, { className: "size-3.5 text-sf-brand" });
37
- if (sorted === "desc") return /* @__PURE__ */ jsx(CaretDownIcon, { className: "size-3.5 text-sf-brand" });
38
- return /* @__PURE__ */ jsx(CaretUpDownIcon, { className: "size-3.5 text-sf-subtle" });
39
- }
40
- /**
41
- * Toolbar component for DataGrid.
42
- * Shows filters, column visibility toggle, and custom actions.
43
- */
44
- function DataGridToolbar({ className, children }) {
45
- return /* @__PURE__ */ jsx("div", {
46
- className: cn("flex items-center gap-2 border-b border-sf-line p-3", className),
47
- children
48
- });
49
- }
50
- DataGridToolbar.displayName = "DataGrid.Toolbar";
51
- /**
52
- * Column visibility toggle dropdown.
53
- * Shows checkboxes for each hideable column.
54
- */
55
- function DataGridColumnToggle({ className, trigger, label = "Columns" }) {
56
- const { table } = useDataGridContext();
57
- const hideableColumns = useMemo(() => {
58
- return table.getAllColumns().filter((col) => col.getCanHide() && (col.columnDef.enableHiding !== false || col.getCanHide()));
59
- }, [table]);
60
- if (hideableColumns.length === 0) return null;
61
- return /* @__PURE__ */ jsxs(DropdownMenu, { children: [/* @__PURE__ */ jsx(DropdownMenu.Trigger, { children: trigger ?? /* @__PURE__ */ jsxs(Button, {
62
- variant: "secondary",
63
- size: "sm",
64
- className,
65
- children: [/* @__PURE__ */ jsx(ColumnsIcon, { className: "mr-1.5 size-4" }), label]
66
- }) }), /* @__PURE__ */ jsx(DropdownMenu.Content, {
67
- className: "w-48",
68
- children: /* @__PURE__ */ jsxs("div", {
69
- className: "flex flex-col gap-1 p-1",
70
- children: [hideableColumns.map((column) => /* @__PURE__ */ jsxs("label", {
71
- className: "flex cursor-pointer items-center gap-2 rounded-md px-2 py-1.5 text-sm hover:bg-sf-tint",
72
- children: [/* @__PURE__ */ jsx(Checkbox, {
73
- checked: column.getIsVisible(),
74
- onCheckedChange: (checked) => column.toggleVisibility(!!checked)
75
- }), /* @__PURE__ */ jsx("span", {
76
- className: "flex-1",
77
- children: typeof column.columnDef.header === "string" ? column.columnDef.header : column.id
78
- })]
79
- }, column.id)), hideableColumns.length > 0 && /* @__PURE__ */ jsxs(Fragment$1, { children: [
80
- /* @__PURE__ */ jsx("div", { className: "my-1 h-px bg-sf-line" }),
81
- /* @__PURE__ */ jsx(DropdownMenu.Item, {
82
- onClick: () => hideableColumns.forEach((col) => col.toggleVisibility(true)),
83
- children: "Show all"
84
- }),
85
- /* @__PURE__ */ jsx(DropdownMenu.Item, {
86
- onClick: () => hideableColumns.forEach((col) => col.toggleVisibility(false)),
87
- children: "Hide all"
88
- })
89
- ] })]
90
- })
91
- })] });
92
- }
93
- DataGridColumnToggle.displayName = "DataGrid.ColumnToggle";
94
- /**
95
- * Main table content component.
96
- * Renders the table with headers, rows, and cells.
97
- */
98
- function DataGridContent({ className }) {
99
- const { table, loading, loadingRows, enableColumnResizing } = useDataGridContext();
100
- if (loading) return /* @__PURE__ */ jsx("div", {
101
- className: "p-4",
102
- children: /* @__PURE__ */ jsx("div", {
103
- className: "space-y-2",
104
- children: Array.from({ length: loadingRows ?? 5 }).map((_, i) => /* @__PURE__ */ jsx(Loader, { className: "h-10 w-full" }, i))
105
- })
106
- });
107
- return /* @__PURE__ */ jsxs(Table, {
108
- className,
109
- children: [/* @__PURE__ */ jsx(Table.Header, { children: table.getHeaderGroups().map((headerGroup) => /* @__PURE__ */ jsx(Table.Row, { children: headerGroup.headers.map((header) => {
110
- const canSort = header.column.getCanSort();
111
- const sorted = header.column.getIsSorted();
112
- const canResize = enableColumnResizing && header.column.getCanResize();
113
- const isResizing = header.column.getIsResizing();
114
- return /* @__PURE__ */ jsxs(Table.Head, {
115
- className: cn("bg-sf-base relative group", canSort && "cursor-pointer select-none hover:bg-sf-overlay", header.column.columnDef.headerClassName),
116
- style: canResize ? { width: header.getSize() } : void 0,
117
- onClick: canSort ? () => header.column.toggleSorting() : void 0,
118
- children: [/* @__PURE__ */ jsxs("div", {
119
- className: "flex items-center gap-1.5",
120
- children: [header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext()), canSort && /* @__PURE__ */ jsx(SortIcon, { sorted })]
121
- }), canResize && /* @__PURE__ */ jsx(Table.ResizeHandle, {
122
- onMouseDown: header.getResizeHandler(),
123
- onTouchStart: header.getResizeHandler(),
124
- onDoubleClick: () => header.column.resetSize(),
125
- className: cn(isResizing && "visible bg-sf-brand/20")
126
- })]
127
- }, header.id);
128
- }) }, headerGroup.id)) }), /* @__PURE__ */ jsx(Table.Body, { children: table.getRowModel().rows.map((row) => /* @__PURE__ */ jsx(Table.Row, {
129
- variant: row.getIsSelected() ? "selected" : "default",
130
- className: cn(row.getIsSelected() && "bg-sf-tint", "hover:bg-sf-overlay"),
131
- children: row.getVisibleCells().map((cell) => /* @__PURE__ */ jsx(Table.Cell, {
132
- className: cell.column.columnDef.cellClassName,
133
- style: enableColumnResizing ? { width: cell.column.getSize() } : void 0,
134
- children: flexRender(cell.column.columnDef.cell, cell.getContext())
135
- }, cell.id))
136
- }, row.id)) })]
137
- });
138
- }
139
- DataGridContent.displayName = "DataGrid.Content";
140
- /**
141
- * Pagination controls for DataGrid.
142
- * Wraps the Pagination component with table state.
143
- */
144
- function DataGridPagination({ className }) {
145
- const { table, pageSize: _pageSize, pageIndex: _pageIndex, totalCount, manualPagination } = useDataGridContext();
146
- const paginationState = table.getState().pagination;
147
- const currentPageIndex = paginationState.pageIndex;
148
- const currentPageSize = paginationState.pageSize;
149
- const startRow = currentPageIndex * currentPageSize + 1;
150
- const endRow = Math.min((currentPageIndex + 1) * currentPageSize, manualPagination ? totalCount : table.getCoreRowModel().rows.length);
151
- if (table.getPageCount() <= 1 && !manualPagination) return null;
152
- return /* @__PURE__ */ jsxs("div", {
153
- className: cn("flex items-center justify-between border-t border-sf-line p-3", className),
154
- children: [/* @__PURE__ */ jsxs("div", {
155
- className: "text-sm text-sf-subtle",
156
- children: [
157
- "Showing ",
158
- startRow,
159
- "–",
160
- endRow,
161
- " of",
162
- " ",
163
- manualPagination ? totalCount : table.getCoreRowModel().rows.length
164
- ]
165
- }), /* @__PURE__ */ jsx(Pagination, {
166
- page: currentPageIndex + 1,
167
- setPage: (page) => table.setPageIndex(page - 1),
168
- perPage: currentPageSize,
169
- totalCount: manualPagination ? totalCount : table.getCoreRowModel().rows.length,
170
- text: ({ pageShowingRange, totalCount: total }) => `Showing ${pageShowingRange} of ${total}`
171
- })]
172
- });
173
- }
174
- DataGridPagination.displayName = "DataGrid.Pagination";
175
- /**
176
- * Empty state component for DataGrid.
177
- * Shown when there are no rows to display.
178
- */
179
- function DataGridEmpty({ className, children, title = "No results", description = "No data to display." }) {
180
- const { table } = useDataGridContext();
181
- if (table.getCoreRowModel().rows.length > 0) return null;
182
- return /* @__PURE__ */ jsx("div", {
183
- className: cn("p-8", className),
184
- children: children ?? /* @__PURE__ */ jsx(Empty, {
185
- icon: /* @__PURE__ */ jsx(FadersHorizontalIcon, { className: "size-10 text-sf-subtle" }),
186
- title,
187
- description
188
- })
189
- });
190
- }
191
- DataGridEmpty.displayName = "DataGrid.Empty";
192
- /**
193
- * DataGrid root component.
194
- * Sets up the react-table instance and provides context to child components.
195
- */
196
- function DataGridRoot({ data, columns, sorting: controlledSorting, onSortingChange, enableSorting = true, columnVisibility: controlledColumnVisibility, onColumnVisibilityChange, enableColumnVisibility = true, rowSelection: controlledRowSelection, onRowSelectionChange, enableRowSelection, pageSize = 10, pageIndex = 0, onPaginationChange, totalCount, manualPagination = false, pageSizeOptions: _pageSizeOptions = [
197
- 10,
198
- 25,
199
- 50,
200
- 100
201
- ], filters, onFiltersChange, filterFields, enableFiltering, layout: _layout = SF_DATA_GRID_DEFAULT_VARIANTS.layout, className, tableClassName, emptyState, loading, loadingRows, toolbar, showToolbar = true, showPagination = true, pagination: customPagination, enableColumnResizing, columnResizeMode = "onEnd", children }) {
202
- const [internalSorting, setInternalSorting] = useState([]);
203
- const [internalColumnVisibility, setInternalColumnVisibility] = useState({});
204
- const [internalRowSelection, setInternalRowSelection] = useState({});
205
- const [internalPagination, setInternalPagination] = useState({
206
- pageIndex,
207
- pageSize
208
- });
209
- const sorting = controlledSorting ?? internalSorting;
210
- const columnVisibility = controlledColumnVisibility ?? internalColumnVisibility;
211
- const rowSelection = controlledRowSelection ?? internalRowSelection;
212
- const pagination = internalPagination;
213
- const handleSortingChange = (updater) => {
214
- const newSorting = typeof updater === "function" ? updater(sorting) : updater;
215
- if (onSortingChange) onSortingChange(newSorting);
216
- else setInternalSorting(newSorting);
217
- };
218
- const handleColumnVisibilityChange = (updater) => {
219
- const newVisibility = typeof updater === "function" ? updater(columnVisibility) : updater;
220
- if (onColumnVisibilityChange) onColumnVisibilityChange(newVisibility);
221
- else setInternalColumnVisibility(newVisibility);
222
- };
223
- const handleRowSelectionChange = (updater) => {
224
- const newSelection = typeof updater === "function" ? updater(rowSelection) : updater;
225
- if (onRowSelectionChange) onRowSelectionChange(newSelection);
226
- else setInternalRowSelection(newSelection);
227
- };
228
- const handlePaginationChange = (updater) => {
229
- const newPagination = typeof updater === "function" ? updater(pagination) : updater;
230
- setInternalPagination(newPagination);
231
- if (onPaginationChange) onPaginationChange({
232
- pageIndex: newPagination.pageIndex,
233
- pageSize: newPagination.pageSize
234
- });
235
- };
236
- const contextValue = {
237
- table: useReactTable({
238
- data,
239
- columns,
240
- state: {
241
- sorting,
242
- columnVisibility,
243
- rowSelection,
244
- pagination
245
- },
246
- onSortingChange: handleSortingChange,
247
- onColumnVisibilityChange: handleColumnVisibilityChange,
248
- onRowSelectionChange: handleRowSelectionChange,
249
- onPaginationChange: handlePaginationChange,
250
- getCoreRowModel: getCoreRowModel(),
251
- getSortedRowModel: enableSorting ? getSortedRowModel() : void 0,
252
- getPaginationRowModel: getPaginationRowModel(),
253
- getFilteredRowModel: getFilteredRowModel(),
254
- enableSorting,
255
- enableRowSelection: enableRowSelection !== false,
256
- enableColumnResizing,
257
- columnResizeMode,
258
- manualPagination,
259
- pageCount: manualPagination ? Math.ceil((totalCount ?? data.length) / pageSize) : void 0,
260
- enableMultiRowSelection: true
261
- }),
262
- pageSize,
263
- pageIndex,
264
- totalCount: totalCount ?? data.length,
265
- manualPagination,
266
- loading,
267
- loadingRows,
268
- enableColumnResizing,
269
- columnResizeMode
270
- };
271
- return /* @__PURE__ */ jsx(DataGridContext.Provider, {
272
- value: contextValue,
273
- children: /* @__PURE__ */ jsx("div", {
274
- className: cn("flex flex-col overflow-hidden rounded-lg border border-sf-line bg-sf-base", className),
275
- children: children || /* @__PURE__ */ jsxs(Fragment$1, { children: [
276
- showToolbar && /* @__PURE__ */ jsx(DataGridToolbar, { children: toolbar ?? /* @__PURE__ */ jsxs(Fragment$1, { children: [enableFiltering && filterFields && /* @__PURE__ */ jsx(Filters, {
277
- filters: filters ?? [],
278
- fields: filterFields,
279
- onChange: onFiltersChange ?? (() => {}),
280
- size: "sm"
281
- }), /* @__PURE__ */ jsx("div", {
282
- className: "ml-auto flex items-center gap-2",
283
- children: enableColumnVisibility && /* @__PURE__ */ jsx(DataGridColumnToggle, {})
284
- })] }) }),
285
- /* @__PURE__ */ jsxs("div", {
286
- className: "flex-1 overflow-auto",
287
- children: [/* @__PURE__ */ jsx(DataGridContent, { className: tableClassName }), /* @__PURE__ */ jsx(DataGridEmpty, { children: emptyState })]
288
- }),
289
- showPagination && (customPagination ?? /* @__PURE__ */ jsx(DataGridPagination, {}))
290
- ] })
291
- })
292
- });
293
- }
294
- DataGridRoot.displayName = "DataGrid";
295
- var DataGrid = Object.assign(DataGridRoot, {
296
- Toolbar: DataGridToolbar,
297
- Content: DataGridContent,
298
- Pagination: DataGridPagination,
299
- ColumnToggle: DataGridColumnToggle,
300
- Empty: DataGridEmpty
301
- });
302
- //#endregion
303
- export { SF_DATA_GRID_DEFAULT_VARIANTS as n, SF_DATA_GRID_VARIANTS as r, DataGrid as t };
304
-
305
- //# sourceMappingURL=data-grid-DGHmU0w3.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"data-grid-DGHmU0w3.js","names":[],"sources":["../src/components/data-grid/data-grid.tsx"],"sourcesContent":["\"use client\";\n\nimport {\n CaretDownIcon,\n CaretUpIcon,\n CaretUpDownIcon,\n ColumnsIcon,\n FadersHorizontalIcon,\n} from \"@phosphor-icons/react\";\nimport {\n useReactTable,\n getCoreRowModel,\n getSortedRowModel,\n getPaginationRowModel,\n getFilteredRowModel,\n flexRender,\n type SortingState,\n type VisibilityState,\n type RowSelectionState,\n type PaginationState,\n} from \"@tanstack/react-table\";\nimport {\n createContext,\n useContext,\n useMemo,\n useState,\n type ReactNode,\n} from \"react\";\n\nimport { cn } from \"../../utils/cn\";\nimport { Button } from \"../button\";\nimport { Checkbox } from \"../checkbox\";\nimport { DropdownMenu } from \"../dropdown\";\nimport { Empty } from \"../empty\";\nimport { Filters } from \"../filters\";\nimport { Loader } from \"../loader\";\nimport { Pagination } from \"../pagination\";\nimport { Table } from \"../table\";\nimport type {\n DataGridProps,\n DataGridColumn,\n DataGridContextValue,\n DataGridToolbarProps,\n DataGridContentProps,\n DataGridPaginationProps,\n DataGridColumnToggleProps,\n DataGridEmptyProps,\n} from \"./types\";\n\n// ============================================================================\n// Variants\n// ============================================================================\n\n/** DataGrid layout variant definitions */\nexport const SF_DATA_GRID_VARIANTS = {\n layout: {\n auto: {\n classes: \"\",\n description: \"Auto column sizing - columns resize based on content\",\n },\n fixed: {\n classes: \"table-fixed\",\n description: \"Fixed column sizing - columns have equal width\",\n },\n },\n} as const;\n\n/** Default variants for DataGrid */\nexport const SF_DATA_GRID_DEFAULT_VARIANTS = {\n layout: \"auto\",\n} as const;\n\n// ============================================================================\n// Context\n// ============================================================================\n\nconst DataGridContext = createContext<DataGridContextValue | null>(null);\n\nfunction useDataGridContext<TData>() {\n const context = useContext(DataGridContext);\n if (!context) {\n throw new Error(\n \"DataGrid compound components must be used within a DataGrid\"\n );\n }\n return context as DataGridContextValue<TData>;\n}\n\n// ============================================================================\n// Sort Icon Component\n// ============================================================================\n\nfunction SortIcon({ sorted }: { sorted: false | \"asc\" | \"desc\" }) {\n if (sorted === \"asc\") {\n return <CaretUpIcon className=\"size-3.5 text-sf-brand\" />;\n }\n if (sorted === \"desc\") {\n return <CaretDownIcon className=\"size-3.5 text-sf-brand\" />;\n }\n return <CaretUpDownIcon className=\"size-3.5 text-sf-subtle\" />;\n}\n\n// ============================================================================\n// DataGrid Toolbar\n// ============================================================================\n\n/**\n * Toolbar component for DataGrid.\n * Shows filters, column visibility toggle, and custom actions.\n */\nfunction DataGridToolbar({ className, children }: DataGridToolbarProps) {\n return (\n <div\n className={cn(\n \"flex items-center gap-2 border-b border-sf-line p-3\",\n className\n )}\n >\n {children}\n </div>\n );\n}\n\nDataGridToolbar.displayName = \"DataGrid.Toolbar\";\n\n// ============================================================================\n// DataGrid Column Toggle\n// ============================================================================\n\n/**\n * Column visibility toggle dropdown.\n * Shows checkboxes for each hideable column.\n */\nfunction DataGridColumnToggle({\n className,\n trigger,\n label = \"Columns\",\n}: DataGridColumnToggleProps) {\n const { table } = useDataGridContext();\n\n const hideableColumns = useMemo(() => {\n return table\n .getAllColumns()\n .filter(\n (col) =>\n col.getCanHide() &&\n (col.columnDef.enableHiding !== false || col.getCanHide())\n );\n }, [table]);\n\n if (hideableColumns.length === 0) return null;\n\n return (\n <DropdownMenu>\n <DropdownMenu.Trigger>\n {trigger ?? (\n <Button variant=\"secondary\" size=\"sm\" className={className}>\n <ColumnsIcon className=\"mr-1.5 size-4\" />\n {label}\n </Button>\n )}\n </DropdownMenu.Trigger>\n <DropdownMenu.Content className=\"w-48\">\n <div className=\"flex flex-col gap-1 p-1\">\n {hideableColumns.map((column) => (\n <label\n key={column.id}\n className=\"flex cursor-pointer items-center gap-2 rounded-md px-2 py-1.5 text-sm hover:bg-sf-tint\"\n >\n <Checkbox\n checked={column.getIsVisible()}\n onCheckedChange={(checked) =>\n column.toggleVisibility(!!checked)\n }\n />\n <span className=\"flex-1\">\n {typeof column.columnDef.header === \"string\"\n ? column.columnDef.header\n : column.id}\n </span>\n </label>\n ))}\n {hideableColumns.length > 0 && (\n <>\n <div className=\"my-1 h-px bg-sf-line\" />\n <DropdownMenu.Item\n onClick={() =>\n hideableColumns.forEach((col) => col.toggleVisibility(true))\n }\n >\n Show all\n </DropdownMenu.Item>\n <DropdownMenu.Item\n onClick={() =>\n hideableColumns.forEach((col) => col.toggleVisibility(false))\n }\n >\n Hide all\n </DropdownMenu.Item>\n </>\n )}\n </div>\n </DropdownMenu.Content>\n </DropdownMenu>\n );\n}\n\nDataGridColumnToggle.displayName = \"DataGrid.ColumnToggle\";\n\n// ============================================================================\n// DataGrid Content\n// ============================================================================\n\n/**\n * Main table content component.\n * Renders the table with headers, rows, and cells.\n */\nfunction DataGridContent({ className }: DataGridContentProps) {\n const { table, loading, loadingRows, enableColumnResizing } =\n useDataGridContext();\n\n if (loading) {\n return (\n <div className=\"p-4\">\n <div className=\"space-y-2\">\n {Array.from({ length: loadingRows ?? 5 }).map((_, i) => (\n <Loader key={i} className=\"h-10 w-full\" />\n ))}\n </div>\n </div>\n );\n }\n\n return (\n <Table className={className}>\n <Table.Header>\n {table.getHeaderGroups().map((headerGroup) => (\n <Table.Row key={headerGroup.id}>\n {headerGroup.headers.map((header) => {\n const canSort = header.column.getCanSort();\n const sorted = header.column.getIsSorted();\n const canResize =\n enableColumnResizing && header.column.getCanResize();\n const isResizing = header.column.getIsResizing();\n\n return (\n <Table.Head\n key={header.id}\n className={cn(\n \"bg-sf-base relative group\",\n canSort && \"cursor-pointer select-none hover:bg-sf-overlay\",\n (\n header.column.columnDef as unknown as Record<\n string,\n unknown\n >\n ).headerClassName as string\n )}\n style={canResize ? { width: header.getSize() } : undefined}\n onClick={\n canSort ? () => header.column.toggleSorting() : undefined\n }\n >\n <div className=\"flex items-center gap-1.5\">\n {header.isPlaceholder\n ? null\n : flexRender(\n header.column.columnDef.header,\n header.getContext()\n )}\n {canSort && <SortIcon sorted={sorted} />}\n </div>\n {canResize && (\n <Table.ResizeHandle\n onMouseDown={header.getResizeHandler()}\n onTouchStart={header.getResizeHandler()}\n onDoubleClick={() => header.column.resetSize()}\n className={cn(isResizing && \"visible bg-sf-brand/20\")}\n />\n )}\n </Table.Head>\n );\n })}\n </Table.Row>\n ))}\n </Table.Header>\n <Table.Body>\n {table.getRowModel().rows.map((row) => (\n <Table.Row\n key={row.id}\n variant={row.getIsSelected() ? \"selected\" : \"default\"}\n className={cn(\n row.getIsSelected() && \"bg-sf-tint\",\n \"hover:bg-sf-overlay\"\n )}\n >\n {row.getVisibleCells().map((cell) => (\n <Table.Cell\n key={cell.id}\n className={\n (cell.column.columnDef as unknown as Record<string, unknown>)\n .cellClassName as string\n }\n style={\n enableColumnResizing\n ? { width: cell.column.getSize() }\n : undefined\n }\n >\n {flexRender(cell.column.columnDef.cell, cell.getContext())}\n </Table.Cell>\n ))}\n </Table.Row>\n ))}\n </Table.Body>\n </Table>\n );\n}\n\nDataGridContent.displayName = \"DataGrid.Content\";\n\n// ============================================================================\n// DataGrid Pagination\n// ============================================================================\n\n/**\n * Pagination controls for DataGrid.\n * Wraps the Pagination component with table state.\n */\nfunction DataGridPagination({ className }: DataGridPaginationProps) {\n const {\n table,\n pageSize: _pageSize,\n pageIndex: _pageIndex,\n totalCount,\n manualPagination,\n } = useDataGridContext();\n\n // Get pagination state\n const paginationState = table.getState().pagination;\n const currentPageIndex = paginationState.pageIndex;\n const currentPageSize = paginationState.pageSize;\n\n // Calculate row range\n const startRow = currentPageIndex * currentPageSize + 1;\n const endRow = Math.min(\n (currentPageIndex + 1) * currentPageSize,\n manualPagination ? totalCount : table.getCoreRowModel().rows.length\n );\n\n if (table.getPageCount() <= 1 && !manualPagination) return null;\n\n return (\n <div\n className={cn(\n \"flex items-center justify-between border-t border-sf-line p-3\",\n className\n )}\n >\n <div className=\"text-sm text-sf-subtle\">\n Showing {startRow}–{endRow} of{\" \"}\n {manualPagination ? totalCount : table.getCoreRowModel().rows.length}\n </div>\n <Pagination\n page={currentPageIndex + 1}\n setPage={(page) => table.setPageIndex(page - 1)}\n perPage={currentPageSize}\n totalCount={\n manualPagination ? totalCount : table.getCoreRowModel().rows.length\n }\n text={({ pageShowingRange, totalCount: total }) =>\n `Showing ${pageShowingRange} of ${total}`\n }\n />\n </div>\n );\n}\n\nDataGridPagination.displayName = \"DataGrid.Pagination\";\n\n// ============================================================================\n// DataGrid Empty\n// ============================================================================\n\n/**\n * Empty state component for DataGrid.\n * Shown when there are no rows to display.\n */\nfunction DataGridEmpty({\n className,\n children,\n title = \"No results\",\n description = \"No data to display.\",\n}: DataGridEmptyProps) {\n const { table } = useDataGridContext();\n\n // Only show if there are no rows\n if (table.getCoreRowModel().rows.length > 0) return null;\n\n return (\n <div className={cn(\"p-8\", className)}>\n {children ?? (\n <Empty\n icon={<FadersHorizontalIcon className=\"size-10 text-sf-subtle\" />}\n title={title}\n description={description}\n />\n )}\n </div>\n );\n}\n\nDataGridEmpty.displayName = \"DataGrid.Empty\";\n\n// ============================================================================\n// DataGrid Root\n// ============================================================================\n\n/**\n * DataGrid root component.\n * Sets up the react-table instance and provides context to child components.\n */\nfunction DataGridRoot<TData>({\n data,\n columns,\n sorting: controlledSorting,\n onSortingChange,\n enableSorting = true,\n columnVisibility: controlledColumnVisibility,\n onColumnVisibilityChange,\n enableColumnVisibility = true,\n rowSelection: controlledRowSelection,\n onRowSelectionChange,\n enableRowSelection,\n pageSize = 10,\n pageIndex = 0,\n onPaginationChange,\n totalCount,\n manualPagination = false,\n pageSizeOptions: _pageSizeOptions = [10, 25, 50, 100],\n filters,\n onFiltersChange,\n filterFields,\n enableFiltering,\n layout: _layout = SF_DATA_GRID_DEFAULT_VARIANTS.layout,\n className,\n tableClassName,\n emptyState,\n loading,\n loadingRows,\n toolbar,\n showToolbar = true,\n showPagination = true,\n pagination: customPagination,\n enableColumnResizing,\n columnResizeMode = \"onEnd\",\n children,\n}: DataGridProps<TData> & { children?: ReactNode }) {\n // Internal state for uncontrolled mode\n const [internalSorting, setInternalSorting] = useState<SortingState>([]);\n const [internalColumnVisibility, setInternalColumnVisibility] =\n useState<VisibilityState>({});\n const [internalRowSelection, setInternalRowSelection] =\n useState<RowSelectionState>({});\n const [internalPagination, setInternalPagination] = useState<PaginationState>(\n {\n pageIndex,\n pageSize,\n }\n );\n\n // Determine controlled vs uncontrolled\n const sorting = controlledSorting ?? internalSorting;\n const columnVisibility =\n controlledColumnVisibility ?? internalColumnVisibility;\n const rowSelection = controlledRowSelection ?? internalRowSelection;\n const pagination = internalPagination;\n\n // Handle sorting change\n const handleSortingChange = (\n updater: SortingState | ((old: SortingState) => SortingState)\n ) => {\n const newSorting =\n typeof updater === \"function\" ? updater(sorting) : updater;\n if (onSortingChange) {\n onSortingChange(newSorting);\n } else {\n setInternalSorting(newSorting);\n }\n };\n\n // Handle column visibility change\n const handleColumnVisibilityChange = (\n updater: VisibilityState | ((old: VisibilityState) => VisibilityState)\n ) => {\n const newVisibility =\n typeof updater === \"function\" ? updater(columnVisibility) : updater;\n if (onColumnVisibilityChange) {\n onColumnVisibilityChange(newVisibility);\n } else {\n setInternalColumnVisibility(newVisibility);\n }\n };\n\n // Handle row selection change\n const handleRowSelectionChange = (\n updater: RowSelectionState | ((old: RowSelectionState) => RowSelectionState)\n ) => {\n const newSelection =\n typeof updater === \"function\" ? updater(rowSelection) : updater;\n if (onRowSelectionChange) {\n onRowSelectionChange(newSelection);\n } else {\n setInternalRowSelection(newSelection);\n }\n };\n\n // Handle pagination change\n const handlePaginationChange = (\n updater: PaginationState | ((old: PaginationState) => PaginationState)\n ) => {\n const newPagination =\n typeof updater === \"function\" ? updater(pagination) : updater;\n setInternalPagination(newPagination);\n if (onPaginationChange) {\n onPaginationChange({\n pageIndex: newPagination.pageIndex,\n pageSize: newPagination.pageSize,\n });\n }\n };\n\n // Create table instance\n const table = useReactTable({\n data,\n columns: columns as import(\"@tanstack/react-table\").ColumnDef<\n TData,\n unknown\n >[],\n state: {\n sorting,\n columnVisibility,\n rowSelection,\n pagination,\n },\n onSortingChange: handleSortingChange,\n onColumnVisibilityChange: handleColumnVisibilityChange,\n onRowSelectionChange: handleRowSelectionChange,\n onPaginationChange: handlePaginationChange,\n getCoreRowModel: getCoreRowModel(),\n getSortedRowModel: enableSorting ? getSortedRowModel() : undefined,\n getPaginationRowModel: getPaginationRowModel(),\n getFilteredRowModel: getFilteredRowModel(),\n enableSorting,\n enableRowSelection: enableRowSelection !== false,\n enableColumnResizing,\n columnResizeMode,\n manualPagination,\n pageCount: manualPagination\n ? Math.ceil((totalCount ?? data.length) / pageSize)\n : undefined,\n enableMultiRowSelection: true,\n });\n\n // Provide context to children\n const contextValue: DataGridContextValue<TData> = {\n table,\n pageSize,\n pageIndex,\n totalCount: totalCount ?? data.length,\n manualPagination,\n loading,\n loadingRows,\n enableColumnResizing,\n columnResizeMode,\n };\n\n return (\n <DataGridContext.Provider value={contextValue as DataGridContextValue}>\n <div\n className={cn(\n \"flex flex-col overflow-hidden rounded-lg border border-sf-line bg-sf-base\",\n className\n )}\n >\n {children || (\n // Auto mode - DataGrid renders everything based on props\n <>\n {/* Toolbar */}\n {showToolbar && (\n <DataGridToolbar>\n {toolbar ?? (\n <>\n {enableFiltering && filterFields && (\n <Filters\n filters={filters ?? []}\n fields={filterFields}\n onChange={onFiltersChange ?? (() => {})}\n size=\"sm\"\n />\n )}\n <div className=\"ml-auto flex items-center gap-2\">\n {enableColumnVisibility && <DataGridColumnToggle />}\n </div>\n </>\n )}\n </DataGridToolbar>\n )}\n\n {/* Table content */}\n <div className=\"flex-1 overflow-auto\">\n <DataGridContent className={tableClassName} />\n <DataGridEmpty>{emptyState}</DataGridEmpty>\n </div>\n\n {/* Pagination */}\n {showPagination && (customPagination ?? <DataGridPagination />)}\n </>\n )}\n </div>\n </DataGridContext.Provider>\n );\n}\n\nDataGridRoot.displayName = \"DataGrid\";\n\n// ============================================================================\n// Exports\n// ============================================================================\n\nexport const DataGrid = Object.assign(DataGridRoot, {\n Toolbar: DataGridToolbar,\n Content: DataGridContent,\n Pagination: DataGridPagination,\n ColumnToggle: DataGridColumnToggle,\n Empty: DataGridEmpty,\n});\n\nexport type {\n DataGridProps,\n DataGridColumn,\n DataGridToolbarProps,\n DataGridContentProps,\n DataGridPaginationProps,\n DataGridColumnToggleProps,\n DataGridEmptyProps,\n} from \"./types\";\n"],"mappings":"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"}