@stackframe/stack-ui 2.8.61 → 2.8.63

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 (386) hide show
  1. package/dist/components/action-dialog.js +130 -36
  2. package/dist/components/action-dialog.js.map +1 -0
  3. package/dist/components/brand-icons.js +413 -93
  4. package/dist/components/brand-icons.js.map +1 -0
  5. package/dist/components/browser-frame/index.js +63 -8
  6. package/dist/components/browser-frame/index.js.map +1 -0
  7. package/dist/components/copy-button.js +56 -17
  8. package/dist/components/copy-button.js.map +1 -0
  9. package/dist/components/copy-field.js +68 -12
  10. package/dist/components/copy-field.js.map +1 -0
  11. package/dist/components/data-table/cells.js +121 -50
  12. package/dist/components/data-table/cells.js.map +1 -0
  13. package/dist/components/data-table/column-header.js +62 -7
  14. package/dist/components/data-table/column-header.js.map +1 -0
  15. package/dist/components/data-table/data-table.js +263 -93
  16. package/dist/components/data-table/data-table.js.map +1 -0
  17. package/dist/components/data-table/faceted-filter.js +133 -25
  18. package/dist/components/data-table/faceted-filter.js.map +1 -0
  19. package/dist/components/data-table/index.js +41 -9
  20. package/dist/components/data-table/index.js.map +1 -0
  21. package/dist/components/data-table/pagination.js +89 -9
  22. package/dist/components/data-table/pagination.js.map +1 -0
  23. package/dist/components/data-table/toolbar-items.js +42 -4
  24. package/dist/components/data-table/toolbar-items.js.map +1 -0
  25. package/dist/components/data-table/toolbar.js +114 -44
  26. package/dist/components/data-table/toolbar.js.map +1 -0
  27. package/dist/components/data-table/utils.js +36 -4
  28. package/dist/components/data-table/utils.js.map +1 -0
  29. package/dist/components/data-table/view-options.js +70 -10
  30. package/dist/components/data-table/view-options.js.map +1 -0
  31. package/dist/components/simple-tooltip.js +45 -13
  32. package/dist/components/simple-tooltip.js.map +1 -0
  33. package/dist/components/ui/accordion.js +85 -10
  34. package/dist/components/ui/accordion.js.map +1 -0
  35. package/dist/components/ui/alert.js +75 -17
  36. package/dist/components/ui/alert.js.map +1 -0
  37. package/dist/components/ui/aspect-ratio.js +43 -3
  38. package/dist/components/ui/aspect-ratio.js.map +1 -0
  39. package/dist/components/ui/avatar.js +79 -8
  40. package/dist/components/ui/avatar.js.map +1 -0
  41. package/dist/components/ui/badge.js +51 -17
  42. package/dist/components/ui/badge.js.map +1 -0
  43. package/dist/components/ui/breadcrumb.js +118 -15
  44. package/dist/components/ui/breadcrumb.js.map +1 -0
  45. package/dist/components/ui/button.js +98 -39
  46. package/dist/components/ui/button.js.map +1 -0
  47. package/dist/components/ui/calendar.js +93 -39
  48. package/dist/components/ui/calendar.js.map +1 -0
  49. package/dist/components/ui/card.js +97 -11
  50. package/dist/components/ui/card.js.map +1 -0
  51. package/dist/components/ui/checkbox.js +64 -7
  52. package/dist/components/ui/checkbox.js.map +1 -0
  53. package/dist/components/ui/collapsible.js +49 -5
  54. package/dist/components/ui/collapsible.js.map +1 -0
  55. package/dist/components/ui/command.js +147 -25
  56. package/dist/components/ui/command.js.map +1 -0
  57. package/dist/components/ui/context-menu.js +196 -24
  58. package/dist/components/ui/context-menu.js.map +1 -0
  59. package/dist/components/ui/dialog.js +151 -17
  60. package/dist/components/ui/dialog.js.map +1 -0
  61. package/dist/components/ui/dropdown-menu.js +237 -55
  62. package/dist/components/ui/dropdown-menu.js.map +1 -0
  63. package/dist/components/ui/form.js +142 -53
  64. package/dist/components/ui/form.js.map +1 -0
  65. package/dist/components/ui/hover-card.js +64 -8
  66. package/dist/components/ui/hover-card.js.map +1 -0
  67. package/dist/components/ui/inline-code.js +62 -25
  68. package/dist/components/ui/inline-code.js.map +1 -0
  69. package/dist/components/ui/input-otp.js +87 -14
  70. package/dist/components/ui/input-otp.js.map +1 -0
  71. package/dist/components/ui/input.js +86 -22
  72. package/dist/components/ui/input.js.map +1 -0
  73. package/dist/components/ui/label.js +67 -9
  74. package/dist/components/ui/label.js.map +1 -0
  75. package/dist/components/ui/menubar.js +224 -24
  76. package/dist/components/ui/menubar.js.map +1 -0
  77. package/dist/components/ui/navigation-menu.js +149 -20
  78. package/dist/components/ui/navigation-menu.js.map +1 -0
  79. package/dist/components/ui/password-input.js +79 -11
  80. package/dist/components/ui/password-input.js.map +1 -0
  81. package/dist/components/ui/popover.js +67 -9
  82. package/dist/components/ui/popover.js.map +1 -0
  83. package/dist/components/ui/progress.js +63 -6
  84. package/dist/components/ui/progress.js.map +1 -0
  85. package/dist/components/ui/radio-group.js +70 -10
  86. package/dist/components/ui/radio-group.js.map +1 -0
  87. package/dist/components/ui/resizable.js +78 -8
  88. package/dist/components/ui/resizable.js.map +1 -0
  89. package/dist/components/ui/scroll-area.js +75 -9
  90. package/dist/components/ui/scroll-area.js.map +1 -0
  91. package/dist/components/ui/select.js +166 -20
  92. package/dist/components/ui/select.js.map +1 -0
  93. package/dist/components/ui/separator.js +61 -6
  94. package/dist/components/ui/separator.js.map +1 -0
  95. package/dist/components/ui/sheet.js +153 -27
  96. package/dist/components/ui/sheet.js.map +1 -0
  97. package/dist/components/ui/skeleton.js +46 -5
  98. package/dist/components/ui/skeleton.js.map +1 -0
  99. package/dist/components/ui/slider.js +60 -6
  100. package/dist/components/ui/slider.js.map +1 -0
  101. package/dist/components/ui/spinner.js +36 -6
  102. package/dist/components/ui/spinner.js.map +1 -0
  103. package/dist/components/ui/switch.js +92 -21
  104. package/dist/components/ui/switch.js.map +1 -0
  105. package/dist/components/ui/table.js +117 -12
  106. package/dist/components/ui/table.js.map +1 -0
  107. package/dist/components/ui/tabs.js +85 -9
  108. package/dist/components/ui/tabs.js.map +1 -0
  109. package/dist/components/ui/textarea.js +47 -6
  110. package/dist/components/ui/textarea.js.map +1 -0
  111. package/dist/components/ui/toast.js +135 -25
  112. package/dist/components/ui/toast.js.map +1 -0
  113. package/dist/components/ui/toaster.js +49 -8
  114. package/dist/components/ui/toaster.js.map +1 -0
  115. package/dist/components/ui/toggle-group.js +78 -17
  116. package/dist/components/ui/toggle-group.js.map +1 -0
  117. package/dist/components/ui/toggle.js +73 -21
  118. package/dist/components/ui/toggle.js.map +1 -0
  119. package/dist/components/ui/tooltip.js +72 -9
  120. package/dist/components/ui/tooltip.js.map +1 -0
  121. package/dist/components/ui/typography.js +69 -31
  122. package/dist/components/ui/typography.js.map +1 -0
  123. package/dist/components/ui/use-toast.js +151 -116
  124. package/dist/components/ui/use-toast.js.map +1 -0
  125. package/dist/esm/components/action-dialog.js +97 -0
  126. package/dist/esm/components/action-dialog.js.map +1 -0
  127. package/dist/esm/components/brand-icons.js +390 -0
  128. package/dist/esm/components/brand-icons.js.map +1 -0
  129. package/dist/esm/components/browser-frame/index.js +43 -0
  130. package/dist/esm/components/browser-frame/index.js.map +1 -0
  131. package/dist/esm/components/copy-button.js +35 -0
  132. package/dist/esm/components/copy-button.js.map +1 -0
  133. package/dist/esm/components/copy-field.js +44 -0
  134. package/dist/esm/components/copy-field.js.map +1 -0
  135. package/dist/esm/components/data-table/cells.js +88 -0
  136. package/dist/esm/components/data-table/cells.js.map +1 -0
  137. package/dist/esm/components/data-table/column-header.js +40 -0
  138. package/dist/esm/components/data-table/column-header.js.map +1 -0
  139. package/dist/esm/components/data-table/data-table.js +249 -0
  140. package/dist/esm/components/data-table/data-table.js.map +1 -0
  141. package/dist/esm/components/data-table/faceted-filter.js +117 -0
  142. package/dist/esm/components/data-table/faceted-filter.js.map +1 -0
  143. package/dist/esm/components/data-table/index.js +11 -0
  144. package/dist/esm/components/data-table/index.js.map +1 -0
  145. package/dist/esm/components/data-table/pagination.js +71 -0
  146. package/dist/esm/components/data-table/pagination.js.map +1 -0
  147. package/dist/esm/components/data-table/toolbar-items.js +18 -0
  148. package/dist/esm/components/data-table/toolbar-items.js.map +1 -0
  149. package/dist/esm/components/data-table/toolbar.js +92 -0
  150. package/dist/esm/components/data-table/toolbar.js.map +1 -0
  151. package/dist/esm/components/data-table/utils.js +12 -0
  152. package/dist/esm/components/data-table/utils.js.map +1 -0
  153. package/dist/esm/components/data-table/view-options.js +55 -0
  154. package/dist/esm/components/data-table/view-options.js.map +1 -0
  155. package/dist/esm/components/simple-tooltip.js +21 -0
  156. package/dist/esm/components/simple-tooltip.js.map +1 -0
  157. package/dist/esm/components/ui/accordion.js +52 -0
  158. package/dist/esm/components/ui/accordion.js.map +1 -0
  159. package/dist/esm/components/ui/alert.js +54 -0
  160. package/dist/esm/components/ui/alert.js.map +1 -0
  161. package/dist/esm/components/ui/aspect-ratio.js +10 -0
  162. package/dist/esm/components/ui/aspect-ratio.js.map +1 -0
  163. package/dist/esm/components/ui/avatar.js +47 -0
  164. package/dist/esm/components/ui/avatar.js.map +1 -0
  165. package/dist/esm/components/ui/badge.js +30 -0
  166. package/dist/esm/components/ui/badge.js.map +1 -0
  167. package/dist/esm/components/ui/breadcrumb.js +95 -0
  168. package/dist/esm/components/ui/breadcrumb.js.map +1 -0
  169. package/dist/esm/components/ui/button.js +79 -0
  170. package/dist/esm/components/ui/button.js.map +1 -0
  171. package/dist/esm/components/ui/calendar.js +72 -0
  172. package/dist/esm/components/ui/calendar.js.map +1 -0
  173. package/dist/esm/components/ui/card.js +72 -0
  174. package/dist/esm/components/ui/card.js.map +1 -0
  175. package/dist/esm/components/ui/checkbox.js +32 -0
  176. package/dist/esm/components/ui/checkbox.js.map +1 -0
  177. package/dist/esm/components/ui/collapsible.js +14 -0
  178. package/dist/esm/components/ui/collapsible.js.map +1 -0
  179. package/dist/esm/components/ui/command.js +119 -0
  180. package/dist/esm/components/ui/command.js.map +1 -0
  181. package/dist/esm/components/ui/context-menu.js +162 -0
  182. package/dist/esm/components/ui/context-menu.js.map +1 -0
  183. package/dist/esm/components/ui/dialog.js +114 -0
  184. package/dist/esm/components/ui/dialog.js.map +1 -0
  185. package/dist/esm/components/ui/dropdown-menu.js +200 -0
  186. package/dist/esm/components/ui/dropdown-menu.js.map +1 -0
  187. package/dist/esm/components/ui/form.js +118 -0
  188. package/dist/esm/components/ui/form.js.map +1 -0
  189. package/dist/esm/components/ui/hover-card.js +30 -0
  190. package/dist/esm/components/ui/hover-card.js.map +1 -0
  191. package/dist/esm/components/ui/inline-code.js +42 -0
  192. package/dist/esm/components/ui/inline-code.js.map +1 -0
  193. package/dist/esm/components/ui/input-otp.js +56 -0
  194. package/dist/esm/components/ui/input-otp.js.map +1 -0
  195. package/dist/esm/components/ui/input.js +57 -0
  196. package/dist/esm/components/ui/input.js.map +1 -0
  197. package/dist/esm/components/ui/label.js +35 -0
  198. package/dist/esm/components/ui/label.js.map +1 -0
  199. package/dist/esm/components/ui/menubar.js +192 -0
  200. package/dist/esm/components/ui/menubar.js.map +1 -0
  201. package/dist/esm/components/ui/navigation-menu.js +112 -0
  202. package/dist/esm/components/ui/navigation-menu.js.map +1 -0
  203. package/dist/esm/components/ui/password-input.js +58 -0
  204. package/dist/esm/components/ui/password-input.js.map +1 -0
  205. package/dist/esm/components/ui/popover.js +32 -0
  206. package/dist/esm/components/ui/popover.js.map +1 -0
  207. package/dist/esm/components/ui/progress.js +31 -0
  208. package/dist/esm/components/ui/progress.js.map +1 -0
  209. package/dist/esm/components/ui/radio-group.js +40 -0
  210. package/dist/esm/components/ui/radio-group.js.map +1 -0
  211. package/dist/esm/components/ui/resizable.js +43 -0
  212. package/dist/esm/components/ui/resizable.js.map +1 -0
  213. package/dist/esm/components/ui/scroll-area.js +43 -0
  214. package/dist/esm/components/ui/scroll-area.js.map +1 -0
  215. package/dist/esm/components/ui/select.js +135 -0
  216. package/dist/esm/components/ui/select.js.map +1 -0
  217. package/dist/esm/components/ui/separator.js +29 -0
  218. package/dist/esm/components/ui/separator.js.map +1 -0
  219. package/dist/esm/components/ui/sheet.js +120 -0
  220. package/dist/esm/components/ui/sheet.js.map +1 -0
  221. package/dist/esm/components/ui/skeleton.js +24 -0
  222. package/dist/esm/components/ui/skeleton.js.map +1 -0
  223. package/dist/esm/components/ui/slider.js +28 -0
  224. package/dist/esm/components/ui/slider.js.map +1 -0
  225. package/dist/esm/components/ui/spinner.js +13 -0
  226. package/dist/esm/components/ui/spinner.js.map +1 -0
  227. package/dist/esm/components/ui/switch.js +62 -0
  228. package/dist/esm/components/ui/switch.js.map +1 -0
  229. package/dist/esm/components/ui/table.js +93 -0
  230. package/dist/esm/components/ui/table.js.map +1 -0
  231. package/dist/esm/components/ui/tabs.js +52 -0
  232. package/dist/esm/components/ui/tabs.js.map +1 -0
  233. package/dist/esm/components/ui/textarea.js +24 -0
  234. package/dist/esm/components/ui/textarea.js.map +1 -0
  235. package/dist/esm/components/ui/toast.js +105 -0
  236. package/dist/esm/components/ui/toast.js.map +1 -0
  237. package/dist/esm/components/ui/toaster.js +34 -0
  238. package/dist/esm/components/ui/toaster.js.map +1 -0
  239. package/dist/esm/components/ui/toggle-group.js +48 -0
  240. package/dist/esm/components/ui/toggle-group.js.map +1 -0
  241. package/dist/esm/components/ui/toggle.js +43 -0
  242. package/dist/esm/components/ui/toggle.js.map +1 -0
  243. package/dist/esm/components/ui/tooltip.js +38 -0
  244. package/dist/esm/components/ui/tooltip.js.map +1 -0
  245. package/dist/esm/components/ui/typography.js +47 -0
  246. package/dist/esm/components/ui/typography.js.map +1 -0
  247. package/dist/esm/components/ui/use-toast.js +130 -0
  248. package/dist/esm/components/ui/use-toast.js.map +1 -0
  249. package/dist/esm/index.js +59 -0
  250. package/dist/esm/index.js.map +1 -0
  251. package/dist/esm/lib/utils.js +10 -0
  252. package/dist/esm/lib/utils.js.map +1 -0
  253. package/dist/index.d.mts +967 -0
  254. package/dist/index.d.ts +967 -54
  255. package/dist/index.js +147 -53
  256. package/dist/index.js.map +1 -0
  257. package/dist/lib/utils.js +34 -4
  258. package/dist/lib/utils.js.map +1 -0
  259. package/package.json +10 -5
  260. package/dist/components/action-dialog.d.ts +0 -28
  261. package/dist/components/action-dialog.d.ts.map +0 -1
  262. package/dist/components/brand-icons.d.ts +0 -43
  263. package/dist/components/brand-icons.d.ts.map +0 -1
  264. package/dist/components/browser-frame/index.d.ts +0 -10
  265. package/dist/components/browser-frame/index.d.ts.map +0 -1
  266. package/dist/components/copy-button.d.ts +0 -17
  267. package/dist/components/copy-button.d.ts.map +0 -1
  268. package/dist/components/copy-field.d.ts +0 -13
  269. package/dist/components/copy-field.d.ts.map +0 -1
  270. package/dist/components/data-table/cells.d.ts +0 -31
  271. package/dist/components/data-table/cells.d.ts.map +0 -1
  272. package/dist/components/data-table/column-header.d.ts +0 -8
  273. package/dist/components/data-table/column-header.d.ts.map +0 -1
  274. package/dist/components/data-table/data-table.d.ts +0 -36
  275. package/dist/components/data-table/data-table.d.ts.map +0 -1
  276. package/dist/components/data-table/faceted-filter.d.ts +0 -16
  277. package/dist/components/data-table/faceted-filter.d.ts.map +0 -1
  278. package/dist/components/data-table/index.d.ts +0 -10
  279. package/dist/components/data-table/index.d.ts.map +0 -1
  280. package/dist/components/data-table/pagination.d.ts +0 -7
  281. package/dist/components/data-table/pagination.d.ts.map +0 -1
  282. package/dist/components/data-table/toolbar-items.d.ts +0 -8
  283. package/dist/components/data-table/toolbar-items.d.ts.map +0 -1
  284. package/dist/components/data-table/toolbar.d.ts +0 -12
  285. package/dist/components/data-table/toolbar.d.ts.map +0 -1
  286. package/dist/components/data-table/utils.d.ts +0 -3
  287. package/dist/components/data-table/utils.d.ts.map +0 -1
  288. package/dist/components/data-table/view-options.d.ts +0 -7
  289. package/dist/components/data-table/view-options.d.ts.map +0 -1
  290. package/dist/components/simple-tooltip.d.ts +0 -9
  291. package/dist/components/simple-tooltip.d.ts.map +0 -1
  292. package/dist/components/ui/accordion.d.ts +0 -14
  293. package/dist/components/ui/accordion.d.ts.map +0 -1
  294. package/dist/components/ui/alert.d.ts +0 -15
  295. package/dist/components/ui/alert.d.ts.map +0 -1
  296. package/dist/components/ui/aspect-ratio.d.ts +0 -4
  297. package/dist/components/ui/aspect-ratio.d.ts.map +0 -1
  298. package/dist/components/ui/avatar.d.ts +0 -13
  299. package/dist/components/ui/avatar.d.ts.map +0 -1
  300. package/dist/components/ui/badge.d.ts +0 -13
  301. package/dist/components/ui/badge.d.ts.map +0 -1
  302. package/dist/components/ui/breadcrumb.d.ts +0 -30
  303. package/dist/components/ui/breadcrumb.d.ts.map +0 -1
  304. package/dist/components/ui/button.d.ts +0 -28
  305. package/dist/components/ui/button.d.ts.map +0 -1
  306. package/dist/components/ui/calendar.d.ts +0 -9
  307. package/dist/components/ui/calendar.d.ts.map +0 -1
  308. package/dist/components/ui/card.d.ts +0 -23
  309. package/dist/components/ui/card.d.ts.map +0 -1
  310. package/dist/components/ui/checkbox.d.ts +0 -7
  311. package/dist/components/ui/checkbox.d.ts.map +0 -1
  312. package/dist/components/ui/collapsible.d.ts +0 -6
  313. package/dist/components/ui/collapsible.d.ts.map +0 -1
  314. package/dist/components/ui/command.d.ts +0 -18
  315. package/dist/components/ui/command.d.ts.map +0 -1
  316. package/dist/components/ui/context-menu.d.ts +0 -44
  317. package/dist/components/ui/context-menu.d.ts.map +0 -1
  318. package/dist/components/ui/dialog.d.ts +0 -34
  319. package/dist/components/ui/dialog.d.ts.map +0 -1
  320. package/dist/components/ui/dropdown-menu.d.ts +0 -47
  321. package/dist/components/ui/dropdown-menu.d.ts.map +0 -1
  322. package/dist/components/ui/form.d.ts +0 -34
  323. package/dist/components/ui/form.d.ts.map +0 -1
  324. package/dist/components/ui/hover-card.d.ts +0 -9
  325. package/dist/components/ui/hover-card.d.ts.map +0 -1
  326. package/dist/components/ui/inline-code.d.ts +0 -6
  327. package/dist/components/ui/inline-code.d.ts.map +0 -1
  328. package/dist/components/ui/input-otp.d.ts +0 -17
  329. package/dist/components/ui/input-otp.d.ts.map +0 -1
  330. package/dist/components/ui/input.d.ts +0 -20
  331. package/dist/components/ui/input.d.ts.map +0 -1
  332. package/dist/components/ui/label.d.ts +0 -11
  333. package/dist/components/ui/label.d.ts.map +0 -1
  334. package/dist/components/ui/menubar.d.ts +0 -31
  335. package/dist/components/ui/menubar.d.ts.map +0 -1
  336. package/dist/components/ui/navigation-menu.d.ts +0 -25
  337. package/dist/components/ui/navigation-menu.d.ts.map +0 -1
  338. package/dist/components/ui/password-input.d.ts +0 -7
  339. package/dist/components/ui/password-input.d.ts.map +0 -1
  340. package/dist/components/ui/popover.d.ts +0 -10
  341. package/dist/components/ui/popover.d.ts.map +0 -1
  342. package/dist/components/ui/progress.d.ts +0 -7
  343. package/dist/components/ui/progress.d.ts.map +0 -1
  344. package/dist/components/ui/radio-group.d.ts +0 -10
  345. package/dist/components/ui/radio-group.d.ts.map +0 -1
  346. package/dist/components/ui/resizable.d.ts +0 -37
  347. package/dist/components/ui/resizable.d.ts.map +0 -1
  348. package/dist/components/ui/scroll-area.d.ts +0 -10
  349. package/dist/components/ui/scroll-area.d.ts.map +0 -1
  350. package/dist/components/ui/select.d.ts +0 -30
  351. package/dist/components/ui/select.d.ts.map +0 -1
  352. package/dist/components/ui/separator.d.ts +0 -7
  353. package/dist/components/ui/separator.d.ts.map +0 -1
  354. package/dist/components/ui/sheet.d.ts +0 -33
  355. package/dist/components/ui/sheet.d.ts.map +0 -1
  356. package/dist/components/ui/skeleton.d.ts +0 -4
  357. package/dist/components/ui/skeleton.d.ts.map +0 -1
  358. package/dist/components/ui/slider.d.ts +0 -7
  359. package/dist/components/ui/slider.d.ts.map +0 -1
  360. package/dist/components/ui/spinner.d.ts +0 -7
  361. package/dist/components/ui/spinner.d.ts.map +0 -1
  362. package/dist/components/ui/switch.d.ts +0 -11
  363. package/dist/components/ui/switch.d.ts.map +0 -1
  364. package/dist/components/ui/table.d.ts +0 -27
  365. package/dist/components/ui/table.d.ts.map +0 -1
  366. package/dist/components/ui/tabs.d.ts +0 -14
  367. package/dist/components/ui/tabs.d.ts.map +0 -1
  368. package/dist/components/ui/textarea.d.ts +0 -7
  369. package/dist/components/ui/textarea.d.ts.map +0 -1
  370. package/dist/components/ui/toast.d.ts +0 -28
  371. package/dist/components/ui/toast.d.ts.map +0 -1
  372. package/dist/components/ui/toaster.d.ts +0 -2
  373. package/dist/components/ui/toaster.d.ts.map +0 -1
  374. package/dist/components/ui/toggle-group.d.ts +0 -17
  375. package/dist/components/ui/toggle-group.d.ts.map +0 -1
  376. package/dist/components/ui/toggle.d.ts +0 -15
  377. package/dist/components/ui/toggle.d.ts.map +0 -1
  378. package/dist/components/ui/tooltip.d.ts +0 -12
  379. package/dist/components/ui/tooltip.d.ts.map +0 -1
  380. package/dist/components/ui/typography.d.ts +0 -10
  381. package/dist/components/ui/typography.d.ts.map +0 -1
  382. package/dist/components/ui/use-toast.d.ts +0 -45
  383. package/dist/components/ui/use-toast.d.ts.map +0 -1
  384. package/dist/index.d.ts.map +0 -1
  385. package/dist/lib/utils.d.ts +0 -3
  386. package/dist/lib/utils.d.ts.map +0 -1
