@stackframe/stack-ui 2.8.61 → 2.8.62

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
@@ -1,98 +1,268 @@
1
1
  "use client";
2
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
- import { runAsynchronouslyWithAlert } from "@stackframe/stack-shared/dist/utils/promises";
4
- import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow, } from "@stackframe/stack-ui";
5
- import { GlobalFiltering, flexRender, getCoreRowModel, getFacetedRowModel, getFacetedUniqueValues, getFilteredRowModel, getPaginationRowModel, getSortedRowModel, useReactTable, } from "@tanstack/react-table";
6
- import React from "react";
7
- import { DataTablePagination } from "./pagination";
8
- import { DataTableToolbar } from "./toolbar";
9
- export function TableView(props) {
10
- return (_jsxs("div", { className: "space-y-4", children: [_jsx(DataTableToolbar, { table: props.table, toolbarRender: props.toolbarRender, showDefaultToolbar: props.showDefaultToolbar, defaultColumnFilters: props.defaultColumnFilters, defaultSorting: props.defaultSorting }), _jsx("div", { className: "rounded-md border", children: _jsxs(Table, { children: [_jsx(TableHeader, { children: props.table.getHeaderGroups().map((headerGroup) => (_jsx(TableRow, { children: headerGroup.headers.map((header) => {
11
- return (_jsx(TableHead, { colSpan: header.colSpan, children: header.isPlaceholder
12
- ? null
13
- : flexRender(header.column.columnDef.header, header.getContext()) }, header.id));
14
- }) }, headerGroup.id))) }), _jsx(TableBody, { children: props.table.getRowModel().rows.length ? (props.table.getRowModel().rows.map((row) => (_jsx(TableRow, { "data-state": row.getIsSelected() && "selected", onClick: (ev) => {
15
- // only trigger onRowClick if the element is a direct descendant; don't trigger for portals
16
- if (ev.target instanceof Node && ev.currentTarget.contains(ev.target)) {
17
- props.onRowClick?.(row.original);
18
- }
19
- }, children: row.getVisibleCells().map((cell) => (_jsx(TableCell, { children: flexRender(cell.column.columnDef.cell, cell.getContext()) }, cell.id))) }, row.id)))) : (_jsx(TableRow, { children: _jsx(TableCell, { colSpan: props.columns.length, className: "h-24 text-center", children: "No results." }) })) })] }) }), _jsx(DataTablePagination, { table: props.table })] }));
20
- }
21
- export function DataTable({ columns, data, toolbarRender, defaultVisibility, defaultColumnFilters, defaultSorting, showDefaultToolbar = true, onRowClick, }) {
22
- const [sorting, setSorting] = React.useState(defaultSorting);
23
- const [columnFilters, setColumnFilters] = React.useState(defaultColumnFilters);
24
- const [pagination, setPagination] = React.useState({
25
- pageIndex: 0,
26
- pageSize: 10,
27
- });
28
- const [globalFilter, setGlobalFilter] = React.useState();
29
- return _jsx(DataTableBase, { columns: columns, data: data, toolbarRender: toolbarRender, defaultVisibility: defaultVisibility, sorting: sorting, setSorting: setSorting, defaultSorting: defaultSorting, columnFilters: columnFilters, setColumnFilters: setColumnFilters, defaultColumnFilters: defaultColumnFilters, manualPagination: false, manualFiltering: false, pagination: pagination, setPagination: setPagination, globalFilter: globalFilter, setGlobalFilter: setGlobalFilter, showDefaultToolbar: showDefaultToolbar, onRowClick: onRowClick });
2
+ "use strict";
3
+ "use client";
4
+ var __create = Object.create;
5
+ var __defProp = Object.defineProperty;
6
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
7
+ var __getOwnPropNames = Object.getOwnPropertyNames;
8
+ var __getProtoOf = Object.getPrototypeOf;
9
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
10
+ var __export = (target, all) => {
11
+ for (var name in all)
12
+ __defProp(target, name, { get: all[name], enumerable: true });
13
+ };
14
+ var __copyProps = (to, from, except, desc) => {
15
+ if (from && typeof from === "object" || typeof from === "function") {
16
+ for (let key of __getOwnPropNames(from))
17
+ if (!__hasOwnProp.call(to, key) && key !== except)
18
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
19
+ }
20
+ return to;
21
+ };
22
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
23
+ // If the importer is in node compatibility mode or this is not an ESM
24
+ // file that has been converted to a CommonJS file using a Babel-
25
+ // compatible transform (i.e. "__esModule" has not been set), then set
26
+ // "default" to the CommonJS "module.exports" for node compatibility.
27
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
28
+ mod
29
+ ));
30
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
31
+
32
+ // src/components/data-table/data-table.tsx
33
+ var data_table_exports = {};
34
+ __export(data_table_exports, {
35
+ DataTable: () => DataTable,
36
+ DataTableManualPagination: () => DataTableManualPagination,
37
+ TableView: () => TableView
38
+ });
39
+ module.exports = __toCommonJS(data_table_exports);
40
+ var import_promises = require("@stackframe/stack-shared/dist/utils/promises");
41
+ var import_table = require("../ui/table.js");
42
+ var import_react_table = require("@tanstack/react-table");
43
+ var import_react = __toESM(require("react"));
44
+ var import_pagination = require("./pagination.js");
45
+ var import_toolbar = require("./toolbar.js");
46
+ var import_jsx_runtime = require("react/jsx-runtime");
47
+ function TableView(props) {
48
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: "space-y-4", children: [
49
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
50
+ import_toolbar.DataTableToolbar,
51
+ {
52
+ table: props.table,
53
+ toolbarRender: props.toolbarRender,
54
+ showDefaultToolbar: props.showDefaultToolbar,
55
+ defaultColumnFilters: props.defaultColumnFilters,
56
+ defaultSorting: props.defaultSorting
57
+ }
58
+ ),
59
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: "rounded-md border", children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_table.Table, { children: [
60
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_table.TableHeader, { children: props.table.getHeaderGroups().map((headerGroup) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_table.TableRow, { children: headerGroup.headers.map((header) => {
61
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_table.TableHead, { colSpan: header.colSpan, children: header.isPlaceholder ? null : (0, import_react_table.flexRender)(
62
+ header.column.columnDef.header,
63
+ header.getContext()
64
+ ) }, header.id);
65
+ }) }, headerGroup.id)) }),
66
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_table.TableBody, { children: props.table.getRowModel().rows.length ? props.table.getRowModel().rows.map((row) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
67
+ import_table.TableRow,
68
+ {
69
+ "data-state": row.getIsSelected() && "selected",
70
+ onClick: (ev) => {
71
+ if (ev.target instanceof Node && ev.currentTarget.contains(ev.target)) {
72
+ props.onRowClick?.(row.original);
73
+ }
74
+ },
75
+ children: row.getVisibleCells().map((cell) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_table.TableCell, { children: (0, import_react_table.flexRender)(
76
+ cell.column.columnDef.cell,
77
+ cell.getContext()
78
+ ) }, cell.id))
79
+ },
80
+ row.id
81
+ )) : /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_table.TableRow, { children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
82
+ import_table.TableCell,
83
+ {
84
+ colSpan: props.columns.length,
85
+ className: "h-24 text-center",
86
+ children: "No results."
87
+ }
88
+ ) }) })
89
+ ] }) }),
90
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_pagination.DataTablePagination, { table: props.table })
91
+ ] });
30
92
  }
