@stackframe/stack-ui 2.8.60 → 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.
- package/dist/components/action-dialog.js +130 -36
- package/dist/components/action-dialog.js.map +1 -0
- package/dist/components/brand-icons.js +413 -93
- package/dist/components/brand-icons.js.map +1 -0
- package/dist/components/browser-frame/index.js +63 -8
- package/dist/components/browser-frame/index.js.map +1 -0
- package/dist/components/copy-button.js +56 -17
- package/dist/components/copy-button.js.map +1 -0
- package/dist/components/copy-field.js +68 -12
- package/dist/components/copy-field.js.map +1 -0
- package/dist/components/data-table/cells.js +121 -50
- package/dist/components/data-table/cells.js.map +1 -0
- package/dist/components/data-table/column-header.js +62 -7
- package/dist/components/data-table/column-header.js.map +1 -0
- package/dist/components/data-table/data-table.js +263 -93
- package/dist/components/data-table/data-table.js.map +1 -0
- package/dist/components/data-table/faceted-filter.js +133 -25
- package/dist/components/data-table/faceted-filter.js.map +1 -0
- package/dist/components/data-table/index.js +41 -9
- package/dist/components/data-table/index.js.map +1 -0
- package/dist/components/data-table/pagination.js +89 -9
- package/dist/components/data-table/pagination.js.map +1 -0
- package/dist/components/data-table/toolbar-items.js +42 -4
- package/dist/components/data-table/toolbar-items.js.map +1 -0
- package/dist/components/data-table/toolbar.js +114 -44
- package/dist/components/data-table/toolbar.js.map +1 -0
- package/dist/components/data-table/utils.js +36 -4
- package/dist/components/data-table/utils.js.map +1 -0
- package/dist/components/data-table/view-options.js +70 -10
- package/dist/components/data-table/view-options.js.map +1 -0
- package/dist/components/simple-tooltip.js +45 -13
- package/dist/components/simple-tooltip.js.map +1 -0
- package/dist/components/ui/accordion.js +85 -10
- package/dist/components/ui/accordion.js.map +1 -0
- package/dist/components/ui/alert.js +75 -17
- package/dist/components/ui/alert.js.map +1 -0
- package/dist/components/ui/aspect-ratio.js +43 -3
- package/dist/components/ui/aspect-ratio.js.map +1 -0
- package/dist/components/ui/avatar.js +79 -8
- package/dist/components/ui/avatar.js.map +1 -0
- package/dist/components/ui/badge.js +51 -17
- package/dist/components/ui/badge.js.map +1 -0
- package/dist/components/ui/breadcrumb.js +118 -15
- package/dist/components/ui/breadcrumb.js.map +1 -0
- package/dist/components/ui/button.js +98 -39
- package/dist/components/ui/button.js.map +1 -0
- package/dist/components/ui/calendar.js +93 -39
- package/dist/components/ui/calendar.js.map +1 -0
- package/dist/components/ui/card.js +97 -11
- package/dist/components/ui/card.js.map +1 -0
- package/dist/components/ui/checkbox.js +64 -7
- package/dist/components/ui/checkbox.js.map +1 -0
- package/dist/components/ui/collapsible.js +49 -5
- package/dist/components/ui/collapsible.js.map +1 -0
- package/dist/components/ui/command.js +147 -25
- package/dist/components/ui/command.js.map +1 -0
- package/dist/components/ui/context-menu.js +196 -24
- package/dist/components/ui/context-menu.js.map +1 -0
- package/dist/components/ui/dialog.js +151 -17
- package/dist/components/ui/dialog.js.map +1 -0
- package/dist/components/ui/dropdown-menu.js +237 -55
- package/dist/components/ui/dropdown-menu.js.map +1 -0
- package/dist/components/ui/form.js +142 -53
- package/dist/components/ui/form.js.map +1 -0
- package/dist/components/ui/hover-card.js +64 -8
- package/dist/components/ui/hover-card.js.map +1 -0
- package/dist/components/ui/inline-code.js +62 -25
- package/dist/components/ui/inline-code.js.map +1 -0
- package/dist/components/ui/input-otp.js +87 -14
- package/dist/components/ui/input-otp.js.map +1 -0
- package/dist/components/ui/input.js +86 -22
- package/dist/components/ui/input.js.map +1 -0
- package/dist/components/ui/label.js +67 -9
- package/dist/components/ui/label.js.map +1 -0
- package/dist/components/ui/menubar.js +224 -24
- package/dist/components/ui/menubar.js.map +1 -0
- package/dist/components/ui/navigation-menu.js +149 -20
- package/dist/components/ui/navigation-menu.js.map +1 -0
- package/dist/components/ui/password-input.js +79 -11
- package/dist/components/ui/password-input.js.map +1 -0
- package/dist/components/ui/popover.js +67 -9
- package/dist/components/ui/popover.js.map +1 -0
- package/dist/components/ui/progress.js +63 -6
- package/dist/components/ui/progress.js.map +1 -0
- package/dist/components/ui/radio-group.js +70 -10
- package/dist/components/ui/radio-group.js.map +1 -0
- package/dist/components/ui/resizable.js +78 -8
- package/dist/components/ui/resizable.js.map +1 -0
- package/dist/components/ui/scroll-area.js +75 -9
- package/dist/components/ui/scroll-area.js.map +1 -0
- package/dist/components/ui/select.js +166 -20
- package/dist/components/ui/select.js.map +1 -0
- package/dist/components/ui/separator.js +61 -6
- package/dist/components/ui/separator.js.map +1 -0
- package/dist/components/ui/sheet.js +153 -27
- package/dist/components/ui/sheet.js.map +1 -0
- package/dist/components/ui/skeleton.js +46 -5
- package/dist/components/ui/skeleton.js.map +1 -0
- package/dist/components/ui/slider.js +60 -6
- package/dist/components/ui/slider.js.map +1 -0
- package/dist/components/ui/spinner.js +36 -6
- package/dist/components/ui/spinner.js.map +1 -0
- package/dist/components/ui/switch.js +92 -21
- package/dist/components/ui/switch.js.map +1 -0
- package/dist/components/ui/table.js +117 -12
- package/dist/components/ui/table.js.map +1 -0
- package/dist/components/ui/tabs.js +85 -9
- package/dist/components/ui/tabs.js.map +1 -0
- package/dist/components/ui/textarea.js +47 -6
- package/dist/components/ui/textarea.js.map +1 -0
- package/dist/components/ui/toast.js +135 -25
- package/dist/components/ui/toast.js.map +1 -0
- package/dist/components/ui/toaster.js +49 -8
- package/dist/components/ui/toaster.js.map +1 -0
- package/dist/components/ui/toggle-group.js +78 -17
- package/dist/components/ui/toggle-group.js.map +1 -0
- package/dist/components/ui/toggle.js +73 -21
- package/dist/components/ui/toggle.js.map +1 -0
- package/dist/components/ui/tooltip.js +72 -9
- package/dist/components/ui/tooltip.js.map +1 -0
- package/dist/components/ui/typography.js +69 -31
- package/dist/components/ui/typography.js.map +1 -0
- package/dist/components/ui/use-toast.js +151 -116
- package/dist/components/ui/use-toast.js.map +1 -0
- package/dist/esm/components/action-dialog.js +97 -0
- package/dist/esm/components/action-dialog.js.map +1 -0
- package/dist/esm/components/brand-icons.js +390 -0
- package/dist/esm/components/brand-icons.js.map +1 -0
- package/dist/esm/components/browser-frame/index.js +43 -0
- package/dist/esm/components/browser-frame/index.js.map +1 -0
- package/dist/esm/components/copy-button.js +35 -0
- package/dist/esm/components/copy-button.js.map +1 -0
- package/dist/esm/components/copy-field.js +44 -0
- package/dist/esm/components/copy-field.js.map +1 -0
- package/dist/esm/components/data-table/cells.js +88 -0
- package/dist/esm/components/data-table/cells.js.map +1 -0
- package/dist/esm/components/data-table/column-header.js +40 -0
- package/dist/esm/components/data-table/column-header.js.map +1 -0
- package/dist/esm/components/data-table/data-table.js +249 -0
- package/dist/esm/components/data-table/data-table.js.map +1 -0
- package/dist/esm/components/data-table/faceted-filter.js +117 -0
- package/dist/esm/components/data-table/faceted-filter.js.map +1 -0
- package/dist/esm/components/data-table/index.js +11 -0
- package/dist/esm/components/data-table/index.js.map +1 -0
- package/dist/esm/components/data-table/pagination.js +71 -0
- package/dist/esm/components/data-table/pagination.js.map +1 -0
- package/dist/esm/components/data-table/toolbar-items.js +18 -0
- package/dist/esm/components/data-table/toolbar-items.js.map +1 -0
- package/dist/esm/components/data-table/toolbar.js +92 -0
- package/dist/esm/components/data-table/toolbar.js.map +1 -0
- package/dist/esm/components/data-table/utils.js +12 -0
- package/dist/esm/components/data-table/utils.js.map +1 -0
- package/dist/esm/components/data-table/view-options.js +55 -0
- package/dist/esm/components/data-table/view-options.js.map +1 -0
- package/dist/esm/components/simple-tooltip.js +21 -0
- package/dist/esm/components/simple-tooltip.js.map +1 -0
- package/dist/esm/components/ui/accordion.js +52 -0
- package/dist/esm/components/ui/accordion.js.map +1 -0
- package/dist/esm/components/ui/alert.js +54 -0
- package/dist/esm/components/ui/alert.js.map +1 -0
- package/dist/esm/components/ui/aspect-ratio.js +10 -0
- package/dist/esm/components/ui/aspect-ratio.js.map +1 -0
- package/dist/esm/components/ui/avatar.js +47 -0
- package/dist/esm/components/ui/avatar.js.map +1 -0
- package/dist/esm/components/ui/badge.js +30 -0
- package/dist/esm/components/ui/badge.js.map +1 -0
- package/dist/esm/components/ui/breadcrumb.js +95 -0
- package/dist/esm/components/ui/breadcrumb.js.map +1 -0
- package/dist/esm/components/ui/button.js +79 -0
- package/dist/esm/components/ui/button.js.map +1 -0
- package/dist/esm/components/ui/calendar.js +72 -0
- package/dist/esm/components/ui/calendar.js.map +1 -0
- package/dist/esm/components/ui/card.js +72 -0
- package/dist/esm/components/ui/card.js.map +1 -0
- package/dist/esm/components/ui/checkbox.js +32 -0
- package/dist/esm/components/ui/checkbox.js.map +1 -0
- package/dist/esm/components/ui/collapsible.js +14 -0
- package/dist/esm/components/ui/collapsible.js.map +1 -0
- package/dist/esm/components/ui/command.js +119 -0
- package/dist/esm/components/ui/command.js.map +1 -0
- package/dist/esm/components/ui/context-menu.js +162 -0
- package/dist/esm/components/ui/context-menu.js.map +1 -0
- package/dist/esm/components/ui/dialog.js +114 -0
- package/dist/esm/components/ui/dialog.js.map +1 -0
- package/dist/esm/components/ui/dropdown-menu.js +200 -0
- package/dist/esm/components/ui/dropdown-menu.js.map +1 -0
- package/dist/esm/components/ui/form.js +118 -0
- package/dist/esm/components/ui/form.js.map +1 -0
- package/dist/esm/components/ui/hover-card.js +30 -0
- package/dist/esm/components/ui/hover-card.js.map +1 -0
- package/dist/esm/components/ui/inline-code.js +42 -0
- package/dist/esm/components/ui/inline-code.js.map +1 -0
- package/dist/esm/components/ui/input-otp.js +56 -0
- package/dist/esm/components/ui/input-otp.js.map +1 -0
- package/dist/esm/components/ui/input.js +57 -0
- package/dist/esm/components/ui/input.js.map +1 -0
- package/dist/esm/components/ui/label.js +35 -0
- package/dist/esm/components/ui/label.js.map +1 -0
- package/dist/esm/components/ui/menubar.js +192 -0
- package/dist/esm/components/ui/menubar.js.map +1 -0
- package/dist/esm/components/ui/navigation-menu.js +112 -0
- package/dist/esm/components/ui/navigation-menu.js.map +1 -0
- package/dist/esm/components/ui/password-input.js +58 -0
- package/dist/esm/components/ui/password-input.js.map +1 -0
- package/dist/esm/components/ui/popover.js +32 -0
- package/dist/esm/components/ui/popover.js.map +1 -0
- package/dist/esm/components/ui/progress.js +31 -0
- package/dist/esm/components/ui/progress.js.map +1 -0
- package/dist/esm/components/ui/radio-group.js +40 -0
- package/dist/esm/components/ui/radio-group.js.map +1 -0
- package/dist/esm/components/ui/resizable.js +43 -0
- package/dist/esm/components/ui/resizable.js.map +1 -0
- package/dist/esm/components/ui/scroll-area.js +43 -0
- package/dist/esm/components/ui/scroll-area.js.map +1 -0
- package/dist/esm/components/ui/select.js +135 -0
- package/dist/esm/components/ui/select.js.map +1 -0
- package/dist/esm/components/ui/separator.js +29 -0
- package/dist/esm/components/ui/separator.js.map +1 -0
- package/dist/esm/components/ui/sheet.js +120 -0
- package/dist/esm/components/ui/sheet.js.map +1 -0
- package/dist/esm/components/ui/skeleton.js +24 -0
- package/dist/esm/components/ui/skeleton.js.map +1 -0
- package/dist/esm/components/ui/slider.js +28 -0
- package/dist/esm/components/ui/slider.js.map +1 -0
- package/dist/esm/components/ui/spinner.js +13 -0
- package/dist/esm/components/ui/spinner.js.map +1 -0
- package/dist/esm/components/ui/switch.js +62 -0
- package/dist/esm/components/ui/switch.js.map +1 -0
- package/dist/esm/components/ui/table.js +93 -0
- package/dist/esm/components/ui/table.js.map +1 -0
- package/dist/esm/components/ui/tabs.js +52 -0
- package/dist/esm/components/ui/tabs.js.map +1 -0
- package/dist/esm/components/ui/textarea.js +24 -0
- package/dist/esm/components/ui/textarea.js.map +1 -0
- package/dist/esm/components/ui/toast.js +105 -0
- package/dist/esm/components/ui/toast.js.map +1 -0
- package/dist/esm/components/ui/toaster.js +34 -0
- package/dist/esm/components/ui/toaster.js.map +1 -0
- package/dist/esm/components/ui/toggle-group.js +48 -0
- package/dist/esm/components/ui/toggle-group.js.map +1 -0
- package/dist/esm/components/ui/toggle.js +43 -0
- package/dist/esm/components/ui/toggle.js.map +1 -0
- package/dist/esm/components/ui/tooltip.js +38 -0
- package/dist/esm/components/ui/tooltip.js.map +1 -0
- package/dist/esm/components/ui/typography.js +47 -0
- package/dist/esm/components/ui/typography.js.map +1 -0
- package/dist/esm/components/ui/use-toast.js +130 -0
- package/dist/esm/components/ui/use-toast.js.map +1 -0
- package/dist/esm/index.js +59 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/utils.js +10 -0
- package/dist/esm/lib/utils.js.map +1 -0
- package/dist/index.d.mts +967 -0
- package/dist/index.d.ts +967 -54
- package/dist/index.js +147 -53
- package/dist/index.js.map +1 -0
- package/dist/lib/utils.js +34 -4
- package/dist/lib/utils.js.map +1 -0
- package/package.json +10 -5
- package/dist/components/action-dialog.d.ts +0 -28
- package/dist/components/action-dialog.d.ts.map +0 -1
- package/dist/components/brand-icons.d.ts +0 -43
- package/dist/components/brand-icons.d.ts.map +0 -1
- package/dist/components/browser-frame/index.d.ts +0 -10
- package/dist/components/browser-frame/index.d.ts.map +0 -1
- package/dist/components/copy-button.d.ts +0 -17
- package/dist/components/copy-button.d.ts.map +0 -1
- package/dist/components/copy-field.d.ts +0 -13
- package/dist/components/copy-field.d.ts.map +0 -1
- package/dist/components/data-table/cells.d.ts +0 -31
- package/dist/components/data-table/cells.d.ts.map +0 -1
- package/dist/components/data-table/column-header.d.ts +0 -8
- package/dist/components/data-table/column-header.d.ts.map +0 -1
- package/dist/components/data-table/data-table.d.ts +0 -36
- package/dist/components/data-table/data-table.d.ts.map +0 -1
- package/dist/components/data-table/faceted-filter.d.ts +0 -16
- package/dist/components/data-table/faceted-filter.d.ts.map +0 -1
- package/dist/components/data-table/index.d.ts +0 -10
- package/dist/components/data-table/index.d.ts.map +0 -1
- package/dist/components/data-table/pagination.d.ts +0 -7
- package/dist/components/data-table/pagination.d.ts.map +0 -1
- package/dist/components/data-table/toolbar-items.d.ts +0 -8
- package/dist/components/data-table/toolbar-items.d.ts.map +0 -1
- package/dist/components/data-table/toolbar.d.ts +0 -12
- package/dist/components/data-table/toolbar.d.ts.map +0 -1
- package/dist/components/data-table/utils.d.ts +0 -3
- package/dist/components/data-table/utils.d.ts.map +0 -1
- package/dist/components/data-table/view-options.d.ts +0 -7
- package/dist/components/data-table/view-options.d.ts.map +0 -1
- package/dist/components/simple-tooltip.d.ts +0 -9
- package/dist/components/simple-tooltip.d.ts.map +0 -1
- package/dist/components/ui/accordion.d.ts +0 -14
- package/dist/components/ui/accordion.d.ts.map +0 -1
- package/dist/components/ui/alert.d.ts +0 -15
- package/dist/components/ui/alert.d.ts.map +0 -1
- package/dist/components/ui/aspect-ratio.d.ts +0 -4
- package/dist/components/ui/aspect-ratio.d.ts.map +0 -1
- package/dist/components/ui/avatar.d.ts +0 -13
- package/dist/components/ui/avatar.d.ts.map +0 -1
- package/dist/components/ui/badge.d.ts +0 -13
- package/dist/components/ui/badge.d.ts.map +0 -1
- package/dist/components/ui/breadcrumb.d.ts +0 -30
- package/dist/components/ui/breadcrumb.d.ts.map +0 -1
- package/dist/components/ui/button.d.ts +0 -28
- package/dist/components/ui/button.d.ts.map +0 -1
- package/dist/components/ui/calendar.d.ts +0 -9
- package/dist/components/ui/calendar.d.ts.map +0 -1
- package/dist/components/ui/card.d.ts +0 -23
- package/dist/components/ui/card.d.ts.map +0 -1
- package/dist/components/ui/checkbox.d.ts +0 -7
- package/dist/components/ui/checkbox.d.ts.map +0 -1
- package/dist/components/ui/collapsible.d.ts +0 -6
- package/dist/components/ui/collapsible.d.ts.map +0 -1
- package/dist/components/ui/command.d.ts +0 -18
- package/dist/components/ui/command.d.ts.map +0 -1
- package/dist/components/ui/context-menu.d.ts +0 -44
- package/dist/components/ui/context-menu.d.ts.map +0 -1
- package/dist/components/ui/dialog.d.ts +0 -34
- package/dist/components/ui/dialog.d.ts.map +0 -1
- package/dist/components/ui/dropdown-menu.d.ts +0 -47
- package/dist/components/ui/dropdown-menu.d.ts.map +0 -1
- package/dist/components/ui/form.d.ts +0 -34
- package/dist/components/ui/form.d.ts.map +0 -1
- package/dist/components/ui/hover-card.d.ts +0 -9
- package/dist/components/ui/hover-card.d.ts.map +0 -1
- package/dist/components/ui/inline-code.d.ts +0 -6
- package/dist/components/ui/inline-code.d.ts.map +0 -1
- package/dist/components/ui/input-otp.d.ts +0 -17
- package/dist/components/ui/input-otp.d.ts.map +0 -1
- package/dist/components/ui/input.d.ts +0 -20
- package/dist/components/ui/input.d.ts.map +0 -1
- package/dist/components/ui/label.d.ts +0 -11
- package/dist/components/ui/label.d.ts.map +0 -1
- package/dist/components/ui/menubar.d.ts +0 -31
- package/dist/components/ui/menubar.d.ts.map +0 -1
- package/dist/components/ui/navigation-menu.d.ts +0 -25
- package/dist/components/ui/navigation-menu.d.ts.map +0 -1
- package/dist/components/ui/password-input.d.ts +0 -7
- package/dist/components/ui/password-input.d.ts.map +0 -1
- package/dist/components/ui/popover.d.ts +0 -10
- package/dist/components/ui/popover.d.ts.map +0 -1
- package/dist/components/ui/progress.d.ts +0 -7
- package/dist/components/ui/progress.d.ts.map +0 -1
- package/dist/components/ui/radio-group.d.ts +0 -10
- package/dist/components/ui/radio-group.d.ts.map +0 -1
- package/dist/components/ui/resizable.d.ts +0 -37
- package/dist/components/ui/resizable.d.ts.map +0 -1
- package/dist/components/ui/scroll-area.d.ts +0 -10
- package/dist/components/ui/scroll-area.d.ts.map +0 -1
- package/dist/components/ui/select.d.ts +0 -30
- package/dist/components/ui/select.d.ts.map +0 -1
- package/dist/components/ui/separator.d.ts +0 -7
- package/dist/components/ui/separator.d.ts.map +0 -1
- package/dist/components/ui/sheet.d.ts +0 -33
- package/dist/components/ui/sheet.d.ts.map +0 -1
- package/dist/components/ui/skeleton.d.ts +0 -4
- package/dist/components/ui/skeleton.d.ts.map +0 -1
- package/dist/components/ui/slider.d.ts +0 -7
- package/dist/components/ui/slider.d.ts.map +0 -1
- package/dist/components/ui/spinner.d.ts +0 -7
- package/dist/components/ui/spinner.d.ts.map +0 -1
- package/dist/components/ui/switch.d.ts +0 -11
- package/dist/components/ui/switch.d.ts.map +0 -1
- package/dist/components/ui/table.d.ts +0 -27
- package/dist/components/ui/table.d.ts.map +0 -1
- package/dist/components/ui/tabs.d.ts +0 -14
- package/dist/components/ui/tabs.d.ts.map +0 -1
- package/dist/components/ui/textarea.d.ts +0 -7
- package/dist/components/ui/textarea.d.ts.map +0 -1
- package/dist/components/ui/toast.d.ts +0 -28
- package/dist/components/ui/toast.d.ts.map +0 -1
- package/dist/components/ui/toaster.d.ts +0 -2
- package/dist/components/ui/toaster.d.ts.map +0 -1
- package/dist/components/ui/toggle-group.d.ts +0 -17
- package/dist/components/ui/toggle-group.d.ts.map +0 -1
- package/dist/components/ui/toggle.d.ts +0 -15
- package/dist/components/ui/toggle.d.ts.map +0 -1
- package/dist/components/ui/tooltip.d.ts +0 -12
- package/dist/components/ui/tooltip.d.ts.map +0 -1
- package/dist/components/ui/typography.d.ts +0 -10
- package/dist/components/ui/typography.d.ts.map +0 -1
- package/dist/components/ui/use-toast.d.ts +0 -45
- package/dist/components/ui/use-toast.d.ts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/lib/utils.d.ts +0 -3
- 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":[]}
|