@@ -0,0 +1,88 @@
1
+ "use client";
2
+ "use client";
3
+
4
+ // src/components/data-table/cells.tsx
5
+ import { DotsHorizontalIcon } from "@radix-ui/react-icons";
6
+ import React, { useEffect, useRef, useState } from "react";
7
+ import { Avatar, AvatarFallback, AvatarImage, Badge, Button, DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuSeparator, DropdownMenuTrigger, SimpleTooltip, cn } from "../../index.js";
8
+ import { jsx, jsxs } from "react/jsx-runtime";
9
+ import { createElement } from "react";
10
+ function TextCell(props) {
11
+ const textRef = useRef(null);
12
+ const [isOverflowing, setIsOverflowing] = useState(false);
13
+ const overflowStyle = "text-ellipsis text-nowrap overflow-x-hidden";
14
+ useEffect(() => {
15
+ const checkOverflow = () => {
16
+ if (textRef.current) {
17
+ const isOverflowing2 = textRef.current.scrollWidth > textRef.current.clientWidth;
18
+ setIsOverflowing(isOverflowing2);
19
+ }
20
+ };
21
+ checkOverflow();
22
+ window.addEventListener("resize", checkOverflow);
23
+ return () => {
24
+ window.removeEventListener("resize", checkOverflow);
25
+ };
26
+ }, []);
27
+ return /* @__PURE__ */ jsx("div", { className: "relative", style: { minWidth: props.size }, children: /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2 absolute inset-0", children: [
28
+ /* @__PURE__ */ jsx("div", { className: overflowStyle, ref: textRef, children: isOverflowing ? /* @__PURE__ */ jsx(SimpleTooltip, { tooltip: props.children, children: /* @__PURE__ */ jsx("div", { className: overflowStyle, children: props.children }) }) : props.children }),
29
+ props.icon && /* @__PURE__ */ jsx("div", { children: props.icon })
30
+ ] }) });
31
+ }
32
+ function AvatarCell(props) {
33
+ return /* @__PURE__ */ jsxs(Avatar, { className: "h-6 w-6", children: [
34
+ /* @__PURE__ */ jsx(AvatarImage, { src: props.src }),
35
+ /* @__PURE__ */ jsx(AvatarFallback, { children: props.fallback })
36
+ ] });
37
+ }
38
+ function DateCell(props) {
39
+ const ignore = !!props.ignoreAfterYears && new Date((/* @__PURE__ */ new Date()).setFullYear((/* @__PURE__ */ new Date()).getFullYear() + props.ignoreAfterYears)) < props.date;
40
+ const timeString = props.date.toLocaleTimeString([], { year: "numeric", month: "numeric", day: "numeric", hour: "2-digit", minute: "2-digit" });
41
+ return /* @__PURE__ */ jsx(TextCell, { size: 140, children: ignore ? "Never" : timeString });
42
+ }
43
+ function ActionCell(props) {
44
+ return /* @__PURE__ */ jsxs(DropdownMenu, { children: [
45
+ /* @__PURE__ */ jsx(DropdownMenuTrigger, { asChild: true, children: /* @__PURE__ */ jsxs(
46
+ Button,
47
+ {
48
+ variant: "ghost",
49
+ className: cn(
50
+ "flex h-8 w-8 p-0 data-[state=open]:bg-muted",
51
+ props.invisible && "invisible"
52
+ ),
53
+ children: [
54
+ /* @__PURE__ */ jsx(DotsHorizontalIcon, { className: "h-4 w-4" }),
55
+ /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Open menu" })
56
+ ]
57
+ }
58
+ ) }),
59
+ /* @__PURE__ */ jsx(DropdownMenuContent, { align: "end", className: "min-w-[150px] max-w-[300px] stack-scope", children: props.items?.map((item, index) => {
60
+ if (item === "-") {
61
+ return /* @__PURE__ */ jsx(DropdownMenuSeparator, {}, index);
62
+ }
63
+ const menuItemProps = {
64
+ onClick: item.onClick,
65
+ className: cn(item.danger ? "text-destructive" : ""),
66
+ disabled: item.disabled
67
+ };
68
+ const menuItem = /* @__PURE__ */ createElement(DropdownMenuItem, { ...menuItemProps, key: index }, item.item);
69
+ if (item.disabled && item.disabledTooltip) {
70
+ return /* @__PURE__ */ jsx(SimpleTooltip, { tooltip: item.disabledTooltip, children: React.cloneElement(menuItem, {
71
+ className: cn(menuItemProps.className, "opacity-50 cursor-not-allowed")
72
+ }) }, index);
73
+ }
74
+ return menuItem;
75
+ }) })
76
+ ] });
77
+ }
78
+ function BadgeCell(props) {
79
+ return /* @__PURE__ */ jsx("div", { className: "flex items-center gap-1 flex-wrap", children: props.badges.map((badge, index) => /* @__PURE__ */ jsx(Badge, { variant: "secondary", children: badge }, index)) });
80
+ }
81
+ export {
82
+ ActionCell,
83
+ AvatarCell,
84
+ BadgeCell,
85
+ DateCell,
86
+ TextCell
87
+ };
88
+ //# sourceMappingURL=cells.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/components/data-table/cells.tsx"],"sourcesContent":["\n'use client';\nimport { DotsHorizontalIcon } from \"@radix-ui/react-icons\";\nimport React, { useEffect, useRef, useState } from \"react\";\nimport { Avatar, AvatarFallback, AvatarImage, Badge, Button, DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuSeparator, DropdownMenuTrigger, SimpleTooltip, cn } from \"../..\";\n\nexport function TextCell(props: { children: React.ReactNode, size?: number, icon?: React.ReactNode }) {\n const textRef = useRef<HTMLDivElement>(null);\n const [isOverflowing, setIsOverflowing] = useState(false);\n const overflowStyle = \"text-ellipsis text-nowrap overflow-x-hidden\";\n\n useEffect(() => {\n const checkOverflow = () => {\n if (textRef.current) {\n const isOverflowing = textRef.current.scrollWidth > textRef.current.clientWidth;\n setIsOverflowing(isOverflowing);\n }\n };\n\n checkOverflow();\n window.addEventListener('resize', checkOverflow);\n return () => {\n window.removeEventListener('resize', checkOverflow);\n };\n }, []);\n\n return (\n <div className=\"relative\" style={{ minWidth: props.size }}>\n <div className=\"flex items-center gap-2 absolute inset-0\">\n <div className={overflowStyle} ref={textRef}>\n {isOverflowing ? (\n <SimpleTooltip tooltip={props.children}>\n <div className={overflowStyle}>\n {props.children}\n </div>\n </SimpleTooltip>\n ) : props.children}\n </div>\n {props.icon && <div>{props.icon}</div>}\n </div>\n </div>\n );\n}\n\nexport function AvatarCell(props: { src?: string, fallback?: string }) {\n return (\n <Avatar className=\"h-6 w-6\">\n <AvatarImage src={props.src} />\n <AvatarFallback>{props.fallback}</AvatarFallback>\n </Avatar>\n );\n}\n\nexport function DateCell(props: { date: Date, ignoreAfterYears?: number }) {\n const ignore = !!props.ignoreAfterYears && new Date(new Date().setFullYear(new Date().getFullYear() + props.ignoreAfterYears)) < props.date;\n const timeString = props.date.toLocaleTimeString([], { year: 'numeric', month: 'numeric', day: 'numeric', hour: '2-digit', minute: '2-digit' });\n return (\n <TextCell size={140}>\n {ignore ? 'Never' : timeString}\n </TextCell>\n );\n}\n\ntype ActionItem = '-' | {\n item: React.ReactNode,\n onClick: (e: React.MouseEvent) => void | Promise<void>,\n danger?: boolean,\n disabled?: boolean,\n disabledTooltip?: string,\n}\n\nexport function ActionCell(props: {\n items?: ActionItem[],\n invisible?: boolean,\n}) {\n return (\n <DropdownMenu>\n <DropdownMenuTrigger asChild>\n <Button\n variant=\"ghost\"\n className={cn(\n \"flex h-8 w-8 p-0 data-[state=open]:bg-muted\",\n props.invisible && \"invisible\",\n )}\n >\n <DotsHorizontalIcon className=\"h-4 w-4\" />\n <span className=\"sr-only\">Open menu</span>\n </Button>\n </DropdownMenuTrigger>\n <DropdownMenuContent align=\"end\" className=\"min-w-[150px] max-w-[300px] stack-scope\">\n {props.items?.map((item, index) => {\n if (item === '-') {\n return <DropdownMenuSeparator key={index} />;\n }\n\n const menuItemProps = {\n onClick: item.onClick,\n className: cn(item.danger ? \"text-destructive\" : \"\"),\n disabled: item.disabled\n };\n\n const menuItem = (\n <DropdownMenuItem {...menuItemProps} key={index}>\n {item.item}\n </DropdownMenuItem>\n );\n\n if (item.disabled && item.disabledTooltip) {\n return (\n <SimpleTooltip tooltip={item.disabledTooltip} key={index}>\n {React.cloneElement(menuItem, {\n className: cn(menuItemProps.className, \"opacity-50 cursor-not-allowed\")\n })}\n </SimpleTooltip>\n );\n }\n\n return menuItem;\n })}\n </DropdownMenuContent>\n </DropdownMenu>\n );\n}\n\nexport function BadgeCell(props: { badges: string[], size?: number }) {\n return (\n <div className=\"flex items-center gap-1 flex-wrap\">\n {props.badges.map((badge, index) => (\n <Badge key={index} variant=\"secondary\">{badge}</Badge>\n ))}\n </div>\n );\n}\n"],"mappings":"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","names":["isOverflowing"]}
@@ -0,0 +1,40 @@
1
+ // src/components/data-table/column-header.tsx
2
+ import { Button } from "../ui/button.js";
3
+ import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from "../ui/dropdown-menu.js";
4
+ import { ArrowDown, ArrowUp } from "lucide-react";
5
+ import { cn } from "../../lib/utils.js";
6
+ import { jsx, jsxs } from "react/jsx-runtime";
7
+ function Item(props) {
8
+ return /* @__PURE__ */ jsx(DropdownMenuItem, { onClick: props.onClick, children: /* @__PURE__ */ jsxs("div", { className: "flex items-center", children: [
9
+ /* @__PURE__ */ jsx(props.icon, { className: "mr-2 h-3.5 w-3.5 text-muted-foreground/70" }),
10
+ props.children
11
+ ] }) });
12
+ }
13
+ function DataTableColumnHeader({
14
+ column,
15
+ columnTitle,
16
+ className
17
+ }) {
18
+ return /* @__PURE__ */ jsx("div", { className: cn("flex items-center space-x-2", className), children: /* @__PURE__ */ jsxs(DropdownMenu, { children: [
19
+ /* @__PURE__ */ jsx(DropdownMenuTrigger, { asChild: true, children: /* @__PURE__ */ jsxs(
20
+ Button,
21
+ {
22
+ variant: "ghost",
23
+ size: "sm",
24
+ className: cn("-ml-3 h-8 data-[state=open]:bg-accent", !column.getCanSort() && "pointer-events-none"),
25
+ children: [
26
+ /* @__PURE__ */ jsx("span", { children: columnTitle }),
27
+ column.getIsSorted() === "desc" ? /* @__PURE__ */ jsx(ArrowDown, { className: "ml-2 h-4 w-4" }) : column.getIsSorted() === "asc" ? /* @__PURE__ */ jsx(ArrowUp, { className: "ml-2 h-4 w-4" }) : null
28
+ ]
29
+ }
30
+ ) }),
31
+ /* @__PURE__ */ jsxs(DropdownMenuContent, { align: "start", className: "stack-scope", children: [
32
+ /* @__PURE__ */ jsx(Item, { icon: ArrowUp, onClick: () => column.toggleSorting(false), children: "Asc" }),
33
+ /* @__PURE__ */ jsx(Item, { icon: ArrowDown, onClick: () => column.toggleSorting(true), children: "Desc" })
34
+ ] })
35
+ ] }) });
36
+ }
37
+ export {
38
+ DataTableColumnHeader
39
+ };
40
+ //# sourceMappingURL=column-header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/components/data-table/column-header.tsx"],"sourcesContent":["import { Button } from \"../ui/button\";\nimport { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from \"../ui/dropdown-menu\";\nimport { Column } from \"@tanstack/react-table\";\nimport { ArrowDown, ArrowUp, LucideIcon } from \"lucide-react\";\nimport { cn } from \"../../lib/utils\";\n\ntype DataTableColumnHeaderProps<TData, TValue> = {\n column: Column<TData, TValue>,\n columnTitle: React.ReactNode,\n} & React.HTMLAttributes<HTMLDivElement>\n\nfunction Item(props: { icon: LucideIcon, onClick: () => void, children: React.ReactNode }) {\n return (\n <DropdownMenuItem onClick={props.onClick}>\n <div className=\"flex items-center\">\n <props.icon className=\"mr-2 h-3.5 w-3.5 text-muted-foreground/70\" />\n {props.children}\n </div>\n </DropdownMenuItem>\n );\n}\n\nexport function DataTableColumnHeader<TData, TValue>({\n column,\n columnTitle,\n className,\n}: DataTableColumnHeaderProps<TData, TValue>) {\n return (\n <div className={cn(\"flex items-center space-x-2\", className)}>\n <DropdownMenu>\n <DropdownMenuTrigger asChild>\n <Button\n variant=\"ghost\"\n size=\"sm\"\n className={cn(\"-ml-3 h-8 data-[state=open]:bg-accent\", !column.getCanSort() && \"pointer-events-none\")}\n >\n <span>{columnTitle}</span>\n {column.getIsSorted() === \"desc\" ? (\n <ArrowDown className=\"ml-2 h-4 w-4\" />\n ) : column.getIsSorted() === \"asc\" ? (\n <ArrowUp className=\"ml-2 h-4 w-4\" />\n ) : null}\n </Button>\n </DropdownMenuTrigger>\n <DropdownMenuContent align=\"start\" className=\"stack-scope\">\n <Item icon={ArrowUp} onClick={() => column.toggleSorting(false)}>Asc</Item>\n <Item icon={ArrowDown} onClick={() => column.toggleSorting(true)}>Desc</Item>\n </DropdownMenuContent>\n </DropdownMenu>\n </div>\n );\n}\n"],"mappings":";AAAA,SAAS,cAAc;AACvB,SAAS,cAAc,qBAAqB,kBAAkB,2BAA2B;AAEzF,SAAS,WAAW,eAA2B;AAC/C,SAAS,UAAU;AAUb,SACE,KADF;AAHN,SAAS,KAAK,OAA6E;AACzF,SACE,oBAAC,oBAAiB,SAAS,MAAM,SAC/B,+BAAC,SAAI,WAAU,qBACb;AAAA,wBAAC,MAAM,MAAN,EAAW,WAAU,6CAA4C;AAAA,IACjE,MAAM;AAAA,KACT,GACF;AAEJ;AAEO,SAAS,sBAAqC;AAAA,EACnD;AAAA,EACA;AAAA,EACA;AACF,GAA8C;AAC5C,SACE,oBAAC,SAAI,WAAW,GAAG,+BAA+B,SAAS,GACzD,+BAAC,gBACC;AAAA,wBAAC,uBAAoB,SAAO,MAC1B;AAAA,MAAC;AAAA;AAAA,QACC,SAAQ;AAAA,QACR,MAAK;AAAA,QACL,WAAW,GAAG,yCAAyC,CAAC,OAAO,WAAW,KAAK,qBAAqB;AAAA,QAEpG;AAAA,8BAAC,UAAM,uBAAY;AAAA,UAClB,OAAO,YAAY,MAAM,SACxB,oBAAC,aAAU,WAAU,gBAAe,IAClC,OAAO,YAAY,MAAM,QAC3B,oBAAC,WAAQ,WAAU,gBAAe,IAChC;AAAA;AAAA;AAAA,IACN,GACF;AAAA,IACA,qBAAC,uBAAoB,OAAM,SAAQ,WAAU,eAC3C;AAAA,0BAAC,QAAK,MAAM,SAAS,SAAS,MAAM,OAAO,cAAc,KAAK,GAAG,iBAAG;AAAA,MACpE,oBAAC,QAAK,MAAM,WAAW,SAAS,MAAM,OAAO,cAAc,IAAI,GAAG,kBAAI;AAAA,OACxE;AAAA,KACF,GACF;AAEJ;","names":[]}
@@ -0,0 +1,249 @@
1
+ "use client";
2
+ "use client";
3
+
4
+ // src/components/data-table/data-table.tsx
5
+ import { runAsynchronouslyWithAlert } from "@stackframe/stack-shared/dist/utils/promises";
6
+ import {
7
+ Table,
8
+ TableBody,
9
+ TableCell,
10
+ TableHead,
11
+ TableHeader,
12
+ TableRow
13
+ } from "../ui/table.js";
14
+ import {
15
+ GlobalFiltering,
16
+ flexRender,
17
+ getCoreRowModel,
18
+ getFacetedRowModel,
19
+ getFacetedUniqueValues,
20
+ getFilteredRowModel,
21
+ getPaginationRowModel,
22
+ getSortedRowModel,
23
+ useReactTable
24
+ } from "@tanstack/react-table";
25
+ import React from "react";
26
+ import { DataTablePagination } from "./pagination.js";
27
+ import { DataTableToolbar } from "./toolbar.js";
28
+ import { jsx, jsxs } from "react/jsx-runtime";
29
+ function TableView(props) {
30
+ return /* @__PURE__ */ jsxs("div", { className: "space-y-4", children: [
31
+ /* @__PURE__ */ jsx(
32
+ DataTableToolbar,
33
+ {
34
+ table: props.table,
35
+ toolbarRender: props.toolbarRender,
36
+ showDefaultToolbar: props.showDefaultToolbar,
37
+ defaultColumnFilters: props.defaultColumnFilters,
38
+ defaultSorting: props.defaultSorting
39
+ }
40
+ ),
41
+ /* @__PURE__ */ jsx("div", { className: "rounded-md border", children: /* @__PURE__ */ jsxs(Table, { children: [
42
+ /* @__PURE__ */ jsx(TableHeader, { children: props.table.getHeaderGroups().map((headerGroup) => /* @__PURE__ */ jsx(TableRow, { children: headerGroup.headers.map((header) => {
43
+ return /* @__PURE__ */ jsx(TableHead, { colSpan: header.colSpan, children: header.isPlaceholder ? null : flexRender(
44
+ header.column.columnDef.header,
45
+ header.getContext()
46
+ ) }, header.id);
47
+ }) }, headerGroup.id)) }),
48
+ /* @__PURE__ */ jsx(TableBody, { children: props.table.getRowModel().rows.length ? props.table.getRowModel().rows.map((row) => /* @__PURE__ */ jsx(
49
+ TableRow,
50
+ {
51
+ "data-state": row.getIsSelected() && "selected",
52
+ onClick: (ev) => {
53
+ if (ev.target instanceof Node && ev.currentTarget.contains(ev.target)) {
54
+ props.onRowClick?.(row.original);
55
+ }
56
+ },
57
+ children: row.getVisibleCells().map((cell) => /* @__PURE__ */ jsx(TableCell, { children: flexRender(
58
+ cell.column.columnDef.cell,
59
+ cell.getContext()
60
+ ) }, cell.id))
61
+ },
62
+ row.id
63
+ )) : /* @__PURE__ */ jsx(TableRow, { children: /* @__PURE__ */ jsx(
64
+ TableCell,
65
+ {
66
+ colSpan: props.columns.length,
67
+ className: "h-24 text-center",
68
+ children: "No results."
69
+ }
70
+ ) }) })
71
+ ] }) }),
72
+ /* @__PURE__ */ jsx(DataTablePagination, { table: props.table })
73
+ ] });
74
+ }
75
+ function DataTable({
76
+ columns,
77
+ data,
78
+ toolbarRender,
79
+ defaultVisibility,
80
+ defaultColumnFilters,
81
+ defaultSorting,
82
+ showDefaultToolbar = true,
83
+ onRowClick
84
+ }) {
85
+ const [sorting, setSorting] = React.useState(defaultSorting);
86
+ const [columnFilters, setColumnFilters] = React.useState(defaultColumnFilters);
87
+ const [pagination, setPagination] = React.useState({
88
+ pageIndex: 0,
89
+ pageSize: 10
90
+ });
91
+ const [globalFilter, setGlobalFilter] = React.useState();
92
+ return /* @__PURE__ */ jsx(
93
+ DataTableBase,
94
+ {
95
+ columns,
96
+ data,
97
+ toolbarRender,
98
+ defaultVisibility,
99
+ sorting,
100
+ setSorting,
101
+ defaultSorting,
102
+ columnFilters,
103
+ setColumnFilters,
104
+ defaultColumnFilters,
105
+ manualPagination: false,
106
+ manualFiltering: false,
107
+ pagination,
108
+ setPagination,
109
+ globalFilter,
110
+ setGlobalFilter,
111
+ showDefaultToolbar,
112
+ onRowClick
113
+ }
114
+ );
115
+ }
116
+ function DataTableManualPagination({
117
+ columns,
118
+ data,
119
+ toolbarRender,
120
+ defaultVisibility,
121
+ defaultColumnFilters,
122
+ defaultSorting,
123
+ onRowClick,
124
+ onUpdate,
125
+ showDefaultToolbar = true
126
+ }) {
127
+ const [sorting, setSorting] = React.useState(defaultSorting);
128
+ const [pagination, setPagination] = React.useState({ pageIndex: 0, pageSize: 10 });
129
+ const [cursors, setCursors] = React.useState({});
130
+ const [columnFilters, setColumnFilters] = React.useState(defaultColumnFilters);
131
+ const [globalFilter, setGlobalFilter] = React.useState();
132
+ const [refreshCounter, setRefreshCounter] = React.useState(0);
133
+ React.useEffect(() => {
134
+ runAsynchronouslyWithAlert(async () => {
135
+ const { nextCursor } = await onUpdate({
136
+ cursor: cursors[pagination.pageIndex],
137
+ limit: pagination.pageSize,
138
+ sorting,
139
+ columnFilters,
140
+ globalFilters: globalFilter
141
+ });
142
+ setCursors((c) => nextCursor ? { ...c, [pagination.pageIndex + 1]: nextCursor } : c);
143
+ });
144
+ }, [pagination, sorting, columnFilters, refreshCounter]);
145
+ React.useEffect(() => {
146
+ setPagination((pagination2) => ({ ...pagination2, pageIndex: 0 }));
147
+ setCursors({});
148
+ }, [columnFilters, sorting, pagination.pageSize]);
149
+ React.useEffect(() => {
150
+ const timer = setTimeout(() => {
151
+ setRefreshCounter((x) => x + 1);
152
+ }, 3e3);
153
+ return () => clearTimeout(timer);
154
+ }, [globalFilter]);
155
+ return /* @__PURE__ */ jsx(
156
+ DataTableBase,
157
+ {
158
+ columns,
159
+ data,
160
+ toolbarRender,
161
+ sorting,
162
+ setSorting,
163
+ pagination,
164
+ setPagination,
165
+ columnFilters,
166
+ setColumnFilters,
167
+ rowCount: pagination.pageSize * Object.keys(cursors).length + (cursors[pagination.pageIndex + 1] ? 1 : 0),
168
+ globalFilter,
169
+ setGlobalFilter,
170
+ defaultColumnFilters,
171
+ defaultSorting,
172
+ defaultVisibility,
173
+ showDefaultToolbar,
174
+ onRowClick
175
+ }
176
+ );
177
+ }
178
+ function DataTableBase({
179
+ columns,
180
+ data,
181
+ toolbarRender,
182
+ defaultVisibility,
183
+ sorting,
184
+ setSorting,
185
+ defaultColumnFilters,
186
+ defaultSorting,
187
+ pagination,
188
+ setPagination,
189
+ rowCount,
190
+ columnFilters,
191
+ setColumnFilters,
192
+ globalFilter,
193
+ setGlobalFilter,
194
+ manualPagination = true,
195
+ manualFiltering = true,
196
+ showDefaultToolbar = true,
197
+ onRowClick
198
+ }) {
199
+ const [rowSelection, setRowSelection] = React.useState({});
200
+ const [columnVisibility, setColumnVisibility] = React.useState(defaultVisibility || {});
201
+ const table = useReactTable({
202
+ data,
203
+ columns,
204
+ state: {
205
+ sorting,
206
+ columnVisibility,
207
+ rowSelection,
208
+ columnFilters,
209
+ pagination,
210
+ globalFilter
211
+ },
212
+ enableRowSelection: true,
213
+ onGlobalFilterChange: setGlobalFilter,
214
+ onRowSelectionChange: setRowSelection,
215
+ onSortingChange: setSorting,
216
+ onColumnFiltersChange: setColumnFilters,
217
+ onColumnVisibilityChange: setColumnVisibility,
218
+ onPaginationChange: setPagination,
219
+ getColumnCanGlobalFilter: (c) => c.columnDef.enableGlobalFilter ?? GlobalFiltering.getDefaultOptions(table).getColumnCanGlobalFilter(c),
220
+ getCoreRowModel: getCoreRowModel(),
221
+ getFilteredRowModel: getFilteredRowModel(),
222
+ getPaginationRowModel: getPaginationRowModel(),
223
+ getSortedRowModel: getSortedRowModel(),
224
+ getFacetedRowModel: getFacetedRowModel(),
225
+ getFacetedUniqueValues: getFacetedUniqueValues(),
226
+ autoResetAll: false,
227
+ manualPagination,
228
+ manualFiltering,
229
+ rowCount
230
+ });
231
+ return /* @__PURE__ */ jsx(
232
+ TableView,
233
+ {
234
+ table,
235
+ columns,
236
+ toolbarRender,
237
+ showDefaultToolbar,
238
+ defaultColumnFilters,
239
+ defaultSorting,
240
+ onRowClick
241
+ }
242
+ );
243
+ }
244
+ export {
245
+ DataTable,
246
+ DataTableManualPagination,
247
+ TableView
248
+ };
249
+ //# sourceMappingURL=data-table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/components/data-table/data-table.tsx"],"sourcesContent":["\"use client\";\n\nimport { runAsynchronouslyWithAlert } from \"@stackframe/stack-shared/dist/utils/promises\";\nimport {\n Table,\n TableBody,\n TableCell,\n TableHead,\n TableHeader,\n TableRow,\n} from \"../ui/table\";\nimport {\n ColumnDef,\n ColumnFiltersState,\n GlobalFiltering,\n OnChangeFn,\n PaginationState,\n SortingState,\n Table as TableType,\n VisibilityState,\n flexRender,\n getCoreRowModel,\n getFacetedRowModel,\n getFacetedUniqueValues,\n getFilteredRowModel,\n getPaginationRowModel,\n getSortedRowModel,\n useReactTable,\n} from \"@tanstack/react-table\";\nimport React from \"react\";\nimport { DataTablePagination } from \"./pagination\";\nimport { DataTableToolbar } from \"./toolbar\";\n\nexport function TableView<TData, TValue>(props: {\n table: TableType<TData>,\n columns: ColumnDef<TData, TValue>[],\n toolbarRender?: (table: TableType<TData>) => React.ReactNode,\n showDefaultToolbar?: boolean,\n defaultColumnFilters: ColumnFiltersState,\n defaultSorting: SortingState,\n onRowClick?: (row: TData) => void,\n}) {\n return (\n <div className=\"space-y-4\">\n <DataTableToolbar\n table={props.table}\n toolbarRender={props.toolbarRender}\n showDefaultToolbar={props.showDefaultToolbar}\n defaultColumnFilters={props.defaultColumnFilters}\n defaultSorting={props.defaultSorting}\n />\n <div className=\"rounded-md border\">\n <Table>\n <TableHeader>\n {props.table.getHeaderGroups().map((headerGroup) => (\n <TableRow key={headerGroup.id} >\n {headerGroup.headers.map((header) => {\n return (\n <TableHead key={header.id} colSpan={header.colSpan}>\n {header.isPlaceholder\n ? null\n : flexRender(\n header.column.columnDef.header,\n header.getContext()\n )}\n </TableHead>\n );\n })}\n </TableRow>\n ))}\n </TableHeader>\n <TableBody>\n {props.table.getRowModel().rows.length ? (\n props.table.getRowModel().rows.map((row) => (\n <TableRow\n key={row.id}\n data-state={row.getIsSelected() && \"selected\"}\n onClick={(ev) => {\n // only trigger onRowClick if the element is a direct descendant; don't trigger for portals\n if (ev.target instanceof Node && ev.currentTarget.contains(ev.target)) {\n props.onRowClick?.(row.original);\n }\n }}\n >\n {row.getVisibleCells().map((cell) => (\n <TableCell key={cell.id}>\n {flexRender(\n cell.column.columnDef.cell,\n cell.getContext()\n )}\n </TableCell>\n ))}\n </TableRow>\n ))\n ) : (\n <TableRow>\n <TableCell\n colSpan={props.columns.length}\n className=\"h-24 text-center\"\n >\n No results.\n </TableCell>\n </TableRow>\n )}\n </TableBody>\n </Table>\n </div>\n <DataTablePagination table={props.table} />\n </div>\n );\n}\n\ntype DataTableProps<TData, TValue> = {\n columns: ColumnDef<TData, TValue>[],\n data: TData[],\n toolbarRender?: (table: TableType<TData>) => React.ReactNode,\n defaultVisibility?: VisibilityState,\n defaultColumnFilters: ColumnFiltersState,\n defaultSorting: SortingState,\n showDefaultToolbar?: boolean,\n onRowClick?: (row: TData) => void,\n}\n\nexport function DataTable<TData, TValue>({\n columns,\n data,\n toolbarRender,\n defaultVisibility,\n defaultColumnFilters,\n defaultSorting,\n showDefaultToolbar = true,\n onRowClick,\n}: DataTableProps<TData, TValue>) {\n const [sorting, setSorting] = React.useState<SortingState>(defaultSorting);\n const [columnFilters, setColumnFilters] = React.useState<ColumnFiltersState>(defaultColumnFilters);\n const [pagination, setPagination] = React.useState<PaginationState>({\n pageIndex: 0,\n pageSize: 10,\n });\n const [globalFilter, setGlobalFilter] = React.useState<any>();\n\n return <DataTableBase\n columns={columns}\n data={data}\n toolbarRender={toolbarRender}\n defaultVisibility={defaultVisibility}\n sorting={sorting}\n setSorting={setSorting}\n defaultSorting={defaultSorting}\n columnFilters={columnFilters}\n setColumnFilters={setColumnFilters}\n defaultColumnFilters={defaultColumnFilters}\n manualPagination={false}\n manualFiltering={false}\n pagination={pagination}\n setPagination={setPagination}\n globalFilter={globalFilter}\n setGlobalFilter={setGlobalFilter}\n showDefaultToolbar={showDefaultToolbar}\n onRowClick={onRowClick}\n />;\n}\n\ntype DataTableManualPaginationProps<TData, TValue> = DataTableProps<TData, TValue> & {\n onUpdate: (options: {\n cursor: string,\n limit: number,\n sorting: SortingState,\n columnFilters: ColumnFiltersState,\n globalFilters: any,\n }) => Promise<{ nextCursor: string | null }>,\n}\n\nexport function DataTableManualPagination<TData, TValue>({\n columns,\n data,\n toolbarRender,\n defaultVisibility,\n defaultColumnFilters,\n defaultSorting,\n onRowClick,\n onUpdate,\n showDefaultToolbar = true,\n}: DataTableManualPaginationProps<TData, TValue>) {\n const [sorting, setSorting] = React.useState<SortingState>(defaultSorting);\n const [pagination, setPagination] = React.useState({ pageIndex: 0, pageSize: 10 });\n const [cursors, setCursors] = React.useState<Record<number, string>>({});\n const [columnFilters, setColumnFilters] = React.useState<ColumnFiltersState>(defaultColumnFilters);\n const [globalFilter, setGlobalFilter] = React.useState<any>();\n const [refreshCounter, setRefreshCounter] = React.useState(0);\n\n React.useEffect(() => {\n runAsynchronouslyWithAlert(async () => {\n const { nextCursor } = await onUpdate({\n cursor: cursors[pagination.pageIndex],\n limit: pagination.pageSize,\n sorting,\n columnFilters,\n globalFilters: globalFilter,\n });\n setCursors(c => nextCursor ? { ...c, [pagination.pageIndex + 1]: nextCursor } : c);\n });\n }, [pagination, sorting, columnFilters, refreshCounter]);\n\n // Reset to first page when filters change\n React.useEffect(() => {\n setPagination(pagination => ({ ...pagination, pageIndex: 0 }));\n setCursors({});\n }, [columnFilters, sorting, pagination.pageSize]);\n\n // Refresh the users when the global filter changes. Delay to prevent unnecessary re-renders.\n React.useEffect(() => {\n const timer = setTimeout(() => {\n setRefreshCounter(x => x + 1);\n }, 3_000);\n return () => clearTimeout(timer);\n }, [globalFilter]);\n\n return <DataTableBase\n columns={columns}\n data={data}\n toolbarRender={toolbarRender}\n sorting={sorting}\n setSorting={setSorting}\n pagination={pagination}\n setPagination={setPagination}\n columnFilters={columnFilters}\n setColumnFilters={setColumnFilters}\n rowCount={pagination.pageSize * Object.keys(cursors).length + (cursors[pagination.pageIndex + 1] ? 1 : 0)}\n globalFilter={globalFilter}\n setGlobalFilter={setGlobalFilter}\n defaultColumnFilters={defaultColumnFilters}\n defaultSorting={defaultSorting}\n defaultVisibility={defaultVisibility}\n showDefaultToolbar={showDefaultToolbar}\n onRowClick={onRowClick}\n />;\n}\n\ntype DataTableBaseProps<TData, TValue> = DataTableProps<TData, TValue> & {\n sorting?: SortingState,\n setSorting?: OnChangeFn<SortingState>,\n pagination?: PaginationState,\n setPagination?: OnChangeFn<PaginationState>,\n rowCount?: number,\n columnFilters?: ColumnFiltersState,\n setColumnFilters?: OnChangeFn<ColumnFiltersState>,\n manualPagination?: boolean,\n manualFiltering?: boolean,\n globalFilter?: any,\n setGlobalFilter?: OnChangeFn<any>,\n}\n\nfunction DataTableBase<TData, TValue>({\n columns,\n data,\n toolbarRender,\n defaultVisibility,\n sorting,\n setSorting,\n defaultColumnFilters,\n defaultSorting,\n pagination,\n setPagination,\n rowCount,\n columnFilters,\n setColumnFilters,\n globalFilter,\n setGlobalFilter,\n manualPagination = true,\n manualFiltering = true,\n showDefaultToolbar = true,\n onRowClick,\n}: DataTableBaseProps<TData, TValue>) {\n const [rowSelection, setRowSelection] = React.useState({});\n const [columnVisibility, setColumnVisibility] = React.useState<VisibilityState>(defaultVisibility || {});\n\n const table: TableType<TData> = useReactTable({\n data,\n columns,\n state: {\n sorting,\n columnVisibility,\n rowSelection,\n columnFilters,\n pagination,\n globalFilter: globalFilter,\n },\n enableRowSelection: true,\n onGlobalFilterChange: setGlobalFilter,\n onRowSelectionChange: setRowSelection,\n onSortingChange: setSorting,\n onColumnFiltersChange: setColumnFilters,\n onColumnVisibilityChange: setColumnVisibility,\n onPaginationChange: setPagination,\n getColumnCanGlobalFilter: (c) => c.columnDef.enableGlobalFilter ?? GlobalFiltering.getDefaultOptions!(table).getColumnCanGlobalFilter!(c),\n getCoreRowModel: getCoreRowModel(),\n getFilteredRowModel: getFilteredRowModel(),\n getPaginationRowModel: getPaginationRowModel(),\n getSortedRowModel: getSortedRowModel(),\n getFacetedRowModel: getFacetedRowModel(),\n getFacetedUniqueValues: getFacetedUniqueValues(),\n autoResetAll: false,\n manualPagination,\n manualFiltering,\n rowCount,\n });\n\n return <TableView\n table={table}\n columns={columns}\n toolbarRender={toolbarRender}\n showDefaultToolbar={showDefaultToolbar}\n defaultColumnFilters={defaultColumnFilters}\n defaultSorting={defaultSorting}\n onRowClick={onRowClick}\n />;\n}\n"],"mappings":"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","names":["pagination"]}
@@ -0,0 +1,117 @@
1
+ // src/components/data-table/faceted-filter.tsx
2
+ import { CheckIcon } from "@radix-ui/react-icons";
3
+ import { Badge } from "../ui/badge.js";
4
+ import { Button } from "../ui/button.js";
5
+ import {
6
+ Command,
7
+ CommandEmpty,
8
+ CommandGroup,
9
+ CommandInput,
10
+ CommandItem,
11
+ CommandList,
12
+ CommandSeparator
13
+ } from "../ui/command.js";
14
+ import { Popover, PopoverContent, PopoverTrigger } from "../ui/popover.js";
15
+ import { Separator } from "../ui/separator.js";
16
+ import { ListFilter } from "lucide-react";
17
+ import { cn } from "../../lib/utils.js";
18
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
19
+ function DataTableFacetedFilter({
20
+ column,
21
+ title,
22
+ options
23
+ }) {
24
+ const facets = column?.getFacetedUniqueValues();
25
+ const selectedValues = new Set(column?.getFilterValue());
26
+ return /* @__PURE__ */ jsxs(Popover, { children: [
27
+ /* @__PURE__ */ jsx(PopoverTrigger, { asChild: true, children: /* @__PURE__ */ jsxs(Button, { variant: "outline", size: "sm", className: "h-8 border", children: [
28
+ /* @__PURE__ */ jsx(ListFilter, { className: "mr-2 h-4 w-4 text-gray-500" }),
29
+ title,
30
+ selectedValues.size > 0 && /* @__PURE__ */ jsxs(Fragment, { children: [
31
+ /* @__PURE__ */ jsx(Separator, { orientation: "vertical", className: "mx-2 h-4" }),
32
+ /* @__PURE__ */ jsx(
33
+ Badge,
34
+ {
35
+ variant: "secondary",
36
+ className: "rounded-sm px-1 font-normal lg:hidden",
37
+ children: selectedValues.size
38
+ }
39
+ ),
40
+ /* @__PURE__ */ jsx("div", { className: "hidden space-x-1 lg:flex", children: selectedValues.size > 2 ? /* @__PURE__ */ jsxs(
41
+ Badge,
42
+ {
43
+ variant: "secondary",
44
+ className: "rounded-sm px-1 font-normal",
45
+ children: [
46
+ selectedValues.size,
47
+ " selected"
48
+ ]
49
+ }
50
+ ) : options.filter((option) => selectedValues.has(option.value)).map((option) => /* @__PURE__ */ jsx(
51
+ Badge,
52
+ {
53
+ variant: "secondary",
54
+ className: "rounded-sm px-1 font-normal",
55
+ children: option.label
56
+ },
57
+ option.value
58
+ )) })
59
+ ] })
60
+ ] }) }),
61
+ /* @__PURE__ */ jsx(PopoverContent, { className: "w-[200px] p-0", align: "start", children: /* @__PURE__ */ jsxs(Command, { children: [
62
+ /* @__PURE__ */ jsx(CommandInput, { placeholder: title }),
63
+ /* @__PURE__ */ jsxs(CommandList, { children: [
64
+ /* @__PURE__ */ jsx(CommandEmpty, { children: "No results found." }),
65
+ /* @__PURE__ */ jsx(CommandGroup, { children: options.map((option) => {
66
+ const isSelected = selectedValues.has(option.value);
67
+ return /* @__PURE__ */ jsxs(
68
+ CommandItem,
69
+ {
70
+ onSelect: () => {
71
+ if (isSelected) {
72
+ selectedValues.delete(option.value);
73
+ } else {
74
+ selectedValues.add(option.value);
75
+ }
76
+ const filterValues = Array.from(selectedValues);
77
+ column?.setFilterValue(
78
+ filterValues.length ? filterValues : void 0
79
+ );
80
+ },
81
+ children: [
82
+ /* @__PURE__ */ jsx(
83
+ "div",
84
+ {
85
+ className: cn(
86
+ "mr-2 flex h-4 w-4 items-center justify-center rounded-sm border border-primary",
87
+ isSelected ? "bg-primary text-primary-foreground" : "opacity-50 [&_svg]:invisible"
88
+ ),
89
+ children: /* @__PURE__ */ jsx(CheckIcon, { className: cn("h-4 w-4") })
90
+ }
91
+ ),
92
+ option.icon && /* @__PURE__ */ jsx(option.icon, { className: "mr-2 h-4 w-4 text-muted-foreground" }),
93
+ /* @__PURE__ */ jsx("span", { children: option.label })
94
+ ]
95
+ },
96
+ option.value
97
+ );
98
+ }) }),
99
+ selectedValues.size > 0 && /* @__PURE__ */ jsxs(Fragment, { children: [
100
+ /* @__PURE__ */ jsx(CommandSeparator, {}),
101
+ /* @__PURE__ */ jsx(CommandGroup, { children: /* @__PURE__ */ jsx(
102
+ CommandItem,
103
+ {
104
+ onSelect: () => column?.setFilterValue(void 0),
105
+ className: "justify-center text-center",
106
+ children: "Clear filters"
107
+ }
108
+ ) })
109
+ ] })
110
+ ] })
111
+ ] }) })
112
+ ] });
113
+ }
114
+ export {
115
+ DataTableFacetedFilter
116
+ };
117
+ //# sourceMappingURL=faceted-filter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/components/data-table/faceted-filter.tsx"],"sourcesContent":["import { CheckIcon } from \"@radix-ui/react-icons\";\nimport { Badge } from \"../ui/badge\";\nimport { Button } from \"../ui/button\";\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n CommandSeparator,\n} from \"../ui/command\";\nimport { Popover, PopoverContent, PopoverTrigger } from \"../ui/popover\";\nimport { Separator } from \"../ui/separator\";\nimport { Column } from \"@tanstack/react-table\";\nimport { ListFilter } from \"lucide-react\";\nimport React from \"react\";\nimport { cn } from \"../../lib/utils\";\n\ntype DataTableFacetedFilterProps<TData, TValue> = {\n column?: Column<TData, TValue>,\n title?: string,\n options: {\n label: string,\n value: string,\n icon?: React.ComponentType<{ className?: string }>,\n }[],\n}\n\nexport function DataTableFacetedFilter<TData, TValue>({\n column,\n title,\n options,\n}: DataTableFacetedFilterProps<TData, TValue>) {\n const facets = column?.getFacetedUniqueValues();\n const selectedValues = new Set(column?.getFilterValue() as string[]);\n\n return (\n <Popover>\n <PopoverTrigger asChild>\n <Button variant=\"outline\" size=\"sm\" className=\"h-8 border\">\n <ListFilter className=\"mr-2 h-4 w-4 text-gray-500\" />\n {title}\n {selectedValues.size > 0 && (\n <>\n <Separator orientation=\"vertical\" className=\"mx-2 h-4\" />\n <Badge\n variant=\"secondary\"\n className=\"rounded-sm px-1 font-normal lg:hidden\"\n >\n {selectedValues.size}\n </Badge>\n <div className=\"hidden space-x-1 lg:flex\">\n {selectedValues.size > 2 ? (\n <Badge\n variant=\"secondary\"\n className=\"rounded-sm px-1 font-normal\"\n >\n {selectedValues.size} selected\n </Badge>\n ) : (\n options\n .filter((option) => selectedValues.has(option.value))\n .map((option) => (\n <Badge\n variant=\"secondary\"\n key={option.value}\n className=\"rounded-sm px-1 font-normal\"\n >\n {option.label}\n </Badge>\n ))\n )}\n </div>\n </>\n )}\n </Button>\n </PopoverTrigger>\n <PopoverContent className=\"w-[200px] p-0\" align=\"start\">\n <Command>\n <CommandInput placeholder={title} />\n <CommandList>\n <CommandEmpty>No results found.</CommandEmpty>\n <CommandGroup>\n {options.map((option) => {\n const isSelected = selectedValues.has(option.value);\n return (\n <CommandItem\n key={option.value}\n onSelect={() => {\n if (isSelected) {\n selectedValues.delete(option.value);\n } else {\n selectedValues.add(option.value);\n }\n const filterValues = Array.from(selectedValues);\n column?.setFilterValue(\n filterValues.length ? filterValues : undefined\n );\n }}\n >\n <div\n className={cn(\n \"mr-2 flex h-4 w-4 items-center justify-center rounded-sm border border-primary\",\n isSelected\n ? \"bg-primary text-primary-foreground\"\n : \"opacity-50 [&_svg]:invisible\"\n )}\n >\n <CheckIcon className={cn(\"h-4 w-4\")} />\n </div>\n {option.icon && (\n <option.icon className=\"mr-2 h-4 w-4 text-muted-foreground\" />\n )}\n <span>{option.label}</span>\n </CommandItem>\n );\n })}\n </CommandGroup>\n {selectedValues.size > 0 && (\n <>\n <CommandSeparator />\n <CommandGroup>\n <CommandItem\n onSelect={() => column?.setFilterValue(undefined)}\n className=\"justify-center text-center\"\n >\n Clear filters\n </CommandItem>\n </CommandGroup>\n </>\n )}\n </CommandList>\n </Command>\n </PopoverContent>\n </Popover>\n );\n}\n"],"mappings":";AAAA,SAAS,iBAAiB;AAC1B,SAAS,aAAa;AACtB,SAAS,cAAc;AACvB;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,SAAS,gBAAgB,sBAAsB;AACxD,SAAS,iBAAiB;AAE1B,SAAS,kBAAkB;AAE3B,SAAS,UAAU;AAwBT,SAGE,UAHF,KAaQ,YAbR;AAZH,SAAS,uBAAsC;AAAA,EACpD;AAAA,EACA;AAAA,EACA;AACF,GAA+C;AAC7C,QAAM,SAAS,QAAQ,uBAAuB;AAC9C,QAAM,iBAAiB,IAAI,IAAI,QAAQ,eAAe,CAAa;AAEnE,SACE,qBAAC,WACC;AAAA,wBAAC,kBAAe,SAAO,MACrB,+BAAC,UAAO,SAAQ,WAAU,MAAK,MAAK,WAAU,cAC5C;AAAA,0BAAC,cAAW,WAAU,8BAA6B;AAAA,MAClD;AAAA,MACA,eAAe,OAAO,KACrB,iCACE;AAAA,4BAAC,aAAU,aAAY,YAAW,WAAU,YAAW;AAAA,QACvD;AAAA,UAAC;AAAA;AAAA,YACC,SAAQ;AAAA,YACR,WAAU;AAAA,YAET,yBAAe;AAAA;AAAA,QAClB;AAAA,QACA,oBAAC,SAAI,WAAU,4BACZ,yBAAe,OAAO,IACrB;AAAA,UAAC;AAAA;AAAA,YACC,SAAQ;AAAA,YACR,WAAU;AAAA,YAET;AAAA,6BAAe;AAAA,cAAK;AAAA;AAAA;AAAA,QACvB,IAEA,QACG,OAAO,CAAC,WAAW,eAAe,IAAI,OAAO,KAAK,CAAC,EACnD,IAAI,CAAC,WACJ;AAAA,UAAC;AAAA;AAAA,YACC,SAAQ;AAAA,YAER,WAAU;AAAA,YAET,iBAAO;AAAA;AAAA,UAHH,OAAO;AAAA,QAId,CACD,GAEP;AAAA,SACF;AAAA,OAEJ,GACF;AAAA,IACA,oBAAC,kBAAe,WAAU,iBAAgB,OAAM,SAC9C,+BAAC,WACC;AAAA,0BAAC,gBAAa,aAAa,OAAO;AAAA,MAClC,qBAAC,eACC;AAAA,4BAAC,gBAAa,+BAAiB;AAAA,QAC/B,oBAAC,gBACE,kBAAQ,IAAI,CAAC,WAAW;AACvB,gBAAM,aAAa,eAAe,IAAI,OAAO,KAAK;AAClD,iBACE;AAAA,YAAC;AAAA;AAAA,cAEC,UAAU,MAAM;AACd,oBAAI,YAAY;AACd,iCAAe,OAAO,OAAO,KAAK;AAAA,gBACpC,OAAO;AACL,iCAAe,IAAI,OAAO,KAAK;AAAA,gBACjC;AACA,sBAAM,eAAe,MAAM,KAAK,cAAc;AAC9C,wBAAQ;AAAA,kBACN,aAAa,SAAS,eAAe;AAAA,gBACvC;AAAA,cACF;AAAA,cAEA;AAAA;AAAA,kBAAC;AAAA;AAAA,oBACC,WAAW;AAAA,sBACT;AAAA,sBACA,aACI,uCACA;AAAA,oBACN;AAAA,oBAEA,8BAAC,aAAU,WAAW,GAAG,SAAS,GAAG;AAAA;AAAA,gBACvC;AAAA,gBACC,OAAO,QACN,oBAAC,OAAO,MAAP,EAAY,WAAU,sCAAqC;AAAA,gBAE9D,oBAAC,UAAM,iBAAO,OAAM;AAAA;AAAA;AAAA,YA1Bf,OAAO;AAAA,UA2Bd;AAAA,QAEJ,CAAC,GACH;AAAA,QACC,eAAe,OAAO,KACrB,iCACE;AAAA,8BAAC,oBAAiB;AAAA,UAClB,oBAAC,gBACC;AAAA,YAAC;AAAA;AAAA,cACC,UAAU,MAAM,QAAQ,eAAe,MAAS;AAAA,cAChD,WAAU;AAAA,cACX;AAAA;AAAA,UAED,GACF;AAAA,WACF;AAAA,SAEJ;AAAA,OACF,GACF;AAAA,KACF;AAEJ;","names":[]}
@@ -0,0 +1,11 @@
1
+ // src/components/data-table/index.tsx
2
+ export * from "./cells.js";
3
+ export * from "./column-header.js";
4
+ export * from "./data-table.js";
5
+ export * from "./faceted-filter.js";
6
+ export * from "./pagination.js";
7
+ export * from "./toolbar-items.js";
8
+ export * from "./toolbar.js";
9
+ export * from "./utils.js";
10
+ export * from "./view-options.js";
11
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/components/data-table/index.tsx"],"sourcesContent":["export * from \"./cells\";\nexport * from \"./column-header\";\nexport * from \"./data-table\";\nexport * from \"./faceted-filter\";\nexport * from \"./pagination\";\nexport * from \"./toolbar-items\";\nexport * from \"./toolbar\";\nexport * from \"./utils\";\nexport * from \"./view-options\";\n"],"mappings":";AAAA,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;","names":[]}