31
- export function DataTableManualPagination({ columns, data, toolbarRender, defaultVisibility, defaultColumnFilters, defaultSorting, onRowClick, onUpdate, showDefaultToolbar = true, }) {
32
- const [sorting, setSorting] = React.useState(defaultSorting);
33
- const [pagination, setPagination] = React.useState({ pageIndex: 0, pageSize: 10 });
34
- const [cursors, setCursors] = React.useState({});
35
- const [columnFilters, setColumnFilters] = React.useState(defaultColumnFilters);
36
- const [globalFilter, setGlobalFilter] = React.useState();
37
- const [refreshCounter, setRefreshCounter] = React.useState(0);
38
- React.useEffect(() => {
39
- runAsynchronouslyWithAlert(async () => {
40
- const { nextCursor } = await onUpdate({
41
- cursor: cursors[pagination.pageIndex],
42
- limit: pagination.pageSize,
43
- sorting,
44
- columnFilters,
45
- globalFilters: globalFilter,
46
- });
47
- setCursors(c => nextCursor ? { ...c, [pagination.pageIndex + 1]: nextCursor } : c);
48
- });
49
- }, [pagination, sorting, columnFilters, refreshCounter]);
50
- // Reset to first page when filters change
51
- React.useEffect(() => {
52
- setPagination(pagination => ({ ...pagination, pageIndex: 0 }));
53
- setCursors({});
54
- }, [columnFilters, sorting, pagination.pageSize]);
55
- // Refresh the users when the global filter changes. Delay to prevent unnecessary re-renders.
56
- React.useEffect(() => {
57
- const timer = setTimeout(() => {
58
- setRefreshCounter(x => x + 1);
59
- }, 3000);
60
- return () => clearTimeout(timer);
61
- }, [globalFilter]);
62
- return _jsx(DataTableBase, { columns: columns, data: data, toolbarRender: toolbarRender, sorting: sorting, setSorting: setSorting, pagination: pagination, setPagination: setPagination, columnFilters: columnFilters, setColumnFilters: setColumnFilters, rowCount: pagination.pageSize * Object.keys(cursors).length + (cursors[pagination.pageIndex + 1] ? 1 : 0), globalFilter: globalFilter, setGlobalFilter: setGlobalFilter, defaultColumnFilters: defaultColumnFilters, defaultSorting: defaultSorting, defaultVisibility: defaultVisibility, showDefaultToolbar: showDefaultToolbar, onRowClick: onRowClick });
93
+ function DataTable({
94
+ columns,
95
+ data,
96
+ toolbarRender,
97
+ defaultVisibility,
98
+ defaultColumnFilters,
99
+ defaultSorting,
100
+ showDefaultToolbar = true,
101
+ onRowClick
102
+ }) {
103
+ const [sorting, setSorting] = import_react.default.useState(defaultSorting);
104
+ const [columnFilters, setColumnFilters] = import_react.default.useState(defaultColumnFilters);
105
+ const [pagination, setPagination] = import_react.default.useState({
106
+ pageIndex: 0,
107
+ pageSize: 10
108
+ });
109
+ const [globalFilter, setGlobalFilter] = import_react.default.useState();
110
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
111
+ DataTableBase,
112
+ {
113
+ columns,
114
+ data,
115
+ toolbarRender,
116
+ defaultVisibility,
117
+ sorting,
118
+ setSorting,
119
+ defaultSorting,
120
+ columnFilters,
121
+ setColumnFilters,
122
+ defaultColumnFilters,
123
+ manualPagination: false,
124
+ manualFiltering: false,
125
+ pagination,
126
+ setPagination,
127
+ globalFilter,
128
+ setGlobalFilter,
129
+ showDefaultToolbar,
130
+ onRowClick
131
+ }
132
+ );
63
133
  }
