@stackframe/stack-ui 2.8.61 → 2.8.63
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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
|
@@ -1,98 +1,268 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
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
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
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
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
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
|
-
|
|
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
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
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
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
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
|