64
- function DataTableBase({ columns, data, toolbarRender, defaultVisibility, sorting, setSorting, defaultColumnFilters, defaultSorting, pagination, setPagination, rowCount, columnFilters, setColumnFilters, globalFilter, setGlobalFilter, manualPagination = true, manualFiltering = true, showDefaultToolbar = true, onRowClick, }) {
65
- const [rowSelection, setRowSelection] = React.useState({});
66
- const [columnVisibility, setColumnVisibility] = React.useState(defaultVisibility || {});
67
- const table = useReactTable({
68
- data,
69
- columns,
70
- state: {
71
- sorting,
72
- columnVisibility,
73
- rowSelection,
74
- columnFilters,
75
- pagination,
76
- globalFilter: globalFilter,
77
- },
78
- enableRowSelection: true,
79
- onGlobalFilterChange: setGlobalFilter,
80
- onRowSelectionChange: setRowSelection,
81
- onSortingChange: setSorting,
82
- onColumnFiltersChange: setColumnFilters,
83
- onColumnVisibilityChange: setColumnVisibility,
84
- onPaginationChange: setPagination,
85
- getColumnCanGlobalFilter: (c) => c.columnDef.enableGlobalFilter ?? GlobalFiltering.getDefaultOptions(table).getColumnCanGlobalFilter(c),
86
- getCoreRowModel: getCoreRowModel(),
87
- getFilteredRowModel: getFilteredRowModel(),
88
- getPaginationRowModel: getPaginationRowModel(),
89
- getSortedRowModel: getSortedRowModel(),
90
- getFacetedRowModel: getFacetedRowModel(),
91
- getFacetedUniqueValues: getFacetedUniqueValues(),
92
- autoResetAll: false,
93
- manualPagination,
94
- manualFiltering,
95
- rowCount,
134
+ function DataTableManualPagination({
135
+ columns,
136
+ data,
137
+ toolbarRender,
138
+ defaultVisibility,
139
+ defaultColumnFilters,
140
+ defaultSorting,
141
+ onRowClick,
142
+ onUpdate,
143
+ showDefaultToolbar = true
144
+ }) {
145
+ const [sorting, setSorting] = import_react.default.useState(defaultSorting);
146
+ const [pagination, setPagination] = import_react.default.useState({ pageIndex: 0, pageSize: 10 });
147
+ const [cursors, setCursors] = import_react.default.useState({});
148
+ const [columnFilters, setColumnFilters] = import_react.default.useState(defaultColumnFilters);
149
+ const [globalFilter, setGlobalFilter] = import_react.default.useState();
150
+ const [refreshCounter, setRefreshCounter] = import_react.default.useState(0);
151
+ import_react.default.useEffect(() => {
152
+ (0, import_promises.runAsynchronouslyWithAlert)(async () => {
153
+ const { nextCursor } = await onUpdate({
154
+ cursor: cursors[pagination.pageIndex],
155
+ limit: pagination.pageSize,
156
+ sorting,
157
+ columnFilters,
158
+ globalFilters: globalFilter
159
+ });
160
+ setCursors((c) => nextCursor ? { ...c, [pagination.pageIndex + 1]: nextCursor } : c);
96
161
  });
97
- return _jsx(TableView, { table: table, columns: columns, toolbarRender: toolbarRender, showDefaultToolbar: showDefaultToolbar, defaultColumnFilters: defaultColumnFilters, defaultSorting: defaultSorting, onRowClick: onRowClick });
162
+ }, [pagination, sorting, columnFilters, refreshCounter]);
163
+ import_react.default.useEffect(() => {
164
+ setPagination((pagination2) => ({ ...pagination2, pageIndex: 0 }));
165
+ setCursors({});
166
+ }, [columnFilters, sorting, pagination.pageSize]);
167
+ import_react.default.useEffect(() => {
168
+ const timer = setTimeout(() => {
169
+ setRefreshCounter((x) => x + 1);
170
+ }, 3e3);
171
+ return () => clearTimeout(timer);
172
+ }, [globalFilter]);
173
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
174
+ DataTableBase,
175
+ {
176
+ columns,
177
+ data,
178
+ toolbarRender,
179
+ sorting,
180
+ setSorting,
181
+ pagination,
182
+ setPagination,
183
+ columnFilters,
184
+ setColumnFilters,
185
+ rowCount: pagination.pageSize * Object.keys(cursors).length + (cursors[pagination.pageIndex + 1] ? 1 : 0),
186
+ globalFilter,
187
+ setGlobalFilter,
188
+ defaultColumnFilters,
189
+ defaultSorting,
190
+ defaultVisibility,
191
+ showDefaultToolbar,
192
+ onRowClick
193
+ }
194
+ );
195
+ }
196
+ function DataTableBase({
197
+ columns,
198
+ data,
199
+ toolbarRender,
200
+ defaultVisibility,
201
+ sorting,
202
+ setSorting,
203
+ defaultColumnFilters,
204
+ defaultSorting,
205
+ pagination,
206
+ setPagination,
207
+ rowCount,
208
+ columnFilters,
209
+ setColumnFilters,
210
+ globalFilter,
211
+ setGlobalFilter,
212
+ manualPagination = true,
213
+ manualFiltering = true,
214
+ showDefaultToolbar = true,
215
+ onRowClick
216
+ }) {
217
+ const [rowSelection, setRowSelection] = import_react.default.useState({});
218
+ const [columnVisibility, setColumnVisibility] = import_react.default.useState(defaultVisibility || {});
219
+ const table = (0, import_react_table.useReactTable)({
220
+ data,
221
+ columns,
222
+ state: {
223
+ sorting,
224
+ columnVisibility,
225
+ rowSelection,
226
+ columnFilters,
227
+ pagination,
228
+ globalFilter
229
+ },
230
+ enableRowSelection: true,
231
+ onGlobalFilterChange: setGlobalFilter,
232
+ onRowSelectionChange: setRowSelection,
233
+ onSortingChange: setSorting,
234
+ onColumnFiltersChange: setColumnFilters,
235
+ onColumnVisibilityChange: setColumnVisibility,
236
+ onPaginationChange: setPagination,
237
+ getColumnCanGlobalFilter: (c) => c.columnDef.enableGlobalFilter ?? import_react_table.GlobalFiltering.getDefaultOptions(table).getColumnCanGlobalFilter(c),
238
+ getCoreRowModel: (0, import_react_table.getCoreRowModel)(),
239
+ getFilteredRowModel: (0, import_react_table.getFilteredRowModel)(),
240
+ getPaginationRowModel: (0, import_react_table.getPaginationRowModel)(),
241
+ getSortedRowModel: (0, import_react_table.getSortedRowModel)(),
242
+ getFacetedRowModel: (0, import_react_table.getFacetedRowModel)(),
243
+ getFacetedUniqueValues: (0, import_react_table.getFacetedUniqueValues)(),
244
+ autoResetAll: false,
245
+ manualPagination,
246
+ manualFiltering,
247
+ rowCount
248
+ });
249
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
250
+ TableView,
251
+ {
252
+ table,
253
+ columns,
254
+ toolbarRender,
255
+ showDefaultToolbar,
256
+ defaultColumnFilters,
257
+ defaultSorting,
258
+ onRowClick
259
+ }
260
+ );
98
261
  }
262
+ // Annotate the CommonJS export names for ESM import in node:
263
+ 0 && (module.exports = {
264
+ DataTable,
265
+ DataTableManualPagination,
266
+ TableView
267
+ });
268
+ //# 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":["React","pagination"]}
@@ -1,26 +1,134 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
- import { CheckIcon } from "@radix-ui/react-icons";
3
- import { Badge, Button, Command, CommandEmpty, CommandGroup, CommandInput, CommandItem, CommandList, CommandSeparator, Popover, PopoverContent, PopoverTrigger, Separator } from "@stackframe/stack-ui";
4
- import { ListFilter } from "lucide-react";
5
- import { cn } from "../../lib/utils";
6
- export function DataTableFacetedFilter({ column, title, options, }) {
7
- const facets = column?.getFacetedUniqueValues();
8
- const selectedValues = new Set(column?.getFilterValue());
9
- return (_jsxs(Popover, { children: [_jsx(PopoverTrigger, { asChild: true, children: _jsxs(Button, { variant: "outline", size: "sm", className: "h-8 border", children: [_jsx(ListFilter, { className: "mr-2 h-4 w-4 text-gray-500" }), title, selectedValues.size > 0 && (_jsxs(_Fragment, { children: [_jsx(Separator, { orientation: "vertical", className: "mx-2 h-4" }), _jsx(Badge, { variant: "secondary", className: "rounded-sm px-1 font-normal lg:hidden", children: selectedValues.size }), _jsx("div", { className: "hidden space-x-1 lg:flex", children: selectedValues.size > 2 ? (_jsxs(Badge, { variant: "secondary", className: "rounded-sm px-1 font-normal", children: [selectedValues.size, " selected"] })) : (options
10
- .filter((option) => selectedValues.has(option.value))
11
- .map((option) => (_jsx(Badge, { variant: "secondary", className: "rounded-sm px-1 font-normal", children: option.label }, option.value)))) })] }))] }) }), _jsx(PopoverContent, { className: "w-[200px] p-0", align: "start", children: _jsxs(Command, { children: [_jsx(CommandInput, { placeholder: title }), _jsxs(CommandList, { children: [_jsx(CommandEmpty, { children: "No results found." }), _jsx(CommandGroup, { children: options.map((option) => {
12
- const isSelected = selectedValues.has(option.value);
13
- return (_jsxs(CommandItem, { onSelect: () => {
14
- if (isSelected) {
15
- selectedValues.delete(option.value);
16
- }
17
- else {
18
- selectedValues.add(option.value);
19
- }
20
- const filterValues = Array.from(selectedValues);
21
- column?.setFilterValue(filterValues.length ? filterValues : undefined);
22
- }, children: [_jsx("div", { className: cn("mr-2 flex h-4 w-4 items-center justify-center rounded-sm border border-primary", isSelected
23
- ? "bg-primary text-primary-foreground"
24
- : "opacity-50 [&_svg]:invisible"), children: _jsx(CheckIcon, { className: cn("h-4 w-4") }) }), option.icon && (_jsx(option.icon, { className: "mr-2 h-4 w-4 text-muted-foreground" })), _jsx("span", { children: option.label })] }, option.value));
25
- }) }), selectedValues.size > 0 && (_jsxs(_Fragment, { children: [_jsx(CommandSeparator, {}), _jsx(CommandGroup, { children: _jsx(CommandItem, { onSelect: () => column?.setFilterValue(undefined), className: "justify-center text-center", children: "Clear filters" }) })] }))] })] }) })] }));
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/components/data-table/faceted-filter.tsx
21
+ var faceted_filter_exports = {};
22
+ __export(faceted_filter_exports, {
23
+ DataTableFacetedFilter: () => DataTableFacetedFilter
24
+ });
25
+ module.exports = __toCommonJS(faceted_filter_exports);
26
+ var import_react_icons = require("@radix-ui/react-icons");
27
+ var import_badge = require("../ui/badge.js");
28
+ var import_button = require("../ui/button.js");
29
+ var import_command = require("../ui/command.js");
30
+ var import_popover = require("../ui/popover.js");
31
+ var import_separator = require("../ui/separator.js");
32
+ var import_lucide_react = require("lucide-react");
33
+ var import_utils = require("../../lib/utils.js");
34
+ var import_jsx_runtime = require("react/jsx-runtime");
35
+ function DataTableFacetedFilter({
36
+ column,
37
+ title,
38
+ options
39
+ }) {
40
+ const facets = column?.getFacetedUniqueValues();
41
+ const selectedValues = new Set(column?.getFilterValue());
42
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_popover.Popover, { children: [
43
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_popover.PopoverTrigger, { asChild: true, children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_button.Button, { variant: "outline", size: "sm", className: "h-8 border", children: [
44
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_lucide_react.ListFilter, { className: "mr-2 h-4 w-4 text-gray-500" }),
45
+ title,
46
+ selectedValues.size > 0 && /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_jsx_runtime.Fragment, { children: [
47
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_separator.Separator, { orientation: "vertical", className: "mx-2 h-4" }),
48
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
49
+ import_badge.Badge,
50
+ {
51
+ variant: "secondary",
52
+ className: "rounded-sm px-1 font-normal lg:hidden",
53
+ children: selectedValues.size
54
+ }
55
+ ),
56
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: "hidden space-x-1 lg:flex", children: selectedValues.size > 2 ? /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
57
+ import_badge.Badge,
58
+ {
59
+ variant: "secondary",
60
+ className: "rounded-sm px-1 font-normal",
61
+ children: [
62
+ selectedValues.size,
63
+ " selected"
64
+ ]
65
+ }
66
+ ) : options.filter((option) => selectedValues.has(option.value)).map((option) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
67
+ import_badge.Badge,
68
+ {
69
+ variant: "secondary",
70
+ className: "rounded-sm px-1 font-normal",
71
+ children: option.label
72
+ },
73
+ option.value
74
+ )) })
75
+ ] })
76
+ ] }) }),
77
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_popover.PopoverContent, { className: "w-[200px] p-0", align: "start", children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_command.Command, { children: [
78
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_command.CommandInput, { placeholder: title }),
79
+ /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_command.CommandList, { children: [
80
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_command.CommandEmpty, { children: "No results found." }),
81
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_command.CommandGroup, { children: options.map((option) => {
82
+ const isSelected = selectedValues.has(option.value);
83
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
84
+ import_command.CommandItem,
85
+ {
86
+ onSelect: () => {
87
+ if (isSelected) {
88
+ selectedValues.delete(option.value);
89
+ } else {
90
+ selectedValues.add(option.value);
91
+ }
92
+ const filterValues = Array.from(selectedValues);
93
+ column?.setFilterValue(
94
+ filterValues.length ? filterValues : void 0
95
+ );
96
+ },
97
+ children: [
98
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
99
+ "div",
100
+ {
101
+ className: (0, import_utils.cn)(
102
+ "mr-2 flex h-4 w-4 items-center justify-center rounded-sm border border-primary",
103
+ isSelected ? "bg-primary text-primary-foreground" : "opacity-50 [&_svg]:invisible"
104
+ ),
105
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_icons.CheckIcon, { className: (0, import_utils.cn)("h-4 w-4") })
106
+ }
107
+ ),
108
+ option.icon && /* @__PURE__ */ (0, import_jsx_runtime.jsx)(option.icon, { className: "mr-2 h-4 w-4 text-muted-foreground" }),
109
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { children: option.label })
110
+ ]
111
+ },
112
+ option.value
113
+ );
114
+ }) }),
115
+ selectedValues.size > 0 && /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_jsx_runtime.Fragment, { children: [
116
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_command.CommandSeparator, {}),
117
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_command.CommandGroup, { children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
118
+ import_command.CommandItem,
119
+ {
120
+ onSelect: () => column?.setFilterValue(void 0),
121
+ className: "justify-center text-center",
122
+ children: "Clear filters"
123
+ }
124
+ ) })
125
+ ] })
126
+ ] })
127
+ ] }) })
128
+ ] });
26
129
  }
130
+ // Annotate the CommonJS export names for ESM import in node:
131
+ 0 && (module.exports = {
132
+ DataTableFacetedFilter
133
+ });
134
+ //# 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;AAAA;AAAA;AAAA;AAAA;AAAA,yBAA0B;AAC1B,mBAAsB;AACtB,oBAAuB;AACvB,qBAQO;AACP,qBAAwD;AACxD,uBAA0B;AAE1B,0BAA2B;AAE3B,mBAAmB;AAwBT;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,6CAAC,0BACC;AAAA,gDAAC,iCAAe,SAAO,MACrB,uDAAC,wBAAO,SAAQ,WAAU,MAAK,MAAK,WAAU,cAC5C;AAAA,kDAAC,kCAAW,WAAU,8BAA6B;AAAA,MAClD;AAAA,MACA,eAAe,OAAO,KACrB,4EACE;AAAA,oDAAC,8BAAU,aAAY,YAAW,WAAU,YAAW;AAAA,QACvD;AAAA,UAAC;AAAA;AAAA,YACC,SAAQ;AAAA,YACR,WAAU;AAAA,YAET,yBAAe;AAAA;AAAA,QAClB;AAAA,QACA,4CAAC,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,4CAAC,iCAAe,WAAU,iBAAgB,OAAM,SAC9C,uDAAC,0BACC;AAAA,kDAAC,+BAAa,aAAa,OAAO;AAAA,MAClC,6CAAC,8BACC;AAAA,oDAAC,+BAAa,+BAAiB;AAAA,QAC/B,4CAAC,+BACE,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,eAAW;AAAA,sBACT;AAAA,sBACA,aACI,uCACA;AAAA,oBACN;AAAA,oBAEA,sDAAC,gCAAU,eAAW,iBAAG,SAAS,GAAG;AAAA;AAAA,gBACvC;AAAA,gBACC,OAAO,QACN,4CAAC,OAAO,MAAP,EAAY,WAAU,sCAAqC;AAAA,gBAE9D,4CAAC,UAAM,iBAAO,OAAM;AAAA;AAAA;AAAA,YA1Bf,OAAO;AAAA,UA2Bd;AAAA,QAEJ,CAAC,GACH;AAAA,QACC,eAAe,OAAO,KACrB,4EACE;AAAA,sDAAC,mCAAiB;AAAA,UAClB,4CAAC,+BACC;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":[]}
@@ -1,9 +1,41 @@
1
- export * from "./cells";
2
- export * from "./column-header";
3
- export * from "./data-table";
4
- export * from "./faceted-filter";
5
- export * from "./pagination";
6
- export * from "./toolbar-items";
7
- export * from "./toolbar";
8
- export * from "./utils";
9
- export * from "./view-options";
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __copyProps = (to, from, except, desc) => {
7
+ if (from && typeof from === "object" || typeof from === "function") {
8
+ for (let key of __getOwnPropNames(from))
9
+ if (!__hasOwnProp.call(to, key) && key !== except)
10
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
11
+ }
12
+ return to;
13
+ };
14
+ var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
15
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
16
+
17
+ // src/components/data-table/index.tsx
18
+ var data_table_exports = {};
19
+ module.exports = __toCommonJS(data_table_exports);
20
+ __reExport(data_table_exports, require("./cells.js"), module.exports);
21
+ __reExport(data_table_exports, require("./column-header.js"), module.exports);
22
+ __reExport(data_table_exports, require("./data-table.js"), module.exports);
23
+ __reExport(data_table_exports, require("./faceted-filter.js"), module.exports);
24
+ __reExport(data_table_exports, require("./pagination.js"), module.exports);
25
+ __reExport(data_table_exports, require("./toolbar-items.js"), module.exports);
26
+ __reExport(data_table_exports, require("./toolbar.js"), module.exports);
27
+ __reExport(data_table_exports, require("./utils.js"), module.exports);
28
+ __reExport(data_table_exports, require("./view-options.js"), module.exports);
29
+ // Annotate the CommonJS export names for ESM import in node:
30
+ 0 && (module.exports = {
31
+ ...require("./cells.js"),
32
+ ...require("./column-header.js"),
33
+ ...require("./data-table.js"),
34
+ ...require("./faceted-filter.js"),
35
+ ...require("./pagination.js"),
36
+ ...require("./toolbar-items.js"),
37
+ ...require("./toolbar.js"),
38
+ ...require("./utils.js"),
39
+ ...require("./view-options.js")
40
+ });
41
+ //# sourceMappingURL=index.js.map